diff --git a/build.gradle b/build.gradle index b75c080270f..e7216affefa 100644 --- a/build.gradle +++ b/build.gradle @@ -64,8 +64,8 @@ configurations { allprojects { group = 'org.jetbrains.lets-plot' - version = "2.0.6-alpha1" - project.ext.js_artifact_version = "2.0.6.dev1" + version = "2.1.0-rc1" + project.ext.js_artifact_version = "2.1.0rc1" // see also: python-package/lets_plot/_version.py repositories { diff --git a/js-package/distr/lets-plot.js b/js-package/distr/lets-plot.js index 38094ccde5c..3dfcfc9d3f2 100644 --- a/js-package/distr/lets-plot.js +++ b/js-package/distr/lets-plot.js @@ -95,7 +95,7 @@ eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPAC \***************************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! kotlin-logging-jsLegacy */ \"./kotlin-dce-dev/kotlin-logging-jsLegacy.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$kotlin_logging_jsLegacy) {\n 'use strict';\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var last = Kotlin.kotlin.collections.last_2p1efm$;\n var get_lastIndex = Kotlin.kotlin.collections.get_lastIndex_55thoc$;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var plus = Kotlin.kotlin.collections.plus_qloxvw$;\n var equals = Kotlin.equals;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var JsMath = Math;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var joinToString = Kotlin.kotlin.collections.joinToString_fmv235$;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var substring = Kotlin.kotlin.text.substring_fc3b62$;\n var padStart = Kotlin.kotlin.text.padStart_vrc1nu$;\n var Map = Kotlin.kotlin.collections.Map;\n var throwCCE = Kotlin.throwCCE;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var Regex_init = Kotlin.kotlin.text.Regex_init_61zpoe$;\n var IllegalArgumentException_init_0 = Kotlin.kotlin.IllegalArgumentException_init;\n var ensureNotNull = Kotlin.ensureNotNull;\n var hashCode = Kotlin.hashCode;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init;\n var toInt = Kotlin.kotlin.text.toInt_pdl1vz$;\n var Comparable = Kotlin.kotlin.Comparable;\n var toString = Kotlin.toString;\n var L0 = Kotlin.Long.ZERO;\n var L1 = Kotlin.Long.ONE;\n var L1000 = Kotlin.Long.fromInt(1000);\n var L60 = Kotlin.Long.fromInt(60);\n var L24 = Kotlin.Long.fromInt(24);\n var L7 = Kotlin.Long.fromInt(7);\n var contains = Kotlin.kotlin.text.contains_li3zpu$;\n var NumberFormatException = Kotlin.kotlin.NumberFormatException;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var L_5 = Kotlin.Long.fromInt(-5);\n var L4 = Kotlin.Long.fromInt(4);\n var L3 = Kotlin.Long.fromInt(3);\n var L60000 = Kotlin.Long.fromInt(60000);\n var L3600000 = Kotlin.Long.fromInt(3600000);\n var L86400000 = Kotlin.Long.fromInt(86400000);\n var defineInlineFunction = Kotlin.defineInlineFunction;\n var wrapFunction = Kotlin.wrapFunction;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_bwtc7$;\n var IllegalStateException_init_0 = Kotlin.kotlin.IllegalStateException_init;\n var unboxChar = Kotlin.unboxChar;\n var toChar = Kotlin.toChar;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var asList = Kotlin.kotlin.collections.asList_us0mfu$;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var copyToArray = Kotlin.kotlin.collections.copyToArray;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var NullPointerException_init = Kotlin.kotlin.NullPointerException_init;\n var IllegalArgumentException = Kotlin.kotlin.IllegalArgumentException;\n var NoSuchElementException_init = Kotlin.kotlin.NoSuchElementException_init;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var IndexOutOfBoundsException = Kotlin.kotlin.IndexOutOfBoundsException;\n var toList = Kotlin.kotlin.collections.toList_7wnvza$;\n var count = Kotlin.kotlin.collections.count_7wnvza$;\n var Collection = Kotlin.kotlin.collections.Collection;\n var plus_0 = Kotlin.kotlin.collections.plus_q4559j$;\n var List = Kotlin.kotlin.collections.List;\n var last_0 = Kotlin.kotlin.collections.last_7wnvza$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var Comparator = Kotlin.kotlin.Comparator;\n var sortWith = Kotlin.kotlin.collections.sortWith_iwcb0m$;\n var toList_0 = Kotlin.kotlin.collections.toList_us0mfu$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var naturalOrder = Kotlin.kotlin.comparisons.naturalOrder_dahdeg$;\n var lastOrNull = Kotlin.kotlin.collections.lastOrNull_2p1efm$;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var abs = Kotlin.kotlin.math.abs_za3lpa$;\n var Unit = Kotlin.kotlin.Unit;\n var getCallableRef = Kotlin.getCallableRef;\n var map = Kotlin.kotlin.sequences.map_z5avom$;\n var numberToInt = Kotlin.numberToInt;\n var toMutableMap = Kotlin.kotlin.collections.toMutableMap_abgq59$;\n var throwUPAE = Kotlin.throwUPAE;\n var kotlin_js_internal_BooleanCompanionObject = Kotlin.kotlin.js.internal.BooleanCompanionObject;\n var first_0 = Kotlin.kotlin.collections.first_7wnvza$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var drop = Kotlin.kotlin.sequences.drop_wuwhe2$;\n var isWhitespace = Kotlin.kotlin.text.isWhitespace_myv2d0$;\n var toBoxedChar = Kotlin.toBoxedChar;\n var contains_0 = Kotlin.kotlin.collections.contains_o2f9me$;\n var CharRange = Kotlin.kotlin.ranges.CharRange;\n var iterator = Kotlin.kotlin.text.iterator_gw00vp$;\n var toDouble = Kotlin.kotlin.text.toDouble_pdl1vz$;\n var Exception_init = Kotlin.kotlin.Exception_init_pdl1vj$;\n var Exception = Kotlin.kotlin.Exception;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var MutableMap = Kotlin.kotlin.collections.MutableMap;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var StringBuilder = Kotlin.kotlin.text.StringBuilder;\n var toString_0 = Kotlin.kotlin.text.toString_dqglrj$;\n var toInt_0 = Kotlin.kotlin.text.toInt_6ic1pp$;\n var numberToDouble = Kotlin.numberToDouble;\n var equals_0 = Kotlin.kotlin.text.equals_igcy3c$;\n var NoSuchElementException_init_0 = Kotlin.kotlin.NoSuchElementException;\n var Any = Object;\n var AbstractMutableSet = Kotlin.kotlin.collections.AbstractMutableSet;\n var AbstractCollection = Kotlin.kotlin.collections.AbstractCollection;\n var AbstractSet = Kotlin.kotlin.collections.AbstractSet;\n var MutableIterator = Kotlin.kotlin.collections.MutableIterator;\n var Array_0 = Array;\n var println = Kotlin.kotlin.io.println_s8jyv4$;\n var math = Kotlin.kotlin.math;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var toLong = Kotlin.kotlin.text.toLong_pdl1vz$;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var toIntOrNull = Kotlin.kotlin.text.toIntOrNull_pdl1vz$;\n var repeat = Kotlin.kotlin.text.repeat_94bcnn$;\n var trimEnd = Kotlin.kotlin.text.trimEnd_wqw3xr$;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var slice = Kotlin.kotlin.text.slice_fc3b62$;\n var startsWith = Kotlin.kotlin.text.startsWith_sgbm27$;\n var roundToLong = Kotlin.kotlin.math.roundToLong_yrwdxr$;\n var toString_1 = Kotlin.kotlin.text.toString_if0zpk$;\n var padEnd = Kotlin.kotlin.text.padEnd_vrc1nu$;\n var get_sign = Kotlin.kotlin.math.get_sign_s8ev3n$;\n var coerceAtLeast_0 = Kotlin.kotlin.ranges.coerceAtLeast_38ydlf$;\n var coerceAtMost = Kotlin.kotlin.ranges.coerceAtMost_38ydlf$;\n var asSequence_0 = Kotlin.kotlin.text.asSequence_gw00vp$;\n var plus_1 = Kotlin.kotlin.sequences.plus_v0iwhp$;\n var indexOf = Kotlin.kotlin.text.indexOf_l5u8uk$;\n var chunked = Kotlin.kotlin.sequences.chunked_wuwhe2$;\n var joinToString_0 = Kotlin.kotlin.sequences.joinToString_853xkz$;\n var reversed_0 = Kotlin.kotlin.text.reversed_gw00vp$;\n var MutableCollection = Kotlin.kotlin.collections.MutableCollection;\n var AbstractMutableList = Kotlin.kotlin.collections.AbstractMutableList;\n var MutableList = Kotlin.kotlin.collections.MutableList;\n var Throwable = Error;\n var plus_2 = Kotlin.kotlin.collections.plus_mydzjv$;\n var Random = Kotlin.kotlin.random.Random;\n var random = Kotlin.kotlin.collections.random_iscd7z$;\n var arrayListOf = Kotlin.kotlin.collections.arrayListOf_i5x0yv$;\n var minOrNull = Kotlin.kotlin.sequences.minOrNull_1bslqu$;\n var maxOrNull = Kotlin.kotlin.sequences.maxOrNull_1bslqu$;\n var flatten = Kotlin.kotlin.sequences.flatten_d9bjs1$;\n var first_1 = Kotlin.kotlin.sequences.first_veqyi0$;\n var Pair = Kotlin.kotlin.Pair;\n var sortedWith = Kotlin.kotlin.sequences.sortedWith_vjgqpk$;\n var filter = Kotlin.kotlin.sequences.filter_euau3h$;\n var toList_1 = Kotlin.kotlin.sequences.toList_veqyi0$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_mh5how$;\n var single = Kotlin.kotlin.collections.single_2p1efm$;\n var replace = Kotlin.kotlin.text.replace_680rmw$;\n var StringBuilder_init_0 = Kotlin.kotlin.text.StringBuilder_init_za3lpa$;\n var toDoubleOrNull = Kotlin.kotlin.text.toDoubleOrNull_pdl1vz$;\n var AbstractList = Kotlin.kotlin.collections.AbstractList;\n var asIterable = Kotlin.kotlin.sequences.asIterable_veqyi0$;\n var Set = Kotlin.kotlin.collections.Set;\n var UnsupportedOperationException_init = Kotlin.kotlin.UnsupportedOperationException_init;\n var UnsupportedOperationException_init_0 = Kotlin.kotlin.UnsupportedOperationException_init_pdl1vj$;\n var startsWith_0 = Kotlin.kotlin.text.startsWith_7epoxm$;\n var roundToInt = Kotlin.kotlin.math.roundToInt_yrwdxr$;\n var indexOf_0 = Kotlin.kotlin.text.indexOf_8eortd$;\n var plus_3 = Kotlin.kotlin.collections.plus_iwxh38$;\n var replace_0 = Kotlin.kotlin.text.replace_r2fvfm$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var mu = $module$kotlin_logging_jsLegacy.mu;\n Format$PatternSpecPart.prototype = Object.create(Format$SpecPart.prototype);\n Format$PatternSpecPart.prototype.constructor = Format$PatternSpecPart;\n Pattern$Companion$Kind.prototype = Object.create(Enum.prototype);\n Pattern$Companion$Kind.prototype.constructor = Pattern$Companion$Kind;\n Pattern.prototype = Object.create(Enum.prototype);\n Pattern.prototype.constructor = Pattern;\n Month$VarLengthMonth.prototype = Object.create(Month.prototype);\n Month$VarLengthMonth.prototype.constructor = Month$VarLengthMonth;\n WeekDay.prototype = Object.create(Enum.prototype);\n WeekDay.prototype.constructor = WeekDay;\n TimeZoneMoscow.prototype = Object.create(TimeZone.prototype);\n TimeZoneMoscow.prototype.constructor = TimeZoneMoscow;\n TimeZones$utc$ObjectLiteral.prototype = Object.create(TimeZone.prototype);\n TimeZones$utc$ObjectLiteral.prototype.constructor = TimeZones$utc$ObjectLiteral;\n TimeZones$offset$ObjectLiteral.prototype = Object.create(TimeZone.prototype);\n TimeZones$offset$ObjectLiteral.prototype.constructor = TimeZones$offset$ObjectLiteral;\n TimeZones$DSTimeZone.prototype = Object.create(TimeZone.prototype);\n TimeZones$DSTimeZone.prototype.constructor = TimeZones$DSTimeZone;\n TimeZones$withEuSummerTime$ObjectLiteral.prototype = Object.create(TimeZones$DSTimeZone.prototype);\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.constructor = TimeZones$withEuSummerTime$ObjectLiteral;\n TimeZones$withUsSummerTime$ObjectLiteral.prototype = Object.create(TimeZones$DSTimeZone.prototype);\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.constructor = TimeZones$withUsSummerTime$ObjectLiteral;\n Button.prototype = Object.create(Enum.prototype);\n Button.prototype.constructor = Button;\n Key.prototype = Object.create(Enum.prototype);\n Key.prototype.constructor = Key;\n KeyEvent.prototype = Object.create(Event.prototype);\n KeyEvent.prototype.constructor = KeyEvent;\n ModifierKey.prototype = Object.create(Enum.prototype);\n ModifierKey.prototype.constructor = ModifierKey;\n PointEvent.prototype = Object.create(Event.prototype);\n PointEvent.prototype.constructor = PointEvent;\n MouseEvent.prototype = Object.create(PointEvent.prototype);\n MouseEvent.prototype.constructor = MouseEvent;\n MouseEventSpec.prototype = Object.create(Enum.prototype);\n MouseEventSpec.prototype.constructor = MouseEventSpec;\n ComparatorOrdering.prototype = Object.create(Ordering.prototype);\n ComparatorOrdering.prototype.constructor = ComparatorOrdering;\n FluentArray.prototype = Object.create(FluentValue.prototype);\n FluentArray.prototype.constructor = FluentArray;\n FluentObject.prototype = Object.create(FluentValue.prototype);\n FluentObject.prototype.constructor = FluentObject;\n FluentPrimitive.prototype = Object.create(FluentValue.prototype);\n FluentPrimitive.prototype.constructor = FluentPrimitive;\n JsonParser$JsonException.prototype = Object.create(Exception.prototype);\n JsonParser$JsonException.prototype.constructor = JsonParser$JsonException;\n Token.prototype = Object.create(Enum.prototype);\n Token.prototype.constructor = Token;\n ListMap$keySet$ObjectLiteral.prototype = Object.create(AbstractMutableSet.prototype);\n ListMap$keySet$ObjectLiteral.prototype.constructor = ListMap$keySet$ObjectLiteral;\n ListMap$values$ObjectLiteral.prototype = Object.create(AbstractCollection.prototype);\n ListMap$values$ObjectLiteral.prototype.constructor = ListMap$values$ObjectLiteral;\n ListMap$entrySet$ObjectLiteral.prototype = Object.create(AbstractSet.prototype);\n ListMap$entrySet$ObjectLiteral.prototype.constructor = ListMap$entrySet$ObjectLiteral;\n ChildList_init$ObjectLiteral.prototype = Object.create(CollectionAdapter.prototype);\n ChildList_init$ObjectLiteral.prototype.constructor = ChildList_init$ObjectLiteral;\n AbstractObservableList.prototype = Object.create(AbstractMutableList.prototype);\n AbstractObservableList.prototype.constructor = AbstractObservableList;\n ObservableArrayList.prototype = Object.create(AbstractObservableList.prototype);\n ObservableArrayList.prototype.constructor = ObservableArrayList;\n ChildList.prototype = Object.create(ObservableArrayList.prototype);\n ChildList.prototype.constructor = ChildList;\n ValueProperty.prototype = Object.create(BaseReadableProperty.prototype);\n ValueProperty.prototype.constructor = ValueProperty;\n ChildProperty.prototype = Object.create(ValueProperty.prototype);\n ChildProperty.prototype.constructor = ChildProperty;\n CollectionItemEvent$EventType.prototype = Object.create(Enum.prototype);\n CollectionItemEvent$EventType.prototype.constructor = CollectionItemEvent$EventType;\n AbstractObservableList$addListener$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n AbstractObservableList$addListener$ObjectLiteral.prototype.constructor = AbstractObservableList$addListener$ObjectLiteral;\n CompositeEventSource$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n CompositeEventSource$addHandler$ObjectLiteral.prototype.constructor = CompositeEventSource$addHandler$ObjectLiteral;\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype = Object.create(CollectionAdapter.prototype);\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.constructor = EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral;\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype.constructor = EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0;\n Listeners$add$ObjectLiteral.prototype = Object.create(Registration.prototype);\n Listeners$add$ObjectLiteral.prototype.constructor = Listeners$add$ObjectLiteral;\n DelayedValueProperty$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n DelayedValueProperty$addHandler$ObjectLiteral.prototype.constructor = DelayedValueProperty$addHandler$ObjectLiteral;\n DelayedValueProperty.prototype = Object.create(BaseReadableProperty.prototype);\n DelayedValueProperty.prototype.constructor = DelayedValueProperty;\n ValueProperty$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n ValueProperty$addHandler$ObjectLiteral.prototype.constructor = ValueProperty$addHandler$ObjectLiteral;\n CompositeRegistration.prototype = Object.create(Registration.prototype);\n CompositeRegistration.prototype.constructor = CompositeRegistration;\n Registration$EmptyRegistration.prototype = Object.create(Registration.prototype);\n Registration$EmptyRegistration.prototype.constructor = Registration$EmptyRegistration;\n Registration$Companion$from$ObjectLiteral.prototype = Object.create(Registration.prototype);\n Registration$Companion$from$ObjectLiteral.prototype.constructor = Registration$Companion$from$ObjectLiteral;\n Registration$Companion$from$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n Registration$Companion$from$ObjectLiteral_0.prototype.constructor = Registration$Companion$from$ObjectLiteral_0;\n SimpleFeature$GeometryType.prototype = Object.create(Enum.prototype);\n SimpleFeature$GeometryType.prototype.constructor = SimpleFeature$GeometryType;\n StringFormat$FormatType.prototype = Object.create(Enum.prototype);\n StringFormat$FormatType.prototype.constructor = StringFormat$FormatType;\n AbstractGeometryList.prototype = Object.create(AbstractList.prototype);\n AbstractGeometryList.prototype.constructor = AbstractGeometryList;\n GeometryType.prototype = Object.create(Enum.prototype);\n GeometryType.prototype.constructor = GeometryType;\n LineString.prototype = Object.create(AbstractGeometryList.prototype);\n LineString.prototype.constructor = LineString;\n MultiLineString.prototype = Object.create(AbstractGeometryList.prototype);\n MultiLineString.prototype.constructor = MultiLineString;\n MultiPoint.prototype = Object.create(AbstractGeometryList.prototype);\n MultiPoint.prototype.constructor = MultiPoint;\n MultiPolygon.prototype = Object.create(AbstractGeometryList.prototype);\n MultiPolygon.prototype.constructor = MultiPolygon;\n Polygon.prototype = Object.create(AbstractGeometryList.prototype);\n Polygon.prototype.constructor = Polygon;\n Ring.prototype = Object.create(AbstractGeometryList.prototype);\n Ring.prototype.constructor = Ring;\n function splitRings(points) {\n var $receiver = findRingIntervals(points);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(sublist(points, item));\n }\n var rings = toMutableList(destination);\n if (!rings.isEmpty()) {\n if (!isClosed(last(rings))) {\n rings.set_wxm5ur$(get_lastIndex(rings), makeClosed(last(rings)));\n }}return rings;\n }\n function makeClosed(path) {\n return plus(toMutableList(path), first(path));\n }\n function isClosed($receiver) {\n return equals(first($receiver), last($receiver));\n }\n function findRingIntervals(path) {\n var intervals = ArrayList_init();\n var startIndex = 0;\n var i = 0;\n var n = path.size;\n while (i < n) {\n if (startIndex !== i && equals(path.get_za3lpa$(startIndex), path.get_za3lpa$(i))) {\n intervals.add_11rb$(new ClosedRange(startIndex, i + 1 | 0));\n startIndex = i + 1 | 0;\n }i = i + 1 | 0;\n }\n if (startIndex !== path.size) {\n intervals.add_11rb$(new ClosedRange(startIndex, path.size));\n }return intervals;\n }\n function sublist($receiver, range) {\n return $receiver.subList_vux9f0$(range.lowerEnd, range.upperEnd);\n }\n function calculateArea(ring) {\n return calculateArea_0(ring, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }));\n }\n function isClockwise(ring, x, y) {\n var tmp$;\n if (!!ring.isEmpty()) {\n var message = \"Ring shouldn't be empty to calculate clockwise\";\n throw IllegalStateException_init(message.toString());\n }var sum = 0.0;\n var prev = ring.get_za3lpa$(ring.size - 1 | 0);\n tmp$ = ring.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n sum += x(prev) * y(point) - x(point) * y(prev);\n prev = point;\n }\n return sum < 0.0;\n }\n function calculateArea_0(ring, x, y) {\n var area = 0.0;\n var j = ring.size - 1 | 0;\n for (var i = 0; i !== ring.size; ++i) {\n var p1 = ring.get_za3lpa$(i);\n var p2 = ring.get_za3lpa$(j);\n area += (x(p2) + x(p1)) * (y(p2) - y(p1));\n j = i;\n }\n var x_0 = area / 2;\n return JsMath.abs(x_0);\n }\n function DateLocale() {\n DateLocale_instance = this;\n this.weekDayAbbr = mapOf([to(WeekDay$MONDAY_getInstance(), 'Mon'), to(WeekDay$TUESDAY_getInstance(), 'Tue'), to(WeekDay$WEDNESDAY_getInstance(), 'Wed'), to(WeekDay$THURSDAY_getInstance(), 'Thu'), to(WeekDay$FRIDAY_getInstance(), 'Fri'), to(WeekDay$SATURDAY_getInstance(), 'Sat'), to(WeekDay$SUNDAY_getInstance(), 'Sun')]);\n this.weekDayFull = mapOf([to(WeekDay$MONDAY_getInstance(), 'Monday'), to(WeekDay$TUESDAY_getInstance(), 'Tuesday'), to(WeekDay$WEDNESDAY_getInstance(), 'Wednesday'), to(WeekDay$THURSDAY_getInstance(), 'Thursday'), to(WeekDay$FRIDAY_getInstance(), 'Friday'), to(WeekDay$SATURDAY_getInstance(), 'Saturday'), to(WeekDay$SUNDAY_getInstance(), 'Sunday')]);\n this.monthAbbr = mapOf([to(Month$Companion_getInstance().JANUARY, 'Jan'), to(Month$Companion_getInstance().FEBRUARY, 'Feb'), to(Month$Companion_getInstance().MARCH, 'Mar'), to(Month$Companion_getInstance().APRIL, 'Apr'), to(Month$Companion_getInstance().MAY, 'May'), to(Month$Companion_getInstance().JUNE, 'Jun'), to(Month$Companion_getInstance().JULY, 'Jul'), to(Month$Companion_getInstance().AUGUST, 'Aug'), to(Month$Companion_getInstance().SEPTEMBER, 'Sep'), to(Month$Companion_getInstance().OCTOBER, 'Oct'), to(Month$Companion_getInstance().NOVEMBER, 'Nov'), to(Month$Companion_getInstance().DECEMBER, 'Dec')]);\n this.monthFull = mapOf([to(Month$Companion_getInstance().JANUARY, 'January'), to(Month$Companion_getInstance().FEBRUARY, 'February'), to(Month$Companion_getInstance().MARCH, 'March'), to(Month$Companion_getInstance().APRIL, 'April'), to(Month$Companion_getInstance().MAY, 'May'), to(Month$Companion_getInstance().JUNE, 'June'), to(Month$Companion_getInstance().JULY, 'July'), to(Month$Companion_getInstance().AUGUST, 'August'), to(Month$Companion_getInstance().SEPTEMBER, 'September'), to(Month$Companion_getInstance().OCTOBER, 'October'), to(Month$Companion_getInstance().NOVEMBER, 'November'), to(Month$Companion_getInstance().DECEMBER, 'December')]);\n }\n DateLocale.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateLocale',\n interfaces: []\n };\n var DateLocale_instance = null;\n function DateLocale_getInstance() {\n if (DateLocale_instance === null) {\n new DateLocale();\n }return DateLocale_instance;\n }\n function Format(spec) {\n Format$Companion_getInstance();\n this.spec_0 = spec;\n }\n function Format$SpecPart(str) {\n this.str = str;\n }\n Format$SpecPart.prototype.exec_amwj4p$ = function (dateTime) {\n return this.str;\n };\n Format$SpecPart.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SpecPart',\n interfaces: []\n };\n function Format$PatternSpecPart(str) {\n Format$SpecPart.call(this, str);\n var tmp$;\n tmp$ = Pattern$Companion_getInstance().patternByString_61zpoe$(str);\n if (tmp$ == null) {\n throw IllegalArgumentException_init('Wrong pattern: ' + str);\n }this.pattern = tmp$;\n }\n Format$PatternSpecPart.prototype.exec_amwj4p$ = function (dateTime) {\n return Format$Companion_getInstance().getValueForPattern_0(this.pattern, dateTime);\n };\n Format$PatternSpecPart.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PatternSpecPart',\n interfaces: [Format$SpecPart]\n };\n function Format$apply$lambda(closure$dateTime) {\n return function (it) {\n return it.exec_amwj4p$(closure$dateTime);\n };\n }\n Format.prototype.apply_amwj4p$ = function (dateTime) {\n return joinToString(this.spec_0, '', void 0, void 0, void 0, void 0, Format$apply$lambda(dateTime));\n };\n function Format$apply$lambda_0(closure$date) {\n return function (it) {\n return it.exec_amwj4p$(new DateTime(closure$date));\n };\n }\n Format.prototype.apply_z9gqti$ = function (date) {\n var $receiver = this.spec_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var predicate$result;\n if (Kotlin.isType(element, Format$PatternSpecPart) && element.pattern.kind === Pattern$Companion$Kind$DATE_getInstance()) {\n predicate$result = true;\n } else if (!Kotlin.isType(element, Format$PatternSpecPart)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination.add_11rb$(element);\n }\n return joinToString(destination, '', void 0, void 0, void 0, void 0, Format$apply$lambda_0(date));\n };\n function Format$apply$lambda_1(closure$time) {\n return function (it) {\n return it.exec_amwj4p$(new DateTime(Date$Companion_getInstance().EPOCH, closure$time));\n };\n }\n Format.prototype.apply_z96d9j$ = function (time) {\n var $receiver = this.spec_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var predicate$result;\n if (Kotlin.isType(element, Format$PatternSpecPart) && element.pattern.kind === Pattern$Companion$Kind$TIME_getInstance()) {\n predicate$result = true;\n } else if (!Kotlin.isType(element, Format$PatternSpecPart)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination.add_11rb$(element);\n }\n return joinToString(destination, '', void 0, void 0, void 0, void 0, Format$apply$lambda_1(time));\n };\n function Format$Companion() {\n Format$Companion_instance = this;\n }\n Format$Companion.prototype.parse_61zpoe$ = function (str) {\n var result = ArrayList_init();\n var resultSequence = Pattern$Companion_getInstance().PATTERN_REGEX.findAll_905azu$(str);\n var lastIndex = {v: 0};\n var tmp$;\n tmp$ = resultSequence.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var value = element.value;\n var range = element.range;\n var startIndex = range.first;\n var endIndex = range.last;\n if (startIndex > 0) {\n var spec = new Format$SpecPart(substring(str, until(lastIndex.v, startIndex)));\n result.add_11rb$(spec);\n }result.add_11rb$(new Format$PatternSpecPart(value));\n lastIndex.v = endIndex + 1 | 0;\n }\n if (lastIndex.v < str.length) {\n var startIndex_0 = lastIndex.v;\n result.add_11rb$(new Format$SpecPart(str.substring(startIndex_0)));\n }return result;\n };\n Format$Companion.prototype.getValueForPattern_0 = function (type, dateTime) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n switch (type.name) {\n case 'SECOND':\n return this.leadZero_0(dateTime.seconds);\n case 'MINUTE':\n return this.leadZero_0(dateTime.minutes);\n case 'HOUR_12':\n return this.getHours12_0(dateTime).toString();\n case 'HOUR_12_LEADING_ZERO':\n return this.leadZero_0(this.getHours12_0(dateTime));\n case 'HOUR_24':\n return this.leadZero_0(this.getHours24_0(dateTime));\n case 'MERIDIAN_LOWER':\n return this.getMeridian_0(dateTime);\n case 'MERIDIAN_UPPER':\n return this.getMeridian_0(dateTime).toUpperCase();\n case 'DAY_OF_WEEK':\n return this.getWeekDayNumber_0(dateTime);\n case 'DAY_OF_WEEK_ABBR':\n return (tmp$ = DateLocale_getInstance().weekDayAbbr.get_11rb$(dateTime.weekDay)) != null ? tmp$ : '';\n case 'DAY_OF_WEEK_FULL':\n return (tmp$_0 = DateLocale_getInstance().weekDayFull.get_11rb$(dateTime.weekDay)) != null ? tmp$_0 : '';\n case 'DAY_OF_MONTH':\n return dateTime.day.toString();\n case 'DAY_OF_MONTH_LEADING_ZERO':\n return this.leadZero_0(dateTime.day);\n case 'DAY_OF_THE_YEAR':\n return this.leadZero_0(dateTime.date.daysFromYearStart(), 3);\n case 'MONTH':\n return this.leadZero_0(((tmp$_2 = (tmp$_1 = dateTime.month) != null ? tmp$_1.ordinal() : null) != null ? tmp$_2 : 0) + 1 | 0);\n case 'MONTH_ABBR':\n var $receiver = DateLocale_getInstance().monthAbbr;\n var key = dateTime.month;\n var tmp$_5;\n return (tmp$_3 = (Kotlin.isType(tmp$_5 = $receiver, Map) ? tmp$_5 : throwCCE()).get_11rb$(key)) != null ? tmp$_3 : '';\n case 'MONTH_FULL':\n var $receiver_0 = DateLocale_getInstance().monthFull;\n var key_0 = dateTime.month;\n var tmp$_6;\n return (tmp$_4 = (Kotlin.isType(tmp$_6 = $receiver_0, Map) ? tmp$_6 : throwCCE()).get_11rb$(key_0)) != null ? tmp$_4 : '';\n case 'YEAR_SHORT':\n return dateTime.year.toString().substring(2);\n case 'YEAR_FULL':\n return dateTime.year.toString();\n default:return Kotlin.noWhenBranchMatched();\n }\n };\n Format$Companion.prototype.leadZero_0 = function (value, length) {\n if (length === void 0)\n length = 2;\n return padStart(value.toString(), length, 48);\n };\n Format$Companion.prototype.getHours12_0 = function (dateTime) {\n var tmp$;\n var hours = dateTime.hours;\n if (hours === 0)\n tmp$ = 12;\n else if (hours <= 12)\n tmp$ = hours;\n else\n tmp$ = hours - 12 | 0;\n return tmp$;\n };\n Format$Companion.prototype.getHours24_0 = function (dateTime) {\n if (dateTime.hours === 0)\n return 24;\n else\n return dateTime.hours;\n };\n Format$Companion.prototype.getMeridian_0 = function (dateTime) {\n var tmp$;\n var hours = dateTime.hours;\n if (hours === 24)\n tmp$ = 'am';\n else if (hours <= 12)\n tmp$ = 'am';\n else\n tmp$ = 'pm';\n return tmp$;\n };\n Format$Companion.prototype.getWeekDayNumber_0 = function (dateTime) {\n var num = dateTime.weekDay.ordinal + 1 | 0;\n if (num === 7) {\n num = 0;\n }return num.toString();\n };\n Format$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Format$Companion_instance = null;\n function Format$Companion_getInstance() {\n if (Format$Companion_instance === null) {\n new Format$Companion();\n }return Format$Companion_instance;\n }\n Format.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Format',\n interfaces: []\n };\n function Format_init(spec, $this) {\n $this = $this || Object.create(Format.prototype);\n Format.call($this, Format$Companion_getInstance().parse_61zpoe$(spec));\n return $this;\n }\n function Pattern(name, ordinal, string, kind) {\n Enum.call(this);\n this.string = string;\n this.kind = kind;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Pattern_initFields() {\n Pattern_initFields = function () {\n };\n Pattern$DAY_OF_WEEK_ABBR_instance = new Pattern('DAY_OF_WEEK_ABBR', 0, '%a', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_WEEK_FULL_instance = new Pattern('DAY_OF_WEEK_FULL', 1, '%A', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_ABBR_instance = new Pattern('MONTH_ABBR', 2, '%b', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_FULL_instance = new Pattern('MONTH_FULL', 3, '%B', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_MONTH_LEADING_ZERO_instance = new Pattern('DAY_OF_MONTH_LEADING_ZERO', 4, '%d', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_MONTH_instance = new Pattern('DAY_OF_MONTH', 5, '%e', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_THE_YEAR_instance = new Pattern('DAY_OF_THE_YEAR', 6, '%j', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_instance = new Pattern('MONTH', 7, '%m', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_WEEK_instance = new Pattern('DAY_OF_WEEK', 8, '%w', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$YEAR_SHORT_instance = new Pattern('YEAR_SHORT', 9, '%y', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$YEAR_FULL_instance = new Pattern('YEAR_FULL', 10, '%Y', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$HOUR_24_instance = new Pattern('HOUR_24', 11, '%H', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$HOUR_12_LEADING_ZERO_instance = new Pattern('HOUR_12_LEADING_ZERO', 12, '%I', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$HOUR_12_instance = new Pattern('HOUR_12', 13, '%l', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MINUTE_instance = new Pattern('MINUTE', 14, '%M', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MERIDIAN_LOWER_instance = new Pattern('MERIDIAN_LOWER', 15, '%P', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MERIDIAN_UPPER_instance = new Pattern('MERIDIAN_UPPER', 16, '%p', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$SECOND_instance = new Pattern('SECOND', 17, '%S', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$Companion_getInstance();\n }\n var Pattern$DAY_OF_WEEK_ABBR_instance;\n function Pattern$DAY_OF_WEEK_ABBR_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_ABBR_instance;\n }\n var Pattern$DAY_OF_WEEK_FULL_instance;\n function Pattern$DAY_OF_WEEK_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_FULL_instance;\n }\n var Pattern$MONTH_ABBR_instance;\n function Pattern$MONTH_ABBR_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_ABBR_instance;\n }\n var Pattern$MONTH_FULL_instance;\n function Pattern$MONTH_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_FULL_instance;\n }\n var Pattern$DAY_OF_MONTH_LEADING_ZERO_instance;\n function Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_MONTH_LEADING_ZERO_instance;\n }\n var Pattern$DAY_OF_MONTH_instance;\n function Pattern$DAY_OF_MONTH_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_MONTH_instance;\n }\n var Pattern$DAY_OF_THE_YEAR_instance;\n function Pattern$DAY_OF_THE_YEAR_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_THE_YEAR_instance;\n }\n var Pattern$MONTH_instance;\n function Pattern$MONTH_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_instance;\n }\n var Pattern$DAY_OF_WEEK_instance;\n function Pattern$DAY_OF_WEEK_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_instance;\n }\n var Pattern$YEAR_SHORT_instance;\n function Pattern$YEAR_SHORT_getInstance() {\n Pattern_initFields();\n return Pattern$YEAR_SHORT_instance;\n }\n var Pattern$YEAR_FULL_instance;\n function Pattern$YEAR_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$YEAR_FULL_instance;\n }\n var Pattern$HOUR_24_instance;\n function Pattern$HOUR_24_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_24_instance;\n }\n var Pattern$HOUR_12_LEADING_ZERO_instance;\n function Pattern$HOUR_12_LEADING_ZERO_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_12_LEADING_ZERO_instance;\n }\n var Pattern$HOUR_12_instance;\n function Pattern$HOUR_12_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_12_instance;\n }\n var Pattern$MINUTE_instance;\n function Pattern$MINUTE_getInstance() {\n Pattern_initFields();\n return Pattern$MINUTE_instance;\n }\n var Pattern$MERIDIAN_LOWER_instance;\n function Pattern$MERIDIAN_LOWER_getInstance() {\n Pattern_initFields();\n return Pattern$MERIDIAN_LOWER_instance;\n }\n var Pattern$MERIDIAN_UPPER_instance;\n function Pattern$MERIDIAN_UPPER_getInstance() {\n Pattern_initFields();\n return Pattern$MERIDIAN_UPPER_instance;\n }\n var Pattern$SECOND_instance;\n function Pattern$SECOND_getInstance() {\n Pattern_initFields();\n return Pattern$SECOND_instance;\n }\n function Pattern$Companion() {\n Pattern$Companion_instance = this;\n this.PATTERN_REGEX = Regex_init('(%[aAbBdejmwyYHIlMpPS])');\n }\n function Pattern$Companion$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Pattern$Companion$Kind_initFields() {\n Pattern$Companion$Kind_initFields = function () {\n };\n Pattern$Companion$Kind$DATE_instance = new Pattern$Companion$Kind('DATE', 0);\n Pattern$Companion$Kind$TIME_instance = new Pattern$Companion$Kind('TIME', 1);\n }\n var Pattern$Companion$Kind$DATE_instance;\n function Pattern$Companion$Kind$DATE_getInstance() {\n Pattern$Companion$Kind_initFields();\n return Pattern$Companion$Kind$DATE_instance;\n }\n var Pattern$Companion$Kind$TIME_instance;\n function Pattern$Companion$Kind$TIME_getInstance() {\n Pattern$Companion$Kind_initFields();\n return Pattern$Companion$Kind$TIME_instance;\n }\n Pattern$Companion$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function Pattern$Companion$Kind$values() {\n return [Pattern$Companion$Kind$DATE_getInstance(), Pattern$Companion$Kind$TIME_getInstance()];\n }\n Pattern$Companion$Kind.values = Pattern$Companion$Kind$values;\n function Pattern$Companion$Kind$valueOf(name) {\n switch (name) {\n case 'DATE':\n return Pattern$Companion$Kind$DATE_getInstance();\n case 'TIME':\n return Pattern$Companion$Kind$TIME_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.dateFormat.Pattern.Companion.Kind.' + name);\n }\n }\n Pattern$Companion$Kind.valueOf_61zpoe$ = Pattern$Companion$Kind$valueOf;\n Pattern$Companion.prototype.patternByString_61zpoe$ = function (patternString) {\n var $receiver = Pattern$values();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$;\n for (tmp$ = 0; tmp$ !== $receiver.length; ++tmp$) {\n var element = $receiver[tmp$];\n if (equals(element.string, patternString)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n return firstOrNull$result;\n };\n Pattern$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Pattern$Companion_instance = null;\n function Pattern$Companion_getInstance() {\n Pattern_initFields();\n if (Pattern$Companion_instance === null) {\n new Pattern$Companion();\n }return Pattern$Companion_instance;\n }\n Pattern.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Pattern',\n interfaces: [Enum]\n };\n function Pattern$values() {\n return [Pattern$DAY_OF_WEEK_ABBR_getInstance(), Pattern$DAY_OF_WEEK_FULL_getInstance(), Pattern$MONTH_ABBR_getInstance(), Pattern$MONTH_FULL_getInstance(), Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance(), Pattern$DAY_OF_MONTH_getInstance(), Pattern$DAY_OF_THE_YEAR_getInstance(), Pattern$MONTH_getInstance(), Pattern$DAY_OF_WEEK_getInstance(), Pattern$YEAR_SHORT_getInstance(), Pattern$YEAR_FULL_getInstance(), Pattern$HOUR_24_getInstance(), Pattern$HOUR_12_LEADING_ZERO_getInstance(), Pattern$HOUR_12_getInstance(), Pattern$MINUTE_getInstance(), Pattern$MERIDIAN_LOWER_getInstance(), Pattern$MERIDIAN_UPPER_getInstance(), Pattern$SECOND_getInstance()];\n }\n Pattern.values = Pattern$values;\n function Pattern$valueOf(name) {\n switch (name) {\n case 'DAY_OF_WEEK_ABBR':\n return Pattern$DAY_OF_WEEK_ABBR_getInstance();\n case 'DAY_OF_WEEK_FULL':\n return Pattern$DAY_OF_WEEK_FULL_getInstance();\n case 'MONTH_ABBR':\n return Pattern$MONTH_ABBR_getInstance();\n case 'MONTH_FULL':\n return Pattern$MONTH_FULL_getInstance();\n case 'DAY_OF_MONTH_LEADING_ZERO':\n return Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance();\n case 'DAY_OF_MONTH':\n return Pattern$DAY_OF_MONTH_getInstance();\n case 'DAY_OF_THE_YEAR':\n return Pattern$DAY_OF_THE_YEAR_getInstance();\n case 'MONTH':\n return Pattern$MONTH_getInstance();\n case 'DAY_OF_WEEK':\n return Pattern$DAY_OF_WEEK_getInstance();\n case 'YEAR_SHORT':\n return Pattern$YEAR_SHORT_getInstance();\n case 'YEAR_FULL':\n return Pattern$YEAR_FULL_getInstance();\n case 'HOUR_24':\n return Pattern$HOUR_24_getInstance();\n case 'HOUR_12_LEADING_ZERO':\n return Pattern$HOUR_12_LEADING_ZERO_getInstance();\n case 'HOUR_12':\n return Pattern$HOUR_12_getInstance();\n case 'MINUTE':\n return Pattern$MINUTE_getInstance();\n case 'MERIDIAN_LOWER':\n return Pattern$MERIDIAN_LOWER_getInstance();\n case 'MERIDIAN_UPPER':\n return Pattern$MERIDIAN_UPPER_getInstance();\n case 'SECOND':\n return Pattern$SECOND_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.dateFormat.Pattern.' + name);\n }\n }\n Pattern.valueOf_61zpoe$ = Pattern$valueOf;\n function Date_0(day, month, year) {\n Date$Companion_getInstance();\n this.day = day;\n this.month = month;\n this.year = year;\n this.validate_0();\n }\n Object.defineProperty(Date_0.prototype, 'weekDay', {\n configurable: true,\n get: function () {\n var daysFromOrigin = this.daysFrom_z9gqti$(Date$Companion_getInstance().EPOCH);\n return WeekDay$values()[(daysFromOrigin + Date$Companion_getInstance().EPOCH_WEEKDAY_0.ordinal | 0) % WeekDay$values().length];\n }\n });\n Object.defineProperty(Date_0.prototype, 'dateStart', {\n configurable: true,\n get: function () {\n return new DateTime(this);\n }\n });\n Object.defineProperty(Date_0.prototype, 'dateEnd', {\n configurable: true,\n get: function () {\n return new DateTime(this, Time$Companion_getInstance().DAY_END);\n }\n });\n Date_0.prototype.validate_0 = function () {\n var tmp$;\n var daysInMonth = this.month.getDaysInYear_za3lpa$(this.year);\n tmp$ = this.day;\n var isValid = 1 <= tmp$ && tmp$ <= daysInMonth;\n if (!isValid) {\n throw IllegalArgumentException_init_0();\n }};\n Date_0.prototype.daysFrom_z9gqti$ = function (date) {\n if (this.compareTo_11rb$(date) < 0) {\n throw IllegalArgumentException_init_0();\n }var result = 0;\n if (this.year !== date.year) {\n var fromYear = date.year;\n var toYear = this.year;\n var leapYears = DateTimeUtil_getInstance().leapYearsBetween_6xvm5r$(fromYear, toYear);\n var years = toYear - fromYear | 0;\n result = result + (Kotlin.imul(leapYears, DateTimeUtil_getInstance().DAYS_IN_LEAP_YEAR_8be2vx$) + Kotlin.imul(years - leapYears | 0, DateTimeUtil_getInstance().DAYS_IN_YEAR_8be2vx$)) | 0;\n }return result + this.daysFromYearStart() - date.daysFromYearStart() | 0;\n };\n Date_0.prototype.daysFromYearStart = function () {\n var result = this.day;\n var current = this.month.prev();\n while (current != null) {\n result = result + current.getDaysInYear_za3lpa$(this.year) | 0;\n current = current.prev();\n }\n return result;\n };\n Date_0.prototype.addDays_za3lpa$ = function (days) {\n var days_0 = days;\n if (days_0 < 0) {\n throw IllegalArgumentException_init_0();\n }if (days_0 === 0)\n return this;\n var day = this.day;\n var month = this.month;\n var year = this.year;\n var lessThanYear = false;\n if (days_0 >= Date$Companion_getInstance().CACHE_DAYS_0 && year === Date$Companion_getInstance().EPOCH.year) {\n year = Date$Companion_getInstance().CACHE_STAMP_0.year;\n month = Date$Companion_getInstance().CACHE_STAMP_0.month;\n day = Date$Companion_getInstance().CACHE_STAMP_0.day;\n days_0 = days_0 - Date$Companion_getInstance().CACHE_DAYS_0 | 0;\n }while (days_0 > 0) {\n var daysToNextMonth = month.getDaysInYear_za3lpa$(year) - day + 1 | 0;\n if (days_0 < daysToNextMonth) {\n return new Date_0(day + days_0 | 0, month, year);\n } else {\n if (lessThanYear) {\n month = ensureNotNull(month.next());\n day = 1;\n days_0 = days_0 - daysToNextMonth | 0;\n } else {\n var daysToNextYear = Date$Companion_getInstance().lastDayOf_8fsw02$(year).daysFrom_z9gqti$(new Date_0(day, month, year)) + 1 | 0;\n if (days_0 >= daysToNextYear) {\n day = 1;\n month = Month$Companion_getInstance().JANUARY;\n year = year + 1 | 0;\n days_0 = days_0 - daysToNextYear | 0;\n } else {\n month = ensureNotNull(month.next());\n day = 1;\n days_0 = days_0 - daysToNextMonth | 0;\n lessThanYear = true;\n }\n }\n }\n }\n return new Date_0(day, month, year);\n };\n Date_0.prototype.nextDate = function () {\n return this.addDays_za3lpa$(1);\n };\n Date_0.prototype.prevDate = function () {\n return this.subtractDays_za3lpa$(1);\n };\n Date_0.prototype.subtractDays_za3lpa$ = function (days) {\n var tmp$;\n if (days < 0) {\n throw IllegalArgumentException_init_0();\n }if (days === 0)\n return this;\n if (days < this.day) {\n return new Date_0(this.day - days | 0, this.month, this.year);\n } else {\n var daysToPrevYear = this.daysFrom_z9gqti$(Date$Companion_getInstance().firstDayOf_8fsw02$(this.year));\n if (days > daysToPrevYear) {\n tmp$ = Date$Companion_getInstance().lastDayOf_8fsw02$(this.year - 1 | 0).subtractDays_za3lpa$(days - daysToPrevYear - 1 | 0);\n } else {\n tmp$ = Date$Companion_getInstance().lastDayOf_8fsw02$(this.year, ensureNotNull(this.month.prev())).subtractDays_za3lpa$(days - this.day | 0);\n }\n return tmp$;\n }\n };\n Date_0.prototype.compareTo_11rb$ = function (other) {\n if (this.year !== other.year)\n return this.year - other.year | 0;\n return this.month.ordinal() !== other.month.ordinal() ? this.month.ordinal() - other.month.ordinal() | 0 : this.day - other.day | 0;\n };\n Date_0.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, Date_0))\n return false;\n var date = (tmp$ = other) == null || Kotlin.isType(tmp$, Date_0) ? tmp$ : throwCCE();\n return ensureNotNull(date).year === this.year && date.month === this.month && date.day === this.day;\n };\n Date_0.prototype.hashCode = function () {\n return (this.year * 239 | 0) + (hashCode(this.month) * 31 | 0) + this.day | 0;\n };\n Date_0.prototype.toString = function () {\n var result = StringBuilder_init();\n result.append_s8jyv4$(this.year);\n this.appendMonth_0(result);\n this.appendDay_0(result);\n return result.toString();\n };\n Date_0.prototype.appendDay_0 = function (result) {\n if (this.day < 10) {\n result.append_pdl1vj$('0');\n }result.append_s8jyv4$(this.day);\n };\n Date_0.prototype.appendMonth_0 = function (result) {\n var month = this.month.ordinal() + 1 | 0;\n if (month < 10) {\n result.append_pdl1vj$('0');\n }result.append_s8jyv4$(month);\n };\n Date_0.prototype.toPrettyString = function () {\n var result = StringBuilder_init();\n this.appendDay_0(result);\n result.append_pdl1vj$('.');\n this.appendMonth_0(result);\n result.append_pdl1vj$('.');\n result.append_s8jyv4$(this.year);\n return result.toString();\n };\n function Date$Companion() {\n Date$Companion_instance = this;\n this.EPOCH = new Date_0(1, Month$Companion_getInstance().JANUARY, 1970);\n this.EPOCH_WEEKDAY_0 = WeekDay$THURSDAY_getInstance();\n this.CACHE_STAMP_0 = new Date_0(1, Month$Companion_getInstance().JANUARY, 2012);\n this.CACHE_DAYS_0 = this.CACHE_STAMP_0.daysFrom_z9gqti$(this.EPOCH);\n }\n Date$Companion.prototype.parse_61zpoe$ = function (str) {\n if (str.length !== 8) {\n throw RuntimeException_init();\n }var year = toInt(str.substring(0, 4));\n var month = toInt(str.substring(4, 6));\n var day = toInt(str.substring(6, 8));\n return new Date_0(day, Month$Companion_getInstance().values()[month - 1 | 0], year);\n };\n Date$Companion.prototype.firstDayOf_8fsw02$ = function (year, month) {\n if (month === void 0)\n month = Month$Companion_getInstance().JANUARY;\n return new Date_0(1, month, year);\n };\n Date$Companion.prototype.lastDayOf_8fsw02$ = function (year, month) {\n if (month === void 0)\n month = Month$Companion_getInstance().DECEMBER;\n return new Date_0(month.days, month, year);\n };\n Date$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Date$Companion_instance = null;\n function Date$Companion_getInstance() {\n if (Date$Companion_instance === null) {\n new Date$Companion();\n }return Date$Companion_instance;\n }\n Date_0.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Date',\n interfaces: [Comparable]\n };\n function DateTime(date, time) {\n DateTime$Companion_getInstance();\n if (time === void 0)\n time = Time$Companion_getInstance().DAY_START;\n this.date = date;\n this.time = time;\n }\n Object.defineProperty(DateTime.prototype, 'year', {\n configurable: true,\n get: function () {\n return this.date.year;\n }\n });\n Object.defineProperty(DateTime.prototype, 'month', {\n configurable: true,\n get: function () {\n return this.date.month;\n }\n });\n Object.defineProperty(DateTime.prototype, 'day', {\n configurable: true,\n get: function () {\n return this.date.day;\n }\n });\n Object.defineProperty(DateTime.prototype, 'weekDay', {\n configurable: true,\n get: function () {\n return this.date.weekDay;\n }\n });\n Object.defineProperty(DateTime.prototype, 'hours', {\n configurable: true,\n get: function () {\n return this.time.hours;\n }\n });\n Object.defineProperty(DateTime.prototype, 'minutes', {\n configurable: true,\n get: function () {\n return this.time.minutes;\n }\n });\n Object.defineProperty(DateTime.prototype, 'seconds', {\n configurable: true,\n get: function () {\n return this.time.seconds;\n }\n });\n Object.defineProperty(DateTime.prototype, 'milliseconds', {\n configurable: true,\n get: function () {\n return this.time.milliseconds;\n }\n });\n DateTime.prototype.changeDate_z9gqti$ = function (date) {\n return new DateTime(date, this.time);\n };\n DateTime.prototype.changeTime_z96d9j$ = function (time) {\n return new DateTime(this.date, time);\n };\n DateTime.prototype.add_27523k$ = function (duration) {\n var utcInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(this);\n return TimeZone$Companion_getInstance().UTC.toDateTime_x2y23v$(utcInstant.add_27523k$(duration));\n };\n DateTime.prototype.to_amwj4p$ = function (otherTime) {\n var currentInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(this);\n var otherInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(otherTime);\n return currentInstant.to_x2y23v$(otherInstant);\n };\n DateTime.prototype.isBefore_amwj4p$ = function (dateTime) {\n return this.compareTo_11rb$(dateTime) < 0;\n };\n DateTime.prototype.isAfter_amwj4p$ = function (dateTime) {\n return this.compareTo_11rb$(dateTime) > 0;\n };\n DateTime.prototype.hashCode = function () {\n return (this.date.hashCode() * 31 | 0) + this.time.hashCode() | 0;\n };\n DateTime.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, DateTime))\n return false;\n var otherDateTime = (tmp$ = other) == null || Kotlin.isType(tmp$, DateTime) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.date) != null ? tmp$_0.equals(ensureNotNull(otherDateTime).date) : null) && ((tmp$_1 = this.time) != null ? tmp$_1.equals(otherDateTime.time) : null);\n };\n DateTime.prototype.compareTo_11rb$ = function (other) {\n var dateComparison = this.date.compareTo_11rb$(other.date);\n return dateComparison !== 0 ? dateComparison : this.time.compareTo_11rb$(other.time);\n };\n DateTime.prototype.toString = function () {\n return this.date.toString() + 'T' + toString(this.time);\n };\n DateTime.prototype.toPrettyString = function () {\n return this.time.toPrettyHMString() + ' ' + this.date.toPrettyString();\n };\n function DateTime$Companion() {\n DateTime$Companion_instance = this;\n }\n DateTime$Companion.prototype.parse_61zpoe$ = function (s) {\n if (s.length < 15) {\n throw IllegalArgumentException_init_0();\n }return new DateTime(Date$Companion_getInstance().parse_61zpoe$(s.substring(0, 8)), Time$Companion_getInstance().parse_61zpoe$(s.substring(9)));\n };\n DateTime$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DateTime$Companion_instance = null;\n function DateTime$Companion_getInstance() {\n if (DateTime$Companion_instance === null) {\n new DateTime$Companion();\n }return DateTime$Companion_instance;\n }\n DateTime.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTime',\n interfaces: [Comparable]\n };\n function DateTimeUtil() {\n DateTimeUtil_instance = this;\n this.BASE_YEAR = 1900;\n this.MAX_SUPPORTED_YEAR = 2100;\n this.MIN_SUPPORTED_YEAR_8be2vx$ = 1970;\n this.DAYS_IN_YEAR_8be2vx$ = 0;\n this.DAYS_IN_LEAP_YEAR_8be2vx$ = 0;\n this.LEAP_YEARS_FROM_1969_8be2vx$ = new Int32Array([477, 477, 477, 478, 478, 478, 478, 479, 479, 479, 479, 480, 480, 480, 480, 481, 481, 481, 481, 482, 482, 482, 482, 483, 483, 483, 483, 484, 484, 484, 484, 485, 485, 485, 485, 486, 486, 486, 486, 487, 487, 487, 487, 488, 488, 488, 488, 489, 489, 489, 489, 490, 490, 490, 490, 491, 491, 491, 491, 492, 492, 492, 492, 493, 493, 493, 493, 494, 494, 494, 494, 495, 495, 495, 495, 496, 496, 496, 496, 497, 497, 497, 497, 498, 498, 498, 498, 499, 499, 499, 499, 500, 500, 500, 500, 501, 501, 501, 501, 502, 502, 502, 502, 503, 503, 503, 503, 504, 504, 504, 504, 505, 505, 505, 505, 506, 506, 506, 506, 507, 507, 507, 507, 508, 508, 508, 508, 509, 509, 509, 509, 509]);\n var tmp$, tmp$_0;\n var leapYearDays = 0;\n var yearDays = 0;\n tmp$ = Month$Companion_getInstance().values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var m = tmp$[tmp$_0];\n leapYearDays = leapYearDays + m.getDaysInLeapYear() | 0;\n yearDays = yearDays + m.days | 0;\n }\n this.DAYS_IN_YEAR_8be2vx$ = yearDays;\n this.DAYS_IN_LEAP_YEAR_8be2vx$ = leapYearDays;\n }\n DateTimeUtil.prototype.isLeap_kcn2v3$ = function (year) {\n this.checkYear_0(year);\n return (this.LEAP_YEARS_FROM_1969_8be2vx$[year - 1970 + 1 | 0] - this.LEAP_YEARS_FROM_1969_8be2vx$[year - 1970 | 0] | 0) === 1;\n };\n DateTimeUtil.prototype.leapYearsBetween_6xvm5r$ = function (fromYear, toYear) {\n if (fromYear > toYear) {\n throw IllegalArgumentException_init_0();\n }this.checkYear_0(fromYear);\n this.checkYear_0(toYear);\n return this.LEAP_YEARS_FROM_1969_8be2vx$[toYear - 1970 | 0] - this.LEAP_YEARS_FROM_1969_8be2vx$[fromYear - 1970 | 0] | 0;\n };\n DateTimeUtil.prototype.leapYearsFromZero_0 = function (year) {\n return (year / 4 | 0) - (year / 100 | 0) + (year / 400 | 0) | 0;\n };\n DateTimeUtil.prototype.checkYear_0 = function (year) {\n if (year > 2100 || year < 1970) {\n throw IllegalArgumentException_init(year.toString() + '');\n }};\n DateTimeUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateTimeUtil',\n interfaces: []\n };\n var DateTimeUtil_instance = null;\n function DateTimeUtil_getInstance() {\n if (DateTimeUtil_instance === null) {\n new DateTimeUtil();\n }return DateTimeUtil_instance;\n }\n function Duration(duration) {\n Duration$Companion_getInstance();\n this.duration = duration;\n }\n Object.defineProperty(Duration.prototype, 'isPositive', {\n configurable: true,\n get: function () {\n return this.duration.toNumber() > 0;\n }\n });\n Duration.prototype.mul_s8cxhz$ = function (times) {\n return new Duration(this.duration.multiply(times));\n };\n Duration.prototype.add_27523k$ = function (duration) {\n return new Duration(this.duration.add(duration.duration));\n };\n Duration.prototype.sub_27523k$ = function (duration) {\n return new Duration(this.duration.subtract(duration.duration));\n };\n Duration.prototype.div_27523k$ = function (duration) {\n return this.duration.toNumber() / duration.duration.toNumber();\n };\n Duration.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var delta = this.duration.subtract(other.duration);\n if (delta.toNumber() > 0) {\n tmp$ = 1;\n } else if (equals(delta, L0)) {\n tmp$ = 0;\n } else {\n tmp$ = -1;\n }\n return tmp$;\n };\n Duration.prototype.hashCode = function () {\n return this.duration.toInt();\n };\n Duration.prototype.equals = function (other) {\n return !Kotlin.isType(other, Duration) ? false : equals(this.duration, other.duration);\n };\n Duration.prototype.toString = function () {\n return 'Duration : ' + toString(this.duration) + 'ms';\n };\n function Duration$Companion() {\n Duration$Companion_instance = this;\n this.MS = new Duration(L1);\n this.SECOND = this.MS.mul_s8cxhz$(L1000);\n this.MINUTE = this.SECOND.mul_s8cxhz$(L60);\n this.HOUR = this.MINUTE.mul_s8cxhz$(L60);\n this.DAY = this.HOUR.mul_s8cxhz$(L24);\n this.WEEK = this.DAY.mul_s8cxhz$(L7);\n }\n Duration$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Duration$Companion_instance = null;\n function Duration$Companion_getInstance() {\n if (Duration$Companion_instance === null) {\n new Duration$Companion();\n }return Duration$Companion_instance;\n }\n Duration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Duration',\n interfaces: [Comparable]\n };\n function Instant(timeSinceEpoch) {\n this.timeSinceEpoch = timeSinceEpoch;\n }\n Instant.prototype.add_27523k$ = function (duration) {\n return new Instant(this.timeSinceEpoch.add(duration.duration));\n };\n Instant.prototype.sub_27523k$ = function (duration) {\n return new Instant(this.timeSinceEpoch.subtract(duration.duration));\n };\n Instant.prototype.to_x2y23v$ = function (instant) {\n return new Duration(instant.timeSinceEpoch.subtract(this.timeSinceEpoch));\n };\n Instant.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var delta = this.timeSinceEpoch.subtract(other.timeSinceEpoch);\n if (delta.toNumber() > 0) {\n tmp$ = 1;\n } else if (equals(delta, L0)) {\n tmp$ = 0;\n } else {\n tmp$ = -1;\n }\n return tmp$;\n };\n Instant.prototype.hashCode = function () {\n return this.timeSinceEpoch.toInt();\n };\n Instant.prototype.toString = function () {\n return '' + toString(this.timeSinceEpoch);\n };\n Instant.prototype.equals = function (other) {\n return !Kotlin.isType(other, Instant) ? false : equals(this.timeSinceEpoch, other.timeSinceEpoch);\n };\n Instant.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Instant',\n interfaces: [Comparable]\n };\n function Month(days, myOrdinal, myName) {\n Month$Companion_getInstance();\n this.days = days;\n this.myOrdinal_hzcl1t$_0 = myOrdinal;\n this.myName_s01cg9$_0 = myName;\n }\n Month.prototype.ordinal = function () {\n return this.myOrdinal_hzcl1t$_0;\n };\n Month.prototype.getDaysInYear_za3lpa$ = function (year) {\n return this.days;\n };\n Month.prototype.getDaysInLeapYear = function () {\n return this.days;\n };\n Month.prototype.prev = function () {\n return this.myOrdinal_hzcl1t$_0 === 0 ? null : Month$Companion_getInstance().values()[this.myOrdinal_hzcl1t$_0 - 1 | 0];\n };\n Month.prototype.next = function () {\n var values = Month$Companion_getInstance().values();\n return this.myOrdinal_hzcl1t$_0 === (values.length - 1 | 0) ? null : values[this.myOrdinal_hzcl1t$_0 + 1 | 0];\n };\n Month.prototype.toString = function () {\n return this.myName_s01cg9$_0;\n };\n function Month$VarLengthMonth(days, myDaysInLeapYear, ordinal, name) {\n Month.call(this, days, ordinal, name);\n this.myDaysInLeapYear_0 = myDaysInLeapYear;\n }\n Month$VarLengthMonth.prototype.getDaysInLeapYear = function () {\n return this.myDaysInLeapYear_0;\n };\n Month$VarLengthMonth.prototype.getDaysInYear_za3lpa$ = function (year) {\n var tmp$;\n if (DateTimeUtil_getInstance().isLeap_kcn2v3$(year)) {\n tmp$ = this.getDaysInLeapYear();\n } else {\n tmp$ = this.days;\n }\n return tmp$;\n };\n Month$VarLengthMonth.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VarLengthMonth',\n interfaces: [Month]\n };\n function Month$Companion() {\n Month$Companion_instance = this;\n this.JANUARY = new Month(31, 0, 'January');\n this.FEBRUARY = new Month$VarLengthMonth(28, 29, 1, 'February');\n this.MARCH = new Month(31, 2, 'March');\n this.APRIL = new Month(30, 3, 'April');\n this.MAY = new Month(31, 4, 'May');\n this.JUNE = new Month(30, 5, 'June');\n this.JULY = new Month(31, 6, 'July');\n this.AUGUST = new Month(31, 7, 'August');\n this.SEPTEMBER = new Month(30, 8, 'September');\n this.OCTOBER = new Month(31, 9, 'October');\n this.NOVEMBER = new Month(30, 10, 'November');\n this.DECEMBER = new Month(31, 11, 'December');\n this.VALUES_0 = [this.JANUARY, this.FEBRUARY, this.MARCH, this.APRIL, this.MAY, this.JUNE, this.JULY, this.AUGUST, this.SEPTEMBER, this.OCTOBER, this.NOVEMBER, this.DECEMBER];\n }\n Month$Companion.prototype.values = function () {\n return this.VALUES_0;\n };\n Month$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Month$Companion_instance = null;\n function Month$Companion_getInstance() {\n if (Month$Companion_instance === null) {\n new Month$Companion();\n }return Month$Companion_instance;\n }\n Month.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Month',\n interfaces: []\n };\n function Time(hours, minutes, seconds, milliseconds) {\n Time$Companion_getInstance();\n if (seconds === void 0)\n seconds = 0;\n if (milliseconds === void 0)\n milliseconds = 0;\n this.hours = hours;\n this.minutes = minutes;\n this.seconds = seconds;\n this.milliseconds = milliseconds;\n if (this.hours < 0 || this.hours > 24) {\n throw IllegalArgumentException_init_0();\n }if (this.hours === 24 && (this.minutes !== 0 || this.seconds !== 0)) {\n throw IllegalArgumentException_init_0();\n }if (this.minutes < 0 || this.minutes >= 60) {\n throw IllegalArgumentException_init_0();\n }if (this.seconds < 0 || this.seconds >= 60) {\n throw IllegalArgumentException_init_0();\n }}\n Time.prototype.compareTo_11rb$ = function (other) {\n var delta = this.hours - other.hours | 0;\n if (delta !== 0)\n return delta;\n delta = this.minutes - other.minutes | 0;\n if (delta !== 0)\n return delta;\n delta = this.seconds - other.seconds | 0;\n return delta !== 0 ? delta : this.milliseconds - other.milliseconds | 0;\n };\n Time.prototype.hashCode = function () {\n return (this.hours * 239 | 0) + (this.minutes * 491 | 0) + (this.seconds * 41 | 0) + this.milliseconds | 0;\n };\n Time.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (!Kotlin.isType(other, Time))\n tmp$_0 = false;\n else {\n tmp$_0 = this.compareTo_11rb$(ensureNotNull((tmp$ = other) == null || Kotlin.isType(tmp$, Time) ? tmp$ : throwCCE())) === 0;\n }\n return tmp$_0;\n };\n Time.prototype.toString = function () {\n var result = StringBuilder_init();\n if (this.hours < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.hours);\n if (this.minutes < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.minutes);\n if (this.seconds < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.seconds);\n return result.toString();\n };\n Time.prototype.toPrettyHMString = function () {\n var result = StringBuilder_init();\n if (this.hours < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.hours).append_s8itvh$(Time$Companion_getInstance().DELIMITER_0);\n if (this.minutes < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.minutes);\n return result.toString();\n };\n function Time$Companion() {\n Time$Companion_instance = this;\n this.DELIMITER_0 = 58;\n this.DAY_START = new Time(0, 0);\n this.DAY_END = new Time(24, 0);\n }\n Time$Companion.prototype.parse_61zpoe$ = function (s) {\n if (s.length < 6) {\n throw IllegalArgumentException_init_0();\n }var hours = toInt(s.substring(0, 2));\n var minutes = toInt(s.substring(2, 4));\n var seconds = toInt(s.substring(4, 6));\n return new Time(hours, minutes, seconds);\n };\n Time$Companion.prototype.fromPrettyHMString_61zpoe$ = function (time) {\n var $receiver = this.DELIMITER_0;\n if (!contains(time, String.fromCharCode($receiver) + '')) {\n throw IllegalArgumentException_init_0();\n }var length = time.length;\n if (length !== 5 && length !== 4) {\n throw IllegalArgumentException_init_0();\n }var hourLength = length === 4 ? 1 : 2;\n try {\n var tmp$ = toInt(time.substring(0, hourLength));\n var startIndex = hourLength + 1 | 0;\n return new Time(tmp$, toInt(time.substring(startIndex, length)), 0);\n } catch (ignored) {\n if (Kotlin.isType(ignored, NumberFormatException)) {\n throw IllegalArgumentException_init_0();\n } else\n throw ignored;\n }\n };\n Time$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Time$Companion_instance = null;\n function Time$Companion_getInstance() {\n if (Time$Companion_instance === null) {\n new Time$Companion();\n }return Time$Companion_instance;\n }\n Time.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Time',\n interfaces: [Comparable]\n };\n function WeekDay(name, ordinal, abbreviation, isWeekend) {\n Enum.call(this);\n this.abbreviation = abbreviation;\n this.isWeekend = isWeekend;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function WeekDay_initFields() {\n WeekDay_initFields = function () {\n };\n WeekDay$MONDAY_instance = new WeekDay('MONDAY', 0, 'MO', false);\n WeekDay$TUESDAY_instance = new WeekDay('TUESDAY', 1, 'TU', false);\n WeekDay$WEDNESDAY_instance = new WeekDay('WEDNESDAY', 2, 'WE', false);\n WeekDay$THURSDAY_instance = new WeekDay('THURSDAY', 3, 'TH', false);\n WeekDay$FRIDAY_instance = new WeekDay('FRIDAY', 4, 'FR', false);\n WeekDay$SATURDAY_instance = new WeekDay('SATURDAY', 5, 'SA', true);\n WeekDay$SUNDAY_instance = new WeekDay('SUNDAY', 6, 'SU', true);\n }\n var WeekDay$MONDAY_instance;\n function WeekDay$MONDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$MONDAY_instance;\n }\n var WeekDay$TUESDAY_instance;\n function WeekDay$TUESDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$TUESDAY_instance;\n }\n var WeekDay$WEDNESDAY_instance;\n function WeekDay$WEDNESDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$WEDNESDAY_instance;\n }\n var WeekDay$THURSDAY_instance;\n function WeekDay$THURSDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$THURSDAY_instance;\n }\n var WeekDay$FRIDAY_instance;\n function WeekDay$FRIDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$FRIDAY_instance;\n }\n var WeekDay$SATURDAY_instance;\n function WeekDay$SATURDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$SATURDAY_instance;\n }\n var WeekDay$SUNDAY_instance;\n function WeekDay$SUNDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$SUNDAY_instance;\n }\n WeekDay.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'WeekDay',\n interfaces: [Enum]\n };\n function WeekDay$values() {\n return [WeekDay$MONDAY_getInstance(), WeekDay$TUESDAY_getInstance(), WeekDay$WEDNESDAY_getInstance(), WeekDay$THURSDAY_getInstance(), WeekDay$FRIDAY_getInstance(), WeekDay$SATURDAY_getInstance(), WeekDay$SUNDAY_getInstance()];\n }\n WeekDay.values = WeekDay$values;\n function WeekDay$valueOf(name) {\n switch (name) {\n case 'MONDAY':\n return WeekDay$MONDAY_getInstance();\n case 'TUESDAY':\n return WeekDay$TUESDAY_getInstance();\n case 'WEDNESDAY':\n return WeekDay$WEDNESDAY_getInstance();\n case 'THURSDAY':\n return WeekDay$THURSDAY_getInstance();\n case 'FRIDAY':\n return WeekDay$FRIDAY_getInstance();\n case 'SATURDAY':\n return WeekDay$SATURDAY_getInstance();\n case 'SUNDAY':\n return WeekDay$SUNDAY_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.datetime.WeekDay.' + name);\n }\n }\n WeekDay.valueOf_61zpoe$ = WeekDay$valueOf;\n function DateSpec() {\n }\n DateSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'DateSpec',\n interfaces: []\n };\n function DateSpecs() {\n DateSpecs_instance = this;\n }\n function DateSpecs$last$ObjectLiteral(closure$weekDay, closure$month) {\n this.closure$weekDay = closure$weekDay;\n this.closure$month = closure$month;\n }\n Object.defineProperty(DateSpecs$last$ObjectLiteral.prototype, 'rRule', {\n configurable: true,\n get: function () {\n return 'RRULE:FREQ=YEARLY;BYDAY=-1' + this.closure$weekDay.abbreviation + ';BYMONTH=' + toString(this.closure$month.ordinal() + 1 | 0);\n }\n });\n DateSpecs$last$ObjectLiteral.prototype.getDate_za3lpa$ = function (year) {\n var days = this.closure$month.getDaysInYear_za3lpa$(year);\n for (var d = days; d >= 1; d--) {\n var date = new Date_0(d, this.closure$month, year);\n if (date.weekDay === this.closure$weekDay)\n return date;\n }\n throw RuntimeException_init();\n };\n DateSpecs$last$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DateSpec]\n };\n DateSpecs.prototype.last_kvq57g$ = function (weekDay, month) {\n return new DateSpecs$last$ObjectLiteral(weekDay, month);\n };\n function DateSpecs$first$ObjectLiteral(closure$number, closure$weekDay, closure$month) {\n this.closure$number = closure$number;\n this.closure$weekDay = closure$weekDay;\n this.closure$month = closure$month;\n }\n Object.defineProperty(DateSpecs$first$ObjectLiteral.prototype, 'rRule', {\n configurable: true,\n get: function () {\n return 'RRULE:FREQ=YEARLY;BYDAY=' + toString(this.closure$number) + this.closure$weekDay.abbreviation + ';BYMONTH=' + toString(this.closure$month.ordinal() + 1 | 0);\n }\n });\n DateSpecs$first$ObjectLiteral.prototype.getDate_za3lpa$ = function (year) {\n var startDay = Kotlin.imul(this.closure$number - 1 | 0, WeekDay$values().length) + 1 | 0;\n var days = this.closure$month.getDaysInYear_za3lpa$(year);\n for (var d = startDay; d <= days; d++) {\n var date = new Date_0(d, this.closure$month, year);\n if (date.weekDay === this.closure$weekDay)\n return date;\n }\n throw RuntimeException_init();\n };\n DateSpecs$first$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DateSpec]\n };\n DateSpecs.prototype.first_t96ihi$ = function (weekDay, month, number) {\n if (number === void 0)\n number = 1;\n return new DateSpecs$first$ObjectLiteral(number, weekDay, month);\n };\n DateSpecs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateSpecs',\n interfaces: []\n };\n var DateSpecs_instance = null;\n function DateSpecs_getInstance() {\n if (DateSpecs_instance === null) {\n new DateSpecs();\n }return DateSpecs_instance;\n }\n function TimeZone(id) {\n TimeZone$Companion_getInstance();\n this.id = id;\n }\n TimeZone.prototype.convertTo_8hfrhi$ = function (toConvert, to) {\n return to === this ? toConvert : to.toDateTime_x2y23v$(this.toInstant_amwj4p$(toConvert));\n };\n TimeZone.prototype.convertTimeAtDay_aopdye$ = function (srcTime, dstDate, dstTimeZone) {\n var src = new DateTime(dstDate, srcTime);\n var dst = this.convertTo_8hfrhi$(src, dstTimeZone);\n var dayDiff = dstDate.compareTo_11rb$(dst.date);\n if (dayDiff !== 0) {\n var correctedDay = dayDiff > 0 ? dstDate.nextDate() : dstDate.prevDate();\n src = new DateTime(correctedDay, srcTime);\n dst = this.convertTo_8hfrhi$(src, dstTimeZone);\n }return dst.time;\n };\n TimeZone.prototype.getTimeZoneShift_x2y23v$ = function (instant) {\n var utcDateTime = this.toDateTime_x2y23v$(instant);\n return instant.to_x2y23v$(TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(utcDateTime));\n };\n TimeZone.prototype.toString = function () {\n return ensureNotNull(this.id);\n };\n function TimeZone$Companion() {\n TimeZone$Companion_instance = this;\n this.UTC = TimeZones_getInstance().utc();\n this.BERLIN = TimeZones_getInstance().withEuSummerTime_rwkwum$('Europe/Berlin', Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L1));\n this.MOSCOW = new TimeZoneMoscow();\n this.NY = TimeZones_getInstance().withUsSummerTime_rwkwum$('America/New_York', Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L_5));\n }\n TimeZone$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeZone$Companion_instance = null;\n function TimeZone$Companion_getInstance() {\n if (TimeZone$Companion_instance === null) {\n new TimeZone$Companion();\n }return TimeZone$Companion_instance;\n }\n TimeZone.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeZone',\n interfaces: []\n };\n function TimeZoneMoscow() {\n TimeZoneMoscow$Companion_getInstance();\n TimeZone.call(this, TimeZoneMoscow$Companion_getInstance().ID_0);\n this.myOldOffset_0 = Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L4);\n this.myNewOffset_0 = Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L3);\n this.myOldTz_0 = TimeZones_getInstance().offset_nf4kng$(null, this.myOldOffset_0, TimeZone$Companion_getInstance().UTC);\n this.myNewTz_0 = TimeZones_getInstance().offset_nf4kng$(null, this.myNewOffset_0, TimeZone$Companion_getInstance().UTC);\n this.myOffsetChangeTime_0 = new DateTime(new Date_0(26, Month$Companion_getInstance().OCTOBER, 2014), new Time(2, 0));\n this.myOffsetChangeInstant_0 = this.myOldTz_0.toInstant_amwj4p$(this.myOffsetChangeTime_0);\n }\n TimeZoneMoscow.prototype.toDateTime_x2y23v$ = function (instant) {\n return instant.compareTo_11rb$(this.myOffsetChangeInstant_0) >= 0 ? this.myNewTz_0.toDateTime_x2y23v$(instant) : this.myOldTz_0.toDateTime_x2y23v$(instant);\n };\n TimeZoneMoscow.prototype.toInstant_amwj4p$ = function (dateTime) {\n return dateTime.compareTo_11rb$(this.myOffsetChangeTime_0) >= 0 ? this.myNewTz_0.toInstant_amwj4p$(dateTime) : this.myOldTz_0.toInstant_amwj4p$(dateTime);\n };\n function TimeZoneMoscow$Companion() {\n TimeZoneMoscow$Companion_instance = this;\n this.ID_0 = 'Europe/Moscow';\n }\n TimeZoneMoscow$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeZoneMoscow$Companion_instance = null;\n function TimeZoneMoscow$Companion_getInstance() {\n if (TimeZoneMoscow$Companion_instance === null) {\n new TimeZoneMoscow$Companion();\n }return TimeZoneMoscow$Companion_instance;\n }\n TimeZoneMoscow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeZoneMoscow',\n interfaces: [TimeZone]\n };\n function TimeZones() {\n TimeZones_instance = this;\n this.MILLIS_IN_SECOND_0 = L1000;\n this.MILLIS_IN_MINUTE_0 = L60000;\n this.MILLIS_IN_HOUR_0 = L3600000;\n this.MILLIS_IN_DAY_0 = L86400000;\n }\n TimeZones.prototype.toDateTime_0 = function (instant, offset) {\n var instant_0 = instant;\n instant_0 = instant_0.add_27523k$(offset);\n var days = instant_0.timeSinceEpoch.div(this.MILLIS_IN_DAY_0).toInt();\n var date = Date$Companion_getInstance().EPOCH.addDays_za3lpa$(days);\n var rest = instant_0.timeSinceEpoch.modulo(this.MILLIS_IN_DAY_0);\n var hour = rest.div(this.MILLIS_IN_HOUR_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_HOUR_0);\n var minutes = rest.div(this.MILLIS_IN_MINUTE_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_MINUTE_0);\n var seconds = rest.div(this.MILLIS_IN_SECOND_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_SECOND_0);\n var milliseconds = rest.modulo(this.MILLIS_IN_SECOND_0).toInt();\n return new DateTime(date, new Time(hour, minutes, seconds, milliseconds));\n };\n TimeZones.prototype.toInstant_0 = function (dateTime, offset) {\n return (new Instant(this.toMillis_0(dateTime.date).add(this.toMillis_1(dateTime.time)))).sub_27523k$(offset);\n };\n TimeZones.prototype.toMillis_1 = function (time) {\n var minutes = Kotlin.Long.fromInt(time.hours).multiply(L60).add(Kotlin.Long.fromInt(time.minutes));\n var seconds = minutes.multiply(Kotlin.Long.fromInt(60)).add(Kotlin.Long.fromInt(time.seconds));\n return seconds.multiply(Kotlin.Long.fromInt(1000)).add(Kotlin.Long.fromInt(time.milliseconds));\n };\n TimeZones.prototype.toMillis_0 = function (date) {\n return Kotlin.Long.fromInt(date.daysFrom_z9gqti$(Date$Companion_getInstance().EPOCH)).multiply(this.MILLIS_IN_DAY_0);\n };\n function TimeZones$utc$ObjectLiteral(id) {\n TimeZone.call(this, id);\n }\n TimeZones$utc$ObjectLiteral.prototype.toDateTime_x2y23v$ = function (instant) {\n return TimeZones_getInstance().toDateTime_0(instant, new Duration(L0));\n };\n TimeZones$utc$ObjectLiteral.prototype.toInstant_amwj4p$ = function (dateTime) {\n return TimeZones_getInstance().toInstant_0(dateTime, new Duration(L0));\n };\n TimeZones$utc$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZone]\n };\n TimeZones.prototype.utc = function () {\n return new TimeZones$utc$ObjectLiteral('UTC');\n };\n function TimeZones$offset$ObjectLiteral(closure$base, closure$offset, id) {\n this.closure$base = closure$base;\n this.closure$offset = closure$offset;\n TimeZone.call(this, id);\n }\n TimeZones$offset$ObjectLiteral.prototype.toDateTime_x2y23v$ = function (instant) {\n return this.closure$base.toDateTime_x2y23v$(instant.add_27523k$(this.closure$offset));\n };\n TimeZones$offset$ObjectLiteral.prototype.toInstant_amwj4p$ = function (dateTime) {\n return this.closure$base.toInstant_amwj4p$(dateTime).sub_27523k$(this.closure$offset);\n };\n TimeZones$offset$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZone]\n };\n TimeZones.prototype.offset_nf4kng$ = function (id, offset, base) {\n return new TimeZones$offset$ObjectLiteral(base, offset, id);\n };\n function TimeZones$withEuSummerTime$ObjectLiteral(closure$startSpec, closure$utcChangeTime, closure$endSpec, id, offset) {\n this.closure$startSpec = closure$startSpec;\n this.closure$utcChangeTime = closure$utcChangeTime;\n this.closure$endSpec = closure$endSpec;\n TimeZones$DSTimeZone.call(this, id, offset);\n }\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.getStartInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$startSpec.getDate_za3lpa$(year), this.closure$utcChangeTime));\n };\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.getEndInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$endSpec.getDate_za3lpa$(year), this.closure$utcChangeTime));\n };\n TimeZones$withEuSummerTime$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZones$DSTimeZone]\n };\n TimeZones.prototype.withEuSummerTime_rwkwum$ = function (id, offset) {\n var startSpec = DateSpecs_getInstance().last_kvq57g$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().MARCH);\n var endSpec = DateSpecs_getInstance().last_kvq57g$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().OCTOBER);\n var utcChangeTime = new Time(1, 0);\n return new TimeZones$withEuSummerTime$ObjectLiteral(startSpec, utcChangeTime, endSpec, id, offset);\n };\n function TimeZones$withUsSummerTime$ObjectLiteral(closure$startSpec, closure$offset, closure$endSpec, id, offset) {\n this.closure$startSpec = closure$startSpec;\n this.closure$offset = closure$offset;\n this.closure$endSpec = closure$endSpec;\n TimeZones$DSTimeZone.call(this, id, offset);\n }\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.getStartInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$startSpec.getDate_za3lpa$(year), new Time(2, 0))).sub_27523k$(this.closure$offset);\n };\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.getEndInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$endSpec.getDate_za3lpa$(year), new Time(2, 0))).sub_27523k$(this.closure$offset.add_27523k$(Duration$Companion_getInstance().HOUR));\n };\n TimeZones$withUsSummerTime$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZones$DSTimeZone]\n };\n TimeZones.prototype.withUsSummerTime_rwkwum$ = function (id, offset) {\n var startSpec = DateSpecs_getInstance().first_t96ihi$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().MARCH, 2);\n var endSpec = DateSpecs_getInstance().first_t96ihi$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().NOVEMBER);\n return new TimeZones$withUsSummerTime$ObjectLiteral(startSpec, offset, endSpec, id, offset);\n };\n function TimeZones$DSTimeZone(id, offset) {\n TimeZone.call(this, id);\n this.myTz_0 = TimeZones_getInstance().offset_nf4kng$(null, offset, TimeZone$Companion_getInstance().UTC);\n this.mySummerTz_0 = TimeZones_getInstance().offset_nf4kng$(null, offset.add_27523k$(Duration$Companion_getInstance().HOUR), TimeZone$Companion_getInstance().UTC);\n }\n TimeZones$DSTimeZone.prototype.toDateTime_x2y23v$ = function (instant) {\n var tmp$;\n var tzDt = this.myTz_0.toDateTime_x2y23v$(instant);\n var start = this.getStartInstant_za3lpa$(tzDt.year);\n var end = this.getEndInstant_za3lpa$(tzDt.year);\n if (instant.compareTo_11rb$(start) > 0 && instant.compareTo_11rb$(end) < 0) {\n tmp$ = this.mySummerTz_0.toDateTime_x2y23v$(instant);\n } else {\n tmp$ = tzDt;\n }\n return tmp$;\n };\n TimeZones$DSTimeZone.prototype.toInstant_amwj4p$ = function (dateTime) {\n var tmp$;\n var startDt = this.toDateTime_x2y23v$(this.getStartInstant_za3lpa$(dateTime.year));\n var endDt = this.toDateTime_x2y23v$(this.getEndInstant_za3lpa$(dateTime.year));\n if (dateTime.compareTo_11rb$(startDt) > 0 && dateTime.compareTo_11rb$(endDt) < 0) {\n tmp$ = this.mySummerTz_0.toInstant_amwj4p$(dateTime);\n } else {\n tmp$ = this.myTz_0.toInstant_amwj4p$(dateTime);\n }\n return tmp$;\n };\n TimeZones$DSTimeZone.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DSTimeZone',\n interfaces: [TimeZone]\n };\n TimeZones.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TimeZones',\n interfaces: []\n };\n var TimeZones_instance = null;\n function TimeZones_getInstance() {\n if (TimeZones_instance === null) {\n new TimeZones();\n }return TimeZones_instance;\n }\n function EnumInfo() {\n }\n EnumInfo.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EnumInfo',\n interfaces: []\n };\n function EnumInfoFactory() {\n EnumInfoFactory_instance = this;\n }\n EnumInfoFactory.prototype.createEnumInfo_nxd2ia$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.enums.EnumInfoFactory.createEnumInfo_nxd2ia$', wrapFunction(function () {\n var EnumInfoImpl_init = _.jetbrains.datalore.base.enums.EnumInfoImpl;\n return function (EnumT_0, isEnumT) {\n return new EnumInfoImpl_init(EnumT_0.values());\n };\n }));\n EnumInfoFactory.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'EnumInfoFactory',\n interfaces: []\n };\n var EnumInfoFactory_instance = null;\n function EnumInfoFactory_getInstance() {\n if (EnumInfoFactory_instance === null) {\n new EnumInfoFactory();\n }return EnumInfoFactory_instance;\n }\n function EnumInfoImpl(enumConstants) {\n this.myNormalizedValueMap_0 = null;\n this.myOriginalNames_0 = null;\n var tmp$;\n var numConstants = enumConstants.length;\n var valueMap = HashMap_init(numConstants);\n var originalNames = ArrayList_init_0(numConstants);\n for (tmp$ = 0; tmp$ !== enumConstants.length; ++tmp$) {\n var value = enumConstants[tmp$];\n var originalName = value.toString();\n originalNames.add_11rb$(originalName);\n var normalizedName = this.toNormalizedName_0(originalName);\n var oldValue = valueMap.put_xwzc9p$(normalizedName, value);\n if (oldValue != null) {\n throw IllegalArgumentException_init(\"duplicate values: '\" + value + \"', '\" + toString(oldValue) + \"'\");\n }}\n this.myOriginalNames_0 = originalNames;\n this.myNormalizedValueMap_0 = valueMap;\n }\n Object.defineProperty(EnumInfoImpl.prototype, 'originalNames', {\n configurable: true,\n get: function () {\n return this.myOriginalNames_0;\n }\n });\n EnumInfoImpl.prototype.toNormalizedName_0 = function (name) {\n return name.toUpperCase();\n };\n EnumInfoImpl.prototype.safeValueOf_7po0m$ = function (name, defaultValue) {\n var value = this.safeValueOf_pdl1vj$(name);\n return value != null ? value : defaultValue;\n };\n EnumInfoImpl.prototype.safeValueOf_pdl1vj$ = function (name) {\n var result;\n if (this.hasValue_pdl1vj$(name)) {\n result = this.myNormalizedValueMap_0.get_11rb$(this.toNormalizedName_0(ensureNotNull(name)));\n } else {\n result = null;\n }\n return result;\n };\n EnumInfoImpl.prototype.hasValue_pdl1vj$ = function (name) {\n return name != null && this.myNormalizedValueMap_0.containsKey_11rb$(this.toNormalizedName_0(name));\n };\n EnumInfoImpl.prototype.unsafeValueOf_61zpoe$ = function (name) {\n var tmp$;\n tmp$ = this.safeValueOf_pdl1vj$(name);\n if (tmp$ == null) {\n throw IllegalArgumentException_init(\"name not found: '\" + name + \"'\");\n }return tmp$;\n };\n EnumInfoImpl.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EnumInfoImpl',\n interfaces: [EnumInfo]\n };\n function Enums() {\n Enums_instance = this;\n }\n Enums.prototype.valueOf_a9gw98$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.enums.Enums.valueOf_a9gw98$', wrapFunction(function () {\n var equals = Kotlin.equals;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n return function (EnumT_0, isEnumT, name) {\n var tmp$, tmp$_0;\n tmp$ = EnumT_0.values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var e = tmp$[tmp$_0];\n if (equals(name, e.toString())) {\n return e;\n }}\n throw IllegalArgumentException_init(name);\n };\n }));\n Enums.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Enums',\n interfaces: []\n };\n var Enums_instance = null;\n function Enums_getInstance() {\n if (Enums_instance === null) {\n new Enums();\n }return Enums_instance;\n }\n function Button(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Button_initFields() {\n Button_initFields = function () {\n };\n Button$NONE_instance = new Button('NONE', 0);\n Button$LEFT_instance = new Button('LEFT', 1);\n Button$MIDDLE_instance = new Button('MIDDLE', 2);\n Button$RIGHT_instance = new Button('RIGHT', 3);\n }\n var Button$NONE_instance;\n function Button$NONE_getInstance() {\n Button_initFields();\n return Button$NONE_instance;\n }\n var Button$LEFT_instance;\n function Button$LEFT_getInstance() {\n Button_initFields();\n return Button$LEFT_instance;\n }\n var Button$MIDDLE_instance;\n function Button$MIDDLE_getInstance() {\n Button_initFields();\n return Button$MIDDLE_instance;\n }\n var Button$RIGHT_instance;\n function Button$RIGHT_getInstance() {\n Button_initFields();\n return Button$RIGHT_instance;\n }\n Button.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Button',\n interfaces: [Enum]\n };\n function Button$values() {\n return [Button$NONE_getInstance(), Button$LEFT_getInstance(), Button$MIDDLE_getInstance(), Button$RIGHT_getInstance()];\n }\n Button.values = Button$values;\n function Button$valueOf(name) {\n switch (name) {\n case 'NONE':\n return Button$NONE_getInstance();\n case 'LEFT':\n return Button$LEFT_getInstance();\n case 'MIDDLE':\n return Button$MIDDLE_getInstance();\n case 'RIGHT':\n return Button$RIGHT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.Button.' + name);\n }\n }\n Button.valueOf_61zpoe$ = Button$valueOf;\n function Event() {\n this.eventContext_qzl3re$_d6nbbo$_0 = null;\n this.isConsumed_gb68t5$_0 = false;\n }\n Object.defineProperty(Event.prototype, 'eventContext_qzl3re$_0', {\n configurable: true,\n get: function () {\n return this.eventContext_qzl3re$_d6nbbo$_0;\n },\n set: function (eventContext) {\n if (this.eventContext_qzl3re$_0 != null) {\n throw IllegalStateException_init('Already set ' + toString(ensureNotNull(this.eventContext_qzl3re$_0)));\n }if (this.isConsumed) {\n throw IllegalStateException_init(\"Can't set a context to the consumed event\");\n }if (eventContext == null) {\n throw IllegalArgumentException_init(\"Can't set null context\");\n }this.eventContext_qzl3re$_d6nbbo$_0 = eventContext;\n }\n });\n Object.defineProperty(Event.prototype, 'isConsumed', {\n configurable: true,\n get: function () {\n return this.isConsumed_gb68t5$_0;\n },\n set: function (isConsumed) {\n this.isConsumed_gb68t5$_0 = isConsumed;\n }\n });\n Event.prototype.consume = function () {\n this.doConsume_smptag$_0();\n };\n Event.prototype.doConsume_smptag$_0 = function () {\n if (this.isConsumed) {\n throw IllegalStateException_init_0();\n }this.isConsumed = true;\n };\n Event.prototype.ensureConsumed = function () {\n if (!this.isConsumed) {\n this.consume();\n }};\n Event.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Event',\n interfaces: []\n };\n function EventContext() {\n }\n EventContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventContext',\n interfaces: []\n };\n function Key(name, ordinal, myValue) {\n Enum.call(this);\n this.myValue_n4kdnj$_0 = myValue;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Key_initFields() {\n Key_initFields = function () {\n };\n Key$A_instance = new Key('A', 0, 'A');\n Key$B_instance = new Key('B', 1, 'B');\n Key$C_instance = new Key('C', 2, 'C');\n Key$D_instance = new Key('D', 3, 'D');\n Key$E_instance = new Key('E', 4, 'E');\n Key$F_instance = new Key('F', 5, 'F');\n Key$G_instance = new Key('G', 6, 'G');\n Key$H_instance = new Key('H', 7, 'H');\n Key$I_instance = new Key('I', 8, 'I');\n Key$J_instance = new Key('J', 9, 'J');\n Key$K_instance = new Key('K', 10, 'K');\n Key$L_instance = new Key('L', 11, 'L');\n Key$M_instance = new Key('M', 12, 'M');\n Key$N_instance = new Key('N', 13, 'N');\n Key$O_instance = new Key('O', 14, 'O');\n Key$P_instance = new Key('P', 15, 'P');\n Key$Q_instance = new Key('Q', 16, 'Q');\n Key$R_instance = new Key('R', 17, 'R');\n Key$S_instance = new Key('S', 18, 'S');\n Key$T_instance = new Key('T', 19, 'T');\n Key$U_instance = new Key('U', 20, 'U');\n Key$V_instance = new Key('V', 21, 'V');\n Key$W_instance = new Key('W', 22, 'W');\n Key$X_instance = new Key('X', 23, 'X');\n Key$Y_instance = new Key('Y', 24, 'Y');\n Key$Z_instance = new Key('Z', 25, 'Z');\n Key$DIGIT_0_instance = new Key('DIGIT_0', 26, '0');\n Key$DIGIT_1_instance = new Key('DIGIT_1', 27, '1');\n Key$DIGIT_2_instance = new Key('DIGIT_2', 28, '2');\n Key$DIGIT_3_instance = new Key('DIGIT_3', 29, '3');\n Key$DIGIT_4_instance = new Key('DIGIT_4', 30, '4');\n Key$DIGIT_5_instance = new Key('DIGIT_5', 31, '5');\n Key$DIGIT_6_instance = new Key('DIGIT_6', 32, '6');\n Key$DIGIT_7_instance = new Key('DIGIT_7', 33, '7');\n Key$DIGIT_8_instance = new Key('DIGIT_8', 34, '8');\n Key$DIGIT_9_instance = new Key('DIGIT_9', 35, '9');\n Key$LEFT_BRACE_instance = new Key('LEFT_BRACE', 36, '[');\n Key$RIGHT_BRACE_instance = new Key('RIGHT_BRACE', 37, ']');\n Key$UP_instance = new Key('UP', 38, 'Up');\n Key$DOWN_instance = new Key('DOWN', 39, 'Down');\n Key$LEFT_instance = new Key('LEFT', 40, 'Left');\n Key$RIGHT_instance = new Key('RIGHT', 41, 'Right');\n Key$PAGE_UP_instance = new Key('PAGE_UP', 42, 'Page Up');\n Key$PAGE_DOWN_instance = new Key('PAGE_DOWN', 43, 'Page Down');\n Key$ESCAPE_instance = new Key('ESCAPE', 44, 'Escape');\n Key$ENTER_instance = new Key('ENTER', 45, 'Enter');\n Key$HOME_instance = new Key('HOME', 46, 'Home');\n Key$END_instance = new Key('END', 47, 'End');\n Key$TAB_instance = new Key('TAB', 48, 'Tab');\n Key$SPACE_instance = new Key('SPACE', 49, 'Space');\n Key$INSERT_instance = new Key('INSERT', 50, 'Insert');\n Key$DELETE_instance = new Key('DELETE', 51, 'Delete');\n Key$BACKSPACE_instance = new Key('BACKSPACE', 52, 'Backspace');\n Key$EQUALS_instance = new Key('EQUALS', 53, 'Equals');\n Key$BACK_QUOTE_instance = new Key('BACK_QUOTE', 54, '`');\n Key$PLUS_instance = new Key('PLUS', 55, 'Plus');\n Key$MINUS_instance = new Key('MINUS', 56, 'Minus');\n Key$SLASH_instance = new Key('SLASH', 57, 'Slash');\n Key$CONTROL_instance = new Key('CONTROL', 58, 'Ctrl');\n Key$META_instance = new Key('META', 59, 'Meta');\n Key$ALT_instance = new Key('ALT', 60, 'Alt');\n Key$SHIFT_instance = new Key('SHIFT', 61, 'Shift');\n Key$UNKNOWN_instance = new Key('UNKNOWN', 62, '?');\n Key$F1_instance = new Key('F1', 63, 'F1');\n Key$F2_instance = new Key('F2', 64, 'F2');\n Key$F3_instance = new Key('F3', 65, 'F3');\n Key$F4_instance = new Key('F4', 66, 'F4');\n Key$F5_instance = new Key('F5', 67, 'F5');\n Key$F6_instance = new Key('F6', 68, 'F6');\n Key$F7_instance = new Key('F7', 69, 'F7');\n Key$F8_instance = new Key('F8', 70, 'F8');\n Key$F9_instance = new Key('F9', 71, 'F9');\n Key$F10_instance = new Key('F10', 72, 'F10');\n Key$F11_instance = new Key('F11', 73, 'F11');\n Key$F12_instance = new Key('F12', 74, 'F12');\n Key$COMMA_instance = new Key('COMMA', 75, ',');\n Key$PERIOD_instance = new Key('PERIOD', 76, '.');\n }\n var Key$A_instance;\n function Key$A_getInstance() {\n Key_initFields();\n return Key$A_instance;\n }\n var Key$B_instance;\n function Key$B_getInstance() {\n Key_initFields();\n return Key$B_instance;\n }\n var Key$C_instance;\n function Key$C_getInstance() {\n Key_initFields();\n return Key$C_instance;\n }\n var Key$D_instance;\n function Key$D_getInstance() {\n Key_initFields();\n return Key$D_instance;\n }\n var Key$E_instance;\n function Key$E_getInstance() {\n Key_initFields();\n return Key$E_instance;\n }\n var Key$F_instance;\n function Key$F_getInstance() {\n Key_initFields();\n return Key$F_instance;\n }\n var Key$G_instance;\n function Key$G_getInstance() {\n Key_initFields();\n return Key$G_instance;\n }\n var Key$H_instance;\n function Key$H_getInstance() {\n Key_initFields();\n return Key$H_instance;\n }\n var Key$I_instance;\n function Key$I_getInstance() {\n Key_initFields();\n return Key$I_instance;\n }\n var Key$J_instance;\n function Key$J_getInstance() {\n Key_initFields();\n return Key$J_instance;\n }\n var Key$K_instance;\n function Key$K_getInstance() {\n Key_initFields();\n return Key$K_instance;\n }\n var Key$L_instance;\n function Key$L_getInstance() {\n Key_initFields();\n return Key$L_instance;\n }\n var Key$M_instance;\n function Key$M_getInstance() {\n Key_initFields();\n return Key$M_instance;\n }\n var Key$N_instance;\n function Key$N_getInstance() {\n Key_initFields();\n return Key$N_instance;\n }\n var Key$O_instance;\n function Key$O_getInstance() {\n Key_initFields();\n return Key$O_instance;\n }\n var Key$P_instance;\n function Key$P_getInstance() {\n Key_initFields();\n return Key$P_instance;\n }\n var Key$Q_instance;\n function Key$Q_getInstance() {\n Key_initFields();\n return Key$Q_instance;\n }\n var Key$R_instance;\n function Key$R_getInstance() {\n Key_initFields();\n return Key$R_instance;\n }\n var Key$S_instance;\n function Key$S_getInstance() {\n Key_initFields();\n return Key$S_instance;\n }\n var Key$T_instance;\n function Key$T_getInstance() {\n Key_initFields();\n return Key$T_instance;\n }\n var Key$U_instance;\n function Key$U_getInstance() {\n Key_initFields();\n return Key$U_instance;\n }\n var Key$V_instance;\n function Key$V_getInstance() {\n Key_initFields();\n return Key$V_instance;\n }\n var Key$W_instance;\n function Key$W_getInstance() {\n Key_initFields();\n return Key$W_instance;\n }\n var Key$X_instance;\n function Key$X_getInstance() {\n Key_initFields();\n return Key$X_instance;\n }\n var Key$Y_instance;\n function Key$Y_getInstance() {\n Key_initFields();\n return Key$Y_instance;\n }\n var Key$Z_instance;\n function Key$Z_getInstance() {\n Key_initFields();\n return Key$Z_instance;\n }\n var Key$DIGIT_0_instance;\n function Key$DIGIT_0_getInstance() {\n Key_initFields();\n return Key$DIGIT_0_instance;\n }\n var Key$DIGIT_1_instance;\n function Key$DIGIT_1_getInstance() {\n Key_initFields();\n return Key$DIGIT_1_instance;\n }\n var Key$DIGIT_2_instance;\n function Key$DIGIT_2_getInstance() {\n Key_initFields();\n return Key$DIGIT_2_instance;\n }\n var Key$DIGIT_3_instance;\n function Key$DIGIT_3_getInstance() {\n Key_initFields();\n return Key$DIGIT_3_instance;\n }\n var Key$DIGIT_4_instance;\n function Key$DIGIT_4_getInstance() {\n Key_initFields();\n return Key$DIGIT_4_instance;\n }\n var Key$DIGIT_5_instance;\n function Key$DIGIT_5_getInstance() {\n Key_initFields();\n return Key$DIGIT_5_instance;\n }\n var Key$DIGIT_6_instance;\n function Key$DIGIT_6_getInstance() {\n Key_initFields();\n return Key$DIGIT_6_instance;\n }\n var Key$DIGIT_7_instance;\n function Key$DIGIT_7_getInstance() {\n Key_initFields();\n return Key$DIGIT_7_instance;\n }\n var Key$DIGIT_8_instance;\n function Key$DIGIT_8_getInstance() {\n Key_initFields();\n return Key$DIGIT_8_instance;\n }\n var Key$DIGIT_9_instance;\n function Key$DIGIT_9_getInstance() {\n Key_initFields();\n return Key$DIGIT_9_instance;\n }\n var Key$LEFT_BRACE_instance;\n function Key$LEFT_BRACE_getInstance() {\n Key_initFields();\n return Key$LEFT_BRACE_instance;\n }\n var Key$RIGHT_BRACE_instance;\n function Key$RIGHT_BRACE_getInstance() {\n Key_initFields();\n return Key$RIGHT_BRACE_instance;\n }\n var Key$UP_instance;\n function Key$UP_getInstance() {\n Key_initFields();\n return Key$UP_instance;\n }\n var Key$DOWN_instance;\n function Key$DOWN_getInstance() {\n Key_initFields();\n return Key$DOWN_instance;\n }\n var Key$LEFT_instance;\n function Key$LEFT_getInstance() {\n Key_initFields();\n return Key$LEFT_instance;\n }\n var Key$RIGHT_instance;\n function Key$RIGHT_getInstance() {\n Key_initFields();\n return Key$RIGHT_instance;\n }\n var Key$PAGE_UP_instance;\n function Key$PAGE_UP_getInstance() {\n Key_initFields();\n return Key$PAGE_UP_instance;\n }\n var Key$PAGE_DOWN_instance;\n function Key$PAGE_DOWN_getInstance() {\n Key_initFields();\n return Key$PAGE_DOWN_instance;\n }\n var Key$ESCAPE_instance;\n function Key$ESCAPE_getInstance() {\n Key_initFields();\n return Key$ESCAPE_instance;\n }\n var Key$ENTER_instance;\n function Key$ENTER_getInstance() {\n Key_initFields();\n return Key$ENTER_instance;\n }\n var Key$HOME_instance;\n function Key$HOME_getInstance() {\n Key_initFields();\n return Key$HOME_instance;\n }\n var Key$END_instance;\n function Key$END_getInstance() {\n Key_initFields();\n return Key$END_instance;\n }\n var Key$TAB_instance;\n function Key$TAB_getInstance() {\n Key_initFields();\n return Key$TAB_instance;\n }\n var Key$SPACE_instance;\n function Key$SPACE_getInstance() {\n Key_initFields();\n return Key$SPACE_instance;\n }\n var Key$INSERT_instance;\n function Key$INSERT_getInstance() {\n Key_initFields();\n return Key$INSERT_instance;\n }\n var Key$DELETE_instance;\n function Key$DELETE_getInstance() {\n Key_initFields();\n return Key$DELETE_instance;\n }\n var Key$BACKSPACE_instance;\n function Key$BACKSPACE_getInstance() {\n Key_initFields();\n return Key$BACKSPACE_instance;\n }\n var Key$EQUALS_instance;\n function Key$EQUALS_getInstance() {\n Key_initFields();\n return Key$EQUALS_instance;\n }\n var Key$BACK_QUOTE_instance;\n function Key$BACK_QUOTE_getInstance() {\n Key_initFields();\n return Key$BACK_QUOTE_instance;\n }\n var Key$PLUS_instance;\n function Key$PLUS_getInstance() {\n Key_initFields();\n return Key$PLUS_instance;\n }\n var Key$MINUS_instance;\n function Key$MINUS_getInstance() {\n Key_initFields();\n return Key$MINUS_instance;\n }\n var Key$SLASH_instance;\n function Key$SLASH_getInstance() {\n Key_initFields();\n return Key$SLASH_instance;\n }\n var Key$CONTROL_instance;\n function Key$CONTROL_getInstance() {\n Key_initFields();\n return Key$CONTROL_instance;\n }\n var Key$META_instance;\n function Key$META_getInstance() {\n Key_initFields();\n return Key$META_instance;\n }\n var Key$ALT_instance;\n function Key$ALT_getInstance() {\n Key_initFields();\n return Key$ALT_instance;\n }\n var Key$SHIFT_instance;\n function Key$SHIFT_getInstance() {\n Key_initFields();\n return Key$SHIFT_instance;\n }\n var Key$UNKNOWN_instance;\n function Key$UNKNOWN_getInstance() {\n Key_initFields();\n return Key$UNKNOWN_instance;\n }\n var Key$F1_instance;\n function Key$F1_getInstance() {\n Key_initFields();\n return Key$F1_instance;\n }\n var Key$F2_instance;\n function Key$F2_getInstance() {\n Key_initFields();\n return Key$F2_instance;\n }\n var Key$F3_instance;\n function Key$F3_getInstance() {\n Key_initFields();\n return Key$F3_instance;\n }\n var Key$F4_instance;\n function Key$F4_getInstance() {\n Key_initFields();\n return Key$F4_instance;\n }\n var Key$F5_instance;\n function Key$F5_getInstance() {\n Key_initFields();\n return Key$F5_instance;\n }\n var Key$F6_instance;\n function Key$F6_getInstance() {\n Key_initFields();\n return Key$F6_instance;\n }\n var Key$F7_instance;\n function Key$F7_getInstance() {\n Key_initFields();\n return Key$F7_instance;\n }\n var Key$F8_instance;\n function Key$F8_getInstance() {\n Key_initFields();\n return Key$F8_instance;\n }\n var Key$F9_instance;\n function Key$F9_getInstance() {\n Key_initFields();\n return Key$F9_instance;\n }\n var Key$F10_instance;\n function Key$F10_getInstance() {\n Key_initFields();\n return Key$F10_instance;\n }\n var Key$F11_instance;\n function Key$F11_getInstance() {\n Key_initFields();\n return Key$F11_instance;\n }\n var Key$F12_instance;\n function Key$F12_getInstance() {\n Key_initFields();\n return Key$F12_instance;\n }\n var Key$COMMA_instance;\n function Key$COMMA_getInstance() {\n Key_initFields();\n return Key$COMMA_instance;\n }\n var Key$PERIOD_instance;\n function Key$PERIOD_getInstance() {\n Key_initFields();\n return Key$PERIOD_instance;\n }\n Key.prototype.toString = function () {\n return this.myValue_n4kdnj$_0;\n };\n Key.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Key',\n interfaces: [Enum]\n };\n function Key$values() {\n return [Key$A_getInstance(), Key$B_getInstance(), Key$C_getInstance(), Key$D_getInstance(), Key$E_getInstance(), Key$F_getInstance(), Key$G_getInstance(), Key$H_getInstance(), Key$I_getInstance(), Key$J_getInstance(), Key$K_getInstance(), Key$L_getInstance(), Key$M_getInstance(), Key$N_getInstance(), Key$O_getInstance(), Key$P_getInstance(), Key$Q_getInstance(), Key$R_getInstance(), Key$S_getInstance(), Key$T_getInstance(), Key$U_getInstance(), Key$V_getInstance(), Key$W_getInstance(), Key$X_getInstance(), Key$Y_getInstance(), Key$Z_getInstance(), Key$DIGIT_0_getInstance(), Key$DIGIT_1_getInstance(), Key$DIGIT_2_getInstance(), Key$DIGIT_3_getInstance(), Key$DIGIT_4_getInstance(), Key$DIGIT_5_getInstance(), Key$DIGIT_6_getInstance(), Key$DIGIT_7_getInstance(), Key$DIGIT_8_getInstance(), Key$DIGIT_9_getInstance(), Key$LEFT_BRACE_getInstance(), Key$RIGHT_BRACE_getInstance(), Key$UP_getInstance(), Key$DOWN_getInstance(), Key$LEFT_getInstance(), Key$RIGHT_getInstance(), Key$PAGE_UP_getInstance(), Key$PAGE_DOWN_getInstance(), Key$ESCAPE_getInstance(), Key$ENTER_getInstance(), Key$HOME_getInstance(), Key$END_getInstance(), Key$TAB_getInstance(), Key$SPACE_getInstance(), Key$INSERT_getInstance(), Key$DELETE_getInstance(), Key$BACKSPACE_getInstance(), Key$EQUALS_getInstance(), Key$BACK_QUOTE_getInstance(), Key$PLUS_getInstance(), Key$MINUS_getInstance(), Key$SLASH_getInstance(), Key$CONTROL_getInstance(), Key$META_getInstance(), Key$ALT_getInstance(), Key$SHIFT_getInstance(), Key$UNKNOWN_getInstance(), Key$F1_getInstance(), Key$F2_getInstance(), Key$F3_getInstance(), Key$F4_getInstance(), Key$F5_getInstance(), Key$F6_getInstance(), Key$F7_getInstance(), Key$F8_getInstance(), Key$F9_getInstance(), Key$F10_getInstance(), Key$F11_getInstance(), Key$F12_getInstance(), Key$COMMA_getInstance(), Key$PERIOD_getInstance()];\n }\n Key.values = Key$values;\n function Key$valueOf(name) {\n switch (name) {\n case 'A':\n return Key$A_getInstance();\n case 'B':\n return Key$B_getInstance();\n case 'C':\n return Key$C_getInstance();\n case 'D':\n return Key$D_getInstance();\n case 'E':\n return Key$E_getInstance();\n case 'F':\n return Key$F_getInstance();\n case 'G':\n return Key$G_getInstance();\n case 'H':\n return Key$H_getInstance();\n case 'I':\n return Key$I_getInstance();\n case 'J':\n return Key$J_getInstance();\n case 'K':\n return Key$K_getInstance();\n case 'L':\n return Key$L_getInstance();\n case 'M':\n return Key$M_getInstance();\n case 'N':\n return Key$N_getInstance();\n case 'O':\n return Key$O_getInstance();\n case 'P':\n return Key$P_getInstance();\n case 'Q':\n return Key$Q_getInstance();\n case 'R':\n return Key$R_getInstance();\n case 'S':\n return Key$S_getInstance();\n case 'T':\n return Key$T_getInstance();\n case 'U':\n return Key$U_getInstance();\n case 'V':\n return Key$V_getInstance();\n case 'W':\n return Key$W_getInstance();\n case 'X':\n return Key$X_getInstance();\n case 'Y':\n return Key$Y_getInstance();\n case 'Z':\n return Key$Z_getInstance();\n case 'DIGIT_0':\n return Key$DIGIT_0_getInstance();\n case 'DIGIT_1':\n return Key$DIGIT_1_getInstance();\n case 'DIGIT_2':\n return Key$DIGIT_2_getInstance();\n case 'DIGIT_3':\n return Key$DIGIT_3_getInstance();\n case 'DIGIT_4':\n return Key$DIGIT_4_getInstance();\n case 'DIGIT_5':\n return Key$DIGIT_5_getInstance();\n case 'DIGIT_6':\n return Key$DIGIT_6_getInstance();\n case 'DIGIT_7':\n return Key$DIGIT_7_getInstance();\n case 'DIGIT_8':\n return Key$DIGIT_8_getInstance();\n case 'DIGIT_9':\n return Key$DIGIT_9_getInstance();\n case 'LEFT_BRACE':\n return Key$LEFT_BRACE_getInstance();\n case 'RIGHT_BRACE':\n return Key$RIGHT_BRACE_getInstance();\n case 'UP':\n return Key$UP_getInstance();\n case 'DOWN':\n return Key$DOWN_getInstance();\n case 'LEFT':\n return Key$LEFT_getInstance();\n case 'RIGHT':\n return Key$RIGHT_getInstance();\n case 'PAGE_UP':\n return Key$PAGE_UP_getInstance();\n case 'PAGE_DOWN':\n return Key$PAGE_DOWN_getInstance();\n case 'ESCAPE':\n return Key$ESCAPE_getInstance();\n case 'ENTER':\n return Key$ENTER_getInstance();\n case 'HOME':\n return Key$HOME_getInstance();\n case 'END':\n return Key$END_getInstance();\n case 'TAB':\n return Key$TAB_getInstance();\n case 'SPACE':\n return Key$SPACE_getInstance();\n case 'INSERT':\n return Key$INSERT_getInstance();\n case 'DELETE':\n return Key$DELETE_getInstance();\n case 'BACKSPACE':\n return Key$BACKSPACE_getInstance();\n case 'EQUALS':\n return Key$EQUALS_getInstance();\n case 'BACK_QUOTE':\n return Key$BACK_QUOTE_getInstance();\n case 'PLUS':\n return Key$PLUS_getInstance();\n case 'MINUS':\n return Key$MINUS_getInstance();\n case 'SLASH':\n return Key$SLASH_getInstance();\n case 'CONTROL':\n return Key$CONTROL_getInstance();\n case 'META':\n return Key$META_getInstance();\n case 'ALT':\n return Key$ALT_getInstance();\n case 'SHIFT':\n return Key$SHIFT_getInstance();\n case 'UNKNOWN':\n return Key$UNKNOWN_getInstance();\n case 'F1':\n return Key$F1_getInstance();\n case 'F2':\n return Key$F2_getInstance();\n case 'F3':\n return Key$F3_getInstance();\n case 'F4':\n return Key$F4_getInstance();\n case 'F5':\n return Key$F5_getInstance();\n case 'F6':\n return Key$F6_getInstance();\n case 'F7':\n return Key$F7_getInstance();\n case 'F8':\n return Key$F8_getInstance();\n case 'F9':\n return Key$F9_getInstance();\n case 'F10':\n return Key$F10_getInstance();\n case 'F11':\n return Key$F11_getInstance();\n case 'F12':\n return Key$F12_getInstance();\n case 'COMMA':\n return Key$COMMA_getInstance();\n case 'PERIOD':\n return Key$PERIOD_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.Key.' + name);\n }\n }\n Key.valueOf_61zpoe$ = Key$valueOf;\n function KeyEvent() {\n this.keyStroke = null;\n this.keyChar = null;\n }\n Object.defineProperty(KeyEvent.prototype, 'key', {\n configurable: true,\n get: function () {\n return this.keyStroke.key;\n }\n });\n Object.defineProperty(KeyEvent.prototype, 'modifiers', {\n configurable: true,\n get: function () {\n return this.keyStroke.modifiers;\n }\n });\n KeyEvent.prototype.is_ji7i3y$ = function (key, modifiers) {\n return this.keyStroke.is_ji7i3y$(key, modifiers.slice());\n };\n KeyEvent.prototype.is_c4rqdo$ = function (specs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var s = specs[tmp$];\n if (s.matches_l9pgtg$(this.keyStroke))\n return true;\n }\n return false;\n };\n KeyEvent.prototype.is_4t3vif$ = function (specs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var s = specs[tmp$];\n if (s.matches_l9pgtg$(this.keyStroke))\n return true;\n }\n return false;\n };\n KeyEvent.prototype.has_hny0b7$ = function (key) {\n return this.keyStroke.has_hny0b7$(key);\n };\n KeyEvent.prototype.copy = function () {\n return KeyEvent_init_1(this.key, unboxChar(this.keyChar), this.modifiers);\n };\n KeyEvent.prototype.toString = function () {\n return this.keyStroke.toString();\n };\n KeyEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyEvent',\n interfaces: [Event]\n };\n function KeyEvent_init(keyStroke, $this) {\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = keyStroke;\n $this.keyChar = toChar(0);\n return $this;\n }\n function KeyEvent_init_0(key, ch, $this) {\n if (ch === void 0)\n ch = toChar(0);\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = KeyStroke_init_0(key, emptyList());\n $this.keyChar = ch;\n return $this;\n }\n function KeyEvent_init_1(key, ch, modifiers, $this) {\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = KeyStroke_init_0(key, modifiers);\n $this.keyChar = ch;\n return $this;\n }\n function KeyModifiers(isCtrl, isAlt, isShift, isMeta) {\n KeyModifiers$Companion_getInstance();\n this.isCtrl = isCtrl;\n this.isAlt = isAlt;\n this.isShift = isShift;\n this.isMeta = isMeta;\n }\n function KeyModifiers$Companion() {\n KeyModifiers$Companion_instance = this;\n this.EMPTY_MODIFIERS_0 = KeyModifiers_init();\n }\n KeyModifiers$Companion.prototype.emptyModifiers = function () {\n return this.EMPTY_MODIFIERS_0;\n };\n KeyModifiers$Companion.prototype.withShift = function () {\n return new KeyModifiers(false, false, true, false);\n };\n KeyModifiers$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var KeyModifiers$Companion_instance = null;\n function KeyModifiers$Companion_getInstance() {\n if (KeyModifiers$Companion_instance === null) {\n new KeyModifiers$Companion();\n }return KeyModifiers$Companion_instance;\n }\n KeyModifiers.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyModifiers',\n interfaces: []\n };\n function KeyModifiers_init($this) {\n $this = $this || Object.create(KeyModifiers.prototype);\n KeyModifiers.call($this, false, false, false, false);\n return $this;\n }\n function KeyStroke() {\n this.key = null;\n this.modifiers = null;\n }\n KeyStroke.prototype.has_hny0b7$ = function (key) {\n return this.modifiers.contains_11rb$(key);\n };\n KeyStroke.prototype.is_ji7i3y$ = function (key, modifiers) {\n return this.matches_l9pgtg$(KeyStroke_init(key, modifiers.slice()));\n };\n KeyStroke.prototype.matches_l9pgtg$ = function (keyStroke) {\n return this.equals(keyStroke);\n };\n KeyStroke.prototype.with_hny0b7$ = function (key) {\n var keys = HashSet_init(this.modifiers);\n keys.add_11rb$(key);\n return KeyStroke_init_0(this.key, keys);\n };\n KeyStroke.prototype.hashCode = function () {\n return (this.key.hashCode() * 31 | 0) + hashCode(this.modifiers) | 0;\n };\n KeyStroke.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, KeyStroke))\n return false;\n var otherKeyStroke = (tmp$ = other) == null || Kotlin.isType(tmp$, KeyStroke) ? tmp$ : throwCCE();\n return this.key === ensureNotNull(otherKeyStroke).key && equals(this.modifiers, ensureNotNull(otherKeyStroke).modifiers);\n };\n KeyStroke.prototype.toString = function () {\n return this.key.toString() + ' ' + this.modifiers;\n };\n KeyStroke.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyStroke',\n interfaces: []\n };\n function KeyStroke_init(key, modifiers, $this) {\n $this = $this || Object.create(KeyStroke.prototype);\n KeyStroke_init_0(key, asList(modifiers), $this);\n return $this;\n }\n function KeyStroke_init_0(key, modifiers, $this) {\n $this = $this || Object.create(KeyStroke.prototype);\n KeyStroke.call($this);\n $this.key = key;\n $this.modifiers = HashSet_init(modifiers);\n return $this;\n }\n function KeyStrokeSpec() {\n this.myKeyStrokes_0 = null;\n }\n Object.defineProperty(KeyStrokeSpec.prototype, 'keyStrokes', {\n configurable: true,\n get: function () {\n return listOf(this.myKeyStrokes_0.slice());\n }\n });\n Object.defineProperty(KeyStrokeSpec.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myKeyStrokes_0.length === 0;\n }\n });\n KeyStrokeSpec.prototype.matches_l9pgtg$ = function (keyStroke) {\n var tmp$, tmp$_0;\n tmp$ = this.myKeyStrokes_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var spec = tmp$[tmp$_0];\n if (spec.matches_l9pgtg$(keyStroke)) {\n return true;\n }}\n return false;\n };\n KeyStrokeSpec.prototype.with_hny0b7$ = function (key) {\n var tmp$, tmp$_0;\n var modified = ArrayList_init();\n tmp$ = this.myKeyStrokes_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var keyStroke = tmp$[tmp$_0];\n modified.add_11rb$(keyStroke.with_hny0b7$(key));\n }\n return KeyStrokeSpec_init_0(modified);\n };\n KeyStrokeSpec.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, KeyStrokeSpec) ? tmp$_0 : throwCCE();\n return equals(this.keyStrokes, ensureNotNull(that).keyStrokes);\n };\n KeyStrokeSpec.prototype.hashCode = function () {\n return hashCode(this.keyStrokes);\n };\n KeyStrokeSpec.prototype.toString = function () {\n return this.keyStrokes.toString();\n };\n KeyStrokeSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyStrokeSpec',\n interfaces: []\n };\n function KeyStrokeSpec_init(key, modifiers, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = [KeyStroke_init(key, modifiers.slice())];\n return $this;\n }\n function KeyStrokeSpec_init_0(keyStrokes, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = copyToArray(keyStrokes);\n return $this;\n }\n function KeyStrokeSpec_init_1(keyStrokes, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = keyStrokes.slice();\n return $this;\n }\n function KeyStrokeSpecs() {\n KeyStrokeSpecs_instance = this;\n this.COPY = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$C_getInstance(), []), KeyStrokeSpec_init(Key$INSERT_getInstance(), [ModifierKey$CONTROL_getInstance()])]);\n this.CUT = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$X_getInstance(), []), KeyStrokeSpec_init(Key$DELETE_getInstance(), [ModifierKey$SHIFT_getInstance()])]);\n this.PASTE = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$V_getInstance(), []), KeyStrokeSpec_init(Key$INSERT_getInstance(), [ModifierKey$SHIFT_getInstance()])]);\n this.UNDO = this.ctrlOrMeta_ji7i3y$(Key$Z_getInstance(), []);\n this.REDO = this.UNDO.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.COMPLETE = KeyStrokeSpec_init(Key$SPACE_getInstance(), [ModifierKey$CONTROL_getInstance()]);\n this.SHOW_DOC = this.composite_c4rqdo$([KeyStrokeSpec_init(Key$F1_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$J_getInstance(), [])]);\n this.HELP = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$I_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$F1_getInstance(), [])]);\n this.HOME = this.composite_4t3vif$([KeyStroke_init(Key$HOME_getInstance(), []), KeyStroke_init(Key$LEFT_getInstance(), [ModifierKey$META_getInstance()])]);\n this.END = this.composite_4t3vif$([KeyStroke_init(Key$END_getInstance(), []), KeyStroke_init(Key$RIGHT_getInstance(), [ModifierKey$META_getInstance()])]);\n this.FILE_HOME = this.ctrlOrMeta_ji7i3y$(Key$HOME_getInstance(), []);\n this.FILE_END = this.ctrlOrMeta_ji7i3y$(Key$END_getInstance(), []);\n this.PREV_WORD = this.ctrlOrAlt_ji7i3y$(Key$LEFT_getInstance(), []);\n this.NEXT_WORD = this.ctrlOrAlt_ji7i3y$(Key$RIGHT_getInstance(), []);\n this.NEXT_EDITABLE = this.ctrlOrMeta_ji7i3y$(Key$RIGHT_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.PREV_EDITABLE = this.ctrlOrMeta_ji7i3y$(Key$LEFT_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.SELECT_ALL = this.ctrlOrMeta_ji7i3y$(Key$A_getInstance(), []);\n this.SELECT_FILE_HOME = this.FILE_HOME.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_FILE_END = this.FILE_END.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_HOME = this.HOME.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_END = this.END.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_WORD_FORWARD = this.NEXT_WORD.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_WORD_BACKWARD = this.PREV_WORD.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_LEFT = KeyStrokeSpec_init(Key$LEFT_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_RIGHT = KeyStrokeSpec_init(Key$RIGHT_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_UP = KeyStrokeSpec_init(Key$UP_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_DOWN = KeyStrokeSpec_init(Key$DOWN_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.INCREASE_SELECTION = KeyStrokeSpec_init(Key$UP_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.DECREASE_SELECTION = KeyStrokeSpec_init(Key$DOWN_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.INSERT_BEFORE = this.composite_4t3vif$([KeyStroke_init_0(Key$ENTER_getInstance(), this.add_0(ModifierKey$META_getInstance(), [])), KeyStroke_init(Key$INSERT_getInstance(), []), KeyStroke_init_0(Key$ENTER_getInstance(), this.add_0(ModifierKey$CONTROL_getInstance(), []))]);\n this.INSERT_AFTER = KeyStrokeSpec_init(Key$ENTER_getInstance(), []);\n this.INSERT = this.composite_c4rqdo$([this.INSERT_BEFORE, this.INSERT_AFTER]);\n this.DUPLICATE = this.ctrlOrMeta_ji7i3y$(Key$D_getInstance(), []);\n this.DELETE_CURRENT = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$BACKSPACE_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$DELETE_getInstance(), [])]);\n this.DELETE_TO_WORD_START = KeyStrokeSpec_init(Key$BACKSPACE_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.MATCHING_CONSTRUCTS = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$LEFT_BRACE_getInstance(), [ModifierKey$ALT_getInstance()]), this.ctrlOrMeta_ji7i3y$(Key$RIGHT_BRACE_getInstance(), [ModifierKey$ALT_getInstance()])]);\n this.NAVIGATE = this.ctrlOrMeta_ji7i3y$(Key$B_getInstance(), []);\n this.NAVIGATE_BACK = this.ctrlOrMeta_ji7i3y$(Key$LEFT_BRACE_getInstance(), []);\n this.NAVIGATE_FORWARD = this.ctrlOrMeta_ji7i3y$(Key$RIGHT_BRACE_getInstance(), []);\n }\n KeyStrokeSpecs.prototype.ctrlOrMeta_ji7i3y$ = function (key, modifiers) {\n return this.composite_4t3vif$([KeyStroke_init_0(key, this.add_0(ModifierKey$CONTROL_getInstance(), modifiers.slice())), KeyStroke_init_0(key, this.add_0(ModifierKey$META_getInstance(), modifiers.slice()))]);\n };\n KeyStrokeSpecs.prototype.ctrlOrAlt_ji7i3y$ = function (key, modifiers) {\n return this.composite_4t3vif$([KeyStroke_init_0(key, this.add_0(ModifierKey$CONTROL_getInstance(), modifiers.slice())), KeyStroke_init_0(key, this.add_0(ModifierKey$ALT_getInstance(), modifiers.slice()))]);\n };\n KeyStrokeSpecs.prototype.add_0 = function (key, otherKeys) {\n var result = HashSet_init(asList(otherKeys));\n result.add_11rb$(key);\n return result;\n };\n KeyStrokeSpecs.prototype.composite_c4rqdo$ = function (specs) {\n var tmp$, tmp$_0;\n var keyStrokes = HashSet_init_0();\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var spec = specs[tmp$];\n tmp$_0 = spec.keyStrokes.iterator();\n while (tmp$_0.hasNext()) {\n var ks = tmp$_0.next();\n keyStrokes.add_11rb$(ks);\n }\n }\n return KeyStrokeSpec_init_0(keyStrokes);\n };\n KeyStrokeSpecs.prototype.composite_4t3vif$ = function (specs) {\n return KeyStrokeSpec_init_1(specs.slice());\n };\n KeyStrokeSpecs.prototype.withoutShift_b0jlop$ = function (spec) {\n var tmp$;\n var keyStroke = spec.keyStrokes.iterator().next();\n var modifiers = keyStroke.modifiers;\n var withoutShift = HashSet_init_0();\n tmp$ = modifiers.iterator();\n while (tmp$.hasNext()) {\n var modifier = tmp$.next();\n if (modifier !== ModifierKey$SHIFT_getInstance()) {\n withoutShift.add_11rb$(modifier);\n }}\n return KeyEvent_init_1(keyStroke.key, toChar(0), withoutShift);\n };\n KeyStrokeSpecs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'KeyStrokeSpecs',\n interfaces: []\n };\n var KeyStrokeSpecs_instance = null;\n function KeyStrokeSpecs_getInstance() {\n if (KeyStrokeSpecs_instance === null) {\n new KeyStrokeSpecs();\n }return KeyStrokeSpecs_instance;\n }\n function ModifierKey(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ModifierKey_initFields() {\n ModifierKey_initFields = function () {\n };\n ModifierKey$CONTROL_instance = new ModifierKey('CONTROL', 0);\n ModifierKey$ALT_instance = new ModifierKey('ALT', 1);\n ModifierKey$SHIFT_instance = new ModifierKey('SHIFT', 2);\n ModifierKey$META_instance = new ModifierKey('META', 3);\n }\n var ModifierKey$CONTROL_instance;\n function ModifierKey$CONTROL_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$CONTROL_instance;\n }\n var ModifierKey$ALT_instance;\n function ModifierKey$ALT_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$ALT_instance;\n }\n var ModifierKey$SHIFT_instance;\n function ModifierKey$SHIFT_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$SHIFT_instance;\n }\n var ModifierKey$META_instance;\n function ModifierKey$META_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$META_instance;\n }\n ModifierKey.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ModifierKey',\n interfaces: [Enum]\n };\n function ModifierKey$values() {\n return [ModifierKey$CONTROL_getInstance(), ModifierKey$ALT_getInstance(), ModifierKey$SHIFT_getInstance(), ModifierKey$META_getInstance()];\n }\n ModifierKey.values = ModifierKey$values;\n function ModifierKey$valueOf(name) {\n switch (name) {\n case 'CONTROL':\n return ModifierKey$CONTROL_getInstance();\n case 'ALT':\n return ModifierKey$ALT_getInstance();\n case 'SHIFT':\n return ModifierKey$SHIFT_getInstance();\n case 'META':\n return ModifierKey$META_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.ModifierKey.' + name);\n }\n }\n ModifierKey.valueOf_61zpoe$ = ModifierKey$valueOf;\n function MouseEvent(x, y, button, modifiers) {\n MouseEvent$Companion_getInstance();\n PointEvent.call(this, x, y);\n this.button = button;\n this.modifiers = modifiers;\n if (this.button == null) {\n var message = 'Null button';\n throw IllegalArgumentException_init(message.toString());\n }}\n function MouseEvent$Companion() {\n MouseEvent$Companion_instance = this;\n }\n MouseEvent$Companion.prototype.noButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$NONE_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.leftButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$LEFT_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.middleButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$MIDDLE_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.rightButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$RIGHT_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MouseEvent$Companion_instance = null;\n function MouseEvent$Companion_getInstance() {\n if (MouseEvent$Companion_instance === null) {\n new MouseEvent$Companion();\n }return MouseEvent$Companion_instance;\n }\n MouseEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEvent',\n interfaces: [PointEvent]\n };\n function MouseEvent_init(v, button, modifiers, $this) {\n $this = $this || Object.create(MouseEvent.prototype);\n MouseEvent.call($this, v.x, v.y, button, modifiers);\n return $this;\n }\n function MouseEventSource() {\n }\n MouseEventSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MouseEventSource',\n interfaces: []\n };\n function MouseEventSpec(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MouseEventSpec_initFields() {\n MouseEventSpec_initFields = function () {\n };\n MouseEventSpec$MOUSE_ENTERED_instance = new MouseEventSpec('MOUSE_ENTERED', 0);\n MouseEventSpec$MOUSE_LEFT_instance = new MouseEventSpec('MOUSE_LEFT', 1);\n MouseEventSpec$MOUSE_MOVED_instance = new MouseEventSpec('MOUSE_MOVED', 2);\n MouseEventSpec$MOUSE_DRAGGED_instance = new MouseEventSpec('MOUSE_DRAGGED', 3);\n MouseEventSpec$MOUSE_CLICKED_instance = new MouseEventSpec('MOUSE_CLICKED', 4);\n MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance = new MouseEventSpec('MOUSE_DOUBLE_CLICKED', 5);\n MouseEventSpec$MOUSE_PRESSED_instance = new MouseEventSpec('MOUSE_PRESSED', 6);\n MouseEventSpec$MOUSE_RELEASED_instance = new MouseEventSpec('MOUSE_RELEASED', 7);\n }\n var MouseEventSpec$MOUSE_ENTERED_instance;\n function MouseEventSpec$MOUSE_ENTERED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_ENTERED_instance;\n }\n var MouseEventSpec$MOUSE_LEFT_instance;\n function MouseEventSpec$MOUSE_LEFT_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_LEFT_instance;\n }\n var MouseEventSpec$MOUSE_MOVED_instance;\n function MouseEventSpec$MOUSE_MOVED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_MOVED_instance;\n }\n var MouseEventSpec$MOUSE_DRAGGED_instance;\n function MouseEventSpec$MOUSE_DRAGGED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_DRAGGED_instance;\n }\n var MouseEventSpec$MOUSE_CLICKED_instance;\n function MouseEventSpec$MOUSE_CLICKED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_CLICKED_instance;\n }\n var MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance;\n function MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance;\n }\n var MouseEventSpec$MOUSE_PRESSED_instance;\n function MouseEventSpec$MOUSE_PRESSED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_PRESSED_instance;\n }\n var MouseEventSpec$MOUSE_RELEASED_instance;\n function MouseEventSpec$MOUSE_RELEASED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_RELEASED_instance;\n }\n MouseEventSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEventSpec',\n interfaces: [Enum]\n };\n function MouseEventSpec$values() {\n return [MouseEventSpec$MOUSE_ENTERED_getInstance(), MouseEventSpec$MOUSE_LEFT_getInstance(), MouseEventSpec$MOUSE_MOVED_getInstance(), MouseEventSpec$MOUSE_DRAGGED_getInstance(), MouseEventSpec$MOUSE_CLICKED_getInstance(), MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance(), MouseEventSpec$MOUSE_PRESSED_getInstance(), MouseEventSpec$MOUSE_RELEASED_getInstance()];\n }\n MouseEventSpec.values = MouseEventSpec$values;\n function MouseEventSpec$valueOf(name) {\n switch (name) {\n case 'MOUSE_ENTERED':\n return MouseEventSpec$MOUSE_ENTERED_getInstance();\n case 'MOUSE_LEFT':\n return MouseEventSpec$MOUSE_LEFT_getInstance();\n case 'MOUSE_MOVED':\n return MouseEventSpec$MOUSE_MOVED_getInstance();\n case 'MOUSE_DRAGGED':\n return MouseEventSpec$MOUSE_DRAGGED_getInstance();\n case 'MOUSE_CLICKED':\n return MouseEventSpec$MOUSE_CLICKED_getInstance();\n case 'MOUSE_DOUBLE_CLICKED':\n return MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance();\n case 'MOUSE_PRESSED':\n return MouseEventSpec$MOUSE_PRESSED_getInstance();\n case 'MOUSE_RELEASED':\n return MouseEventSpec$MOUSE_RELEASED_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.MouseEventSpec.' + name);\n }\n }\n MouseEventSpec.valueOf_61zpoe$ = MouseEventSpec$valueOf;\n function PointEvent(x, y) {\n Event.call(this);\n this.x = x;\n this.y = y;\n }\n Object.defineProperty(PointEvent.prototype, 'location', {\n configurable: true,\n get: function () {\n return new Vector(this.x, this.y);\n }\n });\n PointEvent.prototype.toString = function () {\n return '{x=' + this.x + ',y=' + this.y + '}';\n };\n PointEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointEvent',\n interfaces: [Event]\n };\n function Function() {\n }\n Function.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Function',\n interfaces: []\n };\n function Functions() {\n Functions_instance = this;\n this.TRUE_PREDICATE_0 = Functions$TRUE_PREDICATE$lambda;\n this.FALSE_PREDICATE_0 = Functions$FALSE_PREDICATE$lambda;\n this.NULL_PREDICATE_0 = Functions$NULL_PREDICATE$lambda;\n this.NOT_NULL_PREDICATE_0 = Functions$NOT_NULL_PREDICATE$lambda;\n }\n function Functions$constantSupplier$ObjectLiteral(closure$value) {\n this.closure$value = closure$value;\n }\n Functions$constantSupplier$ObjectLiteral.prototype.get = function () {\n return this.closure$value;\n };\n Functions$constantSupplier$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Supplier]\n };\n Functions.prototype.constantSupplier_mh5how$ = function (value) {\n return new Functions$constantSupplier$ObjectLiteral(value);\n };\n Functions.prototype.memorize_kji2v1$ = function (supplier) {\n return new Functions$Memo(supplier);\n };\n Functions.prototype.alwaysTrue_287e2$ = function () {\n return this.TRUE_PREDICATE_0;\n };\n Functions.prototype.alwaysFalse_287e2$ = function () {\n return this.FALSE_PREDICATE_0;\n };\n function Functions$constant$lambda(closure$result) {\n return function (it) {\n return closure$result;\n };\n }\n Functions.prototype.constant_jkq9vw$ = function (result) {\n return Functions$constant$lambda(result);\n };\n Functions.prototype.isNull_287e2$ = function () {\n return this.NULL_PREDICATE_0;\n };\n Functions.prototype.isNotNull_287e2$ = function () {\n return this.NOT_NULL_PREDICATE_0;\n };\n function Functions$identity$lambda(it) {\n return it;\n }\n Functions.prototype.identity_287e2$ = function () {\n return Functions$identity$lambda;\n };\n function Functions$same$lambda(closure$value) {\n return function (it) {\n return it === closure$value;\n };\n }\n Functions.prototype.same_tpy1pm$ = function (value) {\n return Functions$same$lambda(value);\n };\n function Functions$funcOf$ObjectLiteral(closure$lambda) {\n this.closure$lambda = closure$lambda;\n }\n Functions$funcOf$ObjectLiteral.prototype.apply_11rb$ = function (value) {\n return this.closure$lambda(value);\n };\n Functions$funcOf$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Function]\n };\n Functions.prototype.funcOf_7h29gk$ = function (lambda) {\n return new Functions$funcOf$ObjectLiteral(lambda);\n };\n function Functions$Memo(mySupplier) {\n this.mySupplier_0 = mySupplier;\n this.myCachedValue_0 = null;\n this.myCached_0 = false;\n }\n Functions$Memo.prototype.get = function () {\n if (!this.myCached_0) {\n this.myCachedValue_0 = this.mySupplier_0.get();\n this.myCached_0 = true;\n }return ensureNotNull(this.myCachedValue_0);\n };\n Functions$Memo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Memo',\n interfaces: [Supplier]\n };\n function Functions$TRUE_PREDICATE$lambda(it) {\n return true;\n }\n function Functions$FALSE_PREDICATE$lambda(it) {\n return false;\n }\n function Functions$NULL_PREDICATE$lambda(it) {\n return it == null;\n }\n function Functions$NOT_NULL_PREDICATE$lambda(it) {\n return it != null;\n }\n Functions.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Functions',\n interfaces: []\n };\n var Functions_instance = null;\n function Functions_getInstance() {\n if (Functions_instance === null) {\n new Functions();\n }return Functions_instance;\n }\n function Runnable() {\n }\n Runnable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Runnable',\n interfaces: []\n };\n function Supplier() {\n }\n Supplier.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Supplier',\n interfaces: []\n };\n function Value(myValue) {\n this.myValue_0 = myValue;\n }\n Value.prototype.get = function () {\n return this.myValue_0;\n };\n Value.prototype.set_11rb$ = function (value) {\n this.myValue_0 = value;\n };\n Value.prototype.toString = function () {\n return '' + toString(this.myValue_0);\n };\n Value.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Value',\n interfaces: [Supplier]\n };\n function Preconditions() {\n Preconditions_instance = this;\n }\n Preconditions.prototype.checkState_6taknv$ = function (expression) {\n if (!expression) {\n throw IllegalStateException_init_0();\n }};\n Preconditions.prototype.checkState_eltq40$ = function (expression, errorMessage) {\n if (!expression) {\n throw IllegalStateException_init(errorMessage.toString());\n }};\n Preconditions.prototype.checkArgument_6taknv$ = function (expression) {\n if (!expression) {\n throw IllegalArgumentException_init_0();\n }};\n Preconditions.prototype.checkArgument_eltq40$ = function (expression, errorMessage) {\n if (!expression) {\n throw IllegalArgumentException_init(errorMessage.toString());\n }};\n Preconditions.prototype.checkNotNull_mh5how$ = function (reference) {\n if (reference == null) {\n throw NullPointerException_init();\n }return reference;\n };\n Preconditions.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Preconditions',\n interfaces: []\n };\n var Preconditions_instance = null;\n function Preconditions_getInstance() {\n if (Preconditions_instance === null) {\n new Preconditions();\n }return Preconditions_instance;\n }\n function Strings() {\n Strings_instance = this;\n }\n Strings.prototype.isNullOrEmpty_pdl1vj$ = function (s) {\n var tmp$ = s == null;\n if (!tmp$) {\n tmp$ = s.length === 0;\n }return tmp$;\n };\n Strings.prototype.nullToEmpty_pdl1vj$ = function (string) {\n return string != null ? string : '';\n };\n Strings.prototype.repeat_bm4lxs$ = function (string, count) {\n var stringBuilder = StringBuilder_init();\n for (var i = 0; i < count; i++) {\n stringBuilder.append_pdl1vj$(string);\n }\n return stringBuilder.toString();\n };\n Strings.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Strings',\n interfaces: []\n };\n var Strings_instance = null;\n function Strings_getInstance() {\n if (Strings_instance === null) {\n new Strings();\n }return Strings_instance;\n }\n function Throwables() {\n Throwables_instance = this;\n }\n Throwables.prototype.getRootCause_tcv7n7$ = function (throwable) {\n var slowPointer = throwable;\n var advanceSlowPointer = false;\n var cause = throwable;\n while (cause.cause != null) {\n cause = ensureNotNull(cause.cause);\n if (cause === slowPointer) {\n throw new IllegalArgumentException('Loop in causal chain detected.', cause);\n }if (advanceSlowPointer) {\n slowPointer = ensureNotNull(slowPointer.cause);\n }advanceSlowPointer = !advanceSlowPointer;\n }\n return cause;\n };\n Throwables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Throwables',\n interfaces: []\n };\n var Throwables_instance = null;\n function Throwables_getInstance() {\n if (Throwables_instance === null) {\n new Throwables();\n }return Throwables_instance;\n }\n function ClosedRange(lower, upper) {\n ClosedRange$Companion_getInstance();\n this.lowerEnd = null;\n this.upperEnd = null;\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if ((tmp$_0 = typeof (tmp$ = lower) === 'number' ? tmp$ : null) != null) {\n if (!isFinite(tmp$_0)) {\n var message = 'ends must be finite: lower=' + lower + ' upper=' + upper;\n throw IllegalArgumentException_init(message.toString());\n }}if ((tmp$_2 = typeof (tmp$_1 = upper) === 'number' ? tmp$_1 : null) != null) {\n if (!isFinite(tmp$_2)) {\n var message_0 = 'ends must be finite: lower=' + lower + ' upper=' + upper;\n throw IllegalArgumentException_init(message_0.toString());\n }}this.lowerEnd = Comparables_getInstance().min_sdesaw$(lower, upper);\n this.upperEnd = Comparables_getInstance().max_sdesaw$(lower, upper);\n }\n ClosedRange.prototype.contains_mef7kx$ = function (v) {\n return Comparables_getInstance().lse_sdesaw$(this.lowerEnd, v) && Comparables_getInstance().lse_sdesaw$(v, this.upperEnd);\n };\n ClosedRange.prototype.span_d226ot$ = function (other) {\n if (this.encloses_d226ot$(other))\n return this;\n return other.encloses_d226ot$(this) ? other : new ClosedRange(Comparables_getInstance().min_sdesaw$(this.lowerEnd, other.lowerEnd), Comparables_getInstance().max_sdesaw$(this.upperEnd, other.upperEnd));\n };\n ClosedRange.prototype.encloses_d226ot$ = function (other) {\n return Comparables_getInstance().lse_sdesaw$(this.lowerEnd, other.lowerEnd) && Comparables_getInstance().gte_sdesaw$(this.upperEnd, other.upperEnd);\n };\n ClosedRange.prototype.isConnected_d226ot$ = function (other) {\n return !(Comparables_getInstance().gt_sdesaw$(this.lowerEnd, other.upperEnd) || Comparables_getInstance().ls_sdesaw$(this.upperEnd, other.lowerEnd));\n };\n ClosedRange.prototype.intersection_d226ot$ = function (other) {\n if (!this.isConnected_d226ot$(other))\n throw IllegalArgumentException_init('Ranges are not connected: this=' + this + ' other=' + other);\n if (this.encloses_d226ot$(other))\n return other;\n return other.encloses_d226ot$(this) ? this : new ClosedRange(Comparables_getInstance().max_sdesaw$(this.lowerEnd, other.lowerEnd), Comparables_getInstance().min_sdesaw$(this.upperEnd, other.upperEnd));\n };\n ClosedRange.prototype.toString = function () {\n return 'ClosedRange[' + this.lowerEnd + ', ' + this.upperEnd + ']';\n };\n ClosedRange.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, ClosedRange) ? tmp$_0 : throwCCE();\n if (!equals(this.lowerEnd, other.lowerEnd))\n return false;\n if (!equals(this.upperEnd, other.upperEnd))\n return false;\n return true;\n };\n ClosedRange.prototype.hashCode = function () {\n return hashCode(this.lowerEnd) + (31 * hashCode(this.upperEnd) | 0) | 0;\n };\n function ClosedRange$Companion() {\n ClosedRange$Companion_instance = this;\n }\n ClosedRange$Companion.prototype.singleton_f1zjgi$ = function (v) {\n return new ClosedRange(v, v);\n };\n ClosedRange$Companion.prototype.encloseAll_17hg47$ = function (values) {\n var tmp$;\n var iterated = false;\n var min = null;\n var max = null;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!iterated) {\n iterated = true;\n min = v;\n max = v;\n } else {\n min = Comparables_getInstance().min_sdesaw$(ensureNotNull(min), ensureNotNull(v));\n max = Comparables_getInstance().max_sdesaw$(ensureNotNull(max), v);\n }\n }\n if (!iterated) {\n throw NoSuchElementException_init();\n }return new ClosedRange(ensureNotNull(min), ensureNotNull(max));\n };\n ClosedRange$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ClosedRange$Companion_instance = null;\n function ClosedRange$Companion_getInstance() {\n if (ClosedRange$Companion_instance === null) {\n new ClosedRange$Companion();\n }return ClosedRange$Companion_instance;\n }\n ClosedRange.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ClosedRange',\n interfaces: []\n };\n function Comparables() {\n Comparables_instance = this;\n }\n Comparables.prototype.min_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) < 0 ? a : b;\n };\n Comparables.prototype.max_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) >= 0 ? a : b;\n };\n Comparables.prototype.lse_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) <= 0;\n };\n Comparables.prototype.gte_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) >= 0;\n };\n Comparables.prototype.ls_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) < 0;\n };\n Comparables.prototype.gt_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) > 0;\n };\n Comparables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Comparables',\n interfaces: []\n };\n var Comparables_instance = null;\n function Comparables_getInstance() {\n if (Comparables_instance === null) {\n new Comparables();\n }return Comparables_instance;\n }\n function ComparatorOrdering(comparator) {\n Ordering.call(this);\n this.myComparator_0 = comparator;\n }\n ComparatorOrdering.prototype.compare = function (a, b) {\n return this.myComparator_0.compare(a, b);\n };\n ComparatorOrdering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ComparatorOrdering',\n interfaces: [Ordering]\n };\n function Iterables() {\n Iterables_instance = this;\n }\n Iterables.prototype.checkNonNegative_0 = function (position) {\n if (position < 0) {\n throw new IndexOutOfBoundsException(position.toString());\n }};\n Iterables.prototype.toList_yl67zr$ = function (iterable) {\n return toList(iterable);\n };\n Iterables.prototype.size_fakr2g$ = function (iterable) {\n return count(iterable);\n };\n Iterables.prototype.isEmpty_fakr2g$ = function (iterable) {\n var tmp$, tmp$_0, tmp$_1;\n return (tmp$_1 = (tmp$_0 = Kotlin.isType(tmp$ = iterable, Collection) ? tmp$ : null) != null ? tmp$_0.isEmpty() : null) != null ? tmp$_1 : !iterable.iterator().hasNext();\n };\n Iterables.prototype.filter_fpit1u$ = function (unfiltered, retainIfTrue) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = unfiltered.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (retainIfTrue(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n Iterables.prototype.all_fpit1u$ = function (iterable, predicate) {\n var all$result;\n all$break: do {\n var tmp$;\n if (Kotlin.isType(iterable, Collection) && iterable.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$ = iterable.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!predicate(element)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n return all$result;\n };\n Iterables.prototype.concat_yxozss$ = function (a, b) {\n return plus_0(a, b);\n };\n Iterables.prototype.get_7iig3d$ = function (iterable, position) {\n var tmp$;\n this.checkNonNegative_0(position);\n if (Kotlin.isType(iterable, List)) {\n return (Kotlin.isType(tmp$ = iterable, List) ? tmp$ : throwCCE()).get_za3lpa$(position);\n }var it = iterable.iterator();\n for (var i = 0; i <= position; i++) {\n if (i === position) {\n return it.next();\n }it.next();\n }\n throw new IndexOutOfBoundsException(position.toString());\n };\n Iterables.prototype.get_dhabsj$ = function (iterable, position, defaultValue) {\n var tmp$;\n this.checkNonNegative_0(position);\n if (Kotlin.isType(iterable, List)) {\n var list = Kotlin.isType(tmp$ = iterable, List) ? tmp$ : throwCCE();\n return position < list.size ? list.get_za3lpa$(position) : defaultValue;\n }var it = iterable.iterator();\n var i = 0;\n while (i <= position && it.hasNext()) {\n if (i === position) {\n return it.next();\n }it.next();\n i = i + 1 | 0;\n }\n return defaultValue;\n };\n Iterables.prototype.find_nk18wc$ = function (iterable, predicate, defaultValue) {\n var tmp$;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_0;\n tmp$_0 = iterable.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (predicate(element)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n return (tmp$ = firstOrNull$result) != null ? tmp$ : defaultValue;\n };\n Iterables.prototype.getLast_yl67zr$ = function (iterable) {\n return last_0(iterable);\n };\n Iterables.prototype.toArray_hjktyj$ = function (iterable) {\n var collection;\n if (Kotlin.isType(iterable, Collection)) {\n collection = iterable;\n } else {\n collection = toList(iterable);\n }\n return copyToArray(collection);\n };\n Iterables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Iterables',\n interfaces: []\n };\n var Iterables_instance = null;\n function Iterables_getInstance() {\n if (Iterables_instance === null) {\n new Iterables();\n }return Iterables_instance;\n }\n function Lists() {\n Lists_instance = this;\n }\n Lists.prototype.transform_l7riir$ = function (fromList, function_0) {\n var destination = ArrayList_init_0(collectionSizeOrDefault(fromList, 10));\n var tmp$;\n tmp$ = fromList.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(function_0(item));\n }\n return destination;\n };\n Lists.prototype.reverse_bemo1h$ = function (list) {\n var copy = ArrayList_init_1(list);\n reverse(copy);\n return copy;\n };\n Lists.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Lists',\n interfaces: []\n };\n var Lists_instance = null;\n function Lists_getInstance() {\n if (Lists_instance === null) {\n new Lists();\n }return Lists_instance;\n }\n function Ordering() {\n Ordering$Companion_getInstance();\n }\n Ordering.prototype.isOrdered_p1ys8y$ = function (iterable) {\n var it = iterable.iterator();\n if (it.hasNext()) {\n var prev = it.next();\n while (it.hasNext()) {\n var next = it.next();\n if (this.compare(prev, next) > 0) {\n return false;\n }prev = next;\n }\n }return true;\n };\n function Ordering$sortedCopy$ObjectLiteral(this$Ordering) {\n this.this$Ordering = this$Ordering;\n }\n Ordering$sortedCopy$ObjectLiteral.prototype.compare = function (a, b) {\n return this.this$Ordering.compare(a, b);\n };\n Ordering$sortedCopy$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n Ordering.prototype.sortedCopy_m5x2f4$ = function (elements) {\n var tmp$;\n var array = Kotlin.isArray(tmp$ = Iterables_getInstance().toArray_hjktyj$(elements)) ? tmp$ : throwCCE();\n sortWith(array, new Ordering$sortedCopy$ObjectLiteral(this));\n return toList_0(array);\n };\n Ordering.prototype.reverse = function () {\n return new ComparatorOrdering(reversed(this));\n };\n Ordering.prototype.min_t5quzl$ = function (a, b) {\n return this.compare(a, b) <= 0 ? a : b;\n };\n Ordering.prototype.min_m5x2f4$ = function (iterable) {\n return this.min_x5a2gs$(iterable.iterator());\n };\n Ordering.prototype.min_x5a2gs$ = function (iterator) {\n var result = iterator.next();\n while (iterator.hasNext()) {\n result = this.min_t5quzl$(result, iterator.next());\n }\n return result;\n };\n Ordering.prototype.max_t5quzl$ = function (a, b) {\n return this.compare(a, b) >= 0 ? a : b;\n };\n Ordering.prototype.max_m5x2f4$ = function (iterable) {\n return this.max_x5a2gs$(iterable.iterator());\n };\n Ordering.prototype.max_x5a2gs$ = function (iterator) {\n var result = iterator.next();\n while (iterator.hasNext()) {\n result = this.max_t5quzl$(result, iterator.next());\n }\n return result;\n };\n function Ordering$Companion() {\n Ordering$Companion_instance = this;\n }\n Ordering$Companion.prototype.from_iajr8b$ = function (comparator) {\n var tmp$;\n return Kotlin.isType(comparator, Ordering) ? Kotlin.isType(tmp$ = comparator, Ordering) ? tmp$ : throwCCE() : new ComparatorOrdering(comparator);\n };\n Ordering$Companion.prototype.natural_dahdeg$ = function () {\n return new ComparatorOrdering(naturalOrder());\n };\n Ordering$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Ordering$Companion_instance = null;\n function Ordering$Companion_getInstance() {\n if (Ordering$Companion_instance === null) {\n new Ordering$Companion();\n }return Ordering$Companion_instance;\n }\n Ordering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Ordering',\n interfaces: [Comparator]\n };\n function Sets() {\n Sets_instance = this;\n }\n Sets.prototype.newHashSet_yl67zr$ = function (elements) {\n var tmp$;\n if (Kotlin.isType(elements, Collection)) {\n var collection = Kotlin.isType(tmp$ = elements, Collection) ? tmp$ : throwCCE();\n return HashSet_init(collection);\n }return this.newHashSet_0(elements.iterator());\n };\n Sets.prototype.newHashSet_0 = function (elements) {\n var set = HashSet_init_0();\n while (elements.hasNext()) {\n set.add_11rb$(elements.next());\n }\n return set;\n };\n Sets.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Sets',\n interfaces: []\n };\n var Sets_instance = null;\n function Sets_getInstance() {\n if (Sets_instance === null) {\n new Sets();\n }return Sets_instance;\n }\n function Stack() {\n this.elements_0 = ArrayList_init();\n }\n Stack.prototype.empty = function () {\n return this.elements_0.isEmpty();\n };\n Stack.prototype.push_11rb$ = function (item) {\n return this.elements_0.add_11rb$(item);\n };\n Stack.prototype.pop = function () {\n return this.elements_0.isEmpty() ? null : this.elements_0.removeAt_za3lpa$(this.elements_0.size - 1 | 0);\n };\n Stack.prototype.peek = function () {\n return lastOrNull(this.elements_0);\n };\n Stack.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Stack',\n interfaces: []\n };\n function TreeMap() {\n this.sortedKeys_0 = ArrayList_init();\n this.map_0 = HashMap_init_0();\n }\n Object.defineProperty(TreeMap.prototype, 'values', {\n configurable: true,\n get: function () {\n return this.map_0.values;\n }\n });\n TreeMap.prototype.get_mef7kx$ = function (key) {\n return this.map_0.get_11rb$(key);\n };\n TreeMap.prototype.put_ncwa5f$ = function (key, value) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n this.sortedKeys_0.add_wxm5ur$(~index, key);\n } else {\n this.sortedKeys_0.set_wxm5ur$(index, key);\n }\n return this.map_0.put_xwzc9p$(key, value);\n };\n TreeMap.prototype.containsKey_mef7kx$ = function (key) {\n return this.map_0.containsKey_11rb$(key);\n };\n TreeMap.prototype.floorKey_mef7kx$ = function (key) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n index = ~index - 1 | 0;\n if (index < 0)\n return null;\n }return this.sortedKeys_0.get_za3lpa$(index);\n };\n TreeMap.prototype.ceilingKey_mef7kx$ = function (key) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n index = ~index;\n if (index === this.sortedKeys_0.size)\n return null;\n }return this.sortedKeys_0.get_za3lpa$(index);\n };\n TreeMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TreeMap',\n interfaces: []\n };\n function DoubleRectangle(origin, dimension) {\n DoubleRectangle$Companion_getInstance();\n this.origin = origin;\n this.dimension = dimension;\n }\n Object.defineProperty(DoubleRectangle.prototype, 'center', {\n configurable: true,\n get: function () {\n return this.origin.add_gpjtzr$(this.dimension.mul_14dthe$(0.5));\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'left', {\n configurable: true,\n get: function () {\n return this.origin.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'right', {\n configurable: true,\n get: function () {\n return this.origin.x + this.dimension.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'top', {\n configurable: true,\n get: function () {\n return this.origin.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'bottom', {\n configurable: true,\n get: function () {\n return this.origin.y + this.dimension.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'width', {\n configurable: true,\n get: function () {\n return this.dimension.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'height', {\n configurable: true,\n get: function () {\n return this.dimension.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'parts', {\n configurable: true,\n get: function () {\n var result = ArrayList_init();\n result.add_11rb$(new DoubleSegment(this.origin, this.origin.add_gpjtzr$(new DoubleVector(this.dimension.x, 0.0))));\n result.add_11rb$(new DoubleSegment(this.origin, this.origin.add_gpjtzr$(new DoubleVector(0.0, this.dimension.y))));\n result.add_11rb$(new DoubleSegment(this.origin.add_gpjtzr$(this.dimension), this.origin.add_gpjtzr$(new DoubleVector(this.dimension.x, 0.0))));\n result.add_11rb$(new DoubleSegment(this.origin.add_gpjtzr$(this.dimension), this.origin.add_gpjtzr$(new DoubleVector(0.0, this.dimension.y))));\n return result;\n }\n });\n DoubleRectangle.prototype.xRange = function () {\n return new ClosedRange(this.origin.x, this.origin.x + this.dimension.x);\n };\n DoubleRectangle.prototype.yRange = function () {\n return new ClosedRange(this.origin.y, this.origin.y + this.dimension.y);\n };\n DoubleRectangle.prototype.contains_gpjtzr$ = function (v) {\n return this.origin.x <= v.x && this.origin.x + this.dimension.x >= v.x && this.origin.y <= v.y && this.origin.y + this.dimension.y >= v.y;\n };\n DoubleRectangle.prototype.union_wthzt5$ = function (rect) {\n var newOrigin = this.origin.min_gpjtzr$(rect.origin);\n var corner = this.origin.add_gpjtzr$(this.dimension);\n var rectCorner = rect.origin.add_gpjtzr$(rect.dimension);\n var newCorner = corner.max_gpjtzr$(rectCorner);\n var newDimension = newCorner.subtract_gpjtzr$(newOrigin);\n return new DoubleRectangle(newOrigin, newDimension);\n };\n DoubleRectangle.prototype.intersects_wthzt5$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_gpjtzr$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_gpjtzr$(rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n };\n DoubleRectangle.prototype.intersect_wthzt5$ = function (r) {\n var tmp$;\n var t1 = this.origin;\n var t2 = this.origin.add_gpjtzr$(this.dimension);\n var r1 = r.origin;\n var r2 = r.origin.add_gpjtzr$(r.dimension);\n var res1 = t1.max_gpjtzr$(r1);\n var res2 = t2.min_gpjtzr$(r2);\n var dim = res2.subtract_gpjtzr$(res1);\n if (dim.x < 0 || dim.y < 0) {\n tmp$ = null;\n } else\n tmp$ = new DoubleRectangle(res1, dim);\n return tmp$;\n };\n DoubleRectangle.prototype.add_gpjtzr$ = function (v) {\n return new DoubleRectangle(this.origin.add_gpjtzr$(v), this.dimension);\n };\n DoubleRectangle.prototype.subtract_gpjtzr$ = function (v) {\n return new DoubleRectangle(this.origin.subtract_gpjtzr$(v), this.dimension);\n };\n DoubleRectangle.prototype.distance_gpjtzr$ = function (to) {\n var tmp$;\n var result = 0.0;\n var hasResult = false;\n tmp$ = this.parts.iterator();\n while (tmp$.hasNext()) {\n var s = tmp$.next();\n if (!hasResult) {\n result = s.distance_gpjtzr$(to);\n hasResult = true;\n } else {\n var distance = s.distance_gpjtzr$(to);\n if (distance < result) {\n result = distance;\n }}\n }\n return result;\n };\n DoubleRectangle.prototype.hashCode = function () {\n return (this.origin.hashCode() * 31 | 0) + this.dimension.hashCode() | 0;\n };\n DoubleRectangle.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleRectangle)) {\n return false;\n }var r = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleRectangle) ? tmp$ : throwCCE();\n return ensureNotNull(r).origin.equals(this.origin) && r.dimension.equals(this.dimension);\n };\n DoubleRectangle.prototype.toString = function () {\n return '[rect ' + this.origin + ', ' + this.dimension + ']';\n };\n function DoubleRectangle$Companion() {\n DoubleRectangle$Companion_instance = this;\n }\n DoubleRectangle$Companion.prototype.span_qt8ska$ = function (leftTop, rightBottom) {\n return new DoubleRectangle(leftTop, rightBottom.subtract_gpjtzr$(leftTop));\n };\n DoubleRectangle$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DoubleRectangle$Companion_instance = null;\n function DoubleRectangle$Companion_getInstance() {\n if (DoubleRectangle$Companion_instance === null) {\n new DoubleRectangle$Companion();\n }return DoubleRectangle$Companion_instance;\n }\n DoubleRectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleRectangle',\n interfaces: []\n };\n function DoubleRectangle_init(x, y, w, h, $this) {\n $this = $this || Object.create(DoubleRectangle.prototype);\n DoubleRectangle.call($this, new DoubleVector(x, y), new DoubleVector(w, h));\n return $this;\n }\n function DoubleRectangles() {\n DoubleRectangles_instance = this;\n }\n function DoubleRectangles$boundingBox$lambda(minX, minY, maxX, maxY) {\n return DoubleRectangle$Companion_getInstance().span_qt8ska$(new DoubleVector(minX, minY), new DoubleVector(maxX, maxY));\n }\n DoubleRectangles.prototype.boundingBox_qdtdbw$ = function (points) {\n return this.calculateBoundingBox_h5l7ap$(points, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }), DoubleRectangles$boundingBox$lambda);\n };\n DoubleRectangles.prototype.calculateBoundingBox_h5l7ap$ = function (points, getX, getY, factory) {\n var tmp$;\n var first = points.iterator().next();\n var minLon = getX(first);\n var minLat = getY(first);\n var maxLon = minLon;\n var maxLat = minLat;\n tmp$ = points.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n var a = minLon;\n var b = getX(point);\n minLon = JsMath.min(a, b);\n var a_0 = maxLon;\n var b_0 = getX(point);\n maxLon = JsMath.max(a_0, b_0);\n var a_1 = minLat;\n var b_1 = getY(point);\n minLat = JsMath.min(a_1, b_1);\n var a_2 = maxLat;\n var b_2 = getY(point);\n maxLat = JsMath.max(a_2, b_2);\n }\n return factory(minLon, minLat, maxLon, maxLat);\n };\n DoubleRectangles.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DoubleRectangles',\n interfaces: []\n };\n var DoubleRectangles_instance = null;\n function DoubleRectangles_getInstance() {\n if (DoubleRectangles_instance === null) {\n new DoubleRectangles();\n }return DoubleRectangles_instance;\n }\n function DoubleSegment(start, end) {\n this.start = start;\n this.end = end;\n }\n DoubleSegment.prototype.distance_gpjtzr$ = function (v) {\n var vs = this.start.subtract_gpjtzr$(v);\n var ve = this.end.subtract_gpjtzr$(v);\n if (this.isDistanceToLineBest_0(v)) {\n var x = vs.x * ve.y - vs.y * ve.x;\n var pVolume = JsMath.abs(x);\n return pVolume / this.length();\n } else {\n var a = vs.length();\n var b = ve.length();\n return JsMath.min(a, b);\n }\n };\n DoubleSegment.prototype.isDistanceToLineBest_0 = function (v) {\n var es = this.start.subtract_gpjtzr$(this.end);\n var se = es.negate();\n var ev = v.subtract_gpjtzr$(this.end);\n var sv = v.subtract_gpjtzr$(this.start);\n return es.dotProduct_gpjtzr$(ev) >= 0 && se.dotProduct_gpjtzr$(sv) >= 0;\n };\n DoubleSegment.prototype.intersection_69p9e5$ = function (with_0) {\n var tmp$;\n var o1 = this.start;\n var o2 = with_0.start;\n var d1 = this.end.subtract_gpjtzr$(this.start);\n var d2 = with_0.end.subtract_gpjtzr$(with_0.start);\n var td = d1.dotProduct_gpjtzr$(d2.orthogonal());\n if (td === 0.0) {\n return null;\n }var t = o2.subtract_gpjtzr$(o1).dotProduct_gpjtzr$(d2.orthogonal()) / td;\n if (t < 0 || t > 1) {\n return null;\n }var sd = d2.dotProduct_gpjtzr$(d1.orthogonal());\n var s = o1.subtract_gpjtzr$(o2).dotProduct_gpjtzr$(d1.orthogonal()) / sd;\n if (s < 0 || s > 1) {\n tmp$ = null;\n } else\n tmp$ = o1.add_gpjtzr$(d1.mul_14dthe$(t));\n return tmp$;\n };\n DoubleSegment.prototype.length = function () {\n return this.start.subtract_gpjtzr$(this.end).length();\n };\n DoubleSegment.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleSegment)) {\n return false;\n }var l = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleSegment) ? tmp$ : throwCCE();\n return ensureNotNull(l).start.equals(this.start) && l.end.equals(this.end);\n };\n DoubleSegment.prototype.hashCode = function () {\n return (this.start.hashCode() * 31 | 0) + this.end.hashCode() | 0;\n };\n DoubleSegment.prototype.toString = function () {\n return '[' + this.start + ' -> ' + this.end + ']';\n };\n DoubleSegment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleSegment',\n interfaces: []\n };\n function DoubleVector(x, y) {\n DoubleVector$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n DoubleVector.prototype.add_gpjtzr$ = function (v) {\n return new DoubleVector(this.x + v.x, this.y + v.y);\n };\n DoubleVector.prototype.subtract_gpjtzr$ = function (v) {\n return new DoubleVector(this.x - v.x, this.y - v.y);\n };\n DoubleVector.prototype.max_gpjtzr$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new DoubleVector(tmp$, JsMath.max(a_0, b_0));\n };\n DoubleVector.prototype.min_gpjtzr$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new DoubleVector(tmp$, JsMath.min(a_0, b_0));\n };\n DoubleVector.prototype.mul_14dthe$ = function (value) {\n return new DoubleVector(this.x * value, this.y * value);\n };\n DoubleVector.prototype.dotProduct_gpjtzr$ = function (v) {\n return this.x * v.x + this.y * v.y;\n };\n DoubleVector.prototype.negate = function () {\n return new DoubleVector(-this.x, -this.y);\n };\n DoubleVector.prototype.orthogonal = function () {\n return new DoubleVector(-this.y, this.x);\n };\n DoubleVector.prototype.length = function () {\n var x = this.x * this.x + this.y * this.y;\n return JsMath.sqrt(x);\n };\n DoubleVector.prototype.normalize = function () {\n return this.mul_14dthe$(1 / this.length());\n };\n DoubleVector.prototype.rotate_14dthe$ = function (phi) {\n var x = this.x * JsMath.cos(phi) - this.y * JsMath.sin(phi);\n var y = this.x * JsMath.sin(phi) + this.y * JsMath.cos(phi);\n return new DoubleVector(x, y);\n };\n DoubleVector.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleVector)) {\n return false;\n }var v = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleVector) ? tmp$ : throwCCE();\n return ensureNotNull(v).x === this.x && v.y === this.y;\n };\n DoubleVector.prototype.hashCode = function () {\n return hashCode(this.x) + (31 * hashCode(this.y) | 0) | 0;\n };\n DoubleVector.prototype.toString = function () {\n return '(' + this.x + ', ' + this.y + ')';\n };\n function DoubleVector$Companion() {\n DoubleVector$Companion_instance = this;\n this.ZERO = new DoubleVector(0.0, 0.0);\n }\n DoubleVector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DoubleVector$Companion_instance = null;\n function DoubleVector$Companion_getInstance() {\n if (DoubleVector$Companion_instance === null) {\n new DoubleVector$Companion();\n }return DoubleVector$Companion_instance;\n }\n DoubleVector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleVector',\n interfaces: []\n };\n function Rectangle(origin, dimension) {\n this.origin = origin;\n this.dimension = dimension;\n }\n Object.defineProperty(Rectangle.prototype, 'boundSegments', {\n configurable: true,\n get: function () {\n var p = this.boundPoints_0;\n return [new Segment(p[0], p[1]), new Segment(p[1], p[2]), new Segment(p[2], p[3]), new Segment(p[3], p[0])];\n }\n });\n Object.defineProperty(Rectangle.prototype, 'boundPoints_0', {\n configurable: true,\n get: function () {\n return [this.origin, this.origin.add_119tl4$(new Vector(this.dimension.x, 0)), this.origin.add_119tl4$(this.dimension), this.origin.add_119tl4$(new Vector(0, this.dimension.y))];\n }\n });\n Rectangle.prototype.add_119tl4$ = function (v) {\n return new Rectangle(this.origin.add_119tl4$(v), this.dimension);\n };\n Rectangle.prototype.sub_119tl4$ = function (v) {\n return new Rectangle(this.origin.sub_119tl4$(v), this.dimension);\n };\n Rectangle.prototype.contains_vfns7u$ = function (r) {\n return this.contains_119tl4$(r.origin) && this.contains_119tl4$(r.origin.add_119tl4$(r.dimension));\n };\n Rectangle.prototype.contains_119tl4$ = function (v) {\n return this.origin.x <= v.x && (this.origin.x + this.dimension.x | 0) >= v.x && this.origin.y <= v.y && (this.origin.y + this.dimension.y | 0) >= v.y;\n };\n Rectangle.prototype.union_vfns7u$ = function (rect) {\n var newOrigin = this.origin.min_119tl4$(rect.origin);\n var corner = this.origin.add_119tl4$(this.dimension);\n var rectCorner = rect.origin.add_119tl4$(rect.dimension);\n var newCorner = corner.max_119tl4$(rectCorner);\n var newDimension = newCorner.sub_119tl4$(newOrigin);\n return new Rectangle(newOrigin, newDimension);\n };\n Rectangle.prototype.intersects_vfns7u$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_119tl4$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_119tl4$(rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n };\n Rectangle.prototype.intersect_vfns7u$ = function (r) {\n if (!this.intersects_vfns7u$(r)) {\n throw IllegalStateException_init('rectangle [' + this + \"] doesn't intersect [\" + r + ']');\n }var too = this.origin.add_119tl4$(this.dimension);\n var roo = r.origin.add_119tl4$(r.dimension);\n var ioo = too.min_119tl4$(roo);\n var io = this.origin.max_119tl4$(r.origin);\n return new Rectangle(io, ioo.sub_119tl4$(io));\n };\n Rectangle.prototype.innerIntersects_vfns7u$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_119tl4$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_119tl4$(rect.dimension);\n return r2.x > t1.x && t2.x > r1.x && r2.y > t1.y && t2.y > r1.y;\n };\n Rectangle.prototype.changeDimension_119tl4$ = function (dim) {\n return new Rectangle(this.origin, dim);\n };\n Rectangle.prototype.distance_119tl4$ = function (to) {\n return this.toDoubleRectangle_0().distance_gpjtzr$(to.toDoubleVector());\n };\n Rectangle.prototype.xRange = function () {\n return new ClosedRange(this.origin.x, this.origin.x + this.dimension.x | 0);\n };\n Rectangle.prototype.yRange = function () {\n return new ClosedRange(this.origin.y, this.origin.y + this.dimension.y | 0);\n };\n Rectangle.prototype.hashCode = function () {\n return (this.origin.hashCode() * 31 | 0) + this.dimension.hashCode() | 0;\n };\n Rectangle.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, Rectangle))\n return false;\n var otherRect = (tmp$ = other) == null || Kotlin.isType(tmp$, Rectangle) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.origin) != null ? tmp$_0.equals(ensureNotNull(otherRect).origin) : null) && ((tmp$_1 = this.dimension) != null ? tmp$_1.equals(otherRect.dimension) : null);\n };\n Rectangle.prototype.toDoubleRectangle_0 = function () {\n return new DoubleRectangle(this.origin.toDoubleVector(), this.dimension.toDoubleVector());\n };\n Rectangle.prototype.center = function () {\n return this.origin.add_119tl4$(new Vector(this.dimension.x / 2 | 0, this.dimension.y / 2 | 0));\n };\n Rectangle.prototype.toString = function () {\n return this.origin.toString() + ' - ' + this.dimension;\n };\n Rectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Rectangle',\n interfaces: []\n };\n function Rectangle_init(x, y, width, height, $this) {\n $this = $this || Object.create(Rectangle.prototype);\n Rectangle.call($this, new Vector(x, y), new Vector(width, height));\n return $this;\n }\n function Rectangles() {\n Rectangles_instance = this;\n }\n Rectangles.prototype.zeroOrigin_vfns7u$ = function (r) {\n return new Rectangle(Vector$Companion_getInstance().ZERO, r.dimension);\n };\n Rectangles.prototype.upperDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topLeft_0(inner).y - this.topLeft_0(outer).y | 0;\n };\n Rectangles.prototype.lowerDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.bottomLeft_0(outer).y - this.bottomLeft_0(inner).y | 0;\n };\n Rectangles.prototype.leftDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topLeft_0(inner).x - this.topLeft_0(outer).x | 0;\n };\n Rectangles.prototype.rightDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topRight_vfns7u$(outer).x - this.topRight_vfns7u$(inner).x | 0;\n };\n Rectangles.prototype.assertOuterInner_0 = function (outer, inner) {\n if (!outer.contains_vfns7u$(inner)) {\n throw IllegalArgumentException_init('Outer does not contain inner: outer = ' + outer + ', inner = ' + inner);\n }};\n Rectangles.prototype.extendUp_o8ajws$ = function (r, distance) {\n var change = new Vector(0, distance);\n return new Rectangle(r.origin.sub_119tl4$(change), r.dimension.add_119tl4$(change));\n };\n Rectangles.prototype.extendDown_o8ajws$ = function (r, distance) {\n return r.changeDimension_119tl4$(r.dimension.add_119tl4$(new Vector(0, distance)));\n };\n Rectangles.prototype.extendLeft_o8ajws$ = function (r, distance) {\n var change = new Vector(distance, 0);\n return new Rectangle(r.origin.sub_119tl4$(change), r.dimension.add_119tl4$(change));\n };\n Rectangles.prototype.extendRight_o8ajws$ = function (r, distance) {\n return r.changeDimension_119tl4$(r.dimension.add_119tl4$(new Vector(distance, 0)));\n };\n Rectangles.prototype.extendSides_ogcnvu$ = function (left, r, right) {\n return this.extendRight_o8ajws$(this.extendLeft_o8ajws$(r, left), right);\n };\n Rectangles.prototype.shrinkRight_o8ajws$ = function (r, distance) {\n if (r.dimension.x < distance) {\n throw IllegalArgumentException_init('To small rectangle = ' + r + ', distance = ' + distance);\n }return r.changeDimension_119tl4$(r.dimension.sub_119tl4$(new Vector(distance, 0)));\n };\n Rectangles.prototype.topLeft_0 = function (r) {\n return r.origin;\n };\n Rectangles.prototype.topRight_vfns7u$ = function (r) {\n return r.origin.add_119tl4$(new Vector(r.dimension.x, 0));\n };\n Rectangles.prototype.bottomLeft_0 = function (r) {\n return r.origin.add_119tl4$(new Vector(0, r.dimension.y));\n };\n Rectangles.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Rectangles',\n interfaces: []\n };\n var Rectangles_instance = null;\n function Rectangles_getInstance() {\n if (Rectangles_instance === null) {\n new Rectangles();\n }return Rectangles_instance;\n }\n function Segment(start, end) {\n this.start = start;\n this.end = end;\n }\n Segment.prototype.distance_119tl4$ = function (v) {\n var vs = this.start.sub_119tl4$(v);\n var ve = this.end.sub_119tl4$(v);\n if (this.isDistanceToLineBest_0(v)) {\n var pVolume = abs(Kotlin.imul(vs.x, ve.y) - Kotlin.imul(vs.y, ve.x) | 0);\n return pVolume / this.length();\n } else {\n var a = vs.toDoubleVector().length();\n var b = ve.toDoubleVector().length();\n return JsMath.min(a, b);\n }\n };\n Segment.prototype.isDistanceToLineBest_0 = function (v) {\n var es = this.start.sub_119tl4$(this.end);\n var se = es.negate();\n var ev = v.sub_119tl4$(this.end);\n var sv = v.sub_119tl4$(this.start);\n return es.dotProduct_119tl4$(ev) >= 0 && se.dotProduct_119tl4$(sv) >= 0;\n };\n Segment.prototype.toDoubleSegment = function () {\n return new DoubleSegment(this.start.toDoubleVector(), this.end.toDoubleVector());\n };\n Segment.prototype.intersection_51grtu$ = function (with_0) {\n return this.toDoubleSegment().intersection_69p9e5$(with_0.toDoubleSegment());\n };\n Segment.prototype.length = function () {\n return this.start.sub_119tl4$(this.end).length();\n };\n Segment.prototype.contains_119tl4$ = function (v) {\n var tmp$;\n var p1 = v.sub_119tl4$(this.start);\n var p2 = v.sub_119tl4$(this.end);\n if (p1.isParallel_119tl4$(p2)) {\n tmp$ = p1.dotProduct_119tl4$(p2) <= 0;\n } else\n tmp$ = false;\n return tmp$;\n };\n Segment.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, Segment)) {\n return false;\n }var l = (tmp$ = other) == null || Kotlin.isType(tmp$, Segment) ? tmp$ : throwCCE();\n return ((tmp$_0 = ensureNotNull(l).start) != null ? tmp$_0.equals(this.start) : null) && ((tmp$_1 = l.end) != null ? tmp$_1.equals(this.end) : null);\n };\n Segment.prototype.hashCode = function () {\n return (this.start.hashCode() * 31 | 0) + this.end.hashCode() | 0;\n };\n Segment.prototype.toString = function () {\n return '[' + this.start + ' -> ' + this.end + ']';\n };\n Segment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Segment',\n interfaces: []\n };\n function Vector(x, y) {\n Vector$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n function Vector$Companion() {\n Vector$Companion_instance = this;\n this.ZERO = new Vector(0, 0);\n }\n Vector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Vector$Companion_instance = null;\n function Vector$Companion_getInstance() {\n if (Vector$Companion_instance === null) {\n new Vector$Companion();\n }return Vector$Companion_instance;\n }\n Vector.prototype.add_119tl4$ = function (v) {\n return new Vector(this.x + v.x | 0, this.y + v.y | 0);\n };\n Vector.prototype.sub_119tl4$ = function (v) {\n return this.add_119tl4$(v.negate());\n };\n Vector.prototype.negate = function () {\n return new Vector(-this.x | 0, -this.y | 0);\n };\n Vector.prototype.max_119tl4$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new Vector(tmp$, JsMath.max(a_0, b_0));\n };\n Vector.prototype.min_119tl4$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new Vector(tmp$, JsMath.min(a_0, b_0));\n };\n Vector.prototype.mul_za3lpa$ = function (i) {\n return new Vector(Kotlin.imul(this.x, i), Kotlin.imul(this.y, i));\n };\n Vector.prototype.div_za3lpa$ = function (i) {\n return new Vector(this.x / i | 0, this.y / i | 0);\n };\n Vector.prototype.dotProduct_119tl4$ = function (v) {\n return Kotlin.imul(this.x, v.x) + Kotlin.imul(this.y, v.y) | 0;\n };\n Vector.prototype.length = function () {\n var x = Kotlin.imul(this.x, this.x) + Kotlin.imul(this.y, this.y) | 0;\n return JsMath.sqrt(x);\n };\n Vector.prototype.toDoubleVector = function () {\n return new DoubleVector(this.x, this.y);\n };\n Vector.prototype.abs = function () {\n return new Vector(abs(this.x), abs(this.y));\n };\n Vector.prototype.isParallel_119tl4$ = function (to) {\n return (Kotlin.imul(this.x, to.y) - Kotlin.imul(to.x, this.y) | 0) === 0;\n };\n Vector.prototype.orthogonal = function () {\n return new Vector(-this.y | 0, this.x);\n };\n Vector.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, Vector))\n return false;\n var otherVector = (tmp$ = other) == null || Kotlin.isType(tmp$, Vector) ? tmp$ : throwCCE();\n return this.x === ensureNotNull(otherVector).x && this.y === otherVector.y;\n };\n Vector.prototype.hashCode = function () {\n return (this.x * 31 | 0) + this.y | 0;\n };\n Vector.prototype.toString = function () {\n return '(' + this.x + ', ' + this.y + ')';\n };\n Vector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Vector',\n interfaces: []\n };\n function JsObjectSupport() {\n JsObjectSupport_instance = this;\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda(it) {\n return Unit;\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_0(closure$buffer, closure$handleValue) {\n return function (list) {\n var tmp$;\n closure$buffer.append_s8itvh$(91);\n var first = true;\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!first)\n closure$buffer.append_s8itvh$(44);\n else\n first = false;\n closure$handleValue.v(v);\n }\n return closure$buffer.append_s8itvh$(93);\n };\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_1(closure$buffer, closure$handleValue) {\n return function (map) {\n var tmp$, tmp$_0, tmp$_1;\n closure$buffer.append_s8itvh$(123);\n var first = true;\n tmp$ = map.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_2 = tmp$.next();\n var k = tmp$_2.key;\n var v = tmp$_2.value;\n if ((typeof (tmp$_0 = k) === 'string' ? tmp$_0 : null) == null) {\n throw IllegalArgumentException_init('Only `string` keys are supported, was: ' + ((tmp$_1 = Kotlin.getKClassFromExpression(ensureNotNull(k)).simpleName) != null ? tmp$_1 : 'no class name'));\n }if (!first)\n closure$buffer.append_s8itvh$(44);\n else\n first = false;\n closure$buffer.append_s8itvh$(10);\n closure$buffer.append_s8itvh$(34).append_pdl1vj$(escape(k)).append_s8itvh$(34).append_s8itvh$(58);\n closure$handleValue.v(v);\n }\n return closure$buffer.append_pdl1vj$('\\n}');\n };\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_2(closure$buffer, closure$handleList, closure$handleMap) {\n return function (v) {\n if (typeof v === 'string')\n closure$buffer.append_s8itvh$(34).append_pdl1vj$(escape(v)).append_s8itvh$(34);\n else if (typeof v === 'boolean' || Kotlin.isNumber(v))\n closure$buffer.append_s8jyv4$(v);\n else if (v == null)\n closure$buffer.append_pdl1vj$('null');\n else if (Kotlin.isArray(v))\n closure$handleList(asList(v));\n else if (Kotlin.isType(v, List))\n closure$handleList(v);\n else if (Kotlin.isType(v, Map))\n closure$handleMap(v);\n else\n throw IllegalArgumentException_init(\"Can't serialize object \" + toString(v));\n return Unit;\n };\n }\n JsObjectSupport.prototype.mapToJsObjectInitializer_6uu7i0$ = function (map) {\n var buffer = StringBuilder_init();\n var handleValue = {v: JsObjectSupport$mapToJsObjectInitializer$lambda};\n var handleList = JsObjectSupport$mapToJsObjectInitializer$lambda_0(buffer, handleValue);\n var handleMap = JsObjectSupport$mapToJsObjectInitializer$lambda_1(buffer, handleValue);\n handleValue.v = JsObjectSupport$mapToJsObjectInitializer$lambda_2(buffer, handleList, handleMap);\n handleMap(map);\n return buffer.toString();\n };\n JsObjectSupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'JsObjectSupport',\n interfaces: []\n };\n var JsObjectSupport_instance = null;\n function JsObjectSupport_getInstance() {\n if (JsObjectSupport_instance === null) {\n new JsObjectSupport();\n }return JsObjectSupport_instance;\n }\n function FluentArray() {\n this.myArray_0 = null;\n }\n FluentArray.prototype.getDouble_za3lpa$ = function (index) {\n var tmp$;\n return typeof (tmp$ = this.myArray_0.get_za3lpa$(index)) === 'number' ? tmp$ : throwCCE();\n };\n FluentArray.prototype.add_pdl1vj$ = function (v) {\n this.myArray_0.add_11rb$(v);\n return this;\n };\n FluentArray.prototype.add_yrwdxb$ = function (v) {\n this.myArray_0.add_11rb$(v);\n return this;\n };\n FluentArray.prototype.addStrings_d294za$ = function (values) {\n this.myArray_0.addAll_brywnq$(values);\n return this;\n };\n FluentArray.prototype.addAll_5ry1at$ = function (values) {\n var tmp$;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.myArray_0.add_11rb$(element.get());\n }\n return this;\n };\n FluentArray.prototype.addAll_m5dwgt$ = function (values) {\n this.addAll_5ry1at$(listOf(values.slice()));\n return this;\n };\n FluentArray.prototype.stream = function () {\n return streamOf(this.myArray_0);\n };\n FluentArray.prototype.objectStream = function () {\n return objectsStreamOf(this.myArray_0);\n };\n FluentArray.prototype.fluentObjectStream = function () {\n return map(objectsStreamOf(this.myArray_0), getCallableRef('FluentObject', function (p1) {\n return FluentObject_init(p1);\n }));\n };\n FluentArray.prototype.get = function () {\n return this.myArray_0;\n };\n FluentArray.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentArray',\n interfaces: [FluentValue]\n };\n function FluentArray_init($this) {\n $this = $this || Object.create(FluentArray.prototype);\n FluentValue.call($this);\n FluentArray.call($this);\n $this.myArray_0 = ArrayList_init();\n return $this;\n }\n function FluentArray_init_0(array, $this) {\n $this = $this || Object.create(FluentArray.prototype);\n FluentValue.call($this);\n FluentArray.call($this);\n $this.myArray_0 = ArrayList_init_1(array);\n return $this;\n }\n function FluentObject() {\n this.myObj_0 = null;\n }\n FluentObject.prototype.getArr_0 = function (key) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myObj_0.get_11rb$(key), List) ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getObj_0 = function (key) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myObj_0.get_11rb$(key), Map) ? tmp$ : throwCCE();\n };\n FluentObject.prototype.get = function () {\n return this.myObj_0;\n };\n FluentObject.prototype.contains_61zpoe$ = function (key) {\n return this.myObj_0.containsKey_11rb$(key);\n };\n FluentObject.prototype.containsNotNull_0 = function (key) {\n return this.contains_61zpoe$(key) && this.myObj_0.get_11rb$(key) != null;\n };\n FluentObject.prototype.put_wxs67v$ = function (key, v) {\n var $receiver = this.myObj_0;\n var value = v != null ? v.get() : null;\n $receiver.put_xwzc9p$(key, value);\n return this;\n };\n FluentObject.prototype.put_jyasbz$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_hzlfav$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_h92gdm$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_snuhza$ = function (key, v) {\n var tmp$ = this.myObj_0;\n var value = v != null ? formatEnum(v) : null;\n tmp$.put_xwzc9p$(key, value);\n return this;\n };\n FluentObject.prototype.getInt_61zpoe$ = function (key) {\n return numberToInt(getNumber(this.myObj_0, key));\n };\n FluentObject.prototype.getDouble_61zpoe$ = function (key) {\n return getDouble(this.myObj_0, key);\n };\n FluentObject.prototype.getBoolean_61zpoe$ = function (key) {\n var tmp$;\n return typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'boolean' ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getString_61zpoe$ = function (key) {\n var tmp$;\n return typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'string' ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getStrings_61zpoe$ = function (key) {\n var $receiver = this.getArr_0(key);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(getAsString(item));\n }\n return destination;\n };\n FluentObject.prototype.getEnum_xwn52g$ = function (key, enumValues) {\n var tmp$;\n return parseEnum(typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'string' ? tmp$ : throwCCE(), enumValues);\n };\n FluentObject.prototype.getEnum_a9gw98$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.json.FluentObject.getEnum_a9gw98$', function (T_0, isT, key) {\n return this.getEnum_xwn52g$(key, T_0.values());\n });\n FluentObject.prototype.getArray_61zpoe$ = function (key) {\n return FluentArray_init_0(this.getArr_0(key));\n };\n FluentObject.prototype.getObject_61zpoe$ = function (key) {\n return FluentObject_init(this.getObj_0(key));\n };\n FluentObject.prototype.getInt_qoz5hj$ = function (key, processor) {\n processor(this.getInt_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getDouble_l47sdb$ = function (key, processor) {\n processor(this.getDouble_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getBoolean_48wr2m$ = function (key, processor) {\n processor(this.getBoolean_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getString_hyc7mn$ = function (key, processor) {\n processor(this.getString_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getStrings_lpk3a7$ = function (key, processor) {\n processor(this.getStrings_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getEnum_651ru9$ = function (key, processor, enumValues) {\n processor(this.getEnum_xwn52g$(key, enumValues));\n return this;\n };\n FluentObject.prototype.getArray_nhu1ij$ = function (key, processor) {\n processor(this.getArray_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getObject_6k19qz$ = function (key, processor) {\n processor(this.getObject_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.putRemovable_wxs67v$ = function (key, v) {\n if (v != null) {\n this.put_wxs67v$(key, v);\n }return this;\n };\n FluentObject.prototype.putRemovable_snuhza$ = function (key, v) {\n if (v != null) {\n this.put_snuhza$(key, v);\n }return this;\n };\n FluentObject.prototype.forEntries_ophlsb$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n consumer(element, this.myObj_0.get_11rb$(element));\n }\n return this;\n };\n FluentObject.prototype.forObjEntries_izf7h5$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n consumer(element, Kotlin.isType(tmp$_0 = this.myObj_0.get_11rb$(element), Map) ? tmp$_0 : throwCCE());\n }\n return this;\n };\n FluentObject.prototype.forArrEntries_2wy1dl$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n consumer(element, Kotlin.isType(tmp$_0 = this.myObj_0.get_11rb$(element), List) ? tmp$_0 : throwCCE());\n }\n return this;\n };\n FluentObject.prototype.accept_ysf37t$ = function (consumer) {\n consumer(this);\n return this;\n };\n FluentObject.prototype.forStrings_2by8ig$ = function (key, processor) {\n var $receiver = getArr(this.myObj_0, key);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(getAsString(item));\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n processor(element);\n }\n return this;\n };\n FluentObject.prototype.getExistingDouble_l47sdb$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.getDouble_l47sdb$(key, processor);\n }return this;\n };\n FluentObject.prototype.getOptionalStrings_jpy86i$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getStrings_61zpoe$(key));\n } else {\n processor(null);\n }\n return this;\n };\n FluentObject.prototype.getExistingString_hyc7mn$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.getString_hyc7mn$(key, processor);\n }return this;\n };\n function FluentObject$forExistingStrings$lambda$lambda(closure$processor) {\n return function (it) {\n closure$processor(ensureNotNull(it));\n return Unit;\n };\n }\n FluentObject.prototype.forExistingStrings_hyc7mn$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.forStrings_2by8ig$(key, FluentObject$forExistingStrings$lambda$lambda(processor));\n }return this;\n };\n FluentObject.prototype.getExistingObject_6k19qz$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n var obj = this.getObject_61zpoe$(key);\n if (!obj.myObj_0.keys.isEmpty()) {\n processor(obj);\n }}return this;\n };\n FluentObject.prototype.getExistingArray_nhu1ij$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getArray_61zpoe$(key));\n }return this;\n };\n FluentObject.prototype.forObjects_6k19qz$ = function (key, processor) {\n var tmp$;\n tmp$ = this.getArray_61zpoe$(key).fluentObjectStream().iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n processor(element);\n }\n return this;\n };\n FluentObject.prototype.getOptionalInt_w5p0jm$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getInt_61zpoe$(key));\n } else {\n processor(null);\n }\n return this;\n };\n FluentObject.prototype.getIntOrDefault_u1i54l$ = function (key, processor, defaultValue) {\n if (this.containsNotNull_0(key)) {\n processor(this.getInt_61zpoe$(key));\n } else {\n processor(defaultValue);\n }\n return this;\n };\n FluentObject.prototype.forEnums_651ru9$ = function (key, processor, enumValues) {\n var tmp$;\n tmp$ = this.getArr_0(key).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n processor(parseEnum(typeof (tmp$_0 = element) === 'string' ? tmp$_0 : throwCCE(), enumValues));\n }\n return this;\n };\n FluentObject.prototype.getOptionalEnum_651ru9$ = function (key, processor, enumValues) {\n if (this.containsNotNull_0(key))\n processor(this.getEnum_xwn52g$(key, enumValues));\n else\n processor(null);\n return this;\n };\n FluentObject.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentObject',\n interfaces: [FluentValue]\n };\n function FluentObject_init(obj, $this) {\n $this = $this || Object.create(FluentObject.prototype);\n FluentValue.call($this);\n FluentObject.call($this);\n var tmp$;\n $this.myObj_0 = toMutableMap(Kotlin.isType(tmp$ = obj, Map) ? tmp$ : throwCCE());\n return $this;\n }\n function FluentObject_init_0($this) {\n $this = $this || Object.create(FluentObject.prototype);\n FluentValue.call($this);\n FluentObject.call($this);\n $this.myObj_0 = HashMap_init_0();\n return $this;\n }\n function FluentPrimitive() {\n this.value_0 = null;\n }\n FluentPrimitive.prototype.get = function () {\n return this.value_0;\n };\n FluentPrimitive.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentPrimitive',\n interfaces: [FluentValue]\n };\n function FluentPrimitive_init(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_0(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_1(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_2(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentValue() {\n }\n FluentValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentValue',\n interfaces: []\n };\n function JsonFormatter() {\n this.buffer_suueb3$_0 = this.buffer_suueb3$_0;\n }\n Object.defineProperty(JsonFormatter.prototype, 'buffer_0', {\n configurable: true,\n get: function () {\n if (this.buffer_suueb3$_0 == null)\n return throwUPAE('buffer');\n return this.buffer_suueb3$_0;\n },\n set: function (buffer) {\n this.buffer_suueb3$_0 = buffer;\n }\n });\n JsonFormatter.prototype.formatJson_za3rmp$ = function (o) {\n this.buffer_0 = StringBuilder_init();\n this.handleValue_0(o);\n return this.buffer_0.toString();\n };\n function JsonFormatter$handleList$lambda(this$JsonFormatter) {\n return function (tail) {\n var tmp$;\n tmp$ = tail.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var this$JsonFormatter_0 = this$JsonFormatter;\n this$JsonFormatter_0.append_0(',');\n this$JsonFormatter_0.handleValue_0(element);\n }\n return Unit;\n };\n }\n JsonFormatter.prototype.handleList_0 = function (list) {\n this.append_0('[');\n this.headTail_0(list, getCallableRef('handleValue', function ($receiver, p1) {\n return $receiver.handleValue_0(p1), Unit;\n }.bind(null, this)), JsonFormatter$handleList$lambda(this));\n this.append_0(']');\n };\n function JsonFormatter$handleMap$lambda(this$JsonFormatter) {\n return function (tail) {\n var tmp$;\n tmp$ = tail.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var this$JsonFormatter_0 = this$JsonFormatter;\n this$JsonFormatter_0.append_0(',\\n');\n this$JsonFormatter_0.handlePair_0(element);\n }\n return Unit;\n };\n }\n JsonFormatter.prototype.handleMap_0 = function (map) {\n this.append_0('{');\n this.headTail_0(map.entries, getCallableRef('handlePair', function ($receiver, p1) {\n return $receiver.handlePair_0(p1), Unit;\n }.bind(null, this)), JsonFormatter$handleMap$lambda(this));\n this.append_0('}');\n };\n JsonFormatter.prototype.handleValue_0 = function (v) {\n if (v == null)\n this.append_0('null');\n else if (typeof v === 'string')\n this.handleString_0(v);\n else if (Kotlin.isNumber(v) || equals(v, kotlin_js_internal_BooleanCompanionObject))\n this.append_0(v.toString());\n else if (Kotlin.isArray(v))\n this.handleList_0(asList(v));\n else if (Kotlin.isType(v, List))\n this.handleList_0(v);\n else if (Kotlin.isType(v, Map))\n this.handleMap_0(v);\n else\n throw IllegalArgumentException_init(\"Can't serialize object \" + toString(v));\n };\n JsonFormatter.prototype.handlePair_0 = function (pair) {\n this.handleString_0(pair.key);\n this.append_0(':');\n this.handleValue_0(pair.value);\n };\n JsonFormatter.prototype.handleString_0 = function (v) {\n if (v != null)\n if (typeof v === 'string')\n this.append_0('\"' + escape(v) + '\"');\n else\n throw IllegalArgumentException_init(\"Expected a string, but got '\" + toString(Kotlin.getKClassFromExpression(v).simpleName) + \"'\");\n };\n JsonFormatter.prototype.append_0 = function (s) {\n return this.buffer_0.append_pdl1vj$(s);\n };\n JsonFormatter.prototype.headTail_0 = function ($receiver, head, tail) {\n if (!$receiver.isEmpty()) {\n head(first_0($receiver));\n tail(drop(asSequence($receiver), 1));\n }};\n JsonFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonFormatter',\n interfaces: []\n };\n function JsonLexer(input) {\n JsonLexer$Companion_getInstance();\n this.input_0 = input;\n this.i_0 = 0;\n this.tokenStart_0 = 0;\n this.currentToken_dslfm7$_0 = null;\n this.nextToken();\n }\n Object.defineProperty(JsonLexer.prototype, 'currentToken', {\n configurable: true,\n get: function () {\n return this.currentToken_dslfm7$_0;\n },\n set: function (currentToken) {\n this.currentToken_dslfm7$_0 = currentToken;\n }\n });\n Object.defineProperty(JsonLexer.prototype, 'currentChar_0', {\n configurable: true,\n get: function () {\n return this.input_0.charCodeAt(this.i_0);\n }\n });\n function JsonLexer$nextToken$lambda(it) {\n return isWhitespace(unboxChar(it));\n }\n JsonLexer.prototype.nextToken = function () {\n var tmp$;\n this.advanceWhile_0(JsonLexer$nextToken$lambda);\n if (this.isFinished()) {\n return;\n }if (this.currentChar_0 === 123) {\n var $receiver = Token$LEFT_BRACE_getInstance();\n this.advance_0();\n tmp$ = $receiver;\n } else if (this.currentChar_0 === 125) {\n var $receiver_0 = Token$RIGHT_BRACE_getInstance();\n this.advance_0();\n tmp$ = $receiver_0;\n } else if (this.currentChar_0 === 91) {\n var $receiver_1 = Token$LEFT_BRACKET_getInstance();\n this.advance_0();\n tmp$ = $receiver_1;\n } else if (this.currentChar_0 === 93) {\n var $receiver_2 = Token$RIGHT_BRACKET_getInstance();\n this.advance_0();\n tmp$ = $receiver_2;\n } else if (this.currentChar_0 === 44) {\n var $receiver_3 = Token$COMMA_getInstance();\n this.advance_0();\n tmp$ = $receiver_3;\n } else if (this.currentChar_0 === 58) {\n var $receiver_4 = Token$COLON_getInstance();\n this.advance_0();\n tmp$ = $receiver_4;\n } else if (this.currentChar_0 === 116) {\n var $receiver_5 = Token$TRUE_getInstance();\n this.read_0('true');\n tmp$ = $receiver_5;\n } else if (this.currentChar_0 === 102) {\n var $receiver_6 = Token$FALSE_getInstance();\n this.read_0('false');\n tmp$ = $receiver_6;\n } else if (this.currentChar_0 === 110) {\n var $receiver_7 = Token$NULL_getInstance();\n this.read_0('null');\n tmp$ = $receiver_7;\n } else if (this.currentChar_0 === 34) {\n var $receiver_8 = Token$STRING_getInstance();\n this.readString_0();\n tmp$ = $receiver_8;\n } else if (this.readNumber_0())\n tmp$ = Token$NUMBER_getInstance();\n else {\n throw IllegalStateException_init((this.i_0.toString() + ':' + String.fromCharCode(this.currentChar_0) + ' - unkown token').toString());\n }\n this.currentToken = tmp$;\n };\n JsonLexer.prototype.tokenValue = function () {\n var $receiver = this.input_0;\n var startIndex = this.tokenStart_0;\n var endIndex = this.i_0;\n return $receiver.substring(startIndex, endIndex);\n };\n JsonLexer.prototype.readString_0 = function () {\n this.startToken_0();\n this.advance_0();\n while (this.currentChar_0 !== 34) {\n if (this.currentChar_0 === 92) {\n this.advance_0();\n if (this.currentChar_0 === 117) {\n this.advance_0();\n for (var index = 0; index < 4; index++) {\n if (!JsonLexer$Companion_getInstance().isHex_0(this.currentChar_0)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }this.advance_0();\n }\n } else {\n var $receiver = SPECIAL_CHARS;\n var key = toBoxedChar(this.currentChar_0);\n var tmp$;\n if ((Kotlin.isType(tmp$ = $receiver, Map) ? tmp$ : throwCCE()).containsKey_11rb$(key))\n this.advance_0();\n else {\n throw IllegalStateException_init('Invalid escape sequence'.toString());\n }\n }\n } else {\n this.advance_0();\n }\n }\n this.advance_0();\n };\n function JsonLexer$readNumber$lambda(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda$lambda(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda_0(this$JsonLexer) {\n return function () {\n if (!JsonLexer$Companion_getInstance().isDigit_0(this$JsonLexer.currentChar_0)) {\n var message = 'Number should have decimal part';\n throw IllegalArgumentException_init(message.toString());\n }this$JsonLexer.advanceWhile_0(JsonLexer$readNumber$lambda$lambda);\n return Unit;\n };\n }\n function JsonLexer$readNumber$lambda$lambda_0(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda_1(this$JsonLexer) {\n return function () {\n this$JsonLexer.advanceIfCurrent_0(Kotlin.charArrayOf(43, 45));\n this$JsonLexer.advanceWhile_0(JsonLexer$readNumber$lambda$lambda_0);\n return Unit;\n };\n }\n JsonLexer.prototype.readNumber_0 = function () {\n if (!(JsonLexer$Companion_getInstance().isDigit_0(this.currentChar_0) || this.currentChar_0 === 45)) {\n return false;\n }this.startToken_0();\n this.advanceIfCurrent_0(Kotlin.charArrayOf(45));\n this.advanceWhile_0(JsonLexer$readNumber$lambda);\n this.advanceIfCurrent_0(Kotlin.charArrayOf(46), JsonLexer$readNumber$lambda_0(this));\n this.advanceIfCurrent_0(Kotlin.charArrayOf(101, 69), JsonLexer$readNumber$lambda_1(this));\n return true;\n };\n JsonLexer.prototype.isFinished = function () {\n return this.i_0 === this.input_0.length;\n };\n JsonLexer.prototype.startToken_0 = function () {\n this.tokenStart_0 = this.i_0;\n };\n JsonLexer.prototype.advance_0 = function () {\n this.i_0 = this.i_0 + 1 | 0;\n };\n JsonLexer.prototype.read_0 = function (str) {\n var forEach$result;\n var tmp$;\n tmp$ = iterator(str);\n while (tmp$.hasNext()) {\n var element = unboxChar(tmp$.next());\n var it = toBoxedChar(element);\n if (!(this.currentChar_0 === unboxChar(it))) {\n var message = 'Wrong data: ' + str;\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.isFinished()) {\n var message_0 = 'Unexpected end of string';\n throw IllegalArgumentException_init(message_0.toString());\n }this.advance_0();\n }\n return forEach$result;\n };\n JsonLexer.prototype.advanceWhile_0 = function (pred) {\n while (!this.isFinished() && pred(toBoxedChar(this.currentChar_0)))\n this.advance_0();\n };\n function JsonLexer$advanceIfCurrent$lambda() {\n return Unit;\n }\n JsonLexer.prototype.advanceIfCurrent_0 = function (expected, then) {\n if (then === void 0)\n then = JsonLexer$advanceIfCurrent$lambda;\n if (!this.isFinished() && contains_0(expected, this.currentChar_0)) {\n this.advance_0();\n then();\n }};\n function JsonLexer$Companion() {\n JsonLexer$Companion_instance = this;\n this.digits_0 = new CharRange(48, 57);\n }\n JsonLexer$Companion.prototype.isDigit_0 = function ($receiver) {\n var $receiver_0 = this.digits_0;\n return $receiver != null && $receiver_0.contains_mef7kx$($receiver);\n };\n JsonLexer$Companion.prototype.isHex_0 = function ($receiver) {\n return this.isDigit_0($receiver) || (new CharRange(97, 102)).contains_mef7kx$($receiver) || (new CharRange(65, 70)).contains_mef7kx$($receiver);\n };\n JsonLexer$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JsonLexer$Companion_instance = null;\n function JsonLexer$Companion_getInstance() {\n if (JsonLexer$Companion_instance === null) {\n new JsonLexer$Companion();\n }return JsonLexer$Companion_instance;\n }\n JsonLexer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonLexer',\n interfaces: []\n };\n function JsonParser(json) {\n this.json_0 = json;\n }\n JsonParser.prototype.parseJson = function () {\n var lexer = new JsonLexer(this.json_0);\n return this.parseValue_0(lexer);\n };\n JsonParser.prototype.parseValue_0 = function (lexer) {\n var tmp$, tmp$_0;\n tmp$ = lexer.currentToken;\n if (equals(tmp$, Token$STRING_getInstance())) {\n var $receiver = unescape(lexer.tokenValue());\n lexer.nextToken();\n tmp$_0 = $receiver;\n } else if (equals(tmp$, Token$NUMBER_getInstance())) {\n var $receiver_0 = toDouble(lexer.tokenValue());\n lexer.nextToken();\n tmp$_0 = $receiver_0;\n } else if (equals(tmp$, Token$FALSE_getInstance())) {\n lexer.nextToken();\n tmp$_0 = false;\n } else if (equals(tmp$, Token$TRUE_getInstance())) {\n lexer.nextToken();\n tmp$_0 = true;\n } else if (equals(tmp$, Token$NULL_getInstance())) {\n lexer.nextToken();\n tmp$_0 = null;\n } else if (equals(tmp$, Token$LEFT_BRACE_getInstance()))\n tmp$_0 = this.parseObject_0(lexer);\n else if (equals(tmp$, Token$LEFT_BRACKET_getInstance()))\n tmp$_0 = this.parseArray_0(lexer);\n else {\n throw IllegalStateException_init(('Invalid token: ' + toString(lexer.currentToken)).toString());\n }\n return tmp$_0;\n };\n function JsonParser$parseArray$checkCurrentToken(closure$lexer, this$JsonParser) {\n return function (token) {\n this$JsonParser.require_0(closure$lexer.currentToken, token, '[Arr] ');\n };\n }\n JsonParser.prototype.parseArray_0 = function (lexer) {\n var checkCurrentToken = JsonParser$parseArray$checkCurrentToken(lexer, this);\n var list = ArrayList_init();\n checkCurrentToken(Token$LEFT_BRACKET_getInstance());\n lexer.nextToken();\n while (!equals(lexer.currentToken, Token$RIGHT_BRACKET_getInstance())) {\n if (!list.isEmpty()) {\n checkCurrentToken(Token$COMMA_getInstance());\n lexer.nextToken();\n }list.add_11rb$(this.parseValue_0(lexer));\n }\n checkCurrentToken(Token$RIGHT_BRACKET_getInstance());\n lexer.nextToken();\n return list;\n };\n function JsonParser$parseObject$checkCurrentToken(closure$lexer, this$JsonParser) {\n return function (token) {\n this$JsonParser.require_0(closure$lexer.currentToken, token, '[Obj] ');\n };\n }\n JsonParser.prototype.parseObject_0 = function (lexer) {\n var checkCurrentToken = JsonParser$parseObject$checkCurrentToken(lexer, this);\n var map = LinkedHashMap_init();\n checkCurrentToken(Token$LEFT_BRACE_getInstance());\n lexer.nextToken();\n while (!equals(lexer.currentToken, Token$RIGHT_BRACE_getInstance())) {\n if (!map.isEmpty()) {\n checkCurrentToken(Token$COMMA_getInstance());\n lexer.nextToken();\n }checkCurrentToken(Token$STRING_getInstance());\n var key = unescape(lexer.tokenValue());\n lexer.nextToken();\n checkCurrentToken(Token$COLON_getInstance());\n lexer.nextToken();\n var value = this.parseValue_0(lexer);\n map.put_xwzc9p$(key, value);\n }\n checkCurrentToken(Token$RIGHT_BRACE_getInstance());\n lexer.nextToken();\n return map;\n };\n JsonParser.prototype.require_0 = function (current, expected, messagePrefix) {\n if (messagePrefix === void 0)\n messagePrefix = null;\n if (!equals(current, expected)) {\n throw new JsonParser$JsonException(messagePrefix + ('Expected token: ' + toString(expected) + ', actual: ' + toString(current)));\n }};\n function JsonParser$JsonException(message) {\n Exception_init(message, this);\n this.name = 'JsonParser$JsonException';\n }\n JsonParser$JsonException.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonException',\n interfaces: [Exception]\n };\n JsonParser.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonParser',\n interfaces: []\n };\n function JsonSupport() {\n JsonSupport_instance = this;\n }\n JsonSupport.prototype.parseJson_61zpoe$ = function (jsonString) {\n var tmp$;\n return Kotlin.isType(tmp$ = (new JsonParser(jsonString)).parseJson(), MutableMap) ? tmp$ : throwCCE();\n };\n JsonSupport.prototype.formatJson_za3rmp$ = function (o) {\n return (new JsonFormatter()).formatJson_za3rmp$(o);\n };\n JsonSupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'JsonSupport',\n interfaces: []\n };\n var JsonSupport_instance = null;\n function JsonSupport_getInstance() {\n if (JsonSupport_instance === null) {\n new JsonSupport();\n }return JsonSupport_instance;\n }\n function Token(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Token_initFields() {\n Token_initFields = function () {\n };\n Token$LEFT_BRACE_instance = new Token('LEFT_BRACE', 0);\n Token$RIGHT_BRACE_instance = new Token('RIGHT_BRACE', 1);\n Token$LEFT_BRACKET_instance = new Token('LEFT_BRACKET', 2);\n Token$RIGHT_BRACKET_instance = new Token('RIGHT_BRACKET', 3);\n Token$COMMA_instance = new Token('COMMA', 4);\n Token$COLON_instance = new Token('COLON', 5);\n Token$STRING_instance = new Token('STRING', 6);\n Token$NUMBER_instance = new Token('NUMBER', 7);\n Token$TRUE_instance = new Token('TRUE', 8);\n Token$FALSE_instance = new Token('FALSE', 9);\n Token$NULL_instance = new Token('NULL', 10);\n }\n var Token$LEFT_BRACE_instance;\n function Token$LEFT_BRACE_getInstance() {\n Token_initFields();\n return Token$LEFT_BRACE_instance;\n }\n var Token$RIGHT_BRACE_instance;\n function Token$RIGHT_BRACE_getInstance() {\n Token_initFields();\n return Token$RIGHT_BRACE_instance;\n }\n var Token$LEFT_BRACKET_instance;\n function Token$LEFT_BRACKET_getInstance() {\n Token_initFields();\n return Token$LEFT_BRACKET_instance;\n }\n var Token$RIGHT_BRACKET_instance;\n function Token$RIGHT_BRACKET_getInstance() {\n Token_initFields();\n return Token$RIGHT_BRACKET_instance;\n }\n var Token$COMMA_instance;\n function Token$COMMA_getInstance() {\n Token_initFields();\n return Token$COMMA_instance;\n }\n var Token$COLON_instance;\n function Token$COLON_getInstance() {\n Token_initFields();\n return Token$COLON_instance;\n }\n var Token$STRING_instance;\n function Token$STRING_getInstance() {\n Token_initFields();\n return Token$STRING_instance;\n }\n var Token$NUMBER_instance;\n function Token$NUMBER_getInstance() {\n Token_initFields();\n return Token$NUMBER_instance;\n }\n var Token$TRUE_instance;\n function Token$TRUE_getInstance() {\n Token_initFields();\n return Token$TRUE_instance;\n }\n var Token$FALSE_instance;\n function Token$FALSE_getInstance() {\n Token_initFields();\n return Token$FALSE_instance;\n }\n var Token$NULL_instance;\n function Token$NULL_getInstance() {\n Token_initFields();\n return Token$NULL_instance;\n }\n Token.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Token',\n interfaces: [Enum]\n };\n function Token$values() {\n return [Token$LEFT_BRACE_getInstance(), Token$RIGHT_BRACE_getInstance(), Token$LEFT_BRACKET_getInstance(), Token$RIGHT_BRACKET_getInstance(), Token$COMMA_getInstance(), Token$COLON_getInstance(), Token$STRING_getInstance(), Token$NUMBER_getInstance(), Token$TRUE_getInstance(), Token$FALSE_getInstance(), Token$NULL_getInstance()];\n }\n Token.values = Token$values;\n function Token$valueOf(name) {\n switch (name) {\n case 'LEFT_BRACE':\n return Token$LEFT_BRACE_getInstance();\n case 'RIGHT_BRACE':\n return Token$RIGHT_BRACE_getInstance();\n case 'LEFT_BRACKET':\n return Token$LEFT_BRACKET_getInstance();\n case 'RIGHT_BRACKET':\n return Token$RIGHT_BRACKET_getInstance();\n case 'COMMA':\n return Token$COMMA_getInstance();\n case 'COLON':\n return Token$COLON_getInstance();\n case 'STRING':\n return Token$STRING_getInstance();\n case 'NUMBER':\n return Token$NUMBER_getInstance();\n case 'TRUE':\n return Token$TRUE_getInstance();\n case 'FALSE':\n return Token$FALSE_getInstance();\n case 'NULL':\n return Token$NULL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.json.Token.' + name);\n }\n }\n Token.valueOf_61zpoe$ = Token$valueOf;\n var SPECIAL_CHARS;\n var CONTROL_CHARS;\n function escape$appendOutput(closure$output, closure$i, this$escape) {\n return function (str) {\n var tmp$;\n var tmp$_0 = closure$output;\n var tmp$_1;\n if ((tmp$ = closure$output.v) != null)\n tmp$_1 = tmp$;\n else {\n var $receiver = this$escape;\n var endIndex = closure$i.v;\n tmp$_1 = new StringBuilder($receiver.substring(0, endIndex));\n }\n tmp$_0.v = tmp$_1.append_pdl1vj$(str);\n };\n }\n function escape($receiver) {\n var tmp$, tmp$_0, tmp$_1;\n var output = {v: null};\n var i = {v: 0};\n var appendOutput = escape$appendOutput(output, i, $receiver);\n while (i.v < $receiver.length) {\n var ch = $receiver.charCodeAt(i.v);\n switch (ch) {\n case 92:\n appendOutput('\\\\\\\\');\n break;\n case 34:\n appendOutput('\\\\\"');\n break;\n case 10:\n appendOutput('\\\\n');\n break;\n case 13:\n appendOutput('\\\\r');\n break;\n case 9:\n appendOutput('\\\\t');\n break;\n default:if (CONTROL_CHARS.contains_11rb$(toBoxedChar(ch))) {\n appendOutput('\\\\' + 'u' + padStart(toString_0(ch | 0, 16), 4, 48));\n } else\n (tmp$ = output.v) != null ? tmp$.append_s8itvh$(ch) : null;\n break;\n }\n i.v = i.v + 1 | 0;\n }\n return (tmp$_1 = (tmp$_0 = output.v) != null ? tmp$_0.toString() : null) != null ? tmp$_1 : $receiver;\n }\n function unescape($receiver) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var output = {v: null};\n var start = 1;\n var end = $receiver.length - 1 | 0;\n var i = {v: start};\n while (i.v < end) {\n var ch = $receiver.charCodeAt(i.v);\n if (ch === 92) {\n var tmp$_4;\n if ((tmp$ = output.v) != null)\n tmp$_4 = tmp$;\n else {\n var endIndex = i.v;\n tmp$_4 = new StringBuilder($receiver.substring(start, endIndex));\n }\n output.v = tmp$_4;\n var escapedChar = $receiver.charCodeAt((i.v = i.v + 1 | 0, i.v));\n var $receiver_0 = SPECIAL_CHARS;\n var key = toBoxedChar(escapedChar);\n var tmp$_5;\n if ((Kotlin.isType(tmp$_5 = $receiver_0, Map) ? tmp$_5 : throwCCE()).containsKey_11rb$(key)) {\n var $receiver_1 = SPECIAL_CHARS.get_11rb$(toBoxedChar(escapedChar));\n i.v = i.v + 1 | 0;\n tmp$_0 = unboxChar($receiver_1);\n } else if (escapedChar === 117) {\n var startIndex = i.v + 1 | 0;\n var endIndex_0 = i.v + 5 | 0;\n var $receiver_2 = toBoxedChar(toChar(toInt_0($receiver.substring(startIndex, endIndex_0), 16)));\n i.v = i.v + 5 | 0;\n tmp$_0 = unboxChar($receiver_2);\n } else\n throw new JsonParser$JsonException('Invalid escape character: ' + String.fromCharCode(escapedChar));\n output.v.append_s8jyv4$(toBoxedChar(tmp$_0));\n } else {\n (tmp$_1 = output.v) != null ? tmp$_1.append_s8itvh$(ch) : null;\n i.v = i.v + 1 | 0;\n }\n }\n return (tmp$_3 = (tmp$_2 = output.v) != null ? tmp$_2.toString() : null) != null ? tmp$_3 : $receiver.substring(start, end);\n }\n function streamOf(arr) {\n return asSequence(arr);\n }\n function objectsStreamOf$lambda(it) {\n var tmp$;\n return Kotlin.isType(tmp$ = it, Map) ? tmp$ : throwCCE();\n }\n function objectsStreamOf(arr) {\n return map(streamOf(arr), objectsStreamOf$lambda);\n }\n function stringStreamOf$lambda(it) {\n var tmp$;\n return (tmp$ = it) == null || typeof tmp$ === 'string' ? tmp$ : throwCCE();\n }\n function stringStreamOf(arr) {\n return map(streamOf(arr), stringStreamOf$lambda);\n }\n function isBoolean(e) {\n return typeof e === 'boolean';\n }\n function isNumber(e) {\n return Kotlin.isNumber(e);\n }\n function isString(e) {\n return typeof e === 'string';\n }\n function getAsDouble(v) {\n var tmp$;\n return numberToDouble(Kotlin.isNumber(tmp$ = v) ? tmp$ : throwCCE());\n }\n function getAsInt(v) {\n var tmp$;\n return numberToInt(Kotlin.isNumber(tmp$ = v) ? tmp$ : throwCCE());\n }\n function getAsBoolean(v) {\n var tmp$;\n return typeof (tmp$ = v) === 'boolean' ? tmp$ : throwCCE();\n }\n function containsString(obj, key) {\n var v = obj.get_11rb$(key);\n if (v == null || equals(v, isString(v)))\n return true;\n else\n return false;\n }\n function getAsString(e) {\n var tmp$;\n if (e == null)\n return null;\n else\n return typeof (tmp$ = e) === 'string' ? tmp$ : throwCCE();\n }\n function parseEnum(enumStringValue, values) {\n var first$result;\n first$break: do {\n var tmp$;\n for (tmp$ = 0; tmp$ !== values.length; ++tmp$) {\n var element = values[tmp$];\n if (equals_0(element.toString(), enumStringValue, true)) {\n first$result = element;\n break first$break;\n }}\n throw new NoSuchElementException_init_0('Array contains no element matching the predicate.');\n }\n while (false);\n return first$result;\n }\n var parseEnum_0 = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.json.parseEnum_a9gw98$', wrapFunction(function () {\n var parseEnum = _.jetbrains.datalore.base.json.parseEnum_xwn52g$;\n return function (T_0, isT, enumStringValue) {\n return parseEnum(enumStringValue, T_0.values());\n };\n }));\n function formatEnum(enumValue) {\n return enumValue.toString().toLowerCase();\n }\n function put($receiver, key, v) {\n var destination = ArrayList_init_0(collectionSizeOrDefault(v, 10));\n var tmp$;\n tmp$ = v.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(formatEnum(item));\n }\n return put_0($receiver, key, destination);\n }\n function put_0($receiver, key, v) {\n var tmp$ = FluentArray_init();\n var destination = ArrayList_init_0(collectionSizeOrDefault(v, 10));\n var tmp$_0;\n tmp$_0 = v.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item);\n }\n return $receiver.put_wxs67v$(key, tmp$.addStrings_d294za$(destination));\n }\n function getNumber($receiver, key) {\n var tmp$;\n var tmp$_0;\n var tmp$_1;\n if ((Kotlin.isType(tmp$_1 = $receiver, Map) ? tmp$_1 : throwCCE()).get_11rb$(key) == null)\n tmp$_0 = 0.0;\n else {\n var tmp$_2;\n tmp$_0 = Kotlin.isNumber(tmp$ = (Kotlin.isType(tmp$_2 = $receiver, Map) ? tmp$_2 : throwCCE()).get_11rb$(key)) ? tmp$ : throwCCE();\n }\n return tmp$_0;\n }\n function getDouble($receiver, key) {\n return numberToDouble(getNumber($receiver, key));\n }\n function getString($receiver, key) {\n var tmp$;\n var tmp$_0;\n return typeof (tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key)) === 'string' ? tmp$ : throwCCE();\n }\n function getObj($receiver, key) {\n var tmp$;\n var tmp$_0;\n return Kotlin.isType(tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key), Map) ? tmp$ : throwCCE();\n }\n function getArr($receiver, key) {\n var tmp$;\n var tmp$_0;\n return Kotlin.isType(tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key), List) ? tmp$ : throwCCE();\n }\n function ListMap() {\n ListMap$Companion_getInstance();\n this.myData_0 = ListMap$Companion_getInstance().EMPTY_ARRAY_0;\n }\n function ListMap$Companion() {\n ListMap$Companion_instance = this;\n this.EMPTY_ARRAY_0 = Kotlin.newArray(0, null);\n }\n ListMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ListMap$Companion_instance = null;\n function ListMap$Companion_getInstance() {\n if (ListMap$Companion_instance === null) {\n new ListMap$Companion();\n }return ListMap$Companion_instance;\n }\n Object.defineProperty(ListMap.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.size() === 0;\n }\n });\n ListMap.prototype.containsKey_11rb$ = function (key) {\n return this.findByKey_0(key) >= 0;\n };\n ListMap.prototype.remove_11rb$ = function (key) {\n var tmp$;\n var index = this.findByKey_0(key);\n if (index >= 0) {\n var value = this.myData_0[index + 1 | 0];\n this.removeAt_0(index);\n return (tmp$ = value) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n } else {\n return null;\n }\n };\n function ListMap$keySet$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractMutableSet.call(this);\n }\n Object.defineProperty(ListMap$keySet$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n ListMap$keySet$ObjectLiteral.prototype.add_11rb$ = function (element) {\n throw IllegalStateException_init('Not available in keySet');\n };\n function ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return this.this$ListMap.myData_0[index];\n };\n ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$keySet$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$keySet$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractMutableSet]\n };\n ListMap.prototype.keySet = function () {\n return new ListMap$keySet$ObjectLiteral(this);\n };\n function ListMap$values$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractCollection.call(this);\n }\n Object.defineProperty(ListMap$values$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n function ListMap$values$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$values$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return this.this$ListMap.myData_0[index + 1 | 0];\n };\n ListMap$values$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$values$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$values$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$values$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractCollection]\n };\n ListMap.prototype.values = function () {\n return new ListMap$values$ObjectLiteral(this);\n };\n function ListMap$entrySet$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractSet.call(this);\n }\n Object.defineProperty(ListMap$entrySet$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n function ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return new ListMap$Entry(this.this$ListMap, index);\n };\n ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$entrySet$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$entrySet$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractSet]\n };\n ListMap.prototype.entrySet = function () {\n return new ListMap$entrySet$ObjectLiteral(this);\n };\n ListMap.prototype.size = function () {\n return this.myData_0.length / 2 | 0;\n };\n ListMap.prototype.put_xwzc9p$ = function (key, value) {\n var tmp$;\n var index = this.findByKey_0(key);\n if (index >= 0) {\n var oldValue = this.myData_0[index + 1 | 0];\n this.myData_0[index + 1 | 0] = value;\n return (tmp$ = oldValue) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }var array = Array_0(this.myData_0.length + 2 | 0);\n var tmp$_0;\n tmp$_0 = array.length - 1 | 0;\n for (var i = 0; i <= tmp$_0; i++) {\n array[i] = i < this.myData_0.length ? this.myData_0[i] : null;\n }\n var newArray = array;\n newArray[this.myData_0.length] = key;\n newArray[this.myData_0.length + 1 | 0] = value;\n this.myData_0 = newArray;\n return null;\n };\n ListMap.prototype.get_11rb$ = function (key) {\n var tmp$, tmp$_0;\n var index = this.findByKey_0(key);\n if (index === -1) {\n tmp$_0 = null;\n } else {\n tmp$_0 = (tmp$ = this.myData_0[index + 1 | 0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }\n return tmp$_0;\n };\n ListMap.prototype.toString = function () {\n var builder = StringBuilder_init();\n builder.append_pdl1vj$('{');\n var i = 0;\n while (i < this.myData_0.length) {\n var k = this.myData_0[i];\n var v = this.myData_0[i + 1 | 0];\n if (i !== 0) {\n builder.append_pdl1vj$(',');\n }builder.append_s8jyv4$(k).append_pdl1vj$('=').append_s8jyv4$(v);\n i = i + 2 | 0;\n }\n builder.append_pdl1vj$('}');\n return builder.toString();\n };\n function ListMap$mapIterator$ObjectLiteral(this$ListMap, closure$spec) {\n this.this$ListMap = this$ListMap;\n this.closure$spec = closure$spec;\n this.index_0 = 0;\n this.nextCalled_0 = false;\n }\n ListMap$mapIterator$ObjectLiteral.prototype.hasNext = function () {\n return this.index_0 < this.this$ListMap.myData_0.length;\n };\n ListMap$mapIterator$ObjectLiteral.prototype.next = function () {\n var tmp$;\n if (!this.hasNext()) {\n throw NoSuchElementException_init();\n }this.nextCalled_0 = true;\n var value = (tmp$ = this.closure$spec.get_za3lpa$(this.index_0)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n this.index_0 = this.index_0 + 2 | 0;\n return value;\n };\n ListMap$mapIterator$ObjectLiteral.prototype.remove = function () {\n if (!this.nextCalled_0) {\n throw IllegalStateException_init_0();\n }this.index_0 = this.index_0 - 2 | 0;\n this.this$ListMap.removeAt_0(this.index_0);\n this.nextCalled_0 = false;\n };\n ListMap$mapIterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MutableIterator]\n };\n ListMap.prototype.mapIterator_0 = function (spec) {\n return new ListMap$mapIterator$ObjectLiteral(this, spec);\n };\n ListMap.prototype.findByKey_0 = function (key) {\n var i = 0;\n while (i < this.myData_0.length) {\n var k = this.myData_0[i];\n if (equals(key, k)) {\n return i;\n }i = i + 2 | 0;\n }\n return -1;\n };\n ListMap.prototype.removeAt_0 = function (index) {\n if (this.myData_0.length === 2) {\n this.myData_0 = ListMap$Companion_getInstance().EMPTY_ARRAY_0;\n return;\n }var array = Array_0(this.myData_0.length - 2 | 0);\n var tmp$;\n tmp$ = array.length - 1 | 0;\n for (var i = 0; i <= tmp$; i++) {\n var init$result;\n if (i < index) {\n init$result = this.myData_0[i];\n } else {\n init$result = this.myData_0[i + 2 | 0];\n }\n array[i] = init$result;\n }\n var newArray = array;\n this.myData_0 = newArray;\n };\n function ListMap$Entry($outer, myIndex) {\n this.$outer = $outer;\n this.myIndex_0 = myIndex;\n }\n ListMap$Entry.prototype.key = function () {\n var tmp$;\n return (tmp$ = this.$outer.myData_0[this.myIndex_0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n };\n ListMap$Entry.prototype.value = function () {\n var tmp$;\n return (tmp$ = this.$outer.myData_0[this.myIndex_0 + 1 | 0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n };\n ListMap$Entry.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Entry',\n interfaces: []\n };\n function ListMap$IteratorSpec() {\n }\n ListMap$IteratorSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'IteratorSpec',\n interfaces: []\n };\n ListMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ListMap',\n interfaces: []\n };\n function Logger() {\n }\n Logger.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Logger',\n interfaces: []\n };\n function PrintlnLogger(name) {\n this.name = name;\n }\n PrintlnLogger.prototype.error_l35kib$ = function (e, message) {\n println('ERR [' + this.name + '] : ' + message());\n };\n PrintlnLogger.prototype.info_h4ejuu$ = function (message) {\n println('INFO [' + this.name + '] : ' + message());\n };\n PrintlnLogger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PrintlnLogger',\n interfaces: [Logger]\n };\n function toRadians(degrees) {\n return degrees * math.PI / 180.0;\n }\n function toDegrees(radians) {\n return radians * 180.0 / math.PI;\n }\n function round_0(v) {\n return round_1(v.x, v.y);\n }\n function ceil(v) {\n return ceil_0(v.x, v.y);\n }\n function round_1(x, y) {\n return new Vector(numberToInt(round(x)), numberToInt(round(y)));\n }\n function ceil_0(x, y) {\n return new Vector(numberToInt(JsMath.ceil(x)), numberToInt(JsMath.ceil(y)));\n }\n function distance(vector, doubleVector) {\n var dx = doubleVector.x - vector.x;\n var dy = doubleVector.y - vector.y;\n var x = dx * dx + dy * dy;\n return JsMath.sqrt(x);\n }\n function ipow($receiver, e) {\n return JsMath.pow($receiver, e);\n }\n function length(v) {\n if (equals(v, L0)) {\n return 1;\n }var len = 0;\n var rem = v;\n while (rem.toNumber() > 0) {\n len = len + 1 | 0;\n rem = rem.div(Kotlin.Long.fromInt(10));\n }\n return len;\n }\n function NumberFormat(spec) {\n NumberFormat$Companion_getInstance();\n this.spec_0 = spec;\n }\n function NumberFormat$Spec(fill, align, sign, symbol, zero, width, comma, precision, type, trim) {\n if (fill === void 0)\n fill = ' ';\n if (align === void 0)\n align = '>';\n if (sign === void 0)\n sign = '-';\n if (width === void 0)\n width = -1;\n if (precision === void 0)\n precision = 6;\n if (type === void 0)\n type = '';\n if (trim === void 0)\n trim = false;\n this.fill = fill;\n this.align = align;\n this.sign = sign;\n this.symbol = symbol;\n this.zero = zero;\n this.width = width;\n this.comma = comma;\n this.precision = precision;\n this.type = type;\n this.trim = trim;\n }\n NumberFormat$Spec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Spec',\n interfaces: []\n };\n NumberFormat$Spec.prototype.component1 = function () {\n return this.fill;\n };\n NumberFormat$Spec.prototype.component2 = function () {\n return this.align;\n };\n NumberFormat$Spec.prototype.component3 = function () {\n return this.sign;\n };\n NumberFormat$Spec.prototype.component4 = function () {\n return this.symbol;\n };\n NumberFormat$Spec.prototype.component5 = function () {\n return this.zero;\n };\n NumberFormat$Spec.prototype.component6 = function () {\n return this.width;\n };\n NumberFormat$Spec.prototype.component7 = function () {\n return this.comma;\n };\n NumberFormat$Spec.prototype.component8 = function () {\n return this.precision;\n };\n NumberFormat$Spec.prototype.component9 = function () {\n return this.type;\n };\n NumberFormat$Spec.prototype.component10 = function () {\n return this.trim;\n };\n NumberFormat$Spec.prototype.copy_xzdl1p$ = function (fill, align, sign, symbol, zero, width, comma, precision, type, trim) {\n return new NumberFormat$Spec(fill === void 0 ? this.fill : fill, align === void 0 ? this.align : align, sign === void 0 ? this.sign : sign, symbol === void 0 ? this.symbol : symbol, zero === void 0 ? this.zero : zero, width === void 0 ? this.width : width, comma === void 0 ? this.comma : comma, precision === void 0 ? this.precision : precision, type === void 0 ? this.type : type, trim === void 0 ? this.trim : trim);\n };\n NumberFormat$Spec.prototype.toString = function () {\n return 'Spec(fill=' + Kotlin.toString(this.fill) + (', align=' + Kotlin.toString(this.align)) + (', sign=' + Kotlin.toString(this.sign)) + (', symbol=' + Kotlin.toString(this.symbol)) + (', zero=' + Kotlin.toString(this.zero)) + (', width=' + Kotlin.toString(this.width)) + (', comma=' + Kotlin.toString(this.comma)) + (', precision=' + Kotlin.toString(this.precision)) + (', type=' + Kotlin.toString(this.type)) + (', trim=' + Kotlin.toString(this.trim)) + ')';\n };\n NumberFormat$Spec.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.fill) | 0;\n result = result * 31 + Kotlin.hashCode(this.align) | 0;\n result = result * 31 + Kotlin.hashCode(this.sign) | 0;\n result = result * 31 + Kotlin.hashCode(this.symbol) | 0;\n result = result * 31 + Kotlin.hashCode(this.zero) | 0;\n result = result * 31 + Kotlin.hashCode(this.width) | 0;\n result = result * 31 + Kotlin.hashCode(this.comma) | 0;\n result = result * 31 + Kotlin.hashCode(this.precision) | 0;\n result = result * 31 + Kotlin.hashCode(this.type) | 0;\n result = result * 31 + Kotlin.hashCode(this.trim) | 0;\n return result;\n };\n NumberFormat$Spec.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.fill, other.fill) && Kotlin.equals(this.align, other.align) && Kotlin.equals(this.sign, other.sign) && Kotlin.equals(this.symbol, other.symbol) && Kotlin.equals(this.zero, other.zero) && Kotlin.equals(this.width, other.width) && Kotlin.equals(this.comma, other.comma) && Kotlin.equals(this.precision, other.precision) && Kotlin.equals(this.type, other.type) && Kotlin.equals(this.trim, other.trim)))));\n };\n function NumberFormat$NumberInfo(number, negative, integerPart, fractionalPart, exponent) {\n NumberFormat$NumberInfo$Companion_getInstance();\n if (number === void 0)\n number = 0.0;\n if (negative === void 0)\n negative = false;\n if (integerPart === void 0)\n integerPart = L0;\n if (fractionalPart === void 0)\n fractionalPart = L0;\n if (exponent === void 0)\n exponent = null;\n this.number = number;\n this.negative = negative;\n this.integerPart = integerPart;\n this.fractionalPart = fractionalPart;\n this.exponent = exponent;\n this.fractionLeadingZeros = 18 - length(this.fractionalPart) | 0;\n this.integerLength = length(this.integerPart);\n this.fractionString = repeat('0', this.fractionLeadingZeros) + trimEnd(this.fractionalPart.toString(), Kotlin.charArrayOf(48));\n }\n function NumberFormat$NumberInfo$Companion() {\n NumberFormat$NumberInfo$Companion_instance = this;\n this.MAX_DECIMALS_0 = 18;\n this.MAX_DECIMAL_VALUE_8be2vx$ = Kotlin.Long.fromNumber(JsMath.pow(10.0, 18));\n }\n function NumberFormat$NumberInfo$Companion$createNumberInfo$lambda(frac, exp) {\n var fraction = frac;\n if (exp > 18) {\n fraction = substring(frac, until(0, frac.length - (exp - 18) | 0));\n }var tmp$ = toLong(fraction);\n var n = coerceAtLeast(18 - exp | 0, 0);\n return tmp$.multiply(Kotlin.Long.fromNumber(JsMath.pow(10.0, n)));\n }\n NumberFormat$NumberInfo$Companion.prototype.createNumberInfo_yjmjg9$ = function (num) {\n var tmp$, tmp$_0, tmp$_1;\n var encodeFraction = NumberFormat$NumberInfo$Companion$createNumberInfo$lambda;\n var tmp$_2 = Regex_init('^(\\\\d+)\\\\.?(\\\\d+)?e?([+-]?\\\\d+)?$');\n var tmp$_3;\n var $receiver = numberToDouble(num);\n if ((tmp$_0 = (tmp$ = tmp$_2.find_905azu$(JsMath.abs($receiver).toString().toLowerCase())) != null ? tmp$.destructured : null) != null)\n tmp$_3 = tmp$_0;\n else {\n throw IllegalStateException_init(('Wrong number: ' + num.toString()).toString());\n }\n var tmp$_4 = tmp$_3;\n var intStr = tmp$_4.match.groupValues.get_za3lpa$(1);\n var fracStr = tmp$_4.match.groupValues.get_za3lpa$(2);\n var exponentString = tmp$_4.match.groupValues.get_za3lpa$(3);\n var exponent = (tmp$_1 = toIntOrNull(exponentString)) != null ? tmp$_1 : 0;\n if (abs(exponent) >= 18) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, toLong(intStr), L0, exponent);\n }if (!(exponent < 18)) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }if (exponent < 0) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, void 0, encodeFraction(intStr + fracStr, abs(exponent) + fracStr.length | 0));\n }if (!(exponent >= 0 && exponent <= 18)) {\n var message_0 = 'Check failed.';\n throw IllegalStateException_init(message_0.toString());\n }if (exponent >= fracStr.length) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, toLong(intStr + fracStr + repeat('0', exponent - fracStr.length | 0)));\n }if (!(exponent >= 0 && exponent < fracStr.length)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }var tmp$_5 = toLong(intStr + substring(fracStr, until(0, exponent)));\n var $receiver_0 = fracStr.substring(exponent);\n return NumberFormat$NumberFormat$NumberInfo_init(num, tmp$_5, encodeFraction($receiver_0, $receiver_0.length));\n };\n NumberFormat$NumberInfo$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NumberFormat$NumberInfo$Companion_instance = null;\n function NumberFormat$NumberInfo$Companion_getInstance() {\n if (NumberFormat$NumberInfo$Companion_instance === null) {\n new NumberFormat$NumberInfo$Companion();\n }return NumberFormat$NumberInfo$Companion_instance;\n }\n NumberFormat$NumberInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumberInfo',\n interfaces: []\n };\n function NumberFormat$NumberFormat$NumberInfo_init(number, integerPart, fractionalPart, exponent, $this) {\n if (integerPart === void 0)\n integerPart = L0;\n if (fractionalPart === void 0)\n fractionalPart = L0;\n if (exponent === void 0)\n exponent = null;\n $this = $this || Object.create(NumberFormat$NumberInfo.prototype);\n var $receiver = numberToDouble(number);\n NumberFormat$NumberInfo.call($this, JsMath.abs($receiver), numberToDouble(number) < 0.0, integerPart, fractionalPart, exponent);\n return $this;\n }\n NumberFormat$NumberInfo.prototype.component1 = function () {\n return this.number;\n };\n NumberFormat$NumberInfo.prototype.component2 = function () {\n return this.negative;\n };\n NumberFormat$NumberInfo.prototype.component3 = function () {\n return this.integerPart;\n };\n NumberFormat$NumberInfo.prototype.component4 = function () {\n return this.fractionalPart;\n };\n NumberFormat$NumberInfo.prototype.component5 = function () {\n return this.exponent;\n };\n NumberFormat$NumberInfo.prototype.copy_xz9h4k$ = function (number, negative, integerPart, fractionalPart, exponent) {\n return new NumberFormat$NumberInfo(number === void 0 ? this.number : number, negative === void 0 ? this.negative : negative, integerPart === void 0 ? this.integerPart : integerPart, fractionalPart === void 0 ? this.fractionalPart : fractionalPart, exponent === void 0 ? this.exponent : exponent);\n };\n NumberFormat$NumberInfo.prototype.toString = function () {\n return 'NumberInfo(number=' + Kotlin.toString(this.number) + (', negative=' + Kotlin.toString(this.negative)) + (', integerPart=' + Kotlin.toString(this.integerPart)) + (', fractionalPart=' + Kotlin.toString(this.fractionalPart)) + (', exponent=' + Kotlin.toString(this.exponent)) + ')';\n };\n NumberFormat$NumberInfo.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.number) | 0;\n result = result * 31 + Kotlin.hashCode(this.negative) | 0;\n result = result * 31 + Kotlin.hashCode(this.integerPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.fractionalPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.exponent) | 0;\n return result;\n };\n NumberFormat$NumberInfo.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.number, other.number) && Kotlin.equals(this.negative, other.negative) && Kotlin.equals(this.integerPart, other.integerPart) && Kotlin.equals(this.fractionalPart, other.fractionalPart) && Kotlin.equals(this.exponent, other.exponent)))));\n };\n function NumberFormat$Output(body, sign, prefix, suffix, padding) {\n if (body === void 0)\n body = new NumberFormat$FormattedNumber();\n if (sign === void 0)\n sign = '';\n if (prefix === void 0)\n prefix = '';\n if (suffix === void 0)\n suffix = '';\n if (padding === void 0)\n padding = '';\n this.body = body;\n this.sign = sign;\n this.prefix = prefix;\n this.suffix = suffix;\n this.padding = padding;\n }\n NumberFormat$Output.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Output',\n interfaces: []\n };\n NumberFormat$Output.prototype.component1 = function () {\n return this.body;\n };\n NumberFormat$Output.prototype.component2 = function () {\n return this.sign;\n };\n NumberFormat$Output.prototype.component3 = function () {\n return this.prefix;\n };\n NumberFormat$Output.prototype.component4 = function () {\n return this.suffix;\n };\n NumberFormat$Output.prototype.component5 = function () {\n return this.padding;\n };\n NumberFormat$Output.prototype.copy_rm1j3u$ = function (body, sign, prefix, suffix, padding) {\n return new NumberFormat$Output(body === void 0 ? this.body : body, sign === void 0 ? this.sign : sign, prefix === void 0 ? this.prefix : prefix, suffix === void 0 ? this.suffix : suffix, padding === void 0 ? this.padding : padding);\n };\n NumberFormat$Output.prototype.toString = function () {\n return 'Output(body=' + Kotlin.toString(this.body) + (', sign=' + Kotlin.toString(this.sign)) + (', prefix=' + Kotlin.toString(this.prefix)) + (', suffix=' + Kotlin.toString(this.suffix)) + (', padding=' + Kotlin.toString(this.padding)) + ')';\n };\n NumberFormat$Output.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.body) | 0;\n result = result * 31 + Kotlin.hashCode(this.sign) | 0;\n result = result * 31 + Kotlin.hashCode(this.prefix) | 0;\n result = result * 31 + Kotlin.hashCode(this.suffix) | 0;\n result = result * 31 + Kotlin.hashCode(this.padding) | 0;\n return result;\n };\n NumberFormat$Output.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.body, other.body) && Kotlin.equals(this.sign, other.sign) && Kotlin.equals(this.prefix, other.prefix) && Kotlin.equals(this.suffix, other.suffix) && Kotlin.equals(this.padding, other.padding)))));\n };\n function NumberFormat$FormattedNumber(integerPart, fractionalPart, exponentialPart) {\n if (integerPart === void 0)\n integerPart = '';\n if (fractionalPart === void 0)\n fractionalPart = '';\n if (exponentialPart === void 0)\n exponentialPart = '';\n this.integerPart = integerPart;\n this.fractionalPart = fractionalPart;\n this.exponentialPart = exponentialPart;\n var tmp$;\n this.fractionalLength = (tmp$ = this.fractionalPart.length === 0 ? 0 : null) != null ? tmp$ : 1 + this.fractionalPart.length | 0;\n this.fullLength = this.integerPart.length + this.fractionalLength + this.exponentialPart.length | 0;\n }\n NumberFormat$FormattedNumber.prototype.toString = function () {\n var tmp$;\n var tmp$_0 = this.integerPart;\n var $receiver = NumberFormat$Companion_getInstance().FRACTION_DELIMITER_0;\n return tmp$_0 + ((tmp$ = this.fractionalPart.length > 0 ? $receiver : null) != null ? tmp$ : '') + this.fractionalPart + this.exponentialPart;\n };\n NumberFormat$FormattedNumber.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FormattedNumber',\n interfaces: []\n };\n NumberFormat$FormattedNumber.prototype.component1 = function () {\n return this.integerPart;\n };\n NumberFormat$FormattedNumber.prototype.component2 = function () {\n return this.fractionalPart;\n };\n NumberFormat$FormattedNumber.prototype.component3 = function () {\n return this.exponentialPart;\n };\n NumberFormat$FormattedNumber.prototype.copy_6hosri$ = function (integerPart, fractionalPart, exponentialPart) {\n return new NumberFormat$FormattedNumber(integerPart === void 0 ? this.integerPart : integerPart, fractionalPart === void 0 ? this.fractionalPart : fractionalPart, exponentialPart === void 0 ? this.exponentialPart : exponentialPart);\n };\n NumberFormat$FormattedNumber.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.integerPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.fractionalPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.exponentialPart) | 0;\n return result;\n };\n NumberFormat$FormattedNumber.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.integerPart, other.integerPart) && Kotlin.equals(this.fractionalPart, other.fractionalPart) && Kotlin.equals(this.exponentialPart, other.exponentialPart)))));\n };\n NumberFormat.prototype.apply_3p81yu$ = function (num) {\n var nonNumberString = this.handleNonNumbers_0(num);\n if (nonNumberString != null) {\n return nonNumberString;\n }var numberInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(num);\n var output = new NumberFormat$Output();\n output = this.computeBody_0(output, numberInfo);\n output = this.trimFraction_0(output);\n output = this.computeSign_0(output, numberInfo);\n output = this.computePrefix_0(output);\n output = this.computeSuffix_0(output);\n if (this.spec_0.comma && !this.spec_0.zero) {\n output = this.applyGroup_0(output);\n }output = this.computePadding_0(output);\n if (this.spec_0.comma && this.spec_0.zero) {\n output = this.applyGroup_0(output);\n }return this.getAlignedString_0(output);\n };\n NumberFormat.prototype.handleNonNumbers_0 = function (num) {\n var tmp$;\n var number = numberToDouble(num);\n if (isNaN_0(number))\n tmp$ = 'NaN';\n else if (number === kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY)\n tmp$ = '-Infinity';\n else if (number === kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY)\n tmp$ = '+Infinity';\n else\n tmp$ = null;\n return tmp$;\n };\n NumberFormat.prototype.getAlignedString_0 = function (output) {\n var tmp$;\n switch (this.spec_0.align) {\n case '<':\n tmp$ = output.sign + output.prefix + output.body + output.suffix + output.padding;\n break;\n case '=':\n tmp$ = output.sign + output.prefix + output.padding + output.body + output.suffix;\n break;\n case '^':\n var stop = output.padding.length / 2 | 0;\n tmp$ = slice(output.padding, until(0, stop)) + output.sign + output.prefix + output.body + output.suffix + slice(output.padding, until(stop, output.padding.length));\n break;\n default:tmp$ = output.padding + output.sign + output.prefix + output.body + output.suffix;\n break;\n }\n return tmp$;\n };\n NumberFormat.prototype.applyGroup_0 = function (output) {\n var tmp$, tmp$_0;\n var $receiver = output.padding;\n var zeroPadding = (tmp$ = this.spec_0.zero ? $receiver : null) != null ? tmp$ : '';\n var body = output.body;\n var fullIntStr = zeroPadding + body.integerPart;\n var x = fullIntStr.length / 3;\n var commas = numberToInt(JsMath.ceil(x) - 1);\n var width = coerceAtLeast(this.spec_0.width - body.fractionalLength - body.exponentialPart.length | 0, body.integerPart.length + commas | 0);\n fullIntStr = NumberFormat$Companion_getInstance().group_0(fullIntStr);\n if (fullIntStr.length > width) {\n var $receiver_0 = fullIntStr;\n var startIndex = fullIntStr.length - width | 0;\n fullIntStr = $receiver_0.substring(startIndex);\n if (startsWith(fullIntStr, 44)) {\n fullIntStr = '0' + fullIntStr;\n }}return output.copy_rm1j3u$(body.copy_6hosri$(fullIntStr), void 0, void 0, void 0, (tmp$_0 = this.spec_0.zero ? '' : null) != null ? tmp$_0 : output.padding);\n };\n NumberFormat.prototype.computeBody_0 = function (res, numberInfo) {\n var tmp$;\n switch (this.spec_0.type) {\n case '%':\n tmp$ = this.toFixedFormat_0(NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(numberInfo.number * 100), this.spec_0.precision);\n break;\n case 'c':\n tmp$ = new NumberFormat$FormattedNumber(numberInfo.number.toString());\n break;\n case 'd':\n tmp$ = this.toSimpleFormat_0(numberInfo, 0);\n break;\n case 'e':\n tmp$ = this.toSimpleFormat_0(this.toExponential_0(numberInfo, this.spec_0.precision), this.spec_0.precision);\n break;\n case 'f':\n tmp$ = this.toFixedFormat_0(numberInfo, this.spec_0.precision);\n break;\n case 'g':\n tmp$ = this.toPrecisionFormat_0(numberInfo, this.spec_0.precision);\n break;\n case 'b':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 2));\n break;\n case 'o':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 8));\n break;\n case 'X':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 16).toUpperCase());\n break;\n case 'x':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 16));\n break;\n case 's':\n tmp$ = this.toSiFormat_0(numberInfo, this.spec_0.precision);\n break;\n default:throw IllegalArgumentException_init('Wrong type: ' + this.spec_0.type);\n }\n var formattedNumber = tmp$;\n return res.copy_rm1j3u$(formattedNumber);\n };\n NumberFormat.prototype.toExponential_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$, tmp$_0;\n var num = numberInfo.number;\n if (num < NumberFormat$Companion_getInstance().TYPE_E_MIN) {\n return new NumberFormat$NumberInfo(0.0);\n }if (equals(numberInfo.integerPart, L0)) {\n tmp$_0 = -(numberInfo.fractionLeadingZeros + 1 | 0) | 0;\n } else {\n tmp$_0 = (numberInfo.integerLength - 1 | 0) + ((tmp$ = numberInfo.exponent) != null ? tmp$ : 0) | 0;\n }\n var e = tmp$_0;\n var n = e;\n var n_0 = num / JsMath.pow(10.0, n);\n var newInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(n_0);\n if (precision > -1) {\n newInfo = this.roundToPrecision_0(newInfo, precision);\n }if (newInfo.integerLength > 1) {\n e = e + 1 | 0;\n newInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(n_0 / 10);\n }return newInfo.copy_xz9h4k$(void 0, void 0, void 0, void 0, e);\n };\n NumberFormat.prototype.toPrecisionFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n if (equals(numberInfo.integerPart, L0)) {\n if (equals(numberInfo.fractionalPart, L0)) {\n return this.toFixedFormat_0(numberInfo, precision - 1 | 0);\n }return this.toFixedFormat_0(numberInfo, precision + numberInfo.fractionLeadingZeros | 0);\n } else {\n if (numberInfo.integerLength > precision) {\n return this.toSimpleFormat_0(this.toExponential_0(numberInfo, precision - 1 | 0), precision - 1 | 0);\n }return this.toFixedFormat_0(numberInfo, precision - numberInfo.integerLength | 0);\n }\n };\n NumberFormat.prototype.toFixedFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = 0;\n var tmp$;\n if (precision <= 0) {\n return new NumberFormat$FormattedNumber(roundToLong(numberInfo.number).toString());\n }var newNumberInfo = this.roundToPrecision_0(numberInfo, precision);\n if (numberInfo.integerLength < newNumberInfo.integerLength) {\n tmp$ = precision - 1 | 0;\n } else {\n tmp$ = precision;\n }\n var completePrecision = tmp$;\n if (equals(newNumberInfo.fractionalPart, L0)) {\n return new NumberFormat$FormattedNumber(newNumberInfo.integerPart.toString(), repeat('0', completePrecision));\n }var fractionString = padEnd(newNumberInfo.fractionString, completePrecision, 48);\n return new NumberFormat$FormattedNumber(newNumberInfo.integerPart.toString(), fractionString);\n };\n NumberFormat.prototype.toSimpleFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$;\n if (numberInfo.exponent != null) {\n var expSign = get_sign(numberInfo.exponent) >= 0 ? '+' : '';\n tmp$ = 'e' + expSign + toString(numberInfo.exponent);\n } else {\n tmp$ = '';\n }\n var exponentString = tmp$;\n var expNumberInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(numberInfo.integerPart.toNumber() + numberInfo.fractionalPart.toNumber() / NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.toNumber());\n if (precision > -1) {\n var formattedNumber = this.toFixedFormat_0(expNumberInfo, precision);\n return formattedNumber.copy_6hosri$(void 0, void 0, exponentString);\n }var integerString = expNumberInfo.integerPart.toString();\n var fractionString = equals(expNumberInfo.fractionalPart, L0) ? '' : expNumberInfo.fractionString;\n return new NumberFormat$FormattedNumber(integerString, fractionString, exponentString);\n };\n NumberFormat.prototype.toSiFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$, tmp$_0;\n if (numberInfo.exponent == null) {\n tmp$ = this.toExponential_0(numberInfo, precision - 1 | 0);\n } else {\n tmp$ = numberInfo;\n }\n var expNumberInfo = tmp$;\n var exponent = (tmp$_0 = expNumberInfo.exponent) != null ? tmp$_0 : 0;\n var x = exponent / 3.0;\n var suffixExp = numberToInt(coerceAtMost(coerceAtLeast_0(JsMath.floor(x), -8.0), 8.0)) * 3 | 0;\n var tmp$_1 = NumberFormat$NumberInfo$Companion_getInstance();\n var tmp$_2 = numberInfo.number;\n var n = -suffixExp | 0;\n var newNumberInfo = tmp$_1.createNumberInfo_yjmjg9$(tmp$_2 * JsMath.pow(10.0, n));\n var suffixIndex = 8 + (suffixExp / 3 | 0) | 0;\n var exponentString = NumberFormat$Companion_getInstance().SI_SUFFIXES_0[suffixIndex];\n var formattedNumber = this.toFixedFormat_0(newNumberInfo, precision - newNumberInfo.integerLength | 0);\n return formattedNumber.copy_6hosri$(void 0, void 0, exponentString);\n };\n NumberFormat.prototype.roundToPrecision_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = 0;\n var tmp$, tmp$_0, tmp$_1;\n var exp = (tmp$ = numberInfo.exponent) != null ? tmp$ : 0;\n var totalPrecision = precision + exp | 0;\n var fractionalPart;\n var integerPart;\n if (totalPrecision < 0) {\n fractionalPart = L0;\n var intShift = abs(totalPrecision);\n if (numberInfo.integerLength <= intShift) {\n tmp$_0 = L0;\n } else {\n tmp$_0 = numberInfo.integerPart.div(Kotlin.Long.fromNumber(JsMath.pow(10.0, intShift))).multiply(Kotlin.Long.fromNumber(JsMath.pow(10.0, intShift)));\n }\n integerPart = tmp$_0;\n } else {\n var precisionExp = NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.div(Kotlin.Long.fromNumber(JsMath.pow(10.0, totalPrecision)));\n if (equals(precisionExp, L0)) {\n tmp$_1 = numberInfo.fractionalPart;\n } else {\n tmp$_1 = roundToLong(numberInfo.fractionalPart.toNumber() / precisionExp.toNumber()).multiply(precisionExp);\n }\n fractionalPart = tmp$_1;\n integerPart = numberInfo.integerPart;\n if (equals(fractionalPart, NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$)) {\n fractionalPart = L0;\n integerPart = integerPart.inc();\n }}\n var num = integerPart.toNumber() + fractionalPart.toNumber() / NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.toNumber();\n return numberInfo.copy_xz9h4k$(num, void 0, integerPart, fractionalPart);\n };\n NumberFormat.prototype.trimFraction_0 = function (output) {\n var tmp$ = !this.spec_0.trim;\n if (!tmp$) {\n tmp$ = output.body.fractionalPart.length === 0;\n }if (tmp$) {\n return output;\n }var trimmedFraction = trimEnd(output.body.fractionalPart, Kotlin.charArrayOf(48));\n return output.copy_rm1j3u$(output.body.copy_6hosri$(void 0, trimmedFraction));\n };\n NumberFormat.prototype.computeSign_0 = function (output, numberInfo) {\n var tmp$;\n var $receiver = output.body;\n var $receiver_0 = plus_1(asSequence_0($receiver.integerPart), asSequence_0($receiver.fractionalPart));\n var all$result;\n all$break: do {\n var tmp$_0;\n tmp$_0 = $receiver_0.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (!(unboxChar(element) === 48)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n var isBodyZero = all$result;\n var isNegative = numberInfo.negative && !isBodyZero;\n if (isNegative) {\n tmp$ = '-';\n } else {\n tmp$ = !equals(this.spec_0.sign, '-') ? this.spec_0.sign : '';\n }\n var signStr = tmp$;\n return output.copy_rm1j3u$(void 0, signStr);\n };\n NumberFormat.prototype.computePrefix_0 = function (output) {\n var tmp$;\n switch (this.spec_0.symbol) {\n case '$':\n tmp$ = NumberFormat$Companion_getInstance().CURRENCY_0;\n break;\n case '#':\n tmp$ = indexOf('boxX', this.spec_0.type) > -1 ? '0' + this.spec_0.type.toLowerCase() : '';\n break;\n default:tmp$ = '';\n break;\n }\n var prefix = tmp$;\n return output.copy_rm1j3u$(void 0, void 0, prefix);\n };\n NumberFormat.prototype.computeSuffix_0 = function (res) {\n var tmp$ = void 0;\n var tmp$_0 = void 0;\n var tmp$_1 = void 0;\n var $receiver = NumberFormat$Companion_getInstance().PERCENT_0;\n var $receiver_0 = equals(this.spec_0.type, '%') ? $receiver : null;\n return res.copy_rm1j3u$(tmp$, tmp$_0, tmp$_1, $receiver_0 != null ? $receiver_0 : '');\n };\n NumberFormat.prototype.computePadding_0 = function (output) {\n var length = output.sign.length + output.prefix.length + output.body.fullLength + output.suffix.length | 0;\n var padding = length < this.spec_0.width ? repeat(this.spec_0.fill, this.spec_0.width - length | 0) : '';\n return output.copy_rm1j3u$(void 0, void 0, void 0, void 0, padding);\n };\n function NumberFormat$Companion() {\n NumberFormat$Companion_instance = this;\n this.TYPE_E_MIN = 1.0E-323;\n this.TYPE_S_UPPER_LIMiT = 1.0E40;\n this.TYPE_S_MAX = 1.0E26;\n this.CURRENCY_0 = '$';\n this.PERCENT_0 = '%';\n this.COMMA_0 = ',';\n this.FRACTION_DELIMITER_0 = '.';\n this.FRACTION_DELIMITER_LENGTH_0 = 1;\n this.GROUP_SIZE_0 = 3;\n this.SI_SUFFIXES_0 = ['y', 'z', 'a', 'f', 'p', 'n', '\\xB5', 'm', '', 'k', 'M', 'G', 'T', 'P', 'E', 'Z', 'Y'];\n this.NUMBER_REGEX_0 = Regex_init('^(?:([^{}])?([<>=^]))?([+ -])?([#$])?(0)?(\\\\d+)?(,)?(?:\\\\.(\\\\d+))?([%bcdefgosXx])?$');\n }\n NumberFormat$Companion.prototype.create_61zpoe$ = function (spec) {\n return this.create_xck536$(this.parse_0(spec));\n };\n NumberFormat$Companion.prototype.create_xck536$ = function (spec) {\n var precision = spec.precision;\n var type = spec.type;\n var trim = false;\n if (equals(type, '')) {\n if (precision === -1) {\n precision = 12;\n }type = 'g';\n }if (equals(type, 'g')) {\n trim = true;\n }var zero = spec.zero;\n var fill = spec.fill;\n var align = spec.align;\n if (zero || (equals(fill, '0') && equals(align, '='))) {\n zero = true;\n fill = '0';\n align = '=';\n }return spec.copy_xzdl1p$(fill, align, void 0, void 0, zero, void 0, void 0, precision, type, trim);\n };\n NumberFormat$Companion.prototype.isValidPattern_61zpoe$ = function (spec) {\n return this.NUMBER_REGEX_0.matches_6bul2c$(spec);\n };\n NumberFormat$Companion.prototype.parse_0 = function (spec) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5, tmp$_6, tmp$_7, tmp$_8, tmp$_9, tmp$_10, tmp$_11, tmp$_12, tmp$_13;\n tmp$ = this.NUMBER_REGEX_0.find_905azu$(spec);\n if (tmp$ == null) {\n throw IllegalArgumentException_init('Wrong pattern format');\n }var matchResult = tmp$;\n return new NumberFormat$Spec((tmp$_1 = (tmp$_0 = matchResult.groups.get_za3lpa$(1)) != null ? tmp$_0.value : null) != null ? tmp$_1 : ' ', (tmp$_3 = (tmp$_2 = matchResult.groups.get_za3lpa$(2)) != null ? tmp$_2.value : null) != null ? tmp$_3 : '>', (tmp$_5 = (tmp$_4 = matchResult.groups.get_za3lpa$(3)) != null ? tmp$_4.value : null) != null ? tmp$_5 : '-', (tmp$_7 = (tmp$_6 = matchResult.groups.get_za3lpa$(4)) != null ? tmp$_6.value : null) != null ? tmp$_7 : '', matchResult.groups.get_za3lpa$(5) != null, toInt((tmp$_9 = (tmp$_8 = matchResult.groups.get_za3lpa$(6)) != null ? tmp$_8.value : null) != null ? tmp$_9 : '-1'), matchResult.groups.get_za3lpa$(7) != null, toInt((tmp$_11 = (tmp$_10 = matchResult.groups.get_za3lpa$(8)) != null ? tmp$_10.value : null) != null ? tmp$_11 : '6'), (tmp$_13 = (tmp$_12 = matchResult.groups.get_za3lpa$(9)) != null ? tmp$_12.value : null) != null ? tmp$_13 : '');\n };\n function NumberFormat$Companion$group$lambda(it) {\n return joinToString(it, '');\n }\n NumberFormat$Companion.prototype.group_0 = function (str) {\n var tmp$;\n var $receiver = joinToString_0(map(chunked(asSequence_0(reversed_0(Kotlin.isCharSequence(tmp$ = str) ? tmp$ : throwCCE()).toString()), 3), NumberFormat$Companion$group$lambda), this.COMMA_0);\n var tmp$_0;\n return reversed_0(Kotlin.isCharSequence(tmp$_0 = $receiver) ? tmp$_0 : throwCCE()).toString();\n };\n NumberFormat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NumberFormat$Companion_instance = null;\n function NumberFormat$Companion_getInstance() {\n if (NumberFormat$Companion_instance === null) {\n new NumberFormat$Companion();\n }return NumberFormat$Companion_instance;\n }\n NumberFormat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumberFormat',\n interfaces: []\n };\n function NumberFormat_init(spec, $this) {\n $this = $this || Object.create(NumberFormat.prototype);\n NumberFormat.call($this, NumberFormat$Companion_getInstance().create_61zpoe$(spec));\n return $this;\n }\n function ChildList(myParent) {\n ObservableArrayList.call(this);\n this.myParent_2riath$_0 = myParent;\n this.addListener_n5no9j$(new ChildList_init$ObjectLiteral());\n }\n ChildList.prototype.checkAdd_wxm5ur$ = function (index, item) {\n ObservableArrayList.prototype.checkAdd_wxm5ur$.call(this, index, item);\n if (item.parentProperty().get() != null) {\n throw IllegalArgumentException_init_0();\n }};\n function ChildList$beforeItemAdded$ObjectLiteral(closure$item, this$ChildList) {\n this.closure$item = closure$item;\n this.this$ChildList = this$ChildList;\n }\n function ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral(this$ChildList, closure$index) {\n this.this$ChildList = this$ChildList;\n this.closure$index = closure$index;\n }\n Object.defineProperty(ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.prototype, 'role', {\n configurable: true,\n get: function () {\n return this.this$ChildList;\n }\n });\n ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.prototype.get = function () {\n return this.this$ChildList.size <= this.closure$index ? null : this.this$ChildList.get_za3lpa$(this.closure$index);\n };\n ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Position]\n };\n ChildList$beforeItemAdded$ObjectLiteral.prototype.get = function () {\n var index = this.this$ChildList.indexOf_11rb$(this.closure$item);\n return new ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral(this.this$ChildList, index);\n };\n ChildList$beforeItemAdded$ObjectLiteral.prototype.remove = function () {\n this.this$ChildList.remove_11rb$(this.closure$item);\n };\n ChildList$beforeItemAdded$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionData]\n };\n ChildList.prototype.beforeItemAdded_wxm5ur$ = function (index, item) {\n item.parentProperty().set_11rb$(this.myParent_2riath$_0);\n item.setPositionData_uvvaqs$(new ChildList$beforeItemAdded$ObjectLiteral(item, this));\n };\n ChildList.prototype.checkSet_hu11d4$ = function (index, oldItem, newItem) {\n ObservableArrayList.prototype.checkSet_hu11d4$.call(this, index, oldItem, newItem);\n this.checkRemove_wxm5ur$(index, oldItem);\n this.checkAdd_wxm5ur$(index, newItem);\n };\n ChildList.prototype.beforeItemSet_hu11d4$ = function (index, oldItem, newItem) {\n this.beforeItemAdded_wxm5ur$(index, newItem);\n };\n ChildList.prototype.checkRemove_wxm5ur$ = function (index, item) {\n ObservableArrayList.prototype.checkRemove_wxm5ur$.call(this, index, item);\n if (item.parentProperty().get() !== this.myParent_2riath$_0) {\n throw IllegalArgumentException_init_0();\n }};\n function ChildList_init$ObjectLiteral() {\n CollectionAdapter.call(this);\n }\n ChildList_init$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n ensureNotNull(event.newItem).parentProperty().flush();\n };\n ChildList_init$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n var item = event.oldItem;\n ensureNotNull(item).parentProperty().set_11rb$(null);\n item.setPositionData_uvvaqs$(null);\n item.parentProperty().flush();\n };\n ChildList_init$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionAdapter]\n };\n ChildList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ChildList',\n interfaces: [ObservableArrayList]\n };\n function ChildProperty(myParent) {\n ValueProperty.call(this, null);\n this.myParent_0 = myParent;\n }\n function ChildProperty$set$ObjectLiteral(this$ChildProperty) {\n this.this$ChildProperty = this$ChildProperty;\n }\n function ChildProperty$set$ObjectLiteral$get$ObjectLiteral(this$ChildProperty) {\n this.this$ChildProperty = this$ChildProperty;\n }\n Object.defineProperty(ChildProperty$set$ObjectLiteral$get$ObjectLiteral.prototype, 'role', {\n configurable: true,\n get: function () {\n return this.this$ChildProperty;\n }\n });\n ChildProperty$set$ObjectLiteral$get$ObjectLiteral.prototype.get = function () {\n return this.this$ChildProperty.get();\n };\n ChildProperty$set$ObjectLiteral$get$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Position]\n };\n ChildProperty$set$ObjectLiteral.prototype.get = function () {\n return new ChildProperty$set$ObjectLiteral$get$ObjectLiteral(this.this$ChildProperty);\n };\n ChildProperty$set$ObjectLiteral.prototype.remove = function () {\n this.this$ChildProperty.set_11rb$(null);\n };\n ChildProperty$set$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionData]\n };\n ChildProperty.prototype.set_11rb$ = function (value) {\n var tmp$;\n if (this.get() === value)\n return;\n if (value != null && value.parentProperty().get() != null) {\n throw IllegalStateException_init_0();\n }var oldValue = this.get();\n if (oldValue != null) {\n oldValue.parentProperty().set_11rb$(null);\n oldValue.setPositionData_uvvaqs$(null);\n }if (value != null) {\n value.parentProperty().set_11rb$(this.myParent_0);\n value.setPositionData_uvvaqs$(new ChildProperty$set$ObjectLiteral(this));\n }ValueProperty.prototype.set_11rb$.call(this, value);\n if (oldValue != null) {\n oldValue.parentProperty().flush();\n }(tmp$ = value != null ? value.parentProperty() : null) != null ? (tmp$.flush(), Unit) : null;\n };\n ChildProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ChildProperty',\n interfaces: [ValueProperty]\n };\n function Position() {\n }\n Position.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Position',\n interfaces: []\n };\n function PositionData() {\n }\n PositionData.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PositionData',\n interfaces: []\n };\n function SimpleComposite() {\n this.myParent_eaa9sw$_0 = new DelayedValueProperty();\n this.myPositionData_2io8uh$_0 = null;\n }\n Object.defineProperty(SimpleComposite.prototype, 'position', {\n configurable: true,\n get: function () {\n if (this.myPositionData_2io8uh$_0 == null) {\n throw IllegalStateException_init_0();\n }return ensureNotNull(this.myPositionData_2io8uh$_0).get();\n }\n });\n SimpleComposite.prototype.removeFromParent = function () {\n if (this.myPositionData_2io8uh$_0 == null)\n return;\n ensureNotNull(this.myPositionData_2io8uh$_0).remove();\n };\n SimpleComposite.prototype.parentProperty = function () {\n return this.myParent_eaa9sw$_0;\n };\n SimpleComposite.prototype.setPositionData_uvvaqs$ = function (positionData) {\n this.myPositionData_2io8uh$_0 = positionData;\n };\n SimpleComposite.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimpleComposite',\n interfaces: []\n };\n function CollectionAdapter() {\n }\n CollectionAdapter.prototype.onItemAdded_u8tacu$ = function (event) {\n };\n CollectionAdapter.prototype.onItemSet_u8tacu$ = function (event) {\n this.onItemRemoved_u8tacu$(new CollectionItemEvent(event.oldItem, null, event.index, CollectionItemEvent$EventType$REMOVE_getInstance()));\n this.onItemAdded_u8tacu$(new CollectionItemEvent(null, event.newItem, event.index, CollectionItemEvent$EventType$ADD_getInstance()));\n };\n CollectionAdapter.prototype.onItemRemoved_u8tacu$ = function (event) {\n };\n CollectionAdapter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectionAdapter',\n interfaces: [CollectionListener]\n };\n function CollectionItemEvent(oldItem, newItem, index, type) {\n this.oldItem = oldItem;\n this.newItem = newItem;\n this.index = index;\n this.type = type;\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type && this.oldItem != null || (CollectionItemEvent$EventType$REMOVE_getInstance() === this.type && this.newItem != null)) {\n throw IllegalStateException_init_0();\n }}\n CollectionItemEvent.prototype.dispatch_11rb$ = function (l) {\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type) {\n l.onItemAdded_u8tacu$(this);\n } else if (CollectionItemEvent$EventType$SET_getInstance() === this.type) {\n l.onItemSet_u8tacu$(this);\n } else {\n l.onItemRemoved_u8tacu$(this);\n }\n };\n CollectionItemEvent.prototype.toString = function () {\n var tmp$;\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type) {\n tmp$ = toString(this.newItem) + ' added at ' + toString(this.index);\n } else if (CollectionItemEvent$EventType$SET_getInstance() === this.type) {\n tmp$ = toString(this.oldItem) + ' replaced with ' + toString(this.newItem) + ' at ' + toString(this.index);\n } else {\n tmp$ = toString(this.oldItem) + ' removed at ' + toString(this.index);\n }\n return tmp$;\n };\n CollectionItemEvent.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, CollectionItemEvent) ? tmp$_0 : throwCCE();\n if (!equals(this.oldItem, other.oldItem))\n return false;\n if (!equals(this.newItem, other.newItem))\n return false;\n if (this.index !== other.index)\n return false;\n if (this.type !== other.type)\n return false;\n return true;\n };\n CollectionItemEvent.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.oldItem) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.newItem) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n result = (31 * result | 0) + this.index | 0;\n result = (31 * result | 0) + this.type.hashCode() | 0;\n return result;\n };\n function CollectionItemEvent$EventType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CollectionItemEvent$EventType_initFields() {\n CollectionItemEvent$EventType_initFields = function () {\n };\n CollectionItemEvent$EventType$ADD_instance = new CollectionItemEvent$EventType('ADD', 0);\n CollectionItemEvent$EventType$SET_instance = new CollectionItemEvent$EventType('SET', 1);\n CollectionItemEvent$EventType$REMOVE_instance = new CollectionItemEvent$EventType('REMOVE', 2);\n }\n var CollectionItemEvent$EventType$ADD_instance;\n function CollectionItemEvent$EventType$ADD_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$ADD_instance;\n }\n var CollectionItemEvent$EventType$SET_instance;\n function CollectionItemEvent$EventType$SET_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$SET_instance;\n }\n var CollectionItemEvent$EventType$REMOVE_instance;\n function CollectionItemEvent$EventType$REMOVE_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$REMOVE_instance;\n }\n CollectionItemEvent$EventType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EventType',\n interfaces: [Enum]\n };\n function CollectionItemEvent$EventType$values() {\n return [CollectionItemEvent$EventType$ADD_getInstance(), CollectionItemEvent$EventType$SET_getInstance(), CollectionItemEvent$EventType$REMOVE_getInstance()];\n }\n CollectionItemEvent$EventType.values = CollectionItemEvent$EventType$values;\n function CollectionItemEvent$EventType$valueOf(name) {\n switch (name) {\n case 'ADD':\n return CollectionItemEvent$EventType$ADD_getInstance();\n case 'SET':\n return CollectionItemEvent$EventType$SET_getInstance();\n case 'REMOVE':\n return CollectionItemEvent$EventType$REMOVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.observable.collections.CollectionItemEvent.EventType.' + name);\n }\n }\n CollectionItemEvent$EventType.valueOf_61zpoe$ = CollectionItemEvent$EventType$valueOf;\n CollectionItemEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectionItemEvent',\n interfaces: [ListenerEvent]\n };\n function CollectionListener() {\n }\n CollectionListener.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CollectionListener',\n interfaces: []\n };\n function ObservableCollection() {\n }\n ObservableCollection.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ObservableCollection',\n interfaces: [EventSource, MutableCollection]\n };\n function AbstractObservableList() {\n AbstractMutableList.call(this);\n this.myListeners_ky8jhb$_0 = null;\n }\n AbstractObservableList.prototype.checkAdd_wxm5ur$ = function (index, item) {\n if (index < 0 || index > this.size) {\n throw new IndexOutOfBoundsException('Add: index=' + index + ', size=' + this.size);\n }};\n AbstractObservableList.prototype.checkSet_hu11d4$ = function (index, oldItem, newItem) {\n if (index < 0 || index >= this.size) {\n throw new IndexOutOfBoundsException('Set: index=' + index + ', size=' + this.size);\n }};\n AbstractObservableList.prototype.checkRemove_wxm5ur$ = function (index, item) {\n if (index < 0 || index >= this.size) {\n throw new IndexOutOfBoundsException('Remove: index=' + index + ', size=' + this.size);\n }};\n function AbstractObservableList$add$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$add$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemAdded_u8tacu$(this.closure$event);\n };\n AbstractObservableList$add$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.add_wxm5ur$ = function (index, element) {\n this.checkAdd_wxm5ur$(index, element);\n this.beforeItemAdded_wxm5ur$(index, element);\n var success = false;\n try {\n this.doAdd_wxm5ur$(index, element);\n success = true;\n this.onItemAdd_wxm5ur$(index, element);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(null, element, index, CollectionItemEvent$EventType$ADD_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$add$ObjectLiteral(event));\n }}finally {\n this.afterItemAdded_5x52oa$(index, element, success);\n }\n };\n AbstractObservableList.prototype.beforeItemAdded_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.onItemAdd_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.afterItemAdded_5x52oa$ = function (index, item, success) {\n };\n function AbstractObservableList$set$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$set$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemSet_u8tacu$(this.closure$event);\n };\n AbstractObservableList$set$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.set_wxm5ur$ = function (index, element) {\n var old = this.get_za3lpa$(index);\n this.checkSet_hu11d4$(index, old, element);\n this.beforeItemSet_hu11d4$(index, old, element);\n var success = false;\n try {\n this.doSet_wxm5ur$(index, element);\n success = true;\n this.onItemSet_hu11d4$(index, old, element);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(old, element, index, CollectionItemEvent$EventType$SET_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$set$ObjectLiteral(event));\n }}finally {\n this.afterItemSet_yk9x8x$(index, old, element, success);\n }\n return old;\n };\n AbstractObservableList.prototype.doSet_wxm5ur$ = function (index, item) {\n this.doRemove_za3lpa$(index);\n this.doAdd_wxm5ur$(index, item);\n };\n AbstractObservableList.prototype.beforeItemSet_hu11d4$ = function (index, oldItem, newItem) {\n };\n AbstractObservableList.prototype.onItemSet_hu11d4$ = function (index, oldItem, newItem) {\n };\n AbstractObservableList.prototype.afterItemSet_yk9x8x$ = function (index, oldItem, newItem, success) {\n };\n function AbstractObservableList$removeAt$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$removeAt$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemRemoved_u8tacu$(this.closure$event);\n };\n AbstractObservableList$removeAt$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.removeAt_za3lpa$ = function (index) {\n var item = this.get_za3lpa$(index);\n this.checkRemove_wxm5ur$(index, item);\n this.beforeItemRemoved_wxm5ur$(index, item);\n var success = false;\n try {\n this.doRemove_za3lpa$(index);\n success = true;\n this.onItemRemove_wxm5ur$(index, item);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(item, null, index, CollectionItemEvent$EventType$REMOVE_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$removeAt$ObjectLiteral(event));\n }}finally {\n this.afterItemRemoved_5x52oa$(index, item, success);\n }\n return item;\n };\n AbstractObservableList.prototype.beforeItemRemoved_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.onItemRemove_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.afterItemRemoved_5x52oa$ = function (index, item, success) {\n };\n function AbstractObservableList$addListener$ObjectLiteral(this$AbstractObservableList) {\n this.this$AbstractObservableList = this$AbstractObservableList;\n Listeners.call(this);\n }\n AbstractObservableList$addListener$ObjectLiteral.prototype.beforeFirstAdded = function () {\n this.this$AbstractObservableList.onListenersAdded();\n };\n AbstractObservableList$addListener$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$AbstractObservableList.myListeners_ky8jhb$_0 = null;\n this.this$AbstractObservableList.onListenersRemoved();\n };\n AbstractObservableList$addListener$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n AbstractObservableList.prototype.addListener_n5no9j$ = function (l) {\n if (this.myListeners_ky8jhb$_0 == null) {\n this.myListeners_ky8jhb$_0 = new AbstractObservableList$addListener$ObjectLiteral(this);\n }return ensureNotNull(this.myListeners_ky8jhb$_0).add_11rb$(l);\n };\n function AbstractObservableList$addHandler$ObjectLiteral(closure$handler) {\n this.closure$handler = closure$handler;\n }\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemSet_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionListener]\n };\n AbstractObservableList.prototype.addHandler_gxwwpc$ = function (handler) {\n var listener = new AbstractObservableList$addHandler$ObjectLiteral(handler);\n return this.addListener_n5no9j$(listener);\n };\n AbstractObservableList.prototype.onListenersAdded = function () {\n };\n AbstractObservableList.prototype.onListenersRemoved = function () {\n };\n AbstractObservableList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractObservableList',\n interfaces: [ObservableList, AbstractMutableList]\n };\n function ObservableArrayList() {\n AbstractObservableList.call(this);\n this.myContainer_2lyzpq$_0 = null;\n }\n Object.defineProperty(ObservableArrayList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myContainer_2lyzpq$_0 == null ? 0 : ensureNotNull(this.myContainer_2lyzpq$_0).size;\n }\n });\n ObservableArrayList.prototype.get_za3lpa$ = function (index) {\n if (this.myContainer_2lyzpq$_0 == null) {\n throw new IndexOutOfBoundsException(index.toString());\n }return ensureNotNull(this.myContainer_2lyzpq$_0).get_za3lpa$(index);\n };\n ObservableArrayList.prototype.doAdd_wxm5ur$ = function (index, item) {\n this.ensureContainerInitialized_mjxwec$_0();\n ensureNotNull(this.myContainer_2lyzpq$_0).add_wxm5ur$(index, item);\n };\n ObservableArrayList.prototype.doSet_wxm5ur$ = function (index, item) {\n ensureNotNull(this.myContainer_2lyzpq$_0).set_wxm5ur$(index, item);\n };\n ObservableArrayList.prototype.doRemove_za3lpa$ = function (index) {\n ensureNotNull(this.myContainer_2lyzpq$_0).removeAt_za3lpa$(index);\n if (ensureNotNull(this.myContainer_2lyzpq$_0).isEmpty()) {\n this.myContainer_2lyzpq$_0 = null;\n }};\n ObservableArrayList.prototype.ensureContainerInitialized_mjxwec$_0 = function () {\n if (this.myContainer_2lyzpq$_0 == null) {\n this.myContainer_2lyzpq$_0 = ArrayList_init_0(1);\n }};\n ObservableArrayList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ObservableArrayList',\n interfaces: [AbstractObservableList]\n };\n function ObservableList() {\n }\n ObservableList.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ObservableList',\n interfaces: [ObservableCollection, MutableList]\n };\n function CompositeEventSource() {\n this.myHandlers_0 = null;\n this.myEventSources_0 = ArrayList_init();\n this.myRegistrations_0 = ArrayList_init();\n }\n CompositeEventSource.prototype.add_5zt0a2$ = function (source) {\n this.myEventSources_0.add_11rb$(source);\n };\n CompositeEventSource.prototype.remove_r5wlyb$ = function (source) {\n var $receiver = this.myEventSources_0;\n var tmp$;\n (Kotlin.isType(tmp$ = $receiver, MutableCollection) ? tmp$ : throwCCE()).remove_11rb$(source);\n };\n function CompositeEventSource$addHandler$ObjectLiteral(this$CompositeEventSource) {\n this.this$CompositeEventSource = this$CompositeEventSource;\n Listeners.call(this);\n }\n CompositeEventSource$addHandler$ObjectLiteral.prototype.beforeFirstAdded = function () {\n var tmp$;\n tmp$ = this.this$CompositeEventSource.myEventSources_0.iterator();\n while (tmp$.hasNext()) {\n var src = tmp$.next();\n this.this$CompositeEventSource.addHandlerTo_0(src);\n }\n };\n CompositeEventSource$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n var tmp$;\n tmp$ = this.this$CompositeEventSource.myRegistrations_0.iterator();\n while (tmp$.hasNext()) {\n var hr = tmp$.next();\n hr.remove();\n }\n this.this$CompositeEventSource.myRegistrations_0.clear();\n this.this$CompositeEventSource.myHandlers_0 = null;\n };\n CompositeEventSource$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n CompositeEventSource.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_0 == null) {\n this.myHandlers_0 = new CompositeEventSource$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_0).add_11rb$(handler);\n };\n function CompositeEventSource$addHandlerTo$ObjectLiteral(this$CompositeEventSource) {\n this.this$CompositeEventSource = this$CompositeEventSource;\n }\n function CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$event);\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n ensureNotNull(this.this$CompositeEventSource.myHandlers_0).fire_kucmxw$(new CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral(event));\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n CompositeEventSource.prototype.addHandlerTo_0 = function (src) {\n this.myRegistrations_0.add_11rb$(src.addHandler_gxwwpc$(new CompositeEventSource$addHandlerTo$ObjectLiteral(this)));\n };\n CompositeEventSource.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeEventSource',\n interfaces: [EventSource]\n };\n function CompositeEventSource_init(sources, $this) {\n $this = $this || Object.create(CompositeEventSource.prototype);\n CompositeEventSource.call($this);\n var tmp$;\n for (tmp$ = 0; tmp$ !== sources.length; ++tmp$) {\n var s = sources[tmp$];\n $this.add_5zt0a2$(s);\n }\n return $this;\n }\n function CompositeEventSource_init_0(sources, $this) {\n $this = $this || Object.create(CompositeEventSource.prototype);\n CompositeEventSource.call($this);\n var tmp$;\n tmp$ = sources.iterator();\n while (tmp$.hasNext()) {\n var s = tmp$.next();\n $this.add_5zt0a2$(s);\n }\n return $this;\n }\n function EventHandler() {\n }\n EventHandler.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventHandler',\n interfaces: []\n };\n function EventSource() {\n }\n EventSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventSource',\n interfaces: []\n };\n function EventSources() {\n EventSources_instance = this;\n }\n function EventSources$of$ObjectLiteral(closure$events) {\n this.closure$events = closure$events;\n }\n EventSources$of$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n var tmp$, tmp$_0;\n tmp$ = this.closure$events;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var e = tmp$[tmp$_0];\n handler.onEvent_11rb$(e);\n }\n return Registration$Companion_getInstance().EMPTY;\n };\n EventSources$of$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.of_i5x0yv$ = function (events) {\n return new EventSources$of$ObjectLiteral(events);\n };\n EventSources.prototype.empty_287e2$ = function () {\n return this.composite_xw2ruy$([]);\n };\n EventSources.prototype.composite_xw2ruy$ = function (sources) {\n return CompositeEventSource_init(sources.slice());\n };\n EventSources.prototype.composite_3qo2qg$ = function (sources) {\n return CompositeEventSource_init_0(sources);\n };\n function EventSources$filter$ObjectLiteral(closure$source, closure$pred) {\n this.closure$source = closure$source;\n this.closure$pred = closure$pred;\n }\n function EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral(closure$pred, closure$handler) {\n this.closure$pred = closure$pred;\n this.closure$handler = closure$handler;\n }\n EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n if (this.closure$pred(event)) {\n this.closure$handler.onEvent_11rb$(event);\n }};\n EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n EventSources$filter$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n return this.closure$source.addHandler_gxwwpc$(new EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral(this.closure$pred, handler));\n };\n EventSources$filter$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.filter_ff3xdm$ = function (source, pred) {\n return new EventSources$filter$ObjectLiteral(source, pred);\n };\n EventSources.prototype.map_9hq6p$ = function (src, f) {\n return new MappingEventSource(src, f);\n };\n function EventSources$selectList$ObjectLiteral(closure$list, closure$selector) {\n this.closure$list = closure$list;\n this.closure$selector = closure$selector;\n }\n function EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral(closure$itemRegs, closure$selector, closure$handler) {\n this.closure$itemRegs = closure$itemRegs;\n this.closure$selector = closure$selector;\n this.closure$handler = closure$handler;\n CollectionAdapter.call(this);\n }\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n this.closure$itemRegs.add_wxm5ur$(event.index, this.closure$selector(event.newItem).addHandler_gxwwpc$(this.closure$handler));\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n this.closure$itemRegs.removeAt_za3lpa$(event.index).remove();\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionAdapter]\n };\n function EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0(closure$itemRegs, closure$listReg) {\n this.closure$itemRegs = closure$itemRegs;\n this.closure$listReg = closure$listReg;\n Registration.call(this);\n }\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype.doRemove = function () {\n var tmp$;\n tmp$ = this.closure$itemRegs.iterator();\n while (tmp$.hasNext()) {\n var r = tmp$.next();\n r.remove();\n }\n this.closure$listReg.remove();\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n EventSources$selectList$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n var tmp$;\n var itemRegs = ArrayList_init();\n tmp$ = this.closure$list.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n itemRegs.add_11rb$(this.closure$selector(item).addHandler_gxwwpc$(handler));\n }\n var listReg = this.closure$list.addListener_n5no9j$(new EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral(itemRegs, this.closure$selector, handler));\n return new EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0(itemRegs, listReg);\n };\n EventSources$selectList$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.selectList_jnjwvc$ = function (list, selector) {\n return new EventSources$selectList$ObjectLiteral(list, selector);\n };\n EventSources.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'EventSources',\n interfaces: []\n };\n var EventSources_instance = null;\n function EventSources_getInstance() {\n if (EventSources_instance === null) {\n new EventSources();\n }return EventSources_instance;\n }\n function ListenerCaller() {\n }\n ListenerCaller.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ListenerCaller',\n interfaces: []\n };\n function ListenerEvent() {\n }\n ListenerEvent.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ListenerEvent',\n interfaces: []\n };\n function Listeners() {\n this.myListeners_30lqoe$_0 = null;\n this.myFireDepth_t4vnc0$_0 = 0;\n this.myListenersCount_umrzvt$_0 = 0;\n }\n Object.defineProperty(Listeners.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myListeners_30lqoe$_0 == null || ensureNotNull(this.myListeners_30lqoe$_0).isEmpty();\n }\n });\n function Listeners$add$ObjectLiteral(this$Listeners, closure$l) {\n this.this$Listeners = this$Listeners;\n this.closure$l = closure$l;\n Registration.call(this);\n }\n Listeners$add$ObjectLiteral.prototype.doRemove = function () {\n var tmp$, tmp$_0;\n if (this.this$Listeners.myFireDepth_t4vnc0$_0 > 0) {\n ensureNotNull(this.this$Listeners.myListeners_30lqoe$_0).add_11rb$(new Listeners$ListenerOp(this.closure$l, false));\n } else {\n ensureNotNull(this.this$Listeners.myListeners_30lqoe$_0).remove_11rb$(Kotlin.isType(tmp$ = this.closure$l, Any) ? tmp$ : throwCCE());\n tmp$_0 = this.this$Listeners.myListenersCount_umrzvt$_0;\n this.this$Listeners.myListenersCount_umrzvt$_0 = tmp$_0 - 1 | 0;\n }\n if (this.this$Listeners.isEmpty) {\n this.this$Listeners.afterLastRemoved();\n }};\n Listeners$add$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Listeners.prototype.add_11rb$ = function (l) {\n var tmp$;\n if (this.isEmpty) {\n this.beforeFirstAdded();\n }if (this.myFireDepth_t4vnc0$_0 > 0) {\n ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(new Listeners$ListenerOp(l, true));\n } else {\n if (this.myListeners_30lqoe$_0 == null) {\n this.myListeners_30lqoe$_0 = ArrayList_init_0(1);\n }ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(Kotlin.isType(tmp$ = l, Any) ? tmp$ : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 + 1 | 0;\n }\n return new Listeners$add$ObjectLiteral(this, l);\n };\n Listeners.prototype.fire_kucmxw$ = function (h) {\n var tmp$;\n if (this.isEmpty)\n return;\n this.beforeFire_ul1jia$_0();\n try {\n var size = this.myListenersCount_umrzvt$_0;\n for (var i = 0; i < size; i++) {\n var l = (tmp$ = ensureNotNull(this.myListeners_30lqoe$_0).get_za3lpa$(i)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n if (this.isRemoved_265rjw$_0(l))\n continue;\n try {\n h.call_11rb$(l);\n } catch (t) {\n if (Kotlin.isType(t, Throwable)) {\n ThrowableHandlers_getInstance().instance.handle_tcv7n7$(t);\n } else\n throw t;\n }\n }\n }finally {\n this.afterFire_xwa8xb$_0();\n }\n };\n Listeners.prototype.isRemoved_265rjw$_0 = function (l) {\n var tmp$;\n var size = ensureNotNull(this.myListeners_30lqoe$_0).size;\n for (var i = this.myListenersCount_umrzvt$_0; i < size; i++) {\n var op = Kotlin.isType(tmp$ = ensureNotNull(this.myListeners_30lqoe$_0).get_za3lpa$(i), Listeners$ListenerOp) ? tmp$ : throwCCE();\n if (!op.add && op.listener === l)\n return true;\n }\n return false;\n };\n Listeners.prototype.beforeFirstAdded = function () {\n };\n Listeners.prototype.afterLastRemoved = function () {\n };\n Listeners.prototype.beforeFire_ul1jia$_0 = function () {\n this.myFireDepth_t4vnc0$_0 = this.myFireDepth_t4vnc0$_0 + 1 | 0;\n };\n Listeners.prototype.afterFire_xwa8xb$_0 = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n this.myFireDepth_t4vnc0$_0 = this.myFireDepth_t4vnc0$_0 - 1 | 0;\n if (this.myFireDepth_t4vnc0$_0 === 0) {\n var opsList = ensureNotNull(this.myListeners_30lqoe$_0).subList_vux9f0$(this.myListenersCount_umrzvt$_0, ensureNotNull(this.myListeners_30lqoe$_0).size);\n var ops = copyToArray(opsList);\n opsList.clear();\n for (tmp$ = 0; tmp$ !== ops.length; ++tmp$) {\n var o = ops[tmp$];\n var op = Kotlin.isType(tmp$_0 = o, Listeners$ListenerOp) ? tmp$_0 : throwCCE();\n if (op.add) {\n ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(Kotlin.isType(tmp$_1 = op.listener, Any) ? tmp$_1 : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 + 1 | 0;\n } else {\n ensureNotNull(this.myListeners_30lqoe$_0).remove_11rb$(Kotlin.isType(tmp$_2 = op.listener, Any) ? tmp$_2 : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 - 1 | 0;\n }\n }\n if (this.isEmpty) {\n this.afterLastRemoved();\n }}};\n Listeners.prototype.size_8be2vx$ = function () {\n return this.myListeners_30lqoe$_0 == null ? 0 : ensureNotNull(this.myListeners_30lqoe$_0).size;\n };\n function Listeners$ListenerOp(listener, add) {\n this.listener = listener;\n this.add = add;\n }\n Listeners$ListenerOp.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ListenerOp',\n interfaces: []\n };\n Listeners.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Listeners',\n interfaces: []\n };\n function MappingEventSource(mySourceEventSource, myFunction) {\n this.mySourceEventSource_0 = mySourceEventSource;\n this.myFunction_0 = myFunction;\n }\n function MappingEventSource$addHandler$ObjectLiteral(closure$handler, this$MappingEventSource) {\n this.closure$handler = closure$handler;\n this.this$MappingEventSource = this$MappingEventSource;\n }\n MappingEventSource$addHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.closure$handler.onEvent_11rb$(this.this$MappingEventSource.myFunction_0(event));\n };\n MappingEventSource$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n MappingEventSource.prototype.addHandler_gxwwpc$ = function (handler) {\n return this.mySourceEventSource_0.addHandler_gxwwpc$(new MappingEventSource$addHandler$ObjectLiteral(handler, this));\n };\n MappingEventSource.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappingEventSource',\n interfaces: [EventSource]\n };\n function BaseReadableProperty() {\n this.propExpr_4jt19b$_0 = Kotlin.getKClassFromExpression(this).toString();\n }\n Object.defineProperty(BaseReadableProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return this.propExpr_4jt19b$_0;\n }\n });\n BaseReadableProperty.prototype.toString = function () {\n return this.propExpr;\n };\n BaseReadableProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseReadableProperty',\n interfaces: [ReadableProperty]\n };\n function DelayedValueProperty(myValue) {\n if (myValue === void 0)\n myValue = null;\n BaseReadableProperty.call(this);\n this.myValue_0 = myValue;\n this.myHandlers_0 = null;\n this.myPendingEvent_0 = null;\n }\n Object.defineProperty(DelayedValueProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return 'delayedProperty()';\n }\n });\n DelayedValueProperty.prototype.get = function () {\n return this.myValue_0;\n };\n DelayedValueProperty.prototype.set_11rb$ = function (value) {\n if (equals(value, this.myValue_0))\n return;\n var oldValue = this.myValue_0;\n this.myValue_0 = value;\n if (this.myPendingEvent_0 != null) {\n throw IllegalStateException_init_0();\n }this.myPendingEvent_0 = new PropertyChangeEvent(oldValue, this.myValue_0);\n };\n function DelayedValueProperty$flush$ObjectLiteral(this$DelayedValueProperty) {\n this.this$DelayedValueProperty = this$DelayedValueProperty;\n }\n DelayedValueProperty$flush$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(ensureNotNull(this.this$DelayedValueProperty.myPendingEvent_0));\n };\n DelayedValueProperty$flush$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n DelayedValueProperty.prototype.flush = function () {\n if (this.myHandlers_0 != null) {\n ensureNotNull(this.myHandlers_0).fire_kucmxw$(new DelayedValueProperty$flush$ObjectLiteral(this));\n }this.myPendingEvent_0 = null;\n };\n function DelayedValueProperty$addHandler$ObjectLiteral(this$DelayedValueProperty) {\n this.this$DelayedValueProperty = this$DelayedValueProperty;\n Listeners.call(this);\n }\n DelayedValueProperty$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$DelayedValueProperty.myHandlers_0 = null;\n };\n DelayedValueProperty$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n DelayedValueProperty.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_0 == null) {\n this.myHandlers_0 = new DelayedValueProperty$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_0).add_11rb$(handler);\n };\n DelayedValueProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DelayedValueProperty',\n interfaces: [Property, BaseReadableProperty]\n };\n function Property() {\n }\n Property.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Property',\n interfaces: [WritableProperty, ReadableProperty]\n };\n function PropertyBinding() {\n PropertyBinding_instance = this;\n }\n function PropertyBinding$bindOneWay$ObjectLiteral(closure$target) {\n this.closure$target = closure$target;\n }\n PropertyBinding$bindOneWay$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var tmp$;\n this.closure$target.set_11rb$((tmp$ = event.newValue) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE());\n };\n PropertyBinding$bindOneWay$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n PropertyBinding.prototype.bindOneWay_2ov6i0$ = function (source, target) {\n target.set_11rb$(source.get());\n return source.addHandler_gxwwpc$(new PropertyBinding$bindOneWay$ObjectLiteral(target));\n };\n function PropertyBinding$bindTwoWay$UpdatingEventHandler(closure$syncing, closure$target, closure$source, myForward) {\n this.closure$syncing = closure$syncing;\n this.closure$target = closure$target;\n this.closure$source = closure$source;\n this.myForward_0 = myForward;\n }\n PropertyBinding$bindTwoWay$UpdatingEventHandler.prototype.onEvent_11rb$ = function (event) {\n if (this.closure$syncing.get())\n return;\n this.closure$syncing.set_11rb$(true);\n try {\n if (this.myForward_0) {\n this.closure$target.set_11rb$(this.closure$source.get());\n } else {\n this.closure$source.set_11rb$(this.closure$target.get());\n }\n }finally {\n this.closure$syncing.set_11rb$(false);\n }\n };\n PropertyBinding$bindTwoWay$UpdatingEventHandler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'UpdatingEventHandler',\n interfaces: [EventHandler]\n };\n PropertyBinding.prototype.bindTwoWay_ejkotq$ = function (source, target) {\n var syncing = new ValueProperty(false);\n target.set_11rb$(source.get());\n return new CompositeRegistration([source.addHandler_gxwwpc$(new PropertyBinding$bindTwoWay$UpdatingEventHandler(syncing, target, source, true)), target.addHandler_gxwwpc$(new PropertyBinding$bindTwoWay$UpdatingEventHandler(syncing, target, source, false))]);\n };\n PropertyBinding.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PropertyBinding',\n interfaces: []\n };\n var PropertyBinding_instance = null;\n function PropertyBinding_getInstance() {\n if (PropertyBinding_instance === null) {\n new PropertyBinding();\n }return PropertyBinding_instance;\n }\n function PropertyChangeEvent(oldValue, newValue) {\n this.oldValue = oldValue;\n this.newValue = newValue;\n }\n PropertyChangeEvent.prototype.toString = function () {\n return toString(this.oldValue) + ' -> ' + toString(this.newValue);\n };\n PropertyChangeEvent.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, PropertyChangeEvent) ? tmp$_0 : throwCCE();\n if (!equals(this.oldValue, other.oldValue))\n return false;\n if (!equals(this.newValue, other.newValue))\n return false;\n return true;\n };\n PropertyChangeEvent.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.oldValue) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.newValue) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n return result;\n };\n PropertyChangeEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PropertyChangeEvent',\n interfaces: []\n };\n function ReadableProperty() {\n }\n ReadableProperty.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ReadableProperty',\n interfaces: [Supplier, EventSource]\n };\n function ValueProperty(myValue) {\n BaseReadableProperty.call(this);\n this.myValue_x0fqz2$_0 = myValue;\n this.myHandlers_sdxgfs$_0 = null;\n }\n Object.defineProperty(ValueProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return 'valueProperty()';\n }\n });\n ValueProperty.prototype.get = function () {\n return this.myValue_x0fqz2$_0;\n };\n ValueProperty.prototype.set_11rb$ = function (value) {\n if (equals(value, this.myValue_x0fqz2$_0))\n return;\n var oldValue = this.myValue_x0fqz2$_0;\n this.myValue_x0fqz2$_0 = value;\n this.fireEvents_ym4swk$_0(oldValue, this.myValue_x0fqz2$_0);\n };\n function ValueProperty$fireEvents$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n ValueProperty$fireEvents$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$event);\n };\n ValueProperty$fireEvents$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n ValueProperty.prototype.fireEvents_ym4swk$_0 = function (oldValue, newValue) {\n if (this.myHandlers_sdxgfs$_0 != null) {\n var event = new PropertyChangeEvent(oldValue, newValue);\n ensureNotNull(this.myHandlers_sdxgfs$_0).fire_kucmxw$(new ValueProperty$fireEvents$ObjectLiteral(event));\n }};\n function ValueProperty$addHandler$ObjectLiteral(this$ValueProperty) {\n this.this$ValueProperty = this$ValueProperty;\n Listeners.call(this);\n }\n ValueProperty$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$ValueProperty.myHandlers_sdxgfs$_0 = null;\n };\n ValueProperty$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n ValueProperty.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_sdxgfs$_0 == null) {\n this.myHandlers_sdxgfs$_0 = new ValueProperty$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_sdxgfs$_0).add_11rb$(handler);\n };\n ValueProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ValueProperty',\n interfaces: [Property, BaseReadableProperty]\n };\n function WritableProperty() {\n }\n WritableProperty.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WritableProperty',\n interfaces: []\n };\n function RandomGaussian(random) {\n this.random = random;\n this.nextNextGaussian_0 = 0.0;\n this.haveNextNextGaussian_0 = false;\n }\n RandomGaussian.prototype.nextGaussian = function () {\n if (this.haveNextNextGaussian_0) {\n this.haveNextNextGaussian_0 = false;\n return this.nextNextGaussian_0;\n } else {\n var v1;\n var v2;\n var s;\n do {\n v1 = 2 * this.random.nextDouble() - 1;\n v2 = 2 * this.random.nextDouble() - 1;\n s = v1 * v1 + v2 * v2;\n }\n while (s >= 1 || s === 0.0);\n var x = s;\n var x_0 = -2 * JsMath.log(x) / s;\n var multiplier = JsMath.sqrt(x_0);\n this.nextNextGaussian_0 = v2 * multiplier;\n this.haveNextNextGaussian_0 = true;\n return v1 * multiplier;\n }\n };\n RandomGaussian.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomGaussian',\n interfaces: []\n };\n function RandomString() {\n RandomString_instance = this;\n }\n RandomString.prototype.randomString_za3lpa$ = function (len) {\n var alphabet = plus_2(plus_0(new CharRange(97, 122), new CharRange(65, 90)), new CharRange(48, 57));\n var list = ArrayList_init_0(len);\n for (var index = 0; index < len; index++) {\n list.add_11rb$(random(alphabet, Random.Default));\n }\n return joinToString(list, '');\n };\n RandomString.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'RandomString',\n interfaces: []\n };\n var RandomString_instance = null;\n function RandomString_getInstance() {\n if (RandomString_instance === null) {\n new RandomString();\n }return RandomString_instance;\n }\n function CompositeRegistration(regs) {\n Registration.call(this);\n this.myRegistrations_0 = null;\n this.myRegistrations_0 = arrayListOf(regs.slice());\n }\n Object.defineProperty(CompositeRegistration.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myRegistrations_0.isEmpty();\n }\n });\n CompositeRegistration.prototype.add_3xv6fb$ = function (r) {\n this.myRegistrations_0.add_11rb$(r);\n return this;\n };\n CompositeRegistration.prototype.add_4wx45g$ = function (rs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== rs.length; ++tmp$) {\n var r = rs[tmp$];\n this.add_3xv6fb$(r);\n }\n return this;\n };\n CompositeRegistration.prototype.doRemove = function () {\n for (var i = this.myRegistrations_0.size - 1 | 0; i >= 0; i--) {\n this.myRegistrations_0.get_za3lpa$(i).remove();\n }\n this.myRegistrations_0.clear();\n };\n CompositeRegistration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeRegistration',\n interfaces: [Registration]\n };\n function Disposable() {\n }\n Disposable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Disposable',\n interfaces: []\n };\n function Registration() {\n Registration$Companion_getInstance();\n this.myRemoved_guv51v$_0 = false;\n }\n Registration.prototype.remove = function () {\n if (this.myRemoved_guv51v$_0) {\n throw IllegalStateException_init('Registration already removed');\n }this.myRemoved_guv51v$_0 = true;\n this.doRemove();\n };\n Registration.prototype.dispose = function () {\n this.remove();\n };\n function Registration$EmptyRegistration() {\n Registration.call(this);\n }\n Registration$EmptyRegistration.prototype.doRemove = function () {\n };\n Registration$EmptyRegistration.prototype.remove = function () {\n };\n Registration$EmptyRegistration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EmptyRegistration',\n interfaces: [Registration]\n };\n function Registration$Companion() {\n Registration$Companion_instance = this;\n this.EMPTY = new Registration$EmptyRegistration();\n }\n function Registration$Companion$from$ObjectLiteral(closure$disposable) {\n this.closure$disposable = closure$disposable;\n Registration.call(this);\n }\n Registration$Companion$from$ObjectLiteral.prototype.doRemove = function () {\n this.closure$disposable.dispose();\n };\n Registration$Companion$from$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Registration$Companion.prototype.from_gg3y3y$ = function (disposable) {\n return new Registration$Companion$from$ObjectLiteral(disposable);\n };\n function Registration$Companion$from$ObjectLiteral_0(closure$disposables) {\n this.closure$disposables = closure$disposables;\n Registration.call(this);\n }\n Registration$Companion$from$ObjectLiteral_0.prototype.doRemove = function () {\n var tmp$, tmp$_0;\n tmp$ = this.closure$disposables;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var d = tmp$[tmp$_0];\n d.dispose();\n }\n };\n Registration$Companion$from$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Registration$Companion.prototype.from_h9hjd7$ = function (disposables) {\n return new Registration$Companion$from$ObjectLiteral_0(disposables);\n };\n Registration$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Registration$Companion_instance = null;\n function Registration$Companion_getInstance() {\n if (Registration$Companion_instance === null) {\n new Registration$Companion();\n }return Registration$Companion_instance;\n }\n Registration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Registration',\n interfaces: [Disposable]\n };\n function ThrowableHandler() {\n }\n ThrowableHandler.prototype.handle_tcv7n7$ = function (t) {\n throw t;\n };\n ThrowableHandler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ThrowableHandler',\n interfaces: []\n };\n function ThrowableHandlers() {\n ThrowableHandlers_instance = this;\n this.instance = new ThrowableHandler();\n }\n ThrowableHandlers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ThrowableHandlers',\n interfaces: []\n };\n var ThrowableHandlers_instance = null;\n function ThrowableHandlers_getInstance() {\n if (ThrowableHandlers_instance === null) {\n new ThrowableHandlers();\n }return ThrowableHandlers_instance;\n }\n var EARTH_RADIUS;\n var MIN_LONGITUDE;\n var MAX_LONGITUDE;\n var FULL_LONGITUDE;\n var MIN_LATITUDE;\n var MAX_LATITUDE;\n var FULL_LATITUDE;\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function get_start($receiver) {\n return $receiver.first;\n }\n function get_end($receiver) {\n return $receiver.second;\n }\n function GeoBoundingBoxCalculator(myMapRect, myLoopX, myLoopY) {\n GeoBoundingBoxCalculator$Companion_getInstance();\n this.myMapRect_0 = myMapRect;\n this.myLoopX_0 = myLoopX;\n this.myLoopY_0 = myLoopY;\n }\n GeoBoundingBoxCalculator.prototype.calculateBoundingBox_qpfwx8$ = function (xSegments, ySegments) {\n var xRange_0 = this.calculateBoundingRange_0(xSegments, xRange(this.myMapRect_0), this.myLoopX_0);\n var yRange_0 = this.calculateBoundingRange_0(ySegments, yRange(this.myMapRect_0), this.myLoopY_0);\n return Rect_init(xRange_0.lowerEnd, yRange_0.lowerEnd, GeoBoundingBoxCalculator$Companion_getInstance().length_0(xRange_0), GeoBoundingBoxCalculator$Companion_getInstance().length_0(yRange_0));\n };\n GeoBoundingBoxCalculator.prototype.calculateBoundingRange_0 = function (segments, mapRange, loop) {\n var tmp$;\n if (loop) {\n tmp$ = GeoBoundingBoxCalculator$Companion_getInstance().calculateLoopLimitRange_h7l5yb$(segments, mapRange);\n } else {\n tmp$ = new ClosedRange(ensureNotNull(minOrNull(map(segments, getPropertyCallableRef('start', 1, function ($receiver) {\n return get_start($receiver);\n })))), ensureNotNull(maxOrNull(map(segments, getPropertyCallableRef('end', 1, function ($receiver) {\n return get_end($receiver);\n })))));\n }\n return tmp$;\n };\n function GeoBoundingBoxCalculator$Companion() {\n GeoBoundingBoxCalculator$Companion_instance = this;\n }\n function GeoBoundingBoxCalculator$Companion$calculateLoopLimitRange$lambda(closure$mapRange) {\n return function (it) {\n return LongitudeSegment$Companion_getInstance().splitSegment_6y0v78$(get_start(it), get_end(it), closure$mapRange.lowerEnd, closure$mapRange.upperEnd);\n };\n }\n GeoBoundingBoxCalculator$Companion.prototype.calculateLoopLimitRange_h7l5yb$ = function (segments, mapRange) {\n return this.normalizeCenter_0(this.invertRange_0(this.findMaxGapBetweenRanges_0(flatten(map(segments, GeoBoundingBoxCalculator$Companion$calculateLoopLimitRange$lambda(mapRange))), this.length_0(mapRange)), this.length_0(mapRange)), mapRange);\n };\n GeoBoundingBoxCalculator$Companion.prototype.normalizeCenter_0 = function (range, mapRange) {\n var tmp$;\n if (mapRange.contains_mef7kx$((range.upperEnd + range.lowerEnd) / 2)) {\n tmp$ = range;\n } else {\n tmp$ = new ClosedRange(range.lowerEnd - this.length_0(mapRange), range.upperEnd - this.length_0(mapRange));\n }\n return tmp$;\n };\n GeoBoundingBoxCalculator$Companion.prototype.findMaxGapBetweenRanges_0 = function (ranges, width) {\n var sortedRanges = sortedWith(ranges, new Comparator(compareBy$lambda(getPropertyCallableRef('lowerEnd', 1, function ($receiver) {\n return $receiver.lowerEnd;\n }))));\n var selector = getPropertyCallableRef('upperEnd', 1, function ($receiver) {\n return $receiver.upperEnd;\n });\n var maxByOrNull$result;\n maxByOrNull$break: do {\n var iterator = sortedRanges.iterator();\n if (!iterator.hasNext()) {\n maxByOrNull$result = null;\n break maxByOrNull$break;\n }var maxElem = iterator.next();\n if (!iterator.hasNext()) {\n maxByOrNull$result = maxElem;\n break maxByOrNull$break;\n }var maxValue = selector(maxElem);\n do {\n var e = iterator.next();\n var v = selector(e);\n if (Kotlin.compareTo(maxValue, v) < 0) {\n maxElem = e;\n maxValue = v;\n }}\n while (iterator.hasNext());\n maxByOrNull$result = maxElem;\n }\n while (false);\n var prevUpper = ensureNotNull(maxByOrNull$result).upperEnd;\n var nextLower = first_1(sortedRanges).lowerEnd;\n var a = width + nextLower;\n var b = prevUpper;\n var gapRight = JsMath.max(a, b);\n var maxGapRange = new ClosedRange(prevUpper, gapRight);\n var it = sortedRanges.iterator();\n prevUpper = it.next().upperEnd;\n while (it.hasNext()) {\n var range = it.next();\n nextLower = range.lowerEnd;\n if (nextLower > prevUpper && nextLower - prevUpper > this.length_0(maxGapRange)) {\n maxGapRange = new ClosedRange(prevUpper, nextLower);\n }var a_0 = prevUpper;\n var b_0 = range.upperEnd;\n prevUpper = JsMath.max(a_0, b_0);\n }\n return maxGapRange;\n };\n function GeoBoundingBoxCalculator$Companion$invertRange$safeRange(first, second) {\n return new ClosedRange(JsMath.min(first, second), JsMath.max(first, second));\n }\n GeoBoundingBoxCalculator$Companion.prototype.invertRange_0 = function (range, width) {\n var tmp$;\n var safeRange = GeoBoundingBoxCalculator$Companion$invertRange$safeRange;\n if (this.length_0(range) > width)\n tmp$ = new ClosedRange(range.lowerEnd, range.lowerEnd);\n else if (range.upperEnd > width)\n tmp$ = safeRange(range.upperEnd - width, range.lowerEnd);\n else\n tmp$ = safeRange(range.upperEnd, width + range.lowerEnd);\n return tmp$;\n };\n GeoBoundingBoxCalculator$Companion.prototype.length_0 = function ($receiver) {\n return $receiver.upperEnd - $receiver.lowerEnd;\n };\n GeoBoundingBoxCalculator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeoBoundingBoxCalculator$Companion_instance = null;\n function GeoBoundingBoxCalculator$Companion_getInstance() {\n if (GeoBoundingBoxCalculator$Companion_instance === null) {\n new GeoBoundingBoxCalculator$Companion();\n }return GeoBoundingBoxCalculator$Companion_instance;\n }\n GeoBoundingBoxCalculator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeoBoundingBoxCalculator',\n interfaces: []\n };\n function makeSegments$lambda(closure$start, closure$end) {\n return function (it) {\n return new Pair(closure$start(it), closure$end(it));\n };\n }\n function makeSegments(start, end, size) {\n return map(asSequence(until(0, size)), makeSegments$lambda(start, end));\n }\n function geoRectsBBox$lambda(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).startLongitude();\n };\n }\n function geoRectsBBox$lambda_0(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).endLongitude();\n };\n }\n function geoRectsBBox$lambda_1(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).minLatitude();\n };\n }\n function geoRectsBBox$lambda_2(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).maxLatitude();\n };\n }\n function geoRectsBBox($receiver, rectangles) {\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(geoRectsBBox$lambda(rectangles), geoRectsBBox$lambda_0(rectangles), rectangles.size), makeSegments(geoRectsBBox$lambda_1(rectangles), geoRectsBBox$lambda_2(rectangles), rectangles.size));\n }\n function pointsBBox$lambda(closure$xyCoords) {\n return function (index) {\n return closure$xyCoords.get_za3lpa$(2 * index | 0);\n };\n }\n function pointsBBox$lambda_0(closure$xyCoords) {\n return function (index) {\n return closure$xyCoords.get_za3lpa$((2 * index | 0) + 1 | 0);\n };\n }\n function pointsBBox($receiver, xyCoords) {\n if (!(xyCoords.size % 2 === 0)) {\n var message = 'Longitude-Latitude list is not even-numbered.';\n throw IllegalArgumentException_init(message.toString());\n }var x = pointsBBox$lambda(xyCoords);\n var y = pointsBBox$lambda_0(xyCoords);\n var i = xyCoords.size / 2 | 0;\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(x, x, i), makeSegments(y, y, i));\n }\n function union$lambda(closure$rectangles) {\n return function (it) {\n return get_left(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_0(closure$rectangles) {\n return function (it) {\n return get_right(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_1(closure$rectangles) {\n return function (it) {\n return get_top(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_2(closure$rectangles) {\n return function (it) {\n return get_bottom(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union($receiver, rectangles) {\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(union$lambda(rectangles), union$lambda_0(rectangles), rectangles.size), makeSegments(union$lambda_1(rectangles), union$lambda_2(rectangles), rectangles.size));\n }\n function GeoJson() {\n GeoJson_instance = this;\n this.LON_INDEX_0 = 0;\n this.LAT_INDEX_0 = 1;\n }\n GeoJson.prototype.parse_gdwatq$ = function (geoJson, handler) {\n var geoObj = FluentObject_init(JsonSupport_getInstance().parseJson_61zpoe$(geoJson));\n var $receiver = new SimpleFeature$Consumer();\n handler($receiver);\n var geometryConsumer = $receiver;\n (new GeoJson$Parser()).parse_m8ausf$(geoObj, geometryConsumer);\n };\n GeoJson.prototype.parse_4mzk4t$ = function (geoJson, consumer) {\n var geoObj = FluentObject_init(JsonSupport_getInstance().parseJson_61zpoe$(geoJson));\n (new GeoJson$Parser()).parse_m8ausf$(geoObj, consumer);\n };\n function GeoJson$Parser() {\n }\n function GeoJson$Parser$parse$lambda(it) {\n return equals(it.getString_61zpoe$('type'), 'Feature');\n }\n function GeoJson$Parser$parse$lambda_0(it) {\n return it.getObject_61zpoe$('geometry');\n }\n GeoJson$Parser.prototype.parse_m8ausf$ = function (obj, handler) {\n var type = obj.getString_61zpoe$('type');\n switch (type) {\n case 'FeatureCollection':\n if (!obj.contains_61zpoe$('features')) {\n var message = \"GeoJson: Missing 'features' in 'FeatureCollection'\";\n throw IllegalArgumentException_init(message.toString());\n }\n var tmp$;\n tmp$ = map(filter(obj.getArray_61zpoe$('features').fluentObjectStream(), GeoJson$Parser$parse$lambda), GeoJson$Parser$parse$lambda_0).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.parse_m8ausf$(element, handler);\n }\n\n break;\n case 'GeometryCollection':\n if (!obj.contains_61zpoe$('geometries')) {\n var message_0 = \"GeoJson: Missing 'geometries' in 'GeometryCollection'\";\n throw IllegalArgumentException_init(message_0.toString());\n }\n var tmp$_0;\n tmp$_0 = obj.getArray_61zpoe$('geometries').fluentObjectStream().iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n this.parse_m8ausf$(element_0, handler);\n }\n\n break;\n default:if (!obj.contains_61zpoe$('coordinates')) {\n var message_1 = \"GeoJson: Missing 'coordinates' in \" + type;\n throw IllegalArgumentException_init(message_1.toString());\n }\n var coordinates = obj.getArray_61zpoe$('coordinates');\n switch (type) {\n case 'Point':\n var $receiver = this.parsePoint_0(coordinates);\n getCallableRef('onPoint', function ($receiver, p1) {\n return $receiver.onPoint_adb7pk$(p1), Unit;\n }.bind(null, handler))($receiver);\n break;\n case 'LineString':\n var $receiver_0 = this.parseLineString_0(coordinates);\n getCallableRef('onLineString', function ($receiver, p1) {\n return $receiver.onLineString_1u6eph$(p1), Unit;\n }.bind(null, handler))($receiver_0);\n break;\n case 'Polygon':\n var $receiver_1 = this.parsePolygon_0(coordinates);\n getCallableRef('onPolygon', function ($receiver, p1) {\n return $receiver.onPolygon_z3kb82$(p1), Unit;\n }.bind(null, handler))($receiver_1);\n break;\n case 'MultiPoint':\n var $receiver_2 = this.parseMultiPoint_0(coordinates);\n getCallableRef('onMultiPoint', function ($receiver, p1) {\n return $receiver.onMultiPoint_oeq1z7$(p1), Unit;\n }.bind(null, handler))($receiver_2);\n break;\n case 'MultiLineString':\n var $receiver_3 = this.parseMultiLineString_0(coordinates);\n getCallableRef('onMultiLineString', function ($receiver, p1) {\n return $receiver.onMultiLineString_6n275e$(p1), Unit;\n }.bind(null, handler))($receiver_3);\n break;\n case 'MultiPolygon':\n var $receiver_4 = this.parseMultiPolygon_0(coordinates);\n getCallableRef('onMultiPolygon', function ($receiver, p1) {\n return $receiver.onMultiPolygon_a0zxnd$(p1), Unit;\n }.bind(null, handler))($receiver_4);\n break;\n default:throw IllegalStateException_init(('Not support GeoJson type: ' + type).toString());\n }\n\n break;\n }\n };\n GeoJson$Parser.prototype.parsePoint_0 = function (jsonPoint) {\n return explicitVec(jsonPoint.getDouble_za3lpa$(0), jsonPoint.getDouble_za3lpa$(1));\n };\n GeoJson$Parser.prototype.parseLineString_0 = function (jsonLineString) {\n return new LineString(this.mapArray_0(jsonLineString, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseRing_0 = function (jsonRing) {\n return new Ring(this.mapArray_0(jsonRing, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiPoint_0 = function (jsonMultiPoint) {\n return new MultiPoint(this.mapArray_0(jsonMultiPoint, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parsePolygon_0 = function (jsonPolygon) {\n return new Polygon(this.mapArray_0(jsonPolygon, getCallableRef('parseRing', function ($receiver, p1) {\n return $receiver.parseRing_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiLineString_0 = function (jsonLineStrings) {\n return new MultiLineString(this.mapArray_0(jsonLineStrings, getCallableRef('parseLineString', function ($receiver, p1) {\n return $receiver.parseLineString_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiPolygon_0 = function (jsonMultiPolygon) {\n return new MultiPolygon(this.mapArray_0(jsonMultiPolygon, getCallableRef('parsePolygon', function ($receiver, p1) {\n return $receiver.parsePolygon_0(p1);\n }.bind(null, this))));\n };\n function GeoJson$Parser$mapArray$lambda(closure$f) {\n return function (it) {\n var tmp$;\n return closure$f(FluentArray_init_0(Kotlin.isType(tmp$ = it, List) ? tmp$ : throwCCE()));\n };\n }\n GeoJson$Parser.prototype.mapArray_0 = function ($receiver, f) {\n return toList_1(map($receiver.stream(), GeoJson$Parser$mapArray$lambda(f)));\n };\n GeoJson$Parser.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Parser',\n interfaces: []\n };\n GeoJson.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeoJson',\n interfaces: []\n };\n var GeoJson_instance = null;\n function GeoJson_getInstance() {\n if (GeoJson_instance === null) {\n new GeoJson();\n }return GeoJson_instance;\n }\n function GeoRectangle(startLongitude, minLatitude, endLongitude, maxLatitude) {\n this.myLongitudeSegment_0 = null;\n this.myLatitudeRange_0 = null;\n if (!(minLatitude <= maxLatitude)) {\n var message = 'Invalid latitude range: [' + minLatitude + '..' + maxLatitude + ']';\n throw IllegalArgumentException_init(message.toString());\n }this.myLongitudeSegment_0 = new LongitudeSegment(startLongitude, endLongitude);\n this.myLatitudeRange_0 = new ClosedRange(minLatitude, maxLatitude);\n }\n Object.defineProperty(GeoRectangle.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myLongitudeSegment_0.isEmpty && this.latitudeRangeIsEmpty_0(this.myLatitudeRange_0);\n }\n });\n GeoRectangle.prototype.latitudeRangeIsEmpty_0 = function (range) {\n return range.upperEnd === range.lowerEnd;\n };\n GeoRectangle.prototype.startLongitude = function () {\n return this.myLongitudeSegment_0.start();\n };\n GeoRectangle.prototype.endLongitude = function () {\n return this.myLongitudeSegment_0.end();\n };\n GeoRectangle.prototype.minLatitude = function () {\n return this.myLatitudeRange_0.lowerEnd;\n };\n GeoRectangle.prototype.maxLatitude = function () {\n return this.myLatitudeRange_0.upperEnd;\n };\n GeoRectangle.prototype.encloses_emtjl$ = function (rect) {\n return this.myLongitudeSegment_0.encloses_moa7dh$(rect.myLongitudeSegment_0) && this.myLatitudeRange_0.encloses_d226ot$(rect.myLatitudeRange_0);\n };\n GeoRectangle.prototype.splitByAntiMeridian = function () {\n var tmp$;\n var rects = ArrayList_init();\n var longitudeRanges = this.myLongitudeSegment_0.splitByAntiMeridian();\n tmp$ = longitudeRanges.iterator();\n while (tmp$.hasNext()) {\n var longitudeRange = tmp$.next();\n rects.add_11rb$(newSpanRectangle(new Vec(longitudeRange.lowerEnd, this.myLatitudeRange_0.lowerEnd), new Vec(longitudeRange.upperEnd, this.myLatitudeRange_0.upperEnd)));\n }\n return rects;\n };\n GeoRectangle.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, GeoRectangle) ? tmp$_0 : throwCCE();\n return ((tmp$_1 = this.myLongitudeSegment_0) != null ? tmp$_1.equals(ensureNotNull(that).myLongitudeSegment_0) : null) && ((tmp$_2 = this.myLatitudeRange_0) != null ? tmp$_2.equals(that.myLatitudeRange_0) : null);\n };\n GeoRectangle.prototype.hashCode = function () {\n return hashCode(listOf([this.myLongitudeSegment_0, this.myLatitudeRange_0]));\n };\n GeoRectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeoRectangle',\n interfaces: []\n };\n function LonLat() {\n }\n LonLat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LonLat',\n interfaces: []\n };\n var EARTH_RECT;\n function limitLon(lon) {\n var tmp$ = MIN_LONGITUDE;\n var b = MAX_LONGITUDE;\n var b_0 = JsMath.min(lon, b);\n return JsMath.max(tmp$, b_0);\n }\n function limitLat(lat) {\n var tmp$ = MIN_LATITUDE;\n var b = MAX_LATITUDE;\n var b_0 = JsMath.min(lat, b);\n return JsMath.max(tmp$, b_0);\n }\n function normalizeLon(lon) {\n var result = lon - numberToInt(lon / FULL_LONGITUDE) * FULL_LONGITUDE;\n if (result > MAX_LONGITUDE) {\n result -= FULL_LONGITUDE;\n }if (result < -MAX_LONGITUDE) {\n result += FULL_LONGITUDE;\n }return result;\n }\n var BBOX_CALCULATOR;\n function convertToGeoRectangle(rect) {\n var left;\n var right;\n if (get_width(rect) < get_width(EARTH_RECT)) {\n left = normalizeLon(get_left(rect));\n right = normalizeLon(get_right(rect));\n } else {\n left = get_left(EARTH_RECT);\n right = get_right(EARTH_RECT);\n }\n return new GeoRectangle(left, limitLat(get_top(rect)), right, limitLat(get_bottom(rect)));\n }\n function calculateQuadKeys(rect, zoom) {\n var flippedRect = Rect_init(get_left(rect), -get_bottom(rect), get_width(rect), get_height(rect));\n return calculateQuadKeys_0(EARTH_RECT, flippedRect, zoom, getCallableRef('QuadKey', function (p1) {\n return new QuadKey(p1);\n }));\n }\n function LongitudeSegment(start, end) {\n LongitudeSegment$Companion_getInstance();\n this.myStart_0 = limitLon(start);\n this.myEnd_0 = limitLon(end);\n }\n Object.defineProperty(LongitudeSegment.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myEnd_0 === this.myStart_0;\n }\n });\n LongitudeSegment.prototype.start = function () {\n return this.myStart_0;\n };\n LongitudeSegment.prototype.end = function () {\n return this.myEnd_0;\n };\n LongitudeSegment.prototype.length = function () {\n return this.myEnd_0 - this.myStart_0 + (this.myEnd_0 < this.myStart_0 ? FULL_LONGITUDE : 0.0);\n };\n LongitudeSegment.prototype.encloses_moa7dh$ = function (longitudeSegment) {\n var tmp$;\n var externalRanges = this.splitByAntiMeridian();\n var internalRanges = longitudeSegment.splitByAntiMeridian();\n tmp$ = internalRanges.iterator();\n while (tmp$.hasNext()) {\n var internalRange = tmp$.next();\n if (!LongitudeSegment$Companion_getInstance().disjointRangesEncloseRange_0(externalRanges, internalRange)) {\n return false;\n }}\n return true;\n };\n LongitudeSegment.prototype.invert = function () {\n return new LongitudeSegment(this.myEnd_0, this.myStart_0);\n };\n LongitudeSegment.prototype.splitByAntiMeridian = function () {\n return LongitudeSegment$Companion_getInstance().splitSegment_6y0v78$(this.myStart_0, this.myEnd_0, MIN_LONGITUDE, MAX_LONGITUDE);\n };\n LongitudeSegment.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = Kotlin.isType(tmp$_0 = other, LongitudeSegment) ? tmp$_0 : throwCCE();\n return equals(that.myStart_0, this.myStart_0) && equals(that.myEnd_0, this.myEnd_0);\n };\n LongitudeSegment.prototype.hashCode = function () {\n return hashCode(listOf([this.myStart_0, this.myEnd_0]));\n };\n function LongitudeSegment$Companion() {\n LongitudeSegment$Companion_instance = this;\n }\n LongitudeSegment$Companion.prototype.splitSegment_6y0v78$ = function (start, end, min, max) {\n var tmp$;\n if (start <= end) {\n tmp$ = listOf_0(new ClosedRange(start, end));\n } else {\n tmp$ = listOf([new ClosedRange(start, max), new ClosedRange(min, end)]);\n }\n return tmp$;\n };\n LongitudeSegment$Companion.prototype.disjointRangesEncloseRange_0 = function (ranges, internalRange) {\n var tmp$;\n tmp$ = ranges.iterator();\n while (tmp$.hasNext()) {\n var range = tmp$.next();\n if (range.encloses_d226ot$(internalRange)) {\n return true;\n }}\n return false;\n };\n LongitudeSegment$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LongitudeSegment$Companion_instance = null;\n function LongitudeSegment$Companion_getInstance() {\n if (LongitudeSegment$Companion_instance === null) {\n new LongitudeSegment$Companion();\n }return LongitudeSegment$Companion_instance;\n }\n LongitudeSegment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LongitudeSegment',\n interfaces: []\n };\n function MercatorUtils() {\n MercatorUtils_instance = this;\n this.MAX_LONGITUDE_0 = 180.0;\n this.MAX_LATITUDE_0 = 85.0511287798;\n this.VALID_LONGITUDE_RANGE = new ClosedRange(-this.MAX_LONGITUDE_0, this.MAX_LONGITUDE_0);\n this.VALID_LATITUDE_RANGE = new ClosedRange(-this.MAX_LATITUDE_0, this.MAX_LATITUDE_0);\n }\n MercatorUtils.prototype.getMercatorX_14dthe$ = function (lon) {\n return toRadians(lon) * EARTH_RADIUS;\n };\n MercatorUtils.prototype.getMercatorY_14dthe$ = function (lat) {\n var lat_0 = this.normalizeLat_0(lat);\n var x = math.PI / 4 + toRadians(lat_0) / 2;\n var x_0 = JsMath.tan(x);\n return JsMath.log(x_0) * EARTH_RADIUS;\n };\n MercatorUtils.prototype.getLongitude_14dthe$ = function (x) {\n return toDegrees(x / EARTH_RADIUS);\n };\n MercatorUtils.prototype.getLatitude_14dthe$ = function (y) {\n var x = y / EARTH_RADIUS;\n var x_0 = JsMath.exp(x);\n return this.normalizeLat_0(toDegrees((JsMath.atan(x_0) - math.PI / 4) * 2));\n };\n MercatorUtils.prototype.checkLon_14dthe$ = function (lon) {\n return this.VALID_LONGITUDE_RANGE.contains_mef7kx$(lon);\n };\n MercatorUtils.prototype.checkLat_14dthe$ = function (lat) {\n return this.VALID_LATITUDE_RANGE.contains_mef7kx$(lat);\n };\n MercatorUtils.prototype.normalizeLat_0 = function (lat) {\n var tmp$ = -this.MAX_LATITUDE_0;\n var b = this.MAX_LATITUDE_0;\n var b_0 = JsMath.min(lat, b);\n return JsMath.max(tmp$, b_0);\n };\n MercatorUtils.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MercatorUtils',\n interfaces: []\n };\n var MercatorUtils_instance = null;\n function MercatorUtils_getInstance() {\n if (MercatorUtils_instance === null) {\n new MercatorUtils();\n }return MercatorUtils_instance;\n }\n function QuadKey(key) {\n this.key = key;\n this.length = this.key.length;\n }\n QuadKey.prototype.plus_vnxxg4$ = function (other) {\n return new QuadKey(this.key + other.key);\n };\n QuadKey.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuadKey',\n interfaces: []\n };\n QuadKey.prototype.component1 = function () {\n return this.key;\n };\n QuadKey.prototype.copy_61zpoe$ = function (key) {\n return new QuadKey(key === void 0 ? this.key : key);\n };\n QuadKey.prototype.toString = function () {\n return 'QuadKey(key=' + Kotlin.toString(this.key) + ')';\n };\n QuadKey.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.key) | 0;\n return result;\n };\n QuadKey.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && Kotlin.equals(this.key, other.key))));\n };\n function computeRect$lambda(closure$flippedY) {\n return function (it) {\n return closure$flippedY;\n };\n }\n function computeRect($receiver) {\n var origin = computeOrigin($receiver, EARTH_RECT);\n var dimension = div_0(EARTH_RECT.dimension, calulateQuadsCount($receiver.length));\n var flippedY = minus_0(get_scalarBottom(EARTH_RECT), minus_0(plus_5(get_scalarY(origin), get_scalarY(dimension)), get_scalarTop(EARTH_RECT)));\n return new Rect(transform(origin, void 0, computeRect$lambda(flippedY)), dimension);\n }\n function computeRect_0($receiver, rect) {\n return projectRect($receiver, rect);\n }\n function projectRect($receiver, rect) {\n var origin = projectOrigin($receiver, rect);\n var dimension = div_0(rect.dimension, calulateQuadsCount($receiver.length));\n return new Rect(origin, dimension);\n }\n function zoom($receiver) {\n return $receiver.length;\n }\n function computeOrigin($receiver, mapRect) {\n return projectOrigin($receiver, mapRect);\n }\n function projectOrigin($receiver, mapRect) {\n var tmp$;\n var left = get_scalarLeft(mapRect);\n var top = get_scalarTop(mapRect);\n var width = get_scalarWidth(mapRect);\n var height = get_scalarHeight(mapRect);\n tmp$ = iterator($receiver.key);\n while (tmp$.hasNext()) {\n var quadrant = unboxChar(tmp$.next());\n width = div_2(width, 2.0);\n height = div_2(height, 2.0);\n if (quadrant === 49 || quadrant === 51) {\n left = plus_5(left, width);\n }if (quadrant === 50 || quadrant === 51) {\n top = plus_5(top, height);\n }}\n return newVec(left, top);\n }\n function calulateQuadsCount(zoom) {\n return numberToInt(ipow(2, zoom));\n }\n function calculateQuadKeys$calcQuadNum(value, range, tileCount) {\n var position = (value - range.lowerEnd) / (range.upperEnd - range.lowerEnd);\n var a = position * tileCount;\n var b = tileCount - 1 | 0;\n var b_0 = JsMath.min(a, b);\n return numberToInt(JsMath.max(0.0, b_0));\n }\n function calculateQuadKeys_0(mapRect, viewRect, zoom, quadKeyFactory) {\n var quadKeys = HashSet_init_0();\n var tileCount = calulateQuadsCount(zoom);\n var calcQuadNum = calculateQuadKeys$calcQuadNum;\n var xmin = calcQuadNum(get_left(viewRect), xRange(mapRect), tileCount);\n var xmax = calcQuadNum(get_right(viewRect), xRange(mapRect), tileCount);\n var ymin = calcQuadNum(get_top(viewRect), yRange(mapRect), tileCount);\n var ymax = calcQuadNum(get_bottom(viewRect), yRange(mapRect), tileCount);\n for (var x = xmin; x <= xmax; x++) {\n for (var y = ymin; y <= ymax; y++) {\n var $receiver = quadKeyFactory(xyToKey(x, y, zoom));\n getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_11rb$(p1);\n }.bind(null, quadKeys))($receiver);\n }\n }\n return quadKeys;\n }\n function xyToKey(x, y, zoom) {\n var key = '';\n for (var i = zoom; i >= 1; i--) {\n var digit = 48;\n var mask = 1 << i - 1;\n if ((x & mask) !== 0) {\n digit = Kotlin.charInc(digit);\n }if ((y & mask) !== 0) {\n digit = toChar(digit + 2);\n }key += String.fromCharCode(digit);\n }\n return key;\n }\n function SimpleFeature() {\n SimpleFeature_instance = this;\n }\n function SimpleFeature$GeometryConsumer() {\n }\n SimpleFeature$GeometryConsumer.prototype.onPoint_adb7pk$ = function (point) {\n throw IllegalStateException_init(\"Point isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onLineString_1u6eph$ = function (lineString) {\n throw IllegalStateException_init(\"LineString isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onPolygon_z3kb82$ = function (polygon) {\n throw IllegalStateException_init(\"Polygon isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiPoint_oeq1z7$ = function (multiPoint) {\n throw IllegalStateException_init(\"MultiPoint isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiLineString_6n275e$ = function (multiLineString) {\n throw IllegalStateException_init(\"MultiLineString isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiPolygon_a0zxnd$ = function (multipolygon) {\n throw IllegalStateException_init(\"MultiPolygon isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeometryConsumer',\n interfaces: []\n };\n function SimpleFeature$Consumer(onPoint, onLineString, onPolygon, onMultiPoint, onMultiLineString, onMultiPolygon) {\n if (onPoint === void 0)\n onPoint = SimpleFeature$SimpleFeature$Consumer_init$lambda;\n if (onLineString === void 0)\n onLineString = SimpleFeature$SimpleFeature$Consumer_init$lambda_0;\n if (onPolygon === void 0)\n onPolygon = SimpleFeature$SimpleFeature$Consumer_init$lambda_1;\n if (onMultiPoint === void 0)\n onMultiPoint = SimpleFeature$SimpleFeature$Consumer_init$lambda_2;\n if (onMultiLineString === void 0)\n onMultiLineString = SimpleFeature$SimpleFeature$Consumer_init$lambda_3;\n if (onMultiPolygon === void 0)\n onMultiPolygon = SimpleFeature$SimpleFeature$Consumer_init$lambda_4;\n this.onPoint = onPoint;\n this.onLineString = onLineString;\n this.onPolygon = onPolygon;\n this.onMultiPoint = onMultiPoint;\n this.onMultiLineString = onMultiLineString;\n this.onMultiPolygon = onMultiPolygon;\n }\n SimpleFeature$Consumer.prototype.onPoint_adb7pk$ = function (point) {\n this.onPoint(point);\n };\n SimpleFeature$Consumer.prototype.onLineString_1u6eph$ = function (lineString) {\n this.onLineString(lineString);\n };\n SimpleFeature$Consumer.prototype.onPolygon_z3kb82$ = function (polygon) {\n this.onPolygon(polygon);\n };\n SimpleFeature$Consumer.prototype.onMultiPoint_oeq1z7$ = function (multiPoint) {\n this.onMultiPoint(multiPoint);\n };\n SimpleFeature$Consumer.prototype.onMultiLineString_6n275e$ = function (multiLineString) {\n this.onMultiLineString(multiLineString);\n };\n SimpleFeature$Consumer.prototype.onMultiPolygon_a0zxnd$ = function (multipolygon) {\n this.onMultiPolygon(multipolygon);\n };\n function SimpleFeature$SimpleFeature$Consumer_init$lambda(it) {\n throw IllegalStateException_init(\"Point isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_0(it) {\n throw IllegalStateException_init(\"LineString isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_1(it) {\n throw IllegalStateException_init(\"Polygon isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_2(it) {\n throw IllegalStateException_init(\"MultiPoint isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_3(it) {\n throw IllegalStateException_init(\"MultiLineString isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_4(it) {\n throw IllegalStateException_init(\"MultiPolygon isn't supported\".toString());\n }\n SimpleFeature$Consumer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Consumer',\n interfaces: [SimpleFeature$GeometryConsumer]\n };\n function SimpleFeature$GeometryType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function SimpleFeature$GeometryType_initFields() {\n SimpleFeature$GeometryType_initFields = function () {\n };\n SimpleFeature$GeometryType$POINT_instance = new SimpleFeature$GeometryType('POINT', 0);\n SimpleFeature$GeometryType$LINE_STRING_instance = new SimpleFeature$GeometryType('LINE_STRING', 1);\n SimpleFeature$GeometryType$POLYGON_instance = new SimpleFeature$GeometryType('POLYGON', 2);\n SimpleFeature$GeometryType$MULTI_POINT_instance = new SimpleFeature$GeometryType('MULTI_POINT', 3);\n SimpleFeature$GeometryType$MULTI_LINE_STRING_instance = new SimpleFeature$GeometryType('MULTI_LINE_STRING', 4);\n SimpleFeature$GeometryType$MULTI_POLYGON_instance = new SimpleFeature$GeometryType('MULTI_POLYGON', 5);\n SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance = new SimpleFeature$GeometryType('GEOMETRY_COLLECTION', 6);\n }\n var SimpleFeature$GeometryType$POINT_instance;\n function SimpleFeature$GeometryType$POINT_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$POINT_instance;\n }\n var SimpleFeature$GeometryType$LINE_STRING_instance;\n function SimpleFeature$GeometryType$LINE_STRING_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$LINE_STRING_instance;\n }\n var SimpleFeature$GeometryType$POLYGON_instance;\n function SimpleFeature$GeometryType$POLYGON_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$POLYGON_instance;\n }\n var SimpleFeature$GeometryType$MULTI_POINT_instance;\n function SimpleFeature$GeometryType$MULTI_POINT_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_POINT_instance;\n }\n var SimpleFeature$GeometryType$MULTI_LINE_STRING_instance;\n function SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_LINE_STRING_instance;\n }\n var SimpleFeature$GeometryType$MULTI_POLYGON_instance;\n function SimpleFeature$GeometryType$MULTI_POLYGON_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_POLYGON_instance;\n }\n var SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance;\n function SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance;\n }\n SimpleFeature$GeometryType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeometryType',\n interfaces: [Enum]\n };\n function SimpleFeature$GeometryType$values() {\n return [SimpleFeature$GeometryType$POINT_getInstance(), SimpleFeature$GeometryType$LINE_STRING_getInstance(), SimpleFeature$GeometryType$POLYGON_getInstance(), SimpleFeature$GeometryType$MULTI_POINT_getInstance(), SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance(), SimpleFeature$GeometryType$MULTI_POLYGON_getInstance(), SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance()];\n }\n SimpleFeature$GeometryType.values = SimpleFeature$GeometryType$values;\n function SimpleFeature$GeometryType$valueOf(name) {\n switch (name) {\n case 'POINT':\n return SimpleFeature$GeometryType$POINT_getInstance();\n case 'LINE_STRING':\n return SimpleFeature$GeometryType$LINE_STRING_getInstance();\n case 'POLYGON':\n return SimpleFeature$GeometryType$POLYGON_getInstance();\n case 'MULTI_POINT':\n return SimpleFeature$GeometryType$MULTI_POINT_getInstance();\n case 'MULTI_LINE_STRING':\n return SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance();\n case 'MULTI_POLYGON':\n return SimpleFeature$GeometryType$MULTI_POLYGON_getInstance();\n case 'GEOMETRY_COLLECTION':\n return SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.spatial.SimpleFeature.GeometryType.' + name);\n }\n }\n SimpleFeature$GeometryType.valueOf_61zpoe$ = SimpleFeature$GeometryType$valueOf;\n SimpleFeature.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SimpleFeature',\n interfaces: []\n };\n var SimpleFeature_instance = null;\n function SimpleFeature_getInstance() {\n if (SimpleFeature_instance === null) {\n new SimpleFeature();\n }return SimpleFeature_instance;\n }\n function StringFormat(pattern, formatType) {\n StringFormat$Companion_getInstance();\n this.pattern_0 = pattern;\n this.formatType = formatType;\n this.myNumberFormatters_0 = null;\n var tmp$;\n var initNumberFormat = StringFormat_init$initNumberFormat;\n switch (this.formatType.name) {\n case 'NUMBER_FORMAT':\n tmp$ = listOf_0(initNumberFormat(this.pattern_0));\n break;\n case 'STRING_FORMAT':\n tmp$ = toList_1(map(map(StringFormat$Companion_getInstance().BRACES_REGEX_0.findAll_905azu$(this.pattern_0), StringFormat_init$lambda), StringFormat_init$lambda_0(initNumberFormat)));\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n this.myNumberFormatters_0 = tmp$;\n this.argsNumber = this.myNumberFormatters_0.size;\n }\n function StringFormat$FormatType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function StringFormat$FormatType_initFields() {\n StringFormat$FormatType_initFields = function () {\n };\n StringFormat$FormatType$NUMBER_FORMAT_instance = new StringFormat$FormatType('NUMBER_FORMAT', 0);\n StringFormat$FormatType$STRING_FORMAT_instance = new StringFormat$FormatType('STRING_FORMAT', 1);\n }\n var StringFormat$FormatType$NUMBER_FORMAT_instance;\n function StringFormat$FormatType$NUMBER_FORMAT_getInstance() {\n StringFormat$FormatType_initFields();\n return StringFormat$FormatType$NUMBER_FORMAT_instance;\n }\n var StringFormat$FormatType$STRING_FORMAT_instance;\n function StringFormat$FormatType$STRING_FORMAT_getInstance() {\n StringFormat$FormatType_initFields();\n return StringFormat$FormatType$STRING_FORMAT_instance;\n }\n StringFormat$FormatType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FormatType',\n interfaces: [Enum]\n };\n function StringFormat$FormatType$values() {\n return [StringFormat$FormatType$NUMBER_FORMAT_getInstance(), StringFormat$FormatType$STRING_FORMAT_getInstance()];\n }\n StringFormat$FormatType.values = StringFormat$FormatType$values;\n function StringFormat$FormatType$valueOf(name) {\n switch (name) {\n case 'NUMBER_FORMAT':\n return StringFormat$FormatType$NUMBER_FORMAT_getInstance();\n case 'STRING_FORMAT':\n return StringFormat$FormatType$STRING_FORMAT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.stringFormat.StringFormat.FormatType.' + name);\n }\n }\n StringFormat$FormatType.valueOf_61zpoe$ = StringFormat$FormatType$valueOf;\n StringFormat.prototype.format_za3rmp$ = function (value) {\n return this.format_pqjuzw$(listOf_0(value));\n };\n StringFormat.prototype.format_pqjuzw$ = function (values) {\n var tmp$;\n if (this.argsNumber !== values.size) {\n throw IllegalStateException_init((\"Can't format values \" + values + ' with pattern ' + '\"' + this.pattern_0 + '\"' + '). Wrong number of arguments: expected ' + this.argsNumber + ' instead of ' + values.size).toString());\n }loop_label: switch (this.formatType.name) {\n case 'NUMBER_FORMAT':\n if (!(this.myNumberFormatters_0.size === 1)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }\n tmp$ = this.formatValue_0(single(values), single(this.myNumberFormatters_0));\n break loop_label;\n case 'STRING_FORMAT':\n var index = {v: 0};\n var $this = StringFormat$Companion_getInstance().BRACES_REGEX_0;\n var input = this.pattern_0;\n var replace_20wsma$result;\n replace_20wsma$break: do {\n var match = $this.find_905azu$(input);\n if (match == null) {\n replace_20wsma$result = input.toString();\n break replace_20wsma$break;\n }var lastStart = 0;\n var length = input.length;\n var sb = StringBuilder_init_0(length);\n do {\n var foundMatch = ensureNotNull(match);\n sb.append_ezbsdh$(input, lastStart, foundMatch.range.start);\n var tmp$_0 = sb.append_gw00v9$;\n var tmp$_1;\n var originalValue = values.get_za3lpa$(index.v);\n var formatter = this.myNumberFormatters_0.get_za3lpa$((tmp$_1 = index.v, index.v = tmp$_1 + 1 | 0, tmp$_1));\n tmp$_0.call(sb, this.formatValue_0(originalValue, formatter));\n lastStart = foundMatch.range.endInclusive + 1 | 0;\n match = foundMatch.next();\n }\n while (lastStart < length && match != null);\n if (lastStart < length) {\n sb.append_ezbsdh$(input, lastStart, length);\n }replace_20wsma$result = sb.toString();\n }\n while (false);\n tmp$ = replace(replace(replace_20wsma$result, '{{', '{'), '}}', '}');\n break loop_label;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break loop_label;\n }\n return tmp$;\n };\n StringFormat.prototype.formatValue_0 = function (value, numberFormatter) {\n var tmp$, tmp$_0, tmp$_1;\n if (numberFormatter == null)\n tmp$_1 = value.toString();\n else if (Kotlin.isNumber(value))\n tmp$_1 = numberFormatter.apply_3p81yu$(value);\n else if (typeof value === 'string') {\n tmp$_1 = (tmp$_0 = (tmp$ = toDoubleOrNull(value)) != null ? getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_3p81yu$(p1);\n }.bind(null, numberFormatter))(tmp$) : null) != null ? tmp$_0 : value;\n } else {\n throw IllegalStateException_init(('Failed to format value with type ' + toString(Kotlin.getKClassFromExpression(value).simpleName) + '. Supported types are Number and String.').toString());\n }\n return tmp$_1;\n };\n function StringFormat$Companion() {\n StringFormat$Companion_instance = this;\n this.BRACES_REGEX_0 = Regex_init('(?![^{]|\\\\{\\\\{)(\\\\{([^{}]*)\\\\})(?=[^}]|\\\\}\\\\}|$)');\n this.TEXT_IN_BRACES = 2;\n }\n StringFormat$Companion.prototype.valueInLinePattern = function () {\n return '{}';\n };\n StringFormat$Companion.prototype.forOneArg_86f9bg$ = function (pattern, type, formatFor) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n return this.create_w8bwfu$(pattern, type, formatFor, 1);\n };\n StringFormat$Companion.prototype.forNArgs_8vq31k$ = function (pattern, type, argCount, formatFor) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n return this.create_w8bwfu$(pattern, type, formatFor, argCount);\n };\n StringFormat$Companion.prototype.create_w8bwfu$ = function (pattern, type, formatFor, expectedArgs) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n if (expectedArgs === void 0)\n expectedArgs = -1;\n var tmp$;\n if (type != null)\n tmp$ = type;\n else if (NumberFormat$Companion_getInstance().isValidPattern_61zpoe$(pattern))\n tmp$ = StringFormat$FormatType$NUMBER_FORMAT_getInstance();\n else\n tmp$ = StringFormat$FormatType$STRING_FORMAT_getInstance();\n var formatType = tmp$;\n var $receiver = new StringFormat(pattern, formatType);\n if (expectedArgs > 0) {\n if (!($receiver.argsNumber === expectedArgs)) {\n var tmp$_0;\n var formatFor_0 = (tmp$_0 = formatFor != null ? 'to format ' + \"'\" + toString(formatFor) + \"'\" : null) != null ? tmp$_0 : '';\n var message = 'Wrong number of arguments in pattern ' + \"'\" + pattern + \"'\" + ' ' + formatFor_0 + '. ' + ('Expected ' + expectedArgs + ' ' + (expectedArgs > 1 ? 'arguments' : 'argument') + ' ') + ('instead of ' + $receiver.argsNumber);\n throw IllegalArgumentException_init(message.toString());\n }}return $receiver;\n };\n StringFormat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StringFormat$Companion_instance = null;\n function StringFormat$Companion_getInstance() {\n if (StringFormat$Companion_instance === null) {\n new StringFormat$Companion();\n }return StringFormat$Companion_instance;\n }\n function StringFormat_init$initNumberFormat(pattern) {\n try {\n return NumberFormat_init(pattern);\n } catch (e) {\n if (Kotlin.isType(e, Exception)) {\n throw IllegalStateException_init(('Wrong number pattern: ' + pattern).toString());\n } else\n throw e;\n }\n }\n function StringFormat_init$lambda(it) {\n return it.groupValues.get_za3lpa$(2);\n }\n function StringFormat_init$lambda_0(closure$initNumberFormat) {\n return function (format) {\n if (format.length > 0) {\n return closure$initNumberFormat(format);\n } else {\n return null;\n }\n };\n }\n StringFormat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StringFormat',\n interfaces: []\n };\n function AbstractGeometryList(myGeometry) {\n AbstractList.call(this);\n this.myGeometry_8dt6c9$_0 = myGeometry;\n }\n AbstractGeometryList.prototype.get_za3lpa$ = function (index) {\n return this.myGeometry_8dt6c9$_0.get_za3lpa$(index);\n };\n Object.defineProperty(AbstractGeometryList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myGeometry_8dt6c9$_0.size;\n }\n });\n AbstractGeometryList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractGeometryList',\n interfaces: [AbstractList]\n };\n function isClockwise_0(ring) {\n return isClockwise(ring, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }));\n }\n function createMultiPolygon(points) {\n var tmp$;\n if (points.isEmpty()) {\n return new MultiPolygon(emptyList());\n }var polygons = ArrayList_init();\n var rings = ArrayList_init();\n tmp$ = splitRings(points).iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (!rings.isEmpty() && isClockwise_0(ring)) {\n polygons.add_11rb$(new Polygon(rings));\n rings = ArrayList_init();\n }rings.add_11rb$(new Ring(ring));\n }\n if (!rings.isEmpty()) {\n polygons.add_11rb$(new Polygon(rings));\n }return new MultiPolygon(polygons);\n }\n function boundingBox$lambda(minX, minY, maxX, maxY) {\n return newSpanRectangle(new Vec(minX, minY), new Vec(maxX, maxY));\n }\n function boundingBox($receiver) {\n return DoubleRectangles_getInstance().calculateBoundingBox_h5l7ap$($receiver, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }), boundingBox$lambda);\n }\n function Generic() {\n }\n Generic.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Generic',\n interfaces: []\n };\n function reinterpret($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, Vec) ? tmp$ : throwCCE();\n }\n function reinterpret_0($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiPoint) ? tmp$ : throwCCE();\n }\n function reinterpret_1($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, LineString) ? tmp$ : throwCCE();\n }\n function reinterpret_2($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiLineString) ? tmp$ : throwCCE();\n }\n function reinterpret_3($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, Polygon) ? tmp$ : throwCCE();\n }\n function reinterpret_4($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiPolygon) ? tmp$ : throwCCE();\n }\n function get_bottom($receiver) {\n return $receiver.origin.y + $receiver.dimension.y;\n }\n function get_right($receiver) {\n return $receiver.origin.x + $receiver.dimension.x;\n }\n function get_height($receiver) {\n return $receiver.dimension.y;\n }\n function get_width($receiver) {\n return $receiver.dimension.x;\n }\n function get_top($receiver) {\n return $receiver.origin.y;\n }\n function get_left($receiver) {\n return $receiver.origin.x;\n }\n function get_scalarBottom($receiver) {\n return new Scalar(get_bottom($receiver));\n }\n function get_scalarRight($receiver) {\n return new Scalar(get_right($receiver));\n }\n function get_scalarHeight($receiver) {\n return new Scalar(get_height($receiver));\n }\n function get_scalarWidth($receiver) {\n return new Scalar(get_width($receiver));\n }\n function get_scalarTop($receiver) {\n return new Scalar(get_top($receiver));\n }\n function get_scalarLeft($receiver) {\n return new Scalar(get_left($receiver));\n }\n function get_center($receiver) {\n return plus_4(div_0($receiver.dimension, 2.0), $receiver.origin);\n }\n function get_scalarX($receiver) {\n return new Scalar($receiver.x);\n }\n function get_scalarY($receiver) {\n return new Scalar($receiver.y);\n }\n function plus_4($receiver, other) {\n return new Vec($receiver.x + other.x, $receiver.y + other.y);\n }\n function minus($receiver, other) {\n return new Vec($receiver.x - other.x, $receiver.y - other.y);\n }\n function times($receiver, other) {\n return new Vec($receiver.x * other.x, $receiver.y * other.y);\n }\n function div($receiver, other) {\n return new Vec($receiver.x / other.x, $receiver.y / other.y);\n }\n function times_0($receiver, scale) {\n return new Vec($receiver.x * scale, $receiver.y * scale);\n }\n function div_0($receiver, scale) {\n return new Vec($receiver.x / scale, $receiver.y / scale);\n }\n function unaryMinus($receiver) {\n return new Vec(-$receiver.x, -$receiver.y);\n }\n function transform$lambda(it) {\n return it;\n }\n function transform$lambda_0(it) {\n return it;\n }\n function transform($receiver, newX, newY) {\n if (newX === void 0)\n newX = transform$lambda;\n if (newY === void 0)\n newY = transform$lambda_0;\n return new Vec(newX(get_scalarX($receiver)).value, newY(get_scalarY($receiver)).value);\n }\n function plus_5($receiver, other) {\n return new Scalar($receiver.value + other.value);\n }\n function minus_0($receiver, other) {\n return new Scalar($receiver.value - other.value);\n }\n function times_1($receiver, other) {\n return new Scalar($receiver.value * other.value);\n }\n function div_1($receiver, other) {\n return new Scalar($receiver.value / other.value);\n }\n function div_2($receiver, other) {\n return new Scalar($receiver.value / other);\n }\n function times_2($receiver, other) {\n return new Scalar($receiver.value * other);\n }\n function unaryMinus_0($receiver) {\n return new Scalar(-$receiver.value);\n }\n function compareTo($receiver, i) {\n return Kotlin.compareTo($receiver.value, i);\n }\n function newSpanRectangle(leftTop, rightBottom) {\n return new Rect(leftTop, minus(rightBottom, leftTop));\n }\n function limit($receiver) {\n return boundingBox(asIterable(flatten(asSequence($receiver))));\n }\n function contains_1($receiver, v) {\n return $receiver.origin.x <= v.x && $receiver.origin.x + $receiver.dimension.x >= v.x && $receiver.origin.y <= v.y && $receiver.origin.y + $receiver.dimension.y >= v.y;\n }\n function intersects($receiver, rect) {\n var t1 = $receiver.origin;\n var t2 = plus_4($receiver.origin, $receiver.dimension);\n var r1 = rect.origin;\n var r2 = plus_4(rect.origin, rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n }\n function xRange($receiver) {\n return new ClosedRange($receiver.origin.x, $receiver.origin.x + $receiver.dimension.x);\n }\n function yRange($receiver) {\n return new ClosedRange($receiver.origin.y, $receiver.origin.y + $receiver.dimension.y);\n }\n function limit_0($receiver) {\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(limit(item));\n }\n return destination;\n }\n function GeometryType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeometryType_initFields() {\n GeometryType_initFields = function () {\n };\n GeometryType$MULTI_POINT_instance = new GeometryType('MULTI_POINT', 0);\n GeometryType$MULTI_LINESTRING_instance = new GeometryType('MULTI_LINESTRING', 1);\n GeometryType$MULTI_POLYGON_instance = new GeometryType('MULTI_POLYGON', 2);\n }\n var GeometryType$MULTI_POINT_instance;\n function GeometryType$MULTI_POINT_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_POINT_instance;\n }\n var GeometryType$MULTI_LINESTRING_instance;\n function GeometryType$MULTI_LINESTRING_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_LINESTRING_instance;\n }\n var GeometryType$MULTI_POLYGON_instance;\n function GeometryType$MULTI_POLYGON_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_POLYGON_instance;\n }\n GeometryType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeometryType',\n interfaces: [Enum]\n };\n function GeometryType$values() {\n return [GeometryType$MULTI_POINT_getInstance(), GeometryType$MULTI_LINESTRING_getInstance(), GeometryType$MULTI_POLYGON_getInstance()];\n }\n GeometryType.values = GeometryType$values;\n function GeometryType$valueOf(name) {\n switch (name) {\n case 'MULTI_POINT':\n return GeometryType$MULTI_POINT_getInstance();\n case 'MULTI_LINESTRING':\n return GeometryType$MULTI_LINESTRING_getInstance();\n case 'MULTI_POLYGON':\n return GeometryType$MULTI_POLYGON_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.typedGeometry.GeometryType.' + name);\n }\n }\n GeometryType.valueOf_61zpoe$ = GeometryType$valueOf;\n function Geometry(type, myMultiPoint, myMultiLineString, myMultiPolygon) {\n Geometry$Companion_getInstance();\n this.type = type;\n this.myMultiPoint_0 = myMultiPoint;\n this.myMultiLineString_0 = myMultiLineString;\n this.myMultiPolygon_0 = myMultiPolygon;\n }\n Object.defineProperty(Geometry.prototype, 'multiPoint', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiPoint_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiPoint').toString());\n }\n return tmp$_0;\n }\n });\n Object.defineProperty(Geometry.prototype, 'multiLineString', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiLineString_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiLineString').toString());\n }\n return tmp$_0;\n }\n });\n Object.defineProperty(Geometry.prototype, 'multiPolygon', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiPolygon_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiPolygon').toString());\n }\n return tmp$_0;\n }\n });\n function Geometry$Companion() {\n Geometry$Companion_instance = this;\n }\n Geometry$Companion.prototype.createMultiPoint_xgn53i$ = function (multiPoint) {\n return new Geometry(GeometryType$MULTI_POINT_getInstance(), multiPoint, null, null);\n };\n Geometry$Companion.prototype.createMultiLineString_bc4hlz$ = function (multiLineString) {\n return new Geometry(GeometryType$MULTI_LINESTRING_getInstance(), null, multiLineString, null);\n };\n Geometry$Companion.prototype.createMultiPolygon_8ft4gs$ = function (multiPolygon) {\n return new Geometry(GeometryType$MULTI_POLYGON_getInstance(), null, null, multiPolygon);\n };\n Geometry$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Geometry$Companion_instance = null;\n function Geometry$Companion_getInstance() {\n if (Geometry$Companion_instance === null) {\n new Geometry$Companion();\n }return Geometry$Companion_instance;\n }\n Geometry.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Geometry',\n interfaces: []\n };\n function LineString(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n LineString.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineString',\n interfaces: [AbstractGeometryList]\n };\n function MultiLineString(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n MultiLineString.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiLineString',\n interfaces: [AbstractGeometryList]\n };\n function MultiPoint(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n MultiPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPoint',\n interfaces: [AbstractGeometryList]\n };\n function MultiPolygon(polygons) {\n AbstractGeometryList.call(this, polygons);\n }\n MultiPolygon.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPolygon',\n interfaces: [AbstractGeometryList]\n };\n function Polygon(rings) {\n AbstractGeometryList.call(this, rings);\n }\n Polygon.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Polygon',\n interfaces: [AbstractGeometryList]\n };\n function Rect(origin, dimension) {\n this.origin = origin;\n this.dimension = dimension;\n }\n Rect.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Rect',\n interfaces: []\n };\n function Rect_init(left, top, width, height, $this) {\n $this = $this || Object.create(Rect.prototype);\n Rect.call($this, new Vec(left, top), new Vec(width, height));\n return $this;\n }\n Rect.prototype.component1 = function () {\n return this.origin;\n };\n Rect.prototype.component2 = function () {\n return this.dimension;\n };\n Rect.prototype.copy_rbt1hw$ = function (origin, dimension) {\n return new Rect(origin === void 0 ? this.origin : origin, dimension === void 0 ? this.dimension : dimension);\n };\n Rect.prototype.toString = function () {\n return 'Rect(origin=' + Kotlin.toString(this.origin) + (', dimension=' + Kotlin.toString(this.dimension)) + ')';\n };\n Rect.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.origin) | 0;\n result = result * 31 + Kotlin.hashCode(this.dimension) | 0;\n return result;\n };\n Rect.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.origin, other.origin) && Kotlin.equals(this.dimension, other.dimension)))));\n };\n function Ring(points) {\n AbstractGeometryList.call(this, points);\n }\n Ring.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Ring',\n interfaces: [AbstractGeometryList]\n };\n function Scalar(value) {\n this.value = value;\n }\n Scalar.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Scalar',\n interfaces: []\n };\n Scalar.prototype.component1 = function () {\n return this.value;\n };\n Scalar.prototype.copy_14dthe$ = function (value) {\n return new Scalar(value === void 0 ? this.value : value);\n };\n Scalar.prototype.toString = function () {\n return 'Scalar(value=' + Kotlin.toString(this.value) + ')';\n };\n Scalar.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.value) | 0;\n return result;\n };\n Scalar.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && Kotlin.equals(this.value, other.value))));\n };\n function Vec(x, y) {\n this.x = x;\n this.y = y;\n }\n Vec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Vec',\n interfaces: []\n };\n function Vec_init(x, y, $this) {\n $this = $this || Object.create(Vec.prototype);\n Vec.call($this, x, y);\n return $this;\n }\n Vec.prototype.component1 = function () {\n return this.x;\n };\n Vec.prototype.component2 = function () {\n return this.y;\n };\n Vec.prototype.copy_lu1900$ = function (x, y) {\n return new Vec(x === void 0 ? this.x : x, y === void 0 ? this.y : y);\n };\n Vec.prototype.toString = function () {\n return 'Vec(x=' + Kotlin.toString(this.x) + (', y=' + Kotlin.toString(this.y)) + ')';\n };\n Vec.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.x) | 0;\n result = result * 31 + Kotlin.hashCode(this.y) | 0;\n return result;\n };\n Vec.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.x, other.x) && Kotlin.equals(this.y, other.y)))));\n };\n function explicitVec(x, y) {\n return new Vec(x, y);\n }\n function explicitVec_0(x, y) {\n return new Vec(x, y);\n }\n function newVec(x, y) {\n return new Vec(x.value, y.value);\n }\n function TypedKey() {\n }\n TypedKey.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TypedKey',\n interfaces: []\n };\n function TypedKeyHashMap() {\n this.map = HashMap_init_0();\n }\n TypedKeyHashMap.prototype.get_ex36zt$ = function (key) {\n var tmp$;\n if (this.map.containsKey_11rb$(key)) {\n return (tmp$ = this.map.get_11rb$(key)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }throw new NoSuchElementException_init_0(\"Wasn't found key \" + key);\n };\n TypedKeyHashMap.prototype.set_ev6mlr$ = function (key, value) {\n this.put_ev6mlr$(key, value);\n };\n TypedKeyHashMap.prototype.put_ev6mlr$ = function (key, value) {\n if (value == null) {\n this.map.remove_11rb$(key);\n } else {\n this.map.put_xwzc9p$(key, value);\n }\n };\n TypedKeyHashMap.prototype.contains_ku7evr$ = function (key) {\n return this.containsKey_ex36zt$(key);\n };\n TypedKeyHashMap.prototype.containsKey_ex36zt$ = function (key) {\n return this.map.containsKey_11rb$(key);\n };\n TypedKeyHashMap.prototype.keys_287e2$ = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.map.keys, Set) ? tmp$ : throwCCE();\n };\n TypedKeyHashMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedKeyHashMap',\n interfaces: []\n };\n function UNSUPPORTED() {\n throw UnsupportedOperationException_init();\n }\n function UNSUPPORTED_0(what) {\n throw UnsupportedOperationException_init_0(what);\n }\n function Color(red, green, blue, alpha) {\n Color$Companion_getInstance();\n if (alpha === void 0)\n alpha = 255;\n this.red = red;\n this.green = green;\n this.blue = blue;\n this.alpha = alpha;\n if (!(0 <= this.red && this.red <= 255 && 0 <= this.green && this.green <= 255 && 0 <= this.blue && this.blue <= 255 && 0 <= this.alpha && this.alpha <= 255)) {\n var message = 'Color components out of range: ' + this;\n throw IllegalArgumentException_init(message.toString());\n }}\n Color.prototype.changeAlpha_za3lpa$ = function (newAlpha) {\n return new Color(this.red, this.green, this.blue, newAlpha);\n };\n Color.prototype.equals = function (other) {\n if (this === other) {\n return true;\n }if (!Kotlin.isType(other, Color)) {\n return false;\n }if (this.red !== other.red) {\n return false;\n }if (this.green !== other.green) {\n return false;\n }if (this.blue !== other.blue) {\n return false;\n }return this.alpha === other.alpha;\n };\n Color.prototype.toCssColor = function () {\n var tmp$;\n if (this.alpha === 255) {\n tmp$ = 'rgb(' + this.red + ',' + this.green + ',' + this.blue + ')';\n } else {\n tmp$ = 'rgba(' + toString(this.red) + ',' + toString(this.green) + ',' + toString(this.blue) + ',' + toString(this.alpha / 255.0) + ')';\n }\n return tmp$;\n };\n Color.prototype.toHexColor = function () {\n return '#' + Color$Companion_getInstance().toColorPart_0(this.red) + Color$Companion_getInstance().toColorPart_0(this.green) + Color$Companion_getInstance().toColorPart_0(this.blue);\n };\n Color.prototype.hashCode = function () {\n var result = 0;\n result = (31 * result | 0) + this.red | 0;\n result = (31 * result | 0) + this.green | 0;\n result = (31 * result | 0) + this.blue | 0;\n result = (31 * result | 0) + this.alpha | 0;\n return result;\n };\n Color.prototype.toString = function () {\n return 'color(' + this.red + ',' + this.green + ',' + this.blue + ',' + this.alpha + ')';\n };\n function Color$Companion() {\n Color$Companion_instance = this;\n this.TRANSPARENT = new Color(0, 0, 0, 0);\n this.WHITE = new Color(255, 255, 255);\n this.CONSOLE_WHITE = new Color(204, 204, 204);\n this.BLACK = new Color(0, 0, 0);\n this.LIGHT_GRAY = new Color(192, 192, 192);\n this.VERY_LIGHT_GRAY = new Color(210, 210, 210);\n this.GRAY = new Color(128, 128, 128);\n this.RED = new Color(255, 0, 0);\n this.LIGHT_GREEN = new Color(210, 255, 210);\n this.GREEN = new Color(0, 255, 0);\n this.DARK_GREEN = new Color(0, 128, 0);\n this.BLUE = new Color(0, 0, 255);\n this.DARK_BLUE = new Color(0, 0, 128);\n this.LIGHT_BLUE = new Color(210, 210, 255);\n this.YELLOW = new Color(255, 255, 0);\n this.CONSOLE_YELLOW = new Color(174, 174, 36);\n this.LIGHT_YELLOW = new Color(255, 255, 128);\n this.VERY_LIGHT_YELLOW = new Color(255, 255, 210);\n this.MAGENTA = new Color(255, 0, 255);\n this.LIGHT_MAGENTA = new Color(255, 210, 255);\n this.DARK_MAGENTA = new Color(128, 0, 128);\n this.CYAN = new Color(0, 255, 255);\n this.LIGHT_CYAN = new Color(210, 255, 255);\n this.ORANGE = new Color(255, 192, 0);\n this.PINK = new Color(255, 175, 175);\n this.LIGHT_PINK = new Color(255, 210, 210);\n this.PACIFIC_BLUE = this.parseHex_61zpoe$('#118ED8');\n this.RGB_0 = 'rgb';\n this.COLOR_0 = 'color';\n this.RGBA_0 = 'rgba';\n }\n Color$Companion.prototype.parseRGB_61zpoe$ = function (text) {\n var firstParen = this.findNext_0(text, '(', 0);\n var prefix = text.substring(0, firstParen);\n var firstComma = this.findNext_0(text, ',', firstParen + 1 | 0);\n var secondComma = this.findNext_0(text, ',', firstComma + 1 | 0);\n var thirdComma = -1;\n if (equals(prefix, this.RGBA_0))\n thirdComma = this.findNext_0(text, ',', secondComma + 1 | 0);\n else if (equals(prefix, this.COLOR_0))\n thirdComma = indexOf(text, ',', secondComma + 1 | 0);\n else if (!equals(prefix, this.RGB_0))\n throw IllegalArgumentException_init(text);\n var lastParen = this.findNext_0(text, ')', thirdComma + 1 | 0);\n var startIndex = firstParen + 1 | 0;\n var $receiver = text.substring(startIndex, firstComma);\n var tmp$;\n var $receiver_0 = Kotlin.isCharSequence(tmp$ = $receiver) ? tmp$ : throwCCE();\n var startIndex_0 = 0;\n var endIndex = $receiver_0.length - 1 | 0;\n var startFound = false;\n while (startIndex_0 <= endIndex) {\n var index = !startFound ? startIndex_0 : endIndex;\n var match = unboxChar(toBoxedChar($receiver_0.charCodeAt(index))) <= 32;\n if (!startFound) {\n if (!match)\n startFound = true;\n else\n startIndex_0 = startIndex_0 + 1 | 0;\n } else {\n if (!match)\n break;\n else\n endIndex = endIndex - 1 | 0;\n }\n }\n var red = toInt(Kotlin.subSequence($receiver_0, startIndex_0, endIndex + 1 | 0).toString());\n var startIndex_1 = firstComma + 1 | 0;\n var $receiver_1 = text.substring(startIndex_1, secondComma);\n var tmp$_0;\n var $receiver_0_0 = Kotlin.isCharSequence(tmp$_0 = $receiver_1) ? tmp$_0 : throwCCE();\n var startIndex_2 = 0;\n var endIndex_0 = $receiver_0_0.length - 1 | 0;\n var startFound_0 = false;\n while (startIndex_2 <= endIndex_0) {\n var index_0 = !startFound_0 ? startIndex_2 : endIndex_0;\n var match_0 = unboxChar(toBoxedChar($receiver_0_0.charCodeAt(index_0))) <= 32;\n if (!startFound_0) {\n if (!match_0)\n startFound_0 = true;\n else\n startIndex_2 = startIndex_2 + 1 | 0;\n } else {\n if (!match_0)\n break;\n else\n endIndex_0 = endIndex_0 - 1 | 0;\n }\n }\n var green = toInt(Kotlin.subSequence($receiver_0_0, startIndex_2, endIndex_0 + 1 | 0).toString());\n var blue;\n var alpha;\n if (thirdComma === -1) {\n var startIndex_3 = secondComma + 1 | 0;\n var $receiver_2 = text.substring(startIndex_3, lastParen);\n var tmp$_1;\n var $receiver_0_1 = Kotlin.isCharSequence(tmp$_1 = $receiver_2) ? tmp$_1 : throwCCE();\n var startIndex_4 = 0;\n var endIndex_1 = $receiver_0_1.length - 1 | 0;\n var startFound_1 = false;\n while (startIndex_4 <= endIndex_1) {\n var index_1 = !startFound_1 ? startIndex_4 : endIndex_1;\n var match_1 = unboxChar(toBoxedChar($receiver_0_1.charCodeAt(index_1))) <= 32;\n if (!startFound_1) {\n if (!match_1)\n startFound_1 = true;\n else\n startIndex_4 = startIndex_4 + 1 | 0;\n } else {\n if (!match_1)\n break;\n else\n endIndex_1 = endIndex_1 - 1 | 0;\n }\n }\n blue = toInt(Kotlin.subSequence($receiver_0_1, startIndex_4, endIndex_1 + 1 | 0).toString());\n alpha = 255;\n } else {\n var startIndex_5 = secondComma + 1 | 0;\n var endIndex_2 = thirdComma;\n var $receiver_3 = text.substring(startIndex_5, endIndex_2);\n var tmp$_2;\n var $receiver_0_2 = Kotlin.isCharSequence(tmp$_2 = $receiver_3) ? tmp$_2 : throwCCE();\n var startIndex_6 = 0;\n var endIndex_3 = $receiver_0_2.length - 1 | 0;\n var startFound_2 = false;\n while (startIndex_6 <= endIndex_3) {\n var index_2 = !startFound_2 ? startIndex_6 : endIndex_3;\n var match_2 = unboxChar(toBoxedChar($receiver_0_2.charCodeAt(index_2))) <= 32;\n if (!startFound_2) {\n if (!match_2)\n startFound_2 = true;\n else\n startIndex_6 = startIndex_6 + 1 | 0;\n } else {\n if (!match_2)\n break;\n else\n endIndex_3 = endIndex_3 - 1 | 0;\n }\n }\n blue = toInt(Kotlin.subSequence($receiver_0_2, startIndex_6, endIndex_3 + 1 | 0).toString());\n var startIndex_7 = thirdComma + 1 | 0;\n var $receiver_4 = text.substring(startIndex_7, lastParen);\n var tmp$_3;\n var $receiver_0_3 = Kotlin.isCharSequence(tmp$_3 = $receiver_4) ? tmp$_3 : throwCCE();\n var startIndex_8 = 0;\n var endIndex_4 = $receiver_0_3.length - 1 | 0;\n var startFound_3 = false;\n while (startIndex_8 <= endIndex_4) {\n var index_3 = !startFound_3 ? startIndex_8 : endIndex_4;\n var match_3 = unboxChar(toBoxedChar($receiver_0_3.charCodeAt(index_3))) <= 32;\n if (!startFound_3) {\n if (!match_3)\n startFound_3 = true;\n else\n startIndex_8 = startIndex_8 + 1 | 0;\n } else {\n if (!match_3)\n break;\n else\n endIndex_4 = endIndex_4 - 1 | 0;\n }\n }\n alpha = roundToInt(toDouble(Kotlin.subSequence($receiver_0_3, startIndex_8, endIndex_4 + 1 | 0).toString()) * 255);\n }\n return new Color(red, green, blue, alpha);\n };\n Color$Companion.prototype.findNext_0 = function (s, what, from) {\n var result = indexOf(s, what, from);\n if (result === -1) {\n throw IllegalArgumentException_init('text=' + s + ' what=' + what + ' from=' + from);\n }return result;\n };\n Color$Companion.prototype.parseHex_61zpoe$ = function (hexColor) {\n var hexColor_0 = hexColor;\n if (!startsWith_0(hexColor_0, '#')) {\n throw IllegalArgumentException_init('Not a HEX value: ' + hexColor_0);\n }hexColor_0 = hexColor_0.substring(1);\n if (hexColor_0.length !== 6) {\n throw IllegalArgumentException_init('Not a HEX value: ' + hexColor_0);\n }var r = toInt_0(hexColor_0.substring(0, 2), 16);\n var g = toInt_0(hexColor_0.substring(2, 4), 16);\n var b = toInt_0(hexColor_0.substring(4, 6), 16);\n return new Color(r, g, b);\n };\n Color$Companion.prototype.toColorPart_0 = function (value) {\n var tmp$;\n if (value < 0 || value > 255) {\n throw IllegalArgumentException_init('RGB color part must be in range [0..255] but was ' + value);\n }var result = toString_0(value, 16);\n if (result.length === 1) {\n tmp$ = '0' + result;\n } else {\n tmp$ = result;\n }\n return tmp$;\n };\n Color$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Color$Companion_instance = null;\n function Color$Companion_getInstance() {\n if (Color$Companion_instance === null) {\n new Color$Companion();\n }return Color$Companion_instance;\n }\n Color.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Color',\n interfaces: []\n };\n function Colors() {\n Colors_instance = this;\n this.DEFAULT_FACTOR_0 = 0.7;\n this.variantColors_0 = mapOf([to('dark_blue', Color$Companion_getInstance().DARK_BLUE), to('dark_green', Color$Companion_getInstance().DARK_GREEN), to('dark_magenta', Color$Companion_getInstance().DARK_MAGENTA), to('light_blue', Color$Companion_getInstance().LIGHT_BLUE), to('light_gray', Color$Companion_getInstance().LIGHT_GRAY), to('light_green', Color$Companion_getInstance().LIGHT_GREEN), to('light_yellow', Color$Companion_getInstance().LIGHT_YELLOW), to('light_magenta', Color$Companion_getInstance().LIGHT_MAGENTA), to('light_cyan', Color$Companion_getInstance().LIGHT_CYAN), to('light_pink', Color$Companion_getInstance().LIGHT_PINK), to('very_light_gray', Color$Companion_getInstance().VERY_LIGHT_GRAY), to('very_light_yellow', Color$Companion_getInstance().VERY_LIGHT_YELLOW)]);\n var tmp$ = plus_3(mapOf([to('white', Color$Companion_getInstance().WHITE), to('black', Color$Companion_getInstance().BLACK), to('gray', Color$Companion_getInstance().GRAY), to('red', Color$Companion_getInstance().RED), to('green', Color$Companion_getInstance().GREEN), to('blue', Color$Companion_getInstance().BLUE), to('yellow', Color$Companion_getInstance().YELLOW), to('magenta', Color$Companion_getInstance().MAGENTA), to('cyan', Color$Companion_getInstance().CYAN), to('orange', Color$Companion_getInstance().ORANGE), to('pink', Color$Companion_getInstance().PINK)]), this.variantColors_0);\n var $receiver = this.variantColors_0;\n var destination = LinkedHashMap_init_0(mapCapacity($receiver.size));\n var tmp$_0;\n tmp$_0 = $receiver.entries.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n destination.put_xwzc9p$(replace_0(element.key, 95, 45), element.value);\n }\n var tmp$_1 = plus_3(tmp$, destination);\n var $receiver_0 = this.variantColors_0;\n var destination_0 = LinkedHashMap_init_0(mapCapacity($receiver_0.size));\n var tmp$_2;\n tmp$_2 = $receiver_0.entries.iterator();\n while (tmp$_2.hasNext()) {\n var element_0 = tmp$_2.next();\n destination_0.put_xwzc9p$(replace(element_0.key, '_', ''), element_0.value);\n }\n this.namedColors_0 = plus_3(tmp$_1, destination_0);\n }\n Colors.prototype.parseColor_61zpoe$ = function (c) {\n var tmp$;\n if (indexOf_0(c, 40) > 0)\n tmp$ = Color$Companion_getInstance().parseRGB_61zpoe$(c);\n else if (startsWith_0(c, '#'))\n tmp$ = Color$Companion_getInstance().parseHex_61zpoe$(c);\n else if (this.isColorName_61zpoe$(c))\n tmp$ = this.forName_61zpoe$(c);\n else\n throw IllegalArgumentException_init('Error persing color value: ' + c);\n return tmp$;\n };\n Colors.prototype.isColorName_61zpoe$ = function (colorName) {\n return this.namedColors_0.containsKey_11rb$(colorName.toLowerCase());\n };\n Colors.prototype.forName_61zpoe$ = function (colorName) {\n var tmp$;\n tmp$ = this.namedColors_0.get_11rb$(colorName.toLowerCase());\n if (tmp$ == null) {\n throw IllegalArgumentException_init_0();\n }return tmp$;\n };\n Colors.prototype.generateHueColor = function () {\n return 360 * Random.Default.nextDouble();\n };\n Colors.prototype.generateColor_lu1900$ = function (s, v) {\n return this.rgbFromHsv_yvo9jy$(360 * Random.Default.nextDouble(), s, v);\n };\n Colors.prototype.rgbFromHsv_yvo9jy$ = function (h, s, v) {\n if (v === void 0)\n v = 1.0;\n var hd = h / 60;\n var c = v * s;\n var x = hd % 2 - 1;\n var x_0 = c * (1 - JsMath.abs(x));\n var r = 0.0;\n var g = 0.0;\n var b = 0.0;\n if (hd < 1) {\n r = c;\n g = x_0;\n } else if (hd < 2) {\n r = x_0;\n g = c;\n } else if (hd < 3) {\n g = c;\n b = x_0;\n } else if (hd < 4) {\n g = x_0;\n b = c;\n } else if (hd < 5) {\n r = x_0;\n b = c;\n } else {\n r = c;\n b = x_0;\n }\n var m = v - c;\n return new Color(numberToInt(255 * (r + m)), numberToInt(255 * (g + m)), numberToInt(255 * (b + m)));\n };\n Colors.prototype.hsvFromRgb_98b62m$ = function (color) {\n var tmp$;\n var scale = 1.0 / 255;\n var r = color.red * scale;\n var g = color.green * scale;\n var b = color.blue * scale;\n var b_0 = JsMath.min(g, b);\n var min = JsMath.min(r, b_0);\n var b_1 = JsMath.max(g, b);\n var max = JsMath.max(r, b_1);\n var v = max === 0.0 ? 0.0 : 1 - min / max;\n var h;\n var div = 1.0 / (6 * (max - min));\n if (max === min) {\n tmp$ = 0.0;\n } else if (max === r) {\n tmp$ = g >= b ? (g - b) * div : 1 + (g - b) * div;\n } else if (max === g) {\n tmp$ = 1.0 / 3 + (b - r) * div;\n } else {\n tmp$ = 2.0 / 3 + (r - g) * div;\n }\n h = tmp$;\n return new Float64Array([360 * h, v, max]);\n };\n Colors.prototype.darker_w32t8z$ = function (c, factor) {\n if (factor === void 0)\n factor = this.DEFAULT_FACTOR_0;\n var tmp$;\n if (c != null) {\n var a = numberToInt(c.red * factor);\n var tmp$_0 = JsMath.max(a, 0);\n var a_0 = numberToInt(c.green * factor);\n var tmp$_1 = JsMath.max(a_0, 0);\n var a_1 = numberToInt(c.blue * factor);\n tmp$ = new Color(tmp$_0, tmp$_1, JsMath.max(a_1, 0), c.alpha);\n } else\n tmp$ = null;\n return tmp$;\n };\n Colors.prototype.lighter_o14uds$ = function (c, factor) {\n if (factor === void 0)\n factor = this.DEFAULT_FACTOR_0;\n var r = c.red;\n var g = c.green;\n var b = c.blue;\n var alpha = c.alpha;\n var i = numberToInt(1.0 / (1.0 - factor));\n if (r === 0 && g === 0 && b === 0) {\n return new Color(i, i, i, alpha);\n }if (r > 0 && r < i)\n r = i;\n if (g > 0 && g < i)\n g = i;\n if (b > 0 && b < i)\n b = i;\n var a = numberToInt(r / factor);\n var tmp$ = JsMath.min(a, 255);\n var a_0 = numberToInt(g / factor);\n var tmp$_0 = JsMath.min(a_0, 255);\n var a_1 = numberToInt(b / factor);\n return new Color(tmp$, tmp$_0, JsMath.min(a_1, 255), alpha);\n };\n Colors.prototype.mimicTransparency_w1v12e$ = function (color, alpha, background) {\n var red = numberToInt(color.red * alpha + background.red * (1 - alpha));\n var green = numberToInt(color.green * alpha + background.green * (1 - alpha));\n var blue = numberToInt(color.blue * alpha + background.blue * (1 - alpha));\n return new Color(red, green, blue);\n };\n Colors.prototype.withOpacity_o14uds$ = function (c, opacity) {\n var tmp$;\n if (opacity < 1.0) {\n var b = numberToInt(round(255 * opacity));\n var b_0 = JsMath.min(255, b);\n tmp$ = c.changeAlpha_za3lpa$(JsMath.max(0, b_0));\n } else\n tmp$ = c;\n return tmp$;\n };\n Colors.prototype.contrast_a87jzg$ = function (color, other) {\n return (this.luminance_98b62m$(color) + 0.05) / (this.luminance_98b62m$(other) + 0.05);\n };\n Colors.prototype.luminance_98b62m$ = function (color) {\n return 0.2126 * this.colorLuminance_0(color.red) + 0.7152 * this.colorLuminance_0(color.green) + 0.0722 * this.colorLuminance_0(color.blue);\n };\n Colors.prototype.colorLuminance_0 = function (componentValue) {\n var tmp$;\n if (componentValue <= 10)\n tmp$ = componentValue / 3294.0;\n else {\n var $receiver = componentValue / 269.0 + 0.0513;\n tmp$ = JsMath.pow($receiver, 2.4);\n }\n return tmp$;\n };\n Colors.prototype.solid_98b62m$ = function (c) {\n return c.alpha === 255;\n };\n Colors.prototype.distributeEvenly_5wr77w$ = function (count, saturation) {\n var tmp$;\n var result = Kotlin.newArray(count, null);\n var sector = 360 / count | 0;\n for (var i = 0; i < count; i++) {\n result[i] = this.rgbFromHsv_yvo9jy$(Kotlin.imul(sector, i), saturation);\n }\n return Kotlin.isArray(tmp$ = result) ? tmp$ : throwCCE();\n };\n Colors.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Colors',\n interfaces: []\n };\n var Colors_instance = null;\n function Colors_getInstance() {\n if (Colors_instance === null) {\n new Colors();\n }return Colors_instance;\n }\n function toPngDataUri(base64EncodedPngImage) {\n return 'data:image/png;base64,' + base64EncodedPngImage;\n }\n function Font(family, size, isBold, isItalic) {\n if (isBold === void 0)\n isBold = false;\n if (isItalic === void 0)\n isItalic = false;\n this.family = family;\n this.size = size;\n this.isBold = isBold;\n this.isItalic = isItalic;\n }\n Font.prototype.toString = function () {\n return this.family.toString() + ' ' + this.size + ' ' + (this.isBold ? 'bold' : '') + ' ' + (this.isItalic ? 'italic' : '');\n };\n Font.prototype.equals = function (other) {\n if (this === other)\n return true;\n if (!Kotlin.isType(other, Font))\n return false;\n return this.family === other.family && this.size === other.size && this.isBold === other.isBold && this.isItalic === other.isItalic;\n };\n Font.prototype.hashCode = function () {\n var result = hashCode(this.family);\n result = (31 * result | 0) + this.size | 0;\n result = (31 * result | 0) + (this.isBold ? 1 : 0) | 0;\n result = (31 * result | 0) + (this.isItalic ? 1 : 0) | 0;\n return result;\n };\n Font.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Font',\n interfaces: []\n };\n function FontFamily(myName) {\n FontFamily$Companion_getInstance();\n this.myName_0 = myName;\n }\n FontFamily.prototype.toString = function () {\n return this.myName_0;\n };\n function FontFamily$Companion() {\n FontFamily$Companion_instance = this;\n this.MONOSPACED = this.forName_61zpoe$('monospace');\n this.SERIF = this.forName_61zpoe$('serif');\n }\n FontFamily$Companion.prototype.forName_61zpoe$ = function (name) {\n return new FontFamily(name);\n };\n FontFamily$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FontFamily$Companion_instance = null;\n function FontFamily$Companion_getInstance() {\n if (FontFamily$Companion_instance === null) {\n new FontFamily$Companion();\n }return FontFamily$Companion_instance;\n }\n FontFamily.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FontFamily',\n interfaces: []\n };\n function HSV(h, saturation, value) {\n if (value === void 0)\n value = 1.0;\n this.h = h;\n this.s = 0;\n this.v = 0;\n if (!(saturation >= -0.001 && saturation <= 1.001)) {\n var message = \"HSV 'saturation' must be in range [0, 1] but was \" + saturation;\n throw IllegalArgumentException_init(message.toString());\n }if (!(value >= -0.001 && value <= 1.001)) {\n var message_0 = \"HSV 'value' must be in range [0, 1] but was \" + value;\n throw IllegalArgumentException_init(message_0.toString());\n }var x = numberToInt(saturation * 100) / 100.0;\n this.s = JsMath.abs(x);\n var x_0 = numberToInt(value * 100) / 100.0;\n this.v = JsMath.abs(x_0);\n }\n HSV.prototype.toString = function () {\n return 'HSV(' + this.h + ', ' + this.s + ', ' + this.v + ')';\n };\n HSV.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HSV',\n interfaces: []\n };\n function Interval(lowerBound, upperBound) {\n this.lowerBound = lowerBound;\n this.upperBound = upperBound;\n if (this.lowerBound > this.upperBound) {\n throw IllegalArgumentException_init('Lower bound is greater than upper: lower bound=' + toString(this.lowerBound) + ', upper bound=' + toString(this.upperBound));\n }}\n Object.defineProperty(Interval.prototype, 'length', {\n configurable: true,\n get: function () {\n return this.upperBound - this.lowerBound | 0;\n }\n });\n Interval.prototype.contains_za3lpa$ = function (point) {\n return this.lowerBound <= point && point <= this.upperBound;\n };\n Interval.prototype.contains_fvoaba$ = function (other) {\n return this.contains_za3lpa$(other.lowerBound) && this.contains_za3lpa$(other.upperBound);\n };\n Interval.prototype.intersects_fvoaba$ = function (other) {\n return this.contains_za3lpa$(other.lowerBound) || other.contains_za3lpa$(this.lowerBound);\n };\n Interval.prototype.union_fvoaba$ = function (other) {\n var a = this.lowerBound;\n var b = other.lowerBound;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.upperBound;\n var b_0 = other.upperBound;\n return new Interval(tmp$, JsMath.max(a_0, b_0));\n };\n Interval.prototype.add_za3lpa$ = function (delta) {\n return new Interval(this.lowerBound + delta | 0, this.upperBound + delta | 0);\n };\n Interval.prototype.sub_za3lpa$ = function (delta) {\n return new Interval(this.lowerBound - delta | 0, this.upperBound - delta | 0);\n };\n Interval.prototype.toString = function () {\n return '[' + this.lowerBound + ', ' + this.upperBound + ']';\n };\n Interval.prototype.equals = function (other) {\n var tmp$;\n if (this === other)\n return true;\n if (!Kotlin.isType(other, Interval))\n return false;\n var interval = (tmp$ = other) == null || Kotlin.isType(tmp$, Interval) ? tmp$ : throwCCE();\n return this.lowerBound !== ensureNotNull(interval).lowerBound ? false : this.upperBound === interval.upperBound;\n };\n Interval.prototype.hashCode = function () {\n var result = this.lowerBound;\n result = (31 * result | 0) + this.upperBound | 0;\n return result;\n };\n Interval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Interval',\n interfaces: []\n };\n function Pair_0(first, second) {\n this.first = first;\n this.second = second;\n }\n Pair_0.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, Pair_0) ? tmp$_0 : throwCCE();\n if (!equals(this.first, other.first))\n return false;\n if (!equals(this.second, other.second))\n return false;\n return true;\n };\n Pair_0.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.first) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.second) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n return result;\n };\n Pair_0.prototype.toString = function () {\n return '[' + this.first + ', ' + this.second + ']';\n };\n Pair_0.prototype.component1 = function () {\n return this.first;\n };\n Pair_0.prototype.component2 = function () {\n return this.second;\n };\n Pair_0.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Pair',\n interfaces: []\n };\n function SomeFig() {\n }\n SomeFig.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'SomeFig',\n interfaces: []\n };\n function PortableLogging() {\n PortableLogging_instance = this;\n }\n function PortableLogging$logger$ObjectLiteral(closure$kl) {\n this.closure$kl = closure$kl;\n }\n PortableLogging$logger$ObjectLiteral.prototype.error_l35kib$ = function (e, message) {\n this.closure$kl.error_ca4k3s$(e, message);\n };\n PortableLogging$logger$ObjectLiteral.prototype.info_h4ejuu$ = function (message) {\n this.closure$kl.info_nq59yw$(message);\n };\n PortableLogging$logger$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Logger]\n };\n PortableLogging.prototype.logger_xo1ogr$ = function (cl) {\n var tmp$;\n var kl = mu.KotlinLogging.logger_61zpoe$((tmp$ = cl.simpleName) != null ? tmp$ : '');\n return new PortableLogging$logger$ObjectLiteral(kl);\n };\n PortableLogging.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PortableLogging',\n interfaces: []\n };\n var PortableLogging_instance = null;\n function PortableLogging_getInstance() {\n if (PortableLogging_instance === null) {\n new PortableLogging();\n }return PortableLogging_instance;\n }\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$base = package$datalore.base || (package$datalore.base = {});\n var package$algorithms = package$base.algorithms || (package$base.algorithms = {});\n package$algorithms.splitRings_bemo1h$ = splitRings;\n package$algorithms.isClosed_2p1efm$ = isClosed;\n package$algorithms.calculateArea_ytws2g$ = calculateArea;\n package$algorithms.isClockwise_st9g9f$ = isClockwise;\n package$algorithms.calculateArea_st9g9f$ = calculateArea_0;\n var package$dateFormat = package$base.dateFormat || (package$base.dateFormat = {});\n Object.defineProperty(package$dateFormat, 'DateLocale', {\n get: DateLocale_getInstance\n });\n Format.SpecPart = Format$SpecPart;\n Format.PatternSpecPart = Format$PatternSpecPart;\n Object.defineProperty(Format, 'Companion', {\n get: Format$Companion_getInstance\n });\n package$dateFormat.Format_init_61zpoe$ = Format_init;\n package$dateFormat.Format = Format;\n Object.defineProperty(Pattern, 'DAY_OF_WEEK_ABBR', {\n get: Pattern$DAY_OF_WEEK_ABBR_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_WEEK_FULL', {\n get: Pattern$DAY_OF_WEEK_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH_ABBR', {\n get: Pattern$MONTH_ABBR_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH_FULL', {\n get: Pattern$MONTH_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_MONTH_LEADING_ZERO', {\n get: Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_MONTH', {\n get: Pattern$DAY_OF_MONTH_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_THE_YEAR', {\n get: Pattern$DAY_OF_THE_YEAR_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH', {\n get: Pattern$MONTH_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_WEEK', {\n get: Pattern$DAY_OF_WEEK_getInstance\n });\n Object.defineProperty(Pattern, 'YEAR_SHORT', {\n get: Pattern$YEAR_SHORT_getInstance\n });\n Object.defineProperty(Pattern, 'YEAR_FULL', {\n get: Pattern$YEAR_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_24', {\n get: Pattern$HOUR_24_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_12_LEADING_ZERO', {\n get: Pattern$HOUR_12_LEADING_ZERO_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_12', {\n get: Pattern$HOUR_12_getInstance\n });\n Object.defineProperty(Pattern, 'MINUTE', {\n get: Pattern$MINUTE_getInstance\n });\n Object.defineProperty(Pattern, 'MERIDIAN_LOWER', {\n get: Pattern$MERIDIAN_LOWER_getInstance\n });\n Object.defineProperty(Pattern, 'MERIDIAN_UPPER', {\n get: Pattern$MERIDIAN_UPPER_getInstance\n });\n Object.defineProperty(Pattern, 'SECOND', {\n get: Pattern$SECOND_getInstance\n });\n Object.defineProperty(Pattern$Companion$Kind, 'DATE', {\n get: Pattern$Companion$Kind$DATE_getInstance\n });\n Object.defineProperty(Pattern$Companion$Kind, 'TIME', {\n get: Pattern$Companion$Kind$TIME_getInstance\n });\n Pattern$Companion.prototype.Kind = Pattern$Companion$Kind;\n Object.defineProperty(Pattern, 'Companion', {\n get: Pattern$Companion_getInstance\n });\n package$dateFormat.Pattern = Pattern;\n Object.defineProperty(Date_0, 'Companion', {\n get: Date$Companion_getInstance\n });\n var package$datetime = package$base.datetime || (package$base.datetime = {});\n package$datetime.Date = Date_0;\n Object.defineProperty(DateTime, 'Companion', {\n get: DateTime$Companion_getInstance\n });\n package$datetime.DateTime = DateTime;\n Object.defineProperty(package$datetime, 'DateTimeUtil', {\n get: DateTimeUtil_getInstance\n });\n Object.defineProperty(Duration, 'Companion', {\n get: Duration$Companion_getInstance\n });\n package$datetime.Duration = Duration;\n package$datetime.Instant = Instant;\n Object.defineProperty(Month, 'Companion', {\n get: Month$Companion_getInstance\n });\n package$datetime.Month = Month;\n Object.defineProperty(Time, 'Companion', {\n get: Time$Companion_getInstance\n });\n package$datetime.Time = Time;\n Object.defineProperty(WeekDay, 'MONDAY', {\n get: WeekDay$MONDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'TUESDAY', {\n get: WeekDay$TUESDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'WEDNESDAY', {\n get: WeekDay$WEDNESDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'THURSDAY', {\n get: WeekDay$THURSDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'FRIDAY', {\n get: WeekDay$FRIDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'SATURDAY', {\n get: WeekDay$SATURDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'SUNDAY', {\n get: WeekDay$SUNDAY_getInstance\n });\n package$datetime.WeekDay = WeekDay;\n var package$tz = package$datetime.tz || (package$datetime.tz = {});\n package$tz.DateSpec = DateSpec;\n Object.defineProperty(package$tz, 'DateSpecs', {\n get: DateSpecs_getInstance\n });\n Object.defineProperty(TimeZone, 'Companion', {\n get: TimeZone$Companion_getInstance\n });\n package$tz.TimeZone = TimeZone;\n Object.defineProperty(TimeZoneMoscow, 'Companion', {\n get: TimeZoneMoscow$Companion_getInstance\n });\n package$tz.TimeZoneMoscow = TimeZoneMoscow;\n Object.defineProperty(package$tz, 'TimeZones', {\n get: TimeZones_getInstance\n });\n var package$enums = package$base.enums || (package$base.enums = {});\n package$enums.EnumInfo = EnumInfo;\n Object.defineProperty(package$enums, 'EnumInfoFactory', {\n get: EnumInfoFactory_getInstance\n });\n package$enums.EnumInfoImpl = EnumInfoImpl;\n Object.defineProperty(package$enums, 'Enums', {\n get: Enums_getInstance\n });\n Object.defineProperty(Button, 'NONE', {\n get: Button$NONE_getInstance\n });\n Object.defineProperty(Button, 'LEFT', {\n get: Button$LEFT_getInstance\n });\n Object.defineProperty(Button, 'MIDDLE', {\n get: Button$MIDDLE_getInstance\n });\n Object.defineProperty(Button, 'RIGHT', {\n get: Button$RIGHT_getInstance\n });\n var package$event = package$base.event || (package$base.event = {});\n package$event.Button = Button;\n package$event.Event = Event;\n package$event.EventContext = EventContext;\n Object.defineProperty(Key, 'A', {\n get: Key$A_getInstance\n });\n Object.defineProperty(Key, 'B', {\n get: Key$B_getInstance\n });\n Object.defineProperty(Key, 'C', {\n get: Key$C_getInstance\n });\n Object.defineProperty(Key, 'D', {\n get: Key$D_getInstance\n });\n Object.defineProperty(Key, 'E', {\n get: Key$E_getInstance\n });\n Object.defineProperty(Key, 'F', {\n get: Key$F_getInstance\n });\n Object.defineProperty(Key, 'G', {\n get: Key$G_getInstance\n });\n Object.defineProperty(Key, 'H', {\n get: Key$H_getInstance\n });\n Object.defineProperty(Key, 'I', {\n get: Key$I_getInstance\n });\n Object.defineProperty(Key, 'J', {\n get: Key$J_getInstance\n });\n Object.defineProperty(Key, 'K', {\n get: Key$K_getInstance\n });\n Object.defineProperty(Key, 'L', {\n get: Key$L_getInstance\n });\n Object.defineProperty(Key, 'M', {\n get: Key$M_getInstance\n });\n Object.defineProperty(Key, 'N', {\n get: Key$N_getInstance\n });\n Object.defineProperty(Key, 'O', {\n get: Key$O_getInstance\n });\n Object.defineProperty(Key, 'P', {\n get: Key$P_getInstance\n });\n Object.defineProperty(Key, 'Q', {\n get: Key$Q_getInstance\n });\n Object.defineProperty(Key, 'R', {\n get: Key$R_getInstance\n });\n Object.defineProperty(Key, 'S', {\n get: Key$S_getInstance\n });\n Object.defineProperty(Key, 'T', {\n get: Key$T_getInstance\n });\n Object.defineProperty(Key, 'U', {\n get: Key$U_getInstance\n });\n Object.defineProperty(Key, 'V', {\n get: Key$V_getInstance\n });\n Object.defineProperty(Key, 'W', {\n get: Key$W_getInstance\n });\n Object.defineProperty(Key, 'X', {\n get: Key$X_getInstance\n });\n Object.defineProperty(Key, 'Y', {\n get: Key$Y_getInstance\n });\n Object.defineProperty(Key, 'Z', {\n get: Key$Z_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_0', {\n get: Key$DIGIT_0_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_1', {\n get: Key$DIGIT_1_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_2', {\n get: Key$DIGIT_2_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_3', {\n get: Key$DIGIT_3_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_4', {\n get: Key$DIGIT_4_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_5', {\n get: Key$DIGIT_5_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_6', {\n get: Key$DIGIT_6_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_7', {\n get: Key$DIGIT_7_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_8', {\n get: Key$DIGIT_8_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_9', {\n get: Key$DIGIT_9_getInstance\n });\n Object.defineProperty(Key, 'LEFT_BRACE', {\n get: Key$LEFT_BRACE_getInstance\n });\n Object.defineProperty(Key, 'RIGHT_BRACE', {\n get: Key$RIGHT_BRACE_getInstance\n });\n Object.defineProperty(Key, 'UP', {\n get: Key$UP_getInstance\n });\n Object.defineProperty(Key, 'DOWN', {\n get: Key$DOWN_getInstance\n });\n Object.defineProperty(Key, 'LEFT', {\n get: Key$LEFT_getInstance\n });\n Object.defineProperty(Key, 'RIGHT', {\n get: Key$RIGHT_getInstance\n });\n Object.defineProperty(Key, 'PAGE_UP', {\n get: Key$PAGE_UP_getInstance\n });\n Object.defineProperty(Key, 'PAGE_DOWN', {\n get: Key$PAGE_DOWN_getInstance\n });\n Object.defineProperty(Key, 'ESCAPE', {\n get: Key$ESCAPE_getInstance\n });\n Object.defineProperty(Key, 'ENTER', {\n get: Key$ENTER_getInstance\n });\n Object.defineProperty(Key, 'HOME', {\n get: Key$HOME_getInstance\n });\n Object.defineProperty(Key, 'END', {\n get: Key$END_getInstance\n });\n Object.defineProperty(Key, 'TAB', {\n get: Key$TAB_getInstance\n });\n Object.defineProperty(Key, 'SPACE', {\n get: Key$SPACE_getInstance\n });\n Object.defineProperty(Key, 'INSERT', {\n get: Key$INSERT_getInstance\n });\n Object.defineProperty(Key, 'DELETE', {\n get: Key$DELETE_getInstance\n });\n Object.defineProperty(Key, 'BACKSPACE', {\n get: Key$BACKSPACE_getInstance\n });\n Object.defineProperty(Key, 'EQUALS', {\n get: Key$EQUALS_getInstance\n });\n Object.defineProperty(Key, 'BACK_QUOTE', {\n get: Key$BACK_QUOTE_getInstance\n });\n Object.defineProperty(Key, 'PLUS', {\n get: Key$PLUS_getInstance\n });\n Object.defineProperty(Key, 'MINUS', {\n get: Key$MINUS_getInstance\n });\n Object.defineProperty(Key, 'SLASH', {\n get: Key$SLASH_getInstance\n });\n Object.defineProperty(Key, 'CONTROL', {\n get: Key$CONTROL_getInstance\n });\n Object.defineProperty(Key, 'META', {\n get: Key$META_getInstance\n });\n Object.defineProperty(Key, 'ALT', {\n get: Key$ALT_getInstance\n });\n Object.defineProperty(Key, 'SHIFT', {\n get: Key$SHIFT_getInstance\n });\n Object.defineProperty(Key, 'UNKNOWN', {\n get: Key$UNKNOWN_getInstance\n });\n Object.defineProperty(Key, 'F1', {\n get: Key$F1_getInstance\n });\n Object.defineProperty(Key, 'F2', {\n get: Key$F2_getInstance\n });\n Object.defineProperty(Key, 'F3', {\n get: Key$F3_getInstance\n });\n Object.defineProperty(Key, 'F4', {\n get: Key$F4_getInstance\n });\n Object.defineProperty(Key, 'F5', {\n get: Key$F5_getInstance\n });\n Object.defineProperty(Key, 'F6', {\n get: Key$F6_getInstance\n });\n Object.defineProperty(Key, 'F7', {\n get: Key$F7_getInstance\n });\n Object.defineProperty(Key, 'F8', {\n get: Key$F8_getInstance\n });\n Object.defineProperty(Key, 'F9', {\n get: Key$F9_getInstance\n });\n Object.defineProperty(Key, 'F10', {\n get: Key$F10_getInstance\n });\n Object.defineProperty(Key, 'F11', {\n get: Key$F11_getInstance\n });\n Object.defineProperty(Key, 'F12', {\n get: Key$F12_getInstance\n });\n Object.defineProperty(Key, 'COMMA', {\n get: Key$COMMA_getInstance\n });\n Object.defineProperty(Key, 'PERIOD', {\n get: Key$PERIOD_getInstance\n });\n package$event.Key = Key;\n package$event.KeyEvent_init_l9pgtg$ = KeyEvent_init;\n package$event.KeyEvent_init_79e79$ = KeyEvent_init_0;\n package$event.KeyEvent_init_m5etgt$ = KeyEvent_init_1;\n package$event.KeyEvent = KeyEvent;\n Object.defineProperty(KeyModifiers, 'Companion', {\n get: KeyModifiers$Companion_getInstance\n });\n package$event.KeyModifiers = KeyModifiers;\n package$event.KeyStroke_init_ji7i3y$ = KeyStroke_init;\n package$event.KeyStroke_init_812rgc$ = KeyStroke_init_0;\n package$event.KeyStroke = KeyStroke;\n package$event.KeyStrokeSpec_init_ji7i3y$ = KeyStrokeSpec_init;\n package$event.KeyStrokeSpec_init_luoraj$ = KeyStrokeSpec_init_0;\n package$event.KeyStrokeSpec_init_4t3vif$ = KeyStrokeSpec_init_1;\n package$event.KeyStrokeSpec = KeyStrokeSpec;\n Object.defineProperty(package$event, 'KeyStrokeSpecs', {\n get: KeyStrokeSpecs_getInstance\n });\n Object.defineProperty(ModifierKey, 'CONTROL', {\n get: ModifierKey$CONTROL_getInstance\n });\n Object.defineProperty(ModifierKey, 'ALT', {\n get: ModifierKey$ALT_getInstance\n });\n Object.defineProperty(ModifierKey, 'SHIFT', {\n get: ModifierKey$SHIFT_getInstance\n });\n Object.defineProperty(ModifierKey, 'META', {\n get: ModifierKey$META_getInstance\n });\n package$event.ModifierKey = ModifierKey;\n Object.defineProperty(MouseEvent, 'Companion', {\n get: MouseEvent$Companion_getInstance\n });\n package$event.MouseEvent_init_fbovgd$ = MouseEvent_init;\n package$event.MouseEvent = MouseEvent;\n package$event.MouseEventSource = MouseEventSource;\n Object.defineProperty(MouseEventSpec, 'MOUSE_ENTERED', {\n get: MouseEventSpec$MOUSE_ENTERED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_LEFT', {\n get: MouseEventSpec$MOUSE_LEFT_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_MOVED', {\n get: MouseEventSpec$MOUSE_MOVED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_DRAGGED', {\n get: MouseEventSpec$MOUSE_DRAGGED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_CLICKED', {\n get: MouseEventSpec$MOUSE_CLICKED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_DOUBLE_CLICKED', {\n get: MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_PRESSED', {\n get: MouseEventSpec$MOUSE_PRESSED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_RELEASED', {\n get: MouseEventSpec$MOUSE_RELEASED_getInstance\n });\n package$event.MouseEventSpec = MouseEventSpec;\n package$event.PointEvent = PointEvent;\n var package$function = package$base.function || (package$base.function = {});\n package$function.Function = Function;\n Object.defineProperty(package$function, 'Functions', {\n get: Functions_getInstance\n });\n package$function.Runnable = Runnable;\n package$function.Supplier = Supplier;\n package$function.Value = Value;\n var package$gcommon = package$base.gcommon || (package$base.gcommon = {});\n var package$base_0 = package$gcommon.base || (package$gcommon.base = {});\n Object.defineProperty(package$base_0, 'Preconditions', {\n get: Preconditions_getInstance\n });\n Object.defineProperty(package$base_0, 'Strings', {\n get: Strings_getInstance\n });\n Object.defineProperty(package$base_0, 'Throwables', {\n get: Throwables_getInstance\n });\n Object.defineProperty(ClosedRange, 'Companion', {\n get: ClosedRange$Companion_getInstance\n });\n var package$collect = package$gcommon.collect || (package$gcommon.collect = {});\n package$collect.ClosedRange = ClosedRange;\n Object.defineProperty(package$collect, 'Comparables', {\n get: Comparables_getInstance\n });\n package$collect.ComparatorOrdering = ComparatorOrdering;\n Object.defineProperty(package$collect, 'Iterables', {\n get: Iterables_getInstance\n });\n Object.defineProperty(package$collect, 'Lists', {\n get: Lists_getInstance\n });\n Object.defineProperty(Ordering, 'Companion', {\n get: Ordering$Companion_getInstance\n });\n package$collect.Ordering = Ordering;\n Object.defineProperty(package$collect, 'Sets', {\n get: Sets_getInstance\n });\n package$collect.Stack = Stack;\n package$collect.TreeMap = TreeMap;\n Object.defineProperty(DoubleRectangle, 'Companion', {\n get: DoubleRectangle$Companion_getInstance\n });\n var package$geometry = package$base.geometry || (package$base.geometry = {});\n package$geometry.DoubleRectangle_init_6y0v78$ = DoubleRectangle_init;\n package$geometry.DoubleRectangle = DoubleRectangle;\n Object.defineProperty(package$geometry, 'DoubleRectangles', {\n get: DoubleRectangles_getInstance\n });\n package$geometry.DoubleSegment = DoubleSegment;\n Object.defineProperty(DoubleVector, 'Companion', {\n get: DoubleVector$Companion_getInstance\n });\n package$geometry.DoubleVector = DoubleVector;\n package$geometry.Rectangle_init_tjonv8$ = Rectangle_init;\n package$geometry.Rectangle = Rectangle;\n Object.defineProperty(package$geometry, 'Rectangles', {\n get: Rectangles_getInstance\n });\n package$geometry.Segment = Segment;\n Object.defineProperty(Vector, 'Companion', {\n get: Vector$Companion_getInstance\n });\n package$geometry.Vector = Vector;\n var package$jsObject = package$base.jsObject || (package$base.jsObject = {});\n Object.defineProperty(package$jsObject, 'JsObjectSupport', {\n get: JsObjectSupport_getInstance\n });\n var package$json = package$base.json || (package$base.json = {});\n package$json.FluentArray_init = FluentArray_init;\n package$json.FluentArray_init_giv38x$ = FluentArray_init_0;\n package$json.FluentArray = FluentArray;\n package$json.FluentObject_init_bkhwtg$ = FluentObject_init;\n package$json.FluentObject_init = FluentObject_init_0;\n package$json.FluentObject = FluentObject;\n package$json.FluentPrimitive_init_s8ev37$ = FluentPrimitive_init;\n package$json.FluentPrimitive_init_pdl1vj$ = FluentPrimitive_init_0;\n package$json.FluentPrimitive_init_1v8dbw$ = FluentPrimitive_init_1;\n package$json.FluentPrimitive_init_rcaewn$ = FluentPrimitive_init_2;\n package$json.FluentPrimitive = FluentPrimitive;\n package$json.FluentValue = FluentValue;\n package$json.JsonFormatter = JsonFormatter;\n Object.defineProperty(JsonLexer, 'Companion', {\n get: JsonLexer$Companion_getInstance\n });\n package$json.JsonLexer = JsonLexer;\n JsonParser.JsonException = JsonParser$JsonException;\n package$json.JsonParser = JsonParser;\n Object.defineProperty(package$json, 'JsonSupport', {\n get: JsonSupport_getInstance\n });\n Object.defineProperty(Token, 'LEFT_BRACE', {\n get: Token$LEFT_BRACE_getInstance\n });\n Object.defineProperty(Token, 'RIGHT_BRACE', {\n get: Token$RIGHT_BRACE_getInstance\n });\n Object.defineProperty(Token, 'LEFT_BRACKET', {\n get: Token$LEFT_BRACKET_getInstance\n });\n Object.defineProperty(Token, 'RIGHT_BRACKET', {\n get: Token$RIGHT_BRACKET_getInstance\n });\n Object.defineProperty(Token, 'COMMA', {\n get: Token$COMMA_getInstance\n });\n Object.defineProperty(Token, 'COLON', {\n get: Token$COLON_getInstance\n });\n Object.defineProperty(Token, 'STRING', {\n get: Token$STRING_getInstance\n });\n Object.defineProperty(Token, 'NUMBER', {\n get: Token$NUMBER_getInstance\n });\n Object.defineProperty(Token, 'TRUE', {\n get: Token$TRUE_getInstance\n });\n Object.defineProperty(Token, 'FALSE', {\n get: Token$FALSE_getInstance\n });\n Object.defineProperty(Token, 'NULL', {\n get: Token$NULL_getInstance\n });\n package$json.Token = Token;\n Object.defineProperty(package$json, 'SPECIAL_CHARS_8be2vx$', {\n get: function () {\n return SPECIAL_CHARS;\n }\n });\n package$json.escape_pdl1vz$ = escape;\n package$json.unescape_pdl1vz$ = unescape;\n package$json.streamOf_9ma18$ = streamOf;\n package$json.objectsStreamOf_9ma18$ = objectsStreamOf;\n package$json.stringStreamOf_9ma18$ = stringStreamOf;\n package$json.isBoolean_za3rmp$ = isBoolean;\n package$json.isNumber_za3rmp$ = isNumber;\n package$json.isString_za3rmp$ = isString;\n package$json.getAsDouble_za3rmp$ = getAsDouble;\n package$json.getAsInt_s8jyv4$ = getAsInt;\n package$json.getAsBoolean_za3rmp$ = getAsBoolean;\n package$json.containsString_mer726$ = containsString;\n package$json.getAsString_s8jyv4$ = getAsString;\n package$json.parseEnum_xwn52g$ = parseEnum;\n package$json.formatEnum_wbfx10$ = formatEnum;\n package$json.put_tvzjva$ = put;\n package$json.put_5zytao$ = put_0;\n package$json.getNumber_8dq7w5$ = getNumber;\n package$json.getDouble_8dq7w5$ = getDouble;\n package$json.getString_8dq7w5$ = getString;\n package$json.getObj_8dq7w5$ = getObj;\n package$json.getArr_8dq7w5$ = getArr;\n Object.defineProperty(ListMap, 'Companion', {\n get: ListMap$Companion_getInstance\n });\n ListMap.Entry = ListMap$Entry;\n var package$listMap = package$base.listMap || (package$base.listMap = {});\n package$listMap.ListMap = ListMap;\n var package$logging = package$base.logging || (package$base.logging = {});\n package$logging.Logger = Logger;\n package$logging.PrintlnLogger = PrintlnLogger;\n var package$math = package$base.math || (package$base.math = {});\n package$math.toRadians_14dthe$ = toRadians;\n package$math.toDegrees_14dthe$ = toDegrees;\n package$math.round_gpjtzr$ = round_0;\n package$math.ceil_gpjtzr$ = ceil;\n package$math.round_lu1900$ = round_1;\n package$math.ceil_lu1900$ = ceil_0;\n package$math.distance_l3ath1$ = distance;\n package$math.ipow_dqglrj$ = ipow;\n var package$numberFormat = package$base.numberFormat || (package$base.numberFormat = {});\n package$numberFormat.length_s8cxhz$ = length;\n NumberFormat.Spec = NumberFormat$Spec;\n Object.defineProperty(NumberFormat$NumberInfo, 'Companion', {\n get: NumberFormat$NumberInfo$Companion_getInstance\n });\n NumberFormat.NumberInfo_init_hjbnfl$ = NumberFormat$NumberFormat$NumberInfo_init;\n NumberFormat.NumberInfo = NumberFormat$NumberInfo;\n NumberFormat.Output = NumberFormat$Output;\n NumberFormat.FormattedNumber = NumberFormat$FormattedNumber;\n Object.defineProperty(NumberFormat, 'Companion', {\n get: NumberFormat$Companion_getInstance\n });\n package$numberFormat.NumberFormat_init_61zpoe$ = NumberFormat_init;\n package$numberFormat.NumberFormat = NumberFormat;\n var package$observable = package$base.observable || (package$base.observable = {});\n var package$children = package$observable.children || (package$observable.children = {});\n package$children.ChildList = ChildList;\n package$children.ChildProperty = ChildProperty;\n package$children.Position = Position;\n package$children.PositionData = PositionData;\n package$children.SimpleComposite = SimpleComposite;\n var package$collections = package$observable.collections || (package$observable.collections = {});\n package$collections.CollectionAdapter = CollectionAdapter;\n Object.defineProperty(CollectionItemEvent$EventType, 'ADD', {\n get: CollectionItemEvent$EventType$ADD_getInstance\n });\n Object.defineProperty(CollectionItemEvent$EventType, 'SET', {\n get: CollectionItemEvent$EventType$SET_getInstance\n });\n Object.defineProperty(CollectionItemEvent$EventType, 'REMOVE', {\n get: CollectionItemEvent$EventType$REMOVE_getInstance\n });\n CollectionItemEvent.EventType = CollectionItemEvent$EventType;\n package$collections.CollectionItemEvent = CollectionItemEvent;\n package$collections.CollectionListener = CollectionListener;\n package$collections.ObservableCollection = ObservableCollection;\n var package$list = package$collections.list || (package$collections.list = {});\n package$list.AbstractObservableList = AbstractObservableList;\n package$list.ObservableArrayList = ObservableArrayList;\n package$list.ObservableList = ObservableList;\n var package$event_0 = package$observable.event || (package$observable.event = {});\n package$event_0.CompositeEventSource_init_xw2ruy$ = CompositeEventSource_init;\n package$event_0.CompositeEventSource_init_3qo2qg$ = CompositeEventSource_init_0;\n package$event_0.CompositeEventSource = CompositeEventSource;\n package$event_0.EventHandler = EventHandler;\n package$event_0.EventSource = EventSource;\n Object.defineProperty(package$event_0, 'EventSources', {\n get: EventSources_getInstance\n });\n package$event_0.ListenerCaller = ListenerCaller;\n package$event_0.ListenerEvent = ListenerEvent;\n package$event_0.Listeners = Listeners;\n package$event_0.MappingEventSource = MappingEventSource;\n var package$property = package$observable.property || (package$observable.property = {});\n package$property.BaseReadableProperty = BaseReadableProperty;\n package$property.DelayedValueProperty = DelayedValueProperty;\n package$property.Property = Property;\n Object.defineProperty(package$property, 'PropertyBinding', {\n get: PropertyBinding_getInstance\n });\n package$property.PropertyChangeEvent = PropertyChangeEvent;\n package$property.ReadableProperty = ReadableProperty;\n package$property.ValueProperty = ValueProperty;\n package$property.WritableProperty = WritableProperty;\n var package$random = package$base.random || (package$base.random = {});\n package$random.RandomGaussian = RandomGaussian;\n Object.defineProperty(package$random, 'RandomString', {\n get: RandomString_getInstance\n });\n var package$registration = package$base.registration || (package$base.registration = {});\n package$registration.CompositeRegistration = CompositeRegistration;\n package$registration.Disposable = Disposable;\n Object.defineProperty(Registration, 'Companion', {\n get: Registration$Companion_getInstance\n });\n package$registration.Registration = Registration;\n var package$throwableHandlers = package$registration.throwableHandlers || (package$registration.throwableHandlers = {});\n package$throwableHandlers.ThrowableHandler = ThrowableHandler;\n Object.defineProperty(package$throwableHandlers, 'ThrowableHandlers', {\n get: ThrowableHandlers_getInstance\n });\n var package$spatial = package$base.spatial || (package$base.spatial = {});\n Object.defineProperty(package$spatial, 'EARTH_RADIUS', {\n get: function () {\n return EARTH_RADIUS;\n }\n });\n Object.defineProperty(package$spatial, 'MIN_LONGITUDE', {\n get: function () {\n return MIN_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MAX_LONGITUDE', {\n get: function () {\n return MAX_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'FULL_LONGITUDE', {\n get: function () {\n return FULL_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MIN_LATITUDE', {\n get: function () {\n return MIN_LATITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MAX_LATITUDE', {\n get: function () {\n return MAX_LATITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'FULL_LATITUDE', {\n get: function () {\n return FULL_LATITUDE;\n }\n });\n package$spatial.get_start_cawtq0$ = get_start;\n package$spatial.get_end_cawtq0$ = get_end;\n Object.defineProperty(GeoBoundingBoxCalculator, 'Companion', {\n get: GeoBoundingBoxCalculator$Companion_getInstance\n });\n package$spatial.GeoBoundingBoxCalculator = GeoBoundingBoxCalculator;\n package$spatial.makeSegments_8o5yvy$ = makeSegments;\n package$spatial.geoRectsBBox_wfabpm$ = geoRectsBBox;\n package$spatial.pointsBBox_2r9fhj$ = pointsBBox;\n package$spatial.union_86o20w$ = union;\n Object.defineProperty(package$spatial, 'GeoJson', {\n get: GeoJson_getInstance\n });\n package$spatial.GeoRectangle = GeoRectangle;\n package$spatial.LonLat = LonLat;\n Object.defineProperty(package$spatial, 'EARTH_RECT', {\n get: function () {\n return EARTH_RECT;\n }\n });\n package$spatial.limitLon_14dthe$ = limitLon;\n package$spatial.limitLat_14dthe$ = limitLat;\n package$spatial.normalizeLon_14dthe$ = normalizeLon;\n Object.defineProperty(package$spatial, 'BBOX_CALCULATOR', {\n get: function () {\n return BBOX_CALCULATOR;\n }\n });\n package$spatial.convertToGeoRectangle_i3vl8m$ = convertToGeoRectangle;\n package$spatial.calculateQuadKeys_h9hod0$ = calculateQuadKeys;\n Object.defineProperty(LongitudeSegment, 'Companion', {\n get: LongitudeSegment$Companion_getInstance\n });\n package$spatial.LongitudeSegment = LongitudeSegment;\n Object.defineProperty(package$spatial, 'MercatorUtils', {\n get: MercatorUtils_getInstance\n });\n package$spatial.QuadKey = QuadKey;\n package$spatial.computeRect_c2pv3p$ = computeRect;\n package$spatial.computeRect_v4gkf3$ = computeRect_0;\n package$spatial.projectRect_cub2h3$ = projectRect;\n package$spatial.zoom_c2pv3p$ = zoom;\n package$spatial.computeOrigin_v4gkf3$ = computeOrigin;\n package$spatial.projectOrigin_cub2h3$ = projectOrigin;\n package$spatial.calulateQuadsCount_za3lpa$ = calulateQuadsCount;\n package$spatial.calculateQuadKeys_a35lcs$ = calculateQuadKeys_0;\n package$spatial.xyToKey_qt1dr2$ = xyToKey;\n SimpleFeature.prototype.GeometryConsumer = SimpleFeature$GeometryConsumer;\n SimpleFeature.prototype.Consumer = SimpleFeature$Consumer;\n Object.defineProperty(SimpleFeature$GeometryType, 'POINT', {\n get: SimpleFeature$GeometryType$POINT_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'LINE_STRING', {\n get: SimpleFeature$GeometryType$LINE_STRING_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'POLYGON', {\n get: SimpleFeature$GeometryType$POLYGON_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_POINT', {\n get: SimpleFeature$GeometryType$MULTI_POINT_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_LINE_STRING', {\n get: SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_POLYGON', {\n get: SimpleFeature$GeometryType$MULTI_POLYGON_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'GEOMETRY_COLLECTION', {\n get: SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance\n });\n SimpleFeature.prototype.GeometryType = SimpleFeature$GeometryType;\n Object.defineProperty(package$spatial, 'SimpleFeature', {\n get: SimpleFeature_getInstance\n });\n Object.defineProperty(StringFormat$FormatType, 'NUMBER_FORMAT', {\n get: StringFormat$FormatType$NUMBER_FORMAT_getInstance\n });\n Object.defineProperty(StringFormat$FormatType, 'STRING_FORMAT', {\n get: StringFormat$FormatType$STRING_FORMAT_getInstance\n });\n StringFormat.FormatType = StringFormat$FormatType;\n Object.defineProperty(StringFormat, 'Companion', {\n get: StringFormat$Companion_getInstance\n });\n var package$stringFormat = package$base.stringFormat || (package$base.stringFormat = {});\n package$stringFormat.StringFormat = StringFormat;\n var package$typedGeometry = package$base.typedGeometry || (package$base.typedGeometry = {});\n package$typedGeometry.AbstractGeometryList = AbstractGeometryList;\n package$typedGeometry.isClockwise_hv912c$ = isClockwise_0;\n package$typedGeometry.createMultiPolygon_hv912c$ = createMultiPolygon;\n package$typedGeometry.boundingBox_gyuce3$ = boundingBox;\n package$typedGeometry.Generic = Generic;\n package$typedGeometry.reinterpret_q42o9k$ = reinterpret;\n package$typedGeometry.reinterpret_dr0qel$ = reinterpret_0;\n package$typedGeometry.reinterpret_2z483p$ = reinterpret_1;\n package$typedGeometry.reinterpret_typ3lq$ = reinterpret_2;\n package$typedGeometry.reinterpret_sux9xa$ = reinterpret_3;\n package$typedGeometry.reinterpret_dg847r$ = reinterpret_4;\n package$typedGeometry.get_bottom_h9e6jg$ = get_bottom;\n package$typedGeometry.get_right_h9e6jg$ = get_right;\n package$typedGeometry.get_height_h9e6jg$ = get_height;\n package$typedGeometry.get_width_h9e6jg$ = get_width;\n package$typedGeometry.get_top_h9e6jg$ = get_top;\n package$typedGeometry.get_left_h9e6jg$ = get_left;\n package$typedGeometry.get_scalarBottom_xdjzag$ = get_scalarBottom;\n package$typedGeometry.get_scalarRight_xdjzag$ = get_scalarRight;\n package$typedGeometry.get_scalarHeight_xdjzag$ = get_scalarHeight;\n package$typedGeometry.get_scalarWidth_xdjzag$ = get_scalarWidth;\n package$typedGeometry.get_scalarTop_xdjzag$ = get_scalarTop;\n package$typedGeometry.get_scalarLeft_xdjzag$ = get_scalarLeft;\n package$typedGeometry.get_center_xdjzag$ = get_center;\n package$typedGeometry.get_scalarX_xocuba$ = get_scalarX;\n package$typedGeometry.get_scalarY_xocuba$ = get_scalarY;\n package$typedGeometry.plus_cg1mpz$ = plus_4;\n package$typedGeometry.minus_cg1mpz$ = minus;\n package$typedGeometry.times_cg1mpz$ = times;\n package$typedGeometry.div_cg1mpz$ = div;\n package$typedGeometry.times_4nb5xq$ = times_0;\n package$typedGeometry.div_4nb5xq$ = div_0;\n package$typedGeometry.unaryMinus_e0pgg$ = unaryMinus;\n package$typedGeometry.transform_nj6yk8$ = transform;\n package$typedGeometry.plus_qnxb21$ = plus_5;\n package$typedGeometry.minus_qnxb21$ = minus_0;\n package$typedGeometry.times_qnxb21$ = times_1;\n package$typedGeometry.div_qnxb21$ = div_1;\n package$typedGeometry.div_i3tdhk$ = div_2;\n package$typedGeometry.times_i3tdhk$ = times_2;\n package$typedGeometry.unaryMinus_cr59ze$ = unaryMinus_0;\n package$typedGeometry.compareTo_85q7fw$ = compareTo;\n package$typedGeometry.newSpanRectangle_2d1svq$ = newSpanRectangle;\n package$typedGeometry.limit_106pae$ = limit;\n package$typedGeometry.contains_h8bixx$ = contains_1;\n package$typedGeometry.intersects_32samh$ = intersects;\n package$typedGeometry.xRange_h9e6jg$ = xRange;\n package$typedGeometry.yRange_h9e6jg$ = yRange;\n package$typedGeometry.limit_lddjmn$ = limit_0;\n Object.defineProperty(GeometryType, 'MULTI_POINT', {\n get: GeometryType$MULTI_POINT_getInstance\n });\n Object.defineProperty(GeometryType, 'MULTI_LINESTRING', {\n get: GeometryType$MULTI_LINESTRING_getInstance\n });\n Object.defineProperty(GeometryType, 'MULTI_POLYGON', {\n get: GeometryType$MULTI_POLYGON_getInstance\n });\n package$typedGeometry.GeometryType = GeometryType;\n Object.defineProperty(Geometry, 'Companion', {\n get: Geometry$Companion_getInstance\n });\n package$typedGeometry.Geometry = Geometry;\n package$typedGeometry.LineString = LineString;\n package$typedGeometry.MultiLineString = MultiLineString;\n package$typedGeometry.MultiPoint = MultiPoint;\n package$typedGeometry.MultiPolygon = MultiPolygon;\n package$typedGeometry.Polygon = Polygon;\n package$typedGeometry.Rect_init_94ua8u$ = Rect_init;\n package$typedGeometry.Rect = Rect;\n package$typedGeometry.Ring = Ring;\n package$typedGeometry.Scalar = Scalar;\n package$typedGeometry.Vec_init_vrm8gm$ = Vec_init;\n package$typedGeometry.Vec = Vec;\n package$typedGeometry.explicitVec_y7b45i$ = explicitVec;\n package$typedGeometry.explicitVec_vrm8gm$ = explicitVec_0;\n package$typedGeometry.newVec_4xl464$ = newVec;\n var package$typedKey = package$base.typedKey || (package$base.typedKey = {});\n package$typedKey.TypedKey = TypedKey;\n package$typedKey.TypedKeyHashMap = TypedKeyHashMap;\n var package$unsupported = package$base.unsupported || (package$base.unsupported = {});\n package$unsupported.UNSUPPORTED = UNSUPPORTED;\n package$unsupported.UNSUPPORTED_61zpoe$ = UNSUPPORTED_0;\n Object.defineProperty(Color, 'Companion', {\n get: Color$Companion_getInstance\n });\n var package$values = package$base.values || (package$base.values = {});\n package$values.Color = Color;\n Object.defineProperty(package$values, 'Colors', {\n get: Colors_getInstance\n });\n package$values.toPngDataUri_61zpoe$ = toPngDataUri;\n package$values.Font = Font;\n Object.defineProperty(FontFamily, 'Companion', {\n get: FontFamily$Companion_getInstance\n });\n package$values.FontFamily = FontFamily;\n package$values.HSV = HSV;\n package$values.Interval = Interval;\n package$values.Pair = Pair_0;\n package$values.SomeFig = SomeFig;\n Object.defineProperty(package$logging, 'PortableLogging', {\n get: PortableLogging_getInstance\n });\n SPECIAL_CHARS = mapOf([to(toBoxedChar(34), toBoxedChar(34)), to(toBoxedChar(92), toBoxedChar(92)), to(toBoxedChar(47), toBoxedChar(47)), to(toBoxedChar(98), toBoxedChar(8)), to(toBoxedChar(102), toBoxedChar(12)), to(toBoxedChar(110), toBoxedChar(10)), to(toBoxedChar(114), toBoxedChar(13)), to(toBoxedChar(116), toBoxedChar(9))]);\n var $receiver = until(0, 32);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(toBoxedChar(toChar(item)));\n }\n CONTROL_CHARS = toSet(destination);\n EARTH_RADIUS = 6378137.0;\n MIN_LONGITUDE = -180.0;\n MAX_LONGITUDE = 180.0;\n FULL_LONGITUDE = MAX_LONGITUDE - MIN_LONGITUDE;\n MIN_LATITUDE = -90.0;\n MAX_LATITUDE = 90.0;\n FULL_LATITUDE = MAX_LATITUDE - MIN_LATITUDE;\n EARTH_RECT = Rect_init(MIN_LONGITUDE, MIN_LATITUDE, FULL_LONGITUDE, FULL_LATITUDE);\n BBOX_CALCULATOR = new GeoBoundingBoxCalculator(EARTH_RECT, true, false);\n Kotlin.defineModule('lets-plot-base-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/RegexExtensions.kt?c518","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Duration.kt?57e0","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZone.kt?13d2","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZoneMoscow.kt?b1a5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZones.kt?ba1e","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/collections.kt?4ea3","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Strings.kt?4e99","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/./kotlin-dce-dev/runtime/arrayUtils.kt?7b24","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Sequences.kt?4687","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/regex.kt?0a6a","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/numberConversions.kt?49a1","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/algorithms/Geometry.kt?154f","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/DateLocale.kt?a10a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/Format.kt?9df9","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/Pattern.kt?c190","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Date.kt?9fc3","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/DateTime.kt?dc25","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/DateTimeUtil.kt?83fc","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Instant.kt?6f4e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Month.kt?1b62","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Time.kt?0342","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Char.kt?2197","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/WeekDay.kt?b818","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/DateSpecs.kt?373a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/EnumInfoFactory.kt?12af","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/EnumInfoImpl.kt?8f00","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/Enums.kt?3ae7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Button.kt?49b6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Event.kt?9322","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Key.kt?5df4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyEvent.kt?a294","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyModifiers.kt?456f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStroke.kt?9b43","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStrokeSpec.kt?8979","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStrokeSpecs.kt?1d8b","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/ModifierKey.kt?5f38","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/MouseEvent.kt?c3e5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/MouseEventSpec.kt?debd","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/PointEvent.kt?e6b5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/function/Functions.kt?ee36","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/function/Value.kt?82af","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Preconditions.kt?bbcf","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Strings.kt?0a39","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Throwables.kt?22c6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/ClosedRange.kt?ef02","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Comparables.kt?24be","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/ComparatorOrdering.kt?cccb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Iterables.kt?38e9","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Lists.kt?74b6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Ordering.kt?196f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Sets.kt?cde7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Stack.kt?7183","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/TreeMap.kt?ed91","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleRectangle.kt?a23c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleRectangles.kt?664b","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleSegment.kt?86b1","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleVector.kt?f66d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Rectangle.kt?1f0f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Rectangles.kt?0399","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Segment.kt?6b4a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Vector.kt?ac75","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/jsObject/JsObjectSupport.kt?5591","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentArray.kt?e8fb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentObject.kt?7da5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentPrimitive.kt?5eeb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentValue.kt?f41f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonFormatter.kt?7d5a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonLexer.kt?32db","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Ranges.kt?94da","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonParser.kt?7c06","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonSupport.kt?5348","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/CharCode.kt?1167","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/Utils.kt?4443","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/listMap/ListMap.kt?c0ae","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/logging/PrintlnLogger.kt?4be6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/math/Math.kt?1259","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/numberFormat/NumberFormat.kt?3d91","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/MatchResult.kt?8829","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/ChildList.kt?ce9e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/ChildProperty.kt?3276","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/SimpleComposite.kt?4bce","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/CollectionAdapter.kt?6397","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/CollectionItemEvent.kt?50fe","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/list/AbstractObservableList.kt?327f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/list/ObservableArrayList.kt?a76c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/CompositeEventSource.kt?6ec0","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/EventSources.kt?d63c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/Listeners.kt?7ac5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/MappingEventSource.kt?9f39","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/BaseReadableProperty.kt?978e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/DelayedValueProperty.kt?20a7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/PropertyBinding.kt?d0ae","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/PropertyChangeEvent.kt?6045","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/ValueProperty.kt?f6eb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/random/RandomGaussian.kt?7a79","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/random/RandomString.kt?a4a8","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/CompositeRegistration.kt?86f4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/Registration.kt?6be7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/throwableHandlers/ThrowableHandler.kt?639a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/throwableHandlers/ThrowableHandlers.kt?e111","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoBoundingBoxCalculator.kt?9573","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoJson.kt?9f24","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoRectangle.kt?80a7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Geographic.kt?19e0","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/LongitudeSegment.kt?d739","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/MercatorUtils.kt?d373","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/QuadKey.kt?1597","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Quads.kt?bee8","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/SimpleFeature.kt?4179","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/stringFormat/StringFormat.kt?282d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/AbstractGeometryList.kt?b659","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Algorithms.kt?bf10","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Functions.kt?ae41","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Geometry.kt?29df","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/LineString.kt?4fe4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiLineString.kt?2aba","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiPoint.kt?eb32","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiPolygon.kt?4b65","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Polygon.kt?b466","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Rect.kt?e402","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Ring.kt?5a0e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Scalar.kt?966f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Vec.kt?954a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedKey/TypedKeyHashMap.kt?cbee","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/unsupported/Unsupported.kt?d7bc","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Color.kt?dd42","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Colors.kt?5201","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/DataURI.kt?9e73","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Font.kt?e020","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/FontFamily.kt?bb4d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/HSV.kt?7f7c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Interval.kt?2612","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Pair.kt?014b","webpack://LetsPlot/../base-portable/src/jsMain/kotlin/jetbrains/datalore/base/logging/PortableLogging.kt?0550","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Constants.kt?b916"],"names":[],"mappings":"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IAAA,oB;IAAA,6B;;;EACA,2C;IAAA,oB;IAAA,mC;;;EAGA,0C;IAAA,oB;IAAA,kC;;;EAEA,yC;IAAA,oB;IAAA,iC;;;EAEA,uC;IAAA,oB;IAAA,+B;;;EAEA,oD;IAAA,oB;IAAA,4C;;;EACA,uC;IAAA,oB;IAAA,+B;;;EACA,sC;IAAA,oB;IAAA,8B;;;EACA,8C;IAAA,oB;IAAA,sC;;;EACA,8C;IAAA,oB;IAAA,sC;;;EACA,sC;IAAA,oB;IAAA,8B;;EAQA,6B;IAAA,iC;IACI,qBjB9BoC,WiB8BhB,yBjB9BgB,C;;EiBgCpC,+C;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,6C;IAAA,gD;;IACI,4E;IACA,4E;;;EADA,mD;IAAA,mC;IAAA,2C;;;EACA,mD;IAAA,mC;IAAA,2C;;;;;;;EAFJ,yC;IAAA,6F;;;EAAA,8C;IAAA,a;MAAA,Y;QAAA,gD;MAAA,Y;QAAA,gD;MAAA,sG;;;;wDAKA,yB;IAAsD,gBAAT,gB;IV8wB1C,sB;;MAybS,Q;MAAhB,iD;QAAgB,cAAhB,e;QAAsB,IUvsC2C,OVusC7B,OUvsCgC,OAAH,gBVusC3C,C;UAAwB,qBAAO,O;UAAP,uB;;MAC9C,qBAAO,I;;;IUxsC0C,OV8wBjD,kB;;;;;;;;EUtxBA,yC;IAAA,oB;IAAA,wC;MAAA,uB;KAAA,iC;;;;;;;EApCJ,0B;IAAA,4oB;;;EAAA,+B;IAAA,a;MAAA,wB;QAAA,6C;MAAA,wB;QAAA,6C;MAAA,kB;QAAA,uC;MAAA,kB;QAAA,uC;MAAA,iC;QAAA,sD;MAAA,oB;QAAA,yC;MAAA,uB;QAAA,4C;MAAA,a;QAAA,kC;MAAA,mB;QAAA,wC;MAAA,kB;QAAA,uC;MAAA,iB;QAAA,sC;MAAA,e;QAAA,oC;MAAA,4B;QAAA,iD;MAAA,e;QAAA,oC;MAAA,c;QAAA,mC;MAAA,sB;QAAA,2C;MAAA,sB;QAAA,2C;MAAA,c;QAAA,mC;MAAA,uF;;;;ECEU,kC;IAsLN,4B;IAtLO,c;IAAc,kB;IAAkB,gB;IAenC,iB;;;;SAZA,Y;MACI,qBAAqB,sBAAS,kCAAT,C;MACrB,OAAe,gBAAR,CAAiB,CAAC,iBA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B;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,qC;IAAA,gB;IAAA,6B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,qC;IAAA,gB;IAAA,6B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,sC;IAAA,gB;IAAA,8B;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,kC;IAAA,gB;IAAA,0B;;2BAEA,Y;IACI,OAAO,sB;EACX,C;;;;;;EAjFJ,sB;IAAA,4yD;;;EAAA,2B;IAAA,a;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;M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S,UAAT,CAAqB,qBACpB,EAAO,2BAAP,CACA,EAAI,6BAAJ,CnGquCL,W;QAAhB,OAAgB,cAAhB,C;UAAgB,yB;UmGpuCe,mBnGouCF,OmGpuCE,U;;;QANnB,K;WASA,oB;Q/GLZ,IAAI,C+GMoB,GAAI,kBAAS,YAAT,C/GN5B,C;UACI,gB+GKkD,uD;U/GJlD,MAAM,8BAAyB,SAAQ,WAAjC,C;;QYouCM,U;QAAA,SmG9tCA,GAAI,kBAAS,YAAT,CAAuB,qBnG8tC3B,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UmG7tCe,mBnG6tCF,SmG7tCE,U;;;QAJnB,K;c/GLZ,IAAI,C+GaoB,GAAI,kBAAS,aAAT,C/Gb5B,C;UACI,gB+GYmD,2C;U/GXnD,MAAM,8BAAyB,SAAQ,WAAjC,C;;Q+GaM,kBAAkB,GAAI,kBAAS,aAAT,C;QACtB,QAAM,IAAN,C;eACI,O;YAAmC,gBAAxB,kBAAW,WAAX,C;YpC2DxB,0BoC3DoD,yB;;apC2DpD,YoC3DoD,OpC2DpD,GAAM,SAAN,C;YoC3Da,K;eACA,Y;YAA6C,kBAA7B,uBAAgB,WAAhB,C;YpC0D7B,+BoC1D8D,yB;;apC0D9D,YoC1D8D,OpC0D9D,GAAM,WAAN,C;YoC1Da,K;eACA,S;YAAuC,kBAA1B,oBAAa,WAAb,C;YpCyD1B,4BoCzDwD,yB;;apCyDxD,YoCzDwD,OpCyDxD,GAAM,WAAN,C;YoCzDa,K;eACA,Y;YAA6C,kBAA7B,uBAAgB,WAAhB,C;YpCwD7B,+BoCxD8D,yB;;apCwD9D,YoCxD8D,OpCwD9D,GAAM,WAAN,C;YoCxDa,K;eACA,iB;YAAuD,kBAAlC,4BAAqB,WAArB,C;YpCuDlC,oCoCvDwE,yB;;apCuDxE,YoCvDwE,OpCuDxE,GAAM,WAAN,C;YoCvDa,K;eACA,c;YAAiD,kBAA/B,yBAAkB,WAAlB,C;YpCsD/B,iCoCtDkE,yB;;apCsDlE,YoCtDkE,OpCsDlE,GAAM,WAAN,C;YoCtDa,K;kB/GqFyB,MAAM,2BAA8B,C+GpF/C,+BAA4B,I/GoFmB,YAA9B,C;;;Q+GhH3C,K;;EAgCJ,C;0CAEA,qB;IACI,OAAO,YACH,SAAU,mBAAU,CA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EAZnC,8D;ItH0HS,MAAM,2BsH1HP,uBtH0HqC,WAA9B,C;EsH1HkB,C;EACrB,gE;ItHyHH,MAAM,2BsHzHK,4BtHyHyB,WAA9B,C;EsHzHmC,C;EAC5C,gE;ItHwHG,MAAM,2BsHxHD,yBtHwH+B,WAA9B,C;EsHxH0B,C;EAC7B,gE;ItHuHH,MAAM,2BsHvHK,4BtHuHyB,WAA9B,C;EsHvHmC,C;EAC5B,gE;ItHsHb,MAAM,2BsHtHe,iCtHsHe,WAA9B,C;EsHtHkD,C;EACjD,gE;ItHqHP,MAAM,2BsHrHS,8BtHqHqB,WAA9B,C;EsHrHyC,C;;;;;;EAU5F,mD;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,iD;IAAA,oD;;IACI,sF;IACA,kG;IACA,0F;IACA,kG;IACA,8G;IACA,sG;IACA,kH;;;EANA,wD;IAAA,uC;IAAA,gD;;;EACA,8D;IAAA,uC;IAAA,sD;;;EACA,0D;IAAA,uC;IAAA,kD;;;EACA,8D;IAAA,uC;IAAA,sD;;;EACA,oE;IAAA,uC;IAAA,4D;;;EACA,gE;IAAA,uC;IAAA,wD;;;EACA,sE;IAAA,uC;IAAA,8D;;;;;;;EAPJ,6C;IAAA,uY;;;EAAA,kD;IAAA,a;MAAA,a;QAAA,qD;MAAA,mB;QAAA,2D;MAAA,e;QAAA,uD;MAAA,mB;QAAA,2D;MAAA,yB;QAAA,iE;MAAA,qB;QAAA,6D;MAAA,2B;QAAA,mE;MAAA,uG;;;;;;;;;;EA1BJ,qC;IAAA,oC;MAAA,mB;KAAA,6B;;ECAmB,2C;IAwEf,oC;IAvEA,wB;IACA,4B;IAOA,gC;IAW+B,IAAN,I;IARrB,yD;IAQqB,QAAM,eAAN,M;WACjB,e;QAA4B,gBAAO,iBAAiB,cAAjB,CAAP,C;QAA5B,K;WACA,e;QAUS,gBAPA,IADA,IADL,mDAAa,iBAAQ,cAAR,CACR,EAAI,wBAAJ,CACA,EAAI,4CAAJ,CAOA,C;QAVT,K;;QAFiB,K;;IAArB,gC;IAiBJ,kBAAiB,yBAAmB,K;;EAjCpC,gD;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,8C;IAAA,iD;;IACI,gG;IACA,gG;;;EADA,6D;IAAA,oC;IAAA,qD;;;EACA,6D;IAAA,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","file":"./kotlin-dce-dev/lets-plot-base-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n/**\n * Converts the string into a regular expression [Regex] with the default options.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(): Regex = Regex(this)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified single [option].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(option: RegexOption): Regex = Regex(this, option)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified set of [options].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(options: Set<RegexOption>): Regex = Regex(this, options)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nclass Duration(val duration: Long) : Comparable<Duration> {\n\n    val isPositive: Boolean\n        get() = duration > 0\n\n    fun mul(times: Long): Duration {\n        return Duration(duration * times)\n    }\n\n    fun add(duration: Duration): Duration {\n        return Duration(this.duration + duration.duration)\n    }\n\n    fun sub(duration: Duration): Duration {\n        return Duration(this.duration - duration.duration)\n    }\n\n    operator fun div(duration: Duration): Double {\n        return this.duration / duration.duration.toDouble()\n    }\n\n    override fun compareTo(other: Duration): Int {\n        val delta = duration - other.duration\n        return if (delta > 0) {\n            1\n        } else if (delta == 0L) {\n            0\n        } else {\n            -1\n        }\n    }\n\n    override fun hashCode(): Int {\n        return duration.toInt()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Duration) false else duration == other.duration\n\n    }\n\n    override fun toString(): String {\n        return \"Duration : \" + duration + \"ms\"\n    }\n\n    companion object {\n        val MS = Duration(1)\n        val SECOND = MS.mul(1000)\n        val MINUTE = SECOND.mul(60)\n        val HOUR = MINUTE.mul(60)\n        val DAY = HOUR.mul(24)\n        val WEEK = DAY.mul(7)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\nabstract class TimeZone protected constructor(val id: String?) {\n\n    init {\n//        if (id != null) {\n//            ourTimeZones.put(id, this)\n//        }\n    }\n\n    abstract fun toDateTime(instant: Instant): DateTime\n    abstract fun toInstant(dateTime: DateTime): Instant\n\n    fun convertTo(toConvert: DateTime, to: TimeZone): DateTime {\n        return if (to === this) toConvert else to.toDateTime(toInstant(toConvert))\n    }\n\n    fun convertTimeAtDay(srcTime: Time, dstDate: Date, dstTimeZone: TimeZone): Time {\n        var src = DateTime(dstDate, srcTime)\n        var dst = convertTo(src, dstTimeZone)\n        val dayDiff = dstDate.compareTo(dst.date)\n        if (dayDiff != 0) {\n            val correctedDay = if (dayDiff > 0) dstDate.nextDate() else dstDate.prevDate()\n            src = DateTime(correctedDay, srcTime)\n            dst = convertTo(src, dstTimeZone)\n        }\n        return dst.time\n    }\n\n    fun getTimeZoneShift(instant: Instant): Duration {\n        val utcDateTime = toDateTime(instant)\n        return instant.to(UTC.toInstant(utcDateTime))\n    }\n\n    override fun toString(): String {\n        return id!!\n    }\n\n    companion object {\n//        private val ourTimeZones = TreeMap<String, TimeZone>()\n\n        val UTC = TimeZones.utc()\n        val BERLIN = TimeZones.withEuSummerTime(\"Europe/Berlin\", Duration.HOUR.mul(1))\n        val MOSCOW: TimeZone = TimeZoneMoscow()\n        val NY = TimeZones.withUsSummerTime(\"America/New_York\", Duration.HOUR.mul(-5))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\ninternal class TimeZoneMoscow : TimeZone(ID) {\n    private val myOldOffset = Duration.HOUR.mul(4)\n    private val myNewOffset = Duration.HOUR.mul(3)\n    private val myOldTz = TimeZones.offset(null, myOldOffset, TimeZone.UTC)\n    private val myNewTz = TimeZones.offset(null, myNewOffset, TimeZone.UTC)\n\n    private val myOffsetChangeTime = DateTime(Date(26, Month.OCTOBER, 2014), Time(2, 0))\n    private val myOffsetChangeInstant = myOldTz.toInstant(myOffsetChangeTime)\n\n    override fun toDateTime(instant: Instant): DateTime {\n        return if (instant.compareTo(myOffsetChangeInstant) >= 0) myNewTz.toDateTime(instant) else myOldTz.toDateTime(instant)\n    }\n\n    override fun toInstant(dateTime: DateTime): Instant {\n        return if (dateTime.compareTo(myOffsetChangeTime) >= 0) myNewTz.toInstant(dateTime) else myOldTz.toInstant(dateTime)\n    }\n\n    companion object {\n        private val ID = \"Europe/Moscow\"\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\ninternal object TimeZones {\n    private const val MILLIS_IN_SECOND: Long = 1000\n    private const val MILLIS_IN_MINUTE = MILLIS_IN_SECOND * 60\n    private const val MILLIS_IN_HOUR = MILLIS_IN_MINUTE * 60\n    private const val MILLIS_IN_DAY = MILLIS_IN_HOUR * 24\n\n    private fun toDateTime(instant: Instant, offset: Duration): DateTime {\n        @Suppress(\"NAME_SHADOWING\")\n        var instant = instant\n        instant = instant.add(offset)\n\n        val days = (instant.timeSinceEpoch / MILLIS_IN_DAY).toInt()\n        val date = Date.EPOCH.addDays(days)\n        var rest = instant.timeSinceEpoch % MILLIS_IN_DAY\n        val hour = (rest / MILLIS_IN_HOUR).toInt()\n        rest %= MILLIS_IN_HOUR\n        val minutes = (rest / MILLIS_IN_MINUTE).toInt()\n        rest %= MILLIS_IN_MINUTE\n        val seconds = (rest / MILLIS_IN_SECOND).toInt()\n        rest %= MILLIS_IN_SECOND\n        val milliseconds = (rest % MILLIS_IN_SECOND).toInt()\n        return DateTime(date, Time(hour, minutes, seconds, milliseconds))\n    }\n\n    private fun toInstant(dateTime: DateTime, offset: Duration): Instant {\n        return Instant(toMillis(dateTime.date) + toMillis(dateTime.time)).sub(offset)\n    }\n\n    private fun toMillis(time: Time): Long {\n        val minutes = time.hours * 60L + time.minutes\n        val seconds = minutes * 60 + time.seconds\n        return seconds * 1000 + time.milliseconds\n    }\n\n    private fun toMillis(date: Date): Long {\n        return date.daysFrom(Date.EPOCH) * MILLIS_IN_DAY\n    }\n\n    fun utc(): TimeZone {\n        return object : TimeZone(\"UTC\") {\n            override fun toDateTime(instant: Instant): DateTime {\n                return toDateTime(instant, Duration(0))\n            }\n\n            override fun toInstant(dateTime: DateTime): Instant {\n                return toInstant(dateTime, Duration(0))\n            }\n        }\n    }\n\n    fun offset(id: String?, offset: Duration, base: TimeZone): TimeZone {\n        return object : TimeZone(id) {\n            override fun toDateTime(instant: Instant): DateTime {\n                return base.toDateTime(instant.add(offset))\n            }\n\n            override fun toInstant(dateTime: DateTime): Instant {\n                return base.toInstant(dateTime).sub(offset)\n            }\n\n        }\n    }\n\n    fun withEuSummerTime(id: String, offset: Duration): TimeZone {\n        val startSpec = DateSpecs.last(WeekDay.SUNDAY, Month.MARCH)\n        val endSpec = DateSpecs.last(WeekDay.SUNDAY, Month.OCTOBER)\n        val utcChangeTime = Time(1, 0)\n        return object : DSTimeZone(id, offset) {\n            override fun getStartInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(startSpec.getDate(year), utcChangeTime))\n            }\n\n            override fun getEndInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(endSpec.getDate(year), utcChangeTime))\n            }\n\n        }\n    }\n\n    fun withUsSummerTime(id: String, offset: Duration): TimeZone {\n        val startSpec = DateSpecs.first(WeekDay.SUNDAY, Month.MARCH, 2)\n        val endSpec = DateSpecs.first(WeekDay.SUNDAY, Month.NOVEMBER)\n\n        return object : DSTimeZone(id, offset) {\n            override fun getStartInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(startSpec.getDate(year), Time(2, 0))).sub(offset)\n            }\n\n            override fun getEndInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(endSpec.getDate(year), Time(2, 0))).sub(offset.add(Duration.HOUR))\n            }\n\n        }\n    }\n\n    private abstract class DSTimeZone(id: String, offset: Duration) : TimeZone(id) {\n        private val myTz: TimeZone = offset(null, offset, UTC)\n        private val mySummerTz: TimeZone = offset(null, offset.add(Duration.HOUR), UTC)\n\n        override fun toDateTime(instant: Instant): DateTime {\n            val tzDt = myTz.toDateTime(instant)\n            val start = getStartInstant(tzDt.year)\n            val end = getEndInstant(tzDt.year)\n            return if (instant > start && instant < end) {\n                mySummerTz.toDateTime(instant)\n            } else {\n                tzDt\n            }\n        }\n\n        override fun toInstant(dateTime: DateTime): Instant {\n            val startDt = toDateTime(getStartInstant(dateTime.year))\n            val endDt = toDateTime(getEndInstant(dateTime.year))\n\n            return if (dateTime > startDt && dateTime < endDt) {\n                mySummerTz.toInstant(dateTime)\n            } else {\n                myTz.toInstant(dateTime)\n            }\n        }\n\n        protected abstract fun getStartInstant(year: Int): Instant\n\n        protected abstract fun getEndInstant(year: Int): Instant\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\nimport kotlin.comparisons.naturalOrder\nimport kotlin.random.Random\n\n/**\n * Returns the array if it's not `null`, or an empty array otherwise.\n * @sample samples.collections.Arrays.Usage.arrayOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Array<out T>?.orEmpty(): Array<out T> = this ?: emptyArray<T>()\n\n/**\n * Returns a *typed* array containing all of the elements of this collection.\n *\n * Allocates an array of runtime type `T` having its size equal to the size of this collection\n * and populates the array with the elements of this collection.\n * @sample samples.collections.Collections.Collections.collectionToTypedArray\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Collection<T>.toTypedArray(): Array<T> = copyToArray(this)\n\n@JsName(\"copyToArray\")\n@PublishedApi\ninternal fun <T> copyToArray(collection: Collection<T>): Array<T> {\n    return if (collection.asDynamic().toArray !== undefined)\n        collection.asDynamic().toArray().unsafeCast<Array<T>>()\n    else\n        copyToArrayImpl(collection).unsafeCast<Array<T>>()\n}\n\n@JsName(\"copyToArrayImpl\")\ninternal actual fun copyToArrayImpl(collection: Collection<*>): Array<Any?> {\n    val array = emptyArray<Any?>()\n    val iterator = collection.iterator()\n    while (iterator.hasNext())\n        array.asDynamic().push(iterator.next())\n    return array\n}\n\n@JsName(\"copyToExistingArrayImpl\")\ninternal actual fun <T> copyToArrayImpl(collection: Collection<*>, array: Array<T>): Array<T> {\n    if (array.size < collection.size)\n        return copyToArrayImpl(collection).unsafeCast<Array<T>>()\n\n    val iterator = collection.iterator()\n    var index = 0\n    while (iterator.hasNext()) {\n        array[index++] = iterator.next().unsafeCast<T>()\n    }\n    if (index < array.size) {\n        array[index] = null.unsafeCast<T>()\n    }\n    return array\n}\n\n\n/**\n * Returns an immutable list containing only the specified object [element].\n */\npublic fun <T> listOf(element: T): List<T> = arrayListOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E> {\n    return ArrayList<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E> {\n    checkBuilderCapacity(capacity)\n    return ArrayList<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable set containing only the specified object [element].\n */\npublic fun <T> setOf(element: T): Set<T> = hashSetOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable map, mapping only the specified key to the\n * specified value.\n */\npublic fun <K, V> mapOf(pair: Pair<K, V>): Map<K, V> = hashMapOf(pair)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Fills the list with the provided [value].\n *\n * Each element in the list gets replaced with the [value].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.fill(value: T): Unit {\n    for (index in 0..lastIndex) {\n        this[index] = value\n    }\n}\n\n/**\n * Randomly shuffles elements in this list.\n *\n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.shuffle(): Unit = shuffle(Random)\n\n/**\n * Returns a new list with the elements of this list randomly shuffled.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> Iterable<T>.shuffled(): List<T> = toMutableList().apply { shuffle() }\n\n/**\n * Sorts elements in the list in-place according to their natural sort order.\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableList\n */\npublic actual fun <T : Comparable<T>> MutableList<T>.sort(): Unit {\n    collectionsSort(this, naturalOrder())\n}\n\n/**\n * Sorts elements in the list in-place according to the order specified with [comparator].\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableListWith\n */\npublic actual fun <T> MutableList<T>.sortWith(comparator: Comparator<in T>): Unit {\n    collectionsSort(this, comparator)\n}\n\nprivate fun <T> collectionsSort(list: MutableList<T>, comparator: Comparator<in T>) {\n    if (list.size <= 1) return\n\n    val array = copyToArray(list)\n    sortArrayWith(array, comparator)\n\n    for (i in 0 until array.size) {\n        list[i] = array[i]\n    }\n}\n\ninternal actual fun <T> arrayOfNulls(reference: Array<T>, size: Int): Array<T> {\n    return arrayOfNulls<Any>(size).unsafeCast<Array<T>>()\n}\n\n@SinceKotlin(\"1.3\")\n@PublishedApi\n@JsName(\"arrayCopy\")\ninternal fun <T> arrayCopy(source: Array<out T>, destination: Array<in T>, destinationOffset: Int, startIndex: Int, endIndex: Int) {\n    AbstractList.checkRangeIndexes(startIndex, endIndex, source.size)\n    val rangeSize = endIndex - startIndex\n    AbstractList.checkRangeIndexes(destinationOffset, destinationOffset + rangeSize, destination.size)\n\n    if (js(\"ArrayBuffer\").isView(destination) && js(\"ArrayBuffer\").isView(source)) {\n        val subrange = source.asDynamic().subarray(startIndex, endIndex)\n        destination.asDynamic().set(subrange, destinationOffset)\n    } else {\n        if (source !== destination || destinationOffset <= startIndex) {\n            for (index in 0 until rangeSize) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        } else {\n            for (index in rangeSize - 1 downTo 0) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        }\n    }\n}\n\n// no singleton map implementation in js, return map as is\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<K, V>.toSingletonMapOrSelf(): Map<K, V> = this\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<out K, V>.toSingletonMap(): Map<K, V> = this.toMutableMap()\n\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <T> Array<out T>.copyToArrayOfAny(isVarargs: Boolean): Array<out Any?> =\n    if (isVarargs)\n    // no need to copy vararg array in JS\n        this\n    else\n        this.copyOf()\n\n\n\n@PublishedApi\ninternal actual fun checkIndexOverflow(index: Int): Int {\n    if (index < 0) {\n        throwIndexOverflow()\n    }\n    return index\n}\n\n@PublishedApi\ninternal actual fun checkCountOverflow(count: Int): Int {\n    if (count < 0) {\n        throwCountOverflow()\n    }\n    return count\n}\n\n\n/**\n * JS map and set implementations do not make use of capacities or load factors.\n */\n@PublishedApi\ninternal actual fun mapCapacity(expectedSize: Int) = expectedSize\n\n/**\n * Checks a collection builder function capacity argument.\n * In JS no validation is made in Map/Set constructor yet.\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@PublishedApi\ninternal fun checkBuilderCapacity(capacity: Int) {\n    require(capacity >= 0) { \"capacity must be non-negative.\" }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns a character at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharSequence.elementAt(index: Int): Char\n\n/**\n * Returns a character at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns a character at the given [index] or `null` if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first character.\n * @throws [NoSuchElementException] if the char sequence is empty.\n */\npublic fun CharSequence.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first character matching the given [predicate].\n * @throws [NoSuchElementException] if no such character is found.\n */\npublic inline fun CharSequence.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to characters of this char sequence in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <R : Any> CharSequence.firstNotNullOf(transform: (Char) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the char sequence was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to characters of this char sequence in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <R : Any> CharSequence.firstNotNullOfOrNull(transform: (Char) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first character, or `null` if the char sequence is empty.\n */\npublic fun CharSequence.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first character matching the given [predicate], or `null` if character was not found.\n */\npublic inline fun CharSequence.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns a character at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this char sequence.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns a character at the given [index] or `null` if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharSequence.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns index of the first character matching the given [predicate], or -1 if the char sequence does not contain such character.\n */\npublic inline fun CharSequence.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last character matching the given [predicate], or -1 if the char sequence does not contain such character.\n */\npublic inline fun CharSequence.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last character.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n * \n * @sample samples.text.Strings.last\n */\npublic fun CharSequence.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last character matching the given [predicate].\n * \n * @throws NoSuchElementException if no such character is found.\n * \n * @sample samples.text.Strings.last\n */\npublic inline fun CharSequence.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n}\n\n/**\n * Returns the last character, or `null` if the char sequence is empty.\n * \n * @sample samples.text.Strings.last\n */\npublic fun CharSequence.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[length - 1]\n}\n\n/**\n * Returns the last character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.text.Strings.last\n */\npublic inline fun CharSequence.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random character from this char sequence.\n * \n * @throws NoSuchElementException if this char sequence is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random character from this char sequence using the specified source of randomness.\n * \n * @throws NoSuchElementException if this char sequence is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharSequence.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return get(random.nextInt(length))\n}\n\n/**\n * Returns a random character from this char sequence, or `null` if this char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random character from this char sequence using the specified source of randomness, or `null` if this char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharSequence.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(length))\n}\n\n/**\n * Returns the single character, or throws an exception if the char sequence is empty or has more than one character.\n */\npublic fun CharSequence.single(): Char {\n    return when (length) {\n        0 -> throw NoSuchElementException(\"Char sequence is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Char sequence has more than one element.\")\n    }\n}\n\n/**\n * Returns the single character matching the given [predicate], or throws exception if there is no or more than one matching character.\n */\npublic inline fun CharSequence.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Char sequence contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single character, or `null` if the char sequence is empty or has more than one character.\n */\npublic fun CharSequence.singleOrNull(): Char? {\n    return if (length == 1) this[0] else null\n}\n\n/**\n * Returns the single character matching the given [predicate], or `null` if character was not found or more than one character was found.\n */\npublic inline fun CharSequence.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a subsequence of this char sequence with the first [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun CharSequence.drop(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return subSequence(n.coerceAtMost(length), length)\n}\n\n/**\n * Returns a string with the first [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun String.drop(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return substring(n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence with the last [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun CharSequence.dropLast(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return take((length - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a string with the last [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun String.dropLast(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return take((length - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a subsequence of this char sequence containing all characters except last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun CharSequence.dropLastWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in lastIndex downTo 0)\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n    return \"\"\n}\n\n/**\n * Returns a string containing all characters except last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun String.dropLastWhile(predicate: (Char) -> Boolean): String {\n    for (index in lastIndex downTo 0)\n        if (!predicate(this[index]))\n            return substring(0, index + 1)\n    return \"\"\n}\n\n/**\n * Returns a subsequence of this char sequence containing all characters except first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun CharSequence.dropWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n    return \"\"\n}\n\n/**\n * Returns a string containing all characters except first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun String.dropWhile(predicate: (Char) -> Boolean): String {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return substring(index)\n    return \"\"\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that match the given [predicate].\n * \n * @sample samples.text.Strings.filter\n */\npublic inline fun CharSequence.filter(predicate: (Char) -> Boolean): CharSequence {\n    return filterTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that match the given [predicate].\n * \n * @sample samples.text.Strings.filter\n */\npublic inline fun String.filter(predicate: (Char) -> Boolean): String {\n    return filterTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that match the given [predicate].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharSequence.filterIndexed(predicate: (index: Int, Char) -> Boolean): CharSequence {\n    return filterIndexedTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that match the given [predicate].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun String.filterIndexed(predicate: (index: Int, Char) -> Boolean): String {\n    return filterIndexedTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Appends all characters matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : Appendable> CharSequence.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.append(element)\n    }\n    return destination\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that do not match the given [predicate].\n * \n * @sample samples.text.Strings.filterNot\n */\npublic inline fun CharSequence.filterNot(predicate: (Char) -> Boolean): CharSequence {\n    return filterNotTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that do not match the given [predicate].\n * \n * @sample samples.text.Strings.filterNot\n */\npublic inline fun String.filterNot(predicate: (Char) -> Boolean): String {\n    return filterNotTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Appends all characters not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : Appendable> CharSequence.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.append(element)\n    return destination\n}\n\n/**\n * Appends all characters matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : Appendable> CharSequence.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (index in 0 until length) {\n        val element = get(index)\n        if (predicate(element)) destination.append(element)\n    }\n    return destination\n}\n\n/**\n * Returns a char sequence containing characters of the original char sequence at the specified range of [indices].\n */\npublic fun CharSequence.slice(indices: IntRange): CharSequence {\n    if (indices.isEmpty()) return \"\"\n    return subSequence(indices)\n}\n\n/**\n * Returns a string containing characters of the original string at the specified range of [indices].\n */\npublic fun String.slice(indices: IntRange): String {\n    if (indices.isEmpty()) return \"\"\n    return substring(indices)\n}\n\n/**\n * Returns a char sequence containing characters of the original char sequence at specified [indices].\n */\npublic fun CharSequence.slice(indices: Iterable<Int>): CharSequence {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return \"\"\n    val result = StringBuilder(size)\n    for (i in indices) {\n        result.append(get(i))\n    }\n    return result\n}\n\n/**\n * Returns a string containing characters of the original string at specified [indices].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.slice(indices: Iterable<Int>): String {\n    return (this as CharSequence).slice(indices).toString()\n}\n\n/**\n * Returns a subsequence of this char sequence containing the first [n] characters from this char sequence, or the entire char sequence if this char sequence is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun CharSequence.take(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return subSequence(0, n.coerceAtMost(length))\n}\n\n/**\n * Returns a string containing the first [n] characters from this string, or the entire string if this string is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun String.take(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return substring(0, n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence containing the last [n] characters from this char sequence, or the entire char sequence if this char sequence is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun CharSequence.takeLast(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    val length = length\n    return subSequence(length - n.coerceAtMost(length), length)\n}\n\n/**\n * Returns a string containing the last [n] characters from this string, or the entire string if this string is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun String.takeLast(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    val length = length\n    return substring(length - n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence containing last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun CharSequence.takeLastWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return subSequence(index + 1, length)\n        }\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Returns a string containing last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun String.takeLastWhile(predicate: (Char) -> Boolean): String {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return substring(index + 1)\n        }\n    }\n    return this\n}\n\n/**\n * Returns a subsequence of this char sequence containing the first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun CharSequence.takeWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in 0 until length)\n        if (!predicate(get(index))) {\n            return subSequence(0, index)\n        }\n    return subSequence(0, length)\n}\n\n/**\n * Returns a string containing the first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun String.takeWhile(predicate: (Char) -> Boolean): String {\n    for (index in 0 until length)\n        if (!predicate(get(index))) {\n            return substring(0, index)\n        }\n    return this\n}\n\n/**\n * Returns a char sequence with characters in reversed order.\n */\npublic fun CharSequence.reversed(): CharSequence {\n    return StringBuilder(this).reverse()\n}\n\n/**\n * Returns a string with characters in reversed order.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.reversed(): String {\n    return (this as CharSequence).reversed().toString()\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to characters of the given char sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associate\n */\npublic inline fun <K, V> CharSequence.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the characters from the given char sequence indexed by the key\n * returned from [keySelector] function applied to each character.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateBy\n */\npublic inline fun <K> CharSequence.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to characters of the given char sequence.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateByWithValueTransform\n */\npublic inline fun <K, V> CharSequence.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each character of the given char sequence\n * and value is the character itself.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharSequence.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to characters of the given char sequence.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharSequence.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each character of the given char sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharSequence.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are characters from the given char sequence and values are\n * produced by the [valueSelector] function applied to each character.\n * \n * If any two characters are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <V> CharSequence.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(length.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each character of the given char sequence,\n * where key is the character itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two characters are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.text.Strings.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <V, M : MutableMap<in Char, in V>> CharSequence.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all characters to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharSequence.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all characters.\n */\npublic fun CharSequence.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(length.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all characters.\n */\npublic fun CharSequence.toList(): List<Char> {\n    return when (length) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all characters of this char sequence.\n */\npublic fun CharSequence.toMutableList(): MutableList<Char> {\n    return toCollection(ArrayList<Char>(length))\n}\n\n/**\n * Returns a [Set] of all characters.\n * \n * The returned set preserves the element iteration order of the original char sequence.\n */\npublic fun CharSequence.toSet(): Set<Char> {\n    return when (length) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(length.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each character of original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharSequence.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each character\n * and its index in the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each character\n * and its index in the original char sequence, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each character of original char sequence, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups characters of the original char sequence by the key returned by the given [keySelector] function\n * applied to each character and returns a map where each group key is associated with a list of corresponding characters.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharSequence.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each character of the original char sequence\n * by the key returned by the given [keySelector] function applied to the character\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharSequence.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups characters of the original char sequence by the key returned by the given [keySelector] function\n * applied to each character and puts to the [destination] map each group key associated with a list of corresponding characters.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharSequence.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each character of the original char sequence\n * by the key returned by the given [keySelector] function applied to the character\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharSequence.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a char sequence to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each character.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <K> CharSequence.groupingBy(crossinline keySelector: (Char) -> K): Grouping<Char, K> {\n    return object : Grouping<Char, K> {\n        override fun sourceIterator(): Iterator<Char> = this@groupingBy.iterator()\n        override fun keyOf(element: Char): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each character in the original char sequence.\n * \n * @sample samples.text.Strings.map\n */\npublic inline fun <R> CharSequence.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(length), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each character and its index in the original char sequence.\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R> CharSequence.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(length), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each character and its index in the original char sequence.\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R : Any> CharSequence.mapIndexedNotNull(transform: (index: Int, Char) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each character and its index in the original char sequence\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R : Any, C : MutableCollection<in R>> CharSequence.mapIndexedNotNullTo(destination: C, transform: (index: Int, Char) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each character and its index in the original char sequence\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each character in the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <R : Any> CharSequence.mapNotNull(transform: (Char) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each character in the original char sequence\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <R : Any, C : MutableCollection<in R>> CharSequence.mapNotNullTo(destination: C, transform: (Char) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each character of the original char sequence\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each character of the original char sequence\n * into an [IndexedValue] containing the index of that character and the character itself.\n */\npublic fun CharSequence.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns `true` if all characters match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharSequence.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if char sequence has at least one character.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharSequence.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one character matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharSequence.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the length of this char sequence.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.count(): Int {\n    return length\n}\n\n/**\n * Returns the number of characters matching the given [predicate].\n */\npublic inline fun CharSequence.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes a character and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each character.\n */\npublic inline fun CharSequence.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each character, providing sequential index with the character.\n * @param [action] function that takes the index of a character and the character itself\n * and performs the action on the character.\n */\npublic inline fun CharSequence.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharSequence.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first character yielding the largest value of the given function or `null` if there are no characters.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharSequence.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest character or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first character having the largest value according to the provided [comparator] or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharSequence.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first character yielding the smallest value of the given function or `null` if there are no characters.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharSequence.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest character or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first character having the smallest value according to the provided [comparator] or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the char sequence has no characters.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharSequence.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no characters match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharSequence.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each character and returns the char sequence itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <S : CharSequence> S.onEach(action: (Char) -> Unit): S {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each character, providing sequential index with the character,\n * and returns the char sequence itself afterwards.\n * @param [action] function that takes the index of a character and the character itself\n * and performs the action on the character.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S : CharSequence> S.onEachIndexed(action: (index: Int, Char) -> Unit): S {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and a character,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharSequence.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value and the character itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharSequence.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value and the character itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and a character,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharSequence.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes a character and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharSequence.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharSequence.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes a character and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharSequence.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R> CharSequence.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(length + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R> CharSequence.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(length + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with the first character of this char sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(length).apply { add(accumulator) }\n    for (index in 1 until length) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with the first character of this char sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(length).apply { add(accumulator) }\n    for (index in 1 until length) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <R> CharSequence.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <R> CharSequence.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharSequence.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharSequence.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Splits this char sequence into a list of strings each not exceeding the given [size].\n * \n * The last string in the resulting list may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each string, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.chunked(size: Int): List<String> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this char sequence into several char sequences each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each char sequence.\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last char sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each char sequence, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.chunked(size: Int, transform: (CharSequence) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Splits this char sequence into a sequence of strings each not exceeding the given [size].\n * \n * The last string in the resulting sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each string, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.chunkedSequence(size: Int): Sequence<String> {\n    return chunkedSequence(size) { it.toString() }\n}\n\n/**\n * Splits this char sequence into several char sequences each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return sequence of results of the [transform] applied to an each char sequence.\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last char sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each char sequence, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunkedTransformToSequence\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.chunkedSequence(size: Int, transform: (CharSequence) -> R): Sequence<R> {\n    return windowedSequence(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Splits the original char sequence into pair of char sequences,\n * where *first* char sequence contains characters for which [predicate] yielded `true`,\n * while *second* char sequence contains characters for which [predicate] yielded `false`.\n * \n * @sample samples.text.Strings.partition\n */\npublic inline fun CharSequence.partition(predicate: (Char) -> Boolean): Pair<CharSequence, CharSequence> {\n    val first = StringBuilder()\n    val second = StringBuilder()\n    for (element in this) {\n        if (predicate(element)) {\n            first.append(element)\n        } else {\n            second.append(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original string into pair of strings,\n * where *first* string contains characters for which [predicate] yielded `true`,\n * while *second* string contains characters for which [predicate] yielded `false`.\n * \n * @sample samples.text.Strings.partition\n */\npublic inline fun String.partition(predicate: (Char) -> Boolean): Pair<String, String> {\n    val first = StringBuilder()\n    val second = StringBuilder()\n    for (element in this) {\n        if (predicate(element)) {\n            first.append(element)\n        } else {\n            second.append(element)\n        }\n    }\n    return Pair(first.toString(), second.toString())\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this char sequence with the given [step], where each\n * snapshot is a string.\n * \n * Several last strings may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<String> {\n    return windowed(size, step, partialWindows) { it.toString() }\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each char sequence representing a view over the window of the given [size]\n * sliding along this char sequence with the given [step].\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last char sequences may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (CharSequence) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    val thisSize = this.length\n    val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n    val result = ArrayList<R>(resultCapacity)\n    var index = 0\n    while (index in 0 until thisSize) {\n        val end = index + size\n        val coercedEnd = if (end < 0 || end > thisSize) { if (partialWindows) thisSize else break } else end\n        result.add(transform(subSequence(index, coercedEnd)))\n        index += step\n    }\n    return result\n}\n\n/**\n * Returns a sequence of snapshots of the window of the given [size]\n * sliding along this char sequence with the given [step], where each\n * snapshot is a string.\n * \n * Several last strings may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.windowedSequence(size: Int, step: Int = 1, partialWindows: Boolean = false): Sequence<String> {\n    return windowedSequence(size, step, partialWindows) { it.toString() }\n}\n\n/**\n * Returns a sequence of results of applying the given [transform] function to\n * an each char sequence representing a view over the window of the given [size]\n * sliding along this char sequence with the given [step].\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last char sequences may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.windowedSequence(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (CharSequence) -> R): Sequence<R> {\n    checkWindowSizeStep(size, step)\n    val windows = (if (partialWindows) indices else 0 until length - size + 1) step step\n    return windows.asSequence().map { index ->\n        val end = index + size\n        val coercedEnd = if (end < 0 || end > length) length else end\n        transform(subSequence(index, coercedEnd))\n    }\n}\n\n/**\n * Returns a list of pairs built from the characters of `this` and the [other] char sequences with the same index\n * The returned list has length of the shortest char sequence.\n * \n * @sample samples.text.Strings.zip\n */\npublic infix fun CharSequence.zip(other: CharSequence): List<Pair<Char, Char>> {\n    return zip(other) { c1, c2 -> c1 to c2 }\n}\n\n/**\n * Returns a list of values built from the characters of `this` and the [other] char sequences with the same index\n * using the provided [transform] function applied to each pair of characters.\n * The returned list has length of the shortest char sequence.\n * \n * @sample samples.text.Strings.zipWithTransform\n */\npublic inline fun <V> CharSequence.zip(other: CharSequence, transform: (a: Char, b: Char) -> V): List<V> {\n    val length = minOf(this.length, other.length)\n    val list = ArrayList<V>(length)\n    for (i in 0 until length) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent characters in this char sequence.\n * \n * The returned list is empty if this char sequence contains less than two characters.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.zipWithNext(): List<Pair<Char, Char>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent characters in this char sequence.\n * \n * The returned list is empty if this char sequence contains less than two characters.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <R> CharSequence.zipWithNext(transform: (a: Char, b: Char) -> R): List<R> {\n    val size = length - 1\n    if (size < 1) return emptyList()\n    val result = ArrayList<R>(size)\n    for (index in 0 until size) {\n        result.add(transform(this[index], this[index + 1]))\n    }\n    return result\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original char sequence returning its characters when being iterated.\n */\npublic fun CharSequence.asIterable(): Iterable<Char> {\n    if (this is String && isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original char sequence returning its characters when being iterated.\n */\npublic fun CharSequence.asSequence(): Sequence<Char> {\n    if (this is String && isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n// a package is omitted to get declarations directly under the module\n\n@PublishedApi\nexternal internal fun <T> Array(size: Int): Array<T>\n\n@JsName(\"newArray\")\nfun <T> newArray(size: Int, initValue: T) = fillArrayVal(Array<T>(size), initValue)\n\n@JsName(\"newArrayF\")\ninline fun <T> arrayWithFun(size: Int, init: (Int) -> T) = fillArrayFun(Array<T>(size), init)\n\n@JsName(\"fillArray\")\ninline fun <T> fillArrayFun(array: Array<T>, init: (Int) -> T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = init(i)\n    }\n    return array\n}\n\n@JsName(\"booleanArray\")\nfun booleanArray(size: Int, init: dynamic): Array<Boolean> {\n    val result: dynamic = Array<Boolean>(size)\n    result.`$type$` = \"BooleanArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, false)\n        false -> result\n        else -> fillArrayFun<Boolean>(result, init)\n    }\n}\n\n@JsName(\"booleanArrayF\")\ninline fun booleanArrayWithFun(size: Int, init: (Int) -> Boolean): Array<Boolean> = fillArrayFun(booleanArray(size, false), init)\n\n@JsName(\"charArray\")\n@Suppress(\"UNUSED_PARAMETER\")\nfun charArray(size: Int, init: dynamic): Array<Char> {\n    val result = js(\"new Uint16Array(size)\")\n    result.`$type$` = \"CharArray\"\n    return when (init) {\n        null, true, false -> result // For consistency\n        else -> fillArrayFun<Char>(result, init)\n    }\n}\n\n@JsName(\"charArrayF\")\ninline fun charArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = charArray(size, null)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"untypedCharArrayF\")\ninline fun untypedCharArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = Array<Char>(size)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"longArray\")\nfun longArray(size: Int, init: dynamic): Array<Long> {\n    val result: dynamic = Array<Long>(size)\n    result.`$type$` = \"LongArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, 0L)\n        false -> result\n        else -> fillArrayFun<Long>(result, init)\n    }\n}\n\n@JsName(\"longArrayF\")\ninline fun longArrayWithFun(size: Int, init: (Int) -> Long): Array<Long> = fillArrayFun(longArray(size, false), init)\n\nprivate fun <T> fillArrayVal(array: Array<T>, initValue: T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = initValue\n    }\n    return array\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"SequencesKt\")\n\npackage kotlin.sequences\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns `true` if [element] is found in the sequence.\n *\n * The operation is _terminal_.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Sequence<T>.elementAt(index: Int): T {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Sequence doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Sequence<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Sequence<T>.elementAtOrNull(index: Int): T? {\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the sequence is empty.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.first(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    return iterator.next()\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this sequence in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Sequence<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the sequence was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this sequence in iteration order,\n * or `null` if no non-null value was produced.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Sequence<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the sequence is empty.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.firstOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    return iterator.next()\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns first index of [element], or -1 if the sequence does not contain element.\n *\n * The operation is _terminal_.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.indexOf(element: T): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the sequence does not contain such element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the sequence does not contain such element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns the last element.\n *\n * The operation is _terminal_.\n * \n * @throws NoSuchElementException if the sequence is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Sequence<T>.last(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    var last = iterator.next()\n    while (iterator.hasNext())\n        last = iterator.next()\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Sequence<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns last index of [element], or -1 if the sequence does not contain element.\n *\n * The operation is _terminal_.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.lastIndexOf(element: T): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns the last element, or `null` if the sequence is empty.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Sequence<T>.lastOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    var last = iterator.next()\n    while (iterator.hasNext())\n        last = iterator.next()\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Sequence<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the single element, or throws an exception if the sequence is empty or has more than one element.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.single(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    val single = iterator.next()\n    if (iterator.hasNext())\n        throw IllegalArgumentException(\"Sequence has more than one element.\")\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Sequence contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the sequence is empty or has more than one element.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.singleOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    val single = iterator.next()\n    if (iterator.hasNext())\n        return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a sequence containing all elements except first [n] elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Sequence<T>.drop(n: Int): Sequence<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return when {\n        n == 0 -> this\n        this is DropTakeSequence -> this.drop(n)\n        else -> DropSequence(this, n)\n    }\n}\n\n/**\n * Returns a sequence containing all elements except first elements that satisfy the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Sequence<T>.dropWhile(predicate: (T) -> Boolean): Sequence<T> {\n    return DropWhileSequence(this, predicate)\n}\n\n/**\n * Returns a sequence containing only elements matching the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic fun <T> Sequence<T>.filter(predicate: (T) -> Boolean): Sequence<T> {\n    return FilteringSequence(this, true, predicate)\n}\n\n/**\n * Returns a sequence containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic fun <T> Sequence<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): Sequence<T> {\n    // TODO: Rewrite with generalized MapFilterIndexingSequence\n    return TransformingSequence(FilteringSequence(IndexingSequence(this), true, { predicate(it.index, it.value) }), { it.value })\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a sequence containing all elements that are instances of specified type parameter R.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Sequence<*>.filterIsInstance(): Sequence<@kotlin.internal.NoInfer R> {\n    @Suppress(\"UNCHECKED_CAST\")\n    return filter { it is R } as Sequence<R>\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Sequence<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a sequence containing all elements not matching the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic fun <T> Sequence<T>.filterNot(predicate: (T) -> Boolean): Sequence<T> {\n    return FilteringSequence(this, false, predicate)\n}\n\n/**\n * Returns a sequence containing all elements that are not `null`.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Sequence<T?>.filterNotNull(): Sequence<T> {\n    @Suppress(\"UNCHECKED_CAST\")\n    return filterNot { it == null } as Sequence<T>\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Sequence<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a sequence containing first [n] elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Sequence<T>.take(n: Int): Sequence<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return when {\n        n == 0 -> emptySequence()\n        this is DropTakeSequence -> this.take(n)\n        else -> TakeSequence(this, n)\n    }\n}\n\n/**\n * Returns a sequence containing first elements satisfying the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Sequence<T>.takeWhile(predicate: (T) -> Boolean): Sequence<T> {\n    return TakeWhileSequence(this, predicate)\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T : Comparable<T>> Sequence<T>.sorted(): Sequence<T> {\n    return object : Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val sortedList = this@sorted.toMutableList()\n            sortedList.sort()\n            return sortedList.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Sequence<T>.sortedBy(crossinline selector: (T) -> R?): Sequence<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic inline fun <T, R : Comparable<R>> Sequence<T>.sortedByDescending(crossinline selector: (T) -> R?): Sequence<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T : Comparable<T>> Sequence<T>.sortedDescending(): Sequence<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T> Sequence<T>.sortedWith(comparator: Comparator<in T>): Sequence<T> {\n    return object : Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val sortedList = this@sortedWith.toMutableList()\n            sortedList.sortWith(comparator)\n            return sortedList.iterator()\n        }\n    }\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Sequence<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    return associateTo(LinkedHashMap<K, V>(), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given sequence indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Sequence<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    return associateByTo(LinkedHashMap<K, T>(), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given sequence.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Sequence<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    return associateByTo(LinkedHashMap<K, V>(), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given sequence\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Sequence<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given sequence.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Sequence<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Sequence<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given sequence and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Sequence<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given sequence,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Sequence<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n *\n * The operation is _terminal_.\n */\npublic fun <T, C : MutableCollection<in T>> Sequence<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>())\n}\n\n/**\n * Returns a [List] containing all elements.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toList(): List<T> {\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toMutableList(): MutableList<T> {\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toSet(): Set<T> {\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single sequence of all elements from results of [transform] function being invoked on each element of original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIterable\")\npublic fun <T, R> Sequence<T>.flatMap(transform: (T) -> Iterable<R>): Sequence<R> {\n    return FlatteningSequence(this, transform, Iterable<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements from results of [transform] function being invoked on each element of original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic fun <T, R> Sequence<T>.flatMap(transform: (T) -> Sequence<R>): Sequence<R> {\n    return FlatteningSequence(this, transform, Sequence<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\npublic fun <T, R> Sequence<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): Sequence<R> {\n    return flatMapIndexed(this, transform, Iterable<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\npublic fun <T, R> Sequence<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): Sequence<R> {\n    return flatMapIndexed(this, transform, Sequence<R>::iterator)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIterableTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original sequence by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Sequence<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original sequence\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Sequence<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original sequence by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Sequence<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original sequence\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Sequence<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a sequence to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Sequence<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to each element in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic fun <T, R> Sequence<T>.map(transform: (T) -> R): Sequence<R> {\n    return TransformingSequence(this, transform)\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to each element and its index in the original sequence.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T, R> Sequence<T>.mapIndexed(transform: (index: Int, T) -> R): Sequence<R> {\n    return TransformingIndexedSequence(this, transform)\n}\n\n/**\n * Returns a sequence containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original sequence.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T, R : Any> Sequence<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): Sequence<R> {\n    return TransformingIndexedSequence(this, transform).filterNotNull()\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original sequence\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Sequence<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original sequence\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a sequence containing only the non-null results of applying the given [transform] function\n * to each element in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic fun <T, R : Any> Sequence<T>.mapNotNull(transform: (T) -> R?): Sequence<R> {\n    return TransformingSequence(this, transform).filterNotNull()\n}\n\n/**\n * Applies the given [transform] function to each element in the original sequence\n * and appends only the non-null results to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Sequence<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original sequence\n * and appends the results to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a sequence that wraps each element of the original sequence\n * into an [IndexedValue] containing the index of that element and the element itself.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T> Sequence<T>.withIndex(): Sequence<IndexedValue<T>> {\n    return IndexingSequence(this)\n}\n\n/**\n * Returns a sequence containing only distinct elements from the given sequence.\n * \n * Among equal elements of the given sequence, only the first one will be present in the resulting sequence.\n * The elements in the resulting sequence are in the same order as they were in the source sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Sequence<T>.distinct(): Sequence<T> {\n    return this.distinctBy { it }\n}\n\n/**\n * Returns a sequence containing only elements from the given sequence\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given sequence with equal keys, only the first one will be present in the resulting sequence.\n * The elements in the resulting sequence are in the same order as they were in the source sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T, K> Sequence<T>.distinctBy(selector: (T) -> K): Sequence<T> {\n    return DistinctSequence(this, selector)\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given sequence.\n * \n * The returned set preserves the element iteration order of the original sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toMutableSet(): MutableSet<T> {\n    val set = LinkedHashSet<T>()\n    for (item in this) set.add(item)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Sequence<T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if sequence has at least one element.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Sequence<T>.any(): Boolean {\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Sequence<T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.count(): Int {\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R> Sequence<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Returns the specified [initial] value if the sequence is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R> Sequence<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Sequence<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Sequence<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Sequence<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Sequence<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Sequence<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Sequence<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the sequence has no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Sequence<T>.none(): Boolean {\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Sequence<T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns a sequence which performs the given [action] on each element of the original sequence as they pass through it.\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@SinceKotlin(\"1.1\")\npublic fun <T> Sequence<T>.onEach(action: (T) -> Unit): Sequence<T> {\n    return map {\n        action(it)\n        it\n    }\n}\n\n/**\n * Returns a sequence which performs the given [action] on each element of the original sequence as they pass through it.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.onEachIndexed(action: (index: Int, T) -> Unit): Sequence<T> {\n    return mapIndexed { index, element ->\n        action(index, element)\n        element\n    }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this sequence is empty. If the sequence can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Sequence<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty sequence can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Throws an exception if this sequence is empty. If the sequence can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Sequence<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty sequence can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Returns `null` if the sequence is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Sequence<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Sequence<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic fun <T, R> Sequence<T>.runningFold(initial: R, operation: (acc: R, T) -> R): Sequence<R> {\n    return sequence {\n        yield(initial)\n        var accumulator = initial\n        for (element in this@runningFold) {\n            accumulator = operation(accumulator, element)\n            yield(accumulator)\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic fun <T, R> Sequence<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): Sequence<R> {\n    return sequence {\n        yield(initial)\n        var index = 0\n        var accumulator = initial\n        for (element in this@runningFoldIndexed) {\n            accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n            yield(accumulator)\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <S, T : S> Sequence<T>.runningReduce(operation: (acc: S, T) -> S): Sequence<S> {\n    return sequence {\n        val iterator = iterator()\n        if (iterator.hasNext()) {\n            var accumulator: S = iterator.next()\n            yield(accumulator)\n            while (iterator.hasNext()) {\n                accumulator = operation(accumulator, iterator.next())\n                yield(accumulator)\n            }\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with the first element of this sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic fun <S, T : S> Sequence<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): Sequence<S> {\n    return sequence {\n        val iterator = iterator()\n        if (iterator.hasNext()) {\n            var accumulator: S = iterator.next()\n            yield(accumulator)\n            var index = 1\n            while (iterator.hasNext()) {\n                accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n                yield(accumulator)\n            }\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T, R> Sequence<T>.scan(initial: R, operation: (acc: R, T) -> R): Sequence<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T, R> Sequence<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): Sequence<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Sequence<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Sequence<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T : Any> Sequence<T?>.requireNoNulls(): Sequence<T> {\n    return map { it ?: throw IllegalArgumentException(\"null element found in $this.\") }\n}\n\n/**\n * Splits this sequence into a sequence of lists each not exceeding the given [size].\n * \n * The last list in the resulting sequence may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.chunked(size: Int): Sequence<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this sequence into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return sequence of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.chunked(size: Int, transform: (List<T>) -> R): Sequence<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence without the first occurrence of the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.minus(element: T): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            var removed = false\n            return this@minus.filter { if (!removed && it == element) { removed = true; false } else true }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] array.\n * \n * Note that the source sequence and the array being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Array<out T>): Sequence<T> {\n    if (elements.isEmpty()) return this\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.toHashSet()\n            return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] collection.\n * \n * Note that the source sequence and the collection being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Iterable<T>): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.convertToSetForSetOperation()\n            if (other.isEmpty())\n                return this@minus.iterator()\n            else\n                return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] sequence.\n * \n * Note that the source sequence and the sequence being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The operation is _intermediate_ for this sequence and _terminal_ and _stateful_ for the [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Sequence<T>): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.toHashSet()\n            if (other.isEmpty())\n                return this@minus.iterator()\n            else\n                return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence without the first occurrence of the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minusElement(element: T): Sequence<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original sequence into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Sequences.Transformations.partition\n */\npublic inline fun <T> Sequence<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence and then the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(element: T): Sequence<T> {\n    return sequenceOf(this, sequenceOf(element)).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] array.\n * \n * Note that the source sequence and the array being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Array<out T>): Sequence<T> {\n    return this.plus(elements.asList())\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] collection.\n * \n * Note that the source sequence and the collection being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Iterable<T>): Sequence<T> {\n    return sequenceOf(this, elements.asSequence()).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] sequence.\n * \n * Note that the source sequence and the sequence being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Sequence<T>): Sequence<T> {\n    return sequenceOf(this, elements).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence and then the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.plusElement(element: T): Sequence<T> {\n    return plus(element)\n}\n\n/**\n * Returns a sequence of snapshots of the window of the given [size]\n * sliding along this sequence with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): Sequence<List<T>> {\n    return windowedSequence(size, step, partialWindows, reuseBuffer = false)\n}\n\n/**\n * Returns a sequence of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this sequence with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): Sequence<R> {\n    return windowedSequence(size, step, partialWindows, reuseBuffer = true).map(transform)\n}\n\n/**\n * Returns a sequence of values built from the elements of `this` sequence and the [other] sequence with the same index.\n * The resulting sequence ends as soon as the shortest input sequence ends.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Sequences.Transformations.zip\n */\npublic infix fun <T, R> Sequence<T>.zip(other: Sequence<R>): Sequence<Pair<T, R>> {\n    return MergingSequence(this, other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a sequence of values built from the elements of `this` sequence and the [other] sequence with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The resulting sequence ends as soon as the shortest input sequence ends.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Sequences.Transformations.zipWithTransform\n */\npublic fun <T, R, V> Sequence<T>.zip(other: Sequence<R>, transform: (a: T, b: R) -> V): Sequence<V> {\n    return MergingSequence(this, other, transform)\n}\n\n/**\n * Returns a sequence of pairs of each two adjacent elements in this sequence.\n * \n * The returned sequence is empty if this sequence contains less than two elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.zipWithNext(): Sequence<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this sequence.\n * \n * The returned sequence is empty if this sequence contains less than two elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.zipWithNext(transform: (a: T, b: T) -> R): Sequence<R> {\n    return sequence result@ {\n        val iterator = iterator()\n        if (!iterator.hasNext()) return@result\n        var current = iterator.next()\n        while (iterator.hasNext()) {\n            val next = iterator.next()\n            yield(transform(current, next))\n            current = next\n        }\n    }\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Sequence<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Sequence<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original sequence returning its elements when being iterated.\n */\npublic fun <T> Sequence<T>.asIterable(): Iterable<T> {\n    return Iterable { this.iterator() }\n}\n\n/**\n * Returns this sequence as a [Sequence].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.asSequence(): Sequence<T> {\n    return this\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Sequence<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Sequence<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Sequence<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Sequence<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Sequence<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Sequence<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Sequence<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Sequence<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Sequence<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Sequence<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Sequence<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Sequence<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Provides enumeration values to use to set regular expression options.\n */\npublic actual enum class RegexOption(val value: String) {\n    /** Enables case-insensitive matching. */\n    IGNORE_CASE(\"i\"),\n    /** Enables multiline mode.\n     *\n     * In multiline mode the expressions `^` and `$` match just after or just before,\n     * respectively, a line terminator or the end of the input sequence. */\n    MULTILINE(\"m\")\n}\n\n\n/**\n * Represents the results from a single capturing group within a [MatchResult] of [Regex].\n *\n * @param value The value of captured group.\n */\npublic actual data class MatchGroup(actual val value: String)\n\n\n/**\n * Represents a compiled regular expression.\n * Provides functions to match strings in text with a pattern, replace the found occurrences and split text around matches.\n *\n * For pattern syntax reference see [MDN RegExp](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#Special_characters_meaning_in_regular_expressions)\n * and [http://www.w3schools.com/jsref/jsref_obj_regexp.asp](https://www.w3schools.com/jsref/jsref_obj_regexp.asp).\n *\n * @constructor Creates a regular expression from the specified [pattern] string and the specified set of [options].\n */\npublic actual class Regex actual constructor(pattern: String, options: Set<RegexOption>) {\n\n    /** Creates a regular expression from the specified [pattern] string and the specified single [option].  */\n    public actual constructor(pattern: String, option: RegexOption) : this(pattern, setOf(option))\n\n    /** Creates a regular expression from the specified [pattern] string and the default options.  */\n    public actual constructor(pattern: String) : this(pattern, emptySet())\n\n\n    /** The pattern string of this regular expression. */\n    public actual val pattern: String = pattern\n    /** The set of options that were used to create this regular expression. */\n    public actual val options: Set<RegexOption> = options.toSet()\n    private val nativePattern: RegExp = RegExp(pattern, options.joinToString(separator = \"\", prefix = \"gu\") { it.value })\n\n    /** Indicates whether the regular expression matches the entire [input]. */\n    public actual infix fun matches(input: CharSequence): Boolean {\n        nativePattern.reset()\n        val match = nativePattern.exec(input.toString())\n        return match != null && match.index == 0 && nativePattern.lastIndex == input.length\n    }\n\n    /** Indicates whether the regular expression can find at least one match in the specified [input]. */\n    public actual fun containsMatchIn(input: CharSequence): Boolean {\n        nativePattern.reset()\n        return nativePattern.test(input.toString())\n    }\n\n    /**\n     * Returns the first match of a regular expression in the [input], beginning at the specified [startIndex].\n     *\n     * @param startIndex An index to start search with, by default 0. Must be not less than zero and not greater than `input.length()`\n     * @return An instance of [MatchResult] if match was found or `null` otherwise.\n     * @throws IndexOutOfBoundsException if [startIndex] is less than zero or greater than the length of the [input] char sequence.\n     * @sample samples.text.Regexps.find\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun find(input: CharSequence, startIndex: Int = 0): MatchResult? {\n        if (startIndex < 0 || startIndex > input.length) {\n            throw IndexOutOfBoundsException(\"Start index out of bounds: $startIndex, input length: ${input.length}\")\n        }\n        return nativePattern.findNext(input.toString(), startIndex)\n    }\n\n    /**\n     * Returns a sequence of all occurrences of a regular expression within the [input] string, beginning at the specified [startIndex].\n     *\n     * @throws IndexOutOfBoundsException if [startIndex] is less than zero or greater than the length of the [input] char sequence.\n     *\n     * @sample samples.text.Regexps.findAll\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun findAll(input: CharSequence, startIndex: Int = 0): Sequence<MatchResult> {\n        if (startIndex < 0 || startIndex > input.length) {\n            throw IndexOutOfBoundsException(\"Start index out of bounds: $startIndex, input length: ${input.length}\")\n        }\n        return generateSequence({ find(input, startIndex) }, { match -> match.next() })\n    }\n\n    /**\n     * Attempts to match the entire [input] CharSequence against the pattern.\n     *\n     * @return An instance of [MatchResult] if the entire input matches or `null` otherwise.\n     */\n    public actual fun matchEntire(input: CharSequence): MatchResult? {\n        if (pattern.startsWith('^') && pattern.endsWith('$'))\n            return find(input)\n        else\n            return Regex(\"^${pattern.trimStart('^').trimEnd('$')}$\", options).find(input)\n    }\n\n    /**\n     * Replaces all occurrences of this regular expression in the specified [input] string with specified [replacement] expression.\n     *\n     * @param replacement A replacement expression that can include substitutions. See [String.prototype.replace](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace) function docs for details.\n     */\n    public actual fun replace(input: CharSequence, replacement: String): String = input.toString().nativeReplace(nativePattern, replacement)\n\n    /**\n     * Replaces all occurrences of this regular expression in the specified [input] string with the result of\n     * the given function [transform] that takes [MatchResult] and returns a string to be used as a\n     * replacement for that match.\n     */\n    public actual inline fun replace(input: CharSequence, transform: (MatchResult) -> CharSequence): String {\n        var match = find(input)\n        if (match == null) return input.toString()\n\n        var lastStart = 0\n        val length = input.length\n        val sb = StringBuilder(length)\n        do {\n            val foundMatch = match!!\n            sb.append(input, lastStart, foundMatch.range.start)\n            sb.append(transform(foundMatch))\n            lastStart = foundMatch.range.endInclusive + 1\n            match = foundMatch.next()\n        } while (lastStart < length && match != null)\n\n        if (lastStart < length) {\n            sb.append(input, lastStart, length)\n        }\n\n        return sb.toString()\n    }\n\n    /**\n     * Replaces the first occurrence of this regular expression in the specified [input] string with specified [replacement] expression.\n     *\n     * @param replacement A replacement expression that can include substitutions. See [String.prototype.replace](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace) function docs for details.\n     */\n    public actual fun replaceFirst(input: CharSequence, replacement: String): String {\n        val nonGlobalOptions = options.map { it.value }.joinToString(separator = \"\")\n        return input.toString().nativeReplace(RegExp(pattern, nonGlobalOptions), replacement)\n    }\n\n    /**\n     * Splits the [input] CharSequence around matches of this regular expression.\n     *\n     * @param limit Non-negative value specifying the maximum number of substrings the string can be split to.\n     * Zero by default means no limit is set.\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun split(input: CharSequence, limit: Int = 0): List<String> {\n        require(limit >= 0) { \"Limit must be non-negative, but was $limit\" }\n        val matches = findAll(input).let { if (limit == 0) it else it.take(limit - 1) }\n        val result = mutableListOf<String>()\n        var lastStart = 0\n\n        for (match in matches) {\n            result.add(input.subSequence(lastStart, match.range.start).toString())\n            lastStart = match.range.endInclusive + 1\n        }\n        result.add(input.subSequence(lastStart, input.length).toString())\n        return result\n    }\n\n\n    /**\n     * Returns the string representation of this regular expression, namely the [pattern] of this regular expression.\n     *\n     * Note that another regular expression constructed from the same pattern string may have different [options]\n     * and may match strings differently.\n     */\n    public override fun toString(): String = nativePattern.toString()\n\n    actual companion object {\n        /**\n         * Returns a regular expression that matches the specified [literal] string literally.\n         * No characters of that string will have special meaning when searching for an occurrence of the regular expression.\n         */\n        public actual fun fromLiteral(literal: String): Regex = Regex(escape(literal))\n\n        /**\n         * Returns a regular expression pattern string that matches the specified [literal] string literally.\n         * No characters of that string will have special meaning when searching for an occurrence of the regular expression.\n         */\n        public actual fun escape(literal: String): String = literal.nativeReplace(patternEscape, \"\\\\$&\")\n\n        /**\n         * Returns a literal replacement expression for the specified [literal] string.\n         * No characters of that string will have special meaning when it is used as a replacement string in [Regex.replace] function.\n         */\n        public actual fun escapeReplacement(literal: String): String = literal.nativeReplace(replacementEscape, \"$$$$\")\n\n        private val patternEscape = RegExp(\"\"\"[\\\\^$*+?.()|[\\]{}]\"\"\", \"g\")\n        private val replacementEscape = RegExp(\"\"\"\\$\"\"\", \"g\")\n    }\n}\n\n/** Creates a regular expression from the specified [pattern] string and the specified single [option].  */\n@Deprecated(\"Provided for binary compatibility\", level = DeprecationLevel.HIDDEN)\n@JsName(\"Regex_sb3q2\\$\")\npublic fun Regex_0(pattern: String, option: RegexOption): Regex = Regex(pattern, setOf(option))\n\n/** Creates a regular expression from the specified [pattern] string and the default options.  */\n@Deprecated(\"Provided for binary compatibility\", level = DeprecationLevel.HIDDEN)\n@JsName(\"Regex_61zpoe\\$\")\npublic fun Regex_1(pattern: String): Regex = Regex(pattern, emptySet())\n\n\n\n\nprivate fun RegExp.findNext(input: String, from: Int): MatchResult? {\n    this.lastIndex = from\n    val match = exec(input)\n    if (match == null) return null\n    val range = match.index..lastIndex - 1\n\n    return object : MatchResult {\n        override val range: IntRange = range\n        override val value: String\n            get() = match[0]!!\n\n        override val groups: MatchGroupCollection = object : MatchGroupCollection, AbstractCollection<MatchGroup?>() {\n            override val size: Int get() = match.length\n            override fun iterator(): Iterator<MatchGroup?> = indices.asSequence().map { this[it] }.iterator()\n            override fun get(index: Int): MatchGroup? = match[index]?.let { MatchGroup(it) }\n        }\n\n\n        private var groupValues_: List<String>? = null\n\n        override val groupValues: List<String>\n            get() {\n                if (groupValues_ == null) {\n                    groupValues_ = object : AbstractList<String>() {\n                        override val size: Int get() = match.length\n                        override fun get(index: Int): String = match[index] ?: \"\"\n                    }\n                }\n                return groupValues_!!\n            }\n\n        override fun next(): MatchResult? = this@findNext.findNext(input, if (range.isEmpty()) range.start + 1 else range.endInclusive + 1)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", ignoring case, and `false` otherwise.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toBoolean(): Boolean = this.toBoolean()\n\n/**\n * Returns `true` if this string is not `null` and its content is equal to the word \"true\", ignoring case, and `false` otherwise.\n *\n * There are also strict versions of the function available on non-nullable String, [toBooleanStrict] and [toBooleanStrictOrNull].\n */\n@SinceKotlin(\"1.4\")\npublic actual fun String?.toBoolean(): Boolean = this != null && this.lowercase() == \"true\"\n\n/**\n * Parses the string as a signed [Byte] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toByte(): Byte = toByteOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a signed [Byte] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toByte(radix: Int): Byte = toByteOrNull(radix) ?: numberFormatError(this)\n\n\n/**\n * Parses the string as a [Short] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toShort(): Short = toShortOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Short] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toShort(radix: Int): Short = toShortOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as an [Int] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toInt(): Int = toIntOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as an [Int] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toInt(radix: Int): Int = toIntOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Long] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toLong(): Long = toLongOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Long] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toLong(radix: Int): Long = toLongOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Double] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toDouble(): Double = (+(this.asDynamic())).unsafeCast<Double>().also {\n    if (it.isNaN() && !this.isNaN() || it == 0.0 && this.isBlank())\n        numberFormatError(this)\n}\n\n/**\n * Parses the string as a [Float] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toFloat(): Float = toDouble().unsafeCast<Float>()\n\n/**\n * Parses the string as a [Double] number and returns the result\n * or `null` if the string is not a valid representation of a number.\n */\npublic actual fun String.toDoubleOrNull(): Double? = (+(this.asDynamic())).unsafeCast<Double>().takeIf {\n    !(it.isNaN() && !this.isNaN() || it == 0.0 && this.isBlank())\n}\n\n/**\n * Parses the string as a [Float] number and returns the result\n * or `null` if the string is not a valid representation of a number.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toFloatOrNull(): Float? = toDoubleOrNull().unsafeCast<Float?>()\n\n/**\n * Returns a string representation of this [Byte] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\n@kotlin.internal.InlineOnly\npublic actual inline fun Byte.toString(radix: Int): String = this.toInt().toString(radix)\n\n/**\n * Returns a string representation of this [Short] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\n@kotlin.internal.InlineOnly\npublic actual inline fun Short.toString(radix: Int): String = this.toInt().toString(radix)\n\n/**\n * Returns a string representation of this [Int] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Int.toString(radix: Int): String = asDynamic().toString(checkRadix(radix))\n\nprivate fun String.isNaN(): Boolean = when (this.lowercase()) {\n    \"nan\", \"+nan\", \"-nan\" -> true\n    else -> false\n}\n\n/**\n * Checks whether the given [radix] is valid radix for string to number and number to string conversion.\n */\n@PublishedApi\ninternal actual fun checkRadix(radix: Int): Int {\n    if (radix !in 2..36) {\n        throw IllegalArgumentException(\"radix $radix was not in valid range 2..36\")\n    }\n    return radix\n}\n\ninternal actual fun digitOf(char: Char, radix: Int): Int = when {\n    char >= '0' && char <= '9' -> char - '0'\n    char >= 'A' && char <= 'Z' -> char - 'A' + 10\n    char >= 'a' && char <= 'z' -> char - 'a' + 10\n    char < '\\u0080' -> -1\n    char >= '\\uFF21' && char <= '\\uFF3A' -> char - '\\uFF21' + 10 // full-width latin capital letter\n    char >= '\\uFF41' && char <= '\\uFF5A' -> char - '\\uFF41' + 10 // full-width latin small letter\n    else -> char.digitToIntImpl()\n}.let { if (it >= radix) -1 else it }\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.algorithms\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.math.abs\n\nfun <T> splitRings(points: List<T>): List<List<T>> {\n    val rings = findRingIntervals(points).map { points.sublist(it) }.toMutableList()\n\n    if (rings.isNotEmpty()) {\n        if (!rings.last().isClosed()) {\n            rings.set(rings.lastIndex, makeClosed(rings.last()))\n        }\n    }\n\n    return rings\n}\n\nprivate fun <T> makeClosed(path: List<T>) = path.toMutableList() + path.first()\n\nfun <T> List<T>.isClosed() = first() == last()\n\nprivate fun <T> findRingIntervals(path: List<T>): List<ClosedRange<Int>> {\n    val intervals = ArrayList<ClosedRange<Int>>()\n    var startIndex = 0\n\n    var i = 0\n    val n = path.size\n    while (i < n) {\n        if (startIndex != i && path[startIndex] == path[i]) {\n            intervals.add(ClosedRange(startIndex, i + 1))\n            startIndex = i + 1\n        }\n        i++\n    }\n\n    if (startIndex != path.size) {\n        intervals.add(ClosedRange(startIndex, path.size))\n    }\n    return intervals\n}\n\nprivate fun <T> List<T>.sublist(range: ClosedRange<Int>): List<T> {\n    return this.subList(range.lowerEnd, range.upperEnd)\n}\n\n\nfun calculateArea(ring: List<DoubleVector>): Double {\n    return calculateArea(ring, DoubleVector::x, DoubleVector::y)\n}\n\nfun <T> isClockwise(ring: List<T>, x: (T) -> Double, y: (T) -> Double): Boolean {\n    check(ring.isNotEmpty()) { \"Ring shouldn't be empty to calculate clockwise\" }\n\n    var sum = 0.0\n    var prev = ring[ring.size - 1]\n    for (point in ring) {\n        sum += x(prev) * y(point) - x(point) * y(prev)\n        prev = point\n    }\n    return sum < 0.0\n}\n\nfun <T> calculateArea(ring: List<T>, x: T.() -> Double, y: T.() -> Double): Double {\n    var area = 0.0\n\n    var j = ring.size - 1\n\n    for (i in ring.indices) {\n        val p1 = ring[i]\n        val p2 = ring[j]\n\n        area += (p2.x() + p1.x()) * (p2.y() - p1.y())\n        j = i\n    }\n\n    return abs(area / 2)\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\nimport jetbrains.datalore.base.datetime.Month\nimport jetbrains.datalore.base.datetime.WeekDay\n\nobject DateLocale {\n    val weekDayAbbr = mapOf(\n        WeekDay.MONDAY to \"Mon\",\n        WeekDay.TUESDAY to \"Tue\",\n        WeekDay.WEDNESDAY to \"Wed\",\n        WeekDay.THURSDAY to \"Thu\",\n        WeekDay.FRIDAY to \"Fri\",\n        WeekDay.SATURDAY to \"Sat\",\n        WeekDay.SUNDAY to \"Sun\"\n    )\n\n    val weekDayFull = mapOf(\n        WeekDay.MONDAY to \"Monday\",\n        WeekDay.TUESDAY to \"Tuesday\",\n        WeekDay.WEDNESDAY to \"Wednesday\",\n        WeekDay.THURSDAY to \"Thursday\",\n        WeekDay.FRIDAY to \"Friday\",\n        WeekDay.SATURDAY to \"Saturday\",\n        WeekDay.SUNDAY to \"Sunday\"\n    )\n\n    val monthAbbr = mapOf(\n        Month.JANUARY to \"Jan\",\n        Month.FEBRUARY to \"Feb\",\n        Month.MARCH to \"Mar\",\n        Month.APRIL to \"Apr\",\n        Month.MAY to \"May\",\n        Month.JUNE to \"Jun\",\n        Month.JULY to \"Jul\",\n        Month.AUGUST to \"Aug\",\n        Month.SEPTEMBER to \"Sep\",\n        Month.OCTOBER to \"Oct\",\n        Month.NOVEMBER to \"Nov\",\n        Month.DECEMBER to \"Dec\"\n    )\n\n    val monthFull = mapOf(\n        Month.JANUARY to \"January\",\n        Month.FEBRUARY to \"February\",\n        Month.MARCH to \"March\",\n        Month.APRIL to \"April\",\n        Month.MAY to \"May\",\n        Month.JUNE to \"June\",\n        Month.JULY to \"July\",\n        Month.AUGUST to \"August\",\n        Month.SEPTEMBER to \"September\",\n        Month.OCTOBER to \"October\",\n        Month.NOVEMBER to \"November\",\n        Month.DECEMBER to \"December\"\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\nimport jetbrains.datalore.base.dateFormat.Pattern.Companion.Kind\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Time\n\nclass Format(private val spec: List<SpecPart>) {\n\n    constructor(spec: String): this(parse(spec))\n\n    open class SpecPart(val str: String) {\n        open fun exec(dateTime: DateTime) = str\n    }\n\n    class PatternSpecPart(str: String): SpecPart(str) {\n        val pattern: Pattern = Pattern.patternByString(str) ?: throw IllegalArgumentException(\"Wrong pattern: $str\")\n\n        override fun exec(dateTime: DateTime): String {\n            return getValueForPattern(pattern, dateTime)\n        }\n    }\n\n    fun apply(dateTime: DateTime): String = spec.joinToString(\"\") { it.exec(dateTime) }\n\n    fun apply(date: Date): String =\n        spec\n            .filter {\n                when {\n                    (it is PatternSpecPart && it.pattern.kind == Kind.DATE) -> true\n                    it !is PatternSpecPart -> true\n                    else -> false\n                }\n            }\n            .joinToString(\"\") { it.exec(DateTime(date)) }\n\n    fun apply(time: Time): String =\n        spec\n            .filter {\n                when {\n                    (it is PatternSpecPart && it.pattern.kind == Kind.TIME) -> true\n                    it !is PatternSpecPart -> true\n                    else -> false\n                }\n            }\n            .joinToString(\"\") { it.exec(DateTime(Date.EPOCH, time)) }\n\n    companion object {\n        fun parse(str: String): List<SpecPart> {\n            val result = mutableListOf<SpecPart>()\n            val resultSequence = Pattern.PATTERN_REGEX.findAll(str)\n            var lastIndex = 0\n            resultSequence.forEach {\n                val value = it.value\n                val range = it.range\n                val startIndex = range.first\n                val endIndex = range.last\n                if (startIndex > 0) {\n                    val spec = SpecPart(str.substring(lastIndex until startIndex))\n                    result.add(spec)\n                }\n                result.add(PatternSpecPart(value))\n                lastIndex = endIndex + 1\n            }\n\n            if (lastIndex < str.length) {\n                result.add(SpecPart(str.substring(lastIndex)))\n            }\n\n            return result\n        }\n\n        private fun getValueForPattern(type: Pattern, dateTime: DateTime): String =\n            when(type) {\n                Pattern.SECOND -> leadZero(dateTime.seconds)\n                Pattern.MINUTE -> leadZero(dateTime.minutes)\n                Pattern.HOUR_12 -> getHours12(dateTime).toString()\n                Pattern.HOUR_12_LEADING_ZERO -> leadZero(getHours12(dateTime))\n                Pattern.HOUR_24 -> leadZero(getHours24(dateTime))\n                Pattern.MERIDIAN_LOWER -> getMeridian(dateTime)\n                Pattern.MERIDIAN_UPPER -> getMeridian(dateTime).uppercase()\n                Pattern.DAY_OF_WEEK -> getWeekDayNumber(dateTime)\n                Pattern.DAY_OF_WEEK_ABBR -> DateLocale.weekDayAbbr[dateTime.weekDay] ?: \"\"\n                Pattern.DAY_OF_WEEK_FULL -> DateLocale.weekDayFull[dateTime.weekDay] ?: \"\"\n                Pattern.DAY_OF_MONTH -> dateTime.day.toString()\n                Pattern.DAY_OF_MONTH_LEADING_ZERO -> leadZero(dateTime.day)\n                Pattern.DAY_OF_THE_YEAR -> leadZero(dateTime.date.daysFromYearStart(), 3)\n                Pattern.MONTH -> leadZero((dateTime.month?.ordinal() ?: 0) + 1)\n                Pattern.MONTH_ABBR -> DateLocale.monthAbbr[dateTime.month] ?: \"\"\n                Pattern.MONTH_FULL -> DateLocale.monthFull[dateTime.month] ?: \"\"\n                Pattern.YEAR_SHORT -> dateTime.year.toString().substring(2)\n                Pattern.YEAR_FULL -> dateTime.year.toString()\n            }\n\n        private fun leadZero(value: Int, length: Int = 2): String = value.toString().padStart(length, '0')\n\n        private fun getHours12(dateTime: DateTime): Int {\n            val hours = dateTime.hours\n            return when {\n                hours == 0 -> 12\n                hours <= 12 -> hours\n                else -> hours - 12\n            }\n        }\n\n        private fun getHours24(dateTime: DateTime): Int =\n            when(dateTime.hours) {\n                0 -> 24\n                else -> dateTime.hours\n            }\n\n        private fun getMeridian(dateTime: DateTime): String {\n            val hours = dateTime.hours\n            return when {\n                hours == 24 -> \"am\"\n                hours <= 12 -> \"am\"\n                else -> \"pm\"\n            }\n        }\n\n        private fun getWeekDayNumber(dateTime: DateTime): String {\n            var num = dateTime.weekDay.ordinal + 1\n            if (num == 7) {\n                num = 0\n            }\n            return num.toString()\n        }\n    }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\n/**\n * Pattern for \"strftime\" datetime formatting\n * (https://docs.python.org/3/library/datetime.html#strftime-strptime-behavior, www.strfti.me/)\n */\nenum class Pattern(val string: String, val kind: Kind) {\n    //Date\n    DAY_OF_WEEK_ABBR(\"%a\", Kind.DATE),\n    DAY_OF_WEEK_FULL(\"%A\", Kind.DATE),\n    MONTH_ABBR(\"%b\", Kind.DATE),\n    MONTH_FULL(\"%B\", Kind.DATE),\n    DAY_OF_MONTH_LEADING_ZERO(\"%d\", Kind.DATE),\n    DAY_OF_MONTH(\"%e\", Kind.DATE),\n    DAY_OF_THE_YEAR(\"%j\", Kind.DATE),\n    MONTH(\"%m\", Kind.DATE),\n    //WEEK_NUMBER_FROM_SUNDAY(\"%U\", Kind.DATE),\n    //WEEK_NUMBER_FROM_MONDAY(\"%W\", Kind.DATE),\n    DAY_OF_WEEK(\"%w\", Kind.DATE),\n    //LOCALE_DATE(\"%x\", Kind.DATE),\n    YEAR_SHORT(\"%y\", Kind.DATE),\n    YEAR_FULL(\"%Y\", Kind.DATE),\n\n    //Time\n    HOUR_24(\"%H\", Kind.TIME),\n    HOUR_12_LEADING_ZERO(\"%I\", Kind.TIME),\n    HOUR_12(\"%l\", Kind.TIME),\n    MINUTE(\"%M\", Kind.TIME),\n    MERIDIAN_LOWER(\"%P\", Kind.TIME),\n    MERIDIAN_UPPER(\"%p\", Kind.TIME),\n    SECOND(\"%S\", Kind.TIME);\n    //LOCALE_TIME(\"%X\", Kind.TIME),\n    //TIME_ZONE(\"%Z\", Kind.TIME),\n\n    //Other\n    //LOCALE_DATE_TIME(\"%c\", Kind.OTHER);\n\n\n    companion object {\n        val PATTERN_REGEX = \"(%[aAbBdejmwyYHIlMpPS])\".toRegex()\n        \n        enum class Kind {\n            DATE,\n            TIME\n        }\n\n        fun patternByString(patternString: String) = values().find { it.string == patternString }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport kotlin.jvm.JvmOverloads\n\nclass Date(val day: Int, val month: Month, val year: Int) : Comparable<Date> {\n\n    val weekDay: WeekDay\n        get() {\n            val daysFromOrigin = daysFrom(EPOCH)\n            return WeekDay.values()[(daysFromOrigin + EPOCH_WEEKDAY.ordinal) % WeekDay.values().size]\n        }\n\n    val dateStart: DateTime\n        get() = DateTime(this)\n\n    val dateEnd: DateTime\n        get() = DateTime(this, Time.DAY_END)\n\n    init {\n        validate()\n    }\n\n    private fun validate() {\n        val daysInMonth = month.getDaysInYear(year)\n        val isValid = day in 1..daysInMonth\n\n        if (!isValid) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    fun daysFrom(date: Date): Int {\n        if (compareTo(date) < 0) {\n            throw IllegalArgumentException()\n        }\n\n        var result = 0\n\n        if (year != date.year) {\n            val fromYear = date.year\n            val toYear = year\n            val leapYears = DateTimeUtil.leapYearsBetween(fromYear, toYear)\n            val years = toYear - fromYear\n            result += leapYears * DateTimeUtil.DAYS_IN_LEAP_YEAR + (years - leapYears) * DateTimeUtil.DAYS_IN_YEAR\n        }\n\n        return result + daysFromYearStart() - date.daysFromYearStart()\n    }\n\n    fun daysFromYearStart(): Int {\n        var result = day\n        var current = month.prev()\n        while (current != null) {\n            result += current.getDaysInYear(year)\n            current = current.prev()\n        }\n        return result\n    }\n\n    fun addDays(days: Int): Date {\n        @Suppress(\"NAME_SHADOWING\")\n        var days = days\n        if (days < 0) {\n            throw IllegalArgumentException()\n        }\n        if (days == 0) return this\n\n        var day = this.day\n        var month = this.month\n        var year = this.year\n        var lessThanYear = false\n\n        if (days >= CACHE_DAYS && year == EPOCH.year) {\n            year = CACHE_STAMP.year\n            month = CACHE_STAMP.month\n            day = CACHE_STAMP.day\n            days -= CACHE_DAYS\n        }\n\n        while (days > 0) {\n            val daysToNextMonth = month.getDaysInYear(year) - day + 1\n            if (days < daysToNextMonth) {\n                return Date(day + days, month, year)\n            } else {\n                if (lessThanYear) {\n                    month = month.next()!!\n                    day = 1\n                    days -= daysToNextMonth\n                } else {\n                    val daysToNextYear = lastDayOf(year).daysFrom(Date(day, month, year)) + 1\n                    if (days >= daysToNextYear) {\n                        day = 1\n                        month = Month.JANUARY\n                        year += 1\n                        days -= daysToNextYear\n                    } else {\n                        month = month.next()!!\n                        day = 1\n                        days -= daysToNextMonth\n                        lessThanYear = true\n                    }\n                }\n            }\n        }\n\n        return Date(day, month, year)\n    }\n\n    fun nextDate(): Date {\n        return addDays(1)\n    }\n\n    fun prevDate(): Date {\n        return subtractDays(1)\n    }\n\n    fun subtractDays(days: Int): Date {\n        if (days < 0) {\n            throw IllegalArgumentException()\n        }\n        if (days == 0) return this\n\n        if (days < day) {\n            return Date(day - days, month, year)\n        } else {\n            val daysToPrevYear = daysFrom(firstDayOf(year))\n            return if (days > daysToPrevYear) {\n                lastDayOf(year - 1).subtractDays(days - daysToPrevYear - 1)\n            } else {\n                lastDayOf(year, month.prev()!!).subtractDays(days - day)\n            }\n        }\n    }\n\n    override fun compareTo(other: Date): Int {\n        if (year != other.year) return year - other.year\n        return if (month.ordinal() != other.month.ordinal()) month.ordinal() - other.month.ordinal() else day - other.day\n\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Date) return false\n\n        val date = other as Date?\n        return date!!.year == year &&\n                date.month === month &&\n                date.day == day\n    }\n\n    override fun hashCode(): Int {\n        return year * 239 + month.hashCode() * 31 + day\n    }\n\n    override fun toString(): String {\n        val result = StringBuilder()\n        result.append(year)\n        appendMonth(result)\n        appendDay(result)\n        return result.toString()\n    }\n\n    private fun appendDay(result: StringBuilder) {\n        if (day < 10) {\n            result.append(\"0\")\n        }\n        result.append(day)\n    }\n\n    private fun appendMonth(result: StringBuilder) {\n        val month = this.month.ordinal() + 1\n        if (month < 10) {\n            result.append(\"0\")\n        }\n        result.append(month)\n    }\n\n    fun toPrettyString(): String {\n        val result = StringBuilder()\n        appendDay(result)\n        result.append(\".\")\n        appendMonth(result)\n        result.append(\".\")\n        result.append(year)\n        return result.toString()\n    }\n\n    companion object {\n        val EPOCH = Date(1, Month.JANUARY, 1970)\n        private val EPOCH_WEEKDAY = WeekDay.THURSDAY\n\n        private val CACHE_STAMP = Date(1, Month.JANUARY, 2012)\n        private val CACHE_DAYS = CACHE_STAMP.daysFrom(EPOCH)\n\n        fun parse(str: String): Date {\n            if (str.length != 8) {\n                throw RuntimeException()\n            }\n\n            val year = str.substring(0, 4).toInt()\n            val month = str.substring(4, 6).toInt()\n            val day = str.substring(6, 8).toInt()\n            return Date(day, Month.values()[month - 1], year)\n        }\n\n        @JvmOverloads\n        fun firstDayOf(year: Int, month: Month = Month.JANUARY): Date {\n            return Date(1, month, year)\n        }\n\n        @JvmOverloads\n        fun lastDayOf(year: Int, month: Month = Month.DECEMBER): Date {\n            return Date(month.days, month, year)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport jetbrains.datalore.base.datetime.tz.TimeZone\nimport kotlin.jvm.JvmOverloads\n\nclass DateTime @JvmOverloads constructor(val date: Date, val time: Time = Time.DAY_START) : Comparable<DateTime> {\n\n    val year: Int\n        get() = date.year\n\n    val month: Month?\n        get() = date.month\n\n    val day: Int\n        get() = date.day\n\n    val weekDay: WeekDay\n        get() = date.weekDay\n\n    val hours: Int\n        get() = time.hours\n\n    val minutes: Int\n        get() = time.minutes\n\n    val seconds: Int\n        get() = time.seconds\n\n    val milliseconds: Int\n        get() = time.milliseconds\n\n    fun changeDate(date: Date): DateTime {\n        return DateTime(date, time)\n    }\n\n    fun changeTime(time: Time): DateTime {\n        return DateTime(date, time)\n    }\n\n    fun add(duration: Duration): DateTime {\n        val utcInstant = TimeZone.UTC.toInstant(this)\n        return TimeZone.UTC.toDateTime(utcInstant.add(duration))\n    }\n\n    fun to(otherTime: DateTime): Duration {\n        val currentInstant = TimeZone.UTC.toInstant(this)\n        val otherInstant = TimeZone.UTC.toInstant(otherTime)\n        return currentInstant.to(otherInstant)\n    }\n\n    fun isBefore(dateTime: DateTime): Boolean {\n        return compareTo(dateTime) < 0\n    }\n\n    fun isAfter(dateTime: DateTime): Boolean {\n        return compareTo(dateTime) > 0\n    }\n\n    override fun hashCode(): Int {\n        return date.hashCode() * 31 + time.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DateTime) return false\n\n        val otherDateTime = other as DateTime?\n\n        return date == otherDateTime!!.date && time == otherDateTime.time\n    }\n\n    override fun compareTo(other: DateTime): Int {\n        val dateComparison = date.compareTo(other.date)\n        return if (dateComparison != 0) dateComparison else time.compareTo(other.time)\n    }\n\n    override fun toString(): String {\n        return date.toString() + \"T\" + time\n    }\n\n    fun toPrettyString(): String {\n        return time.toPrettyHMString() + \" \" + date.toPrettyString()\n    }\n\n    companion object {\n\n        fun parse(s: String): DateTime {\n            if (s.length < 15) {\n                throw IllegalArgumentException()\n            }\n\n            return DateTime(Date.parse(s.substring(0, 8)), Time.parse(s.substring(9)))\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\n\nobject DateTimeUtil {\n    const val BASE_YEAR = 1900\n    const val MAX_SUPPORTED_YEAR = 2100 //inclusive; defined by LEAP_YEARS_FROM_1969 length\n    internal const val MIN_SUPPORTED_YEAR = 1970 //inclusive\n    internal val DAYS_IN_YEAR: Int\n    internal val DAYS_IN_LEAP_YEAR: Int\n\n    internal val LEAP_YEARS_FROM_1969 = intArrayOf(477, 477, 477, 478, 478, 478, 478, 479, 479, 479, 479, 480, 480, 480, 480, 481, 481, 481, 481, 482, 482, 482, 482, 483, 483, 483, 483, 484, 484, 484, 484, 485, 485, 485, 485, 486, 486, 486, 486, 487, 487, 487, 487, 488, 488, 488, 488, 489, 489, 489, 489, 490, 490, 490, 490, 491, 491, 491, 491, 492, 492, 492, 492, 493, 493, 493, 493, 494, 494, 494, 494, 495, 495, 495, 495, 496, 496, 496, 496, 497, 497, 497, 497, 498, 498, 498, 498, 499, 499, 499, 499, 500, 500, 500, 500, 501, 501, 501, 501, 502, 502, 502, 502, 503, 503, 503, 503, 504, 504, 504, 504, 505, 505, 505, 505, 506, 506, 506, 506, 507, 507, 507, 507, 508, 508, 508, 508, 509, 509, 509, 509, 509)\n\n    init {\n        var leapYearDays = 0\n        var yearDays = 0\n        for (m in Month.values()) {\n            leapYearDays += m.getDaysInLeapYear()\n            yearDays += m.days\n        }\n        DAYS_IN_YEAR = yearDays\n        DAYS_IN_LEAP_YEAR = leapYearDays\n    }\n\n    internal fun isLeap(year: Int): Boolean {\n        checkYear(year)\n        return LEAP_YEARS_FROM_1969[year - MIN_SUPPORTED_YEAR + 1] - LEAP_YEARS_FROM_1969[year - MIN_SUPPORTED_YEAR] == 1\n        //hack for quick load\n        //    return leapYearsFromZero(year) - leapYearsFromZero(year - 1) == 1;\n    }\n\n    internal fun leapYearsBetween(fromYear: Int, toYear: Int): Int {\n        if (fromYear > toYear) {\n            throw IllegalArgumentException()\n        }\n        checkYear(fromYear)\n        checkYear(toYear)\n\n        return LEAP_YEARS_FROM_1969[toYear - MIN_SUPPORTED_YEAR] - LEAP_YEARS_FROM_1969[fromYear - MIN_SUPPORTED_YEAR]\n        //    return leapYearsFromZero(toYear - 1) - leapYearsFromZero(fromYear - 1);\n    }\n\n    private fun leapYearsFromZero(year: Int): Int {\n        return year / 4 - year / 100 + year / 400\n    }\n\n    private fun checkYear(year: Int) {\n        if (year > MAX_SUPPORTED_YEAR || year < MIN_SUPPORTED_YEAR) {\n            throw IllegalArgumentException(year.toString() + \"\")\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\n//class Instant @JvmOverloads constructor(val timeSinceEpoch: Long = System.currentTimeMillis()) : Comparable<Instant> {\nclass Instant(val timeSinceEpoch: Long) : Comparable<Instant> {\n\n    fun add(duration: Duration): Instant {\n        return Instant(timeSinceEpoch + duration.duration)\n    }\n\n    fun sub(duration: Duration): Instant {\n        return Instant(timeSinceEpoch - duration.duration)\n    }\n\n    fun to(instant: Instant): Duration {\n        return Duration(instant.timeSinceEpoch - timeSinceEpoch)\n    }\n\n    override fun compareTo(other: Instant): Int {\n        val delta = timeSinceEpoch - other.timeSinceEpoch\n        return if (delta > 0) {\n            1\n        } else if (delta == 0L) {\n            0\n        } else {\n            -1\n        }\n    }\n\n    override fun hashCode(): Int {\n        return timeSinceEpoch.toInt()\n    }\n\n    override fun toString(): String {\n        return \"\" + timeSinceEpoch\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Instant) false else timeSinceEpoch == other.timeSinceEpoch\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nopen class Month private constructor(val days: Int, private val myOrdinal: Int, private val myName: String) {\n\n    fun ordinal(): Int {\n        return myOrdinal\n    }\n\n    open fun getDaysInYear(year: Int): Int {\n        return days\n    }\n\n    open fun getDaysInLeapYear(): Int {\n        return days\n    }\n\n    fun prev(): Month? {\n        return if (myOrdinal == 0) null else Month.values()[myOrdinal - 1]\n    }\n\n    operator fun next(): Month? {\n        val values = Month.values()\n        return if (myOrdinal == values.size - 1) null else values[myOrdinal + 1]\n    }\n\n    override fun toString(): String {\n        return myName\n    }\n\n    private class VarLengthMonth(days: Int, private val myDaysInLeapYear: Int, ordinal: Int, name: String) : Month(days, ordinal, name) {\n\n        override fun getDaysInLeapYear(): Int {\n            return myDaysInLeapYear\n        }\n\n        override fun getDaysInYear(year: Int): Int {\n            return if (DateTimeUtil.isLeap(year)) {\n                getDaysInLeapYear()\n            } else {\n                days\n            }\n        }\n    }\n\n    companion object {\n        val JANUARY = Month(31, 0, \"January\")\n\n        val FEBRUARY: Month = VarLengthMonth(28, 29, 1, \"February\")\n        val MARCH = Month(31, 2, \"March\")\n        val APRIL = Month(30, 3, \"April\")\n        val MAY = Month(31, 4, \"May\")\n        val JUNE = Month(30, 5, \"June\")\n        val JULY = Month(31, 6, \"July\")\n        val AUGUST = Month(31, 7, \"August\")\n        val SEPTEMBER = Month(30, 8, \"September\")\n        val OCTOBER = Month(31, 9, \"October\")\n        val NOVEMBER = Month(30, 10, \"November\")\n        val DECEMBER = Month(31, 11, \"December\")\n\n        private val VALUES = arrayOf(JANUARY, FEBRUARY, MARCH, APRIL, MAY, JUNE, JULY, AUGUST, SEPTEMBER, OCTOBER, NOVEMBER, DECEMBER)\n\n        fun values(): Array<Month> {\n            return VALUES\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport kotlin.jvm.JvmOverloads\n\nclass Time @JvmOverloads constructor(\n        val hours: Int,\n        val minutes: Int,\n        val seconds: Int = 0,\n        val milliseconds: Int = 0) : Comparable<Time> {\n\n    init {\n        if (hours < 0 || hours > 24) {\n            throw IllegalArgumentException()\n        }\n        if (hours == 24 && (minutes != 0 || seconds != 0)) {\n            throw IllegalArgumentException()\n        }\n        if (minutes < 0 || minutes >= 60) {\n            throw IllegalArgumentException()\n        }\n        if (seconds < 0 || seconds >= 60) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    override fun compareTo(other: Time): Int {\n        var delta = hours - other.hours\n        if (delta != 0) return delta\n        delta = minutes - other.minutes\n        if (delta != 0) return delta\n        delta = seconds - other.seconds\n        return if (delta != 0) delta else milliseconds - other.milliseconds\n    }\n\n    override fun hashCode(): Int {\n        return hours * 239 + minutes * 491 + seconds * 41 + milliseconds\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Time) false else compareTo((other as Time?)!!) == 0\n\n    }\n\n    override fun toString(): String {\n        val result = StringBuilder()\n        if (hours < 10) result.append(\"0\")\n        result.append(hours)\n        if (minutes < 10) result.append(\"0\")\n        result.append(minutes)\n        if (seconds < 10) result.append(\"0\")\n        result.append(seconds)\n        return result.toString()\n    }\n\n    fun toPrettyHMString(): String {\n        val result = StringBuilder()\n        if (hours < 10) result.append(\"0\")\n        result.append(hours).append(DELIMITER)\n        if (minutes < 10) result.append(\"0\")\n        result.append(minutes)\n        return result.toString()\n    }\n\n    companion object {\n        private val DELIMITER = ':'\n        val DAY_START = Time(0, 0)\n        val DAY_END = Time(24, 0)\n\n        fun parse(s: String): Time {\n            if (s.length < 6) {\n                throw IllegalArgumentException()\n            }\n\n            val hours = s.substring(0, 2).toInt()\n            val minutes = s.substring(2, 4).toInt()\n            val seconds = s.substring(4, 6).toInt()\n\n            return Time(hours, minutes, seconds)\n        }\n\n        fun fromPrettyHMString(time: String): Time {\n            if (!time.contains(DELIMITER + \"\")) {\n                throw IllegalArgumentException()\n            }\n            val length = time.length\n            if (length != 5 && length != 4) {\n                throw IllegalArgumentException()\n            }\n            val hourLength = if (length == 4) 1 else 2\n            try {\n                return Time(\n                        time.substring(0, hourLength).toInt(),\n                        time.substring(hourLength + 1, length).toInt(), 0)\n            } catch (ignored: NumberFormatException) {\n                throw IllegalArgumentException()\n            }\n\n        }\n    }\n\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CharsKt\")\n\npackage kotlin.text\n\n/**\n * Returns the numeric value of the decimal digit that this Char represents.\n * Throws an exception if this Char is not a valid decimal digit.\n *\n * A Char is considered to represent a decimal digit if [isDigit] is true for the Char.\n * In this case, the Unicode decimal digit value of the character is returned.\n *\n * @sample samples.text.Chars.digitToInt\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToInt(): Int {\n    return digitOf(this, 10).also {\n        if (it < 0) throw IllegalArgumentException(\"Char $this is not a decimal digit\")\n    }\n}\n\n/**\n * Returns the numeric value of the digit that this Char represents in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36` or if this Char is not a valid digit in the specified [radix].\n *\n * A Char is considered to represent a digit in the specified [radix] if at least one of the following is true:\n *  - [isDigit] is `true` for the Char and the Unicode decimal digit value of the character is less than the specified [radix]. In this case the decimal digit value is returned.\n *  - The Char is one of the uppercase Latin letters 'A' through 'Z' and its [code] is less than `radix + 'A'.code - 10`. In this case, `this.code - 'A'.code + 10` is returned.\n *  - The Char is one of the lowercase Latin letters 'a' through 'z' and its [code] is less than `radix + 'a'.code - 10`. In this case, `this.code - 'a'.code + 10` is returned.\n *  - The Char is one of the fullwidth Latin capital letters '\\uFF21' through '\\uFF3A' and its [code] is less than `radix + 0xFF21 - 10`. In this case, `this.code - 0xFF21 + 10` is returned.\n *  - The Char is one of the fullwidth Latin small letters '\\uFF41' through '\\uFF5A' and its [code] is less than `radix + 0xFF41 - 10`. In this case, `this.code - 0xFF41 + 10` is returned.\n *\n * @sample samples.text.Chars.digitToInt\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToInt(radix: Int): Int {\n    return digitToIntOrNull(radix) ?: throw IllegalArgumentException(\"Char $this is not a digit in the given radix=$radix\")\n}\n\n/**\n *\n * Returns the numeric value of the decimal digit that this Char represents, or `null` if this Char is not a valid decimal digit.\n *\n * A Char is considered to represent a decimal digit if [isDigit] is true for the Char.\n * In this case, the Unicode decimal digit value of the character is returned.\n *\n * @sample samples.text.Chars.digitToIntOrNull\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToIntOrNull(): Int? {\n    return digitOf(this, 10).takeIf { it >= 0 }\n}\n\n/**\n * Returns the numeric value of the digit that this Char represents in the specified [radix], or `null` if this Char is not a valid digit in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36`.\n *\n * A Char is considered to represent a digit in the specified [radix] if at least one of the following is true:\n *  - [isDigit] is `true` for the Char and the Unicode decimal digit value of the character is less than the specified [radix]. In this case the decimal digit value is returned.\n *  - The Char is one of the uppercase Latin letters 'A' through 'Z' and its [code] is less than `radix + 'A'.code - 10`. In this case, `this.code - 'A'.code + 10` is returned.\n *  - The Char is one of the lowercase Latin letters 'a' through 'z' and its [code] is less than `radix + 'a'.code - 10`. In this case, `this.code - 'a'.code + 10` is returned.\n *  - The Char is one of the fullwidth Latin capital letters '\\uFF21' through '\\uFF3A' and its [code] is less than `radix + 0xFF21 - 10`. In this case, `this.code - 0xFF21 + 10` is returned.\n *  - The Char is one of the fullwidth Latin small letters '\\uFF41' through '\\uFF5A' and its [code] is less than `radix + 0xFF41 - 10`. In this case, `this.code - 0xFF41 + 10` is returned.\n *\n * @sample samples.text.Chars.digitToIntOrNull\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToIntOrNull(radix: Int): Int? {\n    checkRadix(radix)\n    return digitOf(this, radix).takeIf { it >= 0 }\n}\n\n/**\n * Returns the Char that represents this decimal digit.\n * Throws an exception if this value is not in the range `0..9`.\n *\n * If this value is in `0..9`, the decimal digit Char with code `'0'.code + this` is returned.\n *\n * @sample samples.text.Chars.digitToChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Int.digitToChar(): Char {\n    if (this in 0..9) {\n        return '0' + this\n    }\n    throw IllegalArgumentException(\"Int $this is not a decimal digit\")\n}\n\n/**\n * Returns the Char that represents this numeric digit value in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36` or if this value is not in the range `0 until radix`.\n *\n * If this value is less than `10`, the decimal digit Char with code `'0'.code + this` is returned.\n * Otherwise, the uppercase Latin letter with code `'A'.code + this - 10` is returned.\n *\n * @sample samples.text.Chars.digitToChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Int.digitToChar(radix: Int): Char {\n    if (radix !in 2..36) {\n        throw IllegalArgumentException(\"Invalid radix: $radix. Valid radix values are in range 2..36\")\n    }\n    if (this < 0 || this >= radix) {\n        throw IllegalArgumentException(\"Digit $this does not represent a valid digit in radix $radix\")\n    }\n    return if (this < 10) {\n        '0' + this\n    } else {\n        'A' + this - 10\n    }\n}\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n */\n@Deprecated(\"Use lowercaseChar() instead.\", ReplaceWith(\"lowercaseChar()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun Char.toLowerCase(): Char\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [lowercase] function.\n * If this character has no mapping equivalent, the character itself is returned.\n *\n * @sample samples.text.Chars.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.lowercaseChar(): Char\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\u0130'.lowercase()` returns `\"\\u0069\\u0307\"`,\n * where `'\\u0130'` is the LATIN CAPITAL LETTER I WITH DOT ABOVE character (`İ`).\n * If this character has no lower case mapping, the result of `toString()` of this char is returned.\n *\n * @sample samples.text.Chars.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.lowercase(): String\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n */\n@Deprecated(\"Use uppercaseChar() instead.\", ReplaceWith(\"uppercaseChar()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun Char.toUpperCase(): Char\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [uppercase] function.\n * If this character has no mapping equivalent, the character itself is returned.\n *\n * @sample samples.text.Chars.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.uppercaseChar(): Char\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\uFB00'.uppercase()` returns `\"\\u0046\\u0046\"`,\n * where `'\\uFB00'` is the LATIN SMALL LIGATURE FF character (`ﬀ`).\n * If this character has no upper case mapping, the result of `toString()` of this char is returned.\n *\n * @sample samples.text.Chars.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.uppercase(): String\n\n/**\n * Converts this character to title case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [titlecase] function.\n * If this character has no mapping equivalent, the result of calling [uppercaseChar] is returned.\n *\n * @sample samples.text.Chars.titlecase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.titlecaseChar(): Char\n\n/**\n * Converts this character to title case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\uFB00'.titlecase()` returns `\"\\u0046\\u0066\"`,\n * where `'\\uFB00'` is the LATIN SMALL LIGATURE FF character (`ﬀ`).\n * If this character has no title case mapping, the result of [uppercase] is returned instead.\n *\n * @sample samples.text.Chars.titlecase\n */\n@SinceKotlin(\"1.5\")\npublic fun Char.titlecase(): String = titlecaseImpl()\n\n/**\n * Concatenates this Char and a String.\n *\n * @sample samples.text.Chars.plus\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun Char.plus(other: String): String = this.toString() + other\n\n/**\n * Returns `true` if this character is equal to the [other] character, optionally ignoring character case.\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n *\n * Two characters are considered the same ignoring case if at least one of the following is `true`:\n *   - The two characters are the same (as compared by the == operator)\n *   - Applying the method [uppercaseChar] to each character produces the same result\n *   - Applying the method [lowercaseChar] to each character produces the same result\n *\n * @sample samples.text.Chars.equals\n */\npublic fun Char.equals(other: Char, ignoreCase: Boolean = false): Boolean {\n    if (this == other) return true\n    if (!ignoreCase) return false\n\n    val thisUpper = this.uppercaseChar()\n    val otherUpper = other.uppercaseChar()\n\n    return thisUpper == otherUpper || thisUpper.lowercaseChar() == otherUpper.lowercaseChar()\n}\n\n/**\n * Returns `true` if this character is a Unicode surrogate code unit.\n */\npublic fun Char.isSurrogate(): Boolean = this in Char.MIN_SURROGATE..Char.MAX_SURROGATE\n\n/**\n * Returns the Unicode general category of this character.\n */\n@SinceKotlin(\"1.5\")\npublic expect val Char.category: CharCategory\n\n/**\n * Returns `true` if this character (Unicode code point) is defined in Unicode.\n *\n * A character is considered to be defined in Unicode if its [category] is not [CharCategory.UNASSIGNED].\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isDefined(): Boolean\n\n/**\n * Returns `true` if this character is a letter.\n *\n * A character is considered to be a letter if its [category] is [CharCategory.UPPERCASE_LETTER],\n * [CharCategory.LOWERCASE_LETTER], [CharCategory.TITLECASE_LETTER], [CharCategory.MODIFIER_LETTER], or [CharCategory.OTHER_LETTER].\n *\n * @sample samples.text.Chars.isLetter\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLetter(): Boolean\n\n/**\n * Returns `true` if this character is a letter or digit.\n *\n * @see isLetter\n * @see isDigit\n *\n * @sample samples.text.Chars.isLetterOrDigit\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLetterOrDigit(): Boolean\n\n/**\n * Returns `true` if this character is a digit.\n *\n * A character is considered to be a digit if its [category] is [CharCategory.DECIMAL_DIGIT_NUMBER].\n *\n * @sample samples.text.Chars.isDigit\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isDigit(): Boolean\n\n/**\n * Returns `true` if this character is upper case.\n *\n * A character is considered to be an upper case character if its [category] is [CharCategory.UPPERCASE_LETTER],\n * or it has contributory property Other_Uppercase as defined by the Unicode Standard.\n *\n * @sample samples.text.Chars.isUpperCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isUpperCase(): Boolean\n\n/**\n * Returns `true` if this character is lower case.\n *\n * A character is considered to be a lower case character if its [category] is [CharCategory.LOWERCASE_LETTER],\n * or it has contributory property Other_Lowercase as defined by the Unicode Standard.\n *\n * @sample samples.text.Chars.isLowerCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLowerCase(): Boolean\n\n/**\n * Returns `true` if this character is a title case letter.\n *\n * A character is considered to be a title case letter if its [category] is [CharCategory.TITLECASE_LETTER].\n *\n * @sample samples.text.Chars.isTitleCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isTitleCase(): Boolean\n\n/**\n * Returns `true` if this character is an ISO control character.\n *\n * A character is considered to be an ISO control character if its [category] is [CharCategory.CONTROL],\n * meaning the Char is in the range `'\\u0000'..'\\u001F'` or in the range `'\\u007F'..'\\u009F'`.\n *\n * @sample samples.text.Chars.isISOControl\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isISOControl(): Boolean\n\n/**\n * Determines whether a character is whitespace according to the Unicode standard.\n * Returns `true` if the character is whitespace.\n *\n * @sample samples.text.Chars.isWhitespace\n */\npublic expect fun Char.isWhitespace(): Boolean\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nenum class WeekDay(val abbreviation: String, val isWeekend: Boolean) {\n    MONDAY(\"MO\", false),\n    TUESDAY(\"TU\", false),\n    WEDNESDAY(\"WE\", false),\n    THURSDAY(\"TH\", false),\n    FRIDAY(\"FR\", false),\n    SATURDAY(\"SA\", true),\n    SUNDAY(\"SU\", true)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.Month\nimport jetbrains.datalore.base.datetime.WeekDay\nimport kotlin.jvm.JvmOverloads\n\ninternal object DateSpecs {\n    fun last(weekDay: WeekDay, month: Month): DateSpec {\n        return object : DateSpec {\n\n            override val rRule: String\n                get() = \"RRULE:FREQ=YEARLY;BYDAY=-1\" + weekDay.abbreviation + \";BYMONTH=\" + (month.ordinal() + 1)\n\n            override fun getDate(year: Int): Date {\n                val days = month.getDaysInYear(year)\n                for (d in days downTo 1) {\n                    val date = Date(d, month, year)\n                    if (date.weekDay === weekDay) return date\n                }\n                throw RuntimeException()\n            }\n        }\n    }\n\n    @JvmOverloads\n    fun first(weekDay: WeekDay, month: Month, number: Int = 1): DateSpec {\n        return object : DateSpec {\n\n            override val rRule: String\n                get() = \"RRULE:FREQ=YEARLY;BYDAY=\" + number + weekDay.abbreviation + \";BYMONTH=\" + (month.ordinal() + 1)\n\n            override fun getDate(year: Int): Date {\n                val startDay = (number - 1) * WeekDay.values().size + 1\n                val days = month.getDaysInYear(year)\n                for (d in startDay..days) {\n                    val date = Date(d, month, year)\n                    if (date.weekDay === weekDay) return date\n                }\n                throw RuntimeException()\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nobject EnumInfoFactory {\n\n    /**\n     * @throws IllegalArgumentException if there are same enumConstant.toString() values (case insensitive) in the enum\n     */\n    inline fun <reified EnumT : Enum<EnumT>> createEnumInfo(): EnumInfo<EnumT> {\n        return EnumInfoImpl(enumValues())\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nclass EnumInfoImpl<EnumT : Enum<EnumT>>(enumConstants: Array<EnumT>) : EnumInfo<EnumT> {\n\n    private val myNormalizedValueMap: Map<String, EnumT>\n    private val myOriginalNames: List<String>\n\n    override val originalNames: List<String>\n        get() = myOriginalNames\n\n    private fun toNormalizedName(name: String): String {\n        return name.uppercase()\n    }\n\n    init {\n        val numConstants = enumConstants.size\n        val valueMap = HashMap<String, EnumT>(numConstants)\n        val originalNames = ArrayList<String>(numConstants)\n        for (value in enumConstants) {\n            val originalName = value.toString()\n            originalNames.add(originalName)\n            val normalizedName = toNormalizedName(originalName)\n            val oldValue = valueMap.put(normalizedName, value)\n            if (oldValue != null) {\n                throw IllegalArgumentException(\"duplicate values: '$value', '$oldValue'\")\n            }\n        }\n        myOriginalNames = originalNames\n        myNormalizedValueMap = valueMap\n    }\n\n    override fun safeValueOf(name: String?, defaultValue: EnumT): EnumT {\n        val value = safeValueOf(name)\n        return value ?: defaultValue\n    }\n\n    override fun safeValueOf(name: String?): EnumT? {\n        val result: EnumT?\n        if (hasValue(name)) {\n            result = myNormalizedValueMap[toNormalizedName(name!!)]\n        } else {\n            result = null\n        }\n        return result\n    }\n\n    override fun hasValue(name: String?): Boolean {\n        return name != null && myNormalizedValueMap.containsKey(toNormalizedName(name))\n    }\n\n    override fun unsafeValueOf(name: String): EnumT {\n        return safeValueOf(name) ?: throw IllegalArgumentException(\"name not found: '$name'\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nobject Enums {\n    /**\n     * Value of method for enums which takes into account toString() instead of saved generated name\n     */\n    inline fun <reified EnumT : Enum<EnumT>> valueOf(name: String): EnumT {\n        for (e in enumValues<EnumT>()) {\n            if (name == e.toString()) {\n                return e\n            }\n        }\n\n        throw IllegalArgumentException(name)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class Button {\n    NONE, LEFT, MIDDLE, RIGHT\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\n\nopen class Event {\n    private var eventContext: EventContext? = null\n        set(eventContext) {\n            if (this.eventContext != null) {\n                throw kotlin.IllegalStateException(\"Already set \" + this.eventContext!!)\n            }\n            if (isConsumed) {\n                throw IllegalStateException(\"Can't set a context to the consumed event\")\n            }\n            if (eventContext == null) {\n                throw IllegalArgumentException(\"Can't set null context\")\n            }\n            field = eventContext\n        }\n    var isConsumed: Boolean = false\n        private set\n\n    fun consume() {\n        doConsume()\n    }\n\n    private fun doConsume() {\n        if (isConsumed) {\n            throw IllegalStateException()\n        }\n        isConsumed = true\n    }\n\n    fun ensureConsumed() {\n        if (!isConsumed) {\n            consume()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class Key private constructor(private val myValue: String) {\n    A(\"A\"),\n    B(\"B\"),\n    C(\"C\"),\n    D(\"D\"),\n    E(\"E\"),\n    F(\"F\"),\n    G(\"G\"),\n    H(\"H\"),\n    I(\"I\"),\n    J(\"J\"),\n    K(\"K\"),\n    L(\"L\"),\n    M(\"M\"),\n    N(\"N\"),\n    O(\"O\"),\n    P(\"P\"),\n    Q(\"Q\"),\n    R(\"R\"),\n    S(\"S\"),\n    T(\"T\"),\n    U(\"U\"),\n    V(\"V\"),\n    W(\"W\"),\n    X(\"X\"),\n    Y(\"Y\"),\n    Z(\"Z\"),\n    DIGIT_0(\"0\"),\n    DIGIT_1(\"1\"),\n    DIGIT_2(\"2\"),\n    DIGIT_3(\"3\"),\n    DIGIT_4(\"4\"),\n    DIGIT_5(\"5\"),\n    DIGIT_6(\"6\"),\n    DIGIT_7(\"7\"),\n    DIGIT_8(\"8\"),\n    DIGIT_9(\"9\"),\n    LEFT_BRACE(\"[\"),\n    RIGHT_BRACE(\"]\"),\n    UP(\"Up\"),\n    DOWN(\"Down\"),\n    LEFT(\"Left\"),\n    RIGHT(\"Right\"),\n    PAGE_UP(\"Page Up\"),\n    PAGE_DOWN(\"Page Down\"),\n    ESCAPE(\"Escape\"),\n    ENTER(\"Enter\"),\n    HOME(\"Home\"),\n    END(\"End\"),\n    TAB(\"Tab\"),\n    SPACE(\"Space\"),\n    INSERT(\"Insert\"),\n    DELETE(\"Delete\"),\n    BACKSPACE(\"Backspace\"),\n    EQUALS(\"Equals\"),\n    BACK_QUOTE(\"`\"),\n    PLUS(\"Plus\"),\n    MINUS(\"Minus\"),\n    SLASH(\"Slash\"),\n    CONTROL(\"Ctrl\"),\n    META(\"Meta\"),\n    ALT(\"Alt\"),\n    SHIFT(\"Shift\"),\n    UNKNOWN(\"?\"),\n    F1(\"F1\"),\n    F2(\"F2\"),\n    F3(\"F3\"),\n    F4(\"F4\"),\n    F5(\"F5\"),\n    F6(\"F6\"),\n    F7(\"F7\"),\n    F8(\"F8\"),\n    F9(\"F9\"),\n    F10(\"F10\"),\n    F11(\"F11\"),\n    F12(\"F12\"),\n    COMMA(\",\"),\n    PERIOD(\".\");\n\n    override fun toString(): String {\n        return myValue\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyEvent : Event {\n\n    val keyStroke: KeyStroke\n    val keyChar: Char\n\n    val key: Key\n        get() = keyStroke.key\n\n    val modifiers: Set<ModifierKey>\n        get() = keyStroke.modifiers\n\n    constructor(keyStroke: KeyStroke) {\n        this.keyStroke = keyStroke\n        keyChar = 0.toChar()\n    }\n\n    constructor(key: Key, ch: Char = 0.toChar()) {\n        keyStroke = KeyStroke(key, emptyList())\n        keyChar = ch\n    }\n\n    constructor(key: Key, ch: Char, modifiers: Collection<ModifierKey>) {\n        keyStroke = KeyStroke(key, modifiers)\n        keyChar = ch\n    }\n\n    fun `is`(key: Key, vararg modifiers: ModifierKey): Boolean {\n        return keyStroke.`is`(key, *modifiers)\n    }\n\n    fun `is`(vararg specs: KeyStrokeSpec): Boolean {\n        for (s in specs) {\n            if (s.matches(keyStroke)) return true\n        }\n        return false\n    }\n\n    fun `is`(vararg specs: KeyStroke): Boolean {\n        for (s in specs) {\n            if (s.matches(keyStroke)) return true\n        }\n        return false\n    }\n\n    fun has(key: ModifierKey): Boolean {\n        return keyStroke.has(key)\n    }\n\n    fun copy(): KeyEvent {\n        return KeyEvent(key, keyChar, modifiers)\n    }\n\n    override fun toString(): String {\n        return keyStroke.toString()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyModifiers(val isCtrl: Boolean, val isAlt: Boolean, val isShift: Boolean, val isMeta: Boolean) {\n\n    private constructor() : this(false, false, false, false)\n\n    companion object {\n\n        private val EMPTY_MODIFIERS = KeyModifiers()\n\n        fun emptyModifiers(): KeyModifiers {\n            return EMPTY_MODIFIERS\n        }\n\n        fun withShift(): KeyModifiers {\n            return KeyModifiers(false, false, true, false)\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyStroke {\n    val key: Key\n    val modifiers: Set<ModifierKey>\n\n    constructor(key: Key, vararg modifiers: ModifierKey) : this(key, modifiers.asList())\n\n    constructor(key: Key, modifiers: Collection<ModifierKey>) {\n        this.key = key\n        this.modifiers = HashSet(modifiers)\n    }\n\n    fun has(key: ModifierKey): Boolean {\n        return modifiers.contains(key)\n    }\n\n    fun `is`(key: Key, vararg modifiers: ModifierKey): Boolean {\n        return matches(KeyStroke(key, *modifiers))\n    }\n\n    fun matches(keyStroke: KeyStroke): Boolean {\n        return equals(keyStroke)\n    }\n\n    fun with(key: ModifierKey): KeyStroke {\n        val keys = HashSet(modifiers)\n        keys.add(key)\n        return KeyStroke(this.key, keys)\n    }\n\n    override fun hashCode(): Int {\n        return key.hashCode() * 31 + modifiers.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is KeyStroke) return false\n        val otherKeyStroke = other as KeyStroke?\n\n        return key === otherKeyStroke!!.key && modifiers == otherKeyStroke!!.modifiers\n    }\n\n    override fun toString(): String {\n        return \"$key $modifiers\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyStrokeSpec {\n\n    private val myKeyStrokes: Array<KeyStroke>\n\n    val keyStrokes: Iterable<KeyStroke>\n        get() = listOf(*myKeyStrokes)\n\n    val isEmpty: Boolean\n        get() = myKeyStrokes.isEmpty()\n\n    constructor(key: Key, vararg modifiers: ModifierKey) {\n        myKeyStrokes = arrayOf(KeyStroke(key, *modifiers))\n    }\n\n    constructor(keyStrokes: Collection<KeyStroke>) {\n        myKeyStrokes = keyStrokes.toTypedArray()\n    }\n\n    constructor(vararg keyStrokes: KeyStroke) {\n        myKeyStrokes = arrayOf(*keyStrokes)\n    }\n\n    fun matches(keyStroke: KeyStroke): Boolean {\n        for (spec in myKeyStrokes) {\n            if (spec.matches(keyStroke)) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun with(key: ModifierKey): KeyStrokeSpec {\n        val modified = ArrayList<KeyStroke>()\n        for (keyStroke in myKeyStrokes) {\n            modified.add(keyStroke.with(key))\n        }\n        return KeyStrokeSpec(modified)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        val that = other as KeyStrokeSpec?\n        return keyStrokes == that!!.keyStrokes\n    }\n\n    override fun hashCode(): Int {\n        return keyStrokes.hashCode()\n    }\n\n    override fun toString(): String {\n        return keyStrokes.toString()\n    }\n\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.event.ModifierKey.*\n\nobject KeyStrokeSpecs {\n    val COPY = composite(ctrlOrMeta(Key.C), KeyStrokeSpec(Key.INSERT, CONTROL))\n    val CUT = composite(ctrlOrMeta(Key.X), KeyStrokeSpec(Key.DELETE, SHIFT))\n    val PASTE = composite(ctrlOrMeta(Key.V), KeyStrokeSpec(Key.INSERT, SHIFT))\n\n    val UNDO = ctrlOrMeta(Key.Z)\n    val REDO = UNDO.with(SHIFT)\n\n    val COMPLETE = KeyStrokeSpec(Key.SPACE, CONTROL)\n\n    val SHOW_DOC = composite(KeyStrokeSpec(Key.F1), ctrlOrMeta(Key.J))\n\n    val HELP = composite(ctrlOrMeta(Key.I), ctrlOrMeta(Key.F1))\n\n    val HOME = composite(KeyStroke(Key.HOME), KeyStroke(Key.LEFT, META))\n    val END = composite(KeyStroke(Key.END), KeyStroke(Key.RIGHT, META))\n\n    val FILE_HOME = ctrlOrMeta(Key.HOME)\n    val FILE_END = ctrlOrMeta(Key.END)\n\n    val PREV_WORD = ctrlOrAlt(Key.LEFT)\n    val NEXT_WORD = ctrlOrAlt(Key.RIGHT)\n\n    val NEXT_EDITABLE = ctrlOrMeta(Key.RIGHT, ALT)\n    val PREV_EDITABLE = ctrlOrMeta(Key.LEFT, ALT)\n\n    val SELECT_ALL = ctrlOrMeta(Key.A)\n\n    val SELECT_FILE_HOME = FILE_HOME.with(SHIFT)\n    val SELECT_FILE_END = FILE_END.with(SHIFT)\n\n    val SELECT_HOME = HOME.with(SHIFT)\n    val SELECT_END = END.with(SHIFT)\n\n    val SELECT_WORD_FORWARD = NEXT_WORD.with(SHIFT)\n    val SELECT_WORD_BACKWARD = PREV_WORD.with(SHIFT)\n\n    val SELECT_LEFT = KeyStrokeSpec(Key.LEFT, SHIFT)\n    val SELECT_RIGHT = KeyStrokeSpec(Key.RIGHT, SHIFT)\n\n    val SELECT_UP = KeyStrokeSpec(Key.UP, SHIFT)\n    val SELECT_DOWN = KeyStrokeSpec(Key.DOWN, SHIFT)\n\n    val INCREASE_SELECTION = KeyStrokeSpec(Key.UP, ALT)\n    val DECREASE_SELECTION = KeyStrokeSpec(Key.DOWN, ALT)\n\n    val INSERT_BEFORE = composite(\n            KeyStroke(Key.ENTER, add(META)),\n            KeyStroke(Key.INSERT),\n            KeyStroke(Key.ENTER, add(CONTROL))\n    )\n    val INSERT_AFTER = KeyStrokeSpec(Key.ENTER)\n    val INSERT = composite(INSERT_BEFORE, INSERT_AFTER)\n\n    val DUPLICATE = ctrlOrMeta(Key.D)\n\n    val DELETE_CURRENT = composite(ctrlOrMeta(Key.BACKSPACE), ctrlOrMeta(Key.DELETE))\n\n    val DELETE_TO_WORD_START = KeyStrokeSpec(Key.BACKSPACE, ALT)\n\n    val MATCHING_CONSTRUCTS = composite(ctrlOrMeta(Key.LEFT_BRACE, ALT), ctrlOrMeta(Key.RIGHT_BRACE, ALT))\n\n    val NAVIGATE = ctrlOrMeta(Key.B)\n    val NAVIGATE_BACK = ctrlOrMeta(Key.LEFT_BRACE)\n    val NAVIGATE_FORWARD = ctrlOrMeta(Key.RIGHT_BRACE)\n\n    fun ctrlOrMeta(key: Key, vararg modifiers: ModifierKey): KeyStrokeSpec {\n        return composite(KeyStroke(key, add(CONTROL, *modifiers)), KeyStroke(key, add(META, *modifiers)))\n    }\n\n    fun ctrlOrAlt(key: Key, vararg modifiers: ModifierKey): KeyStrokeSpec {\n        return composite(KeyStroke(key, add(CONTROL, *modifiers)), KeyStroke(key, add(ALT, *modifiers)))\n    }\n\n    private fun add(key: ModifierKey, vararg otherKeys: ModifierKey): Set<ModifierKey> {\n        val result = HashSet(otherKeys.asList())\n        result.add(key)\n        return result\n    }\n\n    fun composite(vararg specs: KeyStrokeSpec): KeyStrokeSpec {\n        val keyStrokes = HashSet<KeyStroke>()\n        for (spec in specs) {\n            for (ks in spec.keyStrokes) {\n                keyStrokes.add(ks)\n            }\n        }\n        return KeyStrokeSpec(keyStrokes)\n    }\n\n    fun composite(vararg specs: KeyStroke): KeyStrokeSpec {\n        return KeyStrokeSpec(*specs)\n    }\n\n    fun withoutShift(spec: KeyStrokeSpec): KeyEvent {\n        val keyStroke = spec.keyStrokes.iterator().next()\n        val modifiers = keyStroke.modifiers\n        val withoutShift = HashSet<ModifierKey>()\n        for (modifier in modifiers) {\n            if (modifier !== SHIFT) {\n                withoutShift.add(modifier)\n            }\n        }\n        return KeyEvent(keyStroke.key, 0.toChar(), withoutShift)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class ModifierKey private constructor() {\n\n    CONTROL,\n    ALT,\n    SHIFT,\n    META\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.event.KeyModifiers.Companion.emptyModifiers\nimport jetbrains.datalore.base.geometry.Vector\n\n\nclass MouseEvent(x: Int, y: Int, val button: Button?, val modifiers: KeyModifiers) : PointEvent(x, y) {\n\n    companion object {\n\n        fun noButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.NONE, emptyModifiers())\n        }\n\n        fun leftButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.LEFT, emptyModifiers())\n        }\n\n        fun middleButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.MIDDLE, emptyModifiers())\n        }\n\n        fun rightButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.RIGHT, emptyModifiers())\n        }\n    }\n\n    init {\n        requireNotNull(button) { \"Null button\" }\n    }\n\n    constructor(v: Vector, button: Button, modifiers: KeyModifiers) : this(v.x, v.y, button, modifiers)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class MouseEventSpec {\n    MOUSE_ENTERED,\n    MOUSE_LEFT,\n    MOUSE_MOVED,\n    MOUSE_DRAGGED,\n    MOUSE_CLICKED,\n    MOUSE_DOUBLE_CLICKED,\n    MOUSE_PRESSED,\n    MOUSE_RELEASED\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.geometry.Vector\n\nopen class PointEvent(val x: Int, val y: Int) : Event() {\n\n    val location: Vector\n        get() = Vector(x, y)\n\n    override fun toString(): String {\n        return \"{x=$x,y=$y}\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.function\n\nobject Functions {\n\n    private val TRUE_PREDICATE: Predicate<Any?> = {\n        true\n    }\n\n    private val FALSE_PREDICATE: Predicate<Any?> = {\n        false\n    }\n\n    private val NULL_PREDICATE: Predicate<Any?> = {\n        it == null\n    }\n\n    private val NOT_NULL_PREDICATE: Predicate<Any?> = {\n        it != null\n    }\n\n    fun <ItemT> constantSupplier(value: ItemT): Supplier<ItemT> {\n        return object : Supplier<ItemT> {\n            override fun get(): ItemT {\n                return value\n            }\n        }\n    }\n\n    fun <ItemT> memorize(supplier: Supplier<ItemT>): Supplier<ItemT> {\n        return Memo(supplier)\n    }\n\n    fun <ArgT> alwaysTrue(): Predicate<ArgT> {\n        return TRUE_PREDICATE\n    }\n\n    fun <ArgT> alwaysFalse(): Predicate<ArgT> {\n        return FALSE_PREDICATE\n    }\n\n    fun <ArgT, ResultT> constant(result: ResultT): (ArgT) -> ResultT {\n        return {\n            result\n        }\n    }\n\n    fun <ArgT> isNull(): Predicate<ArgT> {\n        return NULL_PREDICATE\n    }\n\n    fun <ArgT> isNotNull(): Predicate<ArgT> {\n        return NOT_NULL_PREDICATE\n    }\n\n    fun <ValueT> identity(): (ValueT) -> ValueT {\n        return { it }\n    }\n\n    fun <ValueT> same(value: Any?): Predicate<ValueT> {\n        return {\n            it === value\n        }\n    }\n\n    fun <ArgT, ResultT> funcOf(lambda: (ArgT) -> ResultT): Function<ArgT, ResultT> {\n        return object : Function<ArgT, ResultT> {\n            override fun apply(value: ArgT): ResultT {\n                return lambda(value)\n            }\n        }\n    }\n\n    private class Memo<ItemT> internal constructor(private val mySupplier: Supplier<ItemT>) : Supplier<ItemT> {\n        private var myCachedValue: ItemT? = null\n        private var myCached = false\n\n        override fun get(): ItemT {\n            if (!myCached) {\n                myCachedValue = mySupplier.get()\n                myCached = true\n            }\n            return myCachedValue!!\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.function\n\n/**\n * Mutable container for ValueT. Used mainly to change values from inside of anonymous class/function\n */\nclass Value<ValueT>(private var myValue: ValueT) : Supplier<ValueT> {\n\n    override fun get(): ValueT {\n        return myValue\n    }\n\n    fun set(value: ValueT) {\n        myValue = value\n    }\n\n    override fun toString(): String {\n        return \"\" + myValue\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Preconditions {\n    @Deprecated(\"Replace with Kotlin 'check()'\")\n    fun checkState(expression: Boolean) {\n        if (!expression) {\n            throw IllegalStateException()\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'check()'\")\n    fun checkState(expression: Boolean, errorMessage: Any) {\n        if (!expression) {\n            throw IllegalStateException(errorMessage.toString())\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'require()'\")\n    fun checkArgument(expression: Boolean) {\n        if (!expression) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'require()'\")\n    fun checkArgument(expression: Boolean, errorMessage: Any) {\n        if (!expression) {\n            throw IllegalArgumentException(errorMessage.toString())\n        }\n    }\n\n    // ToDo: use `checkNotNull` from kotlin std-lib\n    fun <T> checkNotNull(reference: T?): T {\n        if (reference == null) {\n            throw NullPointerException()\n        }\n        return reference\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Strings {\n\n    // ToDo: use Kotlin `isNullOrEmpty` or `isNullOrBlank`\n    fun isNullOrEmpty(s: String?): Boolean {\n        return s == null || s.isEmpty()\n    }\n\n    fun nullToEmpty(string: String?): String {\n        return string ?: \"\"\n    }\n\n    fun repeat(string: String, count: Int): String {\n        val stringBuilder = StringBuilder()\n        for (i in 0 until count) {\n            stringBuilder.append(string)\n        }\n        return stringBuilder.toString()\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Throwables {\n    fun getRootCause(throwable: Throwable): Throwable {\n        // Keep a second pointer that slowly walks the causal chain. If the fast pointer ever catches\n        // the slower pointer, then there's a loop.\n        var slowPointer: Throwable = throwable\n        var advanceSlowPointer = false\n\n        var cause = throwable\n        while (cause.cause != null) {\n            cause = cause.cause!!\n\n            if (cause === slowPointer) {\n                throw IllegalArgumentException(\"Loop in causal chain detected.\", cause)\n            }\n            if (advanceSlowPointer) {\n                slowPointer = slowPointer.cause!!\n            }\n            advanceSlowPointer = !advanceSlowPointer // only advance every other iteration\n        }\n        return cause\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nimport jetbrains.datalore.base.gcommon.collect.Comparables.gt\nimport jetbrains.datalore.base.gcommon.collect.Comparables.gte\nimport jetbrains.datalore.base.gcommon.collect.Comparables.ls\nimport jetbrains.datalore.base.gcommon.collect.Comparables.lse\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\n\nopen class ClosedRange<T : Comparable<T>>(\n    lower: T,\n    upper: T\n) {\n    val lowerEnd: T\n    val upperEnd: T\n\n    init {\n        (lower as? Double)?.run { require(isFinite()) {\n            \"ends must be finite: lower=$lower upper=$upper\"\n        } }\n        (upper as? Double)?.run { require(isFinite()) {\n            \"ends must be finite: lower=$lower upper=$upper\" }\n        }\n        lowerEnd = min(lower, upper)\n        upperEnd = max(lower, upper)\n    }\n\n    operator fun contains(v: T): Boolean {\n        return lse(lowerEnd, v) && lse(v, upperEnd)\n    }\n\n    fun span(other: ClosedRange<T>): ClosedRange<T> {\n        if (encloses(other)) return this\n        return if (other.encloses(this)) other else ClosedRange(\n            min(lowerEnd, other.lowerEnd),\n            max(upperEnd, other.upperEnd)\n        )\n    }\n\n    fun encloses(other: ClosedRange<T>): Boolean {\n        return lse(lowerEnd, other.lowerEnd) && gte(upperEnd, other.upperEnd)\n    }\n\n    fun isConnected(other: ClosedRange<T>): Boolean {\n        return !(gt(lowerEnd, other.upperEnd) || ls(upperEnd, other.lowerEnd))\n    }\n\n    fun intersection(other: ClosedRange<T>): ClosedRange<T> {\n        if (!isConnected(other)) throw IllegalArgumentException(\"Ranges are not connected: this=$this other=$other\")\n        if (encloses(other)) return other\n        return if (other.encloses(this)) this else ClosedRange(\n            max(lowerEnd, other.lowerEnd),\n            min(upperEnd, other.upperEnd)\n        )\n    }\n\n    override fun toString(): String {\n        return \"ClosedRange[$lowerEnd, $upperEnd]\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as ClosedRange<*>\n\n        if (lowerEnd != other.lowerEnd) return false\n        if (upperEnd != other.upperEnd) return false\n        return true\n    }\n\n    override fun hashCode(): Int {\n        return lowerEnd.hashCode() + 31 * upperEnd.hashCode()\n    }\n\n    companion object {\n        fun <T : Comparable<T>> singleton(v: T): ClosedRange<T> {\n            return ClosedRange(v, v)\n        }\n\n        fun <T : Comparable<T>> encloseAll(values: Iterable<T?>): ClosedRange<T> {\n            var iterated = false\n            var min: T? = null\n            var max: T? = null\n            for (v: T? in values) {\n                if (!iterated) {\n                    iterated = true\n                    min = v\n                    max = v\n                } else {\n                    min = min(min!!, v!!)\n                    max = max(max!!, v)\n                }\n            }\n            if (!iterated) {\n                throw NoSuchElementException()\n            }\n            return ClosedRange<T>(min!!, max!!)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\n\nobject Comparables {\n    fun <T : Comparable<T>> min(a: T, b: T): T {\n        return if (a < b) a else b\n    }\n\n    fun <T : Comparable<T>> max(a: T, b: T): T {\n        return if (a >= b) a else b\n    }\n\n    fun <T : Comparable<T>> lse(a: T, b: T): Boolean {\n        return a <= b\n    }\n\n    fun <T : Comparable<T>> gte(a: T, b: T): Boolean {\n        return a >= b\n    }\n\n    fun <T : Comparable<T>> ls(a: T, b: T): Boolean {\n        return a < b\n    }\n\n    fun <T : Comparable<T>> gt(a: T, b: T): Boolean {\n        return a > b\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\ninternal class ComparatorOrdering<T>(comparator: Comparator<T>) : Ordering<T>() {\n    private val myComparator: Comparator<T> = comparator\n\n    override fun compare(a: T, b: T): Int {\n        return myComparator.compare(a, b)\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nimport jetbrains.datalore.base.function.Predicate\n\nobject Iterables {\n    private fun checkNonNegative(position: Int) {\n        if (position < 0) {\n            throw IndexOutOfBoundsException(position.toString())\n        }\n    }\n\n    fun <T> toList(iterable: Iterable<T>): List<T> {\n        return iterable.toList()\n    }\n\n    fun size(iterable: Iterable<*>): Int {\n        return iterable.count()\n    }\n\n    fun isEmpty(iterable: Iterable<*>): Boolean {\n        return (iterable as? Collection<*>)?.isEmpty() ?: !iterable.iterator().hasNext()\n    }\n\n    fun <T> filter(unfiltered: Iterable<T>, retainIfTrue: Predicate<in T>): Iterable<T> {\n        return unfiltered.filter(retainIfTrue)\n    }\n\n    fun <T> all(iterable: Iterable<T>, predicate: Predicate<in T>): Boolean {\n        return iterable.all(predicate)\n    }\n\n    fun <T> concat(a: Iterable<T>, b: Iterable<T>): Iterable<T> {\n        return a + b\n    }\n\n    operator fun <T> get(iterable: Iterable<T>, position: Int): T {\n        checkNonNegative(position)\n        if (iterable is List<*>) {\n            return (iterable as List<T>)[position]\n        }\n\n        val it = iterable.iterator()\n        for (i in 0..position) {\n            if (i == position) {\n                return it.next()\n            }\n            it.next()\n        }\n        throw IndexOutOfBoundsException(position.toString())\n    }\n\n    operator fun <T> get(iterable: Iterable<T>, position: Int, defaultValue: T): T {\n        checkNonNegative(position)\n        if (iterable is List<*>) {\n            val list = iterable as List<T>\n            return if (position < list.size) list[position] else defaultValue\n        }\n        val it = iterable.iterator()\n        var i = 0\n        while (i <= position && it.hasNext()) {\n            if (i == position) {\n                return it.next()\n            }\n            it.next()\n            i++\n        }\n        return defaultValue\n    }\n\n    fun <T> find(iterable: Iterable<T>, predicate: Predicate<in T>, defaultValue: T): T {\n        return iterable.find(predicate) ?: defaultValue\n    }\n\n    fun <T> getLast(iterable: Iterable<T>): T {\n        return iterable.last()\n    }\n\n    internal fun toArray(iterable: Iterable<*>): Array<*> {\n        val collection: Collection<*>\n        if (iterable is Collection<*>) {\n            collection = iterable\n        } else {\n            collection = iterable.toList()\n        }\n        return collection.toTypedArray()\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\n\nobject Lists {\n    fun <F, T> transform(fromList: List<F>, function: (F) -> T): List<T> {\n        return fromList.map { t -> function.invoke(t) }\n    }\n\n    /**\n     * Doesn't return reversed `view` of the list (guava)\n     * Instead creates reversed copy.\n     */\n    fun <T> reverse(list: List<T>): List<T> {\n        val copy = ArrayList(list)\n        copy.reverse()\n        return copy\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nabstract class Ordering<T> : Comparator<T> {\n\n    fun isOrdered(iterable: Iterable<T>): Boolean {\n        val it = iterable.iterator()\n        if (it.hasNext()) {\n            var prev: T = it.next()\n            while (it.hasNext()) {\n                val next = it.next()\n                if (compare(prev, next) > 0) {\n                    return false\n                }\n                prev = next\n            }\n        }\n        return true\n    }\n\n    /**\n     * @return immutable sorted list\n     */\n    fun <E : T> sortedCopy(elements: Iterable<E>): List<E> {\n        @Suppress(\"UNCHECKED_CAST\")\n        val array = Iterables.toArray(elements) as Array<E>\n        array.sortWith(object : Comparator<E> {\n            override fun compare(a: E, b: E): Int {\n                return this@Ordering.compare(a, b)\n            }\n        })\n        return array.toList()\n    }\n\n    fun reverse(): Ordering<T> {\n        return ComparatorOrdering(reversed())\n    }\n\n    fun <E : T> min(a: E, b: E): E {\n        return if (compare(a, b) <= 0) a else b\n    }\n\n    fun <E : T> min(iterable: Iterable<E>): E {\n        return min(iterable.iterator())\n    }\n\n    fun <E : T> min(iterator: Iterator<E>): E {\n        // input must not be empty\n        var result = iterator.next()\n        while (iterator.hasNext()) {\n            result = min(result, iterator.next())\n        }\n\n        return result\n    }\n\n\n    fun <E : T> max(a: E, b: E): E {\n        return if (compare(a, b) >= 0) a else b\n    }\n\n    fun <E : T> max(iterable: Iterable<E>): E {\n        return max(iterable.iterator())\n    }\n\n    fun <E : T> max(iterator: Iterator<E>): E {\n        // input must not be empty\n        var result = iterator.next()\n        while (iterator.hasNext()) {\n            result = max(result, iterator.next())\n        }\n\n        return result\n    }\n\n    companion object {\n\n        fun <T> from(comparator: Comparator<T>): Ordering<T> {\n            return if (comparator is Ordering<*>)\n                comparator as Ordering<T>\n            else\n                ComparatorOrdering(comparator)\n        }\n\n        fun <T : Comparable<T>> natural(): Ordering<T> {\n            return ComparatorOrdering(naturalOrder())\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nobject Sets {\n    /**\n     * Mutable set\n     */\n    fun <E> newHashSet(elements: Iterable<E>): MutableSet<E> {\n        if (elements is Collection<*>) {\n            val collection = elements as Collection<E>\n            return HashSet(collection)\n        }\n        return newHashSet(elements.iterator())\n    }\n\n    /**\n     * Mutable set\n     */\n    private fun <E> newHashSet(elements: Iterator<E>): MutableSet<E> {\n        val set = HashSet<E>()\n        while (elements.hasNext()) {\n            set.add(elements.next())\n        }\n        return set\n    }\n\n//    /**\n//     * Unmodifiable copy\n//     */\n//    fun <E> difference(set1: Set<E>, set2: Set<E>): Set<E> {\n//        val copy = HashSet(set1)\n//        copy.removeAll(set2)\n//        return copy\n//    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nclass Stack<T> {\n    private val elements: MutableList<T> = ArrayList()\n\n    fun empty() = elements.isEmpty()\n\n    fun push(item: T) = elements.add(item)\n\n    fun pop(): T? = if (elements.isEmpty()) null else elements.removeAt(elements.size - 1)\n\n    fun peek(): T? = elements.lastOrNull()\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nclass TreeMap<K : Comparable<K>, V> {\n    val values: Collection<V>\n        get() = map.values\n    private val sortedKeys: MutableList<K> = ArrayList()\n    private val map: MutableMap<K, V> = HashMap()\n\n    operator fun get(key: K): V? = map[key]\n\n    fun put(key: K, value: V): V? {\n        val index = sortedKeys.binarySearch(key)\n        if (index < 0) {\n            sortedKeys.add(index.inv(), key)\n        } else {\n            sortedKeys[index] = key\n        }\n        return map.put(key, value)\n    }\n\n    fun containsKey(key: K): Boolean = map.containsKey(key)\n\n    fun floorKey(key: K): K? {\n        var index = sortedKeys.binarySearch(key)\n\n        if (index < 0) {\n            index = index.inv() - 1\n\n            if (index < 0)\n                return null\n        }\n        return sortedKeys[index]\n    }\n\n    fun ceilingKey(key: K): K? {\n        var index = sortedKeys.binarySearch(key)\n\n        if (index < 0) {\n            index = index.inv()\n\n            if (index == sortedKeys.size)\n                return null\n        }\n        return sortedKeys[index]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass DoubleRectangle(val origin: DoubleVector, val dimension: DoubleVector) {\n\n    val center: DoubleVector\n        get() = origin.add(dimension.mul(0.5))\n\n    val left: Double\n        get() = origin.x\n\n    val right: Double\n        get() = origin.x + dimension.x\n\n    val top: Double\n        get() = origin.y\n\n    val bottom: Double\n        get() = origin.y + dimension.y\n\n    val width: Double\n        get() = dimension.x\n\n    val height: Double\n        get() = dimension.y\n\n    val parts: Iterable<DoubleSegment>\n        get() {\n            val result = ArrayList<DoubleSegment>()\n            result.add(DoubleSegment(origin, origin.add(DoubleVector(dimension.x, 0.0))))\n            result.add(DoubleSegment(origin, origin.add(DoubleVector(0.0, dimension.y))))\n            result.add(DoubleSegment(origin.add(dimension), origin.add(DoubleVector(dimension.x, 0.0))))\n            result.add(DoubleSegment(origin.add(dimension), origin.add(DoubleVector(0.0, dimension.y))))\n            return result\n        }\n\n    constructor(x: Double, y: Double, w: Double, h: Double) : this(DoubleVector(x, y), DoubleVector(w, h))\n\n    fun xRange(): ClosedRange<Double> {\n        return ClosedRange(origin.x, origin.x + dimension.x)\n    }\n\n    fun yRange(): ClosedRange<Double> {\n        return ClosedRange(origin.y, origin.y + dimension.y)\n    }\n\n    operator fun contains(v: DoubleVector): Boolean {\n        return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n    }\n\n    fun union(rect: DoubleRectangle): DoubleRectangle {\n        val newOrigin = origin.min(rect.origin)\n        val corner = origin.add(dimension)\n        val rectCorner = rect.origin.add(rect.dimension)\n        val newCorner = corner.max(rectCorner)\n        val newDimension = newCorner.subtract(newOrigin)\n        return DoubleRectangle(newOrigin, newDimension)\n    }\n\n    fun intersects(rect: DoubleRectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n    }\n\n    fun intersect(r: DoubleRectangle): DoubleRectangle? {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = r.origin\n        val r2 = r.origin.add(r.dimension)\n\n        val res1 = t1.max(r1)\n        val res2 = t2.min(r2)\n\n        val dim = res2.subtract(res1)\n\n        return if (dim.x < 0 || dim.y < 0) {\n            null\n        } else DoubleRectangle(res1, dim)\n\n    }\n\n    fun add(v: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(origin.add(v), dimension)\n    }\n\n    fun subtract(v: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(origin.subtract(v), dimension)\n    }\n\n    fun distance(to: DoubleVector): Double {\n        var result = 0.0\n        var hasResult = false\n        for (s in parts) {\n            if (!hasResult) {\n                result = s.distance(to)\n                hasResult = true\n            } else {\n                val distance = s.distance(to)\n                if (distance < result) {\n                    result = distance\n                }\n            }\n        }\n        return result\n    }\n\n    override fun hashCode(): Int {\n        return origin.hashCode() * 31 + dimension.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleRectangle) {\n            return false\n        }\n        val r = other as DoubleRectangle?\n        return r!!.origin.equals(origin) && r.dimension.equals(dimension)\n    }\n\n    override fun toString(): String {\n        return \"[rect $origin, $dimension]\"\n    }\n\n    companion object {\n        fun span(leftTop: DoubleVector, rightBottom: DoubleVector): DoubleRectangle {\n            return DoubleRectangle(leftTop, rightBottom.subtract(leftTop))\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject DoubleRectangles {\n\n    fun boundingBox(points: Iterable<DoubleVector>): DoubleRectangle {\n        return calculateBoundingBox(points, DoubleVector::x, DoubleVector::y)\n        { minX, minY, maxX, maxY ->\n            DoubleRectangle.span(\n                DoubleVector(minX, minY),\n                DoubleVector(maxX, maxY)\n            )\n        }\n    }\n\n    fun <PointT, BoxT> calculateBoundingBox(\n        points: Iterable<PointT>,\n        getX: (PointT) -> Double,\n        getY: (PointT) -> Double,\n        factory: (minX: Double, minY: Double, maxX: Double, maxY: Double) -> BoxT\n    ): BoxT {\n        val first = points.iterator().next()\n        var minLon = getX(first)\n        var minLat = getY(first)\n        var maxLon = minLon\n        var maxLat = minLat\n\n        for (point in points) {\n            minLon = min(minLon, getX(point))\n            maxLon = max(maxLon, getX(point))\n            minLat = min(minLat, getY(point))\n            maxLat = max(maxLat, getY(point))\n        }\n\n        return factory(minLon, minLat, maxLon, maxLat)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.min\n\nclass DoubleSegment(val start: DoubleVector, val end: DoubleVector) {\n\n    fun distance(v: DoubleVector): Double {\n        val vs = start.subtract(v)\n        val ve = end.subtract(v)\n\n        if (isDistanceToLineBest(v)) {\n            val pVolume = abs(vs.x * ve.y - vs.y * ve.x)\n            return pVolume / length()\n        } else {\n            return min(vs.length(), ve.length())\n        }\n    }\n\n    private fun isDistanceToLineBest(v: DoubleVector): Boolean {\n        val es = start.subtract(end)\n        val se = es.negate()\n        val ev = v.subtract(end)\n        val sv = v.subtract(start)\n\n        return es.dotProduct(ev) >= 0 && se.dotProduct(sv) >= 0\n    }\n\n    fun intersection(with: DoubleSegment): DoubleVector? {\n        val o1 = start\n        val o2 = with.start\n        val d1 = end.subtract(start)\n        val d2 = with.end.subtract(with.start)\n\n        val td = d1.dotProduct(d2.orthogonal())\n        if (td == 0.0) {\n            return null\n        }\n        val t = o2.subtract(o1).dotProduct(d2.orthogonal()) / td\n        if (t < 0 || t > 1) {\n            return null\n        }\n\n        val sd = d2.dotProduct(d1.orthogonal())\n        val s = o1.subtract(o2).dotProduct(d1.orthogonal()) / sd\n        return if (s < 0 || s > 1) {\n            null\n        } else o1.add(d1.mul(t))\n\n    }\n\n    fun length(): Double {\n        return start.subtract(end).length()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleSegment) {\n            return false\n        }\n\n        val l = other as DoubleSegment?\n        return l!!.start.equals(start) && l.end.equals(end)\n    }\n\n    override fun hashCode(): Int {\n        return start.hashCode() * 31 + end.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"[$start -> $end]\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.*\n\nclass DoubleVector(val x: Double, val y: Double) {\n\n    fun add(v: DoubleVector): DoubleVector {\n        return DoubleVector(x + v.x, y + v.y)\n    }\n\n    fun subtract(v: DoubleVector): DoubleVector {\n        return DoubleVector(x - v.x, y - v.y)\n    }\n\n    fun max(v: DoubleVector): DoubleVector {\n        return DoubleVector(max(x, v.x), max(y, v.y))\n    }\n\n    fun min(v: DoubleVector): DoubleVector {\n        return DoubleVector(min(x, v.x), min(y, v.y))\n    }\n\n    fun mul(value: Double): DoubleVector {\n        return DoubleVector(x * value, y * value)\n    }\n\n    fun dotProduct(v: DoubleVector): Double {\n        return x * v.x + y * v.y\n    }\n\n    fun negate(): DoubleVector {\n        return DoubleVector(-x, -y)\n    }\n\n    fun orthogonal(): DoubleVector {\n        return DoubleVector(-y, x)\n    }\n\n    fun length(): Double {\n        return sqrt(x * x + y * y)\n    }\n\n    fun normalize(): DoubleVector {\n        return mul(1 / length())\n    }\n\n    fun rotate(phi: Double): DoubleVector {\n        val x = this.x * cos(phi) - this.y * sin(phi)\n        val y = this.x * sin(phi) + this.y * cos(phi)\n        return DoubleVector(x, y)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleVector) {\n            return false\n        }\n        val v = other as DoubleVector?\n        return v!!.x == x && v.y == y\n    }\n\n    override fun hashCode(): Int {\n        return x.hashCode() + 31 * y.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"($x, $y)\"\n    }\n\n    companion object {\n        val ZERO = DoubleVector(0.0, 0.0)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass Rectangle(val origin: Vector, val dimension: Vector) {\n\n    val boundSegments: Array<Segment>\n        get() {\n            val p = boundPoints\n            return arrayOf<Segment>(Segment(p[0], p[1]), Segment(p[1], p[2]), Segment(p[2], p[3]), Segment(p[3], p[0]))\n        }\n\n    private val boundPoints: Array<Vector>\n        get() = arrayOf(origin, origin.add(Vector(dimension.x, 0)), origin.add(dimension), origin.add(Vector(0, dimension.y)))\n\n    constructor(x: Int, y: Int, width: Int, height: Int) : this(Vector(x, y), Vector(width, height))\n\n    fun add(v: Vector): Rectangle {\n        return Rectangle(origin.add(v), dimension)\n    }\n\n    fun sub(v: Vector): Rectangle {\n        return Rectangle(origin.sub(v), dimension)\n    }\n\n    operator fun contains(r: Rectangle): Boolean {\n        return contains(r.origin) && contains(r.origin.add(r.dimension))\n    }\n\n    operator fun contains(v: Vector): Boolean {\n        return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n    }\n\n    fun union(rect: Rectangle): Rectangle {\n        val newOrigin = origin.min(rect.origin)\n        val corner = origin.add(dimension)\n        val rectCorner = rect.origin.add(rect.dimension)\n        val newCorner = corner.max(rectCorner)\n        val newDimension = newCorner.sub(newOrigin)\n        return Rectangle(newOrigin, newDimension)\n    }\n\n    fun intersects(rect: Rectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n    }\n\n    fun intersect(r: Rectangle): Rectangle {\n        if (!intersects(r)) {\n            throw IllegalStateException(\"rectangle [$this] doesn't intersect [$r]\")\n        }\n\n        val too = origin.add(dimension)\n        val roo = r.origin.add(r.dimension)\n        val ioo = too.min(roo)\n\n        val io = origin.max(r.origin)\n        return Rectangle(io, ioo.sub(io))\n    }\n\n    fun innerIntersects(rect: Rectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x > t1.x && t2.x > r1.x && r2.y > t1.y && t2.y > r1.y\n    }\n\n    fun changeDimension(dim: Vector): Rectangle {\n        return Rectangle(origin, dim)\n    }\n\n    fun distance(to: Vector): Double {\n        return toDoubleRectangle().distance(to.toDoubleVector())\n    }\n\n    fun xRange(): ClosedRange<Int> {\n        return ClosedRange(origin.x, origin.x + dimension.x)\n    }\n\n    fun yRange(): ClosedRange<Int> {\n        return ClosedRange(origin.y, origin.y + dimension.y)\n    }\n\n    override fun hashCode(): Int {\n        return origin.hashCode() * 31 + dimension.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Rectangle) return false\n\n        val otherRect = other as Rectangle?\n        return origin == otherRect!!.origin && dimension == otherRect.dimension\n    }\n\n    private fun toDoubleRectangle(): DoubleRectangle {\n        return DoubleRectangle(origin.toDoubleVector(), dimension.toDoubleVector())\n    }\n\n    fun center(): Vector {\n        return origin.add(Vector(dimension.x / 2, dimension.y / 2))\n    }\n\n    override fun toString(): String {\n        return \"$origin - $dimension\"\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\n/**\n * X axis positive direction is right;\n * Y axis positive direction is down.\n */\nobject Rectangles {\n    fun zeroOrigin(r: Rectangle): Rectangle {\n        return Rectangle(Vector.ZERO, r.dimension)\n    }\n\n    fun upperDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topLeft(inner).y - topLeft(outer).y\n    }\n\n    fun lowerDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return bottomLeft(outer).y - bottomLeft(inner).y\n    }\n\n    fun leftDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topLeft(inner).x - topLeft(outer).x\n    }\n\n    fun rightDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topRight(outer).x - topRight(inner).x\n    }\n\n    private fun assertOuterInner(outer: Rectangle, inner: Rectangle) {\n        if (!outer.contains(inner)) {\n            throw IllegalArgumentException(\"Outer does not contain inner: outer = $outer, inner = $inner\")\n        }\n    }\n\n    fun extendUp(r: Rectangle, distance: Int): Rectangle {\n        val change = Vector(0, distance)\n        return Rectangle(r.origin.sub(change), r.dimension.add(change))\n    }\n\n    fun extendDown(r: Rectangle, distance: Int): Rectangle {\n        return r.changeDimension(r.dimension.add(Vector(0, distance)))\n    }\n\n    fun extendLeft(r: Rectangle, distance: Int): Rectangle {\n        val change = Vector(distance, 0)\n        return Rectangle(r.origin.sub(change), r.dimension.add(change))\n    }\n\n    fun extendRight(r: Rectangle, distance: Int): Rectangle {\n        return r.changeDimension(r.dimension.add(Vector(distance, 0)))\n    }\n\n    fun extendSides(left: Int, r: Rectangle, right: Int): Rectangle {\n        return extendRight(extendLeft(r, left), right)\n    }\n\n    fun shrinkRight(r: Rectangle, distance: Int): Rectangle {\n        if (r.dimension.x < distance) {\n            throw IllegalArgumentException(\"To small rectangle = $r, distance = $distance\")\n        }\n        return r.changeDimension(r.dimension.sub(Vector(distance, 0)))\n    }\n\n    private fun topLeft(r: Rectangle): Vector {\n        return r.origin\n    }\n\n    fun topRight(r: Rectangle): Vector {\n        return r.origin.add(Vector(r.dimension.x, 0))\n    }\n\n    private fun bottomLeft(r: Rectangle): Vector {\n        return r.origin.add(Vector(0, r.dimension.y))\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.min\n\nclass Segment(val start: Vector, val end: Vector) {\n\n    fun distance(v: Vector): Double {\n        val vs = start.sub(v)\n        val ve = end.sub(v)\n\n        if (isDistanceToLineBest(v)) {\n            val pVolume = abs(vs.x * ve.y - vs.y * ve.x).toDouble()\n            return pVolume / length()\n        } else {\n            return min(vs.toDoubleVector().length(), ve.toDoubleVector().length())\n        }\n    }\n\n    private fun isDistanceToLineBest(v: Vector): Boolean {\n        val es = start.sub(end)\n        val se = es.negate()\n        val ev = v.sub(end)\n        val sv = v.sub(start)\n\n        return es.dotProduct(ev) >= 0 && se.dotProduct(sv) >= 0\n    }\n\n    fun toDoubleSegment(): DoubleSegment {\n        return DoubleSegment(start.toDoubleVector(), end.toDoubleVector())\n    }\n\n    fun intersection(with: Segment): DoubleVector? {\n        return toDoubleSegment().intersection(with.toDoubleSegment())\n    }\n\n    fun length(): Double {\n        return start.sub(end).length()\n    }\n\n    operator fun contains(v: Vector): Boolean {\n        val p1 = v.sub(start)\n        val p2 = v.sub(end)\n        return if (p1.isParallel(p2)) {\n            p1.dotProduct(p2) <= 0\n        } else false\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Segment) {\n            return false\n        }\n\n        val l = other as Segment?\n        return l!!.start == start && l.end == end\n    }\n\n    override fun hashCode(): Int {\n        return start.hashCode() * 31 + end.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"[$start -> $end]\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\nimport kotlin.math.sqrt\n\nclass Vector(val x: Int, val y: Int) {\n\n    companion object {\n        val ZERO = Vector(0, 0)\n    }\n\n    fun add(v: Vector): Vector {\n        return Vector(x + v.x, y + v.y)\n    }\n\n    fun sub(v: Vector): Vector {\n        return add(v.negate())\n    }\n\n    fun negate(): Vector {\n        return Vector(-x, -y)\n    }\n\n    fun max(v: Vector): Vector {\n        return Vector(max(x, v.x), max(y, v.y))\n    }\n\n    fun min(v: Vector): Vector {\n        return Vector(min(x, v.x), min(y, v.y))\n    }\n\n    fun mul(i: Int): Vector {\n        return Vector(x * i, y * i)\n    }\n\n    operator fun div(i: Int): Vector {\n        return Vector(x / i, y / i)\n    }\n\n    fun dotProduct(v: Vector): Int {\n        return x * v.x + y * v.y\n    }\n\n    fun length(): Double {\n        return sqrt((x * x + y * y).toDouble())\n    }\n\n    fun toDoubleVector(): DoubleVector {\n        return DoubleVector(x.toDouble(), y.toDouble())\n    }\n\n    fun abs(): Vector {\n        return Vector(abs(x), abs(y))\n    }\n\n    fun isParallel(to: Vector): Boolean {\n        return x * to.y - to.x * y == 0\n    }\n\n    fun orthogonal(): Vector {\n        return Vector(-y, x)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Vector) return false\n\n        val otherVector = other as Vector?\n        return x == otherVector!!.x && y == otherVector.y\n    }\n\n    override fun hashCode(): Int {\n        return x * 31 + y\n    }\n\n    override fun toString(): String {\n        return \"($x, $y)\"\n    }\n\n//    operator fun get(axis: Axis): Int {\n//        val value: Int\n//        when (axis) {\n//            X -> value = x\n//            Y -> value = y\n//            else -> throw UnsupportedOperationException(\"unknown axis: $axis\")\n//        }\n//        return value\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.jsObject\n\nimport jetbrains.datalore.base.json.escape\n\nobject JsObjectSupport {\n    fun mapToJsObjectInitializer(map: Map<String, *>): String {\n        val buffer = StringBuilder()\n\n        var handleValue: (v: Any?) -> Unit = {}\n        val handleList = { list: List<*> ->\n            buffer.append('[')\n            var first = true\n            for (v in list) {\n                if (!first) buffer.append(',') else first = false\n                handleValue(v)\n            }\n            buffer.append(']')\n        }\n        @Suppress(\"NAME_SHADOWING\")\n        val handleMap = { map: Map<*, *> ->\n            buffer.append('{')\n            var first = true\n            for ((k, v) in map) {\n                k as? String ?: throw IllegalArgumentException(\n                    \"Only `string` keys are supported, was: ${k!!::class.simpleName ?: \"no class name\"}\"\n                )\n                if (!first) buffer.append(',') else first = false\n                buffer.append('\\n')\n                buffer.append('\"').append(k.escape()).append('\"').append(':')\n                handleValue(v)\n            }\n\n            buffer.append(\"\\n}\")\n        }\n        handleValue = { v: Any? ->\n            when (v) {\n                is String -> buffer.append('\"').append(v.escape()).append('\"')\n                is Boolean,\n                is Number -> buffer.append(v)\n                null -> buffer.append(\"null\")\n                is Array<*> -> handleList(v.asList())\n                is List<*> -> handleList(v)\n                is Map<*, *> -> handleMap(v)\n                else -> throw IllegalArgumentException(\"Can't serialize object $v\")\n            }\n        }\n\n        handleMap(map)\n        return buffer.toString()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\n\nclass FluentArray: FluentValue {\n    private val myArray: ArrayList<Any?>\n\n    constructor() {\n        myArray = ArrayList<Any?>()\n    }\n\n    constructor(array: List<Any?>) {\n        myArray = ArrayList<Any?>(array)\n    }\n\n    fun getDouble(index: Int) = myArray[index] as Double\n\n    fun add(v: String?) = apply { myArray.add(v) }\n    fun add(v: Double?) = apply { myArray.add(v) }\n    fun addStrings(values: List<String?>) = apply { myArray.addAll(values) }\n    fun addAll(values: List<FluentValue>) = apply { values.forEach { v -> myArray.add(v.get()) } }\n    fun addAll(vararg values: FluentValue) = apply { addAll(listOf(*values)) }\n\n    fun stream() = streamOf(myArray)\n    fun objectStream() = objectsStreamOf(myArray)\n    fun fluentObjectStream() = objectsStreamOf(myArray).map(::FluentObject)\n\n    override fun get() = myArray\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nimport jetbrains.datalore.base.function.Consumer\n\n\nclass FluentObject : FluentValue {\n    private val myObj: MutableMap<String, Any?>\n\n    constructor(obj: Map<*, *>) {\n        @Suppress(\"UNCHECKED_CAST\")\n        myObj = (obj as Map<String, Any?>).toMutableMap()\n    }\n\n    constructor() {\n        myObj = HashMap()\n\n   }\n    private fun getArr(key: String) = myObj[key] as Arr\n    private fun getObj(key: String) = myObj[key] as Obj\n\n    override fun get(): Obj = myObj\n    operator fun contains(key: String) = myObj.containsKey(key)\n    private fun containsNotNull(key: String) = contains(key) && myObj[key] != null\n\n    fun put(key: String, v: FluentValue?) = apply { myObj[key] = v?.get() }\n    fun put(key: String, v: String?) = apply { myObj[key] = v }\n    fun put(key: String, v: Number?) = apply { myObj[key] = v }\n    fun put(key: String, v: Boolean?) = apply { myObj[key] = v }\n    fun <T : Enum<T>> put(key: String, v: T?) = apply { myObj[key] = v?.let { formatEnum(it) } }\n\n    fun getInt(key: String) = myObj.getNumber(key).toInt()\n    fun getDouble(key: String) = myObj.getDouble(key)\n    fun getBoolean(key: String) = myObj[key] as Boolean\n    fun getString(key: String) = myObj[key] as String\n    fun getStrings(key: String) = getArr(key).map { getAsString(it) }\n    fun <T : Enum<T>> getEnum(key: String, enumValues: Array<T>) =\n        parseEnum<T>(myObj[key] as String, enumValues)\n    inline fun <reified T : Enum<T>> getEnum(key: String) = getEnum<T>(key, enumValues<T>())\n    fun getArray(key: String) = FluentArray(getArr(key))\n    fun getObject(key: String) = FluentObject(getObj(key))\n\n    fun getInt(key: String, processor: (Int) -> Unit) = apply { processor(getInt(key)) }\n    fun getDouble(key: String, processor: (Double) -> Unit) = apply { processor(getDouble(key)) }\n    fun getBoolean(key: String, processor: (Boolean) -> Unit) = apply { processor(getBoolean(key)) }\n    fun getString(key: String, processor: (String) -> Unit) = apply { processor(getString(key)) }\n    fun getStrings(key: String, processor: (List<String?>) -> Unit) = apply { processor(getStrings(key)) }\n    fun <T : Enum<T>> getEnum(key: String, processor: (T) -> Unit, enumValues: Array<T>) = apply { processor(getEnum(key, enumValues)) }\n    fun getArray(key: String, processor: (FluentArray) -> Unit) = apply { processor(getArray(key)) }\n    fun getObject(key: String, processor: (FluentObject) -> Unit) = apply { processor(getObject(key)) }\n\n    fun putRemovable(key: String, v: FluentValue?) = apply { v?.let { put(key, it) } }\n    fun <T : Enum<T>> putRemovable(key: String, v: T?) = apply { v?.let { put(key, it) } }\n\n    fun forEntries(consumer: (String, Any?) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it]) } }\n    fun forObjEntries(consumer: (String, Obj) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it] as Obj) } }\n    fun forArrEntries(consumer: (String, Arr) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it] as Arr) } }\n    fun accept(consumer: (FluentObject) -> Unit) = apply { consumer(this) }\n    fun forStrings(key: String, processor: (String?) -> Unit) = apply { myObj.getArr(key).map(::getAsString).forEach(processor) }\n\n\n    fun getExistingDouble(key: String, processor: Consumer<Double>) = apply {\n        if (containsNotNull(key)) {\n            getDouble(key, processor)\n        }\n    }\n\n    fun getOptionalStrings(key: String, processor: (List<String?>?) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getStrings(key))\n        } else {\n            processor(null)\n        }\n    }\n\n    fun getExistingString(key: String, processor: (String) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            getString(key, processor)\n        }\n    }\n\n    fun forExistingStrings(key: String, processor: (String) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            forStrings(key) { processor(it!!) }\n        }\n    }\n\n    fun getExistingObject(key: String, processor: (FluentObject) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            val obj = getObject(key)\n            if (obj.myObj.keys.isNotEmpty()) {\n                processor(obj)\n            }\n        }\n    }\n\n    fun getExistingArray(key: String, processor: (FluentArray) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getArray(key))\n        }\n    }\n\n    fun forObjects(key: String, processor: (FluentObject) -> Unit) = apply {\n        getArray(key).fluentObjectStream().forEach(processor)\n    }\n\n\n    fun getOptionalInt(key: String, processor: (Int?) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getInt(key))\n        } else {\n            processor(null)\n        }\n    }\n\n    fun getIntOrDefault(key: String, processor: (Int) -> Unit, defaultValue: Int) = apply {\n        if (containsNotNull(key)) {\n            processor(getInt(key))\n        } else {\n            processor(defaultValue)\n        }\n    }\n\n    fun <T : Enum<T>> forEnums(key: String, processor: (T) -> Unit, enumValues: Array<T>) = apply {\n        getArr(key).forEach { processor(parseEnum(it as String, enumValues)) }\n    }\n\n    fun <T : Enum<T>> getOptionalEnum(key: String, processor: (T?) -> Unit, enumValues: Array<T>) = apply {\n        when {\n            containsNotNull(key) -> processor(getEnum(key, enumValues))\n            else -> processor(null)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass FluentPrimitive : FluentValue {\n    private val value: Any?\n\n    constructor(v: Int?) {\n        value = v\n    }\n\n    constructor(v: String?) {\n        value = v\n    }\n\n    constructor(v: Boolean?) {\n        value = v\n    }\n\n    constructor(v: Number?) {\n        value = v\n    }\n\n    override fun get(): Any? {\n        return value\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\n\nabstract class FluentValue {\n    abstract fun get(): Any?\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass JsonFormatter {\n    private lateinit var buffer: StringBuilder\n\n    fun formatJson(o: Any): String {\n        buffer = StringBuilder()\n        handleValue(o)\n        return buffer.toString()\n    }\n\n    private fun handleList(list: List<*>) {\n        append(\"[\")\n        list.headTail(::handleValue) { tail -> tail.forEach { append(\",\"); handleValue(it) } }\n        append(\"]\")\n    }\n\n    private fun handleMap(map: Map<*, *>) {\n        append(\"{\")\n        map.entries.headTail(::handlePair) { tail -> tail.forEach { append(\",\\n\"); handlePair(it) } }\n        append(\"}\")\n    }\n\n    private fun handleValue(v: Any?) {\n        when (v) {\n            null -> append(\"null\")\n            is String -> handleString(v)\n            is Number, Boolean -> append(v.toString())\n            is Array<*> -> handleList(v.asList())\n            is List<*> -> handleList(v)\n            is Map<*, *> -> handleMap(v)\n            else -> throw IllegalArgumentException(\"Can't serialize object $v\")\n        }\n    }\n\n    private fun handlePair(pair: Map.Entry<Any?, Any?>) {\n        handleString(pair.key); append(\":\"); handleValue(pair.value)\n    }\n\n    private fun handleString(v: Any?) {\n        when (v) {\n            null -> {}\n            is String -> append(\"\\\"${v.escape()}\\\"\")\n            else -> throw IllegalArgumentException(\"Expected a string, but got '${v::class.simpleName}'\")\n        }\n    }\n\n    private fun append(s: String) = buffer.append(s)\n\n    private fun <E> Collection<E>.headTail(head: (E) -> Unit, tail: (Sequence<E>) -> Unit) {\n        if (!isEmpty()) {\n            head(first())\n            tail(asSequence().drop(1))\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\ninternal class JsonLexer(\n    private val input: String\n) {\n    private var i = 0\n    private var tokenStart = 0\n    var currentToken: Token? = null\n        private set\n\n    private val currentChar: Char\n        get() = input[i]\n\n    init {\n        nextToken() // read first token\n    }\n\n    fun nextToken() {\n        advanceWhile { it.isWhitespace() }\n\n        if (isFinished()) {\n            return\n        }\n\n        when {\n            currentChar == '{' -> Token.LEFT_BRACE.also { advance() }\n            currentChar == '}' -> Token.RIGHT_BRACE.also { advance() }\n            currentChar == '[' -> Token.LEFT_BRACKET.also { advance() }\n            currentChar == ']' -> Token.RIGHT_BRACKET.also { advance() }\n            currentChar == ',' -> Token.COMMA.also { advance() }\n            currentChar == ':' -> Token.COLON.also { advance() }\n            currentChar == 't' -> Token.TRUE.also { read(\"true\") }\n            currentChar == 'f' -> Token.FALSE.also { read(\"false\") }\n            currentChar == 'n' -> Token.NULL.also { read(\"null\") }\n            currentChar == '\"' -> Token.STRING.also { readString() }\n            readNumber() -> Token.NUMBER\n            else -> error(\"$i:${currentChar} - unkown token\")\n        }.also { currentToken = it }\n    }\n\n    fun tokenValue() = input.substring(tokenStart, i)\n\n    private fun readString() {\n        startToken()\n        advance() // opening quote\n        while(!(currentChar == '\"')) {\n            if(currentChar == '\\\\') {\n                advance()\n                when {\n                    currentChar == 'u' -> {\n                        advance()\n                        repeat(4) {\n                            require(currentChar.isHex());\n                            advance()\n                        }\n                    }\n                    currentChar in SPECIAL_CHARS -> advance()\n                    else -> error(\"Invalid escape sequence\")\n                }\n            } else {\n                advance()\n            }\n        }\n        advance() // closing quote\n    }\n\n    private fun readNumber(): Boolean {\n        if (!(currentChar.isDigit() || currentChar == '-')) {\n            return false\n        }\n\n        startToken()\n        advanceIfCurrent('-')\n        advanceWhile { it.isDigit() }\n\n        advanceIfCurrent('.') {\n            require(currentChar.isDigit()) { \"Number should have decimal part\" }\n            advanceWhile { it.isDigit() }\n        }\n\n        advanceIfCurrent('e', 'E') {\n            advanceIfCurrent('+', '-')\n            advanceWhile { it.isDigit() }\n        }\n\n        return true\n    }\n\n    fun isFinished(): Boolean = i == input.length\n    private fun startToken() { tokenStart = i }\n    private fun advance() { ++i }\n\n    private fun read(str: String) {\n        return str.forEach {\n            require(currentChar == it) { \"Wrong data: $str\" }\n            require(!isFinished()) { \"Unexpected end of string\" }\n            advance()\n        }\n    }\n\n    private fun advanceWhile(pred: (Char) -> Boolean) {\n        while (!isFinished() && pred(currentChar)) advance()\n    }\n\n    private fun advanceIfCurrent(vararg expected: Char, then: () -> Unit = {}) {\n        if (!isFinished() && currentChar in expected) {\n            advance()\n            then()\n        }\n    }\n\n    companion object {\n        private val digits: CharRange = '0'..'9'\n        private fun Char?.isDigit() = this in digits\n        private fun Char.isHex(): Boolean { return isDigit() || this in 'a'..'f' || this in 'A'..'F' }\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"RangesKt\")\n\npackage kotlin.ranges\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntRange.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongRange.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharRange.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntRange.random(random: Random): Int {\n    try {\n        return random.nextInt(this)\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongRange.random(random: Random): Long {\n    try {\n        return random.nextLong(this)\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharRange.random(random: Random): Char {\n    try {\n        return random.nextInt(first.code, last.code + 1).toChar()\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntRange.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongRange.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharRange.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntRange.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return random.nextInt(this)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongRange.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return random.nextLong(this)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharRange.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return random.nextInt(first.code, last.code + 1).toChar()\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun IntRange.contains(element: Int?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun LongRange.contains(element: Long?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun CharRange.contains(element: Char?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Byte): Boolean {\n    return contains(value.toInt())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Byte): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Byte): Boolean {\n    return contains(value.toShort())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Byte): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Byte): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Double): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Double): Boolean {\n    return value.toLongExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Double): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Double): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Double): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Float): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Float): Boolean {\n    return value.toLongExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Float): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Float): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Float): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Int): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Int): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Int): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Int): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Int): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Long): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Long): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Long): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Long): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Long): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Short): Boolean {\n    return contains(value.toInt())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Short): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Short): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Short): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Short): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this, to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Byte): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Char.downTo(to: Char): CharProgression {\n    return CharProgression.fromClosedRange(this, to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this, to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Int): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this, to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this, to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Short): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun IntProgression.reversed(): IntProgression {\n    return IntProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun LongProgression.reversed(): LongProgression {\n    return LongProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun CharProgression.reversed(): CharProgression {\n    return CharProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun IntProgression.step(step: Int): IntProgression {\n    checkStepIsPositive(step > 0, step)\n    return IntProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun LongProgression.step(step: Long): LongProgression {\n    checkStepIsPositive(step > 0, step)\n    return LongProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun CharProgression.step(step: Int): CharProgression {\n    checkStepIsPositive(step > 0, step)\n    return CharProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\ninternal fun Int.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toInt()..Byte.MAX_VALUE.toInt()) this.toByte() else null\n}\n\ninternal fun Long.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toLong()..Byte.MAX_VALUE.toLong()) this.toByte() else null\n}\n\ninternal fun Short.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toShort()..Byte.MAX_VALUE.toShort()) this.toByte() else null\n}\n\ninternal fun Double.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toDouble()..Byte.MAX_VALUE.toDouble()) this.toInt().toByte() else null\n}\n\ninternal fun Float.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toFloat()..Byte.MAX_VALUE.toFloat()) this.toInt().toByte() else null\n}\n\ninternal fun Long.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toLong()..Int.MAX_VALUE.toLong()) this.toInt() else null\n}\n\ninternal fun Double.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toDouble()..Int.MAX_VALUE.toDouble()) this.toInt() else null\n}\n\ninternal fun Float.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toFloat()..Int.MAX_VALUE.toFloat()) this.toInt() else null\n}\n\ninternal fun Double.toLongExactOrNull(): Long? {\n    return if (this in Long.MIN_VALUE.toDouble()..Long.MAX_VALUE.toDouble()) this.toLong() else null\n}\n\ninternal fun Float.toLongExactOrNull(): Long? {\n    return if (this in Long.MIN_VALUE.toFloat()..Long.MAX_VALUE.toFloat()) this.toLong() else null\n}\n\ninternal fun Int.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toInt()..Short.MAX_VALUE.toInt()) this.toShort() else null\n}\n\ninternal fun Long.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toLong()..Short.MAX_VALUE.toLong()) this.toShort() else null\n}\n\ninternal fun Double.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toDouble()..Short.MAX_VALUE.toDouble()) this.toInt().toShort() else null\n}\n\ninternal fun Float.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toFloat()..Short.MAX_VALUE.toFloat()) this.toInt().toShort() else null\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Byte): IntRange {\n    return this .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Byte): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Byte): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Byte): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Char.until(to: Char): CharRange {\n    if (to <= '\\u0000') return CharRange.EMPTY\n    return this .. (to - 1).toChar()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Int): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this.toInt() .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this.toInt() .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Short): IntRange {\n    return this .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Short): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Short): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Short): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeastComparable\n */\npublic fun <T : Comparable<T>> T.coerceAtLeast(minimumValue: T): T {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Byte.coerceAtLeast(minimumValue: Byte): Byte {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Short.coerceAtLeast(minimumValue: Short): Short {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Int.coerceAtLeast(minimumValue: Int): Int {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Long.coerceAtLeast(minimumValue: Long): Long {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Float.coerceAtLeast(minimumValue: Float): Float {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Double.coerceAtLeast(minimumValue: Double): Double {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMostComparable\n */\npublic fun <T : Comparable<T>> T.coerceAtMost(maximumValue: T): T {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Byte.coerceAtMost(maximumValue: Byte): Byte {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Short.coerceAtMost(maximumValue: Short): Short {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Int.coerceAtMost(maximumValue: Int): Int {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Long.coerceAtMost(maximumValue: Long): Long {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Float.coerceAtMost(maximumValue: Float): Float {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Double.coerceAtMost(maximumValue: Double): Double {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceInComparable\n */\npublic fun <T : Comparable<T>> T.coerceIn(minimumValue: T?, maximumValue: T?): T {\n    if (minimumValue !== null && maximumValue !== null) {\n        if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n        if (this < minimumValue) return minimumValue\n        if (this > maximumValue) return maximumValue\n    }\n    else {\n        if (minimumValue !== null && this < minimumValue) return minimumValue\n        if (maximumValue !== null && this > maximumValue) return maximumValue\n    }\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Byte.coerceIn(minimumValue: Byte, maximumValue: Byte): Byte {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Short.coerceIn(minimumValue: Short, maximumValue: Short): Short {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Int.coerceIn(minimumValue: Int, maximumValue: Int): Int {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Long.coerceIn(minimumValue: Long, maximumValue: Long): Long {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Float.coerceIn(minimumValue: Float, maximumValue: Float): Float {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Double.coerceIn(minimumValue: Double, maximumValue: Double): Double {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceInFloatingPointRange\n */\n@SinceKotlin(\"1.1\")\npublic fun <T : Comparable<T>> T.coerceIn(range: ClosedFloatingPointRange<T>): T {\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        // this < start equiv to this <= start && !(this >= start)\n        range.lessThanOrEquals(this, range.start) && !range.lessThanOrEquals(range.start, this) -> range.start\n        // this > end equiv to this >= end && !(this <= end)\n        range.lessThanOrEquals(range.endInclusive, this) && !range.lessThanOrEquals(this, range.endInclusive) -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceInComparable\n */\npublic fun <T : Comparable<T>> T.coerceIn(range: ClosedRange<T>): T {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<T>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Int.coerceIn(range: ClosedRange<Int>): Int {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<Int>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Long.coerceIn(range: ClosedRange<Long>): Long {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<Long>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass JsonParser(\n    private val json: String\n) {\n    fun parseJson(): Any? {\n        val lexer = JsonLexer(json)\n        return parseValue(lexer)\n    }\n\n    private fun parseValue(lexer: JsonLexer): Any? {\n        return when(lexer.currentToken) {\n            Token.STRING -> lexer.tokenValue().unescape().also { lexer.nextToken() }\n            Token.NUMBER -> lexer.tokenValue().toDouble().also { lexer.nextToken() }\n            Token.FALSE -> false.also { lexer.nextToken() }\n            Token.TRUE -> true.also { lexer.nextToken() }\n            Token.NULL -> null.also { lexer.nextToken() }\n            Token.LEFT_BRACE -> parseObject(lexer)\n            Token.LEFT_BRACKET -> parseArray(lexer)\n            else -> error(\"Invalid token: ${lexer.currentToken}\")\n        }\n    }\n\n    private fun parseArray(lexer: JsonLexer): MutableList<Any?> {\n        fun checkCurrentToken(token: Token) { require(lexer.currentToken, token, \"[Arr] \") }\n\n        val list = mutableListOf<Any?>()\n\n        checkCurrentToken(Token.LEFT_BRACKET)\n        lexer.nextToken()\n\n        while (lexer.currentToken != Token.RIGHT_BRACKET) {\n            if (list.isNotEmpty()) {\n                checkCurrentToken(Token.COMMA)\n                lexer.nextToken()\n            }\n            list.add(parseValue(lexer))\n        }\n\n        checkCurrentToken(Token.RIGHT_BRACKET)\n        lexer.nextToken()\n\n        return list\n    }\n\n    private fun parseObject(lexer: JsonLexer): Map<String, Any?> {\n        fun checkCurrentToken(token: Token) { require(lexer.currentToken, token, \"[Obj] \") }\n\n        val map = mutableMapOf<String, Any?>()\n\n        checkCurrentToken(Token.LEFT_BRACE)\n        lexer.nextToken()\n\n        while (lexer.currentToken != Token.RIGHT_BRACE) {\n            if (map.isNotEmpty()) {\n                checkCurrentToken(Token.COMMA)\n                lexer.nextToken()\n            }\n\n            checkCurrentToken(Token.STRING)\n            val key = lexer.tokenValue().unescape()\n            lexer.nextToken()\n\n            checkCurrentToken(Token.COLON)\n            lexer.nextToken()\n\n            val value = parseValue(lexer)\n            map[key] = value\n        }\n\n        checkCurrentToken(Token.RIGHT_BRACE)\n        lexer.nextToken()\n\n        return map\n    }\n\n    private fun require(current: Token?, expected: Token?, messagePrefix: String? = null) {\n        if (current != expected) {\n            throw JsonException(messagePrefix + \"Expected token: $expected, actual: $current\")\n        }\n    }\n\n    class JsonException(message: String) : Exception(message)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nobject JsonSupport {\n    fun parseJson(jsonString: String): MutableMap<String, Any?> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return JsonParser(jsonString).parseJson() as MutableMap<String, Any?>\n    }\n    fun formatJson(o: Any): String {\n        return JsonFormatter().formatJson(o)\n    }\n}\n\n\n// Usefull resources:\n// https://www.ietf.org/rfc/rfc4627.txt\n// https://github.com/nst/JSONTestSuite\n\ninternal enum class Token {\n    LEFT_BRACE,\n    RIGHT_BRACE,\n    LEFT_BRACKET,\n    RIGHT_BRACKET,\n    COMMA,\n    COLON,\n    STRING,\n    NUMBER,\n    TRUE,\n    FALSE,\n    NULL,\n}\n\ninternal val SPECIAL_CHARS = mapOf(\n    '\"' to '\"',\n    '\\\\' to '\\\\',\n    '/' to '/',\n    'b' to '\\b',\n    'f' to '\\u000C',\n    'n' to '\\n',\n    'r' to '\\r',\n    't' to '\\t'\n)\n\nprivate val CONTROL_CHARS = (0 until 0x20).map(Int::toChar).toSet()\n\nfun String.escape(): String {\n    var output: StringBuilder? = null\n    var i = 0\n\n    fun appendOutput(str: String) {\n        output = (output ?: StringBuilder(substring(0, i))).append(str)\n    }\n\n    while(i < length) {\n        when(val ch = get(i)) {\n            '\\\\' -> appendOutput(\"\"\"\\\\\"\"\")\n            '\"' -> appendOutput(\"\"\"\\\"\"\"\")\n            '\\n' -> appendOutput(\"\"\"\\n\"\"\")\n            '\\r' -> appendOutput(\"\"\"\\r\"\"\")\n            '\\t' -> appendOutput(\"\"\"\\t\"\"\")\n            in CONTROL_CHARS -> appendOutput(\"\"\"\\u${ch.code.toString(16).padStart(4, '0')}\"\"\")\n            else -> output?.append(ch)\n        }\n        i++\n    }\n    return output?.toString() ?: this\n}\n\nfun String.unescape(): String {\n    var output: StringBuilder? = null\n    val start = 1\n    val end = length - 1\n\n    var i = start\n    while(i < end) {\n        val ch = get(i)\n        if (ch == '\\\\') {\n            output = output ?: StringBuilder(substring(start, i))\n            when(val escapedChar = get(++i)) {\n                in SPECIAL_CHARS -> SPECIAL_CHARS[escapedChar].also { i++ }\n                'u' -> substring(i + 1, i + 5).toInt(16).toChar().also { i += 5 }\n                else -> throw JsonParser.JsonException(\"Invalid escape character: ${escapedChar}\")\n            }.let { output.append(it) }\n        } else {\n            output?.append(ch); i++\n        }\n    }\n    return output?.toString() ?: substring(start, end)\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin\n\n\n/**\n * Creates a Char with the specified [code], or throws an exception if the [code] is out of `Char.MIN_VALUE.code..Char.MAX_VALUE.code`.\n *\n * If the program that calls this function is written in a way that only valid [code] is passed as the argument,\n * using the overload that takes a [UShort] argument is preferable (`Char(intValue.toUShort())`).\n * That overload doesn't check validity of the argument, and may improve program performance when the function is called routinely inside a loop.\n *\n * @sample samples.text.Chars.charFromCode\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun Char(code: Int): Char {\n    if (code < Char.MIN_VALUE.code || code > Char.MAX_VALUE.code) {\n        throw IllegalArgumentException(\"Invalid Char code: $code\")\n    }\n    return code.toChar()\n}\n\n/**\n * Creates a Char with the specified [code].\n *\n * @sample samples.text.Chars.charFromCode\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun Char(code: UShort): Char\n\n/**\n * Returns the code of this Char.\n *\n * Code of a Char is the value it was constructed with, and the UTF-16 code unit corresponding to this Char.\n *\n * @sample samples.text.Chars.code\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\n@Suppress(\"DEPRECATION\")\npublic inline val Char.code: Int get() = this.toInt()\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\ntypealias Arr = List<*>\ntypealias Obj = Map<*, *>\n\nfun streamOf(arr: Arr): Sequence<*> = arr.asSequence()\nfun objectsStreamOf(arr: Arr): Sequence<Obj> = streamOf(arr).map { it as Obj }\nfun stringStreamOf(arr: Arr): Sequence<String?> = streamOf(arr).map { it as String? }\n\nfun isBoolean(e: Any) = e is Boolean\nfun isNumber(e: Any) = e is Number\nfun isString(e: Any) = e is String\n\nfun getAsDouble(v: Any) = (v as Number).toDouble()\nfun getAsInt(v: Any?) = (v as Number).toInt()\nfun getAsBoolean(v: Any) = v as Boolean\n\nfun containsString(obj: MutableMap<String, Any?>, key: String): Boolean =\n    when (val v = obj[key]) {\n        null, isString(v) -> true\n        else -> false\n    }\n\nfun getAsString(e: Any?): String? =\n    when (e) {\n        null -> null\n        else -> e as String\n    }\n\nfun <T : Enum<T>> parseEnum(enumStringValue: String, values: Array<T>): T =\n    values.first { mode -> mode.toString().equals(enumStringValue, ignoreCase = true) }\n\ninline fun <reified T : Enum<T>> parseEnum(enumStringValue: String): T = parseEnum(enumStringValue, enumValues<T>())\nfun <T : Enum<T>> formatEnum(enumValue: T): String = enumValue.toString().lowercase()\n\nfun <T : Enum<T>> FluentObject.put(key: String, v: Collection<T>) = this.put(key, v.map { formatEnum(it) })\nfun FluentObject.put(key: String, v: List<String>) = put(key, FluentArray().addStrings(v.map { it }))\n\nfun Map<*, *>.getNumber(key: String) = if (this[key] == null) 0.0 else this[key] as Number\nfun Map<*, *>.getDouble(key: String) = this.getNumber(key).toDouble()\nfun Map<*, *>.getString(key: String) = this[key] as String\nfun Map<*, *>.getObj(key: String) = this[key] as Obj\nfun Map<*, *>.getArr(key: String) = this[key] as Arr\n\n\n//    private fun toObject(v: Any?): Any? {\n//        return when (v) {\n//            null -> null\n//            is String -> v\n//            is Number -> v\n//            is Boolean -> v\n//            is Map<*, *> -> toMap(v)\n//            is List<*> -> toArray(v)\n//            else -> throw IllegalArgumentException(\"Unknown type: ${v.toString()}\")\n//        }\n//    }\n\n\n//    fun toMap(obj: JsonObject): Map<String, Any> {\n//        val res = HashMap<String, Any>()\n//\n//        for (key in obj.getKeys()) {\n//            toObject(obj[key]).ifPresent({ q -> res[key] = q })\n//        }\n//\n//        return res\n//    }\n//\n//    private fun toArray(arr: JsonArray): List<Any> {\n//        val res = ArrayList<Any>()\n//\n//        var i = 0\n//        val n = arr.size()\n//        while (i < n) {\n//            toObject(arr.get(i)).ifPresent(Consumer<Any> { res.add(it) })\n//            i++\n//        }\n//\n//        return res\n//    }\n//\n//\n//    fun readString(obj: JsonObject, key: String): String {\n//        if (!containsString(obj, key)) {\n//            throw IllegalStateException(\"JsonObject does not contain string: $key\")\n//        }\n//\n//        return obj.getString(key)\n//    }\n//\n//    fun containsBoolean(obj: JsonObject, key: String): Boolean {\n//        val v = obj[key]\n//        return isBoolean(v)\n//    }\n//\n//    fun readBoolean(obj: JsonObject, key: String): Boolean {\n//        return obj.getBoolean(key)\n//    }\n//\n//    // JsonNull counts as empty array\n//    fun containsArray(obj: JsonObject, key: String): Boolean {\n//        val arr = obj[key]\n//        return arr is JsonNull || arr is JsonArray\n//    }\n//\n//    // JsonNull -> empty array\n//    fun getArr(obj: JsonObject, key: String): JsonArray {\n//        val arr = obj[key]\n//        if (arr is JsonNull) {\n//            return JsonArray()\n//        } else if (arr is JsonArray) {\n//            return arr as JsonArray\n//        }\n//\n//        throw IllegalStateException(\"JsonObject does not contain array: $key\")\n//    }\n//\n//    fun readDouble(array: JsonArray, index: Int): Double {\n//        return array.getDouble(index)\n//    }\n//\n//    fun getOptional(obj: JsonObject, key: String): Optional<Any> {\n//        return if (!obj.getKeys().contains(key)) {\n//            Optional.empty()\n//        } else Optional.ofNullable(obj[key])\n//    }\n//\n//    fun getOptionalInt(v: Any): Optional<Int> {\n//        if (v is JsonNull) {\n//            return Optional.empty()\n//        } else if (isNumber(v)) {\n//            return Optional.of((v as JsonNumber).getIntValue())\n//        }\n//\n//        throw IllegalStateException(\"Object is not JsonNumber: \" + v.getClass().getName())\n//    }\n//\n//    fun readStringArray(obj: JsonObject, key: String): List<String> {\n//        return parseJsonArray(obj.getArr(key), { jsonValue -> (jsonValue as JsonString).getStringValue() })\n//    }\n//\n//    fun <T> parseJsonArray(jsonArray: JsonArray, converter: Function<Any, T>): List<T> {\n//        val resultArray = ArrayList<T>()\n//        jsonArray.forEach { jsonValue -> resultArray.add(converter.apply(jsonValue)) }\n//        return resultArray\n//    }\n//\n//\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.listMap\n\n/**\n * Memory efficient implementation of a map based on an array.\n *\n *\n * It works better than a HashMap and TreeMap on small sized collections.\n */\nclass ListMap<K, V> {\n\n    companion object {\n        private val EMPTY_ARRAY = arrayOfNulls<Any>(0)\n    }\n\n    private var myData = EMPTY_ARRAY\n\n    val isEmpty: Boolean\n        get() = size() == 0\n\n    fun containsKey(key: K): Boolean {\n        return findByKey(key) >= 0\n    }\n\n    fun remove(key: K): V? {\n        val index = findByKey(key)\n        if (index >= 0) {\n            val value = myData[index + 1]\n            removeAt(index)\n            @Suppress(\"UNCHECKED_CAST\")\n            return value as V?\n        } else {\n            return null\n        }\n    }\n\n    fun keySet(): MutableSet<K> {\n        return object : AbstractMutableSet<K>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun add(element: K): Boolean {\n                throw IllegalStateException(\"Not available in keySet\")\n            }\n\n            override fun iterator(): MutableIterator<K> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any? {\n                        return myData[index]\n                    }\n                })\n            }\n        }\n    }\n\n    fun values(): Collection<V?> {\n        return object : AbstractCollection<V?>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun iterator(): Iterator<V?> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any? {\n                        return myData[index + 1]\n                    }\n                })\n            }\n        }\n    }\n\n    fun entrySet(): Set<Entry> {\n        return object : AbstractSet<Entry>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun iterator(): Iterator<ListMap<K, V>.Entry> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any {\n                        return Entry(index)\n                    }\n                })\n            }\n        }\n    }\n\n    fun size(): Int {\n        return myData.size / 2\n    }\n\n    fun put(key: K, value: V?): V? {\n        val index = findByKey(key)\n        if (index >= 0) {\n            val oldValue = myData[index + 1]\n            myData[index + 1] = value\n            @Suppress(\"UNCHECKED_CAST\")\n            return oldValue as V?\n        }\n\n        val newArray = Array(myData.size + 2) { i ->\n            if (i < myData.size) myData[i] else null\n        }\n\n        newArray[myData.size] = key\n        newArray[myData.size + 1] = value\n        myData = newArray\n        return null\n    }\n\n    operator fun get(key: K): V? {\n        val index = findByKey(key)\n        return if (index == -1) {\n            null\n        } else {\n            @Suppress(\"UNCHECKED_CAST\")\n            myData[index + 1] as V?\n        }\n    }\n\n    override fun toString(): String {\n        val builder = StringBuilder()\n        builder.append(\"{\")\n        var i = 0\n        while (i < myData.size) {\n            val k = myData[i]\n            val v = myData[i + 1]\n            if (i != 0) {\n                builder.append(\",\")\n            }\n            builder.append(k).append(\"=\").append(v)\n            i += 2\n        }\n        builder.append(\"}\")\n\n        return builder.toString()\n    }\n\n    private fun <T> mapIterator(spec: IteratorSpec): MutableIterator<T> {\n        return object : MutableIterator<T> {\n            private var index = 0\n            private var nextCalled = false\n\n            override fun hasNext(): Boolean {\n                return index < myData.size\n            }\n\n            override fun next(): T {\n                if (!hasNext()) {\n                    throw NoSuchElementException()\n                }\n                nextCalled = true\n                @Suppress(\"UNCHECKED_CAST\")\n                val value = spec[index] as T\n                index += 2\n                return value\n            }\n\n            override fun remove() {\n                if (!nextCalled) {\n                    throw IllegalStateException()\n                }\n                index -= 2\n                removeAt(index)\n                nextCalled = false\n            }\n        }\n    }\n\n    private fun findByKey(key: K): Int {\n        var i = 0\n        while (i < myData.size) {\n            val k = myData[i]\n            if (key == k) {\n                return i\n            }\n            i += 2\n        }\n        return -1\n    }\n\n    private fun removeAt(index: Int) {\n        if (myData.size == 2) {\n            myData = EMPTY_ARRAY\n            return\n        }\n\n        val newArray = Array(myData.size - 2) { i ->\n            if (i < index) {\n                myData[i]\n            } else {\n                myData[i + 2]\n            }\n        }\n\n        myData = newArray\n    }\n\n    inner class Entry internal constructor(private val myIndex: Int) {\n        fun key(): K {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myData[myIndex] as K\n        }\n\n        fun value(): V? {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myData[myIndex + 1] as V?\n        }\n    }\n\n    private interface IteratorSpec {\n        operator fun get(index: Int): Any?\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.logging\n\nclass PrintlnLogger(val name: String) : Logger {\n    override fun error(e: Throwable, message: () -> String) {\n        println(\"ERR [$name] : ${message()}\")\n    }\n\n    override fun info(message: () -> String) {\n        println(\"INFO [$name] : ${message()}\")\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.math\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.geometry.Vector\nimport kotlin.math.*\n\nfun toRadians(degrees: Double): Double = degrees * PI / 180.0\nfun toDegrees(radians: Double): Double = radians * 180.0 / PI\n\nfun round(v: DoubleVector) = round(v.x, v.y)\nfun ceil(v: DoubleVector) = ceil(v.x, v.y)\n\nfun round(x: Double, y: Double): Vector {\n    return Vector(\n        round(x).toInt(),\n        round(y).toInt()\n    )\n}\n\n\nfun ceil(x: Double, y: Double): Vector {\n    return Vector(\n        ceil(x).toInt(),\n        ceil(y).toInt()\n    )\n}\n\n\nfun distance(vector: Vector, doubleVector: DoubleVector): Double {\n    val dx = doubleVector.x - vector.x\n    val dy = doubleVector.y - vector.y\n    return sqrt(dx * dx + dy * dy)\n}\n\n\nfun Int.ipow(e: Int): Double {\n    return this.toDouble().pow(e)\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.numberFormat\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat.NumberInfo.Companion.createNumberInfo\nimport kotlin.math.*\n\nfun length(v: Long): Int {\n    // log10 doesn't work for values 10^17 + 1, returning 17.0 instead of 17.00001\n\n    if (v == 0L) {\n        return 1\n    }\n\n    var len = 0\n    var rem = v\n    while (rem > 0) {\n        len++\n        rem /= 10\n    }\n\n    return len\n}\n\nclass NumberFormat(private val spec: Spec) {\n\n    constructor(spec: String) : this(create(spec))\n\n    data class Spec(\n        val fill: String = \" \",\n        val align: String = \">\",\n        val sign: String = \"-\",\n        val symbol: String,\n        val zero: Boolean,\n        val width: Int = -1,\n        val comma: Boolean,\n        val precision: Int = 6,\n        val type: String = \"\",\n        val trim: Boolean = false\n    )\n\n\n    data class NumberInfo(\n        val number: Double = 0.0,\n        val negative: Boolean = false,\n        val integerPart: Long = 0,\n        val fractionalPart: Long = 0,\n        val exponent: Int? = null\n    ) {\n        constructor(\n            number: Number,\n            integerPart: Long = 0,\n            fractionalPart: Long = 0,\n            exponent: Int? = null\n        ) : this(number.toDouble().absoluteValue, number.toDouble() < 0.0, integerPart, fractionalPart, exponent)\n\n        val fractionLeadingZeros = MAX_DECIMALS - length(fractionalPart)\n        val integerLength = length(integerPart)\n        val fractionString = \"0\".repeat(fractionLeadingZeros) + fractionalPart.toString().trimEnd('0')\n\n        companion object {\n            /**\n             * max fraction length we can format (as any other format library does)\n             */\n            private const val MAX_DECIMALS = 18\n            internal val MAX_DECIMAL_VALUE = 10.0.pow(MAX_DECIMALS).toLong()\n\n            internal fun createNumberInfo(num: Number): NumberInfo {\n                // frac: \"123\", exp: 8, double: 0.00000123\n                //   -> long: 000_001_230_000_000_000 (extended to max decimal digits)\n                val encodeFraction = { frac: String, exp: Int ->\n                    var fraction = frac\n                    // cutting the fraction if it longer than max decimal digits\n                    if (exp > MAX_DECIMALS) {\n                        fraction = frac.substring(0 until (frac.length - (exp - MAX_DECIMALS)))\n                    }\n                    fraction.toLong() * 10.0.pow((MAX_DECIMALS - exp).coerceAtLeast(0)).toLong()\n                }\n\n                val (intStr, fracStr, exponentString) =\n                    \"^(\\\\d+)\\\\.?(\\\\d+)?e?([+-]?\\\\d+)?\\$\"\n                        .toRegex()\n                        .find(num.toDouble().absoluteValue.toString().lowercase())\n                        ?.destructured\n                        ?: error(\"Wrong number: $num\")\n\n                val exponent: Int = exponentString.toIntOrNull() ?: 0\n\n                // number = 1.23456E+55\n                if (exponent.absoluteValue >= MAX_DECIMALS) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" -> 1\n                        integerPart = intStr.toLong(),\n                        // fraction part ignored intentionally\n                        fractionalPart = 0,\n                        // 55\n                        exponent = exponent\n                    )\n                }\n\n                check(exponent < MAX_DECIMALS)\n                // number = 1.23E-4. double: 0.000123\n                if (exponent < 0) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" + \"23\" -> 000_123_000_000_000_000L\n                        fractionalPart = encodeFraction(intStr + fracStr, exponent.absoluteValue + fracStr.length)\n                    )\n                }\n\n                check(exponent >= 0 && exponent <= MAX_DECIMALS)\n                // number = 1.234E+5, double: 123400.0\n                if (exponent >= fracStr.length) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" + \"234\" + \"00\" -> 123400\n                        integerPart = (intStr + fracStr + \"0\".repeat(exponent - fracStr.length)).toLong()\n                    )\n                }\n\n                check(exponent >= 0 && exponent < fracStr.length)\n                // number = 1.234567E+3, double: 1234.567\n                return NumberInfo(\n                    number = num,\n                    // \"1\" + \"[234]567\" -> 1234\n                    integerPart = (intStr + fracStr.substring(0 until exponent)).toLong(),\n                    // \"234[567]\" -> 567_000_000_000_000_000\n                    fractionalPart = fracStr.substring(exponent).run { encodeFraction(this, this.length) }\n                )\n            }\n        }\n    }\n\n    data class Output(\n        val body: FormattedNumber = FormattedNumber(),\n        val sign: String = \"\",\n        val prefix: String = \"\",\n        val suffix: String = \"\",\n        val padding: String = \"\"\n    )\n\n    data class FormattedNumber(\n        val integerPart: String = \"\",\n        val fractionalPart: String = \"\",\n        val exponentialPart: String = \"\"\n    ) {\n        val fractionalLength =\n            0.takeIf { fractionalPart.isEmpty() } ?: FRACTION_DELIMITER_LENGTH + fractionalPart.length\n        val fullLength = integerPart.length + fractionalLength + exponentialPart.length\n\n        override fun toString() =\n            \"$integerPart${FRACTION_DELIMITER.takeIf { fractionalPart.isNotEmpty() } ?: \"\"}$fractionalPart$exponentialPart\"\n    }\n\n    fun apply(num: Number): String {\n        val nonNumberString = handleNonNumbers(num)\n        if (nonNumberString != null) {\n            return nonNumberString\n        }\n\n        val numberInfo = createNumberInfo(num)\n        var output = Output()\n\n        output = computeBody(output, numberInfo)\n        output = trimFraction(output)\n\n        output = computeSign(output, numberInfo)\n        output = computePrefix(output)\n        output = computeSuffix(output)\n\n        if (spec.comma && !spec.zero) {\n            output = applyGroup(output)\n        }\n\n        output = computePadding(output)\n\n        if (spec.comma && spec.zero) {\n            output = applyGroup(output)\n        }\n\n        return getAlignedString(output)\n    }\n\n    private fun handleNonNumbers(num: Number): String? {\n        val number = num.toDouble()\n        return when {\n            number.isNaN() -> \"NaN\"\n            number == Double.NEGATIVE_INFINITY -> \"-Infinity\"\n            number == Double.POSITIVE_INFINITY -> \"+Infinity\"\n            else -> null\n        }\n    }\n\n\n    private fun getAlignedString(output: Output): String {\n        with(output) {\n            return when (spec.align) {\n                \"<\" -> \"$sign$prefix$body$suffix$padding\"\n                \"=\" -> \"$sign$prefix$padding$body$suffix\"\n                \"^\" -> {\n                    val stop = padding.length / 2\n                    \"${padding.slice(0 until stop)}$sign$prefix$body$suffix${padding.slice(stop until output.padding.length)}\"\n                }\n                else -> \"$padding$sign$prefix$body$suffix\"\n            }\n        }\n    }\n\n    private fun applyGroup(output: Output): Output {\n\n        val zeroPadding = output.padding.takeIf { spec.zero } ?: \"\"\n\n        val body = output.body\n        var fullIntStr = zeroPadding + body.integerPart\n        val commas = (ceil(fullIntStr.length / GROUP_SIZE.toDouble()) - 1).toInt()\n\n        val width = (spec.width - body.fractionalLength - body.exponentialPart.length)\n            .coerceAtLeast(body.integerPart.length + commas)\n\n        fullIntStr = group(fullIntStr)\n\n        if (fullIntStr.length > width) {\n            fullIntStr = fullIntStr.substring(fullIntStr.length - width)\n            if (fullIntStr.startsWith(',')) {\n                fullIntStr = \"0$fullIntStr\"\n            }\n        }\n\n        return output.copy(\n            body = body.copy(integerPart = fullIntStr),\n            padding = \"\".takeIf { spec.zero } ?: output.padding\n        )\n    }\n\n    private fun computeBody(res: Output, numberInfo: NumberInfo): Output {\n        val formattedNumber = when (spec.type) {\n            \"%\" -> toFixedFormat(createNumberInfo(numberInfo.number * 100), spec.precision)\n            \"c\" -> FormattedNumber(numberInfo.number.toString())\n            \"d\" -> toSimpleFormat(numberInfo, 0)\n            \"e\" -> toSimpleFormat(toExponential(numberInfo, spec.precision), spec.precision)\n            \"f\" -> toFixedFormat(numberInfo, spec.precision)\n            \"g\" -> toPrecisionFormat(numberInfo, spec.precision)\n            \"b\" -> FormattedNumber(numberInfo.number.roundToLong().toString(2))\n            \"o\" -> FormattedNumber(numberInfo.number.roundToLong().toString(8))\n            \"X\" -> FormattedNumber(numberInfo.number.roundToLong().toString(16).uppercase())\n            \"x\" -> FormattedNumber(numberInfo.number.roundToLong().toString(16))\n            \"s\" -> toSiFormat(numberInfo, spec.precision)\n            else -> throw IllegalArgumentException(\"Wrong type: ${spec.type}\")\n        }\n        return res.copy(body = formattedNumber)\n    }\n\n    private fun toExponential(numberInfo: NumberInfo, precision: Int = -1): NumberInfo {\n        val num = numberInfo.number\n        if (num < TYPE_E_MIN) {\n            return NumberInfo(0.0)\n        }\n\n        var e = if (numberInfo.integerPart == 0L) {\n            -(numberInfo.fractionLeadingZeros + 1)\n        } else {\n            numberInfo.integerLength - 1 +\n                    (numberInfo.exponent ?: 0)\n        }\n        val n = num / 10.0.pow(e)\n\n        var newInfo = createNumberInfo(n)\n\n        if (precision > -1) {\n            newInfo = roundToPrecision(newInfo, precision)\n        }\n\n        if (newInfo.integerLength > 1) {\n            e += 1\n            newInfo = createNumberInfo(n / 10)\n        }\n\n        return newInfo.copy(exponent = e)\n    }\n\n    private fun toPrecisionFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        if (numberInfo.integerPart == 0L) {\n            if (numberInfo.fractionalPart == 0L) {\n                return toFixedFormat(numberInfo, precision - 1)\n            }\n            return toFixedFormat(numberInfo, precision + numberInfo.fractionLeadingZeros)\n        } else {\n            if (numberInfo.integerLength > precision) {\n                return toSimpleFormat(toExponential(numberInfo, precision - 1), precision - 1)\n            }\n            return toFixedFormat(numberInfo, precision - numberInfo.integerLength)\n        }\n    }\n\n    private fun toFixedFormat(numberInfo: NumberInfo, precision: Int = 0): FormattedNumber {\n        if (precision <= 0) {\n            return FormattedNumber(numberInfo.number.roundToLong().toString())\n        }\n\n        val newNumberInfo = roundToPrecision(numberInfo, precision)\n\n        val completePrecision = if (numberInfo.integerLength < newNumberInfo.integerLength) {\n            precision - 1\n        } else {\n            precision\n        }\n\n        if (newNumberInfo.fractionalPart == 0L) {\n            return FormattedNumber(newNumberInfo.integerPart.toString(), \"0\".repeat(completePrecision))\n        }\n\n        val fractionString = newNumberInfo.fractionString.padEnd(completePrecision, '0')\n\n        return FormattedNumber(newNumberInfo.integerPart.toString(), fractionString)\n    }\n\n    private fun toSimpleFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        val exponentString = if (numberInfo.exponent != null) {\n            val expSign = if (numberInfo.exponent.sign >= 0) \"+\" else \"\"\n            \"e$expSign${numberInfo.exponent}\"\n        } else {\n            \"\"\n        }\n\n        val expNumberInfo =\n            createNumberInfo(numberInfo.integerPart + numberInfo.fractionalPart / NumberInfo.MAX_DECIMAL_VALUE.toDouble())\n\n        if (precision > -1) {\n            val formattedNumber = toFixedFormat(expNumberInfo, precision)\n            return formattedNumber.copy(exponentialPart = exponentString)\n        }\n\n        val integerString = expNumberInfo.integerPart.toString()\n        val fractionString = if (expNumberInfo.fractionalPart == 0L) \"\" else expNumberInfo.fractionString\n        return FormattedNumber(integerString, fractionString, exponentString)\n    }\n\n    private fun toSiFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        val expNumberInfo = if (numberInfo.exponent == null) {\n            toExponential(numberInfo, precision - 1)\n        } else {\n            numberInfo\n        }\n        val exponent = expNumberInfo.exponent ?: 0\n        val suffixExp = floor(exponent / 3.0).coerceAtLeast(-8.0).coerceAtMost(8.0).toInt() * 3\n        val newNumberInfo = createNumberInfo(numberInfo.number * 10.0.pow(-suffixExp))\n\n        val suffixIndex = 8 + suffixExp / 3\n        val exponentString = SI_SUFFIXES[suffixIndex]\n        val formattedNumber = toFixedFormat(newNumberInfo, precision - newNumberInfo.integerLength)\n        return formattedNumber.copy(exponentialPart = exponentString)\n    }\n\n    private fun roundToPrecision(numberInfo: NumberInfo, precision: Int = 0): NumberInfo {\n        val exp = numberInfo.exponent ?: 0\n        val totalPrecision = precision + exp\n\n        var fractionalPart: Long\n        var integerPart: Long\n\n        if (totalPrecision < 0) {\n            fractionalPart = 0L\n            val intShift = totalPrecision.absoluteValue\n            integerPart = if (numberInfo.integerLength <= intShift) {\n                0\n            } else {\n                numberInfo.integerPart / 10.0.pow(intShift).toLong() * 10.0.pow(intShift).toLong()\n            }\n        } else {\n            val precisionExp = NumberInfo.MAX_DECIMAL_VALUE / 10.0.pow(totalPrecision).toLong()\n            fractionalPart = if (precisionExp == 0L) {\n                numberInfo.fractionalPart\n            } else {\n                (numberInfo.fractionalPart.toDouble() / precisionExp).roundToLong() * precisionExp\n            }\n            integerPart = numberInfo.integerPart\n            if (fractionalPart == NumberInfo.MAX_DECIMAL_VALUE) {\n                fractionalPart = 0\n                ++integerPart\n            }\n        }\n\n        val num = integerPart + fractionalPart.toDouble() / NumberInfo.MAX_DECIMAL_VALUE\n\n        return numberInfo.copy(number = num, fractionalPart = fractionalPart, integerPart = integerPart)\n    }\n\n    private fun trimFraction(output: Output): Output {\n        if (!spec.trim || output.body.fractionalPart.isEmpty()) {\n            return output\n        }\n\n        val trimmedFraction = output.body.fractionalPart.trimEnd('0')\n        return output.copy(\n            body = output.body.copy(\n                fractionalPart = trimmedFraction\n            )\n        )\n    }\n\n    private fun computeSign(output: Output, numberInfo: NumberInfo): Output {\n        val isBodyZero = output.body.run { (integerPart.asSequence() + fractionalPart.asSequence()).all { it == '0' } }\n\n        val isNegative = numberInfo.negative && !isBodyZero\n        val signStr = if (isNegative) {\n            \"-\"\n        } else {\n            if (spec.sign != \"-\") spec.sign else \"\"\n        }\n        return output.copy(sign = signStr)\n    }\n\n    private fun computePrefix(output: Output): Output {\n        val prefix = when (spec.symbol) {\n            \"$\" -> CURRENCY\n            \"#\" -> if (\"boxX\".indexOf(spec.type) > -1) \"0${spec.type.lowercase()}\" else \"\"\n            else -> \"\"\n        }\n        return output.copy(prefix = prefix)\n    }\n\n    private fun computeSuffix(res: Output): Output {\n        return res.copy(\n            suffix = PERCENT.takeIf { spec.type == \"%\" }.orEmpty()\n        )\n    }\n\n    private fun computePadding(output: Output): Output {\n        val length = output.sign.length + output.prefix.length + output.body.fullLength + output.suffix.length\n        val padding = if (length < spec.width) spec.fill.repeat(spec.width - length) else \"\"\n        return output.copy(padding = padding)\n    }\n\n    companion object {\n        const val TYPE_E_MIN = 1E-323 // Will likely crash on smaller numbers.\n        const val TYPE_S_UPPER_LIMiT = 1E40  // Will likely crash on bigger numbers.\n        const val TYPE_S_MAX = 1E26  // The largest supported SI-prefix is Y - yotta (1.E24).\n\n        private const val CURRENCY = \"$\"\n        private const val PERCENT = \"%\"\n        private const val COMMA = \",\"\n        private const val FRACTION_DELIMITER = \".\"\n        private const val FRACTION_DELIMITER_LENGTH = FRACTION_DELIMITER.length\n        private const val GROUP_SIZE = 3\n        private val SI_SUFFIXES =\n            arrayOf(\"y\", \"z\", \"a\", \"f\", \"p\", \"n\", \"µ\", \"m\", \"\", \"k\", \"M\", \"G\", \"T\", \"P\", \"E\", \"Z\", \"Y\")\n\n        fun create(spec: String): Spec {\n            return create(parse(spec))\n        }\n\n        fun create(spec: Spec): Spec {\n            var precision = spec.precision\n            var type = spec.type\n            var trim = false\n            if (type == \"\") {\n                if (precision == -1) {\n                    precision = 12\n                }\n                type = \"g\"\n            }\n\n            if (type == \"g\") {\n                trim = true\n            }\n\n            var zero = spec.zero\n            var fill = spec.fill\n            var align = spec.align\n            if (zero || (fill == \"0\" && align == \"=\")) {\n                zero = true\n                fill = \"0\"\n                align = \"=\"\n            }\n\n            return spec.copy(type = type, precision = precision, zero = zero, fill = fill, align = align, trim = trim)\n        }\n\n        private val NUMBER_REGEX =\n            \"\"\"^(?:([^{}])?([<>=^]))?([+ -])?([#$])?(0)?(\\d+)?(,)?(?:\\.(\\d+))?([%bcdefgosXx])?$\"\"\".toRegex()\n\n        fun isValidPattern(spec: String) = NUMBER_REGEX.matches(spec)\n\n        private fun parse(spec: String): Spec {\n            val matchResult = NUMBER_REGEX.find(spec) ?: throw IllegalArgumentException(\"Wrong pattern format\")\n\n            return Spec(\n                fill = matchResult.groups[1]?.value ?: \" \",\n                align = matchResult.groups[2]?.value ?: \">\",\n                sign = matchResult.groups[3]?.value ?: \"-\",\n                symbol = matchResult.groups[4]?.value ?: \"\",\n                zero = matchResult.groups[5] != null,\n                width = (matchResult.groups[6]?.value ?: \"-1\").toInt(),\n                comma = matchResult.groups[7] != null,\n                precision = (matchResult.groups[8]?.value ?: \"6\").toInt(),\n                type = matchResult.groups[9]?.value ?: \"\"\n            )\n        }\n\n        private fun group(str: String) = str\n            .reversed() // 1234 -> 4321\n            .asSequence() // [4,3,2,1]\n            .chunked(GROUP_SIZE) // [[4,3,2], [1]]\n            .map { it.joinToString(\"\") } // [[432], [1]]\n            .joinToString(COMMA) // 432,1\n            .reversed() // 1,234\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\n/**\n * Represents a collection of captured groups in a single match of a regular expression.\n *\n * This collection has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n *\n * An element of the collection at the particular index can be `null`,\n * if the corresponding group in the regular expression is optional and\n * there was no match captured by that group.\n */\npublic interface MatchGroupCollection : Collection<MatchGroup?> {\n\n    /** Returns a group with the specified [index].\n     *\n     * @return An instance of [MatchGroup] if the group with the specified [index] was matched or `null` otherwise.\n     *\n     * Groups are indexed from 1 to the count of groups in the regular expression. A group with the index 0\n     * corresponds to the entire match.\n     */\n    public operator fun get(index: Int): MatchGroup?\n}\n\n/**\n * Extends [MatchGroupCollection] by introducing a way to get matched groups by name, when regex supports it.\n */\n@SinceKotlin(\"1.1\")\npublic interface MatchNamedGroupCollection : MatchGroupCollection {\n    /**\n     * Returns a named group with the specified [name].\n     * @return An instance of [MatchGroup] if the group with the specified [name] was matched or `null` otherwise.\n     * @throws IllegalArgumentException if there is no group with the specified [name] defined in the regex pattern.\n     * @throws UnsupportedOperationException if getting named groups isn't supported on the current platform.\n     */\n    public operator fun get(name: String): MatchGroup?\n}\n\n/**\n * Represents the results from a single regular expression match.\n */\npublic interface MatchResult {\n    /** The range of indices in the original string where match was captured. */\n    public val range: IntRange\n    /** The substring from the input string captured by this match. */\n    public val value: String\n    /**\n     * A collection of groups matched by the regular expression.\n     *\n     * This collection has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n     * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n     */\n    public val groups: MatchGroupCollection\n    /**\n     * A list of matched indexed group values.\n     *\n     * This list has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n     * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n     *\n     * If the group in the regular expression is optional and there were no match captured by that group,\n     * corresponding item in [groupValues] is an empty string.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public val groupValues: List<String>\n\n    /**\n     * An instance of [MatchResult.Destructured] wrapper providing components for destructuring assignment of group values.\n     *\n     * component1 corresponds to the value of the first group, component2 — of the second, and so on.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public val destructured: Destructured get() = Destructured(this)\n\n    /** Returns a new [MatchResult] with the results for the next match, starting at the position\n     *  at which the last match ended (at the character after the last matched character).\n     */\n    public fun next(): MatchResult?\n\n    /**\n     * Provides components for destructuring assignment of group values.\n     *\n     * [component1] corresponds to the value of the first group, [component2] — of the second, and so on.\n     *\n     * If the group in the regular expression is optional and there were no match captured by that group,\n     * corresponding component value is an empty string.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public class Destructured internal constructor(public val match: MatchResult) {\n        @kotlin.internal.InlineOnly\n        public operator inline fun component1():  String = match.groupValues[1]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component2():  String = match.groupValues[2]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component3():  String = match.groupValues[3]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component4():  String = match.groupValues[4]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component5():  String = match.groupValues[5]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component6():  String = match.groupValues[6]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component7():  String = match.groupValues[7]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component8():  String = match.groupValues[8]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component9():  String = match.groupValues[9]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component10(): String = match.groupValues[10]\n\n        /**\n         *  Returns destructured group values as a list of strings.\n         *  First value in the returned list corresponds to the value of the first group, and so on.\n         *\n         * @sample samples.text.Regexps.matchDestructuringToGroupValues\n         */\n        public fun toList(): List<String> = match.groupValues.subList(1, match.groupValues.size)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.collections.CollectionAdapter\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.list.ObservableArrayList\n\nopen class ChildList<ParentT, ChildT : SimpleComposite<in ParentT?, in ChildT>>(private val myParent: ParentT) :\n        ObservableArrayList<ChildT>() {\n\n    init {\n        addListener(object : CollectionAdapter<ChildT>() {\n            override fun onItemAdded(event: CollectionItemEvent<out ChildT>) {\n                event.newItem!!.parent().flush()\n            }\n\n            override fun onItemRemoved(event: CollectionItemEvent<out ChildT>) {\n                val item = event.oldItem\n                item!!.parent().set(null)\n                item.setPositionData(null)\n                item.parent().flush()\n            }\n        })\n    }\n\n    override fun checkAdd(index: Int, item: ChildT) {\n        super.checkAdd(index, item)\n        if (item.parent().get() != null) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    override fun beforeItemAdded(index: Int, item: ChildT) {\n        item.parent().set(myParent)\n        item.setPositionData(object :\n            PositionData<ChildT> {\n            override fun get(): Position<ChildT> {\n                @Suppress(\"NAME_SHADOWING\")\n                val index = indexOf(item)\n                return object : Position<ChildT> {\n\n                    override val role: Any\n                        get() = this@ChildList\n\n                    override fun get(): ChildT? {\n                        return if (size <= index) null else this@ChildList.get(index)\n                    }\n                }\n            }\n\n            override fun remove() {\n                this@ChildList.remove(item)\n            }\n        })\n    }\n\n    override fun checkSet(index: Int, oldItem: ChildT, newItem: ChildT) {\n        super.checkSet(index, oldItem, newItem)\n        checkRemove(index, oldItem)\n        checkAdd(index, newItem)\n    }\n\n    override fun beforeItemSet(index: Int, oldItem: ChildT, newItem: ChildT) {\n        beforeItemAdded(index, newItem)\n    }\n\n    override fun checkRemove(index: Int, item: ChildT) {\n        super.checkRemove(index, item)\n        if (item.parent().get() !== myParent) {\n            throw IllegalArgumentException()\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.property.ValueProperty\n\nclass ChildProperty<ParentT, ChildT : SimpleComposite<in ParentT?, in ChildT>>(private val myParent: ParentT) :\n        ValueProperty<ChildT?>(null) {\n\n    override fun set(value: ChildT?) {\n        if (get() === value) return\n\n        if (value != null && value.parent().get() != null) {\n            throw IllegalStateException()\n        }\n\n        val oldValue = get()\n        if (oldValue != null) {\n            oldValue.parent().set(null)\n            oldValue.setPositionData(null)\n        }\n        if (value != null) {\n            value.parent().set(myParent)\n            value.setPositionData(object :\n                PositionData<ChildT> {\n                override fun get(): Position<ChildT> {\n                    return object : Position<ChildT> {\n\n                        override val role: Any\n                            get() = this@ChildProperty\n\n                        override fun get(): ChildT? {\n                            return this@ChildProperty.get()\n                        }\n                    }\n                }\n\n                override fun remove() {\n                    set(null)\n                }\n            })\n        }\n\n        super.set(value)\n\n        if (oldValue != null) {\n            oldValue.parent().flush()\n        }\n        value?.parent()?.flush()\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.property.DelayedValueProperty\nimport kotlin.js.JsName\n\nopen class SimpleComposite<ParentT, SiblingT> {\n    private val myParent = DelayedValueProperty<ParentT>()\n    private var myPositionData: PositionData<out SiblingT>? = null\n\n    val position: Position<out SiblingT>\n        get() {\n            if (myPositionData == null) {\n                throw IllegalStateException()\n            }\n            return myPositionData!!.get()\n        }\n\n    fun removeFromParent() {\n        if (myPositionData == null) return\n        myPositionData!!.remove()\n    }\n\n    @JsName(\"parentProperty\")   // `parent` clashes with HasParent.parent\n    fun parent(): DelayedValueProperty<ParentT> {\n        return myParent\n    }\n\n    fun setPositionData(positionData: PositionData<out SiblingT>?) {\n        myPositionData = positionData\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections\n\nopen class CollectionAdapter<ItemT> :\n    CollectionListener<ItemT> {\n    override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {}\n\n    override fun onItemSet(event: CollectionItemEvent<out ItemT>) {\n        onItemRemoved(\n            CollectionItemEvent(\n                event.oldItem,\n                null,\n                event.index,\n                CollectionItemEvent.EventType.REMOVE\n            )\n        )\n        onItemAdded(\n            CollectionItemEvent(\n                null,\n                event.newItem,\n                event.index,\n                CollectionItemEvent.EventType.ADD\n            )\n        )\n    }\n\n    override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {}\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections\n\nimport jetbrains.datalore.base.observable.event.ListenerEvent\n\nclass CollectionItemEvent<ItemT>(\n        val oldItem: ItemT?,\n        val newItem: ItemT?,\n        val index: Int,\n        val type: EventType\n) :\n        ListenerEvent<CollectionListener<ItemT>> {\n\n    init {\n        if (EventType.ADD == type && oldItem != null || EventType.REMOVE == type && newItem != null) {\n            throw IllegalStateException()\n        }\n    }\n\n    override fun dispatch(l: CollectionListener<ItemT>) {\n        if (EventType.ADD == type) {\n            l.onItemAdded(this)\n        } else if (EventType.SET == type) {\n            l.onItemSet(this)\n        } else {\n            l.onItemRemoved(this)\n        }\n    }\n\n    override fun toString(): String {\n        return if (EventType.ADD == type) {\n            newItem.toString() + \" added at \" + index\n        } else if (EventType.SET == type) {\n            oldItem.toString() + \" replaced with \" + newItem + \" at \" + index\n        } else {\n            oldItem.toString() + \" removed at \" + index\n        }\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as CollectionItemEvent<*>\n\n        if (oldItem != other.oldItem) return false\n        if (newItem != other.newItem) return false\n        if (index != other.index) return false\n        if (type != other.type) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = oldItem?.hashCode() ?: 0\n        result = 31 * result + (newItem?.hashCode() ?: 0)\n        result = 31 * result + index\n        result = 31 * result + type.hashCode()\n        return result\n    }\n\n    enum class EventType {\n        ADD, SET, REMOVE\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections.list\n\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.CollectionListener\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\n\nabstract class AbstractObservableList<ItemT> : AbstractMutableList<ItemT>(),\n    ObservableList<ItemT> {\n    private var myListeners: Listeners<CollectionListener<in ItemT>>? = null\n\n    protected open fun checkAdd(index: Int, item: ItemT) {\n        if (index < 0 || index > size) {\n            throw IndexOutOfBoundsException(\"Add: index=$index, size=$size\")\n        }\n    }\n\n    protected open fun checkSet(index: Int, oldItem: ItemT, newItem: ItemT) {\n        if (index < 0 || index >= size) {\n            throw IndexOutOfBoundsException(\"Set: index=$index, size=$size\")\n        }\n    }\n\n    protected open fun checkRemove(index: Int, item: ItemT) {\n        if (index < 0 || index >= size) {\n            throw IndexOutOfBoundsException(\"Remove: index=$index, size=$size\")\n        }\n    }\n\n    override fun add(index: Int, element: ItemT) {\n        checkAdd(index, element)\n        beforeItemAdded(index, element)\n        var success = false\n        try {\n            doAdd(index, element)\n            success = true\n            onItemAdd(index, element)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(null, element, index, CollectionItemEvent.EventType.ADD)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemAdded(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemAdded(index, element, success)\n        }\n    }\n\n    protected abstract fun doAdd(index: Int, item: ItemT)\n\n    protected open fun beforeItemAdded(index: Int, item: ItemT) {}\n\n    protected open fun onItemAdd(index: Int, item: ItemT) {}\n\n    protected open fun afterItemAdded(index: Int, item: ItemT, success: Boolean) {}\n\n    override operator fun set(index: Int, element: ItemT): ItemT {\n        val old = get(index)\n        checkSet(index, old, element)\n        beforeItemSet(index, old, element)\n        var success = false\n        try {\n            doSet(index, element)\n            success = true\n            onItemSet(index, old, element)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(old, element, index, CollectionItemEvent.EventType.SET)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemSet(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemSet(index, old, element, success)\n        }\n        return old\n    }\n\n    protected open fun doSet(index: Int, item: ItemT) {\n        doRemove(index)\n        doAdd(index, item)\n    }\n\n    protected open fun beforeItemSet(index: Int, oldItem: ItemT, newItem: ItemT) {}\n\n    protected open fun onItemSet(index: Int, oldItem: ItemT, newItem: ItemT) {}\n\n    protected open fun afterItemSet(index: Int, oldItem: ItemT, newItem: ItemT, success: Boolean) {}\n\n    override fun removeAt(index: Int): ItemT {\n        val item = get(index)\n        checkRemove(index, item)\n        beforeItemRemoved(index, item)\n        var success = false\n        try {\n            doRemove(index)\n            success = true\n            onItemRemove(index, item)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(item, null, index, CollectionItemEvent.EventType.REMOVE)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemRemoved(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemRemoved(index, item, success)\n        }\n        return item\n    }\n\n    protected abstract fun doRemove(index: Int)\n\n    protected open fun beforeItemRemoved(index: Int, item: ItemT) {}\n\n    protected open fun onItemRemove(index: Int, item: ItemT) {}\n\n    protected open fun afterItemRemoved(index: Int, item: ItemT, success: Boolean) {}\n\n    override fun addListener(l: CollectionListener<in ItemT>): Registration {\n        if (myListeners == null) {\n            myListeners = object : Listeners<CollectionListener<in ItemT>>() {\n                override fun beforeFirstAdded() {\n                    onListenersAdded()\n                }\n\n                override fun afterLastRemoved() {\n                    myListeners = null\n                    onListenersRemoved()\n                }\n            }\n        }\n\n        return myListeners!!.add(l)\n    }\n\n    override fun addHandler(handler: EventHandler<CollectionItemEvent<out ItemT>>): Registration {\n        val listener = object :\n            CollectionListener<ItemT> {\n            override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n\n            override fun onItemSet(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n\n            override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n        }\n        return addListener(listener)\n    }\n\n    protected open fun onListenersAdded() {}\n\n    protected open fun onListenersRemoved() {}\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections.list\n\n\nopen class ObservableArrayList<ItemT> : AbstractObservableList<ItemT>() {\n    private var myContainer: MutableList<ItemT>? = null\n\n    override val size: Int\n        get() = if (myContainer == null) 0 else myContainer!!.size\n\n    override operator fun get(index: Int): ItemT {\n        if (myContainer == null) {\n            throw IndexOutOfBoundsException(\"$index\")\n        }\n\n        return myContainer!![index]\n    }\n\n    override fun doAdd(index: Int, item: ItemT) {\n        ensureContainerInitialized()\n        myContainer!!.add(index, item)\n    }\n\n    override fun doSet(index: Int, item: ItemT) {\n        myContainer!![index] = item\n    }\n\n    override fun doRemove(index: Int) {\n        myContainer!!.removeAt(index)\n        if (myContainer!!.isEmpty()) {\n            myContainer = null\n        }\n    }\n\n    private fun ensureContainerInitialized() {\n        if (myContainer == null) {\n            myContainer = ArrayList(1)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.registration.Registration\n\ninternal class CompositeEventSource<EventT> : EventSource<EventT> {\n    private var myHandlers: Listeners<EventHandler<EventT>>? = null\n    private val myEventSources = ArrayList<EventSource<EventT>>()\n    private val myRegistrations = ArrayList<Registration>()\n\n    constructor(vararg sources: EventSource<EventT>) {\n        for (s in sources) {\n            add(s)\n        }\n    }\n\n    constructor(sources: Iterable<EventSource<EventT>>) {\n        for (s in sources) {\n            add(s)\n        }\n    }\n\n    fun add(source: EventSource<EventT>) {\n        myEventSources.add(source)\n    }\n\n    fun remove(source: EventSource<out EventT>) {\n        myEventSources.remove(source)\n    }\n\n    override fun addHandler(handler: EventHandler<EventT>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<EventT>>() {\n                override fun beforeFirstAdded() {\n                    for (src in myEventSources) {\n                        addHandlerTo(src)\n                    }\n                }\n\n                override fun afterLastRemoved() {\n                    for (hr in myRegistrations) {\n                        hr.remove()\n                    }\n                    myRegistrations.clear()\n                    myHandlers = null\n                }\n            }\n        }\n        return myHandlers!!.add(handler)\n    }\n\n    private fun <PartEventT : EventT> addHandlerTo(src: EventSource<PartEventT>) {\n        myRegistrations.add(src.addHandler(object : EventHandler<PartEventT> {\n            override fun onEvent(event: PartEventT) {\n                myHandlers!!.fire(object : ListenerCaller<EventHandler<EventT>> {\n                    override fun call(l: EventHandler<EventT>) {\n                        l.onEvent(event)\n                    }\n                })\n            }\n        }))\n    }\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.function.Predicate\nimport jetbrains.datalore.base.observable.collections.CollectionAdapter\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.list.ObservableList\nimport jetbrains.datalore.base.registration.Registration\n\nobject EventSources {\n    /**\n     * Event source which always dispatched the same events on subscription. It's useful for testing and\n     * composition. In Rx-like libraries a similar thing is called cold observable.\n     */\n    fun <EventT> of(vararg events: EventT): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                for (e in events) {\n                    handler.onEvent(e)\n                }\n                return Registration.EMPTY\n            }\n        }\n    }\n\n    fun <EventT> empty(): EventSource<EventT> {\n        return composite<EventT>()\n    }\n\n    fun <EventT> composite(vararg sources: EventSource<EventT>): EventSource<EventT> {\n        return CompositeEventSource(*sources)\n    }\n\n\n    fun <EventT> composite(sources: Iterable<EventSource<EventT>>): EventSource<EventT> {\n        return CompositeEventSource(sources)\n    }\n\n    fun <EventT> filter(source: EventSource<EventT>, pred: Predicate<in EventT>): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                return source.addHandler(object : EventHandler<EventT> {\n                    override fun onEvent(event: EventT) {\n                        if (pred(event)) {\n                            handler.onEvent(event)\n                        }\n                    }\n                })\n            }\n        }\n    }\n\n    fun <SourceEventT, TargetEventT> map(src: EventSource<SourceEventT>, f: (SourceEventT) -> TargetEventT): EventSource<TargetEventT> {\n        return MappingEventSource<SourceEventT, TargetEventT>(src, f)\n    }\n\n    fun <EventT, ItemT> selectList(\n            list: ObservableList<ItemT>, selector: (ItemT?) -> EventSource<EventT>): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                val itemRegs = ArrayList<Registration>()\n                for (item in list) {\n                    itemRegs.add(selector(item).addHandler(handler))\n                }\n\n\n                val listReg = list.addListener(object : CollectionAdapter<ItemT>() {\n                    override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {\n                        itemRegs.add(event.index, selector(event.newItem).addHandler(handler))\n                    }\n\n                    override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {\n                        itemRegs.removeAt(event.index).remove()\n                    }\n                })\n\n                return object : Registration() {\n                    override fun doRemove() {\n                        for (r in itemRegs) {\n                            r.remove()\n                        }\n\n                        listReg.remove()\n                    }\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\n\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.registration.throwableHandlers.ThrowableHandlers\n\n/**\n * Reusable container for listeners.\n * It supports:\n * - managing listeners\n * - firing events\n */\nopen class Listeners<ListenerT> {\n    private var myListeners: MutableList<Any>? = null\n    private var myFireDepth: Int = 0\n    private var myListenersCount: Int = 0\n\n    val isEmpty: Boolean\n        get() = myListeners == null || myListeners!!.isEmpty()\n\n    fun add(l: ListenerT): Registration {\n        if (isEmpty) {\n            beforeFirstAdded()\n        }\n\n        if (myFireDepth > 0) {\n            myListeners!!.add(ListenerOp(l, true))\n        } else {\n            if (myListeners == null) {\n                myListeners = ArrayList(1)\n            }\n            myListeners!!.add(l as Any)\n            myListenersCount++\n        }\n        return object : Registration() {\n            override fun doRemove() {\n                if (myFireDepth > 0) {\n                    myListeners!!.add(\n                        ListenerOp(\n                            l,\n                            false\n                        )\n                    )\n                } else {\n                    myListeners!!.remove(l as Any)\n                    myListenersCount--\n                }\n\n                if (isEmpty) {\n                    afterLastRemoved()\n                }\n            }\n        }\n    }\n\n    fun fire(h: ListenerCaller<ListenerT>) {\n        if (isEmpty) return\n        beforeFire()\n        //exception can be thrown from ThrowableHandlers.getInstance().handle()\n        try {\n            val size = myListenersCount\n            for (i in 0 until size) {\n                @Suppress(\"UNCHECKED_CAST\")\n                val l = myListeners!![i] as ListenerT\n\n                if (isRemoved(l)) continue\n\n                try {\n                    h.call(l)\n                } catch (t: Throwable) {\n                    ThrowableHandlers.instance.handle(t)\n                }\n\n            }\n        } finally {\n            afterFire()\n        }\n    }\n\n    private fun isRemoved(l: ListenerT): Boolean {\n        val size = myListeners!!.size\n        for (i in myListenersCount until size) {\n            @Suppress(\"UNCHECKED_CAST\")\n            val op = myListeners!![i] as ListenerOp<ListenerT>\n            if (!op.add && op.listener === l) return true\n        }\n        return false\n    }\n\n    protected open fun beforeFirstAdded() {}\n\n    protected open fun afterLastRemoved() {}\n\n    private fun beforeFire() {\n        myFireDepth++\n    }\n\n    private fun afterFire() {\n        myFireDepth--\n        if (myFireDepth == 0) {\n            val opsList = myListeners!!.subList(myListenersCount, myListeners!!.size)\n            val ops = opsList.toTypedArray()\n            opsList.clear()\n            for (o in ops) {\n                @Suppress(\"UNCHECKED_CAST\")\n                val op = o as ListenerOp<ListenerT>\n                if (op.add) {\n                    myListeners!!.add(op.listener as Any)\n                    myListenersCount++\n                } else {\n                    myListeners!!.remove(op.listener as Any)\n                    myListenersCount--\n                }\n            }\n            if (isEmpty) {\n                afterLastRemoved()\n            }\n        }\n    }\n\n    internal fun size(): Int {\n        return if (myListeners == null) 0 else myListeners!!.size\n    }\n\n    private class ListenerOp<ListenerT> internal constructor(\n            val listener: ListenerT,\n            val add: Boolean\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.registration.Registration\n\ninternal class MappingEventSource<SourceEventT, TargetEventT>(\n        private val mySourceEventSource: EventSource<SourceEventT>,\n        private val myFunction: (SourceEventT) -> TargetEventT) : EventSource<TargetEventT> {\n\n    override fun addHandler(handler: EventHandler<TargetEventT>): Registration {\n        return mySourceEventSource.addHandler(object : EventHandler<SourceEventT> {\n            override fun onEvent(event: SourceEventT) {\n                handler.onEvent(myFunction(event))\n            }\n        })\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nabstract class BaseReadableProperty<ValueT> :\n    ReadableProperty<ValueT> {\n    override val propExpr: String = this::class.toString()\n\n    override fun toString(): String {\n        return propExpr\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\nimport kotlin.jvm.JvmOverloads\n\nclass DelayedValueProperty<ValueT>\n@JvmOverloads\nconstructor(\n        private var myValue: ValueT? = null) :\n        BaseReadableProperty<ValueT?>(),\n    Property<ValueT?> {\n\n    private var myHandlers: Listeners<EventHandler<PropertyChangeEvent<out ValueT?>>>? = null\n    private var myPendingEvent: PropertyChangeEvent<out ValueT?>? = null\n\n    override val propExpr: String\n        get() = \"delayedProperty()\"\n\n    override fun get(): ValueT? {\n        return myValue\n    }\n\n    override fun set(value: ValueT?) {\n        if (value == myValue) return\n        val oldValue = myValue\n        myValue = value\n\n        if (myPendingEvent != null) {\n            throw IllegalStateException()\n        }\n        myPendingEvent =\n            PropertyChangeEvent(oldValue, myValue)\n    }\n\n    fun flush() {\n        if (myHandlers != null) {\n            myHandlers!!.fire(object : ListenerCaller<EventHandler<PropertyChangeEvent<out ValueT?>>> {\n                override fun call(l: EventHandler<PropertyChangeEvent<out ValueT?>>) {\n                    l.onEvent(myPendingEvent!!)\n                }\n            })\n        }\n        myPendingEvent = null\n    }\n\n    override fun addHandler(handler: EventHandler<PropertyChangeEvent<out ValueT?>>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<PropertyChangeEvent<out ValueT?>>>() {\n                override fun afterLastRemoved() {\n                    myHandlers = null\n                }\n            }\n        }\n        return myHandlers!!.add(handler)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\n\n/**\n * One and two-way property binding support\n */\nobject PropertyBinding {\n    fun <ValueT> bindOneWay(\n            source: ReadableProperty<out ValueT>, target: WritableProperty<in ValueT>): Registration {\n        target.set(source.get())\n        return source.addHandler(object : EventHandler<PropertyChangeEvent<out ValueT>> {\n            override fun onEvent(event: PropertyChangeEvent<out ValueT>) {\n                @Suppress(\"UNCHECKED_CAST\")\n                target.set(event.newValue as ValueT)\n            }\n        })\n    }\n\n    fun <ValueT> bindTwoWay(source: Property<ValueT>, target: Property<ValueT>): Registration {\n        val syncing = ValueProperty<Boolean>(false)\n        target.set(source.get())\n\n        class UpdatingEventHandler(private val myForward: Boolean) : EventHandler<PropertyChangeEvent<out ValueT>> {\n\n            override fun onEvent(event: PropertyChangeEvent<out ValueT>) {\n                if (syncing.get()) return\n\n                syncing.set(true)\n                try {\n                    if (myForward) {\n                        target.set(source.get())\n                    } else {\n                        source.set(target.get())\n                    }\n                } finally {\n                    syncing.set(false)\n                }\n            }\n        }\n\n        return CompositeRegistration(\n                source.addHandler(UpdatingEventHandler(true)),\n                target.addHandler(UpdatingEventHandler(false))\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nclass PropertyChangeEvent<ValueT>(val oldValue: ValueT?, val newValue: ValueT?) {\n\n    override fun toString(): String {\n        return oldValue.toString() + \" -> \" + newValue\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as PropertyChangeEvent<*>\n\n        if (oldValue != other.oldValue) return false\n        if (newValue != other.newValue) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = oldValue?.hashCode() ?: 0\n        result = 31 * result + (newValue?.hashCode() ?: 0)\n        return result\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\n\n/**\n * A simple implementation of Read/Write property which stores the value in a field\n */\nopen class ValueProperty<ValueT>(private var myValue: ValueT) :\n    BaseReadableProperty<ValueT>(),\n    Property<ValueT> {\n\n    private var myHandlers: Listeners<EventHandler<PropertyChangeEvent<out ValueT>>>? = null\n\n    override val propExpr: String\n        get() = \"valueProperty()\"\n\n    override fun get(): ValueT {\n        return myValue\n    }\n\n    override fun set(value: ValueT) {\n        if (value == myValue) return\n        val oldValue = myValue\n        myValue = value\n\n        fireEvents(oldValue, myValue)\n    }\n\n    private fun fireEvents(oldValue: ValueT, newValue: ValueT) {\n        if (myHandlers != null) {\n            val event =\n                PropertyChangeEvent(oldValue, newValue)\n            myHandlers!!.fire(object : ListenerCaller<EventHandler<PropertyChangeEvent<out ValueT>>> {\n                override fun call(l: EventHandler<PropertyChangeEvent<out ValueT>>) {\n                    l.onEvent(event)\n                }\n            })\n        }\n    }\n\n    override fun addHandler(handler: EventHandler<PropertyChangeEvent<out ValueT>>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<PropertyChangeEvent<out ValueT>>>() {\n                override fun afterLastRemoved() {\n                    myHandlers = null\n                }\n            }\n        }\n\n        return myHandlers!!.add(handler)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.random\n\nimport kotlin.math.ln\nimport kotlin.math.sqrt\nimport kotlin.random.Random\n\nclass RandomGaussian(val random: Random) {\n    private var nextNextGaussian: Double = 0.0\n    private var haveNextNextGaussian = false\n\n    // From JDK Random (but not as good)\n    fun nextGaussian(): Double {\n        // See Knuth, ACP, Section 3.4.1 Algorithm C.\n        if (haveNextNextGaussian) {\n            haveNextNextGaussian = false\n            return nextNextGaussian\n        } else {\n            var v1: Double\n            var v2: Double\n            var s: Double\n            do {\n                v1 = 2 * random.nextDouble() - 1 // between -1 and 1\n                v2 = 2 * random.nextDouble() - 1 // between -1 and 1\n                s = v1 * v1 + v2 * v2\n            } while (s >= 1 || s == 0.0)\n            val multiplier = sqrt(-2 * ln(s) / s)\n            nextNextGaussian = v2 * multiplier\n            haveNextNextGaussian = true\n            return v1 * multiplier\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.random\n\nobject RandomString {\n    fun randomString(len: Int): String {\n        val alphabet = ('a'..'z') + ('A'..'Z') + ('0'..'9')\n        return List(len) { alphabet.random() }.joinToString(\"\")\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration\n\n/**\n * Registration which consists of several subregistrations.\n * Useful as an utility to aggregate registration and them dispose them with one call.\n */\nclass CompositeRegistration(vararg regs: Registration) : Registration() {\n    private val myRegistrations: MutableList<Registration>\n\n    val isEmpty: Boolean\n        get() = myRegistrations.isEmpty()\n\n    init {\n        myRegistrations = arrayListOf(*regs)\n    }\n\n    fun add(r: Registration): CompositeRegistration {\n        myRegistrations.add(r)\n        return this\n    }\n\n    fun add(vararg rs: Registration): CompositeRegistration {\n        for (r in rs) {\n            add(r)\n        }\n        return this\n    }\n\n    override fun doRemove() {\n        for (i in myRegistrations.size - 1 downTo -1 + 1) {\n            myRegistrations[i].remove()\n        }\n        myRegistrations.clear()\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration\n\nabstract class Registration : Disposable {\n\n    private var myRemoved: Boolean = false\n\n    protected abstract fun doRemove()\n\n    //this method should never be overridden except in Registration.EMPTY\n    open fun remove() {\n        if (myRemoved) {\n            throw IllegalStateException(\"Registration already removed\")\n        }\n        myRemoved = true\n        doRemove()\n    }\n\n    override fun dispose() {\n        remove()\n    }\n\n    private class EmptyRegistration : Registration() {\n\n        override fun doRemove() {}\n\n        override fun remove() {}\n    }\n\n    companion object {\n        val EMPTY: Registration =\n            EmptyRegistration()\n\n        fun from(disposable: Disposable): Registration {\n            return object : Registration() {\n                override fun doRemove() {\n                    disposable.dispose()\n                }\n            }\n        }\n\n        fun from(vararg disposables: Disposable): Registration {\n            return object : Registration() {\n                override fun doRemove() {\n                    for (d in disposables) {\n                        d.dispose()\n                    }\n                }\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration.throwableHandlers\n\nclass ThrowableHandler internal constructor() {\n\n    fun handle(t: Throwable) {\n        throw t\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration.throwableHandlers\n\nobject ThrowableHandlers {\n    val instance = ThrowableHandler()\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.LongitudeSegment.Companion.splitSegment\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\n// Segment have direction, i.e. `start` can be less than `end` for the case\n// of the antimeridian intersection.\n// That's why we can't use ClosedRange class with lower <= upper invariant\ntypealias Segment = Pair<Double, Double>\n\nval Segment.start get() = first\nval Segment.end get() = second\n\nclass GeoBoundingBoxCalculator<TypeT>(\n    private val myMapRect: Rect<TypeT>,\n    private val myLoopX: Boolean,\n    private val myLoopY: Boolean\n) {\n\n\n    fun calculateBoundingBox(\n        xSegments: Sequence<Segment>,\n        ySegments: Sequence<Segment>\n    ): Rect<TypeT> {\n        val xRange = calculateBoundingRange(\n            xSegments,\n            myMapRect.xRange(),\n            myLoopX\n        )\n        val yRange = calculateBoundingRange(\n            ySegments,\n            myMapRect.yRange(),\n            myLoopY\n        )\n        return Rect(\n            xRange.lowerEnd,\n            yRange.lowerEnd,\n            xRange.length(),\n            yRange.length()\n        )\n    }\n\n    private fun calculateBoundingRange(\n        segments: Sequence<Segment>,\n        mapRange: ClosedRange<Double>,\n        loop: Boolean\n    ): ClosedRange<Double> {\n        return if (loop) {\n            calculateLoopLimitRange(segments, mapRange)\n        } else {\n            ClosedRange(\n                segments.map(Segment::start).minOrNull()!!,\n                segments.map(Segment::end).maxOrNull()!!\n            )\n        }\n    }\n\n    companion object {\n        internal fun calculateLoopLimitRange(\n            segments: Sequence<Segment>,\n            mapRange: ClosedRange<Double>\n        ): ClosedRange<Double> {\n            return segments\n                .map {\n                    splitSegment(\n                        it.start, it.end,\n                        mapRange.lowerEnd,\n                        mapRange.upperEnd\n                    )\n                }\n                .flatten()\n                .run { findMaxGapBetweenRanges(this, mapRange.length()) }\n                .run { invertRange(this, mapRange.length()) }\n                .run { normalizeCenter(this, mapRange) }\n        }\n\n        private fun normalizeCenter(range: ClosedRange<Double>, mapRange: ClosedRange<Double>): ClosedRange<Double> {\n            return if (mapRange.contains((range.upperEnd + range.lowerEnd) / 2)) {\n                range\n            } else {\n                ClosedRange(\n                    range.lowerEnd - mapRange.length(),\n                    range.upperEnd - mapRange.length()\n                )\n            }\n        }\n\n        private fun findMaxGapBetweenRanges(ranges: Sequence<ClosedRange<Double>>, width: Double): ClosedRange<Double> {\n            val sortedRanges = ranges.sortedBy(ClosedRange<Double>::lowerEnd)\n            var prevUpper = sortedRanges.maxByOrNull(ClosedRange<Double>::upperEnd)!!.upperEnd\n            var nextLower = sortedRanges.first().lowerEnd\n            val gapRight = max(width + nextLower, prevUpper)\n            var maxGapRange = ClosedRange(prevUpper, gapRight)\n\n            val it = sortedRanges.iterator()\n            prevUpper = it.next().upperEnd\n\n            while (it.hasNext()) {\n                val range = it.next()\n\n                nextLower = range.lowerEnd\n                if (nextLower > prevUpper && nextLower - prevUpper > maxGapRange.length()) {\n                    maxGapRange = ClosedRange(prevUpper, nextLower)\n                }\n                prevUpper = max(prevUpper, range.upperEnd)\n            }\n            return maxGapRange\n        }\n\n        private fun invertRange(range: ClosedRange<Double>, width: Double): ClosedRange<Double> {\n            // Fix for rounding error for invertRange introduced by math with width.\n            fun safeRange(first: Double, second: Double) = ClosedRange(min(first, second), max(first, second))\n\n            return when {\n                range.length() > width ->\n                    ClosedRange(range.lowerEnd, range.lowerEnd)\n                range.upperEnd > width ->\n                    safeRange(range.upperEnd - width, range.lowerEnd)\n                else ->\n                    safeRange(range.upperEnd, width + range.lowerEnd)\n            }\n        }\n\n        private fun ClosedRange<Double>.length(): Double {\n            return upperEnd - lowerEnd\n        }\n    }\n}\n\nfun makeSegments(start: (Int) -> Double, end: (Int) -> Double, size: Int): Sequence<Segment> {\n    return (0 until size).asSequence().map { Segment(start(it), end(it)) }\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.geoRectsBBox(rectangles: List<GeoRectangle>): Rect<T> {\n    return calculateBoundingBox(\n        makeSegments(\n            { rectangles[it].startLongitude() },\n            { rectangles[it].endLongitude() },\n            rectangles.size\n        ),\n        makeSegments(\n            { rectangles[it].minLatitude() },\n            { rectangles[it].maxLatitude() },\n            rectangles.size\n        )\n    )\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.pointsBBox(xyCoords: List<Double>): Rect<T> {\n    require(xyCoords.size % 2 == 0) { \"Longitude-Latitude list is not even-numbered.\" }\n    val x: (Int) -> Double = { index -> xyCoords[2 * index] }\n    val y: (Int) -> Double = { index -> xyCoords[2 * index + 1] }\n\n    val i = xyCoords.size / 2\n    return calculateBoundingBox(\n        makeSegments(x, x, i),\n        makeSegments(y, y, i)\n    )\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.union(rectangles: List<Rect<T>>): Rect<T> {\n    return calculateBoundingBox(\n        makeSegments(\n            { rectangles[it].left },\n            { rectangles[it].right },\n            rectangles.size\n        ),\n        makeSegments(\n            { rectangles[it].top },\n            { rectangles[it].bottom },\n            rectangles.size\n        )\n    )\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.json.FluentArray\nimport jetbrains.datalore.base.json.FluentObject\nimport jetbrains.datalore.base.json.JsonSupport\nimport jetbrains.datalore.base.typedGeometry.*\n\nobject GeoJson {\n    private const val LON_INDEX = 0\n    private const val LAT_INDEX = 1\n\n    fun <T> parse(geoJson: String, handler: SimpleFeature.Consumer<T>.() -> Unit) {\n        val geoObj = FluentObject(JsonSupport.parseJson(geoJson))\n        val geometryConsumer = SimpleFeature.Consumer<T>().apply(handler)\n        Parser<T>().parse(geoObj, geometryConsumer)\n    }\n\n    fun <T> parse(geoJson: String, consumer: SimpleFeature.GeometryConsumer<T>) {\n        val geoObj = FluentObject(JsonSupport.parseJson(geoJson))\n        Parser<T>().parse(geoObj, consumer)\n    }\n\n    private class Parser<T> {\n\n        internal fun parse(obj: FluentObject, handler: SimpleFeature.GeometryConsumer<T>) {\n            when (val type = obj.getString(\"type\")) {\n                \"FeatureCollection\" -> {\n                    require(obj.contains(\"features\")) { \"GeoJson: Missing 'features' in 'FeatureCollection'\" }\n\n                    obj.getArray(\"features\").fluentObjectStream()\n                        .filter { it.getString(\"type\") == \"Feature\" }\n                        .map { it.getObject(\"geometry\") }\n                        .forEach { parse(it, handler) }\n                }\n\n                \"GeometryCollection\" -> {\n                    require(obj.contains(\"geometries\")) { \"GeoJson: Missing 'geometries' in 'GeometryCollection'\" }\n\n                    obj.getArray(\"geometries\").fluentObjectStream()\n                        .forEach { parse(it, handler) }\n                }\n\n                else -> {\n                    require(obj.contains(\"coordinates\")) { \"GeoJson: Missing 'coordinates' in $type\" }\n\n                    val coordinates = obj.getArray(\"coordinates\")\n                    when (type) {\n                        \"Point\" -> parsePoint(coordinates).let(handler::onPoint)\n                        \"LineString\" -> parseLineString(coordinates).let(handler::onLineString)\n                        \"Polygon\" -> parsePolygon(coordinates).let(handler::onPolygon)\n                        \"MultiPoint\" -> parseMultiPoint(coordinates).let(handler::onMultiPoint)\n                        \"MultiLineString\" -> parseMultiLineString(coordinates).let(handler::onMultiLineString)\n                        \"MultiPolygon\" -> parseMultiPolygon(coordinates).let(handler::onMultiPolygon)\n                        else -> error(\"Not support GeoJson type: $type\")\n                    }\n                }\n            }\n        }\n\n        private fun parsePoint(jsonPoint: FluentArray): Vec<T> {\n            return explicitVec<T>(\n                jsonPoint.getDouble(LON_INDEX),\n                jsonPoint.getDouble(LAT_INDEX)\n            )\n        }\n\n        private fun parseLineString(jsonLineString: FluentArray): LineString<T> {\n            return jsonLineString.mapArray(this::parsePoint).let(::LineString)\n        }\n\n        private fun parseRing(jsonRing: FluentArray): Ring<T> {\n            return jsonRing.mapArray(this::parsePoint).let(::Ring)\n        }\n\n        private fun parseMultiPoint(jsonMultiPoint: FluentArray): MultiPoint<T> {\n            return jsonMultiPoint.mapArray(this::parsePoint).let(::MultiPoint)\n        }\n\n        private fun parsePolygon(jsonPolygon: FluentArray): Polygon<T> {\n            return jsonPolygon.mapArray(this::parseRing).let(::Polygon)\n        }\n\n        private fun parseMultiLineString(jsonLineStrings: FluentArray): MultiLineString<T> {\n            return jsonLineStrings.mapArray(this::parseLineString).let(::MultiLineString)\n        }\n\n        private fun parseMultiPolygon(jsonMultiPolygon: FluentArray): MultiPolygon<T> {\n            return jsonMultiPolygon.mapArray(this::parsePolygon).let(::MultiPolygon)\n        }\n\n        private fun <T> FluentArray.mapArray(f: (FluentArray) -> T): List<T> {\n            return this.stream().map { f(FluentArray(it as List<Any?>)) }.toList()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.typedGeometry.Rect\nimport jetbrains.datalore.base.typedGeometry.Vec\nimport jetbrains.datalore.base.typedGeometry.newSpanRectangle\n\nclass GeoRectangle(startLongitude: Double, minLatitude: Double, endLongitude: Double, maxLatitude: Double) {\n    private val myLongitudeSegment: LongitudeSegment\n    private val myLatitudeRange: ClosedRange<Double>\n\n    val isEmpty: Boolean\n        get() = myLongitudeSegment.isEmpty && latitudeRangeIsEmpty(myLatitudeRange)\n\n    private fun latitudeRangeIsEmpty(range: ClosedRange<Double>): Boolean {\n        return range.upperEnd == range.lowerEnd\n    }\n\n    init {\n        require(minLatitude <= maxLatitude) { \"Invalid latitude range: [$minLatitude..$maxLatitude]\" }\n\n        myLongitudeSegment = LongitudeSegment(startLongitude, endLongitude)\n        myLatitudeRange = ClosedRange(minLatitude, maxLatitude)\n    }\n\n    fun startLongitude(): Double = myLongitudeSegment.start()\n    fun endLongitude(): Double = myLongitudeSegment.end()\n\n    fun minLatitude(): Double = myLatitudeRange.lowerEnd\n    fun maxLatitude(): Double = myLatitudeRange.upperEnd\n\n    fun encloses(rect: GeoRectangle): Boolean {\n        return myLongitudeSegment.encloses(rect.myLongitudeSegment) && myLatitudeRange.encloses(rect.myLatitudeRange)\n    }\n\n    fun splitByAntiMeridian(): List<Rect<LonLat>> {\n        val rects = ArrayList<Rect<LonLat>>()\n\n        val longitudeRanges = myLongitudeSegment.splitByAntiMeridian()\n        for (longitudeRange in longitudeRanges) {\n            rects.add(\n                newSpanRectangle(\n                    Vec(longitudeRange.lowerEnd, myLatitudeRange.lowerEnd),\n                    Vec(longitudeRange.upperEnd, myLatitudeRange.upperEnd)\n                )\n            )\n        }\n        return rects\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as GeoRectangle?\n        return myLongitudeSegment == that!!.myLongitudeSegment && myLatitudeRange == that.myLatitudeRange\n    }\n\n    override fun hashCode(): Int {\n        return listOf(myLongitudeSegment, myLatitudeRange).hashCode()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass LonLat\ntypealias LonLatPoint = Vec<LonLat>\n\nval EARTH_RECT = Rect<LonLat>(\n    MIN_LONGITUDE,\n    MIN_LATITUDE,\n    FULL_LONGITUDE,\n    FULL_LATITUDE\n)\n\nfun limitLon(lon: Double) = max(\n    MIN_LONGITUDE, min(lon,\n        MAX_LONGITUDE\n    ))\n\nfun limitLat(lat: Double) = max(\n    MIN_LATITUDE, min(lat,\n        MAX_LATITUDE\n    ))\n\nfun normalizeLon(lon: Double): Double {\n    var result = lon - (lon / FULL_LONGITUDE).toInt() * FULL_LONGITUDE\n\n    if (result > MAX_LONGITUDE) {\n        result -= FULL_LONGITUDE\n    }\n    if (result < -MAX_LONGITUDE) {\n        result += FULL_LONGITUDE\n    }\n\n    return result\n}\n\nval BBOX_CALCULATOR = GeoBoundingBoxCalculator(\n    EARTH_RECT,\n    myLoopX = true,\n    myLoopY = false\n)\n\nfun convertToGeoRectangle(rect: Rect<LonLat>): GeoRectangle {\n    val left: Double\n    val right: Double\n\n    if (rect.width < EARTH_RECT.width) {\n        left = normalizeLon(rect.left)\n        right = normalizeLon(rect.right)\n    } else {\n        left = EARTH_RECT.left\n        right = EARTH_RECT.right\n    }\n\n    return GeoRectangle(\n        left,\n        limitLat(rect.top),\n        right,\n        limitLat(rect.bottom)\n    )\n}\n\nfun calculateQuadKeys(rect: Rect<LonLat>, zoom: Int): Set<QuadKey<LonLat>> {\n    val flippedRect = Rect<LonLat>(\n        rect.left,\n        -rect.bottom,\n        rect.width,\n        rect.height\n    )\n    return calculateQuadKeys(\n        EARTH_RECT,\n        flippedRect,\n        zoom,\n        ::QuadKey\n    )\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\n\ninternal class LongitudeSegment(start: Double, end: Double) {\n    private val myStart: Double = limitLon(start)\n    private val myEnd: Double = limitLon(end)\n\n    val isEmpty: Boolean\n        get() = myEnd == myStart\n\n    fun start(): Double {\n        return myStart\n    }\n\n    fun end(): Double {\n        return myEnd\n    }\n\n    fun length(): Double {\n        return myEnd - myStart + if (myEnd < myStart) FULL_LONGITUDE else 0.0\n    }\n\n    fun encloses(longitudeSegment: LongitudeSegment): Boolean {\n        val externalRanges = splitByAntiMeridian()\n        val internalRanges = longitudeSegment.splitByAntiMeridian()\n\n        for (internalRange in internalRanges) {\n            if (!disjointRangesEncloseRange(\n                    externalRanges,\n                    internalRange\n                )\n            ) {\n                return false\n            }\n        }\n        return true\n    }\n\n    fun invert(): LongitudeSegment {\n        return LongitudeSegment(myEnd, myStart)\n    }\n\n    fun splitByAntiMeridian(): List<ClosedRange<Double>> {\n        return splitSegment(\n            myStart, myEnd,\n            MIN_LONGITUDE,\n            MAX_LONGITUDE\n        )\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as LongitudeSegment\n        return that.myStart.equals(myStart) && that.myEnd.equals(myEnd)\n    }\n\n    override fun hashCode(): Int {\n        return listOf(myStart, myEnd).hashCode()\n    }\n\n    companion object {\n        fun splitSegment(\n            start: Double,\n            end: Double,\n            min: Double,\n            max: Double\n        ) : List<ClosedRange<Double>> {\n            return if (start <= end) {\n                listOf(ClosedRange(start, end))\n            } else {\n                listOf(\n                    ClosedRange(start, max),\n                    ClosedRange(min, end)\n                )\n            }\n        }\n\n        private fun disjointRangesEncloseRange(\n            ranges: List<ClosedRange<Double>>,\n            internalRange: ClosedRange<Double>\n        ): Boolean {\n            for (range in ranges) {\n                if (range.encloses(internalRange)) {\n                    return true\n                }\n            }\n            return false\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.math.toDegrees\nimport jetbrains.datalore.base.math.toRadians\n\nimport kotlin.math.*\n\nobject MercatorUtils {\n    private const val MAX_LONGITUDE = 180.0\n    private const val MAX_LATITUDE = 85.0511287798\n    val VALID_LONGITUDE_RANGE = ClosedRange(\n        -MAX_LONGITUDE,\n        MAX_LONGITUDE\n    )\n    val VALID_LATITUDE_RANGE = ClosedRange(\n        -MAX_LATITUDE,\n        MAX_LATITUDE\n    )\n\n    fun getMercatorX(lon: Double): Double = toRadians(lon) * EARTH_RADIUS\n\n    fun getMercatorY(lat: Double): Double {\n        @Suppress(\"NAME_SHADOWING\")\n        val lat = normalizeLat(lat)\n        return ln(tan(PI / 4 + toRadians(lat) / 2)) * EARTH_RADIUS\n    }\n\n    fun getLongitude(x: Double): Double {\n        return toDegrees(x / EARTH_RADIUS)\n    }\n\n    fun getLatitude(y: Double): Double {\n        return normalizeLat(toDegrees((atan(exp(y / EARTH_RADIUS)) - PI / 4) * 2))\n    }\n\n    fun checkLon(lon: Double): Boolean {\n        return VALID_LONGITUDE_RANGE.contains(lon)\n    }\n\n    fun checkLat(lat: Double): Boolean {\n        return VALID_LATITUDE_RANGE.contains(lat)\n    }\n\n    private fun normalizeLat(lat: Double): Double {\n        return max(\n            -MAX_LATITUDE, min(\n                lat,\n                MAX_LATITUDE\n            )\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\n\n\ndata class QuadKey<T>(\n    val key: String\n) {\n    operator fun plus(other: QuadKey<T>): QuadKey<T> {\n        return QuadKey(key + other.key)\n    }\n\n    val length = key.length\n}\n\nfun QuadKey<LonLat>.computeRect(): Rect<LonLat> {\n    val origin = this.computeOrigin(EARTH_RECT)\n    val dimension = EARTH_RECT.dimension / calulateQuadsCount(length).toDouble()\n\n    val flippedY = EARTH_RECT.scalarBottom - (origin.scalarY + dimension.scalarY - EARTH_RECT.scalarTop)\n    return Rect(origin.transform(newY = { flippedY }), dimension)\n}\n\nfun <T> QuadKey<T>.computeRect(rect: Rect<T>): Rect<T> {\n    return projectRect(rect)\n}\n\nfun <T, OutT> QuadKey<T>.projectRect(rect: Rect<OutT>): Rect<OutT> {\n    val origin = projectOrigin(rect)\n    val dimension = rect.dimension / calulateQuadsCount(length).toDouble()\n\n    return Rect(origin, dimension)\n}\n\nfun QuadKey<LonLat>.zoom() = length\n\nfun <TypeT> QuadKey<TypeT>.computeOrigin(mapRect: Rect<TypeT>): Vec<TypeT> {\n    return projectOrigin(mapRect)\n}\n\nfun <TypeT, OutT> QuadKey<TypeT>.projectOrigin(mapRect: Rect<OutT>): Vec<OutT> {\n    var left = mapRect.scalarLeft\n    var top = mapRect.scalarTop\n    var width = mapRect.scalarWidth\n    var height = mapRect.scalarHeight\n\n    for (quadrant in key) {\n        width /= 2.0\n        height /= 2.0\n\n        if (quadrant == '1' || quadrant == '3') {\n            left += width\n        }\n        if (quadrant == '2' || quadrant == '3') {\n            top += height\n        }\n    }\n    return newVec(left, top)\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.math.ipow\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\nfun calulateQuadsCount(zoom: Int): Int {\n    return 2.ipow(zoom).toInt()\n}\n\nfun <GeometryT, QuadT> calculateQuadKeys(\n    mapRect: Rect<GeometryT>,\n    viewRect: Rect<GeometryT>,\n    zoom: Int,\n    quadKeyFactory: (String) -> QuadT\n): Set<QuadT> {\n    val quadKeys = HashSet<QuadT>()\n    val tileCount = calulateQuadsCount(zoom)\n\n    fun calcQuadNum(value: Double, range: ClosedRange<Double>, tileCount: Int): Int {\n        val position = (value - range.lowerEnd) / (range.upperEnd - range.lowerEnd)\n        return max(0.0, min(position * tileCount, (tileCount - 1).toDouble())).toInt()\n    }\n\n    val xmin = calcQuadNum(viewRect.left, mapRect.xRange(), tileCount)\n    val xmax = calcQuadNum(viewRect.right, mapRect.xRange(), tileCount)\n    val ymin = calcQuadNum(viewRect.top, mapRect.yRange(), tileCount)\n    val ymax = calcQuadNum(viewRect.bottom, mapRect.yRange(), tileCount)\n\n    for (x in xmin..xmax) {\n        for (y in ymin..ymax) {\n            xyToKey(x, y, zoom).run(quadKeyFactory).run(quadKeys::add)\n        }\n    }\n\n    return quadKeys\n}\n\nfun xyToKey(x: Int, y: Int, zoom: Int): String {\n    var key = \"\"\n\n    for (i in zoom downTo 1) {\n        var digit = '0'\n        val mask = 1 shl i - 1\n\n        if (x and mask != 0) {\n            ++digit\n        }\n\n        if (y and mask != 0) {\n            digit += 2\n        }\n\n        key += digit\n    }\n\n    return key\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\n\nobject SimpleFeature {\n    interface GeometryConsumer<T> {\n        fun onPoint(point: Vec<T>): Unit = error(\"Point isn't supported\")\n        fun onLineString(lineString: LineString<T>): Unit = error(\"LineString isn't supported\")\n        fun onPolygon(polygon: Polygon<T>): Unit = error(\"Polygon isn't supported\")\n        fun onMultiPoint(multiPoint: MultiPoint<T>): Unit = error(\"MultiPoint isn't supported\")\n        fun onMultiLineString(multiLineString: MultiLineString<T>): Unit = error(\"MultiLineString isn't supported\")\n        fun onMultiPolygon(multipolygon: MultiPolygon<T>): Unit = error(\"MultiPolygon isn't supported\")\n    }\n\n    class Consumer<T>(\n        var onPoint: (Vec<T>) -> Unit = { error(\"Point isn't supported\") },\n        var onLineString: (LineString<T>) -> Unit = { error(\"LineString isn't supported\") },\n        var onPolygon: (Polygon<T>) -> Unit = { error(\"Polygon isn't supported\") },\n        var onMultiPoint: (MultiPoint<T>) -> Unit = { error(\"MultiPoint isn't supported\") },\n        var onMultiLineString: (MultiLineString<T>) -> Unit = { error(\"MultiLineString isn't supported\") },\n        var onMultiPolygon: (MultiPolygon<T>) -> Unit = { error(\"MultiPolygon isn't supported\") }\n    ) : GeometryConsumer<T> {\n        override fun onPoint(point: Vec<T>): Unit = (onPoint)(point)\n        override fun onLineString(lineString: LineString<T>): Unit = (onLineString)(lineString)\n        override fun onPolygon(polygon: Polygon<T>): Unit = (onPolygon)(polygon)\n        override fun onMultiPoint(multiPoint: MultiPoint<T>): Unit = (onMultiPoint)(multiPoint)\n        override fun onMultiLineString(multiLineString: MultiLineString<T>): Unit = (onMultiLineString)(multiLineString)\n        override fun onMultiPolygon(multipolygon: MultiPolygon<T>): Unit = (onMultiPolygon)(multipolygon)\n    }\n\n    enum class GeometryType {\n        POINT,\n        LINE_STRING,\n        POLYGON,\n        MULTI_POINT,\n        MULTI_LINE_STRING,\n        MULTI_POLYGON,\n        GEOMETRY_COLLECTION;\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.stringFormat\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\n\nclass StringFormat private constructor(\n    private val pattern: String,\n    val formatType: FormatType\n) {\n    enum class FormatType {\n        NUMBER_FORMAT,\n        STRING_FORMAT\n    }\n\n    private val myNumberFormatters: List<NumberFormat?>\n\n    init {\n        fun initNumberFormat(pattern: String): NumberFormat {\n            try {\n                return NumberFormat(pattern)\n            } catch (e: Exception) {\n                error(\"Wrong number pattern: $pattern\")\n            }\n        }\n\n        myNumberFormatters = when (formatType) {\n            FormatType.NUMBER_FORMAT -> listOf(initNumberFormat(pattern))\n            FormatType.STRING_FORMAT -> {\n                BRACES_REGEX.findAll(pattern)\n                    .map { it.groupValues[TEXT_IN_BRACES] }\n                    .map { format ->\n                        if (format.isNotEmpty()) {\n                            initNumberFormat(format)\n                        } else {\n                            null\n                        }\n                    }\n                    .toList()\n            }\n        }\n    }\n\n    val argsNumber = myNumberFormatters.size\n\n    fun format(value: Any): String = format(listOf(value))\n\n    fun format(values: List<Any>): String {\n        if (argsNumber != values.size) {\n            error(\"Can't format values $values with pattern \\\"$pattern\\\"). Wrong number of arguments: expected $argsNumber instead of ${values.size}\")\n        }\n        return when (formatType) {\n            FormatType.NUMBER_FORMAT -> {\n                require(myNumberFormatters.size == 1)\n                formatValue(values.single(), myNumberFormatters.single())\n            }\n            FormatType.STRING_FORMAT -> {\n                var index = 0\n                BRACES_REGEX.replace(pattern) {\n                    val originalValue = values[index]\n                    val formatter = myNumberFormatters[index++]\n                    formatValue(originalValue, formatter)\n                }\n                    .replace(\"{{\", \"{\")\n                    .replace(\"}}\", \"}\")\n            }\n        }\n    }\n\n    private fun formatValue(value: Any, numberFormatter: NumberFormat?): String {\n        return when {\n            numberFormatter == null -> value.toString()\n            value is Number -> numberFormatter.apply(value)\n            value is String -> value.toFloatOrNull()?.let(numberFormatter::apply) ?: value\n            else -> error(\"Failed to format value with type ${value::class.simpleName}. Supported types are Number and String.\")\n        }\n    }\n\n    companion object {\n        // Format strings contain “replacement fields” surrounded by braces {}.\n        // Anything that is not contained in braces is considered literal text, which is copied unchanged to the output.\n        // If you need to include a brace character in the literal text, it can be escaped by doubling: {{ and }}.\n        //     \"text\" -> \"text\"\n        //     \"{{text}}\" -> \"{text}\"\n        //     \"{.1f} -> 1.2\n        //     \"{{{.1f}}} -> {1.2}\n        private val BRACES_REGEX = Regex(\"\"\"(?![^{]|\\{\\{)(\\{([^{}]*)\\})(?=[^}]|\\}\\}|$)\"\"\")\n        const val TEXT_IN_BRACES = 2\n\n        fun valueInLinePattern() = \"{}\"\n\n        fun forOneArg(\n            pattern: String,\n            type: FormatType? = null,\n            formatFor: String? = null,\n        ): StringFormat {\n            return create(pattern, type, formatFor, 1)\n        }\n\n        fun forNArgs(\n            pattern: String,\n            type: FormatType? = null,\n            argCount: Int,\n            formatFor: String? = null\n        ): StringFormat {\n            return create(pattern, type, formatFor, argCount)\n        }\n\n        fun create(\n            pattern: String,\n            type: FormatType? = null,\n            formatFor: String? = null,\n            expectedArgs: Int = -1\n        ): StringFormat {\n            val formatType = when {\n                type != null -> type\n                NumberFormat.isValidPattern(pattern) -> FormatType.NUMBER_FORMAT\n                else -> FormatType.STRING_FORMAT\n            }\n\n            return StringFormat(pattern, formatType).also {\n                if (expectedArgs > 0) {\n                    require(it.argsNumber == expectedArgs) {\n                        @Suppress(\"NAME_SHADOWING\")\n                        val formatFor = formatFor?.let { \"to format \\'$formatFor\\'\" } ?: \"\"\n                        \"Wrong number of arguments in pattern \\'$pattern\\' $formatFor. \" +\n                                \"Expected $expectedArgs ${if (expectedArgs > 1) \"arguments\" else \"argument\"} \" +\n                                \"instead of ${it.argsNumber}\"\n                    }\n                }\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nopen class AbstractGeometryList<T>(private val myGeometry: List<T>) : AbstractList<T>() {\n    override fun get(index: Int): T {\n        return myGeometry[index]\n    }\n\n    override val size: Int\n        get() = myGeometry.size\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.geometry.DoubleRectangles\n\nfun <T> isClockwise(ring: List<Vec<T>>): Boolean {\n    return jetbrains.datalore.base.algorithms.isClockwise(ring, Vec<T>::x, Vec<T>::y)\n}\n\nfun <T> createMultiPolygon(points: List<Vec<T>>): MultiPolygon<T> {\n    if (points.isEmpty()) {\n        return MultiPolygon(emptyList())\n    }\n\n    val polygons = ArrayList<Polygon<T>>()\n    var rings = ArrayList<Ring<T>>()\n\n    for (ring in splitRings(points)) {\n        if (rings.isNotEmpty() && isClockwise(ring)) {\n            polygons.add(Polygon(rings))\n            rings = ArrayList()\n        }\n        rings.add(Ring(ring))\n    }\n\n    if (rings.isNotEmpty()) {\n        polygons.add(Polygon(rings))\n    }\n\n    return MultiPolygon(polygons)\n}\n\nfun <TypeT> Iterable<Vec<TypeT>>.boundingBox(): Rect<TypeT> {\n    return DoubleRectangles.calculateBoundingBox(this,\n        Vec<*>::x,\n        Vec<*>::y\n    )\n    { minX, minY, maxX, maxY ->\n        newSpanRectangle(\n            Vec(minX, minY),\n            Vec(maxX, maxY)\n        )\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass Generic\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> Vec<Generic>.reinterpret(): Vec<TypeT> = this as Vec<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiPoint<Generic>.reinterpret(): MultiPoint<TypeT> = this as MultiPoint<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> LineString<Generic>.reinterpret(): LineString<TypeT> = this as LineString<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiLineString<Generic>.reinterpret(): MultiLineString<TypeT> = this as MultiLineString<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> Polygon<Generic>.reinterpret(): Polygon<TypeT> = this as Polygon<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiPolygon<Generic>.reinterpret(): MultiPolygon<TypeT> = this as MultiPolygon<TypeT>\n\nval Rect<*>.bottom: Double get() = origin.y + dimension.y\nval Rect<*>.right: Double get() = origin.x + dimension.x\nval Rect<*>.height: Double get() = dimension.y\nval Rect<*>.width: Double get() = dimension.x\nval Rect<*>.top: Double get() = origin.y\nval Rect<*>.left: Double get() = origin.x\n\nval <TypeT> Rect<TypeT>.scalarBottom: Scalar<TypeT> get() = Scalar(bottom)\nval <TypeT> Rect<TypeT>.scalarRight: Scalar<TypeT> get() = Scalar(right)\nval <TypeT> Rect<TypeT>.scalarHeight: Scalar<TypeT> get() = Scalar(height)\nval <TypeT> Rect<TypeT>.scalarWidth: Scalar<TypeT> get() = Scalar(width)\nval <TypeT> Rect<TypeT>.scalarTop: Scalar<TypeT> get() = Scalar(top)\nval <TypeT> Rect<TypeT>.scalarLeft: Scalar<TypeT> get() = Scalar(left)\n\nval <TypeT> Rect<TypeT>.center: Vec<TypeT> get() = dimension / 2.0 + origin\n\nval <TypeT> Vec<TypeT>.scalarX get(): Scalar<TypeT> = Scalar(x)\nval <TypeT> Vec<TypeT>.scalarY get(): Scalar<TypeT> = Scalar(y)\n\noperator fun <TypeT> Vec<TypeT>.plus(other: Vec<TypeT>): Vec<TypeT> = Vec(x + other.x, y + other.y)\noperator fun <TypeT> Vec<TypeT>.minus(other: Vec<TypeT>): Vec<TypeT> = Vec(x - other.x, y - other.y)\noperator fun <TypeT> Vec<TypeT>.times(other: Vec<TypeT>): Vec<TypeT> = Vec(x * other.x, y * other.y)\noperator fun <TypeT> Vec<TypeT>.div(other: Vec<TypeT>): Vec<TypeT> = Vec(x / other.x, y / other.y)\n\noperator fun <TypeT> Vec<TypeT>.times(scale: Double): Vec<TypeT> = Vec(x * scale, y * scale)\noperator fun <TypeT> Vec<TypeT>.div(scale: Double): Vec<TypeT> = Vec(x / scale, y / scale)\noperator fun <TypeT> Vec<TypeT>.unaryMinus(): Vec<TypeT> = Vec(-x, -y)\n\nfun <TypeT> Vec<TypeT>.transform(\n    newX: (Scalar<TypeT>) -> Scalar<TypeT> = { it },\n    newY: (Scalar<TypeT>) -> Scalar<TypeT> = { it }\n) = Vec<TypeT>(newX(scalarX).value, newY(scalarY).value)\n\noperator fun <T> Scalar<T>.plus(other: Scalar<T>): Scalar<T> = Scalar(value + other.value)\noperator fun <T> Scalar<T>.minus(other: Scalar<T>): Scalar<T> = Scalar(value - other.value)\noperator fun <T> Scalar<T>.times(other: Scalar<T>): Scalar<T> = Scalar(value * other.value)\n\noperator fun <T> Scalar<T>.div(other: Scalar<T>): Scalar<T> = Scalar(value / other.value)\noperator fun <T> Scalar<T>.div(other: Double): Scalar<T> = Scalar(value / other)\noperator fun <T> Scalar<T>.times(other: Double): Scalar<T> = Scalar(value * other)\noperator fun <T> Scalar<T>.unaryMinus(): Scalar<T> = Scalar(-value)\n\noperator fun <T> Scalar<T>.compareTo(i: Int) = value.compareTo(i)\n\n\nfun <TypeT> newSpanRectangle(leftTop: Vec<TypeT>, rightBottom: Vec<TypeT>): Rect<TypeT> {\n    return Rect(leftTop, rightBottom - leftTop)\n}\n\nfun <TypeT> Polygon<TypeT>.limit(): Rect<TypeT> {\n    return asSequence().flatten().asIterable().boundingBox()\n}\n\nfun <TypeT> Rect<TypeT>.contains(v: Vec<TypeT>): Boolean {\n    return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n}\n\nfun <TypeT> Rect<TypeT>.intersects(rect: Rect<TypeT>): Boolean {\n    val t1 = origin\n    val t2 = origin + dimension\n    val r1 = rect.origin\n    val r2 = rect.origin + rect.dimension\n    return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n}\n\nfun Rect<*>.xRange() = ClosedRange(origin.x, origin.x + dimension.x)\nfun Rect<*>.yRange() = ClosedRange(origin.y, origin.y + dimension.y)\n\nfun <TypeT> MultiPolygon<TypeT>.limit(): List<Rect<TypeT>> {\n    return map { polygon -> polygon.limit() }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nenum class GeometryType {\n    MULTI_POINT,\n    MULTI_LINESTRING,\n    MULTI_POLYGON;\n}\n\nclass Geometry<TypeT> private constructor(\n    val type: GeometryType,\n    private val myMultiPoint: MultiPoint<TypeT>?,\n    private val myMultiLineString: MultiLineString<TypeT>?,\n    private val myMultiPolygon: MultiPolygon<TypeT>?\n) {\n    val multiPoint: MultiPoint<TypeT>\n        get() = myMultiPoint ?: error(\"$type is not a MultiPoint\")\n    val multiLineString: MultiLineString<TypeT>\n        get() = myMultiLineString ?: error(\"$type is not a MultiLineString\")\n    val multiPolygon: MultiPolygon<TypeT>\n        get() = myMultiPolygon ?: error(\"$type is not a MultiPolygon\")\n\n    companion object {\n        fun <TypeT> createMultiPoint(multiPoint: MultiPoint<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_POINT,\n                myMultiPoint = multiPoint,\n                myMultiLineString = null,\n                myMultiPolygon = null\n            )\n        }\n\n        fun <TypeT> createMultiLineString(multiLineString: MultiLineString<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_LINESTRING,\n                myMultiPoint = null,\n                myMultiLineString = multiLineString,\n                myMultiPolygon = null\n            )\n        }\n\n        fun <TypeT> createMultiPolygon(multiPolygon: MultiPolygon<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_POLYGON,\n                myMultiPoint = null,\n                myMultiLineString = null,\n                myMultiPolygon = multiPolygon\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass LineString<TypeT>(geometry: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiLineString<TypeT>(geometry: List<LineString<TypeT>>) : AbstractGeometryList<LineString<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiPoint<TypeT>(geometry: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiPolygon<TypeT>(polygons: List<Polygon<TypeT>>) : AbstractGeometryList<Polygon<TypeT>>(polygons)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass Polygon<TypeT>(rings: List<Ring<TypeT>>) : AbstractGeometryList<Ring<TypeT>>(rings)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Rect<TypeT>(\n    val origin: Vec<TypeT>,\n    val dimension: Vec<TypeT>\n) {\n    constructor(\n        left: Double,\n        top: Double,\n        width: Double,\n        height: Double\n    ) : this(\n        Vec(left, top),\n        Vec(width, height)\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass Ring<TypeT>(points: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(points)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Scalar<T>(\n    val value: Double\n)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Vec<TypeT> (\n    val x: Double,\n    val y: Double\n) {\n    constructor(x: Int, y: Int) : this(x.toDouble(), y.toDouble())\n}\n\nfun <T> explicitVec(x: Double, y: Double): Vec<T> = Vec(x, y)\nfun <T> explicitVec(x: Int, y: Int): Vec<T> = Vec(x.toDouble(), y.toDouble())\nfun <T> newVec(x: Scalar<T>, y: Scalar<T>): Vec<T> = Vec(x.value, y.value)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedKey\n\n/**\n * Maps typed keys to not-null values.\n * The type parametr can't be a nullable type.\n */\nclass TypedKeyHashMap {\n\n    val map = hashMapOf<TypedKey<*>, Any?>()\n\n    /**\n     * Throws NoSuchElementException if key is not present.\n     */\n    operator fun <T> get(key: TypedKey<T>): T {\n        if (map.containsKey(key)) {\n            @Suppress(\"UNCHECKED_CAST\")\n            return map[key] as T\n        }\n        throw NoSuchElementException(\"Wasn't found key $key\")\n    }\n\n    operator fun <T> set(key: TypedKey<T>, value: T?) {\n        put(key, value)\n    }\n\n    /**\n     * Null value is ignored and the key (if present) is removed from container.\n     *\n     * Note: the fact that the value type is nullable is very important when used with 'primitive'\n     * Kotlin type (like Double) in 'native' context.\n     * Without 'T?' Kotlin may choose to represent Double by double and will crash on an attempt to cast type (`as`) or\n     * to apply null-safe operator (!!). Such behavior was observed in Kotlin native.\n     * See Kotlin docs: https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/-double/index.html\n     */\n    fun <T> put(key: TypedKey<T>, value: T?) {\n        if (value == null) {\n            map.remove(key)\n        } else {\n            map[key] = value\n        }\n    }\n\n    fun contains(key: TypedKey<*>): Boolean {\n        return containsKey(key)\n    }\n\n    fun <T> containsKey(key: TypedKey<T>): Boolean {\n        return map.containsKey(key)\n    }\n\n    fun <T> keys(): Set<TypedKey<T>> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return map.keys as Set<TypedKey<T>>\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.unsupported\n\n/*\n\nUse UNSUPPORTED() instead of TODO() from Kotlin standard library.\nTODO() throws an `Error` and we are generally don't try to catch errors.\n\n */\n\n@Suppress(\"FunctionName\")\nfun UNSUPPORTED(): Nothing = throw UnsupportedOperationException()\n\n@Suppress(\"FunctionName\")\nfun UNSUPPORTED(what: String): Nothing = throw UnsupportedOperationException(what)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.roundToInt\n\n// ToDo: ubyte?\nclass Color @JvmOverloads constructor(\n    val red: Int,\n    val green: Int,\n    val blue: Int,\n    val alpha: Int = 255\n) {\n    init {\n        require(\n            0 <= red && red <= 255 &&\n                    0 <= green && green <= 255 &&\n                    0 <= blue && blue <= 255 &&\n                    0 <= alpha && alpha <= 255\n        ) { \"Color components out of range: $this\" }\n    }\n\n    fun changeAlpha(newAlpha: Int): Color {\n        return Color(red, green, blue, newAlpha)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) {\n            return true\n        }\n        if (other !is Color) {\n            return false\n        }\n\n        if (red != other.red) {\n            return false\n        }\n        if (green != other.green) {\n            return false\n        }\n        if (blue != other.blue) {\n            return false\n        }\n        return alpha == other.alpha\n    }\n\n    fun toCssColor(): String {\n        return if (alpha == 255) {\n            \"rgb($red,$green,$blue)\"\n        } else {\n            \"rgba(\" + red + \",\" + green + \",\" + blue + \",\" + alpha / 255.0 + \")\"\n        }\n    }\n\n    fun toHexColor(): String {\n        return \"#\" + toColorPart(red) + toColorPart(green) + toColorPart(blue)\n    }\n\n    override fun hashCode(): Int {\n        var result = 0\n        result = 31 * result + red\n        result = 31 * result + green\n        result = 31 * result + blue\n        result = 31 * result + alpha\n        return result\n    }\n\n    override fun toString(): String {\n        return \"color($red,$green,$blue,$alpha)\"\n    }\n\n    companion object {\n        val TRANSPARENT = Color(0, 0, 0, 0)\n        val WHITE = Color(255, 255, 255)\n        val CONSOLE_WHITE = Color(204, 204, 204)\n        val BLACK = Color(0, 0, 0)\n        val LIGHT_GRAY = Color(192, 192, 192)\n        val VERY_LIGHT_GRAY = Color(210, 210, 210)\n        val GRAY = Color(128, 128, 128)\n        val RED = Color(255, 0, 0)\n        val LIGHT_GREEN = Color(210, 255, 210)\n        val GREEN = Color(0, 255, 0)\n        val DARK_GREEN = Color(0, 128, 0)\n        val BLUE = Color(0, 0, 255)\n        val DARK_BLUE = Color(0, 0, 128)\n        val LIGHT_BLUE = Color(210, 210, 255)\n        val YELLOW = Color(255, 255, 0)\n        val CONSOLE_YELLOW = Color(174, 174, 36)\n        val LIGHT_YELLOW = Color(255, 255, 128)\n        val VERY_LIGHT_YELLOW = Color(255, 255, 210)\n        val MAGENTA = Color(255, 0, 255)\n        val LIGHT_MAGENTA = Color(255, 210, 255)\n        val DARK_MAGENTA = Color(128, 0, 128)\n        val CYAN = Color(0, 255, 255)\n        val LIGHT_CYAN = Color(210, 255, 255)\n        val ORANGE = Color(255, 192, 0)\n        val PINK = Color(255, 175, 175)\n        val LIGHT_PINK = Color(255, 210, 210)\n\n        val PACIFIC_BLUE = parseHex(\"#118ED8\")\n\n        private const val RGB = \"rgb\"\n        private const val COLOR = \"color\"\n        private const val RGBA = \"rgba\"\n\n        fun parseRGB(text: String): Color {\n            val firstParen = findNext(text, \"(\", 0)\n            val prefix = text.substring(0, firstParen)\n\n            val firstComma = findNext(text, \",\", firstParen + 1)\n            val secondComma = findNext(text, \",\", firstComma + 1)\n\n            var thirdComma = -1\n\n            when {\n                prefix == RGBA -> thirdComma = findNext(text, \",\", secondComma + 1)\n                prefix == COLOR -> thirdComma = text.indexOf(\",\", secondComma + 1)\n                prefix != RGB -> throw IllegalArgumentException(text)\n            }\n\n            val lastParen = findNext(text, \")\", thirdComma + 1)\n            val red = text.substring(firstParen + 1, firstComma).trim { it <= ' ' }.toInt()\n            val green = text.substring(firstComma + 1, secondComma).trim { it <= ' ' }.toInt()\n\n            val blue: Int\n            val alpha: Int\n            if (thirdComma == -1) {\n                blue = text.substring(secondComma + 1, lastParen).trim { it <= ' ' }.toInt()\n                alpha = 255\n            } else {\n                blue = text.substring(secondComma + 1, thirdComma).trim { it <= ' ' }.toInt()\n                alpha = (text.substring(thirdComma + 1, lastParen).trim { it <= ' ' }.toFloat() * 255).roundToInt()\n            }\n\n            return Color(red, green, blue, alpha)\n        }\n\n        private fun findNext(s: String, what: String, from: Int): Int {\n            val result = s.indexOf(what, from)\n            if (result == -1) {\n                throw IllegalArgumentException(\"text=$s what=$what from=$from\")\n            }\n            return result\n        }\n\n        fun parseHex(hexColor: String): Color {\n            @Suppress(\"NAME_SHADOWING\")\n            var hexColor = hexColor\n            if (!hexColor.startsWith(\"#\")) {\n                throw IllegalArgumentException(\"Not a HEX value: $hexColor\")\n            }\n            hexColor = hexColor.substring(1)\n            if (hexColor.length != 6) {\n                throw IllegalArgumentException(\"Not a HEX value: $hexColor\")\n            }\n            val r = hexColor.substring(0, 2).toInt(16)\n            val g = hexColor.substring(2, 4).toInt(16)\n            val b = hexColor.substring(4, 6).toInt(16)\n            return Color(r, g, b)\n        }\n\n        private fun toColorPart(value: Int): String {\n            if (value < 0 || value > 255) {\n                throw IllegalArgumentException(\"RGB color part must be in range [0..255] but was $value\")\n            }\n\n            val result = value.toString(16)\n            return if (result.length == 1) {\n                \"0$result\"\n            } else {\n                result\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.*\nimport kotlin.random.Random\n\nobject Colors {\n    private const val DEFAULT_FACTOR = 0.7\n\n    private val variantColors = mapOf<String, Color>(\n        \"dark_blue\" to Color.DARK_BLUE,\n        \"dark_green\" to Color.DARK_GREEN,\n        \"dark_magenta\" to Color.DARK_MAGENTA,\n        \"light_blue\" to Color.LIGHT_BLUE,\n        \"light_gray\" to Color.LIGHT_GRAY,\n        \"light_green\" to Color.LIGHT_GREEN,\n        \"light_yellow\" to Color.LIGHT_YELLOW,\n        \"light_magenta\" to Color.LIGHT_MAGENTA,\n        \"light_cyan\" to Color.LIGHT_CYAN,\n        \"light_pink\" to Color.LIGHT_PINK,\n        \"very_light_gray\" to Color.VERY_LIGHT_GRAY,\n        \"very_light_yellow\" to Color.VERY_LIGHT_YELLOW\n    )\n    private val namedColors = mapOf<String, Color>(\n        \"white\" to Color.WHITE,\n        \"black\" to Color.BLACK,\n        \"gray\" to Color.GRAY,\n        \"red\" to Color.RED,\n        \"green\" to Color.GREEN,\n        \"blue\" to Color.BLUE,\n        \"yellow\" to Color.YELLOW,\n        \"magenta\" to Color.MAGENTA,\n        \"cyan\" to Color.CYAN,\n        \"orange\" to Color.ORANGE,\n        \"pink\" to Color.PINK\n    ) +\n            // light_gray\n            variantColors +\n            // light-gray\n            variantColors.mapKeys { it.key.replace('_', '-') } +\n            // lightgray\n            variantColors.mapKeys { it.key.replace(\"_\", \"\") }\n\n\n    /**\n     * @param c color string to parse. Accepted formats:\n     *     - rgb(r, g, b)\n     *     - rgba(r, g, b, a)\n     *     - color(r, g, b, a)\n     *     - #rrggbb\n     *     - white, green etc.\n     */\n    fun parseColor(c: String): Color {\n        return when {\n            c.indexOf('(') > 0 -> Color.parseRGB(c)\n            c.startsWith(\"#\") -> Color.parseHex(c)\n            isColorName(c) -> forName(c)\n            else -> throw IllegalArgumentException(\"Error persing color value: $c\")\n        }\n    }\n\n    fun isColorName(colorName: String): Boolean {\n        return namedColors.containsKey(colorName.lowercase())\n    }\n\n    fun forName(colorName: String): Color {\n        return namedColors[colorName.lowercase()] ?: throw IllegalArgumentException()\n    }\n\n    fun generateHueColor(): Double {\n        return 360 * Random.nextDouble()\n    }\n\n    fun generateColor(s: Double, v: Double): Color {\n        return rgbFromHsv(360 * Random.nextDouble(), s, v)\n    }\n\n    /**\n     * @param h hue, [0, 360] degree\n     * @param s saturation, [0, 1]\n     * @param v value, [0, 1]\n     */\n    @JvmOverloads\n    fun rgbFromHsv(h: Double, s: Double, v: Double = 1.0): Color {\n        val hd = h / 60\n        val c = v * s\n        val x = c * (1 - abs(hd % 2 - 1))\n\n        var r = 0.0\n        var g = 0.0\n        var b = 0.0\n\n        when {\n            hd < 1 -> {\n                r = c\n                g = x\n            }\n            hd < 2 -> {\n                r = x\n                g = c\n            }\n            hd < 3 -> {\n                g = c\n                b = x\n            }\n            hd < 4 -> {\n                g = x\n                b = c\n            }\n            hd < 5 -> {\n                r = x\n                b = c\n            }\n            else -> {\n                r = c\n                b = x\n            }\n        }\n\n        val m = v - c\n        return Color((255 * (r + m)).toInt(), (255 * (g + m)).toInt(), (255 * (b + m)).toInt())\n    }\n\n    fun hsvFromRgb(color: Color): DoubleArray {\n        val scale = (1f / 255).toDouble()\n        val r = color.red * scale\n        val g = color.green * scale\n        val b = color.blue * scale\n        val min = min(r, min(g, b))\n        val max = max(r, max(g, b))\n\n        val v = if (max == 0.0) 0.0 else 1 - min / max\n        val h: Double\n        val div = 1f / (6 * (max - min))\n\n        h = if (max == min) {\n            0.0\n        } else if (max == r) {\n            if (g >= b) (g - b) * div else 1 + (g - b) * div\n        } else if (max == g) {\n            1f / 3 + (b - r) * div\n        } else {\n            2f / 3 + (r - g) * div\n        }\n\n        return doubleArrayOf(360 * h, v, max)\n    }\n\n    @JvmOverloads\n    fun darker(c: Color?, factor: Double = DEFAULT_FACTOR): Color? {\n        return c?.let {\n            Color(\n                max((c.red * factor).toInt(), 0),\n                max((c.green * factor).toInt(), 0),\n                max((c.blue * factor).toInt(), 0),\n                c.alpha\n            )\n        }\n    }\n\n    @JvmOverloads\n    fun lighter(c: Color, factor: Double = DEFAULT_FACTOR): Color {\n        var r = c.red\n        var g = c.green\n        var b = c.blue\n        val alpha = c.alpha\n\n        val i = (1.0 / (1.0 - factor)).toInt()\n        if (r == 0 && g == 0 && b == 0) {\n            return Color(i, i, i, alpha)\n        }\n        if (r > 0 && r < i) r = i\n        if (g > 0 && g < i) g = i\n        if (b > 0 && b < i) b = i\n\n        return Color(\n            min((r / factor).toInt(), 255),\n            min((g / factor).toInt(), 255),\n            min((b / factor).toInt(), 255),\n            alpha\n        )\n    }\n\n    fun mimicTransparency(color: Color, alpha: Double, background: Color): Color {\n        val red = (color.red * alpha + background.red * (1 - alpha)).toInt()\n        val green = (color.green * alpha + background.green * (1 - alpha)).toInt()\n        val blue = (color.blue * alpha + background.blue * (1 - alpha)).toInt()\n        return Color(red, green, blue)\n    }\n\n    fun withOpacity(c: Color, opacity: Double): Color {\n        return if (opacity < 1.0) {\n            c.changeAlpha(max(0, min(255, round(255 * opacity).toInt())))\n        } else c\n    }\n\n    fun contrast(color: Color, other: Color): Double {\n        return (luminance(color) + .05) / (luminance(other) + .05)\n    }\n\n    fun luminance(color: Color): Double {\n        return .2126 * colorLuminance(color.red) + .7152 * colorLuminance(color.green) + .0722 * colorLuminance(color.blue)\n    }\n\n    private fun colorLuminance(componentValue: Int): Double {\n        return if (componentValue <= 10) componentValue / 3294.0 else (componentValue / 269.0 + .0513).pow(2.4)\n    }\n\n    fun solid(c: Color): Boolean {\n        return c.alpha == 255\n    }\n\n    fun distributeEvenly(count: Int, saturation: Double): Array<Color> {\n        val result = arrayOfNulls<Color>(count)\n\n        val sector = 360 / count\n        for (i in 0 until count) {\n            result[i] = rgbFromHsv((sector * i).toDouble(), saturation)\n        }\n        @Suppress(\"UNCHECKED_CAST\")\n        return result as Array<Color>\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nfun toPngDataUri(base64EncodedPngImage: String): String {\n    return \"data:image/png;base64,$base64EncodedPngImage\"\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\n\nclass Font @JvmOverloads constructor(val family: FontFamily, val size: Int, val isBold: Boolean = false, val isItalic: Boolean = false) {\n\n    override fun toString(): String {\n        return \"$family $size ${if (isBold) \"bold\" else \"\"} ${if (isItalic) \"italic\" else \"\"}\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other !is Font) return false\n        return family === other.family &&\n                size == other.size &&\n                isBold == other.isBold &&\n                isItalic == other.isItalic\n    }\n\n    override fun hashCode(): Int {\n        var result = family.hashCode()\n        result = 31 * result + size\n        result = 31 * result + if (isBold) 1 else 0\n        result = 31 * result + if (isItalic) 1 else 0\n        return result\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nclass FontFamily private constructor(private val myName: String) {\n\n    override fun toString(): String {\n        return myName\n    }\n\n    companion object {\n        val MONOSPACED = forName(\"monospace\")\n        val SERIF = forName(\"serif\")\n\n        fun forName(name: String): FontFamily {\n            return FontFamily(name)\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.math.abs\n\n/**\n * @param h hue, degree. Normal range: [0, 360]\n * @param saturation saturation, [0, 1]\n * @param value value, [0, 1]\n */\nclass HSV(val h: Double, saturation: Double, value: Double = 1.0) {\n    val s: Double\n    val v: Double\n\n    init {\n        require(saturation >= -0.001 && saturation <= 1.001) { \"HSV 'saturation' must be in range [0, 1] but was $saturation\" }\n        require(value >= -0.001 && value <= 1.001) { \"HSV 'value' must be in range [0, 1] but was $value\" }\n\n        s = abs((saturation * 100).toInt() / 100.0)\n        v = abs((value * 100).toInt() / 100.0)\n    }\n\n    override fun toString(): String {\n        return \"HSV($h, $s, $v)\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass Interval(val lowerBound: Int, val upperBound: Int) {\n\n    val length: Int\n        get() = upperBound - lowerBound\n\n    init {\n        if (lowerBound > upperBound) {\n            throw IllegalArgumentException(\"Lower bound is greater than upper: lower bound=\" + lowerBound\n                    + \", upper bound=\" + upperBound)\n        }\n    }\n\n    operator fun contains(point: Int): Boolean {\n        return lowerBound <= point && point <= upperBound\n    }\n\n    operator fun contains(other: Interval): Boolean {\n        return contains(other.lowerBound) && contains(other.upperBound)\n    }\n\n    fun intersects(other: Interval): Boolean {\n        return contains(other.lowerBound) || other.contains(lowerBound)\n    }\n\n    /**\n     * Returns minimal interval that contains both this and other intervals.\n     */\n    fun union(other: Interval): Interval {\n        return Interval(min(lowerBound, other.lowerBound), max(upperBound, other.upperBound))\n    }\n\n    fun add(delta: Int): Interval {\n        return Interval(lowerBound + delta, upperBound + delta)\n    }\n\n    fun sub(delta: Int): Interval {\n        return Interval(lowerBound - delta, upperBound - delta)\n    }\n\n    override fun toString(): String {\n        return \"[$lowerBound, $upperBound]\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other !is Interval) return false\n\n        val interval = other as Interval?\n        return if (lowerBound != interval!!.lowerBound) false else upperBound == interval.upperBound\n    }\n\n    override fun hashCode(): Int {\n        var result = lowerBound\n        result = 31 * result + upperBound\n        return result\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\n// ToDo: use Kotlin Pair\nclass Pair<FirstT, SecondT>(val first: FirstT, val second: SecondT) {\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as Pair<*, *>\n\n        if (first != other.first) return false\n        if (second != other.second) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = first?.hashCode() ?: 0\n        result = 31 * result + (second?.hashCode() ?: 0)\n        return result\n    }\n\n    override fun toString(): String {\n        return \"[$first, $second]\"\n    }\n\n    operator fun component1() = first\n    operator fun component2() = second\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o. \n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.logging\n\nimport mu.KotlinLogging\nimport kotlin.reflect.KClass\n\nactual object PortableLogging {\n    actual fun logger(cl: KClass<*>): Logger {\n        val kl = KotlinLogging.logger(cl.simpleName ?: \"<anonymous>\")\n        return object : Logger {\n            override fun error(e: Throwable, message: () -> String) {\n                kl.error(e, message)\n            }\n\n            override fun info(message: () -> String) {\n                kl.info(message)\n            }\n        }\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nconst val EARTH_RADIUS = 6378137.0\nconst val MIN_LONGITUDE = -180.0\nconst val MAX_LONGITUDE = 180.0\nconst val FULL_LONGITUDE = MAX_LONGITUDE - MIN_LONGITUDE\nconst val MIN_LATITUDE = -90.0\nconst val MAX_LATITUDE = 90.0\nconst val FULL_LATITUDE = MAX_LATITUDE - MIN_LATITUDE\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-base-portable.js\n"); +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! kotlin-logging-jsLegacy */ \"./kotlin-dce-dev/kotlin-logging-jsLegacy.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$kotlin_logging_jsLegacy) {\n 'use strict';\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var last = Kotlin.kotlin.collections.last_2p1efm$;\n var get_lastIndex = Kotlin.kotlin.collections.get_lastIndex_55thoc$;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var plus = Kotlin.kotlin.collections.plus_qloxvw$;\n var equals = Kotlin.equals;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var JsMath = Math;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var joinToString = Kotlin.kotlin.collections.joinToString_fmv235$;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var substring = Kotlin.kotlin.text.substring_fc3b62$;\n var padStart = Kotlin.kotlin.text.padStart_vrc1nu$;\n var Map = Kotlin.kotlin.collections.Map;\n var throwCCE = Kotlin.throwCCE;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var Regex_init = Kotlin.kotlin.text.Regex_init_61zpoe$;\n var IllegalArgumentException_init_0 = Kotlin.kotlin.IllegalArgumentException_init;\n var ensureNotNull = Kotlin.ensureNotNull;\n var hashCode = Kotlin.hashCode;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init;\n var toInt = Kotlin.kotlin.text.toInt_pdl1vz$;\n var Comparable = Kotlin.kotlin.Comparable;\n var toString = Kotlin.toString;\n var L0 = Kotlin.Long.ZERO;\n var L1 = Kotlin.Long.ONE;\n var L1000 = Kotlin.Long.fromInt(1000);\n var L60 = Kotlin.Long.fromInt(60);\n var L24 = Kotlin.Long.fromInt(24);\n var L7 = Kotlin.Long.fromInt(7);\n var contains = Kotlin.kotlin.text.contains_li3zpu$;\n var NumberFormatException = Kotlin.kotlin.NumberFormatException;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var L_5 = Kotlin.Long.fromInt(-5);\n var L4 = Kotlin.Long.fromInt(4);\n var L3 = Kotlin.Long.fromInt(3);\n var L60000 = Kotlin.Long.fromInt(60000);\n var L3600000 = Kotlin.Long.fromInt(3600000);\n var L86400000 = Kotlin.Long.fromInt(86400000);\n var defineInlineFunction = Kotlin.defineInlineFunction;\n var wrapFunction = Kotlin.wrapFunction;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_bwtc7$;\n var IllegalStateException_init_0 = Kotlin.kotlin.IllegalStateException_init;\n var unboxChar = Kotlin.unboxChar;\n var toChar = Kotlin.toChar;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var asList = Kotlin.kotlin.collections.asList_us0mfu$;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var copyToArray = Kotlin.kotlin.collections.copyToArray;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var NullPointerException_init = Kotlin.kotlin.NullPointerException_init;\n var IllegalArgumentException = Kotlin.kotlin.IllegalArgumentException;\n var NoSuchElementException_init = Kotlin.kotlin.NoSuchElementException_init;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var IndexOutOfBoundsException = Kotlin.kotlin.IndexOutOfBoundsException;\n var toList = Kotlin.kotlin.collections.toList_7wnvza$;\n var count = Kotlin.kotlin.collections.count_7wnvza$;\n var Collection = Kotlin.kotlin.collections.Collection;\n var plus_0 = Kotlin.kotlin.collections.plus_q4559j$;\n var List = Kotlin.kotlin.collections.List;\n var last_0 = Kotlin.kotlin.collections.last_7wnvza$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var Comparator = Kotlin.kotlin.Comparator;\n var sortWith = Kotlin.kotlin.collections.sortWith_iwcb0m$;\n var toList_0 = Kotlin.kotlin.collections.toList_us0mfu$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var naturalOrder = Kotlin.kotlin.comparisons.naturalOrder_dahdeg$;\n var lastOrNull = Kotlin.kotlin.collections.lastOrNull_2p1efm$;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var abs = Kotlin.kotlin.math.abs_za3lpa$;\n var Unit = Kotlin.kotlin.Unit;\n var getCallableRef = Kotlin.getCallableRef;\n var map = Kotlin.kotlin.sequences.map_z5avom$;\n var numberToInt = Kotlin.numberToInt;\n var toMutableMap = Kotlin.kotlin.collections.toMutableMap_abgq59$;\n var throwUPAE = Kotlin.throwUPAE;\n var kotlin_js_internal_BooleanCompanionObject = Kotlin.kotlin.js.internal.BooleanCompanionObject;\n var first_0 = Kotlin.kotlin.collections.first_7wnvza$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var drop = Kotlin.kotlin.sequences.drop_wuwhe2$;\n var isWhitespace = Kotlin.kotlin.text.isWhitespace_myv2d0$;\n var toBoxedChar = Kotlin.toBoxedChar;\n var contains_0 = Kotlin.kotlin.collections.contains_o2f9me$;\n var CharRange = Kotlin.kotlin.ranges.CharRange;\n var iterator = Kotlin.kotlin.text.iterator_gw00vp$;\n var toDouble = Kotlin.kotlin.text.toDouble_pdl1vz$;\n var Exception_init = Kotlin.kotlin.Exception_init_pdl1vj$;\n var Exception = Kotlin.kotlin.Exception;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var MutableMap = Kotlin.kotlin.collections.MutableMap;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var StringBuilder = Kotlin.kotlin.text.StringBuilder;\n var toString_0 = Kotlin.kotlin.text.toString_dqglrj$;\n var toInt_0 = Kotlin.kotlin.text.toInt_6ic1pp$;\n var numberToDouble = Kotlin.numberToDouble;\n var equals_0 = Kotlin.kotlin.text.equals_igcy3c$;\n var NoSuchElementException_init_0 = Kotlin.kotlin.NoSuchElementException;\n var Any = Object;\n var AbstractMutableSet = Kotlin.kotlin.collections.AbstractMutableSet;\n var AbstractCollection = Kotlin.kotlin.collections.AbstractCollection;\n var AbstractSet = Kotlin.kotlin.collections.AbstractSet;\n var MutableIterator = Kotlin.kotlin.collections.MutableIterator;\n var Array_0 = Array;\n var println = Kotlin.kotlin.io.println_s8jyv4$;\n var math = Kotlin.kotlin.math;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var toLong = Kotlin.kotlin.text.toLong_pdl1vz$;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var toIntOrNull = Kotlin.kotlin.text.toIntOrNull_pdl1vz$;\n var repeat = Kotlin.kotlin.text.repeat_94bcnn$;\n var trimEnd = Kotlin.kotlin.text.trimEnd_wqw3xr$;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var slice = Kotlin.kotlin.text.slice_fc3b62$;\n var startsWith = Kotlin.kotlin.text.startsWith_sgbm27$;\n var roundToLong = Kotlin.kotlin.math.roundToLong_yrwdxr$;\n var toString_1 = Kotlin.kotlin.text.toString_if0zpk$;\n var padEnd = Kotlin.kotlin.text.padEnd_vrc1nu$;\n var get_sign = Kotlin.kotlin.math.get_sign_s8ev3n$;\n var coerceAtLeast_0 = Kotlin.kotlin.ranges.coerceAtLeast_38ydlf$;\n var coerceAtMost = Kotlin.kotlin.ranges.coerceAtMost_38ydlf$;\n var asSequence_0 = Kotlin.kotlin.text.asSequence_gw00vp$;\n var plus_1 = Kotlin.kotlin.sequences.plus_v0iwhp$;\n var indexOf = Kotlin.kotlin.text.indexOf_l5u8uk$;\n var chunked = Kotlin.kotlin.sequences.chunked_wuwhe2$;\n var joinToString_0 = Kotlin.kotlin.sequences.joinToString_853xkz$;\n var reversed_0 = Kotlin.kotlin.text.reversed_gw00vp$;\n var MutableCollection = Kotlin.kotlin.collections.MutableCollection;\n var AbstractMutableList = Kotlin.kotlin.collections.AbstractMutableList;\n var MutableList = Kotlin.kotlin.collections.MutableList;\n var Throwable = Error;\n var plus_2 = Kotlin.kotlin.collections.plus_mydzjv$;\n var Random = Kotlin.kotlin.random.Random;\n var random = Kotlin.kotlin.collections.random_iscd7z$;\n var arrayListOf = Kotlin.kotlin.collections.arrayListOf_i5x0yv$;\n var minOrNull = Kotlin.kotlin.sequences.minOrNull_1bslqu$;\n var maxOrNull = Kotlin.kotlin.sequences.maxOrNull_1bslqu$;\n var flatten = Kotlin.kotlin.sequences.flatten_d9bjs1$;\n var first_1 = Kotlin.kotlin.sequences.first_veqyi0$;\n var Pair = Kotlin.kotlin.Pair;\n var sortedWith = Kotlin.kotlin.sequences.sortedWith_vjgqpk$;\n var filter = Kotlin.kotlin.sequences.filter_euau3h$;\n var toList_1 = Kotlin.kotlin.sequences.toList_veqyi0$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_mh5how$;\n var single = Kotlin.kotlin.collections.single_2p1efm$;\n var replace = Kotlin.kotlin.text.replace_680rmw$;\n var StringBuilder_init_0 = Kotlin.kotlin.text.StringBuilder_init_za3lpa$;\n var toDoubleOrNull = Kotlin.kotlin.text.toDoubleOrNull_pdl1vz$;\n var AbstractList = Kotlin.kotlin.collections.AbstractList;\n var asIterable = Kotlin.kotlin.sequences.asIterable_veqyi0$;\n var Set = Kotlin.kotlin.collections.Set;\n var UnsupportedOperationException_init = Kotlin.kotlin.UnsupportedOperationException_init;\n var UnsupportedOperationException_init_0 = Kotlin.kotlin.UnsupportedOperationException_init_pdl1vj$;\n var startsWith_0 = Kotlin.kotlin.text.startsWith_7epoxm$;\n var roundToInt = Kotlin.kotlin.math.roundToInt_yrwdxr$;\n var indexOf_0 = Kotlin.kotlin.text.indexOf_8eortd$;\n var plus_3 = Kotlin.kotlin.collections.plus_iwxh38$;\n var replace_0 = Kotlin.kotlin.text.replace_r2fvfm$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var mu = $module$kotlin_logging_jsLegacy.mu;\n Format$PatternSpecPart.prototype = Object.create(Format$SpecPart.prototype);\n Format$PatternSpecPart.prototype.constructor = Format$PatternSpecPart;\n Pattern$Companion$Kind.prototype = Object.create(Enum.prototype);\n Pattern$Companion$Kind.prototype.constructor = Pattern$Companion$Kind;\n Pattern.prototype = Object.create(Enum.prototype);\n Pattern.prototype.constructor = Pattern;\n Month$VarLengthMonth.prototype = Object.create(Month.prototype);\n Month$VarLengthMonth.prototype.constructor = Month$VarLengthMonth;\n WeekDay.prototype = Object.create(Enum.prototype);\n WeekDay.prototype.constructor = WeekDay;\n TimeZoneMoscow.prototype = Object.create(TimeZone.prototype);\n TimeZoneMoscow.prototype.constructor = TimeZoneMoscow;\n TimeZones$utc$ObjectLiteral.prototype = Object.create(TimeZone.prototype);\n TimeZones$utc$ObjectLiteral.prototype.constructor = TimeZones$utc$ObjectLiteral;\n TimeZones$offset$ObjectLiteral.prototype = Object.create(TimeZone.prototype);\n TimeZones$offset$ObjectLiteral.prototype.constructor = TimeZones$offset$ObjectLiteral;\n TimeZones$DSTimeZone.prototype = Object.create(TimeZone.prototype);\n TimeZones$DSTimeZone.prototype.constructor = TimeZones$DSTimeZone;\n TimeZones$withEuSummerTime$ObjectLiteral.prototype = Object.create(TimeZones$DSTimeZone.prototype);\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.constructor = TimeZones$withEuSummerTime$ObjectLiteral;\n TimeZones$withUsSummerTime$ObjectLiteral.prototype = Object.create(TimeZones$DSTimeZone.prototype);\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.constructor = TimeZones$withUsSummerTime$ObjectLiteral;\n Button.prototype = Object.create(Enum.prototype);\n Button.prototype.constructor = Button;\n Key.prototype = Object.create(Enum.prototype);\n Key.prototype.constructor = Key;\n KeyEvent.prototype = Object.create(Event.prototype);\n KeyEvent.prototype.constructor = KeyEvent;\n ModifierKey.prototype = Object.create(Enum.prototype);\n ModifierKey.prototype.constructor = ModifierKey;\n PointEvent.prototype = Object.create(Event.prototype);\n PointEvent.prototype.constructor = PointEvent;\n MouseEvent.prototype = Object.create(PointEvent.prototype);\n MouseEvent.prototype.constructor = MouseEvent;\n MouseEventSpec.prototype = Object.create(Enum.prototype);\n MouseEventSpec.prototype.constructor = MouseEventSpec;\n ComparatorOrdering.prototype = Object.create(Ordering.prototype);\n ComparatorOrdering.prototype.constructor = ComparatorOrdering;\n FluentArray.prototype = Object.create(FluentValue.prototype);\n FluentArray.prototype.constructor = FluentArray;\n FluentObject.prototype = Object.create(FluentValue.prototype);\n FluentObject.prototype.constructor = FluentObject;\n FluentPrimitive.prototype = Object.create(FluentValue.prototype);\n FluentPrimitive.prototype.constructor = FluentPrimitive;\n JsonParser$JsonException.prototype = Object.create(Exception.prototype);\n JsonParser$JsonException.prototype.constructor = JsonParser$JsonException;\n Token.prototype = Object.create(Enum.prototype);\n Token.prototype.constructor = Token;\n ListMap$keySet$ObjectLiteral.prototype = Object.create(AbstractMutableSet.prototype);\n ListMap$keySet$ObjectLiteral.prototype.constructor = ListMap$keySet$ObjectLiteral;\n ListMap$values$ObjectLiteral.prototype = Object.create(AbstractCollection.prototype);\n ListMap$values$ObjectLiteral.prototype.constructor = ListMap$values$ObjectLiteral;\n ListMap$entrySet$ObjectLiteral.prototype = Object.create(AbstractSet.prototype);\n ListMap$entrySet$ObjectLiteral.prototype.constructor = ListMap$entrySet$ObjectLiteral;\n ChildList_init$ObjectLiteral.prototype = Object.create(CollectionAdapter.prototype);\n ChildList_init$ObjectLiteral.prototype.constructor = ChildList_init$ObjectLiteral;\n AbstractObservableList.prototype = Object.create(AbstractMutableList.prototype);\n AbstractObservableList.prototype.constructor = AbstractObservableList;\n ObservableArrayList.prototype = Object.create(AbstractObservableList.prototype);\n ObservableArrayList.prototype.constructor = ObservableArrayList;\n ChildList.prototype = Object.create(ObservableArrayList.prototype);\n ChildList.prototype.constructor = ChildList;\n ValueProperty.prototype = Object.create(BaseReadableProperty.prototype);\n ValueProperty.prototype.constructor = ValueProperty;\n ChildProperty.prototype = Object.create(ValueProperty.prototype);\n ChildProperty.prototype.constructor = ChildProperty;\n CollectionItemEvent$EventType.prototype = Object.create(Enum.prototype);\n CollectionItemEvent$EventType.prototype.constructor = CollectionItemEvent$EventType;\n AbstractObservableList$addListener$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n AbstractObservableList$addListener$ObjectLiteral.prototype.constructor = AbstractObservableList$addListener$ObjectLiteral;\n CompositeEventSource$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n CompositeEventSource$addHandler$ObjectLiteral.prototype.constructor = CompositeEventSource$addHandler$ObjectLiteral;\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype = Object.create(CollectionAdapter.prototype);\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.constructor = EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral;\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype.constructor = EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0;\n Listeners$add$ObjectLiteral.prototype = Object.create(Registration.prototype);\n Listeners$add$ObjectLiteral.prototype.constructor = Listeners$add$ObjectLiteral;\n DelayedValueProperty$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n DelayedValueProperty$addHandler$ObjectLiteral.prototype.constructor = DelayedValueProperty$addHandler$ObjectLiteral;\n DelayedValueProperty.prototype = Object.create(BaseReadableProperty.prototype);\n DelayedValueProperty.prototype.constructor = DelayedValueProperty;\n ValueProperty$addHandler$ObjectLiteral.prototype = Object.create(Listeners.prototype);\n ValueProperty$addHandler$ObjectLiteral.prototype.constructor = ValueProperty$addHandler$ObjectLiteral;\n CompositeRegistration.prototype = Object.create(Registration.prototype);\n CompositeRegistration.prototype.constructor = CompositeRegistration;\n Registration$EmptyRegistration.prototype = Object.create(Registration.prototype);\n Registration$EmptyRegistration.prototype.constructor = Registration$EmptyRegistration;\n Registration$Companion$from$ObjectLiteral.prototype = Object.create(Registration.prototype);\n Registration$Companion$from$ObjectLiteral.prototype.constructor = Registration$Companion$from$ObjectLiteral;\n Registration$Companion$from$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n Registration$Companion$from$ObjectLiteral_0.prototype.constructor = Registration$Companion$from$ObjectLiteral_0;\n SimpleFeature$GeometryType.prototype = Object.create(Enum.prototype);\n SimpleFeature$GeometryType.prototype.constructor = SimpleFeature$GeometryType;\n StringFormat$FormatType.prototype = Object.create(Enum.prototype);\n StringFormat$FormatType.prototype.constructor = StringFormat$FormatType;\n AbstractGeometryList.prototype = Object.create(AbstractList.prototype);\n AbstractGeometryList.prototype.constructor = AbstractGeometryList;\n GeometryType.prototype = Object.create(Enum.prototype);\n GeometryType.prototype.constructor = GeometryType;\n LineString.prototype = Object.create(AbstractGeometryList.prototype);\n LineString.prototype.constructor = LineString;\n MultiLineString.prototype = Object.create(AbstractGeometryList.prototype);\n MultiLineString.prototype.constructor = MultiLineString;\n MultiPoint.prototype = Object.create(AbstractGeometryList.prototype);\n MultiPoint.prototype.constructor = MultiPoint;\n MultiPolygon.prototype = Object.create(AbstractGeometryList.prototype);\n MultiPolygon.prototype.constructor = MultiPolygon;\n Polygon.prototype = Object.create(AbstractGeometryList.prototype);\n Polygon.prototype.constructor = Polygon;\n Ring.prototype = Object.create(AbstractGeometryList.prototype);\n Ring.prototype.constructor = Ring;\n function splitRings(points) {\n var $receiver = findRingIntervals(points);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(sublist(points, item));\n }\n var rings = toMutableList(destination);\n if (!rings.isEmpty()) {\n if (!isClosed(last(rings))) {\n rings.set_wxm5ur$(get_lastIndex(rings), makeClosed(last(rings)));\n }}return rings;\n }\n function makeClosed(path) {\n return plus(toMutableList(path), first(path));\n }\n function isClosed($receiver) {\n return equals(first($receiver), last($receiver));\n }\n function findRingIntervals(path) {\n var intervals = ArrayList_init();\n var startIndex = 0;\n var i = 0;\n var n = path.size;\n while (i < n) {\n if (startIndex !== i && equals(path.get_za3lpa$(startIndex), path.get_za3lpa$(i))) {\n intervals.add_11rb$(new ClosedRange(startIndex, i + 1 | 0));\n startIndex = i + 1 | 0;\n }i = i + 1 | 0;\n }\n if (startIndex !== path.size) {\n intervals.add_11rb$(new ClosedRange(startIndex, path.size));\n }return intervals;\n }\n function sublist($receiver, range) {\n return $receiver.subList_vux9f0$(range.lowerEnd, range.upperEnd);\n }\n function calculateArea(ring) {\n return calculateArea_0(ring, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }));\n }\n function isClockwise(ring, x, y) {\n var tmp$;\n if (!!ring.isEmpty()) {\n var message = \"Ring shouldn't be empty to calculate clockwise\";\n throw IllegalStateException_init(message.toString());\n }var sum = 0.0;\n var prev = ring.get_za3lpa$(ring.size - 1 | 0);\n tmp$ = ring.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n sum += x(prev) * y(point) - x(point) * y(prev);\n prev = point;\n }\n return sum < 0.0;\n }\n function calculateArea_0(ring, x, y) {\n var area = 0.0;\n var j = ring.size - 1 | 0;\n for (var i = 0; i !== ring.size; ++i) {\n var p1 = ring.get_za3lpa$(i);\n var p2 = ring.get_za3lpa$(j);\n area += (x(p2) + x(p1)) * (y(p2) - y(p1));\n j = i;\n }\n var x_0 = area / 2;\n return JsMath.abs(x_0);\n }\n function DateLocale() {\n DateLocale_instance = this;\n this.weekDayAbbr = mapOf([to(WeekDay$MONDAY_getInstance(), 'Mon'), to(WeekDay$TUESDAY_getInstance(), 'Tue'), to(WeekDay$WEDNESDAY_getInstance(), 'Wed'), to(WeekDay$THURSDAY_getInstance(), 'Thu'), to(WeekDay$FRIDAY_getInstance(), 'Fri'), to(WeekDay$SATURDAY_getInstance(), 'Sat'), to(WeekDay$SUNDAY_getInstance(), 'Sun')]);\n this.weekDayFull = mapOf([to(WeekDay$MONDAY_getInstance(), 'Monday'), to(WeekDay$TUESDAY_getInstance(), 'Tuesday'), to(WeekDay$WEDNESDAY_getInstance(), 'Wednesday'), to(WeekDay$THURSDAY_getInstance(), 'Thursday'), to(WeekDay$FRIDAY_getInstance(), 'Friday'), to(WeekDay$SATURDAY_getInstance(), 'Saturday'), to(WeekDay$SUNDAY_getInstance(), 'Sunday')]);\n this.monthAbbr = mapOf([to(Month$Companion_getInstance().JANUARY, 'Jan'), to(Month$Companion_getInstance().FEBRUARY, 'Feb'), to(Month$Companion_getInstance().MARCH, 'Mar'), to(Month$Companion_getInstance().APRIL, 'Apr'), to(Month$Companion_getInstance().MAY, 'May'), to(Month$Companion_getInstance().JUNE, 'Jun'), to(Month$Companion_getInstance().JULY, 'Jul'), to(Month$Companion_getInstance().AUGUST, 'Aug'), to(Month$Companion_getInstance().SEPTEMBER, 'Sep'), to(Month$Companion_getInstance().OCTOBER, 'Oct'), to(Month$Companion_getInstance().NOVEMBER, 'Nov'), to(Month$Companion_getInstance().DECEMBER, 'Dec')]);\n this.monthFull = mapOf([to(Month$Companion_getInstance().JANUARY, 'January'), to(Month$Companion_getInstance().FEBRUARY, 'February'), to(Month$Companion_getInstance().MARCH, 'March'), to(Month$Companion_getInstance().APRIL, 'April'), to(Month$Companion_getInstance().MAY, 'May'), to(Month$Companion_getInstance().JUNE, 'June'), to(Month$Companion_getInstance().JULY, 'July'), to(Month$Companion_getInstance().AUGUST, 'August'), to(Month$Companion_getInstance().SEPTEMBER, 'September'), to(Month$Companion_getInstance().OCTOBER, 'October'), to(Month$Companion_getInstance().NOVEMBER, 'November'), to(Month$Companion_getInstance().DECEMBER, 'December')]);\n }\n DateLocale.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateLocale',\n interfaces: []\n };\n var DateLocale_instance = null;\n function DateLocale_getInstance() {\n if (DateLocale_instance === null) {\n new DateLocale();\n }return DateLocale_instance;\n }\n function Format(spec) {\n Format$Companion_getInstance();\n this.spec_0 = spec;\n }\n function Format$SpecPart(str) {\n this.str = str;\n }\n Format$SpecPart.prototype.exec_amwj4p$ = function (dateTime) {\n return this.str;\n };\n Format$SpecPart.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SpecPart',\n interfaces: []\n };\n function Format$PatternSpecPart(str) {\n Format$SpecPart.call(this, str);\n var tmp$;\n tmp$ = Pattern$Companion_getInstance().patternByString_61zpoe$(str);\n if (tmp$ == null) {\n throw IllegalArgumentException_init('Wrong pattern: ' + str);\n }this.pattern = tmp$;\n }\n Format$PatternSpecPart.prototype.exec_amwj4p$ = function (dateTime) {\n return Format$Companion_getInstance().getValueForPattern_0(this.pattern, dateTime);\n };\n Format$PatternSpecPart.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PatternSpecPart',\n interfaces: [Format$SpecPart]\n };\n function Format$apply$lambda(closure$dateTime) {\n return function (it) {\n return it.exec_amwj4p$(closure$dateTime);\n };\n }\n Format.prototype.apply_amwj4p$ = function (dateTime) {\n return joinToString(this.spec_0, '', void 0, void 0, void 0, void 0, Format$apply$lambda(dateTime));\n };\n function Format$apply$lambda_0(closure$date) {\n return function (it) {\n return it.exec_amwj4p$(new DateTime(closure$date));\n };\n }\n Format.prototype.apply_z9gqti$ = function (date) {\n var $receiver = this.spec_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var predicate$result;\n if (Kotlin.isType(element, Format$PatternSpecPart) && element.pattern.kind === Pattern$Companion$Kind$DATE_getInstance()) {\n predicate$result = true;\n } else if (!Kotlin.isType(element, Format$PatternSpecPart)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination.add_11rb$(element);\n }\n return joinToString(destination, '', void 0, void 0, void 0, void 0, Format$apply$lambda_0(date));\n };\n function Format$apply$lambda_1(closure$time) {\n return function (it) {\n return it.exec_amwj4p$(new DateTime(Date$Companion_getInstance().EPOCH, closure$time));\n };\n }\n Format.prototype.apply_z96d9j$ = function (time) {\n var $receiver = this.spec_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var predicate$result;\n if (Kotlin.isType(element, Format$PatternSpecPart) && element.pattern.kind === Pattern$Companion$Kind$TIME_getInstance()) {\n predicate$result = true;\n } else if (!Kotlin.isType(element, Format$PatternSpecPart)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination.add_11rb$(element);\n }\n return joinToString(destination, '', void 0, void 0, void 0, void 0, Format$apply$lambda_1(time));\n };\n function Format$Companion() {\n Format$Companion_instance = this;\n }\n Format$Companion.prototype.parse_61zpoe$ = function (str) {\n var result = ArrayList_init();\n var resultSequence = Pattern$Companion_getInstance().PATTERN_REGEX.findAll_905azu$(str);\n var lastIndex = {v: 0};\n var tmp$;\n tmp$ = resultSequence.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var value = element.value;\n var range = element.range;\n var startIndex = range.first;\n var endIndex = range.last;\n if (startIndex > 0) {\n var spec = new Format$SpecPart(substring(str, until(lastIndex.v, startIndex)));\n result.add_11rb$(spec);\n }result.add_11rb$(new Format$PatternSpecPart(value));\n lastIndex.v = endIndex + 1 | 0;\n }\n if (lastIndex.v < str.length) {\n var startIndex_0 = lastIndex.v;\n result.add_11rb$(new Format$SpecPart(str.substring(startIndex_0)));\n }return result;\n };\n Format$Companion.prototype.getValueForPattern_0 = function (type, dateTime) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n switch (type.name) {\n case 'SECOND':\n return this.leadZero_0(dateTime.seconds);\n case 'MINUTE':\n return this.leadZero_0(dateTime.minutes);\n case 'HOUR_12':\n return this.getHours12_0(dateTime).toString();\n case 'HOUR_12_LEADING_ZERO':\n return this.leadZero_0(this.getHours12_0(dateTime));\n case 'HOUR_24':\n return this.leadZero_0(this.getHours24_0(dateTime));\n case 'MERIDIAN_LOWER':\n return this.getMeridian_0(dateTime);\n case 'MERIDIAN_UPPER':\n return this.getMeridian_0(dateTime).toUpperCase();\n case 'DAY_OF_WEEK':\n return this.getWeekDayNumber_0(dateTime);\n case 'DAY_OF_WEEK_ABBR':\n return (tmp$ = DateLocale_getInstance().weekDayAbbr.get_11rb$(dateTime.weekDay)) != null ? tmp$ : '';\n case 'DAY_OF_WEEK_FULL':\n return (tmp$_0 = DateLocale_getInstance().weekDayFull.get_11rb$(dateTime.weekDay)) != null ? tmp$_0 : '';\n case 'DAY_OF_MONTH':\n return dateTime.day.toString();\n case 'DAY_OF_MONTH_LEADING_ZERO':\n return this.leadZero_0(dateTime.day);\n case 'DAY_OF_THE_YEAR':\n return this.leadZero_0(dateTime.date.daysFromYearStart(), 3);\n case 'MONTH':\n return this.leadZero_0(((tmp$_2 = (tmp$_1 = dateTime.month) != null ? tmp$_1.ordinal() : null) != null ? tmp$_2 : 0) + 1 | 0);\n case 'MONTH_ABBR':\n var $receiver = DateLocale_getInstance().monthAbbr;\n var key = dateTime.month;\n var tmp$_5;\n return (tmp$_3 = (Kotlin.isType(tmp$_5 = $receiver, Map) ? tmp$_5 : throwCCE()).get_11rb$(key)) != null ? tmp$_3 : '';\n case 'MONTH_FULL':\n var $receiver_0 = DateLocale_getInstance().monthFull;\n var key_0 = dateTime.month;\n var tmp$_6;\n return (tmp$_4 = (Kotlin.isType(tmp$_6 = $receiver_0, Map) ? tmp$_6 : throwCCE()).get_11rb$(key_0)) != null ? tmp$_4 : '';\n case 'YEAR_SHORT':\n return dateTime.year.toString().substring(2);\n case 'YEAR_FULL':\n return dateTime.year.toString();\n default:return Kotlin.noWhenBranchMatched();\n }\n };\n Format$Companion.prototype.leadZero_0 = function (value, length) {\n if (length === void 0)\n length = 2;\n return padStart(value.toString(), length, 48);\n };\n Format$Companion.prototype.getHours12_0 = function (dateTime) {\n var tmp$;\n var hours = dateTime.hours;\n if (hours === 0)\n tmp$ = 12;\n else if (hours <= 12)\n tmp$ = hours;\n else\n tmp$ = hours - 12 | 0;\n return tmp$;\n };\n Format$Companion.prototype.getHours24_0 = function (dateTime) {\n if (dateTime.hours === 0)\n return 24;\n else\n return dateTime.hours;\n };\n Format$Companion.prototype.getMeridian_0 = function (dateTime) {\n var tmp$;\n var hours = dateTime.hours;\n if (hours === 24)\n tmp$ = 'am';\n else if (hours <= 12)\n tmp$ = 'am';\n else\n tmp$ = 'pm';\n return tmp$;\n };\n Format$Companion.prototype.getWeekDayNumber_0 = function (dateTime) {\n var num = dateTime.weekDay.ordinal + 1 | 0;\n if (num === 7) {\n num = 0;\n }return num.toString();\n };\n Format$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Format$Companion_instance = null;\n function Format$Companion_getInstance() {\n if (Format$Companion_instance === null) {\n new Format$Companion();\n }return Format$Companion_instance;\n }\n Format.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Format',\n interfaces: []\n };\n function Format_init(spec, $this) {\n $this = $this || Object.create(Format.prototype);\n Format.call($this, Format$Companion_getInstance().parse_61zpoe$(spec));\n return $this;\n }\n function Pattern(name, ordinal, string, kind) {\n Enum.call(this);\n this.string = string;\n this.kind = kind;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Pattern_initFields() {\n Pattern_initFields = function () {\n };\n Pattern$DAY_OF_WEEK_ABBR_instance = new Pattern('DAY_OF_WEEK_ABBR', 0, '%a', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_WEEK_FULL_instance = new Pattern('DAY_OF_WEEK_FULL', 1, '%A', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_ABBR_instance = new Pattern('MONTH_ABBR', 2, '%b', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_FULL_instance = new Pattern('MONTH_FULL', 3, '%B', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_MONTH_LEADING_ZERO_instance = new Pattern('DAY_OF_MONTH_LEADING_ZERO', 4, '%d', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_MONTH_instance = new Pattern('DAY_OF_MONTH', 5, '%e', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_THE_YEAR_instance = new Pattern('DAY_OF_THE_YEAR', 6, '%j', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$MONTH_instance = new Pattern('MONTH', 7, '%m', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$DAY_OF_WEEK_instance = new Pattern('DAY_OF_WEEK', 8, '%w', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$YEAR_SHORT_instance = new Pattern('YEAR_SHORT', 9, '%y', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$YEAR_FULL_instance = new Pattern('YEAR_FULL', 10, '%Y', Pattern$Companion$Kind$DATE_getInstance());\n Pattern$HOUR_24_instance = new Pattern('HOUR_24', 11, '%H', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$HOUR_12_LEADING_ZERO_instance = new Pattern('HOUR_12_LEADING_ZERO', 12, '%I', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$HOUR_12_instance = new Pattern('HOUR_12', 13, '%l', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MINUTE_instance = new Pattern('MINUTE', 14, '%M', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MERIDIAN_LOWER_instance = new Pattern('MERIDIAN_LOWER', 15, '%P', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$MERIDIAN_UPPER_instance = new Pattern('MERIDIAN_UPPER', 16, '%p', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$SECOND_instance = new Pattern('SECOND', 17, '%S', Pattern$Companion$Kind$TIME_getInstance());\n Pattern$Companion_getInstance();\n }\n var Pattern$DAY_OF_WEEK_ABBR_instance;\n function Pattern$DAY_OF_WEEK_ABBR_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_ABBR_instance;\n }\n var Pattern$DAY_OF_WEEK_FULL_instance;\n function Pattern$DAY_OF_WEEK_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_FULL_instance;\n }\n var Pattern$MONTH_ABBR_instance;\n function Pattern$MONTH_ABBR_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_ABBR_instance;\n }\n var Pattern$MONTH_FULL_instance;\n function Pattern$MONTH_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_FULL_instance;\n }\n var Pattern$DAY_OF_MONTH_LEADING_ZERO_instance;\n function Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_MONTH_LEADING_ZERO_instance;\n }\n var Pattern$DAY_OF_MONTH_instance;\n function Pattern$DAY_OF_MONTH_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_MONTH_instance;\n }\n var Pattern$DAY_OF_THE_YEAR_instance;\n function Pattern$DAY_OF_THE_YEAR_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_THE_YEAR_instance;\n }\n var Pattern$MONTH_instance;\n function Pattern$MONTH_getInstance() {\n Pattern_initFields();\n return Pattern$MONTH_instance;\n }\n var Pattern$DAY_OF_WEEK_instance;\n function Pattern$DAY_OF_WEEK_getInstance() {\n Pattern_initFields();\n return Pattern$DAY_OF_WEEK_instance;\n }\n var Pattern$YEAR_SHORT_instance;\n function Pattern$YEAR_SHORT_getInstance() {\n Pattern_initFields();\n return Pattern$YEAR_SHORT_instance;\n }\n var Pattern$YEAR_FULL_instance;\n function Pattern$YEAR_FULL_getInstance() {\n Pattern_initFields();\n return Pattern$YEAR_FULL_instance;\n }\n var Pattern$HOUR_24_instance;\n function Pattern$HOUR_24_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_24_instance;\n }\n var Pattern$HOUR_12_LEADING_ZERO_instance;\n function Pattern$HOUR_12_LEADING_ZERO_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_12_LEADING_ZERO_instance;\n }\n var Pattern$HOUR_12_instance;\n function Pattern$HOUR_12_getInstance() {\n Pattern_initFields();\n return Pattern$HOUR_12_instance;\n }\n var Pattern$MINUTE_instance;\n function Pattern$MINUTE_getInstance() {\n Pattern_initFields();\n return Pattern$MINUTE_instance;\n }\n var Pattern$MERIDIAN_LOWER_instance;\n function Pattern$MERIDIAN_LOWER_getInstance() {\n Pattern_initFields();\n return Pattern$MERIDIAN_LOWER_instance;\n }\n var Pattern$MERIDIAN_UPPER_instance;\n function Pattern$MERIDIAN_UPPER_getInstance() {\n Pattern_initFields();\n return Pattern$MERIDIAN_UPPER_instance;\n }\n var Pattern$SECOND_instance;\n function Pattern$SECOND_getInstance() {\n Pattern_initFields();\n return Pattern$SECOND_instance;\n }\n function Pattern$Companion() {\n Pattern$Companion_instance = this;\n this.PATTERN_REGEX = Regex_init('(%[aAbBdejmwyYHIlMpPS])');\n }\n function Pattern$Companion$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Pattern$Companion$Kind_initFields() {\n Pattern$Companion$Kind_initFields = function () {\n };\n Pattern$Companion$Kind$DATE_instance = new Pattern$Companion$Kind('DATE', 0);\n Pattern$Companion$Kind$TIME_instance = new Pattern$Companion$Kind('TIME', 1);\n }\n var Pattern$Companion$Kind$DATE_instance;\n function Pattern$Companion$Kind$DATE_getInstance() {\n Pattern$Companion$Kind_initFields();\n return Pattern$Companion$Kind$DATE_instance;\n }\n var Pattern$Companion$Kind$TIME_instance;\n function Pattern$Companion$Kind$TIME_getInstance() {\n Pattern$Companion$Kind_initFields();\n return Pattern$Companion$Kind$TIME_instance;\n }\n Pattern$Companion$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function Pattern$Companion$Kind$values() {\n return [Pattern$Companion$Kind$DATE_getInstance(), Pattern$Companion$Kind$TIME_getInstance()];\n }\n Pattern$Companion$Kind.values = Pattern$Companion$Kind$values;\n function Pattern$Companion$Kind$valueOf(name) {\n switch (name) {\n case 'DATE':\n return Pattern$Companion$Kind$DATE_getInstance();\n case 'TIME':\n return Pattern$Companion$Kind$TIME_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.dateFormat.Pattern.Companion.Kind.' + name);\n }\n }\n Pattern$Companion$Kind.valueOf_61zpoe$ = Pattern$Companion$Kind$valueOf;\n Pattern$Companion.prototype.patternByString_61zpoe$ = function (patternString) {\n var $receiver = Pattern$values();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$;\n for (tmp$ = 0; tmp$ !== $receiver.length; ++tmp$) {\n var element = $receiver[tmp$];\n if (equals(element.string, patternString)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n return firstOrNull$result;\n };\n Pattern$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Pattern$Companion_instance = null;\n function Pattern$Companion_getInstance() {\n Pattern_initFields();\n if (Pattern$Companion_instance === null) {\n new Pattern$Companion();\n }return Pattern$Companion_instance;\n }\n Pattern.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Pattern',\n interfaces: [Enum]\n };\n function Pattern$values() {\n return [Pattern$DAY_OF_WEEK_ABBR_getInstance(), Pattern$DAY_OF_WEEK_FULL_getInstance(), Pattern$MONTH_ABBR_getInstance(), Pattern$MONTH_FULL_getInstance(), Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance(), Pattern$DAY_OF_MONTH_getInstance(), Pattern$DAY_OF_THE_YEAR_getInstance(), Pattern$MONTH_getInstance(), Pattern$DAY_OF_WEEK_getInstance(), Pattern$YEAR_SHORT_getInstance(), Pattern$YEAR_FULL_getInstance(), Pattern$HOUR_24_getInstance(), Pattern$HOUR_12_LEADING_ZERO_getInstance(), Pattern$HOUR_12_getInstance(), Pattern$MINUTE_getInstance(), Pattern$MERIDIAN_LOWER_getInstance(), Pattern$MERIDIAN_UPPER_getInstance(), Pattern$SECOND_getInstance()];\n }\n Pattern.values = Pattern$values;\n function Pattern$valueOf(name) {\n switch (name) {\n case 'DAY_OF_WEEK_ABBR':\n return Pattern$DAY_OF_WEEK_ABBR_getInstance();\n case 'DAY_OF_WEEK_FULL':\n return Pattern$DAY_OF_WEEK_FULL_getInstance();\n case 'MONTH_ABBR':\n return Pattern$MONTH_ABBR_getInstance();\n case 'MONTH_FULL':\n return Pattern$MONTH_FULL_getInstance();\n case 'DAY_OF_MONTH_LEADING_ZERO':\n return Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance();\n case 'DAY_OF_MONTH':\n return Pattern$DAY_OF_MONTH_getInstance();\n case 'DAY_OF_THE_YEAR':\n return Pattern$DAY_OF_THE_YEAR_getInstance();\n case 'MONTH':\n return Pattern$MONTH_getInstance();\n case 'DAY_OF_WEEK':\n return Pattern$DAY_OF_WEEK_getInstance();\n case 'YEAR_SHORT':\n return Pattern$YEAR_SHORT_getInstance();\n case 'YEAR_FULL':\n return Pattern$YEAR_FULL_getInstance();\n case 'HOUR_24':\n return Pattern$HOUR_24_getInstance();\n case 'HOUR_12_LEADING_ZERO':\n return Pattern$HOUR_12_LEADING_ZERO_getInstance();\n case 'HOUR_12':\n return Pattern$HOUR_12_getInstance();\n case 'MINUTE':\n return Pattern$MINUTE_getInstance();\n case 'MERIDIAN_LOWER':\n return Pattern$MERIDIAN_LOWER_getInstance();\n case 'MERIDIAN_UPPER':\n return Pattern$MERIDIAN_UPPER_getInstance();\n case 'SECOND':\n return Pattern$SECOND_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.dateFormat.Pattern.' + name);\n }\n }\n Pattern.valueOf_61zpoe$ = Pattern$valueOf;\n function Date_0(day, month, year) {\n Date$Companion_getInstance();\n this.day = day;\n this.month = month;\n this.year = year;\n this.validate_0();\n }\n Object.defineProperty(Date_0.prototype, 'weekDay', {\n configurable: true,\n get: function () {\n var daysFromOrigin = this.daysFrom_z9gqti$(Date$Companion_getInstance().EPOCH);\n return WeekDay$values()[(daysFromOrigin + Date$Companion_getInstance().EPOCH_WEEKDAY_0.ordinal | 0) % WeekDay$values().length];\n }\n });\n Object.defineProperty(Date_0.prototype, 'dateStart', {\n configurable: true,\n get: function () {\n return new DateTime(this);\n }\n });\n Object.defineProperty(Date_0.prototype, 'dateEnd', {\n configurable: true,\n get: function () {\n return new DateTime(this, Time$Companion_getInstance().DAY_END);\n }\n });\n Date_0.prototype.validate_0 = function () {\n var tmp$;\n var daysInMonth = this.month.getDaysInYear_za3lpa$(this.year);\n tmp$ = this.day;\n var isValid = 1 <= tmp$ && tmp$ <= daysInMonth;\n if (!isValid) {\n throw IllegalArgumentException_init_0();\n }};\n Date_0.prototype.daysFrom_z9gqti$ = function (date) {\n if (this.compareTo_11rb$(date) < 0) {\n throw IllegalArgumentException_init_0();\n }var result = 0;\n if (this.year !== date.year) {\n var fromYear = date.year;\n var toYear = this.year;\n var leapYears = DateTimeUtil_getInstance().leapYearsBetween_6xvm5r$(fromYear, toYear);\n var years = toYear - fromYear | 0;\n result = result + (Kotlin.imul(leapYears, DateTimeUtil_getInstance().DAYS_IN_LEAP_YEAR_8be2vx$) + Kotlin.imul(years - leapYears | 0, DateTimeUtil_getInstance().DAYS_IN_YEAR_8be2vx$)) | 0;\n }return result + this.daysFromYearStart() - date.daysFromYearStart() | 0;\n };\n Date_0.prototype.daysFromYearStart = function () {\n var result = this.day;\n var current = this.month.prev();\n while (current != null) {\n result = result + current.getDaysInYear_za3lpa$(this.year) | 0;\n current = current.prev();\n }\n return result;\n };\n Date_0.prototype.addDays_za3lpa$ = function (days) {\n var days_0 = days;\n if (days_0 < 0) {\n throw IllegalArgumentException_init_0();\n }if (days_0 === 0)\n return this;\n var day = this.day;\n var month = this.month;\n var year = this.year;\n var lessThanYear = false;\n if (days_0 >= Date$Companion_getInstance().CACHE_DAYS_0 && year === Date$Companion_getInstance().EPOCH.year) {\n year = Date$Companion_getInstance().CACHE_STAMP_0.year;\n month = Date$Companion_getInstance().CACHE_STAMP_0.month;\n day = Date$Companion_getInstance().CACHE_STAMP_0.day;\n days_0 = days_0 - Date$Companion_getInstance().CACHE_DAYS_0 | 0;\n }while (days_0 > 0) {\n var daysToNextMonth = month.getDaysInYear_za3lpa$(year) - day + 1 | 0;\n if (days_0 < daysToNextMonth) {\n return new Date_0(day + days_0 | 0, month, year);\n } else {\n if (lessThanYear) {\n month = ensureNotNull(month.next());\n day = 1;\n days_0 = days_0 - daysToNextMonth | 0;\n } else {\n var daysToNextYear = Date$Companion_getInstance().lastDayOf_8fsw02$(year).daysFrom_z9gqti$(new Date_0(day, month, year)) + 1 | 0;\n if (days_0 >= daysToNextYear) {\n day = 1;\n month = Month$Companion_getInstance().JANUARY;\n year = year + 1 | 0;\n days_0 = days_0 - daysToNextYear | 0;\n } else {\n month = ensureNotNull(month.next());\n day = 1;\n days_0 = days_0 - daysToNextMonth | 0;\n lessThanYear = true;\n }\n }\n }\n }\n return new Date_0(day, month, year);\n };\n Date_0.prototype.nextDate = function () {\n return this.addDays_za3lpa$(1);\n };\n Date_0.prototype.prevDate = function () {\n return this.subtractDays_za3lpa$(1);\n };\n Date_0.prototype.subtractDays_za3lpa$ = function (days) {\n var tmp$;\n if (days < 0) {\n throw IllegalArgumentException_init_0();\n }if (days === 0)\n return this;\n if (days < this.day) {\n return new Date_0(this.day - days | 0, this.month, this.year);\n } else {\n var daysToPrevYear = this.daysFrom_z9gqti$(Date$Companion_getInstance().firstDayOf_8fsw02$(this.year));\n if (days > daysToPrevYear) {\n tmp$ = Date$Companion_getInstance().lastDayOf_8fsw02$(this.year - 1 | 0).subtractDays_za3lpa$(days - daysToPrevYear - 1 | 0);\n } else {\n tmp$ = Date$Companion_getInstance().lastDayOf_8fsw02$(this.year, ensureNotNull(this.month.prev())).subtractDays_za3lpa$(days - this.day | 0);\n }\n return tmp$;\n }\n };\n Date_0.prototype.compareTo_11rb$ = function (other) {\n if (this.year !== other.year)\n return this.year - other.year | 0;\n return this.month.ordinal() !== other.month.ordinal() ? this.month.ordinal() - other.month.ordinal() | 0 : this.day - other.day | 0;\n };\n Date_0.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, Date_0))\n return false;\n var date = (tmp$ = other) == null || Kotlin.isType(tmp$, Date_0) ? tmp$ : throwCCE();\n return ensureNotNull(date).year === this.year && date.month === this.month && date.day === this.day;\n };\n Date_0.prototype.hashCode = function () {\n return (this.year * 239 | 0) + (hashCode(this.month) * 31 | 0) + this.day | 0;\n };\n Date_0.prototype.toString = function () {\n var result = StringBuilder_init();\n result.append_s8jyv4$(this.year);\n this.appendMonth_0(result);\n this.appendDay_0(result);\n return result.toString();\n };\n Date_0.prototype.appendDay_0 = function (result) {\n if (this.day < 10) {\n result.append_pdl1vj$('0');\n }result.append_s8jyv4$(this.day);\n };\n Date_0.prototype.appendMonth_0 = function (result) {\n var month = this.month.ordinal() + 1 | 0;\n if (month < 10) {\n result.append_pdl1vj$('0');\n }result.append_s8jyv4$(month);\n };\n Date_0.prototype.toPrettyString = function () {\n var result = StringBuilder_init();\n this.appendDay_0(result);\n result.append_pdl1vj$('.');\n this.appendMonth_0(result);\n result.append_pdl1vj$('.');\n result.append_s8jyv4$(this.year);\n return result.toString();\n };\n function Date$Companion() {\n Date$Companion_instance = this;\n this.EPOCH = new Date_0(1, Month$Companion_getInstance().JANUARY, 1970);\n this.EPOCH_WEEKDAY_0 = WeekDay$THURSDAY_getInstance();\n this.CACHE_STAMP_0 = new Date_0(1, Month$Companion_getInstance().JANUARY, 2012);\n this.CACHE_DAYS_0 = this.CACHE_STAMP_0.daysFrom_z9gqti$(this.EPOCH);\n }\n Date$Companion.prototype.parse_61zpoe$ = function (str) {\n if (str.length !== 8) {\n throw RuntimeException_init();\n }var year = toInt(str.substring(0, 4));\n var month = toInt(str.substring(4, 6));\n var day = toInt(str.substring(6, 8));\n return new Date_0(day, Month$Companion_getInstance().values()[month - 1 | 0], year);\n };\n Date$Companion.prototype.firstDayOf_8fsw02$ = function (year, month) {\n if (month === void 0)\n month = Month$Companion_getInstance().JANUARY;\n return new Date_0(1, month, year);\n };\n Date$Companion.prototype.lastDayOf_8fsw02$ = function (year, month) {\n if (month === void 0)\n month = Month$Companion_getInstance().DECEMBER;\n return new Date_0(month.days, month, year);\n };\n Date$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Date$Companion_instance = null;\n function Date$Companion_getInstance() {\n if (Date$Companion_instance === null) {\n new Date$Companion();\n }return Date$Companion_instance;\n }\n Date_0.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Date',\n interfaces: [Comparable]\n };\n function DateTime(date, time) {\n DateTime$Companion_getInstance();\n if (time === void 0)\n time = Time$Companion_getInstance().DAY_START;\n this.date = date;\n this.time = time;\n }\n Object.defineProperty(DateTime.prototype, 'year', {\n configurable: true,\n get: function () {\n return this.date.year;\n }\n });\n Object.defineProperty(DateTime.prototype, 'month', {\n configurable: true,\n get: function () {\n return this.date.month;\n }\n });\n Object.defineProperty(DateTime.prototype, 'day', {\n configurable: true,\n get: function () {\n return this.date.day;\n }\n });\n Object.defineProperty(DateTime.prototype, 'weekDay', {\n configurable: true,\n get: function () {\n return this.date.weekDay;\n }\n });\n Object.defineProperty(DateTime.prototype, 'hours', {\n configurable: true,\n get: function () {\n return this.time.hours;\n }\n });\n Object.defineProperty(DateTime.prototype, 'minutes', {\n configurable: true,\n get: function () {\n return this.time.minutes;\n }\n });\n Object.defineProperty(DateTime.prototype, 'seconds', {\n configurable: true,\n get: function () {\n return this.time.seconds;\n }\n });\n Object.defineProperty(DateTime.prototype, 'milliseconds', {\n configurable: true,\n get: function () {\n return this.time.milliseconds;\n }\n });\n DateTime.prototype.changeDate_z9gqti$ = function (date) {\n return new DateTime(date, this.time);\n };\n DateTime.prototype.changeTime_z96d9j$ = function (time) {\n return new DateTime(this.date, time);\n };\n DateTime.prototype.add_27523k$ = function (duration) {\n var utcInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(this);\n return TimeZone$Companion_getInstance().UTC.toDateTime_x2y23v$(utcInstant.add_27523k$(duration));\n };\n DateTime.prototype.to_amwj4p$ = function (otherTime) {\n var currentInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(this);\n var otherInstant = TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(otherTime);\n return currentInstant.to_x2y23v$(otherInstant);\n };\n DateTime.prototype.isBefore_amwj4p$ = function (dateTime) {\n return this.compareTo_11rb$(dateTime) < 0;\n };\n DateTime.prototype.isAfter_amwj4p$ = function (dateTime) {\n return this.compareTo_11rb$(dateTime) > 0;\n };\n DateTime.prototype.hashCode = function () {\n return (this.date.hashCode() * 31 | 0) + this.time.hashCode() | 0;\n };\n DateTime.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, DateTime))\n return false;\n var otherDateTime = (tmp$ = other) == null || Kotlin.isType(tmp$, DateTime) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.date) != null ? tmp$_0.equals(ensureNotNull(otherDateTime).date) : null) && ((tmp$_1 = this.time) != null ? tmp$_1.equals(otherDateTime.time) : null);\n };\n DateTime.prototype.compareTo_11rb$ = function (other) {\n var dateComparison = this.date.compareTo_11rb$(other.date);\n return dateComparison !== 0 ? dateComparison : this.time.compareTo_11rb$(other.time);\n };\n DateTime.prototype.toString = function () {\n return this.date.toString() + 'T' + toString(this.time);\n };\n DateTime.prototype.toPrettyString = function () {\n return this.time.toPrettyHMString() + ' ' + this.date.toPrettyString();\n };\n function DateTime$Companion() {\n DateTime$Companion_instance = this;\n }\n DateTime$Companion.prototype.parse_61zpoe$ = function (s) {\n if (s.length < 15) {\n throw IllegalArgumentException_init_0();\n }return new DateTime(Date$Companion_getInstance().parse_61zpoe$(s.substring(0, 8)), Time$Companion_getInstance().parse_61zpoe$(s.substring(9)));\n };\n DateTime$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DateTime$Companion_instance = null;\n function DateTime$Companion_getInstance() {\n if (DateTime$Companion_instance === null) {\n new DateTime$Companion();\n }return DateTime$Companion_instance;\n }\n DateTime.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTime',\n interfaces: [Comparable]\n };\n function DateTimeUtil() {\n DateTimeUtil_instance = this;\n this.BASE_YEAR = 1900;\n this.MAX_SUPPORTED_YEAR = 2100;\n this.MIN_SUPPORTED_YEAR_8be2vx$ = 1970;\n this.DAYS_IN_YEAR_8be2vx$ = 0;\n this.DAYS_IN_LEAP_YEAR_8be2vx$ = 0;\n this.LEAP_YEARS_FROM_1969_8be2vx$ = new Int32Array([477, 477, 477, 478, 478, 478, 478, 479, 479, 479, 479, 480, 480, 480, 480, 481, 481, 481, 481, 482, 482, 482, 482, 483, 483, 483, 483, 484, 484, 484, 484, 485, 485, 485, 485, 486, 486, 486, 486, 487, 487, 487, 487, 488, 488, 488, 488, 489, 489, 489, 489, 490, 490, 490, 490, 491, 491, 491, 491, 492, 492, 492, 492, 493, 493, 493, 493, 494, 494, 494, 494, 495, 495, 495, 495, 496, 496, 496, 496, 497, 497, 497, 497, 498, 498, 498, 498, 499, 499, 499, 499, 500, 500, 500, 500, 501, 501, 501, 501, 502, 502, 502, 502, 503, 503, 503, 503, 504, 504, 504, 504, 505, 505, 505, 505, 506, 506, 506, 506, 507, 507, 507, 507, 508, 508, 508, 508, 509, 509, 509, 509, 509]);\n var tmp$, tmp$_0;\n var leapYearDays = 0;\n var yearDays = 0;\n tmp$ = Month$Companion_getInstance().values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var m = tmp$[tmp$_0];\n leapYearDays = leapYearDays + m.getDaysInLeapYear() | 0;\n yearDays = yearDays + m.days | 0;\n }\n this.DAYS_IN_YEAR_8be2vx$ = yearDays;\n this.DAYS_IN_LEAP_YEAR_8be2vx$ = leapYearDays;\n }\n DateTimeUtil.prototype.isLeap_kcn2v3$ = function (year) {\n this.checkYear_0(year);\n return (this.LEAP_YEARS_FROM_1969_8be2vx$[year - 1970 + 1 | 0] - this.LEAP_YEARS_FROM_1969_8be2vx$[year - 1970 | 0] | 0) === 1;\n };\n DateTimeUtil.prototype.leapYearsBetween_6xvm5r$ = function (fromYear, toYear) {\n if (fromYear > toYear) {\n throw IllegalArgumentException_init_0();\n }this.checkYear_0(fromYear);\n this.checkYear_0(toYear);\n return this.LEAP_YEARS_FROM_1969_8be2vx$[toYear - 1970 | 0] - this.LEAP_YEARS_FROM_1969_8be2vx$[fromYear - 1970 | 0] | 0;\n };\n DateTimeUtil.prototype.leapYearsFromZero_0 = function (year) {\n return (year / 4 | 0) - (year / 100 | 0) + (year / 400 | 0) | 0;\n };\n DateTimeUtil.prototype.checkYear_0 = function (year) {\n if (year > 2100 || year < 1970) {\n throw IllegalArgumentException_init(year.toString() + '');\n }};\n DateTimeUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateTimeUtil',\n interfaces: []\n };\n var DateTimeUtil_instance = null;\n function DateTimeUtil_getInstance() {\n if (DateTimeUtil_instance === null) {\n new DateTimeUtil();\n }return DateTimeUtil_instance;\n }\n function Duration(duration) {\n Duration$Companion_getInstance();\n this.duration = duration;\n }\n Object.defineProperty(Duration.prototype, 'isPositive', {\n configurable: true,\n get: function () {\n return this.duration.toNumber() > 0;\n }\n });\n Duration.prototype.mul_s8cxhz$ = function (times) {\n return new Duration(this.duration.multiply(times));\n };\n Duration.prototype.add_27523k$ = function (duration) {\n return new Duration(this.duration.add(duration.duration));\n };\n Duration.prototype.sub_27523k$ = function (duration) {\n return new Duration(this.duration.subtract(duration.duration));\n };\n Duration.prototype.div_27523k$ = function (duration) {\n return this.duration.toNumber() / duration.duration.toNumber();\n };\n Duration.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var delta = this.duration.subtract(other.duration);\n if (delta.toNumber() > 0) {\n tmp$ = 1;\n } else if (equals(delta, L0)) {\n tmp$ = 0;\n } else {\n tmp$ = -1;\n }\n return tmp$;\n };\n Duration.prototype.hashCode = function () {\n return this.duration.toInt();\n };\n Duration.prototype.equals = function (other) {\n return !Kotlin.isType(other, Duration) ? false : equals(this.duration, other.duration);\n };\n Duration.prototype.toString = function () {\n return 'Duration : ' + toString(this.duration) + 'ms';\n };\n function Duration$Companion() {\n Duration$Companion_instance = this;\n this.MS = new Duration(L1);\n this.SECOND = this.MS.mul_s8cxhz$(L1000);\n this.MINUTE = this.SECOND.mul_s8cxhz$(L60);\n this.HOUR = this.MINUTE.mul_s8cxhz$(L60);\n this.DAY = this.HOUR.mul_s8cxhz$(L24);\n this.WEEK = this.DAY.mul_s8cxhz$(L7);\n }\n Duration$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Duration$Companion_instance = null;\n function Duration$Companion_getInstance() {\n if (Duration$Companion_instance === null) {\n new Duration$Companion();\n }return Duration$Companion_instance;\n }\n Duration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Duration',\n interfaces: [Comparable]\n };\n function Instant(timeSinceEpoch) {\n this.timeSinceEpoch = timeSinceEpoch;\n }\n Instant.prototype.add_27523k$ = function (duration) {\n return new Instant(this.timeSinceEpoch.add(duration.duration));\n };\n Instant.prototype.sub_27523k$ = function (duration) {\n return new Instant(this.timeSinceEpoch.subtract(duration.duration));\n };\n Instant.prototype.to_x2y23v$ = function (instant) {\n return new Duration(instant.timeSinceEpoch.subtract(this.timeSinceEpoch));\n };\n Instant.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var delta = this.timeSinceEpoch.subtract(other.timeSinceEpoch);\n if (delta.toNumber() > 0) {\n tmp$ = 1;\n } else if (equals(delta, L0)) {\n tmp$ = 0;\n } else {\n tmp$ = -1;\n }\n return tmp$;\n };\n Instant.prototype.hashCode = function () {\n return this.timeSinceEpoch.toInt();\n };\n Instant.prototype.toString = function () {\n return '' + toString(this.timeSinceEpoch);\n };\n Instant.prototype.equals = function (other) {\n return !Kotlin.isType(other, Instant) ? false : equals(this.timeSinceEpoch, other.timeSinceEpoch);\n };\n Instant.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Instant',\n interfaces: [Comparable]\n };\n function Month(days, myOrdinal, myName) {\n Month$Companion_getInstance();\n this.days = days;\n this.myOrdinal_hzcl1t$_0 = myOrdinal;\n this.myName_s01cg9$_0 = myName;\n }\n Month.prototype.ordinal = function () {\n return this.myOrdinal_hzcl1t$_0;\n };\n Month.prototype.getDaysInYear_za3lpa$ = function (year) {\n return this.days;\n };\n Month.prototype.getDaysInLeapYear = function () {\n return this.days;\n };\n Month.prototype.prev = function () {\n return this.myOrdinal_hzcl1t$_0 === 0 ? null : Month$Companion_getInstance().values()[this.myOrdinal_hzcl1t$_0 - 1 | 0];\n };\n Month.prototype.next = function () {\n var values = Month$Companion_getInstance().values();\n return this.myOrdinal_hzcl1t$_0 === (values.length - 1 | 0) ? null : values[this.myOrdinal_hzcl1t$_0 + 1 | 0];\n };\n Month.prototype.toString = function () {\n return this.myName_s01cg9$_0;\n };\n function Month$VarLengthMonth(days, myDaysInLeapYear, ordinal, name) {\n Month.call(this, days, ordinal, name);\n this.myDaysInLeapYear_0 = myDaysInLeapYear;\n }\n Month$VarLengthMonth.prototype.getDaysInLeapYear = function () {\n return this.myDaysInLeapYear_0;\n };\n Month$VarLengthMonth.prototype.getDaysInYear_za3lpa$ = function (year) {\n var tmp$;\n if (DateTimeUtil_getInstance().isLeap_kcn2v3$(year)) {\n tmp$ = this.getDaysInLeapYear();\n } else {\n tmp$ = this.days;\n }\n return tmp$;\n };\n Month$VarLengthMonth.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VarLengthMonth',\n interfaces: [Month]\n };\n function Month$Companion() {\n Month$Companion_instance = this;\n this.JANUARY = new Month(31, 0, 'January');\n this.FEBRUARY = new Month$VarLengthMonth(28, 29, 1, 'February');\n this.MARCH = new Month(31, 2, 'March');\n this.APRIL = new Month(30, 3, 'April');\n this.MAY = new Month(31, 4, 'May');\n this.JUNE = new Month(30, 5, 'June');\n this.JULY = new Month(31, 6, 'July');\n this.AUGUST = new Month(31, 7, 'August');\n this.SEPTEMBER = new Month(30, 8, 'September');\n this.OCTOBER = new Month(31, 9, 'October');\n this.NOVEMBER = new Month(30, 10, 'November');\n this.DECEMBER = new Month(31, 11, 'December');\n this.VALUES_0 = [this.JANUARY, this.FEBRUARY, this.MARCH, this.APRIL, this.MAY, this.JUNE, this.JULY, this.AUGUST, this.SEPTEMBER, this.OCTOBER, this.NOVEMBER, this.DECEMBER];\n }\n Month$Companion.prototype.values = function () {\n return this.VALUES_0;\n };\n Month$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Month$Companion_instance = null;\n function Month$Companion_getInstance() {\n if (Month$Companion_instance === null) {\n new Month$Companion();\n }return Month$Companion_instance;\n }\n Month.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Month',\n interfaces: []\n };\n function Time(hours, minutes, seconds, milliseconds) {\n Time$Companion_getInstance();\n if (seconds === void 0)\n seconds = 0;\n if (milliseconds === void 0)\n milliseconds = 0;\n this.hours = hours;\n this.minutes = minutes;\n this.seconds = seconds;\n this.milliseconds = milliseconds;\n if (this.hours < 0 || this.hours > 24) {\n throw IllegalArgumentException_init_0();\n }if (this.hours === 24 && (this.minutes !== 0 || this.seconds !== 0)) {\n throw IllegalArgumentException_init_0();\n }if (this.minutes < 0 || this.minutes >= 60) {\n throw IllegalArgumentException_init_0();\n }if (this.seconds < 0 || this.seconds >= 60) {\n throw IllegalArgumentException_init_0();\n }}\n Time.prototype.compareTo_11rb$ = function (other) {\n var delta = this.hours - other.hours | 0;\n if (delta !== 0)\n return delta;\n delta = this.minutes - other.minutes | 0;\n if (delta !== 0)\n return delta;\n delta = this.seconds - other.seconds | 0;\n return delta !== 0 ? delta : this.milliseconds - other.milliseconds | 0;\n };\n Time.prototype.hashCode = function () {\n return (this.hours * 239 | 0) + (this.minutes * 491 | 0) + (this.seconds * 41 | 0) + this.milliseconds | 0;\n };\n Time.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (!Kotlin.isType(other, Time))\n tmp$_0 = false;\n else {\n tmp$_0 = this.compareTo_11rb$(ensureNotNull((tmp$ = other) == null || Kotlin.isType(tmp$, Time) ? tmp$ : throwCCE())) === 0;\n }\n return tmp$_0;\n };\n Time.prototype.toString = function () {\n var result = StringBuilder_init();\n if (this.hours < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.hours);\n if (this.minutes < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.minutes);\n if (this.seconds < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.seconds);\n return result.toString();\n };\n Time.prototype.toPrettyHMString = function () {\n var result = StringBuilder_init();\n if (this.hours < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.hours).append_s8itvh$(Time$Companion_getInstance().DELIMITER_0);\n if (this.minutes < 10)\n result.append_pdl1vj$('0');\n result.append_s8jyv4$(this.minutes);\n return result.toString();\n };\n function Time$Companion() {\n Time$Companion_instance = this;\n this.DELIMITER_0 = 58;\n this.DAY_START = new Time(0, 0);\n this.DAY_END = new Time(24, 0);\n }\n Time$Companion.prototype.parse_61zpoe$ = function (s) {\n if (s.length < 6) {\n throw IllegalArgumentException_init_0();\n }var hours = toInt(s.substring(0, 2));\n var minutes = toInt(s.substring(2, 4));\n var seconds = toInt(s.substring(4, 6));\n return new Time(hours, minutes, seconds);\n };\n Time$Companion.prototype.fromPrettyHMString_61zpoe$ = function (time) {\n var $receiver = this.DELIMITER_0;\n if (!contains(time, String.fromCharCode($receiver) + '')) {\n throw IllegalArgumentException_init_0();\n }var length = time.length;\n if (length !== 5 && length !== 4) {\n throw IllegalArgumentException_init_0();\n }var hourLength = length === 4 ? 1 : 2;\n try {\n var tmp$ = toInt(time.substring(0, hourLength));\n var startIndex = hourLength + 1 | 0;\n return new Time(tmp$, toInt(time.substring(startIndex, length)), 0);\n } catch (ignored) {\n if (Kotlin.isType(ignored, NumberFormatException)) {\n throw IllegalArgumentException_init_0();\n } else\n throw ignored;\n }\n };\n Time$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Time$Companion_instance = null;\n function Time$Companion_getInstance() {\n if (Time$Companion_instance === null) {\n new Time$Companion();\n }return Time$Companion_instance;\n }\n Time.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Time',\n interfaces: [Comparable]\n };\n function WeekDay(name, ordinal, abbreviation, isWeekend) {\n Enum.call(this);\n this.abbreviation = abbreviation;\n this.isWeekend = isWeekend;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function WeekDay_initFields() {\n WeekDay_initFields = function () {\n };\n WeekDay$MONDAY_instance = new WeekDay('MONDAY', 0, 'MO', false);\n WeekDay$TUESDAY_instance = new WeekDay('TUESDAY', 1, 'TU', false);\n WeekDay$WEDNESDAY_instance = new WeekDay('WEDNESDAY', 2, 'WE', false);\n WeekDay$THURSDAY_instance = new WeekDay('THURSDAY', 3, 'TH', false);\n WeekDay$FRIDAY_instance = new WeekDay('FRIDAY', 4, 'FR', false);\n WeekDay$SATURDAY_instance = new WeekDay('SATURDAY', 5, 'SA', true);\n WeekDay$SUNDAY_instance = new WeekDay('SUNDAY', 6, 'SU', true);\n }\n var WeekDay$MONDAY_instance;\n function WeekDay$MONDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$MONDAY_instance;\n }\n var WeekDay$TUESDAY_instance;\n function WeekDay$TUESDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$TUESDAY_instance;\n }\n var WeekDay$WEDNESDAY_instance;\n function WeekDay$WEDNESDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$WEDNESDAY_instance;\n }\n var WeekDay$THURSDAY_instance;\n function WeekDay$THURSDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$THURSDAY_instance;\n }\n var WeekDay$FRIDAY_instance;\n function WeekDay$FRIDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$FRIDAY_instance;\n }\n var WeekDay$SATURDAY_instance;\n function WeekDay$SATURDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$SATURDAY_instance;\n }\n var WeekDay$SUNDAY_instance;\n function WeekDay$SUNDAY_getInstance() {\n WeekDay_initFields();\n return WeekDay$SUNDAY_instance;\n }\n WeekDay.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'WeekDay',\n interfaces: [Enum]\n };\n function WeekDay$values() {\n return [WeekDay$MONDAY_getInstance(), WeekDay$TUESDAY_getInstance(), WeekDay$WEDNESDAY_getInstance(), WeekDay$THURSDAY_getInstance(), WeekDay$FRIDAY_getInstance(), WeekDay$SATURDAY_getInstance(), WeekDay$SUNDAY_getInstance()];\n }\n WeekDay.values = WeekDay$values;\n function WeekDay$valueOf(name) {\n switch (name) {\n case 'MONDAY':\n return WeekDay$MONDAY_getInstance();\n case 'TUESDAY':\n return WeekDay$TUESDAY_getInstance();\n case 'WEDNESDAY':\n return WeekDay$WEDNESDAY_getInstance();\n case 'THURSDAY':\n return WeekDay$THURSDAY_getInstance();\n case 'FRIDAY':\n return WeekDay$FRIDAY_getInstance();\n case 'SATURDAY':\n return WeekDay$SATURDAY_getInstance();\n case 'SUNDAY':\n return WeekDay$SUNDAY_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.datetime.WeekDay.' + name);\n }\n }\n WeekDay.valueOf_61zpoe$ = WeekDay$valueOf;\n function DateSpec() {\n }\n DateSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'DateSpec',\n interfaces: []\n };\n function DateSpecs() {\n DateSpecs_instance = this;\n }\n function DateSpecs$last$ObjectLiteral(closure$weekDay, closure$month) {\n this.closure$weekDay = closure$weekDay;\n this.closure$month = closure$month;\n }\n Object.defineProperty(DateSpecs$last$ObjectLiteral.prototype, 'rRule', {\n configurable: true,\n get: function () {\n return 'RRULE:FREQ=YEARLY;BYDAY=-1' + this.closure$weekDay.abbreviation + ';BYMONTH=' + toString(this.closure$month.ordinal() + 1 | 0);\n }\n });\n DateSpecs$last$ObjectLiteral.prototype.getDate_za3lpa$ = function (year) {\n var days = this.closure$month.getDaysInYear_za3lpa$(year);\n for (var d = days; d >= 1; d--) {\n var date = new Date_0(d, this.closure$month, year);\n if (date.weekDay === this.closure$weekDay)\n return date;\n }\n throw RuntimeException_init();\n };\n DateSpecs$last$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DateSpec]\n };\n DateSpecs.prototype.last_kvq57g$ = function (weekDay, month) {\n return new DateSpecs$last$ObjectLiteral(weekDay, month);\n };\n function DateSpecs$first$ObjectLiteral(closure$number, closure$weekDay, closure$month) {\n this.closure$number = closure$number;\n this.closure$weekDay = closure$weekDay;\n this.closure$month = closure$month;\n }\n Object.defineProperty(DateSpecs$first$ObjectLiteral.prototype, 'rRule', {\n configurable: true,\n get: function () {\n return 'RRULE:FREQ=YEARLY;BYDAY=' + toString(this.closure$number) + this.closure$weekDay.abbreviation + ';BYMONTH=' + toString(this.closure$month.ordinal() + 1 | 0);\n }\n });\n DateSpecs$first$ObjectLiteral.prototype.getDate_za3lpa$ = function (year) {\n var startDay = Kotlin.imul(this.closure$number - 1 | 0, WeekDay$values().length) + 1 | 0;\n var days = this.closure$month.getDaysInYear_za3lpa$(year);\n for (var d = startDay; d <= days; d++) {\n var date = new Date_0(d, this.closure$month, year);\n if (date.weekDay === this.closure$weekDay)\n return date;\n }\n throw RuntimeException_init();\n };\n DateSpecs$first$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DateSpec]\n };\n DateSpecs.prototype.first_t96ihi$ = function (weekDay, month, number) {\n if (number === void 0)\n number = 1;\n return new DateSpecs$first$ObjectLiteral(number, weekDay, month);\n };\n DateSpecs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateSpecs',\n interfaces: []\n };\n var DateSpecs_instance = null;\n function DateSpecs_getInstance() {\n if (DateSpecs_instance === null) {\n new DateSpecs();\n }return DateSpecs_instance;\n }\n function TimeZone(id) {\n TimeZone$Companion_getInstance();\n this.id = id;\n }\n TimeZone.prototype.convertTo_8hfrhi$ = function (toConvert, to) {\n return to === this ? toConvert : to.toDateTime_x2y23v$(this.toInstant_amwj4p$(toConvert));\n };\n TimeZone.prototype.convertTimeAtDay_aopdye$ = function (srcTime, dstDate, dstTimeZone) {\n var src = new DateTime(dstDate, srcTime);\n var dst = this.convertTo_8hfrhi$(src, dstTimeZone);\n var dayDiff = dstDate.compareTo_11rb$(dst.date);\n if (dayDiff !== 0) {\n var correctedDay = dayDiff > 0 ? dstDate.nextDate() : dstDate.prevDate();\n src = new DateTime(correctedDay, srcTime);\n dst = this.convertTo_8hfrhi$(src, dstTimeZone);\n }return dst.time;\n };\n TimeZone.prototype.getTimeZoneShift_x2y23v$ = function (instant) {\n var utcDateTime = this.toDateTime_x2y23v$(instant);\n return instant.to_x2y23v$(TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(utcDateTime));\n };\n TimeZone.prototype.toString = function () {\n return ensureNotNull(this.id);\n };\n function TimeZone$Companion() {\n TimeZone$Companion_instance = this;\n this.UTC = TimeZones_getInstance().utc();\n this.BERLIN = TimeZones_getInstance().withEuSummerTime_rwkwum$('Europe/Berlin', Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L1));\n this.MOSCOW = new TimeZoneMoscow();\n this.NY = TimeZones_getInstance().withUsSummerTime_rwkwum$('America/New_York', Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L_5));\n }\n TimeZone$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeZone$Companion_instance = null;\n function TimeZone$Companion_getInstance() {\n if (TimeZone$Companion_instance === null) {\n new TimeZone$Companion();\n }return TimeZone$Companion_instance;\n }\n TimeZone.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeZone',\n interfaces: []\n };\n function TimeZoneMoscow() {\n TimeZoneMoscow$Companion_getInstance();\n TimeZone.call(this, TimeZoneMoscow$Companion_getInstance().ID_0);\n this.myOldOffset_0 = Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L4);\n this.myNewOffset_0 = Duration$Companion_getInstance().HOUR.mul_s8cxhz$(L3);\n this.myOldTz_0 = TimeZones_getInstance().offset_nf4kng$(null, this.myOldOffset_0, TimeZone$Companion_getInstance().UTC);\n this.myNewTz_0 = TimeZones_getInstance().offset_nf4kng$(null, this.myNewOffset_0, TimeZone$Companion_getInstance().UTC);\n this.myOffsetChangeTime_0 = new DateTime(new Date_0(26, Month$Companion_getInstance().OCTOBER, 2014), new Time(2, 0));\n this.myOffsetChangeInstant_0 = this.myOldTz_0.toInstant_amwj4p$(this.myOffsetChangeTime_0);\n }\n TimeZoneMoscow.prototype.toDateTime_x2y23v$ = function (instant) {\n return instant.compareTo_11rb$(this.myOffsetChangeInstant_0) >= 0 ? this.myNewTz_0.toDateTime_x2y23v$(instant) : this.myOldTz_0.toDateTime_x2y23v$(instant);\n };\n TimeZoneMoscow.prototype.toInstant_amwj4p$ = function (dateTime) {\n return dateTime.compareTo_11rb$(this.myOffsetChangeTime_0) >= 0 ? this.myNewTz_0.toInstant_amwj4p$(dateTime) : this.myOldTz_0.toInstant_amwj4p$(dateTime);\n };\n function TimeZoneMoscow$Companion() {\n TimeZoneMoscow$Companion_instance = this;\n this.ID_0 = 'Europe/Moscow';\n }\n TimeZoneMoscow$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeZoneMoscow$Companion_instance = null;\n function TimeZoneMoscow$Companion_getInstance() {\n if (TimeZoneMoscow$Companion_instance === null) {\n new TimeZoneMoscow$Companion();\n }return TimeZoneMoscow$Companion_instance;\n }\n TimeZoneMoscow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeZoneMoscow',\n interfaces: [TimeZone]\n };\n function TimeZones() {\n TimeZones_instance = this;\n this.MILLIS_IN_SECOND_0 = L1000;\n this.MILLIS_IN_MINUTE_0 = L60000;\n this.MILLIS_IN_HOUR_0 = L3600000;\n this.MILLIS_IN_DAY_0 = L86400000;\n }\n TimeZones.prototype.toDateTime_0 = function (instant, offset) {\n var instant_0 = instant;\n instant_0 = instant_0.add_27523k$(offset);\n var days = instant_0.timeSinceEpoch.div(this.MILLIS_IN_DAY_0).toInt();\n var date = Date$Companion_getInstance().EPOCH.addDays_za3lpa$(days);\n var rest = instant_0.timeSinceEpoch.modulo(this.MILLIS_IN_DAY_0);\n var hour = rest.div(this.MILLIS_IN_HOUR_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_HOUR_0);\n var minutes = rest.div(this.MILLIS_IN_MINUTE_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_MINUTE_0);\n var seconds = rest.div(this.MILLIS_IN_SECOND_0).toInt();\n rest = rest.modulo(this.MILLIS_IN_SECOND_0);\n var milliseconds = rest.modulo(this.MILLIS_IN_SECOND_0).toInt();\n return new DateTime(date, new Time(hour, minutes, seconds, milliseconds));\n };\n TimeZones.prototype.toInstant_0 = function (dateTime, offset) {\n return (new Instant(this.toMillis_0(dateTime.date).add(this.toMillis_1(dateTime.time)))).sub_27523k$(offset);\n };\n TimeZones.prototype.toMillis_1 = function (time) {\n var minutes = Kotlin.Long.fromInt(time.hours).multiply(L60).add(Kotlin.Long.fromInt(time.minutes));\n var seconds = minutes.multiply(Kotlin.Long.fromInt(60)).add(Kotlin.Long.fromInt(time.seconds));\n return seconds.multiply(Kotlin.Long.fromInt(1000)).add(Kotlin.Long.fromInt(time.milliseconds));\n };\n TimeZones.prototype.toMillis_0 = function (date) {\n return Kotlin.Long.fromInt(date.daysFrom_z9gqti$(Date$Companion_getInstance().EPOCH)).multiply(this.MILLIS_IN_DAY_0);\n };\n function TimeZones$utc$ObjectLiteral(id) {\n TimeZone.call(this, id);\n }\n TimeZones$utc$ObjectLiteral.prototype.toDateTime_x2y23v$ = function (instant) {\n return TimeZones_getInstance().toDateTime_0(instant, new Duration(L0));\n };\n TimeZones$utc$ObjectLiteral.prototype.toInstant_amwj4p$ = function (dateTime) {\n return TimeZones_getInstance().toInstant_0(dateTime, new Duration(L0));\n };\n TimeZones$utc$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZone]\n };\n TimeZones.prototype.utc = function () {\n return new TimeZones$utc$ObjectLiteral('UTC');\n };\n function TimeZones$offset$ObjectLiteral(closure$base, closure$offset, id) {\n this.closure$base = closure$base;\n this.closure$offset = closure$offset;\n TimeZone.call(this, id);\n }\n TimeZones$offset$ObjectLiteral.prototype.toDateTime_x2y23v$ = function (instant) {\n return this.closure$base.toDateTime_x2y23v$(instant.add_27523k$(this.closure$offset));\n };\n TimeZones$offset$ObjectLiteral.prototype.toInstant_amwj4p$ = function (dateTime) {\n return this.closure$base.toInstant_amwj4p$(dateTime).sub_27523k$(this.closure$offset);\n };\n TimeZones$offset$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZone]\n };\n TimeZones.prototype.offset_nf4kng$ = function (id, offset, base) {\n return new TimeZones$offset$ObjectLiteral(base, offset, id);\n };\n function TimeZones$withEuSummerTime$ObjectLiteral(closure$startSpec, closure$utcChangeTime, closure$endSpec, id, offset) {\n this.closure$startSpec = closure$startSpec;\n this.closure$utcChangeTime = closure$utcChangeTime;\n this.closure$endSpec = closure$endSpec;\n TimeZones$DSTimeZone.call(this, id, offset);\n }\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.getStartInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$startSpec.getDate_za3lpa$(year), this.closure$utcChangeTime));\n };\n TimeZones$withEuSummerTime$ObjectLiteral.prototype.getEndInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$endSpec.getDate_za3lpa$(year), this.closure$utcChangeTime));\n };\n TimeZones$withEuSummerTime$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZones$DSTimeZone]\n };\n TimeZones.prototype.withEuSummerTime_rwkwum$ = function (id, offset) {\n var startSpec = DateSpecs_getInstance().last_kvq57g$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().MARCH);\n var endSpec = DateSpecs_getInstance().last_kvq57g$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().OCTOBER);\n var utcChangeTime = new Time(1, 0);\n return new TimeZones$withEuSummerTime$ObjectLiteral(startSpec, utcChangeTime, endSpec, id, offset);\n };\n function TimeZones$withUsSummerTime$ObjectLiteral(closure$startSpec, closure$offset, closure$endSpec, id, offset) {\n this.closure$startSpec = closure$startSpec;\n this.closure$offset = closure$offset;\n this.closure$endSpec = closure$endSpec;\n TimeZones$DSTimeZone.call(this, id, offset);\n }\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.getStartInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$startSpec.getDate_za3lpa$(year), new Time(2, 0))).sub_27523k$(this.closure$offset);\n };\n TimeZones$withUsSummerTime$ObjectLiteral.prototype.getEndInstant_za3lpa$ = function (year) {\n return TimeZone$Companion_getInstance().UTC.toInstant_amwj4p$(new DateTime(this.closure$endSpec.getDate_za3lpa$(year), new Time(2, 0))).sub_27523k$(this.closure$offset.add_27523k$(Duration$Companion_getInstance().HOUR));\n };\n TimeZones$withUsSummerTime$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [TimeZones$DSTimeZone]\n };\n TimeZones.prototype.withUsSummerTime_rwkwum$ = function (id, offset) {\n var startSpec = DateSpecs_getInstance().first_t96ihi$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().MARCH, 2);\n var endSpec = DateSpecs_getInstance().first_t96ihi$(WeekDay$SUNDAY_getInstance(), Month$Companion_getInstance().NOVEMBER);\n return new TimeZones$withUsSummerTime$ObjectLiteral(startSpec, offset, endSpec, id, offset);\n };\n function TimeZones$DSTimeZone(id, offset) {\n TimeZone.call(this, id);\n this.myTz_0 = TimeZones_getInstance().offset_nf4kng$(null, offset, TimeZone$Companion_getInstance().UTC);\n this.mySummerTz_0 = TimeZones_getInstance().offset_nf4kng$(null, offset.add_27523k$(Duration$Companion_getInstance().HOUR), TimeZone$Companion_getInstance().UTC);\n }\n TimeZones$DSTimeZone.prototype.toDateTime_x2y23v$ = function (instant) {\n var tmp$;\n var tzDt = this.myTz_0.toDateTime_x2y23v$(instant);\n var start = this.getStartInstant_za3lpa$(tzDt.year);\n var end = this.getEndInstant_za3lpa$(tzDt.year);\n if (instant.compareTo_11rb$(start) > 0 && instant.compareTo_11rb$(end) < 0) {\n tmp$ = this.mySummerTz_0.toDateTime_x2y23v$(instant);\n } else {\n tmp$ = tzDt;\n }\n return tmp$;\n };\n TimeZones$DSTimeZone.prototype.toInstant_amwj4p$ = function (dateTime) {\n var tmp$;\n var startDt = this.toDateTime_x2y23v$(this.getStartInstant_za3lpa$(dateTime.year));\n var endDt = this.toDateTime_x2y23v$(this.getEndInstant_za3lpa$(dateTime.year));\n if (dateTime.compareTo_11rb$(startDt) > 0 && dateTime.compareTo_11rb$(endDt) < 0) {\n tmp$ = this.mySummerTz_0.toInstant_amwj4p$(dateTime);\n } else {\n tmp$ = this.myTz_0.toInstant_amwj4p$(dateTime);\n }\n return tmp$;\n };\n TimeZones$DSTimeZone.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DSTimeZone',\n interfaces: [TimeZone]\n };\n TimeZones.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TimeZones',\n interfaces: []\n };\n var TimeZones_instance = null;\n function TimeZones_getInstance() {\n if (TimeZones_instance === null) {\n new TimeZones();\n }return TimeZones_instance;\n }\n function EnumInfo() {\n }\n EnumInfo.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EnumInfo',\n interfaces: []\n };\n function EnumInfoFactory() {\n EnumInfoFactory_instance = this;\n }\n EnumInfoFactory.prototype.createEnumInfo_nxd2ia$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.enums.EnumInfoFactory.createEnumInfo_nxd2ia$', wrapFunction(function () {\n var EnumInfoImpl_init = _.jetbrains.datalore.base.enums.EnumInfoImpl;\n return function (EnumT_0, isEnumT) {\n return new EnumInfoImpl_init(EnumT_0.values());\n };\n }));\n EnumInfoFactory.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'EnumInfoFactory',\n interfaces: []\n };\n var EnumInfoFactory_instance = null;\n function EnumInfoFactory_getInstance() {\n if (EnumInfoFactory_instance === null) {\n new EnumInfoFactory();\n }return EnumInfoFactory_instance;\n }\n function EnumInfoImpl(enumConstants) {\n this.myNormalizedValueMap_0 = null;\n this.myOriginalNames_0 = null;\n var tmp$;\n var numConstants = enumConstants.length;\n var valueMap = HashMap_init(numConstants);\n var originalNames = ArrayList_init_0(numConstants);\n for (tmp$ = 0; tmp$ !== enumConstants.length; ++tmp$) {\n var value = enumConstants[tmp$];\n var originalName = value.toString();\n originalNames.add_11rb$(originalName);\n var normalizedName = this.toNormalizedName_0(originalName);\n var oldValue = valueMap.put_xwzc9p$(normalizedName, value);\n if (oldValue != null) {\n throw IllegalArgumentException_init(\"duplicate values: '\" + value + \"', '\" + toString(oldValue) + \"'\");\n }}\n this.myOriginalNames_0 = originalNames;\n this.myNormalizedValueMap_0 = valueMap;\n }\n Object.defineProperty(EnumInfoImpl.prototype, 'originalNames', {\n configurable: true,\n get: function () {\n return this.myOriginalNames_0;\n }\n });\n EnumInfoImpl.prototype.toNormalizedName_0 = function (name) {\n return name.toUpperCase();\n };\n EnumInfoImpl.prototype.safeValueOf_7po0m$ = function (name, defaultValue) {\n var value = this.safeValueOf_pdl1vj$(name);\n return value != null ? value : defaultValue;\n };\n EnumInfoImpl.prototype.safeValueOf_pdl1vj$ = function (name) {\n var result;\n if (this.hasValue_pdl1vj$(name)) {\n result = this.myNormalizedValueMap_0.get_11rb$(this.toNormalizedName_0(ensureNotNull(name)));\n } else {\n result = null;\n }\n return result;\n };\n EnumInfoImpl.prototype.hasValue_pdl1vj$ = function (name) {\n return name != null && this.myNormalizedValueMap_0.containsKey_11rb$(this.toNormalizedName_0(name));\n };\n EnumInfoImpl.prototype.unsafeValueOf_61zpoe$ = function (name) {\n var tmp$;\n tmp$ = this.safeValueOf_pdl1vj$(name);\n if (tmp$ == null) {\n throw IllegalArgumentException_init(\"name not found: '\" + name + \"'\");\n }return tmp$;\n };\n EnumInfoImpl.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EnumInfoImpl',\n interfaces: [EnumInfo]\n };\n function Enums() {\n Enums_instance = this;\n }\n Enums.prototype.valueOf_a9gw98$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.enums.Enums.valueOf_a9gw98$', wrapFunction(function () {\n var equals = Kotlin.equals;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n return function (EnumT_0, isEnumT, name) {\n var tmp$, tmp$_0;\n tmp$ = EnumT_0.values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var e = tmp$[tmp$_0];\n if (equals(name, e.toString())) {\n return e;\n }}\n throw IllegalArgumentException_init(name);\n };\n }));\n Enums.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Enums',\n interfaces: []\n };\n var Enums_instance = null;\n function Enums_getInstance() {\n if (Enums_instance === null) {\n new Enums();\n }return Enums_instance;\n }\n function Button(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Button_initFields() {\n Button_initFields = function () {\n };\n Button$NONE_instance = new Button('NONE', 0);\n Button$LEFT_instance = new Button('LEFT', 1);\n Button$MIDDLE_instance = new Button('MIDDLE', 2);\n Button$RIGHT_instance = new Button('RIGHT', 3);\n }\n var Button$NONE_instance;\n function Button$NONE_getInstance() {\n Button_initFields();\n return Button$NONE_instance;\n }\n var Button$LEFT_instance;\n function Button$LEFT_getInstance() {\n Button_initFields();\n return Button$LEFT_instance;\n }\n var Button$MIDDLE_instance;\n function Button$MIDDLE_getInstance() {\n Button_initFields();\n return Button$MIDDLE_instance;\n }\n var Button$RIGHT_instance;\n function Button$RIGHT_getInstance() {\n Button_initFields();\n return Button$RIGHT_instance;\n }\n Button.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Button',\n interfaces: [Enum]\n };\n function Button$values() {\n return [Button$NONE_getInstance(), Button$LEFT_getInstance(), Button$MIDDLE_getInstance(), Button$RIGHT_getInstance()];\n }\n Button.values = Button$values;\n function Button$valueOf(name) {\n switch (name) {\n case 'NONE':\n return Button$NONE_getInstance();\n case 'LEFT':\n return Button$LEFT_getInstance();\n case 'MIDDLE':\n return Button$MIDDLE_getInstance();\n case 'RIGHT':\n return Button$RIGHT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.Button.' + name);\n }\n }\n Button.valueOf_61zpoe$ = Button$valueOf;\n function Event() {\n this.eventContext_qzl3re$_d6nbbo$_0 = null;\n this.isConsumed_gb68t5$_0 = false;\n }\n Object.defineProperty(Event.prototype, 'eventContext_qzl3re$_0', {\n configurable: true,\n get: function () {\n return this.eventContext_qzl3re$_d6nbbo$_0;\n },\n set: function (eventContext) {\n if (this.eventContext_qzl3re$_0 != null) {\n throw IllegalStateException_init('Already set ' + toString(ensureNotNull(this.eventContext_qzl3re$_0)));\n }if (this.isConsumed) {\n throw IllegalStateException_init(\"Can't set a context to the consumed event\");\n }if (eventContext == null) {\n throw IllegalArgumentException_init(\"Can't set null context\");\n }this.eventContext_qzl3re$_d6nbbo$_0 = eventContext;\n }\n });\n Object.defineProperty(Event.prototype, 'isConsumed', {\n configurable: true,\n get: function () {\n return this.isConsumed_gb68t5$_0;\n },\n set: function (isConsumed) {\n this.isConsumed_gb68t5$_0 = isConsumed;\n }\n });\n Event.prototype.consume = function () {\n this.doConsume_smptag$_0();\n };\n Event.prototype.doConsume_smptag$_0 = function () {\n if (this.isConsumed) {\n throw IllegalStateException_init_0();\n }this.isConsumed = true;\n };\n Event.prototype.ensureConsumed = function () {\n if (!this.isConsumed) {\n this.consume();\n }};\n Event.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Event',\n interfaces: []\n };\n function EventContext() {\n }\n EventContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventContext',\n interfaces: []\n };\n function Key(name, ordinal, myValue) {\n Enum.call(this);\n this.myValue_n4kdnj$_0 = myValue;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Key_initFields() {\n Key_initFields = function () {\n };\n Key$A_instance = new Key('A', 0, 'A');\n Key$B_instance = new Key('B', 1, 'B');\n Key$C_instance = new Key('C', 2, 'C');\n Key$D_instance = new Key('D', 3, 'D');\n Key$E_instance = new Key('E', 4, 'E');\n Key$F_instance = new Key('F', 5, 'F');\n Key$G_instance = new Key('G', 6, 'G');\n Key$H_instance = new Key('H', 7, 'H');\n Key$I_instance = new Key('I', 8, 'I');\n Key$J_instance = new Key('J', 9, 'J');\n Key$K_instance = new Key('K', 10, 'K');\n Key$L_instance = new Key('L', 11, 'L');\n Key$M_instance = new Key('M', 12, 'M');\n Key$N_instance = new Key('N', 13, 'N');\n Key$O_instance = new Key('O', 14, 'O');\n Key$P_instance = new Key('P', 15, 'P');\n Key$Q_instance = new Key('Q', 16, 'Q');\n Key$R_instance = new Key('R', 17, 'R');\n Key$S_instance = new Key('S', 18, 'S');\n Key$T_instance = new Key('T', 19, 'T');\n Key$U_instance = new Key('U', 20, 'U');\n Key$V_instance = new Key('V', 21, 'V');\n Key$W_instance = new Key('W', 22, 'W');\n Key$X_instance = new Key('X', 23, 'X');\n Key$Y_instance = new Key('Y', 24, 'Y');\n Key$Z_instance = new Key('Z', 25, 'Z');\n Key$DIGIT_0_instance = new Key('DIGIT_0', 26, '0');\n Key$DIGIT_1_instance = new Key('DIGIT_1', 27, '1');\n Key$DIGIT_2_instance = new Key('DIGIT_2', 28, '2');\n Key$DIGIT_3_instance = new Key('DIGIT_3', 29, '3');\n Key$DIGIT_4_instance = new Key('DIGIT_4', 30, '4');\n Key$DIGIT_5_instance = new Key('DIGIT_5', 31, '5');\n Key$DIGIT_6_instance = new Key('DIGIT_6', 32, '6');\n Key$DIGIT_7_instance = new Key('DIGIT_7', 33, '7');\n Key$DIGIT_8_instance = new Key('DIGIT_8', 34, '8');\n Key$DIGIT_9_instance = new Key('DIGIT_9', 35, '9');\n Key$LEFT_BRACE_instance = new Key('LEFT_BRACE', 36, '[');\n Key$RIGHT_BRACE_instance = new Key('RIGHT_BRACE', 37, ']');\n Key$UP_instance = new Key('UP', 38, 'Up');\n Key$DOWN_instance = new Key('DOWN', 39, 'Down');\n Key$LEFT_instance = new Key('LEFT', 40, 'Left');\n Key$RIGHT_instance = new Key('RIGHT', 41, 'Right');\n Key$PAGE_UP_instance = new Key('PAGE_UP', 42, 'Page Up');\n Key$PAGE_DOWN_instance = new Key('PAGE_DOWN', 43, 'Page Down');\n Key$ESCAPE_instance = new Key('ESCAPE', 44, 'Escape');\n Key$ENTER_instance = new Key('ENTER', 45, 'Enter');\n Key$HOME_instance = new Key('HOME', 46, 'Home');\n Key$END_instance = new Key('END', 47, 'End');\n Key$TAB_instance = new Key('TAB', 48, 'Tab');\n Key$SPACE_instance = new Key('SPACE', 49, 'Space');\n Key$INSERT_instance = new Key('INSERT', 50, 'Insert');\n Key$DELETE_instance = new Key('DELETE', 51, 'Delete');\n Key$BACKSPACE_instance = new Key('BACKSPACE', 52, 'Backspace');\n Key$EQUALS_instance = new Key('EQUALS', 53, 'Equals');\n Key$BACK_QUOTE_instance = new Key('BACK_QUOTE', 54, '`');\n Key$PLUS_instance = new Key('PLUS', 55, 'Plus');\n Key$MINUS_instance = new Key('MINUS', 56, 'Minus');\n Key$SLASH_instance = new Key('SLASH', 57, 'Slash');\n Key$CONTROL_instance = new Key('CONTROL', 58, 'Ctrl');\n Key$META_instance = new Key('META', 59, 'Meta');\n Key$ALT_instance = new Key('ALT', 60, 'Alt');\n Key$SHIFT_instance = new Key('SHIFT', 61, 'Shift');\n Key$UNKNOWN_instance = new Key('UNKNOWN', 62, '?');\n Key$F1_instance = new Key('F1', 63, 'F1');\n Key$F2_instance = new Key('F2', 64, 'F2');\n Key$F3_instance = new Key('F3', 65, 'F3');\n Key$F4_instance = new Key('F4', 66, 'F4');\n Key$F5_instance = new Key('F5', 67, 'F5');\n Key$F6_instance = new Key('F6', 68, 'F6');\n Key$F7_instance = new Key('F7', 69, 'F7');\n Key$F8_instance = new Key('F8', 70, 'F8');\n Key$F9_instance = new Key('F9', 71, 'F9');\n Key$F10_instance = new Key('F10', 72, 'F10');\n Key$F11_instance = new Key('F11', 73, 'F11');\n Key$F12_instance = new Key('F12', 74, 'F12');\n Key$COMMA_instance = new Key('COMMA', 75, ',');\n Key$PERIOD_instance = new Key('PERIOD', 76, '.');\n }\n var Key$A_instance;\n function Key$A_getInstance() {\n Key_initFields();\n return Key$A_instance;\n }\n var Key$B_instance;\n function Key$B_getInstance() {\n Key_initFields();\n return Key$B_instance;\n }\n var Key$C_instance;\n function Key$C_getInstance() {\n Key_initFields();\n return Key$C_instance;\n }\n var Key$D_instance;\n function Key$D_getInstance() {\n Key_initFields();\n return Key$D_instance;\n }\n var Key$E_instance;\n function Key$E_getInstance() {\n Key_initFields();\n return Key$E_instance;\n }\n var Key$F_instance;\n function Key$F_getInstance() {\n Key_initFields();\n return Key$F_instance;\n }\n var Key$G_instance;\n function Key$G_getInstance() {\n Key_initFields();\n return Key$G_instance;\n }\n var Key$H_instance;\n function Key$H_getInstance() {\n Key_initFields();\n return Key$H_instance;\n }\n var Key$I_instance;\n function Key$I_getInstance() {\n Key_initFields();\n return Key$I_instance;\n }\n var Key$J_instance;\n function Key$J_getInstance() {\n Key_initFields();\n return Key$J_instance;\n }\n var Key$K_instance;\n function Key$K_getInstance() {\n Key_initFields();\n return Key$K_instance;\n }\n var Key$L_instance;\n function Key$L_getInstance() {\n Key_initFields();\n return Key$L_instance;\n }\n var Key$M_instance;\n function Key$M_getInstance() {\n Key_initFields();\n return Key$M_instance;\n }\n var Key$N_instance;\n function Key$N_getInstance() {\n Key_initFields();\n return Key$N_instance;\n }\n var Key$O_instance;\n function Key$O_getInstance() {\n Key_initFields();\n return Key$O_instance;\n }\n var Key$P_instance;\n function Key$P_getInstance() {\n Key_initFields();\n return Key$P_instance;\n }\n var Key$Q_instance;\n function Key$Q_getInstance() {\n Key_initFields();\n return Key$Q_instance;\n }\n var Key$R_instance;\n function Key$R_getInstance() {\n Key_initFields();\n return Key$R_instance;\n }\n var Key$S_instance;\n function Key$S_getInstance() {\n Key_initFields();\n return Key$S_instance;\n }\n var Key$T_instance;\n function Key$T_getInstance() {\n Key_initFields();\n return Key$T_instance;\n }\n var Key$U_instance;\n function Key$U_getInstance() {\n Key_initFields();\n return Key$U_instance;\n }\n var Key$V_instance;\n function Key$V_getInstance() {\n Key_initFields();\n return Key$V_instance;\n }\n var Key$W_instance;\n function Key$W_getInstance() {\n Key_initFields();\n return Key$W_instance;\n }\n var Key$X_instance;\n function Key$X_getInstance() {\n Key_initFields();\n return Key$X_instance;\n }\n var Key$Y_instance;\n function Key$Y_getInstance() {\n Key_initFields();\n return Key$Y_instance;\n }\n var Key$Z_instance;\n function Key$Z_getInstance() {\n Key_initFields();\n return Key$Z_instance;\n }\n var Key$DIGIT_0_instance;\n function Key$DIGIT_0_getInstance() {\n Key_initFields();\n return Key$DIGIT_0_instance;\n }\n var Key$DIGIT_1_instance;\n function Key$DIGIT_1_getInstance() {\n Key_initFields();\n return Key$DIGIT_1_instance;\n }\n var Key$DIGIT_2_instance;\n function Key$DIGIT_2_getInstance() {\n Key_initFields();\n return Key$DIGIT_2_instance;\n }\n var Key$DIGIT_3_instance;\n function Key$DIGIT_3_getInstance() {\n Key_initFields();\n return Key$DIGIT_3_instance;\n }\n var Key$DIGIT_4_instance;\n function Key$DIGIT_4_getInstance() {\n Key_initFields();\n return Key$DIGIT_4_instance;\n }\n var Key$DIGIT_5_instance;\n function Key$DIGIT_5_getInstance() {\n Key_initFields();\n return Key$DIGIT_5_instance;\n }\n var Key$DIGIT_6_instance;\n function Key$DIGIT_6_getInstance() {\n Key_initFields();\n return Key$DIGIT_6_instance;\n }\n var Key$DIGIT_7_instance;\n function Key$DIGIT_7_getInstance() {\n Key_initFields();\n return Key$DIGIT_7_instance;\n }\n var Key$DIGIT_8_instance;\n function Key$DIGIT_8_getInstance() {\n Key_initFields();\n return Key$DIGIT_8_instance;\n }\n var Key$DIGIT_9_instance;\n function Key$DIGIT_9_getInstance() {\n Key_initFields();\n return Key$DIGIT_9_instance;\n }\n var Key$LEFT_BRACE_instance;\n function Key$LEFT_BRACE_getInstance() {\n Key_initFields();\n return Key$LEFT_BRACE_instance;\n }\n var Key$RIGHT_BRACE_instance;\n function Key$RIGHT_BRACE_getInstance() {\n Key_initFields();\n return Key$RIGHT_BRACE_instance;\n }\n var Key$UP_instance;\n function Key$UP_getInstance() {\n Key_initFields();\n return Key$UP_instance;\n }\n var Key$DOWN_instance;\n function Key$DOWN_getInstance() {\n Key_initFields();\n return Key$DOWN_instance;\n }\n var Key$LEFT_instance;\n function Key$LEFT_getInstance() {\n Key_initFields();\n return Key$LEFT_instance;\n }\n var Key$RIGHT_instance;\n function Key$RIGHT_getInstance() {\n Key_initFields();\n return Key$RIGHT_instance;\n }\n var Key$PAGE_UP_instance;\n function Key$PAGE_UP_getInstance() {\n Key_initFields();\n return Key$PAGE_UP_instance;\n }\n var Key$PAGE_DOWN_instance;\n function Key$PAGE_DOWN_getInstance() {\n Key_initFields();\n return Key$PAGE_DOWN_instance;\n }\n var Key$ESCAPE_instance;\n function Key$ESCAPE_getInstance() {\n Key_initFields();\n return Key$ESCAPE_instance;\n }\n var Key$ENTER_instance;\n function Key$ENTER_getInstance() {\n Key_initFields();\n return Key$ENTER_instance;\n }\n var Key$HOME_instance;\n function Key$HOME_getInstance() {\n Key_initFields();\n return Key$HOME_instance;\n }\n var Key$END_instance;\n function Key$END_getInstance() {\n Key_initFields();\n return Key$END_instance;\n }\n var Key$TAB_instance;\n function Key$TAB_getInstance() {\n Key_initFields();\n return Key$TAB_instance;\n }\n var Key$SPACE_instance;\n function Key$SPACE_getInstance() {\n Key_initFields();\n return Key$SPACE_instance;\n }\n var Key$INSERT_instance;\n function Key$INSERT_getInstance() {\n Key_initFields();\n return Key$INSERT_instance;\n }\n var Key$DELETE_instance;\n function Key$DELETE_getInstance() {\n Key_initFields();\n return Key$DELETE_instance;\n }\n var Key$BACKSPACE_instance;\n function Key$BACKSPACE_getInstance() {\n Key_initFields();\n return Key$BACKSPACE_instance;\n }\n var Key$EQUALS_instance;\n function Key$EQUALS_getInstance() {\n Key_initFields();\n return Key$EQUALS_instance;\n }\n var Key$BACK_QUOTE_instance;\n function Key$BACK_QUOTE_getInstance() {\n Key_initFields();\n return Key$BACK_QUOTE_instance;\n }\n var Key$PLUS_instance;\n function Key$PLUS_getInstance() {\n Key_initFields();\n return Key$PLUS_instance;\n }\n var Key$MINUS_instance;\n function Key$MINUS_getInstance() {\n Key_initFields();\n return Key$MINUS_instance;\n }\n var Key$SLASH_instance;\n function Key$SLASH_getInstance() {\n Key_initFields();\n return Key$SLASH_instance;\n }\n var Key$CONTROL_instance;\n function Key$CONTROL_getInstance() {\n Key_initFields();\n return Key$CONTROL_instance;\n }\n var Key$META_instance;\n function Key$META_getInstance() {\n Key_initFields();\n return Key$META_instance;\n }\n var Key$ALT_instance;\n function Key$ALT_getInstance() {\n Key_initFields();\n return Key$ALT_instance;\n }\n var Key$SHIFT_instance;\n function Key$SHIFT_getInstance() {\n Key_initFields();\n return Key$SHIFT_instance;\n }\n var Key$UNKNOWN_instance;\n function Key$UNKNOWN_getInstance() {\n Key_initFields();\n return Key$UNKNOWN_instance;\n }\n var Key$F1_instance;\n function Key$F1_getInstance() {\n Key_initFields();\n return Key$F1_instance;\n }\n var Key$F2_instance;\n function Key$F2_getInstance() {\n Key_initFields();\n return Key$F2_instance;\n }\n var Key$F3_instance;\n function Key$F3_getInstance() {\n Key_initFields();\n return Key$F3_instance;\n }\n var Key$F4_instance;\n function Key$F4_getInstance() {\n Key_initFields();\n return Key$F4_instance;\n }\n var Key$F5_instance;\n function Key$F5_getInstance() {\n Key_initFields();\n return Key$F5_instance;\n }\n var Key$F6_instance;\n function Key$F6_getInstance() {\n Key_initFields();\n return Key$F6_instance;\n }\n var Key$F7_instance;\n function Key$F7_getInstance() {\n Key_initFields();\n return Key$F7_instance;\n }\n var Key$F8_instance;\n function Key$F8_getInstance() {\n Key_initFields();\n return Key$F8_instance;\n }\n var Key$F9_instance;\n function Key$F9_getInstance() {\n Key_initFields();\n return Key$F9_instance;\n }\n var Key$F10_instance;\n function Key$F10_getInstance() {\n Key_initFields();\n return Key$F10_instance;\n }\n var Key$F11_instance;\n function Key$F11_getInstance() {\n Key_initFields();\n return Key$F11_instance;\n }\n var Key$F12_instance;\n function Key$F12_getInstance() {\n Key_initFields();\n return Key$F12_instance;\n }\n var Key$COMMA_instance;\n function Key$COMMA_getInstance() {\n Key_initFields();\n return Key$COMMA_instance;\n }\n var Key$PERIOD_instance;\n function Key$PERIOD_getInstance() {\n Key_initFields();\n return Key$PERIOD_instance;\n }\n Key.prototype.toString = function () {\n return this.myValue_n4kdnj$_0;\n };\n Key.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Key',\n interfaces: [Enum]\n };\n function Key$values() {\n return [Key$A_getInstance(), Key$B_getInstance(), Key$C_getInstance(), Key$D_getInstance(), Key$E_getInstance(), Key$F_getInstance(), Key$G_getInstance(), Key$H_getInstance(), Key$I_getInstance(), Key$J_getInstance(), Key$K_getInstance(), Key$L_getInstance(), Key$M_getInstance(), Key$N_getInstance(), Key$O_getInstance(), Key$P_getInstance(), Key$Q_getInstance(), Key$R_getInstance(), Key$S_getInstance(), Key$T_getInstance(), Key$U_getInstance(), Key$V_getInstance(), Key$W_getInstance(), Key$X_getInstance(), Key$Y_getInstance(), Key$Z_getInstance(), Key$DIGIT_0_getInstance(), Key$DIGIT_1_getInstance(), Key$DIGIT_2_getInstance(), Key$DIGIT_3_getInstance(), Key$DIGIT_4_getInstance(), Key$DIGIT_5_getInstance(), Key$DIGIT_6_getInstance(), Key$DIGIT_7_getInstance(), Key$DIGIT_8_getInstance(), Key$DIGIT_9_getInstance(), Key$LEFT_BRACE_getInstance(), Key$RIGHT_BRACE_getInstance(), Key$UP_getInstance(), Key$DOWN_getInstance(), Key$LEFT_getInstance(), Key$RIGHT_getInstance(), Key$PAGE_UP_getInstance(), Key$PAGE_DOWN_getInstance(), Key$ESCAPE_getInstance(), Key$ENTER_getInstance(), Key$HOME_getInstance(), Key$END_getInstance(), Key$TAB_getInstance(), Key$SPACE_getInstance(), Key$INSERT_getInstance(), Key$DELETE_getInstance(), Key$BACKSPACE_getInstance(), Key$EQUALS_getInstance(), Key$BACK_QUOTE_getInstance(), Key$PLUS_getInstance(), Key$MINUS_getInstance(), Key$SLASH_getInstance(), Key$CONTROL_getInstance(), Key$META_getInstance(), Key$ALT_getInstance(), Key$SHIFT_getInstance(), Key$UNKNOWN_getInstance(), Key$F1_getInstance(), Key$F2_getInstance(), Key$F3_getInstance(), Key$F4_getInstance(), Key$F5_getInstance(), Key$F6_getInstance(), Key$F7_getInstance(), Key$F8_getInstance(), Key$F9_getInstance(), Key$F10_getInstance(), Key$F11_getInstance(), Key$F12_getInstance(), Key$COMMA_getInstance(), Key$PERIOD_getInstance()];\n }\n Key.values = Key$values;\n function Key$valueOf(name) {\n switch (name) {\n case 'A':\n return Key$A_getInstance();\n case 'B':\n return Key$B_getInstance();\n case 'C':\n return Key$C_getInstance();\n case 'D':\n return Key$D_getInstance();\n case 'E':\n return Key$E_getInstance();\n case 'F':\n return Key$F_getInstance();\n case 'G':\n return Key$G_getInstance();\n case 'H':\n return Key$H_getInstance();\n case 'I':\n return Key$I_getInstance();\n case 'J':\n return Key$J_getInstance();\n case 'K':\n return Key$K_getInstance();\n case 'L':\n return Key$L_getInstance();\n case 'M':\n return Key$M_getInstance();\n case 'N':\n return Key$N_getInstance();\n case 'O':\n return Key$O_getInstance();\n case 'P':\n return Key$P_getInstance();\n case 'Q':\n return Key$Q_getInstance();\n case 'R':\n return Key$R_getInstance();\n case 'S':\n return Key$S_getInstance();\n case 'T':\n return Key$T_getInstance();\n case 'U':\n return Key$U_getInstance();\n case 'V':\n return Key$V_getInstance();\n case 'W':\n return Key$W_getInstance();\n case 'X':\n return Key$X_getInstance();\n case 'Y':\n return Key$Y_getInstance();\n case 'Z':\n return Key$Z_getInstance();\n case 'DIGIT_0':\n return Key$DIGIT_0_getInstance();\n case 'DIGIT_1':\n return Key$DIGIT_1_getInstance();\n case 'DIGIT_2':\n return Key$DIGIT_2_getInstance();\n case 'DIGIT_3':\n return Key$DIGIT_3_getInstance();\n case 'DIGIT_4':\n return Key$DIGIT_4_getInstance();\n case 'DIGIT_5':\n return Key$DIGIT_5_getInstance();\n case 'DIGIT_6':\n return Key$DIGIT_6_getInstance();\n case 'DIGIT_7':\n return Key$DIGIT_7_getInstance();\n case 'DIGIT_8':\n return Key$DIGIT_8_getInstance();\n case 'DIGIT_9':\n return Key$DIGIT_9_getInstance();\n case 'LEFT_BRACE':\n return Key$LEFT_BRACE_getInstance();\n case 'RIGHT_BRACE':\n return Key$RIGHT_BRACE_getInstance();\n case 'UP':\n return Key$UP_getInstance();\n case 'DOWN':\n return Key$DOWN_getInstance();\n case 'LEFT':\n return Key$LEFT_getInstance();\n case 'RIGHT':\n return Key$RIGHT_getInstance();\n case 'PAGE_UP':\n return Key$PAGE_UP_getInstance();\n case 'PAGE_DOWN':\n return Key$PAGE_DOWN_getInstance();\n case 'ESCAPE':\n return Key$ESCAPE_getInstance();\n case 'ENTER':\n return Key$ENTER_getInstance();\n case 'HOME':\n return Key$HOME_getInstance();\n case 'END':\n return Key$END_getInstance();\n case 'TAB':\n return Key$TAB_getInstance();\n case 'SPACE':\n return Key$SPACE_getInstance();\n case 'INSERT':\n return Key$INSERT_getInstance();\n case 'DELETE':\n return Key$DELETE_getInstance();\n case 'BACKSPACE':\n return Key$BACKSPACE_getInstance();\n case 'EQUALS':\n return Key$EQUALS_getInstance();\n case 'BACK_QUOTE':\n return Key$BACK_QUOTE_getInstance();\n case 'PLUS':\n return Key$PLUS_getInstance();\n case 'MINUS':\n return Key$MINUS_getInstance();\n case 'SLASH':\n return Key$SLASH_getInstance();\n case 'CONTROL':\n return Key$CONTROL_getInstance();\n case 'META':\n return Key$META_getInstance();\n case 'ALT':\n return Key$ALT_getInstance();\n case 'SHIFT':\n return Key$SHIFT_getInstance();\n case 'UNKNOWN':\n return Key$UNKNOWN_getInstance();\n case 'F1':\n return Key$F1_getInstance();\n case 'F2':\n return Key$F2_getInstance();\n case 'F3':\n return Key$F3_getInstance();\n case 'F4':\n return Key$F4_getInstance();\n case 'F5':\n return Key$F5_getInstance();\n case 'F6':\n return Key$F6_getInstance();\n case 'F7':\n return Key$F7_getInstance();\n case 'F8':\n return Key$F8_getInstance();\n case 'F9':\n return Key$F9_getInstance();\n case 'F10':\n return Key$F10_getInstance();\n case 'F11':\n return Key$F11_getInstance();\n case 'F12':\n return Key$F12_getInstance();\n case 'COMMA':\n return Key$COMMA_getInstance();\n case 'PERIOD':\n return Key$PERIOD_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.Key.' + name);\n }\n }\n Key.valueOf_61zpoe$ = Key$valueOf;\n function KeyEvent() {\n this.keyStroke = null;\n this.keyChar = null;\n }\n Object.defineProperty(KeyEvent.prototype, 'key', {\n configurable: true,\n get: function () {\n return this.keyStroke.key;\n }\n });\n Object.defineProperty(KeyEvent.prototype, 'modifiers', {\n configurable: true,\n get: function () {\n return this.keyStroke.modifiers;\n }\n });\n KeyEvent.prototype.is_ji7i3y$ = function (key, modifiers) {\n return this.keyStroke.is_ji7i3y$(key, modifiers.slice());\n };\n KeyEvent.prototype.is_c4rqdo$ = function (specs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var s = specs[tmp$];\n if (s.matches_l9pgtg$(this.keyStroke))\n return true;\n }\n return false;\n };\n KeyEvent.prototype.is_4t3vif$ = function (specs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var s = specs[tmp$];\n if (s.matches_l9pgtg$(this.keyStroke))\n return true;\n }\n return false;\n };\n KeyEvent.prototype.has_hny0b7$ = function (key) {\n return this.keyStroke.has_hny0b7$(key);\n };\n KeyEvent.prototype.copy = function () {\n return KeyEvent_init_1(this.key, unboxChar(this.keyChar), this.modifiers);\n };\n KeyEvent.prototype.toString = function () {\n return this.keyStroke.toString();\n };\n KeyEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyEvent',\n interfaces: [Event]\n };\n function KeyEvent_init(keyStroke, $this) {\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = keyStroke;\n $this.keyChar = toChar(0);\n return $this;\n }\n function KeyEvent_init_0(key, ch, $this) {\n if (ch === void 0)\n ch = toChar(0);\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = KeyStroke_init_0(key, emptyList());\n $this.keyChar = ch;\n return $this;\n }\n function KeyEvent_init_1(key, ch, modifiers, $this) {\n $this = $this || Object.create(KeyEvent.prototype);\n Event.call($this);\n KeyEvent.call($this);\n $this.keyStroke = KeyStroke_init_0(key, modifiers);\n $this.keyChar = ch;\n return $this;\n }\n function KeyModifiers(isCtrl, isAlt, isShift, isMeta) {\n KeyModifiers$Companion_getInstance();\n this.isCtrl = isCtrl;\n this.isAlt = isAlt;\n this.isShift = isShift;\n this.isMeta = isMeta;\n }\n function KeyModifiers$Companion() {\n KeyModifiers$Companion_instance = this;\n this.EMPTY_MODIFIERS_0 = KeyModifiers_init();\n }\n KeyModifiers$Companion.prototype.emptyModifiers = function () {\n return this.EMPTY_MODIFIERS_0;\n };\n KeyModifiers$Companion.prototype.withShift = function () {\n return new KeyModifiers(false, false, true, false);\n };\n KeyModifiers$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var KeyModifiers$Companion_instance = null;\n function KeyModifiers$Companion_getInstance() {\n if (KeyModifiers$Companion_instance === null) {\n new KeyModifiers$Companion();\n }return KeyModifiers$Companion_instance;\n }\n KeyModifiers.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyModifiers',\n interfaces: []\n };\n function KeyModifiers_init($this) {\n $this = $this || Object.create(KeyModifiers.prototype);\n KeyModifiers.call($this, false, false, false, false);\n return $this;\n }\n function KeyStroke() {\n this.key = null;\n this.modifiers = null;\n }\n KeyStroke.prototype.has_hny0b7$ = function (key) {\n return this.modifiers.contains_11rb$(key);\n };\n KeyStroke.prototype.is_ji7i3y$ = function (key, modifiers) {\n return this.matches_l9pgtg$(KeyStroke_init(key, modifiers.slice()));\n };\n KeyStroke.prototype.matches_l9pgtg$ = function (keyStroke) {\n return this.equals(keyStroke);\n };\n KeyStroke.prototype.with_hny0b7$ = function (key) {\n var keys = HashSet_init(this.modifiers);\n keys.add_11rb$(key);\n return KeyStroke_init_0(this.key, keys);\n };\n KeyStroke.prototype.hashCode = function () {\n return (this.key.hashCode() * 31 | 0) + hashCode(this.modifiers) | 0;\n };\n KeyStroke.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, KeyStroke))\n return false;\n var otherKeyStroke = (tmp$ = other) == null || Kotlin.isType(tmp$, KeyStroke) ? tmp$ : throwCCE();\n return this.key === ensureNotNull(otherKeyStroke).key && equals(this.modifiers, ensureNotNull(otherKeyStroke).modifiers);\n };\n KeyStroke.prototype.toString = function () {\n return this.key.toString() + ' ' + this.modifiers;\n };\n KeyStroke.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyStroke',\n interfaces: []\n };\n function KeyStroke_init(key, modifiers, $this) {\n $this = $this || Object.create(KeyStroke.prototype);\n KeyStroke_init_0(key, asList(modifiers), $this);\n return $this;\n }\n function KeyStroke_init_0(key, modifiers, $this) {\n $this = $this || Object.create(KeyStroke.prototype);\n KeyStroke.call($this);\n $this.key = key;\n $this.modifiers = HashSet_init(modifiers);\n return $this;\n }\n function KeyStrokeSpec() {\n this.myKeyStrokes_0 = null;\n }\n Object.defineProperty(KeyStrokeSpec.prototype, 'keyStrokes', {\n configurable: true,\n get: function () {\n return listOf(this.myKeyStrokes_0.slice());\n }\n });\n Object.defineProperty(KeyStrokeSpec.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myKeyStrokes_0.length === 0;\n }\n });\n KeyStrokeSpec.prototype.matches_l9pgtg$ = function (keyStroke) {\n var tmp$, tmp$_0;\n tmp$ = this.myKeyStrokes_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var spec = tmp$[tmp$_0];\n if (spec.matches_l9pgtg$(keyStroke)) {\n return true;\n }}\n return false;\n };\n KeyStrokeSpec.prototype.with_hny0b7$ = function (key) {\n var tmp$, tmp$_0;\n var modified = ArrayList_init();\n tmp$ = this.myKeyStrokes_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var keyStroke = tmp$[tmp$_0];\n modified.add_11rb$(keyStroke.with_hny0b7$(key));\n }\n return KeyStrokeSpec_init_0(modified);\n };\n KeyStrokeSpec.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, KeyStrokeSpec) ? tmp$_0 : throwCCE();\n return equals(this.keyStrokes, ensureNotNull(that).keyStrokes);\n };\n KeyStrokeSpec.prototype.hashCode = function () {\n return hashCode(this.keyStrokes);\n };\n KeyStrokeSpec.prototype.toString = function () {\n return this.keyStrokes.toString();\n };\n KeyStrokeSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'KeyStrokeSpec',\n interfaces: []\n };\n function KeyStrokeSpec_init(key, modifiers, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = [KeyStroke_init(key, modifiers.slice())];\n return $this;\n }\n function KeyStrokeSpec_init_0(keyStrokes, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = copyToArray(keyStrokes);\n return $this;\n }\n function KeyStrokeSpec_init_1(keyStrokes, $this) {\n $this = $this || Object.create(KeyStrokeSpec.prototype);\n KeyStrokeSpec.call($this);\n $this.myKeyStrokes_0 = keyStrokes.slice();\n return $this;\n }\n function KeyStrokeSpecs() {\n KeyStrokeSpecs_instance = this;\n this.COPY = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$C_getInstance(), []), KeyStrokeSpec_init(Key$INSERT_getInstance(), [ModifierKey$CONTROL_getInstance()])]);\n this.CUT = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$X_getInstance(), []), KeyStrokeSpec_init(Key$DELETE_getInstance(), [ModifierKey$SHIFT_getInstance()])]);\n this.PASTE = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$V_getInstance(), []), KeyStrokeSpec_init(Key$INSERT_getInstance(), [ModifierKey$SHIFT_getInstance()])]);\n this.UNDO = this.ctrlOrMeta_ji7i3y$(Key$Z_getInstance(), []);\n this.REDO = this.UNDO.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.COMPLETE = KeyStrokeSpec_init(Key$SPACE_getInstance(), [ModifierKey$CONTROL_getInstance()]);\n this.SHOW_DOC = this.composite_c4rqdo$([KeyStrokeSpec_init(Key$F1_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$J_getInstance(), [])]);\n this.HELP = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$I_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$F1_getInstance(), [])]);\n this.HOME = this.composite_4t3vif$([KeyStroke_init(Key$HOME_getInstance(), []), KeyStroke_init(Key$LEFT_getInstance(), [ModifierKey$META_getInstance()])]);\n this.END = this.composite_4t3vif$([KeyStroke_init(Key$END_getInstance(), []), KeyStroke_init(Key$RIGHT_getInstance(), [ModifierKey$META_getInstance()])]);\n this.FILE_HOME = this.ctrlOrMeta_ji7i3y$(Key$HOME_getInstance(), []);\n this.FILE_END = this.ctrlOrMeta_ji7i3y$(Key$END_getInstance(), []);\n this.PREV_WORD = this.ctrlOrAlt_ji7i3y$(Key$LEFT_getInstance(), []);\n this.NEXT_WORD = this.ctrlOrAlt_ji7i3y$(Key$RIGHT_getInstance(), []);\n this.NEXT_EDITABLE = this.ctrlOrMeta_ji7i3y$(Key$RIGHT_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.PREV_EDITABLE = this.ctrlOrMeta_ji7i3y$(Key$LEFT_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.SELECT_ALL = this.ctrlOrMeta_ji7i3y$(Key$A_getInstance(), []);\n this.SELECT_FILE_HOME = this.FILE_HOME.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_FILE_END = this.FILE_END.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_HOME = this.HOME.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_END = this.END.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_WORD_FORWARD = this.NEXT_WORD.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_WORD_BACKWARD = this.PREV_WORD.with_hny0b7$(ModifierKey$SHIFT_getInstance());\n this.SELECT_LEFT = KeyStrokeSpec_init(Key$LEFT_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_RIGHT = KeyStrokeSpec_init(Key$RIGHT_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_UP = KeyStrokeSpec_init(Key$UP_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.SELECT_DOWN = KeyStrokeSpec_init(Key$DOWN_getInstance(), [ModifierKey$SHIFT_getInstance()]);\n this.INCREASE_SELECTION = KeyStrokeSpec_init(Key$UP_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.DECREASE_SELECTION = KeyStrokeSpec_init(Key$DOWN_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.INSERT_BEFORE = this.composite_4t3vif$([KeyStroke_init_0(Key$ENTER_getInstance(), this.add_0(ModifierKey$META_getInstance(), [])), KeyStroke_init(Key$INSERT_getInstance(), []), KeyStroke_init_0(Key$ENTER_getInstance(), this.add_0(ModifierKey$CONTROL_getInstance(), []))]);\n this.INSERT_AFTER = KeyStrokeSpec_init(Key$ENTER_getInstance(), []);\n this.INSERT = this.composite_c4rqdo$([this.INSERT_BEFORE, this.INSERT_AFTER]);\n this.DUPLICATE = this.ctrlOrMeta_ji7i3y$(Key$D_getInstance(), []);\n this.DELETE_CURRENT = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$BACKSPACE_getInstance(), []), this.ctrlOrMeta_ji7i3y$(Key$DELETE_getInstance(), [])]);\n this.DELETE_TO_WORD_START = KeyStrokeSpec_init(Key$BACKSPACE_getInstance(), [ModifierKey$ALT_getInstance()]);\n this.MATCHING_CONSTRUCTS = this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Key$LEFT_BRACE_getInstance(), [ModifierKey$ALT_getInstance()]), this.ctrlOrMeta_ji7i3y$(Key$RIGHT_BRACE_getInstance(), [ModifierKey$ALT_getInstance()])]);\n this.NAVIGATE = this.ctrlOrMeta_ji7i3y$(Key$B_getInstance(), []);\n this.NAVIGATE_BACK = this.ctrlOrMeta_ji7i3y$(Key$LEFT_BRACE_getInstance(), []);\n this.NAVIGATE_FORWARD = this.ctrlOrMeta_ji7i3y$(Key$RIGHT_BRACE_getInstance(), []);\n }\n KeyStrokeSpecs.prototype.ctrlOrMeta_ji7i3y$ = function (key, modifiers) {\n return this.composite_4t3vif$([KeyStroke_init_0(key, this.add_0(ModifierKey$CONTROL_getInstance(), modifiers.slice())), KeyStroke_init_0(key, this.add_0(ModifierKey$META_getInstance(), modifiers.slice()))]);\n };\n KeyStrokeSpecs.prototype.ctrlOrAlt_ji7i3y$ = function (key, modifiers) {\n return this.composite_4t3vif$([KeyStroke_init_0(key, this.add_0(ModifierKey$CONTROL_getInstance(), modifiers.slice())), KeyStroke_init_0(key, this.add_0(ModifierKey$ALT_getInstance(), modifiers.slice()))]);\n };\n KeyStrokeSpecs.prototype.add_0 = function (key, otherKeys) {\n var result = HashSet_init(asList(otherKeys));\n result.add_11rb$(key);\n return result;\n };\n KeyStrokeSpecs.prototype.composite_c4rqdo$ = function (specs) {\n var tmp$, tmp$_0;\n var keyStrokes = HashSet_init_0();\n for (tmp$ = 0; tmp$ !== specs.length; ++tmp$) {\n var spec = specs[tmp$];\n tmp$_0 = spec.keyStrokes.iterator();\n while (tmp$_0.hasNext()) {\n var ks = tmp$_0.next();\n keyStrokes.add_11rb$(ks);\n }\n }\n return KeyStrokeSpec_init_0(keyStrokes);\n };\n KeyStrokeSpecs.prototype.composite_4t3vif$ = function (specs) {\n return KeyStrokeSpec_init_1(specs.slice());\n };\n KeyStrokeSpecs.prototype.withoutShift_b0jlop$ = function (spec) {\n var tmp$;\n var keyStroke = spec.keyStrokes.iterator().next();\n var modifiers = keyStroke.modifiers;\n var withoutShift = HashSet_init_0();\n tmp$ = modifiers.iterator();\n while (tmp$.hasNext()) {\n var modifier = tmp$.next();\n if (modifier !== ModifierKey$SHIFT_getInstance()) {\n withoutShift.add_11rb$(modifier);\n }}\n return KeyEvent_init_1(keyStroke.key, toChar(0), withoutShift);\n };\n KeyStrokeSpecs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'KeyStrokeSpecs',\n interfaces: []\n };\n var KeyStrokeSpecs_instance = null;\n function KeyStrokeSpecs_getInstance() {\n if (KeyStrokeSpecs_instance === null) {\n new KeyStrokeSpecs();\n }return KeyStrokeSpecs_instance;\n }\n function ModifierKey(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ModifierKey_initFields() {\n ModifierKey_initFields = function () {\n };\n ModifierKey$CONTROL_instance = new ModifierKey('CONTROL', 0);\n ModifierKey$ALT_instance = new ModifierKey('ALT', 1);\n ModifierKey$SHIFT_instance = new ModifierKey('SHIFT', 2);\n ModifierKey$META_instance = new ModifierKey('META', 3);\n }\n var ModifierKey$CONTROL_instance;\n function ModifierKey$CONTROL_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$CONTROL_instance;\n }\n var ModifierKey$ALT_instance;\n function ModifierKey$ALT_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$ALT_instance;\n }\n var ModifierKey$SHIFT_instance;\n function ModifierKey$SHIFT_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$SHIFT_instance;\n }\n var ModifierKey$META_instance;\n function ModifierKey$META_getInstance() {\n ModifierKey_initFields();\n return ModifierKey$META_instance;\n }\n ModifierKey.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ModifierKey',\n interfaces: [Enum]\n };\n function ModifierKey$values() {\n return [ModifierKey$CONTROL_getInstance(), ModifierKey$ALT_getInstance(), ModifierKey$SHIFT_getInstance(), ModifierKey$META_getInstance()];\n }\n ModifierKey.values = ModifierKey$values;\n function ModifierKey$valueOf(name) {\n switch (name) {\n case 'CONTROL':\n return ModifierKey$CONTROL_getInstance();\n case 'ALT':\n return ModifierKey$ALT_getInstance();\n case 'SHIFT':\n return ModifierKey$SHIFT_getInstance();\n case 'META':\n return ModifierKey$META_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.ModifierKey.' + name);\n }\n }\n ModifierKey.valueOf_61zpoe$ = ModifierKey$valueOf;\n function MouseEvent(x, y, button, modifiers) {\n MouseEvent$Companion_getInstance();\n PointEvent.call(this, x, y);\n this.button = button;\n this.modifiers = modifiers;\n if (this.button == null) {\n var message = 'Null button';\n throw IllegalArgumentException_init(message.toString());\n }}\n function MouseEvent$Companion() {\n MouseEvent$Companion_instance = this;\n }\n MouseEvent$Companion.prototype.noButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$NONE_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.leftButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$LEFT_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.middleButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$MIDDLE_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.prototype.rightButton_119tl4$ = function (v) {\n return MouseEvent_init(v, Button$RIGHT_getInstance(), KeyModifiers$Companion_getInstance().emptyModifiers());\n };\n MouseEvent$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MouseEvent$Companion_instance = null;\n function MouseEvent$Companion_getInstance() {\n if (MouseEvent$Companion_instance === null) {\n new MouseEvent$Companion();\n }return MouseEvent$Companion_instance;\n }\n MouseEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEvent',\n interfaces: [PointEvent]\n };\n function MouseEvent_init(v, button, modifiers, $this) {\n $this = $this || Object.create(MouseEvent.prototype);\n MouseEvent.call($this, v.x, v.y, button, modifiers);\n return $this;\n }\n function MouseEventSource() {\n }\n MouseEventSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MouseEventSource',\n interfaces: []\n };\n function MouseEventSpec(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MouseEventSpec_initFields() {\n MouseEventSpec_initFields = function () {\n };\n MouseEventSpec$MOUSE_ENTERED_instance = new MouseEventSpec('MOUSE_ENTERED', 0);\n MouseEventSpec$MOUSE_LEFT_instance = new MouseEventSpec('MOUSE_LEFT', 1);\n MouseEventSpec$MOUSE_MOVED_instance = new MouseEventSpec('MOUSE_MOVED', 2);\n MouseEventSpec$MOUSE_DRAGGED_instance = new MouseEventSpec('MOUSE_DRAGGED', 3);\n MouseEventSpec$MOUSE_CLICKED_instance = new MouseEventSpec('MOUSE_CLICKED', 4);\n MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance = new MouseEventSpec('MOUSE_DOUBLE_CLICKED', 5);\n MouseEventSpec$MOUSE_PRESSED_instance = new MouseEventSpec('MOUSE_PRESSED', 6);\n MouseEventSpec$MOUSE_RELEASED_instance = new MouseEventSpec('MOUSE_RELEASED', 7);\n }\n var MouseEventSpec$MOUSE_ENTERED_instance;\n function MouseEventSpec$MOUSE_ENTERED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_ENTERED_instance;\n }\n var MouseEventSpec$MOUSE_LEFT_instance;\n function MouseEventSpec$MOUSE_LEFT_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_LEFT_instance;\n }\n var MouseEventSpec$MOUSE_MOVED_instance;\n function MouseEventSpec$MOUSE_MOVED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_MOVED_instance;\n }\n var MouseEventSpec$MOUSE_DRAGGED_instance;\n function MouseEventSpec$MOUSE_DRAGGED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_DRAGGED_instance;\n }\n var MouseEventSpec$MOUSE_CLICKED_instance;\n function MouseEventSpec$MOUSE_CLICKED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_CLICKED_instance;\n }\n var MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance;\n function MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_DOUBLE_CLICKED_instance;\n }\n var MouseEventSpec$MOUSE_PRESSED_instance;\n function MouseEventSpec$MOUSE_PRESSED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_PRESSED_instance;\n }\n var MouseEventSpec$MOUSE_RELEASED_instance;\n function MouseEventSpec$MOUSE_RELEASED_getInstance() {\n MouseEventSpec_initFields();\n return MouseEventSpec$MOUSE_RELEASED_instance;\n }\n MouseEventSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEventSpec',\n interfaces: [Enum]\n };\n function MouseEventSpec$values() {\n return [MouseEventSpec$MOUSE_ENTERED_getInstance(), MouseEventSpec$MOUSE_LEFT_getInstance(), MouseEventSpec$MOUSE_MOVED_getInstance(), MouseEventSpec$MOUSE_DRAGGED_getInstance(), MouseEventSpec$MOUSE_CLICKED_getInstance(), MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance(), MouseEventSpec$MOUSE_PRESSED_getInstance(), MouseEventSpec$MOUSE_RELEASED_getInstance()];\n }\n MouseEventSpec.values = MouseEventSpec$values;\n function MouseEventSpec$valueOf(name) {\n switch (name) {\n case 'MOUSE_ENTERED':\n return MouseEventSpec$MOUSE_ENTERED_getInstance();\n case 'MOUSE_LEFT':\n return MouseEventSpec$MOUSE_LEFT_getInstance();\n case 'MOUSE_MOVED':\n return MouseEventSpec$MOUSE_MOVED_getInstance();\n case 'MOUSE_DRAGGED':\n return MouseEventSpec$MOUSE_DRAGGED_getInstance();\n case 'MOUSE_CLICKED':\n return MouseEventSpec$MOUSE_CLICKED_getInstance();\n case 'MOUSE_DOUBLE_CLICKED':\n return MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance();\n case 'MOUSE_PRESSED':\n return MouseEventSpec$MOUSE_PRESSED_getInstance();\n case 'MOUSE_RELEASED':\n return MouseEventSpec$MOUSE_RELEASED_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.event.MouseEventSpec.' + name);\n }\n }\n MouseEventSpec.valueOf_61zpoe$ = MouseEventSpec$valueOf;\n function PointEvent(x, y) {\n Event.call(this);\n this.x = x;\n this.y = y;\n }\n Object.defineProperty(PointEvent.prototype, 'location', {\n configurable: true,\n get: function () {\n return new Vector(this.x, this.y);\n }\n });\n PointEvent.prototype.toString = function () {\n return '{x=' + this.x + ',y=' + this.y + '}';\n };\n PointEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointEvent',\n interfaces: [Event]\n };\n function Function() {\n }\n Function.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Function',\n interfaces: []\n };\n function Functions() {\n Functions_instance = this;\n this.TRUE_PREDICATE_0 = Functions$TRUE_PREDICATE$lambda;\n this.FALSE_PREDICATE_0 = Functions$FALSE_PREDICATE$lambda;\n this.NULL_PREDICATE_0 = Functions$NULL_PREDICATE$lambda;\n this.NOT_NULL_PREDICATE_0 = Functions$NOT_NULL_PREDICATE$lambda;\n }\n function Functions$constantSupplier$ObjectLiteral(closure$value) {\n this.closure$value = closure$value;\n }\n Functions$constantSupplier$ObjectLiteral.prototype.get = function () {\n return this.closure$value;\n };\n Functions$constantSupplier$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Supplier]\n };\n Functions.prototype.constantSupplier_mh5how$ = function (value) {\n return new Functions$constantSupplier$ObjectLiteral(value);\n };\n Functions.prototype.memorize_kji2v1$ = function (supplier) {\n return new Functions$Memo(supplier);\n };\n Functions.prototype.alwaysTrue_287e2$ = function () {\n return this.TRUE_PREDICATE_0;\n };\n Functions.prototype.alwaysFalse_287e2$ = function () {\n return this.FALSE_PREDICATE_0;\n };\n function Functions$constant$lambda(closure$result) {\n return function (it) {\n return closure$result;\n };\n }\n Functions.prototype.constant_jkq9vw$ = function (result) {\n return Functions$constant$lambda(result);\n };\n Functions.prototype.isNull_287e2$ = function () {\n return this.NULL_PREDICATE_0;\n };\n Functions.prototype.isNotNull_287e2$ = function () {\n return this.NOT_NULL_PREDICATE_0;\n };\n function Functions$identity$lambda(it) {\n return it;\n }\n Functions.prototype.identity_287e2$ = function () {\n return Functions$identity$lambda;\n };\n function Functions$same$lambda(closure$value) {\n return function (it) {\n return it === closure$value;\n };\n }\n Functions.prototype.same_tpy1pm$ = function (value) {\n return Functions$same$lambda(value);\n };\n function Functions$funcOf$ObjectLiteral(closure$lambda) {\n this.closure$lambda = closure$lambda;\n }\n Functions$funcOf$ObjectLiteral.prototype.apply_11rb$ = function (value) {\n return this.closure$lambda(value);\n };\n Functions$funcOf$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Function]\n };\n Functions.prototype.funcOf_7h29gk$ = function (lambda) {\n return new Functions$funcOf$ObjectLiteral(lambda);\n };\n function Functions$Memo(mySupplier) {\n this.mySupplier_0 = mySupplier;\n this.myCachedValue_0 = null;\n this.myCached_0 = false;\n }\n Functions$Memo.prototype.get = function () {\n if (!this.myCached_0) {\n this.myCachedValue_0 = this.mySupplier_0.get();\n this.myCached_0 = true;\n }return ensureNotNull(this.myCachedValue_0);\n };\n Functions$Memo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Memo',\n interfaces: [Supplier]\n };\n function Functions$TRUE_PREDICATE$lambda(it) {\n return true;\n }\n function Functions$FALSE_PREDICATE$lambda(it) {\n return false;\n }\n function Functions$NULL_PREDICATE$lambda(it) {\n return it == null;\n }\n function Functions$NOT_NULL_PREDICATE$lambda(it) {\n return it != null;\n }\n Functions.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Functions',\n interfaces: []\n };\n var Functions_instance = null;\n function Functions_getInstance() {\n if (Functions_instance === null) {\n new Functions();\n }return Functions_instance;\n }\n function Runnable() {\n }\n Runnable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Runnable',\n interfaces: []\n };\n function Supplier() {\n }\n Supplier.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Supplier',\n interfaces: []\n };\n function Value(myValue) {\n this.myValue_0 = myValue;\n }\n Value.prototype.get = function () {\n return this.myValue_0;\n };\n Value.prototype.set_11rb$ = function (value) {\n this.myValue_0 = value;\n };\n Value.prototype.toString = function () {\n return '' + toString(this.myValue_0);\n };\n Value.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Value',\n interfaces: [Supplier]\n };\n function Preconditions() {\n Preconditions_instance = this;\n }\n Preconditions.prototype.checkState_6taknv$ = function (expression) {\n if (!expression) {\n throw IllegalStateException_init_0();\n }};\n Preconditions.prototype.checkState_eltq40$ = function (expression, errorMessage) {\n if (!expression) {\n throw IllegalStateException_init(errorMessage.toString());\n }};\n Preconditions.prototype.checkArgument_6taknv$ = function (expression) {\n if (!expression) {\n throw IllegalArgumentException_init_0();\n }};\n Preconditions.prototype.checkArgument_eltq40$ = function (expression, errorMessage) {\n if (!expression) {\n throw IllegalArgumentException_init(errorMessage.toString());\n }};\n Preconditions.prototype.checkNotNull_mh5how$ = function (reference) {\n if (reference == null) {\n throw NullPointerException_init();\n }return reference;\n };\n Preconditions.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Preconditions',\n interfaces: []\n };\n var Preconditions_instance = null;\n function Preconditions_getInstance() {\n if (Preconditions_instance === null) {\n new Preconditions();\n }return Preconditions_instance;\n }\n function Strings() {\n Strings_instance = this;\n }\n Strings.prototype.isNullOrEmpty_pdl1vj$ = function (s) {\n var tmp$ = s == null;\n if (!tmp$) {\n tmp$ = s.length === 0;\n }return tmp$;\n };\n Strings.prototype.nullToEmpty_pdl1vj$ = function (string) {\n return string != null ? string : '';\n };\n Strings.prototype.repeat_bm4lxs$ = function (string, count) {\n var stringBuilder = StringBuilder_init();\n for (var i = 0; i < count; i++) {\n stringBuilder.append_pdl1vj$(string);\n }\n return stringBuilder.toString();\n };\n Strings.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Strings',\n interfaces: []\n };\n var Strings_instance = null;\n function Strings_getInstance() {\n if (Strings_instance === null) {\n new Strings();\n }return Strings_instance;\n }\n function Throwables() {\n Throwables_instance = this;\n }\n Throwables.prototype.getRootCause_tcv7n7$ = function (throwable) {\n var slowPointer = throwable;\n var advanceSlowPointer = false;\n var cause = throwable;\n while (cause.cause != null) {\n cause = ensureNotNull(cause.cause);\n if (cause === slowPointer) {\n throw new IllegalArgumentException('Loop in causal chain detected.', cause);\n }if (advanceSlowPointer) {\n slowPointer = ensureNotNull(slowPointer.cause);\n }advanceSlowPointer = !advanceSlowPointer;\n }\n return cause;\n };\n Throwables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Throwables',\n interfaces: []\n };\n var Throwables_instance = null;\n function Throwables_getInstance() {\n if (Throwables_instance === null) {\n new Throwables();\n }return Throwables_instance;\n }\n function ClosedRange(lower, upper) {\n ClosedRange$Companion_getInstance();\n this.lowerEnd = null;\n this.upperEnd = null;\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if ((tmp$_0 = typeof (tmp$ = lower) === 'number' ? tmp$ : null) != null) {\n if (!isFinite(tmp$_0)) {\n var message = 'ends must be finite: lower=' + lower + ' upper=' + upper;\n throw IllegalStateException_init(message.toString());\n }}if ((tmp$_2 = typeof (tmp$_1 = upper) === 'number' ? tmp$_1 : null) != null) {\n if (!isFinite(tmp$_2)) {\n var message_0 = 'ends must be finite: lower=' + lower + ' upper=' + upper;\n throw IllegalStateException_init(message_0.toString());\n }}this.lowerEnd = Comparables_getInstance().min_sdesaw$(lower, upper);\n this.upperEnd = Comparables_getInstance().max_sdesaw$(lower, upper);\n }\n ClosedRange.prototype.contains_mef7kx$ = function (v) {\n return Comparables_getInstance().lse_sdesaw$(this.lowerEnd, v) && Comparables_getInstance().lse_sdesaw$(v, this.upperEnd);\n };\n ClosedRange.prototype.span_d226ot$ = function (other) {\n if (this.encloses_d226ot$(other))\n return this;\n return other.encloses_d226ot$(this) ? other : new ClosedRange(Comparables_getInstance().min_sdesaw$(this.lowerEnd, other.lowerEnd), Comparables_getInstance().max_sdesaw$(this.upperEnd, other.upperEnd));\n };\n ClosedRange.prototype.encloses_d226ot$ = function (other) {\n return Comparables_getInstance().lse_sdesaw$(this.lowerEnd, other.lowerEnd) && Comparables_getInstance().gte_sdesaw$(this.upperEnd, other.upperEnd);\n };\n ClosedRange.prototype.isConnected_d226ot$ = function (other) {\n return !(Comparables_getInstance().gt_sdesaw$(this.lowerEnd, other.upperEnd) || Comparables_getInstance().ls_sdesaw$(this.upperEnd, other.lowerEnd));\n };\n ClosedRange.prototype.intersection_d226ot$ = function (other) {\n if (!this.isConnected_d226ot$(other))\n throw IllegalArgumentException_init('Ranges are not connected: this=' + this + ' other=' + other);\n if (this.encloses_d226ot$(other))\n return other;\n return other.encloses_d226ot$(this) ? this : new ClosedRange(Comparables_getInstance().max_sdesaw$(this.lowerEnd, other.lowerEnd), Comparables_getInstance().min_sdesaw$(this.upperEnd, other.upperEnd));\n };\n ClosedRange.prototype.toString = function () {\n return 'ClosedRange[' + this.lowerEnd + ', ' + this.upperEnd + ']';\n };\n ClosedRange.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, ClosedRange) ? tmp$_0 : throwCCE();\n if (!equals(this.lowerEnd, other.lowerEnd))\n return false;\n if (!equals(this.upperEnd, other.upperEnd))\n return false;\n return true;\n };\n ClosedRange.prototype.hashCode = function () {\n return hashCode(this.lowerEnd) + (31 * hashCode(this.upperEnd) | 0) | 0;\n };\n function ClosedRange$Companion() {\n ClosedRange$Companion_instance = this;\n }\n ClosedRange$Companion.prototype.singleton_f1zjgi$ = function (v) {\n return new ClosedRange(v, v);\n };\n ClosedRange$Companion.prototype.encloseAll_17hg47$ = function (values) {\n var tmp$;\n var iterated = false;\n var min = null;\n var max = null;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!iterated) {\n iterated = true;\n min = v;\n max = v;\n } else {\n min = Comparables_getInstance().min_sdesaw$(ensureNotNull(min), ensureNotNull(v));\n max = Comparables_getInstance().max_sdesaw$(ensureNotNull(max), v);\n }\n }\n if (!iterated) {\n throw NoSuchElementException_init();\n }return new ClosedRange(ensureNotNull(min), ensureNotNull(max));\n };\n ClosedRange$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ClosedRange$Companion_instance = null;\n function ClosedRange$Companion_getInstance() {\n if (ClosedRange$Companion_instance === null) {\n new ClosedRange$Companion();\n }return ClosedRange$Companion_instance;\n }\n ClosedRange.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ClosedRange',\n interfaces: []\n };\n function Comparables() {\n Comparables_instance = this;\n }\n Comparables.prototype.min_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) < 0 ? a : b;\n };\n Comparables.prototype.max_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) >= 0 ? a : b;\n };\n Comparables.prototype.lse_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) <= 0;\n };\n Comparables.prototype.gte_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) >= 0;\n };\n Comparables.prototype.ls_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) < 0;\n };\n Comparables.prototype.gt_sdesaw$ = function (a, b) {\n return Kotlin.compareTo(a, b) > 0;\n };\n Comparables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Comparables',\n interfaces: []\n };\n var Comparables_instance = null;\n function Comparables_getInstance() {\n if (Comparables_instance === null) {\n new Comparables();\n }return Comparables_instance;\n }\n function ComparatorOrdering(comparator) {\n Ordering.call(this);\n this.myComparator_0 = comparator;\n }\n ComparatorOrdering.prototype.compare = function (a, b) {\n return this.myComparator_0.compare(a, b);\n };\n ComparatorOrdering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ComparatorOrdering',\n interfaces: [Ordering]\n };\n function Iterables() {\n Iterables_instance = this;\n }\n Iterables.prototype.checkNonNegative_0 = function (position) {\n if (position < 0) {\n throw new IndexOutOfBoundsException(position.toString());\n }};\n Iterables.prototype.toList_yl67zr$ = function (iterable) {\n return toList(iterable);\n };\n Iterables.prototype.size_fakr2g$ = function (iterable) {\n return count(iterable);\n };\n Iterables.prototype.isEmpty_fakr2g$ = function (iterable) {\n var tmp$, tmp$_0, tmp$_1;\n return (tmp$_1 = (tmp$_0 = Kotlin.isType(tmp$ = iterable, Collection) ? tmp$ : null) != null ? tmp$_0.isEmpty() : null) != null ? tmp$_1 : !iterable.iterator().hasNext();\n };\n Iterables.prototype.filter_fpit1u$ = function (unfiltered, retainIfTrue) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = unfiltered.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (retainIfTrue(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n Iterables.prototype.all_fpit1u$ = function (iterable, predicate) {\n var all$result;\n all$break: do {\n var tmp$;\n if (Kotlin.isType(iterable, Collection) && iterable.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$ = iterable.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!predicate(element)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n return all$result;\n };\n Iterables.prototype.concat_yxozss$ = function (a, b) {\n return plus_0(a, b);\n };\n Iterables.prototype.get_7iig3d$ = function (iterable, position) {\n var tmp$;\n this.checkNonNegative_0(position);\n if (Kotlin.isType(iterable, List)) {\n return (Kotlin.isType(tmp$ = iterable, List) ? tmp$ : throwCCE()).get_za3lpa$(position);\n }var it = iterable.iterator();\n for (var i = 0; i <= position; i++) {\n if (i === position) {\n return it.next();\n }it.next();\n }\n throw new IndexOutOfBoundsException(position.toString());\n };\n Iterables.prototype.get_dhabsj$ = function (iterable, position, defaultValue) {\n var tmp$;\n this.checkNonNegative_0(position);\n if (Kotlin.isType(iterable, List)) {\n var list = Kotlin.isType(tmp$ = iterable, List) ? tmp$ : throwCCE();\n return position < list.size ? list.get_za3lpa$(position) : defaultValue;\n }var it = iterable.iterator();\n var i = 0;\n while (i <= position && it.hasNext()) {\n if (i === position) {\n return it.next();\n }it.next();\n i = i + 1 | 0;\n }\n return defaultValue;\n };\n Iterables.prototype.find_nk18wc$ = function (iterable, predicate, defaultValue) {\n var tmp$;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_0;\n tmp$_0 = iterable.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (predicate(element)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n return (tmp$ = firstOrNull$result) != null ? tmp$ : defaultValue;\n };\n Iterables.prototype.getLast_yl67zr$ = function (iterable) {\n return last_0(iterable);\n };\n Iterables.prototype.toArray_hjktyj$ = function (iterable) {\n var collection;\n if (Kotlin.isType(iterable, Collection)) {\n collection = iterable;\n } else {\n collection = toList(iterable);\n }\n return copyToArray(collection);\n };\n Iterables.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Iterables',\n interfaces: []\n };\n var Iterables_instance = null;\n function Iterables_getInstance() {\n if (Iterables_instance === null) {\n new Iterables();\n }return Iterables_instance;\n }\n function Lists() {\n Lists_instance = this;\n }\n Lists.prototype.transform_l7riir$ = function (fromList, function_0) {\n var destination = ArrayList_init_0(collectionSizeOrDefault(fromList, 10));\n var tmp$;\n tmp$ = fromList.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(function_0(item));\n }\n return destination;\n };\n Lists.prototype.reverse_bemo1h$ = function (list) {\n var copy = ArrayList_init_1(list);\n reverse(copy);\n return copy;\n };\n Lists.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Lists',\n interfaces: []\n };\n var Lists_instance = null;\n function Lists_getInstance() {\n if (Lists_instance === null) {\n new Lists();\n }return Lists_instance;\n }\n function Ordering() {\n Ordering$Companion_getInstance();\n }\n Ordering.prototype.isOrdered_p1ys8y$ = function (iterable) {\n var it = iterable.iterator();\n if (it.hasNext()) {\n var prev = it.next();\n while (it.hasNext()) {\n var next = it.next();\n if (this.compare(prev, next) > 0) {\n return false;\n }prev = next;\n }\n }return true;\n };\n function Ordering$sortedCopy$ObjectLiteral(this$Ordering) {\n this.this$Ordering = this$Ordering;\n }\n Ordering$sortedCopy$ObjectLiteral.prototype.compare = function (a, b) {\n return this.this$Ordering.compare(a, b);\n };\n Ordering$sortedCopy$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n Ordering.prototype.sortedCopy_m5x2f4$ = function (elements) {\n var tmp$;\n var array = Kotlin.isArray(tmp$ = Iterables_getInstance().toArray_hjktyj$(elements)) ? tmp$ : throwCCE();\n sortWith(array, new Ordering$sortedCopy$ObjectLiteral(this));\n return toList_0(array);\n };\n Ordering.prototype.reverse = function () {\n return new ComparatorOrdering(reversed(this));\n };\n Ordering.prototype.min_t5quzl$ = function (a, b) {\n return this.compare(a, b) <= 0 ? a : b;\n };\n Ordering.prototype.min_m5x2f4$ = function (iterable) {\n return this.min_x5a2gs$(iterable.iterator());\n };\n Ordering.prototype.min_x5a2gs$ = function (iterator) {\n var result = iterator.next();\n while (iterator.hasNext()) {\n result = this.min_t5quzl$(result, iterator.next());\n }\n return result;\n };\n Ordering.prototype.max_t5quzl$ = function (a, b) {\n return this.compare(a, b) >= 0 ? a : b;\n };\n Ordering.prototype.max_m5x2f4$ = function (iterable) {\n return this.max_x5a2gs$(iterable.iterator());\n };\n Ordering.prototype.max_x5a2gs$ = function (iterator) {\n var result = iterator.next();\n while (iterator.hasNext()) {\n result = this.max_t5quzl$(result, iterator.next());\n }\n return result;\n };\n function Ordering$Companion() {\n Ordering$Companion_instance = this;\n }\n Ordering$Companion.prototype.from_iajr8b$ = function (comparator) {\n var tmp$;\n return Kotlin.isType(comparator, Ordering) ? Kotlin.isType(tmp$ = comparator, Ordering) ? tmp$ : throwCCE() : new ComparatorOrdering(comparator);\n };\n Ordering$Companion.prototype.natural_dahdeg$ = function () {\n return new ComparatorOrdering(naturalOrder());\n };\n Ordering$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Ordering$Companion_instance = null;\n function Ordering$Companion_getInstance() {\n if (Ordering$Companion_instance === null) {\n new Ordering$Companion();\n }return Ordering$Companion_instance;\n }\n Ordering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Ordering',\n interfaces: [Comparator]\n };\n function Sets() {\n Sets_instance = this;\n }\n Sets.prototype.newHashSet_yl67zr$ = function (elements) {\n var tmp$;\n if (Kotlin.isType(elements, Collection)) {\n var collection = Kotlin.isType(tmp$ = elements, Collection) ? tmp$ : throwCCE();\n return HashSet_init(collection);\n }return this.newHashSet_0(elements.iterator());\n };\n Sets.prototype.newHashSet_0 = function (elements) {\n var set = HashSet_init_0();\n while (elements.hasNext()) {\n set.add_11rb$(elements.next());\n }\n return set;\n };\n Sets.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Sets',\n interfaces: []\n };\n var Sets_instance = null;\n function Sets_getInstance() {\n if (Sets_instance === null) {\n new Sets();\n }return Sets_instance;\n }\n function Stack() {\n this.elements_0 = ArrayList_init();\n }\n Stack.prototype.empty = function () {\n return this.elements_0.isEmpty();\n };\n Stack.prototype.push_11rb$ = function (item) {\n return this.elements_0.add_11rb$(item);\n };\n Stack.prototype.pop = function () {\n return this.elements_0.isEmpty() ? null : this.elements_0.removeAt_za3lpa$(this.elements_0.size - 1 | 0);\n };\n Stack.prototype.peek = function () {\n return lastOrNull(this.elements_0);\n };\n Stack.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Stack',\n interfaces: []\n };\n function TreeMap() {\n this.sortedKeys_0 = ArrayList_init();\n this.map_0 = HashMap_init_0();\n }\n Object.defineProperty(TreeMap.prototype, 'values', {\n configurable: true,\n get: function () {\n return this.map_0.values;\n }\n });\n TreeMap.prototype.get_mef7kx$ = function (key) {\n return this.map_0.get_11rb$(key);\n };\n TreeMap.prototype.put_ncwa5f$ = function (key, value) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n this.sortedKeys_0.add_wxm5ur$(~index, key);\n } else {\n this.sortedKeys_0.set_wxm5ur$(index, key);\n }\n return this.map_0.put_xwzc9p$(key, value);\n };\n TreeMap.prototype.containsKey_mef7kx$ = function (key) {\n return this.map_0.containsKey_11rb$(key);\n };\n TreeMap.prototype.floorKey_mef7kx$ = function (key) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n index = ~index - 1 | 0;\n if (index < 0)\n return null;\n }return this.sortedKeys_0.get_za3lpa$(index);\n };\n TreeMap.prototype.ceilingKey_mef7kx$ = function (key) {\n var index = binarySearch(this.sortedKeys_0, key);\n if (index < 0) {\n index = ~index;\n if (index === this.sortedKeys_0.size)\n return null;\n }return this.sortedKeys_0.get_za3lpa$(index);\n };\n TreeMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TreeMap',\n interfaces: []\n };\n function DoubleRectangle(origin, dimension) {\n DoubleRectangle$Companion_getInstance();\n this.origin = origin;\n this.dimension = dimension;\n }\n Object.defineProperty(DoubleRectangle.prototype, 'center', {\n configurable: true,\n get: function () {\n return this.origin.add_gpjtzr$(this.dimension.mul_14dthe$(0.5));\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'left', {\n configurable: true,\n get: function () {\n return this.origin.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'right', {\n configurable: true,\n get: function () {\n return this.origin.x + this.dimension.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'top', {\n configurable: true,\n get: function () {\n return this.origin.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'bottom', {\n configurable: true,\n get: function () {\n return this.origin.y + this.dimension.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'width', {\n configurable: true,\n get: function () {\n return this.dimension.x;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'height', {\n configurable: true,\n get: function () {\n return this.dimension.y;\n }\n });\n Object.defineProperty(DoubleRectangle.prototype, 'parts', {\n configurable: true,\n get: function () {\n var result = ArrayList_init();\n result.add_11rb$(new DoubleSegment(this.origin, this.origin.add_gpjtzr$(new DoubleVector(this.dimension.x, 0.0))));\n result.add_11rb$(new DoubleSegment(this.origin, this.origin.add_gpjtzr$(new DoubleVector(0.0, this.dimension.y))));\n result.add_11rb$(new DoubleSegment(this.origin.add_gpjtzr$(this.dimension), this.origin.add_gpjtzr$(new DoubleVector(this.dimension.x, 0.0))));\n result.add_11rb$(new DoubleSegment(this.origin.add_gpjtzr$(this.dimension), this.origin.add_gpjtzr$(new DoubleVector(0.0, this.dimension.y))));\n return result;\n }\n });\n DoubleRectangle.prototype.xRange = function () {\n return new ClosedRange(this.origin.x, this.origin.x + this.dimension.x);\n };\n DoubleRectangle.prototype.yRange = function () {\n return new ClosedRange(this.origin.y, this.origin.y + this.dimension.y);\n };\n DoubleRectangle.prototype.contains_gpjtzr$ = function (v) {\n return this.origin.x <= v.x && this.origin.x + this.dimension.x >= v.x && this.origin.y <= v.y && this.origin.y + this.dimension.y >= v.y;\n };\n DoubleRectangle.prototype.union_wthzt5$ = function (rect) {\n var newOrigin = this.origin.min_gpjtzr$(rect.origin);\n var corner = this.origin.add_gpjtzr$(this.dimension);\n var rectCorner = rect.origin.add_gpjtzr$(rect.dimension);\n var newCorner = corner.max_gpjtzr$(rectCorner);\n var newDimension = newCorner.subtract_gpjtzr$(newOrigin);\n return new DoubleRectangle(newOrigin, newDimension);\n };\n DoubleRectangle.prototype.intersects_wthzt5$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_gpjtzr$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_gpjtzr$(rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n };\n DoubleRectangle.prototype.intersect_wthzt5$ = function (r) {\n var tmp$;\n var t1 = this.origin;\n var t2 = this.origin.add_gpjtzr$(this.dimension);\n var r1 = r.origin;\n var r2 = r.origin.add_gpjtzr$(r.dimension);\n var res1 = t1.max_gpjtzr$(r1);\n var res2 = t2.min_gpjtzr$(r2);\n var dim = res2.subtract_gpjtzr$(res1);\n if (dim.x < 0 || dim.y < 0) {\n tmp$ = null;\n } else\n tmp$ = new DoubleRectangle(res1, dim);\n return tmp$;\n };\n DoubleRectangle.prototype.add_gpjtzr$ = function (v) {\n return new DoubleRectangle(this.origin.add_gpjtzr$(v), this.dimension);\n };\n DoubleRectangle.prototype.subtract_gpjtzr$ = function (v) {\n return new DoubleRectangle(this.origin.subtract_gpjtzr$(v), this.dimension);\n };\n DoubleRectangle.prototype.distance_gpjtzr$ = function (to) {\n var tmp$;\n var result = 0.0;\n var hasResult = false;\n tmp$ = this.parts.iterator();\n while (tmp$.hasNext()) {\n var s = tmp$.next();\n if (!hasResult) {\n result = s.distance_gpjtzr$(to);\n hasResult = true;\n } else {\n var distance = s.distance_gpjtzr$(to);\n if (distance < result) {\n result = distance;\n }}\n }\n return result;\n };\n DoubleRectangle.prototype.hashCode = function () {\n return (this.origin.hashCode() * 31 | 0) + this.dimension.hashCode() | 0;\n };\n DoubleRectangle.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleRectangle)) {\n return false;\n }var r = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleRectangle) ? tmp$ : throwCCE();\n return ensureNotNull(r).origin.equals(this.origin) && r.dimension.equals(this.dimension);\n };\n DoubleRectangle.prototype.toString = function () {\n return '[rect ' + this.origin + ', ' + this.dimension + ']';\n };\n function DoubleRectangle$Companion() {\n DoubleRectangle$Companion_instance = this;\n }\n DoubleRectangle$Companion.prototype.span_qt8ska$ = function (leftTop, rightBottom) {\n return new DoubleRectangle(leftTop, rightBottom.subtract_gpjtzr$(leftTop));\n };\n DoubleRectangle$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DoubleRectangle$Companion_instance = null;\n function DoubleRectangle$Companion_getInstance() {\n if (DoubleRectangle$Companion_instance === null) {\n new DoubleRectangle$Companion();\n }return DoubleRectangle$Companion_instance;\n }\n DoubleRectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleRectangle',\n interfaces: []\n };\n function DoubleRectangle_init(x, y, w, h, $this) {\n $this = $this || Object.create(DoubleRectangle.prototype);\n DoubleRectangle.call($this, new DoubleVector(x, y), new DoubleVector(w, h));\n return $this;\n }\n function DoubleRectangles() {\n DoubleRectangles_instance = this;\n }\n function DoubleRectangles$boundingBox$lambda(minX, minY, maxX, maxY) {\n return DoubleRectangle$Companion_getInstance().span_qt8ska$(new DoubleVector(minX, minY), new DoubleVector(maxX, maxY));\n }\n DoubleRectangles.prototype.boundingBox_qdtdbw$ = function (points) {\n return this.calculateBoundingBox_h5l7ap$(points, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }), DoubleRectangles$boundingBox$lambda);\n };\n DoubleRectangles.prototype.calculateBoundingBox_h5l7ap$ = function (points, getX, getY, factory) {\n var tmp$;\n var first = points.iterator().next();\n var minLon = getX(first);\n var minLat = getY(first);\n var maxLon = minLon;\n var maxLat = minLat;\n tmp$ = points.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n var a = minLon;\n var b = getX(point);\n minLon = JsMath.min(a, b);\n var a_0 = maxLon;\n var b_0 = getX(point);\n maxLon = JsMath.max(a_0, b_0);\n var a_1 = minLat;\n var b_1 = getY(point);\n minLat = JsMath.min(a_1, b_1);\n var a_2 = maxLat;\n var b_2 = getY(point);\n maxLat = JsMath.max(a_2, b_2);\n }\n return factory(minLon, minLat, maxLon, maxLat);\n };\n DoubleRectangles.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DoubleRectangles',\n interfaces: []\n };\n var DoubleRectangles_instance = null;\n function DoubleRectangles_getInstance() {\n if (DoubleRectangles_instance === null) {\n new DoubleRectangles();\n }return DoubleRectangles_instance;\n }\n function DoubleSegment(start, end) {\n this.start = start;\n this.end = end;\n }\n DoubleSegment.prototype.distance_gpjtzr$ = function (v) {\n var vs = this.start.subtract_gpjtzr$(v);\n var ve = this.end.subtract_gpjtzr$(v);\n if (this.isDistanceToLineBest_0(v)) {\n var x = vs.x * ve.y - vs.y * ve.x;\n var pVolume = JsMath.abs(x);\n return pVolume / this.length();\n } else {\n var a = vs.length();\n var b = ve.length();\n return JsMath.min(a, b);\n }\n };\n DoubleSegment.prototype.isDistanceToLineBest_0 = function (v) {\n var es = this.start.subtract_gpjtzr$(this.end);\n var se = es.negate();\n var ev = v.subtract_gpjtzr$(this.end);\n var sv = v.subtract_gpjtzr$(this.start);\n return es.dotProduct_gpjtzr$(ev) >= 0 && se.dotProduct_gpjtzr$(sv) >= 0;\n };\n DoubleSegment.prototype.intersection_69p9e5$ = function (with_0) {\n var tmp$;\n var o1 = this.start;\n var o2 = with_0.start;\n var d1 = this.end.subtract_gpjtzr$(this.start);\n var d2 = with_0.end.subtract_gpjtzr$(with_0.start);\n var td = d1.dotProduct_gpjtzr$(d2.orthogonal());\n if (td === 0.0) {\n return null;\n }var t = o2.subtract_gpjtzr$(o1).dotProduct_gpjtzr$(d2.orthogonal()) / td;\n if (t < 0 || t > 1) {\n return null;\n }var sd = d2.dotProduct_gpjtzr$(d1.orthogonal());\n var s = o1.subtract_gpjtzr$(o2).dotProduct_gpjtzr$(d1.orthogonal()) / sd;\n if (s < 0 || s > 1) {\n tmp$ = null;\n } else\n tmp$ = o1.add_gpjtzr$(d1.mul_14dthe$(t));\n return tmp$;\n };\n DoubleSegment.prototype.length = function () {\n return this.start.subtract_gpjtzr$(this.end).length();\n };\n DoubleSegment.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleSegment)) {\n return false;\n }var l = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleSegment) ? tmp$ : throwCCE();\n return ensureNotNull(l).start.equals(this.start) && l.end.equals(this.end);\n };\n DoubleSegment.prototype.hashCode = function () {\n return (this.start.hashCode() * 31 | 0) + this.end.hashCode() | 0;\n };\n DoubleSegment.prototype.toString = function () {\n return '[' + this.start + ' -> ' + this.end + ']';\n };\n DoubleSegment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleSegment',\n interfaces: []\n };\n function DoubleVector(x, y) {\n DoubleVector$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n DoubleVector.prototype.add_gpjtzr$ = function (v) {\n return new DoubleVector(this.x + v.x, this.y + v.y);\n };\n DoubleVector.prototype.subtract_gpjtzr$ = function (v) {\n return new DoubleVector(this.x - v.x, this.y - v.y);\n };\n DoubleVector.prototype.max_gpjtzr$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new DoubleVector(tmp$, JsMath.max(a_0, b_0));\n };\n DoubleVector.prototype.min_gpjtzr$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new DoubleVector(tmp$, JsMath.min(a_0, b_0));\n };\n DoubleVector.prototype.mul_14dthe$ = function (value) {\n return new DoubleVector(this.x * value, this.y * value);\n };\n DoubleVector.prototype.dotProduct_gpjtzr$ = function (v) {\n return this.x * v.x + this.y * v.y;\n };\n DoubleVector.prototype.negate = function () {\n return new DoubleVector(-this.x, -this.y);\n };\n DoubleVector.prototype.orthogonal = function () {\n return new DoubleVector(-this.y, this.x);\n };\n DoubleVector.prototype.length = function () {\n var x = this.x * this.x + this.y * this.y;\n return JsMath.sqrt(x);\n };\n DoubleVector.prototype.normalize = function () {\n return this.mul_14dthe$(1 / this.length());\n };\n DoubleVector.prototype.rotate_14dthe$ = function (phi) {\n var x = this.x * JsMath.cos(phi) - this.y * JsMath.sin(phi);\n var y = this.x * JsMath.sin(phi) + this.y * JsMath.cos(phi);\n return new DoubleVector(x, y);\n };\n DoubleVector.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, DoubleVector)) {\n return false;\n }var v = (tmp$ = other) == null || Kotlin.isType(tmp$, DoubleVector) ? tmp$ : throwCCE();\n return ensureNotNull(v).x === this.x && v.y === this.y;\n };\n DoubleVector.prototype.hashCode = function () {\n return hashCode(this.x) + (31 * hashCode(this.y) | 0) | 0;\n };\n DoubleVector.prototype.toString = function () {\n return '(' + this.x + ', ' + this.y + ')';\n };\n function DoubleVector$Companion() {\n DoubleVector$Companion_instance = this;\n this.ZERO = new DoubleVector(0.0, 0.0);\n }\n DoubleVector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DoubleVector$Companion_instance = null;\n function DoubleVector$Companion_getInstance() {\n if (DoubleVector$Companion_instance === null) {\n new DoubleVector$Companion();\n }return DoubleVector$Companion_instance;\n }\n DoubleVector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleVector',\n interfaces: []\n };\n function Rectangle(origin, dimension) {\n this.origin = origin;\n this.dimension = dimension;\n }\n Object.defineProperty(Rectangle.prototype, 'boundSegments', {\n configurable: true,\n get: function () {\n var p = this.boundPoints_0;\n return [new Segment(p[0], p[1]), new Segment(p[1], p[2]), new Segment(p[2], p[3]), new Segment(p[3], p[0])];\n }\n });\n Object.defineProperty(Rectangle.prototype, 'boundPoints_0', {\n configurable: true,\n get: function () {\n return [this.origin, this.origin.add_119tl4$(new Vector(this.dimension.x, 0)), this.origin.add_119tl4$(this.dimension), this.origin.add_119tl4$(new Vector(0, this.dimension.y))];\n }\n });\n Rectangle.prototype.add_119tl4$ = function (v) {\n return new Rectangle(this.origin.add_119tl4$(v), this.dimension);\n };\n Rectangle.prototype.sub_119tl4$ = function (v) {\n return new Rectangle(this.origin.sub_119tl4$(v), this.dimension);\n };\n Rectangle.prototype.contains_vfns7u$ = function (r) {\n return this.contains_119tl4$(r.origin) && this.contains_119tl4$(r.origin.add_119tl4$(r.dimension));\n };\n Rectangle.prototype.contains_119tl4$ = function (v) {\n return this.origin.x <= v.x && (this.origin.x + this.dimension.x | 0) >= v.x && this.origin.y <= v.y && (this.origin.y + this.dimension.y | 0) >= v.y;\n };\n Rectangle.prototype.union_vfns7u$ = function (rect) {\n var newOrigin = this.origin.min_119tl4$(rect.origin);\n var corner = this.origin.add_119tl4$(this.dimension);\n var rectCorner = rect.origin.add_119tl4$(rect.dimension);\n var newCorner = corner.max_119tl4$(rectCorner);\n var newDimension = newCorner.sub_119tl4$(newOrigin);\n return new Rectangle(newOrigin, newDimension);\n };\n Rectangle.prototype.intersects_vfns7u$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_119tl4$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_119tl4$(rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n };\n Rectangle.prototype.intersect_vfns7u$ = function (r) {\n if (!this.intersects_vfns7u$(r)) {\n throw IllegalStateException_init('rectangle [' + this + \"] doesn't intersect [\" + r + ']');\n }var too = this.origin.add_119tl4$(this.dimension);\n var roo = r.origin.add_119tl4$(r.dimension);\n var ioo = too.min_119tl4$(roo);\n var io = this.origin.max_119tl4$(r.origin);\n return new Rectangle(io, ioo.sub_119tl4$(io));\n };\n Rectangle.prototype.innerIntersects_vfns7u$ = function (rect) {\n var t1 = this.origin;\n var t2 = this.origin.add_119tl4$(this.dimension);\n var r1 = rect.origin;\n var r2 = rect.origin.add_119tl4$(rect.dimension);\n return r2.x > t1.x && t2.x > r1.x && r2.y > t1.y && t2.y > r1.y;\n };\n Rectangle.prototype.changeDimension_119tl4$ = function (dim) {\n return new Rectangle(this.origin, dim);\n };\n Rectangle.prototype.distance_119tl4$ = function (to) {\n return this.toDoubleRectangle_0().distance_gpjtzr$(to.toDoubleVector());\n };\n Rectangle.prototype.xRange = function () {\n return new ClosedRange(this.origin.x, this.origin.x + this.dimension.x | 0);\n };\n Rectangle.prototype.yRange = function () {\n return new ClosedRange(this.origin.y, this.origin.y + this.dimension.y | 0);\n };\n Rectangle.prototype.hashCode = function () {\n return (this.origin.hashCode() * 31 | 0) + this.dimension.hashCode() | 0;\n };\n Rectangle.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, Rectangle))\n return false;\n var otherRect = (tmp$ = other) == null || Kotlin.isType(tmp$, Rectangle) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.origin) != null ? tmp$_0.equals(ensureNotNull(otherRect).origin) : null) && ((tmp$_1 = this.dimension) != null ? tmp$_1.equals(otherRect.dimension) : null);\n };\n Rectangle.prototype.toDoubleRectangle_0 = function () {\n return new DoubleRectangle(this.origin.toDoubleVector(), this.dimension.toDoubleVector());\n };\n Rectangle.prototype.center = function () {\n return this.origin.add_119tl4$(new Vector(this.dimension.x / 2 | 0, this.dimension.y / 2 | 0));\n };\n Rectangle.prototype.toString = function () {\n return this.origin.toString() + ' - ' + this.dimension;\n };\n Rectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Rectangle',\n interfaces: []\n };\n function Rectangle_init(x, y, width, height, $this) {\n $this = $this || Object.create(Rectangle.prototype);\n Rectangle.call($this, new Vector(x, y), new Vector(width, height));\n return $this;\n }\n function Rectangles() {\n Rectangles_instance = this;\n }\n Rectangles.prototype.zeroOrigin_vfns7u$ = function (r) {\n return new Rectangle(Vector$Companion_getInstance().ZERO, r.dimension);\n };\n Rectangles.prototype.upperDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topLeft_0(inner).y - this.topLeft_0(outer).y | 0;\n };\n Rectangles.prototype.lowerDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.bottomLeft_0(outer).y - this.bottomLeft_0(inner).y | 0;\n };\n Rectangles.prototype.leftDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topLeft_0(inner).x - this.topLeft_0(outer).x | 0;\n };\n Rectangles.prototype.rightDistance_w66x3o$ = function (inner, outer) {\n this.assertOuterInner_0(outer, inner);\n return this.topRight_vfns7u$(outer).x - this.topRight_vfns7u$(inner).x | 0;\n };\n Rectangles.prototype.assertOuterInner_0 = function (outer, inner) {\n if (!outer.contains_vfns7u$(inner)) {\n throw IllegalArgumentException_init('Outer does not contain inner: outer = ' + outer + ', inner = ' + inner);\n }};\n Rectangles.prototype.extendUp_o8ajws$ = function (r, distance) {\n var change = new Vector(0, distance);\n return new Rectangle(r.origin.sub_119tl4$(change), r.dimension.add_119tl4$(change));\n };\n Rectangles.prototype.extendDown_o8ajws$ = function (r, distance) {\n return r.changeDimension_119tl4$(r.dimension.add_119tl4$(new Vector(0, distance)));\n };\n Rectangles.prototype.extendLeft_o8ajws$ = function (r, distance) {\n var change = new Vector(distance, 0);\n return new Rectangle(r.origin.sub_119tl4$(change), r.dimension.add_119tl4$(change));\n };\n Rectangles.prototype.extendRight_o8ajws$ = function (r, distance) {\n return r.changeDimension_119tl4$(r.dimension.add_119tl4$(new Vector(distance, 0)));\n };\n Rectangles.prototype.extendSides_ogcnvu$ = function (left, r, right) {\n return this.extendRight_o8ajws$(this.extendLeft_o8ajws$(r, left), right);\n };\n Rectangles.prototype.shrinkRight_o8ajws$ = function (r, distance) {\n if (r.dimension.x < distance) {\n throw IllegalArgumentException_init('To small rectangle = ' + r + ', distance = ' + distance);\n }return r.changeDimension_119tl4$(r.dimension.sub_119tl4$(new Vector(distance, 0)));\n };\n Rectangles.prototype.topLeft_0 = function (r) {\n return r.origin;\n };\n Rectangles.prototype.topRight_vfns7u$ = function (r) {\n return r.origin.add_119tl4$(new Vector(r.dimension.x, 0));\n };\n Rectangles.prototype.bottomLeft_0 = function (r) {\n return r.origin.add_119tl4$(new Vector(0, r.dimension.y));\n };\n Rectangles.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Rectangles',\n interfaces: []\n };\n var Rectangles_instance = null;\n function Rectangles_getInstance() {\n if (Rectangles_instance === null) {\n new Rectangles();\n }return Rectangles_instance;\n }\n function Segment(start, end) {\n this.start = start;\n this.end = end;\n }\n Segment.prototype.distance_119tl4$ = function (v) {\n var vs = this.start.sub_119tl4$(v);\n var ve = this.end.sub_119tl4$(v);\n if (this.isDistanceToLineBest_0(v)) {\n var pVolume = abs(Kotlin.imul(vs.x, ve.y) - Kotlin.imul(vs.y, ve.x) | 0);\n return pVolume / this.length();\n } else {\n var a = vs.toDoubleVector().length();\n var b = ve.toDoubleVector().length();\n return JsMath.min(a, b);\n }\n };\n Segment.prototype.isDistanceToLineBest_0 = function (v) {\n var es = this.start.sub_119tl4$(this.end);\n var se = es.negate();\n var ev = v.sub_119tl4$(this.end);\n var sv = v.sub_119tl4$(this.start);\n return es.dotProduct_119tl4$(ev) >= 0 && se.dotProduct_119tl4$(sv) >= 0;\n };\n Segment.prototype.toDoubleSegment = function () {\n return new DoubleSegment(this.start.toDoubleVector(), this.end.toDoubleVector());\n };\n Segment.prototype.intersection_51grtu$ = function (with_0) {\n return this.toDoubleSegment().intersection_69p9e5$(with_0.toDoubleSegment());\n };\n Segment.prototype.length = function () {\n return this.start.sub_119tl4$(this.end).length();\n };\n Segment.prototype.contains_119tl4$ = function (v) {\n var tmp$;\n var p1 = v.sub_119tl4$(this.start);\n var p2 = v.sub_119tl4$(this.end);\n if (p1.isParallel_119tl4$(p2)) {\n tmp$ = p1.dotProduct_119tl4$(p2) <= 0;\n } else\n tmp$ = false;\n return tmp$;\n };\n Segment.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1;\n if (!Kotlin.isType(other, Segment)) {\n return false;\n }var l = (tmp$ = other) == null || Kotlin.isType(tmp$, Segment) ? tmp$ : throwCCE();\n return ((tmp$_0 = ensureNotNull(l).start) != null ? tmp$_0.equals(this.start) : null) && ((tmp$_1 = l.end) != null ? tmp$_1.equals(this.end) : null);\n };\n Segment.prototype.hashCode = function () {\n return (this.start.hashCode() * 31 | 0) + this.end.hashCode() | 0;\n };\n Segment.prototype.toString = function () {\n return '[' + this.start + ' -> ' + this.end + ']';\n };\n Segment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Segment',\n interfaces: []\n };\n function Vector(x, y) {\n Vector$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n function Vector$Companion() {\n Vector$Companion_instance = this;\n this.ZERO = new Vector(0, 0);\n }\n Vector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Vector$Companion_instance = null;\n function Vector$Companion_getInstance() {\n if (Vector$Companion_instance === null) {\n new Vector$Companion();\n }return Vector$Companion_instance;\n }\n Vector.prototype.add_119tl4$ = function (v) {\n return new Vector(this.x + v.x | 0, this.y + v.y | 0);\n };\n Vector.prototype.sub_119tl4$ = function (v) {\n return this.add_119tl4$(v.negate());\n };\n Vector.prototype.negate = function () {\n return new Vector(-this.x | 0, -this.y | 0);\n };\n Vector.prototype.max_119tl4$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new Vector(tmp$, JsMath.max(a_0, b_0));\n };\n Vector.prototype.min_119tl4$ = function (v) {\n var a = this.x;\n var b = v.x;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.y;\n var b_0 = v.y;\n return new Vector(tmp$, JsMath.min(a_0, b_0));\n };\n Vector.prototype.mul_za3lpa$ = function (i) {\n return new Vector(Kotlin.imul(this.x, i), Kotlin.imul(this.y, i));\n };\n Vector.prototype.div_za3lpa$ = function (i) {\n return new Vector(this.x / i | 0, this.y / i | 0);\n };\n Vector.prototype.dotProduct_119tl4$ = function (v) {\n return Kotlin.imul(this.x, v.x) + Kotlin.imul(this.y, v.y) | 0;\n };\n Vector.prototype.length = function () {\n var x = Kotlin.imul(this.x, this.x) + Kotlin.imul(this.y, this.y) | 0;\n return JsMath.sqrt(x);\n };\n Vector.prototype.toDoubleVector = function () {\n return new DoubleVector(this.x, this.y);\n };\n Vector.prototype.abs = function () {\n return new Vector(abs(this.x), abs(this.y));\n };\n Vector.prototype.isParallel_119tl4$ = function (to) {\n return (Kotlin.imul(this.x, to.y) - Kotlin.imul(to.x, this.y) | 0) === 0;\n };\n Vector.prototype.orthogonal = function () {\n return new Vector(-this.y | 0, this.x);\n };\n Vector.prototype.equals = function (other) {\n var tmp$;\n if (!Kotlin.isType(other, Vector))\n return false;\n var otherVector = (tmp$ = other) == null || Kotlin.isType(tmp$, Vector) ? tmp$ : throwCCE();\n return this.x === ensureNotNull(otherVector).x && this.y === otherVector.y;\n };\n Vector.prototype.hashCode = function () {\n return (this.x * 31 | 0) + this.y | 0;\n };\n Vector.prototype.toString = function () {\n return '(' + this.x + ', ' + this.y + ')';\n };\n Vector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Vector',\n interfaces: []\n };\n function JsObjectSupport() {\n JsObjectSupport_instance = this;\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda(it) {\n return Unit;\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_0(closure$buffer, closure$handleValue) {\n return function (list) {\n var tmp$;\n closure$buffer.append_s8itvh$(91);\n var first = true;\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!first)\n closure$buffer.append_s8itvh$(44);\n else\n first = false;\n closure$handleValue.v(v);\n }\n return closure$buffer.append_s8itvh$(93);\n };\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_1(closure$buffer, closure$handleValue) {\n return function (map) {\n var tmp$, tmp$_0, tmp$_1;\n closure$buffer.append_s8itvh$(123);\n var first = true;\n tmp$ = map.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_2 = tmp$.next();\n var k = tmp$_2.key;\n var v = tmp$_2.value;\n if ((typeof (tmp$_0 = k) === 'string' ? tmp$_0 : null) == null) {\n throw IllegalArgumentException_init('Only `string` keys are supported, was: ' + ((tmp$_1 = Kotlin.getKClassFromExpression(ensureNotNull(k)).simpleName) != null ? tmp$_1 : 'no class name'));\n }if (!first)\n closure$buffer.append_s8itvh$(44);\n else\n first = false;\n closure$buffer.append_s8itvh$(10);\n closure$buffer.append_s8itvh$(34).append_pdl1vj$(escape(k)).append_s8itvh$(34).append_s8itvh$(58);\n closure$handleValue.v(v);\n }\n return closure$buffer.append_pdl1vj$('\\n}');\n };\n }\n function JsObjectSupport$mapToJsObjectInitializer$lambda_2(closure$buffer, closure$handleList, closure$handleMap) {\n return function (v) {\n if (typeof v === 'string')\n closure$buffer.append_s8itvh$(34).append_pdl1vj$(escape(v)).append_s8itvh$(34);\n else if (typeof v === 'boolean' || Kotlin.isNumber(v))\n closure$buffer.append_s8jyv4$(v);\n else if (v == null)\n closure$buffer.append_pdl1vj$('null');\n else if (Kotlin.isArray(v))\n closure$handleList(asList(v));\n else if (Kotlin.isType(v, List))\n closure$handleList(v);\n else if (Kotlin.isType(v, Map))\n closure$handleMap(v);\n else\n throw IllegalArgumentException_init(\"Can't serialize object \" + toString(v));\n return Unit;\n };\n }\n JsObjectSupport.prototype.mapToJsObjectInitializer_6uu7i0$ = function (map) {\n var buffer = StringBuilder_init();\n var handleValue = {v: JsObjectSupport$mapToJsObjectInitializer$lambda};\n var handleList = JsObjectSupport$mapToJsObjectInitializer$lambda_0(buffer, handleValue);\n var handleMap = JsObjectSupport$mapToJsObjectInitializer$lambda_1(buffer, handleValue);\n handleValue.v = JsObjectSupport$mapToJsObjectInitializer$lambda_2(buffer, handleList, handleMap);\n handleMap(map);\n return buffer.toString();\n };\n JsObjectSupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'JsObjectSupport',\n interfaces: []\n };\n var JsObjectSupport_instance = null;\n function JsObjectSupport_getInstance() {\n if (JsObjectSupport_instance === null) {\n new JsObjectSupport();\n }return JsObjectSupport_instance;\n }\n function FluentArray() {\n this.myArray_0 = null;\n }\n FluentArray.prototype.getDouble_za3lpa$ = function (index) {\n var tmp$;\n return typeof (tmp$ = this.myArray_0.get_za3lpa$(index)) === 'number' ? tmp$ : throwCCE();\n };\n FluentArray.prototype.add_pdl1vj$ = function (v) {\n this.myArray_0.add_11rb$(v);\n return this;\n };\n FluentArray.prototype.add_yrwdxb$ = function (v) {\n this.myArray_0.add_11rb$(v);\n return this;\n };\n FluentArray.prototype.addStrings_d294za$ = function (values) {\n this.myArray_0.addAll_brywnq$(values);\n return this;\n };\n FluentArray.prototype.addAll_5ry1at$ = function (values) {\n var tmp$;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.myArray_0.add_11rb$(element.get());\n }\n return this;\n };\n FluentArray.prototype.addAll_m5dwgt$ = function (values) {\n this.addAll_5ry1at$(listOf(values.slice()));\n return this;\n };\n FluentArray.prototype.stream = function () {\n return streamOf(this.myArray_0);\n };\n FluentArray.prototype.objectStream = function () {\n return objectsStreamOf(this.myArray_0);\n };\n FluentArray.prototype.fluentObjectStream = function () {\n return map(objectsStreamOf(this.myArray_0), getCallableRef('FluentObject', function (p1) {\n return FluentObject_init(p1);\n }));\n };\n FluentArray.prototype.get = function () {\n return this.myArray_0;\n };\n FluentArray.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentArray',\n interfaces: [FluentValue]\n };\n function FluentArray_init($this) {\n $this = $this || Object.create(FluentArray.prototype);\n FluentValue.call($this);\n FluentArray.call($this);\n $this.myArray_0 = ArrayList_init();\n return $this;\n }\n function FluentArray_init_0(array, $this) {\n $this = $this || Object.create(FluentArray.prototype);\n FluentValue.call($this);\n FluentArray.call($this);\n $this.myArray_0 = ArrayList_init_1(array);\n return $this;\n }\n function FluentObject() {\n this.myObj_0 = null;\n }\n FluentObject.prototype.getArr_0 = function (key) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myObj_0.get_11rb$(key), List) ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getObj_0 = function (key) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myObj_0.get_11rb$(key), Map) ? tmp$ : throwCCE();\n };\n FluentObject.prototype.get = function () {\n return this.myObj_0;\n };\n FluentObject.prototype.contains_61zpoe$ = function (key) {\n return this.myObj_0.containsKey_11rb$(key);\n };\n FluentObject.prototype.containsNotNull_0 = function (key) {\n return this.contains_61zpoe$(key) && this.myObj_0.get_11rb$(key) != null;\n };\n FluentObject.prototype.put_wxs67v$ = function (key, v) {\n var $receiver = this.myObj_0;\n var value = v != null ? v.get() : null;\n $receiver.put_xwzc9p$(key, value);\n return this;\n };\n FluentObject.prototype.put_jyasbz$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_hzlfav$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_h92gdm$ = function (key, v) {\n this.myObj_0.put_xwzc9p$(key, v);\n return this;\n };\n FluentObject.prototype.put_snuhza$ = function (key, v) {\n var tmp$ = this.myObj_0;\n var value = v != null ? formatEnum(v) : null;\n tmp$.put_xwzc9p$(key, value);\n return this;\n };\n FluentObject.prototype.getInt_61zpoe$ = function (key) {\n return numberToInt(getNumber(this.myObj_0, key));\n };\n FluentObject.prototype.getDouble_61zpoe$ = function (key) {\n return getDouble(this.myObj_0, key);\n };\n FluentObject.prototype.getBoolean_61zpoe$ = function (key) {\n var tmp$;\n return typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'boolean' ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getString_61zpoe$ = function (key) {\n var tmp$;\n return typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'string' ? tmp$ : throwCCE();\n };\n FluentObject.prototype.getStrings_61zpoe$ = function (key) {\n var $receiver = this.getArr_0(key);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(getAsString(item));\n }\n return destination;\n };\n FluentObject.prototype.getEnum_xwn52g$ = function (key, enumValues) {\n var tmp$;\n return parseEnum(typeof (tmp$ = this.myObj_0.get_11rb$(key)) === 'string' ? tmp$ : throwCCE(), enumValues);\n };\n FluentObject.prototype.getEnum_a9gw98$ = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.json.FluentObject.getEnum_a9gw98$', function (T_0, isT, key) {\n return this.getEnum_xwn52g$(key, T_0.values());\n });\n FluentObject.prototype.getArray_61zpoe$ = function (key) {\n return FluentArray_init_0(this.getArr_0(key));\n };\n FluentObject.prototype.getObject_61zpoe$ = function (key) {\n return FluentObject_init(this.getObj_0(key));\n };\n FluentObject.prototype.getInt_qoz5hj$ = function (key, processor) {\n processor(this.getInt_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getDouble_l47sdb$ = function (key, processor) {\n processor(this.getDouble_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getBoolean_48wr2m$ = function (key, processor) {\n processor(this.getBoolean_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getString_hyc7mn$ = function (key, processor) {\n processor(this.getString_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getStrings_lpk3a7$ = function (key, processor) {\n processor(this.getStrings_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getEnum_651ru9$ = function (key, processor, enumValues) {\n processor(this.getEnum_xwn52g$(key, enumValues));\n return this;\n };\n FluentObject.prototype.getArray_nhu1ij$ = function (key, processor) {\n processor(this.getArray_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.getObject_6k19qz$ = function (key, processor) {\n processor(this.getObject_61zpoe$(key));\n return this;\n };\n FluentObject.prototype.putRemovable_wxs67v$ = function (key, v) {\n if (v != null) {\n this.put_wxs67v$(key, v);\n }return this;\n };\n FluentObject.prototype.putRemovable_snuhza$ = function (key, v) {\n if (v != null) {\n this.put_snuhza$(key, v);\n }return this;\n };\n FluentObject.prototype.forEntries_ophlsb$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n consumer(element, this.myObj_0.get_11rb$(element));\n }\n return this;\n };\n FluentObject.prototype.forObjEntries_izf7h5$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n consumer(element, Kotlin.isType(tmp$_0 = this.myObj_0.get_11rb$(element), Map) ? tmp$_0 : throwCCE());\n }\n return this;\n };\n FluentObject.prototype.forArrEntries_2wy1dl$ = function (consumer) {\n var tmp$;\n tmp$ = this.myObj_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n consumer(element, Kotlin.isType(tmp$_0 = this.myObj_0.get_11rb$(element), List) ? tmp$_0 : throwCCE());\n }\n return this;\n };\n FluentObject.prototype.accept_ysf37t$ = function (consumer) {\n consumer(this);\n return this;\n };\n FluentObject.prototype.forStrings_2by8ig$ = function (key, processor) {\n var $receiver = getArr(this.myObj_0, key);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(getAsString(item));\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n processor(element);\n }\n return this;\n };\n FluentObject.prototype.getExistingDouble_l47sdb$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.getDouble_l47sdb$(key, processor);\n }return this;\n };\n FluentObject.prototype.getOptionalStrings_jpy86i$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getStrings_61zpoe$(key));\n } else {\n processor(null);\n }\n return this;\n };\n FluentObject.prototype.getExistingString_hyc7mn$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.getString_hyc7mn$(key, processor);\n }return this;\n };\n function FluentObject$forExistingStrings$lambda$lambda(closure$processor) {\n return function (it) {\n closure$processor(ensureNotNull(it));\n return Unit;\n };\n }\n FluentObject.prototype.forExistingStrings_hyc7mn$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n this.forStrings_2by8ig$(key, FluentObject$forExistingStrings$lambda$lambda(processor));\n }return this;\n };\n FluentObject.prototype.getExistingObject_6k19qz$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n var obj = this.getObject_61zpoe$(key);\n if (!obj.myObj_0.keys.isEmpty()) {\n processor(obj);\n }}return this;\n };\n FluentObject.prototype.getExistingArray_nhu1ij$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getArray_61zpoe$(key));\n }return this;\n };\n FluentObject.prototype.forObjects_6k19qz$ = function (key, processor) {\n var tmp$;\n tmp$ = this.getArray_61zpoe$(key).fluentObjectStream().iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n processor(element);\n }\n return this;\n };\n FluentObject.prototype.getOptionalInt_w5p0jm$ = function (key, processor) {\n if (this.containsNotNull_0(key)) {\n processor(this.getInt_61zpoe$(key));\n } else {\n processor(null);\n }\n return this;\n };\n FluentObject.prototype.getIntOrDefault_u1i54l$ = function (key, processor, defaultValue) {\n if (this.containsNotNull_0(key)) {\n processor(this.getInt_61zpoe$(key));\n } else {\n processor(defaultValue);\n }\n return this;\n };\n FluentObject.prototype.forEnums_651ru9$ = function (key, processor, enumValues) {\n var tmp$;\n tmp$ = this.getArr_0(key).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n processor(parseEnum(typeof (tmp$_0 = element) === 'string' ? tmp$_0 : throwCCE(), enumValues));\n }\n return this;\n };\n FluentObject.prototype.getOptionalEnum_651ru9$ = function (key, processor, enumValues) {\n if (this.containsNotNull_0(key))\n processor(this.getEnum_xwn52g$(key, enumValues));\n else\n processor(null);\n return this;\n };\n FluentObject.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentObject',\n interfaces: [FluentValue]\n };\n function FluentObject_init(obj, $this) {\n $this = $this || Object.create(FluentObject.prototype);\n FluentValue.call($this);\n FluentObject.call($this);\n var tmp$;\n $this.myObj_0 = toMutableMap(Kotlin.isType(tmp$ = obj, Map) ? tmp$ : throwCCE());\n return $this;\n }\n function FluentObject_init_0($this) {\n $this = $this || Object.create(FluentObject.prototype);\n FluentValue.call($this);\n FluentObject.call($this);\n $this.myObj_0 = HashMap_init_0();\n return $this;\n }\n function FluentPrimitive() {\n this.value_0 = null;\n }\n FluentPrimitive.prototype.get = function () {\n return this.value_0;\n };\n FluentPrimitive.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentPrimitive',\n interfaces: [FluentValue]\n };\n function FluentPrimitive_init(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_0(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_1(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentPrimitive_init_2(v, $this) {\n $this = $this || Object.create(FluentPrimitive.prototype);\n FluentValue.call($this);\n FluentPrimitive.call($this);\n $this.value_0 = v;\n return $this;\n }\n function FluentValue() {\n }\n FluentValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FluentValue',\n interfaces: []\n };\n function JsonFormatter() {\n this.buffer_suueb3$_0 = this.buffer_suueb3$_0;\n }\n Object.defineProperty(JsonFormatter.prototype, 'buffer_0', {\n configurable: true,\n get: function () {\n if (this.buffer_suueb3$_0 == null)\n return throwUPAE('buffer');\n return this.buffer_suueb3$_0;\n },\n set: function (buffer) {\n this.buffer_suueb3$_0 = buffer;\n }\n });\n JsonFormatter.prototype.formatJson_za3rmp$ = function (o) {\n this.buffer_0 = StringBuilder_init();\n this.handleValue_0(o);\n return this.buffer_0.toString();\n };\n function JsonFormatter$handleList$lambda(this$JsonFormatter) {\n return function (tail) {\n var tmp$;\n tmp$ = tail.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var this$JsonFormatter_0 = this$JsonFormatter;\n this$JsonFormatter_0.append_0(',');\n this$JsonFormatter_0.handleValue_0(element);\n }\n return Unit;\n };\n }\n JsonFormatter.prototype.handleList_0 = function (list) {\n this.append_0('[');\n this.headTail_0(list, getCallableRef('handleValue', function ($receiver, p1) {\n return $receiver.handleValue_0(p1), Unit;\n }.bind(null, this)), JsonFormatter$handleList$lambda(this));\n this.append_0(']');\n };\n function JsonFormatter$handleMap$lambda(this$JsonFormatter) {\n return function (tail) {\n var tmp$;\n tmp$ = tail.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var this$JsonFormatter_0 = this$JsonFormatter;\n this$JsonFormatter_0.append_0(',\\n');\n this$JsonFormatter_0.handlePair_0(element);\n }\n return Unit;\n };\n }\n JsonFormatter.prototype.handleMap_0 = function (map) {\n this.append_0('{');\n this.headTail_0(map.entries, getCallableRef('handlePair', function ($receiver, p1) {\n return $receiver.handlePair_0(p1), Unit;\n }.bind(null, this)), JsonFormatter$handleMap$lambda(this));\n this.append_0('}');\n };\n JsonFormatter.prototype.handleValue_0 = function (v) {\n if (v == null)\n this.append_0('null');\n else if (typeof v === 'string')\n this.handleString_0(v);\n else if (Kotlin.isNumber(v) || equals(v, kotlin_js_internal_BooleanCompanionObject))\n this.append_0(v.toString());\n else if (Kotlin.isArray(v))\n this.handleList_0(asList(v));\n else if (Kotlin.isType(v, List))\n this.handleList_0(v);\n else if (Kotlin.isType(v, Map))\n this.handleMap_0(v);\n else\n throw IllegalArgumentException_init(\"Can't serialize object \" + toString(v));\n };\n JsonFormatter.prototype.handlePair_0 = function (pair) {\n this.handleString_0(pair.key);\n this.append_0(':');\n this.handleValue_0(pair.value);\n };\n JsonFormatter.prototype.handleString_0 = function (v) {\n if (v != null)\n if (typeof v === 'string')\n this.append_0('\"' + escape(v) + '\"');\n else\n throw IllegalArgumentException_init(\"Expected a string, but got '\" + toString(Kotlin.getKClassFromExpression(v).simpleName) + \"'\");\n };\n JsonFormatter.prototype.append_0 = function (s) {\n return this.buffer_0.append_pdl1vj$(s);\n };\n JsonFormatter.prototype.headTail_0 = function ($receiver, head, tail) {\n if (!$receiver.isEmpty()) {\n head(first_0($receiver));\n tail(drop(asSequence($receiver), 1));\n }};\n JsonFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonFormatter',\n interfaces: []\n };\n function JsonLexer(input) {\n JsonLexer$Companion_getInstance();\n this.input_0 = input;\n this.i_0 = 0;\n this.tokenStart_0 = 0;\n this.currentToken_dslfm7$_0 = null;\n this.nextToken();\n }\n Object.defineProperty(JsonLexer.prototype, 'currentToken', {\n configurable: true,\n get: function () {\n return this.currentToken_dslfm7$_0;\n },\n set: function (currentToken) {\n this.currentToken_dslfm7$_0 = currentToken;\n }\n });\n Object.defineProperty(JsonLexer.prototype, 'currentChar_0', {\n configurable: true,\n get: function () {\n return this.input_0.charCodeAt(this.i_0);\n }\n });\n function JsonLexer$nextToken$lambda(it) {\n return isWhitespace(unboxChar(it));\n }\n JsonLexer.prototype.nextToken = function () {\n var tmp$;\n this.advanceWhile_0(JsonLexer$nextToken$lambda);\n if (this.isFinished()) {\n return;\n }if (this.currentChar_0 === 123) {\n var $receiver = Token$LEFT_BRACE_getInstance();\n this.advance_0();\n tmp$ = $receiver;\n } else if (this.currentChar_0 === 125) {\n var $receiver_0 = Token$RIGHT_BRACE_getInstance();\n this.advance_0();\n tmp$ = $receiver_0;\n } else if (this.currentChar_0 === 91) {\n var $receiver_1 = Token$LEFT_BRACKET_getInstance();\n this.advance_0();\n tmp$ = $receiver_1;\n } else if (this.currentChar_0 === 93) {\n var $receiver_2 = Token$RIGHT_BRACKET_getInstance();\n this.advance_0();\n tmp$ = $receiver_2;\n } else if (this.currentChar_0 === 44) {\n var $receiver_3 = Token$COMMA_getInstance();\n this.advance_0();\n tmp$ = $receiver_3;\n } else if (this.currentChar_0 === 58) {\n var $receiver_4 = Token$COLON_getInstance();\n this.advance_0();\n tmp$ = $receiver_4;\n } else if (this.currentChar_0 === 116) {\n var $receiver_5 = Token$TRUE_getInstance();\n this.read_0('true');\n tmp$ = $receiver_5;\n } else if (this.currentChar_0 === 102) {\n var $receiver_6 = Token$FALSE_getInstance();\n this.read_0('false');\n tmp$ = $receiver_6;\n } else if (this.currentChar_0 === 110) {\n var $receiver_7 = Token$NULL_getInstance();\n this.read_0('null');\n tmp$ = $receiver_7;\n } else if (this.currentChar_0 === 34) {\n var $receiver_8 = Token$STRING_getInstance();\n this.readString_0();\n tmp$ = $receiver_8;\n } else if (this.readNumber_0())\n tmp$ = Token$NUMBER_getInstance();\n else {\n throw IllegalStateException_init((this.i_0.toString() + ':' + String.fromCharCode(this.currentChar_0) + ' - unkown token').toString());\n }\n this.currentToken = tmp$;\n };\n JsonLexer.prototype.tokenValue = function () {\n var $receiver = this.input_0;\n var startIndex = this.tokenStart_0;\n var endIndex = this.i_0;\n return $receiver.substring(startIndex, endIndex);\n };\n JsonLexer.prototype.readString_0 = function () {\n this.startToken_0();\n this.advance_0();\n while (this.currentChar_0 !== 34) {\n if (this.currentChar_0 === 92) {\n this.advance_0();\n if (this.currentChar_0 === 117) {\n this.advance_0();\n for (var index = 0; index < 4; index++) {\n if (!JsonLexer$Companion_getInstance().isHex_0(this.currentChar_0)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }this.advance_0();\n }\n } else {\n var $receiver = SPECIAL_CHARS;\n var key = toBoxedChar(this.currentChar_0);\n var tmp$;\n if ((Kotlin.isType(tmp$ = $receiver, Map) ? tmp$ : throwCCE()).containsKey_11rb$(key))\n this.advance_0();\n else {\n throw IllegalStateException_init('Invalid escape sequence'.toString());\n }\n }\n } else {\n this.advance_0();\n }\n }\n this.advance_0();\n };\n function JsonLexer$readNumber$lambda(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda$lambda(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda_0(this$JsonLexer) {\n return function () {\n if (!JsonLexer$Companion_getInstance().isDigit_0(this$JsonLexer.currentChar_0)) {\n var message = 'Number should have decimal part';\n throw IllegalArgumentException_init(message.toString());\n }this$JsonLexer.advanceWhile_0(JsonLexer$readNumber$lambda$lambda);\n return Unit;\n };\n }\n function JsonLexer$readNumber$lambda$lambda_0(it) {\n return JsonLexer$Companion_getInstance().isDigit_0(unboxChar(it));\n }\n function JsonLexer$readNumber$lambda_1(this$JsonLexer) {\n return function () {\n this$JsonLexer.advanceIfCurrent_0(Kotlin.charArrayOf(43, 45));\n this$JsonLexer.advanceWhile_0(JsonLexer$readNumber$lambda$lambda_0);\n return Unit;\n };\n }\n JsonLexer.prototype.readNumber_0 = function () {\n if (!(JsonLexer$Companion_getInstance().isDigit_0(this.currentChar_0) || this.currentChar_0 === 45)) {\n return false;\n }this.startToken_0();\n this.advanceIfCurrent_0(Kotlin.charArrayOf(45));\n this.advanceWhile_0(JsonLexer$readNumber$lambda);\n this.advanceIfCurrent_0(Kotlin.charArrayOf(46), JsonLexer$readNumber$lambda_0(this));\n this.advanceIfCurrent_0(Kotlin.charArrayOf(101, 69), JsonLexer$readNumber$lambda_1(this));\n return true;\n };\n JsonLexer.prototype.isFinished = function () {\n return this.i_0 === this.input_0.length;\n };\n JsonLexer.prototype.startToken_0 = function () {\n this.tokenStart_0 = this.i_0;\n };\n JsonLexer.prototype.advance_0 = function () {\n this.i_0 = this.i_0 + 1 | 0;\n };\n JsonLexer.prototype.read_0 = function (str) {\n var forEach$result;\n var tmp$;\n tmp$ = iterator(str);\n while (tmp$.hasNext()) {\n var element = unboxChar(tmp$.next());\n var it = toBoxedChar(element);\n if (!(this.currentChar_0 === unboxChar(it))) {\n var message = 'Wrong data: ' + str;\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.isFinished()) {\n var message_0 = 'Unexpected end of string';\n throw IllegalArgumentException_init(message_0.toString());\n }this.advance_0();\n }\n return forEach$result;\n };\n JsonLexer.prototype.advanceWhile_0 = function (pred) {\n while (!this.isFinished() && pred(toBoxedChar(this.currentChar_0)))\n this.advance_0();\n };\n function JsonLexer$advanceIfCurrent$lambda() {\n return Unit;\n }\n JsonLexer.prototype.advanceIfCurrent_0 = function (expected, then) {\n if (then === void 0)\n then = JsonLexer$advanceIfCurrent$lambda;\n if (!this.isFinished() && contains_0(expected, this.currentChar_0)) {\n this.advance_0();\n then();\n }};\n function JsonLexer$Companion() {\n JsonLexer$Companion_instance = this;\n this.digits_0 = new CharRange(48, 57);\n }\n JsonLexer$Companion.prototype.isDigit_0 = function ($receiver) {\n var $receiver_0 = this.digits_0;\n return $receiver != null && $receiver_0.contains_mef7kx$($receiver);\n };\n JsonLexer$Companion.prototype.isHex_0 = function ($receiver) {\n return this.isDigit_0($receiver) || (new CharRange(97, 102)).contains_mef7kx$($receiver) || (new CharRange(65, 70)).contains_mef7kx$($receiver);\n };\n JsonLexer$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JsonLexer$Companion_instance = null;\n function JsonLexer$Companion_getInstance() {\n if (JsonLexer$Companion_instance === null) {\n new JsonLexer$Companion();\n }return JsonLexer$Companion_instance;\n }\n JsonLexer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonLexer',\n interfaces: []\n };\n function JsonParser(json) {\n this.json_0 = json;\n }\n JsonParser.prototype.parseJson = function () {\n var lexer = new JsonLexer(this.json_0);\n return this.parseValue_0(lexer);\n };\n JsonParser.prototype.parseValue_0 = function (lexer) {\n var tmp$, tmp$_0;\n tmp$ = lexer.currentToken;\n if (equals(tmp$, Token$STRING_getInstance())) {\n var $receiver = unescape(lexer.tokenValue());\n lexer.nextToken();\n tmp$_0 = $receiver;\n } else if (equals(tmp$, Token$NUMBER_getInstance())) {\n var $receiver_0 = toDouble(lexer.tokenValue());\n lexer.nextToken();\n tmp$_0 = $receiver_0;\n } else if (equals(tmp$, Token$FALSE_getInstance())) {\n lexer.nextToken();\n tmp$_0 = false;\n } else if (equals(tmp$, Token$TRUE_getInstance())) {\n lexer.nextToken();\n tmp$_0 = true;\n } else if (equals(tmp$, Token$NULL_getInstance())) {\n lexer.nextToken();\n tmp$_0 = null;\n } else if (equals(tmp$, Token$LEFT_BRACE_getInstance()))\n tmp$_0 = this.parseObject_0(lexer);\n else if (equals(tmp$, Token$LEFT_BRACKET_getInstance()))\n tmp$_0 = this.parseArray_0(lexer);\n else {\n throw IllegalStateException_init(('Invalid token: ' + toString(lexer.currentToken)).toString());\n }\n return tmp$_0;\n };\n function JsonParser$parseArray$checkCurrentToken(closure$lexer, this$JsonParser) {\n return function (token) {\n this$JsonParser.require_0(closure$lexer.currentToken, token, '[Arr] ');\n };\n }\n JsonParser.prototype.parseArray_0 = function (lexer) {\n var checkCurrentToken = JsonParser$parseArray$checkCurrentToken(lexer, this);\n var list = ArrayList_init();\n checkCurrentToken(Token$LEFT_BRACKET_getInstance());\n lexer.nextToken();\n while (!equals(lexer.currentToken, Token$RIGHT_BRACKET_getInstance())) {\n if (!list.isEmpty()) {\n checkCurrentToken(Token$COMMA_getInstance());\n lexer.nextToken();\n }list.add_11rb$(this.parseValue_0(lexer));\n }\n checkCurrentToken(Token$RIGHT_BRACKET_getInstance());\n lexer.nextToken();\n return list;\n };\n function JsonParser$parseObject$checkCurrentToken(closure$lexer, this$JsonParser) {\n return function (token) {\n this$JsonParser.require_0(closure$lexer.currentToken, token, '[Obj] ');\n };\n }\n JsonParser.prototype.parseObject_0 = function (lexer) {\n var checkCurrentToken = JsonParser$parseObject$checkCurrentToken(lexer, this);\n var map = LinkedHashMap_init();\n checkCurrentToken(Token$LEFT_BRACE_getInstance());\n lexer.nextToken();\n while (!equals(lexer.currentToken, Token$RIGHT_BRACE_getInstance())) {\n if (!map.isEmpty()) {\n checkCurrentToken(Token$COMMA_getInstance());\n lexer.nextToken();\n }checkCurrentToken(Token$STRING_getInstance());\n var key = unescape(lexer.tokenValue());\n lexer.nextToken();\n checkCurrentToken(Token$COLON_getInstance());\n lexer.nextToken();\n var value = this.parseValue_0(lexer);\n map.put_xwzc9p$(key, value);\n }\n checkCurrentToken(Token$RIGHT_BRACE_getInstance());\n lexer.nextToken();\n return map;\n };\n JsonParser.prototype.require_0 = function (current, expected, messagePrefix) {\n if (messagePrefix === void 0)\n messagePrefix = null;\n if (!equals(current, expected)) {\n throw new JsonParser$JsonException(messagePrefix + ('Expected token: ' + toString(expected) + ', actual: ' + toString(current)));\n }};\n function JsonParser$JsonException(message) {\n Exception_init(message, this);\n this.name = 'JsonParser$JsonException';\n }\n JsonParser$JsonException.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonException',\n interfaces: [Exception]\n };\n JsonParser.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JsonParser',\n interfaces: []\n };\n function JsonSupport() {\n JsonSupport_instance = this;\n }\n JsonSupport.prototype.parseJson_61zpoe$ = function (jsonString) {\n var tmp$;\n return Kotlin.isType(tmp$ = (new JsonParser(jsonString)).parseJson(), MutableMap) ? tmp$ : throwCCE();\n };\n JsonSupport.prototype.formatJson_za3rmp$ = function (o) {\n return (new JsonFormatter()).formatJson_za3rmp$(o);\n };\n JsonSupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'JsonSupport',\n interfaces: []\n };\n var JsonSupport_instance = null;\n function JsonSupport_getInstance() {\n if (JsonSupport_instance === null) {\n new JsonSupport();\n }return JsonSupport_instance;\n }\n function Token(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Token_initFields() {\n Token_initFields = function () {\n };\n Token$LEFT_BRACE_instance = new Token('LEFT_BRACE', 0);\n Token$RIGHT_BRACE_instance = new Token('RIGHT_BRACE', 1);\n Token$LEFT_BRACKET_instance = new Token('LEFT_BRACKET', 2);\n Token$RIGHT_BRACKET_instance = new Token('RIGHT_BRACKET', 3);\n Token$COMMA_instance = new Token('COMMA', 4);\n Token$COLON_instance = new Token('COLON', 5);\n Token$STRING_instance = new Token('STRING', 6);\n Token$NUMBER_instance = new Token('NUMBER', 7);\n Token$TRUE_instance = new Token('TRUE', 8);\n Token$FALSE_instance = new Token('FALSE', 9);\n Token$NULL_instance = new Token('NULL', 10);\n }\n var Token$LEFT_BRACE_instance;\n function Token$LEFT_BRACE_getInstance() {\n Token_initFields();\n return Token$LEFT_BRACE_instance;\n }\n var Token$RIGHT_BRACE_instance;\n function Token$RIGHT_BRACE_getInstance() {\n Token_initFields();\n return Token$RIGHT_BRACE_instance;\n }\n var Token$LEFT_BRACKET_instance;\n function Token$LEFT_BRACKET_getInstance() {\n Token_initFields();\n return Token$LEFT_BRACKET_instance;\n }\n var Token$RIGHT_BRACKET_instance;\n function Token$RIGHT_BRACKET_getInstance() {\n Token_initFields();\n return Token$RIGHT_BRACKET_instance;\n }\n var Token$COMMA_instance;\n function Token$COMMA_getInstance() {\n Token_initFields();\n return Token$COMMA_instance;\n }\n var Token$COLON_instance;\n function Token$COLON_getInstance() {\n Token_initFields();\n return Token$COLON_instance;\n }\n var Token$STRING_instance;\n function Token$STRING_getInstance() {\n Token_initFields();\n return Token$STRING_instance;\n }\n var Token$NUMBER_instance;\n function Token$NUMBER_getInstance() {\n Token_initFields();\n return Token$NUMBER_instance;\n }\n var Token$TRUE_instance;\n function Token$TRUE_getInstance() {\n Token_initFields();\n return Token$TRUE_instance;\n }\n var Token$FALSE_instance;\n function Token$FALSE_getInstance() {\n Token_initFields();\n return Token$FALSE_instance;\n }\n var Token$NULL_instance;\n function Token$NULL_getInstance() {\n Token_initFields();\n return Token$NULL_instance;\n }\n Token.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Token',\n interfaces: [Enum]\n };\n function Token$values() {\n return [Token$LEFT_BRACE_getInstance(), Token$RIGHT_BRACE_getInstance(), Token$LEFT_BRACKET_getInstance(), Token$RIGHT_BRACKET_getInstance(), Token$COMMA_getInstance(), Token$COLON_getInstance(), Token$STRING_getInstance(), Token$NUMBER_getInstance(), Token$TRUE_getInstance(), Token$FALSE_getInstance(), Token$NULL_getInstance()];\n }\n Token.values = Token$values;\n function Token$valueOf(name) {\n switch (name) {\n case 'LEFT_BRACE':\n return Token$LEFT_BRACE_getInstance();\n case 'RIGHT_BRACE':\n return Token$RIGHT_BRACE_getInstance();\n case 'LEFT_BRACKET':\n return Token$LEFT_BRACKET_getInstance();\n case 'RIGHT_BRACKET':\n return Token$RIGHT_BRACKET_getInstance();\n case 'COMMA':\n return Token$COMMA_getInstance();\n case 'COLON':\n return Token$COLON_getInstance();\n case 'STRING':\n return Token$STRING_getInstance();\n case 'NUMBER':\n return Token$NUMBER_getInstance();\n case 'TRUE':\n return Token$TRUE_getInstance();\n case 'FALSE':\n return Token$FALSE_getInstance();\n case 'NULL':\n return Token$NULL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.json.Token.' + name);\n }\n }\n Token.valueOf_61zpoe$ = Token$valueOf;\n var SPECIAL_CHARS;\n var CONTROL_CHARS;\n function escape$appendOutput(closure$output, closure$i, this$escape) {\n return function (str) {\n var tmp$;\n var tmp$_0 = closure$output;\n var tmp$_1;\n if ((tmp$ = closure$output.v) != null)\n tmp$_1 = tmp$;\n else {\n var $receiver = this$escape;\n var endIndex = closure$i.v;\n tmp$_1 = new StringBuilder($receiver.substring(0, endIndex));\n }\n tmp$_0.v = tmp$_1.append_pdl1vj$(str);\n };\n }\n function escape($receiver) {\n var tmp$, tmp$_0, tmp$_1;\n var output = {v: null};\n var i = {v: 0};\n var appendOutput = escape$appendOutput(output, i, $receiver);\n while (i.v < $receiver.length) {\n var ch = $receiver.charCodeAt(i.v);\n switch (ch) {\n case 92:\n appendOutput('\\\\\\\\');\n break;\n case 34:\n appendOutput('\\\\\"');\n break;\n case 10:\n appendOutput('\\\\n');\n break;\n case 13:\n appendOutput('\\\\r');\n break;\n case 9:\n appendOutput('\\\\t');\n break;\n default:if (CONTROL_CHARS.contains_11rb$(toBoxedChar(ch))) {\n appendOutput('\\\\' + 'u' + padStart(toString_0(ch | 0, 16), 4, 48));\n } else\n (tmp$ = output.v) != null ? tmp$.append_s8itvh$(ch) : null;\n break;\n }\n i.v = i.v + 1 | 0;\n }\n return (tmp$_1 = (tmp$_0 = output.v) != null ? tmp$_0.toString() : null) != null ? tmp$_1 : $receiver;\n }\n function unescape($receiver) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var output = {v: null};\n var start = 1;\n var end = $receiver.length - 1 | 0;\n var i = {v: start};\n while (i.v < end) {\n var ch = $receiver.charCodeAt(i.v);\n if (ch === 92) {\n var tmp$_4;\n if ((tmp$ = output.v) != null)\n tmp$_4 = tmp$;\n else {\n var endIndex = i.v;\n tmp$_4 = new StringBuilder($receiver.substring(start, endIndex));\n }\n output.v = tmp$_4;\n var escapedChar = $receiver.charCodeAt((i.v = i.v + 1 | 0, i.v));\n var $receiver_0 = SPECIAL_CHARS;\n var key = toBoxedChar(escapedChar);\n var tmp$_5;\n if ((Kotlin.isType(tmp$_5 = $receiver_0, Map) ? tmp$_5 : throwCCE()).containsKey_11rb$(key)) {\n var $receiver_1 = SPECIAL_CHARS.get_11rb$(toBoxedChar(escapedChar));\n i.v = i.v + 1 | 0;\n tmp$_0 = unboxChar($receiver_1);\n } else if (escapedChar === 117) {\n var startIndex = i.v + 1 | 0;\n var endIndex_0 = i.v + 5 | 0;\n var $receiver_2 = toBoxedChar(toChar(toInt_0($receiver.substring(startIndex, endIndex_0), 16)));\n i.v = i.v + 5 | 0;\n tmp$_0 = unboxChar($receiver_2);\n } else\n throw new JsonParser$JsonException('Invalid escape character: ' + String.fromCharCode(escapedChar));\n output.v.append_s8jyv4$(toBoxedChar(tmp$_0));\n } else {\n (tmp$_1 = output.v) != null ? tmp$_1.append_s8itvh$(ch) : null;\n i.v = i.v + 1 | 0;\n }\n }\n return (tmp$_3 = (tmp$_2 = output.v) != null ? tmp$_2.toString() : null) != null ? tmp$_3 : $receiver.substring(start, end);\n }\n function streamOf(arr) {\n return asSequence(arr);\n }\n function objectsStreamOf$lambda(it) {\n var tmp$;\n return Kotlin.isType(tmp$ = it, Map) ? tmp$ : throwCCE();\n }\n function objectsStreamOf(arr) {\n return map(streamOf(arr), objectsStreamOf$lambda);\n }\n function stringStreamOf$lambda(it) {\n var tmp$;\n return (tmp$ = it) == null || typeof tmp$ === 'string' ? tmp$ : throwCCE();\n }\n function stringStreamOf(arr) {\n return map(streamOf(arr), stringStreamOf$lambda);\n }\n function isBoolean(e) {\n return typeof e === 'boolean';\n }\n function isNumber(e) {\n return Kotlin.isNumber(e);\n }\n function isString(e) {\n return typeof e === 'string';\n }\n function getAsDouble(v) {\n var tmp$;\n return numberToDouble(Kotlin.isNumber(tmp$ = v) ? tmp$ : throwCCE());\n }\n function getAsInt(v) {\n var tmp$;\n return numberToInt(Kotlin.isNumber(tmp$ = v) ? tmp$ : throwCCE());\n }\n function getAsBoolean(v) {\n var tmp$;\n return typeof (tmp$ = v) === 'boolean' ? tmp$ : throwCCE();\n }\n function containsString(obj, key) {\n var v = obj.get_11rb$(key);\n if (v == null || equals(v, isString(v)))\n return true;\n else\n return false;\n }\n function getAsString(e) {\n var tmp$;\n if (e == null)\n return null;\n else\n return typeof (tmp$ = e) === 'string' ? tmp$ : throwCCE();\n }\n function parseEnum(enumStringValue, values) {\n var first$result;\n first$break: do {\n var tmp$;\n for (tmp$ = 0; tmp$ !== values.length; ++tmp$) {\n var element = values[tmp$];\n if (equals_0(element.toString(), enumStringValue, true)) {\n first$result = element;\n break first$break;\n }}\n throw new NoSuchElementException_init_0('Array contains no element matching the predicate.');\n }\n while (false);\n return first$result;\n }\n var parseEnum_0 = defineInlineFunction('lets-plot-base-portable.jetbrains.datalore.base.json.parseEnum_a9gw98$', wrapFunction(function () {\n var parseEnum = _.jetbrains.datalore.base.json.parseEnum_xwn52g$;\n return function (T_0, isT, enumStringValue) {\n return parseEnum(enumStringValue, T_0.values());\n };\n }));\n function formatEnum(enumValue) {\n return enumValue.toString().toLowerCase();\n }\n function put($receiver, key, v) {\n var destination = ArrayList_init_0(collectionSizeOrDefault(v, 10));\n var tmp$;\n tmp$ = v.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(formatEnum(item));\n }\n return put_0($receiver, key, destination);\n }\n function put_0($receiver, key, v) {\n var tmp$ = FluentArray_init();\n var destination = ArrayList_init_0(collectionSizeOrDefault(v, 10));\n var tmp$_0;\n tmp$_0 = v.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item);\n }\n return $receiver.put_wxs67v$(key, tmp$.addStrings_d294za$(destination));\n }\n function getNumber($receiver, key) {\n var tmp$;\n var tmp$_0;\n var tmp$_1;\n if ((Kotlin.isType(tmp$_1 = $receiver, Map) ? tmp$_1 : throwCCE()).get_11rb$(key) == null)\n tmp$_0 = 0.0;\n else {\n var tmp$_2;\n tmp$_0 = Kotlin.isNumber(tmp$ = (Kotlin.isType(tmp$_2 = $receiver, Map) ? tmp$_2 : throwCCE()).get_11rb$(key)) ? tmp$ : throwCCE();\n }\n return tmp$_0;\n }\n function getDouble($receiver, key) {\n return numberToDouble(getNumber($receiver, key));\n }\n function getString($receiver, key) {\n var tmp$;\n var tmp$_0;\n return typeof (tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key)) === 'string' ? tmp$ : throwCCE();\n }\n function getObj($receiver, key) {\n var tmp$;\n var tmp$_0;\n return Kotlin.isType(tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key), Map) ? tmp$ : throwCCE();\n }\n function getArr($receiver, key) {\n var tmp$;\n var tmp$_0;\n return Kotlin.isType(tmp$ = (Kotlin.isType(tmp$_0 = $receiver, Map) ? tmp$_0 : throwCCE()).get_11rb$(key), List) ? tmp$ : throwCCE();\n }\n function ListMap() {\n ListMap$Companion_getInstance();\n this.myData_0 = ListMap$Companion_getInstance().EMPTY_ARRAY_0;\n }\n function ListMap$Companion() {\n ListMap$Companion_instance = this;\n this.EMPTY_ARRAY_0 = Kotlin.newArray(0, null);\n }\n ListMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ListMap$Companion_instance = null;\n function ListMap$Companion_getInstance() {\n if (ListMap$Companion_instance === null) {\n new ListMap$Companion();\n }return ListMap$Companion_instance;\n }\n Object.defineProperty(ListMap.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.size() === 0;\n }\n });\n ListMap.prototype.containsKey_11rb$ = function (key) {\n return this.findByKey_0(key) >= 0;\n };\n ListMap.prototype.remove_11rb$ = function (key) {\n var tmp$;\n var index = this.findByKey_0(key);\n if (index >= 0) {\n var value = this.myData_0[index + 1 | 0];\n this.removeAt_0(index);\n return (tmp$ = value) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n } else {\n return null;\n }\n };\n function ListMap$keySet$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractMutableSet.call(this);\n }\n Object.defineProperty(ListMap$keySet$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n ListMap$keySet$ObjectLiteral.prototype.add_11rb$ = function (element) {\n throw IllegalStateException_init('Not available in keySet');\n };\n function ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return this.this$ListMap.myData_0[index];\n };\n ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$keySet$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$keySet$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$keySet$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractMutableSet]\n };\n ListMap.prototype.keySet = function () {\n return new ListMap$keySet$ObjectLiteral(this);\n };\n function ListMap$values$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractCollection.call(this);\n }\n Object.defineProperty(ListMap$values$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n function ListMap$values$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$values$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return this.this$ListMap.myData_0[index + 1 | 0];\n };\n ListMap$values$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$values$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$values$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$values$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractCollection]\n };\n ListMap.prototype.values = function () {\n return new ListMap$values$ObjectLiteral(this);\n };\n function ListMap$entrySet$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n AbstractSet.call(this);\n }\n Object.defineProperty(ListMap$entrySet$ObjectLiteral.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.this$ListMap.size();\n }\n });\n function ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral(this$ListMap) {\n this.this$ListMap = this$ListMap;\n }\n ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral.prototype.get_za3lpa$ = function (index) {\n return new ListMap$Entry(this.this$ListMap, index);\n };\n ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListMap$IteratorSpec]\n };\n ListMap$entrySet$ObjectLiteral.prototype.iterator = function () {\n return this.this$ListMap.mapIterator_0(new ListMap$entrySet$ObjectLiteral$iterator$ObjectLiteral(this.this$ListMap));\n };\n ListMap$entrySet$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AbstractSet]\n };\n ListMap.prototype.entrySet = function () {\n return new ListMap$entrySet$ObjectLiteral(this);\n };\n ListMap.prototype.size = function () {\n return this.myData_0.length / 2 | 0;\n };\n ListMap.prototype.put_xwzc9p$ = function (key, value) {\n var tmp$;\n var index = this.findByKey_0(key);\n if (index >= 0) {\n var oldValue = this.myData_0[index + 1 | 0];\n this.myData_0[index + 1 | 0] = value;\n return (tmp$ = oldValue) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }var array = Array_0(this.myData_0.length + 2 | 0);\n var tmp$_0;\n tmp$_0 = array.length - 1 | 0;\n for (var i = 0; i <= tmp$_0; i++) {\n array[i] = i < this.myData_0.length ? this.myData_0[i] : null;\n }\n var newArray = array;\n newArray[this.myData_0.length] = key;\n newArray[this.myData_0.length + 1 | 0] = value;\n this.myData_0 = newArray;\n return null;\n };\n ListMap.prototype.get_11rb$ = function (key) {\n var tmp$, tmp$_0;\n var index = this.findByKey_0(key);\n if (index === -1) {\n tmp$_0 = null;\n } else {\n tmp$_0 = (tmp$ = this.myData_0[index + 1 | 0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }\n return tmp$_0;\n };\n ListMap.prototype.toString = function () {\n var builder = StringBuilder_init();\n builder.append_pdl1vj$('{');\n var i = 0;\n while (i < this.myData_0.length) {\n var k = this.myData_0[i];\n var v = this.myData_0[i + 1 | 0];\n if (i !== 0) {\n builder.append_pdl1vj$(',');\n }builder.append_s8jyv4$(k).append_pdl1vj$('=').append_s8jyv4$(v);\n i = i + 2 | 0;\n }\n builder.append_pdl1vj$('}');\n return builder.toString();\n };\n function ListMap$mapIterator$ObjectLiteral(this$ListMap, closure$spec) {\n this.this$ListMap = this$ListMap;\n this.closure$spec = closure$spec;\n this.index_0 = 0;\n this.nextCalled_0 = false;\n }\n ListMap$mapIterator$ObjectLiteral.prototype.hasNext = function () {\n return this.index_0 < this.this$ListMap.myData_0.length;\n };\n ListMap$mapIterator$ObjectLiteral.prototype.next = function () {\n var tmp$;\n if (!this.hasNext()) {\n throw NoSuchElementException_init();\n }this.nextCalled_0 = true;\n var value = (tmp$ = this.closure$spec.get_za3lpa$(this.index_0)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n this.index_0 = this.index_0 + 2 | 0;\n return value;\n };\n ListMap$mapIterator$ObjectLiteral.prototype.remove = function () {\n if (!this.nextCalled_0) {\n throw IllegalStateException_init_0();\n }this.index_0 = this.index_0 - 2 | 0;\n this.this$ListMap.removeAt_0(this.index_0);\n this.nextCalled_0 = false;\n };\n ListMap$mapIterator$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MutableIterator]\n };\n ListMap.prototype.mapIterator_0 = function (spec) {\n return new ListMap$mapIterator$ObjectLiteral(this, spec);\n };\n ListMap.prototype.findByKey_0 = function (key) {\n var i = 0;\n while (i < this.myData_0.length) {\n var k = this.myData_0[i];\n if (equals(key, k)) {\n return i;\n }i = i + 2 | 0;\n }\n return -1;\n };\n ListMap.prototype.removeAt_0 = function (index) {\n if (this.myData_0.length === 2) {\n this.myData_0 = ListMap$Companion_getInstance().EMPTY_ARRAY_0;\n return;\n }var array = Array_0(this.myData_0.length - 2 | 0);\n var tmp$;\n tmp$ = array.length - 1 | 0;\n for (var i = 0; i <= tmp$; i++) {\n var init$result;\n if (i < index) {\n init$result = this.myData_0[i];\n } else {\n init$result = this.myData_0[i + 2 | 0];\n }\n array[i] = init$result;\n }\n var newArray = array;\n this.myData_0 = newArray;\n };\n function ListMap$Entry($outer, myIndex) {\n this.$outer = $outer;\n this.myIndex_0 = myIndex;\n }\n ListMap$Entry.prototype.key = function () {\n var tmp$;\n return (tmp$ = this.$outer.myData_0[this.myIndex_0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n };\n ListMap$Entry.prototype.value = function () {\n var tmp$;\n return (tmp$ = this.$outer.myData_0[this.myIndex_0 + 1 | 0]) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n };\n ListMap$Entry.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Entry',\n interfaces: []\n };\n function ListMap$IteratorSpec() {\n }\n ListMap$IteratorSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'IteratorSpec',\n interfaces: []\n };\n ListMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ListMap',\n interfaces: []\n };\n function Logger() {\n }\n Logger.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Logger',\n interfaces: []\n };\n function PrintlnLogger(name) {\n this.name = name;\n }\n PrintlnLogger.prototype.error_l35kib$ = function (e, message) {\n println('ERR [' + this.name + '] : ' + message());\n };\n PrintlnLogger.prototype.info_h4ejuu$ = function (message) {\n println('INFO [' + this.name + '] : ' + message());\n };\n PrintlnLogger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PrintlnLogger',\n interfaces: [Logger]\n };\n function toRadians(degrees) {\n return degrees * math.PI / 180.0;\n }\n function toDegrees(radians) {\n return radians * 180.0 / math.PI;\n }\n function round_0(v) {\n return round_1(v.x, v.y);\n }\n function ceil(v) {\n return ceil_0(v.x, v.y);\n }\n function round_1(x, y) {\n return new Vector(numberToInt(round(x)), numberToInt(round(y)));\n }\n function ceil_0(x, y) {\n return new Vector(numberToInt(JsMath.ceil(x)), numberToInt(JsMath.ceil(y)));\n }\n function distance(vector, doubleVector) {\n var dx = doubleVector.x - vector.x;\n var dy = doubleVector.y - vector.y;\n var x = dx * dx + dy * dy;\n return JsMath.sqrt(x);\n }\n function ipow($receiver, e) {\n return JsMath.pow($receiver, e);\n }\n function length(v) {\n if (equals(v, L0)) {\n return 1;\n }var len = 0;\n var rem = v;\n while (rem.toNumber() > 0) {\n len = len + 1 | 0;\n rem = rem.div(Kotlin.Long.fromInt(10));\n }\n return len;\n }\n function NumberFormat(spec) {\n NumberFormat$Companion_getInstance();\n this.spec_0 = spec;\n }\n function NumberFormat$Spec(fill, align, sign, symbol, zero, width, comma, precision, type, trim) {\n if (fill === void 0)\n fill = ' ';\n if (align === void 0)\n align = '>';\n if (sign === void 0)\n sign = '-';\n if (width === void 0)\n width = -1;\n if (precision === void 0)\n precision = 6;\n if (type === void 0)\n type = '';\n if (trim === void 0)\n trim = false;\n this.fill = fill;\n this.align = align;\n this.sign = sign;\n this.symbol = symbol;\n this.zero = zero;\n this.width = width;\n this.comma = comma;\n this.precision = precision;\n this.type = type;\n this.trim = trim;\n }\n NumberFormat$Spec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Spec',\n interfaces: []\n };\n NumberFormat$Spec.prototype.component1 = function () {\n return this.fill;\n };\n NumberFormat$Spec.prototype.component2 = function () {\n return this.align;\n };\n NumberFormat$Spec.prototype.component3 = function () {\n return this.sign;\n };\n NumberFormat$Spec.prototype.component4 = function () {\n return this.symbol;\n };\n NumberFormat$Spec.prototype.component5 = function () {\n return this.zero;\n };\n NumberFormat$Spec.prototype.component6 = function () {\n return this.width;\n };\n NumberFormat$Spec.prototype.component7 = function () {\n return this.comma;\n };\n NumberFormat$Spec.prototype.component8 = function () {\n return this.precision;\n };\n NumberFormat$Spec.prototype.component9 = function () {\n return this.type;\n };\n NumberFormat$Spec.prototype.component10 = function () {\n return this.trim;\n };\n NumberFormat$Spec.prototype.copy_xzdl1p$ = function (fill, align, sign, symbol, zero, width, comma, precision, type, trim) {\n return new NumberFormat$Spec(fill === void 0 ? this.fill : fill, align === void 0 ? this.align : align, sign === void 0 ? this.sign : sign, symbol === void 0 ? this.symbol : symbol, zero === void 0 ? this.zero : zero, width === void 0 ? this.width : width, comma === void 0 ? this.comma : comma, precision === void 0 ? this.precision : precision, type === void 0 ? this.type : type, trim === void 0 ? this.trim : trim);\n };\n NumberFormat$Spec.prototype.toString = function () {\n return 'Spec(fill=' + Kotlin.toString(this.fill) + (', align=' + Kotlin.toString(this.align)) + (', sign=' + Kotlin.toString(this.sign)) + (', symbol=' + Kotlin.toString(this.symbol)) + (', zero=' + Kotlin.toString(this.zero)) + (', width=' + Kotlin.toString(this.width)) + (', comma=' + Kotlin.toString(this.comma)) + (', precision=' + Kotlin.toString(this.precision)) + (', type=' + Kotlin.toString(this.type)) + (', trim=' + Kotlin.toString(this.trim)) + ')';\n };\n NumberFormat$Spec.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.fill) | 0;\n result = result * 31 + Kotlin.hashCode(this.align) | 0;\n result = result * 31 + Kotlin.hashCode(this.sign) | 0;\n result = result * 31 + Kotlin.hashCode(this.symbol) | 0;\n result = result * 31 + Kotlin.hashCode(this.zero) | 0;\n result = result * 31 + Kotlin.hashCode(this.width) | 0;\n result = result * 31 + Kotlin.hashCode(this.comma) | 0;\n result = result * 31 + Kotlin.hashCode(this.precision) | 0;\n result = result * 31 + Kotlin.hashCode(this.type) | 0;\n result = result * 31 + Kotlin.hashCode(this.trim) | 0;\n return result;\n };\n NumberFormat$Spec.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.fill, other.fill) && Kotlin.equals(this.align, other.align) && Kotlin.equals(this.sign, other.sign) && Kotlin.equals(this.symbol, other.symbol) && Kotlin.equals(this.zero, other.zero) && Kotlin.equals(this.width, other.width) && Kotlin.equals(this.comma, other.comma) && Kotlin.equals(this.precision, other.precision) && Kotlin.equals(this.type, other.type) && Kotlin.equals(this.trim, other.trim)))));\n };\n function NumberFormat$NumberInfo(number, negative, integerPart, fractionalPart, exponent) {\n NumberFormat$NumberInfo$Companion_getInstance();\n if (number === void 0)\n number = 0.0;\n if (negative === void 0)\n negative = false;\n if (integerPart === void 0)\n integerPart = L0;\n if (fractionalPart === void 0)\n fractionalPart = L0;\n if (exponent === void 0)\n exponent = null;\n this.number = number;\n this.negative = negative;\n this.integerPart = integerPart;\n this.fractionalPart = fractionalPart;\n this.exponent = exponent;\n this.fractionLeadingZeros = 18 - length(this.fractionalPart) | 0;\n this.integerLength = length(this.integerPart);\n this.fractionString = repeat('0', this.fractionLeadingZeros) + trimEnd(this.fractionalPart.toString(), Kotlin.charArrayOf(48));\n }\n function NumberFormat$NumberInfo$Companion() {\n NumberFormat$NumberInfo$Companion_instance = this;\n this.MAX_DECIMALS_0 = 18;\n this.MAX_DECIMAL_VALUE_8be2vx$ = Kotlin.Long.fromNumber(JsMath.pow(10.0, 18));\n }\n function NumberFormat$NumberInfo$Companion$createNumberInfo$lambda(frac, exp) {\n var fraction = frac;\n if (exp > 18) {\n fraction = substring(frac, until(0, frac.length - (exp - 18) | 0));\n }var tmp$ = toLong(fraction);\n var n = coerceAtLeast(18 - exp | 0, 0);\n return tmp$.multiply(Kotlin.Long.fromNumber(JsMath.pow(10.0, n)));\n }\n NumberFormat$NumberInfo$Companion.prototype.createNumberInfo_yjmjg9$ = function (num) {\n var tmp$, tmp$_0, tmp$_1;\n var encodeFraction = NumberFormat$NumberInfo$Companion$createNumberInfo$lambda;\n var tmp$_2 = Regex_init('^(\\\\d+)\\\\.?(\\\\d+)?e?([+-]?\\\\d+)?$');\n var tmp$_3;\n var $receiver = numberToDouble(num);\n if ((tmp$_0 = (tmp$ = tmp$_2.find_905azu$(JsMath.abs($receiver).toString().toLowerCase())) != null ? tmp$.destructured : null) != null)\n tmp$_3 = tmp$_0;\n else {\n throw IllegalStateException_init(('Wrong number: ' + num.toString()).toString());\n }\n var tmp$_4 = tmp$_3;\n var intStr = tmp$_4.match.groupValues.get_za3lpa$(1);\n var fracStr = tmp$_4.match.groupValues.get_za3lpa$(2);\n var exponentString = tmp$_4.match.groupValues.get_za3lpa$(3);\n var exponent = (tmp$_1 = toIntOrNull(exponentString)) != null ? tmp$_1 : 0;\n if (abs(exponent) >= 18) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, toLong(intStr), L0, exponent);\n }if (!(exponent < 18)) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }if (exponent < 0) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, void 0, encodeFraction(intStr + fracStr, abs(exponent) + fracStr.length | 0));\n }if (!(exponent >= 0 && exponent <= 18)) {\n var message_0 = 'Check failed.';\n throw IllegalStateException_init(message_0.toString());\n }if (exponent >= fracStr.length) {\n return NumberFormat$NumberFormat$NumberInfo_init(num, toLong(intStr + fracStr + repeat('0', exponent - fracStr.length | 0)));\n }if (!(exponent >= 0 && exponent < fracStr.length)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }var tmp$_5 = toLong(intStr + substring(fracStr, until(0, exponent)));\n var $receiver_0 = fracStr.substring(exponent);\n return NumberFormat$NumberFormat$NumberInfo_init(num, tmp$_5, encodeFraction($receiver_0, $receiver_0.length));\n };\n NumberFormat$NumberInfo$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NumberFormat$NumberInfo$Companion_instance = null;\n function NumberFormat$NumberInfo$Companion_getInstance() {\n if (NumberFormat$NumberInfo$Companion_instance === null) {\n new NumberFormat$NumberInfo$Companion();\n }return NumberFormat$NumberInfo$Companion_instance;\n }\n NumberFormat$NumberInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumberInfo',\n interfaces: []\n };\n function NumberFormat$NumberFormat$NumberInfo_init(number, integerPart, fractionalPart, exponent, $this) {\n if (integerPart === void 0)\n integerPart = L0;\n if (fractionalPart === void 0)\n fractionalPart = L0;\n if (exponent === void 0)\n exponent = null;\n $this = $this || Object.create(NumberFormat$NumberInfo.prototype);\n var $receiver = numberToDouble(number);\n NumberFormat$NumberInfo.call($this, JsMath.abs($receiver), numberToDouble(number) < 0.0, integerPart, fractionalPart, exponent);\n return $this;\n }\n NumberFormat$NumberInfo.prototype.component1 = function () {\n return this.number;\n };\n NumberFormat$NumberInfo.prototype.component2 = function () {\n return this.negative;\n };\n NumberFormat$NumberInfo.prototype.component3 = function () {\n return this.integerPart;\n };\n NumberFormat$NumberInfo.prototype.component4 = function () {\n return this.fractionalPart;\n };\n NumberFormat$NumberInfo.prototype.component5 = function () {\n return this.exponent;\n };\n NumberFormat$NumberInfo.prototype.copy_xz9h4k$ = function (number, negative, integerPart, fractionalPart, exponent) {\n return new NumberFormat$NumberInfo(number === void 0 ? this.number : number, negative === void 0 ? this.negative : negative, integerPart === void 0 ? this.integerPart : integerPart, fractionalPart === void 0 ? this.fractionalPart : fractionalPart, exponent === void 0 ? this.exponent : exponent);\n };\n NumberFormat$NumberInfo.prototype.toString = function () {\n return 'NumberInfo(number=' + Kotlin.toString(this.number) + (', negative=' + Kotlin.toString(this.negative)) + (', integerPart=' + Kotlin.toString(this.integerPart)) + (', fractionalPart=' + Kotlin.toString(this.fractionalPart)) + (', exponent=' + Kotlin.toString(this.exponent)) + ')';\n };\n NumberFormat$NumberInfo.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.number) | 0;\n result = result * 31 + Kotlin.hashCode(this.negative) | 0;\n result = result * 31 + Kotlin.hashCode(this.integerPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.fractionalPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.exponent) | 0;\n return result;\n };\n NumberFormat$NumberInfo.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.number, other.number) && Kotlin.equals(this.negative, other.negative) && Kotlin.equals(this.integerPart, other.integerPart) && Kotlin.equals(this.fractionalPart, other.fractionalPart) && Kotlin.equals(this.exponent, other.exponent)))));\n };\n function NumberFormat$Output(body, sign, prefix, suffix, padding) {\n if (body === void 0)\n body = new NumberFormat$FormattedNumber();\n if (sign === void 0)\n sign = '';\n if (prefix === void 0)\n prefix = '';\n if (suffix === void 0)\n suffix = '';\n if (padding === void 0)\n padding = '';\n this.body = body;\n this.sign = sign;\n this.prefix = prefix;\n this.suffix = suffix;\n this.padding = padding;\n }\n NumberFormat$Output.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Output',\n interfaces: []\n };\n NumberFormat$Output.prototype.component1 = function () {\n return this.body;\n };\n NumberFormat$Output.prototype.component2 = function () {\n return this.sign;\n };\n NumberFormat$Output.prototype.component3 = function () {\n return this.prefix;\n };\n NumberFormat$Output.prototype.component4 = function () {\n return this.suffix;\n };\n NumberFormat$Output.prototype.component5 = function () {\n return this.padding;\n };\n NumberFormat$Output.prototype.copy_rm1j3u$ = function (body, sign, prefix, suffix, padding) {\n return new NumberFormat$Output(body === void 0 ? this.body : body, sign === void 0 ? this.sign : sign, prefix === void 0 ? this.prefix : prefix, suffix === void 0 ? this.suffix : suffix, padding === void 0 ? this.padding : padding);\n };\n NumberFormat$Output.prototype.toString = function () {\n return 'Output(body=' + Kotlin.toString(this.body) + (', sign=' + Kotlin.toString(this.sign)) + (', prefix=' + Kotlin.toString(this.prefix)) + (', suffix=' + Kotlin.toString(this.suffix)) + (', padding=' + Kotlin.toString(this.padding)) + ')';\n };\n NumberFormat$Output.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.body) | 0;\n result = result * 31 + Kotlin.hashCode(this.sign) | 0;\n result = result * 31 + Kotlin.hashCode(this.prefix) | 0;\n result = result * 31 + Kotlin.hashCode(this.suffix) | 0;\n result = result * 31 + Kotlin.hashCode(this.padding) | 0;\n return result;\n };\n NumberFormat$Output.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.body, other.body) && Kotlin.equals(this.sign, other.sign) && Kotlin.equals(this.prefix, other.prefix) && Kotlin.equals(this.suffix, other.suffix) && Kotlin.equals(this.padding, other.padding)))));\n };\n function NumberFormat$FormattedNumber(integerPart, fractionalPart, exponentialPart) {\n if (integerPart === void 0)\n integerPart = '';\n if (fractionalPart === void 0)\n fractionalPart = '';\n if (exponentialPart === void 0)\n exponentialPart = '';\n this.integerPart = integerPart;\n this.fractionalPart = fractionalPart;\n this.exponentialPart = exponentialPart;\n var tmp$;\n this.fractionalLength = (tmp$ = this.fractionalPart.length === 0 ? 0 : null) != null ? tmp$ : 1 + this.fractionalPart.length | 0;\n this.fullLength = this.integerPart.length + this.fractionalLength + this.exponentialPart.length | 0;\n }\n NumberFormat$FormattedNumber.prototype.toString = function () {\n var tmp$;\n var tmp$_0 = this.integerPart;\n var $receiver = NumberFormat$Companion_getInstance().FRACTION_DELIMITER_0;\n return tmp$_0 + ((tmp$ = this.fractionalPart.length > 0 ? $receiver : null) != null ? tmp$ : '') + this.fractionalPart + this.exponentialPart;\n };\n NumberFormat$FormattedNumber.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FormattedNumber',\n interfaces: []\n };\n NumberFormat$FormattedNumber.prototype.component1 = function () {\n return this.integerPart;\n };\n NumberFormat$FormattedNumber.prototype.component2 = function () {\n return this.fractionalPart;\n };\n NumberFormat$FormattedNumber.prototype.component3 = function () {\n return this.exponentialPart;\n };\n NumberFormat$FormattedNumber.prototype.copy_6hosri$ = function (integerPart, fractionalPart, exponentialPart) {\n return new NumberFormat$FormattedNumber(integerPart === void 0 ? this.integerPart : integerPart, fractionalPart === void 0 ? this.fractionalPart : fractionalPart, exponentialPart === void 0 ? this.exponentialPart : exponentialPart);\n };\n NumberFormat$FormattedNumber.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.integerPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.fractionalPart) | 0;\n result = result * 31 + Kotlin.hashCode(this.exponentialPart) | 0;\n return result;\n };\n NumberFormat$FormattedNumber.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.integerPart, other.integerPart) && Kotlin.equals(this.fractionalPart, other.fractionalPart) && Kotlin.equals(this.exponentialPart, other.exponentialPart)))));\n };\n NumberFormat.prototype.apply_3p81yu$ = function (num) {\n var nonNumberString = this.handleNonNumbers_0(num);\n if (nonNumberString != null) {\n return nonNumberString;\n }var numberInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(num);\n var output = new NumberFormat$Output();\n output = this.computeBody_0(output, numberInfo);\n output = this.trimFraction_0(output);\n output = this.computeSign_0(output, numberInfo);\n output = this.computePrefix_0(output);\n output = this.computeSuffix_0(output);\n if (this.spec_0.comma && !this.spec_0.zero) {\n output = this.applyGroup_0(output);\n }output = this.computePadding_0(output);\n if (this.spec_0.comma && this.spec_0.zero) {\n output = this.applyGroup_0(output);\n }return this.getAlignedString_0(output);\n };\n NumberFormat.prototype.handleNonNumbers_0 = function (num) {\n var tmp$;\n var number = numberToDouble(num);\n if (isNaN_0(number))\n tmp$ = 'NaN';\n else if (number === kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY)\n tmp$ = '-Infinity';\n else if (number === kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY)\n tmp$ = '+Infinity';\n else\n tmp$ = null;\n return tmp$;\n };\n NumberFormat.prototype.getAlignedString_0 = function (output) {\n var tmp$;\n switch (this.spec_0.align) {\n case '<':\n tmp$ = output.sign + output.prefix + output.body + output.suffix + output.padding;\n break;\n case '=':\n tmp$ = output.sign + output.prefix + output.padding + output.body + output.suffix;\n break;\n case '^':\n var stop = output.padding.length / 2 | 0;\n tmp$ = slice(output.padding, until(0, stop)) + output.sign + output.prefix + output.body + output.suffix + slice(output.padding, until(stop, output.padding.length));\n break;\n default:tmp$ = output.padding + output.sign + output.prefix + output.body + output.suffix;\n break;\n }\n return tmp$;\n };\n NumberFormat.prototype.applyGroup_0 = function (output) {\n var tmp$, tmp$_0;\n var $receiver = output.padding;\n var zeroPadding = (tmp$ = this.spec_0.zero ? $receiver : null) != null ? tmp$ : '';\n var body = output.body;\n var fullIntStr = zeroPadding + body.integerPart;\n var x = fullIntStr.length / 3;\n var commas = numberToInt(JsMath.ceil(x) - 1);\n var width = coerceAtLeast(this.spec_0.width - body.fractionalLength - body.exponentialPart.length | 0, body.integerPart.length + commas | 0);\n fullIntStr = NumberFormat$Companion_getInstance().group_0(fullIntStr);\n if (fullIntStr.length > width) {\n var $receiver_0 = fullIntStr;\n var startIndex = fullIntStr.length - width | 0;\n fullIntStr = $receiver_0.substring(startIndex);\n if (startsWith(fullIntStr, 44)) {\n fullIntStr = '0' + fullIntStr;\n }}return output.copy_rm1j3u$(body.copy_6hosri$(fullIntStr), void 0, void 0, void 0, (tmp$_0 = this.spec_0.zero ? '' : null) != null ? tmp$_0 : output.padding);\n };\n NumberFormat.prototype.computeBody_0 = function (res, numberInfo) {\n var tmp$;\n switch (this.spec_0.type) {\n case '%':\n tmp$ = this.toFixedFormat_0(NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(numberInfo.number * 100), this.spec_0.precision);\n break;\n case 'c':\n tmp$ = new NumberFormat$FormattedNumber(numberInfo.number.toString());\n break;\n case 'd':\n tmp$ = this.toSimpleFormat_0(numberInfo, 0);\n break;\n case 'e':\n tmp$ = this.toSimpleFormat_0(this.toExponential_0(numberInfo, this.spec_0.precision), this.spec_0.precision);\n break;\n case 'f':\n tmp$ = this.toFixedFormat_0(numberInfo, this.spec_0.precision);\n break;\n case 'g':\n tmp$ = this.toPrecisionFormat_0(numberInfo, this.spec_0.precision);\n break;\n case 'b':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 2));\n break;\n case 'o':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 8));\n break;\n case 'X':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 16).toUpperCase());\n break;\n case 'x':\n tmp$ = new NumberFormat$FormattedNumber(toString_1(roundToLong(numberInfo.number), 16));\n break;\n case 's':\n tmp$ = this.toSiFormat_0(numberInfo, this.spec_0.precision);\n break;\n default:throw IllegalArgumentException_init('Wrong type: ' + this.spec_0.type);\n }\n var formattedNumber = tmp$;\n return res.copy_rm1j3u$(formattedNumber);\n };\n NumberFormat.prototype.toExponential_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$, tmp$_0;\n var num = numberInfo.number;\n if (num < NumberFormat$Companion_getInstance().TYPE_E_MIN) {\n return new NumberFormat$NumberInfo(0.0);\n }if (equals(numberInfo.integerPart, L0)) {\n tmp$_0 = -(numberInfo.fractionLeadingZeros + 1 | 0) | 0;\n } else {\n tmp$_0 = (numberInfo.integerLength - 1 | 0) + ((tmp$ = numberInfo.exponent) != null ? tmp$ : 0) | 0;\n }\n var e = tmp$_0;\n var n = e;\n var n_0 = num / JsMath.pow(10.0, n);\n var newInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(n_0);\n if (precision > -1) {\n newInfo = this.roundToPrecision_0(newInfo, precision);\n }if (newInfo.integerLength > 1) {\n e = e + 1 | 0;\n newInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(n_0 / 10);\n }return newInfo.copy_xz9h4k$(void 0, void 0, void 0, void 0, e);\n };\n NumberFormat.prototype.toPrecisionFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n if (equals(numberInfo.integerPart, L0)) {\n if (equals(numberInfo.fractionalPart, L0)) {\n return this.toFixedFormat_0(numberInfo, precision - 1 | 0);\n }return this.toFixedFormat_0(numberInfo, precision + numberInfo.fractionLeadingZeros | 0);\n } else {\n if (numberInfo.integerLength > precision) {\n return this.toSimpleFormat_0(this.toExponential_0(numberInfo, precision - 1 | 0), precision - 1 | 0);\n }return this.toFixedFormat_0(numberInfo, precision - numberInfo.integerLength | 0);\n }\n };\n NumberFormat.prototype.toFixedFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = 0;\n var tmp$;\n if (precision <= 0) {\n return new NumberFormat$FormattedNumber(roundToLong(numberInfo.number).toString());\n }var newNumberInfo = this.roundToPrecision_0(numberInfo, precision);\n if (numberInfo.integerLength < newNumberInfo.integerLength) {\n tmp$ = precision - 1 | 0;\n } else {\n tmp$ = precision;\n }\n var completePrecision = tmp$;\n if (equals(newNumberInfo.fractionalPart, L0)) {\n return new NumberFormat$FormattedNumber(newNumberInfo.integerPart.toString(), repeat('0', completePrecision));\n }var fractionString = padEnd(newNumberInfo.fractionString, completePrecision, 48);\n return new NumberFormat$FormattedNumber(newNumberInfo.integerPart.toString(), fractionString);\n };\n NumberFormat.prototype.toSimpleFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$;\n if (numberInfo.exponent != null) {\n var expSign = get_sign(numberInfo.exponent) >= 0 ? '+' : '';\n tmp$ = 'e' + expSign + toString(numberInfo.exponent);\n } else {\n tmp$ = '';\n }\n var exponentString = tmp$;\n var expNumberInfo = NumberFormat$NumberInfo$Companion_getInstance().createNumberInfo_yjmjg9$(numberInfo.integerPart.toNumber() + numberInfo.fractionalPart.toNumber() / NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.toNumber());\n if (precision > -1) {\n var formattedNumber = this.toFixedFormat_0(expNumberInfo, precision);\n return formattedNumber.copy_6hosri$(void 0, void 0, exponentString);\n }var integerString = expNumberInfo.integerPart.toString();\n var fractionString = equals(expNumberInfo.fractionalPart, L0) ? '' : expNumberInfo.fractionString;\n return new NumberFormat$FormattedNumber(integerString, fractionString, exponentString);\n };\n NumberFormat.prototype.toSiFormat_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = -1;\n var tmp$, tmp$_0;\n if (numberInfo.exponent == null) {\n tmp$ = this.toExponential_0(numberInfo, precision - 1 | 0);\n } else {\n tmp$ = numberInfo;\n }\n var expNumberInfo = tmp$;\n var exponent = (tmp$_0 = expNumberInfo.exponent) != null ? tmp$_0 : 0;\n var x = exponent / 3.0;\n var suffixExp = numberToInt(coerceAtMost(coerceAtLeast_0(JsMath.floor(x), -8.0), 8.0)) * 3 | 0;\n var tmp$_1 = NumberFormat$NumberInfo$Companion_getInstance();\n var tmp$_2 = numberInfo.number;\n var n = -suffixExp | 0;\n var newNumberInfo = tmp$_1.createNumberInfo_yjmjg9$(tmp$_2 * JsMath.pow(10.0, n));\n var suffixIndex = 8 + (suffixExp / 3 | 0) | 0;\n var exponentString = NumberFormat$Companion_getInstance().SI_SUFFIXES_0[suffixIndex];\n var formattedNumber = this.toFixedFormat_0(newNumberInfo, precision - newNumberInfo.integerLength | 0);\n return formattedNumber.copy_6hosri$(void 0, void 0, exponentString);\n };\n NumberFormat.prototype.roundToPrecision_0 = function (numberInfo, precision) {\n if (precision === void 0)\n precision = 0;\n var tmp$, tmp$_0, tmp$_1;\n var exp = (tmp$ = numberInfo.exponent) != null ? tmp$ : 0;\n var totalPrecision = precision + exp | 0;\n var fractionalPart;\n var integerPart;\n if (totalPrecision < 0) {\n fractionalPart = L0;\n var intShift = abs(totalPrecision);\n if (numberInfo.integerLength <= intShift) {\n tmp$_0 = L0;\n } else {\n tmp$_0 = numberInfo.integerPart.div(Kotlin.Long.fromNumber(JsMath.pow(10.0, intShift))).multiply(Kotlin.Long.fromNumber(JsMath.pow(10.0, intShift)));\n }\n integerPart = tmp$_0;\n } else {\n var precisionExp = NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.div(Kotlin.Long.fromNumber(JsMath.pow(10.0, totalPrecision)));\n if (equals(precisionExp, L0)) {\n tmp$_1 = numberInfo.fractionalPart;\n } else {\n tmp$_1 = roundToLong(numberInfo.fractionalPart.toNumber() / precisionExp.toNumber()).multiply(precisionExp);\n }\n fractionalPart = tmp$_1;\n integerPart = numberInfo.integerPart;\n if (equals(fractionalPart, NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$)) {\n fractionalPart = L0;\n integerPart = integerPart.inc();\n }}\n var num = integerPart.toNumber() + fractionalPart.toNumber() / NumberFormat$NumberInfo$Companion_getInstance().MAX_DECIMAL_VALUE_8be2vx$.toNumber();\n return numberInfo.copy_xz9h4k$(num, void 0, integerPart, fractionalPart);\n };\n NumberFormat.prototype.trimFraction_0 = function (output) {\n var tmp$ = !this.spec_0.trim;\n if (!tmp$) {\n tmp$ = output.body.fractionalPart.length === 0;\n }if (tmp$) {\n return output;\n }var trimmedFraction = trimEnd(output.body.fractionalPart, Kotlin.charArrayOf(48));\n return output.copy_rm1j3u$(output.body.copy_6hosri$(void 0, trimmedFraction));\n };\n NumberFormat.prototype.computeSign_0 = function (output, numberInfo) {\n var tmp$;\n var $receiver = output.body;\n var $receiver_0 = plus_1(asSequence_0($receiver.integerPart), asSequence_0($receiver.fractionalPart));\n var all$result;\n all$break: do {\n var tmp$_0;\n tmp$_0 = $receiver_0.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (!(unboxChar(element) === 48)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n var isBodyZero = all$result;\n var isNegative = numberInfo.negative && !isBodyZero;\n if (isNegative) {\n tmp$ = '-';\n } else {\n tmp$ = !equals(this.spec_0.sign, '-') ? this.spec_0.sign : '';\n }\n var signStr = tmp$;\n return output.copy_rm1j3u$(void 0, signStr);\n };\n NumberFormat.prototype.computePrefix_0 = function (output) {\n var tmp$;\n switch (this.spec_0.symbol) {\n case '$':\n tmp$ = NumberFormat$Companion_getInstance().CURRENCY_0;\n break;\n case '#':\n tmp$ = indexOf('boxX', this.spec_0.type) > -1 ? '0' + this.spec_0.type.toLowerCase() : '';\n break;\n default:tmp$ = '';\n break;\n }\n var prefix = tmp$;\n return output.copy_rm1j3u$(void 0, void 0, prefix);\n };\n NumberFormat.prototype.computeSuffix_0 = function (res) {\n var tmp$ = void 0;\n var tmp$_0 = void 0;\n var tmp$_1 = void 0;\n var $receiver = NumberFormat$Companion_getInstance().PERCENT_0;\n var $receiver_0 = equals(this.spec_0.type, '%') ? $receiver : null;\n return res.copy_rm1j3u$(tmp$, tmp$_0, tmp$_1, $receiver_0 != null ? $receiver_0 : '');\n };\n NumberFormat.prototype.computePadding_0 = function (output) {\n var length = output.sign.length + output.prefix.length + output.body.fullLength + output.suffix.length | 0;\n var padding = length < this.spec_0.width ? repeat(this.spec_0.fill, this.spec_0.width - length | 0) : '';\n return output.copy_rm1j3u$(void 0, void 0, void 0, void 0, padding);\n };\n function NumberFormat$Companion() {\n NumberFormat$Companion_instance = this;\n this.TYPE_E_MIN = 1.0E-323;\n this.TYPE_S_UPPER_LIMiT = 1.0E40;\n this.TYPE_S_MAX = 1.0E26;\n this.CURRENCY_0 = '$';\n this.PERCENT_0 = '%';\n this.COMMA_0 = ',';\n this.FRACTION_DELIMITER_0 = '.';\n this.FRACTION_DELIMITER_LENGTH_0 = 1;\n this.GROUP_SIZE_0 = 3;\n this.SI_SUFFIXES_0 = ['y', 'z', 'a', 'f', 'p', 'n', '\\xB5', 'm', '', 'k', 'M', 'G', 'T', 'P', 'E', 'Z', 'Y'];\n this.NUMBER_REGEX_0 = Regex_init('^(?:([^{}])?([<>=^]))?([+ -])?([#$])?(0)?(\\\\d+)?(,)?(?:\\\\.(\\\\d+))?([%bcdefgosXx])?$');\n }\n NumberFormat$Companion.prototype.create_61zpoe$ = function (spec) {\n return this.create_xck536$(this.parse_0(spec));\n };\n NumberFormat$Companion.prototype.create_xck536$ = function (spec) {\n var precision = spec.precision;\n var type = spec.type;\n var trim = false;\n if (equals(type, '')) {\n if (precision === -1) {\n precision = 12;\n }type = 'g';\n }if (equals(type, 'g')) {\n trim = true;\n }var zero = spec.zero;\n var fill = spec.fill;\n var align = spec.align;\n if (zero || (equals(fill, '0') && equals(align, '='))) {\n zero = true;\n fill = '0';\n align = '=';\n }return spec.copy_xzdl1p$(fill, align, void 0, void 0, zero, void 0, void 0, precision, type, trim);\n };\n NumberFormat$Companion.prototype.isValidPattern_61zpoe$ = function (spec) {\n return this.NUMBER_REGEX_0.matches_6bul2c$(spec);\n };\n NumberFormat$Companion.prototype.parse_0 = function (spec) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5, tmp$_6, tmp$_7, tmp$_8, tmp$_9, tmp$_10, tmp$_11, tmp$_12, tmp$_13;\n tmp$ = this.NUMBER_REGEX_0.find_905azu$(spec);\n if (tmp$ == null) {\n throw IllegalArgumentException_init('Wrong pattern format');\n }var matchResult = tmp$;\n return new NumberFormat$Spec((tmp$_1 = (tmp$_0 = matchResult.groups.get_za3lpa$(1)) != null ? tmp$_0.value : null) != null ? tmp$_1 : ' ', (tmp$_3 = (tmp$_2 = matchResult.groups.get_za3lpa$(2)) != null ? tmp$_2.value : null) != null ? tmp$_3 : '>', (tmp$_5 = (tmp$_4 = matchResult.groups.get_za3lpa$(3)) != null ? tmp$_4.value : null) != null ? tmp$_5 : '-', (tmp$_7 = (tmp$_6 = matchResult.groups.get_za3lpa$(4)) != null ? tmp$_6.value : null) != null ? tmp$_7 : '', matchResult.groups.get_za3lpa$(5) != null, toInt((tmp$_9 = (tmp$_8 = matchResult.groups.get_za3lpa$(6)) != null ? tmp$_8.value : null) != null ? tmp$_9 : '-1'), matchResult.groups.get_za3lpa$(7) != null, toInt((tmp$_11 = (tmp$_10 = matchResult.groups.get_za3lpa$(8)) != null ? tmp$_10.value : null) != null ? tmp$_11 : '6'), (tmp$_13 = (tmp$_12 = matchResult.groups.get_za3lpa$(9)) != null ? tmp$_12.value : null) != null ? tmp$_13 : '');\n };\n function NumberFormat$Companion$group$lambda(it) {\n return joinToString(it, '');\n }\n NumberFormat$Companion.prototype.group_0 = function (str) {\n var tmp$;\n var $receiver = joinToString_0(map(chunked(asSequence_0(reversed_0(Kotlin.isCharSequence(tmp$ = str) ? tmp$ : throwCCE()).toString()), 3), NumberFormat$Companion$group$lambda), this.COMMA_0);\n var tmp$_0;\n return reversed_0(Kotlin.isCharSequence(tmp$_0 = $receiver) ? tmp$_0 : throwCCE()).toString();\n };\n NumberFormat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NumberFormat$Companion_instance = null;\n function NumberFormat$Companion_getInstance() {\n if (NumberFormat$Companion_instance === null) {\n new NumberFormat$Companion();\n }return NumberFormat$Companion_instance;\n }\n NumberFormat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumberFormat',\n interfaces: []\n };\n function NumberFormat_init(spec, $this) {\n $this = $this || Object.create(NumberFormat.prototype);\n NumberFormat.call($this, NumberFormat$Companion_getInstance().create_61zpoe$(spec));\n return $this;\n }\n function ChildList(myParent) {\n ObservableArrayList.call(this);\n this.myParent_2riath$_0 = myParent;\n this.addListener_n5no9j$(new ChildList_init$ObjectLiteral());\n }\n ChildList.prototype.checkAdd_wxm5ur$ = function (index, item) {\n ObservableArrayList.prototype.checkAdd_wxm5ur$.call(this, index, item);\n if (item.parentProperty().get() != null) {\n throw IllegalArgumentException_init_0();\n }};\n function ChildList$beforeItemAdded$ObjectLiteral(closure$item, this$ChildList) {\n this.closure$item = closure$item;\n this.this$ChildList = this$ChildList;\n }\n function ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral(this$ChildList, closure$index) {\n this.this$ChildList = this$ChildList;\n this.closure$index = closure$index;\n }\n Object.defineProperty(ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.prototype, 'role', {\n configurable: true,\n get: function () {\n return this.this$ChildList;\n }\n });\n ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.prototype.get = function () {\n return this.this$ChildList.size <= this.closure$index ? null : this.this$ChildList.get_za3lpa$(this.closure$index);\n };\n ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Position]\n };\n ChildList$beforeItemAdded$ObjectLiteral.prototype.get = function () {\n var index = this.this$ChildList.indexOf_11rb$(this.closure$item);\n return new ChildList$beforeItemAdded$ObjectLiteral$get$ObjectLiteral(this.this$ChildList, index);\n };\n ChildList$beforeItemAdded$ObjectLiteral.prototype.remove = function () {\n this.this$ChildList.remove_11rb$(this.closure$item);\n };\n ChildList$beforeItemAdded$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionData]\n };\n ChildList.prototype.beforeItemAdded_wxm5ur$ = function (index, item) {\n item.parentProperty().set_11rb$(this.myParent_2riath$_0);\n item.setPositionData_uvvaqs$(new ChildList$beforeItemAdded$ObjectLiteral(item, this));\n };\n ChildList.prototype.checkSet_hu11d4$ = function (index, oldItem, newItem) {\n ObservableArrayList.prototype.checkSet_hu11d4$.call(this, index, oldItem, newItem);\n this.checkRemove_wxm5ur$(index, oldItem);\n this.checkAdd_wxm5ur$(index, newItem);\n };\n ChildList.prototype.beforeItemSet_hu11d4$ = function (index, oldItem, newItem) {\n this.beforeItemAdded_wxm5ur$(index, newItem);\n };\n ChildList.prototype.checkRemove_wxm5ur$ = function (index, item) {\n ObservableArrayList.prototype.checkRemove_wxm5ur$.call(this, index, item);\n if (item.parentProperty().get() !== this.myParent_2riath$_0) {\n throw IllegalArgumentException_init_0();\n }};\n function ChildList_init$ObjectLiteral() {\n CollectionAdapter.call(this);\n }\n ChildList_init$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n ensureNotNull(event.newItem).parentProperty().flush();\n };\n ChildList_init$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n var item = event.oldItem;\n ensureNotNull(item).parentProperty().set_11rb$(null);\n item.setPositionData_uvvaqs$(null);\n item.parentProperty().flush();\n };\n ChildList_init$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionAdapter]\n };\n ChildList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ChildList',\n interfaces: [ObservableArrayList]\n };\n function ChildProperty(myParent) {\n ValueProperty.call(this, null);\n this.myParent_0 = myParent;\n }\n function ChildProperty$set$ObjectLiteral(this$ChildProperty) {\n this.this$ChildProperty = this$ChildProperty;\n }\n function ChildProperty$set$ObjectLiteral$get$ObjectLiteral(this$ChildProperty) {\n this.this$ChildProperty = this$ChildProperty;\n }\n Object.defineProperty(ChildProperty$set$ObjectLiteral$get$ObjectLiteral.prototype, 'role', {\n configurable: true,\n get: function () {\n return this.this$ChildProperty;\n }\n });\n ChildProperty$set$ObjectLiteral$get$ObjectLiteral.prototype.get = function () {\n return this.this$ChildProperty.get();\n };\n ChildProperty$set$ObjectLiteral$get$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Position]\n };\n ChildProperty$set$ObjectLiteral.prototype.get = function () {\n return new ChildProperty$set$ObjectLiteral$get$ObjectLiteral(this.this$ChildProperty);\n };\n ChildProperty$set$ObjectLiteral.prototype.remove = function () {\n this.this$ChildProperty.set_11rb$(null);\n };\n ChildProperty$set$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionData]\n };\n ChildProperty.prototype.set_11rb$ = function (value) {\n var tmp$;\n if (this.get() === value)\n return;\n if (value != null && value.parentProperty().get() != null) {\n throw IllegalStateException_init_0();\n }var oldValue = this.get();\n if (oldValue != null) {\n oldValue.parentProperty().set_11rb$(null);\n oldValue.setPositionData_uvvaqs$(null);\n }if (value != null) {\n value.parentProperty().set_11rb$(this.myParent_0);\n value.setPositionData_uvvaqs$(new ChildProperty$set$ObjectLiteral(this));\n }ValueProperty.prototype.set_11rb$.call(this, value);\n if (oldValue != null) {\n oldValue.parentProperty().flush();\n }(tmp$ = value != null ? value.parentProperty() : null) != null ? (tmp$.flush(), Unit) : null;\n };\n ChildProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ChildProperty',\n interfaces: [ValueProperty]\n };\n function Position() {\n }\n Position.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Position',\n interfaces: []\n };\n function PositionData() {\n }\n PositionData.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PositionData',\n interfaces: []\n };\n function SimpleComposite() {\n this.myParent_eaa9sw$_0 = new DelayedValueProperty();\n this.myPositionData_2io8uh$_0 = null;\n }\n Object.defineProperty(SimpleComposite.prototype, 'position', {\n configurable: true,\n get: function () {\n if (this.myPositionData_2io8uh$_0 == null) {\n throw IllegalStateException_init_0();\n }return ensureNotNull(this.myPositionData_2io8uh$_0).get();\n }\n });\n SimpleComposite.prototype.removeFromParent = function () {\n if (this.myPositionData_2io8uh$_0 == null)\n return;\n ensureNotNull(this.myPositionData_2io8uh$_0).remove();\n };\n SimpleComposite.prototype.parentProperty = function () {\n return this.myParent_eaa9sw$_0;\n };\n SimpleComposite.prototype.setPositionData_uvvaqs$ = function (positionData) {\n this.myPositionData_2io8uh$_0 = positionData;\n };\n SimpleComposite.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimpleComposite',\n interfaces: []\n };\n function CollectionAdapter() {\n }\n CollectionAdapter.prototype.onItemAdded_u8tacu$ = function (event) {\n };\n CollectionAdapter.prototype.onItemSet_u8tacu$ = function (event) {\n this.onItemRemoved_u8tacu$(new CollectionItemEvent(event.oldItem, null, event.index, CollectionItemEvent$EventType$REMOVE_getInstance()));\n this.onItemAdded_u8tacu$(new CollectionItemEvent(null, event.newItem, event.index, CollectionItemEvent$EventType$ADD_getInstance()));\n };\n CollectionAdapter.prototype.onItemRemoved_u8tacu$ = function (event) {\n };\n CollectionAdapter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectionAdapter',\n interfaces: [CollectionListener]\n };\n function CollectionItemEvent(oldItem, newItem, index, type) {\n this.oldItem = oldItem;\n this.newItem = newItem;\n this.index = index;\n this.type = type;\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type && this.oldItem != null || (CollectionItemEvent$EventType$REMOVE_getInstance() === this.type && this.newItem != null)) {\n throw IllegalStateException_init_0();\n }}\n CollectionItemEvent.prototype.dispatch_11rb$ = function (l) {\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type) {\n l.onItemAdded_u8tacu$(this);\n } else if (CollectionItemEvent$EventType$SET_getInstance() === this.type) {\n l.onItemSet_u8tacu$(this);\n } else {\n l.onItemRemoved_u8tacu$(this);\n }\n };\n CollectionItemEvent.prototype.toString = function () {\n var tmp$;\n if (CollectionItemEvent$EventType$ADD_getInstance() === this.type) {\n tmp$ = toString(this.newItem) + ' added at ' + toString(this.index);\n } else if (CollectionItemEvent$EventType$SET_getInstance() === this.type) {\n tmp$ = toString(this.oldItem) + ' replaced with ' + toString(this.newItem) + ' at ' + toString(this.index);\n } else {\n tmp$ = toString(this.oldItem) + ' removed at ' + toString(this.index);\n }\n return tmp$;\n };\n CollectionItemEvent.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, CollectionItemEvent) ? tmp$_0 : throwCCE();\n if (!equals(this.oldItem, other.oldItem))\n return false;\n if (!equals(this.newItem, other.newItem))\n return false;\n if (this.index !== other.index)\n return false;\n if (this.type !== other.type)\n return false;\n return true;\n };\n CollectionItemEvent.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.oldItem) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.newItem) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n result = (31 * result | 0) + this.index | 0;\n result = (31 * result | 0) + this.type.hashCode() | 0;\n return result;\n };\n function CollectionItemEvent$EventType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CollectionItemEvent$EventType_initFields() {\n CollectionItemEvent$EventType_initFields = function () {\n };\n CollectionItemEvent$EventType$ADD_instance = new CollectionItemEvent$EventType('ADD', 0);\n CollectionItemEvent$EventType$SET_instance = new CollectionItemEvent$EventType('SET', 1);\n CollectionItemEvent$EventType$REMOVE_instance = new CollectionItemEvent$EventType('REMOVE', 2);\n }\n var CollectionItemEvent$EventType$ADD_instance;\n function CollectionItemEvent$EventType$ADD_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$ADD_instance;\n }\n var CollectionItemEvent$EventType$SET_instance;\n function CollectionItemEvent$EventType$SET_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$SET_instance;\n }\n var CollectionItemEvent$EventType$REMOVE_instance;\n function CollectionItemEvent$EventType$REMOVE_getInstance() {\n CollectionItemEvent$EventType_initFields();\n return CollectionItemEvent$EventType$REMOVE_instance;\n }\n CollectionItemEvent$EventType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EventType',\n interfaces: [Enum]\n };\n function CollectionItemEvent$EventType$values() {\n return [CollectionItemEvent$EventType$ADD_getInstance(), CollectionItemEvent$EventType$SET_getInstance(), CollectionItemEvent$EventType$REMOVE_getInstance()];\n }\n CollectionItemEvent$EventType.values = CollectionItemEvent$EventType$values;\n function CollectionItemEvent$EventType$valueOf(name) {\n switch (name) {\n case 'ADD':\n return CollectionItemEvent$EventType$ADD_getInstance();\n case 'SET':\n return CollectionItemEvent$EventType$SET_getInstance();\n case 'REMOVE':\n return CollectionItemEvent$EventType$REMOVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.observable.collections.CollectionItemEvent.EventType.' + name);\n }\n }\n CollectionItemEvent$EventType.valueOf_61zpoe$ = CollectionItemEvent$EventType$valueOf;\n CollectionItemEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectionItemEvent',\n interfaces: [ListenerEvent]\n };\n function CollectionListener() {\n }\n CollectionListener.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CollectionListener',\n interfaces: []\n };\n function ObservableCollection() {\n }\n ObservableCollection.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ObservableCollection',\n interfaces: [EventSource, MutableCollection]\n };\n function AbstractObservableList() {\n AbstractMutableList.call(this);\n this.myListeners_ky8jhb$_0 = null;\n }\n AbstractObservableList.prototype.checkAdd_wxm5ur$ = function (index, item) {\n if (index < 0 || index > this.size) {\n throw new IndexOutOfBoundsException('Add: index=' + index + ', size=' + this.size);\n }};\n AbstractObservableList.prototype.checkSet_hu11d4$ = function (index, oldItem, newItem) {\n if (index < 0 || index >= this.size) {\n throw new IndexOutOfBoundsException('Set: index=' + index + ', size=' + this.size);\n }};\n AbstractObservableList.prototype.checkRemove_wxm5ur$ = function (index, item) {\n if (index < 0 || index >= this.size) {\n throw new IndexOutOfBoundsException('Remove: index=' + index + ', size=' + this.size);\n }};\n function AbstractObservableList$add$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$add$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemAdded_u8tacu$(this.closure$event);\n };\n AbstractObservableList$add$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.add_wxm5ur$ = function (index, element) {\n this.checkAdd_wxm5ur$(index, element);\n this.beforeItemAdded_wxm5ur$(index, element);\n var success = false;\n try {\n this.doAdd_wxm5ur$(index, element);\n success = true;\n this.onItemAdd_wxm5ur$(index, element);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(null, element, index, CollectionItemEvent$EventType$ADD_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$add$ObjectLiteral(event));\n }}finally {\n this.afterItemAdded_5x52oa$(index, element, success);\n }\n };\n AbstractObservableList.prototype.beforeItemAdded_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.onItemAdd_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.afterItemAdded_5x52oa$ = function (index, item, success) {\n };\n function AbstractObservableList$set$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$set$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemSet_u8tacu$(this.closure$event);\n };\n AbstractObservableList$set$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.set_wxm5ur$ = function (index, element) {\n var old = this.get_za3lpa$(index);\n this.checkSet_hu11d4$(index, old, element);\n this.beforeItemSet_hu11d4$(index, old, element);\n var success = false;\n try {\n this.doSet_wxm5ur$(index, element);\n success = true;\n this.onItemSet_hu11d4$(index, old, element);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(old, element, index, CollectionItemEvent$EventType$SET_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$set$ObjectLiteral(event));\n }}finally {\n this.afterItemSet_yk9x8x$(index, old, element, success);\n }\n return old;\n };\n AbstractObservableList.prototype.doSet_wxm5ur$ = function (index, item) {\n this.doRemove_za3lpa$(index);\n this.doAdd_wxm5ur$(index, item);\n };\n AbstractObservableList.prototype.beforeItemSet_hu11d4$ = function (index, oldItem, newItem) {\n };\n AbstractObservableList.prototype.onItemSet_hu11d4$ = function (index, oldItem, newItem) {\n };\n AbstractObservableList.prototype.afterItemSet_yk9x8x$ = function (index, oldItem, newItem, success) {\n };\n function AbstractObservableList$removeAt$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n AbstractObservableList$removeAt$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onItemRemoved_u8tacu$(this.closure$event);\n };\n AbstractObservableList$removeAt$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n AbstractObservableList.prototype.removeAt_za3lpa$ = function (index) {\n var item = this.get_za3lpa$(index);\n this.checkRemove_wxm5ur$(index, item);\n this.beforeItemRemoved_wxm5ur$(index, item);\n var success = false;\n try {\n this.doRemove_za3lpa$(index);\n success = true;\n this.onItemRemove_wxm5ur$(index, item);\n if (this.myListeners_ky8jhb$_0 != null) {\n var event = new CollectionItemEvent(item, null, index, CollectionItemEvent$EventType$REMOVE_getInstance());\n ensureNotNull(this.myListeners_ky8jhb$_0).fire_kucmxw$(new AbstractObservableList$removeAt$ObjectLiteral(event));\n }}finally {\n this.afterItemRemoved_5x52oa$(index, item, success);\n }\n return item;\n };\n AbstractObservableList.prototype.beforeItemRemoved_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.onItemRemove_wxm5ur$ = function (index, item) {\n };\n AbstractObservableList.prototype.afterItemRemoved_5x52oa$ = function (index, item, success) {\n };\n function AbstractObservableList$addListener$ObjectLiteral(this$AbstractObservableList) {\n this.this$AbstractObservableList = this$AbstractObservableList;\n Listeners.call(this);\n }\n AbstractObservableList$addListener$ObjectLiteral.prototype.beforeFirstAdded = function () {\n this.this$AbstractObservableList.onListenersAdded();\n };\n AbstractObservableList$addListener$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$AbstractObservableList.myListeners_ky8jhb$_0 = null;\n this.this$AbstractObservableList.onListenersRemoved();\n };\n AbstractObservableList$addListener$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n AbstractObservableList.prototype.addListener_n5no9j$ = function (l) {\n if (this.myListeners_ky8jhb$_0 == null) {\n this.myListeners_ky8jhb$_0 = new AbstractObservableList$addListener$ObjectLiteral(this);\n }return ensureNotNull(this.myListeners_ky8jhb$_0).add_11rb$(l);\n };\n function AbstractObservableList$addHandler$ObjectLiteral(closure$handler) {\n this.closure$handler = closure$handler;\n }\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemSet_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n this.closure$handler.onEvent_11rb$(event);\n };\n AbstractObservableList$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionListener]\n };\n AbstractObservableList.prototype.addHandler_gxwwpc$ = function (handler) {\n var listener = new AbstractObservableList$addHandler$ObjectLiteral(handler);\n return this.addListener_n5no9j$(listener);\n };\n AbstractObservableList.prototype.onListenersAdded = function () {\n };\n AbstractObservableList.prototype.onListenersRemoved = function () {\n };\n AbstractObservableList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractObservableList',\n interfaces: [ObservableList, AbstractMutableList]\n };\n function ObservableArrayList() {\n AbstractObservableList.call(this);\n this.myContainer_2lyzpq$_0 = null;\n }\n Object.defineProperty(ObservableArrayList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myContainer_2lyzpq$_0 == null ? 0 : ensureNotNull(this.myContainer_2lyzpq$_0).size;\n }\n });\n ObservableArrayList.prototype.get_za3lpa$ = function (index) {\n if (this.myContainer_2lyzpq$_0 == null) {\n throw new IndexOutOfBoundsException(index.toString());\n }return ensureNotNull(this.myContainer_2lyzpq$_0).get_za3lpa$(index);\n };\n ObservableArrayList.prototype.doAdd_wxm5ur$ = function (index, item) {\n this.ensureContainerInitialized_mjxwec$_0();\n ensureNotNull(this.myContainer_2lyzpq$_0).add_wxm5ur$(index, item);\n };\n ObservableArrayList.prototype.doSet_wxm5ur$ = function (index, item) {\n ensureNotNull(this.myContainer_2lyzpq$_0).set_wxm5ur$(index, item);\n };\n ObservableArrayList.prototype.doRemove_za3lpa$ = function (index) {\n ensureNotNull(this.myContainer_2lyzpq$_0).removeAt_za3lpa$(index);\n if (ensureNotNull(this.myContainer_2lyzpq$_0).isEmpty()) {\n this.myContainer_2lyzpq$_0 = null;\n }};\n ObservableArrayList.prototype.ensureContainerInitialized_mjxwec$_0 = function () {\n if (this.myContainer_2lyzpq$_0 == null) {\n this.myContainer_2lyzpq$_0 = ArrayList_init_0(1);\n }};\n ObservableArrayList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ObservableArrayList',\n interfaces: [AbstractObservableList]\n };\n function ObservableList() {\n }\n ObservableList.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ObservableList',\n interfaces: [ObservableCollection, MutableList]\n };\n function CompositeEventSource() {\n this.myHandlers_0 = null;\n this.myEventSources_0 = ArrayList_init();\n this.myRegistrations_0 = ArrayList_init();\n }\n CompositeEventSource.prototype.add_5zt0a2$ = function (source) {\n this.myEventSources_0.add_11rb$(source);\n };\n CompositeEventSource.prototype.remove_r5wlyb$ = function (source) {\n var $receiver = this.myEventSources_0;\n var tmp$;\n (Kotlin.isType(tmp$ = $receiver, MutableCollection) ? tmp$ : throwCCE()).remove_11rb$(source);\n };\n function CompositeEventSource$addHandler$ObjectLiteral(this$CompositeEventSource) {\n this.this$CompositeEventSource = this$CompositeEventSource;\n Listeners.call(this);\n }\n CompositeEventSource$addHandler$ObjectLiteral.prototype.beforeFirstAdded = function () {\n var tmp$;\n tmp$ = this.this$CompositeEventSource.myEventSources_0.iterator();\n while (tmp$.hasNext()) {\n var src = tmp$.next();\n this.this$CompositeEventSource.addHandlerTo_0(src);\n }\n };\n CompositeEventSource$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n var tmp$;\n tmp$ = this.this$CompositeEventSource.myRegistrations_0.iterator();\n while (tmp$.hasNext()) {\n var hr = tmp$.next();\n hr.remove();\n }\n this.this$CompositeEventSource.myRegistrations_0.clear();\n this.this$CompositeEventSource.myHandlers_0 = null;\n };\n CompositeEventSource$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n CompositeEventSource.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_0 == null) {\n this.myHandlers_0 = new CompositeEventSource$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_0).add_11rb$(handler);\n };\n function CompositeEventSource$addHandlerTo$ObjectLiteral(this$CompositeEventSource) {\n this.this$CompositeEventSource = this$CompositeEventSource;\n }\n function CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$event);\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n ensureNotNull(this.this$CompositeEventSource.myHandlers_0).fire_kucmxw$(new CompositeEventSource$addHandlerTo$ObjectLiteral$onEvent$ObjectLiteral(event));\n };\n CompositeEventSource$addHandlerTo$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n CompositeEventSource.prototype.addHandlerTo_0 = function (src) {\n this.myRegistrations_0.add_11rb$(src.addHandler_gxwwpc$(new CompositeEventSource$addHandlerTo$ObjectLiteral(this)));\n };\n CompositeEventSource.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeEventSource',\n interfaces: [EventSource]\n };\n function CompositeEventSource_init(sources, $this) {\n $this = $this || Object.create(CompositeEventSource.prototype);\n CompositeEventSource.call($this);\n var tmp$;\n for (tmp$ = 0; tmp$ !== sources.length; ++tmp$) {\n var s = sources[tmp$];\n $this.add_5zt0a2$(s);\n }\n return $this;\n }\n function CompositeEventSource_init_0(sources, $this) {\n $this = $this || Object.create(CompositeEventSource.prototype);\n CompositeEventSource.call($this);\n var tmp$;\n tmp$ = sources.iterator();\n while (tmp$.hasNext()) {\n var s = tmp$.next();\n $this.add_5zt0a2$(s);\n }\n return $this;\n }\n function EventHandler() {\n }\n EventHandler.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventHandler',\n interfaces: []\n };\n function EventSource() {\n }\n EventSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'EventSource',\n interfaces: []\n };\n function EventSources() {\n EventSources_instance = this;\n }\n function EventSources$of$ObjectLiteral(closure$events) {\n this.closure$events = closure$events;\n }\n EventSources$of$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n var tmp$, tmp$_0;\n tmp$ = this.closure$events;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var e = tmp$[tmp$_0];\n handler.onEvent_11rb$(e);\n }\n return Registration$Companion_getInstance().EMPTY;\n };\n EventSources$of$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.of_i5x0yv$ = function (events) {\n return new EventSources$of$ObjectLiteral(events);\n };\n EventSources.prototype.empty_287e2$ = function () {\n return this.composite_xw2ruy$([]);\n };\n EventSources.prototype.composite_xw2ruy$ = function (sources) {\n return CompositeEventSource_init(sources.slice());\n };\n EventSources.prototype.composite_3qo2qg$ = function (sources) {\n return CompositeEventSource_init_0(sources);\n };\n function EventSources$filter$ObjectLiteral(closure$source, closure$pred) {\n this.closure$source = closure$source;\n this.closure$pred = closure$pred;\n }\n function EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral(closure$pred, closure$handler) {\n this.closure$pred = closure$pred;\n this.closure$handler = closure$handler;\n }\n EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n if (this.closure$pred(event)) {\n this.closure$handler.onEvent_11rb$(event);\n }};\n EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n EventSources$filter$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n return this.closure$source.addHandler_gxwwpc$(new EventSources$filter$ObjectLiteral$addHandler$ObjectLiteral(this.closure$pred, handler));\n };\n EventSources$filter$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.filter_ff3xdm$ = function (source, pred) {\n return new EventSources$filter$ObjectLiteral(source, pred);\n };\n EventSources.prototype.map_9hq6p$ = function (src, f) {\n return new MappingEventSource(src, f);\n };\n function EventSources$selectList$ObjectLiteral(closure$list, closure$selector) {\n this.closure$list = closure$list;\n this.closure$selector = closure$selector;\n }\n function EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral(closure$itemRegs, closure$selector, closure$handler) {\n this.closure$itemRegs = closure$itemRegs;\n this.closure$selector = closure$selector;\n this.closure$handler = closure$handler;\n CollectionAdapter.call(this);\n }\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.onItemAdded_u8tacu$ = function (event) {\n this.closure$itemRegs.add_wxm5ur$(event.index, this.closure$selector(event.newItem).addHandler_gxwwpc$(this.closure$handler));\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.prototype.onItemRemoved_u8tacu$ = function (event) {\n this.closure$itemRegs.removeAt_za3lpa$(event.index).remove();\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [CollectionAdapter]\n };\n function EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0(closure$itemRegs, closure$listReg) {\n this.closure$itemRegs = closure$itemRegs;\n this.closure$listReg = closure$listReg;\n Registration.call(this);\n }\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.prototype.doRemove = function () {\n var tmp$;\n tmp$ = this.closure$itemRegs.iterator();\n while (tmp$.hasNext()) {\n var r = tmp$.next();\n r.remove();\n }\n this.closure$listReg.remove();\n };\n EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n EventSources$selectList$ObjectLiteral.prototype.addHandler_gxwwpc$ = function (handler) {\n var tmp$;\n var itemRegs = ArrayList_init();\n tmp$ = this.closure$list.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n itemRegs.add_11rb$(this.closure$selector(item).addHandler_gxwwpc$(handler));\n }\n var listReg = this.closure$list.addListener_n5no9j$(new EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral(itemRegs, this.closure$selector, handler));\n return new EventSources$selectList$ObjectLiteral$addHandler$ObjectLiteral_0(itemRegs, listReg);\n };\n EventSources$selectList$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventSource]\n };\n EventSources.prototype.selectList_jnjwvc$ = function (list, selector) {\n return new EventSources$selectList$ObjectLiteral(list, selector);\n };\n EventSources.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'EventSources',\n interfaces: []\n };\n var EventSources_instance = null;\n function EventSources_getInstance() {\n if (EventSources_instance === null) {\n new EventSources();\n }return EventSources_instance;\n }\n function ListenerCaller() {\n }\n ListenerCaller.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ListenerCaller',\n interfaces: []\n };\n function ListenerEvent() {\n }\n ListenerEvent.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ListenerEvent',\n interfaces: []\n };\n function Listeners() {\n this.myListeners_30lqoe$_0 = null;\n this.myFireDepth_t4vnc0$_0 = 0;\n this.myListenersCount_umrzvt$_0 = 0;\n }\n Object.defineProperty(Listeners.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myListeners_30lqoe$_0 == null || ensureNotNull(this.myListeners_30lqoe$_0).isEmpty();\n }\n });\n function Listeners$add$ObjectLiteral(this$Listeners, closure$l) {\n this.this$Listeners = this$Listeners;\n this.closure$l = closure$l;\n Registration.call(this);\n }\n Listeners$add$ObjectLiteral.prototype.doRemove = function () {\n var tmp$, tmp$_0;\n if (this.this$Listeners.myFireDepth_t4vnc0$_0 > 0) {\n ensureNotNull(this.this$Listeners.myListeners_30lqoe$_0).add_11rb$(new Listeners$ListenerOp(this.closure$l, false));\n } else {\n ensureNotNull(this.this$Listeners.myListeners_30lqoe$_0).remove_11rb$(Kotlin.isType(tmp$ = this.closure$l, Any) ? tmp$ : throwCCE());\n tmp$_0 = this.this$Listeners.myListenersCount_umrzvt$_0;\n this.this$Listeners.myListenersCount_umrzvt$_0 = tmp$_0 - 1 | 0;\n }\n if (this.this$Listeners.isEmpty) {\n this.this$Listeners.afterLastRemoved();\n }};\n Listeners$add$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Listeners.prototype.add_11rb$ = function (l) {\n var tmp$;\n if (this.isEmpty) {\n this.beforeFirstAdded();\n }if (this.myFireDepth_t4vnc0$_0 > 0) {\n ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(new Listeners$ListenerOp(l, true));\n } else {\n if (this.myListeners_30lqoe$_0 == null) {\n this.myListeners_30lqoe$_0 = ArrayList_init_0(1);\n }ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(Kotlin.isType(tmp$ = l, Any) ? tmp$ : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 + 1 | 0;\n }\n return new Listeners$add$ObjectLiteral(this, l);\n };\n Listeners.prototype.fire_kucmxw$ = function (h) {\n var tmp$;\n if (this.isEmpty)\n return;\n this.beforeFire_ul1jia$_0();\n try {\n var size = this.myListenersCount_umrzvt$_0;\n for (var i = 0; i < size; i++) {\n var l = (tmp$ = ensureNotNull(this.myListeners_30lqoe$_0).get_za3lpa$(i)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n if (this.isRemoved_265rjw$_0(l))\n continue;\n try {\n h.call_11rb$(l);\n } catch (t) {\n if (Kotlin.isType(t, Throwable)) {\n ThrowableHandlers_getInstance().instance.handle_tcv7n7$(t);\n } else\n throw t;\n }\n }\n }finally {\n this.afterFire_xwa8xb$_0();\n }\n };\n Listeners.prototype.isRemoved_265rjw$_0 = function (l) {\n var tmp$;\n var size = ensureNotNull(this.myListeners_30lqoe$_0).size;\n for (var i = this.myListenersCount_umrzvt$_0; i < size; i++) {\n var op = Kotlin.isType(tmp$ = ensureNotNull(this.myListeners_30lqoe$_0).get_za3lpa$(i), Listeners$ListenerOp) ? tmp$ : throwCCE();\n if (!op.add && op.listener === l)\n return true;\n }\n return false;\n };\n Listeners.prototype.beforeFirstAdded = function () {\n };\n Listeners.prototype.afterLastRemoved = function () {\n };\n Listeners.prototype.beforeFire_ul1jia$_0 = function () {\n this.myFireDepth_t4vnc0$_0 = this.myFireDepth_t4vnc0$_0 + 1 | 0;\n };\n Listeners.prototype.afterFire_xwa8xb$_0 = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n this.myFireDepth_t4vnc0$_0 = this.myFireDepth_t4vnc0$_0 - 1 | 0;\n if (this.myFireDepth_t4vnc0$_0 === 0) {\n var opsList = ensureNotNull(this.myListeners_30lqoe$_0).subList_vux9f0$(this.myListenersCount_umrzvt$_0, ensureNotNull(this.myListeners_30lqoe$_0).size);\n var ops = copyToArray(opsList);\n opsList.clear();\n for (tmp$ = 0; tmp$ !== ops.length; ++tmp$) {\n var o = ops[tmp$];\n var op = Kotlin.isType(tmp$_0 = o, Listeners$ListenerOp) ? tmp$_0 : throwCCE();\n if (op.add) {\n ensureNotNull(this.myListeners_30lqoe$_0).add_11rb$(Kotlin.isType(tmp$_1 = op.listener, Any) ? tmp$_1 : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 + 1 | 0;\n } else {\n ensureNotNull(this.myListeners_30lqoe$_0).remove_11rb$(Kotlin.isType(tmp$_2 = op.listener, Any) ? tmp$_2 : throwCCE());\n this.myListenersCount_umrzvt$_0 = this.myListenersCount_umrzvt$_0 - 1 | 0;\n }\n }\n if (this.isEmpty) {\n this.afterLastRemoved();\n }}};\n Listeners.prototype.size_8be2vx$ = function () {\n return this.myListeners_30lqoe$_0 == null ? 0 : ensureNotNull(this.myListeners_30lqoe$_0).size;\n };\n function Listeners$ListenerOp(listener, add) {\n this.listener = listener;\n this.add = add;\n }\n Listeners$ListenerOp.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ListenerOp',\n interfaces: []\n };\n Listeners.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Listeners',\n interfaces: []\n };\n function MappingEventSource(mySourceEventSource, myFunction) {\n this.mySourceEventSource_0 = mySourceEventSource;\n this.myFunction_0 = myFunction;\n }\n function MappingEventSource$addHandler$ObjectLiteral(closure$handler, this$MappingEventSource) {\n this.closure$handler = closure$handler;\n this.this$MappingEventSource = this$MappingEventSource;\n }\n MappingEventSource$addHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.closure$handler.onEvent_11rb$(this.this$MappingEventSource.myFunction_0(event));\n };\n MappingEventSource$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n MappingEventSource.prototype.addHandler_gxwwpc$ = function (handler) {\n return this.mySourceEventSource_0.addHandler_gxwwpc$(new MappingEventSource$addHandler$ObjectLiteral(handler, this));\n };\n MappingEventSource.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappingEventSource',\n interfaces: [EventSource]\n };\n function BaseReadableProperty() {\n this.propExpr_4jt19b$_0 = Kotlin.getKClassFromExpression(this).toString();\n }\n Object.defineProperty(BaseReadableProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return this.propExpr_4jt19b$_0;\n }\n });\n BaseReadableProperty.prototype.toString = function () {\n return this.propExpr;\n };\n BaseReadableProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseReadableProperty',\n interfaces: [ReadableProperty]\n };\n function DelayedValueProperty(myValue) {\n if (myValue === void 0)\n myValue = null;\n BaseReadableProperty.call(this);\n this.myValue_0 = myValue;\n this.myHandlers_0 = null;\n this.myPendingEvent_0 = null;\n }\n Object.defineProperty(DelayedValueProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return 'delayedProperty()';\n }\n });\n DelayedValueProperty.prototype.get = function () {\n return this.myValue_0;\n };\n DelayedValueProperty.prototype.set_11rb$ = function (value) {\n if (equals(value, this.myValue_0))\n return;\n var oldValue = this.myValue_0;\n this.myValue_0 = value;\n if (this.myPendingEvent_0 != null) {\n throw IllegalStateException_init_0();\n }this.myPendingEvent_0 = new PropertyChangeEvent(oldValue, this.myValue_0);\n };\n function DelayedValueProperty$flush$ObjectLiteral(this$DelayedValueProperty) {\n this.this$DelayedValueProperty = this$DelayedValueProperty;\n }\n DelayedValueProperty$flush$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(ensureNotNull(this.this$DelayedValueProperty.myPendingEvent_0));\n };\n DelayedValueProperty$flush$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n DelayedValueProperty.prototype.flush = function () {\n if (this.myHandlers_0 != null) {\n ensureNotNull(this.myHandlers_0).fire_kucmxw$(new DelayedValueProperty$flush$ObjectLiteral(this));\n }this.myPendingEvent_0 = null;\n };\n function DelayedValueProperty$addHandler$ObjectLiteral(this$DelayedValueProperty) {\n this.this$DelayedValueProperty = this$DelayedValueProperty;\n Listeners.call(this);\n }\n DelayedValueProperty$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$DelayedValueProperty.myHandlers_0 = null;\n };\n DelayedValueProperty$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n DelayedValueProperty.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_0 == null) {\n this.myHandlers_0 = new DelayedValueProperty$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_0).add_11rb$(handler);\n };\n DelayedValueProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DelayedValueProperty',\n interfaces: [Property, BaseReadableProperty]\n };\n function Property() {\n }\n Property.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Property',\n interfaces: [WritableProperty, ReadableProperty]\n };\n function PropertyBinding() {\n PropertyBinding_instance = this;\n }\n function PropertyBinding$bindOneWay$ObjectLiteral(closure$target) {\n this.closure$target = closure$target;\n }\n PropertyBinding$bindOneWay$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var tmp$;\n this.closure$target.set_11rb$((tmp$ = event.newValue) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE());\n };\n PropertyBinding$bindOneWay$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n PropertyBinding.prototype.bindOneWay_2ov6i0$ = function (source, target) {\n target.set_11rb$(source.get());\n return source.addHandler_gxwwpc$(new PropertyBinding$bindOneWay$ObjectLiteral(target));\n };\n function PropertyBinding$bindTwoWay$UpdatingEventHandler(closure$syncing, closure$target, closure$source, myForward) {\n this.closure$syncing = closure$syncing;\n this.closure$target = closure$target;\n this.closure$source = closure$source;\n this.myForward_0 = myForward;\n }\n PropertyBinding$bindTwoWay$UpdatingEventHandler.prototype.onEvent_11rb$ = function (event) {\n if (this.closure$syncing.get())\n return;\n this.closure$syncing.set_11rb$(true);\n try {\n if (this.myForward_0) {\n this.closure$target.set_11rb$(this.closure$source.get());\n } else {\n this.closure$source.set_11rb$(this.closure$target.get());\n }\n }finally {\n this.closure$syncing.set_11rb$(false);\n }\n };\n PropertyBinding$bindTwoWay$UpdatingEventHandler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'UpdatingEventHandler',\n interfaces: [EventHandler]\n };\n PropertyBinding.prototype.bindTwoWay_ejkotq$ = function (source, target) {\n var syncing = new ValueProperty(false);\n target.set_11rb$(source.get());\n return new CompositeRegistration([source.addHandler_gxwwpc$(new PropertyBinding$bindTwoWay$UpdatingEventHandler(syncing, target, source, true)), target.addHandler_gxwwpc$(new PropertyBinding$bindTwoWay$UpdatingEventHandler(syncing, target, source, false))]);\n };\n PropertyBinding.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PropertyBinding',\n interfaces: []\n };\n var PropertyBinding_instance = null;\n function PropertyBinding_getInstance() {\n if (PropertyBinding_instance === null) {\n new PropertyBinding();\n }return PropertyBinding_instance;\n }\n function PropertyChangeEvent(oldValue, newValue) {\n this.oldValue = oldValue;\n this.newValue = newValue;\n }\n PropertyChangeEvent.prototype.toString = function () {\n return toString(this.oldValue) + ' -> ' + toString(this.newValue);\n };\n PropertyChangeEvent.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, PropertyChangeEvent) ? tmp$_0 : throwCCE();\n if (!equals(this.oldValue, other.oldValue))\n return false;\n if (!equals(this.newValue, other.newValue))\n return false;\n return true;\n };\n PropertyChangeEvent.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.oldValue) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.newValue) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n return result;\n };\n PropertyChangeEvent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PropertyChangeEvent',\n interfaces: []\n };\n function ReadableProperty() {\n }\n ReadableProperty.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ReadableProperty',\n interfaces: [Supplier, EventSource]\n };\n function ValueProperty(myValue) {\n BaseReadableProperty.call(this);\n this.myValue_x0fqz2$_0 = myValue;\n this.myHandlers_sdxgfs$_0 = null;\n }\n Object.defineProperty(ValueProperty.prototype, 'propExpr', {\n configurable: true,\n get: function () {\n return 'valueProperty()';\n }\n });\n ValueProperty.prototype.get = function () {\n return this.myValue_x0fqz2$_0;\n };\n ValueProperty.prototype.set_11rb$ = function (value) {\n if (equals(value, this.myValue_x0fqz2$_0))\n return;\n var oldValue = this.myValue_x0fqz2$_0;\n this.myValue_x0fqz2$_0 = value;\n this.fireEvents_ym4swk$_0(oldValue, this.myValue_x0fqz2$_0);\n };\n function ValueProperty$fireEvents$ObjectLiteral(closure$event) {\n this.closure$event = closure$event;\n }\n ValueProperty$fireEvents$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$event);\n };\n ValueProperty$fireEvents$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n ValueProperty.prototype.fireEvents_ym4swk$_0 = function (oldValue, newValue) {\n if (this.myHandlers_sdxgfs$_0 != null) {\n var event = new PropertyChangeEvent(oldValue, newValue);\n ensureNotNull(this.myHandlers_sdxgfs$_0).fire_kucmxw$(new ValueProperty$fireEvents$ObjectLiteral(event));\n }};\n function ValueProperty$addHandler$ObjectLiteral(this$ValueProperty) {\n this.this$ValueProperty = this$ValueProperty;\n Listeners.call(this);\n }\n ValueProperty$addHandler$ObjectLiteral.prototype.afterLastRemoved = function () {\n this.this$ValueProperty.myHandlers_sdxgfs$_0 = null;\n };\n ValueProperty$addHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Listeners]\n };\n ValueProperty.prototype.addHandler_gxwwpc$ = function (handler) {\n if (this.myHandlers_sdxgfs$_0 == null) {\n this.myHandlers_sdxgfs$_0 = new ValueProperty$addHandler$ObjectLiteral(this);\n }return ensureNotNull(this.myHandlers_sdxgfs$_0).add_11rb$(handler);\n };\n ValueProperty.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ValueProperty',\n interfaces: [Property, BaseReadableProperty]\n };\n function WritableProperty() {\n }\n WritableProperty.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WritableProperty',\n interfaces: []\n };\n function RandomGaussian(random) {\n this.random = random;\n this.nextNextGaussian_0 = 0.0;\n this.haveNextNextGaussian_0 = false;\n }\n RandomGaussian.prototype.nextGaussian = function () {\n if (this.haveNextNextGaussian_0) {\n this.haveNextNextGaussian_0 = false;\n return this.nextNextGaussian_0;\n } else {\n var v1;\n var v2;\n var s;\n do {\n v1 = 2 * this.random.nextDouble() - 1;\n v2 = 2 * this.random.nextDouble() - 1;\n s = v1 * v1 + v2 * v2;\n }\n while (s >= 1 || s === 0.0);\n var x = s;\n var x_0 = -2 * JsMath.log(x) / s;\n var multiplier = JsMath.sqrt(x_0);\n this.nextNextGaussian_0 = v2 * multiplier;\n this.haveNextNextGaussian_0 = true;\n return v1 * multiplier;\n }\n };\n RandomGaussian.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomGaussian',\n interfaces: []\n };\n function RandomString() {\n RandomString_instance = this;\n }\n RandomString.prototype.randomString_za3lpa$ = function (len) {\n var alphabet = plus_2(plus_0(new CharRange(97, 122), new CharRange(65, 90)), new CharRange(48, 57));\n var list = ArrayList_init_0(len);\n for (var index = 0; index < len; index++) {\n list.add_11rb$(random(alphabet, Random.Default));\n }\n return joinToString(list, '');\n };\n RandomString.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'RandomString',\n interfaces: []\n };\n var RandomString_instance = null;\n function RandomString_getInstance() {\n if (RandomString_instance === null) {\n new RandomString();\n }return RandomString_instance;\n }\n function CompositeRegistration(regs) {\n Registration.call(this);\n this.myRegistrations_0 = null;\n this.myRegistrations_0 = arrayListOf(regs.slice());\n }\n Object.defineProperty(CompositeRegistration.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myRegistrations_0.isEmpty();\n }\n });\n CompositeRegistration.prototype.add_3xv6fb$ = function (r) {\n this.myRegistrations_0.add_11rb$(r);\n return this;\n };\n CompositeRegistration.prototype.add_4wx45g$ = function (rs) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== rs.length; ++tmp$) {\n var r = rs[tmp$];\n this.add_3xv6fb$(r);\n }\n return this;\n };\n CompositeRegistration.prototype.doRemove = function () {\n for (var i = this.myRegistrations_0.size - 1 | 0; i >= 0; i--) {\n this.myRegistrations_0.get_za3lpa$(i).remove();\n }\n this.myRegistrations_0.clear();\n };\n CompositeRegistration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeRegistration',\n interfaces: [Registration]\n };\n function Disposable() {\n }\n Disposable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Disposable',\n interfaces: []\n };\n function Registration() {\n Registration$Companion_getInstance();\n this.myRemoved_guv51v$_0 = false;\n }\n Registration.prototype.remove = function () {\n if (this.myRemoved_guv51v$_0) {\n throw IllegalStateException_init('Registration already removed');\n }this.myRemoved_guv51v$_0 = true;\n this.doRemove();\n };\n Registration.prototype.dispose = function () {\n this.remove();\n };\n function Registration$EmptyRegistration() {\n Registration.call(this);\n }\n Registration$EmptyRegistration.prototype.doRemove = function () {\n };\n Registration$EmptyRegistration.prototype.remove = function () {\n };\n Registration$EmptyRegistration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EmptyRegistration',\n interfaces: [Registration]\n };\n function Registration$Companion() {\n Registration$Companion_instance = this;\n this.EMPTY = new Registration$EmptyRegistration();\n }\n function Registration$Companion$from$ObjectLiteral(closure$disposable) {\n this.closure$disposable = closure$disposable;\n Registration.call(this);\n }\n Registration$Companion$from$ObjectLiteral.prototype.doRemove = function () {\n this.closure$disposable.dispose();\n };\n Registration$Companion$from$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Registration$Companion.prototype.from_gg3y3y$ = function (disposable) {\n return new Registration$Companion$from$ObjectLiteral(disposable);\n };\n function Registration$Companion$from$ObjectLiteral_0(closure$disposables) {\n this.closure$disposables = closure$disposables;\n Registration.call(this);\n }\n Registration$Companion$from$ObjectLiteral_0.prototype.doRemove = function () {\n var tmp$, tmp$_0;\n tmp$ = this.closure$disposables;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var d = tmp$[tmp$_0];\n d.dispose();\n }\n };\n Registration$Companion$from$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Registration$Companion.prototype.from_h9hjd7$ = function (disposables) {\n return new Registration$Companion$from$ObjectLiteral_0(disposables);\n };\n Registration$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Registration$Companion_instance = null;\n function Registration$Companion_getInstance() {\n if (Registration$Companion_instance === null) {\n new Registration$Companion();\n }return Registration$Companion_instance;\n }\n Registration.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Registration',\n interfaces: [Disposable]\n };\n function ThrowableHandler() {\n }\n ThrowableHandler.prototype.handle_tcv7n7$ = function (t) {\n throw t;\n };\n ThrowableHandler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ThrowableHandler',\n interfaces: []\n };\n function ThrowableHandlers() {\n ThrowableHandlers_instance = this;\n this.instance = new ThrowableHandler();\n }\n ThrowableHandlers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ThrowableHandlers',\n interfaces: []\n };\n var ThrowableHandlers_instance = null;\n function ThrowableHandlers_getInstance() {\n if (ThrowableHandlers_instance === null) {\n new ThrowableHandlers();\n }return ThrowableHandlers_instance;\n }\n var EARTH_RADIUS;\n var MIN_LONGITUDE;\n var MAX_LONGITUDE;\n var FULL_LONGITUDE;\n var MIN_LATITUDE;\n var MAX_LATITUDE;\n var FULL_LATITUDE;\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function get_start($receiver) {\n return $receiver.first;\n }\n function get_end($receiver) {\n return $receiver.second;\n }\n function GeoBoundingBoxCalculator(myMapRect, myLoopX, myLoopY) {\n GeoBoundingBoxCalculator$Companion_getInstance();\n this.myMapRect_0 = myMapRect;\n this.myLoopX_0 = myLoopX;\n this.myLoopY_0 = myLoopY;\n }\n GeoBoundingBoxCalculator.prototype.calculateBoundingBox_qpfwx8$ = function (xSegments, ySegments) {\n var xRange_0 = this.calculateBoundingRange_0(xSegments, xRange(this.myMapRect_0), this.myLoopX_0);\n var yRange_0 = this.calculateBoundingRange_0(ySegments, yRange(this.myMapRect_0), this.myLoopY_0);\n return Rect_init(xRange_0.lowerEnd, yRange_0.lowerEnd, GeoBoundingBoxCalculator$Companion_getInstance().length_0(xRange_0), GeoBoundingBoxCalculator$Companion_getInstance().length_0(yRange_0));\n };\n GeoBoundingBoxCalculator.prototype.calculateBoundingRange_0 = function (segments, mapRange, loop) {\n var tmp$;\n if (loop) {\n tmp$ = GeoBoundingBoxCalculator$Companion_getInstance().calculateLoopLimitRange_h7l5yb$(segments, mapRange);\n } else {\n tmp$ = new ClosedRange(ensureNotNull(minOrNull(map(segments, getPropertyCallableRef('start', 1, function ($receiver) {\n return get_start($receiver);\n })))), ensureNotNull(maxOrNull(map(segments, getPropertyCallableRef('end', 1, function ($receiver) {\n return get_end($receiver);\n })))));\n }\n return tmp$;\n };\n function GeoBoundingBoxCalculator$Companion() {\n GeoBoundingBoxCalculator$Companion_instance = this;\n }\n function GeoBoundingBoxCalculator$Companion$calculateLoopLimitRange$lambda(closure$mapRange) {\n return function (it) {\n return LongitudeSegment$Companion_getInstance().splitSegment_6y0v78$(get_start(it), get_end(it), closure$mapRange.lowerEnd, closure$mapRange.upperEnd);\n };\n }\n GeoBoundingBoxCalculator$Companion.prototype.calculateLoopLimitRange_h7l5yb$ = function (segments, mapRange) {\n return this.normalizeCenter_0(this.invertRange_0(this.findMaxGapBetweenRanges_0(flatten(map(segments, GeoBoundingBoxCalculator$Companion$calculateLoopLimitRange$lambda(mapRange))), this.length_0(mapRange)), this.length_0(mapRange)), mapRange);\n };\n GeoBoundingBoxCalculator$Companion.prototype.normalizeCenter_0 = function (range, mapRange) {\n var tmp$;\n if (mapRange.contains_mef7kx$((range.upperEnd + range.lowerEnd) / 2)) {\n tmp$ = range;\n } else {\n tmp$ = new ClosedRange(range.lowerEnd - this.length_0(mapRange), range.upperEnd - this.length_0(mapRange));\n }\n return tmp$;\n };\n GeoBoundingBoxCalculator$Companion.prototype.findMaxGapBetweenRanges_0 = function (ranges, width) {\n var sortedRanges = sortedWith(ranges, new Comparator(compareBy$lambda(getPropertyCallableRef('lowerEnd', 1, function ($receiver) {\n return $receiver.lowerEnd;\n }))));\n var selector = getPropertyCallableRef('upperEnd', 1, function ($receiver) {\n return $receiver.upperEnd;\n });\n var maxByOrNull$result;\n maxByOrNull$break: do {\n var iterator = sortedRanges.iterator();\n if (!iterator.hasNext()) {\n maxByOrNull$result = null;\n break maxByOrNull$break;\n }var maxElem = iterator.next();\n if (!iterator.hasNext()) {\n maxByOrNull$result = maxElem;\n break maxByOrNull$break;\n }var maxValue = selector(maxElem);\n do {\n var e = iterator.next();\n var v = selector(e);\n if (Kotlin.compareTo(maxValue, v) < 0) {\n maxElem = e;\n maxValue = v;\n }}\n while (iterator.hasNext());\n maxByOrNull$result = maxElem;\n }\n while (false);\n var prevUpper = ensureNotNull(maxByOrNull$result).upperEnd;\n var nextLower = first_1(sortedRanges).lowerEnd;\n var a = width + nextLower;\n var b = prevUpper;\n var gapRight = JsMath.max(a, b);\n var maxGapRange = new ClosedRange(prevUpper, gapRight);\n var it = sortedRanges.iterator();\n prevUpper = it.next().upperEnd;\n while (it.hasNext()) {\n var range = it.next();\n nextLower = range.lowerEnd;\n if (nextLower > prevUpper && nextLower - prevUpper > this.length_0(maxGapRange)) {\n maxGapRange = new ClosedRange(prevUpper, nextLower);\n }var a_0 = prevUpper;\n var b_0 = range.upperEnd;\n prevUpper = JsMath.max(a_0, b_0);\n }\n return maxGapRange;\n };\n function GeoBoundingBoxCalculator$Companion$invertRange$safeRange(first, second) {\n return new ClosedRange(JsMath.min(first, second), JsMath.max(first, second));\n }\n GeoBoundingBoxCalculator$Companion.prototype.invertRange_0 = function (range, width) {\n var tmp$;\n var safeRange = GeoBoundingBoxCalculator$Companion$invertRange$safeRange;\n if (this.length_0(range) > width)\n tmp$ = new ClosedRange(range.lowerEnd, range.lowerEnd);\n else if (range.upperEnd > width)\n tmp$ = safeRange(range.upperEnd - width, range.lowerEnd);\n else\n tmp$ = safeRange(range.upperEnd, width + range.lowerEnd);\n return tmp$;\n };\n GeoBoundingBoxCalculator$Companion.prototype.length_0 = function ($receiver) {\n return $receiver.upperEnd - $receiver.lowerEnd;\n };\n GeoBoundingBoxCalculator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeoBoundingBoxCalculator$Companion_instance = null;\n function GeoBoundingBoxCalculator$Companion_getInstance() {\n if (GeoBoundingBoxCalculator$Companion_instance === null) {\n new GeoBoundingBoxCalculator$Companion();\n }return GeoBoundingBoxCalculator$Companion_instance;\n }\n GeoBoundingBoxCalculator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeoBoundingBoxCalculator',\n interfaces: []\n };\n function makeSegments$lambda(closure$start, closure$end) {\n return function (it) {\n return new Pair(closure$start(it), closure$end(it));\n };\n }\n function makeSegments(start, end, size) {\n return map(asSequence(until(0, size)), makeSegments$lambda(start, end));\n }\n function geoRectsBBox$lambda(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).startLongitude();\n };\n }\n function geoRectsBBox$lambda_0(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).endLongitude();\n };\n }\n function geoRectsBBox$lambda_1(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).minLatitude();\n };\n }\n function geoRectsBBox$lambda_2(closure$rectangles) {\n return function (it) {\n return closure$rectangles.get_za3lpa$(it).maxLatitude();\n };\n }\n function geoRectsBBox($receiver, rectangles) {\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(geoRectsBBox$lambda(rectangles), geoRectsBBox$lambda_0(rectangles), rectangles.size), makeSegments(geoRectsBBox$lambda_1(rectangles), geoRectsBBox$lambda_2(rectangles), rectangles.size));\n }\n function pointsBBox$lambda(closure$xyCoords) {\n return function (index) {\n return closure$xyCoords.get_za3lpa$(2 * index | 0);\n };\n }\n function pointsBBox$lambda_0(closure$xyCoords) {\n return function (index) {\n return closure$xyCoords.get_za3lpa$((2 * index | 0) + 1 | 0);\n };\n }\n function pointsBBox($receiver, xyCoords) {\n if (!(xyCoords.size % 2 === 0)) {\n var message = 'Longitude-Latitude list is not even-numbered.';\n throw IllegalArgumentException_init(message.toString());\n }var x = pointsBBox$lambda(xyCoords);\n var y = pointsBBox$lambda_0(xyCoords);\n var i = xyCoords.size / 2 | 0;\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(x, x, i), makeSegments(y, y, i));\n }\n function union$lambda(closure$rectangles) {\n return function (it) {\n return get_left(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_0(closure$rectangles) {\n return function (it) {\n return get_right(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_1(closure$rectangles) {\n return function (it) {\n return get_top(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union$lambda_2(closure$rectangles) {\n return function (it) {\n return get_bottom(closure$rectangles.get_za3lpa$(it));\n };\n }\n function union($receiver, rectangles) {\n return $receiver.calculateBoundingBox_qpfwx8$(makeSegments(union$lambda(rectangles), union$lambda_0(rectangles), rectangles.size), makeSegments(union$lambda_1(rectangles), union$lambda_2(rectangles), rectangles.size));\n }\n function GeoJson() {\n GeoJson_instance = this;\n this.LON_INDEX_0 = 0;\n this.LAT_INDEX_0 = 1;\n }\n GeoJson.prototype.parse_gdwatq$ = function (geoJson, handler) {\n var geoObj = FluentObject_init(JsonSupport_getInstance().parseJson_61zpoe$(geoJson));\n var $receiver = new SimpleFeature$Consumer();\n handler($receiver);\n var geometryConsumer = $receiver;\n (new GeoJson$Parser()).parse_m8ausf$(geoObj, geometryConsumer);\n };\n GeoJson.prototype.parse_4mzk4t$ = function (geoJson, consumer) {\n var geoObj = FluentObject_init(JsonSupport_getInstance().parseJson_61zpoe$(geoJson));\n (new GeoJson$Parser()).parse_m8ausf$(geoObj, consumer);\n };\n function GeoJson$Parser() {\n }\n function GeoJson$Parser$parse$lambda(it) {\n return equals(it.getString_61zpoe$('type'), 'Feature');\n }\n function GeoJson$Parser$parse$lambda_0(it) {\n return it.getObject_61zpoe$('geometry');\n }\n GeoJson$Parser.prototype.parse_m8ausf$ = function (obj, handler) {\n var type = obj.getString_61zpoe$('type');\n switch (type) {\n case 'FeatureCollection':\n if (!obj.contains_61zpoe$('features')) {\n var message = \"GeoJson: Missing 'features' in 'FeatureCollection'\";\n throw IllegalArgumentException_init(message.toString());\n }\n var tmp$;\n tmp$ = map(filter(obj.getArray_61zpoe$('features').fluentObjectStream(), GeoJson$Parser$parse$lambda), GeoJson$Parser$parse$lambda_0).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.parse_m8ausf$(element, handler);\n }\n\n break;\n case 'GeometryCollection':\n if (!obj.contains_61zpoe$('geometries')) {\n var message_0 = \"GeoJson: Missing 'geometries' in 'GeometryCollection'\";\n throw IllegalArgumentException_init(message_0.toString());\n }\n var tmp$_0;\n tmp$_0 = obj.getArray_61zpoe$('geometries').fluentObjectStream().iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n this.parse_m8ausf$(element_0, handler);\n }\n\n break;\n default:if (!obj.contains_61zpoe$('coordinates')) {\n var message_1 = \"GeoJson: Missing 'coordinates' in \" + type;\n throw IllegalArgumentException_init(message_1.toString());\n }\n var coordinates = obj.getArray_61zpoe$('coordinates');\n switch (type) {\n case 'Point':\n var $receiver = this.parsePoint_0(coordinates);\n getCallableRef('onPoint', function ($receiver, p1) {\n return $receiver.onPoint_adb7pk$(p1), Unit;\n }.bind(null, handler))($receiver);\n break;\n case 'LineString':\n var $receiver_0 = this.parseLineString_0(coordinates);\n getCallableRef('onLineString', function ($receiver, p1) {\n return $receiver.onLineString_1u6eph$(p1), Unit;\n }.bind(null, handler))($receiver_0);\n break;\n case 'Polygon':\n var $receiver_1 = this.parsePolygon_0(coordinates);\n getCallableRef('onPolygon', function ($receiver, p1) {\n return $receiver.onPolygon_z3kb82$(p1), Unit;\n }.bind(null, handler))($receiver_1);\n break;\n case 'MultiPoint':\n var $receiver_2 = this.parseMultiPoint_0(coordinates);\n getCallableRef('onMultiPoint', function ($receiver, p1) {\n return $receiver.onMultiPoint_oeq1z7$(p1), Unit;\n }.bind(null, handler))($receiver_2);\n break;\n case 'MultiLineString':\n var $receiver_3 = this.parseMultiLineString_0(coordinates);\n getCallableRef('onMultiLineString', function ($receiver, p1) {\n return $receiver.onMultiLineString_6n275e$(p1), Unit;\n }.bind(null, handler))($receiver_3);\n break;\n case 'MultiPolygon':\n var $receiver_4 = this.parseMultiPolygon_0(coordinates);\n getCallableRef('onMultiPolygon', function ($receiver, p1) {\n return $receiver.onMultiPolygon_a0zxnd$(p1), Unit;\n }.bind(null, handler))($receiver_4);\n break;\n default:throw IllegalStateException_init(('Not support GeoJson type: ' + type).toString());\n }\n\n break;\n }\n };\n GeoJson$Parser.prototype.parsePoint_0 = function (jsonPoint) {\n return explicitVec(jsonPoint.getDouble_za3lpa$(0), jsonPoint.getDouble_za3lpa$(1));\n };\n GeoJson$Parser.prototype.parseLineString_0 = function (jsonLineString) {\n return new LineString(this.mapArray_0(jsonLineString, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseRing_0 = function (jsonRing) {\n return new Ring(this.mapArray_0(jsonRing, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiPoint_0 = function (jsonMultiPoint) {\n return new MultiPoint(this.mapArray_0(jsonMultiPoint, getCallableRef('parsePoint', function ($receiver, p1) {\n return $receiver.parsePoint_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parsePolygon_0 = function (jsonPolygon) {\n return new Polygon(this.mapArray_0(jsonPolygon, getCallableRef('parseRing', function ($receiver, p1) {\n return $receiver.parseRing_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiLineString_0 = function (jsonLineStrings) {\n return new MultiLineString(this.mapArray_0(jsonLineStrings, getCallableRef('parseLineString', function ($receiver, p1) {\n return $receiver.parseLineString_0(p1);\n }.bind(null, this))));\n };\n GeoJson$Parser.prototype.parseMultiPolygon_0 = function (jsonMultiPolygon) {\n return new MultiPolygon(this.mapArray_0(jsonMultiPolygon, getCallableRef('parsePolygon', function ($receiver, p1) {\n return $receiver.parsePolygon_0(p1);\n }.bind(null, this))));\n };\n function GeoJson$Parser$mapArray$lambda(closure$f) {\n return function (it) {\n var tmp$;\n return closure$f(FluentArray_init_0(Kotlin.isType(tmp$ = it, List) ? tmp$ : throwCCE()));\n };\n }\n GeoJson$Parser.prototype.mapArray_0 = function ($receiver, f) {\n return toList_1(map($receiver.stream(), GeoJson$Parser$mapArray$lambda(f)));\n };\n GeoJson$Parser.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Parser',\n interfaces: []\n };\n GeoJson.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeoJson',\n interfaces: []\n };\n var GeoJson_instance = null;\n function GeoJson_getInstance() {\n if (GeoJson_instance === null) {\n new GeoJson();\n }return GeoJson_instance;\n }\n function GeoRectangle(startLongitude, minLatitude, endLongitude, maxLatitude) {\n this.myLongitudeSegment_0 = null;\n this.myLatitudeRange_0 = null;\n if (!(minLatitude <= maxLatitude)) {\n var message = 'Invalid latitude range: [' + minLatitude + '..' + maxLatitude + ']';\n throw IllegalArgumentException_init(message.toString());\n }this.myLongitudeSegment_0 = new LongitudeSegment(startLongitude, endLongitude);\n this.myLatitudeRange_0 = new ClosedRange(minLatitude, maxLatitude);\n }\n Object.defineProperty(GeoRectangle.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myLongitudeSegment_0.isEmpty && this.latitudeRangeIsEmpty_0(this.myLatitudeRange_0);\n }\n });\n GeoRectangle.prototype.latitudeRangeIsEmpty_0 = function (range) {\n return range.upperEnd === range.lowerEnd;\n };\n GeoRectangle.prototype.startLongitude = function () {\n return this.myLongitudeSegment_0.start();\n };\n GeoRectangle.prototype.endLongitude = function () {\n return this.myLongitudeSegment_0.end();\n };\n GeoRectangle.prototype.minLatitude = function () {\n return this.myLatitudeRange_0.lowerEnd;\n };\n GeoRectangle.prototype.maxLatitude = function () {\n return this.myLatitudeRange_0.upperEnd;\n };\n GeoRectangle.prototype.encloses_emtjl$ = function (rect) {\n return this.myLongitudeSegment_0.encloses_moa7dh$(rect.myLongitudeSegment_0) && this.myLatitudeRange_0.encloses_d226ot$(rect.myLatitudeRange_0);\n };\n GeoRectangle.prototype.splitByAntiMeridian = function () {\n var tmp$;\n var rects = ArrayList_init();\n var longitudeRanges = this.myLongitudeSegment_0.splitByAntiMeridian();\n tmp$ = longitudeRanges.iterator();\n while (tmp$.hasNext()) {\n var longitudeRange = tmp$.next();\n rects.add_11rb$(newSpanRectangle(new Vec(longitudeRange.lowerEnd, this.myLatitudeRange_0.lowerEnd), new Vec(longitudeRange.upperEnd, this.myLatitudeRange_0.upperEnd)));\n }\n return rects;\n };\n GeoRectangle.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, GeoRectangle) ? tmp$_0 : throwCCE();\n return ((tmp$_1 = this.myLongitudeSegment_0) != null ? tmp$_1.equals(ensureNotNull(that).myLongitudeSegment_0) : null) && ((tmp$_2 = this.myLatitudeRange_0) != null ? tmp$_2.equals(that.myLatitudeRange_0) : null);\n };\n GeoRectangle.prototype.hashCode = function () {\n return hashCode(listOf([this.myLongitudeSegment_0, this.myLatitudeRange_0]));\n };\n GeoRectangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeoRectangle',\n interfaces: []\n };\n function LonLat() {\n }\n LonLat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LonLat',\n interfaces: []\n };\n var EARTH_RECT;\n function limitLon(lon) {\n var tmp$ = MIN_LONGITUDE;\n var b = MAX_LONGITUDE;\n var b_0 = JsMath.min(lon, b);\n return JsMath.max(tmp$, b_0);\n }\n function limitLat(lat) {\n var tmp$ = MIN_LATITUDE;\n var b = MAX_LATITUDE;\n var b_0 = JsMath.min(lat, b);\n return JsMath.max(tmp$, b_0);\n }\n function normalizeLon(lon) {\n var result = lon - numberToInt(lon / FULL_LONGITUDE) * FULL_LONGITUDE;\n if (result > MAX_LONGITUDE) {\n result -= FULL_LONGITUDE;\n }if (result < -MAX_LONGITUDE) {\n result += FULL_LONGITUDE;\n }return result;\n }\n var BBOX_CALCULATOR;\n function convertToGeoRectangle(rect) {\n var left;\n var right;\n if (get_width(rect) < get_width(EARTH_RECT)) {\n left = normalizeLon(get_left(rect));\n right = normalizeLon(get_right(rect));\n } else {\n left = get_left(EARTH_RECT);\n right = get_right(EARTH_RECT);\n }\n return new GeoRectangle(left, limitLat(get_top(rect)), right, limitLat(get_bottom(rect)));\n }\n function calculateQuadKeys(rect, zoom) {\n var flippedRect = Rect_init(get_left(rect), -get_bottom(rect), get_width(rect), get_height(rect));\n return calculateQuadKeys_0(EARTH_RECT, flippedRect, zoom, getCallableRef('QuadKey', function (p1) {\n return new QuadKey(p1);\n }));\n }\n function LongitudeSegment(start, end) {\n LongitudeSegment$Companion_getInstance();\n this.myStart_0 = limitLon(start);\n this.myEnd_0 = limitLon(end);\n }\n Object.defineProperty(LongitudeSegment.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myEnd_0 === this.myStart_0;\n }\n });\n LongitudeSegment.prototype.start = function () {\n return this.myStart_0;\n };\n LongitudeSegment.prototype.end = function () {\n return this.myEnd_0;\n };\n LongitudeSegment.prototype.length = function () {\n return this.myEnd_0 - this.myStart_0 + (this.myEnd_0 < this.myStart_0 ? FULL_LONGITUDE : 0.0);\n };\n LongitudeSegment.prototype.encloses_moa7dh$ = function (longitudeSegment) {\n var tmp$;\n var externalRanges = this.splitByAntiMeridian();\n var internalRanges = longitudeSegment.splitByAntiMeridian();\n tmp$ = internalRanges.iterator();\n while (tmp$.hasNext()) {\n var internalRange = tmp$.next();\n if (!LongitudeSegment$Companion_getInstance().disjointRangesEncloseRange_0(externalRanges, internalRange)) {\n return false;\n }}\n return true;\n };\n LongitudeSegment.prototype.invert = function () {\n return new LongitudeSegment(this.myEnd_0, this.myStart_0);\n };\n LongitudeSegment.prototype.splitByAntiMeridian = function () {\n return LongitudeSegment$Companion_getInstance().splitSegment_6y0v78$(this.myStart_0, this.myEnd_0, MIN_LONGITUDE, MAX_LONGITUDE);\n };\n LongitudeSegment.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = Kotlin.isType(tmp$_0 = other, LongitudeSegment) ? tmp$_0 : throwCCE();\n return equals(that.myStart_0, this.myStart_0) && equals(that.myEnd_0, this.myEnd_0);\n };\n LongitudeSegment.prototype.hashCode = function () {\n return hashCode(listOf([this.myStart_0, this.myEnd_0]));\n };\n function LongitudeSegment$Companion() {\n LongitudeSegment$Companion_instance = this;\n }\n LongitudeSegment$Companion.prototype.splitSegment_6y0v78$ = function (start, end, min, max) {\n var tmp$;\n if (start <= end) {\n tmp$ = listOf_0(new ClosedRange(start, end));\n } else {\n tmp$ = listOf([new ClosedRange(start, max), new ClosedRange(min, end)]);\n }\n return tmp$;\n };\n LongitudeSegment$Companion.prototype.disjointRangesEncloseRange_0 = function (ranges, internalRange) {\n var tmp$;\n tmp$ = ranges.iterator();\n while (tmp$.hasNext()) {\n var range = tmp$.next();\n if (range.encloses_d226ot$(internalRange)) {\n return true;\n }}\n return false;\n };\n LongitudeSegment$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LongitudeSegment$Companion_instance = null;\n function LongitudeSegment$Companion_getInstance() {\n if (LongitudeSegment$Companion_instance === null) {\n new LongitudeSegment$Companion();\n }return LongitudeSegment$Companion_instance;\n }\n LongitudeSegment.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LongitudeSegment',\n interfaces: []\n };\n function MercatorUtils() {\n MercatorUtils_instance = this;\n this.MAX_LONGITUDE_0 = 180.0;\n this.MAX_LATITUDE_0 = 85.0511287798;\n this.VALID_LONGITUDE_RANGE = new ClosedRange(-this.MAX_LONGITUDE_0, this.MAX_LONGITUDE_0);\n this.VALID_LATITUDE_RANGE = new ClosedRange(-this.MAX_LATITUDE_0, this.MAX_LATITUDE_0);\n }\n MercatorUtils.prototype.getMercatorX_14dthe$ = function (lon) {\n return toRadians(lon) * EARTH_RADIUS;\n };\n MercatorUtils.prototype.getMercatorY_14dthe$ = function (lat) {\n var lat_0 = this.normalizeLat_0(lat);\n var x = math.PI / 4 + toRadians(lat_0) / 2;\n var x_0 = JsMath.tan(x);\n return JsMath.log(x_0) * EARTH_RADIUS;\n };\n MercatorUtils.prototype.getLongitude_14dthe$ = function (x) {\n return toDegrees(x / EARTH_RADIUS);\n };\n MercatorUtils.prototype.getLatitude_14dthe$ = function (y) {\n var x = y / EARTH_RADIUS;\n var x_0 = JsMath.exp(x);\n return this.normalizeLat_0(toDegrees((JsMath.atan(x_0) - math.PI / 4) * 2));\n };\n MercatorUtils.prototype.checkLon_14dthe$ = function (lon) {\n return this.VALID_LONGITUDE_RANGE.contains_mef7kx$(lon);\n };\n MercatorUtils.prototype.checkLat_14dthe$ = function (lat) {\n return this.VALID_LATITUDE_RANGE.contains_mef7kx$(lat);\n };\n MercatorUtils.prototype.normalizeLat_0 = function (lat) {\n var tmp$ = -this.MAX_LATITUDE_0;\n var b = this.MAX_LATITUDE_0;\n var b_0 = JsMath.min(lat, b);\n return JsMath.max(tmp$, b_0);\n };\n MercatorUtils.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MercatorUtils',\n interfaces: []\n };\n var MercatorUtils_instance = null;\n function MercatorUtils_getInstance() {\n if (MercatorUtils_instance === null) {\n new MercatorUtils();\n }return MercatorUtils_instance;\n }\n function QuadKey(key) {\n this.key = key;\n this.length = this.key.length;\n }\n QuadKey.prototype.plus_vnxxg4$ = function (other) {\n return new QuadKey(this.key + other.key);\n };\n QuadKey.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuadKey',\n interfaces: []\n };\n QuadKey.prototype.component1 = function () {\n return this.key;\n };\n QuadKey.prototype.copy_61zpoe$ = function (key) {\n return new QuadKey(key === void 0 ? this.key : key);\n };\n QuadKey.prototype.toString = function () {\n return 'QuadKey(key=' + Kotlin.toString(this.key) + ')';\n };\n QuadKey.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.key) | 0;\n return result;\n };\n QuadKey.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && Kotlin.equals(this.key, other.key))));\n };\n function computeRect$lambda(closure$flippedY) {\n return function (it) {\n return closure$flippedY;\n };\n }\n function computeRect($receiver) {\n var origin = computeOrigin($receiver, EARTH_RECT);\n var dimension = div_0(EARTH_RECT.dimension, calulateQuadsCount($receiver.length));\n var flippedY = minus_0(get_scalarBottom(EARTH_RECT), minus_0(plus_5(get_scalarY(origin), get_scalarY(dimension)), get_scalarTop(EARTH_RECT)));\n return new Rect(transform(origin, void 0, computeRect$lambda(flippedY)), dimension);\n }\n function computeRect_0($receiver, rect) {\n return projectRect($receiver, rect);\n }\n function projectRect($receiver, rect) {\n var origin = projectOrigin($receiver, rect);\n var dimension = div_0(rect.dimension, calulateQuadsCount($receiver.length));\n return new Rect(origin, dimension);\n }\n function zoom($receiver) {\n return $receiver.length;\n }\n function computeOrigin($receiver, mapRect) {\n return projectOrigin($receiver, mapRect);\n }\n function projectOrigin($receiver, mapRect) {\n var tmp$;\n var left = get_scalarLeft(mapRect);\n var top = get_scalarTop(mapRect);\n var width = get_scalarWidth(mapRect);\n var height = get_scalarHeight(mapRect);\n tmp$ = iterator($receiver.key);\n while (tmp$.hasNext()) {\n var quadrant = unboxChar(tmp$.next());\n width = div_2(width, 2.0);\n height = div_2(height, 2.0);\n if (quadrant === 49 || quadrant === 51) {\n left = plus_5(left, width);\n }if (quadrant === 50 || quadrant === 51) {\n top = plus_5(top, height);\n }}\n return newVec(left, top);\n }\n function calulateQuadsCount(zoom) {\n return numberToInt(ipow(2, zoom));\n }\n function calculateQuadKeys$calcQuadNum(value, range, tileCount) {\n var position = (value - range.lowerEnd) / (range.upperEnd - range.lowerEnd);\n var a = position * tileCount;\n var b = tileCount - 1 | 0;\n var b_0 = JsMath.min(a, b);\n return numberToInt(JsMath.max(0.0, b_0));\n }\n function calculateQuadKeys_0(mapRect, viewRect, zoom, quadKeyFactory) {\n var quadKeys = HashSet_init_0();\n var tileCount = calulateQuadsCount(zoom);\n var calcQuadNum = calculateQuadKeys$calcQuadNum;\n var xmin = calcQuadNum(get_left(viewRect), xRange(mapRect), tileCount);\n var xmax = calcQuadNum(get_right(viewRect), xRange(mapRect), tileCount);\n var ymin = calcQuadNum(get_top(viewRect), yRange(mapRect), tileCount);\n var ymax = calcQuadNum(get_bottom(viewRect), yRange(mapRect), tileCount);\n for (var x = xmin; x <= xmax; x++) {\n for (var y = ymin; y <= ymax; y++) {\n var $receiver = quadKeyFactory(xyToKey(x, y, zoom));\n getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_11rb$(p1);\n }.bind(null, quadKeys))($receiver);\n }\n }\n return quadKeys;\n }\n function xyToKey(x, y, zoom) {\n var key = '';\n for (var i = zoom; i >= 1; i--) {\n var digit = 48;\n var mask = 1 << i - 1;\n if ((x & mask) !== 0) {\n digit = Kotlin.charInc(digit);\n }if ((y & mask) !== 0) {\n digit = toChar(digit + 2);\n }key += String.fromCharCode(digit);\n }\n return key;\n }\n function SimpleFeature() {\n SimpleFeature_instance = this;\n }\n function SimpleFeature$GeometryConsumer() {\n }\n SimpleFeature$GeometryConsumer.prototype.onPoint_adb7pk$ = function (point) {\n throw IllegalStateException_init(\"Point isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onLineString_1u6eph$ = function (lineString) {\n throw IllegalStateException_init(\"LineString isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onPolygon_z3kb82$ = function (polygon) {\n throw IllegalStateException_init(\"Polygon isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiPoint_oeq1z7$ = function (multiPoint) {\n throw IllegalStateException_init(\"MultiPoint isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiLineString_6n275e$ = function (multiLineString) {\n throw IllegalStateException_init(\"MultiLineString isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.prototype.onMultiPolygon_a0zxnd$ = function (multipolygon) {\n throw IllegalStateException_init(\"MultiPolygon isn't supported\".toString());\n };\n SimpleFeature$GeometryConsumer.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeometryConsumer',\n interfaces: []\n };\n function SimpleFeature$Consumer(onPoint, onLineString, onPolygon, onMultiPoint, onMultiLineString, onMultiPolygon) {\n if (onPoint === void 0)\n onPoint = SimpleFeature$SimpleFeature$Consumer_init$lambda;\n if (onLineString === void 0)\n onLineString = SimpleFeature$SimpleFeature$Consumer_init$lambda_0;\n if (onPolygon === void 0)\n onPolygon = SimpleFeature$SimpleFeature$Consumer_init$lambda_1;\n if (onMultiPoint === void 0)\n onMultiPoint = SimpleFeature$SimpleFeature$Consumer_init$lambda_2;\n if (onMultiLineString === void 0)\n onMultiLineString = SimpleFeature$SimpleFeature$Consumer_init$lambda_3;\n if (onMultiPolygon === void 0)\n onMultiPolygon = SimpleFeature$SimpleFeature$Consumer_init$lambda_4;\n this.onPoint = onPoint;\n this.onLineString = onLineString;\n this.onPolygon = onPolygon;\n this.onMultiPoint = onMultiPoint;\n this.onMultiLineString = onMultiLineString;\n this.onMultiPolygon = onMultiPolygon;\n }\n SimpleFeature$Consumer.prototype.onPoint_adb7pk$ = function (point) {\n this.onPoint(point);\n };\n SimpleFeature$Consumer.prototype.onLineString_1u6eph$ = function (lineString) {\n this.onLineString(lineString);\n };\n SimpleFeature$Consumer.prototype.onPolygon_z3kb82$ = function (polygon) {\n this.onPolygon(polygon);\n };\n SimpleFeature$Consumer.prototype.onMultiPoint_oeq1z7$ = function (multiPoint) {\n this.onMultiPoint(multiPoint);\n };\n SimpleFeature$Consumer.prototype.onMultiLineString_6n275e$ = function (multiLineString) {\n this.onMultiLineString(multiLineString);\n };\n SimpleFeature$Consumer.prototype.onMultiPolygon_a0zxnd$ = function (multipolygon) {\n this.onMultiPolygon(multipolygon);\n };\n function SimpleFeature$SimpleFeature$Consumer_init$lambda(it) {\n throw IllegalStateException_init(\"Point isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_0(it) {\n throw IllegalStateException_init(\"LineString isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_1(it) {\n throw IllegalStateException_init(\"Polygon isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_2(it) {\n throw IllegalStateException_init(\"MultiPoint isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_3(it) {\n throw IllegalStateException_init(\"MultiLineString isn't supported\".toString());\n }\n function SimpleFeature$SimpleFeature$Consumer_init$lambda_4(it) {\n throw IllegalStateException_init(\"MultiPolygon isn't supported\".toString());\n }\n SimpleFeature$Consumer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Consumer',\n interfaces: [SimpleFeature$GeometryConsumer]\n };\n function SimpleFeature$GeometryType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function SimpleFeature$GeometryType_initFields() {\n SimpleFeature$GeometryType_initFields = function () {\n };\n SimpleFeature$GeometryType$POINT_instance = new SimpleFeature$GeometryType('POINT', 0);\n SimpleFeature$GeometryType$LINE_STRING_instance = new SimpleFeature$GeometryType('LINE_STRING', 1);\n SimpleFeature$GeometryType$POLYGON_instance = new SimpleFeature$GeometryType('POLYGON', 2);\n SimpleFeature$GeometryType$MULTI_POINT_instance = new SimpleFeature$GeometryType('MULTI_POINT', 3);\n SimpleFeature$GeometryType$MULTI_LINE_STRING_instance = new SimpleFeature$GeometryType('MULTI_LINE_STRING', 4);\n SimpleFeature$GeometryType$MULTI_POLYGON_instance = new SimpleFeature$GeometryType('MULTI_POLYGON', 5);\n SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance = new SimpleFeature$GeometryType('GEOMETRY_COLLECTION', 6);\n }\n var SimpleFeature$GeometryType$POINT_instance;\n function SimpleFeature$GeometryType$POINT_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$POINT_instance;\n }\n var SimpleFeature$GeometryType$LINE_STRING_instance;\n function SimpleFeature$GeometryType$LINE_STRING_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$LINE_STRING_instance;\n }\n var SimpleFeature$GeometryType$POLYGON_instance;\n function SimpleFeature$GeometryType$POLYGON_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$POLYGON_instance;\n }\n var SimpleFeature$GeometryType$MULTI_POINT_instance;\n function SimpleFeature$GeometryType$MULTI_POINT_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_POINT_instance;\n }\n var SimpleFeature$GeometryType$MULTI_LINE_STRING_instance;\n function SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_LINE_STRING_instance;\n }\n var SimpleFeature$GeometryType$MULTI_POLYGON_instance;\n function SimpleFeature$GeometryType$MULTI_POLYGON_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$MULTI_POLYGON_instance;\n }\n var SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance;\n function SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance() {\n SimpleFeature$GeometryType_initFields();\n return SimpleFeature$GeometryType$GEOMETRY_COLLECTION_instance;\n }\n SimpleFeature$GeometryType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeometryType',\n interfaces: [Enum]\n };\n function SimpleFeature$GeometryType$values() {\n return [SimpleFeature$GeometryType$POINT_getInstance(), SimpleFeature$GeometryType$LINE_STRING_getInstance(), SimpleFeature$GeometryType$POLYGON_getInstance(), SimpleFeature$GeometryType$MULTI_POINT_getInstance(), SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance(), SimpleFeature$GeometryType$MULTI_POLYGON_getInstance(), SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance()];\n }\n SimpleFeature$GeometryType.values = SimpleFeature$GeometryType$values;\n function SimpleFeature$GeometryType$valueOf(name) {\n switch (name) {\n case 'POINT':\n return SimpleFeature$GeometryType$POINT_getInstance();\n case 'LINE_STRING':\n return SimpleFeature$GeometryType$LINE_STRING_getInstance();\n case 'POLYGON':\n return SimpleFeature$GeometryType$POLYGON_getInstance();\n case 'MULTI_POINT':\n return SimpleFeature$GeometryType$MULTI_POINT_getInstance();\n case 'MULTI_LINE_STRING':\n return SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance();\n case 'MULTI_POLYGON':\n return SimpleFeature$GeometryType$MULTI_POLYGON_getInstance();\n case 'GEOMETRY_COLLECTION':\n return SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.spatial.SimpleFeature.GeometryType.' + name);\n }\n }\n SimpleFeature$GeometryType.valueOf_61zpoe$ = SimpleFeature$GeometryType$valueOf;\n SimpleFeature.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SimpleFeature',\n interfaces: []\n };\n var SimpleFeature_instance = null;\n function SimpleFeature_getInstance() {\n if (SimpleFeature_instance === null) {\n new SimpleFeature();\n }return SimpleFeature_instance;\n }\n function StringFormat(pattern, formatType) {\n StringFormat$Companion_getInstance();\n this.pattern_0 = pattern;\n this.formatType = formatType;\n this.myNumberFormatters_0 = null;\n var tmp$;\n var initNumberFormat = StringFormat_init$initNumberFormat;\n switch (this.formatType.name) {\n case 'NUMBER_FORMAT':\n tmp$ = listOf_0(initNumberFormat(this.pattern_0));\n break;\n case 'STRING_FORMAT':\n tmp$ = toList_1(map(map(StringFormat$Companion_getInstance().BRACES_REGEX_0.findAll_905azu$(this.pattern_0), StringFormat_init$lambda), StringFormat_init$lambda_0(initNumberFormat)));\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n this.myNumberFormatters_0 = tmp$;\n this.argsNumber = this.myNumberFormatters_0.size;\n }\n function StringFormat$FormatType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function StringFormat$FormatType_initFields() {\n StringFormat$FormatType_initFields = function () {\n };\n StringFormat$FormatType$NUMBER_FORMAT_instance = new StringFormat$FormatType('NUMBER_FORMAT', 0);\n StringFormat$FormatType$STRING_FORMAT_instance = new StringFormat$FormatType('STRING_FORMAT', 1);\n }\n var StringFormat$FormatType$NUMBER_FORMAT_instance;\n function StringFormat$FormatType$NUMBER_FORMAT_getInstance() {\n StringFormat$FormatType_initFields();\n return StringFormat$FormatType$NUMBER_FORMAT_instance;\n }\n var StringFormat$FormatType$STRING_FORMAT_instance;\n function StringFormat$FormatType$STRING_FORMAT_getInstance() {\n StringFormat$FormatType_initFields();\n return StringFormat$FormatType$STRING_FORMAT_instance;\n }\n StringFormat$FormatType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FormatType',\n interfaces: [Enum]\n };\n function StringFormat$FormatType$values() {\n return [StringFormat$FormatType$NUMBER_FORMAT_getInstance(), StringFormat$FormatType$STRING_FORMAT_getInstance()];\n }\n StringFormat$FormatType.values = StringFormat$FormatType$values;\n function StringFormat$FormatType$valueOf(name) {\n switch (name) {\n case 'NUMBER_FORMAT':\n return StringFormat$FormatType$NUMBER_FORMAT_getInstance();\n case 'STRING_FORMAT':\n return StringFormat$FormatType$STRING_FORMAT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.stringFormat.StringFormat.FormatType.' + name);\n }\n }\n StringFormat$FormatType.valueOf_61zpoe$ = StringFormat$FormatType$valueOf;\n StringFormat.prototype.format_za3rmp$ = function (value) {\n return this.format_pqjuzw$(listOf_0(value));\n };\n StringFormat.prototype.format_pqjuzw$ = function (values) {\n var tmp$;\n if (this.argsNumber !== values.size) {\n throw IllegalStateException_init((\"Can't format values \" + values + ' with pattern ' + '\"' + this.pattern_0 + '\"' + '). Wrong number of arguments: expected ' + this.argsNumber + ' instead of ' + values.size).toString());\n }loop_label: switch (this.formatType.name) {\n case 'NUMBER_FORMAT':\n if (!(this.myNumberFormatters_0.size === 1)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }\n tmp$ = this.formatValue_0(single(values), single(this.myNumberFormatters_0));\n break loop_label;\n case 'STRING_FORMAT':\n var index = {v: 0};\n var $this = StringFormat$Companion_getInstance().BRACES_REGEX_0;\n var input = this.pattern_0;\n var replace_20wsma$result;\n replace_20wsma$break: do {\n var match = $this.find_905azu$(input);\n if (match == null) {\n replace_20wsma$result = input.toString();\n break replace_20wsma$break;\n }var lastStart = 0;\n var length = input.length;\n var sb = StringBuilder_init_0(length);\n do {\n var foundMatch = ensureNotNull(match);\n sb.append_ezbsdh$(input, lastStart, foundMatch.range.start);\n var tmp$_0 = sb.append_gw00v9$;\n var tmp$_1;\n var originalValue = values.get_za3lpa$(index.v);\n var formatter = this.myNumberFormatters_0.get_za3lpa$((tmp$_1 = index.v, index.v = tmp$_1 + 1 | 0, tmp$_1));\n tmp$_0.call(sb, this.formatValue_0(originalValue, formatter));\n lastStart = foundMatch.range.endInclusive + 1 | 0;\n match = foundMatch.next();\n }\n while (lastStart < length && match != null);\n if (lastStart < length) {\n sb.append_ezbsdh$(input, lastStart, length);\n }replace_20wsma$result = sb.toString();\n }\n while (false);\n tmp$ = replace(replace(replace_20wsma$result, '{{', '{'), '}}', '}');\n break loop_label;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break loop_label;\n }\n return tmp$;\n };\n StringFormat.prototype.formatValue_0 = function (value, numberFormatter) {\n var tmp$, tmp$_0, tmp$_1;\n if (numberFormatter == null)\n tmp$_1 = value.toString();\n else if (Kotlin.isNumber(value))\n tmp$_1 = numberFormatter.apply_3p81yu$(value);\n else if (typeof value === 'string') {\n tmp$_1 = (tmp$_0 = (tmp$ = toDoubleOrNull(value)) != null ? getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_3p81yu$(p1);\n }.bind(null, numberFormatter))(tmp$) : null) != null ? tmp$_0 : value;\n } else {\n throw IllegalStateException_init(('Failed to format value with type ' + toString(Kotlin.getKClassFromExpression(value).simpleName) + '. Supported types are Number and String.').toString());\n }\n return tmp$_1;\n };\n function StringFormat$Companion() {\n StringFormat$Companion_instance = this;\n this.BRACES_REGEX_0 = Regex_init('(?![^{]|\\\\{\\\\{)(\\\\{([^{}]*)\\\\})(?=[^}]|\\\\}\\\\}|$)');\n this.TEXT_IN_BRACES = 2;\n }\n StringFormat$Companion.prototype.valueInLinePattern = function () {\n return '{}';\n };\n StringFormat$Companion.prototype.forOneArg_86f9bg$ = function (pattern, type, formatFor) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n return this.create_w8bwfu$(pattern, type, formatFor, 1);\n };\n StringFormat$Companion.prototype.forNArgs_8vq31k$ = function (pattern, type, argCount, formatFor) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n return this.create_w8bwfu$(pattern, type, formatFor, argCount);\n };\n StringFormat$Companion.prototype.create_w8bwfu$ = function (pattern, type, formatFor, expectedArgs) {\n if (type === void 0)\n type = null;\n if (formatFor === void 0)\n formatFor = null;\n if (expectedArgs === void 0)\n expectedArgs = -1;\n var tmp$;\n if (type != null)\n tmp$ = type;\n else if (NumberFormat$Companion_getInstance().isValidPattern_61zpoe$(pattern))\n tmp$ = StringFormat$FormatType$NUMBER_FORMAT_getInstance();\n else\n tmp$ = StringFormat$FormatType$STRING_FORMAT_getInstance();\n var formatType = tmp$;\n var $receiver = new StringFormat(pattern, formatType);\n if (expectedArgs > 0) {\n if (!($receiver.argsNumber === expectedArgs)) {\n var tmp$_0;\n var formatFor_0 = (tmp$_0 = formatFor != null ? 'to format ' + \"'\" + toString(formatFor) + \"'\" : null) != null ? tmp$_0 : '';\n var message = 'Wrong number of arguments in pattern ' + \"'\" + pattern + \"'\" + ' ' + formatFor_0 + '. ' + ('Expected ' + expectedArgs + ' ' + (expectedArgs > 1 ? 'arguments' : 'argument') + ' ') + ('instead of ' + $receiver.argsNumber);\n throw IllegalArgumentException_init(message.toString());\n }}return $receiver;\n };\n StringFormat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StringFormat$Companion_instance = null;\n function StringFormat$Companion_getInstance() {\n if (StringFormat$Companion_instance === null) {\n new StringFormat$Companion();\n }return StringFormat$Companion_instance;\n }\n function StringFormat_init$initNumberFormat(pattern) {\n try {\n return NumberFormat_init(pattern);\n } catch (e) {\n if (Kotlin.isType(e, Exception)) {\n throw IllegalStateException_init(('Wrong number pattern: ' + pattern).toString());\n } else\n throw e;\n }\n }\n function StringFormat_init$lambda(it) {\n return it.groupValues.get_za3lpa$(2);\n }\n function StringFormat_init$lambda_0(closure$initNumberFormat) {\n return function (format) {\n if (format.length > 0) {\n return closure$initNumberFormat(format);\n } else {\n return null;\n }\n };\n }\n StringFormat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StringFormat',\n interfaces: []\n };\n function AbstractGeometryList(myGeometry) {\n AbstractList.call(this);\n this.myGeometry_8dt6c9$_0 = myGeometry;\n }\n AbstractGeometryList.prototype.get_za3lpa$ = function (index) {\n return this.myGeometry_8dt6c9$_0.get_za3lpa$(index);\n };\n Object.defineProperty(AbstractGeometryList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myGeometry_8dt6c9$_0.size;\n }\n });\n AbstractGeometryList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractGeometryList',\n interfaces: [AbstractList]\n };\n function isClockwise_0(ring) {\n return isClockwise(ring, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }));\n }\n function createMultiPolygon(points) {\n var tmp$;\n if (points.isEmpty()) {\n return new MultiPolygon(emptyList());\n }var polygons = ArrayList_init();\n var rings = ArrayList_init();\n tmp$ = splitRings(points).iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (!rings.isEmpty() && isClockwise_0(ring)) {\n polygons.add_11rb$(new Polygon(rings));\n rings = ArrayList_init();\n }rings.add_11rb$(new Ring(ring));\n }\n if (!rings.isEmpty()) {\n polygons.add_11rb$(new Polygon(rings));\n }return new MultiPolygon(polygons);\n }\n function boundingBox$lambda(minX, minY, maxX, maxY) {\n return newSpanRectangle(new Vec(minX, minY), new Vec(maxX, maxY));\n }\n function boundingBox($receiver) {\n return DoubleRectangles_getInstance().calculateBoundingBox_h5l7ap$($receiver, getPropertyCallableRef('x', 1, function ($receiver) {\n return $receiver.x;\n }), getPropertyCallableRef('y', 1, function ($receiver) {\n return $receiver.y;\n }), boundingBox$lambda);\n }\n function Generic() {\n }\n Generic.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Generic',\n interfaces: []\n };\n function reinterpret($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, Vec) ? tmp$ : throwCCE();\n }\n function reinterpret_0($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiPoint) ? tmp$ : throwCCE();\n }\n function reinterpret_1($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, LineString) ? tmp$ : throwCCE();\n }\n function reinterpret_2($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiLineString) ? tmp$ : throwCCE();\n }\n function reinterpret_3($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, Polygon) ? tmp$ : throwCCE();\n }\n function reinterpret_4($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, MultiPolygon) ? tmp$ : throwCCE();\n }\n function get_bottom($receiver) {\n return $receiver.origin.y + $receiver.dimension.y;\n }\n function get_right($receiver) {\n return $receiver.origin.x + $receiver.dimension.x;\n }\n function get_height($receiver) {\n return $receiver.dimension.y;\n }\n function get_width($receiver) {\n return $receiver.dimension.x;\n }\n function get_top($receiver) {\n return $receiver.origin.y;\n }\n function get_left($receiver) {\n return $receiver.origin.x;\n }\n function get_scalarBottom($receiver) {\n return new Scalar(get_bottom($receiver));\n }\n function get_scalarRight($receiver) {\n return new Scalar(get_right($receiver));\n }\n function get_scalarHeight($receiver) {\n return new Scalar(get_height($receiver));\n }\n function get_scalarWidth($receiver) {\n return new Scalar(get_width($receiver));\n }\n function get_scalarTop($receiver) {\n return new Scalar(get_top($receiver));\n }\n function get_scalarLeft($receiver) {\n return new Scalar(get_left($receiver));\n }\n function get_center($receiver) {\n return plus_4(div_0($receiver.dimension, 2.0), $receiver.origin);\n }\n function get_scalarX($receiver) {\n return new Scalar($receiver.x);\n }\n function get_scalarY($receiver) {\n return new Scalar($receiver.y);\n }\n function plus_4($receiver, other) {\n return new Vec($receiver.x + other.x, $receiver.y + other.y);\n }\n function minus($receiver, other) {\n return new Vec($receiver.x - other.x, $receiver.y - other.y);\n }\n function times($receiver, other) {\n return new Vec($receiver.x * other.x, $receiver.y * other.y);\n }\n function div($receiver, other) {\n return new Vec($receiver.x / other.x, $receiver.y / other.y);\n }\n function times_0($receiver, scale) {\n return new Vec($receiver.x * scale, $receiver.y * scale);\n }\n function div_0($receiver, scale) {\n return new Vec($receiver.x / scale, $receiver.y / scale);\n }\n function unaryMinus($receiver) {\n return new Vec(-$receiver.x, -$receiver.y);\n }\n function transform$lambda(it) {\n return it;\n }\n function transform$lambda_0(it) {\n return it;\n }\n function transform($receiver, newX, newY) {\n if (newX === void 0)\n newX = transform$lambda;\n if (newY === void 0)\n newY = transform$lambda_0;\n return new Vec(newX(get_scalarX($receiver)).value, newY(get_scalarY($receiver)).value);\n }\n function plus_5($receiver, other) {\n return new Scalar($receiver.value + other.value);\n }\n function minus_0($receiver, other) {\n return new Scalar($receiver.value - other.value);\n }\n function times_1($receiver, other) {\n return new Scalar($receiver.value * other.value);\n }\n function div_1($receiver, other) {\n return new Scalar($receiver.value / other.value);\n }\n function div_2($receiver, other) {\n return new Scalar($receiver.value / other);\n }\n function times_2($receiver, other) {\n return new Scalar($receiver.value * other);\n }\n function unaryMinus_0($receiver) {\n return new Scalar(-$receiver.value);\n }\n function compareTo($receiver, i) {\n return Kotlin.compareTo($receiver.value, i);\n }\n function newSpanRectangle(leftTop, rightBottom) {\n return new Rect(leftTop, minus(rightBottom, leftTop));\n }\n function limit($receiver) {\n return boundingBox(asIterable(flatten(asSequence($receiver))));\n }\n function contains_1($receiver, v) {\n return $receiver.origin.x <= v.x && $receiver.origin.x + $receiver.dimension.x >= v.x && $receiver.origin.y <= v.y && $receiver.origin.y + $receiver.dimension.y >= v.y;\n }\n function intersects($receiver, rect) {\n var t1 = $receiver.origin;\n var t2 = plus_4($receiver.origin, $receiver.dimension);\n var r1 = rect.origin;\n var r2 = plus_4(rect.origin, rect.dimension);\n return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y;\n }\n function xRange($receiver) {\n return new ClosedRange($receiver.origin.x, $receiver.origin.x + $receiver.dimension.x);\n }\n function yRange($receiver) {\n return new ClosedRange($receiver.origin.y, $receiver.origin.y + $receiver.dimension.y);\n }\n function limit_0($receiver) {\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(limit(item));\n }\n return destination;\n }\n function GeometryType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeometryType_initFields() {\n GeometryType_initFields = function () {\n };\n GeometryType$MULTI_POINT_instance = new GeometryType('MULTI_POINT', 0);\n GeometryType$MULTI_LINESTRING_instance = new GeometryType('MULTI_LINESTRING', 1);\n GeometryType$MULTI_POLYGON_instance = new GeometryType('MULTI_POLYGON', 2);\n }\n var GeometryType$MULTI_POINT_instance;\n function GeometryType$MULTI_POINT_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_POINT_instance;\n }\n var GeometryType$MULTI_LINESTRING_instance;\n function GeometryType$MULTI_LINESTRING_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_LINESTRING_instance;\n }\n var GeometryType$MULTI_POLYGON_instance;\n function GeometryType$MULTI_POLYGON_getInstance() {\n GeometryType_initFields();\n return GeometryType$MULTI_POLYGON_instance;\n }\n GeometryType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeometryType',\n interfaces: [Enum]\n };\n function GeometryType$values() {\n return [GeometryType$MULTI_POINT_getInstance(), GeometryType$MULTI_LINESTRING_getInstance(), GeometryType$MULTI_POLYGON_getInstance()];\n }\n GeometryType.values = GeometryType$values;\n function GeometryType$valueOf(name) {\n switch (name) {\n case 'MULTI_POINT':\n return GeometryType$MULTI_POINT_getInstance();\n case 'MULTI_LINESTRING':\n return GeometryType$MULTI_LINESTRING_getInstance();\n case 'MULTI_POLYGON':\n return GeometryType$MULTI_POLYGON_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.base.typedGeometry.GeometryType.' + name);\n }\n }\n GeometryType.valueOf_61zpoe$ = GeometryType$valueOf;\n function Geometry(type, myMultiPoint, myMultiLineString, myMultiPolygon) {\n Geometry$Companion_getInstance();\n this.type = type;\n this.myMultiPoint_0 = myMultiPoint;\n this.myMultiLineString_0 = myMultiLineString;\n this.myMultiPolygon_0 = myMultiPolygon;\n }\n Object.defineProperty(Geometry.prototype, 'multiPoint', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiPoint_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiPoint').toString());\n }\n return tmp$_0;\n }\n });\n Object.defineProperty(Geometry.prototype, 'multiLineString', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiLineString_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiLineString').toString());\n }\n return tmp$_0;\n }\n });\n Object.defineProperty(Geometry.prototype, 'multiPolygon', {\n configurable: true,\n get: function () {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myMultiPolygon_0) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init((this.type.toString() + ' is not a MultiPolygon').toString());\n }\n return tmp$_0;\n }\n });\n function Geometry$Companion() {\n Geometry$Companion_instance = this;\n }\n Geometry$Companion.prototype.createMultiPoint_xgn53i$ = function (multiPoint) {\n return new Geometry(GeometryType$MULTI_POINT_getInstance(), multiPoint, null, null);\n };\n Geometry$Companion.prototype.createMultiLineString_bc4hlz$ = function (multiLineString) {\n return new Geometry(GeometryType$MULTI_LINESTRING_getInstance(), null, multiLineString, null);\n };\n Geometry$Companion.prototype.createMultiPolygon_8ft4gs$ = function (multiPolygon) {\n return new Geometry(GeometryType$MULTI_POLYGON_getInstance(), null, null, multiPolygon);\n };\n Geometry$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Geometry$Companion_instance = null;\n function Geometry$Companion_getInstance() {\n if (Geometry$Companion_instance === null) {\n new Geometry$Companion();\n }return Geometry$Companion_instance;\n }\n Geometry.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Geometry',\n interfaces: []\n };\n function LineString(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n LineString.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineString',\n interfaces: [AbstractGeometryList]\n };\n function MultiLineString(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n MultiLineString.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiLineString',\n interfaces: [AbstractGeometryList]\n };\n function MultiPoint(geometry) {\n AbstractGeometryList.call(this, geometry);\n }\n MultiPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPoint',\n interfaces: [AbstractGeometryList]\n };\n function MultiPolygon(polygons) {\n AbstractGeometryList.call(this, polygons);\n }\n MultiPolygon.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPolygon',\n interfaces: [AbstractGeometryList]\n };\n function Polygon(rings) {\n AbstractGeometryList.call(this, rings);\n }\n Polygon.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Polygon',\n interfaces: [AbstractGeometryList]\n };\n function Rect(origin, dimension) {\n this.origin = origin;\n this.dimension = dimension;\n }\n Rect.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Rect',\n interfaces: []\n };\n function Rect_init(left, top, width, height, $this) {\n $this = $this || Object.create(Rect.prototype);\n Rect.call($this, new Vec(left, top), new Vec(width, height));\n return $this;\n }\n Rect.prototype.component1 = function () {\n return this.origin;\n };\n Rect.prototype.component2 = function () {\n return this.dimension;\n };\n Rect.prototype.copy_rbt1hw$ = function (origin, dimension) {\n return new Rect(origin === void 0 ? this.origin : origin, dimension === void 0 ? this.dimension : dimension);\n };\n Rect.prototype.toString = function () {\n return 'Rect(origin=' + Kotlin.toString(this.origin) + (', dimension=' + Kotlin.toString(this.dimension)) + ')';\n };\n Rect.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.origin) | 0;\n result = result * 31 + Kotlin.hashCode(this.dimension) | 0;\n return result;\n };\n Rect.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.origin, other.origin) && Kotlin.equals(this.dimension, other.dimension)))));\n };\n function Ring(points) {\n AbstractGeometryList.call(this, points);\n }\n Ring.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Ring',\n interfaces: [AbstractGeometryList]\n };\n function Scalar(value) {\n this.value = value;\n }\n Scalar.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Scalar',\n interfaces: []\n };\n Scalar.prototype.component1 = function () {\n return this.value;\n };\n Scalar.prototype.copy_14dthe$ = function (value) {\n return new Scalar(value === void 0 ? this.value : value);\n };\n Scalar.prototype.toString = function () {\n return 'Scalar(value=' + Kotlin.toString(this.value) + ')';\n };\n Scalar.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.value) | 0;\n return result;\n };\n Scalar.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && Kotlin.equals(this.value, other.value))));\n };\n function Vec(x, y) {\n this.x = x;\n this.y = y;\n }\n Vec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Vec',\n interfaces: []\n };\n function Vec_init(x, y, $this) {\n $this = $this || Object.create(Vec.prototype);\n Vec.call($this, x, y);\n return $this;\n }\n Vec.prototype.component1 = function () {\n return this.x;\n };\n Vec.prototype.component2 = function () {\n return this.y;\n };\n Vec.prototype.copy_lu1900$ = function (x, y) {\n return new Vec(x === void 0 ? this.x : x, y === void 0 ? this.y : y);\n };\n Vec.prototype.toString = function () {\n return 'Vec(x=' + Kotlin.toString(this.x) + (', y=' + Kotlin.toString(this.y)) + ')';\n };\n Vec.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.x) | 0;\n result = result * 31 + Kotlin.hashCode(this.y) | 0;\n return result;\n };\n Vec.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.x, other.x) && Kotlin.equals(this.y, other.y)))));\n };\n function explicitVec(x, y) {\n return new Vec(x, y);\n }\n function explicitVec_0(x, y) {\n return new Vec(x, y);\n }\n function newVec(x, y) {\n return new Vec(x.value, y.value);\n }\n function TypedKey() {\n }\n TypedKey.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TypedKey',\n interfaces: []\n };\n function TypedKeyHashMap() {\n this.map = HashMap_init_0();\n }\n TypedKeyHashMap.prototype.get_ex36zt$ = function (key) {\n var tmp$;\n if (this.map.containsKey_11rb$(key)) {\n return (tmp$ = this.map.get_11rb$(key)) == null || Kotlin.isType(tmp$, Any) ? tmp$ : throwCCE();\n }throw new NoSuchElementException_init_0(\"Wasn't found key \" + key);\n };\n TypedKeyHashMap.prototype.set_ev6mlr$ = function (key, value) {\n this.put_ev6mlr$(key, value);\n };\n TypedKeyHashMap.prototype.put_ev6mlr$ = function (key, value) {\n if (value == null) {\n this.map.remove_11rb$(key);\n } else {\n this.map.put_xwzc9p$(key, value);\n }\n };\n TypedKeyHashMap.prototype.contains_ku7evr$ = function (key) {\n return this.containsKey_ex36zt$(key);\n };\n TypedKeyHashMap.prototype.containsKey_ex36zt$ = function (key) {\n return this.map.containsKey_11rb$(key);\n };\n TypedKeyHashMap.prototype.keys_287e2$ = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.map.keys, Set) ? tmp$ : throwCCE();\n };\n TypedKeyHashMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedKeyHashMap',\n interfaces: []\n };\n function UNSUPPORTED() {\n throw UnsupportedOperationException_init();\n }\n function UNSUPPORTED_0(what) {\n throw UnsupportedOperationException_init_0(what);\n }\n function Color(red, green, blue, alpha) {\n Color$Companion_getInstance();\n if (alpha === void 0)\n alpha = 255;\n this.red = red;\n this.green = green;\n this.blue = blue;\n this.alpha = alpha;\n if (!(0 <= this.red && this.red <= 255 && 0 <= this.green && this.green <= 255 && 0 <= this.blue && this.blue <= 255 && 0 <= this.alpha && this.alpha <= 255)) {\n var message = 'Color components out of range: ' + this;\n throw IllegalArgumentException_init(message.toString());\n }}\n Color.prototype.changeAlpha_za3lpa$ = function (newAlpha) {\n return new Color(this.red, this.green, this.blue, newAlpha);\n };\n Color.prototype.equals = function (other) {\n if (this === other) {\n return true;\n }if (!Kotlin.isType(other, Color)) {\n return false;\n }if (this.red !== other.red) {\n return false;\n }if (this.green !== other.green) {\n return false;\n }if (this.blue !== other.blue) {\n return false;\n }return this.alpha === other.alpha;\n };\n Color.prototype.toCssColor = function () {\n var tmp$;\n if (this.alpha === 255) {\n tmp$ = 'rgb(' + this.red + ',' + this.green + ',' + this.blue + ')';\n } else {\n tmp$ = 'rgba(' + toString(this.red) + ',' + toString(this.green) + ',' + toString(this.blue) + ',' + toString(this.alpha / 255.0) + ')';\n }\n return tmp$;\n };\n Color.prototype.toHexColor = function () {\n return '#' + Color$Companion_getInstance().toColorPart_0(this.red) + Color$Companion_getInstance().toColorPart_0(this.green) + Color$Companion_getInstance().toColorPart_0(this.blue);\n };\n Color.prototype.hashCode = function () {\n var result = 0;\n result = (31 * result | 0) + this.red | 0;\n result = (31 * result | 0) + this.green | 0;\n result = (31 * result | 0) + this.blue | 0;\n result = (31 * result | 0) + this.alpha | 0;\n return result;\n };\n Color.prototype.toString = function () {\n return 'color(' + this.red + ',' + this.green + ',' + this.blue + ',' + this.alpha + ')';\n };\n function Color$Companion() {\n Color$Companion_instance = this;\n this.TRANSPARENT = new Color(0, 0, 0, 0);\n this.WHITE = new Color(255, 255, 255);\n this.CONSOLE_WHITE = new Color(204, 204, 204);\n this.BLACK = new Color(0, 0, 0);\n this.LIGHT_GRAY = new Color(192, 192, 192);\n this.VERY_LIGHT_GRAY = new Color(210, 210, 210);\n this.GRAY = new Color(128, 128, 128);\n this.RED = new Color(255, 0, 0);\n this.LIGHT_GREEN = new Color(210, 255, 210);\n this.GREEN = new Color(0, 255, 0);\n this.DARK_GREEN = new Color(0, 128, 0);\n this.BLUE = new Color(0, 0, 255);\n this.DARK_BLUE = new Color(0, 0, 128);\n this.LIGHT_BLUE = new Color(210, 210, 255);\n this.YELLOW = new Color(255, 255, 0);\n this.CONSOLE_YELLOW = new Color(174, 174, 36);\n this.LIGHT_YELLOW = new Color(255, 255, 128);\n this.VERY_LIGHT_YELLOW = new Color(255, 255, 210);\n this.MAGENTA = new Color(255, 0, 255);\n this.LIGHT_MAGENTA = new Color(255, 210, 255);\n this.DARK_MAGENTA = new Color(128, 0, 128);\n this.CYAN = new Color(0, 255, 255);\n this.LIGHT_CYAN = new Color(210, 255, 255);\n this.ORANGE = new Color(255, 192, 0);\n this.PINK = new Color(255, 175, 175);\n this.LIGHT_PINK = new Color(255, 210, 210);\n this.PACIFIC_BLUE = this.parseHex_61zpoe$('#118ED8');\n this.RGB_0 = 'rgb';\n this.COLOR_0 = 'color';\n this.RGBA_0 = 'rgba';\n }\n Color$Companion.prototype.parseRGB_61zpoe$ = function (text) {\n var firstParen = this.findNext_0(text, '(', 0);\n var prefix = text.substring(0, firstParen);\n var firstComma = this.findNext_0(text, ',', firstParen + 1 | 0);\n var secondComma = this.findNext_0(text, ',', firstComma + 1 | 0);\n var thirdComma = -1;\n if (equals(prefix, this.RGBA_0))\n thirdComma = this.findNext_0(text, ',', secondComma + 1 | 0);\n else if (equals(prefix, this.COLOR_0))\n thirdComma = indexOf(text, ',', secondComma + 1 | 0);\n else if (!equals(prefix, this.RGB_0))\n throw IllegalArgumentException_init(text);\n var lastParen = this.findNext_0(text, ')', thirdComma + 1 | 0);\n var startIndex = firstParen + 1 | 0;\n var $receiver = text.substring(startIndex, firstComma);\n var tmp$;\n var $receiver_0 = Kotlin.isCharSequence(tmp$ = $receiver) ? tmp$ : throwCCE();\n var startIndex_0 = 0;\n var endIndex = $receiver_0.length - 1 | 0;\n var startFound = false;\n while (startIndex_0 <= endIndex) {\n var index = !startFound ? startIndex_0 : endIndex;\n var match = unboxChar(toBoxedChar($receiver_0.charCodeAt(index))) <= 32;\n if (!startFound) {\n if (!match)\n startFound = true;\n else\n startIndex_0 = startIndex_0 + 1 | 0;\n } else {\n if (!match)\n break;\n else\n endIndex = endIndex - 1 | 0;\n }\n }\n var red = toInt(Kotlin.subSequence($receiver_0, startIndex_0, endIndex + 1 | 0).toString());\n var startIndex_1 = firstComma + 1 | 0;\n var $receiver_1 = text.substring(startIndex_1, secondComma);\n var tmp$_0;\n var $receiver_0_0 = Kotlin.isCharSequence(tmp$_0 = $receiver_1) ? tmp$_0 : throwCCE();\n var startIndex_2 = 0;\n var endIndex_0 = $receiver_0_0.length - 1 | 0;\n var startFound_0 = false;\n while (startIndex_2 <= endIndex_0) {\n var index_0 = !startFound_0 ? startIndex_2 : endIndex_0;\n var match_0 = unboxChar(toBoxedChar($receiver_0_0.charCodeAt(index_0))) <= 32;\n if (!startFound_0) {\n if (!match_0)\n startFound_0 = true;\n else\n startIndex_2 = startIndex_2 + 1 | 0;\n } else {\n if (!match_0)\n break;\n else\n endIndex_0 = endIndex_0 - 1 | 0;\n }\n }\n var green = toInt(Kotlin.subSequence($receiver_0_0, startIndex_2, endIndex_0 + 1 | 0).toString());\n var blue;\n var alpha;\n if (thirdComma === -1) {\n var startIndex_3 = secondComma + 1 | 0;\n var $receiver_2 = text.substring(startIndex_3, lastParen);\n var tmp$_1;\n var $receiver_0_1 = Kotlin.isCharSequence(tmp$_1 = $receiver_2) ? tmp$_1 : throwCCE();\n var startIndex_4 = 0;\n var endIndex_1 = $receiver_0_1.length - 1 | 0;\n var startFound_1 = false;\n while (startIndex_4 <= endIndex_1) {\n var index_1 = !startFound_1 ? startIndex_4 : endIndex_1;\n var match_1 = unboxChar(toBoxedChar($receiver_0_1.charCodeAt(index_1))) <= 32;\n if (!startFound_1) {\n if (!match_1)\n startFound_1 = true;\n else\n startIndex_4 = startIndex_4 + 1 | 0;\n } else {\n if (!match_1)\n break;\n else\n endIndex_1 = endIndex_1 - 1 | 0;\n }\n }\n blue = toInt(Kotlin.subSequence($receiver_0_1, startIndex_4, endIndex_1 + 1 | 0).toString());\n alpha = 255;\n } else {\n var startIndex_5 = secondComma + 1 | 0;\n var endIndex_2 = thirdComma;\n var $receiver_3 = text.substring(startIndex_5, endIndex_2);\n var tmp$_2;\n var $receiver_0_2 = Kotlin.isCharSequence(tmp$_2 = $receiver_3) ? tmp$_2 : throwCCE();\n var startIndex_6 = 0;\n var endIndex_3 = $receiver_0_2.length - 1 | 0;\n var startFound_2 = false;\n while (startIndex_6 <= endIndex_3) {\n var index_2 = !startFound_2 ? startIndex_6 : endIndex_3;\n var match_2 = unboxChar(toBoxedChar($receiver_0_2.charCodeAt(index_2))) <= 32;\n if (!startFound_2) {\n if (!match_2)\n startFound_2 = true;\n else\n startIndex_6 = startIndex_6 + 1 | 0;\n } else {\n if (!match_2)\n break;\n else\n endIndex_3 = endIndex_3 - 1 | 0;\n }\n }\n blue = toInt(Kotlin.subSequence($receiver_0_2, startIndex_6, endIndex_3 + 1 | 0).toString());\n var startIndex_7 = thirdComma + 1 | 0;\n var $receiver_4 = text.substring(startIndex_7, lastParen);\n var tmp$_3;\n var $receiver_0_3 = Kotlin.isCharSequence(tmp$_3 = $receiver_4) ? tmp$_3 : throwCCE();\n var startIndex_8 = 0;\n var endIndex_4 = $receiver_0_3.length - 1 | 0;\n var startFound_3 = false;\n while (startIndex_8 <= endIndex_4) {\n var index_3 = !startFound_3 ? startIndex_8 : endIndex_4;\n var match_3 = unboxChar(toBoxedChar($receiver_0_3.charCodeAt(index_3))) <= 32;\n if (!startFound_3) {\n if (!match_3)\n startFound_3 = true;\n else\n startIndex_8 = startIndex_8 + 1 | 0;\n } else {\n if (!match_3)\n break;\n else\n endIndex_4 = endIndex_4 - 1 | 0;\n }\n }\n alpha = roundToInt(toDouble(Kotlin.subSequence($receiver_0_3, startIndex_8, endIndex_4 + 1 | 0).toString()) * 255);\n }\n return new Color(red, green, blue, alpha);\n };\n Color$Companion.prototype.findNext_0 = function (s, what, from) {\n var result = indexOf(s, what, from);\n if (result === -1) {\n throw IllegalArgumentException_init('text=' + s + ' what=' + what + ' from=' + from);\n }return result;\n };\n Color$Companion.prototype.parseHex_61zpoe$ = function (hexColor) {\n var hexColor_0 = hexColor;\n if (!startsWith_0(hexColor_0, '#')) {\n throw IllegalArgumentException_init('Not a HEX value: ' + hexColor_0);\n }hexColor_0 = hexColor_0.substring(1);\n if (hexColor_0.length !== 6) {\n throw IllegalArgumentException_init('Not a HEX value: ' + hexColor_0);\n }var r = toInt_0(hexColor_0.substring(0, 2), 16);\n var g = toInt_0(hexColor_0.substring(2, 4), 16);\n var b = toInt_0(hexColor_0.substring(4, 6), 16);\n return new Color(r, g, b);\n };\n Color$Companion.prototype.toColorPart_0 = function (value) {\n var tmp$;\n if (value < 0 || value > 255) {\n throw IllegalArgumentException_init('RGB color part must be in range [0..255] but was ' + value);\n }var result = toString_0(value, 16);\n if (result.length === 1) {\n tmp$ = '0' + result;\n } else {\n tmp$ = result;\n }\n return tmp$;\n };\n Color$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Color$Companion_instance = null;\n function Color$Companion_getInstance() {\n if (Color$Companion_instance === null) {\n new Color$Companion();\n }return Color$Companion_instance;\n }\n Color.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Color',\n interfaces: []\n };\n function Colors() {\n Colors_instance = this;\n this.DEFAULT_FACTOR_0 = 0.7;\n this.variantColors_0 = mapOf([to('dark_blue', Color$Companion_getInstance().DARK_BLUE), to('dark_green', Color$Companion_getInstance().DARK_GREEN), to('dark_magenta', Color$Companion_getInstance().DARK_MAGENTA), to('light_blue', Color$Companion_getInstance().LIGHT_BLUE), to('light_gray', Color$Companion_getInstance().LIGHT_GRAY), to('light_green', Color$Companion_getInstance().LIGHT_GREEN), to('light_yellow', Color$Companion_getInstance().LIGHT_YELLOW), to('light_magenta', Color$Companion_getInstance().LIGHT_MAGENTA), to('light_cyan', Color$Companion_getInstance().LIGHT_CYAN), to('light_pink', Color$Companion_getInstance().LIGHT_PINK), to('very_light_gray', Color$Companion_getInstance().VERY_LIGHT_GRAY), to('very_light_yellow', Color$Companion_getInstance().VERY_LIGHT_YELLOW)]);\n var tmp$ = plus_3(mapOf([to('white', Color$Companion_getInstance().WHITE), to('black', Color$Companion_getInstance().BLACK), to('gray', Color$Companion_getInstance().GRAY), to('red', Color$Companion_getInstance().RED), to('green', Color$Companion_getInstance().GREEN), to('blue', Color$Companion_getInstance().BLUE), to('yellow', Color$Companion_getInstance().YELLOW), to('magenta', Color$Companion_getInstance().MAGENTA), to('cyan', Color$Companion_getInstance().CYAN), to('orange', Color$Companion_getInstance().ORANGE), to('pink', Color$Companion_getInstance().PINK)]), this.variantColors_0);\n var $receiver = this.variantColors_0;\n var destination = LinkedHashMap_init_0(mapCapacity($receiver.size));\n var tmp$_0;\n tmp$_0 = $receiver.entries.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n destination.put_xwzc9p$(replace_0(element.key, 95, 45), element.value);\n }\n var tmp$_1 = plus_3(tmp$, destination);\n var $receiver_0 = this.variantColors_0;\n var destination_0 = LinkedHashMap_init_0(mapCapacity($receiver_0.size));\n var tmp$_2;\n tmp$_2 = $receiver_0.entries.iterator();\n while (tmp$_2.hasNext()) {\n var element_0 = tmp$_2.next();\n destination_0.put_xwzc9p$(replace(element_0.key, '_', ''), element_0.value);\n }\n this.namedColors_0 = plus_3(tmp$_1, destination_0);\n }\n Colors.prototype.parseColor_61zpoe$ = function (c) {\n var tmp$;\n if (indexOf_0(c, 40) > 0)\n tmp$ = Color$Companion_getInstance().parseRGB_61zpoe$(c);\n else if (startsWith_0(c, '#'))\n tmp$ = Color$Companion_getInstance().parseHex_61zpoe$(c);\n else if (this.isColorName_61zpoe$(c))\n tmp$ = this.forName_61zpoe$(c);\n else\n throw IllegalArgumentException_init('Error persing color value: ' + c);\n return tmp$;\n };\n Colors.prototype.isColorName_61zpoe$ = function (colorName) {\n return this.namedColors_0.containsKey_11rb$(colorName.toLowerCase());\n };\n Colors.prototype.forName_61zpoe$ = function (colorName) {\n var tmp$;\n tmp$ = this.namedColors_0.get_11rb$(colorName.toLowerCase());\n if (tmp$ == null) {\n throw IllegalArgumentException_init_0();\n }return tmp$;\n };\n Colors.prototype.generateHueColor = function () {\n return 360 * Random.Default.nextDouble();\n };\n Colors.prototype.generateColor_lu1900$ = function (s, v) {\n return this.rgbFromHsv_yvo9jy$(360 * Random.Default.nextDouble(), s, v);\n };\n Colors.prototype.rgbFromHsv_yvo9jy$ = function (h, s, v) {\n if (v === void 0)\n v = 1.0;\n var hd = h / 60;\n var c = v * s;\n var x = hd % 2 - 1;\n var x_0 = c * (1 - JsMath.abs(x));\n var r = 0.0;\n var g = 0.0;\n var b = 0.0;\n if (hd < 1) {\n r = c;\n g = x_0;\n } else if (hd < 2) {\n r = x_0;\n g = c;\n } else if (hd < 3) {\n g = c;\n b = x_0;\n } else if (hd < 4) {\n g = x_0;\n b = c;\n } else if (hd < 5) {\n r = x_0;\n b = c;\n } else {\n r = c;\n b = x_0;\n }\n var m = v - c;\n return new Color(numberToInt(255 * (r + m)), numberToInt(255 * (g + m)), numberToInt(255 * (b + m)));\n };\n Colors.prototype.hsvFromRgb_98b62m$ = function (color) {\n var tmp$;\n var scale = 1.0 / 255;\n var r = color.red * scale;\n var g = color.green * scale;\n var b = color.blue * scale;\n var b_0 = JsMath.min(g, b);\n var min = JsMath.min(r, b_0);\n var b_1 = JsMath.max(g, b);\n var max = JsMath.max(r, b_1);\n var v = max === 0.0 ? 0.0 : 1 - min / max;\n var h;\n var div = 1.0 / (6 * (max - min));\n if (max === min) {\n tmp$ = 0.0;\n } else if (max === r) {\n tmp$ = g >= b ? (g - b) * div : 1 + (g - b) * div;\n } else if (max === g) {\n tmp$ = 1.0 / 3 + (b - r) * div;\n } else {\n tmp$ = 2.0 / 3 + (r - g) * div;\n }\n h = tmp$;\n return new Float64Array([360 * h, v, max]);\n };\n Colors.prototype.darker_w32t8z$ = function (c, factor) {\n if (factor === void 0)\n factor = this.DEFAULT_FACTOR_0;\n var tmp$;\n if (c != null) {\n var a = numberToInt(c.red * factor);\n var tmp$_0 = JsMath.max(a, 0);\n var a_0 = numberToInt(c.green * factor);\n var tmp$_1 = JsMath.max(a_0, 0);\n var a_1 = numberToInt(c.blue * factor);\n tmp$ = new Color(tmp$_0, tmp$_1, JsMath.max(a_1, 0), c.alpha);\n } else\n tmp$ = null;\n return tmp$;\n };\n Colors.prototype.lighter_o14uds$ = function (c, factor) {\n if (factor === void 0)\n factor = this.DEFAULT_FACTOR_0;\n var r = c.red;\n var g = c.green;\n var b = c.blue;\n var alpha = c.alpha;\n var i = numberToInt(1.0 / (1.0 - factor));\n if (r === 0 && g === 0 && b === 0) {\n return new Color(i, i, i, alpha);\n }if (r > 0 && r < i)\n r = i;\n if (g > 0 && g < i)\n g = i;\n if (b > 0 && b < i)\n b = i;\n var a = numberToInt(r / factor);\n var tmp$ = JsMath.min(a, 255);\n var a_0 = numberToInt(g / factor);\n var tmp$_0 = JsMath.min(a_0, 255);\n var a_1 = numberToInt(b / factor);\n return new Color(tmp$, tmp$_0, JsMath.min(a_1, 255), alpha);\n };\n Colors.prototype.mimicTransparency_w1v12e$ = function (color, alpha, background) {\n var red = numberToInt(color.red * alpha + background.red * (1 - alpha));\n var green = numberToInt(color.green * alpha + background.green * (1 - alpha));\n var blue = numberToInt(color.blue * alpha + background.blue * (1 - alpha));\n return new Color(red, green, blue);\n };\n Colors.prototype.withOpacity_o14uds$ = function (c, opacity) {\n var tmp$;\n if (opacity < 1.0) {\n var b = numberToInt(round(255 * opacity));\n var b_0 = JsMath.min(255, b);\n tmp$ = c.changeAlpha_za3lpa$(JsMath.max(0, b_0));\n } else\n tmp$ = c;\n return tmp$;\n };\n Colors.prototype.contrast_a87jzg$ = function (color, other) {\n return (this.luminance_98b62m$(color) + 0.05) / (this.luminance_98b62m$(other) + 0.05);\n };\n Colors.prototype.luminance_98b62m$ = function (color) {\n return 0.2126 * this.colorLuminance_0(color.red) + 0.7152 * this.colorLuminance_0(color.green) + 0.0722 * this.colorLuminance_0(color.blue);\n };\n Colors.prototype.colorLuminance_0 = function (componentValue) {\n var tmp$;\n if (componentValue <= 10)\n tmp$ = componentValue / 3294.0;\n else {\n var $receiver = componentValue / 269.0 + 0.0513;\n tmp$ = JsMath.pow($receiver, 2.4);\n }\n return tmp$;\n };\n Colors.prototype.solid_98b62m$ = function (c) {\n return c.alpha === 255;\n };\n Colors.prototype.distributeEvenly_5wr77w$ = function (count, saturation) {\n var tmp$;\n var result = Kotlin.newArray(count, null);\n var sector = 360 / count | 0;\n for (var i = 0; i < count; i++) {\n result[i] = this.rgbFromHsv_yvo9jy$(Kotlin.imul(sector, i), saturation);\n }\n return Kotlin.isArray(tmp$ = result) ? tmp$ : throwCCE();\n };\n Colors.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Colors',\n interfaces: []\n };\n var Colors_instance = null;\n function Colors_getInstance() {\n if (Colors_instance === null) {\n new Colors();\n }return Colors_instance;\n }\n function toPngDataUri(base64EncodedPngImage) {\n return 'data:image/png;base64,' + base64EncodedPngImage;\n }\n function Font(family, size, isBold, isItalic) {\n if (isBold === void 0)\n isBold = false;\n if (isItalic === void 0)\n isItalic = false;\n this.family = family;\n this.size = size;\n this.isBold = isBold;\n this.isItalic = isItalic;\n }\n Font.prototype.toString = function () {\n return this.family.toString() + ' ' + this.size + ' ' + (this.isBold ? 'bold' : '') + ' ' + (this.isItalic ? 'italic' : '');\n };\n Font.prototype.equals = function (other) {\n if (this === other)\n return true;\n if (!Kotlin.isType(other, Font))\n return false;\n return this.family === other.family && this.size === other.size && this.isBold === other.isBold && this.isItalic === other.isItalic;\n };\n Font.prototype.hashCode = function () {\n var result = hashCode(this.family);\n result = (31 * result | 0) + this.size | 0;\n result = (31 * result | 0) + (this.isBold ? 1 : 0) | 0;\n result = (31 * result | 0) + (this.isItalic ? 1 : 0) | 0;\n return result;\n };\n Font.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Font',\n interfaces: []\n };\n function FontFamily(myName) {\n FontFamily$Companion_getInstance();\n this.myName_0 = myName;\n }\n FontFamily.prototype.toString = function () {\n return this.myName_0;\n };\n function FontFamily$Companion() {\n FontFamily$Companion_instance = this;\n this.MONOSPACED = this.forName_61zpoe$('monospace');\n this.SERIF = this.forName_61zpoe$('serif');\n }\n FontFamily$Companion.prototype.forName_61zpoe$ = function (name) {\n return new FontFamily(name);\n };\n FontFamily$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FontFamily$Companion_instance = null;\n function FontFamily$Companion_getInstance() {\n if (FontFamily$Companion_instance === null) {\n new FontFamily$Companion();\n }return FontFamily$Companion_instance;\n }\n FontFamily.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FontFamily',\n interfaces: []\n };\n function HSV(h, saturation, value) {\n if (value === void 0)\n value = 1.0;\n this.h = h;\n this.s = 0;\n this.v = 0;\n if (!(saturation >= -0.001 && saturation <= 1.001)) {\n var message = \"HSV 'saturation' must be in range [0, 1] but was \" + saturation;\n throw IllegalArgumentException_init(message.toString());\n }if (!(value >= -0.001 && value <= 1.001)) {\n var message_0 = \"HSV 'value' must be in range [0, 1] but was \" + value;\n throw IllegalArgumentException_init(message_0.toString());\n }var x = numberToInt(saturation * 100) / 100.0;\n this.s = JsMath.abs(x);\n var x_0 = numberToInt(value * 100) / 100.0;\n this.v = JsMath.abs(x_0);\n }\n HSV.prototype.toString = function () {\n return 'HSV(' + this.h + ', ' + this.s + ', ' + this.v + ')';\n };\n HSV.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HSV',\n interfaces: []\n };\n function Interval(lowerBound, upperBound) {\n this.lowerBound = lowerBound;\n this.upperBound = upperBound;\n if (this.lowerBound > this.upperBound) {\n throw IllegalArgumentException_init('Lower bound is greater than upper: lower bound=' + toString(this.lowerBound) + ', upper bound=' + toString(this.upperBound));\n }}\n Object.defineProperty(Interval.prototype, 'length', {\n configurable: true,\n get: function () {\n return this.upperBound - this.lowerBound | 0;\n }\n });\n Interval.prototype.contains_za3lpa$ = function (point) {\n return this.lowerBound <= point && point <= this.upperBound;\n };\n Interval.prototype.contains_fvoaba$ = function (other) {\n return this.contains_za3lpa$(other.lowerBound) && this.contains_za3lpa$(other.upperBound);\n };\n Interval.prototype.intersects_fvoaba$ = function (other) {\n return this.contains_za3lpa$(other.lowerBound) || other.contains_za3lpa$(this.lowerBound);\n };\n Interval.prototype.union_fvoaba$ = function (other) {\n var a = this.lowerBound;\n var b = other.lowerBound;\n var tmp$ = JsMath.min(a, b);\n var a_0 = this.upperBound;\n var b_0 = other.upperBound;\n return new Interval(tmp$, JsMath.max(a_0, b_0));\n };\n Interval.prototype.add_za3lpa$ = function (delta) {\n return new Interval(this.lowerBound + delta | 0, this.upperBound + delta | 0);\n };\n Interval.prototype.sub_za3lpa$ = function (delta) {\n return new Interval(this.lowerBound - delta | 0, this.upperBound - delta | 0);\n };\n Interval.prototype.toString = function () {\n return '[' + this.lowerBound + ', ' + this.upperBound + ']';\n };\n Interval.prototype.equals = function (other) {\n var tmp$;\n if (this === other)\n return true;\n if (!Kotlin.isType(other, Interval))\n return false;\n var interval = (tmp$ = other) == null || Kotlin.isType(tmp$, Interval) ? tmp$ : throwCCE();\n return this.lowerBound !== ensureNotNull(interval).lowerBound ? false : this.upperBound === interval.upperBound;\n };\n Interval.prototype.hashCode = function () {\n var result = this.lowerBound;\n result = (31 * result | 0) + this.upperBound | 0;\n return result;\n };\n Interval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Interval',\n interfaces: []\n };\n function Pair_0(first, second) {\n this.first = first;\n this.second = second;\n }\n Pair_0.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, Pair_0) ? tmp$_0 : throwCCE();\n if (!equals(this.first, other.first))\n return false;\n if (!equals(this.second, other.second))\n return false;\n return true;\n };\n Pair_0.prototype.hashCode = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = (tmp$_0 = (tmp$ = this.first) != null ? hashCode(tmp$) : null) != null ? tmp$_0 : 0;\n result = (31 * result | 0) + ((tmp$_2 = (tmp$_1 = this.second) != null ? hashCode(tmp$_1) : null) != null ? tmp$_2 : 0) | 0;\n return result;\n };\n Pair_0.prototype.toString = function () {\n return '[' + this.first + ', ' + this.second + ']';\n };\n Pair_0.prototype.component1 = function () {\n return this.first;\n };\n Pair_0.prototype.component2 = function () {\n return this.second;\n };\n Pair_0.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Pair',\n interfaces: []\n };\n function SomeFig() {\n }\n SomeFig.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'SomeFig',\n interfaces: []\n };\n function PortableLogging() {\n PortableLogging_instance = this;\n }\n function PortableLogging$logger$ObjectLiteral(closure$kl) {\n this.closure$kl = closure$kl;\n }\n PortableLogging$logger$ObjectLiteral.prototype.error_l35kib$ = function (e, message) {\n this.closure$kl.error_ca4k3s$(e, message);\n };\n PortableLogging$logger$ObjectLiteral.prototype.info_h4ejuu$ = function (message) {\n this.closure$kl.info_nq59yw$(message);\n };\n PortableLogging$logger$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Logger]\n };\n PortableLogging.prototype.logger_xo1ogr$ = function (cl) {\n var tmp$;\n var kl = mu.KotlinLogging.logger_61zpoe$((tmp$ = cl.simpleName) != null ? tmp$ : '');\n return new PortableLogging$logger$ObjectLiteral(kl);\n };\n PortableLogging.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PortableLogging',\n interfaces: []\n };\n var PortableLogging_instance = null;\n function PortableLogging_getInstance() {\n if (PortableLogging_instance === null) {\n new PortableLogging();\n }return PortableLogging_instance;\n }\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$base = package$datalore.base || (package$datalore.base = {});\n var package$algorithms = package$base.algorithms || (package$base.algorithms = {});\n package$algorithms.splitRings_bemo1h$ = splitRings;\n package$algorithms.isClosed_2p1efm$ = isClosed;\n package$algorithms.calculateArea_ytws2g$ = calculateArea;\n package$algorithms.isClockwise_st9g9f$ = isClockwise;\n package$algorithms.calculateArea_st9g9f$ = calculateArea_0;\n var package$dateFormat = package$base.dateFormat || (package$base.dateFormat = {});\n Object.defineProperty(package$dateFormat, 'DateLocale', {\n get: DateLocale_getInstance\n });\n Format.SpecPart = Format$SpecPart;\n Format.PatternSpecPart = Format$PatternSpecPart;\n Object.defineProperty(Format, 'Companion', {\n get: Format$Companion_getInstance\n });\n package$dateFormat.Format_init_61zpoe$ = Format_init;\n package$dateFormat.Format = Format;\n Object.defineProperty(Pattern, 'DAY_OF_WEEK_ABBR', {\n get: Pattern$DAY_OF_WEEK_ABBR_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_WEEK_FULL', {\n get: Pattern$DAY_OF_WEEK_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH_ABBR', {\n get: Pattern$MONTH_ABBR_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH_FULL', {\n get: Pattern$MONTH_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_MONTH_LEADING_ZERO', {\n get: Pattern$DAY_OF_MONTH_LEADING_ZERO_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_MONTH', {\n get: Pattern$DAY_OF_MONTH_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_THE_YEAR', {\n get: Pattern$DAY_OF_THE_YEAR_getInstance\n });\n Object.defineProperty(Pattern, 'MONTH', {\n get: Pattern$MONTH_getInstance\n });\n Object.defineProperty(Pattern, 'DAY_OF_WEEK', {\n get: Pattern$DAY_OF_WEEK_getInstance\n });\n Object.defineProperty(Pattern, 'YEAR_SHORT', {\n get: Pattern$YEAR_SHORT_getInstance\n });\n Object.defineProperty(Pattern, 'YEAR_FULL', {\n get: Pattern$YEAR_FULL_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_24', {\n get: Pattern$HOUR_24_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_12_LEADING_ZERO', {\n get: Pattern$HOUR_12_LEADING_ZERO_getInstance\n });\n Object.defineProperty(Pattern, 'HOUR_12', {\n get: Pattern$HOUR_12_getInstance\n });\n Object.defineProperty(Pattern, 'MINUTE', {\n get: Pattern$MINUTE_getInstance\n });\n Object.defineProperty(Pattern, 'MERIDIAN_LOWER', {\n get: Pattern$MERIDIAN_LOWER_getInstance\n });\n Object.defineProperty(Pattern, 'MERIDIAN_UPPER', {\n get: Pattern$MERIDIAN_UPPER_getInstance\n });\n Object.defineProperty(Pattern, 'SECOND', {\n get: Pattern$SECOND_getInstance\n });\n Object.defineProperty(Pattern$Companion$Kind, 'DATE', {\n get: Pattern$Companion$Kind$DATE_getInstance\n });\n Object.defineProperty(Pattern$Companion$Kind, 'TIME', {\n get: Pattern$Companion$Kind$TIME_getInstance\n });\n Pattern$Companion.prototype.Kind = Pattern$Companion$Kind;\n Object.defineProperty(Pattern, 'Companion', {\n get: Pattern$Companion_getInstance\n });\n package$dateFormat.Pattern = Pattern;\n Object.defineProperty(Date_0, 'Companion', {\n get: Date$Companion_getInstance\n });\n var package$datetime = package$base.datetime || (package$base.datetime = {});\n package$datetime.Date = Date_0;\n Object.defineProperty(DateTime, 'Companion', {\n get: DateTime$Companion_getInstance\n });\n package$datetime.DateTime = DateTime;\n Object.defineProperty(package$datetime, 'DateTimeUtil', {\n get: DateTimeUtil_getInstance\n });\n Object.defineProperty(Duration, 'Companion', {\n get: Duration$Companion_getInstance\n });\n package$datetime.Duration = Duration;\n package$datetime.Instant = Instant;\n Object.defineProperty(Month, 'Companion', {\n get: Month$Companion_getInstance\n });\n package$datetime.Month = Month;\n Object.defineProperty(Time, 'Companion', {\n get: Time$Companion_getInstance\n });\n package$datetime.Time = Time;\n Object.defineProperty(WeekDay, 'MONDAY', {\n get: WeekDay$MONDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'TUESDAY', {\n get: WeekDay$TUESDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'WEDNESDAY', {\n get: WeekDay$WEDNESDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'THURSDAY', {\n get: WeekDay$THURSDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'FRIDAY', {\n get: WeekDay$FRIDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'SATURDAY', {\n get: WeekDay$SATURDAY_getInstance\n });\n Object.defineProperty(WeekDay, 'SUNDAY', {\n get: WeekDay$SUNDAY_getInstance\n });\n package$datetime.WeekDay = WeekDay;\n var package$tz = package$datetime.tz || (package$datetime.tz = {});\n package$tz.DateSpec = DateSpec;\n Object.defineProperty(package$tz, 'DateSpecs', {\n get: DateSpecs_getInstance\n });\n Object.defineProperty(TimeZone, 'Companion', {\n get: TimeZone$Companion_getInstance\n });\n package$tz.TimeZone = TimeZone;\n Object.defineProperty(TimeZoneMoscow, 'Companion', {\n get: TimeZoneMoscow$Companion_getInstance\n });\n package$tz.TimeZoneMoscow = TimeZoneMoscow;\n Object.defineProperty(package$tz, 'TimeZones', {\n get: TimeZones_getInstance\n });\n var package$enums = package$base.enums || (package$base.enums = {});\n package$enums.EnumInfo = EnumInfo;\n Object.defineProperty(package$enums, 'EnumInfoFactory', {\n get: EnumInfoFactory_getInstance\n });\n package$enums.EnumInfoImpl = EnumInfoImpl;\n Object.defineProperty(package$enums, 'Enums', {\n get: Enums_getInstance\n });\n Object.defineProperty(Button, 'NONE', {\n get: Button$NONE_getInstance\n });\n Object.defineProperty(Button, 'LEFT', {\n get: Button$LEFT_getInstance\n });\n Object.defineProperty(Button, 'MIDDLE', {\n get: Button$MIDDLE_getInstance\n });\n Object.defineProperty(Button, 'RIGHT', {\n get: Button$RIGHT_getInstance\n });\n var package$event = package$base.event || (package$base.event = {});\n package$event.Button = Button;\n package$event.Event = Event;\n package$event.EventContext = EventContext;\n Object.defineProperty(Key, 'A', {\n get: Key$A_getInstance\n });\n Object.defineProperty(Key, 'B', {\n get: Key$B_getInstance\n });\n Object.defineProperty(Key, 'C', {\n get: Key$C_getInstance\n });\n Object.defineProperty(Key, 'D', {\n get: Key$D_getInstance\n });\n Object.defineProperty(Key, 'E', {\n get: Key$E_getInstance\n });\n Object.defineProperty(Key, 'F', {\n get: Key$F_getInstance\n });\n Object.defineProperty(Key, 'G', {\n get: Key$G_getInstance\n });\n Object.defineProperty(Key, 'H', {\n get: Key$H_getInstance\n });\n Object.defineProperty(Key, 'I', {\n get: Key$I_getInstance\n });\n Object.defineProperty(Key, 'J', {\n get: Key$J_getInstance\n });\n Object.defineProperty(Key, 'K', {\n get: Key$K_getInstance\n });\n Object.defineProperty(Key, 'L', {\n get: Key$L_getInstance\n });\n Object.defineProperty(Key, 'M', {\n get: Key$M_getInstance\n });\n Object.defineProperty(Key, 'N', {\n get: Key$N_getInstance\n });\n Object.defineProperty(Key, 'O', {\n get: Key$O_getInstance\n });\n Object.defineProperty(Key, 'P', {\n get: Key$P_getInstance\n });\n Object.defineProperty(Key, 'Q', {\n get: Key$Q_getInstance\n });\n Object.defineProperty(Key, 'R', {\n get: Key$R_getInstance\n });\n Object.defineProperty(Key, 'S', {\n get: Key$S_getInstance\n });\n Object.defineProperty(Key, 'T', {\n get: Key$T_getInstance\n });\n Object.defineProperty(Key, 'U', {\n get: Key$U_getInstance\n });\n Object.defineProperty(Key, 'V', {\n get: Key$V_getInstance\n });\n Object.defineProperty(Key, 'W', {\n get: Key$W_getInstance\n });\n Object.defineProperty(Key, 'X', {\n get: Key$X_getInstance\n });\n Object.defineProperty(Key, 'Y', {\n get: Key$Y_getInstance\n });\n Object.defineProperty(Key, 'Z', {\n get: Key$Z_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_0', {\n get: Key$DIGIT_0_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_1', {\n get: Key$DIGIT_1_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_2', {\n get: Key$DIGIT_2_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_3', {\n get: Key$DIGIT_3_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_4', {\n get: Key$DIGIT_4_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_5', {\n get: Key$DIGIT_5_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_6', {\n get: Key$DIGIT_6_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_7', {\n get: Key$DIGIT_7_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_8', {\n get: Key$DIGIT_8_getInstance\n });\n Object.defineProperty(Key, 'DIGIT_9', {\n get: Key$DIGIT_9_getInstance\n });\n Object.defineProperty(Key, 'LEFT_BRACE', {\n get: Key$LEFT_BRACE_getInstance\n });\n Object.defineProperty(Key, 'RIGHT_BRACE', {\n get: Key$RIGHT_BRACE_getInstance\n });\n Object.defineProperty(Key, 'UP', {\n get: Key$UP_getInstance\n });\n Object.defineProperty(Key, 'DOWN', {\n get: Key$DOWN_getInstance\n });\n Object.defineProperty(Key, 'LEFT', {\n get: Key$LEFT_getInstance\n });\n Object.defineProperty(Key, 'RIGHT', {\n get: Key$RIGHT_getInstance\n });\n Object.defineProperty(Key, 'PAGE_UP', {\n get: Key$PAGE_UP_getInstance\n });\n Object.defineProperty(Key, 'PAGE_DOWN', {\n get: Key$PAGE_DOWN_getInstance\n });\n Object.defineProperty(Key, 'ESCAPE', {\n get: Key$ESCAPE_getInstance\n });\n Object.defineProperty(Key, 'ENTER', {\n get: Key$ENTER_getInstance\n });\n Object.defineProperty(Key, 'HOME', {\n get: Key$HOME_getInstance\n });\n Object.defineProperty(Key, 'END', {\n get: Key$END_getInstance\n });\n Object.defineProperty(Key, 'TAB', {\n get: Key$TAB_getInstance\n });\n Object.defineProperty(Key, 'SPACE', {\n get: Key$SPACE_getInstance\n });\n Object.defineProperty(Key, 'INSERT', {\n get: Key$INSERT_getInstance\n });\n Object.defineProperty(Key, 'DELETE', {\n get: Key$DELETE_getInstance\n });\n Object.defineProperty(Key, 'BACKSPACE', {\n get: Key$BACKSPACE_getInstance\n });\n Object.defineProperty(Key, 'EQUALS', {\n get: Key$EQUALS_getInstance\n });\n Object.defineProperty(Key, 'BACK_QUOTE', {\n get: Key$BACK_QUOTE_getInstance\n });\n Object.defineProperty(Key, 'PLUS', {\n get: Key$PLUS_getInstance\n });\n Object.defineProperty(Key, 'MINUS', {\n get: Key$MINUS_getInstance\n });\n Object.defineProperty(Key, 'SLASH', {\n get: Key$SLASH_getInstance\n });\n Object.defineProperty(Key, 'CONTROL', {\n get: Key$CONTROL_getInstance\n });\n Object.defineProperty(Key, 'META', {\n get: Key$META_getInstance\n });\n Object.defineProperty(Key, 'ALT', {\n get: Key$ALT_getInstance\n });\n Object.defineProperty(Key, 'SHIFT', {\n get: Key$SHIFT_getInstance\n });\n Object.defineProperty(Key, 'UNKNOWN', {\n get: Key$UNKNOWN_getInstance\n });\n Object.defineProperty(Key, 'F1', {\n get: Key$F1_getInstance\n });\n Object.defineProperty(Key, 'F2', {\n get: Key$F2_getInstance\n });\n Object.defineProperty(Key, 'F3', {\n get: Key$F3_getInstance\n });\n Object.defineProperty(Key, 'F4', {\n get: Key$F4_getInstance\n });\n Object.defineProperty(Key, 'F5', {\n get: Key$F5_getInstance\n });\n Object.defineProperty(Key, 'F6', {\n get: Key$F6_getInstance\n });\n Object.defineProperty(Key, 'F7', {\n get: Key$F7_getInstance\n });\n Object.defineProperty(Key, 'F8', {\n get: Key$F8_getInstance\n });\n Object.defineProperty(Key, 'F9', {\n get: Key$F9_getInstance\n });\n Object.defineProperty(Key, 'F10', {\n get: Key$F10_getInstance\n });\n Object.defineProperty(Key, 'F11', {\n get: Key$F11_getInstance\n });\n Object.defineProperty(Key, 'F12', {\n get: Key$F12_getInstance\n });\n Object.defineProperty(Key, 'COMMA', {\n get: Key$COMMA_getInstance\n });\n Object.defineProperty(Key, 'PERIOD', {\n get: Key$PERIOD_getInstance\n });\n package$event.Key = Key;\n package$event.KeyEvent_init_l9pgtg$ = KeyEvent_init;\n package$event.KeyEvent_init_79e79$ = KeyEvent_init_0;\n package$event.KeyEvent_init_m5etgt$ = KeyEvent_init_1;\n package$event.KeyEvent = KeyEvent;\n Object.defineProperty(KeyModifiers, 'Companion', {\n get: KeyModifiers$Companion_getInstance\n });\n package$event.KeyModifiers = KeyModifiers;\n package$event.KeyStroke_init_ji7i3y$ = KeyStroke_init;\n package$event.KeyStroke_init_812rgc$ = KeyStroke_init_0;\n package$event.KeyStroke = KeyStroke;\n package$event.KeyStrokeSpec_init_ji7i3y$ = KeyStrokeSpec_init;\n package$event.KeyStrokeSpec_init_luoraj$ = KeyStrokeSpec_init_0;\n package$event.KeyStrokeSpec_init_4t3vif$ = KeyStrokeSpec_init_1;\n package$event.KeyStrokeSpec = KeyStrokeSpec;\n Object.defineProperty(package$event, 'KeyStrokeSpecs', {\n get: KeyStrokeSpecs_getInstance\n });\n Object.defineProperty(ModifierKey, 'CONTROL', {\n get: ModifierKey$CONTROL_getInstance\n });\n Object.defineProperty(ModifierKey, 'ALT', {\n get: ModifierKey$ALT_getInstance\n });\n Object.defineProperty(ModifierKey, 'SHIFT', {\n get: ModifierKey$SHIFT_getInstance\n });\n Object.defineProperty(ModifierKey, 'META', {\n get: ModifierKey$META_getInstance\n });\n package$event.ModifierKey = ModifierKey;\n Object.defineProperty(MouseEvent, 'Companion', {\n get: MouseEvent$Companion_getInstance\n });\n package$event.MouseEvent_init_fbovgd$ = MouseEvent_init;\n package$event.MouseEvent = MouseEvent;\n package$event.MouseEventSource = MouseEventSource;\n Object.defineProperty(MouseEventSpec, 'MOUSE_ENTERED', {\n get: MouseEventSpec$MOUSE_ENTERED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_LEFT', {\n get: MouseEventSpec$MOUSE_LEFT_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_MOVED', {\n get: MouseEventSpec$MOUSE_MOVED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_DRAGGED', {\n get: MouseEventSpec$MOUSE_DRAGGED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_CLICKED', {\n get: MouseEventSpec$MOUSE_CLICKED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_DOUBLE_CLICKED', {\n get: MouseEventSpec$MOUSE_DOUBLE_CLICKED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_PRESSED', {\n get: MouseEventSpec$MOUSE_PRESSED_getInstance\n });\n Object.defineProperty(MouseEventSpec, 'MOUSE_RELEASED', {\n get: MouseEventSpec$MOUSE_RELEASED_getInstance\n });\n package$event.MouseEventSpec = MouseEventSpec;\n package$event.PointEvent = PointEvent;\n var package$function = package$base.function || (package$base.function = {});\n package$function.Function = Function;\n Object.defineProperty(package$function, 'Functions', {\n get: Functions_getInstance\n });\n package$function.Runnable = Runnable;\n package$function.Supplier = Supplier;\n package$function.Value = Value;\n var package$gcommon = package$base.gcommon || (package$base.gcommon = {});\n var package$base_0 = package$gcommon.base || (package$gcommon.base = {});\n Object.defineProperty(package$base_0, 'Preconditions', {\n get: Preconditions_getInstance\n });\n Object.defineProperty(package$base_0, 'Strings', {\n get: Strings_getInstance\n });\n Object.defineProperty(package$base_0, 'Throwables', {\n get: Throwables_getInstance\n });\n Object.defineProperty(ClosedRange, 'Companion', {\n get: ClosedRange$Companion_getInstance\n });\n var package$collect = package$gcommon.collect || (package$gcommon.collect = {});\n package$collect.ClosedRange = ClosedRange;\n Object.defineProperty(package$collect, 'Comparables', {\n get: Comparables_getInstance\n });\n package$collect.ComparatorOrdering = ComparatorOrdering;\n Object.defineProperty(package$collect, 'Iterables', {\n get: Iterables_getInstance\n });\n Object.defineProperty(package$collect, 'Lists', {\n get: Lists_getInstance\n });\n Object.defineProperty(Ordering, 'Companion', {\n get: Ordering$Companion_getInstance\n });\n package$collect.Ordering = Ordering;\n Object.defineProperty(package$collect, 'Sets', {\n get: Sets_getInstance\n });\n package$collect.Stack = Stack;\n package$collect.TreeMap = TreeMap;\n Object.defineProperty(DoubleRectangle, 'Companion', {\n get: DoubleRectangle$Companion_getInstance\n });\n var package$geometry = package$base.geometry || (package$base.geometry = {});\n package$geometry.DoubleRectangle_init_6y0v78$ = DoubleRectangle_init;\n package$geometry.DoubleRectangle = DoubleRectangle;\n Object.defineProperty(package$geometry, 'DoubleRectangles', {\n get: DoubleRectangles_getInstance\n });\n package$geometry.DoubleSegment = DoubleSegment;\n Object.defineProperty(DoubleVector, 'Companion', {\n get: DoubleVector$Companion_getInstance\n });\n package$geometry.DoubleVector = DoubleVector;\n package$geometry.Rectangle_init_tjonv8$ = Rectangle_init;\n package$geometry.Rectangle = Rectangle;\n Object.defineProperty(package$geometry, 'Rectangles', {\n get: Rectangles_getInstance\n });\n package$geometry.Segment = Segment;\n Object.defineProperty(Vector, 'Companion', {\n get: Vector$Companion_getInstance\n });\n package$geometry.Vector = Vector;\n var package$jsObject = package$base.jsObject || (package$base.jsObject = {});\n Object.defineProperty(package$jsObject, 'JsObjectSupport', {\n get: JsObjectSupport_getInstance\n });\n var package$json = package$base.json || (package$base.json = {});\n package$json.FluentArray_init = FluentArray_init;\n package$json.FluentArray_init_giv38x$ = FluentArray_init_0;\n package$json.FluentArray = FluentArray;\n package$json.FluentObject_init_bkhwtg$ = FluentObject_init;\n package$json.FluentObject_init = FluentObject_init_0;\n package$json.FluentObject = FluentObject;\n package$json.FluentPrimitive_init_s8ev37$ = FluentPrimitive_init;\n package$json.FluentPrimitive_init_pdl1vj$ = FluentPrimitive_init_0;\n package$json.FluentPrimitive_init_1v8dbw$ = FluentPrimitive_init_1;\n package$json.FluentPrimitive_init_rcaewn$ = FluentPrimitive_init_2;\n package$json.FluentPrimitive = FluentPrimitive;\n package$json.FluentValue = FluentValue;\n package$json.JsonFormatter = JsonFormatter;\n Object.defineProperty(JsonLexer, 'Companion', {\n get: JsonLexer$Companion_getInstance\n });\n package$json.JsonLexer = JsonLexer;\n JsonParser.JsonException = JsonParser$JsonException;\n package$json.JsonParser = JsonParser;\n Object.defineProperty(package$json, 'JsonSupport', {\n get: JsonSupport_getInstance\n });\n Object.defineProperty(Token, 'LEFT_BRACE', {\n get: Token$LEFT_BRACE_getInstance\n });\n Object.defineProperty(Token, 'RIGHT_BRACE', {\n get: Token$RIGHT_BRACE_getInstance\n });\n Object.defineProperty(Token, 'LEFT_BRACKET', {\n get: Token$LEFT_BRACKET_getInstance\n });\n Object.defineProperty(Token, 'RIGHT_BRACKET', {\n get: Token$RIGHT_BRACKET_getInstance\n });\n Object.defineProperty(Token, 'COMMA', {\n get: Token$COMMA_getInstance\n });\n Object.defineProperty(Token, 'COLON', {\n get: Token$COLON_getInstance\n });\n Object.defineProperty(Token, 'STRING', {\n get: Token$STRING_getInstance\n });\n Object.defineProperty(Token, 'NUMBER', {\n get: Token$NUMBER_getInstance\n });\n Object.defineProperty(Token, 'TRUE', {\n get: Token$TRUE_getInstance\n });\n Object.defineProperty(Token, 'FALSE', {\n get: Token$FALSE_getInstance\n });\n Object.defineProperty(Token, 'NULL', {\n get: Token$NULL_getInstance\n });\n package$json.Token = Token;\n Object.defineProperty(package$json, 'SPECIAL_CHARS_8be2vx$', {\n get: function () {\n return SPECIAL_CHARS;\n }\n });\n package$json.escape_pdl1vz$ = escape;\n package$json.unescape_pdl1vz$ = unescape;\n package$json.streamOf_9ma18$ = streamOf;\n package$json.objectsStreamOf_9ma18$ = objectsStreamOf;\n package$json.stringStreamOf_9ma18$ = stringStreamOf;\n package$json.isBoolean_za3rmp$ = isBoolean;\n package$json.isNumber_za3rmp$ = isNumber;\n package$json.isString_za3rmp$ = isString;\n package$json.getAsDouble_za3rmp$ = getAsDouble;\n package$json.getAsInt_s8jyv4$ = getAsInt;\n package$json.getAsBoolean_za3rmp$ = getAsBoolean;\n package$json.containsString_mer726$ = containsString;\n package$json.getAsString_s8jyv4$ = getAsString;\n package$json.parseEnum_xwn52g$ = parseEnum;\n package$json.formatEnum_wbfx10$ = formatEnum;\n package$json.put_tvzjva$ = put;\n package$json.put_5zytao$ = put_0;\n package$json.getNumber_8dq7w5$ = getNumber;\n package$json.getDouble_8dq7w5$ = getDouble;\n package$json.getString_8dq7w5$ = getString;\n package$json.getObj_8dq7w5$ = getObj;\n package$json.getArr_8dq7w5$ = getArr;\n Object.defineProperty(ListMap, 'Companion', {\n get: ListMap$Companion_getInstance\n });\n ListMap.Entry = ListMap$Entry;\n var package$listMap = package$base.listMap || (package$base.listMap = {});\n package$listMap.ListMap = ListMap;\n var package$logging = package$base.logging || (package$base.logging = {});\n package$logging.Logger = Logger;\n package$logging.PrintlnLogger = PrintlnLogger;\n var package$math = package$base.math || (package$base.math = {});\n package$math.toRadians_14dthe$ = toRadians;\n package$math.toDegrees_14dthe$ = toDegrees;\n package$math.round_gpjtzr$ = round_0;\n package$math.ceil_gpjtzr$ = ceil;\n package$math.round_lu1900$ = round_1;\n package$math.ceil_lu1900$ = ceil_0;\n package$math.distance_l3ath1$ = distance;\n package$math.ipow_dqglrj$ = ipow;\n var package$numberFormat = package$base.numberFormat || (package$base.numberFormat = {});\n package$numberFormat.length_s8cxhz$ = length;\n NumberFormat.Spec = NumberFormat$Spec;\n Object.defineProperty(NumberFormat$NumberInfo, 'Companion', {\n get: NumberFormat$NumberInfo$Companion_getInstance\n });\n NumberFormat.NumberInfo_init_hjbnfl$ = NumberFormat$NumberFormat$NumberInfo_init;\n NumberFormat.NumberInfo = NumberFormat$NumberInfo;\n NumberFormat.Output = NumberFormat$Output;\n NumberFormat.FormattedNumber = NumberFormat$FormattedNumber;\n Object.defineProperty(NumberFormat, 'Companion', {\n get: NumberFormat$Companion_getInstance\n });\n package$numberFormat.NumberFormat_init_61zpoe$ = NumberFormat_init;\n package$numberFormat.NumberFormat = NumberFormat;\n var package$observable = package$base.observable || (package$base.observable = {});\n var package$children = package$observable.children || (package$observable.children = {});\n package$children.ChildList = ChildList;\n package$children.ChildProperty = ChildProperty;\n package$children.Position = Position;\n package$children.PositionData = PositionData;\n package$children.SimpleComposite = SimpleComposite;\n var package$collections = package$observable.collections || (package$observable.collections = {});\n package$collections.CollectionAdapter = CollectionAdapter;\n Object.defineProperty(CollectionItemEvent$EventType, 'ADD', {\n get: CollectionItemEvent$EventType$ADD_getInstance\n });\n Object.defineProperty(CollectionItemEvent$EventType, 'SET', {\n get: CollectionItemEvent$EventType$SET_getInstance\n });\n Object.defineProperty(CollectionItemEvent$EventType, 'REMOVE', {\n get: CollectionItemEvent$EventType$REMOVE_getInstance\n });\n CollectionItemEvent.EventType = CollectionItemEvent$EventType;\n package$collections.CollectionItemEvent = CollectionItemEvent;\n package$collections.CollectionListener = CollectionListener;\n package$collections.ObservableCollection = ObservableCollection;\n var package$list = package$collections.list || (package$collections.list = {});\n package$list.AbstractObservableList = AbstractObservableList;\n package$list.ObservableArrayList = ObservableArrayList;\n package$list.ObservableList = ObservableList;\n var package$event_0 = package$observable.event || (package$observable.event = {});\n package$event_0.CompositeEventSource_init_xw2ruy$ = CompositeEventSource_init;\n package$event_0.CompositeEventSource_init_3qo2qg$ = CompositeEventSource_init_0;\n package$event_0.CompositeEventSource = CompositeEventSource;\n package$event_0.EventHandler = EventHandler;\n package$event_0.EventSource = EventSource;\n Object.defineProperty(package$event_0, 'EventSources', {\n get: EventSources_getInstance\n });\n package$event_0.ListenerCaller = ListenerCaller;\n package$event_0.ListenerEvent = ListenerEvent;\n package$event_0.Listeners = Listeners;\n package$event_0.MappingEventSource = MappingEventSource;\n var package$property = package$observable.property || (package$observable.property = {});\n package$property.BaseReadableProperty = BaseReadableProperty;\n package$property.DelayedValueProperty = DelayedValueProperty;\n package$property.Property = Property;\n Object.defineProperty(package$property, 'PropertyBinding', {\n get: PropertyBinding_getInstance\n });\n package$property.PropertyChangeEvent = PropertyChangeEvent;\n package$property.ReadableProperty = ReadableProperty;\n package$property.ValueProperty = ValueProperty;\n package$property.WritableProperty = WritableProperty;\n var package$random = package$base.random || (package$base.random = {});\n package$random.RandomGaussian = RandomGaussian;\n Object.defineProperty(package$random, 'RandomString', {\n get: RandomString_getInstance\n });\n var package$registration = package$base.registration || (package$base.registration = {});\n package$registration.CompositeRegistration = CompositeRegistration;\n package$registration.Disposable = Disposable;\n Object.defineProperty(Registration, 'Companion', {\n get: Registration$Companion_getInstance\n });\n package$registration.Registration = Registration;\n var package$throwableHandlers = package$registration.throwableHandlers || (package$registration.throwableHandlers = {});\n package$throwableHandlers.ThrowableHandler = ThrowableHandler;\n Object.defineProperty(package$throwableHandlers, 'ThrowableHandlers', {\n get: ThrowableHandlers_getInstance\n });\n var package$spatial = package$base.spatial || (package$base.spatial = {});\n Object.defineProperty(package$spatial, 'EARTH_RADIUS', {\n get: function () {\n return EARTH_RADIUS;\n }\n });\n Object.defineProperty(package$spatial, 'MIN_LONGITUDE', {\n get: function () {\n return MIN_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MAX_LONGITUDE', {\n get: function () {\n return MAX_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'FULL_LONGITUDE', {\n get: function () {\n return FULL_LONGITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MIN_LATITUDE', {\n get: function () {\n return MIN_LATITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'MAX_LATITUDE', {\n get: function () {\n return MAX_LATITUDE;\n }\n });\n Object.defineProperty(package$spatial, 'FULL_LATITUDE', {\n get: function () {\n return FULL_LATITUDE;\n }\n });\n package$spatial.get_start_cawtq0$ = get_start;\n package$spatial.get_end_cawtq0$ = get_end;\n Object.defineProperty(GeoBoundingBoxCalculator, 'Companion', {\n get: GeoBoundingBoxCalculator$Companion_getInstance\n });\n package$spatial.GeoBoundingBoxCalculator = GeoBoundingBoxCalculator;\n package$spatial.makeSegments_8o5yvy$ = makeSegments;\n package$spatial.geoRectsBBox_wfabpm$ = geoRectsBBox;\n package$spatial.pointsBBox_2r9fhj$ = pointsBBox;\n package$spatial.union_86o20w$ = union;\n Object.defineProperty(package$spatial, 'GeoJson', {\n get: GeoJson_getInstance\n });\n package$spatial.GeoRectangle = GeoRectangle;\n package$spatial.LonLat = LonLat;\n Object.defineProperty(package$spatial, 'EARTH_RECT', {\n get: function () {\n return EARTH_RECT;\n }\n });\n package$spatial.limitLon_14dthe$ = limitLon;\n package$spatial.limitLat_14dthe$ = limitLat;\n package$spatial.normalizeLon_14dthe$ = normalizeLon;\n Object.defineProperty(package$spatial, 'BBOX_CALCULATOR', {\n get: function () {\n return BBOX_CALCULATOR;\n }\n });\n package$spatial.convertToGeoRectangle_i3vl8m$ = convertToGeoRectangle;\n package$spatial.calculateQuadKeys_h9hod0$ = calculateQuadKeys;\n Object.defineProperty(LongitudeSegment, 'Companion', {\n get: LongitudeSegment$Companion_getInstance\n });\n package$spatial.LongitudeSegment = LongitudeSegment;\n Object.defineProperty(package$spatial, 'MercatorUtils', {\n get: MercatorUtils_getInstance\n });\n package$spatial.QuadKey = QuadKey;\n package$spatial.computeRect_c2pv3p$ = computeRect;\n package$spatial.computeRect_v4gkf3$ = computeRect_0;\n package$spatial.projectRect_cub2h3$ = projectRect;\n package$spatial.zoom_c2pv3p$ = zoom;\n package$spatial.computeOrigin_v4gkf3$ = computeOrigin;\n package$spatial.projectOrigin_cub2h3$ = projectOrigin;\n package$spatial.calulateQuadsCount_za3lpa$ = calulateQuadsCount;\n package$spatial.calculateQuadKeys_a35lcs$ = calculateQuadKeys_0;\n package$spatial.xyToKey_qt1dr2$ = xyToKey;\n SimpleFeature.prototype.GeometryConsumer = SimpleFeature$GeometryConsumer;\n SimpleFeature.prototype.Consumer = SimpleFeature$Consumer;\n Object.defineProperty(SimpleFeature$GeometryType, 'POINT', {\n get: SimpleFeature$GeometryType$POINT_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'LINE_STRING', {\n get: SimpleFeature$GeometryType$LINE_STRING_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'POLYGON', {\n get: SimpleFeature$GeometryType$POLYGON_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_POINT', {\n get: SimpleFeature$GeometryType$MULTI_POINT_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_LINE_STRING', {\n get: SimpleFeature$GeometryType$MULTI_LINE_STRING_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'MULTI_POLYGON', {\n get: SimpleFeature$GeometryType$MULTI_POLYGON_getInstance\n });\n Object.defineProperty(SimpleFeature$GeometryType, 'GEOMETRY_COLLECTION', {\n get: SimpleFeature$GeometryType$GEOMETRY_COLLECTION_getInstance\n });\n SimpleFeature.prototype.GeometryType = SimpleFeature$GeometryType;\n Object.defineProperty(package$spatial, 'SimpleFeature', {\n get: SimpleFeature_getInstance\n });\n Object.defineProperty(StringFormat$FormatType, 'NUMBER_FORMAT', {\n get: StringFormat$FormatType$NUMBER_FORMAT_getInstance\n });\n Object.defineProperty(StringFormat$FormatType, 'STRING_FORMAT', {\n get: StringFormat$FormatType$STRING_FORMAT_getInstance\n });\n StringFormat.FormatType = StringFormat$FormatType;\n Object.defineProperty(StringFormat, 'Companion', {\n get: StringFormat$Companion_getInstance\n });\n var package$stringFormat = package$base.stringFormat || (package$base.stringFormat = {});\n package$stringFormat.StringFormat = StringFormat;\n var package$typedGeometry = package$base.typedGeometry || (package$base.typedGeometry = {});\n package$typedGeometry.AbstractGeometryList = AbstractGeometryList;\n package$typedGeometry.isClockwise_hv912c$ = isClockwise_0;\n package$typedGeometry.createMultiPolygon_hv912c$ = createMultiPolygon;\n package$typedGeometry.boundingBox_gyuce3$ = boundingBox;\n package$typedGeometry.Generic = Generic;\n package$typedGeometry.reinterpret_q42o9k$ = reinterpret;\n package$typedGeometry.reinterpret_dr0qel$ = reinterpret_0;\n package$typedGeometry.reinterpret_2z483p$ = reinterpret_1;\n package$typedGeometry.reinterpret_typ3lq$ = reinterpret_2;\n package$typedGeometry.reinterpret_sux9xa$ = reinterpret_3;\n package$typedGeometry.reinterpret_dg847r$ = reinterpret_4;\n package$typedGeometry.get_bottom_h9e6jg$ = get_bottom;\n package$typedGeometry.get_right_h9e6jg$ = get_right;\n package$typedGeometry.get_height_h9e6jg$ = get_height;\n package$typedGeometry.get_width_h9e6jg$ = get_width;\n package$typedGeometry.get_top_h9e6jg$ = get_top;\n package$typedGeometry.get_left_h9e6jg$ = get_left;\n package$typedGeometry.get_scalarBottom_xdjzag$ = get_scalarBottom;\n package$typedGeometry.get_scalarRight_xdjzag$ = get_scalarRight;\n package$typedGeometry.get_scalarHeight_xdjzag$ = get_scalarHeight;\n package$typedGeometry.get_scalarWidth_xdjzag$ = get_scalarWidth;\n package$typedGeometry.get_scalarTop_xdjzag$ = get_scalarTop;\n package$typedGeometry.get_scalarLeft_xdjzag$ = get_scalarLeft;\n package$typedGeometry.get_center_xdjzag$ = get_center;\n package$typedGeometry.get_scalarX_xocuba$ = get_scalarX;\n package$typedGeometry.get_scalarY_xocuba$ = get_scalarY;\n package$typedGeometry.plus_cg1mpz$ = plus_4;\n package$typedGeometry.minus_cg1mpz$ = minus;\n package$typedGeometry.times_cg1mpz$ = times;\n package$typedGeometry.div_cg1mpz$ = div;\n package$typedGeometry.times_4nb5xq$ = times_0;\n package$typedGeometry.div_4nb5xq$ = div_0;\n package$typedGeometry.unaryMinus_e0pgg$ = unaryMinus;\n package$typedGeometry.transform_nj6yk8$ = transform;\n package$typedGeometry.plus_qnxb21$ = plus_5;\n package$typedGeometry.minus_qnxb21$ = minus_0;\n package$typedGeometry.times_qnxb21$ = times_1;\n package$typedGeometry.div_qnxb21$ = div_1;\n package$typedGeometry.div_i3tdhk$ = div_2;\n package$typedGeometry.times_i3tdhk$ = times_2;\n package$typedGeometry.unaryMinus_cr59ze$ = unaryMinus_0;\n package$typedGeometry.compareTo_85q7fw$ = compareTo;\n package$typedGeometry.newSpanRectangle_2d1svq$ = newSpanRectangle;\n package$typedGeometry.limit_106pae$ = limit;\n package$typedGeometry.contains_h8bixx$ = contains_1;\n package$typedGeometry.intersects_32samh$ = intersects;\n package$typedGeometry.xRange_h9e6jg$ = xRange;\n package$typedGeometry.yRange_h9e6jg$ = yRange;\n package$typedGeometry.limit_lddjmn$ = limit_0;\n Object.defineProperty(GeometryType, 'MULTI_POINT', {\n get: GeometryType$MULTI_POINT_getInstance\n });\n Object.defineProperty(GeometryType, 'MULTI_LINESTRING', {\n get: GeometryType$MULTI_LINESTRING_getInstance\n });\n Object.defineProperty(GeometryType, 'MULTI_POLYGON', {\n get: GeometryType$MULTI_POLYGON_getInstance\n });\n package$typedGeometry.GeometryType = GeometryType;\n Object.defineProperty(Geometry, 'Companion', {\n get: Geometry$Companion_getInstance\n });\n package$typedGeometry.Geometry = Geometry;\n package$typedGeometry.LineString = LineString;\n package$typedGeometry.MultiLineString = MultiLineString;\n package$typedGeometry.MultiPoint = MultiPoint;\n package$typedGeometry.MultiPolygon = MultiPolygon;\n package$typedGeometry.Polygon = Polygon;\n package$typedGeometry.Rect_init_94ua8u$ = Rect_init;\n package$typedGeometry.Rect = Rect;\n package$typedGeometry.Ring = Ring;\n package$typedGeometry.Scalar = Scalar;\n package$typedGeometry.Vec_init_vrm8gm$ = Vec_init;\n package$typedGeometry.Vec = Vec;\n package$typedGeometry.explicitVec_y7b45i$ = explicitVec;\n package$typedGeometry.explicitVec_vrm8gm$ = explicitVec_0;\n package$typedGeometry.newVec_4xl464$ = newVec;\n var package$typedKey = package$base.typedKey || (package$base.typedKey = {});\n package$typedKey.TypedKey = TypedKey;\n package$typedKey.TypedKeyHashMap = TypedKeyHashMap;\n var package$unsupported = package$base.unsupported || (package$base.unsupported = {});\n package$unsupported.UNSUPPORTED = UNSUPPORTED;\n package$unsupported.UNSUPPORTED_61zpoe$ = UNSUPPORTED_0;\n Object.defineProperty(Color, 'Companion', {\n get: Color$Companion_getInstance\n });\n var package$values = package$base.values || (package$base.values = {});\n package$values.Color = Color;\n Object.defineProperty(package$values, 'Colors', {\n get: Colors_getInstance\n });\n package$values.toPngDataUri_61zpoe$ = toPngDataUri;\n package$values.Font = Font;\n Object.defineProperty(FontFamily, 'Companion', {\n get: FontFamily$Companion_getInstance\n });\n package$values.FontFamily = FontFamily;\n package$values.HSV = HSV;\n package$values.Interval = Interval;\n package$values.Pair = Pair_0;\n package$values.SomeFig = SomeFig;\n Object.defineProperty(package$logging, 'PortableLogging', {\n get: PortableLogging_getInstance\n });\n SPECIAL_CHARS = mapOf([to(toBoxedChar(34), toBoxedChar(34)), to(toBoxedChar(92), toBoxedChar(92)), to(toBoxedChar(47), toBoxedChar(47)), to(toBoxedChar(98), toBoxedChar(8)), to(toBoxedChar(102), toBoxedChar(12)), to(toBoxedChar(110), toBoxedChar(10)), to(toBoxedChar(114), toBoxedChar(13)), to(toBoxedChar(116), toBoxedChar(9))]);\n var $receiver = until(0, 32);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(toBoxedChar(toChar(item)));\n }\n CONTROL_CHARS = toSet(destination);\n EARTH_RADIUS = 6378137.0;\n MIN_LONGITUDE = -180.0;\n MAX_LONGITUDE = 180.0;\n FULL_LONGITUDE = MAX_LONGITUDE - MIN_LONGITUDE;\n MIN_LATITUDE = -90.0;\n MAX_LATITUDE = 90.0;\n FULL_LATITUDE = MAX_LATITUDE - MIN_LATITUDE;\n EARTH_RECT = Rect_init(MIN_LONGITUDE, MIN_LATITUDE, FULL_LONGITUDE, FULL_LATITUDE);\n BBOX_CALCULATOR = new GeoBoundingBoxCalculator(EARTH_RECT, true, false);\n Kotlin.defineModule('lets-plot-base-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/RegexExtensions.kt?c518","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Duration.kt?57e0","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZone.kt?13d2","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZoneMoscow.kt?b1a5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/TimeZones.kt?ba1e","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/collections.kt?4ea3","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Strings.kt?4e99","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/./kotlin-dce-dev/runtime/arrayUtils.kt?7b24","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Sequences.kt?4687","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/regex.kt?0a6a","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/numberConversions.kt?49a1","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/algorithms/Geometry.kt?154f","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/DateLocale.kt?a10a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/Format.kt?9df9","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/dateFormat/Pattern.kt?c190","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Date.kt?9fc3","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/DateTime.kt?dc25","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/DateTimeUtil.kt?83fc","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Instant.kt?6f4e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Month.kt?1b62","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/Time.kt?0342","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Char.kt?2197","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/WeekDay.kt?b818","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/datetime/tz/DateSpecs.kt?373a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/EnumInfoFactory.kt?12af","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/EnumInfoImpl.kt?8f00","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/enums/Enums.kt?3ae7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Button.kt?49b6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Event.kt?9322","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/Key.kt?5df4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyEvent.kt?a294","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyModifiers.kt?456f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStroke.kt?9b43","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStrokeSpec.kt?8979","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/KeyStrokeSpecs.kt?1d8b","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/ModifierKey.kt?5f38","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/MouseEvent.kt?c3e5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/MouseEventSpec.kt?debd","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/event/PointEvent.kt?e6b5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/function/Functions.kt?ee36","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/function/Value.kt?82af","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Preconditions.kt?bbcf","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Strings.kt?0a39","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/base/Throwables.kt?22c6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/ClosedRange.kt?ef02","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Comparables.kt?24be","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/ComparatorOrdering.kt?cccb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Iterables.kt?38e9","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Lists.kt?74b6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Ordering.kt?196f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Sets.kt?cde7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/Stack.kt?7183","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/gcommon/collect/TreeMap.kt?ed91","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleRectangle.kt?a23c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleRectangles.kt?664b","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleSegment.kt?86b1","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/DoubleVector.kt?f66d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Rectangle.kt?1f0f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Rectangles.kt?0399","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Segment.kt?6b4a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/geometry/Vector.kt?ac75","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/jsObject/JsObjectSupport.kt?5591","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentArray.kt?e8fb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentObject.kt?7da5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentPrimitive.kt?5eeb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/FluentValue.kt?f41f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonFormatter.kt?7d5a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonLexer.kt?32db","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Ranges.kt?94da","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonParser.kt?7c06","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/JsonSupport.kt?5348","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/CharCode.kt?1167","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/json/Utils.kt?4443","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/listMap/ListMap.kt?c0ae","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/logging/PrintlnLogger.kt?4be6","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/math/Math.kt?1259","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/numberFormat/NumberFormat.kt?3d91","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/MatchResult.kt?8829","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/ChildList.kt?ce9e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/ChildProperty.kt?3276","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/children/SimpleComposite.kt?4bce","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/CollectionAdapter.kt?6397","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/CollectionItemEvent.kt?50fe","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/list/AbstractObservableList.kt?327f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/collections/list/ObservableArrayList.kt?a76c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/CompositeEventSource.kt?6ec0","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/EventSources.kt?d63c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/Listeners.kt?7ac5","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/event/MappingEventSource.kt?9f39","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/BaseReadableProperty.kt?978e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/DelayedValueProperty.kt?20a7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/PropertyBinding.kt?d0ae","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/PropertyChangeEvent.kt?6045","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/observable/property/ValueProperty.kt?f6eb","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/random/RandomGaussian.kt?7a79","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/random/RandomString.kt?a4a8","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/CompositeRegistration.kt?86f4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/Registration.kt?6be7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/throwableHandlers/ThrowableHandler.kt?639a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/registration/throwableHandlers/ThrowableHandlers.kt?e111","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoBoundingBoxCalculator.kt?9573","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoJson.kt?9f24","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/GeoRectangle.kt?80a7","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Geographic.kt?19e0","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/LongitudeSegment.kt?d739","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/MercatorUtils.kt?d373","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/QuadKey.kt?1597","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Quads.kt?bee8","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/SimpleFeature.kt?4179","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/stringFormat/StringFormat.kt?282d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/AbstractGeometryList.kt?b659","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Algorithms.kt?bf10","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Functions.kt?ae41","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Geometry.kt?29df","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/LineString.kt?4fe4","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiLineString.kt?2aba","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiPoint.kt?eb32","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/MultiPolygon.kt?4b65","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Polygon.kt?b466","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Rect.kt?e402","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Ring.kt?5a0e","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Scalar.kt?966f","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedGeometry/Vec.kt?954a","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/typedKey/TypedKeyHashMap.kt?cbee","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/unsupported/Unsupported.kt?d7bc","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Color.kt?dd42","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Colors.kt?5201","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/DataURI.kt?9e73","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Font.kt?e020","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/FontFamily.kt?bb4d","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/HSV.kt?7f7c","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Interval.kt?2612","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/values/Pair.kt?014b","webpack://LetsPlot/../base-portable/src/jsMain/kotlin/jetbrains/datalore/base/logging/PortableLogging.kt?0550","webpack://LetsPlot/../base-portable/src/commonMain/kotlin/jetbrains/datalore/base/spatial/Constants.kt?b916"],"names":[],"mappings":"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IAAA,oB;IAAA,6B;;;EACA,2C;IAAA,oB;IAAA,mC;;;EAGA,0C;IAAA,oB;IAAA,kC;;;EAEA,yC;IAAA,oB;IAAA,iC;;;EAEA,uC;IAAA,oB;IAAA,+B;;;EAEA,oD;IAAA,oB;IAAA,4C;;;EACA,uC;IAAA,oB;IAAA,+B;;;EACA,sC;IAAA,oB;IAAA,8B;;;EACA,8C;IAAA,oB;IAAA,sC;;;EACA,8C;IAAA,oB;IAAA,sC;;;EACA,sC;IAAA,oB;IAAA,8B;;EAQA,6B;IAAA,iC;IACI,qBjB9BoC,WiB8BhB,yBjB9BgB,C;;EiBgCpC,+C;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,6C;IAAA,gD;;IACI,4E;IACA,4E;;;EADA,mD;IAAA,mC;IAAA,2C;;;EACA,mD;IAAA,mC;IAAA,2C;;;;;;;EAFJ,yC;IAAA,6F;;;EAAA,8C;IAAA,a;MAAA,Y;QAAA,gD;MAAA,Y;QAAA,gD;MAAA,sG;;;;wDAKA,yB;IAAsD,gBAAT,gB;IV8wB1C,sB;;MAybS,Q;MAAhB,iD;QAAgB,cAAhB,e;QAAsB,IUvsC2C,OVusC7B,OUvsCgC,OAAH,gBVusC3C,C;UAAwB,qBAAO,O;UAAP,uB;;MAC9C,qBAAO,I;;;IUxsC0C,OV8wBjD,kB;;;;;;;;EUtxBA,yC;IAAA,oB;IAAA,wC;MAAA,uB;KAAA,iC;;;;;;;EApCJ,0B;IAAA,4oB;;;EAAA,+B;IAAA,a;MAAA,wB;QAAA,6C;MAAA,wB;QAAA,6C;MAAA,kB;QAAA,uC;MAAA,kB;QAAA,uC;MAAA,iC;QAAA,sD;MAAA,oB;QAAA,yC;MAAA,uB;QAAA,4C;MAAA,a;QAAA,kC;MAAA,mB;QAAA,wC;MAAA,kB;QAAA,uC;MAAA,iB;QAAA,sC;MAAA,e;QAAA,oC;MAAA,4B;QAAA,iD;MAAA,e;QAAA,oC;MAAA,c;QAAA,mC;MAAA,sB;QAAA,2C;MAAA,sB;QAAA,2C;MAAA,c;QAAA,mC;MAAA,uF;;;;ECEU,kC;IAsLN,4B;IAtLO,c;IAAc,kB;IAAkB,gB;IAenC,iB;;;;SAZA,Y;MACI,qBAAqB,sBAAS,kCAAT,C;MACrB,OAAe,gBAAR,CAAiB,CAAC,iBA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B;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,qC;IAAA,gB;IAAA,6B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,qC;IAAA,gB;IAAA,6B;;;EACA,kC;IAAA,gB;IAAA,0B;;;EACA,sC;IAAA,gB;IAAA,8B;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,gC;IAAA,gB;IAAA,wB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,mC;IAAA,gB;IAAA,2B;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,8B;IAAA,gB;IAAA,sB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,+B;IAAA,gB;IAAA,uB;;;EACA,iC;IAAA,gB;IAAA,yB;;;EACA,kC;IAAA,gB;IAAA,0B;;2BAEA,Y;IACI,OAAO,sB;EACX,C;;;;;;EAjFJ,sB;IAAA,4yD;;;EAAA,2B;IAAA,a;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;MAAA,S;QAAA,0B;M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AAI,kBAAS,UAAT,CAAqB,qBACpB,EAAO,2BAAP,CACA,EAAI,6BAAJ,CnGquCL,W;QAAhB,OAAgB,cAAhB,C;UAAgB,yB;UmGpuCe,mBnGouCF,OmGpuCE,U;;;QANnB,K;WASA,oB;Q/GLZ,IAAI,C+GMoB,GAAI,kBAAS,YAAT,C/GN5B,C;UACI,gB+GKkD,uD;U/GJlD,MAAM,8BAAyB,SAAQ,WAAjC,C;;QYouCM,U;QAAA,SmG9tCA,GAAI,kBAAS,YAAT,CAAuB,qBnG8tC3B,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UmG7tCe,mBnG6tCF,SmG7tCE,U;;;QAJnB,K;c/GLZ,IAAI,C+GaoB,GAAI,kBAAS,aAAT,C/Gb5B,C;UACI,gB+GYmD,2C;U/GXnD,MAAM,8BAAyB,SAAQ,WAAjC,C;;Q+GaM,kBAAkB,GAAI,kBAAS,aAAT,C;QACtB,QAAM,IAAN,C;eACI,O;YAAmC,gBAAxB,kBAAW,WAAX,C;YpC2DxB,0BoC3DoD,yB;;apC2DpD,YoC3DoD,OpC2DpD,GAAM,SAAN,C;YoC3Da,K;eACA,Y;YAA6C,kBAA7B,uBAAgB,WAAhB,C;YpC0D7B,+BoC1D8D,yB;;apC0D9D,YoC1D8D,OpC0D9D,GAAM,WAAN,C;YoC1Da,K;eACA,S;YAAuC,kBAA1B,oBAAa,WAAb,C;YpCyD1B,4BoCzDwD,yB;;apCyDxD,YoCzDwD,OpCyDxD,GAAM,WAAN,C;YoCzDa,K;eACA,Y;YAA6C,kBAA7B,uBAAgB,WAAhB,C;YpCwD7B,+BoCxD8D,yB;;apCwD9D,YoCxD8D,OpCwD9D,GAAM,WAAN,C;YoCxDa,K;eACA,iB;YAAuD,kBAAlC,4BAAqB,WAArB,C;YpCuDlC,oCoCvDwE,yB;;apCuDxE,YoCvDwE,OpCuDxE,GAAM,WAAN,C;YoCvDa,K;eACA,c;YAAiD,kBAA/B,yBAAkB,WAAlB,C;YpCsD/B,iCoCtDkE,yB;;apCsDlE,YoCtDkE,OpCsDlE,GAAM,WAAN,C;YoCtDa,K;kB/GqFyB,MAAM,2BAA8B,C+GpF/C,+BAA4B,I/GoFmB,YAA9B,C;;;Q+GhH3C,K;;EAgCJ,C;0CAEA,qB;IACI,OAAO,YACH,SAAU,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AAjB,C;;EAZnC,8D;ItH0HS,MAAM,2BsH1HP,uBtH0HqC,WAA9B,C;EsH1HkB,C;EACrB,gE;ItHyHH,MAAM,2BsHzHK,4BtHyHyB,WAA9B,C;EsHzHmC,C;EAC5C,gE;ItHwHG,MAAM,2BsHxHD,yBtHwH+B,WAA9B,C;EsHxH0B,C;EAC7B,gE;ItHuHH,MAAM,2BsHvHK,4BtHuHyB,WAA9B,C;EsHvHmC,C;EAC5B,gE;ItHsHb,MAAM,2BsHtHe,iCtHsHe,WAA9B,C;EsHtHkD,C;EACjD,gE;ItHqHP,MAAM,2BsHrHS,8BtHqHqB,WAA9B,C;EsHrHyC,C;;;;;;EAU5F,mD;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,iD;IAAA,oD;;IACI,sF;IACA,kG;IACA,0F;IACA,kG;IACA,8G;IACA,sG;IACA,kH;;;EANA,wD;IAAA,uC;IAAA,gD;;;EACA,8D;IAAA,uC;IAAA,sD;;;EACA,0D;IAAA,uC;IAAA,kD;;;EACA,8D;IAAA,uC;IAAA,sD;;;EACA,oE;IAAA,uC;IAAA,4D;;;EACA,gE;IAAA,uC;IAAA,wD;;;EACA,sE;IAAA,uC;IAAA,8D;;;;;;;EAPJ,6C;IAAA,uY;;;EAAA,kD;IAAA,a;MAAA,a;QAAA,qD;MAAA,mB;QAAA,2D;MAAA,e;QAAA,uD;MAAA,mB;QAAA,2D;MAAA,yB;QAAA,iE;MAAA,qB;QAAA,6D;MAAA,2B;QAAA,mE;MAAA,uG;;;;;;;;;;EA1BJ,qC;IAAA,oC;MAAA,mB;KAAA,6B;;ECAmB,2C;IAwEf,oC;IAvEA,wB;IACA,4B;IAOA,gC;IAW+B,IAAN,I;IARrB,yD;IAQqB,QAAM,eAAN,M;WACjB,e;QAA4B,gBAAO,iBAAiB,cAAjB,CAAP,C;QAA5B,K;WACA,e;QAUS,gBAPA,IADA,IADL,mDAAa,iBAAQ,cAAR,CACR,EAAI,wBAAJ,CACA,EAAI,4CAAJ,CAOA,C;QAVT,K;;QAFiB,K;;IAArB,gC;IAiBJ,kBAAiB,yBAAmB,K;;EAjCpC,gD;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,8C;IAAA,iD;;IACI,gG;IACA,gG;;;EADA,6D;IAAA,oC;IAAA,qD;;;EACA,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","file":"./kotlin-dce-dev/lets-plot-base-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n/**\n * Converts the string into a regular expression [Regex] with the default options.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(): Regex = Regex(this)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified single [option].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(option: RegexOption): Regex = Regex(this, option)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified set of [options].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(options: Set<RegexOption>): Regex = Regex(this, options)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nclass Duration(val duration: Long) : Comparable<Duration> {\n\n    val isPositive: Boolean\n        get() = duration > 0\n\n    fun mul(times: Long): Duration {\n        return Duration(duration * times)\n    }\n\n    fun add(duration: Duration): Duration {\n        return Duration(this.duration + duration.duration)\n    }\n\n    fun sub(duration: Duration): Duration {\n        return Duration(this.duration - duration.duration)\n    }\n\n    operator fun div(duration: Duration): Double {\n        return this.duration / duration.duration.toDouble()\n    }\n\n    override fun compareTo(other: Duration): Int {\n        val delta = duration - other.duration\n        return if (delta > 0) {\n            1\n        } else if (delta == 0L) {\n            0\n        } else {\n            -1\n        }\n    }\n\n    override fun hashCode(): Int {\n        return duration.toInt()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Duration) false else duration == other.duration\n\n    }\n\n    override fun toString(): String {\n        return \"Duration : \" + duration + \"ms\"\n    }\n\n    companion object {\n        val MS = Duration(1)\n        val SECOND = MS.mul(1000)\n        val MINUTE = SECOND.mul(60)\n        val HOUR = MINUTE.mul(60)\n        val DAY = HOUR.mul(24)\n        val WEEK = DAY.mul(7)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\nabstract class TimeZone protected constructor(val id: String?) {\n\n    init {\n//        if (id != null) {\n//            ourTimeZones.put(id, this)\n//        }\n    }\n\n    abstract fun toDateTime(instant: Instant): DateTime\n    abstract fun toInstant(dateTime: DateTime): Instant\n\n    fun convertTo(toConvert: DateTime, to: TimeZone): DateTime {\n        return if (to === this) toConvert else to.toDateTime(toInstant(toConvert))\n    }\n\n    fun convertTimeAtDay(srcTime: Time, dstDate: Date, dstTimeZone: TimeZone): Time {\n        var src = DateTime(dstDate, srcTime)\n        var dst = convertTo(src, dstTimeZone)\n        val dayDiff = dstDate.compareTo(dst.date)\n        if (dayDiff != 0) {\n            val correctedDay = if (dayDiff > 0) dstDate.nextDate() else dstDate.prevDate()\n            src = DateTime(correctedDay, srcTime)\n            dst = convertTo(src, dstTimeZone)\n        }\n        return dst.time\n    }\n\n    fun getTimeZoneShift(instant: Instant): Duration {\n        val utcDateTime = toDateTime(instant)\n        return instant.to(UTC.toInstant(utcDateTime))\n    }\n\n    override fun toString(): String {\n        return id!!\n    }\n\n    companion object {\n//        private val ourTimeZones = TreeMap<String, TimeZone>()\n\n        val UTC = TimeZones.utc()\n        val BERLIN = TimeZones.withEuSummerTime(\"Europe/Berlin\", Duration.HOUR.mul(1))\n        val MOSCOW: TimeZone = TimeZoneMoscow()\n        val NY = TimeZones.withUsSummerTime(\"America/New_York\", Duration.HOUR.mul(-5))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\ninternal class TimeZoneMoscow : TimeZone(ID) {\n    private val myOldOffset = Duration.HOUR.mul(4)\n    private val myNewOffset = Duration.HOUR.mul(3)\n    private val myOldTz = TimeZones.offset(null, myOldOffset, TimeZone.UTC)\n    private val myNewTz = TimeZones.offset(null, myNewOffset, TimeZone.UTC)\n\n    private val myOffsetChangeTime = DateTime(Date(26, Month.OCTOBER, 2014), Time(2, 0))\n    private val myOffsetChangeInstant = myOldTz.toInstant(myOffsetChangeTime)\n\n    override fun toDateTime(instant: Instant): DateTime {\n        return if (instant.compareTo(myOffsetChangeInstant) >= 0) myNewTz.toDateTime(instant) else myOldTz.toDateTime(instant)\n    }\n\n    override fun toInstant(dateTime: DateTime): Instant {\n        return if (dateTime.compareTo(myOffsetChangeTime) >= 0) myNewTz.toInstant(dateTime) else myOldTz.toInstant(dateTime)\n    }\n\n    companion object {\n        private val ID = \"Europe/Moscow\"\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.*\n\ninternal object TimeZones {\n    private const val MILLIS_IN_SECOND: Long = 1000\n    private const val MILLIS_IN_MINUTE = MILLIS_IN_SECOND * 60\n    private const val MILLIS_IN_HOUR = MILLIS_IN_MINUTE * 60\n    private const val MILLIS_IN_DAY = MILLIS_IN_HOUR * 24\n\n    private fun toDateTime(instant: Instant, offset: Duration): DateTime {\n        @Suppress(\"NAME_SHADOWING\")\n        var instant = instant\n        instant = instant.add(offset)\n\n        val days = (instant.timeSinceEpoch / MILLIS_IN_DAY).toInt()\n        val date = Date.EPOCH.addDays(days)\n        var rest = instant.timeSinceEpoch % MILLIS_IN_DAY\n        val hour = (rest / MILLIS_IN_HOUR).toInt()\n        rest %= MILLIS_IN_HOUR\n        val minutes = (rest / MILLIS_IN_MINUTE).toInt()\n        rest %= MILLIS_IN_MINUTE\n        val seconds = (rest / MILLIS_IN_SECOND).toInt()\n        rest %= MILLIS_IN_SECOND\n        val milliseconds = (rest % MILLIS_IN_SECOND).toInt()\n        return DateTime(date, Time(hour, minutes, seconds, milliseconds))\n    }\n\n    private fun toInstant(dateTime: DateTime, offset: Duration): Instant {\n        return Instant(toMillis(dateTime.date) + toMillis(dateTime.time)).sub(offset)\n    }\n\n    private fun toMillis(time: Time): Long {\n        val minutes = time.hours * 60L + time.minutes\n        val seconds = minutes * 60 + time.seconds\n        return seconds * 1000 + time.milliseconds\n    }\n\n    private fun toMillis(date: Date): Long {\n        return date.daysFrom(Date.EPOCH) * MILLIS_IN_DAY\n    }\n\n    fun utc(): TimeZone {\n        return object : TimeZone(\"UTC\") {\n            override fun toDateTime(instant: Instant): DateTime {\n                return toDateTime(instant, Duration(0))\n            }\n\n            override fun toInstant(dateTime: DateTime): Instant {\n                return toInstant(dateTime, Duration(0))\n            }\n        }\n    }\n\n    fun offset(id: String?, offset: Duration, base: TimeZone): TimeZone {\n        return object : TimeZone(id) {\n            override fun toDateTime(instant: Instant): DateTime {\n                return base.toDateTime(instant.add(offset))\n            }\n\n            override fun toInstant(dateTime: DateTime): Instant {\n                return base.toInstant(dateTime).sub(offset)\n            }\n\n        }\n    }\n\n    fun withEuSummerTime(id: String, offset: Duration): TimeZone {\n        val startSpec = DateSpecs.last(WeekDay.SUNDAY, Month.MARCH)\n        val endSpec = DateSpecs.last(WeekDay.SUNDAY, Month.OCTOBER)\n        val utcChangeTime = Time(1, 0)\n        return object : DSTimeZone(id, offset) {\n            override fun getStartInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(startSpec.getDate(year), utcChangeTime))\n            }\n\n            override fun getEndInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(endSpec.getDate(year), utcChangeTime))\n            }\n\n        }\n    }\n\n    fun withUsSummerTime(id: String, offset: Duration): TimeZone {\n        val startSpec = DateSpecs.first(WeekDay.SUNDAY, Month.MARCH, 2)\n        val endSpec = DateSpecs.first(WeekDay.SUNDAY, Month.NOVEMBER)\n\n        return object : DSTimeZone(id, offset) {\n            override fun getStartInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(startSpec.getDate(year), Time(2, 0))).sub(offset)\n            }\n\n            override fun getEndInstant(year: Int): Instant {\n                return UTC.toInstant(DateTime(endSpec.getDate(year), Time(2, 0))).sub(offset.add(Duration.HOUR))\n            }\n\n        }\n    }\n\n    private abstract class DSTimeZone(id: String, offset: Duration) : TimeZone(id) {\n        private val myTz: TimeZone = offset(null, offset, UTC)\n        private val mySummerTz: TimeZone = offset(null, offset.add(Duration.HOUR), UTC)\n\n        override fun toDateTime(instant: Instant): DateTime {\n            val tzDt = myTz.toDateTime(instant)\n            val start = getStartInstant(tzDt.year)\n            val end = getEndInstant(tzDt.year)\n            return if (instant > start && instant < end) {\n                mySummerTz.toDateTime(instant)\n            } else {\n                tzDt\n            }\n        }\n\n        override fun toInstant(dateTime: DateTime): Instant {\n            val startDt = toDateTime(getStartInstant(dateTime.year))\n            val endDt = toDateTime(getEndInstant(dateTime.year))\n\n            return if (dateTime > startDt && dateTime < endDt) {\n                mySummerTz.toInstant(dateTime)\n            } else {\n                myTz.toInstant(dateTime)\n            }\n        }\n\n        protected abstract fun getStartInstant(year: Int): Instant\n\n        protected abstract fun getEndInstant(year: Int): Instant\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\nimport kotlin.comparisons.naturalOrder\nimport kotlin.random.Random\n\n/**\n * Returns the array if it's not `null`, or an empty array otherwise.\n * @sample samples.collections.Arrays.Usage.arrayOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Array<out T>?.orEmpty(): Array<out T> = this ?: emptyArray<T>()\n\n/**\n * Returns a *typed* array containing all of the elements of this collection.\n *\n * Allocates an array of runtime type `T` having its size equal to the size of this collection\n * and populates the array with the elements of this collection.\n * @sample samples.collections.Collections.Collections.collectionToTypedArray\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Collection<T>.toTypedArray(): Array<T> = copyToArray(this)\n\n@JsName(\"copyToArray\")\n@PublishedApi\ninternal fun <T> copyToArray(collection: Collection<T>): Array<T> {\n    return if (collection.asDynamic().toArray !== undefined)\n        collection.asDynamic().toArray().unsafeCast<Array<T>>()\n    else\n        copyToArrayImpl(collection).unsafeCast<Array<T>>()\n}\n\n@JsName(\"copyToArrayImpl\")\ninternal actual fun copyToArrayImpl(collection: Collection<*>): Array<Any?> {\n    val array = emptyArray<Any?>()\n    val iterator = collection.iterator()\n    while (iterator.hasNext())\n        array.asDynamic().push(iterator.next())\n    return array\n}\n\n@JsName(\"copyToExistingArrayImpl\")\ninternal actual fun <T> copyToArrayImpl(collection: Collection<*>, array: Array<T>): Array<T> {\n    if (array.size < collection.size)\n        return copyToArrayImpl(collection).unsafeCast<Array<T>>()\n\n    val iterator = collection.iterator()\n    var index = 0\n    while (iterator.hasNext()) {\n        array[index++] = iterator.next().unsafeCast<T>()\n    }\n    if (index < array.size) {\n        array[index] = null.unsafeCast<T>()\n    }\n    return array\n}\n\n\n/**\n * Returns an immutable list containing only the specified object [element].\n */\npublic fun <T> listOf(element: T): List<T> = arrayListOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E> {\n    return ArrayList<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E> {\n    checkBuilderCapacity(capacity)\n    return ArrayList<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable set containing only the specified object [element].\n */\npublic fun <T> setOf(element: T): Set<T> = hashSetOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable map, mapping only the specified key to the\n * specified value.\n */\npublic fun <K, V> mapOf(pair: Pair<K, V>): Map<K, V> = hashMapOf(pair)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Fills the list with the provided [value].\n *\n * Each element in the list gets replaced with the [value].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.fill(value: T): Unit {\n    for (index in 0..lastIndex) {\n        this[index] = value\n    }\n}\n\n/**\n * Randomly shuffles elements in this list.\n *\n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.shuffle(): Unit = shuffle(Random)\n\n/**\n * Returns a new list with the elements of this list randomly shuffled.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> Iterable<T>.shuffled(): List<T> = toMutableList().apply { shuffle() }\n\n/**\n * Sorts elements in the list in-place according to their natural sort order.\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableList\n */\npublic actual fun <T : Comparable<T>> MutableList<T>.sort(): Unit {\n    collectionsSort(this, naturalOrder())\n}\n\n/**\n * Sorts elements in the list in-place according to the order specified with [comparator].\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableListWith\n */\npublic actual fun <T> MutableList<T>.sortWith(comparator: Comparator<in T>): Unit {\n    collectionsSort(this, comparator)\n}\n\nprivate fun <T> collectionsSort(list: MutableList<T>, comparator: Comparator<in T>) {\n    if (list.size <= 1) return\n\n    val array = copyToArray(list)\n    sortArrayWith(array, comparator)\n\n    for (i in 0 until array.size) {\n        list[i] = array[i]\n    }\n}\n\ninternal actual fun <T> arrayOfNulls(reference: Array<T>, size: Int): Array<T> {\n    return arrayOfNulls<Any>(size).unsafeCast<Array<T>>()\n}\n\n@SinceKotlin(\"1.3\")\n@PublishedApi\n@JsName(\"arrayCopy\")\ninternal fun <T> arrayCopy(source: Array<out T>, destination: Array<in T>, destinationOffset: Int, startIndex: Int, endIndex: Int) {\n    AbstractList.checkRangeIndexes(startIndex, endIndex, source.size)\n    val rangeSize = endIndex - startIndex\n    AbstractList.checkRangeIndexes(destinationOffset, destinationOffset + rangeSize, destination.size)\n\n    if (js(\"ArrayBuffer\").isView(destination) && js(\"ArrayBuffer\").isView(source)) {\n        val subrange = source.asDynamic().subarray(startIndex, endIndex)\n        destination.asDynamic().set(subrange, destinationOffset)\n    } else {\n        if (source !== destination || destinationOffset <= startIndex) {\n            for (index in 0 until rangeSize) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        } else {\n            for (index in rangeSize - 1 downTo 0) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        }\n    }\n}\n\n// no singleton map implementation in js, return map as is\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<K, V>.toSingletonMapOrSelf(): Map<K, V> = this\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<out K, V>.toSingletonMap(): Map<K, V> = this.toMutableMap()\n\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <T> Array<out T>.copyToArrayOfAny(isVarargs: Boolean): Array<out Any?> =\n    if (isVarargs)\n    // no need to copy vararg array in JS\n        this\n    else\n        this.copyOf()\n\n\n\n@PublishedApi\ninternal actual fun checkIndexOverflow(index: Int): Int {\n    if (index < 0) {\n        throwIndexOverflow()\n    }\n    return index\n}\n\n@PublishedApi\ninternal actual fun checkCountOverflow(count: Int): Int {\n    if (count < 0) {\n        throwCountOverflow()\n    }\n    return count\n}\n\n\n/**\n * JS map and set implementations do not make use of capacities or load factors.\n */\n@PublishedApi\ninternal actual fun mapCapacity(expectedSize: Int) = expectedSize\n\n/**\n * Checks a collection builder function capacity argument.\n * In JS no validation is made in Map/Set constructor yet.\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@PublishedApi\ninternal fun checkBuilderCapacity(capacity: Int) {\n    require(capacity >= 0) { \"capacity must be non-negative.\" }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns a character at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharSequence.elementAt(index: Int): Char\n\n/**\n * Returns a character at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns a character at the given [index] or `null` if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first character.\n * @throws [NoSuchElementException] if the char sequence is empty.\n */\npublic fun CharSequence.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first character matching the given [predicate].\n * @throws [NoSuchElementException] if no such character is found.\n */\npublic inline fun CharSequence.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to characters of this char sequence in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <R : Any> CharSequence.firstNotNullOf(transform: (Char) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the char sequence was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to characters of this char sequence in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <R : Any> CharSequence.firstNotNullOfOrNull(transform: (Char) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first character, or `null` if the char sequence is empty.\n */\npublic fun CharSequence.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first character matching the given [predicate], or `null` if character was not found.\n */\npublic inline fun CharSequence.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns a character at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this char sequence.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns a character at the given [index] or `null` if the [index] is out of bounds of this char sequence.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharSequence.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns index of the first character matching the given [predicate], or -1 if the char sequence does not contain such character.\n */\npublic inline fun CharSequence.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last character matching the given [predicate], or -1 if the char sequence does not contain such character.\n */\npublic inline fun CharSequence.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last character.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n * \n * @sample samples.text.Strings.last\n */\npublic fun CharSequence.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last character matching the given [predicate].\n * \n * @throws NoSuchElementException if no such character is found.\n * \n * @sample samples.text.Strings.last\n */\npublic inline fun CharSequence.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n}\n\n/**\n * Returns the last character, or `null` if the char sequence is empty.\n * \n * @sample samples.text.Strings.last\n */\npublic fun CharSequence.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[length - 1]\n}\n\n/**\n * Returns the last character matching the given [predicate], or `null` if no such character was found.\n * \n * @sample samples.text.Strings.last\n */\npublic inline fun CharSequence.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random character from this char sequence.\n * \n * @throws NoSuchElementException if this char sequence is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random character from this char sequence using the specified source of randomness.\n * \n * @throws NoSuchElementException if this char sequence is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharSequence.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Char sequence is empty.\")\n    return get(random.nextInt(length))\n}\n\n/**\n * Returns a random character from this char sequence, or `null` if this char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random character from this char sequence using the specified source of randomness, or `null` if this char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharSequence.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(length))\n}\n\n/**\n * Returns the single character, or throws an exception if the char sequence is empty or has more than one character.\n */\npublic fun CharSequence.single(): Char {\n    return when (length) {\n        0 -> throw NoSuchElementException(\"Char sequence is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Char sequence has more than one element.\")\n    }\n}\n\n/**\n * Returns the single character matching the given [predicate], or throws exception if there is no or more than one matching character.\n */\npublic inline fun CharSequence.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Char sequence contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Char sequence contains no character matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single character, or `null` if the char sequence is empty or has more than one character.\n */\npublic fun CharSequence.singleOrNull(): Char? {\n    return if (length == 1) this[0] else null\n}\n\n/**\n * Returns the single character matching the given [predicate], or `null` if character was not found or more than one character was found.\n */\npublic inline fun CharSequence.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a subsequence of this char sequence with the first [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun CharSequence.drop(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return subSequence(n.coerceAtMost(length), length)\n}\n\n/**\n * Returns a string with the first [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun String.drop(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return substring(n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence with the last [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun CharSequence.dropLast(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return take((length - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a string with the last [n] characters removed.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.drop\n */\npublic fun String.dropLast(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return take((length - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a subsequence of this char sequence containing all characters except last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun CharSequence.dropLastWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in lastIndex downTo 0)\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n    return \"\"\n}\n\n/**\n * Returns a string containing all characters except last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun String.dropLastWhile(predicate: (Char) -> Boolean): String {\n    for (index in lastIndex downTo 0)\n        if (!predicate(this[index]))\n            return substring(0, index + 1)\n    return \"\"\n}\n\n/**\n * Returns a subsequence of this char sequence containing all characters except first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun CharSequence.dropWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n    return \"\"\n}\n\n/**\n * Returns a string containing all characters except first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.drop\n */\npublic inline fun String.dropWhile(predicate: (Char) -> Boolean): String {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return substring(index)\n    return \"\"\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that match the given [predicate].\n * \n * @sample samples.text.Strings.filter\n */\npublic inline fun CharSequence.filter(predicate: (Char) -> Boolean): CharSequence {\n    return filterTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that match the given [predicate].\n * \n * @sample samples.text.Strings.filter\n */\npublic inline fun String.filter(predicate: (Char) -> Boolean): String {\n    return filterTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that match the given [predicate].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharSequence.filterIndexed(predicate: (index: Int, Char) -> Boolean): CharSequence {\n    return filterIndexedTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that match the given [predicate].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun String.filterIndexed(predicate: (index: Int, Char) -> Boolean): String {\n    return filterIndexedTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Appends all characters matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of a character and the character itself\n * and returns the result of predicate evaluation on the character.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : Appendable> CharSequence.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.append(element)\n    }\n    return destination\n}\n\n/**\n * Returns a char sequence containing only those characters from the original char sequence that do not match the given [predicate].\n * \n * @sample samples.text.Strings.filterNot\n */\npublic inline fun CharSequence.filterNot(predicate: (Char) -> Boolean): CharSequence {\n    return filterNotTo(StringBuilder(), predicate)\n}\n\n/**\n * Returns a string containing only those characters from the original string that do not match the given [predicate].\n * \n * @sample samples.text.Strings.filterNot\n */\npublic inline fun String.filterNot(predicate: (Char) -> Boolean): String {\n    return filterNotTo(StringBuilder(), predicate).toString()\n}\n\n/**\n * Appends all characters not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : Appendable> CharSequence.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.append(element)\n    return destination\n}\n\n/**\n * Appends all characters matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : Appendable> CharSequence.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (index in 0 until length) {\n        val element = get(index)\n        if (predicate(element)) destination.append(element)\n    }\n    return destination\n}\n\n/**\n * Returns a char sequence containing characters of the original char sequence at the specified range of [indices].\n */\npublic fun CharSequence.slice(indices: IntRange): CharSequence {\n    if (indices.isEmpty()) return \"\"\n    return subSequence(indices)\n}\n\n/**\n * Returns a string containing characters of the original string at the specified range of [indices].\n */\npublic fun String.slice(indices: IntRange): String {\n    if (indices.isEmpty()) return \"\"\n    return substring(indices)\n}\n\n/**\n * Returns a char sequence containing characters of the original char sequence at specified [indices].\n */\npublic fun CharSequence.slice(indices: Iterable<Int>): CharSequence {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return \"\"\n    val result = StringBuilder(size)\n    for (i in indices) {\n        result.append(get(i))\n    }\n    return result\n}\n\n/**\n * Returns a string containing characters of the original string at specified [indices].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.slice(indices: Iterable<Int>): String {\n    return (this as CharSequence).slice(indices).toString()\n}\n\n/**\n * Returns a subsequence of this char sequence containing the first [n] characters from this char sequence, or the entire char sequence if this char sequence is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun CharSequence.take(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return subSequence(0, n.coerceAtMost(length))\n}\n\n/**\n * Returns a string containing the first [n] characters from this string, or the entire string if this string is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun String.take(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    return substring(0, n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence containing the last [n] characters from this char sequence, or the entire char sequence if this char sequence is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun CharSequence.takeLast(n: Int): CharSequence {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    val length = length\n    return subSequence(length - n.coerceAtMost(length), length)\n}\n\n/**\n * Returns a string containing the last [n] characters from this string, or the entire string if this string is shorter.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.text.Strings.take\n */\npublic fun String.takeLast(n: Int): String {\n    require(n >= 0) { \"Requested character count $n is less than zero.\" }\n    val length = length\n    return substring(length - n.coerceAtMost(length))\n}\n\n/**\n * Returns a subsequence of this char sequence containing last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun CharSequence.takeLastWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return subSequence(index + 1, length)\n        }\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Returns a string containing last characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun String.takeLastWhile(predicate: (Char) -> Boolean): String {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return substring(index + 1)\n        }\n    }\n    return this\n}\n\n/**\n * Returns a subsequence of this char sequence containing the first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun CharSequence.takeWhile(predicate: (Char) -> Boolean): CharSequence {\n    for (index in 0 until length)\n        if (!predicate(get(index))) {\n            return subSequence(0, index)\n        }\n    return subSequence(0, length)\n}\n\n/**\n * Returns a string containing the first characters that satisfy the given [predicate].\n * \n * @sample samples.text.Strings.take\n */\npublic inline fun String.takeWhile(predicate: (Char) -> Boolean): String {\n    for (index in 0 until length)\n        if (!predicate(get(index))) {\n            return substring(0, index)\n        }\n    return this\n}\n\n/**\n * Returns a char sequence with characters in reversed order.\n */\npublic fun CharSequence.reversed(): CharSequence {\n    return StringBuilder(this).reverse()\n}\n\n/**\n * Returns a string with characters in reversed order.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.reversed(): String {\n    return (this as CharSequence).reversed().toString()\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to characters of the given char sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associate\n */\npublic inline fun <K, V> CharSequence.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the characters from the given char sequence indexed by the key\n * returned from [keySelector] function applied to each character.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateBy\n */\npublic inline fun <K> CharSequence.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to characters of the given char sequence.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateByWithValueTransform\n */\npublic inline fun <K, V> CharSequence.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(length).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each character of the given char sequence\n * and value is the character itself.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharSequence.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to characters of the given char sequence.\n * \n * If any two characters would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharSequence.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each character of the given char sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.text.Strings.associateTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharSequence.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are characters from the given char sequence and values are\n * produced by the [valueSelector] function applied to each character.\n * \n * If any two characters are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original char sequence.\n * \n * @sample samples.text.Strings.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <V> CharSequence.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(length.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each character of the given char sequence,\n * where key is the character itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two characters are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.text.Strings.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <V, M : MutableMap<in Char, in V>> CharSequence.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all characters to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharSequence.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all characters.\n */\npublic fun CharSequence.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(length.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all characters.\n */\npublic fun CharSequence.toList(): List<Char> {\n    return when (length) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all characters of this char sequence.\n */\npublic fun CharSequence.toMutableList(): MutableList<Char> {\n    return toCollection(ArrayList<Char>(length))\n}\n\n/**\n * Returns a [Set] of all characters.\n * \n * The returned set preserves the element iteration order of the original char sequence.\n */\npublic fun CharSequence.toSet(): Set<Char> {\n    return when (length) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(length.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each character of original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharSequence.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each character\n * and its index in the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each character\n * and its index in the original char sequence, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each character of original char sequence, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups characters of the original char sequence by the key returned by the given [keySelector] function\n * applied to each character and returns a map where each group key is associated with a list of corresponding characters.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharSequence.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each character of the original char sequence\n * by the key returned by the given [keySelector] function applied to the character\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharSequence.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups characters of the original char sequence by the key returned by the given [keySelector] function\n * applied to each character and puts to the [destination] map each group key associated with a list of corresponding characters.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharSequence.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each character of the original char sequence\n * by the key returned by the given [keySelector] function applied to the character\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharSequence.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a char sequence to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each character.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <K> CharSequence.groupingBy(crossinline keySelector: (Char) -> K): Grouping<Char, K> {\n    return object : Grouping<Char, K> {\n        override fun sourceIterator(): Iterator<Char> = this@groupingBy.iterator()\n        override fun keyOf(element: Char): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each character in the original char sequence.\n * \n * @sample samples.text.Strings.map\n */\npublic inline fun <R> CharSequence.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(length), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each character and its index in the original char sequence.\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R> CharSequence.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(length), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each character and its index in the original char sequence.\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R : Any> CharSequence.mapIndexedNotNull(transform: (index: Int, Char) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each character and its index in the original char sequence\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R : Any, C : MutableCollection<in R>> CharSequence.mapIndexedNotNullTo(destination: C, transform: (index: Int, Char) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each character and its index in the original char sequence\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of a character and the character itself\n * and returns the result of the transform applied to the character.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each character in the original char sequence.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <R : Any> CharSequence.mapNotNull(transform: (Char) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each character in the original char sequence\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <R : Any, C : MutableCollection<in R>> CharSequence.mapNotNullTo(destination: C, transform: (Char) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each character of the original char sequence\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharSequence.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each character of the original char sequence\n * into an [IndexedValue] containing the index of that character and the character itself.\n */\npublic fun CharSequence.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns `true` if all characters match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharSequence.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if char sequence has at least one character.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharSequence.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one character matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharSequence.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the length of this char sequence.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.count(): Int {\n    return length\n}\n\n/**\n * Returns the number of characters matching the given [predicate].\n */\npublic inline fun CharSequence.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes a character and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Returns the specified [initial] value if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharSequence.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each character.\n */\npublic inline fun CharSequence.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each character, providing sequential index with the character.\n * @param [action] function that takes the index of a character and the character itself\n * and performs the action on the character.\n */\npublic inline fun CharSequence.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharSequence.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first character yielding the largest value of the given function or `null` if there are no characters.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharSequence.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest character or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first character having the largest value according to the provided [comparator] or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharSequence.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first character yielding the smallest value of the given function or `null` if there are no characters.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharSequence.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharSequence.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence.\n * \n * @throws NoSuchElementException if the char sequence is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each character in the char sequence or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharSequence.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest character or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharSequence.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first character having the smallest value according to the provided [comparator] or `null` if there are no characters.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharSequence.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the char sequence has no characters.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharSequence.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no characters match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharSequence.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each character and returns the char sequence itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <S : CharSequence> S.onEach(action: (Char) -> Unit): S {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each character, providing sequential index with the character,\n * and returns the char sequence itself afterwards.\n * @param [action] function that takes the index of a character and the character itself\n * and performs the action on the character.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S : CharSequence> S.onEachIndexed(action: (index: Int, Char) -> Unit): S {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and a character,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharSequence.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value and the character itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharSequence.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character with its index in the original char sequence.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, current accumulator value and the character itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first character and applying [operation] from left to right\n * to current accumulator value and each character.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and a character,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharSequence.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes a character and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharSequence.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Throws an exception if this char sequence is empty. If the char sequence can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharSequence.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty char sequence can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character with its index in the original char sequence and current accumulator value.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes the index of a character, the character itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last character and applying [operation] from right to left\n * to each character and current accumulator value.\n * \n * Returns `null` if the char sequence is empty.\n * \n * @param [operation] function that takes a character and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharSequence.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R> CharSequence.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(length + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R> CharSequence.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(length + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with the first character of this char sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(length).apply { add(accumulator) }\n    for (index in 1 until length) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with the first character of this char sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharSequence.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(length).apply { add(accumulator) }\n    for (index in 1 until length) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and a character, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <R> CharSequence.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each character, its index in the original char sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of a character, current accumulator value\n * and the character itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <R> CharSequence.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharSequence.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharSequence.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each character in the char sequence.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Splits this char sequence into a list of strings each not exceeding the given [size].\n * \n * The last string in the resulting list may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each string, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.chunked(size: Int): List<String> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this char sequence into several char sequences each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each char sequence.\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last char sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each char sequence, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.chunked(size: Int, transform: (CharSequence) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Splits this char sequence into a sequence of strings each not exceeding the given [size].\n * \n * The last string in the resulting sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each string, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.chunkedSequence(size: Int): Sequence<String> {\n    return chunkedSequence(size) { it.toString() }\n}\n\n/**\n * Splits this char sequence into several char sequences each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return sequence of results of the [transform] applied to an each char sequence.\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last char sequence may have fewer characters than the given [size].\n * \n * @param size the number of elements to take in each char sequence, must be positive and can be greater than the number of elements in this char sequence.\n * \n * @sample samples.text.Strings.chunkedTransformToSequence\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.chunkedSequence(size: Int, transform: (CharSequence) -> R): Sequence<R> {\n    return windowedSequence(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Splits the original char sequence into pair of char sequences,\n * where *first* char sequence contains characters for which [predicate] yielded `true`,\n * while *second* char sequence contains characters for which [predicate] yielded `false`.\n * \n * @sample samples.text.Strings.partition\n */\npublic inline fun CharSequence.partition(predicate: (Char) -> Boolean): Pair<CharSequence, CharSequence> {\n    val first = StringBuilder()\n    val second = StringBuilder()\n    for (element in this) {\n        if (predicate(element)) {\n            first.append(element)\n        } else {\n            second.append(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original string into pair of strings,\n * where *first* string contains characters for which [predicate] yielded `true`,\n * while *second* string contains characters for which [predicate] yielded `false`.\n * \n * @sample samples.text.Strings.partition\n */\npublic inline fun String.partition(predicate: (Char) -> Boolean): Pair<String, String> {\n    val first = StringBuilder()\n    val second = StringBuilder()\n    for (element in this) {\n        if (predicate(element)) {\n            first.append(element)\n        } else {\n            second.append(element)\n        }\n    }\n    return Pair(first.toString(), second.toString())\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this char sequence with the given [step], where each\n * snapshot is a string.\n * \n * Several last strings may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<String> {\n    return windowed(size, step, partialWindows) { it.toString() }\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each char sequence representing a view over the window of the given [size]\n * sliding along this char sequence with the given [step].\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last char sequences may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (CharSequence) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    val thisSize = this.length\n    val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n    val result = ArrayList<R>(resultCapacity)\n    var index = 0\n    while (index in 0 until thisSize) {\n        val end = index + size\n        val coercedEnd = if (end < 0 || end > thisSize) { if (partialWindows) thisSize else break } else end\n        result.add(transform(subSequence(index, coercedEnd)))\n        index += step\n    }\n    return result\n}\n\n/**\n * Returns a sequence of snapshots of the window of the given [size]\n * sliding along this char sequence with the given [step], where each\n * snapshot is a string.\n * \n * Several last strings may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.windowedSequence(size: Int, step: Int = 1, partialWindows: Boolean = false): Sequence<String> {\n    return windowedSequence(size, step, partialWindows) { it.toString() }\n}\n\n/**\n * Returns a sequence of results of applying the given [transform] function to\n * an each char sequence representing a view over the window of the given [size]\n * sliding along this char sequence with the given [step].\n * \n * Note that the char sequence passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last char sequences may have fewer characters than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this char sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <R> CharSequence.windowedSequence(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (CharSequence) -> R): Sequence<R> {\n    checkWindowSizeStep(size, step)\n    val windows = (if (partialWindows) indices else 0 until length - size + 1) step step\n    return windows.asSequence().map { index ->\n        val end = index + size\n        val coercedEnd = if (end < 0 || end > length) length else end\n        transform(subSequence(index, coercedEnd))\n    }\n}\n\n/**\n * Returns a list of pairs built from the characters of `this` and the [other] char sequences with the same index\n * The returned list has length of the shortest char sequence.\n * \n * @sample samples.text.Strings.zip\n */\npublic infix fun CharSequence.zip(other: CharSequence): List<Pair<Char, Char>> {\n    return zip(other) { c1, c2 -> c1 to c2 }\n}\n\n/**\n * Returns a list of values built from the characters of `this` and the [other] char sequences with the same index\n * using the provided [transform] function applied to each pair of characters.\n * The returned list has length of the shortest char sequence.\n * \n * @sample samples.text.Strings.zipWithTransform\n */\npublic inline fun <V> CharSequence.zip(other: CharSequence, transform: (a: Char, b: Char) -> V): List<V> {\n    val length = minOf(this.length, other.length)\n    val list = ArrayList<V>(length)\n    for (i in 0 until length) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent characters in this char sequence.\n * \n * The returned list is empty if this char sequence contains less than two characters.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun CharSequence.zipWithNext(): List<Pair<Char, Char>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent characters in this char sequence.\n * \n * The returned list is empty if this char sequence contains less than two characters.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <R> CharSequence.zipWithNext(transform: (a: Char, b: Char) -> R): List<R> {\n    val size = length - 1\n    if (size < 1) return emptyList()\n    val result = ArrayList<R>(size)\n    for (index in 0 until size) {\n        result.add(transform(this[index], this[index + 1]))\n    }\n    return result\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original char sequence returning its characters when being iterated.\n */\npublic fun CharSequence.asIterable(): Iterable<Char> {\n    if (this is String && isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original char sequence returning its characters when being iterated.\n */\npublic fun CharSequence.asSequence(): Sequence<Char> {\n    if (this is String && isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n// a package is omitted to get declarations directly under the module\n\n@PublishedApi\nexternal internal fun <T> Array(size: Int): Array<T>\n\n@JsName(\"newArray\")\nfun <T> newArray(size: Int, initValue: T) = fillArrayVal(Array<T>(size), initValue)\n\n@JsName(\"newArrayF\")\ninline fun <T> arrayWithFun(size: Int, init: (Int) -> T) = fillArrayFun(Array<T>(size), init)\n\n@JsName(\"fillArray\")\ninline fun <T> fillArrayFun(array: Array<T>, init: (Int) -> T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = init(i)\n    }\n    return array\n}\n\n@JsName(\"booleanArray\")\nfun booleanArray(size: Int, init: dynamic): Array<Boolean> {\n    val result: dynamic = Array<Boolean>(size)\n    result.`$type$` = \"BooleanArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, false)\n        false -> result\n        else -> fillArrayFun<Boolean>(result, init)\n    }\n}\n\n@JsName(\"booleanArrayF\")\ninline fun booleanArrayWithFun(size: Int, init: (Int) -> Boolean): Array<Boolean> = fillArrayFun(booleanArray(size, false), init)\n\n@JsName(\"charArray\")\n@Suppress(\"UNUSED_PARAMETER\")\nfun charArray(size: Int, init: dynamic): Array<Char> {\n    val result = js(\"new Uint16Array(size)\")\n    result.`$type$` = \"CharArray\"\n    return when (init) {\n        null, true, false -> result // For consistency\n        else -> fillArrayFun<Char>(result, init)\n    }\n}\n\n@JsName(\"charArrayF\")\ninline fun charArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = charArray(size, null)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"untypedCharArrayF\")\ninline fun untypedCharArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = Array<Char>(size)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"longArray\")\nfun longArray(size: Int, init: dynamic): Array<Long> {\n    val result: dynamic = Array<Long>(size)\n    result.`$type$` = \"LongArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, 0L)\n        false -> result\n        else -> fillArrayFun<Long>(result, init)\n    }\n}\n\n@JsName(\"longArrayF\")\ninline fun longArrayWithFun(size: Int, init: (Int) -> Long): Array<Long> = fillArrayFun(longArray(size, false), init)\n\nprivate fun <T> fillArrayVal(array: Array<T>, initValue: T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = initValue\n    }\n    return array\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"SequencesKt\")\n\npackage kotlin.sequences\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns `true` if [element] is found in the sequence.\n *\n * The operation is _terminal_.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Sequence<T>.elementAt(index: Int): T {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Sequence doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Sequence<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Sequence<T>.elementAtOrNull(index: Int): T? {\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the sequence is empty.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.first(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    return iterator.next()\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this sequence in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Sequence<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the sequence was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this sequence in iteration order,\n * or `null` if no non-null value was produced.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Sequence<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the sequence is empty.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.firstOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    return iterator.next()\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns first index of [element], or -1 if the sequence does not contain element.\n *\n * The operation is _terminal_.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.indexOf(element: T): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the sequence does not contain such element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the sequence does not contain such element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns the last element.\n *\n * The operation is _terminal_.\n * \n * @throws NoSuchElementException if the sequence is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Sequence<T>.last(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    var last = iterator.next()\n    while (iterator.hasNext())\n        last = iterator.next()\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Sequence<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns last index of [element], or -1 if the sequence does not contain element.\n *\n * The operation is _terminal_.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Sequence<T>.lastIndexOf(element: T): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns the last element, or `null` if the sequence is empty.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Sequence<T>.lastOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    var last = iterator.next()\n    while (iterator.hasNext())\n        last = iterator.next()\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Sequence<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the single element, or throws an exception if the sequence is empty or has more than one element.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.single(): T {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        throw NoSuchElementException(\"Sequence is empty.\")\n    val single = iterator.next()\n    if (iterator.hasNext())\n        throw IllegalArgumentException(\"Sequence has more than one element.\")\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Sequence contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Sequence contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the sequence is empty or has more than one element.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.singleOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext())\n        return null\n    val single = iterator.next()\n    if (iterator.hasNext())\n        return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a sequence containing all elements except first [n] elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Sequence<T>.drop(n: Int): Sequence<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return when {\n        n == 0 -> this\n        this is DropTakeSequence -> this.drop(n)\n        else -> DropSequence(this, n)\n    }\n}\n\n/**\n * Returns a sequence containing all elements except first elements that satisfy the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Sequence<T>.dropWhile(predicate: (T) -> Boolean): Sequence<T> {\n    return DropWhileSequence(this, predicate)\n}\n\n/**\n * Returns a sequence containing only elements matching the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic fun <T> Sequence<T>.filter(predicate: (T) -> Boolean): Sequence<T> {\n    return FilteringSequence(this, true, predicate)\n}\n\n/**\n * Returns a sequence containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic fun <T> Sequence<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): Sequence<T> {\n    // TODO: Rewrite with generalized MapFilterIndexingSequence\n    return TransformingSequence(FilteringSequence(IndexingSequence(this), true, { predicate(it.index, it.value) }), { it.value })\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a sequence containing all elements that are instances of specified type parameter R.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Sequence<*>.filterIsInstance(): Sequence<@kotlin.internal.NoInfer R> {\n    @Suppress(\"UNCHECKED_CAST\")\n    return filter { it is R } as Sequence<R>\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Sequence<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a sequence containing all elements not matching the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic fun <T> Sequence<T>.filterNot(predicate: (T) -> Boolean): Sequence<T> {\n    return FilteringSequence(this, false, predicate)\n}\n\n/**\n * Returns a sequence containing all elements that are not `null`.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Sequence<T?>.filterNotNull(): Sequence<T> {\n    @Suppress(\"UNCHECKED_CAST\")\n    return filterNot { it == null } as Sequence<T>\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Sequence<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Sequence<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a sequence containing first [n] elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Sequence<T>.take(n: Int): Sequence<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return when {\n        n == 0 -> emptySequence()\n        this is DropTakeSequence -> this.take(n)\n        else -> TakeSequence(this, n)\n    }\n}\n\n/**\n * Returns a sequence containing first elements satisfying the given [predicate].\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Sequence<T>.takeWhile(predicate: (T) -> Boolean): Sequence<T> {\n    return TakeWhileSequence(this, predicate)\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T : Comparable<T>> Sequence<T>.sorted(): Sequence<T> {\n    return object : Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val sortedList = this@sorted.toMutableList()\n            sortedList.sort()\n            return sortedList.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Sequence<T>.sortedBy(crossinline selector: (T) -> R?): Sequence<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic inline fun <T, R : Comparable<R>> Sequence<T>.sortedByDescending(crossinline selector: (T) -> R?): Sequence<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T : Comparable<T>> Sequence<T>.sortedDescending(): Sequence<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a sequence that yields elements of this sequence sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic fun <T> Sequence<T>.sortedWith(comparator: Comparator<in T>): Sequence<T> {\n    return object : Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val sortedList = this@sortedWith.toMutableList()\n            sortedList.sortWith(comparator)\n            return sortedList.iterator()\n        }\n    }\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Sequence<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    return associateTo(LinkedHashMap<K, V>(), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given sequence indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Sequence<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    return associateByTo(LinkedHashMap<K, T>(), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given sequence.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Sequence<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    return associateByTo(LinkedHashMap<K, V>(), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given sequence\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Sequence<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given sequence.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Sequence<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given sequence.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Sequence<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given sequence and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Sequence<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given sequence,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Sequence<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n *\n * The operation is _terminal_.\n */\npublic fun <T, C : MutableCollection<in T>> Sequence<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>())\n}\n\n/**\n * Returns a [List] containing all elements.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toList(): List<T> {\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toMutableList(): MutableList<T> {\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toSet(): Set<T> {\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single sequence of all elements from results of [transform] function being invoked on each element of original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIterable\")\npublic fun <T, R> Sequence<T>.flatMap(transform: (T) -> Iterable<R>): Sequence<R> {\n    return FlatteningSequence(this, transform, Iterable<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements from results of [transform] function being invoked on each element of original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic fun <T, R> Sequence<T>.flatMap(transform: (T) -> Sequence<R>): Sequence<R> {\n    return FlatteningSequence(this, transform, Sequence<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\npublic fun <T, R> Sequence<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): Sequence<R> {\n    return flatMapIndexed(this, transform, Iterable<R>::iterator)\n}\n\n/**\n * Returns a single sequence of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\npublic fun <T, R> Sequence<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): Sequence<R> {\n    return flatMapIndexed(this, transform, Sequence<R>::iterator)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIterableTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original sequence, to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original sequence by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Sequence<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original sequence\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original sequence.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Sequence<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original sequence by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Sequence<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original sequence\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Sequence<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a sequence to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Sequence<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to each element in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic fun <T, R> Sequence<T>.map(transform: (T) -> R): Sequence<R> {\n    return TransformingSequence(this, transform)\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to each element and its index in the original sequence.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T, R> Sequence<T>.mapIndexed(transform: (index: Int, T) -> R): Sequence<R> {\n    return TransformingIndexedSequence(this, transform)\n}\n\n/**\n * Returns a sequence containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original sequence.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T, R : Any> Sequence<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): Sequence<R> {\n    return TransformingIndexedSequence(this, transform).filterNotNull()\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original sequence\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Sequence<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original sequence\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a sequence containing only the non-null results of applying the given [transform] function\n * to each element in the original sequence.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic fun <T, R : Any> Sequence<T>.mapNotNull(transform: (T) -> R?): Sequence<R> {\n    return TransformingSequence(this, transform).filterNotNull()\n}\n\n/**\n * Applies the given [transform] function to each element in the original sequence\n * and appends only the non-null results to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Sequence<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original sequence\n * and appends the results to the given [destination].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Sequence<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a sequence that wraps each element of the original sequence\n * into an [IndexedValue] containing the index of that element and the element itself.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T> Sequence<T>.withIndex(): Sequence<IndexedValue<T>> {\n    return IndexingSequence(this)\n}\n\n/**\n * Returns a sequence containing only distinct elements from the given sequence.\n * \n * Among equal elements of the given sequence, only the first one will be present in the resulting sequence.\n * The elements in the resulting sequence are in the same order as they were in the source sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Sequence<T>.distinct(): Sequence<T> {\n    return this.distinctBy { it }\n}\n\n/**\n * Returns a sequence containing only elements from the given sequence\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given sequence with equal keys, only the first one will be present in the resulting sequence.\n * The elements in the resulting sequence are in the same order as they were in the source sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T, K> Sequence<T>.distinctBy(selector: (T) -> K): Sequence<T> {\n    return DistinctSequence(this, selector)\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given sequence.\n * \n * The returned set preserves the element iteration order of the original sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.toMutableSet(): MutableSet<T> {\n    val set = LinkedHashSet<T>()\n    for (item in this) set.add(item)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Sequence<T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if sequence has at least one element.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Sequence<T>.any(): Boolean {\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Sequence<T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this sequence.\n *\n * The operation is _terminal_.\n */\npublic fun <T> Sequence<T>.count(): Int {\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R> Sequence<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Returns the specified [initial] value if the sequence is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T, R> Sequence<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n *\n * The operation is _terminal_.\n */\npublic inline fun <T> Sequence<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Sequence<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Sequence<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Sequence<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Sequence<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Sequence<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Sequence<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence.\n * \n * @throws NoSuchElementException if the sequence is empty.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the sequence or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Sequence<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun Sequence<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Sequence<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Sequence<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the sequence has no elements.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Sequence<T>.none(): Boolean {\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Sequence<T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns a sequence which performs the given [action] on each element of the original sequence as they pass through it.\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@SinceKotlin(\"1.1\")\npublic fun <T> Sequence<T>.onEach(action: (T) -> Unit): Sequence<T> {\n    return map {\n        action(it)\n        it\n    }\n}\n\n/**\n * Returns a sequence which performs the given [action] on each element of the original sequence as they pass through it.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Sequence<T>.onEachIndexed(action: (index: Int, T) -> Unit): Sequence<T> {\n    return mapIndexed { index, element ->\n        action(index, element)\n        element\n    }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this sequence is empty. If the sequence can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Sequence<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty sequence can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Throws an exception if this sequence is empty. If the sequence can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Sequence<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty sequence can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original sequence.\n * \n * Returns `null` if the sequence is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Sequence<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the sequence is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Sequence<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic fun <T, R> Sequence<T>.runningFold(initial: R, operation: (acc: R, T) -> R): Sequence<R> {\n    return sequence {\n        yield(initial)\n        var accumulator = initial\n        for (element in this@runningFold) {\n            accumulator = operation(accumulator, element)\n            yield(accumulator)\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic fun <T, R> Sequence<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): Sequence<R> {\n    return sequence {\n        yield(initial)\n        var index = 0\n        var accumulator = initial\n        for (element in this@runningFoldIndexed) {\n            accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n            yield(accumulator)\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <S, T : S> Sequence<T>.runningReduce(operation: (acc: S, T) -> S): Sequence<S> {\n    return sequence {\n        val iterator = iterator()\n        if (iterator.hasNext()) {\n            var accumulator: S = iterator.next()\n            yield(accumulator)\n            while (iterator.hasNext()) {\n                accumulator = operation(accumulator, iterator.next())\n                yield(accumulator)\n            }\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with the first element of this sequence.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic fun <S, T : S> Sequence<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): Sequence<S> {\n    return sequence {\n        val iterator = iterator()\n        if (iterator.hasNext()) {\n            var accumulator: S = iterator.next()\n            yield(accumulator)\n            var index = 1\n            while (iterator.hasNext()) {\n                accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n                yield(accumulator)\n            }\n        }\n    }\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T, R> Sequence<T>.scan(initial: R, operation: (acc: R, T) -> R): Sequence<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a sequence containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original sequence and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting sequence.\n * The [initial] value should also be immutable (or should not be mutated)\n * as it may be passed to [operation] function later because of sequence's lazy nature.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T, R> Sequence<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): Sequence<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Sequence<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Sequence<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the sequence.\n *\n * The operation is _terminal_.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic fun <T : Any> Sequence<T?>.requireNoNulls(): Sequence<T> {\n    return map { it ?: throw IllegalArgumentException(\"null element found in $this.\") }\n}\n\n/**\n * Splits this sequence into a sequence of lists each not exceeding the given [size].\n * \n * The last list in the resulting sequence may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.chunked(size: Int): Sequence<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this sequence into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return sequence of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this sequence.\n *\n * The operation is _intermediate_ and _stateful_.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.chunked(size: Int, transform: (List<T>) -> R): Sequence<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence without the first occurrence of the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.minus(element: T): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            var removed = false\n            return this@minus.filter { if (!removed && it == element) { removed = true; false } else true }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] array.\n * \n * Note that the source sequence and the array being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Array<out T>): Sequence<T> {\n    if (elements.isEmpty()) return this\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.toHashSet()\n            return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] collection.\n * \n * Note that the source sequence and the collection being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n *\n * The operation is _intermediate_ and _stateful_.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Iterable<T>): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.convertToSetForSetOperation()\n            if (other.isEmpty())\n                return this@minus.iterator()\n            else\n                return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of original sequence except the elements contained in the given [elements] sequence.\n * \n * Note that the source sequence and the sequence being subtracted are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n * \n * The operation is _intermediate_ for this sequence and _terminal_ and _stateful_ for the [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Sequence<T>.minus(elements: Sequence<T>): Sequence<T> {\n    return object: Sequence<T> {\n        override fun iterator(): Iterator<T> {\n            val other = elements.toHashSet()\n            if (other.isEmpty())\n                return this@minus.iterator()\n            else\n                return this@minus.filterNot { it in other }.iterator()\n        }\n    }\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence without the first occurrence of the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.minusElement(element: T): Sequence<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original sequence into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Sequences.Transformations.partition\n */\npublic inline fun <T> Sequence<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence and then the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(element: T): Sequence<T> {\n    return sequenceOf(this, sequenceOf(element)).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] array.\n * \n * Note that the source sequence and the array being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Array<out T>): Sequence<T> {\n    return this.plus(elements.asList())\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] collection.\n * \n * Note that the source sequence and the collection being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Iterable<T>): Sequence<T> {\n    return sequenceOf(this, elements.asSequence()).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of original sequence and then all elements of the given [elements] sequence.\n * \n * Note that the source sequence and the sequence being added are iterated only when an `iterator` is requested from\n * the resulting sequence. Changing any of them between successive calls to `iterator` may affect the result.\n *\n * The operation is _intermediate_ and _stateless_.\n */\npublic operator fun <T> Sequence<T>.plus(elements: Sequence<T>): Sequence<T> {\n    return sequenceOf(this, elements).flatten()\n}\n\n/**\n * Returns a sequence containing all elements of the original sequence and then the given [element].\n *\n * The operation is _intermediate_ and _stateless_.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.plusElement(element: T): Sequence<T> {\n    return plus(element)\n}\n\n/**\n * Returns a sequence of snapshots of the window of the given [size]\n * sliding along this sequence with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): Sequence<List<T>> {\n    return windowedSequence(size, step, partialWindows, reuseBuffer = false)\n}\n\n/**\n * Returns a sequence of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this sequence with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this sequence.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): Sequence<R> {\n    return windowedSequence(size, step, partialWindows, reuseBuffer = true).map(transform)\n}\n\n/**\n * Returns a sequence of values built from the elements of `this` sequence and the [other] sequence with the same index.\n * The resulting sequence ends as soon as the shortest input sequence ends.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Sequences.Transformations.zip\n */\npublic infix fun <T, R> Sequence<T>.zip(other: Sequence<R>): Sequence<Pair<T, R>> {\n    return MergingSequence(this, other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a sequence of values built from the elements of `this` sequence and the [other] sequence with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The resulting sequence ends as soon as the shortest input sequence ends.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Sequences.Transformations.zipWithTransform\n */\npublic fun <T, R, V> Sequence<T>.zip(other: Sequence<R>, transform: (a: T, b: R) -> V): Sequence<V> {\n    return MergingSequence(this, other, transform)\n}\n\n/**\n * Returns a sequence of pairs of each two adjacent elements in this sequence.\n * \n * The returned sequence is empty if this sequence contains less than two elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Sequence<T>.zipWithNext(): Sequence<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a sequence containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this sequence.\n * \n * The returned sequence is empty if this sequence contains less than two elements.\n *\n * The operation is _intermediate_ and _stateless_.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Sequence<T>.zipWithNext(transform: (a: T, b: T) -> R): Sequence<R> {\n    return sequence result@ {\n        val iterator = iterator()\n        if (!iterator.hasNext()) return@result\n        var current = iterator.next()\n        while (iterator.hasNext()) {\n            val next = iterator.next()\n            yield(transform(current, next))\n            current = next\n        }\n    }\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Sequence<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n *\n * The operation is _terminal_.\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Sequence<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original sequence returning its elements when being iterated.\n */\npublic fun <T> Sequence<T>.asIterable(): Iterable<T> {\n    return Iterable { this.iterator() }\n}\n\n/**\n * Returns this sequence as a [Sequence].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Sequence<T>.asSequence(): Sequence<T> {\n    return this\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Sequence<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Sequence<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Sequence<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Sequence<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Sequence<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Sequence<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Sequence<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Sequence<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Sequence<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Sequence<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Sequence<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the sequence.\n *\n * The operation is _terminal_.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Sequence<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Provides enumeration values to use to set regular expression options.\n */\npublic actual enum class RegexOption(val value: String) {\n    /** Enables case-insensitive matching. */\n    IGNORE_CASE(\"i\"),\n    /** Enables multiline mode.\n     *\n     * In multiline mode the expressions `^` and `$` match just after or just before,\n     * respectively, a line terminator or the end of the input sequence. */\n    MULTILINE(\"m\")\n}\n\n\n/**\n * Represents the results from a single capturing group within a [MatchResult] of [Regex].\n *\n * @param value The value of captured group.\n */\npublic actual data class MatchGroup(actual val value: String)\n\n\n/**\n * Represents a compiled regular expression.\n * Provides functions to match strings in text with a pattern, replace the found occurrences and split text around matches.\n *\n * For pattern syntax reference see [MDN RegExp](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#Special_characters_meaning_in_regular_expressions)\n * and [http://www.w3schools.com/jsref/jsref_obj_regexp.asp](https://www.w3schools.com/jsref/jsref_obj_regexp.asp).\n *\n * @constructor Creates a regular expression from the specified [pattern] string and the specified set of [options].\n */\npublic actual class Regex actual constructor(pattern: String, options: Set<RegexOption>) {\n\n    /** Creates a regular expression from the specified [pattern] string and the specified single [option].  */\n    public actual constructor(pattern: String, option: RegexOption) : this(pattern, setOf(option))\n\n    /** Creates a regular expression from the specified [pattern] string and the default options.  */\n    public actual constructor(pattern: String) : this(pattern, emptySet())\n\n\n    /** The pattern string of this regular expression. */\n    public actual val pattern: String = pattern\n    /** The set of options that were used to create this regular expression. */\n    public actual val options: Set<RegexOption> = options.toSet()\n    private val nativePattern: RegExp = RegExp(pattern, options.joinToString(separator = \"\", prefix = \"gu\") { it.value })\n\n    /** Indicates whether the regular expression matches the entire [input]. */\n    public actual infix fun matches(input: CharSequence): Boolean {\n        nativePattern.reset()\n        val match = nativePattern.exec(input.toString())\n        return match != null && match.index == 0 && nativePattern.lastIndex == input.length\n    }\n\n    /** Indicates whether the regular expression can find at least one match in the specified [input]. */\n    public actual fun containsMatchIn(input: CharSequence): Boolean {\n        nativePattern.reset()\n        return nativePattern.test(input.toString())\n    }\n\n    /**\n     * Returns the first match of a regular expression in the [input], beginning at the specified [startIndex].\n     *\n     * @param startIndex An index to start search with, by default 0. Must be not less than zero and not greater than `input.length()`\n     * @return An instance of [MatchResult] if match was found or `null` otherwise.\n     * @throws IndexOutOfBoundsException if [startIndex] is less than zero or greater than the length of the [input] char sequence.\n     * @sample samples.text.Regexps.find\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun find(input: CharSequence, startIndex: Int = 0): MatchResult? {\n        if (startIndex < 0 || startIndex > input.length) {\n            throw IndexOutOfBoundsException(\"Start index out of bounds: $startIndex, input length: ${input.length}\")\n        }\n        return nativePattern.findNext(input.toString(), startIndex)\n    }\n\n    /**\n     * Returns a sequence of all occurrences of a regular expression within the [input] string, beginning at the specified [startIndex].\n     *\n     * @throws IndexOutOfBoundsException if [startIndex] is less than zero or greater than the length of the [input] char sequence.\n     *\n     * @sample samples.text.Regexps.findAll\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun findAll(input: CharSequence, startIndex: Int = 0): Sequence<MatchResult> {\n        if (startIndex < 0 || startIndex > input.length) {\n            throw IndexOutOfBoundsException(\"Start index out of bounds: $startIndex, input length: ${input.length}\")\n        }\n        return generateSequence({ find(input, startIndex) }, { match -> match.next() })\n    }\n\n    /**\n     * Attempts to match the entire [input] CharSequence against the pattern.\n     *\n     * @return An instance of [MatchResult] if the entire input matches or `null` otherwise.\n     */\n    public actual fun matchEntire(input: CharSequence): MatchResult? {\n        if (pattern.startsWith('^') && pattern.endsWith('$'))\n            return find(input)\n        else\n            return Regex(\"^${pattern.trimStart('^').trimEnd('$')}$\", options).find(input)\n    }\n\n    /**\n     * Replaces all occurrences of this regular expression in the specified [input] string with specified [replacement] expression.\n     *\n     * @param replacement A replacement expression that can include substitutions. See [String.prototype.replace](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace) function docs for details.\n     */\n    public actual fun replace(input: CharSequence, replacement: String): String = input.toString().nativeReplace(nativePattern, replacement)\n\n    /**\n     * Replaces all occurrences of this regular expression in the specified [input] string with the result of\n     * the given function [transform] that takes [MatchResult] and returns a string to be used as a\n     * replacement for that match.\n     */\n    public actual inline fun replace(input: CharSequence, transform: (MatchResult) -> CharSequence): String {\n        var match = find(input)\n        if (match == null) return input.toString()\n\n        var lastStart = 0\n        val length = input.length\n        val sb = StringBuilder(length)\n        do {\n            val foundMatch = match!!\n            sb.append(input, lastStart, foundMatch.range.start)\n            sb.append(transform(foundMatch))\n            lastStart = foundMatch.range.endInclusive + 1\n            match = foundMatch.next()\n        } while (lastStart < length && match != null)\n\n        if (lastStart < length) {\n            sb.append(input, lastStart, length)\n        }\n\n        return sb.toString()\n    }\n\n    /**\n     * Replaces the first occurrence of this regular expression in the specified [input] string with specified [replacement] expression.\n     *\n     * @param replacement A replacement expression that can include substitutions. See [String.prototype.replace](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace) function docs for details.\n     */\n    public actual fun replaceFirst(input: CharSequence, replacement: String): String {\n        val nonGlobalOptions = options.map { it.value }.joinToString(separator = \"\")\n        return input.toString().nativeReplace(RegExp(pattern, nonGlobalOptions), replacement)\n    }\n\n    /**\n     * Splits the [input] CharSequence around matches of this regular expression.\n     *\n     * @param limit Non-negative value specifying the maximum number of substrings the string can be split to.\n     * Zero by default means no limit is set.\n     */\n    @Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\n    public actual fun split(input: CharSequence, limit: Int = 0): List<String> {\n        require(limit >= 0) { \"Limit must be non-negative, but was $limit\" }\n        val matches = findAll(input).let { if (limit == 0) it else it.take(limit - 1) }\n        val result = mutableListOf<String>()\n        var lastStart = 0\n\n        for (match in matches) {\n            result.add(input.subSequence(lastStart, match.range.start).toString())\n            lastStart = match.range.endInclusive + 1\n        }\n        result.add(input.subSequence(lastStart, input.length).toString())\n        return result\n    }\n\n\n    /**\n     * Returns the string representation of this regular expression, namely the [pattern] of this regular expression.\n     *\n     * Note that another regular expression constructed from the same pattern string may have different [options]\n     * and may match strings differently.\n     */\n    public override fun toString(): String = nativePattern.toString()\n\n    actual companion object {\n        /**\n         * Returns a regular expression that matches the specified [literal] string literally.\n         * No characters of that string will have special meaning when searching for an occurrence of the regular expression.\n         */\n        public actual fun fromLiteral(literal: String): Regex = Regex(escape(literal))\n\n        /**\n         * Returns a regular expression pattern string that matches the specified [literal] string literally.\n         * No characters of that string will have special meaning when searching for an occurrence of the regular expression.\n         */\n        public actual fun escape(literal: String): String = literal.nativeReplace(patternEscape, \"\\\\$&\")\n\n        /**\n         * Returns a literal replacement expression for the specified [literal] string.\n         * No characters of that string will have special meaning when it is used as a replacement string in [Regex.replace] function.\n         */\n        public actual fun escapeReplacement(literal: String): String = literal.nativeReplace(replacementEscape, \"$$$$\")\n\n        private val patternEscape = RegExp(\"\"\"[\\\\^$*+?.()|[\\]{}]\"\"\", \"g\")\n        private val replacementEscape = RegExp(\"\"\"\\$\"\"\", \"g\")\n    }\n}\n\n/** Creates a regular expression from the specified [pattern] string and the specified single [option].  */\n@Deprecated(\"Provided for binary compatibility\", level = DeprecationLevel.HIDDEN)\n@JsName(\"Regex_sb3q2\\$\")\npublic fun Regex_0(pattern: String, option: RegexOption): Regex = Regex(pattern, setOf(option))\n\n/** Creates a regular expression from the specified [pattern] string and the default options.  */\n@Deprecated(\"Provided for binary compatibility\", level = DeprecationLevel.HIDDEN)\n@JsName(\"Regex_61zpoe\\$\")\npublic fun Regex_1(pattern: String): Regex = Regex(pattern, emptySet())\n\n\n\n\nprivate fun RegExp.findNext(input: String, from: Int): MatchResult? {\n    this.lastIndex = from\n    val match = exec(input)\n    if (match == null) return null\n    val range = match.index..lastIndex - 1\n\n    return object : MatchResult {\n        override val range: IntRange = range\n        override val value: String\n            get() = match[0]!!\n\n        override val groups: MatchGroupCollection = object : MatchGroupCollection, AbstractCollection<MatchGroup?>() {\n            override val size: Int get() = match.length\n            override fun iterator(): Iterator<MatchGroup?> = indices.asSequence().map { this[it] }.iterator()\n            override fun get(index: Int): MatchGroup? = match[index]?.let { MatchGroup(it) }\n        }\n\n\n        private var groupValues_: List<String>? = null\n\n        override val groupValues: List<String>\n            get() {\n                if (groupValues_ == null) {\n                    groupValues_ = object : AbstractList<String>() {\n                        override val size: Int get() = match.length\n                        override fun get(index: Int): String = match[index] ?: \"\"\n                    }\n                }\n                return groupValues_!!\n            }\n\n        override fun next(): MatchResult? = this@findNext.findNext(input, if (range.isEmpty()) range.start + 1 else range.endInclusive + 1)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", ignoring case, and `false` otherwise.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toBoolean(): Boolean = this.toBoolean()\n\n/**\n * Returns `true` if this string is not `null` and its content is equal to the word \"true\", ignoring case, and `false` otherwise.\n *\n * There are also strict versions of the function available on non-nullable String, [toBooleanStrict] and [toBooleanStrictOrNull].\n */\n@SinceKotlin(\"1.4\")\npublic actual fun String?.toBoolean(): Boolean = this != null && this.lowercase() == \"true\"\n\n/**\n * Parses the string as a signed [Byte] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toByte(): Byte = toByteOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a signed [Byte] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toByte(radix: Int): Byte = toByteOrNull(radix) ?: numberFormatError(this)\n\n\n/**\n * Parses the string as a [Short] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toShort(): Short = toShortOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Short] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toShort(radix: Int): Short = toShortOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as an [Int] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toInt(): Int = toIntOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as an [Int] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toInt(radix: Int): Int = toIntOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Long] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toLong(): Long = toLongOrNull() ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Long] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n * @throws IllegalArgumentException when [radix] is not a valid radix for string to number conversion.\n */\npublic actual fun String.toLong(radix: Int): Long = toLongOrNull(radix) ?: numberFormatError(this)\n\n/**\n * Parses the string as a [Double] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\npublic actual fun String.toDouble(): Double = (+(this.asDynamic())).unsafeCast<Double>().also {\n    if (it.isNaN() && !this.isNaN() || it == 0.0 && this.isBlank())\n        numberFormatError(this)\n}\n\n/**\n * Parses the string as a [Float] number and returns the result.\n * @throws NumberFormatException if the string is not a valid representation of a number.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toFloat(): Float = toDouble().unsafeCast<Float>()\n\n/**\n * Parses the string as a [Double] number and returns the result\n * or `null` if the string is not a valid representation of a number.\n */\npublic actual fun String.toDoubleOrNull(): Double? = (+(this.asDynamic())).unsafeCast<Double>().takeIf {\n    !(it.isNaN() && !this.isNaN() || it == 0.0 && this.isBlank())\n}\n\n/**\n * Parses the string as a [Float] number and returns the result\n * or `null` if the string is not a valid representation of a number.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toFloatOrNull(): Float? = toDoubleOrNull().unsafeCast<Float?>()\n\n/**\n * Returns a string representation of this [Byte] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\n@kotlin.internal.InlineOnly\npublic actual inline fun Byte.toString(radix: Int): String = this.toInt().toString(radix)\n\n/**\n * Returns a string representation of this [Short] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\n@kotlin.internal.InlineOnly\npublic actual inline fun Short.toString(radix: Int): String = this.toInt().toString(radix)\n\n/**\n * Returns a string representation of this [Int] value in the specified [radix].\n *\n * @throws IllegalArgumentException when [radix] is not a valid radix for number to string conversion.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Int.toString(radix: Int): String = asDynamic().toString(checkRadix(radix))\n\nprivate fun String.isNaN(): Boolean = when (this.lowercase()) {\n    \"nan\", \"+nan\", \"-nan\" -> true\n    else -> false\n}\n\n/**\n * Checks whether the given [radix] is valid radix for string to number and number to string conversion.\n */\n@PublishedApi\ninternal actual fun checkRadix(radix: Int): Int {\n    if (radix !in 2..36) {\n        throw IllegalArgumentException(\"radix $radix was not in valid range 2..36\")\n    }\n    return radix\n}\n\ninternal actual fun digitOf(char: Char, radix: Int): Int = when {\n    char >= '0' && char <= '9' -> char - '0'\n    char >= 'A' && char <= 'Z' -> char - 'A' + 10\n    char >= 'a' && char <= 'z' -> char - 'a' + 10\n    char < '\\u0080' -> -1\n    char >= '\\uFF21' && char <= '\\uFF3A' -> char - '\\uFF21' + 10 // full-width latin capital letter\n    char >= '\\uFF41' && char <= '\\uFF5A' -> char - '\\uFF41' + 10 // full-width latin small letter\n    else -> char.digitToIntImpl()\n}.let { if (it >= radix) -1 else it }\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.algorithms\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.math.abs\n\nfun <T> splitRings(points: List<T>): List<List<T>> {\n    val rings = findRingIntervals(points).map { points.sublist(it) }.toMutableList()\n\n    if (rings.isNotEmpty()) {\n        if (!rings.last().isClosed()) {\n            rings.set(rings.lastIndex, makeClosed(rings.last()))\n        }\n    }\n\n    return rings\n}\n\nprivate fun <T> makeClosed(path: List<T>) = path.toMutableList() + path.first()\n\nfun <T> List<T>.isClosed() = first() == last()\n\nprivate fun <T> findRingIntervals(path: List<T>): List<ClosedRange<Int>> {\n    val intervals = ArrayList<ClosedRange<Int>>()\n    var startIndex = 0\n\n    var i = 0\n    val n = path.size\n    while (i < n) {\n        if (startIndex != i && path[startIndex] == path[i]) {\n            intervals.add(ClosedRange(startIndex, i + 1))\n            startIndex = i + 1\n        }\n        i++\n    }\n\n    if (startIndex != path.size) {\n        intervals.add(ClosedRange(startIndex, path.size))\n    }\n    return intervals\n}\n\nprivate fun <T> List<T>.sublist(range: ClosedRange<Int>): List<T> {\n    return this.subList(range.lowerEnd, range.upperEnd)\n}\n\n\nfun calculateArea(ring: List<DoubleVector>): Double {\n    return calculateArea(ring, DoubleVector::x, DoubleVector::y)\n}\n\nfun <T> isClockwise(ring: List<T>, x: (T) -> Double, y: (T) -> Double): Boolean {\n    check(ring.isNotEmpty()) { \"Ring shouldn't be empty to calculate clockwise\" }\n\n    var sum = 0.0\n    var prev = ring[ring.size - 1]\n    for (point in ring) {\n        sum += x(prev) * y(point) - x(point) * y(prev)\n        prev = point\n    }\n    return sum < 0.0\n}\n\nfun <T> calculateArea(ring: List<T>, x: T.() -> Double, y: T.() -> Double): Double {\n    var area = 0.0\n\n    var j = ring.size - 1\n\n    for (i in ring.indices) {\n        val p1 = ring[i]\n        val p2 = ring[j]\n\n        area += (p2.x() + p1.x()) * (p2.y() - p1.y())\n        j = i\n    }\n\n    return abs(area / 2)\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\nimport jetbrains.datalore.base.datetime.Month\nimport jetbrains.datalore.base.datetime.WeekDay\n\nobject DateLocale {\n    val weekDayAbbr = mapOf(\n        WeekDay.MONDAY to \"Mon\",\n        WeekDay.TUESDAY to \"Tue\",\n        WeekDay.WEDNESDAY to \"Wed\",\n        WeekDay.THURSDAY to \"Thu\",\n        WeekDay.FRIDAY to \"Fri\",\n        WeekDay.SATURDAY to \"Sat\",\n        WeekDay.SUNDAY to \"Sun\"\n    )\n\n    val weekDayFull = mapOf(\n        WeekDay.MONDAY to \"Monday\",\n        WeekDay.TUESDAY to \"Tuesday\",\n        WeekDay.WEDNESDAY to \"Wednesday\",\n        WeekDay.THURSDAY to \"Thursday\",\n        WeekDay.FRIDAY to \"Friday\",\n        WeekDay.SATURDAY to \"Saturday\",\n        WeekDay.SUNDAY to \"Sunday\"\n    )\n\n    val monthAbbr = mapOf(\n        Month.JANUARY to \"Jan\",\n        Month.FEBRUARY to \"Feb\",\n        Month.MARCH to \"Mar\",\n        Month.APRIL to \"Apr\",\n        Month.MAY to \"May\",\n        Month.JUNE to \"Jun\",\n        Month.JULY to \"Jul\",\n        Month.AUGUST to \"Aug\",\n        Month.SEPTEMBER to \"Sep\",\n        Month.OCTOBER to \"Oct\",\n        Month.NOVEMBER to \"Nov\",\n        Month.DECEMBER to \"Dec\"\n    )\n\n    val monthFull = mapOf(\n        Month.JANUARY to \"January\",\n        Month.FEBRUARY to \"February\",\n        Month.MARCH to \"March\",\n        Month.APRIL to \"April\",\n        Month.MAY to \"May\",\n        Month.JUNE to \"June\",\n        Month.JULY to \"July\",\n        Month.AUGUST to \"August\",\n        Month.SEPTEMBER to \"September\",\n        Month.OCTOBER to \"October\",\n        Month.NOVEMBER to \"November\",\n        Month.DECEMBER to \"December\"\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\nimport jetbrains.datalore.base.dateFormat.Pattern.Companion.Kind\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Time\n\nclass Format(private val spec: List<SpecPart>) {\n\n    constructor(spec: String): this(parse(spec))\n\n    open class SpecPart(val str: String) {\n        open fun exec(dateTime: DateTime) = str\n    }\n\n    class PatternSpecPart(str: String): SpecPart(str) {\n        val pattern: Pattern = Pattern.patternByString(str) ?: throw IllegalArgumentException(\"Wrong pattern: $str\")\n\n        override fun exec(dateTime: DateTime): String {\n            return getValueForPattern(pattern, dateTime)\n        }\n    }\n\n    fun apply(dateTime: DateTime): String = spec.joinToString(\"\") { it.exec(dateTime) }\n\n    fun apply(date: Date): String =\n        spec\n            .filter {\n                when {\n                    (it is PatternSpecPart && it.pattern.kind == Kind.DATE) -> true\n                    it !is PatternSpecPart -> true\n                    else -> false\n                }\n            }\n            .joinToString(\"\") { it.exec(DateTime(date)) }\n\n    fun apply(time: Time): String =\n        spec\n            .filter {\n                when {\n                    (it is PatternSpecPart && it.pattern.kind == Kind.TIME) -> true\n                    it !is PatternSpecPart -> true\n                    else -> false\n                }\n            }\n            .joinToString(\"\") { it.exec(DateTime(Date.EPOCH, time)) }\n\n    companion object {\n        fun parse(str: String): List<SpecPart> {\n            val result = mutableListOf<SpecPart>()\n            val resultSequence = Pattern.PATTERN_REGEX.findAll(str)\n            var lastIndex = 0\n            resultSequence.forEach {\n                val value = it.value\n                val range = it.range\n                val startIndex = range.first\n                val endIndex = range.last\n                if (startIndex > 0) {\n                    val spec = SpecPart(str.substring(lastIndex until startIndex))\n                    result.add(spec)\n                }\n                result.add(PatternSpecPart(value))\n                lastIndex = endIndex + 1\n            }\n\n            if (lastIndex < str.length) {\n                result.add(SpecPart(str.substring(lastIndex)))\n            }\n\n            return result\n        }\n\n        private fun getValueForPattern(type: Pattern, dateTime: DateTime): String =\n            when(type) {\n                Pattern.SECOND -> leadZero(dateTime.seconds)\n                Pattern.MINUTE -> leadZero(dateTime.minutes)\n                Pattern.HOUR_12 -> getHours12(dateTime).toString()\n                Pattern.HOUR_12_LEADING_ZERO -> leadZero(getHours12(dateTime))\n                Pattern.HOUR_24 -> leadZero(getHours24(dateTime))\n                Pattern.MERIDIAN_LOWER -> getMeridian(dateTime)\n                Pattern.MERIDIAN_UPPER -> getMeridian(dateTime).uppercase()\n                Pattern.DAY_OF_WEEK -> getWeekDayNumber(dateTime)\n                Pattern.DAY_OF_WEEK_ABBR -> DateLocale.weekDayAbbr[dateTime.weekDay] ?: \"\"\n                Pattern.DAY_OF_WEEK_FULL -> DateLocale.weekDayFull[dateTime.weekDay] ?: \"\"\n                Pattern.DAY_OF_MONTH -> dateTime.day.toString()\n                Pattern.DAY_OF_MONTH_LEADING_ZERO -> leadZero(dateTime.day)\n                Pattern.DAY_OF_THE_YEAR -> leadZero(dateTime.date.daysFromYearStart(), 3)\n                Pattern.MONTH -> leadZero((dateTime.month?.ordinal() ?: 0) + 1)\n                Pattern.MONTH_ABBR -> DateLocale.monthAbbr[dateTime.month] ?: \"\"\n                Pattern.MONTH_FULL -> DateLocale.monthFull[dateTime.month] ?: \"\"\n                Pattern.YEAR_SHORT -> dateTime.year.toString().substring(2)\n                Pattern.YEAR_FULL -> dateTime.year.toString()\n            }\n\n        private fun leadZero(value: Int, length: Int = 2): String = value.toString().padStart(length, '0')\n\n        private fun getHours12(dateTime: DateTime): Int {\n            val hours = dateTime.hours\n            return when {\n                hours == 0 -> 12\n                hours <= 12 -> hours\n                else -> hours - 12\n            }\n        }\n\n        private fun getHours24(dateTime: DateTime): Int =\n            when(dateTime.hours) {\n                0 -> 24\n                else -> dateTime.hours\n            }\n\n        private fun getMeridian(dateTime: DateTime): String {\n            val hours = dateTime.hours\n            return when {\n                hours == 24 -> \"am\"\n                hours <= 12 -> \"am\"\n                else -> \"pm\"\n            }\n        }\n\n        private fun getWeekDayNumber(dateTime: DateTime): String {\n            var num = dateTime.weekDay.ordinal + 1\n            if (num == 7) {\n                num = 0\n            }\n            return num.toString()\n        }\n    }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.dateFormat\n\n/**\n * Pattern for \"strftime\" datetime formatting\n * (https://docs.python.org/3/library/datetime.html#strftime-strptime-behavior, www.strfti.me/)\n */\nenum class Pattern(val string: String, val kind: Kind) {\n    //Date\n    DAY_OF_WEEK_ABBR(\"%a\", Kind.DATE),\n    DAY_OF_WEEK_FULL(\"%A\", Kind.DATE),\n    MONTH_ABBR(\"%b\", Kind.DATE),\n    MONTH_FULL(\"%B\", Kind.DATE),\n    DAY_OF_MONTH_LEADING_ZERO(\"%d\", Kind.DATE),\n    DAY_OF_MONTH(\"%e\", Kind.DATE),\n    DAY_OF_THE_YEAR(\"%j\", Kind.DATE),\n    MONTH(\"%m\", Kind.DATE),\n    //WEEK_NUMBER_FROM_SUNDAY(\"%U\", Kind.DATE),\n    //WEEK_NUMBER_FROM_MONDAY(\"%W\", Kind.DATE),\n    DAY_OF_WEEK(\"%w\", Kind.DATE),\n    //LOCALE_DATE(\"%x\", Kind.DATE),\n    YEAR_SHORT(\"%y\", Kind.DATE),\n    YEAR_FULL(\"%Y\", Kind.DATE),\n\n    //Time\n    HOUR_24(\"%H\", Kind.TIME),\n    HOUR_12_LEADING_ZERO(\"%I\", Kind.TIME),\n    HOUR_12(\"%l\", Kind.TIME),\n    MINUTE(\"%M\", Kind.TIME),\n    MERIDIAN_LOWER(\"%P\", Kind.TIME),\n    MERIDIAN_UPPER(\"%p\", Kind.TIME),\n    SECOND(\"%S\", Kind.TIME);\n    //LOCALE_TIME(\"%X\", Kind.TIME),\n    //TIME_ZONE(\"%Z\", Kind.TIME),\n\n    //Other\n    //LOCALE_DATE_TIME(\"%c\", Kind.OTHER);\n\n\n    companion object {\n        val PATTERN_REGEX = \"(%[aAbBdejmwyYHIlMpPS])\".toRegex()\n        \n        enum class Kind {\n            DATE,\n            TIME\n        }\n\n        fun patternByString(patternString: String) = values().find { it.string == patternString }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport kotlin.jvm.JvmOverloads\n\nclass Date(val day: Int, val month: Month, val year: Int) : Comparable<Date> {\n\n    val weekDay: WeekDay\n        get() {\n            val daysFromOrigin = daysFrom(EPOCH)\n            return WeekDay.values()[(daysFromOrigin + EPOCH_WEEKDAY.ordinal) % WeekDay.values().size]\n        }\n\n    val dateStart: DateTime\n        get() = DateTime(this)\n\n    val dateEnd: DateTime\n        get() = DateTime(this, Time.DAY_END)\n\n    init {\n        validate()\n    }\n\n    private fun validate() {\n        val daysInMonth = month.getDaysInYear(year)\n        val isValid = day in 1..daysInMonth\n\n        if (!isValid) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    fun daysFrom(date: Date): Int {\n        if (compareTo(date) < 0) {\n            throw IllegalArgumentException()\n        }\n\n        var result = 0\n\n        if (year != date.year) {\n            val fromYear = date.year\n            val toYear = year\n            val leapYears = DateTimeUtil.leapYearsBetween(fromYear, toYear)\n            val years = toYear - fromYear\n            result += leapYears * DateTimeUtil.DAYS_IN_LEAP_YEAR + (years - leapYears) * DateTimeUtil.DAYS_IN_YEAR\n        }\n\n        return result + daysFromYearStart() - date.daysFromYearStart()\n    }\n\n    fun daysFromYearStart(): Int {\n        var result = day\n        var current = month.prev()\n        while (current != null) {\n            result += current.getDaysInYear(year)\n            current = current.prev()\n        }\n        return result\n    }\n\n    fun addDays(days: Int): Date {\n        @Suppress(\"NAME_SHADOWING\")\n        var days = days\n        if (days < 0) {\n            throw IllegalArgumentException()\n        }\n        if (days == 0) return this\n\n        var day = this.day\n        var month = this.month\n        var year = this.year\n        var lessThanYear = false\n\n        if (days >= CACHE_DAYS && year == EPOCH.year) {\n            year = CACHE_STAMP.year\n            month = CACHE_STAMP.month\n            day = CACHE_STAMP.day\n            days -= CACHE_DAYS\n        }\n\n        while (days > 0) {\n            val daysToNextMonth = month.getDaysInYear(year) - day + 1\n            if (days < daysToNextMonth) {\n                return Date(day + days, month, year)\n            } else {\n                if (lessThanYear) {\n                    month = month.next()!!\n                    day = 1\n                    days -= daysToNextMonth\n                } else {\n                    val daysToNextYear = lastDayOf(year).daysFrom(Date(day, month, year)) + 1\n                    if (days >= daysToNextYear) {\n                        day = 1\n                        month = Month.JANUARY\n                        year += 1\n                        days -= daysToNextYear\n                    } else {\n                        month = month.next()!!\n                        day = 1\n                        days -= daysToNextMonth\n                        lessThanYear = true\n                    }\n                }\n            }\n        }\n\n        return Date(day, month, year)\n    }\n\n    fun nextDate(): Date {\n        return addDays(1)\n    }\n\n    fun prevDate(): Date {\n        return subtractDays(1)\n    }\n\n    fun subtractDays(days: Int): Date {\n        if (days < 0) {\n            throw IllegalArgumentException()\n        }\n        if (days == 0) return this\n\n        if (days < day) {\n            return Date(day - days, month, year)\n        } else {\n            val daysToPrevYear = daysFrom(firstDayOf(year))\n            return if (days > daysToPrevYear) {\n                lastDayOf(year - 1).subtractDays(days - daysToPrevYear - 1)\n            } else {\n                lastDayOf(year, month.prev()!!).subtractDays(days - day)\n            }\n        }\n    }\n\n    override fun compareTo(other: Date): Int {\n        if (year != other.year) return year - other.year\n        return if (month.ordinal() != other.month.ordinal()) month.ordinal() - other.month.ordinal() else day - other.day\n\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Date) return false\n\n        val date = other as Date?\n        return date!!.year == year &&\n                date.month === month &&\n                date.day == day\n    }\n\n    override fun hashCode(): Int {\n        return year * 239 + month.hashCode() * 31 + day\n    }\n\n    override fun toString(): String {\n        val result = StringBuilder()\n        result.append(year)\n        appendMonth(result)\n        appendDay(result)\n        return result.toString()\n    }\n\n    private fun appendDay(result: StringBuilder) {\n        if (day < 10) {\n            result.append(\"0\")\n        }\n        result.append(day)\n    }\n\n    private fun appendMonth(result: StringBuilder) {\n        val month = this.month.ordinal() + 1\n        if (month < 10) {\n            result.append(\"0\")\n        }\n        result.append(month)\n    }\n\n    fun toPrettyString(): String {\n        val result = StringBuilder()\n        appendDay(result)\n        result.append(\".\")\n        appendMonth(result)\n        result.append(\".\")\n        result.append(year)\n        return result.toString()\n    }\n\n    companion object {\n        val EPOCH = Date(1, Month.JANUARY, 1970)\n        private val EPOCH_WEEKDAY = WeekDay.THURSDAY\n\n        private val CACHE_STAMP = Date(1, Month.JANUARY, 2012)\n        private val CACHE_DAYS = CACHE_STAMP.daysFrom(EPOCH)\n\n        fun parse(str: String): Date {\n            if (str.length != 8) {\n                throw RuntimeException()\n            }\n\n            val year = str.substring(0, 4).toInt()\n            val month = str.substring(4, 6).toInt()\n            val day = str.substring(6, 8).toInt()\n            return Date(day, Month.values()[month - 1], year)\n        }\n\n        @JvmOverloads\n        fun firstDayOf(year: Int, month: Month = Month.JANUARY): Date {\n            return Date(1, month, year)\n        }\n\n        @JvmOverloads\n        fun lastDayOf(year: Int, month: Month = Month.DECEMBER): Date {\n            return Date(month.days, month, year)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport jetbrains.datalore.base.datetime.tz.TimeZone\nimport kotlin.jvm.JvmOverloads\n\nclass DateTime @JvmOverloads constructor(val date: Date, val time: Time = Time.DAY_START) : Comparable<DateTime> {\n\n    val year: Int\n        get() = date.year\n\n    val month: Month?\n        get() = date.month\n\n    val day: Int\n        get() = date.day\n\n    val weekDay: WeekDay\n        get() = date.weekDay\n\n    val hours: Int\n        get() = time.hours\n\n    val minutes: Int\n        get() = time.minutes\n\n    val seconds: Int\n        get() = time.seconds\n\n    val milliseconds: Int\n        get() = time.milliseconds\n\n    fun changeDate(date: Date): DateTime {\n        return DateTime(date, time)\n    }\n\n    fun changeTime(time: Time): DateTime {\n        return DateTime(date, time)\n    }\n\n    fun add(duration: Duration): DateTime {\n        val utcInstant = TimeZone.UTC.toInstant(this)\n        return TimeZone.UTC.toDateTime(utcInstant.add(duration))\n    }\n\n    fun to(otherTime: DateTime): Duration {\n        val currentInstant = TimeZone.UTC.toInstant(this)\n        val otherInstant = TimeZone.UTC.toInstant(otherTime)\n        return currentInstant.to(otherInstant)\n    }\n\n    fun isBefore(dateTime: DateTime): Boolean {\n        return compareTo(dateTime) < 0\n    }\n\n    fun isAfter(dateTime: DateTime): Boolean {\n        return compareTo(dateTime) > 0\n    }\n\n    override fun hashCode(): Int {\n        return date.hashCode() * 31 + time.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DateTime) return false\n\n        val otherDateTime = other as DateTime?\n\n        return date == otherDateTime!!.date && time == otherDateTime.time\n    }\n\n    override fun compareTo(other: DateTime): Int {\n        val dateComparison = date.compareTo(other.date)\n        return if (dateComparison != 0) dateComparison else time.compareTo(other.time)\n    }\n\n    override fun toString(): String {\n        return date.toString() + \"T\" + time\n    }\n\n    fun toPrettyString(): String {\n        return time.toPrettyHMString() + \" \" + date.toPrettyString()\n    }\n\n    companion object {\n\n        fun parse(s: String): DateTime {\n            if (s.length < 15) {\n                throw IllegalArgumentException()\n            }\n\n            return DateTime(Date.parse(s.substring(0, 8)), Time.parse(s.substring(9)))\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\n\nobject DateTimeUtil {\n    const val BASE_YEAR = 1900\n    const val MAX_SUPPORTED_YEAR = 2100 //inclusive; defined by LEAP_YEARS_FROM_1969 length\n    internal const val MIN_SUPPORTED_YEAR = 1970 //inclusive\n    internal val DAYS_IN_YEAR: Int\n    internal val DAYS_IN_LEAP_YEAR: Int\n\n    internal val LEAP_YEARS_FROM_1969 = intArrayOf(477, 477, 477, 478, 478, 478, 478, 479, 479, 479, 479, 480, 480, 480, 480, 481, 481, 481, 481, 482, 482, 482, 482, 483, 483, 483, 483, 484, 484, 484, 484, 485, 485, 485, 485, 486, 486, 486, 486, 487, 487, 487, 487, 488, 488, 488, 488, 489, 489, 489, 489, 490, 490, 490, 490, 491, 491, 491, 491, 492, 492, 492, 492, 493, 493, 493, 493, 494, 494, 494, 494, 495, 495, 495, 495, 496, 496, 496, 496, 497, 497, 497, 497, 498, 498, 498, 498, 499, 499, 499, 499, 500, 500, 500, 500, 501, 501, 501, 501, 502, 502, 502, 502, 503, 503, 503, 503, 504, 504, 504, 504, 505, 505, 505, 505, 506, 506, 506, 506, 507, 507, 507, 507, 508, 508, 508, 508, 509, 509, 509, 509, 509)\n\n    init {\n        var leapYearDays = 0\n        var yearDays = 0\n        for (m in Month.values()) {\n            leapYearDays += m.getDaysInLeapYear()\n            yearDays += m.days\n        }\n        DAYS_IN_YEAR = yearDays\n        DAYS_IN_LEAP_YEAR = leapYearDays\n    }\n\n    internal fun isLeap(year: Int): Boolean {\n        checkYear(year)\n        return LEAP_YEARS_FROM_1969[year - MIN_SUPPORTED_YEAR + 1] - LEAP_YEARS_FROM_1969[year - MIN_SUPPORTED_YEAR] == 1\n        //hack for quick load\n        //    return leapYearsFromZero(year) - leapYearsFromZero(year - 1) == 1;\n    }\n\n    internal fun leapYearsBetween(fromYear: Int, toYear: Int): Int {\n        if (fromYear > toYear) {\n            throw IllegalArgumentException()\n        }\n        checkYear(fromYear)\n        checkYear(toYear)\n\n        return LEAP_YEARS_FROM_1969[toYear - MIN_SUPPORTED_YEAR] - LEAP_YEARS_FROM_1969[fromYear - MIN_SUPPORTED_YEAR]\n        //    return leapYearsFromZero(toYear - 1) - leapYearsFromZero(fromYear - 1);\n    }\n\n    private fun leapYearsFromZero(year: Int): Int {\n        return year / 4 - year / 100 + year / 400\n    }\n\n    private fun checkYear(year: Int) {\n        if (year > MAX_SUPPORTED_YEAR || year < MIN_SUPPORTED_YEAR) {\n            throw IllegalArgumentException(year.toString() + \"\")\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\n//class Instant @JvmOverloads constructor(val timeSinceEpoch: Long = System.currentTimeMillis()) : Comparable<Instant> {\nclass Instant(val timeSinceEpoch: Long) : Comparable<Instant> {\n\n    fun add(duration: Duration): Instant {\n        return Instant(timeSinceEpoch + duration.duration)\n    }\n\n    fun sub(duration: Duration): Instant {\n        return Instant(timeSinceEpoch - duration.duration)\n    }\n\n    fun to(instant: Instant): Duration {\n        return Duration(instant.timeSinceEpoch - timeSinceEpoch)\n    }\n\n    override fun compareTo(other: Instant): Int {\n        val delta = timeSinceEpoch - other.timeSinceEpoch\n        return if (delta > 0) {\n            1\n        } else if (delta == 0L) {\n            0\n        } else {\n            -1\n        }\n    }\n\n    override fun hashCode(): Int {\n        return timeSinceEpoch.toInt()\n    }\n\n    override fun toString(): String {\n        return \"\" + timeSinceEpoch\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Instant) false else timeSinceEpoch == other.timeSinceEpoch\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nopen class Month private constructor(val days: Int, private val myOrdinal: Int, private val myName: String) {\n\n    fun ordinal(): Int {\n        return myOrdinal\n    }\n\n    open fun getDaysInYear(year: Int): Int {\n        return days\n    }\n\n    open fun getDaysInLeapYear(): Int {\n        return days\n    }\n\n    fun prev(): Month? {\n        return if (myOrdinal == 0) null else Month.values()[myOrdinal - 1]\n    }\n\n    operator fun next(): Month? {\n        val values = Month.values()\n        return if (myOrdinal == values.size - 1) null else values[myOrdinal + 1]\n    }\n\n    override fun toString(): String {\n        return myName\n    }\n\n    private class VarLengthMonth(days: Int, private val myDaysInLeapYear: Int, ordinal: Int, name: String) : Month(days, ordinal, name) {\n\n        override fun getDaysInLeapYear(): Int {\n            return myDaysInLeapYear\n        }\n\n        override fun getDaysInYear(year: Int): Int {\n            return if (DateTimeUtil.isLeap(year)) {\n                getDaysInLeapYear()\n            } else {\n                days\n            }\n        }\n    }\n\n    companion object {\n        val JANUARY = Month(31, 0, \"January\")\n\n        val FEBRUARY: Month = VarLengthMonth(28, 29, 1, \"February\")\n        val MARCH = Month(31, 2, \"March\")\n        val APRIL = Month(30, 3, \"April\")\n        val MAY = Month(31, 4, \"May\")\n        val JUNE = Month(30, 5, \"June\")\n        val JULY = Month(31, 6, \"July\")\n        val AUGUST = Month(31, 7, \"August\")\n        val SEPTEMBER = Month(30, 8, \"September\")\n        val OCTOBER = Month(31, 9, \"October\")\n        val NOVEMBER = Month(30, 10, \"November\")\n        val DECEMBER = Month(31, 11, \"December\")\n\n        private val VALUES = arrayOf(JANUARY, FEBRUARY, MARCH, APRIL, MAY, JUNE, JULY, AUGUST, SEPTEMBER, OCTOBER, NOVEMBER, DECEMBER)\n\n        fun values(): Array<Month> {\n            return VALUES\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nimport kotlin.jvm.JvmOverloads\n\nclass Time @JvmOverloads constructor(\n        val hours: Int,\n        val minutes: Int,\n        val seconds: Int = 0,\n        val milliseconds: Int = 0) : Comparable<Time> {\n\n    init {\n        if (hours < 0 || hours > 24) {\n            throw IllegalArgumentException()\n        }\n        if (hours == 24 && (minutes != 0 || seconds != 0)) {\n            throw IllegalArgumentException()\n        }\n        if (minutes < 0 || minutes >= 60) {\n            throw IllegalArgumentException()\n        }\n        if (seconds < 0 || seconds >= 60) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    override fun compareTo(other: Time): Int {\n        var delta = hours - other.hours\n        if (delta != 0) return delta\n        delta = minutes - other.minutes\n        if (delta != 0) return delta\n        delta = seconds - other.seconds\n        return if (delta != 0) delta else milliseconds - other.milliseconds\n    }\n\n    override fun hashCode(): Int {\n        return hours * 239 + minutes * 491 + seconds * 41 + milliseconds\n    }\n\n    override fun equals(other: Any?): Boolean {\n        return if (other !is Time) false else compareTo((other as Time?)!!) == 0\n\n    }\n\n    override fun toString(): String {\n        val result = StringBuilder()\n        if (hours < 10) result.append(\"0\")\n        result.append(hours)\n        if (minutes < 10) result.append(\"0\")\n        result.append(minutes)\n        if (seconds < 10) result.append(\"0\")\n        result.append(seconds)\n        return result.toString()\n    }\n\n    fun toPrettyHMString(): String {\n        val result = StringBuilder()\n        if (hours < 10) result.append(\"0\")\n        result.append(hours).append(DELIMITER)\n        if (minutes < 10) result.append(\"0\")\n        result.append(minutes)\n        return result.toString()\n    }\n\n    companion object {\n        private val DELIMITER = ':'\n        val DAY_START = Time(0, 0)\n        val DAY_END = Time(24, 0)\n\n        fun parse(s: String): Time {\n            if (s.length < 6) {\n                throw IllegalArgumentException()\n            }\n\n            val hours = s.substring(0, 2).toInt()\n            val minutes = s.substring(2, 4).toInt()\n            val seconds = s.substring(4, 6).toInt()\n\n            return Time(hours, minutes, seconds)\n        }\n\n        fun fromPrettyHMString(time: String): Time {\n            if (!time.contains(DELIMITER + \"\")) {\n                throw IllegalArgumentException()\n            }\n            val length = time.length\n            if (length != 5 && length != 4) {\n                throw IllegalArgumentException()\n            }\n            val hourLength = if (length == 4) 1 else 2\n            try {\n                return Time(\n                        time.substring(0, hourLength).toInt(),\n                        time.substring(hourLength + 1, length).toInt(), 0)\n            } catch (ignored: NumberFormatException) {\n                throw IllegalArgumentException()\n            }\n\n        }\n    }\n\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CharsKt\")\n\npackage kotlin.text\n\n/**\n * Returns the numeric value of the decimal digit that this Char represents.\n * Throws an exception if this Char is not a valid decimal digit.\n *\n * A Char is considered to represent a decimal digit if [isDigit] is true for the Char.\n * In this case, the Unicode decimal digit value of the character is returned.\n *\n * @sample samples.text.Chars.digitToInt\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToInt(): Int {\n    return digitOf(this, 10).also {\n        if (it < 0) throw IllegalArgumentException(\"Char $this is not a decimal digit\")\n    }\n}\n\n/**\n * Returns the numeric value of the digit that this Char represents in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36` or if this Char is not a valid digit in the specified [radix].\n *\n * A Char is considered to represent a digit in the specified [radix] if at least one of the following is true:\n *  - [isDigit] is `true` for the Char and the Unicode decimal digit value of the character is less than the specified [radix]. In this case the decimal digit value is returned.\n *  - The Char is one of the uppercase Latin letters 'A' through 'Z' and its [code] is less than `radix + 'A'.code - 10`. In this case, `this.code - 'A'.code + 10` is returned.\n *  - The Char is one of the lowercase Latin letters 'a' through 'z' and its [code] is less than `radix + 'a'.code - 10`. In this case, `this.code - 'a'.code + 10` is returned.\n *  - The Char is one of the fullwidth Latin capital letters '\\uFF21' through '\\uFF3A' and its [code] is less than `radix + 0xFF21 - 10`. In this case, `this.code - 0xFF21 + 10` is returned.\n *  - The Char is one of the fullwidth Latin small letters '\\uFF41' through '\\uFF5A' and its [code] is less than `radix + 0xFF41 - 10`. In this case, `this.code - 0xFF41 + 10` is returned.\n *\n * @sample samples.text.Chars.digitToInt\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToInt(radix: Int): Int {\n    return digitToIntOrNull(radix) ?: throw IllegalArgumentException(\"Char $this is not a digit in the given radix=$radix\")\n}\n\n/**\n *\n * Returns the numeric value of the decimal digit that this Char represents, or `null` if this Char is not a valid decimal digit.\n *\n * A Char is considered to represent a decimal digit if [isDigit] is true for the Char.\n * In this case, the Unicode decimal digit value of the character is returned.\n *\n * @sample samples.text.Chars.digitToIntOrNull\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToIntOrNull(): Int? {\n    return digitOf(this, 10).takeIf { it >= 0 }\n}\n\n/**\n * Returns the numeric value of the digit that this Char represents in the specified [radix], or `null` if this Char is not a valid digit in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36`.\n *\n * A Char is considered to represent a digit in the specified [radix] if at least one of the following is true:\n *  - [isDigit] is `true` for the Char and the Unicode decimal digit value of the character is less than the specified [radix]. In this case the decimal digit value is returned.\n *  - The Char is one of the uppercase Latin letters 'A' through 'Z' and its [code] is less than `radix + 'A'.code - 10`. In this case, `this.code - 'A'.code + 10` is returned.\n *  - The Char is one of the lowercase Latin letters 'a' through 'z' and its [code] is less than `radix + 'a'.code - 10`. In this case, `this.code - 'a'.code + 10` is returned.\n *  - The Char is one of the fullwidth Latin capital letters '\\uFF21' through '\\uFF3A' and its [code] is less than `radix + 0xFF21 - 10`. In this case, `this.code - 0xFF21 + 10` is returned.\n *  - The Char is one of the fullwidth Latin small letters '\\uFF41' through '\\uFF5A' and its [code] is less than `radix + 0xFF41 - 10`. In this case, `this.code - 0xFF41 + 10` is returned.\n *\n * @sample samples.text.Chars.digitToIntOrNull\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Char.digitToIntOrNull(radix: Int): Int? {\n    checkRadix(radix)\n    return digitOf(this, radix).takeIf { it >= 0 }\n}\n\n/**\n * Returns the Char that represents this decimal digit.\n * Throws an exception if this value is not in the range `0..9`.\n *\n * If this value is in `0..9`, the decimal digit Char with code `'0'.code + this` is returned.\n *\n * @sample samples.text.Chars.digitToChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Int.digitToChar(): Char {\n    if (this in 0..9) {\n        return '0' + this\n    }\n    throw IllegalArgumentException(\"Int $this is not a decimal digit\")\n}\n\n/**\n * Returns the Char that represents this numeric digit value in the specified [radix].\n * Throws an exception if the [radix] is not in the range `2..36` or if this value is not in the range `0 until radix`.\n *\n * If this value is less than `10`, the decimal digit Char with code `'0'.code + this` is returned.\n * Otherwise, the uppercase Latin letter with code `'A'.code + this - 10` is returned.\n *\n * @sample samples.text.Chars.digitToChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun Int.digitToChar(radix: Int): Char {\n    if (radix !in 2..36) {\n        throw IllegalArgumentException(\"Invalid radix: $radix. Valid radix values are in range 2..36\")\n    }\n    if (this < 0 || this >= radix) {\n        throw IllegalArgumentException(\"Digit $this does not represent a valid digit in radix $radix\")\n    }\n    return if (this < 10) {\n        '0' + this\n    } else {\n        'A' + this - 10\n    }\n}\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n */\n@Deprecated(\"Use lowercaseChar() instead.\", ReplaceWith(\"lowercaseChar()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun Char.toLowerCase(): Char\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [lowercase] function.\n * If this character has no mapping equivalent, the character itself is returned.\n *\n * @sample samples.text.Chars.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.lowercaseChar(): Char\n\n/**\n * Converts this character to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\u0130'.lowercase()` returns `\"\\u0069\\u0307\"`,\n * where `'\\u0130'` is the LATIN CAPITAL LETTER I WITH DOT ABOVE character (`İ`).\n * If this character has no lower case mapping, the result of `toString()` of this char is returned.\n *\n * @sample samples.text.Chars.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.lowercase(): String\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n */\n@Deprecated(\"Use uppercaseChar() instead.\", ReplaceWith(\"uppercaseChar()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun Char.toUpperCase(): Char\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [uppercase] function.\n * If this character has no mapping equivalent, the character itself is returned.\n *\n * @sample samples.text.Chars.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.uppercaseChar(): Char\n\n/**\n * Converts this character to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\uFB00'.uppercase()` returns `\"\\u0046\\u0046\"`,\n * where `'\\uFB00'` is the LATIN SMALL LIGATURE FF character (`ﬀ`).\n * If this character has no upper case mapping, the result of `toString()` of this char is returned.\n *\n * @sample samples.text.Chars.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun Char.uppercase(): String\n\n/**\n * Converts this character to title case using Unicode mapping rules of the invariant locale.\n *\n * This function performs one-to-one character mapping.\n * To support one-to-many character mapping use the [titlecase] function.\n * If this character has no mapping equivalent, the result of calling [uppercaseChar] is returned.\n *\n * @sample samples.text.Chars.titlecase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.titlecaseChar(): Char\n\n/**\n * Converts this character to title case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many character mapping, thus the length of the returned string can be greater than one.\n * For example, `'\\uFB00'.titlecase()` returns `\"\\u0046\\u0066\"`,\n * where `'\\uFB00'` is the LATIN SMALL LIGATURE FF character (`ﬀ`).\n * If this character has no title case mapping, the result of [uppercase] is returned instead.\n *\n * @sample samples.text.Chars.titlecase\n */\n@SinceKotlin(\"1.5\")\npublic fun Char.titlecase(): String = titlecaseImpl()\n\n/**\n * Concatenates this Char and a String.\n *\n * @sample samples.text.Chars.plus\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun Char.plus(other: String): String = this.toString() + other\n\n/**\n * Returns `true` if this character is equal to the [other] character, optionally ignoring character case.\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n *\n * Two characters are considered the same ignoring case if at least one of the following is `true`:\n *   - The two characters are the same (as compared by the == operator)\n *   - Applying the method [uppercaseChar] to each character produces the same result\n *   - Applying the method [lowercaseChar] to each character produces the same result\n *\n * @sample samples.text.Chars.equals\n */\npublic fun Char.equals(other: Char, ignoreCase: Boolean = false): Boolean {\n    if (this == other) return true\n    if (!ignoreCase) return false\n\n    val thisUpper = this.uppercaseChar()\n    val otherUpper = other.uppercaseChar()\n\n    return thisUpper == otherUpper || thisUpper.lowercaseChar() == otherUpper.lowercaseChar()\n}\n\n/**\n * Returns `true` if this character is a Unicode surrogate code unit.\n */\npublic fun Char.isSurrogate(): Boolean = this in Char.MIN_SURROGATE..Char.MAX_SURROGATE\n\n/**\n * Returns the Unicode general category of this character.\n */\n@SinceKotlin(\"1.5\")\npublic expect val Char.category: CharCategory\n\n/**\n * Returns `true` if this character (Unicode code point) is defined in Unicode.\n *\n * A character is considered to be defined in Unicode if its [category] is not [CharCategory.UNASSIGNED].\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isDefined(): Boolean\n\n/**\n * Returns `true` if this character is a letter.\n *\n * A character is considered to be a letter if its [category] is [CharCategory.UPPERCASE_LETTER],\n * [CharCategory.LOWERCASE_LETTER], [CharCategory.TITLECASE_LETTER], [CharCategory.MODIFIER_LETTER], or [CharCategory.OTHER_LETTER].\n *\n * @sample samples.text.Chars.isLetter\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLetter(): Boolean\n\n/**\n * Returns `true` if this character is a letter or digit.\n *\n * @see isLetter\n * @see isDigit\n *\n * @sample samples.text.Chars.isLetterOrDigit\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLetterOrDigit(): Boolean\n\n/**\n * Returns `true` if this character is a digit.\n *\n * A character is considered to be a digit if its [category] is [CharCategory.DECIMAL_DIGIT_NUMBER].\n *\n * @sample samples.text.Chars.isDigit\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isDigit(): Boolean\n\n/**\n * Returns `true` if this character is upper case.\n *\n * A character is considered to be an upper case character if its [category] is [CharCategory.UPPERCASE_LETTER],\n * or it has contributory property Other_Uppercase as defined by the Unicode Standard.\n *\n * @sample samples.text.Chars.isUpperCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isUpperCase(): Boolean\n\n/**\n * Returns `true` if this character is lower case.\n *\n * A character is considered to be a lower case character if its [category] is [CharCategory.LOWERCASE_LETTER],\n * or it has contributory property Other_Lowercase as defined by the Unicode Standard.\n *\n * @sample samples.text.Chars.isLowerCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isLowerCase(): Boolean\n\n/**\n * Returns `true` if this character is a title case letter.\n *\n * A character is considered to be a title case letter if its [category] is [CharCategory.TITLECASE_LETTER].\n *\n * @sample samples.text.Chars.isTitleCase\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isTitleCase(): Boolean\n\n/**\n * Returns `true` if this character is an ISO control character.\n *\n * A character is considered to be an ISO control character if its [category] is [CharCategory.CONTROL],\n * meaning the Char is in the range `'\\u0000'..'\\u001F'` or in the range `'\\u007F'..'\\u009F'`.\n *\n * @sample samples.text.Chars.isISOControl\n */\n@SinceKotlin(\"1.5\")\npublic expect fun Char.isISOControl(): Boolean\n\n/**\n * Determines whether a character is whitespace according to the Unicode standard.\n * Returns `true` if the character is whitespace.\n *\n * @sample samples.text.Chars.isWhitespace\n */\npublic expect fun Char.isWhitespace(): Boolean\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime\n\nenum class WeekDay(val abbreviation: String, val isWeekend: Boolean) {\n    MONDAY(\"MO\", false),\n    TUESDAY(\"TU\", false),\n    WEDNESDAY(\"WE\", false),\n    THURSDAY(\"TH\", false),\n    FRIDAY(\"FR\", false),\n    SATURDAY(\"SA\", true),\n    SUNDAY(\"SU\", true)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.datetime.tz\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.Month\nimport jetbrains.datalore.base.datetime.WeekDay\nimport kotlin.jvm.JvmOverloads\n\ninternal object DateSpecs {\n    fun last(weekDay: WeekDay, month: Month): DateSpec {\n        return object : DateSpec {\n\n            override val rRule: String\n                get() = \"RRULE:FREQ=YEARLY;BYDAY=-1\" + weekDay.abbreviation + \";BYMONTH=\" + (month.ordinal() + 1)\n\n            override fun getDate(year: Int): Date {\n                val days = month.getDaysInYear(year)\n                for (d in days downTo 1) {\n                    val date = Date(d, month, year)\n                    if (date.weekDay === weekDay) return date\n                }\n                throw RuntimeException()\n            }\n        }\n    }\n\n    @JvmOverloads\n    fun first(weekDay: WeekDay, month: Month, number: Int = 1): DateSpec {\n        return object : DateSpec {\n\n            override val rRule: String\n                get() = \"RRULE:FREQ=YEARLY;BYDAY=\" + number + weekDay.abbreviation + \";BYMONTH=\" + (month.ordinal() + 1)\n\n            override fun getDate(year: Int): Date {\n                val startDay = (number - 1) * WeekDay.values().size + 1\n                val days = month.getDaysInYear(year)\n                for (d in startDay..days) {\n                    val date = Date(d, month, year)\n                    if (date.weekDay === weekDay) return date\n                }\n                throw RuntimeException()\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nobject EnumInfoFactory {\n\n    /**\n     * @throws IllegalArgumentException if there are same enumConstant.toString() values (case insensitive) in the enum\n     */\n    inline fun <reified EnumT : Enum<EnumT>> createEnumInfo(): EnumInfo<EnumT> {\n        return EnumInfoImpl(enumValues())\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nclass EnumInfoImpl<EnumT : Enum<EnumT>>(enumConstants: Array<EnumT>) : EnumInfo<EnumT> {\n\n    private val myNormalizedValueMap: Map<String, EnumT>\n    private val myOriginalNames: List<String>\n\n    override val originalNames: List<String>\n        get() = myOriginalNames\n\n    private fun toNormalizedName(name: String): String {\n        return name.uppercase()\n    }\n\n    init {\n        val numConstants = enumConstants.size\n        val valueMap = HashMap<String, EnumT>(numConstants)\n        val originalNames = ArrayList<String>(numConstants)\n        for (value in enumConstants) {\n            val originalName = value.toString()\n            originalNames.add(originalName)\n            val normalizedName = toNormalizedName(originalName)\n            val oldValue = valueMap.put(normalizedName, value)\n            if (oldValue != null) {\n                throw IllegalArgumentException(\"duplicate values: '$value', '$oldValue'\")\n            }\n        }\n        myOriginalNames = originalNames\n        myNormalizedValueMap = valueMap\n    }\n\n    override fun safeValueOf(name: String?, defaultValue: EnumT): EnumT {\n        val value = safeValueOf(name)\n        return value ?: defaultValue\n    }\n\n    override fun safeValueOf(name: String?): EnumT? {\n        val result: EnumT?\n        if (hasValue(name)) {\n            result = myNormalizedValueMap[toNormalizedName(name!!)]\n        } else {\n            result = null\n        }\n        return result\n    }\n\n    override fun hasValue(name: String?): Boolean {\n        return name != null && myNormalizedValueMap.containsKey(toNormalizedName(name))\n    }\n\n    override fun unsafeValueOf(name: String): EnumT {\n        return safeValueOf(name) ?: throw IllegalArgumentException(\"name not found: '$name'\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.enums\n\nobject Enums {\n    /**\n     * Value of method for enums which takes into account toString() instead of saved generated name\n     */\n    inline fun <reified EnumT : Enum<EnumT>> valueOf(name: String): EnumT {\n        for (e in enumValues<EnumT>()) {\n            if (name == e.toString()) {\n                return e\n            }\n        }\n\n        throw IllegalArgumentException(name)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class Button {\n    NONE, LEFT, MIDDLE, RIGHT\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\n\nopen class Event {\n    private var eventContext: EventContext? = null\n        set(eventContext) {\n            if (this.eventContext != null) {\n                throw kotlin.IllegalStateException(\"Already set \" + this.eventContext!!)\n            }\n            if (isConsumed) {\n                throw IllegalStateException(\"Can't set a context to the consumed event\")\n            }\n            if (eventContext == null) {\n                throw IllegalArgumentException(\"Can't set null context\")\n            }\n            field = eventContext\n        }\n    var isConsumed: Boolean = false\n        private set\n\n    fun consume() {\n        doConsume()\n    }\n\n    private fun doConsume() {\n        if (isConsumed) {\n            throw IllegalStateException()\n        }\n        isConsumed = true\n    }\n\n    fun ensureConsumed() {\n        if (!isConsumed) {\n            consume()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class Key private constructor(private val myValue: String) {\n    A(\"A\"),\n    B(\"B\"),\n    C(\"C\"),\n    D(\"D\"),\n    E(\"E\"),\n    F(\"F\"),\n    G(\"G\"),\n    H(\"H\"),\n    I(\"I\"),\n    J(\"J\"),\n    K(\"K\"),\n    L(\"L\"),\n    M(\"M\"),\n    N(\"N\"),\n    O(\"O\"),\n    P(\"P\"),\n    Q(\"Q\"),\n    R(\"R\"),\n    S(\"S\"),\n    T(\"T\"),\n    U(\"U\"),\n    V(\"V\"),\n    W(\"W\"),\n    X(\"X\"),\n    Y(\"Y\"),\n    Z(\"Z\"),\n    DIGIT_0(\"0\"),\n    DIGIT_1(\"1\"),\n    DIGIT_2(\"2\"),\n    DIGIT_3(\"3\"),\n    DIGIT_4(\"4\"),\n    DIGIT_5(\"5\"),\n    DIGIT_6(\"6\"),\n    DIGIT_7(\"7\"),\n    DIGIT_8(\"8\"),\n    DIGIT_9(\"9\"),\n    LEFT_BRACE(\"[\"),\n    RIGHT_BRACE(\"]\"),\n    UP(\"Up\"),\n    DOWN(\"Down\"),\n    LEFT(\"Left\"),\n    RIGHT(\"Right\"),\n    PAGE_UP(\"Page Up\"),\n    PAGE_DOWN(\"Page Down\"),\n    ESCAPE(\"Escape\"),\n    ENTER(\"Enter\"),\n    HOME(\"Home\"),\n    END(\"End\"),\n    TAB(\"Tab\"),\n    SPACE(\"Space\"),\n    INSERT(\"Insert\"),\n    DELETE(\"Delete\"),\n    BACKSPACE(\"Backspace\"),\n    EQUALS(\"Equals\"),\n    BACK_QUOTE(\"`\"),\n    PLUS(\"Plus\"),\n    MINUS(\"Minus\"),\n    SLASH(\"Slash\"),\n    CONTROL(\"Ctrl\"),\n    META(\"Meta\"),\n    ALT(\"Alt\"),\n    SHIFT(\"Shift\"),\n    UNKNOWN(\"?\"),\n    F1(\"F1\"),\n    F2(\"F2\"),\n    F3(\"F3\"),\n    F4(\"F4\"),\n    F5(\"F5\"),\n    F6(\"F6\"),\n    F7(\"F7\"),\n    F8(\"F8\"),\n    F9(\"F9\"),\n    F10(\"F10\"),\n    F11(\"F11\"),\n    F12(\"F12\"),\n    COMMA(\",\"),\n    PERIOD(\".\");\n\n    override fun toString(): String {\n        return myValue\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyEvent : Event {\n\n    val keyStroke: KeyStroke\n    val keyChar: Char\n\n    val key: Key\n        get() = keyStroke.key\n\n    val modifiers: Set<ModifierKey>\n        get() = keyStroke.modifiers\n\n    constructor(keyStroke: KeyStroke) {\n        this.keyStroke = keyStroke\n        keyChar = 0.toChar()\n    }\n\n    constructor(key: Key, ch: Char = 0.toChar()) {\n        keyStroke = KeyStroke(key, emptyList())\n        keyChar = ch\n    }\n\n    constructor(key: Key, ch: Char, modifiers: Collection<ModifierKey>) {\n        keyStroke = KeyStroke(key, modifiers)\n        keyChar = ch\n    }\n\n    fun `is`(key: Key, vararg modifiers: ModifierKey): Boolean {\n        return keyStroke.`is`(key, *modifiers)\n    }\n\n    fun `is`(vararg specs: KeyStrokeSpec): Boolean {\n        for (s in specs) {\n            if (s.matches(keyStroke)) return true\n        }\n        return false\n    }\n\n    fun `is`(vararg specs: KeyStroke): Boolean {\n        for (s in specs) {\n            if (s.matches(keyStroke)) return true\n        }\n        return false\n    }\n\n    fun has(key: ModifierKey): Boolean {\n        return keyStroke.has(key)\n    }\n\n    fun copy(): KeyEvent {\n        return KeyEvent(key, keyChar, modifiers)\n    }\n\n    override fun toString(): String {\n        return keyStroke.toString()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyModifiers(val isCtrl: Boolean, val isAlt: Boolean, val isShift: Boolean, val isMeta: Boolean) {\n\n    private constructor() : this(false, false, false, false)\n\n    companion object {\n\n        private val EMPTY_MODIFIERS = KeyModifiers()\n\n        fun emptyModifiers(): KeyModifiers {\n            return EMPTY_MODIFIERS\n        }\n\n        fun withShift(): KeyModifiers {\n            return KeyModifiers(false, false, true, false)\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyStroke {\n    val key: Key\n    val modifiers: Set<ModifierKey>\n\n    constructor(key: Key, vararg modifiers: ModifierKey) : this(key, modifiers.asList())\n\n    constructor(key: Key, modifiers: Collection<ModifierKey>) {\n        this.key = key\n        this.modifiers = HashSet(modifiers)\n    }\n\n    fun has(key: ModifierKey): Boolean {\n        return modifiers.contains(key)\n    }\n\n    fun `is`(key: Key, vararg modifiers: ModifierKey): Boolean {\n        return matches(KeyStroke(key, *modifiers))\n    }\n\n    fun matches(keyStroke: KeyStroke): Boolean {\n        return equals(keyStroke)\n    }\n\n    fun with(key: ModifierKey): KeyStroke {\n        val keys = HashSet(modifiers)\n        keys.add(key)\n        return KeyStroke(this.key, keys)\n    }\n\n    override fun hashCode(): Int {\n        return key.hashCode() * 31 + modifiers.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is KeyStroke) return false\n        val otherKeyStroke = other as KeyStroke?\n\n        return key === otherKeyStroke!!.key && modifiers == otherKeyStroke!!.modifiers\n    }\n\n    override fun toString(): String {\n        return \"$key $modifiers\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nclass KeyStrokeSpec {\n\n    private val myKeyStrokes: Array<KeyStroke>\n\n    val keyStrokes: Iterable<KeyStroke>\n        get() = listOf(*myKeyStrokes)\n\n    val isEmpty: Boolean\n        get() = myKeyStrokes.isEmpty()\n\n    constructor(key: Key, vararg modifiers: ModifierKey) {\n        myKeyStrokes = arrayOf(KeyStroke(key, *modifiers))\n    }\n\n    constructor(keyStrokes: Collection<KeyStroke>) {\n        myKeyStrokes = keyStrokes.toTypedArray()\n    }\n\n    constructor(vararg keyStrokes: KeyStroke) {\n        myKeyStrokes = arrayOf(*keyStrokes)\n    }\n\n    fun matches(keyStroke: KeyStroke): Boolean {\n        for (spec in myKeyStrokes) {\n            if (spec.matches(keyStroke)) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun with(key: ModifierKey): KeyStrokeSpec {\n        val modified = ArrayList<KeyStroke>()\n        for (keyStroke in myKeyStrokes) {\n            modified.add(keyStroke.with(key))\n        }\n        return KeyStrokeSpec(modified)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        val that = other as KeyStrokeSpec?\n        return keyStrokes == that!!.keyStrokes\n    }\n\n    override fun hashCode(): Int {\n        return keyStrokes.hashCode()\n    }\n\n    override fun toString(): String {\n        return keyStrokes.toString()\n    }\n\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.event.ModifierKey.*\n\nobject KeyStrokeSpecs {\n    val COPY = composite(ctrlOrMeta(Key.C), KeyStrokeSpec(Key.INSERT, CONTROL))\n    val CUT = composite(ctrlOrMeta(Key.X), KeyStrokeSpec(Key.DELETE, SHIFT))\n    val PASTE = composite(ctrlOrMeta(Key.V), KeyStrokeSpec(Key.INSERT, SHIFT))\n\n    val UNDO = ctrlOrMeta(Key.Z)\n    val REDO = UNDO.with(SHIFT)\n\n    val COMPLETE = KeyStrokeSpec(Key.SPACE, CONTROL)\n\n    val SHOW_DOC = composite(KeyStrokeSpec(Key.F1), ctrlOrMeta(Key.J))\n\n    val HELP = composite(ctrlOrMeta(Key.I), ctrlOrMeta(Key.F1))\n\n    val HOME = composite(KeyStroke(Key.HOME), KeyStroke(Key.LEFT, META))\n    val END = composite(KeyStroke(Key.END), KeyStroke(Key.RIGHT, META))\n\n    val FILE_HOME = ctrlOrMeta(Key.HOME)\n    val FILE_END = ctrlOrMeta(Key.END)\n\n    val PREV_WORD = ctrlOrAlt(Key.LEFT)\n    val NEXT_WORD = ctrlOrAlt(Key.RIGHT)\n\n    val NEXT_EDITABLE = ctrlOrMeta(Key.RIGHT, ALT)\n    val PREV_EDITABLE = ctrlOrMeta(Key.LEFT, ALT)\n\n    val SELECT_ALL = ctrlOrMeta(Key.A)\n\n    val SELECT_FILE_HOME = FILE_HOME.with(SHIFT)\n    val SELECT_FILE_END = FILE_END.with(SHIFT)\n\n    val SELECT_HOME = HOME.with(SHIFT)\n    val SELECT_END = END.with(SHIFT)\n\n    val SELECT_WORD_FORWARD = NEXT_WORD.with(SHIFT)\n    val SELECT_WORD_BACKWARD = PREV_WORD.with(SHIFT)\n\n    val SELECT_LEFT = KeyStrokeSpec(Key.LEFT, SHIFT)\n    val SELECT_RIGHT = KeyStrokeSpec(Key.RIGHT, SHIFT)\n\n    val SELECT_UP = KeyStrokeSpec(Key.UP, SHIFT)\n    val SELECT_DOWN = KeyStrokeSpec(Key.DOWN, SHIFT)\n\n    val INCREASE_SELECTION = KeyStrokeSpec(Key.UP, ALT)\n    val DECREASE_SELECTION = KeyStrokeSpec(Key.DOWN, ALT)\n\n    val INSERT_BEFORE = composite(\n            KeyStroke(Key.ENTER, add(META)),\n            KeyStroke(Key.INSERT),\n            KeyStroke(Key.ENTER, add(CONTROL))\n    )\n    val INSERT_AFTER = KeyStrokeSpec(Key.ENTER)\n    val INSERT = composite(INSERT_BEFORE, INSERT_AFTER)\n\n    val DUPLICATE = ctrlOrMeta(Key.D)\n\n    val DELETE_CURRENT = composite(ctrlOrMeta(Key.BACKSPACE), ctrlOrMeta(Key.DELETE))\n\n    val DELETE_TO_WORD_START = KeyStrokeSpec(Key.BACKSPACE, ALT)\n\n    val MATCHING_CONSTRUCTS = composite(ctrlOrMeta(Key.LEFT_BRACE, ALT), ctrlOrMeta(Key.RIGHT_BRACE, ALT))\n\n    val NAVIGATE = ctrlOrMeta(Key.B)\n    val NAVIGATE_BACK = ctrlOrMeta(Key.LEFT_BRACE)\n    val NAVIGATE_FORWARD = ctrlOrMeta(Key.RIGHT_BRACE)\n\n    fun ctrlOrMeta(key: Key, vararg modifiers: ModifierKey): KeyStrokeSpec {\n        return composite(KeyStroke(key, add(CONTROL, *modifiers)), KeyStroke(key, add(META, *modifiers)))\n    }\n\n    fun ctrlOrAlt(key: Key, vararg modifiers: ModifierKey): KeyStrokeSpec {\n        return composite(KeyStroke(key, add(CONTROL, *modifiers)), KeyStroke(key, add(ALT, *modifiers)))\n    }\n\n    private fun add(key: ModifierKey, vararg otherKeys: ModifierKey): Set<ModifierKey> {\n        val result = HashSet(otherKeys.asList())\n        result.add(key)\n        return result\n    }\n\n    fun composite(vararg specs: KeyStrokeSpec): KeyStrokeSpec {\n        val keyStrokes = HashSet<KeyStroke>()\n        for (spec in specs) {\n            for (ks in spec.keyStrokes) {\n                keyStrokes.add(ks)\n            }\n        }\n        return KeyStrokeSpec(keyStrokes)\n    }\n\n    fun composite(vararg specs: KeyStroke): KeyStrokeSpec {\n        return KeyStrokeSpec(*specs)\n    }\n\n    fun withoutShift(spec: KeyStrokeSpec): KeyEvent {\n        val keyStroke = spec.keyStrokes.iterator().next()\n        val modifiers = keyStroke.modifiers\n        val withoutShift = HashSet<ModifierKey>()\n        for (modifier in modifiers) {\n            if (modifier !== SHIFT) {\n                withoutShift.add(modifier)\n            }\n        }\n        return KeyEvent(keyStroke.key, 0.toChar(), withoutShift)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class ModifierKey private constructor() {\n\n    CONTROL,\n    ALT,\n    SHIFT,\n    META\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.event.KeyModifiers.Companion.emptyModifiers\nimport jetbrains.datalore.base.geometry.Vector\n\n\nclass MouseEvent(x: Int, y: Int, val button: Button?, val modifiers: KeyModifiers) : PointEvent(x, y) {\n\n    companion object {\n\n        fun noButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.NONE, emptyModifiers())\n        }\n\n        fun leftButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.LEFT, emptyModifiers())\n        }\n\n        fun middleButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.MIDDLE, emptyModifiers())\n        }\n\n        fun rightButton(v: Vector): MouseEvent {\n            return MouseEvent(v, Button.RIGHT, emptyModifiers())\n        }\n    }\n\n    init {\n        requireNotNull(button) { \"Null button\" }\n    }\n\n    constructor(v: Vector, button: Button, modifiers: KeyModifiers) : this(v.x, v.y, button, modifiers)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nenum class MouseEventSpec {\n    MOUSE_ENTERED,\n    MOUSE_LEFT,\n    MOUSE_MOVED,\n    MOUSE_DRAGGED,\n    MOUSE_CLICKED,\n    MOUSE_DOUBLE_CLICKED,\n    MOUSE_PRESSED,\n    MOUSE_RELEASED\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.event\n\nimport jetbrains.datalore.base.geometry.Vector\n\nopen class PointEvent(val x: Int, val y: Int) : Event() {\n\n    val location: Vector\n        get() = Vector(x, y)\n\n    override fun toString(): String {\n        return \"{x=$x,y=$y}\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.function\n\nobject Functions {\n\n    private val TRUE_PREDICATE: Predicate<Any?> = {\n        true\n    }\n\n    private val FALSE_PREDICATE: Predicate<Any?> = {\n        false\n    }\n\n    private val NULL_PREDICATE: Predicate<Any?> = {\n        it == null\n    }\n\n    private val NOT_NULL_PREDICATE: Predicate<Any?> = {\n        it != null\n    }\n\n    fun <ItemT> constantSupplier(value: ItemT): Supplier<ItemT> {\n        return object : Supplier<ItemT> {\n            override fun get(): ItemT {\n                return value\n            }\n        }\n    }\n\n    fun <ItemT> memorize(supplier: Supplier<ItemT>): Supplier<ItemT> {\n        return Memo(supplier)\n    }\n\n    fun <ArgT> alwaysTrue(): Predicate<ArgT> {\n        return TRUE_PREDICATE\n    }\n\n    fun <ArgT> alwaysFalse(): Predicate<ArgT> {\n        return FALSE_PREDICATE\n    }\n\n    fun <ArgT, ResultT> constant(result: ResultT): (ArgT) -> ResultT {\n        return {\n            result\n        }\n    }\n\n    fun <ArgT> isNull(): Predicate<ArgT> {\n        return NULL_PREDICATE\n    }\n\n    fun <ArgT> isNotNull(): Predicate<ArgT> {\n        return NOT_NULL_PREDICATE\n    }\n\n    fun <ValueT> identity(): (ValueT) -> ValueT {\n        return { it }\n    }\n\n    fun <ValueT> same(value: Any?): Predicate<ValueT> {\n        return {\n            it === value\n        }\n    }\n\n    fun <ArgT, ResultT> funcOf(lambda: (ArgT) -> ResultT): Function<ArgT, ResultT> {\n        return object : Function<ArgT, ResultT> {\n            override fun apply(value: ArgT): ResultT {\n                return lambda(value)\n            }\n        }\n    }\n\n    private class Memo<ItemT> internal constructor(private val mySupplier: Supplier<ItemT>) : Supplier<ItemT> {\n        private var myCachedValue: ItemT? = null\n        private var myCached = false\n\n        override fun get(): ItemT {\n            if (!myCached) {\n                myCachedValue = mySupplier.get()\n                myCached = true\n            }\n            return myCachedValue!!\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.function\n\n/**\n * Mutable container for ValueT. Used mainly to change values from inside of anonymous class/function\n */\nclass Value<ValueT>(private var myValue: ValueT) : Supplier<ValueT> {\n\n    override fun get(): ValueT {\n        return myValue\n    }\n\n    fun set(value: ValueT) {\n        myValue = value\n    }\n\n    override fun toString(): String {\n        return \"\" + myValue\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Preconditions {\n    @Deprecated(\"Replace with Kotlin 'check()'\")\n    fun checkState(expression: Boolean) {\n        if (!expression) {\n            throw IllegalStateException()\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'check()'\")\n    fun checkState(expression: Boolean, errorMessage: Any) {\n        if (!expression) {\n            throw IllegalStateException(errorMessage.toString())\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'require()'\")\n    fun checkArgument(expression: Boolean) {\n        if (!expression) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    @Deprecated(\"Replace with Kotlin 'require()'\")\n    fun checkArgument(expression: Boolean, errorMessage: Any) {\n        if (!expression) {\n            throw IllegalArgumentException(errorMessage.toString())\n        }\n    }\n\n    // ToDo: use `checkNotNull` from kotlin std-lib\n    fun <T> checkNotNull(reference: T?): T {\n        if (reference == null) {\n            throw NullPointerException()\n        }\n        return reference\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Strings {\n\n    // ToDo: use Kotlin `isNullOrEmpty` or `isNullOrBlank`\n    fun isNullOrEmpty(s: String?): Boolean {\n        return s == null || s.isEmpty()\n    }\n\n    fun nullToEmpty(string: String?): String {\n        return string ?: \"\"\n    }\n\n    fun repeat(string: String, count: Int): String {\n        val stringBuilder = StringBuilder()\n        for (i in 0 until count) {\n            stringBuilder.append(string)\n        }\n        return stringBuilder.toString()\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.base\n\nobject Throwables {\n    fun getRootCause(throwable: Throwable): Throwable {\n        // Keep a second pointer that slowly walks the causal chain. If the fast pointer ever catches\n        // the slower pointer, then there's a loop.\n        var slowPointer: Throwable = throwable\n        var advanceSlowPointer = false\n\n        var cause = throwable\n        while (cause.cause != null) {\n            cause = cause.cause!!\n\n            if (cause === slowPointer) {\n                throw IllegalArgumentException(\"Loop in causal chain detected.\", cause)\n            }\n            if (advanceSlowPointer) {\n                slowPointer = slowPointer.cause!!\n            }\n            advanceSlowPointer = !advanceSlowPointer // only advance every other iteration\n        }\n        return cause\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nimport jetbrains.datalore.base.gcommon.collect.Comparables.gt\nimport jetbrains.datalore.base.gcommon.collect.Comparables.gte\nimport jetbrains.datalore.base.gcommon.collect.Comparables.ls\nimport jetbrains.datalore.base.gcommon.collect.Comparables.lse\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\n\nopen class ClosedRange<T : Comparable<T>>(\n    lower: T,\n    upper: T\n) {\n    val lowerEnd: T\n    val upperEnd: T\n\n    init {\n        (lower as? Double)?.run {\n            check(isFinite()) {\n                \"ends must be finite: lower=$lower upper=$upper\"\n            }\n        }\n        (upper as? Double)?.run {\n            check(isFinite()) {\n                \"ends must be finite: lower=$lower upper=$upper\"\n            }\n        }\n        lowerEnd = min(lower, upper)\n        upperEnd = max(lower, upper)\n    }\n\n    operator fun contains(v: T): Boolean {\n        return lse(lowerEnd, v) && lse(v, upperEnd)\n    }\n\n    fun span(other: ClosedRange<T>): ClosedRange<T> {\n        if (encloses(other)) return this\n        return if (other.encloses(this)) other else ClosedRange(\n            min(lowerEnd, other.lowerEnd),\n            max(upperEnd, other.upperEnd)\n        )\n    }\n\n    fun encloses(other: ClosedRange<T>): Boolean {\n        return lse(lowerEnd, other.lowerEnd) && gte(upperEnd, other.upperEnd)\n    }\n\n    fun isConnected(other: ClosedRange<T>): Boolean {\n        return !(gt(lowerEnd, other.upperEnd) || ls(upperEnd, other.lowerEnd))\n    }\n\n    fun intersection(other: ClosedRange<T>): ClosedRange<T> {\n        if (!isConnected(other)) throw IllegalArgumentException(\"Ranges are not connected: this=$this other=$other\")\n        if (encloses(other)) return other\n        return if (other.encloses(this)) this else ClosedRange(\n            max(lowerEnd, other.lowerEnd),\n            min(upperEnd, other.upperEnd)\n        )\n    }\n\n    override fun toString(): String {\n        return \"ClosedRange[$lowerEnd, $upperEnd]\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as ClosedRange<*>\n\n        if (lowerEnd != other.lowerEnd) return false\n        if (upperEnd != other.upperEnd) return false\n        return true\n    }\n\n    override fun hashCode(): Int {\n        return lowerEnd.hashCode() + 31 * upperEnd.hashCode()\n    }\n\n    companion object {\n        fun <T : Comparable<T>> singleton(v: T): ClosedRange<T> {\n            return ClosedRange(v, v)\n        }\n\n        fun <T : Comparable<T>> encloseAll(values: Iterable<T?>): ClosedRange<T> {\n            var iterated = false\n            var min: T? = null\n            var max: T? = null\n            for (v: T? in values) {\n                if (!iterated) {\n                    iterated = true\n                    min = v\n                    max = v\n                } else {\n                    min = min(min!!, v!!)\n                    max = max(max!!, v)\n                }\n            }\n            if (!iterated) {\n                throw NoSuchElementException()\n            }\n            return ClosedRange<T>(min!!, max!!)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\n\nobject Comparables {\n    fun <T : Comparable<T>> min(a: T, b: T): T {\n        return if (a < b) a else b\n    }\n\n    fun <T : Comparable<T>> max(a: T, b: T): T {\n        return if (a >= b) a else b\n    }\n\n    fun <T : Comparable<T>> lse(a: T, b: T): Boolean {\n        return a <= b\n    }\n\n    fun <T : Comparable<T>> gte(a: T, b: T): Boolean {\n        return a >= b\n    }\n\n    fun <T : Comparable<T>> ls(a: T, b: T): Boolean {\n        return a < b\n    }\n\n    fun <T : Comparable<T>> gt(a: T, b: T): Boolean {\n        return a > b\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\ninternal class ComparatorOrdering<T>(comparator: Comparator<T>) : Ordering<T>() {\n    private val myComparator: Comparator<T> = comparator\n\n    override fun compare(a: T, b: T): Int {\n        return myComparator.compare(a, b)\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nimport jetbrains.datalore.base.function.Predicate\n\nobject Iterables {\n    private fun checkNonNegative(position: Int) {\n        if (position < 0) {\n            throw IndexOutOfBoundsException(position.toString())\n        }\n    }\n\n    fun <T> toList(iterable: Iterable<T>): List<T> {\n        return iterable.toList()\n    }\n\n    fun size(iterable: Iterable<*>): Int {\n        return iterable.count()\n    }\n\n    fun isEmpty(iterable: Iterable<*>): Boolean {\n        return (iterable as? Collection<*>)?.isEmpty() ?: !iterable.iterator().hasNext()\n    }\n\n    fun <T> filter(unfiltered: Iterable<T>, retainIfTrue: Predicate<in T>): Iterable<T> {\n        return unfiltered.filter(retainIfTrue)\n    }\n\n    fun <T> all(iterable: Iterable<T>, predicate: Predicate<in T>): Boolean {\n        return iterable.all(predicate)\n    }\n\n    fun <T> concat(a: Iterable<T>, b: Iterable<T>): Iterable<T> {\n        return a + b\n    }\n\n    operator fun <T> get(iterable: Iterable<T>, position: Int): T {\n        checkNonNegative(position)\n        if (iterable is List<*>) {\n            return (iterable as List<T>)[position]\n        }\n\n        val it = iterable.iterator()\n        for (i in 0..position) {\n            if (i == position) {\n                return it.next()\n            }\n            it.next()\n        }\n        throw IndexOutOfBoundsException(position.toString())\n    }\n\n    operator fun <T> get(iterable: Iterable<T>, position: Int, defaultValue: T): T {\n        checkNonNegative(position)\n        if (iterable is List<*>) {\n            val list = iterable as List<T>\n            return if (position < list.size) list[position] else defaultValue\n        }\n        val it = iterable.iterator()\n        var i = 0\n        while (i <= position && it.hasNext()) {\n            if (i == position) {\n                return it.next()\n            }\n            it.next()\n            i++\n        }\n        return defaultValue\n    }\n\n    fun <T> find(iterable: Iterable<T>, predicate: Predicate<in T>, defaultValue: T): T {\n        return iterable.find(predicate) ?: defaultValue\n    }\n\n    fun <T> getLast(iterable: Iterable<T>): T {\n        return iterable.last()\n    }\n\n    internal fun toArray(iterable: Iterable<*>): Array<*> {\n        val collection: Collection<*>\n        if (iterable is Collection<*>) {\n            collection = iterable\n        } else {\n            collection = iterable.toList()\n        }\n        return collection.toTypedArray()\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\n\nobject Lists {\n    fun <F, T> transform(fromList: List<F>, function: (F) -> T): List<T> {\n        return fromList.map { t -> function.invoke(t) }\n    }\n\n    /**\n     * Doesn't return reversed `view` of the list (guava)\n     * Instead creates reversed copy.\n     */\n    fun <T> reverse(list: List<T>): List<T> {\n        val copy = ArrayList(list)\n        copy.reverse()\n        return copy\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nabstract class Ordering<T> : Comparator<T> {\n\n    fun isOrdered(iterable: Iterable<T>): Boolean {\n        val it = iterable.iterator()\n        if (it.hasNext()) {\n            var prev: T = it.next()\n            while (it.hasNext()) {\n                val next = it.next()\n                if (compare(prev, next) > 0) {\n                    return false\n                }\n                prev = next\n            }\n        }\n        return true\n    }\n\n    /**\n     * @return immutable sorted list\n     */\n    fun <E : T> sortedCopy(elements: Iterable<E>): List<E> {\n        @Suppress(\"UNCHECKED_CAST\")\n        val array = Iterables.toArray(elements) as Array<E>\n        array.sortWith(object : Comparator<E> {\n            override fun compare(a: E, b: E): Int {\n                return this@Ordering.compare(a, b)\n            }\n        })\n        return array.toList()\n    }\n\n    fun reverse(): Ordering<T> {\n        return ComparatorOrdering(reversed())\n    }\n\n    fun <E : T> min(a: E, b: E): E {\n        return if (compare(a, b) <= 0) a else b\n    }\n\n    fun <E : T> min(iterable: Iterable<E>): E {\n        return min(iterable.iterator())\n    }\n\n    fun <E : T> min(iterator: Iterator<E>): E {\n        // input must not be empty\n        var result = iterator.next()\n        while (iterator.hasNext()) {\n            result = min(result, iterator.next())\n        }\n\n        return result\n    }\n\n\n    fun <E : T> max(a: E, b: E): E {\n        return if (compare(a, b) >= 0) a else b\n    }\n\n    fun <E : T> max(iterable: Iterable<E>): E {\n        return max(iterable.iterator())\n    }\n\n    fun <E : T> max(iterator: Iterator<E>): E {\n        // input must not be empty\n        var result = iterator.next()\n        while (iterator.hasNext()) {\n            result = max(result, iterator.next())\n        }\n\n        return result\n    }\n\n    companion object {\n\n        fun <T> from(comparator: Comparator<T>): Ordering<T> {\n            return if (comparator is Ordering<*>)\n                comparator as Ordering<T>\n            else\n                ComparatorOrdering(comparator)\n        }\n\n        fun <T : Comparable<T>> natural(): Ordering<T> {\n            return ComparatorOrdering(naturalOrder())\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nobject Sets {\n    /**\n     * Mutable set\n     */\n    fun <E> newHashSet(elements: Iterable<E>): MutableSet<E> {\n        if (elements is Collection<*>) {\n            val collection = elements as Collection<E>\n            return HashSet(collection)\n        }\n        return newHashSet(elements.iterator())\n    }\n\n    /**\n     * Mutable set\n     */\n    private fun <E> newHashSet(elements: Iterator<E>): MutableSet<E> {\n        val set = HashSet<E>()\n        while (elements.hasNext()) {\n            set.add(elements.next())\n        }\n        return set\n    }\n\n//    /**\n//     * Unmodifiable copy\n//     */\n//    fun <E> difference(set1: Set<E>, set2: Set<E>): Set<E> {\n//        val copy = HashSet(set1)\n//        copy.removeAll(set2)\n//        return copy\n//    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nclass Stack<T> {\n    private val elements: MutableList<T> = ArrayList()\n\n    fun empty() = elements.isEmpty()\n\n    fun push(item: T) = elements.add(item)\n\n    fun pop(): T? = if (elements.isEmpty()) null else elements.removeAt(elements.size - 1)\n\n    fun peek(): T? = elements.lastOrNull()\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Copyright (C) 2007 The Guava Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\npackage jetbrains.datalore.base.gcommon.collect\n\nclass TreeMap<K : Comparable<K>, V> {\n    val values: Collection<V>\n        get() = map.values\n    private val sortedKeys: MutableList<K> = ArrayList()\n    private val map: MutableMap<K, V> = HashMap()\n\n    operator fun get(key: K): V? = map[key]\n\n    fun put(key: K, value: V): V? {\n        val index = sortedKeys.binarySearch(key)\n        if (index < 0) {\n            sortedKeys.add(index.inv(), key)\n        } else {\n            sortedKeys[index] = key\n        }\n        return map.put(key, value)\n    }\n\n    fun containsKey(key: K): Boolean = map.containsKey(key)\n\n    fun floorKey(key: K): K? {\n        var index = sortedKeys.binarySearch(key)\n\n        if (index < 0) {\n            index = index.inv() - 1\n\n            if (index < 0)\n                return null\n        }\n        return sortedKeys[index]\n    }\n\n    fun ceilingKey(key: K): K? {\n        var index = sortedKeys.binarySearch(key)\n\n        if (index < 0) {\n            index = index.inv()\n\n            if (index == sortedKeys.size)\n                return null\n        }\n        return sortedKeys[index]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass DoubleRectangle(val origin: DoubleVector, val dimension: DoubleVector) {\n\n    val center: DoubleVector\n        get() = origin.add(dimension.mul(0.5))\n\n    val left: Double\n        get() = origin.x\n\n    val right: Double\n        get() = origin.x + dimension.x\n\n    val top: Double\n        get() = origin.y\n\n    val bottom: Double\n        get() = origin.y + dimension.y\n\n    val width: Double\n        get() = dimension.x\n\n    val height: Double\n        get() = dimension.y\n\n    val parts: Iterable<DoubleSegment>\n        get() {\n            val result = ArrayList<DoubleSegment>()\n            result.add(DoubleSegment(origin, origin.add(DoubleVector(dimension.x, 0.0))))\n            result.add(DoubleSegment(origin, origin.add(DoubleVector(0.0, dimension.y))))\n            result.add(DoubleSegment(origin.add(dimension), origin.add(DoubleVector(dimension.x, 0.0))))\n            result.add(DoubleSegment(origin.add(dimension), origin.add(DoubleVector(0.0, dimension.y))))\n            return result\n        }\n\n    constructor(x: Double, y: Double, w: Double, h: Double) : this(DoubleVector(x, y), DoubleVector(w, h))\n\n    fun xRange(): ClosedRange<Double> {\n        return ClosedRange(origin.x, origin.x + dimension.x)\n    }\n\n    fun yRange(): ClosedRange<Double> {\n        return ClosedRange(origin.y, origin.y + dimension.y)\n    }\n\n    operator fun contains(v: DoubleVector): Boolean {\n        return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n    }\n\n    fun union(rect: DoubleRectangle): DoubleRectangle {\n        val newOrigin = origin.min(rect.origin)\n        val corner = origin.add(dimension)\n        val rectCorner = rect.origin.add(rect.dimension)\n        val newCorner = corner.max(rectCorner)\n        val newDimension = newCorner.subtract(newOrigin)\n        return DoubleRectangle(newOrigin, newDimension)\n    }\n\n    fun intersects(rect: DoubleRectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n    }\n\n    fun intersect(r: DoubleRectangle): DoubleRectangle? {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = r.origin\n        val r2 = r.origin.add(r.dimension)\n\n        val res1 = t1.max(r1)\n        val res2 = t2.min(r2)\n\n        val dim = res2.subtract(res1)\n\n        return if (dim.x < 0 || dim.y < 0) {\n            null\n        } else DoubleRectangle(res1, dim)\n\n    }\n\n    fun add(v: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(origin.add(v), dimension)\n    }\n\n    fun subtract(v: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(origin.subtract(v), dimension)\n    }\n\n    fun distance(to: DoubleVector): Double {\n        var result = 0.0\n        var hasResult = false\n        for (s in parts) {\n            if (!hasResult) {\n                result = s.distance(to)\n                hasResult = true\n            } else {\n                val distance = s.distance(to)\n                if (distance < result) {\n                    result = distance\n                }\n            }\n        }\n        return result\n    }\n\n    override fun hashCode(): Int {\n        return origin.hashCode() * 31 + dimension.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleRectangle) {\n            return false\n        }\n        val r = other as DoubleRectangle?\n        return r!!.origin.equals(origin) && r.dimension.equals(dimension)\n    }\n\n    override fun toString(): String {\n        return \"[rect $origin, $dimension]\"\n    }\n\n    companion object {\n        fun span(leftTop: DoubleVector, rightBottom: DoubleVector): DoubleRectangle {\n            return DoubleRectangle(leftTop, rightBottom.subtract(leftTop))\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject DoubleRectangles {\n\n    fun boundingBox(points: Iterable<DoubleVector>): DoubleRectangle {\n        return calculateBoundingBox(points, DoubleVector::x, DoubleVector::y)\n        { minX, minY, maxX, maxY ->\n            DoubleRectangle.span(\n                DoubleVector(minX, minY),\n                DoubleVector(maxX, maxY)\n            )\n        }\n    }\n\n    fun <PointT, BoxT> calculateBoundingBox(\n        points: Iterable<PointT>,\n        getX: (PointT) -> Double,\n        getY: (PointT) -> Double,\n        factory: (minX: Double, minY: Double, maxX: Double, maxY: Double) -> BoxT\n    ): BoxT {\n        val first = points.iterator().next()\n        var minLon = getX(first)\n        var minLat = getY(first)\n        var maxLon = minLon\n        var maxLat = minLat\n\n        for (point in points) {\n            minLon = min(minLon, getX(point))\n            maxLon = max(maxLon, getX(point))\n            minLat = min(minLat, getY(point))\n            maxLat = max(maxLat, getY(point))\n        }\n\n        return factory(minLon, minLat, maxLon, maxLat)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.min\n\nclass DoubleSegment(val start: DoubleVector, val end: DoubleVector) {\n\n    fun distance(v: DoubleVector): Double {\n        val vs = start.subtract(v)\n        val ve = end.subtract(v)\n\n        if (isDistanceToLineBest(v)) {\n            val pVolume = abs(vs.x * ve.y - vs.y * ve.x)\n            return pVolume / length()\n        } else {\n            return min(vs.length(), ve.length())\n        }\n    }\n\n    private fun isDistanceToLineBest(v: DoubleVector): Boolean {\n        val es = start.subtract(end)\n        val se = es.negate()\n        val ev = v.subtract(end)\n        val sv = v.subtract(start)\n\n        return es.dotProduct(ev) >= 0 && se.dotProduct(sv) >= 0\n    }\n\n    fun intersection(with: DoubleSegment): DoubleVector? {\n        val o1 = start\n        val o2 = with.start\n        val d1 = end.subtract(start)\n        val d2 = with.end.subtract(with.start)\n\n        val td = d1.dotProduct(d2.orthogonal())\n        if (td == 0.0) {\n            return null\n        }\n        val t = o2.subtract(o1).dotProduct(d2.orthogonal()) / td\n        if (t < 0 || t > 1) {\n            return null\n        }\n\n        val sd = d2.dotProduct(d1.orthogonal())\n        val s = o1.subtract(o2).dotProduct(d1.orthogonal()) / sd\n        return if (s < 0 || s > 1) {\n            null\n        } else o1.add(d1.mul(t))\n\n    }\n\n    fun length(): Double {\n        return start.subtract(end).length()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleSegment) {\n            return false\n        }\n\n        val l = other as DoubleSegment?\n        return l!!.start.equals(start) && l.end.equals(end)\n    }\n\n    override fun hashCode(): Int {\n        return start.hashCode() * 31 + end.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"[$start -> $end]\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.*\n\nclass DoubleVector(val x: Double, val y: Double) {\n\n    fun add(v: DoubleVector): DoubleVector {\n        return DoubleVector(x + v.x, y + v.y)\n    }\n\n    fun subtract(v: DoubleVector): DoubleVector {\n        return DoubleVector(x - v.x, y - v.y)\n    }\n\n    fun max(v: DoubleVector): DoubleVector {\n        return DoubleVector(max(x, v.x), max(y, v.y))\n    }\n\n    fun min(v: DoubleVector): DoubleVector {\n        return DoubleVector(min(x, v.x), min(y, v.y))\n    }\n\n    fun mul(value: Double): DoubleVector {\n        return DoubleVector(x * value, y * value)\n    }\n\n    fun dotProduct(v: DoubleVector): Double {\n        return x * v.x + y * v.y\n    }\n\n    fun negate(): DoubleVector {\n        return DoubleVector(-x, -y)\n    }\n\n    fun orthogonal(): DoubleVector {\n        return DoubleVector(-y, x)\n    }\n\n    fun length(): Double {\n        return sqrt(x * x + y * y)\n    }\n\n    fun normalize(): DoubleVector {\n        return mul(1 / length())\n    }\n\n    fun rotate(phi: Double): DoubleVector {\n        val x = this.x * cos(phi) - this.y * sin(phi)\n        val y = this.x * sin(phi) + this.y * cos(phi)\n        return DoubleVector(x, y)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is DoubleVector) {\n            return false\n        }\n        val v = other as DoubleVector?\n        return v!!.x == x && v.y == y\n    }\n\n    override fun hashCode(): Int {\n        return x.hashCode() + 31 * y.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"($x, $y)\"\n    }\n\n    companion object {\n        val ZERO = DoubleVector(0.0, 0.0)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass Rectangle(val origin: Vector, val dimension: Vector) {\n\n    val boundSegments: Array<Segment>\n        get() {\n            val p = boundPoints\n            return arrayOf<Segment>(Segment(p[0], p[1]), Segment(p[1], p[2]), Segment(p[2], p[3]), Segment(p[3], p[0]))\n        }\n\n    private val boundPoints: Array<Vector>\n        get() = arrayOf(origin, origin.add(Vector(dimension.x, 0)), origin.add(dimension), origin.add(Vector(0, dimension.y)))\n\n    constructor(x: Int, y: Int, width: Int, height: Int) : this(Vector(x, y), Vector(width, height))\n\n    fun add(v: Vector): Rectangle {\n        return Rectangle(origin.add(v), dimension)\n    }\n\n    fun sub(v: Vector): Rectangle {\n        return Rectangle(origin.sub(v), dimension)\n    }\n\n    operator fun contains(r: Rectangle): Boolean {\n        return contains(r.origin) && contains(r.origin.add(r.dimension))\n    }\n\n    operator fun contains(v: Vector): Boolean {\n        return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n    }\n\n    fun union(rect: Rectangle): Rectangle {\n        val newOrigin = origin.min(rect.origin)\n        val corner = origin.add(dimension)\n        val rectCorner = rect.origin.add(rect.dimension)\n        val newCorner = corner.max(rectCorner)\n        val newDimension = newCorner.sub(newOrigin)\n        return Rectangle(newOrigin, newDimension)\n    }\n\n    fun intersects(rect: Rectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n    }\n\n    fun intersect(r: Rectangle): Rectangle {\n        if (!intersects(r)) {\n            throw IllegalStateException(\"rectangle [$this] doesn't intersect [$r]\")\n        }\n\n        val too = origin.add(dimension)\n        val roo = r.origin.add(r.dimension)\n        val ioo = too.min(roo)\n\n        val io = origin.max(r.origin)\n        return Rectangle(io, ioo.sub(io))\n    }\n\n    fun innerIntersects(rect: Rectangle): Boolean {\n        val t1 = origin\n        val t2 = origin.add(dimension)\n        val r1 = rect.origin\n        val r2 = rect.origin.add(rect.dimension)\n        return r2.x > t1.x && t2.x > r1.x && r2.y > t1.y && t2.y > r1.y\n    }\n\n    fun changeDimension(dim: Vector): Rectangle {\n        return Rectangle(origin, dim)\n    }\n\n    fun distance(to: Vector): Double {\n        return toDoubleRectangle().distance(to.toDoubleVector())\n    }\n\n    fun xRange(): ClosedRange<Int> {\n        return ClosedRange(origin.x, origin.x + dimension.x)\n    }\n\n    fun yRange(): ClosedRange<Int> {\n        return ClosedRange(origin.y, origin.y + dimension.y)\n    }\n\n    override fun hashCode(): Int {\n        return origin.hashCode() * 31 + dimension.hashCode()\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Rectangle) return false\n\n        val otherRect = other as Rectangle?\n        return origin == otherRect!!.origin && dimension == otherRect.dimension\n    }\n\n    private fun toDoubleRectangle(): DoubleRectangle {\n        return DoubleRectangle(origin.toDoubleVector(), dimension.toDoubleVector())\n    }\n\n    fun center(): Vector {\n        return origin.add(Vector(dimension.x / 2, dimension.y / 2))\n    }\n\n    override fun toString(): String {\n        return \"$origin - $dimension\"\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\n/**\n * X axis positive direction is right;\n * Y axis positive direction is down.\n */\nobject Rectangles {\n    fun zeroOrigin(r: Rectangle): Rectangle {\n        return Rectangle(Vector.ZERO, r.dimension)\n    }\n\n    fun upperDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topLeft(inner).y - topLeft(outer).y\n    }\n\n    fun lowerDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return bottomLeft(outer).y - bottomLeft(inner).y\n    }\n\n    fun leftDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topLeft(inner).x - topLeft(outer).x\n    }\n\n    fun rightDistance(inner: Rectangle, outer: Rectangle): Int {\n        assertOuterInner(outer, inner)\n        return topRight(outer).x - topRight(inner).x\n    }\n\n    private fun assertOuterInner(outer: Rectangle, inner: Rectangle) {\n        if (!outer.contains(inner)) {\n            throw IllegalArgumentException(\"Outer does not contain inner: outer = $outer, inner = $inner\")\n        }\n    }\n\n    fun extendUp(r: Rectangle, distance: Int): Rectangle {\n        val change = Vector(0, distance)\n        return Rectangle(r.origin.sub(change), r.dimension.add(change))\n    }\n\n    fun extendDown(r: Rectangle, distance: Int): Rectangle {\n        return r.changeDimension(r.dimension.add(Vector(0, distance)))\n    }\n\n    fun extendLeft(r: Rectangle, distance: Int): Rectangle {\n        val change = Vector(distance, 0)\n        return Rectangle(r.origin.sub(change), r.dimension.add(change))\n    }\n\n    fun extendRight(r: Rectangle, distance: Int): Rectangle {\n        return r.changeDimension(r.dimension.add(Vector(distance, 0)))\n    }\n\n    fun extendSides(left: Int, r: Rectangle, right: Int): Rectangle {\n        return extendRight(extendLeft(r, left), right)\n    }\n\n    fun shrinkRight(r: Rectangle, distance: Int): Rectangle {\n        if (r.dimension.x < distance) {\n            throw IllegalArgumentException(\"To small rectangle = $r, distance = $distance\")\n        }\n        return r.changeDimension(r.dimension.sub(Vector(distance, 0)))\n    }\n\n    private fun topLeft(r: Rectangle): Vector {\n        return r.origin\n    }\n\n    fun topRight(r: Rectangle): Vector {\n        return r.origin.add(Vector(r.dimension.x, 0))\n    }\n\n    private fun bottomLeft(r: Rectangle): Vector {\n        return r.origin.add(Vector(0, r.dimension.y))\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.min\n\nclass Segment(val start: Vector, val end: Vector) {\n\n    fun distance(v: Vector): Double {\n        val vs = start.sub(v)\n        val ve = end.sub(v)\n\n        if (isDistanceToLineBest(v)) {\n            val pVolume = abs(vs.x * ve.y - vs.y * ve.x).toDouble()\n            return pVolume / length()\n        } else {\n            return min(vs.toDoubleVector().length(), ve.toDoubleVector().length())\n        }\n    }\n\n    private fun isDistanceToLineBest(v: Vector): Boolean {\n        val es = start.sub(end)\n        val se = es.negate()\n        val ev = v.sub(end)\n        val sv = v.sub(start)\n\n        return es.dotProduct(ev) >= 0 && se.dotProduct(sv) >= 0\n    }\n\n    fun toDoubleSegment(): DoubleSegment {\n        return DoubleSegment(start.toDoubleVector(), end.toDoubleVector())\n    }\n\n    fun intersection(with: Segment): DoubleVector? {\n        return toDoubleSegment().intersection(with.toDoubleSegment())\n    }\n\n    fun length(): Double {\n        return start.sub(end).length()\n    }\n\n    operator fun contains(v: Vector): Boolean {\n        val p1 = v.sub(start)\n        val p2 = v.sub(end)\n        return if (p1.isParallel(p2)) {\n            p1.dotProduct(p2) <= 0\n        } else false\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Segment) {\n            return false\n        }\n\n        val l = other as Segment?\n        return l!!.start == start && l.end == end\n    }\n\n    override fun hashCode(): Int {\n        return start.hashCode() * 31 + end.hashCode()\n    }\n\n    override fun toString(): String {\n        return \"[$start -> $end]\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.geometry\n\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\nimport kotlin.math.sqrt\n\nclass Vector(val x: Int, val y: Int) {\n\n    companion object {\n        val ZERO = Vector(0, 0)\n    }\n\n    fun add(v: Vector): Vector {\n        return Vector(x + v.x, y + v.y)\n    }\n\n    fun sub(v: Vector): Vector {\n        return add(v.negate())\n    }\n\n    fun negate(): Vector {\n        return Vector(-x, -y)\n    }\n\n    fun max(v: Vector): Vector {\n        return Vector(max(x, v.x), max(y, v.y))\n    }\n\n    fun min(v: Vector): Vector {\n        return Vector(min(x, v.x), min(y, v.y))\n    }\n\n    fun mul(i: Int): Vector {\n        return Vector(x * i, y * i)\n    }\n\n    operator fun div(i: Int): Vector {\n        return Vector(x / i, y / i)\n    }\n\n    fun dotProduct(v: Vector): Int {\n        return x * v.x + y * v.y\n    }\n\n    fun length(): Double {\n        return sqrt((x * x + y * y).toDouble())\n    }\n\n    fun toDoubleVector(): DoubleVector {\n        return DoubleVector(x.toDouble(), y.toDouble())\n    }\n\n    fun abs(): Vector {\n        return Vector(abs(x), abs(y))\n    }\n\n    fun isParallel(to: Vector): Boolean {\n        return x * to.y - to.x * y == 0\n    }\n\n    fun orthogonal(): Vector {\n        return Vector(-y, x)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (other !is Vector) return false\n\n        val otherVector = other as Vector?\n        return x == otherVector!!.x && y == otherVector.y\n    }\n\n    override fun hashCode(): Int {\n        return x * 31 + y\n    }\n\n    override fun toString(): String {\n        return \"($x, $y)\"\n    }\n\n//    operator fun get(axis: Axis): Int {\n//        val value: Int\n//        when (axis) {\n//            X -> value = x\n//            Y -> value = y\n//            else -> throw UnsupportedOperationException(\"unknown axis: $axis\")\n//        }\n//        return value\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.jsObject\n\nimport jetbrains.datalore.base.json.escape\n\nobject JsObjectSupport {\n    fun mapToJsObjectInitializer(map: Map<String, *>): String {\n        val buffer = StringBuilder()\n\n        var handleValue: (v: Any?) -> Unit = {}\n        val handleList = { list: List<*> ->\n            buffer.append('[')\n            var first = true\n            for (v in list) {\n                if (!first) buffer.append(',') else first = false\n                handleValue(v)\n            }\n            buffer.append(']')\n        }\n        @Suppress(\"NAME_SHADOWING\")\n        val handleMap = { map: Map<*, *> ->\n            buffer.append('{')\n            var first = true\n            for ((k, v) in map) {\n                k as? String ?: throw IllegalArgumentException(\n                    \"Only `string` keys are supported, was: ${k!!::class.simpleName ?: \"no class name\"}\"\n                )\n                if (!first) buffer.append(',') else first = false\n                buffer.append('\\n')\n                buffer.append('\"').append(k.escape()).append('\"').append(':')\n                handleValue(v)\n            }\n\n            buffer.append(\"\\n}\")\n        }\n        handleValue = { v: Any? ->\n            when (v) {\n                is String -> buffer.append('\"').append(v.escape()).append('\"')\n                is Boolean,\n                is Number -> buffer.append(v)\n                null -> buffer.append(\"null\")\n                is Array<*> -> handleList(v.asList())\n                is List<*> -> handleList(v)\n                is Map<*, *> -> handleMap(v)\n                else -> throw IllegalArgumentException(\"Can't serialize object $v\")\n            }\n        }\n\n        handleMap(map)\n        return buffer.toString()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\n\nclass FluentArray: FluentValue {\n    private val myArray: ArrayList<Any?>\n\n    constructor() {\n        myArray = ArrayList<Any?>()\n    }\n\n    constructor(array: List<Any?>) {\n        myArray = ArrayList<Any?>(array)\n    }\n\n    fun getDouble(index: Int) = myArray[index] as Double\n\n    fun add(v: String?) = apply { myArray.add(v) }\n    fun add(v: Double?) = apply { myArray.add(v) }\n    fun addStrings(values: List<String?>) = apply { myArray.addAll(values) }\n    fun addAll(values: List<FluentValue>) = apply { values.forEach { v -> myArray.add(v.get()) } }\n    fun addAll(vararg values: FluentValue) = apply { addAll(listOf(*values)) }\n\n    fun stream() = streamOf(myArray)\n    fun objectStream() = objectsStreamOf(myArray)\n    fun fluentObjectStream() = objectsStreamOf(myArray).map(::FluentObject)\n\n    override fun get() = myArray\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nimport jetbrains.datalore.base.function.Consumer\n\n\nclass FluentObject : FluentValue {\n    private val myObj: MutableMap<String, Any?>\n\n    constructor(obj: Map<*, *>) {\n        @Suppress(\"UNCHECKED_CAST\")\n        myObj = (obj as Map<String, Any?>).toMutableMap()\n    }\n\n    constructor() {\n        myObj = HashMap()\n\n   }\n    private fun getArr(key: String) = myObj[key] as Arr\n    private fun getObj(key: String) = myObj[key] as Obj\n\n    override fun get(): Obj = myObj\n    operator fun contains(key: String) = myObj.containsKey(key)\n    private fun containsNotNull(key: String) = contains(key) && myObj[key] != null\n\n    fun put(key: String, v: FluentValue?) = apply { myObj[key] = v?.get() }\n    fun put(key: String, v: String?) = apply { myObj[key] = v }\n    fun put(key: String, v: Number?) = apply { myObj[key] = v }\n    fun put(key: String, v: Boolean?) = apply { myObj[key] = v }\n    fun <T : Enum<T>> put(key: String, v: T?) = apply { myObj[key] = v?.let { formatEnum(it) } }\n\n    fun getInt(key: String) = myObj.getNumber(key).toInt()\n    fun getDouble(key: String) = myObj.getDouble(key)\n    fun getBoolean(key: String) = myObj[key] as Boolean\n    fun getString(key: String) = myObj[key] as String\n    fun getStrings(key: String) = getArr(key).map { getAsString(it) }\n    fun <T : Enum<T>> getEnum(key: String, enumValues: Array<T>) =\n        parseEnum<T>(myObj[key] as String, enumValues)\n    inline fun <reified T : Enum<T>> getEnum(key: String) = getEnum<T>(key, enumValues<T>())\n    fun getArray(key: String) = FluentArray(getArr(key))\n    fun getObject(key: String) = FluentObject(getObj(key))\n\n    fun getInt(key: String, processor: (Int) -> Unit) = apply { processor(getInt(key)) }\n    fun getDouble(key: String, processor: (Double) -> Unit) = apply { processor(getDouble(key)) }\n    fun getBoolean(key: String, processor: (Boolean) -> Unit) = apply { processor(getBoolean(key)) }\n    fun getString(key: String, processor: (String) -> Unit) = apply { processor(getString(key)) }\n    fun getStrings(key: String, processor: (List<String?>) -> Unit) = apply { processor(getStrings(key)) }\n    fun <T : Enum<T>> getEnum(key: String, processor: (T) -> Unit, enumValues: Array<T>) = apply { processor(getEnum(key, enumValues)) }\n    fun getArray(key: String, processor: (FluentArray) -> Unit) = apply { processor(getArray(key)) }\n    fun getObject(key: String, processor: (FluentObject) -> Unit) = apply { processor(getObject(key)) }\n\n    fun putRemovable(key: String, v: FluentValue?) = apply { v?.let { put(key, it) } }\n    fun <T : Enum<T>> putRemovable(key: String, v: T?) = apply { v?.let { put(key, it) } }\n\n    fun forEntries(consumer: (String, Any?) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it]) } }\n    fun forObjEntries(consumer: (String, Obj) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it] as Obj) } }\n    fun forArrEntries(consumer: (String, Arr) -> Unit) = apply { myObj.keys.forEach { consumer(it, myObj[it] as Arr) } }\n    fun accept(consumer: (FluentObject) -> Unit) = apply { consumer(this) }\n    fun forStrings(key: String, processor: (String?) -> Unit) = apply { myObj.getArr(key).map(::getAsString).forEach(processor) }\n\n\n    fun getExistingDouble(key: String, processor: Consumer<Double>) = apply {\n        if (containsNotNull(key)) {\n            getDouble(key, processor)\n        }\n    }\n\n    fun getOptionalStrings(key: String, processor: (List<String?>?) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getStrings(key))\n        } else {\n            processor(null)\n        }\n    }\n\n    fun getExistingString(key: String, processor: (String) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            getString(key, processor)\n        }\n    }\n\n    fun forExistingStrings(key: String, processor: (String) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            forStrings(key) { processor(it!!) }\n        }\n    }\n\n    fun getExistingObject(key: String, processor: (FluentObject) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            val obj = getObject(key)\n            if (obj.myObj.keys.isNotEmpty()) {\n                processor(obj)\n            }\n        }\n    }\n\n    fun getExistingArray(key: String, processor: (FluentArray) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getArray(key))\n        }\n    }\n\n    fun forObjects(key: String, processor: (FluentObject) -> Unit) = apply {\n        getArray(key).fluentObjectStream().forEach(processor)\n    }\n\n\n    fun getOptionalInt(key: String, processor: (Int?) -> Unit) = apply {\n        if (containsNotNull(key)) {\n            processor(getInt(key))\n        } else {\n            processor(null)\n        }\n    }\n\n    fun getIntOrDefault(key: String, processor: (Int) -> Unit, defaultValue: Int) = apply {\n        if (containsNotNull(key)) {\n            processor(getInt(key))\n        } else {\n            processor(defaultValue)\n        }\n    }\n\n    fun <T : Enum<T>> forEnums(key: String, processor: (T) -> Unit, enumValues: Array<T>) = apply {\n        getArr(key).forEach { processor(parseEnum(it as String, enumValues)) }\n    }\n\n    fun <T : Enum<T>> getOptionalEnum(key: String, processor: (T?) -> Unit, enumValues: Array<T>) = apply {\n        when {\n            containsNotNull(key) -> processor(getEnum(key, enumValues))\n            else -> processor(null)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass FluentPrimitive : FluentValue {\n    private val value: Any?\n\n    constructor(v: Int?) {\n        value = v\n    }\n\n    constructor(v: String?) {\n        value = v\n    }\n\n    constructor(v: Boolean?) {\n        value = v\n    }\n\n    constructor(v: Number?) {\n        value = v\n    }\n\n    override fun get(): Any? {\n        return value\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\n\nabstract class FluentValue {\n    abstract fun get(): Any?\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass JsonFormatter {\n    private lateinit var buffer: StringBuilder\n\n    fun formatJson(o: Any): String {\n        buffer = StringBuilder()\n        handleValue(o)\n        return buffer.toString()\n    }\n\n    private fun handleList(list: List<*>) {\n        append(\"[\")\n        list.headTail(::handleValue) { tail -> tail.forEach { append(\",\"); handleValue(it) } }\n        append(\"]\")\n    }\n\n    private fun handleMap(map: Map<*, *>) {\n        append(\"{\")\n        map.entries.headTail(::handlePair) { tail -> tail.forEach { append(\",\\n\"); handlePair(it) } }\n        append(\"}\")\n    }\n\n    private fun handleValue(v: Any?) {\n        when (v) {\n            null -> append(\"null\")\n            is String -> handleString(v)\n            is Number, Boolean -> append(v.toString())\n            is Array<*> -> handleList(v.asList())\n            is List<*> -> handleList(v)\n            is Map<*, *> -> handleMap(v)\n            else -> throw IllegalArgumentException(\"Can't serialize object $v\")\n        }\n    }\n\n    private fun handlePair(pair: Map.Entry<Any?, Any?>) {\n        handleString(pair.key); append(\":\"); handleValue(pair.value)\n    }\n\n    private fun handleString(v: Any?) {\n        when (v) {\n            null -> {}\n            is String -> append(\"\\\"${v.escape()}\\\"\")\n            else -> throw IllegalArgumentException(\"Expected a string, but got '${v::class.simpleName}'\")\n        }\n    }\n\n    private fun append(s: String) = buffer.append(s)\n\n    private fun <E> Collection<E>.headTail(head: (E) -> Unit, tail: (Sequence<E>) -> Unit) {\n        if (!isEmpty()) {\n            head(first())\n            tail(asSequence().drop(1))\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\ninternal class JsonLexer(\n    private val input: String\n) {\n    private var i = 0\n    private var tokenStart = 0\n    var currentToken: Token? = null\n        private set\n\n    private val currentChar: Char\n        get() = input[i]\n\n    init {\n        nextToken() // read first token\n    }\n\n    fun nextToken() {\n        advanceWhile { it.isWhitespace() }\n\n        if (isFinished()) {\n            return\n        }\n\n        when {\n            currentChar == '{' -> Token.LEFT_BRACE.also { advance() }\n            currentChar == '}' -> Token.RIGHT_BRACE.also { advance() }\n            currentChar == '[' -> Token.LEFT_BRACKET.also { advance() }\n            currentChar == ']' -> Token.RIGHT_BRACKET.also { advance() }\n            currentChar == ',' -> Token.COMMA.also { advance() }\n            currentChar == ':' -> Token.COLON.also { advance() }\n            currentChar == 't' -> Token.TRUE.also { read(\"true\") }\n            currentChar == 'f' -> Token.FALSE.also { read(\"false\") }\n            currentChar == 'n' -> Token.NULL.also { read(\"null\") }\n            currentChar == '\"' -> Token.STRING.also { readString() }\n            readNumber() -> Token.NUMBER\n            else -> error(\"$i:${currentChar} - unkown token\")\n        }.also { currentToken = it }\n    }\n\n    fun tokenValue() = input.substring(tokenStart, i)\n\n    private fun readString() {\n        startToken()\n        advance() // opening quote\n        while(!(currentChar == '\"')) {\n            if(currentChar == '\\\\') {\n                advance()\n                when {\n                    currentChar == 'u' -> {\n                        advance()\n                        repeat(4) {\n                            require(currentChar.isHex());\n                            advance()\n                        }\n                    }\n                    currentChar in SPECIAL_CHARS -> advance()\n                    else -> error(\"Invalid escape sequence\")\n                }\n            } else {\n                advance()\n            }\n        }\n        advance() // closing quote\n    }\n\n    private fun readNumber(): Boolean {\n        if (!(currentChar.isDigit() || currentChar == '-')) {\n            return false\n        }\n\n        startToken()\n        advanceIfCurrent('-')\n        advanceWhile { it.isDigit() }\n\n        advanceIfCurrent('.') {\n            require(currentChar.isDigit()) { \"Number should have decimal part\" }\n            advanceWhile { it.isDigit() }\n        }\n\n        advanceIfCurrent('e', 'E') {\n            advanceIfCurrent('+', '-')\n            advanceWhile { it.isDigit() }\n        }\n\n        return true\n    }\n\n    fun isFinished(): Boolean = i == input.length\n    private fun startToken() { tokenStart = i }\n    private fun advance() { ++i }\n\n    private fun read(str: String) {\n        return str.forEach {\n            require(currentChar == it) { \"Wrong data: $str\" }\n            require(!isFinished()) { \"Unexpected end of string\" }\n            advance()\n        }\n    }\n\n    private fun advanceWhile(pred: (Char) -> Boolean) {\n        while (!isFinished() && pred(currentChar)) advance()\n    }\n\n    private fun advanceIfCurrent(vararg expected: Char, then: () -> Unit = {}) {\n        if (!isFinished() && currentChar in expected) {\n            advance()\n            then()\n        }\n    }\n\n    companion object {\n        private val digits: CharRange = '0'..'9'\n        private fun Char?.isDigit() = this in digits\n        private fun Char.isHex(): Boolean { return isDigit() || this in 'a'..'f' || this in 'A'..'F' }\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"RangesKt\")\n\npackage kotlin.ranges\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntRange.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongRange.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharRange.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntRange.random(random: Random): Int {\n    try {\n        return random.nextInt(this)\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongRange.random(random: Random): Long {\n    try {\n        return random.nextLong(this)\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness.\n * \n * @throws IllegalArgumentException if this range is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharRange.random(random: Random): Char {\n    try {\n        return random.nextInt(first.code, last.code + 1).toChar()\n    } catch(e: IllegalArgumentException) {\n        throw NoSuchElementException(e.message)\n    }\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntRange.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongRange.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharRange.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntRange.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return random.nextInt(this)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongRange.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return random.nextLong(this)\n}\n\n/**\n * Returns a random element from this range using the specified source of randomness, or `null` if this range is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharRange.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return random.nextInt(first.code, last.code + 1).toChar()\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun IntRange.contains(element: Int?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun LongRange.contains(element: Long?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Returns `true` if this range contains the specified [element].\n * \n * Always returns `false` if the [element] is `null`.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline operator fun CharRange.contains(element: Char?): Boolean {\n    return element != null && contains(element)\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Byte): Boolean {\n    return contains(value.toInt())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Byte): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Byte): Boolean {\n    return contains(value.toShort())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Byte): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Byte): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Double): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Double): Boolean {\n    return value.toLongExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Double): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Double): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Double): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Float): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Float): Boolean {\n    return value.toLongExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Float): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Float): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Float): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Int): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Int): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Int): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Int): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Int): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Long): Boolean {\n    return value.toIntExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Long): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"shortRangeContains\")\npublic operator fun ClosedRange<Short>.contains(value: Long): Boolean {\n    return value.toShortExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Long): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Long): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"intRangeContains\")\npublic operator fun ClosedRange<Int>.contains(value: Short): Boolean {\n    return contains(value.toInt())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"longRangeContains\")\npublic operator fun ClosedRange<Long>.contains(value: Short): Boolean {\n    return contains(value.toLong())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@kotlin.jvm.JvmName(\"byteRangeContains\")\npublic operator fun ClosedRange<Byte>.contains(value: Short): Boolean {\n    return value.toByteExactOrNull().let { if (it != null) contains(it) else false }\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"doubleRangeContains\")\npublic operator fun ClosedRange<Double>.contains(value: Short): Boolean {\n    return contains(value.toDouble())\n}\n\n/**\n * Checks if the specified [value] belongs to this range.\n */\n@Deprecated(\"This `contains` operation mixing integer and floating point arguments has ambiguous semantics and is going to be removed.\")\n@DeprecatedSinceKotlin(warningSince = \"1.3\", errorSince = \"1.4\", hiddenSince = \"1.5\")\n@kotlin.jvm.JvmName(\"floatRangeContains\")\npublic operator fun ClosedRange<Float>.contains(value: Short): Boolean {\n    return contains(value.toFloat())\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this, to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Byte): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Byte): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Char.downTo(to: Char): CharProgression {\n    return CharProgression.fromClosedRange(this, to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this, to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Int): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Int): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to, -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this, to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Long): LongProgression {\n    return LongProgression.fromClosedRange(this.toLong(), to, -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Int.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this, to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Long.downTo(to: Short): LongProgression {\n    return LongProgression.fromClosedRange(this, to.toLong(), -1L)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Byte.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression from this value down to the specified [to] value with the step -1.\n * \n * The [to] value should be less than or equal to `this` value.\n * If the [to] value is greater than `this` value the returned progression is empty.\n */\npublic infix fun Short.downTo(to: Short): IntProgression {\n    return IntProgression.fromClosedRange(this.toInt(), to.toInt(), -1)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun IntProgression.reversed(): IntProgression {\n    return IntProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun LongProgression.reversed(): LongProgression {\n    return LongProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range in the opposite direction with the same step.\n */\npublic fun CharProgression.reversed(): CharProgression {\n    return CharProgression.fromClosedRange(last, first, -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun IntProgression.step(step: Int): IntProgression {\n    checkStepIsPositive(step > 0, step)\n    return IntProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun LongProgression.step(step: Long): LongProgression {\n    checkStepIsPositive(step > 0, step)\n    return LongProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\n/**\n * Returns a progression that goes over the same range with the given step.\n */\npublic infix fun CharProgression.step(step: Int): CharProgression {\n    checkStepIsPositive(step > 0, step)\n    return CharProgression.fromClosedRange(first, last, if (this.step > 0) step else -step)\n}\n\ninternal fun Int.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toInt()..Byte.MAX_VALUE.toInt()) this.toByte() else null\n}\n\ninternal fun Long.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toLong()..Byte.MAX_VALUE.toLong()) this.toByte() else null\n}\n\ninternal fun Short.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toShort()..Byte.MAX_VALUE.toShort()) this.toByte() else null\n}\n\ninternal fun Double.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toDouble()..Byte.MAX_VALUE.toDouble()) this.toInt().toByte() else null\n}\n\ninternal fun Float.toByteExactOrNull(): Byte? {\n    return if (this in Byte.MIN_VALUE.toFloat()..Byte.MAX_VALUE.toFloat()) this.toInt().toByte() else null\n}\n\ninternal fun Long.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toLong()..Int.MAX_VALUE.toLong()) this.toInt() else null\n}\n\ninternal fun Double.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toDouble()..Int.MAX_VALUE.toDouble()) this.toInt() else null\n}\n\ninternal fun Float.toIntExactOrNull(): Int? {\n    return if (this in Int.MIN_VALUE.toFloat()..Int.MAX_VALUE.toFloat()) this.toInt() else null\n}\n\ninternal fun Double.toLongExactOrNull(): Long? {\n    return if (this in Long.MIN_VALUE.toDouble()..Long.MAX_VALUE.toDouble()) this.toLong() else null\n}\n\ninternal fun Float.toLongExactOrNull(): Long? {\n    return if (this in Long.MIN_VALUE.toFloat()..Long.MAX_VALUE.toFloat()) this.toLong() else null\n}\n\ninternal fun Int.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toInt()..Short.MAX_VALUE.toInt()) this.toShort() else null\n}\n\ninternal fun Long.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toLong()..Short.MAX_VALUE.toLong()) this.toShort() else null\n}\n\ninternal fun Double.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toDouble()..Short.MAX_VALUE.toDouble()) this.toInt().toShort() else null\n}\n\ninternal fun Float.toShortExactOrNull(): Short? {\n    return if (this in Short.MIN_VALUE.toFloat()..Short.MAX_VALUE.toFloat()) this.toInt().toShort() else null\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Byte): IntRange {\n    return this .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Byte): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Byte): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Byte): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Char.until(to: Char): CharRange {\n    if (to <= '\\u0000') return CharRange.EMPTY\n    return this .. (to - 1).toChar()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Int): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this.toInt() .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Int): IntRange {\n    if (to <= Int.MIN_VALUE) return IntRange.EMPTY\n    return this.toInt() .. (to - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Long): LongRange {\n    if (to <= Long.MIN_VALUE) return LongRange.EMPTY\n    return this.toLong() .. (to - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Int.until(to: Short): IntRange {\n    return this .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Long.until(to: Short): LongRange {\n    return this .. (to.toLong() - 1).toLong()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Byte.until(to: Short): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Returns a range from this value up to but excluding the specified [to] value.\n * \n * If the [to] value is less than or equal to `this` value, then the returned range is empty.\n */\npublic infix fun Short.until(to: Short): IntRange {\n    return this.toInt() .. (to.toInt() - 1).toInt()\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeastComparable\n */\npublic fun <T : Comparable<T>> T.coerceAtLeast(minimumValue: T): T {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Byte.coerceAtLeast(minimumValue: Byte): Byte {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Short.coerceAtLeast(minimumValue: Short): Short {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Int.coerceAtLeast(minimumValue: Int): Int {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Long.coerceAtLeast(minimumValue: Long): Long {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Float.coerceAtLeast(minimumValue: Float): Float {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not less than the specified [minimumValue].\n * \n * @return this value if it's greater than or equal to the [minimumValue] or the [minimumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtLeast\n */\npublic fun Double.coerceAtLeast(minimumValue: Double): Double {\n    return if (this < minimumValue) minimumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMostComparable\n */\npublic fun <T : Comparable<T>> T.coerceAtMost(maximumValue: T): T {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Byte.coerceAtMost(maximumValue: Byte): Byte {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Short.coerceAtMost(maximumValue: Short): Short {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Int.coerceAtMost(maximumValue: Int): Int {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Long.coerceAtMost(maximumValue: Long): Long {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Float.coerceAtMost(maximumValue: Float): Float {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value is not greater than the specified [maximumValue].\n * \n * @return this value if it's less than or equal to the [maximumValue] or the [maximumValue] otherwise.\n * \n * @sample samples.comparisons.ComparableOps.coerceAtMost\n */\npublic fun Double.coerceAtMost(maximumValue: Double): Double {\n    return if (this > maximumValue) maximumValue else this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceInComparable\n */\npublic fun <T : Comparable<T>> T.coerceIn(minimumValue: T?, maximumValue: T?): T {\n    if (minimumValue !== null && maximumValue !== null) {\n        if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n        if (this < minimumValue) return minimumValue\n        if (this > maximumValue) return maximumValue\n    }\n    else {\n        if (minimumValue !== null && this < minimumValue) return minimumValue\n        if (maximumValue !== null && this > maximumValue) return maximumValue\n    }\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Byte.coerceIn(minimumValue: Byte, maximumValue: Byte): Byte {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Short.coerceIn(minimumValue: Short, maximumValue: Short): Short {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Int.coerceIn(minimumValue: Int, maximumValue: Int): Int {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Long.coerceIn(minimumValue: Long, maximumValue: Long): Long {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Float.coerceIn(minimumValue: Float, maximumValue: Float): Float {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified range [minimumValue]..[maximumValue].\n * \n * @return this value if it's in the range, or [minimumValue] if this value is less than [minimumValue], or [maximumValue] if this value is greater than [maximumValue].\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Double.coerceIn(minimumValue: Double, maximumValue: Double): Double {\n    if (minimumValue > maximumValue) throw IllegalArgumentException(\"Cannot coerce value to an empty range: maximum $maximumValue is less than minimum $minimumValue.\")\n    if (this < minimumValue) return minimumValue\n    if (this > maximumValue) return maximumValue\n    return this\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceInFloatingPointRange\n */\n@SinceKotlin(\"1.1\")\npublic fun <T : Comparable<T>> T.coerceIn(range: ClosedFloatingPointRange<T>): T {\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        // this < start equiv to this <= start && !(this >= start)\n        range.lessThanOrEquals(this, range.start) && !range.lessThanOrEquals(range.start, this) -> range.start\n        // this > end equiv to this >= end && !(this <= end)\n        range.lessThanOrEquals(range.endInclusive, this) && !range.lessThanOrEquals(this, range.endInclusive) -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceInComparable\n */\npublic fun <T : Comparable<T>> T.coerceIn(range: ClosedRange<T>): T {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<T>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Int.coerceIn(range: ClosedRange<Int>): Int {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<Int>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n/**\n * Ensures that this value lies in the specified [range].\n * \n * @return this value if it's in the [range], or `range.start` if this value is less than `range.start`, or `range.endInclusive` if this value is greater than `range.endInclusive`.\n * \n * @sample samples.comparisons.ComparableOps.coerceIn\n */\npublic fun Long.coerceIn(range: ClosedRange<Long>): Long {\n    if (range is ClosedFloatingPointRange) {\n        return this.coerceIn<Long>(range)\n    }\n    if (range.isEmpty()) throw IllegalArgumentException(\"Cannot coerce value to an empty range: $range.\")\n    return when {\n        this < range.start -> range.start\n        this > range.endInclusive -> range.endInclusive\n        else -> this\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nclass JsonParser(\n    private val json: String\n) {\n    fun parseJson(): Any? {\n        val lexer = JsonLexer(json)\n        return parseValue(lexer)\n    }\n\n    private fun parseValue(lexer: JsonLexer): Any? {\n        return when(lexer.currentToken) {\n            Token.STRING -> lexer.tokenValue().unescape().also { lexer.nextToken() }\n            Token.NUMBER -> lexer.tokenValue().toDouble().also { lexer.nextToken() }\n            Token.FALSE -> false.also { lexer.nextToken() }\n            Token.TRUE -> true.also { lexer.nextToken() }\n            Token.NULL -> null.also { lexer.nextToken() }\n            Token.LEFT_BRACE -> parseObject(lexer)\n            Token.LEFT_BRACKET -> parseArray(lexer)\n            else -> error(\"Invalid token: ${lexer.currentToken}\")\n        }\n    }\n\n    private fun parseArray(lexer: JsonLexer): MutableList<Any?> {\n        fun checkCurrentToken(token: Token) { require(lexer.currentToken, token, \"[Arr] \") }\n\n        val list = mutableListOf<Any?>()\n\n        checkCurrentToken(Token.LEFT_BRACKET)\n        lexer.nextToken()\n\n        while (lexer.currentToken != Token.RIGHT_BRACKET) {\n            if (list.isNotEmpty()) {\n                checkCurrentToken(Token.COMMA)\n                lexer.nextToken()\n            }\n            list.add(parseValue(lexer))\n        }\n\n        checkCurrentToken(Token.RIGHT_BRACKET)\n        lexer.nextToken()\n\n        return list\n    }\n\n    private fun parseObject(lexer: JsonLexer): Map<String, Any?> {\n        fun checkCurrentToken(token: Token) { require(lexer.currentToken, token, \"[Obj] \") }\n\n        val map = mutableMapOf<String, Any?>()\n\n        checkCurrentToken(Token.LEFT_BRACE)\n        lexer.nextToken()\n\n        while (lexer.currentToken != Token.RIGHT_BRACE) {\n            if (map.isNotEmpty()) {\n                checkCurrentToken(Token.COMMA)\n                lexer.nextToken()\n            }\n\n            checkCurrentToken(Token.STRING)\n            val key = lexer.tokenValue().unescape()\n            lexer.nextToken()\n\n            checkCurrentToken(Token.COLON)\n            lexer.nextToken()\n\n            val value = parseValue(lexer)\n            map[key] = value\n        }\n\n        checkCurrentToken(Token.RIGHT_BRACE)\n        lexer.nextToken()\n\n        return map\n    }\n\n    private fun require(current: Token?, expected: Token?, messagePrefix: String? = null) {\n        if (current != expected) {\n            throw JsonException(messagePrefix + \"Expected token: $expected, actual: $current\")\n        }\n    }\n\n    class JsonException(message: String) : Exception(message)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\nobject JsonSupport {\n    fun parseJson(jsonString: String): MutableMap<String, Any?> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return JsonParser(jsonString).parseJson() as MutableMap<String, Any?>\n    }\n    fun formatJson(o: Any): String {\n        return JsonFormatter().formatJson(o)\n    }\n}\n\n\n// Usefull resources:\n// https://www.ietf.org/rfc/rfc4627.txt\n// https://github.com/nst/JSONTestSuite\n\ninternal enum class Token {\n    LEFT_BRACE,\n    RIGHT_BRACE,\n    LEFT_BRACKET,\n    RIGHT_BRACKET,\n    COMMA,\n    COLON,\n    STRING,\n    NUMBER,\n    TRUE,\n    FALSE,\n    NULL,\n}\n\ninternal val SPECIAL_CHARS = mapOf(\n    '\"' to '\"',\n    '\\\\' to '\\\\',\n    '/' to '/',\n    'b' to '\\b',\n    'f' to '\\u000C',\n    'n' to '\\n',\n    'r' to '\\r',\n    't' to '\\t'\n)\n\nprivate val CONTROL_CHARS = (0 until 0x20).map(Int::toChar).toSet()\n\nfun String.escape(): String {\n    var output: StringBuilder? = null\n    var i = 0\n\n    fun appendOutput(str: String) {\n        output = (output ?: StringBuilder(substring(0, i))).append(str)\n    }\n\n    while(i < length) {\n        when(val ch = get(i)) {\n            '\\\\' -> appendOutput(\"\"\"\\\\\"\"\")\n            '\"' -> appendOutput(\"\"\"\\\"\"\"\")\n            '\\n' -> appendOutput(\"\"\"\\n\"\"\")\n            '\\r' -> appendOutput(\"\"\"\\r\"\"\")\n            '\\t' -> appendOutput(\"\"\"\\t\"\"\")\n            in CONTROL_CHARS -> appendOutput(\"\"\"\\u${ch.code.toString(16).padStart(4, '0')}\"\"\")\n            else -> output?.append(ch)\n        }\n        i++\n    }\n    return output?.toString() ?: this\n}\n\nfun String.unescape(): String {\n    var output: StringBuilder? = null\n    val start = 1\n    val end = length - 1\n\n    var i = start\n    while(i < end) {\n        val ch = get(i)\n        if (ch == '\\\\') {\n            output = output ?: StringBuilder(substring(start, i))\n            when(val escapedChar = get(++i)) {\n                in SPECIAL_CHARS -> SPECIAL_CHARS[escapedChar].also { i++ }\n                'u' -> substring(i + 1, i + 5).toInt(16).toChar().also { i += 5 }\n                else -> throw JsonParser.JsonException(\"Invalid escape character: ${escapedChar}\")\n            }.let { output.append(it) }\n        } else {\n            output?.append(ch); i++\n        }\n    }\n    return output?.toString() ?: substring(start, end)\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin\n\n\n/**\n * Creates a Char with the specified [code], or throws an exception if the [code] is out of `Char.MIN_VALUE.code..Char.MAX_VALUE.code`.\n *\n * If the program that calls this function is written in a way that only valid [code] is passed as the argument,\n * using the overload that takes a [UShort] argument is preferable (`Char(intValue.toUShort())`).\n * That overload doesn't check validity of the argument, and may improve program performance when the function is called routinely inside a loop.\n *\n * @sample samples.text.Chars.charFromCode\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun Char(code: Int): Char {\n    if (code < Char.MIN_VALUE.code || code > Char.MAX_VALUE.code) {\n        throw IllegalArgumentException(\"Invalid Char code: $code\")\n    }\n    return code.toChar()\n}\n\n/**\n * Creates a Char with the specified [code].\n *\n * @sample samples.text.Chars.charFromCode\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun Char(code: UShort): Char\n\n/**\n * Returns the code of this Char.\n *\n * Code of a Char is the value it was constructed with, and the UTF-16 code unit corresponding to this Char.\n *\n * @sample samples.text.Chars.code\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\n@Suppress(\"DEPRECATION\")\npublic inline val Char.code: Int get() = this.toInt()\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.json\n\ntypealias Arr = List<*>\ntypealias Obj = Map<*, *>\n\nfun streamOf(arr: Arr): Sequence<*> = arr.asSequence()\nfun objectsStreamOf(arr: Arr): Sequence<Obj> = streamOf(arr).map { it as Obj }\nfun stringStreamOf(arr: Arr): Sequence<String?> = streamOf(arr).map { it as String? }\n\nfun isBoolean(e: Any) = e is Boolean\nfun isNumber(e: Any) = e is Number\nfun isString(e: Any) = e is String\n\nfun getAsDouble(v: Any) = (v as Number).toDouble()\nfun getAsInt(v: Any?) = (v as Number).toInt()\nfun getAsBoolean(v: Any) = v as Boolean\n\nfun containsString(obj: MutableMap<String, Any?>, key: String): Boolean =\n    when (val v = obj[key]) {\n        null, isString(v) -> true\n        else -> false\n    }\n\nfun getAsString(e: Any?): String? =\n    when (e) {\n        null -> null\n        else -> e as String\n    }\n\nfun <T : Enum<T>> parseEnum(enumStringValue: String, values: Array<T>): T =\n    values.first { mode -> mode.toString().equals(enumStringValue, ignoreCase = true) }\n\ninline fun <reified T : Enum<T>> parseEnum(enumStringValue: String): T = parseEnum(enumStringValue, enumValues<T>())\nfun <T : Enum<T>> formatEnum(enumValue: T): String = enumValue.toString().lowercase()\n\nfun <T : Enum<T>> FluentObject.put(key: String, v: Collection<T>) = this.put(key, v.map { formatEnum(it) })\nfun FluentObject.put(key: String, v: List<String>) = put(key, FluentArray().addStrings(v.map { it }))\n\nfun Map<*, *>.getNumber(key: String) = if (this[key] == null) 0.0 else this[key] as Number\nfun Map<*, *>.getDouble(key: String) = this.getNumber(key).toDouble()\nfun Map<*, *>.getString(key: String) = this[key] as String\nfun Map<*, *>.getObj(key: String) = this[key] as Obj\nfun Map<*, *>.getArr(key: String) = this[key] as Arr\n\n\n//    private fun toObject(v: Any?): Any? {\n//        return when (v) {\n//            null -> null\n//            is String -> v\n//            is Number -> v\n//            is Boolean -> v\n//            is Map<*, *> -> toMap(v)\n//            is List<*> -> toArray(v)\n//            else -> throw IllegalArgumentException(\"Unknown type: ${v.toString()}\")\n//        }\n//    }\n\n\n//    fun toMap(obj: JsonObject): Map<String, Any> {\n//        val res = HashMap<String, Any>()\n//\n//        for (key in obj.getKeys()) {\n//            toObject(obj[key]).ifPresent({ q -> res[key] = q })\n//        }\n//\n//        return res\n//    }\n//\n//    private fun toArray(arr: JsonArray): List<Any> {\n//        val res = ArrayList<Any>()\n//\n//        var i = 0\n//        val n = arr.size()\n//        while (i < n) {\n//            toObject(arr.get(i)).ifPresent(Consumer<Any> { res.add(it) })\n//            i++\n//        }\n//\n//        return res\n//    }\n//\n//\n//    fun readString(obj: JsonObject, key: String): String {\n//        if (!containsString(obj, key)) {\n//            throw IllegalStateException(\"JsonObject does not contain string: $key\")\n//        }\n//\n//        return obj.getString(key)\n//    }\n//\n//    fun containsBoolean(obj: JsonObject, key: String): Boolean {\n//        val v = obj[key]\n//        return isBoolean(v)\n//    }\n//\n//    fun readBoolean(obj: JsonObject, key: String): Boolean {\n//        return obj.getBoolean(key)\n//    }\n//\n//    // JsonNull counts as empty array\n//    fun containsArray(obj: JsonObject, key: String): Boolean {\n//        val arr = obj[key]\n//        return arr is JsonNull || arr is JsonArray\n//    }\n//\n//    // JsonNull -> empty array\n//    fun getArr(obj: JsonObject, key: String): JsonArray {\n//        val arr = obj[key]\n//        if (arr is JsonNull) {\n//            return JsonArray()\n//        } else if (arr is JsonArray) {\n//            return arr as JsonArray\n//        }\n//\n//        throw IllegalStateException(\"JsonObject does not contain array: $key\")\n//    }\n//\n//    fun readDouble(array: JsonArray, index: Int): Double {\n//        return array.getDouble(index)\n//    }\n//\n//    fun getOptional(obj: JsonObject, key: String): Optional<Any> {\n//        return if (!obj.getKeys().contains(key)) {\n//            Optional.empty()\n//        } else Optional.ofNullable(obj[key])\n//    }\n//\n//    fun getOptionalInt(v: Any): Optional<Int> {\n//        if (v is JsonNull) {\n//            return Optional.empty()\n//        } else if (isNumber(v)) {\n//            return Optional.of((v as JsonNumber).getIntValue())\n//        }\n//\n//        throw IllegalStateException(\"Object is not JsonNumber: \" + v.getClass().getName())\n//    }\n//\n//    fun readStringArray(obj: JsonObject, key: String): List<String> {\n//        return parseJsonArray(obj.getArr(key), { jsonValue -> (jsonValue as JsonString).getStringValue() })\n//    }\n//\n//    fun <T> parseJsonArray(jsonArray: JsonArray, converter: Function<Any, T>): List<T> {\n//        val resultArray = ArrayList<T>()\n//        jsonArray.forEach { jsonValue -> resultArray.add(converter.apply(jsonValue)) }\n//        return resultArray\n//    }\n//\n//\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.listMap\n\n/**\n * Memory efficient implementation of a map based on an array.\n *\n *\n * It works better than a HashMap and TreeMap on small sized collections.\n */\nclass ListMap<K, V> {\n\n    companion object {\n        private val EMPTY_ARRAY = arrayOfNulls<Any>(0)\n    }\n\n    private var myData = EMPTY_ARRAY\n\n    val isEmpty: Boolean\n        get() = size() == 0\n\n    fun containsKey(key: K): Boolean {\n        return findByKey(key) >= 0\n    }\n\n    fun remove(key: K): V? {\n        val index = findByKey(key)\n        if (index >= 0) {\n            val value = myData[index + 1]\n            removeAt(index)\n            @Suppress(\"UNCHECKED_CAST\")\n            return value as V?\n        } else {\n            return null\n        }\n    }\n\n    fun keySet(): MutableSet<K> {\n        return object : AbstractMutableSet<K>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun add(element: K): Boolean {\n                throw IllegalStateException(\"Not available in keySet\")\n            }\n\n            override fun iterator(): MutableIterator<K> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any? {\n                        return myData[index]\n                    }\n                })\n            }\n        }\n    }\n\n    fun values(): Collection<V?> {\n        return object : AbstractCollection<V?>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun iterator(): Iterator<V?> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any? {\n                        return myData[index + 1]\n                    }\n                })\n            }\n        }\n    }\n\n    fun entrySet(): Set<Entry> {\n        return object : AbstractSet<Entry>() {\n            override val size: Int\n                get() = this@ListMap.size()\n\n            override fun iterator(): Iterator<ListMap<K, V>.Entry> {\n                return mapIterator(object : IteratorSpec {\n                    override operator fun get(index: Int): Any {\n                        return Entry(index)\n                    }\n                })\n            }\n        }\n    }\n\n    fun size(): Int {\n        return myData.size / 2\n    }\n\n    fun put(key: K, value: V?): V? {\n        val index = findByKey(key)\n        if (index >= 0) {\n            val oldValue = myData[index + 1]\n            myData[index + 1] = value\n            @Suppress(\"UNCHECKED_CAST\")\n            return oldValue as V?\n        }\n\n        val newArray = Array(myData.size + 2) { i ->\n            if (i < myData.size) myData[i] else null\n        }\n\n        newArray[myData.size] = key\n        newArray[myData.size + 1] = value\n        myData = newArray\n        return null\n    }\n\n    operator fun get(key: K): V? {\n        val index = findByKey(key)\n        return if (index == -1) {\n            null\n        } else {\n            @Suppress(\"UNCHECKED_CAST\")\n            myData[index + 1] as V?\n        }\n    }\n\n    override fun toString(): String {\n        val builder = StringBuilder()\n        builder.append(\"{\")\n        var i = 0\n        while (i < myData.size) {\n            val k = myData[i]\n            val v = myData[i + 1]\n            if (i != 0) {\n                builder.append(\",\")\n            }\n            builder.append(k).append(\"=\").append(v)\n            i += 2\n        }\n        builder.append(\"}\")\n\n        return builder.toString()\n    }\n\n    private fun <T> mapIterator(spec: IteratorSpec): MutableIterator<T> {\n        return object : MutableIterator<T> {\n            private var index = 0\n            private var nextCalled = false\n\n            override fun hasNext(): Boolean {\n                return index < myData.size\n            }\n\n            override fun next(): T {\n                if (!hasNext()) {\n                    throw NoSuchElementException()\n                }\n                nextCalled = true\n                @Suppress(\"UNCHECKED_CAST\")\n                val value = spec[index] as T\n                index += 2\n                return value\n            }\n\n            override fun remove() {\n                if (!nextCalled) {\n                    throw IllegalStateException()\n                }\n                index -= 2\n                removeAt(index)\n                nextCalled = false\n            }\n        }\n    }\n\n    private fun findByKey(key: K): Int {\n        var i = 0\n        while (i < myData.size) {\n            val k = myData[i]\n            if (key == k) {\n                return i\n            }\n            i += 2\n        }\n        return -1\n    }\n\n    private fun removeAt(index: Int) {\n        if (myData.size == 2) {\n            myData = EMPTY_ARRAY\n            return\n        }\n\n        val newArray = Array(myData.size - 2) { i ->\n            if (i < index) {\n                myData[i]\n            } else {\n                myData[i + 2]\n            }\n        }\n\n        myData = newArray\n    }\n\n    inner class Entry internal constructor(private val myIndex: Int) {\n        fun key(): K {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myData[myIndex] as K\n        }\n\n        fun value(): V? {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myData[myIndex + 1] as V?\n        }\n    }\n\n    private interface IteratorSpec {\n        operator fun get(index: Int): Any?\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.logging\n\nclass PrintlnLogger(val name: String) : Logger {\n    override fun error(e: Throwable, message: () -> String) {\n        println(\"ERR [$name] : ${message()}\")\n    }\n\n    override fun info(message: () -> String) {\n        println(\"INFO [$name] : ${message()}\")\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.math\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.geometry.Vector\nimport kotlin.math.*\n\nfun toRadians(degrees: Double): Double = degrees * PI / 180.0\nfun toDegrees(radians: Double): Double = radians * 180.0 / PI\n\nfun round(v: DoubleVector) = round(v.x, v.y)\nfun ceil(v: DoubleVector) = ceil(v.x, v.y)\n\nfun round(x: Double, y: Double): Vector {\n    return Vector(\n        round(x).toInt(),\n        round(y).toInt()\n    )\n}\n\n\nfun ceil(x: Double, y: Double): Vector {\n    return Vector(\n        ceil(x).toInt(),\n        ceil(y).toInt()\n    )\n}\n\n\nfun distance(vector: Vector, doubleVector: DoubleVector): Double {\n    val dx = doubleVector.x - vector.x\n    val dy = doubleVector.y - vector.y\n    return sqrt(dx * dx + dy * dy)\n}\n\n\nfun Int.ipow(e: Int): Double {\n    return this.toDouble().pow(e)\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.numberFormat\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat.NumberInfo.Companion.createNumberInfo\nimport kotlin.math.*\n\nfun length(v: Long): Int {\n    // log10 doesn't work for values 10^17 + 1, returning 17.0 instead of 17.00001\n\n    if (v == 0L) {\n        return 1\n    }\n\n    var len = 0\n    var rem = v\n    while (rem > 0) {\n        len++\n        rem /= 10\n    }\n\n    return len\n}\n\nclass NumberFormat(private val spec: Spec) {\n\n    constructor(spec: String) : this(create(spec))\n\n    data class Spec(\n        val fill: String = \" \",\n        val align: String = \">\",\n        val sign: String = \"-\",\n        val symbol: String,\n        val zero: Boolean,\n        val width: Int = -1,\n        val comma: Boolean,\n        val precision: Int = 6,\n        val type: String = \"\",\n        val trim: Boolean = false\n    )\n\n\n    data class NumberInfo(\n        val number: Double = 0.0,\n        val negative: Boolean = false,\n        val integerPart: Long = 0,\n        val fractionalPart: Long = 0,\n        val exponent: Int? = null\n    ) {\n        constructor(\n            number: Number,\n            integerPart: Long = 0,\n            fractionalPart: Long = 0,\n            exponent: Int? = null\n        ) : this(number.toDouble().absoluteValue, number.toDouble() < 0.0, integerPart, fractionalPart, exponent)\n\n        val fractionLeadingZeros = MAX_DECIMALS - length(fractionalPart)\n        val integerLength = length(integerPart)\n        val fractionString = \"0\".repeat(fractionLeadingZeros) + fractionalPart.toString().trimEnd('0')\n\n        companion object {\n            /**\n             * max fraction length we can format (as any other format library does)\n             */\n            private const val MAX_DECIMALS = 18\n            internal val MAX_DECIMAL_VALUE = 10.0.pow(MAX_DECIMALS).toLong()\n\n            internal fun createNumberInfo(num: Number): NumberInfo {\n                // frac: \"123\", exp: 8, double: 0.00000123\n                //   -> long: 000_001_230_000_000_000 (extended to max decimal digits)\n                val encodeFraction = { frac: String, exp: Int ->\n                    var fraction = frac\n                    // cutting the fraction if it longer than max decimal digits\n                    if (exp > MAX_DECIMALS) {\n                        fraction = frac.substring(0 until (frac.length - (exp - MAX_DECIMALS)))\n                    }\n                    fraction.toLong() * 10.0.pow((MAX_DECIMALS - exp).coerceAtLeast(0)).toLong()\n                }\n\n                val (intStr, fracStr, exponentString) =\n                    \"^(\\\\d+)\\\\.?(\\\\d+)?e?([+-]?\\\\d+)?\\$\"\n                        .toRegex()\n                        .find(num.toDouble().absoluteValue.toString().lowercase())\n                        ?.destructured\n                        ?: error(\"Wrong number: $num\")\n\n                val exponent: Int = exponentString.toIntOrNull() ?: 0\n\n                // number = 1.23456E+55\n                if (exponent.absoluteValue >= MAX_DECIMALS) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" -> 1\n                        integerPart = intStr.toLong(),\n                        // fraction part ignored intentionally\n                        fractionalPart = 0,\n                        // 55\n                        exponent = exponent\n                    )\n                }\n\n                check(exponent < MAX_DECIMALS)\n                // number = 1.23E-4. double: 0.000123\n                if (exponent < 0) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" + \"23\" -> 000_123_000_000_000_000L\n                        fractionalPart = encodeFraction(intStr + fracStr, exponent.absoluteValue + fracStr.length)\n                    )\n                }\n\n                check(exponent >= 0 && exponent <= MAX_DECIMALS)\n                // number = 1.234E+5, double: 123400.0\n                if (exponent >= fracStr.length) {\n                    return NumberInfo(\n                        number = num,\n                        // \"1\" + \"234\" + \"00\" -> 123400\n                        integerPart = (intStr + fracStr + \"0\".repeat(exponent - fracStr.length)).toLong()\n                    )\n                }\n\n                check(exponent >= 0 && exponent < fracStr.length)\n                // number = 1.234567E+3, double: 1234.567\n                return NumberInfo(\n                    number = num,\n                    // \"1\" + \"[234]567\" -> 1234\n                    integerPart = (intStr + fracStr.substring(0 until exponent)).toLong(),\n                    // \"234[567]\" -> 567_000_000_000_000_000\n                    fractionalPart = fracStr.substring(exponent).run { encodeFraction(this, this.length) }\n                )\n            }\n        }\n    }\n\n    data class Output(\n        val body: FormattedNumber = FormattedNumber(),\n        val sign: String = \"\",\n        val prefix: String = \"\",\n        val suffix: String = \"\",\n        val padding: String = \"\"\n    )\n\n    data class FormattedNumber(\n        val integerPart: String = \"\",\n        val fractionalPart: String = \"\",\n        val exponentialPart: String = \"\"\n    ) {\n        val fractionalLength =\n            0.takeIf { fractionalPart.isEmpty() } ?: FRACTION_DELIMITER_LENGTH + fractionalPart.length\n        val fullLength = integerPart.length + fractionalLength + exponentialPart.length\n\n        override fun toString() =\n            \"$integerPart${FRACTION_DELIMITER.takeIf { fractionalPart.isNotEmpty() } ?: \"\"}$fractionalPart$exponentialPart\"\n    }\n\n    fun apply(num: Number): String {\n        val nonNumberString = handleNonNumbers(num)\n        if (nonNumberString != null) {\n            return nonNumberString\n        }\n\n        val numberInfo = createNumberInfo(num)\n        var output = Output()\n\n        output = computeBody(output, numberInfo)\n        output = trimFraction(output)\n\n        output = computeSign(output, numberInfo)\n        output = computePrefix(output)\n        output = computeSuffix(output)\n\n        if (spec.comma && !spec.zero) {\n            output = applyGroup(output)\n        }\n\n        output = computePadding(output)\n\n        if (spec.comma && spec.zero) {\n            output = applyGroup(output)\n        }\n\n        return getAlignedString(output)\n    }\n\n    private fun handleNonNumbers(num: Number): String? {\n        val number = num.toDouble()\n        return when {\n            number.isNaN() -> \"NaN\"\n            number == Double.NEGATIVE_INFINITY -> \"-Infinity\"\n            number == Double.POSITIVE_INFINITY -> \"+Infinity\"\n            else -> null\n        }\n    }\n\n\n    private fun getAlignedString(output: Output): String {\n        with(output) {\n            return when (spec.align) {\n                \"<\" -> \"$sign$prefix$body$suffix$padding\"\n                \"=\" -> \"$sign$prefix$padding$body$suffix\"\n                \"^\" -> {\n                    val stop = padding.length / 2\n                    \"${padding.slice(0 until stop)}$sign$prefix$body$suffix${padding.slice(stop until output.padding.length)}\"\n                }\n                else -> \"$padding$sign$prefix$body$suffix\"\n            }\n        }\n    }\n\n    private fun applyGroup(output: Output): Output {\n\n        val zeroPadding = output.padding.takeIf { spec.zero } ?: \"\"\n\n        val body = output.body\n        var fullIntStr = zeroPadding + body.integerPart\n        val commas = (ceil(fullIntStr.length / GROUP_SIZE.toDouble()) - 1).toInt()\n\n        val width = (spec.width - body.fractionalLength - body.exponentialPart.length)\n            .coerceAtLeast(body.integerPart.length + commas)\n\n        fullIntStr = group(fullIntStr)\n\n        if (fullIntStr.length > width) {\n            fullIntStr = fullIntStr.substring(fullIntStr.length - width)\n            if (fullIntStr.startsWith(',')) {\n                fullIntStr = \"0$fullIntStr\"\n            }\n        }\n\n        return output.copy(\n            body = body.copy(integerPart = fullIntStr),\n            padding = \"\".takeIf { spec.zero } ?: output.padding\n        )\n    }\n\n    private fun computeBody(res: Output, numberInfo: NumberInfo): Output {\n        val formattedNumber = when (spec.type) {\n            \"%\" -> toFixedFormat(createNumberInfo(numberInfo.number * 100), spec.precision)\n            \"c\" -> FormattedNumber(numberInfo.number.toString())\n            \"d\" -> toSimpleFormat(numberInfo, 0)\n            \"e\" -> toSimpleFormat(toExponential(numberInfo, spec.precision), spec.precision)\n            \"f\" -> toFixedFormat(numberInfo, spec.precision)\n            \"g\" -> toPrecisionFormat(numberInfo, spec.precision)\n            \"b\" -> FormattedNumber(numberInfo.number.roundToLong().toString(2))\n            \"o\" -> FormattedNumber(numberInfo.number.roundToLong().toString(8))\n            \"X\" -> FormattedNumber(numberInfo.number.roundToLong().toString(16).uppercase())\n            \"x\" -> FormattedNumber(numberInfo.number.roundToLong().toString(16))\n            \"s\" -> toSiFormat(numberInfo, spec.precision)\n            else -> throw IllegalArgumentException(\"Wrong type: ${spec.type}\")\n        }\n        return res.copy(body = formattedNumber)\n    }\n\n    private fun toExponential(numberInfo: NumberInfo, precision: Int = -1): NumberInfo {\n        val num = numberInfo.number\n        if (num < TYPE_E_MIN) {\n            return NumberInfo(0.0)\n        }\n\n        var e = if (numberInfo.integerPart == 0L) {\n            -(numberInfo.fractionLeadingZeros + 1)\n        } else {\n            numberInfo.integerLength - 1 +\n                    (numberInfo.exponent ?: 0)\n        }\n        val n = num / 10.0.pow(e)\n\n        var newInfo = createNumberInfo(n)\n\n        if (precision > -1) {\n            newInfo = roundToPrecision(newInfo, precision)\n        }\n\n        if (newInfo.integerLength > 1) {\n            e += 1\n            newInfo = createNumberInfo(n / 10)\n        }\n\n        return newInfo.copy(exponent = e)\n    }\n\n    private fun toPrecisionFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        if (numberInfo.integerPart == 0L) {\n            if (numberInfo.fractionalPart == 0L) {\n                return toFixedFormat(numberInfo, precision - 1)\n            }\n            return toFixedFormat(numberInfo, precision + numberInfo.fractionLeadingZeros)\n        } else {\n            if (numberInfo.integerLength > precision) {\n                return toSimpleFormat(toExponential(numberInfo, precision - 1), precision - 1)\n            }\n            return toFixedFormat(numberInfo, precision - numberInfo.integerLength)\n        }\n    }\n\n    private fun toFixedFormat(numberInfo: NumberInfo, precision: Int = 0): FormattedNumber {\n        if (precision <= 0) {\n            return FormattedNumber(numberInfo.number.roundToLong().toString())\n        }\n\n        val newNumberInfo = roundToPrecision(numberInfo, precision)\n\n        val completePrecision = if (numberInfo.integerLength < newNumberInfo.integerLength) {\n            precision - 1\n        } else {\n            precision\n        }\n\n        if (newNumberInfo.fractionalPart == 0L) {\n            return FormattedNumber(newNumberInfo.integerPart.toString(), \"0\".repeat(completePrecision))\n        }\n\n        val fractionString = newNumberInfo.fractionString.padEnd(completePrecision, '0')\n\n        return FormattedNumber(newNumberInfo.integerPart.toString(), fractionString)\n    }\n\n    private fun toSimpleFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        val exponentString = if (numberInfo.exponent != null) {\n            val expSign = if (numberInfo.exponent.sign >= 0) \"+\" else \"\"\n            \"e$expSign${numberInfo.exponent}\"\n        } else {\n            \"\"\n        }\n\n        val expNumberInfo =\n            createNumberInfo(numberInfo.integerPart + numberInfo.fractionalPart / NumberInfo.MAX_DECIMAL_VALUE.toDouble())\n\n        if (precision > -1) {\n            val formattedNumber = toFixedFormat(expNumberInfo, precision)\n            return formattedNumber.copy(exponentialPart = exponentString)\n        }\n\n        val integerString = expNumberInfo.integerPart.toString()\n        val fractionString = if (expNumberInfo.fractionalPart == 0L) \"\" else expNumberInfo.fractionString\n        return FormattedNumber(integerString, fractionString, exponentString)\n    }\n\n    private fun toSiFormat(numberInfo: NumberInfo, precision: Int = -1): FormattedNumber {\n        val expNumberInfo = if (numberInfo.exponent == null) {\n            toExponential(numberInfo, precision - 1)\n        } else {\n            numberInfo\n        }\n        val exponent = expNumberInfo.exponent ?: 0\n        val suffixExp = floor(exponent / 3.0).coerceAtLeast(-8.0).coerceAtMost(8.0).toInt() * 3\n        val newNumberInfo = createNumberInfo(numberInfo.number * 10.0.pow(-suffixExp))\n\n        val suffixIndex = 8 + suffixExp / 3\n        val exponentString = SI_SUFFIXES[suffixIndex]\n        val formattedNumber = toFixedFormat(newNumberInfo, precision - newNumberInfo.integerLength)\n        return formattedNumber.copy(exponentialPart = exponentString)\n    }\n\n    private fun roundToPrecision(numberInfo: NumberInfo, precision: Int = 0): NumberInfo {\n        val exp = numberInfo.exponent ?: 0\n        val totalPrecision = precision + exp\n\n        var fractionalPart: Long\n        var integerPart: Long\n\n        if (totalPrecision < 0) {\n            fractionalPart = 0L\n            val intShift = totalPrecision.absoluteValue\n            integerPart = if (numberInfo.integerLength <= intShift) {\n                0\n            } else {\n                numberInfo.integerPart / 10.0.pow(intShift).toLong() * 10.0.pow(intShift).toLong()\n            }\n        } else {\n            val precisionExp = NumberInfo.MAX_DECIMAL_VALUE / 10.0.pow(totalPrecision).toLong()\n            fractionalPart = if (precisionExp == 0L) {\n                numberInfo.fractionalPart\n            } else {\n                (numberInfo.fractionalPart.toDouble() / precisionExp).roundToLong() * precisionExp\n            }\n            integerPart = numberInfo.integerPart\n            if (fractionalPart == NumberInfo.MAX_DECIMAL_VALUE) {\n                fractionalPart = 0\n                ++integerPart\n            }\n        }\n\n        val num = integerPart + fractionalPart.toDouble() / NumberInfo.MAX_DECIMAL_VALUE\n\n        return numberInfo.copy(number = num, fractionalPart = fractionalPart, integerPart = integerPart)\n    }\n\n    private fun trimFraction(output: Output): Output {\n        if (!spec.trim || output.body.fractionalPart.isEmpty()) {\n            return output\n        }\n\n        val trimmedFraction = output.body.fractionalPart.trimEnd('0')\n        return output.copy(\n            body = output.body.copy(\n                fractionalPart = trimmedFraction\n            )\n        )\n    }\n\n    private fun computeSign(output: Output, numberInfo: NumberInfo): Output {\n        val isBodyZero = output.body.run { (integerPart.asSequence() + fractionalPart.asSequence()).all { it == '0' } }\n\n        val isNegative = numberInfo.negative && !isBodyZero\n        val signStr = if (isNegative) {\n            \"-\"\n        } else {\n            if (spec.sign != \"-\") spec.sign else \"\"\n        }\n        return output.copy(sign = signStr)\n    }\n\n    private fun computePrefix(output: Output): Output {\n        val prefix = when (spec.symbol) {\n            \"$\" -> CURRENCY\n            \"#\" -> if (\"boxX\".indexOf(spec.type) > -1) \"0${spec.type.lowercase()}\" else \"\"\n            else -> \"\"\n        }\n        return output.copy(prefix = prefix)\n    }\n\n    private fun computeSuffix(res: Output): Output {\n        return res.copy(\n            suffix = PERCENT.takeIf { spec.type == \"%\" }.orEmpty()\n        )\n    }\n\n    private fun computePadding(output: Output): Output {\n        val length = output.sign.length + output.prefix.length + output.body.fullLength + output.suffix.length\n        val padding = if (length < spec.width) spec.fill.repeat(spec.width - length) else \"\"\n        return output.copy(padding = padding)\n    }\n\n    companion object {\n        const val TYPE_E_MIN = 1E-323 // Will likely crash on smaller numbers.\n        const val TYPE_S_UPPER_LIMiT = 1E40  // Will likely crash on bigger numbers.\n        const val TYPE_S_MAX = 1E26  // The largest supported SI-prefix is Y - yotta (1.E24).\n\n        private const val CURRENCY = \"$\"\n        private const val PERCENT = \"%\"\n        private const val COMMA = \",\"\n        private const val FRACTION_DELIMITER = \".\"\n        private const val FRACTION_DELIMITER_LENGTH = FRACTION_DELIMITER.length\n        private const val GROUP_SIZE = 3\n        private val SI_SUFFIXES =\n            arrayOf(\"y\", \"z\", \"a\", \"f\", \"p\", \"n\", \"µ\", \"m\", \"\", \"k\", \"M\", \"G\", \"T\", \"P\", \"E\", \"Z\", \"Y\")\n\n        fun create(spec: String): Spec {\n            return create(parse(spec))\n        }\n\n        fun create(spec: Spec): Spec {\n            var precision = spec.precision\n            var type = spec.type\n            var trim = false\n            if (type == \"\") {\n                if (precision == -1) {\n                    precision = 12\n                }\n                type = \"g\"\n            }\n\n            if (type == \"g\") {\n                trim = true\n            }\n\n            var zero = spec.zero\n            var fill = spec.fill\n            var align = spec.align\n            if (zero || (fill == \"0\" && align == \"=\")) {\n                zero = true\n                fill = \"0\"\n                align = \"=\"\n            }\n\n            return spec.copy(type = type, precision = precision, zero = zero, fill = fill, align = align, trim = trim)\n        }\n\n        private val NUMBER_REGEX =\n            \"\"\"^(?:([^{}])?([<>=^]))?([+ -])?([#$])?(0)?(\\d+)?(,)?(?:\\.(\\d+))?([%bcdefgosXx])?$\"\"\".toRegex()\n\n        fun isValidPattern(spec: String) = NUMBER_REGEX.matches(spec)\n\n        private fun parse(spec: String): Spec {\n            val matchResult = NUMBER_REGEX.find(spec) ?: throw IllegalArgumentException(\"Wrong pattern format\")\n\n            return Spec(\n                fill = matchResult.groups[1]?.value ?: \" \",\n                align = matchResult.groups[2]?.value ?: \">\",\n                sign = matchResult.groups[3]?.value ?: \"-\",\n                symbol = matchResult.groups[4]?.value ?: \"\",\n                zero = matchResult.groups[5] != null,\n                width = (matchResult.groups[6]?.value ?: \"-1\").toInt(),\n                comma = matchResult.groups[7] != null,\n                precision = (matchResult.groups[8]?.value ?: \"6\").toInt(),\n                type = matchResult.groups[9]?.value ?: \"\"\n            )\n        }\n\n        private fun group(str: String) = str\n            .reversed() // 1234 -> 4321\n            .asSequence() // [4,3,2,1]\n            .chunked(GROUP_SIZE) // [[4,3,2], [1]]\n            .map { it.joinToString(\"\") } // [[432], [1]]\n            .joinToString(COMMA) // 432,1\n            .reversed() // 1,234\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\n/**\n * Represents a collection of captured groups in a single match of a regular expression.\n *\n * This collection has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n *\n * An element of the collection at the particular index can be `null`,\n * if the corresponding group in the regular expression is optional and\n * there was no match captured by that group.\n */\npublic interface MatchGroupCollection : Collection<MatchGroup?> {\n\n    /** Returns a group with the specified [index].\n     *\n     * @return An instance of [MatchGroup] if the group with the specified [index] was matched or `null` otherwise.\n     *\n     * Groups are indexed from 1 to the count of groups in the regular expression. A group with the index 0\n     * corresponds to the entire match.\n     */\n    public operator fun get(index: Int): MatchGroup?\n}\n\n/**\n * Extends [MatchGroupCollection] by introducing a way to get matched groups by name, when regex supports it.\n */\n@SinceKotlin(\"1.1\")\npublic interface MatchNamedGroupCollection : MatchGroupCollection {\n    /**\n     * Returns a named group with the specified [name].\n     * @return An instance of [MatchGroup] if the group with the specified [name] was matched or `null` otherwise.\n     * @throws IllegalArgumentException if there is no group with the specified [name] defined in the regex pattern.\n     * @throws UnsupportedOperationException if getting named groups isn't supported on the current platform.\n     */\n    public operator fun get(name: String): MatchGroup?\n}\n\n/**\n * Represents the results from a single regular expression match.\n */\npublic interface MatchResult {\n    /** The range of indices in the original string where match was captured. */\n    public val range: IntRange\n    /** The substring from the input string captured by this match. */\n    public val value: String\n    /**\n     * A collection of groups matched by the regular expression.\n     *\n     * This collection has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n     * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n     */\n    public val groups: MatchGroupCollection\n    /**\n     * A list of matched indexed group values.\n     *\n     * This list has size of `groupCount + 1` where `groupCount` is the count of groups in the regular expression.\n     * Groups are indexed from 1 to `groupCount` and group with the index 0 corresponds to the entire match.\n     *\n     * If the group in the regular expression is optional and there were no match captured by that group,\n     * corresponding item in [groupValues] is an empty string.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public val groupValues: List<String>\n\n    /**\n     * An instance of [MatchResult.Destructured] wrapper providing components for destructuring assignment of group values.\n     *\n     * component1 corresponds to the value of the first group, component2 — of the second, and so on.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public val destructured: Destructured get() = Destructured(this)\n\n    /** Returns a new [MatchResult] with the results for the next match, starting at the position\n     *  at which the last match ended (at the character after the last matched character).\n     */\n    public fun next(): MatchResult?\n\n    /**\n     * Provides components for destructuring assignment of group values.\n     *\n     * [component1] corresponds to the value of the first group, [component2] — of the second, and so on.\n     *\n     * If the group in the regular expression is optional and there were no match captured by that group,\n     * corresponding component value is an empty string.\n     *\n     * @sample samples.text.Regexps.matchDestructuringToGroupValues\n     */\n    public class Destructured internal constructor(public val match: MatchResult) {\n        @kotlin.internal.InlineOnly\n        public operator inline fun component1():  String = match.groupValues[1]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component2():  String = match.groupValues[2]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component3():  String = match.groupValues[3]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component4():  String = match.groupValues[4]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component5():  String = match.groupValues[5]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component6():  String = match.groupValues[6]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component7():  String = match.groupValues[7]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component8():  String = match.groupValues[8]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component9():  String = match.groupValues[9]\n        @kotlin.internal.InlineOnly\n        public operator inline fun component10(): String = match.groupValues[10]\n\n        /**\n         *  Returns destructured group values as a list of strings.\n         *  First value in the returned list corresponds to the value of the first group, and so on.\n         *\n         * @sample samples.text.Regexps.matchDestructuringToGroupValues\n         */\n        public fun toList(): List<String> = match.groupValues.subList(1, match.groupValues.size)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.collections.CollectionAdapter\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.list.ObservableArrayList\n\nopen class ChildList<ParentT, ChildT : SimpleComposite<in ParentT?, in ChildT>>(private val myParent: ParentT) :\n        ObservableArrayList<ChildT>() {\n\n    init {\n        addListener(object : CollectionAdapter<ChildT>() {\n            override fun onItemAdded(event: CollectionItemEvent<out ChildT>) {\n                event.newItem!!.parent().flush()\n            }\n\n            override fun onItemRemoved(event: CollectionItemEvent<out ChildT>) {\n                val item = event.oldItem\n                item!!.parent().set(null)\n                item.setPositionData(null)\n                item.parent().flush()\n            }\n        })\n    }\n\n    override fun checkAdd(index: Int, item: ChildT) {\n        super.checkAdd(index, item)\n        if (item.parent().get() != null) {\n            throw IllegalArgumentException()\n        }\n    }\n\n    override fun beforeItemAdded(index: Int, item: ChildT) {\n        item.parent().set(myParent)\n        item.setPositionData(object :\n            PositionData<ChildT> {\n            override fun get(): Position<ChildT> {\n                @Suppress(\"NAME_SHADOWING\")\n                val index = indexOf(item)\n                return object : Position<ChildT> {\n\n                    override val role: Any\n                        get() = this@ChildList\n\n                    override fun get(): ChildT? {\n                        return if (size <= index) null else this@ChildList.get(index)\n                    }\n                }\n            }\n\n            override fun remove() {\n                this@ChildList.remove(item)\n            }\n        })\n    }\n\n    override fun checkSet(index: Int, oldItem: ChildT, newItem: ChildT) {\n        super.checkSet(index, oldItem, newItem)\n        checkRemove(index, oldItem)\n        checkAdd(index, newItem)\n    }\n\n    override fun beforeItemSet(index: Int, oldItem: ChildT, newItem: ChildT) {\n        beforeItemAdded(index, newItem)\n    }\n\n    override fun checkRemove(index: Int, item: ChildT) {\n        super.checkRemove(index, item)\n        if (item.parent().get() !== myParent) {\n            throw IllegalArgumentException()\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.property.ValueProperty\n\nclass ChildProperty<ParentT, ChildT : SimpleComposite<in ParentT?, in ChildT>>(private val myParent: ParentT) :\n        ValueProperty<ChildT?>(null) {\n\n    override fun set(value: ChildT?) {\n        if (get() === value) return\n\n        if (value != null && value.parent().get() != null) {\n            throw IllegalStateException()\n        }\n\n        val oldValue = get()\n        if (oldValue != null) {\n            oldValue.parent().set(null)\n            oldValue.setPositionData(null)\n        }\n        if (value != null) {\n            value.parent().set(myParent)\n            value.setPositionData(object :\n                PositionData<ChildT> {\n                override fun get(): Position<ChildT> {\n                    return object : Position<ChildT> {\n\n                        override val role: Any\n                            get() = this@ChildProperty\n\n                        override fun get(): ChildT? {\n                            return this@ChildProperty.get()\n                        }\n                    }\n                }\n\n                override fun remove() {\n                    set(null)\n                }\n            })\n        }\n\n        super.set(value)\n\n        if (oldValue != null) {\n            oldValue.parent().flush()\n        }\n        value?.parent()?.flush()\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.children\n\nimport jetbrains.datalore.base.observable.property.DelayedValueProperty\nimport kotlin.js.JsName\n\nopen class SimpleComposite<ParentT, SiblingT> {\n    private val myParent = DelayedValueProperty<ParentT>()\n    private var myPositionData: PositionData<out SiblingT>? = null\n\n    val position: Position<out SiblingT>\n        get() {\n            if (myPositionData == null) {\n                throw IllegalStateException()\n            }\n            return myPositionData!!.get()\n        }\n\n    fun removeFromParent() {\n        if (myPositionData == null) return\n        myPositionData!!.remove()\n    }\n\n    @JsName(\"parentProperty\")   // `parent` clashes with HasParent.parent\n    fun parent(): DelayedValueProperty<ParentT> {\n        return myParent\n    }\n\n    fun setPositionData(positionData: PositionData<out SiblingT>?) {\n        myPositionData = positionData\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections\n\nopen class CollectionAdapter<ItemT> :\n    CollectionListener<ItemT> {\n    override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {}\n\n    override fun onItemSet(event: CollectionItemEvent<out ItemT>) {\n        onItemRemoved(\n            CollectionItemEvent(\n                event.oldItem,\n                null,\n                event.index,\n                CollectionItemEvent.EventType.REMOVE\n            )\n        )\n        onItemAdded(\n            CollectionItemEvent(\n                null,\n                event.newItem,\n                event.index,\n                CollectionItemEvent.EventType.ADD\n            )\n        )\n    }\n\n    override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {}\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections\n\nimport jetbrains.datalore.base.observable.event.ListenerEvent\n\nclass CollectionItemEvent<ItemT>(\n        val oldItem: ItemT?,\n        val newItem: ItemT?,\n        val index: Int,\n        val type: EventType\n) :\n        ListenerEvent<CollectionListener<ItemT>> {\n\n    init {\n        if (EventType.ADD == type && oldItem != null || EventType.REMOVE == type && newItem != null) {\n            throw IllegalStateException()\n        }\n    }\n\n    override fun dispatch(l: CollectionListener<ItemT>) {\n        if (EventType.ADD == type) {\n            l.onItemAdded(this)\n        } else if (EventType.SET == type) {\n            l.onItemSet(this)\n        } else {\n            l.onItemRemoved(this)\n        }\n    }\n\n    override fun toString(): String {\n        return if (EventType.ADD == type) {\n            newItem.toString() + \" added at \" + index\n        } else if (EventType.SET == type) {\n            oldItem.toString() + \" replaced with \" + newItem + \" at \" + index\n        } else {\n            oldItem.toString() + \" removed at \" + index\n        }\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as CollectionItemEvent<*>\n\n        if (oldItem != other.oldItem) return false\n        if (newItem != other.newItem) return false\n        if (index != other.index) return false\n        if (type != other.type) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = oldItem?.hashCode() ?: 0\n        result = 31 * result + (newItem?.hashCode() ?: 0)\n        result = 31 * result + index\n        result = 31 * result + type.hashCode()\n        return result\n    }\n\n    enum class EventType {\n        ADD, SET, REMOVE\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections.list\n\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.CollectionListener\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\n\nabstract class AbstractObservableList<ItemT> : AbstractMutableList<ItemT>(),\n    ObservableList<ItemT> {\n    private var myListeners: Listeners<CollectionListener<in ItemT>>? = null\n\n    protected open fun checkAdd(index: Int, item: ItemT) {\n        if (index < 0 || index > size) {\n            throw IndexOutOfBoundsException(\"Add: index=$index, size=$size\")\n        }\n    }\n\n    protected open fun checkSet(index: Int, oldItem: ItemT, newItem: ItemT) {\n        if (index < 0 || index >= size) {\n            throw IndexOutOfBoundsException(\"Set: index=$index, size=$size\")\n        }\n    }\n\n    protected open fun checkRemove(index: Int, item: ItemT) {\n        if (index < 0 || index >= size) {\n            throw IndexOutOfBoundsException(\"Remove: index=$index, size=$size\")\n        }\n    }\n\n    override fun add(index: Int, element: ItemT) {\n        checkAdd(index, element)\n        beforeItemAdded(index, element)\n        var success = false\n        try {\n            doAdd(index, element)\n            success = true\n            onItemAdd(index, element)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(null, element, index, CollectionItemEvent.EventType.ADD)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemAdded(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemAdded(index, element, success)\n        }\n    }\n\n    protected abstract fun doAdd(index: Int, item: ItemT)\n\n    protected open fun beforeItemAdded(index: Int, item: ItemT) {}\n\n    protected open fun onItemAdd(index: Int, item: ItemT) {}\n\n    protected open fun afterItemAdded(index: Int, item: ItemT, success: Boolean) {}\n\n    override operator fun set(index: Int, element: ItemT): ItemT {\n        val old = get(index)\n        checkSet(index, old, element)\n        beforeItemSet(index, old, element)\n        var success = false\n        try {\n            doSet(index, element)\n            success = true\n            onItemSet(index, old, element)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(old, element, index, CollectionItemEvent.EventType.SET)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemSet(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemSet(index, old, element, success)\n        }\n        return old\n    }\n\n    protected open fun doSet(index: Int, item: ItemT) {\n        doRemove(index)\n        doAdd(index, item)\n    }\n\n    protected open fun beforeItemSet(index: Int, oldItem: ItemT, newItem: ItemT) {}\n\n    protected open fun onItemSet(index: Int, oldItem: ItemT, newItem: ItemT) {}\n\n    protected open fun afterItemSet(index: Int, oldItem: ItemT, newItem: ItemT, success: Boolean) {}\n\n    override fun removeAt(index: Int): ItemT {\n        val item = get(index)\n        checkRemove(index, item)\n        beforeItemRemoved(index, item)\n        var success = false\n        try {\n            doRemove(index)\n            success = true\n            onItemRemove(index, item)\n            if (myListeners != null) {\n                val event = CollectionItemEvent(item, null, index, CollectionItemEvent.EventType.REMOVE)\n                myListeners!!.fire(object : ListenerCaller<CollectionListener<in ItemT>> {\n                    override fun call(l: CollectionListener<in ItemT>) {\n                        l.onItemRemoved(event)\n                    }\n                })\n            }\n        } finally {\n            afterItemRemoved(index, item, success)\n        }\n        return item\n    }\n\n    protected abstract fun doRemove(index: Int)\n\n    protected open fun beforeItemRemoved(index: Int, item: ItemT) {}\n\n    protected open fun onItemRemove(index: Int, item: ItemT) {}\n\n    protected open fun afterItemRemoved(index: Int, item: ItemT, success: Boolean) {}\n\n    override fun addListener(l: CollectionListener<in ItemT>): Registration {\n        if (myListeners == null) {\n            myListeners = object : Listeners<CollectionListener<in ItemT>>() {\n                override fun beforeFirstAdded() {\n                    onListenersAdded()\n                }\n\n                override fun afterLastRemoved() {\n                    myListeners = null\n                    onListenersRemoved()\n                }\n            }\n        }\n\n        return myListeners!!.add(l)\n    }\n\n    override fun addHandler(handler: EventHandler<CollectionItemEvent<out ItemT>>): Registration {\n        val listener = object :\n            CollectionListener<ItemT> {\n            override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n\n            override fun onItemSet(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n\n            override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {\n                handler.onEvent(event)\n            }\n        }\n        return addListener(listener)\n    }\n\n    protected open fun onListenersAdded() {}\n\n    protected open fun onListenersRemoved() {}\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.collections.list\n\n\nopen class ObservableArrayList<ItemT> : AbstractObservableList<ItemT>() {\n    private var myContainer: MutableList<ItemT>? = null\n\n    override val size: Int\n        get() = if (myContainer == null) 0 else myContainer!!.size\n\n    override operator fun get(index: Int): ItemT {\n        if (myContainer == null) {\n            throw IndexOutOfBoundsException(\"$index\")\n        }\n\n        return myContainer!![index]\n    }\n\n    override fun doAdd(index: Int, item: ItemT) {\n        ensureContainerInitialized()\n        myContainer!!.add(index, item)\n    }\n\n    override fun doSet(index: Int, item: ItemT) {\n        myContainer!![index] = item\n    }\n\n    override fun doRemove(index: Int) {\n        myContainer!!.removeAt(index)\n        if (myContainer!!.isEmpty()) {\n            myContainer = null\n        }\n    }\n\n    private fun ensureContainerInitialized() {\n        if (myContainer == null) {\n            myContainer = ArrayList(1)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.registration.Registration\n\ninternal class CompositeEventSource<EventT> : EventSource<EventT> {\n    private var myHandlers: Listeners<EventHandler<EventT>>? = null\n    private val myEventSources = ArrayList<EventSource<EventT>>()\n    private val myRegistrations = ArrayList<Registration>()\n\n    constructor(vararg sources: EventSource<EventT>) {\n        for (s in sources) {\n            add(s)\n        }\n    }\n\n    constructor(sources: Iterable<EventSource<EventT>>) {\n        for (s in sources) {\n            add(s)\n        }\n    }\n\n    fun add(source: EventSource<EventT>) {\n        myEventSources.add(source)\n    }\n\n    fun remove(source: EventSource<out EventT>) {\n        myEventSources.remove(source)\n    }\n\n    override fun addHandler(handler: EventHandler<EventT>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<EventT>>() {\n                override fun beforeFirstAdded() {\n                    for (src in myEventSources) {\n                        addHandlerTo(src)\n                    }\n                }\n\n                override fun afterLastRemoved() {\n                    for (hr in myRegistrations) {\n                        hr.remove()\n                    }\n                    myRegistrations.clear()\n                    myHandlers = null\n                }\n            }\n        }\n        return myHandlers!!.add(handler)\n    }\n\n    private fun <PartEventT : EventT> addHandlerTo(src: EventSource<PartEventT>) {\n        myRegistrations.add(src.addHandler(object : EventHandler<PartEventT> {\n            override fun onEvent(event: PartEventT) {\n                myHandlers!!.fire(object : ListenerCaller<EventHandler<EventT>> {\n                    override fun call(l: EventHandler<EventT>) {\n                        l.onEvent(event)\n                    }\n                })\n            }\n        }))\n    }\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.function.Predicate\nimport jetbrains.datalore.base.observable.collections.CollectionAdapter\nimport jetbrains.datalore.base.observable.collections.CollectionItemEvent\nimport jetbrains.datalore.base.observable.collections.list.ObservableList\nimport jetbrains.datalore.base.registration.Registration\n\nobject EventSources {\n    /**\n     * Event source which always dispatched the same events on subscription. It's useful for testing and\n     * composition. In Rx-like libraries a similar thing is called cold observable.\n     */\n    fun <EventT> of(vararg events: EventT): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                for (e in events) {\n                    handler.onEvent(e)\n                }\n                return Registration.EMPTY\n            }\n        }\n    }\n\n    fun <EventT> empty(): EventSource<EventT> {\n        return composite<EventT>()\n    }\n\n    fun <EventT> composite(vararg sources: EventSource<EventT>): EventSource<EventT> {\n        return CompositeEventSource(*sources)\n    }\n\n\n    fun <EventT> composite(sources: Iterable<EventSource<EventT>>): EventSource<EventT> {\n        return CompositeEventSource(sources)\n    }\n\n    fun <EventT> filter(source: EventSource<EventT>, pred: Predicate<in EventT>): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                return source.addHandler(object : EventHandler<EventT> {\n                    override fun onEvent(event: EventT) {\n                        if (pred(event)) {\n                            handler.onEvent(event)\n                        }\n                    }\n                })\n            }\n        }\n    }\n\n    fun <SourceEventT, TargetEventT> map(src: EventSource<SourceEventT>, f: (SourceEventT) -> TargetEventT): EventSource<TargetEventT> {\n        return MappingEventSource<SourceEventT, TargetEventT>(src, f)\n    }\n\n    fun <EventT, ItemT> selectList(\n            list: ObservableList<ItemT>, selector: (ItemT?) -> EventSource<EventT>): EventSource<EventT> {\n        return object : EventSource<EventT> {\n            override fun addHandler(handler: EventHandler<EventT>): Registration {\n                val itemRegs = ArrayList<Registration>()\n                for (item in list) {\n                    itemRegs.add(selector(item).addHandler(handler))\n                }\n\n\n                val listReg = list.addListener(object : CollectionAdapter<ItemT>() {\n                    override fun onItemAdded(event: CollectionItemEvent<out ItemT>) {\n                        itemRegs.add(event.index, selector(event.newItem).addHandler(handler))\n                    }\n\n                    override fun onItemRemoved(event: CollectionItemEvent<out ItemT>) {\n                        itemRegs.removeAt(event.index).remove()\n                    }\n                })\n\n                return object : Registration() {\n                    override fun doRemove() {\n                        for (r in itemRegs) {\n                            r.remove()\n                        }\n\n                        listReg.remove()\n                    }\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\n\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.registration.throwableHandlers.ThrowableHandlers\n\n/**\n * Reusable container for listeners.\n * It supports:\n * - managing listeners\n * - firing events\n */\nopen class Listeners<ListenerT> {\n    private var myListeners: MutableList<Any>? = null\n    private var myFireDepth: Int = 0\n    private var myListenersCount: Int = 0\n\n    val isEmpty: Boolean\n        get() = myListeners == null || myListeners!!.isEmpty()\n\n    fun add(l: ListenerT): Registration {\n        if (isEmpty) {\n            beforeFirstAdded()\n        }\n\n        if (myFireDepth > 0) {\n            myListeners!!.add(ListenerOp(l, true))\n        } else {\n            if (myListeners == null) {\n                myListeners = ArrayList(1)\n            }\n            myListeners!!.add(l as Any)\n            myListenersCount++\n        }\n        return object : Registration() {\n            override fun doRemove() {\n                if (myFireDepth > 0) {\n                    myListeners!!.add(\n                        ListenerOp(\n                            l,\n                            false\n                        )\n                    )\n                } else {\n                    myListeners!!.remove(l as Any)\n                    myListenersCount--\n                }\n\n                if (isEmpty) {\n                    afterLastRemoved()\n                }\n            }\n        }\n    }\n\n    fun fire(h: ListenerCaller<ListenerT>) {\n        if (isEmpty) return\n        beforeFire()\n        //exception can be thrown from ThrowableHandlers.getInstance().handle()\n        try {\n            val size = myListenersCount\n            for (i in 0 until size) {\n                @Suppress(\"UNCHECKED_CAST\")\n                val l = myListeners!![i] as ListenerT\n\n                if (isRemoved(l)) continue\n\n                try {\n                    h.call(l)\n                } catch (t: Throwable) {\n                    ThrowableHandlers.instance.handle(t)\n                }\n\n            }\n        } finally {\n            afterFire()\n        }\n    }\n\n    private fun isRemoved(l: ListenerT): Boolean {\n        val size = myListeners!!.size\n        for (i in myListenersCount until size) {\n            @Suppress(\"UNCHECKED_CAST\")\n            val op = myListeners!![i] as ListenerOp<ListenerT>\n            if (!op.add && op.listener === l) return true\n        }\n        return false\n    }\n\n    protected open fun beforeFirstAdded() {}\n\n    protected open fun afterLastRemoved() {}\n\n    private fun beforeFire() {\n        myFireDepth++\n    }\n\n    private fun afterFire() {\n        myFireDepth--\n        if (myFireDepth == 0) {\n            val opsList = myListeners!!.subList(myListenersCount, myListeners!!.size)\n            val ops = opsList.toTypedArray()\n            opsList.clear()\n            for (o in ops) {\n                @Suppress(\"UNCHECKED_CAST\")\n                val op = o as ListenerOp<ListenerT>\n                if (op.add) {\n                    myListeners!!.add(op.listener as Any)\n                    myListenersCount++\n                } else {\n                    myListeners!!.remove(op.listener as Any)\n                    myListenersCount--\n                }\n            }\n            if (isEmpty) {\n                afterLastRemoved()\n            }\n        }\n    }\n\n    internal fun size(): Int {\n        return if (myListeners == null) 0 else myListeners!!.size\n    }\n\n    private class ListenerOp<ListenerT> internal constructor(\n            val listener: ListenerT,\n            val add: Boolean\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.event\n\nimport jetbrains.datalore.base.registration.Registration\n\ninternal class MappingEventSource<SourceEventT, TargetEventT>(\n        private val mySourceEventSource: EventSource<SourceEventT>,\n        private val myFunction: (SourceEventT) -> TargetEventT) : EventSource<TargetEventT> {\n\n    override fun addHandler(handler: EventHandler<TargetEventT>): Registration {\n        return mySourceEventSource.addHandler(object : EventHandler<SourceEventT> {\n            override fun onEvent(event: SourceEventT) {\n                handler.onEvent(myFunction(event))\n            }\n        })\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nabstract class BaseReadableProperty<ValueT> :\n    ReadableProperty<ValueT> {\n    override val propExpr: String = this::class.toString()\n\n    override fun toString(): String {\n        return propExpr\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\nimport kotlin.jvm.JvmOverloads\n\nclass DelayedValueProperty<ValueT>\n@JvmOverloads\nconstructor(\n        private var myValue: ValueT? = null) :\n        BaseReadableProperty<ValueT?>(),\n    Property<ValueT?> {\n\n    private var myHandlers: Listeners<EventHandler<PropertyChangeEvent<out ValueT?>>>? = null\n    private var myPendingEvent: PropertyChangeEvent<out ValueT?>? = null\n\n    override val propExpr: String\n        get() = \"delayedProperty()\"\n\n    override fun get(): ValueT? {\n        return myValue\n    }\n\n    override fun set(value: ValueT?) {\n        if (value == myValue) return\n        val oldValue = myValue\n        myValue = value\n\n        if (myPendingEvent != null) {\n            throw IllegalStateException()\n        }\n        myPendingEvent =\n            PropertyChangeEvent(oldValue, myValue)\n    }\n\n    fun flush() {\n        if (myHandlers != null) {\n            myHandlers!!.fire(object : ListenerCaller<EventHandler<PropertyChangeEvent<out ValueT?>>> {\n                override fun call(l: EventHandler<PropertyChangeEvent<out ValueT?>>) {\n                    l.onEvent(myPendingEvent!!)\n                }\n            })\n        }\n        myPendingEvent = null\n    }\n\n    override fun addHandler(handler: EventHandler<PropertyChangeEvent<out ValueT?>>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<PropertyChangeEvent<out ValueT?>>>() {\n                override fun afterLastRemoved() {\n                    myHandlers = null\n                }\n            }\n        }\n        return myHandlers!!.add(handler)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\n\n/**\n * One and two-way property binding support\n */\nobject PropertyBinding {\n    fun <ValueT> bindOneWay(\n            source: ReadableProperty<out ValueT>, target: WritableProperty<in ValueT>): Registration {\n        target.set(source.get())\n        return source.addHandler(object : EventHandler<PropertyChangeEvent<out ValueT>> {\n            override fun onEvent(event: PropertyChangeEvent<out ValueT>) {\n                @Suppress(\"UNCHECKED_CAST\")\n                target.set(event.newValue as ValueT)\n            }\n        })\n    }\n\n    fun <ValueT> bindTwoWay(source: Property<ValueT>, target: Property<ValueT>): Registration {\n        val syncing = ValueProperty<Boolean>(false)\n        target.set(source.get())\n\n        class UpdatingEventHandler(private val myForward: Boolean) : EventHandler<PropertyChangeEvent<out ValueT>> {\n\n            override fun onEvent(event: PropertyChangeEvent<out ValueT>) {\n                if (syncing.get()) return\n\n                syncing.set(true)\n                try {\n                    if (myForward) {\n                        target.set(source.get())\n                    } else {\n                        source.set(target.get())\n                    }\n                } finally {\n                    syncing.set(false)\n                }\n            }\n        }\n\n        return CompositeRegistration(\n                source.addHandler(UpdatingEventHandler(true)),\n                target.addHandler(UpdatingEventHandler(false))\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nclass PropertyChangeEvent<ValueT>(val oldValue: ValueT?, val newValue: ValueT?) {\n\n    override fun toString(): String {\n        return oldValue.toString() + \" -> \" + newValue\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as PropertyChangeEvent<*>\n\n        if (oldValue != other.oldValue) return false\n        if (newValue != other.newValue) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = oldValue?.hashCode() ?: 0\n        result = 31 * result + (newValue?.hashCode() ?: 0)\n        return result\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.observable.property\n\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.Registration\n\n/**\n * A simple implementation of Read/Write property which stores the value in a field\n */\nopen class ValueProperty<ValueT>(private var myValue: ValueT) :\n    BaseReadableProperty<ValueT>(),\n    Property<ValueT> {\n\n    private var myHandlers: Listeners<EventHandler<PropertyChangeEvent<out ValueT>>>? = null\n\n    override val propExpr: String\n        get() = \"valueProperty()\"\n\n    override fun get(): ValueT {\n        return myValue\n    }\n\n    override fun set(value: ValueT) {\n        if (value == myValue) return\n        val oldValue = myValue\n        myValue = value\n\n        fireEvents(oldValue, myValue)\n    }\n\n    private fun fireEvents(oldValue: ValueT, newValue: ValueT) {\n        if (myHandlers != null) {\n            val event =\n                PropertyChangeEvent(oldValue, newValue)\n            myHandlers!!.fire(object : ListenerCaller<EventHandler<PropertyChangeEvent<out ValueT>>> {\n                override fun call(l: EventHandler<PropertyChangeEvent<out ValueT>>) {\n                    l.onEvent(event)\n                }\n            })\n        }\n    }\n\n    override fun addHandler(handler: EventHandler<PropertyChangeEvent<out ValueT>>): Registration {\n        if (myHandlers == null) {\n            myHandlers = object : Listeners<EventHandler<PropertyChangeEvent<out ValueT>>>() {\n                override fun afterLastRemoved() {\n                    myHandlers = null\n                }\n            }\n        }\n\n        return myHandlers!!.add(handler)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.random\n\nimport kotlin.math.ln\nimport kotlin.math.sqrt\nimport kotlin.random.Random\n\nclass RandomGaussian(val random: Random) {\n    private var nextNextGaussian: Double = 0.0\n    private var haveNextNextGaussian = false\n\n    // From JDK Random (but not as good)\n    fun nextGaussian(): Double {\n        // See Knuth, ACP, Section 3.4.1 Algorithm C.\n        if (haveNextNextGaussian) {\n            haveNextNextGaussian = false\n            return nextNextGaussian\n        } else {\n            var v1: Double\n            var v2: Double\n            var s: Double\n            do {\n                v1 = 2 * random.nextDouble() - 1 // between -1 and 1\n                v2 = 2 * random.nextDouble() - 1 // between -1 and 1\n                s = v1 * v1 + v2 * v2\n            } while (s >= 1 || s == 0.0)\n            val multiplier = sqrt(-2 * ln(s) / s)\n            nextNextGaussian = v2 * multiplier\n            haveNextNextGaussian = true\n            return v1 * multiplier\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.random\n\nobject RandomString {\n    fun randomString(len: Int): String {\n        val alphabet = ('a'..'z') + ('A'..'Z') + ('0'..'9')\n        return List(len) { alphabet.random() }.joinToString(\"\")\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration\n\n/**\n * Registration which consists of several subregistrations.\n * Useful as an utility to aggregate registration and them dispose them with one call.\n */\nclass CompositeRegistration(vararg regs: Registration) : Registration() {\n    private val myRegistrations: MutableList<Registration>\n\n    val isEmpty: Boolean\n        get() = myRegistrations.isEmpty()\n\n    init {\n        myRegistrations = arrayListOf(*regs)\n    }\n\n    fun add(r: Registration): CompositeRegistration {\n        myRegistrations.add(r)\n        return this\n    }\n\n    fun add(vararg rs: Registration): CompositeRegistration {\n        for (r in rs) {\n            add(r)\n        }\n        return this\n    }\n\n    override fun doRemove() {\n        for (i in myRegistrations.size - 1 downTo -1 + 1) {\n            myRegistrations[i].remove()\n        }\n        myRegistrations.clear()\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration\n\nabstract class Registration : Disposable {\n\n    private var myRemoved: Boolean = false\n\n    protected abstract fun doRemove()\n\n    //this method should never be overridden except in Registration.EMPTY\n    open fun remove() {\n        if (myRemoved) {\n            throw IllegalStateException(\"Registration already removed\")\n        }\n        myRemoved = true\n        doRemove()\n    }\n\n    override fun dispose() {\n        remove()\n    }\n\n    private class EmptyRegistration : Registration() {\n\n        override fun doRemove() {}\n\n        override fun remove() {}\n    }\n\n    companion object {\n        val EMPTY: Registration =\n            EmptyRegistration()\n\n        fun from(disposable: Disposable): Registration {\n            return object : Registration() {\n                override fun doRemove() {\n                    disposable.dispose()\n                }\n            }\n        }\n\n        fun from(vararg disposables: Disposable): Registration {\n            return object : Registration() {\n                override fun doRemove() {\n                    for (d in disposables) {\n                        d.dispose()\n                    }\n                }\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration.throwableHandlers\n\nclass ThrowableHandler internal constructor() {\n\n    fun handle(t: Throwable) {\n        throw t\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.registration.throwableHandlers\n\nobject ThrowableHandlers {\n    val instance = ThrowableHandler()\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.LongitudeSegment.Companion.splitSegment\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\n// Segment have direction, i.e. `start` can be less than `end` for the case\n// of the antimeridian intersection.\n// That's why we can't use ClosedRange class with lower <= upper invariant\ntypealias Segment = Pair<Double, Double>\n\nval Segment.start get() = first\nval Segment.end get() = second\n\nclass GeoBoundingBoxCalculator<TypeT>(\n    private val myMapRect: Rect<TypeT>,\n    private val myLoopX: Boolean,\n    private val myLoopY: Boolean\n) {\n\n\n    fun calculateBoundingBox(\n        xSegments: Sequence<Segment>,\n        ySegments: Sequence<Segment>\n    ): Rect<TypeT> {\n        val xRange = calculateBoundingRange(\n            xSegments,\n            myMapRect.xRange(),\n            myLoopX\n        )\n        val yRange = calculateBoundingRange(\n            ySegments,\n            myMapRect.yRange(),\n            myLoopY\n        )\n        return Rect(\n            xRange.lowerEnd,\n            yRange.lowerEnd,\n            xRange.length(),\n            yRange.length()\n        )\n    }\n\n    private fun calculateBoundingRange(\n        segments: Sequence<Segment>,\n        mapRange: ClosedRange<Double>,\n        loop: Boolean\n    ): ClosedRange<Double> {\n        return if (loop) {\n            calculateLoopLimitRange(segments, mapRange)\n        } else {\n            ClosedRange(\n                segments.map(Segment::start).minOrNull()!!,\n                segments.map(Segment::end).maxOrNull()!!\n            )\n        }\n    }\n\n    companion object {\n        internal fun calculateLoopLimitRange(\n            segments: Sequence<Segment>,\n            mapRange: ClosedRange<Double>\n        ): ClosedRange<Double> {\n            return segments\n                .map {\n                    splitSegment(\n                        it.start, it.end,\n                        mapRange.lowerEnd,\n                        mapRange.upperEnd\n                    )\n                }\n                .flatten()\n                .run { findMaxGapBetweenRanges(this, mapRange.length()) }\n                .run { invertRange(this, mapRange.length()) }\n                .run { normalizeCenter(this, mapRange) }\n        }\n\n        private fun normalizeCenter(range: ClosedRange<Double>, mapRange: ClosedRange<Double>): ClosedRange<Double> {\n            return if (mapRange.contains((range.upperEnd + range.lowerEnd) / 2)) {\n                range\n            } else {\n                ClosedRange(\n                    range.lowerEnd - mapRange.length(),\n                    range.upperEnd - mapRange.length()\n                )\n            }\n        }\n\n        private fun findMaxGapBetweenRanges(ranges: Sequence<ClosedRange<Double>>, width: Double): ClosedRange<Double> {\n            val sortedRanges = ranges.sortedBy(ClosedRange<Double>::lowerEnd)\n            var prevUpper = sortedRanges.maxByOrNull(ClosedRange<Double>::upperEnd)!!.upperEnd\n            var nextLower = sortedRanges.first().lowerEnd\n            val gapRight = max(width + nextLower, prevUpper)\n            var maxGapRange = ClosedRange(prevUpper, gapRight)\n\n            val it = sortedRanges.iterator()\n            prevUpper = it.next().upperEnd\n\n            while (it.hasNext()) {\n                val range = it.next()\n\n                nextLower = range.lowerEnd\n                if (nextLower > prevUpper && nextLower - prevUpper > maxGapRange.length()) {\n                    maxGapRange = ClosedRange(prevUpper, nextLower)\n                }\n                prevUpper = max(prevUpper, range.upperEnd)\n            }\n            return maxGapRange\n        }\n\n        private fun invertRange(range: ClosedRange<Double>, width: Double): ClosedRange<Double> {\n            // Fix for rounding error for invertRange introduced by math with width.\n            fun safeRange(first: Double, second: Double) = ClosedRange(min(first, second), max(first, second))\n\n            return when {\n                range.length() > width ->\n                    ClosedRange(range.lowerEnd, range.lowerEnd)\n                range.upperEnd > width ->\n                    safeRange(range.upperEnd - width, range.lowerEnd)\n                else ->\n                    safeRange(range.upperEnd, width + range.lowerEnd)\n            }\n        }\n\n        private fun ClosedRange<Double>.length(): Double {\n            return upperEnd - lowerEnd\n        }\n    }\n}\n\nfun makeSegments(start: (Int) -> Double, end: (Int) -> Double, size: Int): Sequence<Segment> {\n    return (0 until size).asSequence().map { Segment(start(it), end(it)) }\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.geoRectsBBox(rectangles: List<GeoRectangle>): Rect<T> {\n    return calculateBoundingBox(\n        makeSegments(\n            { rectangles[it].startLongitude() },\n            { rectangles[it].endLongitude() },\n            rectangles.size\n        ),\n        makeSegments(\n            { rectangles[it].minLatitude() },\n            { rectangles[it].maxLatitude() },\n            rectangles.size\n        )\n    )\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.pointsBBox(xyCoords: List<Double>): Rect<T> {\n    require(xyCoords.size % 2 == 0) { \"Longitude-Latitude list is not even-numbered.\" }\n    val x: (Int) -> Double = { index -> xyCoords[2 * index] }\n    val y: (Int) -> Double = { index -> xyCoords[2 * index + 1] }\n\n    val i = xyCoords.size / 2\n    return calculateBoundingBox(\n        makeSegments(x, x, i),\n        makeSegments(y, y, i)\n    )\n}\n\nfun <T> GeoBoundingBoxCalculator<T>.union(rectangles: List<Rect<T>>): Rect<T> {\n    return calculateBoundingBox(\n        makeSegments(\n            { rectangles[it].left },\n            { rectangles[it].right },\n            rectangles.size\n        ),\n        makeSegments(\n            { rectangles[it].top },\n            { rectangles[it].bottom },\n            rectangles.size\n        )\n    )\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.json.FluentArray\nimport jetbrains.datalore.base.json.FluentObject\nimport jetbrains.datalore.base.json.JsonSupport\nimport jetbrains.datalore.base.typedGeometry.*\n\nobject GeoJson {\n    private const val LON_INDEX = 0\n    private const val LAT_INDEX = 1\n\n    fun <T> parse(geoJson: String, handler: SimpleFeature.Consumer<T>.() -> Unit) {\n        val geoObj = FluentObject(JsonSupport.parseJson(geoJson))\n        val geometryConsumer = SimpleFeature.Consumer<T>().apply(handler)\n        Parser<T>().parse(geoObj, geometryConsumer)\n    }\n\n    fun <T> parse(geoJson: String, consumer: SimpleFeature.GeometryConsumer<T>) {\n        val geoObj = FluentObject(JsonSupport.parseJson(geoJson))\n        Parser<T>().parse(geoObj, consumer)\n    }\n\n    private class Parser<T> {\n\n        internal fun parse(obj: FluentObject, handler: SimpleFeature.GeometryConsumer<T>) {\n            when (val type = obj.getString(\"type\")) {\n                \"FeatureCollection\" -> {\n                    require(obj.contains(\"features\")) { \"GeoJson: Missing 'features' in 'FeatureCollection'\" }\n\n                    obj.getArray(\"features\").fluentObjectStream()\n                        .filter { it.getString(\"type\") == \"Feature\" }\n                        .map { it.getObject(\"geometry\") }\n                        .forEach { parse(it, handler) }\n                }\n\n                \"GeometryCollection\" -> {\n                    require(obj.contains(\"geometries\")) { \"GeoJson: Missing 'geometries' in 'GeometryCollection'\" }\n\n                    obj.getArray(\"geometries\").fluentObjectStream()\n                        .forEach { parse(it, handler) }\n                }\n\n                else -> {\n                    require(obj.contains(\"coordinates\")) { \"GeoJson: Missing 'coordinates' in $type\" }\n\n                    val coordinates = obj.getArray(\"coordinates\")\n                    when (type) {\n                        \"Point\" -> parsePoint(coordinates).let(handler::onPoint)\n                        \"LineString\" -> parseLineString(coordinates).let(handler::onLineString)\n                        \"Polygon\" -> parsePolygon(coordinates).let(handler::onPolygon)\n                        \"MultiPoint\" -> parseMultiPoint(coordinates).let(handler::onMultiPoint)\n                        \"MultiLineString\" -> parseMultiLineString(coordinates).let(handler::onMultiLineString)\n                        \"MultiPolygon\" -> parseMultiPolygon(coordinates).let(handler::onMultiPolygon)\n                        else -> error(\"Not support GeoJson type: $type\")\n                    }\n                }\n            }\n        }\n\n        private fun parsePoint(jsonPoint: FluentArray): Vec<T> {\n            return explicitVec<T>(\n                jsonPoint.getDouble(LON_INDEX),\n                jsonPoint.getDouble(LAT_INDEX)\n            )\n        }\n\n        private fun parseLineString(jsonLineString: FluentArray): LineString<T> {\n            return jsonLineString.mapArray(this::parsePoint).let(::LineString)\n        }\n\n        private fun parseRing(jsonRing: FluentArray): Ring<T> {\n            return jsonRing.mapArray(this::parsePoint).let(::Ring)\n        }\n\n        private fun parseMultiPoint(jsonMultiPoint: FluentArray): MultiPoint<T> {\n            return jsonMultiPoint.mapArray(this::parsePoint).let(::MultiPoint)\n        }\n\n        private fun parsePolygon(jsonPolygon: FluentArray): Polygon<T> {\n            return jsonPolygon.mapArray(this::parseRing).let(::Polygon)\n        }\n\n        private fun parseMultiLineString(jsonLineStrings: FluentArray): MultiLineString<T> {\n            return jsonLineStrings.mapArray(this::parseLineString).let(::MultiLineString)\n        }\n\n        private fun parseMultiPolygon(jsonMultiPolygon: FluentArray): MultiPolygon<T> {\n            return jsonMultiPolygon.mapArray(this::parsePolygon).let(::MultiPolygon)\n        }\n\n        private fun <T> FluentArray.mapArray(f: (FluentArray) -> T): List<T> {\n            return this.stream().map { f(FluentArray(it as List<Any?>)) }.toList()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.typedGeometry.Rect\nimport jetbrains.datalore.base.typedGeometry.Vec\nimport jetbrains.datalore.base.typedGeometry.newSpanRectangle\n\nclass GeoRectangle(startLongitude: Double, minLatitude: Double, endLongitude: Double, maxLatitude: Double) {\n    private val myLongitudeSegment: LongitudeSegment\n    private val myLatitudeRange: ClosedRange<Double>\n\n    val isEmpty: Boolean\n        get() = myLongitudeSegment.isEmpty && latitudeRangeIsEmpty(myLatitudeRange)\n\n    private fun latitudeRangeIsEmpty(range: ClosedRange<Double>): Boolean {\n        return range.upperEnd == range.lowerEnd\n    }\n\n    init {\n        require(minLatitude <= maxLatitude) { \"Invalid latitude range: [$minLatitude..$maxLatitude]\" }\n\n        myLongitudeSegment = LongitudeSegment(startLongitude, endLongitude)\n        myLatitudeRange = ClosedRange(minLatitude, maxLatitude)\n    }\n\n    fun startLongitude(): Double = myLongitudeSegment.start()\n    fun endLongitude(): Double = myLongitudeSegment.end()\n\n    fun minLatitude(): Double = myLatitudeRange.lowerEnd\n    fun maxLatitude(): Double = myLatitudeRange.upperEnd\n\n    fun encloses(rect: GeoRectangle): Boolean {\n        return myLongitudeSegment.encloses(rect.myLongitudeSegment) && myLatitudeRange.encloses(rect.myLatitudeRange)\n    }\n\n    fun splitByAntiMeridian(): List<Rect<LonLat>> {\n        val rects = ArrayList<Rect<LonLat>>()\n\n        val longitudeRanges = myLongitudeSegment.splitByAntiMeridian()\n        for (longitudeRange in longitudeRanges) {\n            rects.add(\n                newSpanRectangle(\n                    Vec(longitudeRange.lowerEnd, myLatitudeRange.lowerEnd),\n                    Vec(longitudeRange.upperEnd, myLatitudeRange.upperEnd)\n                )\n            )\n        }\n        return rects\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as GeoRectangle?\n        return myLongitudeSegment == that!!.myLongitudeSegment && myLatitudeRange == that.myLatitudeRange\n    }\n\n    override fun hashCode(): Int {\n        return listOf(myLongitudeSegment, myLatitudeRange).hashCode()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass LonLat\ntypealias LonLatPoint = Vec<LonLat>\n\nval EARTH_RECT = Rect<LonLat>(\n    MIN_LONGITUDE,\n    MIN_LATITUDE,\n    FULL_LONGITUDE,\n    FULL_LATITUDE\n)\n\nfun limitLon(lon: Double) = max(\n    MIN_LONGITUDE, min(lon,\n        MAX_LONGITUDE\n    ))\n\nfun limitLat(lat: Double) = max(\n    MIN_LATITUDE, min(lat,\n        MAX_LATITUDE\n    ))\n\nfun normalizeLon(lon: Double): Double {\n    var result = lon - (lon / FULL_LONGITUDE).toInt() * FULL_LONGITUDE\n\n    if (result > MAX_LONGITUDE) {\n        result -= FULL_LONGITUDE\n    }\n    if (result < -MAX_LONGITUDE) {\n        result += FULL_LONGITUDE\n    }\n\n    return result\n}\n\nval BBOX_CALCULATOR = GeoBoundingBoxCalculator(\n    EARTH_RECT,\n    myLoopX = true,\n    myLoopY = false\n)\n\nfun convertToGeoRectangle(rect: Rect<LonLat>): GeoRectangle {\n    val left: Double\n    val right: Double\n\n    if (rect.width < EARTH_RECT.width) {\n        left = normalizeLon(rect.left)\n        right = normalizeLon(rect.right)\n    } else {\n        left = EARTH_RECT.left\n        right = EARTH_RECT.right\n    }\n\n    return GeoRectangle(\n        left,\n        limitLat(rect.top),\n        right,\n        limitLat(rect.bottom)\n    )\n}\n\nfun calculateQuadKeys(rect: Rect<LonLat>, zoom: Int): Set<QuadKey<LonLat>> {\n    val flippedRect = Rect<LonLat>(\n        rect.left,\n        -rect.bottom,\n        rect.width,\n        rect.height\n    )\n    return calculateQuadKeys(\n        EARTH_RECT,\n        flippedRect,\n        zoom,\n        ::QuadKey\n    )\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\n\ninternal class LongitudeSegment(start: Double, end: Double) {\n    private val myStart: Double = limitLon(start)\n    private val myEnd: Double = limitLon(end)\n\n    val isEmpty: Boolean\n        get() = myEnd == myStart\n\n    fun start(): Double {\n        return myStart\n    }\n\n    fun end(): Double {\n        return myEnd\n    }\n\n    fun length(): Double {\n        return myEnd - myStart + if (myEnd < myStart) FULL_LONGITUDE else 0.0\n    }\n\n    fun encloses(longitudeSegment: LongitudeSegment): Boolean {\n        val externalRanges = splitByAntiMeridian()\n        val internalRanges = longitudeSegment.splitByAntiMeridian()\n\n        for (internalRange in internalRanges) {\n            if (!disjointRangesEncloseRange(\n                    externalRanges,\n                    internalRange\n                )\n            ) {\n                return false\n            }\n        }\n        return true\n    }\n\n    fun invert(): LongitudeSegment {\n        return LongitudeSegment(myEnd, myStart)\n    }\n\n    fun splitByAntiMeridian(): List<ClosedRange<Double>> {\n        return splitSegment(\n            myStart, myEnd,\n            MIN_LONGITUDE,\n            MAX_LONGITUDE\n        )\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as LongitudeSegment\n        return that.myStart.equals(myStart) && that.myEnd.equals(myEnd)\n    }\n\n    override fun hashCode(): Int {\n        return listOf(myStart, myEnd).hashCode()\n    }\n\n    companion object {\n        fun splitSegment(\n            start: Double,\n            end: Double,\n            min: Double,\n            max: Double\n        ) : List<ClosedRange<Double>> {\n            return if (start <= end) {\n                listOf(ClosedRange(start, end))\n            } else {\n                listOf(\n                    ClosedRange(start, max),\n                    ClosedRange(min, end)\n                )\n            }\n        }\n\n        private fun disjointRangesEncloseRange(\n            ranges: List<ClosedRange<Double>>,\n            internalRange: ClosedRange<Double>\n        ): Boolean {\n            for (range in ranges) {\n                if (range.encloses(internalRange)) {\n                    return true\n                }\n            }\n            return false\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.math.toDegrees\nimport jetbrains.datalore.base.math.toRadians\n\nimport kotlin.math.*\n\nobject MercatorUtils {\n    private const val MAX_LONGITUDE = 180.0\n    private const val MAX_LATITUDE = 85.0511287798\n    val VALID_LONGITUDE_RANGE = ClosedRange(\n        -MAX_LONGITUDE,\n        MAX_LONGITUDE\n    )\n    val VALID_LATITUDE_RANGE = ClosedRange(\n        -MAX_LATITUDE,\n        MAX_LATITUDE\n    )\n\n    fun getMercatorX(lon: Double): Double = toRadians(lon) * EARTH_RADIUS\n\n    fun getMercatorY(lat: Double): Double {\n        @Suppress(\"NAME_SHADOWING\")\n        val lat = normalizeLat(lat)\n        return ln(tan(PI / 4 + toRadians(lat) / 2)) * EARTH_RADIUS\n    }\n\n    fun getLongitude(x: Double): Double {\n        return toDegrees(x / EARTH_RADIUS)\n    }\n\n    fun getLatitude(y: Double): Double {\n        return normalizeLat(toDegrees((atan(exp(y / EARTH_RADIUS)) - PI / 4) * 2))\n    }\n\n    fun checkLon(lon: Double): Boolean {\n        return VALID_LONGITUDE_RANGE.contains(lon)\n    }\n\n    fun checkLat(lat: Double): Boolean {\n        return VALID_LATITUDE_RANGE.contains(lat)\n    }\n\n    private fun normalizeLat(lat: Double): Double {\n        return max(\n            -MAX_LATITUDE, min(\n                lat,\n                MAX_LATITUDE\n            )\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\n\n\ndata class QuadKey<T>(\n    val key: String\n) {\n    operator fun plus(other: QuadKey<T>): QuadKey<T> {\n        return QuadKey(key + other.key)\n    }\n\n    val length = key.length\n}\n\nfun QuadKey<LonLat>.computeRect(): Rect<LonLat> {\n    val origin = this.computeOrigin(EARTH_RECT)\n    val dimension = EARTH_RECT.dimension / calulateQuadsCount(length).toDouble()\n\n    val flippedY = EARTH_RECT.scalarBottom - (origin.scalarY + dimension.scalarY - EARTH_RECT.scalarTop)\n    return Rect(origin.transform(newY = { flippedY }), dimension)\n}\n\nfun <T> QuadKey<T>.computeRect(rect: Rect<T>): Rect<T> {\n    return projectRect(rect)\n}\n\nfun <T, OutT> QuadKey<T>.projectRect(rect: Rect<OutT>): Rect<OutT> {\n    val origin = projectOrigin(rect)\n    val dimension = rect.dimension / calulateQuadsCount(length).toDouble()\n\n    return Rect(origin, dimension)\n}\n\nfun QuadKey<LonLat>.zoom() = length\n\nfun <TypeT> QuadKey<TypeT>.computeOrigin(mapRect: Rect<TypeT>): Vec<TypeT> {\n    return projectOrigin(mapRect)\n}\n\nfun <TypeT, OutT> QuadKey<TypeT>.projectOrigin(mapRect: Rect<OutT>): Vec<OutT> {\n    var left = mapRect.scalarLeft\n    var top = mapRect.scalarTop\n    var width = mapRect.scalarWidth\n    var height = mapRect.scalarHeight\n\n    for (quadrant in key) {\n        width /= 2.0\n        height /= 2.0\n\n        if (quadrant == '1' || quadrant == '3') {\n            left += width\n        }\n        if (quadrant == '2' || quadrant == '3') {\n            top += height\n        }\n    }\n    return newVec(left, top)\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.math.ipow\nimport jetbrains.datalore.base.typedGeometry.*\nimport kotlin.math.max\nimport kotlin.math.min\n\nfun calulateQuadsCount(zoom: Int): Int {\n    return 2.ipow(zoom).toInt()\n}\n\nfun <GeometryT, QuadT> calculateQuadKeys(\n    mapRect: Rect<GeometryT>,\n    viewRect: Rect<GeometryT>,\n    zoom: Int,\n    quadKeyFactory: (String) -> QuadT\n): Set<QuadT> {\n    val quadKeys = HashSet<QuadT>()\n    val tileCount = calulateQuadsCount(zoom)\n\n    fun calcQuadNum(value: Double, range: ClosedRange<Double>, tileCount: Int): Int {\n        val position = (value - range.lowerEnd) / (range.upperEnd - range.lowerEnd)\n        return max(0.0, min(position * tileCount, (tileCount - 1).toDouble())).toInt()\n    }\n\n    val xmin = calcQuadNum(viewRect.left, mapRect.xRange(), tileCount)\n    val xmax = calcQuadNum(viewRect.right, mapRect.xRange(), tileCount)\n    val ymin = calcQuadNum(viewRect.top, mapRect.yRange(), tileCount)\n    val ymax = calcQuadNum(viewRect.bottom, mapRect.yRange(), tileCount)\n\n    for (x in xmin..xmax) {\n        for (y in ymin..ymax) {\n            xyToKey(x, y, zoom).run(quadKeyFactory).run(quadKeys::add)\n        }\n    }\n\n    return quadKeys\n}\n\nfun xyToKey(x: Int, y: Int, zoom: Int): String {\n    var key = \"\"\n\n    for (i in zoom downTo 1) {\n        var digit = '0'\n        val mask = 1 shl i - 1\n\n        if (x and mask != 0) {\n            ++digit\n        }\n\n        if (y and mask != 0) {\n            digit += 2\n        }\n\n        key += digit\n    }\n\n    return key\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nimport jetbrains.datalore.base.typedGeometry.*\n\nobject SimpleFeature {\n    interface GeometryConsumer<T> {\n        fun onPoint(point: Vec<T>): Unit = error(\"Point isn't supported\")\n        fun onLineString(lineString: LineString<T>): Unit = error(\"LineString isn't supported\")\n        fun onPolygon(polygon: Polygon<T>): Unit = error(\"Polygon isn't supported\")\n        fun onMultiPoint(multiPoint: MultiPoint<T>): Unit = error(\"MultiPoint isn't supported\")\n        fun onMultiLineString(multiLineString: MultiLineString<T>): Unit = error(\"MultiLineString isn't supported\")\n        fun onMultiPolygon(multipolygon: MultiPolygon<T>): Unit = error(\"MultiPolygon isn't supported\")\n    }\n\n    class Consumer<T>(\n        var onPoint: (Vec<T>) -> Unit = { error(\"Point isn't supported\") },\n        var onLineString: (LineString<T>) -> Unit = { error(\"LineString isn't supported\") },\n        var onPolygon: (Polygon<T>) -> Unit = { error(\"Polygon isn't supported\") },\n        var onMultiPoint: (MultiPoint<T>) -> Unit = { error(\"MultiPoint isn't supported\") },\n        var onMultiLineString: (MultiLineString<T>) -> Unit = { error(\"MultiLineString isn't supported\") },\n        var onMultiPolygon: (MultiPolygon<T>) -> Unit = { error(\"MultiPolygon isn't supported\") }\n    ) : GeometryConsumer<T> {\n        override fun onPoint(point: Vec<T>): Unit = (onPoint)(point)\n        override fun onLineString(lineString: LineString<T>): Unit = (onLineString)(lineString)\n        override fun onPolygon(polygon: Polygon<T>): Unit = (onPolygon)(polygon)\n        override fun onMultiPoint(multiPoint: MultiPoint<T>): Unit = (onMultiPoint)(multiPoint)\n        override fun onMultiLineString(multiLineString: MultiLineString<T>): Unit = (onMultiLineString)(multiLineString)\n        override fun onMultiPolygon(multipolygon: MultiPolygon<T>): Unit = (onMultiPolygon)(multipolygon)\n    }\n\n    enum class GeometryType {\n        POINT,\n        LINE_STRING,\n        POLYGON,\n        MULTI_POINT,\n        MULTI_LINE_STRING,\n        MULTI_POLYGON,\n        GEOMETRY_COLLECTION;\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.stringFormat\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\n\nclass StringFormat private constructor(\n    private val pattern: String,\n    val formatType: FormatType\n) {\n    enum class FormatType {\n        NUMBER_FORMAT,\n        STRING_FORMAT\n    }\n\n    private val myNumberFormatters: List<NumberFormat?>\n\n    init {\n        fun initNumberFormat(pattern: String): NumberFormat {\n            try {\n                return NumberFormat(pattern)\n            } catch (e: Exception) {\n                error(\"Wrong number pattern: $pattern\")\n            }\n        }\n\n        myNumberFormatters = when (formatType) {\n            FormatType.NUMBER_FORMAT -> listOf(initNumberFormat(pattern))\n            FormatType.STRING_FORMAT -> {\n                BRACES_REGEX.findAll(pattern)\n                    .map { it.groupValues[TEXT_IN_BRACES] }\n                    .map { format ->\n                        if (format.isNotEmpty()) {\n                            initNumberFormat(format)\n                        } else {\n                            null\n                        }\n                    }\n                    .toList()\n            }\n        }\n    }\n\n    val argsNumber = myNumberFormatters.size\n\n    fun format(value: Any): String = format(listOf(value))\n\n    fun format(values: List<Any>): String {\n        if (argsNumber != values.size) {\n            error(\"Can't format values $values with pattern \\\"$pattern\\\"). Wrong number of arguments: expected $argsNumber instead of ${values.size}\")\n        }\n        return when (formatType) {\n            FormatType.NUMBER_FORMAT -> {\n                require(myNumberFormatters.size == 1)\n                formatValue(values.single(), myNumberFormatters.single())\n            }\n            FormatType.STRING_FORMAT -> {\n                var index = 0\n                BRACES_REGEX.replace(pattern) {\n                    val originalValue = values[index]\n                    val formatter = myNumberFormatters[index++]\n                    formatValue(originalValue, formatter)\n                }\n                    .replace(\"{{\", \"{\")\n                    .replace(\"}}\", \"}\")\n            }\n        }\n    }\n\n    private fun formatValue(value: Any, numberFormatter: NumberFormat?): String {\n        return when {\n            numberFormatter == null -> value.toString()\n            value is Number -> numberFormatter.apply(value)\n            value is String -> value.toFloatOrNull()?.let(numberFormatter::apply) ?: value\n            else -> error(\"Failed to format value with type ${value::class.simpleName}. Supported types are Number and String.\")\n        }\n    }\n\n    companion object {\n        // Format strings contain “replacement fields” surrounded by braces {}.\n        // Anything that is not contained in braces is considered literal text, which is copied unchanged to the output.\n        // If you need to include a brace character in the literal text, it can be escaped by doubling: {{ and }}.\n        //     \"text\" -> \"text\"\n        //     \"{{text}}\" -> \"{text}\"\n        //     \"{.1f} -> 1.2\n        //     \"{{{.1f}}} -> {1.2}\n        private val BRACES_REGEX = Regex(\"\"\"(?![^{]|\\{\\{)(\\{([^{}]*)\\})(?=[^}]|\\}\\}|$)\"\"\")\n        const val TEXT_IN_BRACES = 2\n\n        fun valueInLinePattern() = \"{}\"\n\n        fun forOneArg(\n            pattern: String,\n            type: FormatType? = null,\n            formatFor: String? = null,\n        ): StringFormat {\n            return create(pattern, type, formatFor, 1)\n        }\n\n        fun forNArgs(\n            pattern: String,\n            type: FormatType? = null,\n            argCount: Int,\n            formatFor: String? = null\n        ): StringFormat {\n            return create(pattern, type, formatFor, argCount)\n        }\n\n        fun create(\n            pattern: String,\n            type: FormatType? = null,\n            formatFor: String? = null,\n            expectedArgs: Int = -1\n        ): StringFormat {\n            val formatType = when {\n                type != null -> type\n                NumberFormat.isValidPattern(pattern) -> FormatType.NUMBER_FORMAT\n                else -> FormatType.STRING_FORMAT\n            }\n\n            return StringFormat(pattern, formatType).also {\n                if (expectedArgs > 0) {\n                    require(it.argsNumber == expectedArgs) {\n                        @Suppress(\"NAME_SHADOWING\")\n                        val formatFor = formatFor?.let { \"to format \\'$formatFor\\'\" } ?: \"\"\n                        \"Wrong number of arguments in pattern \\'$pattern\\' $formatFor. \" +\n                                \"Expected $expectedArgs ${if (expectedArgs > 1) \"arguments\" else \"argument\"} \" +\n                                \"instead of ${it.argsNumber}\"\n                    }\n                }\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nopen class AbstractGeometryList<T>(private val myGeometry: List<T>) : AbstractList<T>() {\n    override fun get(index: Int): T {\n        return myGeometry[index]\n    }\n\n    override val size: Int\n        get() = myGeometry.size\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.geometry.DoubleRectangles\n\nfun <T> isClockwise(ring: List<Vec<T>>): Boolean {\n    return jetbrains.datalore.base.algorithms.isClockwise(ring, Vec<T>::x, Vec<T>::y)\n}\n\nfun <T> createMultiPolygon(points: List<Vec<T>>): MultiPolygon<T> {\n    if (points.isEmpty()) {\n        return MultiPolygon(emptyList())\n    }\n\n    val polygons = ArrayList<Polygon<T>>()\n    var rings = ArrayList<Ring<T>>()\n\n    for (ring in splitRings(points)) {\n        if (rings.isNotEmpty() && isClockwise(ring)) {\n            polygons.add(Polygon(rings))\n            rings = ArrayList()\n        }\n        rings.add(Ring(ring))\n    }\n\n    if (rings.isNotEmpty()) {\n        polygons.add(Polygon(rings))\n    }\n\n    return MultiPolygon(polygons)\n}\n\nfun <TypeT> Iterable<Vec<TypeT>>.boundingBox(): Rect<TypeT> {\n    return DoubleRectangles.calculateBoundingBox(this,\n        Vec<*>::x,\n        Vec<*>::y\n    )\n    { minX, minY, maxX, maxY ->\n        newSpanRectangle(\n            Vec(minX, minY),\n            Vec(maxX, maxY)\n        )\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\nclass Generic\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> Vec<Generic>.reinterpret(): Vec<TypeT> = this as Vec<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiPoint<Generic>.reinterpret(): MultiPoint<TypeT> = this as MultiPoint<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> LineString<Generic>.reinterpret(): LineString<TypeT> = this as LineString<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiLineString<Generic>.reinterpret(): MultiLineString<TypeT> = this as MultiLineString<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> Polygon<Generic>.reinterpret(): Polygon<TypeT> = this as Polygon<TypeT>\n\n@Suppress(\"UNCHECKED_CAST\")\nfun <TypeT> MultiPolygon<Generic>.reinterpret(): MultiPolygon<TypeT> = this as MultiPolygon<TypeT>\n\nval Rect<*>.bottom: Double get() = origin.y + dimension.y\nval Rect<*>.right: Double get() = origin.x + dimension.x\nval Rect<*>.height: Double get() = dimension.y\nval Rect<*>.width: Double get() = dimension.x\nval Rect<*>.top: Double get() = origin.y\nval Rect<*>.left: Double get() = origin.x\n\nval <TypeT> Rect<TypeT>.scalarBottom: Scalar<TypeT> get() = Scalar(bottom)\nval <TypeT> Rect<TypeT>.scalarRight: Scalar<TypeT> get() = Scalar(right)\nval <TypeT> Rect<TypeT>.scalarHeight: Scalar<TypeT> get() = Scalar(height)\nval <TypeT> Rect<TypeT>.scalarWidth: Scalar<TypeT> get() = Scalar(width)\nval <TypeT> Rect<TypeT>.scalarTop: Scalar<TypeT> get() = Scalar(top)\nval <TypeT> Rect<TypeT>.scalarLeft: Scalar<TypeT> get() = Scalar(left)\n\nval <TypeT> Rect<TypeT>.center: Vec<TypeT> get() = dimension / 2.0 + origin\n\nval <TypeT> Vec<TypeT>.scalarX get(): Scalar<TypeT> = Scalar(x)\nval <TypeT> Vec<TypeT>.scalarY get(): Scalar<TypeT> = Scalar(y)\n\noperator fun <TypeT> Vec<TypeT>.plus(other: Vec<TypeT>): Vec<TypeT> = Vec(x + other.x, y + other.y)\noperator fun <TypeT> Vec<TypeT>.minus(other: Vec<TypeT>): Vec<TypeT> = Vec(x - other.x, y - other.y)\noperator fun <TypeT> Vec<TypeT>.times(other: Vec<TypeT>): Vec<TypeT> = Vec(x * other.x, y * other.y)\noperator fun <TypeT> Vec<TypeT>.div(other: Vec<TypeT>): Vec<TypeT> = Vec(x / other.x, y / other.y)\n\noperator fun <TypeT> Vec<TypeT>.times(scale: Double): Vec<TypeT> = Vec(x * scale, y * scale)\noperator fun <TypeT> Vec<TypeT>.div(scale: Double): Vec<TypeT> = Vec(x / scale, y / scale)\noperator fun <TypeT> Vec<TypeT>.unaryMinus(): Vec<TypeT> = Vec(-x, -y)\n\nfun <TypeT> Vec<TypeT>.transform(\n    newX: (Scalar<TypeT>) -> Scalar<TypeT> = { it },\n    newY: (Scalar<TypeT>) -> Scalar<TypeT> = { it }\n) = Vec<TypeT>(newX(scalarX).value, newY(scalarY).value)\n\noperator fun <T> Scalar<T>.plus(other: Scalar<T>): Scalar<T> = Scalar(value + other.value)\noperator fun <T> Scalar<T>.minus(other: Scalar<T>): Scalar<T> = Scalar(value - other.value)\noperator fun <T> Scalar<T>.times(other: Scalar<T>): Scalar<T> = Scalar(value * other.value)\n\noperator fun <T> Scalar<T>.div(other: Scalar<T>): Scalar<T> = Scalar(value / other.value)\noperator fun <T> Scalar<T>.div(other: Double): Scalar<T> = Scalar(value / other)\noperator fun <T> Scalar<T>.times(other: Double): Scalar<T> = Scalar(value * other)\noperator fun <T> Scalar<T>.unaryMinus(): Scalar<T> = Scalar(-value)\n\noperator fun <T> Scalar<T>.compareTo(i: Int) = value.compareTo(i)\n\n\nfun <TypeT> newSpanRectangle(leftTop: Vec<TypeT>, rightBottom: Vec<TypeT>): Rect<TypeT> {\n    return Rect(leftTop, rightBottom - leftTop)\n}\n\nfun <TypeT> Polygon<TypeT>.limit(): Rect<TypeT> {\n    return asSequence().flatten().asIterable().boundingBox()\n}\n\nfun <TypeT> Rect<TypeT>.contains(v: Vec<TypeT>): Boolean {\n    return origin.x <= v.x && origin.x + dimension.x >= v.x && origin.y <= v.y && origin.y + dimension.y >= v.y\n}\n\nfun <TypeT> Rect<TypeT>.intersects(rect: Rect<TypeT>): Boolean {\n    val t1 = origin\n    val t2 = origin + dimension\n    val r1 = rect.origin\n    val r2 = rect.origin + rect.dimension\n    return r2.x >= t1.x && t2.x >= r1.x && r2.y >= t1.y && t2.y >= r1.y\n}\n\nfun Rect<*>.xRange() = ClosedRange(origin.x, origin.x + dimension.x)\nfun Rect<*>.yRange() = ClosedRange(origin.y, origin.y + dimension.y)\n\nfun <TypeT> MultiPolygon<TypeT>.limit(): List<Rect<TypeT>> {\n    return map { polygon -> polygon.limit() }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nenum class GeometryType {\n    MULTI_POINT,\n    MULTI_LINESTRING,\n    MULTI_POLYGON;\n}\n\nclass Geometry<TypeT> private constructor(\n    val type: GeometryType,\n    private val myMultiPoint: MultiPoint<TypeT>?,\n    private val myMultiLineString: MultiLineString<TypeT>?,\n    private val myMultiPolygon: MultiPolygon<TypeT>?\n) {\n    val multiPoint: MultiPoint<TypeT>\n        get() = myMultiPoint ?: error(\"$type is not a MultiPoint\")\n    val multiLineString: MultiLineString<TypeT>\n        get() = myMultiLineString ?: error(\"$type is not a MultiLineString\")\n    val multiPolygon: MultiPolygon<TypeT>\n        get() = myMultiPolygon ?: error(\"$type is not a MultiPolygon\")\n\n    companion object {\n        fun <TypeT> createMultiPoint(multiPoint: MultiPoint<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_POINT,\n                myMultiPoint = multiPoint,\n                myMultiLineString = null,\n                myMultiPolygon = null\n            )\n        }\n\n        fun <TypeT> createMultiLineString(multiLineString: MultiLineString<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_LINESTRING,\n                myMultiPoint = null,\n                myMultiLineString = multiLineString,\n                myMultiPolygon = null\n            )\n        }\n\n        fun <TypeT> createMultiPolygon(multiPolygon: MultiPolygon<TypeT>): Geometry<TypeT> {\n            return Geometry(\n                type = GeometryType.MULTI_POLYGON,\n                myMultiPoint = null,\n                myMultiLineString = null,\n                myMultiPolygon = multiPolygon\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass LineString<TypeT>(geometry: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiLineString<TypeT>(geometry: List<LineString<TypeT>>) : AbstractGeometryList<LineString<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiPoint<TypeT>(geometry: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(geometry)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass MultiPolygon<TypeT>(polygons: List<Polygon<TypeT>>) : AbstractGeometryList<Polygon<TypeT>>(polygons)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass Polygon<TypeT>(rings: List<Ring<TypeT>>) : AbstractGeometryList<Ring<TypeT>>(rings)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Rect<TypeT>(\n    val origin: Vec<TypeT>,\n    val dimension: Vec<TypeT>\n) {\n    constructor(\n        left: Double,\n        top: Double,\n        width: Double,\n        height: Double\n    ) : this(\n        Vec(left, top),\n        Vec(width, height)\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\nclass Ring<TypeT>(points: List<Vec<TypeT>>) : AbstractGeometryList<Vec<TypeT>>(points)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Scalar<T>(\n    val value: Double\n)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedGeometry\n\ndata class Vec<TypeT> (\n    val x: Double,\n    val y: Double\n) {\n    constructor(x: Int, y: Int) : this(x.toDouble(), y.toDouble())\n}\n\nfun <T> explicitVec(x: Double, y: Double): Vec<T> = Vec(x, y)\nfun <T> explicitVec(x: Int, y: Int): Vec<T> = Vec(x.toDouble(), y.toDouble())\nfun <T> newVec(x: Scalar<T>, y: Scalar<T>): Vec<T> = Vec(x.value, y.value)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.typedKey\n\n/**\n * Maps typed keys to not-null values.\n * The type parametr can't be a nullable type.\n */\nclass TypedKeyHashMap {\n\n    val map = hashMapOf<TypedKey<*>, Any?>()\n\n    /**\n     * Throws NoSuchElementException if key is not present.\n     */\n    operator fun <T> get(key: TypedKey<T>): T {\n        if (map.containsKey(key)) {\n            @Suppress(\"UNCHECKED_CAST\")\n            return map[key] as T\n        }\n        throw NoSuchElementException(\"Wasn't found key $key\")\n    }\n\n    operator fun <T> set(key: TypedKey<T>, value: T?) {\n        put(key, value)\n    }\n\n    /**\n     * Null value is ignored and the key (if present) is removed from container.\n     *\n     * Note: the fact that the value type is nullable is very important when used with 'primitive'\n     * Kotlin type (like Double) in 'native' context.\n     * Without 'T?' Kotlin may choose to represent Double by double and will crash on an attempt to cast type (`as`) or\n     * to apply null-safe operator (!!). Such behavior was observed in Kotlin native.\n     * See Kotlin docs: https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/-double/index.html\n     */\n    fun <T> put(key: TypedKey<T>, value: T?) {\n        if (value == null) {\n            map.remove(key)\n        } else {\n            map[key] = value\n        }\n    }\n\n    fun contains(key: TypedKey<*>): Boolean {\n        return containsKey(key)\n    }\n\n    fun <T> containsKey(key: TypedKey<T>): Boolean {\n        return map.containsKey(key)\n    }\n\n    fun <T> keys(): Set<TypedKey<T>> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return map.keys as Set<TypedKey<T>>\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.unsupported\n\n/*\n\nUse UNSUPPORTED() instead of TODO() from Kotlin standard library.\nTODO() throws an `Error` and we are generally don't try to catch errors.\n\n */\n\n@Suppress(\"FunctionName\")\nfun UNSUPPORTED(): Nothing = throw UnsupportedOperationException()\n\n@Suppress(\"FunctionName\")\nfun UNSUPPORTED(what: String): Nothing = throw UnsupportedOperationException(what)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.roundToInt\n\n// ToDo: ubyte?\nclass Color @JvmOverloads constructor(\n    val red: Int,\n    val green: Int,\n    val blue: Int,\n    val alpha: Int = 255\n) {\n    init {\n        require(\n            0 <= red && red <= 255 &&\n                    0 <= green && green <= 255 &&\n                    0 <= blue && blue <= 255 &&\n                    0 <= alpha && alpha <= 255\n        ) { \"Color components out of range: $this\" }\n    }\n\n    fun changeAlpha(newAlpha: Int): Color {\n        return Color(red, green, blue, newAlpha)\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) {\n            return true\n        }\n        if (other !is Color) {\n            return false\n        }\n\n        if (red != other.red) {\n            return false\n        }\n        if (green != other.green) {\n            return false\n        }\n        if (blue != other.blue) {\n            return false\n        }\n        return alpha == other.alpha\n    }\n\n    fun toCssColor(): String {\n        return if (alpha == 255) {\n            \"rgb($red,$green,$blue)\"\n        } else {\n            \"rgba(\" + red + \",\" + green + \",\" + blue + \",\" + alpha / 255.0 + \")\"\n        }\n    }\n\n    fun toHexColor(): String {\n        return \"#\" + toColorPart(red) + toColorPart(green) + toColorPart(blue)\n    }\n\n    override fun hashCode(): Int {\n        var result = 0\n        result = 31 * result + red\n        result = 31 * result + green\n        result = 31 * result + blue\n        result = 31 * result + alpha\n        return result\n    }\n\n    override fun toString(): String {\n        return \"color($red,$green,$blue,$alpha)\"\n    }\n\n    companion object {\n        val TRANSPARENT = Color(0, 0, 0, 0)\n        val WHITE = Color(255, 255, 255)\n        val CONSOLE_WHITE = Color(204, 204, 204)\n        val BLACK = Color(0, 0, 0)\n        val LIGHT_GRAY = Color(192, 192, 192)\n        val VERY_LIGHT_GRAY = Color(210, 210, 210)\n        val GRAY = Color(128, 128, 128)\n        val RED = Color(255, 0, 0)\n        val LIGHT_GREEN = Color(210, 255, 210)\n        val GREEN = Color(0, 255, 0)\n        val DARK_GREEN = Color(0, 128, 0)\n        val BLUE = Color(0, 0, 255)\n        val DARK_BLUE = Color(0, 0, 128)\n        val LIGHT_BLUE = Color(210, 210, 255)\n        val YELLOW = Color(255, 255, 0)\n        val CONSOLE_YELLOW = Color(174, 174, 36)\n        val LIGHT_YELLOW = Color(255, 255, 128)\n        val VERY_LIGHT_YELLOW = Color(255, 255, 210)\n        val MAGENTA = Color(255, 0, 255)\n        val LIGHT_MAGENTA = Color(255, 210, 255)\n        val DARK_MAGENTA = Color(128, 0, 128)\n        val CYAN = Color(0, 255, 255)\n        val LIGHT_CYAN = Color(210, 255, 255)\n        val ORANGE = Color(255, 192, 0)\n        val PINK = Color(255, 175, 175)\n        val LIGHT_PINK = Color(255, 210, 210)\n\n        val PACIFIC_BLUE = parseHex(\"#118ED8\")\n\n        private const val RGB = \"rgb\"\n        private const val COLOR = \"color\"\n        private const val RGBA = \"rgba\"\n\n        fun parseRGB(text: String): Color {\n            val firstParen = findNext(text, \"(\", 0)\n            val prefix = text.substring(0, firstParen)\n\n            val firstComma = findNext(text, \",\", firstParen + 1)\n            val secondComma = findNext(text, \",\", firstComma + 1)\n\n            var thirdComma = -1\n\n            when {\n                prefix == RGBA -> thirdComma = findNext(text, \",\", secondComma + 1)\n                prefix == COLOR -> thirdComma = text.indexOf(\",\", secondComma + 1)\n                prefix != RGB -> throw IllegalArgumentException(text)\n            }\n\n            val lastParen = findNext(text, \")\", thirdComma + 1)\n            val red = text.substring(firstParen + 1, firstComma).trim { it <= ' ' }.toInt()\n            val green = text.substring(firstComma + 1, secondComma).trim { it <= ' ' }.toInt()\n\n            val blue: Int\n            val alpha: Int\n            if (thirdComma == -1) {\n                blue = text.substring(secondComma + 1, lastParen).trim { it <= ' ' }.toInt()\n                alpha = 255\n            } else {\n                blue = text.substring(secondComma + 1, thirdComma).trim { it <= ' ' }.toInt()\n                alpha = (text.substring(thirdComma + 1, lastParen).trim { it <= ' ' }.toFloat() * 255).roundToInt()\n            }\n\n            return Color(red, green, blue, alpha)\n        }\n\n        private fun findNext(s: String, what: String, from: Int): Int {\n            val result = s.indexOf(what, from)\n            if (result == -1) {\n                throw IllegalArgumentException(\"text=$s what=$what from=$from\")\n            }\n            return result\n        }\n\n        fun parseHex(hexColor: String): Color {\n            @Suppress(\"NAME_SHADOWING\")\n            var hexColor = hexColor\n            if (!hexColor.startsWith(\"#\")) {\n                throw IllegalArgumentException(\"Not a HEX value: $hexColor\")\n            }\n            hexColor = hexColor.substring(1)\n            if (hexColor.length != 6) {\n                throw IllegalArgumentException(\"Not a HEX value: $hexColor\")\n            }\n            val r = hexColor.substring(0, 2).toInt(16)\n            val g = hexColor.substring(2, 4).toInt(16)\n            val b = hexColor.substring(4, 6).toInt(16)\n            return Color(r, g, b)\n        }\n\n        private fun toColorPart(value: Int): String {\n            if (value < 0 || value > 255) {\n                throw IllegalArgumentException(\"RGB color part must be in range [0..255] but was $value\")\n            }\n\n            val result = value.toString(16)\n            return if (result.length == 1) {\n                \"0$result\"\n            } else {\n                result\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.*\nimport kotlin.random.Random\n\nobject Colors {\n    private const val DEFAULT_FACTOR = 0.7\n\n    private val variantColors = mapOf<String, Color>(\n        \"dark_blue\" to Color.DARK_BLUE,\n        \"dark_green\" to Color.DARK_GREEN,\n        \"dark_magenta\" to Color.DARK_MAGENTA,\n        \"light_blue\" to Color.LIGHT_BLUE,\n        \"light_gray\" to Color.LIGHT_GRAY,\n        \"light_green\" to Color.LIGHT_GREEN,\n        \"light_yellow\" to Color.LIGHT_YELLOW,\n        \"light_magenta\" to Color.LIGHT_MAGENTA,\n        \"light_cyan\" to Color.LIGHT_CYAN,\n        \"light_pink\" to Color.LIGHT_PINK,\n        \"very_light_gray\" to Color.VERY_LIGHT_GRAY,\n        \"very_light_yellow\" to Color.VERY_LIGHT_YELLOW\n    )\n    private val namedColors = mapOf<String, Color>(\n        \"white\" to Color.WHITE,\n        \"black\" to Color.BLACK,\n        \"gray\" to Color.GRAY,\n        \"red\" to Color.RED,\n        \"green\" to Color.GREEN,\n        \"blue\" to Color.BLUE,\n        \"yellow\" to Color.YELLOW,\n        \"magenta\" to Color.MAGENTA,\n        \"cyan\" to Color.CYAN,\n        \"orange\" to Color.ORANGE,\n        \"pink\" to Color.PINK\n    ) +\n            // light_gray\n            variantColors +\n            // light-gray\n            variantColors.mapKeys { it.key.replace('_', '-') } +\n            // lightgray\n            variantColors.mapKeys { it.key.replace(\"_\", \"\") }\n\n\n    /**\n     * @param c color string to parse. Accepted formats:\n     *     - rgb(r, g, b)\n     *     - rgba(r, g, b, a)\n     *     - color(r, g, b, a)\n     *     - #rrggbb\n     *     - white, green etc.\n     */\n    fun parseColor(c: String): Color {\n        return when {\n            c.indexOf('(') > 0 -> Color.parseRGB(c)\n            c.startsWith(\"#\") -> Color.parseHex(c)\n            isColorName(c) -> forName(c)\n            else -> throw IllegalArgumentException(\"Error persing color value: $c\")\n        }\n    }\n\n    fun isColorName(colorName: String): Boolean {\n        return namedColors.containsKey(colorName.lowercase())\n    }\n\n    fun forName(colorName: String): Color {\n        return namedColors[colorName.lowercase()] ?: throw IllegalArgumentException()\n    }\n\n    fun generateHueColor(): Double {\n        return 360 * Random.nextDouble()\n    }\n\n    fun generateColor(s: Double, v: Double): Color {\n        return rgbFromHsv(360 * Random.nextDouble(), s, v)\n    }\n\n    /**\n     * @param h hue, [0, 360] degree\n     * @param s saturation, [0, 1]\n     * @param v value, [0, 1]\n     */\n    @JvmOverloads\n    fun rgbFromHsv(h: Double, s: Double, v: Double = 1.0): Color {\n        val hd = h / 60\n        val c = v * s\n        val x = c * (1 - abs(hd % 2 - 1))\n\n        var r = 0.0\n        var g = 0.0\n        var b = 0.0\n\n        when {\n            hd < 1 -> {\n                r = c\n                g = x\n            }\n            hd < 2 -> {\n                r = x\n                g = c\n            }\n            hd < 3 -> {\n                g = c\n                b = x\n            }\n            hd < 4 -> {\n                g = x\n                b = c\n            }\n            hd < 5 -> {\n                r = x\n                b = c\n            }\n            else -> {\n                r = c\n                b = x\n            }\n        }\n\n        val m = v - c\n        return Color((255 * (r + m)).toInt(), (255 * (g + m)).toInt(), (255 * (b + m)).toInt())\n    }\n\n    fun hsvFromRgb(color: Color): DoubleArray {\n        val scale = (1f / 255).toDouble()\n        val r = color.red * scale\n        val g = color.green * scale\n        val b = color.blue * scale\n        val min = min(r, min(g, b))\n        val max = max(r, max(g, b))\n\n        val v = if (max == 0.0) 0.0 else 1 - min / max\n        val h: Double\n        val div = 1f / (6 * (max - min))\n\n        h = if (max == min) {\n            0.0\n        } else if (max == r) {\n            if (g >= b) (g - b) * div else 1 + (g - b) * div\n        } else if (max == g) {\n            1f / 3 + (b - r) * div\n        } else {\n            2f / 3 + (r - g) * div\n        }\n\n        return doubleArrayOf(360 * h, v, max)\n    }\n\n    @JvmOverloads\n    fun darker(c: Color?, factor: Double = DEFAULT_FACTOR): Color? {\n        return c?.let {\n            Color(\n                max((c.red * factor).toInt(), 0),\n                max((c.green * factor).toInt(), 0),\n                max((c.blue * factor).toInt(), 0),\n                c.alpha\n            )\n        }\n    }\n\n    @JvmOverloads\n    fun lighter(c: Color, factor: Double = DEFAULT_FACTOR): Color {\n        var r = c.red\n        var g = c.green\n        var b = c.blue\n        val alpha = c.alpha\n\n        val i = (1.0 / (1.0 - factor)).toInt()\n        if (r == 0 && g == 0 && b == 0) {\n            return Color(i, i, i, alpha)\n        }\n        if (r > 0 && r < i) r = i\n        if (g > 0 && g < i) g = i\n        if (b > 0 && b < i) b = i\n\n        return Color(\n            min((r / factor).toInt(), 255),\n            min((g / factor).toInt(), 255),\n            min((b / factor).toInt(), 255),\n            alpha\n        )\n    }\n\n    fun mimicTransparency(color: Color, alpha: Double, background: Color): Color {\n        val red = (color.red * alpha + background.red * (1 - alpha)).toInt()\n        val green = (color.green * alpha + background.green * (1 - alpha)).toInt()\n        val blue = (color.blue * alpha + background.blue * (1 - alpha)).toInt()\n        return Color(red, green, blue)\n    }\n\n    fun withOpacity(c: Color, opacity: Double): Color {\n        return if (opacity < 1.0) {\n            c.changeAlpha(max(0, min(255, round(255 * opacity).toInt())))\n        } else c\n    }\n\n    fun contrast(color: Color, other: Color): Double {\n        return (luminance(color) + .05) / (luminance(other) + .05)\n    }\n\n    fun luminance(color: Color): Double {\n        return .2126 * colorLuminance(color.red) + .7152 * colorLuminance(color.green) + .0722 * colorLuminance(color.blue)\n    }\n\n    private fun colorLuminance(componentValue: Int): Double {\n        return if (componentValue <= 10) componentValue / 3294.0 else (componentValue / 269.0 + .0513).pow(2.4)\n    }\n\n    fun solid(c: Color): Boolean {\n        return c.alpha == 255\n    }\n\n    fun distributeEvenly(count: Int, saturation: Double): Array<Color> {\n        val result = arrayOfNulls<Color>(count)\n\n        val sector = 360 / count\n        for (i in 0 until count) {\n            result[i] = rgbFromHsv((sector * i).toDouble(), saturation)\n        }\n        @Suppress(\"UNCHECKED_CAST\")\n        return result as Array<Color>\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nfun toPngDataUri(base64EncodedPngImage: String): String {\n    return \"data:image/png;base64,$base64EncodedPngImage\"\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.jvm.JvmOverloads\n\nclass Font @JvmOverloads constructor(val family: FontFamily, val size: Int, val isBold: Boolean = false, val isItalic: Boolean = false) {\n\n    override fun toString(): String {\n        return \"$family $size ${if (isBold) \"bold\" else \"\"} ${if (isItalic) \"italic\" else \"\"}\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other !is Font) return false\n        return family === other.family &&\n                size == other.size &&\n                isBold == other.isBold &&\n                isItalic == other.isItalic\n    }\n\n    override fun hashCode(): Int {\n        var result = family.hashCode()\n        result = 31 * result + size\n        result = 31 * result + if (isBold) 1 else 0\n        result = 31 * result + if (isItalic) 1 else 0\n        return result\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nclass FontFamily private constructor(private val myName: String) {\n\n    override fun toString(): String {\n        return myName\n    }\n\n    companion object {\n        val MONOSPACED = forName(\"monospace\")\n        val SERIF = forName(\"serif\")\n\n        fun forName(name: String): FontFamily {\n            return FontFamily(name)\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.math.abs\n\n/**\n * @param h hue, degree. Normal range: [0, 360]\n * @param saturation saturation, [0, 1]\n * @param value value, [0, 1]\n */\nclass HSV(val h: Double, saturation: Double, value: Double = 1.0) {\n    val s: Double\n    val v: Double\n\n    init {\n        require(saturation >= -0.001 && saturation <= 1.001) { \"HSV 'saturation' must be in range [0, 1] but was $saturation\" }\n        require(value >= -0.001 && value <= 1.001) { \"HSV 'value' must be in range [0, 1] but was $value\" }\n\n        s = abs((saturation * 100).toInt() / 100.0)\n        v = abs((value * 100).toInt() / 100.0)\n    }\n\n    override fun toString(): String {\n        return \"HSV($h, $s, $v)\"\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass Interval(val lowerBound: Int, val upperBound: Int) {\n\n    val length: Int\n        get() = upperBound - lowerBound\n\n    init {\n        if (lowerBound > upperBound) {\n            throw IllegalArgumentException(\"Lower bound is greater than upper: lower bound=\" + lowerBound\n                    + \", upper bound=\" + upperBound)\n        }\n    }\n\n    operator fun contains(point: Int): Boolean {\n        return lowerBound <= point && point <= upperBound\n    }\n\n    operator fun contains(other: Interval): Boolean {\n        return contains(other.lowerBound) && contains(other.upperBound)\n    }\n\n    fun intersects(other: Interval): Boolean {\n        return contains(other.lowerBound) || other.contains(lowerBound)\n    }\n\n    /**\n     * Returns minimal interval that contains both this and other intervals.\n     */\n    fun union(other: Interval): Interval {\n        return Interval(min(lowerBound, other.lowerBound), max(upperBound, other.upperBound))\n    }\n\n    fun add(delta: Int): Interval {\n        return Interval(lowerBound + delta, upperBound + delta)\n    }\n\n    fun sub(delta: Int): Interval {\n        return Interval(lowerBound - delta, upperBound - delta)\n    }\n\n    override fun toString(): String {\n        return \"[$lowerBound, $upperBound]\"\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other !is Interval) return false\n\n        val interval = other as Interval?\n        return if (lowerBound != interval!!.lowerBound) false else upperBound == interval.upperBound\n    }\n\n    override fun hashCode(): Int {\n        var result = lowerBound\n        result = 31 * result + upperBound\n        return result\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.values\n\n// ToDo: use Kotlin Pair\nclass Pair<FirstT, SecondT>(val first: FirstT, val second: SecondT) {\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as Pair<*, *>\n\n        if (first != other.first) return false\n        if (second != other.second) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = first?.hashCode() ?: 0\n        result = 31 * result + (second?.hashCode() ?: 0)\n        return result\n    }\n\n    override fun toString(): String {\n        return \"[$first, $second]\"\n    }\n\n    operator fun component1() = first\n    operator fun component2() = second\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o. \n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.logging\n\nimport mu.KotlinLogging\nimport kotlin.reflect.KClass\n\nactual object PortableLogging {\n    actual fun logger(cl: KClass<*>): Logger {\n        val kl = KotlinLogging.logger(cl.simpleName ?: \"<anonymous>\")\n        return object : Logger {\n            override fun error(e: Throwable, message: () -> String) {\n                kl.error(e, message)\n            }\n\n            override fun info(message: () -> String) {\n                kl.info(message)\n            }\n        }\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.base.spatial\n\nconst val EARTH_RADIUS = 6378137.0\nconst val MIN_LONGITUDE = -180.0\nconst val MAX_LONGITUDE = 180.0\nconst val FULL_LONGITUDE = MAX_LONGITUDE - MIN_LONGITUDE\nconst val MIN_LATITUDE = -90.0\nconst val MAX_LATITUDE = 90.0\nconst val FULL_LATITUDE = MAX_LATITUDE - MIN_LATITUDE\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-base-portable.js\n"); /***/ }), @@ -155,7 +155,7 @@ eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPAC \********************************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-plot-common-portable */ \"./kotlin-dce-dev/lets-plot-plot-common-portable.js\"), __webpack_require__(/*! lets-plot-vis-svg-portable */ \"./kotlin-dce-dev/lets-plot-vis-svg-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_base_portable, $module$lets_plot_plot_common_portable, $module$lets_plot_vis_svg_portable) {\n 'use strict';\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var Iterable = Kotlin.kotlin.collections.Iterable;\n var throwCCE = Kotlin.throwCCE;\n var equals = Kotlin.equals;\n var List = Kotlin.kotlin.collections.List;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var TypedKey = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKey;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var ensureNotNull = Kotlin.ensureNotNull;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var LinkedHashSet_init = Kotlin.kotlin.collections.LinkedHashSet_init_mqih57$;\n var Collection = Kotlin.kotlin.collections.Collection;\n var data = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.data;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var zip = Kotlin.kotlin.collections.zip_45mdf7$;\n var getCallableRef = Kotlin.getCallableRef;\n var toList = Kotlin.kotlin.collections.toList_abgq59$;\n var compareBy = Kotlin.kotlin.comparisons.compareBy_bvgy4j$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var reversed = Kotlin.kotlin.collections.reversed_7wnvza$;\n var plus = Kotlin.kotlin.collections.plus_mydzjv$;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var logging = $module$lets_plot_base_portable.jetbrains.datalore.base.logging;\n var getKClass = Kotlin.getKClass;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_73mtqc$;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var MutableCollection = Kotlin.kotlin.collections.MutableCollection;\n var toString = Kotlin.toString;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var TreeMap = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.TreeMap;\n var intersect = Kotlin.kotlin.collections.intersect_q4559j$;\n var Map = Kotlin.kotlin.collections.Map;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var JsMath = Math;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var Unit = Kotlin.kotlin.Unit;\n var TypedKeyHashMap = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKeyHashMap;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var NoSuchElementException = Kotlin.kotlin.NoSuchElementException;\n var Iterator = Kotlin.kotlin.collections.Iterator;\n var Function = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Function;\n var values = $module$lets_plot_base_portable.jetbrains.datalore.base.values;\n var svg = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg;\n var DoubleVector = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleVector;\n var geometry = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var Comparator = Kotlin.kotlin.Comparator;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var base = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.base;\n var startsWith = Kotlin.kotlin.text.startsWith_7epoxm$;\n var Regex_init = Kotlin.kotlin.text.Regex_init_61zpoe$;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_ww73n8$;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var Any = Object;\n var DoubleRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle;\n var DoubleRectangle_init = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$;\n var SvgLineElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement_init_6y0v78$;\n var SvgGElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGElement;\n var slim = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.slim;\n var SvgRectElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_6y0v78$;\n var SvgImageElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElement_init_6y0v78$;\n var throwUPAE = Kotlin.throwUPAE;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var SvgPathDataBuilder = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathDataBuilder;\n var math = Kotlin.kotlin.math;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var numberToInt = Kotlin.numberToInt;\n var SvgImageElementEx$Bitmap = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElementEx.Bitmap;\n var SvgImageElementEx = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElementEx;\n var SvgPathElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathElement_init_7jrsat$;\n var SvgShape = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgShape;\n var SvgElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgElement;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var copyToArray = Kotlin.kotlin.collections.copyToArray;\n var splitRings = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.splitRings_bemo1h$;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var SvgRectElement_init_0 = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_wthzt5$;\n var emptyMap = Kotlin.kotlin.collections.emptyMap_q3lmfv$;\n var Random = Kotlin.kotlin.random.Random;\n var asList = Kotlin.kotlin.collections.asList_us0mfu$;\n var SvgSlimObject = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.slim.SvgSlimObject;\n var SvgPathData = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathData;\n var SvgPathDataBuilder$Interpolation = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathDataBuilder.Interpolation;\n var WritableProperty = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property.WritableProperty;\n var SvgColors = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgColors;\n var EventHandler = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventHandler;\n var CompositeRegistration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.CompositeRegistration;\n var SvgClipPathElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgClipPathElement;\n var SvgRectElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement;\n var SvgDefsElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgDefsElement;\n var SvgIRI = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgIRI;\n var SvgGraphicsElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGraphicsElement;\n var SvgTransformBuilder = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgTransformBuilder;\n var random = $module$lets_plot_base_portable.jetbrains.datalore.base.random;\n var SvgTextElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgTextElement_init_61zpoe$;\n var isBlank = Kotlin.kotlin.text.isBlank_gw00vp$;\n var numberToDouble = Kotlin.numberToDouble;\n var Pair_0 = Kotlin.kotlin.Pair;\n var toMap = Kotlin.kotlin.collections.toMap_6hr0sd$;\n var getValue = Kotlin.kotlin.collections.getValue_t9ocha$;\n var toList_0 = Kotlin.kotlin.collections.toList_7wnvza$;\n var checkIndexOverflow = Kotlin.kotlin.collections.checkIndexOverflow_za3lpa$;\n var isInfinite = Kotlin.kotlin.isInfinite_yrwdxr$;\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var YearInterval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval.YearInterval;\n var time = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time;\n var interval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_mh5how$;\n var asReversed = Kotlin.kotlin.collections.asReversed_2p1efm$;\n var NumberFormat_init = $module$lets_plot_base_portable.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$;\n var text = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.text;\n var TimeInterval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval.TimeInterval;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var last = Kotlin.kotlin.collections.last_2p1efm$;\n var filterNotNull = Kotlin.kotlin.collections.filterNotNull_m3lr2h$;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var abs = Kotlin.kotlin.math.abs_za3lpa$;\n var maxOrNull = Kotlin.kotlin.collections.maxOrNull_l63kqw$;\n var mutableMapOf = Kotlin.kotlin.collections.mutableMapOf_qfcya0$;\n var HashSet_init_1 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var sortWith = Kotlin.kotlin.collections.sortWith_nqfjgj$;\n var hashCode = Kotlin.hashCode;\n var rangeTo = Kotlin.kotlin.ranges.rangeTo_38ydlf$;\n var withIndex = Kotlin.kotlin.collections.withIndex_7wnvza$;\n var LinkedHashSet_init_0 = Kotlin.kotlin.collections.LinkedHashSet_init_287e2$;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var unzip = Kotlin.kotlin.collections.unzip_6hr0sd$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var sum = Kotlin.kotlin.collections.sum_l63kqw$;\n var wrapFunction = Kotlin.wrapFunction;\n var Array_0 = Array;\n var L37 = Kotlin.Long.fromInt(37);\n var Random_0 = Kotlin.kotlin.random.Random_s8cxhz$;\n var coerceIn = Kotlin.kotlin.ranges.coerceIn_nig4hr$;\n var L_38038050983108802 = new Kotlin.Long(456400702, -8856424);\n var arrayCopy = Kotlin.kotlin.collections.arrayCopy;\n var average = Kotlin.kotlin.collections.average_bvy38s$;\n var arrayListOf = Kotlin.kotlin.collections.arrayListOf_i5x0yv$;\n var fill = Kotlin.kotlin.collections.fill_x4f2cq$;\n var sort = Kotlin.primitiveArraySort;\n var fill_0 = Kotlin.kotlin.collections.fill_tpuxuu$;\n var get_lastIndex = Kotlin.kotlin.collections.get_lastIndex_bvy38s$;\n var get_indices = Kotlin.kotlin.collections.get_indices_bvy38s$;\n var reversed_0 = Kotlin.kotlin.ranges.reversed_zf1xzc$;\n var toMutableList_0 = Kotlin.kotlin.collections.toMutableList_bvy38s$;\n var isNaN_1 = Kotlin.kotlin.isNaN_81szk$;\n var toBits = Kotlin.floatToBits;\n var toBits_0 = Kotlin.doubleToBits;\n var abs_0 = Kotlin.kotlin.math.abs_s8cxhz$;\n var L_2147483648 = Kotlin.Long.fromInt(-2147483648);\n var L_5852615386664158222 = new Kotlin.Long(1994767346, -1362668208);\n var zip_0 = Kotlin.kotlin.collections.zip_pmvpm9$;\n var toDoubleArray = Kotlin.kotlin.collections.toDoubleArray_tcduak$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var zip_1 = Kotlin.kotlin.sequences.zip_r7q3s9$;\n var drop = Kotlin.kotlin.sequences.drop_wuwhe2$;\n DataFrame$Variable$Source.prototype = Object.create(Enum.prototype);\n DataFrame$Variable$Source.prototype.constructor = DataFrame$Variable$Source;\n GeomKind.prototype = Object.create(Enum.prototype);\n GeomKind.prototype.constructor = GeomKind;\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$bar$ObjectLiteral;\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$histogram$ObjectLiteral;\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$area$ObjectLiteral;\n TransformVar$TransformVarByAes.prototype = Object.create(AesVisitor.prototype);\n TransformVar$TransformVarByAes.prototype.constructor = TransformVar$TransformVarByAes;\n ABLineGeom.prototype = Object.create(GeomBase.prototype);\n ABLineGeom.prototype.constructor = ABLineGeom;\n AreaGeom.prototype = Object.create(GeomBase.prototype);\n AreaGeom.prototype.constructor = AreaGeom;\n BarGeom.prototype = Object.create(GeomBase.prototype);\n BarGeom.prototype.constructor = BarGeom;\n TileGeom.prototype = Object.create(GeomBase.prototype);\n TileGeom.prototype.constructor = TileGeom;\n Bin2dGeom.prototype = Object.create(TileGeom.prototype);\n Bin2dGeom.prototype.constructor = Bin2dGeom;\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype = Object.create(DataPointAestheticsDelegate.prototype);\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.constructor = BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral;\n BoxplotGeom.prototype = Object.create(GeomBase.prototype);\n BoxplotGeom.prototype.constructor = BoxplotGeom;\n PathGeom.prototype = Object.create(GeomBase.prototype);\n PathGeom.prototype.constructor = PathGeom;\n ContourGeom.prototype = Object.create(PathGeom.prototype);\n ContourGeom.prototype.constructor = ContourGeom;\n PolygonGeom.prototype = Object.create(GeomBase.prototype);\n PolygonGeom.prototype.constructor = PolygonGeom;\n ContourfGeom.prototype = Object.create(PolygonGeom.prototype);\n ContourfGeom.prototype.constructor = ContourfGeom;\n CrossBarGeom.prototype = Object.create(GeomBase.prototype);\n CrossBarGeom.prototype.constructor = CrossBarGeom;\n Density2dGeom.prototype = Object.create(ContourGeom.prototype);\n Density2dGeom.prototype.constructor = Density2dGeom;\n Density2dfGeom.prototype = Object.create(ContourfGeom.prototype);\n Density2dfGeom.prototype.constructor = Density2dfGeom;\n DensityGeom.prototype = Object.create(AreaGeom.prototype);\n DensityGeom.prototype.constructor = DensityGeom;\n ErrorBarGeom.prototype = Object.create(GeomBase.prototype);\n ErrorBarGeom.prototype.constructor = ErrorBarGeom;\n LineGeom.prototype = Object.create(PathGeom.prototype);\n LineGeom.prototype.constructor = LineGeom;\n FreqpolyGeom.prototype = Object.create(LineGeom.prototype);\n FreqpolyGeom.prototype.constructor = FreqpolyGeom;\n HLineGeom.prototype = Object.create(GeomBase.prototype);\n HLineGeom.prototype.constructor = HLineGeom;\n HistogramGeom.prototype = Object.create(BarGeom.prototype);\n HistogramGeom.prototype.constructor = HistogramGeom;\n ImageGeom.prototype = Object.create(GeomBase.prototype);\n ImageGeom.prototype.constructor = ImageGeom;\n PointGeom.prototype = Object.create(GeomBase.prototype);\n PointGeom.prototype.constructor = PointGeom;\n JitterGeom.prototype = Object.create(PointGeom.prototype);\n JitterGeom.prototype.constructor = JitterGeom;\n LineRangeGeom.prototype = Object.create(GeomBase.prototype);\n LineRangeGeom.prototype.constructor = LineRangeGeom;\n MapGeom.prototype = Object.create(PolygonGeom.prototype);\n MapGeom.prototype.constructor = MapGeom;\n LinesHelper.prototype = Object.create(GeomHelper.prototype);\n LinesHelper.prototype.constructor = LinesHelper;\n PieGeom$PieHelper.prototype = Object.create(LinesHelper.prototype);\n PieGeom$PieHelper.prototype.constructor = PieGeom$PieHelper;\n PieGeom.prototype = Object.create(GeomBase.prototype);\n PieGeom.prototype.constructor = PieGeom;\n PointRangeGeom.prototype = Object.create(GeomBase.prototype);\n PointRangeGeom.prototype.constructor = PointRangeGeom;\n RasterGeom.prototype = Object.create(GeomBase.prototype);\n RasterGeom.prototype.constructor = RasterGeom;\n RectGeom.prototype = Object.create(GeomBase.prototype);\n RectGeom.prototype.constructor = RectGeom;\n RibbonGeom.prototype = Object.create(GeomBase.prototype);\n RibbonGeom.prototype.constructor = RibbonGeom;\n SegmentGeom.prototype = Object.create(GeomBase.prototype);\n SegmentGeom.prototype.constructor = SegmentGeom;\n SmoothGeom.prototype = Object.create(GeomBase.prototype);\n SmoothGeom.prototype.constructor = SmoothGeom;\n StepGeom$Direction.prototype = Object.create(Enum.prototype);\n StepGeom$Direction.prototype.constructor = StepGeom$Direction;\n StepGeom.prototype = Object.create(LineGeom.prototype);\n StepGeom.prototype.constructor = StepGeom;\n TextGeom.prototype = Object.create(GeomBase.prototype);\n TextGeom.prototype.constructor = TextGeom;\n VLineGeom.prototype = Object.create(GeomBase.prototype);\n VLineGeom.prototype.constructor = VLineGeom;\n ArrowSpec$toArrowAes$ObjectLiteral.prototype = Object.create(DataPointAestheticsDelegate.prototype);\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.constructor = ArrowSpec$toArrowAes$ObjectLiteral;\n ArrowSpec$End.prototype = Object.create(Enum.prototype);\n ArrowSpec$End.prototype.constructor = ArrowSpec$End;\n ArrowSpec$Type.prototype = Object.create(Enum.prototype);\n ArrowSpec$Type.prototype.constructor = ArrowSpec$Type;\n RectanglesHelper.prototype = Object.create(GeomHelper.prototype);\n RectanglesHelper.prototype.constructor = RectanglesHelper;\n GeomTargetLocator$LookupSpace.prototype = Object.create(Enum.prototype);\n GeomTargetLocator$LookupSpace.prototype.constructor = GeomTargetLocator$LookupSpace;\n GeomTargetLocator$LookupStrategy.prototype = Object.create(Enum.prototype);\n GeomTargetLocator$LookupStrategy.prototype.constructor = GeomTargetLocator$LookupStrategy;\n HitShape$Kind.prototype = Object.create(Enum.prototype);\n HitShape$Kind.prototype.constructor = HitShape$Kind;\n HitShape$Companion$shapeWithPath$ObjectLiteral.prototype = Object.create(HitShape.prototype);\n HitShape$Companion$shapeWithPath$ObjectLiteral.prototype.constructor = HitShape$Companion$shapeWithPath$ObjectLiteral;\n TipLayoutHint$StemLength.prototype = Object.create(Enum.prototype);\n TipLayoutHint$StemLength.prototype.constructor = TipLayoutHint$StemLength;\n TipLayoutHint$Kind.prototype = Object.create(Enum.prototype);\n TipLayoutHint$Kind.prototype.constructor = TipLayoutHint$Kind;\n TooltipAnchor$VerticalAnchor.prototype = Object.create(Enum.prototype);\n TooltipAnchor$VerticalAnchor.prototype.constructor = TooltipAnchor$VerticalAnchor;\n TooltipAnchor$HorizontalAnchor.prototype = Object.create(Enum.prototype);\n TooltipAnchor$HorizontalAnchor.prototype.constructor = TooltipAnchor$HorizontalAnchor;\n LivemapConstants$DisplayMode.prototype = Object.create(Enum.prototype);\n LivemapConstants$DisplayMode.prototype.constructor = LivemapConstants$DisplayMode;\n LivemapConstants$Theme.prototype = Object.create(Enum.prototype);\n LivemapConstants$Theme.prototype.constructor = LivemapConstants$Theme;\n LivemapConstants$Projection.prototype = Object.create(Enum.prototype);\n LivemapConstants$Projection.prototype.constructor = LivemapConstants$Projection;\n PositionAdjustments$Meta.prototype = Object.create(Enum.prototype);\n PositionAdjustments$Meta.prototype.constructor = PositionAdjustments$Meta;\n PositionAdjustments$StackingStrategy.prototype = Object.create(Enum.prototype);\n PositionAdjustments$StackingStrategy.prototype.constructor = PositionAdjustments$StackingStrategy;\n StackPos$SplitPositiveNegative.prototype = Object.create(StackPos.prototype);\n StackPos$SplitPositiveNegative.prototype.constructor = StackPos$SplitPositiveNegative;\n StackPos$SumPositiveNegative.prototype = Object.create(StackPos.prototype);\n StackPos$SumPositiveNegative.prototype.constructor = StackPos$SumPositiveNegative;\n NamedLineType.prototype = Object.create(Enum.prototype);\n NamedLineType.prototype.constructor = NamedLineType;\n NamedLineType$BLANK.prototype = Object.create(NamedLineType.prototype);\n NamedLineType$BLANK.prototype.constructor = NamedLineType$BLANK;\n NamedLineType$SOLID.prototype = Object.create(NamedLineType.prototype);\n NamedLineType$SOLID.prototype.constructor = NamedLineType$SOLID;\n NamedShape.prototype = Object.create(Enum.prototype);\n NamedShape.prototype.constructor = NamedShape;\n CircleGlyph.prototype = Object.create(SingletonGlyph.prototype);\n CircleGlyph.prototype.constructor = CircleGlyph;\n TwoShapeGlyph.prototype = Object.create(MultiShapeGlyph.prototype);\n TwoShapeGlyph.prototype.constructor = TwoShapeGlyph;\n CrossGlyph.prototype = Object.create(TwoShapeGlyph.prototype);\n CrossGlyph.prototype.constructor = CrossGlyph;\n DiamondGlyph.prototype = Object.create(SingletonGlyph.prototype);\n DiamondGlyph.prototype.constructor = DiamondGlyph;\n PlusGlyph.prototype = Object.create(TwoShapeGlyph.prototype);\n PlusGlyph.prototype.constructor = PlusGlyph;\n SquareGlyph.prototype = Object.create(SingletonGlyph.prototype);\n SquareGlyph.prototype.constructor = SquareGlyph;\n TriangleGlyph.prototype = Object.create(SingletonGlyph.prototype);\n TriangleGlyph.prototype.constructor = TriangleGlyph;\n GroupComponent.prototype = Object.create(SvgComponent.prototype);\n GroupComponent.prototype.constructor = GroupComponent;\n LinePath.prototype = Object.create(SvgComponent.prototype);\n LinePath.prototype.constructor = LinePath;\n TextLabel$HorizontalAnchor.prototype = Object.create(Enum.prototype);\n TextLabel$HorizontalAnchor.prototype.constructor = TextLabel$HorizontalAnchor;\n TextLabel$VerticalAnchor.prototype = Object.create(Enum.prototype);\n TextLabel$VerticalAnchor.prototype.constructor = TextLabel$VerticalAnchor;\n TextLabel.prototype = Object.create(SvgComponent.prototype);\n TextLabel.prototype.constructor = TextLabel;\n ContinuousScale$MyBuilder.prototype = Object.create(AbstractScale$AbstractBuilder.prototype);\n ContinuousScale$MyBuilder.prototype.constructor = ContinuousScale$MyBuilder;\n ContinuousScale.prototype = Object.create(AbstractScale.prototype);\n ContinuousScale.prototype.constructor = ContinuousScale;\n DiscreteScale$MyBuilder.prototype = Object.create(AbstractScale$AbstractBuilder.prototype);\n DiscreteScale$MyBuilder.prototype.constructor = DiscreteScale$MyBuilder;\n DiscreteScale.prototype = Object.create(AbstractScale.prototype);\n DiscreteScale.prototype.constructor = DiscreteScale;\n DateTimeBreaksHelper.prototype = Object.create(BreaksHelperBase.prototype);\n DateTimeBreaksHelper.prototype.constructor = DateTimeBreaksHelper;\n LinearBreaksHelper.prototype = Object.create(BreaksHelperBase.prototype);\n LinearBreaksHelper.prototype.constructor = LinearBreaksHelper;\n IdentityTransform.prototype = Object.create(FunTransform.prototype);\n IdentityTransform.prototype.constructor = IdentityTransform;\n Log10Transform.prototype = Object.create(FunTransform.prototype);\n Log10Transform.prototype.constructor = Log10Transform;\n ReverseTransform.prototype = Object.create(FunTransform.prototype);\n ReverseTransform.prototype.constructor = ReverseTransform;\n SqrtTransform.prototype = Object.create(FunTransform.prototype);\n SqrtTransform.prototype.constructor = SqrtTransform;\n AbstractDensity2dStat.prototype = Object.create(BaseStat.prototype);\n AbstractDensity2dStat.prototype.constructor = AbstractDensity2dStat;\n Bin2dStat.prototype = Object.create(BaseStat.prototype);\n Bin2dStat.prototype.constructor = Bin2dStat;\n BinStat$XPosKind.prototype = Object.create(Enum.prototype);\n BinStat$XPosKind.prototype.constructor = BinStat$XPosKind;\n BinStat.prototype = Object.create(BaseStat.prototype);\n BinStat.prototype.constructor = BinStat;\n BoxplotStat.prototype = Object.create(BaseStat.prototype);\n BoxplotStat.prototype.constructor = BoxplotStat;\n ContourFillHelper$BorderKind.prototype = Object.create(Enum.prototype);\n ContourFillHelper$BorderKind.prototype.constructor = ContourFillHelper$BorderKind;\n ContourStat.prototype = Object.create(BaseStat.prototype);\n ContourStat.prototype.constructor = ContourStat;\n ContourfStat.prototype = Object.create(BaseStat.prototype);\n ContourfStat.prototype.constructor = ContourfStat;\n CorrelationStat$Method.prototype = Object.create(Enum.prototype);\n CorrelationStat$Method.prototype.constructor = CorrelationStat$Method;\n CorrelationStat$Type.prototype = Object.create(Enum.prototype);\n CorrelationStat$Type.prototype.constructor = CorrelationStat$Type;\n CorrelationStat.prototype = Object.create(BaseStat.prototype);\n CorrelationStat.prototype.constructor = CorrelationStat;\n CountStat.prototype = Object.create(BaseStat.prototype);\n CountStat.prototype.constructor = CountStat;\n Density2dStat.prototype = Object.create(AbstractDensity2dStat.prototype);\n Density2dStat.prototype.constructor = Density2dStat;\n Density2dfStat.prototype = Object.create(AbstractDensity2dStat.prototype);\n Density2dfStat.prototype.constructor = Density2dfStat;\n DensityStat$Kernel.prototype = Object.create(Enum.prototype);\n DensityStat$Kernel.prototype.constructor = DensityStat$Kernel;\n DensityStat$BandWidthMethod.prototype = Object.create(Enum.prototype);\n DensityStat$BandWidthMethod.prototype.constructor = DensityStat$BandWidthMethod;\n DensityStat.prototype = Object.create(BaseStat.prototype);\n DensityStat.prototype.constructor = DensityStat;\n SmoothStat$Method.prototype = Object.create(Enum.prototype);\n SmoothStat$Method.prototype.constructor = SmoothStat$Method;\n SmoothStat.prototype = Object.create(BaseStat.prototype);\n SmoothStat.prototype.constructor = SmoothStat;\n Stats$IdentityStat.prototype = Object.create(BaseStat.prototype);\n Stats$IdentityStat.prototype.constructor = Stats$IdentityStat;\n AbstractUnivariateSolver.prototype = Object.create(BaseAbstractUnivariateSolver.prototype);\n AbstractUnivariateSolver.prototype.constructor = AbstractUnivariateSolver;\n AllowedSolution.prototype = Object.create(Enum.prototype);\n AllowedSolution.prototype.constructor = AllowedSolution;\n Beta$regularizedBeta$ObjectLiteral.prototype = Object.create(ContinuedFraction.prototype);\n Beta$regularizedBeta$ObjectLiteral.prototype.constructor = Beta$regularizedBeta$ObjectLiteral;\n BrentSolver.prototype = Object.create(AbstractUnivariateSolver.prototype);\n BrentSolver.prototype.constructor = BrentSolver;\n Gamma$regularizedGammaQ$ObjectLiteral.prototype = Object.create(ContinuedFraction.prototype);\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.constructor = Gamma$regularizedGammaQ$ObjectLiteral;\n MathArrays$OrderDirection.prototype = Object.create(Enum.prototype);\n MathArrays$OrderDirection.prototype.constructor = MathArrays$OrderDirection;\n TDistribution.prototype = Object.create(AbstractRealDistribution.prototype);\n TDistribution.prototype.constructor = TDistribution;\n LinearRegression.prototype = Object.create(RegressionEvaluator.prototype);\n LinearRegression.prototype.constructor = LinearRegression;\n LocalPolynomialRegression.prototype = Object.create(RegressionEvaluator.prototype);\n LocalPolynomialRegression.prototype.constructor = LocalPolynomialRegression;\n PolynomialRegression.prototype = Object.create(RegressionEvaluator.prototype);\n PolynomialRegression.prototype.constructor = PolynomialRegression;\n function Aes(name, isNumeric) {\n Aes$Companion_getInstance();\n if (isNumeric === void 0)\n isNumeric = true;\n this.name = name;\n this.isNumeric = isNumeric;\n Aes$Companion_getInstance().values_0.add_11rb$(this);\n }\n Object.defineProperty(Aes.prototype, 'isColor', {\n configurable: true,\n get: function () {\n return Aes$Companion_getInstance().isColor_896ixz$(this);\n }\n });\n Aes.prototype.toString = function () {\n return \"aes '\" + this.name + \"'\";\n };\n function Aes$Companion() {\n Aes$Companion_instance = this;\n this.values_0 = ArrayList_init();\n this.X = new Aes('x');\n this.Y = new Aes('y');\n this.Z = new Aes('z');\n this.COLOR = new Aes('color', false);\n this.FILL = new Aes('fill', false);\n this.ALPHA = new Aes('alpha');\n this.SHAPE = new Aes('shape', false);\n this.LINETYPE = new Aes('linetype', false);\n this.SIZE = new Aes('size');\n this.WIDTH = new Aes('width');\n this.HEIGHT = new Aes('height');\n this.WEIGHT = new Aes('weight');\n this.INTERCEPT = new Aes('intercept');\n this.SLOPE = new Aes('slope');\n this.XINTERCEPT = new Aes('xintercept');\n this.YINTERCEPT = new Aes('yintercept');\n this.LOWER = new Aes('lower');\n this.MIDDLE = new Aes('middle');\n this.UPPER = new Aes('upper');\n this.XMIN = new Aes('xmin');\n this.XMAX = new Aes('xmax');\n this.YMIN = new Aes('ymin');\n this.YMAX = new Aes('ymax');\n this.XEND = new Aes('xend');\n this.YEND = new Aes('yend');\n this.FRAME = new Aes('frame', false);\n this.SPEED = new Aes('speed');\n this.FLOW = new Aes('flow');\n this.LABEL = new Aes('label', false);\n this.FAMILY = new Aes('family', false);\n this.FONTFACE = new Aes('fontface', false);\n this.HJUST = new Aes('hjust', false);\n this.VJUST = new Aes('vjust', false);\n this.ANGLE = new Aes('angle');\n this.SYM_X = new Aes('sym_x');\n this.SYM_Y = new Aes('sym_y');\n }\n function Aes$Companion$numeric$lambda(aes) {\n return aes.isNumeric;\n }\n Aes$Companion.prototype.numeric_shhb9a$ = function (unfiltered) {\n var tmp$;\n return Kotlin.isType(tmp$ = collect.Iterables.filter_fpit1u$(unfiltered, Aes$Companion$numeric$lambda), Iterable) ? tmp$ : throwCCE();\n };\n Aes$Companion.prototype.isPositional_896ixz$ = function (aes) {\n return this.isPositionalXY_896ixz$(aes) || equals(aes, this.SLOPE);\n };\n Aes$Companion.prototype.isPositionalXY_896ixz$ = function (aes) {\n return this.isPositionalX_896ixz$(aes) || this.isPositionalY_896ixz$(aes);\n };\n Aes$Companion.prototype.isPositionalX_896ixz$ = function (aes) {\n return equals(aes, this.X) || equals(aes, this.XINTERCEPT) || equals(aes, this.XMIN) || equals(aes, this.XMAX) || equals(aes, this.XEND);\n };\n Aes$Companion.prototype.isPositionalY_896ixz$ = function (aes) {\n return equals(aes, this.Y) || equals(aes, this.YMIN) || equals(aes, this.YMAX) || equals(aes, this.INTERCEPT) || equals(aes, this.YINTERCEPT) || equals(aes, this.LOWER) || equals(aes, this.MIDDLE) || equals(aes, this.UPPER) || equals(aes, this.YEND);\n };\n Aes$Companion.prototype.isColor_896ixz$ = function (aes) {\n return equals(aes, this.COLOR) || equals(aes, this.FILL);\n };\n Aes$Companion.prototype.isAffectingScaleX_896ixz$ = function (aes) {\n return this.isPositionalX_896ixz$(aes);\n };\n Aes$Companion.prototype.isAffectingScaleY_896ixz$ = function (aes) {\n return this.isPositionalY_896ixz$(aes) && !equals(aes, this.INTERCEPT);\n };\n function Aes$Companion$affectingScaleX$lambda(this$Aes$) {\n return function (it) {\n return this$Aes$.isAffectingScaleX_896ixz$(it);\n };\n }\n Aes$Companion.prototype.affectingScaleX_shhb9a$ = function (unfiltered) {\n var numeric = this.numeric_shhb9a$(unfiltered);\n return collect.Iterables.filter_fpit1u$(numeric, Aes$Companion$affectingScaleX$lambda(this));\n };\n function Aes$Companion$affectingScaleY$lambda(this$Aes$) {\n return function (it) {\n return this$Aes$.isAffectingScaleY_896ixz$(it);\n };\n }\n Aes$Companion.prototype.affectingScaleY_shhb9a$ = function (unfiltered) {\n var numeric = this.numeric_shhb9a$(unfiltered);\n return collect.Iterables.filter_fpit1u$(numeric, Aes$Companion$affectingScaleY$lambda(this));\n };\n Aes$Companion.prototype.noGuideNeeded_896ixz$ = function (aes) {\n return equals(aes, this.FRAME) || equals(aes, this.SPEED) || equals(aes, this.FLOW) || equals(aes, this.LABEL) || equals(aes, this.SLOPE) || equals(aes, this.WIDTH) || equals(aes, this.HEIGHT) || equals(aes, this.HJUST) || equals(aes, this.VJUST) || equals(aes, this.ANGLE) || equals(aes, this.FAMILY) || equals(aes, this.FONTFACE) || equals(aes, this.SYM_X) || equals(aes, this.SYM_Y) || this.isPositional_896ixz$(aes);\n };\n Aes$Companion.prototype.values = function () {\n return this.values_0;\n };\n Aes$Companion.prototype.allPositional = function () {\n var tmp$;\n var $receiver = this.values_0;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (this.isPositional_896ixz$(element))\n destination.add_11rb$(element);\n }\n return Kotlin.isType(tmp$ = destination, List) ? tmp$ : throwCCE();\n };\n Aes$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Aes$Companion_instance = null;\n function Aes$Companion_getInstance() {\n if (Aes$Companion_instance === null) {\n new Aes$Companion();\n }return Aes$Companion_instance;\n }\n Aes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Aes',\n interfaces: [TypedKey]\n };\n function Aesthetics() {\n }\n Aesthetics.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Aesthetics',\n interfaces: []\n };\n function ContinuousTransform() {\n }\n ContinuousTransform.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ContinuousTransform',\n interfaces: [Transform]\n };\n function CoordinateSystem() {\n }\n CoordinateSystem.prototype.isPointInLimits_k2qmv6$ = function (p, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(p, isClient) : this.isPointInLimits_k2qmv6$$default(p, isClient);\n };\n CoordinateSystem.prototype.isRectInLimits_fd842m$ = function (rect, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(rect, isClient) : this.isRectInLimits_fd842m$$default(rect, isClient);\n };\n CoordinateSystem.prototype.isPathInLimits_f6t8kh$ = function (path, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(path, isClient) : this.isPathInLimits_f6t8kh$$default(path, isClient);\n };\n CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = function (polygon, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(polygon, isClient) : this.isPolygonInLimits_f6t8kh$$default(polygon, isClient);\n };\n CoordinateSystem.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CoordinateSystem',\n interfaces: []\n };\n function DataFrame(builder) {\n DataFrame$Companion_getInstance();\n this.myVectorByVar_0 = null;\n this.myIsNumeric_0 = null;\n this.myRanges_0 = HashMap_init();\n this.myDistinctValues_0 = HashMap_init();\n this.myOrderSpecs_0 = null;\n this.assertAllSeriesAreSameSize_0(builder.myVectorByVar_8be2vx$);\n this.myVectorByVar_0 = HashMap_init_0(builder.myVectorByVar_8be2vx$);\n this.myIsNumeric_0 = HashMap_init_0(builder.myIsNumeric_8be2vx$);\n this.myOrderSpecs_0 = builder.myOrderSpecs_8be2vx$;\n var tmp$;\n tmp$ = this.myOrderSpecs_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var $receiver = this.myDistinctValues_0;\n var key = element.variable;\n var value = this.getOrderedDistinctValues_0(element);\n $receiver.put_xwzc9p$(key, value);\n }\n }\n function DataFrame$OrderSpec(variable, orderBy, direction, aggregateOperation) {\n if (aggregateOperation === void 0)\n aggregateOperation = null;\n this.variable = variable;\n this.orderBy = orderBy;\n this.direction = direction;\n this.aggregateOperation = aggregateOperation;\n }\n DataFrame$OrderSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderSpec',\n interfaces: []\n };\n Object.defineProperty(DataFrame.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myVectorByVar_0.isEmpty();\n }\n });\n DataFrame.prototype.assertAllSeriesAreSameSize_0 = function (vectorByVar) {\n if (vectorByVar.size > 1) {\n var entries = vectorByVar.entries.iterator();\n var first = entries.next();\n var size = first.value.size;\n while (entries.hasNext()) {\n var next = entries.next();\n if (next.value.size !== size) {\n throw IllegalArgumentException_init('All data series in data frame must have equal size\\n' + this.dumpSizes_0(vectorByVar));\n }}\n }};\n DataFrame.prototype.dumpSizes_0 = function (vectorByVar) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = vectorByVar.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var key = tmp$_0.key;\n var value = tmp$_0.value;\n sb.append_pdl1vj$(key.name).append_pdl1vj$(' : ').append_s8jyv4$(value.size).append_s8itvh$(10);\n }\n return sb.toString();\n };\n DataFrame.prototype.rowCount = function () {\n return this.myVectorByVar_0.isEmpty() ? 0 : this.myVectorByVar_0.entries.iterator().next().value.size;\n };\n DataFrame.prototype.has_8xm3sj$ = function (variable) {\n return this.myVectorByVar_0.containsKey_11rb$(variable);\n };\n DataFrame.prototype.isEmpty_8xm3sj$ = function (variable) {\n return this.get_8xm3sj$(variable).isEmpty();\n };\n DataFrame.prototype.hasNoOrEmpty_8xm3sj$ = function (variable) {\n return !this.has_8xm3sj$(variable) || this.isEmpty_8xm3sj$(variable);\n };\n DataFrame.prototype.get_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n return ensureNotNull(this.myVectorByVar_0.get_11rb$(variable));\n };\n DataFrame.prototype.getNumeric_8xm3sj$ = function (variable) {\n var tmp$;\n this.assertDefined_0(variable);\n var list = this.myVectorByVar_0.get_11rb$(variable);\n if (ensureNotNull(list).isEmpty()) {\n return emptyList();\n }this.assertNumeric_0(variable);\n return Kotlin.isType(tmp$ = list, List) ? tmp$ : throwCCE();\n };\n DataFrame.prototype.distinctValues_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n var tmp$;\n var value = this.myDistinctValues_0.get_11rb$(variable);\n if (value == null) {\n var tmp$_0;\n var $receiver = LinkedHashSet_init(this.get_8xm3sj$(variable));\n $receiver.remove_11rb$(null);\n var values = $receiver;\n return Kotlin.isType(tmp$_0 = values, Collection) ? tmp$_0 : throwCCE();\n } else {\n tmp$ = value;\n }\n return tmp$;\n };\n DataFrame.prototype.variables = function () {\n return this.myVectorByVar_0.keys;\n };\n DataFrame.prototype.isNumeric_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n if (!this.myIsNumeric_0.containsKey_11rb$(variable)) {\n var checkedDoubles = data.SeriesUtil.checkedDoubles_9ma18$(this.get_8xm3sj$(variable));\n var $receiver = this.myIsNumeric_0;\n var value = checkedDoubles.notEmptyAndCanBeCast();\n $receiver.put_xwzc9p$(variable, value);\n }return ensureNotNull(this.myIsNumeric_0.get_11rb$(variable));\n };\n DataFrame.prototype.range_8xm3sj$ = function (variable) {\n if (!this.myRanges_0.containsKey_11rb$(variable)) {\n var v = this.getNumeric_8xm3sj$(variable);\n var r = data.SeriesUtil.range_l63ks6$(v);\n this.myRanges_0.put_xwzc9p$(variable, r);\n }return this.myRanges_0.get_11rb$(variable);\n };\n DataFrame.prototype.builder = function () {\n return DataFrame$DataFrame$Builder_init_0(this);\n };\n function DataFrame$assertDefined$lambda(closure$e) {\n return function () {\n return ensureNotNull(closure$e.message);\n };\n }\n DataFrame.prototype.assertDefined_0 = function (variable) {\n if (!this.has_8xm3sj$(variable)) {\n var e = IllegalArgumentException_init(\"Undefined variable: '\" + variable + \"'\");\n DataFrame$Companion_getInstance().LOG_0.error_l35kib$(e, DataFrame$assertDefined$lambda(e));\n throw e;\n }};\n function DataFrame$assertNumeric$lambda(closure$e) {\n return function () {\n return ensureNotNull(closure$e.message);\n };\n }\n DataFrame.prototype.assertNumeric_0 = function (variable) {\n if (!this.isNumeric_8xm3sj$(variable)) {\n var e = IllegalArgumentException_init(\"Not a numeric variable: '\" + variable + \"'\");\n DataFrame$Companion_getInstance().LOG_0.error_l35kib$(e, DataFrame$assertNumeric$lambda(e));\n throw e;\n }};\n function DataFrame$selectIndices$lambda(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.pickAtIndices_ge51dg$(serie, closure$indices);\n };\n }\n DataFrame.prototype.selectIndices_pqoyrt$ = function (indices) {\n return this.buildModified_0(DataFrame$selectIndices$lambda(indices));\n };\n function DataFrame$selectIndices$lambda_0(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.pickAtIndices_jlfzfq$(serie, closure$indices);\n };\n }\n DataFrame.prototype.selectIndices_p1n9e9$ = function (indices) {\n return this.buildModified_0(DataFrame$selectIndices$lambda_0(indices));\n };\n function DataFrame$dropIndices$lambda(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.skipAtIndices_jlfzfq$(serie, closure$indices);\n };\n }\n DataFrame.prototype.dropIndices_p1n9e9$ = function (indices) {\n return indices.isEmpty() ? this : this.buildModified_0(DataFrame$dropIndices$lambda(indices));\n };\n DataFrame.prototype.buildModified_0 = function (serieFun) {\n var tmp$;\n var builder = this.builder();\n tmp$ = this.myVectorByVar_0.keys.iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n var serie = this.myVectorByVar_0.get_11rb$(variable);\n var modifiedSerie = serieFun(ensureNotNull(serie));\n builder.putIntern_bxyhp4$(variable, modifiedSerie);\n }\n return builder.build();\n };\n function DataFrame$Variable(name, source, label) {\n DataFrame$Variable$Companion_getInstance();\n if (source === void 0)\n source = DataFrame$Variable$Source$ORIGIN_getInstance();\n if (label === void 0)\n label = name;\n this.name = name;\n this.source = source;\n this.label = label;\n }\n Object.defineProperty(DataFrame$Variable.prototype, 'isOrigin', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$ORIGIN_getInstance();\n }\n });\n Object.defineProperty(DataFrame$Variable.prototype, 'isStat', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$STAT_getInstance();\n }\n });\n Object.defineProperty(DataFrame$Variable.prototype, 'isTransform', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$TRANSFORM_getInstance();\n }\n });\n DataFrame$Variable.prototype.toString = function () {\n return this.name;\n };\n DataFrame$Variable.prototype.toSummaryString = function () {\n return this.name + \", '\" + this.label + \"' [\" + this.source + ']';\n };\n function DataFrame$Variable$Source(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DataFrame$Variable$Source_initFields() {\n DataFrame$Variable$Source_initFields = function () {\n };\n DataFrame$Variable$Source$ORIGIN_instance = new DataFrame$Variable$Source('ORIGIN', 0);\n DataFrame$Variable$Source$TRANSFORM_instance = new DataFrame$Variable$Source('TRANSFORM', 1);\n DataFrame$Variable$Source$STAT_instance = new DataFrame$Variable$Source('STAT', 2);\n }\n var DataFrame$Variable$Source$ORIGIN_instance;\n function DataFrame$Variable$Source$ORIGIN_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$ORIGIN_instance;\n }\n var DataFrame$Variable$Source$TRANSFORM_instance;\n function DataFrame$Variable$Source$TRANSFORM_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$TRANSFORM_instance;\n }\n var DataFrame$Variable$Source$STAT_instance;\n function DataFrame$Variable$Source$STAT_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$STAT_instance;\n }\n DataFrame$Variable$Source.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Source',\n interfaces: [Enum]\n };\n function DataFrame$Variable$Source$values() {\n return [DataFrame$Variable$Source$ORIGIN_getInstance(), DataFrame$Variable$Source$TRANSFORM_getInstance(), DataFrame$Variable$Source$STAT_getInstance()];\n }\n DataFrame$Variable$Source.values = DataFrame$Variable$Source$values;\n function DataFrame$Variable$Source$valueOf(name) {\n switch (name) {\n case 'ORIGIN':\n return DataFrame$Variable$Source$ORIGIN_getInstance();\n case 'TRANSFORM':\n return DataFrame$Variable$Source$TRANSFORM_getInstance();\n case 'STAT':\n return DataFrame$Variable$Source$STAT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.DataFrame.Variable.Source.' + name);\n }\n }\n DataFrame$Variable$Source.valueOf_61zpoe$ = DataFrame$Variable$Source$valueOf;\n function DataFrame$Variable$Companion() {\n DataFrame$Variable$Companion_instance = this;\n }\n DataFrame$Variable$Companion.prototype.createOriginal_puj7f4$ = function (name, label) {\n if (label === void 0)\n label = name;\n return new DataFrame$Variable(name, DataFrame$Variable$Source$ORIGIN_getInstance(), label);\n };\n DataFrame$Variable$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Variable$Companion_instance = null;\n function DataFrame$Variable$Companion_getInstance() {\n if (DataFrame$Variable$Companion_instance === null) {\n new DataFrame$Variable$Companion();\n }return DataFrame$Variable$Companion_instance;\n }\n DataFrame$Variable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Variable',\n interfaces: []\n };\n function DataFrame$getOrderedDistinctValues$isValueComparable(value) {\n return value != null && (!(typeof value === 'number') || isFinite(value));\n }\n function DataFrame$getOrderedDistinctValues$lambda(it) {\n var tmp$;\n return Kotlin.isComparable(tmp$ = it.second) ? tmp$ : throwCCE();\n }\n function DataFrame$getOrderedDistinctValues$lambda_0(it) {\n var tmp$;\n return Kotlin.isComparable(tmp$ = it.first) ? tmp$ : throwCCE();\n }\n DataFrame.prototype.getOrderedDistinctValues_0 = function (orderSpec) {\n var tmp$, tmp$_0;\n var isValueComparable = DataFrame$getOrderedDistinctValues$isValueComparable;\n if (orderSpec.aggregateOperation != null) {\n if (!this.isNumeric_8xm3sj$(orderSpec.orderBy)) {\n var message = \"Can't apply aggregate operation to non-numeric values\";\n throw IllegalArgumentException_init(message.toString());\n }var $receiver = zip(this.get_8xm3sj$(orderSpec.variable), this.getNumeric_8xm3sj$(orderSpec.orderBy));\n var destination = LinkedHashMap_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n var value = element.component1();\n var key = value;\n var tmp$_0_0;\n var value_0 = destination.get_11rb$(key);\n if (value_0 == null) {\n var answer = ArrayList_init();\n destination.put_xwzc9p$(key, answer);\n tmp$_0_0 = answer;\n } else {\n tmp$_0_0 = value_0;\n }\n var list = tmp$_0_0;\n var tmp$_2 = list.add_11rb$;\n var byValue = element.component2();\n tmp$_2.call(list, byValue);\n }\n var destination_0 = LinkedHashMap_init_0(mapCapacity(destination.size));\n var tmp$_3;\n tmp$_3 = destination.entries.iterator();\n while (tmp$_3.hasNext()) {\n var element_0 = tmp$_3.next();\n var tmp$_4 = destination_0.put_xwzc9p$;\n var tmp$_5 = element_0.key;\n var byValues = element_0.value;\n var tmp$_6 = orderSpec.aggregateOperation;\n var destination_1 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = byValues.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (isValueComparable(element_1))\n destination_1.add_11rb$(element_1);\n }\n tmp$_4.call(destination_0, tmp$_5, tmp$_6.call(orderSpec, destination_1));\n }\n tmp$ = toList(destination_0);\n } else {\n tmp$ = zip(this.get_8xm3sj$(orderSpec.variable), this.get_8xm3sj$(orderSpec.orderBy));\n }\n var $receiver_0 = tmp$;\n var destination_2 = ArrayList_init();\n var tmp$_8;\n tmp$_8 = $receiver_0.iterator();\n while (tmp$_8.hasNext()) {\n var element_2 = tmp$_8.next();\n if (isValueComparable(element_2.second) && isValueComparable(element_2.first))\n destination_2.add_11rb$(element_2);\n }\n var $receiver_1 = sortedWith(destination_2, compareBy([DataFrame$getOrderedDistinctValues$lambda, DataFrame$getOrderedDistinctValues$lambda_0]));\n var destination_3 = ArrayList_init();\n var tmp$_9;\n tmp$_9 = $receiver_1.iterator();\n while (tmp$_9.hasNext()) {\n var element_3 = tmp$_9.next();\n var tmp$_0_1;\n if ((tmp$_0_1 = element_3.first) != null) {\n destination_3.add_11rb$(tmp$_0_1);\n }}\n var orderedValues = destination_3;\n var $receiver_2 = zip(this.get_8xm3sj$(orderSpec.variable), this.get_8xm3sj$(orderSpec.orderBy));\n var destination_4 = ArrayList_init();\n var tmp$_10;\n tmp$_10 = $receiver_2.iterator();\n while (tmp$_10.hasNext()) {\n var element_4 = tmp$_10.next();\n if (!isValueComparable(element_4.second))\n destination_4.add_11rb$(element_4);\n }\n var destination_5 = ArrayList_init();\n var tmp$_11;\n tmp$_11 = destination_4.iterator();\n while (tmp$_11.hasNext()) {\n var element_5 = tmp$_11.next();\n var tmp$_0_2;\n if ((tmp$_0_2 = element_5.first) != null) {\n destination_5.add_11rb$(tmp$_0_2);\n }}\n var nonComparableAppendix = destination_5;\n if (orderSpec.direction < 0) {\n tmp$_0 = reversed(orderedValues);\n } else {\n tmp$_0 = orderedValues;\n }\n return toSet(plus(tmp$_0, nonComparableAppendix));\n };\n function DataFrame$Companion() {\n DataFrame$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(DataFrame));\n }\n DataFrame$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Companion_instance = null;\n function DataFrame$Companion_getInstance() {\n if (DataFrame$Companion_instance === null) {\n new DataFrame$Companion();\n }return DataFrame$Companion_instance;\n }\n function DataFrame$Builder() {\n DataFrame$Builder$Companion_getInstance();\n this.myVectorByVar_8be2vx$ = HashMap_init();\n this.myIsNumeric_8be2vx$ = HashMap_init();\n this.myOrderSpecs_8be2vx$ = ArrayList_init();\n }\n DataFrame$Builder.prototype.put_2l962d$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.remove_11rb$(variable);\n return this;\n };\n DataFrame$Builder.prototype.putNumeric_s1rqo9$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.put_xwzc9p$(variable, true);\n return this;\n };\n DataFrame$Builder.prototype.putDiscrete_2l962d$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.put_xwzc9p$(variable, false);\n return this;\n };\n DataFrame$Builder.prototype.putIntern_bxyhp4$ = function (variable, v) {\n var $receiver = this.myVectorByVar_8be2vx$;\n var value = ArrayList_init_0(v);\n $receiver.put_xwzc9p$(variable, value);\n };\n DataFrame$Builder.prototype.remove_8xm3sj$ = function (variable) {\n this.myVectorByVar_8be2vx$.remove_11rb$(variable);\n this.myIsNumeric_8be2vx$.remove_11rb$(variable);\n return this;\n };\n DataFrame$Builder.prototype.addOrderSpecs_l2t0xf$ = function (orderSpecs) {\n var action = getCallableRef('addOrderSpec', function ($receiver, p1) {\n return $receiver.addOrderSpec_22dbp4$(p1);\n }.bind(null, this));\n var tmp$;\n tmp$ = orderSpecs.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n action(element);\n }\n return this;\n };\n DataFrame$Builder.prototype.addOrderSpec_22dbp4$ = function (orderSpec) {\n var $receiver = this.myOrderSpecs_8be2vx$;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (equals(element.variable, orderSpec.variable)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var currentOrderSpec = firstOrNull$result;\n if ((currentOrderSpec != null ? currentOrderSpec.aggregateOperation : null) == null) {\n var $receiver_0 = this.myOrderSpecs_8be2vx$;\n var tmp$_0;\n (Kotlin.isType(tmp$_0 = $receiver_0, MutableCollection) ? tmp$_0 : throwCCE()).remove_11rb$(currentOrderSpec);\n this.myOrderSpecs_8be2vx$.add_11rb$(orderSpec);\n }return this;\n };\n DataFrame$Builder.prototype.build = function () {\n return new DataFrame(this);\n };\n function DataFrame$Builder$Companion() {\n DataFrame$Builder$Companion_instance = this;\n }\n DataFrame$Builder$Companion.prototype.emptyFrame = function () {\n return DataFrame$DataFrame$Builder_init().build();\n };\n DataFrame$Builder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Builder$Companion_instance = null;\n function DataFrame$Builder$Companion_getInstance() {\n if (DataFrame$Builder$Companion_instance === null) {\n new DataFrame$Builder$Companion();\n }return DataFrame$Builder$Companion_instance;\n }\n DataFrame$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n function DataFrame$DataFrame$Builder_init($this) {\n $this = $this || Object.create(DataFrame$Builder.prototype);\n DataFrame$Builder.call($this);\n return $this;\n }\n function DataFrame$DataFrame$Builder_init_0(data, $this) {\n $this = $this || Object.create(DataFrame$Builder.prototype);\n DataFrame$Builder.call($this);\n $this.myVectorByVar_8be2vx$.putAll_a2k3zr$(data.myVectorByVar_0);\n $this.myIsNumeric_8be2vx$.putAll_a2k3zr$(data.myIsNumeric_0);\n $this.myOrderSpecs_8be2vx$.addAll_brywnq$(data.myOrderSpecs_0);\n return $this;\n }\n DataFrame.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataFrame',\n interfaces: []\n };\n function DataPointAesthetics() {\n }\n DataPointAesthetics.prototype.defined_896ixz$ = function (aes) {\n var tmp$;\n if (aes.isNumeric) {\n var number = this.get_31786j$(aes);\n return number != null && isFinite(typeof (tmp$ = number) === 'number' ? tmp$ : throwCCE());\n }return true;\n };\n DataPointAesthetics.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'DataPointAesthetics',\n interfaces: []\n };\n function DiscreteTransform(domainValues, domainLimits) {\n this.domainValues = domainValues;\n this.domainLimits = domainLimits;\n this.numberByDomainValue_0 = LinkedHashMap_init();\n this.domainValueByNumber_0 = new TreeMap();\n var tmp$, tmp$_0;\n if (this.domainLimits.isEmpty()) {\n tmp$ = this.domainValues;\n } else {\n tmp$ = intersect(this.domainLimits, this.domainValues);\n }\n var effectiveDomain = tmp$;\n this.numberByDomainValue_0.putAll_a2k3zr$(MapperUtil_getInstance().mapDiscreteDomainValuesToNumbers_7f6uoc$(effectiveDomain));\n tmp$_0 = this.numberByDomainValue_0.entries.iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_1 = tmp$_0.next();\n var domainValue = tmp$_1.key;\n var number = tmp$_1.value;\n this.domainValueByNumber_0.put_ncwa5f$(number, domainValue);\n }\n }\n DiscreteTransform.prototype.hasDomainLimits = function () {\n return !this.domainLimits.isEmpty();\n };\n DiscreteTransform.prototype.isInDomain_s8jyv4$ = function (v) {\n var $receiver = this.numberByDomainValue_0;\n var tmp$;\n return (Kotlin.isType(tmp$ = $receiver, Map) ? tmp$ : throwCCE()).containsKey_11rb$(v);\n };\n DiscreteTransform.prototype.apply_9ma18$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.asNumber_0(item));\n }\n return destination;\n };\n DiscreteTransform.prototype.applyInverse_yrwdxb$ = function (v) {\n return this.fromNumber_0(v);\n };\n DiscreteTransform.prototype.asNumber_0 = function (input) {\n if (input == null) {\n return null;\n }if (this.numberByDomainValue_0.containsKey_11rb$(input)) {\n return this.numberByDomainValue_0.get_11rb$(input);\n }throw IllegalStateException_init('value ' + toString(input) + ' is not in the domain: ' + this.numberByDomainValue_0.keys);\n };\n DiscreteTransform.prototype.fromNumber_0 = function (v) {\n var tmp$;\n if (v == null) {\n return null;\n }if (this.domainValueByNumber_0.containsKey_mef7kx$(v)) {\n return this.domainValueByNumber_0.get_mef7kx$(v);\n }var ceilingKey = this.domainValueByNumber_0.ceilingKey_mef7kx$(v);\n var floorKey = this.domainValueByNumber_0.floorKey_mef7kx$(v);\n var keyNumber = null;\n if (ceilingKey != null || floorKey != null) {\n if (ceilingKey == null)\n tmp$ = floorKey;\n else if (floorKey == null)\n tmp$ = ceilingKey;\n else {\n var x = ceilingKey - v;\n var ceilingDist = JsMath.abs(x);\n var x_0 = floorKey - v;\n var floorDist = JsMath.abs(x_0);\n tmp$ = ceilingDist < floorDist ? ceilingKey : floorKey;\n }\n keyNumber = tmp$;\n }return keyNumber != null ? this.domainValueByNumber_0.get_mef7kx$(keyNumber) : null;\n };\n DiscreteTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteTransform',\n interfaces: [Transform]\n };\n function Geom() {\n }\n Geom.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Geom',\n interfaces: []\n };\n function GeomContext() {\n }\n GeomContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomContext',\n interfaces: []\n };\n function GeomKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomKind_initFields() {\n GeomKind_initFields = function () {\n };\n GeomKind$PATH_instance = new GeomKind('PATH', 0);\n GeomKind$LINE_instance = new GeomKind('LINE', 1);\n GeomKind$SMOOTH_instance = new GeomKind('SMOOTH', 2);\n GeomKind$BAR_instance = new GeomKind('BAR', 3);\n GeomKind$HISTOGRAM_instance = new GeomKind('HISTOGRAM', 4);\n GeomKind$TILE_instance = new GeomKind('TILE', 5);\n GeomKind$BIN_2D_instance = new GeomKind('BIN_2D', 6);\n GeomKind$MAP_instance = new GeomKind('MAP', 7);\n GeomKind$ERROR_BAR_instance = new GeomKind('ERROR_BAR', 8);\n GeomKind$CROSS_BAR_instance = new GeomKind('CROSS_BAR', 9);\n GeomKind$LINE_RANGE_instance = new GeomKind('LINE_RANGE', 10);\n GeomKind$POINT_RANGE_instance = new GeomKind('POINT_RANGE', 11);\n GeomKind$POLYGON_instance = new GeomKind('POLYGON', 12);\n GeomKind$AB_LINE_instance = new GeomKind('AB_LINE', 13);\n GeomKind$H_LINE_instance = new GeomKind('H_LINE', 14);\n GeomKind$V_LINE_instance = new GeomKind('V_LINE', 15);\n GeomKind$BOX_PLOT_instance = new GeomKind('BOX_PLOT', 16);\n GeomKind$LIVE_MAP_instance = new GeomKind('LIVE_MAP', 17);\n GeomKind$POINT_instance = new GeomKind('POINT', 18);\n GeomKind$RIBBON_instance = new GeomKind('RIBBON', 19);\n GeomKind$AREA_instance = new GeomKind('AREA', 20);\n GeomKind$DENSITY_instance = new GeomKind('DENSITY', 21);\n GeomKind$CONTOUR_instance = new GeomKind('CONTOUR', 22);\n GeomKind$CONTOURF_instance = new GeomKind('CONTOURF', 23);\n GeomKind$DENSITY2D_instance = new GeomKind('DENSITY2D', 24);\n GeomKind$DENSITY2DF_instance = new GeomKind('DENSITY2DF', 25);\n GeomKind$JITTER_instance = new GeomKind('JITTER', 26);\n GeomKind$FREQPOLY_instance = new GeomKind('FREQPOLY', 27);\n GeomKind$STEP_instance = new GeomKind('STEP', 28);\n GeomKind$RECT_instance = new GeomKind('RECT', 29);\n GeomKind$SEGMENT_instance = new GeomKind('SEGMENT', 30);\n GeomKind$TEXT_instance = new GeomKind('TEXT', 31);\n GeomKind$RASTER_instance = new GeomKind('RASTER', 32);\n GeomKind$IMAGE_instance = new GeomKind('IMAGE', 33);\n }\n var GeomKind$PATH_instance;\n function GeomKind$PATH_getInstance() {\n GeomKind_initFields();\n return GeomKind$PATH_instance;\n }\n var GeomKind$LINE_instance;\n function GeomKind$LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$LINE_instance;\n }\n var GeomKind$SMOOTH_instance;\n function GeomKind$SMOOTH_getInstance() {\n GeomKind_initFields();\n return GeomKind$SMOOTH_instance;\n }\n var GeomKind$BAR_instance;\n function GeomKind$BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$BAR_instance;\n }\n var GeomKind$HISTOGRAM_instance;\n function GeomKind$HISTOGRAM_getInstance() {\n GeomKind_initFields();\n return GeomKind$HISTOGRAM_instance;\n }\n var GeomKind$TILE_instance;\n function GeomKind$TILE_getInstance() {\n GeomKind_initFields();\n return GeomKind$TILE_instance;\n }\n var GeomKind$BIN_2D_instance;\n function GeomKind$BIN_2D_getInstance() {\n GeomKind_initFields();\n return GeomKind$BIN_2D_instance;\n }\n var GeomKind$MAP_instance;\n function GeomKind$MAP_getInstance() {\n GeomKind_initFields();\n return GeomKind$MAP_instance;\n }\n var GeomKind$ERROR_BAR_instance;\n function GeomKind$ERROR_BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$ERROR_BAR_instance;\n }\n var GeomKind$CROSS_BAR_instance;\n function GeomKind$CROSS_BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$CROSS_BAR_instance;\n }\n var GeomKind$LINE_RANGE_instance;\n function GeomKind$LINE_RANGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$LINE_RANGE_instance;\n }\n var GeomKind$POINT_RANGE_instance;\n function GeomKind$POINT_RANGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$POINT_RANGE_instance;\n }\n var GeomKind$POLYGON_instance;\n function GeomKind$POLYGON_getInstance() {\n GeomKind_initFields();\n return GeomKind$POLYGON_instance;\n }\n var GeomKind$AB_LINE_instance;\n function GeomKind$AB_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$AB_LINE_instance;\n }\n var GeomKind$H_LINE_instance;\n function GeomKind$H_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$H_LINE_instance;\n }\n var GeomKind$V_LINE_instance;\n function GeomKind$V_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$V_LINE_instance;\n }\n var GeomKind$BOX_PLOT_instance;\n function GeomKind$BOX_PLOT_getInstance() {\n GeomKind_initFields();\n return GeomKind$BOX_PLOT_instance;\n }\n var GeomKind$LIVE_MAP_instance;\n function GeomKind$LIVE_MAP_getInstance() {\n GeomKind_initFields();\n return GeomKind$LIVE_MAP_instance;\n }\n var GeomKind$POINT_instance;\n function GeomKind$POINT_getInstance() {\n GeomKind_initFields();\n return GeomKind$POINT_instance;\n }\n var GeomKind$RIBBON_instance;\n function GeomKind$RIBBON_getInstance() {\n GeomKind_initFields();\n return GeomKind$RIBBON_instance;\n }\n var GeomKind$AREA_instance;\n function GeomKind$AREA_getInstance() {\n GeomKind_initFields();\n return GeomKind$AREA_instance;\n }\n var GeomKind$DENSITY_instance;\n function GeomKind$DENSITY_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY_instance;\n }\n var GeomKind$CONTOUR_instance;\n function GeomKind$CONTOUR_getInstance() {\n GeomKind_initFields();\n return GeomKind$CONTOUR_instance;\n }\n var GeomKind$CONTOURF_instance;\n function GeomKind$CONTOURF_getInstance() {\n GeomKind_initFields();\n return GeomKind$CONTOURF_instance;\n }\n var GeomKind$DENSITY2D_instance;\n function GeomKind$DENSITY2D_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY2D_instance;\n }\n var GeomKind$DENSITY2DF_instance;\n function GeomKind$DENSITY2DF_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY2DF_instance;\n }\n var GeomKind$JITTER_instance;\n function GeomKind$JITTER_getInstance() {\n GeomKind_initFields();\n return GeomKind$JITTER_instance;\n }\n var GeomKind$FREQPOLY_instance;\n function GeomKind$FREQPOLY_getInstance() {\n GeomKind_initFields();\n return GeomKind$FREQPOLY_instance;\n }\n var GeomKind$STEP_instance;\n function GeomKind$STEP_getInstance() {\n GeomKind_initFields();\n return GeomKind$STEP_instance;\n }\n var GeomKind$RECT_instance;\n function GeomKind$RECT_getInstance() {\n GeomKind_initFields();\n return GeomKind$RECT_instance;\n }\n var GeomKind$SEGMENT_instance;\n function GeomKind$SEGMENT_getInstance() {\n GeomKind_initFields();\n return GeomKind$SEGMENT_instance;\n }\n var GeomKind$TEXT_instance;\n function GeomKind$TEXT_getInstance() {\n GeomKind_initFields();\n return GeomKind$TEXT_instance;\n }\n var GeomKind$RASTER_instance;\n function GeomKind$RASTER_getInstance() {\n GeomKind_initFields();\n return GeomKind$RASTER_instance;\n }\n var GeomKind$IMAGE_instance;\n function GeomKind$IMAGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$IMAGE_instance;\n }\n GeomKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomKind',\n interfaces: [Enum]\n };\n function GeomKind$values() {\n return [GeomKind$PATH_getInstance(), GeomKind$LINE_getInstance(), GeomKind$SMOOTH_getInstance(), GeomKind$BAR_getInstance(), GeomKind$HISTOGRAM_getInstance(), GeomKind$TILE_getInstance(), GeomKind$BIN_2D_getInstance(), GeomKind$MAP_getInstance(), GeomKind$ERROR_BAR_getInstance(), GeomKind$CROSS_BAR_getInstance(), GeomKind$LINE_RANGE_getInstance(), GeomKind$POINT_RANGE_getInstance(), GeomKind$POLYGON_getInstance(), GeomKind$AB_LINE_getInstance(), GeomKind$H_LINE_getInstance(), GeomKind$V_LINE_getInstance(), GeomKind$BOX_PLOT_getInstance(), GeomKind$LIVE_MAP_getInstance(), GeomKind$POINT_getInstance(), GeomKind$RIBBON_getInstance(), GeomKind$AREA_getInstance(), GeomKind$DENSITY_getInstance(), GeomKind$CONTOUR_getInstance(), GeomKind$CONTOURF_getInstance(), GeomKind$DENSITY2D_getInstance(), GeomKind$DENSITY2DF_getInstance(), GeomKind$JITTER_getInstance(), GeomKind$FREQPOLY_getInstance(), GeomKind$STEP_getInstance(), GeomKind$RECT_getInstance(), GeomKind$SEGMENT_getInstance(), GeomKind$TEXT_getInstance(), GeomKind$RASTER_getInstance(), GeomKind$IMAGE_getInstance()];\n }\n GeomKind.values = GeomKind$values;\n function GeomKind$valueOf(name) {\n switch (name) {\n case 'PATH':\n return GeomKind$PATH_getInstance();\n case 'LINE':\n return GeomKind$LINE_getInstance();\n case 'SMOOTH':\n return GeomKind$SMOOTH_getInstance();\n case 'BAR':\n return GeomKind$BAR_getInstance();\n case 'HISTOGRAM':\n return GeomKind$HISTOGRAM_getInstance();\n case 'TILE':\n return GeomKind$TILE_getInstance();\n case 'BIN_2D':\n return GeomKind$BIN_2D_getInstance();\n case 'MAP':\n return GeomKind$MAP_getInstance();\n case 'ERROR_BAR':\n return GeomKind$ERROR_BAR_getInstance();\n case 'CROSS_BAR':\n return GeomKind$CROSS_BAR_getInstance();\n case 'LINE_RANGE':\n return GeomKind$LINE_RANGE_getInstance();\n case 'POINT_RANGE':\n return GeomKind$POINT_RANGE_getInstance();\n case 'POLYGON':\n return GeomKind$POLYGON_getInstance();\n case 'AB_LINE':\n return GeomKind$AB_LINE_getInstance();\n case 'H_LINE':\n return GeomKind$H_LINE_getInstance();\n case 'V_LINE':\n return GeomKind$V_LINE_getInstance();\n case 'BOX_PLOT':\n return GeomKind$BOX_PLOT_getInstance();\n case 'LIVE_MAP':\n return GeomKind$LIVE_MAP_getInstance();\n case 'POINT':\n return GeomKind$POINT_getInstance();\n case 'RIBBON':\n return GeomKind$RIBBON_getInstance();\n case 'AREA':\n return GeomKind$AREA_getInstance();\n case 'DENSITY':\n return GeomKind$DENSITY_getInstance();\n case 'CONTOUR':\n return GeomKind$CONTOUR_getInstance();\n case 'CONTOURF':\n return GeomKind$CONTOURF_getInstance();\n case 'DENSITY2D':\n return GeomKind$DENSITY2D_getInstance();\n case 'DENSITY2DF':\n return GeomKind$DENSITY2DF_getInstance();\n case 'JITTER':\n return GeomKind$JITTER_getInstance();\n case 'FREQPOLY':\n return GeomKind$FREQPOLY_getInstance();\n case 'STEP':\n return GeomKind$STEP_getInstance();\n case 'RECT':\n return GeomKind$RECT_getInstance();\n case 'SEGMENT':\n return GeomKind$SEGMENT_getInstance();\n case 'TEXT':\n return GeomKind$TEXT_getInstance();\n case 'RASTER':\n return GeomKind$RASTER_getInstance();\n case 'IMAGE':\n return GeomKind$IMAGE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.GeomKind.' + name);\n }\n }\n GeomKind.valueOf_61zpoe$ = GeomKind$valueOf;\n function GeomMeta() {\n GeomMeta_instance = this;\n this.renderedAesByGeom_0 = HashMap_init();\n this.POINT_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SHAPE]);\n this.PATH_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SPEED, Aes$Companion_getInstance().FLOW]);\n this.POLYGON_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n this.AREA_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n }\n GeomMeta.prototype.renders_7dhqpi$ = function (geomKind) {\n if (!this.renderedAesByGeom_0.containsKey_11rb$(geomKind)) {\n var $receiver = this.renderedAesByGeom_0;\n var value = this.renderedAesList_0(geomKind);\n $receiver.put_xwzc9p$(geomKind, value);\n }return ensureNotNull(this.renderedAesByGeom_0.get_11rb$(geomKind));\n };\n GeomMeta.prototype.renderedAesList_0 = function (geomKind) {\n var tmp$;\n switch (geomKind.name) {\n case 'POINT':\n tmp$ = this.POINT_0;\n break;\n case 'PATH':\n tmp$ = this.PATH_0;\n break;\n case 'LINE':\n tmp$ = this.PATH_0;\n break;\n case 'SMOOTH':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n break;\n case 'HISTOGRAM':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n break;\n case 'TILE':\n case 'BIN_2D':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().HEIGHT, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'ERROR_BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'CROSS_BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'LINE_RANGE':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'POINT_RANGE':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'CONTOUR':\n tmp$ = this.PATH_0;\n break;\n case 'CONTOURF':\n tmp$ = this.POLYGON_0;\n break;\n case 'POLYGON':\n tmp$ = this.POLYGON_0;\n break;\n case 'MAP':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'AB_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().INTERCEPT, Aes$Companion_getInstance().SLOPE, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'H_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().YINTERCEPT, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'V_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().XINTERCEPT, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'BOX_PLOT':\n tmp$ = listOf([Aes$Companion_getInstance().LOWER, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().UPPER, Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().WIDTH]);\n break;\n case 'RIBBON':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'AREA':\n tmp$ = this.AREA_0;\n break;\n case 'DENSITY':\n tmp$ = this.AREA_0;\n break;\n case 'DENSITY2D':\n tmp$ = this.PATH_0;\n break;\n case 'DENSITY2DF':\n tmp$ = this.POLYGON_0;\n break;\n case 'JITTER':\n tmp$ = this.POINT_0;\n break;\n case 'FREQPOLY':\n tmp$ = this.PATH_0;\n break;\n case 'STEP':\n tmp$ = this.PATH_0;\n break;\n case 'RECT':\n tmp$ = listOf([Aes$Companion_getInstance().XMIN, Aes$Companion_getInstance().XMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'SEGMENT':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().XEND, Aes$Companion_getInstance().YEND, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SPEED, Aes$Companion_getInstance().FLOW]);\n break;\n case 'TEXT':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().LABEL, Aes$Companion_getInstance().FAMILY, Aes$Companion_getInstance().FONTFACE, Aes$Companion_getInstance().HJUST, Aes$Companion_getInstance().VJUST, Aes$Companion_getInstance().ANGLE]);\n break;\n case 'LIVE_MAP':\n tmp$ = listOf([Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().FRAME, Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SYM_X, Aes$Companion_getInstance().SYM_Y]);\n break;\n case 'RASTER':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().HEIGHT, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'IMAGE':\n tmp$ = listOf([Aes$Companion_getInstance().XMIN, Aes$Companion_getInstance().XMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX]);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n GeomMeta.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomMeta',\n interfaces: []\n };\n var GeomMeta_instance = null;\n function GeomMeta_getInstance() {\n if (GeomMeta_instance === null) {\n new GeomMeta();\n }return GeomMeta_instance;\n }\n function PositionAdjustment() {\n }\n Object.defineProperty(PositionAdjustment.prototype, 'isIdentity', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n PositionAdjustment.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PositionAdjustment',\n interfaces: []\n };\n function Scale() {\n }\n function Scale$Builder() {\n }\n Scale$Builder.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Builder',\n interfaces: []\n };\n Scale.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Scale',\n interfaces: []\n };\n function Stat() {\n }\n function Stat$apply$lambda(it) {\n return Unit;\n }\n Stat.prototype.apply_kdy6bf$ = function (data, statCtx, messageConsumer, callback$default) {\n if (messageConsumer === void 0)\n messageConsumer = Stat$apply$lambda;\n return callback$default ? callback$default(data, statCtx, messageConsumer) : this.apply_kdy6bf$$default(data, statCtx, messageConsumer);\n };\n Stat.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Stat',\n interfaces: []\n };\n function StatContext() {\n }\n StatContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'StatContext',\n interfaces: []\n };\n function Transform() {\n }\n Transform.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Transform',\n interfaces: []\n };\n function AesInitValue() {\n AesInitValue_instance = this;\n this.VALUE_MAP_0 = new TypedKeyHashMap();\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().X, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().Y, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().Z, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YMIN, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YMAX, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().COLOR, Color.Companion.PACIFIC_BLUE);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FILL, Color.Companion.PACIFIC_BLUE);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().ALPHA, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SHAPE, NamedShape$SOLID_CIRCLE_getInstance());\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LINETYPE, NamedLineType$SOLID_getInstance());\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SIZE, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().WIDTH, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().HEIGHT, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().WEIGHT, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().INTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SLOPE, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XINTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YINTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LOWER, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().MIDDLE, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().UPPER, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FRAME, 'empty frame');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SPEED, 10.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FLOW, 0.1);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XMIN, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XMAX, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XEND, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YEND, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LABEL, '');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FAMILY, 'sans-serif');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FONTFACE, 'plain');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().HJUST, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().VJUST, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().ANGLE, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SYM_X, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SYM_Y, 0.0);\n }\n AesInitValue.prototype.has_896ixz$ = function (aes) {\n return this.VALUE_MAP_0.containsKey_ex36zt$(aes);\n };\n AesInitValue.prototype.get_31786j$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n AesInitValue.prototype.get_ex36zt$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n AesInitValue.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AesInitValue',\n interfaces: []\n };\n var AesInitValue_instance = null;\n function AesInitValue_getInstance() {\n if (AesInitValue_instance === null) {\n new AesInitValue();\n }return AesInitValue_instance;\n }\n function AesScaling() {\n AesScaling_instance = this;\n this.UNIT_SHAPE_SIZE = 2.2;\n }\n AesScaling.prototype.strokeWidth_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2.0;\n };\n AesScaling.prototype.circleDiameter_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * this.UNIT_SHAPE_SIZE;\n };\n AesScaling.prototype.circleDiameterSmaller_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 1.5;\n };\n AesScaling.prototype.sizeFromCircleDiameter_14dthe$ = function (diameter) {\n return diameter / this.UNIT_SHAPE_SIZE;\n };\n AesScaling.prototype.textSize_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2;\n };\n AesScaling.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AesScaling',\n interfaces: []\n };\n var AesScaling_instance = null;\n function AesScaling_getInstance() {\n if (AesScaling_instance === null) {\n new AesScaling();\n }return AesScaling_instance;\n }\n function AesVisitor() {\n }\n AesVisitor.prototype.visit_896ixz$ = function (aes) {\n var tmp$, tmp$_0;\n if (aes.isNumeric) {\n tmp$_0 = this.visitNumeric_vktour$(Kotlin.isType(tmp$ = aes, Aes) ? tmp$ : throwCCE());\n } else\n tmp$_0 = this.visitIntern_rp5ogw$_0(aes);\n return tmp$_0;\n };\n AesVisitor.prototype.visitNumeric_vktour$ = function (aes) {\n return this.visitIntern_rp5ogw$_0(aes);\n };\n AesVisitor.prototype.visitIntern_rp5ogw$_0 = function (aes) {\n if (equals(aes, Aes$Companion_getInstance().X)) {\n return this.x();\n }if (equals(aes, Aes$Companion_getInstance().Y)) {\n return this.y();\n }if (equals(aes, Aes$Companion_getInstance().Z)) {\n return this.z();\n }if (equals(aes, Aes$Companion_getInstance().YMIN)) {\n return this.ymin();\n }if (equals(aes, Aes$Companion_getInstance().YMAX)) {\n return this.ymax();\n }if (equals(aes, Aes$Companion_getInstance().COLOR)) {\n return this.color();\n }if (equals(aes, Aes$Companion_getInstance().FILL)) {\n return this.fill();\n }if (equals(aes, Aes$Companion_getInstance().ALPHA)) {\n return this.alpha();\n }if (equals(aes, Aes$Companion_getInstance().SHAPE)) {\n return this.shape();\n }if (equals(aes, Aes$Companion_getInstance().SIZE)) {\n return this.size();\n }if (equals(aes, Aes$Companion_getInstance().LINETYPE)) {\n return this.lineType();\n }if (equals(aes, Aes$Companion_getInstance().WIDTH)) {\n return this.width();\n }if (equals(aes, Aes$Companion_getInstance().HEIGHT)) {\n return this.height();\n }if (equals(aes, Aes$Companion_getInstance().WEIGHT)) {\n return this.weight();\n }if (equals(aes, Aes$Companion_getInstance().INTERCEPT)) {\n return this.intercept();\n }if (equals(aes, Aes$Companion_getInstance().SLOPE)) {\n return this.slope();\n }if (equals(aes, Aes$Companion_getInstance().XINTERCEPT)) {\n return this.interceptX();\n }if (equals(aes, Aes$Companion_getInstance().YINTERCEPT)) {\n return this.interceptY();\n }if (equals(aes, Aes$Companion_getInstance().LOWER)) {\n return this.lower();\n }if (equals(aes, Aes$Companion_getInstance().MIDDLE)) {\n return this.middle();\n }if (equals(aes, Aes$Companion_getInstance().UPPER)) {\n return this.upper();\n }if (equals(aes, Aes$Companion_getInstance().FRAME)) {\n return this.frame();\n }if (equals(aes, Aes$Companion_getInstance().SPEED)) {\n return this.speed();\n }if (equals(aes, Aes$Companion_getInstance().FLOW)) {\n return this.flow();\n }if (equals(aes, Aes$Companion_getInstance().XMIN)) {\n return this.xmin();\n }if (equals(aes, Aes$Companion_getInstance().XMAX)) {\n return this.xmax();\n }if (equals(aes, Aes$Companion_getInstance().XEND)) {\n return this.xend();\n }if (equals(aes, Aes$Companion_getInstance().YEND)) {\n return this.yend();\n }if (equals(aes, Aes$Companion_getInstance().LABEL)) {\n return this.label();\n }if (equals(aes, Aes$Companion_getInstance().FAMILY)) {\n return this.family();\n }if (equals(aes, Aes$Companion_getInstance().FONTFACE)) {\n return this.fontface();\n }if (equals(aes, Aes$Companion_getInstance().HJUST)) {\n return this.hjust();\n }if (equals(aes, Aes$Companion_getInstance().VJUST)) {\n return this.vjust();\n }if (equals(aes, Aes$Companion_getInstance().ANGLE)) {\n return this.angle();\n }if (equals(aes, Aes$Companion_getInstance().SYM_X)) {\n return this.symX();\n }if (equals(aes, Aes$Companion_getInstance().SYM_Y)) {\n return this.symY();\n }throw IllegalArgumentException_init('Unexpected aes: ' + aes);\n };\n AesVisitor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AesVisitor',\n interfaces: []\n };\n function AestheticsBuilder(myDataPointCount) {\n AestheticsBuilder$Companion_getInstance();\n if (myDataPointCount === void 0)\n myDataPointCount = 0;\n this.myDataPointCount_0 = myDataPointCount;\n this.myIndexFunctionMap_0 = null;\n this.myGroup_0 = AestheticsBuilder$Companion_getInstance().constant_mh5how$(0);\n this.myConstantAes_0 = collect.Sets.newHashSet_yl67zr$(Aes$Companion_getInstance().values());\n this.myOverallRangeByNumericAes_0 = HashMap_init();\n var tmp$;\n this.myIndexFunctionMap_0 = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var $receiver = this.myIndexFunctionMap_0;\n var value = AestheticsBuilder$Companion_getInstance().constant_mh5how$(AesInitValue_getInstance().get_31786j$(aes));\n $receiver.put_xwzc9p$(aes, value);\n }\n }\n AestheticsBuilder.prototype.dataPointCount_za3lpa$ = function (v) {\n this.myDataPointCount_0 = v;\n return this;\n };\n AestheticsBuilder.prototype.overallRange_xlyz3f$ = function (aes, range) {\n this.myOverallRangeByNumericAes_0.put_xwzc9p$(aes, range);\n return this;\n };\n AestheticsBuilder.prototype.x_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().X, v);\n };\n AestheticsBuilder.prototype.y_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().Y, v);\n };\n AestheticsBuilder.prototype.color_u2gvuj$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().COLOR, v);\n };\n AestheticsBuilder.prototype.fill_u2gvuj$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FILL, v);\n };\n AestheticsBuilder.prototype.alpha_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().ALPHA, v);\n };\n AestheticsBuilder.prototype.shape_9kzkiq$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SHAPE, v);\n };\n AestheticsBuilder.prototype.lineType_vv264d$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().LINETYPE, v);\n };\n AestheticsBuilder.prototype.size_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SIZE, v);\n };\n AestheticsBuilder.prototype.width_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().WIDTH, v);\n };\n AestheticsBuilder.prototype.weight_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().WEIGHT, v);\n };\n AestheticsBuilder.prototype.frame_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FRAME, v);\n };\n AestheticsBuilder.prototype.speed_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SPEED, v);\n };\n AestheticsBuilder.prototype.flow_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FLOW, v);\n };\n AestheticsBuilder.prototype.group_ddsh32$ = function (v) {\n this.myGroup_0 = v;\n return this;\n };\n AestheticsBuilder.prototype.label_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().LABEL, v);\n };\n AestheticsBuilder.prototype.family_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FAMILY, v);\n };\n AestheticsBuilder.prototype.fontface_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FONTFACE, v);\n };\n AestheticsBuilder.prototype.hjust_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().HJUST, v);\n };\n AestheticsBuilder.prototype.vjust_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().VJUST, v);\n };\n AestheticsBuilder.prototype.angle_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().ANGLE, v);\n };\n AestheticsBuilder.prototype.xmin_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().XMIN, v);\n };\n AestheticsBuilder.prototype.xmax_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().XMAX, v);\n };\n AestheticsBuilder.prototype.ymin_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().YMIN, v);\n };\n AestheticsBuilder.prototype.ymax_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().YMAX, v);\n };\n AestheticsBuilder.prototype.symX_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SYM_X, v);\n };\n AestheticsBuilder.prototype.symY_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SYM_Y, v);\n };\n AestheticsBuilder.prototype.constantAes_bbdhip$ = function (aes, v) {\n this.myConstantAes_0.add_11rb$(aes);\n var $receiver = this.myIndexFunctionMap_0;\n var value = AestheticsBuilder$Companion_getInstance().constant_mh5how$(v);\n $receiver.put_xwzc9p$(aes, value);\n return this;\n };\n AestheticsBuilder.prototype.aes_u42xfl$ = function (aes, v) {\n this.myConstantAes_0.remove_11rb$(aes);\n this.myIndexFunctionMap_0.put_xwzc9p$(aes, v);\n return this;\n };\n AestheticsBuilder.prototype.build = function () {\n return new AestheticsBuilder$MyAesthetics(this);\n };\n function AestheticsBuilder$MyAesthetics(b) {\n this.myDataPointCount_0 = b.myDataPointCount_0;\n this.myIndexFunctionMap_0 = new TypedIndexFunctionMap(b.myIndexFunctionMap_0);\n this.group = b.myGroup_0;\n this.myConstantAes_0 = null;\n this.myOverallRangeByNumericAes_0 = null;\n this.myResolutionByAes_0 = HashMap_init();\n this.myRangeByNumericAes_0 = HashMap_init();\n this.myConstantAes_0 = HashSet_init(b.myConstantAes_0);\n this.myOverallRangeByNumericAes_0 = HashMap_init_0(b.myOverallRangeByNumericAes_0);\n }\n Object.defineProperty(AestheticsBuilder$MyAesthetics.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myDataPointCount_0 === 0;\n }\n });\n AestheticsBuilder$MyAesthetics.prototype.aes_31786j$ = function (aes) {\n return this.myIndexFunctionMap_0.get_31786j$(aes);\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPointAt_za3lpa$ = function (index) {\n return new AestheticsBuilder$MyDataPointAesthetics(index, this);\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPointCount = function () {\n return this.myDataPointCount_0;\n };\n function AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral(this$MyAesthetics, closure$self) {\n this.this$MyAesthetics = this$MyAesthetics;\n this.closure$self = closure$self;\n }\n AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$MyDataPointsIterator(this.this$MyAesthetics.myDataPointCount_0, this.closure$self);\n };\n AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPoints = function () {\n var self_0 = this;\n return new AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral(this, self_0);\n };\n AestheticsBuilder$MyAesthetics.prototype.range_vktour$ = function (aes) {\n var tmp$;\n if (!this.myRangeByNumericAes_0.containsKey_11rb$(aes)) {\n if (this.myDataPointCount_0 <= 0)\n tmp$ = new ClosedRange(0.0, 0.0);\n else if (this.myConstantAes_0.contains_11rb$(aes)) {\n var v = ensureNotNull(this.numericValues_vktour$(aes).iterator().next());\n if (isFinite(v)) {\n tmp$ = new ClosedRange(v, v);\n } else\n tmp$ = null;\n } else {\n var values = this.numericValues_vktour$(aes);\n tmp$ = data.SeriesUtil.range_l63ks6$(values);\n }\n var r = tmp$;\n this.myRangeByNumericAes_0.put_xwzc9p$(aes, r);\n }return this.myRangeByNumericAes_0.get_11rb$(aes);\n };\n AestheticsBuilder$MyAesthetics.prototype.overallRange_vktour$ = function (aes) {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myOverallRangeByNumericAes_0.get_11rb$(aes)) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init(('Overall range is unknown for ' + aes).toString());\n }\n return tmp$_0;\n };\n AestheticsBuilder$MyAesthetics.prototype.resolution_594811$ = function (aes, naValue) {\n var tmp$;\n if (!this.myResolutionByAes_0.containsKey_11rb$(aes)) {\n if (this.myConstantAes_0.contains_11rb$(aes))\n tmp$ = 0.0;\n else {\n var values = this.numericValues_vktour$(aes);\n tmp$ = data.SeriesUtil.resolution_u62iiw$(values, naValue);\n }\n var resolution = tmp$;\n this.myResolutionByAes_0.put_xwzc9p$(aes, resolution);\n }return ensureNotNull(this.myResolutionByAes_0.get_11rb$(aes));\n };\n function AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral(this$MyAesthetics, closure$aes) {\n this.this$MyAesthetics = this$MyAesthetics;\n this.closure$aes = closure$aes;\n }\n AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$AesIterator(this.this$MyAesthetics.myDataPointCount_0, this.this$MyAesthetics.aes_31786j$(this.closure$aes));\n };\n AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.numericValues_vktour$ = function (aes) {\n if (!aes.isNumeric) {\n var message = 'Numeric aes is expected: ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }return new AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral(this, aes);\n };\n function AestheticsBuilder$MyAesthetics$groups$ObjectLiteral(this$MyAesthetics) {\n this.this$MyAesthetics = this$MyAesthetics;\n }\n AestheticsBuilder$MyAesthetics$groups$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$AesIterator(this.this$MyAesthetics.myDataPointCount_0, this.this$MyAesthetics.group);\n };\n AestheticsBuilder$MyAesthetics$groups$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.groups = function () {\n return new AestheticsBuilder$MyAesthetics$groups$ObjectLiteral(this);\n };\n AestheticsBuilder$MyAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyAesthetics',\n interfaces: [Aesthetics]\n };\n function AestheticsBuilder$MyDataPointsIterator(myLength, myAesthetics) {\n this.myLength_0 = myLength;\n this.myAesthetics_0 = myAesthetics;\n this.myIndex_0 = 0;\n }\n AestheticsBuilder$MyDataPointsIterator.prototype.hasNext = function () {\n return this.myIndex_0 < this.myLength_0;\n };\n AestheticsBuilder$MyDataPointsIterator.prototype.next = function () {\n var tmp$;\n if (this.hasNext()) {\n return this.myAesthetics_0.dataPointAt_za3lpa$((tmp$ = this.myIndex_0, this.myIndex_0 = tmp$ + 1 | 0, tmp$));\n }throw new NoSuchElementException('index=' + this.myIndex_0);\n };\n AestheticsBuilder$MyDataPointsIterator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyDataPointsIterator',\n interfaces: [Iterator]\n };\n function AestheticsBuilder$AesIterator(myLength, myAes) {\n this.myLength_0 = myLength;\n this.myAes_0 = myAes;\n this.myIndex_0 = 0;\n }\n AestheticsBuilder$AesIterator.prototype.hasNext = function () {\n return this.myIndex_0 < this.myLength_0;\n };\n AestheticsBuilder$AesIterator.prototype.next = function () {\n var tmp$;\n if (this.hasNext()) {\n return this.myAes_0((tmp$ = this.myIndex_0, this.myIndex_0 = tmp$ + 1 | 0, tmp$));\n }throw new NoSuchElementException('index=' + this.myIndex_0);\n };\n AestheticsBuilder$AesIterator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AesIterator',\n interfaces: [Iterator]\n };\n function AestheticsBuilder$MyDataPointAesthetics(myIndex, myAesthetics) {\n this.myIndex_0 = myIndex;\n this.myAesthetics_0 = myAesthetics;\n }\n AestheticsBuilder$MyDataPointAesthetics.prototype.index = function () {\n return ensureNotNull(this.myIndex_0);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.x = function () {\n return this.get_31786j$(Aes$Companion_getInstance().X);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.y = function () {\n return this.get_31786j$(Aes$Companion_getInstance().Y);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.z = function () {\n return this.get_31786j$(Aes$Companion_getInstance().Z);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.ymin = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YMIN);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.ymax = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YMAX);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.color = function () {\n return this.get_31786j$(Aes$Companion_getInstance().COLOR);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.fill = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FILL);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.alpha = function () {\n return this.get_31786j$(Aes$Companion_getInstance().ALPHA);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.shape = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SHAPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.lineType = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LINETYPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.size = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SIZE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.width = function () {\n return this.get_31786j$(Aes$Companion_getInstance().WIDTH);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.height = function () {\n return this.get_31786j$(Aes$Companion_getInstance().HEIGHT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.weight = function () {\n return this.get_31786j$(Aes$Companion_getInstance().WEIGHT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.intercept = function () {\n return this.get_31786j$(Aes$Companion_getInstance().INTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.slope = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SLOPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.interceptX = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XINTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.interceptY = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YINTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.lower = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LOWER);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.middle = function () {\n return this.get_31786j$(Aes$Companion_getInstance().MIDDLE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.upper = function () {\n return this.get_31786j$(Aes$Companion_getInstance().UPPER);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.frame = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FRAME);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.speed = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SPEED);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.flow = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FLOW);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xmin = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XMIN);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xmax = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XMAX);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xend = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XEND);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.yend = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YEND);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.label = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LABEL);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.family = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FAMILY);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.fontface = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FONTFACE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.hjust = function () {\n return this.get_31786j$(Aes$Companion_getInstance().HJUST);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.vjust = function () {\n return this.get_31786j$(Aes$Companion_getInstance().VJUST);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.angle = function () {\n return this.get_31786j$(Aes$Companion_getInstance().ANGLE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.symX = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SYM_X);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.symY = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SYM_Y);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.group = function () {\n return this.myAesthetics_0.group(ensureNotNull(this.myIndex_0));\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.numeric_vktour$ = function (aes) {\n return this.get_31786j$(aes);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.get_31786j$ = function (aes) {\n return this.myAesthetics_0.aes_31786j$(aes)(ensureNotNull(this.myIndex_0));\n };\n AestheticsBuilder$MyDataPointAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyDataPointAesthetics',\n interfaces: [DataPointAesthetics]\n };\n function AestheticsBuilder$ArrayAes(myVal) {\n this.myVal_0 = myVal;\n }\n AestheticsBuilder$ArrayAes.prototype.apply_11rb$ = function (value) {\n return this.myVal_0[value];\n };\n AestheticsBuilder$ArrayAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ArrayAes',\n interfaces: [Function]\n };\n function AestheticsBuilder$MapperAes(myL, myF) {\n this.myL_0 = myL;\n this.myF_0 = myF;\n }\n AestheticsBuilder$MapperAes.prototype.apply_11rb$ = function (value) {\n return this.myF_0(this.myL_0.get_za3lpa$(value));\n };\n AestheticsBuilder$MapperAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapperAes',\n interfaces: [Function]\n };\n function AestheticsBuilder$Companion() {\n AestheticsBuilder$Companion_instance = this;\n }\n function AestheticsBuilder$Companion$constant$lambda(closure$v) {\n return function (it) {\n return closure$v;\n };\n }\n AestheticsBuilder$Companion.prototype.constant_mh5how$ = function (v) {\n return AestheticsBuilder$Companion$constant$lambda(v);\n };\n function AestheticsBuilder$Companion$array$lambda(closure$v) {\n return function (value) {\n return closure$v[value];\n };\n }\n AestheticsBuilder$Companion.prototype.array_ro6dgy$ = function (v) {\n return AestheticsBuilder$Companion$array$lambda(v);\n };\n function AestheticsBuilder$Companion$collection$lambda(closure$v) {\n return function (value) {\n return collect.Iterables.get_7iig3d$(closure$v, value);\n };\n }\n AestheticsBuilder$Companion.prototype.collection_mqih57$ = function (v) {\n return AestheticsBuilder$Companion$collection$lambda(v);\n };\n function AestheticsBuilder$Companion$listMapper$lambda(closure$f, closure$v) {\n return function (value) {\n return closure$f(closure$v.get_za3lpa$(value));\n };\n }\n AestheticsBuilder$Companion.prototype.listMapper_sedzz5$ = function (v, f) {\n return AestheticsBuilder$Companion$listMapper$lambda(f, v);\n };\n AestheticsBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AestheticsBuilder$Companion_instance = null;\n function AestheticsBuilder$Companion_getInstance() {\n if (AestheticsBuilder$Companion_instance === null) {\n new AestheticsBuilder$Companion();\n }return AestheticsBuilder$Companion_instance;\n }\n AestheticsBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AestheticsBuilder',\n interfaces: []\n };\n function AestheticsDefaults() {\n AestheticsDefaults$Companion_getInstance();\n var $receiver = new TypedKeyHashMap();\n var tmp$, tmp$_0;\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n $receiver.put_ev6mlr$(Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE(), AesInitValue_getInstance().get_31786j$(aes));\n }\n this.myDefaults_vq25h0$_0 = $receiver;\n this.myDefaultsInLegend_yhkzvq$_0 = new TypedKeyHashMap();\n }\n AestheticsDefaults.prototype.update_bbdhip$ = function (aes, defaultValue) {\n this.myDefaults_vq25h0$_0.put_ev6mlr$(aes, defaultValue);\n return this;\n };\n AestheticsDefaults.prototype.updateInLegend_bbdhip$ = function (aes, defaultValue) {\n this.myDefaultsInLegend_yhkzvq$_0.put_ev6mlr$(aes, defaultValue);\n return this;\n };\n AestheticsDefaults.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return false;\n };\n AestheticsDefaults.prototype.defaultValue_31786j$ = function (aes) {\n return this.myDefaults_vq25h0$_0.get_ex36zt$(aes);\n };\n AestheticsDefaults.prototype.defaultValueInLegend_31786j$ = function (aes) {\n var tmp$;\n if (this.myDefaultsInLegend_yhkzvq$_0.containsKey_ex36zt$(aes)) {\n tmp$ = this.myDefaultsInLegend_yhkzvq$_0.get_ex36zt$(aes);\n } else\n tmp$ = this.defaultValue_31786j$(aes);\n return tmp$;\n };\n function AestheticsDefaults$Companion() {\n AestheticsDefaults$Companion_instance = this;\n }\n AestheticsDefaults$Companion.prototype.point = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 2.0).updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n };\n AestheticsDefaults$Companion.prototype.path = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.line = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.abline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.hline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.vline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.smooth = function () {\n return this.path().update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.MAGENTA).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.BLACK);\n };\n function AestheticsDefaults$Companion$bar$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$bar$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.bar = function () {\n return (new AestheticsDefaults$Companion$bar$ObjectLiteral()).update_bbdhip$(Aes$Companion_getInstance().WIDTH, 0.9).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n function AestheticsDefaults$Companion$histogram$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$histogram$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.histogram = function () {\n return (new AestheticsDefaults$Companion$histogram$ObjectLiteral()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.tile = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.bin2d = function () {\n return this.tile();\n };\n AestheticsDefaults$Companion.prototype.errorBar = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.BLACK);\n };\n AestheticsDefaults$Companion.prototype.crossBar = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().WIDTH, 0.9).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.BLACK).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.WHITE);\n };\n AestheticsDefaults$Companion.prototype.lineRange = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.pointRange = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.polygon = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.map = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 0.2).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.GRAY).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.boxplot = function () {\n return this.crossBar();\n };\n AestheticsDefaults$Companion.prototype.livemap_cx3y7u$ = function (displayMode) {\n var tmp$;\n switch (displayMode.name) {\n case 'POINT':\n tmp$ = this.point().updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n break;\n case 'BAR':\n tmp$ = this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 40.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n break;\n case 'PIE':\n tmp$ = this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 20.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT).updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n AestheticsDefaults$Companion.prototype.ribbon = function () {\n return this.base_0();\n };\n function AestheticsDefaults$Companion$area$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$area$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.area = function () {\n return new AestheticsDefaults$Companion$area$ObjectLiteral();\n };\n AestheticsDefaults$Companion.prototype.density = function () {\n return this.area().update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.contour = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.contourf = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 0.0);\n };\n AestheticsDefaults$Companion.prototype.density2d = function () {\n return this.contour();\n };\n AestheticsDefaults$Companion.prototype.density2df = function () {\n return this.contourf();\n };\n AestheticsDefaults$Companion.prototype.jitter = function () {\n return this.point();\n };\n AestheticsDefaults$Companion.prototype.freqpoly = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.step = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.rect = function () {\n return this.polygon();\n };\n AestheticsDefaults$Companion.prototype.segment = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.text = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 7.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.parseHex_61zpoe$('#3d3d3d'));\n };\n AestheticsDefaults$Companion.prototype.raster = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.image = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.base_0 = function () {\n return new AestheticsDefaults();\n };\n AestheticsDefaults$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AestheticsDefaults$Companion_instance = null;\n function AestheticsDefaults$Companion_getInstance() {\n if (AestheticsDefaults$Companion_instance === null) {\n new AestheticsDefaults$Companion();\n }return AestheticsDefaults$Companion_instance;\n }\n AestheticsDefaults.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AestheticsDefaults',\n interfaces: []\n };\n function AestheticsUtil() {\n AestheticsUtil_instance = this;\n this.ALPHA_CONTROLS_BOTH_8be2vx$ = false;\n }\n AestheticsUtil.prototype.fill_edjgex$ = function (filled, solid, p) {\n if (filled) {\n return ensureNotNull(p.fill());\n } else if (solid) {\n return ensureNotNull(p.color());\n }return Color.Companion.TRANSPARENT;\n };\n AestheticsUtil.prototype.decorate_l4vgcq$ = function (shape, filled, solid, p, strokeWidth) {\n var fill = this.fill_edjgex$(filled, solid, p);\n var stroke = ensureNotNull(p.color());\n var fillAlpha = 0.0;\n if (filled || solid) {\n fillAlpha = this.alpha_il6rhx$(fill, p);\n }var strokeAlpha = 0.0;\n if (strokeWidth > 0) {\n strokeAlpha = this.alpha_il6rhx$(stroke, p);\n }shape.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n AestheticsUtil.prototype.alpha_il6rhx$ = function (color, p) {\n var tmp$;\n if (values.Colors.solid_98b62m$(color)) {\n tmp$ = ensureNotNull(p.alpha());\n } else\n tmp$ = svg.SvgUtils.alpha2opacity_za3lpa$(color.alpha);\n return tmp$;\n };\n AestheticsUtil.prototype.strokeWidth_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2.0;\n };\n AestheticsUtil.prototype.textSize_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2;\n };\n AestheticsUtil.prototype.updateStroke_g0plfl$ = function (shape, p, applyAlpha) {\n shape.strokeColor().set_11rb$(p.color());\n if (values.Colors.solid_98b62m$(ensureNotNull(p.color())) && applyAlpha) {\n shape.strokeOpacity().set_11rb$(p.alpha());\n }};\n AestheticsUtil.prototype.updateFill_v4tjbc$ = function (shape, p) {\n shape.fillColor().set_11rb$(p.fill());\n if (values.Colors.solid_98b62m$(ensureNotNull(p.fill()))) {\n shape.fillOpacity().set_11rb$(p.alpha());\n }};\n AestheticsUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AestheticsUtil',\n interfaces: []\n };\n var AestheticsUtil_instance = null;\n function AestheticsUtil_getInstance() {\n if (AestheticsUtil_instance === null) {\n new AestheticsUtil();\n }return AestheticsUtil_instance;\n }\n function TypedIndexFunctionMap(indexFunctionMap) {\n this.myMap_0 = indexFunctionMap;\n }\n TypedIndexFunctionMap.prototype.get_31786j$ = function (aes) {\n var tmp$;\n return typeof (tmp$ = this.myMap_0.get_11rb$(aes)) === 'function' ? tmp$ : throwCCE();\n };\n TypedIndexFunctionMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedIndexFunctionMap',\n interfaces: []\n };\n function Coords() {\n Coords_instance = this;\n }\n Coords.prototype.create_wd6eaa$ = function (xRange, yRange, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n var origin = new DoubleVector(this.originX_0(xRange), this.originY_0(yRange));\n return this.create_e5yqp7$(origin, xLim, yLim);\n };\n Coords.prototype.create_e5yqp7$ = function (origin, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new DefaultCoordinateSystem(this.toClientOffsetX_0(origin.x), this.toClientOffsetY_0(origin.y), this.fromClientOffsetX_0(origin.x), this.fromClientOffsetY_0(origin.y), xLim, yLim);\n };\n Coords.prototype.toClientOffsetX_4fzjta$ = function (xRange) {\n return this.toClientOffsetX_0(this.originX_0(xRange));\n };\n Coords.prototype.toClientOffsetY_4fzjta$ = function (yRange) {\n return this.toClientOffsetY_0(this.originY_0(yRange));\n };\n Coords.prototype.originX_0 = function (xRange) {\n return -xRange.lowerEnd;\n };\n Coords.prototype.originY_0 = function (yRange) {\n return yRange.upperEnd;\n };\n function Coords$toClientOffsetX$lambda(closure$originX) {\n return function (x) {\n return closure$originX + x;\n };\n }\n Coords.prototype.toClientOffsetX_0 = function (originX) {\n return Coords$toClientOffsetX$lambda(originX);\n };\n function Coords$fromClientOffsetX$lambda(closure$originX) {\n return function (x) {\n return x - closure$originX;\n };\n }\n Coords.prototype.fromClientOffsetX_0 = function (originX) {\n return Coords$fromClientOffsetX$lambda(originX);\n };\n function Coords$toClientOffsetY$lambda(closure$originY) {\n return function (y) {\n return closure$originY - y;\n };\n }\n Coords.prototype.toClientOffsetY_0 = function (originY) {\n return Coords$toClientOffsetY$lambda(originY);\n };\n function Coords$fromClientOffsetY$lambda(closure$originY) {\n return function (y) {\n return closure$originY - y;\n };\n }\n Coords.prototype.fromClientOffsetY_0 = function (originY) {\n return Coords$fromClientOffsetY$lambda(originY);\n };\n Coords.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Coords',\n interfaces: []\n };\n var Coords_instance = null;\n function Coords_getInstance() {\n if (Coords_instance === null) {\n new Coords();\n }return Coords_instance;\n }\n function DefaultCoordinateSystem(myToClientOffsetX, myToClientOffsetY, myFromClientOffsetX, myFromClientOffsetY, xLim, yLim) {\n this.myToClientOffsetX_0 = myToClientOffsetX;\n this.myToClientOffsetY_0 = myToClientOffsetY;\n this.myFromClientOffsetX_0 = myFromClientOffsetX;\n this.myFromClientOffsetY_0 = myFromClientOffsetY;\n this.xLim_0 = xLim;\n this.yLim_0 = yLim;\n }\n DefaultCoordinateSystem.prototype.toClient_gpjtzr$ = function (p) {\n return new DoubleVector(this.myToClientOffsetX_0(p.x), this.myToClientOffsetY_0(p.y));\n };\n DefaultCoordinateSystem.prototype.fromClient_gpjtzr$ = function (p) {\n return new DoubleVector(this.myFromClientOffsetX_0(p.x), this.myFromClientOffsetY_0(p.y));\n };\n DefaultCoordinateSystem.prototype.isPointInLimits_k2qmv6$$default = function (p, isClient) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var coord = isClient ? this.fromClient_gpjtzr$(p) : p;\n return ((tmp$_0 = (tmp$ = this.xLim_0) != null ? tmp$.contains_mef7kx$(coord.x) : null) != null ? tmp$_0 : true) && ((tmp$_2 = (tmp$_1 = this.yLim_0) != null ? tmp$_1.contains_mef7kx$(coord.y) : null) != null ? tmp$_2 : true);\n };\n DefaultCoordinateSystem.prototype.isRectInLimits_fd842m$$default = function (rect, isClient) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var r = isClient ? (new GeomCoord(this)).fromClient_wthzt5$(rect) : rect;\n return ((tmp$_0 = (tmp$ = this.xLim_0) != null ? tmp$.encloses_d226ot$(r.xRange()) : null) != null ? tmp$_0 : true) && ((tmp$_2 = (tmp$_1 = this.yLim_0) != null ? tmp$_1.encloses_d226ot$(r.yRange()) : null) != null ? tmp$_2 : true);\n };\n DefaultCoordinateSystem.prototype.isPathInLimits_f6t8kh$$default = function (path, isClient) {\n var any$result;\n any$break: do {\n var tmp$;\n if (Kotlin.isType(path, Collection) && path.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$ = path.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.isPointInLimits_k2qmv6$(element, isClient)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n return any$result;\n };\n DefaultCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$$default = function (polygon, isClient) {\n var bbox = geometry.DoubleRectangles.boundingBox_qdtdbw$(polygon);\n return this.isRectInLimits_fd842m$(bbox, isClient);\n };\n Object.defineProperty(DefaultCoordinateSystem.prototype, 'xClientLimit', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.xLim_0) != null ? this.convertRange_0(tmp$, this.myToClientOffsetX_0) : null;\n }\n });\n Object.defineProperty(DefaultCoordinateSystem.prototype, 'yClientLimit', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.yLim_0) != null ? this.convertRange_0(tmp$, this.myToClientOffsetY_0) : null;\n }\n });\n DefaultCoordinateSystem.prototype.convertRange_0 = function (range, transform) {\n var l = transform(range.lowerEnd);\n var u = transform(range.upperEnd);\n return new ClosedRange(collect.Comparables.min_sdesaw$(l, u), collect.Comparables.max_sdesaw$(l, u));\n };\n DefaultCoordinateSystem.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultCoordinateSystem',\n interfaces: [CoordinateSystem]\n };\n function Projection() {\n }\n Projection.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Projection',\n interfaces: []\n };\n function DataFrameUtil() {\n DataFrameUtil_instance = this;\n }\n DataFrameUtil.prototype.transformVarFor_896ixz$ = function (aes) {\n return TransformVar_getInstance().forAes_896ixz$(aes);\n };\n DataFrameUtil.prototype.applyTransform_xaiv89$ = function (data, var_0, aes, scale) {\n var transformVar = this.transformVarFor_896ixz$(aes);\n return this.applyTransform_0(data, var_0, transformVar, scale);\n };\n DataFrameUtil.prototype.applyTransform_0 = function (data, variable, transformVar, scale) {\n var transformSource = this.getTransformSource_0(data, variable, scale);\n var transformResult = scale.transform.apply_9ma18$(transformSource);\n return data.builder().putNumeric_s1rqo9$(transformVar, transformResult).build();\n };\n DataFrameUtil.prototype.getTransformSource_0 = function (data, variable, scale) {\n var transformSource = data.get_8xm3sj$(variable);\n return ScaleUtil_getInstance().cleanUpTransformSource_2jj1lg$(transformSource, scale);\n };\n DataFrameUtil.prototype.hasVariable_vede35$ = function (data, varName) {\n var tmp$;\n tmp$ = data.variables().iterator();\n while (tmp$.hasNext()) {\n var var_0 = tmp$.next();\n if (equals(varName, var_0.name)) {\n return true;\n }}\n return false;\n };\n DataFrameUtil.prototype.findVariableOrFail_vede35$ = function (data, varName) {\n var tmp$;\n tmp$ = data.variables().iterator();\n while (tmp$.hasNext()) {\n var var_0 = tmp$.next();\n if (equals(varName, var_0.name)) {\n return var_0;\n }}\n var tmp$_0 = \"Variable not found: '\" + varName + \"'. Variables in data frame: \";\n var $receiver = data.variables();\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination.add_11rb$(\"'\" + item.name + \"'\");\n }\n throw IllegalArgumentException_init(tmp$_0 + destination);\n };\n DataFrameUtil.prototype.isNumeric_vede35$ = function (data, varName) {\n return data.isNumeric_8xm3sj$(this.findVariableOrFail_vede35$(data, varName));\n };\n function DataFrameUtil$sortedCopy$lambda(o1, o2) {\n return Kotlin.compareTo(o1.name, o2.name);\n }\n DataFrameUtil.prototype.sortedCopy_jgbhqw$ = function (variables) {\n var ordering = Ordering.Companion.from_iajr8b$(new Comparator(DataFrameUtil$sortedCopy$lambda));\n return ordering.sortedCopy_m5x2f4$(variables);\n };\n DataFrameUtil.prototype.variables_dhhkv7$ = function (df) {\n var $receiver = df.variables();\n var keySelector = getPropertyCallableRef('name', 1, function ($receiver) {\n return $receiver.name;\n });\n var capacity = coerceAtLeast(mapCapacity(collectionSizeOrDefault($receiver, 10)), 16);\n var destination = LinkedHashMap_init_0(capacity);\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n destination.put_xwzc9p$(keySelector(element), element);\n }\n return destination;\n };\n function DataFrameUtil$appendReplace$put(this$DataFrameUtil) {\n return function ($receiver, destVars, df) {\n var this$DataFrameUtil_0 = this$DataFrameUtil;\n var tmp$;\n tmp$ = destVars.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n var srcVar = this$DataFrameUtil_0.findVariableOrFail_vede35$(df, element.name);\n tmp$_0 = df.isNumeric_8xm3sj$(srcVar);\n if (tmp$_0 === true)\n $receiver.putNumeric_s1rqo9$(element, df.getNumeric_8xm3sj$(srcVar));\n else if (tmp$_0 === false)\n $receiver.putDiscrete_2l962d$(element, df.get_8xm3sj$(srcVar));\n else\n Kotlin.noWhenBranchMatched();\n }\n return $receiver;\n };\n }\n DataFrameUtil.prototype.appendReplace_yxlle4$ = function (df0, df1) {\n var put = DataFrameUtil$appendReplace$put(this);\n var tmp$ = DataFrame$DataFrame$Builder_init();\n var $receiver = df0.variables();\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var $receiver_0 = this.variables_dhhkv7$(df1);\n var key = element.name;\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = $receiver_0, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(key))\n destination.add_11rb$(element);\n }\n var tmp$_2 = put(tmp$, destination, df0);\n var $receiver_1 = df0.variables();\n var destination_0 = ArrayList_init();\n var tmp$_3;\n tmp$_3 = $receiver_1.iterator();\n while (tmp$_3.hasNext()) {\n var element_0 = tmp$_3.next();\n var $receiver_2 = this.variables_dhhkv7$(df1);\n var key_0 = element_0.name;\n var tmp$_4;\n if ((Kotlin.isType(tmp$_4 = $receiver_2, Map) ? tmp$_4 : throwCCE()).containsKey_11rb$(key_0))\n destination_0.add_11rb$(element_0);\n }\n var tmp$_5 = put(tmp$_2, destination_0, df1);\n var $receiver_3 = df1.variables();\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = $receiver_3.iterator();\n while (tmp$_6.hasNext()) {\n var element_1 = tmp$_6.next();\n var $receiver_4 = this.variables_dhhkv7$(df0);\n var key_1 = element_1.name;\n var tmp$_7;\n if (!(Kotlin.isType(tmp$_7 = $receiver_4, Map) ? tmp$_7 : throwCCE()).containsKey_11rb$(key_1))\n destination_1.add_11rb$(element_1);\n }\n return put(tmp$_5, destination_1, df1).build();\n };\n DataFrameUtil.prototype.toMap_dhhkv7$ = function (df) {\n var tmp$;\n var result = HashMap_init();\n var variables = df.variables();\n tmp$ = variables.iterator();\n while (tmp$.hasNext()) {\n var var_0 = tmp$.next();\n var key = var_0.name;\n var value = df.get_8xm3sj$(var_0);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n DataFrameUtil.prototype.fromMap_bkhwtg$ = function (map) {\n var tmp$;\n var frameBuilder = DataFrame$DataFrame$Builder_init();\n tmp$ = map.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var key = tmp$_0.key;\n var value = tmp$_0.value;\n if (!(typeof key === 'string')) {\n var message = 'Map to data-frame: key expected a String but was ' + Kotlin.getKClassFromExpression(ensureNotNull(key)).simpleName + ' : ' + toString(key);\n throw IllegalArgumentException_init(message.toString());\n }if (!Kotlin.isType(value, List)) {\n var message_0 = 'Map to data-frame: value expected a List but was ' + Kotlin.getKClassFromExpression(ensureNotNull(value)).simpleName + ' : ' + toString(value);\n throw IllegalArgumentException_init(message_0.toString());\n }frameBuilder.put_2l962d$(this.createVariable_puj7f4$(key), value);\n }\n return frameBuilder.build();\n };\n DataFrameUtil.prototype.createVariable_puj7f4$ = function (name, label) {\n if (label === void 0)\n label = name;\n var tmp$;\n if (TransformVar_getInstance().isTransformVar_61zpoe$(name))\n tmp$ = TransformVar_getInstance().get_61zpoe$(name);\n else if (Stats_getInstance().isStatVar_61zpoe$(name))\n tmp$ = Stats_getInstance().statVar_61zpoe$(name);\n else if (Dummies_getInstance().isDummyVar_61zpoe$(name))\n tmp$ = Dummies_getInstance().newDummy_61zpoe$(name);\n else\n tmp$ = new DataFrame$Variable(name, DataFrame$Variable$Source$ORIGIN_getInstance(), label);\n return tmp$;\n };\n DataFrameUtil.prototype.getSummaryText_dhhkv7$ = function (df) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = df.variables().iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n sb.append_pdl1vj$(variable.toSummaryString()).append_pdl1vj$(' numeric: ' + toString(df.isNumeric_8xm3sj$(variable))).append_pdl1vj$(' size: ' + toString(df.get_8xm3sj$(variable).size)).append_s8itvh$(10);\n }\n return sb.toString();\n };\n DataFrameUtil.prototype.removeAllExcept_dipqvu$ = function (df, keepNames) {\n var tmp$;\n var b = df.builder();\n tmp$ = df.variables().iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n if (!keepNames.contains_11rb$(variable.name)) {\n b.remove_8xm3sj$(variable);\n }}\n return b.build();\n };\n DataFrameUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DataFrameUtil',\n interfaces: []\n };\n var DataFrameUtil_instance = null;\n function DataFrameUtil_getInstance() {\n if (DataFrameUtil_instance === null) {\n new DataFrameUtil();\n }return DataFrameUtil_instance;\n }\n function Dummies() {\n Dummies_instance = this;\n this.PREFIX_0 = '__';\n }\n Dummies.prototype.isDummyVar_61zpoe$ = function (varName) {\n if (!base.Strings.isNullOrEmpty_pdl1vj$(varName) && varName.length > 2 && startsWith(varName, this.PREFIX_0)) {\n var numStr = varName.substring(2);\n return Regex_init('[0-9]+').matches_6bul2c$(numStr);\n }return false;\n };\n Dummies.prototype.dummyNames_za3lpa$ = function (count) {\n var l = ArrayList_init();\n for (var i = 0; i < count; i++) {\n l.add_11rb$(this.PREFIX_0 + toString(i));\n }\n return l;\n };\n Dummies.prototype.newDummy_61zpoe$ = function (varName) {\n if (!this.isDummyVar_61zpoe$(varName)) {\n var message = 'Not a dummy var name';\n throw IllegalArgumentException_init(message.toString());\n }return new DataFrame$Variable(varName, DataFrame$Variable$Source$ORIGIN_getInstance(), '');\n };\n Dummies.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Dummies',\n interfaces: []\n };\n var Dummies_instance = null;\n function Dummies_getInstance() {\n if (Dummies_instance === null) {\n new Dummies();\n }return Dummies_instance;\n }\n function TransformVar() {\n TransformVar_instance = this;\n this.X = new DataFrame$Variable('transform.X', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.Y = new DataFrame$Variable('transform.Y', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.Z = new DataFrame$Variable('transform.Z', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YMIN = new DataFrame$Variable('transform.YMIN', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YMAX = new DataFrame$Variable('transform.YMAX', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.COLOR = new DataFrame$Variable('transform.COLOR', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FILL = new DataFrame$Variable('transform.FILL', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.ALPHA = new DataFrame$Variable('transform.ALPHA', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SHAPE = new DataFrame$Variable('transform.SHAPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LINETYPE = new DataFrame$Variable('transform.LINETYPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SIZE = new DataFrame$Variable('transform.SIZE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.WIDTH = new DataFrame$Variable('transform.WIDTH', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.HEIGHT = new DataFrame$Variable('transform.HEIGHT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.WEIGHT = new DataFrame$Variable('transform.WEIGHT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.INTERCEPT = new DataFrame$Variable('transform.INTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SLOPE = new DataFrame$Variable('transform.SLOPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XINTERCEPT = new DataFrame$Variable('transform.XINTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YINTERCEPT = new DataFrame$Variable('transform.YINTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LOWER = new DataFrame$Variable('transform.LOWER', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.MIDDLE = new DataFrame$Variable('transform.MIDDLE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.UPPER = new DataFrame$Variable('transform.UPPER', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FRAME = new DataFrame$Variable('transform.FRAME', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SPEED = new DataFrame$Variable('transform.SPEED', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FLOW = new DataFrame$Variable('transform.FLOW', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XMIN = new DataFrame$Variable('transform.XMIN', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XMAX = new DataFrame$Variable('transform.XMAX', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XEND = new DataFrame$Variable('transform.XEND', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YEND = new DataFrame$Variable('transform.YEND', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LABEL = new DataFrame$Variable('transform.LABEL', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FONT_FAMILY = new DataFrame$Variable('transform.FONT_FAMILY', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FONT_FACE = new DataFrame$Variable('transform.FONT_FACE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.HJUST = new DataFrame$Variable('transform.HJUST', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.VJUST = new DataFrame$Variable('transform.VJUST', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.ANGLE = new DataFrame$Variable('transform.ANGLE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SYM_X = new DataFrame$Variable('transform.SYM_X', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SYM_Y = new DataFrame$Variable('transform.SYM_Y', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.VAR_BY_AES_0 = new TransformVar$TransformVarByAes();\n this.VARS_0 = null;\n var tmp$;\n var varByName = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var var_0 = this.VAR_BY_AES_0.visit_896ixz$(aes);\n var key = var_0.name;\n varByName.put_xwzc9p$(key, var_0);\n }\n this.VARS_0 = varByName;\n }\n TransformVar.prototype.isTransformVar_61zpoe$ = function (varName) {\n return this.VARS_0.containsKey_11rb$(varName);\n };\n TransformVar.prototype.get_61zpoe$ = function (varName) {\n if (!this.VARS_0.containsKey_11rb$(varName)) {\n var message = 'Unknown transform variable ' + varName;\n throw IllegalStateException_init(message.toString());\n }return ensureNotNull(this.VARS_0.get_11rb$(varName));\n };\n TransformVar.prototype.forAes_896ixz$ = function (aes) {\n return this.VAR_BY_AES_0.visit_896ixz$(aes);\n };\n function TransformVar$TransformVarByAes() {\n AesVisitor.call(this);\n }\n TransformVar$TransformVarByAes.prototype.x = function () {\n return TransformVar_getInstance().X;\n };\n TransformVar$TransformVarByAes.prototype.y = function () {\n return TransformVar_getInstance().Y;\n };\n TransformVar$TransformVarByAes.prototype.z = function () {\n return TransformVar_getInstance().Z;\n };\n TransformVar$TransformVarByAes.prototype.ymin = function () {\n return TransformVar_getInstance().YMIN;\n };\n TransformVar$TransformVarByAes.prototype.ymax = function () {\n return TransformVar_getInstance().YMAX;\n };\n TransformVar$TransformVarByAes.prototype.color = function () {\n return TransformVar_getInstance().COLOR;\n };\n TransformVar$TransformVarByAes.prototype.fill = function () {\n return TransformVar_getInstance().FILL;\n };\n TransformVar$TransformVarByAes.prototype.alpha = function () {\n return TransformVar_getInstance().ALPHA;\n };\n TransformVar$TransformVarByAes.prototype.shape = function () {\n return TransformVar_getInstance().SHAPE;\n };\n TransformVar$TransformVarByAes.prototype.lineType = function () {\n return TransformVar_getInstance().LINETYPE;\n };\n TransformVar$TransformVarByAes.prototype.size = function () {\n return TransformVar_getInstance().SIZE;\n };\n TransformVar$TransformVarByAes.prototype.width = function () {\n return TransformVar_getInstance().WIDTH;\n };\n TransformVar$TransformVarByAes.prototype.height = function () {\n return TransformVar_getInstance().HEIGHT;\n };\n TransformVar$TransformVarByAes.prototype.weight = function () {\n return TransformVar_getInstance().WEIGHT;\n };\n TransformVar$TransformVarByAes.prototype.intercept = function () {\n return TransformVar_getInstance().INTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.slope = function () {\n return TransformVar_getInstance().SLOPE;\n };\n TransformVar$TransformVarByAes.prototype.interceptX = function () {\n return TransformVar_getInstance().XINTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.interceptY = function () {\n return TransformVar_getInstance().YINTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.lower = function () {\n return TransformVar_getInstance().LOWER;\n };\n TransformVar$TransformVarByAes.prototype.middle = function () {\n return TransformVar_getInstance().MIDDLE;\n };\n TransformVar$TransformVarByAes.prototype.upper = function () {\n return TransformVar_getInstance().UPPER;\n };\n TransformVar$TransformVarByAes.prototype.frame = function () {\n return TransformVar_getInstance().FRAME;\n };\n TransformVar$TransformVarByAes.prototype.speed = function () {\n return TransformVar_getInstance().SPEED;\n };\n TransformVar$TransformVarByAes.prototype.flow = function () {\n return TransformVar_getInstance().FLOW;\n };\n TransformVar$TransformVarByAes.prototype.xmin = function () {\n return TransformVar_getInstance().XMIN;\n };\n TransformVar$TransformVarByAes.prototype.xmax = function () {\n return TransformVar_getInstance().XMAX;\n };\n TransformVar$TransformVarByAes.prototype.xend = function () {\n return TransformVar_getInstance().XEND;\n };\n TransformVar$TransformVarByAes.prototype.yend = function () {\n return TransformVar_getInstance().YEND;\n };\n TransformVar$TransformVarByAes.prototype.label = function () {\n return TransformVar_getInstance().LABEL;\n };\n TransformVar$TransformVarByAes.prototype.family = function () {\n return TransformVar_getInstance().FONT_FAMILY;\n };\n TransformVar$TransformVarByAes.prototype.fontface = function () {\n return TransformVar_getInstance().FONT_FACE;\n };\n TransformVar$TransformVarByAes.prototype.hjust = function () {\n return TransformVar_getInstance().HJUST;\n };\n TransformVar$TransformVarByAes.prototype.vjust = function () {\n return TransformVar_getInstance().VJUST;\n };\n TransformVar$TransformVarByAes.prototype.angle = function () {\n return TransformVar_getInstance().ANGLE;\n };\n TransformVar$TransformVarByAes.prototype.symX = function () {\n return TransformVar_getInstance().SYM_X;\n };\n TransformVar$TransformVarByAes.prototype.symY = function () {\n return TransformVar_getInstance().SYM_Y;\n };\n TransformVar$TransformVarByAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TransformVarByAes',\n interfaces: [AesVisitor]\n };\n TransformVar.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TransformVar',\n interfaces: []\n };\n var TransformVar_instance = null;\n function TransformVar_getInstance() {\n if (TransformVar_instance === null) {\n new TransformVar();\n }return TransformVar_instance;\n }\n function ABLineGeom() {\n ABLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(ABLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n ABLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$, tmp$_0;\n var helper = (new GeomHelper(pos, coord, ctx)).createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var boundaries = collect.Iterables.toList_yl67zr$(viewPort.parts);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.intercept();\n var slope = p.slope();\n if (data.SeriesUtil.allFinite_jma9l8$(intercept, slope)) {\n var p1 = new DoubleVector(viewPort.left, ensureNotNull(intercept) + viewPort.left * ensureNotNull(slope));\n var p2 = new DoubleVector(viewPort.right, p1.y + viewPort.dimension.x * slope);\n var s = new DoubleSegment(p1, p2);\n var lineEnds = HashSet_init_0(2);\n tmp$_0 = boundaries.iterator();\n while (tmp$_0.hasNext()) {\n var boundary = tmp$_0.next();\n var intersection = boundary.intersection_69p9e5$(s);\n if (intersection != null) {\n lineEnds.add_11rb$(intersection);\n if (lineEnds.size === 2) {\n break;\n }}}\n if (lineEnds.size === 2) {\n var it = lineEnds.iterator();\n var line = helper.createLine_ollnar$(it.next(), it.next(), p);\n lines.add_11rb$(line);\n }}}\n var tmp$_1;\n tmp$_1 = lines.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n root.add_26jijc$(element);\n }\n };\n function ABLineGeom$Companion() {\n ABLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ABLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ABLineGeom$Companion_instance = null;\n function ABLineGeom$Companion_getInstance() {\n if (ABLineGeom$Companion_instance === null) {\n new ABLineGeom$Companion();\n }return ABLineGeom$Companion_instance;\n }\n ABLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ABLineGeom',\n interfaces: [GeomBase]\n };\n function AreaGeom() {\n AreaGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n AreaGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().ordered_X_83glv4$(aesthetics.dataPoints());\n };\n AreaGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var paths = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y, GeomUtil_getInstance().TO_LOCATION_X_ZERO);\n reverse(paths);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(paths, root);\n helper.setAlphaEnabled_6taknv$(false);\n var lines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(lines, root);\n this.buildHints_69ip36$_0(aesthetics, pos, coord, ctx);\n };\n function AreaGeom$buildHints$lambda(closure$geomHelper, this$AreaGeom) {\n return function (p) {\n return this$AreaGeom.toClient_6nkesc$_0(closure$geomHelper, p);\n };\n }\n AreaGeom.prototype.buildHints_69ip36$_0 = function (aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var $receiver = this.dataPoints_m7huy5$(aesthetics);\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var x = element.x();\n var y = element.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && coord.isPointInLimits_k2qmv6$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), false))\n destination.add_11rb$(element);\n }\n var dataPoints = destination;\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(AreaGeom$buildHints$lambda(geomHelper, this)), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, false));\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n targetCollector.addPath_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, this.setupTooltipParams_l6g9mh$(multiPointData.aes));\n }\n };\n AreaGeom.prototype.setupTooltipParams_l6g9mh$ = function (aes) {\n return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromFill_l6g9mh$(aes));\n };\n AreaGeom.prototype.toClient_6nkesc$_0 = function (geomHelper, p) {\n var tmp$;\n var coord = GeomUtil_getInstance().TO_LOCATION_X_Y(p);\n if (coord != null) {\n tmp$ = geomHelper.toClient_tkjljq$(coord, p);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n function AreaGeom$Companion() {\n AreaGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n AreaGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AreaGeom$Companion_instance = null;\n function AreaGeom$Companion_getInstance() {\n if (AreaGeom$Companion_instance === null) {\n new AreaGeom$Companion();\n }return AreaGeom$Companion_instance;\n }\n AreaGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AreaGeom',\n interfaces: [GeomBase]\n };\n function BarGeom() {\n BarGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n function BarGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromFill_l6g9mh$(it);\n }\n BarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var rectangles = helper.createRectangles_rezc4r$(BarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n reverse(rectangles);\n var tmp$;\n tmp$ = rectangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n root.add_26jijc$(element);\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(emptyList(), aesthetics, pos, coord, ctx, BarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), BarGeom$buildIntern$lambda);\n };\n function BarGeom$Companion() {\n BarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function BarGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n var x = p.x();\n var y = p.y();\n var w = p.width();\n return !data.SeriesUtil.allFinite_xjrefz$(x, y, w) ? null : GeomUtil_getInstance().rectangleByDataPoint_dyn5n6$(p, closure$ctx);\n };\n }\n BarGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return BarGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n BarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BarGeom$Companion_instance = null;\n function BarGeom$Companion_getInstance() {\n if (BarGeom$Companion_instance === null) {\n new BarGeom$Companion();\n }return BarGeom$Companion_instance;\n }\n BarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BarGeom',\n interfaces: [GeomBase]\n };\n function Bin2dGeom() {\n Bin2dGeom$Companion_getInstance();\n TileGeom.call(this);\n }\n function Bin2dGeom$Companion() {\n Bin2dGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n Bin2dGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Bin2dGeom$Companion_instance = null;\n function Bin2dGeom$Companion_getInstance() {\n if (Bin2dGeom$Companion_instance === null) {\n new Bin2dGeom$Companion();\n }return Bin2dGeom$Companion_instance;\n }\n Bin2dGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bin2dGeom',\n interfaces: [TileGeom]\n };\n function BoxplotGeom() {\n BoxplotGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidline = 1.0;\n this.outlierColor = null;\n this.outlierFill = null;\n this.outlierShape = null;\n this.outlierSize = null;\n }\n Object.defineProperty(BoxplotGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return BoxplotGeom$Companion_getInstance().LEGEND_FACTORY_0;\n }\n });\n function BoxplotGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n BoxplotGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n CrossBarHelper_getInstance().buildBoxes_sm51l0$(root, aesthetics, pos, coord, ctx, BoxplotGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n this.buildLines_0(root, aesthetics, pos, coord, ctx);\n this.buildOutliers_0(root, aesthetics, pos, coord, ctx);\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().UPPER, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().LOWER, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, BoxplotGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), BoxplotGeom$buildIntern$lambda);\n };\n BoxplotGeom.prototype.buildLines_0 = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n CrossBarHelper_getInstance().buildMidlines_z5ejb9$(root, aesthetics, pos, coord, ctx, this.fattenMidline);\n var helper = new GeomHelper(pos, coord, ctx);\n var elementHelper = helper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_2oeq97$(aesthetics.dataPoints(), Aes$Companion_getInstance().X).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var lines = ArrayList_init();\n if (p.defined_896ixz$(Aes$Companion_getInstance().LOWER) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN)) {\n var hinge = ensureNotNull(p.lower());\n var fence = ensureNotNull(p.ymin());\n lines.add_11rb$(elementHelper.createLine_ollnar$(new DoubleVector(x, hinge), new DoubleVector(x, fence), p));\n }if (p.defined_896ixz$(Aes$Companion_getInstance().UPPER) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX)) {\n var hinge_0 = ensureNotNull(p.upper());\n var fence_0 = ensureNotNull(p.ymax());\n lines.add_11rb$(elementHelper.createLine_ollnar$(new DoubleVector(x, hinge_0), new DoubleVector(x, fence_0), p));\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n }}\n };\n BoxplotGeom.prototype.buildOutliers_0 = function (root, aesthetics, pos, coord, ctx) {\n var outlierAesthetics = this.getOutliersAesthetics_0(aesthetics);\n (new PointGeom()).buildIntern_uzv8ab$(root, outlierAesthetics, pos, coord, ctx.withTargetCollector_xrq6q$(new NullGeomTargetCollector()));\n };\n function BoxplotGeom$getOutliersAesthetics$lambda(this$BoxplotGeom) {\n return function (p) {\n return this$BoxplotGeom.toOutlierDataPointAesthetics_0(p);\n };\n }\n BoxplotGeom.prototype.getOutliersAesthetics_0 = function (aesthetics) {\n return new MappedAesthetics(aesthetics, BoxplotGeom$getOutliersAesthetics$lambda(this));\n };\n function BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral(this$BoxplotGeom, p) {\n this.this$BoxplotGeom = this$BoxplotGeom;\n DataPointAestheticsDelegate.call(this, p);\n }\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.get_31786j$ = function (aes) {\n return this.getIntern_0(aes);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.color = function () {\n return this.getIntern_0(Aes$Companion_getInstance().COLOR);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.fill = function () {\n return this.getIntern_0(Aes$Companion_getInstance().FILL);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.shape = function () {\n return this.getIntern_0(Aes$Companion_getInstance().SHAPE);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.size = function () {\n return this.getIntern_0(Aes$Companion_getInstance().SIZE);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.getIntern_0 = function (aes) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n if (equals(aes, Aes$Companion_getInstance().COLOR))\n tmp$_3 = (tmp$ = this.this$BoxplotGeom.outlierColor) != null ? tmp$ : DataPointAestheticsDelegate.prototype.color.call(this);\n else if (equals(aes, Aes$Companion_getInstance().FILL))\n tmp$_3 = (tmp$_0 = this.this$BoxplotGeom.outlierFill) != null ? tmp$_0 : DataPointAestheticsDelegate.prototype.fill.call(this);\n else if (equals(aes, Aes$Companion_getInstance().SHAPE))\n tmp$_3 = (tmp$_1 = this.this$BoxplotGeom.outlierShape) != null ? tmp$_1 : DataPointAestheticsDelegate.prototype.shape.call(this);\n else if (equals(aes, Aes$Companion_getInstance().SIZE))\n tmp$_3 = (tmp$_2 = this.this$BoxplotGeom.outlierSize) != null ? tmp$_2 : BoxplotGeom$Companion_getInstance().OUTLIER_DEF_SIZE_0;\n else\n tmp$_3 = DataPointAestheticsDelegate.prototype.get_31786j$.call(this, aes);\n var value = tmp$_3;\n return (tmp$_4 = value) == null || Kotlin.isType(tmp$_4, Any) ? tmp$_4 : throwCCE();\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DataPointAestheticsDelegate]\n };\n BoxplotGeom.prototype.toOutlierDataPointAesthetics_0 = function (p) {\n if (!p.defined_896ixz$(Aes$Companion_getInstance().Y)) {\n return p;\n }return new BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral(this, p);\n };\n function BoxplotGeom$Companion() {\n BoxplotGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_FACTORY_0 = CrossBarHelper_getInstance().legendFactory_6taknv$(true);\n this.OUTLIER_DEF_SIZE_0 = AestheticsDefaults$Companion_getInstance().point().defaultValue_31786j$(Aes$Companion_getInstance().SIZE);\n }\n function BoxplotGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().LOWER) && p.defined_896ixz$(Aes$Companion_getInstance().UPPER) && p.defined_896ixz$(Aes$Companion_getInstance().WIDTH)) {\n var x = ensureNotNull(p.x());\n var lower = ensureNotNull(p.lower());\n var upper = ensureNotNull(p.upper());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin = new DoubleVector(x - width / 2, lower);\n var dimensions = new DoubleVector(width, upper - lower);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n };\n }\n BoxplotGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return BoxplotGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n BoxplotGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BoxplotGeom$Companion_instance = null;\n function BoxplotGeom$Companion_getInstance() {\n if (BoxplotGeom$Companion_instance === null) {\n new BoxplotGeom$Companion();\n }return BoxplotGeom$Companion_instance;\n }\n BoxplotGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxplotGeom',\n interfaces: [GeomBase]\n };\n function ContourGeom() {\n ContourGeom$Companion_getInstance();\n PathGeom.call(this);\n }\n function ContourGeom$Companion() {\n ContourGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PathGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n ContourGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourGeom$Companion_instance = null;\n function ContourGeom$Companion_getInstance() {\n if (ContourGeom$Companion_instance === null) {\n new ContourGeom$Companion();\n }return ContourGeom$Companion_instance;\n }\n ContourGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourGeom',\n interfaces: [PathGeom]\n };\n function ContourfGeom() {\n ContourfGeom$Companion_getInstance();\n PolygonGeom.call(this);\n }\n function ContourfGeom$Companion() {\n ContourfGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PolygonGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n ContourfGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourfGeom$Companion_instance = null;\n function ContourfGeom$Companion_getInstance() {\n if (ContourfGeom$Companion_instance === null) {\n new ContourfGeom$Companion();\n }return ContourfGeom$Companion_instance;\n }\n ContourfGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourfGeom',\n interfaces: [PolygonGeom]\n };\n function CrossBarGeom() {\n CrossBarGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidline = 2.5;\n }\n Object.defineProperty(CrossBarGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return CrossBarGeom$Companion_getInstance().LEGEND_FACTORY_0;\n }\n });\n function CrossBarGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n CrossBarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n CrossBarHelper_getInstance().buildBoxes_sm51l0$(root, aesthetics, pos, coord, ctx, CrossBarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx, false));\n CrossBarHelper_getInstance().buildMidlines_z5ejb9$(root, aesthetics, pos, coord, ctx, this.fattenMidline);\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, CrossBarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx, true), CrossBarGeom$buildIntern$lambda);\n };\n function CrossBarGeom$Companion() {\n CrossBarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_FACTORY_0 = CrossBarHelper_getInstance().legendFactory_6taknv$(false);\n }\n function CrossBarGeom$Companion$rectangleByDataPoint$lambda(closure$isHintRect, closure$ctx) {\n return function (p) {\n if (!closure$isHintRect && p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX) && p.defined_896ixz$(Aes$Companion_getInstance().WIDTH)) {\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin = new DoubleVector(x - width / 2, ymin);\n var dimensions = new DoubleVector(width, ymax - ymin);\n return new DoubleRectangle(origin, dimensions);\n } else if (closure$isHintRect && p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().MIDDLE)) {\n var x_0 = ensureNotNull(p.x());\n var middle = ensureNotNull(p.middle());\n var width_0 = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin_0 = new DoubleVector(x_0 - width_0 / 2, middle);\n var dimensions_0 = new DoubleVector(width_0, 0.0);\n return new DoubleRectangle(origin_0, dimensions_0);\n } else {\n return null;\n }\n };\n }\n CrossBarGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx, isHintRect) {\n return CrossBarGeom$Companion$rectangleByDataPoint$lambda(isHintRect, ctx);\n };\n CrossBarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CrossBarGeom$Companion_instance = null;\n function CrossBarGeom$Companion_getInstance() {\n if (CrossBarGeom$Companion_instance === null) {\n new CrossBarGeom$Companion();\n }return CrossBarGeom$Companion_instance;\n }\n CrossBarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossBarGeom',\n interfaces: [GeomBase]\n };\n function Density2dGeom() {\n Density2dGeom$Companion_getInstance();\n ContourGeom.call(this);\n }\n function Density2dGeom$Companion() {\n Density2dGeom$Companion_instance = this;\n this.HANDLES_GROUPS = ContourGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n Density2dGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Density2dGeom$Companion_instance = null;\n function Density2dGeom$Companion_getInstance() {\n if (Density2dGeom$Companion_instance === null) {\n new Density2dGeom$Companion();\n }return Density2dGeom$Companion_instance;\n }\n Density2dGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dGeom',\n interfaces: [ContourGeom]\n };\n function Density2dfGeom() {\n Density2dfGeom$Companion_getInstance();\n ContourfGeom.call(this);\n }\n function Density2dfGeom$Companion() {\n Density2dfGeom$Companion_instance = this;\n this.HANDLES_GROUPS = ContourfGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n Density2dfGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Density2dfGeom$Companion_instance = null;\n function Density2dfGeom$Companion_getInstance() {\n if (Density2dfGeom$Companion_instance === null) {\n new Density2dfGeom$Companion();\n }return Density2dfGeom$Companion_instance;\n }\n Density2dfGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dfGeom',\n interfaces: [ContourfGeom]\n };\n function DensityGeom() {\n DensityGeom$Companion_getInstance();\n AreaGeom.call(this);\n }\n DensityGeom.prototype.setupTooltipParams_l6g9mh$ = function (aes) {\n return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(aes));\n };\n function DensityGeom$Companion() {\n DensityGeom$Companion_instance = this;\n this.HANDLES_GROUPS = AreaGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n DensityGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DensityGeom$Companion_instance = null;\n function DensityGeom$Companion_getInstance() {\n if (DensityGeom$Companion_instance === null) {\n new DensityGeom$Companion();\n }return DensityGeom$Companion_instance;\n }\n DensityGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DensityGeom',\n interfaces: [AreaGeom]\n };\n function ErrorBarGeom() {\n ErrorBarGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(ErrorBarGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new ErrorBarGeom$MyLegendKeyElementFactory();\n }\n });\n ErrorBarGeom.prototype.dataPoints_0 = function (aesthetics) {\n return GeomUtil_getInstance().with_X_83glv4$(aesthetics.dataPoints());\n };\n ErrorBarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var helper = new LinesHelper(pos, coord, ctx);\n var dataPoints = this.dataPoints_0(aesthetics);\n var geomHelper = new GeomHelper(pos, coord, ctx);\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = p.x();\n var ymin = p.ymin();\n var ymax = p.ymax();\n if (!data.SeriesUtil.allFinite_xjrefz$(x, ymin, ymax)) {\n continue;\n }var width = ensureNotNull(p.width());\n width *= ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var height = ensureNotNull(ymax) - ensureNotNull(ymin);\n var r = DoubleRectangle_init(ensureNotNull(x) - width / 2, ymin, width, height);\n var g = ErrorBarGeom$Companion_getInstance().errorBarShape_0(helper.toClient_ioi29i$(r, p), p);\n root.add_26jijc$(g);\n this.buildHints_0(DoubleRectangle_init(r.left, r.center.y, r.width, 0.0), p, ctx, geomHelper);\n }\n };\n ErrorBarGeom.prototype.buildHints_0 = function (rect, p, ctx, geomHelper) {\n var clientRect = geomHelper.toClient_ioi29i$(rect, p);\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(clientRect.width / 2.0).defaultX_14dthe$(ensureNotNull(p.x())).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance());\n var hints = (new HintsCollection(p, geomHelper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN)).hints;\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), clientRect, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hints).setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n };\n function ErrorBarGeom$MyLegendKeyElementFactory() {\n }\n ErrorBarGeom$MyLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = ensureNotNull(p.width()) * (size.x - strokeWidth);\n var height = size.y - strokeWidth;\n var x = (size.x - width) / 2;\n var y = strokeWidth / 2;\n return ErrorBarGeom$Companion_getInstance().errorBarShape_0(DoubleRectangle_init(x, y, width, height), p);\n };\n ErrorBarGeom$MyLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function ErrorBarGeom$Companion() {\n ErrorBarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ErrorBarGeom$Companion.prototype.errorBarShape_0 = function (r, p) {\n var tmp$;\n var left = r.left;\n var top = r.top;\n var right = r.right;\n var bottom = r.bottom;\n var center = left + r.width / 2;\n var shapeLines = ArrayList_init();\n shapeLines.add_11rb$(SvgLineElement_init(left, top, right, top));\n shapeLines.add_11rb$(SvgLineElement_init(left, bottom, right, bottom));\n shapeLines.add_11rb$(SvgLineElement_init(center, top, center, bottom));\n var g = new SvgGElement();\n tmp$ = shapeLines.iterator();\n while (tmp$.hasNext()) {\n var shapeLine = tmp$.next();\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(shapeLine, p);\n g.children().add_11rb$(shapeLine);\n }\n return g;\n };\n ErrorBarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ErrorBarGeom$Companion_instance = null;\n function ErrorBarGeom$Companion_getInstance() {\n if (ErrorBarGeom$Companion_instance === null) {\n new ErrorBarGeom$Companion();\n }return ErrorBarGeom$Companion_instance;\n }\n ErrorBarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ErrorBarGeom',\n interfaces: [GeomBase]\n };\n function FilledCircleLegendKeyElementFactory() {\n FilledCircleLegendKeyElementFactory$Companion_getInstance();\n }\n FilledCircleLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var location = new DoubleVector(size.x / 2, size.y / 2);\n var slimObject = PointShapeSvg_getInstance().create_d8smhz$(FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0, location, p);\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(1);\n slimObject.appendTo_i2myw1$(slimGroup);\n return GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup);\n };\n FilledCircleLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var shapeSize = FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0.size_l6g9mh$(p);\n var strokeWidth = FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0.strokeWidth_l6g9mh$(p);\n var size = shapeSize + strokeWidth + 2.0;\n return new DoubleVector(size, size);\n };\n function FilledCircleLegendKeyElementFactory$Companion() {\n FilledCircleLegendKeyElementFactory$Companion_instance = this;\n this.SHAPE_0 = NamedShape$FILLED_CIRCLE_getInstance();\n }\n FilledCircleLegendKeyElementFactory$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FilledCircleLegendKeyElementFactory$Companion_instance = null;\n function FilledCircleLegendKeyElementFactory$Companion_getInstance() {\n if (FilledCircleLegendKeyElementFactory$Companion_instance === null) {\n new FilledCircleLegendKeyElementFactory$Companion();\n }return FilledCircleLegendKeyElementFactory$Companion_instance;\n }\n FilledCircleLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FilledCircleLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function FilledSquareLegendKeyElementFactory() {\n }\n FilledSquareLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var rect = SvgRectElement_init(0.0, 0.0, size.x, size.y);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(rect, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n return g;\n };\n FilledSquareLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FilledSquareLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function FreqpolyGeom() {\n FreqpolyGeom$Companion_getInstance();\n LineGeom.call(this);\n }\n function FreqpolyGeom$Companion() {\n FreqpolyGeom$Companion_instance = this;\n this.HANDLES_GROUPS = LineGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n FreqpolyGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FreqpolyGeom$Companion_instance = null;\n function FreqpolyGeom$Companion_getInstance() {\n if (FreqpolyGeom$Companion_instance === null) {\n new FreqpolyGeom$Companion();\n }return FreqpolyGeom$Companion_instance;\n }\n FreqpolyGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FreqpolyGeom',\n interfaces: [LineGeom]\n };\n function GeomBase() {\n GeomBase$Companion_getInstance();\n }\n Object.defineProperty(GeomBase.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new GenericLegendKeyElementFactory();\n }\n });\n GeomBase.prototype.build_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n this.buildIntern_uzv8ab$(root, aesthetics, pos, coord, ctx);\n };\n GeomBase.prototype.getGeomTargetCollector_vl74i5$ = function (ctx) {\n return ctx.targetCollector;\n };\n function GeomBase$Companion() {\n GeomBase$Companion_instance = this;\n }\n GeomBase$Companion.prototype.wrap_i2myw1$ = function (slimGroup) {\n var g = new SvgGElement();\n g.isPrebuiltSubtree = true;\n g.children().add_11rb$(slimGroup.asDummySvgNode());\n return g;\n };\n GeomBase$Companion.prototype.wrap_4fnnkz$ = function (o) {\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(1);\n o.appendTo_i2myw1$(slimGroup);\n return this.wrap_i2myw1$(slimGroup);\n };\n GeomBase$Companion.prototype.aesViewPort_m7huy5$ = function (aesthetics) {\n return this.rect_0(aesthetics.overallRange_vktour$(Aes$Companion_getInstance().X), aesthetics.overallRange_vktour$(Aes$Companion_getInstance().Y));\n };\n GeomBase$Companion.prototype.aesBoundingBox_m7huy5$ = function (aesthetics) {\n return this.rect_0(ensureNotNull(aesthetics.range_vktour$(Aes$Companion_getInstance().X)), ensureNotNull(aesthetics.range_vktour$(Aes$Companion_getInstance().Y)));\n };\n GeomBase$Companion.prototype.rect_0 = function (rangeX, rangeY) {\n return DoubleRectangle_init(rangeX.lowerEnd, rangeY.lowerEnd, data.SeriesUtil.span_4fzjta$(rangeX), data.SeriesUtil.span_4fzjta$(rangeY));\n };\n GeomBase$Companion.prototype.appendNodes_37zgbi$ = function (paths, root) {\n var tmp$;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n root.add_26jijc$(path.rootGroup);\n }\n };\n GeomBase$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomBase$Companion_instance = null;\n function GeomBase$Companion_getInstance() {\n if (GeomBase$Companion_instance === null) {\n new GeomBase$Companion();\n }return GeomBase$Companion_instance;\n }\n GeomBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomBase',\n interfaces: [Geom]\n };\n function HLineGeom() {\n HLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(HLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n HLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.interceptY();\n if (data.SeriesUtil.isFinite_yrwdxb$(intercept)) {\n if (viewPort.yRange().contains_mef7kx$(ensureNotNull(intercept))) {\n var start = new DoubleVector(viewPort.left, intercept);\n var end = new DoubleVector(viewPort.right, intercept);\n var line = helper.createLine_ollnar$(start, end, p);\n lines.add_11rb$(line);\n var h = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var origin = new DoubleVector(start.x, intercept - h / 2 - 2.0);\n var dimensions = new DoubleVector(viewPort.dimension.x, h + 4.0);\n var rect = new DoubleRectangle(origin, dimensions);\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), geomHelper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance());\n }}}\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n };\n function HLineGeom$Companion() {\n HLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_KEY_ELEMENT_FACTORY = new HLineLegendKeyElementFactory();\n }\n HLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HLineGeom$Companion_instance = null;\n function HLineGeom$Companion_getInstance() {\n if (HLineGeom$Companion_instance === null) {\n new HLineGeom$Companion();\n }return HLineGeom$Companion_instance;\n }\n HLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HLineGeom',\n interfaces: [GeomBase]\n };\n function HistogramGeom() {\n HistogramGeom$Companion_getInstance();\n BarGeom.call(this);\n }\n function HistogramGeom$Companion() {\n HistogramGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n HistogramGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HistogramGeom$Companion_instance = null;\n function HistogramGeom$Companion_getInstance() {\n if (HistogramGeom$Companion_instance === null) {\n new HistogramGeom$Companion();\n }return HistogramGeom$Companion_instance;\n }\n HistogramGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HistogramGeom',\n interfaces: [BarGeom]\n };\n function ImageGeom(imageUrl) {\n ImageGeom$Companion_getInstance();\n GeomBase.call(this);\n this.imageUrl_0 = imageUrl;\n }\n ImageGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n if (aesthetics.isEmpty)\n return;\n var p = aesthetics.dataPointAt_za3lpa$(0);\n var boundsAes = DoubleRectangle.Companion.span_qt8ska$(new DoubleVector(ensureNotNull(p.xmin()), ensureNotNull(p.ymin())), new DoubleVector(ensureNotNull(p.xmax()), ensureNotNull(p.ymax())));\n var helper = new GeomHelper(pos, coord, ctx);\n var boundsClient = helper.toClient_ioi29i$(boundsAes, p);\n var svgImageElement = SvgImageElement_init(boundsClient.origin.x, boundsClient.origin.y, boundsClient.dimension.x, boundsClient.dimension.y);\n svgImageElement.href().set_11rb$(this.imageUrl_0);\n root.add_26jijc$(svgImageElement);\n };\n function ImageGeom$Companion() {\n ImageGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ImageGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ImageGeom$Companion_instance = null;\n function ImageGeom$Companion_getInstance() {\n if (ImageGeom$Companion_instance === null) {\n new ImageGeom$Companion();\n }return ImageGeom$Companion_instance;\n }\n ImageGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ImageGeom',\n interfaces: [GeomBase]\n };\n function JitterGeom() {\n JitterGeom$Companion_getInstance();\n PointGeom.call(this);\n }\n function JitterGeom$Companion() {\n JitterGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PointGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n JitterGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JitterGeom$Companion_instance = null;\n function JitterGeom$Companion_getInstance() {\n if (JitterGeom$Companion_instance === null) {\n new JitterGeom$Companion();\n }return JitterGeom$Companion_instance;\n }\n JitterGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterGeom',\n interfaces: [PointGeom]\n };\n function LineGeom() {\n LineGeom$Companion_getInstance();\n PathGeom.call(this);\n }\n LineGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().ordered_X_83glv4$(PathGeom.prototype.dataPoints_m7huy5$.call(this, aesthetics));\n };\n function LineGeom$Companion() {\n LineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PathGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n LineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LineGeom$Companion_instance = null;\n function LineGeom$Companion_getInstance() {\n if (LineGeom$Companion_instance === null) {\n new LineGeom$Companion();\n }return LineGeom$Companion_instance;\n }\n LineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineGeom',\n interfaces: [PathGeom]\n };\n function LineRangeGeom() {\n LineRangeGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(LineRangeGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return VLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n function LineRangeGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n LineRangeGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var start = new DoubleVector(x, ymin);\n var end = new DoubleVector(x, ymax);\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, LineRangeGeom$Companion_getInstance().rectangleByDataPoint(), LineRangeGeom$buildIntern$lambda);\n };\n function LineRangeGeom$Companion() {\n LineRangeGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function LineRangeGeom$Companion$rectangleByDataPoint$lambda(p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX)) {\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var a = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = JsMath.max(a, 2.0) * 2.0;\n var height = ymax - ymin;\n var origin = new DoubleVector(x - width / 2, ymax - height / 2);\n var dimensions = new DoubleVector(width, 0.0);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n }\n LineRangeGeom$Companion.prototype.rectangleByDataPoint = function () {\n return LineRangeGeom$Companion$rectangleByDataPoint$lambda;\n };\n LineRangeGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LineRangeGeom$Companion_instance = null;\n function LineRangeGeom$Companion_getInstance() {\n if (LineRangeGeom$Companion_instance === null) {\n new LineRangeGeom$Companion();\n }return LineRangeGeom$Companion_instance;\n }\n LineRangeGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineRangeGeom',\n interfaces: [GeomBase]\n };\n function LiveMapGeom(myDisplayMode) {\n LiveMapGeom$Companion_getInstance();\n this.myDisplayMode_0 = myDisplayMode;\n this.myMapProvider_pcd1rb$_0 = this.myMapProvider_pcd1rb$_0;\n }\n Object.defineProperty(LiveMapGeom.prototype, 'myMapProvider_0', {\n configurable: true,\n get: function () {\n if (this.myMapProvider_pcd1rb$_0 == null)\n return throwUPAE('myMapProvider');\n return this.myMapProvider_pcd1rb$_0;\n },\n set: function (myMapProvider) {\n this.myMapProvider_pcd1rb$_0 = myMapProvider;\n }\n });\n Object.defineProperty(LiveMapGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n var tmp$;\n switch (this.myDisplayMode_0.name) {\n case 'POINT':\n tmp$ = new PointLegendKeyElementFactory();\n break;\n case 'PIE':\n tmp$ = new FilledCircleLegendKeyElementFactory();\n break;\n default:tmp$ = new GenericLegendKeyElementFactory();\n break;\n }\n return tmp$;\n }\n });\n LiveMapGeom.prototype.build_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n throw IllegalStateException_init('Not applicable to live map');\n };\n LiveMapGeom.prototype.setLiveMapProvider_kld0fp$ = function (liveMapProvider) {\n this.myMapProvider_0 = liveMapProvider;\n };\n LiveMapGeom.prototype.createCanvasFigure_wthzt5$ = function (bounds) {\n return this.myMapProvider_0.createLiveMap_wthzt5$(bounds);\n };\n function LiveMapGeom$Companion() {\n LiveMapGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n LiveMapGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LiveMapGeom$Companion_instance = null;\n function LiveMapGeom$Companion_getInstance() {\n if (LiveMapGeom$Companion_instance === null) {\n new LiveMapGeom$Companion();\n }return LiveMapGeom$Companion_instance;\n }\n LiveMapGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapGeom',\n interfaces: [Geom]\n };\n function LiveMapProvider() {\n }\n function LiveMapProvider$LiveMapData(canvasFigure, targetLocator) {\n this.canvasFigure = canvasFigure;\n this.targetLocator = targetLocator;\n }\n LiveMapProvider$LiveMapData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapData',\n interfaces: []\n };\n LiveMapProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LiveMapProvider',\n interfaces: []\n };\n function MapGeom() {\n MapGeom$Companion_getInstance();\n PolygonGeom.call(this);\n }\n function MapGeom$Companion() {\n MapGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n MapGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MapGeom$Companion_instance = null;\n function MapGeom$Companion_getInstance() {\n if (MapGeom$Companion_instance === null) {\n new MapGeom$Companion();\n }return MapGeom$Companion_instance;\n }\n MapGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapGeom',\n interfaces: [PolygonGeom]\n };\n function PathGeom() {\n PathGeom$Companion_getInstance();\n GeomBase.call(this);\n this.animation = null;\n }\n Object.defineProperty(PathGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n PathGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n };\n PathGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var linesHelper = new LinesHelper(pos, coord, ctx);\n var geomConstructor = new LinePathConstructor(targetCollector, dataPoints, linesHelper, false);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(geomConstructor.construct_6taknv$(false), root);\n this.buildHints_9cwuu0$_0(aesthetics, coord, linesHelper, targetCollector);\n };\n PathGeom.prototype.buildHints_9cwuu0$_0 = function (aesthetics, coord, linesHelper, targetCollector) {\n var $receiver = this.dataPoints_m7huy5$(aesthetics);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var x = element.x();\n var y = element.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && coord.isPointInLimits_k2qmv6$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), false))\n destination.add_11rb$(element);\n }\n var dataPoints = destination;\n (new LinePathConstructor(targetCollector, dataPoints, linesHelper, false)).buildHints();\n };\n function PathGeom$Companion() {\n PathGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n PathGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathGeom$Companion_instance = null;\n function PathGeom$Companion_getInstance() {\n if (PathGeom$Companion_instance === null) {\n new PathGeom$Companion();\n }return PathGeom$Companion_instance;\n }\n PathGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathGeom',\n interfaces: [GeomBase]\n };\n function PieGeom(myCenter, myRadius) {\n PieGeom$Companion_getInstance();\n GeomBase.call(this);\n this.myCenter_0 = myCenter;\n this.myRadius_0 = myRadius;\n }\n PieGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new PieGeom$PieHelper(pos, coord, ctx);\n var segments = helper.createSegments_67zh1d$(aesthetics, this.myCenter_0, this.myRadius_0);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(segments, root);\n };\n function PieGeom$PieHelper(pos, coord, ctx) {\n LinesHelper.call(this, pos, coord, ctx);\n }\n PieGeom$PieHelper.prototype.createSegments_67zh1d$ = function (aesthetics, center, radius) {\n var tmp$;\n var result = ArrayList_init();\n var basis = new DoubleVector(0.0, -radius);\n var curAngle = kotlin_js_internal_DoubleCompanionObject.NaN;\n tmp$ = PieGeom$Companion_getInstance().dataPoints_0(aesthetics).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var segmentSize = PieGeom$Companion_getInstance().shareToRad_0(ensureNotNull(p.y()));\n if (isNaN_0(curAngle)) {\n curAngle = segmentSize;\n }var angle = -segmentSize;\n var builder = new SvgPathDataBuilder(true);\n builder.moveTo_gpjtzr$(center);\n builder.lineTo_gpjtzr$(center.add_gpjtzr$(basis.rotate_14dthe$(curAngle)));\n var arcTo = center.add_gpjtzr$(basis.rotate_14dthe$(curAngle + angle));\n builder.ellipticalArc_gc0whr$(radius, radius, 0.0, -angle > math.PI, false, arcTo);\n builder.closePath();\n curAngle += angle;\n var path = new LinePath(builder);\n this.decorate_frjrd5$(path, p, true);\n result.add_11rb$(path);\n }\n return result;\n };\n PieGeom$PieHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PieHelper',\n interfaces: [LinesHelper]\n };\n function PieGeom$Companion() {\n PieGeom$Companion_instance = this;\n this.RENDERS = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n this.HANDLES_GROUPS = false;\n }\n PieGeom$Companion.prototype.dataPoints_0 = function (aesthetics) {\n var tmp$;\n var withX = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n if (collect.Iterables.isEmpty_fakr2g$(withX) || this.allEqualX_0(withX, collect.Iterables.get_7iig3d$(withX, 0).x())) {\n tmp$ = GeomUtil_getInstance().ordered_Y_hku6c7$(GeomUtil_getInstance().with_Y_83glv4$(aesthetics.dataPoints()), true);\n } else\n tmp$ = GeomUtil_getInstance().ordered_X_83glv4$(withX);\n return tmp$;\n };\n PieGeom$Companion.prototype.allEqualX_0 = function (hasX, val) {\n var tmp$;\n tmp$ = hasX.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n if (p.x() != val) {\n return false;\n }}\n return true;\n };\n PieGeom$Companion.prototype.shareToRad_0 = function (share) {\n return 0.9999 * 2.0 * math.PI * share;\n };\n PieGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PieGeom$Companion_instance = null;\n function PieGeom$Companion_getInstance() {\n if (PieGeom$Companion_instance === null) {\n new PieGeom$Companion();\n }return PieGeom$Companion_instance;\n }\n PieGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PieGeom',\n interfaces: [GeomBase]\n };\n function PointGeom() {\n PointGeom$Companion_getInstance();\n GeomBase.call(this);\n this.animation = null;\n this.sizeUnit = null;\n }\n Object.defineProperty(PointGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new PointLegendKeyElementFactory();\n }\n });\n PointGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new GeomHelper(pos, coord, ctx);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var count = aesthetics.dataPointCount();\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(count);\n var sizeUnitRatio = this.getSizeUnitRatio_a8x9k9$_0(ctx);\n for (var i = 0; i < count; i++) {\n var p = aesthetics.dataPointAt_za3lpa$(i);\n var x = p.x();\n var y = p.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n var location = helper.toClient_tkjljq$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), p);\n var shape = ensureNotNull(p.shape());\n targetCollector.addPoint_cnsimy$(i, location, sizeUnitRatio * shape.size_l6g9mh$(p) / 2, PointGeom$Companion_getInstance().tooltipParams_l6g9mh$(p));\n var o = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, sizeUnitRatio);\n o.appendTo_i2myw1$(slimGroup);\n }}\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup));\n };\n PointGeom.prototype.getSizeUnitRatio_a8x9k9$_0 = function (ctx) {\n var tmp$;\n if (this.sizeUnit != null) {\n var unitRes = ctx.getUnitResolution_vktour$(GeomHelper$Companion_getInstance().getSizeUnitAes_61zpoe$(ensureNotNull(this.sizeUnit)));\n tmp$ = unitRes / AesScaling_getInstance().UNIT_SHAPE_SIZE;\n } else {\n tmp$ = 1.0;\n }\n return tmp$;\n };\n function PointGeom$Companion() {\n PointGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n PointGeom$Companion.prototype.tooltipParams_l6g9mh$ = function (p) {\n var tmp$;\n var color = Color.Companion.TRANSPARENT;\n if (equals(p.shape(), TinyPointShape_getInstance())) {\n color = ensureNotNull(p.color());\n } else if (Kotlin.isType(p.shape(), NamedShape)) {\n var shape = Kotlin.isType(tmp$ = p.shape(), NamedShape) ? tmp$ : throwCCE();\n color = AestheticsUtil_getInstance().fill_edjgex$(shape.isFilled, shape.isSolid, p);\n }return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColorValue_o14uds$(color, ensureNotNull(p.alpha())));\n };\n PointGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointGeom$Companion_instance = null;\n function PointGeom$Companion_getInstance() {\n if (PointGeom$Companion_instance === null) {\n new PointGeom$Companion();\n }return PointGeom$Companion_instance;\n }\n PointGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointGeom',\n interfaces: [GeomBase]\n };\n function PointLegendKeyElementFactory(fatten) {\n if (fatten === void 0)\n fatten = 1.0;\n this.fatten_0 = fatten;\n }\n PointLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var location = new DoubleVector(size.x / 2, size.y / 2);\n var shape = ensureNotNull(p.shape());\n var slimObject = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, this.fatten_0);\n return GeomBase$Companion_getInstance().wrap_4fnnkz$(slimObject);\n };\n PointLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var shape = ensureNotNull(p.shape());\n var shapeSize = shape.size_l6g9mh$(p) * this.fatten_0;\n var strokeWidth = shape.strokeWidth_l6g9mh$(p);\n var size = shapeSize + strokeWidth + 2.0;\n return new DoubleVector(size, size);\n };\n PointLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function PointRangeGeom() {\n PointRangeGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidPoint = PointRangeGeom$Companion_getInstance().DEF_FATTEN;\n }\n Object.defineProperty(PointRangeGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new CompositeLegendKeyElementFactory([new VLineLegendKeyElementFactory(), new PointLegendKeyElementFactory(PointRangeGeom$Companion_getInstance().DEF_FATTEN)]);\n }\n });\n function PointRangeGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n PointRangeGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_i1kplo$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var start = new DoubleVector(x, ymin);\n var end = new DoubleVector(x, ymax);\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n var location = geomHelper.toClient_tkjljq$(new DoubleVector(x, y), p);\n var shape = ensureNotNull(p.shape());\n var o = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, this.fattenMidPoint);\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_4fnnkz$(o));\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, PointRangeGeom$Companion_getInstance().rectangleByDataPoint_14dthe$(this.fattenMidPoint), PointRangeGeom$buildIntern$lambda);\n };\n function PointRangeGeom$Companion() {\n PointRangeGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.DEF_FATTEN = 5.0;\n }\n function PointRangeGeom$Companion$rectangleByDataPoint$lambda(closure$fatten) {\n return function (p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().Y)) {\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var shape = ensureNotNull(p.shape());\n var shapeSize = shape.size_l6g9mh$(p) * closure$fatten;\n var strokeWidth = shape.strokeWidth_l6g9mh$(p);\n var width = shapeSize + strokeWidth;\n var origin = new DoubleVector(x - width / 2, y);\n var dimensions = new DoubleVector(width, 0.0);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n };\n }\n PointRangeGeom$Companion.prototype.rectangleByDataPoint_14dthe$ = function (fatten) {\n return PointRangeGeom$Companion$rectangleByDataPoint$lambda(fatten);\n };\n PointRangeGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointRangeGeom$Companion_instance = null;\n function PointRangeGeom$Companion_getInstance() {\n if (PointRangeGeom$Companion_instance === null) {\n new PointRangeGeom$Companion();\n }return PointRangeGeom$Companion_instance;\n }\n PointRangeGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointRangeGeom',\n interfaces: [GeomBase]\n };\n function PolygonGeom() {\n PolygonGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n PolygonGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n };\n PolygonGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var linesHelper = new LinesHelper(pos, coord, ctx);\n var geomConstructor = new LinePathConstructor(targetCollector, dataPoints, linesHelper, true);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(geomConstructor.construct_6taknv$(true), root);\n };\n function PolygonGeom$Companion() {\n PolygonGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n PolygonGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolygonGeom$Companion_instance = null;\n function PolygonGeom$Companion_getInstance() {\n if (PolygonGeom$Companion_instance === null) {\n new PolygonGeom$Companion();\n }return PolygonGeom$Companion_instance;\n }\n PolygonGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolygonGeom',\n interfaces: [GeomBase]\n };\n function RasterGeom() {\n RasterGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(RasterGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new FilledSquareLegendKeyElementFactory();\n }\n });\n RasterGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$, tmp$_0;\n var iter = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()).iterator();\n if (!iter.hasNext()) {\n return;\n }var randomP = iter.next();\n var helper = new GeomHelper(pos, coord, ctx);\n var boundsXY = GeomBase$Companion_getInstance().aesBoundingBox_m7huy5$(aesthetics);\n var stepX = ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var stepY = ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n if (!(stepX > data.SeriesUtil.TINY)) {\n var message = 'x-step is too small: ' + stepX;\n throw IllegalArgumentException_init(message.toString());\n }if (!(stepY > data.SeriesUtil.TINY)) {\n var message_0 = 'y-step is too small: ' + stepY;\n throw IllegalArgumentException_init(message_0.toString());\n }var width = round(boundsXY.dimension.x / stepX) + 1;\n var height = round(boundsXY.dimension.y / stepY) + 1;\n if (width * height > 5000000) {\n var center = boundsXY.center;\n var lines = ['Raster image size', '[' + width + ' X ' + height + ']', 'exceeds capability', 'of', 'your imaging device'];\n var fontSize = 12.0;\n var lineHeight = fontSize + 4;\n var y = center.y + lineHeight * lines.length / 2.0;\n for (tmp$ = 0; tmp$ !== lines.length; ++tmp$) {\n var line = lines[tmp$];\n var label = new TextLabel(line);\n label.textColor().set_11rb$(Color.Companion.DARK_MAGENTA);\n label.textOpacity().set_11rb$(0.5);\n label.setFontSize_14dthe$(fontSize);\n label.setFontWeight_pdl1vj$('bold');\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor$CENTER_getInstance());\n var loc = helper.toClient_vf7nkp$(center.x, y, randomP);\n label.moveTo_gpjtzr$(loc);\n root.add_26jijc$(label.rootGroup);\n y -= lineHeight;\n }\n return;\n }var cols = numberToInt(round(width));\n var rows = numberToInt(round(height));\n var halfStep = new DoubleVector(stepX * 0.5, stepY * 0.5);\n var corner0 = helper.toClient_tkjljq$(boundsXY.origin.subtract_gpjtzr$(halfStep), randomP);\n var corner2 = helper.toClient_tkjljq$(boundsXY.origin.add_gpjtzr$(boundsXY.dimension).add_gpjtzr$(halfStep), randomP);\n var invertedX = corner2.x < corner0.x;\n var invertedY = corner2.y < corner0.y;\n var x0 = boundsXY.origin.x;\n var y0 = boundsXY.origin.y;\n var argbValues = new Int32Array(Kotlin.imul(cols, rows));\n tmp$_0 = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()).iterator();\n while (tmp$_0.hasNext()) {\n var p = tmp$_0.next();\n var x = p.x();\n var y_0 = p.y();\n var alpha = p.alpha();\n var color = p.fill();\n var col = numberToInt(round((ensureNotNull(x) - x0) / stepX));\n var row = numberToInt(round((ensureNotNull(y_0) - y0) / stepY));\n if (invertedX) {\n col = cols - (col + 1) | 0;\n }if (invertedY) {\n row = rows - (row + 1) | 0;\n }argbValues[Kotlin.imul(row, cols) + col | 0] = svg.SvgUtils.toARGB_o14uds$(ensureNotNull(color), ensureNotNull(alpha));\n }\n var bitmap = new SvgImageElementEx$Bitmap(cols, rows, argbValues);\n var a = corner0.x;\n var b = corner2.x;\n var tmp$_1 = JsMath.min(a, b);\n var a_0 = corner0.y;\n var b_0 = corner2.y;\n var tmp$_2 = JsMath.min(a_0, b_0);\n var x_0 = corner0.x - corner2.x;\n var tmp$_3 = JsMath.abs(x_0);\n var x_1 = corner0.y - corner2.y;\n var svgImageElement = new SvgImageElementEx(tmp$_1, tmp$_2, tmp$_3, JsMath.abs(x_1), bitmap);\n root.add_26jijc$(svgImageElement);\n };\n function RasterGeom$Companion() {\n RasterGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n RasterGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RasterGeom$Companion_instance = null;\n function RasterGeom$Companion_getInstance() {\n if (RasterGeom$Companion_instance === null) {\n new RasterGeom$Companion();\n }return RasterGeom$Companion_instance;\n }\n RasterGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RasterGeom',\n interfaces: [GeomBase]\n };\n function RectGeom() {\n RectGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n RectGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var $receiver = helper.createRectangles_rezc4r$(getCallableRef('rectangleByDataPoint', function ($receiver, p1) {\n return $receiver.rectangleByDataPoint_0(p1);\n }.bind(null, RectGeom$Companion_getInstance())));\n var action = getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_26jijc$(p1), Unit;\n }.bind(null, root));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n action(element);\n }\n (new RectTargetCollectorHelper(helper, getCallableRef('rectangleByDataPoint', function ($receiver, p1) {\n return $receiver.rectangleByDataPoint_0(p1);\n }.bind(null, RectGeom$Companion_getInstance())), getCallableRef('fromFill', function ($receiver, p1) {\n return $receiver.fromFill_l6g9mh$(p1);\n }.bind(null, HintColorUtil_getInstance())), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance())).collectTo_xrq6q$(ctx.targetCollector);\n };\n function RectGeom$Companion() {\n RectGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n RectGeom$Companion.prototype.rectangleByDataPoint_0 = function (p) {\n var tmp$;\n var xmin = p.xmin();\n var xmax = p.xmax();\n var ymin = p.ymin();\n var ymax = p.ymax();\n if (data.SeriesUtil.allFinite_rd1tgs$(xmin, xmax, ymin, ymax)) {\n tmp$ = DoubleRectangle.Companion.span_qt8ska$(new DoubleVector(ensureNotNull(xmin), ensureNotNull(ymin)), new DoubleVector(ensureNotNull(xmax), ensureNotNull(ymax)));\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n RectGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RectGeom$Companion_instance = null;\n function RectGeom$Companion_getInstance() {\n if (RectGeom$Companion_instance === null) {\n new RectGeom$Companion();\n }return RectGeom$Companion_instance;\n }\n RectGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectGeom',\n interfaces: [GeomBase]\n };\n function RibbonGeom() {\n RibbonGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n RibbonGeom.prototype.dataPoints_0 = function (aesthetics) {\n var data = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX);\n return GeomUtil_getInstance().ordered_X_83glv4$(data);\n };\n RibbonGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_0(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var paths = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX, GeomUtil_getInstance().TO_LOCATION_X_YMIN);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(paths, root);\n helper.setAlphaEnabled_6taknv$(false);\n var lines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX);\n lines.addAll_brywnq$(helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMIN));\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(lines, root);\n this.buildHints_0(aesthetics, pos, coord, ctx);\n };\n RibbonGeom.prototype.buildHints_0 = function (aesthetics, pos, coord, ctx) {\n var tmp$;\n var targetCollector = ctx.targetCollector;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n this.addTarget_0(p, targetCollector, GeomUtil_getInstance().TO_LOCATION_X_YMAX, helper);\n }\n };\n RibbonGeom.prototype.addTarget_0 = function (p, collector, toLocation, helper) {\n var coord = toLocation(p);\n if (coord != null) {\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(0.0).defaultX_14dthe$(ensureNotNull(p.x())).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()).defaultColor_yo1m5r$(ensureNotNull(p.fill()), null);\n var hintsCollection = (new HintsCollection(p, helper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN));\n collector.addPoint_cnsimy$(p.index(), helper.toClient_tkjljq$(coord, p), 0.0, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintsCollection.hints));\n }};\n function RibbonGeom$Companion() {\n RibbonGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n RibbonGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RibbonGeom$Companion_instance = null;\n function RibbonGeom$Companion_getInstance() {\n if (RibbonGeom$Companion_instance === null) {\n new RibbonGeom$Companion();\n }return RibbonGeom$Companion_instance;\n }\n RibbonGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RibbonGeom',\n interfaces: [GeomBase]\n };\n function SegmentGeom() {\n SegmentGeom$Companion_getInstance();\n GeomBase.call(this);\n this.arrowSpec = null;\n this.animation = null;\n }\n Object.defineProperty(SegmentGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n function SegmentGeom$buildIntern$lambda(closure$p) {\n return function (it) {\n return closure$p.index();\n };\n }\n SegmentGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var helper = (new GeomHelper(pos, coord, ctx)).createSvgElementHelper();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n if (data.SeriesUtil.allFinite_rd1tgs$(p.x(), p.y(), p.xend(), p.yend())) {\n var start = new DoubleVector(ensureNotNull(p.x()), ensureNotNull(p.y()));\n var end = new DoubleVector(ensureNotNull(p.xend()), ensureNotNull(p.yend()));\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n targetCollector.addPath_sa5m83$(listOf([coord.toClient_gpjtzr$(start), coord.toClient_gpjtzr$(end)]), SegmentGeom$buildIntern$lambda(p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n if (this.arrowSpec != null) {\n var clientX1 = ensureNotNull(line.x1().get());\n var clientY1 = ensureNotNull(line.y1().get());\n var clientX2 = ensureNotNull(line.x2().get());\n var clientY2 = ensureNotNull(line.y2().get());\n var abscissa = clientX2 - clientX1;\n var ordinate = clientY2 - clientY1;\n if (abscissa !== 0.0 || ordinate !== 0.0) {\n var polarAngle = JsMath.atan2(ordinate, abscissa);\n var arrowAes = ensureNotNull(this.arrowSpec).toArrowAes_l6g9mh$(p);\n if (ensureNotNull(this.arrowSpec).isOnLastEnd) {\n var arrow = ensureNotNull(this.arrowSpec).createElement_yvo9jy$(polarAngle, clientX2, clientY2);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(arrow, arrowAes);\n root.add_26jijc$(arrow);\n }if (ensureNotNull(this.arrowSpec).isOnFirstEnd) {\n var arrow_0 = ensureNotNull(this.arrowSpec).createElement_yvo9jy$(polarAngle + math.PI, clientX1, clientY1);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(arrow_0, arrowAes);\n root.add_26jijc$(arrow_0);\n }}}}}\n };\n function SegmentGeom$Companion() {\n SegmentGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n SegmentGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SegmentGeom$Companion_instance = null;\n function SegmentGeom$Companion_getInstance() {\n if (SegmentGeom$Companion_instance === null) {\n new SegmentGeom$Companion();\n }return SegmentGeom$Companion_instance;\n }\n SegmentGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SegmentGeom',\n interfaces: [GeomBase]\n };\n function SmoothGeom() {\n SmoothGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(SmoothGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n SmoothGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = GeomUtil_getInstance().ordered_X_83glv4$(GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()));\n var helper = new LinesHelper(pos, coord, ctx);\n helper.setAlphaEnabled_6taknv$(false);\n var regressionLines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(regressionLines, root);\n helper.setAlphaFilter_m9g0ow$(SmoothGeom$Companion_getInstance().PROPORTION_0);\n helper.setWidthFilter_m9g0ow$(SmoothGeom$Companion_getInstance().ZERO_0);\n var bands = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX, GeomUtil_getInstance().TO_LOCATION_X_YMIN);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(bands, root);\n this.buildHints_0(dataPoints, pos, coord, ctx);\n };\n SmoothGeom.prototype.buildHints_0 = function (dataPoints, pos, coord, ctx) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var xCoord = ensureNotNull(p.x());\n var objectRadius = 0.0;\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(objectRadius).defaultX_14dthe$(xCoord).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()).defaultColor_yo1m5r$(ensureNotNull(p.fill()), SmoothGeom$Companion_getInstance().PROPORTION_0(p.alpha()));\n var hintsCollection = (new HintsCollection(p, helper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().Y).color_98b62m$(ensureNotNull(p.color())));\n var clientCoord = helper.toClient_vf7nkp$(p.x(), p.y(), p);\n ctx.targetCollector.addPoint_cnsimy$(p.index(), clientCoord, objectRadius, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintsCollection.hints));\n }\n };\n function SmoothGeom$Companion() {\n SmoothGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n this.PROPORTION_0 = SmoothGeom$Companion$PROPORTION$lambda;\n this.ZERO_0 = SmoothGeom$Companion$ZERO$lambda;\n }\n function SmoothGeom$Companion$PROPORTION$lambda(v) {\n return v == null ? null : v / 10;\n }\n function SmoothGeom$Companion$ZERO$lambda(f) {\n return 0.0;\n }\n SmoothGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SmoothGeom$Companion_instance = null;\n function SmoothGeom$Companion_getInstance() {\n if (SmoothGeom$Companion_instance === null) {\n new SmoothGeom$Companion();\n }return SmoothGeom$Companion_instance;\n }\n SmoothGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SmoothGeom',\n interfaces: [GeomBase]\n };\n function StepGeom() {\n StepGeom$Companion_getInstance();\n LineGeom.call(this);\n this.myDirection_0 = StepGeom$Companion_getInstance().DEF_DIRECTION;\n }\n StepGeom.prototype.setDirection_61zpoe$ = function (dir) {\n this.myDirection_0 = StepGeom$Direction$Companion_getInstance().toDirection_61zpoe$(dir);\n };\n StepGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var pathInfos = helper.createSteps_1fp004$(dataPoints, this.myDirection_0);\n tmp$ = pathInfos.iterator();\n while (tmp$.hasNext()) {\n var pathInfo = tmp$.next();\n root.add_26jijc$(pathInfo.path.rootGroup);\n }\n };\n function StepGeom$Direction(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function StepGeom$Direction_initFields() {\n StepGeom$Direction_initFields = function () {\n };\n StepGeom$Direction$HV_instance = new StepGeom$Direction('HV', 0);\n StepGeom$Direction$VH_instance = new StepGeom$Direction('VH', 1);\n StepGeom$Direction$Companion_getInstance();\n }\n var StepGeom$Direction$HV_instance;\n function StepGeom$Direction$HV_getInstance() {\n StepGeom$Direction_initFields();\n return StepGeom$Direction$HV_instance;\n }\n var StepGeom$Direction$VH_instance;\n function StepGeom$Direction$VH_getInstance() {\n StepGeom$Direction_initFields();\n return StepGeom$Direction$VH_instance;\n }\n function StepGeom$Direction$Companion() {\n StepGeom$Direction$Companion_instance = this;\n }\n StepGeom$Direction$Companion.prototype.toDirection_61zpoe$ = function (str) {\n var tmp$;\n switch (str) {\n case 'hv':\n case 'HV':\n tmp$ = StepGeom$Direction$HV_getInstance();\n break;\n case 'vh':\n case 'VH':\n tmp$ = StepGeom$Direction$VH_getInstance();\n break;\n default:throw IllegalArgumentException_init('Direction ' + str + \" is not allowed, only accept 'hv' or 'vh'\");\n }\n return tmp$;\n };\n StepGeom$Direction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StepGeom$Direction$Companion_instance = null;\n function StepGeom$Direction$Companion_getInstance() {\n StepGeom$Direction_initFields();\n if (StepGeom$Direction$Companion_instance === null) {\n new StepGeom$Direction$Companion();\n }return StepGeom$Direction$Companion_instance;\n }\n StepGeom$Direction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Direction',\n interfaces: [Enum]\n };\n function StepGeom$Direction$values() {\n return [StepGeom$Direction$HV_getInstance(), StepGeom$Direction$VH_getInstance()];\n }\n StepGeom$Direction.values = StepGeom$Direction$values;\n function StepGeom$Direction$valueOf(name) {\n switch (name) {\n case 'HV':\n return StepGeom$Direction$HV_getInstance();\n case 'VH':\n return StepGeom$Direction$VH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.StepGeom.Direction.' + name);\n }\n }\n StepGeom$Direction.valueOf_61zpoe$ = StepGeom$Direction$valueOf;\n function StepGeom$Companion() {\n StepGeom$Companion_instance = this;\n this.DEF_DIRECTION = StepGeom$Direction$HV_getInstance();\n this.HANDLES_GROUPS = LineGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n StepGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StepGeom$Companion_instance = null;\n function StepGeom$Companion_getInstance() {\n if (StepGeom$Companion_instance === null) {\n new StepGeom$Companion();\n }return StepGeom$Companion_instance;\n }\n StepGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StepGeom',\n interfaces: [LineGeom]\n };\n function TextGeom() {\n TextGeom$Companion_getInstance();\n GeomBase.call(this);\n this.formatter = null;\n this.naValue = TextGeom$Companion_getInstance().DEF_NA_VALUE;\n this.sizeUnit = null;\n }\n Object.defineProperty(TextGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new TextLegendKeyElementFactory();\n }\n });\n TextGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var sizeUnitRatio = this.getSizeUnitRatio_0(ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = p.x();\n var y = p.y();\n var text = this.toString_0(p.label());\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && !base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n var label = new TextLabel(text);\n GeomHelper$Companion_getInstance().decorate_ijkgsm$(label, p, sizeUnitRatio);\n var loc = helper.toClient_vf7nkp$(x, y, p);\n label.moveTo_gpjtzr$(loc);\n root.add_26jijc$(label.rootGroup);\n targetCollector.addPoint_cnsimy$(p.index(), loc, sizeUnitRatio * AesScaling_getInstance().textSize_l6g9mh$(p) / 2, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance());\n }}\n };\n TextGeom.prototype.getSizeUnitRatio_0 = function (ctx) {\n var tmp$;\n if (this.sizeUnit != null) {\n var textWidth = 6.0;\n var unitRes = ctx.getUnitResolution_vktour$(GeomHelper$Companion_getInstance().getSizeUnitAes_61zpoe$(ensureNotNull(this.sizeUnit)));\n tmp$ = unitRes / textWidth;\n } else {\n tmp$ = 1.0;\n }\n return tmp$;\n };\n TextGeom.prototype.toString_0 = function (label) {\n var tmp$;\n if (label == null)\n tmp$ = this.naValue;\n else if (this.formatter != null)\n tmp$ = ensureNotNull(this.formatter).format_za3rmp$(label);\n else\n tmp$ = label.toString();\n return tmp$;\n };\n function TextGeom$Companion() {\n TextGeom$Companion_instance = this;\n this.DEF_NA_VALUE = 'n/a';\n this.HANDLES_GROUPS = false;\n }\n TextGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TextGeom$Companion_instance = null;\n function TextGeom$Companion_getInstance() {\n if (TextGeom$Companion_instance === null) {\n new TextGeom$Companion();\n }return TextGeom$Companion_instance;\n }\n TextGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextGeom',\n interfaces: [GeomBase]\n };\n function TextLegendKeyElementFactory() {\n }\n TextLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var label = new TextLabel('a');\n GeomHelper$Companion_getInstance().decorate_ijkgsm$(label, p);\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor$CENTER_getInstance());\n label.moveTo_lu1900$(size.x / 2, size.y / 2);\n var g = new SvgGElement();\n g.children().add_11rb$(label.rootGroup);\n return g;\n };\n TextLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(4.0, strokeWidth + 4);\n };\n TextLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function TileGeom() {\n TileGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n function TileGeom$buildIntern$lambda(p) {\n return HintColorUtil_getInstance().fromFill_l6g9mh$(p);\n }\n TileGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var slimGroup = helper.createSlimRectangles_rezc4r$(TileGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup));\n (new RectTargetCollectorHelper(helper, TileGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), TileGeom$buildIntern$lambda, TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance())).collectTo_xrq6q$(ctx.targetCollector);\n };\n function TileGeom$Companion() {\n TileGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function TileGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n var x = p.x();\n var y = p.y();\n var w = p.width();\n var h = p.height();\n var rect = null;\n if (data.SeriesUtil.allFinite_rd1tgs$(x, y, w, h)) {\n var width = ensureNotNull(w) * closure$ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var height = ensureNotNull(h) * closure$ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n var origin = new DoubleVector(ensureNotNull(x) - width / 2, ensureNotNull(y) - height / 2);\n var dimensions = new DoubleVector(width, height);\n rect = new DoubleRectangle(origin, dimensions);\n }return rect;\n };\n }\n TileGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return TileGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n TileGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TileGeom$Companion_instance = null;\n function TileGeom$Companion_getInstance() {\n if (TileGeom$Companion_instance === null) {\n new TileGeom$Companion();\n }return TileGeom$Companion_instance;\n }\n TileGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileGeom',\n interfaces: [GeomBase]\n };\n function VLineGeom() {\n VLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(VLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return VLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n VLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.interceptX();\n if (data.SeriesUtil.isFinite_yrwdxb$(intercept)) {\n if (viewPort.xRange().contains_mef7kx$(ensureNotNull(intercept))) {\n var start = new DoubleVector(intercept, viewPort.top);\n var end = new DoubleVector(intercept, viewPort.bottom);\n var line = helper.createLine_ollnar$(start, end, p);\n lines.add_11rb$(line);\n var a = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = JsMath.max(a, 2.0) * 2.0;\n var origin = new DoubleVector(intercept - width / 2, end.y);\n var dimensions = new DoubleVector(width, 0.0);\n var rect = new DoubleRectangle(origin, dimensions);\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), geomHelper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n }}}\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n };\n function VLineGeom$Companion() {\n VLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_KEY_ELEMENT_FACTORY = new VLineLegendKeyElementFactory();\n }\n VLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VLineGeom$Companion_instance = null;\n function VLineGeom$Companion_getInstance() {\n if (VLineGeom$Companion_instance === null) {\n new VLineGeom$Companion();\n }return VLineGeom$Companion_instance;\n }\n VLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VLineGeom',\n interfaces: [GeomBase]\n };\n function CompositeLegendKeyElementFactory(factories) {\n this.factories_0 = factories;\n }\n CompositeLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var tmp$, tmp$_0;\n var g = new SvgGElement();\n tmp$ = this.factories_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var factory = tmp$[tmp$_0];\n g.children().add_11rb$(factory.createKeyElement_s1fn0c$(p, size));\n }\n return g;\n };\n CompositeLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n return LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$.call(this, p);\n };\n CompositeLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function GenericLegendKeyElementFactory() {\n }\n GenericLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var rect = SvgRectElement_init(0.0, 0.0, size.x, size.y);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(rect, p);\n var line = SvgLineElement_init(0.0, size.y, size.x, 0.0);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n g.children().add_11rb$(line);\n return g;\n };\n GenericLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GenericLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function HLineLegendKeyElementFactory() {\n }\n HLineLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var line = SvgLineElement_init(0.0, size.y / 2, size.x, size.y / 2);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(line);\n return g;\n };\n HLineLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(4.0, strokeWidth + 4);\n };\n HLineLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HLineLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function VLineLegendKeyElementFactory() {\n }\n VLineLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var line = SvgLineElement_init(size.x / 2, 0.0, size.x / 2, size.y);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(line);\n return g;\n };\n VLineLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(strokeWidth + 4, 4.0);\n };\n VLineLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VLineLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function ArrowSpec(angle, length, end, type) {\n this.angle = angle;\n this.length = length;\n this.end = end;\n this.type = type;\n }\n Object.defineProperty(ArrowSpec.prototype, 'isOnFirstEnd', {\n configurable: true,\n get: function () {\n return this.end === ArrowSpec$End$FIRST_getInstance() || this.end === ArrowSpec$End$BOTH_getInstance();\n }\n });\n Object.defineProperty(ArrowSpec.prototype, 'isOnLastEnd', {\n configurable: true,\n get: function () {\n return this.end === ArrowSpec$End$LAST_getInstance() || this.end === ArrowSpec$End$BOTH_getInstance();\n }\n });\n ArrowSpec.prototype.createElement_yvo9jy$ = function (polarAngle, x, y) {\n var tmp$ = Float64Array;\n var tmp$_0 = this.length;\n var x_0 = polarAngle - this.angle;\n var tmp$_1 = x - tmp$_0 * JsMath.cos(x_0);\n var tmp$_2 = this.length;\n var x_1 = polarAngle + this.angle;\n var xs = new tmp$([tmp$_1, x, x - tmp$_2 * JsMath.cos(x_1)]);\n var tmp$_3 = Float64Array;\n var tmp$_4 = this.length;\n var x_2 = polarAngle - this.angle;\n var tmp$_5 = y - tmp$_4 * JsMath.sin(x_2);\n var tmp$_6 = this.length;\n var x_3 = polarAngle + this.angle;\n var ys = new tmp$_3([tmp$_5, y, y - tmp$_6 * JsMath.sin(x_3)]);\n var b = (new SvgPathDataBuilder(true)).moveTo_przk3b$(xs[0], ys[0]);\n for (var i = 1; i <= 2; i++) {\n b.lineTo_przk3b$(xs[i], ys[i], true);\n }\n if (this.type === ArrowSpec$Type$CLOSED_getInstance()) {\n b.closePath();\n }return SvgPathElement_init(b.build());\n };\n function ArrowSpec$toArrowAes$ObjectLiteral(this$ArrowSpec, p) {\n DataPointAestheticsDelegate.call(this, p);\n this.myFilled_0 = this$ArrowSpec.type === ArrowSpec$Type$CLOSED_getInstance();\n }\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.fill = function () {\n var tmp$;\n if (this.myFilled_0) {\n tmp$ = this.color();\n } else\n tmp$ = Color.Companion.TRANSPARENT;\n return tmp$;\n };\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.lineType = function () {\n var tmp$;\n if (this.myFilled_0) {\n tmp$ = NamedLineType$SOLID_getInstance();\n } else\n tmp$ = DataPointAestheticsDelegate.prototype.lineType.call(this);\n return tmp$;\n };\n ArrowSpec$toArrowAes$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DataPointAestheticsDelegate]\n };\n ArrowSpec.prototype.toArrowAes_l6g9mh$ = function (p) {\n return new ArrowSpec$toArrowAes$ObjectLiteral(this, p);\n };\n function ArrowSpec$End(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ArrowSpec$End_initFields() {\n ArrowSpec$End_initFields = function () {\n };\n ArrowSpec$End$LAST_instance = new ArrowSpec$End('LAST', 0);\n ArrowSpec$End$FIRST_instance = new ArrowSpec$End('FIRST', 1);\n ArrowSpec$End$BOTH_instance = new ArrowSpec$End('BOTH', 2);\n }\n var ArrowSpec$End$LAST_instance;\n function ArrowSpec$End$LAST_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$LAST_instance;\n }\n var ArrowSpec$End$FIRST_instance;\n function ArrowSpec$End$FIRST_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$FIRST_instance;\n }\n var ArrowSpec$End$BOTH_instance;\n function ArrowSpec$End$BOTH_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$BOTH_instance;\n }\n ArrowSpec$End.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'End',\n interfaces: [Enum]\n };\n function ArrowSpec$End$values() {\n return [ArrowSpec$End$LAST_getInstance(), ArrowSpec$End$FIRST_getInstance(), ArrowSpec$End$BOTH_getInstance()];\n }\n ArrowSpec$End.values = ArrowSpec$End$values;\n function ArrowSpec$End$valueOf(name) {\n switch (name) {\n case 'LAST':\n return ArrowSpec$End$LAST_getInstance();\n case 'FIRST':\n return ArrowSpec$End$FIRST_getInstance();\n case 'BOTH':\n return ArrowSpec$End$BOTH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.util.ArrowSpec.End.' + name);\n }\n }\n ArrowSpec$End.valueOf_61zpoe$ = ArrowSpec$End$valueOf;\n function ArrowSpec$Type(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ArrowSpec$Type_initFields() {\n ArrowSpec$Type_initFields = function () {\n };\n ArrowSpec$Type$OPEN_instance = new ArrowSpec$Type('OPEN', 0);\n ArrowSpec$Type$CLOSED_instance = new ArrowSpec$Type('CLOSED', 1);\n }\n var ArrowSpec$Type$OPEN_instance;\n function ArrowSpec$Type$OPEN_getInstance() {\n ArrowSpec$Type_initFields();\n return ArrowSpec$Type$OPEN_instance;\n }\n var ArrowSpec$Type$CLOSED_instance;\n function ArrowSpec$Type$CLOSED_getInstance() {\n ArrowSpec$Type_initFields();\n return ArrowSpec$Type$CLOSED_instance;\n }\n ArrowSpec$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function ArrowSpec$Type$values() {\n return [ArrowSpec$Type$OPEN_getInstance(), ArrowSpec$Type$CLOSED_getInstance()];\n }\n ArrowSpec$Type.values = ArrowSpec$Type$values;\n function ArrowSpec$Type$valueOf(name) {\n switch (name) {\n case 'OPEN':\n return ArrowSpec$Type$OPEN_getInstance();\n case 'CLOSED':\n return ArrowSpec$Type$CLOSED_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.util.ArrowSpec.Type.' + name);\n }\n }\n ArrowSpec$Type.valueOf_61zpoe$ = ArrowSpec$Type$valueOf;\n ArrowSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ArrowSpec',\n interfaces: []\n };\n function BarTooltipHelper() {\n BarTooltipHelper_instance = this;\n }\n BarTooltipHelper.prototype.collectRectangleTargets_mj9gdb$ = function (hintAesList, aesthetics, pos, coord, ctx, rectFactory, colorFactory) {\n var tmp$, tmp$_0;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n tmp$_0 = rectFactory(p);\n if (tmp$_0 == null) {\n continue;\n }var rect = tmp$_0;\n var clientRect = helper.toClient_ioi29i$(DoubleRectangle_init(0.0, 0.0, rect.width, 0.0), p);\n var objectRadius = clientRect.width / 2.0;\n var xCoord = rect.center.x;\n var hintFactory = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(objectRadius).defaultX_14dthe$(xCoord).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance());\n var tmp$_1;\n var accumulator = new HintsCollection(p, helper);\n tmp$_1 = hintAesList.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n accumulator = accumulator.addHint_p9kkqu$(hintFactory.create_vktour$(element));\n }\n var hintConfigs = accumulator;\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), helper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintConfigs.hints).setColor_98b62m$(colorFactory(p)));\n }\n };\n BarTooltipHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BarTooltipHelper',\n interfaces: []\n };\n var BarTooltipHelper_instance = null;\n function BarTooltipHelper_getInstance() {\n if (BarTooltipHelper_instance === null) {\n new BarTooltipHelper();\n }return BarTooltipHelper_instance;\n }\n function CrossBarHelper() {\n CrossBarHelper_instance = this;\n }\n CrossBarHelper.prototype.buildBoxes_sm51l0$ = function (root, aesthetics, pos, coord, ctx, rectFactory) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var rectangles = helper.createRectangles_rezc4r$(rectFactory);\n var tmp$;\n tmp$ = rectangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n root.add_26jijc$(element);\n }\n };\n CrossBarHelper.prototype.buildMidlines_z5ejb9$ = function (root, aesthetics, pos, coord, ctx, fatten) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n var elementHelper = helper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().MIDDLE).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var middle = ensureNotNull(p.middle());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, ctx, 2.0);\n var line = elementHelper.createLine_ollnar$(new DoubleVector(x - width / 2, middle), new DoubleVector(x + width / 2, middle), p);\n var thickness = ensureNotNull(line.strokeWidth().get());\n line.strokeWidth().set_11rb$(thickness * fatten);\n root.add_26jijc$(line);\n }\n };\n CrossBarHelper.prototype.legendFactory_6taknv$ = function (whiskers) {\n return new CrossBarLegendKeyElementFactory(whiskers);\n };\n CrossBarHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CrossBarHelper',\n interfaces: []\n };\n var CrossBarHelper_instance = null;\n function CrossBarHelper_getInstance() {\n if (CrossBarHelper_instance === null) {\n new CrossBarHelper();\n }return CrossBarHelper_instance;\n }\n function CrossBarLegendKeyElementFactory(whiskers) {\n this.whiskers = whiskers;\n }\n CrossBarLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var whiskerSize = 0.2;\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = (size.x - strokeWidth) * 0.8;\n var height = size.y - strokeWidth;\n var x = (size.x - width) / 2;\n var y = strokeWidth / 2;\n var boxHeight = height;\n var boxY = y;\n if (this.whiskers) {\n boxHeight = height * (1 - 2 * whiskerSize);\n boxY = y + height * whiskerSize;\n }var rect = SvgRectElement_init(x, boxY, width, boxHeight);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(rect, p);\n var middleY = y + height * 0.5;\n var middle = SvgLineElement_init(x, middleY, x + width, middleY);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(middle, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n g.children().add_11rb$(middle);\n if (this.whiskers) {\n var middleX = x + width * 0.5;\n var lowerWhisker = SvgLineElement_init(middleX, y + height * (1 - whiskerSize), middleX, y + height);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(lowerWhisker, p);\n var upperWhisker = SvgLineElement_init(middleX, y, middleX, y + height * whiskerSize);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(upperWhisker, p);\n g.children().add_11rb$(lowerWhisker);\n g.children().add_11rb$(upperWhisker);\n }return g;\n };\n CrossBarLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossBarLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function DataPointAestheticsDelegate(p) {\n this.p_bcayt6$_0 = p;\n }\n DataPointAestheticsDelegate.prototype.index = function () {\n return this.p_bcayt6$_0.index();\n };\n DataPointAestheticsDelegate.prototype.x = function () {\n return this.p_bcayt6$_0.x();\n };\n DataPointAestheticsDelegate.prototype.y = function () {\n return this.p_bcayt6$_0.y();\n };\n DataPointAestheticsDelegate.prototype.z = function () {\n return this.p_bcayt6$_0.z();\n };\n DataPointAestheticsDelegate.prototype.ymin = function () {\n return this.p_bcayt6$_0.ymin();\n };\n DataPointAestheticsDelegate.prototype.ymax = function () {\n return this.p_bcayt6$_0.ymax();\n };\n DataPointAestheticsDelegate.prototype.color = function () {\n return this.p_bcayt6$_0.color();\n };\n DataPointAestheticsDelegate.prototype.fill = function () {\n return this.p_bcayt6$_0.fill();\n };\n DataPointAestheticsDelegate.prototype.alpha = function () {\n return this.p_bcayt6$_0.alpha();\n };\n DataPointAestheticsDelegate.prototype.shape = function () {\n return this.p_bcayt6$_0.shape();\n };\n DataPointAestheticsDelegate.prototype.lineType = function () {\n return this.p_bcayt6$_0.lineType();\n };\n DataPointAestheticsDelegate.prototype.size = function () {\n return this.p_bcayt6$_0.size();\n };\n DataPointAestheticsDelegate.prototype.width = function () {\n return this.p_bcayt6$_0.width();\n };\n DataPointAestheticsDelegate.prototype.height = function () {\n return this.p_bcayt6$_0.height();\n };\n DataPointAestheticsDelegate.prototype.weight = function () {\n return this.p_bcayt6$_0.weight();\n };\n DataPointAestheticsDelegate.prototype.intercept = function () {\n return this.p_bcayt6$_0.intercept();\n };\n DataPointAestheticsDelegate.prototype.slope = function () {\n return this.p_bcayt6$_0.slope();\n };\n DataPointAestheticsDelegate.prototype.interceptX = function () {\n return this.p_bcayt6$_0.interceptX();\n };\n DataPointAestheticsDelegate.prototype.interceptY = function () {\n return this.p_bcayt6$_0.interceptY();\n };\n DataPointAestheticsDelegate.prototype.lower = function () {\n return this.p_bcayt6$_0.lower();\n };\n DataPointAestheticsDelegate.prototype.middle = function () {\n return this.p_bcayt6$_0.middle();\n };\n DataPointAestheticsDelegate.prototype.upper = function () {\n return this.p_bcayt6$_0.upper();\n };\n DataPointAestheticsDelegate.prototype.frame = function () {\n return this.p_bcayt6$_0.frame();\n };\n DataPointAestheticsDelegate.prototype.speed = function () {\n return this.p_bcayt6$_0.speed();\n };\n DataPointAestheticsDelegate.prototype.flow = function () {\n return this.p_bcayt6$_0.flow();\n };\n DataPointAestheticsDelegate.prototype.xmin = function () {\n return this.p_bcayt6$_0.xmin();\n };\n DataPointAestheticsDelegate.prototype.xmax = function () {\n return this.p_bcayt6$_0.xmax();\n };\n DataPointAestheticsDelegate.prototype.xend = function () {\n return this.p_bcayt6$_0.xend();\n };\n DataPointAestheticsDelegate.prototype.yend = function () {\n return this.p_bcayt6$_0.yend();\n };\n DataPointAestheticsDelegate.prototype.label = function () {\n return this.p_bcayt6$_0.label();\n };\n DataPointAestheticsDelegate.prototype.family = function () {\n return this.p_bcayt6$_0.family();\n };\n DataPointAestheticsDelegate.prototype.fontface = function () {\n return this.p_bcayt6$_0.fontface();\n };\n DataPointAestheticsDelegate.prototype.hjust = function () {\n return this.p_bcayt6$_0.hjust();\n };\n DataPointAestheticsDelegate.prototype.vjust = function () {\n return this.p_bcayt6$_0.vjust();\n };\n DataPointAestheticsDelegate.prototype.angle = function () {\n return this.p_bcayt6$_0.angle();\n };\n DataPointAestheticsDelegate.prototype.symX = function () {\n return this.p_bcayt6$_0.symX();\n };\n DataPointAestheticsDelegate.prototype.symY = function () {\n return this.p_bcayt6$_0.symY();\n };\n DataPointAestheticsDelegate.prototype.group = function () {\n return this.p_bcayt6$_0.group();\n };\n DataPointAestheticsDelegate.prototype.numeric_vktour$ = function (aes) {\n return this.p_bcayt6$_0.numeric_vktour$(aes);\n };\n DataPointAestheticsDelegate.prototype.get_31786j$ = function (aes) {\n return this.p_bcayt6$_0.get_31786j$(aes);\n };\n DataPointAestheticsDelegate.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataPointAestheticsDelegate',\n interfaces: [DataPointAesthetics]\n };\n function GeomCoord(myCoord) {\n this.myCoord_0 = myCoord;\n }\n GeomCoord.prototype.toClient_gpjtzr$ = function (p) {\n return this.myCoord_0.toClient_gpjtzr$(p);\n };\n GeomCoord.prototype.fromClient_xoefl8$ = function (location) {\n return this.myCoord_0.fromClient_gpjtzr$(location);\n };\n function GeomCoord$toClient$lambda(this$GeomCoord) {\n return function (coord) {\n return this$GeomCoord.myCoord_0.toClient_gpjtzr$(coord);\n };\n }\n GeomCoord.prototype.toClient_wthzt5$ = function (r) {\n return this.translateRect_0(r, GeomCoord$toClient$lambda(this));\n };\n function GeomCoord$fromClient$lambda(this$GeomCoord) {\n return function (coord) {\n return this$GeomCoord.myCoord_0.fromClient_gpjtzr$(coord);\n };\n }\n GeomCoord.prototype.fromClient_wthzt5$ = function (r) {\n return this.translateRect_0(r, GeomCoord$fromClient$lambda(this));\n };\n GeomCoord.prototype.translateRect_0 = function (r, toLocation) {\n var r_0 = r;\n var xy1 = r_0.origin;\n var xy2 = new DoubleVector(r_0.right, r_0.bottom);\n var xy1cl = toLocation(xy1);\n var xy2cl = toLocation(xy2);\n if (!(xy1 != null ? xy1.equals(xy1cl) : null) || !(xy2 != null ? xy2.equals(xy2cl) : null)) {\n var a = xy1cl.x;\n var b = xy2cl.x;\n var xMin = JsMath.min(a, b);\n var a_0 = xy1cl.y;\n var b_0 = xy2cl.y;\n var yMin = JsMath.min(a_0, b_0);\n var a_1 = xy1cl.x;\n var b_1 = xy2cl.x;\n var xMax = JsMath.max(a_1, b_1);\n var a_2 = xy1cl.y;\n var b_2 = xy2cl.y;\n var yMax = JsMath.max(a_2, b_2);\n r_0 = DoubleRectangle_init(xMin, yMin, xMax - xMin, yMax - yMin);\n }return r_0;\n };\n GeomCoord.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomCoord',\n interfaces: []\n };\n function GeomHelper(myPos, coord, ctx) {\n GeomHelper$Companion_getInstance();\n this.myPos_ts7al2$_0 = myPos;\n this.ctx = ctx;\n this.myGeomCoord_mnazw1$_0 = new GeomCoord(coord);\n }\n GeomHelper.prototype.toClient_tkjljq$ = function (location, p) {\n return this.myGeomCoord_mnazw1$_0.toClient_gpjtzr$(this.adjust_umm47c$_0(location, p, this.myPos_ts7al2$_0, this.ctx));\n };\n GeomHelper.prototype.toClient_vf7nkp$ = function (x, y, p) {\n var location = new DoubleVector(ensureNotNull(x), ensureNotNull(y));\n return this.myGeomCoord_mnazw1$_0.toClient_gpjtzr$(this.adjust_umm47c$_0(location, p, this.myPos_ts7al2$_0, this.ctx));\n };\n GeomHelper.prototype.toClient_ioi29i$ = function (r, p) {\n var clientRect = this.myGeomCoord_mnazw1$_0.toClient_wthzt5$(this.adjust_en6it6$_0(r, p, this.myPos_ts7al2$_0, this.ctx));\n if (clientRect.width === 0.0) {\n clientRect = DoubleRectangle_init(clientRect.origin.x, clientRect.origin.y, 0.1, clientRect.height);\n }if (clientRect.height === 0.0) {\n clientRect = DoubleRectangle_init(clientRect.origin.x, clientRect.origin.y, clientRect.width, 0.1);\n }return clientRect;\n };\n GeomHelper.prototype.fromClient_gpjtzr$ = function (location) {\n return this.myGeomCoord_mnazw1$_0.fromClient_xoefl8$(location);\n };\n GeomHelper.prototype.adjust_umm47c$_0 = function (location, p, pos, ctx) {\n return pos.translate_tshsjz$(location, p, ctx);\n };\n GeomHelper.prototype.toClientRect_7iz5gz$ = function (p, aesMapper) {\n var tmp$;\n tmp$ = aesMapper(p);\n if (tmp$ == null) {\n return null;\n }var r = tmp$;\n return this.toClient_ioi29i$(r, p);\n };\n GeomHelper.prototype.adjust_en6it6$_0 = function (r, p, pos, ctx) {\n var leftTop = pos.translate_tshsjz$(r.origin, p, ctx);\n var rightBottom = pos.translate_tshsjz$(r.origin.add_gpjtzr$(r.dimension), p, ctx);\n return DoubleRectangle.Companion.span_qt8ska$(leftTop, rightBottom);\n };\n GeomHelper.prototype.project_rrreuh$ = function (dataPoints, projection) {\n var tmp$;\n var points = ArrayList_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var location = projection(p);\n if (location != null) {\n var pp = this.toClient_tkjljq$(location, p);\n points.add_11rb$(pp);\n }}\n return points;\n };\n function GeomHelper$toClientLocation$lambda(closure$aesMapper, this$GeomHelper) {\n return function (aes) {\n var location = closure$aesMapper(aes);\n if (location != null) {\n return this$GeomHelper.toClient_tkjljq$(location, aes);\n } else {\n return null;\n }\n };\n }\n GeomHelper.prototype.toClientLocation_sfitzs$ = function (aesMapper) {\n return GeomHelper$toClientLocation$lambda(aesMapper, this);\n };\n GeomHelper.prototype.createSvgElementHelper = function () {\n return new GeomHelper$SvgElementHelper(this);\n };\n GeomHelper.prototype.toClient_je5qx7$ = function (locations, p) {\n var tmp$;\n var localLocations = ArrayList_init();\n tmp$ = locations.iterator();\n while (tmp$.hasNext()) {\n var location = tmp$.next();\n localLocations.add_11rb$(this.toClient_tkjljq$(location, p));\n }\n return localLocations;\n };\n function GeomHelper$SvgElementHelper($outer) {\n this.$outer = $outer;\n this.myStrokeAlphaEnabled_0 = false;\n }\n GeomHelper$SvgElementHelper.prototype.setStrokeAlphaEnabled_6taknv$ = function (b) {\n this.myStrokeAlphaEnabled_0 = b;\n };\n GeomHelper$SvgElementHelper.prototype.createLine_ollnar$ = function (start, end, p) {\n var start_0 = this.$outer.toClient_tkjljq$(start, p);\n var end_0 = this.$outer.toClient_tkjljq$(end, p);\n var line = SvgLineElement_init(start_0.x, start_0.y, end_0.x, end_0.y);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p, this.myStrokeAlphaEnabled_0);\n return line;\n };\n GeomHelper$SvgElementHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgElementHelper',\n interfaces: []\n };\n function GeomHelper$Companion() {\n GeomHelper$Companion_instance = this;\n this.HJUST_MAP = mapOf([to('right', TextLabel$HorizontalAnchor$RIGHT_getInstance()), to('middle', TextLabel$HorizontalAnchor$MIDDLE_getInstance()), to('left', TextLabel$HorizontalAnchor$LEFT_getInstance()), to(0.0, TextLabel$HorizontalAnchor$RIGHT_getInstance()), to(0.5, TextLabel$HorizontalAnchor$MIDDLE_getInstance()), to(1.0, TextLabel$HorizontalAnchor$LEFT_getInstance())]);\n this.VJUST_MAP = mapOf([to('bottom', TextLabel$VerticalAnchor$BOTTOM_getInstance()), to('center', TextLabel$VerticalAnchor$CENTER_getInstance()), to('top', TextLabel$VerticalAnchor$TOP_getInstance()), to(0.0, TextLabel$VerticalAnchor$BOTTOM_getInstance()), to(0.5, TextLabel$VerticalAnchor$CENTER_getInstance()), to(1.0, TextLabel$VerticalAnchor$TOP_getInstance())]);\n this.FONT_WEIGHT_SET_0 = setOf(['bold', 'bolder', 'lighter']);\n this.FONT_STYLE_SET_0 = setOf(['italic', 'oblique']);\n this.FONT_FAMILY_MAP_0 = mapOf([to('sans', 'sans-serif'), to('serif', 'serif'), to('mono', 'monospace')]);\n }\n GeomHelper$Companion.prototype.decorate_ijkgsm$ = function (label, p, scale) {\n if (scale === void 0)\n scale = 1.0;\n var tmp$, tmp$_0;\n label.textColor().set_11rb$(p.color());\n label.textOpacity().set_11rb$(p.alpha());\n label.setFontSize_14dthe$(AesScaling_getInstance().textSize_l6g9mh$(p) * scale);\n var family = p.family();\n if (this.FONT_FAMILY_MAP_0.containsKey_11rb$(family)) {\n family = ensureNotNull(this.FONT_FAMILY_MAP_0.get_11rb$(family));\n }label.setFontFamily_pdl1vj$(family);\n var fontface = p.fontface();\n if (!base.Strings.isNullOrEmpty_pdl1vj$(fontface)) {\n var $receiver = Regex_init(' ').split_905azu$(fontface, 0);\n var dropLastWhile$result;\n dropLastWhile$break: do {\n if (!$receiver.isEmpty()) {\n var iterator = $receiver.listIterator_za3lpa$($receiver.size);\n while (iterator.hasPrevious()) {\n if (!(iterator.previous().length === 0)) {\n dropLastWhile$result = take($receiver, iterator.nextIndex() + 1 | 0);\n break dropLastWhile$break;\n }}\n }dropLastWhile$result = emptyList();\n }\n while (false);\n tmp$ = copyToArray(dropLastWhile$result);\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var s = tmp$[tmp$_0];\n if (this.FONT_WEIGHT_SET_0.contains_11rb$(s)) {\n label.setFontWeight_pdl1vj$(s);\n } else if (this.FONT_STYLE_SET_0.contains_11rb$(s)) {\n label.setFontStyle_pdl1vj$(s);\n }}\n }var hAnchor = this.textLabelAnchor_3zqsx9$(p.hjust(), this.HJUST_MAP, TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n var vAnchor = this.textLabelAnchor_3zqsx9$(p.vjust(), this.VJUST_MAP, TextLabel$VerticalAnchor$CENTER_getInstance());\n if (hAnchor !== TextLabel$HorizontalAnchor$LEFT_getInstance()) {\n label.setHorizontalAnchor_ja80zo$(hAnchor);\n }if (vAnchor !== TextLabel$VerticalAnchor$BOTTOM_getInstance()) {\n label.setVerticalAnchor_yaudma$(vAnchor);\n }var angle = ensureNotNull(p.angle());\n if (angle !== 0.0) {\n angle = 360 - angle % 360;\n label.rotate_14dthe$(angle);\n }};\n GeomHelper$Companion.prototype.textLabelAnchor_3zqsx9$ = function (o, conversionMap, def) {\n var tmp$;\n return (tmp$ = conversionMap.get_11rb$(o)) != null ? tmp$ : def;\n };\n GeomHelper$Companion.prototype.decorate_d9jm6k$ = function (node, p, applyAlphaToAll) {\n if (applyAlphaToAll === void 0)\n applyAlphaToAll = AestheticsUtil_getInstance().ALPHA_CONTROLS_BOTH_8be2vx$;\n var tmp$;\n if (Kotlin.isType(node, SvgShape)) {\n this.decorateShape_0(Kotlin.isType(tmp$ = node, SvgShape) ? tmp$ : throwCCE(), p, applyAlphaToAll);\n }if (Kotlin.isType(node, SvgElement)) {\n var lineType = p.lineType();\n if (!(lineType.isBlank || lineType.isSolid)) {\n StrokeDashArraySupport_getInstance().apply_3xqz7j$(node, AesScaling_getInstance().strokeWidth_l6g9mh$(p), lineType.dashArray);\n }}};\n GeomHelper$Companion.prototype.decorateShape_0 = function (shape, p, applyAlphaToAll) {\n AestheticsUtil_getInstance().updateStroke_g0plfl$(shape, p, applyAlphaToAll);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(shape, p);\n shape.strokeWidth().set_11rb$(AesScaling_getInstance().strokeWidth_l6g9mh$(p));\n };\n GeomHelper$Companion.prototype.decorateSlimShape_gb6c9f$ = function (shape, p) {\n var stroke = ensureNotNull(p.color());\n var strokeAlpha = AestheticsUtil_getInstance().alpha_il6rhx$(stroke, p);\n var fill = ensureNotNull(p.fill());\n var fillAlpha = AestheticsUtil_getInstance().alpha_il6rhx$(fill, p);\n shape.setFill_o14uds$(fill, fillAlpha);\n shape.setStroke_o14uds$(stroke, strokeAlpha);\n shape.setStrokeWidth_14dthe$(AesScaling_getInstance().strokeWidth_l6g9mh$(p));\n };\n GeomHelper$Companion.prototype.getSizeUnitAes_61zpoe$ = function (sizeUnitName) {\n var tmp$;\n switch (sizeUnitName.toLowerCase()) {\n case 'x':\n tmp$ = Aes$Companion_getInstance().X;\n break;\n case 'y':\n tmp$ = Aes$Companion_getInstance().Y;\n break;\n default:throw IllegalStateException_init((\"Size unit value must be either 'x' or 'y', but was \" + sizeUnitName + '.').toString());\n }\n return tmp$;\n };\n GeomHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomHelper$Companion_instance = null;\n function GeomHelper$Companion_getInstance() {\n if (GeomHelper$Companion_instance === null) {\n new GeomHelper$Companion();\n }return GeomHelper$Companion_instance;\n }\n GeomHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomHelper',\n interfaces: []\n };\n function GeomUtil() {\n GeomUtil_instance = this;\n this.TO_LOCATION_X_Y = GeomUtil$TO_LOCATION_X_Y$lambda(this);\n this.TO_LOCATION_X_YMIN = GeomUtil$TO_LOCATION_X_YMIN$lambda(this);\n this.TO_LOCATION_X_YMAX = GeomUtil$TO_LOCATION_X_YMAX$lambda(this);\n this.TO_LOCATION_X_ZERO = GeomUtil$TO_LOCATION_X_ZERO$lambda(this);\n this.TO_RECTANGLE = GeomUtil$TO_RECTANGLE$lambda(this);\n this.ORDERING_X_0 = Ordering.Companion.from_iajr8b$(new GeomUtil$ORDERING_X$ObjectLiteral());\n this.ORDERING_Y_0 = Ordering.Companion.from_iajr8b$(new GeomUtil$ORDERING_Y$ObjectLiteral());\n this.WITH_X_Y_0 = GeomUtil$WITH_X_Y$lambda;\n this.WITH_X_0 = GeomUtil$WITH_X$lambda;\n this.WITH_Y_0 = GeomUtil$WITH_Y$lambda;\n }\n GeomUtil.prototype.toLocationOrNull_0 = function (x, y) {\n var tmp$;\n if (data.SeriesUtil.isFinite_yrwdxb$(x) && data.SeriesUtil.isFinite_yrwdxb$(y)) {\n tmp$ = new DoubleVector(ensureNotNull(x), ensureNotNull(y));\n } else\n tmp$ = null;\n return tmp$;\n };\n GeomUtil.prototype.with_X_Y_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_X_Y_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.with_X_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_X_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.with_Y_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_Y_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.ordered_X_83glv4$ = function (dataPoints) {\n if (this.ORDERING_X_0.isOrdered_p1ys8y$(dataPoints)) {\n return dataPoints;\n }return this.ORDERING_X_0.sortedCopy_m5x2f4$(dataPoints);\n };\n GeomUtil.prototype.ordered_Y_hku6c7$ = function (dataPoints, reversed) {\n var ordering = reversed ? this.ORDERING_Y_0.reverse() : this.ORDERING_Y_0;\n if (ordering.isOrdered_p1ys8y$(dataPoints)) {\n return dataPoints;\n }return ordering.sortedCopy_m5x2f4$(dataPoints);\n };\n GeomUtil.prototype.widthPx_c6teas$ = function (p, ctx, minWidth) {\n var w = p.width();\n var width = ensureNotNull(w) * ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n return JsMath.max(width, minWidth);\n };\n GeomUtil.prototype.withDefined_2oeq97$ = function (dataPoints, aes) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_fl3lpi$ = function (dataPoints, aes0, aes1) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_7jazl$ = function (dataPoints, aes0, aes1, aes2) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1) && element.defined_896ixz$(aes2))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_i1kplo$ = function (dataPoints, aes0, aes1, aes2, aes3) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1) && element.defined_896ixz$(aes2) && element.defined_896ixz$(aes3))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.rectangleByDataPoint_dyn5n6$ = function (p, ctx) {\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var width = this.widthPx_c6teas$(p, ctx, 2.0);\n var origin;\n var dimensions;\n if (y >= 0) {\n origin = new DoubleVector(x - width / 2, 0.0);\n dimensions = new DoubleVector(width, y);\n } else {\n origin = new DoubleVector(x - width / 2, y);\n dimensions = new DoubleVector(width, -y);\n }\n return new DoubleRectangle(origin, dimensions);\n };\n GeomUtil.prototype.createGroups_83glv4$ = function (dataPoints) {\n var tmp$;\n var pointsByGroup = HashMap_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var group = ensureNotNull(p.group());\n if (!pointsByGroup.containsKey_11rb$(group)) {\n var value = ArrayList_init();\n pointsByGroup.put_xwzc9p$(group, value);\n }ensureNotNull(pointsByGroup.get_11rb$(group)).add_11rb$(p);\n }\n return pointsByGroup;\n };\n GeomUtil.prototype.rectToGeometry_6y0v78$ = function (minX, minY, maxX, maxY) {\n return listOf([new DoubleVector(minX, minY), new DoubleVector(minX, maxY), new DoubleVector(maxX, maxY), new DoubleVector(maxX, minY), new DoubleVector(minX, minY)]);\n };\n function GeomUtil$TO_LOCATION_X_Y$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.y());\n };\n }\n function GeomUtil$TO_LOCATION_X_YMIN$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.ymin());\n };\n }\n function GeomUtil$TO_LOCATION_X_YMAX$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.ymax());\n };\n }\n function GeomUtil$TO_LOCATION_X_ZERO$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), 0.0);\n };\n }\n function GeomUtil$TO_RECTANGLE$lambda(this$GeomUtil) {\n return function (p) {\n if (data.SeriesUtil.allFinite_rd1tgs$(p.xmin(), p.ymin(), p.xmax(), p.ymax())) {\n return this$GeomUtil.rectToGeometry_6y0v78$(ensureNotNull(p.xmin()), ensureNotNull(p.ymin()), ensureNotNull(p.xmax()), ensureNotNull(p.ymax()));\n } else {\n return emptyList();\n }\n };\n }\n function GeomUtil$ORDERING_X$ObjectLiteral() {\n }\n GeomUtil$ORDERING_X$ObjectLiteral.prototype.compare = function (a, b) {\n var x1 = a != null ? a.x() : null;\n var x2 = b != null ? b.x() : null;\n if (x1 == null || x2 == null)\n return 0;\n else\n return Kotlin.compareTo(x1, x2);\n };\n GeomUtil$ORDERING_X$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n function GeomUtil$ORDERING_Y$ObjectLiteral() {\n }\n GeomUtil$ORDERING_Y$ObjectLiteral.prototype.compare = function (a, b) {\n var y1 = a != null ? a.y() : null;\n var y2 = b != null ? b.y() : null;\n if (y1 == null || y2 == null)\n return 0;\n else\n return Kotlin.compareTo(y1, y2);\n };\n GeomUtil$ORDERING_Y$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n function GeomUtil$WITH_X_Y$lambda(pointAes) {\n return data.SeriesUtil.allFinite_jma9l8$(pointAes.x(), pointAes.y());\n }\n function GeomUtil$WITH_X$lambda(pointAes) {\n return data.SeriesUtil.isFinite_yrwdxb$(pointAes.x());\n }\n function GeomUtil$WITH_Y$lambda(pointAes) {\n return data.SeriesUtil.isFinite_yrwdxb$(pointAes.y());\n }\n GeomUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomUtil',\n interfaces: []\n };\n var GeomUtil_instance = null;\n function GeomUtil_getInstance() {\n if (GeomUtil_instance === null) {\n new GeomUtil();\n }return GeomUtil_instance;\n }\n function HintColorUtil() {\n HintColorUtil_instance = this;\n }\n HintColorUtil.prototype.fromColor_l6g9mh$ = function (p) {\n return this.fromColorValue_o14uds$(ensureNotNull(p.color()), ensureNotNull(p.alpha()));\n };\n HintColorUtil.prototype.fromFill_l6g9mh$ = function (p) {\n return this.fromColorValue_o14uds$(ensureNotNull(p.fill()), ensureNotNull(p.alpha()));\n };\n HintColorUtil.prototype.fromColorValue_o14uds$ = function (color, alpha) {\n var tmp$;\n var intAlpha = numberToInt(255 * alpha);\n if (values.Colors.solid_98b62m$(color)) {\n tmp$ = color.changeAlpha_za3lpa$(intAlpha);\n } else\n tmp$ = color;\n return tmp$;\n };\n HintColorUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'HintColorUtil',\n interfaces: []\n };\n var HintColorUtil_instance = null;\n function HintColorUtil_getInstance() {\n if (HintColorUtil_instance === null) {\n new HintColorUtil();\n }return HintColorUtil_instance;\n }\n function HintsCollection(myPoint, myHelper) {\n this.myPoint_0 = myPoint;\n this.myHelper_0 = myHelper;\n this.myHints_0 = HashMap_init();\n }\n Object.defineProperty(HintsCollection.prototype, 'hints', {\n configurable: true,\n get: function () {\n return this.myHints_0;\n }\n });\n HintsCollection.prototype.addHint_p9kkqu$ = function (hintConfig) {\n var coord = this.getCoord_0(hintConfig);\n if (coord != null) {\n var $receiver = this.hints;\n var key = hintConfig.aes;\n var value = this.createHint_0(hintConfig, coord);\n $receiver.put_xwzc9p$(key, value);\n }return this;\n };\n HintsCollection.prototype.getCoord_0 = function (hintConfig) {\n var tmp$;\n if (hintConfig.x == null) {\n throw IllegalArgumentException_init('x coord is not set');\n }var aes = hintConfig.aes;\n if (!this.myPoint_0.defined_896ixz$(aes)) {\n tmp$ = null;\n } else\n tmp$ = this.myHelper_0.toClient_tkjljq$(new DoubleVector(ensureNotNull(hintConfig.x), ensureNotNull(this.myPoint_0.get_31786j$(aes))), this.myPoint_0);\n return tmp$;\n };\n HintsCollection.prototype.createHint_0 = function (hintConfig, coord) {\n var tmp$, tmp$_0;\n var objectRadius = hintConfig.objectRadius;\n var color = hintConfig.color_8be2vx$;\n if (objectRadius == null) {\n throw IllegalArgumentException_init('object radius is not set');\n }tmp$ = hintConfig.kind;\n if (equals(tmp$, TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().verticalTooltip_6lq1u6$(coord, objectRadius, color);\n else if (equals(tmp$, TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().horizontalTooltip_6lq1u6$(coord, objectRadius, color);\n else if (equals(tmp$, TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().cursorTooltip_itpcqk$(coord, color);\n else\n throw IllegalArgumentException_init('Unknown hint kind: ' + toString(hintConfig.kind));\n return tmp$_0;\n };\n function HintsCollection$HintConfigFactory() {\n this.myDefaultObjectRadius_0 = null;\n this.myDefaultX_0 = null;\n this.myDefaultColor_0 = null;\n this.myDefaultKind_0 = null;\n }\n HintsCollection$HintConfigFactory.prototype.defaultObjectRadius_14dthe$ = function (defaultObjectRadius) {\n this.myDefaultObjectRadius_0 = defaultObjectRadius;\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.defaultX_14dthe$ = function (defaultX) {\n this.myDefaultX_0 = defaultX;\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.defaultColor_yo1m5r$ = function (v, alpha) {\n if (alpha != null) {\n this.myDefaultColor_0 = v.changeAlpha_za3lpa$(numberToInt(255 * alpha));\n } else {\n this.myDefaultColor_0 = v;\n }\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.create_vktour$ = function (aes) {\n return new HintsCollection$HintConfigFactory$HintConfig(this, aes);\n };\n HintsCollection$HintConfigFactory.prototype.defaultKind_nnfttk$ = function (kind) {\n this.myDefaultKind_0 = kind;\n return this;\n };\n function HintsCollection$HintConfigFactory$HintConfig($outer, aes) {\n this.$outer = $outer;\n this.aes = aes;\n this.kind = null;\n this.objectRadius_u2tfw5$_0 = null;\n this.x_is741i$_0 = null;\n this.color_8be2vx$_ng3d4v$_0 = null;\n this.objectRadius = this.$outer.myDefaultObjectRadius_0;\n this.x = this.$outer.myDefaultX_0;\n this.kind = this.$outer.myDefaultKind_0;\n this.color_8be2vx$ = this.$outer.myDefaultColor_0;\n }\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'objectRadius', {\n configurable: true,\n get: function () {\n return this.objectRadius_u2tfw5$_0;\n },\n set: function (objectRadius) {\n this.objectRadius_u2tfw5$_0 = objectRadius;\n }\n });\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'x', {\n configurable: true,\n get: function () {\n return this.x_is741i$_0;\n },\n set: function (x) {\n this.x_is741i$_0 = x;\n }\n });\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'color_8be2vx$', {\n configurable: true,\n get: function () {\n return this.color_8be2vx$_ng3d4v$_0;\n },\n set: function (color) {\n this.color_8be2vx$_ng3d4v$_0 = color;\n }\n });\n HintsCollection$HintConfigFactory$HintConfig.prototype.objectRadius_14dthe$ = function (v) {\n this.objectRadius = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.prototype.x_14dthe$ = function (v) {\n this.x = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.prototype.color_98b62m$ = function (v) {\n this.color_8be2vx$ = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintConfig',\n interfaces: []\n };\n HintsCollection$HintConfigFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintConfigFactory',\n interfaces: []\n };\n HintsCollection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintsCollection',\n interfaces: []\n };\n function LinePathConstructor(myTargetCollector, myDataPoints, myLinesHelper, myClosePath) {\n LinePathConstructor$Companion_getInstance();\n this.myTargetCollector_0 = myTargetCollector;\n this.myDataPoints_0 = myDataPoints;\n this.myLinesHelper_0 = myLinesHelper;\n this.myClosePath_0 = myClosePath;\n }\n LinePathConstructor.prototype.construct_6taknv$ = function (withHints) {\n var tmp$;\n var linePaths = ArrayList_init();\n var multiPointDataList = this.createMultiPointDataByGroup_0();\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n linePaths.addAll_brywnq$(this.myLinesHelper_0.createPaths_edlkk9$(multiPointData.aes, multiPointData.points, this.myClosePath_0));\n }\n if (withHints) {\n this.buildHints_0(multiPointDataList);\n }return linePaths;\n };\n LinePathConstructor.prototype.buildHints = function () {\n this.buildHints_0(this.createMultiPointDataByGroup_0());\n };\n LinePathConstructor.prototype.buildHints_0 = function (multiPointDataList) {\n var tmp$;\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n if (this.myClosePath_0) {\n this.myTargetCollector_0.addPolygon_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromFill_l6g9mh$(multiPointData.aes)));\n } else {\n this.myTargetCollector_0.addPath_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(multiPointData.aes)));\n }\n }\n };\n function LinePathConstructor$createMultiPointDataByGroup$lambda(this$LinePathConstructor) {\n return function (p) {\n return this$LinePathConstructor.myLinesHelper_0.toClient_tkjljq$(ensureNotNull(GeomUtil_getInstance().TO_LOCATION_X_Y(p)), p);\n };\n }\n LinePathConstructor.prototype.createMultiPointDataByGroup_0 = function () {\n return MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(this.myDataPoints_0, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(LinePathConstructor$createMultiPointDataByGroup$lambda(this)), MultiPointDataConstructor_getInstance().reducer_8555vt$(LinePathConstructor$Companion_getInstance().DROP_POINT_DISTANCE_0, this.myClosePath_0));\n };\n function LinePathConstructor$Companion() {\n LinePathConstructor$Companion_instance = this;\n this.DROP_POINT_DISTANCE_0 = 0.999;\n }\n LinePathConstructor$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinePathConstructor$Companion_instance = null;\n function LinePathConstructor$Companion_getInstance() {\n if (LinePathConstructor$Companion_instance === null) {\n new LinePathConstructor$Companion();\n }return LinePathConstructor$Companion_instance;\n }\n LinePathConstructor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinePathConstructor',\n interfaces: []\n };\n function LinesHelper(pos, coord, ctx) {\n GeomHelper.call(this, pos, coord, ctx);\n this.myAlphaFilter_nxoahd$_0 = LinesHelper$myAlphaFilter$lambda;\n this.myWidthFilter_sx37fb$_0 = LinesHelper$myWidthFilter$lambda;\n this.myAlphaEnabled_98jfa$_0 = true;\n }\n LinesHelper.prototype.insertPathSeparators_fr5rf4$_0 = function (rings) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (!result.isEmpty()) {\n result.add_11rb$(LinePath$Companion_getInstance().END_OF_SUBPATH);\n }result.addAll_brywnq$(ring);\n }\n return result;\n };\n LinesHelper.prototype.setAlphaEnabled_6taknv$ = function (b) {\n this.myAlphaEnabled_98jfa$_0 = b;\n };\n LinesHelper.prototype.createLines_rrreuh$ = function (dataPoints, toLocation) {\n return this.createPaths_gfkrhx$_0(dataPoints, toLocation, false);\n };\n function LinesHelper$createPaths$lambda(closure$toLocation) {\n return function (it) {\n return closure$toLocation(it);\n };\n }\n LinesHelper.prototype.createPaths_gfkrhx$_0 = function (dataPoints, toLocation, closePath) {\n var tmp$;\n var paths = ArrayList_init();\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(LinesHelper$createPaths$lambda(toLocation))), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, closePath));\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n paths.addAll_brywnq$(this.createPaths_edlkk9$(multiPointData.aes, multiPointData.points, closePath));\n }\n return paths;\n };\n LinesHelper.prototype.createPaths_edlkk9$ = function (aes, points, closePath) {\n var paths = ArrayList_init();\n if (closePath) {\n paths.add_11rb$(LinePath$Companion_getInstance().polygon_yh26e7$(this.insertPathSeparators_fr5rf4$_0(splitRings(points))));\n } else {\n paths.add_11rb$(LinePath$Companion_getInstance().line_qdtdbw$(points));\n }\n var tmp$;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.decorate_frjrd5$(element, aes, closePath);\n }\n return paths;\n };\n LinesHelper.prototype.createSteps_1fp004$ = function (dataPoints, dir) {\n var tmp$, tmp$_0;\n var pathInfos = ArrayList_init();\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(GeomUtil_getInstance().TO_LOCATION_X_Y)), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, false));\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n var points = multiPointData.points;\n if (!points.isEmpty()) {\n var newPoints = ArrayList_init();\n var prev = null;\n tmp$_0 = points.iterator();\n while (tmp$_0.hasNext()) {\n var point = tmp$_0.next();\n if (prev != null) {\n var x = dir === StepGeom$Direction$HV_getInstance() ? point.x : prev.x;\n var y = dir === StepGeom$Direction$HV_getInstance() ? prev.y : point.y;\n newPoints.add_11rb$(new DoubleVector(x, y));\n }newPoints.add_11rb$(point);\n prev = point;\n }\n var path = LinePath$Companion_getInstance().line_qdtdbw$(newPoints);\n this.decorate_frjrd5$(path, multiPointData.aes, false);\n pathInfos.add_11rb$(new LinesHelper$PathInfo(path));\n }}\n return pathInfos;\n };\n function LinesHelper$createBands$lambda(closure$toLocationUpper) {\n return function (it) {\n return closure$toLocationUpper(it);\n };\n }\n function LinesHelper$createBands$lambda_0(closure$toLocationLower) {\n return function (it) {\n return closure$toLocationLower(it);\n };\n }\n LinesHelper.prototype.createBands_22uu1u$ = function (dataPoints, toLocationUpper, toLocationLower) {\n var tmp$;\n var lines = ArrayList_init();\n var pointsByGroup = GeomUtil_getInstance().createGroups_83glv4$(dataPoints);\n tmp$ = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(pointsByGroup.keys).iterator();\n while (tmp$.hasNext()) {\n var group = tmp$.next();\n var groupDataPoints = pointsByGroup.get_11rb$(group);\n var points = ArrayList_init_0(this.project_rrreuh$(ensureNotNull(groupDataPoints), LinesHelper$createBands$lambda(toLocationUpper)));\n var lowerPoints = reversed(groupDataPoints);\n points.addAll_brywnq$(this.project_rrreuh$(lowerPoints, LinesHelper$createBands$lambda_0(toLocationLower)));\n if (!points.isEmpty()) {\n var path = LinePath$Companion_getInstance().polygon_yh26e7$(points);\n this.decorateFillingPart_e7h5w8$_0(path, groupDataPoints.get_za3lpa$(0));\n lines.add_11rb$(path);\n }}\n return lines;\n };\n LinesHelper.prototype.decorate_frjrd5$ = function (path, p, filled) {\n var stroke = p.color();\n var strokeAlpha = ensureNotNull(this.myAlphaFilter_nxoahd$_0(AestheticsUtil_getInstance().alpha_il6rhx$(ensureNotNull(stroke), p)));\n path.color().set_11rb$(values.Colors.withOpacity_o14uds$(stroke, strokeAlpha));\n if (!AestheticsUtil_getInstance().ALPHA_CONTROLS_BOTH_8be2vx$ && (filled || !this.myAlphaEnabled_98jfa$_0)) {\n path.color().set_11rb$(stroke);\n }if (filled) {\n this.decorateFillingPart_e7h5w8$_0(path, p);\n }var size = ensureNotNull(this.myWidthFilter_sx37fb$_0(AesScaling_getInstance().strokeWidth_l6g9mh$(p)));\n path.width().set_11rb$(size);\n var lineType = p.lineType();\n if (!(lineType.isBlank || lineType.isSolid)) {\n path.dashArray().set_11rb$(lineType.dashArray);\n }};\n LinesHelper.prototype.decorateFillingPart_e7h5w8$_0 = function (path, p) {\n var fill = p.fill();\n var fillAlpha = ensureNotNull(this.myAlphaFilter_nxoahd$_0(AestheticsUtil_getInstance().alpha_il6rhx$(ensureNotNull(fill), p)));\n path.fill().set_11rb$(values.Colors.withOpacity_o14uds$(fill, fillAlpha));\n };\n LinesHelper.prototype.setAlphaFilter_m9g0ow$ = function (alphaFilter) {\n this.myAlphaFilter_nxoahd$_0 = alphaFilter;\n };\n LinesHelper.prototype.setWidthFilter_m9g0ow$ = function (widthFilter) {\n this.myWidthFilter_sx37fb$_0 = widthFilter;\n };\n function LinesHelper$PathInfo(path) {\n this.path = path;\n }\n LinesHelper$PathInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathInfo',\n interfaces: []\n };\n function LinesHelper$myAlphaFilter$lambda(v) {\n return v;\n }\n function LinesHelper$myWidthFilter$lambda(v) {\n return v;\n }\n LinesHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinesHelper',\n interfaces: [GeomHelper]\n };\n function MappedAesthetics(myAesthetics, myPointAestheticsMapper) {\n this.myAesthetics_0 = myAesthetics;\n this.myPointAestheticsMapper_0 = myPointAestheticsMapper;\n }\n Object.defineProperty(MappedAesthetics.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myAesthetics_0.isEmpty;\n }\n });\n MappedAesthetics.prototype.dataPointAt_za3lpa$ = function (index) {\n return this.myPointAestheticsMapper_0(this.myAesthetics_0.dataPointAt_za3lpa$(index));\n };\n MappedAesthetics.prototype.dataPointCount = function () {\n return this.myAesthetics_0.dataPointCount();\n };\n MappedAesthetics.prototype.dataPoints = function () {\n var source = this.myAesthetics_0.dataPoints();\n var destination = ArrayList_init_1(collectionSizeOrDefault(source, 10));\n var tmp$;\n tmp$ = source.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.myPointAestheticsMapper_0(item));\n }\n return destination;\n };\n MappedAesthetics.prototype.range_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.range: not implemented ' + aes);\n };\n MappedAesthetics.prototype.overallRange_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.overallRange: not implemented ' + aes);\n };\n MappedAesthetics.prototype.resolution_594811$ = function (aes, naValue) {\n throw IllegalStateException_init('MappedAesthetics.resolution: not implemented ' + aes);\n };\n MappedAesthetics.prototype.numericValues_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.numericValues: not implemented ' + aes);\n };\n MappedAesthetics.prototype.groups = function () {\n return this.myAesthetics_0.groups();\n };\n MappedAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappedAesthetics',\n interfaces: [Aesthetics]\n };\n function MultiPointData(aes, points, localToGlobalIndex, group) {\n this.aes = aes;\n this.points = points;\n this.localToGlobalIndex = localToGlobalIndex;\n this.group = group;\n }\n MultiPointData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPointData',\n interfaces: []\n };\n function MultiPointDataConstructor() {\n MultiPointDataConstructor_instance = this;\n }\n function MultiPointDataConstructor$collector$lambda() {\n return new MultiPointDataConstructor$SimplePointCollector();\n }\n MultiPointDataConstructor.prototype.collector = function () {\n return MultiPointDataConstructor$collector$lambda;\n };\n function MultiPointDataConstructor$reducer$lambda(closure$dropPointDistance, closure$isPolygon) {\n return function () {\n return new MultiPointDataConstructor$PointReducer(closure$dropPointDistance, closure$isPolygon);\n };\n }\n MultiPointDataConstructor.prototype.reducer_8555vt$ = function (dropPointDistance, isPolygon) {\n return MultiPointDataConstructor$reducer$lambda(dropPointDistance, isPolygon);\n };\n function MultiPointDataConstructor$singlePointAppender$lambda(closure$toPoint) {\n return function (aes, coordinateConsumer) {\n coordinateConsumer(closure$toPoint(aes));\n return Unit;\n };\n }\n MultiPointDataConstructor.prototype.singlePointAppender_v9bvvf$ = function (toPoint) {\n return MultiPointDataConstructor$singlePointAppender$lambda(toPoint);\n };\n function MultiPointDataConstructor$multiPointAppender$lambda(closure$toPath) {\n return function (aes, coordinateConsumer) {\n var tmp$;\n tmp$ = closure$toPath(aes).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n coordinateConsumer(element);\n }\n return Unit;\n };\n }\n MultiPointDataConstructor.prototype.multiPointAppender_t2aup3$ = function (toPath) {\n return MultiPointDataConstructor$multiPointAppender$lambda(toPath);\n };\n MultiPointDataConstructor.prototype.createMultiPointDataByGroup_ugj9hh$ = function (dataPoints, coordinateAppender, pointCollectorSupplier) {\n var tmp$, tmp$_0;\n var multiPointDataCombiners = HashMap_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var group = p.group();\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = multiPointDataCombiners, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(group)) {\n var key = ensureNotNull(group);\n var value = new MultiPointDataConstructor$MultiPointDataCombiner(coordinateAppender, pointCollectorSupplier());\n multiPointDataCombiners.put_xwzc9p$(key, value);\n }var tmp$_2;\n ensureNotNull((Kotlin.isType(tmp$_2 = multiPointDataCombiners, Map) ? tmp$_2 : throwCCE()).get_11rb$(group)).add_lsjzq4$(p);\n }\n var result = ArrayList_init();\n var sortedGroup = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(multiPointDataCombiners.keys);\n tmp$_0 = sortedGroup.iterator();\n while (tmp$_0.hasNext()) {\n var group_0 = tmp$_0.next();\n var multiPointData = ensureNotNull(multiPointDataCombiners.get_11rb$(group_0)).create_kcn2v3$(group_0);\n if (!multiPointData.points.isEmpty()) {\n result.add_11rb$(multiPointData);\n }}\n return result;\n };\n function MultiPointDataConstructor$PointCollector() {\n }\n MultiPointDataConstructor$PointCollector.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointCollector',\n interfaces: []\n };\n function MultiPointDataConstructor$MultiPointDataCombiner(myCoordinateAppender, myPointCollector) {\n this.myCoordinateAppender_0 = myCoordinateAppender;\n this.myPointCollector_0 = myPointCollector;\n this.myFirstAes_0 = null;\n }\n function MultiPointDataConstructor$MultiPointDataCombiner$add$lambda(this$MultiPointDataCombiner, closure$aes) {\n return function (it) {\n this$MultiPointDataCombiner.myPointCollector_0.add_aqrfag$(it, closure$aes.index());\n return Unit;\n };\n }\n MultiPointDataConstructor$MultiPointDataCombiner.prototype.add_lsjzq4$ = function (aes) {\n if (this.myFirstAes_0 == null) {\n this.myFirstAes_0 = aes;\n }this.myCoordinateAppender_0(aes, MultiPointDataConstructor$MultiPointDataCombiner$add$lambda(this, aes));\n };\n function MultiPointDataConstructor$MultiPointDataCombiner$create$lambda(closure$points) {\n return function (it) {\n return closure$points.second.get_za3lpa$(it);\n };\n }\n MultiPointDataConstructor$MultiPointDataCombiner.prototype.create_kcn2v3$ = function (group) {\n var points = this.myPointCollector_0.points;\n return new MultiPointData(ensureNotNull(this.myFirstAes_0), points.first, MultiPointDataConstructor$MultiPointDataCombiner$create$lambda(points), group);\n };\n MultiPointDataConstructor$MultiPointDataCombiner.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPointDataCombiner',\n interfaces: []\n };\n function MultiPointDataConstructor$SimplePointCollector() {\n this.myPoints_0 = ArrayList_init();\n this.myIndexes_0 = ArrayList_init();\n }\n Object.defineProperty(MultiPointDataConstructor$SimplePointCollector.prototype, 'points', {\n configurable: true,\n get: function () {\n return new Pair(this.myPoints_0, this.myIndexes_0);\n }\n });\n MultiPointDataConstructor$SimplePointCollector.prototype.add_aqrfag$ = function (coord, index) {\n this.myPoints_0.add_11rb$(ensureNotNull(coord));\n this.myIndexes_0.add_11rb$(index);\n };\n MultiPointDataConstructor$SimplePointCollector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimplePointCollector',\n interfaces: [MultiPointDataConstructor$PointCollector]\n };\n function MultiPointDataConstructor$PointReducer(myDropPointDistance, myPolygon) {\n this.myDropPointDistance_0 = myDropPointDistance;\n this.myPolygon_0 = myPolygon;\n this.myReducedPoints_0 = ArrayList_init();\n this.myReducedIndexes_0 = ArrayList_init();\n this.myLastAdded_0 = null;\n this.myLastPostponed_0 = null;\n this.myRegionStart_0 = null;\n }\n Object.defineProperty(MultiPointDataConstructor$PointReducer.prototype, 'points', {\n configurable: true,\n get: function () {\n if (this.myLastPostponed_0 != null) {\n this.addPoint_0(ensureNotNull(this.myLastPostponed_0).first, ensureNotNull(this.myLastPostponed_0).second);\n this.myLastPostponed_0 = null;\n }return new Pair(this.myReducedPoints_0, this.myReducedIndexes_0);\n }\n });\n MultiPointDataConstructor$PointReducer.prototype.isCloserThan_0 = function (p0, p1, distance) {\n var x = p0.x - p1.x;\n var tmp$ = JsMath.abs(x) < distance;\n if (tmp$) {\n var x_0 = p0.y - p1.y;\n tmp$ = JsMath.abs(x_0) < distance;\n }return tmp$;\n };\n MultiPointDataConstructor$PointReducer.prototype.add_aqrfag$ = function (coord, index) {\n if (coord == null) {\n return;\n }if (this.myLastAdded_0 == null) {\n this.storePoint_0(coord, index);\n return;\n }if (this.needPostpone_0(coord)) {\n this.postponePoint_0(coord, index);\n } else {\n if (this.myLastPostponed_0 != null) {\n this.addPoint_0(ensureNotNull(this.myLastPostponed_0).first, ensureNotNull(this.myLastPostponed_0).second);\n this.myLastPostponed_0 = null;\n }this.storePoint_0(coord, index);\n }\n };\n MultiPointDataConstructor$PointReducer.prototype.needPostpone_0 = function (loc) {\n var closeToAdded = this.areTooClose_0(this.myLastAdded_0, loc);\n var closeToPostponed = this.myLastPostponed_0 == null || this.areTooClose_0(ensureNotNull(this.myLastPostponed_0).first, loc);\n var regionClosePoint = this.isRegionStart_0(loc);\n return closeToAdded && closeToPostponed && !regionClosePoint;\n };\n MultiPointDataConstructor$PointReducer.prototype.postponePoint_0 = function (loc, index) {\n this.myLastPostponed_0 = new Pair(loc, index);\n };\n MultiPointDataConstructor$PointReducer.prototype.storePoint_0 = function (loc, index) {\n this.addPoint_0(loc, index);\n this.myLastAdded_0 = loc;\n this.processRegionStart_0(loc, index);\n };\n MultiPointDataConstructor$PointReducer.prototype.processRegionStart_0 = function (loc, index) {\n if (!this.myPolygon_0) {\n return;\n }if (this.myRegionStart_0 == null) {\n this.myRegionStart_0 = new Pair(loc, index);\n return;\n }if (this.isRegionStart_0(loc)) {\n this.myRegionStart_0 = null;\n this.myLastAdded_0 = null;\n }};\n MultiPointDataConstructor$PointReducer.prototype.isRegionStart_0 = function (loc) {\n var tmp$;\n if (!this.myPolygon_0) {\n return false;\n }if (this.myRegionStart_0 == null) {\n tmp$ = false;\n } else\n tmp$ = equals(ensureNotNull(this.myRegionStart_0).first, loc);\n return tmp$;\n };\n MultiPointDataConstructor$PointReducer.prototype.addPoint_0 = function (loc, index) {\n this.myReducedPoints_0.add_11rb$(loc);\n this.myReducedIndexes_0.add_11rb$(index);\n };\n MultiPointDataConstructor$PointReducer.prototype.areTooClose_0 = function (p1, p2) {\n return this.isCloserThan_0(ensureNotNull(p1), p2, this.myDropPointDistance_0);\n };\n MultiPointDataConstructor$PointReducer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointReducer',\n interfaces: [MultiPointDataConstructor$PointCollector]\n };\n MultiPointDataConstructor.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MultiPointDataConstructor',\n interfaces: []\n };\n var MultiPointDataConstructor_instance = null;\n function MultiPointDataConstructor_getInstance() {\n if (MultiPointDataConstructor_instance === null) {\n new MultiPointDataConstructor();\n }return MultiPointDataConstructor_instance;\n }\n function RectTargetCollectorHelper(rectanglesHelper, rectangleByDataPoint, fillByDataPoint, tooltipKind) {\n this.rectanglesHelper_0 = rectanglesHelper;\n this.rectangleByDataPoint_0 = rectangleByDataPoint;\n this.fillByDataPoint_0 = fillByDataPoint;\n this.tooltipKind_0 = tooltipKind;\n }\n function RectTargetCollectorHelper$collectTo$lambda(closure$targetCollector, this$RectTargetCollectorHelper) {\n return function (p, rectangle) {\n closure$targetCollector.addRectangle_bxzvr8$(p.index(), rectangle, this$RectTargetCollectorHelper.tooltipParams_0(p), this$RectTargetCollectorHelper.tooltipKind_0);\n return Unit;\n };\n }\n RectTargetCollectorHelper.prototype.collectTo_xrq6q$ = function (targetCollector) {\n this.rectanglesHelper_0.iterateRectangleGeometry_xwqduk$(this.rectangleByDataPoint_0, RectTargetCollectorHelper$collectTo$lambda(targetCollector, this));\n };\n RectTargetCollectorHelper.prototype.tooltipParams_0 = function (p) {\n var params = GeomTargetCollector$TooltipParams$Companion_getInstance().params();\n params.setColor_98b62m$(this.fillByDataPoint_0(p));\n return params;\n };\n RectTargetCollectorHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectTargetCollectorHelper',\n interfaces: []\n };\n function RectanglesHelper(myAesthetics, pos, coord, ctx) {\n GeomHelper.call(this, pos, coord, ctx);\n this.myAesthetics_0 = myAesthetics;\n }\n RectanglesHelper.prototype.createRectangles_rezc4r$ = function (rectangleByDataPoint) {\n var tmp$, tmp$_0;\n var result = ArrayList_init();\n tmp$ = this.myAesthetics_0.dataPointCount();\n for (var index = 0; index < tmp$; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n tmp$_0 = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (tmp$_0 == null) {\n continue;\n }var clientRect = tmp$_0;\n var svgRect = SvgRectElement_init_0(clientRect);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(svgRect, p);\n result.add_11rb$(svgRect);\n }\n return result;\n };\n RectanglesHelper.prototype.iterateRectangleGeometry_xwqduk$ = function (rectangleByDataPoint, iterator) {\n var tmp$;\n tmp$ = this.myAesthetics_0.dataPointCount();\n for (var index = 0; index < tmp$; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n var rect = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (rect != null) {\n iterator(p, rect);\n }}\n };\n RectanglesHelper.prototype.createSlimRectangles_rezc4r$ = function (rectangleByDataPoint) {\n var tmp$;\n var pointCount = this.myAesthetics_0.dataPointCount();\n var group = slim.SvgSlimElements.g_za3lpa$(pointCount);\n for (var index = 0; index < pointCount; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n tmp$ = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (tmp$ == null) {\n continue;\n }var clientRect = tmp$;\n var slimShape = slim.SvgSlimElements.rect_6y0v78$(clientRect.left, clientRect.top, clientRect.width, clientRect.height);\n GeomHelper$Companion_getInstance().decorateSlimShape_gb6c9f$(slimShape, p);\n slimShape.appendTo_i2myw1$(group);\n }\n return group;\n };\n RectanglesHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectanglesHelper',\n interfaces: [GeomHelper]\n };\n function ContextualMapping(tooltipLines, tooltipAnchor, tooltipMinWidth, tooltipColor, ignoreInvisibleTargets, hasGeneralTooltip, hasAxisTooltip, isCrosshairEnabled) {\n this.tooltipLines_85czob$_0 = tooltipLines;\n this.tooltipAnchor = tooltipAnchor;\n this.tooltipMinWidth = tooltipMinWidth;\n this.tooltipColor = tooltipColor;\n this.ignoreInvisibleTargets = ignoreInvisibleTargets;\n this.hasGeneralTooltip = hasGeneralTooltip;\n this.hasAxisTooltip = hasAxisTooltip;\n this.isCrosshairEnabled = isCrosshairEnabled;\n }\n ContextualMapping.prototype.getDataPoints_za3lpa$ = function (index) {\n var $receiver = this.tooltipLines_85czob$_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element.getDataPoint_za3lpa$(index)) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return destination;\n };\n ContextualMapping.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContextualMapping',\n interfaces: []\n };\n function DataContext(dataFrame, mappedDataAccess) {\n this.dataFrame = dataFrame;\n this.mappedDataAccess = mappedDataAccess;\n }\n DataContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataContext',\n interfaces: []\n };\n DataContext.prototype.component1 = function () {\n return this.dataFrame;\n };\n DataContext.prototype.component2 = function () {\n return this.mappedDataAccess;\n };\n DataContext.prototype.copy_nqispu$ = function (dataFrame, mappedDataAccess) {\n return new DataContext(dataFrame === void 0 ? this.dataFrame : dataFrame, mappedDataAccess === void 0 ? this.mappedDataAccess : mappedDataAccess);\n };\n DataContext.prototype.toString = function () {\n return 'DataContext(dataFrame=' + Kotlin.toString(this.dataFrame) + (', mappedDataAccess=' + Kotlin.toString(this.mappedDataAccess)) + ')';\n };\n DataContext.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.dataFrame) | 0;\n result = result * 31 + Kotlin.hashCode(this.mappedDataAccess) | 0;\n return result;\n };\n DataContext.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.dataFrame, other.dataFrame) && Kotlin.equals(this.mappedDataAccess, other.mappedDataAccess)))));\n };\n function GeomTarget(hitIndex, tipLayoutHint, aesTipLayoutHints) {\n this.hitIndex = hitIndex;\n this.tipLayoutHint_hymvab$_0 = tipLayoutHint;\n this.aesTipLayoutHints_wcnfmb$_0 = aesTipLayoutHints;\n }\n Object.defineProperty(GeomTarget.prototype, 'tipLayoutHint', {\n get: function () {\n return this.tipLayoutHint_hymvab$_0;\n }\n });\n Object.defineProperty(GeomTarget.prototype, 'aesTipLayoutHints', {\n get: function () {\n return this.aesTipLayoutHints_wcnfmb$_0;\n }\n });\n GeomTarget.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomTarget',\n interfaces: []\n };\n function GeomTargetCollector() {\n }\n GeomTargetCollector.prototype.addPoint_cnsimy$ = function (index, point, radius, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance();\n callback$default ? callback$default(index, point, radius, tooltipParams, tooltipKind) : this.addPoint_cnsimy$$default(index, point, radius, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addRectangle_bxzvr8$ = function (index, rectangle, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n callback$default ? callback$default(index, rectangle, tooltipParams, tooltipKind) : this.addRectangle_bxzvr8$$default(index, rectangle, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addPath_sa5m83$ = function (points, localToGlobalIndex, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n callback$default ? callback$default(points, localToGlobalIndex, tooltipParams, tooltipKind) : this.addPath_sa5m83$$default(points, localToGlobalIndex, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addPolygon_sa5m83$ = function (points, localToGlobalIndex, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance();\n callback$default ? callback$default(points, localToGlobalIndex, tooltipParams, tooltipKind) : this.addPolygon_sa5m83$$default(points, localToGlobalIndex, tooltipParams, tooltipKind);\n };\n function GeomTargetCollector$TooltipParams() {\n GeomTargetCollector$TooltipParams$Companion_getInstance();\n this.myTipLayoutHints_0 = emptyMap();\n this.myColor_0 = Color.Companion.GRAY;\n this.myStemLength_0 = TipLayoutHint$StemLength$NORMAL_getInstance();\n }\n GeomTargetCollector$TooltipParams.prototype.getTipLayoutHints = function () {\n return this.myTipLayoutHints_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setTipLayoutHints_vgcgsc$ = function (tipLayoutHints) {\n this.myTipLayoutHints_0 = tipLayoutHints;\n return this;\n };\n GeomTargetCollector$TooltipParams.prototype.getColor = function () {\n return this.myColor_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setColor_98b62m$ = function (color) {\n this.myColor_0 = color;\n return this;\n };\n GeomTargetCollector$TooltipParams.prototype.getStemLength = function () {\n return this.myStemLength_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setStemLength_6gy7x$ = function (stemLength) {\n this.myStemLength_0 = stemLength;\n return this;\n };\n function GeomTargetCollector$TooltipParams$Companion() {\n GeomTargetCollector$TooltipParams$Companion_instance = this;\n }\n GeomTargetCollector$TooltipParams$Companion.prototype.params = function () {\n return new GeomTargetCollector$TooltipParams();\n };\n GeomTargetCollector$TooltipParams$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomTargetCollector$TooltipParams$Companion_instance = null;\n function GeomTargetCollector$TooltipParams$Companion_getInstance() {\n if (GeomTargetCollector$TooltipParams$Companion_instance === null) {\n new GeomTargetCollector$TooltipParams$Companion();\n }return GeomTargetCollector$TooltipParams$Companion_instance;\n }\n GeomTargetCollector$TooltipParams.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipParams',\n interfaces: []\n };\n GeomTargetCollector.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomTargetCollector',\n interfaces: []\n };\n function GeomTargetLocator() {\n }\n function GeomTargetLocator$LookupSpace(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomTargetLocator$LookupSpace_initFields() {\n GeomTargetLocator$LookupSpace_initFields = function () {\n };\n GeomTargetLocator$LookupSpace$X_instance = new GeomTargetLocator$LookupSpace('X', 0);\n GeomTargetLocator$LookupSpace$XY_instance = new GeomTargetLocator$LookupSpace('XY', 1);\n GeomTargetLocator$LookupSpace$NONE_instance = new GeomTargetLocator$LookupSpace('NONE', 2);\n }\n var GeomTargetLocator$LookupSpace$X_instance;\n function GeomTargetLocator$LookupSpace$X_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$X_instance;\n }\n var GeomTargetLocator$LookupSpace$XY_instance;\n function GeomTargetLocator$LookupSpace$XY_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$XY_instance;\n }\n var GeomTargetLocator$LookupSpace$NONE_instance;\n function GeomTargetLocator$LookupSpace$NONE_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$NONE_instance;\n }\n GeomTargetLocator$LookupSpace.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupSpace',\n interfaces: [Enum]\n };\n function GeomTargetLocator$LookupSpace$values() {\n return [GeomTargetLocator$LookupSpace$X_getInstance(), GeomTargetLocator$LookupSpace$XY_getInstance(), GeomTargetLocator$LookupSpace$NONE_getInstance()];\n }\n GeomTargetLocator$LookupSpace.values = GeomTargetLocator$LookupSpace$values;\n function GeomTargetLocator$LookupSpace$valueOf(name) {\n switch (name) {\n case 'X':\n return GeomTargetLocator$LookupSpace$X_getInstance();\n case 'XY':\n return GeomTargetLocator$LookupSpace$XY_getInstance();\n case 'NONE':\n return GeomTargetLocator$LookupSpace$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace.' + name);\n }\n }\n GeomTargetLocator$LookupSpace.valueOf_61zpoe$ = GeomTargetLocator$LookupSpace$valueOf;\n function GeomTargetLocator$LookupStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomTargetLocator$LookupStrategy_initFields() {\n GeomTargetLocator$LookupStrategy_initFields = function () {\n };\n GeomTargetLocator$LookupStrategy$HOVER_instance = new GeomTargetLocator$LookupStrategy('HOVER', 0);\n GeomTargetLocator$LookupStrategy$NEAREST_instance = new GeomTargetLocator$LookupStrategy('NEAREST', 1);\n GeomTargetLocator$LookupStrategy$NONE_instance = new GeomTargetLocator$LookupStrategy('NONE', 2);\n }\n var GeomTargetLocator$LookupStrategy$HOVER_instance;\n function GeomTargetLocator$LookupStrategy$HOVER_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$HOVER_instance;\n }\n var GeomTargetLocator$LookupStrategy$NEAREST_instance;\n function GeomTargetLocator$LookupStrategy$NEAREST_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$NEAREST_instance;\n }\n var GeomTargetLocator$LookupStrategy$NONE_instance;\n function GeomTargetLocator$LookupStrategy$NONE_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$NONE_instance;\n }\n GeomTargetLocator$LookupStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupStrategy',\n interfaces: [Enum]\n };\n function GeomTargetLocator$LookupStrategy$values() {\n return [GeomTargetLocator$LookupStrategy$HOVER_getInstance(), GeomTargetLocator$LookupStrategy$NEAREST_getInstance(), GeomTargetLocator$LookupStrategy$NONE_getInstance()];\n }\n GeomTargetLocator$LookupStrategy.values = GeomTargetLocator$LookupStrategy$values;\n function GeomTargetLocator$LookupStrategy$valueOf(name) {\n switch (name) {\n case 'HOVER':\n return GeomTargetLocator$LookupStrategy$HOVER_getInstance();\n case 'NEAREST':\n return GeomTargetLocator$LookupStrategy$NEAREST_getInstance();\n case 'NONE':\n return GeomTargetLocator$LookupStrategy$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy.' + name);\n }\n }\n GeomTargetLocator$LookupStrategy.valueOf_61zpoe$ = GeomTargetLocator$LookupStrategy$valueOf;\n function GeomTargetLocator$LookupSpec(lookupSpace, lookupStrategy) {\n GeomTargetLocator$LookupSpec$Companion_getInstance();\n this.lookupSpace = lookupSpace;\n this.lookupStrategy = lookupStrategy;\n }\n function GeomTargetLocator$LookupSpec$Companion() {\n GeomTargetLocator$LookupSpec$Companion_instance = this;\n this.NONE = new GeomTargetLocator$LookupSpec(GeomTargetLocator$LookupSpace$NONE_getInstance(), GeomTargetLocator$LookupStrategy$NONE_getInstance());\n }\n GeomTargetLocator$LookupSpec$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomTargetLocator$LookupSpec$Companion_instance = null;\n function GeomTargetLocator$LookupSpec$Companion_getInstance() {\n if (GeomTargetLocator$LookupSpec$Companion_instance === null) {\n new GeomTargetLocator$LookupSpec$Companion();\n }return GeomTargetLocator$LookupSpec$Companion_instance;\n }\n GeomTargetLocator$LookupSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupSpec',\n interfaces: []\n };\n function GeomTargetLocator$LookupResult(targets, distance, geomKind, contextualMapping, isCrosshairEnabled) {\n this.targets = targets;\n this.distance_isy6z$_0 = distance;\n this.geomKind_g9qdl6$_0 = geomKind;\n this.contextualMapping_r13yoz$_0 = contextualMapping;\n this.isCrosshairEnabled = isCrosshairEnabled;\n }\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'distance', {\n get: function () {\n return this.distance_isy6z$_0;\n }\n });\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'geomKind', {\n get: function () {\n return this.geomKind_g9qdl6$_0;\n }\n });\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'contextualMapping', {\n get: function () {\n return this.contextualMapping_r13yoz$_0;\n }\n });\n GeomTargetLocator$LookupResult.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupResult',\n interfaces: []\n };\n GeomTargetLocator.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomTargetLocator',\n interfaces: []\n };\n function HitShape(kind, shape) {\n HitShape$Companion_getInstance();\n this.kind = kind;\n this.shape_kp8049$_0 = shape;\n }\n Object.defineProperty(HitShape.prototype, 'point', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.shape_kp8049$_0, HitShape$DoubleCircle) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(HitShape.prototype, 'rect', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.shape_kp8049$_0, DoubleRectangle) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(HitShape.prototype, 'points', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Not applicable to ' + this.kind);\n }\n });\n function HitShape$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function HitShape$Kind_initFields() {\n HitShape$Kind_initFields = function () {\n };\n HitShape$Kind$POINT_instance = new HitShape$Kind('POINT', 0);\n HitShape$Kind$RECT_instance = new HitShape$Kind('RECT', 1);\n HitShape$Kind$POLYGON_instance = new HitShape$Kind('POLYGON', 2);\n HitShape$Kind$PATH_instance = new HitShape$Kind('PATH', 3);\n }\n var HitShape$Kind$POINT_instance;\n function HitShape$Kind$POINT_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$POINT_instance;\n }\n var HitShape$Kind$RECT_instance;\n function HitShape$Kind$RECT_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$RECT_instance;\n }\n var HitShape$Kind$POLYGON_instance;\n function HitShape$Kind$POLYGON_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$POLYGON_instance;\n }\n var HitShape$Kind$PATH_instance;\n function HitShape$Kind$PATH_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$PATH_instance;\n }\n HitShape$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function HitShape$Kind$values() {\n return [HitShape$Kind$POINT_getInstance(), HitShape$Kind$RECT_getInstance(), HitShape$Kind$POLYGON_getInstance(), HitShape$Kind$PATH_getInstance()];\n }\n HitShape$Kind.values = HitShape$Kind$values;\n function HitShape$Kind$valueOf(name) {\n switch (name) {\n case 'POINT':\n return HitShape$Kind$POINT_getInstance();\n case 'RECT':\n return HitShape$Kind$RECT_getInstance();\n case 'POLYGON':\n return HitShape$Kind$POLYGON_getInstance();\n case 'PATH':\n return HitShape$Kind$PATH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.HitShape.Kind.' + name);\n }\n }\n HitShape$Kind.valueOf_61zpoe$ = HitShape$Kind$valueOf;\n function HitShape$DoubleCircle(center, radius) {\n this.center = center;\n this.radius = radius;\n }\n HitShape$DoubleCircle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleCircle',\n interfaces: []\n };\n function HitShape$Companion() {\n HitShape$Companion_instance = this;\n }\n HitShape$Companion.prototype.point_e1sv3v$ = function (p, radius) {\n return new HitShape(HitShape$Kind$POINT_getInstance(), new HitShape$DoubleCircle(p, radius));\n };\n HitShape$Companion.prototype.rect_wthzt5$ = function (r) {\n return new HitShape(HitShape$Kind$RECT_getInstance(), r);\n };\n HitShape$Companion.prototype.path_ytws2g$ = function (points) {\n return this.shapeWithPath_0(HitShape$Kind$PATH_getInstance(), points);\n };\n HitShape$Companion.prototype.polygon_ytws2g$ = function (points) {\n return this.shapeWithPath_0(HitShape$Kind$POLYGON_getInstance(), points);\n };\n function HitShape$Companion$shapeWithPath$ObjectLiteral(closure$points, kind, shape) {\n this.closure$points = closure$points;\n HitShape.call(this, kind, shape);\n }\n Object.defineProperty(HitShape$Companion$shapeWithPath$ObjectLiteral.prototype, 'points', {\n configurable: true,\n get: function () {\n return this.closure$points;\n }\n });\n HitShape$Companion$shapeWithPath$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [HitShape]\n };\n HitShape$Companion.prototype.shapeWithPath_0 = function (kind, points) {\n return new HitShape$Companion$shapeWithPath$ObjectLiteral(points, kind, points);\n };\n HitShape$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HitShape$Companion_instance = null;\n function HitShape$Companion_getInstance() {\n if (HitShape$Companion_instance === null) {\n new HitShape$Companion();\n }return HitShape$Companion_instance;\n }\n HitShape.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HitShape',\n interfaces: []\n };\n function MappedDataAccess() {\n }\n function MappedDataAccess$MappedData(label, value, isContinuous) {\n this.label = label;\n this.value = value;\n this.isContinuous = isContinuous;\n }\n MappedDataAccess$MappedData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappedData',\n interfaces: []\n };\n MappedDataAccess.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MappedDataAccess',\n interfaces: []\n };\n function NullGeomTargetCollector() {\n }\n NullGeomTargetCollector.prototype.addPoint_cnsimy$$default = function (index, point, radius, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addRectangle_bxzvr8$$default = function (index, rectangle, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addPath_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addPolygon_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NullGeomTargetCollector',\n interfaces: [GeomTargetCollector]\n };\n function TipLayoutHint(kind, coord, objectRadius, color, stemLength) {\n TipLayoutHint$Companion_getInstance();\n this.kind_mdwpny$_0 = kind;\n this.coord_cmx6yh$_0 = coord;\n this.objectRadius_tv0yd$_0 = objectRadius;\n this.color_cmv83v$_0 = color;\n this.stemLength_x5log9$_0 = stemLength;\n }\n Object.defineProperty(TipLayoutHint.prototype, 'kind', {\n get: function () {\n return this.kind_mdwpny$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'coord', {\n get: function () {\n return this.coord_cmx6yh$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'objectRadius', {\n get: function () {\n return this.objectRadius_tv0yd$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'color', {\n get: function () {\n return this.color_cmv83v$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'stemLength', {\n get: function () {\n return this.stemLength_x5log9$_0;\n }\n });\n function TipLayoutHint$StemLength(name, ordinal, value) {\n Enum.call(this);\n this.value = value;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TipLayoutHint$StemLength_initFields() {\n TipLayoutHint$StemLength_initFields = function () {\n };\n TipLayoutHint$StemLength$NORMAL_instance = new TipLayoutHint$StemLength('NORMAL', 0, 12.0);\n TipLayoutHint$StemLength$SHORT_instance = new TipLayoutHint$StemLength('SHORT', 1, 5.0);\n TipLayoutHint$StemLength$NONE_instance = new TipLayoutHint$StemLength('NONE', 2, 0.0);\n }\n var TipLayoutHint$StemLength$NORMAL_instance;\n function TipLayoutHint$StemLength$NORMAL_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$NORMAL_instance;\n }\n var TipLayoutHint$StemLength$SHORT_instance;\n function TipLayoutHint$StemLength$SHORT_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$SHORT_instance;\n }\n var TipLayoutHint$StemLength$NONE_instance;\n function TipLayoutHint$StemLength$NONE_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$NONE_instance;\n }\n TipLayoutHint$StemLength.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StemLength',\n interfaces: [Enum]\n };\n function TipLayoutHint$StemLength$values() {\n return [TipLayoutHint$StemLength$NORMAL_getInstance(), TipLayoutHint$StemLength$SHORT_getInstance(), TipLayoutHint$StemLength$NONE_getInstance()];\n }\n TipLayoutHint$StemLength.values = TipLayoutHint$StemLength$values;\n function TipLayoutHint$StemLength$valueOf(name) {\n switch (name) {\n case 'NORMAL':\n return TipLayoutHint$StemLength$NORMAL_getInstance();\n case 'SHORT':\n return TipLayoutHint$StemLength$SHORT_getInstance();\n case 'NONE':\n return TipLayoutHint$StemLength$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TipLayoutHint.StemLength.' + name);\n }\n }\n TipLayoutHint$StemLength.valueOf_61zpoe$ = TipLayoutHint$StemLength$valueOf;\n TipLayoutHint.prototype.toString = function () {\n return this.kind.toString();\n };\n function TipLayoutHint$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TipLayoutHint$Kind_initFields() {\n TipLayoutHint$Kind_initFields = function () {\n };\n TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance = new TipLayoutHint$Kind('VERTICAL_TOOLTIP', 0);\n TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance = new TipLayoutHint$Kind('HORIZONTAL_TOOLTIP', 1);\n TipLayoutHint$Kind$CURSOR_TOOLTIP_instance = new TipLayoutHint$Kind('CURSOR_TOOLTIP', 2);\n TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance = new TipLayoutHint$Kind('X_AXIS_TOOLTIP', 3);\n TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance = new TipLayoutHint$Kind('Y_AXIS_TOOLTIP', 4);\n }\n var TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance;\n function TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance;\n function TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$CURSOR_TOOLTIP_instance;\n function TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$CURSOR_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance;\n function TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance;\n function TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance;\n }\n TipLayoutHint$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function TipLayoutHint$Kind$values() {\n return [TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance(), TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance(), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance(), TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance(), TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance()];\n }\n TipLayoutHint$Kind.values = TipLayoutHint$Kind$values;\n function TipLayoutHint$Kind$valueOf(name) {\n switch (name) {\n case 'VERTICAL_TOOLTIP':\n return TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance();\n case 'HORIZONTAL_TOOLTIP':\n return TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n case 'CURSOR_TOOLTIP':\n return TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance();\n case 'X_AXIS_TOOLTIP':\n return TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance();\n case 'Y_AXIS_TOOLTIP':\n return TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.' + name);\n }\n }\n TipLayoutHint$Kind.valueOf_61zpoe$ = TipLayoutHint$Kind$valueOf;\n function TipLayoutHint$Companion() {\n TipLayoutHint$Companion_instance = this;\n }\n TipLayoutHint$Companion.prototype.verticalTooltip_6lq1u6$ = function (coord, objectRadius, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance(), coord, objectRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.horizontalTooltip_6lq1u6$ = function (coord, objectRadius, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance(), coord, objectRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.cursorTooltip_itpcqk$ = function (coord, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance(), coord, 0.0, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.xAxisTooltip_cgf2ia$ = function (coord, color, axisRadius, stemLength) {\n if (axisRadius === void 0)\n axisRadius = 0.0;\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NONE_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance(), coord, axisRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.yAxisTooltip_cgf2ia$ = function (coord, color, axisRadius, stemLength) {\n if (axisRadius === void 0)\n axisRadius = 0.0;\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NONE_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance(), coord, axisRadius, color, stemLength);\n };\n TipLayoutHint$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TipLayoutHint$Companion_instance = null;\n function TipLayoutHint$Companion_getInstance() {\n if (TipLayoutHint$Companion_instance === null) {\n new TipLayoutHint$Companion();\n }return TipLayoutHint$Companion_instance;\n }\n TipLayoutHint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TipLayoutHint',\n interfaces: []\n };\n function TooltipAnchor(verticalAnchor, horizontalAnchor) {\n this.verticalAnchor = verticalAnchor;\n this.horizontalAnchor = horizontalAnchor;\n }\n function TooltipAnchor$VerticalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TooltipAnchor$VerticalAnchor_initFields() {\n TooltipAnchor$VerticalAnchor_initFields = function () {\n };\n TooltipAnchor$VerticalAnchor$TOP_instance = new TooltipAnchor$VerticalAnchor('TOP', 0);\n TooltipAnchor$VerticalAnchor$BOTTOM_instance = new TooltipAnchor$VerticalAnchor('BOTTOM', 1);\n TooltipAnchor$VerticalAnchor$MIDDLE_instance = new TooltipAnchor$VerticalAnchor('MIDDLE', 2);\n }\n var TooltipAnchor$VerticalAnchor$TOP_instance;\n function TooltipAnchor$VerticalAnchor$TOP_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$TOP_instance;\n }\n var TooltipAnchor$VerticalAnchor$BOTTOM_instance;\n function TooltipAnchor$VerticalAnchor$BOTTOM_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$BOTTOM_instance;\n }\n var TooltipAnchor$VerticalAnchor$MIDDLE_instance;\n function TooltipAnchor$VerticalAnchor$MIDDLE_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$MIDDLE_instance;\n }\n TooltipAnchor$VerticalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAnchor',\n interfaces: [Enum]\n };\n function TooltipAnchor$VerticalAnchor$values() {\n return [TooltipAnchor$VerticalAnchor$TOP_getInstance(), TooltipAnchor$VerticalAnchor$BOTTOM_getInstance(), TooltipAnchor$VerticalAnchor$MIDDLE_getInstance()];\n }\n TooltipAnchor$VerticalAnchor.values = TooltipAnchor$VerticalAnchor$values;\n function TooltipAnchor$VerticalAnchor$valueOf(name) {\n switch (name) {\n case 'TOP':\n return TooltipAnchor$VerticalAnchor$TOP_getInstance();\n case 'BOTTOM':\n return TooltipAnchor$VerticalAnchor$BOTTOM_getInstance();\n case 'MIDDLE':\n return TooltipAnchor$VerticalAnchor$MIDDLE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TooltipAnchor.VerticalAnchor.' + name);\n }\n }\n TooltipAnchor$VerticalAnchor.valueOf_61zpoe$ = TooltipAnchor$VerticalAnchor$valueOf;\n function TooltipAnchor$HorizontalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TooltipAnchor$HorizontalAnchor_initFields() {\n TooltipAnchor$HorizontalAnchor_initFields = function () {\n };\n TooltipAnchor$HorizontalAnchor$LEFT_instance = new TooltipAnchor$HorizontalAnchor('LEFT', 0);\n TooltipAnchor$HorizontalAnchor$RIGHT_instance = new TooltipAnchor$HorizontalAnchor('RIGHT', 1);\n TooltipAnchor$HorizontalAnchor$CENTER_instance = new TooltipAnchor$HorizontalAnchor('CENTER', 2);\n }\n var TooltipAnchor$HorizontalAnchor$LEFT_instance;\n function TooltipAnchor$HorizontalAnchor$LEFT_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$LEFT_instance;\n }\n var TooltipAnchor$HorizontalAnchor$RIGHT_instance;\n function TooltipAnchor$HorizontalAnchor$RIGHT_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$RIGHT_instance;\n }\n var TooltipAnchor$HorizontalAnchor$CENTER_instance;\n function TooltipAnchor$HorizontalAnchor$CENTER_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$CENTER_instance;\n }\n TooltipAnchor$HorizontalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAnchor',\n interfaces: [Enum]\n };\n function TooltipAnchor$HorizontalAnchor$values() {\n return [TooltipAnchor$HorizontalAnchor$LEFT_getInstance(), TooltipAnchor$HorizontalAnchor$RIGHT_getInstance(), TooltipAnchor$HorizontalAnchor$CENTER_getInstance()];\n }\n TooltipAnchor$HorizontalAnchor.values = TooltipAnchor$HorizontalAnchor$values;\n function TooltipAnchor$HorizontalAnchor$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return TooltipAnchor$HorizontalAnchor$LEFT_getInstance();\n case 'RIGHT':\n return TooltipAnchor$HorizontalAnchor$RIGHT_getInstance();\n case 'CENTER':\n return TooltipAnchor$HorizontalAnchor$CENTER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TooltipAnchor.HorizontalAnchor.' + name);\n }\n }\n TooltipAnchor$HorizontalAnchor.valueOf_61zpoe$ = TooltipAnchor$HorizontalAnchor$valueOf;\n TooltipAnchor.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, TooltipAnchor) ? tmp$_0 : throwCCE();\n if (this.verticalAnchor !== other.verticalAnchor)\n return false;\n if (this.horizontalAnchor !== other.horizontalAnchor)\n return false;\n return true;\n };\n TooltipAnchor.prototype.hashCode = function () {\n var result = this.verticalAnchor.hashCode();\n result = (31 * result | 0) + this.horizontalAnchor.hashCode() | 0;\n return result;\n };\n TooltipAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipAnchor',\n interfaces: []\n };\n function TooltipLineSpec() {\n }\n function TooltipLineSpec$DataPoint(label, value, aes, isAxis, isOutlier) {\n this.label = label;\n this.value = value;\n this.aes = aes;\n this.isAxis = isAxis;\n this.isOutlier = isOutlier;\n }\n TooltipLineSpec$DataPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataPoint',\n interfaces: []\n };\n TooltipLineSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TooltipLineSpec',\n interfaces: []\n };\n function LivemapConstants() {\n }\n function LivemapConstants$DisplayMode(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$DisplayMode_initFields() {\n LivemapConstants$DisplayMode_initFields = function () {\n };\n LivemapConstants$DisplayMode$POINT_instance = new LivemapConstants$DisplayMode('POINT', 0);\n LivemapConstants$DisplayMode$PIE_instance = new LivemapConstants$DisplayMode('PIE', 1);\n LivemapConstants$DisplayMode$BAR_instance = new LivemapConstants$DisplayMode('BAR', 2);\n }\n var LivemapConstants$DisplayMode$POINT_instance;\n function LivemapConstants$DisplayMode$POINT_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$POINT_instance;\n }\n var LivemapConstants$DisplayMode$PIE_instance;\n function LivemapConstants$DisplayMode$PIE_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$PIE_instance;\n }\n var LivemapConstants$DisplayMode$BAR_instance;\n function LivemapConstants$DisplayMode$BAR_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$BAR_instance;\n }\n LivemapConstants$DisplayMode.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DisplayMode',\n interfaces: [Enum]\n };\n function LivemapConstants$DisplayMode$values() {\n return [LivemapConstants$DisplayMode$POINT_getInstance(), LivemapConstants$DisplayMode$PIE_getInstance(), LivemapConstants$DisplayMode$BAR_getInstance()];\n }\n LivemapConstants$DisplayMode.values = LivemapConstants$DisplayMode$values;\n function LivemapConstants$DisplayMode$valueOf(name) {\n switch (name) {\n case 'POINT':\n return LivemapConstants$DisplayMode$POINT_getInstance();\n case 'PIE':\n return LivemapConstants$DisplayMode$PIE_getInstance();\n case 'BAR':\n return LivemapConstants$DisplayMode$BAR_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode.' + name);\n }\n }\n LivemapConstants$DisplayMode.valueOf_61zpoe$ = LivemapConstants$DisplayMode$valueOf;\n function LivemapConstants$Theme(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$Theme_initFields() {\n LivemapConstants$Theme_initFields = function () {\n };\n LivemapConstants$Theme$COLOR_instance = new LivemapConstants$Theme('COLOR', 0);\n LivemapConstants$Theme$LIGHT_instance = new LivemapConstants$Theme('LIGHT', 1);\n LivemapConstants$Theme$DARK_instance = new LivemapConstants$Theme('DARK', 2);\n }\n var LivemapConstants$Theme$COLOR_instance;\n function LivemapConstants$Theme$COLOR_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$COLOR_instance;\n }\n var LivemapConstants$Theme$LIGHT_instance;\n function LivemapConstants$Theme$LIGHT_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$LIGHT_instance;\n }\n var LivemapConstants$Theme$DARK_instance;\n function LivemapConstants$Theme$DARK_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$DARK_instance;\n }\n LivemapConstants$Theme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Theme',\n interfaces: [Enum]\n };\n function LivemapConstants$Theme$values() {\n return [LivemapConstants$Theme$COLOR_getInstance(), LivemapConstants$Theme$LIGHT_getInstance(), LivemapConstants$Theme$DARK_getInstance()];\n }\n LivemapConstants$Theme.values = LivemapConstants$Theme$values;\n function LivemapConstants$Theme$valueOf(name) {\n switch (name) {\n case 'COLOR':\n return LivemapConstants$Theme$COLOR_getInstance();\n case 'LIGHT':\n return LivemapConstants$Theme$LIGHT_getInstance();\n case 'DARK':\n return LivemapConstants$Theme$DARK_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.Theme.' + name);\n }\n }\n LivemapConstants$Theme.valueOf_61zpoe$ = LivemapConstants$Theme$valueOf;\n function LivemapConstants$Projection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$Projection_initFields() {\n LivemapConstants$Projection_initFields = function () {\n };\n LivemapConstants$Projection$EPSG3857_instance = new LivemapConstants$Projection('EPSG3857', 0);\n LivemapConstants$Projection$EPSG4326_instance = new LivemapConstants$Projection('EPSG4326', 1);\n LivemapConstants$Projection$AZIMUTHAL_instance = new LivemapConstants$Projection('AZIMUTHAL', 2);\n LivemapConstants$Projection$CONIC_instance = new LivemapConstants$Projection('CONIC', 3);\n }\n var LivemapConstants$Projection$EPSG3857_instance;\n function LivemapConstants$Projection$EPSG3857_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$EPSG3857_instance;\n }\n var LivemapConstants$Projection$EPSG4326_instance;\n function LivemapConstants$Projection$EPSG4326_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$EPSG4326_instance;\n }\n var LivemapConstants$Projection$AZIMUTHAL_instance;\n function LivemapConstants$Projection$AZIMUTHAL_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$AZIMUTHAL_instance;\n }\n var LivemapConstants$Projection$CONIC_instance;\n function LivemapConstants$Projection$CONIC_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$CONIC_instance;\n }\n LivemapConstants$Projection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Projection',\n interfaces: [Enum]\n };\n function LivemapConstants$Projection$values() {\n return [LivemapConstants$Projection$EPSG3857_getInstance(), LivemapConstants$Projection$EPSG4326_getInstance(), LivemapConstants$Projection$AZIMUTHAL_getInstance(), LivemapConstants$Projection$CONIC_getInstance()];\n }\n LivemapConstants$Projection.values = LivemapConstants$Projection$values;\n function LivemapConstants$Projection$valueOf(name) {\n switch (name) {\n case 'EPSG3857':\n return LivemapConstants$Projection$EPSG3857_getInstance();\n case 'EPSG4326':\n return LivemapConstants$Projection$EPSG4326_getInstance();\n case 'AZIMUTHAL':\n return LivemapConstants$Projection$AZIMUTHAL_getInstance();\n case 'CONIC':\n return LivemapConstants$Projection$CONIC_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection.' + name);\n }\n }\n LivemapConstants$Projection.valueOf_61zpoe$ = LivemapConstants$Projection$valueOf;\n LivemapConstants.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LivemapConstants',\n interfaces: []\n };\n function LiveMapOptions(zoom, location, stroke, interactive, displayMode, scaled, clustering, labels, projection, geodesic, geocodingService, tileProvider, devParams) {\n this.zoom = zoom;\n this.location = location;\n this.stroke = stroke;\n this.interactive = interactive;\n this.displayMode = displayMode;\n this.scaled = scaled;\n this.clustering = clustering;\n this.labels = labels;\n this.projection = projection;\n this.geodesic = geodesic;\n this.geocodingService = geocodingService;\n this.tileProvider = tileProvider;\n this.devParams = devParams;\n }\n LiveMapOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapOptions',\n interfaces: []\n };\n function DodgePos(aesthetics, myGroupCount, myWidth) {\n this.myGroupCount_0 = myGroupCount;\n this.myWidth_0 = myWidth;\n this.myDodgingNeeded_0 = false;\n this.myDodgingNeeded_0 = this.isDodgingNeeded_0(aesthetics);\n }\n DodgePos.prototype.isDodgingNeeded_0 = function (aesthetics) {\n var tmp$;\n var groupByX = HashMap_init();\n tmp$ = aesthetics.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var p = aesthetics.dataPointAt_za3lpa$(i);\n if (p.defined_896ixz$(Aes$Companion_getInstance().X)) {\n var x = ensureNotNull(p.x());\n var group = p.group();\n if (groupByX.containsKey_11rb$(x)) {\n if (groupByX.get_11rb$(x) != group) {\n return true;\n }} else {\n groupByX.put_xwzc9p$(x, group);\n }\n }}\n return false;\n };\n DodgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var tmp$;\n if (this.myDodgingNeeded_0) {\n var dataResolution = ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var width = (tmp$ = this.myWidth_0) != null ? tmp$ : p.width();\n if (!data.SeriesUtil.isFinite_yrwdxb$(width)) {\n return v;\n }var slotIndex = ensureNotNull(p.group());\n var median = (this.myGroupCount_0 - 1 | 0) / 2.0;\n var xOffset = (slotIndex - median) * dataResolution * ensureNotNull(width);\n var xCenter = ensureNotNull(p.x());\n var xScaler = 1.0 / this.myGroupCount_0;\n var newX = (v.x + xOffset - xCenter) * xScaler + xCenter;\n return new DoubleVector(newX, v.y);\n }return v;\n };\n DodgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$DODGE_getInstance().handlesGroups();\n };\n DodgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DodgePos',\n interfaces: [PositionAdjustment]\n };\n function FillPos(aes) {\n this.myStackPosHelper_0 = StackPos$Companion_getInstance().splitPositiveNegative_m7huy5$(aes);\n this.myScalerByIndex_0 = this.mapIndexToScaler_0(aes);\n }\n FillPos.prototype.mapIndexToScaler_0 = function (aes) {\n var tmp$, tmp$_0;\n var posMaxByBin = HashMap_init();\n var negMaxByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPoint = aes.dataPointAt_za3lpa$(i);\n var x = dataPoint.x();\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = posMaxByBin, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(x)) {\n var key = ensureNotNull(x);\n posMaxByBin.put_xwzc9p$(key, 0.0);\n negMaxByBin.put_xwzc9p$(x, 0.0);\n }var y = dataPoint.y();\n if (data.SeriesUtil.isFinite_yrwdxb$(y)) {\n if (ensureNotNull(y) >= 0) {\n var key_0 = ensureNotNull(x);\n var value = ensureNotNull(posMaxByBin.get_11rb$(x)) + y;\n posMaxByBin.put_xwzc9p$(key_0, value);\n } else {\n var key_1 = ensureNotNull(x);\n var value_0 = ensureNotNull(negMaxByBin.get_11rb$(x)) - y;\n negMaxByBin.put_xwzc9p$(key_1, value_0);\n }\n }}}\n var scalerByIndex = HashMap_init();\n tmp$_0 = aes.dataPointCount();\n for (var i_0 = 0; i_0 < tmp$_0; i_0++) {\n var dataPoint_0 = aes.dataPointAt_za3lpa$(i_0);\n var x_0 = dataPoint_0.x();\n var y_0 = dataPoint_0.y();\n var tmp$_2;\n if ((Kotlin.isType(tmp$_2 = posMaxByBin, Map) ? tmp$_2 : throwCCE()).containsKey_11rb$(x_0) && data.SeriesUtil.isFinite_yrwdxb$(y_0)) {\n var tmp$_3 = ensureNotNull(y_0) >= 0;\n if (tmp$_3) {\n var tmp$_4;\n tmp$_3 = ensureNotNull((Kotlin.isType(tmp$_4 = posMaxByBin, Map) ? tmp$_4 : throwCCE()).get_11rb$(x_0)) > 0;\n }if (tmp$_3) {\n var tmp$_5;\n var value_1 = 1.0 / ensureNotNull((Kotlin.isType(tmp$_5 = posMaxByBin, Map) ? tmp$_5 : throwCCE()).get_11rb$(x_0));\n scalerByIndex.put_xwzc9p$(i_0, value_1);\n } else {\n var tmp$_6 = y_0 < 0;\n if (tmp$_6) {\n var tmp$_7;\n tmp$_6 = ensureNotNull((Kotlin.isType(tmp$_7 = negMaxByBin, Map) ? tmp$_7 : throwCCE()).get_11rb$(x_0)) > 0;\n }if (tmp$_6) {\n var tmp$_8;\n var value_2 = 1.0 / ensureNotNull((Kotlin.isType(tmp$_8 = negMaxByBin, Map) ? tmp$_8 : throwCCE()).get_11rb$(x_0));\n scalerByIndex.put_xwzc9p$(i_0, value_2);\n } else {\n scalerByIndex.put_xwzc9p$(i_0, 1.0);\n }\n }\n } else {\n scalerByIndex.put_xwzc9p$(i_0, 1.0);\n }\n }\n return scalerByIndex;\n };\n FillPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var newLoc = this.myStackPosHelper_0.translate_tshsjz$(v, p, ctx);\n return new DoubleVector(newLoc.x, newLoc.y * ensureNotNull(this.myScalerByIndex_0.get_11rb$(p.index())) * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().Y));\n };\n FillPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$FILL_getInstance().handlesGroups();\n };\n FillPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FillPos',\n interfaces: [PositionAdjustment]\n };\n function JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight) {\n this.myJitterPosHelper_0 = null;\n this.myDodgePosHelper_0 = null;\n this.myJitterPosHelper_0 = new JitterPos(jitterWidth, jitterHeight);\n this.myDodgePosHelper_0 = new DodgePos(aesthetics, groupCount, width);\n }\n JitterDodgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var afterJitter = this.myJitterPosHelper_0.translate_tshsjz$(v, p, ctx);\n return this.myDodgePosHelper_0.translate_tshsjz$(afterJitter, p, ctx);\n };\n JitterDodgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$JITTER_DODGE_getInstance().handlesGroups();\n };\n JitterDodgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterDodgePos',\n interfaces: [PositionAdjustment]\n };\n function JitterPos(width, height) {\n JitterPos$Companion_getInstance();\n this.myWidth_0 = 0;\n this.myHeight_0 = 0;\n this.myWidth_0 = width != null ? width : JitterPos$Companion_getInstance().DEF_JITTER_WIDTH;\n this.myHeight_0 = height != null ? height : JitterPos$Companion_getInstance().DEF_JITTER_HEIGHT;\n }\n JitterPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var x = (2 * Random.Default.nextDouble() - 1) * this.myWidth_0 * ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var y = (2 * Random.Default.nextDouble() - 1) * this.myHeight_0 * ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n return v.add_gpjtzr$(new DoubleVector(x, y));\n };\n JitterPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$JITTER_getInstance().handlesGroups();\n };\n function JitterPos$Companion() {\n JitterPos$Companion_instance = this;\n this.DEF_JITTER_WIDTH = 0.4;\n this.DEF_JITTER_HEIGHT = 0.4;\n }\n JitterPos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JitterPos$Companion_instance = null;\n function JitterPos$Companion_getInstance() {\n if (JitterPos$Companion_instance === null) {\n new JitterPos$Companion();\n }return JitterPos$Companion_instance;\n }\n JitterPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterPos',\n interfaces: [PositionAdjustment]\n };\n function NudgePos(width, height) {\n NudgePos$Companion_getInstance();\n this.myWidth_0 = 0;\n this.myHeight_0 = 0;\n this.myWidth_0 = width != null ? width : NudgePos$Companion_getInstance().DEF_NUDGE_WIDTH;\n this.myHeight_0 = height != null ? height : NudgePos$Companion_getInstance().DEF_NUDGE_HEIGHT;\n }\n NudgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var x = this.myWidth_0 * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().X);\n var y = this.myHeight_0 * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().Y);\n return v.add_gpjtzr$(new DoubleVector(x, y));\n };\n NudgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$NUDGE_getInstance().handlesGroups();\n };\n function NudgePos$Companion() {\n NudgePos$Companion_instance = this;\n this.DEF_NUDGE_WIDTH = 0.0;\n this.DEF_NUDGE_HEIGHT = 0.0;\n }\n NudgePos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NudgePos$Companion_instance = null;\n function NudgePos$Companion_getInstance() {\n if (NudgePos$Companion_instance === null) {\n new NudgePos$Companion();\n }return NudgePos$Companion_instance;\n }\n NudgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NudgePos',\n interfaces: [PositionAdjustment]\n };\n function PositionAdjustments() {\n PositionAdjustments_instance = this;\n }\n function PositionAdjustments$identity$ObjectLiteral() {\n }\n Object.defineProperty(PositionAdjustments$identity$ObjectLiteral.prototype, 'isIdentity', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n PositionAdjustments$identity$ObjectLiteral.prototype.translate_tshsjz$ = function (v, p, ctx) {\n return v;\n };\n PositionAdjustments$identity$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$IDENTITY_getInstance().handlesGroups();\n };\n PositionAdjustments$identity$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionAdjustment]\n };\n PositionAdjustments.prototype.identity = function () {\n return new PositionAdjustments$identity$ObjectLiteral();\n };\n PositionAdjustments.prototype.dodge_vvhcz8$ = function (aesthetics, groupCount, width) {\n return new DodgePos(aesthetics, groupCount, width);\n };\n PositionAdjustments.prototype.stack_4vnpmn$ = function (aes, strategy) {\n var tmp$;\n switch (strategy.name) {\n case 'SPLIT_POSITIVE_NEGATIVE':\n tmp$ = StackPos$Companion_getInstance().splitPositiveNegative_m7huy5$(aes);\n break;\n case 'SUM_POSITIVE_NEGATIVE':\n tmp$ = StackPos$Companion_getInstance().sumPositiveNegative_m7huy5$(aes);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PositionAdjustments.prototype.fill_m7huy5$ = function (aesthetics) {\n return new FillPos(aesthetics);\n };\n PositionAdjustments.prototype.jitter_jma9l8$ = function (width, height) {\n return new JitterPos(width, height);\n };\n PositionAdjustments.prototype.nudge_jma9l8$ = function (width, height) {\n return new NudgePos(width, height);\n };\n PositionAdjustments.prototype.jitterDodge_e2pc44$ = function (aesthetics, groupCount, width, jitterWidth, jitterHeight) {\n return new JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight);\n };\n function PositionAdjustments$Meta(name, ordinal, myHandlesGroups) {\n Enum.call(this);\n this.myHandlesGroups_39qcox$_0 = myHandlesGroups;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function PositionAdjustments$Meta_initFields() {\n PositionAdjustments$Meta_initFields = function () {\n };\n PositionAdjustments$Meta$IDENTITY_instance = new PositionAdjustments$Meta('IDENTITY', 0, false);\n PositionAdjustments$Meta$DODGE_instance = new PositionAdjustments$Meta('DODGE', 1, true);\n PositionAdjustments$Meta$STACK_instance = new PositionAdjustments$Meta('STACK', 2, true);\n PositionAdjustments$Meta$FILL_instance = new PositionAdjustments$Meta('FILL', 3, true);\n PositionAdjustments$Meta$JITTER_instance = new PositionAdjustments$Meta('JITTER', 4, false);\n PositionAdjustments$Meta$NUDGE_instance = new PositionAdjustments$Meta('NUDGE', 5, false);\n PositionAdjustments$Meta$JITTER_DODGE_instance = new PositionAdjustments$Meta('JITTER_DODGE', 6, true);\n }\n var PositionAdjustments$Meta$IDENTITY_instance;\n function PositionAdjustments$Meta$IDENTITY_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$IDENTITY_instance;\n }\n var PositionAdjustments$Meta$DODGE_instance;\n function PositionAdjustments$Meta$DODGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$DODGE_instance;\n }\n var PositionAdjustments$Meta$STACK_instance;\n function PositionAdjustments$Meta$STACK_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$STACK_instance;\n }\n var PositionAdjustments$Meta$FILL_instance;\n function PositionAdjustments$Meta$FILL_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$FILL_instance;\n }\n var PositionAdjustments$Meta$JITTER_instance;\n function PositionAdjustments$Meta$JITTER_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$JITTER_instance;\n }\n var PositionAdjustments$Meta$NUDGE_instance;\n function PositionAdjustments$Meta$NUDGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$NUDGE_instance;\n }\n var PositionAdjustments$Meta$JITTER_DODGE_instance;\n function PositionAdjustments$Meta$JITTER_DODGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$JITTER_DODGE_instance;\n }\n PositionAdjustments$Meta.prototype.handlesGroups = function () {\n return this.myHandlesGroups_39qcox$_0;\n };\n PositionAdjustments$Meta.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Meta',\n interfaces: [Enum]\n };\n function PositionAdjustments$Meta$values() {\n return [PositionAdjustments$Meta$IDENTITY_getInstance(), PositionAdjustments$Meta$DODGE_getInstance(), PositionAdjustments$Meta$STACK_getInstance(), PositionAdjustments$Meta$FILL_getInstance(), PositionAdjustments$Meta$JITTER_getInstance(), PositionAdjustments$Meta$NUDGE_getInstance(), PositionAdjustments$Meta$JITTER_DODGE_getInstance()];\n }\n PositionAdjustments$Meta.values = PositionAdjustments$Meta$values;\n function PositionAdjustments$Meta$valueOf(name) {\n switch (name) {\n case 'IDENTITY':\n return PositionAdjustments$Meta$IDENTITY_getInstance();\n case 'DODGE':\n return PositionAdjustments$Meta$DODGE_getInstance();\n case 'STACK':\n return PositionAdjustments$Meta$STACK_getInstance();\n case 'FILL':\n return PositionAdjustments$Meta$FILL_getInstance();\n case 'JITTER':\n return PositionAdjustments$Meta$JITTER_getInstance();\n case 'NUDGE':\n return PositionAdjustments$Meta$NUDGE_getInstance();\n case 'JITTER_DODGE':\n return PositionAdjustments$Meta$JITTER_DODGE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.Meta.' + name);\n }\n }\n PositionAdjustments$Meta.valueOf_61zpoe$ = PositionAdjustments$Meta$valueOf;\n function PositionAdjustments$StackingStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function PositionAdjustments$StackingStrategy_initFields() {\n PositionAdjustments$StackingStrategy_initFields = function () {\n };\n PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance = new PositionAdjustments$StackingStrategy('SUM_POSITIVE_NEGATIVE', 0);\n PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance = new PositionAdjustments$StackingStrategy('SPLIT_POSITIVE_NEGATIVE', 1);\n }\n var PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance;\n function PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance() {\n PositionAdjustments$StackingStrategy_initFields();\n return PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance;\n }\n var PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance;\n function PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance() {\n PositionAdjustments$StackingStrategy_initFields();\n return PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance;\n }\n PositionAdjustments$StackingStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StackingStrategy',\n interfaces: [Enum]\n };\n function PositionAdjustments$StackingStrategy$values() {\n return [PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance(), PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance()];\n }\n PositionAdjustments$StackingStrategy.values = PositionAdjustments$StackingStrategy$values;\n function PositionAdjustments$StackingStrategy$valueOf(name) {\n switch (name) {\n case 'SUM_POSITIVE_NEGATIVE':\n return PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance();\n case 'SPLIT_POSITIVE_NEGATIVE':\n return PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.StackingStrategy.' + name);\n }\n }\n PositionAdjustments$StackingStrategy.valueOf_61zpoe$ = PositionAdjustments$StackingStrategy$valueOf;\n PositionAdjustments.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PositionAdjustments',\n interfaces: []\n };\n var PositionAdjustments_instance = null;\n function PositionAdjustments_getInstance() {\n if (PositionAdjustments_instance === null) {\n new PositionAdjustments();\n }return PositionAdjustments_instance;\n }\n function StackPos(aes) {\n StackPos$Companion_getInstance();\n this.myOffsetByIndex_0 = null;\n this.myOffsetByIndex_0 = this.mapIndexToOffset_m7huy5$(aes);\n }\n StackPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n return v.add_gpjtzr$(new DoubleVector(0.0, ensureNotNull(this.myOffsetByIndex_0.get_11rb$(p.index()))));\n };\n StackPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$STACK_getInstance().handlesGroups();\n };\n function StackPos$SplitPositiveNegative(aes) {\n StackPos.call(this, aes);\n }\n StackPos$SplitPositiveNegative.prototype.mapIndexToOffset_m7huy5$ = function (aes) {\n var tmp$;\n var offsetByIndex = HashMap_init();\n var negPosBaseByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPoint = aes.dataPointAt_za3lpa$(i);\n var x = dataPoint.x();\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n var tmp$_0;\n if (!(Kotlin.isType(tmp$_0 = negPosBaseByBin, Map) ? tmp$_0 : throwCCE()).containsKey_11rb$(x)) {\n var key = ensureNotNull(x);\n var value = new Pair(new MutableDouble(0.0), new MutableDouble(0.0));\n negPosBaseByBin.put_xwzc9p$(key, value);\n }var y = dataPoint.y();\n if (data.SeriesUtil.isFinite_yrwdxb$(y)) {\n var tmp$_1;\n var pair = ensureNotNull((Kotlin.isType(tmp$_1 = negPosBaseByBin, Map) ? tmp$_1 : throwCCE()).get_11rb$(x));\n var offset;\n if (ensureNotNull(y) >= 0) {\n offset = pair.second.getAndAdd_14dthe$(y);\n } else {\n offset = pair.first.getAndAdd_14dthe$(y);\n }\n var value_0 = offset;\n offsetByIndex.put_xwzc9p$(i, value_0);\n }}}\n return offsetByIndex;\n };\n StackPos$SplitPositiveNegative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SplitPositiveNegative',\n interfaces: [StackPos]\n };\n function StackPos$SumPositiveNegative(aes) {\n StackPos.call(this, aes);\n }\n StackPos$SumPositiveNegative.prototype.mapIndexToOffset_m7huy5$ = function (aes) {\n var tmp$;\n var offsetByIndex = HashMap_init();\n var baseByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPointAes = aes.dataPointAt_za3lpa$(i);\n var x = ensureNotNull(dataPointAes.x());\n if (data.SeriesUtil.isFinite_14dthe$(x)) {\n if (!baseByBin.containsKey_11rb$(x)) {\n var value = new MutableDouble(0.0);\n baseByBin.put_xwzc9p$(x, value);\n }var y = ensureNotNull(dataPointAes.y());\n if (data.SeriesUtil.isFinite_14dthe$(y)) {\n var base = ensureNotNull(baseByBin.get_11rb$(x));\n var offset = base.getAndAdd_14dthe$(y);\n offsetByIndex.put_xwzc9p$(i, offset);\n }}}\n return offsetByIndex;\n };\n StackPos$SumPositiveNegative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SumPositiveNegative',\n interfaces: [StackPos]\n };\n function StackPos$Companion() {\n StackPos$Companion_instance = this;\n }\n StackPos$Companion.prototype.splitPositiveNegative_m7huy5$ = function (aes) {\n return new StackPos$SplitPositiveNegative(aes);\n };\n StackPos$Companion.prototype.sumPositiveNegative_m7huy5$ = function (aes) {\n return new StackPos$SumPositiveNegative(aes);\n };\n StackPos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StackPos$Companion_instance = null;\n function StackPos$Companion_getInstance() {\n if (StackPos$Companion_instance === null) {\n new StackPos$Companion();\n }return StackPos$Companion_instance;\n }\n StackPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StackPos',\n interfaces: [PositionAdjustment]\n };\n function LegendKeyElementFactory() {\n }\n LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var size = 2 * strokeWidth + 4;\n return new DoubleVector(size, size);\n };\n LegendKeyElementFactory.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LegendKeyElementFactory',\n interfaces: []\n };\n function SvgRoot() {\n }\n SvgRoot.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'SvgRoot',\n interfaces: []\n };\n function LineType() {\n }\n LineType.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LineType',\n interfaces: []\n };\n function NamedLineType(name, ordinal, code, myDashArray) {\n Enum.call(this);\n this.code = code;\n this.myDashArray_j93rys$_0 = myDashArray;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function NamedLineType_initFields() {\n NamedLineType_initFields = function () {\n };\n new NamedLineType$BLANK();\n new NamedLineType$SOLID();\n NamedLineType$DASHED_instance = new NamedLineType('DASHED', 2, 2, listOf([4.3, 4.3]));\n NamedLineType$DOTTED_instance = new NamedLineType('DOTTED', 3, 3, listOf([1.0, 3.2]));\n NamedLineType$DOTDASH_instance = new NamedLineType('DOTDASH', 4, 4, listOf([1.0, 3.2, 4.3, 3.2]));\n NamedLineType$LONGDASH_instance = new NamedLineType('LONGDASH', 5, 5, listOf([7.4, 3.2]));\n NamedLineType$TWODASH_instance = new NamedLineType('TWODASH', 6, 6, listOf([2.4, 2.4, 6.4, 2.4]));\n }\n function NamedLineType$BLANK() {\n NamedLineType$BLANK_instance = this;\n NamedLineType.call(this, 'BLANK', 0, 0, null);\n }\n Object.defineProperty(NamedLineType$BLANK.prototype, 'isBlank', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n NamedLineType$BLANK.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BLANK',\n interfaces: [NamedLineType]\n };\n var NamedLineType$BLANK_instance = null;\n function NamedLineType$BLANK_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$BLANK_instance;\n }\n function NamedLineType$SOLID() {\n NamedLineType$SOLID_instance = this;\n NamedLineType.call(this, 'SOLID', 1, 1, null);\n }\n Object.defineProperty(NamedLineType$SOLID.prototype, 'isSolid', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n NamedLineType$SOLID.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SOLID',\n interfaces: [NamedLineType]\n };\n var NamedLineType$SOLID_instance = null;\n function NamedLineType$SOLID_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$SOLID_instance;\n }\n var NamedLineType$DASHED_instance;\n function NamedLineType$DASHED_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DASHED_instance;\n }\n var NamedLineType$DOTTED_instance;\n function NamedLineType$DOTTED_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DOTTED_instance;\n }\n var NamedLineType$DOTDASH_instance;\n function NamedLineType$DOTDASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DOTDASH_instance;\n }\n var NamedLineType$LONGDASH_instance;\n function NamedLineType$LONGDASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$LONGDASH_instance;\n }\n var NamedLineType$TWODASH_instance;\n function NamedLineType$TWODASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$TWODASH_instance;\n }\n Object.defineProperty(NamedLineType.prototype, 'isSolid', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(NamedLineType.prototype, 'isBlank', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(NamedLineType.prototype, 'dashArray', {\n configurable: true,\n get: function () {\n if (!(this.isSolid || this.isBlank)) {\n return ensureNotNull(this.myDashArray_j93rys$_0);\n }throw IllegalStateException_init('No dash array in ' + this.name.toLowerCase() + ' linetype');\n }\n });\n NamedLineType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NamedLineType',\n interfaces: [LineType, Enum]\n };\n function NamedLineType$values() {\n return [NamedLineType$BLANK_getInstance(), NamedLineType$SOLID_getInstance(), NamedLineType$DASHED_getInstance(), NamedLineType$DOTTED_getInstance(), NamedLineType$DOTDASH_getInstance(), NamedLineType$LONGDASH_getInstance(), NamedLineType$TWODASH_getInstance()];\n }\n NamedLineType.values = NamedLineType$values;\n function NamedLineType$valueOf(name) {\n switch (name) {\n case 'BLANK':\n return NamedLineType$BLANK_getInstance();\n case 'SOLID':\n return NamedLineType$SOLID_getInstance();\n case 'DASHED':\n return NamedLineType$DASHED_getInstance();\n case 'DOTTED':\n return NamedLineType$DOTTED_getInstance();\n case 'DOTDASH':\n return NamedLineType$DOTDASH_getInstance();\n case 'LONGDASH':\n return NamedLineType$LONGDASH_getInstance();\n case 'TWODASH':\n return NamedLineType$TWODASH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.linetype.NamedLineType.' + name);\n }\n }\n NamedLineType.valueOf_61zpoe$ = NamedLineType$valueOf;\n function NamedShape(name, ordinal, code, isSolid, isFilled, isSmall) {\n if (isSolid === void 0)\n isSolid = false;\n if (isFilled === void 0)\n isFilled = false;\n if (isSmall === void 0)\n isSmall = false;\n Enum.call(this);\n this.code_djxmtz$_0 = code;\n this.isSolid = isSolid;\n this.isFilled = isFilled;\n this.isSmall_kvok7h$_0 = isSmall;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function NamedShape_initFields() {\n NamedShape_initFields = function () {\n };\n NamedShape$STICK_SQUARE_instance = new NamedShape('STICK_SQUARE', 0, 0);\n NamedShape$STICK_CIRCLE_instance = new NamedShape('STICK_CIRCLE', 1, 1);\n NamedShape$STICK_TRIANGLE_UP_instance = new NamedShape('STICK_TRIANGLE_UP', 2, 2);\n NamedShape$STICK_PLUS_instance = new NamedShape('STICK_PLUS', 3, 3);\n NamedShape$STICK_CROSS_instance = new NamedShape('STICK_CROSS', 4, 4);\n NamedShape$STICK_DIAMOND_instance = new NamedShape('STICK_DIAMOND', 5, 5);\n NamedShape$STICK_TRIANGLE_DOWN_instance = new NamedShape('STICK_TRIANGLE_DOWN', 6, 6);\n NamedShape$STICK_SQUARE_CROSS_instance = new NamedShape('STICK_SQUARE_CROSS', 7, 7);\n NamedShape$STICK_STAR_instance = new NamedShape('STICK_STAR', 8, 8);\n NamedShape$STICK_DIAMOND_PLUS_instance = new NamedShape('STICK_DIAMOND_PLUS', 9, 9);\n NamedShape$STICK_CIRCLE_PLUS_instance = new NamedShape('STICK_CIRCLE_PLUS', 10, 10);\n NamedShape$STICK_TRIANGLE_UP_DOWN_instance = new NamedShape('STICK_TRIANGLE_UP_DOWN', 11, 11);\n NamedShape$STICK_SQUARE_PLUS_instance = new NamedShape('STICK_SQUARE_PLUS', 12, 12);\n NamedShape$STICK_CIRCLE_CROSS_instance = new NamedShape('STICK_CIRCLE_CROSS', 13, 13);\n NamedShape$STICK_SQUARE_TRIANGLE_UP_instance = new NamedShape('STICK_SQUARE_TRIANGLE_UP', 14, 14);\n NamedShape$SOLID_SQUARE_instance = new NamedShape('SOLID_SQUARE', 15, 15, true, false);\n NamedShape$SOLID_CIRCLE_instance = new NamedShape('SOLID_CIRCLE', 16, 16, true, false);\n NamedShape$SOLID_TRIANGLE_UP_instance = new NamedShape('SOLID_TRIANGLE_UP', 17, 17, true, false);\n NamedShape$SOLID_DIAMOND_instance = new NamedShape('SOLID_DIAMOND', 18, 18, true, false, true);\n NamedShape$SOLID_CIRCLE_2_instance = new NamedShape('SOLID_CIRCLE_2', 19, 19, true, false);\n NamedShape$BULLET_instance = new NamedShape('BULLET', 20, 20, true, false, true);\n NamedShape$FILLED_CIRCLE_instance = new NamedShape('FILLED_CIRCLE', 21, 21, false, true);\n NamedShape$FILLED_SQUARE_instance = new NamedShape('FILLED_SQUARE', 22, 22, false, true);\n NamedShape$FILLED_DIAMOND_instance = new NamedShape('FILLED_DIAMOND', 23, 23, false, true);\n NamedShape$FILLED_TRIANGLE_UP_instance = new NamedShape('FILLED_TRIANGLE_UP', 24, 24, false, true);\n NamedShape$FILLED_TRIANGLE_DOWN_instance = new NamedShape('FILLED_TRIANGLE_DOWN', 25, 25, false, true);\n }\n Object.defineProperty(NamedShape.prototype, 'code', {\n get: function () {\n return this.code_djxmtz$_0;\n }\n });\n var NamedShape$STICK_SQUARE_instance;\n function NamedShape$STICK_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_instance;\n }\n var NamedShape$STICK_CIRCLE_instance;\n function NamedShape$STICK_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_instance;\n }\n var NamedShape$STICK_TRIANGLE_UP_instance;\n function NamedShape$STICK_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_UP_instance;\n }\n var NamedShape$STICK_PLUS_instance;\n function NamedShape$STICK_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_PLUS_instance;\n }\n var NamedShape$STICK_CROSS_instance;\n function NamedShape$STICK_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CROSS_instance;\n }\n var NamedShape$STICK_DIAMOND_instance;\n function NamedShape$STICK_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_DIAMOND_instance;\n }\n var NamedShape$STICK_TRIANGLE_DOWN_instance;\n function NamedShape$STICK_TRIANGLE_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_DOWN_instance;\n }\n var NamedShape$STICK_SQUARE_CROSS_instance;\n function NamedShape$STICK_SQUARE_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_CROSS_instance;\n }\n var NamedShape$STICK_STAR_instance;\n function NamedShape$STICK_STAR_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_STAR_instance;\n }\n var NamedShape$STICK_DIAMOND_PLUS_instance;\n function NamedShape$STICK_DIAMOND_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_DIAMOND_PLUS_instance;\n }\n var NamedShape$STICK_CIRCLE_PLUS_instance;\n function NamedShape$STICK_CIRCLE_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_PLUS_instance;\n }\n var NamedShape$STICK_TRIANGLE_UP_DOWN_instance;\n function NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_UP_DOWN_instance;\n }\n var NamedShape$STICK_SQUARE_PLUS_instance;\n function NamedShape$STICK_SQUARE_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_PLUS_instance;\n }\n var NamedShape$STICK_CIRCLE_CROSS_instance;\n function NamedShape$STICK_CIRCLE_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_CROSS_instance;\n }\n var NamedShape$STICK_SQUARE_TRIANGLE_UP_instance;\n function NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_TRIANGLE_UP_instance;\n }\n var NamedShape$SOLID_SQUARE_instance;\n function NamedShape$SOLID_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_SQUARE_instance;\n }\n var NamedShape$SOLID_CIRCLE_instance;\n function NamedShape$SOLID_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_CIRCLE_instance;\n }\n var NamedShape$SOLID_TRIANGLE_UP_instance;\n function NamedShape$SOLID_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_TRIANGLE_UP_instance;\n }\n var NamedShape$SOLID_DIAMOND_instance;\n function NamedShape$SOLID_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_DIAMOND_instance;\n }\n var NamedShape$SOLID_CIRCLE_2_instance;\n function NamedShape$SOLID_CIRCLE_2_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_CIRCLE_2_instance;\n }\n var NamedShape$BULLET_instance;\n function NamedShape$BULLET_getInstance() {\n NamedShape_initFields();\n return NamedShape$BULLET_instance;\n }\n var NamedShape$FILLED_CIRCLE_instance;\n function NamedShape$FILLED_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_CIRCLE_instance;\n }\n var NamedShape$FILLED_SQUARE_instance;\n function NamedShape$FILLED_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_SQUARE_instance;\n }\n var NamedShape$FILLED_DIAMOND_instance;\n function NamedShape$FILLED_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_DIAMOND_instance;\n }\n var NamedShape$FILLED_TRIANGLE_UP_instance;\n function NamedShape$FILLED_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_TRIANGLE_UP_instance;\n }\n var NamedShape$FILLED_TRIANGLE_DOWN_instance;\n function NamedShape$FILLED_TRIANGLE_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_TRIANGLE_DOWN_instance;\n }\n Object.defineProperty(NamedShape.prototype, 'isHollow', {\n configurable: true,\n get: function () {\n return !(this.isFilled || this.isSolid);\n }\n });\n NamedShape.prototype.size_l6g9mh$ = function (dataPoint) {\n return this.isSmall_kvok7h$_0 ? AesScaling_getInstance().circleDiameterSmaller_l6g9mh$(dataPoint) : AesScaling_getInstance().circleDiameter_l6g9mh$(dataPoint);\n };\n NamedShape.prototype.strokeWidth_l6g9mh$ = function (dataPoint) {\n return this.isSolid ? 0.0 : 1.0;\n };\n NamedShape.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NamedShape',\n interfaces: [PointShape, Enum]\n };\n function NamedShape$values() {\n return [NamedShape$STICK_SQUARE_getInstance(), NamedShape$STICK_CIRCLE_getInstance(), NamedShape$STICK_TRIANGLE_UP_getInstance(), NamedShape$STICK_PLUS_getInstance(), NamedShape$STICK_CROSS_getInstance(), NamedShape$STICK_DIAMOND_getInstance(), NamedShape$STICK_TRIANGLE_DOWN_getInstance(), NamedShape$STICK_SQUARE_CROSS_getInstance(), NamedShape$STICK_STAR_getInstance(), NamedShape$STICK_DIAMOND_PLUS_getInstance(), NamedShape$STICK_CIRCLE_PLUS_getInstance(), NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance(), NamedShape$STICK_SQUARE_PLUS_getInstance(), NamedShape$STICK_CIRCLE_CROSS_getInstance(), NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance(), NamedShape$SOLID_SQUARE_getInstance(), NamedShape$SOLID_CIRCLE_getInstance(), NamedShape$SOLID_TRIANGLE_UP_getInstance(), NamedShape$SOLID_DIAMOND_getInstance(), NamedShape$SOLID_CIRCLE_2_getInstance(), NamedShape$BULLET_getInstance(), NamedShape$FILLED_CIRCLE_getInstance(), NamedShape$FILLED_SQUARE_getInstance(), NamedShape$FILLED_DIAMOND_getInstance(), NamedShape$FILLED_TRIANGLE_UP_getInstance(), NamedShape$FILLED_TRIANGLE_DOWN_getInstance()];\n }\n NamedShape.values = NamedShape$values;\n function NamedShape$valueOf(name) {\n switch (name) {\n case 'STICK_SQUARE':\n return NamedShape$STICK_SQUARE_getInstance();\n case 'STICK_CIRCLE':\n return NamedShape$STICK_CIRCLE_getInstance();\n case 'STICK_TRIANGLE_UP':\n return NamedShape$STICK_TRIANGLE_UP_getInstance();\n case 'STICK_PLUS':\n return NamedShape$STICK_PLUS_getInstance();\n case 'STICK_CROSS':\n return NamedShape$STICK_CROSS_getInstance();\n case 'STICK_DIAMOND':\n return NamedShape$STICK_DIAMOND_getInstance();\n case 'STICK_TRIANGLE_DOWN':\n return NamedShape$STICK_TRIANGLE_DOWN_getInstance();\n case 'STICK_SQUARE_CROSS':\n return NamedShape$STICK_SQUARE_CROSS_getInstance();\n case 'STICK_STAR':\n return NamedShape$STICK_STAR_getInstance();\n case 'STICK_DIAMOND_PLUS':\n return NamedShape$STICK_DIAMOND_PLUS_getInstance();\n case 'STICK_CIRCLE_PLUS':\n return NamedShape$STICK_CIRCLE_PLUS_getInstance();\n case 'STICK_TRIANGLE_UP_DOWN':\n return NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance();\n case 'STICK_SQUARE_PLUS':\n return NamedShape$STICK_SQUARE_PLUS_getInstance();\n case 'STICK_CIRCLE_CROSS':\n return NamedShape$STICK_CIRCLE_CROSS_getInstance();\n case 'STICK_SQUARE_TRIANGLE_UP':\n return NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance();\n case 'SOLID_SQUARE':\n return NamedShape$SOLID_SQUARE_getInstance();\n case 'SOLID_CIRCLE':\n return NamedShape$SOLID_CIRCLE_getInstance();\n case 'SOLID_TRIANGLE_UP':\n return NamedShape$SOLID_TRIANGLE_UP_getInstance();\n case 'SOLID_DIAMOND':\n return NamedShape$SOLID_DIAMOND_getInstance();\n case 'SOLID_CIRCLE_2':\n return NamedShape$SOLID_CIRCLE_2_getInstance();\n case 'BULLET':\n return NamedShape$BULLET_getInstance();\n case 'FILLED_CIRCLE':\n return NamedShape$FILLED_CIRCLE_getInstance();\n case 'FILLED_SQUARE':\n return NamedShape$FILLED_SQUARE_getInstance();\n case 'FILLED_DIAMOND':\n return NamedShape$FILLED_DIAMOND_getInstance();\n case 'FILLED_TRIANGLE_UP':\n return NamedShape$FILLED_TRIANGLE_UP_getInstance();\n case 'FILLED_TRIANGLE_DOWN':\n return NamedShape$FILLED_TRIANGLE_DOWN_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.point.NamedShape.' + name);\n }\n }\n NamedShape.valueOf_61zpoe$ = NamedShape$valueOf;\n function PointShape() {\n }\n PointShape.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointShape',\n interfaces: []\n };\n function PointShapeSvg() {\n PointShapeSvg_instance = this;\n }\n PointShapeSvg.prototype.create_d8smhz$ = function (shape, location, p, fatten) {\n if (fatten === void 0)\n fatten = 1.0;\n if (equals(shape, TinyPointShape_getInstance())) {\n return this.createTinyDotShape_0(location, p);\n }if (Kotlin.isType(shape, NamedShape)) {\n return this.createNamedShape_0(shape, location, p, fatten);\n }throw IllegalArgumentException_init('Unsupported point shape code ' + shape.code + ' ' + toString(Kotlin.getKClassFromExpression(shape).simpleName));\n };\n PointShapeSvg.prototype.createTinyDotShape_0 = function (location, p) {\n var r = slim.SvgSlimElements.rect_6y0v78$(location.x - 0.5, location.y - 0.5, 1.0, 1.0);\n var color = ensureNotNull(p.color());\n var alpha = AestheticsUtil_getInstance().alpha_il6rhx$(color, p);\n r.setFill_o14uds$(color, alpha);\n r.setStrokeWidth_14dthe$(0.0);\n return r;\n };\n PointShapeSvg.prototype.createNamedShape_0 = function (shape, location, p, fatten) {\n var glyph = this.createSlimGlyph_0(shape, location, shape.size_l6g9mh$(p) * fatten);\n AestheticsUtil_getInstance().decorate_l4vgcq$(glyph, shape.isFilled, shape.isSolid, p, shape.strokeWidth_l6g9mh$(p));\n return glyph;\n };\n PointShapeSvg.prototype.createSlimGlyph_0 = function (shape, location, size) {\n switch (shape.name) {\n case 'STICK_SQUARE':\n case 'SOLID_SQUARE':\n case 'FILLED_SQUARE':\n return Glyphs_getInstance().square_e1sv3v$(location, size);\n case 'STICK_CIRCLE':\n case 'SOLID_CIRCLE':\n case 'SOLID_CIRCLE_2':\n case 'BULLET':\n case 'FILLED_CIRCLE':\n return Glyphs_getInstance().circle_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_UP':\n case 'SOLID_TRIANGLE_UP':\n case 'FILLED_TRIANGLE_UP':\n return Glyphs_getInstance().triangleUp_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_DOWN':\n case 'FILLED_TRIANGLE_DOWN':\n return Glyphs_getInstance().triangleDown_e1sv3v$(location, size);\n case 'STICK_DIAMOND':\n case 'SOLID_DIAMOND':\n case 'FILLED_DIAMOND':\n return Glyphs_getInstance().diamond_e1sv3v$(location, size);\n case 'STICK_PLUS':\n return Glyphs_getInstance().stickPlus_e1sv3v$(location, size);\n case 'STICK_CROSS':\n return Glyphs_getInstance().stickCross_e1sv3v$(location, size);\n case 'STICK_SQUARE_CROSS':\n return Glyphs_getInstance().stickSquareCross_e1sv3v$(location, size);\n case 'STICK_STAR':\n return Glyphs_getInstance().stickStar_e1sv3v$(location, size);\n case 'STICK_DIAMOND_PLUS':\n return Glyphs_getInstance().stickDiamondPlus_e1sv3v$(location, size);\n case 'STICK_CIRCLE_PLUS':\n return Glyphs_getInstance().stickCirclePlus_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_UP_DOWN':\n return Glyphs_getInstance().stickTriangleUpDown_e1sv3v$(location, size);\n case 'STICK_SQUARE_PLUS':\n return Glyphs_getInstance().stickSquarePlus_e1sv3v$(location, size);\n case 'STICK_CIRCLE_CROSS':\n return Glyphs_getInstance().stickCircleCross_e1sv3v$(location, size);\n case 'STICK_SQUARE_TRIANGLE_UP':\n return Glyphs_getInstance().stickSquareTriangleUp_e1sv3v$(location, size);\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n };\n PointShapeSvg.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PointShapeSvg',\n interfaces: []\n };\n var PointShapeSvg_instance = null;\n function PointShapeSvg_getInstance() {\n if (PointShapeSvg_instance === null) {\n new PointShapeSvg();\n }return PointShapeSvg_instance;\n }\n function TinyPointShape() {\n TinyPointShape_instance = this;\n }\n Object.defineProperty(TinyPointShape.prototype, 'code', {\n configurable: true,\n get: function () {\n return 46;\n }\n });\n TinyPointShape.prototype.size_l6g9mh$ = function (dataPoint) {\n return 1.0;\n };\n TinyPointShape.prototype.strokeWidth_l6g9mh$ = function (dataPoint) {\n return 0.0;\n };\n TinyPointShape.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TinyPointShape',\n interfaces: [PointShape]\n };\n var TinyPointShape_instance = null;\n function TinyPointShape_getInstance() {\n if (TinyPointShape_instance === null) {\n new TinyPointShape();\n }return TinyPointShape_instance;\n }\n function UpdatableShape() {\n }\n UpdatableShape.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UpdatableShape',\n interfaces: []\n };\n function CircleGlyph(location, width) {\n SingletonGlyph_init_0(location, width, this);\n }\n CircleGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n return slim.SvgSlimElements.circle_yvo9jy$(location.x, location.y, width / 2);\n };\n CircleGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CircleGlyph',\n interfaces: [SingletonGlyph]\n };\n function CrossGlyph(location, size, inscribedInCircle) {\n CrossGlyph$Companion_getInstance();\n if (inscribedInCircle === void 0)\n inscribedInCircle = true;\n TwoShapeGlyph.call(this);\n var cx = location.x;\n var cy = location.y;\n var w = inscribedInCircle ? size * CrossGlyph$Companion_getInstance().CIRCLE_WIDTH_ADJUST_RATIO : size;\n var half = w / 2;\n var backSlashLine = slim.SvgSlimElements.line_6y0v78$(cx - half, cy - half, cx + half, cy + half);\n var slashLine = slim.SvgSlimElements.line_6y0v78$(cx - half, cy + half, cx + half, cy - half);\n this.setShapes_0(backSlashLine, slashLine);\n }\n function CrossGlyph$Companion() {\n CrossGlyph$Companion_instance = this;\n var x = math.PI / 4;\n this.CIRCLE_WIDTH_ADJUST_RATIO = JsMath.cos(x);\n }\n CrossGlyph$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CrossGlyph$Companion_instance = null;\n function CrossGlyph$Companion_getInstance() {\n if (CrossGlyph$Companion_instance === null) {\n new CrossGlyph$Companion();\n }return CrossGlyph$Companion_instance;\n }\n CrossGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossGlyph',\n interfaces: [TwoShapeGlyph]\n };\n function DiamondGlyph(location, width) {\n SingletonGlyph_init_0(location, width, this);\n }\n DiamondGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n var half = width / 2;\n var x = new Float64Array([half, width, half, 0.0]);\n var y = new Float64Array([0.0, half, width, half]);\n var ox = location.x - half;\n var oy = location.y - half;\n for (var i = 0; i <= 3; i++) {\n x[i] = ox + x[i];\n y[i] = oy + y[i];\n }\n var pathData = GlyphUtil_getInstance().buildPathData_ceb5dm$(asList(x), asList(y));\n return slim.SvgSlimElements.path_za3rmp$(pathData);\n };\n DiamondGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiamondGlyph',\n interfaces: [SingletonGlyph]\n };\n function Glyph() {\n }\n Glyph.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Glyph',\n interfaces: [SvgSlimObject, UpdatableShape]\n };\n function GlyphPair(myG1, myG2) {\n this.myG1_0 = myG1;\n this.myG2_0 = myG2;\n }\n GlyphPair.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.myG1_0.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n this.myG2_0.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n GlyphPair.prototype.appendTo_i2myw1$ = function (g) {\n this.myG1_0.appendTo_i2myw1$(g);\n this.myG2_0.appendTo_i2myw1$(g);\n };\n GlyphPair.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GlyphPair',\n interfaces: [Glyph]\n };\n function GlyphUtil() {\n GlyphUtil_instance = this;\n }\n GlyphUtil.prototype.buildPathData_ceb5dm$ = function (xs, ys) {\n if (!(xs.size === ys.size)) {\n var message = 'Sizes of X/Y collections must be equal';\n throw IllegalArgumentException_init(message.toString());\n }if (xs.isEmpty()) {\n return SvgPathData.Companion.EMPTY;\n }var builder = (new SvgPathDataBuilder(true)).moveTo_przk3b$(collect.Iterables.get_7iig3d$(xs, 0), collect.Iterables.get_7iig3d$(ys, 0)).interpolatePoints_3g1a62$(xs, ys, SvgPathDataBuilder$Interpolation.LINEAR).closePath();\n return builder.build();\n };\n GlyphUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GlyphUtil',\n interfaces: []\n };\n var GlyphUtil_instance = null;\n function GlyphUtil_getInstance() {\n if (GlyphUtil_instance === null) {\n new GlyphUtil();\n }return GlyphUtil_instance;\n }\n function Glyphs() {\n Glyphs_instance = this;\n }\n Glyphs.prototype.square_e1sv3v$ = function (location, width) {\n return new SquareGlyph(location, width);\n };\n Glyphs.prototype.circle_e1sv3v$ = function (location, width) {\n return new CircleGlyph(location, width);\n };\n Glyphs.prototype.diamond_e1sv3v$ = function (location, width) {\n return new DiamondGlyph(location, width);\n };\n Glyphs.prototype.triangleUp_e1sv3v$ = function (location, width) {\n return new TriangleGlyph(location, width, true);\n };\n Glyphs.prototype.triangleDown_e1sv3v$ = function (location, width) {\n return new TriangleGlyph(location, width, false);\n };\n Glyphs.prototype.stickPlus_e1sv3v$ = function (location, width) {\n return new PlusGlyph(location, width);\n };\n Glyphs.prototype.stickCross_e1sv3v$ = function (location, width) {\n return new CrossGlyph(location, width);\n };\n Glyphs.prototype.stickSquareCross_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new CrossGlyph(location, size, false));\n };\n Glyphs.prototype.stickStar_e1sv3v$ = function (location, size) {\n return new GlyphPair(new PlusGlyph(location, size), new CrossGlyph(location, size));\n };\n Glyphs.prototype.stickDiamondPlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new DiamondGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickCirclePlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new CircleGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickTriangleUpDown_e1sv3v$ = function (location, size) {\n return new GlyphPair(new TriangleGlyph(location, size, true), new TriangleGlyph(location, size, false));\n };\n Glyphs.prototype.stickSquarePlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickCircleCross_e1sv3v$ = function (location, size) {\n return new GlyphPair(new CircleGlyph(location, size), new CrossGlyph(location, size));\n };\n Glyphs.prototype.stickSquareTriangleUp_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new TriangleGlyph(location, size, true, true));\n };\n Glyphs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Glyphs',\n interfaces: []\n };\n var Glyphs_instance = null;\n function Glyphs_getInstance() {\n if (Glyphs_instance === null) {\n new Glyphs();\n }return Glyphs_instance;\n }\n function MultiShapeGlyph() {\n }\n MultiShapeGlyph.prototype.update_0 = function (shape, fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n shape != null ? (shape.setFill_o14uds$(fill, fillAlpha), Unit) : null;\n shape != null ? (shape.setStroke_o14uds$(stroke, strokeAlpha), Unit) : null;\n shape != null ? (shape.setStrokeWidth_14dthe$(strokeWidth), Unit) : null;\n };\n MultiShapeGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiShapeGlyph',\n interfaces: [Glyph]\n };\n function PlusGlyph(location, size) {\n TwoShapeGlyph.call(this);\n var half = size / 2;\n var ox = location.x - half;\n var oy = location.y - half;\n var hLine = slim.SvgSlimElements.line_6y0v78$(0 + ox, half + oy, size + ox, half + oy);\n var vLine = slim.SvgSlimElements.line_6y0v78$(half + ox, 0 + oy, half + ox, size + oy);\n this.setShapes_0(hLine, vLine);\n }\n PlusGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlusGlyph',\n interfaces: [TwoShapeGlyph]\n };\n function SingletonGlyph() {\n this.myShape_tmqwxg$_0 = null;\n }\n SingletonGlyph.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.myShape_tmqwxg$_0.setFill_o14uds$(fill, fillAlpha);\n this.myShape_tmqwxg$_0.setStroke_o14uds$(stroke, strokeAlpha);\n this.myShape_tmqwxg$_0.setStrokeWidth_14dthe$(strokeWidth);\n };\n SingletonGlyph.prototype.appendTo_i2myw1$ = function (g) {\n this.myShape_tmqwxg$_0.appendTo_i2myw1$(g);\n };\n SingletonGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SingletonGlyph',\n interfaces: [Glyph]\n };\n function SingletonGlyph_init(shape, $this) {\n $this = $this || Object.create(SingletonGlyph.prototype);\n SingletonGlyph.call($this);\n $this.myShape_tmqwxg$_0 = shape;\n return $this;\n }\n function SingletonGlyph_init_0(location, width, $this) {\n $this = $this || Object.create(SingletonGlyph.prototype);\n SingletonGlyph.call($this);\n $this.myShape_tmqwxg$_0 = $this.createShape_e1sv3v$(location, width);\n return $this;\n }\n function SquareGlyph(location, size) {\n SingletonGlyph_init_0(location, size, this);\n }\n SquareGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n return slim.SvgSlimElements.rect_6y0v78$(location.x - width / 2, location.y - width / 2, width, width);\n };\n SquareGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SquareGlyph',\n interfaces: [SingletonGlyph]\n };\n function TriangleGlyph(location, size, pointingUp, inscribedInSquare) {\n TriangleGlyph$Companion_getInstance();\n if (inscribedInSquare === void 0)\n inscribedInSquare = false;\n SingletonGlyph_init(TriangleGlyph$Companion_getInstance().createTriangleShape_0(location, size, pointingUp, inscribedInSquare), this);\n }\n TriangleGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n throw IllegalStateException_init('Not applicable');\n };\n function TriangleGlyph$Companion() {\n TriangleGlyph$Companion_instance = this;\n var x = math.PI / 3;\n this.SIDE_TO_HEIGHT_RATIO_0 = JsMath.sin(x);\n this.VERTICAL_OFFSET_RATIO_0 = 1.0 / 12;\n }\n TriangleGlyph$Companion.prototype.createTriangleShape_0 = function (location, size, pointingUp, inscribedInSquare) {\n var half = size / 2;\n var height = inscribedInSquare ? size : this.SIDE_TO_HEIGHT_RATIO_0 * size;\n var vOffset = inscribedInSquare ? 0.0 : height * this.VERTICAL_OFFSET_RATIO_0;\n var x;\n var y;\n var dy = (size - height) / 2;\n if (pointingUp) {\n dy -= vOffset;\n x = new Float64Array([half, size, 0.0]);\n y = new Float64Array([0.0 + dy, height + dy, height + dy]);\n } else {\n dy += vOffset;\n x = new Float64Array([0.0, size, half]);\n y = new Float64Array([0.0 + dy, 0.0 + dy, height + dy]);\n }\n var ox = location.x - half;\n var oy = location.y - half;\n for (var i = 0; i <= 2; i++) {\n x[i] = ox + x[i];\n y[i] = oy + y[i];\n }\n var pathData = GlyphUtil_getInstance().buildPathData_ceb5dm$(asList(x), asList(y));\n return slim.SvgSlimElements.path_za3rmp$(pathData);\n };\n TriangleGlyph$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TriangleGlyph$Companion_instance = null;\n function TriangleGlyph$Companion_getInstance() {\n if (TriangleGlyph$Companion_instance === null) {\n new TriangleGlyph$Companion();\n }return TriangleGlyph$Companion_instance;\n }\n TriangleGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TriangleGlyph',\n interfaces: [SingletonGlyph]\n };\n function TwoShapeGlyph() {\n MultiShapeGlyph.call(this);\n this.myS1_0 = null;\n this.myS2_0 = null;\n }\n TwoShapeGlyph.prototype.setShapes_0 = function (s1, s2) {\n this.myS1_0 = s1;\n this.myS2_0 = s2;\n };\n TwoShapeGlyph.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.update_0(this.myS1_0, fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n this.update_0(this.myS2_0, fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n TwoShapeGlyph.prototype.appendTo_i2myw1$ = function (g) {\n ensureNotNull(this.myS1_0).appendTo_i2myw1$(g);\n ensureNotNull(this.myS2_0).appendTo_i2myw1$(g);\n };\n TwoShapeGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TwoShapeGlyph',\n interfaces: [MultiShapeGlyph]\n };\n function GroupComponent() {\n SvgComponent.call(this);\n }\n GroupComponent.prototype.buildComponent = function () {\n };\n GroupComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupComponent',\n interfaces: [SvgComponent]\n };\n function LinePath(builder) {\n LinePath$Companion_getInstance();\n SvgComponent.call(this);\n this.myPath_0 = null;\n this.myDashArray_0 = null;\n this.myPath_0 = SvgPathElement_init(builder.build());\n this.myPath_0.fill().set_11rb$(SvgColors.NONE);\n var lineWidth = 1.0;\n this.myPath_0.strokeWidth().set_11rb$(lineWidth);\n this.add_26jijc$(this.myPath_0);\n }\n LinePath.prototype.buildComponent = function () {\n };\n LinePath.prototype.color = function () {\n return this.myPath_0.strokeColor();\n };\n LinePath.prototype.fill = function () {\n return this.myPath_0.fillColor();\n };\n function LinePath$width$ObjectLiteral(this$LinePath) {\n this.this$LinePath = this$LinePath;\n }\n LinePath$width$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$LinePath.myPath_0.strokeWidth().set_11rb$(value);\n this.this$LinePath.updatePathDashArray_0();\n };\n LinePath$width$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n LinePath.prototype.width = function () {\n return new LinePath$width$ObjectLiteral(this);\n };\n function LinePath$dashArray$ObjectLiteral(this$LinePath) {\n this.this$LinePath = this$LinePath;\n }\n LinePath$dashArray$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$LinePath.myDashArray_0 = ArrayList_init_0(value);\n this.this$LinePath.updatePathDashArray_0();\n };\n LinePath$dashArray$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n LinePath.prototype.dashArray = function () {\n return new LinePath$dashArray$ObjectLiteral(this);\n };\n LinePath.prototype.updatePathDashArray_0 = function () {\n if (!(this.myDashArray_0 == null || ensureNotNull(this.myDashArray_0).isEmpty())) {\n var w = this.myPath_0.strokeWidth().get();\n var width = w != null ? w : 1.0;\n StrokeDashArraySupport_getInstance().apply_3xqz7j$(this.myPath_0, width, ensureNotNull(this.myDashArray_0));\n }};\n function LinePath$Companion() {\n LinePath$Companion_instance = this;\n this.END_OF_SUBPATH = null;\n }\n LinePath$Companion.prototype.line_qdtdbw$ = function (points) {\n return new LinePath(this.pathBuilder_0(points, false));\n };\n LinePath$Companion.prototype.polygon_yh26e7$ = function (points) {\n return new LinePath(this.pathBuilder_0(points, true));\n };\n LinePath$Companion.prototype.pathBuilder_0 = function (points, isPolygon) {\n var tmp$;\n var builder = new SvgPathDataBuilder(true);\n var curSegment = ArrayList_init();\n var interpolate = false;\n tmp$ = points.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n if (point === this.END_OF_SUBPATH) {\n this.buildSegment_0(builder, curSegment, interpolate);\n if (isPolygon) {\n builder.closePath();\n }curSegment = ArrayList_init();\n } else {\n curSegment.add_11rb$(ensureNotNull(point));\n }\n }\n this.buildSegment_0(builder, curSegment, interpolate);\n if (isPolygon) {\n builder.closePath();\n }return builder;\n };\n LinePath$Companion.prototype.buildSegment_0 = function (builder, curSegment, interpolate) {\n if (curSegment.isEmpty()) {\n return;\n }builder.moveTo_gpjtzr$(curSegment.get_za3lpa$(0));\n builder.interpolatePoints_1ravjc$(curSegment, interpolate ? SvgPathDataBuilder$Interpolation.CARDINAL : SvgPathDataBuilder$Interpolation.LINEAR);\n };\n LinePath$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinePath$Companion_instance = null;\n function LinePath$Companion_getInstance() {\n if (LinePath$Companion_instance === null) {\n new LinePath$Companion();\n }return LinePath$Companion_instance;\n }\n LinePath.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinePath',\n interfaces: [SvgComponent]\n };\n function StrokeDashArraySupport() {\n StrokeDashArraySupport_instance = this;\n }\n StrokeDashArraySupport.prototype.apply_3xqz7j$ = function (element, strokeWidth, dashArray) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = dashArray.iterator();\n while (tmp$.hasNext()) {\n var relativeLength = tmp$.next();\n var length = relativeLength * strokeWidth;\n if (sb.length > 0) {\n sb.append_s8itvh$(44);\n }sb.append_pdl1vj$(length.toString());\n }\n element.getAttribute_61zpoe$(svg.SvgConstants.SVG_STROKE_DASHARRAY_ATTRIBUTE).set_11rb$(sb.toString());\n };\n StrokeDashArraySupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'StrokeDashArraySupport',\n interfaces: []\n };\n var StrokeDashArraySupport_instance = null;\n function StrokeDashArraySupport_getInstance() {\n if (StrokeDashArraySupport_instance === null) {\n new StrokeDashArraySupport();\n }return StrokeDashArraySupport_instance;\n }\n function SvgComponent() {\n SvgComponent$Companion_getInstance();\n this.myIsBuilt_hfl4wb$_0 = false;\n this.myIsBuilding_wftuqx$_0 = false;\n this.myRootGroup_34n42m$_0 = new SvgGElement();\n this.myChildComponents_jx3u37$_0 = ArrayList_init();\n this.myOrigin_c2o9zl$_0 = DoubleVector.Companion.ZERO;\n this.myRotationAngle_woxwye$_0 = 0.0;\n this.myCompositeRegistration_t8l21t$_0 = new CompositeRegistration([]);\n }\n Object.defineProperty(SvgComponent.prototype, 'childComponents', {\n configurable: true,\n get: function () {\n if (!this.myIsBuilt_hfl4wb$_0) {\n var message = 'Plot has not yet built';\n throw IllegalArgumentException_init(message.toString());\n }return ArrayList_init_0(this.myChildComponents_jx3u37$_0);\n }\n });\n Object.defineProperty(SvgComponent.prototype, 'rootGroup', {\n configurable: true,\n get: function () {\n this.ensureBuilt();\n return this.myRootGroup_34n42m$_0;\n }\n });\n SvgComponent.prototype.ensureBuilt = function () {\n if (!(this.myIsBuilt_hfl4wb$_0 || this.myIsBuilding_wftuqx$_0)) {\n this.buildComponentIntern_92lbvk$_0();\n }};\n SvgComponent.prototype.buildComponentIntern_92lbvk$_0 = function () {\n try {\n this.myIsBuilding_wftuqx$_0 = true;\n this.buildComponent();\n }finally {\n this.myIsBuilding_wftuqx$_0 = false;\n this.myIsBuilt_hfl4wb$_0 = true;\n }\n };\n function SvgComponent$rebuildHandler$ObjectLiteral(this$SvgComponent) {\n this.this$SvgComponent = this$SvgComponent;\n }\n SvgComponent$rebuildHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.this$SvgComponent.needRebuild();\n };\n SvgComponent$rebuildHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n SvgComponent.prototype.rebuildHandler_287e2$ = function () {\n return new SvgComponent$rebuildHandler$ObjectLiteral(this);\n };\n SvgComponent.prototype.needRebuild = function () {\n if (this.myIsBuilt_hfl4wb$_0) {\n this.clear();\n this.buildComponentIntern_92lbvk$_0();\n }};\n SvgComponent.prototype.reg_3xv6fb$ = function (r) {\n this.myCompositeRegistration_t8l21t$_0.add_3xv6fb$(r);\n };\n SvgComponent.prototype.clear = function () {\n var tmp$;\n this.myIsBuilt_hfl4wb$_0 = false;\n tmp$ = this.myChildComponents_jx3u37$_0.iterator();\n while (tmp$.hasNext()) {\n var child = tmp$.next();\n child.clear();\n }\n this.myChildComponents_jx3u37$_0.clear();\n this.myRootGroup_34n42m$_0.children().clear();\n this.myCompositeRegistration_t8l21t$_0.remove();\n this.myCompositeRegistration_t8l21t$_0 = new CompositeRegistration([]);\n };\n SvgComponent.prototype.add_8icvvv$ = function (child) {\n this.myChildComponents_jx3u37$_0.add_11rb$(child);\n this.add_26jijc$(child.rootGroup);\n };\n SvgComponent.prototype.add_26jijc$ = function (node) {\n this.myRootGroup_34n42m$_0.children().add_11rb$(node);\n };\n SvgComponent.prototype.moveTo_gpjtzr$ = function (p) {\n this.myOrigin_c2o9zl$_0 = p;\n this.myRootGroup_34n42m$_0.transform().set_11rb$(SvgComponent$Companion_getInstance().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0, this.myRotationAngle_woxwye$_0));\n };\n SvgComponent.prototype.moveTo_lu1900$ = function (x, y) {\n this.moveTo_gpjtzr$(new DoubleVector(x, y));\n };\n SvgComponent.prototype.rotate_14dthe$ = function (angle) {\n this.myRotationAngle_woxwye$_0 = angle;\n this.myRootGroup_34n42m$_0.transform().set_11rb$(SvgComponent$Companion_getInstance().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0, this.myRotationAngle_woxwye$_0));\n };\n SvgComponent.prototype.toRelativeCoordinates_gpjtzr$ = function (location) {\n return this.rootGroup.pointToTransformedCoordinates_gpjtzr$(location);\n };\n SvgComponent.prototype.toAbsoluteCoordinates_gpjtzr$ = function (location) {\n return this.rootGroup.pointToAbsoluteCoordinates_gpjtzr$(location);\n };\n SvgComponent.prototype.clipBounds_wthzt5$ = function (rect) {\n var $receiver = new SvgClipPathElement();\n $receiver.id().set_11rb$(SvgUID_getInstance().get_61zpoe$(SvgComponent$Companion_getInstance().CLIP_PATH_ID_PREFIX));\n var tmp$ = $receiver.children();\n var $receiver_0 = new SvgRectElement();\n $receiver_0.x().set_11rb$(rect.left);\n $receiver_0.y().set_11rb$(rect.top);\n $receiver_0.width().set_11rb$(rect.width);\n $receiver_0.height().set_11rb$(rect.height);\n tmp$.add_11rb$($receiver_0);\n var clipPathElement = $receiver;\n var $receiver_1 = new SvgDefsElement();\n $receiver_1.children().add_11rb$(clipPathElement);\n var defs = $receiver_1;\n this.add_26jijc$(defs);\n this.rootGroup.clipPath().set_11rb$(new SvgIRI(ensureNotNull(clipPathElement.id().get())));\n this.rootGroup.setAttribute_qdh7ux$(SvgGraphicsElement.Companion.CLIP_BOUNDS_JFX, rect);\n };\n SvgComponent.prototype.addClassName_61zpoe$ = function (className) {\n this.myRootGroup_34n42m$_0.addClass_61zpoe$(className);\n };\n function SvgComponent$Companion() {\n SvgComponent$Companion_instance = this;\n this.CLIP_PATH_ID_PREFIX = '';\n }\n SvgComponent$Companion.prototype.buildTransform_e1sv3v$ = function (origin, rotationAngle) {\n var transformBuilder = new SvgTransformBuilder();\n if (!(origin != null ? origin.equals(DoubleVector.Companion.ZERO) : null)) {\n transformBuilder.translate_lu1900$(origin.x, origin.y);\n }if (rotationAngle !== 0.0) {\n transformBuilder.rotate_14dthe$(rotationAngle);\n }return transformBuilder.build();\n };\n SvgComponent$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SvgComponent$Companion_instance = null;\n function SvgComponent$Companion_getInstance() {\n if (SvgComponent$Companion_instance === null) {\n new SvgComponent$Companion();\n }return SvgComponent$Companion_instance;\n }\n SvgComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgComponent',\n interfaces: []\n };\n function SvgUID() {\n SvgUID_instance = this;\n this.suffixGen_0 = SvgUID$suffixGen$lambda;\n }\n function SvgUID$setUpForTest$lambda(closure$incrementalId) {\n return function () {\n return closure$incrementalId.next();\n };\n }\n SvgUID.prototype.setUpForTest = function () {\n var incrementalId = new SvgUID$IncrementalId();\n this.suffixGen_0 = SvgUID$setUpForTest$lambda(incrementalId);\n };\n SvgUID.prototype.get_61zpoe$ = function (prefix) {\n return prefix + this.suffixGen_0().toString();\n };\n function SvgUID$IncrementalId() {\n this.nextIndex_0 = 0;\n }\n SvgUID$IncrementalId.prototype.next = function () {\n var tmp$;\n return 'clip-' + (tmp$ = this.nextIndex_0, this.nextIndex_0 = tmp$ + 1 | 0, tmp$);\n };\n SvgUID$IncrementalId.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IncrementalId',\n interfaces: []\n };\n function SvgUID$suffixGen$lambda() {\n return random.RandomString.randomString_za3lpa$(6);\n }\n SvgUID.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SvgUID',\n interfaces: []\n };\n var SvgUID_instance = null;\n function SvgUID_getInstance() {\n if (SvgUID_instance === null) {\n new SvgUID();\n }return SvgUID_instance;\n }\n function TextLabel(text) {\n SvgComponent.call(this);\n this.myText_0 = SvgTextElement_init(text);\n this.myTextColor_0 = null;\n this.myFontSize_0 = 0.0;\n this.myFontWeight_0 = null;\n this.myFontFamily_0 = null;\n this.myFontStyle_0 = null;\n this.rootGroup.children().add_11rb$(this.myText_0);\n }\n TextLabel.prototype.buildComponent = function () {\n };\n function TextLabel$textColor$ObjectLiteral(this$TextLabel) {\n this.this$TextLabel = this$TextLabel;\n }\n TextLabel$textColor$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$TextLabel.myText_0.fillColor();\n this.this$TextLabel.myTextColor_0 = value;\n this.this$TextLabel.updateStyleAttribute_0();\n };\n TextLabel$textColor$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n TextLabel.prototype.textColor = function () {\n return new TextLabel$textColor$ObjectLiteral(this);\n };\n TextLabel.prototype.textOpacity = function () {\n return this.myText_0.fillOpacity();\n };\n TextLabel.prototype.x = function () {\n return this.myText_0.x();\n };\n TextLabel.prototype.y = function () {\n return this.myText_0.y();\n };\n TextLabel.prototype.setHorizontalAnchor_ja80zo$ = function (anchor) {\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_TEXT_ANCHOR_ATTRIBUTE, this.toTextAnchor_0(anchor));\n };\n TextLabel.prototype.setVerticalAnchor_yaudma$ = function (anchor) {\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_TEXT_DY_ATTRIBUTE, this.toDY_0(anchor));\n };\n TextLabel.prototype.setFontSize_14dthe$ = function (px) {\n this.myFontSize_0 = px;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontWeight_pdl1vj$ = function (cssName) {\n this.myFontWeight_0 = cssName;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontStyle_pdl1vj$ = function (cssName) {\n this.myFontStyle_0 = cssName;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontFamily_pdl1vj$ = function (fontFamily) {\n this.myFontFamily_0 = fontFamily;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.updateStyleAttribute_0 = function () {\n var sb = StringBuilder_init();\n if (this.myTextColor_0 != null) {\n sb.append_pdl1vj$('fill:').append_pdl1vj$(ensureNotNull(this.myTextColor_0).toHexColor()).append_s8itvh$(59);\n }if (this.myFontSize_0 > 0 && this.myFontFamily_0 != null) {\n var fnt = StringBuilder_init();\n var $receiver = this.myFontStyle_0;\n if (!($receiver == null || $receiver.length === 0)) {\n fnt.append_pdl1vj$(ensureNotNull(this.myFontStyle_0)).append_s8itvh$(32);\n }var $receiver_0 = this.myFontWeight_0;\n if (!($receiver_0 == null || $receiver_0.length === 0)) {\n fnt.append_pdl1vj$(ensureNotNull(this.myFontWeight_0)).append_s8itvh$(32);\n }fnt.append_s8jyv4$(this.myFontSize_0).append_pdl1vj$('px ');\n fnt.append_pdl1vj$(ensureNotNull(this.myFontFamily_0)).append_pdl1vj$(';');\n sb.append_pdl1vj$('font:').append_gw00v9$(fnt);\n } else {\n var $receiver_1 = this.myFontStyle_0;\n if (!($receiver_1 == null || isBlank($receiver_1))) {\n sb.append_pdl1vj$('font-style:').append_pdl1vj$(ensureNotNull(this.myFontStyle_0)).append_s8itvh$(59);\n }var $receiver_2 = this.myFontWeight_0;\n if (!($receiver_2 == null || $receiver_2.length === 0)) {\n sb.append_pdl1vj$('font-weight:').append_pdl1vj$(ensureNotNull(this.myFontWeight_0)).append_s8itvh$(59);\n }if (this.myFontSize_0 > 0) {\n sb.append_pdl1vj$('font-size:').append_s8jyv4$(this.myFontSize_0).append_pdl1vj$('px;');\n }var $receiver_3 = this.myFontFamily_0;\n if (!($receiver_3 == null || $receiver_3.length === 0)) {\n sb.append_pdl1vj$('font-family:').append_pdl1vj$(ensureNotNull(this.myFontFamily_0)).append_s8itvh$(59);\n }}\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_STYLE_ATTRIBUTE, sb.toString());\n };\n TextLabel.prototype.toTextAnchor_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'LEFT':\n tmp$ = null;\n break;\n case 'MIDDLE':\n tmp$ = svg.SvgConstants.SVG_TEXT_ANCHOR_MIDDLE;\n break;\n case 'RIGHT':\n tmp$ = svg.SvgConstants.SVG_TEXT_ANCHOR_END;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TextLabel.prototype.toDominantBaseline_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'TOP':\n tmp$ = 'hanging';\n break;\n case 'CENTER':\n tmp$ = 'central';\n break;\n case 'BOTTOM':\n tmp$ = null;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TextLabel.prototype.toDY_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'TOP':\n tmp$ = svg.SvgConstants.SVG_TEXT_DY_TOP;\n break;\n case 'CENTER':\n tmp$ = svg.SvgConstants.SVG_TEXT_DY_CENTER;\n break;\n case 'BOTTOM':\n tmp$ = null;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n function TextLabel$HorizontalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TextLabel$HorizontalAnchor_initFields() {\n TextLabel$HorizontalAnchor_initFields = function () {\n };\n TextLabel$HorizontalAnchor$LEFT_instance = new TextLabel$HorizontalAnchor('LEFT', 0);\n TextLabel$HorizontalAnchor$RIGHT_instance = new TextLabel$HorizontalAnchor('RIGHT', 1);\n TextLabel$HorizontalAnchor$MIDDLE_instance = new TextLabel$HorizontalAnchor('MIDDLE', 2);\n }\n var TextLabel$HorizontalAnchor$LEFT_instance;\n function TextLabel$HorizontalAnchor$LEFT_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$LEFT_instance;\n }\n var TextLabel$HorizontalAnchor$RIGHT_instance;\n function TextLabel$HorizontalAnchor$RIGHT_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$RIGHT_instance;\n }\n var TextLabel$HorizontalAnchor$MIDDLE_instance;\n function TextLabel$HorizontalAnchor$MIDDLE_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$MIDDLE_instance;\n }\n TextLabel$HorizontalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAnchor',\n interfaces: [Enum]\n };\n function TextLabel$HorizontalAnchor$values() {\n return [TextLabel$HorizontalAnchor$LEFT_getInstance(), TextLabel$HorizontalAnchor$RIGHT_getInstance(), TextLabel$HorizontalAnchor$MIDDLE_getInstance()];\n }\n TextLabel$HorizontalAnchor.values = TextLabel$HorizontalAnchor$values;\n function TextLabel$HorizontalAnchor$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return TextLabel$HorizontalAnchor$LEFT_getInstance();\n case 'RIGHT':\n return TextLabel$HorizontalAnchor$RIGHT_getInstance();\n case 'MIDDLE':\n return TextLabel$HorizontalAnchor$MIDDLE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor.' + name);\n }\n }\n TextLabel$HorizontalAnchor.valueOf_61zpoe$ = TextLabel$HorizontalAnchor$valueOf;\n function TextLabel$VerticalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TextLabel$VerticalAnchor_initFields() {\n TextLabel$VerticalAnchor_initFields = function () {\n };\n TextLabel$VerticalAnchor$TOP_instance = new TextLabel$VerticalAnchor('TOP', 0);\n TextLabel$VerticalAnchor$BOTTOM_instance = new TextLabel$VerticalAnchor('BOTTOM', 1);\n TextLabel$VerticalAnchor$CENTER_instance = new TextLabel$VerticalAnchor('CENTER', 2);\n }\n var TextLabel$VerticalAnchor$TOP_instance;\n function TextLabel$VerticalAnchor$TOP_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$TOP_instance;\n }\n var TextLabel$VerticalAnchor$BOTTOM_instance;\n function TextLabel$VerticalAnchor$BOTTOM_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$BOTTOM_instance;\n }\n var TextLabel$VerticalAnchor$CENTER_instance;\n function TextLabel$VerticalAnchor$CENTER_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$CENTER_instance;\n }\n TextLabel$VerticalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAnchor',\n interfaces: [Enum]\n };\n function TextLabel$VerticalAnchor$values() {\n return [TextLabel$VerticalAnchor$TOP_getInstance(), TextLabel$VerticalAnchor$BOTTOM_getInstance(), TextLabel$VerticalAnchor$CENTER_getInstance()];\n }\n TextLabel$VerticalAnchor.values = TextLabel$VerticalAnchor$values;\n function TextLabel$VerticalAnchor$valueOf(name) {\n switch (name) {\n case 'TOP':\n return TextLabel$VerticalAnchor$TOP_getInstance();\n case 'BOTTOM':\n return TextLabel$VerticalAnchor$BOTTOM_getInstance();\n case 'CENTER':\n return TextLabel$VerticalAnchor$CENTER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor.' + name);\n }\n }\n TextLabel$VerticalAnchor.valueOf_61zpoe$ = TextLabel$VerticalAnchor$valueOf;\n TextLabel.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextLabel',\n interfaces: [SvgComponent]\n };\n function AbstractScale() {\n this.definedBreaks_0 = null;\n this.definedLabels_0 = null;\n this.name_iafnnl$_0 = null;\n this.mapper_ohg8eh$_0 = null;\n this.multiplicativeExpand_lxi716$_0 = 0.0;\n this.additiveExpand_59ok4k$_0 = 0.0;\n this.labelFormatter_tb2f2k$_0 = null;\n }\n Object.defineProperty(AbstractScale.prototype, 'name', {\n configurable: true,\n get: function () {\n return this.name_iafnnl$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'mapper', {\n configurable: true,\n get: function () {\n return this.mapper_ohg8eh$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'multiplicativeExpand', {\n configurable: true,\n get: function () {\n return this.multiplicativeExpand_lxi716$_0;\n },\n set: function (multiplicativeExpand) {\n this.multiplicativeExpand_lxi716$_0 = multiplicativeExpand;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'additiveExpand', {\n configurable: true,\n get: function () {\n return this.additiveExpand_59ok4k$_0;\n },\n set: function (additiveExpand) {\n this.additiveExpand_59ok4k$_0 = additiveExpand;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'labelFormatter', {\n configurable: true,\n get: function () {\n return this.labelFormatter_tb2f2k$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'breaks', {\n configurable: true,\n get: function () {\n var tmp$;\n if (!this.hasBreaks()) {\n var message = 'No breaks defined for scale ' + this.name;\n throw IllegalStateException_init(message.toString());\n }return Kotlin.isType(tmp$ = this.definedBreaks_0, List) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'labels', {\n configurable: true,\n get: function () {\n if (!this.labelsDefined_0()) {\n var message = 'No labels defined for scale ' + this.name;\n throw IllegalStateException_init(message.toString());\n }return ensureNotNull(this.definedLabels_0);\n }\n });\n AbstractScale.prototype.hasBreaks = function () {\n return this.definedBreaks_0 != null;\n };\n AbstractScale.prototype.hasLabels = function () {\n return this.labelsDefined_0();\n };\n AbstractScale.prototype.labelsDefined_0 = function () {\n return this.definedLabels_0 != null;\n };\n function AbstractScale$AbstractBuilder(scale) {\n this.myName_8be2vx$ = scale.name;\n this.myBreaks_8be2vx$ = scale.definedBreaks_0;\n this.myLabels_8be2vx$ = scale.definedLabels_0;\n this.myLabelFormatter_8be2vx$ = scale.labelFormatter;\n this.myMapper_8be2vx$ = scale.mapper;\n this.myMultiplicativeExpand_8be2vx$ = scale.multiplicativeExpand;\n this.myAdditiveExpand_8be2vx$ = scale.additiveExpand;\n }\n AbstractScale$AbstractBuilder.prototype.breaks_pqjuzw$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0;\n destination.add_11rb$((tmp$_0 = item) == null || Kotlin.isType(tmp$_0, Any) ? tmp$_0 : throwCCE());\n }\n this.myBreaks_8be2vx$ = destination;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.labels_mhpeer$ = function (l) {\n this.myLabels_8be2vx$ = l;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.labelFormatter_h0j1qz$ = function (v) {\n this.myLabelFormatter_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.mapper_1uitho$ = function (m) {\n this.myMapper_8be2vx$ = m;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.multiplicativeExpand_14dthe$ = function (v) {\n this.myMultiplicativeExpand_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.additiveExpand_14dthe$ = function (v) {\n this.myAdditiveExpand_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractBuilder',\n interfaces: [Scale$Builder]\n };\n AbstractScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractScale',\n interfaces: [Scale]\n };\n function AbstractScale_init(name, mapper, breaks, $this) {\n if (breaks === void 0)\n breaks = null;\n $this = $this || Object.create(AbstractScale.prototype);\n AbstractScale.call($this);\n $this.name_iafnnl$_0 = name;\n $this.mapper_ohg8eh$_0 = mapper;\n $this.definedBreaks_0 = breaks;\n $this.definedLabels_0 = null;\n $this.labelFormatter_tb2f2k$_0 = null;\n return $this;\n }\n function AbstractScale_init_0(b, $this) {\n $this = $this || Object.create(AbstractScale.prototype);\n AbstractScale.call($this);\n $this.name_iafnnl$_0 = b.myName_8be2vx$;\n $this.definedBreaks_0 = b.myBreaks_8be2vx$;\n $this.definedLabels_0 = b.myLabels_8be2vx$;\n $this.labelFormatter_tb2f2k$_0 = b.myLabelFormatter_8be2vx$;\n $this.mapper_ohg8eh$_0 = b.myMapper_8be2vx$;\n $this.multiplicativeExpand = b.myMultiplicativeExpand_8be2vx$;\n $this.additiveExpand = b.myAdditiveExpand_8be2vx$;\n return $this;\n }\n function BreaksGenerator() {\n }\n BreaksGenerator.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BreaksGenerator',\n interfaces: []\n };\n function ContinuousScale() {\n this.continuousTransform_0 = null;\n this.customBreaksGenerator_0 = null;\n this.isContinuous_r02bms$_0 = false;\n this.isContinuousDomain_cs93sw$_0 = true;\n this.domainLimits_m56boh$_0 = null;\n }\n Object.defineProperty(ContinuousScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return this.isContinuous_r02bms$_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n return this.isContinuousDomain_cs93sw$_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'domainLimits', {\n configurable: true,\n get: function () {\n return this.domainLimits_m56boh$_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n return this.continuousTransform_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'breaksGenerator', {\n configurable: true,\n get: function () {\n var tmp$;\n if (this.customBreaksGenerator_0 != null) {\n tmp$ = new Transforms$BreaksGeneratorForTransformedDomain(this.continuousTransform_0, this.customBreaksGenerator_0);\n } else {\n tmp$ = Transforms_getInstance().createBreaksGeneratorForTransformedDomain_5x42z5$(this.continuousTransform_0, this.labelFormatter);\n }\n return tmp$;\n }\n });\n ContinuousScale.prototype.hasBreaksGenerator = function () {\n return true;\n };\n ContinuousScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n var tmp$;\n if (Kotlin.isNumber(v)) {\n var d = numberToDouble(v);\n tmp$ = (isFinite(d) && d >= this.domainLimits.first && d <= this.domainLimits.second);\n } else {\n tmp$ = false;\n }\n return tmp$;\n };\n ContinuousScale.prototype.hasDomainLimits = function () {\n return isFinite(this.domainLimits.first) || isFinite(this.domainLimits.second);\n };\n ContinuousScale.prototype.with = function () {\n return new ContinuousScale$MyBuilder(this);\n };\n function ContinuousScale$MyBuilder(scale) {\n AbstractScale$AbstractBuilder.call(this, scale);\n this.myContinuousTransform = scale.continuousTransform_0;\n this.myCustomBreaksGenerator = scale.customBreaksGenerator_0;\n this.myLowerLimit = scale.domainLimits.first;\n this.myUpperLimit = scale.domainLimits.second;\n this.myContinuousOutput = scale.isContinuous;\n }\n ContinuousScale$MyBuilder.prototype.lowerLimit_14dthe$ = function (v) {\n if (!isFinite(v)) {\n var message = \"`lower` can't be \" + v;\n throw IllegalArgumentException_init(message.toString());\n }this.myLowerLimit = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.upperLimit_14dthe$ = function (v) {\n if (!isFinite(v)) {\n var message = \"`upper` can't be \" + v;\n throw IllegalArgumentException_init(message.toString());\n }this.myUpperLimit = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.limits_pqjuzw$ = function (domainValues) {\n throw IllegalArgumentException_init(\"Can't apply discrete limits to scale with continuous domain\");\n };\n ContinuousScale$MyBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n this.myContinuousTransform = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n this.myCustomBreaksGenerator = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.build = function () {\n return ContinuousScale_init_0(this);\n };\n ContinuousScale$MyBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyBuilder',\n interfaces: [AbstractScale$AbstractBuilder]\n };\n ContinuousScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuousScale',\n interfaces: [AbstractScale]\n };\n function ContinuousScale_init(name, mapper, continuousOutput, $this) {\n $this = $this || Object.create(ContinuousScale.prototype);\n AbstractScale_init(name, mapper, void 0, $this);\n ContinuousScale.call($this);\n $this.isContinuous_r02bms$_0 = continuousOutput;\n $this.domainLimits_m56boh$_0 = new Pair_0(kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY, kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY);\n $this.continuousTransform_0 = Transforms_getInstance().IDENTITY;\n $this.customBreaksGenerator_0 = null;\n $this.multiplicativeExpand = 0.05;\n $this.additiveExpand = 0.0;\n return $this;\n }\n function ContinuousScale_init_0(b, $this) {\n $this = $this || Object.create(ContinuousScale.prototype);\n AbstractScale_init_0(b, $this);\n ContinuousScale.call($this);\n $this.continuousTransform_0 = b.myContinuousTransform;\n $this.customBreaksGenerator_0 = b.myCustomBreaksGenerator;\n $this.isContinuous_r02bms$_0 = b.myContinuousOutput;\n var lower = data.SeriesUtil.isFinite_yrwdxb$(b.myLowerLimit) ? ensureNotNull(b.myLowerLimit) : kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY;\n var upper = data.SeriesUtil.isFinite_yrwdxb$(b.myUpperLimit) ? ensureNotNull(b.myUpperLimit) : kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n $this.domainLimits_m56boh$_0 = new Pair_0(JsMath.min(lower, upper), JsMath.max(lower, upper));\n return $this;\n }\n function DiscreteScale() {\n this.discreteTransform_0 = null;\n }\n Object.defineProperty(DiscreteScale.prototype, 'breaks', {\n configurable: true,\n get: function () {\n var tmp$;\n if (!this.hasDomainLimits()) {\n tmp$ = Kotlin.callGetter(this, AbstractScale.prototype, 'breaks');\n } else {\n var breaksSet = toSet(Kotlin.callGetter(this, AbstractScale.prototype, 'breaks'));\n var $receiver = this.discreteTransform_0.domainLimits;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (breaksSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n tmp$ = destination;\n }\n return tmp$;\n }\n });\n Object.defineProperty(DiscreteScale.prototype, 'labels', {\n configurable: true,\n get: function () {\n var tmp$;\n var labels = Kotlin.callGetter(this, AbstractScale.prototype, 'labels');\n if (!this.hasDomainLimits() || labels.isEmpty()) {\n tmp$ = labels;\n } else {\n var breaks = Kotlin.callGetter(this, AbstractScale.prototype, 'breaks');\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_0, tmp$_0_0;\n var index = 0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(labels.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index, index = tmp$_0_0 + 1 | 0, tmp$_0_0)) % labels.size));\n }\n var breakLabels = destination;\n var labelByBreak = toMap(zip(breaks, breakLabels));\n var $receiver = this.discreteTransform_0.domainLimits;\n var destination_0 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (labelByBreak.containsKey_11rb$(element))\n destination_0.add_11rb$(element);\n }\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault(destination_0, 10));\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_1.add_11rb$(getValue(labelByBreak, item_0));\n }\n tmp$ = destination_1;\n }\n return tmp$;\n }\n });\n Object.defineProperty(DiscreteScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n return this.discreteTransform_0;\n }\n });\n Object.defineProperty(DiscreteScale.prototype, 'breaksGenerator', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init(\"No breaks generator for discrete scale '\" + this.name + \"'\");\n }\n });\n Object.defineProperty(DiscreteScale.prototype, 'domainLimits', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init(\"Not applicable to scale with discrete domain '\" + this.name + \"'\");\n }\n });\n DiscreteScale.prototype.hasBreaksGenerator = function () {\n return false;\n };\n DiscreteScale.prototype.hasDomainLimits = function () {\n return this.discreteTransform_0.hasDomainLimits();\n };\n DiscreteScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n return this.discreteTransform_0.isInDomain_s8jyv4$(v);\n };\n DiscreteScale.prototype.with = function () {\n return new DiscreteScale$MyBuilder(this);\n };\n function DiscreteScale$MyBuilder(scale) {\n AbstractScale$AbstractBuilder.call(this, scale);\n this.myDomainValues_8be2vx$ = scale.discreteTransform_0.domainValues;\n this.myDomainLimits_8be2vx$ = scale.discreteTransform_0.domainLimits;\n }\n DiscreteScale$MyBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.lowerLimit_14dthe$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.upperLimit_14dthe$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.limits_pqjuzw$ = function (domainValues) {\n this.myDomainLimits_8be2vx$ = domainValues;\n return this;\n };\n DiscreteScale$MyBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n return this;\n };\n DiscreteScale$MyBuilder.prototype.build = function () {\n return DiscreteScale_init_0(this);\n };\n DiscreteScale$MyBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyBuilder',\n interfaces: [AbstractScale$AbstractBuilder]\n };\n DiscreteScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteScale',\n interfaces: [AbstractScale]\n };\n function DiscreteScale_init(name, domainValues, mapper, $this) {\n $this = $this || Object.create(DiscreteScale.prototype);\n AbstractScale_init(name, mapper, toList_0(domainValues), $this);\n DiscreteScale.call($this);\n $this.discreteTransform_0 = new DiscreteTransform(domainValues, emptyList());\n $this.multiplicativeExpand = 0.0;\n $this.additiveExpand = 0.6;\n return $this;\n }\n function DiscreteScale_init_0(b, $this) {\n $this = $this || Object.create(DiscreteScale.prototype);\n AbstractScale_init_0(b, $this);\n DiscreteScale.call($this);\n $this.discreteTransform_0 = new DiscreteTransform(b.myDomainValues_8be2vx$, b.myDomainLimits_8be2vx$);\n return $this;\n }\n function MapperUtil() {\n MapperUtil_instance = this;\n }\n MapperUtil.prototype.map_rejkqi$ = function (r, mapper) {\n var a = ensureNotNull(mapper(r.lowerEnd));\n var b = ensureNotNull(mapper(r.upperEnd));\n return new ClosedRange(JsMath.min(a, b), JsMath.max(a, b));\n };\n MapperUtil.prototype.mapDiscreteDomainValuesToNumbers_7f6uoc$ = function (values) {\n return this.mapDiscreteDomainValuesToIndices_0(values);\n };\n MapperUtil.prototype.mapDiscreteDomainValuesToIndices_0 = function (values) {\n var tmp$, tmp$_0;\n var result = LinkedHashMap_init();\n var index = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (v != null && !result.containsKey_11rb$(v)) {\n var value = (tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0);\n result.put_xwzc9p$(v, value);\n }}\n return result;\n };\n MapperUtil.prototype.rangeWithLimitsAfterTransform_5yamkg$ = function (dataRange, lowerLimit, upperLimit, trans) {\n var tmp$, tmp$_0;\n if (lowerLimit != null && isFinite(lowerLimit)) {\n tmp$ = lowerLimit;\n } else {\n tmp$ = dataRange.lowerEnd;\n }\n var lower = tmp$;\n if (upperLimit != null && isFinite(upperLimit)) {\n tmp$_0 = upperLimit;\n } else {\n tmp$_0 = dataRange.upperEnd;\n }\n var upper = tmp$_0;\n var limits = listOf([lower, upper]);\n return ClosedRange.Companion.encloseAll_17hg47$(trans.apply_9ma18$(limits));\n };\n MapperUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MapperUtil',\n interfaces: []\n };\n var MapperUtil_instance = null;\n function MapperUtil_getInstance() {\n if (MapperUtil_instance === null) {\n new MapperUtil();\n }return MapperUtil_instance;\n }\n function Mappers() {\n Mappers_instance = this;\n this.IDENTITY = Mappers$IDENTITY$lambda;\n }\n function Mappers$undefined$lambda(it) {\n throw IllegalStateException_init('Undefined mapper');\n }\n Mappers.prototype.undefined_287e2$ = function () {\n return Mappers$undefined$lambda;\n };\n function Mappers$nullable$lambda(closure$ifNull, closure$f) {\n return function (n) {\n if (n == null) {\n return closure$ifNull;\n } else {\n return closure$f(n);\n }\n };\n }\n Mappers.prototype.nullable_q9jsah$ = function (f, ifNull) {\n return Mappers$nullable$lambda(ifNull, f);\n };\n function Mappers$constant$lambda(closure$v) {\n return function (it) {\n return closure$v;\n };\n }\n Mappers.prototype.constant_14dthe$ = function (v) {\n return Mappers$constant$lambda(v);\n };\n Mappers.prototype.mul_mdyssk$ = function (domain, rangeSpan) {\n var factor = rangeSpan / (domain.upperEnd - domain.lowerEnd);\n if (!!(isInfinite(factor) || isNaN_0(factor))) {\n var message = \"Can't create mapper with ratio: \" + factor;\n throw IllegalStateException_init(message.toString());\n }return this.mul_14dthe$(factor);\n };\n function Mappers$mul$lambda(closure$factor) {\n return function (v) {\n if (v != null) {\n return closure$factor * v;\n } else\n return null;\n };\n }\n Mappers.prototype.mul_14dthe$ = function (factor) {\n return Mappers$mul$lambda(factor);\n };\n Mappers.prototype.linear_1jkouz$ = function (domain, range, reverse) {\n if (reverse === void 0)\n reverse = false;\n return this.linear_yl4mmw$(domain, reverse ? range.upperEnd : range.lowerEnd, reverse ? range.lowerEnd : range.upperEnd, kotlin_js_internal_DoubleCompanionObject.NaN);\n };\n Mappers.prototype.linear_lww37m$ = function (domain, range, defaultValue) {\n return this.linear_yl4mmw$(domain, range.lowerEnd, range.upperEnd, defaultValue);\n };\n function Mappers$linear$lambda(closure$slop, closure$intersect, closure$defaultValue) {\n return function (input) {\n return data.SeriesUtil.isFinite_yrwdxb$(input) ? ensureNotNull(input) * closure$slop + closure$intersect : closure$defaultValue;\n };\n }\n Mappers.prototype.linear_yl4mmw$ = function (domain, rangeLow, rangeHigh, defaultValue) {\n var slop = (rangeHigh - rangeLow) / (domain.upperEnd - domain.lowerEnd);\n if (!data.SeriesUtil.isFinite_14dthe$(slop)) {\n var v = (rangeHigh - rangeLow) / 2 + rangeLow;\n return this.constant_14dthe$(v);\n }var intersect = rangeLow - domain.lowerEnd * slop;\n return Mappers$linear$lambda(slop, intersect, defaultValue);\n };\n Mappers.prototype.discreteToContinuous_83ntpg$ = function (domainValues, outputRange, naValue) {\n var tmp$;\n var numberByDomainValue = MapperUtil_getInstance().mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n tmp$ = data.SeriesUtil.range_l63ks6$(numberByDomainValue.values);\n if (tmp$ == null) {\n return this.IDENTITY;\n }var dataRange = tmp$;\n return this.linear_lww37m$(dataRange, outputRange, naValue);\n };\n function Mappers$discrete$lambda(closure$f) {\n return function (it) {\n return closure$f.apply_11rb$(it);\n };\n }\n Mappers.prototype.discrete_rath1t$ = function (outputValues, defaultOutputValue) {\n var f = new Mappers$DiscreteFun(outputValues, defaultOutputValue);\n return Mappers$discrete$lambda(f);\n };\n function Mappers$quantized$lambda(closure$defaultOutputValue) {\n return function (it) {\n return closure$defaultOutputValue;\n };\n }\n function Mappers$quantized$lambda_0(closure$f) {\n return function (it) {\n return closure$f.apply_11rb$(it);\n };\n }\n Mappers.prototype.quantized_hd8s0$ = function (domain, outputValues, defaultOutputValue) {\n if (domain == null) {\n return Mappers$quantized$lambda(defaultOutputValue);\n }var quantizer = new QuantizeScale();\n quantizer.domain_lu1900$(domain.lowerEnd, domain.upperEnd);\n quantizer.range_brywnq$(outputValues);\n var f = new Mappers$QuantizedFun(quantizer, defaultOutputValue);\n return Mappers$quantized$lambda_0(f);\n };\n function Mappers$DiscreteFun(myOutputValues, myDefaultOutputValue) {\n this.myOutputValues_0 = myOutputValues;\n this.myDefaultOutputValue_0 = myDefaultOutputValue;\n }\n Mappers$DiscreteFun.prototype.apply_11rb$ = function (value) {\n if (!data.SeriesUtil.isFinite_yrwdxb$(value)) {\n return this.myDefaultOutputValue_0;\n }var index = numberToInt(round(ensureNotNull(value)));\n index = index % this.myOutputValues_0.size;\n if (index < 0) {\n index = index + this.myOutputValues_0.size | 0;\n }return this.myOutputValues_0.get_za3lpa$(index);\n };\n Mappers$DiscreteFun.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteFun',\n interfaces: [Function]\n };\n function Mappers$QuantizedFun(myQuantizer, myDefaultOutputValue) {\n this.myQuantizer_0 = myQuantizer;\n this.myDefaultOutputValue_0 = myDefaultOutputValue;\n }\n Mappers$QuantizedFun.prototype.apply_11rb$ = function (value) {\n return !data.SeriesUtil.isFinite_yrwdxb$(value) ? this.myDefaultOutputValue_0 : this.myQuantizer_0.quantize_14dthe$(ensureNotNull(value));\n };\n Mappers$QuantizedFun.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuantizedFun',\n interfaces: [Function]\n };\n function Mappers$IDENTITY$lambda(v) {\n return v;\n }\n Mappers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Mappers',\n interfaces: []\n };\n var Mappers_instance = null;\n function Mappers_getInstance() {\n if (Mappers_instance === null) {\n new Mappers();\n }return Mappers_instance;\n }\n function ScaleBreaks(domainValues, transformValues, labels) {\n this.domainValues = ArrayList_init_0(domainValues);\n this.transformValues = ArrayList_init_0(transformValues);\n this.labels = ArrayList_init_0(labels);\n }\n ScaleBreaks.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ScaleBreaks',\n interfaces: []\n };\n function ScaleUtil() {\n ScaleUtil_instance = this;\n }\n function ScaleUtil$labels$lambda(v) {\n return v.toString();\n }\n ScaleUtil.prototype.labels_x4zrm4$ = function (scale) {\n var tmp$;\n if (!scale.hasBreaks()) {\n return emptyList();\n }var breaks = scale.breaks;\n if (scale.hasLabels()) {\n var labels = scale.labels;\n if (breaks.size <= labels.size) {\n return labels.subList_vux9f0$(0, breaks.size);\n }var result = ArrayList_init();\n for (var i = 0; i !== breaks.size; ++i) {\n if (labels.isEmpty()) {\n result.add_11rb$('');\n } else {\n result.add_11rb$(labels.get_za3lpa$(i % labels.size));\n }\n }\n return result;\n }var formatter = (tmp$ = scale.labelFormatter) != null ? tmp$ : ScaleUtil$labels$lambda;\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(formatter(item));\n }\n return destination;\n };\n ScaleUtil.prototype.labelByBreak_x4zrm4$ = function (scale) {\n var result = HashMap_init();\n if (scale.hasBreaks()) {\n var breaks = scale.breaks.iterator();\n var labels = this.labels_x4zrm4$(scale).iterator();\n while (breaks.hasNext() && labels.hasNext()) {\n var key = breaks.next();\n var value = labels.next();\n result.put_xwzc9p$(key, value);\n }\n }return result;\n };\n ScaleUtil.prototype.breaksTransformed_x4zrm4$ = function (scale) {\n var $receiver = scale.transform.apply_9ma18$(scale.breaks);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0;\n destination.add_11rb$(typeof (tmp$_0 = item) === 'number' ? tmp$_0 : throwCCE());\n }\n return destination;\n };\n ScaleUtil.prototype.axisBreaks_2m8kky$ = function (scale, coord, horizontal) {\n var tmp$;\n var scaleBreaks = this.transformAndMap_syim1y$(scale.breaks, scale);\n var axisBreaks = ArrayList_init();\n tmp$ = scaleBreaks.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var mappedBrPoint = horizontal ? new DoubleVector(ensureNotNull(br), 0.0) : new DoubleVector(0.0, ensureNotNull(br));\n var axisBrPoint = coord.toClient_gpjtzr$(mappedBrPoint);\n var axisBr = horizontal ? axisBrPoint.x : axisBrPoint.y;\n axisBreaks.add_11rb$(axisBr);\n if (!isFinite(axisBr)) {\n throw IllegalStateException_init(\"Illegal axis '\" + scale.name + \"' break position \" + toString(axisBr) + ' at index ' + toString(axisBreaks.size - 1 | 0) + '\\nsource breaks : ' + toString(scale.breaks) + '\\ntranslated breaks: ' + toString(scaleBreaks) + '\\naxis breaks : ' + toString(axisBreaks));\n }}\n return axisBreaks;\n };\n ScaleUtil.prototype.map_dp4lfi$ = function (range, scale) {\n return MapperUtil_getInstance().map_rejkqi$(range, scale.mapper);\n };\n ScaleUtil.prototype.map_9ksyxk$ = function (l, scale) {\n var mapper = scale.mapper;\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(mapper(item));\n }\n return destination;\n };\n ScaleUtil.prototype.transformAndMap_syim1y$ = function (l, scale) {\n var cleaned = this.cleanUpTransformSource_2jj1lg$(l, scale);\n var transformed = scale.transform.apply_9ma18$(cleaned);\n return this.map_9ksyxk$(transformed, scale);\n };\n ScaleUtil.prototype.cleanUpTransformSource_2jj1lg$ = function (source, scale) {\n var tmp$;\n var source_0 = source;\n if (scale.hasDomainLimits()) {\n var $receiver = source_0;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item == null || scale.isInDomainLimits_za3rmp$(item) ? item : null);\n }\n source_0 = destination;\n }if (Kotlin.isType(scale.transform, ContinuousTransform)) {\n var continuousTransform = Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE();\n if (continuousTransform.hasDomainLimits()) {\n var $receiver_0 = source_0;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_1;\n tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n var tmp$_2;\n destination_0.add_11rb$(continuousTransform.isInDomain_yrwdxb$((tmp$_2 = item_0) == null || typeof tmp$_2 === 'number' ? tmp$_2 : throwCCE()) ? item_0 : null);\n }\n source_0 = destination_0;\n }}return source_0;\n };\n ScaleUtil.prototype.inverseTransformToContinuousDomain_codrxm$ = function (l, scale) {\n var tmp$;\n if (!scale.isContinuousDomain) {\n var message = 'Not continuous numeric domain: ' + scale;\n throw IllegalStateException_init(message.toString());\n }return (Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE()).applyInverse_k9kaly$(l);\n };\n ScaleUtil.prototype.inverseTransform_codrxm$ = function (l, scale) {\n var tmp$;\n var transform = scale.transform;\n if (Kotlin.isType(transform, ContinuousTransform)) {\n tmp$ = transform.applyInverse_k9kaly$(l);\n } else {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$_0;\n tmp$_0 = l.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(transform.applyInverse_yrwdxb$(item));\n }\n tmp$ = destination;\n }\n return tmp$;\n };\n ScaleUtil.prototype.transformedDefinedLimits_x4zrm4$ = function (scale) {\n var tmp$, tmp$_0;\n var tmp$_1 = scale.domainLimits;\n var lower = tmp$_1.component1()\n , upper = tmp$_1.component2();\n var transform = Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE();\n var tmp$_2 = new Pair_0(transform.isInDomain_yrwdxb$(lower) ? ensureNotNull(transform.apply_yrwdxb$(lower)) : kotlin_js_internal_DoubleCompanionObject.NaN, transform.isInDomain_yrwdxb$(upper) ? ensureNotNull(transform.apply_yrwdxb$(upper)) : kotlin_js_internal_DoubleCompanionObject.NaN);\n var transformedLower = tmp$_2.component1()\n , transformedUpper = tmp$_2.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(transformedLower, transformedUpper)) {\n tmp$_0 = new Pair_0(JsMath.min(transformedLower, transformedUpper), JsMath.max(transformedLower, transformedUpper));\n } else {\n tmp$_0 = new Pair_0(transformedLower, transformedUpper);\n }\n return tmp$_0;\n };\n ScaleUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleUtil',\n interfaces: []\n };\n var ScaleUtil_instance = null;\n function ScaleUtil_getInstance() {\n if (ScaleUtil_instance === null) {\n new ScaleUtil();\n }return ScaleUtil_instance;\n }\n function Scales() {\n Scales_instance = this;\n }\n Scales.prototype.continuousDomain_sqn2xl$ = function (name, aes) {\n return ContinuousScale_init(name, Mappers_getInstance().undefined_287e2$(), aes.isNumeric);\n };\n Scales.prototype.continuousDomainNumericRange_61zpoe$ = function (name) {\n return ContinuousScale_init(name, Mappers_getInstance().undefined_287e2$(), true);\n };\n Scales.prototype.continuousDomain_lo18em$ = function (name, mapper, continuousRange) {\n return ContinuousScale_init(name, mapper, continuousRange);\n };\n Scales.prototype.discreteDomain_uksd38$ = function (name, domainValues) {\n return this.discreteDomain_l9mre7$(name, domainValues, Mappers_getInstance().undefined_287e2$());\n };\n Scales.prototype.discreteDomain_l9mre7$ = function (name, domainValues, mapper) {\n return DiscreteScale_init(name, domainValues, mapper);\n };\n Scales.prototype.pureDiscrete_kiqtr1$ = function (name, domainValues, outputValues, defaultOutputValue) {\n return this.discreteDomain_uksd38$(name, domainValues).with().mapper_1uitho$(Mappers_getInstance().discrete_rath1t$(outputValues, defaultOutputValue)).build();\n };\n Scales.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Scales',\n interfaces: []\n };\n var Scales_instance = null;\n function Scales_getInstance() {\n if (Scales_instance === null) {\n new Scales();\n }return Scales_instance;\n }\n function BreaksHelperBase(start, end, targetCount) {\n this.normalStart = 0;\n this.normalEnd = 0;\n this.span = 0;\n this.targetStep = 0;\n this.isReversed = false;\n if (!isFinite(start)) {\n var message = 'range start ' + start;\n throw IllegalArgumentException_init(message.toString());\n }if (!isFinite(end)) {\n var message_0 = 'range end ' + end;\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(targetCount > 0)) {\n var message_1 = \"'count' must be positive: \" + targetCount;\n throw IllegalArgumentException_init(message_1.toString());\n }var span = end - start;\n var reversed = false;\n if (span < 0) {\n span = -span;\n reversed = true;\n }this.span = span;\n this.targetStep = this.span / targetCount;\n this.isReversed = reversed;\n this.normalStart = reversed ? end : start;\n this.normalEnd = reversed ? start : end;\n }\n BreaksHelperBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreaksHelperBase',\n interfaces: []\n };\n function DateTimeBreaksHelper(rangeStart, rangeEnd, count, minInterval) {\n if (minInterval === void 0)\n minInterval = null;\n BreaksHelperBase.call(this, rangeStart, rangeEnd, count);\n this.breaks_n95hiz$_0 = null;\n this.formatter = null;\n var tmp$;\n var step = this.targetStep;\n if (step < 1000) {\n this.formatter = (new TimeScaleTickFormatterFactory(minInterval)).getFormatter_14dthe$(step);\n this.breaks_n95hiz$_0 = (new LinearBreaksHelper(rangeStart, rangeEnd, count)).breaks;\n } else {\n var start = this.normalStart;\n var end = this.normalEnd;\n var ticks = null;\n if (minInterval != null) {\n ticks = toMutableList(minInterval.range_lu1900$(start, end));\n }if (ticks != null && ticks.size <= count) {\n this.formatter = ensureNotNull(minInterval).tickFormatter;\n } else if (step > YearInterval.Companion.MS) {\n this.formatter = YearInterval.Companion.TICK_FORMATTER;\n ticks = ArrayList_init();\n var startDateTime = time.TimeUtil.asDateTimeUTC_14dthe$(start);\n var startYear = startDateTime.year;\n if (startDateTime.isAfter_amwj4p$(time.TimeUtil.yearStart_za3lpa$(startYear))) {\n startYear = startYear + 1 | 0;\n }var endYear = time.TimeUtil.asDateTimeUTC_14dthe$(end).year;\n var helper = new LinearBreaksHelper(startYear, endYear, count);\n tmp$ = helper.breaks.iterator();\n while (tmp$.hasNext()) {\n var tickYear = tmp$.next();\n var tickDate = time.TimeUtil.yearStart_za3lpa$(numberToInt(round(tickYear)));\n ticks.add_11rb$(time.TimeUtil.asInstantUTC_amwj4p$(tickDate).toNumber());\n }\n } else {\n var interval_0 = interval.NiceTimeInterval.forMillis_14dthe$(step);\n this.formatter = interval_0.tickFormatter;\n ticks = toMutableList(interval_0.range_lu1900$(start, end));\n }\n if (this.isReversed) {\n reverse(ticks);\n }this.breaks_n95hiz$_0 = ticks;\n }\n }\n Object.defineProperty(DateTimeBreaksHelper.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_n95hiz$_0;\n }\n });\n DateTimeBreaksHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTimeBreaksHelper',\n interfaces: [BreaksHelperBase]\n };\n function LinearBreaksHelper(rangeStart, rangeEnd, count, precise) {\n LinearBreaksHelper$Companion_getInstance();\n if (precise === void 0)\n precise = false;\n BreaksHelperBase.call(this, rangeStart, rangeEnd, count);\n this.breaks_egvm9d$_0 = null;\n var tmp$, tmp$_0, tmp$_1;\n if (!(count > 0)) {\n var message = \"Can't compute breaks for count: \" + count;\n throw IllegalStateException_init(message.toString());\n }if (precise) {\n tmp$ = this.targetStep;\n } else {\n tmp$ = LinearBreaksHelper$Companion_getInstance().computeNiceStep_0(this.span, count);\n }\n var step = tmp$;\n if (precise) {\n var $receiver = until(0, count);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_2;\n tmp$_2 = $receiver.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(this.normalStart + step / 2 + item * step);\n }\n tmp$_0 = destination;\n } else {\n tmp$_0 = LinearBreaksHelper$Companion_getInstance().computeNiceBreaks_0(this.normalStart, this.normalEnd, step);\n }\n var breaks = tmp$_0;\n if (breaks.isEmpty()) {\n tmp$_1 = listOf_0(this.normalStart);\n } else if (this.isReversed) {\n tmp$_1 = asReversed(breaks);\n } else {\n tmp$_1 = breaks;\n }\n this.breaks_egvm9d$_0 = tmp$_1;\n }\n Object.defineProperty(LinearBreaksHelper.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_egvm9d$_0;\n }\n });\n function LinearBreaksHelper$Companion() {\n LinearBreaksHelper$Companion_instance = this;\n }\n LinearBreaksHelper$Companion.prototype.computeNiceStep_0 = function (span, count) {\n var tmp$;\n var stepRaw = span / count;\n var x = JsMath.log10(stepRaw);\n var step10Power = JsMath.floor(x);\n var step = JsMath.pow(10.0, step10Power);\n var error = step * count / span;\n if (error <= 0.15)\n tmp$ = step * 10.0;\n else if (error <= 0.35)\n tmp$ = step * 5.0;\n else if (error <= 0.75)\n tmp$ = step * 2.0;\n else\n tmp$ = step;\n return tmp$;\n };\n LinearBreaksHelper$Companion.prototype.computeNiceBreaks_0 = function (start, end, step) {\n if (step === 0.0)\n return emptyList();\n var delta = step / 10000;\n var startE = start - delta;\n var endE = end + delta;\n var breaks = ArrayList_init();\n var x = startE / step;\n var tick = JsMath.ceil(x) * step;\n if (start >= 0 && startE < 0) {\n tick = 0.0;\n }while (tick <= endE) {\n var a = tick;\n tick = JsMath.min(a, end);\n breaks.add_11rb$(tick);\n tick += step;\n }\n return breaks;\n };\n LinearBreaksHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinearBreaksHelper$Companion_instance = null;\n function LinearBreaksHelper$Companion_getInstance() {\n if (LinearBreaksHelper$Companion_instance === null) {\n new LinearBreaksHelper$Companion();\n }return LinearBreaksHelper$Companion_instance;\n }\n LinearBreaksHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearBreaksHelper',\n interfaces: [BreaksHelperBase]\n };\n function NumericBreakFormatter(value, step, allowMetricPrefix) {\n this.formatter_0 = null;\n var tmp$, tmp$_0, tmp$_1;\n if (value === 0.0) {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.MIN_VALUE * 10;\n } else {\n tmp$ = JsMath.abs(value);\n }\n var value_0 = tmp$;\n if (step === 0.0) {\n tmp$_0 = value_0 / 10;\n } else {\n tmp$_0 = JsMath.abs(step);\n }\n var step_0 = tmp$_0;\n var type = 'f';\n var delimiter = '';\n var x = JsMath.abs(value_0);\n var domain10Power = JsMath.log10(x);\n var step10Power = JsMath.log10(step_0);\n var precision = -step10Power;\n var scientificNotation = false;\n if (domain10Power < 0 && step10Power < -4) {\n scientificNotation = true;\n type = 'e';\n precision = domain10Power - step10Power;\n } else if (domain10Power > 7 && step10Power > 2) {\n scientificNotation = true;\n precision = domain10Power - step10Power;\n }if (precision < 0) {\n precision = 0.0;\n type = 'd';\n }var x_0 = precision - 0.001;\n precision = JsMath.ceil(x_0);\n if (scientificNotation) {\n if (domain10Power > 0 && allowMetricPrefix) {\n tmp$_1 = 's';\n } else {\n tmp$_1 = 'e';\n }\n type = tmp$_1;\n } else {\n delimiter = ',';\n }\n this.formatter_0 = NumberFormat_init(delimiter + '.' + numberToInt(precision) + type);\n }\n NumericBreakFormatter.prototype.apply_za3rmp$ = function (value) {\n var tmp$;\n return this.formatter_0.apply_3p81yu$(Kotlin.isNumber(tmp$ = value) ? tmp$ : throwCCE());\n };\n NumericBreakFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumericBreakFormatter',\n interfaces: []\n };\n function QuantizeScale() {\n this.myHasDomain_0 = false;\n this.myDomainStart_0 = 0.0;\n this.myDomainEnd_0 = 0.0;\n this.myOutputValues_9bxfi2$_0 = this.myOutputValues_9bxfi2$_0;\n }\n Object.defineProperty(QuantizeScale.prototype, 'myOutputValues_0', {\n configurable: true,\n get: function () {\n if (this.myOutputValues_9bxfi2$_0 == null)\n return throwUPAE('myOutputValues');\n return this.myOutputValues_9bxfi2$_0;\n },\n set: function (myOutputValues) {\n this.myOutputValues_9bxfi2$_0 = myOutputValues;\n }\n });\n Object.defineProperty(QuantizeScale.prototype, 'outputValues', {\n configurable: true,\n get: function () {\n return this.myOutputValues_0;\n }\n });\n Object.defineProperty(QuantizeScale.prototype, 'domainQuantized', {\n configurable: true,\n get: function () {\n var tmp$;\n if (this.myDomainStart_0 === this.myDomainEnd_0) {\n return listOf_0(new ClosedRange(this.myDomainStart_0, this.myDomainEnd_0));\n }var list = ArrayList_init();\n var numBuckets = this.myOutputValues_0.size;\n var bucketSize = this.bucketSize_0();\n tmp$ = numBuckets - 1 | 0;\n for (var i = 0; i < tmp$; i++) {\n var bucket = new ClosedRange(this.myDomainStart_0 + bucketSize * i, this.myDomainStart_0 + bucketSize * (i + 1 | 0));\n list.add_11rb$(bucket);\n }\n var bucket_0 = new ClosedRange(this.myDomainStart_0 + bucketSize * (numBuckets - 1 | 0), this.myDomainEnd_0);\n list.add_11rb$(bucket_0);\n return list;\n }\n });\n QuantizeScale.prototype.domain_lu1900$ = function (start, end) {\n if (!(start <= end)) {\n var message = 'Domain start must be less then domain end: ' + start + ' > ' + end;\n throw IllegalArgumentException_init(message.toString());\n }this.myHasDomain_0 = true;\n this.myDomainStart_0 = start;\n this.myDomainEnd_0 = end;\n return this;\n };\n QuantizeScale.prototype.range_brywnq$ = function (values) {\n this.myOutputValues_0 = ArrayList_init_0(values);\n return this;\n };\n QuantizeScale.prototype.quantize_14dthe$ = function (v) {\n var i = this.outputIndex_0(v);\n return this.myOutputValues_0.get_za3lpa$(i);\n };\n QuantizeScale.prototype.outputIndex_0 = function (v) {\n if (!this.myHasDomain_0) {\n var message = 'Domain not defined.';\n throw IllegalStateException_init(message.toString());\n }var tmp$ = this.myOutputValues_9bxfi2$_0 != null;\n if (tmp$) {\n tmp$ = !this.myOutputValues_0.isEmpty();\n }if (!tmp$) {\n var message_0 = 'Output values are not defined.';\n throw IllegalStateException_init(message_0.toString());\n }var bucketSize = this.bucketSize_0();\n var index = numberToInt((v - this.myDomainStart_0) / bucketSize);\n var maxIndex = this.myOutputValues_0.size - 1 | 0;\n var b = JsMath.min(maxIndex, index);\n return JsMath.max(0, b);\n };\n QuantizeScale.prototype.getOutputValueIndex_za3rmp$ = function (domainValue) {\n var tmp$;\n if (Kotlin.isNumber(domainValue)) {\n tmp$ = this.outputIndex_0(numberToDouble(domainValue));\n } else\n tmp$ = -1;\n return tmp$;\n };\n QuantizeScale.prototype.getOutputValue_za3rmp$ = function (domainValue) {\n var tmp$;\n if (Kotlin.isNumber(domainValue)) {\n tmp$ = this.quantize_14dthe$(numberToDouble(domainValue));\n } else\n tmp$ = null;\n return tmp$;\n };\n QuantizeScale.prototype.bucketSize_0 = function () {\n return (this.myDomainEnd_0 - this.myDomainStart_0) / this.myOutputValues_0.size;\n };\n QuantizeScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuantizeScale',\n interfaces: [WithFiniteOrderedOutput]\n };\n function ScaleBreaksUtil() {\n ScaleBreaksUtil_instance = this;\n }\n ScaleBreaksUtil.prototype.withBreaks_qt1l9m$ = function (scale, transformedDomain, breakCount) {\n var scaleBreaks = scale.breaksGenerator.generateBreaks_1tlvto$(transformedDomain, breakCount);\n var breaks = scaleBreaks.domainValues;\n var labels = scaleBreaks.labels;\n return scale.with().breaks_pqjuzw$(breaks).labels_mhpeer$(labels).build();\n };\n ScaleBreaksUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleBreaksUtil',\n interfaces: []\n };\n var ScaleBreaksUtil_instance = null;\n function ScaleBreaksUtil_getInstance() {\n if (ScaleBreaksUtil_instance === null) {\n new ScaleBreaksUtil();\n }return ScaleBreaksUtil_instance;\n }\n function TimeScaleTickFormatterFactory(minInterval) {\n this.minInterval_0 = minInterval;\n }\n TimeScaleTickFormatterFactory.prototype.getFormatter_14dthe$ = function (step) {\n return text.Formatter.time_61zpoe$(this.formatPattern_0(step));\n };\n TimeScaleTickFormatterFactory.prototype.formatPattern_0 = function (step) {\n if (step < 1000) {\n return TimeInterval.Companion.milliseconds_za3lpa$(1).tickFormatPattern;\n }if (this.minInterval_0 != null) {\n var stepCount = 100;\n var start = 0.0;\n var end = step * stepCount;\n var intervalCount = this.minInterval_0.range_lu1900$(start, end).size;\n if (stepCount >= intervalCount) {\n return this.minInterval_0.tickFormatPattern;\n }}if (step > YearInterval.Companion.MS) {\n return YearInterval.Companion.TICK_FORMAT;\n }var interval_0 = interval.NiceTimeInterval.forMillis_14dthe$(step);\n return interval_0.tickFormatPattern;\n };\n TimeScaleTickFormatterFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeScaleTickFormatterFactory',\n interfaces: []\n };\n function WithFiniteOrderedOutput() {\n }\n WithFiniteOrderedOutput.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WithFiniteOrderedOutput',\n interfaces: []\n };\n function DateTimeBreaksGen(labelFormatter) {\n if (labelFormatter === void 0)\n labelFormatter = null;\n this.labelFormatter_0 = labelFormatter;\n }\n DateTimeBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$, tmp$_0;\n var helper = this.breaksHelper_0(domain, targetCount);\n var ticks = helper.breaks;\n var labelFormatter = (tmp$ = this.labelFormatter_0) != null ? tmp$ : helper.formatter;\n var labels = ArrayList_init();\n tmp$_0 = ticks.iterator();\n while (tmp$_0.hasNext()) {\n var tick = tmp$_0.next();\n labels.add_11rb$(labelFormatter(tick));\n }\n return new ScaleBreaks(ticks, ticks, labels);\n };\n DateTimeBreaksGen.prototype.breaksHelper_0 = function (domainAfterTransform, targetCount) {\n return new DateTimeBreaksHelper(domainAfterTransform.lowerEnd, domainAfterTransform.upperEnd, targetCount);\n };\n DateTimeBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.labelFormatter_0) != null ? tmp$ : this.breaksHelper_0(domain, targetCount).formatter;\n };\n DateTimeBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTimeBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function FunTransform(transformFun, inverseFun) {\n this.transformFun_vpw6mq$_0 = transformFun;\n this.inverseFun_2rsie$_0 = inverseFun;\n }\n FunTransform.prototype.apply_yrwdxb$ = function (v) {\n var tmp$;\n if (v != null) {\n tmp$ = this.transformFun_vpw6mq$_0(v);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n FunTransform.prototype.apply_9ma18$ = function (l) {\n var $receiver = this.safeCastToDoubles_9ma18$(l);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.apply_yrwdxb$(item));\n }\n return destination;\n };\n FunTransform.prototype.applyInverse_yrwdxb$ = function (v) {\n var tmp$;\n if (v != null) {\n tmp$ = this.inverseFun_2rsie$_0(v);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n FunTransform.prototype.applyInverse_k9kaly$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.applyInverse_yrwdxb$(item));\n }\n return destination;\n };\n FunTransform.prototype.safeCastToDoubles_9ma18$ = function (list) {\n var checkedDoubles = data.SeriesUtil.checkedDoubles_9ma18$(list);\n if (!checkedDoubles.canBeCast()) {\n var message = 'Not a collections of Double(s)';\n throw IllegalArgumentException_init(message.toString());\n }return checkedDoubles.cast();\n };\n FunTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FunTransform',\n interfaces: [ContinuousTransform]\n };\n function IdentityTransform() {\n FunTransform.call(this, IdentityTransform_init$lambda, IdentityTransform_init$lambda_0);\n }\n IdentityTransform.prototype.hasDomainLimits = function () {\n return false;\n };\n IdentityTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v);\n };\n IdentityTransform.prototype.createApplicableDomain_14dthe$ = function (middle) {\n var middle_0 = isFinite(middle) ? middle : 0.0;\n return new ClosedRange(middle_0 - 0.5, middle_0 + 0.5);\n };\n IdentityTransform.prototype.apply_9ma18$ = function (l) {\n return this.safeCastToDoubles_9ma18$(l);\n };\n IdentityTransform.prototype.applyInverse_k9kaly$ = function (l) {\n return l;\n };\n function IdentityTransform_init$lambda(v) {\n return v;\n }\n function IdentityTransform_init$lambda_0(v) {\n return v;\n }\n IdentityTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityTransform',\n interfaces: [FunTransform]\n };\n function LinearBreaksGen(formatter) {\n LinearBreaksGen$Companion_getInstance();\n if (formatter === void 0)\n formatter = null;\n this.formatter_0 = formatter;\n }\n LinearBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n var breaks = LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(domain, targetCount);\n var fmt = (tmp$ = this.formatter_0) != null ? tmp$ : LinearBreaksGen$Companion_getInstance().createFormatter_0(breaks);\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(fmt(item));\n }\n var labels = destination;\n return new ScaleBreaks(breaks, breaks, labels);\n };\n LinearBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.formatter_0) != null ? tmp$ : LinearBreaksGen$Companion_getInstance().createFormatter_0(LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(domain, targetCount));\n };\n function LinearBreaksGen$Companion() {\n LinearBreaksGen$Companion_instance = this;\n }\n LinearBreaksGen$Companion.prototype.generateBreakValues_omwdpb$ = function (domain, targetCount) {\n var helper = new LinearBreaksHelper(domain.lowerEnd, domain.upperEnd, targetCount);\n return helper.breaks;\n };\n LinearBreaksGen$Companion.prototype.createFormatter_0 = function (breakValues) {\n var tmp$, tmp$_0;\n if (breakValues.isEmpty())\n tmp$_0 = new Pair_0(0.0, 0.5);\n else {\n var x = first(breakValues);\n var tmp$_1 = JsMath.abs(x);\n var x_0 = last(breakValues);\n var b = JsMath.abs(x_0);\n var v = JsMath.max(tmp$_1, b);\n if (breakValues.size === 1)\n tmp$ = v / 10;\n else {\n var x_1 = breakValues.get_za3lpa$(1) - breakValues.get_za3lpa$(0);\n tmp$ = JsMath.abs(x_1);\n }\n var s = tmp$;\n tmp$_0 = new Pair_0(v, s);\n }\n var tmp$_2 = tmp$_0;\n var referenceValue = tmp$_2.component1()\n , step = tmp$_2.component2();\n var formatter = new NumericBreakFormatter(referenceValue, step, true);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, formatter));\n };\n LinearBreaksGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinearBreaksGen$Companion_instance = null;\n function LinearBreaksGen$Companion_getInstance() {\n if (LinearBreaksGen$Companion_instance === null) {\n new LinearBreaksGen$Companion();\n }return LinearBreaksGen$Companion_instance;\n }\n LinearBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function Log10Transform() {\n Log10Transform$Companion_getInstance();\n FunTransform.call(this, Log10Transform_init$lambda, Log10Transform_init$lambda_0);\n }\n Log10Transform.prototype.hasDomainLimits = function () {\n return true;\n };\n Log10Transform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v) && ensureNotNull(v) >= 0.0;\n };\n Log10Transform.prototype.apply_yrwdxb$ = function (v) {\n return Log10Transform$Companion_getInstance().trimInfinity_0(FunTransform.prototype.apply_yrwdxb$.call(this, v));\n };\n Log10Transform.prototype.applyInverse_yrwdxb$ = function (v) {\n return FunTransform.prototype.applyInverse_yrwdxb$.call(this, v);\n };\n Log10Transform.prototype.createApplicableDomain_14dthe$ = function (middle) {\n var tmp$;\n if (this.isInDomain_yrwdxb$(middle))\n tmp$ = middle;\n else\n tmp$ = 0.0;\n var middle_0 = tmp$;\n var lower = middle_0 / 2;\n var upper = middle_0 === 0.0 ? 10.0 : middle_0 * 2;\n return new ClosedRange(lower, upper);\n };\n function Log10Transform$Companion() {\n Log10Transform$Companion_instance = this;\n this.LOWER_LIM_8be2vx$ = -kotlin_js_internal_DoubleCompanionObject.MAX_VALUE / 10;\n }\n Log10Transform$Companion.prototype.trimInfinity_0 = function (v) {\n var tmp$;\n if (v == null)\n tmp$ = null;\n else if (isNaN_0(v))\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n else {\n var a = this.LOWER_LIM_8be2vx$;\n tmp$ = JsMath.max(a, v);\n }\n return tmp$;\n };\n Log10Transform$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Log10Transform$Companion_instance = null;\n function Log10Transform$Companion_getInstance() {\n if (Log10Transform$Companion_instance === null) {\n new Log10Transform$Companion();\n }return Log10Transform$Companion_instance;\n }\n function Log10Transform_init$lambda(v) {\n return JsMath.log10(v);\n }\n function Log10Transform_init$lambda_0(v) {\n return JsMath.pow(10.0, v);\n }\n Log10Transform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Log10Transform',\n interfaces: [FunTransform]\n };\n function NonlinearBreaksGen(transform, formatter) {\n NonlinearBreaksGen$Companion_getInstance();\n if (formatter === void 0)\n formatter = null;\n this.transform_0 = transform;\n this.formatter_0 = formatter;\n }\n NonlinearBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n var breakValues = NonlinearBreaksGen$Companion_getInstance().generateBreakValues_0(domain, targetCount, this.transform_0);\n if (this.formatter_0 != null) {\n var size = breakValues.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(this.formatter_0);\n }\n tmp$ = list;\n } else {\n tmp$ = NonlinearBreaksGen$Companion_getInstance().createFormatters_0(breakValues);\n }\n var breakFormatters = tmp$;\n var destination = ArrayList_init_1(collectionSizeOrDefault(breakValues, 10));\n var tmp$_0, tmp$_0_0;\n var index_0 = 0;\n tmp$_0 = breakValues.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(breakFormatters.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index_0, index_0 = tmp$_0_0 + 1 | 0, tmp$_0_0)))(item));\n }\n var labels = destination;\n return new ScaleBreaks(breakValues, breakValues, labels);\n };\n NonlinearBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.formatter_0) != null ? tmp$ : NonlinearBreaksGen$Companion_getInstance().createMultiFormatter_0(NonlinearBreaksGen$Companion_getInstance().generateBreakValues_0(domain, targetCount, this.transform_0));\n };\n function NonlinearBreaksGen$Companion() {\n NonlinearBreaksGen$Companion_instance = this;\n }\n function NonlinearBreaksGen$Companion$generateBreakValues$lambda(closure$transform) {\n return function (it) {\n return closure$transform.apply_yrwdxb$(it);\n };\n }\n NonlinearBreaksGen$Companion.prototype.generateBreakValues_0 = function (domain, targetCount, transform) {\n var transformedDomain = MapperUtil_getInstance().map_rejkqi$(domain, NonlinearBreaksGen$Companion$generateBreakValues$lambda(transform));\n var transformedBreakValues = LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(transformedDomain, targetCount);\n return filterNotNull(transform.applyInverse_k9kaly$(transformedBreakValues));\n };\n NonlinearBreaksGen$Companion.prototype.createMultiFormatter_0 = function (breakValues) {\n var breakFormatters = this.createFormatters_0(breakValues);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, new NonlinearBreaksGen$MultiFormatter(breakValues, breakFormatters)));\n };\n NonlinearBreaksGen$Companion.prototype.createFormatters_0 = function (breakValues) {\n if (breakValues.isEmpty())\n return emptyList();\n if (breakValues.size === 1) {\n var domainValue = breakValues.get_za3lpa$(0);\n var step = domainValue / 10;\n return listOf_0(this.createFormatter_0(domainValue, step));\n }var destination = ArrayList_init_1(collectionSizeOrDefault(breakValues, 10));\n var tmp$, tmp$_0;\n var index = 0;\n tmp$ = breakValues.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_1 = destination.add_11rb$;\n var i = checkIndexOverflow((tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0));\n var tmp$_2;\n if (i === 0)\n tmp$_2 = item - breakValues.get_za3lpa$(i + 1 | 0);\n else\n tmp$_2 = item - breakValues.get_za3lpa$(i - 1 | 0);\n var x = tmp$_2;\n var step_0 = JsMath.abs(x);\n tmp$_1.call(destination, this.createFormatter_0(item, step_0));\n }\n var formatters = destination;\n return formatters;\n };\n NonlinearBreaksGen$Companion.prototype.createFormatter_0 = function (domainValue, step) {\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, new NumericBreakFormatter(domainValue, step, true)));\n };\n NonlinearBreaksGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NonlinearBreaksGen$Companion_instance = null;\n function NonlinearBreaksGen$Companion_getInstance() {\n if (NonlinearBreaksGen$Companion_instance === null) {\n new NonlinearBreaksGen$Companion();\n }return NonlinearBreaksGen$Companion_instance;\n }\n function NonlinearBreaksGen$MultiFormatter(breakValues, breakFormatters) {\n this.breakValues = breakValues;\n this.breakFormatters = breakFormatters;\n if (!(this.breakValues.size === this.breakFormatters.size)) {\n var message = 'MultiFormatter: breakValues.size=' + this.breakValues.size + ' but breakFormatters.size=' + this.breakFormatters.size;\n throw IllegalStateException_init(message.toString());\n }if (this.breakValues.size > 1) {\n var $receiver = this.breakValues;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$, tmp$_0;\n var index = 0;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_1 = destination.add_11rb$;\n var i = checkIndexOverflow((tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0));\n tmp$_1.call(destination, i === 0 ? 0.0 : item - this.breakValues.get_za3lpa$(i - 1 | 0));\n }\n var all$result;\n all$break: do {\n var tmp$_2;\n if (Kotlin.isType(destination, Collection) && destination.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (!(element >= 0.0)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n var ordered = all$result;\n if (!ordered) {\n var message_0 = 'MultiFormatter: values must be sorted in ascending order. Were: ' + this.breakValues + '.';\n throw IllegalStateException_init(message_0.toString());\n }}}\n NonlinearBreaksGen$MultiFormatter.prototype.apply_za3rmp$ = function (v) {\n var tmp$, tmp$_0;\n typeof (tmp$ = v) === 'number' ? tmp$ : throwCCE();\n if (this.breakValues.isEmpty())\n tmp$_0 = v.toString();\n else {\n var i = abs(binarySearch(this.breakValues, v));\n var b = this.breakValues.size - 1 | 0;\n var ii = JsMath.min(i, b);\n tmp$_0 = this.breakFormatters.get_za3lpa$(ii)(v);\n }\n return tmp$_0;\n };\n NonlinearBreaksGen$MultiFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiFormatter',\n interfaces: []\n };\n NonlinearBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NonlinearBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function ReverseTransform() {\n FunTransform.call(this, ReverseTransform_init$lambda, ReverseTransform_init$lambda_0);\n }\n ReverseTransform.prototype.hasDomainLimits = function () {\n return false;\n };\n ReverseTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v);\n };\n ReverseTransform.prototype.createApplicableDomain_14dthe$ = function (middle) {\n var middle_0 = isFinite(middle) ? middle : 0.0;\n return new ClosedRange(middle_0 - 0.5, middle_0 + 0.5);\n };\n function ReverseTransform_init$lambda(v) {\n return -v;\n }\n function ReverseTransform_init$lambda_0(v) {\n return -v;\n }\n ReverseTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ReverseTransform',\n interfaces: [FunTransform]\n };\n function SqrtTransform() {\n FunTransform.call(this, SqrtTransform_init$lambda, SqrtTransform_init$lambda_0);\n }\n SqrtTransform.prototype.hasDomainLimits = function () {\n return true;\n };\n SqrtTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v) && ensureNotNull(v) >= 0.0;\n };\n SqrtTransform.prototype.createApplicableDomain_14dthe$ = function (middle) {\n var tmp$;\n if (this.isInDomain_yrwdxb$(middle))\n tmp$ = middle;\n else\n tmp$ = 0.0;\n var middle_0 = tmp$;\n var a = middle_0 - 0.5;\n var lower = JsMath.max(a, 0.0);\n return new ClosedRange(lower, lower + 1.0);\n };\n function SqrtTransform_init$lambda(v) {\n return JsMath.sqrt(v);\n }\n function SqrtTransform_init$lambda_0(v) {\n return v * v;\n }\n SqrtTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SqrtTransform',\n interfaces: [FunTransform]\n };\n function Transforms() {\n Transforms_instance = this;\n this.IDENTITY = new IdentityTransform();\n this.REVERSE = new ReverseTransform();\n this.SQRT = new SqrtTransform();\n this.LOG10 = new Log10Transform();\n }\n Transforms.prototype.createBreaksGeneratorForTransformedDomain_5x42z5$ = function (transform, labelFormatter) {\n if (labelFormatter === void 0)\n labelFormatter = null;\n var tmp$;\n if (equals(transform, this.IDENTITY))\n tmp$ = new LinearBreaksGen(labelFormatter);\n else if (equals(transform, this.REVERSE))\n tmp$ = new LinearBreaksGen(labelFormatter);\n else if (equals(transform, this.SQRT))\n tmp$ = new NonlinearBreaksGen(this.SQRT, labelFormatter);\n else if (equals(transform, this.LOG10))\n tmp$ = new NonlinearBreaksGen(this.LOG10, labelFormatter);\n else\n throw IllegalStateException_init(\"Unexpected 'transform' type: \" + toString(Kotlin.getKClassFromExpression(transform).simpleName));\n var breaksGenerator = tmp$;\n return new Transforms$BreaksGeneratorForTransformedDomain(transform, breaksGenerator);\n };\n function Transforms$BreaksGeneratorForTransformedDomain(transform, breaksGenerator) {\n this.transform_0 = transform;\n this.breaksGenerator = breaksGenerator;\n }\n function Transforms$BreaksGeneratorForTransformedDomain$labelFormatter$lambda(this$BreaksGeneratorForTransformedDomain) {\n return function (it) {\n return this$BreaksGeneratorForTransformedDomain.transform_0.applyInverse_yrwdxb$(it);\n };\n }\n Transforms$BreaksGeneratorForTransformedDomain.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var domainBeforeTransform = MapperUtil_getInstance().map_rejkqi$(domain, Transforms$BreaksGeneratorForTransformedDomain$labelFormatter$lambda(this));\n return this.breaksGenerator.labelFormatter_1tlvto$(domainBeforeTransform, targetCount);\n };\n function Transforms$BreaksGeneratorForTransformedDomain$generateBreaks$lambda(this$BreaksGeneratorForTransformedDomain) {\n return function (it) {\n return this$BreaksGeneratorForTransformedDomain.transform_0.applyInverse_yrwdxb$(it);\n };\n }\n Transforms$BreaksGeneratorForTransformedDomain.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var domainBeforeTransform = MapperUtil_getInstance().map_rejkqi$(domain, Transforms$BreaksGeneratorForTransformedDomain$generateBreaks$lambda(this));\n var scaleBreaks = this.breaksGenerator.generateBreaks_1tlvto$(domainBeforeTransform, targetCount);\n var originalBreaks = scaleBreaks.domainValues;\n var $receiver = this.transform_0.apply_9ma18$(originalBreaks);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0;\n destination.add_11rb$(typeof (tmp$_0 = item) === 'number' ? tmp$_0 : throwCCE());\n }\n var transformedBreaks = destination;\n return new ScaleBreaks(originalBreaks, transformedBreaks, scaleBreaks.labels);\n };\n Transforms$BreaksGeneratorForTransformedDomain.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreaksGeneratorForTransformedDomain',\n interfaces: [BreaksGenerator]\n };\n Transforms.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Transforms',\n interfaces: []\n };\n var Transforms_instance = null;\n function Transforms_getInstance() {\n if (Transforms_instance === null) {\n new Transforms();\n }return Transforms_instance;\n }\n function AbstractDensity2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat$Companion_getInstance();\n BaseStat.call(this, AbstractDensity2dStat$Companion_getInstance().DEF_MAPPING_0);\n this.bandWidthX_pmqi0t$_0 = bandWidthX;\n this.bandWidthY_pmqi1o$_0 = bandWidthY;\n this.bandWidthMethod_3lcf4y$_0 = bandWidthMethod;\n this.adjust = adjust;\n this.kernel_ba223r$_0 = kernel;\n this.nX = nX;\n this.nY = nY;\n this.isContour = isContour;\n this.binCount_6z2ebo$_0 = binCount;\n this.binWidth_2e8jdx$_0 = binWidth;\n this.kernelFun = DensityStatUtil_getInstance().kernel_uyf859$(this.kernel_ba223r$_0);\n this.binOptions = new BinStatUtil$BinOptions(this.binCount_6z2ebo$_0, this.binWidth_2e8jdx$_0);\n if (!(this.nX <= 999)) {\n var message = 'The input nX = ' + this.nX + ' > ' + '999' + ' is too large!';\n throw IllegalArgumentException_init(message.toString());\n }if (!(this.nY <= 999)) {\n var message_0 = 'The input nY = ' + this.nY + ' > ' + '999' + ' is too large!';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n AbstractDensity2dStat.prototype.getBandWidthX_k9kaly$ = function (xs) {\n var tmp$;\n return (tmp$ = this.bandWidthX_pmqi0t$_0) != null ? tmp$ : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0, xs);\n };\n AbstractDensity2dStat.prototype.getBandWidthY_k9kaly$ = function (ys) {\n var tmp$;\n return (tmp$ = this.bandWidthY_pmqi1o$_0) != null ? tmp$ : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0, ys);\n };\n AbstractDensity2dStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WEIGHT]);\n };\n AbstractDensity2dStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n throw IllegalStateException_init(\"'density2d' statistic can't be executed on the client side\");\n };\n function AbstractDensity2dStat$Companion() {\n AbstractDensity2dStat$Companion_instance = this;\n this.DEF_KERNEL = DensityStat$Kernel$GAUSSIAN_getInstance();\n this.DEF_ADJUST = 1.0;\n this.DEF_N = 100;\n this.DEF_BW = DensityStat$BandWidthMethod$NRD0_getInstance();\n this.DEF_CONTOUR = true;\n this.DEF_BIN_COUNT = 10;\n this.DEF_BIN_WIDTH = 0.0;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n this.MAX_N_0 = 999;\n }\n AbstractDensity2dStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractDensity2dStat$Companion_instance = null;\n function AbstractDensity2dStat$Companion_getInstance() {\n if (AbstractDensity2dStat$Companion_instance === null) {\n new AbstractDensity2dStat$Companion();\n }return AbstractDensity2dStat$Companion_instance;\n }\n AbstractDensity2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractDensity2dStat',\n interfaces: [BaseStat]\n };\n function BaseStat(defaultMappings) {\n this.defaultMappings_lvkmi1$_0 = defaultMappings;\n }\n BaseStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return this.defaultMappings_lvkmi1$_0.containsKey_11rb$(aes);\n };\n BaseStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n if (this.defaultMappings_lvkmi1$_0.containsKey_11rb$(aes)) {\n return ensureNotNull(this.defaultMappings_lvkmi1$_0.get_11rb$(aes));\n }throw IllegalArgumentException_init('Stat ' + Kotlin.getKClassFromExpression(this).simpleName + ' has no default mapping for aes: ' + toString(aes));\n };\n BaseStat.prototype.hasRequiredValues_xht41f$ = function (data, aes) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== aes.length; ++tmp$) {\n var requiredAes = aes[tmp$];\n var variable = TransformVar_getInstance().forAes_896ixz$(requiredAes);\n if (data.hasNoOrEmpty_8xm3sj$(variable)) {\n return false;\n }}\n return true;\n };\n BaseStat.prototype.withEmptyStatValues = function () {\n var tmp$;\n var newData = DataFrame$DataFrame$Builder_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (this.hasDefaultMapping_896ixz$(aes)) {\n newData.put_2l962d$(this.getDefaultMapping_896ixz$(aes), emptyList());\n }}\n return newData.build();\n };\n BaseStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseStat',\n interfaces: [Stat]\n };\n function Bin2dStat(binCountX, binCountY, binWidthX, binWidthY, drop) {\n Bin2dStat$Companion_getInstance();\n if (binCountX === void 0)\n binCountX = 30;\n if (binCountY === void 0)\n binCountY = 30;\n if (binWidthX === void 0)\n binWidthX = Bin2dStat$Companion_getInstance().DEF_BINWIDTH;\n if (binWidthY === void 0)\n binWidthY = Bin2dStat$Companion_getInstance().DEF_BINWIDTH;\n if (drop === void 0)\n drop = Bin2dStat$Companion_getInstance().DEF_DROP;\n BaseStat.call(this, Bin2dStat$Companion_getInstance().DEF_MAPPING_0);\n this.drop_0 = drop;\n this.binOptionsX_0 = new BinStatUtil$BinOptions(binCountX, binWidthX);\n this.binOptionsY_0 = new BinStatUtil$BinOptions(binCountY, binWidthY);\n }\n Bin2dStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WEIGHT]);\n };\n Bin2dStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n if (xRange == null || yRange == null) {\n return this.withEmptyStatValues();\n }var xRangeInit = Bin2dStat$Companion_getInstance().adjustRangeInitial_0(xRange);\n var yRangeInit = Bin2dStat$Companion_getInstance().adjustRangeInitial_0(yRange);\n var xCountAndWidthInit = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(xRangeInit), this.binOptionsX_0);\n var yCountAndWidthInit = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(yRangeInit), this.binOptionsY_0);\n var xRangeFinal = Bin2dStat$Companion_getInstance().adjustRangeFinal_0(xRange, xCountAndWidthInit.width);\n var yRangeFinal = Bin2dStat$Companion_getInstance().adjustRangeFinal_0(yRange, yCountAndWidthInit.width);\n var xCountAndWidthFinal = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(xRangeFinal), this.binOptionsX_0);\n var yCountAndWidthFinal = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(yRangeFinal), this.binOptionsY_0);\n var countTotal = Kotlin.imul(xCountAndWidthFinal.count, yCountAndWidthFinal.count);\n var densityNormalizingFactor = Bin2dStat$Companion_getInstance().densityNormalizingFactor_0(data.SeriesUtil.span_4fzjta$(xRangeFinal), data.SeriesUtil.span_4fzjta$(yRangeFinal), countTotal);\n var binsData = this.computeBins_0(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X), data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y), xRangeFinal.lowerEnd, yRangeFinal.lowerEnd, xCountAndWidthFinal.count, yCountAndWidthFinal.count, xCountAndWidthFinal.width, yCountAndWidthFinal.width, BinStatUtil_getInstance().weightAtIndex_dhhkv7$(data_0), densityNormalizingFactor);\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, binsData.x_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().Y, binsData.y_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().COUNT, binsData.count_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, binsData.density_8be2vx$).build();\n };\n Bin2dStat.prototype.computeBins_0 = function (xValues, yValues, xStart, yStart, binCountX, binCountY, binWidth, binHeight, weightAtIndex, densityNormalizingFactor) {\n var totalCount = 0.0;\n var countByBinIndexKey = HashMap_init();\n for (var dataIndex = 0; dataIndex !== xValues.size; ++dataIndex) {\n var x = xValues.get_za3lpa$(dataIndex);\n var y = yValues.get_za3lpa$(dataIndex);\n if (!data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n continue;\n }var weight = weightAtIndex(dataIndex);\n totalCount += weight;\n var x_0 = (ensureNotNull(x) - xStart) / binWidth;\n var binIndexX = numberToInt(JsMath.floor(x_0));\n var x_1 = (ensureNotNull(y) - yStart) / binHeight;\n var binIndexY = numberToInt(JsMath.floor(x_1));\n var binIndexKey = new Pair_0(binIndexX, binIndexY);\n if (!countByBinIndexKey.containsKey_11rb$(binIndexKey)) {\n var value = new MutableDouble(0.0);\n countByBinIndexKey.put_xwzc9p$(binIndexKey, value);\n }ensureNotNull(countByBinIndexKey.get_11rb$(binIndexKey)).getAndAdd_14dthe$(weight);\n }\n var xs = ArrayList_init();\n var ys = ArrayList_init();\n var counts = ArrayList_init();\n var densities = ArrayList_init();\n var x0 = xStart + binWidth / 2;\n var y0 = yStart + binHeight / 2;\n for (var xIndex = 0; xIndex < binCountX; xIndex++) {\n for (var yIndex = 0; yIndex < binCountY; yIndex++) {\n var binIndexKey_0 = new Pair_0(xIndex, yIndex);\n var count = 0.0;\n if (countByBinIndexKey.containsKey_11rb$(binIndexKey_0)) {\n count = ensureNotNull(countByBinIndexKey.get_11rb$(binIndexKey_0)).get();\n }if (this.drop_0 && count === 0.0) {\n continue;\n }xs.add_11rb$(x0 + xIndex * binWidth);\n ys.add_11rb$(y0 + yIndex * binHeight);\n counts.add_11rb$(count);\n var density = count / totalCount * densityNormalizingFactor;\n densities.add_11rb$(density);\n }\n }\n return new Bin2dStat$Bins2dData(xs, ys, counts, densities);\n };\n function Bin2dStat$Companion() {\n Bin2dStat$Companion_instance = this;\n this.DEF_BINS = 30;\n this.DEF_BINWIDTH = null;\n this.DEF_DROP = true;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().FILL, Stats_getInstance().COUNT)]);\n }\n Bin2dStat$Companion.prototype.adjustRangeInitial_0 = function (r) {\n return data.SeriesUtil.ensureApplicableRange_4am1sd$(r);\n };\n Bin2dStat$Companion.prototype.adjustRangeFinal_0 = function (r, binWidth) {\n var tmp$;\n if (data.SeriesUtil.isSubTiny_4fzjta$(r)) {\n tmp$ = data.SeriesUtil.expand_wws5xy$(r, 0.5, 0.5);\n } else {\n var exp = binWidth / 2.0;\n tmp$ = data.SeriesUtil.expand_wws5xy$(r, exp, exp);\n }\n return tmp$;\n };\n Bin2dStat$Companion.prototype.densityNormalizingFactor_0 = function (xSpan, ySpan, count) {\n var area = xSpan * ySpan;\n var binArea = area / count;\n return 1.0 / binArea;\n };\n Bin2dStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Bin2dStat$Companion_instance = null;\n function Bin2dStat$Companion_getInstance() {\n if (Bin2dStat$Companion_instance === null) {\n new Bin2dStat$Companion();\n }return Bin2dStat$Companion_instance;\n }\n function Bin2dStat$Bins2dData(x, y, count, density) {\n this.x_8be2vx$ = x;\n this.y_8be2vx$ = y;\n this.count_8be2vx$ = count;\n this.density_8be2vx$ = density;\n }\n Bin2dStat$Bins2dData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bins2dData',\n interfaces: []\n };\n function Bin2dStat$Bins2dWeightedCounts(total, countByBinXY) {\n this.total_8be2vx$ = total;\n this.countByBinXY_8be2vx$ = countByBinXY;\n }\n Bin2dStat$Bins2dWeightedCounts.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bins2dWeightedCounts',\n interfaces: []\n };\n Bin2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bin2dStat',\n interfaces: [BaseStat]\n };\n function BinStat(binCount, binWidth, xPosKind, xPos) {\n BinStat$Companion_getInstance();\n BaseStat.call(this, BinStat$Companion_getInstance().DEF_MAPPING_0);\n this.xPosKind_0 = xPosKind;\n this.xPos_0 = xPos;\n this.binOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n BinStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n BinStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var statX = ArrayList_init();\n var statCount = ArrayList_init();\n var statDensity = ArrayList_init();\n var rangeX = statCtx.overallXRange();\n if (rangeX != null) {\n var binsData = this.computeStatSeries_0(data, rangeX, data.getNumeric_8xm3sj$(TransformVar_getInstance().X));\n statX.addAll_brywnq$(binsData.x_8be2vx$);\n statCount.addAll_brywnq$(binsData.count_8be2vx$);\n statDensity.addAll_brywnq$(binsData.density_8be2vx$);\n }return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n };\n BinStat.prototype.computeStatSeries_0 = function (data_0, rangeX, valuesX) {\n var startX = rangeX.lowerEnd;\n var spanX = rangeX.upperEnd - ensureNotNull(startX);\n var b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(spanX, this.binOptions_0);\n startX -= b.width * 0.7;\n spanX += b.width * 1.4;\n b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(spanX, this.binOptions_0);\n var binCount = b.count;\n var binWidth = b.width;\n if (this.xPosKind_0 !== BinStat$XPosKind$NONE_getInstance()) {\n var minDelta = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n var x = this.xPos_0;\n for (var i = 0; i < binCount; i++) {\n var binLeft = startX + i * binWidth;\n var delta;\n if (this.xPosKind_0 === BinStat$XPosKind$CENTER_getInstance()) {\n delta = x - (binLeft + binWidth / 2);\n } else {\n if (i === 0) {\n minDelta = x - startX;\n }delta = x - (binLeft + binWidth);\n }\n var x_0 = delta;\n var tmp$ = JsMath.abs(x_0);\n var x_1 = minDelta;\n if (tmp$ < JsMath.abs(x_1)) {\n minDelta = delta;\n }}\n var offset = minDelta % (binWidth / 2);\n startX += offset;\n }var normalBinWidth = data.SeriesUtil.span_4fzjta$(rangeX) / binCount;\n var densityNormalizingFactor = normalBinWidth > 0 ? 1.0 / normalBinWidth : 1.0;\n var binsData = BinStatUtil_getInstance().computeBins_3oz8yg$(valuesX, startX, binCount, binWidth, BinStatUtil_getInstance().weightAtIndex_dhhkv7$(data_0), densityNormalizingFactor);\n if (!(binsData.x_8be2vx$.size === binCount)) {\n var message = 'Internal: stat data size=' + toString(binsData.x_8be2vx$.size) + ' expected bin count=' + toString(binCount);\n throw IllegalStateException_init(message.toString());\n }return binsData;\n };\n function BinStat$XPosKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function BinStat$XPosKind_initFields() {\n BinStat$XPosKind_initFields = function () {\n };\n BinStat$XPosKind$NONE_instance = new BinStat$XPosKind('NONE', 0);\n BinStat$XPosKind$CENTER_instance = new BinStat$XPosKind('CENTER', 1);\n BinStat$XPosKind$BOUNDARY_instance = new BinStat$XPosKind('BOUNDARY', 2);\n }\n var BinStat$XPosKind$NONE_instance;\n function BinStat$XPosKind$NONE_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$NONE_instance;\n }\n var BinStat$XPosKind$CENTER_instance;\n function BinStat$XPosKind$CENTER_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$CENTER_instance;\n }\n var BinStat$XPosKind$BOUNDARY_instance;\n function BinStat$XPosKind$BOUNDARY_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$BOUNDARY_instance;\n }\n BinStat$XPosKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'XPosKind',\n interfaces: [Enum]\n };\n function BinStat$XPosKind$values() {\n return [BinStat$XPosKind$NONE_getInstance(), BinStat$XPosKind$CENTER_getInstance(), BinStat$XPosKind$BOUNDARY_getInstance()];\n }\n BinStat$XPosKind.values = BinStat$XPosKind$values;\n function BinStat$XPosKind$valueOf(name) {\n switch (name) {\n case 'NONE':\n return BinStat$XPosKind$NONE_getInstance();\n case 'CENTER':\n return BinStat$XPosKind$CENTER_getInstance();\n case 'BOUNDARY':\n return BinStat$XPosKind$BOUNDARY_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.BinStat.XPosKind.' + name);\n }\n }\n BinStat$XPosKind.valueOf_61zpoe$ = BinStat$XPosKind$valueOf;\n function BinStat$Companion() {\n BinStat$Companion_instance = this;\n this.DEF_BIN_COUNT = 30;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().COUNT)]);\n }\n BinStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BinStat$Companion_instance = null;\n function BinStat$Companion_getInstance() {\n if (BinStat$Companion_instance === null) {\n new BinStat$Companion();\n }return BinStat$Companion_instance;\n }\n BinStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinStat',\n interfaces: [BaseStat]\n };\n function BinStatUtil() {\n BinStatUtil_instance = this;\n this.MAX_BIN_COUNT_0 = 500;\n }\n function BinStatUtil$weightAtIndex$lambda(closure$weights) {\n return function (index) {\n var weight = closure$weights.get_za3lpa$(index);\n return data.SeriesUtil.asFinite_z03gcz$(weight, 0.0);\n };\n }\n function BinStatUtil$weightAtIndex$lambda_0(it) {\n return 1.0;\n }\n BinStatUtil.prototype.weightAtIndex_dhhkv7$ = function (data) {\n if (data.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n var weights = data.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT);\n return BinStatUtil$weightAtIndex$lambda(weights);\n }return BinStatUtil$weightAtIndex$lambda_0;\n };\n BinStatUtil.prototype.weightVector_5m8trb$ = function (dataLength, data) {\n var tmp$;\n if (data.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n tmp$ = data.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT);\n } else {\n var list = ArrayList_init_1(dataLength);\n for (var index = 0; index < dataLength; index++) {\n list.add_11rb$(1.0);\n }\n tmp$ = list;\n }\n return tmp$;\n };\n BinStatUtil.prototype.binCountAndWidth_11nzti$ = function (dataRange, binOptions) {\n var binCount = binOptions.binCount;\n var binWidth;\n if (binOptions.hasBinWidth()) {\n binWidth = ensureNotNull(binOptions.binWidth);\n var count = dataRange / binWidth;\n var b = count;\n count = JsMath.min(500, b);\n var x = count;\n binCount = numberToInt(JsMath.ceil(x));\n } else {\n binWidth = dataRange / binCount;\n }\n return new BinStatUtil$CountAndWidth(binCount, binWidth);\n };\n BinStatUtil.prototype.computeBins_3oz8yg$ = function (valuesX, startX, binCount, binWidth, weightAtIndex, densityNormalizingFactor) {\n var totalCount = 0.0;\n var countByBinIndex = HashMap_init();\n for (var dataIndex = 0; dataIndex !== valuesX.size; ++dataIndex) {\n var x = valuesX.get_za3lpa$(dataIndex);\n if (!data.SeriesUtil.isFinite_yrwdxb$(x)) {\n continue;\n }var weight = weightAtIndex(dataIndex);\n totalCount += weight;\n var x_0 = (ensureNotNull(x) - startX) / binWidth;\n var binIndex = numberToInt(JsMath.floor(x_0));\n if (!countByBinIndex.containsKey_11rb$(binIndex)) {\n var value = new MutableDouble(0.0);\n countByBinIndex.put_xwzc9p$(binIndex, value);\n }ensureNotNull(countByBinIndex.get_11rb$(binIndex)).getAndAdd_14dthe$(weight);\n }\n var x_1 = ArrayList_init();\n var counts = ArrayList_init();\n var densities = ArrayList_init();\n var x0 = startX + binWidth / 2;\n for (var i = 0; i < binCount; i++) {\n x_1.add_11rb$(x0 + i * binWidth);\n var count = 0.0;\n if (countByBinIndex.containsKey_11rb$(i)) {\n count = ensureNotNull(countByBinIndex.get_11rb$(i)).get();\n }counts.add_11rb$(count);\n var density = count / totalCount * densityNormalizingFactor;\n densities.add_11rb$(density);\n }\n return new BinStatUtil$BinsData(x_1, counts, densities);\n };\n function BinStatUtil$BinOptions(binCount, binWidth) {\n this.binWidth = binWidth;\n var b = JsMath.max(1, binCount);\n this.binCount = JsMath.min(500, b);\n }\n BinStatUtil$BinOptions.prototype.hasBinWidth = function () {\n return this.binWidth != null && this.binWidth > 0;\n };\n BinStatUtil$BinOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinOptions',\n interfaces: []\n };\n function BinStatUtil$CountAndWidth(count, width) {\n this.count = count;\n this.width = width;\n }\n BinStatUtil$CountAndWidth.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CountAndWidth',\n interfaces: []\n };\n function BinStatUtil$BinsData(x, count, density) {\n this.x_8be2vx$ = x;\n this.count_8be2vx$ = count;\n this.density_8be2vx$ = density;\n }\n BinStatUtil$BinsData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinsData',\n interfaces: []\n };\n BinStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BinStatUtil',\n interfaces: []\n };\n var BinStatUtil_instance = null;\n function BinStatUtil_getInstance() {\n if (BinStatUtil_instance === null) {\n new BinStatUtil();\n }return BinStatUtil_instance;\n }\n function BoxplotStat(whiskerIQRRatio, computeWidth) {\n BoxplotStat$Companion_getInstance();\n BaseStat.call(this, BoxplotStat$Companion_getInstance().DEF_MAPPING_0);\n this.whiskerIQRRatio_0 = whiskerIQRRatio;\n this.computeWidth_0 = computeWidth;\n }\n BoxplotStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return BaseStat.prototype.hasDefaultMapping_896ixz$.call(this, aes) || (equals(aes, Aes$Companion_getInstance().WIDTH) && this.computeWidth_0);\n };\n BoxplotStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n var tmp$;\n if (equals(aes, Aes$Companion_getInstance().WIDTH)) {\n tmp$ = Stats_getInstance().WIDTH;\n } else {\n tmp$ = BaseStat.prototype.getDefaultMapping_896ixz$.call(this, aes);\n }\n return tmp$;\n };\n BoxplotStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y]);\n };\n BoxplotStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var ys = data.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (data.has_8xm3sj$(TransformVar_getInstance().X)) {\n tmp$ = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n } else {\n var size = ys.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(0.0);\n }\n tmp$ = list;\n }\n var xs = tmp$;\n var statData = BoxplotStat$Companion_getInstance().buildStat_7jxs1q$(xs, ys, this.whiskerIQRRatio_0);\n var statCount = statData.remove_11rb$(Stats_getInstance().COUNT);\n var maxCountPerBin = (tmp$_1 = (tmp$_0 = statCount != null ? maxOrNull(statCount) : null) != null ? numberToInt(tmp$_0) : null) != null ? tmp$_1 : 0;\n if (maxCountPerBin === 0) {\n return this.withEmptyStatValues();\n }if (this.computeWidth_0) {\n var norm = JsMath.sqrt(maxCountPerBin);\n var $receiver = ensureNotNull(statCount);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_3;\n tmp$_3 = $receiver.iterator();\n while (tmp$_3.hasNext()) {\n var item = tmp$_3.next();\n destination.add_11rb$(JsMath.sqrt(item) / norm);\n }\n var statWidth = destination;\n var key = Stats_getInstance().WIDTH;\n statData.put_xwzc9p$(key, statWidth);\n }var builder = DataFrame$DataFrame$Builder_init();\n tmp$_2 = statData.entries.iterator();\n while (tmp$_2.hasNext()) {\n var tmp$_4 = tmp$_2.next();\n var variable = tmp$_4.key;\n var series = tmp$_4.value;\n builder.putNumeric_s1rqo9$(variable, series);\n }\n return builder.build();\n };\n function BoxplotStat$Companion() {\n BoxplotStat$Companion_instance = this;\n this.DEF_WHISKER_IQR_RATIO = 1.5;\n this.DEF_COMPUTE_WIDTH = false;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().YMIN, Stats_getInstance().Y_MIN), to(Aes$Companion_getInstance().YMAX, Stats_getInstance().Y_MAX), to(Aes$Companion_getInstance().LOWER, Stats_getInstance().LOWER), to(Aes$Companion_getInstance().MIDDLE, Stats_getInstance().MIDDLE), to(Aes$Companion_getInstance().UPPER, Stats_getInstance().UPPER)]);\n }\n BoxplotStat$Companion.prototype.buildStat_7jxs1q$ = function (xs, ys, whiskerIQRRatio) {\n var tmp$, tmp$_0, tmp$_1;\n var $receiver = zip(xs, ys);\n var destination = ArrayList_init();\n var tmp$_2;\n tmp$_2 = $receiver.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n var x = element.component1()\n , y = element.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y))\n destination.add_11rb$(element);\n }\n var xyPairs = destination;\n if (xyPairs.isEmpty()) {\n return LinkedHashMap_init();\n }var binnedData = HashMap_init();\n tmp$ = xyPairs.iterator();\n while (tmp$.hasNext()) {\n var tmp$_3 = tmp$.next();\n var x_0 = tmp$_3.component1()\n , y_0 = tmp$_3.component2();\n var key = ensureNotNull(x_0);\n var tmp$_4;\n var value = binnedData.get_11rb$(key);\n if (value == null) {\n var answer = ArrayList_init();\n binnedData.put_xwzc9p$(key, answer);\n tmp$_4 = answer;\n } else {\n tmp$_4 = value;\n }\n tmp$_4.add_11rb$(ensureNotNull(y_0));\n }\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statMiddle = ArrayList_init();\n var statLower = ArrayList_init();\n var statUpper = ArrayList_init();\n var statMin = ArrayList_init();\n var statMax = ArrayList_init();\n var statCount = ArrayList_init();\n tmp$_0 = binnedData.entries.iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_5 = tmp$_0.next();\n var x_1 = tmp$_5.key;\n var bin = tmp$_5.value;\n var count = bin.size;\n var summary = FiveNumberSummary_init(bin);\n var middle = summary.median;\n var lowerHinge = summary.firstQuartile;\n var upperHinge = summary.thirdQuartile;\n var IQR = upperHinge - lowerHinge;\n var lowerFence = lowerHinge - IQR * whiskerIQRRatio;\n var upperFence = upperHinge + IQR * whiskerIQRRatio;\n var lowerWhisker = lowerFence;\n var upperWhisker = upperFence;\n if (data.SeriesUtil.allFinite_jma9l8$(lowerFence, upperFence)) {\n var destination_0 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = bin.iterator();\n while (tmp$_6.hasNext()) {\n var element_0 = tmp$_6.next();\n if (element_0 >= lowerFence && element_0 <= upperFence)\n destination_0.add_11rb$(element_0);\n }\n var boxed = destination_0;\n var range = data.SeriesUtil.range_l63ks6$(boxed);\n if (range != null) {\n lowerWhisker = range.lowerEnd;\n upperWhisker = range.upperEnd;\n }}var destination_1 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = bin.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (element_1 < lowerFence || element_1 > upperFence)\n destination_1.add_11rb$(element_1);\n }\n var outliers = destination_1;\n tmp$_1 = outliers.iterator();\n while (tmp$_1.hasNext()) {\n var y_1 = tmp$_1.next();\n statX.add_11rb$(x_1);\n statY.add_11rb$(y_1);\n statMiddle.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statLower.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statUpper.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMin.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMax.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statCount.add_11rb$(count);\n }\n statX.add_11rb$(x_1);\n statY.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMiddle.add_11rb$(middle);\n statLower.add_11rb$(lowerHinge);\n statUpper.add_11rb$(upperHinge);\n statMin.add_11rb$(lowerWhisker);\n statMax.add_11rb$(upperWhisker);\n statCount.add_11rb$(count);\n }\n return mutableMapOf([to(Stats_getInstance().X, statX), to(Stats_getInstance().Y, statY), to(Stats_getInstance().MIDDLE, statMiddle), to(Stats_getInstance().LOWER, statLower), to(Stats_getInstance().UPPER, statUpper), to(Stats_getInstance().Y_MIN, statMin), to(Stats_getInstance().Y_MAX, statMax), to(Stats_getInstance().COUNT, statCount)]);\n };\n BoxplotStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BoxplotStat$Companion_instance = null;\n function BoxplotStat$Companion_getInstance() {\n if (BoxplotStat$Companion_instance === null) {\n new BoxplotStat$Companion();\n }return BoxplotStat$Companion_instance;\n }\n BoxplotStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxplotStat',\n interfaces: [BaseStat]\n };\n function Contour() {\n Contour$Companion_getInstance();\n this.myContourX_0 = ArrayList_init();\n this.myContourY_0 = ArrayList_init();\n this.myContourLevel_0 = ArrayList_init();\n this.myContourGroup_0 = ArrayList_init();\n this.myGroup_0 = 0.0;\n }\n Object.defineProperty(Contour.prototype, 'dataFrame_0', {\n configurable: true,\n get: function () {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, this.myContourX_0).putNumeric_s1rqo9$(Stats_getInstance().Y, this.myContourY_0).putNumeric_s1rqo9$(Stats_getInstance().LEVEL, this.myContourLevel_0).putNumeric_s1rqo9$(Stats_getInstance().GROUP, this.myContourGroup_0).build();\n }\n });\n Contour.prototype.add_e7h60q$ = function (polygon, fillLevel) {\n var tmp$;\n tmp$ = polygon.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n this.myContourX_0.add_11rb$(p.x);\n this.myContourY_0.add_11rb$(p.y);\n this.myContourLevel_0.add_11rb$(fillLevel);\n this.myContourGroup_0.add_11rb$(this.myGroup_0);\n }\n this.myGroup_0 += 1.0;\n };\n function Contour$Companion() {\n Contour$Companion_instance = this;\n }\n Contour$Companion.prototype.getPathDataFrame_9s3d7f$ = function (levels, pathListByLevel) {\n var tmp$, tmp$_0;\n var contour = new Contour();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var paths = ensureNotNull(pathListByLevel.get_11rb$(level));\n tmp$_0 = paths.iterator();\n while (tmp$_0.hasNext()) {\n var path = tmp$_0.next();\n contour.add_e7h60q$(path, level);\n }\n }\n return contour.dataFrame_0;\n };\n Contour$Companion.prototype.getPolygonDataFrame_dnsuee$ = function (fillLevels, polygonListByFillLevel) {\n var tmp$;\n var contour = new Contour();\n tmp$ = fillLevels.iterator();\n while (tmp$.hasNext()) {\n var fillLevel = tmp$.next();\n var polygon = ensureNotNull(polygonListByFillLevel.get_11rb$(fillLevel));\n contour.add_e7h60q$(polygon, fillLevel);\n }\n return contour.dataFrame_0;\n };\n Contour$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Contour$Companion_instance = null;\n function Contour$Companion_getInstance() {\n if (Contour$Companion_instance === null) {\n new Contour$Companion();\n }return Contour$Companion_instance;\n }\n Contour.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Contour',\n interfaces: []\n };\n function ContourFillHelper(xRange, yRange) {\n ContourFillHelper$Companion_getInstance();\n this.myLowLeft_0 = null;\n this.myLowRight_0 = null;\n this.myUpLeft_0 = null;\n this.myUpRight_0 = null;\n var xMin = xRange.lowerEnd;\n var xMax = xRange.upperEnd;\n var yMin = yRange.lowerEnd;\n var yMax = yRange.upperEnd;\n this.myLowLeft_0 = new DoubleVector(xMin, yMin);\n this.myLowRight_0 = new DoubleVector(xMax, yMin);\n this.myUpLeft_0 = new DoubleVector(xMin, yMax);\n this.myUpRight_0 = new DoubleVector(xMax, yMax);\n }\n ContourFillHelper.prototype.createPolygons_lrt0be$ = function (pathByLevels, levels, fillLevels) {\n var tmp$, tmp$_0, tmp$_1;\n var result = HashMap_init();\n var allPaths = ArrayList_init();\n tmp$ = pathByLevels.values.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n allPaths.addAll_brywnq$(level);\n }\n var cornerPoints = ArrayList_init();\n var outerMap = this.createOuterMap_0(allPaths, cornerPoints);\n var n = pathByLevels.keys.size;\n tmp$_0 = n + 1 | 0;\n for (var i = 0; i < tmp$_0; i++) {\n var polygonPieces = ArrayList_init();\n var value = ArrayList_init();\n if (i > 0) {\n polygonPieces.addAll_brywnq$(ContourFillHelper$Companion_getInstance().reverseAll_0(ensureNotNull(pathByLevels.get_11rb$(levels.get_za3lpa$(i - 1 | 0)))));\n }if (i < n) {\n polygonPieces.addAll_brywnq$(ensureNotNull(pathByLevels.get_11rb$(levels.get_za3lpa$(i))));\n }polygonPieces = this.createClosedPolygonLevels_0(polygonPieces, outerMap, cornerPoints);\n tmp$_1 = polygonPieces.iterator();\n while (tmp$_1.hasNext()) {\n var path = tmp$_1.next();\n value.addAll_brywnq$(path);\n }\n var key = fillLevels.get_za3lpa$(i);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n ContourFillHelper.prototype.createClosedPolygonLevels_0 = function (openLevels, outerMap, cornerPoints) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = ArrayList_init();\n var donePath = HashSet_init_1();\n tmp$ = openLevels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var levelCopy = ArrayList_init_0(level);\n var p0 = levelCopy.get_za3lpa$(0);\n var p1 = levelCopy.get_za3lpa$(levelCopy.size - 1 | 0);\n if (p0 != null ? p0.equals(p1) : null) {\n result.add_11rb$(levelCopy);\n continue;\n }var pi2 = ensureNotNull(outerMap.get_11rb$(p1));\n levelCopy.add_11rb$(pi2);\n p1 = pi2;\n while (cornerPoints.contains_11rb$(p1)) {\n pi2 = ensureNotNull(outerMap.get_11rb$(p1));\n levelCopy.add_11rb$(pi2);\n p1 = pi2;\n }\n donePath.add_11rb$(levelCopy);\n }\n var pathByEndPoint = HashMap_init();\n tmp$_0 = donePath.iterator();\n while (tmp$_0.hasNext()) {\n var path = tmp$_0.next();\n var p0_0 = path.get_za3lpa$(0);\n var p1_0 = path.get_za3lpa$(path.size - 1 | 0);\n if (p0_0 != null ? p0_0.equals(p1_0) : null) {\n result.add_11rb$(path);\n continue;\n }if (pathByEndPoint.containsKey_11rb$(p0_0) || pathByEndPoint.containsKey_11rb$(p1_0)) {\n var path0 = pathByEndPoint.get_11rb$(p0_0);\n var path1 = pathByEndPoint.get_11rb$(p1_0);\n ContourStatUtil_getInstance().removePathByEndpoints_ebaanh$(path0, pathByEndPoint);\n ContourStatUtil_getInstance().removePathByEndpoints_ebaanh$(path1, pathByEndPoint);\n var longPath;\n if (path0 === path1) {\n ensureNotNull(path0).addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n result.add_11rb$(path0);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath = path0;\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size - 1 | 0));\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath = ensureNotNull(path1);\n longPath.addAll_u57x28$(0, path.subList_vux9f0$(0, path.size - 1 | 0));\n } else {\n longPath = path0;\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n }\n var key = longPath.get_za3lpa$(0);\n var value = longPath;\n pathByEndPoint.put_xwzc9p$(key, value);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n var value_0 = longPath;\n pathByEndPoint.put_xwzc9p$(key_0, value_0);\n } else {\n var key_1 = path.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = path.get_za3lpa$(path.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n if (!pathByEndPoint.keys.isEmpty()) {\n throw IllegalArgumentException_init('Some paths are not cleared yet there is something wrong!' + toString(pathByEndPoint.keys.size));\n }tmp$_1 = result.iterator();\n while (tmp$_1.hasNext()) {\n var path_0 = tmp$_1.next();\n if (!((tmp$_2 = path_0.get_za3lpa$(0)) != null ? tmp$_2.equals(path_0.get_za3lpa$(path_0.size - 1 | 0)) : null)) {\n throw IllegalArgumentException_init('The polygons are not entirely closed!');\n }}\n return result;\n };\n function ContourFillHelper$createOuterMap$lambda(o1, o2) {\n return Kotlin.compareTo(o1.x, o2.x);\n }\n function ContourFillHelper$createOuterMap$lambda_0(o1, o2) {\n return Kotlin.compareTo(o1.y, o2.y);\n }\n function ContourFillHelper$createOuterMap$lambda_1(o1, o2) {\n return Kotlin.compareTo(o2.x, o1.x);\n }\n function ContourFillHelper$createOuterMap$lambda_2(o1, o2) {\n return Kotlin.compareTo(o2.y, o1.y);\n }\n ContourFillHelper.prototype.createOuterMap_0 = function (paths, cornerPoints) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var points = ArrayList_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n if (!((tmp$_0 = path.get_za3lpa$(0)) != null ? tmp$_0.equals(path.get_za3lpa$(path.size - 1 | 0)) : null)) {\n points.add_11rb$(path.get_za3lpa$(0));\n points.add_11rb$(path.get_za3lpa$(path.size - 1 | 0));\n }}\n var result = HashMap_init();\n var list = ArrayList_init();\n for (var i = 0; i <= 3; i++) {\n list.add_11rb$(ArrayList_init());\n }\n tmp$_1 = points.iterator();\n while (tmp$_1.hasNext()) {\n var point = tmp$_1.next();\n var kind = this.getKind_0(point);\n switch (kind.name) {\n case 'DOWN':\n list.get_za3lpa$(0).add_11rb$(point);\n break;\n case 'RIGHT':\n list.get_za3lpa$(1).add_11rb$(point);\n break;\n case 'UP':\n list.get_za3lpa$(2).add_11rb$(point);\n break;\n case 'LEFT':\n list.get_za3lpa$(3).add_11rb$(point);\n break;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n }\n sortWith(list.get_za3lpa$(0), new Comparator(ContourFillHelper$createOuterMap$lambda));\n sortWith(list.get_za3lpa$(1), new Comparator(ContourFillHelper$createOuterMap$lambda_0));\n sortWith(list.get_za3lpa$(2), new Comparator(ContourFillHelper$createOuterMap$lambda_1));\n sortWith(list.get_za3lpa$(3), new Comparator(ContourFillHelper$createOuterMap$lambda_2));\n var prepareMap = ArrayList_init();\n if (!list.get_za3lpa$(0).contains_11rb$(this.myLowLeft_0)) {\n prepareMap.add_11rb$(this.myLowLeft_0);\n cornerPoints.add_11rb$(this.myLowLeft_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(0));\n if (!list.get_za3lpa$(0).contains_11rb$(this.myLowRight_0)) {\n prepareMap.add_11rb$(this.myLowRight_0);\n cornerPoints.add_11rb$(this.myLowRight_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(1));\n if (!list.get_za3lpa$(1).contains_11rb$(this.myUpRight_0)) {\n prepareMap.add_11rb$(this.myUpRight_0);\n cornerPoints.add_11rb$(this.myUpRight_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(2));\n if (!list.get_za3lpa$(3).contains_11rb$(this.myUpLeft_0)) {\n prepareMap.add_11rb$(this.myUpLeft_0);\n cornerPoints.add_11rb$(this.myUpLeft_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(3));\n prepareMap.add_11rb$(prepareMap.get_za3lpa$(0));\n tmp$_2 = prepareMap.size - 1 | 0;\n for (var i_0 = 0; i_0 < tmp$_2; i_0++) {\n var key = prepareMap.get_za3lpa$(i_0);\n var value = prepareMap.get_za3lpa$(i_0 + 1 | 0);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n ContourFillHelper.prototype.getKind_0 = function (point) {\n var tmp$;\n if (ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$DOWN_getInstance();\n } else if (ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && !ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$RIGHT_getInstance();\n } else if (!ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && !ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$UP_getInstance();\n } else if (!ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$LEFT_getInstance();\n } else {\n throw IllegalArgumentException_init('The Contour Point is not on the border ' + point);\n }\n return tmp$;\n };\n function ContourFillHelper$BorderKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ContourFillHelper$BorderKind_initFields() {\n ContourFillHelper$BorderKind_initFields = function () {\n };\n ContourFillHelper$BorderKind$DOWN_instance = new ContourFillHelper$BorderKind('DOWN', 0);\n ContourFillHelper$BorderKind$RIGHT_instance = new ContourFillHelper$BorderKind('RIGHT', 1);\n ContourFillHelper$BorderKind$UP_instance = new ContourFillHelper$BorderKind('UP', 2);\n ContourFillHelper$BorderKind$LEFT_instance = new ContourFillHelper$BorderKind('LEFT', 3);\n }\n var ContourFillHelper$BorderKind$DOWN_instance;\n function ContourFillHelper$BorderKind$DOWN_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$DOWN_instance;\n }\n var ContourFillHelper$BorderKind$RIGHT_instance;\n function ContourFillHelper$BorderKind$RIGHT_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$RIGHT_instance;\n }\n var ContourFillHelper$BorderKind$UP_instance;\n function ContourFillHelper$BorderKind$UP_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$UP_instance;\n }\n var ContourFillHelper$BorderKind$LEFT_instance;\n function ContourFillHelper$BorderKind$LEFT_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$LEFT_instance;\n }\n ContourFillHelper$BorderKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BorderKind',\n interfaces: [Enum]\n };\n function ContourFillHelper$BorderKind$values() {\n return [ContourFillHelper$BorderKind$DOWN_getInstance(), ContourFillHelper$BorderKind$RIGHT_getInstance(), ContourFillHelper$BorderKind$UP_getInstance(), ContourFillHelper$BorderKind$LEFT_getInstance()];\n }\n ContourFillHelper$BorderKind.values = ContourFillHelper$BorderKind$values;\n function ContourFillHelper$BorderKind$valueOf(name) {\n switch (name) {\n case 'DOWN':\n return ContourFillHelper$BorderKind$DOWN_getInstance();\n case 'RIGHT':\n return ContourFillHelper$BorderKind$RIGHT_getInstance();\n case 'UP':\n return ContourFillHelper$BorderKind$UP_getInstance();\n case 'LEFT':\n return ContourFillHelper$BorderKind$LEFT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.ContourFillHelper.BorderKind.' + name);\n }\n }\n ContourFillHelper$BorderKind.valueOf_61zpoe$ = ContourFillHelper$BorderKind$valueOf;\n function ContourFillHelper$Companion() {\n ContourFillHelper$Companion_instance = this;\n }\n ContourFillHelper$Companion.prototype.computeFillLevels_4v6zbb$ = function (zRange, levels) {\n var tmp$;\n var fillLevels = ArrayList_init();\n fillLevels.add_11rb$(zRange.lowerEnd);\n tmp$ = levels.size - 1 | 0;\n for (var i = 0; i < tmp$; i++) {\n fillLevels.add_11rb$((levels.get_za3lpa$(i) + levels.get_za3lpa$(i + 1 | 0)) / 2.0);\n }\n fillLevels.add_11rb$(zRange.upperEnd);\n return fillLevels;\n };\n ContourFillHelper$Companion.prototype.reverseAll_0 = function (list) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var copy = ArrayList_init_0(item);\n reverse(copy);\n result.add_11rb$(copy);\n }\n return result;\n };\n ContourFillHelper$Companion.prototype.belowOrOnLine_0 = function (a, b, test) {\n var value = test.subtract_gpjtzr$(a);\n var standard = b.subtract_gpjtzr$(a);\n return standard.y * value.x - value.y * standard.x >= 0;\n };\n ContourFillHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourFillHelper$Companion_instance = null;\n function ContourFillHelper$Companion_getInstance() {\n if (ContourFillHelper$Companion_instance === null) {\n new ContourFillHelper$Companion();\n }return ContourFillHelper$Companion_instance;\n }\n ContourFillHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourFillHelper',\n interfaces: []\n };\n function ContourStat(binCount, binWidth) {\n ContourStat$Companion_getInstance();\n BaseStat.call(this, ContourStat$Companion_getInstance().DEF_MAPPING_0);\n this.myBinOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n ContourStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z]);\n };\n ContourStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z])) {\n return this.withEmptyStatValues();\n }tmp$ = ContourStatUtil_getInstance().computeLevels_wuiwgl$(data, this.myBinOptions_0);\n if (tmp$ == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_jco5dt$(data, levels);\n return Contour$Companion_getInstance().getPathDataFrame_9s3d7f$(levels, pathListByLevel);\n };\n function ContourStat$Companion() {\n ContourStat$Companion_instance = this;\n this.DEF_BIN_COUNT = 10;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n }\n ContourStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourStat$Companion_instance = null;\n function ContourStat$Companion_getInstance() {\n if (ContourStat$Companion_instance === null) {\n new ContourStat$Companion();\n }return ContourStat$Companion_instance;\n }\n ContourStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourStat',\n interfaces: [BaseStat]\n };\n function ContourStatUtil() {\n ContourStatUtil_instance = this;\n this.xLoc_0 = new Float64Array([0.0, 1.0, 1.0, 0.0, 0.5]);\n this.yLoc_0 = new Float64Array([0.0, 0.0, 1.0, 1.0, 0.5]);\n }\n ContourStatUtil.prototype.estimateRegularGridShape_fsp013$ = function (xs) {\n var tmp$;\n var colCount = 0;\n var x0 = null;\n tmp$ = xs.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n if (x0 == null) {\n x0 = x;\n } else if (x == x0) {\n break;\n }colCount = colCount + 1 | 0;\n }\n if (colCount <= 1) {\n throw IllegalArgumentException_init('Data grid must be at least 2 columns wide (was ' + colCount + ')');\n }var rowCount = xs.size / colCount | 0;\n if (rowCount <= 1) {\n throw IllegalArgumentException_init('Data grid must be at least 2 rows tall (was ' + rowCount + ')');\n }return new Pair(colCount, rowCount);\n };\n ContourStatUtil.prototype.computeLevels_wuiwgl$ = function (data, binOptions) {\n if (!(data.has_8xm3sj$(TransformVar_getInstance().X) && data.has_8xm3sj$(TransformVar_getInstance().Y) && data.has_8xm3sj$(TransformVar_getInstance().Z))) {\n return null;\n }var zRange = data.range_8xm3sj$(TransformVar_getInstance().Z);\n return this.computeLevels_kgz263$(zRange, binOptions);\n };\n ContourStatUtil.prototype.computeLevels_kgz263$ = function (zRange, binOptions) {\n var tmp$;\n if (zRange == null || data.SeriesUtil.isSubTiny_4fzjta$(zRange))\n return null;\n var b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(zRange), binOptions);\n var levels = ArrayList_init();\n tmp$ = b.count;\n for (var i = 0; i < tmp$; i++) {\n var level = i * b.width + zRange.lowerEnd;\n level += b.width / 2;\n levels.add_11rb$(level);\n }\n return levels;\n };\n ContourStatUtil.prototype.computeContours_jco5dt$ = function (data, levels) {\n var xVector = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var zVector = data.getNumeric_8xm3sj$(TransformVar_getInstance().Z);\n var shape = this.estimateRegularGridShape_fsp013$(xVector);\n var colCount = shape.first;\n var rowCount = shape.second;\n var xRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().X));\n var yRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Y));\n return this.computeContours_cxleoh$(xRange, yRange, colCount, rowCount, zVector, levels);\n };\n ContourStatUtil.prototype.computeContours_cxleoh$ = function (xRange, yRange, colCount, rowCount, data_0, levels) {\n var tmp$;\n var xStep = data.SeriesUtil.span_4fzjta$(xRange) / (colCount - 1 | 0);\n var yStep = data.SeriesUtil.span_4fzjta$(yRange) / (rowCount - 1 | 0);\n var origin = new DoubleVector(xRange.lowerEnd, yRange.lowerEnd);\n var pathListByLevel = HashMap_init();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var levelSegments = this.computeSegments_0(colCount, rowCount, data_0, level);\n var paths = this.joinSegments_0(levelSegments);\n var pathsReal = this.convertPaths_0(paths, xStep, yStep, origin, level);\n pathsReal = this.confirmPaths_0(pathsReal);\n var value = pathsReal;\n pathListByLevel.put_xwzc9p$(level, value);\n }\n return pathListByLevel;\n };\n ContourStatUtil.prototype.joinSegments_0 = function (segments) {\n var tmp$, tmp$_0;\n var pathList = ArrayList_init();\n var pathByEndPoint = HashMap_init();\n tmp$ = segments.iterator();\n while (tmp$.hasNext()) {\n var segment = tmp$.next();\n var p0 = segment.first;\n var p1 = segment.second;\n if (pathByEndPoint.containsKey_11rb$(p0) || pathByEndPoint.containsKey_11rb$(p1)) {\n var path0 = pathByEndPoint.get_11rb$(p0);\n var path1 = pathByEndPoint.get_11rb$(p1);\n if (path0 != null) {\n pathByEndPoint.remove_11rb$(path0.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path0.get_za3lpa$(path0.size - 1 | 0));\n }if (path1 != null) {\n pathByEndPoint.remove_11rb$(path1.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path1.get_za3lpa$(path1.size - 1 | 0));\n }var longPath;\n if (path0 === path1) {\n ensureNotNull(path0).add_11rb$(segment.second);\n pathList.add_11rb$(path0);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath = path0;\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath = ensureNotNull(path1);\n longPath.add_wxm5ur$(0, segment.first);\n } else {\n longPath = path0;\n longPath.add_11rb$(segment.second);\n }\n var key = longPath.get_za3lpa$(0);\n var value = longPath;\n pathByEndPoint.put_xwzc9p$(key, value);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n var value_0 = longPath;\n pathByEndPoint.put_xwzc9p$(key_0, value_0);\n } else {\n var path = ArrayList_init();\n path.add_11rb$(segment.first);\n path.add_11rb$(segment.second);\n var key_1 = segment.first;\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = segment.second;\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n var pathSet = HashSet_init(pathByEndPoint.values);\n tmp$_0 = pathSet.iterator();\n while (tmp$_0.hasNext()) {\n var path_0 = tmp$_0.next();\n pathList.add_11rb$(path_0);\n }\n return pathList;\n };\n ContourStatUtil.prototype.convertPaths_0 = function (paths, xStep, yStep, origin, level) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = ArrayList_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n var temp = ArrayList_init();\n var lastPoint = null;\n tmp$_0 = path.iterator();\n while (tmp$_0.hasNext()) {\n var edge = tmp$_0.next();\n var intersect = edge.intersect_14dthe$(ensureNotNull(level));\n intersect = (new DoubleVector(xStep * intersect.x, yStep * intersect.y)).add_gpjtzr$(origin);\n if (equals(intersect, lastPoint)) {\n continue;\n }temp.add_11rb$(intersect);\n lastPoint = intersect;\n }\n if (((tmp$_1 = path.get_za3lpa$(0)) != null ? tmp$_1.equals(path.get_za3lpa$(path.size - 1 | 0)) : null) && !((tmp$_2 = temp.get_za3lpa$(0)) != null ? tmp$_2.equals(temp.get_za3lpa$(temp.size - 1 | 0)) : null)) {\n temp.set_wxm5ur$(temp.size - 1 | 0, temp.get_za3lpa$(0));\n }if (temp.size > 1) {\n result.add_11rb$(temp);\n }}\n return result;\n };\n ContourStatUtil.prototype.confirmPaths_0 = function (paths) {\n var tmp$, tmp$_0, tmp$_1;\n var newPaths = ArrayList_init();\n var pathByEndPoint = HashMap_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n var p0 = path.get_za3lpa$(0);\n var p1 = path.get_za3lpa$(path.size - 1 | 0);\n if (p0 != null ? p0.equals(p1) : null) {\n newPaths.add_11rb$(path);\n continue;\n }if (pathByEndPoint.containsKey_11rb$(p0) || pathByEndPoint.containsKey_11rb$(p1)) {\n var path0 = pathByEndPoint.get_11rb$(p0);\n var path1 = pathByEndPoint.get_11rb$(p1);\n this.removePathByEndpoints_ebaanh$(path0, pathByEndPoint);\n this.removePathByEndpoints_ebaanh$(path1, pathByEndPoint);\n var longPath = ArrayList_init();\n if (path0 === path1) {\n longPath.addAll_brywnq$(ensureNotNull(path0));\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n newPaths.add_11rb$(longPath);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath.addAll_brywnq$(path0);\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size - 1 | 0));\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath.addAll_brywnq$(ensureNotNull(path1));\n longPath.addAll_u57x28$(0, path.subList_vux9f0$(0, path.size - 1 | 0));\n } else {\n longPath.addAll_brywnq$(path0);\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n }\n var key = longPath.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key, longPath);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_0, longPath);\n } else {\n var key_1 = path.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = path.get_za3lpa$(path.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n var pathSet = HashSet_init(pathByEndPoint.values);\n tmp$_0 = pathSet.iterator();\n while (tmp$_0.hasNext()) {\n var path_0 = tmp$_0.next();\n newPaths.add_11rb$(path_0);\n }\n var result = ArrayList_init();\n tmp$_1 = newPaths.iterator();\n while (tmp$_1.hasNext()) {\n var path_1 = tmp$_1.next();\n result.addAll_brywnq$(this.pathSeparator_0(path_1));\n }\n return result;\n };\n ContourStatUtil.prototype.removePathByEndpoints_ebaanh$ = function (path, pathByEndPoint) {\n if (path != null) {\n pathByEndPoint.remove_11rb$(path.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path.get_za3lpa$(path.size - 1 | 0));\n }};\n ContourStatUtil.prototype.pathSeparator_0 = function (path) {\n var tmp$, tmp$_0;\n var result = ArrayList_init();\n var startIndex = 0;\n tmp$ = path.size - 1 | 0;\n for (var nextIndex = 1; nextIndex < tmp$; nextIndex++) {\n if ((tmp$_0 = path.get_za3lpa$(startIndex)) != null ? tmp$_0.equals(path.get_za3lpa$(nextIndex)) : null) {\n result.add_11rb$(path.subList_vux9f0$(startIndex, nextIndex + 1 | 0));\n startIndex = nextIndex;\n }}\n if (startIndex === 0) {\n return listOf_0(path);\n } else {\n result.add_11rb$(path.subList_vux9f0$(startIndex, path.size));\n return result;\n }\n };\n ContourStatUtil.prototype.computeSegments_0 = function (colCount, rowCount, data, level) {\n var tmp$, tmp$_0;\n var segments = ArrayList_init();\n tmp$ = rowCount - 1 | 0;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = colCount - 1 | 0;\n for (var col = 0; col < tmp$_0; col++) {\n var i0 = Kotlin.imul(row, colCount) + col | 0;\n var i1 = Kotlin.imul(row, colCount) + col + 1 | 0;\n var i2 = Kotlin.imul(row + 1 | 0, colCount) + col + 1 | 0;\n var i3 = Kotlin.imul(row + 1 | 0, colCount) + col | 0;\n var v = new Float64Array(5);\n v[0] = ensureNotNull(data.get_za3lpa$(i0));\n v[1] = ensureNotNull(data.get_za3lpa$(i1));\n v[2] = ensureNotNull(data.get_za3lpa$(i2));\n v[3] = ensureNotNull(data.get_za3lpa$(i3));\n var min = v[0];\n var max = v[0];\n for (var i = 1; i <= 3; i++) {\n var a = min;\n var b = v[i];\n min = JsMath.min(a, b);\n var a_0 = max;\n var b_0 = v[i];\n max = JsMath.max(a_0, b_0);\n }\n if (min === max) {\n continue;\n }v[4] = (v[0] + v[1] + v[2] + v[3] - min - max) / 2;\n if (level > min && level <= max) {\n var cellSegments = this.computeSegmentsForGridCell_0(level, v, col, row);\n segments.addAll_brywnq$(cellSegments);\n }}\n }\n return segments;\n };\n ContourStatUtil.prototype.computeSegmentsForGridCell_0 = function (level, value5, col, row) {\n var result = ArrayList_init();\n var points = ArrayList_init();\n var tempVector;\n for (var i = 0; i <= 4; i++) {\n points.add_11rb$(new ContourStatUtil$TripleVector(col + this.xLoc_0[i], row + this.yLoc_0[i], value5[i]));\n }\n for (var i_0 = 0; i_0 <= 3; i_0++) {\n var i1 = (i_0 + 1 | 0) % 4;\n tempVector = ArrayList_init();\n tempVector.add_11rb$(points.get_za3lpa$(i_0));\n tempVector.add_11rb$(points.get_za3lpa$(i1));\n tempVector.add_11rb$(points.get_za3lpa$(4));\n var temp = this.intersectionSegment_0(tempVector, level);\n if (temp != null) {\n result.add_11rb$(temp);\n }}\n return result;\n };\n ContourStatUtil.prototype.intersectionSegment_0 = function (vectors, level) {\n var type = (vectors.get_za3lpa$(0).getType_14dthe$(ensureNotNull(level)) * 100 | 0) + (vectors.get_za3lpa$(1).getType_14dthe$(level) * 10 | 0) + vectors.get_za3lpa$(2).getType_14dthe$(level) | 0;\n var start;\n var end;\n switch (type) {\n case 100:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(0));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(1));\n break;\n case 10:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(1));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(2));\n break;\n case 1:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(2));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(0));\n break;\n case 110:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(2));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(1));\n break;\n case 101:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(1));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(0));\n break;\n case 11:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(0));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(2));\n break;\n default:return null;\n }\n return new Pair(start, end);\n };\n ContourStatUtil.prototype.checkEdges_0 = function (paths, colCount, rowCount) {\n var tmp$, tmp$_0;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n if (!((tmp$_0 = path.get_za3lpa$(0)) != null ? tmp$_0.equals(path.get_za3lpa$(path.size - 1 | 0)) : null)) {\n this.checkEdge_0(path.get_za3lpa$(0), colCount, rowCount);\n this.checkEdge_0(path.get_za3lpa$(path.size - 1 | 0), colCount, rowCount);\n }}\n };\n ContourStatUtil.prototype.checkEdge_0 = function (edge, colCount, rowCount) {\n var a = edge.myA;\n var b = edge.myB;\n if (a.myX === 0 && b.myX === 0) {\n return;\n }if (a.myY === 0 && b.myY === 0) {\n return;\n }if (a.myX === (colCount - 1 | 0) && b.myX === (colCount - 1 | 0)) {\n return;\n }if (a.myY === (rowCount - 1 | 0) && b.myY === (rowCount - 1 | 0)) {\n return;\n }throw IllegalArgumentException_init('Check Edge Failed');\n };\n function ContourStatUtil$TripleVector(x, y, z) {\n this.z = z;\n this.myX = 0;\n this.myY = 0;\n this.myIsCenter_0 = 0;\n this.myX = numberToInt(x);\n this.myY = numberToInt(y);\n this.myIsCenter_0 = x % 1 === 0.0 ? 0 : 1;\n }\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'coord', {\n configurable: true,\n get: function () {\n return new DoubleVector(this.x, this.y);\n }\n });\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'x', {\n configurable: true,\n get: function () {\n return this.myX + 0.5 * this.myIsCenter_0;\n }\n });\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'y', {\n configurable: true,\n get: function () {\n return this.myY + 0.5 * this.myIsCenter_0;\n }\n });\n ContourStatUtil$TripleVector.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, ContourStatUtil$TripleVector) ? tmp$_0 : throwCCE();\n return this.myX === ensureNotNull(that).myX && this.myY === that.myY && this.myIsCenter_0 === that.myIsCenter_0;\n };\n ContourStatUtil$TripleVector.prototype.hashCode = function () {\n return hashCode([this.myX, this.myY, this.myIsCenter_0]);\n };\n ContourStatUtil$TripleVector.prototype.getType_14dthe$ = function (level) {\n var tmp$;\n if (this.z >= level) {\n tmp$ = 1;\n } else {\n tmp$ = 0;\n }\n return tmp$;\n };\n ContourStatUtil$TripleVector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TripleVector',\n interfaces: []\n };\n function ContourStatUtil$Edge(myA, myB) {\n this.myA = myA;\n this.myB = myB;\n }\n ContourStatUtil$Edge.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n if (!Kotlin.isType(other, ContourStatUtil$Edge)) {\n return false;\n }var obj = (tmp$ = other) == null || Kotlin.isType(tmp$, ContourStatUtil$Edge) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.myA) != null ? tmp$_0.equals(ensureNotNull(obj).myA) : null) && ((tmp$_1 = this.myB) != null ? tmp$_1.equals(obj.myB) : null) || (((tmp$_2 = this.myA) != null ? tmp$_2.equals(obj.myB) : null) && ((tmp$_3 = this.myB) != null ? tmp$_3.equals(obj.myA) : null));\n };\n ContourStatUtil$Edge.prototype.hashCode = function () {\n return this.myA.coord.hashCode() + this.myB.coord.hashCode() | 0;\n };\n ContourStatUtil$Edge.prototype.intersect_14dthe$ = function (level) {\n var z0 = this.myA.z;\n var z1 = this.myB.z;\n if (level === z0) {\n return this.myA.coord;\n }if (level === z1) {\n return this.myB.coord;\n }var ratio = (z1 - z0) / (level - z0);\n var x0 = this.myA.x;\n var y0 = this.myA.y;\n var x1 = this.myB.x;\n var y1 = this.myB.y;\n var x = x0 + (x1 - x0) / ratio;\n var y = y0 + (y1 - y0) / ratio;\n return new DoubleVector(x, y);\n };\n ContourStatUtil$Edge.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Edge',\n interfaces: []\n };\n ContourStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ContourStatUtil',\n interfaces: []\n };\n var ContourStatUtil_instance = null;\n function ContourStatUtil_getInstance() {\n if (ContourStatUtil_instance === null) {\n new ContourStatUtil();\n }return ContourStatUtil_instance;\n }\n function ContourfStat(binCount, binWidth) {\n ContourfStat$Companion_getInstance();\n BaseStat.call(this, ContourfStat$Companion_getInstance().DEF_MAPPING_0);\n this.myBinOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n ContourfStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z]);\n };\n ContourfStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z])) {\n return this.withEmptyStatValues();\n }tmp$ = ContourStatUtil_getInstance().computeLevels_wuiwgl$(data, this.myBinOptions_0);\n if (tmp$ == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_jco5dt$(data, levels);\n var xRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().X));\n var yRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Y));\n var zRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Z));\n var helper = new ContourFillHelper(xRange, yRange);\n var fillLevels = ContourFillHelper$Companion_getInstance().computeFillLevels_4v6zbb$(zRange, levels);\n var polygonListByFillLevel = helper.createPolygons_lrt0be$(pathListByLevel, levels, fillLevels);\n return Contour$Companion_getInstance().getPolygonDataFrame_dnsuee$(fillLevels, polygonListByFillLevel);\n };\n function ContourfStat$Companion() {\n ContourfStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n }\n ContourfStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourfStat$Companion_instance = null;\n function ContourfStat$Companion_getInstance() {\n if (ContourfStat$Companion_instance === null) {\n new ContourfStat$Companion();\n }return ContourfStat$Companion_instance;\n }\n ContourfStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourfStat',\n interfaces: [BaseStat]\n };\n function CorrelationStat(correlationMethod, type, fillDiagonal, threshold) {\n CorrelationStat$Companion_getInstance();\n BaseStat.call(this, CorrelationStat$Companion_getInstance().DEF_MAPPING_0);\n this.correlationMethod = correlationMethod;\n this.type = type;\n this.fillDiagonal = fillDiagonal;\n this.threshold = threshold;\n }\n CorrelationStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n if (!(this.correlationMethod === CorrelationStat$Method$PEARSON_getInstance())) {\n var message = 'Unsupported correlation method: ' + this.correlationMethod + ' (only Pearson is currently available)';\n throw IllegalArgumentException_init(message.toString());\n }if (!rangeTo(0.0, 1.0).contains_mef7kx$(this.threshold)) {\n var message_0 = 'Threshold value: ' + this.threshold + ' must be in interval [0.0, 1.0]';\n throw IllegalArgumentException_init(message_0.toString());\n }var cm = CorrelationUtil_getInstance().correlationMatrix_ofg6u8$(data, this.type, this.fillDiagonal, getCallableRef('correlationPearson', function (p1, p2) {\n return correlationPearson(p1, p2);\n }), this.threshold);\n var values = cm.getNumeric_8xm3sj$(Stats_getInstance().CORR);\n var destination = ArrayList_init_1(collectionSizeOrDefault(values, 10));\n var tmp$;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item != null ? JsMath.abs(item) : null);\n }\n var abs = destination;\n return cm.builder().putNumeric_s1rqo9$(Stats_getInstance().CORR_ABS, abs).build();\n };\n CorrelationStat.prototype.consumes = function () {\n return emptyList();\n };\n function CorrelationStat$Method(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CorrelationStat$Method_initFields() {\n CorrelationStat$Method_initFields = function () {\n };\n CorrelationStat$Method$PEARSON_instance = new CorrelationStat$Method('PEARSON', 0);\n CorrelationStat$Method$SPEARMAN_instance = new CorrelationStat$Method('SPEARMAN', 1);\n CorrelationStat$Method$KENDALL_instance = new CorrelationStat$Method('KENDALL', 2);\n }\n var CorrelationStat$Method$PEARSON_instance;\n function CorrelationStat$Method$PEARSON_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$PEARSON_instance;\n }\n var CorrelationStat$Method$SPEARMAN_instance;\n function CorrelationStat$Method$SPEARMAN_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$SPEARMAN_instance;\n }\n var CorrelationStat$Method$KENDALL_instance;\n function CorrelationStat$Method$KENDALL_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$KENDALL_instance;\n }\n CorrelationStat$Method.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Method',\n interfaces: [Enum]\n };\n function CorrelationStat$Method$values() {\n return [CorrelationStat$Method$PEARSON_getInstance(), CorrelationStat$Method$SPEARMAN_getInstance(), CorrelationStat$Method$KENDALL_getInstance()];\n }\n CorrelationStat$Method.values = CorrelationStat$Method$values;\n function CorrelationStat$Method$valueOf(name) {\n switch (name) {\n case 'PEARSON':\n return CorrelationStat$Method$PEARSON_getInstance();\n case 'SPEARMAN':\n return CorrelationStat$Method$SPEARMAN_getInstance();\n case 'KENDALL':\n return CorrelationStat$Method$KENDALL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Method.' + name);\n }\n }\n CorrelationStat$Method.valueOf_61zpoe$ = CorrelationStat$Method$valueOf;\n function CorrelationStat$Type(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CorrelationStat$Type_initFields() {\n CorrelationStat$Type_initFields = function () {\n };\n CorrelationStat$Type$FULL_instance = new CorrelationStat$Type('FULL', 0);\n CorrelationStat$Type$UPPER_instance = new CorrelationStat$Type('UPPER', 1);\n CorrelationStat$Type$LOWER_instance = new CorrelationStat$Type('LOWER', 2);\n }\n var CorrelationStat$Type$FULL_instance;\n function CorrelationStat$Type$FULL_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$FULL_instance;\n }\n var CorrelationStat$Type$UPPER_instance;\n function CorrelationStat$Type$UPPER_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$UPPER_instance;\n }\n var CorrelationStat$Type$LOWER_instance;\n function CorrelationStat$Type$LOWER_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$LOWER_instance;\n }\n CorrelationStat$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function CorrelationStat$Type$values() {\n return [CorrelationStat$Type$FULL_getInstance(), CorrelationStat$Type$UPPER_getInstance(), CorrelationStat$Type$LOWER_getInstance()];\n }\n CorrelationStat$Type.values = CorrelationStat$Type$values;\n function CorrelationStat$Type$valueOf(name) {\n switch (name) {\n case 'FULL':\n return CorrelationStat$Type$FULL_getInstance();\n case 'UPPER':\n return CorrelationStat$Type$UPPER_getInstance();\n case 'LOWER':\n return CorrelationStat$Type$LOWER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Type.' + name);\n }\n }\n CorrelationStat$Type.valueOf_61zpoe$ = CorrelationStat$Type$valueOf;\n function CorrelationStat$Companion() {\n CorrelationStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().COLOR, Stats_getInstance().CORR), to(Aes$Companion_getInstance().FILL, Stats_getInstance().CORR), to(Aes$Companion_getInstance().LABEL, Stats_getInstance().CORR)]);\n this.DEF_CORRELATION_METHOD = CorrelationStat$Method$PEARSON_getInstance();\n this.DEF_TYPE = CorrelationStat$Type$FULL_getInstance();\n this.DEF_FILL_DIAGONAL = true;\n this.DEF_THRESHOLD = 0.0;\n }\n CorrelationStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CorrelationStat$Companion_instance = null;\n function CorrelationStat$Companion_getInstance() {\n if (CorrelationStat$Companion_instance === null) {\n new CorrelationStat$Companion();\n }return CorrelationStat$Companion_instance;\n }\n CorrelationStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CorrelationStat',\n interfaces: [BaseStat]\n };\n function CorrelationUtil() {\n CorrelationUtil_instance = this;\n }\n CorrelationUtil.prototype.correlation_n2j75g$ = function (lxs, lys, correlationFunction) {\n var tmp$ = allFinite(lxs, lys);\n var xs = tmp$.component1()\n , ys = tmp$.component2();\n return correlationFunction(xs, ys);\n };\n function CorrelationUtil$createComparator$lambda(closure$indexMap) {\n return function (a, b) {\n var tmp$, tmp$_0;\n var tmp$_1;\n if ((tmp$ = closure$indexMap.get_11rb$(a)) != null)\n tmp$_1 = tmp$;\n else {\n throw IllegalStateException_init(('Unknown variable label ' + a + '.').toString());\n }\n var lhsWeight = tmp$_1;\n var tmp$_2;\n if ((tmp$_0 = closure$indexMap.get_11rb$(b)) != null)\n tmp$_2 = tmp$_0;\n else {\n throw IllegalStateException_init(('Unknown variable label ' + b + '.').toString());\n }\n var rhsWeight = tmp$_2;\n return lhsWeight - rhsWeight | 0;\n };\n }\n CorrelationUtil.prototype.createComparator_0 = function (vars) {\n var $receiver = withIndex(vars);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(to(item.value.label, item.index));\n }\n var indexMap = toMap(destination);\n return new Comparator(CorrelationUtil$createComparator$lambda(indexMap));\n };\n function CorrelationUtil$correlationMatrix$addCorrelation(closure$threshold, closure$knownVars, closure$corrData) {\n return function (varX, varY, v) {\n if (JsMath.abs(v) >= closure$threshold) {\n closure$knownVars.add_11rb$(varX);\n closure$knownVars.add_11rb$(varY);\n var $receiver = closure$corrData;\n var key = to(varX, varY);\n $receiver.put_xwzc9p$(key, v);\n }};\n }\n CorrelationUtil.prototype.correlationMatrix_ofg6u8$ = function (data, type, fillDiagonal, correlationFunction, threshold) {\n if (threshold === void 0)\n threshold = CorrelationStat$Companion_getInstance().DEF_THRESHOLD;\n var tmp$, tmp$_0;\n var $receiver = data.variables();\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (DataFrameUtil_getInstance().isNumeric_vede35$(data, element.name))\n destination.add_11rb$(element);\n }\n var numerics = destination;\n var knownVars = LinkedHashSet_init_0();\n var corrData = LinkedHashMap_init();\n var addCorrelation = CorrelationUtil$correlationMatrix$addCorrelation(threshold, knownVars, corrData);\n var i = 0;\n for (var tmp$_2 = numerics.iterator(); tmp$_2.hasNext(); ++i) {\n var vx = tmp$_2.next();\n var xs = data.getNumeric_8xm3sj$(vx);\n if (fillDiagonal) {\n addCorrelation(vx.label, vx.label, 1.0);\n }for (var j = 0; j < i; j++) {\n var vy = numerics.get_za3lpa$(j);\n var ys = data.getNumeric_8xm3sj$(vy);\n var c = this.correlation_n2j75g$(xs, ys, correlationFunction);\n if (type === CorrelationStat$Type$FULL_getInstance() || type === CorrelationStat$Type$LOWER_getInstance()) {\n addCorrelation(vx.label, vy.label, c);\n }if (type === CorrelationStat$Type$FULL_getInstance() || type === CorrelationStat$Type$UPPER_getInstance()) {\n addCorrelation(vy.label, vx.label, c);\n }}\n }\n var var1 = ArrayList_init();\n var var2 = ArrayList_init();\n var corr = ArrayList_init();\n var sortedVars = sortedWith(knownVars, this.createComparator_0(numerics));\n tmp$ = sortedVars.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n tmp$_0 = sortedVars.iterator();\n while (tmp$_0.hasNext()) {\n var y = tmp$_0.next();\n var1.add_11rb$(x);\n var2.add_11rb$(y);\n corr.add_11rb$(corrData.get_11rb$(to(x, y)));\n }\n }\n return DataFrame$DataFrame$Builder_init().putDiscrete_2l962d$(Stats_getInstance().X, var1).putDiscrete_2l962d$(Stats_getInstance().Y, var2).putNumeric_s1rqo9$(Stats_getInstance().CORR, corr).build();\n };\n CorrelationUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CorrelationUtil',\n interfaces: []\n };\n var CorrelationUtil_instance = null;\n function CorrelationUtil_getInstance() {\n if (CorrelationUtil_instance === null) {\n new CorrelationUtil();\n }return CorrelationUtil_instance;\n }\n function CountStat() {\n CountStat$Companion_getInstance();\n BaseStat.call(this, CountStat$Companion_getInstance().DEF_MAPPING_0);\n }\n CountStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n CountStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var valuesX = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var weight = BinStatUtil_getInstance().weightVector_5m8trb$(valuesX.size, data);\n var statX = ArrayList_init();\n var statCount = ArrayList_init();\n var countByX = CountStat$Companion_getInstance().countByX_0(valuesX, weight);\n tmp$ = countByX.keys.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n statX.add_11rb$(x);\n statCount.add_11rb$(ensureNotNull(countByX.get_11rb$(x)).get());\n }\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).build();\n };\n function CountStat$Companion() {\n CountStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().COUNT)]);\n }\n CountStat$Companion.prototype.countByX_0 = function (valuesX, weight) {\n var result = LinkedHashMap_init();\n for (var i = 0; i !== valuesX.size; ++i) {\n var x = valuesX.get_za3lpa$(i);\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n if (!result.containsKey_11rb$(ensureNotNull(x))) {\n var value = new MutableDouble(0.0);\n result.put_xwzc9p$(x, value);\n }ensureNotNull(result.get_11rb$(x)).getAndAdd_14dthe$(data.SeriesUtil.asFinite_z03gcz$(weight.get_za3lpa$(i), 0.0));\n }}\n return result;\n };\n CountStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CountStat$Companion_instance = null;\n function CountStat$Companion_getInstance() {\n if (CountStat$Companion_instance === null) {\n new CountStat$Companion();\n }return CountStat$Companion_instance;\n }\n CountStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CountStat',\n interfaces: [BaseStat]\n };\n function Density2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat.call(this, bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n }\n Density2dStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var yVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (xVector.isEmpty()) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }if (xVector.size !== yVector.size) {\n throw RuntimeException_init('len(x)= ' + toString(xVector.size) + ' and len(y)= ' + toString(yVector.size) + \" doesn't match!\");\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statDensity = ArrayList_init();\n var bandWidth = new Float64Array(2);\n bandWidth[0] = this.getBandWidthX_k9kaly$(xVector);\n bandWidth[1] = this.getBandWidthY_k9kaly$(yVector);\n var stepsX = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(xRange), this.nX);\n var stepsY = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(yRange), this.nY);\n var groupWeight = BinStatUtil_getInstance().weightVector_5m8trb$(xVector.size, data_0);\n var matrixX = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(xVector, stepsX, this.kernelFun, bandWidth[0], this.adjust, groupWeight));\n var matrixY = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(yVector, stepsY, this.kernelFun, bandWidth[1], this.adjust, groupWeight));\n var matrixFinal = matrixY.multiply_1dlv11$(matrixX.transpose());\n tmp$ = this.nY;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = this.nX;\n for (var col = 0; col < tmp$_0; col++) {\n statX.add_11rb$(stepsX.get_za3lpa$(col));\n statY.add_11rb$(stepsY.get_za3lpa$(row));\n statDensity.add_11rb$(matrixFinal.getEntry_vux9f0$(row, col) / data.SeriesUtil.sum_k9kaly$(groupWeight));\n }\n }\n if (this.isContour) {\n var zRange = data.SeriesUtil.range_l63ks6$(statDensity);\n tmp$_1 = ContourStatUtil_getInstance().computeLevels_kgz263$(zRange, this.binOptions);\n if (tmp$_1 == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$_1;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_cxleoh$(xRange, yRange, this.nX, this.nY, statDensity, levels);\n return Contour$Companion_getInstance().getPathDataFrame_9s3d7f$(levels, pathListByLevel);\n } else {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n }\n };\n Density2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dStat',\n interfaces: [AbstractDensity2dStat]\n };\n function Density2dfStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat.call(this, bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n }\n Density2dfStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var yVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (xVector.isEmpty()) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }if (xVector.size !== yVector.size) {\n throw RuntimeException_init('len(x)= ' + toString(xVector.size) + ' and len(y)= ' + toString(yVector.size) + \" doesn't match!\");\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statDensity = ArrayList_init();\n var bandWidth = new Float64Array(2);\n bandWidth[0] = this.getBandWidthX_k9kaly$(xVector);\n bandWidth[1] = this.getBandWidthY_k9kaly$(yVector);\n var stepsX = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(xRange), this.nX);\n var stepsY = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(yRange), this.nY);\n var groupWeight = BinStatUtil_getInstance().weightVector_5m8trb$(xVector.size, data_0);\n var matrixX = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(xVector, stepsX, this.kernelFun, bandWidth[0], this.adjust, groupWeight));\n var matrixY = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(yVector, stepsY, this.kernelFun, bandWidth[1], this.adjust, groupWeight));\n var matrixFinal = matrixY.multiply_1dlv11$(matrixX.transpose());\n tmp$ = this.nY;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = this.nX;\n for (var col = 0; col < tmp$_0; col++) {\n statX.add_11rb$(stepsX.get_za3lpa$(col));\n statY.add_11rb$(stepsY.get_za3lpa$(row));\n statDensity.add_11rb$(matrixFinal.getEntry_vux9f0$(row, col) / data.SeriesUtil.sum_k9kaly$(groupWeight));\n }\n }\n if (this.isContour) {\n var zRange = data.SeriesUtil.range_l63ks6$(statDensity);\n tmp$_1 = ContourStatUtil_getInstance().computeLevels_kgz263$(zRange, this.binOptions);\n if (tmp$_1 == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$_1;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_cxleoh$(xRange, yRange, this.nX, this.nY, statDensity, levels);\n var helper = new ContourFillHelper(xRange, yRange);\n var fillLevels = ContourFillHelper$Companion_getInstance().computeFillLevels_4v6zbb$(ensureNotNull(zRange), levels);\n var polygonListByFillLevel = helper.createPolygons_lrt0be$(pathListByLevel, levels, fillLevels);\n return Contour$Companion_getInstance().getPolygonDataFrame_dnsuee$(fillLevels.subList_vux9f0$(1, fillLevels.size), polygonListByFillLevel);\n } else {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n }\n };\n Density2dfStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dfStat',\n interfaces: [AbstractDensity2dStat]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function DensityStat(bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax) {\n DensityStat$Companion_getInstance();\n BaseStat.call(this, DensityStat$Companion_getInstance().DEF_MAPPING_0);\n this.bandWidth_0 = bandWidth;\n this.bandWidthMethod_0 = bandWidthMethod;\n this.adjust_0 = adjust;\n this.kernel_0 = kernel;\n this.n_0 = n;\n this.fullScalMax_0 = fullScalMax;\n if (!(this.n_0 <= 1024)) {\n var message = 'The input n = ' + this.n_0 + ' > ' + '1024' + ' is too large!';\n throw IllegalArgumentException_init(message.toString());\n }}\n DensityStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n function DensityStat$apply$lambda(it) {\n return it.first;\n }\n DensityStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var xs;\n var weights;\n if (data_0.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n var filtered = data.SeriesUtil.filterFinite_10sy24$(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X), data_0.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT));\n var xsFiltered = filtered.get_za3lpa$(0);\n var weightsFiltered = filtered.get_za3lpa$(1);\n var tmp$_5 = unzip(sortedWith(zip(xsFiltered, weightsFiltered), new Comparator(compareBy$lambda(DensityStat$apply$lambda))));\n var xsSorted = tmp$_5.component1()\n , weightsSorted = tmp$_5.component2();\n xs = xsSorted;\n weights = weightsSorted;\n } else {\n var $receiver = filterNotNull(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X));\n var destination = ArrayList_init();\n var tmp$_6;\n tmp$_6 = $receiver.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (isFinite(element))\n destination.add_11rb$(element);\n }\n xs = sorted(destination);\n var size = xs.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(1.0);\n }\n weights = list;\n }\n if (xs.isEmpty())\n return this.withEmptyStatValues();\n var rangeX = (tmp$ = statCtx.overallXRange()) != null ? tmp$ : new ClosedRange(-0.5, 0.5);\n var statX = DensityStatUtil_getInstance().createStepValues_1tlvto$(rangeX, this.n_0);\n var statDensity = ArrayList_init();\n var statCount = ArrayList_init();\n var statScaled = ArrayList_init();\n var bandWidth = (tmp$_0 = this.bandWidth_0) != null ? tmp$_0 : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_0, xs);\n var kernelFun = DensityStatUtil_getInstance().kernel_uyf859$(this.kernel_0);\n tmp$_1 = xs.size <= this.fullScalMax_0;\n if (tmp$_1 === true)\n tmp$_2 = DensityStatUtil_getInstance().densityFunctionFullScan_hztk2d$(xs, weights, kernelFun, bandWidth, this.adjust_0);\n else if (tmp$_1 === false)\n tmp$_2 = DensityStatUtil_getInstance().densityFunctionFast_hztk2d$(xs, weights, kernelFun, bandWidth, this.adjust_0);\n else\n tmp$_2 = Kotlin.noWhenBranchMatched();\n var densityFunction = tmp$_2;\n var nTotal = sum(weights);\n tmp$_3 = statX.iterator();\n while (tmp$_3.hasNext()) {\n var x = tmp$_3.next();\n var d = densityFunction(x);\n statCount.add_11rb$(d);\n statDensity.add_11rb$(d / nTotal);\n }\n var maxm = ensureNotNull(maxOrNull(statCount));\n tmp$_4 = statCount.iterator();\n while (tmp$_4.hasNext()) {\n var d_0 = tmp$_4.next();\n statScaled.add_11rb$(d_0 / maxm);\n }\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).putNumeric_s1rqo9$(Stats_getInstance().SCALED, statScaled).build();\n };\n function DensityStat$Kernel(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DensityStat$Kernel_initFields() {\n DensityStat$Kernel_initFields = function () {\n };\n DensityStat$Kernel$GAUSSIAN_instance = new DensityStat$Kernel('GAUSSIAN', 0);\n DensityStat$Kernel$RECTANGULAR_instance = new DensityStat$Kernel('RECTANGULAR', 1);\n DensityStat$Kernel$TRIANGULAR_instance = new DensityStat$Kernel('TRIANGULAR', 2);\n DensityStat$Kernel$BIWEIGHT_instance = new DensityStat$Kernel('BIWEIGHT', 3);\n DensityStat$Kernel$EPANECHNIKOV_instance = new DensityStat$Kernel('EPANECHNIKOV', 4);\n DensityStat$Kernel$OPTCOSINE_instance = new DensityStat$Kernel('OPTCOSINE', 5);\n DensityStat$Kernel$COSINE_instance = new DensityStat$Kernel('COSINE', 6);\n }\n var DensityStat$Kernel$GAUSSIAN_instance;\n function DensityStat$Kernel$GAUSSIAN_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$GAUSSIAN_instance;\n }\n var DensityStat$Kernel$RECTANGULAR_instance;\n function DensityStat$Kernel$RECTANGULAR_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$RECTANGULAR_instance;\n }\n var DensityStat$Kernel$TRIANGULAR_instance;\n function DensityStat$Kernel$TRIANGULAR_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$TRIANGULAR_instance;\n }\n var DensityStat$Kernel$BIWEIGHT_instance;\n function DensityStat$Kernel$BIWEIGHT_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$BIWEIGHT_instance;\n }\n var DensityStat$Kernel$EPANECHNIKOV_instance;\n function DensityStat$Kernel$EPANECHNIKOV_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$EPANECHNIKOV_instance;\n }\n var DensityStat$Kernel$OPTCOSINE_instance;\n function DensityStat$Kernel$OPTCOSINE_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$OPTCOSINE_instance;\n }\n var DensityStat$Kernel$COSINE_instance;\n function DensityStat$Kernel$COSINE_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$COSINE_instance;\n }\n DensityStat$Kernel.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kernel',\n interfaces: [Enum]\n };\n function DensityStat$Kernel$values() {\n return [DensityStat$Kernel$GAUSSIAN_getInstance(), DensityStat$Kernel$RECTANGULAR_getInstance(), DensityStat$Kernel$TRIANGULAR_getInstance(), DensityStat$Kernel$BIWEIGHT_getInstance(), DensityStat$Kernel$EPANECHNIKOV_getInstance(), DensityStat$Kernel$OPTCOSINE_getInstance(), DensityStat$Kernel$COSINE_getInstance()];\n }\n DensityStat$Kernel.values = DensityStat$Kernel$values;\n function DensityStat$Kernel$valueOf(name) {\n switch (name) {\n case 'GAUSSIAN':\n return DensityStat$Kernel$GAUSSIAN_getInstance();\n case 'RECTANGULAR':\n return DensityStat$Kernel$RECTANGULAR_getInstance();\n case 'TRIANGULAR':\n return DensityStat$Kernel$TRIANGULAR_getInstance();\n case 'BIWEIGHT':\n return DensityStat$Kernel$BIWEIGHT_getInstance();\n case 'EPANECHNIKOV':\n return DensityStat$Kernel$EPANECHNIKOV_getInstance();\n case 'OPTCOSINE':\n return DensityStat$Kernel$OPTCOSINE_getInstance();\n case 'COSINE':\n return DensityStat$Kernel$COSINE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.DensityStat.Kernel.' + name);\n }\n }\n DensityStat$Kernel.valueOf_61zpoe$ = DensityStat$Kernel$valueOf;\n function DensityStat$BandWidthMethod(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DensityStat$BandWidthMethod_initFields() {\n DensityStat$BandWidthMethod_initFields = function () {\n };\n DensityStat$BandWidthMethod$NRD0_instance = new DensityStat$BandWidthMethod('NRD0', 0);\n DensityStat$BandWidthMethod$NRD_instance = new DensityStat$BandWidthMethod('NRD', 1);\n }\n var DensityStat$BandWidthMethod$NRD0_instance;\n function DensityStat$BandWidthMethod$NRD0_getInstance() {\n DensityStat$BandWidthMethod_initFields();\n return DensityStat$BandWidthMethod$NRD0_instance;\n }\n var DensityStat$BandWidthMethod$NRD_instance;\n function DensityStat$BandWidthMethod$NRD_getInstance() {\n DensityStat$BandWidthMethod_initFields();\n return DensityStat$BandWidthMethod$NRD_instance;\n }\n DensityStat$BandWidthMethod.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BandWidthMethod',\n interfaces: [Enum]\n };\n function DensityStat$BandWidthMethod$values() {\n return [DensityStat$BandWidthMethod$NRD0_getInstance(), DensityStat$BandWidthMethod$NRD_getInstance()];\n }\n DensityStat$BandWidthMethod.values = DensityStat$BandWidthMethod$values;\n function DensityStat$BandWidthMethod$valueOf(name) {\n switch (name) {\n case 'NRD0':\n return DensityStat$BandWidthMethod$NRD0_getInstance();\n case 'NRD':\n return DensityStat$BandWidthMethod$NRD_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.DensityStat.BandWidthMethod.' + name);\n }\n }\n DensityStat$BandWidthMethod.valueOf_61zpoe$ = DensityStat$BandWidthMethod$valueOf;\n function DensityStat$Companion() {\n DensityStat$Companion_instance = this;\n this.DEF_KERNEL = DensityStat$Kernel$GAUSSIAN_getInstance();\n this.DEF_ADJUST = 1.0;\n this.DEF_N = 512;\n this.DEF_BW = DensityStat$BandWidthMethod$NRD0_getInstance();\n this.DEF_FULL_SCAN_MAX = 5000;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().DENSITY)]);\n this.MAX_N_0 = 1024;\n }\n DensityStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DensityStat$Companion_instance = null;\n function DensityStat$Companion_getInstance() {\n if (DensityStat$Companion_instance === null) {\n new DensityStat$Companion();\n }return DensityStat$Companion_instance;\n }\n DensityStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DensityStat',\n interfaces: [BaseStat]\n };\n function DensityStatUtil() {\n DensityStatUtil_instance = this;\n this.DEF_STEP_SIZE_0 = 0.5;\n }\n DensityStatUtil.prototype.stdDev_0 = function (data) {\n var tmp$, tmp$_0;\n var sum = 0.0;\n var counter = 0.0;\n tmp$ = data.iterator();\n while (tmp$.hasNext()) {\n var i = tmp$.next();\n sum += i;\n }\n var mean = sum / data.size;\n tmp$_0 = data.iterator();\n while (tmp$_0.hasNext()) {\n var i_0 = tmp$_0.next();\n var $receiver = i_0 - mean;\n counter += JsMath.pow($receiver, 2.0);\n }\n var x = counter / data.size;\n return JsMath.sqrt(x);\n };\n DensityStatUtil.prototype.bandWidth_whucba$ = function (bw, valuesX) {\n var tmp$;\n var mySize = valuesX.size;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = valuesX.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (data.SeriesUtil.isFinite_yrwdxb$(element))\n destination.add_11rb$(element);\n }\n var valuesXFinite = Kotlin.isType(tmp$ = destination, List) ? tmp$ : throwCCE();\n var dataSummary = FiveNumberSummary_init(valuesXFinite);\n var myIQR = dataSummary.thirdQuartile - dataSummary.firstQuartile;\n var myStdD = this.stdDev_0(valuesXFinite);\n switch (bw.name) {\n case 'NRD0':\n if (myIQR > 0) {\n var b = myIQR / 1.34;\n var tmp$_1 = 0.9 * JsMath.min(myStdD, b);\n var x = -0.2;\n return tmp$_1 * JsMath.pow(mySize, x);\n }\n if (myStdD > 0) {\n var tmp$_2 = 0.9 * myStdD;\n var x_0 = -0.2;\n return tmp$_2 * JsMath.pow(mySize, x_0);\n }\n break;\n case 'NRD':\n if (myIQR > 0) {\n var b_0 = myIQR / 1.34;\n var tmp$_3 = 1.06 * JsMath.min(myStdD, b_0);\n var x_1 = -0.2;\n return tmp$_3 * JsMath.pow(mySize, x_1);\n }\n if (myStdD > 0) {\n var tmp$_4 = 1.06 * myStdD;\n var x_2 = -0.2;\n return tmp$_4 * JsMath.pow(mySize, x_2);\n }\n break;\n }\n return 1.0;\n };\n function DensityStatUtil$kernel$lambda(value) {\n var x = 2 * math.PI;\n var tmp$ = 1 / JsMath.sqrt(x);\n var x_0 = -0.5 * JsMath.pow(value, 2.0);\n return tmp$ * JsMath.exp(x_0);\n }\n function DensityStatUtil$kernel$lambda_0(value) {\n return JsMath.abs(value) <= 1 ? 0.5 : 0.0;\n }\n function DensityStatUtil$kernel$lambda_1(value) {\n return JsMath.abs(value) <= 1 ? 1 - JsMath.abs(value) : 0.0;\n }\n function DensityStatUtil$kernel$lambda_2(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var $receiver = 1 - value * value;\n tmp$ = 0.9375 * JsMath.pow($receiver, 2.0);\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n function DensityStatUtil$kernel$lambda_3(value) {\n return JsMath.abs(value) <= 1 ? 0.75 * (1 - value * value) : 0.0;\n }\n function DensityStatUtil$kernel$lambda_4(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var tmp$_0 = math.PI / 4;\n var x = math.PI / 2 * value;\n tmp$ = tmp$_0 * JsMath.cos(x);\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n function DensityStatUtil$kernel$lambda_5(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var x = math.PI * value;\n tmp$ = (JsMath.cos(x) + 1) / 2;\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n DensityStatUtil.prototype.kernel_uyf859$ = function (ker) {\n var tmp$;\n switch (ker.name) {\n case 'GAUSSIAN':\n tmp$ = DensityStatUtil$kernel$lambda;\n break;\n case 'RECTANGULAR':\n tmp$ = DensityStatUtil$kernel$lambda_0;\n break;\n case 'TRIANGULAR':\n tmp$ = DensityStatUtil$kernel$lambda_1;\n break;\n case 'BIWEIGHT':\n tmp$ = DensityStatUtil$kernel$lambda_2;\n break;\n case 'EPANECHNIKOV':\n tmp$ = DensityStatUtil$kernel$lambda_3;\n break;\n case 'OPTCOSINE':\n tmp$ = DensityStatUtil$kernel$lambda_4;\n break;\n default:tmp$ = DensityStatUtil$kernel$lambda_5;\n break;\n }\n return tmp$;\n };\n function DensityStatUtil$densityFunctionFullScan$lambda(closure$xs, closure$ker, closure$h, closure$weights) {\n return function (x) {\n var sum = 0.0;\n for (var i = 0; i !== closure$xs.size; ++i) {\n sum += closure$ker((x - closure$xs.get_za3lpa$(i)) / closure$h) * closure$weights.get_za3lpa$(i);\n }\n return sum / closure$h;\n };\n }\n DensityStatUtil.prototype.densityFunctionFullScan_hztk2d$ = function (xs, weights, ker, bw, ad) {\n var h = bw * ad;\n return DensityStatUtil$densityFunctionFullScan$lambda(xs, ker, h, weights);\n };\n function DensityStatUtil$densityFunctionFast$lambda(closure$xs, closure$cutoff, closure$ker, closure$h, closure$weights) {\n return function (x) {\n var tmp$;\n var sum = 0.0;\n var from = binarySearch(closure$xs, x - closure$cutoff);\n if (from < 0) {\n from = (-from | 0) - 1 | 0;\n }var to = binarySearch(closure$xs, x + closure$cutoff);\n if (to < 0) {\n to = (-to | 0) - 1 | 0;\n }tmp$ = to;\n for (var i = from; i < tmp$; i++) {\n sum += closure$ker((x - closure$xs.get_za3lpa$(i)) / closure$h) * closure$weights.get_za3lpa$(i);\n }\n return sum / closure$h;\n };\n }\n DensityStatUtil.prototype.densityFunctionFast_hztk2d$ = function (xs, weights, ker, bw, ad) {\n var h = bw * ad;\n var cutoff = h * 5;\n return DensityStatUtil$densityFunctionFast$lambda(xs, cutoff, ker, h, weights);\n };\n DensityStatUtil.prototype.createStepValues_1tlvto$ = function (range, n) {\n var x = ArrayList_init();\n var min = range.lowerEnd;\n var max = range.upperEnd;\n var step;\n if (max === min) {\n max += this.DEF_STEP_SIZE_0;\n min -= this.DEF_STEP_SIZE_0;\n }step = (max - min) / (n - 1 | 0);\n for (var i = 0; i < n; i++) {\n x.add_11rb$(min + step * i);\n }\n return x;\n };\n DensityStatUtil.prototype.toKernel_61zpoe$ = function (method) {\n var tmp$;\n switch (method) {\n case 'gaussian':\n tmp$ = DensityStat$Kernel$GAUSSIAN_getInstance();\n break;\n case 'rectangular':\n case 'uniform':\n tmp$ = DensityStat$Kernel$RECTANGULAR_getInstance();\n break;\n case 'triangular':\n tmp$ = DensityStat$Kernel$TRIANGULAR_getInstance();\n break;\n case 'biweight':\n case 'quartic':\n tmp$ = DensityStat$Kernel$BIWEIGHT_getInstance();\n break;\n case 'epanechikov':\n case 'parabolic':\n tmp$ = DensityStat$Kernel$EPANECHNIKOV_getInstance();\n break;\n case 'optcosine':\n tmp$ = DensityStat$Kernel$OPTCOSINE_getInstance();\n break;\n case 'cosine':\n tmp$ = DensityStat$Kernel$COSINE_getInstance();\n break;\n default:throw IllegalArgumentException_init(\"Unsupported kernel method: '\" + method + \"'.\" + '\\n' + 'Use one of: gaussian, rectangular, triangular, biweight, epanechikov, optcosine, cos.');\n }\n return tmp$;\n };\n DensityStatUtil.prototype.toBandWidthMethod_61zpoe$ = function (bw) {\n var tmp$;\n switch (bw) {\n case 'nrd0':\n tmp$ = DensityStat$BandWidthMethod$NRD0_getInstance();\n break;\n case 'nrd':\n tmp$ = DensityStat$BandWidthMethod$NRD_getInstance();\n break;\n default:throw IllegalArgumentException_init(\"Unsupported bandwidth method: '\" + bw + \"'.\" + '\\n' + 'Use one of: nrd0, nrd.');\n }\n return tmp$;\n };\n DensityStatUtil.prototype.createRawMatrix_a6xq99$ = function (values, list, ker, bw, ad, weight) {\n var a = bw * ad;\n var n = values.size;\n var x = list.size;\n var array = Array_0(x);\n var tmp$;\n tmp$ = array.length - 1 | 0;\n for (var i = 0; i <= tmp$; i++) {\n array[i] = new Float64Array(n);\n }\n var result = array;\n for (var row = 0; row < x; row++) {\n for (var col = 0; col < n; col++) {\n var tmp$_0 = result[row];\n var tmp$_1 = ker((list.get_za3lpa$(row) - ensureNotNull(values.get_za3lpa$(col))) / a);\n var x_0 = ensureNotNull(weight.get_za3lpa$(col));\n tmp$_0[col] = tmp$_1 * JsMath.sqrt(x_0) / a;\n }\n }\n return result;\n };\n DensityStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DensityStatUtil',\n interfaces: []\n };\n var DensityStatUtil_instance = null;\n function DensityStatUtil_getInstance() {\n if (DensityStatUtil_instance === null) {\n new DensityStatUtil();\n }return DensityStatUtil_instance;\n }\n function FiveNumberSummary() {\n this.min = 0;\n this.max = 0;\n this.median = 0;\n this.firstQuartile = 0;\n this.thirdQuartile = 0;\n }\n FiveNumberSummary.prototype.medianAtPointer_0 = function (l, pointer) {\n var tmp$;\n var rint = round(pointer);\n if (pointer === rint) {\n tmp$ = l.get_za3lpa$(numberToInt(pointer));\n } else {\n tmp$ = (l.get_za3lpa$(numberToInt(JsMath.ceil(pointer))) + l.get_za3lpa$(numberToInt(JsMath.floor(pointer)))) / 2.0;\n }\n return tmp$;\n };\n FiveNumberSummary.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, FiveNumberSummary) ? tmp$_0 : throwCCE();\n return Kotlin.compareTo(ensureNotNull(that).min, this.min) === 0 && Kotlin.compareTo(that.max, this.max) === 0 && Kotlin.compareTo(that.median, this.median) === 0 && Kotlin.compareTo(that.firstQuartile, this.firstQuartile) === 0 && Kotlin.compareTo(that.thirdQuartile, this.thirdQuartile) === 0;\n };\n FiveNumberSummary.prototype.hashCode = function () {\n return hashCode([this.min, this.max, this.median, this.firstQuartile, this.thirdQuartile]);\n };\n FiveNumberSummary.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FiveNumberSummary',\n interfaces: []\n };\n function FiveNumberSummary_init(data, $this) {\n $this = $this || Object.create(FiveNumberSummary.prototype);\n FiveNumberSummary.call($this);\n var sorted = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(data);\n if (sorted.isEmpty()) {\n $this.thirdQuartile = kotlin_js_internal_DoubleCompanionObject.NaN;\n $this.firstQuartile = $this.thirdQuartile;\n $this.median = $this.firstQuartile;\n $this.max = $this.median;\n $this.min = $this.max;\n } else if (sorted.size === 1) {\n $this.thirdQuartile = sorted.get_za3lpa$(0);\n $this.firstQuartile = $this.thirdQuartile;\n $this.median = $this.firstQuartile;\n $this.max = $this.median;\n $this.min = $this.max;\n } else {\n var maxIndex = sorted.size - 1 | 0;\n $this.min = sorted.get_za3lpa$(0);\n $this.max = sorted.get_za3lpa$(maxIndex);\n $this.median = $this.medianAtPointer_0(sorted, maxIndex * 0.5);\n $this.firstQuartile = $this.medianAtPointer_0(sorted, maxIndex * 0.25);\n $this.thirdQuartile = $this.medianAtPointer_0(sorted, maxIndex * 0.75);\n }\n return $this;\n }\n function FiveNumberSummary_init_0(min, max, median, firstQuartile, thirdQuartile, $this) {\n $this = $this || Object.create(FiveNumberSummary.prototype);\n FiveNumberSummary.call($this);\n $this.min = min;\n $this.max = max;\n $this.median = median;\n $this.firstQuartile = firstQuartile;\n $this.thirdQuartile = thirdQuartile;\n return $this;\n }\n function MultiOrdering(myKeys) {\n this.myKeys_0 = myKeys;\n this.myIndices_0 = null;\n var tmp$;\n this.myIndices_0 = ArrayList_init_1(this.myKeys_0.size);\n tmp$ = this.myKeys_0;\n for (var i = 0; i !== tmp$.size; ++i) {\n this.myIndices_0.add_11rb$(i);\n }\n sortWith(this.myIndices_0, new Comparator(MultiOrdering_init$lambda(this)));\n }\n MultiOrdering.prototype.sortedCopy_bemo1h$ = function (l) {\n var tmp$;\n if (!(l.size === this.myIndices_0.size)) {\n var message = 'Expected size ' + toString(this.myIndices_0.size) + ' but was size ' + toString(l.size);\n throw IllegalArgumentException_init(message.toString());\n }var copy = ArrayList_init_1(this.myIndices_0.size);\n tmp$ = this.myIndices_0.iterator();\n while (tmp$.hasNext()) {\n var oldIndex = tmp$.next();\n var v = l.get_za3lpa$(oldIndex);\n copy.add_11rb$(v);\n }\n return copy;\n };\n MultiOrdering.prototype.sortedCopyOfKeys = function () {\n return this.sortedCopy_bemo1h$(this.myKeys_0);\n };\n function MultiOrdering_init$lambda(this$MultiOrdering) {\n return function (i, j) {\n var keyI = this$MultiOrdering.myKeys_0.get_za3lpa$(ensureNotNull(i));\n var keyJ = this$MultiOrdering.myKeys_0.get_za3lpa$(ensureNotNull(j));\n if (keyI === keyJ)\n return 0;\n else if (keyI == null)\n return -1;\n else if (keyJ == null)\n return 1;\n else\n return Kotlin.compareTo(keyI, keyJ);\n };\n }\n MultiOrdering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiOrdering',\n interfaces: []\n };\n function SimpleStatContext(myDataFrame) {\n this.myDataFrame_0 = myDataFrame;\n }\n SimpleStatContext.prototype.overallXRange = function () {\n return this.myDataFrame_0.range_8xm3sj$(TransformVar_getInstance().X);\n };\n SimpleStatContext.prototype.overallYRange = function () {\n return this.myDataFrame_0.range_8xm3sj$(TransformVar_getInstance().Y);\n };\n SimpleStatContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimpleStatContext',\n interfaces: [StatContext]\n };\n function SmoothStat(smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed) {\n SmoothStat$Companion_getInstance();\n BaseStat.call(this, SmoothStat$Companion_getInstance().DEF_MAPPING_0);\n this.smootherPointCount_0 = smootherPointCount;\n this.smoothingMethod_0 = smoothingMethod;\n this.confidenceLevel_0 = confidenceLevel;\n this.displayConfidenceInterval_0 = displayConfidenceInterval;\n this.span_0 = span;\n this.polynomialDegree_0 = polynomialDegree;\n this.loessCriticalSize_0 = loessCriticalSize;\n this.samplingSeed_0 = samplingSeed;\n }\n SmoothStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return BaseStat.prototype.hasDefaultMapping_896ixz$.call(this, aes) || (equals(aes, Aes$Companion_getInstance().YMIN) && this.displayConfidenceInterval_0) || (equals(aes, Aes$Companion_getInstance().YMAX) && this.displayConfidenceInterval_0);\n };\n SmoothStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n var tmp$;\n if (equals(aes, Aes$Companion_getInstance().YMIN)) {\n return Stats_getInstance().Y_MIN;\n }if (equals(aes, Aes$Companion_getInstance().YMAX)) {\n tmp$ = Stats_getInstance().Y_MAX;\n } else\n tmp$ = BaseStat.prototype.getDefaultMapping_896ixz$.call(this, aes);\n return tmp$;\n };\n function SmoothStat$Method(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function SmoothStat$Method_initFields() {\n SmoothStat$Method_initFields = function () {\n };\n SmoothStat$Method$LM_instance = new SmoothStat$Method('LM', 0);\n SmoothStat$Method$GLM_instance = new SmoothStat$Method('GLM', 1);\n SmoothStat$Method$GAM_instance = new SmoothStat$Method('GAM', 2);\n SmoothStat$Method$LOESS_instance = new SmoothStat$Method('LOESS', 3);\n SmoothStat$Method$RLM_instance = new SmoothStat$Method('RLM', 4);\n }\n var SmoothStat$Method$LM_instance;\n function SmoothStat$Method$LM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$LM_instance;\n }\n var SmoothStat$Method$GLM_instance;\n function SmoothStat$Method$GLM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$GLM_instance;\n }\n var SmoothStat$Method$GAM_instance;\n function SmoothStat$Method$GAM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$GAM_instance;\n }\n var SmoothStat$Method$LOESS_instance;\n function SmoothStat$Method$LOESS_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$LOESS_instance;\n }\n var SmoothStat$Method$RLM_instance;\n function SmoothStat$Method$RLM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$RLM_instance;\n }\n SmoothStat$Method.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Method',\n interfaces: [Enum]\n };\n function SmoothStat$Method$values() {\n return [SmoothStat$Method$LM_getInstance(), SmoothStat$Method$GLM_getInstance(), SmoothStat$Method$GAM_getInstance(), SmoothStat$Method$LOESS_getInstance(), SmoothStat$Method$RLM_getInstance()];\n }\n SmoothStat$Method.values = SmoothStat$Method$values;\n function SmoothStat$Method$valueOf(name) {\n switch (name) {\n case 'LM':\n return SmoothStat$Method$LM_getInstance();\n case 'GLM':\n return SmoothStat$Method$GLM_getInstance();\n case 'GAM':\n return SmoothStat$Method$GAM_getInstance();\n case 'LOESS':\n return SmoothStat$Method$LOESS_getInstance();\n case 'RLM':\n return SmoothStat$Method$RLM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.SmoothStat.Method.' + name);\n }\n }\n SmoothStat$Method.valueOf_61zpoe$ = SmoothStat$Method$valueOf;\n function SmoothStat$Companion() {\n SmoothStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n this.DEF_EVAL_POINT_COUNT = 80;\n this.DEF_SMOOTHING_METHOD = SmoothStat$Method$LM_getInstance();\n this.DEF_CONFIDENCE_LEVEL = 0.95;\n this.DEF_DISPLAY_CONFIDENCE_INTERVAL = true;\n this.DEF_SPAN = 0.5;\n this.DEF_DEG = 1;\n this.DEF_LOESS_CRITICAL_SIZE = 1000;\n this.DEF_SAMPLING_SEED = L37;\n }\n SmoothStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SmoothStat$Companion_instance = null;\n function SmoothStat$Companion_getInstance() {\n if (SmoothStat$Companion_instance === null) {\n new SmoothStat$Companion();\n }return SmoothStat$Companion_instance;\n }\n SmoothStat.prototype.consumes = function () {\n return listOf_0(Aes$Companion_getInstance().Y);\n };\n SmoothStat.prototype.needSampling_za3lpa$ = function (rowCount) {\n if (this.smoothingMethod_0 !== SmoothStat$Method$LOESS_getInstance()) {\n return false;\n }if (rowCount <= this.loessCriticalSize_0) {\n return false;\n }return true;\n };\n SmoothStat.prototype.applySampling_0 = function (data, messageConsumer) {\n var msg = 'LOESS drew a random sample with max_n=' + this.loessCriticalSize_0 + ', seed=' + this.samplingSeed_0.toString();\n messageConsumer(msg);\n return SamplingUtil_getInstance().sampleWithoutReplacement_egh5ya$(this.loessCriticalSize_0, Random_0(this.samplingSeed_0), data);\n };\n SmoothStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var data_1 = data_0;\n if (this.needSampling_za3lpa$(data_1.rowCount())) {\n data_1 = this.applySampling_0(data_1, messageConsumer);\n }var valuesY = data_1.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (valuesY.size < 3) {\n return this.withEmptyStatValues();\n }var valuesX;\n if (data_1.has_8xm3sj$(TransformVar_getInstance().X)) {\n valuesX = data_1.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n } else {\n valuesX = ArrayList_init();\n for (var i = 0; i !== valuesY.size; ++i) {\n valuesX.add_11rb$(i);\n }\n }\n if (data.SeriesUtil.range_l63ks6$(valuesX) == null)\n return this.withEmptyStatValues();\n var statX;\n var statY;\n var statMinY;\n var statMaxY;\n var statSE;\n var statValues = this.applySmoothing_0(valuesX, valuesY);\n statX = ensureNotNull(statValues.get_11rb$(Stats_getInstance().X));\n statY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y));\n statMinY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y_MIN));\n statMaxY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y_MAX));\n statSE = ensureNotNull(statValues.get_11rb$(Stats_getInstance().SE));\n var statData = DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY);\n if (this.displayConfidenceInterval_0) {\n statData.putNumeric_s1rqo9$(Stats_getInstance().Y_MIN, statMinY).putNumeric_s1rqo9$(Stats_getInstance().Y_MAX, statMaxY).putNumeric_s1rqo9$(Stats_getInstance().SE, statSE);\n }return statData.build();\n };\n SmoothStat.prototype.applySmoothing_0 = function (valuesX, valuesY) {\n var tmp$, tmp$_0, tmp$_1;\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statMinY = ArrayList_init();\n var statMaxY = ArrayList_init();\n var statSE = ArrayList_init();\n var result = HashMap_init();\n var key = Stats_getInstance().X;\n result.put_xwzc9p$(key, statX);\n var key_0 = Stats_getInstance().Y;\n result.put_xwzc9p$(key_0, statY);\n var key_1 = Stats_getInstance().Y_MIN;\n result.put_xwzc9p$(key_1, statMinY);\n var key_2 = Stats_getInstance().Y_MAX;\n result.put_xwzc9p$(key_2, statMaxY);\n var key_3 = Stats_getInstance().SE;\n result.put_xwzc9p$(key_3, statSE);\n switch (this.smoothingMethod_0.name) {\n case 'LM':\n if (!(this.polynomialDegree_0 >= 1)) {\n var message = 'Degree of polynomial regression must be at least 1';\n throw IllegalArgumentException_init(message.toString());\n }\n if (this.polynomialDegree_0 === 1) {\n tmp$ = new LinearRegression(valuesX, valuesY, this.confidenceLevel_0);\n } else {\n if (PolynomialRegression$Companion_getInstance().canBeComputed_fgqkrm$(valuesX, valuesY, this.polynomialDegree_0)) {\n tmp$ = new PolynomialRegression(valuesX, valuesY, this.confidenceLevel_0, this.polynomialDegree_0);\n } else {\n return result;\n }\n }\n\n break;\n case 'LOESS':\n var evaluator = new LocalPolynomialRegression(valuesX, valuesY, this.confidenceLevel_0, this.span_0);\n if (evaluator.canCompute) {\n tmp$ = evaluator;\n } else {\n return result;\n }\n\n break;\n default:throw IllegalArgumentException_init('Unsupported smoother method: ' + this.smoothingMethod_0 + \" (only 'lm' and 'loess' methods are currently available)\");\n }\n var regression = tmp$;\n tmp$_0 = data.SeriesUtil.range_l63ks6$(valuesX);\n if (tmp$_0 == null) {\n return result;\n }var rangeX = tmp$_0;\n var startX = rangeX.lowerEnd;\n var spanX = rangeX.upperEnd - startX;\n var stepX = spanX / (this.smootherPointCount_0 - 1 | 0);\n tmp$_1 = this.smootherPointCount_0;\n for (var i = 0; i < tmp$_1; i++) {\n var x = startX + i * stepX;\n var eval_0 = regression.evalX_14dthe$(coerceIn(x, rangeX.lowerEnd, rangeX.upperEnd));\n statX.add_11rb$(x);\n statY.add_11rb$(eval_0.y);\n statMinY.add_11rb$(eval_0.ymin);\n statMaxY.add_11rb$(eval_0.ymax);\n statSE.add_11rb$(eval_0.se);\n }\n return result;\n };\n SmoothStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SmoothStat',\n interfaces: [BaseStat]\n };\n function Stats() {\n Stats_instance = this;\n this.X = new DataFrame$Variable('..x..', DataFrame$Variable$Source$STAT_getInstance(), 'x');\n this.Y = new DataFrame$Variable('..y..', DataFrame$Variable$Source$STAT_getInstance(), 'y');\n this.COUNT = new DataFrame$Variable('..count..', DataFrame$Variable$Source$STAT_getInstance(), 'count');\n this.DENSITY = new DataFrame$Variable('..density..', DataFrame$Variable$Source$STAT_getInstance(), 'density');\n this.Y_MIN = new DataFrame$Variable('..ymin..', DataFrame$Variable$Source$STAT_getInstance(), 'y min');\n this.Y_MAX = new DataFrame$Variable('..ymax..', DataFrame$Variable$Source$STAT_getInstance(), 'y max');\n this.SE = new DataFrame$Variable('..se..', DataFrame$Variable$Source$STAT_getInstance(), 'standard error');\n this.LEVEL = new DataFrame$Variable('..level..', DataFrame$Variable$Source$STAT_getInstance(), 'level');\n this.LOWER = new DataFrame$Variable('..lower..', DataFrame$Variable$Source$STAT_getInstance(), 'lower');\n this.MIDDLE = new DataFrame$Variable('..middle..', DataFrame$Variable$Source$STAT_getInstance(), 'middle');\n this.UPPER = new DataFrame$Variable('..upper..', DataFrame$Variable$Source$STAT_getInstance(), 'upper');\n this.WIDTH = new DataFrame$Variable('..width..', DataFrame$Variable$Source$STAT_getInstance(), 'width');\n this.CORR = new DataFrame$Variable('..corr..', DataFrame$Variable$Source$STAT_getInstance(), 'corr');\n this.CORR_ABS = new DataFrame$Variable('..corr_abs..', DataFrame$Variable$Source$STAT_getInstance(), 'corr_abs');\n this.SCALED = new DataFrame$Variable('..scaled..', DataFrame$Variable$Source$STAT_getInstance(), 'scaled');\n this.GROUP = new DataFrame$Variable('..group..', DataFrame$Variable$Source$STAT_getInstance(), 'group');\n this.IDENTITY = new Stats$IdentityStat();\n var tmp$;\n var variableList = listOf([this.X, this.Y, this.COUNT, this.DENSITY, this.Y_MIN, this.Y_MAX, this.SE, this.LEVEL, this.LOWER, this.MIDDLE, this.UPPER, this.WIDTH, this.SCALED, this.GROUP, this.CORR, this.CORR_ABS]);\n var result = HashMap_init();\n tmp$ = variableList.iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n var key = variable.name;\n result.put_xwzc9p$(key, variable);\n }\n this.VARS_0 = result;\n }\n Stats.prototype.isStatVar_61zpoe$ = function (varName) {\n return this.VARS_0.containsKey_11rb$(varName);\n };\n Stats.prototype.statVar_61zpoe$ = function (varName) {\n if (!this.VARS_0.containsKey_11rb$(varName)) {\n var message = 'Unknown stat variable ' + varName;\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.VARS_0.get_11rb$(varName));\n };\n Stats.prototype.defaultMapping_qbwusa$ = function (stat) {\n var tmp$;\n var map = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (stat.hasDefaultMapping_896ixz$(aes)) {\n var variable = stat.getDefaultMapping_896ixz$(aes);\n map.put_xwzc9p$(aes, variable);\n }}\n return map;\n };\n Stats.prototype.count = function () {\n return new CountStat();\n };\n Stats.prototype.bin_yyf5ez$ = function (binCount, binWidth, center, boundary) {\n if (binCount === void 0)\n binCount = 30;\n if (binWidth === void 0)\n binWidth = null;\n if (center === void 0)\n center = null;\n if (boundary === void 0)\n boundary = null;\n var xPosKind = BinStat$XPosKind$NONE_getInstance();\n var xPosValue = 0.0;\n if (boundary != null) {\n xPosKind = BinStat$XPosKind$BOUNDARY_getInstance();\n xPosValue = boundary;\n } else if (center != null) {\n xPosKind = BinStat$XPosKind$CENTER_getInstance();\n xPosValue = center;\n }return new BinStat(binCount, binWidth, xPosKind, xPosValue);\n };\n Stats.prototype.smooth_aam2id$ = function (smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed) {\n if (smootherPointCount === void 0)\n smootherPointCount = 80;\n if (smoothingMethod === void 0)\n smoothingMethod = SmoothStat$Companion_getInstance().DEF_SMOOTHING_METHOD;\n if (confidenceLevel === void 0)\n confidenceLevel = SmoothStat$Companion_getInstance().DEF_CONFIDENCE_LEVEL;\n if (displayConfidenceInterval === void 0)\n displayConfidenceInterval = SmoothStat$Companion_getInstance().DEF_DISPLAY_CONFIDENCE_INTERVAL;\n if (span === void 0)\n span = SmoothStat$Companion_getInstance().DEF_SPAN;\n if (polynomialDegree === void 0)\n polynomialDegree = 1;\n if (loessCriticalSize === void 0)\n loessCriticalSize = 1000;\n if (samplingSeed === void 0)\n samplingSeed = SmoothStat$Companion_getInstance().DEF_SAMPLING_SEED;\n return new SmoothStat(smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed);\n };\n Stats.prototype.corr_6cvmjw$ = function (correlationMethod, type, fillDiagonal, threshold) {\n if (correlationMethod === void 0)\n correlationMethod = CorrelationStat$Companion_getInstance().DEF_CORRELATION_METHOD;\n if (type === void 0)\n type = CorrelationStat$Companion_getInstance().DEF_TYPE;\n if (fillDiagonal === void 0)\n fillDiagonal = CorrelationStat$Companion_getInstance().DEF_FILL_DIAGONAL;\n if (threshold === void 0)\n threshold = CorrelationStat$Companion_getInstance().DEF_THRESHOLD;\n return new CorrelationStat(correlationMethod, type, fillDiagonal, threshold);\n };\n Stats.prototype.contour_tvwy6j$ = function (binCount, binWidth) {\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = null;\n return new ContourStat(binCount, binWidth);\n };\n Stats.prototype.contourf_tvwy6j$ = function (binCount, binWidth) {\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = null;\n return new ContourfStat(binCount, binWidth);\n };\n Stats.prototype.boxplot_8555vt$ = function (whiskerIQRRatio, computeWidth) {\n if (whiskerIQRRatio === void 0)\n whiskerIQRRatio = BoxplotStat$Companion_getInstance().DEF_WHISKER_IQR_RATIO;\n if (computeWidth === void 0)\n computeWidth = BoxplotStat$Companion_getInstance().DEF_COMPUTE_WIDTH;\n return new BoxplotStat(whiskerIQRRatio, computeWidth);\n };\n Stats.prototype.density_s1yna4$ = function (bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax) {\n if (bandWidth === void 0)\n bandWidth = null;\n if (bandWidthMethod === void 0)\n bandWidthMethod = DensityStat$Companion_getInstance().DEF_BW;\n if (adjust === void 0)\n adjust = DensityStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = DensityStat$Companion_getInstance().DEF_KERNEL;\n if (n === void 0)\n n = 512;\n if (fullScalMax === void 0)\n fullScalMax = 5000;\n return new DensityStat(bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax);\n };\n Stats.prototype.density2d_izm592$ = function (bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n if (bandWidthX === void 0)\n bandWidthX = null;\n if (bandWidthY === void 0)\n bandWidthY = null;\n if (bandWidthMethod === void 0)\n bandWidthMethod = AbstractDensity2dStat$Companion_getInstance().DEF_BW;\n if (adjust === void 0)\n adjust = AbstractDensity2dStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = AbstractDensity2dStat$Companion_getInstance().DEF_KERNEL;\n if (nX === void 0)\n nX = 100;\n if (nY === void 0)\n nY = 100;\n if (isContour === void 0)\n isContour = AbstractDensity2dStat$Companion_getInstance().DEF_CONTOUR;\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = AbstractDensity2dStat$Companion_getInstance().DEF_BIN_WIDTH;\n return new Density2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n };\n Stats.prototype.density2df_izm592$ = function (bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n if (bandWidthX === void 0)\n bandWidthX = null;\n if (bandWidthY === void 0)\n bandWidthY = null;\n if (adjust === void 0)\n adjust = AbstractDensity2dStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = AbstractDensity2dStat$Companion_getInstance().DEF_KERNEL;\n if (nX === void 0)\n nX = 100;\n if (nY === void 0)\n nY = 100;\n if (isContour === void 0)\n isContour = AbstractDensity2dStat$Companion_getInstance().DEF_CONTOUR;\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = AbstractDensity2dStat$Companion_getInstance().DEF_BIN_WIDTH;\n return new Density2dfStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n };\n function Stats$IdentityStat() {\n BaseStat.call(this, emptyMap());\n }\n Stats$IdentityStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n };\n Stats$IdentityStat.prototype.consumes = function () {\n return emptyList();\n };\n Stats$IdentityStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityStat',\n interfaces: [BaseStat]\n };\n Stats.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Stats',\n interfaces: []\n };\n var Stats_instance = null;\n function Stats_getInstance() {\n if (Stats_instance === null) {\n new Stats();\n }return Stats_instance;\n }\n function AbstractRealDistribution() {\n AbstractRealDistribution$Companion_getInstance();\n this.solverAbsoluteAccuracy_ojqt9g$_0 = AbstractRealDistribution$Companion_getInstance().SOLVER_DEFAULT_ABSOLUTE_ACCURACY;\n }\n Object.defineProperty(AbstractRealDistribution.prototype, 'solverAbsoluteAccuracy', {\n configurable: true,\n get: function () {\n return this.solverAbsoluteAccuracy_ojqt9g$_0;\n }\n });\n AbstractRealDistribution.prototype.cumulativeProbability_lu1900$ = function (x0, x1) {\n if (x0 > x1) {\n throw IllegalStateException_init(('NumberIsTooLarge - x0:' + x0 + ', x1:' + x1).toString());\n }return this.cumulativeProbability_14dthe$(x1) - this.cumulativeProbability_14dthe$(x0);\n };\n function AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral(this$AbstractRealDistribution, closure$p) {\n this.this$AbstractRealDistribution = this$AbstractRealDistribution;\n this.closure$p = closure$p;\n }\n AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral.prototype.value_14dthe$ = function (x) {\n return this.this$AbstractRealDistribution.cumulativeProbability_14dthe$(x) - this.closure$p;\n };\n AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [UnivariateFunction]\n };\n AbstractRealDistribution.prototype.inverseCumulativeProbability_14dthe$ = function (p) {\n if (p < 0.0 || p > 1.0) {\n throw IllegalStateException_init(('OutOfRange [0, 1] - p' + p).toString());\n }var lowerBound = this.supportLowerBound;\n if (p === 0.0) {\n return lowerBound;\n }var upperBound = this.supportUpperBound;\n if (p === 1.0) {\n return upperBound;\n }var mu = this.numericalMean;\n var x = this.numericalVariance;\n var sig = JsMath.sqrt(x);\n var chebyshevApplies;\n chebyshevApplies = !(isInfinite(mu) || isNaN_0(mu) || isInfinite(sig) || isNaN_0(sig));\n if (lowerBound === kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY) {\n if (chebyshevApplies) {\n var x_0 = (1.0 - p) / p;\n lowerBound = mu - sig * JsMath.sqrt(x_0);\n } else {\n lowerBound = -1.0;\n while (this.cumulativeProbability_14dthe$(lowerBound) >= p) {\n lowerBound *= 2.0;\n }\n }\n }if (upperBound === kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY) {\n if (chebyshevApplies) {\n var x_1 = p / (1.0 - p);\n upperBound = mu + sig * JsMath.sqrt(x_1);\n } else {\n upperBound = 1.0;\n while (this.cumulativeProbability_14dthe$(upperBound) < p) {\n upperBound *= 2.0;\n }\n }\n }var toSolve = new AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral(this, p);\n var x_2 = UnivariateSolverUtils_getInstance().solve_wb66u3$(toSolve, lowerBound, upperBound, this.solverAbsoluteAccuracy);\n if (!this.isSupportConnected) {\n var dx = this.solverAbsoluteAccuracy;\n if (x_2 - dx >= this.supportLowerBound) {\n var px = this.cumulativeProbability_14dthe$(x_2);\n if (this.cumulativeProbability_14dthe$(x_2 - dx) === px) {\n upperBound = x_2;\n while (upperBound - lowerBound > dx) {\n var midPoint = 0.5 * (lowerBound + upperBound);\n if (this.cumulativeProbability_14dthe$(midPoint) < px) {\n lowerBound = midPoint;\n } else {\n upperBound = midPoint;\n }\n }\n return upperBound;\n }}}return x_2;\n };\n function AbstractRealDistribution$Companion() {\n AbstractRealDistribution$Companion_instance = this;\n this.SOLVER_DEFAULT_ABSOLUTE_ACCURACY = 1.0E-6;\n this.serialVersionUID_0 = L_38038050983108802;\n }\n AbstractRealDistribution$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractRealDistribution$Companion_instance = null;\n function AbstractRealDistribution$Companion_getInstance() {\n if (AbstractRealDistribution$Companion_instance === null) {\n new AbstractRealDistribution$Companion();\n }return AbstractRealDistribution$Companion_instance;\n }\n AbstractRealDistribution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractRealDistribution',\n interfaces: [RealDistribution]\n };\n function AbstractUnivariateSolver() {\n }\n AbstractUnivariateSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractUnivariateSolver',\n interfaces: [UnivariateSolver, BaseAbstractUnivariateSolver]\n };\n function AbstractUnivariateSolver_init(absoluteAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver_init(absoluteAccuracy, $this);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AbstractUnivariateSolver_init_0(relativeAccuracy, absoluteAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, relativeAccuracy, absoluteAccuracy);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AbstractUnivariateSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, relativeAccuracy, absoluteAccuracy, functionValueAccuracy);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AllowedSolution(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function AllowedSolution_initFields() {\n AllowedSolution_initFields = function () {\n };\n AllowedSolution$ANY_SIDE_instance = new AllowedSolution('ANY_SIDE', 0);\n AllowedSolution$LEFT_SIDE_instance = new AllowedSolution('LEFT_SIDE', 1);\n AllowedSolution$RIGHT_SIDE_instance = new AllowedSolution('RIGHT_SIDE', 2);\n AllowedSolution$BELOW_SIDE_instance = new AllowedSolution('BELOW_SIDE', 3);\n AllowedSolution$ABOVE_SIDE_instance = new AllowedSolution('ABOVE_SIDE', 4);\n }\n var AllowedSolution$ANY_SIDE_instance;\n function AllowedSolution$ANY_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$ANY_SIDE_instance;\n }\n var AllowedSolution$LEFT_SIDE_instance;\n function AllowedSolution$LEFT_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$LEFT_SIDE_instance;\n }\n var AllowedSolution$RIGHT_SIDE_instance;\n function AllowedSolution$RIGHT_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$RIGHT_SIDE_instance;\n }\n var AllowedSolution$BELOW_SIDE_instance;\n function AllowedSolution$BELOW_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$BELOW_SIDE_instance;\n }\n var AllowedSolution$ABOVE_SIDE_instance;\n function AllowedSolution$ABOVE_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$ABOVE_SIDE_instance;\n }\n AllowedSolution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AllowedSolution',\n interfaces: [Enum]\n };\n function AllowedSolution$values() {\n return [AllowedSolution$ANY_SIDE_getInstance(), AllowedSolution$LEFT_SIDE_getInstance(), AllowedSolution$RIGHT_SIDE_getInstance(), AllowedSolution$BELOW_SIDE_getInstance(), AllowedSolution$ABOVE_SIDE_getInstance()];\n }\n AllowedSolution.values = AllowedSolution$values;\n function AllowedSolution$valueOf(name) {\n switch (name) {\n case 'ANY_SIDE':\n return AllowedSolution$ANY_SIDE_getInstance();\n case 'LEFT_SIDE':\n return AllowedSolution$LEFT_SIDE_getInstance();\n case 'RIGHT_SIDE':\n return AllowedSolution$RIGHT_SIDE_getInstance();\n case 'BELOW_SIDE':\n return AllowedSolution$BELOW_SIDE_getInstance();\n case 'ABOVE_SIDE':\n return AllowedSolution$ABOVE_SIDE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.math3.AllowedSolution.' + name);\n }\n }\n AllowedSolution.valueOf_61zpoe$ = AllowedSolution$valueOf;\n function BaseAbstractUnivariateSolver(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n BaseAbstractUnivariateSolver$Companion_getInstance();\n if (functionValueAccuracy === void 0)\n functionValueAccuracy = BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_FUNCTION_VALUE_ACCURACY_0;\n this.relativeAccuracy_uztt24$_0 = relativeAccuracy;\n this.absoluteAccuracy_8af9zt$_0 = absoluteAccuracy;\n this.functionValueAccuracy_drq8h3$_0 = functionValueAccuracy;\n this.myEvaluations_xyk8ps$_0 = new Incrementor();\n this.min_3rehp5$_0 = 0;\n this.max_3rec07$_0 = 0;\n this.startValue_pn384a$_0 = 0;\n this.function_54gwsx$_0 = null;\n this.evaluations_io7904$_0 = this.myEvaluations_xyk8ps$_0.count;\n }\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'relativeAccuracy', {\n get: function () {\n return this.relativeAccuracy_uztt24$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'absoluteAccuracy', {\n get: function () {\n return this.absoluteAccuracy_8af9zt$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'functionValueAccuracy', {\n get: function () {\n return this.functionValueAccuracy_drq8h3$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'min', {\n configurable: true,\n get: function () {\n return this.min_3rehp5$_0;\n },\n set: function (min) {\n this.min_3rehp5$_0 = min;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'max', {\n configurable: true,\n get: function () {\n return this.max_3rec07$_0;\n },\n set: function (max) {\n this.max_3rec07$_0 = max;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'startValue', {\n configurable: true,\n get: function () {\n return this.startValue_pn384a$_0;\n },\n set: function (startValue) {\n this.startValue_pn384a$_0 = startValue;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'maxEvaluations', {\n configurable: true,\n get: function () {\n return this.myEvaluations_xyk8ps$_0.maximalCount;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'evaluations', {\n configurable: true,\n get: function () {\n return this.evaluations_io7904$_0;\n }\n });\n BaseAbstractUnivariateSolver.prototype.computeObjectiveValue_14dthe$ = function (point) {\n this.incrementEvaluationCount();\n return ensureNotNull(this.function_54gwsx$_0).value_14dthe$(point);\n };\n BaseAbstractUnivariateSolver.prototype.setup_4y3h91$ = function (maxEval, f, min, max, startValue) {\n this.min = min;\n this.max = max;\n this.startValue = startValue;\n this.function_54gwsx$_0 = f;\n this.myEvaluations_xyk8ps$_0.maximalCount = maxEval;\n this.myEvaluations_xyk8ps$_0.resetCount();\n };\n BaseAbstractUnivariateSolver.prototype.solve_4y3h91$ = function (maxEval, f, min, max, startValue) {\n this.setup_4y3h91$(maxEval, f, min, max, startValue);\n return this.doSolve();\n };\n BaseAbstractUnivariateSolver.prototype.solve_rmnly1$ = function (maxEval, f, min, max) {\n return this.solve_4y3h91$(maxEval, f, min, max, min + 0.5 * (max - min));\n };\n BaseAbstractUnivariateSolver.prototype.solve_t5uqbd$ = function (maxEval, f, startValue) {\n return this.solve_4y3h91$(maxEval, f, kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN, startValue);\n };\n BaseAbstractUnivariateSolver.prototype.isBracketing_lu1900$ = function (lower, upper) {\n return UnivariateSolverUtils_getInstance().isBracketing_ljmp9$(ensureNotNull(this.function_54gwsx$_0), lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.isSequence_yvo9jy$ = function (start, mid, end) {\n return UnivariateSolverUtils_getInstance().isSequence_yvo9jy$(start, mid, end);\n };\n BaseAbstractUnivariateSolver.prototype.verifyInterval_lu1900$ = function (lower, upper) {\n UnivariateSolverUtils_getInstance().verifyInterval_lu1900$(lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.verifySequence_yvo9jy$ = function (lower, initial, upper) {\n UnivariateSolverUtils_getInstance().verifySequence_yvo9jy$(lower, initial, upper);\n };\n BaseAbstractUnivariateSolver.prototype.verifyBracketing_lu1900$ = function (lower, upper) {\n UnivariateSolverUtils_getInstance().verifyBracketing_ljmp9$(ensureNotNull(this.function_54gwsx$_0), lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.incrementEvaluationCount = function () {\n this.myEvaluations_xyk8ps$_0.incrementCount();\n };\n function BaseAbstractUnivariateSolver$Companion() {\n BaseAbstractUnivariateSolver$Companion_instance = this;\n this.DEFAULT_RELATIVE_ACCURACY_0 = 1.0E-14;\n this.DEFAULT_FUNCTION_VALUE_ACCURACY_0 = 1.0E-15;\n }\n BaseAbstractUnivariateSolver$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BaseAbstractUnivariateSolver$Companion_instance = null;\n function BaseAbstractUnivariateSolver$Companion_getInstance() {\n if (BaseAbstractUnivariateSolver$Companion_instance === null) {\n new BaseAbstractUnivariateSolver$Companion();\n }return BaseAbstractUnivariateSolver$Companion_instance;\n }\n BaseAbstractUnivariateSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseAbstractUnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function BaseAbstractUnivariateSolver_init(absoluteAccuracy, $this) {\n $this = $this || Object.create(BaseAbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_RELATIVE_ACCURACY_0, absoluteAccuracy, BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_FUNCTION_VALUE_ACCURACY_0);\n return $this;\n }\n function BaseUnivariateSolver() {\n }\n BaseUnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BaseUnivariateSolver',\n interfaces: []\n };\n function Beta() {\n Beta_instance = this;\n this.DEFAULT_EPSILON_0 = 1.0E-14;\n }\n Beta.prototype.regularizedBeta_88ee24$ = function (x, a, b, maxIterations) {\n return this.regularizedBeta_tychlm$(x, a, b, this.DEFAULT_EPSILON_0, maxIterations);\n };\n function Beta$regularizedBeta$ObjectLiteral(closure$b, closure$a) {\n this.closure$b = closure$b;\n this.closure$a = closure$a;\n ContinuedFraction.call(this);\n }\n Beta$regularizedBeta$ObjectLiteral.prototype.getB_5wr77w$ = function (n, x) {\n var ret;\n var m;\n if (n % 2 === 0) {\n m = n / 2.0;\n ret = m * (this.closure$b - m) * x / ((this.closure$a + 2 * m - 1) * (this.closure$a + 2 * m));\n } else {\n m = (n - 1.0) / 2.0;\n ret = -((this.closure$a + m) * (this.closure$a + this.closure$b + m) * x) / ((this.closure$a + 2 * m) * (this.closure$a + 2 * m + 1.0));\n }\n return ret;\n };\n Beta$regularizedBeta$ObjectLiteral.prototype.getA_5wr77w$ = function (n, x) {\n return 1.0;\n };\n Beta$regularizedBeta$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContinuedFraction]\n };\n Beta.prototype.regularizedBeta_tychlm$ = function (x, a, b, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(x) || isNaN_0(a) || isNaN_0(b) || x < 0 || x > 1 || a <= 0.0 || b <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x > (a + 1.0) / (a + b + 2.0)) {\n ret = 1.0 - this.regularizedBeta_tychlm$(1.0 - x, b, a, epsilon, maxIterations);\n } else {\n var fraction = new Beta$regularizedBeta$ObjectLiteral(b, a);\n var tmp$ = a * JsMath.log(x);\n var x_0 = 1.0 - x;\n var x_1 = tmp$ + b * JsMath.log(x_0) - JsMath.log(a) - this.logBeta_88ee24$(a, b, epsilon, maxIterations);\n ret = JsMath.exp(x_1) * 1.0 / fraction.evaluate_syxxoe$(x, epsilon, maxIterations);\n }\n return ret;\n };\n Beta.prototype.logBeta_88ee24$ = function (a, b, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(b) || a <= 0.0 || b <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else {\n ret = Gamma_getInstance().logGamma_14dthe$(a) + Gamma_getInstance().logGamma_14dthe$(b) - Gamma_getInstance().logGamma_14dthe$(a + b);\n }\n return ret;\n };\n Beta.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Beta',\n interfaces: []\n };\n var Beta_instance = null;\n function Beta_getInstance() {\n if (Beta_instance === null) {\n new Beta();\n }return Beta_instance;\n }\n function BlockRealMatrix() {\n this.BLOCK_SIZE_0 = 52;\n this.rows_0 = 0;\n this.columns_0 = 0;\n this.blockRows_0 = 0;\n this.blockColumns_0 = 0;\n this.blocks_4giiw5$_0 = this.blocks_4giiw5$_0;\n }\n Object.defineProperty(BlockRealMatrix.prototype, 'blocks_0', {\n configurable: true,\n get: function () {\n if (this.blocks_4giiw5$_0 == null)\n return throwUPAE('blocks');\n return this.blocks_4giiw5$_0;\n },\n set: function (blocks) {\n this.blocks_4giiw5$_0 = blocks;\n }\n });\n BlockRealMatrix.prototype.create_omvvzo$ = function (rows, columns, blockData, copyArray) {\n var tmp$;\n this.rows_0 = rows;\n this.columns_0 = columns;\n this.blockRows_0 = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n this.blockColumns_0 = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blocksCopyList = ArrayList_init();\n if (!copyArray) {\n this.blocks_0 = blockData;\n }var index = 0;\n tmp$ = this.blockRows_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n var iHeight = this.blockHeight_0(iBlock);\n var jBlock = 0;\n while (jBlock < this.blockColumns_0) {\n if (blockData[index].length !== Kotlin.imul(iHeight, this.blockWidth_0(jBlock))) {\n throw IllegalStateException_init(''.toString());\n }if (copyArray) {\n blocksCopyList.add_11rb$(blockData[index].slice());\n }jBlock = jBlock + 1 | 0;\n index = index + 1 | 0;\n }\n }\n if (copyArray) {\n this.blocks_0 = copyToArray(blocksCopyList);\n }};\n BlockRealMatrix.prototype.createBlocksLayout_0 = function (rows, columns) {\n var blockRows = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blockColumns = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blocksList = ArrayList_init();\n var blockIndex = 0;\n for (var iBlock = 0; iBlock < blockRows; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var pEnd = JsMath.min(a, rows);\n var iHeight = pEnd - pStart | 0;\n for (var jBlock = 0; jBlock < blockColumns; jBlock++) {\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var qEnd = JsMath.min(a_0, columns);\n var jWidth = qEnd - qStart | 0;\n blocksList.add_11rb$(new Float64Array(Kotlin.imul(iHeight, jWidth)));\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return copyToArray(blocksList);\n };\n BlockRealMatrix.prototype.transpose = function () {\n var tmp$, tmp$_0;\n var nRows = this.getRowDimension_0();\n var nCols = this.getColumnDimension_0();\n var out = BlockRealMatrix_init(nCols, nRows);\n var blockIndex = 0;\n tmp$ = this.blockColumns_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n tmp$_0 = this.blockRows_0;\n for (var jBlock = 0; jBlock < tmp$_0; jBlock++) {\n var outBlock = out.blocks_0[blockIndex];\n var tBlock = this.blocks_0[Kotlin.imul(jBlock, this.blockColumns_0) + iBlock | 0];\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var b = this.columns_0;\n var pEnd = JsMath.min(a, b);\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var b_0 = this.rows_0;\n var qEnd = JsMath.min(a_0, b_0);\n var k = 0;\n for (var p = pStart; p < pEnd; p++) {\n var lInc = pEnd - pStart | 0;\n var l = p - pStart | 0;\n for (var q = qStart; q < qEnd; q++) {\n outBlock[k] = tBlock[l];\n k = k + 1 | 0;\n l = l + lInc | 0;\n }\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return out;\n };\n BlockRealMatrix.prototype.multiply_1dlv11$ = function (m) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (this.getColumnDimension_0() !== m.getRowDimension_0()) {\n throw IllegalStateException_init(('Matrix multiply dimension mismatch: ' + this.getColumnDimension_0() + ' x ' + m.getRowDimension_0()).toString());\n }var out = BlockRealMatrix_init(this.rows_0, m.columns_0);\n var blockIndex = 0;\n tmp$ = out.blockRows_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var b = this.rows_0;\n var pEnd = JsMath.min(a, b);\n tmp$_0 = out.blockColumns_0;\n for (var jBlock = 0; jBlock < tmp$_0; jBlock++) {\n var jWidth = out.blockWidth_0(jBlock);\n var jWidth2 = jWidth + jWidth | 0;\n var jWidth3 = jWidth2 + jWidth | 0;\n var jWidth4 = jWidth3 + jWidth | 0;\n var outBlock = out.blocks_0[blockIndex];\n tmp$_1 = this.blockColumns_0;\n for (var kBlock = 0; kBlock < tmp$_1; kBlock++) {\n var kWidth = this.blockWidth_0(kBlock);\n var tBlock = this.blocks_0[Kotlin.imul(iBlock, this.blockColumns_0) + kBlock | 0];\n var mBlock = m.blocks_0[Kotlin.imul(kBlock, m.blockColumns_0) + jBlock | 0];\n var k = 0;\n for (var p = pStart; p < pEnd; p++) {\n var lStart = Kotlin.imul(p - pStart | 0, kWidth);\n var lEnd = lStart + kWidth | 0;\n for (var nStart = 0; nStart < jWidth; nStart++) {\n var sum = 0.0;\n var l = lStart;\n var n = nStart;\n while (l < (lEnd - 3 | 0)) {\n sum += tBlock[l] * mBlock[n] + tBlock[l + 1 | 0] * mBlock[n + jWidth | 0] + tBlock[l + 2 | 0] * mBlock[n + jWidth2 | 0] + tBlock[l + 3 | 0] * mBlock[n + jWidth3 | 0];\n l = l + 4 | 0;\n n = n + jWidth4 | 0;\n }\n while (l < lEnd) {\n sum = sum + tBlock[tmp$_2 = l, l = tmp$_2 + 1 | 0, tmp$_2] * mBlock[n];\n n = n + jWidth | 0;\n }\n outBlock[k] = outBlock[k] + sum;\n k = k + 1 | 0;\n }\n }\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return out;\n };\n BlockRealMatrix.prototype.getEntry_vux9f0$ = function (row, column) {\n if (row < 0 || row > this.getRowDimension_0()) {\n throw IllegalStateException_init(('row out of range: ' + row).toString());\n }if (column < 0 || column > this.getColumnDimension_0()) {\n throw IllegalStateException_init(('column out of range: ' + column).toString());\n }var iBlock = row / this.BLOCK_SIZE_0 | 0;\n var jBlock = column / this.BLOCK_SIZE_0 | 0;\n var k = Kotlin.imul(row - Kotlin.imul(iBlock, this.BLOCK_SIZE_0) | 0, this.blockWidth_0(jBlock)) + (column - Kotlin.imul(jBlock, this.BLOCK_SIZE_0)) | 0;\n return this.blocks_0[Kotlin.imul(iBlock, this.blockColumns_0) + jBlock | 0][k];\n };\n BlockRealMatrix.prototype.getRowDimension_0 = function () {\n return this.rows_0;\n };\n BlockRealMatrix.prototype.getColumnDimension_0 = function () {\n return this.columns_0;\n };\n BlockRealMatrix.prototype.blockWidth_0 = function (blockColumn) {\n return blockColumn === (this.blockColumns_0 - 1 | 0) ? this.columns_0 - Kotlin.imul(blockColumn, this.BLOCK_SIZE_0) | 0 : this.BLOCK_SIZE_0;\n };\n BlockRealMatrix.prototype.blockHeight_0 = function (blockRow) {\n return blockRow === (this.blockRows_0 - 1 | 0) ? this.rows_0 - Kotlin.imul(blockRow, this.BLOCK_SIZE_0) | 0 : this.BLOCK_SIZE_0;\n };\n BlockRealMatrix.prototype.toBlocksLayout_n8oub7$ = function (rawData) {\n var rows = rawData.length;\n var columns = rawData[0].length;\n var blockRows = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blockColumns = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n for (var i = 0; i !== rawData.length; ++i) {\n var length = rawData[i].length;\n if (length !== columns) {\n throw IllegalStateException_init(('Wrong dimension: ' + columns + ', ' + length).toString());\n }}\n var blocksList = ArrayList_init();\n var blockIndex = 0;\n for (var iBlock = 0; iBlock < blockRows; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var pEnd = JsMath.min(a, rows);\n var iHeight = pEnd - pStart | 0;\n for (var jBlock = 0; jBlock < blockColumns; jBlock++) {\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var qEnd = JsMath.min(a_0, columns);\n var jWidth = qEnd - qStart | 0;\n var block = new Float64Array(Kotlin.imul(iHeight, jWidth));\n blocksList.add_11rb$(block);\n var index = 0;\n for (var p = pStart; p < pEnd; p++) {\n arrayCopy(rawData[p], block, index, qStart, qEnd);\n index = index + jWidth | 0;\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return copyToArray(blocksList);\n };\n BlockRealMatrix.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BlockRealMatrix',\n interfaces: []\n };\n function BlockRealMatrix_init(rows, columns, $this) {\n $this = $this || Object.create(BlockRealMatrix.prototype);\n BlockRealMatrix.call($this);\n $this.rows_0 = rows;\n $this.columns_0 = columns;\n $this.blockRows_0 = (rows + $this.BLOCK_SIZE_0 - 1 | 0) / $this.BLOCK_SIZE_0 | 0;\n $this.blockColumns_0 = (columns + $this.BLOCK_SIZE_0 - 1 | 0) / $this.BLOCK_SIZE_0 | 0;\n $this.blocks_0 = $this.createBlocksLayout_0(rows, columns);\n return $this;\n }\n function BlockRealMatrix_init_0(rawData, $this) {\n $this = $this || Object.create(BlockRealMatrix.prototype);\n BlockRealMatrix.call($this);\n $this.create_omvvzo$(rawData.length, rawData[0].length, $this.toBlocksLayout_n8oub7$(rawData), false);\n return $this;\n }\n function BracketedUnivariateSolver() {\n }\n BracketedUnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BracketedUnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function BrentSolver() {\n BrentSolver$Companion_getInstance();\n }\n BrentSolver.prototype.doSolve = function () {\n var min = this.min;\n var max = this.max;\n var initial = this.startValue;\n var functionValueAccuracy = this.functionValueAccuracy;\n this.verifySequence_yvo9jy$(min, initial, max);\n var yInitial = this.computeObjectiveValue_14dthe$(initial);\n if (JsMath.abs(yInitial) <= functionValueAccuracy) {\n return initial;\n }var yMin = this.computeObjectiveValue_14dthe$(min);\n if (JsMath.abs(yMin) <= functionValueAccuracy) {\n return min;\n }if (yInitial * yMin < 0) {\n return this.brent_0(min, initial, yMin, yInitial);\n }var yMax = this.computeObjectiveValue_14dthe$(max);\n if (JsMath.abs(yMax) <= functionValueAccuracy) {\n return max;\n }if (yInitial * yMax < 0) {\n return this.brent_0(initial, max, yInitial, yMax);\n }throw IllegalStateException_init(('NoBracketing - min: ' + min + ', max: ' + max + ', yMin: ' + yMin + ', yMax: ' + yMax).toString());\n };\n BrentSolver.prototype.brent_0 = function (lo, hi, fLo, fHi) {\n var a = lo;\n var fa = fLo;\n var b = hi;\n var fb = fHi;\n var c = a;\n var fc = fa;\n var d = b - a;\n var e = d;\n var t = this.absoluteAccuracy;\n var eps = this.relativeAccuracy;\n while (true) {\n var x = fc;\n var tmp$ = JsMath.abs(x);\n var x_0 = fb;\n if (tmp$ < JsMath.abs(x_0)) {\n a = b;\n b = c;\n c = a;\n fa = fb;\n fb = fc;\n fc = fa;\n }var tmp$_0 = 2.0 * eps;\n var x_1 = b;\n var tol = tmp$_0 * JsMath.abs(x_1) + t;\n var m = 0.5 * (c - b);\n if (JsMath.abs(m) <= tol || Precision_getInstance().equals_syxxoe$(fb, 0.0)) {\n return b;\n }var x_2 = e;\n var tmp$_1 = JsMath.abs(x_2) < tol;\n if (!tmp$_1) {\n var x_3 = fa;\n var tmp$_2 = JsMath.abs(x_3);\n var x_4 = fb;\n tmp$_1 = tmp$_2 <= JsMath.abs(x_4);\n }if (tmp$_1) {\n d = m;\n e = d;\n } else {\n var s = fb / fa;\n var p;\n var q;\n if (a === c) {\n p = 2.0 * m * s;\n q = 1 - s;\n } else {\n q = fa / fc;\n var r = fb / fc;\n p = s * (2.0 * m * q * (q - r) - (b - a) * (r - 1));\n q = (q - 1) * (r - 1) * (s - 1);\n }\n if (p > 0) {\n q = -q;\n } else {\n p = -p;\n }\n s = e;\n e = d;\n var tmp$_3 = p;\n var tmp$_4 = 1.5 * m * q;\n var x_5 = tol * q;\n var tmp$_5 = tmp$_3 >= tmp$_4 - JsMath.abs(x_5);\n if (!tmp$_5) {\n var tmp$_6 = p;\n var x_6 = 0.5 * s * q;\n tmp$_5 = tmp$_6 >= JsMath.abs(x_6);\n }if (tmp$_5) {\n d = m;\n e = d;\n } else {\n d = p / q;\n }\n }\n a = b;\n fa = fb;\n var x_7 = d;\n if (JsMath.abs(x_7) > tol) {\n b += d;\n } else if (m > 0) {\n b += tol;\n } else {\n b -= tol;\n }\n fb = this.computeObjectiveValue_14dthe$(b);\n if (fb > 0 && fc > 0 || (fb <= 0 && fc <= 0)) {\n c = a;\n fc = fa;\n d = b - a;\n e = d;\n }}\n };\n function BrentSolver$Companion() {\n BrentSolver$Companion_instance = this;\n this.DEFAULT_ABSOLUTE_ACCURACY_0 = 1.0E-6;\n }\n BrentSolver$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BrentSolver$Companion_instance = null;\n function BrentSolver$Companion_getInstance() {\n if (BrentSolver$Companion_instance === null) {\n new BrentSolver$Companion();\n }return BrentSolver$Companion_instance;\n }\n BrentSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BrentSolver',\n interfaces: [AbstractUnivariateSolver]\n };\n function BrentSolver_init(absoluteAccuracy, $this) {\n if (absoluteAccuracy === void 0)\n absoluteAccuracy = BrentSolver$Companion_getInstance().DEFAULT_ABSOLUTE_ACCURACY_0;\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init(absoluteAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function BrentSolver_init_0(relativeAccuracy, absoluteAccuracy, $this) {\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init_0(relativeAccuracy, absoluteAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function BrentSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this) {\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function ContinuedFraction() {\n ContinuedFraction$Companion_getInstance();\n }\n ContinuedFraction.prototype.evaluate_12fank$ = function (x, maxIterations) {\n return this.evaluate_syxxoe$(x, ContinuedFraction$Companion_getInstance().DEFAULT_EPSILON_0, maxIterations);\n };\n ContinuedFraction.prototype.evaluate_syxxoe$ = function (x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = ContinuedFraction$Companion_getInstance().DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var p0 = 1.0;\n var p1 = this.getA_5wr77w$(0, x);\n var q0 = 0.0;\n var q1 = 1.0;\n var c = p1 / q1;\n var n = 0;\n var relativeError = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n while (n < maxIterations && relativeError > epsilon) {\n n = n + 1 | 0;\n var a = this.getA_5wr77w$(n, x);\n var b = this.getB_5wr77w$(n, x);\n var p2 = a * p1 + b * p0;\n var q2 = a * q1 + b * q0;\n var infinite = false;\n if (isInfinite(p2) || isInfinite(q2)) {\n var scaleFactor = 1.0;\n var lastScaleFactor = 1.0;\n var maxPower = 5;\n var scale = JsMath.max(a, b);\n if (scale <= 0) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }infinite = true;\n for (var i = 0; i < maxPower; i++) {\n lastScaleFactor = scaleFactor;\n scaleFactor *= scale;\n if (a !== 0.0 && a > b) {\n p2 = p1 / lastScaleFactor + b / scaleFactor * p0;\n q2 = q1 / lastScaleFactor + b / scaleFactor * q0;\n } else if (b !== 0.0) {\n p2 = a / scaleFactor * p1 + p0 / lastScaleFactor;\n q2 = a / scaleFactor * q1 + q0 / lastScaleFactor;\n }infinite = isInfinite(p2) || isInfinite(q2);\n if (!infinite) {\n break;\n }}\n }if (infinite) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }var r = p2 / q2;\n if (isNaN_0(r)) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }var x_0 = r / c - 1.0;\n relativeError = JsMath.abs(x_0);\n c = p2 / q2;\n p0 = p1;\n p1 = p2;\n q0 = q1;\n q1 = q2;\n }\n if (n >= maxIterations) {\n throw IllegalStateException_init('MaxCountExceeded'.toString());\n }return c;\n };\n function ContinuedFraction$Companion() {\n ContinuedFraction$Companion_instance = this;\n this.DEFAULT_EPSILON_0 = 1.0E-8;\n }\n ContinuedFraction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContinuedFraction$Companion_instance = null;\n function ContinuedFraction$Companion_getInstance() {\n if (ContinuedFraction$Companion_instance === null) {\n new ContinuedFraction$Companion();\n }return ContinuedFraction$Companion_instance;\n }\n ContinuedFraction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuedFraction',\n interfaces: []\n };\n function mean(xs) {\n return average(xs);\n }\n function correlationPearson(xs, ys) {\n if (!(xs.length === ys.length)) {\n var message = 'Two series must have the same size.';\n throw IllegalArgumentException_init(message.toString());\n }if (!!(xs.length === 0)) {\n var message_0 = \"Can't correlate empty sequences.\";\n throw IllegalArgumentException_init(message_0.toString());\n }var mx = mean(xs);\n var my = mean(ys);\n var cov = 0.0;\n var d2x = 0.0;\n var d2y = 0.0;\n for (var i = 0; i !== xs.length; ++i) {\n var dx = xs[i] - mx;\n var dy = ys[i] - my;\n cov += dx * dy;\n d2x += JsMath.pow(dx, 2);\n d2y += JsMath.pow(dy, 2);\n }\n if (!(d2x !== 0.0 && d2y !== 0.0)) {\n var message_1 = 'Correlation is not defined for sequences with zero variation.';\n throw IllegalArgumentException_init(message_1.toString());\n }var x = d2x * d2y;\n return cov / JsMath.sqrt(x);\n }\n function ForsythePolynomialGenerator(knots) {\n ForsythePolynomialGenerator$Companion_getInstance();\n this.knots_0 = knots;\n this.ps_0 = null;\n if (!!(this.knots_0.length === 0)) {\n var message = 'The knots list must not be empty';\n throw IllegalArgumentException_init(message.toString());\n }this.ps_0 = arrayListOf([new PolynomialFunction(new Float64Array([1.0])), new PolynomialFunction(new Float64Array([-average(this.knots_0), 1.0]))]);\n }\n ForsythePolynomialGenerator.prototype.alphaBeta_0 = function (i) {\n var tmp$, tmp$_0;\n if (!(i === this.ps_0.size)) {\n var message = 'Alpha must be calculated sequentially.';\n throw IllegalArgumentException_init(message.toString());\n }var p = last(this.ps_0);\n var pp = this.ps_0.get_za3lpa$(this.ps_0.size - 2 | 0);\n var sxp = 0.0;\n var sp2 = 0.0;\n var spp2 = 0.0;\n tmp$ = this.knots_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var x = tmp$[tmp$_0];\n var $receiver = p.value_14dthe$(x);\n var pv2 = JsMath.pow($receiver, 2);\n var $receiver_0 = pp.value_14dthe$(x);\n var ppv2 = JsMath.pow($receiver_0, 2);\n sxp += x * pv2;\n sp2 += pv2;\n spp2 += ppv2;\n }\n return new Pair_0(sxp / sp2, sp2 / spp2);\n };\n ForsythePolynomialGenerator.prototype.getPolynomial_za3lpa$ = function (n) {\n var tmp$;\n if (!(n >= 0)) {\n var message = 'Degree of Forsythe polynomial must not be negative';\n throw IllegalArgumentException_init(message.toString());\n }if (!(n < this.knots_0.length)) {\n var message_0 = 'Degree of Forsythe polynomial must not exceed knots.size - 1';\n throw IllegalArgumentException_init(message_0.toString());\n }if (n >= this.ps_0.size) {\n var sz = this.ps_0.size;\n tmp$ = n + 1 | 0;\n for (var k = sz; k <= tmp$; k++) {\n var tmp$_0 = this.alphaBeta_0(k);\n var a = tmp$_0.component1()\n , b = tmp$_0.component2();\n var pPrev = last(this.ps_0);\n var pPrevPrev = this.ps_0.get_za3lpa$(this.ps_0.size - 2 | 0);\n var p = ForsythePolynomialGenerator$Companion_getInstance().X.times_3j0b7h$(pPrev).minus_3j0b7h$(times(a, pPrev)).minus_3j0b7h$(times(b, pPrevPrev));\n this.ps_0.add_11rb$(p);\n }\n }return this.ps_0.get_za3lpa$(n);\n };\n function ForsythePolynomialGenerator$Companion() {\n ForsythePolynomialGenerator$Companion_instance = this;\n this.X = new PolynomialFunction(new Float64Array([0.0, 1.0]));\n }\n ForsythePolynomialGenerator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ForsythePolynomialGenerator$Companion_instance = null;\n function ForsythePolynomialGenerator$Companion_getInstance() {\n if (ForsythePolynomialGenerator$Companion_instance === null) {\n new ForsythePolynomialGenerator$Companion();\n }return ForsythePolynomialGenerator$Companion_instance;\n }\n ForsythePolynomialGenerator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ForsythePolynomialGenerator',\n interfaces: []\n };\n function Gamma() {\n Gamma_instance = this;\n this.GAMMA = 0.5772156649015329;\n this.DEFAULT_EPSILON_0 = 1.0E-14;\n this.LANCZOS_0 = new Float64Array([0.9999999999999971, 57.15623566586292, -59.59796035547549, 14.136097974741746, -0.4919138160976202, 3.399464998481189E-5, 4.652362892704858E-5, -9.837447530487956E-5, 1.580887032249125E-4, -2.1026444172410488E-4, 2.1743961811521265E-4, -1.643181065367639E-4, 8.441822398385275E-5, -2.6190838401581408E-5, 3.6899182659531625E-6]);\n var x = 2.0 * math.PI;\n this.HALF_LOG_2_PI_0 = 0.5 * JsMath.log(x);\n this.C_LIMIT_0 = 49.0;\n this.S_LIMIT_0 = 1.0E-5;\n }\n Gamma.prototype.logGamma_14dthe$ = function (x) {\n var ret;\n if (isNaN_0(x) || x <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else {\n var g = 607.0 / 128.0;\n var sum = 0.0;\n for (var i = this.LANCZOS_0.length - 1 | 0; i >= 1; i--) {\n sum = sum + this.LANCZOS_0[i] / (x + i);\n }\n sum = sum + this.LANCZOS_0[0];\n var tmp = x + g + 0.5;\n var tmp$ = (x + 0.5) * JsMath.log(tmp) - tmp + this.HALF_LOG_2_PI_0;\n var x_0 = sum / x;\n ret = tmp$ + JsMath.log(x_0);\n }\n return ret;\n };\n Gamma.prototype.regularizedGammaP_88ee24$ = function (a, x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(x) || a <= 0.0 || x < 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x === 0.0) {\n ret = 0.0;\n } else if (x >= a + 1) {\n ret = 1.0 - this.regularizedGammaQ_88ee24$(a, x, epsilon, maxIterations);\n } else {\n var n = 0.0;\n var an = 1.0 / a;\n var sum = an;\n while (true) {\n var x_0 = an / sum;\n if (!(JsMath.abs(x_0) > epsilon && n < maxIterations && sum < kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY))\n break;\n n = n + 1.0;\n an = an * (x / (a + n));\n sum = sum + an;\n }\n if (n >= maxIterations) {\n throw IllegalStateException_init(('MaxCountExceeded - maxIterations: ' + maxIterations).toString());\n } else if (isInfinite(sum)) {\n ret = 1.0;\n } else {\n var x_1 = -x + a * JsMath.log(x) - this.logGamma_14dthe$(a);\n ret = JsMath.exp(x_1) * sum;\n }\n }\n return ret;\n };\n function Gamma$regularizedGammaQ$ObjectLiteral(closure$a) {\n this.closure$a = closure$a;\n ContinuedFraction.call(this);\n }\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.getA_5wr77w$ = function (n, x) {\n return 2.0 * n + 1.0 - this.closure$a + x;\n };\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.getB_5wr77w$ = function (n, x) {\n return n * (this.closure$a - n);\n };\n Gamma$regularizedGammaQ$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContinuedFraction]\n };\n Gamma.prototype.regularizedGammaQ_88ee24$ = function (a, x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(x) || a <= 0.0 || x < 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x === 0.0) {\n ret = 1.0;\n } else if (x < a + 1.0) {\n ret = 1.0 - this.regularizedGammaP_88ee24$(a, x, epsilon, maxIterations);\n } else {\n var cf = new Gamma$regularizedGammaQ$ObjectLiteral(a);\n ret = 1.0 / cf.evaluate_syxxoe$(x, epsilon, maxIterations);\n var x_0 = -x + a * JsMath.log(x) - this.logGamma_14dthe$(a);\n ret = JsMath.exp(x_0) * ret;\n }\n return ret;\n };\n Gamma.prototype.digamma_14dthe$ = function (x) {\n if (x > 0 && x <= this.S_LIMIT_0) {\n return -this.GAMMA - 1 / x;\n }if (x >= this.C_LIMIT_0) {\n var inv = 1 / (x * x);\n return JsMath.log(x) - 0.5 / x - inv * (1.0 / 12 + inv * (1.0 / 120 - inv / 252));\n }return this.digamma_14dthe$(x + 1) - 1 / x;\n };\n Gamma.prototype.trigamma_14dthe$ = function (x) {\n if (x > 0 && x <= this.S_LIMIT_0) {\n return 1 / (x * x);\n }if (x >= this.C_LIMIT_0) {\n var inv = 1 / (x * x);\n return 1 / x + inv / 2 + inv / x * (1.0 / 6 - inv * (1.0 / 30 + inv / 42));\n }return this.trigamma_14dthe$(x + 1) + 1 / (x * x);\n };\n Gamma.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Gamma',\n interfaces: []\n };\n var Gamma_instance = null;\n function Gamma_getInstance() {\n if (Gamma_instance === null) {\n new Gamma();\n }return Gamma_instance;\n }\n function Incrementor(maximalCount, maxCountCallback) {\n if (maximalCount === void 0)\n maximalCount = 0;\n if (maxCountCallback === void 0)\n maxCountCallback = new Incrementor_init$ObjectLiteral();\n this.maximalCount = maximalCount;\n this.maxCountCallback_0 = maxCountCallback;\n this.count_k39d42$_0 = 0;\n }\n Object.defineProperty(Incrementor.prototype, 'count', {\n configurable: true,\n get: function () {\n return this.count_k39d42$_0;\n },\n set: function (count) {\n this.count_k39d42$_0 = count;\n }\n });\n Incrementor.prototype.canIncrement = function () {\n return this.count < this.maximalCount;\n };\n Incrementor.prototype.incrementCount_za3lpa$ = function (value) {\n for (var i = 0; i < value; i++) {\n this.incrementCount();\n }\n };\n Incrementor.prototype.incrementCount = function () {\n if ((this.count = this.count + 1 | 0, this.count) > this.maximalCount) {\n this.maxCountCallback_0.trigger_za3lpa$(this.maximalCount);\n }};\n Incrementor.prototype.resetCount = function () {\n this.count = 0;\n };\n function Incrementor$MaxCountExceededCallback() {\n }\n Incrementor$MaxCountExceededCallback.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MaxCountExceededCallback',\n interfaces: []\n };\n function Incrementor_init$ObjectLiteral() {\n }\n Incrementor_init$ObjectLiteral.prototype.trigger_za3lpa$ = function (maximalCount) {\n throw IllegalStateException_init(('MaxCountExceeded: ' + maximalCount).toString());\n };\n Incrementor_init$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Incrementor$MaxCountExceededCallback]\n };\n Incrementor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Incrementor',\n interfaces: []\n };\n function LoessInterpolator(bandwidth, robustnessIters, accuracy) {\n LoessInterpolator$Companion_getInstance();\n if (bandwidth === void 0)\n bandwidth = LoessInterpolator$Companion_getInstance().DEFAULT_BANDWIDTH;\n if (robustnessIters === void 0)\n robustnessIters = 2;\n if (accuracy === void 0)\n accuracy = LoessInterpolator$Companion_getInstance().DEFAULT_ACCURACY;\n this.bandwidth_0 = bandwidth;\n this.robustnessIters_0 = robustnessIters;\n this.accuracy_0 = accuracy;\n if (this.bandwidth_0 <= 0 || this.bandwidth_0 > 1) {\n throw IllegalStateException_init(('Out of range of bandwidth value: ' + this.bandwidth_0 + ' should be > 0 and <= 1').toString());\n }if (this.robustnessIters_0 < 0) {\n throw IllegalStateException_init(('Not positive Robutness iterationa: ' + this.robustnessIters_0).toString());\n }}\n LoessInterpolator.prototype.interpolate_g9g6do$ = function (xval, yval) {\n return (new SplineInterpolator()).interpolate_g9g6do$(xval, this.smooth_0(xval, yval));\n };\n LoessInterpolator.prototype.smooth_1 = function (xval, yval, weights) {\n var tmp$, tmp$_0, tmp$_1;\n if (xval.length !== yval.length) {\n throw IllegalStateException_init(('Dimension mismatch of interpolation points: ' + xval.length + ' != ' + yval.length).toString());\n }var n = xval.length;\n if (n === 0) {\n throw IllegalStateException_init('No data to interpolate'.toString());\n }this.checkAllFiniteReal_0(xval);\n this.checkAllFiniteReal_0(yval);\n this.checkAllFiniteReal_0(weights);\n MathArrays_getInstance().checkOrder_gf7tl1$(xval);\n if (n === 1) {\n return new Float64Array([yval[0]]);\n }if (n === 2) {\n return new Float64Array([yval[0], yval[1]]);\n }var bandwidthInPoints = numberToInt(this.bandwidth_0 * n);\n if (bandwidthInPoints < 2) {\n throw IllegalStateException_init((\"LOESS 'bandwidthInPoints' is too small: \" + bandwidthInPoints + ' < 2').toString());\n }var res = new Float64Array(n);\n var residuals = new Float64Array(n);\n var sortedResiduals = new Float64Array(n);\n var robustnessWeights = new Float64Array(n);\n fill(robustnessWeights, 1.0);\n tmp$ = this.robustnessIters_0;\n for (var iter = 0; iter <= tmp$; iter++) {\n var bandwidthInterval = new Int32Array([0, bandwidthInPoints - 1 | 0]);\n for (var i = 0; i < n; i++) {\n var x = xval[i];\n if (i > 0) {\n this.updateBandwidthInterval_0(xval, weights, i, bandwidthInterval);\n }var ileft = bandwidthInterval[0];\n var iright = bandwidthInterval[1];\n var edge;\n if (xval[i] - xval[ileft] > xval[iright] - xval[i]) {\n tmp$_0 = ileft;\n } else {\n tmp$_0 = iright;\n }\n edge = tmp$_0;\n var sumWeights = 0.0;\n var sumX = 0.0;\n var sumXSquared = 0.0;\n var sumY = 0.0;\n var sumXY = 0.0;\n var x_0 = 1.0 / (xval[edge] - x);\n var denom = JsMath.abs(x_0);\n for (var k = ileft; k <= iright; k++) {\n var xk = xval[k];\n var yk = yval[k];\n var dist = k < i ? x - xk : xk - x;\n var w = this.tricube_0(dist * denom) * robustnessWeights[k] * weights[k];\n var xkw = xk * w;\n sumWeights += w;\n sumX += xkw;\n sumXSquared += xk * xkw;\n sumY += yk * w;\n sumXY += yk * xkw;\n }\n var meanX = sumX / sumWeights;\n var meanY = sumY / sumWeights;\n var meanXY = sumXY / sumWeights;\n var meanXSquared = sumXSquared / sumWeights;\n var beta;\n var x_1 = meanXSquared - meanX * meanX;\n var x_2 = JsMath.abs(x_1);\n if (JsMath.sqrt(x_2) < this.accuracy_0) {\n tmp$_1 = 0.0;\n } else {\n tmp$_1 = (meanXY - meanX * meanY) / (meanXSquared - meanX * meanX);\n }\n beta = tmp$_1;\n var alpha = meanY - beta * meanX;\n res[i] = beta * x + alpha;\n var x_3 = yval[i] - res[i];\n residuals[i] = JsMath.abs(x_3);\n }\n if (iter === this.robustnessIters_0) {\n break;\n }arrayCopy(residuals, sortedResiduals, 0, 0, n);\n sort(sortedResiduals);\n var medianResidual = sortedResiduals[n / 2 | 0];\n if (JsMath.abs(medianResidual) < this.accuracy_0) {\n break;\n }for (var i_0 = 0; i_0 < n; i_0++) {\n var arg = residuals[i_0] / (6 * medianResidual);\n if (arg >= 1) {\n robustnessWeights[i_0] = 0.0;\n } else {\n var w_0 = 1 - arg * arg;\n robustnessWeights[i_0] = w_0 * w_0;\n }\n }\n }\n return res;\n };\n LoessInterpolator.prototype.updateBandwidthInterval_0 = function (xval, weights, i, bandwidthInterval) {\n var left = bandwidthInterval[0];\n var right = bandwidthInterval[1];\n var nextRight = this.nextNonzero_0(weights, right);\n if (nextRight < xval.length && xval[nextRight] - xval[i] < xval[i] - xval[left]) {\n var nextLeft = this.nextNonzero_0(weights, bandwidthInterval[0]);\n bandwidthInterval[0] = nextLeft;\n bandwidthInterval[1] = nextRight;\n }};\n LoessInterpolator.prototype.tricube_0 = function (x) {\n var absX = JsMath.abs(x);\n if (absX >= 1.0) {\n return 0.0;\n }var tmp = 1 - absX * absX * absX;\n return tmp * tmp * tmp;\n };\n LoessInterpolator.prototype.nextNonzero_0 = function (weights, i) {\n var j = i + 1 | 0;\n while (j < weights.length && weights[j] === 0.0) {\n j = j + 1 | 0;\n }\n return j;\n };\n LoessInterpolator.prototype.smooth_0 = function (xval, yval) {\n if (xval.length !== yval.length) {\n throw IllegalStateException_init(('Dimension mismatch: ' + xval.length + ' != ' + yval.length).toString());\n }var unitWeights = new Float64Array(xval.length);\n fill(unitWeights, 1.0);\n return this.smooth_1(xval, yval, unitWeights);\n };\n LoessInterpolator.prototype.checkFinite_0 = function (x) {\n if (isInfinite(x) || isNaN_0(x)) {\n throw IllegalStateException_init(('Argument ' + x + ' is not a finite number').toString());\n }};\n LoessInterpolator.prototype.checkAllFiniteReal_0 = function (values) {\n for (var i = 0; i !== values.length; ++i) {\n this.checkFinite_0(values[i]);\n }\n };\n function LoessInterpolator$Companion() {\n LoessInterpolator$Companion_instance = this;\n this.DEFAULT_BANDWIDTH = 0.3;\n this.DEFAULT_ROBUSTNESS_ITERS = 2;\n this.DEFAULT_ACCURACY = 1.0E-12;\n }\n LoessInterpolator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LoessInterpolator$Companion_instance = null;\n function LoessInterpolator$Companion_getInstance() {\n if (LoessInterpolator$Companion_instance === null) {\n new LoessInterpolator$Companion();\n }return LoessInterpolator$Companion_instance;\n }\n LoessInterpolator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LoessInterpolator',\n interfaces: []\n };\n function MathArrays() {\n MathArrays_instance = this;\n }\n function MathArrays$OrderDirection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MathArrays$OrderDirection_initFields() {\n MathArrays$OrderDirection_initFields = function () {\n };\n MathArrays$OrderDirection$INCREASING_instance = new MathArrays$OrderDirection('INCREASING', 0);\n MathArrays$OrderDirection$DECREASING_instance = new MathArrays$OrderDirection('DECREASING', 1);\n }\n var MathArrays$OrderDirection$INCREASING_instance;\n function MathArrays$OrderDirection$INCREASING_getInstance() {\n MathArrays$OrderDirection_initFields();\n return MathArrays$OrderDirection$INCREASING_instance;\n }\n var MathArrays$OrderDirection$DECREASING_instance;\n function MathArrays$OrderDirection$DECREASING_getInstance() {\n MathArrays$OrderDirection_initFields();\n return MathArrays$OrderDirection$DECREASING_instance;\n }\n MathArrays$OrderDirection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderDirection',\n interfaces: [Enum]\n };\n function MathArrays$OrderDirection$values() {\n return [MathArrays$OrderDirection$INCREASING_getInstance(), MathArrays$OrderDirection$DECREASING_getInstance()];\n }\n MathArrays$OrderDirection.values = MathArrays$OrderDirection$values;\n function MathArrays$OrderDirection$valueOf(name) {\n switch (name) {\n case 'INCREASING':\n return MathArrays$OrderDirection$INCREASING_getInstance();\n case 'DECREASING':\n return MathArrays$OrderDirection$DECREASING_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.math3.MathArrays.OrderDirection.' + name);\n }\n }\n MathArrays$OrderDirection.valueOf_61zpoe$ = MathArrays$OrderDirection$valueOf;\n MathArrays.prototype.checkOrder_j8c91m$ = function (val, dir, strict, abort) {\n var tmp$;\n var previous = val[0];\n var max = val.length;\n var index;\n index = 1;\n ITEM: while (index < max) {\n if (equals(dir, MathArrays$OrderDirection$INCREASING_getInstance()))\n if (strict) {\n if (val[index] <= previous) {\n break ITEM;\n }} else {\n if (val[index] < previous) {\n break ITEM;\n }}\n else if (equals(dir, MathArrays$OrderDirection$DECREASING_getInstance()))\n if (strict) {\n if (val[index] >= previous) {\n break ITEM;\n }} else {\n if (val[index] > previous) {\n break ITEM;\n }}\n else {\n throw IllegalStateException_init(''.toString());\n }\n previous = val[index];\n index = index + 1 | 0;\n }\n if (index === max) {\n return true;\n }if (abort) {\n throw IllegalStateException_init('Non monotonic sequence'.toString());\n } else {\n tmp$ = false;\n }\n return tmp$;\n };\n MathArrays.prototype.checkOrder_hixecd$ = function (val, dir, strict) {\n this.checkOrder_j8c91m$(val, dir, strict, true);\n };\n MathArrays.prototype.checkOrder_gf7tl1$ = function (val) {\n this.checkOrder_hixecd$(val, MathArrays$OrderDirection$INCREASING_getInstance(), true);\n };\n MathArrays.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MathArrays',\n interfaces: []\n };\n var MathArrays_instance = null;\n function MathArrays_getInstance() {\n if (MathArrays_instance === null) {\n new MathArrays();\n }return MathArrays_instance;\n }\n function Percentile() {\n Percentile_instance = this;\n this.MIN_SELECT_SIZE_0 = 15;\n this.MAX_CACHED_LEVELS_0 = 10;\n }\n Percentile.prototype.evaluate_pw9xcd$ = function (values, p) {\n this.test_0(values, 0, 0, false);\n return this.evaluate_0(values, 0, values.length, p);\n };\n Percentile.prototype.test_0 = function (values, begin, length, allowEmpty) {\n var tmp$;\n if (values == null) {\n throw IllegalStateException_init('Input array'.toString());\n }if (begin < 0) {\n throw IllegalStateException_init('start postion < 0'.toString());\n }if (length < 0) {\n throw IllegalStateException_init('length < 0'.toString());\n }if ((begin + length | 0) > values.length) {\n throw IllegalStateException_init('subarray ends after array end'.toString());\n }if (length === 0 && !allowEmpty) {\n tmp$ = false;\n } else\n tmp$ = true;\n return tmp$;\n };\n Percentile.prototype.evaluate_0 = function (values, begin, length, p) {\n this.test_0(values, begin, length, false);\n if (p > 100 || p <= 0) {\n throw IllegalStateException_init(('out of bounds quantile value: ' + p + ', must be in (0, 100]').toString());\n }if (length === 0) {\n return kotlin_js_internal_DoubleCompanionObject.NaN;\n }if (length === 1) {\n return values[begin];\n }var n = length;\n var pos = p * (n + 1) / 100;\n var fpos = JsMath.floor(pos);\n var intPos = numberToInt(fpos);\n var dif = pos - fpos;\n var work = new Float64Array(length);\n arrayCopy(values, work, 0, begin, length);\n var pivotsHeap = new Int32Array(1023);\n fill_0(pivotsHeap, -1);\n if (pos < 1) {\n return this.select_0(work, pivotsHeap, 0);\n }if (pos >= n) {\n return this.select_0(work, pivotsHeap, length - 1 | 0);\n }var lower = this.select_0(work, pivotsHeap, intPos - 1 | 0);\n var upper = this.select_0(work, pivotsHeap, intPos);\n return lower + dif * (upper - lower);\n };\n Percentile.prototype.select_0 = function (work, pivotsHeap, k) {\n var begin = 0;\n var end = work.length;\n var node = 0;\n while ((end - begin | 0) > 15) {\n var pivot;\n if (node < pivotsHeap.length && pivotsHeap[node] >= 0) {\n pivot = pivotsHeap[node];\n } else {\n pivot = this.partition_0(work, begin, end, this.medianOf3_0(work, begin, end));\n if (node < pivotsHeap.length) {\n pivotsHeap[node] = pivot;\n }}\n if (k === pivot) {\n return work[k];\n } else if (k < pivot) {\n end = pivot;\n var a = (2 * node | 0) + 1 | 0;\n node = JsMath.min(a, pivotsHeap.length);\n } else {\n begin = pivot + 1 | 0;\n var a_0 = (2 * node | 0) + 2 | 0;\n node = JsMath.min(a_0, pivotsHeap.length);\n }\n }\n this.insertionSort_0(work, begin, end);\n return work[k];\n };\n Percentile.prototype.partition_0 = function (work, begin, end, pivot) {\n var tmp$, tmp$_0;\n var value = work[pivot];\n work[pivot] = work[begin];\n var i = begin + 1 | 0;\n var j = end - 1 | 0;\n while (i < j) {\n while (i < j && work[j] >= value) {\n j = j - 1 | 0;\n }\n while (i < j && work[i] <= value) {\n i = i + 1 | 0;\n }\n if (i < j) {\n var tmp = work[i];\n work[tmp$ = i, i = tmp$ + 1 | 0, tmp$] = work[j];\n work[tmp$_0 = j, j = tmp$_0 - 1 | 0, tmp$_0] = tmp;\n }}\n if (i >= end || work[i] > value) {\n i = i - 1 | 0;\n }work[begin] = work[i];\n work[i] = value;\n return i;\n };\n Percentile.prototype.medianOf3_0 = function (work, begin, end) {\n var tmp$;\n var inclusiveEnd = end - 1 | 0;\n var middle = begin + ((inclusiveEnd - begin | 0) / 2 | 0) | 0;\n var wBegin = work[begin];\n var wMiddle = work[middle];\n var wEnd = work[inclusiveEnd];\n if (wBegin < wMiddle) {\n if (wMiddle < wEnd) {\n tmp$ = middle;\n } else {\n tmp$ = wBegin < wEnd ? inclusiveEnd : begin;\n }\n } else {\n if (wBegin < wEnd) {\n tmp$ = begin;\n } else {\n tmp$ = wMiddle < wEnd ? inclusiveEnd : middle;\n }\n }\n return tmp$;\n };\n Percentile.prototype.insertionSort_0 = function (work, begin, end) {\n for (var j = begin + 1 | 0; j < end; j++) {\n var saved = work[j];\n var i = j - 1 | 0;\n while (i >= begin && saved < work[i]) {\n work[i + 1 | 0] = work[i];\n i = i - 1 | 0;\n }\n work[i + 1 | 0] = saved;\n }\n };\n Percentile.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Percentile',\n interfaces: []\n };\n var Percentile_instance = null;\n function Percentile_getInstance() {\n if (Percentile_instance === null) {\n new Percentile();\n }return Percentile_instance;\n }\n function PolynomialFunction(c) {\n this.coefficients_0 = null;\n var tmp$ = c == null;\n if (!tmp$) {\n tmp$ = c.length === 0;\n }if (tmp$) {\n throw IllegalStateException_init('Empty polynomials coefficients array'.toString());\n }var n = c.length;\n while (n > 1 && c[n - 1 | 0] === 0.0) {\n n = n - 1 | 0;\n }\n this.coefficients_0 = new Float64Array(n);\n arrayCopy(c, this.coefficients_0, 0, 0, n);\n }\n PolynomialFunction.prototype.value_14dthe$ = function (x) {\n return this.evaluate_0(this.coefficients_0, x);\n };\n PolynomialFunction.prototype.evaluate_0 = function (coefficients, argument) {\n if (coefficients == null) {\n throw IllegalStateException_init('Null argument: coefficients of the polynomial to evaluate'.toString());\n }var n = coefficients.length;\n if (n === 0) {\n throw IllegalStateException_init('Empty polynomials coefficients array'.toString());\n }var result = coefficients[n - 1 | 0];\n for (var j = n - 2 | 0; j >= 0; j--) {\n result = argument * result + coefficients[j];\n }\n return result;\n };\n PolynomialFunction.prototype.unaryPlus = function () {\n return new PolynomialFunction(this.coefficients_0);\n };\n PolynomialFunction.prototype.unaryMinus = function () {\n var tmp$;\n var dd = new Float64Array(this.coefficients_0.length);\n tmp$ = this.coefficients_0;\n for (var i = 0; i !== tmp$.length; ++i) {\n var c = tmp$[i];\n dd[i] = -c;\n }\n return new PolynomialFunction(dd);\n };\n PolynomialFunction.prototype.apply_op_0 = function (other, op) {\n var sz = collect.Comparables.max_sdesaw$(this.coefficients_0.length, other.coefficients_0.length);\n var nc = new Float64Array(sz);\n for (var i = 0; i < sz; i++) {\n var a = i < this.coefficients_0.length ? this.coefficients_0[i] : 0.0;\n var b = i < other.coefficients_0.length ? other.coefficients_0[i] : 0.0;\n nc[i] = op(a, b);\n }\n return new PolynomialFunction(nc);\n };\n function PolynomialFunction$plus$lambda(x, y) {\n return x + y;\n }\n PolynomialFunction.prototype.plus_3j0b7h$ = function (other) {\n return this.apply_op_0(other, PolynomialFunction$plus$lambda);\n };\n function PolynomialFunction$minus$lambda(x, y) {\n return x - y;\n }\n PolynomialFunction.prototype.minus_3j0b7h$ = function (other) {\n return this.apply_op_0(other, PolynomialFunction$minus$lambda);\n };\n PolynomialFunction.prototype.multiply_14dthe$ = function (a) {\n var tmp$;\n var dd = new Float64Array(this.coefficients_0.length);\n tmp$ = this.coefficients_0;\n for (var i = 0; i !== tmp$.length; ++i) {\n var c = tmp$[i];\n dd[i] = a * c;\n }\n return new PolynomialFunction(dd);\n };\n PolynomialFunction.prototype.times_3j0b7h$ = function (other) {\n var nd = this.coefficients_0.length + other.coefficients_0.length - 1 | 0;\n var nc = new Float64Array(nd);\n for (var i = 0; i < nd; i++) {\n for (var j = 0; j <= i; j++) {\n var a = j < this.coefficients_0.length ? this.coefficients_0[j] : 0.0;\n var k = i - j | 0;\n var b = k < other.coefficients_0.length ? other.coefficients_0[k] : 0.0;\n nc[i] = nc[i] + a * b;\n }\n }\n return new PolynomialFunction(nc);\n };\n PolynomialFunction.prototype.degree = function () {\n var tmp$ = collect.Comparables;\n var $receiver = this.coefficients_0;\n var indexOfLast$result;\n indexOfLast$break: do {\n var tmp$_0;\n tmp$_0 = reversed_0(get_indices($receiver)).iterator();\n while (tmp$_0.hasNext()) {\n var index = tmp$_0.next();\n if ($receiver[index] !== 0.0) {\n indexOfLast$result = index;\n break indexOfLast$break;\n }}\n indexOfLast$result = -1;\n }\n while (false);\n return tmp$.max_sdesaw$(0, indexOfLast$result);\n };\n PolynomialFunction.prototype.compareTo_3j0b7h$ = function (other) {\n var d1 = this.degree();\n var d2 = other.degree();\n var n = collect.Comparables.min_sdesaw$(d1, d2) + 1 | 0;\n for (var i = 0; i < n; i++) {\n var a = this.coefficients_0[i];\n var b = other.coefficients_0[i];\n var res = Kotlin.compareTo(a, b);\n if (res !== 0)\n return res;\n }\n return Kotlin.primitiveCompareTo(d1, d2);\n };\n PolynomialFunction.prototype.equals = function (other) {\n if (other == null || !Kotlin.isType(other, PolynomialFunction))\n return false;\n return this.compareTo_3j0b7h$(other) === 0;\n };\n PolynomialFunction.prototype.hashCode = function () {\n return hashCode(this.coefficients_0);\n };\n PolynomialFunction.prototype.toString = function () {\n var sb = StringBuilder_init();\n for (var i = get_lastIndex(this.coefficients_0); i >= 0; i--) {\n if (this.coefficients_0[i] !== 0.0) {\n if (!(sb.length === 0))\n sb.append_pdl1vj$(' + ');\n sb.append_pdl1vj$(this.coefficients_0[i].toString());\n if (i > 0)\n sb.append_pdl1vj$('x');\n if (i > 1)\n sb.append_pdl1vj$('^').append_s8jyv4$(i);\n }}\n return sb.toString();\n };\n PolynomialFunction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialFunction',\n interfaces: []\n };\n function times($receiver, p) {\n return p.multiply_14dthe$($receiver);\n }\n function PolynomialSplineFunction(_knots, _polynomials) {\n this.knots = null;\n this.polynomials = null;\n this.n_0 = 0;\n if (_knots == null) {\n throw IllegalStateException_init('Null argument '.toString());\n }if (_knots.length < 2) {\n throw IllegalStateException_init(('Spline partition must have at least 2 points, got ' + _knots.length).toString());\n }if ((_knots.length - 1 | 0) !== _polynomials.length) {\n throw IllegalStateException_init(('Dimensions mismatch: ' + _polynomials.length + ' polynomial functions != ' + _knots.length + ' segment delimiters').toString());\n }MathArrays_getInstance().checkOrder_gf7tl1$(_knots);\n this.n_0 = _knots.length - 1 | 0;\n this.knots = _knots;\n this.polynomials = Kotlin.newArray(this.n_0, null);\n arrayCopy(_polynomials, this.polynomials, 0, 0, this.n_0);\n }\n PolynomialSplineFunction.prototype.value_14dthe$ = function (v) {\n var tmp$;\n if (v < this.knots[0] || v > this.knots[this.n_0]) {\n throw IllegalStateException_init((v.toString() + ' out of [' + this.knots[0] + ', ' + this.knots[this.n_0] + '] range').toString());\n }var i = binarySearch(toMutableList_0(this.knots), v);\n if (i < 0) {\n i = (-i | 0) - 2 | 0;\n }if (i >= this.polynomials.length) {\n i = i - 1 | 0;\n }return (tmp$ = this.polynomials[i]) != null ? tmp$.value_14dthe$(v - this.knots[i]) : null;\n };\n PolynomialSplineFunction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialSplineFunction',\n interfaces: []\n };\n function Precision() {\n Precision_instance = this;\n this.SGN_MASK_0 = L_2147483648;\n this.SGN_MASK_FLOAT_0 = -2147483648;\n }\n Precision.prototype.compareTo_yvo9jy$ = function (x, y, eps) {\n if (this.equals_yvo9jy$(x, y, eps)) {\n return 0;\n } else if (x < y) {\n return -1;\n }return 1;\n };\n Precision.prototype.compareTo_syxxoe$ = function (x, y, maxUlps) {\n if (this.equals_syxxoe$(x, y, maxUlps)) {\n return 0;\n } else if (x < y) {\n return -1;\n }return 1;\n };\n Precision.prototype.equalsIncludingNaN_dleff0$ = function (x, y) {\n return isNaN_1(x) && isNaN_1(y) || this.equals_a5xegy$(x, y, 1);\n };\n Precision.prototype.equals_y2kzbl$ = function (x, y, eps) {\n var tmp$ = this.equals_a5xegy$(x, y, 1);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equalsIncludingNaN_y2kzbl$ = function (x, y, eps) {\n var tmp$ = this.equalsIncludingNaN_dleff0$(x, y);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equals_a5xegy$ = function (x, y, maxUlps) {\n if (maxUlps === void 0)\n maxUlps = 1;\n var xInt = toBits(x);\n var yInt = toBits(y);\n if (xInt < 0) {\n xInt = this.SGN_MASK_FLOAT_0 - xInt | 0;\n }if (yInt < 0) {\n yInt = this.SGN_MASK_FLOAT_0 - yInt | 0;\n }var isEqual = abs(xInt - yInt | 0) <= maxUlps;\n return isEqual && !isNaN_1(x) && !isNaN_1(y);\n };\n Precision.prototype.equalsIncludingNaN_a5xegy$ = function (x, y, maxUlps) {\n return isNaN_1(x) && isNaN_1(y) || this.equals_a5xegy$(x, y, maxUlps);\n };\n Precision.prototype.equalsIncludingNaN_lu1900$ = function (x, y) {\n return isNaN_0(x) && isNaN_0(y) || this.equals_syxxoe$(x, y, 1);\n };\n Precision.prototype.equals_yvo9jy$ = function (x, y, eps) {\n var tmp$ = this.equals_syxxoe$(x, y, 1);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equalsIncludingNaN_yvo9jy$ = function (x, y, eps) {\n var tmp$ = this.equalsIncludingNaN_lu1900$(x, y);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equals_syxxoe$ = function (x, y, maxUlps) {\n if (maxUlps === void 0)\n maxUlps = 1;\n var xInt = toBits_0(x);\n var yInt = toBits_0(y);\n if (xInt.toNumber() < 0) {\n xInt = this.SGN_MASK_0.subtract(xInt);\n }if (yInt.toNumber() < 0) {\n yInt = this.SGN_MASK_0.subtract(yInt);\n }var isEqual = abs_0(xInt.subtract(yInt)).toNumber() <= maxUlps;\n return isEqual && !isNaN_0(x) && !isNaN_0(y);\n };\n Precision.prototype.equalsIncludingNaN_syxxoe$ = function (x, y, maxUlps) {\n return isNaN_0(x) && isNaN_0(y) || this.equals_syxxoe$(x, y, maxUlps);\n };\n Precision.prototype.representableDelta_lu1900$ = function (x, originalDelta) {\n return x + originalDelta - x;\n };\n Precision.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Precision',\n interfaces: []\n };\n var Precision_instance = null;\n function Precision_getInstance() {\n if (Precision_instance === null) {\n new Precision();\n }return Precision_instance;\n }\n function RealDistribution() {\n }\n RealDistribution.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'RealDistribution',\n interfaces: []\n };\n function SplineInterpolator() {\n }\n SplineInterpolator.prototype.interpolate_g9g6do$ = function (x, y) {\n if (x.length !== y.length) {\n throw IllegalStateException_init(('Dimension mismatch ' + x.length + ' != ' + y.length).toString());\n }if (x.length < 3) {\n throw IllegalStateException_init(('Too small value of points number: ' + x.length + ' < 3').toString());\n }var n = x.length - 1 | 0;\n MathArrays_getInstance().checkOrder_gf7tl1$(x);\n var h = new Float64Array(n);\n for (var i = 0; i < n; i++) {\n h[i] = x[i + 1 | 0] - x[i];\n }\n var mu = new Float64Array(n);\n var z = new Float64Array(n + 1 | 0);\n mu[0] = 0.0;\n z[0] = 0.0;\n for (var i_0 = 1; i_0 < n; i_0++) {\n var g = 2.0 * (x[i_0 + 1 | 0] - x[i_0 - 1 | 0]) - h[i_0 - 1 | 0] * mu[i_0 - 1 | 0];\n mu[i_0] = h[i_0] / g;\n z[i_0] = (3.0 * (y[i_0 + 1 | 0] * h[i_0 - 1 | 0] - y[i_0] * (x[i_0 + 1 | 0] - x[i_0 - 1 | 0]) + y[i_0 - 1 | 0] * h[i_0]) / (h[i_0 - 1 | 0] * h[i_0]) - h[i_0 - 1 | 0] * z[i_0 - 1 | 0]) / g;\n }\n var b = new Float64Array(n);\n var c = new Float64Array(n + 1 | 0);\n var d = new Float64Array(n);\n z[n] = 0.0;\n c[n] = 0.0;\n for (var j = n - 1 | 0; j >= 0; j--) {\n c[j] = z[j] - mu[j] * c[j + 1 | 0];\n b[j] = (y[j + 1 | 0] - y[j]) / h[j] - h[j] * (c[j + 1 | 0] + 2.0 * c[j]) / 3.0;\n d[j] = (c[j + 1 | 0] - c[j]) / (3.0 * h[j]);\n }\n var polynomials = Kotlin.newArray(n, null);\n var coefficients = new Float64Array(4);\n for (var i_1 = 0; i_1 < n; i_1++) {\n coefficients[0] = y[i_1];\n coefficients[1] = b[i_1];\n coefficients[2] = c[i_1];\n coefficients[3] = d[i_1];\n polynomials[i_1] = new PolynomialFunction(coefficients);\n }\n return new PolynomialSplineFunction(x, polynomials);\n };\n SplineInterpolator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SplineInterpolator',\n interfaces: []\n };\n function TDistribution(degreesOfFreedom, solverAbsoluteAccuracy) {\n TDistribution$Companion_getInstance();\n if (solverAbsoluteAccuracy === void 0)\n solverAbsoluteAccuracy = TDistribution$Companion_getInstance().DEFAULT_INVERSE_ABSOLUTE_ACCURACY;\n AbstractRealDistribution.call(this);\n this.degreesOfFreedom_0 = degreesOfFreedom;\n this.solverAbsoluteAccuracy_l8ezvu$_0 = solverAbsoluteAccuracy;\n if (this.degreesOfFreedom_0 <= 0) {\n throw IllegalStateException_init(('NotStrictlyPositive - DEGREES_OF_FREEDOM: ' + this.degreesOfFreedom_0).toString());\n }}\n Object.defineProperty(TDistribution.prototype, 'solverAbsoluteAccuracy', {\n get: function () {\n return this.solverAbsoluteAccuracy_l8ezvu$_0;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'numericalMean', {\n configurable: true,\n get: function () {\n var tmp$;\n var df = this.degreesOfFreedom_0;\n if (df > 1) {\n tmp$ = 0.0;\n } else\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n return tmp$;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'numericalVariance', {\n configurable: true,\n get: function () {\n var tmp$;\n var df = this.degreesOfFreedom_0;\n if (df > 2) {\n return df / (df - 2);\n }if (df > 1 && df <= 2) {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n } else\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n return tmp$;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'supportLowerBound', {\n configurable: true,\n get: function () {\n return kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'supportUpperBound', {\n configurable: true,\n get: function () {\n return kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportLowerBoundInclusive', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportUpperBoundInclusive', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportConnected', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n TDistribution.prototype.probability_14dthe$ = function (x) {\n return 0.0;\n };\n TDistribution.prototype.density_14dthe$ = function (x) {\n var n = this.degreesOfFreedom_0;\n var nPlus1Over2 = (n + 1) / 2;\n var tmp$ = Gamma_getInstance().logGamma_14dthe$(nPlus1Over2);\n var x_0 = math.PI;\n var tmp$_0 = tmp$ - 0.5 * (JsMath.log(x_0) + JsMath.log(n)) - Gamma_getInstance().logGamma_14dthe$(n / 2);\n var x_1 = 1 + x * x / n;\n var x_2 = tmp$_0 - nPlus1Over2 * JsMath.log(x_1);\n return JsMath.exp(x_2);\n };\n TDistribution.prototype.cumulativeProbability_14dthe$ = function (x) {\n var ret;\n if (x === 0.0) {\n ret = 0.5;\n } else {\n var t = Beta_getInstance().regularizedBeta_tychlm$(this.degreesOfFreedom_0 / (this.degreesOfFreedom_0 + x * x), 0.5 * this.degreesOfFreedom_0, 0.5);\n if (x < 0.0) {\n ret = 0.5 * t;\n } else {\n ret = 1.0 - 0.5 * t;\n }\n }\n return ret;\n };\n function TDistribution$Companion() {\n TDistribution$Companion_instance = this;\n this.DEFAULT_INVERSE_ABSOLUTE_ACCURACY = 1.0E-9;\n this.serialVersionUID_0 = L_5852615386664158222;\n }\n TDistribution$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TDistribution$Companion_instance = null;\n function TDistribution$Companion_getInstance() {\n if (TDistribution$Companion_instance === null) {\n new TDistribution$Companion();\n }return TDistribution$Companion_instance;\n }\n TDistribution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TDistribution',\n interfaces: [AbstractRealDistribution]\n };\n function UnivariateFunction() {\n }\n UnivariateFunction.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UnivariateFunction',\n interfaces: []\n };\n function UnivariateSolver() {\n }\n UnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function UnivariateSolverUtils() {\n UnivariateSolverUtils_instance = this;\n }\n UnivariateSolverUtils.prototype.solve_ljmp9$ = function (function_0, x0, x1) {\n var solver = BrentSolver_init();\n return solver.solve_rmnly1$(2147483647, function_0, x0, x1);\n };\n UnivariateSolverUtils.prototype.solve_wb66u3$ = function (function_0, x0, x1, absoluteAccuracy) {\n var solver = BrentSolver_init(absoluteAccuracy);\n return solver.solve_rmnly1$(2147483647, function_0, x0, x1);\n };\n UnivariateSolverUtils.prototype.forceSide_i33h9z$ = function (maxEval, f, bracketing, baseRoot, min, max, allowedSolution) {\n if (allowedSolution === AllowedSolution$ANY_SIDE_getInstance()) {\n return baseRoot;\n }var tmp$ = bracketing.absoluteAccuracy;\n var x = baseRoot * bracketing.relativeAccuracy;\n var b = JsMath.abs(x);\n var step = JsMath.max(tmp$, b);\n var b_0 = baseRoot - step;\n var xLo = JsMath.max(min, b_0);\n var fLo = f.value_14dthe$(xLo);\n var b_1 = baseRoot + step;\n var xHi = JsMath.min(max, b_1);\n var fHi = f.value_14dthe$(xHi);\n var remainingEval = maxEval - 2 | 0;\n while (remainingEval > 0) {\n if (fLo >= 0 && fHi <= 0 || (fLo <= 0 && fHi >= 0)) {\n return bracketing.solve_epddgp$(remainingEval, f, xLo, xHi, baseRoot, allowedSolution);\n }var changeLo = false;\n var changeHi = false;\n if (fLo < fHi) {\n if (fLo >= 0) {\n changeLo = true;\n } else {\n changeHi = true;\n }\n } else if (fLo > fHi) {\n if (fLo <= 0) {\n changeLo = true;\n } else {\n changeHi = true;\n }\n } else {\n changeLo = true;\n changeHi = true;\n }\n if (changeLo) {\n var b_2 = xLo - step;\n xLo = JsMath.max(min, b_2);\n fLo = f.value_14dthe$(xLo);\n remainingEval = remainingEval - 1 | 0;\n }if (changeHi) {\n var b_3 = xHi + step;\n xHi = JsMath.min(max, b_3);\n fHi = f.value_14dthe$(xHi);\n remainingEval = remainingEval - 1 | 0;\n }}\n throw IllegalStateException_init('NoBracketing'.toString());\n };\n UnivariateSolverUtils.prototype.bracket_cflw21$ = function (function_0, initial, lowerBound, upperBound, maximumIterations) {\n if (maximumIterations === void 0)\n maximumIterations = 2147483647;\n if (maximumIterations <= 0) {\n throw IllegalStateException_init('NotStrictlyPositive'.toString());\n }this.verifySequence_yvo9jy$(lowerBound, initial, upperBound);\n var a = initial;\n var b = initial;\n var fa;\n var fb;\n var numIterations = 0;\n do {\n var a_0 = a - 1.0;\n a = JsMath.max(a_0, lowerBound);\n var a_1 = b + 1.0;\n b = JsMath.min(a_1, upperBound);\n fa = function_0.value_14dthe$(a);\n fb = function_0.value_14dthe$(b);\n numIterations = numIterations + 1 | 0;\n }\n while (fa * fb > 0.0 && numIterations < maximumIterations && (a > lowerBound || b < upperBound));\n if (fa * fb > 0.0) {\n throw IllegalStateException_init('NoBracketing'.toString());\n }return new Float64Array([a, b]);\n };\n UnivariateSolverUtils.prototype.midpoint_lu1900$ = function (a, b) {\n return (a + b) * 0.5;\n };\n UnivariateSolverUtils.prototype.isBracketing_ljmp9$ = function (function_0, lower, upper) {\n var fLo = function_0.value_14dthe$(lower);\n var fHi = function_0.value_14dthe$(upper);\n return fLo >= 0 && fHi <= 0 || (fLo <= 0 && fHi >= 0);\n };\n UnivariateSolverUtils.prototype.isSequence_yvo9jy$ = function (start, mid, end) {\n return start < mid && mid < end;\n };\n UnivariateSolverUtils.prototype.verifyInterval_lu1900$ = function (lower, upper) {\n if (lower >= upper) {\n throw IllegalStateException_init('NumberIsTooLarge'.toString());\n }};\n UnivariateSolverUtils.prototype.verifySequence_yvo9jy$ = function (lower, initial, upper) {\n this.verifyInterval_lu1900$(lower, initial);\n this.verifyInterval_lu1900$(initial, upper);\n };\n UnivariateSolverUtils.prototype.verifyBracketing_ljmp9$ = function (function_0, lower, upper) {\n this.verifyInterval_lu1900$(lower, upper);\n if (!this.isBracketing_ljmp9$(function_0, lower, upper)) {\n throw IllegalStateException_init('NoBracketing'.toString());\n }};\n UnivariateSolverUtils.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'UnivariateSolverUtils',\n interfaces: []\n };\n var UnivariateSolverUtils_instance = null;\n function UnivariateSolverUtils_getInstance() {\n if (UnivariateSolverUtils_instance === null) {\n new UnivariateSolverUtils();\n }return UnivariateSolverUtils_instance;\n }\n function EvalResult(y, ymin, ymax, se) {\n this.y = y;\n this.ymin = ymin;\n this.ymax = ymax;\n this.se = se;\n }\n EvalResult.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EvalResult',\n interfaces: []\n };\n EvalResult.prototype.component1 = function () {\n return this.y;\n };\n EvalResult.prototype.component2 = function () {\n return this.ymin;\n };\n EvalResult.prototype.component3 = function () {\n return this.ymax;\n };\n EvalResult.prototype.component4 = function () {\n return this.se;\n };\n EvalResult.prototype.copy_6y0v78$ = function (y, ymin, ymax, se) {\n return new EvalResult(y === void 0 ? this.y : y, ymin === void 0 ? this.ymin : ymin, ymax === void 0 ? this.ymax : ymax, se === void 0 ? this.se : se);\n };\n EvalResult.prototype.toString = function () {\n return 'EvalResult(y=' + Kotlin.toString(this.y) + (', ymin=' + Kotlin.toString(this.ymin)) + (', ymax=' + Kotlin.toString(this.ymax)) + (', se=' + Kotlin.toString(this.se)) + ')';\n };\n EvalResult.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.y) | 0;\n result = result * 31 + Kotlin.hashCode(this.ymin) | 0;\n result = result * 31 + Kotlin.hashCode(this.ymax) | 0;\n result = result * 31 + Kotlin.hashCode(this.se) | 0;\n return result;\n };\n EvalResult.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.y, other.y) && Kotlin.equals(this.ymin, other.ymin) && Kotlin.equals(this.ymax, other.ymax) && Kotlin.equals(this.se, other.se)))));\n };\n function LinearRegression(xs, ys, confidenceLevel) {\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.beta1_0 = 0;\n this.beta0_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n var tmp$ = allFinite(xs, ys);\n var xVals = tmp$.component1()\n , yVals = tmp$.component2();\n this.n_0 = xVals.length;\n this.meanX_0 = average(xVals);\n var tmp$_0;\n var sum = 0;\n for (tmp$_0 = 0; tmp$_0 !== xVals.length; ++tmp$_0) {\n var element = xVals[tmp$_0];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var meanY = average(yVals);\n var tmp$_1;\n var sum_0 = 0;\n for (tmp$_1 = 0; tmp$_1 !== yVals.length; ++tmp$_1) {\n var element_0 = yVals[tmp$_1];\n var $receiver_0 = element_0 - meanY;\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sumYY = sum_0;\n var tmp$_2;\n var sum_1 = 0;\n tmp$_2 = zip_0(xVals, yVals).iterator();\n while (tmp$_2.hasNext()) {\n var element_1 = tmp$_2.next();\n var x = element_1.component1()\n , y = element_1.component2();\n sum_1 += (x - this.meanX_0) * (y - meanY);\n }\n var sumXY = sum_1;\n this.beta1_0 = sumXY / this.sumXX_0;\n this.beta0_0 = meanY - this.beta1_0 * this.meanX_0;\n var b = sumYY - sumXY * sumXY / this.sumXX_0;\n var sse = JsMath.max(0.0, b);\n var x_0 = sse / (this.n_0 - 2 | 0);\n this.sy_0 = JsMath.sqrt(x_0);\n var alpha = 1.0 - confidenceLevel;\n this.tcritical_0 = (new TDistribution(this.n_0 - 2.0)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n }\n LinearRegression.prototype.value_0 = function (x) {\n return this.beta1_0 * x + this.beta0_0;\n };\n LinearRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = this.value_0(x);\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n LinearRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearRegression',\n interfaces: [RegressionEvaluator]\n };\n function LocalPolynomialRegression(xs, ys, confidenceLevel, bandwidth) {\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.bandwidth_0 = bandwidth;\n this.canCompute = false;\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n this.polynomial_6goixr$_0 = this.polynomial_6goixr$_0;\n var tmp$;\n var tmp$_0 = averageByX_0(xs, ys);\n var xVals = tmp$_0.component1()\n , yVals = tmp$_0.component2();\n this.n_0 = xVals.length;\n var degreesOfFreedom = this.n_0 - 2.0;\n var bandwidthInPoints = numberToInt(this.bandwidth_0 * this.n_0);\n var bandwidthInPointsOk = bandwidthInPoints >= 2;\n this.canCompute = (this.n_0 >= 3 && degreesOfFreedom > 0 && bandwidthInPointsOk);\n this.meanX_0 = average(xVals);\n var tmp$_1;\n var sum = 0;\n for (tmp$_1 = 0; tmp$_1 !== xVals.length; ++tmp$_1) {\n var element = xVals[tmp$_1];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var meanY = average(yVals);\n var tmp$_2;\n var sum_0 = 0;\n for (tmp$_2 = 0; tmp$_2 !== yVals.length; ++tmp$_2) {\n var element_0 = yVals[tmp$_2];\n var $receiver_0 = element_0 - meanY;\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sumYY = sum_0;\n var tmp$_3;\n var sum_1 = 0;\n tmp$_3 = zip_0(xVals, yVals).iterator();\n while (tmp$_3.hasNext()) {\n var element_1 = tmp$_3.next();\n var x = element_1.component1()\n , y = element_1.component2();\n sum_1 += (x - this.meanX_0) * (y - meanY);\n }\n var sumXY = sum_1;\n var b = sumYY - sumXY * sumXY / this.sumXX_0;\n var sse = JsMath.max(0.0, b);\n var x_0 = sse / (this.n_0 - 2 | 0);\n this.sy_0 = JsMath.sqrt(x_0);\n if (this.canCompute) {\n this.polynomial_0 = this.getPoly_0(xVals, yVals);\n }if (this.canCompute) {\n var alpha = 1.0 - confidenceLevel;\n tmp$ = (new TDistribution(degreesOfFreedom)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n } else {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n }\n this.tcritical_0 = tmp$;\n }\n Object.defineProperty(LocalPolynomialRegression.prototype, 'polynomial_0', {\n configurable: true,\n get: function () {\n if (this.polynomial_6goixr$_0 == null)\n return throwUPAE('polynomial');\n return this.polynomial_6goixr$_0;\n },\n set: function (polynomial) {\n this.polynomial_6goixr$_0 = polynomial;\n }\n });\n LocalPolynomialRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = ensureNotNull(this.polynomial_0.value_14dthe$(x));\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n LocalPolynomialRegression.prototype.getPoly_0 = function (xVals, yVals) {\n return (new LoessInterpolator(this.bandwidth_0, 4)).interpolate_g9g6do$(xVals, yVals);\n };\n LocalPolynomialRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LocalPolynomialRegression',\n interfaces: [RegressionEvaluator]\n };\n function PolynomialRegression(xs, ys, confidenceLevel, deg) {\n PolynomialRegression$Companion_getInstance();\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.p_0 = null;\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n if (!(deg >= 2)) {\n var message = 'Degree of polynomial must be at least 2';\n throw IllegalArgumentException_init(message.toString());\n }var tmp$ = averageByX_0(xs, ys);\n var xVals = tmp$.component1()\n , yVals = tmp$.component2();\n this.n_0 = xVals.length;\n if (!(this.n_0 > deg)) {\n var message_0 = 'The number of valid data points must be greater than deg';\n throw IllegalArgumentException_init(message_0.toString());\n }this.p_0 = this.calcPolynomial_0(deg, xVals, yVals);\n this.meanX_0 = average(xVals);\n var tmp$_0;\n var sum = 0;\n for (tmp$_0 = 0; tmp$_0 !== xVals.length; ++tmp$_0) {\n var element = xVals[tmp$_0];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var df = (this.n_0 - deg | 0) - 1.0;\n var tmp$_1;\n var sum_0 = 0;\n tmp$_1 = zip_0(xVals, yVals).iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n var x = element_0.component1()\n , y = element_0.component2();\n var $receiver_0 = y - this.p_0.value_14dthe$(x);\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sse = sum_0;\n var x_0 = sse / df;\n this.sy_0 = JsMath.sqrt(x_0);\n var alpha = 1.0 - confidenceLevel;\n this.tcritical_0 = (new TDistribution(df)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n }\n PolynomialRegression.prototype.calcPolynomial_0 = function (deg, xVals, yVals) {\n var fpg = new ForsythePolynomialGenerator(xVals);\n var res = new PolynomialFunction(new Float64Array([0.0]));\n for (var i = 0; i <= deg; i++) {\n var p = fpg.getPolynomial_za3lpa$(i);\n var s = this.coefficient_0(p, xVals, yVals);\n res = res.plus_3j0b7h$(times(s, p));\n }\n return res;\n };\n PolynomialRegression.prototype.coefficient_0 = function (p, xVals, yVals) {\n var ww = 0.0;\n var w = 0.0;\n for (var i = 0; i < xVals.length; i++) {\n var x = xVals[i];\n var y = yVals[i];\n var pval = p.value_14dthe$(x);\n ww += pval * pval;\n w += y * pval;\n }\n return w / ww;\n };\n PolynomialRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = this.p_0.value_14dthe$(x);\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n function PolynomialRegression$Companion() {\n PolynomialRegression$Companion_instance = this;\n }\n PolynomialRegression$Companion.prototype.canBeComputed_fgqkrm$ = function (xs, ys, deg) {\n var xVals = averageByX_0(xs, ys).component1();\n return xVals.length > deg;\n };\n PolynomialRegression$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolynomialRegression$Companion_instance = null;\n function PolynomialRegression$Companion_getInstance() {\n if (PolynomialRegression$Companion_instance === null) {\n new PolynomialRegression$Companion();\n }return PolynomialRegression$Companion_instance;\n }\n PolynomialRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialRegression',\n interfaces: [RegressionEvaluator]\n };\n function RegressionEvaluator(xs, ys, confidenceLevel) {\n if (!rangeTo(0.01, 0.99).contains_mef7kx$(confidenceLevel)) {\n var message = 'Confidence level is out of range [0.01-0.99]. CL:' + confidenceLevel;\n throw IllegalArgumentException_init(message.toString());\n }if (!(xs.size === ys.size)) {\n var message_0 = 'X/Y must have same size. X:' + toString(xs.size) + ' Y:' + toString(ys.size);\n throw IllegalArgumentException_init(message_0.toString());\n }}\n RegressionEvaluator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RegressionEvaluator',\n interfaces: []\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function RegressionUtil() {\n RegressionUtil_instance = this;\n }\n RegressionUtil.prototype.sampling_v81hsd$ = function (data, m) {\n var tmp$;\n var index = this.sampleInt_0(data.size, m);\n var result = ArrayList_init();\n for (tmp$ = 0; tmp$ !== index.length; ++tmp$) {\n var i = index[tmp$];\n result.add_11rb$(data.get_za3lpa$(i));\n }\n return result;\n };\n RegressionUtil.prototype.sampleInt_0 = function (n, m) {\n if (n < m || m < 0) {\n throw IllegalStateException_init(('Sample ' + m + ' data from ' + n + ' data is impossible!').toString());\n }var perm = new Int32Array(n);\n for (var i = 0; i < n; i++) {\n perm[i] = i;\n }\n var result = new Int32Array(m);\n for (var j = 0; j < m; j++) {\n var r = j + numberToInt(Random.Default.nextDouble() * (n - j | 0)) | 0;\n result[j] = perm[r];\n perm[r] = perm[j];\n }\n return result;\n };\n RegressionUtil.prototype.percentile_av4ikl$ = function (data, p) {\n return Percentile_getInstance().evaluate_pw9xcd$(toDoubleArray(data), p * 100);\n };\n RegressionUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'RegressionUtil',\n interfaces: []\n };\n var RegressionUtil_instance = null;\n function RegressionUtil_getInstance() {\n if (RegressionUtil_instance === null) {\n new RegressionUtil();\n }return RegressionUtil_instance;\n }\n function allFinite(xs, ys) {\n var tmp$;\n var tx = ArrayList_init();\n var ty = ArrayList_init();\n tmp$ = zip_1(asSequence(xs), asSequence(ys)).iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var x = tmp$_0.component1()\n , y = tmp$_0.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n tx.add_11rb$(ensureNotNull(x));\n ty.add_11rb$(ensureNotNull(y));\n }}\n return new Pair_0(toDoubleArray(tx), toDoubleArray(ty));\n }\n function finitePairs(xs, ys) {\n var tmp$;\n var res = ArrayList_init();\n tmp$ = zip_1(asSequence(xs), asSequence(ys)).iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var x = tmp$_0.component1()\n , y = tmp$_0.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n res.add_11rb$(new Pair_0(ensureNotNull(x), ensureNotNull(y)));\n }}\n return res;\n }\n function averageByX(lst) {\n var tmp$;\n if (lst.isEmpty())\n return new Pair_0(ArrayList_init(), ArrayList_init());\n var tx = ArrayList_init();\n var ty = ArrayList_init();\n var tmp$_0 = first(lst);\n var prevX = tmp$_0.component1()\n , sumY = tmp$_0.component2();\n var countY = 1;\n tmp$ = drop(asSequence(lst), 1).iterator();\n while (tmp$.hasNext()) {\n var tmp$_1 = tmp$.next();\n var x = tmp$_1.component1()\n , y = tmp$_1.component2();\n if (x === prevX) {\n sumY += y;\n countY = countY + 1 | 0;\n } else {\n tx.add_11rb$(prevX);\n ty.add_11rb$(sumY / countY);\n prevX = x;\n sumY = y;\n countY = 1;\n }\n }\n tx.add_11rb$(prevX);\n ty.add_11rb$(sumY / countY);\n return new Pair_0(tx, ty);\n }\n function averageByX$lambda(it) {\n return it.first;\n }\n function averageByX_0(xs, ys) {\n var tp = finitePairs(xs, ys);\n if (tp.size > 1) {\n sortWith(tp, new Comparator(compareBy$lambda_0(averageByX$lambda)));\n }var res = averageByX(tp);\n return new Pair_0(toDoubleArray(res.first), toDoubleArray(res.second));\n }\n function MutableDouble(myValue) {\n this.myValue_0 = myValue;\n }\n MutableDouble.prototype.getAndAdd_14dthe$ = function (v) {\n var prevValue = this.myValue_0;\n this.myValue_0 = prevValue + v;\n return prevValue;\n };\n MutableDouble.prototype.get = function () {\n return this.myValue_0;\n };\n MutableDouble.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MutableDouble',\n interfaces: []\n };\n function MutableInteger(myValue) {\n this.myValue_0 = myValue;\n }\n Object.defineProperty(MutableInteger.prototype, 'andIncrement', {\n configurable: true,\n get: function () {\n return this.getAndAdd_za3lpa$(1);\n }\n });\n MutableInteger.prototype.get = function () {\n return this.myValue_0;\n };\n MutableInteger.prototype.getAndAdd_za3lpa$ = function (v) {\n var prevValue = this.myValue_0;\n this.myValue_0 = prevValue + v | 0;\n return prevValue;\n };\n MutableInteger.prototype.increment = function () {\n this.getAndAdd_za3lpa$(1);\n };\n MutableInteger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MutableInteger',\n interfaces: []\n };\n function SamplingUtil() {\n SamplingUtil_instance = this;\n }\n SamplingUtil.prototype.sampleWithoutReplacement_o7ew15$ = function (popSize, sampleSize, rand, onPick, onDrop) {\n var pick = sampleSize <= (popSize / 2 | 0);\n var indexCount = pick ? sampleSize : popSize - sampleSize | 0;\n var indexSet = HashSet_init_1();\n while (indexSet.size < indexCount) {\n indexSet.add_11rb$(rand.nextInt_za3lpa$(popSize));\n }\n return pick ? onPick(indexSet) : onDrop(indexSet);\n };\n function SamplingUtil$sampleWithoutReplacement$lambda(closure$data) {\n return function (it) {\n return closure$data.selectIndices_p1n9e9$(it);\n };\n }\n function SamplingUtil$sampleWithoutReplacement$lambda_0(closure$data) {\n return function (it) {\n return closure$data.dropIndices_p1n9e9$(it);\n };\n }\n SamplingUtil.prototype.sampleWithoutReplacement_egh5ya$ = function (sampleSize, rand, data) {\n return this.sampleWithoutReplacement_o7ew15$(data.rowCount(), sampleSize, rand, SamplingUtil$sampleWithoutReplacement$lambda(data), SamplingUtil$sampleWithoutReplacement$lambda_0(data));\n };\n SamplingUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SamplingUtil',\n interfaces: []\n };\n var SamplingUtil_instance = null;\n function SamplingUtil_getInstance() {\n if (SamplingUtil_instance === null) {\n new SamplingUtil();\n }return SamplingUtil_instance;\n }\n Object.defineProperty(Aes, 'Companion', {\n get: Aes$Companion_getInstance\n });\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n var package$base = package$plot.base || (package$plot.base = {});\n package$base.Aes = Aes;\n package$base.Aesthetics = Aesthetics;\n package$base.ContinuousTransform = ContinuousTransform;\n package$base.CoordinateSystem = CoordinateSystem;\n DataFrame.OrderSpec = DataFrame$OrderSpec;\n Object.defineProperty(DataFrame$Variable$Source, 'ORIGIN', {\n get: DataFrame$Variable$Source$ORIGIN_getInstance\n });\n Object.defineProperty(DataFrame$Variable$Source, 'TRANSFORM', {\n get: DataFrame$Variable$Source$TRANSFORM_getInstance\n });\n Object.defineProperty(DataFrame$Variable$Source, 'STAT', {\n get: DataFrame$Variable$Source$STAT_getInstance\n });\n DataFrame$Variable.Source = DataFrame$Variable$Source;\n Object.defineProperty(DataFrame$Variable, 'Companion', {\n get: DataFrame$Variable$Companion_getInstance\n });\n DataFrame.Variable = DataFrame$Variable;\n Object.defineProperty(DataFrame, 'Companion', {\n get: DataFrame$Companion_getInstance\n });\n Object.defineProperty(DataFrame$Builder, 'Companion', {\n get: DataFrame$Builder$Companion_getInstance\n });\n DataFrame.Builder_init = DataFrame$DataFrame$Builder_init;\n DataFrame.Builder_init_dhhkv7$ = DataFrame$DataFrame$Builder_init_0;\n DataFrame.Builder = DataFrame$Builder;\n package$base.DataFrame = DataFrame;\n package$base.DataPointAesthetics = DataPointAesthetics;\n package$base.DiscreteTransform = DiscreteTransform;\n package$base.Geom = Geom;\n package$base.GeomContext = GeomContext;\n Object.defineProperty(GeomKind, 'PATH', {\n get: GeomKind$PATH_getInstance\n });\n Object.defineProperty(GeomKind, 'LINE', {\n get: GeomKind$LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'SMOOTH', {\n get: GeomKind$SMOOTH_getInstance\n });\n Object.defineProperty(GeomKind, 'BAR', {\n get: GeomKind$BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'HISTOGRAM', {\n get: GeomKind$HISTOGRAM_getInstance\n });\n Object.defineProperty(GeomKind, 'TILE', {\n get: GeomKind$TILE_getInstance\n });\n Object.defineProperty(GeomKind, 'BIN_2D', {\n get: GeomKind$BIN_2D_getInstance\n });\n Object.defineProperty(GeomKind, 'MAP', {\n get: GeomKind$MAP_getInstance\n });\n Object.defineProperty(GeomKind, 'ERROR_BAR', {\n get: GeomKind$ERROR_BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'CROSS_BAR', {\n get: GeomKind$CROSS_BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'LINE_RANGE', {\n get: GeomKind$LINE_RANGE_getInstance\n });\n Object.defineProperty(GeomKind, 'POINT_RANGE', {\n get: GeomKind$POINT_RANGE_getInstance\n });\n Object.defineProperty(GeomKind, 'POLYGON', {\n get: GeomKind$POLYGON_getInstance\n });\n Object.defineProperty(GeomKind, 'AB_LINE', {\n get: GeomKind$AB_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'H_LINE', {\n get: GeomKind$H_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'V_LINE', {\n get: GeomKind$V_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'BOX_PLOT', {\n get: GeomKind$BOX_PLOT_getInstance\n });\n Object.defineProperty(GeomKind, 'LIVE_MAP', {\n get: GeomKind$LIVE_MAP_getInstance\n });\n Object.defineProperty(GeomKind, 'POINT', {\n get: GeomKind$POINT_getInstance\n });\n Object.defineProperty(GeomKind, 'RIBBON', {\n get: GeomKind$RIBBON_getInstance\n });\n Object.defineProperty(GeomKind, 'AREA', {\n get: GeomKind$AREA_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY', {\n get: GeomKind$DENSITY_getInstance\n });\n Object.defineProperty(GeomKind, 'CONTOUR', {\n get: GeomKind$CONTOUR_getInstance\n });\n Object.defineProperty(GeomKind, 'CONTOURF', {\n get: GeomKind$CONTOURF_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY2D', {\n get: GeomKind$DENSITY2D_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY2DF', {\n get: GeomKind$DENSITY2DF_getInstance\n });\n Object.defineProperty(GeomKind, 'JITTER', {\n get: GeomKind$JITTER_getInstance\n });\n Object.defineProperty(GeomKind, 'FREQPOLY', {\n get: GeomKind$FREQPOLY_getInstance\n });\n Object.defineProperty(GeomKind, 'STEP', {\n get: GeomKind$STEP_getInstance\n });\n Object.defineProperty(GeomKind, 'RECT', {\n get: GeomKind$RECT_getInstance\n });\n Object.defineProperty(GeomKind, 'SEGMENT', {\n get: GeomKind$SEGMENT_getInstance\n });\n Object.defineProperty(GeomKind, 'TEXT', {\n get: GeomKind$TEXT_getInstance\n });\n Object.defineProperty(GeomKind, 'RASTER', {\n get: GeomKind$RASTER_getInstance\n });\n Object.defineProperty(GeomKind, 'IMAGE', {\n get: GeomKind$IMAGE_getInstance\n });\n package$base.GeomKind = GeomKind;\n Object.defineProperty(package$base, 'GeomMeta', {\n get: GeomMeta_getInstance\n });\n package$base.PositionAdjustment = PositionAdjustment;\n Scale.Builder = Scale$Builder;\n package$base.Scale = Scale;\n package$base.Stat = Stat;\n package$base.StatContext = StatContext;\n package$base.Transform = Transform;\n var package$aes = package$base.aes || (package$base.aes = {});\n Object.defineProperty(package$aes, 'AesInitValue', {\n get: AesInitValue_getInstance\n });\n Object.defineProperty(package$aes, 'AesScaling', {\n get: AesScaling_getInstance\n });\n package$aes.AesVisitor = AesVisitor;\n Object.defineProperty(AestheticsBuilder, 'Companion', {\n get: AestheticsBuilder$Companion_getInstance\n });\n package$aes.AestheticsBuilder = AestheticsBuilder;\n Object.defineProperty(AestheticsDefaults, 'Companion', {\n get: AestheticsDefaults$Companion_getInstance\n });\n package$aes.AestheticsDefaults = AestheticsDefaults;\n Object.defineProperty(package$aes, 'AestheticsUtil', {\n get: AestheticsUtil_getInstance\n });\n package$aes.TypedIndexFunctionMap = TypedIndexFunctionMap;\n var package$coord = package$base.coord || (package$base.coord = {});\n Object.defineProperty(package$coord, 'Coords', {\n get: Coords_getInstance\n });\n package$coord.DefaultCoordinateSystem = DefaultCoordinateSystem;\n package$coord.Projection = Projection;\n var package$data = package$base.data || (package$base.data = {});\n Object.defineProperty(package$data, 'DataFrameUtil', {\n get: DataFrameUtil_getInstance\n });\n Object.defineProperty(package$data, 'Dummies', {\n get: Dummies_getInstance\n });\n Object.defineProperty(package$data, 'TransformVar', {\n get: TransformVar_getInstance\n });\n Object.defineProperty(ABLineGeom, 'Companion', {\n get: ABLineGeom$Companion_getInstance\n });\n var package$geom = package$base.geom || (package$base.geom = {});\n package$geom.ABLineGeom = ABLineGeom;\n Object.defineProperty(AreaGeom, 'Companion', {\n get: AreaGeom$Companion_getInstance\n });\n package$geom.AreaGeom = AreaGeom;\n Object.defineProperty(BarGeom, 'Companion', {\n get: BarGeom$Companion_getInstance\n });\n package$geom.BarGeom = BarGeom;\n Object.defineProperty(Bin2dGeom, 'Companion', {\n get: Bin2dGeom$Companion_getInstance\n });\n package$geom.Bin2dGeom = Bin2dGeom;\n Object.defineProperty(BoxplotGeom, 'Companion', {\n get: BoxplotGeom$Companion_getInstance\n });\n package$geom.BoxplotGeom = BoxplotGeom;\n Object.defineProperty(ContourGeom, 'Companion', {\n get: ContourGeom$Companion_getInstance\n });\n package$geom.ContourGeom = ContourGeom;\n Object.defineProperty(ContourfGeom, 'Companion', {\n get: ContourfGeom$Companion_getInstance\n });\n package$geom.ContourfGeom = ContourfGeom;\n Object.defineProperty(CrossBarGeom, 'Companion', {\n get: CrossBarGeom$Companion_getInstance\n });\n package$geom.CrossBarGeom = CrossBarGeom;\n Object.defineProperty(Density2dGeom, 'Companion', {\n get: Density2dGeom$Companion_getInstance\n });\n package$geom.Density2dGeom = Density2dGeom;\n Object.defineProperty(Density2dfGeom, 'Companion', {\n get: Density2dfGeom$Companion_getInstance\n });\n package$geom.Density2dfGeom = Density2dfGeom;\n Object.defineProperty(DensityGeom, 'Companion', {\n get: DensityGeom$Companion_getInstance\n });\n package$geom.DensityGeom = DensityGeom;\n Object.defineProperty(ErrorBarGeom, 'Companion', {\n get: ErrorBarGeom$Companion_getInstance\n });\n package$geom.ErrorBarGeom = ErrorBarGeom;\n Object.defineProperty(FilledCircleLegendKeyElementFactory, 'Companion', {\n get: FilledCircleLegendKeyElementFactory$Companion_getInstance\n });\n package$geom.FilledCircleLegendKeyElementFactory = FilledCircleLegendKeyElementFactory;\n package$geom.FilledSquareLegendKeyElementFactory = FilledSquareLegendKeyElementFactory;\n Object.defineProperty(FreqpolyGeom, 'Companion', {\n get: FreqpolyGeom$Companion_getInstance\n });\n package$geom.FreqpolyGeom = FreqpolyGeom;\n Object.defineProperty(GeomBase, 'Companion', {\n get: GeomBase$Companion_getInstance\n });\n package$geom.GeomBase = GeomBase;\n Object.defineProperty(HLineGeom, 'Companion', {\n get: HLineGeom$Companion_getInstance\n });\n package$geom.HLineGeom = HLineGeom;\n Object.defineProperty(HistogramGeom, 'Companion', {\n get: HistogramGeom$Companion_getInstance\n });\n package$geom.HistogramGeom = HistogramGeom;\n Object.defineProperty(ImageGeom, 'Companion', {\n get: ImageGeom$Companion_getInstance\n });\n package$geom.ImageGeom = ImageGeom;\n Object.defineProperty(JitterGeom, 'Companion', {\n get: JitterGeom$Companion_getInstance\n });\n package$geom.JitterGeom = JitterGeom;\n Object.defineProperty(LineGeom, 'Companion', {\n get: LineGeom$Companion_getInstance\n });\n package$geom.LineGeom = LineGeom;\n Object.defineProperty(LineRangeGeom, 'Companion', {\n get: LineRangeGeom$Companion_getInstance\n });\n package$geom.LineRangeGeom = LineRangeGeom;\n Object.defineProperty(LiveMapGeom, 'Companion', {\n get: LiveMapGeom$Companion_getInstance\n });\n package$geom.LiveMapGeom = LiveMapGeom;\n LiveMapProvider.LiveMapData = LiveMapProvider$LiveMapData;\n package$geom.LiveMapProvider = LiveMapProvider;\n Object.defineProperty(MapGeom, 'Companion', {\n get: MapGeom$Companion_getInstance\n });\n package$geom.MapGeom = MapGeom;\n Object.defineProperty(PathGeom, 'Companion', {\n get: PathGeom$Companion_getInstance\n });\n package$geom.PathGeom = PathGeom;\n Object.defineProperty(PieGeom, 'Companion', {\n get: PieGeom$Companion_getInstance\n });\n package$geom.PieGeom = PieGeom;\n Object.defineProperty(PointGeom, 'Companion', {\n get: PointGeom$Companion_getInstance\n });\n package$geom.PointGeom = PointGeom;\n package$geom.PointLegendKeyElementFactory = PointLegendKeyElementFactory;\n Object.defineProperty(PointRangeGeom, 'Companion', {\n get: PointRangeGeom$Companion_getInstance\n });\n package$geom.PointRangeGeom = PointRangeGeom;\n Object.defineProperty(PolygonGeom, 'Companion', {\n get: PolygonGeom$Companion_getInstance\n });\n package$geom.PolygonGeom = PolygonGeom;\n Object.defineProperty(RasterGeom, 'Companion', {\n get: RasterGeom$Companion_getInstance\n });\n package$geom.RasterGeom = RasterGeom;\n Object.defineProperty(RectGeom, 'Companion', {\n get: RectGeom$Companion_getInstance\n });\n package$geom.RectGeom = RectGeom;\n Object.defineProperty(RibbonGeom, 'Companion', {\n get: RibbonGeom$Companion_getInstance\n });\n package$geom.RibbonGeom = RibbonGeom;\n Object.defineProperty(SegmentGeom, 'Companion', {\n get: SegmentGeom$Companion_getInstance\n });\n package$geom.SegmentGeom = SegmentGeom;\n Object.defineProperty(SmoothGeom, 'Companion', {\n get: SmoothGeom$Companion_getInstance\n });\n package$geom.SmoothGeom = SmoothGeom;\n Object.defineProperty(StepGeom$Direction, 'HV', {\n get: StepGeom$Direction$HV_getInstance\n });\n Object.defineProperty(StepGeom$Direction, 'VH', {\n get: StepGeom$Direction$VH_getInstance\n });\n Object.defineProperty(StepGeom$Direction, 'Companion', {\n get: StepGeom$Direction$Companion_getInstance\n });\n StepGeom.Direction = StepGeom$Direction;\n Object.defineProperty(StepGeom, 'Companion', {\n get: StepGeom$Companion_getInstance\n });\n package$geom.StepGeom = StepGeom;\n Object.defineProperty(TextGeom, 'Companion', {\n get: TextGeom$Companion_getInstance\n });\n package$geom.TextGeom = TextGeom;\n package$geom.TextLegendKeyElementFactory = TextLegendKeyElementFactory;\n Object.defineProperty(TileGeom, 'Companion', {\n get: TileGeom$Companion_getInstance\n });\n package$geom.TileGeom = TileGeom;\n Object.defineProperty(VLineGeom, 'Companion', {\n get: VLineGeom$Companion_getInstance\n });\n package$geom.VLineGeom = VLineGeom;\n var package$legend = package$geom.legend || (package$geom.legend = {});\n package$legend.CompositeLegendKeyElementFactory = CompositeLegendKeyElementFactory;\n package$legend.GenericLegendKeyElementFactory = GenericLegendKeyElementFactory;\n package$legend.HLineLegendKeyElementFactory = HLineLegendKeyElementFactory;\n package$legend.VLineLegendKeyElementFactory = VLineLegendKeyElementFactory;\n Object.defineProperty(ArrowSpec$End, 'LAST', {\n get: ArrowSpec$End$LAST_getInstance\n });\n Object.defineProperty(ArrowSpec$End, 'FIRST', {\n get: ArrowSpec$End$FIRST_getInstance\n });\n Object.defineProperty(ArrowSpec$End, 'BOTH', {\n get: ArrowSpec$End$BOTH_getInstance\n });\n ArrowSpec.End = ArrowSpec$End;\n Object.defineProperty(ArrowSpec$Type, 'OPEN', {\n get: ArrowSpec$Type$OPEN_getInstance\n });\n Object.defineProperty(ArrowSpec$Type, 'CLOSED', {\n get: ArrowSpec$Type$CLOSED_getInstance\n });\n ArrowSpec.Type = ArrowSpec$Type;\n var package$util = package$geom.util || (package$geom.util = {});\n package$util.ArrowSpec = ArrowSpec;\n Object.defineProperty(package$util, 'BarTooltipHelper', {\n get: BarTooltipHelper_getInstance\n });\n Object.defineProperty(package$util, 'CrossBarHelper', {\n get: CrossBarHelper_getInstance\n });\n package$util.DataPointAestheticsDelegate = DataPointAestheticsDelegate;\n package$util.GeomCoord = GeomCoord;\n GeomHelper.SvgElementHelper = GeomHelper$SvgElementHelper;\n Object.defineProperty(GeomHelper, 'Companion', {\n get: GeomHelper$Companion_getInstance\n });\n package$util.GeomHelper = GeomHelper;\n Object.defineProperty(package$util, 'GeomUtil', {\n get: GeomUtil_getInstance\n });\n Object.defineProperty(package$util, 'HintColorUtil', {\n get: HintColorUtil_getInstance\n });\n HintsCollection$HintConfigFactory.HintConfig = HintsCollection$HintConfigFactory$HintConfig;\n HintsCollection.HintConfigFactory = HintsCollection$HintConfigFactory;\n package$util.HintsCollection = HintsCollection;\n Object.defineProperty(LinePathConstructor, 'Companion', {\n get: LinePathConstructor$Companion_getInstance\n });\n package$util.LinePathConstructor = LinePathConstructor;\n LinesHelper.PathInfo = LinesHelper$PathInfo;\n package$util.LinesHelper = LinesHelper;\n package$util.MappedAesthetics = MappedAesthetics;\n package$util.MultiPointData = MultiPointData;\n MultiPointDataConstructor.prototype.PointCollector = MultiPointDataConstructor$PointCollector;\n Object.defineProperty(package$util, 'MultiPointDataConstructor', {\n get: MultiPointDataConstructor_getInstance\n });\n package$util.RectTargetCollectorHelper = RectTargetCollectorHelper;\n package$util.RectanglesHelper = RectanglesHelper;\n var package$interact = package$base.interact || (package$base.interact = {});\n package$interact.ContextualMapping = ContextualMapping;\n package$interact.DataContext = DataContext;\n package$interact.GeomTarget = GeomTarget;\n Object.defineProperty(GeomTargetCollector$TooltipParams, 'Companion', {\n get: GeomTargetCollector$TooltipParams$Companion_getInstance\n });\n GeomTargetCollector.TooltipParams = GeomTargetCollector$TooltipParams;\n package$interact.GeomTargetCollector = GeomTargetCollector;\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'X', {\n get: GeomTargetLocator$LookupSpace$X_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'XY', {\n get: GeomTargetLocator$LookupSpace$XY_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'NONE', {\n get: GeomTargetLocator$LookupSpace$NONE_getInstance\n });\n GeomTargetLocator.LookupSpace = GeomTargetLocator$LookupSpace;\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'HOVER', {\n get: GeomTargetLocator$LookupStrategy$HOVER_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'NEAREST', {\n get: GeomTargetLocator$LookupStrategy$NEAREST_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'NONE', {\n get: GeomTargetLocator$LookupStrategy$NONE_getInstance\n });\n GeomTargetLocator.LookupStrategy = GeomTargetLocator$LookupStrategy;\n Object.defineProperty(GeomTargetLocator$LookupSpec, 'Companion', {\n get: GeomTargetLocator$LookupSpec$Companion_getInstance\n });\n GeomTargetLocator.LookupSpec = GeomTargetLocator$LookupSpec;\n GeomTargetLocator.LookupResult = GeomTargetLocator$LookupResult;\n package$interact.GeomTargetLocator = GeomTargetLocator;\n Object.defineProperty(HitShape$Kind, 'POINT', {\n get: HitShape$Kind$POINT_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'RECT', {\n get: HitShape$Kind$RECT_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'POLYGON', {\n get: HitShape$Kind$POLYGON_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'PATH', {\n get: HitShape$Kind$PATH_getInstance\n });\n HitShape.Kind = HitShape$Kind;\n HitShape.DoubleCircle = HitShape$DoubleCircle;\n Object.defineProperty(HitShape, 'Companion', {\n get: HitShape$Companion_getInstance\n });\n package$interact.HitShape = HitShape;\n MappedDataAccess.MappedData = MappedDataAccess$MappedData;\n package$interact.MappedDataAccess = MappedDataAccess;\n package$interact.NullGeomTargetCollector = NullGeomTargetCollector;\n Object.defineProperty(TipLayoutHint$StemLength, 'NORMAL', {\n get: TipLayoutHint$StemLength$NORMAL_getInstance\n });\n Object.defineProperty(TipLayoutHint$StemLength, 'SHORT', {\n get: TipLayoutHint$StemLength$SHORT_getInstance\n });\n Object.defineProperty(TipLayoutHint$StemLength, 'NONE', {\n get: TipLayoutHint$StemLength$NONE_getInstance\n });\n TipLayoutHint.StemLength = TipLayoutHint$StemLength;\n Object.defineProperty(TipLayoutHint$Kind, 'VERTICAL_TOOLTIP', {\n get: TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'HORIZONTAL_TOOLTIP', {\n get: TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'CURSOR_TOOLTIP', {\n get: TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'X_AXIS_TOOLTIP', {\n get: TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'Y_AXIS_TOOLTIP', {\n get: TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance\n });\n TipLayoutHint.Kind = TipLayoutHint$Kind;\n Object.defineProperty(TipLayoutHint, 'Companion', {\n get: TipLayoutHint$Companion_getInstance\n });\n package$interact.TipLayoutHint = TipLayoutHint;\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'TOP', {\n get: TooltipAnchor$VerticalAnchor$TOP_getInstance\n });\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'BOTTOM', {\n get: TooltipAnchor$VerticalAnchor$BOTTOM_getInstance\n });\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'MIDDLE', {\n get: TooltipAnchor$VerticalAnchor$MIDDLE_getInstance\n });\n TooltipAnchor.VerticalAnchor = TooltipAnchor$VerticalAnchor;\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'LEFT', {\n get: TooltipAnchor$HorizontalAnchor$LEFT_getInstance\n });\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'RIGHT', {\n get: TooltipAnchor$HorizontalAnchor$RIGHT_getInstance\n });\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'CENTER', {\n get: TooltipAnchor$HorizontalAnchor$CENTER_getInstance\n });\n TooltipAnchor.HorizontalAnchor = TooltipAnchor$HorizontalAnchor;\n package$interact.TooltipAnchor = TooltipAnchor;\n TooltipLineSpec.DataPoint = TooltipLineSpec$DataPoint;\n package$interact.TooltipLineSpec = TooltipLineSpec;\n Object.defineProperty(LivemapConstants$DisplayMode, 'POINT', {\n get: LivemapConstants$DisplayMode$POINT_getInstance\n });\n Object.defineProperty(LivemapConstants$DisplayMode, 'PIE', {\n get: LivemapConstants$DisplayMode$PIE_getInstance\n });\n Object.defineProperty(LivemapConstants$DisplayMode, 'BAR', {\n get: LivemapConstants$DisplayMode$BAR_getInstance\n });\n LivemapConstants.DisplayMode = LivemapConstants$DisplayMode;\n Object.defineProperty(LivemapConstants$Theme, 'COLOR', {\n get: LivemapConstants$Theme$COLOR_getInstance\n });\n Object.defineProperty(LivemapConstants$Theme, 'LIGHT', {\n get: LivemapConstants$Theme$LIGHT_getInstance\n });\n Object.defineProperty(LivemapConstants$Theme, 'DARK', {\n get: LivemapConstants$Theme$DARK_getInstance\n });\n LivemapConstants.Theme = LivemapConstants$Theme;\n Object.defineProperty(LivemapConstants$Projection, 'EPSG3857', {\n get: LivemapConstants$Projection$EPSG3857_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'EPSG4326', {\n get: LivemapConstants$Projection$EPSG4326_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'AZIMUTHAL', {\n get: LivemapConstants$Projection$AZIMUTHAL_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'CONIC', {\n get: LivemapConstants$Projection$CONIC_getInstance\n });\n LivemapConstants.Projection = LivemapConstants$Projection;\n var package$livemap = package$base.livemap || (package$base.livemap = {});\n package$livemap.LivemapConstants = LivemapConstants;\n package$livemap.LiveMapOptions = LiveMapOptions;\n var package$pos = package$base.pos || (package$base.pos = {});\n package$pos.DodgePos = DodgePos;\n package$pos.FillPos = FillPos;\n package$pos.JitterDodgePos = JitterDodgePos;\n Object.defineProperty(JitterPos, 'Companion', {\n get: JitterPos$Companion_getInstance\n });\n package$pos.JitterPos = JitterPos;\n Object.defineProperty(NudgePos, 'Companion', {\n get: NudgePos$Companion_getInstance\n });\n package$pos.NudgePos = NudgePos;\n Object.defineProperty(PositionAdjustments$Meta, 'IDENTITY', {\n get: PositionAdjustments$Meta$IDENTITY_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'DODGE', {\n get: PositionAdjustments$Meta$DODGE_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'STACK', {\n get: PositionAdjustments$Meta$STACK_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'FILL', {\n get: PositionAdjustments$Meta$FILL_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'JITTER', {\n get: PositionAdjustments$Meta$JITTER_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'NUDGE', {\n get: PositionAdjustments$Meta$NUDGE_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'JITTER_DODGE', {\n get: PositionAdjustments$Meta$JITTER_DODGE_getInstance\n });\n PositionAdjustments.prototype.Meta = PositionAdjustments$Meta;\n Object.defineProperty(PositionAdjustments$StackingStrategy, 'SUM_POSITIVE_NEGATIVE', {\n get: PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance\n });\n Object.defineProperty(PositionAdjustments$StackingStrategy, 'SPLIT_POSITIVE_NEGATIVE', {\n get: PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance\n });\n PositionAdjustments.prototype.StackingStrategy = PositionAdjustments$StackingStrategy;\n Object.defineProperty(package$pos, 'PositionAdjustments', {\n get: PositionAdjustments_getInstance\n });\n Object.defineProperty(StackPos, 'Companion', {\n get: StackPos$Companion_getInstance\n });\n package$pos.StackPos = StackPos;\n var package$render = package$base.render || (package$base.render = {});\n package$render.LegendKeyElementFactory = LegendKeyElementFactory;\n package$render.SvgRoot = SvgRoot;\n var package$linetype = package$render.linetype || (package$render.linetype = {});\n package$linetype.LineType = LineType;\n Object.defineProperty(NamedLineType, 'BLANK', {\n get: NamedLineType$BLANK_getInstance\n });\n Object.defineProperty(NamedLineType, 'SOLID', {\n get: NamedLineType$SOLID_getInstance\n });\n Object.defineProperty(NamedLineType, 'DASHED', {\n get: NamedLineType$DASHED_getInstance\n });\n Object.defineProperty(NamedLineType, 'DOTTED', {\n get: NamedLineType$DOTTED_getInstance\n });\n Object.defineProperty(NamedLineType, 'DOTDASH', {\n get: NamedLineType$DOTDASH_getInstance\n });\n Object.defineProperty(NamedLineType, 'LONGDASH', {\n get: NamedLineType$LONGDASH_getInstance\n });\n Object.defineProperty(NamedLineType, 'TWODASH', {\n get: NamedLineType$TWODASH_getInstance\n });\n package$linetype.NamedLineType = NamedLineType;\n Object.defineProperty(NamedShape, 'STICK_SQUARE', {\n get: NamedShape$STICK_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE', {\n get: NamedShape$STICK_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_UP', {\n get: NamedShape$STICK_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_PLUS', {\n get: NamedShape$STICK_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CROSS', {\n get: NamedShape$STICK_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_DIAMOND', {\n get: NamedShape$STICK_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_DOWN', {\n get: NamedShape$STICK_TRIANGLE_DOWN_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_CROSS', {\n get: NamedShape$STICK_SQUARE_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_STAR', {\n get: NamedShape$STICK_STAR_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_DIAMOND_PLUS', {\n get: NamedShape$STICK_DIAMOND_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE_PLUS', {\n get: NamedShape$STICK_CIRCLE_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_UP_DOWN', {\n get: NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_PLUS', {\n get: NamedShape$STICK_SQUARE_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE_CROSS', {\n get: NamedShape$STICK_CIRCLE_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_TRIANGLE_UP', {\n get: NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_SQUARE', {\n get: NamedShape$SOLID_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_CIRCLE', {\n get: NamedShape$SOLID_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_TRIANGLE_UP', {\n get: NamedShape$SOLID_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_DIAMOND', {\n get: NamedShape$SOLID_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_CIRCLE_2', {\n get: NamedShape$SOLID_CIRCLE_2_getInstance\n });\n Object.defineProperty(NamedShape, 'BULLET', {\n get: NamedShape$BULLET_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_CIRCLE', {\n get: NamedShape$FILLED_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_SQUARE', {\n get: NamedShape$FILLED_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_DIAMOND', {\n get: NamedShape$FILLED_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_TRIANGLE_UP', {\n get: NamedShape$FILLED_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_TRIANGLE_DOWN', {\n get: NamedShape$FILLED_TRIANGLE_DOWN_getInstance\n });\n var package$point = package$render.point || (package$render.point = {});\n package$point.NamedShape = NamedShape;\n package$point.PointShape = PointShape;\n Object.defineProperty(package$point, 'PointShapeSvg', {\n get: PointShapeSvg_getInstance\n });\n Object.defineProperty(package$point, 'TinyPointShape', {\n get: TinyPointShape_getInstance\n });\n package$point.UpdatableShape = UpdatableShape;\n var package$symbol = package$point.symbol || (package$point.symbol = {});\n package$symbol.CircleGlyph = CircleGlyph;\n Object.defineProperty(CrossGlyph, 'Companion', {\n get: CrossGlyph$Companion_getInstance\n });\n package$symbol.CrossGlyph = CrossGlyph;\n package$symbol.DiamondGlyph = DiamondGlyph;\n package$symbol.Glyph = Glyph;\n package$symbol.GlyphPair = GlyphPair;\n Object.defineProperty(package$symbol, 'GlyphUtil', {\n get: GlyphUtil_getInstance\n });\n Object.defineProperty(package$symbol, 'Glyphs', {\n get: Glyphs_getInstance\n });\n package$symbol.MultiShapeGlyph = MultiShapeGlyph;\n package$symbol.PlusGlyph = PlusGlyph;\n package$symbol.SingletonGlyph_init_i91tmr$ = SingletonGlyph_init;\n package$symbol.SingletonGlyph_init_e1sv3v$ = SingletonGlyph_init_0;\n package$symbol.SingletonGlyph = SingletonGlyph;\n package$symbol.SquareGlyph = SquareGlyph;\n Object.defineProperty(TriangleGlyph, 'Companion', {\n get: TriangleGlyph$Companion_getInstance\n });\n package$symbol.TriangleGlyph = TriangleGlyph;\n package$symbol.TwoShapeGlyph = TwoShapeGlyph;\n var package$svg = package$render.svg || (package$render.svg = {});\n package$svg.GroupComponent = GroupComponent;\n Object.defineProperty(LinePath, 'Companion', {\n get: LinePath$Companion_getInstance\n });\n package$svg.LinePath = LinePath;\n Object.defineProperty(package$svg, 'StrokeDashArraySupport', {\n get: StrokeDashArraySupport_getInstance\n });\n Object.defineProperty(SvgComponent, 'Companion', {\n get: SvgComponent$Companion_getInstance\n });\n package$svg.SvgComponent = SvgComponent;\n Object.defineProperty(package$svg, 'SvgUID', {\n get: SvgUID_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'LEFT', {\n get: TextLabel$HorizontalAnchor$LEFT_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'RIGHT', {\n get: TextLabel$HorizontalAnchor$RIGHT_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'MIDDLE', {\n get: TextLabel$HorizontalAnchor$MIDDLE_getInstance\n });\n TextLabel.HorizontalAnchor = TextLabel$HorizontalAnchor;\n Object.defineProperty(TextLabel$VerticalAnchor, 'TOP', {\n get: TextLabel$VerticalAnchor$TOP_getInstance\n });\n Object.defineProperty(TextLabel$VerticalAnchor, 'BOTTOM', {\n get: TextLabel$VerticalAnchor$BOTTOM_getInstance\n });\n Object.defineProperty(TextLabel$VerticalAnchor, 'CENTER', {\n get: TextLabel$VerticalAnchor$CENTER_getInstance\n });\n TextLabel.VerticalAnchor = TextLabel$VerticalAnchor;\n package$svg.TextLabel = TextLabel;\n var package$scale = package$base.scale || (package$base.scale = {});\n package$scale.AbstractScale = AbstractScale;\n package$scale.BreaksGenerator = BreaksGenerator;\n package$scale.ContinuousScale_init_lo18em$ = ContinuousScale_init;\n package$scale.ContinuousScale = ContinuousScale;\n package$scale.DiscreteScale_init_l9mre7$ = DiscreteScale_init;\n package$scale.DiscreteScale = DiscreteScale;\n Object.defineProperty(package$scale, 'MapperUtil', {\n get: MapperUtil_getInstance\n });\n Object.defineProperty(package$scale, 'Mappers', {\n get: Mappers_getInstance\n });\n package$scale.ScaleBreaks = ScaleBreaks;\n Object.defineProperty(package$scale, 'ScaleUtil', {\n get: ScaleUtil_getInstance\n });\n Object.defineProperty(package$scale, 'Scales', {\n get: Scales_getInstance\n });\n var package$breaks = package$scale.breaks || (package$scale.breaks = {});\n package$breaks.BreaksHelperBase = BreaksHelperBase;\n package$breaks.DateTimeBreaksHelper = DateTimeBreaksHelper;\n Object.defineProperty(LinearBreaksHelper, 'Companion', {\n get: LinearBreaksHelper$Companion_getInstance\n });\n package$breaks.LinearBreaksHelper = LinearBreaksHelper;\n package$breaks.NumericBreakFormatter = NumericBreakFormatter;\n package$breaks.QuantizeScale = QuantizeScale;\n Object.defineProperty(package$breaks, 'ScaleBreaksUtil', {\n get: ScaleBreaksUtil_getInstance\n });\n package$breaks.TimeScaleTickFormatterFactory = TimeScaleTickFormatterFactory;\n package$breaks.WithFiniteOrderedOutput = WithFiniteOrderedOutput;\n var package$transform = package$scale.transform || (package$scale.transform = {});\n package$transform.DateTimeBreaksGen = DateTimeBreaksGen;\n package$transform.FunTransform = FunTransform;\n package$transform.IdentityTransform = IdentityTransform;\n Object.defineProperty(LinearBreaksGen, 'Companion', {\n get: LinearBreaksGen$Companion_getInstance\n });\n package$transform.LinearBreaksGen = LinearBreaksGen;\n Object.defineProperty(Log10Transform, 'Companion', {\n get: Log10Transform$Companion_getInstance\n });\n package$transform.Log10Transform = Log10Transform;\n Object.defineProperty(NonlinearBreaksGen, 'Companion', {\n get: NonlinearBreaksGen$Companion_getInstance\n });\n package$transform.NonlinearBreaksGen = NonlinearBreaksGen;\n package$transform.ReverseTransform = ReverseTransform;\n package$transform.SqrtTransform = SqrtTransform;\n Transforms.prototype.BreaksGeneratorForTransformedDomain = Transforms$BreaksGeneratorForTransformedDomain;\n Object.defineProperty(package$transform, 'Transforms', {\n get: Transforms_getInstance\n });\n Object.defineProperty(AbstractDensity2dStat, 'Companion', {\n get: AbstractDensity2dStat$Companion_getInstance\n });\n var package$stat = package$base.stat || (package$base.stat = {});\n package$stat.AbstractDensity2dStat = AbstractDensity2dStat;\n package$stat.BaseStat = BaseStat;\n Object.defineProperty(Bin2dStat, 'Companion', {\n get: Bin2dStat$Companion_getInstance\n });\n Bin2dStat.Bins2dData = Bin2dStat$Bins2dData;\n Bin2dStat.Bins2dWeightedCounts = Bin2dStat$Bins2dWeightedCounts;\n package$stat.Bin2dStat = Bin2dStat;\n Object.defineProperty(BinStat$XPosKind, 'NONE', {\n get: BinStat$XPosKind$NONE_getInstance\n });\n Object.defineProperty(BinStat$XPosKind, 'CENTER', {\n get: BinStat$XPosKind$CENTER_getInstance\n });\n Object.defineProperty(BinStat$XPosKind, 'BOUNDARY', {\n get: BinStat$XPosKind$BOUNDARY_getInstance\n });\n BinStat.XPosKind = BinStat$XPosKind;\n Object.defineProperty(BinStat, 'Companion', {\n get: BinStat$Companion_getInstance\n });\n package$stat.BinStat = BinStat;\n BinStatUtil.prototype.BinOptions = BinStatUtil$BinOptions;\n BinStatUtil.prototype.CountAndWidth = BinStatUtil$CountAndWidth;\n BinStatUtil.prototype.BinsData = BinStatUtil$BinsData;\n Object.defineProperty(package$stat, 'BinStatUtil', {\n get: BinStatUtil_getInstance\n });\n Object.defineProperty(BoxplotStat, 'Companion', {\n get: BoxplotStat$Companion_getInstance\n });\n package$stat.BoxplotStat = BoxplotStat;\n Object.defineProperty(Contour, 'Companion', {\n get: Contour$Companion_getInstance\n });\n package$stat.Contour = Contour;\n Object.defineProperty(ContourFillHelper, 'Companion', {\n get: ContourFillHelper$Companion_getInstance\n });\n package$stat.ContourFillHelper = ContourFillHelper;\n Object.defineProperty(ContourStat, 'Companion', {\n get: ContourStat$Companion_getInstance\n });\n package$stat.ContourStat = ContourStat;\n Object.defineProperty(package$stat, 'ContourStatUtil', {\n get: ContourStatUtil_getInstance\n });\n Object.defineProperty(ContourfStat, 'Companion', {\n get: ContourfStat$Companion_getInstance\n });\n package$stat.ContourfStat = ContourfStat;\n Object.defineProperty(CorrelationStat$Method, 'PEARSON', {\n get: CorrelationStat$Method$PEARSON_getInstance\n });\n Object.defineProperty(CorrelationStat$Method, 'SPEARMAN', {\n get: CorrelationStat$Method$SPEARMAN_getInstance\n });\n Object.defineProperty(CorrelationStat$Method, 'KENDALL', {\n get: CorrelationStat$Method$KENDALL_getInstance\n });\n CorrelationStat.Method = CorrelationStat$Method;\n Object.defineProperty(CorrelationStat$Type, 'FULL', {\n get: CorrelationStat$Type$FULL_getInstance\n });\n Object.defineProperty(CorrelationStat$Type, 'UPPER', {\n get: CorrelationStat$Type$UPPER_getInstance\n });\n Object.defineProperty(CorrelationStat$Type, 'LOWER', {\n get: CorrelationStat$Type$LOWER_getInstance\n });\n CorrelationStat.Type = CorrelationStat$Type;\n Object.defineProperty(CorrelationStat, 'Companion', {\n get: CorrelationStat$Companion_getInstance\n });\n package$stat.CorrelationStat = CorrelationStat;\n Object.defineProperty(package$stat, 'CorrelationUtil', {\n get: CorrelationUtil_getInstance\n });\n Object.defineProperty(CountStat, 'Companion', {\n get: CountStat$Companion_getInstance\n });\n package$stat.CountStat = CountStat;\n package$stat.Density2dStat = Density2dStat;\n package$stat.Density2dfStat = Density2dfStat;\n Object.defineProperty(DensityStat$Kernel, 'GAUSSIAN', {\n get: DensityStat$Kernel$GAUSSIAN_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'RECTANGULAR', {\n get: DensityStat$Kernel$RECTANGULAR_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'TRIANGULAR', {\n get: DensityStat$Kernel$TRIANGULAR_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'BIWEIGHT', {\n get: DensityStat$Kernel$BIWEIGHT_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'EPANECHNIKOV', {\n get: DensityStat$Kernel$EPANECHNIKOV_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'OPTCOSINE', {\n get: DensityStat$Kernel$OPTCOSINE_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'COSINE', {\n get: DensityStat$Kernel$COSINE_getInstance\n });\n DensityStat.Kernel = DensityStat$Kernel;\n Object.defineProperty(DensityStat$BandWidthMethod, 'NRD0', {\n get: DensityStat$BandWidthMethod$NRD0_getInstance\n });\n Object.defineProperty(DensityStat$BandWidthMethod, 'NRD', {\n get: DensityStat$BandWidthMethod$NRD_getInstance\n });\n DensityStat.BandWidthMethod = DensityStat$BandWidthMethod;\n Object.defineProperty(DensityStat, 'Companion', {\n get: DensityStat$Companion_getInstance\n });\n package$stat.DensityStat = DensityStat;\n Object.defineProperty(package$stat, 'DensityStatUtil', {\n get: DensityStatUtil_getInstance\n });\n package$stat.FiveNumberSummary_init_d3e2cz$ = FiveNumberSummary_init;\n package$stat.FiveNumberSummary_init_1lq62i$ = FiveNumberSummary_init_0;\n package$stat.FiveNumberSummary = FiveNumberSummary;\n package$stat.MultiOrdering = MultiOrdering;\n package$stat.SimpleStatContext = SimpleStatContext;\n Object.defineProperty(SmoothStat$Method, 'LM', {\n get: SmoothStat$Method$LM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'GLM', {\n get: SmoothStat$Method$GLM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'GAM', {\n get: SmoothStat$Method$GAM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'LOESS', {\n get: SmoothStat$Method$LOESS_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'RLM', {\n get: SmoothStat$Method$RLM_getInstance\n });\n SmoothStat.Method = SmoothStat$Method;\n Object.defineProperty(SmoothStat, 'Companion', {\n get: SmoothStat$Companion_getInstance\n });\n package$stat.SmoothStat = SmoothStat;\n Object.defineProperty(package$stat, 'Stats', {\n get: Stats_getInstance\n });\n Object.defineProperty(AbstractRealDistribution, 'Companion', {\n get: AbstractRealDistribution$Companion_getInstance\n });\n var package$math3 = package$stat.math3 || (package$stat.math3 = {});\n package$math3.AbstractRealDistribution = AbstractRealDistribution;\n package$math3.AbstractUnivariateSolver_init_14dthe$ = AbstractUnivariateSolver_init;\n package$math3.AbstractUnivariateSolver_init_lu1900$ = AbstractUnivariateSolver_init_0;\n package$math3.AbstractUnivariateSolver_init_yvo9jy$ = AbstractUnivariateSolver_init_1;\n package$math3.AbstractUnivariateSolver = AbstractUnivariateSolver;\n Object.defineProperty(AllowedSolution, 'ANY_SIDE', {\n get: AllowedSolution$ANY_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'LEFT_SIDE', {\n get: AllowedSolution$LEFT_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'RIGHT_SIDE', {\n get: AllowedSolution$RIGHT_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'BELOW_SIDE', {\n get: AllowedSolution$BELOW_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'ABOVE_SIDE', {\n get: AllowedSolution$ABOVE_SIDE_getInstance\n });\n package$math3.AllowedSolution = AllowedSolution;\n Object.defineProperty(BaseAbstractUnivariateSolver, 'Companion', {\n get: BaseAbstractUnivariateSolver$Companion_getInstance\n });\n package$math3.BaseAbstractUnivariateSolver_init_8vzwiz$ = BaseAbstractUnivariateSolver_init;\n package$math3.BaseAbstractUnivariateSolver = BaseAbstractUnivariateSolver;\n package$math3.BaseUnivariateSolver = BaseUnivariateSolver;\n Object.defineProperty(package$math3, 'Beta', {\n get: Beta_getInstance\n });\n package$math3.BlockRealMatrix_init_vux9f0$ = BlockRealMatrix_init;\n package$math3.BlockRealMatrix_init_n8oub7$ = BlockRealMatrix_init_0;\n package$math3.BlockRealMatrix = BlockRealMatrix;\n package$math3.BracketedUnivariateSolver = BracketedUnivariateSolver;\n Object.defineProperty(BrentSolver, 'Companion', {\n get: BrentSolver$Companion_getInstance\n });\n package$math3.BrentSolver_init_14dthe$ = BrentSolver_init;\n package$math3.BrentSolver_init_lu1900$ = BrentSolver_init_0;\n package$math3.BrentSolver_init_yvo9jy$ = BrentSolver_init_1;\n package$math3.BrentSolver = BrentSolver;\n Object.defineProperty(ContinuedFraction, 'Companion', {\n get: ContinuedFraction$Companion_getInstance\n });\n package$math3.ContinuedFraction = ContinuedFraction;\n package$math3.mean_gf7tl1$ = mean;\n package$math3.correlationPearson_g9g6do$ = correlationPearson;\n Object.defineProperty(ForsythePolynomialGenerator, 'Companion', {\n get: ForsythePolynomialGenerator$Companion_getInstance\n });\n package$math3.ForsythePolynomialGenerator = ForsythePolynomialGenerator;\n Object.defineProperty(package$math3, 'Gamma', {\n get: Gamma_getInstance\n });\n Incrementor.MaxCountExceededCallback = Incrementor$MaxCountExceededCallback;\n package$math3.Incrementor = Incrementor;\n Object.defineProperty(LoessInterpolator, 'Companion', {\n get: LoessInterpolator$Companion_getInstance\n });\n package$math3.LoessInterpolator = LoessInterpolator;\n Object.defineProperty(MathArrays$OrderDirection, 'INCREASING', {\n get: MathArrays$OrderDirection$INCREASING_getInstance\n });\n Object.defineProperty(MathArrays$OrderDirection, 'DECREASING', {\n get: MathArrays$OrderDirection$DECREASING_getInstance\n });\n MathArrays.prototype.OrderDirection = MathArrays$OrderDirection;\n Object.defineProperty(package$math3, 'MathArrays', {\n get: MathArrays_getInstance\n });\n Object.defineProperty(package$math3, 'Percentile', {\n get: Percentile_getInstance\n });\n package$math3.PolynomialFunction = PolynomialFunction;\n package$math3.times_gax024$ = times;\n package$math3.PolynomialSplineFunction = PolynomialSplineFunction;\n Object.defineProperty(package$math3, 'Precision', {\n get: Precision_getInstance\n });\n package$math3.RealDistribution = RealDistribution;\n package$math3.SplineInterpolator = SplineInterpolator;\n Object.defineProperty(TDistribution, 'Companion', {\n get: TDistribution$Companion_getInstance\n });\n package$math3.TDistribution = TDistribution;\n package$math3.UnivariateFunction = UnivariateFunction;\n package$math3.UnivariateSolver = UnivariateSolver;\n Object.defineProperty(package$math3, 'UnivariateSolverUtils', {\n get: UnivariateSolverUtils_getInstance\n });\n var package$regression = package$stat.regression || (package$stat.regression = {});\n package$regression.EvalResult = EvalResult;\n package$regression.LinearRegression = LinearRegression;\n package$regression.LocalPolynomialRegression = LocalPolynomialRegression;\n Object.defineProperty(PolynomialRegression, 'Companion', {\n get: PolynomialRegression$Companion_getInstance\n });\n package$regression.PolynomialRegression = PolynomialRegression;\n package$regression.RegressionEvaluator = RegressionEvaluator;\n Object.defineProperty(package$regression, 'RegressionUtil', {\n get: RegressionUtil_getInstance\n });\n package$regression.allFinite_10sy24$ = allFinite;\n package$regression.averageByX_10sy24$ = averageByX_0;\n var package$util_0 = package$base.util || (package$base.util = {});\n package$util_0.MutableDouble = MutableDouble;\n package$util_0.MutableInteger = MutableInteger;\n Object.defineProperty(package$util_0, 'SamplingUtil', {\n get: SamplingUtil_getInstance\n });\n AestheticsBuilder$MyDataPointAesthetics.prototype.defined_896ixz$ = DataPointAesthetics.prototype.defined_896ixz$;\n DefaultCoordinateSystem.prototype.isPointInLimits_k2qmv6$ = CoordinateSystem.prototype.isPointInLimits_k2qmv6$;\n DefaultCoordinateSystem.prototype.isRectInLimits_fd842m$ = CoordinateSystem.prototype.isRectInLimits_fd842m$;\n DefaultCoordinateSystem.prototype.isPathInLimits_f6t8kh$ = CoordinateSystem.prototype.isPathInLimits_f6t8kh$;\n DefaultCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$;\n DataPointAestheticsDelegate.prototype.defined_896ixz$ = DataPointAesthetics.prototype.defined_896ixz$;\n ErrorBarGeom$MyLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n FilledSquareLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n GenericLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n CrossBarLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n NullGeomTargetCollector.prototype.addPoint_cnsimy$ = GeomTargetCollector.prototype.addPoint_cnsimy$;\n NullGeomTargetCollector.prototype.addRectangle_bxzvr8$ = GeomTargetCollector.prototype.addRectangle_bxzvr8$;\n NullGeomTargetCollector.prototype.addPath_sa5m83$ = GeomTargetCollector.prototype.addPath_sa5m83$;\n NullGeomTargetCollector.prototype.addPolygon_sa5m83$ = GeomTargetCollector.prototype.addPolygon_sa5m83$;\n Object.defineProperty(DodgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(FillPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(JitterDodgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(JitterPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(NudgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(StackPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n BaseStat.prototype.apply_kdy6bf$ = Stat.prototype.apply_kdy6bf$;\n Kotlin.defineModule('lets-plot-plot-base-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/RegexExtensions.kt?c518","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/collections.kt?4ea3","webpack://LetsPlot/./kotlin-dce-dev/js/src/generated/_ArraysJs.kt?eaa5","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Sets.kt?72fd","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/./kotlin-dce-dev/runtime/arrayUtils.kt?7b24","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/SmoothStat.kt?7c46","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AbstractRealDistribution.kt?ba90","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Precision.kt?5144","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/TDistribution.kt?c7fe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/Aes.kt?8728","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/CoordinateSystem.kt?8d7b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DataFrame.kt?df88","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DataPointAesthetics.kt?c580","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DiscreteTransform.kt?6dca","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/GeomKind.kt?293a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/GeomMeta.kt?067c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/PositionAdjustment.kt?e192","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/Stat.kt?4a27","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesInitValue.kt?c3bd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesScaling.kt?4c71","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesVisitor.kt?1c22","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsBuilder.kt?944d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsDefaults.kt?e3ac","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsUtil.kt?9b58","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/TypedIndexFunctionMap.kt?bf9b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/coord/Coords.kt?5830","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/coord/DefaultCoordinateSystem.kt?9625","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/DataFrameUtil.kt?9bbf","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/Dummies.kt?9be2","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/TransformVar.kt?edd7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ABLineGeom.kt?df41","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/AreaGeom.kt?8e6e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/BarGeom.kt?7377","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Bin2dGeom.kt?dfa2","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/BoxplotGeom.kt?dadc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ContourGeom.kt?036e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ContourfGeom.kt?34a7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/CrossBarGeom.kt?3778","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Density2dGeom.kt?9ae3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Density2dfGeom.kt?fcc8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/DensityGeom.kt?b1fe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ErrorBarGeom.kt?047a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FilledCircleLegendKeyElementFactory.kt?58d8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FilledSquareLegendKeyElementFactory.kt?0054","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FreqpolyGeom.kt?81ce","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/GeomBase.kt?5d97","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/HLineGeom.kt?1383","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/HistogramGeom.kt?8b2c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ImageGeom.kt?228f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/JitterGeom.kt?5b94","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LineGeom.kt?0b0a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LineRangeGeom.kt?e195","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LiveMapGeom.kt?ec04","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LiveMapProvider.kt?11d3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/MapGeom.kt?ddd6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PathGeom.kt?cff4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PieGeom.kt?2576","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointGeom.kt?b4c8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointLegendKeyElementFactory.kt?01ff","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointRangeGeom.kt?ab23","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PolygonGeom.kt?7098","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RasterGeom.kt?f1dd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RectGeom.kt?c31f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RibbonGeom.kt?cb22","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/SegmentGeom.kt?ec3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/SmoothGeom.kt?cfd6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/StepGeom.kt?fbc0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TextGeom.kt?0059","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TextLegendKeyElementFactory.kt?2f2b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TileGeom.kt?f47a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/VLineGeom.kt?200c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/CompositeLegendKeyElementFactory.kt?3ec9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/GenericLegendKeyElementFactory.kt?7ef1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/HLineLegendKeyElementFactory.kt?2d5a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/VLineLegendKeyElementFactory.kt?f68f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/ArrowSpec.kt?a3d4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/BarTooltipHelper.kt?a4cc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/CrossBarHelper.kt?beb4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/DataPointAestheticsDelegate.kt?c6e6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomCoord.kt?8d6b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomHelper.kt?6341","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomUtil.kt?9dfe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/HintColorUtil.kt?9cdc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/HintsCollection.kt?daea","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/LinePathConstructor.kt?72dd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/LinesHelper.kt?71fd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MappedAesthetics.kt?6d62","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MultiPointData.kt?95f3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MultiPointDataConstructor.kt?73cb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/RectTargetCollectorHelper.kt?cfb9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/RectanglesHelper.kt?8be6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/ContextualMapping.kt?02c0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/DataContext.kt?963c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTarget.kt?6e3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTargetCollector.kt?811e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTargetLocator.kt?d61c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/HitShape.kt?1ceb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/MappedDataAccess.kt?fc6b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/NullGeomTargetCollector.kt?840f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TipLayoutHint.kt?ccb3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TooltipAnchor.kt?41b4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TooltipLineSpec.kt?f604","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/livemap/LiveMapConstants.kt?175c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/livemap/LiveMapOptions.kt?931a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/DodgePos.kt?d8e1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/FillPos.kt?05e9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/JitterDodgePos.kt?ce83","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/JitterPos.kt?8738","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/NudgePos.kt?4007","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/PositionAdjustments.kt?c624","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/StackPos.kt?9b3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/LegendKeyElementFactory.kt?c96c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/linetype/NamedLineType.kt?b1ab","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/NamedShape.kt?0732","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/PointShapeSvg.kt?d2b2","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/TinyPointShape.kt?172f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/CircleGlyph.kt?fb44","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/CrossGlyph.kt?5e61","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/DiamondGlyph.kt?ecd9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/GlyphPair.kt?7db5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/GlyphUtil.kt?9fe5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/Glyphs.kt?a9c9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/MultiShapeGlyph.kt?0058","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/PlusGlyph.kt?b054","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/SingletonGlyph.kt?ebd3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/SquareGlyph.kt?444a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/TriangleGlyph.kt?03be","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/TwoShapeGlyph.kt?0f95","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/GroupComponent.kt?ff2b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/LinePath.kt?712e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/StrokeDashArraySupport.kt?ade8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/SvgComponent.kt?532b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/SvgUID.kt?db3c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/TextLabel.kt?dfd8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/AbstractScale.kt?f6da","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ContinuousScale.kt?5f80","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/DiscreteScale.kt?6278","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/MapperUtil.kt?3014","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/Mappers.kt?4d4f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ScaleBreaks.kt?f0e3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ScaleUtil.kt?92ef","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/Scales.kt?adfd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/BreaksHelperBase.kt?b5f0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/DateTimeBreaksHelper.kt?4f9d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/LinearBreaksHelper.kt?37ec","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/NumericBreakFormatter.kt?7aad","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/QuantizeScale.kt?b64c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/ScaleBreaksUtil.kt?6a0c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/TimeScaleTickFormatterFactory.kt?ca96","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/DateTimeBreaksGen.kt?d034","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/FunTransform.kt?2ab0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/IdentityTransform.kt?0db0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/LinearBreaksGen.kt?4776","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/Log10Transform.kt?c338","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/NonlinearBreaksGen.kt?849c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/ReverseTransform.kt?382d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/SqrtTransform.kt?8eca","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/Transforms.kt?b3c5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/AbstractDensity2dStat.kt?e0bc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BaseStat.kt?5213","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Bin2dStat.kt?6772","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BinStat.kt?b273","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BinStatUtil.kt?609d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BoxplotStat.kt?0218","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Contour.kt?f77d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourFillHelper.kt?a1e1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourStat.kt?c564","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourStatUtil.kt?f70a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourfStat.kt?82c7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CorrelationStat.kt?e116","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CorrelationUtil.kt?5453","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CountStat.kt?0579","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Density2dStat.kt?aeda","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Density2dfStat.kt?05a8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/DensityStat.kt?4c4e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/DensityStatUtil.kt?5534","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/FiveNumberSummary.kt?e434","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/MultiOrdering.kt?6800","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/SimpleStatContext.kt?f655","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Stats.kt?ad45","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AbstractUnivariateSolver.kt?d821","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AllowedSolution.kt?7261","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BaseAbstractUnivariateSolver.kt?c4e0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Beta.kt?6641","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BlockRealMatrix.kt?a1fb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BrentSolver.kt?cca1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/ContinuedFraction.kt?c04a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Correlation.kt?967c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/ForsythePolynomialGenerator.kt?0296","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Gamma.kt?03ee","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Incrementor.kt?d8b5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/LoessInterpolator.kt?bae1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/MathArrays.kt?4356","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Percentile.kt?4070","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/PolynomialFunction.kt?2951","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/PolynomialSplineFunction.kt?5c81","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/SplineInterpolator.kt?ecd8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/UnivariateSolverUtils.kt?ea94","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/EvalResult.kt?c1c8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/LinearRegression.kt?d1cd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/LocalPolynomialRegression.kt?825d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/PolynomialRegression.kt?5683","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/RegressionEvaluator.kt?0854","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/RegressionUtil.kt?55de","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/MutableDouble.kt?3647","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/MutableInteger.kt?6d36","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/SamplingUtil.kt?b752"],"names":[],"mappings":"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BAAU,SAAU,QAApB,CE7LhB,C;QACI,cF4L4C,uD;QE3L5C,MAAM,8BAAyB,OAAQ,WAAjC,C;OF8LG,gBADA,IADL,iBAAI,SAAU,SAAd,CACK,EAAI,wBAAW,SAAU,QAArB,CAAJ,C;MlB6uCN,kBAAU,oB;MA8BD,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QkB1wCO,IAAC,QlB2wCE,OkB3wCF,a;QlB2wCpB,UkB3wC8B,K;QjBgI3B,Y;QADP,cD6oCe,WC7oCH,WD6oCwB,GC7oCxB,C;QACL,IAAI,eAAJ,C;UACH,aD2oCuC,gB;UAA5B,WC1oCX,aD0oCgC,GC1oChC,EAAS,MAAT,C;UACA,iB;;UAEA,kB;;QDuoCA,mB;qBACA,I;QkB7wCyC,IAAI,UlB6wCrB,OkB7wCqB,a;QlB6wCxC,YAAL,IAAK,EkB7wCoD,OlB6wCpD,C;;MC7jCF,oBAAY,qBAAoB,YD+jChC,WC/jC4C,KAAZ,CAApB,C;MDgyBH,U;MAAA,SA+RT,WCjnCA,QDk1BS,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;qBCl1Ba,a;QAAkB,aDm1Bf,SCn1Be,I;QiB7JtB,IAAI,WlBg/B4B,SCl6BO,M;;QDyczD,oBAAS,gB;QA2FA,U;QAAA,SkBlnB8D,QlBknB9D,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UAAM,sBAAc,UAAd,C;YAAwB,aAAY,WAAI,SAAJ,C;;QA8X1C,YCn1Ba,aDm1Bb,UkBh/BuD,uBlBmnBhE,akBnnBgE,ClBg/BvD,C;;MkB/+BH,cjB4JgB,aiB5JhB,C;;MAEmB,WAAxB,iBAAI,SAAU,SAAd,CAAwB,EAAI,iBAAI,SAAU,QAAd,CAAJ,C;;IAEvB,sB;IlBkhBF,oBAAS,gB;IA2FA,U;IAAA,+B;IAAhB,OAAgB,gBAAhB,C;MAAgB,6B;MAAM,IkB7mBJ,kBlB6mBkB,SkB7mBG,OAArB,KAAgC,kBlB6mBd,SkB7mBmC,MAArB,ClB6mB5B,C;QAAwB,aAAY,WAAI,SAAJ,C;;IkB3mBjD,kBADA,WlB6mBF,akB7mBE,EAAW,WAAU,yCAAV,EAA0C,2CAA1C,EAAX,C;IlBs1CF,oBAAa,gB;IAwPJ,U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,6D;IACA,qD;IACA,yD;IACA,iD;IACA,iD;IACA,uD;IACA,iD;IACA,qD;IACA,mD;;;EAjCA,qC;IAAA,qB;IAAA,6B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,oC;IAAA,qB;IAAA,4B;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,oC;IAAA,qB;IAAA,4B;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,2C;IAAA,qB;IAAA,mC;;;EACA,4C;IAAA,qB;IAAA,oC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,sC;IAAA,qB;IAAA,8B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,2C;IAAA,qB;IAAA,mC;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,sC;IAAA,qB;IAAA,8B;;;;;;;EAlCJ,2B;IAAA,qjC;;;EAAA,gC;IAAA,a;MAAA,Y;QAAA,kC;MAAA,Y;QAAA,kC;MAAA,c;QAAA,oC;MAAA,W;QAAA,iC;MAAA,iB;QAAA,uC;MAAA,Y;QAAA,kC;MAAA,c;QAAA,oC;MAAA,W;QAAA,iC;MAAA,iB;QAAA,uC;MAAA,iB;QAAA,uC;MAAA,kB;QAAA,wC;MAAA,mB;QAAA,yC;MAAA,e;QAAA,qC;MAAA,e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","file":"./kotlin-dce-dev/lets-plot-plot-base-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n/**\n * Converts the string into a regular expression [Regex] with the default options.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(): Regex = Regex(this)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified single [option].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(option: RegexOption): Regex = Regex(this, option)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified set of [options].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(options: Set<RegexOption>): Regex = Regex(this, options)\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\nimport kotlin.comparisons.naturalOrder\nimport kotlin.random.Random\n\n/**\n * Returns the array if it's not `null`, or an empty array otherwise.\n * @sample samples.collections.Arrays.Usage.arrayOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Array<out T>?.orEmpty(): Array<out T> = this ?: emptyArray<T>()\n\n/**\n * Returns a *typed* array containing all of the elements of this collection.\n *\n * Allocates an array of runtime type `T` having its size equal to the size of this collection\n * and populates the array with the elements of this collection.\n * @sample samples.collections.Collections.Collections.collectionToTypedArray\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Collection<T>.toTypedArray(): Array<T> = copyToArray(this)\n\n@JsName(\"copyToArray\")\n@PublishedApi\ninternal fun <T> copyToArray(collection: Collection<T>): Array<T> {\n    return if (collection.asDynamic().toArray !== undefined)\n        collection.asDynamic().toArray().unsafeCast<Array<T>>()\n    else\n        copyToArrayImpl(collection).unsafeCast<Array<T>>()\n}\n\n@JsName(\"copyToArrayImpl\")\ninternal actual fun copyToArrayImpl(collection: Collection<*>): Array<Any?> {\n    val array = emptyArray<Any?>()\n    val iterator = collection.iterator()\n    while (iterator.hasNext())\n        array.asDynamic().push(iterator.next())\n    return array\n}\n\n@JsName(\"copyToExistingArrayImpl\")\ninternal actual fun <T> copyToArrayImpl(collection: Collection<*>, array: Array<T>): Array<T> {\n    if (array.size < collection.size)\n        return copyToArrayImpl(collection).unsafeCast<Array<T>>()\n\n    val iterator = collection.iterator()\n    var index = 0\n    while (iterator.hasNext()) {\n        array[index++] = iterator.next().unsafeCast<T>()\n    }\n    if (index < array.size) {\n        array[index] = null.unsafeCast<T>()\n    }\n    return array\n}\n\n\n/**\n * Returns an immutable list containing only the specified object [element].\n */\npublic fun <T> listOf(element: T): List<T> = arrayListOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E> {\n    return ArrayList<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E> {\n    checkBuilderCapacity(capacity)\n    return ArrayList<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable set containing only the specified object [element].\n */\npublic fun <T> setOf(element: T): Set<T> = hashSetOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable map, mapping only the specified key to the\n * specified value.\n */\npublic fun <K, V> mapOf(pair: Pair<K, V>): Map<K, V> = hashMapOf(pair)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Fills the list with the provided [value].\n *\n * Each element in the list gets replaced with the [value].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.fill(value: T): Unit {\n    for (index in 0..lastIndex) {\n        this[index] = value\n    }\n}\n\n/**\n * Randomly shuffles elements in this list.\n *\n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.shuffle(): Unit = shuffle(Random)\n\n/**\n * Returns a new list with the elements of this list randomly shuffled.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> Iterable<T>.shuffled(): List<T> = toMutableList().apply { shuffle() }\n\n/**\n * Sorts elements in the list in-place according to their natural sort order.\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableList\n */\npublic actual fun <T : Comparable<T>> MutableList<T>.sort(): Unit {\n    collectionsSort(this, naturalOrder())\n}\n\n/**\n * Sorts elements in the list in-place according to the order specified with [comparator].\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableListWith\n */\npublic actual fun <T> MutableList<T>.sortWith(comparator: Comparator<in T>): Unit {\n    collectionsSort(this, comparator)\n}\n\nprivate fun <T> collectionsSort(list: MutableList<T>, comparator: Comparator<in T>) {\n    if (list.size <= 1) return\n\n    val array = copyToArray(list)\n    sortArrayWith(array, comparator)\n\n    for (i in 0 until array.size) {\n        list[i] = array[i]\n    }\n}\n\ninternal actual fun <T> arrayOfNulls(reference: Array<T>, size: Int): Array<T> {\n    return arrayOfNulls<Any>(size).unsafeCast<Array<T>>()\n}\n\n@SinceKotlin(\"1.3\")\n@PublishedApi\n@JsName(\"arrayCopy\")\ninternal fun <T> arrayCopy(source: Array<out T>, destination: Array<in T>, destinationOffset: Int, startIndex: Int, endIndex: Int) {\n    AbstractList.checkRangeIndexes(startIndex, endIndex, source.size)\n    val rangeSize = endIndex - startIndex\n    AbstractList.checkRangeIndexes(destinationOffset, destinationOffset + rangeSize, destination.size)\n\n    if (js(\"ArrayBuffer\").isView(destination) && js(\"ArrayBuffer\").isView(source)) {\n        val subrange = source.asDynamic().subarray(startIndex, endIndex)\n        destination.asDynamic().set(subrange, destinationOffset)\n    } else {\n        if (source !== destination || destinationOffset <= startIndex) {\n            for (index in 0 until rangeSize) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        } else {\n            for (index in rangeSize - 1 downTo 0) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        }\n    }\n}\n\n// no singleton map implementation in js, return map as is\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<K, V>.toSingletonMapOrSelf(): Map<K, V> = this\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<out K, V>.toSingletonMap(): Map<K, V> = this.toMutableMap()\n\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <T> Array<out T>.copyToArrayOfAny(isVarargs: Boolean): Array<out Any?> =\n    if (isVarargs)\n    // no need to copy vararg array in JS\n        this\n    else\n        this.copyOf()\n\n\n\n@PublishedApi\ninternal actual fun checkIndexOverflow(index: Int): Int {\n    if (index < 0) {\n        throwIndexOverflow()\n    }\n    return index\n}\n\n@PublishedApi\ninternal actual fun checkCountOverflow(count: Int): Int {\n    if (count < 0) {\n        throwCountOverflow()\n    }\n    return count\n}\n\n\n/**\n * JS map and set implementations do not make use of capacities or load factors.\n */\n@PublishedApi\ninternal actual fun mapCapacity(expectedSize: Int) = expectedSize\n\n/**\n * Checks a collection builder function capacity argument.\n * In JS no validation is made in Map/Set constructor yet.\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@PublishedApi\ninternal fun checkBuilderCapacity(capacity: Int) {\n    require(capacity >= 0) { \"capacity must be non-negative.\" }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.js.*\nimport primitiveArrayConcat\nimport withType\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun <T> Array<out T>.elementAt(index: Int): T {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun ByteArray.elementAt(index: Int): Byte {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun ShortArray.elementAt(index: Int): Short {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun IntArray.elementAt(index: Int): Int {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun LongArray.elementAt(index: Int): Long {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun FloatArray.elementAt(index: Int): Float {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun DoubleArray.elementAt(index: Int): Double {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun BooleanArray.elementAt(index: Int): Boolean {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun CharArray.elementAt(index: Int): Char {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic actual fun <T> Array<out T>.asList(): List<T> {\n    return ArrayList<T>(this.unsafeCast<Array<Any?>>())\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun ByteArray.asList(): List<Byte> {\n    return this.unsafeCast<Array<Byte>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun ShortArray.asList(): List<Short> {\n    return this.unsafeCast<Array<Short>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun IntArray.asList(): List<Int> {\n    return this.unsafeCast<Array<Int>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun LongArray.asList(): List<Long> {\n    return this.unsafeCast<Array<Long>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun FloatArray.asList(): List<Float> {\n    return this.unsafeCast<Array<Float>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun DoubleArray.asList(): List<Double> {\n    return this.unsafeCast<Array<Double>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun BooleanArray.asList(): List<Boolean> {\n    return this.unsafeCast<Array<Boolean>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic actual fun CharArray.asList(): List<Char> {\n    return object : AbstractList<Char>(), RandomAccess {\n        override val size: Int get() = this@asList.size\n        override fun isEmpty(): Boolean = this@asList.isEmpty()\n        override fun contains(element: Char): Boolean = this@asList.contains(element)\n        override fun get(index: Int): Char {\n            AbstractList.checkElementIndex(index, size)\n            return this@asList[index]\n        }\n        override fun indexOf(element: Char): Int {\n            @Suppress(\"USELESS_CAST\")\n            if ((element as Any?) !is Char) return -1\n            return this@asList.indexOf(element)\n        }\n        override fun lastIndexOf(element: Char): Int {\n            @Suppress(\"USELESS_CAST\")\n            if ((element as Any?) !is Char) return -1\n            return this@asList.lastIndexOf(element)\n        }\n    }\n}\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean {\n    return this.contentDeepEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepEquals\")\npublic actual infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual fun <T> Array<out T>.contentDeepHashCode(): Int {\n    return this.contentDeepHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepHashCode\")\npublic actual fun <T> Array<out T>?.contentDeepHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual fun <T> Array<out T>.contentDeepToString(): String {\n    return this.contentDeepToString()\n}\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepToString\")\npublic actual fun <T> Array<out T>?.contentDeepToString(): String {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun ByteArray.contentEquals(other: ByteArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun ShortArray.contentEquals(other: ShortArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun IntArray.contentEquals(other: IntArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun LongArray.contentEquals(other: LongArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun FloatArray.contentEquals(other: FloatArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun CharArray.contentEquals(other: CharArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun IntArray?.contentEquals(other: IntArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun LongArray?.contentEquals(other: LongArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun CharArray?.contentEquals(other: CharArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun <T> Array<out T>.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ByteArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ShortArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun IntArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun LongArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun FloatArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun DoubleArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun BooleanArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun CharArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun <T> Array<out T>?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun ByteArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun ShortArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun IntArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun LongArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun FloatArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun DoubleArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun BooleanArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun CharArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun <T> Array<out T>.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ByteArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ShortArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun IntArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun LongArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun FloatArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun DoubleArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun BooleanArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun CharArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun <T> Array<out T>?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun ByteArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun ShortArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun IntArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun LongArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun FloatArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun DoubleArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun BooleanArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun CharArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T> {\n    arrayCopy(this, destination, destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray {\n    arrayCopy(this.unsafeCast<Array<Byte>>(), destination.unsafeCast<Array<Byte>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray {\n    arrayCopy(this.unsafeCast<Array<Short>>(), destination.unsafeCast<Array<Short>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray {\n    arrayCopy(this.unsafeCast<Array<Int>>(), destination.unsafeCast<Array<Int>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray {\n    arrayCopy(this.unsafeCast<Array<Long>>(), destination.unsafeCast<Array<Long>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray {\n    arrayCopy(this.unsafeCast<Array<Float>>(), destination.unsafeCast<Array<Float>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray {\n    arrayCopy(this.unsafeCast<Array<Double>>(), destination.unsafeCast<Array<Double>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray {\n    arrayCopy(this.unsafeCast<Array<Boolean>>(), destination.unsafeCast<Array<Boolean>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray {\n    arrayCopy(this.unsafeCast<Array<Char>>(), destination.unsafeCast<Array<Char>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline fun <T> Array<out T>.copyOf(): Array<T> {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun ByteArray.copyOf(): ByteArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun ShortArray.copyOf(): ShortArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun IntArray.copyOf(): IntArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun LongArray.copyOf(): LongArray {\n    return withType(\"LongArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun FloatArray.copyOf(): FloatArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun DoubleArray.copyOf(): DoubleArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun BooleanArray.copyOf(): BooleanArray {\n    return withType(\"BooleanArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun CharArray.copyOf(): CharArray {\n    return withType(\"CharArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun ByteArray.copyOf(newSize: Int): ByteArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, ByteArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun ShortArray.copyOf(newSize: Int): ShortArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, ShortArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun IntArray.copyOf(newSize: Int): IntArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, IntArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun LongArray.copyOf(newSize: Int): LongArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"LongArray\", arrayCopyResize(this, newSize, 0L))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun FloatArray.copyOf(newSize: Int): FloatArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, FloatArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun DoubleArray.copyOf(newSize: Int): DoubleArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, DoubleArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun BooleanArray.copyOf(newSize: Int): BooleanArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"BooleanArray\", arrayCopyResize(this, newSize, false))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun CharArray.copyOf(newSize: Int): CharArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"CharArray\", fillFrom(this, CharArray(newSize)))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual fun <T> Array<out T>.copyOf(newSize: Int): Array<T?> {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return arrayCopyResize(this, newSize, null)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual fun <T> Array<out T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T> {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"LongArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"BooleanArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"CharArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline operator fun <T> Array<out T>.plus(element: T): Array<T> {\n    return this.asDynamic().concat(arrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ByteArray.plus(element: Byte): ByteArray {\n    return plus(byteArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ShortArray.plus(element: Short): ShortArray {\n    return plus(shortArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun IntArray.plus(element: Int): IntArray {\n    return plus(intArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun LongArray.plus(element: Long): LongArray {\n    return plus(longArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun FloatArray.plus(element: Float): FloatArray {\n    return plus(floatArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun DoubleArray.plus(element: Double): DoubleArray {\n    return plus(doubleArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun BooleanArray.plus(element: Boolean): BooleanArray {\n    return plus(booleanArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun CharArray.plus(element: Char): CharArray {\n    return plus(charArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual operator fun <T> Array<out T>.plus(elements: Collection<T>): Array<T> {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun ShortArray.plus(elements: Collection<Short>): ShortArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun IntArray.plus(elements: Collection<Int>): IntArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun LongArray.plus(elements: Collection<Long>): LongArray {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun FloatArray.plus(elements: Collection<Float>): FloatArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun CharArray.plus(elements: Collection<Char>): CharArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline operator fun <T> Array<out T>.plus(elements: Array<out T>): Array<T> {\n    return this.asDynamic().concat(elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ByteArray.plus(elements: ByteArray): ByteArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ShortArray.plus(elements: ShortArray): ShortArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun IntArray.plus(elements: IntArray): IntArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun LongArray.plus(elements: LongArray): LongArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun FloatArray.plus(elements: FloatArray): FloatArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun CharArray.plus(elements: CharArray): CharArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline fun <T> Array<out T>.plusElement(element: T): Array<T> {\n    return this.asDynamic().concat(arrayOf(element))\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun IntArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic actual fun LongArray.sort(): Unit {\n    if (size > 1) sort { a: Long, b: Long -> a.compareTo(b) }\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun ByteArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun ShortArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun DoubleArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun FloatArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun CharArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic actual fun <T : Comparable<T>> Array<out T>.sort(): Unit {\n    if (size > 1) sortArray(this)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sort(comparison: (a: T, b: T) -> Int): Unit {\n    if (size > 1) sortArrayWith(this, comparison)\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this, fromIndex, toIndex, naturalOrder())\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<ByteArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<ShortArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<IntArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this.unsafeCast<Array<Long>>(), fromIndex, toIndex, naturalOrder())\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<FloatArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<DoubleArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<CharArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sort(noinline comparison: (a: Byte, b: Byte) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sort(noinline comparison: (a: Short, b: Short) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sort(noinline comparison: (a: Int, b: Int) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sort(noinline comparison: (a: Long, b: Long) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sort(noinline comparison: (a: Float, b: Float) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sort(noinline comparison: (a: Double, b: Double) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sort(noinline comparison: (a: Char, b: Char) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic actual fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit {\n    if (size > 1) sortArrayWith(this, comparator)\n}\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this, fromIndex, toIndex, comparator)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun ByteArray.toTypedArray(): Array<Byte> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun ShortArray.toTypedArray(): Array<Short> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun IntArray.toTypedArray(): Array<Int> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun LongArray.toTypedArray(): Array<Long> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun FloatArray.toTypedArray(): Array<Float> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun DoubleArray.toTypedArray(): Array<Double> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun BooleanArray.toTypedArray(): Array<Boolean> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun CharArray.toTypedArray(): Array<Char> {\n    return Array(size) { index -> this[index] }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"SetsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\ninternal object EmptySet : Set<Nothing>, Serializable {\n    private const val serialVersionUID: Long = 3406603774387020532\n\n    override fun equals(other: Any?): Boolean = other is Set<*> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n\n    private fun readResolve(): Any = EmptySet\n}\n\n\n/**\n * Returns an empty read-only set.  The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.emptyReadOnlySet\n */\npublic fun <T> emptySet(): Set<T> = EmptySet\n\n/**\n * Returns a new read-only set with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.readOnlySet\n */\npublic fun <T> setOf(vararg elements: T): Set<T> = if (elements.size > 0) elements.toSet() else emptySet()\n\n/**\n * Returns an empty read-only set.  The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.emptyReadOnlySet\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> setOf(): Set<T> = emptySet()\n\n/**\n * Returns an empty new [MutableSet].\n *\n * The returned set preserves the element iteration order.\n * @sample samples.collections.Collections.Sets.emptyMutableSet\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableSetOf(): MutableSet<T> = LinkedHashSet()\n\n/**\n * Returns a new [MutableSet] with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * @sample samples.collections.Collections.Sets.mutableSet\n */\npublic fun <T> mutableSetOf(vararg elements: T): MutableSet<T> = elements.toCollection(LinkedHashSet(mapCapacity(elements.size)))\n\n/** Returns an empty new [HashSet]. */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> hashSetOf(): HashSet<T> = HashSet()\n\n/** Returns a new [HashSet] with the given elements. */\npublic fun <T> hashSetOf(vararg elements: T): HashSet<T> = elements.toCollection(HashSet(mapCapacity(elements.size)))\n\n/**\n * Returns an empty new [LinkedHashSet].\n * @sample samples.collections.Collections.Sets.emptyLinkedHashSet\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> linkedSetOf(): LinkedHashSet<T> = LinkedHashSet()\n\n/**\n * Returns a new [LinkedHashSet] with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * @sample samples.collections.Collections.Sets.linkedHashSet\n */\npublic fun <T> linkedSetOf(vararg elements: T): LinkedHashSet<T> = elements.toCollection(LinkedHashSet(mapCapacity(elements.size)))\n\n/**\n * Returns a new read-only set either with single given element, if it is not null, or empty set if the element is null.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.setOfNotNull\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Any> setOfNotNull(element: T?): Set<T> = if (element != null) setOf(element) else emptySet()\n\n/**\n * Returns a new read-only set only with those given elements, that are not null.\n * Elements of the set are iterated in the order they were specified.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.setOfNotNull\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Any> setOfNotNull(vararg elements: T?): Set<T> {\n    return elements.filterNotNullTo(LinkedHashSet())\n}\n\n/**\n * Builds a new read-only [Set] by populating a [MutableSet] using the given [builderAction]\n * and returning a read-only set with the same elements.\n *\n * The set passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Elements of the set are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Sets.buildSetSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildSet(@BuilderInference builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildSetInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E>\n\n/**\n * Builds a new read-only [Set] by populating a [MutableSet] using the given [builderAction]\n * and returning a read-only set with the same elements.\n *\n * The set passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * Elements of the set are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Sets.buildSetSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildSet(capacity: Int, @BuilderInference builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildSetInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E>\n\n\n/** Returns this Set if it's not `null` and the empty set otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Set<T>?.orEmpty(): Set<T> = this ?: emptySet()\n\ninternal fun <T> Set<T>.optimizeReadOnlySet() = when (size) {\n    0 -> emptySet()\n    1 -> setOf(iterator().next())\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n// a package is omitted to get declarations directly under the module\n\n@PublishedApi\nexternal internal fun <T> Array(size: Int): Array<T>\n\n@JsName(\"newArray\")\nfun <T> newArray(size: Int, initValue: T) = fillArrayVal(Array<T>(size), initValue)\n\n@JsName(\"newArrayF\")\ninline fun <T> arrayWithFun(size: Int, init: (Int) -> T) = fillArrayFun(Array<T>(size), init)\n\n@JsName(\"fillArray\")\ninline fun <T> fillArrayFun(array: Array<T>, init: (Int) -> T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = init(i)\n    }\n    return array\n}\n\n@JsName(\"booleanArray\")\nfun booleanArray(size: Int, init: dynamic): Array<Boolean> {\n    val result: dynamic = Array<Boolean>(size)\n    result.`$type$` = \"BooleanArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, false)\n        false -> result\n        else -> fillArrayFun<Boolean>(result, init)\n    }\n}\n\n@JsName(\"booleanArrayF\")\ninline fun booleanArrayWithFun(size: Int, init: (Int) -> Boolean): Array<Boolean> = fillArrayFun(booleanArray(size, false), init)\n\n@JsName(\"charArray\")\n@Suppress(\"UNUSED_PARAMETER\")\nfun charArray(size: Int, init: dynamic): Array<Char> {\n    val result = js(\"new Uint16Array(size)\")\n    result.`$type$` = \"CharArray\"\n    return when (init) {\n        null, true, false -> result // For consistency\n        else -> fillArrayFun<Char>(result, init)\n    }\n}\n\n@JsName(\"charArrayF\")\ninline fun charArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = charArray(size, null)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"untypedCharArrayF\")\ninline fun untypedCharArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = Array<Char>(size)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"longArray\")\nfun longArray(size: Int, init: dynamic): Array<Long> {\n    val result: dynamic = Array<Long>(size)\n    result.`$type$` = \"LongArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, 0L)\n        false -> result\n        else -> fillArrayFun<Long>(result, init)\n    }\n}\n\n@JsName(\"longArrayF\")\ninline fun longArrayWithFun(size: Int, init: (Int) -> Long): Array<Long> = fillArrayFun(longArray(size, false), init)\n\nprivate fun <T> fillArrayVal(array: Array<T>, initValue: T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = initValue\n    }\n    return array\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.regression.LinearRegression\nimport jetbrains.datalore.plot.base.stat.regression.LocalPolynomialRegression\nimport jetbrains.datalore.plot.base.stat.regression.PolynomialRegression\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.random.Random\n\n\n/**\n *\n * method - smoothing method: lm, glm, gam, loess, rlm\n * (For datasets with n < 1000 default is loess. For datasets with 1000 or more observations defaults to gam)\n * formula - formula to use in smoothing function\n * ( eg. y ~ x, y ~ poly(x, 2), y ~ log(x))\n * se (TRUE ) - display confidence interval around smooth?\n * n (80) - number of points to evaluate smoother at\n *\n *\n * span (0.75) - controls the amount of smoothing for the default loess smoother.\n * fullrange (FALSE) - should the fit span the full range of the plot, or just the data\n * level (0.95) - level of confidence interval to use\n * method.args - ist of additional arguments passed on to the modelling function defined by method\n *\n *\n * Adds columns:\n *\n * y    - predicted value\n * ymin - lower pointwise confidence interval around the mean\n * ymax - upper pointwise confidence interval around the mean\n * se   - standard error\n */\nclass SmoothStat constructor(\n    private val smootherPointCount: Int,\n    private val smoothingMethod: Method,\n    private val confidenceLevel: Double,\n    private val displayConfidenceInterval: Boolean,\n    private val span: Double,\n    private val polynomialDegree: Int,\n    private val loessCriticalSize: Int,\n    private val samplingSeed: Long\n) : BaseStat(DEF_MAPPING) {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return super.hasDefaultMapping(aes) ||\n                aes == Aes.YMIN && displayConfidenceInterval ||\n                aes == Aes.YMAX && displayConfidenceInterval\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        if (aes == Aes.YMIN) {\n            return Stats.Y_MIN\n        }\n        return if (aes == Aes.YMAX) {\n            Stats.Y_MAX\n        } else super.getDefaultMapping(aes)\n    }\n\n    enum class Method {\n        LM, // linear model\n        GLM,\n        GAM,\n        LOESS,\n        RLM\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )  // also conditional Y_MIN / Y_MAX\n        const val DEF_EVAL_POINT_COUNT = 80\n        val DEF_SMOOTHING_METHOD = Method.LM\n        const val DEF_CONFIDENCE_LEVEL = 0.95    // 95 %\n        const val DEF_DISPLAY_CONFIDENCE_INTERVAL = true\n        const val DEF_SPAN = 0.5\n        const val DEF_DEG = 1\n        const val DEF_LOESS_CRITICAL_SIZE = 1_000\n        const val DEF_SAMPLING_SEED = 37L\n    }\n\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf<Aes<*>>(Aes.Y)\n    }\n\n    fun needSampling(rowCount: Int): Boolean {\n        if (smoothingMethod != Method.LOESS) {\n            return false\n        }\n\n        if (rowCount <= loessCriticalSize) {\n            return false\n        }\n\n        return true\n    }\n\n    private fun applySampling(data: DataFrame, messageConsumer: (s: String) -> Unit): DataFrame {\n        val msg = \"LOESS drew a random sample with max_n=$loessCriticalSize, seed=$samplingSeed\"\n        messageConsumer(msg)\n\n        return SamplingUtil.sampleWithoutReplacement(loessCriticalSize, Random(samplingSeed), data)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n\n        if (needSampling(data.rowCount())) {\n            data = applySampling(data, messageConsumer)\n        }\n\n        val valuesY = data.getNumeric(TransformVar.Y)\n        if (valuesY.size < 3) {  // at least 3 data points required\n            return withEmptyStatValues()\n        }\n\n        val valuesX: List<Double?>\n        if (data.has(TransformVar.X)) {\n            valuesX = data.getNumeric(TransformVar.X)\n        } else {\n            valuesX = ArrayList()\n            for (i in valuesY.indices) {\n                valuesX.add(i.toDouble())\n            }\n        }\n\n        SeriesUtil.range(valuesX) ?: return withEmptyStatValues()\n\n        // do stat for each group separately\n\n        val statX: List<Double>\n        val statY: List<Double>\n        val statMinY: List<Double>\n        val statMaxY: List<Double>\n        val statSE: List<Double>\n\n        val statValues = applySmoothing(valuesX, valuesY)\n\n        statX = statValues[Stats.X]!!\n        statY = statValues[Stats.Y]!!\n        statMinY = statValues[Stats.Y_MIN]!!\n        statMaxY = statValues[Stats.Y_MAX]!!\n        statSE = statValues[Stats.SE]!!\n\n        val statData = DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.Y, statY)\n\n        if (displayConfidenceInterval) {\n            statData.putNumeric(Stats.Y_MIN, statMinY)\n                .putNumeric(Stats.Y_MAX, statMaxY)\n                .putNumeric(Stats.SE, statSE)\n        }\n\n        return statData.build()\n    }\n\n    /* About five methods\n   * Linear Regression: DONE\n   * Loess: DONE, SE used bootstrap method, but too many strikes. Refer to www.netlib.org/a/cloess.ps Page 45\n   * Generalized Linear Model: https://spark.apache.org/docs/latest/ml-classification-regression.html#generalized-linear-regression\n   * Robust Linear Model: Unfortunately no Java Library\n   * Generalized Additive Model: Unknown\n   * */\n\n    private fun applySmoothing(valuesX: List<Double?>, valuesY: List<Double?>): Map<DataFrame.Variable, List<Double>> {\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statMinY = ArrayList<Double>()\n        val statMaxY = ArrayList<Double>()\n        val statSE = ArrayList<Double>()\n\n        val result = HashMap<DataFrame.Variable, List<Double>>()\n        result[Stats.X] = statX\n        result[Stats.Y] = statY\n        result[Stats.Y_MIN] = statMinY\n        result[Stats.Y_MAX] = statMaxY\n        result[Stats.SE] = statSE\n\n        val regression = when (smoothingMethod) {\n            Method.LM -> {\n                require(polynomialDegree >= 1) { \"Degree of polynomial regression must be at least 1\" }\n                if (polynomialDegree == 1) {\n                    LinearRegression(valuesX, valuesY, confidenceLevel)\n                } else {\n                    if (PolynomialRegression.canBeComputed(valuesX, valuesY, polynomialDegree)) {\n                        PolynomialRegression(valuesX, valuesY, confidenceLevel, polynomialDegree)\n                    } else {\n                        return result   // empty stat data\n                    }\n                }\n            }\n            Method.LOESS -> {\n                val evaluator = LocalPolynomialRegression(valuesX, valuesY, confidenceLevel, span)\n                if (evaluator.canCompute) {\n                    evaluator\n                } else {\n                    return result   // empty stat data\n                }\n            }\n            else -> throw IllegalArgumentException(\n                \"Unsupported smoother method: $smoothingMethod (only 'lm' and 'loess' methods are currently available)\"\n            )\n        }\n\n        val rangeX = SeriesUtil.range(valuesX) ?: return result\n\n        val startX = rangeX.lowerEnd\n        val spanX = rangeX.upperEnd - startX\n        val stepX = spanX / (smootherPointCount - 1)\n\n        for (i in 0 until smootherPointCount) {\n            val x = startX + i * stepX\n            val eval = regression.evalX(x.coerceIn(rangeX.lowerEnd, rangeX.upperEnd))\n            statX.add(x)\n            statY.add(eval.y)\n            statMinY.add(eval.ymin)\n            statMaxY.add(eval.ymax)\n            statSE.add(eval.se)\n        }\n        return result\n    }\n}\n\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.sqrt\n\n/**\n * Base class for probability distributions on the reals.\n * Default implementations are provided for some of the methods\n * that do not vary from distribution to distribution.\n *\n * @version $Id: AbstractRealDistribution.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 3.0\n */\nabstract class AbstractRealDistribution\n/** Default constructor.  */\nprotected constructor() : RealDistribution {\n\n    /** Solver absolute accuracy for inverse cumulative computation  */\n    /**\n     * Returns the solver absolute accuracy for inverse cumulative computation.\n     * You can override this method in order to use a Brent solver with an\n     * absolute accuracy different from the default.\n     *\n     * @return the maximum absolute error in inverse cumulative probability estimates\n     */\n    protected open val solverAbsoluteAccuracy =\n        SOLVER_DEFAULT_ABSOLUTE_ACCURACY\n\n    /**\n     * {@inheritDoc}\n     *\n     * The default implementation uses the identity\n     *\n     * `P(x0 < X <= x1) = P(X <= x1) - P(X <= x0)`\n     */\n    override fun cumulativeProbability(x0: Double, x1: Double): Double {\n        if (x0 > x1) {\n            error(\"NumberIsTooLarge - x0:$x0, x1:$x1\")\n        }\n        return cumulativeProbability(x1) - cumulativeProbability(x0)\n    }\n\n    /**\n     * {@inheritDoc}\n     *\n     * The default implementation returns\n     *\n     *  * [.getSupportLowerBound] for `p = 0`,\n     *  * [.getSupportUpperBound] for `p = 1`.\n     *\n     */\n    override fun inverseCumulativeProbability(p: Double): Double {\n        /*\n         * IMPLEMENTATION NOTES\n         * --------------------\n         * Where applicable, use is made of the one-sided Chebyshev inequality\n         * to bracket the root. This inequality states that\n         * P(X - mu >= k * sig) <= 1 / (1 + k^2),\n         * mu: mean, sig: standard deviation. Equivalently\n         * 1 - P(X < mu + k * sig) <= 1 / (1 + k^2),\n         * F(mu + k * sig) >= k^2 / (1 + k^2).\n         *\n         * For k = sqrt(p / (1 - p)), we find\n         * F(mu + k * sig) >= p,\n         * and (mu + k * sig) is an upper-bound for the root.\n         *\n         * Then, introducing Y = -X, mean(Y) = -mu, sd(Y) = sig, and\n         * P(Y >= -mu + k * sig) <= 1 / (1 + k^2),\n         * P(-X >= -mu + k * sig) <= 1 / (1 + k^2),\n         * P(X <= mu - k * sig) <= 1 / (1 + k^2),\n         * F(mu - k * sig) <= 1 / (1 + k^2).\n         *\n         * For k = sqrt((1 - p) / p), we find\n         * F(mu - k * sig) <= p,\n         * and (mu - k * sig) is a lower-bound for the root.\n         *\n         * In cases where the Chebyshev inequality does not apply, geometric\n         * progressions 1, 2, 4, ... and -1, -2, -4, ... are used to bracket\n         * the root.\n         */\n        if (p < 0.0 || p > 1.0) {\n            error(\"OutOfRange [0, 1] - p$p\")\n        }\n\n        var lowerBound = supportLowerBound\n        if (p == 0.0) {\n            return lowerBound\n        }\n\n        var upperBound = supportUpperBound\n        if (p == 1.0) {\n            return upperBound\n        }\n\n        val mu = numericalMean\n        val sig = sqrt(numericalVariance)\n        val chebyshevApplies: Boolean\n        chebyshevApplies = !(mu.isInfinite() || mu.isNaN() || sig.isInfinite() || sig.isNaN())\n\n        if (lowerBound == Double.NEGATIVE_INFINITY) {\n            if (chebyshevApplies) {\n                lowerBound = mu - sig * sqrt((1.0 - p) / p)\n            } else {\n                lowerBound = -1.0\n                while (cumulativeProbability(lowerBound) >= p) {\n                    lowerBound *= 2.0\n                }\n            }\n        }\n\n        if (upperBound == Double.POSITIVE_INFINITY) {\n            if (chebyshevApplies) {\n                upperBound = mu + sig * sqrt(p / (1.0 - p))\n            } else {\n                upperBound = 1.0\n                while (cumulativeProbability(upperBound) < p) {\n                    upperBound *= 2.0\n                }\n            }\n        }\n\n        val toSolve = object : UnivariateFunction {\n            override fun value(x: Double): Double {\n                return cumulativeProbability(x) - p\n            }\n        }\n\n        val x = UnivariateSolverUtils.solve(\n            toSolve,\n            lowerBound,\n            upperBound,\n            solverAbsoluteAccuracy\n        )\n\n        if (!isSupportConnected) {\n            /* Test for plateau. */\n            val dx = solverAbsoluteAccuracy\n            if (x - dx >= supportLowerBound) {\n                val px = cumulativeProbability(x)\n                if (cumulativeProbability(x - dx) == px) {\n                    upperBound = x\n                    while (upperBound - lowerBound > dx) {\n                        val midPoint = 0.5 * (lowerBound + upperBound)\n                        if (cumulativeProbability(midPoint) < px) {\n                            lowerBound = midPoint\n                        } else {\n                            upperBound = midPoint\n                        }\n                    }\n                    return upperBound\n                }\n            }\n        }\n        return x\n    }\n\n    companion object {\n        /** Default accuracy.  */\n        val SOLVER_DEFAULT_ABSOLUTE_ACCURACY = 1e-6\n\n        /** Serializable version identifier  */\n        private const val serialVersionUID = -38038050983108802L\n    }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\n\n\n/**\n * Utilities for comparing numbers.\n *\n * @since 3.0\n * @version $Id$\n */\nobject Precision {\n    /** Offset to order signed double numbers lexicographically.  */\n    private val SGN_MASK: Long = 1.shl(63)\n    /** Offset to order signed double numbers lexicographically.  */\n    private val SGN_MASK_FLOAT = 1.shl(31)\n\n    /**\n     * Compares two numbers given some amount of allowed error.\n     *\n     * @param x the first number\n     * @param y the second number\n     * @param eps the amount of error to allow when checking for equality\n     * @return  * 0 if  [equals(x, y, eps)][.equals]\n     *  * &lt; 0 if ![equals(x, y, eps)][.equals] &amp;&amp; x &lt; y\n     *  * > 0 if ![equals(x, y, eps)][.equals] &amp;&amp; x > y\n     */\n    fun compareTo(x: Double, y: Double, eps: Double): Int {\n        if (equals(x, y, eps)) {\n            return 0\n        } else if (x < y) {\n            return -1\n        }\n        return 1\n    }\n\n    /**\n     * Compares two numbers given some amount of allowed error.\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return  * 0 if  [equals(x, y, maxUlps)][.equals]\n     *  * &lt; 0 if ![equals(x, y, maxUlps)][.equals] &amp;&amp; x &lt; y\n     *  * > 0 if ![equals(x, y, maxUlps)][.equals] &amp;&amp; x > y\n     */\n    fun compareTo(x: Double, y: Double, maxUlps: Int): Int {\n        if (equals(x, y, maxUlps)) {\n            return 0\n        } else if (x < y) {\n            return -1\n        }\n        return 1\n    }\n\n    /**\n     * Returns true if both arguments are NaN or neither is NaN and they are\n     * equal as defined by [equals(x, y, 1)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @return `true` if the values are equal or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, 1)\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other.\n     * @since 2.2\n     */\n    fun equals(x: Float, y: Float, eps: Float): Boolean {\n        return equals(x, y, 1) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are NaN or are equal or within the range\n     * of allowed error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other,\n     * or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float, eps: Float): Boolean {\n        return equalsIncludingNaN(x, y) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if there are fewer than `maxUlps` floating\n     * point values between `x` and `y`.\n     * @since 2.2\n     */\n    @JvmOverloads\n    fun equals(x: Float, y: Float, maxUlps: Int = 1): Boolean {\n        var xInt = x.toBits()\n        var yInt = y.toBits()\n\n        // Make lexicographically ordered as a two's-complement integer.\n        if (xInt < 0) {\n            xInt = SGN_MASK_FLOAT - xInt\n        }\n        if (yInt < 0) {\n            yInt = SGN_MASK_FLOAT - yInt\n        }\n\n        val isEqual = abs(xInt - yInt) <= maxUlps\n\n        return isEqual && !x.isNaN() && !y.isNaN()\n    }\n\n    /**\n     * Returns true if both arguments are NaN or if they are equal as defined\n     * by [equals(x, y, maxUlps)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if both arguments are NaN or if there are less than\n     * `maxUlps` floating point values between `x` and `y`.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float, maxUlps: Int): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, maxUlps)\n    }\n\n    /**\n     * Returns true if both arguments are NaN or neither is NaN and they are\n     * equal as defined by [equals(x, y, 1)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @return `true` if the values are equal or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, 1)\n    }\n\n    /**\n     * Returns `true` if there is no double value strictly between the\n     * arguments or the difference between them is within the range of allowed\n     * error (inclusive).\n     *\n     * @param x First value.\n     * @param y Second value.\n     * @param eps Amount of allowed absolute error.\n     * @return `true` if the values are two adjacent floating point\n     * numbers or they are within range of each other.\n     */\n    fun equals(x: Double, y: Double, eps: Double): Boolean {\n        return equals(x, y, 1) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are NaN or are equal or within the range\n     * of allowed error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other,\n     * or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double, eps: Double): Boolean {\n        return equalsIncludingNaN(x, y) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if there are fewer than `maxUlps` floating\n     * point values between `x` and `y`.\n     */\n    @JvmOverloads\n    fun equals(x: Double, y: Double, maxUlps: Int = 1): Boolean {\n        var xInt = x.toBits()\n        var yInt = y.toBits()\n\n        // Make lexicographically ordered as a two's-complement integer.\n        if (xInt < 0) {\n            xInt = SGN_MASK - xInt\n        }\n        if (yInt < 0) {\n            yInt = SGN_MASK - yInt\n        }\n\n        val isEqual = abs(xInt - yInt) <= maxUlps\n\n        return isEqual && !x.isNaN() && !y.isNaN()\n    }\n\n    /**\n     * Returns true if both arguments are NaN or if they are equal as defined\n     * by [equals(x, y, maxUlps)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if both arguments are NaN or if there are less than\n     * `maxUlps` floating point values between `x` and `y`.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double, maxUlps: Int): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, maxUlps)\n    }\n\n\n    /**\n     * Computes a number `delta` close to `originalDelta` with\n     * the property that <pre>`\n     * x + delta - x\n    `</pre> *\n     * is exactly machine-representable.\n     * This is useful when computing numerical derivatives, in order to reduce\n     * roundoff errors.\n     *\n     * @param x Value.\n     * @param originalDelta Offset value.\n     * @return a number `delta` so that `x + delta` and `x`\n     * differ by a representable floating number.\n     */\n    fun representableDelta(\n        x: Double,\n        originalDelta: Double\n    ): Double {\n        return x + originalDelta - x\n    }\n}\n/**\n * Private constructor.\n */\n/**\n * Returns true iff they are equal as defined by\n * [equals(x, y, 1)][.equals].\n *\n * @param x first value\n * @param y second value\n * @return `true` if the values are equal.\n */\n/**\n * Returns true iff they are equal as defined by\n * [equals(x, y, 1)][.equals].\n *\n * @param x first value\n * @param y second value\n * @return `true` if the values are equal.\n */\n/**\n * Rounds the given value to the specified number of decimal places.\n * The value is rounded using the [BigDecimal.ROUND_HALF_UP] method.\n *\n * @param x Value to round.\n * @param scale Number of digits to the right of the decimal point.\n * @return the rounded value.\n * @since 1.1 (previously in `MathUtils`, moved as of version 3.0)\n */\n/**\n * Rounds the given value to the specified number of decimal places.\n * The value is rounded using the [BigDecimal.ROUND_HALF_UP] method.\n *\n * @param x Value to round.\n * @param scale Number of digits to the right of the decimal point.\n * @return the rounded value.\n * @since 1.1 (previously in `MathUtils`, moved as of version 3.0)\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n\n/**\n * Implementation of Student's t-distribution.\n *\n * @see \"[&apos;Student's t-distribution\n * @see \"[Student's t-distribution\n * @version $Id: TDistribution.java 1244107 2012-02-14 16:17:55Z erans $\n](mathworld.wolfram.com/Studentst-Distribution.html)](https://en.wikipedia.org/wiki/Student&apos;s_t-distribution) */\nclass TDistribution\n/**\n * Create a t distribution using the given degrees of freedom and the\n * specified inverse cumulative probability absolute accuracy.\n *\n * @param degreesOfFreedom Degrees of freedom.\n * @param inverseCumAccuracy the maximum absolute error in inverse\n * cumulative probability estimates\n * (defaults to [.DEFAULT_INVERSE_ABSOLUTE_ACCURACY]).\n * @throws NotStrictlyPositiveException if `degreesOfFreedom <= 0`\n * @since 2.1\n */\n@JvmOverloads constructor(\n    /** The degrees of freedom.  */\n    /**\n     * Access the degrees of freedom.\n     *\n     * @return the degrees of freedom.\n     */\n    private val degreesOfFreedom: Double,\n    /** Inverse cumulative probability accuracy.  */\n    /** {@inheritDoc}  */\n    override val solverAbsoluteAccuracy: Double = DEFAULT_INVERSE_ABSOLUTE_ACCURACY\n) : AbstractRealDistribution() {\n\n    /**\n     * {@inheritDoc}\n     *\n     * For degrees of freedom parameter `df`, the mean is\n     *\n     *  * if `df > 1` then `0`,\n     *  * else undefined (`Double.NaN`).\n     *\n     */\n    override val numericalMean: Double\n        get() {\n            val df = degreesOfFreedom\n\n            return if (df > 1) {\n                0.0\n            } else Double.NaN\n\n        }\n\n    /**\n     * {@inheritDoc}\n     *\n     * For degrees of freedom parameter `df`, the variance is\n     *\n     *  * if `df > 2` then `df / (df - 2)`,\n     *  * if `1 < df <= 2` then positive infinity\n     * (`Double.POSITIVE_INFINITY`),\n     *  * else undefined (`Double.NaN`).\n     *\n     */\n    override val numericalVariance: Double\n        get() {\n            val df = degreesOfFreedom\n\n            if (df > 2) {\n                return df / (df - 2)\n            }\n\n            return if (df > 1 && df <= 2) {\n                Double.POSITIVE_INFINITY\n            } else Double.NaN\n\n        }\n\n    /**\n     * {@inheritDoc}\n     *\n     * The lower bound of the support is always negative infinity no matter the\n     * parameters.\n     *\n     * @return lower bound of the support (always\n     * `Double.NEGATIVE_INFINITY`)\n     */\n    override val supportLowerBound: Double\n        get() = Double.NEGATIVE_INFINITY\n\n    /**\n     * {@inheritDoc}\n     *\n     * The upper bound of the support is always positive infinity no matter the\n     * parameters.\n     *\n     * @return upper bound of the support (always\n     * `Double.POSITIVE_INFINITY`)\n     */\n    override val supportUpperBound: Double\n        get() = Double.POSITIVE_INFINITY\n\n    /** {@inheritDoc}  */\n    override val isSupportLowerBoundInclusive: Boolean\n        get() = false\n\n    /** {@inheritDoc}  */\n    override val isSupportUpperBoundInclusive: Boolean\n        get() = false\n\n    /**\n     * {@inheritDoc}\n     *\n     * The support of this distribution is connected.\n     *\n     * @return `true`\n     */\n    override val isSupportConnected: Boolean\n        get() = true\n\n    init {\n        if (degreesOfFreedom <= 0) {\n            error(\"NotStrictlyPositive - DEGREES_OF_FREEDOM: $degreesOfFreedom\")\n        }\n    }\n\n    /**\n     * {@inheritDoc}\n     *\n     * For this distribution `P(X = x)` always evaluates to 0.\n     *\n     * @return 0\n     */\n    override fun probability(x: Double): Double {\n        return 0.0\n    }\n\n    /** {@inheritDoc}  */\n    override fun density(x: Double): Double {\n        val n = degreesOfFreedom\n        val nPlus1Over2 = (n + 1) / 2\n        return exp(\n            Gamma.logGamma(nPlus1Over2) -\n                    0.5 * (ln(PI) + ln(n)) -\n                    Gamma.logGamma(n / 2) -\n                    nPlus1Over2 * ln(1 + x * x / n)\n        )\n    }\n\n    /** {@inheritDoc}  */\n    override fun cumulativeProbability(x: Double): Double {\n        val ret: Double\n        if (x == 0.0) {\n            ret = 0.5\n        } else {\n            val t = Beta.regularizedBeta(\n                degreesOfFreedom / (degreesOfFreedom + x * x),\n                0.5 * degreesOfFreedom,\n                0.5\n            )\n            if (x < 0.0) {\n                ret = 0.5 * t\n            } else {\n                ret = 1.0 - 0.5 * t\n            }\n        }\n\n        return ret\n    }\n\n    companion object {\n        /**\n         * Default inverse cumulative probability accuracy.\n         * @since 2.1\n         */\n        val DEFAULT_INVERSE_ABSOLUTE_ACCURACY = 1e-9\n        /** Serializable version identifier  */\n        private val serialVersionUID = -5852615386664158222L\n    }\n}\n/**\n * Create a t distribution using the given degrees of freedom.\n *\n * @param degreesOfFreedom Degrees of freedom.\n * @throws NotStrictlyPositiveException if `degreesOfFreedom <= 0`\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables.filter\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\nclass Aes<T> private constructor(val name: String, val isNumeric: Boolean = true) : TypedKey<T> {\n\n    val isColor: Boolean\n        get() = isColor(this)\n\n    init {\n        values.add(this)\n    }\n\n    override fun toString(): String {\n        return \"aes '$name'\"\n    }\n\n    companion object {\n        private val values = ArrayList<Aes<*>>()\n\n        val X: Aes<Double> = Aes(\"x\")\n        val Y: Aes<Double> = Aes(\"y\")\n        val Z: Aes<Double> = Aes(\"z\")\n\n        val COLOR: Aes<Color> = Aes(\"color\", false)\n        val FILL: Aes<Color> = Aes(\"fill\", false)\n        val ALPHA: Aes<Double> = Aes(\"alpha\")\n        val SHAPE: Aes<PointShape> = Aes(\"shape\", false)\n        val LINETYPE: Aes<LineType> = Aes(\"linetype\", false)\n\n        val SIZE: Aes<Double> = Aes(\"size\")\n        val WIDTH: Aes<Double> = Aes(\"width\")\n        val HEIGHT: Aes<Double> = Aes(\"height\")\n        val WEIGHT: Aes<Double> = Aes(\"weight\")\n        val INTERCEPT: Aes<Double> = Aes(\"intercept\")\n        val SLOPE: Aes<Double> = Aes(\"slope\")\n        val XINTERCEPT: Aes<Double> = Aes(\"xintercept\")\n        val YINTERCEPT: Aes<Double> = Aes(\"yintercept\")\n        val LOWER: Aes<Double> = Aes(\"lower\")\n        val MIDDLE: Aes<Double> = Aes(\"middle\")\n        val UPPER: Aes<Double> = Aes(\"upper\")\n\n        val XMIN: Aes<Double> = Aes(\"xmin\")\n        val XMAX: Aes<Double> = Aes(\"xmax\")\n        val YMIN: Aes<Double> = Aes(\"ymin\")\n        val YMAX: Aes<Double> = Aes(\"ymax\")\n        val XEND: Aes<Double> = Aes(\"xend\")\n        val YEND: Aes<Double> = Aes(\"yend\")\n\n        val FRAME: Aes<String> = Aes(\"frame\", false)\n\n        val SPEED: Aes<Double> = Aes(\"speed\")\n        val FLOW: Aes<Double> = Aes(\"flow\")\n\n        val LABEL: Aes<Any?> = Aes(\"label\", false)\n        val FAMILY: Aes<String> = Aes(\"family\", false)\n        val FONTFACE: Aes<String> = Aes(\"fontface\", false)\n\n        // text horizontal justification (numbers [0..1] or predefined strings = new Aes<>(); not positional)\n        val HJUST = Aes<Any>(\"hjust\", false)\n\n        // text vertical justification (numbers [0..1] or predefined strings, not positional)\n        val VJUST = Aes<Any>(\"vjust\", false)\n\n        val ANGLE: Aes<Double> = Aes(\"angle\")\n\n        val SYM_X: Aes<Double> = Aes(\"sym_x\")\n        val SYM_Y: Aes<Double> = Aes(\"sym_y\")\n\n\n        fun numeric(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            // safe to cast all 'numeric' aesthetics are 'Double'\n            @Suppress(\"UNCHECKED_CAST\")\n            return filter(unfiltered) { aes -> aes.isNumeric } as Iterable<Aes<Double>>\n        }\n\n        fun isPositional(aes: Aes<*>): Boolean {\n            return isPositionalXY(aes) ||\n                    // SLOPE must be positional or\n                    // `geom_abline(slope=number)` will not work.\n                    // it should draw the same line as:\n                    // `geom_abline(slope=number, intersept=0)`\n                    // See: PlotUtil.createLayerAesthetics()\n                    aes == SLOPE\n        }\n\n        fun isPositionalXY(aes: Aes<*>): Boolean {\n            return isPositionalX(aes) ||\n                    isPositionalY(aes)\n        }\n\n        fun isPositionalX(aes: Aes<*>): Boolean {\n            return aes == X ||\n                    aes == XINTERCEPT ||\n                    aes == XMIN ||\n                    aes == XMAX ||\n                    aes == XEND\n        }\n\n        fun isPositionalY(aes: Aes<*>): Boolean {\n            return aes == Y ||\n                    aes == YMIN ||\n                    aes == YMAX ||\n                    aes == INTERCEPT ||\n                    aes == YINTERCEPT ||\n                    aes == LOWER ||\n                    aes == MIDDLE ||\n                    aes == UPPER ||\n                    aes == YEND\n        }\n\n        fun isColor(aes: Aes<*>): Boolean {\n            return aes == COLOR || aes == FILL\n        }\n\n        fun isAffectingScaleX(aes: Aes<*>): Boolean {\n            return isPositionalX(aes) // && aes != XINTERCEPT\n        }\n\n        fun isAffectingScaleY(aes: Aes<*>): Boolean {\n            return isPositionalY(aes) &&\n                    // \"INTERCEPT\" is \"positional Y\" because it must use the same 'mapper' as other \"positional Y\"-s,\n                    // but its range of values is not taken in account when computing the Y-mapper.\n                    aes != INTERCEPT // &&\n//                    aes != YINTERCEPT\n        }\n\n        fun affectingScaleX(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            val numeric = numeric(unfiltered)\n            return filter(numeric) { isAffectingScaleX(it) }\n        }\n\n        fun affectingScaleY(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            val numeric = numeric(unfiltered)\n            return filter(numeric) { isAffectingScaleY(it) }\n        }\n\n        fun noGuideNeeded(aes: Aes<*>): Boolean {\n            return aes == FRAME ||\n                    aes == SPEED ||\n                    aes == FLOW ||\n                    aes == LABEL ||\n                    aes == SLOPE ||\n                    aes == WIDTH ||\n                    aes == HEIGHT ||\n                    aes == HJUST ||\n                    aes == VJUST ||\n                    aes == ANGLE ||\n                    aes == FAMILY ||\n                    aes == FONTFACE ||\n                    aes == SYM_X ||\n                    aes == SYM_Y ||\n                    isPositional(aes)\n        }\n\n        fun values(): List<Aes<*>> {\n            return values\n        }\n\n        fun allPositional(): List<Aes<Double>> {\n            @Suppress(\"UNCHECKED_CAST\")\n            return values.filter { isPositional(it) } as List<Aes<Double>>\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninterface CoordinateSystem {\n    fun toClient(p: DoubleVector): DoubleVector\n\n    fun fromClient(p: DoubleVector): DoubleVector\n\n    fun isPointInLimits(p: DoubleVector, isClient: Boolean = true): Boolean\n\n    fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean = true): Boolean\n\n    fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean = true): Boolean\n\n    fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean = true): Boolean\n\n    val xClientLimit: ClosedRange<Double>?\n\n    val yClientLimit: ClosedRange<Double>?\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.jvm.JvmOverloads\n\nclass DataFrame private constructor(builder: Builder) {\n    private val myVectorByVar: Map<Variable, List<*>>\n    private val myIsNumeric: MutableMap<Variable, Boolean>\n\n    // volatile variables (yet)\n    private val myRanges = HashMap<Variable, ClosedRange<Double>?>()\n    private val myDistinctValues = HashMap<Variable, Set<Any>>()\n\n    class OrderSpec(\n        val variable: Variable,\n        val orderBy: Variable,\n        val direction: Int,\n        val aggregateOperation: ((List<Double?>) -> Double?)? = null\n    )\n\n    private val myOrderSpecs: List<OrderSpec>\n\n    val isEmpty: Boolean\n        get() = myVectorByVar.isEmpty()\n\n    init {\n        assertAllSeriesAreSameSize(builder.myVectorByVar)\n        myVectorByVar = HashMap(builder.myVectorByVar)\n        myIsNumeric = HashMap(builder.myIsNumeric)\n        myOrderSpecs = builder.myOrderSpecs\n        myOrderSpecs.forEach { orderSpec ->\n            myDistinctValues[orderSpec.variable] = getOrderedDistinctValues(orderSpec)\n        }\n    }\n\n    private fun assertAllSeriesAreSameSize(vectorByVar: Map<Variable, List<*>>) {\n        if (vectorByVar.size > 1) {\n            val entries = vectorByVar.entries.iterator()\n            val first = entries.next()\n            val size = first.value.size\n            while (entries.hasNext()) {\n                val next = entries.next()\n                if (next.value.size != size) {\n                    throw IllegalArgumentException(\n                        \"All data series in data frame must have equal size\\n\" + dumpSizes(\n                            vectorByVar\n                        )\n                    )\n                }\n            }\n        }\n    }\n\n    private fun dumpSizes(vectorByVar: Map<Variable, List<*>>): String {\n        val sb = StringBuilder()\n        for ((key, value) in vectorByVar) {\n            sb.append(key.name)\n                .append(\" : \")\n                .append(value.size)\n                .append('\\n')\n        }\n        return sb.toString()\n    }\n\n    fun rowCount(): Int {\n        return if (myVectorByVar.isEmpty()) 0 else myVectorByVar.entries.iterator().next().value.size\n    }\n\n    fun has(variable: Variable): Boolean {\n        return myVectorByVar.containsKey(variable)\n    }\n\n    fun isEmpty(variable: Variable): Boolean {\n        return get(variable).isEmpty()\n    }\n\n    fun hasNoOrEmpty(variable: Variable): Boolean {\n        return !has(variable) || isEmpty(variable)\n    }\n\n    operator fun get(variable: Variable): List<*> {\n        assertDefined(variable)\n        return myVectorByVar[variable]!!\n    }\n\n    fun getNumeric(variable: Variable): List<Double?> {\n        assertDefined(variable)\n        val list = myVectorByVar[variable]\n        if (list!!.isEmpty()) {\n            return emptyList()\n        }\n\n        assertNumeric(variable)\n        @Suppress(\"UNCHECKED_CAST\")\n        return list as List<Double?>\n    }\n\n    fun distinctValues(variable: Variable): Collection<Any> {\n        assertDefined(variable)\n        return myDistinctValues.getOrPut(variable) {\n            val values = LinkedHashSet(get(variable)).apply {\n                this.remove(null)\n            }\n            @Suppress(\"UNCHECKED_CAST\")\n            return values as Collection<Any>\n        }\n    }\n\n    fun variables(): Set<Variable> {\n        return myVectorByVar.keys\n    }\n\n    fun isNumeric(variable: Variable): Boolean {\n        assertDefined(variable)\n        if (!myIsNumeric.containsKey(variable)) {\n            val checkedDoubles = SeriesUtil.checkedDoubles(get(variable))\n            myIsNumeric[variable] = checkedDoubles.notEmptyAndCanBeCast()\n        }\n        return myIsNumeric[variable]!!\n    }\n\n    fun range(variable: Variable): ClosedRange<Double>? {\n        if (!myRanges.containsKey(variable)) {\n            val v = getNumeric(variable)\n            val r = SeriesUtil.range(v)\n            myRanges[variable] = r\n        }\n        return myRanges[variable]\n    }\n\n    fun builder(): Builder {\n        return Builder(this)\n    }\n\n    private fun assertDefined(variable: Variable) {\n        if (!has(variable)) {\n            val e = IllegalArgumentException(\"Undefined variable: '$variable'\")\n            LOG.error(e) { e.message!! }\n            throw e\n        }\n    }\n\n    private fun assertNumeric(variable: Variable) {\n        if (!isNumeric(variable)) {\n            val e = IllegalArgumentException(\"Not a numeric variable: '$variable'\")\n            LOG.error(e) { e.message!! }\n            throw e\n        }\n    }\n\n    fun selectIndices(indices: List<Int>): DataFrame {\n        return buildModified { serie -> SeriesUtil.pickAtIndices(serie, indices) }\n    }\n\n    fun selectIndices(indices: Set<Int>): DataFrame {\n        return buildModified { serie -> SeriesUtil.pickAtIndices(serie, indices) }\n    }\n\n    fun dropIndices(indices: Set<Int>): DataFrame {\n        return if (indices.isEmpty()) this else buildModified { serie -> SeriesUtil.skipAtIndices(serie, indices) }\n    }\n\n    private fun buildModified(serieFun: (List<*>) -> List<*>): DataFrame {\n        val builder = this.builder()\n        for (variable in myVectorByVar.keys) {\n            val serie = myVectorByVar[variable]\n            val modifiedSerie = serieFun(serie!!)\n            builder.putIntern(variable, modifiedSerie)\n        }\n        return builder.build()\n    }\n\n    class Variable @JvmOverloads constructor(\n        val name: String,\n        val source: Source = Source.ORIGIN,\n        val label: String = name\n    ) {\n\n        val isOrigin: Boolean\n            get() = source == Source.ORIGIN\n\n        val isStat: Boolean\n            get() = source == Source.STAT\n\n        val isTransform: Boolean\n            get() = source == Source.TRANSFORM\n\n        override fun toString(): String {\n            // important\n            return name\n        }\n\n        fun toSummaryString(): String {\n            return \"$name, '$label' [$source]\"\n        }\n\n        enum class Source {\n            ORIGIN, TRANSFORM, STAT\n        }\n\n        companion object {\n\n            @JvmOverloads\n            fun createOriginal(name: String, label: String = name): Variable {\n                return Variable(\n                    name,\n                    Source.ORIGIN,\n                    label\n                )\n            }\n        }\n    }\n\n    private fun getOrderedDistinctValues(orderSpec: OrderSpec): Set<Any> {\n        fun isValueComparable(value: Any?) = value != null && (value !is Double || value.isFinite())\n\n        val orderedValues = if (orderSpec.aggregateOperation != null) {\n            require(isNumeric(orderSpec.orderBy)) { \"Can't apply aggregate operation to non-numeric values\" }\n            get(orderSpec.variable)\n                .zip(getNumeric(orderSpec.orderBy))\n                .groupBy({ (value) -> value }) { (_, byValue) -> byValue }\n                .mapValues { (_, byValues) -> orderSpec.aggregateOperation.invoke(byValues.filter(::isValueComparable)) }\n                .toList()\n        } else {\n            get(orderSpec.variable).zip(get(orderSpec.orderBy))\n        }\n            .filter { isValueComparable(it.second) && isValueComparable(it.first)}\n            .sortedWith(compareBy({ it.second as Comparable<*> }, { it.first as Comparable<*> }))\n            .mapNotNull { it.first }\n\n        // the values corresponding to non-comparable values will be placed at the end of the result\n        val nonComparableAppendix = get(orderSpec.variable).zip(get(orderSpec.orderBy))\n            .filterNot { isValueComparable(it.second) }\n            .mapNotNull { it.first }\n\n        return (if (orderSpec.direction < 0) {\n            orderedValues.reversed()\n        } else {\n            orderedValues\n        } + nonComparableAppendix).toSet()\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(DataFrame::class)\n    }\n\n    class Builder {\n        internal val myVectorByVar = HashMap<Variable, List<*>>()\n        internal val myIsNumeric = HashMap<Variable, Boolean>()\n        internal val myOrderSpecs = ArrayList<OrderSpec>()\n\n        constructor()\n\n        constructor(data: DataFrame) {\n            myVectorByVar.putAll(data.myVectorByVar)\n            myIsNumeric.putAll(data.myIsNumeric)\n            myOrderSpecs.addAll(data.myOrderSpecs)\n        }\n\n        fun put(variable: Variable, v: List<*>): Builder {\n            putIntern(variable, v)\n            myIsNumeric.remove(variable)  // unknown state\n            return this\n        }\n\n        fun putNumeric(variable: Variable, v: List<Double?>): Builder {\n            putIntern(variable, v)\n            myIsNumeric[variable] = true\n            return this\n        }\n\n        fun putDiscrete(variable: Variable, v: List<*>): Builder {\n            putIntern(variable, v)\n            myIsNumeric[variable] = false\n            return this\n        }\n\n        internal fun putIntern(variable: Variable, v: List<*>) {\n            myVectorByVar[variable] = ArrayList(v)\n        }\n\n        fun remove(variable: Variable): Builder {\n            myVectorByVar.remove(variable)\n            myIsNumeric.remove(variable)\n            return this\n        }\n\n        fun addOrderSpecs(orderSpecs: List<OrderSpec>): Builder {\n            orderSpecs.forEach(::addOrderSpec)\n            return this\n        }\n\n        fun addOrderSpec(orderSpec: OrderSpec): Builder {\n            val currentOrderSpec = myOrderSpecs.find { it.variable == orderSpec.variable }\n            // If multiple specifications for the variable - choose a more specific one:\n            if (currentOrderSpec?.aggregateOperation == null) {\n                myOrderSpecs.remove(currentOrderSpec)\n                myOrderSpecs.add(orderSpec)\n            }\n            return this\n        }\n\n        fun build(): DataFrame {\n            return DataFrame(this)\n        }\n\n        companion object {\n            fun emptyFrame(): DataFrame {\n                return Builder().build()\n            }\n        }\n    }\n}","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\ninterface DataPointAesthetics {\n    fun index(): Int\n\n    fun x(): Double?\n\n    fun y(): Double?\n\n    fun z(): Double?\n\n    fun ymin(): Double?\n\n    fun ymax(): Double?\n\n    fun color(): Color?\n\n    fun fill(): Color?\n\n    fun alpha(): Double?\n\n    fun shape(): PointShape?\n\n    fun lineType(): LineType\n\n    fun size(): Double?\n\n    fun width(): Double?\n\n    fun height(): Double?\n\n    fun weight(): Double?\n\n    fun intercept(): Double?\n\n    fun slope(): Double?\n\n    fun interceptX(): Double?\n\n    fun interceptY(): Double?\n\n    fun lower(): Double?\n\n    fun middle(): Double?\n\n    fun upper(): Double?\n\n    fun frame(): String\n\n    fun speed(): Double?\n\n    fun flow(): Double?\n\n    fun xmin(): Double?\n\n    fun xmax(): Double?\n\n    fun xend(): Double?\n\n    fun yend(): Double?\n\n    fun label(): Any?\n\n    fun family(): String\n\n    fun fontface(): String\n\n    fun hjust(): Any\n\n    fun vjust(): Any\n\n    fun angle(): Double?\n\n    fun symX(): Double?\n\n    fun symY(): Double?\n\n    fun group(): Int?\n\n    fun numeric(aes: Aes<Double>): Double?\n\n    operator fun <T> get(aes: Aes<T>): T?\n\n    fun defined(aes: Aes<*>): Boolean {\n        if (aes.isNumeric) {\n            val number = get(aes)\n            return number != null && (number as Double).isFinite()\n        }\n        return true\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.TreeMap\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport kotlin.math.abs\n\nfinal class DiscreteTransform(\n    val domainValues: Collection<Any>,\n    val domainLimits: List<Any>\n) : Transform {\n\n    private val numberByDomainValue = LinkedHashMap<Any, Double>()\n    private val domainValueByNumber: TreeMap<Double, Any> = TreeMap()\n\n    init {\n        val effectiveDomain = if (domainLimits.isEmpty()) {\n            domainValues\n        } else {\n            domainLimits.intersect(domainValues)\n        }\n\n        numberByDomainValue.putAll(\n            MapperUtil.mapDiscreteDomainValuesToNumbers(effectiveDomain)\n        )\n\n        for ((domainValue, number) in numberByDomainValue) {\n            domainValueByNumber.put(number, domainValue)\n        }\n    }\n\n    fun hasDomainLimits(): Boolean {\n        return domainLimits.isNotEmpty()\n    }\n\n    fun isInDomain(v: Any?): Boolean {\n        return numberByDomainValue.containsKey(v)\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return l.map { asNumber(it) }\n    }\n\n    override fun applyInverse(v: Double?): Any? {\n        return fromNumber(v)\n    }\n\n    private fun asNumber(input: Any?): Double? {\n        if (input == null) {\n            return null\n        }\n        if (numberByDomainValue.containsKey(input)) {\n            return numberByDomainValue[input]\n        }\n\n        throw IllegalStateException(\n            \"value $input is not in the domain: ${numberByDomainValue.keys}\"\n        )\n    }\n\n    private fun fromNumber(v: Double?): Any? {\n        if (v == null) {\n            return null\n        }\n\n        if (domainValueByNumber.containsKey(v)) {\n            return domainValueByNumber[v]\n        }\n\n        // look-up the closest key (number)\n        val ceilingKey = domainValueByNumber.ceilingKey(v)\n        val floorKey = domainValueByNumber.floorKey(v)\n        var keyNumber: Double? = null\n        if (ceilingKey != null || floorKey != null) {\n            keyNumber = when {\n                ceilingKey == null -> floorKey\n                floorKey == null -> ceilingKey\n                else -> {\n                    val ceilingDist = abs(ceilingKey - v)\n                    val floorDist = abs(floorKey - v)\n                    if (ceilingDist < floorDist) ceilingKey else floorKey\n                }\n            }\n        }\n        return if (keyNumber != null) domainValueByNumber[keyNumber] else null\n    }\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nenum class GeomKind {\n    PATH,\n    LINE,\n    SMOOTH,\n    BAR,\n    HISTOGRAM,\n    TILE,\n    BIN_2D,\n    MAP,\n    ERROR_BAR,\n    CROSS_BAR,\n    LINE_RANGE,\n    POINT_RANGE,\n    POLYGON,\n    AB_LINE,\n    H_LINE,\n    V_LINE,\n    BOX_PLOT,\n    LIVE_MAP,\n    POINT,\n    RIBBON,\n    AREA,\n    DENSITY,\n    CONTOUR,\n    CONTOURF,\n    DENSITY2D,\n    DENSITY2DF,\n    JITTER,\n    FREQPOLY,\n    STEP,\n    RECT,\n    SEGMENT,\n    TEXT,\n    RASTER,\n    IMAGE\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport kotlin.native.concurrent.ThreadLocal\n\n// In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n// See:  https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n// Required mutations:\n//      -   `renderedAesByGeom` map\n@ThreadLocal\nobject GeomMeta {\n    private val renderedAesByGeom = HashMap<GeomKind, List<Aes<*>>>()\n\n    fun renders(geomKind: GeomKind): List<Aes<*>> {\n        if (!renderedAesByGeom.containsKey(geomKind)) {\n            renderedAesByGeom[geomKind] =\n                renderedAesList(geomKind)\n        }\n        return renderedAesByGeom[geomKind]!!\n    }\n\n    private val POINT = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA,\n        Aes.SHAPE\n        // strokeWidth\n    )\n\n    private val PATH = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE, // path width\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.ALPHA,\n        Aes.SPEED,\n        Aes.FLOW\n    )\n\n    private val POLYGON = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE, // path width\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA\n    )\n\n    private val AREA = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE,\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA\n    )\n\n\n    private fun renderedAesList(geomKind: GeomKind): List<Aes<*>> {\n        return when (geomKind) {\n            GeomKind.POINT -> POINT\n            GeomKind.PATH -> PATH\n            GeomKind.LINE -> PATH\n\n            GeomKind.SMOOTH -> listOf(\n                Aes.X, Aes.Y,\n                Aes.YMIN, Aes.YMAX,\n\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.BAR -> listOf(\n                Aes.X,\n                Aes.Y,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                Aes.WIDTH,\n                Aes.SIZE\n            )\n\n            GeomKind.HISTOGRAM -> listOf(\n                Aes.X, Aes.Y,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                //Aes.WEIGHT,    // ToDo: this is actually handled by 'stat' (bin,count)\n                Aes.WIDTH,\n                Aes.SIZE\n            )\n\n            GeomKind.TILE,\n            GeomKind.BIN_2D -> listOf(\n                Aes.X, Aes.Y,\n                Aes.WIDTH,\n                Aes.HEIGHT,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.ERROR_BAR -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.WIDTH,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.CROSS_BAR -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX, Aes.MIDDLE,\n                Aes.WIDTH,\n\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE\n            )\n\n            GeomKind.LINE_RANGE -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.POINT_RANGE -> listOf(\n                Aes.X, Aes.Y,\n                Aes.YMIN, Aes.YMAX,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE\n            )\n\n            GeomKind.CONTOUR -> PATH\n            GeomKind.CONTOURF -> POLYGON\n            GeomKind.POLYGON -> POLYGON\n            GeomKind.MAP -> listOf(\n                // auto-wired to 'x' or 'long' and to 'y' or 'lat'\n                Aes.X, Aes.Y,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.AB_LINE -> listOf(\n                Aes.INTERCEPT, Aes.SLOPE,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n\n            GeomKind.H_LINE -> listOf(\n                Aes.YINTERCEPT,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n            GeomKind.V_LINE -> listOf(\n                Aes.XINTERCEPT,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n\n            GeomKind.BOX_PLOT -> listOf(\n                Aes.LOWER, // NaN for 'outlier' data-point\n                Aes.MIDDLE, // NaN for 'outlier' data-point\n                Aes.UPPER, // NaN for 'outlier' data-point\n\n                Aes.X,\n                Aes.Y, // NaN for 'box' data-point (used for outliers)\n                Aes.YMAX,\n                Aes.YMIN,\n\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE, // line width\n                Aes.WIDTH\n            )\n\n            GeomKind.RIBBON -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.AREA -> AREA\n            GeomKind.DENSITY -> AREA\n            GeomKind.DENSITY2D -> PATH\n            GeomKind.DENSITY2DF -> POLYGON\n            GeomKind.JITTER -> POINT\n            GeomKind.FREQPOLY -> PATH\n            GeomKind.STEP -> PATH\n            GeomKind.RECT -> listOf(\n                Aes.XMIN, Aes.XMAX,\n                Aes.YMIN, Aes.YMAX,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.SEGMENT -> listOf(\n                Aes.X, Aes.Y,\n                Aes.XEND, Aes.YEND,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA,\n                Aes.SPEED,\n                Aes.FLOW\n            )\n\n            GeomKind.TEXT -> listOf(\n                Aes.X, Aes.Y,\n                Aes.SIZE,\n                Aes.COLOR,\n                Aes.ALPHA,\n                Aes.LABEL,\n                Aes.FAMILY,\n                Aes.FONTFACE,\n                Aes.HJUST,\n                Aes.VJUST,\n                Aes.ANGLE\n            )\n\n            GeomKind.LIVE_MAP -> listOf( // ToDo: not static - depends on 'display mode'\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.SIZE,\n                Aes.SHAPE,\n                Aes.FRAME,\n                Aes.X,\n                Aes.Y,\n                Aes.SYM_X,\n                Aes.SYM_Y\n            )\n\n            GeomKind.RASTER -> listOf(\n                Aes.X, Aes.Y,\n                Aes.WIDTH, // not rendered but required for correct x aes range computation\n                Aes.HEIGHT, // -- the same --\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.IMAGE -> listOf(\n                Aes.XMIN,\n                Aes.XMAX,\n                Aes.YMIN,\n                Aes.YMAX\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninterface PositionAdjustment {\n    val isIdentity: Boolean\n        get() = false\n\n    fun handlesGroups(): Boolean\n\n    fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\ninterface Stat {\n    fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit = {}): DataFrame\n\n    fun consumes(): List<Aes<*>>\n\n    fun hasDefaultMapping(aes: Aes<*>): Boolean\n\n    fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.plot.base.render.point.NamedShape\n\nobject AesInitValue {\n\n    private val VALUE_MAP = TypedKeyHashMap()\n\n    init {\n        VALUE_MAP[X] = 0.0\n        VALUE_MAP[Y] = 0.0\n        VALUE_MAP[Z] = 0.0\n        VALUE_MAP[YMIN] = Double.NaN\n        VALUE_MAP[YMAX] = Double.NaN\n        VALUE_MAP[COLOR] = Color.PACIFIC_BLUE\n        VALUE_MAP[FILL] = Color.PACIFIC_BLUE\n        VALUE_MAP[ALPHA] = 1.0\n        VALUE_MAP[SHAPE] = NamedShape.SOLID_CIRCLE\n        VALUE_MAP[LINETYPE] = NamedLineType.SOLID\n        VALUE_MAP[SIZE] = 0.5  // Line thickness. Should be redefined for other shapes\n        VALUE_MAP[WIDTH] = 1.0\n        VALUE_MAP[HEIGHT] = 1.0\n        VALUE_MAP[WEIGHT] = 1.0\n        VALUE_MAP[INTERCEPT] = 0.0\n        VALUE_MAP[SLOPE] = 1.0\n        VALUE_MAP[XINTERCEPT] = 0.0\n        VALUE_MAP[YINTERCEPT] = 0.0\n        VALUE_MAP[LOWER] = Double.NaN\n        VALUE_MAP[MIDDLE] = Double.NaN\n        VALUE_MAP[UPPER] = Double.NaN\n        VALUE_MAP[FRAME] = \"empty frame\"\n        VALUE_MAP[SPEED] = 10.0\n        VALUE_MAP[FLOW] = 0.1\n        VALUE_MAP[XMIN] = Double.NaN\n        VALUE_MAP[XMAX] = Double.NaN\n        VALUE_MAP[XEND] = Double.NaN\n        VALUE_MAP[YEND] = Double.NaN\n        VALUE_MAP[LABEL] = \"\"\n        VALUE_MAP[FAMILY] = \"sans-serif\"\n        VALUE_MAP[FONTFACE] = \"plain\"\n        VALUE_MAP[HJUST] = 0.5  // 'middle'\n        VALUE_MAP[VJUST] = 0.5  // 'middle'\n        VALUE_MAP[ANGLE] = 0.0\n        VALUE_MAP[SYM_X] = 0.0\n        VALUE_MAP[SYM_Y] = 0.0\n    }\n\n    /**\n     * For test only (must br TRUE for any Aes)\n     */\n    fun has(aes: Aes<*>): Boolean {\n        return VALUE_MAP.containsKey(aes)\n    }\n\n    operator fun <T> get(aes: Aes<T>): T {\n        return VALUE_MAP.get<T>(aes)\n    }\n\n    operator fun <T> get(aes: TypedKey<T>): T {\n        return VALUE_MAP.get<T>(aes)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject AesScaling {\n    const val UNIT_SHAPE_SIZE = 2.2\n\n    fun strokeWidth(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2.0\n    }\n\n    fun circleDiameter(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * UNIT_SHAPE_SIZE\n    }\n\n    fun circleDiameterSmaller(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 1.5\n    }\n\n    fun sizeFromCircleDiameter(diameter: Double): Double {\n        // px -> aes Units\n        return diameter / UNIT_SHAPE_SIZE\n    }\n\n    fun textSize(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2\n    }\n\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\n\nabstract class AesVisitor<T> {\n    fun visit(aes: Aes<*>): T {\n        return if (aes.isNumeric) {\n            // Safe cast because all 'numeric' aesthetics are <Double>\n            @Suppress(\"UNCHECKED_CAST\")\n            visitNumeric(aes as Aes<Double>)\n        } else visitIntern(aes)\n    }\n\n    /**\n     * Descendants can override\n     *\n     * @param aes\n     */\n    @Suppress(\"MemberVisibilityCanBePrivate\")\n    protected fun visitNumeric(aes: Aes<Double>): T {\n        return visitIntern(aes)\n    }\n\n    private fun visitIntern(aes: Aes<*>): T {\n        if (aes == X) {\n            return x()\n        }\n        if (aes == Y) {\n            return y()\n        }\n        if (aes == Z) {\n            return z()\n        }\n        if (aes == YMIN) {\n            return ymin()\n        }\n        if (aes == YMAX) {\n            return ymax()\n        }\n        if (aes == COLOR) {\n            return color()\n        }\n        if (aes == FILL) {\n            return fill()\n        }\n        if (aes == ALPHA) {\n            return alpha()\n        }\n        if (aes == SHAPE) {\n            return shape()\n        }\n        if (aes == SIZE) {\n            return size()\n        }\n        if (aes == LINETYPE) {\n            return lineType()\n        }\n        if (aes == WIDTH) {\n            return width()\n        }\n        if (aes == HEIGHT) {\n            return height()\n        }\n        if (aes == WEIGHT) {\n            return weight()\n        }\n        if (aes == INTERCEPT) {\n            return intercept()\n        }\n        if (aes == SLOPE) {\n            return slope()\n        }\n        if (aes == XINTERCEPT) {\n            return interceptX()\n        }\n        if (aes == YINTERCEPT) {\n            return interceptY()\n        }\n        if (aes == LOWER) {\n            return lower()\n        }\n        if (aes == MIDDLE) {\n            return middle()\n        }\n        if (aes == UPPER) {\n            return upper()\n        }\n        if (aes == FRAME) {\n            return frame()\n        }\n        if (aes == SPEED) {\n            return speed()\n        }\n        if (aes == FLOW) {\n            return flow()\n        }\n        if (aes == XMIN) {\n            return xmin()\n        }\n        if (aes == XMAX) {\n            return xmax()\n        }\n        if (aes == XEND) {\n            return xend()\n        }\n        if (aes == YEND) {\n            return yend()\n        }\n        if (aes == LABEL) {\n            return label()\n        }\n        if (aes == FAMILY) {\n            return family()\n        }\n        if (aes == FONTFACE) {\n            return fontface()\n        }\n        if (aes == HJUST) {\n            return hjust()\n        }\n        if (aes == VJUST) {\n            return vjust()\n        }\n        if (aes == ANGLE) {\n            return angle()\n        }\n\n        if (aes == SYM_X) {\n            return symX()\n        }\n\n        if (aes == SYM_Y) {\n            return symY()\n        }\n\n        throw IllegalArgumentException(\"Unexpected aes: $aes\")\n    }\n\n    protected abstract fun x(): T\n\n    protected abstract fun y(): T\n\n    protected abstract fun z(): T\n\n    protected abstract fun ymin(): T\n\n    protected abstract fun ymax(): T\n\n    protected abstract fun color(): T\n\n    protected abstract fun fill(): T\n\n    protected abstract fun alpha(): T\n\n    protected abstract fun shape(): T\n\n    protected abstract fun lineType(): T\n\n    protected abstract fun size(): T\n\n    protected abstract fun width(): T\n\n    protected abstract fun height(): T\n\n    protected abstract fun weight(): T\n\n    protected abstract fun intercept(): T\n\n    protected abstract fun slope(): T\n\n    protected abstract fun interceptX(): T\n\n    protected abstract fun interceptY(): T\n\n    protected abstract fun lower(): T\n\n    protected abstract fun middle(): T\n\n    protected abstract fun upper(): T\n\n    protected abstract fun frame(): T\n\n    protected abstract fun speed(): T\n\n    protected abstract fun flow(): T\n\n    protected abstract fun xmin(): T\n\n    protected abstract fun xmax(): T\n\n    protected abstract fun xend(): T\n\n    protected abstract fun yend(): T\n\n    protected abstract fun label(): T\n\n    protected abstract fun family(): T\n\n    protected abstract fun fontface(): T\n\n    protected abstract fun hjust(): T\n\n    protected abstract fun vjust(): T\n\n    protected abstract fun angle(): T\n\n    protected abstract fun symX(): T\n\n    protected abstract fun symY(): T\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.function.Function\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Sets\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.jvm.JvmOverloads\n\nclass AestheticsBuilder @JvmOverloads constructor(private var myDataPointCount: Int = 0) {\n\n    private val myIndexFunctionMap: MutableMap<Aes<*>, (Int) -> Any?>\n    private var myGroup = constant(0)\n    private val myConstantAes = Sets.newHashSet(Aes.values())  // initially contains all Aes;\n    private val myOverallRangeByNumericAes = HashMap<Aes<Double>, ClosedRange<Double>>()\n\n    init {\n        myIndexFunctionMap = HashMap()\n        for (aes in Aes.values()) {\n            // Safe cast because AesInitValue.get(aes) is guaranteed to return correct type.\n            myIndexFunctionMap[aes] =\n                constant(\n                    AesInitValue[aes]\n                )\n        }\n    }\n\n    fun dataPointCount(v: Int): AestheticsBuilder {\n        myDataPointCount = v\n        return this\n    }\n\n    fun overallRange(aes: Aes<Double>, range: ClosedRange<Double>): AestheticsBuilder {\n        // It's full range (length px) of x/y axis\n        myOverallRangeByNumericAes[aes] = range\n        return this\n    }\n\n    fun x(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(X, v)\n    }\n\n    fun y(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(Y, v)\n    }\n\n    fun color(v: (Int) -> Color?): AestheticsBuilder {\n        return aes(COLOR, v)\n    }\n\n    fun fill(v: (Int) -> Color?): AestheticsBuilder {\n        return aes(FILL, v)\n    }\n\n    fun alpha(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(ALPHA, v)\n    }\n\n    fun shape(v: (Int) -> PointShape?): AestheticsBuilder {\n        return aes(SHAPE, v)\n    }\n\n    fun lineType(v: (Int) -> LineType?): AestheticsBuilder {\n        return aes(LINETYPE, v)\n    }\n\n    fun size(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SIZE, v)\n    }\n\n    fun width(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(WIDTH, v)\n    }\n\n    fun weight(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(WEIGHT, v)\n    }\n\n    fun frame(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FRAME, v)\n    }\n\n    fun speed(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SPEED, v)\n    }\n\n    fun flow(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(FLOW, v)\n    }\n\n    fun group(v: (Int) -> Int): AestheticsBuilder {\n        myGroup = v\n        return this\n    }\n\n    fun label(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(LABEL, v)\n    }\n\n    fun family(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FAMILY, v)\n    }\n\n    fun fontface(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FONTFACE, v)\n    }\n\n    fun hjust(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(HJUST, v)\n    }\n\n    fun vjust(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(VJUST, v)\n    }\n\n    fun angle(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(ANGLE, v)\n    }\n\n    fun xmin(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(XMIN, v)\n    }\n\n    fun xmax(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(XMAX, v)\n    }\n\n    fun ymin(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(YMIN, v)\n    }\n\n    fun ymax(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(YMAX, v)\n    }\n\n    fun symX(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SYM_X, v)\n    }\n\n    fun symY(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SYM_Y, v)\n    }\n\n    fun <T> constantAes(aes: Aes<T>, v: T): AestheticsBuilder {\n        myConstantAes.add(aes)\n        myIndexFunctionMap[aes] = constant(v)\n        return this\n    }\n\n    fun <T> aes(aes: Aes<T>, v: (Int) -> T?): AestheticsBuilder {\n        myConstantAes.remove(aes)\n        myIndexFunctionMap[aes] = v\n        return this\n    }\n\n    fun build(): Aesthetics {\n        return MyAesthetics(this)\n    }\n\n\n    private class MyAesthetics internal constructor(b: AestheticsBuilder) : Aesthetics {\n        private val myDataPointCount: Int = b.myDataPointCount\n        private val myIndexFunctionMap =\n            TypedIndexFunctionMap(b.myIndexFunctionMap)\n        val group = b.myGroup\n        private val myConstantAes: Set<Aes<*>>\n        private val myOverallRangeByNumericAes: Map<Aes<Double>, ClosedRange<Double>>\n\n        private val myResolutionByAes = HashMap<Aes<*>, Double>()\n        private val myRangeByNumericAes = HashMap<Aes<Double>, ClosedRange<Double>?>()\n\n        override val isEmpty: Boolean\n            get() = myDataPointCount == 0\n\n        init {\n            myConstantAes = HashSet(b.myConstantAes)\n            myOverallRangeByNumericAes = HashMap(b.myOverallRangeByNumericAes)\n        }\n\n        fun <T> aes(aes: Aes<T>): (Int) -> T {\n            return myIndexFunctionMap[aes]\n        }\n\n        override fun dataPointAt(index: Int): DataPointAesthetics {\n            return MyDataPointAesthetics(\n                index,\n                this\n            )\n        }\n\n        override fun dataPointCount(): Int {\n            return myDataPointCount\n        }\n\n        override fun dataPoints(): Iterable<DataPointAesthetics> {\n            val self = this\n            return object : Iterable<DataPointAesthetics> {\n                override fun iterator(): Iterator<DataPointAesthetics> =\n                    MyDataPointsIterator(\n                        myDataPointCount,\n                        self\n                    )\n            }\n        }\n\n        override fun range(aes: Aes<Double>): ClosedRange<Double>? {\n            if (!myRangeByNumericAes.containsKey(aes)) {\n                val r = when {\n                    myDataPointCount <= 0 ->\n                        ClosedRange(0.0, 0.0)\n                    myConstantAes.contains(aes) -> {\n                        // constant should not be null\n                        val v = numericValues(aes).iterator().next()!!\n                        if (v.isFinite()) {\n                            ClosedRange(v, v)\n                        } else null\n                    }\n                    else -> {\n                        val values = numericValues(aes)\n                        SeriesUtil.range(values)\n                    }\n                }\n                myRangeByNumericAes[aes] = r\n            }\n\n            return myRangeByNumericAes[aes]\n        }\n\n        override fun overallRange(aes: Aes<Double>): ClosedRange<Double> {\n            return myOverallRangeByNumericAes[aes] ?: error(\"Overall range is unknown for $aes\")\n        }\n\n        override fun resolution(aes: Aes<Double>, naValue: Double): Double {\n            if (!myResolutionByAes.containsKey(aes)) {\n                val resolution: Double =\n                    when {\n                        myConstantAes.contains(aes) -> 0.0\n                        else -> {\n                            val values = numericValues(aes)\n                            SeriesUtil.resolution(values, naValue)\n                        }\n                    }\n                myResolutionByAes[aes] = resolution\n            }\n\n            return myResolutionByAes[aes]!!\n        }\n\n        override fun numericValues(aes: Aes<Double>): Iterable<Double?> {\n            require(aes.isNumeric) { \"Numeric aes is expected: $aes\" }\n            return object : Iterable<Double> {\n                override fun iterator(): Iterator<Double> {\n                    return AesIterator(\n                        myDataPointCount,\n                        aes(aes)\n                    )\n                }\n            }\n        }\n\n        override fun groups(): Iterable<Int> {\n            return object : Iterable<Int> {\n                override fun iterator(): Iterator<Int> {\n                    return AesIterator(\n                        myDataPointCount,\n                        group\n                    )\n                }\n            }\n        }\n    }\n\n    private class MyDataPointsIterator internal constructor(\n        private val myLength: Int,\n        private val myAesthetics: MyAesthetics\n    ) : Iterator<DataPointAesthetics> {\n        private var myIndex = 0\n\n        override fun hasNext(): Boolean {\n            return myIndex < myLength\n        }\n\n        override fun next(): DataPointAesthetics {\n            if (hasNext()) {\n                return myAesthetics.dataPointAt(myIndex++)\n            }\n            throw NoSuchElementException(\"index=$myIndex\")\n        }\n    }\n\n    private class AesIterator<T> internal constructor(private val myLength: Int, private val myAes: (Int) -> T) :\n        Iterator<T> {\n        private var myIndex = 0\n\n        override fun hasNext(): Boolean {\n            return myIndex < myLength\n        }\n\n        override fun next(): T {\n            if (hasNext()) {\n                return myAes(myIndex++)\n            }\n            throw NoSuchElementException(\"index=$myIndex\")\n        }\n    }\n\n\n    private class MyDataPointAesthetics(\n        private val myIndex: Int?,\n        private val myAesthetics: MyAesthetics\n    ) : DataPointAesthetics {\n\n        override fun index(): Int {\n            return myIndex!!\n        }\n\n        override fun x(): Double? {\n            return get(X)\n        }\n\n        override fun y(): Double? {\n            return get(Y)\n        }\n\n        override fun z(): Double? {\n            return get(Z)\n        }\n\n        override fun ymin(): Double? {\n            return get(YMIN)\n        }\n\n        override fun ymax(): Double? {\n            return get(YMAX)\n        }\n\n        override fun color(): Color {\n            return get(COLOR)\n        }\n\n        override fun fill(): Color {\n            return get(FILL)\n        }\n\n        override fun alpha(): Double? {\n            return get(ALPHA)\n        }\n\n        override fun shape(): PointShape {\n            return get(SHAPE)\n        }\n\n        override fun lineType(): LineType {\n            return get(LINETYPE)\n        }\n\n        override fun size(): Double? {\n            return get(SIZE)\n        }\n\n        override fun width(): Double? {\n            return get(WIDTH)\n        }\n\n        override fun height(): Double? {\n            return get(HEIGHT)\n        }\n\n        override fun weight(): Double? {\n            return get(WEIGHT)\n        }\n\n        override fun intercept(): Double? {\n            return get(INTERCEPT)\n        }\n\n        override fun slope(): Double? {\n            return get(SLOPE)\n        }\n\n        override fun interceptX(): Double? {\n            return get(XINTERCEPT)\n        }\n\n        override fun interceptY(): Double? {\n            return get(YINTERCEPT)\n        }\n\n        override fun lower(): Double? {\n            return get(LOWER)\n        }\n\n        override fun middle(): Double? {\n            return get(MIDDLE)\n        }\n\n        override fun upper(): Double? {\n            return get(UPPER)\n        }\n\n        override fun frame(): String {\n            return get(FRAME)\n        }\n\n        override fun speed(): Double? {\n            return get(SPEED)\n        }\n\n        override fun flow(): Double? {\n            return get(FLOW)\n        }\n\n        override fun xmin(): Double? {\n            return get(XMIN)\n        }\n\n        override fun xmax(): Double? {\n            return get(XMAX)\n        }\n\n        override fun xend(): Double? {\n            return get(XEND)\n        }\n\n        override fun yend(): Double? {\n            return get(YEND)\n        }\n\n        override fun label(): Any? {\n            return get(LABEL)\n        }\n\n        override fun family(): String {\n            return get(FAMILY)\n        }\n\n        override fun fontface(): String {\n            return get(FONTFACE)\n        }\n\n        override fun hjust(): Any {\n            return get(HJUST)\n        }\n\n        override fun vjust(): Any {\n            return get(VJUST)\n        }\n\n        override fun angle(): Double? {\n            return get(ANGLE)\n        }\n\n        override fun symX(): Double? {\n            return get(SYM_X)\n        }\n\n        override fun symY(): Double? {\n            return get(SYM_Y)\n        }\n\n        override fun group(): Int? {\n            return myAesthetics.group(myIndex!!)\n        }\n\n        override fun numeric(aes: Aes<Double>): Double? {\n            return get(aes)\n        }\n\n        override fun <T> get(aes: Aes<T>): T {\n            return myAesthetics.aes(aes)(myIndex!!)\n        }\n    }\n\n\n    private class ArrayAes<ValueT> internal constructor(private val myVal: Array<out ValueT>) : Function<Int, ValueT> {\n        override fun apply(value: Int): ValueT {\n            return myVal[value]\n        }\n    }\n\n    private class MapperAes<ValueT> internal constructor(\n        private val myL: List<Double>,\n        private val myF: ((Double) -> ValueT)\n    ) : Function<Int, ValueT> {\n        override fun apply(value: Int): ValueT {\n            return myF(myL[value])\n        }\n    }\n\n    companion object {\n        fun <T> constant(v: T): (Int) -> T = { v }\n\n        fun <T> array(v: Array<T>): (Int) -> T {\n            return { value -> v[value] }\n        }\n\n//        fun <T> array(vararg v: T): (Int) -> T {\n//            return { value -> v[value] }\n//        }\n\n        fun <T> collection(v: Collection<T>): (Int) -> T {\n            return { value -> Iterables[v, value] }\n        }\n\n        fun <T> listMapper(v: List<Double?>, f: (Double?) -> T?): (Int) -> T? {\n            return { value -> f(v[value]) }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants\n\nopen class AestheticsDefaults {\n\n    private val myDefaults = TypedKeyHashMap().apply {\n        for (aes in Aes.values()) {\n            // Safe cast because AesInitValue.get(aes) is guaranteed to return correct type.\n            @Suppress(\"UNCHECKED_CAST\")\n            put(aes as Aes<Any>, AesInitValue[aes])\n        }\n    }\n    private val myDefaultsInLegend = TypedKeyHashMap()\n\n    protected fun <T> update(aes: Aes<T>, defaultValue: T): AestheticsDefaults {\n        myDefaults.put(aes, defaultValue)\n        return this\n    }\n\n    protected fun <T> updateInLegend(aes: Aes<T>, defaultValue: T): AestheticsDefaults {\n        myDefaultsInLegend.put(aes, defaultValue)\n        return this\n    }\n\n\n    open fun rangeIncludesZero(aes: Aes<*>): Boolean {\n        return false\n    }\n\n    fun <T> defaultValue(aes: Aes<T>): T {\n        return myDefaults[aes]\n    }\n\n    fun <T> defaultValueInLegend(aes: Aes<T>): T {\n        return if (myDefaultsInLegend.containsKey(aes)) {\n            myDefaultsInLegend[aes]\n        } else defaultValue(aes)\n    }\n\n    companion object {\n        fun point(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 2.0)\n                .updateInLegend(Aes.SIZE, 5.0)\n        }\n\n        fun path(): AestheticsDefaults {\n            return base()\n        }\n\n        fun line(): AestheticsDefaults {\n            return path()\n        }\n\n        fun abline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun hline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun vline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun smooth(): AestheticsDefaults {\n            return path()\n                .update(Aes.COLOR, Color.MAGENTA)\n                .update(Aes.FILL, Color.BLACK)\n        }\n\n        fun bar(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n                .update(Aes.WIDTH, 0.9)\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun histogram(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun tile(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun bin2d(): AestheticsDefaults {\n            return tile()\n        }\n\n        fun errorBar(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.COLOR, Color.BLACK)\n        }\n\n        fun crossBar(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.WIDTH, 0.9)\n                .update(Aes.COLOR, Color.BLACK)\n                .update(Aes.FILL, Color.WHITE)\n        }\n\n        fun lineRange(): AestheticsDefaults {\n            return path()\n        }\n\n        fun pointRange(): AestheticsDefaults {\n            return path()\n        }\n\n        fun polygon(): AestheticsDefaults {\n            return base()\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun map(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 0.2)                    // outline thickness\n                .update(Aes.COLOR, Color.GRAY)\n                .update(Aes.FILL, Color.TRANSPARENT)\n        }\n\n        fun boxplot(): AestheticsDefaults {\n            return crossBar()\n        }\n\n        fun livemap(displayMode: LivemapConstants.DisplayMode): AestheticsDefaults {\n            return when (displayMode) {\n                LivemapConstants.DisplayMode.POINT -> point()\n                    .updateInLegend(Aes.SIZE, 5.0)\n                LivemapConstants.DisplayMode.BAR -> base()\n                    .update(Aes.SIZE, 40.0)\n                    .update(Aes.COLOR, Color.TRANSPARENT)\n                LivemapConstants.DisplayMode.PIE -> base()\n                    .update(Aes.SIZE, 20.0)\n                    .update(Aes.COLOR, Color.TRANSPARENT)\n                    .updateInLegend(Aes.SIZE, 5.0)\n            }\n        }\n\n        fun ribbon(): AestheticsDefaults {\n            return base()\n        }\n\n        fun area(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n        }\n\n        fun density(): AestheticsDefaults {\n            return area()\n                .update(Aes.FILL, Color.TRANSPARENT)\n        }\n\n        fun contour(): AestheticsDefaults {\n            return path()\n        }\n\n        fun contourf(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 0.0)\n        }\n\n        fun density2d(): AestheticsDefaults {\n            return contour()\n        }\n\n        fun density2df(): AestheticsDefaults {\n            return contourf()\n        }\n\n        fun jitter(): AestheticsDefaults {\n            return point()\n        }\n\n        fun freqpoly(): AestheticsDefaults {\n            return path()\n        }\n\n        fun step(): AestheticsDefaults {\n            return path()\n        }\n\n        fun rect(): AestheticsDefaults {\n            return polygon()\n        }\n\n        fun segment(): AestheticsDefaults {\n            return path()\n        }\n\n        fun text(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 7.0)\n                .update(Aes.COLOR, Color.parseHex(\"#3d3d3d\")) // dark gray\n        }\n\n\n        fun raster(): AestheticsDefaults {\n            return base()\n        }\n\n        fun image(): AestheticsDefaults {\n            return base()\n        }\n\n        private fun base(): AestheticsDefaults {\n            return AestheticsDefaults()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors.solid\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.point.UpdatableShape\nimport jetbrains.datalore.vis.svg.SvgShape\nimport jetbrains.datalore.vis.svg.SvgUtils\n\nobject AestheticsUtil {\n    //affects bar, smooth, area and ribbon\n    internal const val ALPHA_CONTROLS_BOTH = false\n\n    fun fill(filled: Boolean, solid: Boolean, p: DataPointAesthetics): Color {\n        if (filled) {\n            return p.fill()!!\n        } else if (solid) {\n            return p.color()!!\n        }\n        return Color.TRANSPARENT\n    }\n\n    fun decorate(shape: UpdatableShape, filled: Boolean, solid: Boolean, p: DataPointAesthetics, strokeWidth: Double) {\n        val fill = fill(filled, solid, p)\n        val stroke = p.color()!!\n\n        var fillAlpha = 0.0\n        if (filled || solid) {\n            fillAlpha = alpha(fill, p)\n        }\n\n        var strokeAlpha = 0.0\n        if (strokeWidth > 0) {\n            strokeAlpha = alpha(stroke, p)\n        }\n\n        shape.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    fun alpha(color: Color, p: DataPointAesthetics): Double {\n        return if (solid(color)) {    // only apply 'aes' alpha to solid colors\n            p.alpha()!!\n        } else SvgUtils.alpha2opacity(color.alpha)\n\n        // else, override with color's alpha\n    }\n\n    fun strokeWidth(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2.0\n    }\n//\n//    fun circleDiameter(p: DataPointAesthetics): Double {\n//        // aes Units -> px\n//        return p.size()!! * 2.2\n//    }\n//\n//    fun circleDiameterSmaller(p: DataPointAesthetics): Double {\n//        // aes Units -> px\n//        return p.size()!! * 1.5\n//    }\n//\n//    fun sizeFromCircleDiameter(diameter: Double): Double {\n//        // px -> aes Units\n//        return diameter / 2.2\n//    }\n//\n    fun textSize(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2\n    }\n\n    fun updateStroke(shape: SvgShape, p: DataPointAesthetics, applyAlpha: Boolean) {\n        shape.strokeColor().set(p.color())\n        if (solid(p.color()!!) && applyAlpha) {\n            shape.strokeOpacity().set(p.alpha())\n        }\n    }\n\n    fun updateFill(shape: SvgShape, p: DataPointAesthetics) {\n        shape.fillColor().set(p.fill())\n        if (solid(p.fill()!!)) {\n            shape.fillOpacity().set(p.alpha())\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.Aes\n\ninternal class TypedIndexFunctionMap(indexFunctionMap: Map<Aes<*>, (Int) -> Any?>) {\n    private var myMap: Map<Aes<*>, (Int) -> Any?> = indexFunctionMap\n\n    operator fun <T> get(aes: Aes<T>): (Int) -> T {\n        // Safe cast if 'put' is used responsibly.\n        @Suppress(\"UNCHECKED_CAST\")\n        return myMap[aes] as ((Int) -> T)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\n\nobject Coords {\n    fun create(\n        xRange: ClosedRange<Double>,\n        yRange: ClosedRange<Double>,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordinateSystem {\n        val origin = DoubleVector(\n            originX(xRange),\n            originY(yRange)\n        )\n        return create(origin, xLim, yLim)\n    }\n\n    fun create(\n        origin: DoubleVector,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordinateSystem {\n        return DefaultCoordinateSystem(\n            toClientOffsetX(origin.x),\n            toClientOffsetY(origin.y),\n            fromClientOffsetX(origin.x),\n            fromClientOffsetY(origin.y),\n            xLim,\n            yLim\n        )\n    }\n\n    fun toClientOffsetX(xRange: ClosedRange<Double>): (Double) -> Double {\n        return toClientOffsetX(\n            originX(\n                xRange\n            )\n        )\n    }\n\n    fun toClientOffsetY(yRange: ClosedRange<Double>): (Double) -> Double {\n        return toClientOffsetY(\n            originY(\n                yRange\n            )\n        )\n    }\n\n    private fun originX(xRange: ClosedRange<Double>): Double {\n        return -xRange.lowerEnd\n    }\n\n    private fun originY(yRange: ClosedRange<Double>): Double {\n        return yRange.upperEnd\n    }\n\n    private fun toClientOffsetX(originX: Double): (Double) -> Double {\n        return { x -> originX + x }\n    }\n\n    private fun fromClientOffsetX(originX: Double): (Double) -> Double {\n        return { x -> x - originX }\n    }\n\n    private fun toClientOffsetY(originY: Double): (Double) -> Double {\n        // y-axis is inverted\n        return { y -> originY - y }\n    }\n\n    private fun fromClientOffsetY(originY: Double): (Double) -> Double {\n        // y-axis is inverted\n        return { y -> originY - y }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleRectangles\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.geom.util.GeomCoord\n\ninternal class DefaultCoordinateSystem(\n    private val myToClientOffsetX: (Double) -> Double,\n    private val myToClientOffsetY: (Double) -> Double,\n    private val myFromClientOffsetX: (Double) -> Double,\n    private val myFromClientOffsetY: (Double) -> Double,\n    private val xLim: ClosedRange<Double>?,\n    private val yLim: ClosedRange<Double>?\n) :\n    CoordinateSystem {\n\n    override fun toClient(p: DoubleVector): DoubleVector {\n        return DoubleVector(myToClientOffsetX(p.x), myToClientOffsetY(p.y))\n    }\n\n    override fun fromClient(p: DoubleVector): DoubleVector {\n        return DoubleVector(myFromClientOffsetX(p.x), myFromClientOffsetY(p.y))\n    }\n\n    override fun isPointInLimits(p: DoubleVector, isClient: Boolean): Boolean {\n        val coord = if (isClient) fromClient(p) else p\n        return (xLim?.contains(coord.x) ?: true) && (yLim?.contains(coord.y) ?: true)\n    }\n\n    override fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean): Boolean {\n        val r = if (isClient) GeomCoord(this).fromClient(rect) else rect\n        return (xLim?.encloses(r.xRange()) ?: true) && (yLim?.encloses(r.yRange()) ?: true)\n    }\n\n    override fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean): Boolean {\n        return path.any { point -> isPointInLimits(point, isClient) }\n    }\n\n    override fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean): Boolean {\n        val bbox = DoubleRectangles.boundingBox(polygon)\n        return isRectInLimits(bbox, isClient)\n    }\n\n    override val xClientLimit: ClosedRange<Double>?\n        get() = xLim?.let { range -> convertRange(range, myToClientOffsetX) }\n\n    override val yClientLimit: ClosedRange<Double>?\n        get() = yLim?.let { range -> convertRange(range, myToClientOffsetY) }\n\n    private fun convertRange(range: ClosedRange<Double>, transform: (Double) -> Double): ClosedRange<Double> {\n        val l = transform(range.lowerEnd)\n        val u = transform(range.upperEnd)\n        return ClosedRange(\n            min(l, u),\n            max(l, u),\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.stat.Stats\nimport kotlin.jvm.JvmOverloads\n\nobject DataFrameUtil {\n    fun transformVarFor(aes: Aes<*>): DataFrame.Variable {\n        return TransformVar.forAes(aes)\n    }\n\n    fun applyTransform(data: DataFrame, `var`: DataFrame.Variable, aes: Aes<*>, scale: Scale<*>): DataFrame {\n        val transformVar = transformVarFor(aes)\n        return applyTransform(data, `var`, transformVar, scale)\n    }\n\n    private fun applyTransform(\n        data: DataFrame,\n        variable: DataFrame.Variable,\n        transformVar: DataFrame.Variable,\n        scale: Scale<*>\n    ): DataFrame {\n        val transformSource = getTransformSource(data, variable, scale)\n        val transformResult = scale.transform.apply(transformSource)\n        return data.builder()\n            .putNumeric(transformVar, transformResult)\n            .build()\n    }\n\n    private fun getTransformSource(data: DataFrame, variable: DataFrame.Variable, scale: Scale<*>): List<*> {\n        var transformSource = data[variable]\n\n//        // Replace values outside 'scale limits' with null-s.\n//        if (scale.hasDomainLimits()) {\n//            transformSource = transformSource.map { if (it == null || scale.isInDomainLimits(it)) it else null }\n//        }\n//\n//        // Replace values outside of domain of 'continuous transform' with null-s.\n//        if (scale.transform is ContinuousTransform) {\n//            val continuousTransform = scale.transform as ContinuousTransform\n//            if (continuousTransform.hasDomainLimits()) {\n//                transformSource =\n//                    transformSource.map { if (continuousTransform.isInDomain(it as Double?)) it else null }\n//            }\n//        }\n//\n//        return transformSource\n        return ScaleUtil.cleanUpTransformSource(transformSource, scale)\n    }\n\n    fun hasVariable(data: DataFrame, varName: String): Boolean {\n        for (`var` in data.variables()) {\n            if (varName == `var`.name) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun findVariableOrFail(data: DataFrame, varName: String): DataFrame.Variable {\n        for (`var` in data.variables()) {\n            if (varName == `var`.name) {\n                return `var`\n            }\n        }\n        throw IllegalArgumentException(\n            \"Variable not found: '$varName'. Variables in data frame: ${\n                data.variables().map { \"'${it.name}'\" }\n            }\"\n        )\n    }\n\n    fun isNumeric(data: DataFrame, varName: String): Boolean {\n        return data.isNumeric(findVariableOrFail(data, varName))\n    }\n\n    fun sortedCopy(variables: Iterable<DataFrame.Variable>): List<DataFrame.Variable> {\n        val ordering = Ordering.from(Comparator<DataFrame.Variable> { o1, o2 -> o1.name.compareTo(o2.name) })\n        return ordering.sortedCopy(variables)\n    }\n\n    fun variables(df: DataFrame): Map<String, DataFrame.Variable> {\n        return df.variables().associateBy(DataFrame.Variable::name)\n    }\n\n    fun appendReplace(df0: DataFrame, df1: DataFrame): DataFrame {\n        fun DataFrame.Builder.put(destVars: Collection<DataFrame.Variable>, df: DataFrame) = apply {\n            destVars.forEach { destVar ->\n                val srcVar = findVariableOrFail(df, destVar.name)\n                when (df.isNumeric(srcVar)) {\n                    true -> putNumeric(destVar, df.getNumeric(srcVar))\n                    false -> putDiscrete(destVar, df[srcVar])\n                }\n            }\n        }\n\n        return DataFrame.Builder()\n            .put(df0.variables().filter { it.name !in variables(df1) }, df0) // df0 - df1, keep vars from df0\n            .put(df0.variables().filter { it.name in variables(df1) }, df1)  // df0 & df1, keep vars from df0\n            .put(df1.variables().filter { it.name !in variables(df0) }, df1) // df1 - df0, new vars from df1\n            .build()\n    }\n\n    fun toMap(df: DataFrame): Map<String, List<*>> {\n        val result = HashMap<String, List<*>>()\n        val variables = df.variables()\n        for (`var` in variables) {\n            result[`var`.name] = df[`var`]\n        }\n        return result\n    }\n\n    fun fromMap(map: Map<*, *>): DataFrame {\n        val frameBuilder = DataFrame.Builder()\n        for ((key, value) in map) {\n            require(key is String) {\n                \"Map to data-frame: key expected a String but was \" + key!!::class.simpleName + \" : \" + key\n            }\n            require(value is List<*>) {\n                \"Map to data-frame: value expected a List but was \" + value!!::class.simpleName + \" : \" + value\n            }\n            frameBuilder.put(createVariable(key), value)\n        }\n        return frameBuilder.build()\n    }\n\n    @JvmOverloads\n    fun createVariable(name: String, label: String = name): DataFrame.Variable {\n        return when {\n            TransformVar.isTransformVar(name) -> TransformVar[name]\n            Stats.isStatVar(name) -> Stats.statVar(name)\n            Dummies.isDummyVar(name) -> Dummies.newDummy(name)\n            else -> DataFrame.Variable(name, DataFrame.Variable.Source.ORIGIN, label)\n        }\n    }\n\n    fun getSummaryText(df: DataFrame): String {\n        val sb = StringBuilder()\n        for (variable in df.variables()) {\n            sb.append(variable.toSummaryString())\n                .append(\" numeric: \" + df.isNumeric(variable))\n                .append(\" size: \" + df[variable].size)\n                .append('\\n')\n        }\n        return sb.toString()\n    }\n\n    fun removeAllExcept(df: DataFrame, keepNames: Set<String>): DataFrame {\n        val b = df.builder()\n        for (variable in df.variables()) {\n            if (!keepNames.contains(variable.name)) {\n                b.remove(variable)\n            }\n        }\n        return b.build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.DataFrame\n\nobject Dummies {\n\n    private const val PREFIX = \"__\"\n\n    fun isDummyVar(varName: String): Boolean {\n        if (!Strings.isNullOrEmpty(varName) && varName.length > PREFIX.length && varName.startsWith(\n                PREFIX\n            )\n        ) {\n            val numStr = varName.substring(PREFIX.length)\n            return numStr.matches(\"[0-9]+\".toRegex())\n        }\n        return false\n    }\n\n    fun dummyNames(count: Int): List<String> {\n        val l = ArrayList<String>()\n        for (i in 0 until count) {\n            l.add(PREFIX + i)\n        }\n        return l\n    }\n\n    fun newDummy(varName: String): DataFrame.Variable {\n        require(isDummyVar(varName)) { \"Not a dummy var name\" }\n        // no label\n        return DataFrame.Variable(varName, DataFrame.Variable.Source.ORIGIN, \"\")\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable.Source.TRANSFORM\nimport jetbrains.datalore.plot.base.aes.AesVisitor\n\nobject TransformVar {\n    val X = DataFrame.Variable(\"transform.X\", TRANSFORM)\n    val Y = DataFrame.Variable(\"transform.Y\", TRANSFORM)\n    val Z = DataFrame.Variable(\"transform.Z\", TRANSFORM)\n    val YMIN = DataFrame.Variable(\"transform.YMIN\", TRANSFORM)\n    val YMAX = DataFrame.Variable(\"transform.YMAX\", TRANSFORM)\n    val COLOR = DataFrame.Variable(\"transform.COLOR\", TRANSFORM)\n    val FILL = DataFrame.Variable(\"transform.FILL\", TRANSFORM)\n    val ALPHA = DataFrame.Variable(\"transform.ALPHA\", TRANSFORM)\n    val SHAPE = DataFrame.Variable(\"transform.SHAPE\", TRANSFORM)\n    val LINETYPE = DataFrame.Variable(\"transform.LINETYPE\", TRANSFORM)\n    val SIZE = DataFrame.Variable(\"transform.SIZE\", TRANSFORM)\n    val WIDTH = DataFrame.Variable(\"transform.WIDTH\", TRANSFORM)\n    val HEIGHT = DataFrame.Variable(\"transform.HEIGHT\", TRANSFORM)\n    val WEIGHT = DataFrame.Variable(\"transform.WEIGHT\", TRANSFORM)\n    val INTERCEPT = DataFrame.Variable(\"transform.INTERCEPT\", TRANSFORM)\n    val SLOPE = DataFrame.Variable(\"transform.SLOPE\", TRANSFORM)\n    val XINTERCEPT = DataFrame.Variable(\"transform.XINTERCEPT\", TRANSFORM)\n    val YINTERCEPT = DataFrame.Variable(\"transform.YINTERCEPT\", TRANSFORM)\n    val LOWER = DataFrame.Variable(\"transform.LOWER\", TRANSFORM)\n    val MIDDLE = DataFrame.Variable(\"transform.MIDDLE\", TRANSFORM)\n    val UPPER = DataFrame.Variable(\"transform.UPPER\", TRANSFORM)\n    val FRAME = DataFrame.Variable(\"transform.FRAME\", TRANSFORM)\n    val SPEED = DataFrame.Variable(\"transform.SPEED\", TRANSFORM)\n    val FLOW = DataFrame.Variable(\"transform.FLOW\", TRANSFORM)\n    val XMIN = DataFrame.Variable(\"transform.XMIN\", TRANSFORM)\n    val XMAX = DataFrame.Variable(\"transform.XMAX\", TRANSFORM)\n    val XEND = DataFrame.Variable(\"transform.XEND\", TRANSFORM)\n    val YEND = DataFrame.Variable(\"transform.YEND\", TRANSFORM)\n    val LABEL = DataFrame.Variable(\"transform.LABEL\", TRANSFORM)\n    val FONT_FAMILY = DataFrame.Variable(\"transform.FONT_FAMILY\", TRANSFORM)\n    val FONT_FACE = DataFrame.Variable(\"transform.FONT_FACE\", TRANSFORM)\n    val HJUST = DataFrame.Variable(\"transform.HJUST\", TRANSFORM)\n    val VJUST = DataFrame.Variable(\"transform.VJUST\", TRANSFORM)\n    val ANGLE = DataFrame.Variable(\"transform.ANGLE\", TRANSFORM)\n    val SYM_X = DataFrame.Variable(\"transform.SYM_X\", TRANSFORM)\n    val SYM_Y = DataFrame.Variable(\"transform.SYM_Y\", TRANSFORM)\n\n    private val VAR_BY_AES = TransformVarByAes()\n    private val VARS: Map<String, DataFrame.Variable>\n\n    init {\n        val varByName = HashMap<String, DataFrame.Variable>()\n        for (aes in Aes.values()) {\n            val `var` = VAR_BY_AES.visit(aes)\n            varByName[`var`.name] = `var`\n        }\n\n        VARS = varByName\n    }\n\n    fun isTransformVar(varName: String): Boolean {\n        return VARS.containsKey(varName)\n    }\n\n    operator fun get(varName: String): DataFrame.Variable {\n        check(VARS.containsKey(varName)) { \"Unknown transform variable $varName\" }\n        return VARS[varName]!!\n    }\n\n    fun forAes(aes: Aes<*>): DataFrame.Variable {\n        return VAR_BY_AES.visit(aes)\n    }\n\n    private class TransformVarByAes : AesVisitor<DataFrame.Variable>() {\n\n        override fun x(): DataFrame.Variable {\n            return X\n        }\n\n        override fun y(): DataFrame.Variable {\n            return Y\n        }\n\n        override fun z(): DataFrame.Variable {\n            return Z\n        }\n\n        override fun ymin(): DataFrame.Variable {\n            return YMIN\n        }\n\n        override fun ymax(): DataFrame.Variable {\n            return YMAX\n        }\n\n        override fun color(): DataFrame.Variable {\n            return COLOR\n        }\n\n        override fun fill(): DataFrame.Variable {\n            return FILL\n        }\n\n        override fun alpha(): DataFrame.Variable {\n            return ALPHA\n        }\n\n        override fun shape(): DataFrame.Variable {\n            return SHAPE\n        }\n\n        override fun lineType(): DataFrame.Variable {\n            return LINETYPE\n        }\n\n        override fun size(): DataFrame.Variable {\n            return SIZE\n        }\n\n        override fun width(): DataFrame.Variable {\n            return WIDTH\n        }\n\n        override fun height(): DataFrame.Variable {\n            return HEIGHT\n        }\n\n        override fun weight(): DataFrame.Variable {\n            return WEIGHT\n        }\n\n        override fun intercept(): DataFrame.Variable {\n            return INTERCEPT\n        }\n\n        override fun slope(): DataFrame.Variable {\n            return SLOPE\n        }\n\n        override fun interceptX(): DataFrame.Variable {\n            return XINTERCEPT\n        }\n\n        override fun interceptY(): DataFrame.Variable {\n            return YINTERCEPT\n        }\n\n        override fun lower(): DataFrame.Variable {\n            return LOWER\n        }\n\n        override fun middle(): DataFrame.Variable {\n            return MIDDLE\n        }\n\n        override fun upper(): DataFrame.Variable {\n            return UPPER\n        }\n\n        override fun frame(): DataFrame.Variable {\n            return FRAME\n        }\n\n        override fun speed(): DataFrame.Variable {\n            return SPEED\n        }\n\n        override fun flow(): DataFrame.Variable {\n            return FLOW\n        }\n\n        override fun xmin(): DataFrame.Variable {\n            return XMIN\n        }\n\n        override fun xmax(): DataFrame.Variable {\n            return XMAX\n        }\n\n        override fun xend(): DataFrame.Variable {\n            return XEND\n        }\n\n        override fun yend(): DataFrame.Variable {\n            return YEND\n        }\n\n        override fun label(): DataFrame.Variable {\n            return LABEL\n        }\n\n        override fun family(): DataFrame.Variable {\n            return FONT_FAMILY\n        }\n\n        override fun fontface(): DataFrame.Variable {\n            return FONT_FACE\n        }\n\n        override fun hjust(): DataFrame.Variable {\n            return HJUST\n        }\n\n        override fun vjust(): DataFrame.Variable {\n            return VJUST\n        }\n\n        override fun angle(): DataFrame.Variable {\n            return ANGLE\n        }\n\n        override fun symX(): DataFrame.Variable {\n            return SYM_X\n        }\n\n        override fun symY(): DataFrame.Variable {\n            return SYM_Y\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass ABLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n            .createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n        val boundaries = Iterables.toList(viewPort.parts)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.intercept()\n            val slope = p.slope()\n            if (SeriesUtil.allFinite(intercept, slope)) {\n                val p1 = DoubleVector(viewPort.left, intercept!! + viewPort.left * slope!!)\n                val p2 = DoubleVector(viewPort.right, p1.y + viewPort.dimension.x * slope)\n                val s = DoubleSegment(p1, p2)\n\n                val lineEnds = HashSet<DoubleVector>(2)\n                for (boundary in boundaries) {\n                    val intersection = boundary.intersection(s)\n                    if (intersection != null) {\n                        lineEnds.add(intersection)\n                        if (lineEnds.size == 2) {\n                            break\n                        }\n                    }\n                }\n\n                if (lineEnds.size == 2) {\n                    val it = lineEnds.iterator()\n                    val line = helper.createLine(it.next(), it.next(), p)\n                    lines.add(line)\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromFill\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nopen class AreaGeom : GeomBase() {\n\n    protected fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.ordered_X(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n\n        val helper = LinesHelper(pos, coord, ctx)\n        val paths = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_Y, GeomUtil.TO_LOCATION_X_ZERO)\n        paths.reverse()\n        appendNodes(paths, root)\n\n        //if you want to retain the side edges of area: comment out the following codes,\n        // and switch decorate method in LinesHelper.createbands\n        helper.setAlphaEnabled(false)\n        val lines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_Y)\n        appendNodes(lines, root)\n\n        buildHints(aesthetics, pos, coord, ctx)\n    }\n\n    private fun buildHints(aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val dataPoints = dataPoints(aesthetics).filter { p ->\n            val x = p.x()\n            val y = p.y()\n            SeriesUtil.allFinite(x, y) && coord.isPointInLimits(DoubleVector(x!!,y!!), isClient = false)\n        }\n        val multiPointDataList = MultiPointDataConstructor.createMultiPointDataByGroup(\n            dataPoints,\n            singlePointAppender { p -> toClient(geomHelper, p) },\n            reducer(0.999, false)\n        )\n\n        val targetCollector = getGeomTargetCollector(ctx)\n        for (multiPointData in multiPointDataList) {\n            targetCollector.addPath(\n                multiPointData.points,\n                multiPointData.localToGlobalIndex,\n                setupTooltipParams(multiPointData.aes)\n            )\n        }\n    }\n\n    protected open fun setupTooltipParams(aes: DataPointAesthetics): TooltipParams {\n        return params().setColor(fromFill(aes))\n    }\n\n    private fun toClient(geomHelper: GeomHelper, p: DataPointAesthetics): DoubleVector? {\n        val coord = GeomUtil.TO_LOCATION_X_Y(p)\n        return if (coord != null) {\n            geomHelper.toClient(coord, p)\n        } else {\n            null\n        }\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nopen class BarGeom : GeomBase() {\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val rectangles = helper.createRectangles(\n            rectangleByDataPoint(\n                ctx\n            )\n        )\n        rectangles.reverse()\n        rectangles.forEach { root.add(it) }\n\n//        RectTargetCollectorHelper(\n//            helper,\n//            rectangleByDataPoint(ctx),\n//            { HintColorUtil.fromFill(it) })\n//            .collectTo(ctx.targetCollector)\n        BarTooltipHelper.collectRectangleTargets(\n            emptyList(),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx),\n            { HintColorUtil.fromFill(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                val x = p.x()\n                val y = p.y()\n                val w = p.width()\n                if (!SeriesUtil.allFinite(x, y, w))\n                    null\n                else\n                    GeomUtil.rectangleByDataPoint(p, ctx)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Bin2dGeom : TileGeom() {\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.geom.util.*\nimport jetbrains.datalore.plot.base.interact.NullGeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass BoxplotGeom : GeomBase() {\n\n    var fattenMidline: Double = 1.0\n\n    var outlierColor: Color? = null\n    var outlierFill: Color? = null\n    var outlierShape: PointShape? = null\n    var outlierSize: Double? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildBoxes(\n            root, aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx)\n        )\n        buildLines(root, aesthetics, pos, coord, ctx)\n        buildOutliers(root, aesthetics, pos, coord, ctx)\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.UPPER, Aes.MIDDLE, Aes.LOWER, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    private fun buildLines(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildMidlines(root, aesthetics, pos, coord, ctx, fattenMidline)\n\n        val helper = GeomHelper(pos, coord, ctx)\n        val elementHelper = helper.createSvgElementHelper()\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X)) {\n            val x = p.x()!!\n            val lines = ArrayList<SvgLineElement>()\n\n            // lower whisker\n            if (p.defined(Aes.LOWER) && p.defined(Aes.YMIN)) {\n                val hinge = p.lower()!!\n                val fence = p.ymin()!!\n                // whisker line\n                lines.add(\n                    elementHelper.createLine(\n                        DoubleVector(x, hinge),\n                        DoubleVector(x, fence),\n                        p\n                    )\n                )\n                // fence line\n                /*\n        lines.add(elementHelper.createLine(\n            new DoubleVector(x - halfFenceWidth, fence),\n            new DoubleVector(x + halfFenceWidth, fence),\n            p));\n        */\n            }\n\n            // upper whisker\n            if (p.defined(Aes.UPPER) && p.defined(Aes.YMAX)) {\n                val hinge = p.upper()!!\n                val fence = p.ymax()!!\n                // whisker line\n                lines.add(\n                    elementHelper.createLine(\n                        DoubleVector(x, hinge),\n                        DoubleVector(x, fence),\n                        p\n                    )\n                )\n                // fence line\n                /*\n        lines.add(elementHelper.createLine(\n            new DoubleVector(x - halfFenceWidth, fence),\n            new DoubleVector(x + halfFenceWidth, fence),\n            p));\n        */\n\n                lines.forEach { root.add(it) }\n            }\n        }\n    }\n\n    private fun buildOutliers(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val outlierAesthetics = getOutliersAesthetics(aesthetics)\n        PointGeom()\n            .buildIntern(root, outlierAesthetics, pos, coord, ctx.withTargetCollector(NullGeomTargetCollector()))\n    }\n\n    private fun getOutliersAesthetics(aesthetics: Aesthetics): Aesthetics {\n        return MappedAesthetics(aesthetics) { p ->\n            toOutlierDataPointAesthetics(p)\n        }\n    }\n\n    /**\n     * The geom `Aesthetics` contains both: reqular data-points and \"outlier\" data-points.\n     * Regular data-point do not yave Y defined. We use this feature to feature to\n     * detect regular data-points and ignore them.\n     */\n    private fun toOutlierDataPointAesthetics(p: DataPointAesthetics): DataPointAesthetics {\n        if (!p.defined(Aes.Y)) {\n            // not an \"outlier\" data-point\n            return p\n        }\n\n        return object : DataPointAestheticsDelegate(p) {\n            override operator fun <T> get(aes: Aes<T>): T? = getIntern(aes)\n\n            override fun color(): Color? = getIntern(Aes.COLOR)\n            override fun fill(): Color? = getIntern(Aes.FILL)\n            override fun shape(): PointShape? = getIntern(Aes.SHAPE)\n            override fun size(): Double? = getIntern(Aes.SIZE)\n\n            private fun <T> getIntern(aes: Aes<T>): T? {\n                val value: Any? = when (aes) {\n                    Aes.COLOR -> outlierColor ?: super.color()\n                    Aes.FILL -> outlierFill ?: super.fill()\n                    Aes.SHAPE -> outlierShape ?: super.shape()\n                    Aes.SIZE -> outlierSize ?: OUTLIER_DEF_SIZE  // 'size' of 'super' is line thickness on box-plot\n                    else -> super.get(aes)\n                }\n                @Suppress(\"UNCHECKED_CAST\")\n                return value as T?\n            }\n        }\n    }\n\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private val LEGEND_FACTORY = CrossBarHelper.legendFactory(true)\n        private val OUTLIER_DEF_SIZE = AestheticsDefaults.point().defaultValue(Aes.SIZE)\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.LOWER) &&\n                    p.defined(Aes.UPPER) &&\n                    p.defined(Aes.WIDTH)\n                ) {\n                    val x = p.x()!!\n                    val lower = p.lower()!!\n                    val upper = p.upper()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, lower)\n                    val dimensions = DoubleVector(width, upper - lower)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nopen class ContourGeom : PathGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = PathGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PathGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nopen class ContourfGeom : PolygonGeom() {\n    companion object {\n\n//        val RENDERS = PolygonGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PolygonGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.CrossBarHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass CrossBarGeom : GeomBase() {\n    var fattenMidline: Double = 2.5\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildBoxes(\n            root, aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx, false)\n        )\n        CrossBarHelper.buildMidlines(root, aesthetics, pos, coord, ctx, fattenMidline)\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx, true),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private val LEGEND_FACTORY = CrossBarHelper.legendFactory(false)\n\n        private fun rectangleByDataPoint(\n            ctx: GeomContext,\n            isHintRect: Boolean\n        ): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (!isHintRect &&\n                    p.defined(Aes.X) &&\n                    p.defined(Aes.YMIN) &&\n                    p.defined(Aes.YMAX) &&\n                    p.defined(Aes.WIDTH)\n                ) {\n                    val x = p.x()!!\n                    val ymin = p.ymin()!!\n                    val ymax = p.ymax()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, ymin)\n                    val dimensions = DoubleVector(width, ymax - ymin)\n                    DoubleRectangle(origin, dimensions)\n                } else if (isHintRect &&\n                    p.defined(Aes.X) &&\n                    p.defined(Aes.MIDDLE)\n                ) {\n                    val x = p.x()!!\n                    val middle = p.middle()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, middle)\n                    val dimensions = DoubleVector(width, 0.0)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Density2dGeom : ContourGeom() {\n    companion object {\n//        val RENDERS = ContourGeom.RENDERS\n\n        val HANDLES_GROUPS = ContourGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Density2dfGeom : ContourfGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = ContourfGeom.RENDERS\n\n        val HANDLES_GROUPS = ContourfGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColor\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\n\nclass DensityGeom : AreaGeom() {\n\n    override fun setupTooltipParams(aes: DataPointAesthetics): TooltipParams {\n        return params().setColor(fromColor(aes))\n    }\n\n    companion object {\n//        val RENDERS: List<Aes<*>> = AreaGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            AreaGeom.HANDLES_GROUPS\n    }\n\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColor\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.HORIZONTAL_TOOLTIP\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass ErrorBarGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = MyLegendKeyElementFactory()\n\n    private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = LinesHelper(pos, coord, ctx)\n        val dataPoints = dataPoints(aesthetics)\n        val geomHelper = GeomHelper(pos, coord, ctx)\n\n        for (p in dataPoints) {\n            val x = p.x()\n            val ymin = p.ymin()\n            val ymax = p.ymax()\n            if (!SeriesUtil.allFinite(x, ymin, ymax)) {\n                continue\n            }\n            var width = p.width()!!\n            width *= ctx.getResolution(Aes.X)\n            val height = ymax!! - ymin!!\n\n            val r = DoubleRectangle(x!! - width / 2, ymin, width, height)\n\n            val g = errorBarShape(\n                helper.toClient(\n                    r,\n                    p\n                ), p\n            )\n            root.add(g)\n\n            buildHints(\n                DoubleRectangle(r.left, r.center.y, r.width, 0.0),\n                p,\n                ctx,\n                geomHelper\n            )\n        }\n    }\n\n    private fun buildHints(rect: DoubleRectangle, p: DataPointAesthetics, ctx: GeomContext, geomHelper: GeomHelper) {\n        val clientRect = geomHelper.toClient(rect, p)\n\n        val hint = HintConfigFactory()\n            .defaultObjectRadius(clientRect.width / 2.0)\n            .defaultX(p.x()!!)\n            .defaultKind(HORIZONTAL_TOOLTIP)\n\n        val hints = HintsCollection(p, geomHelper)\n            .addHint(hint.create(Aes.YMAX))\n            .addHint(hint.create(Aes.YMIN))\n            .hints\n\n        ctx.targetCollector.addRectangle(\n            p.index(), clientRect,\n            params()\n                .setTipLayoutHints(hints)\n                .setColor(fromColor(p))\n        )\n    }\n\n    private class MyLegendKeyElementFactory :\n        LegendKeyElementFactory {\n\n        override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n            val strokeWidth = AesScaling.strokeWidth(p)\n\n            val width = p.width()!! * (size.x - strokeWidth)\n            val height = size.y - strokeWidth\n            val x = (size.x - width) / 2\n            val y = strokeWidth / 2\n            return errorBarShape(\n                DoubleRectangle(\n                    x,\n                    y,\n                    width,\n                    height\n                ), p\n            )\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun errorBarShape(r: DoubleRectangle, p: DataPointAesthetics): SvgGElement {\n            val left = r.left\n            val top = r.top\n            val right = r.right\n            val bottom = r.bottom\n            val center = left + r.width / 2\n            val shapeLines = ArrayList<SvgLineElement>()\n            shapeLines.add(SvgLineElement(left, top, right, top))\n            shapeLines.add(SvgLineElement(left, bottom, right, bottom))\n            shapeLines.add(SvgLineElement(center, top, center, bottom))\n\n            val g = SvgGElement()\n            for (shapeLine in shapeLines) {\n                GeomHelper.decorate(shapeLine, p)\n                g.children().add(shapeLine)\n            }\n            return g\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\ninternal class FilledCircleLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val location = DoubleVector(size.x / 2, size.y / 2)\n//        val slimObject = SHAPE.create(location, p)\n        val slimObject = PointShapeSvg.create(\n            SHAPE, location, p)\n        val slimGroup = SvgSlimElements.g(1)\n        slimObject.appendTo(slimGroup)\n        return GeomBase.Companion.wrap(slimGroup)\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val shapeSize = SHAPE.size(p)\n        val strokeWidth = SHAPE.strokeWidth(p)\n        val size = shapeSize + strokeWidth + 2.0\n        return DoubleVector(size, size)\n    }\n\n    companion object {\n        private val SHAPE = NamedShape.FILLED_CIRCLE\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nclass FilledSquareLegendKeyElementFactory :\n    LegendKeyElementFactory {\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val rect = SvgRectElement(0.0, 0.0, size.x, size.y)\n        AestheticsUtil.updateFill(rect, p)\n        val g = SvgGElement()\n        g.children().add(rect)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass FreqpolyGeom : LineGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = LineGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            LineGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.GenericLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.LinePath\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimObject\n\nabstract class GeomBase : Geom {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = GenericLegendKeyElementFactory()\n\n    override fun build(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        buildIntern(root, aesthetics, pos, coord, ctx)\n    }\n\n    protected fun getGeomTargetCollector(ctx: GeomContext): GeomTargetCollector {\n        return ctx.targetCollector\n    }\n\n    protected abstract fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    )\n\n    companion object {\n        fun wrap(slimGroup: SvgSlimGroup): SvgGElement {\n            val g = SvgGElement()\n            g.isPrebuiltSubtree = true\n            g.children().add(slimGroup.asDummySvgNode())\n            return g\n        }\n\n        fun wrap(o: SvgSlimObject): SvgGElement {\n            val slimGroup = SvgSlimElements.g(1)\n            o.appendTo(slimGroup)\n            return wrap(slimGroup)\n        }\n\n        fun aesViewPort(aesthetics: Aesthetics): DoubleRectangle {\n            return rect(\n                aesthetics.overallRange(Aes.X),\n                aesthetics.overallRange(Aes.Y)\n            )\n        }\n\n        fun aesBoundingBox(aesthetics: Aesthetics): DoubleRectangle {\n            return rect(\n                aesthetics.range(Aes.X)!!,\n                aesthetics.range(Aes.Y)!!\n            )\n        }\n\n        private fun rect(rangeX: ClosedRange<Double>, rangeY: ClosedRange<Double>): DoubleRectangle {\n            return DoubleRectangle(\n                rangeX.lowerEnd, rangeY.lowerEnd,\n                SeriesUtil.span(rangeX), SeriesUtil.span(rangeY)\n            )\n        }\n\n        fun appendNodes(paths: List<LinePath>, root: SvgRoot) {\n            for (path in paths) {\n                root.add(path.rootGroup)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.legend.HLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass HLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.interceptY()\n            if (SeriesUtil.isFinite(intercept)) {\n                if (viewPort.yRange().contains(intercept!!)) {\n                    val start = DoubleVector(viewPort.left, intercept)\n                    val end = DoubleVector(viewPort.right, intercept)\n                    val line = helper.createLine(start, end, p)\n                    lines.add(line)\n\n                    val h = AesScaling.strokeWidth(p)\n                    val origin = DoubleVector(start.x, intercept - h/2 - 2.0)\n                    val dimensions = DoubleVector(viewPort.dimension.x, h + 4.0)\n                    val rect = DoubleRectangle(origin, dimensions)\n                    ctx.targetCollector.addRectangle(\n                        p.index(),\n                        geomHelper.toClient(rect, p),\n                        GeomTargetCollector.TooltipParams.params()\n                            .setColor(HintColorUtil.fromColor(p)),\n                        TipLayoutHint.Kind.CURSOR_TOOLTIP\n                    )\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        val LEGEND_KEY_ELEMENT_FACTORY: LegendKeyElementFactory =\n            HLineLegendKeyElementFactory()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass HistogramGeom : BarGeom() {\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//                //Aes.WEIGHT,    // ToDo: this is actually handled by 'stat' (bin,count)\n//                Aes.WIDTH,\n//                Aes.SIZE\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.vis.svg.SvgImageElement\n\n/**\n * Creates SvgImageElement and assign 'imageUrl' value to 'href' attribute.\n */\nclass ImageGeom(private val imageUrl: String) : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        if (aesthetics.isEmpty) return\n        val p = aesthetics.dataPointAt(0)\n        val boundsAes = DoubleRectangle.span(\n                DoubleVector(p.xmin()!!, p.ymin()!!),\n                DoubleVector(p.xmax()!!, p.ymax()!!))\n\n        // translate to client coordinates\n        val helper = GeomHelper(pos, coord, ctx)\n        val boundsClient = helper.toClient(boundsAes, p)\n\n        val svgImageElement = SvgImageElement(\n            boundsClient.origin.x, boundsClient.origin.y,\n            boundsClient.dimension.x, boundsClient.dimension.y\n        )\n        svgImageElement.href().set(imageUrl)\n        root.add(svgImageElement)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.XMIN,\n//                Aes.XMAX,\n//                Aes.YMIN,\n//                Aes.YMAX\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass JitterGeom : PointGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = PointGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PointGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\n\nopen class LineGeom : PathGeom() {\n\n    override fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.ordered_X(super.dataPoints(aesthetics))\n    }\n\n    companion object {\n//        val RENDERS = PathGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PathGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport kotlin.math.max\n\nclass LineRangeGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = VLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.YMIN, Aes.YMAX)) {\n            val x = p.x()!!\n            val ymin = p.ymin()!!\n            val ymax = p.ymax()!!\n\n            val start = DoubleVector(x, ymin)\n            val end = DoubleVector(x, ymax)\n            val line = helper.createLine(start, end, p)\n            root.add(line)\n        }\n\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        fun rectangleByDataPoint(): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.YMIN) &&\n                    p.defined(Aes.YMAX)\n                ) {\n                    val x = p.x()!!\n                    val ymin = p.ymin()!!\n                    val ymax = p.ymax()!!\n                    val width = max(AesScaling.strokeWidth(p), 2.0) * 2.0\n                    val height = ymax - ymin\n\n                    val origin = DoubleVector(x - width / 2, ymax - height / 2)\n                    val dimensions = DoubleVector(width, 0.0 )\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.GenericLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\n\nclass LiveMapGeom(private val myDisplayMode: DisplayMode) : Geom {\n    private lateinit var myMapProvider: LiveMapProvider\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() {\n            return when (myDisplayMode) {\n                DisplayMode.POINT -> PointLegendKeyElementFactory()\n                DisplayMode.PIE -> FilledCircleLegendKeyElementFactory()\n                else -> GenericLegendKeyElementFactory()\n            }\n        }\n\n    override fun build(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        throw IllegalStateException(\"Not applicable to live map\")\n    }\n\n    fun setLiveMapProvider(liveMapProvider: LiveMapProvider) {\n        myMapProvider = liveMapProvider\n    }\n\n    fun createCanvasFigure(bounds: DoubleRectangle): LiveMapProvider.LiveMapData {\n        return myMapProvider.createLiveMap(bounds)\n    }\n\n    companion object {\n\n        // ToDo: not static, depends on 'display mode'\n//        val RENDERS = listOf(\n//                Aes.ALPHA,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.SIZE,\n//                Aes.SHAPE,\n//                Aes.FRAME,\n//                Aes.X,\n//                Aes.Y\n//        )\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\n\ninterface LiveMapProvider {\n    fun createLiveMap(bounds: DoubleRectangle): LiveMapData\n\n    class LiveMapData(\n        val canvasFigure: SomeFig,\n        val targetLocator: GeomTargetLocator\n    )\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass MapGeom : PolygonGeom() {\n    companion object {\n//        val RENDERS = listOf(\n//\n//                // auto-wired to 'x' or 'long' and to 'y' or 'lat'\n//                Aes.X,\n//                Aes.Y,\n//\n//                Aes.SIZE, // path width\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinePathConstructor\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nopen class PathGeom : GeomBase() {\n\n    var animation: Any? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    protected open fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X_Y(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n\n        val dataPoints = dataPoints(aesthetics)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val linesHelper = LinesHelper(pos, coord, ctx)\n\n        val geomConstructor = LinePathConstructor(\n            targetCollector,\n            dataPoints,\n            linesHelper,\n            false\n        )\n        appendNodes(\n            geomConstructor.construct(withHints = false),\n            root\n        )\n        buildHints(aesthetics, coord, linesHelper, targetCollector)\n    }\n\n    private fun buildHints(\n        aesthetics: Aesthetics,\n        coord: CoordinateSystem,\n        linesHelper: LinesHelper,\n        targetCollector: GeomTargetCollector\n    ) {\n        val dataPoints = dataPoints(aesthetics).filter { p ->\n            val x = p.x()\n            val y = p.y()\n            SeriesUtil.allFinite(x, y) && coord.isPointInLimits(DoubleVector(x!!,y!!), isClient = false)\n        }\n\n        LinePathConstructor(\n            targetCollector,\n            dataPoints,\n            linesHelper,\n            false\n        ).buildHints()\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.get\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.LinePath\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport kotlin.math.PI\n\n/**\n * This is working code but wasn't included to ggplot.\n * Mostly exists to preserve this code.\n */\ninternal class PieGeom(private val myCenter: DoubleVector, private val myRadius: Double) : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val helper = PieHelper(pos, coord, ctx)\n        val segments = helper.createSegments(aesthetics, myCenter, myRadius)\n        appendNodes(segments, root)\n    }\n\n    private class PieHelper internal constructor(pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) : LinesHelper(pos, coord, ctx) {\n\n        internal fun createSegments(aesthetics: Aesthetics, center: DoubleVector, radius: Double): List<LinePath> {\n            val result = ArrayList<LinePath>()\n\n            //DoubleVector basis = new Point(radius, 0);  // x\n            val basis = DoubleVector(0.0, -radius)   // y\n\n            var curAngle = Double.NaN\n            for (p in dataPoints(aesthetics)) {\n                val segmentSize =\n                    shareToRad(p.y()!!)\n\n                // for better presentation: first segment lays to the right of 12 o'clock, and all\n                // segments are added counterclockwise.\n                if (curAngle.isNaN()) {\n                    curAngle = segmentSize\n                }\n\n                // we use negative angles because of screen coordinates and counterclockwise order of segments\n                val angle = -segmentSize\n\n                val builder = SvgPathDataBuilder(true)\n                builder.moveTo(center)\n                builder.lineTo(center.add(basis.rotate(curAngle)))\n                val arcTo = center.add(basis.rotate(curAngle + angle))\n                builder.ellipticalArc(radius, radius, 0.0, -angle > PI, false, arcTo)\n                builder.closePath()\n\n                curAngle += angle\n\n                val path = LinePath(builder)\n                decorate(path, p, true)\n                result.add(path)\n            }\n\n            return result\n        }\n    }\n\n    companion object {\n        val RENDERS = listOf(\n                Aes.X, // optional, can specify order of segments in pie\n                Aes.Y, // angle width of segments\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                Aes.WIDTH,\n                Aes.SIZE\n        )\n\n        const val HANDLES_GROUPS = false\n\n        private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n            val withX = GeomUtil.with_X_Y(aesthetics.dataPoints())\n            return if (Iterables.isEmpty(withX) || allEqualX(\n                    withX,\n                    get(withX, 0).x()\n                )\n            ) {\n                GeomUtil.ordered_Y(GeomUtil.with_Y(aesthetics.dataPoints()), true)\n            } else GeomUtil.ordered_X(withX)\n        }\n\n        private fun allEqualX(hasX: Iterable<DataPointAesthetics>, `val`: Double?): Boolean {\n            for (p in hasX) {\n                if (p.x() != `val`) {\n                    return false\n                }\n            }\n            return true\n        }\n\n        private fun shareToRad(share: Double): Double {\n            // don't allow sum to be more than 99.99 % of full circle (otherwise arc will disappear)\n            return 0.9999 * 2.0 * PI * share\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColorValue\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\nopen class PointGeom : GeomBase() {\n\n    var animation: Any? = null\n    var sizeUnit: String? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = PointLegendKeyElementFactory()\n\n    public override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val targetCollector = getGeomTargetCollector(ctx)\n\n        val count = aesthetics.dataPointCount()\n        val slimGroup = SvgSlimElements.g(count)\n        val sizeUnitRatio = getSizeUnitRatio(ctx)\n\n        for (i in 0 until count) {\n            val p = aesthetics.dataPointAt(i)\n            val x = p.x()\n            val y = p.y()\n\n            if (SeriesUtil.allFinite(x, y)) {\n                val location = helper.toClient(DoubleVector(x!!, y!!), p)\n\n                val shape = p.shape()!!\n\n                targetCollector.addPoint(\n                    i, location, sizeUnitRatio * shape.size(p) / 2,\n                    tooltipParams(p)\n                )\n                val o = PointShapeSvg.create(shape, location, p, sizeUnitRatio)\n                o.appendTo(slimGroup)\n            }\n        }\n        root.add(wrap(slimGroup))\n    }\n\n    private fun getSizeUnitRatio(ctx: GeomContext): Double {\n        return if (sizeUnit != null) {\n            val unitRes = ctx.getUnitResolution(GeomHelper.getSizeUnitAes(sizeUnit!!))\n            // TODO: Need refactoring: It's better to use NamedShape.FILLED_CIRCLE.size(1.0)\n            // but Shape.size() can't be used because it takes DataPointAesthetics as param\n            unitRes / AesScaling.UNIT_SHAPE_SIZE\n        } else {\n            1.0\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        fun tooltipParams(p: DataPointAesthetics): TooltipParams {\n            var color = Color.TRANSPARENT\n            if (p.shape() == TinyPointShape) {\n                color = p.color()!!\n            } else if (p.shape() is NamedShape) {\n                val shape = p.shape() as NamedShape\n                color = AestheticsUtil.fill(shape.isFilled, shape.isSolid, p)\n            }\n\n            return params().setColor(fromColorValue(color, p.alpha()!!))\n        }\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninternal class PointLegendKeyElementFactory(private val fatten: Double = 1.0) :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val location = DoubleVector(size.x / 2, size.y / 2)\n        val shape = p.shape()!!\n        val slimObject = PointShapeSvg.create(shape, location, p, fatten)\n        return GeomBase.Companion.wrap(slimObject)\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val shape = p.shape()!!\n        val shapeSize = shape.size(p) * fatten\n        val strokeWidth = shape.strokeWidth(p)\n        val size = shapeSize + strokeWidth + 2.0\n        return DoubleVector(size, size)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.CompositeLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.legend.VLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\n\nclass PointRangeGeom : GeomBase() {\n    var fattenMidPoint: Double =\n        DEF_FATTEN\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = CompositeLegendKeyElementFactory(\n            VLineLegendKeyElementFactory(),\n            PointLegendKeyElementFactory(DEF_FATTEN)\n        )\n\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.Y, Aes.YMIN, Aes.YMAX)) {\n            val x = p.x()!!\n            val y = p.y()!!\n            val ymin = p.ymin()!!\n            val ymax = p.ymax()!!\n\n            // vertical line\n            val start = DoubleVector(x, ymin)\n            val end = DoubleVector(x, ymax)\n            val line = helper.createLine(start, end, p)\n            root.add(line)\n\n            // mid-point\n            val location = geomHelper.toClient(DoubleVector(x, y), p)\n            val shape = p.shape()!!\n            val o = PointShapeSvg.create(shape, location, p, fattenMidPoint)\n            root.add(wrap(o))\n//            ctx.targetCollector.addPoint(\n//                p.index(),\n//                location,\n//                shape.size(p) * fattenMidline / 2,\n//                PointGeom.tooltipParams(p)\n//            )\n        }\n\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(fattenMidPoint),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        const val DEF_FATTEN = 5.0\n\n        fun rectangleByDataPoint(fatten: Double): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.Y)\n                ) {\n                    val x = p.x()!!\n                    val y = p.y()!!\n\n                    val shape = p.shape()!!\n                    val shapeSize = shape.size(p) * fatten\n                    val strokeWidth = shape.strokeWidth(p)\n                    val width = shapeSize + strokeWidth\n\n                    val origin = DoubleVector(x - width / 2, y)\n                    val dimensions = DoubleVector(width, 0.0)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinePathConstructor\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nopen class PolygonGeom : GeomBase() {\n\n    protected fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X_Y(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val dataPoints = dataPoints(aesthetics)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val linesHelper = LinesHelper(pos, coord, ctx)\n\n        val geomConstructor =\n            LinePathConstructor(\n                targetCollector,\n                dataPoints,\n                linesHelper,\n                true\n            )\n        appendNodes(\n            geomConstructor.construct(withHints = true),\n            root\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.with_X_Y\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgImageElementEx\nimport jetbrains.datalore.vis.svg.SvgImageElementEx.Bitmap\nimport jetbrains.datalore.vis.svg.SvgUtils\nimport kotlin.math.abs\nimport kotlin.math.min\nimport kotlin.math.round\n\nclass RasterGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = FilledSquareLegendKeyElementFactory()\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val iter = with_X_Y(aesthetics.dataPoints()).iterator()\n        if (!iter.hasNext()) {\n            return\n        }\n        val randomP = iter.next()\n        val helper = GeomHelper(pos, coord, ctx)\n\n        // Find size of image (row x col)\n        val boundsXY =\n            aesBoundingBox(aesthetics)\n        val stepX = ctx.getResolution(Aes.X)\n        val stepY = ctx.getResolution(Aes.Y)\n        require(stepX > SeriesUtil.TINY) { \"x-step is too small: $stepX\" }\n        require(stepY > SeriesUtil.TINY) { \"y-step is too small: $stepY\" }\n        val width = (round(boundsXY.dimension.x / stepX) + 1)\n        val height = (round(boundsXY.dimension.y / stepY) + 1)\n\n        if (width * height > 5000000) {\n            val center = boundsXY.center\n            val lines =\n                arrayOf(\"Raster image size\", \"[$width X $height]\", \"exceeds capability\", \"of\", \"your imaging device\")\n            val fontSize = 12.0\n            val lineHeight = fontSize + 4\n            var y = center.y + lineHeight * lines.size / 2.0\n            for (line in lines) {\n                val label = TextLabel(line)\n                label.textColor().set(Color.DARK_MAGENTA)\n                label.textOpacity().set(0.5)\n                label.setFontSize(fontSize)\n                label.setFontWeight(\"bold\")\n                label.setHorizontalAnchor(HorizontalAnchor.MIDDLE)\n                label.setVerticalAnchor(VerticalAnchor.CENTER)\n                val loc = helper.toClient(center.x, y, randomP)\n                label.moveTo(loc)\n                root.add(label.rootGroup)\n                y -= lineHeight\n            }\n\n            return\n        }\n\n        val cols = round(width).toInt()\n        val rows = round(height).toInt()\n\n        // translate to client coordinates\n        // expand bounds by 1/2 step before the translation to adjust for the size of 'image pixel'\n        val halfStep = DoubleVector(stepX * 0.5, stepY * 0.5)\n        val corner0 = helper.toClient(boundsXY.origin.subtract(halfStep), randomP)\n        val corner2 = helper.toClient(boundsXY.origin.add(boundsXY.dimension).add(halfStep), randomP)\n        val invertedX = corner2.x < corner0.x\n        val invertedY = corner2.y < corner0.y\n\n        // Fill image data array with RGB values\n        val x0 = boundsXY.origin.x\n        val y0 = boundsXY.origin.y\n\n        val argbValues = IntArray(cols * rows)\n        for (p in with_X_Y(aesthetics.dataPoints())) {\n            val x = p.x()\n            val y = p.y()\n            val alpha = p.alpha()\n            val color = p.fill()\n\n            var col = round((x!! - x0) / stepX).toInt()\n            var row = round((y!! - y0) / stepY).toInt()\n\n            if (invertedX) {\n                col = cols - (col + 1)\n            }\n\n            if (invertedY) {\n                row = rows - (row + 1)\n            }\n\n            argbValues[row * cols + col] = SvgUtils.toARGB(color!!, alpha!!)\n        }\n\n        val bitmap = Bitmap(cols, rows, argbValues)\n        val svgImageElement = SvgImageElementEx(\n            min(corner0.x, corner2.x), min(corner0.y, corner2.y),\n            abs(corner0.x - corner2.x), abs(corner0.y - corner2.y),\n            bitmap\n        )\n        root.add(svgImageElement)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.WIDTH, // not rendered but required for correct x aes range computation\n//                Aes.HEIGHT, // -- the same --\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}// ToDo: hjust, vjust [0..1] def .5\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectTargetCollectorHelper\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.CURSOR_TOOLTIP\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass RectGeom : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        helper.createRectangles(Companion::rectangleByDataPoint).forEach(root::add)\n        RectTargetCollectorHelper(\n            rectanglesHelper = helper,\n            rectangleByDataPoint = Companion::rectangleByDataPoint,\n            fillByDataPoint = HintColorUtil::fromFill,\n            tooltipKind = CURSOR_TOOLTIP\n        ).collectTo(ctx.targetCollector)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.XMIN,\n//                Aes.XMAX,\n//                Aes.YMIN,\n//                Aes.YMAX,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//        )\n        //rectangle groups are used in geom_livemap\n        const val HANDLES_GROUPS = true\n\n        private fun rectangleByDataPoint(p: DataPointAesthetics): DoubleRectangle? {\n            val xmin = p.xmin()\n            val xmax = p.xmax()\n            val ymin = p.ymin()\n            val ymax = p.ymax()\n            return if (SeriesUtil.allFinite(xmin, xmax, ymin, ymax)) {\n                DoubleRectangle.span(DoubleVector(xmin!!, ymin!!), DoubleVector(xmax!!, ymax!!))\n            }\n            else {\n                null\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass RibbonGeom : GeomBase() {\n\n    private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        val data = GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.YMIN, Aes.YMAX)\n        return GeomUtil.ordered_X(data)\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n        val helper = LinesHelper(pos, coord, ctx)\n        val paths = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_YMAX, GeomUtil.TO_LOCATION_X_YMIN)\n        appendNodes(paths, root)\n\n        //if you want to retain the side edges of ribbon: comment out the following codes, and switch decorate method in LinesHelper.createbands\n        helper.setAlphaEnabled(false)\n        val lines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_YMAX)\n        lines.addAll(helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_YMIN))\n        appendNodes(lines, root)\n\n        buildHints(aesthetics, pos, coord, ctx)\n    }\n\n    private fun buildHints(aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val targetCollector = ctx.targetCollector\n        val helper = GeomHelper(pos, coord, ctx)\n        for (p in aesthetics.dataPoints()) {\n            addTarget(p, targetCollector, GeomUtil.TO_LOCATION_X_YMAX, helper)\n        }\n    }\n\n    private fun addTarget(\n        p: DataPointAesthetics,\n        collector: GeomTargetCollector,\n        toLocation: (DataPointAesthetics) -> DoubleVector?,\n        helper: GeomHelper\n    ) {\n        val coord = toLocation(p)\n        if (coord != null) {\n            val hint = HintsCollection.HintConfigFactory()\n                .defaultObjectRadius(0.0)\n                .defaultX(p.x()!!)\n                .defaultKind(TipLayoutHint.Kind.HORIZONTAL_TOOLTIP)\n                .defaultColor(\n                    p.fill()!!,\n                    alpha = null\n                )\n\n            val hintsCollection = HintsCollection(p, helper)\n                .addHint(hint.create(Aes.YMAX))\n                .addHint(hint.create(Aes.YMIN))\n\n            collector.addPoint(\n                p.index(),\n                helper.toClient(coord, p),\n                0.0,\n                params().setTipLayoutHints(hintsCollection.hints)\n            )\n        }\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.YMIN,\n//                Aes.YMAX,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.ArrowSpec\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper.Companion.decorate\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.PI\nimport kotlin.math.atan2\n\nclass SegmentGeom : GeomBase() {\n\n    var arrowSpec: ArrowSpec? = null\n    var animation: Any? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val targetCollector = getGeomTargetCollector(ctx)\n        val helper = GeomHelper(pos, coord, ctx)\n            .createSvgElementHelper()\n\n        for (p in aesthetics.dataPoints()) {\n            if (SeriesUtil.allFinite(p.x(), p.y(), p.xend(), p.yend())) {\n                val start = DoubleVector(p.x()!!, p.y()!!)\n                val end = DoubleVector(p.xend()!!, p.yend()!!)\n                val line = helper.createLine(start, end, p)\n                root.add(line)\n\n                targetCollector.addPath(\n                    listOf(coord.toClient(start), coord.toClient(end)),\n                    { p.index() },\n                    GeomTargetCollector.TooltipParams.params()\n                        .setColor(HintColorUtil.fromColor(p))\n                )\n\n                if (arrowSpec != null) {\n                    val clientX1 = line.x1().get()!!\n                    val clientY1 = line.y1().get()!!\n                    val clientX2 = line.x2().get()!!\n                    val clientY2 = line.y2().get()!!\n\n                    val abscissa = clientX2 - clientX1\n                    val ordinate = clientY2 - clientY1\n                    if (abscissa != 0.0 || ordinate != 0.0) {\n                        // Compute the angle that the vector defined by this segment makes with the\n                        // X-axis (radians)\n                        val polarAngle = atan2(ordinate, abscissa)\n\n                        val arrowAes = arrowSpec!!.toArrowAes(p)\n                        if (arrowSpec!!.isOnLastEnd) {\n                            val arrow = arrowSpec!!.createElement(polarAngle, clientX2, clientY2)\n                            decorate(arrow, arrowAes)\n                            root.add(arrow)\n                        }\n                        if (arrowSpec!!.isOnFirstEnd) {\n                            val arrow = arrowSpec!!.createElement(polarAngle + PI, clientX1, clientY1)\n                            decorate(arrow, arrowAes)\n                            root.add(arrow)\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.ordered_X\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.with_X_Y\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.HORIZONTAL_TOOLTIP\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass SmoothGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val dataPoints = ordered_X(with_X_Y(aesthetics.dataPoints()))\n        val helper = LinesHelper(pos, coord, ctx)\n\n        // Regression line\n        helper.setAlphaEnabled(false)\n        val regressionLines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_Y)\n        appendNodes(regressionLines, root)\n\n        // Confidence interval\n        helper.setAlphaFilter(PROPORTION)\n        helper.setWidthFilter(ZERO)\n        val bands = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_YMAX, GeomUtil.TO_LOCATION_X_YMIN)\n        appendNodes(bands, root)\n\n        buildHints(dataPoints, pos, coord, ctx)\n    }\n\n    private fun buildHints(\n        dataPoints: Iterable<DataPointAesthetics>,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n\n        for (p in dataPoints) {\n            val xCoord = p.x()!!\n            val objectRadius = 0.0\n\n            val hint = HintConfigFactory()\n                .defaultObjectRadius(objectRadius)\n                .defaultX(xCoord)\n                .defaultKind(HORIZONTAL_TOOLTIP)\n                .defaultColor(\n                    p.fill()!!,\n                    PROPORTION(p.alpha())\n                )\n\n            val hintsCollection = HintsCollection(p, helper)\n                .addHint(hint.create(Aes.YMAX))\n                .addHint(hint.create(Aes.YMIN))\n                .addHint(hint.create(Aes.Y).color(p.color()!!))\n\n            val clientCoord = helper.toClient(p.x(), p.y(), p)\n            ctx.targetCollector.addPoint(\n                p.index(), clientCoord, objectRadius,\n                params()\n                    .setTipLayoutHints(hintsCollection.hints)\n            )\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n\n        private val PROPORTION = { v: Double? -> if (v == null) null else v / 10 }\n        private val ZERO = { _: Double? -> 0.0 }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass StepGeom : LineGeom() {\n    private var myDirection = DEF_DIRECTION\n\n    fun setDirection(dir: String) {\n        myDirection = Direction.toDirection(dir)\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n        val helper = LinesHelper(pos, coord, ctx)\n        val pathInfos = helper.createSteps(dataPoints, myDirection)\n        for (pathInfo in pathInfos) {\n            root.add(pathInfo.path.rootGroup)\n        }\n    }\n\n    enum class Direction {\n        HV, VH;\n\n\n        companion object {\n\n            fun toDirection(str: String): Direction {\n                return when (str) {\n                    \"hv\", \"HV\" -> HV\n                    \"vh\", \"VH\" -> VH\n                    else -> throw IllegalArgumentException(\"Direction $str is not allowed, only accept 'hv' or 'vh'\")\n                }\n            }\n        }\n    }\n\n    companion object {\n        // default\n        val DEF_DIRECTION = Direction.HV\n//        val RENDERS = LineGeom.RENDERS\n        const  val HANDLES_GROUPS =\n    LineGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass TextGeom : GeomBase() {\n    var formatter: StringFormat? = null\n    var naValue = DEF_NA_VALUE\n    var sizeUnit: String? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = TextLegendKeyElementFactory()\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val sizeUnitRatio = getSizeUnitRatio(ctx)\n        for (p in aesthetics.dataPoints()) {\n            val x = p.x()\n            val y = p.y()\n            val text = toString(p.label())\n            if (SeriesUtil.allFinite(x, y) && !Strings.isNullOrEmpty(text)) {\n                val label = TextLabel(text)\n                GeomHelper.decorate(label, p, sizeUnitRatio)\n\n                val loc = helper.toClient(x, y, p)\n                label.moveTo(loc)\n                root.add(label.rootGroup)\n\n                // The geom_text tooltip is similar to the geom_tile:\n                // it looks better when the text is on a tile in corr_plot (but the color will be different from the geom_tile tooltip)\n                targetCollector.addPoint(\n                    p.index(),\n                    loc,\n                    sizeUnitRatio * AesScaling.textSize(p) / 2,\n                    GeomTargetCollector.TooltipParams.params()\n                        .setColor(HintColorUtil.fromColor(p)),\n                    TipLayoutHint.Kind.CURSOR_TOOLTIP\n                )\n            }\n        }\n    }\n\n    // This implementation is oversimplified.\n    // Current implementation works for label_format ='.2f'\n    // and values between -1.0 and 1.0.\n    private fun getSizeUnitRatio(ctx: GeomContext): Double {\n        return if ( sizeUnit != null)  {\n            val textWidth = 6.0\n            val unitRes = ctx.getUnitResolution(GeomHelper.getSizeUnitAes(sizeUnit!!))\n            unitRes / textWidth\n        } else {\n            1.0\n        }\n    }\n\n    private fun toString(label: Any?): String {\n        return when {\n            label == null -> naValue\n            formatter != null -> formatter!!.format(label)\n            else -> label.toString()\n        }\n    }\n\n    companion object {\n        const val DEF_NA_VALUE = \"n/a\"\n        const val HANDLES_GROUPS = false\n    }\n}\n\n// How 'just' and 'angle' works together\n// https://stackoverflow.com/questions/7263849/what-do-hjust-and-vjust-do-when-making-a-plot-using-ggplot\n// ToDo: lineheight (aes)\n// ToDo: nudge_x, nudge_y\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninternal class TextLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val label = TextLabel(\"a\")\n        GeomHelper.decorate(label, p)\n        label.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n        label.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n        label.moveTo(size.x / 2, size.y / 2)\n        val g = SvgGElement()\n        g.children().add(label.rootGroup)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(4.0, strokeWidth + 4)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectTargetCollectorHelper\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * geom_tile uses the center of the tile and its size (x, y, width, height).\n */\nopen class TileGeom : GeomBase() {\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val slimGroup = helper.createSlimRectangles(\n            rectangleByDataPoint(ctx)\n        )\n        root.add(wrap(slimGroup))\n\n        RectTargetCollectorHelper(\n            helper,\n            rectangleByDataPoint(ctx),\n            { p: DataPointAesthetics ->\n                HintColorUtil.fromFill(\n                    p\n                )\n            },\n            TipLayoutHint.Kind.CURSOR_TOOLTIP\n        )\n            .collectTo(ctx.targetCollector)\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                val x = p.x()\n                val y = p.y()\n                val w = p.width()\n                val h = p.height()\n\n                var rect: DoubleRectangle? = null\n                if (SeriesUtil.allFinite(x, y, w, h)) {\n                    val width = w!! * ctx.getResolution(Aes.X)\n                    val height = h!! * ctx.getResolution(Aes.Y)\n\n                    val origin = DoubleVector(x!! - width / 2, y!! - height / 2)\n                    val dimensions = DoubleVector(width, height)\n                    rect = DoubleRectangle(origin, dimensions)\n                }\n                rect\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.legend.VLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport kotlin.math.max\n\nclass VLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.interceptX()\n            if (SeriesUtil.isFinite(intercept)) {\n                if (viewPort.xRange().contains(intercept!!)) {\n                    val start = DoubleVector(intercept, viewPort.top)\n                    val end = DoubleVector(intercept, viewPort.bottom)\n                    val line = helper.createLine(start, end, p)\n                    lines.add(line)\n\n                    val width = max(AesScaling.strokeWidth(p), 2.0) * 2.0\n                    val origin = DoubleVector(intercept - width / 2, end.y)\n                    val dimensions = DoubleVector(width, 0.0)\n                    val rect = DoubleRectangle(origin, dimensions)\n                    ctx.targetCollector.addRectangle(\n                        p.index(),\n                        geomHelper.toClient(rect, p),\n                        GeomTargetCollector.TooltipParams.params()\n                            .setColor(HintColorUtil.fromColor(p))\n                    )\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n        val LEGEND_KEY_ELEMENT_FACTORY: LegendKeyElementFactory =\n            VLineLegendKeyElementFactory()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport kotlin.math.max\n\nclass CompositeLegendKeyElementFactory(vararg factories: LegendKeyElementFactory) :\n    LegendKeyElementFactory {\n    private val factories = factories\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n        for (factory in factories) {\n            g.children().add(factory.createKeyElement(p, size))\n        }\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n//        var minWidth = 0.0\n//        var minHeight = 0.0\n//        for (factory in factories) {\n//            val keySize = factory.minimumKeySize(p)\n//            minWidth = max(minWidth, keySize.x)\n//            minHeight = max(minHeight, keySize.y)\n//        }\n//        return DoubleVector(minWidth, minHeight)\n        return super.minimumKeySize(p)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nclass GenericLegendKeyElementFactory : LegendKeyElementFactory {\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        // background rect (to show fill)\n        val rect = SvgRectElement(0.0, 0.0, size.x, size.y)\n        AestheticsUtil.updateFill(rect, p)\n\n        // slash-line (to show stroke)\n        val line = SvgLineElement(0.0, size.y, size.x, 0.0)\n        GeomHelper.decorate(line, p)\n\n        val g = SvgGElement()\n        g.children().add(rect)\n        g.children().add(line)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\ninternal class HLineLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val line = SvgLineElement(0.0, size.y / 2, size.x, size.y / 2)\n        GeomHelper.decorate(line, p)\n        val g = SvgGElement()\n        g.children().add(line)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(4.0, strokeWidth + 4)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\ninternal class VLineLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val line = SvgLineElement(size.x / 2, 0.0, size.x / 2, size.y)\n        GeomHelper.decorate(line, p)\n        val g = SvgGElement()\n        g.children().add(line)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(strokeWidth + 4, 4.0)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport jetbrains.datalore.vis.svg.SvgPathElement\nimport kotlin.math.cos\nimport kotlin.math.sin\n\nclass ArrowSpec\n/**\n * @param angle  The angle of the arrow head in radians (smaller numbers produce narrower, pointier arrows).\n * Essentially describes the width of the arrow head.\n * @param length The length of the arrow head (px).\n */\n(val angle: Double, val length: Double, val end: End, val type: Type) {\n\n    val isOnFirstEnd: Boolean\n        get() = end == End.FIRST || end == End.BOTH\n\n    val isOnLastEnd: Boolean\n        get() = end == End.LAST || end == End.BOTH\n\n    /**\n     * @param polarAngle Angle between X-axis and the arrowed vector.\n     */\n    fun createElement(polarAngle: Double, x: Double, y: Double): SvgPathElement {\n        val xs = doubleArrayOf(x - length * cos(polarAngle - angle), x, x - length * cos(polarAngle + angle))\n        val ys = doubleArrayOf(y - length * sin(polarAngle - angle), y, y - length * sin(polarAngle + angle))\n\n        val b = SvgPathDataBuilder(true)\n                .moveTo(xs[0], ys[0])\n\n        for (i in 1..2) {\n            b.lineTo(xs[i], ys[i], true)\n        }\n\n        if (type == Type.CLOSED) {\n            b.closePath()\n        }\n\n        return SvgPathElement(b.build())\n    }\n\n    fun toArrowAes(p: DataPointAesthetics): DataPointAesthetics {\n        return object : DataPointAestheticsDelegate(p) {\n            private val myFilled = type == Type.CLOSED\n\n            override fun fill(): Color? {\n                return if (myFilled) {\n                    color()\n                } else Color.TRANSPARENT\n            }\n\n            override fun lineType(): LineType {\n                return if (myFilled) {\n                    NamedLineType.SOLID // avoid ugly patterns if linetype is other than 'solid'\n                } else super.lineType()\n            }\n        }\n    }\n\n    enum class End {\n        LAST, FIRST, BOTH\n    }\n\n    enum class Type {\n        OPEN, CLOSED\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nobject BarTooltipHelper {\n    fun collectRectangleTargets(\n        hintAesList: List<Aes<Double>>,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        rectFactory: (DataPointAesthetics) -> DoubleRectangle?,\n        colorFactory: (DataPointAesthetics) -> Color\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n\n        for (p in aesthetics.dataPoints()) {\n            val rect = rectFactory(p) ?: continue\n\n            val clientRect = helper.toClient(DoubleRectangle(0.0, 0.0, rect.width, 0.0), p)\n            val objectRadius = clientRect.width / 2.0\n\n            val xCoord = rect.center.x\n            val hintFactory = HintsCollection.HintConfigFactory()\n                .defaultObjectRadius(objectRadius)\n                .defaultX(xCoord)\n                .defaultKind(TipLayoutHint.Kind.HORIZONTAL_TOOLTIP)\n\n            val hintConfigs = hintAesList\n                .fold(HintsCollection(p, helper)) { acc, aes ->\n                    acc.addHint(hintFactory.create(aes))\n                }\n\n            ctx.targetCollector.addRectangle(\n                p.index(),\n                helper.toClient(rect, p),\n                GeomTargetCollector.TooltipParams.params()\n                    .setTipLayoutHints(hintConfigs.hints)\n//                    .setColor(HintColorUtil.fromColor(p))\n                    .setColor(colorFactory(p))\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nobject CrossBarHelper {\n    fun buildBoxes(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        rectFactory: (DataPointAesthetics) -> DoubleRectangle?\n    ) {\n        // rectangles\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val rectangles = helper.createRectangles(rectFactory)\n        rectangles.forEach { root.add(it) }\n    }\n\n    fun buildMidlines(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        fatten: Double\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val elementHelper = helper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(\n            aesthetics.dataPoints(),\n            Aes.X,\n            Aes.WIDTH,\n            Aes.MIDDLE\n        )) {\n            val x = p.x()!!\n            val middle = p.middle()!!\n            val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n            val line = elementHelper.createLine(\n                DoubleVector(x - width / 2, middle),\n                DoubleVector(x + width / 2, middle),\n                p\n            )\n\n            // adjust thickness\n            val thickness = line.strokeWidth().get()!!\n            line.strokeWidth().set(thickness * fatten)\n\n            root.add(line)\n        }\n    }\n\n    fun legendFactory(whiskers: Boolean): LegendKeyElementFactory =\n        CrossBarLegendKeyElementFactory(whiskers)\n}\n\nprivate class CrossBarLegendKeyElementFactory(val whiskers: Boolean) :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val whiskerSize = .2\n\n        val strokeWidth = AesScaling.strokeWidth(p)\n        val width = (size.x - strokeWidth) * .8 // a bit narrower\n        val height = size.y - strokeWidth\n        val x = (size.x - width) / 2\n        val y = strokeWidth / 2\n\n\n        // box\n        var boxHeight = height\n        var boxY = y\n        if (whiskers) {\n            boxHeight = height * (1 - 2 * whiskerSize)\n            boxY = y + height * whiskerSize\n        }\n\n        val rect = SvgRectElement(\n            x,\n            boxY,\n            width,\n            boxHeight\n        )\n        GeomHelper.decorate(rect, p)\n\n        // lines\n        val middleY = y + height * .5\n        val middle = SvgLineElement(x, middleY, x + width, middleY)\n        GeomHelper.decorate(middle, p)\n\n        val g = SvgGElement()\n        g.children().add(rect)\n        g.children().add(middle)\n\n        if (whiskers) {\n            val middleX = x + width * .5\n            val lowerWhisker =\n                SvgLineElement(middleX, y + height * (1 - whiskerSize), middleX, y + height)\n            GeomHelper.decorate(lowerWhisker, p)\n            val upperWhisker = SvgLineElement(middleX, y, middleX, y + height * whiskerSize)\n            GeomHelper.decorate(upperWhisker, p)\n            g.children().add(lowerWhisker)\n            g.children().add(upperWhisker)\n        }\n\n        return g\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\nopen class DataPointAestheticsDelegate(private val p: DataPointAesthetics) :\n    DataPointAesthetics {\n\n    override fun index(): Int {\n        return p.index()\n    }\n\n    override fun x(): Double? {\n        return p.x()\n    }\n\n    override fun y(): Double? {\n        return p.y()\n    }\n\n    override fun z(): Double? {\n        return p.z()\n    }\n\n    override fun ymin(): Double? {\n        return p.ymin()\n    }\n\n    override fun ymax(): Double? {\n        return p.ymax()\n    }\n\n    override fun color(): Color? {\n        return p.color()\n    }\n\n    override fun fill(): Color? {\n        return p.fill()\n    }\n\n    override fun alpha(): Double? {\n        return p.alpha()\n    }\n\n    override fun shape(): PointShape? {\n        return p.shape()\n    }\n\n    override fun lineType(): LineType {\n        return p.lineType()\n    }\n\n    override fun size(): Double? {\n        return p.size()\n    }\n\n    override fun width(): Double? {\n        return p.width()\n    }\n\n    override fun height(): Double? {\n        return p.height()\n    }\n\n    override fun weight(): Double? {\n        return p.weight()\n    }\n\n    override fun intercept(): Double? {\n        return p.intercept()\n    }\n\n    override fun slope(): Double? {\n        return p.slope()\n    }\n\n    override fun interceptX(): Double? {\n        return p.interceptX()\n    }\n\n    override fun interceptY(): Double? {\n        return p.interceptY()\n    }\n\n    override fun lower(): Double? {\n        return p.lower()\n    }\n\n    override fun middle(): Double? {\n        return p.middle()\n    }\n\n    override fun upper(): Double? {\n        return p.upper()\n    }\n\n    override fun frame(): String {\n        return p.frame()\n    }\n\n    override fun speed(): Double? {\n        return p.speed()\n    }\n\n    override fun flow(): Double? {\n        return p.flow()\n    }\n\n    override fun xmin(): Double? {\n        return p.xmin()\n    }\n\n    override fun xmax(): Double? {\n        return p.xmax()\n    }\n\n    override fun xend(): Double? {\n        return p.xend()\n    }\n\n    override fun yend(): Double? {\n        return p.yend()\n    }\n\n    override fun label(): Any? {\n        return p.label()\n    }\n\n    override fun family(): String {\n        return p.family()\n    }\n\n    override fun fontface(): String {\n        return p.fontface()\n    }\n\n    override fun hjust(): Any {\n        return p.hjust()\n    }\n\n    override fun vjust(): Any {\n        return p.vjust()\n    }\n\n    override fun angle(): Double? {\n        return p.angle()\n    }\n\n    override fun symX(): Double? {\n        return p.symX()\n    }\n\n    override fun symY(): Double? {\n        return p.symY()\n    }\n\n    override fun group(): Int? {\n        return p.group()\n    }\n\n    override fun numeric(aes: Aes<Double>): Double? {\n        return p.numeric(aes)\n    }\n\n    override fun <T> get(aes: Aes<T>): T? {\n        return p[aes]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass GeomCoord(private val myCoord: CoordinateSystem) {\n\n    fun toClient(p: DoubleVector): DoubleVector {\n        return myCoord.toClient(p)\n    }\n\n    internal fun fromClient(location: DoubleVector): DoubleVector {\n        return myCoord.fromClient(location)\n    }\n\n    fun toClient(r: DoubleRectangle): DoubleRectangle {\n        return translateRect(r) { coord -> myCoord.toClient(coord) }\n    }\n\n    fun fromClient(r: DoubleRectangle): DoubleRectangle {\n        return translateRect(r) { coord -> myCoord.fromClient(coord) }\n    }\n\n    private fun translateRect(r: DoubleRectangle, toLocation: (DoubleVector) -> DoubleVector): DoubleRectangle {\n        @Suppress(\"NAME_SHADOWING\")\n        var r = r\n        val xy1 = r.origin\n        val xy2 = DoubleVector(r.right, r.bottom)\n\n        val xy1cl = toLocation(xy1)\n        val xy2cl = toLocation(xy2)\n        if (xy1 != xy1cl || xy2 != xy2cl) {\n            val xMin = min(xy1cl.x, xy2cl.x)\n            val yMin = min(xy1cl.y, xy2cl.y)\n            val xMax = max(xy1cl.x, xy2cl.x)\n            val yMax = max(xy1cl.y, xy2cl.y)\n\n            r = DoubleRectangle(xMin, yMin, xMax - xMin, yMax - yMin)\n        }\n        return r\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil.ALPHA_CONTROLS_BOTH\nimport jetbrains.datalore.plot.base.render.svg.StrokeDashArraySupport\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.SvgElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgShape\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nopen class GeomHelper(private val myPos: PositionAdjustment, coord: CoordinateSystem, protected val ctx: GeomContext) {\n    private val myGeomCoord: GeomCoord =\n        GeomCoord(coord)\n\n    fun toClient(location: DoubleVector, p: DataPointAesthetics): DoubleVector {\n        return myGeomCoord.toClient(adjust(location, p, myPos, ctx))\n    }\n\n    fun toClient(x: Double?, y: Double?, p: DataPointAesthetics): DoubleVector {\n        // ToDo: don't create new object (optimization)\n        val location = DoubleVector(x!!, y!!)\n        return myGeomCoord.toClient(adjust(location, p, myPos, ctx))\n    }\n\n    fun toClient(r: DoubleRectangle, p: DataPointAesthetics): DoubleRectangle {\n        var clientRect = myGeomCoord.toClient(adjust(r, p, myPos, ctx))\n        // do not allow zero height or width (shape becomes invisible)\n        if (clientRect.width == 0.0) {\n            clientRect = DoubleRectangle(clientRect.origin.x, clientRect.origin.y, 0.1, clientRect.height)\n        }\n        if (clientRect.height == 0.0) {\n            clientRect = DoubleRectangle(clientRect.origin.x, clientRect.origin.y, clientRect.width, 0.1)\n        }\n        return clientRect\n    }\n\n    fun fromClient(location: DoubleVector): DoubleVector {\n        return myGeomCoord.fromClient(location)\n    }\n\n    private fun adjust(\n        location: DoubleVector,\n        p: DataPointAesthetics,\n        pos: PositionAdjustment,\n        ctx: GeomContext\n    ): DoubleVector {\n        return pos.translate(location, p, ctx)\n    }\n\n    internal fun toClientRect(\n        p: DataPointAesthetics,\n        aesMapper: (DataPointAesthetics) -> DoubleRectangle?\n    ): DoubleRectangle? {\n        val r = aesMapper(p) ?: return null\n        return toClient(r, p)\n    }\n\n    private fun adjust(\n        r: DoubleRectangle,\n        p: DataPointAesthetics,\n        pos: PositionAdjustment,\n        ctx: GeomContext\n    ): DoubleRectangle {\n        val leftTop = pos.translate(r.origin, p, ctx)\n        val rightBottom = pos.translate(r.origin.add(r.dimension), p, ctx)\n        return DoubleRectangle.span(leftTop, rightBottom)\n    }\n\n    protected fun project(\n        dataPoints: Iterable<DataPointAesthetics>,\n        projection: (DataPointAesthetics) -> DoubleVector?\n    ): List<DoubleVector> {\n        val points = ArrayList<DoubleVector>()\n        for (p in dataPoints) {\n            val location = projection(p)\n            if (location != null) {\n                val pp = toClient(location, p)\n                points.add(pp)\n            }\n        }\n        return points\n    }\n\n    internal fun toClientLocation(aesMapper: (DataPointAesthetics) -> DoubleVector?): (DataPointAesthetics) -> DoubleVector? {\n        return { aes ->\n            val location = aesMapper(aes)\n            if (location != null) {\n                toClient(location, aes)\n            } else {\n                null\n            }\n        }\n    }\n\n    fun createSvgElementHelper(): SvgElementHelper {\n        return SvgElementHelper()\n    }\n\n    fun toClient(locations: List<DoubleVector>, p: DataPointAesthetics): List<DoubleVector> {\n        val localLocations = ArrayList<DoubleVector>()\n        for (location in locations) {\n            localLocations.add(toClient(location, p))\n        }\n        return localLocations\n    }\n\n    inner class SvgElementHelper {\n        private var myStrokeAlphaEnabled = false\n\n        fun setStrokeAlphaEnabled(b: Boolean) {\n            myStrokeAlphaEnabled = b\n        }\n\n        fun createLine(start: DoubleVector, end: DoubleVector, p: DataPointAesthetics): SvgLineElement {\n            @Suppress(\"NAME_SHADOWING\")\n            val start = toClient(start, p)\n            @Suppress(\"NAME_SHADOWING\")\n            val end = toClient(end, p)\n            val line = SvgLineElement(\n                start.x, start.y,\n                end.x, end.y\n            )\n            decorate(line, p, myStrokeAlphaEnabled)\n            return line\n        }\n    }\n\n    companion object {\n        val HJUST_MAP: Map<Any, TextLabel.HorizontalAnchor> = mapOf(\n            \"right\" to TextLabel.HorizontalAnchor.RIGHT,\n            \"middle\" to TextLabel.HorizontalAnchor.MIDDLE,\n            \"left\" to TextLabel.HorizontalAnchor.LEFT,\n            0.0 to TextLabel.HorizontalAnchor.RIGHT,\n            0.5 to TextLabel.HorizontalAnchor.MIDDLE,\n            1.0 to TextLabel.HorizontalAnchor.LEFT\n        )\n        val VJUST_MAP: Map<Any, TextLabel.VerticalAnchor> = mapOf(\n            \"bottom\" to TextLabel.VerticalAnchor.BOTTOM,\n            \"center\" to TextLabel.VerticalAnchor.CENTER,\n            \"top\" to TextLabel.VerticalAnchor.TOP,\n            0.0 to TextLabel.VerticalAnchor.BOTTOM,\n            0.5 to TextLabel.VerticalAnchor.CENTER,\n            1.0 to TextLabel.VerticalAnchor.TOP\n        )\n        private val FONT_WEIGHT_SET = setOf(\n            \"bold\", \"bolder\", \"lighter\"     // 'normal' is default\n        )\n        private val FONT_STYLE_SET = setOf(\n            \"italic\", \"oblique\"                 // 'normal' is default\n        )\n        private val FONT_FAMILY_MAP = mapOf(\n            \"sans\" to \"sans-serif\",\n            \"serif\" to \"serif\",\n            \"mono\" to \"monospace\"\n        )\n\n        fun decorate(label: TextLabel, p: DataPointAesthetics, scale: Double = 1.0) {\n\n            label.textColor().set(p.color())\n            label.textOpacity().set(p.alpha())\n            label.setFontSize(AesScaling.textSize(p) * scale)\n\n            // family\n            var family = p.family()\n            if (FONT_FAMILY_MAP.containsKey(family)) {   // otherwise - use value as provided by user\n                family = FONT_FAMILY_MAP.get(family)!!\n            }\n            label.setFontFamily(family)\n\n            // fontface\n            // ignore 'plain' / 'normal' as it is default values\n            val fontface = p.fontface()\n            if (!Strings.isNullOrEmpty(fontface)) {\n                for (s in fontface.split(\" \".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray()) {\n                    if (FONT_WEIGHT_SET.contains(s)) {\n                        label.setFontWeight(s)\n                    } else if (FONT_STYLE_SET.contains(s)) {\n                        label.setFontStyle(s)\n                    }\n                }\n            }\n\n            // text justification\n            val hAnchor =\n                textLabelAnchor(\n                    p.hjust(),\n                    HJUST_MAP,\n                    TextLabel.HorizontalAnchor.MIDDLE\n                )\n            val vAnchor =\n                textLabelAnchor(\n                    p.vjust(),\n                    VJUST_MAP,\n                    TextLabel.VerticalAnchor.CENTER\n                )\n\n            if (hAnchor !== TextLabel.HorizontalAnchor.LEFT) {  // 'left' is default\n                label.setHorizontalAnchor(hAnchor)\n            }\n            if (vAnchor !== TextLabel.VerticalAnchor.BOTTOM) {  // 'bottom' is default\n                label.setVerticalAnchor(vAnchor)\n            }\n\n            var angle = p.angle()!!\n            if (angle != 0.0) {\n                // ggplot angle: counter clockwise\n                // SVG angle: clockwise\n                angle = 360 - angle % 360\n                label.rotate(angle)\n            }\n        }\n\n        fun <T> textLabelAnchor(o: Any, conversionMap: Map<Any, T>, def: T): T {\n            return conversionMap.getOrElse(o, { def })\n        }\n\n        fun decorate(node: SvgNode, p: DataPointAesthetics, applyAlphaToAll: Boolean = ALPHA_CONTROLS_BOTH) {\n            if (node is SvgShape) {\n                decorateShape(\n                    node as SvgShape,\n                    p,\n                    applyAlphaToAll\n                )\n            }\n\n            if (node is SvgElement) {\n                val lineType = p.lineType()\n                if (!(lineType.isBlank || lineType.isSolid)) {\n                    StrokeDashArraySupport.apply(node, AesScaling.strokeWidth(p), lineType.dashArray)\n                }\n            }\n        }\n\n        private fun decorateShape(shape: SvgShape, p: DataPointAesthetics, applyAlphaToAll: Boolean) {\n            AestheticsUtil.updateStroke(shape, p, applyAlphaToAll)\n            AestheticsUtil.updateFill(shape, p)\n            shape.strokeWidth().set(AesScaling.strokeWidth(p))\n        }\n\n        internal fun decorateSlimShape(shape: SvgSlimShape, p: DataPointAesthetics) {\n            val stroke = p.color()!!\n            val strokeAlpha = AestheticsUtil.alpha(stroke, p)\n\n            val fill = p.fill()!!\n            val fillAlpha = AestheticsUtil.alpha(fill, p)\n\n            shape.setFill(fill, fillAlpha)\n            shape.setStroke(stroke, strokeAlpha)\n            shape.setStrokeWidth(AesScaling.strokeWidth(p))\n        }\n\n        fun getSizeUnitAes(sizeUnitName: String): Aes<Double> {\n            return when (sizeUnitName.lowercase()) {\n                \"x\" -> Aes.X\n                \"y\" -> Aes.Y\n                else -> error(\"Size unit value must be either 'x' or 'y', but was $sizeUnitName.\")\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\n\n\nobject GeomUtil {\n    val TO_LOCATION_X_Y = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.y()\n        )\n    }\n    val TO_LOCATION_X_YMIN = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.ymin()\n        )\n    }\n    val TO_LOCATION_X_YMAX = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.ymax()\n        )\n    }\n    val TO_LOCATION_X_ZERO = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            0.0\n        )\n    }\n    val TO_RECTANGLE = { p: DataPointAesthetics ->\n        if (SeriesUtil.allFinite(p.xmin(), p.ymin(), p.xmax(), p.ymax())) {\n            rectToGeometry(\n                p.xmin()!!,\n                p.ymin()!!,\n                p.xmax()!!,\n                p.ymax()!!\n            )\n        } else {\n            emptyList()\n        }\n    }\n    private val ORDERING_X = Ordering.from(object : Comparator<DataPointAesthetics?> {\n        override fun compare(a: DataPointAesthetics?, b: DataPointAesthetics?): Int {\n            val x1 = a?.x()\n            val x2 = b?.x()\n            if (x1 == null || x2 == null)\n                return 0\n            else\n                return x1.compareTo(x2)\n        }\n    })\n    private val ORDERING_Y = Ordering.from(object : Comparator<DataPointAesthetics?> {\n        override fun compare(a: DataPointAesthetics?, b: DataPointAesthetics?): Int {\n            val y1 = a?.y()\n            val y2 = b?.y()\n            if (y1 == null || y2 == null)\n                return 0\n            else\n                return y1.compareTo(y2)\n        }\n    })\n    private val WITH_X_Y = { pointAes: DataPointAesthetics -> SeriesUtil.allFinite(pointAes.x(), pointAes.y()) }\n    private val WITH_X = { pointAes: DataPointAesthetics -> SeriesUtil.isFinite(pointAes.x()) }\n    private val WITH_Y = { pointAes: DataPointAesthetics -> SeriesUtil.isFinite(pointAes.y()) }\n\n    private fun toLocationOrNull(x: Double?, y: Double?): DoubleVector? {\n        return if (SeriesUtil.isFinite(x) && SeriesUtil.isFinite(y)) {\n            DoubleVector(x!!, y!!)\n        } else null\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_X_Y(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_X_Y.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_X(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_X.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_Y(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_Y.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun ordered_X(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        if (ORDERING_X.isOrdered(dataPoints)) {\n            return dataPoints\n        }\n        return ORDERING_X.sortedCopy(dataPoints)\n    }\n\n    fun ordered_Y(dataPoints: Iterable<DataPointAesthetics>, reversed: Boolean): Iterable<DataPointAesthetics> {\n        val ordering = if (reversed) ORDERING_Y.reverse() else ORDERING_Y\n        if (ordering.isOrdered(dataPoints)) {\n            return dataPoints\n        }\n        return ordering.sortedCopy(dataPoints)\n    }\n\n    fun widthPx(p: DataPointAesthetics, ctx: GeomContext, minWidth: Double): Double {\n        val w = p.width()\n        val width = w!! * ctx.getResolution(Aes.X)\n        return max(width, minWidth)\n    }\n\n    fun withDefined(dataPoints: Iterable<DataPointAesthetics>, aes: Aes<*>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>,\n        aes2: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) && p.defined(aes2) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>,\n        aes2: Aes<*>,\n        aes3: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) && p.defined(aes2) && p.defined(aes3) }\n    }\n\n    fun rectangleByDataPoint(p: DataPointAesthetics, ctx: GeomContext): DoubleRectangle {\n        val x = p.x()!!\n        val y = p.y()!!\n        val width = widthPx(p, ctx, 2.0)\n\n        val origin: DoubleVector\n        val dimensions: DoubleVector\n        if (y >= 0) {\n            origin = DoubleVector(x - width / 2, 0.0)\n            dimensions = DoubleVector(width, y)\n        } else {\n            origin = DoubleVector(x - width / 2, y)\n            dimensions = DoubleVector(width, -y)\n        }\n\n        return DoubleRectangle(origin, dimensions)\n    }\n\n    fun createGroups(dataPoints: Iterable<DataPointAesthetics>): Map<Int, List<DataPointAesthetics>> {\n        val pointsByGroup = HashMap<Int, MutableList<DataPointAesthetics>>()\n        for (p in dataPoints) {\n            val group = p.group()!!\n            if (!pointsByGroup.containsKey(group)) {\n                pointsByGroup[group] = ArrayList()\n            }\n            pointsByGroup[group]!!.add(p)\n        }\n\n        return pointsByGroup\n    }\n\n    fun rectToGeometry(minX: Double, minY: Double, maxX: Double, maxY: Double): List<DoubleVector> {\n        return listOf(\n            DoubleVector(minX, minY),\n            DoubleVector(minX, maxY),\n            DoubleVector(maxX, maxY),\n            DoubleVector(maxX, minY),\n            DoubleVector(minX, minY)\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors.solid\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject HintColorUtil {\n    fun fromColor(p: DataPointAesthetics): Color {\n        return fromColorValue(\n            p.color()!!,\n            p.alpha()!!\n        )\n    }\n\n    fun fromFill(p: DataPointAesthetics): Color {\n        return fromColorValue(\n            p.fill()!!,\n            p.alpha()!!\n        )\n    }\n\n    fun fromColorValue(color: Color, alpha: Double): Color {\n        val intAlpha = (255 * alpha).toInt()\n        return if (solid(color)) {\n            color.changeAlpha(intAlpha)\n        } else color\n\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory.HintConfig\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind\n\n\nclass HintsCollection(private val myPoint: DataPointAesthetics, private val myHelper: GeomHelper) {\n    private val myHints = HashMap<Aes<*>, TipLayoutHint>()\n\n    val hints: MutableMap<Aes<*>, TipLayoutHint>\n        get() = myHints\n\n    fun addHint(hintConfig: HintConfig): HintsCollection {\n        val coord = getCoord(hintConfig)\n\n        if (coord != null) {\n            hints[hintConfig.aes] = createHint(hintConfig, coord)\n        }\n\n        return this\n    }\n\n    private fun getCoord(hintConfig: HintConfig): DoubleVector? {\n        if (hintConfig.x == null) {\n            throw IllegalArgumentException(\"x coord is not set\")\n        }\n\n        val aes = hintConfig.aes\n        return if (!myPoint.defined(aes)) {\n            null\n        } else myHelper.toClient(DoubleVector(hintConfig.x!!, myPoint.get<Double>(aes)!!), myPoint)\n\n    }\n\n    private fun createHint(hintConfig: HintConfig, coord: DoubleVector): TipLayoutHint {\n        val objectRadius = hintConfig.objectRadius\n        val color = hintConfig.color\n\n        if (objectRadius == null) {\n            throw IllegalArgumentException(\"object radius is not set\")\n        }\n\n        return when (hintConfig.kind) {\n            Kind.VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(coord, objectRadius, color)\n\n            Kind.HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(coord, objectRadius, color)\n\n            Kind.CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(coord, color)\n\n            else -> throw IllegalArgumentException(\"Unknown hint kind: \" + hintConfig.kind)\n        }\n    }\n\n    class HintConfigFactory {\n\n        private var myDefaultObjectRadius: Double? = null\n        private var myDefaultX: Double? = null\n        private var myDefaultColor: Color? = null\n        private var myDefaultKind: Kind? = null\n\n        fun defaultObjectRadius(defaultObjectRadius: Double): HintConfigFactory {\n            myDefaultObjectRadius = defaultObjectRadius\n            return this\n        }\n\n        fun defaultX(defaultX: Double): HintConfigFactory {\n            myDefaultX = defaultX\n            return this\n        }\n\n        fun defaultColor(v: Color, alpha: Double?): HintConfigFactory {\n            if (alpha != null) {\n                myDefaultColor = v.changeAlpha((255 * alpha).toInt())\n            } else {\n                myDefaultColor = v\n            }\n            return this\n        }\n\n        fun create(aes: Aes<Double>): HintConfig {\n            return HintConfig(aes)\n        }\n\n        fun defaultKind(kind: Kind): HintConfigFactory {\n            myDefaultKind = kind\n            return this\n        }\n\n        inner class HintConfig internal constructor(val aes: Aes<Double>) {\n            val kind: Kind?\n            var objectRadius: Double? = null\n                private set\n            var x: Double? = null\n                private set\n            internal var color: Color? = null\n                private set\n\n            init {\n                objectRadius = myDefaultObjectRadius\n                x = myDefaultX\n                kind = myDefaultKind\n                color = myDefaultColor\n            }\n\n            fun objectRadius(v: Double): HintConfig {\n                objectRadius = v\n                return this\n            }\n\n            fun x(v: Double): HintConfig {\n                x = v\n                return this\n            }\n\n            fun color(v: Color): HintConfig {\n                color = v\n                return this\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.svg.LinePath\n\nclass LinePathConstructor(\n    private val myTargetCollector: GeomTargetCollector,\n    private val myDataPoints: Iterable<DataPointAesthetics>,\n    private val myLinesHelper: LinesHelper,\n    private val myClosePath: Boolean\n) {\n\n    fun construct(withHints: Boolean): List<LinePath> {\n        val linePaths = ArrayList<LinePath>()\n        val multiPointDataList = createMultiPointDataByGroup()\n        for (multiPointData in multiPointDataList) {\n           linePaths.addAll(myLinesHelper.createPaths(multiPointData.aes, multiPointData.points, myClosePath))\n        }\n        if (withHints) {\n            buildHints(multiPointDataList)\n        }\n        return linePaths\n    }\n\n    fun buildHints() = buildHints(createMultiPointDataByGroup())\n\n    private fun buildHints(multiPointDataList: List<MultiPointData>) {\n        for (multiPointData in multiPointDataList) {\n            if (myClosePath) {\n                myTargetCollector.addPolygon(\n                    multiPointData.points,\n                    multiPointData.localToGlobalIndex,\n                    params().setColor(\n                        HintColorUtil.fromFill(\n                            multiPointData.aes\n                        )\n                    )\n                )\n            } else {\n                myTargetCollector.addPath(\n                    multiPointData.points,\n                    multiPointData.localToGlobalIndex,\n                    params().setColor(\n                        HintColorUtil.fromColor(\n                            multiPointData.aes\n                        )\n                    )\n                )\n            }\n        }\n    }\n\n    private fun createMultiPointDataByGroup(): List<MultiPointData> {\n        return MultiPointDataConstructor.createMultiPointDataByGroup(\n            myDataPoints,\n            singlePointAppender { p -> myLinesHelper.toClient(GeomUtil.TO_LOCATION_X_Y(p)!!, p) },\n            reducer(DROP_POINT_DISTANCE, myClosePath)\n        )\n    }\n\n    companion object {\n        private const val DROP_POINT_DISTANCE = 0.999\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Colors.withOpacity\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.StepGeom\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.render.svg.LinePath\n\nopen class LinesHelper(pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) :\n    GeomHelper(pos, coord, ctx) {\n\n    private var myAlphaFilter = { v: Double? -> v }\n    private var myWidthFilter = { v: Double? -> v }\n    private var myAlphaEnabled = true\n\n    private fun insertPathSeparators(rings: Iterable<List<DoubleVector>>): List<DoubleVector?> {\n        val result = ArrayList<DoubleVector?>()\n        for (ring in rings) {\n            if (!result.isEmpty()) {\n                result.add(LinePath.END_OF_SUBPATH) // this is polygon's path separator understood by PathLine component\n            }\n\n            result.addAll(ring)\n        }\n\n        return result\n    }\n\n    fun setAlphaEnabled(b: Boolean) {\n        this.myAlphaEnabled = b\n    }\n\n    fun createLines(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocation: (DataPointAesthetics) -> DoubleVector?\n    ): MutableList<LinePath> {\n        return createPaths(dataPoints, toLocation, false)\n    }\n\n    private fun createPaths(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocation: (DataPointAesthetics) -> DoubleVector?,\n        closePath: Boolean\n    ): MutableList<LinePath> {\n        val paths = ArrayList<LinePath>()\n        val multiPointDataList =\n            MultiPointDataConstructor.createMultiPointDataByGroup(\n                dataPoints,\n                singlePointAppender(toClientLocation { toLocation(it) }),\n                reducer(0.999, closePath)\n            )\n\n        // draw line for each group\n        for (multiPointData in multiPointDataList) {\n            paths.addAll(createPaths(multiPointData.aes, multiPointData.points, closePath))\n        }\n\n        return paths\n    }\n\n    internal fun createPaths(aes: DataPointAesthetics, points: List<DoubleVector>, closePath: Boolean): List<LinePath> {\n        val paths = ArrayList<LinePath>()\n        if (closePath) {\n            paths.add(LinePath.polygon(insertPathSeparators(splitRings(points))))\n        } else {\n            paths.add(LinePath.line(points))\n        }\n        paths.forEach { path -> decorate(path, aes, closePath) }\n        return paths\n    }\n\n    internal fun createSteps(dataPoints: Iterable<DataPointAesthetics>, dir: StepGeom.Direction): List<PathInfo> {\n        val pathInfos = ArrayList<PathInfo>()\n        val multiPointDataList =\n            MultiPointDataConstructor.createMultiPointDataByGroup(\n                dataPoints,\n                singlePointAppender(toClientLocation(GeomUtil.TO_LOCATION_X_Y)),\n                reducer(0.999, false)\n            )\n\n        // draw step for each group\n        for (multiPointData in multiPointDataList) {\n            val points = multiPointData.points\n            if (!points.isEmpty()) {\n                val newPoints = ArrayList<DoubleVector>()\n                var prev: DoubleVector? = null\n                for (point in points) {\n                    if (prev != null) {\n                        val x = if (dir === StepGeom.Direction.HV) point.x else prev.x\n                        val y = if (dir === StepGeom.Direction.HV) prev.y else point.y\n                        newPoints.add(DoubleVector(x, y))\n                    }\n                    newPoints.add(point)\n                    prev = point\n                }\n\n                val path = LinePath.line(newPoints)\n                decorate(path, multiPointData.aes, false)\n                pathInfos.add(\n                    PathInfo(\n                        path\n                    )\n                )\n            }\n        }\n\n        return pathInfos\n    }\n\n    fun createBands(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocationUpper: (DataPointAesthetics) -> DoubleVector?,\n        toLocationLower: (DataPointAesthetics) -> DoubleVector?\n    ): MutableList<LinePath> {\n\n        val lines = ArrayList<LinePath>()\n        val pointsByGroup = GeomUtil.createGroups(dataPoints)\n\n        // draw line for each group\n        for (group in Ordering.natural<Int>().sortedCopy(pointsByGroup.keys)) {\n            val groupDataPoints = pointsByGroup[group]\n            // upper margin points\n            val points = ArrayList(project(groupDataPoints!!) { toLocationUpper(it) })\n\n            // lower margin point in reversed order\n//            val lowerPoints = ImmutableList.reverse(groupDataPoints)\n            val lowerPoints = groupDataPoints.reversed()\n            points.addAll(project(lowerPoints) { toLocationLower(it) })\n\n            if (!points.isEmpty()) {\n                val path = LinePath.polygon(points)\n                //decorate(path, groupDataPoints.get(0), true);\n                decorateFillingPart(path, groupDataPoints[0])\n                lines.add(path)\n            }\n        }\n        return lines\n    }\n\n    protected fun decorate(path: LinePath, p: DataPointAesthetics, filled: Boolean) {\n\n        val stroke = p.color()\n        val strokeAlpha = myAlphaFilter(AestheticsUtil.alpha(stroke!!, p))!!\n        path.color().set(withOpacity(stroke, strokeAlpha))\n        if (!AestheticsUtil.ALPHA_CONTROLS_BOTH && (filled || !myAlphaEnabled)) {\n            path.color().set(stroke)\n        }\n\n        if (filled) {\n            decorateFillingPart(path, p)\n        }\n\n        val size = myWidthFilter(AesScaling.strokeWidth(p))!!\n        path.width().set(size)\n\n        val lineType = p.lineType()\n        if (!(lineType.isBlank || lineType.isSolid)) {\n            path.dashArray().set(lineType.dashArray)\n        }\n    }\n\n    private fun decorateFillingPart(path: LinePath, p: DataPointAesthetics) {\n        val fill = p.fill()\n        val fillAlpha = myAlphaFilter(AestheticsUtil.alpha(fill!!, p))!!\n        path.fill().set(withOpacity(fill, fillAlpha))\n    }\n\n    fun setAlphaFilter(alphaFilter: (Double?) -> Double?) {\n        myAlphaFilter = alphaFilter\n    }\n\n    fun setWidthFilter(widthFilter: (Double?) -> Double?) {\n        myWidthFilter = widthFilter\n    }\n\n    // ToDo: get rid of PathInfo class\n    class PathInfo internal constructor(val path: LinePath)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nclass MappedAesthetics(\n    private val myAesthetics: Aesthetics,\n    private val myPointAestheticsMapper: (DataPointAesthetics) -> DataPointAesthetics\n) : Aesthetics {\n\n    override val isEmpty: Boolean\n        get() = myAesthetics.isEmpty\n\n    override fun dataPointAt(index: Int): DataPointAesthetics {\n        return myPointAestheticsMapper(myAesthetics.dataPointAt(index))\n    }\n\n    override fun dataPointCount(): Int {\n        return myAesthetics.dataPointCount()\n    }\n\n    override fun dataPoints(): Iterable<DataPointAesthetics> {\n        val source = myAesthetics.dataPoints()\n        return source.map { myPointAestheticsMapper(it) }\n    }\n\n    override fun range(aes: Aes<Double>): ClosedRange<Double> {\n        throw IllegalStateException(\"MappedAesthetics.range: not implemented $aes\")\n    }\n\n    override fun overallRange(aes: Aes<Double>): ClosedRange<Double> {\n        throw IllegalStateException(\"MappedAesthetics.overallRange: not implemented $aes\")\n    }\n\n    override fun resolution(aes: Aes<Double>, naValue: Double): Double {\n        throw IllegalStateException(\"MappedAesthetics.resolution: not implemented $aes\")\n    }\n\n    override fun numericValues(aes: Aes<Double>): Iterable<Double?> {\n        throw IllegalStateException(\"MappedAesthetics.numericValues: not implemented $aes\")\n    }\n\n    override fun groups(): Iterable<Int> {\n        return myAesthetics.groups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nclass MultiPointData internal constructor(\n    val aes: DataPointAesthetics,\n    val points: List<DoubleVector>,\n    val localToGlobalIndex: (Int) -> Int,\n    val group: Int)\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport kotlin.math.abs\n\nobject MultiPointDataConstructor {\n    fun collector(): () -> PointCollector {\n        return { SimplePointCollector() }\n    }\n\n    fun reducer(dropPointDistance: Double, isPolygon: Boolean): () -> PointCollector {\n        return {\n            PointReducer(\n                dropPointDistance,\n                isPolygon\n            )\n        }\n    }\n\n    fun singlePointAppender(\n            toPoint: (DataPointAesthetics) -> DoubleVector?):\n            (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit {\n        return { aes, coordinateConsumer -> coordinateConsumer(toPoint(aes)) }\n    }\n\n    fun multiPointAppender(\n            toPath: (DataPointAesthetics) -> List<DoubleVector>): (DataPointAesthetics, (DoubleVector) -> Unit) -> Unit {\n        return { aes, coordinateConsumer -> toPath(aes).forEach(coordinateConsumer) }\n    }\n\n    fun createMultiPointDataByGroup(\n        dataPoints: Iterable<DataPointAesthetics>,\n        coordinateAppender: (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit,\n        pointCollectorSupplier: () -> PointCollector\n    ): List<MultiPointData> {\n        val multiPointDataCombiners = HashMap<Int, MultiPointDataCombiner>()\n\n        for (p in dataPoints) {\n            val group = p.group()\n            if (!multiPointDataCombiners.containsKey(group)) {\n                multiPointDataCombiners[group!!] =\n                    MultiPointDataCombiner(\n                        coordinateAppender,\n                        pointCollectorSupplier()\n                    )\n            }\n\n            multiPointDataCombiners[group]!!.add(p)\n        }\n\n        val result = ArrayList<MultiPointData>()\n\n        val sortedGroup = natural<Int>().sortedCopy(multiPointDataCombiners.keys)\n        for (group in sortedGroup) {\n            val multiPointData = multiPointDataCombiners[group]!!.create(group)\n\n            if (multiPointData.points.isNotEmpty()) {\n                result.add(multiPointData)\n            }\n        }\n\n        return result\n    }\n\n    interface PointCollector {\n\n        val points: Pair<List<DoubleVector>, List<Int>>\n        fun add(coord: DoubleVector?, index: Int)\n    }\n\n    private class MultiPointDataCombiner internal constructor(\n        private val myCoordinateAppender: (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit,\n        private val myPointCollector: PointCollector\n    ) {\n\n        private var myFirstAes: DataPointAesthetics? = null\n\n        internal fun add(aes: DataPointAesthetics) {\n            if (myFirstAes == null) {\n                myFirstAes = aes\n            }\n            myCoordinateAppender(aes) { myPointCollector.add(it, aes.index()) }\n        }\n\n        internal fun create(group: Int): MultiPointData {\n            val points = myPointCollector.points\n            return MultiPointData(\n                myFirstAes!!,\n                points.first,\n                { points.second[it] },\n                group\n            )\n        }\n    }\n\n    private class SimplePointCollector internal constructor() :\n        PointCollector {\n        private val myPoints = ArrayList<DoubleVector>()\n        private val myIndexes = ArrayList<Int>()\n\n        override val points: Pair<List<DoubleVector>, List<Int>>\n            get() = Pair(myPoints, myIndexes)\n\n        override fun add(coord: DoubleVector?, index: Int) {\n            myPoints.add(coord!!)\n            myIndexes.add(index)\n        }\n    }\n\n    private class PointReducer internal constructor(private val myDropPointDistance: Double, private val myPolygon: Boolean) :\n        PointCollector {\n\n        private val myReducedPoints = ArrayList<DoubleVector>()\n        private val myReducedIndexes = ArrayList<Int>()\n        private var myLastAdded: DoubleVector? = null\n        private var myLastPostponed: Pair<DoubleVector, Int>? = null\n        private var myRegionStart: Pair<DoubleVector?, Int?>? = null\n\n        override// Add last postponed to avoid disconnected contours\n        val points: Pair<List<DoubleVector>, List<Int>>\n            get() {\n                if (myLastPostponed != null) {\n                    addPoint(myLastPostponed!!.first, myLastPostponed!!.second)\n                    myLastPostponed = null\n                }\n\n                return Pair(myReducedPoints, myReducedIndexes)\n            }\n\n        private fun isCloserThan(p0: DoubleVector, p1: DoubleVector, distance: Double): Boolean {\n            return abs(p0.x - p1.x) < distance && abs(p0.y - p1.y) < distance\n        }\n\n        override fun add(coord: DoubleVector?, index: Int) {\n            if (coord == null) {\n                return\n            }\n\n            if (myLastAdded == null) {\n                storePoint(coord, index)\n                return\n            }\n\n            if (needPostpone(coord)) {\n                postponePoint(coord, index)\n            } else {\n                // add all\n                if (myLastPostponed != null) {\n                    addPoint(myLastPostponed!!.first, myLastPostponed!!.second)\n                    myLastPostponed = null\n                }\n                storePoint(coord, index)\n            }\n        }\n\n        private fun needPostpone(loc: DoubleVector): Boolean {\n            val closeToAdded = areTooClose(myLastAdded, loc)\n            val closeToPostponed = myLastPostponed == null || areTooClose(myLastPostponed!!.first, loc)\n            val regionClosePoint = isRegionStart(loc)\n\n            return closeToAdded && closeToPostponed && !regionClosePoint\n        }\n\n        private fun postponePoint(loc: DoubleVector, index: Int) {\n            myLastPostponed = Pair(loc, index)\n        }\n\n        private fun storePoint(loc: DoubleVector, index: Int) {\n            addPoint(loc, index)\n            myLastAdded = loc\n\n            processRegionStart(loc, index)\n        }\n\n        private fun processRegionStart(loc: DoubleVector?, index: Int?) {\n            if (!myPolygon) {\n                return\n            }\n\n            if (myRegionStart == null) {\n                myRegionStart = Pair(loc, index)\n                return\n            }\n\n            if (isRegionStart(loc)) {\n                // Region is closed. Wait next start point.\n                myRegionStart = null\n                myLastAdded = null\n            }\n        }\n\n        private fun isRegionStart(loc: DoubleVector?): Boolean {\n            if (!myPolygon) {\n                return false\n            }\n\n            return if (myRegionStart == null) {\n                false\n            } else myRegionStart!!.first == loc\n\n        }\n\n        private fun addPoint(loc: DoubleVector, index: Int) {\n            myReducedPoints.add(loc)\n            myReducedIndexes.add(index)\n        }\n\n        private fun areTooClose(p1: DoubleVector?, p2: DoubleVector): Boolean {\n            return isCloserThan(p1!!, p2, myDropPointDistance)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nclass RectTargetCollectorHelper(\n    private val rectanglesHelper: RectanglesHelper,\n    private val rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?,\n    private val fillByDataPoint: (DataPointAesthetics) -> Color,\n    private val tooltipKind: TipLayoutHint.Kind\n) {\n\n    fun collectTo(targetCollector: GeomTargetCollector) {\n        rectanglesHelper.iterateRectangleGeometry(rectangleByDataPoint)\n        { p, rectangle ->\n            targetCollector.addRectangle(p.index(), rectangle, tooltipParams(p), tooltipKind)\n        }\n    }\n\n    private fun tooltipParams(p: DataPointAesthetics): TooltipParams {\n        val params = params()\n        params.setColor(fillByDataPoint(p))\n        return params\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\n\nclass RectanglesHelper(\n    private val myAesthetics: Aesthetics,\n    pos: PositionAdjustment,\n    coord: CoordinateSystem,\n    ctx: GeomContext\n) : GeomHelper(pos, coord, ctx) {\n\n    fun createRectangles(rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?): MutableList<SvgNode> {\n        val result = ArrayList<SvgNode>()\n\n        for (index in 0 until myAesthetics.dataPointCount()) {\n            val p = myAesthetics.dataPointAt(index)\n            val clientRect = toClientRect(p, rectangleByDataPoint) ?: continue\n\n            val svgRect = SvgRectElement(clientRect)\n            decorate(svgRect, p)\n\n            result.add(svgRect)\n        }\n\n        return result\n    }\n\n    fun iterateRectangleGeometry(\n        rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?,\n        iterator: (DataPointAesthetics, DoubleRectangle) -> Unit\n    ) {\n        for (index in 0 until myAesthetics.dataPointCount()) {\n            val p = myAesthetics.dataPointAt(index)\n            val rect = toClientRect(p, rectangleByDataPoint)\n\n            rect?.let {\n                iterator(p, rect)\n            }\n        }\n    }\n\n\n    fun createSlimRectangles(rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?): SvgSlimGroup {\n        val pointCount = myAesthetics.dataPointCount()\n        val group = SvgSlimElements.g(pointCount)\n\n        for (index in 0 until pointCount) {\n            val p = myAesthetics.dataPointAt(index)\n            val clientRect = toClientRect(p, rectangleByDataPoint) ?: continue\n\n            val slimShape = SvgSlimElements.rect(clientRect.left, clientRect.top, clientRect.width, clientRect.height)\n            decorateSlimShape(\n                slimShape,\n                p\n            )\n            slimShape.appendTo(group)\n        }\n\n        return group\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.values.Color\n\n// `open` for Mockito tests\nopen class ContextualMapping(\n    private val tooltipLines: List<TooltipLineSpec>,\n    val tooltipAnchor: TooltipAnchor?,\n    val tooltipMinWidth: Double?,\n    val tooltipColor: Color?,\n    val ignoreInvisibleTargets: Boolean,\n    val hasGeneralTooltip: Boolean,\n    val hasAxisTooltip: Boolean,\n    val isCrosshairEnabled: Boolean\n) {\n    fun getDataPoints(index: Int): List<TooltipLineSpec.DataPoint> {\n        return tooltipLines.mapNotNull { it.getDataPoint(index) }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.DataFrame\n\ndata class DataContext(\n    val dataFrame: DataFrame,\n    val mappedDataAccess: MappedDataAccess\n)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\n\n// `open` - for Mockito tests\nopen class GeomTarget(\n    val hitIndex: Int,\n    open val tipLayoutHint: TipLayoutHint,\n    open val aesTipLayoutHints: Map<Aes<*>, TipLayoutHint>)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind\n\ninterface GeomTargetCollector {\n\n    fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.VERTICAL_TOOLTIP\n    )\n\n    fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.HORIZONTAL_TOOLTIP\n    )\n\n    fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.HORIZONTAL_TOOLTIP\n    )\n\n    fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.CURSOR_TOOLTIP\n    )\n\n    class TooltipParams {\n\n        private var myTipLayoutHints = emptyMap<Aes<*>, TipLayoutHint>()\n        private var myColor = Color.GRAY\n        private var myStemLength = TipLayoutHint.StemLength.NORMAL\n\n        fun getTipLayoutHints(): Map<Aes<*>, TipLayoutHint> {\n            return myTipLayoutHints\n        }\n\n        fun setTipLayoutHints(tipLayoutHints: Map<Aes<*>, TipLayoutHint>): TooltipParams {\n            myTipLayoutHints = tipLayoutHints\n            return this\n        }\n\n        fun getColor(): Color {\n            return myColor\n        }\n\n        fun setColor(color: Color): TooltipParams {\n            myColor = color\n            return this\n        }\n\n        fun getStemLength(): TipLayoutHint.StemLength {\n            return myStemLength\n        }\n\n        fun setStemLength(stemLength: TipLayoutHint.StemLength): TooltipParams {\n            myStemLength = stemLength\n            return this\n        }\n\n        companion object {\n            fun params(): TooltipParams {\n                return TooltipParams()\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\n\ninterface GeomTargetLocator {\n\n    fun search(coord: DoubleVector): LookupResult?\n\n    enum class LookupSpace {\n        X, XY, NONE\n    }\n\n    enum class LookupStrategy {\n        HOVER, NEAREST, NONE\n    }\n\n    class LookupSpec(val lookupSpace: LookupSpace, val lookupStrategy: LookupStrategy) {\n        companion object {\n            val NONE = LookupSpec(\n                LookupSpace.NONE,\n                LookupStrategy.NONE\n            )\n        }\n    }\n\n    // `open` for Mockito test\n    open class LookupResult(\n        val targets: List<GeomTarget>,\n        open val distance: Double,\n        open val geomKind: GeomKind,\n        open val contextualMapping: ContextualMapping,\n        val isCrosshairEnabled: Boolean\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nopen class HitShape private constructor(val kind: Kind, private val shape: Any) {\n\n    val point: DoubleCircle\n        get() = shape as DoubleCircle\n\n    val rect: DoubleRectangle\n        get() = shape as DoubleRectangle\n\n    open val points: List<DoubleVector>\n        get() = throw IllegalStateException(\"Not applicable to $kind\")\n\n    enum class Kind {\n        POINT, RECT, POLYGON, PATH\n    }\n\n    class DoubleCircle(val center: DoubleVector, val radius: Double)\n\n    companion object {\n        fun point(p: DoubleVector, radius: Double): HitShape {\n            return HitShape(Kind.POINT, DoubleCircle(p, radius))\n        }\n\n        fun rect(r: DoubleRectangle): HitShape {\n            return HitShape(Kind.RECT, r)\n        }\n\n        fun path(points: List<DoubleVector>): HitShape {\n            return shapeWithPath(Kind.PATH, points)\n        }\n\n        fun polygon(points: List<DoubleVector>): HitShape {\n            return shapeWithPath(Kind.POLYGON, points)\n        }\n\n        private fun shapeWithPath(kind: Kind, points: List<DoubleVector>): HitShape {\n            return object : HitShape(kind, points) {\n                override val points: List<DoubleVector>\n                    get() = points\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\ninterface MappedDataAccess {\n\n    val mappedAes: Set<Aes<*>>\n\n    val scaleByAes: (Aes<*>) -> Scale<*>\n\n    fun isMapped(aes: Aes<*>): Boolean\n\n    fun <T> getMappedData(aes: Aes<T>, index: Int): MappedData<T>\n\n    fun <T> getOriginalValue(aes: Aes<T>, index: Int): Any?\n\n    fun getMappedDataLabel(aes: Aes<*>): String\n\n    fun isMappedDataContinuous(aes: Aes<*>): Boolean\n\n    class MappedData<T>(\n        val label: String,\n        val value: String,\n        val isContinuous: Boolean\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\n\nclass NullGeomTargetCollector : GeomTargetCollector {\n    override fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\n\n// `open` - for Mockito tests\nopen class TipLayoutHint(\n    open val kind: Kind,\n    open val coord: DoubleVector?,\n    open val objectRadius: Double,\n    open val color: Color?,\n    open val stemLength: StemLength\n) {\n\n    enum class StemLength(val value: Double) {\n        NORMAL(12.0),\n        SHORT(5.0),\n        NONE(0.0)\n    }\n\n    override fun toString(): String {\n        return \"$kind\"\n    }\n\n\n    enum class Kind {\n        VERTICAL_TOOLTIP,\n        HORIZONTAL_TOOLTIP,\n        CURSOR_TOOLTIP,\n        X_AXIS_TOOLTIP,\n        Y_AXIS_TOOLTIP\n    }\n\n\n    companion object {\n\n        fun verticalTooltip(coord: DoubleVector?, objectRadius: Double, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                Kind.VERTICAL_TOOLTIP,\n                coord,\n                objectRadius,\n                color,\n                stemLength\n            )\n        }\n\n        fun horizontalTooltip(coord: DoubleVector?, objectRadius: Double, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                Kind.HORIZONTAL_TOOLTIP,\n                coord,\n                objectRadius,\n                color,\n                stemLength\n            )\n        }\n\n        fun cursorTooltip(coord: DoubleVector?, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.CURSOR_TOOLTIP,\n                coord = coord,\n                objectRadius = 0.0,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n\n        fun xAxisTooltip(coord: DoubleVector?, color: Color?, axisRadius: Double = 0.0, stemLength: StemLength = StemLength.NONE): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.X_AXIS_TOOLTIP,\n                coord = coord,\n                objectRadius = axisRadius,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n\n        fun yAxisTooltip(coord: DoubleVector?, color: Color?, axisRadius: Double = 0.0, stemLength: StemLength = StemLength.NONE): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.Y_AXIS_TOOLTIP,\n                coord = coord,\n                objectRadius = axisRadius,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nclass TooltipAnchor(\n    val verticalAnchor: VerticalAnchor,\n    val horizontalAnchor: HorizontalAnchor\n) {\n    enum class VerticalAnchor {\n        TOP,\n        BOTTOM,\n        MIDDLE\n    }\n\n    enum class HorizontalAnchor {\n        LEFT,\n        RIGHT,\n        CENTER;\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as TooltipAnchor\n\n        if (verticalAnchor != other.verticalAnchor) return false\n        if (horizontalAnchor != other.horizontalAnchor) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = verticalAnchor.hashCode()\n        result = 31 * result + horizontalAnchor.hashCode()\n        return result\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\n\ninterface TooltipLineSpec {\n    fun getDataPoint(index: Int): DataPoint?\n\n    class DataPoint(\n        val label: String?,\n        val value: String,\n        val aes: Aes<*>?,\n        val isAxis: Boolean,\n        val isOutlier: Boolean\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.livemap\n\ninterface LivemapConstants {\n    enum class DisplayMode {\n        POINT,\n        PIE,\n        BAR\n    }\n\n    enum class Theme {\n        COLOR,\n        LIGHT,\n        DARK\n    }\n\n    enum class Projection {\n        EPSG3857,\n        EPSG4326,\n        AZIMUTHAL,\n        CONIC\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.livemap\n\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection\n\nclass LiveMapOptions(\n    val zoom: Int?,\n    val location: Any?,\n    val stroke: Double?,\n    val interactive: Boolean,\n    val displayMode: DisplayMode,\n    val scaled: Boolean,\n    val clustering: Boolean,\n    val labels: Boolean,\n    val projection: Projection,\n    val geodesic: Boolean,\n    val geocodingService: Map<*, *>,\n    val tileProvider: Map<*, *>,\n    val devParams: Map<*, *>\n)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class DodgePos(\n    aesthetics: Aesthetics,\n    private val myGroupCount: Int,\n    private val myWidth: Double?\n) : PositionAdjustment {\n\n    private val myDodgingNeeded: Boolean\n    private fun isDodgingNeeded(aesthetics: Aesthetics): Boolean {\n        // if for some X there are more then just 1 group, then dodging is needed\n        val groupByX = HashMap<Double, Int?>()\n        for (i in 0 until aesthetics.dataPointCount()) {\n            val p = aesthetics.dataPointAt(i)\n            if (p.defined(Aes.X)) {\n                val x = p.x()!!\n                val group = p.group()\n                if (groupByX.containsKey(x)) {\n                    if (groupByX[x] != group) {\n                        // >1 group for this X\n                        return true\n                    }\n                } else {\n                    groupByX[x] = group\n                }\n            }\n        }\n        return false\n    }\n\n    init {\n        myDodgingNeeded = isDodgingNeeded(aesthetics)\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        if (myDodgingNeeded) {\n            val dataResolution = ctx.getResolution(Aes.X)\n            val width = myWidth ?: p.width()\n\n            if (!SeriesUtil.isFinite(width)) {\n                return v\n            }\n\n            val slotIndex = p.group()!!\n            val median = (myGroupCount - 1) / 2.0\n            val xOffset = (slotIndex - median) * dataResolution * width!!\n            val xCenter = p.x()!!\n            val xScaler = 1.0 / myGroupCount\n\n            val newX = (v.x + xOffset - xCenter) * xScaler + xCenter\n\n            return DoubleVector(newX, v.y)\n        }\n        return v\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.DODGE.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class FillPos(aes: Aesthetics) : PositionAdjustment {\n\n    private val myStackPosHelper: PositionAdjustment =\n        StackPos.splitPositiveNegative(aes)\n    private val myScalerByIndex: Map<Int, Double> = mapIndexToScaler(aes)\n\n    private fun mapIndexToScaler(aes: Aesthetics): Map<Int, Double> {\n        val posMaxByBin = HashMap<Double, Double>()\n        val negMaxByBin = HashMap<Double, Double>()\n        for (i in 0 until aes.dataPointCount()) {\n            val dataPoint = aes.dataPointAt(i)\n            val x = dataPoint.x()\n            if (SeriesUtil.isFinite(x)) {\n                if (!posMaxByBin.containsKey(x)) {\n                    posMaxByBin[x!!] = 0.0\n                    negMaxByBin[x] = 0.0\n                }\n\n                val y = dataPoint.y()\n                if (SeriesUtil.isFinite(y)) {\n                    if (y!! >= 0) {\n                        posMaxByBin[x!!] = posMaxByBin[x]!! + y\n                    } else {\n                        negMaxByBin[x!!] = negMaxByBin[x]!! - y\n                    }\n                }\n            }\n        }\n        val scalerByIndex = HashMap<Int, Double>()\n        // Double max = max(Collections.max(posMaxByBin.values()), Collections.max(negMaxByBin.values()));\n        for (i in 0 until aes.dataPointCount()) {\n            val dataPoint = aes.dataPointAt(i)\n            val x = dataPoint.x()\n            val y = dataPoint.y()\n            if (posMaxByBin.containsKey(x) && SeriesUtil.isFinite(y)) {\n                if (y!! >= 0 && posMaxByBin[x]!! > 0) {\n                    scalerByIndex[i] = 1.0 / posMaxByBin[x]!!\n                } else if (y < 0 && negMaxByBin[x]!! > 0) {\n                    scalerByIndex[i] = 1.0 / negMaxByBin[x]!!\n                } else {\n                    scalerByIndex[i] = 1.0\n                }\n            } else {\n                scalerByIndex[i] = 1.0\n            }\n        }\n        return scalerByIndex\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val newLoc = myStackPosHelper.translate(v, p, ctx)\n        return DoubleVector(newLoc.x, newLoc.y * myScalerByIndex[p.index()]!! * ctx.getUnitResolution(Aes.Y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.FILL.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\nclass JitterDodgePos(aesthetics: Aesthetics, groupCount: Int, width: Double?, jitterWidth: Double?, jitterHeight: Double?) :\n    PositionAdjustment {\n    private val myJitterPosHelper: PositionAdjustment\n    private val myDodgePosHelper: PositionAdjustment\n\n    init {\n        myJitterPosHelper = JitterPos(jitterWidth, jitterHeight)\n        myDodgePosHelper = DodgePos(aesthetics, groupCount, width)\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val afterJitter = myJitterPosHelper.translate(v, p, ctx)\n        return myDodgePosHelper.translate(afterJitter, p, ctx)\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.JITTER_DODGE.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport kotlin.random.Random\n\ninternal class JitterPos(width: Double?, height: Double?) : PositionAdjustment {\n\n    //uniform distribution\n    private val myWidth: Double\n    private val myHeight: Double\n\n    init {\n        myWidth = width ?: DEF_JITTER_WIDTH\n        myHeight = height ?: DEF_JITTER_HEIGHT\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val x = (2 * Random.nextDouble() - 1) * myWidth * ctx.getResolution(Aes.X)\n        val y = (2 * Random.nextDouble() - 1) * myHeight * ctx.getResolution(Aes.Y)\n        return v.add(DoubleVector(x, y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.JITTER.handlesGroups()\n    }\n\n    companion object {\n\n        val DEF_JITTER_WIDTH = 0.4\n        val DEF_JITTER_HEIGHT = 0.4\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\ninternal class NudgePos(width: Double?, height: Double?) : PositionAdjustment {\n\n    private val myWidth: Double\n    private val myHeight: Double\n\n    init {\n        myWidth = width ?: DEF_NUDGE_WIDTH\n        myHeight = height ?: DEF_NUDGE_HEIGHT\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        //ToDo: getResolution needs to be changed later. In R, the points move in another way when data is continuous.\n        val x = myWidth * ctx.getUnitResolution(Aes.X)\n        val y = myHeight * ctx.getUnitResolution(Aes.Y)\n        return v.add(DoubleVector(x, y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.NUDGE.handlesGroups()\n    }\n\n    companion object {\n        val DEF_NUDGE_WIDTH = 0.0\n        val DEF_NUDGE_HEIGHT = 0.0\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\nobject PositionAdjustments {\n\n    fun identity(): PositionAdjustment {\n        return object : PositionAdjustment {\n\n            override val isIdentity: Boolean\n                get() = true\n\n            override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n                return v\n            }\n\n            override fun handlesGroups(): Boolean {\n                return Meta.IDENTITY.handlesGroups()\n            }\n        }\n    }\n\n    /**\n     * @param aesthetics\n     * @param groupCount\n     * @param width      NULL - default\n     * @return\n     */\n    fun dodge(aesthetics: Aesthetics, groupCount: Int, width: Double?): PositionAdjustment {\n        return DodgePos(aesthetics, groupCount, width)\n    }\n\n    fun stack(aes: Aesthetics, strategy: StackingStrategy): PositionAdjustment {\n        return when (strategy) {\n            StackingStrategy.SPLIT_POSITIVE_NEGATIVE -> StackPos.splitPositiveNegative(aes)\n            StackingStrategy.SUM_POSITIVE_NEGATIVE -> StackPos.sumPositiveNegative(aes)\n        }\n    }\n\n    fun fill(aesthetics: Aesthetics): PositionAdjustment {\n        return FillPos(aesthetics)\n    }\n\n    fun jitter(width: Double?, height: Double?): PositionAdjustment {\n        return JitterPos(width, height)\n    }\n\n    fun nudge(width: Double?, height: Double?): PositionAdjustment {\n        return NudgePos(width, height)\n    }\n\n    fun jitterDodge(\n        aesthetics: Aesthetics,\n        groupCount: Int,\n        width: Double?,\n        jitterWidth: Double?,\n        jitterHeight: Double?\n    ): PositionAdjustment {\n        return JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight)\n    }\n\n    enum class Meta(private val myHandlesGroups: Boolean) {\n        IDENTITY(false),\n        DODGE(true),\n        STACK(true),\n        FILL(true),\n        JITTER(false),\n        NUDGE(false),\n        JITTER_DODGE(true);\n\n        fun handlesGroups(): Boolean {\n            return myHandlesGroups\n        }\n    }\n\n    enum class StackingStrategy {\n        SUM_POSITIVE_NEGATIVE,\n        SPLIT_POSITIVE_NEGATIVE\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal abstract class StackPos(aes: Aesthetics) :\n    PositionAdjustment {\n\n    private val myOffsetByIndex: Map<Int, Double>\n\n    init {\n        myOffsetByIndex = mapIndexToOffset(aes)\n    }\n\n    protected abstract fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double>\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        return v.add(DoubleVector(0.0, myOffsetByIndex[p.index()]!!))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.STACK.handlesGroups()\n    }\n\n    private class SplitPositiveNegative internal constructor(aes: Aesthetics) : StackPos(aes) {\n\n        override fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double> {\n            val offsetByIndex = HashMap<Int, Double>()\n            val negPosBaseByBin = HashMap<Double, Pair<MutableDouble, MutableDouble>>()\n            for (i in 0 until aes.dataPointCount()) {\n                val dataPoint = aes.dataPointAt(i)\n                val x = dataPoint.x()\n                if (SeriesUtil.isFinite(x)) {\n                    if (!negPosBaseByBin.containsKey(x)) {\n                        negPosBaseByBin[x!!] = Pair(\n                            MutableDouble(0.0),\n                            MutableDouble(0.0)\n                        )\n                    }\n\n                    val y = dataPoint.y()\n                    if (SeriesUtil.isFinite(y)) {\n                        val pair = negPosBaseByBin[x]!!\n                        val offset: Double\n                        if (y!! >= 0) {\n                            offset = pair.second.getAndAdd(y)\n                        } else {\n                            offset = pair.first.getAndAdd(y)\n                        }\n                        offsetByIndex[i] = offset\n                    }\n                }\n            }\n\n            return offsetByIndex\n        }\n\n    }\n\n    private class SumPositiveNegative internal constructor(aes: Aesthetics) : StackPos(aes) {\n\n        override fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double> {\n            val offsetByIndex = HashMap<Int, Double>()\n            val baseByBin = HashMap<Double, MutableDouble>()\n            for (i in 0 until aes.dataPointCount()) {\n                val dataPointAes = aes.dataPointAt(i)\n                val x = dataPointAes.x()!!\n                if (SeriesUtil.isFinite(x)) {\n                    if (!baseByBin.containsKey(x)) {\n                        baseByBin[x] = MutableDouble(0.0)\n                    }\n\n                    val y = dataPointAes.y()!!\n                    if (SeriesUtil.isFinite(y)) {\n                        val base = baseByBin[x]!!\n                        val offset = base.getAndAdd(y)\n                        offsetByIndex[i] = offset\n                    }\n                }\n            }\n\n            return offsetByIndex\n        }\n    }\n\n    companion object {\n        fun splitPositiveNegative(aes: Aesthetics): PositionAdjustment {\n            return SplitPositiveNegative(aes)\n        }\n\n        fun sumPositiveNegative(aes: Aesthetics): PositionAdjustment {\n            return SumPositiveNegative(aes)\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninterface LegendKeyElementFactory {\n    fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement\n\n    fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        val size = 2 * strokeWidth + 4\n        return DoubleVector(size, size)\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.linetype\n\nenum class NamedLineType(val code: Int, private val myDashArray: List<Double>?) :\n    LineType {\n    // 0 = blank, 1 = solid, 2 = dashed, 3 = dotted, 4 = dotdash, 5 = longdash, 6 = twodash\n    BLANK(0, null) {\n        override val isBlank: Boolean\n            get() = true\n    },\n    SOLID(1, null) {\n        override val isSolid: Boolean\n            get() = true\n    },\n    DASHED(2, listOf(4.3, 4.3)),\n    DOTTED(3, listOf(1.0, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    DOTDASH(4, listOf(1.0, 3.2, 4.3, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    LONGDASH(5, listOf(7.4, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    TWODASH(6, listOf(2.4, 2.4, 6.4, 2.4));\n\n    override val isSolid: Boolean\n        get() = false\n\n    override val isBlank: Boolean\n        get() = false\n\n    override val dashArray: List<Double>\n        get() {\n            if (!(isSolid || isBlank)) {\n                return myDashArray!!\n            }\n            throw IllegalStateException(\"No dash array in \" + name.lowercase() + \" linetype\")\n        }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\n\n\n// redundant `final` in overridden members are necessary due to kotlin-native issue:\n// `Not in vtable error` #2865\n// https://github.com/JetBrains/kotlin-native/issues/2865\nenum class NamedShape(\n    @Suppress(\"RedundantModalityModifier\")\n    final override val code: Int,\n    val isSolid: Boolean = false,\n    val isFilled: Boolean = false,\n    private val isSmall: Boolean = false\n) : PointShape {\n\n    STICK_SQUARE(0),\n    STICK_CIRCLE(1),\n    STICK_TRIANGLE_UP(2),\n    STICK_PLUS(3),\n    STICK_CROSS(4),\n    STICK_DIAMOND(5),\n    STICK_TRIANGLE_DOWN(6),\n    STICK_SQUARE_CROSS(7),\n    STICK_STAR(8),\n    STICK_DIAMOND_PLUS(9),\n    STICK_CIRCLE_PLUS(10),\n    STICK_TRIANGLE_UP_DOWN(11),\n    STICK_SQUARE_PLUS(12),\n    STICK_CIRCLE_CROSS(13),\n    STICK_SQUARE_TRIANGLE_UP(14),\n\n    SOLID_SQUARE(15, true, false),\n    SOLID_CIRCLE(16, true, false),\n    SOLID_TRIANGLE_UP(17, true, false),\n    SOLID_DIAMOND(18, true, false, true),\n\n    SOLID_CIRCLE_2(19, true, false), // same as SOLID_CIRCLE\n    BULLET(20, true, false, true), // same as SOLID_CIRCLE but smaller\n\n    FILLED_CIRCLE(21, false, true),\n    FILLED_SQUARE(22, false, true),\n    FILLED_DIAMOND(23, false, true),\n    FILLED_TRIANGLE_UP(24, false, true),\n    FILLED_TRIANGLE_DOWN(25, false, true);\n\n    val isHollow: Boolean\n        get() = !(isFilled || isSolid)\n\n\n    @Suppress(\"RedundantModalityModifier\")\n    final override fun size(dataPoint: DataPointAesthetics): Double {\n        return if (isSmall)\n            AesScaling.circleDiameterSmaller(dataPoint)\n        else\n            AesScaling.circleDiameter(dataPoint)\n    }\n\n    @Suppress(\"RedundantModalityModifier\")\n    final override fun strokeWidth(dataPoint: DataPointAesthetics): Double {\n        // 'size' aes is used for other purpose and\n        // no 'stroke width' aes (?)\n        return if (isSolid)\n            0.0\n        else\n            1.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.render.point.NamedShape.*\nimport jetbrains.datalore.plot.base.render.point.symbol.Glyph\nimport jetbrains.datalore.plot.base.render.point.symbol.Glyphs\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimObject\n\nobject PointShapeSvg {\n    fun create(shape: PointShape, location: DoubleVector, p: DataPointAesthetics, fatten: Double = 1.0): SvgSlimObject {\n        if (shape == TinyPointShape) {\n            return createTinyDotShape(\n                location,\n                p\n            )\n        }\n        if (shape is NamedShape) {\n            return createNamedShape(\n                shape,\n                location,\n                p,\n                fatten\n            )\n        }\n        throw IllegalArgumentException(\"Unsupported point shape code ${shape.code} ${shape::class.simpleName}\")\n    }\n\n    private fun createTinyDotShape(location: DoubleVector, p: DataPointAesthetics): SvgSlimObject {\n        val r = SvgSlimElements.rect(location.x - 0.5, location.y - 0.5, 1.0, 1.0)\n        val color = p.color()!!\n        val alpha = AestheticsUtil.alpha(color, p)\n        r.setFill(color, alpha)\n        r.setStrokeWidth(0.0)\n        return r\n    }\n\n    private fun createNamedShape(\n        shape: NamedShape,\n        location: DoubleVector,\n        p: DataPointAesthetics,\n        fatten: Double\n    ): SvgSlimObject {\n        val glyph = createSlimGlyph(\n            shape,\n            location,\n            shape.size(p) * fatten\n        )\n        AestheticsUtil.decorate(glyph, shape.isFilled, shape.isSolid, p, shape.strokeWidth(p))\n        return glyph\n    }\n\n    private fun createSlimGlyph(shape: NamedShape, location: DoubleVector, size: Double): Glyph {\n        when (shape) {\n            STICK_SQUARE, SOLID_SQUARE, FILLED_SQUARE -> return Glyphs.square(location, size)\n\n            STICK_CIRCLE, SOLID_CIRCLE, SOLID_CIRCLE_2     // same as SOLID_CIRCLE\n                , BULLET             // same as SOLID_CIRCLE but smaller\n                , FILLED_CIRCLE -> return Glyphs.circle(location, size)\n\n            STICK_TRIANGLE_UP, SOLID_TRIANGLE_UP, FILLED_TRIANGLE_UP -> return Glyphs.triangleUp(location, size)\n\n            STICK_TRIANGLE_DOWN, FILLED_TRIANGLE_DOWN -> return Glyphs.triangleDown(location, size)\n\n            STICK_DIAMOND, SOLID_DIAMOND, FILLED_DIAMOND -> return Glyphs.diamond(location, size)\n\n            STICK_PLUS -> return Glyphs.stickPlus(location, size)\n            STICK_CROSS -> return Glyphs.stickCross(location, size)\n            STICK_SQUARE_CROSS -> return Glyphs.stickSquareCross(location, size)\n            STICK_STAR -> return Glyphs.stickStar(location, size)\n            STICK_DIAMOND_PLUS -> return Glyphs.stickDiamondPlus(location, size)\n            STICK_CIRCLE_PLUS -> return Glyphs.stickCirclePlus(location, size)\n            STICK_TRIANGLE_UP_DOWN -> return Glyphs.stickTriangleUpDown(location, size)\n            STICK_SQUARE_PLUS -> return Glyphs.stickSquarePlus(location, size)\n            STICK_CIRCLE_CROSS -> return Glyphs.stickCircleCross(location, size)\n            STICK_SQUARE_TRIANGLE_UP -> return Glyphs.stickSquareTriangleUp(location, size)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject TinyPointShape : PointShape {\n\n    override val code: Int\n        get() = 46 // ASCII dot `.`\n\n    override fun size(dataPoint: DataPointAesthetics): Double {\n        return 1.0\n    }\n\n    override fun strokeWidth(dataPoint: DataPointAesthetics): Double {\n        return 0.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nclass CircleGlyph(location: DoubleVector, width: Double) : SingletonGlyph(location, width) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        return SvgSlimElements.circle(location.x, location.y, width / 2)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.cos\n\ninternal class CrossGlyph @JvmOverloads constructor(location: DoubleVector, size: Double, inscribedInCircle: Boolean = true) : TwoShapeGlyph() {\n\n    init {\n        val cx = location.x\n        val cy = location.y\n        val w = if (inscribedInCircle)\n            size * CIRCLE_WIDTH_ADJUST_RATIO\n        else\n            size\n        val half = w / 2 // half width of inner square\n\n        val backSlashLine = SvgSlimElements.line(\n                cx - half,\n                cy - half,\n                cx + half,\n                cy + half)\n        val slashLine = SvgSlimElements.line(\n                cx - half,\n                cy + half,\n                cx + half,\n                cy - half)\n\n        setShapes(backSlashLine, slashLine)\n    }\n\n    companion object {\n        val CIRCLE_WIDTH_ADJUST_RATIO = cos(PI / 4)   // cos(45)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nclass DiamondGlyph(location: DoubleVector, width: Double) : SingletonGlyph(location, width) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        val half = width / 2\n        val x = doubleArrayOf(half, width, half, 0.0)\n        val y = doubleArrayOf(0.0, half, width, half)\n        val ox = location.x - half\n        val oy = location.y - half\n        for (i in 0..3) {\n            x[i] = ox + x[i]\n            y[i] = oy + y[i]\n        }\n\n        val pathData = GlyphUtil.buildPathData(\n            x.asList(),\n            y.asList()\n        )\n        return SvgSlimElements.path(pathData)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\n\ninternal class GlyphPair(private val myG1: Glyph, private val myG2: Glyph) :\n    Glyph {\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        myG1.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n        myG2.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myG1.appendTo(g)\n        myG2.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.vis.svg.SvgPathData\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\n\ninternal object GlyphUtil {\n    fun buildPathData(xs: Collection<Double>, ys: Collection<Double>): SvgPathData {\n        require(xs.size == ys.size) { \"Sizes of X/Y collections must be equal\" }\n\n        if (xs.isEmpty()) {\n            return SvgPathData.EMPTY\n        }\n\n        val builder = SvgPathDataBuilder(true)\n            .moveTo(Iterables[xs, 0], Iterables[ys, 0])\n            .interpolatePoints(xs, ys, SvgPathDataBuilder.Interpolation.LINEAR)\n            .closePath()\n\n        return builder.build()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nobject Glyphs {\n    fun square(location: DoubleVector, width: Double): Glyph {\n        return SquareGlyph(location, width)\n    }\n\n    fun circle(location: DoubleVector, width: Double): Glyph {\n        return CircleGlyph(location, width)\n    }\n\n    fun diamond(location: DoubleVector, width: Double): Glyph {\n        return DiamondGlyph(location, width)\n    }\n\n    fun triangleUp(location: DoubleVector, width: Double): Glyph {\n        return TriangleGlyph(location, width, true)\n    }\n\n    fun triangleDown(location: DoubleVector, width: Double): Glyph {\n        return TriangleGlyph(location, width, false)\n    }\n\n    fun stickPlus(location: DoubleVector, width: Double): Glyph {\n        return PlusGlyph(location, width)\n    }\n\n    fun stickCross(location: DoubleVector, width: Double): Glyph {\n        return CrossGlyph(location, width)\n    }\n\n    fun stickSquareCross(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            CrossGlyph(location, size, false)\n        )\n    }\n\n    fun stickStar(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            PlusGlyph(location, size),\n            CrossGlyph(location, size)\n        )\n    }\n\n    fun stickDiamondPlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            DiamondGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickCirclePlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            CircleGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickTriangleUpDown(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            TriangleGlyph(location, size, true),\n            TriangleGlyph(location, size, false)\n        )\n    }\n\n    fun stickSquarePlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickCircleCross(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            CircleGlyph(location, size),\n            CrossGlyph(location, size)\n        )\n    }\n\n    fun stickSquareTriangleUp(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            TriangleGlyph(\n                location,\n                size,\n                true,\n                true\n            )\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal abstract class MultiShapeGlyph : Glyph {\n    protected fun update(shape: SvgSlimShape?, fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        shape?.setFill(fill, fillAlpha)\n        shape?.setStroke(stroke, strokeAlpha)\n        shape?.setStrokeWidth(strokeWidth)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\ninternal class PlusGlyph(location: DoubleVector, size: Double) : TwoShapeGlyph() {\n\n    init {\n        val half = size / 2\n        val ox = location.x - half\n        val oy = location.y - half\n        val hLine = SvgSlimElements.line(\n                0 + ox,\n                half + oy,\n                size + ox,\n                half + oy)\n        val vLine = SvgSlimElements.line(\n                half + ox,\n                0 + oy,\n                half + ox,\n                size + oy)\n\n        setShapes(hLine, vLine)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nabstract class SingletonGlyph : Glyph {\n    private val myShape: SvgSlimShape\n\n    protected constructor(shape: SvgSlimShape) {\n        myShape = shape\n    }\n\n    protected constructor(location: DoubleVector, width: Double) {\n        myShape = createShape(location, width)\n    }\n\n    protected abstract fun createShape(location: DoubleVector, width: Double): SvgSlimShape\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        myShape.setFill(fill, fillAlpha)\n        myShape.setStroke(stroke, strokeAlpha)\n        myShape.setStrokeWidth(strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myShape.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal class SquareGlyph(location: DoubleVector, size: Double) : SingletonGlyph(location, size) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        return SvgSlimElements.rect(\n                location.x - width / 2,\n                location.y - width / 2,\n                width,\n                width)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.sin\n\ninternal class TriangleGlyph @JvmOverloads constructor(location: DoubleVector, size: Double, pointingUp: Boolean, inscribedInSquare: Boolean = false) : SingletonGlyph(\n    createTriangleShape(\n        location,\n        size,\n        pointingUp,\n        inscribedInSquare\n    )\n) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        throw IllegalStateException(\"Not applicable\")\n    }\n\n    companion object {\n        // equilateral triangle\n        private val SIDE_TO_HEIGHT_RATIO = sin(PI / 3)\n        private const val VERTICAL_OFFSET_RATIO = 1.0 / 12\n\n        private fun createTriangleShape(\n                location: DoubleVector, size: Double, pointingUp: Boolean, inscribedInSquare: Boolean): SvgSlimShape {\n            val half = size / 2\n            val height = if (inscribedInSquare)\n                size\n            else\n                SIDE_TO_HEIGHT_RATIO * size\n\n            val vOffset = if (inscribedInSquare)\n                0.0\n            else\n                height * VERTICAL_OFFSET_RATIO\n\n            val x: DoubleArray\n            val y: DoubleArray\n            var dy = (size - height) / 2\n            if (pointingUp) {\n                dy -= vOffset\n                x = doubleArrayOf(half, size, 0.0)\n                y = doubleArrayOf(0.0 + dy, height + dy, height + dy)\n            } else {\n                dy += vOffset\n                x = doubleArrayOf(0.0, size, half)\n                y = doubleArrayOf(0.0 + dy, 0.0 + dy, height + dy)\n            }\n\n            val ox = location.x - half\n            val oy = location.y - half\n            for (i in 0..2) {\n                x[i] = ox + x[i]\n                y[i] = oy + y[i]\n            }\n\n            val pathData =\n                GlyphUtil.buildPathData(\n                    x.asList(),\n                    y.asList()\n                )\n            return SvgSlimElements.path(pathData)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal abstract class TwoShapeGlyph : MultiShapeGlyph() {\n    private var myS1: SvgSlimShape? = null\n    private var myS2: SvgSlimShape? = null\n\n    protected fun setShapes(s1: SvgSlimShape, s2: SvgSlimShape) {\n        myS1 = s1\n        myS2 = s2\n    }\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        update(myS1, fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n        update(myS2, fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myS1!!.appendTo(g)\n        myS2!!.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nclass GroupComponent : SvgComponent() {\n    override fun buildComponent() {\n        // empty\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.SvgColors\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport jetbrains.datalore.vis.svg.SvgPathElement\n\n/**\n * Poly-line\n */\nclass LinePath(builder: SvgPathDataBuilder) : SvgComponent() {\n\n    private val myPath: SvgPathElement\n    private var myDashArray: List<Double>? = null\n\n    init {\n        myPath = SvgPathElement(builder.build())\n        myPath.fill().set(SvgColors.NONE)\n        val lineWidth = 1.0\n        myPath.strokeWidth().set(lineWidth)\n\n        add(myPath)\n    }\n\n    /*\n  private void build(List<DoubleVector> points, boolean isPolygon) {\n    SvgPathDataBuilder builder = new SvgPathDataBuilder(true);\n\n    List<DoubleVector> curSegment = new ArrayList<>();\n    boolean interpolate = false;\n    for (DoubleVector point : points) {\n      if (point == END_OF_SUBPATH) {\n        buildSegment(builder, curSegment, interpolate);\n        if (isPolygon) {\n          builder.closePath();\n        }\n        curSegment = new ArrayList<>();\n      } else {\n        curSegment.add(point);\n      }\n    }\n    buildSegment(builder, curSegment, interpolate);\n    if (isPolygon) {\n      builder.closePath();\n    }\n\n    myPath = new SvgPathElement(builder.build());\n    myPath.fill().set(SvgColor.NONE);\n    double lineWidth = 1.;\n    myPath.strokeWidth().set(lineWidth);\n\n    add(myPath);\n  }\n  */\n\n    override fun buildComponent() {\n\n    }\n\n    fun color(): WritableProperty<Color?> {\n        return myPath.strokeColor()\n    }\n\n    fun fill(): WritableProperty<Color?> {\n        return myPath.fillColor()\n    }\n\n    fun width(): WritableProperty<Double> {\n        return object : WritableProperty<Double> {\n            override fun set(value: Double) {\n                myPath.strokeWidth().set(value)\n                updatePathDashArray()\n            }\n        }\n    }\n\n    fun dashArray(): WritableProperty<List<Double>> {\n        return object : WritableProperty<List<Double>> {\n            override fun set(value: List<Double>) {\n                myDashArray = ArrayList(value)\n                updatePathDashArray()\n            }\n        }\n    }\n\n    private fun updatePathDashArray() {\n        if (!(myDashArray == null || myDashArray!!.isEmpty())) {\n            val w = myPath.strokeWidth().get()\n            val width = w ?: 1.0\n            StrokeDashArraySupport.apply(\n                myPath,\n                width,\n                myDashArray!!\n            )\n        }\n    }\n\n    companion object {\n        val END_OF_SUBPATH: DoubleVector? = null  // End of Sub Path\n\n        fun line(points: Iterable<DoubleVector>): LinePath {\n            return LinePath(\n                pathBuilder(\n                    points,\n                    false\n                )\n            )\n        }\n\n        fun polygon(points: Iterable<DoubleVector?>): LinePath {\n            return LinePath(\n                pathBuilder(\n                    points,\n                    true\n                )\n            )\n        }\n\n        private fun pathBuilder(points: Iterable<DoubleVector?>, isPolygon: Boolean): SvgPathDataBuilder {\n            val builder = SvgPathDataBuilder(true)\n\n            var curSegment: MutableList<DoubleVector> = ArrayList()\n            val interpolate = false\n            for (point in points) {\n                if (point === END_OF_SUBPATH) {\n                    buildSegment(\n                        builder,\n                        curSegment,\n                        interpolate\n                    )\n                    if (isPolygon) {\n                        builder.closePath()\n                    }\n                    curSegment = ArrayList()\n                } else {\n                    curSegment.add(point!!)\n                }\n            }\n            buildSegment(\n                builder,\n                curSegment,\n                interpolate\n            )\n            if (isPolygon) {\n                builder.closePath()\n            }\n\n            return builder\n        }\n\n        private fun buildSegment(builder: SvgPathDataBuilder, curSegment: List<DoubleVector>, interpolate: Boolean) {\n            if (curSegment.isEmpty()) {\n                return\n            }\n            builder.moveTo(curSegment[0])\n            builder.interpolatePoints(\n                curSegment,\n                if (interpolate) SvgPathDataBuilder.Interpolation.CARDINAL else SvgPathDataBuilder.Interpolation.LINEAR\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.vis.svg.SvgConstants\nimport jetbrains.datalore.vis.svg.SvgElement\n\n/**\n * The counterpart of SVG 'stroke-dasharray' attribute but\n * length of alternating dashes and gaps\n * is defined as multiples of line width\n */\nobject StrokeDashArraySupport {\n    fun apply(element: SvgElement, strokeWidth: Double, dashArray: List<Double>) {\n        val sb = StringBuilder()\n        for (relativeLength in dashArray) {\n            val length = relativeLength * strokeWidth\n            if (sb.length > 0) {\n                sb.append(',')\n            }\n            sb.append(length.toString())\n        }\n        element.getAttribute(SvgConstants.SVG_STROKE_DASHARRAY_ATTRIBUTE).set(sb.toString())\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.vis.svg.*\nimport jetbrains.datalore.vis.svg.SvgGraphicsElement.Companion.CLIP_BOUNDS_JFX\n\nabstract class SvgComponent {\n    private var myIsBuilt: Boolean = false\n    private var myIsBuilding: Boolean = false\n    private val myRootGroup = SvgGElement()\n    private val myChildComponents = ArrayList<SvgComponent>()\n    private var myOrigin = DoubleVector.ZERO\n    private var myRotationAngle = 0.0\n    private var myCompositeRegistration = CompositeRegistration()\n\n    protected val childComponents: List<SvgComponent>\n        get() {\n            require(myIsBuilt) { \"Plot has not yet built\" }\n            return ArrayList(myChildComponents)\n        }\n\n    val rootGroup: SvgGElement\n        get() {\n            ensureBuilt()\n            return myRootGroup\n        }\n\n    fun ensureBuilt() {\n        if (!(myIsBuilt || myIsBuilding)) {\n            buildComponentIntern()\n        }\n    }\n\n    private fun buildComponentIntern() {\n        try {\n            myIsBuilding = true\n            buildComponent()\n        } finally {\n            myIsBuilding = false\n            myIsBuilt = true\n        }\n    }\n\n    protected abstract fun buildComponent()\n\n    protected fun <EventT> rebuildHandler(): EventHandler<EventT> {\n        return object : EventHandler<EventT> {\n            override fun onEvent(event: EventT) {\n                needRebuild()\n            }\n        }\n    }\n\n    protected fun needRebuild() {\n        if (myIsBuilt) {\n            clear()\n            buildComponentIntern()\n        }\n    }\n\n    protected fun reg(r: Registration) {\n        myCompositeRegistration.add(r)\n    }\n\n    fun clear() {\n        myIsBuilt = false\n        for (child in myChildComponents) {\n            child.clear()\n        }\n        myChildComponents.clear()\n        myRootGroup.children().clear()\n        myCompositeRegistration.remove()\n        myCompositeRegistration = CompositeRegistration()\n    }\n\n    fun add(child: SvgComponent) {\n        myChildComponents.add(child)\n        add(child.rootGroup)\n    }\n\n    fun add(node: SvgNode) {\n        myRootGroup.children().add(node)\n    }\n\n    fun moveTo(p: DoubleVector) {\n        myOrigin = p\n        myRootGroup.transform().set(\n            buildTransform(\n                myOrigin,\n                myRotationAngle\n            )\n        )\n    }\n\n    fun moveTo(x: Double, y: Double) {\n        moveTo(DoubleVector(x, y))\n    }\n\n    /**\n     * @param angle in degrees\n     */\n    fun rotate(angle: Double) {\n        myRotationAngle = angle\n        myRootGroup.transform().set(\n            buildTransform(\n                myOrigin,\n                myRotationAngle\n            )\n        )\n    }\n\n    fun toRelativeCoordinates(location: DoubleVector): DoubleVector {\n        return rootGroup.pointToTransformedCoordinates(location)\n    }\n\n    fun toAbsoluteCoordinates(location: DoubleVector): DoubleVector {\n        return rootGroup.pointToAbsoluteCoordinates(location)\n    }\n\n    fun clipBounds(rect: DoubleRectangle) {\n        val clipPathElement = SvgClipPathElement().apply {\n            id().set(SvgUID.get(CLIP_PATH_ID_PREFIX))\n            children().add(SvgRectElement().apply {\n                x().set(rect.left)\n                y().set(rect.top)\n                width().set(rect.width)\n                height().set(rect.height)\n            }\n            )\n        }\n        val defs = SvgDefsElement().apply {\n            children().add(clipPathElement)\n        }\n        add(defs)\n\n        rootGroup.clipPath().set(SvgIRI(clipPathElement.id().get()!!))\n        rootGroup.setAttribute(CLIP_BOUNDS_JFX, rect) // JFX workaround\n    }\n\n    fun addClassName(className: String) {\n        myRootGroup.addClass(className)\n    }\n\n    companion object {\n        const val CLIP_PATH_ID_PREFIX = \"\" // No prefix\n\n        fun buildTransform(origin: DoubleVector, rotationAngle: Double): SvgTransform {\n            val transformBuilder = SvgTransformBuilder()\n            if (origin != DoubleVector.ZERO) {\n                transformBuilder.translate(origin.x, origin.y)\n            }\n            if (rotationAngle != 0.0) {\n                transformBuilder.rotate(rotationAngle)\n            }\n            return transformBuilder.build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.random.RandomString.randomString\nimport kotlin.native.concurrent.ThreadLocal\n\n// In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n// See:  https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n// Required mutations:\n//      -   `suffixGen`\n@ThreadLocal\nobject SvgUID {\n    private var suffixGen: () -> Any = { randomString(6) }\n\n    fun setUpForTest() {\n        val incrementalId = IncrementalId()\n        suffixGen = { incrementalId.next() }\n    }\n\n    fun get(prefix: String): String {\n        return \"$prefix${suffixGen()}\"\n    }\n\n    private class IncrementalId {\n        private var nextIndex = 0\n        fun next() = (\"clip-${nextIndex++}\")\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.SvgConstants\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_STYLE_ATTRIBUTE\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_ANCHOR_END\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_ANCHOR_MIDDLE\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_DY_CENTER\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_DY_TOP\nimport jetbrains.datalore.vis.svg.SvgTextElement\n\nclass TextLabel(text: String) : SvgComponent() {\n    private val myText: SvgTextElement = SvgTextElement(text)\n    private var myTextColor: Color? = null\n    private var myFontSize = 0.0\n    private var myFontWeight: String? = null\n    private var myFontFamily: String? = null\n    private var myFontStyle: String? = null\n\n    init {\n        rootGroup.children().add(myText)\n    }\n\n    override fun buildComponent() {\n\n    }\n\n    fun textColor(): WritableProperty<Color?> {\n        return object : WritableProperty<Color?> {\n            override fun set(value: Color?) {\n                // set attribute for svg->canvas mapping to work\n                myText.fillColor()\n\n                // duplicate in 'style' to override styles of container\n                myTextColor = value\n                updateStyleAttribute()\n            }\n        }\n    }\n\n    fun textOpacity(): WritableProperty<Double?> {\n        return myText.fillOpacity()\n    }\n\n    fun x(): Property<Double?> {\n        return myText.x()\n    }\n\n    fun y(): Property<Double?> {\n        return myText.y()\n    }\n\n    fun setHorizontalAnchor(anchor: HorizontalAnchor) {\n        myText.setAttribute(SvgConstants.SVG_TEXT_ANCHOR_ATTRIBUTE, toTextAnchor(anchor))\n    }\n\n    fun setVerticalAnchor(anchor: VerticalAnchor) {\n        // replace \"dominant-baseline\" with \"dy\" because \"dominant-baseline\" is not supported by Batik\n        //    myText.setAttribute(\"dominant-baseline\", toDominantBaseline(anchor));\n        myText.setAttribute(SvgConstants.SVG_TEXT_DY_ATTRIBUTE, toDY(anchor))\n    }\n\n    fun setFontSize(px: Double) {\n        myFontSize = px\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param cssName : normal, bold, bolder, lighter\n     */\n    fun setFontWeight(cssName: String?) {\n        myFontWeight = cssName\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param cssName : normal, italic, oblique\n     */\n    fun setFontStyle(cssName: String?) {\n        myFontStyle = cssName\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param fontFamily : for example 'sans-serif' or 'Times New Roman'\n     */\n    fun setFontFamily(fontFamily: String?) {\n        myFontFamily = fontFamily\n        updateStyleAttribute()\n    }\n\n    private fun updateStyleAttribute() {\n        val sb = StringBuilder()\n        if (myTextColor != null) {\n            sb.append(\"fill:\").append(myTextColor!!.toHexColor()).append(';')\n        }\n\n        if (myFontSize > 0 && myFontFamily != null) {\n            // use font shorthand because this format is expected by svg -> canvas mapper\n            // font: [style] [weight] size family;\n            val fnt = StringBuilder()\n            if (!myFontStyle.isNullOrEmpty()) {\n                fnt.append(myFontStyle!!).append(' ')\n            }\n            if (!myFontWeight.isNullOrEmpty()) {\n                fnt.append(myFontWeight!!).append(' ')\n            }\n            fnt.append(myFontSize).append(\"px \")\n            fnt.append(myFontFamily!!).append(\";\")\n\n            sb.append(\"font:\").append(fnt)\n        } else {\n            // set each property separately\n            if (!myFontStyle.isNullOrBlank()) {\n                sb.append(\"font-style:\").append(myFontStyle!!).append(';')\n            }\n            if (!myFontWeight.isNullOrEmpty()) {\n                sb.append(\"font-weight:\").append(myFontWeight!!).append(';')\n            }\n            if (myFontSize > 0) {\n                sb.append(\"font-size:\").append(myFontSize).append(\"px;\")\n            }\n            if (!myFontFamily.isNullOrEmpty()) {\n                sb.append(\"font-family:\").append(myFontFamily!!).append(';')\n            }\n        }\n\n        myText.setAttribute(SVG_STYLE_ATTRIBUTE, sb.toString())\n    }\n\n    private fun toTextAnchor(anchor: HorizontalAnchor): String? {\n        return when (anchor) {\n            HorizontalAnchor.LEFT -> null // default - \"start\";\n            HorizontalAnchor.MIDDLE -> SVG_TEXT_ANCHOR_MIDDLE\n            HorizontalAnchor.RIGHT -> SVG_TEXT_ANCHOR_END\n        }\n    }\n\n    private fun toDominantBaseline(anchor: VerticalAnchor): String? {\n        return when (anchor) {\n            VerticalAnchor.TOP -> \"hanging\"\n            VerticalAnchor.CENTER -> \"central\"\n            VerticalAnchor.BOTTOM -> null // default - \"alphabetic\";\n        }\n    }\n\n    private fun toDY(anchor: VerticalAnchor): String? {\n        return when (anchor) {\n            VerticalAnchor.TOP -> SVG_TEXT_DY_TOP\n            VerticalAnchor.CENTER -> SVG_TEXT_DY_CENTER\n            VerticalAnchor.BOTTOM -> null // default\n        }\n    }\n\n    enum class HorizontalAnchor {\n        LEFT, RIGHT, MIDDLE\n    }\n\n    enum class VerticalAnchor {\n        TOP, BOTTOM, CENTER\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.Scale\n\ninternal abstract class AbstractScale<DomainT, T> : Scale<T> {\n\n    private val definedBreaks: List<DomainT>?\n    private val definedLabels: List<String>?\n\n    final override val name: String\n    final override val mapper: ((Double?) -> T?)\n    final override var multiplicativeExpand = 0.0\n        protected set\n    final override var additiveExpand = 0.0\n        protected set\n    final override val labelFormatter: ((Any) -> String)?\n\n    override val isContinuous: Boolean\n        get() = false\n\n    override val isContinuousDomain: Boolean\n        get() = false\n\n    override val breaks: List<Any>\n        get() {\n            check(hasBreaks()) { \"No breaks defined for scale $name\" }\n            @Suppress(\"UNCHECKED_CAST\")\n            return definedBreaks as List<Any>\n        }\n\n    override val labels: List<String>\n        get() {\n            check(labelsDefined()) { \"No labels defined for scale $name\" }\n            return definedLabels!!\n        }\n\n    protected constructor(name: String, mapper: ((Double?) -> T?), breaks: List<DomainT>? = null) {\n        this.name = name\n        this.mapper = mapper\n        this.definedBreaks = breaks\n        definedLabels = null\n        labelFormatter = null\n    }\n\n    protected constructor(b: AbstractBuilder<DomainT, T>) {\n        name = b.myName\n        definedBreaks = b.myBreaks\n        definedLabels = b.myLabels\n        labelFormatter = b.myLabelFormatter\n        mapper = b.myMapper\n\n        multiplicativeExpand = b.myMultiplicativeExpand\n        additiveExpand = b.myAdditiveExpand\n    }\n\n    override fun hasBreaks(): Boolean {\n        return definedBreaks != null\n    }\n\n    override fun hasLabels(): Boolean {\n        return labelsDefined()\n    }\n\n    private fun labelsDefined(): Boolean {\n        return definedLabels != null\n    }\n\n    protected abstract class AbstractBuilder<DomainT, T>(scale: AbstractScale<DomainT, T>) : Scale.Builder<T> {\n        internal val myName: String = scale.name\n\n        internal var myBreaks: List<DomainT>? = scale.definedBreaks\n        internal var myLabels: List<String>? = scale.definedLabels\n        internal var myLabelFormatter: ((Any) -> String)? = scale.labelFormatter\n        internal var myMapper: (Double?) -> T? = scale.mapper\n\n        internal var myMultiplicativeExpand: Double = scale.multiplicativeExpand\n        internal var myAdditiveExpand: Double = scale.additiveExpand\n\n        override fun breaks(l: List<Any>): Scale.Builder<T> {\n            myBreaks = l.map {\n                @Suppress(\"UNCHECKED_CAST\")\n                it as DomainT\n            }\n            return this\n        }\n\n        override fun labels(l: List<String>): Scale.Builder<T> {\n            myLabels = l\n            return this\n        }\n\n        override fun labelFormatter(v: (Any) -> String): Scale.Builder<T> {\n            myLabelFormatter = v\n            return this\n        }\n\n        override fun mapper(m: (Double?) -> T?): Scale.Builder<T> {\n            myMapper = m\n            return this\n        }\n\n        override fun multiplicativeExpand(v: Double): Scale.Builder<T> {\n            myMultiplicativeExpand = v\n            return this\n        }\n\n        override fun additiveExpand(v: Double): Scale.Builder<T> {\n            myAdditiveExpand = v\n            return this\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\nimport jetbrains.datalore.plot.base.scale.transform.Transforms\nimport jetbrains.datalore.plot.base.scale.transform.Transforms.createBreaksGeneratorForTransformedDomain\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\ninternal class ContinuousScale<T> : AbstractScale<Double, T> {\n\n    private val continuousTransform: ContinuousTransform\n    private val customBreaksGenerator: BreaksGenerator?\n\n    override val isContinuous: Boolean\n    override val isContinuousDomain: Boolean = true\n    override val domainLimits: Pair<Double, Double>\n\n    override val transform: Transform\n        get() = continuousTransform\n\n    override val breaksGenerator: BreaksGenerator\n        get() {\n            return if (customBreaksGenerator != null) {\n                Transforms.BreaksGeneratorForTransformedDomain(continuousTransform, customBreaksGenerator)\n            } else {\n                createBreaksGeneratorForTransformedDomain(continuousTransform, labelFormatter)\n            }\n        }\n\n    constructor(\n        name: String,\n        mapper: ((Double?) -> T?),\n        continuousOutput: Boolean\n    ) : super(name, mapper) {\n        isContinuous = continuousOutput\n        domainLimits = Pair(Double.NEGATIVE_INFINITY, Double.POSITIVE_INFINITY)\n        continuousTransform = Transforms.IDENTITY\n        customBreaksGenerator = null\n\n        // see: https://ggplot2.tidyverse.org/reference/scale_continuous.html\n        // defaults for continuous scale.\n        multiplicativeExpand = 0.05\n        additiveExpand = 0.0\n    }\n\n    private constructor(b: MyBuilder<T>) : super(b) {\n        continuousTransform = b.myContinuousTransform\n        customBreaksGenerator = b.myCustomBreaksGenerator\n        isContinuous = b.myContinuousOutput\n        val lower = if (SeriesUtil.isFinite(b.myLowerLimit)) b.myLowerLimit!! else Double.NEGATIVE_INFINITY\n        val upper = if (SeriesUtil.isFinite(b.myUpperLimit)) b.myUpperLimit!! else Double.POSITIVE_INFINITY\n        domainLimits = Pair(\n            min(lower, upper),\n            max(lower, upper)\n        )\n    }\n\n    override fun hasBreaksGenerator() = true\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        return if (v is Number) {\n            val d = v.toDouble()\n            d.isFinite() && d >= domainLimits.first && d <= domainLimits.second\n        } else {\n            false\n        }\n    }\n\n    override fun hasDomainLimits(): Boolean {\n        return domainLimits.first.isFinite() || domainLimits.second.isFinite()\n    }\n\n    override fun with(): Scale.Builder<T> {\n        return MyBuilder(this)\n    }\n\n\n    private class MyBuilder<T>(scale: ContinuousScale<T>) : AbstractBuilder<Double, T>(scale) {\n        var myContinuousTransform: ContinuousTransform = scale.continuousTransform\n        var myCustomBreaksGenerator: BreaksGenerator? = scale.customBreaksGenerator\n        var myLowerLimit: Double? = scale.domainLimits.first\n        var myUpperLimit: Double? = scale.domainLimits.second\n\n        val myContinuousOutput: Boolean = scale.isContinuous\n\n        override fun lowerLimit(v: Double): Scale.Builder<T> {\n            require(v.isFinite()) { \"`lower` can't be $v\" }\n            myLowerLimit = v\n            return this\n        }\n\n        override fun upperLimit(v: Double): Scale.Builder<T> {\n            require(v.isFinite()) { \"`upper` can't be $v\" }\n            myUpperLimit = v\n            return this\n        }\n\n        override fun limits(domainValues: List<Any>): Scale.Builder<T> {\n            throw IllegalArgumentException(\"Can't apply discrete limits to scale with continuous domain\")\n        }\n\n        override fun continuousTransform(v: ContinuousTransform): Scale.Builder<T> {\n            myContinuousTransform = v\n            return this\n        }\n\n        override fun breaksGenerator(v: BreaksGenerator): Scale.Builder<T> {\n            myCustomBreaksGenerator = v\n            return this\n        }\n\n        override fun build(): Scale<T> {\n            return ContinuousScale(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.DiscreteTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\n\ninternal class DiscreteScale<T> : AbstractScale<Any, T> {\n\n    private val discreteTransform: DiscreteTransform\n\n    override val breaks: List<Any>\n        get() {\n            return if (!hasDomainLimits()) {\n                super.breaks\n            } else {\n                // Filter and preserve the order defined by limits.\n                val breaksSet = super.breaks.toSet()\n                discreteTransform.domainLimits.filter { it in breaksSet }\n            }\n        }\n\n    override val labels: List<String>\n        get() {\n            val labels = super.labels\n            return if (!hasDomainLimits() || labels.isEmpty()) {\n                labels\n            } else {\n                val breaks = super.breaks\n                val breakLabels = breaks.mapIndexed { i, _ -> labels[i % labels.size] }\n\n                // Filter and preserve the order defined by limits.\n                val labelByBreak = breaks.zip(breakLabels).toMap()\n                discreteTransform.domainLimits\n                    .filter { labelByBreak.containsKey(it) }\n                    .map { labelByBreak.getValue(it) }\n            }\n        }\n\n    override val transform: Transform\n        get() = discreteTransform\n\n    override val breaksGenerator: BreaksGenerator\n        get() = throw IllegalStateException(\"No breaks generator for discrete scale '$name'\")\n\n    override val domainLimits: Pair<Double, Double>\n        get() = throw IllegalStateException(\"Not applicable to scale with discrete domain '$name'\")\n\n    constructor(\n        name: String,\n        domainValues: Collection<Any>,\n        mapper: ((Double?) -> T?)\n    ) : super(name, mapper, breaks = domainValues.toList()) {\n        discreteTransform = DiscreteTransform(domainValues, emptyList())\n\n        // see: https://ggplot2.tidyverse.org/reference/scale_continuous.html\n        // defaults for discrete scale.\n        multiplicativeExpand = 0.0\n        additiveExpand = 0.6\n    }\n\n    private constructor(b: MyBuilder<T>) : super(b) {\n        discreteTransform = DiscreteTransform(b.myDomainValues, b.myDomainLimits)\n    }\n\n    override fun hasBreaksGenerator() = false\n\n    override fun hasDomainLimits(): Boolean {\n        return discreteTransform.hasDomainLimits()\n    }\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        return discreteTransform.isInDomain(v)\n    }\n\n    override fun with(): Scale.Builder<T> {\n        return MyBuilder(this)\n    }\n\n    private class MyBuilder<T>(scale: DiscreteScale<T>) : AbstractBuilder<Any, T>(scale) {\n        internal val myDomainValues: Collection<Any> = scale.discreteTransform.domainValues\n        internal var myDomainLimits: List<Any> = scale.discreteTransform.domainLimits\n\n        override fun breaksGenerator(v: BreaksGenerator): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun lowerLimit(v: Double): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun upperLimit(v: Double): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun limits(domainValues: List<Any>): Scale.Builder<T> {\n            myDomainLimits = domainValues\n            return this\n        }\n\n        override fun continuousTransform(v: ContinuousTransform): Scale.Builder<T> {\n            // ignore\n            return this\n        }\n\n        override fun build(): Scale<T> {\n            return DiscreteScale(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Transform\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject MapperUtil {\n    fun map(r: ClosedRange<Double>, mapper: (Double?) -> Double?): ClosedRange<Double> {\n        val a = mapper(r.lowerEnd)!!\n        val b = mapper(r.upperEnd)!!\n        return ClosedRange(min(a, b), max(a, b))\n    }\n\n    fun mapDiscreteDomainValuesToNumbers(values: Collection<*>): Map<Any, Double> {\n        return mapDiscreteDomainValuesToIndices(values)\n    }\n\n    private fun mapDiscreteDomainValuesToIndices(values: Collection<*>): Map<Any, Double> {\n        val result = LinkedHashMap<Any, Double>()\n        var index = 0\n        for (v in values) {\n            if (v != null && !result.containsKey(v)) {\n                result[v] = index++.toDouble()\n            }\n        }\n        return result\n    }\n\n    fun rangeWithLimitsAfterTransform(\n        dataRange: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: Transform\n    ): ClosedRange<Double> {\n        val lower = if (lowerLimit != null && lowerLimit.isFinite()) {\n            lowerLimit\n        } else {\n            dataRange.lowerEnd\n        }\n        val upper = if (upperLimit != null && upperLimit.isFinite()) {\n            upperLimit\n        } else {\n            dataRange.upperEnd\n        }\n        val limits = listOf(lower, upper)\n//        return ClosedRange.encloseAll(trans?.apply(limits) ?: limits)\n        return ClosedRange.encloseAll(trans.apply(limits))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.function.Function\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.breaks.QuantizeScale\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.round\n\nobject Mappers {\n    val IDENTITY = { v: Double? -> v }\n\n    fun <T> undefined(): (Double?) -> T = { throw IllegalStateException(\"Undefined mapper\") }\n\n    fun <T> nullable(f: (Double?) -> T, ifNull: T): (Double?) -> T {\n        return { n ->\n            if (n == null) {\n                ifNull\n            } else {\n                f(n)\n            }\n        }\n    }\n\n    fun constant(v: Double): (Double?) -> Double = { v }\n\n    fun mul(domain: ClosedRange<Double>, rangeSpan: Double): (Double?) -> Double? {\n        val factor = rangeSpan / (domain.upperEnd - domain.lowerEnd)\n        check(!(factor.isInfinite() || factor.isNaN())) { \"Can't create mapper with ratio: $factor\" }\n        return mul(factor)\n    }\n\n    fun mul(factor: Double): (Double?) -> Double? {\n        return { v ->\n            if (v != null) {\n                factor * v\n            } else null\n        }\n    }\n\n    fun linear(domain: ClosedRange<Double>, range: ClosedRange<Double>, reverse: Boolean = false): (Double?) -> Double {\n        return linear(\n            domain,\n            rangeLow = if (reverse) range.upperEnd else range.lowerEnd,\n            rangeHigh = if (reverse) range.lowerEnd else range.upperEnd,\n            Double.NaN\n        )\n    }\n\n    fun linear(domain: ClosedRange<Double>, range: ClosedRange<Double>, defaultValue: Double): (Double?) -> Double {\n        return linear(\n            domain,\n            range.lowerEnd,\n            range.upperEnd,\n            defaultValue\n        )\n    }\n\n    fun linear(\n        domain: ClosedRange<Double>,\n        rangeLow: Double,\n        rangeHigh: Double,\n        defaultValue: Double\n    ): (Double?) -> Double {\n        val slop = (rangeHigh - rangeLow) / (domain.upperEnd - domain.lowerEnd)\n        if (!SeriesUtil.isFinite(slop)) {\n            // no slop\n            val v = (rangeHigh - rangeLow) / 2 + rangeLow\n            return constant(v)\n        }\n        val intersect = rangeLow - domain.lowerEnd * slop\n        return { input ->\n            if (SeriesUtil.isFinite(input))\n                input!! * slop + intersect\n            else\n                defaultValue\n        }\n    }\n\n    fun discreteToContinuous(\n        domainValues: Collection<*>,\n        outputRange: ClosedRange<Double>,\n        naValue: Double\n    ): (Double?) -> Double? {\n        val numberByDomainValue =\n            MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val dataRange = SeriesUtil.range(numberByDomainValue.values) ?: return IDENTITY\n        return linear(dataRange, outputRange, naValue)\n    }\n\n    fun <T> discrete(outputValues: List<T?>, defaultOutputValue: T): (Double?) -> T? {\n        val f = DiscreteFun(outputValues, defaultOutputValue)\n        return { f.apply(it) }\n    }\n\n    fun <T> quantized(\n        domain: ClosedRange<Double>?,\n        outputValues: Collection<T>,\n        defaultOutputValue: T\n    ): (Double?) -> T {\n        if (domain == null) {\n            return { defaultOutputValue }\n        }\n\n        // todo: extract quantizer\n        val quantizer = QuantizeScale<T>()\n        quantizer.domain(domain.lowerEnd, domain.upperEnd)\n        quantizer.range(outputValues)\n\n        val f = QuantizedFun(quantizer, defaultOutputValue)\n        return { f.apply(it) }\n    }\n\n    private class DiscreteFun<T>(\n        private val myOutputValues: List<T?>,\n        private val myDefaultOutputValue: T\n    ) : Function<Double?, T?> {\n\n        override fun apply(value: Double?): T? {\n            if (!SeriesUtil.isFinite(value)) {\n                return myDefaultOutputValue\n            }\n            // ToDo: index-based discrete fun won't work for discrete numeric onput (see: MapperUtil#mapDiscreteDomainValuesToNumbers())\n            var index = round(value!!).toInt()\n            index %= myOutputValues.size\n            if (index < 0) {\n                index += myOutputValues.size\n            }\n            return myOutputValues[index]\n        }\n    }\n\n    private class QuantizedFun<T> internal constructor(\n        private val myQuantizer: QuantizeScale<T>,\n        private val myDefaultOutputValue: T\n    ) : Function<Double?, T> {\n        override fun apply(value: Double?): T {\n            return if (!SeriesUtil.isFinite(value)) myDefaultOutputValue else myQuantizer.quantize(value!!)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nclass ScaleBreaks(domainValues: List<Double>, transformValues: List<Double>, labels: List<String>) {\n    val domainValues: List<Double> = ArrayList(domainValues)\n    val transformValues: List<Double> = ArrayList(transformValues)\n    val labels: List<String> = ArrayList(labels)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ScaleUtil {\n\n    fun labels(scale: Scale<*>): List<String> {\n        if (!scale.hasBreaks()) {\n            return emptyList()\n        }\n\n        val breaks = scale.breaks\n        if (scale.hasLabels()) {\n            val labels = scale.labels\n\n            if (breaks.size <= labels.size) {\n                return labels.subList(0, breaks.size)\n            }\n\n            val result = ArrayList<String>()\n            for (i in breaks.indices) {\n                if (labels.isEmpty()) {\n                    result.add(\"\")\n                } else {\n                    result.add(labels[i % labels.size])\n                }\n            }\n            return result\n        }\n\n        val formatter: (Any) -> String = scale.labelFormatter ?: { v: Any -> v.toString() }\n        // generate labels\n        return breaks.map { formatter(it) }\n    }\n\n    fun labelByBreak(scale: Scale<*>): Map<Any, String> {\n        val result = HashMap<Any, String>()\n        if (scale.hasBreaks()) {\n            val breaks = scale.breaks.iterator()\n            val labels = labels(scale).iterator()\n            while (breaks.hasNext() && labels.hasNext()) {\n                result[breaks.next()] = labels.next()\n            }\n        }\n        return result\n    }\n\n    fun breaksTransformed(scale: Scale<*>): List<Double> {\n        return scale.transform.apply(scale.breaks).map { it as Double }\n    }\n\n    fun axisBreaks(scale: Scale<Double>, coord: CoordinateSystem, horizontal: Boolean): List<Double> {\n        val scaleBreaks = transformAndMap(scale.breaks, scale)\n        val axisBreaks = ArrayList<Double>()\n        for (br in scaleBreaks) {\n            val mappedBrPoint = if (horizontal)\n                DoubleVector(br!!, 0.0)\n            else\n                DoubleVector(0.0, br!!)\n\n            val axisBrPoint = coord.toClient(mappedBrPoint)\n            val axisBr = if (horizontal)\n                axisBrPoint.x\n            else\n                axisBrPoint.y\n\n            axisBreaks.add(axisBr)\n            if (!axisBr.isFinite()) {\n                throw IllegalStateException(\n                    \"Illegal axis '\" + scale.name + \"' break position \" + axisBr +\n                            \" at index \" + (axisBreaks.size - 1) +\n                            \"\\nsource breaks    : \" + scale.breaks +\n                            \"\\ntranslated breaks: \" + scaleBreaks +\n                            \"\\naxis breaks      : \" + axisBreaks\n                )\n            }\n        }\n        return axisBreaks\n    }\n\n    fun map(range: ClosedRange<Double>, scale: Scale<Double>): ClosedRange<Double> {\n        return MapperUtil.map(range, scale.mapper)\n    }\n\n    fun <T> map(l: List<Double?>, scale: Scale<T>): List<T?> {\n        val mapper = scale.mapper\n        return l.map {\n            mapper(it)\n        }\n    }\n\n    fun <T> transformAndMap(l: List<*>, scale: Scale<T>): List<T?> {\n        val cleaned = cleanUpTransformSource(l, scale)\n        val transformed = scale.transform.apply(cleaned)\n        return map(transformed, scale)\n    }\n\n    fun cleanUpTransformSource(source: List<*>, scale: Scale<*>): List<Any?> {\n        @Suppress(\"NAME_SHADOWING\")\n        var source: List<Any?> = source\n\n        // Replace values outside 'scale limits' with null-s.\n        if (scale.hasDomainLimits()) {\n            source = source.map { if (it == null || scale.isInDomainLimits(it)) it else null }\n        }\n\n        // Replace values outside of domain of 'continuous transform' with null-s.\n        if (scale.transform is ContinuousTransform) {\n            val continuousTransform = scale.transform as ContinuousTransform\n            if (continuousTransform.hasDomainLimits()) {\n                source = source.map { if (continuousTransform.isInDomain(it as Double?)) it else null }\n            }\n        }\n\n        return source\n    }\n\n    fun inverseTransformToContinuousDomain(l: List<Double?>, scale: Scale<*>): List<Double?> {\n        check(scale.isContinuousDomain) { \"Not continuous numeric domain: $scale\" }\n        return (scale.transform as ContinuousTransform).applyInverse(l)\n    }\n\n    fun inverseTransform(l: List<Double?>, scale: Scale<*>): List<*> {\n        val transform = scale.transform\n        return if (transform is ContinuousTransform) {\n            transform.applyInverse(l)\n        } else {\n            l.map { transform.applyInverse(it) }\n        }\n    }\n\n    fun transformedDefinedLimits(scale: Scale<*>): Pair<Double, Double> {\n        val (lower, upper) = scale.domainLimits\n        val transform = scale.transform as ContinuousTransform\n        val (transformedLower, transformedUpper) = Pair(\n            if (transform.isInDomain(lower)) transform.apply(lower)!! else Double.NaN,\n            if (transform.isInDomain(upper)) transform.apply(upper)!! else Double.NaN\n        )\n\n        return if (SeriesUtil.allFinite(transformedLower, transformedUpper)) {\n            Pair(\n                min(transformedLower, transformedUpper),\n                max(transformedLower, transformedUpper)\n            )\n        } else {\n            Pair(transformedLower, transformedUpper)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\nobject Scales {\n    fun <T> continuousDomain(\n        name: String,\n        aes: Aes<T>\n    ): Scale<T> {\n        return ContinuousScale<T>(\n            name,\n            Mappers.undefined(),\n            aes.isNumeric\n        )\n    }\n\n    fun continuousDomainNumericRange(\n        name: String\n    ): Scale<Double> {\n        return ContinuousScale<Double>(\n            name,\n            Mappers.undefined(),\n            true\n        )\n    }\n\n    fun <T> continuousDomain(\n        name: String,\n        mapper: (Double?) -> T?,\n        continuousRange: Boolean\n    ): Scale<T> {\n        return ContinuousScale<T>(name, mapper, continuousRange)\n    }\n\n    fun <T> discreteDomain(name: String, domainValues: Collection<Any>): Scale<T> {\n        return discreteDomain(\n            name,\n            domainValues,\n            Mappers.undefined()\n        )\n    }\n\n    fun <T> discreteDomain(name: String, domainValues: Collection<Any>, mapper: ((Double?) -> T?)): Scale<T> {\n        return DiscreteScale(name, domainValues, mapper)\n    }\n\n    fun <T> pureDiscrete(\n        name: String,\n        domainValues: List<Any>,\n        outputValues: List<T>,\n        defaultOutputValue: T\n    ): Scale<T> {\n        return discreteDomain<T>(name, domainValues)\n            .with()\n            .mapper(Mappers.discrete(outputValues, defaultOutputValue))\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nabstract class BreaksHelperBase(\n    start: Double,\n    end: Double,\n    targetCount: Int\n) {\n    abstract val breaks: List<Double>\n\n    protected val normalStart: Double\n    protected val normalEnd: Double\n    protected val span: Double\n    protected val targetStep: Double\n    protected val isReversed: Boolean\n\n    init {\n        require(start.isFinite()) { \"range start $start\" }\n        require(end.isFinite()) { \"range end $end\" }\n        require(targetCount > 0) { \"'count' must be positive: $targetCount\" }\n        var span = end - start\n        var reversed = false\n        if (span < 0) {\n            span = -span\n            reversed = true\n        }\n\n        this.span = span\n        targetStep = this.span / targetCount\n        isReversed = reversed\n        normalStart = if (reversed) end else start\n        normalEnd = if (reversed) start else end\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.plot.common.time.TimeUtil\nimport jetbrains.datalore.plot.common.time.interval.NiceTimeInterval\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\nimport jetbrains.datalore.plot.common.time.interval.YearInterval\nimport kotlin.math.round\n\nclass DateTimeBreaksHelper(\n    rangeStart: Double,\n    rangeEnd: Double,\n    count: Int,\n    minInterval: TimeInterval? = null\n) : BreaksHelperBase(rangeStart, rangeEnd, count) {\n\n    override val breaks: List<Double>\n    val formatter: (Any) -> String\n\n    init {\n\n        val step = targetStep\n        if (step < 1000) {        // milliseconds\n            formatter = TimeScaleTickFormatterFactory(minInterval).getFormatter(step)\n            // compute step so that it is multiple of automatic time steps\n            breaks = LinearBreaksHelper(rangeStart, rangeEnd, count).breaks\n\n        } else {\n\n            val start = normalStart\n            val end = normalEnd\n\n            var ticks: MutableList<Double>? = null\n            if (minInterval != null) {\n                ticks = minInterval.range(start, end).toMutableList()\n            }\n\n            if (ticks != null && ticks.size <= count) {\n                // same or smaller interval requested -> stay with min interval\n                formatter = minInterval!!.tickFormatter\n                // otherwise - larger step requested -> compute ticks\n            } else if (step > YearInterval.MS) {        // years\n                formatter = YearInterval.TICK_FORMATTER\n                ticks = ArrayList()\n                val startDateTime = TimeUtil.asDateTimeUTC(start)\n                var startYear = startDateTime.year\n                if (startDateTime.isAfter(TimeUtil.yearStart(startYear))) {\n                    startYear++\n                }\n                val endYear = TimeUtil.asDateTimeUTC(end).year\n                val helper = LinearBreaksHelper(\n                    startYear.toDouble(),\n                    endYear.toDouble(),\n                    count\n                )\n                for (tickYear in helper.breaks) {\n                    val tickDate = TimeUtil.yearStart(round(tickYear).toInt())\n                    ticks.add(TimeUtil.asInstantUTC(tickDate).toDouble())\n                }\n            } else {\n                val interval = NiceTimeInterval.forMillis(step)\n                formatter = interval.tickFormatter\n                ticks = interval.range(start, end).toMutableList()\n            }\n\n            if (isReversed) {\n                ticks.reverse()\n            }\n            breaks = ticks\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport kotlin.math.*\n\nclass LinearBreaksHelper(\n    rangeStart: Double,\n    rangeEnd: Double,\n    count: Int,\n    precise: Boolean = false\n) : BreaksHelperBase(rangeStart, rangeEnd, count) {\n    override val breaks: List<Double>\n\n    init {\n        check(count > 0) { \"Can't compute breaks for count: $count\" }\n\n        val step = if (precise) {\n            this.targetStep\n        } else {\n            computeNiceStep(this.span, count)\n        }\n\n        val breaks = if (precise) {\n            (0 until count).map { normalStart + step / 2 + it * step }\n        } else {\n            computeNiceBreaks(normalStart, normalEnd, step)\n        }\n\n        this.breaks = if (breaks.isEmpty()) {\n            listOf(normalStart)\n        } else if (isReversed) {\n            breaks.asReversed()\n        } else {\n            breaks\n        }\n    }\n\n    companion object {\n        private fun computeNiceStep(\n            span: Double,\n            count: Int\n        ): Double {\n            // compute step so that it is multiple of 10, 5 or 2.\n            val stepRaw = span / count\n            val step10Power = floor(log10(stepRaw))\n            val step = 10.0.pow(step10Power)\n            val error = step * count / span\n            return when {\n                error <= 0.15 -> step * 10.0\n                error <= 0.35 -> step * 5.0\n                error <= 0.75 -> step * 2.0\n                else -> step\n            }\n        }\n\n        private fun computeNiceBreaks(\n            start: Double,\n            end: Double,\n            step: Double\n        ): List<Double> {\n            if (step == 0.0) return emptyList()\n\n            // extend range to allow for FP errors\n            val delta = step / 10000\n            val startE = start - delta\n            val endE = end + delta\n\n            val breaks = ArrayList<Double>()\n            var tick = ceil(startE / step) * step\n            if (start >= 0 && startE < 0) {\n                // avoid negative zero\n                tick = 0.0\n            }\n            while (tick <= endE) {\n                // don't allow ticks to go beyond the range\n                tick = min(tick, end)\n\n                breaks.add(tick)\n                tick += step\n            }\n\n            return breaks\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\nimport kotlin.math.abs\nimport kotlin.math.ceil\nimport kotlin.math.log10\n\nclass NumericBreakFormatter(value: Double, step: Double, allowMetricPrefix: Boolean) {\n    private var formatter: NumberFormat\n\n    init {\n        @Suppress(\"NAME_SHADOWING\")\n        var value = if (value == 0.0) {\n            // Use very small value instead because log10(0) -> -Infinity.\n            Double.MIN_VALUE * 10\n        } else {\n            abs(value)\n        }\n\n        @Suppress(\"NAME_SHADOWING\")\n        var step = if (step == 0.0) {\n            value / 10\n        } else {\n            abs(step)\n        }\n\n\n        var type = \"f\"\n        var delimiter = \"\"\n\n        val domain10Power = log10(abs(value))\n        val step10Power = log10(step)\n\n        var precision = -step10Power\n        var scientificNotation = false\n        if (domain10Power < 0 && step10Power < -4) {\n            scientificNotation = true\n            type = \"e\"\n            precision = domain10Power - step10Power\n        } else if (domain10Power > 7 && step10Power > 2) {\n            scientificNotation = true\n            precision = domain10Power - step10Power\n        }\n\n        if (precision < 0) {\n            precision = 0.0\n            type = \"d\"\n        }\n        // round-up precision ulless it's very close to smaller int.\n        precision = ceil(precision - 0.001)\n\n        if (scientificNotation) {\n            type = if (domain10Power > 0 && allowMetricPrefix) {\n                // generate 'engineering notation', in which the exponent is a multiple of three\n                \"s\"\n            } else {\n                \"e\"\n            }\n        } else {\n            delimiter = \",\"\n        }\n\n        formatter = NumberFormat(\"$delimiter.${precision.toInt()}$type\")\n    }\n\n    fun apply(value: Any): String = formatter.apply(value as Number)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport kotlin.math.max\nimport kotlin.math.min\n\n\n// ToDo: seem like `WithFiniteOrderedOutput` never used\nclass QuantizeScale<T> : WithFiniteOrderedOutput<T> {\n    private var myHasDomain: Boolean = false\n    private var myDomainStart: Double = 0.0\n    private var myDomainEnd: Double = 0.0\n    private lateinit var myOutputValues: List<T>\n\n    override val outputValues: List<T>\n        get() = myOutputValues\n\n    //return Arrays.asList(ClosedRangeOpen(myDomainStart, myDomainEnd));\n    //    double error = bucketSize / 10;   // prevent creating of 1 extra bucket\n    /*\n    double upperBound = myDomainStart;\n    while (upperBound < myDomainEnd - error) {\n      double lowerBound = upperBound;\n      upperBound = lowerBound + bucketSize;\n      ClosedRange<Double> bucket = ClosedRangeOpen(lowerBound, upperBound);\n      list.add(bucket);\n    }\n*///ClosedRange<Double> bucket = ClosedRangeOpen(myDomainStart + bucketSize * i, myDomainStart + bucketSize * (i + 1));\n    // ToDo: move inside the cycle\n    // last bucket - closed\n    val domainQuantized: List<ClosedRange<Double>>\n        get() {\n            if (myDomainStart == myDomainEnd) {\n                return listOf(ClosedRange(myDomainStart, myDomainEnd))\n            }\n\n            val list = ArrayList<ClosedRange<Double>>()\n            val numBuckets = myOutputValues.size\n            val bucketSize = bucketSize()\n            for (i in 0 until numBuckets - 1) {\n                val bucket = ClosedRange(myDomainStart + bucketSize * i, myDomainStart + bucketSize * (i + 1))\n                list.add(bucket)\n            }\n            val bucket = ClosedRange(myDomainStart + bucketSize * (numBuckets - 1), myDomainEnd)\n            list.add(bucket)\n            return list\n        }\n\n    /**\n     * Set the scale's input domain.\n     */\n    fun domain(start: Double, end: Double): QuantizeScale<T> {\n        require(start <= end) { \"Domain start must be less then domain end: $start > $end\" }\n        myHasDomain = true\n        myDomainStart = start\n        myDomainEnd = end\n        return this\n    }\n\n    /**\n     * Scale's output 'quantized' values\n     */\n    fun range(values: Collection<T>): QuantizeScale<T> {\n        myOutputValues = ArrayList(values)\n        return this\n    }\n\n    fun quantize(v: Double): T {\n        val i = outputIndex(v)\n        return myOutputValues[i]\n    }\n\n    private fun outputIndex(v: Double): Int {\n        check(myHasDomain) { \"Domain not defined.\" }\n        check(::myOutputValues.isInitialized && myOutputValues.isNotEmpty()) { \"Output values are not defined.\" }\n        val bucketSize = bucketSize()\n        val index = ((v - myDomainStart) / bucketSize).toInt()\n        val maxIndex = myOutputValues.size - 1\n        return max(0, min(maxIndex, index))\n    }\n\n    override fun getOutputValueIndex(domainValue: Any): Int {\n        return if (domainValue is Number) {\n            outputIndex(domainValue.toDouble())\n        } else -1\n    }\n\n    override fun getOutputValue(domainValue: Any): T? {\n        return if (domainValue is Number) {\n            quantize(domainValue.toDouble())\n        } else null\n    }\n\n    private fun bucketSize(): Double {\n        return (myDomainEnd - myDomainStart) / myOutputValues.size\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Scale\n\n\nobject ScaleBreaksUtil {\n    fun <TargetT> withBreaks(\n        scale: Scale<TargetT>,\n        transformedDomain: ClosedRange<Double>,\n        breakCount: Int\n    ): Scale<TargetT> {\n        val scaleBreaks = scale.breaksGenerator.generateBreaks(transformedDomain, breakCount)\n        val breaks = scaleBreaks.domainValues\n        val labels = scaleBreaks.labels\n        return scale.with()\n            .breaks(breaks)\n            .labels(labels)\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.plot.common.text.Formatter\nimport jetbrains.datalore.plot.common.time.interval.NiceTimeInterval\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\nimport jetbrains.datalore.plot.common.time.interval.YearInterval\n\ninternal class TimeScaleTickFormatterFactory(\n    private val minInterval: TimeInterval?\n) {\n\n    fun getFormatter(step: Double): (Any) -> String {\n        return Formatter.time(formatPattern(step))\n    }\n\n    private fun formatPattern(step: Double): String {\n        if (step < 1000) {        // milliseconds\n            return TimeInterval.milliseconds(1).tickFormatPattern\n        }\n\n        if (minInterval != null) {\n            // check if we have to hold on minimal interval formatter\n            val stepCount = 100\n            val start = 0.0\n            val end = step * stepCount\n            val intervalCount = minInterval.range(start, end).size\n            if (stepCount >= intervalCount) {\n                // step is smaller than min interval -> stay with min interval\n                return minInterval.tickFormatPattern\n            }\n        }\n\n        if (step > YearInterval.MS) {        // years\n            return YearInterval.TICK_FORMAT\n        }\n\n        val interval = NiceTimeInterval.forMillis(step)\n        return interval.tickFormatPattern\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.DateTimeBreaksHelper\n\nclass DateTimeBreaksGen(\n    private val labelFormatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val helper = breaksHelper(domain, targetCount)\n        val ticks = helper.breaks\n        val labelFormatter = labelFormatter ?: helper.formatter\n        val labels = ArrayList<String>()\n        for (tick in ticks) {\n            labels.add(labelFormatter(tick))\n        }\n        return ScaleBreaks(ticks, ticks, labels)\n    }\n\n    private fun breaksHelper(\n        domainAfterTransform: ClosedRange<Double>,\n        targetCount: Int\n    ): DateTimeBreaksHelper {\n        return DateTimeBreaksHelper(\n            domainAfterTransform.lowerEnd,\n            domainAfterTransform.upperEnd,\n            targetCount\n        )\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return labelFormatter ?: breaksHelper(domain, targetCount).formatter\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nabstract class FunTransform(\n    private val transformFun: (Double) -> Double,\n    private val inverseFun: (Double) -> Double\n) : ContinuousTransform {\n    override fun apply(v: Double?): Double? {\n        return if (v != null) {\n            transformFun(v)\n        } else {\n            null\n        }\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return safeCastToDoubles(l).map { apply(it) }\n    }\n\n    override fun applyInverse(v: Double?): Double? {\n        return if (v != null) {\n            inverseFun(v)\n        } else {\n            null\n        }\n    }\n\n    override fun applyInverse(l: List<Double?>): List<Double?> {\n        return l.map { applyInverse(it) }\n    }\n\n    protected fun safeCastToDoubles(list: List<*>): List<Double?> {\n        val checkedDoubles = SeriesUtil.checkedDoubles(list)\n        require(checkedDoubles.canBeCast()) { \"Not a collections of Double(s)\" }\n        return checkedDoubles.cast()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class IdentityTransform : FunTransform({ v -> v }, { v -> v }) {\n    override fun hasDomainLimits(): Boolean = false\n\n    override fun isInDomain(v: Double?) = SeriesUtil.isFinite(v)\n\n    override fun createApplicableDomain(middle: Double): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = if (middle.isFinite()) middle else 0.0\n        return ClosedRange(middle - 0.5, middle + 0.5)\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return safeCastToDoubles(l)\n    }\n\n    override fun applyInverse(l: List<Double?>): List<Double?> {\n        return l\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.LinearBreaksHelper\nimport jetbrains.datalore.plot.base.scale.breaks.NumericBreakFormatter\nimport kotlin.math.abs\nimport kotlin.math.max\n\ninternal class LinearBreaksGen(\n    private val formatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val breaks = generateBreakValues(domain, targetCount)\n        val fmt = formatter ?: createFormatter(breaks)\n        val labels = breaks.map { fmt(it) }\n        return ScaleBreaks(breaks, breaks, labels)\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return formatter ?: createFormatter(generateBreakValues(domain, targetCount))\n    }\n\n    companion object {\n        internal fun generateBreakValues(domain: ClosedRange<Double>, targetCount: Int): List<Double> {\n            val helper = LinearBreaksHelper(\n                domain.lowerEnd,\n                domain.upperEnd,\n                targetCount\n            )\n            return helper.breaks\n        }\n\n        private fun createFormatter(breakValues: List<Double>): (Any) -> String {\n            val (referenceValue, step) = when {\n                breakValues.isEmpty() -> Pair(0.0, 0.5)\n                else -> {\n                    val v = max(abs(breakValues.first()), abs(breakValues.last()))\n                    val s = when {\n                        breakValues.size == 1 -> v / 10\n                        else -> abs(breakValues[1] - breakValues[0])\n                    }\n                    Pair(v, s)\n                }\n            }\n\n            val formatter = NumericBreakFormatter(\n                referenceValue,\n                step,\n                allowMetricPrefix = true\n            )\n            return formatter::apply\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.log10\nimport kotlin.math.max\nimport kotlin.math.pow\n\ninternal class Log10Transform : FunTransform(\n    transformFun = { v -> log10(v) },\n    inverseFun = { v -> 10.0.pow(v) }\n) {\n    override fun hasDomainLimits() = true\n\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v) && v!! >= 0.0\n    }\n\n    override fun apply(v: Double?): Double? {\n        return trimInfinity(super.apply(v))\n    }\n\n    override fun applyInverse(v: Double?): Double? {\n        return super.applyInverse(v)\n    }\n\n    override fun createApplicableDomain(middle: Double): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = when {\n            isInDomain(middle) -> middle\n            else -> 0.0\n        }\n\n        val lower = middle / 2\n        val upper = if (middle == 0.0) 10.0 else middle * 2\n        return ClosedRange(lower, upper)\n    }\n\n    companion object {\n        internal const val LOWER_LIM: Double = -Double.MAX_VALUE / 10\n\n        /**\n         * Avoid transforming 0.0 -> -Infinity\n         */\n        private fun trimInfinity(v: Double?): Double? {\n            return when {\n                v == null -> null\n                v.isNaN() -> Double.NaN\n                else -> max(LOWER_LIM, v)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.NumericBreakFormatter\nimport kotlin.math.abs\nimport kotlin.math.min\n\ninternal class NonlinearBreaksGen(\n    private val transform: ContinuousTransform,\n    private val formatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val breakValues = generateBreakValues(domain, targetCount, transform)\n        val breakFormatters = if (formatter != null) {\n            List(breakValues.size) { formatter }\n        } else {\n            createFormatters(breakValues)\n        }\n\n        val labels = breakValues.mapIndexed() { i, v -> breakFormatters[i](v) }\n        return ScaleBreaks(breakValues, breakValues, labels)\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return formatter ?: createMultiFormatter(generateBreakValues(domain, targetCount, transform))\n    }\n\n    companion object {\n        private fun generateBreakValues(\n            domain: ClosedRange<Double>,\n            targetCount: Int,\n            transform: ContinuousTransform\n        ): List<Double> {\n            val transformedDomain = MapperUtil.map(domain) { transform.apply(it) }\n            val transformedBreakValues: List<Double> =\n                LinearBreaksGen.generateBreakValues(transformedDomain, targetCount)\n\n            // Transform back to data space.\n            return transform.applyInverse(transformedBreakValues).filterNotNull()\n        }\n\n        private fun createMultiFormatter(breakValues: List<Double>): (Any) -> String {\n            val breakFormatters = createFormatters(breakValues)\n            return MultiFormatter(breakValues, breakFormatters)::apply\n        }\n\n        private fun createFormatters(breakValues: List<Double>): List<(Any) -> String> {\n            if (breakValues.isEmpty()) return emptyList()\n            if (breakValues.size == 1) {\n                val domainValue = breakValues[0]\n                val step = domainValue / 10\n                return listOf(createFormatter(domainValue, step))\n            }\n\n            // format each tick with its own formatter\n            @Suppress(\"UnnecessaryVariable\")\n            val formatters: List<(Any) -> String> = breakValues.mapIndexed { i, currValue ->\n                val step = abs(\n                    when (i) {\n                        0 -> currValue - breakValues[i + 1]\n                        else -> currValue - breakValues[i - 1]\n                    }\n                )\n                createFormatter(currValue, step)\n            }\n            return formatters\n        }\n\n        private fun createFormatter(domainValue: Double, step: Double): (Any) -> String {\n            return NumericBreakFormatter(\n                domainValue,\n                step,\n                true\n            )::apply\n        }\n    }\n\n    private class MultiFormatter(\n        val breakValues: List<Double>,\n        val breakFormatters: List<(Any) -> String>\n    ) {\n        init {\n            check(breakValues.size == breakFormatters.size) {\n                \"MultiFormatter: breakValues.size=${breakValues.size} but breakFormatters.size=${breakFormatters.size}\"\n            }\n            if (breakValues.size > 1) {\n                val ordered = breakValues\n                    .mapIndexed { i, v -> if (i == 0) 0.0 else v - breakValues[i - 1] }\n                    .all { it >= 0.0 }\n                check(ordered) { \"MultiFormatter: values must be sorted in ascending order. Were: $breakValues.\" }\n            }\n        }\n\n        fun apply(v: Any): String {\n            v as Double\n            return when {\n                breakValues.isEmpty() -> v.toString()\n                else -> {\n                    val i = abs(breakValues.binarySearch(v))\n                    val ii = min(i, breakValues.size - 1)\n                    breakFormatters[ii](v)\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class ReverseTransform : FunTransform({ v -> -v }, { v -> -v }) {\n    override fun hasDomainLimits() = false\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v)\n    }\n\n    override fun createApplicableDomain(middle: Double): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = if (middle.isFinite()) middle else 0.0\n        return ClosedRange(middle - 0.5, middle + 0.5)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.sqrt\n\ninternal class SqrtTransform : FunTransform(\n    transformFun = { v -> sqrt(v) },\n    inverseFun = { v -> v * v }\n) {\n    override fun hasDomainLimits() = true\n\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v) && v!! >= 0.0\n    }\n\n    override fun createApplicableDomain(middle: Double): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = when {\n            isInDomain(middle) -> middle\n            else -> 0.0\n        }\n\n        val lower = max(middle - 0.5, 0.0)\n        return ClosedRange(lower, lower + 1.0)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\nobject Transforms {\n    val IDENTITY: ContinuousTransform = IdentityTransform()\n    val REVERSE: ContinuousTransform = ReverseTransform()\n    val SQRT: ContinuousTransform = SqrtTransform()\n    val LOG10: ContinuousTransform = Log10Transform()\n\n    fun createBreaksGeneratorForTransformedDomain(\n        transform: ContinuousTransform,\n        labelFormatter: ((Any) -> String)? = null\n    ): BreaksGenerator {\n        val breaksGenerator: BreaksGenerator = when (transform) {\n            IDENTITY -> LinearBreaksGen(labelFormatter)\n            REVERSE -> LinearBreaksGen(labelFormatter)\n            SQRT -> NonlinearBreaksGen(SQRT, labelFormatter)\n            LOG10 -> NonlinearBreaksGen(LOG10, labelFormatter)\n            else -> throw IllegalStateException(\"Unexpected 'transform' type: ${transform::class.simpleName}\")\n        }\n\n        return BreaksGeneratorForTransformedDomain(transform, breaksGenerator)\n    }\n\n    class BreaksGeneratorForTransformedDomain(\n        private val transform: ContinuousTransform,\n        val breaksGenerator: BreaksGenerator\n    ) : BreaksGenerator {\n        override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n            val domainBeforeTransform = MapperUtil.map(domain) {\n                transform.applyInverse(it)\n            }\n            return breaksGenerator.labelFormatter(domainBeforeTransform, targetCount)\n        }\n\n        override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n            val domainBeforeTransform = MapperUtil.map(domain) {\n                transform.applyInverse(it)\n            }\n            val scaleBreaks = breaksGenerator.generateBreaks(domainBeforeTransform, targetCount)\n            val originalBreaks = scaleBreaks.domainValues\n            val transformedBreaks = transform.apply(originalBreaks).map {\n                it as Double // Should not contain NULLs\n            }\n\n            return ScaleBreaks(originalBreaks, transformedBreaks, scaleBreaks.labels)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\n\nabstract class AbstractDensity2dStat(\n    private val bandWidthX: Double?,\n    private val bandWidthY: Double?,\n    private val bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    protected val adjust: Double,\n    private val kernel: DensityStat.Kernel,\n    protected val nX: Int,\n    protected val nY: Int,\n    protected val isContour: Boolean,\n    private val binCount: Int,\n    private val binWidth: Double\n\n) : BaseStat(DEF_MAPPING) {\n\n    //    var adjust = DEF_ADJUST\n//    var nx = DEF_N\n//        set(n) {\n//            if (n > MAX_N) {\n//                throw IllegalArgumentException(\"The input Nx \" + n + \" > \" + MAX_N + \"is too large!\")\n//            }\n//            field = n\n//        }\n//    var ny = DEF_N\n//        set(n) {\n//            if (n > MAX_N) {\n//                throw IllegalArgumentException(\"The input Ny \" + n + \" > \" + MAX_N + \"is too large!\")\n//            }\n//            field = n\n//        }\n//    var isContour = DEF_CONTOUR\n//    var bandWidthMethod: DensityStat.BandWidthMethod =\n//        DensityStat.BandWidthMethod.NRD\n//        set(bw) {\n//            field = bw\n//            bandWidths = null\n//        }\n//    private var myBinCount = DEF_BIN_COUNT\n//    private var myBinWidth: Double = 0.toDouble()\n\n//    protected val bandWidths: DoubleArray\n\n    protected val kernelFun: ((Double) -> Double) = DensityStatUtil.kernel(kernel)\n\n    protected val binOptions: BinStatUtil.BinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    init {\n        require(nX <= MAX_N) { \"The input nX = $nX  > $MAX_N is too large!\" }\n        require(nY <= MAX_N) { \"The input nY = $nY  > $MAX_N is too large!\" }\n    }\n\n    fun getBandWidthX(xs: List<Double?>): Double {\n        return bandWidthX ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            xs\n        )\n    }\n\n    fun getBandWidthY(ys: List<Double?>): Double {\n        return bandWidthY ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            ys\n        )\n    }\n\n//    fun setBinCount(bin: Int) {\n//        myBinCount = bin\n//    }\n\n//    fun setBinWidth(bin: Double) {\n//        myBinWidth = bin\n//    }\n\n//    fun setBandWidthX(bw: Double) {\n//        //myBW = BandWidth.DOUBLE;\n//        bandWidths = DoubleArray(2)\n//        bandWidths?.set(0, bw)\n//    }\n\n//    fun setBandWidthY(bw: Double) {\n//        //myBW = BandWidth.DOUBLE;\n//        bandWidths?.set(1, bw)\n//    }\n\n//    fun setKernel(kernel: DensityStat.Kernel) {\n//        this.kernel = DensityStatUtil.kernel(kernel)\n//    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        // ToDo: ???\n        throw IllegalStateException(\"'density2d' statistic can't be executed on the client side\")\n    }\n\n    companion object {\n        //        const val DEF_KERNEL = \"gaussian\"\n        val DEF_KERNEL = DensityStat.Kernel.GAUSSIAN\n        const val DEF_ADJUST = 1.0\n        const val DEF_N = 100\n\n        //        const val DEF_BW = \"nrd\"\n        val DEF_BW = DensityStat.BandWidthMethod.NRD0\n        const val DEF_CONTOUR = true\n        const val DEF_BIN_COUNT = 10\n        const val DEF_BIN_WIDTH = 0.0\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n        private const val MAX_N = 999\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Stat\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nabstract class BaseStat(private val defaultMappings: Map<Aes<*>, DataFrame.Variable>) : Stat {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return defaultMappings.containsKey(aes)\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        if (defaultMappings.containsKey(aes)) {\n            return defaultMappings[aes]!!\n        }\n        throw IllegalArgumentException(\"Stat \" + this::class.simpleName + \" has no default mapping for aes: \" + aes)\n    }\n\n    protected fun hasRequiredValues(data: DataFrame, vararg aes: Aes<*>): Boolean {\n        for (requiredAes in aes) {\n            val variable = TransformVar.forAes(requiredAes)\n            if (data.hasNoOrEmpty(variable)) {\n                return false\n            }\n        }\n        return true\n    }\n\n    protected fun withEmptyStatValues(): DataFrame {\n        val newData = DataFrame.Builder()\n        for (aes in Aes.values()) {\n            if (hasDefaultMapping(aes)) {\n                newData.put(getDefaultMapping(aes), emptyList<Any>())\n            }\n        }\n        return newData.build()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil.expand\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isSubTiny\nimport kotlin.math.floor\n\n/**\n * Default stat for geom_bin2d\n *\n * @param binCountX Number of bins (overridden by binWidth).\n * @param binCountY Number of bins (overridden by binWidth).\n * @param binWidthX Used to compute binCount such that bins covers the range of the data.\n * @param binWidthY Used to compute binCount such that bins covers the range of the data.\n * @param drop if TRUE removes all cells with 0 counts.\n *\n * Computed values:\n *\n * count - number of points in bin\n * density - density of points in bin, scaled to integrate to 1\n * ncount - count, scaled to maximum of 1\n * ndensity - density, scaled to maximum of 1\n */\nclass Bin2dStat(\n    binCountX: Int = DEF_BINS,\n    binCountY: Int = DEF_BINS,\n    binWidthX: Double? = DEF_BINWIDTH,\n    binWidthY: Double? = DEF_BINWIDTH,\n    private val drop: Boolean = DEF_DROP\n) : BaseStat(DEF_MAPPING) {\n    private val binOptionsX = BinStatUtil.BinOptions(binCountX, binWidthX)\n    private val binOptionsY = BinStatUtil.BinOptions(binCountY, binWidthY)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n        if (xRange == null || yRange == null) {\n            return withEmptyStatValues()\n        }\n\n        // initial bin width and count\n\n        val xRangeInit = adjustRangeInitial(xRange)\n        val yRangeInit = adjustRangeInitial(yRange)\n\n        val xCountAndWidthInit = BinStatUtil.binCountAndWidth(SeriesUtil.span(xRangeInit), binOptionsX)\n        val yCountAndWidthInit = BinStatUtil.binCountAndWidth(SeriesUtil.span(yRangeInit), binOptionsY)\n\n        // final bin width and count\n\n        val xRangeFinal = adjustRangeFinal(xRange, xCountAndWidthInit.width)\n        val yRangeFinal = adjustRangeFinal(yRange, yCountAndWidthInit.width)\n\n        val xCountAndWidthFinal = BinStatUtil.binCountAndWidth(SeriesUtil.span(xRangeFinal), binOptionsX)\n        val yCountAndWidthFinal = BinStatUtil.binCountAndWidth(SeriesUtil.span(yRangeFinal), binOptionsY)\n\n        val countTotal = xCountAndWidthFinal.count * yCountAndWidthFinal.count\n        val densityNormalizingFactor =\n            densityNormalizingFactor(SeriesUtil.span(xRangeFinal), SeriesUtil.span(yRangeFinal), countTotal)\n\n        val binsData = computeBins(\n            data.getNumeric(TransformVar.X),\n            data.getNumeric(TransformVar.Y),\n            xRangeFinal.lowerEnd,\n            yRangeFinal.lowerEnd,\n            xCountAndWidthFinal.count,\n            yCountAndWidthFinal.count,\n            xCountAndWidthFinal.width,\n            yCountAndWidthFinal.width,\n            BinStatUtil.weightAtIndex(data),\n            densityNormalizingFactor\n        )\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, binsData.x)\n            .putNumeric(Stats.Y, binsData.y)\n            .putNumeric(Stats.COUNT, binsData.count)\n            .putNumeric(Stats.DENSITY, binsData.density)\n            .build()\n    }\n\n    private fun computeBins(\n        xValues: List<Double?>,\n        yValues: List<Double?>,\n        xStart: Double,\n        yStart: Double,\n        binCountX: Int,\n        binCountY: Int,\n        binWidth: Double,\n        binHeight: Double,\n        weightAtIndex: (Int) -> Double,\n        densityNormalizingFactor: Double\n    ): Bins2dData {\n\n        var totalCount = 0.0\n        val countByBinIndexKey = HashMap<Pair<Int, Int>, MutableDouble>()\n        for (dataIndex in xValues.indices) {\n            val x = xValues[dataIndex]\n            val y = yValues[dataIndex]\n            if (!SeriesUtil.allFinite(x, y)) {\n                continue\n            }\n            val weight = weightAtIndex(dataIndex)\n            totalCount += weight\n            val binIndexX = floor((x!! - xStart) / binWidth).toInt()\n            val binIndexY = floor((y!! - yStart) / binHeight).toInt()\n            val binIndexKey = Pair(binIndexX, binIndexY)\n            if (!countByBinIndexKey.containsKey(binIndexKey)) {\n                countByBinIndexKey[binIndexKey] = MutableDouble(0.0)\n            }\n            countByBinIndexKey[binIndexKey]!!.getAndAdd(weight)\n        }\n\n        val xs = ArrayList<Double>()\n        val ys = ArrayList<Double>()\n        val counts = ArrayList<Double>()\n        val densities = ArrayList<Double>()\n\n        val x0 = xStart + binWidth / 2\n        val y0 = yStart + binHeight / 2\n        for (xIndex in 0 until binCountX) {\n            for (yIndex in 0 until binCountY) {\n                val binIndexKey = Pair(xIndex, yIndex)\n                var count = 0.0\n                if (countByBinIndexKey.containsKey(binIndexKey)) {\n                    count = countByBinIndexKey[binIndexKey]!!.get()\n                }\n\n                if (drop && count == 0.0) {\n                    continue\n                }\n\n                xs.add(x0 + xIndex * binWidth)\n                ys.add(y0 + yIndex * binHeight)\n                counts.add(count)\n                val density = count / totalCount * densityNormalizingFactor\n                densities.add(density)\n            }\n        }\n\n        return Bins2dData(xs, ys, counts, densities)\n    }\n\n\n    companion object {\n\n        const val DEF_BINS = 30\n        val DEF_BINWIDTH: Double? = null\n        const val DEF_DROP = true\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.FILL to Stats.COUNT\n        )\n\n        private fun adjustRangeInitial(r: ClosedRange<Double>): ClosedRange<Double> {\n            // span can't be 0\n            return ensureApplicableRange(r)\n        }\n\n        private fun adjustRangeFinal(r: ClosedRange<Double>, binWidth: Double): ClosedRange<Double> {\n            return if (isSubTiny(r)) {\n                // 0 span allways becomes 1\n                expand(r, 0.5, 0.5)\n            } else {\n                // Expand range by half of bin width (arbitrary choise - can be any positive num) to\n                // avoid data-points on the marginal bin margines.\n                val exp = binWidth / 2.0\n                expand(r, exp, exp)\n            }\n        }\n\n        private fun densityNormalizingFactor(\n            xSpan: Double,\n            ySpan: Double,\n            count: Int\n        ): Double {\n            // density should integrate to 1.0\n            val area = xSpan * ySpan\n            val binArea = area / count\n            return 1.0 / binArea\n        }\n    }\n\n    class Bins2dData(\n        internal val x: List<Double>,\n        internal val y: List<Double>,\n        internal val count: List<Double>,\n        internal val density: List<Double>\n    )\n\n    class Bins2dWeightedCounts(\n        internal val total: Double,\n        internal val countByBinXY: Map<Pair<Double, Double>, Double>\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.abs\n\n/**\n * Default stat for geom_histogram\n *\n * @param binCount Number of bins (overridden by binWidth)\n * @param binWidth Used to compute binCount such that bins covers the range of the data\n * @param xPosKind Specifies a way in which bin x-position is interpreted (center, boundary)\n * @param xPos Bin x-position.\n *\n * Computed values:\n *\n * count - number of points in bin\n * density - density of points in bin, scaled to integrate to 1\n * ncount - count, scaled to maximum of 1\n * ndensity - density, scaled to maximum of 1\n */\nclass BinStat(\n    binCount: Int,\n    binWidth: Double?,\n    private val xPosKind: XPosKind,\n    private val xPos: Double\n) : BaseStat(DEF_MAPPING) {\n    private val binOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val statX = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val rangeX = statCtx.overallXRange()\n        if (rangeX != null) { // null means all input values are null\n            val binsData = computeStatSeries(data, rangeX, data.getNumeric(TransformVar.X))\n            statX.addAll(binsData.x)\n            statCount.addAll(binsData.count)\n            statDensity.addAll(binsData.density)\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.COUNT, statCount)\n            .putNumeric(Stats.DENSITY, statDensity)\n            .build()\n    }\n\n    private fun computeStatSeries(\n        data: DataFrame,\n        rangeX: ClosedRange<Double>,\n        valuesX: List<Double?>\n    ): BinStatUtil.BinsData {\n        var startX: Double? = rangeX.lowerEnd\n        var spanX = rangeX.upperEnd - startX!!\n\n        // initial bin count/width\n        var b: BinStatUtil.CountAndWidth = BinStatUtil.binCountAndWidth(spanX, binOptions)\n\n        // adjusted bin count/width\n        // extend the data range by 0.7 of binWidth on each ends (to allow limited horizontal adjustments)\n        startX -= b.width * 0.7\n        spanX += b.width * 1.4\n        b = BinStatUtil.binCountAndWidth(spanX, binOptions)\n        val binCount = b.count\n        val binWidth = b.width\n\n        // optional horizontal adjustment (+/-0.5 bin width max)\n        if (xPosKind != XPosKind.NONE) {\n            var minDelta = Double.MAX_VALUE\n            val x = xPos\n\n            for (i in 0 until binCount) {\n                val binLeft = startX + i * binWidth\n                val delta: Double\n                if (xPosKind == XPosKind.CENTER) {\n                    delta = x - (binLeft + binWidth / 2)\n                } else {       // BOUNDARY\n                    if (i == 0) {\n                        minDelta = x - startX // init still\n                    }\n                    delta = x - (binLeft + binWidth)\n                }\n\n                if (abs(delta) < abs(minDelta)) {\n                    minDelta = delta\n                }\n            }\n\n            // max offset: +/-0.5 bin width\n            val offset = minDelta % (binWidth / 2)\n            startX += offset\n        }\n\n        // density plot area should be == 1\n        val normalBinWidth = SeriesUtil.span(rangeX) / binCount\n        val densityNormalizingFactor = if (normalBinWidth > 0)\n            1.0 / normalBinWidth\n        else\n            1.0\n\n        // compute bins\n\n        val binsData = BinStatUtil.computeBins(\n            valuesX,\n            startX,\n            binCount,\n            binWidth,\n            BinStatUtil.weightAtIndex(data),\n            densityNormalizingFactor\n        )\n        check(binsData.x.size == binCount)\n        { \"Internal: stat data size=\" + binsData.x.size + \" expected bin count=\" + binCount }\n\n        return binsData\n    }\n\n    enum class XPosKind {\n        NONE, CENTER, BOUNDARY\n    }\n\n    companion object {\n        const val DEF_BIN_COUNT = 30\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.COUNT\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject BinStatUtil {\n    private const val MAX_BIN_COUNT = 500\n\n    fun weightAtIndex(data: DataFrame): (Int) -> Double {\n        if (data.has(TransformVar.WEIGHT)) {\n            val weights = data.getNumeric(TransformVar.WEIGHT)\n            return { index ->\n                val weight = weights[index]\n                SeriesUtil.asFinite(weight, 0.0)\n            }\n        }\n        return { 1.0 }\n    }\n\n    // ToDo: need to deal fith n/a values (see DensityStat)\n    fun weightVector(dataLength: Int, data: DataFrame): List<Double?> {\n        return if (data.has(TransformVar.WEIGHT)) {\n            data.getNumeric(TransformVar.WEIGHT)\n        } else List(dataLength) { 1.0 }\n    }\n\n    fun binCountAndWidth(dataRange: Double, binOptions: BinOptions): CountAndWidth {\n        var binCount = binOptions.binCount\n        val binWidth: Double\n        if (binOptions.hasBinWidth()) {\n            binWidth = binOptions.binWidth!!\n            var count = dataRange / binWidth\n            count = min(MAX_BIN_COUNT.toDouble(), count)\n            binCount = ceil(count).toInt()\n        } else {\n            binWidth = dataRange / binCount\n        }\n        return CountAndWidth(binCount, binWidth)\n    }\n\n    fun computeBins(\n        valuesX: List<Double?>,\n        startX: Double,\n        binCount: Int,\n        binWidth: Double,\n        weightAtIndex: (Int) -> Double,\n        densityNormalizingFactor: Double\n    ): BinsData {\n\n        var totalCount = 0.0\n        val countByBinIndex = HashMap<Int, MutableDouble>()\n//        val dataIndicesByBinIndex = HashMap<Int, MutableList<Int>>()\n        for (dataIndex in valuesX.indices) {\n            val x = valuesX[dataIndex]\n            if (!SeriesUtil.isFinite(x)) {\n                continue\n            }\n            val weight = weightAtIndex(dataIndex)\n            totalCount += weight\n            val binIndex = floor((x!! - startX) / binWidth).toInt()\n            if (!countByBinIndex.containsKey(binIndex)) {\n                countByBinIndex[binIndex] = MutableDouble(0.0)\n            }\n            countByBinIndex[binIndex]!!.getAndAdd(weight)\n\n//            if (!dataIndicesByBinIndex.containsKey(binIndex)) {\n//                dataIndicesByBinIndex[binIndex] = ArrayList()\n//            }\n\n//            dataIndicesByBinIndex[binIndex]!!.add(dataIndex)\n        }\n\n        val x = ArrayList<Double>()\n        val counts = ArrayList<Double>()\n        val densities = ArrayList<Double>()\n\n        val x0 = startX + binWidth / 2\n        for (i in 0 until binCount) {\n            x.add(x0 + i * binWidth)\n\n            var count = 0.0\n            // some bins are left empty (not excluded from map)\n            if (countByBinIndex.containsKey(i)) {\n                count = countByBinIndex[i]!!.get()\n            }\n\n            counts.add(count)\n            val density = count / totalCount * densityNormalizingFactor\n            densities.add(density)\n        }\n\n//        return BinsData(x, counts, densities, dataIndicesByBinIndex)\n        return BinsData(x, counts, densities)\n    }\n\n    class BinOptions(\n        binCount: Int, val binWidth: Double?  // optional\n    ) {\n        val binCount: Int = min(MAX_BIN_COUNT, max(1, binCount))\n\n        fun hasBinWidth(): Boolean {\n            return binWidth != null && binWidth > 0\n        }\n    }\n\n    class CountAndWidth(val count: Int, val width: Double)\n\n    class BinsData(\n        internal val x: List<Double>,\n        internal val count: List<Double>,\n        internal val density: List<Double>\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.sqrt\n\n/**\n * Calculate components of box and whisker plot.\n *\n * Creates a \"stat\" dataframe contaning:\n *  a) \"box\" data-points\n *      x\n *      y = NaN\n *      width    - width of box\n *      ymin     - lower whisker = smallest observation greater than or equal to lower hinge - 1.5 * IQR\n *      lower    - lower hinge, 25% quantile\n *      middle   - median, 50% quantile\n *      upper    - upper hinge, 75% quantile\n *      ymax     - upper whisker = largest observation less than or equal to upper hinge + 1.5 * IQR\n *\n *  b) \"outlier\" data-points\n *      x, y, width\n *      ymin, lower... = NaN\n *\n * Not implemented:\n * notchlower   - lower edge of notch = median - 1.58 * IQR / sqrt(n)\n * notchupper   - upper edge of notch = median + 1.58 * IQR / sqrt(n)\n */\nclass BoxplotStat(\n    private val whiskerIQRRatio: Double,    // ggplot: 'coef'\n    private val computeWidth: Boolean       // ggplot: 'varWidth'\n) : BaseStat(DEF_MAPPING) {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return super.hasDefaultMapping(aes) ||\n                aes == WIDTH && computeWidth\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        return if (aes == WIDTH) {\n            Stats.WIDTH\n        } else {\n            super.getDefaultMapping(aes)\n        }\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val ys = data.getNumeric(TransformVar.Y)\n        val xs = if (data.has(TransformVar.X)) {\n            data.getNumeric(TransformVar.X)\n        } else {\n            List<Double>(ys.size) { 0.0 }\n        }\n\n        val statData = buildStat(xs, ys, whiskerIQRRatio)\n\n        val statCount = statData.remove(Stats.COUNT)\n        val maxCountPerBin = statCount?.maxOrNull()?.toInt() ?: 0\n        if (maxCountPerBin == 0) {\n            return withEmptyStatValues()\n        }\n        if (computeWidth) {\n            // 'width' is in range 0..1\n            val norm = sqrt(maxCountPerBin.toDouble())\n            val statWidth = statCount!!.map { count -> sqrt(count) / norm }\n            statData[Stats.WIDTH] = statWidth\n        }\n\n        val builder = DataFrame.Builder()\n        for ((variable, series) in statData) {\n            builder.putNumeric(variable, series)\n        }\n        return builder.build()\n    }\n\n    companion object {\n        const val DEF_WHISKER_IQR_RATIO = 1.5\n        const val DEF_COMPUTE_WIDTH = false\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.YMIN to Stats.Y_MIN,\n            Aes.YMAX to Stats.Y_MAX,\n            Aes.LOWER to Stats.LOWER,\n            Aes.MIDDLE to Stats.MIDDLE,\n            Aes.UPPER to Stats.UPPER\n        )\n\n        fun buildStat(\n            xs: List<Double?>,\n            ys: List<Double?>,\n            whiskerIQRRatio: Double\n        ): MutableMap<DataFrame.Variable, List<Double>> {\n\n            val xyPairs = xs.zip(ys).filter { (x, y) ->\n                SeriesUtil.allFinite(x, y)\n            }\n            if (xyPairs.isEmpty()) {\n                return mutableMapOf()\n            }\n\n            val binnedData: MutableMap<Double, MutableList<Double>> = HashMap()\n            for ((x, y) in xyPairs) {\n                binnedData.getOrPut(x!!) { ArrayList() }.add(y!!)\n            }\n\n            val statX = ArrayList<Double>()\n            val statY = ArrayList<Double>()\n            val statMiddle = ArrayList<Double>()\n            val statLower = ArrayList<Double>()\n            val statUpper = ArrayList<Double>()\n            val statMin = ArrayList<Double>()\n            val statMax = ArrayList<Double>()\n\n            val statCount = ArrayList<Double>()\n\n            for ((x, bin) in binnedData) {\n                val count = bin.size.toDouble()\n\n                val summary = FiveNumberSummary(bin)\n                val middle = summary.median\n                val lowerHinge = summary.firstQuartile\n                val upperHinge = summary.thirdQuartile\n                val IQR = upperHinge - lowerHinge\n                val lowerFence = lowerHinge - IQR * whiskerIQRRatio\n                val upperFence = upperHinge + IQR * whiskerIQRRatio\n\n                var lowerWhisker = lowerFence\n                var upperWhisker = upperFence\n                if (SeriesUtil.allFinite(lowerFence, upperFence)) {\n                    val boxed = bin.filter { y -> y >= lowerFence && y <= upperFence }\n                    val range = SeriesUtil.range(boxed)\n                    if (range != null) {\n                        lowerWhisker = range.lowerEnd\n                        upperWhisker = range.upperEnd\n                    }\n                }\n\n                // add outliers first\n                val outliers = bin.filter { y -> y < lowerFence || y > upperFence }\n                for (y in outliers) {\n                    // 'outlier' data-point\n                    statX.add(x)\n                    statY.add(y)\n                    // no 'box' data\n                    statMiddle.add(Double.NaN)\n                    statLower.add(Double.NaN)\n                    statUpper.add(Double.NaN)\n                    statMin.add(Double.NaN)\n                    statMax.add(Double.NaN)\n\n                    statCount.add(count)\n\n                    // Note: outliers will also need 'width' value,\n                    // for the 'dodge' positioning to work correctly for all data-points.\n                }\n\n                // add 'box' data-point\n                statX.add(x)\n                statY.add(Double.NaN)  // no Y for 'box' data-point\n                statMiddle.add(middle)\n                statLower.add(lowerHinge)\n                statUpper.add(upperHinge)\n                statMin.add(lowerWhisker)\n                statMax.add(upperWhisker)\n\n                statCount.add(count)\n            }\n\n            return mutableMapOf(\n                Stats.X to statX,\n                Stats.Y to statY,\n                Stats.MIDDLE to statMiddle,\n                Stats.LOWER to statLower,\n                Stats.UPPER to statUpper,\n                Stats.Y_MIN to statMin,\n                Stats.Y_MAX to statMax,\n                Stats.COUNT to statCount,\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataFrame\n\ninternal class Contour private constructor() {\n\n    private val myContourX = ArrayList<Double>()\n    private val myContourY = ArrayList<Double>()\n    private val myContourLevel = ArrayList<Double>()\n    private val myContourGroup = ArrayList<Double>()\n\n    private var myGroup = 0.0\n\n    private val dataFrame: DataFrame\n        get() = DataFrame.Builder()\n                .putNumeric(Stats.X, myContourX)\n                .putNumeric(Stats.Y, myContourY)\n                .putNumeric(Stats.LEVEL, myContourLevel)\n                .putNumeric(Stats.GROUP, myContourGroup)\n                .build()\n\n    fun add(polygon: List<DoubleVector>, fillLevel: Double) {\n        for (p in polygon) {\n            myContourX.add(p.x)\n            myContourY.add(p.y)\n            myContourLevel.add(fillLevel)\n            myContourGroup.add(myGroup)\n        }\n        // each polygon in its own group\n        myGroup += 1.0\n    }\n\n    companion object {\n\n        fun getPathDataFrame(\n                levels: List<Double>, pathListByLevel: Map<Double, List<List<DoubleVector>>>): DataFrame {\n            val contour = Contour()\n            for (level in levels) {\n                val paths = pathListByLevel[level]!!\n                for (path in paths) {\n                    contour.add(path, level)\n                }\n            }\n            return contour.dataFrame\n        }\n\n        fun getPolygonDataFrame(\n                fillLevels: List<Double>, polygonListByFillLevel: Map<Double, List<DoubleVector>>): DataFrame {\n            val contour = Contour()\n\n            for (fillLevel in fillLevels) {\n                val polygon = polygonListByFillLevel[fillLevel]!!\n                contour.add(polygon, fillLevel)\n            }\n\n            return contour.dataFrame\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.stat.ContourStatUtil.removePathByEndpoints\n\nclass ContourFillHelper(xRange: ClosedRange<Double>, yRange: ClosedRange<Double>) {\n\n    private val myLowLeft: DoubleVector\n    private val myLowRight: DoubleVector\n    private val myUpLeft: DoubleVector\n    private val myUpRight: DoubleVector\n\n    init {\n        val xMin = xRange.lowerEnd\n        val xMax = xRange.upperEnd\n        val yMin = yRange.lowerEnd\n        val yMax = yRange.upperEnd\n        myLowLeft = DoubleVector(xMin, yMin)\n        myLowRight = DoubleVector(xMax, yMin)\n        myUpLeft = DoubleVector(xMin, yMax)\n        myUpRight = DoubleVector(xMax, yMax)\n    }\n\n    fun createPolygons(\n            pathByLevels: Map<Double, List<List<DoubleVector>>>, levels: List<Double>, fillLevels: List<Double>): Map<Double, List<DoubleVector>> {\n\n        val result = HashMap<Double, List<DoubleVector>>()\n\n        //getBoundary\n        val allPaths = ArrayList<List<DoubleVector>>()\n        for (level in pathByLevels.values) {\n            allPaths.addAll(level)\n        }\n\n        val cornerPoints = ArrayList<DoubleVector>()\n        val outerMap = createOuterMap(allPaths, cornerPoints)\n\n\n        val n = pathByLevels.keys.size\n\n        // The designated area is always to the left\n        for (i in 0 until n + 1) {\n            var polygonPieces: MutableList<List<DoubleVector>> = ArrayList()\n            val value = ArrayList<DoubleVector>()\n            if (i > 0) {\n                polygonPieces.addAll(\n                    reverseAll(\n                        pathByLevels[levels[i - 1]]!!\n                    )\n                )\n            }\n            if (i < n) {\n                polygonPieces.addAll(pathByLevels[levels[i]]!!)\n            }\n            polygonPieces = createClosedPolygonLevels(polygonPieces, outerMap, cornerPoints)\n            for (path in polygonPieces) {\n                value.addAll(path)\n            }\n            result[fillLevels[i]] = value\n        }\n        return result\n    }\n\n    private fun createClosedPolygonLevels(\n            openLevels: List<List<DoubleVector>>, outerMap: Map<DoubleVector, DoubleVector>, cornerPoints: List<DoubleVector>): MutableList<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n\n        val donePath = HashSet<MutableList<DoubleVector>>()\n        //Add boundary part to each openPath\n        for (level in openLevels) {\n            val levelCopy = ArrayList(level)\n            val p0 = levelCopy[0]\n            var p1 = levelCopy[levelCopy.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                result.add(levelCopy)\n                continue\n            }\n            //p1 remains to be the end of levelCopy\n            var pi2 = outerMap[p1]!!\n            levelCopy.add(pi2)\n            p1 = pi2\n            while (cornerPoints.contains(p1)) {\n                pi2 = outerMap[p1]!!\n                levelCopy.add(pi2)\n                p1 = pi2\n            }\n            donePath.add(levelCopy)\n        }\n\n        val pathByEndPoint = HashMap<DoubleVector, MutableList<DoubleVector>>()\n\n        for (path in donePath) {\n            val p0 = path[0]\n            val p1 = path[path.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                result.add(path)\n                continue\n            }\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n                removePathByEndpoints(path0, pathByEndPoint)\n                removePathByEndpoints(path1, pathByEndPoint)\n\n                val longPath: MutableList<DoubleVector>\n                if (path0 === path1) {\n                    //a cycle is formed\n                    path0!!.addAll(path.subList(1, path.size))\n                    result.add(path0)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath = path0\n                    longPath.addAll(path.subList(1, path.size - 1))\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath = path1!!\n                    longPath.addAll(0, path.subList(0, path.size - 1))\n                } else { //path0!=null\n                    longPath = path0\n                    longPath.addAll(path.subList(1, path.size))\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                pathByEndPoint[path[0]] = path\n                pathByEndPoint[path[path.size - 1]] = path\n            }\n        }\n\n        if (!pathByEndPoint.keys.isEmpty()) {\n            throw IllegalArgumentException(\"Some paths are not cleared yet there is something wrong!\" + pathByEndPoint.keys.size)\n        }\n\n        // check\n        for (path in result) {\n            if (path[0] != path[path.size - 1]) {\n                throw IllegalArgumentException(\"The polygons are not entirely closed!\")\n            }\n        }\n        return result\n    }\n\n    //counterclockwise\n    //update corner points for record\n    private fun createOuterMap(paths: List<List<DoubleVector>>, cornerPoints: MutableList<DoubleVector>): Map<DoubleVector, DoubleVector> {\n        val points = ArrayList<DoubleVector>()\n        for (path in paths) {\n            if (path[0] != path[path.size - 1]) {\n                points.add(path[0])\n                points.add(path[path.size - 1])\n            }\n        }\n\n        val result = HashMap<DoubleVector, DoubleVector>()\n\n        val list = ArrayList<MutableList<DoubleVector>>()\n        for (i in 0..3) {\n            list.add(ArrayList())\n        }\n\n        for (point in points) {\n            val kind = getKind(point)\n            when (kind) {\n                BorderKind.DOWN -> list[0].add(point)\n                BorderKind.RIGHT -> list[1].add(point)\n                BorderKind.UP -> list[2].add(point)\n                BorderKind.LEFT -> list[3].add(point)\n            }\n        }\n\n        list[0].sortWith(Comparator { o1, o2 -> o1.x.compareTo(o2.x) })\n        list[1].sortWith(Comparator { o1, o2 -> o1.y.compareTo(o2.y) })\n        list[2].sortWith(Comparator { o1, o2 -> o2.x.compareTo(o1.x) })\n        list[3].sortWith(Comparator { o1, o2 -> o2.y.compareTo(o1.y) })\n\n        // According to getKind: myLowLeft -> DOWN; myLowRight -> DOWN; myUpRight -> RIGHT; myUpLeft -> LEFT\n        val prepareMap = ArrayList<DoubleVector>()\n        if (!list[0].contains(myLowLeft)) {\n            prepareMap.add(myLowLeft)\n            cornerPoints.add(myLowLeft)\n        }\n        prepareMap.addAll(list[0])\n        if (!list[0].contains(myLowRight)) {\n            prepareMap.add(myLowRight)\n            cornerPoints.add(myLowRight)\n        }\n        prepareMap.addAll(list[1])\n        if (!list[1].contains(myUpRight)) {\n            prepareMap.add(myUpRight)\n            cornerPoints.add(myUpRight)\n        }\n        prepareMap.addAll(list[2])\n        if (!list[3].contains(myUpLeft)) {\n            prepareMap.add(myUpLeft)\n            cornerPoints.add(myUpLeft)\n        }\n        prepareMap.addAll(list[3])\n        prepareMap.add(prepareMap[0])\n        for (i in 0 until prepareMap.size - 1) {\n            result[prepareMap[i]] = prepareMap[i + 1]\n        }\n\n        return result\n    }\n\n    private fun getKind(point: DoubleVector): BorderKind {\n        return if (belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.DOWN\n        } else if (belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && !belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.RIGHT\n        } else if (!belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && !belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.UP\n        } else if (!belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.LEFT\n        } else {\n            throw IllegalArgumentException(\"The Contour Point is not on the border $point\")\n        }\n    }\n\n    private enum class BorderKind {\n        DOWN, RIGHT, UP, LEFT\n    }\n\n    companion object {\n\n        fun computeFillLevels(zRange: ClosedRange<Double>, levels: List<Double>): List<Double> {\n            val fillLevels = ArrayList<Double>()\n            fillLevels.add(zRange.lowerEnd)\n            for (i in 0 until levels.size - 1) {\n                fillLevels.add((levels[i] + levels[i + 1]) / 2.0)\n            }\n            fillLevels.add(zRange.upperEnd)\n            return fillLevels\n        }\n\n        private fun <E> reverseAll(list: List<List<E>>): List<List<E>> {\n            val result = ArrayList<List<E>>()\n            for (item in list) {\n                val copy = ArrayList(item)\n                copy.reverse()\n                result.add(copy)\n            }\n            return result\n        }\n\n        // a.x<b.x\n        private fun belowOrOnLine(a: DoubleVector, b: DoubleVector, test: DoubleVector): Boolean {\n            val value = test.subtract(a)\n            val standard = b.subtract(a)\n\n            return standard.y * value.x - value.y * standard.x >= 0\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\n\n/**\n * see doc for geom_contour/stat_contour\n *\n *\n * see also examples: https://www.inside-r.org/packages/cran/ggplot2/docs/stat_contour\n *\n *\n *\n *\n * Defaults:\n *\n *\n * geom = \"path\"\n * position = \"identity\"\n *\n *\n * Other params:\n *\n *\n * bins (def - 10) - Number of bins (overridden by binwidth)\n * binwidth - distance between contours.\n *\n *\n *\n *\n * Adds columns:\n *\n *\n * level - height of contour\n */\nclass ContourStat(binCount: Int, binWidth: Double?) : BaseStat(DEF_MAPPING) {\n\n    private val myBinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.Z)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y, Aes.Z)) {\n            return withEmptyStatValues()\n        }\n\n        val levels = ContourStatUtil.computeLevels(data, myBinOptions)\n            ?: return DataFrame.Builder.emptyFrame()\n\n        val pathListByLevel = ContourStatUtil.computeContours(data, levels)\n\n        // transform paths to x/y data\n        return Contour.getPathDataFrame(levels, pathListByLevel)\n    }\n\n    companion object {\n        const val DEF_BIN_COUNT = 10\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isSubTiny\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ContourStatUtil {\n    private val xLoc = doubleArrayOf(0.0, 1.0, 1.0, 0.0, .5)\n    private val yLoc = doubleArrayOf(0.0, 0.0, 1.0, 1.0, .5)\n\n    /**\n     * @param xs - series defining x-coordinates of data-points\n     * @return Pair(col, row) or fail if not a regular grid\n     */\n    internal fun estimateRegularGridShape(xs: List<Double?>): Pair<Int, Int> {\n        // num of columns\n        // regular X/Y grid is expected\n        var colCount = 0\n        var x0: Double? = null\n        for (x in xs) {\n            if (x0 == null) {\n                x0 = x\n            } else if (x == x0) {\n                break\n            }\n            colCount++\n        }\n\n        if (colCount <= 1) {\n            throw IllegalArgumentException(\"Data grid must be at least 2 columns wide (was $colCount)\")\n        }\n        val rowCount = xs.size / colCount\n        if (rowCount <= 1) {\n            throw IllegalArgumentException(\"Data grid must be at least 2 rows tall (was $rowCount)\")\n        }\n\n        return Pair(colCount, rowCount)\n    }\n\n    fun computeLevels(data: DataFrame, binOptions: BinStatUtil.BinOptions): List<Double>? {\n        if (!(data.has(TransformVar.X) && data.has(TransformVar.Y) && data.has(\n                TransformVar.Z\n            ))\n        ) {\n            return null\n        }\n        val zRange = data.range(TransformVar.Z)\n        return computeLevels(zRange, binOptions)\n    }\n\n    fun computeLevels(zRange: ClosedRange<Double>?, binOptions: BinStatUtil.BinOptions): List<Double>? {\n        if (zRange == null || isSubTiny(zRange)) return null\n\n        val b = BinStatUtil.binCountAndWidth(SeriesUtil.span(zRange), binOptions)\n        val levels = ArrayList<Double>()\n        for (i in 0 until b.count) {\n            var level = i * b.width + zRange.lowerEnd\n            level += b.width / 2   // shift all levels half-step to make 1-st level contour visible\n            levels.add(level)\n        }\n        return levels\n    }\n\n    internal fun computeContours(data: DataFrame, levels: List<Double>): Map<Double, List<List<DoubleVector>>> {\n        val xVector = data.getNumeric(TransformVar.X)\n        val zVector = data.getNumeric(TransformVar.Z)\n\n        val shape = estimateRegularGridShape(xVector)\n        val colCount = shape.first\n        val rowCount = shape.second\n\n        val xRange = data.range(TransformVar.X)!!\n        val yRange = data.range(TransformVar.Y)!!\n\n        return computeContours(\n            xRange,\n            yRange,\n            colCount,\n            rowCount,\n            zVector,\n            levels\n        )\n    }\n\n    fun computeContours(\n        xRange: ClosedRange<Double>,\n        yRange: ClosedRange<Double>,\n        colCount: Int,\n        rowCount: Int,\n        data: List<Double?>,\n        levels: List<Double>\n    ): Map<Double, List<List<DoubleVector>>> {\n\n        val xStep = SeriesUtil.span(xRange) / (colCount - 1)\n        val yStep = SeriesUtil.span(yRange) / (rowCount - 1)\n        val origin = DoubleVector(xRange.lowerEnd, yRange.lowerEnd)\n\n        val pathListByLevel = HashMap<Double, List<List<DoubleVector>>>()\n        for (level in levels) {\n            val levelSegments =\n                computeSegments(colCount, rowCount, data, level)\n            val paths = joinSegments(levelSegments)\n            // checkEdges(paths, colCount, rowCount); // debug use\n            var pathsReal =\n                convertPaths(paths, xStep, yStep, origin, level)\n            pathsReal = confirmPaths(pathsReal)\n            pathListByLevel[level] = pathsReal\n        }\n\n        return pathListByLevel\n    }\n\n    private fun joinSegments(segments: List<Pair<Edge, Edge>>): List<List<Edge>> {\n        val pathList = ArrayList<List<Edge>>()\n\n        val pathByEndPoint = HashMap<Edge, MutableList<Edge>>()\n\n        for (segment in segments) {\n            val p0 = segment.first\n            val p1 = segment.second\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n\n                if (path0 != null) {\n                    pathByEndPoint.remove(path0[0])\n                    pathByEndPoint.remove(path0[path0.size - 1])\n                }\n                if (path1 != null) {\n                    pathByEndPoint.remove(path1[0])\n                    pathByEndPoint.remove(path1[path1.size - 1])\n                }\n\n                val longPath: MutableList<Edge>\n                if (path0 === path1) {\n                    //a cycle is formed\n                    path0!!.add(segment.second)\n                    pathList.add(path0)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath = path0\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath = path1!!\n                    longPath.add(0, segment.first)\n                } else { // path0!=null\n                    longPath = path0\n                    longPath.add(segment.second)\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                val path = ArrayList<Edge>()\n                path.add(segment.first)\n                path.add(segment.second)\n                pathByEndPoint[segment.first] = path\n                pathByEndPoint[segment.second] = path\n            }\n        }\n\n        // collect paths (don't duplicate)\n        val pathSet = HashSet(pathByEndPoint.values)\n        for (path in pathSet) {\n            pathList.add(path)\n        }\n        return pathList\n    }\n\n    private fun convertPaths(\n        paths: List<List<Edge>>,\n        xStep: Double,\n        yStep: Double,\n        origin: DoubleVector,\n        level: Double?\n    ): List<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n\n        for (path in paths) {\n            val temp = ArrayList<DoubleVector>()\n            var lastPoint: DoubleVector? = null\n            for (edge in path) {\n                var intersect = edge.intersect(level!!)\n                intersect = DoubleVector(xStep * intersect.x, yStep * intersect.y).add(origin)\n                // in case two adjacent double vectors are the same\n                if (intersect == lastPoint) {\n                    continue\n                }\n                temp.add(intersect)\n                lastPoint = intersect\n            }\n            // in case of slight computational error in loops\n            if (path[0] == path[path.size - 1] && temp[0] != temp[temp.size - 1]) {\n                temp[temp.size - 1] = temp[0]\n            }\n            if (temp.size > 1) {\n                result.add(temp)\n            }\n        }\n\n        return result\n    }\n\n    private fun confirmPaths(paths: List<List<DoubleVector>>): List<List<DoubleVector>> {\n        // join paths that share the same end points\n        val newPaths = ArrayList<List<DoubleVector>>()\n\n        val pathByEndPoint = HashMap<DoubleVector, List<DoubleVector>>()\n\n        for (path in paths) {\n            val p0 = path[0]\n            val p1 = path[path.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                newPaths.add(path)\n                continue\n            }\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n                removePathByEndpoints(path0, pathByEndPoint)\n                removePathByEndpoints(path1, pathByEndPoint)\n\n                val longPath = ArrayList<DoubleVector>()\n                if (path0 === path1) {\n                    //a cycle is formed\n                    longPath.addAll(path0!!)\n                    longPath.addAll(path.subList(1, path.size))\n                    newPaths.add(longPath)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath.addAll(path0)\n                    longPath.addAll(path.subList(1, path.size - 1))\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath.addAll(path1!!)\n                    longPath.addAll(0, path.subList(0, path.size - 1))\n                } else { //path0!=null\n                    longPath.addAll(path0)\n                    longPath.addAll(path.subList(1, path.size))\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                pathByEndPoint[path[0]] = path\n                pathByEndPoint[path[path.size - 1]] = path\n            }\n        }\n\n        val pathSet = HashSet(pathByEndPoint.values)\n        for (path in pathSet) {\n            newPaths.add(path)\n        }\n\n        // prevent the degenerated polygons from providing weird outputs\n        val result = ArrayList<List<DoubleVector>>()\n        for (path in newPaths) {\n            result.addAll(pathSeparator(path))\n        }\n        return result\n    }\n\n    internal fun <T : List<DoubleVector>> removePathByEndpoints(\n        path: List<DoubleVector>?,\n        pathByEndPoint: MutableMap<DoubleVector, T>\n    ) {\n        if (path != null) {\n            pathByEndPoint.remove(path[0])\n            pathByEndPoint.remove(path[path.size - 1])\n        }\n    }\n\n    private fun pathSeparator(path: List<DoubleVector>): List<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n        var startIndex = 0\n        for (nextIndex in 1 until path.size - 1) {\n            if (path[startIndex] == path[nextIndex]) {\n                result.add(path.subList(startIndex, nextIndex + 1))\n                startIndex = nextIndex\n            }\n        }\n        if (startIndex == 0) {\n            return listOf(path)\n        } else {\n            result.add(path.subList(startIndex, path.size))\n            return result\n        }\n    }\n\n    private fun computeSegments(\n        colCount: Int,\n        rowCount: Int,\n        data: List<Double?>,\n        level: Double\n    ): List<Pair<Edge, Edge>> {\n\n        val segments = ArrayList<Pair<Edge, Edge>>()\n        for (row in 0 until rowCount - 1) {\n            for (col in 0 until colCount - 1) {\n                val i0 = row * colCount + col\n                val i1 = row * colCount + col + 1 // next right\n                val i2 = (row + 1) * colCount + col + 1 // next right & up\n                val i3 = (row + 1) * colCount + col // next up\n\n                val v = DoubleArray(5)\n                v[0] = data[i0]!!\n                v[1] = data[i1]!!\n                v[2] = data[i2]!!\n                v[3] = data[i3]!!\n\n                var min = v[0]\n                var max = v[0]\n                for (i in 1..3) {\n                    min = min(min, v[i])\n                    max = max(max, v[i])\n                }\n\n                if (min == max) {\n                    // special case: all points are in the same plane - drop\n                    continue\n                }\n\n                // v[4] = (v[0] + v[1] + v[2] + v[3]) / 4;   // center  (average of corners)\n                v[4] = (v[0] + v[1] + v[2] + v[3] - min - max) / 2   // center  (average of corners)\n\n                if (level > min && level <= max) {\n\n                    val cellSegments =\n                        computeSegmentsForGridCell(level, v, col, row)\n                    segments.addAll(cellSegments)\n                }\n            }\n        }\n\n        return segments\n    }\n\n    private fun computeSegmentsForGridCell(\n        level: Double?,\n        value5: DoubleArray,\n        col: Int,\n        row: Int\n    ): List<Pair<Edge, Edge>> {\n        // triangles:\n        // [0] 0-1-4\n        // [1] 1-2-4\n        // [2] 2-3-4\n        // [3] 3-0-4\n        // check each edge of each triangle - find edges that cross the level 'plane'\n\n        val result = ArrayList<Pair<Edge, Edge>>()\n        val points = ArrayList<TripleVector>()\n        var tempVector: MutableList<TripleVector>\n        for (i in 0..4) {\n            points.add(\n                TripleVector(\n                    col + xLoc[i],\n                    row + yLoc[i],\n                    value5[i]\n                )\n            )\n        }\n\n        // All triangles are counterclockwise\n        for (i in 0..3) {\n            val i1 = (i + 1) % 4\n            tempVector = ArrayList()\n            tempVector.add(points[i])\n            tempVector.add(points[i1])\n            tempVector.add(points[4])\n            val temp = intersectionSegment(tempVector, level)\n            if (temp != null) {\n                result.add(temp)\n            }\n        }\n        return result\n    }\n\n    private fun intersectionSegment(vectors: List<TripleVector>, level: Double?): Pair<Edge, Edge>? {\n        // input: a counterclockwise triangle\n        // output: a segment, such that the higher part is always to the right\n        val type = vectors[0].getType(level!!) * 100 + vectors[1].getType(level) * 10 + vectors[2].getType(level)\n        val start: Edge\n        val end: Edge\n        when (type) {\n            100 -> {\n                start = Edge(vectors[2], vectors[0])\n                end = Edge(vectors[0], vectors[1])\n            }\n            10 -> {\n                start = Edge(vectors[0], vectors[1])\n                end = Edge(vectors[1], vectors[2])\n            }\n            1 -> {\n                start = Edge(vectors[1], vectors[2])\n                end = Edge(vectors[2], vectors[0])\n            }\n            110 -> {\n                start = Edge(vectors[0], vectors[2])\n                end = Edge(vectors[2], vectors[1])\n            }\n            101 -> {\n                start = Edge(vectors[2], vectors[1])\n                end = Edge(vectors[1], vectors[0])\n            }\n            11 -> {\n                start = Edge(vectors[1], vectors[0])\n                end = Edge(vectors[0], vectors[2])\n            }\n            else -> return null\n        }\n        return Pair(start, end)\n    }\n\n    // to check if all the side edges are on the boarder **Debug Use**\n    private fun checkEdges(paths: List<List<Edge>>, colCount: Int, rowCount: Int) {\n        for (path in paths) {\n            if (path[0] != path[path.size - 1]) {\n                checkEdge(path[0], colCount, rowCount)\n                checkEdge(path[path.size - 1], colCount, rowCount)\n            }\n        }\n    }\n\n    private fun checkEdge(edge: Edge, colCount: Int, rowCount: Int) {\n        val a = edge.myA\n        val b = edge.myB\n        if (a.myX == 0 && b.myX == 0) {\n            return\n        }\n        if (a.myY == 0 && b.myY == 0) {\n            return\n        }\n        if (a.myX == colCount - 1 && b.myX == colCount - 1) {\n            return\n        }\n        if (a.myY == rowCount - 1 && b.myY == rowCount - 1) {\n            return\n        }\n        throw IllegalArgumentException(\"Check Edge Failed\")\n    }\n\n    private class TripleVector internal constructor(x: Double, y: Double, val z: Double) {\n        val myX: Int\n        val myY: Int\n        private val myIsCenter: Int\n\n        val coord: DoubleVector\n            get() = DoubleVector(x, y)\n\n        val x: Double\n            get() = this.myX + 0.5 * myIsCenter\n\n        val y: Double\n            get() = this.myY + 0.5 * myIsCenter\n\n        init {\n            this.myX = x.toInt()\n            this.myY = y.toInt()\n            this.myIsCenter = if (x % 1 == 0.0) 0 else 1\n        }\n\n        override fun equals(other: Any?): Boolean {\n            if (this === other) return true\n            if (other == null || this::class != other::class) return false\n            val that = other as TripleVector?\n            return myX == that!!.myX && myY == that.myY && myIsCenter == that.myIsCenter\n        }\n\n        override fun hashCode(): Int {\n            return arrayOf(myX, myY, myIsCenter).hashCode()\n        }\n\n        fun getType(level: Double): Int {\n            return if (z >= level) {\n                1\n            } else {\n                0\n            }\n        }\n    }\n\n    private class Edge internal constructor(val myA: TripleVector, val myB: TripleVector) {\n\n        override fun equals(other: Any?): Boolean {\n            if (other !is Edge) {\n                return false\n            }\n            val obj = other as Edge?\n            return this.myA == obj!!.myA && this.myB == obj.myB || this.myA == obj.myB && this.myB == obj.myA\n        }\n\n        override fun hashCode(): Int {\n            return myA.coord.hashCode() + myB.coord.hashCode()\n        }\n\n        fun intersect(level: Double): DoubleVector {\n            val z0 = myA.z\n            val z1 = myB.z\n\n            if (level == z0) {\n                return myA.coord\n            }\n            if (level == z1) {\n                return myB.coord\n            }\n\n            val ratio = (z1 - z0) / (level - z0)\n            val x0 = myA.x\n            val y0 = myA.y\n            val x1 = myB.x\n            val y1 = myB.y\n            val x = x0 + (x1 - x0) / ratio\n            val y = y0 + (y1 - y0) / ratio\n            return DoubleVector(x, y)\n        }\n    }\n}// **Debug Use**\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nclass ContourfStat(binCount: Int, binWidth: Double?) : BaseStat(DEF_MAPPING) {\n\n    private val myBinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.Z)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y, Aes.Z)) {\n            return withEmptyStatValues()\n        }\n\n        val levels = ContourStatUtil.computeLevels(data, myBinOptions)\n            ?: return DataFrame.Builder.emptyFrame()\n\n        val pathListByLevel = ContourStatUtil.computeContours(data, levels)\n\n        val xRange = data.range(TransformVar.X)!!\n        val yRange = data.range(TransformVar.Y)!!\n        val zRange = data.range(TransformVar.Z)!!\n        val helper = ContourFillHelper(xRange, yRange)\n        val fillLevels = ContourFillHelper.computeFillLevels(zRange, levels)\n        val polygonListByFillLevel = helper.createPolygons(pathListByLevel, levels, fillLevels)\n\n        return Contour.getPolygonDataFrame(\n            fillLevels,\n            polygonListByFillLevel\n        )\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.stat.CorrelationUtil.correlationMatrix\nimport jetbrains.datalore.plot.base.stat.math3.correlationPearson\nimport kotlin.math.abs\n\n/**\n * Computes correlation between numeric variables in data.\n * Creates a data-frame with the following variables:\n *   - '..x..' : X coordinates\n *   - '..y..' : Y coordinates\n *   - '..corr..' : correlation (in range -1..1)\n *   - '..corr_abs..' : absolute value of correlation (in range 0..1)\n */\nclass CorrelationStat(\n    val correlationMethod: Method,\n    val type: Type,\n    val fillDiagonal: Boolean,\n    val threshold: Double\n) : BaseStat(DEF_MAPPING) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        require(correlationMethod == Method.PEARSON) {\n            \"Unsupported correlation method: $correlationMethod (only Pearson is currently available)\"\n        }\n\n        require(threshold in 0.0..1.0) {\n            \"Threshold value:  $threshold must be in interval [0.0, 1.0]\"\n        }\n\n        val cm = correlationMatrix(data, type, fillDiagonal, ::correlationPearson, threshold)\n        val values = cm.getNumeric(Stats.CORR)\n        val abs: List<Double?> = values.map { it?.let(::abs) }\n\n        return cm.builder().putNumeric(Stats.CORR_ABS, abs).build()\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf()\n    }\n\n    enum class Method {\n        PEARSON,\n        SPEARMAN,\n        KENDALL\n    }\n\n    enum class Type {\n        FULL,\n        UPPER,\n        LOWER\n    }\n\n    companion object {\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.COLOR to Stats.CORR,\n            Aes.FILL to Stats.CORR,\n            Aes.LABEL to Stats.CORR\n        )\n\n        val DEF_CORRELATION_METHOD = Method.PEARSON\n        val DEF_TYPE = Type.FULL\n        const val DEF_FILL_DIAGONAL = true\n        const val DEF_THRESHOLD = 0.0\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil.isNumeric\nimport jetbrains.datalore.plot.base.stat.regression.allFinite\nimport kotlin.math.abs\nimport kotlin.Pair as Pair\n\nobject CorrelationUtil {\n\n    fun correlation(\n        lxs: List<Double?>, lys: List<Double?>,\n        correlationFunction: (DoubleArray, DoubleArray) -> Double\n    ): Double {\n        val (xs, ys) = allFinite(lxs, lys)\n        return correlationFunction(xs, ys)\n    }\n\n    private fun createComparator(vars: List<DataFrame.Variable>): Comparator<String> {\n        val indexMap = vars.withIndex().map { it.value.label to it.index }.toMap()\n\n        return Comparator { a: String, b: String ->\n            val lhsWeight = indexMap[a] ?: error(\"Unknown variable label ${a}.\")\n            val rhsWeight = indexMap[b] ?: error(\"Unknown variable label ${b}.\")\n            return@Comparator lhsWeight - rhsWeight\n        }\n    }\n\n    fun correlationMatrix(\n        data: DataFrame,\n        type: CorrelationStat.Type,\n        fillDiagonal: Boolean,\n        correlationFunction: (DoubleArray, DoubleArray) -> Double,\n        threshold: Double = CorrelationStat.DEF_THRESHOLD\n    ): DataFrame {\n        val numerics = data.variables().filter { isNumeric(data, it.name) }\n        val knownVars = mutableSetOf<String>()\n        val corrData = mutableMapOf<Pair<String, String>, Double>()\n\n        fun addCorrelation(varX: String, varY: String, v: Double) {\n            if (abs(v) >= threshold) {\n                knownVars.add(varX)\n                knownVars.add(varY)\n                corrData[varX to varY] = v\n            }\n        }\n\n        for ((i, vx) in numerics.withIndex()) {\n            val xs = data.getNumeric(vx)\n\n            if (fillDiagonal) {    // values on main diagonal does not require calculations\n                addCorrelation(vx.label, vx.label, 1.0)\n            }\n\n            for (j in 0 until i) {\n                val vy = numerics[j]\n                val ys = data.getNumeric(vy)\n                val c = correlation(xs, ys, correlationFunction)\n\n                if (type == CorrelationStat.Type.FULL || type == CorrelationStat.Type.LOWER) {\n                    addCorrelation(vx.label, vy.label, c)\n                }\n\n                if (type == CorrelationStat.Type.FULL || type == CorrelationStat.Type.UPPER) {\n                    addCorrelation(vy.label, vx.label, c)\n                }\n            }\n        }\n\n        val var1 = arrayListOf<String>()\n        val var2 = arrayListOf<String>()\n        val corr = arrayListOf<Double?>()\n\n        // put all correlation matrix values (including nulls)\n        // to result dataframe in proper order, to keep matrix shape.\n        val sortedVars = knownVars.sortedWith(createComparator(numerics))\n\n        for (x in sortedVars) {\n            for (y in sortedVars) {\n                var1.add(x)\n                var2.add(y)\n                corr.add(corrData[x to y])\n            }\n        }\n\n        return DataFrame.Builder()\n            .putDiscrete(Stats.X, var1)\n            .putDiscrete(Stats.Y, var2)\n            .putNumeric(Stats.CORR, corr)\n            .build()\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * Counts the number of cases at each x position.\n * (or if the weight aesthetic is supplied, the sum of the weights)\n */\ninternal class CountStat : BaseStat(DEF_MAPPING) {\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val valuesX = data.getNumeric(TransformVar.X)\n        val weight = BinStatUtil.weightVector(valuesX.size, data)\n\n        val statX = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n\n        val countByX = countByX(valuesX, weight)\n        for (x in countByX.keys) {\n            statX.add(x)\n            statCount.add(countByX[x]!!.get())\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.COUNT, statCount)\n            .build()\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.COUNT\n        )\n\n        private fun countByX(valuesX: List<Double?>, weight: List<Double?>): Map<Double, MutableDouble> {\n            val result = LinkedHashMap<Double, MutableDouble>()\n            for (i in valuesX.indices) {\n                val x = valuesX[i]\n                if (SeriesUtil.isFinite(x)) {\n                    if (!result.containsKey(x!!)) {\n                        result[x] = MutableDouble(0.0)\n                    }\n                    result[x]!!.getAndAdd(SeriesUtil.asFinite(weight[i], 0.0))\n                }\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.math3.BlockRealMatrix\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass Density2dStat constructor(\n    bandWidthX: Double?,\n    bandWidthY: Double?,\n    bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    adjust: Double,\n    kernel: DensityStat.Kernel,\n    nX: Int,\n    nY: Int,\n    isContour: Boolean,\n    binCount: Int,\n    binWidth: Double\n\n) : AbstractDensity2dStat(\n    bandWidthX = bandWidthX,\n    bandWidthY = bandWidthY,\n    bandWidthMethod = bandWidthMethod,\n    adjust = adjust,\n    kernel = kernel,\n    nX = nX,\n    nY = nY,\n    isContour = isContour,\n    binCount = binCount,\n    binWidth = binWidth\n) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xVector = data.getNumeric(TransformVar.X)\n        val yVector = data.getNumeric(TransformVar.Y)\n\n        // if no data, return empty\n        if (xVector.isEmpty()) {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        // if length of x and y doesn't match, throw error\n        if (xVector.size != yVector.size) {\n            throw RuntimeException(\"len(x)= \" + xVector.size + \" and len(y)= \" + yVector.size + \" doesn't match!\")\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val bandWidth = DoubleArray(2)\n//        bandWidth[0] = if (bandWidths != null) bandWidths!![0] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            xVector\n//        )\n        bandWidth[0] = getBandWidthX(xVector)\n//        bandWidth[1] = if (bandWidths != null) bandWidths!![1] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            yVector\n//        )\n        bandWidth[1] = getBandWidthY(yVector)\n\n        val stepsX = DensityStatUtil.createStepValues(xRange!!, nX)\n        val stepsY = DensityStatUtil.createStepValues(yRange!!, nY)\n\n        // weight aesthetics\n        val groupWeight = BinStatUtil.weightVector(xVector.size, data)\n\n        val matrixX = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                xVector,\n                stepsX,\n                kernelFun,\n                bandWidth[0],\n                adjust,\n                groupWeight\n            )\n        )\n        val matrixY = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                yVector,\n                stepsY,\n                kernelFun,\n                bandWidth[1],\n                adjust,\n                groupWeight\n            )\n        )\n        // size: nY * nX\n        val matrixFinal = matrixY.multiply(matrixX.transpose())\n\n        for (row in 0 until nY) {\n            for (col in 0 until nX) {\n                statX.add(stepsX[col])\n                statY.add(stepsY[row])\n                statDensity.add(matrixFinal.getEntry(row, col) / SeriesUtil.sum(groupWeight))\n                //newGroups.add((double) (int) group);\n            }\n        }\n\n        if (isContour) {\n            val zRange = SeriesUtil.range(statDensity)\n            val levels = ContourStatUtil.computeLevels(zRange, binOptions)\n                ?: return DataFrame.Builder.emptyFrame()\n\n            val pathListByLevel = ContourStatUtil.computeContours(\n                xRange,\n                yRange,\n                nX,\n                nY,\n                statDensity,\n                levels\n            )\n\n            return Contour.getPathDataFrame(levels, pathListByLevel)\n        } else {\n            return DataFrame.Builder()\n                .putNumeric(Stats.X, statX)\n                .putNumeric(Stats.Y, statY)\n                .putNumeric(Stats.DENSITY, statDensity)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.math3.BlockRealMatrix\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass Density2dfStat(\n    bandWidthX: Double?,\n    bandWidthY: Double?,\n    bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    adjust: Double,\n    kernel: DensityStat.Kernel,\n    nX: Int,\n    nY: Int,\n    isContour: Boolean,\n    binCount: Int,\n    binWidth: Double\n\n) : AbstractDensity2dStat(\n    bandWidthX = bandWidthX,\n    bandWidthY = bandWidthY,\n    bandWidthMethod = bandWidthMethod,\n    adjust = adjust,\n    kernel = kernel,\n    nX = nX,\n    nY = nY,\n    isContour = isContour,\n    binCount = binCount,\n    binWidth = binWidth\n) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xVector = data.getNumeric(TransformVar.X)\n        val yVector = data.getNumeric(TransformVar.Y)\n\n        // if no data, return empty\n        if (xVector.isEmpty()) {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        // if length of x and y doesn't match, throw error\n        if (xVector.size != yVector.size) {\n            throw RuntimeException(\"len(x)= \" + xVector.size + \" and len(y)= \" + yVector.size + \" doesn't match!\")\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val bandWidth = DoubleArray(2)\n//        bandWidth[0] = if (bandWidths != null) bandWidths!![0] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            xVector\n//        )\n        bandWidth[0] = getBandWidthX(xVector)\n\n//        bandWidth[1] = if (bandWidths != null) bandWidths!![1] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            yVector\n//        )\n        bandWidth[1] = getBandWidthY(yVector)\n\n        val stepsX = DensityStatUtil.createStepValues(xRange!!, nX)\n        val stepsY = DensityStatUtil.createStepValues(yRange!!, nY)\n\n        // weight aesthetics\n        val groupWeight = BinStatUtil.weightVector(xVector.size, data)\n\n        val matrixX = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                xVector,\n                stepsX,\n                kernelFun,\n                bandWidth[0],\n                adjust,\n                groupWeight\n            )\n        )\n        val matrixY = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                yVector,\n                stepsY,\n                kernelFun,\n                bandWidth[1],\n                adjust,\n                groupWeight\n            )\n        )\n        // size: nY * nX\n        val matrixFinal = matrixY.multiply(matrixX.transpose())\n\n        for (row in 0 until nY) {\n            for (col in 0 until nX) {\n                statX.add(stepsX[col])\n                statY.add(stepsY[row])\n                statDensity.add(matrixFinal.getEntry(row, col) / SeriesUtil.sum(groupWeight))\n            }\n        }\n\n        if (isContour) {\n            // ToDo: change zrange into the range of z over entire dataset\n            val zRange = SeriesUtil.range(statDensity)\n            val levels = ContourStatUtil.computeLevels(zRange, binOptions)\n                ?: return DataFrame.Builder.emptyFrame()\n\n            val pathListByLevel = ContourStatUtil.computeContours(\n                xRange,\n                yRange,\n                nX,\n                nY,\n                statDensity,\n                levels\n            )\n            val helper = ContourFillHelper(xRange, yRange)\n            val fillLevels =\n                ContourFillHelper.computeFillLevels(zRange!!, levels)\n            val polygonListByFillLevel = helper.createPolygons(pathListByLevel, levels, fillLevels)\n\n            return Contour.getPolygonDataFrame(\n                fillLevels.subList(\n                    1,\n                    fillLevels.size\n                ), polygonListByFillLevel\n            )\n        } else {\n            return DataFrame.Builder()\n                .putNumeric(Stats.X, statX)\n                .putNumeric(Stats.Y, statY)\n                .putNumeric(Stats.DENSITY, statDensity)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.DensityStat.BandWidthMethod.NRD0\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * Computes kernel density estimate for 'n' values evenly distributed throughout the range of the input series.\n *\n * If size of the input series exceeds the 'fullScalMax' value, then the less accurate but more efficient computation replaces\n * highly inefficient 'full scan' computation.\n */\nclass DensityStat(\n    private val bandWidth: Double?,\n    private val bandWidthMethod: BandWidthMethod,  // Used is `bandWidth` is not set.\n    private val adjust: Double,\n    private val kernel: Kernel,\n    private val n: Int,\n    private val fullScalMax: Int\n) : BaseStat(DEF_MAPPING) {\n\n    init {\n        require(n <= MAX_N) { \"The input n = $n  > $MAX_N is too large!\" }\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val xs: List<Double>\n        val weights: List<Double>\n        if (data.has(TransformVar.WEIGHT)) {\n            val filtered = SeriesUtil.filterFinite(\n                data.getNumeric(TransformVar.X),\n                data.getNumeric(TransformVar.WEIGHT)\n            )\n            val xsFiltered = filtered[0]\n            val weightsFiltered = filtered[1]\n\n            val (xsSorted, weightsSorted) = xsFiltered\n                .zip(weightsFiltered).sortedBy { it.first }\n                .unzip()\n            xs = xsSorted\n            weights = weightsSorted\n\n        } else {\n            xs = data.getNumeric(TransformVar.X)\n                .filterNotNull().filter { it.isFinite() }\n                .sorted()\n            weights = List(xs.size) { 1.0 }\n        }\n\n        if (xs.isEmpty()) return withEmptyStatValues()\n\n        val rangeX = statCtx.overallXRange() ?: ClosedRange(-0.5, 0.5)\n\n        val statX = DensityStatUtil.createStepValues(rangeX, n)\n        val statDensity = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n        val statScaled = ArrayList<Double>()\n\n        val bandWidth = bandWidth ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            xs\n        )\n\n        val kernelFun: (Double) -> Double = DensityStatUtil.kernel(kernel)\n        val densityFunction: (Double) -> Double = when (xs.size <= fullScalMax) {\n            true -> DensityStatUtil.densityFunctionFullScan(\n                xs,\n                weights,\n                kernelFun,\n                bandWidth,\n                adjust\n            )\n            false -> DensityStatUtil.densityFunctionFast(\n                xs,\n                weights,\n                kernelFun,\n                bandWidth,\n                adjust\n            )\n        }\n\n        val nTotal = weights.sum()\n        for (x in statX) {\n            val d = densityFunction(x)\n            statCount.add(d)\n            statDensity.add(d / nTotal)\n        }\n\n        val maxm = statCount.maxOrNull()!!\n        for (d in statCount) {\n            statScaled.add(d / maxm)\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.DENSITY, statDensity)\n            .putNumeric(Stats.COUNT, statCount)\n            .putNumeric(Stats.SCALED, statScaled)\n            .build()\n    }\n\n    enum class Kernel {\n        GAUSSIAN,\n        RECTANGULAR,\n        TRIANGULAR,\n        BIWEIGHT,\n        EPANECHNIKOV,\n        OPTCOSINE,\n        COSINE\n    }\n\n    enum class BandWidthMethod {\n        NRD0,\n        NRD\n    }\n\n    companion object {\n        val DEF_KERNEL = Kernel.GAUSSIAN\n        const val DEF_ADJUST = 1.0\n        const val DEF_N = 512\n        val DEF_BW = NRD0\n        const val DEF_FULL_SCAN_MAX = 5000\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.DENSITY\n        )\n\n        private const val MAX_N = 1024\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.*\n\nobject DensityStatUtil {\n\n    private const val DEF_STEP_SIZE = 0.5\n\n    private fun stdDev(data: List<Double>): Double {\n        var sum = 0.0\n        var counter = 0.0\n\n        for (i in data) {\n            sum += i\n        }\n        val mean = sum / data.size\n        for (i in data) {\n            counter += (i - mean).pow(2.0)\n        }\n        return sqrt(counter / data.size)\n    }\n\n    fun bandWidth(bw: DensityStat.BandWidthMethod, valuesX: List<Double?>): Double {\n        val mySize = valuesX.size\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val valuesXFinite = valuesX.filter { SeriesUtil.isFinite(it) } as List<Double>\n        val dataSummary = FiveNumberSummary(valuesXFinite)\n        val myIQR = dataSummary.thirdQuartile - dataSummary.firstQuartile\n        val myStdD = stdDev(valuesXFinite)\n\n        when (bw) {\n            DensityStat.BandWidthMethod.NRD0 -> {\n                if (myIQR > 0) {\n                    return 0.9 * min(myStdD, myIQR / 1.34) * mySize.toDouble().pow(-0.2)\n                }\n                if (myStdD > 0) {\n                    return 0.9 * myStdD * mySize.toDouble().pow(-0.2)\n                }\n            }\n            DensityStat.BandWidthMethod.NRD -> {\n                if (myIQR > 0) {\n                    return 1.06 * min(myStdD, myIQR / 1.34) * mySize.toDouble().pow(-0.2)\n                }\n                if (myStdD > 0) {\n                    return 1.06 * myStdD * mySize.toDouble().pow(-0.2)\n                }\n            }\n        }\n        return 1.0\n    }\n\n    fun kernel(ker: DensityStat.Kernel): (Double) -> Double {\n        return when (ker) {\n            DensityStat.Kernel.GAUSSIAN -> { value -> 1 / sqrt(2 * PI) * exp(-0.5 * value.pow(2.0)) }\n            DensityStat.Kernel.RECTANGULAR -> { value -> if (abs(value) <= 1) 0.5 else 0.0 }\n            DensityStat.Kernel.TRIANGULAR -> { value -> if (abs(value) <= 1) 1 - abs(value) else 0.0 }\n            DensityStat.Kernel.BIWEIGHT -> { value -> if (abs(value) <= 1) .9375 * (1 - value * value).pow(2.0) else 0.0 }\n            DensityStat.Kernel.EPANECHNIKOV -> { value -> if (abs(value) <= 1) .75 * (1 - value * value) else 0.0 }\n            DensityStat.Kernel.OPTCOSINE -> { value -> if (abs(value) <= 1) PI / 4 * cos(PI / 2 * value) else 0.0 }\n            else //case COSINE\n            -> { value -> if (abs(value) <= 1) (cos(PI * value) + 1) / 2 else 0.0 }\n        }\n    }\n\n    internal fun densityFunctionFullScan(\n        xs: List<Double>,\n        weights: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double\n    ): (Double) -> Double {\n        val h = bw * ad\n        return { x ->\n            var sum = 0.0\n            for (i in xs.indices) {\n                sum += ker((x - xs[i]) / h) * weights[i]\n            }\n            sum / h\n        }\n    }\n\n    internal fun densityFunctionFast(\n        xs: List<Double>,  // must be ordered!\n        weights: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double\n    ): (Double) -> Double {\n        val h = bw * ad\n        val cutoff = h * 5\n\n        return { x ->\n            var sum = 0.0\n            var from = xs.binarySearch(x - cutoff)\n            if (from < 0) {\n                from = -from - 1\n            }\n            var to = xs.binarySearch(x + cutoff)\n            if (to < 0) {\n                to = -to - 1\n            }\n\n            for (i in (from until to)) {\n                sum += ker((x - xs[i]) / h) * weights[i]\n            }\n            sum / h\n        }\n    }\n\n    fun createStepValues(range: ClosedRange<Double>, n: Int): List<Double> {\n        val x = ArrayList<Double>()\n        var min = range.lowerEnd\n        var max = range.upperEnd\n        val step: Double\n\n        if (max == min) {\n            max += DEF_STEP_SIZE\n            min -= DEF_STEP_SIZE\n        }\n        step = (max - min) / (n - 1)\n        for (i in 0 until n) {\n            x.add(min + step * i)\n        }\n        return x\n    }\n\n    fun toKernel(method: String): DensityStat.Kernel {\n        return when (method) {\n            \"gaussian\" -> DensityStat.Kernel.GAUSSIAN\n            \"rectangular\", \"uniform\" -> DensityStat.Kernel.RECTANGULAR\n            \"triangular\" -> DensityStat.Kernel.TRIANGULAR\n            \"biweight\", \"quartic\" -> DensityStat.Kernel.BIWEIGHT\n            \"epanechikov\", \"parabolic\" -> DensityStat.Kernel.EPANECHNIKOV\n            \"optcosine\" -> DensityStat.Kernel.OPTCOSINE\n            \"cosine\" -> DensityStat.Kernel.COSINE\n            else -> throw IllegalArgumentException(\n                \"Unsupported kernel method: '$method'.\\n\" +\n                        \"Use one of: gaussian, rectangular, triangular, biweight, epanechikov, optcosine, cos.\"\n            )\n        }\n    }\n\n    fun toBandWidthMethod(bw: String): DensityStat.BandWidthMethod {\n        return when (bw) {\n            \"nrd0\" -> DensityStat.BandWidthMethod.NRD0\n            \"nrd\" -> DensityStat.BandWidthMethod.NRD\n            else -> throw IllegalArgumentException(\n                \"Unsupported bandwidth method: '$bw'.\\n\" +\n                        \"Use one of: nrd0, nrd.\"\n            )\n        }\n    }\n\n    fun createRawMatrix(\n        values: List<Double?>,\n        list: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double,\n        weight: List<Double?>\n    ): Array<DoubleArray> {\n        val a = bw * ad\n        val n = values.size\n        val x = list.size\n        val result = Array(x) { DoubleArray(n) }\n\n        for (row in 0 until x) {\n            for (col in 0 until n) {\n                result[row][col] = ker((list[row] - values[col]!!) / a) * sqrt(weight[col]!!) / a\n            }\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.round\n\n/**\n * For a set of data, the minimum, first quartile, median, third quartile, and maximum.\n * Note: A boxplot is a visual display of the five-number summary.\n */\ninternal class FiveNumberSummary {\n\n    val min: Double\n    val max: Double\n    val median: Double\n    val firstQuartile: Double\n    // 25 %\n    val thirdQuartile: Double    // 75 %\n\n    private fun medianAtPointer(l: List<Double>, pointer: Double): Double {\n        val rint = round(pointer)\n        return if (pointer == rint) {\n            l[pointer.toInt()]\n        } else (l[ceil(pointer).toInt()] + l[floor(pointer).toInt()]) / 2.0\n    }\n\n    constructor(data: List<Double>) {\n        val sorted = Ordering.natural<Double>().sortedCopy(data)\n        if (sorted.isEmpty()) {\n            thirdQuartile = Double.NaN\n            firstQuartile = thirdQuartile\n            median = firstQuartile\n            max = median\n            min = max\n        } else if (sorted.size == 1) {\n            thirdQuartile = sorted.get(0)\n            firstQuartile = thirdQuartile\n            median = firstQuartile\n            max = median\n            min = max\n        } else {\n            val maxIndex = sorted.size - 1\n\n            min = sorted.get(0)\n            max = sorted.get(maxIndex)\n            median = medianAtPointer(sorted, maxIndex * .5)\n            firstQuartile = medianAtPointer(sorted, maxIndex * .25)\n            thirdQuartile = medianAtPointer(sorted, maxIndex * .75)\n        }\n    }\n\n    constructor(min: Double, max: Double, median: Double, firstQuartile: Double, thirdQuartile: Double) {\n        this.min = min\n        this.max = max\n        this.median = median\n        this.firstQuartile = firstQuartile\n        this.thirdQuartile = thirdQuartile\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as FiveNumberSummary?\n        return that!!.min.compareTo(min) == 0 &&\n                that.max.compareTo(max) == 0 &&\n                that.median.compareTo(median) == 0 &&\n                that.firstQuartile.compareTo(firstQuartile) == 0 &&\n                that.thirdQuartile.compareTo(thirdQuartile) == 0\n    }\n\n    override fun hashCode(): Int {\n        return arrayOf(min, max, median, firstQuartile, thirdQuartile).hashCode()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\ninternal class MultiOrdering<K : Comparable<K>>(private val myKeys: List<K?>) {\n    private val myIndices: MutableList<Int>\n\n    init {\n        myIndices = ArrayList(myKeys.size)\n        for (i in myKeys.indices) {\n            myIndices.add(i)\n        }\n\n        myIndices.sortWith(Comparator { i: Int?, j: Int? ->\n            val keyI = myKeys[i!!]\n            val keyJ = myKeys[j!!]\n            when {\n                keyI === keyJ -> 0\n                keyI == null -> -1\n                keyJ == null -> 1\n                else -> keyI.compareTo(keyJ)\n            }\n        })\n    }\n\n    fun <T> sortedCopy(l: List<T?>): List<T?> {\n        require(l.size == myIndices.size) { \"Expected size \" + myIndices.size + \" but was size \" + l.size }\n        val copy = ArrayList<T?>(myIndices.size)\n        for (oldIndex in myIndices) {\n            val v = l[oldIndex]\n            copy.add(v)\n        }\n        return copy\n    }\n\n    fun sortedCopyOfKeys(): List<K?> {\n        return sortedCopy(myKeys)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nclass SimpleStatContext(private val myDataFrame: DataFrame) :\n    StatContext {\n\n    override fun overallXRange(): ClosedRange<Double>? {\n        return myDataFrame.range(TransformVar.X)\n    }\n\n    override fun overallYRange(): ClosedRange<Double>? {\n        return myDataFrame.range(TransformVar.Y)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable.Source.STAT\nimport jetbrains.datalore.plot.base.Stat\nimport jetbrains.datalore.plot.base.StatContext\n\nobject Stats {\n    // stat variables can be referenced by name ..name.. (p 54)\n    val X = DataFrame.Variable(\"..x..\", STAT, \"x\")\n    val Y = DataFrame.Variable(\"..y..\", STAT, \"y\")\n    val COUNT = DataFrame.Variable(\"..count..\", STAT, \"count\")\n    val DENSITY = DataFrame.Variable(\"..density..\", STAT, \"density\")\n    val Y_MIN = DataFrame.Variable(\"..ymin..\", STAT, \"y min\")\n    val Y_MAX = DataFrame.Variable(\"..ymax..\", STAT, \"y max\")\n    val SE = DataFrame.Variable(\"..se..\", STAT, \"standard error\")\n    val LEVEL = DataFrame.Variable(\"..level..\", STAT, \"level\")\n\n    val LOWER = DataFrame.Variable(\"..lower..\", STAT, \"lower\")\n    val MIDDLE = DataFrame.Variable(\"..middle..\", STAT, \"middle\")\n    val UPPER = DataFrame.Variable(\"..upper..\", STAT, \"upper\")\n    val WIDTH = DataFrame.Variable(\"..width..\", STAT, \"width\")\n\n    val CORR = DataFrame.Variable(\"..corr..\", STAT, \"corr\")\n    val CORR_ABS = DataFrame.Variable(\"..corr_abs..\", STAT, \"corr_abs\")\n\n    val SCALED = DataFrame.Variable(\"..scaled..\", STAT, \"scaled\")\n\n    val GROUP = DataFrame.Variable(\"..group..\", STAT, \"group\")\n\n    val IDENTITY: Stat = IdentityStat()\n\n    private val VARS: Map<String, DataFrame.Variable> = run {\n        val variableList = listOf(\n            X,\n            Y,\n            COUNT,\n            DENSITY,\n            Y_MIN,\n            Y_MAX,\n            SE,\n            LEVEL,\n            LOWER,\n            MIDDLE,\n            UPPER,\n            WIDTH,\n            SCALED,\n            GROUP,\n            CORR,\n            CORR_ABS\n        )\n\n        val result = HashMap<String, DataFrame.Variable>()\n        for (variable in variableList) {\n            result[variable.name] = variable\n        }\n        result\n    }\n\n    fun isStatVar(varName: String): Boolean {\n        return VARS.containsKey(varName)\n    }\n\n    fun statVar(varName: String): DataFrame.Variable {\n        require(VARS.containsKey(varName)) { \"Unknown stat variable $varName\" }\n        return VARS[varName]!!\n    }\n\n    fun defaultMapping(stat: Stat): Map<Aes<*>, DataFrame.Variable> {\n        val map = HashMap<Aes<*>, DataFrame.Variable>()\n        for (aes in Aes.values()) {\n            if (stat.hasDefaultMapping(aes)) {\n                val variable = stat.getDefaultMapping(aes)\n                map[aes] = variable\n            }\n        }\n        return map\n    }\n\n    fun count(): Stat {\n        return CountStat()\n    }\n\n    fun bin(\n        binCount: Int = BinStat.DEF_BIN_COUNT,\n        binWidth: Double? = null,\n        center: Double? = null,\n        boundary: Double? = null\n    ): BinStat {\n        var xPosKind = BinStat.XPosKind.NONE\n        var xPosValue = 0.0\n        if (boundary != null) {\n            xPosKind = BinStat.XPosKind.BOUNDARY\n            xPosValue = boundary\n        } else if (center != null) {\n            xPosKind = BinStat.XPosKind.CENTER\n            xPosValue = center\n        }\n\n        return BinStat(\n            binCount = binCount,\n            binWidth = binWidth,\n            xPosKind = xPosKind,\n            xPos = xPosValue\n        )\n    }\n\n    fun smooth(\n        smootherPointCount: Int = SmoothStat.DEF_EVAL_POINT_COUNT,\n        smoothingMethod: SmoothStat.Method = SmoothStat.DEF_SMOOTHING_METHOD,\n        confidenceLevel: Double = SmoothStat.DEF_CONFIDENCE_LEVEL,\n        displayConfidenceInterval: Boolean = SmoothStat.DEF_DISPLAY_CONFIDENCE_INTERVAL,\n        span: Double = SmoothStat.DEF_SPAN,\n        polynomialDegree: Int = SmoothStat.DEF_DEG,\n        loessCriticalSize: Int = SmoothStat.DEF_LOESS_CRITICAL_SIZE,\n        samplingSeed: Long = SmoothStat.DEF_SAMPLING_SEED\n    ): SmoothStat {\n        return SmoothStat(\n            smootherPointCount = smootherPointCount,\n            smoothingMethod = smoothingMethod,\n            confidenceLevel = confidenceLevel,\n            displayConfidenceInterval = displayConfidenceInterval,\n            span = span,\n            polynomialDegree = polynomialDegree,\n            loessCriticalSize = loessCriticalSize,\n            samplingSeed = samplingSeed\n        )\n    }\n\n    fun corr(\n        correlationMethod: CorrelationStat.Method = CorrelationStat.DEF_CORRELATION_METHOD,\n        type: CorrelationStat.Type = CorrelationStat.DEF_TYPE,\n        fillDiagonal: Boolean = CorrelationStat.DEF_FILL_DIAGONAL,\n        threshold: Double = CorrelationStat.DEF_THRESHOLD\n    ): CorrelationStat {\n        return CorrelationStat(\n            correlationMethod = correlationMethod,\n            type = type,\n            fillDiagonal = fillDiagonal,\n            threshold = threshold\n        )\n    }\n\n    fun contour(\n        binCount: Int = ContourStat.DEF_BIN_COUNT,\n        binWidth: Double? = null\n    ): ContourStat {\n        return ContourStat(\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun contourf(\n        binCount: Int = ContourStat.DEF_BIN_COUNT,\n        binWidth: Double? = null\n    ): ContourfStat {\n        return ContourfStat(\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun boxplot(\n        whiskerIQRRatio: Double = BoxplotStat.DEF_WHISKER_IQR_RATIO,\n        computeWidth: Boolean = BoxplotStat.DEF_COMPUTE_WIDTH\n    ): BoxplotStat {\n        return BoxplotStat(whiskerIQRRatio, computeWidth)\n    }\n\n    fun density(\n        bandWidth: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod = DensityStat.DEF_BW,\n        adjust: Double = DensityStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = DensityStat.DEF_KERNEL,\n        n: Int = DensityStat.DEF_N,\n        fullScalMax: Int = DensityStat.DEF_FULL_SCAN_MAX\n    ): DensityStat {\n        return DensityStat(\n            bandWidth = bandWidth,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            n = n,\n            fullScalMax = fullScalMax\n        )\n    }\n\n    fun density2d(\n        bandWidthX: Double? = null,\n        bandWidthY: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod = AbstractDensity2dStat.DEF_BW,  // Used is `bandWidth` is not set.\n        adjust: Double = AbstractDensity2dStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = AbstractDensity2dStat.DEF_KERNEL,\n        nX: Int = AbstractDensity2dStat.DEF_N,\n        nY: Int = AbstractDensity2dStat.DEF_N,\n        isContour: Boolean = AbstractDensity2dStat.DEF_CONTOUR,\n        binCount: Int = AbstractDensity2dStat.DEF_BIN_COUNT,\n        binWidth: Double = AbstractDensity2dStat.DEF_BIN_WIDTH\n    ): AbstractDensity2dStat {\n        return Density2dStat(\n            bandWidthX = bandWidthX,\n            bandWidthY = bandWidthY,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            nX = nX,\n            nY = nY,\n            isContour = isContour,\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun density2df(\n        bandWidthX: Double? = null,\n        bandWidthY: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n        adjust: Double = AbstractDensity2dStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = AbstractDensity2dStat.DEF_KERNEL,\n        nX: Int = AbstractDensity2dStat.DEF_N,\n        nY: Int = AbstractDensity2dStat.DEF_N,\n        isContour: Boolean = AbstractDensity2dStat.DEF_CONTOUR,\n        binCount: Int = AbstractDensity2dStat.DEF_BIN_COUNT,\n        binWidth: Double = AbstractDensity2dStat.DEF_BIN_WIDTH\n    ): AbstractDensity2dStat {\n        return Density2dfStat(\n            bandWidthX = bandWidthX,\n            bandWidthY = bandWidthY,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            nX = nX,\n            nY = nY,\n            isContour = isContour,\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    private class IdentityStat internal constructor() : BaseStat(emptyMap()) {\n\n        override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        override fun consumes(): List<Aes<*>> {\n            return emptyList()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Base class for solvers.\n *\n * @version $Id$\n * @since 3.0\n */\nabstract class AbstractUnivariateSolver : BaseAbstractUnivariateSolver<UnivariateFunction>,\n    UnivariateSolver {\n    /**\n     * Construct a solver with given absolute accuracy.\n     *\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(absoluteAccuracy: Double) : super(absoluteAccuracy) {}\n\n    /**\n     * Construct a solver with given accuracies.\n     *\n     * @param relativeAccuracy Maximum relative error.\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver with given accuracies.\n     *\n     * @param relativeAccuracy Maximum relative error.\n     * @param absoluteAccuracy Maximum absolute error.\n     * @param functionValueAccuracy Maximum function value error.\n     */\n    protected constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double,\n        functionValueAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/** The kinds of solutions that a [ (bracketed univariate real) root-finding algorithm][BracketedUnivariateSolver] may accept as solutions.\n * This basically controls whether or not under-approximations and\n * over-approximations are allowed.\n *\n *\n * If all solutions are accepted ([.ANY_SIDE]), then the solution\n * that the root-finding algorithm returns for a given root may be equal to the\n * actual root, but it may also be an approximation that is slightly smaller\n * or slightly larger than the actual root. Root-finding algorithms generally\n * only guarantee that the returned solution is within the requested\n * tolerances. In certain cases however, in particular for\n * [state events][org.apache.commons.math3.ode.events.EventHandler] of\n * [ODE solvers][org.apache.commons.math3.ode.ODEIntegrator], it\n * may be necessary to guarantee that a solution is returned that lies on a\n * specific side the solution.\n *\n * @see BracketedUnivariateSolver\n *\n * @since 3.0\n * @version $Id$\n */\nenum class AllowedSolution {\n    /** There are no additional side restriction on the solutions for\n     * root-finding. That is, both under-approximations and over-approximations\n     * are allowed. So, if a function f(x) has a root at x = x0, then the\n     * root-finding result s may be smaller than x0, equal to x0, or greater\n     * than x0.\n     */\n    ANY_SIDE,\n\n    /** Only solutions that are less than or equal to the actual root are\n     * acceptable as solutions for root-finding. In other words,\n     * over-approximations are not allowed. So, if a function f(x) has a root\n     * at x = x0, then the root-finding result s must satisfy s &lt;= x0.\n     */\n    LEFT_SIDE,\n\n    /** Only solutions that are greater than or equal to the actual root are\n     * acceptable as solutions for root-finding. In other words,\n     * under-approximations are not allowed. So, if a function f(x) has a root\n     * at x = x0, then the root-finding result s must satisfy s &gt;= x0.\n     */\n    RIGHT_SIDE,\n\n    /** Only solutions for which values are less than or equal to zero are\n     * acceptable as solutions for root-finding. So, if a function f(x) has\n     * a root at x = x0, then the root-finding result s must satisfy f(s) &lt;= 0.\n     */\n    BELOW_SIDE,\n\n    /** Only solutions for which values are greater than or equal to zero are\n     * acceptable as solutions for root-finding. So, if a function f(x) has\n     * a root at x = x0, then the root-finding result s must satisfy f(s) &gt;= 0.\n     */\n    ABOVE_SIDE\n\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\n\n\n/**\n * Provide a default implementation for several functions useful to generic\n * solvers.\n *\n * @param <FUNC> Type of function to solve.\n *\n * @version $Id$\n * @since 2.0\n</FUNC> */\nabstract class BaseAbstractUnivariateSolver<FUNC : UnivariateFunction>\n/**\n * Construct a solver with given accuracies.\n *\n * @param relativeAccuracy Maximum relative error.\n * @param absoluteAccuracy Maximum absolute error.\n * @param functionValueAccuracy Maximum function value error.\n */\n@JvmOverloads protected constructor(\n    /** Relative accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val relativeAccuracy: Double,\n    /** Absolute accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val absoluteAccuracy: Double,\n    /** Function value accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val functionValueAccuracy: Double = DEFAULT_FUNCTION_VALUE_ACCURACY\n) : BaseUnivariateSolver<FUNC> {\n    /** Evaluations counter.  */\n    private val myEvaluations = Incrementor()\n    /** Lower end of search interval.  */\n    /**\n     * @return the lower end of the search interval.\n     */\n    var min: Double = 0.toDouble()\n        private set\n    /** Higher end of search interval.  */\n    /**\n     * @return the higher end of the search interval.\n     */\n    var max: Double = 0.toDouble()\n        private set\n    /** Initial guess.  */\n    /**\n     * @return the initial guess.\n     */\n    var startValue: Double = 0.toDouble()\n        private set\n    /** Function to solve.  */\n    private var function: FUNC? = null\n\n    /** {@inheritDoc}  */\n    override val maxEvaluations: Int\n        get() = myEvaluations.maximalCount\n\n    /**\n     * Construct a solver with given absolute accuracy.\n     *\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(absoluteAccuracy: Double) : this(\n        DEFAULT_RELATIVE_ACCURACY,\n        absoluteAccuracy,\n        DEFAULT_FUNCTION_VALUE_ACCURACY\n    ) {\n    }\n\n    override val evaluations = myEvaluations.count\n\n    /**\n     * Compute the objective function value.\n     *\n     * @param point Point at which the objective function must be evaluated.\n     * @return the objective function value at specified point.\n     * @throws TooManyEvaluationsException if the maximal number of evaluations\n     * is exceeded.\n     */\n    protected fun computeObjectiveValue(point: Double): Double {\n        incrementEvaluationCount()\n        return function!!.value(point)\n    }\n\n    /**\n     * Prepare for computation.\n     * Subclasses must call this method if they override any of the\n     * `solve` methods.\n     *\n     * @param f Function to solve.\n     * @param min Lower bound for the interval.\n     * @param max Upper bound for the interval.\n     * @param startValue Start value to use.\n     * @param maxEval Maximum number of evaluations.\n     */\n    protected fun setup(\n        maxEval: Int,\n        f: FUNC,\n        min: Double, max: Double,\n        startValue: Double\n    ) {\n\n        // Reset.\n        this.min = min\n        this.max = max\n        this.startValue = startValue\n        function = f\n        myEvaluations.maximalCount = maxEval\n        myEvaluations.resetCount()\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, min: Double, max: Double, startValue: Double): Double {\n        // Initialization.\n        setup(maxEval, f, min, max, startValue)\n\n        // Perform computation.\n        return doSolve()\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, min: Double, max: Double): Double {\n        return solve(maxEval, f, min, max, min + 0.5 * (max - min))\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, startValue: Double): Double {\n        return solve(maxEval, f, Double.NaN, Double.NaN, startValue)\n    }\n\n    /**\n     * Method for implementing actual optimization algorithms in derived\n     * classes.\n     *\n     * @return the root.\n     * @throws TooManyEvaluationsException if the maximal number of evaluations\n     * is exceeded.\n     * @throws NoBracketingException if the initial search interval does not bracket\n     * a root and the solver requires it.\n     */\n    protected abstract fun doSolve(): Double\n\n    /**\n     * Check whether the function takes opposite signs at the endpoints.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @return `true` if the function values have opposite signs at the\n     * given points.\n     */\n    protected fun isBracketing(\n        lower: Double,\n        upper: Double\n    ): Boolean {\n        return UnivariateSolverUtils.isBracketing(function!!, lower, upper)\n    }\n\n    /**\n     * Check whether the arguments form a (strictly) increasing sequence.\n     *\n     * @param start First number.\n     * @param mid Second number.\n     * @param end Third number.\n     * @return `true` if the arguments form an increasing sequence.\n     */\n    protected fun isSequence(\n        start: Double,\n        mid: Double,\n        end: Double\n    ): Boolean {\n        return UnivariateSolverUtils.isSequence(start, mid, end)\n    }\n\n    /**\n     * Check that the endpoints specify an interval.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws org.apache.commons.math3.exception.NumberIsTooLargeException\n     * if `lower >= upper`.\n     */\n    protected fun verifyInterval(\n        lower: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifyInterval(lower, upper)\n    }\n\n    /**\n     * Check that `lower < initial < upper`.\n     *\n     * @param lower Lower endpoint.\n     * @param initial Initial value.\n     * @param upper Upper endpoint.\n     * @throws org.apache.commons.math3.exception.NumberIsTooLargeException\n     * if `lower >= initial` or `initial >= upper`.\n     */\n    protected fun verifySequence(\n        lower: Double,\n        initial: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifySequence(lower, initial, upper)\n    }\n\n    /**\n     * Check that the endpoints specify an interval and the function takes\n     * opposite signs at the endpoints.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NoBracketingException if\n     * the function has the same sign at the endpoints.\n     */\n    protected fun verifyBracketing(\n        lower: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifyBracketing(function!!, lower, upper)\n    }\n\n    /**\n     * Increment the evaluation count by one.\n     * Method [.computeObjectiveValue] calls this method internally.\n     * It is provided for subclasses that do not exclusively use\n     * `computeObjectiveValue` to solve the function.\n     * See e.g. [AbstractDifferentiableUnivariateSolver].\n     */\n    protected fun incrementEvaluationCount() {\n        myEvaluations.incrementCount()\n\n    }\n\n    companion object {\n        /** Default relative accuracy.  */\n        private val DEFAULT_RELATIVE_ACCURACY = 1e-14\n        /** Default function value accuracy.  */\n        private val DEFAULT_FUNCTION_VALUE_ACCURACY = 1e-15\n    }\n}\n/**\n * Construct a solver with given accuracies.\n *\n * @param relativeAccuracy Maximum relative error.\n * @param absoluteAccuracy Maximum absolute error.\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n\n/**\n * This is a utility class that provides computation methods related to the\n * Beta family of functions.\n *\n * @version $Id: Beta.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject Beta {\n    /** Maximum allowed numerical error.  */\n    private val DEFAULT_EPSILON = 10e-15\n\n    /**\n     * Returns the regularized beta function I(x, a, b).\n     *\n     * @param x the value.\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized beta function I(x, a, b)\n     * @throws org.apache.commons.math3.exception.MaxCountExceededException\n     * if the algorithm fails to converge.\n     */\n    fun regularizedBeta(\n        x: Double,\n        a: Double, b: Double,\n        maxIterations: Int\n    ): Double {\n        return regularizedBeta(\n            x,\n            a,\n            b,\n            DEFAULT_EPSILON,\n            maxIterations\n        )\n    }\n\n    /**\n     * Returns the regularized beta function I(x, a, b).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Beta Function](mathworld.wolfram.com/RegularizedBetaFunction.html).\n     *  *\n     * [\n * Regularized Beta Function](functions.wolfram.com/06.21.10.0001.01).\n     *\n     *\n     * @param x the value.\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized beta function I(x, a, b)\n     * @throws org.apache.commons.math3.exception.MaxCountExceededException\n     * if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedBeta(\n        x: Double,\n        a: Double, b: Double,\n        epsilon: Double = DEFAULT_EPSILON, maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (x.isNaN() ||\n            a.isNaN() ||\n            b.isNaN() ||\n            x < 0 ||\n            x > 1 ||\n            a <= 0.0 ||\n            b <= 0.0\n        ) {\n            ret = Double.NaN\n        } else if (x > (a + 1.0) / (a + b + 2.0)) {\n            ret = 1.0 - regularizedBeta(\n                1.0 - x,\n                b,\n                a,\n                epsilon,\n                maxIterations\n            )\n        } else {\n            val fraction = object : ContinuedFraction() {\n\n                override fun getB(n: Int, x: Double): Double {\n                    @Suppress(\"NAME_SHADOWING\")\n                    val ret: Double\n                    val m: Double\n                    if (n % 2 == 0) { // even\n                        m = n / 2.0\n                        ret = m * (b - m) * x / ((a + 2 * m - 1) * (a + 2 * m))\n                    } else {\n                        m = (n - 1.0) / 2.0\n                        ret = -((a + m) * (a + b + m) * x) / ((a + 2 * m) * (a + 2 * m + 1.0))\n                    }\n                    return ret\n                }\n\n                override fun getA(n: Int, x: Double): Double {\n                    return 1.0\n                }\n            }\n            ret = exp(\n                a * ln(x) + b * ln(1.0 - x) -\n                        ln(a) - logBeta(a, b, epsilon, maxIterations)\n            ) * 1.0 / fraction.evaluate(x, epsilon, maxIterations)\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the natural logarithm of the beta function B(a, b).\n     *\n     * The implementation of this method is based on:\n     *\n     *  * [\n * Beta Function](mathworld.wolfram.com/BetaFunction.html), equation (1).\n     *\n     *\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return log(B(a, b)).\n     */\n    @JvmOverloads\n    fun logBeta(\n        a: Double, b: Double,\n        @Suppress(\"UNUSED_PARAMETER\") epsilon: Double = DEFAULT_EPSILON,\n        @Suppress(\"UNUSED_PARAMETER\") maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (a.isNaN() ||\n            b.isNaN() ||\n            a <= 0.0 ||\n            b <= 0.0\n        ) {\n            ret = Double.NaN\n        } else {\n            ret = Gamma.logGamma(a) + Gamma.logGamma(\n                b\n            ) - Gamma.logGamma(a + b)\n        }\n\n        return ret\n    }\n}\n/**\n * Default constructor.  Prohibit instantiation.\n */\n/**\n * Returns the\n * [\n * regularized beta function](mathworld.wolfram.com/RegularizedBetaFunction.html) I(x, a, b).\n *\n * @param x Value.\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @return the regularized beta function I(x, a, b).\n * @throws org.apache.commons.math3.exception.MaxCountExceededException\n * if the algorithm fails to converge.\n */\n/**\n * Returns the\n * [\n * regularized beta function](mathworld.wolfram.com/RegularizedBetaFunction.html) I(x, a, b).\n *\n * @param x Value.\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @param epsilon When the absolute value of the nth item in the\n * series is less than epsilon the approximation ceases to calculate\n * further elements in the series.\n * @return the regularized beta function I(x, a, b)\n * @throws org.apache.commons.math3.exception.MaxCountExceededException\n * if the algorithm fails to converge.\n */\n/**\n * Returns the natural logarithm of the beta function B(a, b).\n *\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @return log(B(a, b)).\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.min\n\nclass BlockRealMatrix {\n    /** Block size.  */\n    private val BLOCK_SIZE = 52\n    /** Number of rows of the matrix.  */\n    private var rows: Int = 0\n    /** Number of columns of the matrix.  */\n    private var columns: Int = 0\n    /** Number of block rows of the matrix.  */\n    private var blockRows: Int = 0\n    /** Number of block columns of the matrix.  */\n    private var blockColumns: Int = 0\n    /** Blocks of matrix entries.  */\n    private lateinit var blocks: Array<DoubleArray>\n    /**\n     * Create a new matrix with the supplied row and column dimensions.\n     *\n     * @param rows  the number of rows in the new matrix\n     * @param columns  the number of columns in the new matrix\n     * @throws org.apache.commons.math3.exception.NotStrictlyPositiveException\n     * if row or column dimension is not positive.\n     */\n    constructor(rows: Int, columns: Int) {\n        this.rows = rows\n        this.columns = columns\n\n        // number of blocks\n        blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        // allocate storage blocks, taking care of smaller ones at right and bottom\n        blocks = createBlocksLayout(rows, columns)\n    }\n\n    /**\n     * Create a new dense matrix copying entries from raw layout data.\n     *\n     * The input array *must* already be in raw layout.\n     *\n     * Calling this constructor is equivalent to call:\n     * <pre>matrix = new BlockRealMatrix(rawData.length, rawData[0].length,\n     * toBlocksLayout(rawData), false);</pre>\n     *\n     *\n     * @param rawData data for new matrix, in raw layout\n     * @throws DimensionMismatchException if the shape of `blockData` is\n     * inconsistent with block layout.\n     * @see .BlockRealMatrix\n     */\n    constructor(rawData: Array<DoubleArray>) {\n\n        create(rawData.size, rawData[0].size, toBlocksLayout(rawData), false)\n    }\n\n    /**\n     * Create a new dense matrix copying entries from block layout data.\n     *\n     * The input array *must* already be in blocks layout.\n     *\n     * @param rows Number of rows in the new matrix.\n     * @param columns Number of columns in the new matrix.\n     * @param blockData data for new matrix\n     * @param copyArray Whether the input array will be copied or referenced.\n     * @throws DimensionMismatchException if the shape of `blockData` is\n     * inconsistent with block layout.\n     * @see .createBlocksLayout\n     * @see .toBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    fun create(\n        rows: Int, columns: Int,\n        blockData: Array<DoubleArray>, copyArray: Boolean\n    ) {\n        this.rows = rows\n        this.columns = columns\n\n        // number of blocks\n        blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        val blocksCopyList = ArrayList<DoubleArray>()\n        if (copyArray) {\n            // allocate storage blocks, taking care of smaller ones at right and bottom\n        } else {\n            // reference existing array\n            blocks = blockData\n        }\n\n        var index = 0\n        for (iBlock in 0 until blockRows) {\n            val iHeight = blockHeight(iBlock)\n            var jBlock = 0\n            while (jBlock < blockColumns) {\n                if (blockData[index].size != iHeight * blockWidth(jBlock)) {\n                    error(\"\")\n                    //throw DimensionMismatchException(\n                    //    blockData[index].size,\n                    //    iHeight * blockWidth(jBlock)\n                    //)\n                }\n                if (copyArray) {\n                    blocksCopyList.add(blockData[index].copyOf())\n                    //blocks[index] = blockData[index].copyOf()\n                }\n                ++jBlock\n                ++index\n            }\n        }\n\n        if (copyArray) {\n            blocks = blocksCopyList.toTypedArray()\n        }\n    }\n\n    /**\n     * Create a data array in blocks layout.\n     *\n     *\n     * This method can be used to create the array argument of the [ ][.BlockRealMatrix] constructor.\n     *\n     * @param rows Number of rows in the new matrix.\n     * @param columns Number of columns in the new matrix.\n     * @return a new data array in blocks layout.\n     * @see .toBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    private fun createBlocksLayout(rows: Int, columns: Int): Array<DoubleArray> {\n        val blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        val blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        val blocksList = ArrayList<DoubleArray>()\n        var blockIndex = 0\n        for (iBlock in 0 until blockRows) {\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n            val iHeight = pEnd - pStart\n            for (jBlock in 0 until blockColumns) {\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, columns)\n                val jWidth = qEnd - qStart\n                blocksList.add(DoubleArray(iHeight * jWidth))\n                ++blockIndex\n            }\n        }\n\n        return blocksList.toTypedArray()\n    }\n\n    fun transpose(): BlockRealMatrix {\n        val nRows = getRowDimension()\n        val nCols = getColumnDimension()\n        val out = BlockRealMatrix(nCols, nRows)\n\n        // perform transpose block-wise, to ensure good cache behavior\n        var blockIndex = 0\n        for (iBlock in 0 until blockColumns) {\n            for (jBlock in 0 until blockRows) {\n                // transpose current block\n                val outBlock = out.blocks[blockIndex]\n                val tBlock = blocks[jBlock * blockColumns + iBlock]\n                val pStart = iBlock * BLOCK_SIZE\n                val pEnd = min(pStart + BLOCK_SIZE, columns)\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, rows)\n                var k = 0\n                for (p in pStart until pEnd) {\n                    val lInc = pEnd - pStart\n                    var l = p - pStart\n                    for (q in qStart until qEnd) {\n                        outBlock[k] = tBlock[l]\n                        ++k\n                        l += lInc\n                    }\n                }\n                // go to next block\n                ++blockIndex\n            }\n        }\n\n        return out\n    }\n\n    /**\n     * Returns the result of postmultiplying this by `m`.\n     *\n     * @param m Matrix to postmultiply by.\n     * @return `this` * m.\n     * @throws MatrixDimensionMismatchException if the matrices are not\n     * compatible.\n     */\n    fun multiply(m: BlockRealMatrix): BlockRealMatrix {\n        // safety check\n        if (this.getColumnDimension() != m.getRowDimension()) {\n            error(\"Matrix multiply dimension mismatch: ${this.getColumnDimension()} x ${m.getRowDimension()}\")\n        }\n\n        val out = BlockRealMatrix(rows, m.columns)\n\n        // perform multiplication block-wise, to ensure good cache behavior\n        var blockIndex = 0\n        for (iBlock in 0 until out.blockRows) {\n\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n\n            for (jBlock in 0 until out.blockColumns) {\n                val jWidth = out.blockWidth(jBlock)\n                val jWidth2 = jWidth + jWidth\n                val jWidth3 = jWidth2 + jWidth\n                val jWidth4 = jWidth3 + jWidth\n\n                // select current block\n                val outBlock = out.blocks[blockIndex]\n\n                // perform multiplication on current block\n                for (kBlock in 0 until blockColumns) {\n                    val kWidth = blockWidth(kBlock)\n                    val tBlock = blocks[iBlock * blockColumns + kBlock]\n                    val mBlock = m.blocks[kBlock * m.blockColumns + jBlock]\n                    var k = 0\n                    for (p in pStart until pEnd) {\n                        val lStart = (p - pStart) * kWidth\n                        val lEnd = lStart + kWidth\n                        for (nStart in 0 until jWidth) {\n                            var sum = 0.0\n                            var l = lStart\n                            var n = nStart\n                            while (l < lEnd - 3) {\n                                sum += tBlock[l] * mBlock[n] +\n                                        tBlock[l + 1] * mBlock[n + jWidth] +\n                                        tBlock[l + 2] * mBlock[n + jWidth2] +\n                                        tBlock[l + 3] * mBlock[n + jWidth3]\n                                l += 4\n                                n += jWidth4\n                            }\n                            while (l < lEnd) {\n                                sum += tBlock[l++] * mBlock[n]\n                                n += jWidth\n                            }\n                            outBlock[k] += sum\n                            ++k\n                        }\n                    }\n                }\n                // go to next block\n                ++blockIndex\n            }\n        }\n\n        return out\n    }\n\n\n    /** {@inheritDoc}  */\n    fun getEntry(row: Int, column: Int): Double {\n        //MatrixUtils.checkMatrixIndex(this, row, column)\n        if (row < 0 || row > getRowDimension()) error(\"row out of range: $row\")\n        if (column < 0 || column > getColumnDimension()) error(\"column out of range: $column\")\n\n        val iBlock = row / BLOCK_SIZE\n        val jBlock = column / BLOCK_SIZE\n        val k = (row - iBlock * BLOCK_SIZE) * blockWidth(jBlock) + (column - jBlock * BLOCK_SIZE)\n        return blocks[iBlock * blockColumns + jBlock][k]\n    }\n\n    private fun getRowDimension(): Int {\n        return rows\n    }\n\n    /** {@inheritDoc}  */\n    private fun getColumnDimension(): Int {\n        return columns\n    }\n\n    /**\n     * Get the width of a block.\n     * @param blockColumn column index (in block sense) of the block\n     * @return width (number of columns) of the block\n     */\n    private fun blockWidth(blockColumn: Int): Int {\n        return if (blockColumn == blockColumns - 1) columns - blockColumn * BLOCK_SIZE else BLOCK_SIZE\n    }\n\n    /**\n     * Get the height of a block.\n     * @param blockRow row index (in block sense) of the block\n     * @return height (number of rows) of the block\n     */\n    private fun blockHeight(blockRow: Int): Int {\n        return if (blockRow == blockRows - 1) rows - blockRow * BLOCK_SIZE else BLOCK_SIZE\n    }\n\n    /**\n     * Convert a data array from raw layout to blocks layout.\n     *\n     *\n     * Raw layout is the straightforward layout where element at row i and\n     * column j is in array element `rawData[i][j]`. Blocks layout\n     * is the layout used in [BlockRealMatrix] instances, where the matrix\n     * is split in square blocks (except at right and bottom side where blocks may\n     * be rectangular to fit matrix size) and each block is stored in a flattened\n     * one-dimensional array.\n     *\n     *\n     *\n     * This method creates an array in blocks layout from an input array in raw layout.\n     * It can be used to provide the array argument of the [ ][.BlockRealMatrix] constructor.\n     *\n     * @param rawData Data array in raw layout.\n     * @return a new data array containing the same entries but in blocks layout.\n     * @throws DimensionMismatchException if `rawData` is not rectangular.\n     * @see .createBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    fun toBlocksLayout(rawData: Array<DoubleArray>): Array<DoubleArray> {\n        val rows = rawData.size\n        val columns = rawData[0].size\n        val blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        val blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        // safety checks\n        for (i in rawData.indices) {\n            val length = rawData[i].size\n            if (length != columns) {\n                error(\"Wrong dimension: $columns, $length\")\n            }\n        }\n\n        // convert array\n        val blocksList = ArrayList<DoubleArray>()\n        var blockIndex = 0\n        for (iBlock in 0 until blockRows) {\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n            val iHeight = pEnd - pStart\n            for (jBlock in 0 until blockColumns) {\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, columns)\n                val jWidth = qEnd - qStart\n\n                // allocate new block\n                val block = DoubleArray(iHeight * jWidth)\n                blocksList.add(block)\n\n                // copy data\n                var index = 0\n                for (p in pStart until pEnd) {\n                    rawData[p].copyInto(block, index, qStart, qEnd)\n                    //System.arraycopy(rawData[p], qStart, block, index, jWidth)\n                    index += jWidth\n                }\n                ++blockIndex\n            }\n        }\n\n        return blocksList.toTypedArray()\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\n\n/**\n * This class implements the [\n * Brent algorithm](mathworld.wolfram.com/BrentsMethod.html) for finding zeros of real univariate functions.\n * The function should be continuous but not necessarily smooth.\n * The `solve` method returns a zero `x` of the function `f`\n * in the given interval `[a, b]` to within a tolerance\n * `6 eps abs(x) + t` where `eps` is the relative accuracy and\n * `t` is the absolute accuracy.\n * The given interval must bracket the root.\n *\n * @version $Id: BrentSolver.java 1244107 2012-02-14 16:17:55Z erans $\n */\nclass BrentSolver : AbstractUnivariateSolver {\n    /**\n     * Construct a solver.\n     *\n     * @param absoluteAccuracy Absolute accuracy.\n     */\n    @JvmOverloads\n    constructor(absoluteAccuracy: Double = DEFAULT_ABSOLUTE_ACCURACY) : super(absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver.\n     *\n     * @param relativeAccuracy Relative accuracy.\n     * @param absoluteAccuracy Absolute accuracy.\n     */\n    constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver.\n     *\n     * @param relativeAccuracy Relative accuracy.\n     * @param absoluteAccuracy Absolute accuracy.\n     * @param functionValueAccuracy Function value accuracy.\n     */\n    constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double,\n        functionValueAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n    }\n\n    /**\n     * {@inheritDoc}\n     */\n    override fun doSolve(): Double {\n        val min = min\n        val max = max\n        val initial = startValue\n        val functionValueAccuracy = functionValueAccuracy\n\n        verifySequence(min, initial, max)\n\n        // Return the initial guess if it is good enough.\n        val yInitial = computeObjectiveValue(initial)\n        if (abs(yInitial) <= functionValueAccuracy) {\n            return initial\n        }\n\n        // Return the first endpoint if it is good enough.\n        val yMin = computeObjectiveValue(min)\n        if (abs(yMin) <= functionValueAccuracy) {\n            return min\n        }\n\n        // Reduce interval if min and initial bracket the root.\n        if (yInitial * yMin < 0) {\n            return brent(min, initial, yMin, yInitial)\n        }\n\n        // Return the second endpoint if it is good enough.\n        val yMax = computeObjectiveValue(max)\n        if (abs(yMax) <= functionValueAccuracy) {\n            return max\n        }\n\n        // Reduce interval if initial and max bracket the root.\n        if (yInitial * yMax < 0) {\n            return brent(initial, max, yInitial, yMax)\n        }\n\n        error(\"NoBracketing - min: $min, max: $max, yMin: $yMin, yMax: $yMax\")\n    }\n\n    /**\n     * Search for a zero inside the provided interval.\n     * This implementation is based on the algorithm described at page 58 of\n     * the book\n     * <quote>\n     * **Algorithms for Minimization Without Derivatives**\n     * <it>Richard P. Brent</it>\n     * Dover 0-486-41998-3\n    </quote> *\n     *\n     * @param lo Lower bound of the search interval.\n     * @param hi Higher bound of the search interval.\n     * @param fLo Function value at the lower bound of the search interval.\n     * @param fHi Function value at the higher bound of the search interval.\n     * @return the value where the function is zero.\n     */\n    private fun brent(\n        lo: Double, hi: Double,\n        fLo: Double, fHi: Double\n    ): Double {\n        var a = lo\n        var fa = fLo\n        var b = hi\n        var fb = fHi\n        var c = a\n        var fc = fa\n        var d = b - a\n        var e = d\n\n        val t = absoluteAccuracy\n        val eps = relativeAccuracy\n\n        while (true) {\n            if (abs(fc) < abs(fb)) {\n                a = b\n                b = c\n                c = a\n                fa = fb\n                fb = fc\n                fc = fa\n            }\n\n            val tol = 2.0 * eps * abs(b) + t\n            val m = 0.5 * (c - b)\n\n            if (abs(m) <= tol || Precision.equals(fb, 0.0)) {\n                return b\n            }\n            if (abs(e) < tol || abs(fa) <= abs(fb)) {\n                // Force bisection.\n                d = m\n                e = d\n            } else {\n                var s = fb / fa\n                var p: Double\n                var q: Double\n                // The equality test (a == c) is intentional,\n                // it is part of the original Brent's method and\n                // it should NOT be replaced by proximity test.\n                if (a == c) {\n                    // Linear interpolation.\n                    p = 2.0 * m * s\n                    q = 1 - s\n                } else {\n                    // Inverse quadratic interpolation.\n                    q = fa / fc\n                    val r = fb / fc\n                    p = s * (2.0 * m * q * (q - r) - (b - a) * (r - 1))\n                    q = (q - 1) * (r - 1) * (s - 1)\n                }\n                if (p > 0) {\n                    q = -q\n                } else {\n                    p = -p\n                }\n                s = e\n                e = d\n                if (p >= 1.5 * m * q - abs(tol * q) || p >= abs(0.5 * s * q)) {\n                    // Inverse quadratic interpolation gives a value\n                    // in the wrong direction, or progress is slow.\n                    // Fall back to bisection.\n                    d = m\n                    e = d\n                } else {\n                    d = p / q\n                }\n            }\n            a = b\n            fa = fb\n\n            if (abs(d) > tol) {\n                b += d\n            } else if (m > 0) {\n                b += tol\n            } else {\n                b -= tol\n            }\n            fb = computeObjectiveValue(b)\n            if (fb > 0 && fc > 0 || fb <= 0 && fc <= 0) {\n                c = a\n                fc = fa\n                d = b - a\n                e = d\n            }\n        }\n    }\n\n    companion object {\n\n        /** Default absolute accuracy.  */\n        private val DEFAULT_ABSOLUTE_ACCURACY = 1e-6\n    }\n}\n/**\n * Construct a solver with default accuracy (1e-6).\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\nimport kotlin.math.max\n\n\n/**\n * Provides a generic means to evaluate continued fractions.  Subclasses simply\n * provided the a and b coefficients to evaluate the continued fraction.\n *\n *\n *\n * References:\n *\n *  * [\n * Continued Fraction](mathworld.wolfram.com/ContinuedFraction.html)\n *\n *\n *\n * @version $Id: ContinuedFraction.java 1244107 2012-02-14 16:17:55Z erans $\n */\nabstract class ContinuedFraction\n/**\n * Default constructor.\n */\nprotected constructor() {\n\n    /**\n     * Access the n-th a coefficient of the continued fraction.  Since a can be\n     * a function of the evaluation point, x, that is passed in as well.\n     * @param n the coefficient index to retrieve.\n     * @param x the evaluation point.\n     * @return the n-th a coefficient.\n     */\n    protected abstract fun getA(n: Int, x: Double): Double\n\n    /**\n     * Access the n-th b coefficient of the continued fraction.  Since b can be\n     * a function of the evaluation point, x, that is passed in as well.\n     * @param n the coefficient index to retrieve.\n     * @param x the evaluation point.\n     * @return the n-th b coefficient.\n     */\n    protected abstract fun getB(n: Int, x: Double): Double\n\n    /**\n     * Evaluates the continued fraction at the value x.\n     * @param x the evaluation point.\n     * @param maxIterations maximum number of convergents\n     * @return the value of the continued fraction evaluated at x.\n     * @throws ConvergenceException if the algorithm fails to converge.\n     */\n    fun evaluate(x: Double, maxIterations: Int): Double {\n        return evaluate(x,\n            DEFAULT_EPSILON, maxIterations)\n    }\n\n    /**\n     *\n     *\n     * Evaluates the continued fraction at the value x.\n     *\n     *\n     *\n     *\n     * The implementation of this method is based on equations 14-17 of:\n     *\n     *  *\n     * Eric W. Weisstein. \"Continued Fraction.\" From MathWorld--A Wolfram Web\n     * Resource. [\n * mathworld.wolfram.com/ContinuedFraction.html](mathworld.wolfram.com/ContinuedFraction.html)\n     *\n     *\n     * The recurrence relationship defined in those equations can result in\n     * very large intermediate results which can result in numerical overflow.\n     * As a means to combat these overflow conditions, the intermediate results\n     * are scaled whenever they threaten to become numerically unstable.\n     *\n     * @param x the evaluation point.\n     * @param epsilon maximum error allowed.\n     * @param maxIterations maximum number of convergents\n     * @return the value of the continued fraction evaluated at x.\n     * @throws ConvergenceException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun evaluate(x: Double, epsilon: Double = DEFAULT_EPSILON, maxIterations: Int = Int.MAX_VALUE): Double {\n        var p0 = 1.0\n        var p1 = getA(0, x)\n        var q0 = 0.0\n        var q1 = 1.0\n        var c = p1 / q1\n        var n = 0\n        var relativeError = Double.MAX_VALUE\n        while (n < maxIterations && relativeError > epsilon) {\n            ++n\n            val a = getA(n, x)\n            val b = getB(n, x)\n            var p2 = a * p1 + b * p0\n            var q2 = a * q1 + b * q0\n            var infinite = false\n            if (p2.isInfinite() || q2.isInfinite()) {\n                /*\n                 * Need to scale. Try successive powers of the larger of a or b\n                 * up to 5th power. Throw ConvergenceException if one or both\n                 * of p2, q2 still overflow.\n                 */\n                var scaleFactor = 1.0\n                @Suppress(\"VARIABLE_WITH_REDUNDANT_INITIALIZER\")\n                var lastScaleFactor = 1.0\n                val maxPower = 5\n                val scale = max(a, b)\n                if (scale <= 0) {  // Can't scale\n                    error(\"ConvergenceException\")\n                    //LocalizedFormats.CONTINUED_FRACTION_INFINITY_DIVERGENCE,\n                    //x\n                }\n                infinite = true\n                for (i in 0 until maxPower) {\n                    lastScaleFactor = scaleFactor\n                    scaleFactor *= scale\n                    if (a != 0.0 && a > b) {\n                        p2 = p1 / lastScaleFactor + b / scaleFactor * p0\n                        q2 = q1 / lastScaleFactor + b / scaleFactor * q0\n                    } else if (b != 0.0) {\n                        p2 = a / scaleFactor * p1 + p0 / lastScaleFactor\n                        q2 = a / scaleFactor * q1 + q0 / lastScaleFactor\n                    }\n                    infinite = p2.isInfinite() || q2.isInfinite()\n                    if (!infinite) {\n                        break\n                    }\n                }\n            }\n\n            if (infinite) {\n                // Scaling failed\n                error(\"ConvergenceException\")\n                //LocalizedFormats.CONTINUED_FRACTION_INFINITY_DIVERGENCE,\n                //x\n            }\n\n            val r = p2 / q2\n\n            if (r.isNaN()) {\n                error(\"ConvergenceException\")\n                //LocalizedFormats.CONTINUED_FRACTION_NAN_DIVERGENCE,\n                //x\n            }\n            relativeError = abs(r / c - 1.0)\n\n            // prepare for next iteration\n            c = p2 / q2\n            p0 = p1\n            p1 = p2\n            q0 = q1\n            q1 = q2\n        }\n\n        if (n >= maxIterations) {\n            error(\"MaxCountExceeded\")\n            //LocalizedFormats.NON_CONVERGENT_CONTINUED_FRACTION,\n            //maxIterations, x\n        }\n\n        return c\n    }\n\n    companion object {\n        /** Maximum allowed numerical error.  */\n        private val DEFAULT_EPSILON = 10e-9\n    }\n}\n/**\n * Evaluates the continued fraction at the value x.\n * @param x the evaluation point.\n * @return the value of the continued fraction evaluated at x.\n * @throws ConvergenceException if the algorithm fails to converge.\n */\n/**\n * Evaluates the continued fraction at the value x.\n * @param x the evaluation point.\n * @param epsilon maximum error allowed.\n * @return the value of the continued fraction evaluated at x.\n * @throws ConvergenceException if the algorithm fails to converge.\n */\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\n\nfun mean(xs: DoubleArray) = xs.average()\n\nfun correlationPearson(xs: DoubleArray, ys: DoubleArray): Double {\n    require(xs.size == ys.size) { \"Two series must have the same size.\" }\n    require(xs.isNotEmpty()) { \"Can't correlate empty sequences.\" }\n\n    val mx = mean(xs)\n    val my = mean(ys)\n\n    var cov = 0.0\n    var d2x = 0.0\n    var d2y = 0.0\n\n    for (i in xs.indices) {\n        val dx = xs[i] - mx\n        val dy = ys[i] - my\n\n        cov += dx * dy\n        d2x += dx.pow(2)\n        d2y += dy.pow(2)\n    }\n\n    require(d2x != 0.0 && d2y != 0.0) { \"Correlation is not defined for sequences with zero variation.\" }\n\n    return cov.div(sqrt(d2x * d2y))\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.pow\n\nclass ForsythePolynomialGenerator(private val knots: DoubleArray) {\n    private val ps: ArrayList<PolynomialFunction>\n\n    init {\n        require(knots.isNotEmpty()) { \"The knots list must not be empty\" }\n\n        ps = arrayListOf(\n            PolynomialFunction(doubleArrayOf(1.0)),\n            PolynomialFunction(doubleArrayOf(-knots.average(), 1.0))\n        )\n    }\n\n    private fun alphaBeta(i: Int): Pair<Double, Double> {\n        require(i == ps.size) { \"Alpha must be calculated sequentially.\" }\n\n        val p = ps.last()\n        val pp = ps[ps.size - 2]\n        var sxp = 0.0\n        var sp2 = 0.0\n        var spp2 = 0.0\n\n        for (x in knots) {\n            val pv2 = p.value(x).pow(2)\n            val ppv2 = pp.value(x).pow(2)\n            sxp += x * pv2\n            sp2 += pv2\n            spp2 += ppv2\n        }\n\n        return Pair(sxp / sp2, sp2 / spp2)\n    }\n\n    fun getPolynomial(n: Int): PolynomialFunction {\n\n        require(n >= 0) { \"Degree of Forsythe polynomial must not be negative\" }\n\n        require(n < knots.size) { \"Degree of Forsythe polynomial must not exceed knots.size - 1\" }\n\n        if (n >= ps.size) {\n            val sz = ps.size\n\n            for (k in sz..n + 1) {\n                val (a, b) = alphaBeta(k)\n                val pPrev = ps.last()\n                val pPrevPrev = ps[ps.size - 2]\n                val p = X * pPrev - a * pPrev - b * pPrevPrev\n                ps.add(p)\n            }\n        }\n\n        return ps[n]\n    }\n\n    companion object {\n        val X = PolynomialFunction(doubleArrayOf(0.0, 1.0))\n    }\n}\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.abs\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n/**\n * This is a utility class that provides computation methods related to the\n * Gamma family of functions.\n *\n * @version $Id: Gamma.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject Gamma {\n    /**\n     * [Euler-Mascheroni constant](https://en.wikipedia.org/wiki/Euler-Mascheroni_constant)\n     * @since 2.0\n     */\n    val GAMMA = 0.577215664901532860606512090082\n    /** Maximum allowed numerical error.  */\n    private val DEFAULT_EPSILON = 10e-15\n    /** Lanczos coefficients  */\n    private val LANCZOS = doubleArrayOf(\n        0.99999999999999709182,\n        57.156235665862923517,\n        -59.597960355475491248,\n        14.136097974741747174,\n        -0.49191381609762019978,\n        .33994649984811888699e-4,\n        .46523628927048575665e-4,\n        -.98374475304879564677e-4,\n        .15808870322491248884e-3,\n        -.21026444172410488319e-3,\n        .21743961811521264320e-3,\n        -.16431810653676389022e-3,\n        .84418223983852743293e-4,\n        -.26190838401581408670e-4,\n        .36899182659531622704e-5\n    )\n    /** Avoid repeated computation of log of 2 PI in logGamma  */\n    private val HALF_LOG_2_PI = 0.5 * ln(2.0 * PI)\n    // limits for switching algorithm in digamma\n    /** C limit.  */\n    private val C_LIMIT = 49.0\n    /** S limit.  */\n    private val S_LIMIT = 1e-5\n\n    /**\n     * Returns the natural logarithm of the gamma function &#915;(x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  * [\n * Gamma Function](mathworld.wolfram.com/GammaFunction.html), equation (28).\n     *  * [\n * Lanczos Approximation](mathworld.wolfram.com/LanczosApproximation.html), equations (1) through (5).\n     *  * [Paul Godfrey, A note on\n * the computation of the convergent Lanczos complex Gamma approximation\n](https://my.fit.edu/~gabdo/gamma.txt) *\n     *\n     *\n     * @param x Value.\n     * @return log(&#915;(x))\n     */\n    fun logGamma(x: Double): Double {\n        val ret: Double\n\n        if (x.isNaN() || x <= 0.0) {\n            ret = Double.NaN\n        } else {\n            val g = 607.0 / 128.0\n\n            var sum = 0.0\n            for (i in LANCZOS.size - 1 downTo 1) {\n                sum = sum + LANCZOS[i] / (x + i)\n            }\n            sum = sum + LANCZOS[0]\n\n            val tmp = x + g + .5\n            ret = (x + .5) * ln(tmp) - tmp +\n                    HALF_LOG_2_PI + ln(sum / x)\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the regularized gamma function P(a, x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Gamma Function](mathworld.wolfram.com/RegularizedGammaFunction.html), equation (1)\n     *\n     *  *\n     * [\n * Incomplete Gamma Function](mathworld.wolfram.com/IncompleteGammaFunction.html), equation (4).\n     *\n     *  *\n     * [\n * Confluent Hypergeometric Function of the First Kind](mathworld.wolfram.com/ConfluentHypergeometricFunctionoftheFirstKind.html), equation (1).\n     *\n     *\n     *\n     * @param a the a parameter.\n     * @param x the value.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized gamma function P(a, x)\n     * @throws MaxCountExceededException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedGammaP(\n        a: Double,\n        x: Double,\n        epsilon: Double = DEFAULT_EPSILON,\n        maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (a.isNaN() || x.isNaN() || a <= 0.0 || x < 0.0) {\n            ret = Double.NaN\n        } else if (x == 0.0) {\n            ret = 0.0\n        } else if (x >= a + 1) {\n            // use regularizedGammaQ because it should converge faster in this\n            // case.\n            ret = 1.0 - regularizedGammaQ(a, x, epsilon, maxIterations)\n        } else {\n            // calculate series\n            var n = 0.0 // current element index\n            var an = 1.0 / a // n-th element in the series\n            var sum = an // partial sum\n            while (abs(an / sum) > epsilon &&\n                n < maxIterations &&\n                sum < Double.POSITIVE_INFINITY\n            ) {\n                // compute next element in the series\n                n = n + 1.0\n                an = an * (x / (a + n))\n\n                // update partial sum\n                sum = sum + an\n            }\n            if (n >= maxIterations) {\n                error(\"MaxCountExceeded - maxIterations: $maxIterations\")\n            } else if (sum.isInfinite()) {\n                ret = 1.0\n            } else {\n                ret = exp(-x + a * ln(x) - logGamma(a)) * sum\n            }\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the regularized gamma function Q(a, x) = 1 - P(a, x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Gamma Function](mathworld.wolfram.com/RegularizedGammaFunction.html), equation (1).\n     *\n     *  *\n     * [\n * Regularized incomplete gamma function: Continued fraction representations\n * (formula 06.08.10.0003)](functions.wolfram.com/GammaBetaErf/GammaRegularized/10/0003/)\n     *\n     *\n     *\n     * @param a the a parameter.\n     * @param x the value.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized gamma function P(a, x)\n     * @throws MaxCountExceededException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedGammaQ(\n        a: Double,\n        x: Double,\n        epsilon: Double = DEFAULT_EPSILON,\n        maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        var ret: Double\n\n        if (a.isNaN() || x.isNaN() || a <= 0.0 || x < 0.0) {\n            ret = Double.NaN\n        } else if (x == 0.0) {\n            ret = 1.0\n        } else if (x < a + 1.0) {\n            // use regularizedGammaP because it should converge faster in this\n            // case.\n            ret = 1.0 - regularizedGammaP(a, x, epsilon, maxIterations)\n        } else {\n            // create continued fraction\n            val cf = object : ContinuedFraction() {\n\n                override fun getA(n: Int, x: Double): Double {\n                    return 2.0 * n + 1.0 - a + x\n                }\n\n                override fun getB(n: Int, x: Double): Double {\n                    return n * (a - n)\n                }\n            }\n\n            ret = 1.0 / cf.evaluate(x, epsilon, maxIterations)\n            ret = exp(-x + a * ln(x) - logGamma(a)) * ret\n        }\n\n        return ret\n    }\n\n\n    /**\n     *\n     * Computes the digamma function of x.\n     *\n     *\n     * This is an independently written implementation of the algorithm described in\n     * Jose Bernardo, Algorithm AS 103: Psi (Digamma) Function, Applied Statistics, 1976.\n     *\n     *\n     * Some of the constants have been changed to increase accuracy at the moderate expense\n     * of run-time.  The result should be accurate to within 10^-8 absolute tolerance for\n     * x >= 10^-5 and within 10^-8 relative tolerance for x > 0.\n     *\n     *\n     * Performance for large negative values of x will be quite expensive (proportional to\n     * |x|).  Accuracy for negative values of x should be about 10^-8 absolute for results\n     * less than 10^5 and 10^-8 relative for results larger than that.\n     *\n     * @param x Argument.\n     * @return digamma(x) to within 10-8 relative or absolute error whichever is smaller.\n     * @see [Digamma](https://en.wikipedia.org/wiki/Digamma_function)\n     *\n     * @see [Bernardo&apos;s original article ](https://www.uv.es/~bernardo/1976AppStatist.pdf)\n     *\n     * @since 2.0\n     */\n    fun digamma(x: Double): Double {\n        if (x > 0 && x <= S_LIMIT) {\n            // use method 5 from Bernardo AS103\n            // accurate to O(x)\n            return -GAMMA - 1 / x\n        }\n\n        if (x >= C_LIMIT) {\n            // use method 4 (accurate to O(1/x^8)\n            val inv = 1 / (x * x)\n            //            1       1        1         1\n            // log(x) -  --- - ------ + ------- - -------\n            //           2 x   12 x^2   120 x^4   252 x^6\n            return ln(x) - 0.5 / x - inv * (1.0 / 12 + inv * (1.0 / 120 - inv / 252))\n        }\n\n        return digamma(x + 1) - 1 / x\n    }\n\n    /**\n     * Computes the trigamma function of x.\n     * This function is derived by taking the derivative of the implementation\n     * of digamma.\n     *\n     * @param x Argument.\n     * @return trigamma(x) to within 10-8 relative or absolute error whichever is smaller\n     * @see [Trigamma](https://en.wikipedia.org/wiki/Trigamma_function)\n     *\n     * @see Gamma.digamma\n     * @since 2.0\n     */\n    fun trigamma(x: Double): Double {\n        if (x > 0 && x <= S_LIMIT) {\n            return 1 / (x * x)\n        }\n\n        if (x >= C_LIMIT) {\n            val inv = 1 / (x * x)\n            //  1    1      1       1       1\n            //  - + ---- + ---- - ----- + -----\n            //  x      2      3       5       7\n            //      2 x    6 x    30 x    42 x\n            return 1 / x + inv / 2 + inv / x * (1.0 / 6 - inv * (1.0 / 30 + inv / 42))\n        }\n\n        return trigamma(x + 1) + 1 / (x * x)\n    }\n}\n/**\n * Default constructor.  Prohibit instantiation.\n */\n/**\n * Returns the regularized gamma function P(a, x).\n *\n * @param a Parameter.\n * @param x Value.\n * @return the regularized gamma function P(a, x).\n * @throws MaxCountExceededException if the algorithm fails to converge.\n */\n/**\n * Returns the regularized gamma function Q(a, x) = 1 - P(a, x).\n *\n * @param a the a parameter.\n * @param x the value.\n * @return the regularized gamma function Q(a, x)\n * @throws MaxCountExceededException if the algorithm fails to converge.\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport jetbrains.datalore.plot.base.stat.math3.Incrementor.MaxCountExceededCallback\nimport kotlin.jvm.JvmOverloads\n\n\n/**\n * Utility that increments a counter until a maximum is reached, at\n * which point, the instance will by default throw a\n * [MaxCountExceededException].\n * However, the user is able to override this behaviour by defining a\n * custom [callback][MaxCountExceededCallback], in order to e.g.\n * select which exception must be thrown.\n *\n * @version $Id$\n * @since 3.0\n */\nclass Incrementor\n/**\n * Defines a maximal count and a callback method to be triggered at\n * counter exhaustion.\n *\n * @param max Maximal count.\n * @param cb Function to be called when the maximal count has been reached.\n */\n@JvmOverloads constructor(\n    /**\n     * Upper limit for the counter.\n     */\n    /**\n     * Gets the upper limit of the counter.\n     *\n     * @return the counter upper limit.\n     */\n    /**\n     * Sets the upper limit for the counter.\n     * This does not automatically reset the current count to zero (see\n     * [.resetCount]).\n     *\n     * @param max Upper limit of the counter.\n     */\n    var maximalCount: Int = 0,\n    /**\n     * Function called at counter exhaustion.\n     */\n    private val maxCountCallback: MaxCountExceededCallback = object : MaxCountExceededCallback {\n        /** {@inheritDoc}  */\n        override fun trigger(maximalCount: Int) {\n            error(\"MaxCountExceeded: $maximalCount\")\n        }\n    }\n) {\n    /**\n     * Current count.\n     */\n    /**\n     * Gets the current count.\n     *\n     * @return the current count.\n     */\n    var count = 0\n        private set\n\n    /**\n     * Checks whether a single increment is allowed.\n     *\n     * @return `false` if the next call to [ incrementCount][.incrementCount] will trigger a `MaxCountExceededException`,\n     * `true` otherwise.\n     */\n    fun canIncrement(): Boolean {\n        return count < maximalCount\n    }\n\n    /**\n     * Performs multiple increments.\n     * See the other [incrementCount][.incrementCount] method).\n     *\n     * @param value Number of increments.\n     * @throws MaxCountExceededException at counter exhaustion.\n     */\n    fun incrementCount(value: Int) {\n        for (i in 0 until value) {\n            incrementCount()\n        }\n    }\n\n    /**\n     * Adds one to the current iteration count.\n     * At counter exhaustion, this method will call the\n     * [trigger][MaxCountExceededCallback.trigger] method of the\n     * callback object passed to the\n     * [constructor][.Incrementor].\n     * If not explictly set, a default callback is used that will throw\n     * a `MaxCountExceededException`.\n     *\n     * @throws MaxCountExceededException at counter exhaustion, unless a\n     * custom [callback][MaxCountExceededCallback] has been set at\n     * construction.\n     */\n    fun incrementCount() {\n        if (++count > maximalCount) {\n            maxCountCallback.trigger(maximalCount)\n        }\n    }\n\n    /**\n     * Resets the counter to 0.\n     */\n    fun resetCount() {\n        count = 0\n    }\n\n    /**\n     * Defines a method to be called at counter exhaustion.\n     * The [trigger][.trigger] method should usually throw an exception.\n     */\n    interface MaxCountExceededCallback {\n        /**\n         * Function called when the maximal count has been reached.\n         *\n         * @param maximalCount Maximal count.\n         */\n        fun trigger(maximalCount: Int)\n    }\n}\n/**\n * Default constructor.\n * For the new instance to be useful, the maximal count must be set\n * by calling [setMaximalCount][.setMaximalCount].\n */\n/**\n * Defines a maximal count.\n *\n * @param max Maximal count.\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n *  Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.abs\nimport kotlin.math.sqrt\n\n/**\n * Implements the <a href=\"http://en.wikipedia.org/wiki/Local_regression\">\n * Local Regression Algorithm</a> (also Loess, Lowess) for interpolation of\n * real univariate functions.\n * <p/>\n * For reference, see\n * <a href=\"http://www.math.tau.ac.il/~yekutiel/MA seminar/Cleveland 1979.pdf\">\n * William S. Cleveland - Robust Locally Weighted Regression and Smoothing\n * Scatterplots</a>\n * <p/>\n * This class implements both the loess method and serves as an interpolation\n * adapter to it, allowing one to build a spline on the obtained loess fit.\n *\n * @version $Id: LoessInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 2.0\n */\n\n/**\n * Implements the <a href=\"http://en.wikipedia.org/wiki/Local_regression\">\n * Local Regression Algorithm</a> (also Loess, Lowess) for interpolation of\n * real univariate functions.\n * <p/>\n * For reference, see\n * <a href=\"http://www.math.tau.ac.il/~yekutiel/MA seminar/Cleveland 1979.pdf\">\n * William S. Cleveland - Robust Locally Weighted Regression and Smoothing\n * Scatterplots</a>\n * <p/>\n * This class implements both the loess method and serves as an interpolation\n * adapter to it, allowing one to build a spline on the obtained loess fit.\n *\n * @version $Id: LoessInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 2.0\n */\n\nclass LoessInterpolator(\n    private val bandwidth: Double = DEFAULT_BANDWIDTH,\n    private val robustnessIters: Int = DEFAULT_ROBUSTNESS_ITERS,\n    private val accuracy: Double = DEFAULT_ACCURACY\n) {\n\n    /**\n     * Construct a new {@link LoessInterpolator}\n     * with given bandwidth, number of robustness iterations and accuracy.\n     *\n     * @param bandwidth The bandwidth parameter: when computing the loess fit at\n     * a particular point, this fraction of source points closest\n     * to the current point is taken into account for computing\n     * a least-squares regression.\n     * A sensible value is usually 0.25 to 0.5.\n     * A sensible value is usually 0.25 to 0.5, the default value is\n     * {@link #DEFAULT_BANDWIDTH}.\n     * @param robustnessIters The number of robustness iterations parameter:\n     * this many robustness iterations are done.\n     * A sensible value is usually 0 (just the initial fit without any\n     * robustness iterations) to 4, the default value is\n     * {@link #DEFAULT_ROBUSTNESS_ITERS}.\n     * @param accuracy If the median residual at a certain robustness iteration\n     * is less than this amount, no more iterations are done.\n     *\n     * @throws OutOfRangeException if bandwidth does not lie in the interval [0,1].\n     * @throws NotPositiveException if {@code robustnessIters} is negative.\n     * @see #LoessInterpolator(double, int)\n     * @since 2.1\n     */\n\n    init {\n        if (bandwidth <= 0 || bandwidth > 1)\n            error(\"Out of range of bandwidth value: $bandwidth should be > 0 and <= 1\")\n\n        if (robustnessIters < 0)\n            error(\"Not positive Robutness iterationa: $robustnessIters\")\n    }\n\n    /**\n     * Compute an interpolating function by performing a loess fit\n     * on the data at the original abscissae and then building a cubic spline\n     * with a\n     * [org.apache.commons.math3.analysis.interpolation.SplineInterpolator]\n     * on the resulting fit.\n     *\n     * @param xval the arguments for the interpolation points\n     * @param yval the values for the interpolation points\n     * @return A cubic spline built upon a loess fit to the data at the original abscissae\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     */\n    fun interpolate(xval: DoubleArray, yval: DoubleArray): PolynomialSplineFunction {\n        return SplineInterpolator().interpolate(xval, smooth(xval, yval))\n    }\n\n    /**\n     * Compute a weighted loess fit on the data at the original abscissae.\n     *\n     * @param xval Arguments for the interpolation points.\n     * @param yval Values for the interpolation points.\n     * @param weights point weights: coefficients by which the robustness weight\n     * of a point is multiplied.\n     * @return the values of the loess fit at corresponding original abscissae.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     * @since 2.1\n     */\n    private fun smooth(xval: DoubleArray, yval: DoubleArray, weights: DoubleArray): DoubleArray {\n        if (xval.size != yval.size) {\n            error(\"Dimension mismatch of interpolation points: ${xval.size} != ${yval.size}\")\n        }\n        val n = xval.size\n        if (n == 0) {\n            error(\"No data to interpolate\")\n        }\n        checkAllFiniteReal(xval)\n        checkAllFiniteReal(yval)\n        checkAllFiniteReal(weights)\n        MathArrays.checkOrder(xval)\n        if (n == 1) {\n            return doubleArrayOf(yval[0])\n        }\n        if (n == 2) {\n            return doubleArrayOf(yval[0], yval[1])\n        }\n        val bandwidthInPoints = (bandwidth * n).toInt()\n        if (bandwidthInPoints < 2) {\n            error(\"LOESS 'bandwidthInPoints' is too small: $bandwidthInPoints < 2\")\n        }\n        val res = DoubleArray(n)\n        val residuals = DoubleArray(n)\n        val sortedResiduals = DoubleArray(n)\n        val robustnessWeights = DoubleArray(n)\n        // Do an initial fit and 'robustnessIters' robustness iterations.\n        // This is equivalent to doing 'robustnessIters+1' robustness iterations\n        // starting with all robustness weights set to 1.\n        robustnessWeights.fill(1.0)\n        for (iter in 0..robustnessIters) {\n            val bandwidthInterval = intArrayOf(0, bandwidthInPoints - 1)\n            // At each x, compute a local weighted linear regression\n            for (i in 0 until n) {\n                val x = xval[i]\n                // Find out the interval of source points on which\n                // a regression is to be made.\n                if (i > 0) {\n                    updateBandwidthInterval(\n                        xval,\n                        weights,\n                        i,\n                        bandwidthInterval\n                    )\n                }\n                val ileft = bandwidthInterval[0]\n                val iright = bandwidthInterval[1]\n                // Compute the point of the bandwidth interval that is\n                // farthest from x\n                val edge: Int\n                edge = if (xval[i] - xval[ileft] > xval[iright] - xval[i]) {\n                    ileft\n                } else {\n                    iright\n                }\n                // Compute a least-squares linear fit weighted by\n                // the product of robustness weights and the tricube\n                // weight function.\n                // See http://en.wikipedia.org/wiki/Linear_regression\n                // (section \"Univariate linear case\")\n                // and http://en.wikipedia.org/wiki/Weighted_least_squares\n                // (section \"Weighted least squares\")\n                var sumWeights = 0.0\n                var sumX = 0.0\n                var sumXSquared = 0.0\n                var sumY = 0.0\n                var sumXY = 0.0\n                val denom: Double = abs(1.0 / (xval[edge] - x))\n                for (k in ileft..iright) {\n                    val xk = xval[k]\n                    val yk = yval[k]\n                    val dist = if (k < i) x - xk else xk - x\n                    val w: Double = tricube(dist * denom) * robustnessWeights[k] * weights[k]\n                    val xkw = xk * w\n                    sumWeights += w\n                    sumX += xkw\n                    sumXSquared += xk * xkw\n                    sumY += yk * w\n                    sumXY += yk * xkw\n                }\n                val meanX = sumX / sumWeights\n                val meanY = sumY / sumWeights\n                val meanXY = sumXY / sumWeights\n                val meanXSquared = sumXSquared / sumWeights\n                val beta: Double\n                beta = if (sqrt(abs(meanXSquared - meanX * meanX)) < accuracy) {\n                    0.0\n                } else {\n                    (meanXY - meanX * meanY) / (meanXSquared - meanX * meanX)\n                }\n                val alpha = meanY - beta * meanX\n                res[i] = beta * x + alpha\n                residuals[i] = abs(yval[i] - res[i])\n            }\n            // No need to recompute the robustness weights at the last\n            // iteration, they won't be needed anymore\n            if (iter == robustnessIters) {\n                break\n            }\n            // Recompute the robustness weights.\n            // Find the median residual.\n            // An arraycopy and a sort are completely tractable here,\n            // because the preceding loop is a lot more expensive\n            residuals.copyInto(sortedResiduals, 0, 0, n)\n            sortedResiduals.sort()\n\n            val medianResidual = sortedResiduals[n / 2]\n            if (abs(medianResidual) < accuracy) {\n                break\n            }\n            for (i in 0 until n) {\n                val arg = residuals[i] / (6 * medianResidual)\n                if (arg >= 1) {\n                    robustnessWeights[i] = 0.0\n                } else {\n                    val w = 1 - arg * arg\n                    robustnessWeights[i] = w * w\n                }\n            }\n        }\n        return res\n    }\n\n\n    /**\n     * Given an index interval into xval that embraces a certain number of\n     * points closest to `xval[i-1]`, update the interval so that it\n     * embraces the same number of points closest to `xval[i]`,\n     * ignoring zero weights.\n     *\n     * @param xval Arguments array.\n     * @param weights Weights array.\n     * @param i Index around which the new interval should be computed.\n     * @param bandwidthInterval a two-element array {left, right} such that:\n     * `(left==0 or xval[i] - xval[left-1] > xval[right] - xval[i])`\n     * and\n     * `(right==xval.length-1 or xval[right+1] - xval[i] > xval[i] - xval[left])`.\n     * The array will be updated.\n     */\n    private fun updateBandwidthInterval(\n        xval: DoubleArray, weights: DoubleArray,\n        i: Int,\n        bandwidthInterval: IntArray\n    ) {\n        val left = bandwidthInterval[0]\n        val right = bandwidthInterval[1]\n        // The right edge should be adjusted if the next point to the right\n        // is closer to xval[i] than the leftmost point of the current interval\n        val nextRight: Int = nextNonzero(weights, right)\n        if (nextRight < xval.size && xval[nextRight] - xval[i] < xval[i] - xval[left]) {\n            val nextLeft: Int = nextNonzero(\n                weights, bandwidthInterval[0]\n            )\n            bandwidthInterval[0] = nextLeft\n            bandwidthInterval[1] = nextRight\n        }\n    }\n\n\n    /**\n     * Compute the\n     * [tricube](http://en.wikipedia.org/wiki/Local_regression#Weight_function)\n     * weight function\n     *\n     * @param x Argument.\n     * @return `(1 - |x|<sup>3</sup>)<sup>3</sup>` for |x| &lt; 1, 0 otherwise.\n     */\n    private fun tricube(x: Double): Double {\n        val absX: Double = abs(x)\n        if (absX >= 1.0) {\n            return 0.0\n        }\n        val tmp = 1 - absX * absX * absX\n        return tmp * tmp * tmp\n    }\n\n    /**\n     * Return the smallest index `j` such that\n     * `j > i && (j == weights.length || weights[j] != 0)`.\n     *\n     * @param weights Weights array.\n     * @param i Index from which to start search.\n     * @return the smallest compliant index.\n     */\n    private fun nextNonzero(weights: DoubleArray, i: Int): Int {\n        var j = i + 1\n        while (j < weights.size && weights[j] == 0.0) {\n            ++j\n        }\n        return j\n    }\n\n    /**\n     * Compute a loess fit on the data at the original abscissae.\n     *\n     * @param xval the arguments for the interpolation points\n     * @param yval the values for the interpolation points\n     * @return values of the loess fit at corresponding original abscissae\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     */\n    private fun smooth(xval: DoubleArray, yval: DoubleArray): DoubleArray {\n        if (xval.size != yval.size) {\n            error(\"Dimension mismatch: ${xval.size} != ${yval.size}\")\n        }\n        val unitWeights = DoubleArray(xval.size)\n        unitWeights.fill(1.0)\n        return smooth(xval, yval, unitWeights)\n    }\n\n    /**\n     * Check that the argument is a real number.\n     *\n     * @param x Argument.\n     * @throws NotFiniteNumberException if `x` is not a\n     * finite real number.\n     */\n    private fun checkFinite(x: Double) {\n        if (x.isInfinite() || x.isNaN()) {\n            error(\"Argument $x is not a finite number\")\n        }\n    }\n\n    /**\n     * Check that all elements of an array are finite real numbers.\n     *\n     * @param values Values array.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException\n     * if one of the values is not a finite real number.\n     */\n    private fun checkAllFiniteReal(values: DoubleArray) {\n        for (i in values.indices) {\n            checkFinite(values[i])\n        }\n    }\n\n    companion object {\n        /** Default value of the bandwidth parameter.  */\n        const val DEFAULT_BANDWIDTH = 0.3\n\n        /** Default value of the number of robustness iterations.  */\n        const val DEFAULT_ROBUSTNESS_ITERS = 2\n\n        /**\n         * Default value for accuracy.\n         * @since 2.1\n         */\n        const val DEFAULT_ACCURACY = 1e-12\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n/**\n * Arrays utilities.\n *\n * @since 3.0\n * @version $Id$\n */\n\nobject MathArrays {\n\n    /**\n     * Specification of ordering direction.\n     */\n    enum class OrderDirection {\n        /** Constant for increasing direction.  */\n        INCREASING,\n        /** Constant for decreasing direction.  */\n        DECREASING\n    }\n\n    /**\n     * Check that the given array is sorted.\n     *\n     * @param val Values.\n     * @param dir Ordering direction.\n     * @param strict Whether the order should be strict.\n     * @param abort Whether to throw an exception if the check fails.\n     * @return `true` if the array is sorted.\n     * @throws NonMonotonicSequenceException if the array is not sorted\n     * and `abort` is `true`.\n     */\n    fun checkOrder(\n        `val`: DoubleArray, dir: OrderDirection?,\n        strict: Boolean, abort: Boolean\n    ): Boolean {\n        var previous = `val`[0]\n        val max = `val`.size\n        var index: Int\n        index = 1\n        ITEM@ while (index < max) {\n            when (dir) {\n                OrderDirection.INCREASING -> if (strict) {\n                    if (`val`[index] <= previous) {\n                        break@ITEM\n                    }\n                } else {\n                    if (`val`[index] < previous) {\n                        break@ITEM\n                    }\n                }\n                OrderDirection.DECREASING -> if (strict) {\n                    if (`val`[index] >= previous) {\n                        break@ITEM\n                    }\n                } else {\n                    if (`val`[index] > previous) {\n                        break@ITEM\n                    }\n                }\n                else -> error(\"\")\n            }\n            previous = `val`[index]\n            index++\n        }\n        if (index == max) { // Loop completed.\n            return true\n        }\n        // Loop early exit means wrong ordering.\n        return if (abort) {\n            error(\"Non monotonic sequence\")\n        } else {\n            false\n        }\n    }\n\n    /**\n     * Check that the given array is sorted.\n     *\n     * @param val Values.\n     * @param dir Ordering direction.\n     * @param strict Whether the order should be strict.\n     * @throws NonMonotonicSequenceException if the array is not sorted.\n     * @since 2.2\n     */\n    fun checkOrder(\n        `val`: DoubleArray, dir: OrderDirection?,\n        strict: Boolean\n    ) {\n        checkOrder(`val`, dir, strict, true)\n    }\n\n    /**\n     * Check that the given array is sorted in strictly increasing order.\n     *\n     * @param val Values.\n     * @throws NonMonotonicSequenceException if the array is not sorted.\n     * @since 2.2\n     */\n    fun checkOrder(`val`: DoubleArray) {\n        checkOrder(`val`, OrderDirection.INCREASING, true)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.floor\nimport kotlin.math.min\n\n\n/**\n * Provides percentile computation.\n * <p>\n * There are several commonly used methods for estimating percentiles (a.k.a.\n * quantiles) based on sample data.  For large samples, the different methods\n * agree closely, but when sample sizes are small, different methods will give\n * significantly different results.  The algorithm implemented here works as follows:\n * <ol>\n * <li>Let <code>n</code> be the length of the (sorted) array and\n * <code>0 < p <= 100</code> be the desired percentile.</li>\n * <li>If <code> n = 1 </code> return the unique array element (regardless of\n * the value of <code>p</code>); otherwise </li>\n * <li>Compute the estimated percentile position\n * <code> pos = p * (n + 1) / 100</code> and the difference, <code>d</code>\n * between <code>pos</code> and <code>floor(pos)</code> (i.e. the fractional\n * part of <code>pos</code>).</li>\n * <li> If <code>pos < 1</code> return the smallest element in the array.</li>\n * <li> Else if <code>pos >= n</code> return the largest element in the array.</li>\n * <li> Else let <code>lower</code> be the element in position\n * <code>floor(pos)</code> in the array and let <code>upper</code> be the\n * next element in the array.  Return <code>lower + d * (upper - lower)</code>\n * </li>\n * </ol></p>\n * <p>\n * To compute percentiles, the data must be at least partially ordered.  Input\n * arrays are copied and recursively partitioned using an ordering definition.\n * The ordering used by <code>Arrays.sort(double[])</code> is the one determined\n * by {@link java.lang.Double#compareTo(Double)}.  This ordering makes\n * <code>Double.NaN</code> larger than any other value (including\n * <code>Double.POSITIVE_INFINITY</code>).  Therefore, for example, the median\n * (50th percentile) of\n * <code>{0, 1, 2, 3, 4, Double.NaN}</code> evaluates to <code>2.5.</code></p>\n * <p>\n * Since percentile estimation usually involves interpolation between array\n * elements, arrays containing  <code>NaN</code> or infinite values will often\n * result in <code>NaN</code> or infinite values returned.</p>\n * <p>\n * Since 2.2, Percentile uses only selection instead of complete sorting\n * and caches selection algorithm state between calls to the various\n * {@code evaluate} methods. This greatly improves efficiency, both for a single\n * percentile and multiple percentile computations. To maximize performance when\n * multiple percentiles are computed based on the same data, users should set the\n * data array once using either one of the {@link #evaluate(double[], double)} or\n * {@link #setData(double[])} methods and thereafter {@link #evaluate(double)}\n * with just the percentile provided.\n * </p>\n * <p>\n * <strong>Note that this implementation is not synchronized.</strong> If\n * multiple threads access an instance of this class concurrently, and at least\n * one of the threads invokes the <code>increment()</code> or\n * <code>clear()</code> method, it must be synchronized externally.</p>\n *\n * @version $Id: Percentile.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nobject Percentile {\n\n    /** Minimum size under which we use a simple insertion sort rather than Hoare's select.  */\n    private const val MIN_SELECT_SIZE = 15\n\n    /** Maximum number of partitioning pivots cached (each level double the number of pivots).  */\n    private const val MAX_CACHED_LEVELS = 10\n\n    /**\n     * Returns an estimate of the `p`th percentile of the values\n     * in the `values` array.\n     *\n     * Calls to this method do not modify the internal `quantile`\n     * state of this statistic.\n     *\n     *  * Returns `Double.NaN` if `values` has length `0`\n     *  * Returns (for any value of `p`) `values[0]`\n     * if `values` has length `1`\n     *  * Throws `IllegalArgumentException` if `values`\n     * is null or p is not a valid quantile value (p must be greater than 0\n     * and less than or equal to 100)\n     *\n     * See [Percentile] for a description of the percentile estimation\n     * algorithm used.\n     *\n     * @param values input array of values\n     * @param p the percentile value to compute\n     * @return the percentile value or Double.NaN if the array is empty\n     * @throws IllegalArgumentException if `values` is null\n     * or p is invalid\n     */\n    fun evaluate(values: DoubleArray, p: Double): Double {\n        test(values, 0, 0, false)\n        return evaluate(values, 0, values.size, p)\n    }\n\n    /**\n     * This method is used by `evaluate(double[], int, int)` methods\n     * to verify that the input parameters designate a subarray of positive length.\n     *\n     * returns `true` iff the parameters designate a subarray of\n     * non-negative length\n     *  * throws `IllegalArgumentException` if the array is null or\n     * or the indices are invalid\n     *  * returns `false` if the array is non-null, but\n     * `length` is 0 unless `allowEmpty` is `true`\n     *\n     * @param values the input array\n     * @param begin index of the first array element to include\n     * @param length the number of elements to include\n     * @param allowEmpty if `true` then zero length arrays are allowed\n     * @return true if the parameters are valid\n     * @throws IllegalArgumentException if the indices are invalid or the array is null\n     * @since 3.0\n     */\n     private fun test(values: DoubleArray?, begin: Int, length: Int, allowEmpty: Boolean): Boolean {\n        if (values == null) {\n            error(\"Input array\")\n        }\n        if (begin < 0) {\n            error(\"start postion < 0\")\n        }\n        if (length < 0) {\n            error(\"length < 0\")\n        }\n        if (begin + length > values.size) {\n            error(\"subarray ends after array end\")\n        }\n        return if (length == 0 && !allowEmpty) {\n            false\n        } else true\n    }\n\n    /**\n     * Returns an estimate of the `p`th percentile of the values\n     * in the `values` array, starting with the element in (0-based)\n     * position `begin` in the array and including `length`\n     * values.\n     *\n     * Calls to this method do not modify the internal `quantile`\n     * state of this statistic.\n     *\n     *  * Returns `Double.NaN` if `length = 0`\n     *  * Returns (for any value of `p`) `values[begin]`\n     * if `length = 1 `\n     *  * Throws `IllegalArgumentException` if `values`\n     * is null , `begin` or `length` is invalid, or\n     * `p` is not a valid quantile value (p must be greater than 0\n     * and less than or equal to 100)\n     *\n     * See [Percentile] for a description of the percentile estimation\n     * algorithm used.\n     *\n     * @param values array of input values\n     * @param p  the percentile to compute\n     * @param begin  the first (0-based) element to include in the computation\n     * @param length  the number of array elements to include\n     * @return  the percentile value\n     * @throws IllegalArgumentException if the parameters are not valid or the\n     * input array is null\n     */\n    private fun evaluate(values: DoubleArray, begin: Int, length: Int, p: Double): Double {\n\n        test(values, begin, length, false)\n\n        if (p > 100 || p <= 0) {\n            error(\"out of bounds quantile value: $p, must be in (0, 100]\")\n        }\n        if (length == 0) {\n            return Double.NaN\n        }\n        if (length == 1) {\n            return values[begin] // always return single value for n = 1\n        }\n        val n = length.toDouble()\n        val pos = p * (n + 1) / 100\n        val fpos: Double = floor(pos)\n        val intPos = fpos.toInt()\n        val dif = pos - fpos\n\n        val work = DoubleArray(length)\n        values.copyInto(work, 0, begin, length)\n\n        val pivotsHeap = IntArray((0x1 shl MAX_CACHED_LEVELS) - 1)\n        pivotsHeap.fill(-1)\n\n        if (pos < 1) {\n            return select(work, pivotsHeap, 0)\n        }\n        if (pos >= n) {\n            return select(work, pivotsHeap, length - 1)\n        }\n        val lower: Double = select(work, pivotsHeap, intPos - 1)\n        val upper: Double = select(work, pivotsHeap, intPos)\n        return lower + dif * (upper - lower)\n    }\n\n    /**\n     * Select the k<sup>th</sup> smallest element from work array\n     * @param work work array (will be reorganized during the call)\n     * @param pivotsHeap set of pivot index corresponding to elements that\n     * are already at their sorted location, stored as an implicit heap\n     * (i.e. a sorted binary tree stored in a flat array, where the\n     * children of a node at index n are at indices 2n+1 for the left\n     * child and 2n+2 for the right child, with 0-based indices)\n     * @param k index of the desired element\n     * @return k<sup>th</sup> smallest element\n     */\n    private fun select(work: DoubleArray, pivotsHeap: IntArray, k: Int): Double {\n        var begin = 0\n        var end = work.size\n        var node = 0\n        while (end - begin > MIN_SELECT_SIZE) {\n            val pivot: Int\n            if (node < pivotsHeap.size && pivotsHeap[node] >= 0) { // the pivot has already been found in a previous call\n                                                                   // and the array has already been partitioned around it\n                pivot = pivotsHeap[node]\n            } else { // select a pivot and partition work array around it\n                pivot = partition(work, begin, end, medianOf3(work, begin, end))\n                if (node < pivotsHeap.size) {\n                    pivotsHeap[node] = pivot\n                }\n            }\n            if (k == pivot) { // the pivot was exactly the element we wanted\n                return work[k]\n            } else if (k < pivot) { // the element is in the left partition\n                end = pivot\n                node = min(2 * node + 1, pivotsHeap.size) // the min is here to avoid integer overflow\n            } else { // the element is in the right partition\n                begin = pivot + 1\n                node = min(2 * node + 2, pivotsHeap.size) // the min is here to avoid integer overflow\n            }\n        }\n        // the element is somewhere in the small sub-array\n        // sort the sub-array using insertion sort\n        insertionSort(work, begin, end)\n        return work[k]\n    }\n\n\n    /**\n     * Partition an array slice around a pivot\n     *\n     * Partitioning exchanges array elements such that all elements\n     * smaller than pivot are before it and all elements larger than\n     * pivot are after it\n     *\n     * @param work data array\n     * @param begin index of the first element of the slice\n     * @param end index after the last element of the slice\n     * @param pivot initial index of the pivot\n     * @return index of the pivot after partition\n     */\n    private fun partition(work: DoubleArray, begin: Int, end: Int, pivot: Int): Int {\n        val value = work[pivot]\n        work[pivot] = work[begin]\n        var i = begin + 1\n        var j = end - 1\n        while (i < j) {\n            while (i < j && work[j] >= value) {\n                --j\n            }\n            while (i < j && work[i] <= value) {\n                ++i\n            }\n            if (i < j) {\n                val tmp = work[i]\n                work[i++] = work[j]\n                work[j--] = tmp\n            }\n        }\n        if (i >= end || work[i] > value) {\n            --i\n        }\n        work[begin] = work[i]\n        work[i] = value\n        return i\n    }\n\n    /** Select a pivot index as the median of three\n     * @param work data array\n     * @param begin index of the first element of the slice\n     * @param end index after the last element of the slice\n     * @return the index of the median element chosen between the\n     * first, the middle and the last element of the array slice\n     */\n    private fun medianOf3(work: DoubleArray, begin: Int, end: Int): Int {\n        val inclusiveEnd = end - 1\n        val middle = begin + (inclusiveEnd - begin) / 2\n        val wBegin = work[begin]\n        val wMiddle = work[middle]\n        val wEnd = work[inclusiveEnd]\n        return if (wBegin < wMiddle) {\n            if (wMiddle < wEnd) {\n                middle\n            } else {\n                if (wBegin < wEnd) inclusiveEnd else begin\n            }\n        } else {\n            if (wBegin < wEnd) {\n                begin\n            } else {\n                if (wMiddle < wEnd) inclusiveEnd else middle\n            }\n        }\n    }\n\n    /**\n     * Sort in place a (small) array slice using insertion sort\n     * @param work array to sort\n     * @param begin index of the first element of the slice to sort\n     * @param end index after the last element of the slice to sort\n     */\n    private fun insertionSort(work: DoubleArray, begin: Int, end: Int) {\n        for (j in begin + 1 until end) {\n            val saved = work[j]\n            var i = j - 1\n            while (i >= begin && saved < work[i]) {\n                work[i + 1] = work[i]\n                i--\n            }\n            work[i + 1] = saved\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport kotlin.math.abs\n\n/**\n * Immutable representation of a real polynomial function with real coefficients.\n * <p>\n * <a href=\"http://mathworld.wolfram.com/HornersMethod.html\">Horner's Method</a>\n * is used to evaluate the function.</p>\n *\n * @version $Id: PolynomialFunction.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass PolynomialFunction(c: DoubleArray?) {\n\n    /**\n     * The coefficients of the polynomial, ordered by degree -- i.e.,\n     * coefficients[0] is the constant term and coefficients[n] is the\n     * coefficient of x^n where n is the degree of the polynomial.\n     */\n    private var coefficients: DoubleArray\n\n    /**\n     * Construct a polynomial with the given coefficients.  The first element\n     * of the coefficients array is the constant term.  Higher degree\n     * coefficients follow in sequence.  The degree of the resulting polynomial\n     * is the index of the last non-null element of the array, or 0 if all elements\n     * are null.\n     *\n     * The constructor makes a copy of the input array and assigns the copy to\n     * the coefficients property.\n     *\n     * @param c Polynomial coefficients.\n     * @throws NullArgumentException if `c` is `null`.\n     * @throws NoDataException if `c` is empty.\n     */\n    init {\n        if (c == null || c.isEmpty()) {\n            error(\"Empty polynomials coefficients array\")\n        }\n\n        var n = c.size\n        while (n > 1 && c[n - 1] == 0.0) {\n            --n\n        }\n        coefficients = DoubleArray(n)\n        c.copyInto(coefficients, 0, 0, n)\n    }\n\n    /**\n     * Compute the value of the function for the given argument.\n     *\n     * The value returned is <br></br>\n     * `coefficients[n] * x^n + ... + coefficients[1] * x  + coefficients[0]`\n     *\n     * @param x Argument for which the function value should be computed.\n     * @return the value of the polynomial at the given point.\n     * @see UnivariateFunction.value\n     */\n    fun value(x: Double): Double {\n        return evaluate(coefficients, x)\n    }\n\n    /**\n     * Uses Horner's Method to evaluate the polynomial with the given coefficients at\n     * the argument.\n     *\n     * @param coefficients Coefficients of the polynomial to evaluate.\n     * @param argument Input value.\n     * @return the value of the polynomial.\n     * @throws NoDataException if `coefficients` is empty.\n     * @throws NullArgumentException if `coefficients` is `null`.\n     */\n    private fun evaluate(coefficients: DoubleArray?, argument: Double): Double {\n\n        if (coefficients == null)\n            error(\"Null argument: coefficients of the polynomial to evaluate\")\n\n        val n = coefficients.size\n        if (n == 0) {\n            error(\"Empty polynomials coefficients array\")\n        }\n        var result = coefficients[n - 1]\n        for (j in n - 2 downTo 0) {\n            result = argument * result + coefficients[j]\n        }\n        return result\n    }\n\n    operator fun unaryPlus() = PolynomialFunction(coefficients)\n\n    operator fun unaryMinus(): PolynomialFunction {\n        val dd = DoubleArray(coefficients.size)\n\n        for ((i, c) in coefficients.withIndex()) {\n            dd[i] = -c\n        }\n\n        return PolynomialFunction(dd)\n    }\n\n    private fun apply_op(other: PolynomialFunction, op: (Double, Double) -> Double): PolynomialFunction {\n        val sz = max(coefficients.size, other.coefficients.size)\n        val nc = DoubleArray(sz)\n\n        for (i in (0 until sz)) {\n            val a = if (i < coefficients.size) coefficients[i] else 0.0\n            val b = if (i < other.coefficients.size) other.coefficients[i] else 0.0\n            nc[i] = op(a, b)\n        }\n\n        return PolynomialFunction(nc)\n    }\n\n    operator fun plus(other: PolynomialFunction): PolynomialFunction {\n        return apply_op(other) { x, y -> x + y }\n    }\n\n    operator fun minus(other: PolynomialFunction): PolynomialFunction {\n        return apply_op(other) { x, y -> x - y }\n    }\n\n    fun multiply(a: Double): PolynomialFunction {\n        val dd = DoubleArray(coefficients.size)\n\n        for ((i, c) in coefficients.withIndex()) {\n            dd[i] = a * c\n        }\n\n        return PolynomialFunction(dd)\n    }\n\n    operator fun times(other: PolynomialFunction): PolynomialFunction {\n        val nd = coefficients.size + other.coefficients.size - 1\n        val nc = DoubleArray(nd)\n\n        for (i in (0 until nd)) {\n            for (j in (0..i)) {\n                val a = if (j < coefficients.size) coefficients[j] else 0.0\n                val k = i - j\n                val b = if (k < other.coefficients.size) other.coefficients[k] else 0.0\n                nc[i] += a * b\n            }\n        }\n\n        return PolynomialFunction(nc)\n    }\n\n    fun degree(): Int = max(0, coefficients.indexOfLast { it != 0.0 })\n\n    operator fun compareTo(other: PolynomialFunction): Int {\n        val d1 = degree()\n        val d2 = other.degree()\n        val n = min(d1, d2) + 1\n\n        for (i in 0 until n) {\n            val a = coefficients[i]\n            val b = other.coefficients[i]\n\n            val res = a.compareTo(b)\n\n            if (res != 0)\n                return res\n        }\n\n        return d1.compareTo(d2)\n    }\n\n    override operator fun equals(other: Any?): Boolean {\n        if (other == null || other !is PolynomialFunction)\n            return false\n\n        return compareTo(other) == 0\n    }\n\n    override fun hashCode(): Int {\n        return coefficients.hashCode()\n    }\n\n    override fun toString(): String {\n        val sb = StringBuilder()\n\n        for (i in coefficients.lastIndex downTo 0) {\n\n            if (coefficients[i] != 0.0) {\n\n                if (!sb.isEmpty())\n                    sb.append(\" + \")\n\n                sb.append(coefficients[i].toString())\n\n                if (i > 0)\n                    sb.append(\"x\")\n\n                if (i > 1)\n                    sb.append(\"^\").append(i)\n            }\n        }\n\n        return sb.toString()\n    }\n}\n\noperator fun Double.times(p: PolynomialFunction): PolynomialFunction {\n    return p.multiply(this)\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Represents a polynomial spline function.\n * <p>\n * A <strong>polynomial spline function</strong> consists of a set of\n * <i>interpolating polynomials</i> and an ascending array of domain\n * <i>knot points</i>, determining the intervals over which the spline function\n * is defined by the constituent polynomials.  The polynomials are assumed to\n * have been computed to match the values of another function at the knot\n * points.  The value consistency constraints are not currently enforced by\n * <code>PolynomialSplineFunction</code> itself, but are assumed to hold among\n * the polynomials and knot points passed to the constructor.</p>\n * <p>\n * N.B.:  The polynomials in the <code>polynomials</code> property must be\n * centered on the knot points to compute the spline function values.\n * See below.</p>\n * <p>\n * The domain of the polynomial spline function is\n * <code>[smallest knot, largest knot]</code>.  Attempts to evaluate the\n * function at values outside of this range generate IllegalArgumentExceptions.\n * </p>\n * <p>\n * The value of the polynomial spline function for an argument <code>x</code>\n * is computed as follows:\n * <ol>\n * <li>The knot array is searched to find the segment to which <code>x</code>\n * belongs.  If <code>x</code> is less than the smallest knot point or greater\n * than the largest one, an <code>IllegalArgumentException</code>\n * is thrown.</li>\n * <li> Let <code>j</code> be the index of the largest knot point that is less\n * than or equal to <code>x</code>.  The value returned is <br>\n * <code>polynomials[j](x - knot[j])</code></li></ol></p>\n *\n * @version $Id: PolynomialSplineFunction.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass PolynomialSplineFunction(_knots: DoubleArray?, _polynomials: Array<PolynomialFunction?>)\n{\n    /**\n     * Spline segment interval delimiters (knots).\n     * Size is n + 1 for n segments.\n     */\n    val knots: DoubleArray\n\n    /**\n     * The polynomial functions that make up the spline.  The first element\n     * determines the value of the spline over the first subinterval, the\n     * second over the second, etc.   Spline function values are determined by\n     * evaluating these functions at `(x - knot[i])` where i is the\n     * knot segment to which x belongs.\n     */\n    val polynomials: Array<PolynomialFunction?>\n\n    /**\n     * Number of spline segments. It is equal to the number of polynomials and\n     * to the number of partition points - 1.\n     */\n    private val n : Int\n\n    /**\n     * Construct a polynomial spline function with the given segment delimiters\n     * and interpolating polynomials.\n     * The constructor copies both arrays and assigns the copies to the knots\n     * and polynomials properties, respectively.\n     *\n     * @param _knots Spline segment interval delimiters.\n     * @param _polynomials Polynomial functions that make up the spline.\n     * @throws NullArgumentException if either of the input arrays is {@code null}.\n     * @throws NumberIsTooSmallException if knots has length less than 2.\n     * @throws DimensionMismatchException if {@code polynomials.length != knots.length - 1}.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException if\n     * the {@code knots} array is not strictly increasing.\n     *\n     */\n    init {\n\n        if (_knots == null) {\n            error(\"Null argument \")\n        }\n        if (_knots.size < 2) {\n            error(\"Spline partition must have at least 2 points, got ${_knots.size}\")\n        }\n        if (_knots.size - 1 != _polynomials.size) {\n            error(\"Dimensions mismatch: ${_polynomials.size} polynomial functions !=  ${_knots.size} segment delimiters\")\n        }\n\n        MathArrays.checkOrder(_knots)\n\n        this.n = _knots.size - 1\n        this.knots = _knots\n\n        this.polynomials = arrayOfNulls<PolynomialFunction?>(n)\n        _polynomials.copyInto (this.polynomials, 0, 0, n)\n\n    }\n\n    /**\n     * Compute the value for the function.\n     * See [PolynomialSplineFunction] for details on the algorithm for\n     * computing the value of the function.\n     *\n     * @param v Point for which the function value should be computed.\n     * @return the value.\n     * @throws OutOfRangeException if `v` is outside of the domain of the\n     * spline function (smaller than the smallest knot point or larger than the\n     * largest knot point).\n     */\n    fun value(v: Double): Double? {\n        if (v < knots[0] || v > knots[n]) {\n            error(\"$v out of [${knots[0]}, ${knots[n]}] range\")\n        }\n\n        var i: Int =  knots.toMutableList().binarySearch(v)\n        if (i < 0) {\n            i = -i - 2\n        }\n        // This will handle the case where v is the last knot value\n        // There are only n-1 polynomials, so if v is the last knot\n        // then we will use the last polynomial to calculate the value.\n        if (i >= polynomials.size) {\n            i--\n        }\n        return polynomials[i]?.value(v - knots[i])\n    }\n\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Computes a natural (also known as \"free\", \"unclamped\") cubic spline interpolation for the data set.\n *\n * The [.interpolate] method returns a [PolynomialSplineFunction]\n * consisting of n cubic polynomials, defined over the subintervals determined by the x values,\n * x[0] < x[i] ... < x[n].  The x values are referred to as \"knot points.\"\n *\n * The value of the PolynomialSplineFunction at a point x that is greater than or equal to the smallest\n * knot point and strictly less than the largest knot point is computed by finding the subinterval to which\n * x belongs and computing the value of the corresponding polynomial at `x - x[i] ` where\n * `i` is the index of the subinterval.  See [PolynomialSplineFunction] for more details.\n *\n * The interpolating polynomials satisfy:\n *  1. The value of the PolynomialSplineFunction at each of the input x values equals the\n * corresponding y value.\n *  1. Adjacent polynomials are equal through two derivatives at the knot points (i.e., adjacent polynomials\n * \"match up\" at the knot points, as do their first and second derivatives).\n *\n * The cubic spline interpolation algorithm implemented is as described in R.L. Burden, J.D. Faires,\n * <u>Numerical Analysis</u>, 4th Ed., 1989, PWS-Kent, ISBN 0-53491-585-X, pp 126-131.\n *\n *\n * @version $Id: SplineInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass SplineInterpolator {\n    /**\n     * Computes an interpolating function for the data set.\n     * @param x the arguments for the interpolation points\n     * @param y the values for the interpolation points\n     * @return a function which interpolates the data set\n     * @throws DimensionMismatchException if `x` and `y`\n     * @throws DimensionMismatchException if `x` and `y`\n     * have different sizes.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `x` is not sorted in strict increasing order.\n     * @throws NumberIsTooSmallException if the size of `x` is smaller\n     * than 3.\n     */\n    fun interpolate(x: DoubleArray, y: DoubleArray): PolynomialSplineFunction {\n        if (x.size != y.size) {\n            error(\"Dimension mismatch ${x.size} != ${y.size}\")\n        }\n        if (x.size < 3) {\n            error(\"Too small value of points number: ${x.size} < 3\")\n        }\n        // Number of intervals.  The number of data points is n + 1.\n        val n = x.size - 1\n        MathArrays.checkOrder(x)\n        // Differences between knot points\n        val h = DoubleArray(n)\n        for (i in 0 until n) {\n            h[i] = x[i + 1] - x[i]\n        }\n        val mu = DoubleArray(n)\n        val z = DoubleArray(n + 1)\n        mu[0] = 0.0\n        z[0] = 0.0\n\n        for (i in 1 until n) {\n            var g = 2.0 * (x[i + 1] - x[i - 1]) - h[i - 1] * mu[i - 1]\n            mu[i] = h[i] / g\n            z[i] =\n                (3.0 * (y[i + 1] * h[i - 1] - y[i] * (x[i + 1] - x[i - 1]) + y[i - 1] * h[i]) /\n                        (h[i - 1] * h[i]) - h[i - 1] * z[i - 1]) / g\n        }\n        // cubic spline coefficients --  b is linear, c quadratic, d is cubic (original y's are constants)\n        val b = DoubleArray(n)\n        val c = DoubleArray(n + 1)\n        val d = DoubleArray(n)\n        z[n] = 0.0\n        c[n] = 0.0\n        for (j in n - 1 downTo 0) {\n            c[j] = z[j] - mu[j] * c[j + 1]\n            b[j] = (y[j + 1] - y[j]) / h[j] - h[j] * (c[j + 1] + 2.0 * c[j]) / 3.0\n            d[j] = (c[j + 1] - c[j]) / (3.0 * h[j])\n        }\n        val polynomials: Array<PolynomialFunction?> = arrayOfNulls<PolynomialFunction>(n)\n        val coefficients = DoubleArray(4)\n        for (i in 0 until n) {\n            coefficients[0] = y[i]\n            coefficients[1] = b[i]\n            coefficients[2] = c[i]\n            coefficients[3] = d[i]\n            polynomials[i] = PolynomialFunction(coefficients)\n        }\n        return PolynomialSplineFunction(x, polynomials)\n    }\n}\n\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\n\n/**\n * Utility routines for [UnivariateSolver] objects.\n *\n * @version $Id: UnivariateSolverUtils.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject UnivariateSolverUtils {\n\n    /**\n     * Convenience method to find a zero of a univariate real function.  A default\n     * solver is used.\n     *\n     * @param function Function.\n     * @param x0 Lower bound for the interval.\n     * @param x1 Upper bound for the interval.\n     * @return a value where the function is zero.\n     * @throws IllegalArgumentException if f is null or the endpoints do not\n     * specify a valid interval.\n     */\n    fun solve(function: UnivariateFunction, x0: Double, x1: Double): Double {\n        val solver = BrentSolver()\n        return solver.solve(Int.MAX_VALUE, function, x0, x1)\n    }\n\n    /**\n     * Convenience method to find a zero of a univariate real function.  A default\n     * solver is used.\n     *\n     * @param function Function.\n     * @param x0 Lower bound for the interval.\n     * @param x1 Upper bound for the interval.\n     * @param absoluteAccuracy Accuracy to be used by the solver.\n     * @return a value where the function is zero.\n     * @throws IllegalArgumentException if `function` is `null`,\n     * the endpoints do not specify a valid interval, or the absolute accuracy\n     * is not valid for the default solver.\n     */\n    fun solve(\n        function: UnivariateFunction,\n        x0: Double, x1: Double,\n        absoluteAccuracy: Double\n    ): Double {\n        val solver = BrentSolver(absoluteAccuracy)\n        return solver.solve(Int.MAX_VALUE, function, x0, x1)\n    }\n\n    /** Force a root found by a non-bracketing solver to lie on a specified side,\n     * as if the solver was a bracketing one.\n     * @param maxEval maximal number of new evaluations of the function\n     * (evaluations already done for finding the root should have already been subtracted\n     * from this number)\n     * @param f function to solve\n     * @param bracketing bracketing solver to use for shifting the root\n     * @param baseRoot original root found by a previous non-bracketing solver\n     * @param min minimal bound of the search interval\n     * @param max maximal bound of the search interval\n     * @param allowedSolution the kind of solutions that the root-finding algorithm may\n     * accept as solutions.\n     * @return a root approximation, on the specified side of the exact root\n     */\n    fun forceSide(\n        maxEval: Int, f: UnivariateFunction,\n        bracketing: BracketedUnivariateSolver<UnivariateFunction>,\n        baseRoot: Double, min: Double, max: Double,\n        allowedSolution: AllowedSolution\n    ): Double {\n\n        if (allowedSolution == AllowedSolution.ANY_SIDE) {\n            // no further bracketing required\n            return baseRoot\n        }\n\n        // find a very small interval bracketing the root\n        val step = max(\n            bracketing.absoluteAccuracy,\n            abs(baseRoot * bracketing.relativeAccuracy)\n        )\n        var xLo = max(min, baseRoot - step)\n        var fLo = f.value(xLo)\n        var xHi = min(max, baseRoot + step)\n        var fHi = f.value(xHi)\n        var remainingEval = maxEval - 2\n        while (remainingEval > 0) {\n\n            if (fLo >= 0 && fHi <= 0 || fLo <= 0 && fHi >= 0) {\n                // compute the root on the selected side\n                return bracketing.solve(remainingEval, f, xLo, xHi, baseRoot, allowedSolution)\n            }\n\n            // try increasing the interval\n            var changeLo = false\n            var changeHi = false\n            if (fLo < fHi) {\n                // increasing function\n                if (fLo >= 0) {\n                    changeLo = true\n                } else {\n                    changeHi = true\n                }\n            } else if (fLo > fHi) {\n                // decreasing function\n                if (fLo <= 0) {\n                    changeLo = true\n                } else {\n                    changeHi = true\n                }\n            } else {\n                // unknown variation\n                changeLo = true\n                changeHi = true\n            }\n\n            // update the lower bound\n            if (changeLo) {\n                xLo = max(min, xLo - step)\n                fLo = f.value(xLo)\n                remainingEval--\n            }\n\n            // update the higher bound\n            if (changeHi) {\n                xHi = min(max, xHi + step)\n                fHi = f.value(xHi)\n                remainingEval--\n            }\n\n        }\n\n        error(\"NoBracketing\")\n        //Exception - FAILED_BRACKETING xLo:$xLo, xHi: $xHi, fLo: $fLo, fHi: $fHi, maxEval: ${maxEval - remainingEval}, maxEval: $maxEval, baseRoot: $baseRoot, min: $min, max: $max\")\n    }\n\n    /**\n     * This method attempts to find two values a and b satisfying\n     *  *  ` lowerBound <= a < initial < b <= upperBound`\n     *  *  ` f(a) * f(b) <= 0 `\n     *\n     * If f is continuous on `[a,b],` this means that `a`\n     * and `b` bracket a root of f.\n     *\n     *\n     * The algorithm starts by setting\n     * `a := initial -1; b := initial +1,` examines the value of the\n     * function at `a` and `b` and keeps moving\n     * the endpoints out by one unit each time through a loop that terminates\n     * when one of the following happens:\n     *  *  ` f(a) * f(b) <= 0 ` --  success!\n     *  *  ` a = lower ` and ` b = upper`\n     * -- NoBracketingException\n     *  *  ` maximumIterations` iterations elapse\n     * -- NoBracketingException\n     *\n     * @param function Function.\n     * @param initial Initial midpoint of interval being expanded to\n     * bracket a root.\n     * @param lowerBound Lower bound (a is never lower than this value).\n     * @param upperBound Upper bound (b never is greater than this\n     * value).\n     * @param maximumIterations Maximum number of iterations to perform\n     * @return a two element array holding a and b.\n     * @throws NoBracketingException if the algorithm fails to find a and b\n     * satisfying the desired conditions.\n     * @throws IllegalArgumentException if function is null, maximumIterations\n     * is not positive, or initial is not between lowerBound and upperBound.\n     */\n    @JvmOverloads\n    fun bracket(\n        function: UnivariateFunction,\n        initial: Double,\n        lowerBound: Double, upperBound: Double,\n        maximumIterations: Int = Int.MAX_VALUE\n    ): DoubleArray {\n        if (maximumIterations <= 0) {\n            error(\"NotStrictlyPositive\")\n        }\n        verifySequence(lowerBound, initial, upperBound)\n\n        var a = initial\n        var b = initial\n        var fa: Double\n        var fb: Double\n        var numIterations = 0\n\n        do {\n            a = max(a - 1.0, lowerBound)\n            b = min(b + 1.0, upperBound)\n            fa = function.value(a)\n\n            fb = function.value(b)\n            ++numIterations\n        } while (fa * fb > 0.0 && numIterations < maximumIterations &&\n            (a > lowerBound || b < upperBound)\n        )\n\n        if (fa * fb > 0.0) {\n            error(\"NoBracketing\")\n            //LocalizedFormats.FAILED_BRACKETING,\n            //a, b, fa, fb,\n            //numIterations, maximumIterations, initial,\n            //lowerBound, upperBound\n        }\n\n        return doubleArrayOf(a, b)\n    }\n\n    /**\n     * Compute the midpoint of two values.\n     *\n     * @param a first value.\n     * @param b second value.\n     * @return the midpoint.\n     */\n    fun midpoint(a: Double, b: Double): Double {\n        return (a + b) * 0.5\n    }\n\n    /**\n     * Check whether the interval bounds bracket a root. That is, if the\n     * values at the endpoints are not equal to zero, then the function takes\n     * opposite signs at the endpoints.\n     *\n     * @param function Function.\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @return `true` if the function values have opposite signs at the\n     * given points.\n     */\n    fun isBracketing(\n        function: UnivariateFunction,\n        lower: Double,\n        upper: Double\n    ): Boolean {\n        val fLo = function.value(lower)\n        val fHi = function.value(upper)\n        return fLo >= 0 && fHi <= 0 || fLo <= 0 && fHi >= 0\n    }\n\n    /**\n     * Check whether the arguments form a (strictly) increasing sequence.\n     *\n     * @param start First number.\n     * @param mid Second number.\n     * @param end Third number.\n     * @return `true` if the arguments form an increasing sequence.\n     */\n    fun isSequence(\n        start: Double,\n        mid: Double,\n        end: Double\n    ): Boolean {\n        return start < mid && mid < end\n    }\n\n    /**\n     * Check that the endpoints specify an interval.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NumberIsTooLargeException if `lower >= upper`.\n     */\n    fun verifyInterval(\n        lower: Double,\n        upper: Double\n    ) {\n        if (lower >= upper) {\n            error(\"NumberIsTooLarge\")\n            //LocalizedFormats.ENDPOINTS_NOT_AN_INTERVAL,\n            //lower, upper, false\n        }\n    }\n\n    /**\n     * Check that `lower < initial < upper`.\n     *\n     * @param lower Lower endpoint.\n     * @param initial Initial value.\n     * @param upper Upper endpoint.\n     * @throws NumberIsTooLargeException if `lower >= initial` or\n     * `initial >= upper`.\n     */\n    fun verifySequence(\n        lower: Double,\n        initial: Double,\n        upper: Double\n    ) {\n        verifyInterval(lower, initial)\n        verifyInterval(initial, upper)\n    }\n\n    /**\n     * Check that the endpoints specify an interval and the end points\n     * bracket a root.\n     *\n     * @param function Function.\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NoBracketingException if function has the same sign at the\n     * endpoints.\n     */\n    fun verifyBracketing(\n        function: UnivariateFunction,\n        lower: Double,\n        upper: Double\n    ) {\n        verifyInterval(lower, upper)\n        if (!isBracketing(function, lower, upper)) {\n            error(\"NoBracketing\")\n            //lower, upper,\n            //function.value(lower),\n            //function.value(upper)\n        }\n    }\n}\n/**\n * Class contains only static methods.\n */\n/**\n * This method attempts to find two values a and b satisfying\n *  *  ` lowerBound <= a < initial < b <= upperBound`\n *  *  ` f(a) * f(b) < 0 `\n *\n * If f is continuous on `[a,b],` this means that `a`\n * and `b` bracket a root of f.\n *\n *\n * The algorithm starts by setting\n * `a := initial -1; b := initial +1,` examines the value of the\n * function at `a` and `b` and keeps moving\n * the endpoints out by one unit each time through a loop that terminates\n * when one of the following happens:\n *  *  ` f(a) * f(b) < 0 ` --  success!\n *  *  ` a = lower ` and ` b = upper`\n * -- NoBracketingException\n *  *  ` Integer.MAX_VALUE` iterations elapse\n * -- NoBracketingException\n *\n *\n *\n * **Note: ** this method can take\n * `Integer.MAX_VALUE` iterations to throw a\n * `ConvergenceException.`  Unless you are confident that there\n * is a root between `lowerBound` and `upperBound`\n * near `initial,` it is better to use\n * [.bracket],\n * explicitly specifying the maximum number of iterations.\n *\n * @param function Function.\n * @param initial Initial midpoint of interval being expanded to\n * bracket a root.\n * @param lowerBound Lower bound (a is never lower than this value)\n * @param upperBound Upper bound (b never is greater than this\n * value).\n * @return a two-element array holding a and b.\n * @throws NoBracketingException if a root cannot be bracketted.\n * @throws IllegalArgumentException if function is null, maximumIterations\n * is not positive, or initial is not between lowerBound and upperBound.\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\ndata class EvalResult(\n    val y: Double,    // predicted value\n    val ymin: Double, // lower pointwise confidence interval around the mean\n    val ymax: Double, // upper pointwise confidence interval around the mean\n    val se: Double    // standard error\n)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport kotlin.math.max\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass LinearRegression(xs: List<Double?>, ys: List<Double?>, confidenceLevel: Double) :\n    RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val beta1: Double\n    private val beta0: Double\n    private val sy: Double // Standard error of estimate\n    private val tcritical: Double\n\n    init {\n        val (xVals, yVals) = allFinite(xs, ys)\n        n = xVals.size\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n\n        val meanY = yVals.average()\n        val sumYY = yVals.sumOf { (it - meanY).pow(2) }\n        val sumXY = xVals.zip(yVals).sumOf { (x, y) -> (x - meanX) * (y - meanY) }\n\n        beta1 = sumXY / sumXX\n        beta0 = meanY - beta1 * meanX\n\n        sy = run { // Standard error of estimate\n            val sse = max(0.0, sumYY - sumXY * sumXY / sumXX) // https://en.wikipedia.org/wiki/Residual_sum_of_squares\n            sqrt(sse / (n - 2)) // SE estimate\n        }\n\n        tcritical = run {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(n - 2.0).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        }\n    }\n\n    private fun value(x: Double): Double = beta1 * x + beta0\n\n    override fun evalX(x: Double): EvalResult {\n\n        // confidence interval for the conditional mean\n        // https://www.ma.utexas.edu/users/mks/statmistakes/CIvsPI.html\n        // https://onlinecourses.science.psu.edu/stat414/node/297\n\n        // https://www2.stat.duke.edu/~tjl13/s101/slides/unit6lec3H.pdf\n        // Stat symbols:\n        // https://brownmath.com/swt/symbol.htm\n\n\n        // standard error (of estimate?)\n        val se = run {// standard error of predicted means\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n        val yHat = value(x)\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.LoessInterpolator\nimport jetbrains.datalore.plot.base.stat.math3.PolynomialSplineFunction\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport kotlin.math.max\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass LocalPolynomialRegression(\n    xs: List<Double?>,\n    ys: List<Double?>,\n    confidenceLevel: Double,\n    private val bandwidth: Double\n) : RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    val canCompute: Boolean\n\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val sy: Double\n    private val tcritical: Double\n    private lateinit var polynomial: PolynomialSplineFunction\n\n    init {\n        val (xVals, yVals) = averageByX(xs, ys)\n\n        n = xVals.size\n        val degreesOfFreedom = n - 2.0\n\n        // See: LoessInterpolator.kt:168\n        val bandwidthInPoints = (bandwidth * n).toInt()\n        val bandwidthInPointsOk = bandwidthInPoints >= 2\n\n        canCompute = (n >= 3 && degreesOfFreedom > 0 && bandwidthInPointsOk)\n\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n\n        val meanY = yVals.average()\n        val sumYY = yVals.sumOf { (it - meanY).pow(2) }\n        val sumXY = xVals.zip(yVals).sumOf { (x, y) -> (x - meanX) * (y - meanY) }\n\n        sy = run {\n            val sse = max(0.0, sumYY - sumXY * sumXY / sumXX)\n            sqrt(sse / (n - 2))\n        }\n\n\n        if (canCompute) {\n            polynomial = getPoly(xVals, yVals)\n        }\n\n        tcritical = if (canCompute) {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(degreesOfFreedom).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        } else {\n            Double.NaN\n        }\n    }\n\n    override fun evalX(x: Double): EvalResult {\n\n        val se = run {\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n\n        val yHat = polynomial.value(x)!!\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n\n    private fun getPoly(xVals: DoubleArray, yVals: DoubleArray): PolynomialSplineFunction {\n        return LoessInterpolator(bandwidth, 4).interpolate(xVals, yVals)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.ForsythePolynomialGenerator\nimport jetbrains.datalore.plot.base.stat.math3.PolynomialFunction\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport jetbrains.datalore.plot.base.stat.math3.times\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass PolynomialRegression(xs: List<Double?>, ys: List<Double?>, confidenceLevel: Double, deg: Int) :\n    RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    private val p: PolynomialFunction\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val sy: Double\n    private val tcritical: Double\n\n    init {\n        require(deg >= 2) { \"Degree of polynomial must be at least 2\" }\n\n        val (xVals, yVals) = averageByX(xs, ys)\n        n = xVals.size\n\n        require(n > deg) { \"The number of valid data points must be greater than deg\" }\n\n        p = calcPolynomial(deg, xVals, yVals)\n\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n        val df = n - deg - 1.0\n\n        sy = run { // Standard error of estimate\n            val sse = xVals.zip(yVals).sumOf { (x, y) -> (y - p.value(x)).pow(2) }\n            sqrt(sse / (df))\n        }\n\n        tcritical = run {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(df).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        }\n    }\n\n    private fun calcPolynomial(deg: Int, xVals: DoubleArray, yVals: DoubleArray): PolynomialFunction {\n        val fpg = ForsythePolynomialGenerator(xVals)\n        var res = PolynomialFunction(doubleArrayOf(0.0))\n\n        for (i in 0..deg) {\n            val p = fpg.getPolynomial(i)\n            val s = coefficient(p, xVals, yVals)\n            res += s * p\n        }\n\n        return res\n    }\n\n    private fun coefficient(p: PolynomialFunction, xVals: DoubleArray, yVals: DoubleArray): Double {\n        var ww = 0.0\n        var w = 0.0\n        for (i in 0 until xVals.size) {\n            val x = xVals[i]\n            val y = yVals[i]\n            val pval = p.value(x)\n\n            ww += pval * pval\n            w += y * pval\n        }\n\n        return w / ww\n    }\n\n    override fun evalX(x: Double): EvalResult {\n\n        val se = run { // standard error of predicted means\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n\n        val yHat = p.value(x)\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n\n    companion object {\n        fun canBeComputed(xs: List<Double?>, ys: List<Double?>, deg: Int): Boolean {\n            // ToDo: duplicates the constructor code\n            val (xVals, _) = averageByX(xs, ys)\n            return xVals.size > deg\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nabstract class RegressionEvaluator protected constructor(\n    xs: List<Double?>,\n    ys: List<Double?>,\n    confidenceLevel: Double\n) {\n    init {\n        require(confidenceLevel in 0.01..0.99) { \"Confidence level is out of range [0.01-0.99]. CL:$confidenceLevel\" }\n        require(xs.size == ys.size) { \"X/Y must have same size. X:\" + xs.size + \" Y:\" + ys.size }\n    }\n\n    abstract fun evalX(x: Double): EvalResult\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.Percentile\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.random.Random\n\ninternal object RegressionUtil {\n\n    // sample m data randomly\n    fun <T> sampling(data: List<T>, m: Int): ArrayList<T> {\n        val index = sampleInt(data.size, m)\n        val result = ArrayList<T>()\n        for (i in index) {\n            result.add(data[i])\n        }\n        return result\n    }\n\n    // sample m int from 0..n-1\n    private fun sampleInt(n: Int, m: Int): IntArray {\n        if (n < m || m < 0) {\n            error(\"Sample $m data from $n data is impossible!\")\n        }\n        val perm = IntArray(n)\n        for (i in 0 until n) {\n            perm[i] = i\n        }\n\n        val result = IntArray(m)\n        for (j in 0 until m) {\n            val r = j + (Random.nextDouble() * (n - j)).toInt()\n            result[j] = perm[r]\n            perm[r] = perm[j]\n        }\n        return result\n    }\n\n    fun percentile(data: List<Double>, p: Double): Double {\n        return Percentile.evaluate(data.toDoubleArray(), p * 100)\n    }\n}\n\nfun allFinite(xs: List<Double?>, ys: List<Double?>): Pair<DoubleArray, DoubleArray> {\n    val tx = ArrayList<Double>()\n    val ty = ArrayList<Double>()\n\n    for ((x, y) in xs.asSequence().zip(ys.asSequence())) {\n        if (SeriesUtil.allFinite(x, y)) {\n            tx.add(x!!)\n            ty.add(y!!)\n        }\n    }\n\n    return Pair(tx.toDoubleArray(), ty.toDoubleArray())\n}\n\nprivate fun finitePairs(xs: List<Double?>, ys: List<Double?>): ArrayList<Pair<Double, Double>> {\n    val res = ArrayList<Pair<Double, Double>>()\n\n    for ((x, y) in xs.asSequence().zip(ys.asSequence())) {\n        if (SeriesUtil.allFinite(x, y)) {\n            res.add(Pair(x!!, y!!))\n        }\n    }\n\n    return res\n}\n\nprivate fun averageByX(lst: List<Pair<Double, Double>>): Pair<List<Double>, List<Double>> {\n\n    if (lst.isEmpty())\n        return Pair(ArrayList<Double>(), ArrayList<Double>())\n\n    val tx = ArrayList<Double>()\n    val ty = ArrayList<Double>()\n    var (prevX, sumY) = lst.first()\n    var countY = 1\n\n    for ((x, y) in lst.asSequence().drop(1)) {\n        if (x == prevX) {\n            sumY += y\n            ++countY\n        } else {\n            tx.add(prevX)\n            ty.add(sumY.div(countY))\n            prevX = x\n            sumY = y\n            countY = 1\n        }\n    }\n\n    tx.add(prevX)\n    ty.add(sumY.div(countY))\n\n    return Pair(tx, ty)\n}\n\nfun averageByX(xs: List<Double?>, ys: List<Double?>): Pair<DoubleArray, DoubleArray> {\n    val tp = finitePairs(xs, ys)\n    tp.sortBy { it.first }\n    val res = averageByX(tp)\n    return Pair(res.first.toDoubleArray(), res.second.toDoubleArray())\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nclass MutableDouble(private var myValue: Double) {\n\n    fun getAndAdd(v: Double): Double {\n        val prevValue = myValue\n        myValue = prevValue + v\n        return prevValue\n    }\n\n    fun get(): Double {\n        return myValue\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nclass MutableInteger(private var myValue: Int) {\n\n    val andIncrement: Int\n        get() = getAndAdd(1)\n\n    fun get(): Int {\n        return myValue\n    }\n\n    fun getAndAdd(v: Int): Int {\n        val prevValue = myValue\n        myValue = prevValue + v\n        return prevValue\n    }\n\n    fun increment() {\n        getAndAdd(1)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport kotlin.random.Random\n\nobject SamplingUtil {\n\n    fun <T> sampleWithoutReplacement(\n        popSize: Int, sampleSize: Int, rand: Random, onPick: (Set<Int>) -> T, onDrop: (Set<Int>) -> T\n    ): T {\n        val pick = sampleSize <= popSize / 2\n        val indexCount = if (pick) sampleSize else popSize - sampleSize\n\n        val indexSet = HashSet<Int>()\n\n        while (indexSet.size < indexCount) {\n            indexSet.add(rand.nextInt(popSize))\n        }\n\n        return if (pick) onPick(indexSet) else onDrop(indexSet)\n    }\n\n    fun sampleWithoutReplacement(sampleSize: Int, rand: Random, data: DataFrame): DataFrame {\n        return sampleWithoutReplacement(\n            data.rowCount(),\n            sampleSize,\n            rand,\n            { data.selectIndices(it) },\n            { data.dropIndices(it) }\n        )\n    }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-base-portable.js\n"); +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-plot-common-portable */ \"./kotlin-dce-dev/lets-plot-plot-common-portable.js\"), __webpack_require__(/*! lets-plot-vis-svg-portable */ \"./kotlin-dce-dev/lets-plot-vis-svg-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_base_portable, $module$lets_plot_plot_common_portable, $module$lets_plot_vis_svg_portable) {\n 'use strict';\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var Iterable = Kotlin.kotlin.collections.Iterable;\n var throwCCE = Kotlin.throwCCE;\n var equals = Kotlin.equals;\n var List = Kotlin.kotlin.collections.List;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var TypedKey = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKey;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var ensureNotNull = Kotlin.ensureNotNull;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var LinkedHashSet_init = Kotlin.kotlin.collections.LinkedHashSet_init_mqih57$;\n var Collection = Kotlin.kotlin.collections.Collection;\n var data = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.data;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var zip = Kotlin.kotlin.collections.zip_45mdf7$;\n var getCallableRef = Kotlin.getCallableRef;\n var toList = Kotlin.kotlin.collections.toList_abgq59$;\n var compareBy = Kotlin.kotlin.comparisons.compareBy_bvgy4j$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var reversed = Kotlin.kotlin.collections.reversed_7wnvza$;\n var plus = Kotlin.kotlin.collections.plus_mydzjv$;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var logging = $module$lets_plot_base_portable.jetbrains.datalore.base.logging;\n var getKClass = Kotlin.getKClass;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_73mtqc$;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var MutableCollection = Kotlin.kotlin.collections.MutableCollection;\n var toString = Kotlin.toString;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var TreeMap = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.TreeMap;\n var intersect = Kotlin.kotlin.collections.intersect_q4559j$;\n var Map = Kotlin.kotlin.collections.Map;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var JsMath = Math;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var Unit = Kotlin.kotlin.Unit;\n var TypedKeyHashMap = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKeyHashMap;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var NoSuchElementException = Kotlin.kotlin.NoSuchElementException;\n var Iterator = Kotlin.kotlin.collections.Iterator;\n var Function = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Function;\n var values = $module$lets_plot_base_portable.jetbrains.datalore.base.values;\n var svg = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg;\n var DoubleVector = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleVector;\n var geometry = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var Comparator = Kotlin.kotlin.Comparator;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var base = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.base;\n var startsWith = Kotlin.kotlin.text.startsWith_7epoxm$;\n var Regex_init = Kotlin.kotlin.text.Regex_init_61zpoe$;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_ww73n8$;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var Any = Object;\n var DoubleRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle;\n var DoubleRectangle_init = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$;\n var SvgLineElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement_init_6y0v78$;\n var SvgGElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGElement;\n var slim = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.slim;\n var SvgRectElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_6y0v78$;\n var SvgImageElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElement_init_6y0v78$;\n var throwUPAE = Kotlin.throwUPAE;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var SvgPathDataBuilder = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathDataBuilder;\n var math = Kotlin.kotlin.math;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var numberToInt = Kotlin.numberToInt;\n var SvgImageElementEx$Bitmap = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElementEx.Bitmap;\n var SvgImageElementEx = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgImageElementEx;\n var SvgPathElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathElement_init_7jrsat$;\n var SvgShape = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgShape;\n var SvgElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgElement;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var copyToArray = Kotlin.kotlin.collections.copyToArray;\n var splitRings = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.splitRings_bemo1h$;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var SvgRectElement_init_0 = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_wthzt5$;\n var emptyMap = Kotlin.kotlin.collections.emptyMap_q3lmfv$;\n var Random = Kotlin.kotlin.random.Random;\n var asList = Kotlin.kotlin.collections.asList_us0mfu$;\n var SvgSlimObject = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.slim.SvgSlimObject;\n var SvgPathData = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathData;\n var SvgPathDataBuilder$Interpolation = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgPathDataBuilder.Interpolation;\n var WritableProperty = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property.WritableProperty;\n var SvgColors = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgColors;\n var EventHandler = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventHandler;\n var CompositeRegistration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.CompositeRegistration;\n var SvgClipPathElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgClipPathElement;\n var SvgRectElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement;\n var SvgDefsElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgDefsElement;\n var SvgIRI = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgIRI;\n var SvgGraphicsElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGraphicsElement;\n var SvgTransformBuilder = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgTransformBuilder;\n var random = $module$lets_plot_base_portable.jetbrains.datalore.base.random;\n var SvgTextElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgTextElement_init_61zpoe$;\n var isBlank = Kotlin.kotlin.text.isBlank_gw00vp$;\n var filterNotNull = Kotlin.kotlin.collections.filterNotNull_m3lr2h$;\n var checkIndexOverflow = Kotlin.kotlin.collections.checkIndexOverflow_za3lpa$;\n var numberToDouble = Kotlin.numberToDouble;\n var Pair_0 = Kotlin.kotlin.Pair;\n var toMap = Kotlin.kotlin.collections.toMap_6hr0sd$;\n var getValue = Kotlin.kotlin.collections.getValue_t9ocha$;\n var toList_0 = Kotlin.kotlin.collections.toList_7wnvza$;\n var isInfinite = Kotlin.kotlin.isInfinite_yrwdxr$;\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var YearInterval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval.YearInterval;\n var time = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time;\n var interval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_mh5how$;\n var asReversed = Kotlin.kotlin.collections.asReversed_2p1efm$;\n var NumberFormat_init = $module$lets_plot_base_portable.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$;\n var text = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.text;\n var TimeInterval = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.time.interval.TimeInterval;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var last = Kotlin.kotlin.collections.last_2p1efm$;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var abs = Kotlin.kotlin.math.abs_za3lpa$;\n var maxOrNull = Kotlin.kotlin.collections.maxOrNull_l63kqw$;\n var mutableMapOf = Kotlin.kotlin.collections.mutableMapOf_qfcya0$;\n var HashSet_init_1 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var sortWith = Kotlin.kotlin.collections.sortWith_nqfjgj$;\n var hashCode = Kotlin.hashCode;\n var rangeTo = Kotlin.kotlin.ranges.rangeTo_38ydlf$;\n var withIndex = Kotlin.kotlin.collections.withIndex_7wnvza$;\n var LinkedHashSet_init_0 = Kotlin.kotlin.collections.LinkedHashSet_init_287e2$;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var unzip = Kotlin.kotlin.collections.unzip_6hr0sd$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var sum = Kotlin.kotlin.collections.sum_l63kqw$;\n var wrapFunction = Kotlin.wrapFunction;\n var Array_0 = Array;\n var L37 = Kotlin.Long.fromInt(37);\n var Random_0 = Kotlin.kotlin.random.Random_s8cxhz$;\n var coerceIn = Kotlin.kotlin.ranges.coerceIn_nig4hr$;\n var L_38038050983108802 = new Kotlin.Long(456400702, -8856424);\n var arrayCopy = Kotlin.kotlin.collections.arrayCopy;\n var average = Kotlin.kotlin.collections.average_bvy38s$;\n var arrayListOf = Kotlin.kotlin.collections.arrayListOf_i5x0yv$;\n var fill = Kotlin.kotlin.collections.fill_x4f2cq$;\n var sort = Kotlin.primitiveArraySort;\n var fill_0 = Kotlin.kotlin.collections.fill_tpuxuu$;\n var get_lastIndex = Kotlin.kotlin.collections.get_lastIndex_bvy38s$;\n var get_indices = Kotlin.kotlin.collections.get_indices_bvy38s$;\n var reversed_0 = Kotlin.kotlin.ranges.reversed_zf1xzc$;\n var toMutableList_0 = Kotlin.kotlin.collections.toMutableList_bvy38s$;\n var isNaN_1 = Kotlin.kotlin.isNaN_81szk$;\n var toBits = Kotlin.floatToBits;\n var toBits_0 = Kotlin.doubleToBits;\n var abs_0 = Kotlin.kotlin.math.abs_s8cxhz$;\n var L_2147483648 = Kotlin.Long.fromInt(-2147483648);\n var L_5852615386664158222 = new Kotlin.Long(1994767346, -1362668208);\n var zip_0 = Kotlin.kotlin.collections.zip_pmvpm9$;\n var toDoubleArray = Kotlin.kotlin.collections.toDoubleArray_tcduak$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var zip_1 = Kotlin.kotlin.sequences.zip_r7q3s9$;\n var drop = Kotlin.kotlin.sequences.drop_wuwhe2$;\n DataFrame$Variable$Source.prototype = Object.create(Enum.prototype);\n DataFrame$Variable$Source.prototype.constructor = DataFrame$Variable$Source;\n GeomKind.prototype = Object.create(Enum.prototype);\n GeomKind.prototype.constructor = GeomKind;\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$bar$ObjectLiteral;\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$histogram$ObjectLiteral;\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype = Object.create(AestheticsDefaults.prototype);\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype.constructor = AestheticsDefaults$Companion$area$ObjectLiteral;\n TransformVar$TransformVarByAes.prototype = Object.create(AesVisitor.prototype);\n TransformVar$TransformVarByAes.prototype.constructor = TransformVar$TransformVarByAes;\n ABLineGeom.prototype = Object.create(GeomBase.prototype);\n ABLineGeom.prototype.constructor = ABLineGeom;\n AreaGeom.prototype = Object.create(GeomBase.prototype);\n AreaGeom.prototype.constructor = AreaGeom;\n BarGeom.prototype = Object.create(GeomBase.prototype);\n BarGeom.prototype.constructor = BarGeom;\n TileGeom.prototype = Object.create(GeomBase.prototype);\n TileGeom.prototype.constructor = TileGeom;\n Bin2dGeom.prototype = Object.create(TileGeom.prototype);\n Bin2dGeom.prototype.constructor = Bin2dGeom;\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype = Object.create(DataPointAestheticsDelegate.prototype);\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.constructor = BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral;\n BoxplotGeom.prototype = Object.create(GeomBase.prototype);\n BoxplotGeom.prototype.constructor = BoxplotGeom;\n PathGeom.prototype = Object.create(GeomBase.prototype);\n PathGeom.prototype.constructor = PathGeom;\n ContourGeom.prototype = Object.create(PathGeom.prototype);\n ContourGeom.prototype.constructor = ContourGeom;\n PolygonGeom.prototype = Object.create(GeomBase.prototype);\n PolygonGeom.prototype.constructor = PolygonGeom;\n ContourfGeom.prototype = Object.create(PolygonGeom.prototype);\n ContourfGeom.prototype.constructor = ContourfGeom;\n CrossBarGeom.prototype = Object.create(GeomBase.prototype);\n CrossBarGeom.prototype.constructor = CrossBarGeom;\n Density2dGeom.prototype = Object.create(ContourGeom.prototype);\n Density2dGeom.prototype.constructor = Density2dGeom;\n Density2dfGeom.prototype = Object.create(ContourfGeom.prototype);\n Density2dfGeom.prototype.constructor = Density2dfGeom;\n DensityGeom.prototype = Object.create(AreaGeom.prototype);\n DensityGeom.prototype.constructor = DensityGeom;\n ErrorBarGeom.prototype = Object.create(GeomBase.prototype);\n ErrorBarGeom.prototype.constructor = ErrorBarGeom;\n LineGeom.prototype = Object.create(PathGeom.prototype);\n LineGeom.prototype.constructor = LineGeom;\n FreqpolyGeom.prototype = Object.create(LineGeom.prototype);\n FreqpolyGeom.prototype.constructor = FreqpolyGeom;\n HLineGeom.prototype = Object.create(GeomBase.prototype);\n HLineGeom.prototype.constructor = HLineGeom;\n HistogramGeom.prototype = Object.create(BarGeom.prototype);\n HistogramGeom.prototype.constructor = HistogramGeom;\n ImageGeom.prototype = Object.create(GeomBase.prototype);\n ImageGeom.prototype.constructor = ImageGeom;\n PointGeom.prototype = Object.create(GeomBase.prototype);\n PointGeom.prototype.constructor = PointGeom;\n JitterGeom.prototype = Object.create(PointGeom.prototype);\n JitterGeom.prototype.constructor = JitterGeom;\n LineRangeGeom.prototype = Object.create(GeomBase.prototype);\n LineRangeGeom.prototype.constructor = LineRangeGeom;\n MapGeom.prototype = Object.create(PolygonGeom.prototype);\n MapGeom.prototype.constructor = MapGeom;\n LinesHelper.prototype = Object.create(GeomHelper.prototype);\n LinesHelper.prototype.constructor = LinesHelper;\n PieGeom$PieHelper.prototype = Object.create(LinesHelper.prototype);\n PieGeom$PieHelper.prototype.constructor = PieGeom$PieHelper;\n PieGeom.prototype = Object.create(GeomBase.prototype);\n PieGeom.prototype.constructor = PieGeom;\n PointRangeGeom.prototype = Object.create(GeomBase.prototype);\n PointRangeGeom.prototype.constructor = PointRangeGeom;\n RasterGeom.prototype = Object.create(GeomBase.prototype);\n RasterGeom.prototype.constructor = RasterGeom;\n RectGeom.prototype = Object.create(GeomBase.prototype);\n RectGeom.prototype.constructor = RectGeom;\n RibbonGeom.prototype = Object.create(GeomBase.prototype);\n RibbonGeom.prototype.constructor = RibbonGeom;\n SegmentGeom.prototype = Object.create(GeomBase.prototype);\n SegmentGeom.prototype.constructor = SegmentGeom;\n SmoothGeom.prototype = Object.create(GeomBase.prototype);\n SmoothGeom.prototype.constructor = SmoothGeom;\n StepGeom$Direction.prototype = Object.create(Enum.prototype);\n StepGeom$Direction.prototype.constructor = StepGeom$Direction;\n StepGeom.prototype = Object.create(LineGeom.prototype);\n StepGeom.prototype.constructor = StepGeom;\n TextGeom.prototype = Object.create(GeomBase.prototype);\n TextGeom.prototype.constructor = TextGeom;\n VLineGeom.prototype = Object.create(GeomBase.prototype);\n VLineGeom.prototype.constructor = VLineGeom;\n ArrowSpec$toArrowAes$ObjectLiteral.prototype = Object.create(DataPointAestheticsDelegate.prototype);\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.constructor = ArrowSpec$toArrowAes$ObjectLiteral;\n ArrowSpec$End.prototype = Object.create(Enum.prototype);\n ArrowSpec$End.prototype.constructor = ArrowSpec$End;\n ArrowSpec$Type.prototype = Object.create(Enum.prototype);\n ArrowSpec$Type.prototype.constructor = ArrowSpec$Type;\n RectanglesHelper.prototype = Object.create(GeomHelper.prototype);\n RectanglesHelper.prototype.constructor = RectanglesHelper;\n GeomTargetLocator$LookupSpace.prototype = Object.create(Enum.prototype);\n GeomTargetLocator$LookupSpace.prototype.constructor = GeomTargetLocator$LookupSpace;\n GeomTargetLocator$LookupStrategy.prototype = Object.create(Enum.prototype);\n GeomTargetLocator$LookupStrategy.prototype.constructor = GeomTargetLocator$LookupStrategy;\n HitShape$Kind.prototype = Object.create(Enum.prototype);\n HitShape$Kind.prototype.constructor = HitShape$Kind;\n HitShape$Companion$shapeWithPath$ObjectLiteral.prototype = Object.create(HitShape.prototype);\n HitShape$Companion$shapeWithPath$ObjectLiteral.prototype.constructor = HitShape$Companion$shapeWithPath$ObjectLiteral;\n TipLayoutHint$StemLength.prototype = Object.create(Enum.prototype);\n TipLayoutHint$StemLength.prototype.constructor = TipLayoutHint$StemLength;\n TipLayoutHint$Kind.prototype = Object.create(Enum.prototype);\n TipLayoutHint$Kind.prototype.constructor = TipLayoutHint$Kind;\n TooltipAnchor$VerticalAnchor.prototype = Object.create(Enum.prototype);\n TooltipAnchor$VerticalAnchor.prototype.constructor = TooltipAnchor$VerticalAnchor;\n TooltipAnchor$HorizontalAnchor.prototype = Object.create(Enum.prototype);\n TooltipAnchor$HorizontalAnchor.prototype.constructor = TooltipAnchor$HorizontalAnchor;\n LivemapConstants$DisplayMode.prototype = Object.create(Enum.prototype);\n LivemapConstants$DisplayMode.prototype.constructor = LivemapConstants$DisplayMode;\n LivemapConstants$Theme.prototype = Object.create(Enum.prototype);\n LivemapConstants$Theme.prototype.constructor = LivemapConstants$Theme;\n LivemapConstants$Projection.prototype = Object.create(Enum.prototype);\n LivemapConstants$Projection.prototype.constructor = LivemapConstants$Projection;\n PositionAdjustments$Meta.prototype = Object.create(Enum.prototype);\n PositionAdjustments$Meta.prototype.constructor = PositionAdjustments$Meta;\n PositionAdjustments$StackingStrategy.prototype = Object.create(Enum.prototype);\n PositionAdjustments$StackingStrategy.prototype.constructor = PositionAdjustments$StackingStrategy;\n StackPos$SplitPositiveNegative.prototype = Object.create(StackPos.prototype);\n StackPos$SplitPositiveNegative.prototype.constructor = StackPos$SplitPositiveNegative;\n StackPos$SumPositiveNegative.prototype = Object.create(StackPos.prototype);\n StackPos$SumPositiveNegative.prototype.constructor = StackPos$SumPositiveNegative;\n NamedLineType.prototype = Object.create(Enum.prototype);\n NamedLineType.prototype.constructor = NamedLineType;\n NamedLineType$BLANK.prototype = Object.create(NamedLineType.prototype);\n NamedLineType$BLANK.prototype.constructor = NamedLineType$BLANK;\n NamedLineType$SOLID.prototype = Object.create(NamedLineType.prototype);\n NamedLineType$SOLID.prototype.constructor = NamedLineType$SOLID;\n NamedShape.prototype = Object.create(Enum.prototype);\n NamedShape.prototype.constructor = NamedShape;\n CircleGlyph.prototype = Object.create(SingletonGlyph.prototype);\n CircleGlyph.prototype.constructor = CircleGlyph;\n TwoShapeGlyph.prototype = Object.create(MultiShapeGlyph.prototype);\n TwoShapeGlyph.prototype.constructor = TwoShapeGlyph;\n CrossGlyph.prototype = Object.create(TwoShapeGlyph.prototype);\n CrossGlyph.prototype.constructor = CrossGlyph;\n DiamondGlyph.prototype = Object.create(SingletonGlyph.prototype);\n DiamondGlyph.prototype.constructor = DiamondGlyph;\n PlusGlyph.prototype = Object.create(TwoShapeGlyph.prototype);\n PlusGlyph.prototype.constructor = PlusGlyph;\n SquareGlyph.prototype = Object.create(SingletonGlyph.prototype);\n SquareGlyph.prototype.constructor = SquareGlyph;\n TriangleGlyph.prototype = Object.create(SingletonGlyph.prototype);\n TriangleGlyph.prototype.constructor = TriangleGlyph;\n GroupComponent.prototype = Object.create(SvgComponent.prototype);\n GroupComponent.prototype.constructor = GroupComponent;\n LinePath.prototype = Object.create(SvgComponent.prototype);\n LinePath.prototype.constructor = LinePath;\n TextLabel$HorizontalAnchor.prototype = Object.create(Enum.prototype);\n TextLabel$HorizontalAnchor.prototype.constructor = TextLabel$HorizontalAnchor;\n TextLabel$VerticalAnchor.prototype = Object.create(Enum.prototype);\n TextLabel$VerticalAnchor.prototype.constructor = TextLabel$VerticalAnchor;\n TextLabel.prototype = Object.create(SvgComponent.prototype);\n TextLabel.prototype.constructor = TextLabel;\n ContinuousScale$MyBuilder.prototype = Object.create(AbstractScale$AbstractBuilder.prototype);\n ContinuousScale$MyBuilder.prototype.constructor = ContinuousScale$MyBuilder;\n ContinuousScale.prototype = Object.create(AbstractScale.prototype);\n ContinuousScale.prototype.constructor = ContinuousScale;\n DiscreteScale$MyBuilder.prototype = Object.create(AbstractScale$AbstractBuilder.prototype);\n DiscreteScale$MyBuilder.prototype.constructor = DiscreteScale$MyBuilder;\n DiscreteScale.prototype = Object.create(AbstractScale.prototype);\n DiscreteScale.prototype.constructor = DiscreteScale;\n DateTimeBreaksHelper.prototype = Object.create(BreaksHelperBase.prototype);\n DateTimeBreaksHelper.prototype.constructor = DateTimeBreaksHelper;\n LinearBreaksHelper.prototype = Object.create(BreaksHelperBase.prototype);\n LinearBreaksHelper.prototype.constructor = LinearBreaksHelper;\n IdentityTransform.prototype = Object.create(FunTransform.prototype);\n IdentityTransform.prototype.constructor = IdentityTransform;\n Log10Transform.prototype = Object.create(FunTransform.prototype);\n Log10Transform.prototype.constructor = Log10Transform;\n ReverseTransform.prototype = Object.create(FunTransform.prototype);\n ReverseTransform.prototype.constructor = ReverseTransform;\n SqrtTransform.prototype = Object.create(FunTransform.prototype);\n SqrtTransform.prototype.constructor = SqrtTransform;\n AbstractDensity2dStat.prototype = Object.create(BaseStat.prototype);\n AbstractDensity2dStat.prototype.constructor = AbstractDensity2dStat;\n Bin2dStat.prototype = Object.create(BaseStat.prototype);\n Bin2dStat.prototype.constructor = Bin2dStat;\n BinStat$XPosKind.prototype = Object.create(Enum.prototype);\n BinStat$XPosKind.prototype.constructor = BinStat$XPosKind;\n BinStat.prototype = Object.create(BaseStat.prototype);\n BinStat.prototype.constructor = BinStat;\n BoxplotStat.prototype = Object.create(BaseStat.prototype);\n BoxplotStat.prototype.constructor = BoxplotStat;\n ContourFillHelper$BorderKind.prototype = Object.create(Enum.prototype);\n ContourFillHelper$BorderKind.prototype.constructor = ContourFillHelper$BorderKind;\n ContourStat.prototype = Object.create(BaseStat.prototype);\n ContourStat.prototype.constructor = ContourStat;\n ContourfStat.prototype = Object.create(BaseStat.prototype);\n ContourfStat.prototype.constructor = ContourfStat;\n CorrelationStat$Method.prototype = Object.create(Enum.prototype);\n CorrelationStat$Method.prototype.constructor = CorrelationStat$Method;\n CorrelationStat$Type.prototype = Object.create(Enum.prototype);\n CorrelationStat$Type.prototype.constructor = CorrelationStat$Type;\n CorrelationStat.prototype = Object.create(BaseStat.prototype);\n CorrelationStat.prototype.constructor = CorrelationStat;\n CountStat.prototype = Object.create(BaseStat.prototype);\n CountStat.prototype.constructor = CountStat;\n Density2dStat.prototype = Object.create(AbstractDensity2dStat.prototype);\n Density2dStat.prototype.constructor = Density2dStat;\n Density2dfStat.prototype = Object.create(AbstractDensity2dStat.prototype);\n Density2dfStat.prototype.constructor = Density2dfStat;\n DensityStat$Kernel.prototype = Object.create(Enum.prototype);\n DensityStat$Kernel.prototype.constructor = DensityStat$Kernel;\n DensityStat$BandWidthMethod.prototype = Object.create(Enum.prototype);\n DensityStat$BandWidthMethod.prototype.constructor = DensityStat$BandWidthMethod;\n DensityStat.prototype = Object.create(BaseStat.prototype);\n DensityStat.prototype.constructor = DensityStat;\n SmoothStat$Method.prototype = Object.create(Enum.prototype);\n SmoothStat$Method.prototype.constructor = SmoothStat$Method;\n SmoothStat.prototype = Object.create(BaseStat.prototype);\n SmoothStat.prototype.constructor = SmoothStat;\n Stats$IdentityStat.prototype = Object.create(BaseStat.prototype);\n Stats$IdentityStat.prototype.constructor = Stats$IdentityStat;\n AbstractUnivariateSolver.prototype = Object.create(BaseAbstractUnivariateSolver.prototype);\n AbstractUnivariateSolver.prototype.constructor = AbstractUnivariateSolver;\n AllowedSolution.prototype = Object.create(Enum.prototype);\n AllowedSolution.prototype.constructor = AllowedSolution;\n Beta$regularizedBeta$ObjectLiteral.prototype = Object.create(ContinuedFraction.prototype);\n Beta$regularizedBeta$ObjectLiteral.prototype.constructor = Beta$regularizedBeta$ObjectLiteral;\n BrentSolver.prototype = Object.create(AbstractUnivariateSolver.prototype);\n BrentSolver.prototype.constructor = BrentSolver;\n Gamma$regularizedGammaQ$ObjectLiteral.prototype = Object.create(ContinuedFraction.prototype);\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.constructor = Gamma$regularizedGammaQ$ObjectLiteral;\n MathArrays$OrderDirection.prototype = Object.create(Enum.prototype);\n MathArrays$OrderDirection.prototype.constructor = MathArrays$OrderDirection;\n TDistribution.prototype = Object.create(AbstractRealDistribution.prototype);\n TDistribution.prototype.constructor = TDistribution;\n LinearRegression.prototype = Object.create(RegressionEvaluator.prototype);\n LinearRegression.prototype.constructor = LinearRegression;\n LocalPolynomialRegression.prototype = Object.create(RegressionEvaluator.prototype);\n LocalPolynomialRegression.prototype.constructor = LocalPolynomialRegression;\n PolynomialRegression.prototype = Object.create(RegressionEvaluator.prototype);\n PolynomialRegression.prototype.constructor = PolynomialRegression;\n function Aes(name, isNumeric) {\n Aes$Companion_getInstance();\n if (isNumeric === void 0)\n isNumeric = true;\n this.name = name;\n this.isNumeric = isNumeric;\n Aes$Companion_getInstance().values_0.add_11rb$(this);\n }\n Object.defineProperty(Aes.prototype, 'isColor', {\n configurable: true,\n get: function () {\n return Aes$Companion_getInstance().isColor_896ixz$(this);\n }\n });\n Aes.prototype.toString = function () {\n return \"aes '\" + this.name + \"'\";\n };\n function Aes$Companion() {\n Aes$Companion_instance = this;\n this.values_0 = ArrayList_init();\n this.X = new Aes('x');\n this.Y = new Aes('y');\n this.Z = new Aes('z');\n this.COLOR = new Aes('color', false);\n this.FILL = new Aes('fill', false);\n this.ALPHA = new Aes('alpha');\n this.SHAPE = new Aes('shape', false);\n this.LINETYPE = new Aes('linetype', false);\n this.SIZE = new Aes('size');\n this.WIDTH = new Aes('width');\n this.HEIGHT = new Aes('height');\n this.WEIGHT = new Aes('weight');\n this.INTERCEPT = new Aes('intercept');\n this.SLOPE = new Aes('slope');\n this.XINTERCEPT = new Aes('xintercept');\n this.YINTERCEPT = new Aes('yintercept');\n this.LOWER = new Aes('lower');\n this.MIDDLE = new Aes('middle');\n this.UPPER = new Aes('upper');\n this.XMIN = new Aes('xmin');\n this.XMAX = new Aes('xmax');\n this.YMIN = new Aes('ymin');\n this.YMAX = new Aes('ymax');\n this.XEND = new Aes('xend');\n this.YEND = new Aes('yend');\n this.FRAME = new Aes('frame', false);\n this.SPEED = new Aes('speed');\n this.FLOW = new Aes('flow');\n this.LABEL = new Aes('label', false);\n this.FAMILY = new Aes('family', false);\n this.FONTFACE = new Aes('fontface', false);\n this.HJUST = new Aes('hjust', false);\n this.VJUST = new Aes('vjust', false);\n this.ANGLE = new Aes('angle');\n this.SYM_X = new Aes('sym_x');\n this.SYM_Y = new Aes('sym_y');\n }\n function Aes$Companion$numeric$lambda(aes) {\n return aes.isNumeric;\n }\n Aes$Companion.prototype.numeric_shhb9a$ = function (unfiltered) {\n var tmp$;\n return Kotlin.isType(tmp$ = collect.Iterables.filter_fpit1u$(unfiltered, Aes$Companion$numeric$lambda), Iterable) ? tmp$ : throwCCE();\n };\n Aes$Companion.prototype.isPositional_896ixz$ = function (aes) {\n return this.isPositionalXY_896ixz$(aes) || equals(aes, this.SLOPE);\n };\n Aes$Companion.prototype.isPositionalXY_896ixz$ = function (aes) {\n return this.isPositionalX_896ixz$(aes) || this.isPositionalY_896ixz$(aes);\n };\n Aes$Companion.prototype.isPositionalX_896ixz$ = function (aes) {\n return equals(aes, this.X) || equals(aes, this.XINTERCEPT) || equals(aes, this.XMIN) || equals(aes, this.XMAX) || equals(aes, this.XEND);\n };\n Aes$Companion.prototype.isPositionalY_896ixz$ = function (aes) {\n return equals(aes, this.Y) || equals(aes, this.YMIN) || equals(aes, this.YMAX) || equals(aes, this.INTERCEPT) || equals(aes, this.YINTERCEPT) || equals(aes, this.LOWER) || equals(aes, this.MIDDLE) || equals(aes, this.UPPER) || equals(aes, this.YEND);\n };\n Aes$Companion.prototype.isColor_896ixz$ = function (aes) {\n return equals(aes, this.COLOR) || equals(aes, this.FILL);\n };\n Aes$Companion.prototype.isAffectingScaleX_896ixz$ = function (aes) {\n return this.isPositionalX_896ixz$(aes);\n };\n Aes$Companion.prototype.isAffectingScaleY_896ixz$ = function (aes) {\n return this.isPositionalY_896ixz$(aes) && !equals(aes, this.INTERCEPT);\n };\n function Aes$Companion$affectingScaleX$lambda(this$Aes$) {\n return function (it) {\n return this$Aes$.isAffectingScaleX_896ixz$(it);\n };\n }\n Aes$Companion.prototype.affectingScaleX_shhb9a$ = function (unfiltered) {\n var numeric = this.numeric_shhb9a$(unfiltered);\n return collect.Iterables.filter_fpit1u$(numeric, Aes$Companion$affectingScaleX$lambda(this));\n };\n function Aes$Companion$affectingScaleY$lambda(this$Aes$) {\n return function (it) {\n return this$Aes$.isAffectingScaleY_896ixz$(it);\n };\n }\n Aes$Companion.prototype.affectingScaleY_shhb9a$ = function (unfiltered) {\n var numeric = this.numeric_shhb9a$(unfiltered);\n return collect.Iterables.filter_fpit1u$(numeric, Aes$Companion$affectingScaleY$lambda(this));\n };\n Aes$Companion.prototype.noGuideNeeded_896ixz$ = function (aes) {\n return equals(aes, this.FRAME) || equals(aes, this.SPEED) || equals(aes, this.FLOW) || equals(aes, this.LABEL) || equals(aes, this.SLOPE) || equals(aes, this.WIDTH) || equals(aes, this.HEIGHT) || equals(aes, this.HJUST) || equals(aes, this.VJUST) || equals(aes, this.ANGLE) || equals(aes, this.FAMILY) || equals(aes, this.FONTFACE) || equals(aes, this.SYM_X) || equals(aes, this.SYM_Y) || this.isPositional_896ixz$(aes);\n };\n Aes$Companion.prototype.values = function () {\n return this.values_0;\n };\n Aes$Companion.prototype.allPositional = function () {\n var tmp$;\n var $receiver = this.values_0;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (this.isPositional_896ixz$(element))\n destination.add_11rb$(element);\n }\n return Kotlin.isType(tmp$ = destination, List) ? tmp$ : throwCCE();\n };\n Aes$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Aes$Companion_instance = null;\n function Aes$Companion_getInstance() {\n if (Aes$Companion_instance === null) {\n new Aes$Companion();\n }return Aes$Companion_instance;\n }\n Aes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Aes',\n interfaces: [TypedKey]\n };\n function Aesthetics() {\n }\n Aesthetics.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Aesthetics',\n interfaces: []\n };\n function ContinuousTransform() {\n }\n ContinuousTransform.prototype.createApplicableDomain_yrwdxb$ = function (middle, callback$default) {\n if (middle === void 0)\n middle = null;\n return callback$default ? callback$default(middle) : this.createApplicableDomain_yrwdxb$$default(middle);\n };\n ContinuousTransform.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ContinuousTransform',\n interfaces: [Transform]\n };\n function CoordinateSystem() {\n }\n CoordinateSystem.prototype.isPointInLimits_k2qmv6$ = function (p, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(p, isClient) : this.isPointInLimits_k2qmv6$$default(p, isClient);\n };\n CoordinateSystem.prototype.isRectInLimits_fd842m$ = function (rect, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(rect, isClient) : this.isRectInLimits_fd842m$$default(rect, isClient);\n };\n CoordinateSystem.prototype.isPathInLimits_f6t8kh$ = function (path, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(path, isClient) : this.isPathInLimits_f6t8kh$$default(path, isClient);\n };\n CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = function (polygon, isClient, callback$default) {\n if (isClient === void 0)\n isClient = true;\n return callback$default ? callback$default(polygon, isClient) : this.isPolygonInLimits_f6t8kh$$default(polygon, isClient);\n };\n CoordinateSystem.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CoordinateSystem',\n interfaces: []\n };\n function DataFrame(builder) {\n DataFrame$Companion_getInstance();\n this.myVectorByVar_0 = null;\n this.myIsNumeric_0 = null;\n this.myRanges_0 = HashMap_init();\n this.myDistinctValues_0 = HashMap_init();\n this.myOrderSpecs_0 = null;\n this.assertAllSeriesAreSameSize_0(builder.myVectorByVar_8be2vx$);\n this.myVectorByVar_0 = HashMap_init_0(builder.myVectorByVar_8be2vx$);\n this.myIsNumeric_0 = HashMap_init_0(builder.myIsNumeric_8be2vx$);\n this.myOrderSpecs_0 = builder.myOrderSpecs_8be2vx$;\n var tmp$;\n tmp$ = this.myOrderSpecs_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var $receiver = this.myDistinctValues_0;\n var key = element.variable;\n var value = this.getOrderedDistinctValues_0(element);\n $receiver.put_xwzc9p$(key, value);\n }\n }\n function DataFrame$OrderSpec(variable, orderBy, direction, aggregateOperation) {\n if (aggregateOperation === void 0)\n aggregateOperation = null;\n this.variable = variable;\n this.orderBy = orderBy;\n this.direction = direction;\n this.aggregateOperation = aggregateOperation;\n }\n DataFrame$OrderSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderSpec',\n interfaces: []\n };\n Object.defineProperty(DataFrame.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myVectorByVar_0.isEmpty();\n }\n });\n DataFrame.prototype.assertAllSeriesAreSameSize_0 = function (vectorByVar) {\n if (vectorByVar.size > 1) {\n var entries = vectorByVar.entries.iterator();\n var first = entries.next();\n var size = first.value.size;\n while (entries.hasNext()) {\n var next = entries.next();\n if (next.value.size !== size) {\n throw IllegalArgumentException_init('All data series in data frame must have equal size\\n' + this.dumpSizes_0(vectorByVar));\n }}\n }};\n DataFrame.prototype.dumpSizes_0 = function (vectorByVar) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = vectorByVar.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var key = tmp$_0.key;\n var value = tmp$_0.value;\n sb.append_pdl1vj$(key.name).append_pdl1vj$(' : ').append_s8jyv4$(value.size).append_s8itvh$(10);\n }\n return sb.toString();\n };\n DataFrame.prototype.rowCount = function () {\n return this.myVectorByVar_0.isEmpty() ? 0 : this.myVectorByVar_0.entries.iterator().next().value.size;\n };\n DataFrame.prototype.has_8xm3sj$ = function (variable) {\n return this.myVectorByVar_0.containsKey_11rb$(variable);\n };\n DataFrame.prototype.isEmpty_8xm3sj$ = function (variable) {\n return this.get_8xm3sj$(variable).isEmpty();\n };\n DataFrame.prototype.hasNoOrEmpty_8xm3sj$ = function (variable) {\n return !this.has_8xm3sj$(variable) || this.isEmpty_8xm3sj$(variable);\n };\n DataFrame.prototype.get_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n return ensureNotNull(this.myVectorByVar_0.get_11rb$(variable));\n };\n DataFrame.prototype.getNumeric_8xm3sj$ = function (variable) {\n var tmp$;\n this.assertDefined_0(variable);\n var list = this.myVectorByVar_0.get_11rb$(variable);\n if (ensureNotNull(list).isEmpty()) {\n return emptyList();\n }this.assertNumeric_0(variable);\n return Kotlin.isType(tmp$ = list, List) ? tmp$ : throwCCE();\n };\n DataFrame.prototype.distinctValues_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n var tmp$;\n var value = this.myDistinctValues_0.get_11rb$(variable);\n if (value == null) {\n var tmp$_0;\n var $receiver = LinkedHashSet_init(this.get_8xm3sj$(variable));\n $receiver.remove_11rb$(null);\n var values = $receiver;\n return Kotlin.isType(tmp$_0 = values, Collection) ? tmp$_0 : throwCCE();\n } else {\n tmp$ = value;\n }\n return tmp$;\n };\n DataFrame.prototype.variables = function () {\n return this.myVectorByVar_0.keys;\n };\n DataFrame.prototype.isNumeric_8xm3sj$ = function (variable) {\n this.assertDefined_0(variable);\n if (!this.myIsNumeric_0.containsKey_11rb$(variable)) {\n var checkedDoubles = data.SeriesUtil.checkedDoubles_9ma18$(this.get_8xm3sj$(variable));\n var $receiver = this.myIsNumeric_0;\n var value = checkedDoubles.notEmptyAndCanBeCast();\n $receiver.put_xwzc9p$(variable, value);\n }return ensureNotNull(this.myIsNumeric_0.get_11rb$(variable));\n };\n DataFrame.prototype.range_8xm3sj$ = function (variable) {\n if (!this.myRanges_0.containsKey_11rb$(variable)) {\n var v = this.getNumeric_8xm3sj$(variable);\n var r = data.SeriesUtil.range_l63ks6$(v);\n this.myRanges_0.put_xwzc9p$(variable, r);\n }return this.myRanges_0.get_11rb$(variable);\n };\n DataFrame.prototype.builder = function () {\n return DataFrame$DataFrame$Builder_init_0(this);\n };\n function DataFrame$assertDefined$lambda(closure$e) {\n return function () {\n return ensureNotNull(closure$e.message);\n };\n }\n DataFrame.prototype.assertDefined_0 = function (variable) {\n if (!this.has_8xm3sj$(variable)) {\n var e = IllegalArgumentException_init(\"Undefined variable: '\" + variable + \"'\");\n DataFrame$Companion_getInstance().LOG_0.error_l35kib$(e, DataFrame$assertDefined$lambda(e));\n throw e;\n }};\n function DataFrame$assertNumeric$lambda(closure$e) {\n return function () {\n return ensureNotNull(closure$e.message);\n };\n }\n DataFrame.prototype.assertNumeric_0 = function (variable) {\n if (!this.isNumeric_8xm3sj$(variable)) {\n var e = IllegalArgumentException_init(\"Not a numeric variable: '\" + variable + \"'\");\n DataFrame$Companion_getInstance().LOG_0.error_l35kib$(e, DataFrame$assertNumeric$lambda(e));\n throw e;\n }};\n function DataFrame$selectIndices$lambda(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.pickAtIndices_ge51dg$(serie, closure$indices);\n };\n }\n DataFrame.prototype.selectIndices_pqoyrt$ = function (indices) {\n return this.buildModified_0(DataFrame$selectIndices$lambda(indices));\n };\n function DataFrame$selectIndices$lambda_0(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.pickAtIndices_jlfzfq$(serie, closure$indices);\n };\n }\n DataFrame.prototype.selectIndices_p1n9e9$ = function (indices) {\n return this.buildModified_0(DataFrame$selectIndices$lambda_0(indices));\n };\n function DataFrame$dropIndices$lambda(closure$indices) {\n return function (serie) {\n return data.SeriesUtil.skipAtIndices_jlfzfq$(serie, closure$indices);\n };\n }\n DataFrame.prototype.dropIndices_p1n9e9$ = function (indices) {\n return indices.isEmpty() ? this : this.buildModified_0(DataFrame$dropIndices$lambda(indices));\n };\n DataFrame.prototype.buildModified_0 = function (serieFun) {\n var tmp$;\n var builder = this.builder();\n tmp$ = this.myVectorByVar_0.keys.iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n var serie = this.myVectorByVar_0.get_11rb$(variable);\n var modifiedSerie = serieFun(ensureNotNull(serie));\n builder.putIntern_bxyhp4$(variable, modifiedSerie);\n }\n return builder.build();\n };\n function DataFrame$Variable(name, source, label) {\n DataFrame$Variable$Companion_getInstance();\n if (source === void 0)\n source = DataFrame$Variable$Source$ORIGIN_getInstance();\n if (label === void 0)\n label = name;\n this.name = name;\n this.source = source;\n this.label = label;\n }\n Object.defineProperty(DataFrame$Variable.prototype, 'isOrigin', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$ORIGIN_getInstance();\n }\n });\n Object.defineProperty(DataFrame$Variable.prototype, 'isStat', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$STAT_getInstance();\n }\n });\n Object.defineProperty(DataFrame$Variable.prototype, 'isTransform', {\n configurable: true,\n get: function () {\n return this.source === DataFrame$Variable$Source$TRANSFORM_getInstance();\n }\n });\n DataFrame$Variable.prototype.toString = function () {\n return this.name;\n };\n DataFrame$Variable.prototype.toSummaryString = function () {\n return this.name + \", '\" + this.label + \"' [\" + this.source + ']';\n };\n function DataFrame$Variable$Source(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DataFrame$Variable$Source_initFields() {\n DataFrame$Variable$Source_initFields = function () {\n };\n DataFrame$Variable$Source$ORIGIN_instance = new DataFrame$Variable$Source('ORIGIN', 0);\n DataFrame$Variable$Source$TRANSFORM_instance = new DataFrame$Variable$Source('TRANSFORM', 1);\n DataFrame$Variable$Source$STAT_instance = new DataFrame$Variable$Source('STAT', 2);\n }\n var DataFrame$Variable$Source$ORIGIN_instance;\n function DataFrame$Variable$Source$ORIGIN_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$ORIGIN_instance;\n }\n var DataFrame$Variable$Source$TRANSFORM_instance;\n function DataFrame$Variable$Source$TRANSFORM_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$TRANSFORM_instance;\n }\n var DataFrame$Variable$Source$STAT_instance;\n function DataFrame$Variable$Source$STAT_getInstance() {\n DataFrame$Variable$Source_initFields();\n return DataFrame$Variable$Source$STAT_instance;\n }\n DataFrame$Variable$Source.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Source',\n interfaces: [Enum]\n };\n function DataFrame$Variable$Source$values() {\n return [DataFrame$Variable$Source$ORIGIN_getInstance(), DataFrame$Variable$Source$TRANSFORM_getInstance(), DataFrame$Variable$Source$STAT_getInstance()];\n }\n DataFrame$Variable$Source.values = DataFrame$Variable$Source$values;\n function DataFrame$Variable$Source$valueOf(name) {\n switch (name) {\n case 'ORIGIN':\n return DataFrame$Variable$Source$ORIGIN_getInstance();\n case 'TRANSFORM':\n return DataFrame$Variable$Source$TRANSFORM_getInstance();\n case 'STAT':\n return DataFrame$Variable$Source$STAT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.DataFrame.Variable.Source.' + name);\n }\n }\n DataFrame$Variable$Source.valueOf_61zpoe$ = DataFrame$Variable$Source$valueOf;\n function DataFrame$Variable$Companion() {\n DataFrame$Variable$Companion_instance = this;\n }\n DataFrame$Variable$Companion.prototype.createOriginal_puj7f4$ = function (name, label) {\n if (label === void 0)\n label = name;\n return new DataFrame$Variable(name, DataFrame$Variable$Source$ORIGIN_getInstance(), label);\n };\n DataFrame$Variable$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Variable$Companion_instance = null;\n function DataFrame$Variable$Companion_getInstance() {\n if (DataFrame$Variable$Companion_instance === null) {\n new DataFrame$Variable$Companion();\n }return DataFrame$Variable$Companion_instance;\n }\n DataFrame$Variable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Variable',\n interfaces: []\n };\n function DataFrame$getOrderedDistinctValues$isValueComparable(value) {\n return value != null && (!(typeof value === 'number') || isFinite(value));\n }\n function DataFrame$getOrderedDistinctValues$lambda(it) {\n var tmp$;\n return Kotlin.isComparable(tmp$ = it.second) ? tmp$ : throwCCE();\n }\n function DataFrame$getOrderedDistinctValues$lambda_0(it) {\n var tmp$;\n return Kotlin.isComparable(tmp$ = it.first) ? tmp$ : throwCCE();\n }\n DataFrame.prototype.getOrderedDistinctValues_0 = function (orderSpec) {\n var tmp$, tmp$_0;\n var isValueComparable = DataFrame$getOrderedDistinctValues$isValueComparable;\n if (orderSpec.aggregateOperation != null) {\n if (!this.isNumeric_8xm3sj$(orderSpec.orderBy)) {\n var message = \"Can't apply aggregate operation to non-numeric values\";\n throw IllegalArgumentException_init(message.toString());\n }var $receiver = zip(this.get_8xm3sj$(orderSpec.variable), this.getNumeric_8xm3sj$(orderSpec.orderBy));\n var destination = LinkedHashMap_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n var value = element.component1();\n var key = value;\n var tmp$_0_0;\n var value_0 = destination.get_11rb$(key);\n if (value_0 == null) {\n var answer = ArrayList_init();\n destination.put_xwzc9p$(key, answer);\n tmp$_0_0 = answer;\n } else {\n tmp$_0_0 = value_0;\n }\n var list = tmp$_0_0;\n var tmp$_2 = list.add_11rb$;\n var byValue = element.component2();\n tmp$_2.call(list, byValue);\n }\n var destination_0 = LinkedHashMap_init_0(mapCapacity(destination.size));\n var tmp$_3;\n tmp$_3 = destination.entries.iterator();\n while (tmp$_3.hasNext()) {\n var element_0 = tmp$_3.next();\n var tmp$_4 = destination_0.put_xwzc9p$;\n var tmp$_5 = element_0.key;\n var byValues = element_0.value;\n var tmp$_6 = orderSpec.aggregateOperation;\n var destination_1 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = byValues.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (isValueComparable(element_1))\n destination_1.add_11rb$(element_1);\n }\n tmp$_4.call(destination_0, tmp$_5, tmp$_6.call(orderSpec, destination_1));\n }\n tmp$ = toList(destination_0);\n } else {\n tmp$ = zip(this.get_8xm3sj$(orderSpec.variable), this.get_8xm3sj$(orderSpec.orderBy));\n }\n var $receiver_0 = tmp$;\n var destination_2 = ArrayList_init();\n var tmp$_8;\n tmp$_8 = $receiver_0.iterator();\n while (tmp$_8.hasNext()) {\n var element_2 = tmp$_8.next();\n if (isValueComparable(element_2.second) && isValueComparable(element_2.first))\n destination_2.add_11rb$(element_2);\n }\n var $receiver_1 = sortedWith(destination_2, compareBy([DataFrame$getOrderedDistinctValues$lambda, DataFrame$getOrderedDistinctValues$lambda_0]));\n var destination_3 = ArrayList_init();\n var tmp$_9;\n tmp$_9 = $receiver_1.iterator();\n while (tmp$_9.hasNext()) {\n var element_3 = tmp$_9.next();\n var tmp$_0_1;\n if ((tmp$_0_1 = element_3.first) != null) {\n destination_3.add_11rb$(tmp$_0_1);\n }}\n var orderedValues = destination_3;\n var $receiver_2 = zip(this.get_8xm3sj$(orderSpec.variable), this.get_8xm3sj$(orderSpec.orderBy));\n var destination_4 = ArrayList_init();\n var tmp$_10;\n tmp$_10 = $receiver_2.iterator();\n while (tmp$_10.hasNext()) {\n var element_4 = tmp$_10.next();\n if (!isValueComparable(element_4.second))\n destination_4.add_11rb$(element_4);\n }\n var destination_5 = ArrayList_init();\n var tmp$_11;\n tmp$_11 = destination_4.iterator();\n while (tmp$_11.hasNext()) {\n var element_5 = tmp$_11.next();\n var tmp$_0_2;\n if ((tmp$_0_2 = element_5.first) != null) {\n destination_5.add_11rb$(tmp$_0_2);\n }}\n var nonComparableAppendix = destination_5;\n if (orderSpec.direction < 0) {\n tmp$_0 = reversed(orderedValues);\n } else {\n tmp$_0 = orderedValues;\n }\n return toSet(plus(tmp$_0, nonComparableAppendix));\n };\n function DataFrame$Companion() {\n DataFrame$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(DataFrame));\n }\n DataFrame$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Companion_instance = null;\n function DataFrame$Companion_getInstance() {\n if (DataFrame$Companion_instance === null) {\n new DataFrame$Companion();\n }return DataFrame$Companion_instance;\n }\n function DataFrame$Builder() {\n DataFrame$Builder$Companion_getInstance();\n this.myVectorByVar_8be2vx$ = HashMap_init();\n this.myIsNumeric_8be2vx$ = HashMap_init();\n this.myOrderSpecs_8be2vx$ = ArrayList_init();\n }\n DataFrame$Builder.prototype.put_2l962d$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.remove_11rb$(variable);\n return this;\n };\n DataFrame$Builder.prototype.putNumeric_s1rqo9$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.put_xwzc9p$(variable, true);\n return this;\n };\n DataFrame$Builder.prototype.putDiscrete_2l962d$ = function (variable, v) {\n this.putIntern_bxyhp4$(variable, v);\n this.myIsNumeric_8be2vx$.put_xwzc9p$(variable, false);\n return this;\n };\n DataFrame$Builder.prototype.putIntern_bxyhp4$ = function (variable, v) {\n var $receiver = this.myVectorByVar_8be2vx$;\n var value = ArrayList_init_0(v);\n $receiver.put_xwzc9p$(variable, value);\n };\n DataFrame$Builder.prototype.remove_8xm3sj$ = function (variable) {\n this.myVectorByVar_8be2vx$.remove_11rb$(variable);\n this.myIsNumeric_8be2vx$.remove_11rb$(variable);\n return this;\n };\n DataFrame$Builder.prototype.addOrderSpecs_l2t0xf$ = function (orderSpecs) {\n var action = getCallableRef('addOrderSpec', function ($receiver, p1) {\n return $receiver.addOrderSpec_22dbp4$(p1);\n }.bind(null, this));\n var tmp$;\n tmp$ = orderSpecs.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n action(element);\n }\n return this;\n };\n DataFrame$Builder.prototype.addOrderSpec_22dbp4$ = function (orderSpec) {\n var $receiver = this.myOrderSpecs_8be2vx$;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (equals(element.variable, orderSpec.variable)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var currentOrderSpec = firstOrNull$result;\n if ((currentOrderSpec != null ? currentOrderSpec.aggregateOperation : null) == null) {\n var $receiver_0 = this.myOrderSpecs_8be2vx$;\n var tmp$_0;\n (Kotlin.isType(tmp$_0 = $receiver_0, MutableCollection) ? tmp$_0 : throwCCE()).remove_11rb$(currentOrderSpec);\n this.myOrderSpecs_8be2vx$.add_11rb$(orderSpec);\n }return this;\n };\n DataFrame$Builder.prototype.build = function () {\n return new DataFrame(this);\n };\n function DataFrame$Builder$Companion() {\n DataFrame$Builder$Companion_instance = this;\n }\n DataFrame$Builder$Companion.prototype.emptyFrame = function () {\n return DataFrame$DataFrame$Builder_init().build();\n };\n DataFrame$Builder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DataFrame$Builder$Companion_instance = null;\n function DataFrame$Builder$Companion_getInstance() {\n if (DataFrame$Builder$Companion_instance === null) {\n new DataFrame$Builder$Companion();\n }return DataFrame$Builder$Companion_instance;\n }\n DataFrame$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n function DataFrame$DataFrame$Builder_init($this) {\n $this = $this || Object.create(DataFrame$Builder.prototype);\n DataFrame$Builder.call($this);\n return $this;\n }\n function DataFrame$DataFrame$Builder_init_0(data, $this) {\n $this = $this || Object.create(DataFrame$Builder.prototype);\n DataFrame$Builder.call($this);\n $this.myVectorByVar_8be2vx$.putAll_a2k3zr$(data.myVectorByVar_0);\n $this.myIsNumeric_8be2vx$.putAll_a2k3zr$(data.myIsNumeric_0);\n $this.myOrderSpecs_8be2vx$.addAll_brywnq$(data.myOrderSpecs_0);\n return $this;\n }\n DataFrame.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataFrame',\n interfaces: []\n };\n function DataPointAesthetics() {\n }\n DataPointAesthetics.prototype.defined_896ixz$ = function (aes) {\n var tmp$;\n if (aes.isNumeric) {\n var number = this.get_31786j$(aes);\n return number != null && isFinite(typeof (tmp$ = number) === 'number' ? tmp$ : throwCCE());\n }return true;\n };\n DataPointAesthetics.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'DataPointAesthetics',\n interfaces: []\n };\n function DiscreteTransform(domainValues, domainLimits) {\n this.domainValues = domainValues;\n this.domainLimits = domainLimits;\n this.numberByDomainValue_0 = LinkedHashMap_init();\n this.domainValueByNumber_0 = new TreeMap();\n var tmp$, tmp$_0;\n if (this.domainLimits.isEmpty()) {\n tmp$ = this.domainValues;\n } else {\n tmp$ = intersect(this.domainLimits, this.domainValues);\n }\n var effectiveDomain = tmp$;\n this.numberByDomainValue_0.putAll_a2k3zr$(MapperUtil_getInstance().mapDiscreteDomainValuesToNumbers_7f6uoc$(effectiveDomain));\n tmp$_0 = this.numberByDomainValue_0.entries.iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_1 = tmp$_0.next();\n var domainValue = tmp$_1.key;\n var number = tmp$_1.value;\n this.domainValueByNumber_0.put_ncwa5f$(number, domainValue);\n }\n }\n DiscreteTransform.prototype.hasDomainLimits = function () {\n return !this.domainLimits.isEmpty();\n };\n DiscreteTransform.prototype.isInDomain_s8jyv4$ = function (v) {\n var $receiver = this.numberByDomainValue_0;\n var tmp$;\n return (Kotlin.isType(tmp$ = $receiver, Map) ? tmp$ : throwCCE()).containsKey_11rb$(v);\n };\n DiscreteTransform.prototype.apply_9ma18$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.asNumber_0(item));\n }\n return destination;\n };\n DiscreteTransform.prototype.applyInverse_yrwdxb$ = function (v) {\n return this.fromNumber_0(v);\n };\n DiscreteTransform.prototype.asNumber_0 = function (input) {\n if (input == null) {\n return null;\n }if (this.numberByDomainValue_0.containsKey_11rb$(input)) {\n return this.numberByDomainValue_0.get_11rb$(input);\n }throw IllegalStateException_init('value ' + toString(input) + ' is not in the domain: ' + this.numberByDomainValue_0.keys);\n };\n DiscreteTransform.prototype.fromNumber_0 = function (v) {\n var tmp$;\n if (v == null) {\n return null;\n }if (this.domainValueByNumber_0.containsKey_mef7kx$(v)) {\n return this.domainValueByNumber_0.get_mef7kx$(v);\n }var ceilingKey = this.domainValueByNumber_0.ceilingKey_mef7kx$(v);\n var floorKey = this.domainValueByNumber_0.floorKey_mef7kx$(v);\n var keyNumber = null;\n if (ceilingKey != null || floorKey != null) {\n if (ceilingKey == null)\n tmp$ = floorKey;\n else if (floorKey == null)\n tmp$ = ceilingKey;\n else {\n var x = ceilingKey - v;\n var ceilingDist = JsMath.abs(x);\n var x_0 = floorKey - v;\n var floorDist = JsMath.abs(x_0);\n tmp$ = ceilingDist < floorDist ? ceilingKey : floorKey;\n }\n keyNumber = tmp$;\n }return keyNumber != null ? this.domainValueByNumber_0.get_mef7kx$(keyNumber) : null;\n };\n DiscreteTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteTransform',\n interfaces: [Transform]\n };\n function Geom() {\n }\n Geom.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Geom',\n interfaces: []\n };\n function GeomContext() {\n }\n GeomContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomContext',\n interfaces: []\n };\n function GeomKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomKind_initFields() {\n GeomKind_initFields = function () {\n };\n GeomKind$PATH_instance = new GeomKind('PATH', 0);\n GeomKind$LINE_instance = new GeomKind('LINE', 1);\n GeomKind$SMOOTH_instance = new GeomKind('SMOOTH', 2);\n GeomKind$BAR_instance = new GeomKind('BAR', 3);\n GeomKind$HISTOGRAM_instance = new GeomKind('HISTOGRAM', 4);\n GeomKind$TILE_instance = new GeomKind('TILE', 5);\n GeomKind$BIN_2D_instance = new GeomKind('BIN_2D', 6);\n GeomKind$MAP_instance = new GeomKind('MAP', 7);\n GeomKind$ERROR_BAR_instance = new GeomKind('ERROR_BAR', 8);\n GeomKind$CROSS_BAR_instance = new GeomKind('CROSS_BAR', 9);\n GeomKind$LINE_RANGE_instance = new GeomKind('LINE_RANGE', 10);\n GeomKind$POINT_RANGE_instance = new GeomKind('POINT_RANGE', 11);\n GeomKind$POLYGON_instance = new GeomKind('POLYGON', 12);\n GeomKind$AB_LINE_instance = new GeomKind('AB_LINE', 13);\n GeomKind$H_LINE_instance = new GeomKind('H_LINE', 14);\n GeomKind$V_LINE_instance = new GeomKind('V_LINE', 15);\n GeomKind$BOX_PLOT_instance = new GeomKind('BOX_PLOT', 16);\n GeomKind$LIVE_MAP_instance = new GeomKind('LIVE_MAP', 17);\n GeomKind$POINT_instance = new GeomKind('POINT', 18);\n GeomKind$RIBBON_instance = new GeomKind('RIBBON', 19);\n GeomKind$AREA_instance = new GeomKind('AREA', 20);\n GeomKind$DENSITY_instance = new GeomKind('DENSITY', 21);\n GeomKind$CONTOUR_instance = new GeomKind('CONTOUR', 22);\n GeomKind$CONTOURF_instance = new GeomKind('CONTOURF', 23);\n GeomKind$DENSITY2D_instance = new GeomKind('DENSITY2D', 24);\n GeomKind$DENSITY2DF_instance = new GeomKind('DENSITY2DF', 25);\n GeomKind$JITTER_instance = new GeomKind('JITTER', 26);\n GeomKind$FREQPOLY_instance = new GeomKind('FREQPOLY', 27);\n GeomKind$STEP_instance = new GeomKind('STEP', 28);\n GeomKind$RECT_instance = new GeomKind('RECT', 29);\n GeomKind$SEGMENT_instance = new GeomKind('SEGMENT', 30);\n GeomKind$TEXT_instance = new GeomKind('TEXT', 31);\n GeomKind$RASTER_instance = new GeomKind('RASTER', 32);\n GeomKind$IMAGE_instance = new GeomKind('IMAGE', 33);\n }\n var GeomKind$PATH_instance;\n function GeomKind$PATH_getInstance() {\n GeomKind_initFields();\n return GeomKind$PATH_instance;\n }\n var GeomKind$LINE_instance;\n function GeomKind$LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$LINE_instance;\n }\n var GeomKind$SMOOTH_instance;\n function GeomKind$SMOOTH_getInstance() {\n GeomKind_initFields();\n return GeomKind$SMOOTH_instance;\n }\n var GeomKind$BAR_instance;\n function GeomKind$BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$BAR_instance;\n }\n var GeomKind$HISTOGRAM_instance;\n function GeomKind$HISTOGRAM_getInstance() {\n GeomKind_initFields();\n return GeomKind$HISTOGRAM_instance;\n }\n var GeomKind$TILE_instance;\n function GeomKind$TILE_getInstance() {\n GeomKind_initFields();\n return GeomKind$TILE_instance;\n }\n var GeomKind$BIN_2D_instance;\n function GeomKind$BIN_2D_getInstance() {\n GeomKind_initFields();\n return GeomKind$BIN_2D_instance;\n }\n var GeomKind$MAP_instance;\n function GeomKind$MAP_getInstance() {\n GeomKind_initFields();\n return GeomKind$MAP_instance;\n }\n var GeomKind$ERROR_BAR_instance;\n function GeomKind$ERROR_BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$ERROR_BAR_instance;\n }\n var GeomKind$CROSS_BAR_instance;\n function GeomKind$CROSS_BAR_getInstance() {\n GeomKind_initFields();\n return GeomKind$CROSS_BAR_instance;\n }\n var GeomKind$LINE_RANGE_instance;\n function GeomKind$LINE_RANGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$LINE_RANGE_instance;\n }\n var GeomKind$POINT_RANGE_instance;\n function GeomKind$POINT_RANGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$POINT_RANGE_instance;\n }\n var GeomKind$POLYGON_instance;\n function GeomKind$POLYGON_getInstance() {\n GeomKind_initFields();\n return GeomKind$POLYGON_instance;\n }\n var GeomKind$AB_LINE_instance;\n function GeomKind$AB_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$AB_LINE_instance;\n }\n var GeomKind$H_LINE_instance;\n function GeomKind$H_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$H_LINE_instance;\n }\n var GeomKind$V_LINE_instance;\n function GeomKind$V_LINE_getInstance() {\n GeomKind_initFields();\n return GeomKind$V_LINE_instance;\n }\n var GeomKind$BOX_PLOT_instance;\n function GeomKind$BOX_PLOT_getInstance() {\n GeomKind_initFields();\n return GeomKind$BOX_PLOT_instance;\n }\n var GeomKind$LIVE_MAP_instance;\n function GeomKind$LIVE_MAP_getInstance() {\n GeomKind_initFields();\n return GeomKind$LIVE_MAP_instance;\n }\n var GeomKind$POINT_instance;\n function GeomKind$POINT_getInstance() {\n GeomKind_initFields();\n return GeomKind$POINT_instance;\n }\n var GeomKind$RIBBON_instance;\n function GeomKind$RIBBON_getInstance() {\n GeomKind_initFields();\n return GeomKind$RIBBON_instance;\n }\n var GeomKind$AREA_instance;\n function GeomKind$AREA_getInstance() {\n GeomKind_initFields();\n return GeomKind$AREA_instance;\n }\n var GeomKind$DENSITY_instance;\n function GeomKind$DENSITY_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY_instance;\n }\n var GeomKind$CONTOUR_instance;\n function GeomKind$CONTOUR_getInstance() {\n GeomKind_initFields();\n return GeomKind$CONTOUR_instance;\n }\n var GeomKind$CONTOURF_instance;\n function GeomKind$CONTOURF_getInstance() {\n GeomKind_initFields();\n return GeomKind$CONTOURF_instance;\n }\n var GeomKind$DENSITY2D_instance;\n function GeomKind$DENSITY2D_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY2D_instance;\n }\n var GeomKind$DENSITY2DF_instance;\n function GeomKind$DENSITY2DF_getInstance() {\n GeomKind_initFields();\n return GeomKind$DENSITY2DF_instance;\n }\n var GeomKind$JITTER_instance;\n function GeomKind$JITTER_getInstance() {\n GeomKind_initFields();\n return GeomKind$JITTER_instance;\n }\n var GeomKind$FREQPOLY_instance;\n function GeomKind$FREQPOLY_getInstance() {\n GeomKind_initFields();\n return GeomKind$FREQPOLY_instance;\n }\n var GeomKind$STEP_instance;\n function GeomKind$STEP_getInstance() {\n GeomKind_initFields();\n return GeomKind$STEP_instance;\n }\n var GeomKind$RECT_instance;\n function GeomKind$RECT_getInstance() {\n GeomKind_initFields();\n return GeomKind$RECT_instance;\n }\n var GeomKind$SEGMENT_instance;\n function GeomKind$SEGMENT_getInstance() {\n GeomKind_initFields();\n return GeomKind$SEGMENT_instance;\n }\n var GeomKind$TEXT_instance;\n function GeomKind$TEXT_getInstance() {\n GeomKind_initFields();\n return GeomKind$TEXT_instance;\n }\n var GeomKind$RASTER_instance;\n function GeomKind$RASTER_getInstance() {\n GeomKind_initFields();\n return GeomKind$RASTER_instance;\n }\n var GeomKind$IMAGE_instance;\n function GeomKind$IMAGE_getInstance() {\n GeomKind_initFields();\n return GeomKind$IMAGE_instance;\n }\n GeomKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomKind',\n interfaces: [Enum]\n };\n function GeomKind$values() {\n return [GeomKind$PATH_getInstance(), GeomKind$LINE_getInstance(), GeomKind$SMOOTH_getInstance(), GeomKind$BAR_getInstance(), GeomKind$HISTOGRAM_getInstance(), GeomKind$TILE_getInstance(), GeomKind$BIN_2D_getInstance(), GeomKind$MAP_getInstance(), GeomKind$ERROR_BAR_getInstance(), GeomKind$CROSS_BAR_getInstance(), GeomKind$LINE_RANGE_getInstance(), GeomKind$POINT_RANGE_getInstance(), GeomKind$POLYGON_getInstance(), GeomKind$AB_LINE_getInstance(), GeomKind$H_LINE_getInstance(), GeomKind$V_LINE_getInstance(), GeomKind$BOX_PLOT_getInstance(), GeomKind$LIVE_MAP_getInstance(), GeomKind$POINT_getInstance(), GeomKind$RIBBON_getInstance(), GeomKind$AREA_getInstance(), GeomKind$DENSITY_getInstance(), GeomKind$CONTOUR_getInstance(), GeomKind$CONTOURF_getInstance(), GeomKind$DENSITY2D_getInstance(), GeomKind$DENSITY2DF_getInstance(), GeomKind$JITTER_getInstance(), GeomKind$FREQPOLY_getInstance(), GeomKind$STEP_getInstance(), GeomKind$RECT_getInstance(), GeomKind$SEGMENT_getInstance(), GeomKind$TEXT_getInstance(), GeomKind$RASTER_getInstance(), GeomKind$IMAGE_getInstance()];\n }\n GeomKind.values = GeomKind$values;\n function GeomKind$valueOf(name) {\n switch (name) {\n case 'PATH':\n return GeomKind$PATH_getInstance();\n case 'LINE':\n return GeomKind$LINE_getInstance();\n case 'SMOOTH':\n return GeomKind$SMOOTH_getInstance();\n case 'BAR':\n return GeomKind$BAR_getInstance();\n case 'HISTOGRAM':\n return GeomKind$HISTOGRAM_getInstance();\n case 'TILE':\n return GeomKind$TILE_getInstance();\n case 'BIN_2D':\n return GeomKind$BIN_2D_getInstance();\n case 'MAP':\n return GeomKind$MAP_getInstance();\n case 'ERROR_BAR':\n return GeomKind$ERROR_BAR_getInstance();\n case 'CROSS_BAR':\n return GeomKind$CROSS_BAR_getInstance();\n case 'LINE_RANGE':\n return GeomKind$LINE_RANGE_getInstance();\n case 'POINT_RANGE':\n return GeomKind$POINT_RANGE_getInstance();\n case 'POLYGON':\n return GeomKind$POLYGON_getInstance();\n case 'AB_LINE':\n return GeomKind$AB_LINE_getInstance();\n case 'H_LINE':\n return GeomKind$H_LINE_getInstance();\n case 'V_LINE':\n return GeomKind$V_LINE_getInstance();\n case 'BOX_PLOT':\n return GeomKind$BOX_PLOT_getInstance();\n case 'LIVE_MAP':\n return GeomKind$LIVE_MAP_getInstance();\n case 'POINT':\n return GeomKind$POINT_getInstance();\n case 'RIBBON':\n return GeomKind$RIBBON_getInstance();\n case 'AREA':\n return GeomKind$AREA_getInstance();\n case 'DENSITY':\n return GeomKind$DENSITY_getInstance();\n case 'CONTOUR':\n return GeomKind$CONTOUR_getInstance();\n case 'CONTOURF':\n return GeomKind$CONTOURF_getInstance();\n case 'DENSITY2D':\n return GeomKind$DENSITY2D_getInstance();\n case 'DENSITY2DF':\n return GeomKind$DENSITY2DF_getInstance();\n case 'JITTER':\n return GeomKind$JITTER_getInstance();\n case 'FREQPOLY':\n return GeomKind$FREQPOLY_getInstance();\n case 'STEP':\n return GeomKind$STEP_getInstance();\n case 'RECT':\n return GeomKind$RECT_getInstance();\n case 'SEGMENT':\n return GeomKind$SEGMENT_getInstance();\n case 'TEXT':\n return GeomKind$TEXT_getInstance();\n case 'RASTER':\n return GeomKind$RASTER_getInstance();\n case 'IMAGE':\n return GeomKind$IMAGE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.GeomKind.' + name);\n }\n }\n GeomKind.valueOf_61zpoe$ = GeomKind$valueOf;\n function GeomMeta() {\n GeomMeta_instance = this;\n this.renderedAesByGeom_0 = HashMap_init();\n this.POINT_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SHAPE]);\n this.PATH_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SPEED, Aes$Companion_getInstance().FLOW]);\n this.POLYGON_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n this.AREA_0 = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n }\n GeomMeta.prototype.renders_7dhqpi$ = function (geomKind) {\n if (!this.renderedAesByGeom_0.containsKey_11rb$(geomKind)) {\n var $receiver = this.renderedAesByGeom_0;\n var value = this.renderedAesList_0(geomKind);\n $receiver.put_xwzc9p$(geomKind, value);\n }return ensureNotNull(this.renderedAesByGeom_0.get_11rb$(geomKind));\n };\n GeomMeta.prototype.renderedAesList_0 = function (geomKind) {\n var tmp$;\n switch (geomKind.name) {\n case 'POINT':\n tmp$ = this.POINT_0;\n break;\n case 'PATH':\n tmp$ = this.PATH_0;\n break;\n case 'LINE':\n tmp$ = this.PATH_0;\n break;\n case 'SMOOTH':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n break;\n case 'HISTOGRAM':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n break;\n case 'TILE':\n case 'BIN_2D':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().HEIGHT, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'ERROR_BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'CROSS_BAR':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'LINE_RANGE':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'POINT_RANGE':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE]);\n break;\n case 'CONTOUR':\n tmp$ = this.PATH_0;\n break;\n case 'CONTOURF':\n tmp$ = this.POLYGON_0;\n break;\n case 'POLYGON':\n tmp$ = this.POLYGON_0;\n break;\n case 'MAP':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'AB_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().INTERCEPT, Aes$Companion_getInstance().SLOPE, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'H_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().YINTERCEPT, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'V_LINE':\n tmp$ = listOf([Aes$Companion_getInstance().XINTERCEPT, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'BOX_PLOT':\n tmp$ = listOf([Aes$Companion_getInstance().LOWER, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().UPPER, Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().WIDTH]);\n break;\n case 'RIBBON':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'AREA':\n tmp$ = this.AREA_0;\n break;\n case 'DENSITY':\n tmp$ = this.AREA_0;\n break;\n case 'DENSITY2D':\n tmp$ = this.PATH_0;\n break;\n case 'DENSITY2DF':\n tmp$ = this.POLYGON_0;\n break;\n case 'JITTER':\n tmp$ = this.POINT_0;\n break;\n case 'FREQPOLY':\n tmp$ = this.PATH_0;\n break;\n case 'STEP':\n tmp$ = this.PATH_0;\n break;\n case 'RECT':\n tmp$ = listOf([Aes$Companion_getInstance().XMIN, Aes$Companion_getInstance().XMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'SEGMENT':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().XEND, Aes$Companion_getInstance().YEND, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().LINETYPE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().SPEED, Aes$Companion_getInstance().FLOW]);\n break;\n case 'TEXT':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().LABEL, Aes$Companion_getInstance().FAMILY, Aes$Companion_getInstance().FONTFACE, Aes$Companion_getInstance().HJUST, Aes$Companion_getInstance().VJUST, Aes$Companion_getInstance().ANGLE]);\n break;\n case 'LIVE_MAP':\n tmp$ = listOf([Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().SIZE, Aes$Companion_getInstance().SHAPE, Aes$Companion_getInstance().FRAME, Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().SYM_X, Aes$Companion_getInstance().SYM_Y]);\n break;\n case 'RASTER':\n tmp$ = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().HEIGHT, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA]);\n break;\n case 'IMAGE':\n tmp$ = listOf([Aes$Companion_getInstance().XMIN, Aes$Companion_getInstance().XMAX, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX]);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n GeomMeta.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomMeta',\n interfaces: []\n };\n var GeomMeta_instance = null;\n function GeomMeta_getInstance() {\n if (GeomMeta_instance === null) {\n new GeomMeta();\n }return GeomMeta_instance;\n }\n function PositionAdjustment() {\n }\n Object.defineProperty(PositionAdjustment.prototype, 'isIdentity', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n PositionAdjustment.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PositionAdjustment',\n interfaces: []\n };\n function Scale() {\n }\n function Scale$Builder() {\n }\n Scale$Builder.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Builder',\n interfaces: []\n };\n Scale.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Scale',\n interfaces: []\n };\n function Stat() {\n }\n function Stat$apply$lambda(it) {\n return Unit;\n }\n Stat.prototype.apply_kdy6bf$ = function (data, statCtx, messageConsumer, callback$default) {\n if (messageConsumer === void 0)\n messageConsumer = Stat$apply$lambda;\n return callback$default ? callback$default(data, statCtx, messageConsumer) : this.apply_kdy6bf$$default(data, statCtx, messageConsumer);\n };\n Stat.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Stat',\n interfaces: []\n };\n function StatContext() {\n }\n StatContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'StatContext',\n interfaces: []\n };\n function Transform() {\n }\n Transform.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Transform',\n interfaces: []\n };\n function AesInitValue() {\n AesInitValue_instance = this;\n this.VALUE_MAP_0 = new TypedKeyHashMap();\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().X, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().Y, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().Z, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YMIN, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YMAX, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().COLOR, Color.Companion.PACIFIC_BLUE);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FILL, Color.Companion.PACIFIC_BLUE);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().ALPHA, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SHAPE, NamedShape$SOLID_CIRCLE_getInstance());\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LINETYPE, NamedLineType$SOLID_getInstance());\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SIZE, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().WIDTH, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().HEIGHT, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().WEIGHT, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().INTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SLOPE, 1.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XINTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YINTERCEPT, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LOWER, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().MIDDLE, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().UPPER, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FRAME, 'empty frame');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SPEED, 10.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FLOW, 0.1);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XMIN, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XMAX, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().XEND, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().YEND, kotlin_js_internal_DoubleCompanionObject.NaN);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().LABEL, '');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FAMILY, 'sans-serif');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().FONTFACE, 'plain');\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().HJUST, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().VJUST, 0.5);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().ANGLE, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SYM_X, 0.0);\n this.VALUE_MAP_0.set_ev6mlr$(Aes$Companion_getInstance().SYM_Y, 0.0);\n }\n AesInitValue.prototype.has_896ixz$ = function (aes) {\n return this.VALUE_MAP_0.containsKey_ex36zt$(aes);\n };\n AesInitValue.prototype.get_31786j$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n AesInitValue.prototype.get_ex36zt$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n AesInitValue.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AesInitValue',\n interfaces: []\n };\n var AesInitValue_instance = null;\n function AesInitValue_getInstance() {\n if (AesInitValue_instance === null) {\n new AesInitValue();\n }return AesInitValue_instance;\n }\n function AesScaling() {\n AesScaling_instance = this;\n this.UNIT_SHAPE_SIZE = 2.2;\n }\n AesScaling.prototype.strokeWidth_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2.0;\n };\n AesScaling.prototype.circleDiameter_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * this.UNIT_SHAPE_SIZE;\n };\n AesScaling.prototype.circleDiameterSmaller_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 1.5;\n };\n AesScaling.prototype.sizeFromCircleDiameter_14dthe$ = function (diameter) {\n return diameter / this.UNIT_SHAPE_SIZE;\n };\n AesScaling.prototype.textSize_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2;\n };\n AesScaling.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AesScaling',\n interfaces: []\n };\n var AesScaling_instance = null;\n function AesScaling_getInstance() {\n if (AesScaling_instance === null) {\n new AesScaling();\n }return AesScaling_instance;\n }\n function AesVisitor() {\n }\n AesVisitor.prototype.visit_896ixz$ = function (aes) {\n var tmp$, tmp$_0;\n if (aes.isNumeric) {\n tmp$_0 = this.visitNumeric_vktour$(Kotlin.isType(tmp$ = aes, Aes) ? tmp$ : throwCCE());\n } else\n tmp$_0 = this.visitIntern_rp5ogw$_0(aes);\n return tmp$_0;\n };\n AesVisitor.prototype.visitNumeric_vktour$ = function (aes) {\n return this.visitIntern_rp5ogw$_0(aes);\n };\n AesVisitor.prototype.visitIntern_rp5ogw$_0 = function (aes) {\n if (equals(aes, Aes$Companion_getInstance().X)) {\n return this.x();\n }if (equals(aes, Aes$Companion_getInstance().Y)) {\n return this.y();\n }if (equals(aes, Aes$Companion_getInstance().Z)) {\n return this.z();\n }if (equals(aes, Aes$Companion_getInstance().YMIN)) {\n return this.ymin();\n }if (equals(aes, Aes$Companion_getInstance().YMAX)) {\n return this.ymax();\n }if (equals(aes, Aes$Companion_getInstance().COLOR)) {\n return this.color();\n }if (equals(aes, Aes$Companion_getInstance().FILL)) {\n return this.fill();\n }if (equals(aes, Aes$Companion_getInstance().ALPHA)) {\n return this.alpha();\n }if (equals(aes, Aes$Companion_getInstance().SHAPE)) {\n return this.shape();\n }if (equals(aes, Aes$Companion_getInstance().SIZE)) {\n return this.size();\n }if (equals(aes, Aes$Companion_getInstance().LINETYPE)) {\n return this.lineType();\n }if (equals(aes, Aes$Companion_getInstance().WIDTH)) {\n return this.width();\n }if (equals(aes, Aes$Companion_getInstance().HEIGHT)) {\n return this.height();\n }if (equals(aes, Aes$Companion_getInstance().WEIGHT)) {\n return this.weight();\n }if (equals(aes, Aes$Companion_getInstance().INTERCEPT)) {\n return this.intercept();\n }if (equals(aes, Aes$Companion_getInstance().SLOPE)) {\n return this.slope();\n }if (equals(aes, Aes$Companion_getInstance().XINTERCEPT)) {\n return this.interceptX();\n }if (equals(aes, Aes$Companion_getInstance().YINTERCEPT)) {\n return this.interceptY();\n }if (equals(aes, Aes$Companion_getInstance().LOWER)) {\n return this.lower();\n }if (equals(aes, Aes$Companion_getInstance().MIDDLE)) {\n return this.middle();\n }if (equals(aes, Aes$Companion_getInstance().UPPER)) {\n return this.upper();\n }if (equals(aes, Aes$Companion_getInstance().FRAME)) {\n return this.frame();\n }if (equals(aes, Aes$Companion_getInstance().SPEED)) {\n return this.speed();\n }if (equals(aes, Aes$Companion_getInstance().FLOW)) {\n return this.flow();\n }if (equals(aes, Aes$Companion_getInstance().XMIN)) {\n return this.xmin();\n }if (equals(aes, Aes$Companion_getInstance().XMAX)) {\n return this.xmax();\n }if (equals(aes, Aes$Companion_getInstance().XEND)) {\n return this.xend();\n }if (equals(aes, Aes$Companion_getInstance().YEND)) {\n return this.yend();\n }if (equals(aes, Aes$Companion_getInstance().LABEL)) {\n return this.label();\n }if (equals(aes, Aes$Companion_getInstance().FAMILY)) {\n return this.family();\n }if (equals(aes, Aes$Companion_getInstance().FONTFACE)) {\n return this.fontface();\n }if (equals(aes, Aes$Companion_getInstance().HJUST)) {\n return this.hjust();\n }if (equals(aes, Aes$Companion_getInstance().VJUST)) {\n return this.vjust();\n }if (equals(aes, Aes$Companion_getInstance().ANGLE)) {\n return this.angle();\n }if (equals(aes, Aes$Companion_getInstance().SYM_X)) {\n return this.symX();\n }if (equals(aes, Aes$Companion_getInstance().SYM_Y)) {\n return this.symY();\n }throw IllegalArgumentException_init('Unexpected aes: ' + aes);\n };\n AesVisitor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AesVisitor',\n interfaces: []\n };\n function AestheticsBuilder(myDataPointCount) {\n AestheticsBuilder$Companion_getInstance();\n if (myDataPointCount === void 0)\n myDataPointCount = 0;\n this.myDataPointCount_0 = myDataPointCount;\n this.myIndexFunctionMap_0 = null;\n this.myGroup_0 = AestheticsBuilder$Companion_getInstance().constant_mh5how$(0);\n this.myConstantAes_0 = collect.Sets.newHashSet_yl67zr$(Aes$Companion_getInstance().values());\n this.myOverallRangeByNumericAes_0 = HashMap_init();\n var tmp$;\n this.myIndexFunctionMap_0 = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var $receiver = this.myIndexFunctionMap_0;\n var value = AestheticsBuilder$Companion_getInstance().constant_mh5how$(AesInitValue_getInstance().get_31786j$(aes));\n $receiver.put_xwzc9p$(aes, value);\n }\n }\n AestheticsBuilder.prototype.dataPointCount_za3lpa$ = function (v) {\n this.myDataPointCount_0 = v;\n return this;\n };\n AestheticsBuilder.prototype.overallRange_xlyz3f$ = function (aes, range) {\n this.myOverallRangeByNumericAes_0.put_xwzc9p$(aes, range);\n return this;\n };\n AestheticsBuilder.prototype.x_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().X, v);\n };\n AestheticsBuilder.prototype.y_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().Y, v);\n };\n AestheticsBuilder.prototype.color_u2gvuj$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().COLOR, v);\n };\n AestheticsBuilder.prototype.fill_u2gvuj$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FILL, v);\n };\n AestheticsBuilder.prototype.alpha_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().ALPHA, v);\n };\n AestheticsBuilder.prototype.shape_9kzkiq$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SHAPE, v);\n };\n AestheticsBuilder.prototype.lineType_vv264d$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().LINETYPE, v);\n };\n AestheticsBuilder.prototype.size_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SIZE, v);\n };\n AestheticsBuilder.prototype.width_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().WIDTH, v);\n };\n AestheticsBuilder.prototype.weight_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().WEIGHT, v);\n };\n AestheticsBuilder.prototype.frame_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FRAME, v);\n };\n AestheticsBuilder.prototype.speed_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SPEED, v);\n };\n AestheticsBuilder.prototype.flow_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FLOW, v);\n };\n AestheticsBuilder.prototype.group_ddsh32$ = function (v) {\n this.myGroup_0 = v;\n return this;\n };\n AestheticsBuilder.prototype.label_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().LABEL, v);\n };\n AestheticsBuilder.prototype.family_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FAMILY, v);\n };\n AestheticsBuilder.prototype.fontface_cfki2p$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().FONTFACE, v);\n };\n AestheticsBuilder.prototype.hjust_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().HJUST, v);\n };\n AestheticsBuilder.prototype.vjust_bfjv6s$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().VJUST, v);\n };\n AestheticsBuilder.prototype.angle_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().ANGLE, v);\n };\n AestheticsBuilder.prototype.xmin_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().XMIN, v);\n };\n AestheticsBuilder.prototype.xmax_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().XMAX, v);\n };\n AestheticsBuilder.prototype.ymin_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().YMIN, v);\n };\n AestheticsBuilder.prototype.ymax_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().YMAX, v);\n };\n AestheticsBuilder.prototype.symX_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SYM_X, v);\n };\n AestheticsBuilder.prototype.symY_jmvnpd$ = function (v) {\n return this.aes_u42xfl$(Aes$Companion_getInstance().SYM_Y, v);\n };\n AestheticsBuilder.prototype.constantAes_bbdhip$ = function (aes, v) {\n this.myConstantAes_0.add_11rb$(aes);\n var $receiver = this.myIndexFunctionMap_0;\n var value = AestheticsBuilder$Companion_getInstance().constant_mh5how$(v);\n $receiver.put_xwzc9p$(aes, value);\n return this;\n };\n AestheticsBuilder.prototype.aes_u42xfl$ = function (aes, v) {\n this.myConstantAes_0.remove_11rb$(aes);\n this.myIndexFunctionMap_0.put_xwzc9p$(aes, v);\n return this;\n };\n AestheticsBuilder.prototype.build = function () {\n return new AestheticsBuilder$MyAesthetics(this);\n };\n function AestheticsBuilder$MyAesthetics(b) {\n this.myDataPointCount_0 = b.myDataPointCount_0;\n this.myIndexFunctionMap_0 = new TypedIndexFunctionMap(b.myIndexFunctionMap_0);\n this.group = b.myGroup_0;\n this.myConstantAes_0 = null;\n this.myOverallRangeByNumericAes_0 = null;\n this.myResolutionByAes_0 = HashMap_init();\n this.myRangeByNumericAes_0 = HashMap_init();\n this.myConstantAes_0 = HashSet_init(b.myConstantAes_0);\n this.myOverallRangeByNumericAes_0 = HashMap_init_0(b.myOverallRangeByNumericAes_0);\n }\n Object.defineProperty(AestheticsBuilder$MyAesthetics.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myDataPointCount_0 === 0;\n }\n });\n AestheticsBuilder$MyAesthetics.prototype.aes_31786j$ = function (aes) {\n return this.myIndexFunctionMap_0.get_31786j$(aes);\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPointAt_za3lpa$ = function (index) {\n return new AestheticsBuilder$MyDataPointAesthetics(index, this);\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPointCount = function () {\n return this.myDataPointCount_0;\n };\n function AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral(this$MyAesthetics, closure$self) {\n this.this$MyAesthetics = this$MyAesthetics;\n this.closure$self = closure$self;\n }\n AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$MyDataPointsIterator(this.this$MyAesthetics.myDataPointCount_0, this.closure$self);\n };\n AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.dataPoints = function () {\n var self_0 = this;\n return new AestheticsBuilder$MyAesthetics$dataPoints$ObjectLiteral(this, self_0);\n };\n AestheticsBuilder$MyAesthetics.prototype.range_vktour$ = function (aes) {\n var tmp$;\n if (!this.myRangeByNumericAes_0.containsKey_11rb$(aes)) {\n if (this.myDataPointCount_0 <= 0)\n tmp$ = new ClosedRange(0.0, 0.0);\n else if (this.myConstantAes_0.contains_11rb$(aes)) {\n var v = ensureNotNull(this.numericValues_vktour$(aes).iterator().next());\n if (isFinite(v)) {\n tmp$ = new ClosedRange(v, v);\n } else\n tmp$ = null;\n } else {\n var values = this.numericValues_vktour$(aes);\n tmp$ = data.SeriesUtil.range_l63ks6$(values);\n }\n var r = tmp$;\n this.myRangeByNumericAes_0.put_xwzc9p$(aes, r);\n }return this.myRangeByNumericAes_0.get_11rb$(aes);\n };\n AestheticsBuilder$MyAesthetics.prototype.overallRange_vktour$ = function (aes) {\n var tmp$;\n var tmp$_0;\n if ((tmp$ = this.myOverallRangeByNumericAes_0.get_11rb$(aes)) != null)\n tmp$_0 = tmp$;\n else {\n throw IllegalStateException_init(('Overall range is unknown for ' + aes).toString());\n }\n return tmp$_0;\n };\n AestheticsBuilder$MyAesthetics.prototype.resolution_594811$ = function (aes, naValue) {\n var tmp$;\n if (!this.myResolutionByAes_0.containsKey_11rb$(aes)) {\n if (this.myConstantAes_0.contains_11rb$(aes))\n tmp$ = 0.0;\n else {\n var values = this.numericValues_vktour$(aes);\n tmp$ = data.SeriesUtil.resolution_u62iiw$(values, naValue);\n }\n var resolution = tmp$;\n this.myResolutionByAes_0.put_xwzc9p$(aes, resolution);\n }return ensureNotNull(this.myResolutionByAes_0.get_11rb$(aes));\n };\n function AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral(this$MyAesthetics, closure$aes) {\n this.this$MyAesthetics = this$MyAesthetics;\n this.closure$aes = closure$aes;\n }\n AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$AesIterator(this.this$MyAesthetics.myDataPointCount_0, this.this$MyAesthetics.aes_31786j$(this.closure$aes));\n };\n AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.numericValues_vktour$ = function (aes) {\n if (!aes.isNumeric) {\n var message = 'Numeric aes is expected: ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }return new AestheticsBuilder$MyAesthetics$numericValues$ObjectLiteral(this, aes);\n };\n function AestheticsBuilder$MyAesthetics$groups$ObjectLiteral(this$MyAesthetics) {\n this.this$MyAesthetics = this$MyAesthetics;\n }\n AestheticsBuilder$MyAesthetics$groups$ObjectLiteral.prototype.iterator = function () {\n return new AestheticsBuilder$AesIterator(this.this$MyAesthetics.myDataPointCount_0, this.this$MyAesthetics.group);\n };\n AestheticsBuilder$MyAesthetics$groups$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Iterable]\n };\n AestheticsBuilder$MyAesthetics.prototype.groups = function () {\n return new AestheticsBuilder$MyAesthetics$groups$ObjectLiteral(this);\n };\n AestheticsBuilder$MyAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyAesthetics',\n interfaces: [Aesthetics]\n };\n function AestheticsBuilder$MyDataPointsIterator(myLength, myAesthetics) {\n this.myLength_0 = myLength;\n this.myAesthetics_0 = myAesthetics;\n this.myIndex_0 = 0;\n }\n AestheticsBuilder$MyDataPointsIterator.prototype.hasNext = function () {\n return this.myIndex_0 < this.myLength_0;\n };\n AestheticsBuilder$MyDataPointsIterator.prototype.next = function () {\n var tmp$;\n if (this.hasNext()) {\n return this.myAesthetics_0.dataPointAt_za3lpa$((tmp$ = this.myIndex_0, this.myIndex_0 = tmp$ + 1 | 0, tmp$));\n }throw new NoSuchElementException('index=' + this.myIndex_0);\n };\n AestheticsBuilder$MyDataPointsIterator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyDataPointsIterator',\n interfaces: [Iterator]\n };\n function AestheticsBuilder$AesIterator(myLength, myAes) {\n this.myLength_0 = myLength;\n this.myAes_0 = myAes;\n this.myIndex_0 = 0;\n }\n AestheticsBuilder$AesIterator.prototype.hasNext = function () {\n return this.myIndex_0 < this.myLength_0;\n };\n AestheticsBuilder$AesIterator.prototype.next = function () {\n var tmp$;\n if (this.hasNext()) {\n return this.myAes_0((tmp$ = this.myIndex_0, this.myIndex_0 = tmp$ + 1 | 0, tmp$));\n }throw new NoSuchElementException('index=' + this.myIndex_0);\n };\n AestheticsBuilder$AesIterator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AesIterator',\n interfaces: [Iterator]\n };\n function AestheticsBuilder$MyDataPointAesthetics(myIndex, myAesthetics) {\n this.myIndex_0 = myIndex;\n this.myAesthetics_0 = myAesthetics;\n }\n AestheticsBuilder$MyDataPointAesthetics.prototype.index = function () {\n return ensureNotNull(this.myIndex_0);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.x = function () {\n return this.get_31786j$(Aes$Companion_getInstance().X);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.y = function () {\n return this.get_31786j$(Aes$Companion_getInstance().Y);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.z = function () {\n return this.get_31786j$(Aes$Companion_getInstance().Z);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.ymin = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YMIN);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.ymax = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YMAX);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.color = function () {\n return this.get_31786j$(Aes$Companion_getInstance().COLOR);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.fill = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FILL);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.alpha = function () {\n return this.get_31786j$(Aes$Companion_getInstance().ALPHA);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.shape = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SHAPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.lineType = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LINETYPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.size = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SIZE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.width = function () {\n return this.get_31786j$(Aes$Companion_getInstance().WIDTH);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.height = function () {\n return this.get_31786j$(Aes$Companion_getInstance().HEIGHT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.weight = function () {\n return this.get_31786j$(Aes$Companion_getInstance().WEIGHT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.intercept = function () {\n return this.get_31786j$(Aes$Companion_getInstance().INTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.slope = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SLOPE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.interceptX = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XINTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.interceptY = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YINTERCEPT);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.lower = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LOWER);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.middle = function () {\n return this.get_31786j$(Aes$Companion_getInstance().MIDDLE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.upper = function () {\n return this.get_31786j$(Aes$Companion_getInstance().UPPER);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.frame = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FRAME);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.speed = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SPEED);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.flow = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FLOW);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xmin = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XMIN);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xmax = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XMAX);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.xend = function () {\n return this.get_31786j$(Aes$Companion_getInstance().XEND);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.yend = function () {\n return this.get_31786j$(Aes$Companion_getInstance().YEND);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.label = function () {\n return this.get_31786j$(Aes$Companion_getInstance().LABEL);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.family = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FAMILY);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.fontface = function () {\n return this.get_31786j$(Aes$Companion_getInstance().FONTFACE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.hjust = function () {\n return this.get_31786j$(Aes$Companion_getInstance().HJUST);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.vjust = function () {\n return this.get_31786j$(Aes$Companion_getInstance().VJUST);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.angle = function () {\n return this.get_31786j$(Aes$Companion_getInstance().ANGLE);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.symX = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SYM_X);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.symY = function () {\n return this.get_31786j$(Aes$Companion_getInstance().SYM_Y);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.group = function () {\n return this.myAesthetics_0.group(ensureNotNull(this.myIndex_0));\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.numeric_vktour$ = function (aes) {\n return this.get_31786j$(aes);\n };\n AestheticsBuilder$MyDataPointAesthetics.prototype.get_31786j$ = function (aes) {\n return this.myAesthetics_0.aes_31786j$(aes)(ensureNotNull(this.myIndex_0));\n };\n AestheticsBuilder$MyDataPointAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyDataPointAesthetics',\n interfaces: [DataPointAesthetics]\n };\n function AestheticsBuilder$ArrayAes(myVal) {\n this.myVal_0 = myVal;\n }\n AestheticsBuilder$ArrayAes.prototype.apply_11rb$ = function (value) {\n return this.myVal_0[value];\n };\n AestheticsBuilder$ArrayAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ArrayAes',\n interfaces: [Function]\n };\n function AestheticsBuilder$MapperAes(myL, myF) {\n this.myL_0 = myL;\n this.myF_0 = myF;\n }\n AestheticsBuilder$MapperAes.prototype.apply_11rb$ = function (value) {\n return this.myF_0(this.myL_0.get_za3lpa$(value));\n };\n AestheticsBuilder$MapperAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapperAes',\n interfaces: [Function]\n };\n function AestheticsBuilder$Companion() {\n AestheticsBuilder$Companion_instance = this;\n }\n function AestheticsBuilder$Companion$constant$lambda(closure$v) {\n return function (it) {\n return closure$v;\n };\n }\n AestheticsBuilder$Companion.prototype.constant_mh5how$ = function (v) {\n return AestheticsBuilder$Companion$constant$lambda(v);\n };\n function AestheticsBuilder$Companion$array$lambda(closure$v) {\n return function (value) {\n return closure$v[value];\n };\n }\n AestheticsBuilder$Companion.prototype.array_ro6dgy$ = function (v) {\n return AestheticsBuilder$Companion$array$lambda(v);\n };\n function AestheticsBuilder$Companion$collection$lambda(closure$v) {\n return function (value) {\n return collect.Iterables.get_7iig3d$(closure$v, value);\n };\n }\n AestheticsBuilder$Companion.prototype.collection_mqih57$ = function (v) {\n return AestheticsBuilder$Companion$collection$lambda(v);\n };\n function AestheticsBuilder$Companion$listMapper$lambda(closure$f, closure$v) {\n return function (value) {\n return closure$f(closure$v.get_za3lpa$(value));\n };\n }\n AestheticsBuilder$Companion.prototype.listMapper_sedzz5$ = function (v, f) {\n return AestheticsBuilder$Companion$listMapper$lambda(f, v);\n };\n AestheticsBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AestheticsBuilder$Companion_instance = null;\n function AestheticsBuilder$Companion_getInstance() {\n if (AestheticsBuilder$Companion_instance === null) {\n new AestheticsBuilder$Companion();\n }return AestheticsBuilder$Companion_instance;\n }\n AestheticsBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AestheticsBuilder',\n interfaces: []\n };\n function AestheticsDefaults() {\n AestheticsDefaults$Companion_getInstance();\n var $receiver = new TypedKeyHashMap();\n var tmp$, tmp$_0;\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n $receiver.put_ev6mlr$(Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE(), AesInitValue_getInstance().get_31786j$(aes));\n }\n this.myDefaults_vq25h0$_0 = $receiver;\n this.myDefaultsInLegend_yhkzvq$_0 = new TypedKeyHashMap();\n }\n AestheticsDefaults.prototype.update_bbdhip$ = function (aes, defaultValue) {\n this.myDefaults_vq25h0$_0.put_ev6mlr$(aes, defaultValue);\n return this;\n };\n AestheticsDefaults.prototype.updateInLegend_bbdhip$ = function (aes, defaultValue) {\n this.myDefaultsInLegend_yhkzvq$_0.put_ev6mlr$(aes, defaultValue);\n return this;\n };\n AestheticsDefaults.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return false;\n };\n AestheticsDefaults.prototype.defaultValue_31786j$ = function (aes) {\n return this.myDefaults_vq25h0$_0.get_ex36zt$(aes);\n };\n AestheticsDefaults.prototype.defaultValueInLegend_31786j$ = function (aes) {\n var tmp$;\n if (this.myDefaultsInLegend_yhkzvq$_0.containsKey_ex36zt$(aes)) {\n tmp$ = this.myDefaultsInLegend_yhkzvq$_0.get_ex36zt$(aes);\n } else\n tmp$ = this.defaultValue_31786j$(aes);\n return tmp$;\n };\n function AestheticsDefaults$Companion() {\n AestheticsDefaults$Companion_instance = this;\n }\n AestheticsDefaults$Companion.prototype.point = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 2.0).updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n };\n AestheticsDefaults$Companion.prototype.path = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.line = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.abline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.hline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.vline = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.smooth = function () {\n return this.path().update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.MAGENTA).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.BLACK);\n };\n function AestheticsDefaults$Companion$bar$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$bar$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$bar$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.bar = function () {\n return (new AestheticsDefaults$Companion$bar$ObjectLiteral()).update_bbdhip$(Aes$Companion_getInstance().WIDTH, 0.9).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n function AestheticsDefaults$Companion$histogram$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$histogram$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$histogram$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.histogram = function () {\n return (new AestheticsDefaults$Companion$histogram$ObjectLiteral()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.tile = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.bin2d = function () {\n return this.tile();\n };\n AestheticsDefaults$Companion.prototype.errorBar = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.BLACK);\n };\n AestheticsDefaults$Companion.prototype.crossBar = function () {\n return (new AestheticsDefaults()).update_bbdhip$(Aes$Companion_getInstance().WIDTH, 0.9).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.BLACK).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.WHITE);\n };\n AestheticsDefaults$Companion.prototype.lineRange = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.pointRange = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.polygon = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.map = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 0.2).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.GRAY).update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.boxplot = function () {\n return this.crossBar();\n };\n AestheticsDefaults$Companion.prototype.livemap_cx3y7u$ = function (displayMode) {\n var tmp$;\n switch (displayMode.name) {\n case 'POINT':\n tmp$ = this.point().updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n break;\n case 'BAR':\n tmp$ = this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 40.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT);\n break;\n case 'PIE':\n tmp$ = this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 20.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.TRANSPARENT).updateInLegend_bbdhip$(Aes$Companion_getInstance().SIZE, 5.0);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n AestheticsDefaults$Companion.prototype.ribbon = function () {\n return this.base_0();\n };\n function AestheticsDefaults$Companion$area$ObjectLiteral() {\n AestheticsDefaults.call(this);\n }\n AestheticsDefaults$Companion$area$ObjectLiteral.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return equals(aes, Aes$Companion_getInstance().Y) || AestheticsDefaults.prototype.rangeIncludesZero_896ixz$.call(this, aes);\n };\n AestheticsDefaults$Companion$area$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [AestheticsDefaults]\n };\n AestheticsDefaults$Companion.prototype.area = function () {\n return new AestheticsDefaults$Companion$area$ObjectLiteral();\n };\n AestheticsDefaults$Companion.prototype.density = function () {\n return this.area().update_bbdhip$(Aes$Companion_getInstance().FILL, Color.Companion.TRANSPARENT);\n };\n AestheticsDefaults$Companion.prototype.contour = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.contourf = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 0.0);\n };\n AestheticsDefaults$Companion.prototype.density2d = function () {\n return this.contour();\n };\n AestheticsDefaults$Companion.prototype.density2df = function () {\n return this.contourf();\n };\n AestheticsDefaults$Companion.prototype.jitter = function () {\n return this.point();\n };\n AestheticsDefaults$Companion.prototype.freqpoly = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.step = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.rect = function () {\n return this.polygon();\n };\n AestheticsDefaults$Companion.prototype.segment = function () {\n return this.path();\n };\n AestheticsDefaults$Companion.prototype.text = function () {\n return this.base_0().update_bbdhip$(Aes$Companion_getInstance().SIZE, 7.0).update_bbdhip$(Aes$Companion_getInstance().COLOR, Color.Companion.parseHex_61zpoe$('#3d3d3d'));\n };\n AestheticsDefaults$Companion.prototype.raster = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.image = function () {\n return this.base_0();\n };\n AestheticsDefaults$Companion.prototype.base_0 = function () {\n return new AestheticsDefaults();\n };\n AestheticsDefaults$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AestheticsDefaults$Companion_instance = null;\n function AestheticsDefaults$Companion_getInstance() {\n if (AestheticsDefaults$Companion_instance === null) {\n new AestheticsDefaults$Companion();\n }return AestheticsDefaults$Companion_instance;\n }\n AestheticsDefaults.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AestheticsDefaults',\n interfaces: []\n };\n function AestheticsUtil() {\n AestheticsUtil_instance = this;\n this.ALPHA_CONTROLS_BOTH_8be2vx$ = false;\n }\n AestheticsUtil.prototype.fill_edjgex$ = function (filled, solid, p) {\n if (filled) {\n return ensureNotNull(p.fill());\n } else if (solid) {\n return ensureNotNull(p.color());\n }return Color.Companion.TRANSPARENT;\n };\n AestheticsUtil.prototype.decorate_l4vgcq$ = function (shape, filled, solid, p, strokeWidth) {\n var fill = this.fill_edjgex$(filled, solid, p);\n var stroke = ensureNotNull(p.color());\n var fillAlpha = 0.0;\n if (filled || solid) {\n fillAlpha = this.alpha_il6rhx$(fill, p);\n }var strokeAlpha = 0.0;\n if (strokeWidth > 0) {\n strokeAlpha = this.alpha_il6rhx$(stroke, p);\n }shape.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n AestheticsUtil.prototype.alpha_il6rhx$ = function (color, p) {\n var tmp$;\n if (values.Colors.solid_98b62m$(color)) {\n tmp$ = ensureNotNull(p.alpha());\n } else\n tmp$ = svg.SvgUtils.alpha2opacity_za3lpa$(color.alpha);\n return tmp$;\n };\n AestheticsUtil.prototype.strokeWidth_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2.0;\n };\n AestheticsUtil.prototype.textSize_l6g9mh$ = function (p) {\n return ensureNotNull(p.size()) * 2;\n };\n AestheticsUtil.prototype.updateStroke_g0plfl$ = function (shape, p, applyAlpha) {\n shape.strokeColor().set_11rb$(p.color());\n if (values.Colors.solid_98b62m$(ensureNotNull(p.color())) && applyAlpha) {\n shape.strokeOpacity().set_11rb$(p.alpha());\n }};\n AestheticsUtil.prototype.updateFill_v4tjbc$ = function (shape, p) {\n shape.fillColor().set_11rb$(p.fill());\n if (values.Colors.solid_98b62m$(ensureNotNull(p.fill()))) {\n shape.fillOpacity().set_11rb$(p.alpha());\n }};\n AestheticsUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AestheticsUtil',\n interfaces: []\n };\n var AestheticsUtil_instance = null;\n function AestheticsUtil_getInstance() {\n if (AestheticsUtil_instance === null) {\n new AestheticsUtil();\n }return AestheticsUtil_instance;\n }\n function TypedIndexFunctionMap(indexFunctionMap) {\n this.myMap_0 = indexFunctionMap;\n }\n TypedIndexFunctionMap.prototype.get_31786j$ = function (aes) {\n var tmp$;\n return typeof (tmp$ = this.myMap_0.get_11rb$(aes)) === 'function' ? tmp$ : throwCCE();\n };\n TypedIndexFunctionMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedIndexFunctionMap',\n interfaces: []\n };\n function Coords() {\n Coords_instance = this;\n }\n Coords.prototype.create_wd6eaa$ = function (xRange, yRange, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n var origin = new DoubleVector(this.originX_0(xRange), this.originY_0(yRange));\n return this.create_e5yqp7$(origin, xLim, yLim);\n };\n Coords.prototype.create_e5yqp7$ = function (origin, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new DefaultCoordinateSystem(this.toClientOffsetX_0(origin.x), this.toClientOffsetY_0(origin.y), this.fromClientOffsetX_0(origin.x), this.fromClientOffsetY_0(origin.y), xLim, yLim);\n };\n Coords.prototype.toClientOffsetX_4fzjta$ = function (xRange) {\n return this.toClientOffsetX_0(this.originX_0(xRange));\n };\n Coords.prototype.toClientOffsetY_4fzjta$ = function (yRange) {\n return this.toClientOffsetY_0(this.originY_0(yRange));\n };\n Coords.prototype.originX_0 = function (xRange) {\n return -xRange.lowerEnd;\n };\n Coords.prototype.originY_0 = function (yRange) {\n return yRange.upperEnd;\n };\n function Coords$toClientOffsetX$lambda(closure$originX) {\n return function (x) {\n return closure$originX + x;\n };\n }\n Coords.prototype.toClientOffsetX_0 = function (originX) {\n return Coords$toClientOffsetX$lambda(originX);\n };\n function Coords$fromClientOffsetX$lambda(closure$originX) {\n return function (x) {\n return x - closure$originX;\n };\n }\n Coords.prototype.fromClientOffsetX_0 = function (originX) {\n return Coords$fromClientOffsetX$lambda(originX);\n };\n function Coords$toClientOffsetY$lambda(closure$originY) {\n return function (y) {\n return closure$originY - y;\n };\n }\n Coords.prototype.toClientOffsetY_0 = function (originY) {\n return Coords$toClientOffsetY$lambda(originY);\n };\n function Coords$fromClientOffsetY$lambda(closure$originY) {\n return function (y) {\n return closure$originY - y;\n };\n }\n Coords.prototype.fromClientOffsetY_0 = function (originY) {\n return Coords$fromClientOffsetY$lambda(originY);\n };\n Coords.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Coords',\n interfaces: []\n };\n var Coords_instance = null;\n function Coords_getInstance() {\n if (Coords_instance === null) {\n new Coords();\n }return Coords_instance;\n }\n function DefaultCoordinateSystem(myToClientOffsetX, myToClientOffsetY, myFromClientOffsetX, myFromClientOffsetY, xLim, yLim) {\n this.myToClientOffsetX_0 = myToClientOffsetX;\n this.myToClientOffsetY_0 = myToClientOffsetY;\n this.myFromClientOffsetX_0 = myFromClientOffsetX;\n this.myFromClientOffsetY_0 = myFromClientOffsetY;\n this.xLim_0 = xLim;\n this.yLim_0 = yLim;\n }\n DefaultCoordinateSystem.prototype.toClient_gpjtzr$ = function (p) {\n return new DoubleVector(this.myToClientOffsetX_0(p.x), this.myToClientOffsetY_0(p.y));\n };\n DefaultCoordinateSystem.prototype.fromClient_gpjtzr$ = function (p) {\n return new DoubleVector(this.myFromClientOffsetX_0(p.x), this.myFromClientOffsetY_0(p.y));\n };\n DefaultCoordinateSystem.prototype.isPointInLimits_k2qmv6$$default = function (p, isClient) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var coord = isClient ? this.fromClient_gpjtzr$(p) : p;\n return ((tmp$_0 = (tmp$ = this.xLim_0) != null ? tmp$.contains_mef7kx$(coord.x) : null) != null ? tmp$_0 : true) && ((tmp$_2 = (tmp$_1 = this.yLim_0) != null ? tmp$_1.contains_mef7kx$(coord.y) : null) != null ? tmp$_2 : true);\n };\n DefaultCoordinateSystem.prototype.isRectInLimits_fd842m$$default = function (rect, isClient) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var r = isClient ? (new GeomCoord(this)).fromClient_wthzt5$(rect) : rect;\n return ((tmp$_0 = (tmp$ = this.xLim_0) != null ? tmp$.encloses_d226ot$(r.xRange()) : null) != null ? tmp$_0 : true) && ((tmp$_2 = (tmp$_1 = this.yLim_0) != null ? tmp$_1.encloses_d226ot$(r.yRange()) : null) != null ? tmp$_2 : true);\n };\n DefaultCoordinateSystem.prototype.isPathInLimits_f6t8kh$$default = function (path, isClient) {\n var any$result;\n any$break: do {\n var tmp$;\n if (Kotlin.isType(path, Collection) && path.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$ = path.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.isPointInLimits_k2qmv6$(element, isClient)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n return any$result;\n };\n DefaultCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$$default = function (polygon, isClient) {\n var bbox = geometry.DoubleRectangles.boundingBox_qdtdbw$(polygon);\n return this.isRectInLimits_fd842m$(bbox, isClient);\n };\n Object.defineProperty(DefaultCoordinateSystem.prototype, 'xClientLimit', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.xLim_0) != null ? this.convertRange_0(tmp$, this.myToClientOffsetX_0) : null;\n }\n });\n Object.defineProperty(DefaultCoordinateSystem.prototype, 'yClientLimit', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.yLim_0) != null ? this.convertRange_0(tmp$, this.myToClientOffsetY_0) : null;\n }\n });\n DefaultCoordinateSystem.prototype.convertRange_0 = function (range, transform) {\n var l = transform(range.lowerEnd);\n var u = transform(range.upperEnd);\n return new ClosedRange(collect.Comparables.min_sdesaw$(l, u), collect.Comparables.max_sdesaw$(l, u));\n };\n DefaultCoordinateSystem.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultCoordinateSystem',\n interfaces: [CoordinateSystem]\n };\n function Projection() {\n }\n Projection.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Projection',\n interfaces: []\n };\n function DataFrameUtil() {\n DataFrameUtil_instance = this;\n }\n DataFrameUtil.prototype.transformVarFor_896ixz$ = function (aes) {\n return TransformVar_getInstance().forAes_896ixz$(aes);\n };\n DataFrameUtil.prototype.applyTransform_xaiv89$ = function (data, var_0, aes, scale) {\n var transformVar = this.transformVarFor_896ixz$(aes);\n return this.applyTransform_0(data, var_0, transformVar, scale);\n };\n DataFrameUtil.prototype.applyTransform_0 = function (data, variable, transformVar, scale) {\n var transformed = scale.applyTransform_yzw12z$(data.get_8xm3sj$(variable), true);\n return data.builder().putNumeric_s1rqo9$(transformVar, transformed).build();\n };\n DataFrameUtil.prototype.hasVariable_vede35$ = function (data, varName) {\n var tmp$;\n tmp$ = data.variables().iterator();\n while (tmp$.hasNext()) {\n var var_0 = tmp$.next();\n if (equals(varName, var_0.name)) {\n return true;\n }}\n return false;\n };\n DataFrameUtil.prototype.findVariableOrFail_vede35$ = function (data, varName) {\n var tmp$;\n tmp$ = data.variables().iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n if (equals(varName, variable.name)) {\n return variable;\n }}\n var tmp$_0 = \"Variable not found: '\" + varName + \"'. Variables in data frame: \";\n var $receiver = data.variables();\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination.add_11rb$(\"'\" + item.name + \"'\");\n }\n throw IllegalArgumentException_init(tmp$_0 + destination);\n };\n DataFrameUtil.prototype.isNumeric_vede35$ = function (data, varName) {\n return data.isNumeric_8xm3sj$(this.findVariableOrFail_vede35$(data, varName));\n };\n function DataFrameUtil$sortedCopy$lambda(o1, o2) {\n return Kotlin.compareTo(o1.name, o2.name);\n }\n DataFrameUtil.prototype.sortedCopy_jgbhqw$ = function (variables) {\n var ordering = Ordering.Companion.from_iajr8b$(new Comparator(DataFrameUtil$sortedCopy$lambda));\n return ordering.sortedCopy_m5x2f4$(variables);\n };\n DataFrameUtil.prototype.variables_dhhkv7$ = function (df) {\n var $receiver = df.variables();\n var keySelector = getPropertyCallableRef('name', 1, function ($receiver) {\n return $receiver.name;\n });\n var capacity = coerceAtLeast(mapCapacity(collectionSizeOrDefault($receiver, 10)), 16);\n var destination = LinkedHashMap_init_0(capacity);\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n destination.put_xwzc9p$(keySelector(element), element);\n }\n return destination;\n };\n function DataFrameUtil$appendReplace$put(this$DataFrameUtil) {\n return function ($receiver, destVars, df) {\n var this$DataFrameUtil_0 = this$DataFrameUtil;\n var tmp$;\n tmp$ = destVars.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n var srcVar = this$DataFrameUtil_0.findVariableOrFail_vede35$(df, element.name);\n tmp$_0 = df.isNumeric_8xm3sj$(srcVar);\n if (tmp$_0 === true)\n $receiver.putNumeric_s1rqo9$(element, df.getNumeric_8xm3sj$(srcVar));\n else if (tmp$_0 === false)\n $receiver.putDiscrete_2l962d$(element, df.get_8xm3sj$(srcVar));\n else\n Kotlin.noWhenBranchMatched();\n }\n return $receiver;\n };\n }\n DataFrameUtil.prototype.appendReplace_yxlle4$ = function (df0, df1) {\n var put = DataFrameUtil$appendReplace$put(this);\n var tmp$ = DataFrame$DataFrame$Builder_init();\n var $receiver = df0.variables();\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var $receiver_0 = this.variables_dhhkv7$(df1);\n var key = element.name;\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = $receiver_0, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(key))\n destination.add_11rb$(element);\n }\n var tmp$_2 = put(tmp$, destination, df0);\n var $receiver_1 = df0.variables();\n var destination_0 = ArrayList_init();\n var tmp$_3;\n tmp$_3 = $receiver_1.iterator();\n while (tmp$_3.hasNext()) {\n var element_0 = tmp$_3.next();\n var $receiver_2 = this.variables_dhhkv7$(df1);\n var key_0 = element_0.name;\n var tmp$_4;\n if ((Kotlin.isType(tmp$_4 = $receiver_2, Map) ? tmp$_4 : throwCCE()).containsKey_11rb$(key_0))\n destination_0.add_11rb$(element_0);\n }\n var tmp$_5 = put(tmp$_2, destination_0, df1);\n var $receiver_3 = df1.variables();\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = $receiver_3.iterator();\n while (tmp$_6.hasNext()) {\n var element_1 = tmp$_6.next();\n var $receiver_4 = this.variables_dhhkv7$(df0);\n var key_1 = element_1.name;\n var tmp$_7;\n if (!(Kotlin.isType(tmp$_7 = $receiver_4, Map) ? tmp$_7 : throwCCE()).containsKey_11rb$(key_1))\n destination_1.add_11rb$(element_1);\n }\n return put(tmp$_5, destination_1, df1).build();\n };\n DataFrameUtil.prototype.toMap_dhhkv7$ = function (df) {\n var tmp$;\n var result = HashMap_init();\n var variables = df.variables();\n tmp$ = variables.iterator();\n while (tmp$.hasNext()) {\n var var_0 = tmp$.next();\n var key = var_0.name;\n var value = df.get_8xm3sj$(var_0);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n DataFrameUtil.prototype.fromMap_bkhwtg$ = function (map) {\n var tmp$;\n var frameBuilder = DataFrame$DataFrame$Builder_init();\n tmp$ = map.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var key = tmp$_0.key;\n var value = tmp$_0.value;\n if (!(typeof key === 'string')) {\n var message = 'Map to data-frame: key expected a String but was ' + Kotlin.getKClassFromExpression(ensureNotNull(key)).simpleName + ' : ' + toString(key);\n throw IllegalArgumentException_init(message.toString());\n }if (!Kotlin.isType(value, List)) {\n var message_0 = 'Map to data-frame: value expected a List but was ' + Kotlin.getKClassFromExpression(ensureNotNull(value)).simpleName + ' : ' + toString(value);\n throw IllegalArgumentException_init(message_0.toString());\n }frameBuilder.put_2l962d$(this.createVariable_puj7f4$(key), value);\n }\n return frameBuilder.build();\n };\n DataFrameUtil.prototype.createVariable_puj7f4$ = function (name, label) {\n if (label === void 0)\n label = name;\n var tmp$;\n if (TransformVar_getInstance().isTransformVar_61zpoe$(name))\n tmp$ = TransformVar_getInstance().get_61zpoe$(name);\n else if (Stats_getInstance().isStatVar_61zpoe$(name))\n tmp$ = Stats_getInstance().statVar_61zpoe$(name);\n else if (Dummies_getInstance().isDummyVar_61zpoe$(name))\n tmp$ = Dummies_getInstance().newDummy_61zpoe$(name);\n else\n tmp$ = new DataFrame$Variable(name, DataFrame$Variable$Source$ORIGIN_getInstance(), label);\n return tmp$;\n };\n DataFrameUtil.prototype.getSummaryText_dhhkv7$ = function (df) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = df.variables().iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n sb.append_pdl1vj$(variable.toSummaryString()).append_pdl1vj$(' numeric: ' + toString(df.isNumeric_8xm3sj$(variable))).append_pdl1vj$(' size: ' + toString(df.get_8xm3sj$(variable).size)).append_s8itvh$(10);\n }\n return sb.toString();\n };\n DataFrameUtil.prototype.removeAllExcept_dipqvu$ = function (df, keepNames) {\n var tmp$;\n var b = df.builder();\n tmp$ = df.variables().iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n if (!keepNames.contains_11rb$(variable.name)) {\n b.remove_8xm3sj$(variable);\n }}\n return b.build();\n };\n DataFrameUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DataFrameUtil',\n interfaces: []\n };\n var DataFrameUtil_instance = null;\n function DataFrameUtil_getInstance() {\n if (DataFrameUtil_instance === null) {\n new DataFrameUtil();\n }return DataFrameUtil_instance;\n }\n function Dummies() {\n Dummies_instance = this;\n this.PREFIX_0 = '__';\n }\n Dummies.prototype.isDummyVar_61zpoe$ = function (varName) {\n if (!base.Strings.isNullOrEmpty_pdl1vj$(varName) && varName.length > 2 && startsWith(varName, this.PREFIX_0)) {\n var numStr = varName.substring(2);\n return Regex_init('[0-9]+').matches_6bul2c$(numStr);\n }return false;\n };\n Dummies.prototype.dummyNames_za3lpa$ = function (count) {\n var l = ArrayList_init();\n for (var i = 0; i < count; i++) {\n l.add_11rb$(this.PREFIX_0 + toString(i));\n }\n return l;\n };\n Dummies.prototype.newDummy_61zpoe$ = function (varName) {\n if (!this.isDummyVar_61zpoe$(varName)) {\n var message = 'Not a dummy var name';\n throw IllegalArgumentException_init(message.toString());\n }return new DataFrame$Variable(varName, DataFrame$Variable$Source$ORIGIN_getInstance(), '');\n };\n Dummies.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Dummies',\n interfaces: []\n };\n var Dummies_instance = null;\n function Dummies_getInstance() {\n if (Dummies_instance === null) {\n new Dummies();\n }return Dummies_instance;\n }\n function TransformVar() {\n TransformVar_instance = this;\n this.X = new DataFrame$Variable('transform.X', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.Y = new DataFrame$Variable('transform.Y', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.Z = new DataFrame$Variable('transform.Z', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YMIN = new DataFrame$Variable('transform.YMIN', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YMAX = new DataFrame$Variable('transform.YMAX', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.COLOR = new DataFrame$Variable('transform.COLOR', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FILL = new DataFrame$Variable('transform.FILL', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.ALPHA = new DataFrame$Variable('transform.ALPHA', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SHAPE = new DataFrame$Variable('transform.SHAPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LINETYPE = new DataFrame$Variable('transform.LINETYPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SIZE = new DataFrame$Variable('transform.SIZE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.WIDTH = new DataFrame$Variable('transform.WIDTH', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.HEIGHT = new DataFrame$Variable('transform.HEIGHT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.WEIGHT = new DataFrame$Variable('transform.WEIGHT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.INTERCEPT = new DataFrame$Variable('transform.INTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SLOPE = new DataFrame$Variable('transform.SLOPE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XINTERCEPT = new DataFrame$Variable('transform.XINTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YINTERCEPT = new DataFrame$Variable('transform.YINTERCEPT', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LOWER = new DataFrame$Variable('transform.LOWER', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.MIDDLE = new DataFrame$Variable('transform.MIDDLE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.UPPER = new DataFrame$Variable('transform.UPPER', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FRAME = new DataFrame$Variable('transform.FRAME', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SPEED = new DataFrame$Variable('transform.SPEED', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FLOW = new DataFrame$Variable('transform.FLOW', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XMIN = new DataFrame$Variable('transform.XMIN', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XMAX = new DataFrame$Variable('transform.XMAX', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.XEND = new DataFrame$Variable('transform.XEND', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.YEND = new DataFrame$Variable('transform.YEND', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.LABEL = new DataFrame$Variable('transform.LABEL', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FONT_FAMILY = new DataFrame$Variable('transform.FONT_FAMILY', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.FONT_FACE = new DataFrame$Variable('transform.FONT_FACE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.HJUST = new DataFrame$Variable('transform.HJUST', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.VJUST = new DataFrame$Variable('transform.VJUST', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.ANGLE = new DataFrame$Variable('transform.ANGLE', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SYM_X = new DataFrame$Variable('transform.SYM_X', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.SYM_Y = new DataFrame$Variable('transform.SYM_Y', DataFrame$Variable$Source$TRANSFORM_getInstance());\n this.VAR_BY_AES_0 = new TransformVar$TransformVarByAes();\n this.VARS_0 = null;\n var tmp$;\n var varByName = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var var_0 = this.VAR_BY_AES_0.visit_896ixz$(aes);\n var key = var_0.name;\n varByName.put_xwzc9p$(key, var_0);\n }\n this.VARS_0 = varByName;\n }\n TransformVar.prototype.isTransformVar_61zpoe$ = function (varName) {\n return this.VARS_0.containsKey_11rb$(varName);\n };\n TransformVar.prototype.get_61zpoe$ = function (varName) {\n if (!this.VARS_0.containsKey_11rb$(varName)) {\n var message = 'Unknown transform variable ' + varName;\n throw IllegalStateException_init(message.toString());\n }return ensureNotNull(this.VARS_0.get_11rb$(varName));\n };\n TransformVar.prototype.forAes_896ixz$ = function (aes) {\n return this.VAR_BY_AES_0.visit_896ixz$(aes);\n };\n function TransformVar$TransformVarByAes() {\n AesVisitor.call(this);\n }\n TransformVar$TransformVarByAes.prototype.x = function () {\n return TransformVar_getInstance().X;\n };\n TransformVar$TransformVarByAes.prototype.y = function () {\n return TransformVar_getInstance().Y;\n };\n TransformVar$TransformVarByAes.prototype.z = function () {\n return TransformVar_getInstance().Z;\n };\n TransformVar$TransformVarByAes.prototype.ymin = function () {\n return TransformVar_getInstance().YMIN;\n };\n TransformVar$TransformVarByAes.prototype.ymax = function () {\n return TransformVar_getInstance().YMAX;\n };\n TransformVar$TransformVarByAes.prototype.color = function () {\n return TransformVar_getInstance().COLOR;\n };\n TransformVar$TransformVarByAes.prototype.fill = function () {\n return TransformVar_getInstance().FILL;\n };\n TransformVar$TransformVarByAes.prototype.alpha = function () {\n return TransformVar_getInstance().ALPHA;\n };\n TransformVar$TransformVarByAes.prototype.shape = function () {\n return TransformVar_getInstance().SHAPE;\n };\n TransformVar$TransformVarByAes.prototype.lineType = function () {\n return TransformVar_getInstance().LINETYPE;\n };\n TransformVar$TransformVarByAes.prototype.size = function () {\n return TransformVar_getInstance().SIZE;\n };\n TransformVar$TransformVarByAes.prototype.width = function () {\n return TransformVar_getInstance().WIDTH;\n };\n TransformVar$TransformVarByAes.prototype.height = function () {\n return TransformVar_getInstance().HEIGHT;\n };\n TransformVar$TransformVarByAes.prototype.weight = function () {\n return TransformVar_getInstance().WEIGHT;\n };\n TransformVar$TransformVarByAes.prototype.intercept = function () {\n return TransformVar_getInstance().INTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.slope = function () {\n return TransformVar_getInstance().SLOPE;\n };\n TransformVar$TransformVarByAes.prototype.interceptX = function () {\n return TransformVar_getInstance().XINTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.interceptY = function () {\n return TransformVar_getInstance().YINTERCEPT;\n };\n TransformVar$TransformVarByAes.prototype.lower = function () {\n return TransformVar_getInstance().LOWER;\n };\n TransformVar$TransformVarByAes.prototype.middle = function () {\n return TransformVar_getInstance().MIDDLE;\n };\n TransformVar$TransformVarByAes.prototype.upper = function () {\n return TransformVar_getInstance().UPPER;\n };\n TransformVar$TransformVarByAes.prototype.frame = function () {\n return TransformVar_getInstance().FRAME;\n };\n TransformVar$TransformVarByAes.prototype.speed = function () {\n return TransformVar_getInstance().SPEED;\n };\n TransformVar$TransformVarByAes.prototype.flow = function () {\n return TransformVar_getInstance().FLOW;\n };\n TransformVar$TransformVarByAes.prototype.xmin = function () {\n return TransformVar_getInstance().XMIN;\n };\n TransformVar$TransformVarByAes.prototype.xmax = function () {\n return TransformVar_getInstance().XMAX;\n };\n TransformVar$TransformVarByAes.prototype.xend = function () {\n return TransformVar_getInstance().XEND;\n };\n TransformVar$TransformVarByAes.prototype.yend = function () {\n return TransformVar_getInstance().YEND;\n };\n TransformVar$TransformVarByAes.prototype.label = function () {\n return TransformVar_getInstance().LABEL;\n };\n TransformVar$TransformVarByAes.prototype.family = function () {\n return TransformVar_getInstance().FONT_FAMILY;\n };\n TransformVar$TransformVarByAes.prototype.fontface = function () {\n return TransformVar_getInstance().FONT_FACE;\n };\n TransformVar$TransformVarByAes.prototype.hjust = function () {\n return TransformVar_getInstance().HJUST;\n };\n TransformVar$TransformVarByAes.prototype.vjust = function () {\n return TransformVar_getInstance().VJUST;\n };\n TransformVar$TransformVarByAes.prototype.angle = function () {\n return TransformVar_getInstance().ANGLE;\n };\n TransformVar$TransformVarByAes.prototype.symX = function () {\n return TransformVar_getInstance().SYM_X;\n };\n TransformVar$TransformVarByAes.prototype.symY = function () {\n return TransformVar_getInstance().SYM_Y;\n };\n TransformVar$TransformVarByAes.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TransformVarByAes',\n interfaces: [AesVisitor]\n };\n TransformVar.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TransformVar',\n interfaces: []\n };\n var TransformVar_instance = null;\n function TransformVar_getInstance() {\n if (TransformVar_instance === null) {\n new TransformVar();\n }return TransformVar_instance;\n }\n function ABLineGeom() {\n ABLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(ABLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n ABLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$, tmp$_0;\n var helper = (new GeomHelper(pos, coord, ctx)).createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var boundaries = collect.Iterables.toList_yl67zr$(viewPort.parts);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.intercept();\n var slope = p.slope();\n if (data.SeriesUtil.allFinite_jma9l8$(intercept, slope)) {\n var p1 = new DoubleVector(viewPort.left, ensureNotNull(intercept) + viewPort.left * ensureNotNull(slope));\n var p2 = new DoubleVector(viewPort.right, p1.y + viewPort.dimension.x * slope);\n var s = new DoubleSegment(p1, p2);\n var lineEnds = HashSet_init_0(2);\n tmp$_0 = boundaries.iterator();\n while (tmp$_0.hasNext()) {\n var boundary = tmp$_0.next();\n var intersection = boundary.intersection_69p9e5$(s);\n if (intersection != null) {\n lineEnds.add_11rb$(intersection);\n if (lineEnds.size === 2) {\n break;\n }}}\n if (lineEnds.size === 2) {\n var it = lineEnds.iterator();\n var line = helper.createLine_ollnar$(it.next(), it.next(), p);\n lines.add_11rb$(line);\n }}}\n var tmp$_1;\n tmp$_1 = lines.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n root.add_26jijc$(element);\n }\n };\n function ABLineGeom$Companion() {\n ABLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ABLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ABLineGeom$Companion_instance = null;\n function ABLineGeom$Companion_getInstance() {\n if (ABLineGeom$Companion_instance === null) {\n new ABLineGeom$Companion();\n }return ABLineGeom$Companion_instance;\n }\n ABLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ABLineGeom',\n interfaces: [GeomBase]\n };\n function AreaGeom() {\n AreaGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n AreaGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().ordered_X_83glv4$(aesthetics.dataPoints());\n };\n AreaGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var paths = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y, GeomUtil_getInstance().TO_LOCATION_X_ZERO);\n reverse(paths);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(paths, root);\n helper.setAlphaEnabled_6taknv$(false);\n var lines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(lines, root);\n this.buildHints_69ip36$_0(aesthetics, pos, coord, ctx);\n };\n function AreaGeom$buildHints$lambda(closure$geomHelper, this$AreaGeom) {\n return function (p) {\n return this$AreaGeom.toClient_6nkesc$_0(closure$geomHelper, p);\n };\n }\n AreaGeom.prototype.buildHints_69ip36$_0 = function (aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var $receiver = this.dataPoints_m7huy5$(aesthetics);\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var x = element.x();\n var y = element.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && coord.isPointInLimits_k2qmv6$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), false))\n destination.add_11rb$(element);\n }\n var dataPoints = destination;\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(AreaGeom$buildHints$lambda(geomHelper, this)), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, false));\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n targetCollector.addPath_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, this.setupTooltipParams_l6g9mh$(multiPointData.aes));\n }\n };\n AreaGeom.prototype.setupTooltipParams_l6g9mh$ = function (aes) {\n return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromFill_l6g9mh$(aes));\n };\n AreaGeom.prototype.toClient_6nkesc$_0 = function (geomHelper, p) {\n var tmp$;\n var coord = GeomUtil_getInstance().TO_LOCATION_X_Y(p);\n if (coord != null) {\n tmp$ = geomHelper.toClient_tkjljq$(coord, p);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n function AreaGeom$Companion() {\n AreaGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n AreaGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AreaGeom$Companion_instance = null;\n function AreaGeom$Companion_getInstance() {\n if (AreaGeom$Companion_instance === null) {\n new AreaGeom$Companion();\n }return AreaGeom$Companion_instance;\n }\n AreaGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AreaGeom',\n interfaces: [GeomBase]\n };\n function BarGeom() {\n BarGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n function BarGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromFill_l6g9mh$(it);\n }\n BarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var rectangles = helper.createRectangles_rezc4r$(BarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n reverse(rectangles);\n var tmp$;\n tmp$ = rectangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n root.add_26jijc$(element);\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(emptyList(), aesthetics, pos, coord, ctx, BarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), BarGeom$buildIntern$lambda);\n };\n function BarGeom$Companion() {\n BarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function BarGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n var x = p.x();\n var y = p.y();\n var w = p.width();\n return !data.SeriesUtil.allFinite_xjrefz$(x, y, w) ? null : GeomUtil_getInstance().rectangleByDataPoint_dyn5n6$(p, closure$ctx);\n };\n }\n BarGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return BarGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n BarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BarGeom$Companion_instance = null;\n function BarGeom$Companion_getInstance() {\n if (BarGeom$Companion_instance === null) {\n new BarGeom$Companion();\n }return BarGeom$Companion_instance;\n }\n BarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BarGeom',\n interfaces: [GeomBase]\n };\n function Bin2dGeom() {\n Bin2dGeom$Companion_getInstance();\n TileGeom.call(this);\n }\n function Bin2dGeom$Companion() {\n Bin2dGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n Bin2dGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Bin2dGeom$Companion_instance = null;\n function Bin2dGeom$Companion_getInstance() {\n if (Bin2dGeom$Companion_instance === null) {\n new Bin2dGeom$Companion();\n }return Bin2dGeom$Companion_instance;\n }\n Bin2dGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bin2dGeom',\n interfaces: [TileGeom]\n };\n function BoxplotGeom() {\n BoxplotGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidline = 1.0;\n this.outlierColor = null;\n this.outlierFill = null;\n this.outlierShape = null;\n this.outlierSize = null;\n }\n Object.defineProperty(BoxplotGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return BoxplotGeom$Companion_getInstance().LEGEND_FACTORY_0;\n }\n });\n function BoxplotGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n BoxplotGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n CrossBarHelper_getInstance().buildBoxes_sm51l0$(root, aesthetics, pos, coord, ctx, BoxplotGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n this.buildLines_0(root, aesthetics, pos, coord, ctx);\n this.buildOutliers_0(root, aesthetics, pos, coord, ctx);\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().UPPER, Aes$Companion_getInstance().MIDDLE, Aes$Companion_getInstance().LOWER, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, BoxplotGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), BoxplotGeom$buildIntern$lambda);\n };\n BoxplotGeom.prototype.buildLines_0 = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n CrossBarHelper_getInstance().buildMidlines_z5ejb9$(root, aesthetics, pos, coord, ctx, this.fattenMidline);\n var helper = new GeomHelper(pos, coord, ctx);\n var elementHelper = helper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_2oeq97$(aesthetics.dataPoints(), Aes$Companion_getInstance().X).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var lines = ArrayList_init();\n if (p.defined_896ixz$(Aes$Companion_getInstance().LOWER) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN)) {\n var hinge = ensureNotNull(p.lower());\n var fence = ensureNotNull(p.ymin());\n lines.add_11rb$(elementHelper.createLine_ollnar$(new DoubleVector(x, hinge), new DoubleVector(x, fence), p));\n }if (p.defined_896ixz$(Aes$Companion_getInstance().UPPER) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX)) {\n var hinge_0 = ensureNotNull(p.upper());\n var fence_0 = ensureNotNull(p.ymax());\n lines.add_11rb$(elementHelper.createLine_ollnar$(new DoubleVector(x, hinge_0), new DoubleVector(x, fence_0), p));\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n }}\n };\n BoxplotGeom.prototype.buildOutliers_0 = function (root, aesthetics, pos, coord, ctx) {\n var outlierAesthetics = this.getOutliersAesthetics_0(aesthetics);\n (new PointGeom()).buildIntern_uzv8ab$(root, outlierAesthetics, pos, coord, ctx.withTargetCollector_xrq6q$(new NullGeomTargetCollector()));\n };\n function BoxplotGeom$getOutliersAesthetics$lambda(this$BoxplotGeom) {\n return function (p) {\n return this$BoxplotGeom.toOutlierDataPointAesthetics_0(p);\n };\n }\n BoxplotGeom.prototype.getOutliersAesthetics_0 = function (aesthetics) {\n return new MappedAesthetics(aesthetics, BoxplotGeom$getOutliersAesthetics$lambda(this));\n };\n function BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral(this$BoxplotGeom, p) {\n this.this$BoxplotGeom = this$BoxplotGeom;\n DataPointAestheticsDelegate.call(this, p);\n }\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.get_31786j$ = function (aes) {\n return this.getIntern_0(aes);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.color = function () {\n return this.getIntern_0(Aes$Companion_getInstance().COLOR);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.fill = function () {\n return this.getIntern_0(Aes$Companion_getInstance().FILL);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.shape = function () {\n return this.getIntern_0(Aes$Companion_getInstance().SHAPE);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.size = function () {\n return this.getIntern_0(Aes$Companion_getInstance().SIZE);\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.prototype.getIntern_0 = function (aes) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n if (equals(aes, Aes$Companion_getInstance().COLOR))\n tmp$_3 = (tmp$ = this.this$BoxplotGeom.outlierColor) != null ? tmp$ : DataPointAestheticsDelegate.prototype.color.call(this);\n else if (equals(aes, Aes$Companion_getInstance().FILL))\n tmp$_3 = (tmp$_0 = this.this$BoxplotGeom.outlierFill) != null ? tmp$_0 : DataPointAestheticsDelegate.prototype.fill.call(this);\n else if (equals(aes, Aes$Companion_getInstance().SHAPE))\n tmp$_3 = (tmp$_1 = this.this$BoxplotGeom.outlierShape) != null ? tmp$_1 : DataPointAestheticsDelegate.prototype.shape.call(this);\n else if (equals(aes, Aes$Companion_getInstance().SIZE))\n tmp$_3 = (tmp$_2 = this.this$BoxplotGeom.outlierSize) != null ? tmp$_2 : BoxplotGeom$Companion_getInstance().OUTLIER_DEF_SIZE_0;\n else\n tmp$_3 = DataPointAestheticsDelegate.prototype.get_31786j$.call(this, aes);\n var value = tmp$_3;\n return (tmp$_4 = value) == null || Kotlin.isType(tmp$_4, Any) ? tmp$_4 : throwCCE();\n };\n BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DataPointAestheticsDelegate]\n };\n BoxplotGeom.prototype.toOutlierDataPointAesthetics_0 = function (p) {\n if (!p.defined_896ixz$(Aes$Companion_getInstance().Y)) {\n return p;\n }return new BoxplotGeom$toOutlierDataPointAesthetics$ObjectLiteral(this, p);\n };\n function BoxplotGeom$Companion() {\n BoxplotGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_FACTORY_0 = CrossBarHelper_getInstance().legendFactory_6taknv$(true);\n this.OUTLIER_DEF_SIZE_0 = AestheticsDefaults$Companion_getInstance().point().defaultValue_31786j$(Aes$Companion_getInstance().SIZE);\n }\n function BoxplotGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().LOWER) && p.defined_896ixz$(Aes$Companion_getInstance().UPPER) && p.defined_896ixz$(Aes$Companion_getInstance().WIDTH)) {\n var x = ensureNotNull(p.x());\n var lower = ensureNotNull(p.lower());\n var upper = ensureNotNull(p.upper());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin = new DoubleVector(x - width / 2, lower);\n var dimensions = new DoubleVector(width, upper - lower);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n };\n }\n BoxplotGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return BoxplotGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n BoxplotGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BoxplotGeom$Companion_instance = null;\n function BoxplotGeom$Companion_getInstance() {\n if (BoxplotGeom$Companion_instance === null) {\n new BoxplotGeom$Companion();\n }return BoxplotGeom$Companion_instance;\n }\n BoxplotGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxplotGeom',\n interfaces: [GeomBase]\n };\n function ContourGeom() {\n ContourGeom$Companion_getInstance();\n PathGeom.call(this);\n }\n function ContourGeom$Companion() {\n ContourGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PathGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n ContourGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourGeom$Companion_instance = null;\n function ContourGeom$Companion_getInstance() {\n if (ContourGeom$Companion_instance === null) {\n new ContourGeom$Companion();\n }return ContourGeom$Companion_instance;\n }\n ContourGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourGeom',\n interfaces: [PathGeom]\n };\n function ContourfGeom() {\n ContourfGeom$Companion_getInstance();\n PolygonGeom.call(this);\n }\n function ContourfGeom$Companion() {\n ContourfGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PolygonGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n ContourfGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourfGeom$Companion_instance = null;\n function ContourfGeom$Companion_getInstance() {\n if (ContourfGeom$Companion_instance === null) {\n new ContourfGeom$Companion();\n }return ContourfGeom$Companion_instance;\n }\n ContourfGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourfGeom',\n interfaces: [PolygonGeom]\n };\n function CrossBarGeom() {\n CrossBarGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidline = 2.5;\n }\n Object.defineProperty(CrossBarGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return CrossBarGeom$Companion_getInstance().LEGEND_FACTORY_0;\n }\n });\n function CrossBarGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n CrossBarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n CrossBarHelper_getInstance().buildBoxes_sm51l0$(root, aesthetics, pos, coord, ctx, CrossBarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx, false));\n CrossBarHelper_getInstance().buildMidlines_z5ejb9$(root, aesthetics, pos, coord, ctx, this.fattenMidline);\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, CrossBarGeom$Companion_getInstance().rectangleByDataPoint_0(ctx, true), CrossBarGeom$buildIntern$lambda);\n };\n function CrossBarGeom$Companion() {\n CrossBarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_FACTORY_0 = CrossBarHelper_getInstance().legendFactory_6taknv$(false);\n }\n function CrossBarGeom$Companion$rectangleByDataPoint$lambda(closure$isHintRect, closure$ctx) {\n return function (p) {\n if (!closure$isHintRect && p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX) && p.defined_896ixz$(Aes$Companion_getInstance().WIDTH)) {\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin = new DoubleVector(x - width / 2, ymin);\n var dimensions = new DoubleVector(width, ymax - ymin);\n return new DoubleRectangle(origin, dimensions);\n } else if (closure$isHintRect && p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().MIDDLE)) {\n var x_0 = ensureNotNull(p.x());\n var middle = ensureNotNull(p.middle());\n var width_0 = GeomUtil_getInstance().widthPx_c6teas$(p, closure$ctx, 2.0);\n var origin_0 = new DoubleVector(x_0 - width_0 / 2, middle);\n var dimensions_0 = new DoubleVector(width_0, 0.0);\n return new DoubleRectangle(origin_0, dimensions_0);\n } else {\n return null;\n }\n };\n }\n CrossBarGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx, isHintRect) {\n return CrossBarGeom$Companion$rectangleByDataPoint$lambda(isHintRect, ctx);\n };\n CrossBarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CrossBarGeom$Companion_instance = null;\n function CrossBarGeom$Companion_getInstance() {\n if (CrossBarGeom$Companion_instance === null) {\n new CrossBarGeom$Companion();\n }return CrossBarGeom$Companion_instance;\n }\n CrossBarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossBarGeom',\n interfaces: [GeomBase]\n };\n function Density2dGeom() {\n Density2dGeom$Companion_getInstance();\n ContourGeom.call(this);\n }\n function Density2dGeom$Companion() {\n Density2dGeom$Companion_instance = this;\n this.HANDLES_GROUPS = ContourGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n Density2dGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Density2dGeom$Companion_instance = null;\n function Density2dGeom$Companion_getInstance() {\n if (Density2dGeom$Companion_instance === null) {\n new Density2dGeom$Companion();\n }return Density2dGeom$Companion_instance;\n }\n Density2dGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dGeom',\n interfaces: [ContourGeom]\n };\n function Density2dfGeom() {\n Density2dfGeom$Companion_getInstance();\n ContourfGeom.call(this);\n }\n function Density2dfGeom$Companion() {\n Density2dfGeom$Companion_instance = this;\n this.HANDLES_GROUPS = ContourfGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n Density2dfGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Density2dfGeom$Companion_instance = null;\n function Density2dfGeom$Companion_getInstance() {\n if (Density2dfGeom$Companion_instance === null) {\n new Density2dfGeom$Companion();\n }return Density2dfGeom$Companion_instance;\n }\n Density2dfGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dfGeom',\n interfaces: [ContourfGeom]\n };\n function DensityGeom() {\n DensityGeom$Companion_getInstance();\n AreaGeom.call(this);\n }\n DensityGeom.prototype.setupTooltipParams_l6g9mh$ = function (aes) {\n return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(aes));\n };\n function DensityGeom$Companion() {\n DensityGeom$Companion_instance = this;\n this.HANDLES_GROUPS = AreaGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n DensityGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DensityGeom$Companion_instance = null;\n function DensityGeom$Companion_getInstance() {\n if (DensityGeom$Companion_instance === null) {\n new DensityGeom$Companion();\n }return DensityGeom$Companion_instance;\n }\n DensityGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DensityGeom',\n interfaces: [AreaGeom]\n };\n function ErrorBarGeom() {\n ErrorBarGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(ErrorBarGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new ErrorBarGeom$MyLegendKeyElementFactory();\n }\n });\n ErrorBarGeom.prototype.dataPoints_0 = function (aesthetics) {\n return GeomUtil_getInstance().with_X_83glv4$(aesthetics.dataPoints());\n };\n ErrorBarGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var helper = new LinesHelper(pos, coord, ctx);\n var dataPoints = this.dataPoints_0(aesthetics);\n var geomHelper = new GeomHelper(pos, coord, ctx);\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = p.x();\n var ymin = p.ymin();\n var ymax = p.ymax();\n if (!data.SeriesUtil.allFinite_xjrefz$(x, ymin, ymax)) {\n continue;\n }var width = ensureNotNull(p.width());\n width *= ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var height = ensureNotNull(ymax) - ensureNotNull(ymin);\n var r = DoubleRectangle_init(ensureNotNull(x) - width / 2, ymin, width, height);\n var g = ErrorBarGeom$Companion_getInstance().errorBarShape_0(helper.toClient_ioi29i$(r, p), p);\n root.add_26jijc$(g);\n this.buildHints_0(DoubleRectangle_init(r.left, r.center.y, r.width, 0.0), p, ctx, geomHelper);\n }\n };\n ErrorBarGeom.prototype.buildHints_0 = function (rect, p, ctx, geomHelper) {\n var clientRect = geomHelper.toClient_ioi29i$(rect, p);\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(clientRect.width / 2.0).defaultX_14dthe$(ensureNotNull(p.x())).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance());\n var hints = (new HintsCollection(p, geomHelper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN)).hints;\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), clientRect, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hints).setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n };\n function ErrorBarGeom$MyLegendKeyElementFactory() {\n }\n ErrorBarGeom$MyLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = ensureNotNull(p.width()) * (size.x - strokeWidth);\n var height = size.y - strokeWidth;\n var x = (size.x - width) / 2;\n var y = strokeWidth / 2;\n return ErrorBarGeom$Companion_getInstance().errorBarShape_0(DoubleRectangle_init(x, y, width, height), p);\n };\n ErrorBarGeom$MyLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function ErrorBarGeom$Companion() {\n ErrorBarGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ErrorBarGeom$Companion.prototype.errorBarShape_0 = function (r, p) {\n var tmp$;\n var left = r.left;\n var top = r.top;\n var right = r.right;\n var bottom = r.bottom;\n var center = left + r.width / 2;\n var shapeLines = ArrayList_init();\n shapeLines.add_11rb$(SvgLineElement_init(left, top, right, top));\n shapeLines.add_11rb$(SvgLineElement_init(left, bottom, right, bottom));\n shapeLines.add_11rb$(SvgLineElement_init(center, top, center, bottom));\n var g = new SvgGElement();\n tmp$ = shapeLines.iterator();\n while (tmp$.hasNext()) {\n var shapeLine = tmp$.next();\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(shapeLine, p);\n g.children().add_11rb$(shapeLine);\n }\n return g;\n };\n ErrorBarGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ErrorBarGeom$Companion_instance = null;\n function ErrorBarGeom$Companion_getInstance() {\n if (ErrorBarGeom$Companion_instance === null) {\n new ErrorBarGeom$Companion();\n }return ErrorBarGeom$Companion_instance;\n }\n ErrorBarGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ErrorBarGeom',\n interfaces: [GeomBase]\n };\n function FilledCircleLegendKeyElementFactory() {\n FilledCircleLegendKeyElementFactory$Companion_getInstance();\n }\n FilledCircleLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var location = new DoubleVector(size.x / 2, size.y / 2);\n var slimObject = PointShapeSvg_getInstance().create_d8smhz$(FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0, location, p);\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(1);\n slimObject.appendTo_i2myw1$(slimGroup);\n return GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup);\n };\n FilledCircleLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var shapeSize = FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0.size_l6g9mh$(p);\n var strokeWidth = FilledCircleLegendKeyElementFactory$Companion_getInstance().SHAPE_0.strokeWidth_l6g9mh$(p);\n var size = shapeSize + strokeWidth + 2.0;\n return new DoubleVector(size, size);\n };\n function FilledCircleLegendKeyElementFactory$Companion() {\n FilledCircleLegendKeyElementFactory$Companion_instance = this;\n this.SHAPE_0 = NamedShape$FILLED_CIRCLE_getInstance();\n }\n FilledCircleLegendKeyElementFactory$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FilledCircleLegendKeyElementFactory$Companion_instance = null;\n function FilledCircleLegendKeyElementFactory$Companion_getInstance() {\n if (FilledCircleLegendKeyElementFactory$Companion_instance === null) {\n new FilledCircleLegendKeyElementFactory$Companion();\n }return FilledCircleLegendKeyElementFactory$Companion_instance;\n }\n FilledCircleLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FilledCircleLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function FilledSquareLegendKeyElementFactory() {\n }\n FilledSquareLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var rect = SvgRectElement_init(0.0, 0.0, size.x, size.y);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(rect, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n return g;\n };\n FilledSquareLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FilledSquareLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function FreqpolyGeom() {\n FreqpolyGeom$Companion_getInstance();\n LineGeom.call(this);\n }\n function FreqpolyGeom$Companion() {\n FreqpolyGeom$Companion_instance = this;\n this.HANDLES_GROUPS = LineGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n FreqpolyGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FreqpolyGeom$Companion_instance = null;\n function FreqpolyGeom$Companion_getInstance() {\n if (FreqpolyGeom$Companion_instance === null) {\n new FreqpolyGeom$Companion();\n }return FreqpolyGeom$Companion_instance;\n }\n FreqpolyGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FreqpolyGeom',\n interfaces: [LineGeom]\n };\n function GeomBase() {\n GeomBase$Companion_getInstance();\n }\n Object.defineProperty(GeomBase.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new GenericLegendKeyElementFactory();\n }\n });\n GeomBase.prototype.build_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n this.buildIntern_uzv8ab$(root, aesthetics, pos, coord, ctx);\n };\n GeomBase.prototype.getGeomTargetCollector_vl74i5$ = function (ctx) {\n return ctx.targetCollector;\n };\n function GeomBase$Companion() {\n GeomBase$Companion_instance = this;\n }\n GeomBase$Companion.prototype.wrap_i2myw1$ = function (slimGroup) {\n var g = new SvgGElement();\n g.isPrebuiltSubtree = true;\n g.children().add_11rb$(slimGroup.asDummySvgNode());\n return g;\n };\n GeomBase$Companion.prototype.wrap_4fnnkz$ = function (o) {\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(1);\n o.appendTo_i2myw1$(slimGroup);\n return this.wrap_i2myw1$(slimGroup);\n };\n GeomBase$Companion.prototype.aesViewPort_m7huy5$ = function (aesthetics) {\n return this.rect_0(aesthetics.overallRange_vktour$(Aes$Companion_getInstance().X), aesthetics.overallRange_vktour$(Aes$Companion_getInstance().Y));\n };\n GeomBase$Companion.prototype.aesBoundingBox_m7huy5$ = function (aesthetics) {\n return this.rect_0(ensureNotNull(aesthetics.range_vktour$(Aes$Companion_getInstance().X)), ensureNotNull(aesthetics.range_vktour$(Aes$Companion_getInstance().Y)));\n };\n GeomBase$Companion.prototype.rect_0 = function (rangeX, rangeY) {\n return DoubleRectangle_init(rangeX.lowerEnd, rangeY.lowerEnd, data.SeriesUtil.span_4fzjta$(rangeX), data.SeriesUtil.span_4fzjta$(rangeY));\n };\n GeomBase$Companion.prototype.appendNodes_37zgbi$ = function (paths, root) {\n var tmp$;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n root.add_26jijc$(path.rootGroup);\n }\n };\n GeomBase$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomBase$Companion_instance = null;\n function GeomBase$Companion_getInstance() {\n if (GeomBase$Companion_instance === null) {\n new GeomBase$Companion();\n }return GeomBase$Companion_instance;\n }\n GeomBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomBase',\n interfaces: [Geom]\n };\n function HLineGeom() {\n HLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(HLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n HLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.interceptY();\n if (data.SeriesUtil.isFinite_yrwdxb$(intercept)) {\n if (viewPort.yRange().contains_mef7kx$(ensureNotNull(intercept))) {\n var start = new DoubleVector(viewPort.left, intercept);\n var end = new DoubleVector(viewPort.right, intercept);\n var line = helper.createLine_ollnar$(start, end, p);\n lines.add_11rb$(line);\n var h = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var origin = new DoubleVector(start.x, intercept - h / 2 - 2.0);\n var dimensions = new DoubleVector(viewPort.dimension.x, h + 4.0);\n var rect = new DoubleRectangle(origin, dimensions);\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), geomHelper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance());\n }}}\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n };\n function HLineGeom$Companion() {\n HLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_KEY_ELEMENT_FACTORY = new HLineLegendKeyElementFactory();\n }\n HLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HLineGeom$Companion_instance = null;\n function HLineGeom$Companion_getInstance() {\n if (HLineGeom$Companion_instance === null) {\n new HLineGeom$Companion();\n }return HLineGeom$Companion_instance;\n }\n HLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HLineGeom',\n interfaces: [GeomBase]\n };\n function HistogramGeom() {\n HistogramGeom$Companion_getInstance();\n BarGeom.call(this);\n }\n function HistogramGeom$Companion() {\n HistogramGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n HistogramGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HistogramGeom$Companion_instance = null;\n function HistogramGeom$Companion_getInstance() {\n if (HistogramGeom$Companion_instance === null) {\n new HistogramGeom$Companion();\n }return HistogramGeom$Companion_instance;\n }\n HistogramGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HistogramGeom',\n interfaces: [BarGeom]\n };\n function ImageGeom(imageUrl) {\n ImageGeom$Companion_getInstance();\n GeomBase.call(this);\n this.imageUrl_0 = imageUrl;\n }\n ImageGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n if (aesthetics.isEmpty)\n return;\n var p = aesthetics.dataPointAt_za3lpa$(0);\n var boundsAes = DoubleRectangle.Companion.span_qt8ska$(new DoubleVector(ensureNotNull(p.xmin()), ensureNotNull(p.ymin())), new DoubleVector(ensureNotNull(p.xmax()), ensureNotNull(p.ymax())));\n var helper = new GeomHelper(pos, coord, ctx);\n var boundsClient = helper.toClient_ioi29i$(boundsAes, p);\n var svgImageElement = SvgImageElement_init(boundsClient.origin.x, boundsClient.origin.y, boundsClient.dimension.x, boundsClient.dimension.y);\n svgImageElement.href().set_11rb$(this.imageUrl_0);\n root.add_26jijc$(svgImageElement);\n };\n function ImageGeom$Companion() {\n ImageGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n ImageGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ImageGeom$Companion_instance = null;\n function ImageGeom$Companion_getInstance() {\n if (ImageGeom$Companion_instance === null) {\n new ImageGeom$Companion();\n }return ImageGeom$Companion_instance;\n }\n ImageGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ImageGeom',\n interfaces: [GeomBase]\n };\n function JitterGeom() {\n JitterGeom$Companion_getInstance();\n PointGeom.call(this);\n }\n function JitterGeom$Companion() {\n JitterGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PointGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n JitterGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JitterGeom$Companion_instance = null;\n function JitterGeom$Companion_getInstance() {\n if (JitterGeom$Companion_instance === null) {\n new JitterGeom$Companion();\n }return JitterGeom$Companion_instance;\n }\n JitterGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterGeom',\n interfaces: [PointGeom]\n };\n function LineGeom() {\n LineGeom$Companion_getInstance();\n PathGeom.call(this);\n }\n LineGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().ordered_X_83glv4$(PathGeom.prototype.dataPoints_m7huy5$.call(this, aesthetics));\n };\n function LineGeom$Companion() {\n LineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = PathGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n LineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LineGeom$Companion_instance = null;\n function LineGeom$Companion_getInstance() {\n if (LineGeom$Companion_instance === null) {\n new LineGeom$Companion();\n }return LineGeom$Companion_instance;\n }\n LineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineGeom',\n interfaces: [PathGeom]\n };\n function LineRangeGeom() {\n LineRangeGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(LineRangeGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return VLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n function LineRangeGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n LineRangeGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var start = new DoubleVector(x, ymin);\n var end = new DoubleVector(x, ymax);\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, LineRangeGeom$Companion_getInstance().rectangleByDataPoint(), LineRangeGeom$buildIntern$lambda);\n };\n function LineRangeGeom$Companion() {\n LineRangeGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function LineRangeGeom$Companion$rectangleByDataPoint$lambda(p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().YMIN) && p.defined_896ixz$(Aes$Companion_getInstance().YMAX)) {\n var x = ensureNotNull(p.x());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var a = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = JsMath.max(a, 2.0) * 2.0;\n var height = ymax - ymin;\n var origin = new DoubleVector(x - width / 2, ymax - height / 2);\n var dimensions = new DoubleVector(width, 0.0);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n }\n LineRangeGeom$Companion.prototype.rectangleByDataPoint = function () {\n return LineRangeGeom$Companion$rectangleByDataPoint$lambda;\n };\n LineRangeGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LineRangeGeom$Companion_instance = null;\n function LineRangeGeom$Companion_getInstance() {\n if (LineRangeGeom$Companion_instance === null) {\n new LineRangeGeom$Companion();\n }return LineRangeGeom$Companion_instance;\n }\n LineRangeGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LineRangeGeom',\n interfaces: [GeomBase]\n };\n function LiveMapGeom(myDisplayMode) {\n LiveMapGeom$Companion_getInstance();\n this.myDisplayMode_0 = myDisplayMode;\n this.myMapProvider_pcd1rb$_0 = this.myMapProvider_pcd1rb$_0;\n }\n Object.defineProperty(LiveMapGeom.prototype, 'myMapProvider_0', {\n configurable: true,\n get: function () {\n if (this.myMapProvider_pcd1rb$_0 == null)\n return throwUPAE('myMapProvider');\n return this.myMapProvider_pcd1rb$_0;\n },\n set: function (myMapProvider) {\n this.myMapProvider_pcd1rb$_0 = myMapProvider;\n }\n });\n Object.defineProperty(LiveMapGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n var tmp$;\n switch (this.myDisplayMode_0.name) {\n case 'POINT':\n tmp$ = new PointLegendKeyElementFactory();\n break;\n case 'PIE':\n tmp$ = new FilledCircleLegendKeyElementFactory();\n break;\n default:tmp$ = new GenericLegendKeyElementFactory();\n break;\n }\n return tmp$;\n }\n });\n LiveMapGeom.prototype.build_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n throw IllegalStateException_init('Not applicable to live map');\n };\n LiveMapGeom.prototype.setLiveMapProvider_kld0fp$ = function (liveMapProvider) {\n this.myMapProvider_0 = liveMapProvider;\n };\n LiveMapGeom.prototype.createCanvasFigure_wthzt5$ = function (bounds) {\n return this.myMapProvider_0.createLiveMap_wthzt5$(bounds);\n };\n function LiveMapGeom$Companion() {\n LiveMapGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n LiveMapGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LiveMapGeom$Companion_instance = null;\n function LiveMapGeom$Companion_getInstance() {\n if (LiveMapGeom$Companion_instance === null) {\n new LiveMapGeom$Companion();\n }return LiveMapGeom$Companion_instance;\n }\n LiveMapGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapGeom',\n interfaces: [Geom]\n };\n function LiveMapProvider() {\n }\n function LiveMapProvider$LiveMapData(canvasFigure, targetLocator) {\n this.canvasFigure = canvasFigure;\n this.targetLocator = targetLocator;\n }\n LiveMapProvider$LiveMapData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapData',\n interfaces: []\n };\n LiveMapProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LiveMapProvider',\n interfaces: []\n };\n function MapGeom() {\n MapGeom$Companion_getInstance();\n PolygonGeom.call(this);\n }\n function MapGeom$Companion() {\n MapGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n MapGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MapGeom$Companion_instance = null;\n function MapGeom$Companion_getInstance() {\n if (MapGeom$Companion_instance === null) {\n new MapGeom$Companion();\n }return MapGeom$Companion_instance;\n }\n MapGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapGeom',\n interfaces: [PolygonGeom]\n };\n function PathGeom() {\n PathGeom$Companion_getInstance();\n GeomBase.call(this);\n this.animation = null;\n }\n Object.defineProperty(PathGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n PathGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n };\n PathGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var linesHelper = new LinesHelper(pos, coord, ctx);\n var geomConstructor = new LinePathConstructor(targetCollector, dataPoints, linesHelper, false);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(geomConstructor.construct_6taknv$(false), root);\n this.buildHints_9cwuu0$_0(aesthetics, coord, linesHelper, targetCollector);\n };\n PathGeom.prototype.buildHints_9cwuu0$_0 = function (aesthetics, coord, linesHelper, targetCollector) {\n var $receiver = this.dataPoints_m7huy5$(aesthetics);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var x = element.x();\n var y = element.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && coord.isPointInLimits_k2qmv6$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), false))\n destination.add_11rb$(element);\n }\n var dataPoints = destination;\n (new LinePathConstructor(targetCollector, dataPoints, linesHelper, false)).buildHints();\n };\n function PathGeom$Companion() {\n PathGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n PathGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathGeom$Companion_instance = null;\n function PathGeom$Companion_getInstance() {\n if (PathGeom$Companion_instance === null) {\n new PathGeom$Companion();\n }return PathGeom$Companion_instance;\n }\n PathGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathGeom',\n interfaces: [GeomBase]\n };\n function PieGeom(myCenter, myRadius) {\n PieGeom$Companion_getInstance();\n GeomBase.call(this);\n this.myCenter_0 = myCenter;\n this.myRadius_0 = myRadius;\n }\n PieGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new PieGeom$PieHelper(pos, coord, ctx);\n var segments = helper.createSegments_67zh1d$(aesthetics, this.myCenter_0, this.myRadius_0);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(segments, root);\n };\n function PieGeom$PieHelper(pos, coord, ctx) {\n LinesHelper.call(this, pos, coord, ctx);\n }\n PieGeom$PieHelper.prototype.createSegments_67zh1d$ = function (aesthetics, center, radius) {\n var tmp$;\n var result = ArrayList_init();\n var basis = new DoubleVector(0.0, -radius);\n var curAngle = kotlin_js_internal_DoubleCompanionObject.NaN;\n tmp$ = PieGeom$Companion_getInstance().dataPoints_0(aesthetics).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var segmentSize = PieGeom$Companion_getInstance().shareToRad_0(ensureNotNull(p.y()));\n if (isNaN_0(curAngle)) {\n curAngle = segmentSize;\n }var angle = -segmentSize;\n var builder = new SvgPathDataBuilder(true);\n builder.moveTo_gpjtzr$(center);\n builder.lineTo_gpjtzr$(center.add_gpjtzr$(basis.rotate_14dthe$(curAngle)));\n var arcTo = center.add_gpjtzr$(basis.rotate_14dthe$(curAngle + angle));\n builder.ellipticalArc_gc0whr$(radius, radius, 0.0, -angle > math.PI, false, arcTo);\n builder.closePath();\n curAngle += angle;\n var path = new LinePath(builder);\n this.decorate_frjrd5$(path, p, true);\n result.add_11rb$(path);\n }\n return result;\n };\n PieGeom$PieHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PieHelper',\n interfaces: [LinesHelper]\n };\n function PieGeom$Companion() {\n PieGeom$Companion_instance = this;\n this.RENDERS = listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().COLOR, Aes$Companion_getInstance().FILL, Aes$Companion_getInstance().ALPHA, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().SIZE]);\n this.HANDLES_GROUPS = false;\n }\n PieGeom$Companion.prototype.dataPoints_0 = function (aesthetics) {\n var tmp$;\n var withX = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n if (collect.Iterables.isEmpty_fakr2g$(withX) || this.allEqualX_0(withX, collect.Iterables.get_7iig3d$(withX, 0).x())) {\n tmp$ = GeomUtil_getInstance().ordered_Y_hku6c7$(GeomUtil_getInstance().with_Y_83glv4$(aesthetics.dataPoints()), true);\n } else\n tmp$ = GeomUtil_getInstance().ordered_X_83glv4$(withX);\n return tmp$;\n };\n PieGeom$Companion.prototype.allEqualX_0 = function (hasX, val) {\n var tmp$;\n tmp$ = hasX.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n if (p.x() != val) {\n return false;\n }}\n return true;\n };\n PieGeom$Companion.prototype.shareToRad_0 = function (share) {\n return 0.9999 * 2.0 * math.PI * share;\n };\n PieGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PieGeom$Companion_instance = null;\n function PieGeom$Companion_getInstance() {\n if (PieGeom$Companion_instance === null) {\n new PieGeom$Companion();\n }return PieGeom$Companion_instance;\n }\n PieGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PieGeom',\n interfaces: [GeomBase]\n };\n function PointGeom() {\n PointGeom$Companion_getInstance();\n GeomBase.call(this);\n this.animation = null;\n this.sizeUnit = null;\n }\n Object.defineProperty(PointGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new PointLegendKeyElementFactory();\n }\n });\n PointGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new GeomHelper(pos, coord, ctx);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var count = aesthetics.dataPointCount();\n var slimGroup = slim.SvgSlimElements.g_za3lpa$(count);\n var sizeUnitRatio = this.getSizeUnitRatio_a8x9k9$_0(ctx);\n for (var i = 0; i < count; i++) {\n var p = aesthetics.dataPointAt_za3lpa$(i);\n var x = p.x();\n var y = p.y();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n var location = helper.toClient_tkjljq$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), p);\n var shape = ensureNotNull(p.shape());\n targetCollector.addPoint_cnsimy$(i, location, sizeUnitRatio * shape.size_l6g9mh$(p) / 2, PointGeom$Companion_getInstance().tooltipParams_l6g9mh$(p));\n var o = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, sizeUnitRatio);\n o.appendTo_i2myw1$(slimGroup);\n }}\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup));\n };\n PointGeom.prototype.getSizeUnitRatio_a8x9k9$_0 = function (ctx) {\n var tmp$;\n if (this.sizeUnit != null) {\n var unitRes = ctx.getUnitResolution_vktour$(GeomHelper$Companion_getInstance().getSizeUnitAes_61zpoe$(ensureNotNull(this.sizeUnit)));\n tmp$ = unitRes / AesScaling_getInstance().UNIT_SHAPE_SIZE;\n } else {\n tmp$ = 1.0;\n }\n return tmp$;\n };\n function PointGeom$Companion() {\n PointGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n PointGeom$Companion.prototype.tooltipParams_l6g9mh$ = function (p) {\n var tmp$;\n var color = Color.Companion.TRANSPARENT;\n if (equals(p.shape(), TinyPointShape_getInstance())) {\n color = ensureNotNull(p.color());\n } else if (Kotlin.isType(p.shape(), NamedShape)) {\n var shape = Kotlin.isType(tmp$ = p.shape(), NamedShape) ? tmp$ : throwCCE();\n color = AestheticsUtil_getInstance().fill_edjgex$(shape.isFilled, shape.isSolid, p);\n }return GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColorValue_o14uds$(color, ensureNotNull(p.alpha())));\n };\n PointGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointGeom$Companion_instance = null;\n function PointGeom$Companion_getInstance() {\n if (PointGeom$Companion_instance === null) {\n new PointGeom$Companion();\n }return PointGeom$Companion_instance;\n }\n PointGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointGeom',\n interfaces: [GeomBase]\n };\n function PointLegendKeyElementFactory(fatten) {\n if (fatten === void 0)\n fatten = 1.0;\n this.fatten_0 = fatten;\n }\n PointLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var location = new DoubleVector(size.x / 2, size.y / 2);\n var shape = ensureNotNull(p.shape());\n var slimObject = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, this.fatten_0);\n return GeomBase$Companion_getInstance().wrap_4fnnkz$(slimObject);\n };\n PointLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var shape = ensureNotNull(p.shape());\n var shapeSize = shape.size_l6g9mh$(p) * this.fatten_0;\n var strokeWidth = shape.strokeWidth_l6g9mh$(p);\n var size = shapeSize + strokeWidth + 2.0;\n return new DoubleVector(size, size);\n };\n PointLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function PointRangeGeom() {\n PointRangeGeom$Companion_getInstance();\n GeomBase.call(this);\n this.fattenMidPoint = PointRangeGeom$Companion_getInstance().DEF_FATTEN;\n }\n Object.defineProperty(PointRangeGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new CompositeLegendKeyElementFactory([new VLineLegendKeyElementFactory(), new PointLegendKeyElementFactory(PointRangeGeom$Companion_getInstance().DEF_FATTEN)]);\n }\n });\n function PointRangeGeom$buildIntern$lambda(it) {\n return HintColorUtil_getInstance().fromColor_l6g9mh$(it);\n }\n PointRangeGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_i1kplo$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var ymin = ensureNotNull(p.ymin());\n var ymax = ensureNotNull(p.ymax());\n var start = new DoubleVector(x, ymin);\n var end = new DoubleVector(x, ymax);\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n var location = geomHelper.toClient_tkjljq$(new DoubleVector(x, y), p);\n var shape = ensureNotNull(p.shape());\n var o = PointShapeSvg_getInstance().create_d8smhz$(shape, location, p, this.fattenMidPoint);\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_4fnnkz$(o));\n }\n BarTooltipHelper_getInstance().collectRectangleTargets_mj9gdb$(listOf([Aes$Companion_getInstance().YMAX, Aes$Companion_getInstance().YMIN]), aesthetics, pos, coord, ctx, PointRangeGeom$Companion_getInstance().rectangleByDataPoint_14dthe$(this.fattenMidPoint), PointRangeGeom$buildIntern$lambda);\n };\n function PointRangeGeom$Companion() {\n PointRangeGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.DEF_FATTEN = 5.0;\n }\n function PointRangeGeom$Companion$rectangleByDataPoint$lambda(closure$fatten) {\n return function (p) {\n if (p.defined_896ixz$(Aes$Companion_getInstance().X) && p.defined_896ixz$(Aes$Companion_getInstance().Y)) {\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var shape = ensureNotNull(p.shape());\n var shapeSize = shape.size_l6g9mh$(p) * closure$fatten;\n var strokeWidth = shape.strokeWidth_l6g9mh$(p);\n var width = shapeSize + strokeWidth;\n var origin = new DoubleVector(x - width / 2, y);\n var dimensions = new DoubleVector(width, 0.0);\n return new DoubleRectangle(origin, dimensions);\n } else {\n return null;\n }\n };\n }\n PointRangeGeom$Companion.prototype.rectangleByDataPoint_14dthe$ = function (fatten) {\n return PointRangeGeom$Companion$rectangleByDataPoint$lambda(fatten);\n };\n PointRangeGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointRangeGeom$Companion_instance = null;\n function PointRangeGeom$Companion_getInstance() {\n if (PointRangeGeom$Companion_instance === null) {\n new PointRangeGeom$Companion();\n }return PointRangeGeom$Companion_instance;\n }\n PointRangeGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointRangeGeom',\n interfaces: [GeomBase]\n };\n function PolygonGeom() {\n PolygonGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n PolygonGeom.prototype.dataPoints_m7huy5$ = function (aesthetics) {\n return GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints());\n };\n PolygonGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var linesHelper = new LinesHelper(pos, coord, ctx);\n var geomConstructor = new LinePathConstructor(targetCollector, dataPoints, linesHelper, true);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(geomConstructor.construct_6taknv$(true), root);\n };\n function PolygonGeom$Companion() {\n PolygonGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n PolygonGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolygonGeom$Companion_instance = null;\n function PolygonGeom$Companion_getInstance() {\n if (PolygonGeom$Companion_instance === null) {\n new PolygonGeom$Companion();\n }return PolygonGeom$Companion_instance;\n }\n PolygonGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolygonGeom',\n interfaces: [GeomBase]\n };\n function RasterGeom() {\n RasterGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(RasterGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new FilledSquareLegendKeyElementFactory();\n }\n });\n RasterGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$, tmp$_0;\n var iter = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()).iterator();\n if (!iter.hasNext()) {\n return;\n }var randomP = iter.next();\n var helper = new GeomHelper(pos, coord, ctx);\n var boundsXY = GeomBase$Companion_getInstance().aesBoundingBox_m7huy5$(aesthetics);\n var stepX = ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var stepY = ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n if (!(stepX > data.SeriesUtil.TINY)) {\n var message = 'x-step is too small: ' + stepX;\n throw IllegalArgumentException_init(message.toString());\n }if (!(stepY > data.SeriesUtil.TINY)) {\n var message_0 = 'y-step is too small: ' + stepY;\n throw IllegalArgumentException_init(message_0.toString());\n }var width = round(boundsXY.dimension.x / stepX) + 1;\n var height = round(boundsXY.dimension.y / stepY) + 1;\n if (width * height > 5000000) {\n var center = boundsXY.center;\n var lines = ['Raster image size', '[' + width + ' X ' + height + ']', 'exceeds capability', 'of', 'your imaging device'];\n var fontSize = 12.0;\n var lineHeight = fontSize + 4;\n var y = center.y + lineHeight * lines.length / 2.0;\n for (tmp$ = 0; tmp$ !== lines.length; ++tmp$) {\n var line = lines[tmp$];\n var label = new TextLabel(line);\n label.textColor().set_11rb$(Color.Companion.DARK_MAGENTA);\n label.textOpacity().set_11rb$(0.5);\n label.setFontSize_14dthe$(fontSize);\n label.setFontWeight_pdl1vj$('bold');\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor$CENTER_getInstance());\n var loc = helper.toClient_vf7nkp$(center.x, y, randomP);\n label.moveTo_gpjtzr$(loc);\n root.add_26jijc$(label.rootGroup);\n y -= lineHeight;\n }\n return;\n }var cols = numberToInt(round(width));\n var rows = numberToInt(round(height));\n var halfStep = new DoubleVector(stepX * 0.5, stepY * 0.5);\n var corner0 = helper.toClient_tkjljq$(boundsXY.origin.subtract_gpjtzr$(halfStep), randomP);\n var corner2 = helper.toClient_tkjljq$(boundsXY.origin.add_gpjtzr$(boundsXY.dimension).add_gpjtzr$(halfStep), randomP);\n var invertedX = corner2.x < corner0.x;\n var invertedY = corner2.y < corner0.y;\n var x0 = boundsXY.origin.x;\n var y0 = boundsXY.origin.y;\n var argbValues = new Int32Array(Kotlin.imul(cols, rows));\n tmp$_0 = GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()).iterator();\n while (tmp$_0.hasNext()) {\n var p = tmp$_0.next();\n var x = p.x();\n var y_0 = p.y();\n var alpha = p.alpha();\n var color = p.fill();\n var col = numberToInt(round((ensureNotNull(x) - x0) / stepX));\n var row = numberToInt(round((ensureNotNull(y_0) - y0) / stepY));\n if (invertedX) {\n col = cols - (col + 1) | 0;\n }if (invertedY) {\n row = rows - (row + 1) | 0;\n }argbValues[Kotlin.imul(row, cols) + col | 0] = svg.SvgUtils.toARGB_o14uds$(ensureNotNull(color), ensureNotNull(alpha));\n }\n var bitmap = new SvgImageElementEx$Bitmap(cols, rows, argbValues);\n var a = corner0.x;\n var b = corner2.x;\n var tmp$_1 = JsMath.min(a, b);\n var a_0 = corner0.y;\n var b_0 = corner2.y;\n var tmp$_2 = JsMath.min(a_0, b_0);\n var x_0 = corner0.x - corner2.x;\n var tmp$_3 = JsMath.abs(x_0);\n var x_1 = corner0.y - corner2.y;\n var svgImageElement = new SvgImageElementEx(tmp$_1, tmp$_2, tmp$_3, JsMath.abs(x_1), bitmap);\n root.add_26jijc$(svgImageElement);\n };\n function RasterGeom$Companion() {\n RasterGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n RasterGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RasterGeom$Companion_instance = null;\n function RasterGeom$Companion_getInstance() {\n if (RasterGeom$Companion_instance === null) {\n new RasterGeom$Companion();\n }return RasterGeom$Companion_instance;\n }\n RasterGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RasterGeom',\n interfaces: [GeomBase]\n };\n function RectGeom() {\n RectGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n RectGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var $receiver = helper.createRectangles_rezc4r$(getCallableRef('rectangleByDataPoint', function ($receiver, p1) {\n return $receiver.rectangleByDataPoint_0(p1);\n }.bind(null, RectGeom$Companion_getInstance())));\n var action = getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_26jijc$(p1), Unit;\n }.bind(null, root));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n action(element);\n }\n (new RectTargetCollectorHelper(helper, getCallableRef('rectangleByDataPoint', function ($receiver, p1) {\n return $receiver.rectangleByDataPoint_0(p1);\n }.bind(null, RectGeom$Companion_getInstance())), getCallableRef('fromFill', function ($receiver, p1) {\n return $receiver.fromFill_l6g9mh$(p1);\n }.bind(null, HintColorUtil_getInstance())), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance())).collectTo_xrq6q$(ctx.targetCollector);\n };\n function RectGeom$Companion() {\n RectGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n RectGeom$Companion.prototype.rectangleByDataPoint_0 = function (p) {\n var tmp$;\n var xmin = p.xmin();\n var xmax = p.xmax();\n var ymin = p.ymin();\n var ymax = p.ymax();\n if (data.SeriesUtil.allFinite_rd1tgs$(xmin, xmax, ymin, ymax)) {\n tmp$ = DoubleRectangle.Companion.span_qt8ska$(new DoubleVector(ensureNotNull(xmin), ensureNotNull(ymin)), new DoubleVector(ensureNotNull(xmax), ensureNotNull(ymax)));\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n RectGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RectGeom$Companion_instance = null;\n function RectGeom$Companion_getInstance() {\n if (RectGeom$Companion_instance === null) {\n new RectGeom$Companion();\n }return RectGeom$Companion_instance;\n }\n RectGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectGeom',\n interfaces: [GeomBase]\n };\n function RibbonGeom() {\n RibbonGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n RibbonGeom.prototype.dataPoints_0 = function (aesthetics) {\n var data = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().YMIN, Aes$Companion_getInstance().YMAX);\n return GeomUtil_getInstance().ordered_X_83glv4$(data);\n };\n RibbonGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = this.dataPoints_0(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var paths = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX, GeomUtil_getInstance().TO_LOCATION_X_YMIN);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(paths, root);\n helper.setAlphaEnabled_6taknv$(false);\n var lines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX);\n lines.addAll_brywnq$(helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMIN));\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(lines, root);\n this.buildHints_0(aesthetics, pos, coord, ctx);\n };\n RibbonGeom.prototype.buildHints_0 = function (aesthetics, pos, coord, ctx) {\n var tmp$;\n var targetCollector = ctx.targetCollector;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n this.addTarget_0(p, targetCollector, GeomUtil_getInstance().TO_LOCATION_X_YMAX, helper);\n }\n };\n RibbonGeom.prototype.addTarget_0 = function (p, collector, toLocation, helper) {\n var coord = toLocation(p);\n if (coord != null) {\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(0.0).defaultX_14dthe$(ensureNotNull(p.x())).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()).defaultColor_yo1m5r$(ensureNotNull(p.fill()), null);\n var hintsCollection = (new HintsCollection(p, helper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN));\n collector.addPoint_cnsimy$(p.index(), helper.toClient_tkjljq$(coord, p), 0.0, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintsCollection.hints));\n }};\n function RibbonGeom$Companion() {\n RibbonGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n }\n RibbonGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RibbonGeom$Companion_instance = null;\n function RibbonGeom$Companion_getInstance() {\n if (RibbonGeom$Companion_instance === null) {\n new RibbonGeom$Companion();\n }return RibbonGeom$Companion_instance;\n }\n RibbonGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RibbonGeom',\n interfaces: [GeomBase]\n };\n function SegmentGeom() {\n SegmentGeom$Companion_getInstance();\n GeomBase.call(this);\n this.arrowSpec = null;\n this.animation = null;\n }\n Object.defineProperty(SegmentGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n function SegmentGeom$buildIntern$lambda(closure$p) {\n return function (it) {\n return closure$p.index();\n };\n }\n SegmentGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var helper = (new GeomHelper(pos, coord, ctx)).createSvgElementHelper();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n if (data.SeriesUtil.allFinite_rd1tgs$(p.x(), p.y(), p.xend(), p.yend())) {\n var start = new DoubleVector(ensureNotNull(p.x()), ensureNotNull(p.y()));\n var end = new DoubleVector(ensureNotNull(p.xend()), ensureNotNull(p.yend()));\n var line = helper.createLine_ollnar$(start, end, p);\n root.add_26jijc$(line);\n targetCollector.addPath_sa5m83$(listOf([coord.toClient_gpjtzr$(start), coord.toClient_gpjtzr$(end)]), SegmentGeom$buildIntern$lambda(p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n if (this.arrowSpec != null) {\n var clientX1 = ensureNotNull(line.x1().get());\n var clientY1 = ensureNotNull(line.y1().get());\n var clientX2 = ensureNotNull(line.x2().get());\n var clientY2 = ensureNotNull(line.y2().get());\n var abscissa = clientX2 - clientX1;\n var ordinate = clientY2 - clientY1;\n if (abscissa !== 0.0 || ordinate !== 0.0) {\n var polarAngle = JsMath.atan2(ordinate, abscissa);\n var arrowAes = ensureNotNull(this.arrowSpec).toArrowAes_l6g9mh$(p);\n if (ensureNotNull(this.arrowSpec).isOnLastEnd) {\n var arrow = ensureNotNull(this.arrowSpec).createElement_yvo9jy$(polarAngle, clientX2, clientY2);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(arrow, arrowAes);\n root.add_26jijc$(arrow);\n }if (ensureNotNull(this.arrowSpec).isOnFirstEnd) {\n var arrow_0 = ensureNotNull(this.arrowSpec).createElement_yvo9jy$(polarAngle + math.PI, clientX1, clientY1);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(arrow_0, arrowAes);\n root.add_26jijc$(arrow_0);\n }}}}}\n };\n function SegmentGeom$Companion() {\n SegmentGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n SegmentGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SegmentGeom$Companion_instance = null;\n function SegmentGeom$Companion_getInstance() {\n if (SegmentGeom$Companion_instance === null) {\n new SegmentGeom$Companion();\n }return SegmentGeom$Companion_instance;\n }\n SegmentGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SegmentGeom',\n interfaces: [GeomBase]\n };\n function SmoothGeom() {\n SmoothGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(SmoothGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return HLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n SmoothGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var dataPoints = GeomUtil_getInstance().ordered_X_83glv4$(GeomUtil_getInstance().with_X_Y_83glv4$(aesthetics.dataPoints()));\n var helper = new LinesHelper(pos, coord, ctx);\n helper.setAlphaEnabled_6taknv$(false);\n var regressionLines = helper.createLines_rrreuh$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_Y);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(regressionLines, root);\n helper.setAlphaFilter_m9g0ow$(SmoothGeom$Companion_getInstance().PROPORTION_0);\n helper.setWidthFilter_m9g0ow$(SmoothGeom$Companion_getInstance().ZERO_0);\n var bands = helper.createBands_22uu1u$(dataPoints, GeomUtil_getInstance().TO_LOCATION_X_YMAX, GeomUtil_getInstance().TO_LOCATION_X_YMIN);\n GeomBase$Companion_getInstance().appendNodes_37zgbi$(bands, root);\n this.buildHints_0(dataPoints, pos, coord, ctx);\n };\n SmoothGeom.prototype.buildHints_0 = function (dataPoints, pos, coord, ctx) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var xCoord = ensureNotNull(p.x());\n var objectRadius = 0.0;\n var hint = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(objectRadius).defaultX_14dthe$(xCoord).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()).defaultColor_yo1m5r$(ensureNotNull(p.fill()), SmoothGeom$Companion_getInstance().PROPORTION_0(p.alpha()));\n var hintsCollection = (new HintsCollection(p, helper)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMAX)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().YMIN)).addHint_p9kkqu$(hint.create_vktour$(Aes$Companion_getInstance().Y).color_98b62m$(ensureNotNull(p.color())));\n var clientCoord = helper.toClient_vf7nkp$(p.x(), p.y(), p);\n ctx.targetCollector.addPoint_cnsimy$(p.index(), clientCoord, objectRadius, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintsCollection.hints));\n }\n };\n function SmoothGeom$Companion() {\n SmoothGeom$Companion_instance = this;\n this.HANDLES_GROUPS = true;\n this.PROPORTION_0 = SmoothGeom$Companion$PROPORTION$lambda;\n this.ZERO_0 = SmoothGeom$Companion$ZERO$lambda;\n }\n function SmoothGeom$Companion$PROPORTION$lambda(v) {\n return v == null ? null : v / 10;\n }\n function SmoothGeom$Companion$ZERO$lambda(f) {\n return 0.0;\n }\n SmoothGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SmoothGeom$Companion_instance = null;\n function SmoothGeom$Companion_getInstance() {\n if (SmoothGeom$Companion_instance === null) {\n new SmoothGeom$Companion();\n }return SmoothGeom$Companion_instance;\n }\n SmoothGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SmoothGeom',\n interfaces: [GeomBase]\n };\n function StepGeom() {\n StepGeom$Companion_getInstance();\n LineGeom.call(this);\n this.myDirection_0 = StepGeom$Companion_getInstance().DEF_DIRECTION;\n }\n StepGeom.prototype.setDirection_61zpoe$ = function (dir) {\n this.myDirection_0 = StepGeom$Direction$Companion_getInstance().toDirection_61zpoe$(dir);\n };\n StepGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var dataPoints = this.dataPoints_m7huy5$(aesthetics);\n var helper = new LinesHelper(pos, coord, ctx);\n var pathInfos = helper.createSteps_1fp004$(dataPoints, this.myDirection_0);\n tmp$ = pathInfos.iterator();\n while (tmp$.hasNext()) {\n var pathInfo = tmp$.next();\n root.add_26jijc$(pathInfo.path.rootGroup);\n }\n };\n function StepGeom$Direction(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function StepGeom$Direction_initFields() {\n StepGeom$Direction_initFields = function () {\n };\n StepGeom$Direction$HV_instance = new StepGeom$Direction('HV', 0);\n StepGeom$Direction$VH_instance = new StepGeom$Direction('VH', 1);\n StepGeom$Direction$Companion_getInstance();\n }\n var StepGeom$Direction$HV_instance;\n function StepGeom$Direction$HV_getInstance() {\n StepGeom$Direction_initFields();\n return StepGeom$Direction$HV_instance;\n }\n var StepGeom$Direction$VH_instance;\n function StepGeom$Direction$VH_getInstance() {\n StepGeom$Direction_initFields();\n return StepGeom$Direction$VH_instance;\n }\n function StepGeom$Direction$Companion() {\n StepGeom$Direction$Companion_instance = this;\n }\n StepGeom$Direction$Companion.prototype.toDirection_61zpoe$ = function (str) {\n var tmp$;\n switch (str) {\n case 'hv':\n case 'HV':\n tmp$ = StepGeom$Direction$HV_getInstance();\n break;\n case 'vh':\n case 'VH':\n tmp$ = StepGeom$Direction$VH_getInstance();\n break;\n default:throw IllegalArgumentException_init('Direction ' + str + \" is not allowed, only accept 'hv' or 'vh'\");\n }\n return tmp$;\n };\n StepGeom$Direction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StepGeom$Direction$Companion_instance = null;\n function StepGeom$Direction$Companion_getInstance() {\n StepGeom$Direction_initFields();\n if (StepGeom$Direction$Companion_instance === null) {\n new StepGeom$Direction$Companion();\n }return StepGeom$Direction$Companion_instance;\n }\n StepGeom$Direction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Direction',\n interfaces: [Enum]\n };\n function StepGeom$Direction$values() {\n return [StepGeom$Direction$HV_getInstance(), StepGeom$Direction$VH_getInstance()];\n }\n StepGeom$Direction.values = StepGeom$Direction$values;\n function StepGeom$Direction$valueOf(name) {\n switch (name) {\n case 'HV':\n return StepGeom$Direction$HV_getInstance();\n case 'VH':\n return StepGeom$Direction$VH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.StepGeom.Direction.' + name);\n }\n }\n StepGeom$Direction.valueOf_61zpoe$ = StepGeom$Direction$valueOf;\n function StepGeom$Companion() {\n StepGeom$Companion_instance = this;\n this.DEF_DIRECTION = StepGeom$Direction$HV_getInstance();\n this.HANDLES_GROUPS = LineGeom$Companion_getInstance().HANDLES_GROUPS;\n }\n StepGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StepGeom$Companion_instance = null;\n function StepGeom$Companion_getInstance() {\n if (StepGeom$Companion_instance === null) {\n new StepGeom$Companion();\n }return StepGeom$Companion_instance;\n }\n StepGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StepGeom',\n interfaces: [LineGeom]\n };\n function TextGeom() {\n TextGeom$Companion_getInstance();\n GeomBase.call(this);\n this.formatter = null;\n this.naValue = TextGeom$Companion_getInstance().DEF_NA_VALUE;\n this.sizeUnit = null;\n }\n Object.defineProperty(TextGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return new TextLegendKeyElementFactory();\n }\n });\n TextGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n var targetCollector = this.getGeomTargetCollector_vl74i5$(ctx);\n var sizeUnitRatio = this.getSizeUnitRatio_0(ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = p.x();\n var y = p.y();\n var text = this.toString_0(p.label());\n if (data.SeriesUtil.allFinite_jma9l8$(x, y) && !base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n var label = new TextLabel(text);\n GeomHelper$Companion_getInstance().decorate_ijkgsm$(label, p, sizeUnitRatio);\n var loc = helper.toClient_vf7nkp$(x, y, p);\n label.moveTo_gpjtzr$(loc);\n root.add_26jijc$(label.rootGroup);\n targetCollector.addPoint_cnsimy$(p.index(), loc, sizeUnitRatio * AesScaling_getInstance().textSize_l6g9mh$(p) / 2, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance());\n }}\n };\n TextGeom.prototype.getSizeUnitRatio_0 = function (ctx) {\n var tmp$;\n if (this.sizeUnit != null) {\n var textWidth = 6.0;\n var unitRes = ctx.getUnitResolution_vktour$(GeomHelper$Companion_getInstance().getSizeUnitAes_61zpoe$(ensureNotNull(this.sizeUnit)));\n tmp$ = unitRes / textWidth;\n } else {\n tmp$ = 1.0;\n }\n return tmp$;\n };\n TextGeom.prototype.toString_0 = function (label) {\n var tmp$;\n if (label == null)\n tmp$ = this.naValue;\n else if (this.formatter != null)\n tmp$ = ensureNotNull(this.formatter).format_za3rmp$(label);\n else\n tmp$ = label.toString();\n return tmp$;\n };\n function TextGeom$Companion() {\n TextGeom$Companion_instance = this;\n this.DEF_NA_VALUE = 'n/a';\n this.HANDLES_GROUPS = false;\n }\n TextGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TextGeom$Companion_instance = null;\n function TextGeom$Companion_getInstance() {\n if (TextGeom$Companion_instance === null) {\n new TextGeom$Companion();\n }return TextGeom$Companion_instance;\n }\n TextGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextGeom',\n interfaces: [GeomBase]\n };\n function TextLegendKeyElementFactory() {\n }\n TextLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var label = new TextLabel('a');\n GeomHelper$Companion_getInstance().decorate_ijkgsm$(label, p);\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor$CENTER_getInstance());\n label.moveTo_lu1900$(size.x / 2, size.y / 2);\n var g = new SvgGElement();\n g.children().add_11rb$(label.rootGroup);\n return g;\n };\n TextLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(4.0, strokeWidth + 4);\n };\n TextLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function TileGeom() {\n TileGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n function TileGeom$buildIntern$lambda(p) {\n return HintColorUtil_getInstance().fromFill_l6g9mh$(p);\n }\n TileGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var slimGroup = helper.createSlimRectangles_rezc4r$(TileGeom$Companion_getInstance().rectangleByDataPoint_0(ctx));\n root.add_26jijc$(GeomBase$Companion_getInstance().wrap_i2myw1$(slimGroup));\n (new RectTargetCollectorHelper(helper, TileGeom$Companion_getInstance().rectangleByDataPoint_0(ctx), TileGeom$buildIntern$lambda, TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance())).collectTo_xrq6q$(ctx.targetCollector);\n };\n function TileGeom$Companion() {\n TileGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n }\n function TileGeom$Companion$rectangleByDataPoint$lambda(closure$ctx) {\n return function (p) {\n var x = p.x();\n var y = p.y();\n var w = p.width();\n var h = p.height();\n var rect = null;\n if (data.SeriesUtil.allFinite_rd1tgs$(x, y, w, h)) {\n var width = ensureNotNull(w) * closure$ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var height = ensureNotNull(h) * closure$ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n var origin = new DoubleVector(ensureNotNull(x) - width / 2, ensureNotNull(y) - height / 2);\n var dimensions = new DoubleVector(width, height);\n rect = new DoubleRectangle(origin, dimensions);\n }return rect;\n };\n }\n TileGeom$Companion.prototype.rectangleByDataPoint_0 = function (ctx) {\n return TileGeom$Companion$rectangleByDataPoint$lambda(ctx);\n };\n TileGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TileGeom$Companion_instance = null;\n function TileGeom$Companion_getInstance() {\n if (TileGeom$Companion_instance === null) {\n new TileGeom$Companion();\n }return TileGeom$Companion_instance;\n }\n TileGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileGeom',\n interfaces: [GeomBase]\n };\n function VLineGeom() {\n VLineGeom$Companion_getInstance();\n GeomBase.call(this);\n }\n Object.defineProperty(VLineGeom.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return VLineGeom$Companion_getInstance().LEGEND_KEY_ELEMENT_FACTORY;\n }\n });\n VLineGeom.prototype.buildIntern_uzv8ab$ = function (root, aesthetics, pos, coord, ctx) {\n var tmp$;\n var geomHelper = new GeomHelper(pos, coord, ctx);\n var helper = geomHelper.createSvgElementHelper();\n helper.setStrokeAlphaEnabled_6taknv$(true);\n var viewPort = GeomBase$Companion_getInstance().aesViewPort_m7huy5$(aesthetics);\n var lines = ArrayList_init();\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var intercept = p.interceptX();\n if (data.SeriesUtil.isFinite_yrwdxb$(intercept)) {\n if (viewPort.xRange().contains_mef7kx$(ensureNotNull(intercept))) {\n var start = new DoubleVector(intercept, viewPort.top);\n var end = new DoubleVector(intercept, viewPort.bottom);\n var line = helper.createLine_ollnar$(start, end, p);\n lines.add_11rb$(line);\n var a = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = JsMath.max(a, 2.0) * 2.0;\n var origin = new DoubleVector(intercept - width / 2, end.y);\n var dimensions = new DoubleVector(width, 0.0);\n var rect = new DoubleRectangle(origin, dimensions);\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), geomHelper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(p)));\n }}}\n var tmp$_0;\n tmp$_0 = lines.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n root.add_26jijc$(element);\n }\n };\n function VLineGeom$Companion() {\n VLineGeom$Companion_instance = this;\n this.HANDLES_GROUPS = false;\n this.LEGEND_KEY_ELEMENT_FACTORY = new VLineLegendKeyElementFactory();\n }\n VLineGeom$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VLineGeom$Companion_instance = null;\n function VLineGeom$Companion_getInstance() {\n if (VLineGeom$Companion_instance === null) {\n new VLineGeom$Companion();\n }return VLineGeom$Companion_instance;\n }\n VLineGeom.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VLineGeom',\n interfaces: [GeomBase]\n };\n function CompositeLegendKeyElementFactory(factories) {\n this.factories_0 = factories;\n }\n CompositeLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var tmp$, tmp$_0;\n var g = new SvgGElement();\n tmp$ = this.factories_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var factory = tmp$[tmp$_0];\n g.children().add_11rb$(factory.createKeyElement_s1fn0c$(p, size));\n }\n return g;\n };\n CompositeLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n return LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$.call(this, p);\n };\n CompositeLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CompositeLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function GenericLegendKeyElementFactory() {\n }\n GenericLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var rect = SvgRectElement_init(0.0, 0.0, size.x, size.y);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(rect, p);\n var line = SvgLineElement_init(0.0, size.y, size.x, 0.0);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n g.children().add_11rb$(line);\n return g;\n };\n GenericLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GenericLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function HLineLegendKeyElementFactory() {\n }\n HLineLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var line = SvgLineElement_init(0.0, size.y / 2, size.x, size.y / 2);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(line);\n return g;\n };\n HLineLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(4.0, strokeWidth + 4);\n };\n HLineLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HLineLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function VLineLegendKeyElementFactory() {\n }\n VLineLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var line = SvgLineElement_init(size.x / 2, 0.0, size.x / 2, size.y);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p);\n var g = new SvgGElement();\n g.children().add_11rb$(line);\n return g;\n };\n VLineLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n return new DoubleVector(strokeWidth + 4, 4.0);\n };\n VLineLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VLineLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function ArrowSpec(angle, length, end, type) {\n this.angle = angle;\n this.length = length;\n this.end = end;\n this.type = type;\n }\n Object.defineProperty(ArrowSpec.prototype, 'isOnFirstEnd', {\n configurable: true,\n get: function () {\n return this.end === ArrowSpec$End$FIRST_getInstance() || this.end === ArrowSpec$End$BOTH_getInstance();\n }\n });\n Object.defineProperty(ArrowSpec.prototype, 'isOnLastEnd', {\n configurable: true,\n get: function () {\n return this.end === ArrowSpec$End$LAST_getInstance() || this.end === ArrowSpec$End$BOTH_getInstance();\n }\n });\n ArrowSpec.prototype.createElement_yvo9jy$ = function (polarAngle, x, y) {\n var tmp$ = Float64Array;\n var tmp$_0 = this.length;\n var x_0 = polarAngle - this.angle;\n var tmp$_1 = x - tmp$_0 * JsMath.cos(x_0);\n var tmp$_2 = this.length;\n var x_1 = polarAngle + this.angle;\n var xs = new tmp$([tmp$_1, x, x - tmp$_2 * JsMath.cos(x_1)]);\n var tmp$_3 = Float64Array;\n var tmp$_4 = this.length;\n var x_2 = polarAngle - this.angle;\n var tmp$_5 = y - tmp$_4 * JsMath.sin(x_2);\n var tmp$_6 = this.length;\n var x_3 = polarAngle + this.angle;\n var ys = new tmp$_3([tmp$_5, y, y - tmp$_6 * JsMath.sin(x_3)]);\n var b = (new SvgPathDataBuilder(true)).moveTo_przk3b$(xs[0], ys[0]);\n for (var i = 1; i <= 2; i++) {\n b.lineTo_przk3b$(xs[i], ys[i], true);\n }\n if (this.type === ArrowSpec$Type$CLOSED_getInstance()) {\n b.closePath();\n }return SvgPathElement_init(b.build());\n };\n function ArrowSpec$toArrowAes$ObjectLiteral(this$ArrowSpec, p) {\n DataPointAestheticsDelegate.call(this, p);\n this.myFilled_0 = this$ArrowSpec.type === ArrowSpec$Type$CLOSED_getInstance();\n }\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.fill = function () {\n var tmp$;\n if (this.myFilled_0) {\n tmp$ = this.color();\n } else\n tmp$ = Color.Companion.TRANSPARENT;\n return tmp$;\n };\n ArrowSpec$toArrowAes$ObjectLiteral.prototype.lineType = function () {\n var tmp$;\n if (this.myFilled_0) {\n tmp$ = NamedLineType$SOLID_getInstance();\n } else\n tmp$ = DataPointAestheticsDelegate.prototype.lineType.call(this);\n return tmp$;\n };\n ArrowSpec$toArrowAes$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DataPointAestheticsDelegate]\n };\n ArrowSpec.prototype.toArrowAes_l6g9mh$ = function (p) {\n return new ArrowSpec$toArrowAes$ObjectLiteral(this, p);\n };\n function ArrowSpec$End(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ArrowSpec$End_initFields() {\n ArrowSpec$End_initFields = function () {\n };\n ArrowSpec$End$LAST_instance = new ArrowSpec$End('LAST', 0);\n ArrowSpec$End$FIRST_instance = new ArrowSpec$End('FIRST', 1);\n ArrowSpec$End$BOTH_instance = new ArrowSpec$End('BOTH', 2);\n }\n var ArrowSpec$End$LAST_instance;\n function ArrowSpec$End$LAST_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$LAST_instance;\n }\n var ArrowSpec$End$FIRST_instance;\n function ArrowSpec$End$FIRST_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$FIRST_instance;\n }\n var ArrowSpec$End$BOTH_instance;\n function ArrowSpec$End$BOTH_getInstance() {\n ArrowSpec$End_initFields();\n return ArrowSpec$End$BOTH_instance;\n }\n ArrowSpec$End.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'End',\n interfaces: [Enum]\n };\n function ArrowSpec$End$values() {\n return [ArrowSpec$End$LAST_getInstance(), ArrowSpec$End$FIRST_getInstance(), ArrowSpec$End$BOTH_getInstance()];\n }\n ArrowSpec$End.values = ArrowSpec$End$values;\n function ArrowSpec$End$valueOf(name) {\n switch (name) {\n case 'LAST':\n return ArrowSpec$End$LAST_getInstance();\n case 'FIRST':\n return ArrowSpec$End$FIRST_getInstance();\n case 'BOTH':\n return ArrowSpec$End$BOTH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.util.ArrowSpec.End.' + name);\n }\n }\n ArrowSpec$End.valueOf_61zpoe$ = ArrowSpec$End$valueOf;\n function ArrowSpec$Type(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ArrowSpec$Type_initFields() {\n ArrowSpec$Type_initFields = function () {\n };\n ArrowSpec$Type$OPEN_instance = new ArrowSpec$Type('OPEN', 0);\n ArrowSpec$Type$CLOSED_instance = new ArrowSpec$Type('CLOSED', 1);\n }\n var ArrowSpec$Type$OPEN_instance;\n function ArrowSpec$Type$OPEN_getInstance() {\n ArrowSpec$Type_initFields();\n return ArrowSpec$Type$OPEN_instance;\n }\n var ArrowSpec$Type$CLOSED_instance;\n function ArrowSpec$Type$CLOSED_getInstance() {\n ArrowSpec$Type_initFields();\n return ArrowSpec$Type$CLOSED_instance;\n }\n ArrowSpec$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function ArrowSpec$Type$values() {\n return [ArrowSpec$Type$OPEN_getInstance(), ArrowSpec$Type$CLOSED_getInstance()];\n }\n ArrowSpec$Type.values = ArrowSpec$Type$values;\n function ArrowSpec$Type$valueOf(name) {\n switch (name) {\n case 'OPEN':\n return ArrowSpec$Type$OPEN_getInstance();\n case 'CLOSED':\n return ArrowSpec$Type$CLOSED_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.geom.util.ArrowSpec.Type.' + name);\n }\n }\n ArrowSpec$Type.valueOf_61zpoe$ = ArrowSpec$Type$valueOf;\n ArrowSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ArrowSpec',\n interfaces: []\n };\n function BarTooltipHelper() {\n BarTooltipHelper_instance = this;\n }\n BarTooltipHelper.prototype.collectRectangleTargets_mj9gdb$ = function (hintAesList, aesthetics, pos, coord, ctx, rectFactory, colorFactory) {\n var tmp$, tmp$_0;\n var helper = new GeomHelper(pos, coord, ctx);\n tmp$ = aesthetics.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n tmp$_0 = rectFactory(p);\n if (tmp$_0 == null) {\n continue;\n }var rect = tmp$_0;\n var clientRect = helper.toClient_ioi29i$(DoubleRectangle_init(0.0, 0.0, rect.width, 0.0), p);\n var objectRadius = clientRect.width / 2.0;\n var xCoord = rect.center.x;\n var hintFactory = (new HintsCollection$HintConfigFactory()).defaultObjectRadius_14dthe$(objectRadius).defaultX_14dthe$(xCoord).defaultKind_nnfttk$(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance());\n var tmp$_1;\n var accumulator = new HintsCollection(p, helper);\n tmp$_1 = hintAesList.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n accumulator = accumulator.addHint_p9kkqu$(hintFactory.create_vktour$(element));\n }\n var hintConfigs = accumulator;\n ctx.targetCollector.addRectangle_bxzvr8$(p.index(), helper.toClient_ioi29i$(rect, p), GeomTargetCollector$TooltipParams$Companion_getInstance().params().setTipLayoutHints_vgcgsc$(hintConfigs.hints).setColor_98b62m$(colorFactory(p)));\n }\n };\n BarTooltipHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BarTooltipHelper',\n interfaces: []\n };\n var BarTooltipHelper_instance = null;\n function BarTooltipHelper_getInstance() {\n if (BarTooltipHelper_instance === null) {\n new BarTooltipHelper();\n }return BarTooltipHelper_instance;\n }\n function CrossBarHelper() {\n CrossBarHelper_instance = this;\n }\n CrossBarHelper.prototype.buildBoxes_sm51l0$ = function (root, aesthetics, pos, coord, ctx, rectFactory) {\n var helper = new RectanglesHelper(aesthetics, pos, coord, ctx);\n var rectangles = helper.createRectangles_rezc4r$(rectFactory);\n var tmp$;\n tmp$ = rectangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n root.add_26jijc$(element);\n }\n };\n CrossBarHelper.prototype.buildMidlines_z5ejb9$ = function (root, aesthetics, pos, coord, ctx, fatten) {\n var tmp$;\n var helper = new GeomHelper(pos, coord, ctx);\n var elementHelper = helper.createSvgElementHelper();\n tmp$ = GeomUtil_getInstance().withDefined_7jazl$(aesthetics.dataPoints(), Aes$Companion_getInstance().X, Aes$Companion_getInstance().WIDTH, Aes$Companion_getInstance().MIDDLE).iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var x = ensureNotNull(p.x());\n var middle = ensureNotNull(p.middle());\n var width = GeomUtil_getInstance().widthPx_c6teas$(p, ctx, 2.0);\n var line = elementHelper.createLine_ollnar$(new DoubleVector(x - width / 2, middle), new DoubleVector(x + width / 2, middle), p);\n var thickness = ensureNotNull(line.strokeWidth().get());\n line.strokeWidth().set_11rb$(thickness * fatten);\n root.add_26jijc$(line);\n }\n };\n CrossBarHelper.prototype.legendFactory_6taknv$ = function (whiskers) {\n return new CrossBarLegendKeyElementFactory(whiskers);\n };\n CrossBarHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CrossBarHelper',\n interfaces: []\n };\n var CrossBarHelper_instance = null;\n function CrossBarHelper_getInstance() {\n if (CrossBarHelper_instance === null) {\n new CrossBarHelper();\n }return CrossBarHelper_instance;\n }\n function CrossBarLegendKeyElementFactory(whiskers) {\n this.whiskers = whiskers;\n }\n CrossBarLegendKeyElementFactory.prototype.createKeyElement_s1fn0c$ = function (p, size) {\n var whiskerSize = 0.2;\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var width = (size.x - strokeWidth) * 0.8;\n var height = size.y - strokeWidth;\n var x = (size.x - width) / 2;\n var y = strokeWidth / 2;\n var boxHeight = height;\n var boxY = y;\n if (this.whiskers) {\n boxHeight = height * (1 - 2 * whiskerSize);\n boxY = y + height * whiskerSize;\n }var rect = SvgRectElement_init(x, boxY, width, boxHeight);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(rect, p);\n var middleY = y + height * 0.5;\n var middle = SvgLineElement_init(x, middleY, x + width, middleY);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(middle, p);\n var g = new SvgGElement();\n g.children().add_11rb$(rect);\n g.children().add_11rb$(middle);\n if (this.whiskers) {\n var middleX = x + width * 0.5;\n var lowerWhisker = SvgLineElement_init(middleX, y + height * (1 - whiskerSize), middleX, y + height);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(lowerWhisker, p);\n var upperWhisker = SvgLineElement_init(middleX, y, middleX, y + height * whiskerSize);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(upperWhisker, p);\n g.children().add_11rb$(lowerWhisker);\n g.children().add_11rb$(upperWhisker);\n }return g;\n };\n CrossBarLegendKeyElementFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossBarLegendKeyElementFactory',\n interfaces: [LegendKeyElementFactory]\n };\n function DataPointAestheticsDelegate(p) {\n this.p_bcayt6$_0 = p;\n }\n DataPointAestheticsDelegate.prototype.index = function () {\n return this.p_bcayt6$_0.index();\n };\n DataPointAestheticsDelegate.prototype.x = function () {\n return this.p_bcayt6$_0.x();\n };\n DataPointAestheticsDelegate.prototype.y = function () {\n return this.p_bcayt6$_0.y();\n };\n DataPointAestheticsDelegate.prototype.z = function () {\n return this.p_bcayt6$_0.z();\n };\n DataPointAestheticsDelegate.prototype.ymin = function () {\n return this.p_bcayt6$_0.ymin();\n };\n DataPointAestheticsDelegate.prototype.ymax = function () {\n return this.p_bcayt6$_0.ymax();\n };\n DataPointAestheticsDelegate.prototype.color = function () {\n return this.p_bcayt6$_0.color();\n };\n DataPointAestheticsDelegate.prototype.fill = function () {\n return this.p_bcayt6$_0.fill();\n };\n DataPointAestheticsDelegate.prototype.alpha = function () {\n return this.p_bcayt6$_0.alpha();\n };\n DataPointAestheticsDelegate.prototype.shape = function () {\n return this.p_bcayt6$_0.shape();\n };\n DataPointAestheticsDelegate.prototype.lineType = function () {\n return this.p_bcayt6$_0.lineType();\n };\n DataPointAestheticsDelegate.prototype.size = function () {\n return this.p_bcayt6$_0.size();\n };\n DataPointAestheticsDelegate.prototype.width = function () {\n return this.p_bcayt6$_0.width();\n };\n DataPointAestheticsDelegate.prototype.height = function () {\n return this.p_bcayt6$_0.height();\n };\n DataPointAestheticsDelegate.prototype.weight = function () {\n return this.p_bcayt6$_0.weight();\n };\n DataPointAestheticsDelegate.prototype.intercept = function () {\n return this.p_bcayt6$_0.intercept();\n };\n DataPointAestheticsDelegate.prototype.slope = function () {\n return this.p_bcayt6$_0.slope();\n };\n DataPointAestheticsDelegate.prototype.interceptX = function () {\n return this.p_bcayt6$_0.interceptX();\n };\n DataPointAestheticsDelegate.prototype.interceptY = function () {\n return this.p_bcayt6$_0.interceptY();\n };\n DataPointAestheticsDelegate.prototype.lower = function () {\n return this.p_bcayt6$_0.lower();\n };\n DataPointAestheticsDelegate.prototype.middle = function () {\n return this.p_bcayt6$_0.middle();\n };\n DataPointAestheticsDelegate.prototype.upper = function () {\n return this.p_bcayt6$_0.upper();\n };\n DataPointAestheticsDelegate.prototype.frame = function () {\n return this.p_bcayt6$_0.frame();\n };\n DataPointAestheticsDelegate.prototype.speed = function () {\n return this.p_bcayt6$_0.speed();\n };\n DataPointAestheticsDelegate.prototype.flow = function () {\n return this.p_bcayt6$_0.flow();\n };\n DataPointAestheticsDelegate.prototype.xmin = function () {\n return this.p_bcayt6$_0.xmin();\n };\n DataPointAestheticsDelegate.prototype.xmax = function () {\n return this.p_bcayt6$_0.xmax();\n };\n DataPointAestheticsDelegate.prototype.xend = function () {\n return this.p_bcayt6$_0.xend();\n };\n DataPointAestheticsDelegate.prototype.yend = function () {\n return this.p_bcayt6$_0.yend();\n };\n DataPointAestheticsDelegate.prototype.label = function () {\n return this.p_bcayt6$_0.label();\n };\n DataPointAestheticsDelegate.prototype.family = function () {\n return this.p_bcayt6$_0.family();\n };\n DataPointAestheticsDelegate.prototype.fontface = function () {\n return this.p_bcayt6$_0.fontface();\n };\n DataPointAestheticsDelegate.prototype.hjust = function () {\n return this.p_bcayt6$_0.hjust();\n };\n DataPointAestheticsDelegate.prototype.vjust = function () {\n return this.p_bcayt6$_0.vjust();\n };\n DataPointAestheticsDelegate.prototype.angle = function () {\n return this.p_bcayt6$_0.angle();\n };\n DataPointAestheticsDelegate.prototype.symX = function () {\n return this.p_bcayt6$_0.symX();\n };\n DataPointAestheticsDelegate.prototype.symY = function () {\n return this.p_bcayt6$_0.symY();\n };\n DataPointAestheticsDelegate.prototype.group = function () {\n return this.p_bcayt6$_0.group();\n };\n DataPointAestheticsDelegate.prototype.numeric_vktour$ = function (aes) {\n return this.p_bcayt6$_0.numeric_vktour$(aes);\n };\n DataPointAestheticsDelegate.prototype.get_31786j$ = function (aes) {\n return this.p_bcayt6$_0.get_31786j$(aes);\n };\n DataPointAestheticsDelegate.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataPointAestheticsDelegate',\n interfaces: [DataPointAesthetics]\n };\n function GeomCoord(myCoord) {\n this.myCoord_0 = myCoord;\n }\n GeomCoord.prototype.toClient_gpjtzr$ = function (p) {\n return this.myCoord_0.toClient_gpjtzr$(p);\n };\n GeomCoord.prototype.fromClient_xoefl8$ = function (location) {\n return this.myCoord_0.fromClient_gpjtzr$(location);\n };\n function GeomCoord$toClient$lambda(this$GeomCoord) {\n return function (coord) {\n return this$GeomCoord.myCoord_0.toClient_gpjtzr$(coord);\n };\n }\n GeomCoord.prototype.toClient_wthzt5$ = function (r) {\n return this.translateRect_0(r, GeomCoord$toClient$lambda(this));\n };\n function GeomCoord$fromClient$lambda(this$GeomCoord) {\n return function (coord) {\n return this$GeomCoord.myCoord_0.fromClient_gpjtzr$(coord);\n };\n }\n GeomCoord.prototype.fromClient_wthzt5$ = function (r) {\n return this.translateRect_0(r, GeomCoord$fromClient$lambda(this));\n };\n GeomCoord.prototype.translateRect_0 = function (r, toLocation) {\n var r_0 = r;\n var xy1 = r_0.origin;\n var xy2 = new DoubleVector(r_0.right, r_0.bottom);\n var xy1cl = toLocation(xy1);\n var xy2cl = toLocation(xy2);\n if (!(xy1 != null ? xy1.equals(xy1cl) : null) || !(xy2 != null ? xy2.equals(xy2cl) : null)) {\n var a = xy1cl.x;\n var b = xy2cl.x;\n var xMin = JsMath.min(a, b);\n var a_0 = xy1cl.y;\n var b_0 = xy2cl.y;\n var yMin = JsMath.min(a_0, b_0);\n var a_1 = xy1cl.x;\n var b_1 = xy2cl.x;\n var xMax = JsMath.max(a_1, b_1);\n var a_2 = xy1cl.y;\n var b_2 = xy2cl.y;\n var yMax = JsMath.max(a_2, b_2);\n r_0 = DoubleRectangle_init(xMin, yMin, xMax - xMin, yMax - yMin);\n }return r_0;\n };\n GeomCoord.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomCoord',\n interfaces: []\n };\n function GeomHelper(myPos, coord, ctx) {\n GeomHelper$Companion_getInstance();\n this.myPos_ts7al2$_0 = myPos;\n this.ctx = ctx;\n this.myGeomCoord_mnazw1$_0 = new GeomCoord(coord);\n }\n GeomHelper.prototype.toClient_tkjljq$ = function (location, p) {\n return this.myGeomCoord_mnazw1$_0.toClient_gpjtzr$(this.adjust_umm47c$_0(location, p, this.myPos_ts7al2$_0, this.ctx));\n };\n GeomHelper.prototype.toClient_vf7nkp$ = function (x, y, p) {\n var location = new DoubleVector(ensureNotNull(x), ensureNotNull(y));\n return this.myGeomCoord_mnazw1$_0.toClient_gpjtzr$(this.adjust_umm47c$_0(location, p, this.myPos_ts7al2$_0, this.ctx));\n };\n GeomHelper.prototype.toClient_ioi29i$ = function (r, p) {\n var clientRect = this.myGeomCoord_mnazw1$_0.toClient_wthzt5$(this.adjust_en6it6$_0(r, p, this.myPos_ts7al2$_0, this.ctx));\n if (clientRect.width === 0.0) {\n clientRect = DoubleRectangle_init(clientRect.origin.x, clientRect.origin.y, 0.1, clientRect.height);\n }if (clientRect.height === 0.0) {\n clientRect = DoubleRectangle_init(clientRect.origin.x, clientRect.origin.y, clientRect.width, 0.1);\n }return clientRect;\n };\n GeomHelper.prototype.fromClient_gpjtzr$ = function (location) {\n return this.myGeomCoord_mnazw1$_0.fromClient_xoefl8$(location);\n };\n GeomHelper.prototype.adjust_umm47c$_0 = function (location, p, pos, ctx) {\n return pos.translate_tshsjz$(location, p, ctx);\n };\n GeomHelper.prototype.toClientRect_7iz5gz$ = function (p, aesMapper) {\n var tmp$;\n tmp$ = aesMapper(p);\n if (tmp$ == null) {\n return null;\n }var r = tmp$;\n return this.toClient_ioi29i$(r, p);\n };\n GeomHelper.prototype.adjust_en6it6$_0 = function (r, p, pos, ctx) {\n var leftTop = pos.translate_tshsjz$(r.origin, p, ctx);\n var rightBottom = pos.translate_tshsjz$(r.origin.add_gpjtzr$(r.dimension), p, ctx);\n return DoubleRectangle.Companion.span_qt8ska$(leftTop, rightBottom);\n };\n GeomHelper.prototype.project_rrreuh$ = function (dataPoints, projection) {\n var tmp$;\n var points = ArrayList_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var location = projection(p);\n if (location != null) {\n var pp = this.toClient_tkjljq$(location, p);\n points.add_11rb$(pp);\n }}\n return points;\n };\n function GeomHelper$toClientLocation$lambda(closure$aesMapper, this$GeomHelper) {\n return function (aes) {\n var location = closure$aesMapper(aes);\n if (location != null) {\n return this$GeomHelper.toClient_tkjljq$(location, aes);\n } else {\n return null;\n }\n };\n }\n GeomHelper.prototype.toClientLocation_sfitzs$ = function (aesMapper) {\n return GeomHelper$toClientLocation$lambda(aesMapper, this);\n };\n GeomHelper.prototype.createSvgElementHelper = function () {\n return new GeomHelper$SvgElementHelper(this);\n };\n GeomHelper.prototype.toClient_je5qx7$ = function (locations, p) {\n var tmp$;\n var localLocations = ArrayList_init();\n tmp$ = locations.iterator();\n while (tmp$.hasNext()) {\n var location = tmp$.next();\n localLocations.add_11rb$(this.toClient_tkjljq$(location, p));\n }\n return localLocations;\n };\n function GeomHelper$SvgElementHelper($outer) {\n this.$outer = $outer;\n this.myStrokeAlphaEnabled_0 = false;\n }\n GeomHelper$SvgElementHelper.prototype.setStrokeAlphaEnabled_6taknv$ = function (b) {\n this.myStrokeAlphaEnabled_0 = b;\n };\n GeomHelper$SvgElementHelper.prototype.createLine_ollnar$ = function (start, end, p) {\n var start_0 = this.$outer.toClient_tkjljq$(start, p);\n var end_0 = this.$outer.toClient_tkjljq$(end, p);\n var line = SvgLineElement_init(start_0.x, start_0.y, end_0.x, end_0.y);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(line, p, this.myStrokeAlphaEnabled_0);\n return line;\n };\n GeomHelper$SvgElementHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgElementHelper',\n interfaces: []\n };\n function GeomHelper$Companion() {\n GeomHelper$Companion_instance = this;\n this.HJUST_MAP = mapOf([to('right', TextLabel$HorizontalAnchor$RIGHT_getInstance()), to('middle', TextLabel$HorizontalAnchor$MIDDLE_getInstance()), to('left', TextLabel$HorizontalAnchor$LEFT_getInstance()), to(0.0, TextLabel$HorizontalAnchor$RIGHT_getInstance()), to(0.5, TextLabel$HorizontalAnchor$MIDDLE_getInstance()), to(1.0, TextLabel$HorizontalAnchor$LEFT_getInstance())]);\n this.VJUST_MAP = mapOf([to('bottom', TextLabel$VerticalAnchor$BOTTOM_getInstance()), to('center', TextLabel$VerticalAnchor$CENTER_getInstance()), to('top', TextLabel$VerticalAnchor$TOP_getInstance()), to(0.0, TextLabel$VerticalAnchor$BOTTOM_getInstance()), to(0.5, TextLabel$VerticalAnchor$CENTER_getInstance()), to(1.0, TextLabel$VerticalAnchor$TOP_getInstance())]);\n this.FONT_WEIGHT_SET_0 = setOf(['bold', 'bolder', 'lighter']);\n this.FONT_STYLE_SET_0 = setOf(['italic', 'oblique']);\n this.FONT_FAMILY_MAP_0 = mapOf([to('sans', 'sans-serif'), to('serif', 'serif'), to('mono', 'monospace')]);\n }\n GeomHelper$Companion.prototype.decorate_ijkgsm$ = function (label, p, scale) {\n if (scale === void 0)\n scale = 1.0;\n var tmp$, tmp$_0;\n label.textColor().set_11rb$(p.color());\n label.textOpacity().set_11rb$(p.alpha());\n label.setFontSize_14dthe$(AesScaling_getInstance().textSize_l6g9mh$(p) * scale);\n var family = p.family();\n if (this.FONT_FAMILY_MAP_0.containsKey_11rb$(family)) {\n family = ensureNotNull(this.FONT_FAMILY_MAP_0.get_11rb$(family));\n }label.setFontFamily_pdl1vj$(family);\n var fontface = p.fontface();\n if (!base.Strings.isNullOrEmpty_pdl1vj$(fontface)) {\n var $receiver = Regex_init(' ').split_905azu$(fontface, 0);\n var dropLastWhile$result;\n dropLastWhile$break: do {\n if (!$receiver.isEmpty()) {\n var iterator = $receiver.listIterator_za3lpa$($receiver.size);\n while (iterator.hasPrevious()) {\n if (!(iterator.previous().length === 0)) {\n dropLastWhile$result = take($receiver, iterator.nextIndex() + 1 | 0);\n break dropLastWhile$break;\n }}\n }dropLastWhile$result = emptyList();\n }\n while (false);\n tmp$ = copyToArray(dropLastWhile$result);\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var s = tmp$[tmp$_0];\n if (this.FONT_WEIGHT_SET_0.contains_11rb$(s)) {\n label.setFontWeight_pdl1vj$(s);\n } else if (this.FONT_STYLE_SET_0.contains_11rb$(s)) {\n label.setFontStyle_pdl1vj$(s);\n }}\n }var hAnchor = this.textLabelAnchor_3zqsx9$(p.hjust(), this.HJUST_MAP, TextLabel$HorizontalAnchor$MIDDLE_getInstance());\n var vAnchor = this.textLabelAnchor_3zqsx9$(p.vjust(), this.VJUST_MAP, TextLabel$VerticalAnchor$CENTER_getInstance());\n if (hAnchor !== TextLabel$HorizontalAnchor$LEFT_getInstance()) {\n label.setHorizontalAnchor_ja80zo$(hAnchor);\n }if (vAnchor !== TextLabel$VerticalAnchor$BOTTOM_getInstance()) {\n label.setVerticalAnchor_yaudma$(vAnchor);\n }var angle = ensureNotNull(p.angle());\n if (angle !== 0.0) {\n angle = 360 - angle % 360;\n label.rotate_14dthe$(angle);\n }};\n GeomHelper$Companion.prototype.textLabelAnchor_3zqsx9$ = function (o, conversionMap, def) {\n var tmp$;\n return (tmp$ = conversionMap.get_11rb$(o)) != null ? tmp$ : def;\n };\n GeomHelper$Companion.prototype.decorate_d9jm6k$ = function (node, p, applyAlphaToAll) {\n if (applyAlphaToAll === void 0)\n applyAlphaToAll = AestheticsUtil_getInstance().ALPHA_CONTROLS_BOTH_8be2vx$;\n var tmp$;\n if (Kotlin.isType(node, SvgShape)) {\n this.decorateShape_0(Kotlin.isType(tmp$ = node, SvgShape) ? tmp$ : throwCCE(), p, applyAlphaToAll);\n }if (Kotlin.isType(node, SvgElement)) {\n var lineType = p.lineType();\n if (!(lineType.isBlank || lineType.isSolid)) {\n StrokeDashArraySupport_getInstance().apply_3xqz7j$(node, AesScaling_getInstance().strokeWidth_l6g9mh$(p), lineType.dashArray);\n }}};\n GeomHelper$Companion.prototype.decorateShape_0 = function (shape, p, applyAlphaToAll) {\n AestheticsUtil_getInstance().updateStroke_g0plfl$(shape, p, applyAlphaToAll);\n AestheticsUtil_getInstance().updateFill_v4tjbc$(shape, p);\n shape.strokeWidth().set_11rb$(AesScaling_getInstance().strokeWidth_l6g9mh$(p));\n };\n GeomHelper$Companion.prototype.decorateSlimShape_gb6c9f$ = function (shape, p) {\n var stroke = ensureNotNull(p.color());\n var strokeAlpha = AestheticsUtil_getInstance().alpha_il6rhx$(stroke, p);\n var fill = ensureNotNull(p.fill());\n var fillAlpha = AestheticsUtil_getInstance().alpha_il6rhx$(fill, p);\n shape.setFill_o14uds$(fill, fillAlpha);\n shape.setStroke_o14uds$(stroke, strokeAlpha);\n shape.setStrokeWidth_14dthe$(AesScaling_getInstance().strokeWidth_l6g9mh$(p));\n };\n GeomHelper$Companion.prototype.getSizeUnitAes_61zpoe$ = function (sizeUnitName) {\n var tmp$;\n switch (sizeUnitName.toLowerCase()) {\n case 'x':\n tmp$ = Aes$Companion_getInstance().X;\n break;\n case 'y':\n tmp$ = Aes$Companion_getInstance().Y;\n break;\n default:throw IllegalStateException_init((\"Size unit value must be either 'x' or 'y', but was \" + sizeUnitName + '.').toString());\n }\n return tmp$;\n };\n GeomHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomHelper$Companion_instance = null;\n function GeomHelper$Companion_getInstance() {\n if (GeomHelper$Companion_instance === null) {\n new GeomHelper$Companion();\n }return GeomHelper$Companion_instance;\n }\n GeomHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomHelper',\n interfaces: []\n };\n function GeomUtil() {\n GeomUtil_instance = this;\n this.TO_LOCATION_X_Y = GeomUtil$TO_LOCATION_X_Y$lambda(this);\n this.TO_LOCATION_X_YMIN = GeomUtil$TO_LOCATION_X_YMIN$lambda(this);\n this.TO_LOCATION_X_YMAX = GeomUtil$TO_LOCATION_X_YMAX$lambda(this);\n this.TO_LOCATION_X_ZERO = GeomUtil$TO_LOCATION_X_ZERO$lambda(this);\n this.TO_RECTANGLE = GeomUtil$TO_RECTANGLE$lambda(this);\n this.ORDERING_X_0 = Ordering.Companion.from_iajr8b$(new GeomUtil$ORDERING_X$ObjectLiteral());\n this.ORDERING_Y_0 = Ordering.Companion.from_iajr8b$(new GeomUtil$ORDERING_Y$ObjectLiteral());\n this.WITH_X_Y_0 = GeomUtil$WITH_X_Y$lambda;\n this.WITH_X_0 = GeomUtil$WITH_X$lambda;\n this.WITH_Y_0 = GeomUtil$WITH_Y$lambda;\n }\n GeomUtil.prototype.toLocationOrNull_0 = function (x, y) {\n var tmp$;\n if (data.SeriesUtil.isFinite_yrwdxb$(x) && data.SeriesUtil.isFinite_yrwdxb$(y)) {\n tmp$ = new DoubleVector(ensureNotNull(x), ensureNotNull(y));\n } else\n tmp$ = null;\n return tmp$;\n };\n GeomUtil.prototype.with_X_Y_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_X_Y_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.with_X_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_X_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.with_Y_83glv4$ = function (dataPoints) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (this.WITH_Y_0(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.ordered_X_83glv4$ = function (dataPoints) {\n if (this.ORDERING_X_0.isOrdered_p1ys8y$(dataPoints)) {\n return dataPoints;\n }return this.ORDERING_X_0.sortedCopy_m5x2f4$(dataPoints);\n };\n GeomUtil.prototype.ordered_Y_hku6c7$ = function (dataPoints, reversed) {\n var ordering = reversed ? this.ORDERING_Y_0.reverse() : this.ORDERING_Y_0;\n if (ordering.isOrdered_p1ys8y$(dataPoints)) {\n return dataPoints;\n }return ordering.sortedCopy_m5x2f4$(dataPoints);\n };\n GeomUtil.prototype.widthPx_c6teas$ = function (p, ctx, minWidth) {\n var w = p.width();\n var width = ensureNotNull(w) * ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n return JsMath.max(width, minWidth);\n };\n GeomUtil.prototype.withDefined_2oeq97$ = function (dataPoints, aes) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_fl3lpi$ = function (dataPoints, aes0, aes1) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_7jazl$ = function (dataPoints, aes0, aes1, aes2) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1) && element.defined_896ixz$(aes2))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.withDefined_i1kplo$ = function (dataPoints, aes0, aes1, aes2, aes3) {\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.defined_896ixz$(aes0) && element.defined_896ixz$(aes1) && element.defined_896ixz$(aes2) && element.defined_896ixz$(aes3))\n destination.add_11rb$(element);\n }\n return destination;\n };\n GeomUtil.prototype.rectangleByDataPoint_dyn5n6$ = function (p, ctx) {\n var x = ensureNotNull(p.x());\n var y = ensureNotNull(p.y());\n var width = this.widthPx_c6teas$(p, ctx, 2.0);\n var origin;\n var dimensions;\n if (y >= 0) {\n origin = new DoubleVector(x - width / 2, 0.0);\n dimensions = new DoubleVector(width, y);\n } else {\n origin = new DoubleVector(x - width / 2, y);\n dimensions = new DoubleVector(width, -y);\n }\n return new DoubleRectangle(origin, dimensions);\n };\n GeomUtil.prototype.createGroups_83glv4$ = function (dataPoints) {\n var tmp$;\n var pointsByGroup = HashMap_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var group = ensureNotNull(p.group());\n if (!pointsByGroup.containsKey_11rb$(group)) {\n var value = ArrayList_init();\n pointsByGroup.put_xwzc9p$(group, value);\n }ensureNotNull(pointsByGroup.get_11rb$(group)).add_11rb$(p);\n }\n return pointsByGroup;\n };\n GeomUtil.prototype.rectToGeometry_6y0v78$ = function (minX, minY, maxX, maxY) {\n return listOf([new DoubleVector(minX, minY), new DoubleVector(minX, maxY), new DoubleVector(maxX, maxY), new DoubleVector(maxX, minY), new DoubleVector(minX, minY)]);\n };\n function GeomUtil$TO_LOCATION_X_Y$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.y());\n };\n }\n function GeomUtil$TO_LOCATION_X_YMIN$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.ymin());\n };\n }\n function GeomUtil$TO_LOCATION_X_YMAX$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), p.ymax());\n };\n }\n function GeomUtil$TO_LOCATION_X_ZERO$lambda(this$GeomUtil) {\n return function (p) {\n return this$GeomUtil.toLocationOrNull_0(p.x(), 0.0);\n };\n }\n function GeomUtil$TO_RECTANGLE$lambda(this$GeomUtil) {\n return function (p) {\n if (data.SeriesUtil.allFinite_rd1tgs$(p.xmin(), p.ymin(), p.xmax(), p.ymax())) {\n return this$GeomUtil.rectToGeometry_6y0v78$(ensureNotNull(p.xmin()), ensureNotNull(p.ymin()), ensureNotNull(p.xmax()), ensureNotNull(p.ymax()));\n } else {\n return emptyList();\n }\n };\n }\n function GeomUtil$ORDERING_X$ObjectLiteral() {\n }\n GeomUtil$ORDERING_X$ObjectLiteral.prototype.compare = function (a, b) {\n var x1 = a != null ? a.x() : null;\n var x2 = b != null ? b.x() : null;\n if (x1 == null || x2 == null)\n return 0;\n else\n return Kotlin.compareTo(x1, x2);\n };\n GeomUtil$ORDERING_X$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n function GeomUtil$ORDERING_Y$ObjectLiteral() {\n }\n GeomUtil$ORDERING_Y$ObjectLiteral.prototype.compare = function (a, b) {\n var y1 = a != null ? a.y() : null;\n var y2 = b != null ? b.y() : null;\n if (y1 == null || y2 == null)\n return 0;\n else\n return Kotlin.compareTo(y1, y2);\n };\n GeomUtil$ORDERING_Y$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Comparator]\n };\n function GeomUtil$WITH_X_Y$lambda(pointAes) {\n return data.SeriesUtil.allFinite_jma9l8$(pointAes.x(), pointAes.y());\n }\n function GeomUtil$WITH_X$lambda(pointAes) {\n return data.SeriesUtil.isFinite_yrwdxb$(pointAes.x());\n }\n function GeomUtil$WITH_Y$lambda(pointAes) {\n return data.SeriesUtil.isFinite_yrwdxb$(pointAes.y());\n }\n GeomUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomUtil',\n interfaces: []\n };\n var GeomUtil_instance = null;\n function GeomUtil_getInstance() {\n if (GeomUtil_instance === null) {\n new GeomUtil();\n }return GeomUtil_instance;\n }\n function HintColorUtil() {\n HintColorUtil_instance = this;\n }\n HintColorUtil.prototype.fromColor_l6g9mh$ = function (p) {\n return this.fromColorValue_o14uds$(ensureNotNull(p.color()), ensureNotNull(p.alpha()));\n };\n HintColorUtil.prototype.fromFill_l6g9mh$ = function (p) {\n return this.fromColorValue_o14uds$(ensureNotNull(p.fill()), ensureNotNull(p.alpha()));\n };\n HintColorUtil.prototype.fromColorValue_o14uds$ = function (color, alpha) {\n var tmp$;\n var intAlpha = numberToInt(255 * alpha);\n if (values.Colors.solid_98b62m$(color)) {\n tmp$ = color.changeAlpha_za3lpa$(intAlpha);\n } else\n tmp$ = color;\n return tmp$;\n };\n HintColorUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'HintColorUtil',\n interfaces: []\n };\n var HintColorUtil_instance = null;\n function HintColorUtil_getInstance() {\n if (HintColorUtil_instance === null) {\n new HintColorUtil();\n }return HintColorUtil_instance;\n }\n function HintsCollection(myPoint, myHelper) {\n this.myPoint_0 = myPoint;\n this.myHelper_0 = myHelper;\n this.myHints_0 = HashMap_init();\n }\n Object.defineProperty(HintsCollection.prototype, 'hints', {\n configurable: true,\n get: function () {\n return this.myHints_0;\n }\n });\n HintsCollection.prototype.addHint_p9kkqu$ = function (hintConfig) {\n var coord = this.getCoord_0(hintConfig);\n if (coord != null) {\n var $receiver = this.hints;\n var key = hintConfig.aes;\n var value = this.createHint_0(hintConfig, coord);\n $receiver.put_xwzc9p$(key, value);\n }return this;\n };\n HintsCollection.prototype.getCoord_0 = function (hintConfig) {\n var tmp$;\n if (hintConfig.x == null) {\n throw IllegalArgumentException_init('x coord is not set');\n }var aes = hintConfig.aes;\n if (!this.myPoint_0.defined_896ixz$(aes)) {\n tmp$ = null;\n } else\n tmp$ = this.myHelper_0.toClient_tkjljq$(new DoubleVector(ensureNotNull(hintConfig.x), ensureNotNull(this.myPoint_0.get_31786j$(aes))), this.myPoint_0);\n return tmp$;\n };\n HintsCollection.prototype.createHint_0 = function (hintConfig, coord) {\n var tmp$, tmp$_0;\n var objectRadius = hintConfig.objectRadius;\n var color = hintConfig.color_8be2vx$;\n if (objectRadius == null) {\n throw IllegalArgumentException_init('object radius is not set');\n }tmp$ = hintConfig.kind;\n if (equals(tmp$, TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().verticalTooltip_6lq1u6$(coord, objectRadius, color);\n else if (equals(tmp$, TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().horizontalTooltip_6lq1u6$(coord, objectRadius, color);\n else if (equals(tmp$, TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance()))\n tmp$_0 = TipLayoutHint$Companion_getInstance().cursorTooltip_itpcqk$(coord, color);\n else\n throw IllegalArgumentException_init('Unknown hint kind: ' + toString(hintConfig.kind));\n return tmp$_0;\n };\n function HintsCollection$HintConfigFactory() {\n this.myDefaultObjectRadius_0 = null;\n this.myDefaultX_0 = null;\n this.myDefaultColor_0 = null;\n this.myDefaultKind_0 = null;\n }\n HintsCollection$HintConfigFactory.prototype.defaultObjectRadius_14dthe$ = function (defaultObjectRadius) {\n this.myDefaultObjectRadius_0 = defaultObjectRadius;\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.defaultX_14dthe$ = function (defaultX) {\n this.myDefaultX_0 = defaultX;\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.defaultColor_yo1m5r$ = function (v, alpha) {\n if (alpha != null) {\n this.myDefaultColor_0 = v.changeAlpha_za3lpa$(numberToInt(255 * alpha));\n } else {\n this.myDefaultColor_0 = v;\n }\n return this;\n };\n HintsCollection$HintConfigFactory.prototype.create_vktour$ = function (aes) {\n return new HintsCollection$HintConfigFactory$HintConfig(this, aes);\n };\n HintsCollection$HintConfigFactory.prototype.defaultKind_nnfttk$ = function (kind) {\n this.myDefaultKind_0 = kind;\n return this;\n };\n function HintsCollection$HintConfigFactory$HintConfig($outer, aes) {\n this.$outer = $outer;\n this.aes = aes;\n this.kind = null;\n this.objectRadius_u2tfw5$_0 = null;\n this.x_is741i$_0 = null;\n this.color_8be2vx$_ng3d4v$_0 = null;\n this.objectRadius = this.$outer.myDefaultObjectRadius_0;\n this.x = this.$outer.myDefaultX_0;\n this.kind = this.$outer.myDefaultKind_0;\n this.color_8be2vx$ = this.$outer.myDefaultColor_0;\n }\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'objectRadius', {\n configurable: true,\n get: function () {\n return this.objectRadius_u2tfw5$_0;\n },\n set: function (objectRadius) {\n this.objectRadius_u2tfw5$_0 = objectRadius;\n }\n });\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'x', {\n configurable: true,\n get: function () {\n return this.x_is741i$_0;\n },\n set: function (x) {\n this.x_is741i$_0 = x;\n }\n });\n Object.defineProperty(HintsCollection$HintConfigFactory$HintConfig.prototype, 'color_8be2vx$', {\n configurable: true,\n get: function () {\n return this.color_8be2vx$_ng3d4v$_0;\n },\n set: function (color) {\n this.color_8be2vx$_ng3d4v$_0 = color;\n }\n });\n HintsCollection$HintConfigFactory$HintConfig.prototype.objectRadius_14dthe$ = function (v) {\n this.objectRadius = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.prototype.x_14dthe$ = function (v) {\n this.x = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.prototype.color_98b62m$ = function (v) {\n this.color_8be2vx$ = v;\n return this;\n };\n HintsCollection$HintConfigFactory$HintConfig.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintConfig',\n interfaces: []\n };\n HintsCollection$HintConfigFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintConfigFactory',\n interfaces: []\n };\n HintsCollection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HintsCollection',\n interfaces: []\n };\n function LinePathConstructor(myTargetCollector, myDataPoints, myLinesHelper, myClosePath) {\n LinePathConstructor$Companion_getInstance();\n this.myTargetCollector_0 = myTargetCollector;\n this.myDataPoints_0 = myDataPoints;\n this.myLinesHelper_0 = myLinesHelper;\n this.myClosePath_0 = myClosePath;\n }\n LinePathConstructor.prototype.construct_6taknv$ = function (withHints) {\n var tmp$;\n var linePaths = ArrayList_init();\n var multiPointDataList = this.createMultiPointDataByGroup_0();\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n linePaths.addAll_brywnq$(this.myLinesHelper_0.createPaths_edlkk9$(multiPointData.aes, multiPointData.points, this.myClosePath_0));\n }\n if (withHints) {\n this.buildHints_0(multiPointDataList);\n }return linePaths;\n };\n LinePathConstructor.prototype.buildHints = function () {\n this.buildHints_0(this.createMultiPointDataByGroup_0());\n };\n LinePathConstructor.prototype.buildHints_0 = function (multiPointDataList) {\n var tmp$;\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n if (this.myClosePath_0) {\n this.myTargetCollector_0.addPolygon_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromFill_l6g9mh$(multiPointData.aes)));\n } else {\n this.myTargetCollector_0.addPath_sa5m83$(multiPointData.points, multiPointData.localToGlobalIndex, GeomTargetCollector$TooltipParams$Companion_getInstance().params().setColor_98b62m$(HintColorUtil_getInstance().fromColor_l6g9mh$(multiPointData.aes)));\n }\n }\n };\n function LinePathConstructor$createMultiPointDataByGroup$lambda(this$LinePathConstructor) {\n return function (p) {\n return this$LinePathConstructor.myLinesHelper_0.toClient_tkjljq$(ensureNotNull(GeomUtil_getInstance().TO_LOCATION_X_Y(p)), p);\n };\n }\n LinePathConstructor.prototype.createMultiPointDataByGroup_0 = function () {\n return MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(this.myDataPoints_0, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(LinePathConstructor$createMultiPointDataByGroup$lambda(this)), MultiPointDataConstructor_getInstance().reducer_8555vt$(LinePathConstructor$Companion_getInstance().DROP_POINT_DISTANCE_0, this.myClosePath_0));\n };\n function LinePathConstructor$Companion() {\n LinePathConstructor$Companion_instance = this;\n this.DROP_POINT_DISTANCE_0 = 0.999;\n }\n LinePathConstructor$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinePathConstructor$Companion_instance = null;\n function LinePathConstructor$Companion_getInstance() {\n if (LinePathConstructor$Companion_instance === null) {\n new LinePathConstructor$Companion();\n }return LinePathConstructor$Companion_instance;\n }\n LinePathConstructor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinePathConstructor',\n interfaces: []\n };\n function LinesHelper(pos, coord, ctx) {\n GeomHelper.call(this, pos, coord, ctx);\n this.myAlphaFilter_nxoahd$_0 = LinesHelper$myAlphaFilter$lambda;\n this.myWidthFilter_sx37fb$_0 = LinesHelper$myWidthFilter$lambda;\n this.myAlphaEnabled_98jfa$_0 = true;\n }\n LinesHelper.prototype.insertPathSeparators_fr5rf4$_0 = function (rings) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (!result.isEmpty()) {\n result.add_11rb$(LinePath$Companion_getInstance().END_OF_SUBPATH);\n }result.addAll_brywnq$(ring);\n }\n return result;\n };\n LinesHelper.prototype.setAlphaEnabled_6taknv$ = function (b) {\n this.myAlphaEnabled_98jfa$_0 = b;\n };\n LinesHelper.prototype.createLines_rrreuh$ = function (dataPoints, toLocation) {\n return this.createPaths_gfkrhx$_0(dataPoints, toLocation, false);\n };\n function LinesHelper$createPaths$lambda(closure$toLocation) {\n return function (it) {\n return closure$toLocation(it);\n };\n }\n LinesHelper.prototype.createPaths_gfkrhx$_0 = function (dataPoints, toLocation, closePath) {\n var tmp$;\n var paths = ArrayList_init();\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(LinesHelper$createPaths$lambda(toLocation))), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, closePath));\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n paths.addAll_brywnq$(this.createPaths_edlkk9$(multiPointData.aes, multiPointData.points, closePath));\n }\n return paths;\n };\n LinesHelper.prototype.createPaths_edlkk9$ = function (aes, points, closePath) {\n var paths = ArrayList_init();\n if (closePath) {\n paths.add_11rb$(LinePath$Companion_getInstance().polygon_yh26e7$(this.insertPathSeparators_fr5rf4$_0(splitRings(points))));\n } else {\n paths.add_11rb$(LinePath$Companion_getInstance().line_qdtdbw$(points));\n }\n var tmp$;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.decorate_frjrd5$(element, aes, closePath);\n }\n return paths;\n };\n LinesHelper.prototype.createSteps_1fp004$ = function (dataPoints, dir) {\n var tmp$, tmp$_0;\n var pathInfos = ArrayList_init();\n var multiPointDataList = MultiPointDataConstructor_getInstance().createMultiPointDataByGroup_ugj9hh$(dataPoints, MultiPointDataConstructor_getInstance().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(GeomUtil_getInstance().TO_LOCATION_X_Y)), MultiPointDataConstructor_getInstance().reducer_8555vt$(0.999, false));\n tmp$ = multiPointDataList.iterator();\n while (tmp$.hasNext()) {\n var multiPointData = tmp$.next();\n var points = multiPointData.points;\n if (!points.isEmpty()) {\n var newPoints = ArrayList_init();\n var prev = null;\n tmp$_0 = points.iterator();\n while (tmp$_0.hasNext()) {\n var point = tmp$_0.next();\n if (prev != null) {\n var x = dir === StepGeom$Direction$HV_getInstance() ? point.x : prev.x;\n var y = dir === StepGeom$Direction$HV_getInstance() ? prev.y : point.y;\n newPoints.add_11rb$(new DoubleVector(x, y));\n }newPoints.add_11rb$(point);\n prev = point;\n }\n var path = LinePath$Companion_getInstance().line_qdtdbw$(newPoints);\n this.decorate_frjrd5$(path, multiPointData.aes, false);\n pathInfos.add_11rb$(new LinesHelper$PathInfo(path));\n }}\n return pathInfos;\n };\n function LinesHelper$createBands$lambda(closure$toLocationUpper) {\n return function (it) {\n return closure$toLocationUpper(it);\n };\n }\n function LinesHelper$createBands$lambda_0(closure$toLocationLower) {\n return function (it) {\n return closure$toLocationLower(it);\n };\n }\n LinesHelper.prototype.createBands_22uu1u$ = function (dataPoints, toLocationUpper, toLocationLower) {\n var tmp$;\n var lines = ArrayList_init();\n var pointsByGroup = GeomUtil_getInstance().createGroups_83glv4$(dataPoints);\n tmp$ = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(pointsByGroup.keys).iterator();\n while (tmp$.hasNext()) {\n var group = tmp$.next();\n var groupDataPoints = pointsByGroup.get_11rb$(group);\n var points = ArrayList_init_0(this.project_rrreuh$(ensureNotNull(groupDataPoints), LinesHelper$createBands$lambda(toLocationUpper)));\n var lowerPoints = reversed(groupDataPoints);\n points.addAll_brywnq$(this.project_rrreuh$(lowerPoints, LinesHelper$createBands$lambda_0(toLocationLower)));\n if (!points.isEmpty()) {\n var path = LinePath$Companion_getInstance().polygon_yh26e7$(points);\n this.decorateFillingPart_e7h5w8$_0(path, groupDataPoints.get_za3lpa$(0));\n lines.add_11rb$(path);\n }}\n return lines;\n };\n LinesHelper.prototype.decorate_frjrd5$ = function (path, p, filled) {\n var stroke = p.color();\n var strokeAlpha = ensureNotNull(this.myAlphaFilter_nxoahd$_0(AestheticsUtil_getInstance().alpha_il6rhx$(ensureNotNull(stroke), p)));\n path.color().set_11rb$(values.Colors.withOpacity_o14uds$(stroke, strokeAlpha));\n if (!AestheticsUtil_getInstance().ALPHA_CONTROLS_BOTH_8be2vx$ && (filled || !this.myAlphaEnabled_98jfa$_0)) {\n path.color().set_11rb$(stroke);\n }if (filled) {\n this.decorateFillingPart_e7h5w8$_0(path, p);\n }var size = ensureNotNull(this.myWidthFilter_sx37fb$_0(AesScaling_getInstance().strokeWidth_l6g9mh$(p)));\n path.width().set_11rb$(size);\n var lineType = p.lineType();\n if (!(lineType.isBlank || lineType.isSolid)) {\n path.dashArray().set_11rb$(lineType.dashArray);\n }};\n LinesHelper.prototype.decorateFillingPart_e7h5w8$_0 = function (path, p) {\n var fill = p.fill();\n var fillAlpha = ensureNotNull(this.myAlphaFilter_nxoahd$_0(AestheticsUtil_getInstance().alpha_il6rhx$(ensureNotNull(fill), p)));\n path.fill().set_11rb$(values.Colors.withOpacity_o14uds$(fill, fillAlpha));\n };\n LinesHelper.prototype.setAlphaFilter_m9g0ow$ = function (alphaFilter) {\n this.myAlphaFilter_nxoahd$_0 = alphaFilter;\n };\n LinesHelper.prototype.setWidthFilter_m9g0ow$ = function (widthFilter) {\n this.myWidthFilter_sx37fb$_0 = widthFilter;\n };\n function LinesHelper$PathInfo(path) {\n this.path = path;\n }\n LinesHelper$PathInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathInfo',\n interfaces: []\n };\n function LinesHelper$myAlphaFilter$lambda(v) {\n return v;\n }\n function LinesHelper$myWidthFilter$lambda(v) {\n return v;\n }\n LinesHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinesHelper',\n interfaces: [GeomHelper]\n };\n function MappedAesthetics(myAesthetics, myPointAestheticsMapper) {\n this.myAesthetics_0 = myAesthetics;\n this.myPointAestheticsMapper_0 = myPointAestheticsMapper;\n }\n Object.defineProperty(MappedAesthetics.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myAesthetics_0.isEmpty;\n }\n });\n MappedAesthetics.prototype.dataPointAt_za3lpa$ = function (index) {\n return this.myPointAestheticsMapper_0(this.myAesthetics_0.dataPointAt_za3lpa$(index));\n };\n MappedAesthetics.prototype.dataPointCount = function () {\n return this.myAesthetics_0.dataPointCount();\n };\n MappedAesthetics.prototype.dataPoints = function () {\n var source = this.myAesthetics_0.dataPoints();\n var destination = ArrayList_init_1(collectionSizeOrDefault(source, 10));\n var tmp$;\n tmp$ = source.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.myPointAestheticsMapper_0(item));\n }\n return destination;\n };\n MappedAesthetics.prototype.range_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.range: not implemented ' + aes);\n };\n MappedAesthetics.prototype.overallRange_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.overallRange: not implemented ' + aes);\n };\n MappedAesthetics.prototype.resolution_594811$ = function (aes, naValue) {\n throw IllegalStateException_init('MappedAesthetics.resolution: not implemented ' + aes);\n };\n MappedAesthetics.prototype.numericValues_vktour$ = function (aes) {\n throw IllegalStateException_init('MappedAesthetics.numericValues: not implemented ' + aes);\n };\n MappedAesthetics.prototype.groups = function () {\n return this.myAesthetics_0.groups();\n };\n MappedAesthetics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappedAesthetics',\n interfaces: [Aesthetics]\n };\n function MultiPointData(aes, points, localToGlobalIndex, group) {\n this.aes = aes;\n this.points = points;\n this.localToGlobalIndex = localToGlobalIndex;\n this.group = group;\n }\n MultiPointData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPointData',\n interfaces: []\n };\n function MultiPointDataConstructor() {\n MultiPointDataConstructor_instance = this;\n }\n function MultiPointDataConstructor$collector$lambda() {\n return new MultiPointDataConstructor$SimplePointCollector();\n }\n MultiPointDataConstructor.prototype.collector = function () {\n return MultiPointDataConstructor$collector$lambda;\n };\n function MultiPointDataConstructor$reducer$lambda(closure$dropPointDistance, closure$isPolygon) {\n return function () {\n return new MultiPointDataConstructor$PointReducer(closure$dropPointDistance, closure$isPolygon);\n };\n }\n MultiPointDataConstructor.prototype.reducer_8555vt$ = function (dropPointDistance, isPolygon) {\n return MultiPointDataConstructor$reducer$lambda(dropPointDistance, isPolygon);\n };\n function MultiPointDataConstructor$singlePointAppender$lambda(closure$toPoint) {\n return function (aes, coordinateConsumer) {\n coordinateConsumer(closure$toPoint(aes));\n return Unit;\n };\n }\n MultiPointDataConstructor.prototype.singlePointAppender_v9bvvf$ = function (toPoint) {\n return MultiPointDataConstructor$singlePointAppender$lambda(toPoint);\n };\n function MultiPointDataConstructor$multiPointAppender$lambda(closure$toPath) {\n return function (aes, coordinateConsumer) {\n var tmp$;\n tmp$ = closure$toPath(aes).iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n coordinateConsumer(element);\n }\n return Unit;\n };\n }\n MultiPointDataConstructor.prototype.multiPointAppender_t2aup3$ = function (toPath) {\n return MultiPointDataConstructor$multiPointAppender$lambda(toPath);\n };\n MultiPointDataConstructor.prototype.createMultiPointDataByGroup_ugj9hh$ = function (dataPoints, coordinateAppender, pointCollectorSupplier) {\n var tmp$, tmp$_0;\n var multiPointDataCombiners = HashMap_init();\n tmp$ = dataPoints.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var group = p.group();\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = multiPointDataCombiners, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(group)) {\n var key = ensureNotNull(group);\n var value = new MultiPointDataConstructor$MultiPointDataCombiner(coordinateAppender, pointCollectorSupplier());\n multiPointDataCombiners.put_xwzc9p$(key, value);\n }var tmp$_2;\n ensureNotNull((Kotlin.isType(tmp$_2 = multiPointDataCombiners, Map) ? tmp$_2 : throwCCE()).get_11rb$(group)).add_lsjzq4$(p);\n }\n var result = ArrayList_init();\n var sortedGroup = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(multiPointDataCombiners.keys);\n tmp$_0 = sortedGroup.iterator();\n while (tmp$_0.hasNext()) {\n var group_0 = tmp$_0.next();\n var multiPointData = ensureNotNull(multiPointDataCombiners.get_11rb$(group_0)).create_kcn2v3$(group_0);\n if (!multiPointData.points.isEmpty()) {\n result.add_11rb$(multiPointData);\n }}\n return result;\n };\n function MultiPointDataConstructor$PointCollector() {\n }\n MultiPointDataConstructor$PointCollector.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointCollector',\n interfaces: []\n };\n function MultiPointDataConstructor$MultiPointDataCombiner(myCoordinateAppender, myPointCollector) {\n this.myCoordinateAppender_0 = myCoordinateAppender;\n this.myPointCollector_0 = myPointCollector;\n this.myFirstAes_0 = null;\n }\n function MultiPointDataConstructor$MultiPointDataCombiner$add$lambda(this$MultiPointDataCombiner, closure$aes) {\n return function (it) {\n this$MultiPointDataCombiner.myPointCollector_0.add_aqrfag$(it, closure$aes.index());\n return Unit;\n };\n }\n MultiPointDataConstructor$MultiPointDataCombiner.prototype.add_lsjzq4$ = function (aes) {\n if (this.myFirstAes_0 == null) {\n this.myFirstAes_0 = aes;\n }this.myCoordinateAppender_0(aes, MultiPointDataConstructor$MultiPointDataCombiner$add$lambda(this, aes));\n };\n function MultiPointDataConstructor$MultiPointDataCombiner$create$lambda(closure$points) {\n return function (it) {\n return closure$points.second.get_za3lpa$(it);\n };\n }\n MultiPointDataConstructor$MultiPointDataCombiner.prototype.create_kcn2v3$ = function (group) {\n var points = this.myPointCollector_0.points;\n return new MultiPointData(ensureNotNull(this.myFirstAes_0), points.first, MultiPointDataConstructor$MultiPointDataCombiner$create$lambda(points), group);\n };\n MultiPointDataConstructor$MultiPointDataCombiner.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiPointDataCombiner',\n interfaces: []\n };\n function MultiPointDataConstructor$SimplePointCollector() {\n this.myPoints_0 = ArrayList_init();\n this.myIndexes_0 = ArrayList_init();\n }\n Object.defineProperty(MultiPointDataConstructor$SimplePointCollector.prototype, 'points', {\n configurable: true,\n get: function () {\n return new Pair(this.myPoints_0, this.myIndexes_0);\n }\n });\n MultiPointDataConstructor$SimplePointCollector.prototype.add_aqrfag$ = function (coord, index) {\n this.myPoints_0.add_11rb$(ensureNotNull(coord));\n this.myIndexes_0.add_11rb$(index);\n };\n MultiPointDataConstructor$SimplePointCollector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimplePointCollector',\n interfaces: [MultiPointDataConstructor$PointCollector]\n };\n function MultiPointDataConstructor$PointReducer(myDropPointDistance, myPolygon) {\n this.myDropPointDistance_0 = myDropPointDistance;\n this.myPolygon_0 = myPolygon;\n this.myReducedPoints_0 = ArrayList_init();\n this.myReducedIndexes_0 = ArrayList_init();\n this.myLastAdded_0 = null;\n this.myLastPostponed_0 = null;\n this.myRegionStart_0 = null;\n }\n Object.defineProperty(MultiPointDataConstructor$PointReducer.prototype, 'points', {\n configurable: true,\n get: function () {\n if (this.myLastPostponed_0 != null) {\n this.addPoint_0(ensureNotNull(this.myLastPostponed_0).first, ensureNotNull(this.myLastPostponed_0).second);\n this.myLastPostponed_0 = null;\n }return new Pair(this.myReducedPoints_0, this.myReducedIndexes_0);\n }\n });\n MultiPointDataConstructor$PointReducer.prototype.isCloserThan_0 = function (p0, p1, distance) {\n var x = p0.x - p1.x;\n var tmp$ = JsMath.abs(x) < distance;\n if (tmp$) {\n var x_0 = p0.y - p1.y;\n tmp$ = JsMath.abs(x_0) < distance;\n }return tmp$;\n };\n MultiPointDataConstructor$PointReducer.prototype.add_aqrfag$ = function (coord, index) {\n if (coord == null) {\n return;\n }if (this.myLastAdded_0 == null) {\n this.storePoint_0(coord, index);\n return;\n }if (this.needPostpone_0(coord)) {\n this.postponePoint_0(coord, index);\n } else {\n if (this.myLastPostponed_0 != null) {\n this.addPoint_0(ensureNotNull(this.myLastPostponed_0).first, ensureNotNull(this.myLastPostponed_0).second);\n this.myLastPostponed_0 = null;\n }this.storePoint_0(coord, index);\n }\n };\n MultiPointDataConstructor$PointReducer.prototype.needPostpone_0 = function (loc) {\n var closeToAdded = this.areTooClose_0(this.myLastAdded_0, loc);\n var closeToPostponed = this.myLastPostponed_0 == null || this.areTooClose_0(ensureNotNull(this.myLastPostponed_0).first, loc);\n var regionClosePoint = this.isRegionStart_0(loc);\n return closeToAdded && closeToPostponed && !regionClosePoint;\n };\n MultiPointDataConstructor$PointReducer.prototype.postponePoint_0 = function (loc, index) {\n this.myLastPostponed_0 = new Pair(loc, index);\n };\n MultiPointDataConstructor$PointReducer.prototype.storePoint_0 = function (loc, index) {\n this.addPoint_0(loc, index);\n this.myLastAdded_0 = loc;\n this.processRegionStart_0(loc, index);\n };\n MultiPointDataConstructor$PointReducer.prototype.processRegionStart_0 = function (loc, index) {\n if (!this.myPolygon_0) {\n return;\n }if (this.myRegionStart_0 == null) {\n this.myRegionStart_0 = new Pair(loc, index);\n return;\n }if (this.isRegionStart_0(loc)) {\n this.myRegionStart_0 = null;\n this.myLastAdded_0 = null;\n }};\n MultiPointDataConstructor$PointReducer.prototype.isRegionStart_0 = function (loc) {\n var tmp$;\n if (!this.myPolygon_0) {\n return false;\n }if (this.myRegionStart_0 == null) {\n tmp$ = false;\n } else\n tmp$ = equals(ensureNotNull(this.myRegionStart_0).first, loc);\n return tmp$;\n };\n MultiPointDataConstructor$PointReducer.prototype.addPoint_0 = function (loc, index) {\n this.myReducedPoints_0.add_11rb$(loc);\n this.myReducedIndexes_0.add_11rb$(index);\n };\n MultiPointDataConstructor$PointReducer.prototype.areTooClose_0 = function (p1, p2) {\n return this.isCloserThan_0(ensureNotNull(p1), p2, this.myDropPointDistance_0);\n };\n MultiPointDataConstructor$PointReducer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointReducer',\n interfaces: [MultiPointDataConstructor$PointCollector]\n };\n MultiPointDataConstructor.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MultiPointDataConstructor',\n interfaces: []\n };\n var MultiPointDataConstructor_instance = null;\n function MultiPointDataConstructor_getInstance() {\n if (MultiPointDataConstructor_instance === null) {\n new MultiPointDataConstructor();\n }return MultiPointDataConstructor_instance;\n }\n function RectTargetCollectorHelper(rectanglesHelper, rectangleByDataPoint, fillByDataPoint, tooltipKind) {\n this.rectanglesHelper_0 = rectanglesHelper;\n this.rectangleByDataPoint_0 = rectangleByDataPoint;\n this.fillByDataPoint_0 = fillByDataPoint;\n this.tooltipKind_0 = tooltipKind;\n }\n function RectTargetCollectorHelper$collectTo$lambda(closure$targetCollector, this$RectTargetCollectorHelper) {\n return function (p, rectangle) {\n closure$targetCollector.addRectangle_bxzvr8$(p.index(), rectangle, this$RectTargetCollectorHelper.tooltipParams_0(p), this$RectTargetCollectorHelper.tooltipKind_0);\n return Unit;\n };\n }\n RectTargetCollectorHelper.prototype.collectTo_xrq6q$ = function (targetCollector) {\n this.rectanglesHelper_0.iterateRectangleGeometry_xwqduk$(this.rectangleByDataPoint_0, RectTargetCollectorHelper$collectTo$lambda(targetCollector, this));\n };\n RectTargetCollectorHelper.prototype.tooltipParams_0 = function (p) {\n var params = GeomTargetCollector$TooltipParams$Companion_getInstance().params();\n params.setColor_98b62m$(this.fillByDataPoint_0(p));\n return params;\n };\n RectTargetCollectorHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectTargetCollectorHelper',\n interfaces: []\n };\n function RectanglesHelper(myAesthetics, pos, coord, ctx) {\n GeomHelper.call(this, pos, coord, ctx);\n this.myAesthetics_0 = myAesthetics;\n }\n RectanglesHelper.prototype.createRectangles_rezc4r$ = function (rectangleByDataPoint) {\n var tmp$, tmp$_0;\n var result = ArrayList_init();\n tmp$ = this.myAesthetics_0.dataPointCount();\n for (var index = 0; index < tmp$; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n tmp$_0 = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (tmp$_0 == null) {\n continue;\n }var clientRect = tmp$_0;\n var svgRect = SvgRectElement_init_0(clientRect);\n GeomHelper$Companion_getInstance().decorate_d9jm6k$(svgRect, p);\n result.add_11rb$(svgRect);\n }\n return result;\n };\n RectanglesHelper.prototype.iterateRectangleGeometry_xwqduk$ = function (rectangleByDataPoint, iterator) {\n var tmp$;\n tmp$ = this.myAesthetics_0.dataPointCount();\n for (var index = 0; index < tmp$; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n var rect = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (rect != null) {\n iterator(p, rect);\n }}\n };\n RectanglesHelper.prototype.createSlimRectangles_rezc4r$ = function (rectangleByDataPoint) {\n var tmp$;\n var pointCount = this.myAesthetics_0.dataPointCount();\n var group = slim.SvgSlimElements.g_za3lpa$(pointCount);\n for (var index = 0; index < pointCount; index++) {\n var p = this.myAesthetics_0.dataPointAt_za3lpa$(index);\n tmp$ = this.toClientRect_7iz5gz$(p, rectangleByDataPoint);\n if (tmp$ == null) {\n continue;\n }var clientRect = tmp$;\n var slimShape = slim.SvgSlimElements.rect_6y0v78$(clientRect.left, clientRect.top, clientRect.width, clientRect.height);\n GeomHelper$Companion_getInstance().decorateSlimShape_gb6c9f$(slimShape, p);\n slimShape.appendTo_i2myw1$(group);\n }\n return group;\n };\n RectanglesHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectanglesHelper',\n interfaces: [GeomHelper]\n };\n function ContextualMapping(tooltipLines, tooltipAnchor, tooltipMinWidth, tooltipColor, ignoreInvisibleTargets, hasGeneralTooltip, hasAxisTooltip, isCrosshairEnabled) {\n this.tooltipLines_85czob$_0 = tooltipLines;\n this.tooltipAnchor = tooltipAnchor;\n this.tooltipMinWidth = tooltipMinWidth;\n this.tooltipColor = tooltipColor;\n this.ignoreInvisibleTargets = ignoreInvisibleTargets;\n this.hasGeneralTooltip = hasGeneralTooltip;\n this.hasAxisTooltip = hasAxisTooltip;\n this.isCrosshairEnabled = isCrosshairEnabled;\n }\n ContextualMapping.prototype.getDataPoints_za3lpa$ = function (index) {\n var $receiver = this.tooltipLines_85czob$_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element.getDataPoint_za3lpa$(index)) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return destination;\n };\n ContextualMapping.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContextualMapping',\n interfaces: []\n };\n function DataContext(dataFrame, mappedDataAccess) {\n this.dataFrame = dataFrame;\n this.mappedDataAccess = mappedDataAccess;\n }\n DataContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataContext',\n interfaces: []\n };\n DataContext.prototype.component1 = function () {\n return this.dataFrame;\n };\n DataContext.prototype.component2 = function () {\n return this.mappedDataAccess;\n };\n DataContext.prototype.copy_nqispu$ = function (dataFrame, mappedDataAccess) {\n return new DataContext(dataFrame === void 0 ? this.dataFrame : dataFrame, mappedDataAccess === void 0 ? this.mappedDataAccess : mappedDataAccess);\n };\n DataContext.prototype.toString = function () {\n return 'DataContext(dataFrame=' + Kotlin.toString(this.dataFrame) + (', mappedDataAccess=' + Kotlin.toString(this.mappedDataAccess)) + ')';\n };\n DataContext.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.dataFrame) | 0;\n result = result * 31 + Kotlin.hashCode(this.mappedDataAccess) | 0;\n return result;\n };\n DataContext.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.dataFrame, other.dataFrame) && Kotlin.equals(this.mappedDataAccess, other.mappedDataAccess)))));\n };\n function GeomTarget(hitIndex, tipLayoutHint, aesTipLayoutHints) {\n this.hitIndex = hitIndex;\n this.tipLayoutHint_hymvab$_0 = tipLayoutHint;\n this.aesTipLayoutHints_wcnfmb$_0 = aesTipLayoutHints;\n }\n Object.defineProperty(GeomTarget.prototype, 'tipLayoutHint', {\n get: function () {\n return this.tipLayoutHint_hymvab$_0;\n }\n });\n Object.defineProperty(GeomTarget.prototype, 'aesTipLayoutHints', {\n get: function () {\n return this.aesTipLayoutHints_wcnfmb$_0;\n }\n });\n GeomTarget.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomTarget',\n interfaces: []\n };\n function GeomTargetCollector() {\n }\n GeomTargetCollector.prototype.addPoint_cnsimy$ = function (index, point, radius, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance();\n callback$default ? callback$default(index, point, radius, tooltipParams, tooltipKind) : this.addPoint_cnsimy$$default(index, point, radius, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addRectangle_bxzvr8$ = function (index, rectangle, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n callback$default ? callback$default(index, rectangle, tooltipParams, tooltipKind) : this.addRectangle_bxzvr8$$default(index, rectangle, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addPath_sa5m83$ = function (points, localToGlobalIndex, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n callback$default ? callback$default(points, localToGlobalIndex, tooltipParams, tooltipKind) : this.addPath_sa5m83$$default(points, localToGlobalIndex, tooltipParams, tooltipKind);\n };\n GeomTargetCollector.prototype.addPolygon_sa5m83$ = function (points, localToGlobalIndex, tooltipParams, tooltipKind, callback$default) {\n if (tooltipKind === void 0)\n tooltipKind = TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance();\n callback$default ? callback$default(points, localToGlobalIndex, tooltipParams, tooltipKind) : this.addPolygon_sa5m83$$default(points, localToGlobalIndex, tooltipParams, tooltipKind);\n };\n function GeomTargetCollector$TooltipParams() {\n GeomTargetCollector$TooltipParams$Companion_getInstance();\n this.myTipLayoutHints_0 = emptyMap();\n this.myColor_0 = Color.Companion.GRAY;\n this.myStemLength_0 = TipLayoutHint$StemLength$NORMAL_getInstance();\n }\n GeomTargetCollector$TooltipParams.prototype.getTipLayoutHints = function () {\n return this.myTipLayoutHints_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setTipLayoutHints_vgcgsc$ = function (tipLayoutHints) {\n this.myTipLayoutHints_0 = tipLayoutHints;\n return this;\n };\n GeomTargetCollector$TooltipParams.prototype.getColor = function () {\n return this.myColor_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setColor_98b62m$ = function (color) {\n this.myColor_0 = color;\n return this;\n };\n GeomTargetCollector$TooltipParams.prototype.getStemLength = function () {\n return this.myStemLength_0;\n };\n GeomTargetCollector$TooltipParams.prototype.setStemLength_6gy7x$ = function (stemLength) {\n this.myStemLength_0 = stemLength;\n return this;\n };\n function GeomTargetCollector$TooltipParams$Companion() {\n GeomTargetCollector$TooltipParams$Companion_instance = this;\n }\n GeomTargetCollector$TooltipParams$Companion.prototype.params = function () {\n return new GeomTargetCollector$TooltipParams();\n };\n GeomTargetCollector$TooltipParams$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomTargetCollector$TooltipParams$Companion_instance = null;\n function GeomTargetCollector$TooltipParams$Companion_getInstance() {\n if (GeomTargetCollector$TooltipParams$Companion_instance === null) {\n new GeomTargetCollector$TooltipParams$Companion();\n }return GeomTargetCollector$TooltipParams$Companion_instance;\n }\n GeomTargetCollector$TooltipParams.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipParams',\n interfaces: []\n };\n GeomTargetCollector.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomTargetCollector',\n interfaces: []\n };\n function GeomTargetLocator() {\n }\n function GeomTargetLocator$LookupSpace(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomTargetLocator$LookupSpace_initFields() {\n GeomTargetLocator$LookupSpace_initFields = function () {\n };\n GeomTargetLocator$LookupSpace$X_instance = new GeomTargetLocator$LookupSpace('X', 0);\n GeomTargetLocator$LookupSpace$XY_instance = new GeomTargetLocator$LookupSpace('XY', 1);\n GeomTargetLocator$LookupSpace$NONE_instance = new GeomTargetLocator$LookupSpace('NONE', 2);\n }\n var GeomTargetLocator$LookupSpace$X_instance;\n function GeomTargetLocator$LookupSpace$X_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$X_instance;\n }\n var GeomTargetLocator$LookupSpace$XY_instance;\n function GeomTargetLocator$LookupSpace$XY_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$XY_instance;\n }\n var GeomTargetLocator$LookupSpace$NONE_instance;\n function GeomTargetLocator$LookupSpace$NONE_getInstance() {\n GeomTargetLocator$LookupSpace_initFields();\n return GeomTargetLocator$LookupSpace$NONE_instance;\n }\n GeomTargetLocator$LookupSpace.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupSpace',\n interfaces: [Enum]\n };\n function GeomTargetLocator$LookupSpace$values() {\n return [GeomTargetLocator$LookupSpace$X_getInstance(), GeomTargetLocator$LookupSpace$XY_getInstance(), GeomTargetLocator$LookupSpace$NONE_getInstance()];\n }\n GeomTargetLocator$LookupSpace.values = GeomTargetLocator$LookupSpace$values;\n function GeomTargetLocator$LookupSpace$valueOf(name) {\n switch (name) {\n case 'X':\n return GeomTargetLocator$LookupSpace$X_getInstance();\n case 'XY':\n return GeomTargetLocator$LookupSpace$XY_getInstance();\n case 'NONE':\n return GeomTargetLocator$LookupSpace$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace.' + name);\n }\n }\n GeomTargetLocator$LookupSpace.valueOf_61zpoe$ = GeomTargetLocator$LookupSpace$valueOf;\n function GeomTargetLocator$LookupStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function GeomTargetLocator$LookupStrategy_initFields() {\n GeomTargetLocator$LookupStrategy_initFields = function () {\n };\n GeomTargetLocator$LookupStrategy$HOVER_instance = new GeomTargetLocator$LookupStrategy('HOVER', 0);\n GeomTargetLocator$LookupStrategy$NEAREST_instance = new GeomTargetLocator$LookupStrategy('NEAREST', 1);\n GeomTargetLocator$LookupStrategy$NONE_instance = new GeomTargetLocator$LookupStrategy('NONE', 2);\n }\n var GeomTargetLocator$LookupStrategy$HOVER_instance;\n function GeomTargetLocator$LookupStrategy$HOVER_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$HOVER_instance;\n }\n var GeomTargetLocator$LookupStrategy$NEAREST_instance;\n function GeomTargetLocator$LookupStrategy$NEAREST_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$NEAREST_instance;\n }\n var GeomTargetLocator$LookupStrategy$NONE_instance;\n function GeomTargetLocator$LookupStrategy$NONE_getInstance() {\n GeomTargetLocator$LookupStrategy_initFields();\n return GeomTargetLocator$LookupStrategy$NONE_instance;\n }\n GeomTargetLocator$LookupStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupStrategy',\n interfaces: [Enum]\n };\n function GeomTargetLocator$LookupStrategy$values() {\n return [GeomTargetLocator$LookupStrategy$HOVER_getInstance(), GeomTargetLocator$LookupStrategy$NEAREST_getInstance(), GeomTargetLocator$LookupStrategy$NONE_getInstance()];\n }\n GeomTargetLocator$LookupStrategy.values = GeomTargetLocator$LookupStrategy$values;\n function GeomTargetLocator$LookupStrategy$valueOf(name) {\n switch (name) {\n case 'HOVER':\n return GeomTargetLocator$LookupStrategy$HOVER_getInstance();\n case 'NEAREST':\n return GeomTargetLocator$LookupStrategy$NEAREST_getInstance();\n case 'NONE':\n return GeomTargetLocator$LookupStrategy$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy.' + name);\n }\n }\n GeomTargetLocator$LookupStrategy.valueOf_61zpoe$ = GeomTargetLocator$LookupStrategy$valueOf;\n function GeomTargetLocator$LookupSpec(lookupSpace, lookupStrategy) {\n GeomTargetLocator$LookupSpec$Companion_getInstance();\n this.lookupSpace = lookupSpace;\n this.lookupStrategy = lookupStrategy;\n }\n function GeomTargetLocator$LookupSpec$Companion() {\n GeomTargetLocator$LookupSpec$Companion_instance = this;\n this.NONE = new GeomTargetLocator$LookupSpec(GeomTargetLocator$LookupSpace$NONE_getInstance(), GeomTargetLocator$LookupStrategy$NONE_getInstance());\n }\n GeomTargetLocator$LookupSpec$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomTargetLocator$LookupSpec$Companion_instance = null;\n function GeomTargetLocator$LookupSpec$Companion_getInstance() {\n if (GeomTargetLocator$LookupSpec$Companion_instance === null) {\n new GeomTargetLocator$LookupSpec$Companion();\n }return GeomTargetLocator$LookupSpec$Companion_instance;\n }\n GeomTargetLocator$LookupSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupSpec',\n interfaces: []\n };\n function GeomTargetLocator$LookupResult(targets, distance, geomKind, contextualMapping, isCrosshairEnabled) {\n this.targets = targets;\n this.distance_isy6z$_0 = distance;\n this.geomKind_g9qdl6$_0 = geomKind;\n this.contextualMapping_r13yoz$_0 = contextualMapping;\n this.isCrosshairEnabled = isCrosshairEnabled;\n }\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'distance', {\n get: function () {\n return this.distance_isy6z$_0;\n }\n });\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'geomKind', {\n get: function () {\n return this.geomKind_g9qdl6$_0;\n }\n });\n Object.defineProperty(GeomTargetLocator$LookupResult.prototype, 'contextualMapping', {\n get: function () {\n return this.contextualMapping_r13yoz$_0;\n }\n });\n GeomTargetLocator$LookupResult.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LookupResult',\n interfaces: []\n };\n GeomTargetLocator.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomTargetLocator',\n interfaces: []\n };\n function HitShape(kind, shape) {\n HitShape$Companion_getInstance();\n this.kind = kind;\n this.shape_kp8049$_0 = shape;\n }\n Object.defineProperty(HitShape.prototype, 'point', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.shape_kp8049$_0, HitShape$DoubleCircle) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(HitShape.prototype, 'rect', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.shape_kp8049$_0, DoubleRectangle) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(HitShape.prototype, 'points', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Not applicable to ' + this.kind);\n }\n });\n function HitShape$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function HitShape$Kind_initFields() {\n HitShape$Kind_initFields = function () {\n };\n HitShape$Kind$POINT_instance = new HitShape$Kind('POINT', 0);\n HitShape$Kind$RECT_instance = new HitShape$Kind('RECT', 1);\n HitShape$Kind$POLYGON_instance = new HitShape$Kind('POLYGON', 2);\n HitShape$Kind$PATH_instance = new HitShape$Kind('PATH', 3);\n }\n var HitShape$Kind$POINT_instance;\n function HitShape$Kind$POINT_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$POINT_instance;\n }\n var HitShape$Kind$RECT_instance;\n function HitShape$Kind$RECT_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$RECT_instance;\n }\n var HitShape$Kind$POLYGON_instance;\n function HitShape$Kind$POLYGON_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$POLYGON_instance;\n }\n var HitShape$Kind$PATH_instance;\n function HitShape$Kind$PATH_getInstance() {\n HitShape$Kind_initFields();\n return HitShape$Kind$PATH_instance;\n }\n HitShape$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function HitShape$Kind$values() {\n return [HitShape$Kind$POINT_getInstance(), HitShape$Kind$RECT_getInstance(), HitShape$Kind$POLYGON_getInstance(), HitShape$Kind$PATH_getInstance()];\n }\n HitShape$Kind.values = HitShape$Kind$values;\n function HitShape$Kind$valueOf(name) {\n switch (name) {\n case 'POINT':\n return HitShape$Kind$POINT_getInstance();\n case 'RECT':\n return HitShape$Kind$RECT_getInstance();\n case 'POLYGON':\n return HitShape$Kind$POLYGON_getInstance();\n case 'PATH':\n return HitShape$Kind$PATH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.HitShape.Kind.' + name);\n }\n }\n HitShape$Kind.valueOf_61zpoe$ = HitShape$Kind$valueOf;\n function HitShape$DoubleCircle(center, radius) {\n this.center = center;\n this.radius = radius;\n }\n HitShape$DoubleCircle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleCircle',\n interfaces: []\n };\n function HitShape$Companion() {\n HitShape$Companion_instance = this;\n }\n HitShape$Companion.prototype.point_e1sv3v$ = function (p, radius) {\n return new HitShape(HitShape$Kind$POINT_getInstance(), new HitShape$DoubleCircle(p, radius));\n };\n HitShape$Companion.prototype.rect_wthzt5$ = function (r) {\n return new HitShape(HitShape$Kind$RECT_getInstance(), r);\n };\n HitShape$Companion.prototype.path_ytws2g$ = function (points) {\n return this.shapeWithPath_0(HitShape$Kind$PATH_getInstance(), points);\n };\n HitShape$Companion.prototype.polygon_ytws2g$ = function (points) {\n return this.shapeWithPath_0(HitShape$Kind$POLYGON_getInstance(), points);\n };\n function HitShape$Companion$shapeWithPath$ObjectLiteral(closure$points, kind, shape) {\n this.closure$points = closure$points;\n HitShape.call(this, kind, shape);\n }\n Object.defineProperty(HitShape$Companion$shapeWithPath$ObjectLiteral.prototype, 'points', {\n configurable: true,\n get: function () {\n return this.closure$points;\n }\n });\n HitShape$Companion$shapeWithPath$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [HitShape]\n };\n HitShape$Companion.prototype.shapeWithPath_0 = function (kind, points) {\n return new HitShape$Companion$shapeWithPath$ObjectLiteral(points, kind, points);\n };\n HitShape$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HitShape$Companion_instance = null;\n function HitShape$Companion_getInstance() {\n if (HitShape$Companion_instance === null) {\n new HitShape$Companion();\n }return HitShape$Companion_instance;\n }\n HitShape.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HitShape',\n interfaces: []\n };\n function MappedDataAccess() {\n }\n function MappedDataAccess$MappedData(label, value, isContinuous) {\n this.label = label;\n this.value = value;\n this.isContinuous = isContinuous;\n }\n MappedDataAccess$MappedData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappedData',\n interfaces: []\n };\n MappedDataAccess.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MappedDataAccess',\n interfaces: []\n };\n function NullGeomTargetCollector() {\n }\n NullGeomTargetCollector.prototype.addPoint_cnsimy$$default = function (index, point, radius, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addRectangle_bxzvr8$$default = function (index, rectangle, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addPath_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.prototype.addPolygon_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n };\n NullGeomTargetCollector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NullGeomTargetCollector',\n interfaces: [GeomTargetCollector]\n };\n function TipLayoutHint(kind, coord, objectRadius, color, stemLength) {\n TipLayoutHint$Companion_getInstance();\n this.kind_mdwpny$_0 = kind;\n this.coord_cmx6yh$_0 = coord;\n this.objectRadius_tv0yd$_0 = objectRadius;\n this.color_cmv83v$_0 = color;\n this.stemLength_x5log9$_0 = stemLength;\n }\n Object.defineProperty(TipLayoutHint.prototype, 'kind', {\n get: function () {\n return this.kind_mdwpny$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'coord', {\n get: function () {\n return this.coord_cmx6yh$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'objectRadius', {\n get: function () {\n return this.objectRadius_tv0yd$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'color', {\n get: function () {\n return this.color_cmv83v$_0;\n }\n });\n Object.defineProperty(TipLayoutHint.prototype, 'stemLength', {\n get: function () {\n return this.stemLength_x5log9$_0;\n }\n });\n function TipLayoutHint$StemLength(name, ordinal, value) {\n Enum.call(this);\n this.value = value;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TipLayoutHint$StemLength_initFields() {\n TipLayoutHint$StemLength_initFields = function () {\n };\n TipLayoutHint$StemLength$NORMAL_instance = new TipLayoutHint$StemLength('NORMAL', 0, 12.0);\n TipLayoutHint$StemLength$SHORT_instance = new TipLayoutHint$StemLength('SHORT', 1, 5.0);\n TipLayoutHint$StemLength$NONE_instance = new TipLayoutHint$StemLength('NONE', 2, 0.0);\n }\n var TipLayoutHint$StemLength$NORMAL_instance;\n function TipLayoutHint$StemLength$NORMAL_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$NORMAL_instance;\n }\n var TipLayoutHint$StemLength$SHORT_instance;\n function TipLayoutHint$StemLength$SHORT_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$SHORT_instance;\n }\n var TipLayoutHint$StemLength$NONE_instance;\n function TipLayoutHint$StemLength$NONE_getInstance() {\n TipLayoutHint$StemLength_initFields();\n return TipLayoutHint$StemLength$NONE_instance;\n }\n TipLayoutHint$StemLength.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StemLength',\n interfaces: [Enum]\n };\n function TipLayoutHint$StemLength$values() {\n return [TipLayoutHint$StemLength$NORMAL_getInstance(), TipLayoutHint$StemLength$SHORT_getInstance(), TipLayoutHint$StemLength$NONE_getInstance()];\n }\n TipLayoutHint$StemLength.values = TipLayoutHint$StemLength$values;\n function TipLayoutHint$StemLength$valueOf(name) {\n switch (name) {\n case 'NORMAL':\n return TipLayoutHint$StemLength$NORMAL_getInstance();\n case 'SHORT':\n return TipLayoutHint$StemLength$SHORT_getInstance();\n case 'NONE':\n return TipLayoutHint$StemLength$NONE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TipLayoutHint.StemLength.' + name);\n }\n }\n TipLayoutHint$StemLength.valueOf_61zpoe$ = TipLayoutHint$StemLength$valueOf;\n TipLayoutHint.prototype.toString = function () {\n return this.kind.toString();\n };\n function TipLayoutHint$Kind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TipLayoutHint$Kind_initFields() {\n TipLayoutHint$Kind_initFields = function () {\n };\n TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance = new TipLayoutHint$Kind('VERTICAL_TOOLTIP', 0);\n TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance = new TipLayoutHint$Kind('HORIZONTAL_TOOLTIP', 1);\n TipLayoutHint$Kind$CURSOR_TOOLTIP_instance = new TipLayoutHint$Kind('CURSOR_TOOLTIP', 2);\n TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance = new TipLayoutHint$Kind('X_AXIS_TOOLTIP', 3);\n TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance = new TipLayoutHint$Kind('Y_AXIS_TOOLTIP', 4);\n }\n var TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance;\n function TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$VERTICAL_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance;\n function TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$CURSOR_TOOLTIP_instance;\n function TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$CURSOR_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance;\n function TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$X_AXIS_TOOLTIP_instance;\n }\n var TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance;\n function TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance() {\n TipLayoutHint$Kind_initFields();\n return TipLayoutHint$Kind$Y_AXIS_TOOLTIP_instance;\n }\n TipLayoutHint$Kind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kind',\n interfaces: [Enum]\n };\n function TipLayoutHint$Kind$values() {\n return [TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance(), TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance(), TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance(), TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance(), TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance()];\n }\n TipLayoutHint$Kind.values = TipLayoutHint$Kind$values;\n function TipLayoutHint$Kind$valueOf(name) {\n switch (name) {\n case 'VERTICAL_TOOLTIP':\n return TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance();\n case 'HORIZONTAL_TOOLTIP':\n return TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance();\n case 'CURSOR_TOOLTIP':\n return TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance();\n case 'X_AXIS_TOOLTIP':\n return TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance();\n case 'Y_AXIS_TOOLTIP':\n return TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.' + name);\n }\n }\n TipLayoutHint$Kind.valueOf_61zpoe$ = TipLayoutHint$Kind$valueOf;\n function TipLayoutHint$Companion() {\n TipLayoutHint$Companion_instance = this;\n }\n TipLayoutHint$Companion.prototype.verticalTooltip_6lq1u6$ = function (coord, objectRadius, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance(), coord, objectRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.horizontalTooltip_6lq1u6$ = function (coord, objectRadius, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance(), coord, objectRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.cursorTooltip_itpcqk$ = function (coord, color, stemLength) {\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NORMAL_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance(), coord, 0.0, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.xAxisTooltip_cgf2ia$ = function (coord, color, axisRadius, stemLength) {\n if (axisRadius === void 0)\n axisRadius = 0.0;\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NONE_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance(), coord, axisRadius, color, stemLength);\n };\n TipLayoutHint$Companion.prototype.yAxisTooltip_cgf2ia$ = function (coord, color, axisRadius, stemLength) {\n if (axisRadius === void 0)\n axisRadius = 0.0;\n if (stemLength === void 0)\n stemLength = TipLayoutHint$StemLength$NONE_getInstance();\n return new TipLayoutHint(TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance(), coord, axisRadius, color, stemLength);\n };\n TipLayoutHint$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TipLayoutHint$Companion_instance = null;\n function TipLayoutHint$Companion_getInstance() {\n if (TipLayoutHint$Companion_instance === null) {\n new TipLayoutHint$Companion();\n }return TipLayoutHint$Companion_instance;\n }\n TipLayoutHint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TipLayoutHint',\n interfaces: []\n };\n function TooltipAnchor(verticalAnchor, horizontalAnchor) {\n this.verticalAnchor = verticalAnchor;\n this.horizontalAnchor = horizontalAnchor;\n }\n function TooltipAnchor$VerticalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TooltipAnchor$VerticalAnchor_initFields() {\n TooltipAnchor$VerticalAnchor_initFields = function () {\n };\n TooltipAnchor$VerticalAnchor$TOP_instance = new TooltipAnchor$VerticalAnchor('TOP', 0);\n TooltipAnchor$VerticalAnchor$BOTTOM_instance = new TooltipAnchor$VerticalAnchor('BOTTOM', 1);\n TooltipAnchor$VerticalAnchor$MIDDLE_instance = new TooltipAnchor$VerticalAnchor('MIDDLE', 2);\n }\n var TooltipAnchor$VerticalAnchor$TOP_instance;\n function TooltipAnchor$VerticalAnchor$TOP_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$TOP_instance;\n }\n var TooltipAnchor$VerticalAnchor$BOTTOM_instance;\n function TooltipAnchor$VerticalAnchor$BOTTOM_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$BOTTOM_instance;\n }\n var TooltipAnchor$VerticalAnchor$MIDDLE_instance;\n function TooltipAnchor$VerticalAnchor$MIDDLE_getInstance() {\n TooltipAnchor$VerticalAnchor_initFields();\n return TooltipAnchor$VerticalAnchor$MIDDLE_instance;\n }\n TooltipAnchor$VerticalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAnchor',\n interfaces: [Enum]\n };\n function TooltipAnchor$VerticalAnchor$values() {\n return [TooltipAnchor$VerticalAnchor$TOP_getInstance(), TooltipAnchor$VerticalAnchor$BOTTOM_getInstance(), TooltipAnchor$VerticalAnchor$MIDDLE_getInstance()];\n }\n TooltipAnchor$VerticalAnchor.values = TooltipAnchor$VerticalAnchor$values;\n function TooltipAnchor$VerticalAnchor$valueOf(name) {\n switch (name) {\n case 'TOP':\n return TooltipAnchor$VerticalAnchor$TOP_getInstance();\n case 'BOTTOM':\n return TooltipAnchor$VerticalAnchor$BOTTOM_getInstance();\n case 'MIDDLE':\n return TooltipAnchor$VerticalAnchor$MIDDLE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TooltipAnchor.VerticalAnchor.' + name);\n }\n }\n TooltipAnchor$VerticalAnchor.valueOf_61zpoe$ = TooltipAnchor$VerticalAnchor$valueOf;\n function TooltipAnchor$HorizontalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TooltipAnchor$HorizontalAnchor_initFields() {\n TooltipAnchor$HorizontalAnchor_initFields = function () {\n };\n TooltipAnchor$HorizontalAnchor$LEFT_instance = new TooltipAnchor$HorizontalAnchor('LEFT', 0);\n TooltipAnchor$HorizontalAnchor$RIGHT_instance = new TooltipAnchor$HorizontalAnchor('RIGHT', 1);\n TooltipAnchor$HorizontalAnchor$CENTER_instance = new TooltipAnchor$HorizontalAnchor('CENTER', 2);\n }\n var TooltipAnchor$HorizontalAnchor$LEFT_instance;\n function TooltipAnchor$HorizontalAnchor$LEFT_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$LEFT_instance;\n }\n var TooltipAnchor$HorizontalAnchor$RIGHT_instance;\n function TooltipAnchor$HorizontalAnchor$RIGHT_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$RIGHT_instance;\n }\n var TooltipAnchor$HorizontalAnchor$CENTER_instance;\n function TooltipAnchor$HorizontalAnchor$CENTER_getInstance() {\n TooltipAnchor$HorizontalAnchor_initFields();\n return TooltipAnchor$HorizontalAnchor$CENTER_instance;\n }\n TooltipAnchor$HorizontalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAnchor',\n interfaces: [Enum]\n };\n function TooltipAnchor$HorizontalAnchor$values() {\n return [TooltipAnchor$HorizontalAnchor$LEFT_getInstance(), TooltipAnchor$HorizontalAnchor$RIGHT_getInstance(), TooltipAnchor$HorizontalAnchor$CENTER_getInstance()];\n }\n TooltipAnchor$HorizontalAnchor.values = TooltipAnchor$HorizontalAnchor$values;\n function TooltipAnchor$HorizontalAnchor$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return TooltipAnchor$HorizontalAnchor$LEFT_getInstance();\n case 'RIGHT':\n return TooltipAnchor$HorizontalAnchor$RIGHT_getInstance();\n case 'CENTER':\n return TooltipAnchor$HorizontalAnchor$CENTER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.interact.TooltipAnchor.HorizontalAnchor.' + name);\n }\n }\n TooltipAnchor$HorizontalAnchor.valueOf_61zpoe$ = TooltipAnchor$HorizontalAnchor$valueOf;\n TooltipAnchor.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, TooltipAnchor) ? tmp$_0 : throwCCE();\n if (this.verticalAnchor !== other.verticalAnchor)\n return false;\n if (this.horizontalAnchor !== other.horizontalAnchor)\n return false;\n return true;\n };\n TooltipAnchor.prototype.hashCode = function () {\n var result = this.verticalAnchor.hashCode();\n result = (31 * result | 0) + this.horizontalAnchor.hashCode() | 0;\n return result;\n };\n TooltipAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipAnchor',\n interfaces: []\n };\n function TooltipLineSpec() {\n }\n function TooltipLineSpec$DataPoint(label, value, aes, isAxis, isOutlier) {\n this.label = label;\n this.value = value;\n this.aes = aes;\n this.isAxis = isAxis;\n this.isOutlier = isOutlier;\n }\n TooltipLineSpec$DataPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataPoint',\n interfaces: []\n };\n TooltipLineSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TooltipLineSpec',\n interfaces: []\n };\n function LivemapConstants() {\n }\n function LivemapConstants$DisplayMode(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$DisplayMode_initFields() {\n LivemapConstants$DisplayMode_initFields = function () {\n };\n LivemapConstants$DisplayMode$POINT_instance = new LivemapConstants$DisplayMode('POINT', 0);\n LivemapConstants$DisplayMode$PIE_instance = new LivemapConstants$DisplayMode('PIE', 1);\n LivemapConstants$DisplayMode$BAR_instance = new LivemapConstants$DisplayMode('BAR', 2);\n }\n var LivemapConstants$DisplayMode$POINT_instance;\n function LivemapConstants$DisplayMode$POINT_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$POINT_instance;\n }\n var LivemapConstants$DisplayMode$PIE_instance;\n function LivemapConstants$DisplayMode$PIE_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$PIE_instance;\n }\n var LivemapConstants$DisplayMode$BAR_instance;\n function LivemapConstants$DisplayMode$BAR_getInstance() {\n LivemapConstants$DisplayMode_initFields();\n return LivemapConstants$DisplayMode$BAR_instance;\n }\n LivemapConstants$DisplayMode.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DisplayMode',\n interfaces: [Enum]\n };\n function LivemapConstants$DisplayMode$values() {\n return [LivemapConstants$DisplayMode$POINT_getInstance(), LivemapConstants$DisplayMode$PIE_getInstance(), LivemapConstants$DisplayMode$BAR_getInstance()];\n }\n LivemapConstants$DisplayMode.values = LivemapConstants$DisplayMode$values;\n function LivemapConstants$DisplayMode$valueOf(name) {\n switch (name) {\n case 'POINT':\n return LivemapConstants$DisplayMode$POINT_getInstance();\n case 'PIE':\n return LivemapConstants$DisplayMode$PIE_getInstance();\n case 'BAR':\n return LivemapConstants$DisplayMode$BAR_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode.' + name);\n }\n }\n LivemapConstants$DisplayMode.valueOf_61zpoe$ = LivemapConstants$DisplayMode$valueOf;\n function LivemapConstants$Theme(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$Theme_initFields() {\n LivemapConstants$Theme_initFields = function () {\n };\n LivemapConstants$Theme$COLOR_instance = new LivemapConstants$Theme('COLOR', 0);\n LivemapConstants$Theme$LIGHT_instance = new LivemapConstants$Theme('LIGHT', 1);\n LivemapConstants$Theme$DARK_instance = new LivemapConstants$Theme('DARK', 2);\n }\n var LivemapConstants$Theme$COLOR_instance;\n function LivemapConstants$Theme$COLOR_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$COLOR_instance;\n }\n var LivemapConstants$Theme$LIGHT_instance;\n function LivemapConstants$Theme$LIGHT_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$LIGHT_instance;\n }\n var LivemapConstants$Theme$DARK_instance;\n function LivemapConstants$Theme$DARK_getInstance() {\n LivemapConstants$Theme_initFields();\n return LivemapConstants$Theme$DARK_instance;\n }\n LivemapConstants$Theme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Theme',\n interfaces: [Enum]\n };\n function LivemapConstants$Theme$values() {\n return [LivemapConstants$Theme$COLOR_getInstance(), LivemapConstants$Theme$LIGHT_getInstance(), LivemapConstants$Theme$DARK_getInstance()];\n }\n LivemapConstants$Theme.values = LivemapConstants$Theme$values;\n function LivemapConstants$Theme$valueOf(name) {\n switch (name) {\n case 'COLOR':\n return LivemapConstants$Theme$COLOR_getInstance();\n case 'LIGHT':\n return LivemapConstants$Theme$LIGHT_getInstance();\n case 'DARK':\n return LivemapConstants$Theme$DARK_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.Theme.' + name);\n }\n }\n LivemapConstants$Theme.valueOf_61zpoe$ = LivemapConstants$Theme$valueOf;\n function LivemapConstants$Projection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LivemapConstants$Projection_initFields() {\n LivemapConstants$Projection_initFields = function () {\n };\n LivemapConstants$Projection$EPSG3857_instance = new LivemapConstants$Projection('EPSG3857', 0);\n LivemapConstants$Projection$EPSG4326_instance = new LivemapConstants$Projection('EPSG4326', 1);\n LivemapConstants$Projection$AZIMUTHAL_instance = new LivemapConstants$Projection('AZIMUTHAL', 2);\n LivemapConstants$Projection$CONIC_instance = new LivemapConstants$Projection('CONIC', 3);\n }\n var LivemapConstants$Projection$EPSG3857_instance;\n function LivemapConstants$Projection$EPSG3857_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$EPSG3857_instance;\n }\n var LivemapConstants$Projection$EPSG4326_instance;\n function LivemapConstants$Projection$EPSG4326_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$EPSG4326_instance;\n }\n var LivemapConstants$Projection$AZIMUTHAL_instance;\n function LivemapConstants$Projection$AZIMUTHAL_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$AZIMUTHAL_instance;\n }\n var LivemapConstants$Projection$CONIC_instance;\n function LivemapConstants$Projection$CONIC_getInstance() {\n LivemapConstants$Projection_initFields();\n return LivemapConstants$Projection$CONIC_instance;\n }\n LivemapConstants$Projection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Projection',\n interfaces: [Enum]\n };\n function LivemapConstants$Projection$values() {\n return [LivemapConstants$Projection$EPSG3857_getInstance(), LivemapConstants$Projection$EPSG4326_getInstance(), LivemapConstants$Projection$AZIMUTHAL_getInstance(), LivemapConstants$Projection$CONIC_getInstance()];\n }\n LivemapConstants$Projection.values = LivemapConstants$Projection$values;\n function LivemapConstants$Projection$valueOf(name) {\n switch (name) {\n case 'EPSG3857':\n return LivemapConstants$Projection$EPSG3857_getInstance();\n case 'EPSG4326':\n return LivemapConstants$Projection$EPSG4326_getInstance();\n case 'AZIMUTHAL':\n return LivemapConstants$Projection$AZIMUTHAL_getInstance();\n case 'CONIC':\n return LivemapConstants$Projection$CONIC_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection.' + name);\n }\n }\n LivemapConstants$Projection.valueOf_61zpoe$ = LivemapConstants$Projection$valueOf;\n LivemapConstants.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LivemapConstants',\n interfaces: []\n };\n function LiveMapOptions(zoom, location, stroke, interactive, displayMode, scaled, clustering, labels, projection, geodesic, geocodingService, tileProvider, devParams) {\n this.zoom = zoom;\n this.location = location;\n this.stroke = stroke;\n this.interactive = interactive;\n this.displayMode = displayMode;\n this.scaled = scaled;\n this.clustering = clustering;\n this.labels = labels;\n this.projection = projection;\n this.geodesic = geodesic;\n this.geocodingService = geocodingService;\n this.tileProvider = tileProvider;\n this.devParams = devParams;\n }\n LiveMapOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapOptions',\n interfaces: []\n };\n function DodgePos(aesthetics, myGroupCount, myWidth) {\n this.myGroupCount_0 = myGroupCount;\n this.myWidth_0 = myWidth;\n this.myDodgingNeeded_0 = false;\n this.myDodgingNeeded_0 = this.isDodgingNeeded_0(aesthetics);\n }\n DodgePos.prototype.isDodgingNeeded_0 = function (aesthetics) {\n var tmp$;\n var groupByX = HashMap_init();\n tmp$ = aesthetics.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var p = aesthetics.dataPointAt_za3lpa$(i);\n if (p.defined_896ixz$(Aes$Companion_getInstance().X)) {\n var x = ensureNotNull(p.x());\n var group = p.group();\n if (groupByX.containsKey_11rb$(x)) {\n if (groupByX.get_11rb$(x) != group) {\n return true;\n }} else {\n groupByX.put_xwzc9p$(x, group);\n }\n }}\n return false;\n };\n DodgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var tmp$;\n if (this.myDodgingNeeded_0) {\n var dataResolution = ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var width = (tmp$ = this.myWidth_0) != null ? tmp$ : p.width();\n if (!data.SeriesUtil.isFinite_yrwdxb$(width)) {\n return v;\n }var slotIndex = ensureNotNull(p.group());\n var median = (this.myGroupCount_0 - 1 | 0) / 2.0;\n var xOffset = (slotIndex - median) * dataResolution * ensureNotNull(width);\n var xCenter = ensureNotNull(p.x());\n var xScaler = 1.0 / this.myGroupCount_0;\n var newX = (v.x + xOffset - xCenter) * xScaler + xCenter;\n return new DoubleVector(newX, v.y);\n }return v;\n };\n DodgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$DODGE_getInstance().handlesGroups();\n };\n DodgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DodgePos',\n interfaces: [PositionAdjustment]\n };\n function FillPos(aes) {\n this.myStackPosHelper_0 = StackPos$Companion_getInstance().splitPositiveNegative_m7huy5$(aes);\n this.myScalerByIndex_0 = this.mapIndexToScaler_0(aes);\n }\n FillPos.prototype.mapIndexToScaler_0 = function (aes) {\n var tmp$, tmp$_0;\n var posMaxByBin = HashMap_init();\n var negMaxByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPoint = aes.dataPointAt_za3lpa$(i);\n var x = dataPoint.x();\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n var tmp$_1;\n if (!(Kotlin.isType(tmp$_1 = posMaxByBin, Map) ? tmp$_1 : throwCCE()).containsKey_11rb$(x)) {\n var key = ensureNotNull(x);\n posMaxByBin.put_xwzc9p$(key, 0.0);\n negMaxByBin.put_xwzc9p$(x, 0.0);\n }var y = dataPoint.y();\n if (data.SeriesUtil.isFinite_yrwdxb$(y)) {\n if (ensureNotNull(y) >= 0) {\n var key_0 = ensureNotNull(x);\n var value = ensureNotNull(posMaxByBin.get_11rb$(x)) + y;\n posMaxByBin.put_xwzc9p$(key_0, value);\n } else {\n var key_1 = ensureNotNull(x);\n var value_0 = ensureNotNull(negMaxByBin.get_11rb$(x)) - y;\n negMaxByBin.put_xwzc9p$(key_1, value_0);\n }\n }}}\n var scalerByIndex = HashMap_init();\n tmp$_0 = aes.dataPointCount();\n for (var i_0 = 0; i_0 < tmp$_0; i_0++) {\n var dataPoint_0 = aes.dataPointAt_za3lpa$(i_0);\n var x_0 = dataPoint_0.x();\n var y_0 = dataPoint_0.y();\n var tmp$_2;\n if ((Kotlin.isType(tmp$_2 = posMaxByBin, Map) ? tmp$_2 : throwCCE()).containsKey_11rb$(x_0) && data.SeriesUtil.isFinite_yrwdxb$(y_0)) {\n var tmp$_3 = ensureNotNull(y_0) >= 0;\n if (tmp$_3) {\n var tmp$_4;\n tmp$_3 = ensureNotNull((Kotlin.isType(tmp$_4 = posMaxByBin, Map) ? tmp$_4 : throwCCE()).get_11rb$(x_0)) > 0;\n }if (tmp$_3) {\n var tmp$_5;\n var value_1 = 1.0 / ensureNotNull((Kotlin.isType(tmp$_5 = posMaxByBin, Map) ? tmp$_5 : throwCCE()).get_11rb$(x_0));\n scalerByIndex.put_xwzc9p$(i_0, value_1);\n } else {\n var tmp$_6 = y_0 < 0;\n if (tmp$_6) {\n var tmp$_7;\n tmp$_6 = ensureNotNull((Kotlin.isType(tmp$_7 = negMaxByBin, Map) ? tmp$_7 : throwCCE()).get_11rb$(x_0)) > 0;\n }if (tmp$_6) {\n var tmp$_8;\n var value_2 = 1.0 / ensureNotNull((Kotlin.isType(tmp$_8 = negMaxByBin, Map) ? tmp$_8 : throwCCE()).get_11rb$(x_0));\n scalerByIndex.put_xwzc9p$(i_0, value_2);\n } else {\n scalerByIndex.put_xwzc9p$(i_0, 1.0);\n }\n }\n } else {\n scalerByIndex.put_xwzc9p$(i_0, 1.0);\n }\n }\n return scalerByIndex;\n };\n FillPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var newLoc = this.myStackPosHelper_0.translate_tshsjz$(v, p, ctx);\n return new DoubleVector(newLoc.x, newLoc.y * ensureNotNull(this.myScalerByIndex_0.get_11rb$(p.index())) * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().Y));\n };\n FillPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$FILL_getInstance().handlesGroups();\n };\n FillPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FillPos',\n interfaces: [PositionAdjustment]\n };\n function JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight) {\n this.myJitterPosHelper_0 = null;\n this.myDodgePosHelper_0 = null;\n this.myJitterPosHelper_0 = new JitterPos(jitterWidth, jitterHeight);\n this.myDodgePosHelper_0 = new DodgePos(aesthetics, groupCount, width);\n }\n JitterDodgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var afterJitter = this.myJitterPosHelper_0.translate_tshsjz$(v, p, ctx);\n return this.myDodgePosHelper_0.translate_tshsjz$(afterJitter, p, ctx);\n };\n JitterDodgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$JITTER_DODGE_getInstance().handlesGroups();\n };\n JitterDodgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterDodgePos',\n interfaces: [PositionAdjustment]\n };\n function JitterPos(width, height) {\n JitterPos$Companion_getInstance();\n this.myWidth_0 = 0;\n this.myHeight_0 = 0;\n this.myWidth_0 = width != null ? width : JitterPos$Companion_getInstance().DEF_JITTER_WIDTH;\n this.myHeight_0 = height != null ? height : JitterPos$Companion_getInstance().DEF_JITTER_HEIGHT;\n }\n JitterPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var x = (2 * Random.Default.nextDouble() - 1) * this.myWidth_0 * ctx.getResolution_vktour$(Aes$Companion_getInstance().X);\n var y = (2 * Random.Default.nextDouble() - 1) * this.myHeight_0 * ctx.getResolution_vktour$(Aes$Companion_getInstance().Y);\n return v.add_gpjtzr$(new DoubleVector(x, y));\n };\n JitterPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$JITTER_getInstance().handlesGroups();\n };\n function JitterPos$Companion() {\n JitterPos$Companion_instance = this;\n this.DEF_JITTER_WIDTH = 0.4;\n this.DEF_JITTER_HEIGHT = 0.4;\n }\n JitterPos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var JitterPos$Companion_instance = null;\n function JitterPos$Companion_getInstance() {\n if (JitterPos$Companion_instance === null) {\n new JitterPos$Companion();\n }return JitterPos$Companion_instance;\n }\n JitterPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'JitterPos',\n interfaces: [PositionAdjustment]\n };\n function NudgePos(width, height) {\n NudgePos$Companion_getInstance();\n this.myWidth_0 = 0;\n this.myHeight_0 = 0;\n this.myWidth_0 = width != null ? width : NudgePos$Companion_getInstance().DEF_NUDGE_WIDTH;\n this.myHeight_0 = height != null ? height : NudgePos$Companion_getInstance().DEF_NUDGE_HEIGHT;\n }\n NudgePos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n var x = this.myWidth_0 * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().X);\n var y = this.myHeight_0 * ctx.getUnitResolution_vktour$(Aes$Companion_getInstance().Y);\n return v.add_gpjtzr$(new DoubleVector(x, y));\n };\n NudgePos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$NUDGE_getInstance().handlesGroups();\n };\n function NudgePos$Companion() {\n NudgePos$Companion_instance = this;\n this.DEF_NUDGE_WIDTH = 0.0;\n this.DEF_NUDGE_HEIGHT = 0.0;\n }\n NudgePos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NudgePos$Companion_instance = null;\n function NudgePos$Companion_getInstance() {\n if (NudgePos$Companion_instance === null) {\n new NudgePos$Companion();\n }return NudgePos$Companion_instance;\n }\n NudgePos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NudgePos',\n interfaces: [PositionAdjustment]\n };\n function PositionAdjustments() {\n PositionAdjustments_instance = this;\n }\n function PositionAdjustments$identity$ObjectLiteral() {\n }\n Object.defineProperty(PositionAdjustments$identity$ObjectLiteral.prototype, 'isIdentity', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n PositionAdjustments$identity$ObjectLiteral.prototype.translate_tshsjz$ = function (v, p, ctx) {\n return v;\n };\n PositionAdjustments$identity$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$IDENTITY_getInstance().handlesGroups();\n };\n PositionAdjustments$identity$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PositionAdjustment]\n };\n PositionAdjustments.prototype.identity = function () {\n return new PositionAdjustments$identity$ObjectLiteral();\n };\n PositionAdjustments.prototype.dodge_vvhcz8$ = function (aesthetics, groupCount, width) {\n return new DodgePos(aesthetics, groupCount, width);\n };\n PositionAdjustments.prototype.stack_4vnpmn$ = function (aes, strategy) {\n var tmp$;\n switch (strategy.name) {\n case 'SPLIT_POSITIVE_NEGATIVE':\n tmp$ = StackPos$Companion_getInstance().splitPositiveNegative_m7huy5$(aes);\n break;\n case 'SUM_POSITIVE_NEGATIVE':\n tmp$ = StackPos$Companion_getInstance().sumPositiveNegative_m7huy5$(aes);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PositionAdjustments.prototype.fill_m7huy5$ = function (aesthetics) {\n return new FillPos(aesthetics);\n };\n PositionAdjustments.prototype.jitter_jma9l8$ = function (width, height) {\n return new JitterPos(width, height);\n };\n PositionAdjustments.prototype.nudge_jma9l8$ = function (width, height) {\n return new NudgePos(width, height);\n };\n PositionAdjustments.prototype.jitterDodge_e2pc44$ = function (aesthetics, groupCount, width, jitterWidth, jitterHeight) {\n return new JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight);\n };\n function PositionAdjustments$Meta(name, ordinal, myHandlesGroups) {\n Enum.call(this);\n this.myHandlesGroups_39qcox$_0 = myHandlesGroups;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function PositionAdjustments$Meta_initFields() {\n PositionAdjustments$Meta_initFields = function () {\n };\n PositionAdjustments$Meta$IDENTITY_instance = new PositionAdjustments$Meta('IDENTITY', 0, false);\n PositionAdjustments$Meta$DODGE_instance = new PositionAdjustments$Meta('DODGE', 1, true);\n PositionAdjustments$Meta$STACK_instance = new PositionAdjustments$Meta('STACK', 2, true);\n PositionAdjustments$Meta$FILL_instance = new PositionAdjustments$Meta('FILL', 3, true);\n PositionAdjustments$Meta$JITTER_instance = new PositionAdjustments$Meta('JITTER', 4, false);\n PositionAdjustments$Meta$NUDGE_instance = new PositionAdjustments$Meta('NUDGE', 5, false);\n PositionAdjustments$Meta$JITTER_DODGE_instance = new PositionAdjustments$Meta('JITTER_DODGE', 6, true);\n }\n var PositionAdjustments$Meta$IDENTITY_instance;\n function PositionAdjustments$Meta$IDENTITY_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$IDENTITY_instance;\n }\n var PositionAdjustments$Meta$DODGE_instance;\n function PositionAdjustments$Meta$DODGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$DODGE_instance;\n }\n var PositionAdjustments$Meta$STACK_instance;\n function PositionAdjustments$Meta$STACK_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$STACK_instance;\n }\n var PositionAdjustments$Meta$FILL_instance;\n function PositionAdjustments$Meta$FILL_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$FILL_instance;\n }\n var PositionAdjustments$Meta$JITTER_instance;\n function PositionAdjustments$Meta$JITTER_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$JITTER_instance;\n }\n var PositionAdjustments$Meta$NUDGE_instance;\n function PositionAdjustments$Meta$NUDGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$NUDGE_instance;\n }\n var PositionAdjustments$Meta$JITTER_DODGE_instance;\n function PositionAdjustments$Meta$JITTER_DODGE_getInstance() {\n PositionAdjustments$Meta_initFields();\n return PositionAdjustments$Meta$JITTER_DODGE_instance;\n }\n PositionAdjustments$Meta.prototype.handlesGroups = function () {\n return this.myHandlesGroups_39qcox$_0;\n };\n PositionAdjustments$Meta.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Meta',\n interfaces: [Enum]\n };\n function PositionAdjustments$Meta$values() {\n return [PositionAdjustments$Meta$IDENTITY_getInstance(), PositionAdjustments$Meta$DODGE_getInstance(), PositionAdjustments$Meta$STACK_getInstance(), PositionAdjustments$Meta$FILL_getInstance(), PositionAdjustments$Meta$JITTER_getInstance(), PositionAdjustments$Meta$NUDGE_getInstance(), PositionAdjustments$Meta$JITTER_DODGE_getInstance()];\n }\n PositionAdjustments$Meta.values = PositionAdjustments$Meta$values;\n function PositionAdjustments$Meta$valueOf(name) {\n switch (name) {\n case 'IDENTITY':\n return PositionAdjustments$Meta$IDENTITY_getInstance();\n case 'DODGE':\n return PositionAdjustments$Meta$DODGE_getInstance();\n case 'STACK':\n return PositionAdjustments$Meta$STACK_getInstance();\n case 'FILL':\n return PositionAdjustments$Meta$FILL_getInstance();\n case 'JITTER':\n return PositionAdjustments$Meta$JITTER_getInstance();\n case 'NUDGE':\n return PositionAdjustments$Meta$NUDGE_getInstance();\n case 'JITTER_DODGE':\n return PositionAdjustments$Meta$JITTER_DODGE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.Meta.' + name);\n }\n }\n PositionAdjustments$Meta.valueOf_61zpoe$ = PositionAdjustments$Meta$valueOf;\n function PositionAdjustments$StackingStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function PositionAdjustments$StackingStrategy_initFields() {\n PositionAdjustments$StackingStrategy_initFields = function () {\n };\n PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance = new PositionAdjustments$StackingStrategy('SUM_POSITIVE_NEGATIVE', 0);\n PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance = new PositionAdjustments$StackingStrategy('SPLIT_POSITIVE_NEGATIVE', 1);\n }\n var PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance;\n function PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance() {\n PositionAdjustments$StackingStrategy_initFields();\n return PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_instance;\n }\n var PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance;\n function PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance() {\n PositionAdjustments$StackingStrategy_initFields();\n return PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_instance;\n }\n PositionAdjustments$StackingStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StackingStrategy',\n interfaces: [Enum]\n };\n function PositionAdjustments$StackingStrategy$values() {\n return [PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance(), PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance()];\n }\n PositionAdjustments$StackingStrategy.values = PositionAdjustments$StackingStrategy$values;\n function PositionAdjustments$StackingStrategy$valueOf(name) {\n switch (name) {\n case 'SUM_POSITIVE_NEGATIVE':\n return PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance();\n case 'SPLIT_POSITIVE_NEGATIVE':\n return PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.StackingStrategy.' + name);\n }\n }\n PositionAdjustments$StackingStrategy.valueOf_61zpoe$ = PositionAdjustments$StackingStrategy$valueOf;\n PositionAdjustments.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PositionAdjustments',\n interfaces: []\n };\n var PositionAdjustments_instance = null;\n function PositionAdjustments_getInstance() {\n if (PositionAdjustments_instance === null) {\n new PositionAdjustments();\n }return PositionAdjustments_instance;\n }\n function StackPos(aes) {\n StackPos$Companion_getInstance();\n this.myOffsetByIndex_0 = null;\n this.myOffsetByIndex_0 = this.mapIndexToOffset_m7huy5$(aes);\n }\n StackPos.prototype.translate_tshsjz$ = function (v, p, ctx) {\n return v.add_gpjtzr$(new DoubleVector(0.0, ensureNotNull(this.myOffsetByIndex_0.get_11rb$(p.index()))));\n };\n StackPos.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta$STACK_getInstance().handlesGroups();\n };\n function StackPos$SplitPositiveNegative(aes) {\n StackPos.call(this, aes);\n }\n StackPos$SplitPositiveNegative.prototype.mapIndexToOffset_m7huy5$ = function (aes) {\n var tmp$;\n var offsetByIndex = HashMap_init();\n var negPosBaseByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPoint = aes.dataPointAt_za3lpa$(i);\n var x = dataPoint.x();\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n var tmp$_0;\n if (!(Kotlin.isType(tmp$_0 = negPosBaseByBin, Map) ? tmp$_0 : throwCCE()).containsKey_11rb$(x)) {\n var key = ensureNotNull(x);\n var value = new Pair(new MutableDouble(0.0), new MutableDouble(0.0));\n negPosBaseByBin.put_xwzc9p$(key, value);\n }var y = dataPoint.y();\n if (data.SeriesUtil.isFinite_yrwdxb$(y)) {\n var tmp$_1;\n var pair = ensureNotNull((Kotlin.isType(tmp$_1 = negPosBaseByBin, Map) ? tmp$_1 : throwCCE()).get_11rb$(x));\n var offset;\n if (ensureNotNull(y) >= 0) {\n offset = pair.second.getAndAdd_14dthe$(y);\n } else {\n offset = pair.first.getAndAdd_14dthe$(y);\n }\n var value_0 = offset;\n offsetByIndex.put_xwzc9p$(i, value_0);\n }}}\n return offsetByIndex;\n };\n StackPos$SplitPositiveNegative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SplitPositiveNegative',\n interfaces: [StackPos]\n };\n function StackPos$SumPositiveNegative(aes) {\n StackPos.call(this, aes);\n }\n StackPos$SumPositiveNegative.prototype.mapIndexToOffset_m7huy5$ = function (aes) {\n var tmp$;\n var offsetByIndex = HashMap_init();\n var baseByBin = HashMap_init();\n tmp$ = aes.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n var dataPointAes = aes.dataPointAt_za3lpa$(i);\n var x = ensureNotNull(dataPointAes.x());\n if (data.SeriesUtil.isFinite_14dthe$(x)) {\n if (!baseByBin.containsKey_11rb$(x)) {\n var value = new MutableDouble(0.0);\n baseByBin.put_xwzc9p$(x, value);\n }var y = ensureNotNull(dataPointAes.y());\n if (data.SeriesUtil.isFinite_14dthe$(y)) {\n var base = ensureNotNull(baseByBin.get_11rb$(x));\n var offset = base.getAndAdd_14dthe$(y);\n offsetByIndex.put_xwzc9p$(i, offset);\n }}}\n return offsetByIndex;\n };\n StackPos$SumPositiveNegative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SumPositiveNegative',\n interfaces: [StackPos]\n };\n function StackPos$Companion() {\n StackPos$Companion_instance = this;\n }\n StackPos$Companion.prototype.splitPositiveNegative_m7huy5$ = function (aes) {\n return new StackPos$SplitPositiveNegative(aes);\n };\n StackPos$Companion.prototype.sumPositiveNegative_m7huy5$ = function (aes) {\n return new StackPos$SumPositiveNegative(aes);\n };\n StackPos$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var StackPos$Companion_instance = null;\n function StackPos$Companion_getInstance() {\n if (StackPos$Companion_instance === null) {\n new StackPos$Companion();\n }return StackPos$Companion_instance;\n }\n StackPos.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StackPos',\n interfaces: [PositionAdjustment]\n };\n function LegendKeyElementFactory() {\n }\n LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = function (p) {\n var strokeWidth = AesScaling_getInstance().strokeWidth_l6g9mh$(p);\n var size = 2 * strokeWidth + 4;\n return new DoubleVector(size, size);\n };\n LegendKeyElementFactory.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LegendKeyElementFactory',\n interfaces: []\n };\n function SvgRoot() {\n }\n SvgRoot.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'SvgRoot',\n interfaces: []\n };\n function LineType() {\n }\n LineType.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LineType',\n interfaces: []\n };\n function NamedLineType(name, ordinal, code, myDashArray) {\n Enum.call(this);\n this.code = code;\n this.myDashArray_j93rys$_0 = myDashArray;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function NamedLineType_initFields() {\n NamedLineType_initFields = function () {\n };\n new NamedLineType$BLANK();\n new NamedLineType$SOLID();\n NamedLineType$DASHED_instance = new NamedLineType('DASHED', 2, 2, listOf([4.3, 4.3]));\n NamedLineType$DOTTED_instance = new NamedLineType('DOTTED', 3, 3, listOf([1.0, 3.2]));\n NamedLineType$DOTDASH_instance = new NamedLineType('DOTDASH', 4, 4, listOf([1.0, 3.2, 4.3, 3.2]));\n NamedLineType$LONGDASH_instance = new NamedLineType('LONGDASH', 5, 5, listOf([7.4, 3.2]));\n NamedLineType$TWODASH_instance = new NamedLineType('TWODASH', 6, 6, listOf([2.4, 2.4, 6.4, 2.4]));\n }\n function NamedLineType$BLANK() {\n NamedLineType$BLANK_instance = this;\n NamedLineType.call(this, 'BLANK', 0, 0, null);\n }\n Object.defineProperty(NamedLineType$BLANK.prototype, 'isBlank', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n NamedLineType$BLANK.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BLANK',\n interfaces: [NamedLineType]\n };\n var NamedLineType$BLANK_instance = null;\n function NamedLineType$BLANK_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$BLANK_instance;\n }\n function NamedLineType$SOLID() {\n NamedLineType$SOLID_instance = this;\n NamedLineType.call(this, 'SOLID', 1, 1, null);\n }\n Object.defineProperty(NamedLineType$SOLID.prototype, 'isSolid', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n NamedLineType$SOLID.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SOLID',\n interfaces: [NamedLineType]\n };\n var NamedLineType$SOLID_instance = null;\n function NamedLineType$SOLID_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$SOLID_instance;\n }\n var NamedLineType$DASHED_instance;\n function NamedLineType$DASHED_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DASHED_instance;\n }\n var NamedLineType$DOTTED_instance;\n function NamedLineType$DOTTED_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DOTTED_instance;\n }\n var NamedLineType$DOTDASH_instance;\n function NamedLineType$DOTDASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$DOTDASH_instance;\n }\n var NamedLineType$LONGDASH_instance;\n function NamedLineType$LONGDASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$LONGDASH_instance;\n }\n var NamedLineType$TWODASH_instance;\n function NamedLineType$TWODASH_getInstance() {\n NamedLineType_initFields();\n return NamedLineType$TWODASH_instance;\n }\n Object.defineProperty(NamedLineType.prototype, 'isSolid', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(NamedLineType.prototype, 'isBlank', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(NamedLineType.prototype, 'dashArray', {\n configurable: true,\n get: function () {\n if (!(this.isSolid || this.isBlank)) {\n return ensureNotNull(this.myDashArray_j93rys$_0);\n }throw IllegalStateException_init('No dash array in ' + this.name.toLowerCase() + ' linetype');\n }\n });\n NamedLineType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NamedLineType',\n interfaces: [LineType, Enum]\n };\n function NamedLineType$values() {\n return [NamedLineType$BLANK_getInstance(), NamedLineType$SOLID_getInstance(), NamedLineType$DASHED_getInstance(), NamedLineType$DOTTED_getInstance(), NamedLineType$DOTDASH_getInstance(), NamedLineType$LONGDASH_getInstance(), NamedLineType$TWODASH_getInstance()];\n }\n NamedLineType.values = NamedLineType$values;\n function NamedLineType$valueOf(name) {\n switch (name) {\n case 'BLANK':\n return NamedLineType$BLANK_getInstance();\n case 'SOLID':\n return NamedLineType$SOLID_getInstance();\n case 'DASHED':\n return NamedLineType$DASHED_getInstance();\n case 'DOTTED':\n return NamedLineType$DOTTED_getInstance();\n case 'DOTDASH':\n return NamedLineType$DOTDASH_getInstance();\n case 'LONGDASH':\n return NamedLineType$LONGDASH_getInstance();\n case 'TWODASH':\n return NamedLineType$TWODASH_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.linetype.NamedLineType.' + name);\n }\n }\n NamedLineType.valueOf_61zpoe$ = NamedLineType$valueOf;\n function NamedShape(name, ordinal, code, isSolid, isFilled, isSmall) {\n if (isSolid === void 0)\n isSolid = false;\n if (isFilled === void 0)\n isFilled = false;\n if (isSmall === void 0)\n isSmall = false;\n Enum.call(this);\n this.code_djxmtz$_0 = code;\n this.isSolid = isSolid;\n this.isFilled = isFilled;\n this.isSmall_kvok7h$_0 = isSmall;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function NamedShape_initFields() {\n NamedShape_initFields = function () {\n };\n NamedShape$STICK_SQUARE_instance = new NamedShape('STICK_SQUARE', 0, 0);\n NamedShape$STICK_CIRCLE_instance = new NamedShape('STICK_CIRCLE', 1, 1);\n NamedShape$STICK_TRIANGLE_UP_instance = new NamedShape('STICK_TRIANGLE_UP', 2, 2);\n NamedShape$STICK_PLUS_instance = new NamedShape('STICK_PLUS', 3, 3);\n NamedShape$STICK_CROSS_instance = new NamedShape('STICK_CROSS', 4, 4);\n NamedShape$STICK_DIAMOND_instance = new NamedShape('STICK_DIAMOND', 5, 5);\n NamedShape$STICK_TRIANGLE_DOWN_instance = new NamedShape('STICK_TRIANGLE_DOWN', 6, 6);\n NamedShape$STICK_SQUARE_CROSS_instance = new NamedShape('STICK_SQUARE_CROSS', 7, 7);\n NamedShape$STICK_STAR_instance = new NamedShape('STICK_STAR', 8, 8);\n NamedShape$STICK_DIAMOND_PLUS_instance = new NamedShape('STICK_DIAMOND_PLUS', 9, 9);\n NamedShape$STICK_CIRCLE_PLUS_instance = new NamedShape('STICK_CIRCLE_PLUS', 10, 10);\n NamedShape$STICK_TRIANGLE_UP_DOWN_instance = new NamedShape('STICK_TRIANGLE_UP_DOWN', 11, 11);\n NamedShape$STICK_SQUARE_PLUS_instance = new NamedShape('STICK_SQUARE_PLUS', 12, 12);\n NamedShape$STICK_CIRCLE_CROSS_instance = new NamedShape('STICK_CIRCLE_CROSS', 13, 13);\n NamedShape$STICK_SQUARE_TRIANGLE_UP_instance = new NamedShape('STICK_SQUARE_TRIANGLE_UP', 14, 14);\n NamedShape$SOLID_SQUARE_instance = new NamedShape('SOLID_SQUARE', 15, 15, true, false);\n NamedShape$SOLID_CIRCLE_instance = new NamedShape('SOLID_CIRCLE', 16, 16, true, false);\n NamedShape$SOLID_TRIANGLE_UP_instance = new NamedShape('SOLID_TRIANGLE_UP', 17, 17, true, false);\n NamedShape$SOLID_DIAMOND_instance = new NamedShape('SOLID_DIAMOND', 18, 18, true, false, true);\n NamedShape$SOLID_CIRCLE_2_instance = new NamedShape('SOLID_CIRCLE_2', 19, 19, true, false);\n NamedShape$BULLET_instance = new NamedShape('BULLET', 20, 20, true, false, true);\n NamedShape$FILLED_CIRCLE_instance = new NamedShape('FILLED_CIRCLE', 21, 21, false, true);\n NamedShape$FILLED_SQUARE_instance = new NamedShape('FILLED_SQUARE', 22, 22, false, true);\n NamedShape$FILLED_DIAMOND_instance = new NamedShape('FILLED_DIAMOND', 23, 23, false, true);\n NamedShape$FILLED_TRIANGLE_UP_instance = new NamedShape('FILLED_TRIANGLE_UP', 24, 24, false, true);\n NamedShape$FILLED_TRIANGLE_DOWN_instance = new NamedShape('FILLED_TRIANGLE_DOWN', 25, 25, false, true);\n }\n Object.defineProperty(NamedShape.prototype, 'code', {\n get: function () {\n return this.code_djxmtz$_0;\n }\n });\n var NamedShape$STICK_SQUARE_instance;\n function NamedShape$STICK_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_instance;\n }\n var NamedShape$STICK_CIRCLE_instance;\n function NamedShape$STICK_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_instance;\n }\n var NamedShape$STICK_TRIANGLE_UP_instance;\n function NamedShape$STICK_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_UP_instance;\n }\n var NamedShape$STICK_PLUS_instance;\n function NamedShape$STICK_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_PLUS_instance;\n }\n var NamedShape$STICK_CROSS_instance;\n function NamedShape$STICK_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CROSS_instance;\n }\n var NamedShape$STICK_DIAMOND_instance;\n function NamedShape$STICK_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_DIAMOND_instance;\n }\n var NamedShape$STICK_TRIANGLE_DOWN_instance;\n function NamedShape$STICK_TRIANGLE_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_DOWN_instance;\n }\n var NamedShape$STICK_SQUARE_CROSS_instance;\n function NamedShape$STICK_SQUARE_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_CROSS_instance;\n }\n var NamedShape$STICK_STAR_instance;\n function NamedShape$STICK_STAR_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_STAR_instance;\n }\n var NamedShape$STICK_DIAMOND_PLUS_instance;\n function NamedShape$STICK_DIAMOND_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_DIAMOND_PLUS_instance;\n }\n var NamedShape$STICK_CIRCLE_PLUS_instance;\n function NamedShape$STICK_CIRCLE_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_PLUS_instance;\n }\n var NamedShape$STICK_TRIANGLE_UP_DOWN_instance;\n function NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_TRIANGLE_UP_DOWN_instance;\n }\n var NamedShape$STICK_SQUARE_PLUS_instance;\n function NamedShape$STICK_SQUARE_PLUS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_PLUS_instance;\n }\n var NamedShape$STICK_CIRCLE_CROSS_instance;\n function NamedShape$STICK_CIRCLE_CROSS_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_CIRCLE_CROSS_instance;\n }\n var NamedShape$STICK_SQUARE_TRIANGLE_UP_instance;\n function NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$STICK_SQUARE_TRIANGLE_UP_instance;\n }\n var NamedShape$SOLID_SQUARE_instance;\n function NamedShape$SOLID_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_SQUARE_instance;\n }\n var NamedShape$SOLID_CIRCLE_instance;\n function NamedShape$SOLID_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_CIRCLE_instance;\n }\n var NamedShape$SOLID_TRIANGLE_UP_instance;\n function NamedShape$SOLID_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_TRIANGLE_UP_instance;\n }\n var NamedShape$SOLID_DIAMOND_instance;\n function NamedShape$SOLID_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_DIAMOND_instance;\n }\n var NamedShape$SOLID_CIRCLE_2_instance;\n function NamedShape$SOLID_CIRCLE_2_getInstance() {\n NamedShape_initFields();\n return NamedShape$SOLID_CIRCLE_2_instance;\n }\n var NamedShape$BULLET_instance;\n function NamedShape$BULLET_getInstance() {\n NamedShape_initFields();\n return NamedShape$BULLET_instance;\n }\n var NamedShape$FILLED_CIRCLE_instance;\n function NamedShape$FILLED_CIRCLE_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_CIRCLE_instance;\n }\n var NamedShape$FILLED_SQUARE_instance;\n function NamedShape$FILLED_SQUARE_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_SQUARE_instance;\n }\n var NamedShape$FILLED_DIAMOND_instance;\n function NamedShape$FILLED_DIAMOND_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_DIAMOND_instance;\n }\n var NamedShape$FILLED_TRIANGLE_UP_instance;\n function NamedShape$FILLED_TRIANGLE_UP_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_TRIANGLE_UP_instance;\n }\n var NamedShape$FILLED_TRIANGLE_DOWN_instance;\n function NamedShape$FILLED_TRIANGLE_DOWN_getInstance() {\n NamedShape_initFields();\n return NamedShape$FILLED_TRIANGLE_DOWN_instance;\n }\n Object.defineProperty(NamedShape.prototype, 'isHollow', {\n configurable: true,\n get: function () {\n return !(this.isFilled || this.isSolid);\n }\n });\n NamedShape.prototype.size_l6g9mh$ = function (dataPoint) {\n return this.isSmall_kvok7h$_0 ? AesScaling_getInstance().circleDiameterSmaller_l6g9mh$(dataPoint) : AesScaling_getInstance().circleDiameter_l6g9mh$(dataPoint);\n };\n NamedShape.prototype.strokeWidth_l6g9mh$ = function (dataPoint) {\n return this.isSolid ? 0.0 : 1.0;\n };\n NamedShape.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NamedShape',\n interfaces: [PointShape, Enum]\n };\n function NamedShape$values() {\n return [NamedShape$STICK_SQUARE_getInstance(), NamedShape$STICK_CIRCLE_getInstance(), NamedShape$STICK_TRIANGLE_UP_getInstance(), NamedShape$STICK_PLUS_getInstance(), NamedShape$STICK_CROSS_getInstance(), NamedShape$STICK_DIAMOND_getInstance(), NamedShape$STICK_TRIANGLE_DOWN_getInstance(), NamedShape$STICK_SQUARE_CROSS_getInstance(), NamedShape$STICK_STAR_getInstance(), NamedShape$STICK_DIAMOND_PLUS_getInstance(), NamedShape$STICK_CIRCLE_PLUS_getInstance(), NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance(), NamedShape$STICK_SQUARE_PLUS_getInstance(), NamedShape$STICK_CIRCLE_CROSS_getInstance(), NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance(), NamedShape$SOLID_SQUARE_getInstance(), NamedShape$SOLID_CIRCLE_getInstance(), NamedShape$SOLID_TRIANGLE_UP_getInstance(), NamedShape$SOLID_DIAMOND_getInstance(), NamedShape$SOLID_CIRCLE_2_getInstance(), NamedShape$BULLET_getInstance(), NamedShape$FILLED_CIRCLE_getInstance(), NamedShape$FILLED_SQUARE_getInstance(), NamedShape$FILLED_DIAMOND_getInstance(), NamedShape$FILLED_TRIANGLE_UP_getInstance(), NamedShape$FILLED_TRIANGLE_DOWN_getInstance()];\n }\n NamedShape.values = NamedShape$values;\n function NamedShape$valueOf(name) {\n switch (name) {\n case 'STICK_SQUARE':\n return NamedShape$STICK_SQUARE_getInstance();\n case 'STICK_CIRCLE':\n return NamedShape$STICK_CIRCLE_getInstance();\n case 'STICK_TRIANGLE_UP':\n return NamedShape$STICK_TRIANGLE_UP_getInstance();\n case 'STICK_PLUS':\n return NamedShape$STICK_PLUS_getInstance();\n case 'STICK_CROSS':\n return NamedShape$STICK_CROSS_getInstance();\n case 'STICK_DIAMOND':\n return NamedShape$STICK_DIAMOND_getInstance();\n case 'STICK_TRIANGLE_DOWN':\n return NamedShape$STICK_TRIANGLE_DOWN_getInstance();\n case 'STICK_SQUARE_CROSS':\n return NamedShape$STICK_SQUARE_CROSS_getInstance();\n case 'STICK_STAR':\n return NamedShape$STICK_STAR_getInstance();\n case 'STICK_DIAMOND_PLUS':\n return NamedShape$STICK_DIAMOND_PLUS_getInstance();\n case 'STICK_CIRCLE_PLUS':\n return NamedShape$STICK_CIRCLE_PLUS_getInstance();\n case 'STICK_TRIANGLE_UP_DOWN':\n return NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance();\n case 'STICK_SQUARE_PLUS':\n return NamedShape$STICK_SQUARE_PLUS_getInstance();\n case 'STICK_CIRCLE_CROSS':\n return NamedShape$STICK_CIRCLE_CROSS_getInstance();\n case 'STICK_SQUARE_TRIANGLE_UP':\n return NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance();\n case 'SOLID_SQUARE':\n return NamedShape$SOLID_SQUARE_getInstance();\n case 'SOLID_CIRCLE':\n return NamedShape$SOLID_CIRCLE_getInstance();\n case 'SOLID_TRIANGLE_UP':\n return NamedShape$SOLID_TRIANGLE_UP_getInstance();\n case 'SOLID_DIAMOND':\n return NamedShape$SOLID_DIAMOND_getInstance();\n case 'SOLID_CIRCLE_2':\n return NamedShape$SOLID_CIRCLE_2_getInstance();\n case 'BULLET':\n return NamedShape$BULLET_getInstance();\n case 'FILLED_CIRCLE':\n return NamedShape$FILLED_CIRCLE_getInstance();\n case 'FILLED_SQUARE':\n return NamedShape$FILLED_SQUARE_getInstance();\n case 'FILLED_DIAMOND':\n return NamedShape$FILLED_DIAMOND_getInstance();\n case 'FILLED_TRIANGLE_UP':\n return NamedShape$FILLED_TRIANGLE_UP_getInstance();\n case 'FILLED_TRIANGLE_DOWN':\n return NamedShape$FILLED_TRIANGLE_DOWN_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.point.NamedShape.' + name);\n }\n }\n NamedShape.valueOf_61zpoe$ = NamedShape$valueOf;\n function PointShape() {\n }\n PointShape.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointShape',\n interfaces: []\n };\n function PointShapeSvg() {\n PointShapeSvg_instance = this;\n }\n PointShapeSvg.prototype.create_d8smhz$ = function (shape, location, p, fatten) {\n if (fatten === void 0)\n fatten = 1.0;\n if (equals(shape, TinyPointShape_getInstance())) {\n return this.createTinyDotShape_0(location, p);\n }if (Kotlin.isType(shape, NamedShape)) {\n return this.createNamedShape_0(shape, location, p, fatten);\n }throw IllegalArgumentException_init('Unsupported point shape code ' + shape.code + ' ' + toString(Kotlin.getKClassFromExpression(shape).simpleName));\n };\n PointShapeSvg.prototype.createTinyDotShape_0 = function (location, p) {\n var r = slim.SvgSlimElements.rect_6y0v78$(location.x - 0.5, location.y - 0.5, 1.0, 1.0);\n var color = ensureNotNull(p.color());\n var alpha = AestheticsUtil_getInstance().alpha_il6rhx$(color, p);\n r.setFill_o14uds$(color, alpha);\n r.setStrokeWidth_14dthe$(0.0);\n return r;\n };\n PointShapeSvg.prototype.createNamedShape_0 = function (shape, location, p, fatten) {\n var glyph = this.createSlimGlyph_0(shape, location, shape.size_l6g9mh$(p) * fatten);\n AestheticsUtil_getInstance().decorate_l4vgcq$(glyph, shape.isFilled, shape.isSolid, p, shape.strokeWidth_l6g9mh$(p));\n return glyph;\n };\n PointShapeSvg.prototype.createSlimGlyph_0 = function (shape, location, size) {\n switch (shape.name) {\n case 'STICK_SQUARE':\n case 'SOLID_SQUARE':\n case 'FILLED_SQUARE':\n return Glyphs_getInstance().square_e1sv3v$(location, size);\n case 'STICK_CIRCLE':\n case 'SOLID_CIRCLE':\n case 'SOLID_CIRCLE_2':\n case 'BULLET':\n case 'FILLED_CIRCLE':\n return Glyphs_getInstance().circle_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_UP':\n case 'SOLID_TRIANGLE_UP':\n case 'FILLED_TRIANGLE_UP':\n return Glyphs_getInstance().triangleUp_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_DOWN':\n case 'FILLED_TRIANGLE_DOWN':\n return Glyphs_getInstance().triangleDown_e1sv3v$(location, size);\n case 'STICK_DIAMOND':\n case 'SOLID_DIAMOND':\n case 'FILLED_DIAMOND':\n return Glyphs_getInstance().diamond_e1sv3v$(location, size);\n case 'STICK_PLUS':\n return Glyphs_getInstance().stickPlus_e1sv3v$(location, size);\n case 'STICK_CROSS':\n return Glyphs_getInstance().stickCross_e1sv3v$(location, size);\n case 'STICK_SQUARE_CROSS':\n return Glyphs_getInstance().stickSquareCross_e1sv3v$(location, size);\n case 'STICK_STAR':\n return Glyphs_getInstance().stickStar_e1sv3v$(location, size);\n case 'STICK_DIAMOND_PLUS':\n return Glyphs_getInstance().stickDiamondPlus_e1sv3v$(location, size);\n case 'STICK_CIRCLE_PLUS':\n return Glyphs_getInstance().stickCirclePlus_e1sv3v$(location, size);\n case 'STICK_TRIANGLE_UP_DOWN':\n return Glyphs_getInstance().stickTriangleUpDown_e1sv3v$(location, size);\n case 'STICK_SQUARE_PLUS':\n return Glyphs_getInstance().stickSquarePlus_e1sv3v$(location, size);\n case 'STICK_CIRCLE_CROSS':\n return Glyphs_getInstance().stickCircleCross_e1sv3v$(location, size);\n case 'STICK_SQUARE_TRIANGLE_UP':\n return Glyphs_getInstance().stickSquareTriangleUp_e1sv3v$(location, size);\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n };\n PointShapeSvg.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PointShapeSvg',\n interfaces: []\n };\n var PointShapeSvg_instance = null;\n function PointShapeSvg_getInstance() {\n if (PointShapeSvg_instance === null) {\n new PointShapeSvg();\n }return PointShapeSvg_instance;\n }\n function TinyPointShape() {\n TinyPointShape_instance = this;\n }\n Object.defineProperty(TinyPointShape.prototype, 'code', {\n configurable: true,\n get: function () {\n return 46;\n }\n });\n TinyPointShape.prototype.size_l6g9mh$ = function (dataPoint) {\n return 1.0;\n };\n TinyPointShape.prototype.strokeWidth_l6g9mh$ = function (dataPoint) {\n return 0.0;\n };\n TinyPointShape.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TinyPointShape',\n interfaces: [PointShape]\n };\n var TinyPointShape_instance = null;\n function TinyPointShape_getInstance() {\n if (TinyPointShape_instance === null) {\n new TinyPointShape();\n }return TinyPointShape_instance;\n }\n function UpdatableShape() {\n }\n UpdatableShape.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UpdatableShape',\n interfaces: []\n };\n function CircleGlyph(location, width) {\n SingletonGlyph_init_0(location, width, this);\n }\n CircleGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n return slim.SvgSlimElements.circle_yvo9jy$(location.x, location.y, width / 2);\n };\n CircleGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CircleGlyph',\n interfaces: [SingletonGlyph]\n };\n function CrossGlyph(location, size, inscribedInCircle) {\n CrossGlyph$Companion_getInstance();\n if (inscribedInCircle === void 0)\n inscribedInCircle = true;\n TwoShapeGlyph.call(this);\n var cx = location.x;\n var cy = location.y;\n var w = inscribedInCircle ? size * CrossGlyph$Companion_getInstance().CIRCLE_WIDTH_ADJUST_RATIO : size;\n var half = w / 2;\n var backSlashLine = slim.SvgSlimElements.line_6y0v78$(cx - half, cy - half, cx + half, cy + half);\n var slashLine = slim.SvgSlimElements.line_6y0v78$(cx - half, cy + half, cx + half, cy - half);\n this.setShapes_0(backSlashLine, slashLine);\n }\n function CrossGlyph$Companion() {\n CrossGlyph$Companion_instance = this;\n var x = math.PI / 4;\n this.CIRCLE_WIDTH_ADJUST_RATIO = JsMath.cos(x);\n }\n CrossGlyph$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CrossGlyph$Companion_instance = null;\n function CrossGlyph$Companion_getInstance() {\n if (CrossGlyph$Companion_instance === null) {\n new CrossGlyph$Companion();\n }return CrossGlyph$Companion_instance;\n }\n CrossGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CrossGlyph',\n interfaces: [TwoShapeGlyph]\n };\n function DiamondGlyph(location, width) {\n SingletonGlyph_init_0(location, width, this);\n }\n DiamondGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n var half = width / 2;\n var x = new Float64Array([half, width, half, 0.0]);\n var y = new Float64Array([0.0, half, width, half]);\n var ox = location.x - half;\n var oy = location.y - half;\n for (var i = 0; i <= 3; i++) {\n x[i] = ox + x[i];\n y[i] = oy + y[i];\n }\n var pathData = GlyphUtil_getInstance().buildPathData_ceb5dm$(asList(x), asList(y));\n return slim.SvgSlimElements.path_za3rmp$(pathData);\n };\n DiamondGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiamondGlyph',\n interfaces: [SingletonGlyph]\n };\n function Glyph() {\n }\n Glyph.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Glyph',\n interfaces: [SvgSlimObject, UpdatableShape]\n };\n function GlyphPair(myG1, myG2) {\n this.myG1_0 = myG1;\n this.myG2_0 = myG2;\n }\n GlyphPair.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.myG1_0.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n this.myG2_0.update_mjoany$(fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n GlyphPair.prototype.appendTo_i2myw1$ = function (g) {\n this.myG1_0.appendTo_i2myw1$(g);\n this.myG2_0.appendTo_i2myw1$(g);\n };\n GlyphPair.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GlyphPair',\n interfaces: [Glyph]\n };\n function GlyphUtil() {\n GlyphUtil_instance = this;\n }\n GlyphUtil.prototype.buildPathData_ceb5dm$ = function (xs, ys) {\n if (!(xs.size === ys.size)) {\n var message = 'Sizes of X/Y collections must be equal';\n throw IllegalArgumentException_init(message.toString());\n }if (xs.isEmpty()) {\n return SvgPathData.Companion.EMPTY;\n }var builder = (new SvgPathDataBuilder(true)).moveTo_przk3b$(collect.Iterables.get_7iig3d$(xs, 0), collect.Iterables.get_7iig3d$(ys, 0)).interpolatePoints_3g1a62$(xs, ys, SvgPathDataBuilder$Interpolation.LINEAR).closePath();\n return builder.build();\n };\n GlyphUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GlyphUtil',\n interfaces: []\n };\n var GlyphUtil_instance = null;\n function GlyphUtil_getInstance() {\n if (GlyphUtil_instance === null) {\n new GlyphUtil();\n }return GlyphUtil_instance;\n }\n function Glyphs() {\n Glyphs_instance = this;\n }\n Glyphs.prototype.square_e1sv3v$ = function (location, width) {\n return new SquareGlyph(location, width);\n };\n Glyphs.prototype.circle_e1sv3v$ = function (location, width) {\n return new CircleGlyph(location, width);\n };\n Glyphs.prototype.diamond_e1sv3v$ = function (location, width) {\n return new DiamondGlyph(location, width);\n };\n Glyphs.prototype.triangleUp_e1sv3v$ = function (location, width) {\n return new TriangleGlyph(location, width, true);\n };\n Glyphs.prototype.triangleDown_e1sv3v$ = function (location, width) {\n return new TriangleGlyph(location, width, false);\n };\n Glyphs.prototype.stickPlus_e1sv3v$ = function (location, width) {\n return new PlusGlyph(location, width);\n };\n Glyphs.prototype.stickCross_e1sv3v$ = function (location, width) {\n return new CrossGlyph(location, width);\n };\n Glyphs.prototype.stickSquareCross_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new CrossGlyph(location, size, false));\n };\n Glyphs.prototype.stickStar_e1sv3v$ = function (location, size) {\n return new GlyphPair(new PlusGlyph(location, size), new CrossGlyph(location, size));\n };\n Glyphs.prototype.stickDiamondPlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new DiamondGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickCirclePlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new CircleGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickTriangleUpDown_e1sv3v$ = function (location, size) {\n return new GlyphPair(new TriangleGlyph(location, size, true), new TriangleGlyph(location, size, false));\n };\n Glyphs.prototype.stickSquarePlus_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new PlusGlyph(location, size));\n };\n Glyphs.prototype.stickCircleCross_e1sv3v$ = function (location, size) {\n return new GlyphPair(new CircleGlyph(location, size), new CrossGlyph(location, size));\n };\n Glyphs.prototype.stickSquareTriangleUp_e1sv3v$ = function (location, size) {\n return new GlyphPair(new SquareGlyph(location, size), new TriangleGlyph(location, size, true, true));\n };\n Glyphs.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Glyphs',\n interfaces: []\n };\n var Glyphs_instance = null;\n function Glyphs_getInstance() {\n if (Glyphs_instance === null) {\n new Glyphs();\n }return Glyphs_instance;\n }\n function MultiShapeGlyph() {\n }\n MultiShapeGlyph.prototype.update_0 = function (shape, fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n shape != null ? (shape.setFill_o14uds$(fill, fillAlpha), Unit) : null;\n shape != null ? (shape.setStroke_o14uds$(stroke, strokeAlpha), Unit) : null;\n shape != null ? (shape.setStrokeWidth_14dthe$(strokeWidth), Unit) : null;\n };\n MultiShapeGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiShapeGlyph',\n interfaces: [Glyph]\n };\n function PlusGlyph(location, size) {\n TwoShapeGlyph.call(this);\n var half = size / 2;\n var ox = location.x - half;\n var oy = location.y - half;\n var hLine = slim.SvgSlimElements.line_6y0v78$(0 + ox, half + oy, size + ox, half + oy);\n var vLine = slim.SvgSlimElements.line_6y0v78$(half + ox, 0 + oy, half + ox, size + oy);\n this.setShapes_0(hLine, vLine);\n }\n PlusGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlusGlyph',\n interfaces: [TwoShapeGlyph]\n };\n function SingletonGlyph() {\n this.myShape_tmqwxg$_0 = null;\n }\n SingletonGlyph.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.myShape_tmqwxg$_0.setFill_o14uds$(fill, fillAlpha);\n this.myShape_tmqwxg$_0.setStroke_o14uds$(stroke, strokeAlpha);\n this.myShape_tmqwxg$_0.setStrokeWidth_14dthe$(strokeWidth);\n };\n SingletonGlyph.prototype.appendTo_i2myw1$ = function (g) {\n this.myShape_tmqwxg$_0.appendTo_i2myw1$(g);\n };\n SingletonGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SingletonGlyph',\n interfaces: [Glyph]\n };\n function SingletonGlyph_init(shape, $this) {\n $this = $this || Object.create(SingletonGlyph.prototype);\n SingletonGlyph.call($this);\n $this.myShape_tmqwxg$_0 = shape;\n return $this;\n }\n function SingletonGlyph_init_0(location, width, $this) {\n $this = $this || Object.create(SingletonGlyph.prototype);\n SingletonGlyph.call($this);\n $this.myShape_tmqwxg$_0 = $this.createShape_e1sv3v$(location, width);\n return $this;\n }\n function SquareGlyph(location, size) {\n SingletonGlyph_init_0(location, size, this);\n }\n SquareGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n return slim.SvgSlimElements.rect_6y0v78$(location.x - width / 2, location.y - width / 2, width, width);\n };\n SquareGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SquareGlyph',\n interfaces: [SingletonGlyph]\n };\n function TriangleGlyph(location, size, pointingUp, inscribedInSquare) {\n TriangleGlyph$Companion_getInstance();\n if (inscribedInSquare === void 0)\n inscribedInSquare = false;\n SingletonGlyph_init(TriangleGlyph$Companion_getInstance().createTriangleShape_0(location, size, pointingUp, inscribedInSquare), this);\n }\n TriangleGlyph.prototype.createShape_e1sv3v$ = function (location, width) {\n throw IllegalStateException_init('Not applicable');\n };\n function TriangleGlyph$Companion() {\n TriangleGlyph$Companion_instance = this;\n var x = math.PI / 3;\n this.SIDE_TO_HEIGHT_RATIO_0 = JsMath.sin(x);\n this.VERTICAL_OFFSET_RATIO_0 = 1.0 / 12;\n }\n TriangleGlyph$Companion.prototype.createTriangleShape_0 = function (location, size, pointingUp, inscribedInSquare) {\n var half = size / 2;\n var height = inscribedInSquare ? size : this.SIDE_TO_HEIGHT_RATIO_0 * size;\n var vOffset = inscribedInSquare ? 0.0 : height * this.VERTICAL_OFFSET_RATIO_0;\n var x;\n var y;\n var dy = (size - height) / 2;\n if (pointingUp) {\n dy -= vOffset;\n x = new Float64Array([half, size, 0.0]);\n y = new Float64Array([0.0 + dy, height + dy, height + dy]);\n } else {\n dy += vOffset;\n x = new Float64Array([0.0, size, half]);\n y = new Float64Array([0.0 + dy, 0.0 + dy, height + dy]);\n }\n var ox = location.x - half;\n var oy = location.y - half;\n for (var i = 0; i <= 2; i++) {\n x[i] = ox + x[i];\n y[i] = oy + y[i];\n }\n var pathData = GlyphUtil_getInstance().buildPathData_ceb5dm$(asList(x), asList(y));\n return slim.SvgSlimElements.path_za3rmp$(pathData);\n };\n TriangleGlyph$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TriangleGlyph$Companion_instance = null;\n function TriangleGlyph$Companion_getInstance() {\n if (TriangleGlyph$Companion_instance === null) {\n new TriangleGlyph$Companion();\n }return TriangleGlyph$Companion_instance;\n }\n TriangleGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TriangleGlyph',\n interfaces: [SingletonGlyph]\n };\n function TwoShapeGlyph() {\n MultiShapeGlyph.call(this);\n this.myS1_0 = null;\n this.myS2_0 = null;\n }\n TwoShapeGlyph.prototype.setShapes_0 = function (s1, s2) {\n this.myS1_0 = s1;\n this.myS2_0 = s2;\n };\n TwoShapeGlyph.prototype.update_mjoany$ = function (fill, fillAlpha, stroke, strokeAlpha, strokeWidth) {\n this.update_0(this.myS1_0, fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n this.update_0(this.myS2_0, fill, fillAlpha, stroke, strokeAlpha, strokeWidth);\n };\n TwoShapeGlyph.prototype.appendTo_i2myw1$ = function (g) {\n ensureNotNull(this.myS1_0).appendTo_i2myw1$(g);\n ensureNotNull(this.myS2_0).appendTo_i2myw1$(g);\n };\n TwoShapeGlyph.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TwoShapeGlyph',\n interfaces: [MultiShapeGlyph]\n };\n function GroupComponent() {\n SvgComponent.call(this);\n }\n GroupComponent.prototype.buildComponent = function () {\n };\n GroupComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupComponent',\n interfaces: [SvgComponent]\n };\n function LinePath(builder) {\n LinePath$Companion_getInstance();\n SvgComponent.call(this);\n this.myPath_0 = null;\n this.myDashArray_0 = null;\n this.myPath_0 = SvgPathElement_init(builder.build());\n this.myPath_0.fill().set_11rb$(SvgColors.NONE);\n var lineWidth = 1.0;\n this.myPath_0.strokeWidth().set_11rb$(lineWidth);\n this.add_26jijc$(this.myPath_0);\n }\n LinePath.prototype.buildComponent = function () {\n };\n LinePath.prototype.color = function () {\n return this.myPath_0.strokeColor();\n };\n LinePath.prototype.fill = function () {\n return this.myPath_0.fillColor();\n };\n function LinePath$width$ObjectLiteral(this$LinePath) {\n this.this$LinePath = this$LinePath;\n }\n LinePath$width$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$LinePath.myPath_0.strokeWidth().set_11rb$(value);\n this.this$LinePath.updatePathDashArray_0();\n };\n LinePath$width$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n LinePath.prototype.width = function () {\n return new LinePath$width$ObjectLiteral(this);\n };\n function LinePath$dashArray$ObjectLiteral(this$LinePath) {\n this.this$LinePath = this$LinePath;\n }\n LinePath$dashArray$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$LinePath.myDashArray_0 = ArrayList_init_0(value);\n this.this$LinePath.updatePathDashArray_0();\n };\n LinePath$dashArray$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n LinePath.prototype.dashArray = function () {\n return new LinePath$dashArray$ObjectLiteral(this);\n };\n LinePath.prototype.updatePathDashArray_0 = function () {\n if (!(this.myDashArray_0 == null || ensureNotNull(this.myDashArray_0).isEmpty())) {\n var w = this.myPath_0.strokeWidth().get();\n var width = w != null ? w : 1.0;\n StrokeDashArraySupport_getInstance().apply_3xqz7j$(this.myPath_0, width, ensureNotNull(this.myDashArray_0));\n }};\n function LinePath$Companion() {\n LinePath$Companion_instance = this;\n this.END_OF_SUBPATH = null;\n }\n LinePath$Companion.prototype.line_qdtdbw$ = function (points) {\n return new LinePath(this.pathBuilder_0(points, false));\n };\n LinePath$Companion.prototype.polygon_yh26e7$ = function (points) {\n return new LinePath(this.pathBuilder_0(points, true));\n };\n LinePath$Companion.prototype.pathBuilder_0 = function (points, isPolygon) {\n var tmp$;\n var builder = new SvgPathDataBuilder(true);\n var curSegment = ArrayList_init();\n var interpolate = false;\n tmp$ = points.iterator();\n while (tmp$.hasNext()) {\n var point = tmp$.next();\n if (point === this.END_OF_SUBPATH) {\n this.buildSegment_0(builder, curSegment, interpolate);\n if (isPolygon) {\n builder.closePath();\n }curSegment = ArrayList_init();\n } else {\n curSegment.add_11rb$(ensureNotNull(point));\n }\n }\n this.buildSegment_0(builder, curSegment, interpolate);\n if (isPolygon) {\n builder.closePath();\n }return builder;\n };\n LinePath$Companion.prototype.buildSegment_0 = function (builder, curSegment, interpolate) {\n if (curSegment.isEmpty()) {\n return;\n }builder.moveTo_gpjtzr$(curSegment.get_za3lpa$(0));\n builder.interpolatePoints_1ravjc$(curSegment, interpolate ? SvgPathDataBuilder$Interpolation.CARDINAL : SvgPathDataBuilder$Interpolation.LINEAR);\n };\n LinePath$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinePath$Companion_instance = null;\n function LinePath$Companion_getInstance() {\n if (LinePath$Companion_instance === null) {\n new LinePath$Companion();\n }return LinePath$Companion_instance;\n }\n LinePath.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinePath',\n interfaces: [SvgComponent]\n };\n function StrokeDashArraySupport() {\n StrokeDashArraySupport_instance = this;\n }\n StrokeDashArraySupport.prototype.apply_3xqz7j$ = function (element, strokeWidth, dashArray) {\n var tmp$;\n var sb = StringBuilder_init();\n tmp$ = dashArray.iterator();\n while (tmp$.hasNext()) {\n var relativeLength = tmp$.next();\n var length = relativeLength * strokeWidth;\n if (sb.length > 0) {\n sb.append_s8itvh$(44);\n }sb.append_pdl1vj$(length.toString());\n }\n element.getAttribute_61zpoe$(svg.SvgConstants.SVG_STROKE_DASHARRAY_ATTRIBUTE).set_11rb$(sb.toString());\n };\n StrokeDashArraySupport.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'StrokeDashArraySupport',\n interfaces: []\n };\n var StrokeDashArraySupport_instance = null;\n function StrokeDashArraySupport_getInstance() {\n if (StrokeDashArraySupport_instance === null) {\n new StrokeDashArraySupport();\n }return StrokeDashArraySupport_instance;\n }\n function SvgComponent() {\n SvgComponent$Companion_getInstance();\n this.myIsBuilt_hfl4wb$_0 = false;\n this.myIsBuilding_wftuqx$_0 = false;\n this.myRootGroup_34n42m$_0 = new SvgGElement();\n this.myChildComponents_jx3u37$_0 = ArrayList_init();\n this.myOrigin_c2o9zl$_0 = DoubleVector.Companion.ZERO;\n this.myRotationAngle_woxwye$_0 = 0.0;\n this.myCompositeRegistration_t8l21t$_0 = new CompositeRegistration([]);\n }\n Object.defineProperty(SvgComponent.prototype, 'childComponents', {\n configurable: true,\n get: function () {\n if (!this.myIsBuilt_hfl4wb$_0) {\n var message = 'Plot has not yet built';\n throw IllegalArgumentException_init(message.toString());\n }return ArrayList_init_0(this.myChildComponents_jx3u37$_0);\n }\n });\n Object.defineProperty(SvgComponent.prototype, 'rootGroup', {\n configurable: true,\n get: function () {\n this.ensureBuilt();\n return this.myRootGroup_34n42m$_0;\n }\n });\n SvgComponent.prototype.ensureBuilt = function () {\n if (!(this.myIsBuilt_hfl4wb$_0 || this.myIsBuilding_wftuqx$_0)) {\n this.buildComponentIntern_92lbvk$_0();\n }};\n SvgComponent.prototype.buildComponentIntern_92lbvk$_0 = function () {\n try {\n this.myIsBuilding_wftuqx$_0 = true;\n this.buildComponent();\n }finally {\n this.myIsBuilding_wftuqx$_0 = false;\n this.myIsBuilt_hfl4wb$_0 = true;\n }\n };\n function SvgComponent$rebuildHandler$ObjectLiteral(this$SvgComponent) {\n this.this$SvgComponent = this$SvgComponent;\n }\n SvgComponent$rebuildHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.this$SvgComponent.needRebuild();\n };\n SvgComponent$rebuildHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n SvgComponent.prototype.rebuildHandler_287e2$ = function () {\n return new SvgComponent$rebuildHandler$ObjectLiteral(this);\n };\n SvgComponent.prototype.needRebuild = function () {\n if (this.myIsBuilt_hfl4wb$_0) {\n this.clear();\n this.buildComponentIntern_92lbvk$_0();\n }};\n SvgComponent.prototype.reg_3xv6fb$ = function (r) {\n this.myCompositeRegistration_t8l21t$_0.add_3xv6fb$(r);\n };\n SvgComponent.prototype.clear = function () {\n var tmp$;\n this.myIsBuilt_hfl4wb$_0 = false;\n tmp$ = this.myChildComponents_jx3u37$_0.iterator();\n while (tmp$.hasNext()) {\n var child = tmp$.next();\n child.clear();\n }\n this.myChildComponents_jx3u37$_0.clear();\n this.myRootGroup_34n42m$_0.children().clear();\n this.myCompositeRegistration_t8l21t$_0.remove();\n this.myCompositeRegistration_t8l21t$_0 = new CompositeRegistration([]);\n };\n SvgComponent.prototype.add_8icvvv$ = function (child) {\n this.myChildComponents_jx3u37$_0.add_11rb$(child);\n this.add_26jijc$(child.rootGroup);\n };\n SvgComponent.prototype.add_26jijc$ = function (node) {\n this.myRootGroup_34n42m$_0.children().add_11rb$(node);\n };\n SvgComponent.prototype.moveTo_gpjtzr$ = function (p) {\n this.myOrigin_c2o9zl$_0 = p;\n this.myRootGroup_34n42m$_0.transform().set_11rb$(SvgComponent$Companion_getInstance().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0, this.myRotationAngle_woxwye$_0));\n };\n SvgComponent.prototype.moveTo_lu1900$ = function (x, y) {\n this.moveTo_gpjtzr$(new DoubleVector(x, y));\n };\n SvgComponent.prototype.rotate_14dthe$ = function (angle) {\n this.myRotationAngle_woxwye$_0 = angle;\n this.myRootGroup_34n42m$_0.transform().set_11rb$(SvgComponent$Companion_getInstance().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0, this.myRotationAngle_woxwye$_0));\n };\n SvgComponent.prototype.toRelativeCoordinates_gpjtzr$ = function (location) {\n return this.rootGroup.pointToTransformedCoordinates_gpjtzr$(location);\n };\n SvgComponent.prototype.toAbsoluteCoordinates_gpjtzr$ = function (location) {\n return this.rootGroup.pointToAbsoluteCoordinates_gpjtzr$(location);\n };\n SvgComponent.prototype.clipBounds_wthzt5$ = function (rect) {\n var $receiver = new SvgClipPathElement();\n $receiver.id().set_11rb$(SvgUID_getInstance().get_61zpoe$(SvgComponent$Companion_getInstance().CLIP_PATH_ID_PREFIX));\n var tmp$ = $receiver.children();\n var $receiver_0 = new SvgRectElement();\n $receiver_0.x().set_11rb$(rect.left);\n $receiver_0.y().set_11rb$(rect.top);\n $receiver_0.width().set_11rb$(rect.width);\n $receiver_0.height().set_11rb$(rect.height);\n tmp$.add_11rb$($receiver_0);\n var clipPathElement = $receiver;\n var $receiver_1 = new SvgDefsElement();\n $receiver_1.children().add_11rb$(clipPathElement);\n var defs = $receiver_1;\n this.add_26jijc$(defs);\n this.rootGroup.clipPath().set_11rb$(new SvgIRI(ensureNotNull(clipPathElement.id().get())));\n this.rootGroup.setAttribute_qdh7ux$(SvgGraphicsElement.Companion.CLIP_BOUNDS_JFX, rect);\n };\n SvgComponent.prototype.addClassName_61zpoe$ = function (className) {\n this.myRootGroup_34n42m$_0.addClass_61zpoe$(className);\n };\n function SvgComponent$Companion() {\n SvgComponent$Companion_instance = this;\n this.CLIP_PATH_ID_PREFIX = '';\n }\n SvgComponent$Companion.prototype.buildTransform_e1sv3v$ = function (origin, rotationAngle) {\n var transformBuilder = new SvgTransformBuilder();\n if (!(origin != null ? origin.equals(DoubleVector.Companion.ZERO) : null)) {\n transformBuilder.translate_lu1900$(origin.x, origin.y);\n }if (rotationAngle !== 0.0) {\n transformBuilder.rotate_14dthe$(rotationAngle);\n }return transformBuilder.build();\n };\n SvgComponent$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SvgComponent$Companion_instance = null;\n function SvgComponent$Companion_getInstance() {\n if (SvgComponent$Companion_instance === null) {\n new SvgComponent$Companion();\n }return SvgComponent$Companion_instance;\n }\n SvgComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgComponent',\n interfaces: []\n };\n function SvgUID() {\n SvgUID_instance = this;\n this.suffixGen_0 = SvgUID$suffixGen$lambda;\n }\n function SvgUID$setUpForTest$lambda(closure$incrementalId) {\n return function () {\n return closure$incrementalId.next();\n };\n }\n SvgUID.prototype.setUpForTest = function () {\n var incrementalId = new SvgUID$IncrementalId();\n this.suffixGen_0 = SvgUID$setUpForTest$lambda(incrementalId);\n };\n SvgUID.prototype.get_61zpoe$ = function (prefix) {\n return prefix + this.suffixGen_0().toString();\n };\n function SvgUID$IncrementalId() {\n this.nextIndex_0 = 0;\n }\n SvgUID$IncrementalId.prototype.next = function () {\n var tmp$;\n return 'clip-' + (tmp$ = this.nextIndex_0, this.nextIndex_0 = tmp$ + 1 | 0, tmp$);\n };\n SvgUID$IncrementalId.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IncrementalId',\n interfaces: []\n };\n function SvgUID$suffixGen$lambda() {\n return random.RandomString.randomString_za3lpa$(6);\n }\n SvgUID.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SvgUID',\n interfaces: []\n };\n var SvgUID_instance = null;\n function SvgUID_getInstance() {\n if (SvgUID_instance === null) {\n new SvgUID();\n }return SvgUID_instance;\n }\n function TextLabel(text) {\n SvgComponent.call(this);\n this.myText_0 = SvgTextElement_init(text);\n this.myTextColor_0 = null;\n this.myFontSize_0 = 0.0;\n this.myFontWeight_0 = null;\n this.myFontFamily_0 = null;\n this.myFontStyle_0 = null;\n this.rootGroup.children().add_11rb$(this.myText_0);\n }\n TextLabel.prototype.buildComponent = function () {\n };\n function TextLabel$textColor$ObjectLiteral(this$TextLabel) {\n this.this$TextLabel = this$TextLabel;\n }\n TextLabel$textColor$ObjectLiteral.prototype.set_11rb$ = function (value) {\n this.this$TextLabel.myText_0.fillColor();\n this.this$TextLabel.myTextColor_0 = value;\n this.this$TextLabel.updateStyleAttribute_0();\n };\n TextLabel$textColor$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [WritableProperty]\n };\n TextLabel.prototype.textColor = function () {\n return new TextLabel$textColor$ObjectLiteral(this);\n };\n TextLabel.prototype.textOpacity = function () {\n return this.myText_0.fillOpacity();\n };\n TextLabel.prototype.x = function () {\n return this.myText_0.x();\n };\n TextLabel.prototype.y = function () {\n return this.myText_0.y();\n };\n TextLabel.prototype.setHorizontalAnchor_ja80zo$ = function (anchor) {\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_TEXT_ANCHOR_ATTRIBUTE, this.toTextAnchor_0(anchor));\n };\n TextLabel.prototype.setVerticalAnchor_yaudma$ = function (anchor) {\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_TEXT_DY_ATTRIBUTE, this.toDY_0(anchor));\n };\n TextLabel.prototype.setFontSize_14dthe$ = function (px) {\n this.myFontSize_0 = px;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontWeight_pdl1vj$ = function (cssName) {\n this.myFontWeight_0 = cssName;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontStyle_pdl1vj$ = function (cssName) {\n this.myFontStyle_0 = cssName;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.setFontFamily_pdl1vj$ = function (fontFamily) {\n this.myFontFamily_0 = fontFamily;\n this.updateStyleAttribute_0();\n };\n TextLabel.prototype.updateStyleAttribute_0 = function () {\n var sb = StringBuilder_init();\n if (this.myTextColor_0 != null) {\n sb.append_pdl1vj$('fill:').append_pdl1vj$(ensureNotNull(this.myTextColor_0).toHexColor()).append_s8itvh$(59);\n }if (this.myFontSize_0 > 0 && this.myFontFamily_0 != null) {\n var fnt = StringBuilder_init();\n var $receiver = this.myFontStyle_0;\n if (!($receiver == null || $receiver.length === 0)) {\n fnt.append_pdl1vj$(ensureNotNull(this.myFontStyle_0)).append_s8itvh$(32);\n }var $receiver_0 = this.myFontWeight_0;\n if (!($receiver_0 == null || $receiver_0.length === 0)) {\n fnt.append_pdl1vj$(ensureNotNull(this.myFontWeight_0)).append_s8itvh$(32);\n }fnt.append_s8jyv4$(this.myFontSize_0).append_pdl1vj$('px ');\n fnt.append_pdl1vj$(ensureNotNull(this.myFontFamily_0)).append_pdl1vj$(';');\n sb.append_pdl1vj$('font:').append_gw00v9$(fnt);\n } else {\n var $receiver_1 = this.myFontStyle_0;\n if (!($receiver_1 == null || isBlank($receiver_1))) {\n sb.append_pdl1vj$('font-style:').append_pdl1vj$(ensureNotNull(this.myFontStyle_0)).append_s8itvh$(59);\n }var $receiver_2 = this.myFontWeight_0;\n if (!($receiver_2 == null || $receiver_2.length === 0)) {\n sb.append_pdl1vj$('font-weight:').append_pdl1vj$(ensureNotNull(this.myFontWeight_0)).append_s8itvh$(59);\n }if (this.myFontSize_0 > 0) {\n sb.append_pdl1vj$('font-size:').append_s8jyv4$(this.myFontSize_0).append_pdl1vj$('px;');\n }var $receiver_3 = this.myFontFamily_0;\n if (!($receiver_3 == null || $receiver_3.length === 0)) {\n sb.append_pdl1vj$('font-family:').append_pdl1vj$(ensureNotNull(this.myFontFamily_0)).append_s8itvh$(59);\n }}\n this.myText_0.setAttribute_jyasbz$(svg.SvgConstants.SVG_STYLE_ATTRIBUTE, sb.toString());\n };\n TextLabel.prototype.toTextAnchor_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'LEFT':\n tmp$ = null;\n break;\n case 'MIDDLE':\n tmp$ = svg.SvgConstants.SVG_TEXT_ANCHOR_MIDDLE;\n break;\n case 'RIGHT':\n tmp$ = svg.SvgConstants.SVG_TEXT_ANCHOR_END;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TextLabel.prototype.toDominantBaseline_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'TOP':\n tmp$ = 'hanging';\n break;\n case 'CENTER':\n tmp$ = 'central';\n break;\n case 'BOTTOM':\n tmp$ = null;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TextLabel.prototype.toDY_0 = function (anchor) {\n var tmp$;\n switch (anchor.name) {\n case 'TOP':\n tmp$ = svg.SvgConstants.SVG_TEXT_DY_TOP;\n break;\n case 'CENTER':\n tmp$ = svg.SvgConstants.SVG_TEXT_DY_CENTER;\n break;\n case 'BOTTOM':\n tmp$ = null;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n function TextLabel$HorizontalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TextLabel$HorizontalAnchor_initFields() {\n TextLabel$HorizontalAnchor_initFields = function () {\n };\n TextLabel$HorizontalAnchor$LEFT_instance = new TextLabel$HorizontalAnchor('LEFT', 0);\n TextLabel$HorizontalAnchor$RIGHT_instance = new TextLabel$HorizontalAnchor('RIGHT', 1);\n TextLabel$HorizontalAnchor$MIDDLE_instance = new TextLabel$HorizontalAnchor('MIDDLE', 2);\n }\n var TextLabel$HorizontalAnchor$LEFT_instance;\n function TextLabel$HorizontalAnchor$LEFT_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$LEFT_instance;\n }\n var TextLabel$HorizontalAnchor$RIGHT_instance;\n function TextLabel$HorizontalAnchor$RIGHT_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$RIGHT_instance;\n }\n var TextLabel$HorizontalAnchor$MIDDLE_instance;\n function TextLabel$HorizontalAnchor$MIDDLE_getInstance() {\n TextLabel$HorizontalAnchor_initFields();\n return TextLabel$HorizontalAnchor$MIDDLE_instance;\n }\n TextLabel$HorizontalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAnchor',\n interfaces: [Enum]\n };\n function TextLabel$HorizontalAnchor$values() {\n return [TextLabel$HorizontalAnchor$LEFT_getInstance(), TextLabel$HorizontalAnchor$RIGHT_getInstance(), TextLabel$HorizontalAnchor$MIDDLE_getInstance()];\n }\n TextLabel$HorizontalAnchor.values = TextLabel$HorizontalAnchor$values;\n function TextLabel$HorizontalAnchor$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return TextLabel$HorizontalAnchor$LEFT_getInstance();\n case 'RIGHT':\n return TextLabel$HorizontalAnchor$RIGHT_getInstance();\n case 'MIDDLE':\n return TextLabel$HorizontalAnchor$MIDDLE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor.' + name);\n }\n }\n TextLabel$HorizontalAnchor.valueOf_61zpoe$ = TextLabel$HorizontalAnchor$valueOf;\n function TextLabel$VerticalAnchor(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function TextLabel$VerticalAnchor_initFields() {\n TextLabel$VerticalAnchor_initFields = function () {\n };\n TextLabel$VerticalAnchor$TOP_instance = new TextLabel$VerticalAnchor('TOP', 0);\n TextLabel$VerticalAnchor$BOTTOM_instance = new TextLabel$VerticalAnchor('BOTTOM', 1);\n TextLabel$VerticalAnchor$CENTER_instance = new TextLabel$VerticalAnchor('CENTER', 2);\n }\n var TextLabel$VerticalAnchor$TOP_instance;\n function TextLabel$VerticalAnchor$TOP_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$TOP_instance;\n }\n var TextLabel$VerticalAnchor$BOTTOM_instance;\n function TextLabel$VerticalAnchor$BOTTOM_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$BOTTOM_instance;\n }\n var TextLabel$VerticalAnchor$CENTER_instance;\n function TextLabel$VerticalAnchor$CENTER_getInstance() {\n TextLabel$VerticalAnchor_initFields();\n return TextLabel$VerticalAnchor$CENTER_instance;\n }\n TextLabel$VerticalAnchor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAnchor',\n interfaces: [Enum]\n };\n function TextLabel$VerticalAnchor$values() {\n return [TextLabel$VerticalAnchor$TOP_getInstance(), TextLabel$VerticalAnchor$BOTTOM_getInstance(), TextLabel$VerticalAnchor$CENTER_getInstance()];\n }\n TextLabel$VerticalAnchor.values = TextLabel$VerticalAnchor$values;\n function TextLabel$VerticalAnchor$valueOf(name) {\n switch (name) {\n case 'TOP':\n return TextLabel$VerticalAnchor$TOP_getInstance();\n case 'BOTTOM':\n return TextLabel$VerticalAnchor$BOTTOM_getInstance();\n case 'CENTER':\n return TextLabel$VerticalAnchor$CENTER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor.' + name);\n }\n }\n TextLabel$VerticalAnchor.valueOf_61zpoe$ = TextLabel$VerticalAnchor$valueOf;\n TextLabel.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TextLabel',\n interfaces: [SvgComponent]\n };\n function AbstractScale() {\n this.definedBreaks_0 = null;\n this.definedLabels_0 = null;\n this.name_iafnnl$_0 = null;\n this.mapper_ohg8eh$_0 = null;\n this.multiplicativeExpand_lxi716$_0 = 0.0;\n this.additiveExpand_59ok4k$_0 = 0.0;\n this.labelFormatter_tb2f2k$_0 = null;\n }\n Object.defineProperty(AbstractScale.prototype, 'name', {\n configurable: true,\n get: function () {\n return this.name_iafnnl$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'mapper', {\n configurable: true,\n get: function () {\n return this.mapper_ohg8eh$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'multiplicativeExpand', {\n configurable: true,\n get: function () {\n return this.multiplicativeExpand_lxi716$_0;\n },\n set: function (multiplicativeExpand) {\n this.multiplicativeExpand_lxi716$_0 = multiplicativeExpand;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'additiveExpand', {\n configurable: true,\n get: function () {\n return this.additiveExpand_59ok4k$_0;\n },\n set: function (additiveExpand) {\n this.additiveExpand_59ok4k$_0 = additiveExpand;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'labelFormatter', {\n configurable: true,\n get: function () {\n return this.labelFormatter_tb2f2k$_0;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(AbstractScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n AbstractScale.prototype.hasBreaks = function () {\n return this.definedBreaks_0 != null;\n };\n AbstractScale.prototype.getBreaksIntern = function () {\n var tmp$;\n if (!this.hasBreaks()) {\n var message = 'No breaks defined for scale ' + this.name;\n throw IllegalStateException_init(message.toString());\n }return Kotlin.isType(tmp$ = this.definedBreaks_0, List) ? tmp$ : throwCCE();\n };\n AbstractScale.prototype.getLabelsIntern = function () {\n if (!(this.definedLabels_0 != null)) {\n var message = 'No labels defined for scale ' + this.name;\n throw IllegalStateException_init(message.toString());\n }return this.definedLabels_0;\n };\n AbstractScale.prototype.applyTransform_yzw12z$ = function (source, checkLimits) {\n var tmp$;\n var source_0 = source;\n if (checkLimits && this.hasDomainLimits()) {\n var $receiver = source_0;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item == null || this.isInDomainLimits_za3rmp$(item) ? item : null);\n }\n source_0 = destination;\n }if (Kotlin.isType(this.transform, ContinuousTransform)) {\n var continuousTransform = Kotlin.isType(tmp$ = this.transform, ContinuousTransform) ? tmp$ : throwCCE();\n if (continuousTransform.hasDomainLimits()) {\n var $receiver_0 = source_0;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_1;\n tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n var tmp$_2;\n destination_0.add_11rb$(continuousTransform.isInDomain_yrwdxb$((tmp$_2 = item_0) == null || typeof tmp$_2 === 'number' ? tmp$_2 : throwCCE()) ? item_0 : null);\n }\n source_0 = destination_0;\n }}return this.transform.apply_9ma18$(source_0);\n };\n AbstractScale.prototype.getScaleBreaks = function () {\n if (!this.hasBreaks()) {\n return ScaleBreaks$Companion_getInstance().EMPTY;\n }var breakValuesIntern = this.getBreaksIntern();\n var labels = this.getLabels_0(breakValuesIntern);\n var transformed = this.applyTransform_yzw12z$(breakValuesIntern, false);\n var destination = ArrayList_init_1(collectionSizeOrDefault(transformed, 10));\n var tmp$, tmp$_0;\n var index = 0;\n tmp$ = transformed.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_1 = destination.add_11rb$;\n var i = checkIndexOverflow((tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0));\n tmp$_1.call(destination, item == null ? null : i);\n }\n var keepIndices = toSet(filterNotNull(destination));\n var destination_0 = ArrayList_init();\n var tmp$_2, tmp$_0_0;\n var index_0 = 0;\n tmp$_2 = breakValuesIntern.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n if (keepIndices.contains_11rb$(checkIndexOverflow((tmp$_0_0 = index_0, index_0 = tmp$_0_0 + 1 | 0, tmp$_0_0))))\n destination_0.add_11rb$(item_0);\n }\n var tmp$_3 = filterNotNull(transformed);\n var destination_1 = ArrayList_init();\n var tmp$_4, tmp$_0_1;\n var index_1 = 0;\n tmp$_4 = labels.iterator();\n while (tmp$_4.hasNext()) {\n var item_1 = tmp$_4.next();\n if (keepIndices.contains_11rb$(checkIndexOverflow((tmp$_0_1 = index_1, index_1 = tmp$_0_1 + 1 | 0, tmp$_0_1))))\n destination_1.add_11rb$(item_1);\n }\n return new ScaleBreaks(destination_0, tmp$_3, destination_1);\n };\n function AbstractScale$getLabels$lambda(v) {\n return v.toString();\n }\n AbstractScale.prototype.getLabels_0 = function (breaks) {\n var tmp$, tmp$_0;\n if (this.definedLabels_0 != null) {\n var labels = this.getLabelsIntern();\n if (labels.isEmpty()) {\n var size = breaks.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$('');\n }\n tmp$ = list;\n } else if (breaks.size <= labels.size)\n tmp$ = labels.subList_vux9f0$(0, breaks.size);\n else {\n var size_0 = breaks.size;\n var list_0 = ArrayList_init_1(size_0);\n for (var index_0 = 0; index_0 < size_0; index_0++) {\n list_0.add_11rb$(labels.get_za3lpa$(index_0 % labels.size));\n }\n tmp$ = list_0;\n }\n return tmp$;\n }var formatter = (tmp$_0 = this.labelFormatter) != null ? tmp$_0 : AbstractScale$getLabels$lambda;\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_1;\n tmp$_1 = breaks.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination.add_11rb$(formatter(item));\n }\n return destination;\n };\n function AbstractScale$AbstractBuilder(scale) {\n this.myName_8be2vx$ = scale.name;\n this.myBreaks_8be2vx$ = scale.definedBreaks_0;\n this.myLabels_8be2vx$ = scale.definedLabels_0;\n this.myLabelFormatter_8be2vx$ = scale.labelFormatter;\n this.myMapper_8be2vx$ = scale.mapper;\n this.myMultiplicativeExpand_8be2vx$ = scale.multiplicativeExpand;\n this.myAdditiveExpand_8be2vx$ = scale.additiveExpand;\n }\n AbstractScale$AbstractBuilder.prototype.breaks_pqjuzw$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0;\n destination.add_11rb$((tmp$_0 = item) == null || Kotlin.isType(tmp$_0, Any) ? tmp$_0 : throwCCE());\n }\n this.myBreaks_8be2vx$ = destination;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.labels_mhpeer$ = function (l) {\n this.myLabels_8be2vx$ = l;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.labelFormatter_h0j1qz$ = function (v) {\n this.myLabelFormatter_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.mapper_1uitho$ = function (m) {\n this.myMapper_8be2vx$ = m;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.multiplicativeExpand_14dthe$ = function (v) {\n this.myMultiplicativeExpand_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.prototype.additiveExpand_14dthe$ = function (v) {\n this.myAdditiveExpand_8be2vx$ = v;\n return this;\n };\n AbstractScale$AbstractBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractBuilder',\n interfaces: [Scale$Builder]\n };\n AbstractScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractScale',\n interfaces: [Scale]\n };\n function AbstractScale_init(name, mapper, breaks, $this) {\n if (breaks === void 0)\n breaks = null;\n $this = $this || Object.create(AbstractScale.prototype);\n AbstractScale.call($this);\n $this.name_iafnnl$_0 = name;\n $this.mapper_ohg8eh$_0 = mapper;\n $this.definedBreaks_0 = breaks;\n $this.definedLabels_0 = null;\n $this.labelFormatter_tb2f2k$_0 = null;\n return $this;\n }\n function AbstractScale_init_0(b, $this) {\n $this = $this || Object.create(AbstractScale.prototype);\n AbstractScale.call($this);\n $this.name_iafnnl$_0 = b.myName_8be2vx$;\n $this.definedBreaks_0 = b.myBreaks_8be2vx$;\n $this.definedLabels_0 = b.myLabels_8be2vx$;\n $this.labelFormatter_tb2f2k$_0 = b.myLabelFormatter_8be2vx$;\n $this.mapper_ohg8eh$_0 = b.myMapper_8be2vx$;\n $this.multiplicativeExpand = b.myMultiplicativeExpand_8be2vx$;\n $this.additiveExpand = b.myAdditiveExpand_8be2vx$;\n return $this;\n }\n function BreaksGenerator() {\n }\n BreaksGenerator.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BreaksGenerator',\n interfaces: []\n };\n function ContinuousScale() {\n this.continuousTransform_0 = null;\n this.customBreaksGenerator_0 = null;\n this.isContinuous_r02bms$_0 = false;\n this.isContinuousDomain_cs93sw$_0 = true;\n this.continuousDomainLimits = null;\n }\n Object.defineProperty(ContinuousScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return this.isContinuous_r02bms$_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n return this.isContinuousDomain_cs93sw$_0;\n }\n });\n Object.defineProperty(ContinuousScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n return this.continuousTransform_0;\n }\n });\n ContinuousScale.prototype.getBreaksGenerator = function () {\n var tmp$;\n if (this.customBreaksGenerator_0 != null) {\n tmp$ = new Transforms$BreaksGeneratorForTransformedDomain(this.continuousTransform_0, this.customBreaksGenerator_0);\n } else {\n tmp$ = Transforms_getInstance().createBreaksGeneratorForTransformedDomain_5x42z5$(this.continuousTransform_0, this.labelFormatter);\n }\n return tmp$;\n };\n ContinuousScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n var tmp$;\n if (Kotlin.isNumber(v)) {\n var d = numberToDouble(v);\n tmp$ = (isFinite(d) && d >= this.continuousDomainLimits.first && d <= this.continuousDomainLimits.second);\n } else {\n tmp$ = false;\n }\n return tmp$;\n };\n ContinuousScale.prototype.hasDomainLimits = function () {\n return isFinite(this.continuousDomainLimits.first) || isFinite(this.continuousDomainLimits.second);\n };\n ContinuousScale.prototype.with = function () {\n return new ContinuousScale$MyBuilder(this);\n };\n function ContinuousScale$MyBuilder(scale) {\n AbstractScale$AbstractBuilder.call(this, scale);\n this.myContinuousTransform = scale.continuousTransform_0;\n this.myCustomBreaksGenerator = scale.customBreaksGenerator_0;\n this.myLowerLimit = scale.continuousDomainLimits.first;\n this.myUpperLimit = scale.continuousDomainLimits.second;\n this.myContinuousOutput = scale.isContinuous;\n }\n ContinuousScale$MyBuilder.prototype.lowerLimit_14dthe$ = function (v) {\n if (!isFinite(v)) {\n var message = \"`lower` can't be \" + v;\n throw IllegalArgumentException_init(message.toString());\n }this.myLowerLimit = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.upperLimit_14dthe$ = function (v) {\n if (!isFinite(v)) {\n var message = \"`upper` can't be \" + v;\n throw IllegalArgumentException_init(message.toString());\n }this.myUpperLimit = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.limits_pqjuzw$ = function (domainValues) {\n throw IllegalArgumentException_init(\"Can't apply discrete limits to scale with continuous domain\");\n };\n ContinuousScale$MyBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n this.myContinuousTransform = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n this.myCustomBreaksGenerator = v;\n return this;\n };\n ContinuousScale$MyBuilder.prototype.build = function () {\n return ContinuousScale_init_0(this);\n };\n ContinuousScale$MyBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyBuilder',\n interfaces: [AbstractScale$AbstractBuilder]\n };\n ContinuousScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuousScale',\n interfaces: [AbstractScale]\n };\n function ContinuousScale_init(name, mapper, continuousOutput, $this) {\n $this = $this || Object.create(ContinuousScale.prototype);\n AbstractScale_init(name, mapper, void 0, $this);\n ContinuousScale.call($this);\n $this.isContinuous_r02bms$_0 = continuousOutput;\n $this.continuousDomainLimits = new Pair_0(kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY, kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY);\n $this.continuousTransform_0 = Transforms_getInstance().IDENTITY;\n $this.customBreaksGenerator_0 = null;\n $this.multiplicativeExpand = 0.05;\n $this.additiveExpand = 0.0;\n return $this;\n }\n function ContinuousScale_init_0(b, $this) {\n $this = $this || Object.create(ContinuousScale.prototype);\n AbstractScale_init_0(b, $this);\n ContinuousScale.call($this);\n $this.continuousTransform_0 = b.myContinuousTransform;\n $this.customBreaksGenerator_0 = b.myCustomBreaksGenerator;\n $this.isContinuous_r02bms$_0 = b.myContinuousOutput;\n var lower = data.SeriesUtil.isFinite_yrwdxb$(b.myLowerLimit) ? ensureNotNull(b.myLowerLimit) : kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY;\n var upper = data.SeriesUtil.isFinite_yrwdxb$(b.myUpperLimit) ? ensureNotNull(b.myUpperLimit) : kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n $this.continuousDomainLimits = new Pair_0(JsMath.min(lower, upper), JsMath.max(lower, upper));\n return $this;\n }\n function DiscreteScale() {\n this.discreteTransform_0 = null;\n }\n Object.defineProperty(DiscreteScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n return this.discreteTransform_0;\n }\n });\n DiscreteScale.prototype.getBreaksGenerator = function () {\n throw IllegalStateException_init(\"No breaks generator for discrete scale '\" + this.name + \"'\");\n };\n DiscreteScale.prototype.hasDomainLimits = function () {\n return this.discreteTransform_0.hasDomainLimits();\n };\n DiscreteScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n return this.discreteTransform_0.isInDomain_s8jyv4$(v);\n };\n DiscreteScale.prototype.getBreaksIntern = function () {\n var tmp$;\n if (!this.hasDomainLimits()) {\n tmp$ = AbstractScale.prototype.getBreaksIntern.call(this);\n } else {\n var breaksSet = toSet(AbstractScale.prototype.getBreaksIntern.call(this));\n var $receiver = this.discreteTransform_0.domainLimits;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (breaksSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n tmp$ = destination;\n }\n return tmp$;\n };\n DiscreteScale.prototype.getLabelsIntern = function () {\n var tmp$;\n var labels = AbstractScale.prototype.getLabelsIntern.call(this);\n if (!this.hasDomainLimits() || labels.isEmpty()) {\n tmp$ = labels;\n } else {\n var breaks = AbstractScale.prototype.getBreaksIntern.call(this);\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_0, tmp$_0_0;\n var index = 0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(labels.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index, index = tmp$_0_0 + 1 | 0, tmp$_0_0)) % labels.size));\n }\n var breakLabels = destination;\n var labelByBreak = toMap(zip(breaks, breakLabels));\n var $receiver = this.discreteTransform_0.domainLimits;\n var destination_0 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (labelByBreak.containsKey_11rb$(element))\n destination_0.add_11rb$(element);\n }\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault(destination_0, 10));\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_1.add_11rb$(getValue(labelByBreak, item_0));\n }\n tmp$ = destination_1;\n }\n return tmp$;\n };\n DiscreteScale.prototype.with = function () {\n return new DiscreteScale$MyBuilder(this);\n };\n function DiscreteScale$MyBuilder(scale) {\n AbstractScale$AbstractBuilder.call(this, scale);\n this.myDomainValues_8be2vx$ = scale.discreteTransform_0.domainValues;\n this.myDomainLimits_8be2vx$ = scale.discreteTransform_0.domainLimits;\n }\n DiscreteScale$MyBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.lowerLimit_14dthe$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.upperLimit_14dthe$ = function (v) {\n throw IllegalStateException_init('Not applicable to scale with discrete domain');\n };\n DiscreteScale$MyBuilder.prototype.limits_pqjuzw$ = function (domainValues) {\n this.myDomainLimits_8be2vx$ = domainValues;\n return this;\n };\n DiscreteScale$MyBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n return this;\n };\n DiscreteScale$MyBuilder.prototype.build = function () {\n return DiscreteScale_init_0(this);\n };\n DiscreteScale$MyBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyBuilder',\n interfaces: [AbstractScale$AbstractBuilder]\n };\n DiscreteScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteScale',\n interfaces: [AbstractScale]\n };\n function DiscreteScale_init(name, domainValues, mapper, $this) {\n $this = $this || Object.create(DiscreteScale.prototype);\n AbstractScale_init(name, mapper, toList_0(domainValues), $this);\n DiscreteScale.call($this);\n $this.discreteTransform_0 = new DiscreteTransform(domainValues, emptyList());\n $this.multiplicativeExpand = 0.0;\n $this.additiveExpand = 0.6;\n return $this;\n }\n function DiscreteScale_init_0(b, $this) {\n $this = $this || Object.create(DiscreteScale.prototype);\n AbstractScale_init_0(b, $this);\n DiscreteScale.call($this);\n $this.discreteTransform_0 = new DiscreteTransform(b.myDomainValues_8be2vx$, b.myDomainLimits_8be2vx$);\n return $this;\n }\n function MapperUtil() {\n MapperUtil_instance = this;\n }\n MapperUtil.prototype.map_rejkqi$ = function (r, mapper) {\n var a = ensureNotNull(mapper(r.lowerEnd));\n var b = ensureNotNull(mapper(r.upperEnd));\n return new ClosedRange(JsMath.min(a, b), JsMath.max(a, b));\n };\n MapperUtil.prototype.mapDiscreteDomainValuesToNumbers_7f6uoc$ = function (values) {\n return this.mapDiscreteDomainValuesToIndices_0(values);\n };\n MapperUtil.prototype.mapDiscreteDomainValuesToIndices_0 = function (values) {\n var tmp$, tmp$_0;\n var result = LinkedHashMap_init();\n var index = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (v != null && !result.containsKey_11rb$(v)) {\n var value = (tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0);\n result.put_xwzc9p$(v, value);\n }}\n return result;\n };\n MapperUtil.prototype.rangeWithLimitsAfterTransform_1g0x2p$ = function (dataRange, lowerLimit, upperLimit, trans) {\n var tmp$, tmp$_0;\n if (lowerLimit != null && isFinite(lowerLimit)) {\n tmp$ = lowerLimit;\n } else {\n tmp$ = dataRange.lowerEnd;\n }\n var lower = tmp$;\n if (!trans.isInDomain_yrwdxb$(lower)) {\n var message = '[' + toString(Kotlin.getKClassFromExpression(trans).simpleName) + '] Lower end ' + lower + \" is outside of transform's domain.\";\n throw IllegalStateException_init(message.toString());\n }if (upperLimit != null && isFinite(upperLimit)) {\n tmp$_0 = upperLimit;\n } else {\n tmp$_0 = dataRange.upperEnd;\n }\n var upper = tmp$_0;\n if (!trans.isInDomain_yrwdxb$(upper)) {\n var message_0 = '[' + toString(Kotlin.getKClassFromExpression(trans).simpleName) + '] Lower end ' + upper + \" is outside of transform's domain.\";\n throw IllegalStateException_init(message_0.toString());\n }var limits = listOf([lower, upper]);\n return ClosedRange.Companion.encloseAll_17hg47$(trans.apply_9ma18$(limits));\n };\n MapperUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MapperUtil',\n interfaces: []\n };\n var MapperUtil_instance = null;\n function MapperUtil_getInstance() {\n if (MapperUtil_instance === null) {\n new MapperUtil();\n }return MapperUtil_instance;\n }\n function Mappers() {\n Mappers_instance = this;\n this.IDENTITY = Mappers$IDENTITY$lambda;\n }\n function Mappers$undefined$lambda(it) {\n throw IllegalStateException_init('Undefined mapper');\n }\n Mappers.prototype.undefined_287e2$ = function () {\n return Mappers$undefined$lambda;\n };\n function Mappers$nullable$lambda(closure$ifNull, closure$f) {\n return function (n) {\n if (n == null) {\n return closure$ifNull;\n } else {\n return closure$f(n);\n }\n };\n }\n Mappers.prototype.nullable_q9jsah$ = function (f, ifNull) {\n return Mappers$nullable$lambda(ifNull, f);\n };\n function Mappers$constant$lambda(closure$v) {\n return function (it) {\n return closure$v;\n };\n }\n Mappers.prototype.constant_14dthe$ = function (v) {\n return Mappers$constant$lambda(v);\n };\n Mappers.prototype.mul_mdyssk$ = function (domain, rangeSpan) {\n var factor = rangeSpan / (domain.upperEnd - domain.lowerEnd);\n if (!!(isInfinite(factor) || isNaN_0(factor))) {\n var message = \"Can't create mapper with ratio: \" + factor;\n throw IllegalStateException_init(message.toString());\n }return this.mul_14dthe$(factor);\n };\n function Mappers$mul$lambda(closure$factor) {\n return function (v) {\n if (v != null) {\n return closure$factor * v;\n } else\n return null;\n };\n }\n Mappers.prototype.mul_14dthe$ = function (factor) {\n return Mappers$mul$lambda(factor);\n };\n Mappers.prototype.linear_1jkouz$ = function (domain, range, reverse) {\n if (reverse === void 0)\n reverse = false;\n return this.linear_yl4mmw$(domain, reverse ? range.upperEnd : range.lowerEnd, reverse ? range.lowerEnd : range.upperEnd, kotlin_js_internal_DoubleCompanionObject.NaN);\n };\n Mappers.prototype.linear_lww37m$ = function (domain, range, defaultValue) {\n return this.linear_yl4mmw$(domain, range.lowerEnd, range.upperEnd, defaultValue);\n };\n function Mappers$linear$lambda(closure$slop, closure$intersect, closure$defaultValue) {\n return function (input) {\n return data.SeriesUtil.isFinite_yrwdxb$(input) ? ensureNotNull(input) * closure$slop + closure$intersect : closure$defaultValue;\n };\n }\n Mappers.prototype.linear_yl4mmw$ = function (domain, rangeLow, rangeHigh, defaultValue) {\n var slop = (rangeHigh - rangeLow) / (domain.upperEnd - domain.lowerEnd);\n if (!data.SeriesUtil.isFinite_14dthe$(slop)) {\n var v = (rangeHigh - rangeLow) / 2 + rangeLow;\n return this.constant_14dthe$(v);\n }var intersect = rangeLow - domain.lowerEnd * slop;\n return Mappers$linear$lambda(slop, intersect, defaultValue);\n };\n Mappers.prototype.discreteToContinuous_83ntpg$ = function (domainValues, outputRange, naValue) {\n var tmp$;\n var numberByDomainValue = MapperUtil_getInstance().mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n tmp$ = data.SeriesUtil.range_l63ks6$(numberByDomainValue.values);\n if (tmp$ == null) {\n return this.IDENTITY;\n }var dataRange = tmp$;\n return this.linear_lww37m$(dataRange, outputRange, naValue);\n };\n function Mappers$discrete$lambda(closure$f) {\n return function (it) {\n return closure$f.apply_11rb$(it);\n };\n }\n Mappers.prototype.discrete_rath1t$ = function (outputValues, defaultOutputValue) {\n var f = new Mappers$DiscreteFun(outputValues, defaultOutputValue);\n return Mappers$discrete$lambda(f);\n };\n function Mappers$quantized$lambda(closure$defaultOutputValue) {\n return function (it) {\n return closure$defaultOutputValue;\n };\n }\n function Mappers$quantized$lambda_0(closure$f) {\n return function (it) {\n return closure$f.apply_11rb$(it);\n };\n }\n Mappers.prototype.quantized_hd8s0$ = function (domain, outputValues, defaultOutputValue) {\n if (domain == null) {\n return Mappers$quantized$lambda(defaultOutputValue);\n }var quantizer = new QuantizeScale();\n quantizer.domain_lu1900$(domain.lowerEnd, domain.upperEnd);\n quantizer.range_brywnq$(outputValues);\n var f = new Mappers$QuantizedFun(quantizer, defaultOutputValue);\n return Mappers$quantized$lambda_0(f);\n };\n function Mappers$DiscreteFun(myOutputValues, myDefaultOutputValue) {\n this.myOutputValues_0 = myOutputValues;\n this.myDefaultOutputValue_0 = myDefaultOutputValue;\n }\n Mappers$DiscreteFun.prototype.apply_11rb$ = function (value) {\n if (!data.SeriesUtil.isFinite_yrwdxb$(value)) {\n return this.myDefaultOutputValue_0;\n }var index = numberToInt(round(ensureNotNull(value)));\n index = index % this.myOutputValues_0.size;\n if (index < 0) {\n index = index + this.myOutputValues_0.size | 0;\n }return this.myOutputValues_0.get_za3lpa$(index);\n };\n Mappers$DiscreteFun.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteFun',\n interfaces: [Function]\n };\n function Mappers$QuantizedFun(myQuantizer, myDefaultOutputValue) {\n this.myQuantizer_0 = myQuantizer;\n this.myDefaultOutputValue_0 = myDefaultOutputValue;\n }\n Mappers$QuantizedFun.prototype.apply_11rb$ = function (value) {\n return !data.SeriesUtil.isFinite_yrwdxb$(value) ? this.myDefaultOutputValue_0 : this.myQuantizer_0.quantize_14dthe$(ensureNotNull(value));\n };\n Mappers$QuantizedFun.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuantizedFun',\n interfaces: [Function]\n };\n function Mappers$IDENTITY$lambda(v) {\n return v;\n }\n Mappers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Mappers',\n interfaces: []\n };\n var Mappers_instance = null;\n function Mappers_getInstance() {\n if (Mappers_instance === null) {\n new Mappers();\n }return Mappers_instance;\n }\n function ScaleBreaks(domainValues, transformedValues, labels) {\n ScaleBreaks$Companion_getInstance();\n this.domainValues = domainValues;\n this.transformedValues = transformedValues;\n this.labels = labels;\n if (!(this.domainValues.size === this.transformedValues.size)) {\n var message = 'Scale breaks size: ' + this.domainValues.size + ' transformed size: ' + this.transformedValues.size + ' but expected to be the same';\n throw IllegalArgumentException_init(message.toString());\n }if (!(this.domainValues.size === this.labels.size)) {\n var message_0 = 'Scale breaks size: ' + this.domainValues.size + ' labels size: ' + this.labels.size + ' but expected to be the same';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n Object.defineProperty(ScaleBreaks.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.domainValues.isEmpty();\n }\n });\n Object.defineProperty(ScaleBreaks.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.domainValues.size;\n }\n });\n function ScaleBreaks$Companion() {\n ScaleBreaks$Companion_instance = this;\n this.EMPTY = new ScaleBreaks(emptyList(), emptyList(), emptyList());\n }\n ScaleBreaks$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ScaleBreaks$Companion_instance = null;\n function ScaleBreaks$Companion_getInstance() {\n if (ScaleBreaks$Companion_instance === null) {\n new ScaleBreaks$Companion();\n }return ScaleBreaks$Companion_instance;\n }\n ScaleBreaks.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ScaleBreaks',\n interfaces: []\n };\n function ScaleUtil() {\n ScaleUtil_instance = this;\n }\n ScaleUtil.prototype.labelByBreak_x4zrm4$ = function (scale) {\n var scaleBreaks = scale.getScaleBreaks();\n return toMap(zip(scaleBreaks.domainValues, scaleBreaks.labels));\n };\n ScaleUtil.prototype.map_dp4lfi$ = function (range, scale) {\n return MapperUtil_getInstance().map_rejkqi$(range, scale.mapper);\n };\n ScaleUtil.prototype.map_9ksyxk$ = function (l, scale) {\n var mapper = scale.mapper;\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(mapper(item));\n }\n return destination;\n };\n ScaleUtil.prototype.inverseTransformToContinuousDomain_codrxm$ = function (l, scale) {\n var tmp$;\n if (!scale.isContinuousDomain) {\n var message = 'Not continuous numeric domain: ' + scale;\n throw IllegalStateException_init(message.toString());\n }return (Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE()).applyInverse_k9kaly$(l);\n };\n ScaleUtil.prototype.inverseTransform_codrxm$ = function (l, scale) {\n var tmp$;\n var transform = scale.transform;\n if (Kotlin.isType(transform, ContinuousTransform)) {\n tmp$ = transform.applyInverse_k9kaly$(l);\n } else {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$_0;\n tmp$_0 = l.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(transform.applyInverse_yrwdxb$(item));\n }\n tmp$ = destination;\n }\n return tmp$;\n };\n ScaleUtil.prototype.transformedDefinedLimits_x4zrm4$ = function (scale) {\n var tmp$, tmp$_0, tmp$_1;\n Kotlin.isType(tmp$ = scale, ContinuousScale) ? tmp$ : throwCCE();\n var tmp$_2 = scale.continuousDomainLimits;\n var lower = tmp$_2.component1()\n , upper = tmp$_2.component2();\n var transform = Kotlin.isType(tmp$_0 = scale.transform, ContinuousTransform) ? tmp$_0 : throwCCE();\n var tmp$_3 = new Pair_0(transform.isInDomain_yrwdxb$(lower) ? ensureNotNull(transform.apply_yrwdxb$(lower)) : kotlin_js_internal_DoubleCompanionObject.NaN, transform.isInDomain_yrwdxb$(upper) ? ensureNotNull(transform.apply_yrwdxb$(upper)) : kotlin_js_internal_DoubleCompanionObject.NaN);\n var transformedLower = tmp$_3.component1()\n , transformedUpper = tmp$_3.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(transformedLower, transformedUpper)) {\n tmp$_1 = new Pair_0(JsMath.min(transformedLower, transformedUpper), JsMath.max(transformedLower, transformedUpper));\n } else {\n tmp$_1 = new Pair_0(transformedLower, transformedUpper);\n }\n return tmp$_1;\n };\n ScaleUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleUtil',\n interfaces: []\n };\n var ScaleUtil_instance = null;\n function ScaleUtil_getInstance() {\n if (ScaleUtil_instance === null) {\n new ScaleUtil();\n }return ScaleUtil_instance;\n }\n function Scales() {\n Scales_instance = this;\n }\n Scales.prototype.continuousDomain_sqn2xl$ = function (name, aes) {\n return ContinuousScale_init(name, Mappers_getInstance().undefined_287e2$(), aes.isNumeric);\n };\n Scales.prototype.continuousDomainNumericRange_61zpoe$ = function (name) {\n return ContinuousScale_init(name, Mappers_getInstance().undefined_287e2$(), true);\n };\n Scales.prototype.continuousDomain_lo18em$ = function (name, mapper, continuousRange) {\n return ContinuousScale_init(name, mapper, continuousRange);\n };\n Scales.prototype.discreteDomain_uksd38$ = function (name, domainValues) {\n return this.discreteDomain_l9mre7$(name, domainValues, Mappers_getInstance().undefined_287e2$());\n };\n Scales.prototype.discreteDomain_l9mre7$ = function (name, domainValues, mapper) {\n return DiscreteScale_init(name, domainValues, mapper);\n };\n Scales.prototype.pureDiscrete_kiqtr1$ = function (name, domainValues, outputValues, defaultOutputValue) {\n return this.discreteDomain_uksd38$(name, domainValues).with().mapper_1uitho$(Mappers_getInstance().discrete_rath1t$(outputValues, defaultOutputValue)).build();\n };\n Scales.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Scales',\n interfaces: []\n };\n var Scales_instance = null;\n function Scales_getInstance() {\n if (Scales_instance === null) {\n new Scales();\n }return Scales_instance;\n }\n function BreaksHelperBase(start, end, targetCount) {\n this.normalStart = 0;\n this.normalEnd = 0;\n this.span = 0;\n this.targetStep = 0;\n this.isReversed = false;\n if (!isFinite(start)) {\n var message = 'range start ' + start;\n throw IllegalArgumentException_init(message.toString());\n }if (!isFinite(end)) {\n var message_0 = 'range end ' + end;\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(targetCount > 0)) {\n var message_1 = \"'count' must be positive: \" + targetCount;\n throw IllegalArgumentException_init(message_1.toString());\n }var span = end - start;\n var reversed = false;\n if (span < 0) {\n span = -span;\n reversed = true;\n }this.span = span;\n this.targetStep = this.span / targetCount;\n this.isReversed = reversed;\n this.normalStart = reversed ? end : start;\n this.normalEnd = reversed ? start : end;\n }\n BreaksHelperBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreaksHelperBase',\n interfaces: []\n };\n function DateTimeBreaksHelper(rangeStart, rangeEnd, count, minInterval) {\n if (minInterval === void 0)\n minInterval = null;\n BreaksHelperBase.call(this, rangeStart, rangeEnd, count);\n this.breaks_n95hiz$_0 = null;\n this.formatter = null;\n var tmp$;\n var step = this.targetStep;\n if (step < 1000) {\n this.formatter = (new TimeScaleTickFormatterFactory(minInterval)).getFormatter_14dthe$(step);\n this.breaks_n95hiz$_0 = (new LinearBreaksHelper(rangeStart, rangeEnd, count)).breaks;\n } else {\n var start = this.normalStart;\n var end = this.normalEnd;\n var ticks = null;\n if (minInterval != null) {\n ticks = toMutableList(minInterval.range_lu1900$(start, end));\n }if (ticks != null && ticks.size <= count) {\n this.formatter = ensureNotNull(minInterval).tickFormatter;\n } else if (step > YearInterval.Companion.MS) {\n this.formatter = YearInterval.Companion.TICK_FORMATTER;\n ticks = ArrayList_init();\n var startDateTime = time.TimeUtil.asDateTimeUTC_14dthe$(start);\n var startYear = startDateTime.year;\n if (startDateTime.isAfter_amwj4p$(time.TimeUtil.yearStart_za3lpa$(startYear))) {\n startYear = startYear + 1 | 0;\n }var endYear = time.TimeUtil.asDateTimeUTC_14dthe$(end).year;\n var helper = new LinearBreaksHelper(startYear, endYear, count);\n tmp$ = helper.breaks.iterator();\n while (tmp$.hasNext()) {\n var tickYear = tmp$.next();\n var tickDate = time.TimeUtil.yearStart_za3lpa$(numberToInt(round(tickYear)));\n ticks.add_11rb$(time.TimeUtil.asInstantUTC_amwj4p$(tickDate).toNumber());\n }\n } else {\n var interval_0 = interval.NiceTimeInterval.forMillis_14dthe$(step);\n this.formatter = interval_0.tickFormatter;\n ticks = toMutableList(interval_0.range_lu1900$(start, end));\n }\n if (this.isReversed) {\n reverse(ticks);\n }this.breaks_n95hiz$_0 = ticks;\n }\n }\n Object.defineProperty(DateTimeBreaksHelper.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_n95hiz$_0;\n }\n });\n DateTimeBreaksHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTimeBreaksHelper',\n interfaces: [BreaksHelperBase]\n };\n function LinearBreaksHelper(rangeStart, rangeEnd, count, precise) {\n LinearBreaksHelper$Companion_getInstance();\n if (precise === void 0)\n precise = false;\n BreaksHelperBase.call(this, rangeStart, rangeEnd, count);\n this.breaks_egvm9d$_0 = null;\n var tmp$, tmp$_0, tmp$_1;\n if (!(count > 0)) {\n var message = \"Can't compute breaks for count: \" + count;\n throw IllegalStateException_init(message.toString());\n }if (precise) {\n tmp$ = this.targetStep;\n } else {\n tmp$ = LinearBreaksHelper$Companion_getInstance().computeNiceStep_0(this.span, count);\n }\n var step = tmp$;\n if (precise) {\n var $receiver = until(0, count);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_2;\n tmp$_2 = $receiver.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(this.normalStart + step / 2 + item * step);\n }\n tmp$_0 = destination;\n } else {\n tmp$_0 = LinearBreaksHelper$Companion_getInstance().computeNiceBreaks_0(this.normalStart, this.normalEnd, step);\n }\n var breaks = tmp$_0;\n if (breaks.isEmpty()) {\n tmp$_1 = listOf_0(this.normalStart);\n } else if (this.isReversed) {\n tmp$_1 = asReversed(breaks);\n } else {\n tmp$_1 = breaks;\n }\n this.breaks_egvm9d$_0 = tmp$_1;\n }\n Object.defineProperty(LinearBreaksHelper.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_egvm9d$_0;\n }\n });\n function LinearBreaksHelper$Companion() {\n LinearBreaksHelper$Companion_instance = this;\n }\n LinearBreaksHelper$Companion.prototype.computeNiceStep_0 = function (span, count) {\n var tmp$;\n var stepRaw = span / count;\n var x = JsMath.log10(stepRaw);\n var step10Power = JsMath.floor(x);\n var step = JsMath.pow(10.0, step10Power);\n var error = step * count / span;\n if (error <= 0.15)\n tmp$ = step * 10.0;\n else if (error <= 0.35)\n tmp$ = step * 5.0;\n else if (error <= 0.75)\n tmp$ = step * 2.0;\n else\n tmp$ = step;\n return tmp$;\n };\n LinearBreaksHelper$Companion.prototype.computeNiceBreaks_0 = function (start, end, step) {\n if (step === 0.0)\n return emptyList();\n var delta = step / 10000;\n var startE = start - delta;\n var endE = end + delta;\n var breaks = ArrayList_init();\n var x = startE / step;\n var tick = JsMath.ceil(x) * step;\n if (start >= 0 && startE < 0) {\n tick = 0.0;\n }while (tick <= endE) {\n var a = tick;\n tick = JsMath.min(a, end);\n breaks.add_11rb$(tick);\n tick += step;\n }\n return breaks;\n };\n LinearBreaksHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinearBreaksHelper$Companion_instance = null;\n function LinearBreaksHelper$Companion_getInstance() {\n if (LinearBreaksHelper$Companion_instance === null) {\n new LinearBreaksHelper$Companion();\n }return LinearBreaksHelper$Companion_instance;\n }\n LinearBreaksHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearBreaksHelper',\n interfaces: [BreaksHelperBase]\n };\n function NumericBreakFormatter(value, step, allowMetricPrefix) {\n this.formatter_0 = null;\n var tmp$, tmp$_0, tmp$_1;\n if (value === 0.0) {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.MIN_VALUE * 10;\n } else {\n tmp$ = JsMath.abs(value);\n }\n var value_0 = tmp$;\n if (step === 0.0) {\n tmp$_0 = value_0 / 10;\n } else {\n tmp$_0 = JsMath.abs(step);\n }\n var step_0 = tmp$_0;\n var type = 'f';\n var delimiter = '';\n var x = JsMath.abs(value_0);\n var domain10Power = JsMath.log10(x);\n var step10Power = JsMath.log10(step_0);\n var precision = -step10Power;\n var scientificNotation = false;\n if (domain10Power < 0 && step10Power < -4) {\n scientificNotation = true;\n type = 'e';\n precision = domain10Power - step10Power;\n } else if (domain10Power > 7 && step10Power > 2) {\n scientificNotation = true;\n precision = domain10Power - step10Power;\n }if (precision < 0) {\n precision = 0.0;\n type = 'd';\n }var x_0 = precision - 0.001;\n precision = JsMath.ceil(x_0);\n if (scientificNotation) {\n if (domain10Power > 0 && allowMetricPrefix) {\n tmp$_1 = 's';\n } else {\n tmp$_1 = 'e';\n }\n type = tmp$_1;\n } else {\n delimiter = ',';\n }\n this.formatter_0 = NumberFormat_init(delimiter + '.' + numberToInt(precision) + type);\n }\n NumericBreakFormatter.prototype.apply_za3rmp$ = function (value) {\n var tmp$;\n return this.formatter_0.apply_3p81yu$(Kotlin.isNumber(tmp$ = value) ? tmp$ : throwCCE());\n };\n NumericBreakFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NumericBreakFormatter',\n interfaces: []\n };\n function QuantizeScale() {\n this.myHasDomain_0 = false;\n this.myDomainStart_0 = 0.0;\n this.myDomainEnd_0 = 0.0;\n this.myOutputValues_9bxfi2$_0 = this.myOutputValues_9bxfi2$_0;\n }\n Object.defineProperty(QuantizeScale.prototype, 'myOutputValues_0', {\n configurable: true,\n get: function () {\n if (this.myOutputValues_9bxfi2$_0 == null)\n return throwUPAE('myOutputValues');\n return this.myOutputValues_9bxfi2$_0;\n },\n set: function (myOutputValues) {\n this.myOutputValues_9bxfi2$_0 = myOutputValues;\n }\n });\n Object.defineProperty(QuantizeScale.prototype, 'outputValues', {\n configurable: true,\n get: function () {\n return this.myOutputValues_0;\n }\n });\n Object.defineProperty(QuantizeScale.prototype, 'domainQuantized', {\n configurable: true,\n get: function () {\n var tmp$;\n if (this.myDomainStart_0 === this.myDomainEnd_0) {\n return listOf_0(new ClosedRange(this.myDomainStart_0, this.myDomainEnd_0));\n }var list = ArrayList_init();\n var numBuckets = this.myOutputValues_0.size;\n var bucketSize = this.bucketSize_0();\n tmp$ = numBuckets - 1 | 0;\n for (var i = 0; i < tmp$; i++) {\n var bucket = new ClosedRange(this.myDomainStart_0 + bucketSize * i, this.myDomainStart_0 + bucketSize * (i + 1 | 0));\n list.add_11rb$(bucket);\n }\n var bucket_0 = new ClosedRange(this.myDomainStart_0 + bucketSize * (numBuckets - 1 | 0), this.myDomainEnd_0);\n list.add_11rb$(bucket_0);\n return list;\n }\n });\n QuantizeScale.prototype.domain_lu1900$ = function (start, end) {\n if (!(start <= end)) {\n var message = 'Domain start must be less then domain end: ' + start + ' > ' + end;\n throw IllegalArgumentException_init(message.toString());\n }this.myHasDomain_0 = true;\n this.myDomainStart_0 = start;\n this.myDomainEnd_0 = end;\n return this;\n };\n QuantizeScale.prototype.range_brywnq$ = function (values) {\n this.myOutputValues_0 = ArrayList_init_0(values);\n return this;\n };\n QuantizeScale.prototype.quantize_14dthe$ = function (v) {\n var i = this.outputIndex_0(v);\n return this.myOutputValues_0.get_za3lpa$(i);\n };\n QuantizeScale.prototype.outputIndex_0 = function (v) {\n if (!this.myHasDomain_0) {\n var message = 'Domain not defined.';\n throw IllegalStateException_init(message.toString());\n }var tmp$ = this.myOutputValues_9bxfi2$_0 != null;\n if (tmp$) {\n tmp$ = !this.myOutputValues_0.isEmpty();\n }if (!tmp$) {\n var message_0 = 'Output values are not defined.';\n throw IllegalStateException_init(message_0.toString());\n }var bucketSize = this.bucketSize_0();\n var index = numberToInt((v - this.myDomainStart_0) / bucketSize);\n var maxIndex = this.myOutputValues_0.size - 1 | 0;\n var b = JsMath.min(maxIndex, index);\n return JsMath.max(0, b);\n };\n QuantizeScale.prototype.getOutputValueIndex_za3rmp$ = function (domainValue) {\n var tmp$;\n if (Kotlin.isNumber(domainValue)) {\n tmp$ = this.outputIndex_0(numberToDouble(domainValue));\n } else\n tmp$ = -1;\n return tmp$;\n };\n QuantizeScale.prototype.getOutputValue_za3rmp$ = function (domainValue) {\n var tmp$;\n if (Kotlin.isNumber(domainValue)) {\n tmp$ = this.quantize_14dthe$(numberToDouble(domainValue));\n } else\n tmp$ = null;\n return tmp$;\n };\n QuantizeScale.prototype.bucketSize_0 = function () {\n return (this.myDomainEnd_0 - this.myDomainStart_0) / this.myOutputValues_0.size;\n };\n QuantizeScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuantizeScale',\n interfaces: [WithFiniteOrderedOutput]\n };\n function ScaleBreaksUtil() {\n ScaleBreaksUtil_instance = this;\n }\n ScaleBreaksUtil.prototype.withBreaks_qt1l9m$ = function (scale, transformedDomain, breakCount) {\n var scaleBreaks = scale.getBreaksGenerator().generateBreaks_1tlvto$(transformedDomain, breakCount);\n var breaks = scaleBreaks.domainValues;\n var labels = scaleBreaks.labels;\n return scale.with().breaks_pqjuzw$(breaks).labels_mhpeer$(labels).build();\n };\n ScaleBreaksUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleBreaksUtil',\n interfaces: []\n };\n var ScaleBreaksUtil_instance = null;\n function ScaleBreaksUtil_getInstance() {\n if (ScaleBreaksUtil_instance === null) {\n new ScaleBreaksUtil();\n }return ScaleBreaksUtil_instance;\n }\n function TimeScaleTickFormatterFactory(minInterval) {\n this.minInterval_0 = minInterval;\n }\n TimeScaleTickFormatterFactory.prototype.getFormatter_14dthe$ = function (step) {\n return text.Formatter.time_61zpoe$(this.formatPattern_0(step));\n };\n TimeScaleTickFormatterFactory.prototype.formatPattern_0 = function (step) {\n if (step < 1000) {\n return TimeInterval.Companion.milliseconds_za3lpa$(1).tickFormatPattern;\n }if (this.minInterval_0 != null) {\n var stepCount = 100;\n var start = 0.0;\n var end = step * stepCount;\n var intervalCount = this.minInterval_0.range_lu1900$(start, end).size;\n if (stepCount >= intervalCount) {\n return this.minInterval_0.tickFormatPattern;\n }}if (step > YearInterval.Companion.MS) {\n return YearInterval.Companion.TICK_FORMAT;\n }var interval_0 = interval.NiceTimeInterval.forMillis_14dthe$(step);\n return interval_0.tickFormatPattern;\n };\n TimeScaleTickFormatterFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeScaleTickFormatterFactory',\n interfaces: []\n };\n function WithFiniteOrderedOutput() {\n }\n WithFiniteOrderedOutput.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WithFiniteOrderedOutput',\n interfaces: []\n };\n function DateTimeBreaksGen(labelFormatter) {\n if (labelFormatter === void 0)\n labelFormatter = null;\n this.labelFormatter_0 = labelFormatter;\n }\n DateTimeBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$, tmp$_0;\n var helper = this.breaksHelper_0(domain, targetCount);\n var ticks = helper.breaks;\n var labelFormatter = (tmp$ = this.labelFormatter_0) != null ? tmp$ : helper.formatter;\n var labels = ArrayList_init();\n tmp$_0 = ticks.iterator();\n while (tmp$_0.hasNext()) {\n var tick = tmp$_0.next();\n labels.add_11rb$(labelFormatter(tick));\n }\n return new ScaleBreaks(ticks, ticks, labels);\n };\n DateTimeBreaksGen.prototype.breaksHelper_0 = function (domainAfterTransform, targetCount) {\n return new DateTimeBreaksHelper(domainAfterTransform.lowerEnd, domainAfterTransform.upperEnd, targetCount);\n };\n DateTimeBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.labelFormatter_0) != null ? tmp$ : this.breaksHelper_0(domain, targetCount).formatter;\n };\n DateTimeBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DateTimeBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function FunTransform(transformFun, inverseFun) {\n this.transformFun_vpw6mq$_0 = transformFun;\n this.inverseFun_2rsie$_0 = inverseFun;\n }\n FunTransform.prototype.apply_yrwdxb$ = function (v) {\n var tmp$;\n if (v != null) {\n tmp$ = this.transformFun_vpw6mq$_0(v);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n FunTransform.prototype.apply_9ma18$ = function (l) {\n var $receiver = this.safeCastToDoubles_9ma18$(l);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.apply_yrwdxb$(item));\n }\n return destination;\n };\n FunTransform.prototype.applyInverse_yrwdxb$ = function (v) {\n var tmp$;\n if (v != null) {\n tmp$ = this.inverseFun_2rsie$_0(v);\n } else {\n tmp$ = null;\n }\n return tmp$;\n };\n FunTransform.prototype.applyInverse_k9kaly$ = function (l) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(l, 10));\n var tmp$;\n tmp$ = l.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.applyInverse_yrwdxb$(item));\n }\n return destination;\n };\n FunTransform.prototype.safeCastToDoubles_9ma18$ = function (list) {\n var checkedDoubles = data.SeriesUtil.checkedDoubles_9ma18$(list);\n if (!checkedDoubles.canBeCast()) {\n var message = 'Not a collections of Double(s)';\n throw IllegalArgumentException_init(message.toString());\n }return checkedDoubles.cast();\n };\n FunTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FunTransform',\n interfaces: [ContinuousTransform]\n };\n function IdentityTransform() {\n FunTransform.call(this, IdentityTransform_init$lambda, IdentityTransform_init$lambda_0);\n }\n IdentityTransform.prototype.hasDomainLimits = function () {\n return false;\n };\n IdentityTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v);\n };\n IdentityTransform.prototype.createApplicableDomain_yrwdxb$$default = function (middle) {\n if (middle == null) {\n return this.createApplicableDomain_yrwdxb$(0.0);\n }var middle_0 = isFinite(middle) ? middle : 0.0;\n return new ClosedRange(middle_0 - 0.5, middle_0 + 0.5);\n };\n IdentityTransform.prototype.toApplicableDomain_4fzjta$ = function (range) {\n return range;\n };\n IdentityTransform.prototype.apply_9ma18$ = function (l) {\n return this.safeCastToDoubles_9ma18$(l);\n };\n IdentityTransform.prototype.applyInverse_k9kaly$ = function (l) {\n return l;\n };\n function IdentityTransform_init$lambda(v) {\n return v;\n }\n function IdentityTransform_init$lambda_0(v) {\n return v;\n }\n IdentityTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityTransform',\n interfaces: [FunTransform]\n };\n function LinearBreaksGen(formatter) {\n LinearBreaksGen$Companion_getInstance();\n if (formatter === void 0)\n formatter = null;\n this.formatter_0 = formatter;\n }\n LinearBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n var breaks = LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(domain, targetCount);\n var fmt = (tmp$ = this.formatter_0) != null ? tmp$ : LinearBreaksGen$Companion_getInstance().createFormatter_0(breaks);\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$_0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(fmt(item));\n }\n var labels = destination;\n return new ScaleBreaks(breaks, breaks, labels);\n };\n LinearBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.formatter_0) != null ? tmp$ : LinearBreaksGen$Companion_getInstance().createFormatter_0(LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(domain, targetCount));\n };\n function LinearBreaksGen$Companion() {\n LinearBreaksGen$Companion_instance = this;\n }\n LinearBreaksGen$Companion.prototype.generateBreakValues_omwdpb$ = function (domain, targetCount) {\n var helper = new LinearBreaksHelper(domain.lowerEnd, domain.upperEnd, targetCount);\n return helper.breaks;\n };\n LinearBreaksGen$Companion.prototype.createFormatter_0 = function (breakValues) {\n var tmp$, tmp$_0;\n if (breakValues.isEmpty())\n tmp$_0 = new Pair_0(0.0, 0.5);\n else {\n var x = first(breakValues);\n var tmp$_1 = JsMath.abs(x);\n var x_0 = last(breakValues);\n var b = JsMath.abs(x_0);\n var v = JsMath.max(tmp$_1, b);\n if (breakValues.size === 1)\n tmp$ = v / 10;\n else {\n var x_1 = breakValues.get_za3lpa$(1) - breakValues.get_za3lpa$(0);\n tmp$ = JsMath.abs(x_1);\n }\n var s = tmp$;\n tmp$_0 = new Pair_0(v, s);\n }\n var tmp$_2 = tmp$_0;\n var referenceValue = tmp$_2.component1()\n , step = tmp$_2.component2();\n var formatter = new NumericBreakFormatter(referenceValue, step, true);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, formatter));\n };\n LinearBreaksGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LinearBreaksGen$Companion_instance = null;\n function LinearBreaksGen$Companion_getInstance() {\n if (LinearBreaksGen$Companion_instance === null) {\n new LinearBreaksGen$Companion();\n }return LinearBreaksGen$Companion_instance;\n }\n LinearBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function Log10Transform() {\n Log10Transform$Companion_getInstance();\n FunTransform.call(this, Log10Transform_init$lambda, Log10Transform_init$lambda_0);\n }\n Log10Transform.prototype.hasDomainLimits = function () {\n return true;\n };\n Log10Transform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v) && ensureNotNull(v) >= Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n };\n Log10Transform.prototype.isZero_0 = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v) && ensureNotNull(v) >= 0.0 && v < Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n };\n Log10Transform.prototype.apply_yrwdxb$ = function (v) {\n return Log10Transform$Companion_getInstance().trimInfinity_0(FunTransform.prototype.apply_yrwdxb$.call(this, v));\n };\n Log10Transform.prototype.createApplicableDomain_yrwdxb$$default = function (middle) {\n var tmp$, tmp$_0;\n if (this.isInDomain_yrwdxb$(middle)) {\n var a = ensureNotNull(middle);\n var b = Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n tmp$ = JsMath.max(a, b);\n } else if (this.isZero_0(middle))\n tmp$ = Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n else\n tmp$ = 1.0;\n var middle_0 = tmp$;\n if (middle_0 < 1) {\n tmp$_0 = middle_0 / 2;\n } else {\n tmp$_0 = middle_0 - 0.5;\n }\n var lower = tmp$_0;\n var b_0 = Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n return new ClosedRange(JsMath.max(lower, b_0), middle_0 + 0.5);\n };\n Log10Transform.prototype.toApplicableDomain_4fzjta$ = function (range) {\n var a = range.lowerEnd;\n var b = Log10Transform$Companion_getInstance().LOWER_LIM_DOMAIN_8be2vx$;\n var lower = JsMath.max(a, b);\n var a_0 = range.upperEnd;\n var upper = JsMath.max(a_0, lower);\n return new ClosedRange(lower, upper);\n };\n function Log10Transform$Companion() {\n Log10Transform$Companion_instance = this;\n this.LOWER_LIM_TRANSFOTMED_8be2vx$ = -kotlin_js_internal_DoubleCompanionObject.MAX_VALUE / 10;\n this.LOWER_LIM_DOMAIN_8be2vx$ = kotlin_js_internal_DoubleCompanionObject.MIN_VALUE * 10;\n }\n Log10Transform$Companion.prototype.trimInfinity_0 = function (v) {\n var tmp$;\n if (v == null)\n tmp$ = null;\n else if (isNaN_0(v))\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n else {\n var a = this.LOWER_LIM_TRANSFOTMED_8be2vx$;\n tmp$ = JsMath.max(a, v);\n }\n return tmp$;\n };\n Log10Transform$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Log10Transform$Companion_instance = null;\n function Log10Transform$Companion_getInstance() {\n if (Log10Transform$Companion_instance === null) {\n new Log10Transform$Companion();\n }return Log10Transform$Companion_instance;\n }\n function Log10Transform_init$lambda(v) {\n return JsMath.log10(v);\n }\n function Log10Transform_init$lambda_0(v) {\n return JsMath.pow(10.0, v);\n }\n Log10Transform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Log10Transform',\n interfaces: [FunTransform]\n };\n function NonlinearBreaksGen(transform, formatter) {\n NonlinearBreaksGen$Companion_getInstance();\n if (formatter === void 0)\n formatter = null;\n this.transform_0 = transform;\n this.formatter_0 = formatter;\n }\n NonlinearBreaksGen.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n var breakValues = NonlinearBreaksGen$Companion_getInstance().generateBreakValues_0(domain, targetCount, this.transform_0);\n if (this.formatter_0 != null) {\n var size = breakValues.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(this.formatter_0);\n }\n tmp$ = list;\n } else {\n tmp$ = NonlinearBreaksGen$Companion_getInstance().createFormatters_0(breakValues);\n }\n var breakFormatters = tmp$;\n var destination = ArrayList_init_1(collectionSizeOrDefault(breakValues, 10));\n var tmp$_0, tmp$_0_0;\n var index_0 = 0;\n tmp$_0 = breakValues.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(breakFormatters.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index_0, index_0 = tmp$_0_0 + 1 | 0, tmp$_0_0)))(item));\n }\n var labels = destination;\n return new ScaleBreaks(breakValues, breakValues, labels);\n };\n NonlinearBreaksGen.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var tmp$;\n return (tmp$ = this.formatter_0) != null ? tmp$ : NonlinearBreaksGen$Companion_getInstance().createMultiFormatter_0(NonlinearBreaksGen$Companion_getInstance().generateBreakValues_0(domain, targetCount, this.transform_0));\n };\n function NonlinearBreaksGen$Companion() {\n NonlinearBreaksGen$Companion_instance = this;\n }\n function NonlinearBreaksGen$Companion$generateBreakValues$lambda(closure$transform) {\n return function (it) {\n return closure$transform.apply_yrwdxb$(it);\n };\n }\n NonlinearBreaksGen$Companion.prototype.generateBreakValues_0 = function (domain, targetCount, transform) {\n var transformedDomain = MapperUtil_getInstance().map_rejkqi$(domain, NonlinearBreaksGen$Companion$generateBreakValues$lambda(transform));\n var transformedBreakValues = LinearBreaksGen$Companion_getInstance().generateBreakValues_omwdpb$(transformedDomain, targetCount);\n return filterNotNull(transform.applyInverse_k9kaly$(transformedBreakValues));\n };\n NonlinearBreaksGen$Companion.prototype.createMultiFormatter_0 = function (breakValues) {\n var breakFormatters = this.createFormatters_0(breakValues);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, new NonlinearBreaksGen$MultiFormatter(breakValues, breakFormatters)));\n };\n NonlinearBreaksGen$Companion.prototype.createFormatters_0 = function (breakValues) {\n if (breakValues.isEmpty())\n return emptyList();\n if (breakValues.size === 1) {\n var domainValue = breakValues.get_za3lpa$(0);\n var step = domainValue / 10;\n return listOf_0(this.createFormatter_0(domainValue, step));\n }var destination = ArrayList_init_1(collectionSizeOrDefault(breakValues, 10));\n var tmp$, tmp$_0;\n var index = 0;\n tmp$ = breakValues.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_1 = destination.add_11rb$;\n var i = checkIndexOverflow((tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0));\n var tmp$_2;\n if (i === 0)\n tmp$_2 = item - breakValues.get_za3lpa$(i + 1 | 0);\n else\n tmp$_2 = item - breakValues.get_za3lpa$(i - 1 | 0);\n var x = tmp$_2;\n var step_0 = JsMath.abs(x);\n tmp$_1.call(destination, this.createFormatter_0(item, step_0));\n }\n var formatters = destination;\n return formatters;\n };\n NonlinearBreaksGen$Companion.prototype.createFormatter_0 = function (domainValue, step) {\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_za3rmp$(p1);\n }.bind(null, new NumericBreakFormatter(domainValue, step, true)));\n };\n NonlinearBreaksGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var NonlinearBreaksGen$Companion_instance = null;\n function NonlinearBreaksGen$Companion_getInstance() {\n if (NonlinearBreaksGen$Companion_instance === null) {\n new NonlinearBreaksGen$Companion();\n }return NonlinearBreaksGen$Companion_instance;\n }\n function NonlinearBreaksGen$MultiFormatter(breakValues, breakFormatters) {\n this.breakValues = breakValues;\n this.breakFormatters = breakFormatters;\n if (!(this.breakValues.size === this.breakFormatters.size)) {\n var message = 'MultiFormatter: breakValues.size=' + this.breakValues.size + ' but breakFormatters.size=' + this.breakFormatters.size;\n throw IllegalStateException_init(message.toString());\n }if (this.breakValues.size > 1) {\n var $receiver = this.breakValues;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$, tmp$_0;\n var index = 0;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_1 = destination.add_11rb$;\n var i = checkIndexOverflow((tmp$_0 = index, index = tmp$_0 + 1 | 0, tmp$_0));\n tmp$_1.call(destination, i === 0 ? 0.0 : item - this.breakValues.get_za3lpa$(i - 1 | 0));\n }\n var all$result;\n all$break: do {\n var tmp$_2;\n if (Kotlin.isType(destination, Collection) && destination.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (!(element >= 0.0)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n var ordered = all$result;\n if (!ordered) {\n var message_0 = 'MultiFormatter: values must be sorted in ascending order. Were: ' + this.breakValues + '.';\n throw IllegalStateException_init(message_0.toString());\n }}}\n NonlinearBreaksGen$MultiFormatter.prototype.apply_za3rmp$ = function (v) {\n var tmp$, tmp$_0;\n typeof (tmp$ = v) === 'number' ? tmp$ : throwCCE();\n if (this.breakValues.isEmpty())\n tmp$_0 = v.toString();\n else {\n var i = abs(binarySearch(this.breakValues, v));\n var b = this.breakValues.size - 1 | 0;\n var ii = JsMath.min(i, b);\n tmp$_0 = this.breakFormatters.get_za3lpa$(ii)(v);\n }\n return tmp$_0;\n };\n NonlinearBreaksGen$MultiFormatter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiFormatter',\n interfaces: []\n };\n NonlinearBreaksGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NonlinearBreaksGen',\n interfaces: [BreaksGenerator]\n };\n function ReverseTransform() {\n FunTransform.call(this, ReverseTransform_init$lambda, ReverseTransform_init$lambda_0);\n }\n ReverseTransform.prototype.hasDomainLimits = function () {\n return false;\n };\n ReverseTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v);\n };\n ReverseTransform.prototype.createApplicableDomain_yrwdxb$$default = function (middle) {\n return Transforms_getInstance().IDENTITY.createApplicableDomain_yrwdxb$(middle);\n };\n ReverseTransform.prototype.toApplicableDomain_4fzjta$ = function (range) {\n return Transforms_getInstance().IDENTITY.toApplicableDomain_4fzjta$(range);\n };\n function ReverseTransform_init$lambda(v) {\n return -v;\n }\n function ReverseTransform_init$lambda_0(v) {\n return -v;\n }\n ReverseTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ReverseTransform',\n interfaces: [FunTransform]\n };\n function SqrtTransform() {\n FunTransform.call(this, SqrtTransform_init$lambda, SqrtTransform_init$lambda_0);\n }\n SqrtTransform.prototype.hasDomainLimits = function () {\n return true;\n };\n SqrtTransform.prototype.isInDomain_yrwdxb$ = function (v) {\n return data.SeriesUtil.isFinite_yrwdxb$(v) && ensureNotNull(v) >= 0.0;\n };\n SqrtTransform.prototype.createApplicableDomain_yrwdxb$$default = function (middle) {\n var tmp$;\n if (this.isInDomain_yrwdxb$(middle)) {\n var a = ensureNotNull(middle);\n tmp$ = JsMath.max(a, 0.0);\n } else\n tmp$ = 1.0;\n var middle_0 = tmp$;\n var a_0 = middle_0 - 0.5;\n return new ClosedRange(JsMath.max(a_0, 0.0), middle_0 + 0.5);\n };\n SqrtTransform.prototype.toApplicableDomain_4fzjta$ = function (range) {\n var a = range.lowerEnd;\n var lower = JsMath.max(a, 0.0);\n var a_0 = range.upperEnd;\n var upper = JsMath.max(a_0, 0.0);\n return new ClosedRange(lower, upper);\n };\n function SqrtTransform_init$lambda(v) {\n return JsMath.sqrt(v);\n }\n function SqrtTransform_init$lambda_0(v) {\n return v * v;\n }\n SqrtTransform.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SqrtTransform',\n interfaces: [FunTransform]\n };\n function Transforms() {\n Transforms_instance = this;\n this.IDENTITY = new IdentityTransform();\n this.REVERSE = new ReverseTransform();\n this.SQRT = new SqrtTransform();\n this.LOG10 = new Log10Transform();\n }\n Transforms.prototype.createBreaksGeneratorForTransformedDomain_5x42z5$ = function (transform, labelFormatter) {\n if (labelFormatter === void 0)\n labelFormatter = null;\n var tmp$;\n if (equals(transform, this.IDENTITY))\n tmp$ = new LinearBreaksGen(labelFormatter);\n else if (equals(transform, this.REVERSE))\n tmp$ = new LinearBreaksGen(labelFormatter);\n else if (equals(transform, this.SQRT))\n tmp$ = new NonlinearBreaksGen(this.SQRT, labelFormatter);\n else if (equals(transform, this.LOG10))\n tmp$ = new NonlinearBreaksGen(this.LOG10, labelFormatter);\n else\n throw IllegalStateException_init(\"Unexpected 'transform' type: \" + toString(Kotlin.getKClassFromExpression(transform).simpleName));\n var breaksGenerator = tmp$;\n return new Transforms$BreaksGeneratorForTransformedDomain(transform, breaksGenerator);\n };\n Transforms.prototype.ensureApplicableDomain_wa8y5m$ = function (dataRange, transform) {\n var tmp$;\n if (dataRange == null) {\n return transform.createApplicableDomain_yrwdxb$();\n }var domain = transform.toApplicableDomain_4fzjta$(dataRange);\n if (data.SeriesUtil.isSubTiny_4fzjta$(domain))\n tmp$ = transform.createApplicableDomain_yrwdxb$(domain.upperEnd);\n else\n tmp$ = domain;\n return tmp$;\n };\n function Transforms$BreaksGeneratorForTransformedDomain(transform, breaksGenerator) {\n this.transform_0 = transform;\n this.breaksGenerator = breaksGenerator;\n }\n function Transforms$BreaksGeneratorForTransformedDomain$labelFormatter$lambda(this$BreaksGeneratorForTransformedDomain) {\n return function (it) {\n return this$BreaksGeneratorForTransformedDomain.transform_0.applyInverse_yrwdxb$(it);\n };\n }\n Transforms$BreaksGeneratorForTransformedDomain.prototype.labelFormatter_1tlvto$ = function (domain, targetCount) {\n var domainBeforeTransform = MapperUtil_getInstance().map_rejkqi$(domain, Transforms$BreaksGeneratorForTransformedDomain$labelFormatter$lambda(this));\n return this.breaksGenerator.labelFormatter_1tlvto$(domainBeforeTransform, targetCount);\n };\n function Transforms$BreaksGeneratorForTransformedDomain$generateBreaks$lambda(this$BreaksGeneratorForTransformedDomain) {\n return function (it) {\n return this$BreaksGeneratorForTransformedDomain.transform_0.applyInverse_yrwdxb$(it);\n };\n }\n Transforms$BreaksGeneratorForTransformedDomain.prototype.generateBreaks_1tlvto$ = function (domain, targetCount) {\n var domainBeforeTransform = MapperUtil_getInstance().map_rejkqi$(domain, Transforms$BreaksGeneratorForTransformedDomain$generateBreaks$lambda(this));\n var scaleBreaks = this.breaksGenerator.generateBreaks_1tlvto$(domainBeforeTransform, targetCount);\n var originalBreaks = scaleBreaks.domainValues;\n var $receiver = this.transform_0.apply_9ma18$(originalBreaks);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0;\n destination.add_11rb$(typeof (tmp$_0 = item) === 'number' ? tmp$_0 : throwCCE());\n }\n var transformedBreaks = destination;\n return new ScaleBreaks(originalBreaks, transformedBreaks, scaleBreaks.labels);\n };\n Transforms$BreaksGeneratorForTransformedDomain.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreaksGeneratorForTransformedDomain',\n interfaces: [BreaksGenerator]\n };\n Transforms.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Transforms',\n interfaces: []\n };\n var Transforms_instance = null;\n function Transforms_getInstance() {\n if (Transforms_instance === null) {\n new Transforms();\n }return Transforms_instance;\n }\n function AbstractDensity2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat$Companion_getInstance();\n BaseStat.call(this, AbstractDensity2dStat$Companion_getInstance().DEF_MAPPING_0);\n this.bandWidthX_pmqi0t$_0 = bandWidthX;\n this.bandWidthY_pmqi1o$_0 = bandWidthY;\n this.bandWidthMethod_3lcf4y$_0 = bandWidthMethod;\n this.adjust = adjust;\n this.kernel_ba223r$_0 = kernel;\n this.nX = nX;\n this.nY = nY;\n this.isContour = isContour;\n this.binCount_6z2ebo$_0 = binCount;\n this.binWidth_2e8jdx$_0 = binWidth;\n this.kernelFun = DensityStatUtil_getInstance().kernel_uyf859$(this.kernel_ba223r$_0);\n this.binOptions = new BinStatUtil$BinOptions(this.binCount_6z2ebo$_0, this.binWidth_2e8jdx$_0);\n if (!(this.nX <= 999)) {\n var message = 'The input nX = ' + this.nX + ' > ' + '999' + ' is too large!';\n throw IllegalArgumentException_init(message.toString());\n }if (!(this.nY <= 999)) {\n var message_0 = 'The input nY = ' + this.nY + ' > ' + '999' + ' is too large!';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n AbstractDensity2dStat.prototype.getBandWidthX_k9kaly$ = function (xs) {\n var tmp$;\n return (tmp$ = this.bandWidthX_pmqi0t$_0) != null ? tmp$ : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0, xs);\n };\n AbstractDensity2dStat.prototype.getBandWidthY_k9kaly$ = function (ys) {\n var tmp$;\n return (tmp$ = this.bandWidthY_pmqi1o$_0) != null ? tmp$ : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0, ys);\n };\n AbstractDensity2dStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WEIGHT]);\n };\n AbstractDensity2dStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n throw IllegalStateException_init(\"'density2d' statistic can't be executed on the client side\");\n };\n function AbstractDensity2dStat$Companion() {\n AbstractDensity2dStat$Companion_instance = this;\n this.DEF_KERNEL = DensityStat$Kernel$GAUSSIAN_getInstance();\n this.DEF_ADJUST = 1.0;\n this.DEF_N = 100;\n this.DEF_BW = DensityStat$BandWidthMethod$NRD0_getInstance();\n this.DEF_CONTOUR = true;\n this.DEF_BIN_COUNT = 10;\n this.DEF_BIN_WIDTH = 0.0;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n this.MAX_N_0 = 999;\n }\n AbstractDensity2dStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractDensity2dStat$Companion_instance = null;\n function AbstractDensity2dStat$Companion_getInstance() {\n if (AbstractDensity2dStat$Companion_instance === null) {\n new AbstractDensity2dStat$Companion();\n }return AbstractDensity2dStat$Companion_instance;\n }\n AbstractDensity2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractDensity2dStat',\n interfaces: [BaseStat]\n };\n function BaseStat(defaultMappings) {\n this.defaultMappings_lvkmi1$_0 = defaultMappings;\n }\n BaseStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return this.defaultMappings_lvkmi1$_0.containsKey_11rb$(aes);\n };\n BaseStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n if (this.defaultMappings_lvkmi1$_0.containsKey_11rb$(aes)) {\n return ensureNotNull(this.defaultMappings_lvkmi1$_0.get_11rb$(aes));\n }throw IllegalArgumentException_init('Stat ' + Kotlin.getKClassFromExpression(this).simpleName + ' has no default mapping for aes: ' + toString(aes));\n };\n BaseStat.prototype.hasRequiredValues_xht41f$ = function (data, aes) {\n var tmp$;\n for (tmp$ = 0; tmp$ !== aes.length; ++tmp$) {\n var requiredAes = aes[tmp$];\n var variable = TransformVar_getInstance().forAes_896ixz$(requiredAes);\n if (data.hasNoOrEmpty_8xm3sj$(variable)) {\n return false;\n }}\n return true;\n };\n BaseStat.prototype.withEmptyStatValues = function () {\n var tmp$;\n var newData = DataFrame$DataFrame$Builder_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (this.hasDefaultMapping_896ixz$(aes)) {\n newData.put_2l962d$(this.getDefaultMapping_896ixz$(aes), emptyList());\n }}\n return newData.build();\n };\n BaseStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseStat',\n interfaces: [Stat]\n };\n function Bin2dStat(binCountX, binCountY, binWidthX, binWidthY, drop) {\n Bin2dStat$Companion_getInstance();\n if (binCountX === void 0)\n binCountX = 30;\n if (binCountY === void 0)\n binCountY = 30;\n if (binWidthX === void 0)\n binWidthX = Bin2dStat$Companion_getInstance().DEF_BINWIDTH;\n if (binWidthY === void 0)\n binWidthY = Bin2dStat$Companion_getInstance().DEF_BINWIDTH;\n if (drop === void 0)\n drop = Bin2dStat$Companion_getInstance().DEF_DROP;\n BaseStat.call(this, Bin2dStat$Companion_getInstance().DEF_MAPPING_0);\n this.drop_0 = drop;\n this.binOptionsX_0 = new BinStatUtil$BinOptions(binCountX, binWidthX);\n this.binOptionsY_0 = new BinStatUtil$BinOptions(binCountY, binWidthY);\n }\n Bin2dStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().WEIGHT]);\n };\n Bin2dStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n if (xRange == null || yRange == null) {\n return this.withEmptyStatValues();\n }var xRangeInit = Bin2dStat$Companion_getInstance().adjustRangeInitial_0(xRange);\n var yRangeInit = Bin2dStat$Companion_getInstance().adjustRangeInitial_0(yRange);\n var xCountAndWidthInit = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(xRangeInit), this.binOptionsX_0);\n var yCountAndWidthInit = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(yRangeInit), this.binOptionsY_0);\n var xRangeFinal = Bin2dStat$Companion_getInstance().adjustRangeFinal_0(xRange, xCountAndWidthInit.width);\n var yRangeFinal = Bin2dStat$Companion_getInstance().adjustRangeFinal_0(yRange, yCountAndWidthInit.width);\n var xCountAndWidthFinal = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(xRangeFinal), this.binOptionsX_0);\n var yCountAndWidthFinal = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(yRangeFinal), this.binOptionsY_0);\n var countTotal = Kotlin.imul(xCountAndWidthFinal.count, yCountAndWidthFinal.count);\n var densityNormalizingFactor = Bin2dStat$Companion_getInstance().densityNormalizingFactor_0(data.SeriesUtil.span_4fzjta$(xRangeFinal), data.SeriesUtil.span_4fzjta$(yRangeFinal), countTotal);\n var binsData = this.computeBins_0(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X), data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y), xRangeFinal.lowerEnd, yRangeFinal.lowerEnd, xCountAndWidthFinal.count, yCountAndWidthFinal.count, xCountAndWidthFinal.width, yCountAndWidthFinal.width, BinStatUtil_getInstance().weightAtIndex_dhhkv7$(data_0), densityNormalizingFactor);\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, binsData.x_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().Y, binsData.y_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().COUNT, binsData.count_8be2vx$).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, binsData.density_8be2vx$).build();\n };\n Bin2dStat.prototype.computeBins_0 = function (xValues, yValues, xStart, yStart, binCountX, binCountY, binWidth, binHeight, weightAtIndex, densityNormalizingFactor) {\n var totalCount = 0.0;\n var countByBinIndexKey = HashMap_init();\n for (var dataIndex = 0; dataIndex !== xValues.size; ++dataIndex) {\n var x = xValues.get_za3lpa$(dataIndex);\n var y = yValues.get_za3lpa$(dataIndex);\n if (!data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n continue;\n }var weight = weightAtIndex(dataIndex);\n totalCount += weight;\n var x_0 = (ensureNotNull(x) - xStart) / binWidth;\n var binIndexX = numberToInt(JsMath.floor(x_0));\n var x_1 = (ensureNotNull(y) - yStart) / binHeight;\n var binIndexY = numberToInt(JsMath.floor(x_1));\n var binIndexKey = new Pair_0(binIndexX, binIndexY);\n if (!countByBinIndexKey.containsKey_11rb$(binIndexKey)) {\n var value = new MutableDouble(0.0);\n countByBinIndexKey.put_xwzc9p$(binIndexKey, value);\n }ensureNotNull(countByBinIndexKey.get_11rb$(binIndexKey)).getAndAdd_14dthe$(weight);\n }\n var xs = ArrayList_init();\n var ys = ArrayList_init();\n var counts = ArrayList_init();\n var densities = ArrayList_init();\n var x0 = xStart + binWidth / 2;\n var y0 = yStart + binHeight / 2;\n for (var xIndex = 0; xIndex < binCountX; xIndex++) {\n for (var yIndex = 0; yIndex < binCountY; yIndex++) {\n var binIndexKey_0 = new Pair_0(xIndex, yIndex);\n var count = 0.0;\n if (countByBinIndexKey.containsKey_11rb$(binIndexKey_0)) {\n count = ensureNotNull(countByBinIndexKey.get_11rb$(binIndexKey_0)).get();\n }if (this.drop_0 && count === 0.0) {\n continue;\n }xs.add_11rb$(x0 + xIndex * binWidth);\n ys.add_11rb$(y0 + yIndex * binHeight);\n counts.add_11rb$(count);\n var density = count / totalCount * densityNormalizingFactor;\n densities.add_11rb$(density);\n }\n }\n return new Bin2dStat$Bins2dData(xs, ys, counts, densities);\n };\n function Bin2dStat$Companion() {\n Bin2dStat$Companion_instance = this;\n this.DEF_BINS = 30;\n this.DEF_BINWIDTH = null;\n this.DEF_DROP = true;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().FILL, Stats_getInstance().COUNT)]);\n }\n Bin2dStat$Companion.prototype.adjustRangeInitial_0 = function (r) {\n return data.SeriesUtil.ensureApplicableRange_4am1sd$(r);\n };\n Bin2dStat$Companion.prototype.adjustRangeFinal_0 = function (r, binWidth) {\n var tmp$;\n if (data.SeriesUtil.isSubTiny_4fzjta$(r)) {\n tmp$ = data.SeriesUtil.expand_wws5xy$(r, 0.5, 0.5);\n } else {\n var exp = binWidth / 2.0;\n tmp$ = data.SeriesUtil.expand_wws5xy$(r, exp, exp);\n }\n return tmp$;\n };\n Bin2dStat$Companion.prototype.densityNormalizingFactor_0 = function (xSpan, ySpan, count) {\n var area = xSpan * ySpan;\n var binArea = area / count;\n return 1.0 / binArea;\n };\n Bin2dStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Bin2dStat$Companion_instance = null;\n function Bin2dStat$Companion_getInstance() {\n if (Bin2dStat$Companion_instance === null) {\n new Bin2dStat$Companion();\n }return Bin2dStat$Companion_instance;\n }\n function Bin2dStat$Bins2dData(x, y, count, density) {\n this.x_8be2vx$ = x;\n this.y_8be2vx$ = y;\n this.count_8be2vx$ = count;\n this.density_8be2vx$ = density;\n }\n Bin2dStat$Bins2dData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bins2dData',\n interfaces: []\n };\n function Bin2dStat$Bins2dWeightedCounts(total, countByBinXY) {\n this.total_8be2vx$ = total;\n this.countByBinXY_8be2vx$ = countByBinXY;\n }\n Bin2dStat$Bins2dWeightedCounts.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bins2dWeightedCounts',\n interfaces: []\n };\n Bin2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Bin2dStat',\n interfaces: [BaseStat]\n };\n function BinStat(binCount, binWidth, xPosKind, xPos) {\n BinStat$Companion_getInstance();\n BaseStat.call(this, BinStat$Companion_getInstance().DEF_MAPPING_0);\n this.xPosKind_0 = xPosKind;\n this.xPos_0 = xPos;\n this.binOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n BinStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n BinStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var statX = ArrayList_init();\n var statCount = ArrayList_init();\n var statDensity = ArrayList_init();\n var rangeX = statCtx.overallXRange();\n if (rangeX != null) {\n var binsData = this.computeStatSeries_0(data, rangeX, data.getNumeric_8xm3sj$(TransformVar_getInstance().X));\n statX.addAll_brywnq$(binsData.x_8be2vx$);\n statCount.addAll_brywnq$(binsData.count_8be2vx$);\n statDensity.addAll_brywnq$(binsData.density_8be2vx$);\n }return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n };\n BinStat.prototype.computeStatSeries_0 = function (data_0, rangeX, valuesX) {\n var startX = rangeX.lowerEnd;\n var spanX = rangeX.upperEnd - ensureNotNull(startX);\n var b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(spanX, this.binOptions_0);\n startX -= b.width * 0.7;\n spanX += b.width * 1.4;\n b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(spanX, this.binOptions_0);\n var binCount = b.count;\n var binWidth = b.width;\n if (this.xPosKind_0 !== BinStat$XPosKind$NONE_getInstance()) {\n var minDelta = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n var x = this.xPos_0;\n for (var i = 0; i < binCount; i++) {\n var binLeft = startX + i * binWidth;\n var delta;\n if (this.xPosKind_0 === BinStat$XPosKind$CENTER_getInstance()) {\n delta = x - (binLeft + binWidth / 2);\n } else {\n if (i === 0) {\n minDelta = x - startX;\n }delta = x - (binLeft + binWidth);\n }\n var x_0 = delta;\n var tmp$ = JsMath.abs(x_0);\n var x_1 = minDelta;\n if (tmp$ < JsMath.abs(x_1)) {\n minDelta = delta;\n }}\n var offset = minDelta % (binWidth / 2);\n startX += offset;\n }var normalBinWidth = data.SeriesUtil.span_4fzjta$(rangeX) / binCount;\n var densityNormalizingFactor = normalBinWidth > 0 ? 1.0 / normalBinWidth : 1.0;\n var binsData = BinStatUtil_getInstance().computeBins_3oz8yg$(valuesX, startX, binCount, binWidth, BinStatUtil_getInstance().weightAtIndex_dhhkv7$(data_0), densityNormalizingFactor);\n if (!(binsData.x_8be2vx$.size === binCount)) {\n var message = 'Internal: stat data size=' + toString(binsData.x_8be2vx$.size) + ' expected bin count=' + toString(binCount);\n throw IllegalStateException_init(message.toString());\n }return binsData;\n };\n function BinStat$XPosKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function BinStat$XPosKind_initFields() {\n BinStat$XPosKind_initFields = function () {\n };\n BinStat$XPosKind$NONE_instance = new BinStat$XPosKind('NONE', 0);\n BinStat$XPosKind$CENTER_instance = new BinStat$XPosKind('CENTER', 1);\n BinStat$XPosKind$BOUNDARY_instance = new BinStat$XPosKind('BOUNDARY', 2);\n }\n var BinStat$XPosKind$NONE_instance;\n function BinStat$XPosKind$NONE_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$NONE_instance;\n }\n var BinStat$XPosKind$CENTER_instance;\n function BinStat$XPosKind$CENTER_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$CENTER_instance;\n }\n var BinStat$XPosKind$BOUNDARY_instance;\n function BinStat$XPosKind$BOUNDARY_getInstance() {\n BinStat$XPosKind_initFields();\n return BinStat$XPosKind$BOUNDARY_instance;\n }\n BinStat$XPosKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'XPosKind',\n interfaces: [Enum]\n };\n function BinStat$XPosKind$values() {\n return [BinStat$XPosKind$NONE_getInstance(), BinStat$XPosKind$CENTER_getInstance(), BinStat$XPosKind$BOUNDARY_getInstance()];\n }\n BinStat$XPosKind.values = BinStat$XPosKind$values;\n function BinStat$XPosKind$valueOf(name) {\n switch (name) {\n case 'NONE':\n return BinStat$XPosKind$NONE_getInstance();\n case 'CENTER':\n return BinStat$XPosKind$CENTER_getInstance();\n case 'BOUNDARY':\n return BinStat$XPosKind$BOUNDARY_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.BinStat.XPosKind.' + name);\n }\n }\n BinStat$XPosKind.valueOf_61zpoe$ = BinStat$XPosKind$valueOf;\n function BinStat$Companion() {\n BinStat$Companion_instance = this;\n this.DEF_BIN_COUNT = 30;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().COUNT)]);\n }\n BinStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BinStat$Companion_instance = null;\n function BinStat$Companion_getInstance() {\n if (BinStat$Companion_instance === null) {\n new BinStat$Companion();\n }return BinStat$Companion_instance;\n }\n BinStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinStat',\n interfaces: [BaseStat]\n };\n function BinStatUtil() {\n BinStatUtil_instance = this;\n this.MAX_BIN_COUNT_0 = 500;\n }\n function BinStatUtil$weightAtIndex$lambda(closure$weights) {\n return function (index) {\n var weight = closure$weights.get_za3lpa$(index);\n return data.SeriesUtil.asFinite_z03gcz$(weight, 0.0);\n };\n }\n function BinStatUtil$weightAtIndex$lambda_0(it) {\n return 1.0;\n }\n BinStatUtil.prototype.weightAtIndex_dhhkv7$ = function (data) {\n if (data.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n var weights = data.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT);\n return BinStatUtil$weightAtIndex$lambda(weights);\n }return BinStatUtil$weightAtIndex$lambda_0;\n };\n BinStatUtil.prototype.weightVector_5m8trb$ = function (dataLength, data) {\n var tmp$;\n if (data.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n tmp$ = data.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT);\n } else {\n var list = ArrayList_init_1(dataLength);\n for (var index = 0; index < dataLength; index++) {\n list.add_11rb$(1.0);\n }\n tmp$ = list;\n }\n return tmp$;\n };\n BinStatUtil.prototype.binCountAndWidth_11nzti$ = function (dataRange, binOptions) {\n var binCount = binOptions.binCount;\n var binWidth;\n if (binOptions.hasBinWidth()) {\n binWidth = ensureNotNull(binOptions.binWidth);\n var count = dataRange / binWidth;\n var b = count;\n count = JsMath.min(500, b);\n var x = count;\n binCount = numberToInt(JsMath.ceil(x));\n } else {\n binWidth = dataRange / binCount;\n }\n return new BinStatUtil$CountAndWidth(binCount, binWidth);\n };\n BinStatUtil.prototype.computeBins_3oz8yg$ = function (valuesX, startX, binCount, binWidth, weightAtIndex, densityNormalizingFactor) {\n var totalCount = 0.0;\n var countByBinIndex = HashMap_init();\n for (var dataIndex = 0; dataIndex !== valuesX.size; ++dataIndex) {\n var x = valuesX.get_za3lpa$(dataIndex);\n if (!data.SeriesUtil.isFinite_yrwdxb$(x)) {\n continue;\n }var weight = weightAtIndex(dataIndex);\n totalCount += weight;\n var x_0 = (ensureNotNull(x) - startX) / binWidth;\n var binIndex = numberToInt(JsMath.floor(x_0));\n if (!countByBinIndex.containsKey_11rb$(binIndex)) {\n var value = new MutableDouble(0.0);\n countByBinIndex.put_xwzc9p$(binIndex, value);\n }ensureNotNull(countByBinIndex.get_11rb$(binIndex)).getAndAdd_14dthe$(weight);\n }\n var x_1 = ArrayList_init();\n var counts = ArrayList_init();\n var densities = ArrayList_init();\n var x0 = startX + binWidth / 2;\n for (var i = 0; i < binCount; i++) {\n x_1.add_11rb$(x0 + i * binWidth);\n var count = 0.0;\n if (countByBinIndex.containsKey_11rb$(i)) {\n count = ensureNotNull(countByBinIndex.get_11rb$(i)).get();\n }counts.add_11rb$(count);\n var density = count / totalCount * densityNormalizingFactor;\n densities.add_11rb$(density);\n }\n return new BinStatUtil$BinsData(x_1, counts, densities);\n };\n function BinStatUtil$BinOptions(binCount, binWidth) {\n this.binWidth = binWidth;\n var b = JsMath.max(1, binCount);\n this.binCount = JsMath.min(500, b);\n }\n BinStatUtil$BinOptions.prototype.hasBinWidth = function () {\n return this.binWidth != null && this.binWidth > 0;\n };\n BinStatUtil$BinOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinOptions',\n interfaces: []\n };\n function BinStatUtil$CountAndWidth(count, width) {\n this.count = count;\n this.width = width;\n }\n BinStatUtil$CountAndWidth.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CountAndWidth',\n interfaces: []\n };\n function BinStatUtil$BinsData(x, count, density) {\n this.x_8be2vx$ = x;\n this.count_8be2vx$ = count;\n this.density_8be2vx$ = density;\n }\n BinStatUtil$BinsData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BinsData',\n interfaces: []\n };\n BinStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BinStatUtil',\n interfaces: []\n };\n var BinStatUtil_instance = null;\n function BinStatUtil_getInstance() {\n if (BinStatUtil_instance === null) {\n new BinStatUtil();\n }return BinStatUtil_instance;\n }\n function BoxplotStat(whiskerIQRRatio, computeWidth) {\n BoxplotStat$Companion_getInstance();\n BaseStat.call(this, BoxplotStat$Companion_getInstance().DEF_MAPPING_0);\n this.whiskerIQRRatio_0 = whiskerIQRRatio;\n this.computeWidth_0 = computeWidth;\n }\n BoxplotStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return BaseStat.prototype.hasDefaultMapping_896ixz$.call(this, aes) || (equals(aes, Aes$Companion_getInstance().WIDTH) && this.computeWidth_0);\n };\n BoxplotStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n var tmp$;\n if (equals(aes, Aes$Companion_getInstance().WIDTH)) {\n tmp$ = Stats_getInstance().WIDTH;\n } else {\n tmp$ = BaseStat.prototype.getDefaultMapping_896ixz$.call(this, aes);\n }\n return tmp$;\n };\n BoxplotStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y]);\n };\n BoxplotStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var ys = data.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (data.has_8xm3sj$(TransformVar_getInstance().X)) {\n tmp$ = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n } else {\n var size = ys.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(0.0);\n }\n tmp$ = list;\n }\n var xs = tmp$;\n var statData = BoxplotStat$Companion_getInstance().buildStat_7jxs1q$(xs, ys, this.whiskerIQRRatio_0);\n var statCount = statData.remove_11rb$(Stats_getInstance().COUNT);\n var maxCountPerBin = (tmp$_1 = (tmp$_0 = statCount != null ? maxOrNull(statCount) : null) != null ? numberToInt(tmp$_0) : null) != null ? tmp$_1 : 0;\n if (maxCountPerBin === 0) {\n return this.withEmptyStatValues();\n }if (this.computeWidth_0) {\n var norm = JsMath.sqrt(maxCountPerBin);\n var $receiver = ensureNotNull(statCount);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_3;\n tmp$_3 = $receiver.iterator();\n while (tmp$_3.hasNext()) {\n var item = tmp$_3.next();\n destination.add_11rb$(JsMath.sqrt(item) / norm);\n }\n var statWidth = destination;\n var key = Stats_getInstance().WIDTH;\n statData.put_xwzc9p$(key, statWidth);\n }var builder = DataFrame$DataFrame$Builder_init();\n tmp$_2 = statData.entries.iterator();\n while (tmp$_2.hasNext()) {\n var tmp$_4 = tmp$_2.next();\n var variable = tmp$_4.key;\n var series = tmp$_4.value;\n builder.putNumeric_s1rqo9$(variable, series);\n }\n return builder.build();\n };\n function BoxplotStat$Companion() {\n BoxplotStat$Companion_instance = this;\n this.DEF_WHISKER_IQR_RATIO = 1.5;\n this.DEF_COMPUTE_WIDTH = false;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().YMIN, Stats_getInstance().Y_MIN), to(Aes$Companion_getInstance().YMAX, Stats_getInstance().Y_MAX), to(Aes$Companion_getInstance().LOWER, Stats_getInstance().LOWER), to(Aes$Companion_getInstance().MIDDLE, Stats_getInstance().MIDDLE), to(Aes$Companion_getInstance().UPPER, Stats_getInstance().UPPER)]);\n }\n BoxplotStat$Companion.prototype.buildStat_7jxs1q$ = function (xs, ys, whiskerIQRRatio) {\n var tmp$, tmp$_0, tmp$_1;\n var $receiver = zip(xs, ys);\n var destination = ArrayList_init();\n var tmp$_2;\n tmp$_2 = $receiver.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n var x = element.component1()\n , y = element.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y))\n destination.add_11rb$(element);\n }\n var xyPairs = destination;\n if (xyPairs.isEmpty()) {\n return LinkedHashMap_init();\n }var binnedData = HashMap_init();\n tmp$ = xyPairs.iterator();\n while (tmp$.hasNext()) {\n var tmp$_3 = tmp$.next();\n var x_0 = tmp$_3.component1()\n , y_0 = tmp$_3.component2();\n var key = ensureNotNull(x_0);\n var tmp$_4;\n var value = binnedData.get_11rb$(key);\n if (value == null) {\n var answer = ArrayList_init();\n binnedData.put_xwzc9p$(key, answer);\n tmp$_4 = answer;\n } else {\n tmp$_4 = value;\n }\n tmp$_4.add_11rb$(ensureNotNull(y_0));\n }\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statMiddle = ArrayList_init();\n var statLower = ArrayList_init();\n var statUpper = ArrayList_init();\n var statMin = ArrayList_init();\n var statMax = ArrayList_init();\n var statCount = ArrayList_init();\n tmp$_0 = binnedData.entries.iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_5 = tmp$_0.next();\n var x_1 = tmp$_5.key;\n var bin = tmp$_5.value;\n var count = bin.size;\n var summary = FiveNumberSummary_init(bin);\n var middle = summary.median;\n var lowerHinge = summary.firstQuartile;\n var upperHinge = summary.thirdQuartile;\n var IQR = upperHinge - lowerHinge;\n var lowerFence = lowerHinge - IQR * whiskerIQRRatio;\n var upperFence = upperHinge + IQR * whiskerIQRRatio;\n var lowerWhisker = lowerFence;\n var upperWhisker = upperFence;\n if (data.SeriesUtil.allFinite_jma9l8$(lowerFence, upperFence)) {\n var destination_0 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = bin.iterator();\n while (tmp$_6.hasNext()) {\n var element_0 = tmp$_6.next();\n if (element_0 >= lowerFence && element_0 <= upperFence)\n destination_0.add_11rb$(element_0);\n }\n var boxed = destination_0;\n var range = data.SeriesUtil.range_l63ks6$(boxed);\n if (range != null) {\n lowerWhisker = range.lowerEnd;\n upperWhisker = range.upperEnd;\n }}var destination_1 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = bin.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (element_1 < lowerFence || element_1 > upperFence)\n destination_1.add_11rb$(element_1);\n }\n var outliers = destination_1;\n tmp$_1 = outliers.iterator();\n while (tmp$_1.hasNext()) {\n var y_1 = tmp$_1.next();\n statX.add_11rb$(x_1);\n statY.add_11rb$(y_1);\n statMiddle.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statLower.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statUpper.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMin.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMax.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statCount.add_11rb$(count);\n }\n statX.add_11rb$(x_1);\n statY.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n statMiddle.add_11rb$(middle);\n statLower.add_11rb$(lowerHinge);\n statUpper.add_11rb$(upperHinge);\n statMin.add_11rb$(lowerWhisker);\n statMax.add_11rb$(upperWhisker);\n statCount.add_11rb$(count);\n }\n return mutableMapOf([to(Stats_getInstance().X, statX), to(Stats_getInstance().Y, statY), to(Stats_getInstance().MIDDLE, statMiddle), to(Stats_getInstance().LOWER, statLower), to(Stats_getInstance().UPPER, statUpper), to(Stats_getInstance().Y_MIN, statMin), to(Stats_getInstance().Y_MAX, statMax), to(Stats_getInstance().COUNT, statCount)]);\n };\n BoxplotStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BoxplotStat$Companion_instance = null;\n function BoxplotStat$Companion_getInstance() {\n if (BoxplotStat$Companion_instance === null) {\n new BoxplotStat$Companion();\n }return BoxplotStat$Companion_instance;\n }\n BoxplotStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxplotStat',\n interfaces: [BaseStat]\n };\n function Contour() {\n Contour$Companion_getInstance();\n this.myContourX_0 = ArrayList_init();\n this.myContourY_0 = ArrayList_init();\n this.myContourLevel_0 = ArrayList_init();\n this.myContourGroup_0 = ArrayList_init();\n this.myGroup_0 = 0.0;\n }\n Object.defineProperty(Contour.prototype, 'dataFrame_0', {\n configurable: true,\n get: function () {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, this.myContourX_0).putNumeric_s1rqo9$(Stats_getInstance().Y, this.myContourY_0).putNumeric_s1rqo9$(Stats_getInstance().LEVEL, this.myContourLevel_0).putNumeric_s1rqo9$(Stats_getInstance().GROUP, this.myContourGroup_0).build();\n }\n });\n Contour.prototype.add_e7h60q$ = function (polygon, fillLevel) {\n var tmp$;\n tmp$ = polygon.iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n this.myContourX_0.add_11rb$(p.x);\n this.myContourY_0.add_11rb$(p.y);\n this.myContourLevel_0.add_11rb$(fillLevel);\n this.myContourGroup_0.add_11rb$(this.myGroup_0);\n }\n this.myGroup_0 += 1.0;\n };\n function Contour$Companion() {\n Contour$Companion_instance = this;\n }\n Contour$Companion.prototype.getPathDataFrame_9s3d7f$ = function (levels, pathListByLevel) {\n var tmp$, tmp$_0;\n var contour = new Contour();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var paths = ensureNotNull(pathListByLevel.get_11rb$(level));\n tmp$_0 = paths.iterator();\n while (tmp$_0.hasNext()) {\n var path = tmp$_0.next();\n contour.add_e7h60q$(path, level);\n }\n }\n return contour.dataFrame_0;\n };\n Contour$Companion.prototype.getPolygonDataFrame_dnsuee$ = function (fillLevels, polygonListByFillLevel) {\n var tmp$;\n var contour = new Contour();\n tmp$ = fillLevels.iterator();\n while (tmp$.hasNext()) {\n var fillLevel = tmp$.next();\n var polygon = ensureNotNull(polygonListByFillLevel.get_11rb$(fillLevel));\n contour.add_e7h60q$(polygon, fillLevel);\n }\n return contour.dataFrame_0;\n };\n Contour$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Contour$Companion_instance = null;\n function Contour$Companion_getInstance() {\n if (Contour$Companion_instance === null) {\n new Contour$Companion();\n }return Contour$Companion_instance;\n }\n Contour.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Contour',\n interfaces: []\n };\n function ContourFillHelper(xRange, yRange) {\n ContourFillHelper$Companion_getInstance();\n this.myLowLeft_0 = null;\n this.myLowRight_0 = null;\n this.myUpLeft_0 = null;\n this.myUpRight_0 = null;\n var xMin = xRange.lowerEnd;\n var xMax = xRange.upperEnd;\n var yMin = yRange.lowerEnd;\n var yMax = yRange.upperEnd;\n this.myLowLeft_0 = new DoubleVector(xMin, yMin);\n this.myLowRight_0 = new DoubleVector(xMax, yMin);\n this.myUpLeft_0 = new DoubleVector(xMin, yMax);\n this.myUpRight_0 = new DoubleVector(xMax, yMax);\n }\n ContourFillHelper.prototype.createPolygons_lrt0be$ = function (pathByLevels, levels, fillLevels) {\n var tmp$, tmp$_0, tmp$_1;\n var result = HashMap_init();\n var allPaths = ArrayList_init();\n tmp$ = pathByLevels.values.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n allPaths.addAll_brywnq$(level);\n }\n var cornerPoints = ArrayList_init();\n var outerMap = this.createOuterMap_0(allPaths, cornerPoints);\n var n = pathByLevels.keys.size;\n tmp$_0 = n + 1 | 0;\n for (var i = 0; i < tmp$_0; i++) {\n var polygonPieces = ArrayList_init();\n var value = ArrayList_init();\n if (i > 0) {\n polygonPieces.addAll_brywnq$(ContourFillHelper$Companion_getInstance().reverseAll_0(ensureNotNull(pathByLevels.get_11rb$(levels.get_za3lpa$(i - 1 | 0)))));\n }if (i < n) {\n polygonPieces.addAll_brywnq$(ensureNotNull(pathByLevels.get_11rb$(levels.get_za3lpa$(i))));\n }polygonPieces = this.createClosedPolygonLevels_0(polygonPieces, outerMap, cornerPoints);\n tmp$_1 = polygonPieces.iterator();\n while (tmp$_1.hasNext()) {\n var path = tmp$_1.next();\n value.addAll_brywnq$(path);\n }\n var key = fillLevels.get_za3lpa$(i);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n ContourFillHelper.prototype.createClosedPolygonLevels_0 = function (openLevels, outerMap, cornerPoints) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = ArrayList_init();\n var donePath = HashSet_init_1();\n tmp$ = openLevels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var levelCopy = ArrayList_init_0(level);\n var p0 = levelCopy.get_za3lpa$(0);\n var p1 = levelCopy.get_za3lpa$(levelCopy.size - 1 | 0);\n if (p0 != null ? p0.equals(p1) : null) {\n result.add_11rb$(levelCopy);\n continue;\n }var pi2 = ensureNotNull(outerMap.get_11rb$(p1));\n levelCopy.add_11rb$(pi2);\n p1 = pi2;\n while (cornerPoints.contains_11rb$(p1)) {\n pi2 = ensureNotNull(outerMap.get_11rb$(p1));\n levelCopy.add_11rb$(pi2);\n p1 = pi2;\n }\n donePath.add_11rb$(levelCopy);\n }\n var pathByEndPoint = HashMap_init();\n tmp$_0 = donePath.iterator();\n while (tmp$_0.hasNext()) {\n var path = tmp$_0.next();\n var p0_0 = path.get_za3lpa$(0);\n var p1_0 = path.get_za3lpa$(path.size - 1 | 0);\n if (p0_0 != null ? p0_0.equals(p1_0) : null) {\n result.add_11rb$(path);\n continue;\n }if (pathByEndPoint.containsKey_11rb$(p0_0) || pathByEndPoint.containsKey_11rb$(p1_0)) {\n var path0 = pathByEndPoint.get_11rb$(p0_0);\n var path1 = pathByEndPoint.get_11rb$(p1_0);\n ContourStatUtil_getInstance().removePathByEndpoints_ebaanh$(path0, pathByEndPoint);\n ContourStatUtil_getInstance().removePathByEndpoints_ebaanh$(path1, pathByEndPoint);\n var longPath;\n if (path0 === path1) {\n ensureNotNull(path0).addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n result.add_11rb$(path0);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath = path0;\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size - 1 | 0));\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath = ensureNotNull(path1);\n longPath.addAll_u57x28$(0, path.subList_vux9f0$(0, path.size - 1 | 0));\n } else {\n longPath = path0;\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n }\n var key = longPath.get_za3lpa$(0);\n var value = longPath;\n pathByEndPoint.put_xwzc9p$(key, value);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n var value_0 = longPath;\n pathByEndPoint.put_xwzc9p$(key_0, value_0);\n } else {\n var key_1 = path.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = path.get_za3lpa$(path.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n if (!pathByEndPoint.keys.isEmpty()) {\n throw IllegalArgumentException_init('Some paths are not cleared yet there is something wrong!' + toString(pathByEndPoint.keys.size));\n }tmp$_1 = result.iterator();\n while (tmp$_1.hasNext()) {\n var path_0 = tmp$_1.next();\n if (!((tmp$_2 = path_0.get_za3lpa$(0)) != null ? tmp$_2.equals(path_0.get_za3lpa$(path_0.size - 1 | 0)) : null)) {\n throw IllegalArgumentException_init('The polygons are not entirely closed!');\n }}\n return result;\n };\n function ContourFillHelper$createOuterMap$lambda(o1, o2) {\n return Kotlin.compareTo(o1.x, o2.x);\n }\n function ContourFillHelper$createOuterMap$lambda_0(o1, o2) {\n return Kotlin.compareTo(o1.y, o2.y);\n }\n function ContourFillHelper$createOuterMap$lambda_1(o1, o2) {\n return Kotlin.compareTo(o2.x, o1.x);\n }\n function ContourFillHelper$createOuterMap$lambda_2(o1, o2) {\n return Kotlin.compareTo(o2.y, o1.y);\n }\n ContourFillHelper.prototype.createOuterMap_0 = function (paths, cornerPoints) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var points = ArrayList_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n if (!((tmp$_0 = path.get_za3lpa$(0)) != null ? tmp$_0.equals(path.get_za3lpa$(path.size - 1 | 0)) : null)) {\n points.add_11rb$(path.get_za3lpa$(0));\n points.add_11rb$(path.get_za3lpa$(path.size - 1 | 0));\n }}\n var result = HashMap_init();\n var list = ArrayList_init();\n for (var i = 0; i <= 3; i++) {\n list.add_11rb$(ArrayList_init());\n }\n tmp$_1 = points.iterator();\n while (tmp$_1.hasNext()) {\n var point = tmp$_1.next();\n var kind = this.getKind_0(point);\n switch (kind.name) {\n case 'DOWN':\n list.get_za3lpa$(0).add_11rb$(point);\n break;\n case 'RIGHT':\n list.get_za3lpa$(1).add_11rb$(point);\n break;\n case 'UP':\n list.get_za3lpa$(2).add_11rb$(point);\n break;\n case 'LEFT':\n list.get_za3lpa$(3).add_11rb$(point);\n break;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n }\n sortWith(list.get_za3lpa$(0), new Comparator(ContourFillHelper$createOuterMap$lambda));\n sortWith(list.get_za3lpa$(1), new Comparator(ContourFillHelper$createOuterMap$lambda_0));\n sortWith(list.get_za3lpa$(2), new Comparator(ContourFillHelper$createOuterMap$lambda_1));\n sortWith(list.get_za3lpa$(3), new Comparator(ContourFillHelper$createOuterMap$lambda_2));\n var prepareMap = ArrayList_init();\n if (!list.get_za3lpa$(0).contains_11rb$(this.myLowLeft_0)) {\n prepareMap.add_11rb$(this.myLowLeft_0);\n cornerPoints.add_11rb$(this.myLowLeft_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(0));\n if (!list.get_za3lpa$(0).contains_11rb$(this.myLowRight_0)) {\n prepareMap.add_11rb$(this.myLowRight_0);\n cornerPoints.add_11rb$(this.myLowRight_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(1));\n if (!list.get_za3lpa$(1).contains_11rb$(this.myUpRight_0)) {\n prepareMap.add_11rb$(this.myUpRight_0);\n cornerPoints.add_11rb$(this.myUpRight_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(2));\n if (!list.get_za3lpa$(3).contains_11rb$(this.myUpLeft_0)) {\n prepareMap.add_11rb$(this.myUpLeft_0);\n cornerPoints.add_11rb$(this.myUpLeft_0);\n }prepareMap.addAll_brywnq$(list.get_za3lpa$(3));\n prepareMap.add_11rb$(prepareMap.get_za3lpa$(0));\n tmp$_2 = prepareMap.size - 1 | 0;\n for (var i_0 = 0; i_0 < tmp$_2; i_0++) {\n var key = prepareMap.get_za3lpa$(i_0);\n var value = prepareMap.get_za3lpa$(i_0 + 1 | 0);\n result.put_xwzc9p$(key, value);\n }\n return result;\n };\n ContourFillHelper.prototype.getKind_0 = function (point) {\n var tmp$;\n if (ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$DOWN_getInstance();\n } else if (ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && !ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$RIGHT_getInstance();\n } else if (!ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && !ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$UP_getInstance();\n } else if (!ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myLowLeft_0, this.myUpRight_0, point) && ContourFillHelper$Companion_getInstance().belowOrOnLine_0(this.myUpLeft_0, this.myLowRight_0, point)) {\n tmp$ = ContourFillHelper$BorderKind$LEFT_getInstance();\n } else {\n throw IllegalArgumentException_init('The Contour Point is not on the border ' + point);\n }\n return tmp$;\n };\n function ContourFillHelper$BorderKind(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ContourFillHelper$BorderKind_initFields() {\n ContourFillHelper$BorderKind_initFields = function () {\n };\n ContourFillHelper$BorderKind$DOWN_instance = new ContourFillHelper$BorderKind('DOWN', 0);\n ContourFillHelper$BorderKind$RIGHT_instance = new ContourFillHelper$BorderKind('RIGHT', 1);\n ContourFillHelper$BorderKind$UP_instance = new ContourFillHelper$BorderKind('UP', 2);\n ContourFillHelper$BorderKind$LEFT_instance = new ContourFillHelper$BorderKind('LEFT', 3);\n }\n var ContourFillHelper$BorderKind$DOWN_instance;\n function ContourFillHelper$BorderKind$DOWN_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$DOWN_instance;\n }\n var ContourFillHelper$BorderKind$RIGHT_instance;\n function ContourFillHelper$BorderKind$RIGHT_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$RIGHT_instance;\n }\n var ContourFillHelper$BorderKind$UP_instance;\n function ContourFillHelper$BorderKind$UP_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$UP_instance;\n }\n var ContourFillHelper$BorderKind$LEFT_instance;\n function ContourFillHelper$BorderKind$LEFT_getInstance() {\n ContourFillHelper$BorderKind_initFields();\n return ContourFillHelper$BorderKind$LEFT_instance;\n }\n ContourFillHelper$BorderKind.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BorderKind',\n interfaces: [Enum]\n };\n function ContourFillHelper$BorderKind$values() {\n return [ContourFillHelper$BorderKind$DOWN_getInstance(), ContourFillHelper$BorderKind$RIGHT_getInstance(), ContourFillHelper$BorderKind$UP_getInstance(), ContourFillHelper$BorderKind$LEFT_getInstance()];\n }\n ContourFillHelper$BorderKind.values = ContourFillHelper$BorderKind$values;\n function ContourFillHelper$BorderKind$valueOf(name) {\n switch (name) {\n case 'DOWN':\n return ContourFillHelper$BorderKind$DOWN_getInstance();\n case 'RIGHT':\n return ContourFillHelper$BorderKind$RIGHT_getInstance();\n case 'UP':\n return ContourFillHelper$BorderKind$UP_getInstance();\n case 'LEFT':\n return ContourFillHelper$BorderKind$LEFT_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.ContourFillHelper.BorderKind.' + name);\n }\n }\n ContourFillHelper$BorderKind.valueOf_61zpoe$ = ContourFillHelper$BorderKind$valueOf;\n function ContourFillHelper$Companion() {\n ContourFillHelper$Companion_instance = this;\n }\n ContourFillHelper$Companion.prototype.computeFillLevels_4v6zbb$ = function (zRange, levels) {\n var tmp$;\n var fillLevels = ArrayList_init();\n fillLevels.add_11rb$(zRange.lowerEnd);\n tmp$ = levels.size - 1 | 0;\n for (var i = 0; i < tmp$; i++) {\n fillLevels.add_11rb$((levels.get_za3lpa$(i) + levels.get_za3lpa$(i + 1 | 0)) / 2.0);\n }\n fillLevels.add_11rb$(zRange.upperEnd);\n return fillLevels;\n };\n ContourFillHelper$Companion.prototype.reverseAll_0 = function (list) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var copy = ArrayList_init_0(item);\n reverse(copy);\n result.add_11rb$(copy);\n }\n return result;\n };\n ContourFillHelper$Companion.prototype.belowOrOnLine_0 = function (a, b, test) {\n var value = test.subtract_gpjtzr$(a);\n var standard = b.subtract_gpjtzr$(a);\n return standard.y * value.x - value.y * standard.x >= 0;\n };\n ContourFillHelper$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourFillHelper$Companion_instance = null;\n function ContourFillHelper$Companion_getInstance() {\n if (ContourFillHelper$Companion_instance === null) {\n new ContourFillHelper$Companion();\n }return ContourFillHelper$Companion_instance;\n }\n ContourFillHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourFillHelper',\n interfaces: []\n };\n function ContourStat(binCount, binWidth) {\n ContourStat$Companion_getInstance();\n BaseStat.call(this, ContourStat$Companion_getInstance().DEF_MAPPING_0);\n this.myBinOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n ContourStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z]);\n };\n ContourStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z])) {\n return this.withEmptyStatValues();\n }tmp$ = ContourStatUtil_getInstance().computeLevels_wuiwgl$(data, this.myBinOptions_0);\n if (tmp$ == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_jco5dt$(data, levels);\n return Contour$Companion_getInstance().getPathDataFrame_9s3d7f$(levels, pathListByLevel);\n };\n function ContourStat$Companion() {\n ContourStat$Companion_instance = this;\n this.DEF_BIN_COUNT = 10;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n }\n ContourStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourStat$Companion_instance = null;\n function ContourStat$Companion_getInstance() {\n if (ContourStat$Companion_instance === null) {\n new ContourStat$Companion();\n }return ContourStat$Companion_instance;\n }\n ContourStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourStat',\n interfaces: [BaseStat]\n };\n function ContourStatUtil() {\n ContourStatUtil_instance = this;\n this.xLoc_0 = new Float64Array([0.0, 1.0, 1.0, 0.0, 0.5]);\n this.yLoc_0 = new Float64Array([0.0, 0.0, 1.0, 1.0, 0.5]);\n }\n ContourStatUtil.prototype.estimateRegularGridShape_fsp013$ = function (xs) {\n var tmp$;\n var colCount = 0;\n var x0 = null;\n tmp$ = xs.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n if (x0 == null) {\n x0 = x;\n } else if (x == x0) {\n break;\n }colCount = colCount + 1 | 0;\n }\n if (colCount <= 1) {\n throw IllegalArgumentException_init('Data grid must be at least 2 columns wide (was ' + colCount + ')');\n }var rowCount = xs.size / colCount | 0;\n if (rowCount <= 1) {\n throw IllegalArgumentException_init('Data grid must be at least 2 rows tall (was ' + rowCount + ')');\n }return new Pair(colCount, rowCount);\n };\n ContourStatUtil.prototype.computeLevels_wuiwgl$ = function (data, binOptions) {\n if (!(data.has_8xm3sj$(TransformVar_getInstance().X) && data.has_8xm3sj$(TransformVar_getInstance().Y) && data.has_8xm3sj$(TransformVar_getInstance().Z))) {\n return null;\n }var zRange = data.range_8xm3sj$(TransformVar_getInstance().Z);\n return this.computeLevels_kgz263$(zRange, binOptions);\n };\n ContourStatUtil.prototype.computeLevels_kgz263$ = function (zRange, binOptions) {\n var tmp$;\n if (zRange == null || data.SeriesUtil.isSubTiny_4fzjta$(zRange))\n return null;\n var b = BinStatUtil_getInstance().binCountAndWidth_11nzti$(data.SeriesUtil.span_4fzjta$(zRange), binOptions);\n var levels = ArrayList_init();\n tmp$ = b.count;\n for (var i = 0; i < tmp$; i++) {\n var level = i * b.width + zRange.lowerEnd;\n level += b.width / 2;\n levels.add_11rb$(level);\n }\n return levels;\n };\n ContourStatUtil.prototype.computeContours_jco5dt$ = function (data, levels) {\n var xVector = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var zVector = data.getNumeric_8xm3sj$(TransformVar_getInstance().Z);\n var shape = this.estimateRegularGridShape_fsp013$(xVector);\n var colCount = shape.first;\n var rowCount = shape.second;\n var xRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().X));\n var yRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Y));\n return this.computeContours_cxleoh$(xRange, yRange, colCount, rowCount, zVector, levels);\n };\n ContourStatUtil.prototype.computeContours_cxleoh$ = function (xRange, yRange, colCount, rowCount, data_0, levels) {\n var tmp$;\n var xStep = data.SeriesUtil.span_4fzjta$(xRange) / (colCount - 1 | 0);\n var yStep = data.SeriesUtil.span_4fzjta$(yRange) / (rowCount - 1 | 0);\n var origin = new DoubleVector(xRange.lowerEnd, yRange.lowerEnd);\n var pathListByLevel = HashMap_init();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n var levelSegments = this.computeSegments_0(colCount, rowCount, data_0, level);\n var paths = this.joinSegments_0(levelSegments);\n var pathsReal = this.convertPaths_0(paths, xStep, yStep, origin, level);\n pathsReal = this.confirmPaths_0(pathsReal);\n var value = pathsReal;\n pathListByLevel.put_xwzc9p$(level, value);\n }\n return pathListByLevel;\n };\n ContourStatUtil.prototype.joinSegments_0 = function (segments) {\n var tmp$, tmp$_0;\n var pathList = ArrayList_init();\n var pathByEndPoint = HashMap_init();\n tmp$ = segments.iterator();\n while (tmp$.hasNext()) {\n var segment = tmp$.next();\n var p0 = segment.first;\n var p1 = segment.second;\n if (pathByEndPoint.containsKey_11rb$(p0) || pathByEndPoint.containsKey_11rb$(p1)) {\n var path0 = pathByEndPoint.get_11rb$(p0);\n var path1 = pathByEndPoint.get_11rb$(p1);\n if (path0 != null) {\n pathByEndPoint.remove_11rb$(path0.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path0.get_za3lpa$(path0.size - 1 | 0));\n }if (path1 != null) {\n pathByEndPoint.remove_11rb$(path1.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path1.get_za3lpa$(path1.size - 1 | 0));\n }var longPath;\n if (path0 === path1) {\n ensureNotNull(path0).add_11rb$(segment.second);\n pathList.add_11rb$(path0);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath = path0;\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath = ensureNotNull(path1);\n longPath.add_wxm5ur$(0, segment.first);\n } else {\n longPath = path0;\n longPath.add_11rb$(segment.second);\n }\n var key = longPath.get_za3lpa$(0);\n var value = longPath;\n pathByEndPoint.put_xwzc9p$(key, value);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n var value_0 = longPath;\n pathByEndPoint.put_xwzc9p$(key_0, value_0);\n } else {\n var path = ArrayList_init();\n path.add_11rb$(segment.first);\n path.add_11rb$(segment.second);\n var key_1 = segment.first;\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = segment.second;\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n var pathSet = HashSet_init(pathByEndPoint.values);\n tmp$_0 = pathSet.iterator();\n while (tmp$_0.hasNext()) {\n var path_0 = tmp$_0.next();\n pathList.add_11rb$(path_0);\n }\n return pathList;\n };\n ContourStatUtil.prototype.convertPaths_0 = function (paths, xStep, yStep, origin, level) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var result = ArrayList_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n var temp = ArrayList_init();\n var lastPoint = null;\n tmp$_0 = path.iterator();\n while (tmp$_0.hasNext()) {\n var edge = tmp$_0.next();\n var intersect = edge.intersect_14dthe$(ensureNotNull(level));\n intersect = (new DoubleVector(xStep * intersect.x, yStep * intersect.y)).add_gpjtzr$(origin);\n if (equals(intersect, lastPoint)) {\n continue;\n }temp.add_11rb$(intersect);\n lastPoint = intersect;\n }\n if (((tmp$_1 = path.get_za3lpa$(0)) != null ? tmp$_1.equals(path.get_za3lpa$(path.size - 1 | 0)) : null) && !((tmp$_2 = temp.get_za3lpa$(0)) != null ? tmp$_2.equals(temp.get_za3lpa$(temp.size - 1 | 0)) : null)) {\n temp.set_wxm5ur$(temp.size - 1 | 0, temp.get_za3lpa$(0));\n }if (temp.size > 1) {\n result.add_11rb$(temp);\n }}\n return result;\n };\n ContourStatUtil.prototype.confirmPaths_0 = function (paths) {\n var tmp$, tmp$_0, tmp$_1;\n var newPaths = ArrayList_init();\n var pathByEndPoint = HashMap_init();\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n var p0 = path.get_za3lpa$(0);\n var p1 = path.get_za3lpa$(path.size - 1 | 0);\n if (p0 != null ? p0.equals(p1) : null) {\n newPaths.add_11rb$(path);\n continue;\n }if (pathByEndPoint.containsKey_11rb$(p0) || pathByEndPoint.containsKey_11rb$(p1)) {\n var path0 = pathByEndPoint.get_11rb$(p0);\n var path1 = pathByEndPoint.get_11rb$(p1);\n this.removePathByEndpoints_ebaanh$(path0, pathByEndPoint);\n this.removePathByEndpoints_ebaanh$(path1, pathByEndPoint);\n var longPath = ArrayList_init();\n if (path0 === path1) {\n longPath.addAll_brywnq$(ensureNotNull(path0));\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n newPaths.add_11rb$(longPath);\n continue;\n } else if (path0 != null && path1 != null) {\n longPath.addAll_brywnq$(path0);\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size - 1 | 0));\n longPath.addAll_brywnq$(path1);\n } else if (path0 == null) {\n longPath.addAll_brywnq$(ensureNotNull(path1));\n longPath.addAll_u57x28$(0, path.subList_vux9f0$(0, path.size - 1 | 0));\n } else {\n longPath.addAll_brywnq$(path0);\n longPath.addAll_brywnq$(path.subList_vux9f0$(1, path.size));\n }\n var key = longPath.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key, longPath);\n var key_0 = longPath.get_za3lpa$(longPath.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_0, longPath);\n } else {\n var key_1 = path.get_za3lpa$(0);\n pathByEndPoint.put_xwzc9p$(key_1, path);\n var key_2 = path.get_za3lpa$(path.size - 1 | 0);\n pathByEndPoint.put_xwzc9p$(key_2, path);\n }\n }\n var pathSet = HashSet_init(pathByEndPoint.values);\n tmp$_0 = pathSet.iterator();\n while (tmp$_0.hasNext()) {\n var path_0 = tmp$_0.next();\n newPaths.add_11rb$(path_0);\n }\n var result = ArrayList_init();\n tmp$_1 = newPaths.iterator();\n while (tmp$_1.hasNext()) {\n var path_1 = tmp$_1.next();\n result.addAll_brywnq$(this.pathSeparator_0(path_1));\n }\n return result;\n };\n ContourStatUtil.prototype.removePathByEndpoints_ebaanh$ = function (path, pathByEndPoint) {\n if (path != null) {\n pathByEndPoint.remove_11rb$(path.get_za3lpa$(0));\n pathByEndPoint.remove_11rb$(path.get_za3lpa$(path.size - 1 | 0));\n }};\n ContourStatUtil.prototype.pathSeparator_0 = function (path) {\n var tmp$, tmp$_0;\n var result = ArrayList_init();\n var startIndex = 0;\n tmp$ = path.size - 1 | 0;\n for (var nextIndex = 1; nextIndex < tmp$; nextIndex++) {\n if ((tmp$_0 = path.get_za3lpa$(startIndex)) != null ? tmp$_0.equals(path.get_za3lpa$(nextIndex)) : null) {\n result.add_11rb$(path.subList_vux9f0$(startIndex, nextIndex + 1 | 0));\n startIndex = nextIndex;\n }}\n if (startIndex === 0) {\n return listOf_0(path);\n } else {\n result.add_11rb$(path.subList_vux9f0$(startIndex, path.size));\n return result;\n }\n };\n ContourStatUtil.prototype.computeSegments_0 = function (colCount, rowCount, data, level) {\n var tmp$, tmp$_0;\n var segments = ArrayList_init();\n tmp$ = rowCount - 1 | 0;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = colCount - 1 | 0;\n for (var col = 0; col < tmp$_0; col++) {\n var i0 = Kotlin.imul(row, colCount) + col | 0;\n var i1 = Kotlin.imul(row, colCount) + col + 1 | 0;\n var i2 = Kotlin.imul(row + 1 | 0, colCount) + col + 1 | 0;\n var i3 = Kotlin.imul(row + 1 | 0, colCount) + col | 0;\n var v = new Float64Array(5);\n v[0] = ensureNotNull(data.get_za3lpa$(i0));\n v[1] = ensureNotNull(data.get_za3lpa$(i1));\n v[2] = ensureNotNull(data.get_za3lpa$(i2));\n v[3] = ensureNotNull(data.get_za3lpa$(i3));\n var min = v[0];\n var max = v[0];\n for (var i = 1; i <= 3; i++) {\n var a = min;\n var b = v[i];\n min = JsMath.min(a, b);\n var a_0 = max;\n var b_0 = v[i];\n max = JsMath.max(a_0, b_0);\n }\n if (min === max) {\n continue;\n }v[4] = (v[0] + v[1] + v[2] + v[3] - min - max) / 2;\n if (level > min && level <= max) {\n var cellSegments = this.computeSegmentsForGridCell_0(level, v, col, row);\n segments.addAll_brywnq$(cellSegments);\n }}\n }\n return segments;\n };\n ContourStatUtil.prototype.computeSegmentsForGridCell_0 = function (level, value5, col, row) {\n var result = ArrayList_init();\n var points = ArrayList_init();\n var tempVector;\n for (var i = 0; i <= 4; i++) {\n points.add_11rb$(new ContourStatUtil$TripleVector(col + this.xLoc_0[i], row + this.yLoc_0[i], value5[i]));\n }\n for (var i_0 = 0; i_0 <= 3; i_0++) {\n var i1 = (i_0 + 1 | 0) % 4;\n tempVector = ArrayList_init();\n tempVector.add_11rb$(points.get_za3lpa$(i_0));\n tempVector.add_11rb$(points.get_za3lpa$(i1));\n tempVector.add_11rb$(points.get_za3lpa$(4));\n var temp = this.intersectionSegment_0(tempVector, level);\n if (temp != null) {\n result.add_11rb$(temp);\n }}\n return result;\n };\n ContourStatUtil.prototype.intersectionSegment_0 = function (vectors, level) {\n var type = (vectors.get_za3lpa$(0).getType_14dthe$(ensureNotNull(level)) * 100 | 0) + (vectors.get_za3lpa$(1).getType_14dthe$(level) * 10 | 0) + vectors.get_za3lpa$(2).getType_14dthe$(level) | 0;\n var start;\n var end;\n switch (type) {\n case 100:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(0));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(1));\n break;\n case 10:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(1));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(2));\n break;\n case 1:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(2));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(0));\n break;\n case 110:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(2));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(1));\n break;\n case 101:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(2), vectors.get_za3lpa$(1));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(0));\n break;\n case 11:\n start = new ContourStatUtil$Edge(vectors.get_za3lpa$(1), vectors.get_za3lpa$(0));\n end = new ContourStatUtil$Edge(vectors.get_za3lpa$(0), vectors.get_za3lpa$(2));\n break;\n default:return null;\n }\n return new Pair(start, end);\n };\n ContourStatUtil.prototype.checkEdges_0 = function (paths, colCount, rowCount) {\n var tmp$, tmp$_0;\n tmp$ = paths.iterator();\n while (tmp$.hasNext()) {\n var path = tmp$.next();\n if (!((tmp$_0 = path.get_za3lpa$(0)) != null ? tmp$_0.equals(path.get_za3lpa$(path.size - 1 | 0)) : null)) {\n this.checkEdge_0(path.get_za3lpa$(0), colCount, rowCount);\n this.checkEdge_0(path.get_za3lpa$(path.size - 1 | 0), colCount, rowCount);\n }}\n };\n ContourStatUtil.prototype.checkEdge_0 = function (edge, colCount, rowCount) {\n var a = edge.myA;\n var b = edge.myB;\n if (a.myX === 0 && b.myX === 0) {\n return;\n }if (a.myY === 0 && b.myY === 0) {\n return;\n }if (a.myX === (colCount - 1 | 0) && b.myX === (colCount - 1 | 0)) {\n return;\n }if (a.myY === (rowCount - 1 | 0) && b.myY === (rowCount - 1 | 0)) {\n return;\n }throw IllegalArgumentException_init('Check Edge Failed');\n };\n function ContourStatUtil$TripleVector(x, y, z) {\n this.z = z;\n this.myX = 0;\n this.myY = 0;\n this.myIsCenter_0 = 0;\n this.myX = numberToInt(x);\n this.myY = numberToInt(y);\n this.myIsCenter_0 = x % 1 === 0.0 ? 0 : 1;\n }\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'coord', {\n configurable: true,\n get: function () {\n return new DoubleVector(this.x, this.y);\n }\n });\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'x', {\n configurable: true,\n get: function () {\n return this.myX + 0.5 * this.myIsCenter_0;\n }\n });\n Object.defineProperty(ContourStatUtil$TripleVector.prototype, 'y', {\n configurable: true,\n get: function () {\n return this.myY + 0.5 * this.myIsCenter_0;\n }\n });\n ContourStatUtil$TripleVector.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, ContourStatUtil$TripleVector) ? tmp$_0 : throwCCE();\n return this.myX === ensureNotNull(that).myX && this.myY === that.myY && this.myIsCenter_0 === that.myIsCenter_0;\n };\n ContourStatUtil$TripleVector.prototype.hashCode = function () {\n return hashCode([this.myX, this.myY, this.myIsCenter_0]);\n };\n ContourStatUtil$TripleVector.prototype.getType_14dthe$ = function (level) {\n var tmp$;\n if (this.z >= level) {\n tmp$ = 1;\n } else {\n tmp$ = 0;\n }\n return tmp$;\n };\n ContourStatUtil$TripleVector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TripleVector',\n interfaces: []\n };\n function ContourStatUtil$Edge(myA, myB) {\n this.myA = myA;\n this.myB = myB;\n }\n ContourStatUtil$Edge.prototype.equals = function (other) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n if (!Kotlin.isType(other, ContourStatUtil$Edge)) {\n return false;\n }var obj = (tmp$ = other) == null || Kotlin.isType(tmp$, ContourStatUtil$Edge) ? tmp$ : throwCCE();\n return ((tmp$_0 = this.myA) != null ? tmp$_0.equals(ensureNotNull(obj).myA) : null) && ((tmp$_1 = this.myB) != null ? tmp$_1.equals(obj.myB) : null) || (((tmp$_2 = this.myA) != null ? tmp$_2.equals(obj.myB) : null) && ((tmp$_3 = this.myB) != null ? tmp$_3.equals(obj.myA) : null));\n };\n ContourStatUtil$Edge.prototype.hashCode = function () {\n return this.myA.coord.hashCode() + this.myB.coord.hashCode() | 0;\n };\n ContourStatUtil$Edge.prototype.intersect_14dthe$ = function (level) {\n var z0 = this.myA.z;\n var z1 = this.myB.z;\n if (level === z0) {\n return this.myA.coord;\n }if (level === z1) {\n return this.myB.coord;\n }var ratio = (z1 - z0) / (level - z0);\n var x0 = this.myA.x;\n var y0 = this.myA.y;\n var x1 = this.myB.x;\n var y1 = this.myB.y;\n var x = x0 + (x1 - x0) / ratio;\n var y = y0 + (y1 - y0) / ratio;\n return new DoubleVector(x, y);\n };\n ContourStatUtil$Edge.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Edge',\n interfaces: []\n };\n ContourStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ContourStatUtil',\n interfaces: []\n };\n var ContourStatUtil_instance = null;\n function ContourStatUtil_getInstance() {\n if (ContourStatUtil_instance === null) {\n new ContourStatUtil();\n }return ContourStatUtil_instance;\n }\n function ContourfStat(binCount, binWidth) {\n ContourfStat$Companion_getInstance();\n BaseStat.call(this, ContourfStat$Companion_getInstance().DEF_MAPPING_0);\n this.myBinOptions_0 = new BinStatUtil$BinOptions(binCount, binWidth);\n }\n ContourfStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z]);\n };\n ContourfStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y, Aes$Companion_getInstance().Z])) {\n return this.withEmptyStatValues();\n }tmp$ = ContourStatUtil_getInstance().computeLevels_wuiwgl$(data, this.myBinOptions_0);\n if (tmp$ == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_jco5dt$(data, levels);\n var xRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().X));\n var yRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Y));\n var zRange = ensureNotNull(data.range_8xm3sj$(TransformVar_getInstance().Z));\n var helper = new ContourFillHelper(xRange, yRange);\n var fillLevels = ContourFillHelper$Companion_getInstance().computeFillLevels_4v6zbb$(zRange, levels);\n var polygonListByFillLevel = helper.createPolygons_lrt0be$(pathListByLevel, levels, fillLevels);\n return Contour$Companion_getInstance().getPolygonDataFrame_dnsuee$(fillLevels, polygonListByFillLevel);\n };\n function ContourfStat$Companion() {\n ContourfStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n }\n ContourfStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContourfStat$Companion_instance = null;\n function ContourfStat$Companion_getInstance() {\n if (ContourfStat$Companion_instance === null) {\n new ContourfStat$Companion();\n }return ContourfStat$Companion_instance;\n }\n ContourfStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContourfStat',\n interfaces: [BaseStat]\n };\n function CorrelationStat(correlationMethod, type, fillDiagonal, threshold) {\n CorrelationStat$Companion_getInstance();\n BaseStat.call(this, CorrelationStat$Companion_getInstance().DEF_MAPPING_0);\n this.correlationMethod = correlationMethod;\n this.type = type;\n this.fillDiagonal = fillDiagonal;\n this.threshold = threshold;\n }\n CorrelationStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n if (!(this.correlationMethod === CorrelationStat$Method$PEARSON_getInstance())) {\n var message = 'Unsupported correlation method: ' + this.correlationMethod + ' (only Pearson is currently available)';\n throw IllegalArgumentException_init(message.toString());\n }if (!rangeTo(0.0, 1.0).contains_mef7kx$(this.threshold)) {\n var message_0 = 'Threshold value: ' + this.threshold + ' must be in interval [0.0, 1.0]';\n throw IllegalArgumentException_init(message_0.toString());\n }var cm = CorrelationUtil_getInstance().correlationMatrix_ofg6u8$(data, this.type, this.fillDiagonal, getCallableRef('correlationPearson', function (p1, p2) {\n return correlationPearson(p1, p2);\n }), this.threshold);\n var values = cm.getNumeric_8xm3sj$(Stats_getInstance().CORR);\n var destination = ArrayList_init_1(collectionSizeOrDefault(values, 10));\n var tmp$;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item != null ? JsMath.abs(item) : null);\n }\n var abs = destination;\n return cm.builder().putNumeric_s1rqo9$(Stats_getInstance().CORR_ABS, abs).build();\n };\n CorrelationStat.prototype.consumes = function () {\n return emptyList();\n };\n function CorrelationStat$Method(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CorrelationStat$Method_initFields() {\n CorrelationStat$Method_initFields = function () {\n };\n CorrelationStat$Method$PEARSON_instance = new CorrelationStat$Method('PEARSON', 0);\n CorrelationStat$Method$SPEARMAN_instance = new CorrelationStat$Method('SPEARMAN', 1);\n CorrelationStat$Method$KENDALL_instance = new CorrelationStat$Method('KENDALL', 2);\n }\n var CorrelationStat$Method$PEARSON_instance;\n function CorrelationStat$Method$PEARSON_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$PEARSON_instance;\n }\n var CorrelationStat$Method$SPEARMAN_instance;\n function CorrelationStat$Method$SPEARMAN_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$SPEARMAN_instance;\n }\n var CorrelationStat$Method$KENDALL_instance;\n function CorrelationStat$Method$KENDALL_getInstance() {\n CorrelationStat$Method_initFields();\n return CorrelationStat$Method$KENDALL_instance;\n }\n CorrelationStat$Method.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Method',\n interfaces: [Enum]\n };\n function CorrelationStat$Method$values() {\n return [CorrelationStat$Method$PEARSON_getInstance(), CorrelationStat$Method$SPEARMAN_getInstance(), CorrelationStat$Method$KENDALL_getInstance()];\n }\n CorrelationStat$Method.values = CorrelationStat$Method$values;\n function CorrelationStat$Method$valueOf(name) {\n switch (name) {\n case 'PEARSON':\n return CorrelationStat$Method$PEARSON_getInstance();\n case 'SPEARMAN':\n return CorrelationStat$Method$SPEARMAN_getInstance();\n case 'KENDALL':\n return CorrelationStat$Method$KENDALL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Method.' + name);\n }\n }\n CorrelationStat$Method.valueOf_61zpoe$ = CorrelationStat$Method$valueOf;\n function CorrelationStat$Type(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function CorrelationStat$Type_initFields() {\n CorrelationStat$Type_initFields = function () {\n };\n CorrelationStat$Type$FULL_instance = new CorrelationStat$Type('FULL', 0);\n CorrelationStat$Type$UPPER_instance = new CorrelationStat$Type('UPPER', 1);\n CorrelationStat$Type$LOWER_instance = new CorrelationStat$Type('LOWER', 2);\n }\n var CorrelationStat$Type$FULL_instance;\n function CorrelationStat$Type$FULL_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$FULL_instance;\n }\n var CorrelationStat$Type$UPPER_instance;\n function CorrelationStat$Type$UPPER_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$UPPER_instance;\n }\n var CorrelationStat$Type$LOWER_instance;\n function CorrelationStat$Type$LOWER_getInstance() {\n CorrelationStat$Type_initFields();\n return CorrelationStat$Type$LOWER_instance;\n }\n CorrelationStat$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function CorrelationStat$Type$values() {\n return [CorrelationStat$Type$FULL_getInstance(), CorrelationStat$Type$UPPER_getInstance(), CorrelationStat$Type$LOWER_getInstance()];\n }\n CorrelationStat$Type.values = CorrelationStat$Type$values;\n function CorrelationStat$Type$valueOf(name) {\n switch (name) {\n case 'FULL':\n return CorrelationStat$Type$FULL_getInstance();\n case 'UPPER':\n return CorrelationStat$Type$UPPER_getInstance();\n case 'LOWER':\n return CorrelationStat$Type$LOWER_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Type.' + name);\n }\n }\n CorrelationStat$Type.valueOf_61zpoe$ = CorrelationStat$Type$valueOf;\n function CorrelationStat$Companion() {\n CorrelationStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y), to(Aes$Companion_getInstance().COLOR, Stats_getInstance().CORR), to(Aes$Companion_getInstance().FILL, Stats_getInstance().CORR), to(Aes$Companion_getInstance().LABEL, Stats_getInstance().CORR)]);\n this.DEF_CORRELATION_METHOD = CorrelationStat$Method$PEARSON_getInstance();\n this.DEF_TYPE = CorrelationStat$Type$FULL_getInstance();\n this.DEF_FILL_DIAGONAL = true;\n this.DEF_THRESHOLD = 0.0;\n }\n CorrelationStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CorrelationStat$Companion_instance = null;\n function CorrelationStat$Companion_getInstance() {\n if (CorrelationStat$Companion_instance === null) {\n new CorrelationStat$Companion();\n }return CorrelationStat$Companion_instance;\n }\n CorrelationStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CorrelationStat',\n interfaces: [BaseStat]\n };\n function CorrelationUtil() {\n CorrelationUtil_instance = this;\n }\n CorrelationUtil.prototype.correlation_n2j75g$ = function (lxs, lys, correlationFunction) {\n var tmp$ = allFinite(lxs, lys);\n var xs = tmp$.component1()\n , ys = tmp$.component2();\n return correlationFunction(xs, ys);\n };\n function CorrelationUtil$createComparator$lambda(closure$indexMap) {\n return function (a, b) {\n var tmp$, tmp$_0;\n var tmp$_1;\n if ((tmp$ = closure$indexMap.get_11rb$(a)) != null)\n tmp$_1 = tmp$;\n else {\n throw IllegalStateException_init(('Unknown variable label ' + a + '.').toString());\n }\n var lhsWeight = tmp$_1;\n var tmp$_2;\n if ((tmp$_0 = closure$indexMap.get_11rb$(b)) != null)\n tmp$_2 = tmp$_0;\n else {\n throw IllegalStateException_init(('Unknown variable label ' + b + '.').toString());\n }\n var rhsWeight = tmp$_2;\n return lhsWeight - rhsWeight | 0;\n };\n }\n CorrelationUtil.prototype.createComparator_0 = function (vars) {\n var $receiver = withIndex(vars);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(to(item.value.label, item.index));\n }\n var indexMap = toMap(destination);\n return new Comparator(CorrelationUtil$createComparator$lambda(indexMap));\n };\n function CorrelationUtil$correlationMatrix$addCorrelation(closure$threshold, closure$knownVars, closure$corrData) {\n return function (varX, varY, v) {\n if (JsMath.abs(v) >= closure$threshold) {\n closure$knownVars.add_11rb$(varX);\n closure$knownVars.add_11rb$(varY);\n var $receiver = closure$corrData;\n var key = to(varX, varY);\n $receiver.put_xwzc9p$(key, v);\n }};\n }\n CorrelationUtil.prototype.correlationMatrix_ofg6u8$ = function (data, type, fillDiagonal, correlationFunction, threshold) {\n if (threshold === void 0)\n threshold = CorrelationStat$Companion_getInstance().DEF_THRESHOLD;\n var tmp$, tmp$_0;\n var $receiver = data.variables();\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (DataFrameUtil_getInstance().isNumeric_vede35$(data, element.name))\n destination.add_11rb$(element);\n }\n var numerics = destination;\n var knownVars = LinkedHashSet_init_0();\n var corrData = LinkedHashMap_init();\n var addCorrelation = CorrelationUtil$correlationMatrix$addCorrelation(threshold, knownVars, corrData);\n var i = 0;\n for (var tmp$_2 = numerics.iterator(); tmp$_2.hasNext(); ++i) {\n var vx = tmp$_2.next();\n var xs = data.getNumeric_8xm3sj$(vx);\n if (fillDiagonal) {\n addCorrelation(vx.label, vx.label, 1.0);\n }for (var j = 0; j < i; j++) {\n var vy = numerics.get_za3lpa$(j);\n var ys = data.getNumeric_8xm3sj$(vy);\n var c = this.correlation_n2j75g$(xs, ys, correlationFunction);\n if (type === CorrelationStat$Type$FULL_getInstance() || type === CorrelationStat$Type$LOWER_getInstance()) {\n addCorrelation(vx.label, vy.label, c);\n }if (type === CorrelationStat$Type$FULL_getInstance() || type === CorrelationStat$Type$UPPER_getInstance()) {\n addCorrelation(vy.label, vx.label, c);\n }}\n }\n var var1 = ArrayList_init();\n var var2 = ArrayList_init();\n var corr = ArrayList_init();\n var sortedVars = sortedWith(knownVars, this.createComparator_0(numerics));\n tmp$ = sortedVars.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n tmp$_0 = sortedVars.iterator();\n while (tmp$_0.hasNext()) {\n var y = tmp$_0.next();\n var1.add_11rb$(x);\n var2.add_11rb$(y);\n corr.add_11rb$(corrData.get_11rb$(to(x, y)));\n }\n }\n return DataFrame$DataFrame$Builder_init().putDiscrete_2l962d$(Stats_getInstance().X, var1).putDiscrete_2l962d$(Stats_getInstance().Y, var2).putNumeric_s1rqo9$(Stats_getInstance().CORR, corr).build();\n };\n CorrelationUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CorrelationUtil',\n interfaces: []\n };\n var CorrelationUtil_instance = null;\n function CorrelationUtil_getInstance() {\n if (CorrelationUtil_instance === null) {\n new CorrelationUtil();\n }return CorrelationUtil_instance;\n }\n function CountStat() {\n CountStat$Companion_getInstance();\n BaseStat.call(this, CountStat$Companion_getInstance().DEF_MAPPING_0);\n }\n CountStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n CountStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n var tmp$;\n if (!this.hasRequiredValues_xht41f$(data, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var valuesX = data.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var weight = BinStatUtil_getInstance().weightVector_5m8trb$(valuesX.size, data);\n var statX = ArrayList_init();\n var statCount = ArrayList_init();\n var countByX = CountStat$Companion_getInstance().countByX_0(valuesX, weight);\n tmp$ = countByX.keys.iterator();\n while (tmp$.hasNext()) {\n var x = tmp$.next();\n statX.add_11rb$(x);\n statCount.add_11rb$(ensureNotNull(countByX.get_11rb$(x)).get());\n }\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).build();\n };\n function CountStat$Companion() {\n CountStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().COUNT)]);\n }\n CountStat$Companion.prototype.countByX_0 = function (valuesX, weight) {\n var result = LinkedHashMap_init();\n for (var i = 0; i !== valuesX.size; ++i) {\n var x = valuesX.get_za3lpa$(i);\n if (data.SeriesUtil.isFinite_yrwdxb$(x)) {\n if (!result.containsKey_11rb$(ensureNotNull(x))) {\n var value = new MutableDouble(0.0);\n result.put_xwzc9p$(x, value);\n }ensureNotNull(result.get_11rb$(x)).getAndAdd_14dthe$(data.SeriesUtil.asFinite_z03gcz$(weight.get_za3lpa$(i), 0.0));\n }}\n return result;\n };\n CountStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CountStat$Companion_instance = null;\n function CountStat$Companion_getInstance() {\n if (CountStat$Companion_instance === null) {\n new CountStat$Companion();\n }return CountStat$Companion_instance;\n }\n CountStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CountStat',\n interfaces: [BaseStat]\n };\n function Density2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat.call(this, bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n }\n Density2dStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var yVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (xVector.isEmpty()) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }if (xVector.size !== yVector.size) {\n throw RuntimeException_init('len(x)= ' + toString(xVector.size) + ' and len(y)= ' + toString(yVector.size) + \" doesn't match!\");\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statDensity = ArrayList_init();\n var bandWidth = new Float64Array(2);\n bandWidth[0] = this.getBandWidthX_k9kaly$(xVector);\n bandWidth[1] = this.getBandWidthY_k9kaly$(yVector);\n var stepsX = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(xRange), this.nX);\n var stepsY = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(yRange), this.nY);\n var groupWeight = BinStatUtil_getInstance().weightVector_5m8trb$(xVector.size, data_0);\n var matrixX = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(xVector, stepsX, this.kernelFun, bandWidth[0], this.adjust, groupWeight));\n var matrixY = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(yVector, stepsY, this.kernelFun, bandWidth[1], this.adjust, groupWeight));\n var matrixFinal = matrixY.multiply_1dlv11$(matrixX.transpose());\n tmp$ = this.nY;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = this.nX;\n for (var col = 0; col < tmp$_0; col++) {\n statX.add_11rb$(stepsX.get_za3lpa$(col));\n statY.add_11rb$(stepsY.get_za3lpa$(row));\n statDensity.add_11rb$(matrixFinal.getEntry_vux9f0$(row, col) / data.SeriesUtil.sum_k9kaly$(groupWeight));\n }\n }\n if (this.isContour) {\n var zRange = data.SeriesUtil.range_l63ks6$(statDensity);\n tmp$_1 = ContourStatUtil_getInstance().computeLevels_kgz263$(zRange, this.binOptions);\n if (tmp$_1 == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$_1;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_cxleoh$(xRange, yRange, this.nX, this.nY, statDensity, levels);\n return Contour$Companion_getInstance().getPathDataFrame_9s3d7f$(levels, pathListByLevel);\n } else {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n }\n };\n Density2dStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dStat',\n interfaces: [AbstractDensity2dStat]\n };\n function Density2dfStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n AbstractDensity2dStat.call(this, bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n }\n Density2dfStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X, Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var xVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n var yVector = data_0.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (xVector.isEmpty()) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }if (xVector.size !== yVector.size) {\n throw RuntimeException_init('len(x)= ' + toString(xVector.size) + ' and len(y)= ' + toString(yVector.size) + \" doesn't match!\");\n }var xRange = statCtx.overallXRange();\n var yRange = statCtx.overallYRange();\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statDensity = ArrayList_init();\n var bandWidth = new Float64Array(2);\n bandWidth[0] = this.getBandWidthX_k9kaly$(xVector);\n bandWidth[1] = this.getBandWidthY_k9kaly$(yVector);\n var stepsX = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(xRange), this.nX);\n var stepsY = DensityStatUtil_getInstance().createStepValues_1tlvto$(ensureNotNull(yRange), this.nY);\n var groupWeight = BinStatUtil_getInstance().weightVector_5m8trb$(xVector.size, data_0);\n var matrixX = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(xVector, stepsX, this.kernelFun, bandWidth[0], this.adjust, groupWeight));\n var matrixY = BlockRealMatrix_init_0(DensityStatUtil_getInstance().createRawMatrix_a6xq99$(yVector, stepsY, this.kernelFun, bandWidth[1], this.adjust, groupWeight));\n var matrixFinal = matrixY.multiply_1dlv11$(matrixX.transpose());\n tmp$ = this.nY;\n for (var row = 0; row < tmp$; row++) {\n tmp$_0 = this.nX;\n for (var col = 0; col < tmp$_0; col++) {\n statX.add_11rb$(stepsX.get_za3lpa$(col));\n statY.add_11rb$(stepsY.get_za3lpa$(row));\n statDensity.add_11rb$(matrixFinal.getEntry_vux9f0$(row, col) / data.SeriesUtil.sum_k9kaly$(groupWeight));\n }\n }\n if (this.isContour) {\n var zRange = data.SeriesUtil.range_l63ks6$(statDensity);\n tmp$_1 = ContourStatUtil_getInstance().computeLevels_kgz263$(zRange, this.binOptions);\n if (tmp$_1 == null) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n }var levels = tmp$_1;\n var pathListByLevel = ContourStatUtil_getInstance().computeContours_cxleoh$(xRange, yRange, this.nX, this.nY, statDensity, levels);\n var helper = new ContourFillHelper(xRange, yRange);\n var fillLevels = ContourFillHelper$Companion_getInstance().computeFillLevels_4v6zbb$(ensureNotNull(zRange), levels);\n var polygonListByFillLevel = helper.createPolygons_lrt0be$(pathListByLevel, levels, fillLevels);\n return Contour$Companion_getInstance().getPolygonDataFrame_dnsuee$(fillLevels.subList_vux9f0$(1, fillLevels.size), polygonListByFillLevel);\n } else {\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).build();\n }\n };\n Density2dfStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Density2dfStat',\n interfaces: [AbstractDensity2dStat]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function DensityStat(bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax) {\n DensityStat$Companion_getInstance();\n BaseStat.call(this, DensityStat$Companion_getInstance().DEF_MAPPING_0);\n this.bandWidth_0 = bandWidth;\n this.bandWidthMethod_0 = bandWidthMethod;\n this.adjust_0 = adjust;\n this.kernel_0 = kernel;\n this.n_0 = n;\n this.fullScalMax_0 = fullScalMax;\n if (!(this.n_0 <= 1024)) {\n var message = 'The input n = ' + this.n_0 + ' > ' + '1024' + ' is too large!';\n throw IllegalArgumentException_init(message.toString());\n }}\n DensityStat.prototype.consumes = function () {\n return listOf([Aes$Companion_getInstance().X, Aes$Companion_getInstance().WEIGHT]);\n };\n function DensityStat$apply$lambda(it) {\n return it.first;\n }\n DensityStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().X])) {\n return this.withEmptyStatValues();\n }var xs;\n var weights;\n if (data_0.has_8xm3sj$(TransformVar_getInstance().WEIGHT)) {\n var filtered = data.SeriesUtil.filterFinite_10sy24$(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X), data_0.getNumeric_8xm3sj$(TransformVar_getInstance().WEIGHT));\n var xsFiltered = filtered.get_za3lpa$(0);\n var weightsFiltered = filtered.get_za3lpa$(1);\n var tmp$_5 = unzip(sortedWith(zip(xsFiltered, weightsFiltered), new Comparator(compareBy$lambda(DensityStat$apply$lambda))));\n var xsSorted = tmp$_5.component1()\n , weightsSorted = tmp$_5.component2();\n xs = xsSorted;\n weights = weightsSorted;\n } else {\n var $receiver = filterNotNull(data_0.getNumeric_8xm3sj$(TransformVar_getInstance().X));\n var destination = ArrayList_init();\n var tmp$_6;\n tmp$_6 = $receiver.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (isFinite(element))\n destination.add_11rb$(element);\n }\n xs = sorted(destination);\n var size = xs.size;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(1.0);\n }\n weights = list;\n }\n if (xs.isEmpty())\n return this.withEmptyStatValues();\n var rangeX = (tmp$ = statCtx.overallXRange()) != null ? tmp$ : new ClosedRange(-0.5, 0.5);\n var statX = DensityStatUtil_getInstance().createStepValues_1tlvto$(rangeX, this.n_0);\n var statDensity = ArrayList_init();\n var statCount = ArrayList_init();\n var statScaled = ArrayList_init();\n var bandWidth = (tmp$_0 = this.bandWidth_0) != null ? tmp$_0 : DensityStatUtil_getInstance().bandWidth_whucba$(this.bandWidthMethod_0, xs);\n var kernelFun = DensityStatUtil_getInstance().kernel_uyf859$(this.kernel_0);\n tmp$_1 = xs.size <= this.fullScalMax_0;\n if (tmp$_1 === true)\n tmp$_2 = DensityStatUtil_getInstance().densityFunctionFullScan_hztk2d$(xs, weights, kernelFun, bandWidth, this.adjust_0);\n else if (tmp$_1 === false)\n tmp$_2 = DensityStatUtil_getInstance().densityFunctionFast_hztk2d$(xs, weights, kernelFun, bandWidth, this.adjust_0);\n else\n tmp$_2 = Kotlin.noWhenBranchMatched();\n var densityFunction = tmp$_2;\n var nTotal = sum(weights);\n tmp$_3 = statX.iterator();\n while (tmp$_3.hasNext()) {\n var x = tmp$_3.next();\n var d = densityFunction(x);\n statCount.add_11rb$(d);\n statDensity.add_11rb$(d / nTotal);\n }\n var maxm = ensureNotNull(maxOrNull(statCount));\n tmp$_4 = statCount.iterator();\n while (tmp$_4.hasNext()) {\n var d_0 = tmp$_4.next();\n statScaled.add_11rb$(d_0 / maxm);\n }\n return DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().DENSITY, statDensity).putNumeric_s1rqo9$(Stats_getInstance().COUNT, statCount).putNumeric_s1rqo9$(Stats_getInstance().SCALED, statScaled).build();\n };\n function DensityStat$Kernel(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DensityStat$Kernel_initFields() {\n DensityStat$Kernel_initFields = function () {\n };\n DensityStat$Kernel$GAUSSIAN_instance = new DensityStat$Kernel('GAUSSIAN', 0);\n DensityStat$Kernel$RECTANGULAR_instance = new DensityStat$Kernel('RECTANGULAR', 1);\n DensityStat$Kernel$TRIANGULAR_instance = new DensityStat$Kernel('TRIANGULAR', 2);\n DensityStat$Kernel$BIWEIGHT_instance = new DensityStat$Kernel('BIWEIGHT', 3);\n DensityStat$Kernel$EPANECHNIKOV_instance = new DensityStat$Kernel('EPANECHNIKOV', 4);\n DensityStat$Kernel$OPTCOSINE_instance = new DensityStat$Kernel('OPTCOSINE', 5);\n DensityStat$Kernel$COSINE_instance = new DensityStat$Kernel('COSINE', 6);\n }\n var DensityStat$Kernel$GAUSSIAN_instance;\n function DensityStat$Kernel$GAUSSIAN_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$GAUSSIAN_instance;\n }\n var DensityStat$Kernel$RECTANGULAR_instance;\n function DensityStat$Kernel$RECTANGULAR_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$RECTANGULAR_instance;\n }\n var DensityStat$Kernel$TRIANGULAR_instance;\n function DensityStat$Kernel$TRIANGULAR_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$TRIANGULAR_instance;\n }\n var DensityStat$Kernel$BIWEIGHT_instance;\n function DensityStat$Kernel$BIWEIGHT_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$BIWEIGHT_instance;\n }\n var DensityStat$Kernel$EPANECHNIKOV_instance;\n function DensityStat$Kernel$EPANECHNIKOV_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$EPANECHNIKOV_instance;\n }\n var DensityStat$Kernel$OPTCOSINE_instance;\n function DensityStat$Kernel$OPTCOSINE_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$OPTCOSINE_instance;\n }\n var DensityStat$Kernel$COSINE_instance;\n function DensityStat$Kernel$COSINE_getInstance() {\n DensityStat$Kernel_initFields();\n return DensityStat$Kernel$COSINE_instance;\n }\n DensityStat$Kernel.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Kernel',\n interfaces: [Enum]\n };\n function DensityStat$Kernel$values() {\n return [DensityStat$Kernel$GAUSSIAN_getInstance(), DensityStat$Kernel$RECTANGULAR_getInstance(), DensityStat$Kernel$TRIANGULAR_getInstance(), DensityStat$Kernel$BIWEIGHT_getInstance(), DensityStat$Kernel$EPANECHNIKOV_getInstance(), DensityStat$Kernel$OPTCOSINE_getInstance(), DensityStat$Kernel$COSINE_getInstance()];\n }\n DensityStat$Kernel.values = DensityStat$Kernel$values;\n function DensityStat$Kernel$valueOf(name) {\n switch (name) {\n case 'GAUSSIAN':\n return DensityStat$Kernel$GAUSSIAN_getInstance();\n case 'RECTANGULAR':\n return DensityStat$Kernel$RECTANGULAR_getInstance();\n case 'TRIANGULAR':\n return DensityStat$Kernel$TRIANGULAR_getInstance();\n case 'BIWEIGHT':\n return DensityStat$Kernel$BIWEIGHT_getInstance();\n case 'EPANECHNIKOV':\n return DensityStat$Kernel$EPANECHNIKOV_getInstance();\n case 'OPTCOSINE':\n return DensityStat$Kernel$OPTCOSINE_getInstance();\n case 'COSINE':\n return DensityStat$Kernel$COSINE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.DensityStat.Kernel.' + name);\n }\n }\n DensityStat$Kernel.valueOf_61zpoe$ = DensityStat$Kernel$valueOf;\n function DensityStat$BandWidthMethod(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DensityStat$BandWidthMethod_initFields() {\n DensityStat$BandWidthMethod_initFields = function () {\n };\n DensityStat$BandWidthMethod$NRD0_instance = new DensityStat$BandWidthMethod('NRD0', 0);\n DensityStat$BandWidthMethod$NRD_instance = new DensityStat$BandWidthMethod('NRD', 1);\n }\n var DensityStat$BandWidthMethod$NRD0_instance;\n function DensityStat$BandWidthMethod$NRD0_getInstance() {\n DensityStat$BandWidthMethod_initFields();\n return DensityStat$BandWidthMethod$NRD0_instance;\n }\n var DensityStat$BandWidthMethod$NRD_instance;\n function DensityStat$BandWidthMethod$NRD_getInstance() {\n DensityStat$BandWidthMethod_initFields();\n return DensityStat$BandWidthMethod$NRD_instance;\n }\n DensityStat$BandWidthMethod.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BandWidthMethod',\n interfaces: [Enum]\n };\n function DensityStat$BandWidthMethod$values() {\n return [DensityStat$BandWidthMethod$NRD0_getInstance(), DensityStat$BandWidthMethod$NRD_getInstance()];\n }\n DensityStat$BandWidthMethod.values = DensityStat$BandWidthMethod$values;\n function DensityStat$BandWidthMethod$valueOf(name) {\n switch (name) {\n case 'NRD0':\n return DensityStat$BandWidthMethod$NRD0_getInstance();\n case 'NRD':\n return DensityStat$BandWidthMethod$NRD_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.DensityStat.BandWidthMethod.' + name);\n }\n }\n DensityStat$BandWidthMethod.valueOf_61zpoe$ = DensityStat$BandWidthMethod$valueOf;\n function DensityStat$Companion() {\n DensityStat$Companion_instance = this;\n this.DEF_KERNEL = DensityStat$Kernel$GAUSSIAN_getInstance();\n this.DEF_ADJUST = 1.0;\n this.DEF_N = 512;\n this.DEF_BW = DensityStat$BandWidthMethod$NRD0_getInstance();\n this.DEF_FULL_SCAN_MAX = 5000;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().DENSITY)]);\n this.MAX_N_0 = 1024;\n }\n DensityStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DensityStat$Companion_instance = null;\n function DensityStat$Companion_getInstance() {\n if (DensityStat$Companion_instance === null) {\n new DensityStat$Companion();\n }return DensityStat$Companion_instance;\n }\n DensityStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DensityStat',\n interfaces: [BaseStat]\n };\n function DensityStatUtil() {\n DensityStatUtil_instance = this;\n this.DEF_STEP_SIZE_0 = 0.5;\n }\n DensityStatUtil.prototype.stdDev_0 = function (data) {\n var tmp$, tmp$_0;\n var sum = 0.0;\n var counter = 0.0;\n tmp$ = data.iterator();\n while (tmp$.hasNext()) {\n var i = tmp$.next();\n sum += i;\n }\n var mean = sum / data.size;\n tmp$_0 = data.iterator();\n while (tmp$_0.hasNext()) {\n var i_0 = tmp$_0.next();\n var $receiver = i_0 - mean;\n counter += JsMath.pow($receiver, 2.0);\n }\n var x = counter / data.size;\n return JsMath.sqrt(x);\n };\n DensityStatUtil.prototype.bandWidth_whucba$ = function (bw, valuesX) {\n var tmp$;\n var mySize = valuesX.size;\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = valuesX.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (data.SeriesUtil.isFinite_yrwdxb$(element))\n destination.add_11rb$(element);\n }\n var valuesXFinite = Kotlin.isType(tmp$ = destination, List) ? tmp$ : throwCCE();\n var dataSummary = FiveNumberSummary_init(valuesXFinite);\n var myIQR = dataSummary.thirdQuartile - dataSummary.firstQuartile;\n var myStdD = this.stdDev_0(valuesXFinite);\n switch (bw.name) {\n case 'NRD0':\n if (myIQR > 0) {\n var b = myIQR / 1.34;\n var tmp$_1 = 0.9 * JsMath.min(myStdD, b);\n var x = -0.2;\n return tmp$_1 * JsMath.pow(mySize, x);\n }\n if (myStdD > 0) {\n var tmp$_2 = 0.9 * myStdD;\n var x_0 = -0.2;\n return tmp$_2 * JsMath.pow(mySize, x_0);\n }\n break;\n case 'NRD':\n if (myIQR > 0) {\n var b_0 = myIQR / 1.34;\n var tmp$_3 = 1.06 * JsMath.min(myStdD, b_0);\n var x_1 = -0.2;\n return tmp$_3 * JsMath.pow(mySize, x_1);\n }\n if (myStdD > 0) {\n var tmp$_4 = 1.06 * myStdD;\n var x_2 = -0.2;\n return tmp$_4 * JsMath.pow(mySize, x_2);\n }\n break;\n }\n return 1.0;\n };\n function DensityStatUtil$kernel$lambda(value) {\n var x = 2 * math.PI;\n var tmp$ = 1 / JsMath.sqrt(x);\n var x_0 = -0.5 * JsMath.pow(value, 2.0);\n return tmp$ * JsMath.exp(x_0);\n }\n function DensityStatUtil$kernel$lambda_0(value) {\n return JsMath.abs(value) <= 1 ? 0.5 : 0.0;\n }\n function DensityStatUtil$kernel$lambda_1(value) {\n return JsMath.abs(value) <= 1 ? 1 - JsMath.abs(value) : 0.0;\n }\n function DensityStatUtil$kernel$lambda_2(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var $receiver = 1 - value * value;\n tmp$ = 0.9375 * JsMath.pow($receiver, 2.0);\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n function DensityStatUtil$kernel$lambda_3(value) {\n return JsMath.abs(value) <= 1 ? 0.75 * (1 - value * value) : 0.0;\n }\n function DensityStatUtil$kernel$lambda_4(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var tmp$_0 = math.PI / 4;\n var x = math.PI / 2 * value;\n tmp$ = tmp$_0 * JsMath.cos(x);\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n function DensityStatUtil$kernel$lambda_5(value) {\n var tmp$;\n if (JsMath.abs(value) <= 1) {\n var x = math.PI * value;\n tmp$ = (JsMath.cos(x) + 1) / 2;\n } else\n tmp$ = 0.0;\n return tmp$;\n }\n DensityStatUtil.prototype.kernel_uyf859$ = function (ker) {\n var tmp$;\n switch (ker.name) {\n case 'GAUSSIAN':\n tmp$ = DensityStatUtil$kernel$lambda;\n break;\n case 'RECTANGULAR':\n tmp$ = DensityStatUtil$kernel$lambda_0;\n break;\n case 'TRIANGULAR':\n tmp$ = DensityStatUtil$kernel$lambda_1;\n break;\n case 'BIWEIGHT':\n tmp$ = DensityStatUtil$kernel$lambda_2;\n break;\n case 'EPANECHNIKOV':\n tmp$ = DensityStatUtil$kernel$lambda_3;\n break;\n case 'OPTCOSINE':\n tmp$ = DensityStatUtil$kernel$lambda_4;\n break;\n default:tmp$ = DensityStatUtil$kernel$lambda_5;\n break;\n }\n return tmp$;\n };\n function DensityStatUtil$densityFunctionFullScan$lambda(closure$xs, closure$ker, closure$h, closure$weights) {\n return function (x) {\n var sum = 0.0;\n for (var i = 0; i !== closure$xs.size; ++i) {\n sum += closure$ker((x - closure$xs.get_za3lpa$(i)) / closure$h) * closure$weights.get_za3lpa$(i);\n }\n return sum / closure$h;\n };\n }\n DensityStatUtil.prototype.densityFunctionFullScan_hztk2d$ = function (xs, weights, ker, bw, ad) {\n var h = bw * ad;\n return DensityStatUtil$densityFunctionFullScan$lambda(xs, ker, h, weights);\n };\n function DensityStatUtil$densityFunctionFast$lambda(closure$xs, closure$cutoff, closure$ker, closure$h, closure$weights) {\n return function (x) {\n var tmp$;\n var sum = 0.0;\n var from = binarySearch(closure$xs, x - closure$cutoff);\n if (from < 0) {\n from = (-from | 0) - 1 | 0;\n }var to = binarySearch(closure$xs, x + closure$cutoff);\n if (to < 0) {\n to = (-to | 0) - 1 | 0;\n }tmp$ = to;\n for (var i = from; i < tmp$; i++) {\n sum += closure$ker((x - closure$xs.get_za3lpa$(i)) / closure$h) * closure$weights.get_za3lpa$(i);\n }\n return sum / closure$h;\n };\n }\n DensityStatUtil.prototype.densityFunctionFast_hztk2d$ = function (xs, weights, ker, bw, ad) {\n var h = bw * ad;\n var cutoff = h * 5;\n return DensityStatUtil$densityFunctionFast$lambda(xs, cutoff, ker, h, weights);\n };\n DensityStatUtil.prototype.createStepValues_1tlvto$ = function (range, n) {\n var x = ArrayList_init();\n var min = range.lowerEnd;\n var max = range.upperEnd;\n var step;\n if (max === min) {\n max += this.DEF_STEP_SIZE_0;\n min -= this.DEF_STEP_SIZE_0;\n }step = (max - min) / (n - 1 | 0);\n for (var i = 0; i < n; i++) {\n x.add_11rb$(min + step * i);\n }\n return x;\n };\n DensityStatUtil.prototype.toKernel_61zpoe$ = function (method) {\n var tmp$;\n switch (method) {\n case 'gaussian':\n tmp$ = DensityStat$Kernel$GAUSSIAN_getInstance();\n break;\n case 'rectangular':\n case 'uniform':\n tmp$ = DensityStat$Kernel$RECTANGULAR_getInstance();\n break;\n case 'triangular':\n tmp$ = DensityStat$Kernel$TRIANGULAR_getInstance();\n break;\n case 'biweight':\n case 'quartic':\n tmp$ = DensityStat$Kernel$BIWEIGHT_getInstance();\n break;\n case 'epanechikov':\n case 'parabolic':\n tmp$ = DensityStat$Kernel$EPANECHNIKOV_getInstance();\n break;\n case 'optcosine':\n tmp$ = DensityStat$Kernel$OPTCOSINE_getInstance();\n break;\n case 'cosine':\n tmp$ = DensityStat$Kernel$COSINE_getInstance();\n break;\n default:throw IllegalArgumentException_init(\"Unsupported kernel method: '\" + method + \"'.\" + '\\n' + 'Use one of: gaussian, rectangular, triangular, biweight, epanechikov, optcosine, cos.');\n }\n return tmp$;\n };\n DensityStatUtil.prototype.toBandWidthMethod_61zpoe$ = function (bw) {\n var tmp$;\n switch (bw) {\n case 'nrd0':\n tmp$ = DensityStat$BandWidthMethod$NRD0_getInstance();\n break;\n case 'nrd':\n tmp$ = DensityStat$BandWidthMethod$NRD_getInstance();\n break;\n default:throw IllegalArgumentException_init(\"Unsupported bandwidth method: '\" + bw + \"'.\" + '\\n' + 'Use one of: nrd0, nrd.');\n }\n return tmp$;\n };\n DensityStatUtil.prototype.createRawMatrix_a6xq99$ = function (values, list, ker, bw, ad, weight) {\n var a = bw * ad;\n var n = values.size;\n var x = list.size;\n var array = Array_0(x);\n var tmp$;\n tmp$ = array.length - 1 | 0;\n for (var i = 0; i <= tmp$; i++) {\n array[i] = new Float64Array(n);\n }\n var result = array;\n for (var row = 0; row < x; row++) {\n for (var col = 0; col < n; col++) {\n var tmp$_0 = result[row];\n var tmp$_1 = ker((list.get_za3lpa$(row) - ensureNotNull(values.get_za3lpa$(col))) / a);\n var x_0 = ensureNotNull(weight.get_za3lpa$(col));\n tmp$_0[col] = tmp$_1 * JsMath.sqrt(x_0) / a;\n }\n }\n return result;\n };\n DensityStatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DensityStatUtil',\n interfaces: []\n };\n var DensityStatUtil_instance = null;\n function DensityStatUtil_getInstance() {\n if (DensityStatUtil_instance === null) {\n new DensityStatUtil();\n }return DensityStatUtil_instance;\n }\n function FiveNumberSummary() {\n this.min = 0;\n this.max = 0;\n this.median = 0;\n this.firstQuartile = 0;\n this.thirdQuartile = 0;\n }\n FiveNumberSummary.prototype.medianAtPointer_0 = function (l, pointer) {\n var tmp$;\n var rint = round(pointer);\n if (pointer === rint) {\n tmp$ = l.get_za3lpa$(numberToInt(pointer));\n } else {\n tmp$ = (l.get_za3lpa$(numberToInt(JsMath.ceil(pointer))) + l.get_za3lpa$(numberToInt(JsMath.floor(pointer)))) / 2.0;\n }\n return tmp$;\n };\n FiveNumberSummary.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n var that = (tmp$_0 = other) == null || Kotlin.isType(tmp$_0, FiveNumberSummary) ? tmp$_0 : throwCCE();\n return Kotlin.compareTo(ensureNotNull(that).min, this.min) === 0 && Kotlin.compareTo(that.max, this.max) === 0 && Kotlin.compareTo(that.median, this.median) === 0 && Kotlin.compareTo(that.firstQuartile, this.firstQuartile) === 0 && Kotlin.compareTo(that.thirdQuartile, this.thirdQuartile) === 0;\n };\n FiveNumberSummary.prototype.hashCode = function () {\n return hashCode([this.min, this.max, this.median, this.firstQuartile, this.thirdQuartile]);\n };\n FiveNumberSummary.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FiveNumberSummary',\n interfaces: []\n };\n function FiveNumberSummary_init(data, $this) {\n $this = $this || Object.create(FiveNumberSummary.prototype);\n FiveNumberSummary.call($this);\n var sorted = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(data);\n if (sorted.isEmpty()) {\n $this.thirdQuartile = kotlin_js_internal_DoubleCompanionObject.NaN;\n $this.firstQuartile = $this.thirdQuartile;\n $this.median = $this.firstQuartile;\n $this.max = $this.median;\n $this.min = $this.max;\n } else if (sorted.size === 1) {\n $this.thirdQuartile = sorted.get_za3lpa$(0);\n $this.firstQuartile = $this.thirdQuartile;\n $this.median = $this.firstQuartile;\n $this.max = $this.median;\n $this.min = $this.max;\n } else {\n var maxIndex = sorted.size - 1 | 0;\n $this.min = sorted.get_za3lpa$(0);\n $this.max = sorted.get_za3lpa$(maxIndex);\n $this.median = $this.medianAtPointer_0(sorted, maxIndex * 0.5);\n $this.firstQuartile = $this.medianAtPointer_0(sorted, maxIndex * 0.25);\n $this.thirdQuartile = $this.medianAtPointer_0(sorted, maxIndex * 0.75);\n }\n return $this;\n }\n function FiveNumberSummary_init_0(min, max, median, firstQuartile, thirdQuartile, $this) {\n $this = $this || Object.create(FiveNumberSummary.prototype);\n FiveNumberSummary.call($this);\n $this.min = min;\n $this.max = max;\n $this.median = median;\n $this.firstQuartile = firstQuartile;\n $this.thirdQuartile = thirdQuartile;\n return $this;\n }\n function MultiOrdering(myKeys) {\n this.myKeys_0 = myKeys;\n this.myIndices_0 = null;\n var tmp$;\n this.myIndices_0 = ArrayList_init_1(this.myKeys_0.size);\n tmp$ = this.myKeys_0;\n for (var i = 0; i !== tmp$.size; ++i) {\n this.myIndices_0.add_11rb$(i);\n }\n sortWith(this.myIndices_0, new Comparator(MultiOrdering_init$lambda(this)));\n }\n MultiOrdering.prototype.sortedCopy_bemo1h$ = function (l) {\n var tmp$;\n if (!(l.size === this.myIndices_0.size)) {\n var message = 'Expected size ' + toString(this.myIndices_0.size) + ' but was size ' + toString(l.size);\n throw IllegalArgumentException_init(message.toString());\n }var copy = ArrayList_init_1(this.myIndices_0.size);\n tmp$ = this.myIndices_0.iterator();\n while (tmp$.hasNext()) {\n var oldIndex = tmp$.next();\n var v = l.get_za3lpa$(oldIndex);\n copy.add_11rb$(v);\n }\n return copy;\n };\n MultiOrdering.prototype.sortedCopyOfKeys = function () {\n return this.sortedCopy_bemo1h$(this.myKeys_0);\n };\n function MultiOrdering_init$lambda(this$MultiOrdering) {\n return function (i, j) {\n var keyI = this$MultiOrdering.myKeys_0.get_za3lpa$(ensureNotNull(i));\n var keyJ = this$MultiOrdering.myKeys_0.get_za3lpa$(ensureNotNull(j));\n if (keyI === keyJ)\n return 0;\n else if (keyI == null)\n return -1;\n else if (keyJ == null)\n return 1;\n else\n return Kotlin.compareTo(keyI, keyJ);\n };\n }\n MultiOrdering.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MultiOrdering',\n interfaces: []\n };\n function SimpleStatContext(myDataFrame) {\n this.myDataFrame_0 = myDataFrame;\n }\n SimpleStatContext.prototype.overallXRange = function () {\n return this.myDataFrame_0.range_8xm3sj$(TransformVar_getInstance().X);\n };\n SimpleStatContext.prototype.overallYRange = function () {\n return this.myDataFrame_0.range_8xm3sj$(TransformVar_getInstance().Y);\n };\n SimpleStatContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SimpleStatContext',\n interfaces: [StatContext]\n };\n function SmoothStat(smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed) {\n SmoothStat$Companion_getInstance();\n BaseStat.call(this, SmoothStat$Companion_getInstance().DEF_MAPPING_0);\n this.smootherPointCount_0 = smootherPointCount;\n this.smoothingMethod_0 = smoothingMethod;\n this.confidenceLevel_0 = confidenceLevel;\n this.displayConfidenceInterval_0 = displayConfidenceInterval;\n this.span_0 = span;\n this.polynomialDegree_0 = polynomialDegree;\n this.loessCriticalSize_0 = loessCriticalSize;\n this.samplingSeed_0 = samplingSeed;\n }\n SmoothStat.prototype.hasDefaultMapping_896ixz$ = function (aes) {\n return BaseStat.prototype.hasDefaultMapping_896ixz$.call(this, aes) || (equals(aes, Aes$Companion_getInstance().YMIN) && this.displayConfidenceInterval_0) || (equals(aes, Aes$Companion_getInstance().YMAX) && this.displayConfidenceInterval_0);\n };\n SmoothStat.prototype.getDefaultMapping_896ixz$ = function (aes) {\n var tmp$;\n if (equals(aes, Aes$Companion_getInstance().YMIN)) {\n return Stats_getInstance().Y_MIN;\n }if (equals(aes, Aes$Companion_getInstance().YMAX)) {\n tmp$ = Stats_getInstance().Y_MAX;\n } else\n tmp$ = BaseStat.prototype.getDefaultMapping_896ixz$.call(this, aes);\n return tmp$;\n };\n function SmoothStat$Method(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function SmoothStat$Method_initFields() {\n SmoothStat$Method_initFields = function () {\n };\n SmoothStat$Method$LM_instance = new SmoothStat$Method('LM', 0);\n SmoothStat$Method$GLM_instance = new SmoothStat$Method('GLM', 1);\n SmoothStat$Method$GAM_instance = new SmoothStat$Method('GAM', 2);\n SmoothStat$Method$LOESS_instance = new SmoothStat$Method('LOESS', 3);\n SmoothStat$Method$RLM_instance = new SmoothStat$Method('RLM', 4);\n }\n var SmoothStat$Method$LM_instance;\n function SmoothStat$Method$LM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$LM_instance;\n }\n var SmoothStat$Method$GLM_instance;\n function SmoothStat$Method$GLM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$GLM_instance;\n }\n var SmoothStat$Method$GAM_instance;\n function SmoothStat$Method$GAM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$GAM_instance;\n }\n var SmoothStat$Method$LOESS_instance;\n function SmoothStat$Method$LOESS_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$LOESS_instance;\n }\n var SmoothStat$Method$RLM_instance;\n function SmoothStat$Method$RLM_getInstance() {\n SmoothStat$Method_initFields();\n return SmoothStat$Method$RLM_instance;\n }\n SmoothStat$Method.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Method',\n interfaces: [Enum]\n };\n function SmoothStat$Method$values() {\n return [SmoothStat$Method$LM_getInstance(), SmoothStat$Method$GLM_getInstance(), SmoothStat$Method$GAM_getInstance(), SmoothStat$Method$LOESS_getInstance(), SmoothStat$Method$RLM_getInstance()];\n }\n SmoothStat$Method.values = SmoothStat$Method$values;\n function SmoothStat$Method$valueOf(name) {\n switch (name) {\n case 'LM':\n return SmoothStat$Method$LM_getInstance();\n case 'GLM':\n return SmoothStat$Method$GLM_getInstance();\n case 'GAM':\n return SmoothStat$Method$GAM_getInstance();\n case 'LOESS':\n return SmoothStat$Method$LOESS_getInstance();\n case 'RLM':\n return SmoothStat$Method$RLM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.SmoothStat.Method.' + name);\n }\n }\n SmoothStat$Method.valueOf_61zpoe$ = SmoothStat$Method$valueOf;\n function SmoothStat$Companion() {\n SmoothStat$Companion_instance = this;\n this.DEF_MAPPING_0 = mapOf([to(Aes$Companion_getInstance().X, Stats_getInstance().X), to(Aes$Companion_getInstance().Y, Stats_getInstance().Y)]);\n this.DEF_EVAL_POINT_COUNT = 80;\n this.DEF_SMOOTHING_METHOD = SmoothStat$Method$LM_getInstance();\n this.DEF_CONFIDENCE_LEVEL = 0.95;\n this.DEF_DISPLAY_CONFIDENCE_INTERVAL = true;\n this.DEF_SPAN = 0.5;\n this.DEF_DEG = 1;\n this.DEF_LOESS_CRITICAL_SIZE = 1000;\n this.DEF_SAMPLING_SEED = L37;\n }\n SmoothStat$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SmoothStat$Companion_instance = null;\n function SmoothStat$Companion_getInstance() {\n if (SmoothStat$Companion_instance === null) {\n new SmoothStat$Companion();\n }return SmoothStat$Companion_instance;\n }\n SmoothStat.prototype.consumes = function () {\n return listOf_0(Aes$Companion_getInstance().Y);\n };\n SmoothStat.prototype.needSampling_za3lpa$ = function (rowCount) {\n if (this.smoothingMethod_0 !== SmoothStat$Method$LOESS_getInstance()) {\n return false;\n }if (rowCount <= this.loessCriticalSize_0) {\n return false;\n }return true;\n };\n SmoothStat.prototype.applySampling_0 = function (data, messageConsumer) {\n var msg = 'LOESS drew a random sample with max_n=' + this.loessCriticalSize_0 + ', seed=' + this.samplingSeed_0.toString();\n messageConsumer(msg);\n return SamplingUtil_getInstance().sampleWithoutReplacement_egh5ya$(this.loessCriticalSize_0, Random_0(this.samplingSeed_0), data);\n };\n SmoothStat.prototype.apply_kdy6bf$$default = function (data_0, statCtx, messageConsumer) {\n if (!this.hasRequiredValues_xht41f$(data_0, [Aes$Companion_getInstance().Y])) {\n return this.withEmptyStatValues();\n }var data_1 = data_0;\n if (this.needSampling_za3lpa$(data_1.rowCount())) {\n data_1 = this.applySampling_0(data_1, messageConsumer);\n }var valuesY = data_1.getNumeric_8xm3sj$(TransformVar_getInstance().Y);\n if (valuesY.size < 3) {\n return this.withEmptyStatValues();\n }var valuesX;\n if (data_1.has_8xm3sj$(TransformVar_getInstance().X)) {\n valuesX = data_1.getNumeric_8xm3sj$(TransformVar_getInstance().X);\n } else {\n valuesX = ArrayList_init();\n for (var i = 0; i !== valuesY.size; ++i) {\n valuesX.add_11rb$(i);\n }\n }\n if (data.SeriesUtil.range_l63ks6$(valuesX) == null)\n return this.withEmptyStatValues();\n var statX;\n var statY;\n var statMinY;\n var statMaxY;\n var statSE;\n var statValues = this.applySmoothing_0(valuesX, valuesY);\n statX = ensureNotNull(statValues.get_11rb$(Stats_getInstance().X));\n statY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y));\n statMinY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y_MIN));\n statMaxY = ensureNotNull(statValues.get_11rb$(Stats_getInstance().Y_MAX));\n statSE = ensureNotNull(statValues.get_11rb$(Stats_getInstance().SE));\n var statData = DataFrame$DataFrame$Builder_init().putNumeric_s1rqo9$(Stats_getInstance().X, statX).putNumeric_s1rqo9$(Stats_getInstance().Y, statY);\n if (this.displayConfidenceInterval_0) {\n statData.putNumeric_s1rqo9$(Stats_getInstance().Y_MIN, statMinY).putNumeric_s1rqo9$(Stats_getInstance().Y_MAX, statMaxY).putNumeric_s1rqo9$(Stats_getInstance().SE, statSE);\n }return statData.build();\n };\n SmoothStat.prototype.applySmoothing_0 = function (valuesX, valuesY) {\n var tmp$, tmp$_0, tmp$_1;\n var statX = ArrayList_init();\n var statY = ArrayList_init();\n var statMinY = ArrayList_init();\n var statMaxY = ArrayList_init();\n var statSE = ArrayList_init();\n var result = HashMap_init();\n var key = Stats_getInstance().X;\n result.put_xwzc9p$(key, statX);\n var key_0 = Stats_getInstance().Y;\n result.put_xwzc9p$(key_0, statY);\n var key_1 = Stats_getInstance().Y_MIN;\n result.put_xwzc9p$(key_1, statMinY);\n var key_2 = Stats_getInstance().Y_MAX;\n result.put_xwzc9p$(key_2, statMaxY);\n var key_3 = Stats_getInstance().SE;\n result.put_xwzc9p$(key_3, statSE);\n switch (this.smoothingMethod_0.name) {\n case 'LM':\n if (!(this.polynomialDegree_0 >= 1)) {\n var message = 'Degree of polynomial regression must be at least 1';\n throw IllegalArgumentException_init(message.toString());\n }\n if (this.polynomialDegree_0 === 1) {\n tmp$ = new LinearRegression(valuesX, valuesY, this.confidenceLevel_0);\n } else {\n if (PolynomialRegression$Companion_getInstance().canBeComputed_fgqkrm$(valuesX, valuesY, this.polynomialDegree_0)) {\n tmp$ = new PolynomialRegression(valuesX, valuesY, this.confidenceLevel_0, this.polynomialDegree_0);\n } else {\n return result;\n }\n }\n\n break;\n case 'LOESS':\n var evaluator = new LocalPolynomialRegression(valuesX, valuesY, this.confidenceLevel_0, this.span_0);\n if (evaluator.canCompute) {\n tmp$ = evaluator;\n } else {\n return result;\n }\n\n break;\n default:throw IllegalArgumentException_init('Unsupported smoother method: ' + this.smoothingMethod_0 + \" (only 'lm' and 'loess' methods are currently available)\");\n }\n var regression = tmp$;\n tmp$_0 = data.SeriesUtil.range_l63ks6$(valuesX);\n if (tmp$_0 == null) {\n return result;\n }var rangeX = tmp$_0;\n var startX = rangeX.lowerEnd;\n var spanX = rangeX.upperEnd - startX;\n var stepX = spanX / (this.smootherPointCount_0 - 1 | 0);\n tmp$_1 = this.smootherPointCount_0;\n for (var i = 0; i < tmp$_1; i++) {\n var x = startX + i * stepX;\n var eval_0 = regression.evalX_14dthe$(coerceIn(x, rangeX.lowerEnd, rangeX.upperEnd));\n statX.add_11rb$(x);\n statY.add_11rb$(eval_0.y);\n statMinY.add_11rb$(eval_0.ymin);\n statMaxY.add_11rb$(eval_0.ymax);\n statSE.add_11rb$(eval_0.se);\n }\n return result;\n };\n SmoothStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SmoothStat',\n interfaces: [BaseStat]\n };\n function Stats() {\n Stats_instance = this;\n this.X = new DataFrame$Variable('..x..', DataFrame$Variable$Source$STAT_getInstance(), 'x');\n this.Y = new DataFrame$Variable('..y..', DataFrame$Variable$Source$STAT_getInstance(), 'y');\n this.COUNT = new DataFrame$Variable('..count..', DataFrame$Variable$Source$STAT_getInstance(), 'count');\n this.DENSITY = new DataFrame$Variable('..density..', DataFrame$Variable$Source$STAT_getInstance(), 'density');\n this.Y_MIN = new DataFrame$Variable('..ymin..', DataFrame$Variable$Source$STAT_getInstance(), 'y min');\n this.Y_MAX = new DataFrame$Variable('..ymax..', DataFrame$Variable$Source$STAT_getInstance(), 'y max');\n this.SE = new DataFrame$Variable('..se..', DataFrame$Variable$Source$STAT_getInstance(), 'standard error');\n this.LEVEL = new DataFrame$Variable('..level..', DataFrame$Variable$Source$STAT_getInstance(), 'level');\n this.LOWER = new DataFrame$Variable('..lower..', DataFrame$Variable$Source$STAT_getInstance(), 'lower');\n this.MIDDLE = new DataFrame$Variable('..middle..', DataFrame$Variable$Source$STAT_getInstance(), 'middle');\n this.UPPER = new DataFrame$Variable('..upper..', DataFrame$Variable$Source$STAT_getInstance(), 'upper');\n this.WIDTH = new DataFrame$Variable('..width..', DataFrame$Variable$Source$STAT_getInstance(), 'width');\n this.CORR = new DataFrame$Variable('..corr..', DataFrame$Variable$Source$STAT_getInstance(), 'corr');\n this.CORR_ABS = new DataFrame$Variable('..corr_abs..', DataFrame$Variable$Source$STAT_getInstance(), 'corr_abs');\n this.SCALED = new DataFrame$Variable('..scaled..', DataFrame$Variable$Source$STAT_getInstance(), 'scaled');\n this.GROUP = new DataFrame$Variable('..group..', DataFrame$Variable$Source$STAT_getInstance(), 'group');\n this.IDENTITY = new Stats$IdentityStat();\n var tmp$;\n var variableList = listOf([this.X, this.Y, this.COUNT, this.DENSITY, this.Y_MIN, this.Y_MAX, this.SE, this.LEVEL, this.LOWER, this.MIDDLE, this.UPPER, this.WIDTH, this.SCALED, this.GROUP, this.CORR, this.CORR_ABS]);\n var result = HashMap_init();\n tmp$ = variableList.iterator();\n while (tmp$.hasNext()) {\n var variable = tmp$.next();\n var key = variable.name;\n result.put_xwzc9p$(key, variable);\n }\n this.VARS_0 = result;\n }\n Stats.prototype.isStatVar_61zpoe$ = function (varName) {\n return this.VARS_0.containsKey_11rb$(varName);\n };\n Stats.prototype.statVar_61zpoe$ = function (varName) {\n if (!this.VARS_0.containsKey_11rb$(varName)) {\n var message = 'Unknown stat variable ' + varName;\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.VARS_0.get_11rb$(varName));\n };\n Stats.prototype.defaultMapping_qbwusa$ = function (stat) {\n var tmp$;\n var map = HashMap_init();\n tmp$ = Aes$Companion_getInstance().values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (stat.hasDefaultMapping_896ixz$(aes)) {\n var variable = stat.getDefaultMapping_896ixz$(aes);\n map.put_xwzc9p$(aes, variable);\n }}\n return map;\n };\n Stats.prototype.count = function () {\n return new CountStat();\n };\n Stats.prototype.bin_yyf5ez$ = function (binCount, binWidth, center, boundary) {\n if (binCount === void 0)\n binCount = 30;\n if (binWidth === void 0)\n binWidth = null;\n if (center === void 0)\n center = null;\n if (boundary === void 0)\n boundary = null;\n var xPosKind = BinStat$XPosKind$NONE_getInstance();\n var xPosValue = 0.0;\n if (boundary != null) {\n xPosKind = BinStat$XPosKind$BOUNDARY_getInstance();\n xPosValue = boundary;\n } else if (center != null) {\n xPosKind = BinStat$XPosKind$CENTER_getInstance();\n xPosValue = center;\n }return new BinStat(binCount, binWidth, xPosKind, xPosValue);\n };\n Stats.prototype.smooth_aam2id$ = function (smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed) {\n if (smootherPointCount === void 0)\n smootherPointCount = 80;\n if (smoothingMethod === void 0)\n smoothingMethod = SmoothStat$Companion_getInstance().DEF_SMOOTHING_METHOD;\n if (confidenceLevel === void 0)\n confidenceLevel = SmoothStat$Companion_getInstance().DEF_CONFIDENCE_LEVEL;\n if (displayConfidenceInterval === void 0)\n displayConfidenceInterval = SmoothStat$Companion_getInstance().DEF_DISPLAY_CONFIDENCE_INTERVAL;\n if (span === void 0)\n span = SmoothStat$Companion_getInstance().DEF_SPAN;\n if (polynomialDegree === void 0)\n polynomialDegree = 1;\n if (loessCriticalSize === void 0)\n loessCriticalSize = 1000;\n if (samplingSeed === void 0)\n samplingSeed = SmoothStat$Companion_getInstance().DEF_SAMPLING_SEED;\n return new SmoothStat(smootherPointCount, smoothingMethod, confidenceLevel, displayConfidenceInterval, span, polynomialDegree, loessCriticalSize, samplingSeed);\n };\n Stats.prototype.corr_6cvmjw$ = function (correlationMethod, type, fillDiagonal, threshold) {\n if (correlationMethod === void 0)\n correlationMethod = CorrelationStat$Companion_getInstance().DEF_CORRELATION_METHOD;\n if (type === void 0)\n type = CorrelationStat$Companion_getInstance().DEF_TYPE;\n if (fillDiagonal === void 0)\n fillDiagonal = CorrelationStat$Companion_getInstance().DEF_FILL_DIAGONAL;\n if (threshold === void 0)\n threshold = CorrelationStat$Companion_getInstance().DEF_THRESHOLD;\n return new CorrelationStat(correlationMethod, type, fillDiagonal, threshold);\n };\n Stats.prototype.contour_tvwy6j$ = function (binCount, binWidth) {\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = null;\n return new ContourStat(binCount, binWidth);\n };\n Stats.prototype.contourf_tvwy6j$ = function (binCount, binWidth) {\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = null;\n return new ContourfStat(binCount, binWidth);\n };\n Stats.prototype.boxplot_8555vt$ = function (whiskerIQRRatio, computeWidth) {\n if (whiskerIQRRatio === void 0)\n whiskerIQRRatio = BoxplotStat$Companion_getInstance().DEF_WHISKER_IQR_RATIO;\n if (computeWidth === void 0)\n computeWidth = BoxplotStat$Companion_getInstance().DEF_COMPUTE_WIDTH;\n return new BoxplotStat(whiskerIQRRatio, computeWidth);\n };\n Stats.prototype.density_s1yna4$ = function (bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax) {\n if (bandWidth === void 0)\n bandWidth = null;\n if (bandWidthMethod === void 0)\n bandWidthMethod = DensityStat$Companion_getInstance().DEF_BW;\n if (adjust === void 0)\n adjust = DensityStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = DensityStat$Companion_getInstance().DEF_KERNEL;\n if (n === void 0)\n n = 512;\n if (fullScalMax === void 0)\n fullScalMax = 5000;\n return new DensityStat(bandWidth, bandWidthMethod, adjust, kernel, n, fullScalMax);\n };\n Stats.prototype.density2d_izm592$ = function (bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n if (bandWidthX === void 0)\n bandWidthX = null;\n if (bandWidthY === void 0)\n bandWidthY = null;\n if (bandWidthMethod === void 0)\n bandWidthMethod = AbstractDensity2dStat$Companion_getInstance().DEF_BW;\n if (adjust === void 0)\n adjust = AbstractDensity2dStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = AbstractDensity2dStat$Companion_getInstance().DEF_KERNEL;\n if (nX === void 0)\n nX = 100;\n if (nY === void 0)\n nY = 100;\n if (isContour === void 0)\n isContour = AbstractDensity2dStat$Companion_getInstance().DEF_CONTOUR;\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = AbstractDensity2dStat$Companion_getInstance().DEF_BIN_WIDTH;\n return new Density2dStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n };\n Stats.prototype.density2df_izm592$ = function (bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth) {\n if (bandWidthX === void 0)\n bandWidthX = null;\n if (bandWidthY === void 0)\n bandWidthY = null;\n if (adjust === void 0)\n adjust = AbstractDensity2dStat$Companion_getInstance().DEF_ADJUST;\n if (kernel === void 0)\n kernel = AbstractDensity2dStat$Companion_getInstance().DEF_KERNEL;\n if (nX === void 0)\n nX = 100;\n if (nY === void 0)\n nY = 100;\n if (isContour === void 0)\n isContour = AbstractDensity2dStat$Companion_getInstance().DEF_CONTOUR;\n if (binCount === void 0)\n binCount = 10;\n if (binWidth === void 0)\n binWidth = AbstractDensity2dStat$Companion_getInstance().DEF_BIN_WIDTH;\n return new Density2dfStat(bandWidthX, bandWidthY, bandWidthMethod, adjust, kernel, nX, nY, isContour, binCount, binWidth);\n };\n function Stats$IdentityStat() {\n BaseStat.call(this, emptyMap());\n }\n Stats$IdentityStat.prototype.apply_kdy6bf$$default = function (data, statCtx, messageConsumer) {\n return DataFrame$Builder$Companion_getInstance().emptyFrame();\n };\n Stats$IdentityStat.prototype.consumes = function () {\n return emptyList();\n };\n Stats$IdentityStat.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityStat',\n interfaces: [BaseStat]\n };\n Stats.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Stats',\n interfaces: []\n };\n var Stats_instance = null;\n function Stats_getInstance() {\n if (Stats_instance === null) {\n new Stats();\n }return Stats_instance;\n }\n function AbstractRealDistribution() {\n AbstractRealDistribution$Companion_getInstance();\n this.solverAbsoluteAccuracy_ojqt9g$_0 = AbstractRealDistribution$Companion_getInstance().SOLVER_DEFAULT_ABSOLUTE_ACCURACY;\n }\n Object.defineProperty(AbstractRealDistribution.prototype, 'solverAbsoluteAccuracy', {\n configurable: true,\n get: function () {\n return this.solverAbsoluteAccuracy_ojqt9g$_0;\n }\n });\n AbstractRealDistribution.prototype.cumulativeProbability_lu1900$ = function (x0, x1) {\n if (x0 > x1) {\n throw IllegalStateException_init(('NumberIsTooLarge - x0:' + x0 + ', x1:' + x1).toString());\n }return this.cumulativeProbability_14dthe$(x1) - this.cumulativeProbability_14dthe$(x0);\n };\n function AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral(this$AbstractRealDistribution, closure$p) {\n this.this$AbstractRealDistribution = this$AbstractRealDistribution;\n this.closure$p = closure$p;\n }\n AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral.prototype.value_14dthe$ = function (x) {\n return this.this$AbstractRealDistribution.cumulativeProbability_14dthe$(x) - this.closure$p;\n };\n AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [UnivariateFunction]\n };\n AbstractRealDistribution.prototype.inverseCumulativeProbability_14dthe$ = function (p) {\n if (p < 0.0 || p > 1.0) {\n throw IllegalStateException_init(('OutOfRange [0, 1] - p' + p).toString());\n }var lowerBound = this.supportLowerBound;\n if (p === 0.0) {\n return lowerBound;\n }var upperBound = this.supportUpperBound;\n if (p === 1.0) {\n return upperBound;\n }var mu = this.numericalMean;\n var x = this.numericalVariance;\n var sig = JsMath.sqrt(x);\n var chebyshevApplies;\n chebyshevApplies = !(isInfinite(mu) || isNaN_0(mu) || isInfinite(sig) || isNaN_0(sig));\n if (lowerBound === kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY) {\n if (chebyshevApplies) {\n var x_0 = (1.0 - p) / p;\n lowerBound = mu - sig * JsMath.sqrt(x_0);\n } else {\n lowerBound = -1.0;\n while (this.cumulativeProbability_14dthe$(lowerBound) >= p) {\n lowerBound *= 2.0;\n }\n }\n }if (upperBound === kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY) {\n if (chebyshevApplies) {\n var x_1 = p / (1.0 - p);\n upperBound = mu + sig * JsMath.sqrt(x_1);\n } else {\n upperBound = 1.0;\n while (this.cumulativeProbability_14dthe$(upperBound) < p) {\n upperBound *= 2.0;\n }\n }\n }var toSolve = new AbstractRealDistribution$inverseCumulativeProbability$ObjectLiteral(this, p);\n var x_2 = UnivariateSolverUtils_getInstance().solve_wb66u3$(toSolve, lowerBound, upperBound, this.solverAbsoluteAccuracy);\n if (!this.isSupportConnected) {\n var dx = this.solverAbsoluteAccuracy;\n if (x_2 - dx >= this.supportLowerBound) {\n var px = this.cumulativeProbability_14dthe$(x_2);\n if (this.cumulativeProbability_14dthe$(x_2 - dx) === px) {\n upperBound = x_2;\n while (upperBound - lowerBound > dx) {\n var midPoint = 0.5 * (lowerBound + upperBound);\n if (this.cumulativeProbability_14dthe$(midPoint) < px) {\n lowerBound = midPoint;\n } else {\n upperBound = midPoint;\n }\n }\n return upperBound;\n }}}return x_2;\n };\n function AbstractRealDistribution$Companion() {\n AbstractRealDistribution$Companion_instance = this;\n this.SOLVER_DEFAULT_ABSOLUTE_ACCURACY = 1.0E-6;\n this.serialVersionUID_0 = L_38038050983108802;\n }\n AbstractRealDistribution$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractRealDistribution$Companion_instance = null;\n function AbstractRealDistribution$Companion_getInstance() {\n if (AbstractRealDistribution$Companion_instance === null) {\n new AbstractRealDistribution$Companion();\n }return AbstractRealDistribution$Companion_instance;\n }\n AbstractRealDistribution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractRealDistribution',\n interfaces: [RealDistribution]\n };\n function AbstractUnivariateSolver() {\n }\n AbstractUnivariateSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractUnivariateSolver',\n interfaces: [UnivariateSolver, BaseAbstractUnivariateSolver]\n };\n function AbstractUnivariateSolver_init(absoluteAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver_init(absoluteAccuracy, $this);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AbstractUnivariateSolver_init_0(relativeAccuracy, absoluteAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, relativeAccuracy, absoluteAccuracy);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AbstractUnivariateSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this) {\n $this = $this || Object.create(AbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, relativeAccuracy, absoluteAccuracy, functionValueAccuracy);\n AbstractUnivariateSolver.call($this);\n return $this;\n }\n function AllowedSolution(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function AllowedSolution_initFields() {\n AllowedSolution_initFields = function () {\n };\n AllowedSolution$ANY_SIDE_instance = new AllowedSolution('ANY_SIDE', 0);\n AllowedSolution$LEFT_SIDE_instance = new AllowedSolution('LEFT_SIDE', 1);\n AllowedSolution$RIGHT_SIDE_instance = new AllowedSolution('RIGHT_SIDE', 2);\n AllowedSolution$BELOW_SIDE_instance = new AllowedSolution('BELOW_SIDE', 3);\n AllowedSolution$ABOVE_SIDE_instance = new AllowedSolution('ABOVE_SIDE', 4);\n }\n var AllowedSolution$ANY_SIDE_instance;\n function AllowedSolution$ANY_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$ANY_SIDE_instance;\n }\n var AllowedSolution$LEFT_SIDE_instance;\n function AllowedSolution$LEFT_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$LEFT_SIDE_instance;\n }\n var AllowedSolution$RIGHT_SIDE_instance;\n function AllowedSolution$RIGHT_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$RIGHT_SIDE_instance;\n }\n var AllowedSolution$BELOW_SIDE_instance;\n function AllowedSolution$BELOW_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$BELOW_SIDE_instance;\n }\n var AllowedSolution$ABOVE_SIDE_instance;\n function AllowedSolution$ABOVE_SIDE_getInstance() {\n AllowedSolution_initFields();\n return AllowedSolution$ABOVE_SIDE_instance;\n }\n AllowedSolution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AllowedSolution',\n interfaces: [Enum]\n };\n function AllowedSolution$values() {\n return [AllowedSolution$ANY_SIDE_getInstance(), AllowedSolution$LEFT_SIDE_getInstance(), AllowedSolution$RIGHT_SIDE_getInstance(), AllowedSolution$BELOW_SIDE_getInstance(), AllowedSolution$ABOVE_SIDE_getInstance()];\n }\n AllowedSolution.values = AllowedSolution$values;\n function AllowedSolution$valueOf(name) {\n switch (name) {\n case 'ANY_SIDE':\n return AllowedSolution$ANY_SIDE_getInstance();\n case 'LEFT_SIDE':\n return AllowedSolution$LEFT_SIDE_getInstance();\n case 'RIGHT_SIDE':\n return AllowedSolution$RIGHT_SIDE_getInstance();\n case 'BELOW_SIDE':\n return AllowedSolution$BELOW_SIDE_getInstance();\n case 'ABOVE_SIDE':\n return AllowedSolution$ABOVE_SIDE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.math3.AllowedSolution.' + name);\n }\n }\n AllowedSolution.valueOf_61zpoe$ = AllowedSolution$valueOf;\n function BaseAbstractUnivariateSolver(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n BaseAbstractUnivariateSolver$Companion_getInstance();\n if (functionValueAccuracy === void 0)\n functionValueAccuracy = BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_FUNCTION_VALUE_ACCURACY_0;\n this.relativeAccuracy_uztt24$_0 = relativeAccuracy;\n this.absoluteAccuracy_8af9zt$_0 = absoluteAccuracy;\n this.functionValueAccuracy_drq8h3$_0 = functionValueAccuracy;\n this.myEvaluations_xyk8ps$_0 = new Incrementor();\n this.min_3rehp5$_0 = 0;\n this.max_3rec07$_0 = 0;\n this.startValue_pn384a$_0 = 0;\n this.function_54gwsx$_0 = null;\n this.evaluations_io7904$_0 = this.myEvaluations_xyk8ps$_0.count;\n }\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'relativeAccuracy', {\n get: function () {\n return this.relativeAccuracy_uztt24$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'absoluteAccuracy', {\n get: function () {\n return this.absoluteAccuracy_8af9zt$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'functionValueAccuracy', {\n get: function () {\n return this.functionValueAccuracy_drq8h3$_0;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'min', {\n configurable: true,\n get: function () {\n return this.min_3rehp5$_0;\n },\n set: function (min) {\n this.min_3rehp5$_0 = min;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'max', {\n configurable: true,\n get: function () {\n return this.max_3rec07$_0;\n },\n set: function (max) {\n this.max_3rec07$_0 = max;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'startValue', {\n configurable: true,\n get: function () {\n return this.startValue_pn384a$_0;\n },\n set: function (startValue) {\n this.startValue_pn384a$_0 = startValue;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'maxEvaluations', {\n configurable: true,\n get: function () {\n return this.myEvaluations_xyk8ps$_0.maximalCount;\n }\n });\n Object.defineProperty(BaseAbstractUnivariateSolver.prototype, 'evaluations', {\n configurable: true,\n get: function () {\n return this.evaluations_io7904$_0;\n }\n });\n BaseAbstractUnivariateSolver.prototype.computeObjectiveValue_14dthe$ = function (point) {\n this.incrementEvaluationCount();\n return ensureNotNull(this.function_54gwsx$_0).value_14dthe$(point);\n };\n BaseAbstractUnivariateSolver.prototype.setup_4y3h91$ = function (maxEval, f, min, max, startValue) {\n this.min = min;\n this.max = max;\n this.startValue = startValue;\n this.function_54gwsx$_0 = f;\n this.myEvaluations_xyk8ps$_0.maximalCount = maxEval;\n this.myEvaluations_xyk8ps$_0.resetCount();\n };\n BaseAbstractUnivariateSolver.prototype.solve_4y3h91$ = function (maxEval, f, min, max, startValue) {\n this.setup_4y3h91$(maxEval, f, min, max, startValue);\n return this.doSolve();\n };\n BaseAbstractUnivariateSolver.prototype.solve_rmnly1$ = function (maxEval, f, min, max) {\n return this.solve_4y3h91$(maxEval, f, min, max, min + 0.5 * (max - min));\n };\n BaseAbstractUnivariateSolver.prototype.solve_t5uqbd$ = function (maxEval, f, startValue) {\n return this.solve_4y3h91$(maxEval, f, kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN, startValue);\n };\n BaseAbstractUnivariateSolver.prototype.isBracketing_lu1900$ = function (lower, upper) {\n return UnivariateSolverUtils_getInstance().isBracketing_ljmp9$(ensureNotNull(this.function_54gwsx$_0), lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.isSequence_yvo9jy$ = function (start, mid, end) {\n return UnivariateSolverUtils_getInstance().isSequence_yvo9jy$(start, mid, end);\n };\n BaseAbstractUnivariateSolver.prototype.verifyInterval_lu1900$ = function (lower, upper) {\n UnivariateSolverUtils_getInstance().verifyInterval_lu1900$(lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.verifySequence_yvo9jy$ = function (lower, initial, upper) {\n UnivariateSolverUtils_getInstance().verifySequence_yvo9jy$(lower, initial, upper);\n };\n BaseAbstractUnivariateSolver.prototype.verifyBracketing_lu1900$ = function (lower, upper) {\n UnivariateSolverUtils_getInstance().verifyBracketing_ljmp9$(ensureNotNull(this.function_54gwsx$_0), lower, upper);\n };\n BaseAbstractUnivariateSolver.prototype.incrementEvaluationCount = function () {\n this.myEvaluations_xyk8ps$_0.incrementCount();\n };\n function BaseAbstractUnivariateSolver$Companion() {\n BaseAbstractUnivariateSolver$Companion_instance = this;\n this.DEFAULT_RELATIVE_ACCURACY_0 = 1.0E-14;\n this.DEFAULT_FUNCTION_VALUE_ACCURACY_0 = 1.0E-15;\n }\n BaseAbstractUnivariateSolver$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BaseAbstractUnivariateSolver$Companion_instance = null;\n function BaseAbstractUnivariateSolver$Companion_getInstance() {\n if (BaseAbstractUnivariateSolver$Companion_instance === null) {\n new BaseAbstractUnivariateSolver$Companion();\n }return BaseAbstractUnivariateSolver$Companion_instance;\n }\n BaseAbstractUnivariateSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BaseAbstractUnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function BaseAbstractUnivariateSolver_init(absoluteAccuracy, $this) {\n $this = $this || Object.create(BaseAbstractUnivariateSolver.prototype);\n BaseAbstractUnivariateSolver.call($this, BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_RELATIVE_ACCURACY_0, absoluteAccuracy, BaseAbstractUnivariateSolver$Companion_getInstance().DEFAULT_FUNCTION_VALUE_ACCURACY_0);\n return $this;\n }\n function BaseUnivariateSolver() {\n }\n BaseUnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BaseUnivariateSolver',\n interfaces: []\n };\n function Beta() {\n Beta_instance = this;\n this.DEFAULT_EPSILON_0 = 1.0E-14;\n }\n Beta.prototype.regularizedBeta_88ee24$ = function (x, a, b, maxIterations) {\n return this.regularizedBeta_tychlm$(x, a, b, this.DEFAULT_EPSILON_0, maxIterations);\n };\n function Beta$regularizedBeta$ObjectLiteral(closure$b, closure$a) {\n this.closure$b = closure$b;\n this.closure$a = closure$a;\n ContinuedFraction.call(this);\n }\n Beta$regularizedBeta$ObjectLiteral.prototype.getB_5wr77w$ = function (n, x) {\n var ret;\n var m;\n if (n % 2 === 0) {\n m = n / 2.0;\n ret = m * (this.closure$b - m) * x / ((this.closure$a + 2 * m - 1) * (this.closure$a + 2 * m));\n } else {\n m = (n - 1.0) / 2.0;\n ret = -((this.closure$a + m) * (this.closure$a + this.closure$b + m) * x) / ((this.closure$a + 2 * m) * (this.closure$a + 2 * m + 1.0));\n }\n return ret;\n };\n Beta$regularizedBeta$ObjectLiteral.prototype.getA_5wr77w$ = function (n, x) {\n return 1.0;\n };\n Beta$regularizedBeta$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContinuedFraction]\n };\n Beta.prototype.regularizedBeta_tychlm$ = function (x, a, b, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(x) || isNaN_0(a) || isNaN_0(b) || x < 0 || x > 1 || a <= 0.0 || b <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x > (a + 1.0) / (a + b + 2.0)) {\n ret = 1.0 - this.regularizedBeta_tychlm$(1.0 - x, b, a, epsilon, maxIterations);\n } else {\n var fraction = new Beta$regularizedBeta$ObjectLiteral(b, a);\n var tmp$ = a * JsMath.log(x);\n var x_0 = 1.0 - x;\n var x_1 = tmp$ + b * JsMath.log(x_0) - JsMath.log(a) - this.logBeta_88ee24$(a, b, epsilon, maxIterations);\n ret = JsMath.exp(x_1) * 1.0 / fraction.evaluate_syxxoe$(x, epsilon, maxIterations);\n }\n return ret;\n };\n Beta.prototype.logBeta_88ee24$ = function (a, b, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(b) || a <= 0.0 || b <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else {\n ret = Gamma_getInstance().logGamma_14dthe$(a) + Gamma_getInstance().logGamma_14dthe$(b) - Gamma_getInstance().logGamma_14dthe$(a + b);\n }\n return ret;\n };\n Beta.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Beta',\n interfaces: []\n };\n var Beta_instance = null;\n function Beta_getInstance() {\n if (Beta_instance === null) {\n new Beta();\n }return Beta_instance;\n }\n function BlockRealMatrix() {\n this.BLOCK_SIZE_0 = 52;\n this.rows_0 = 0;\n this.columns_0 = 0;\n this.blockRows_0 = 0;\n this.blockColumns_0 = 0;\n this.blocks_4giiw5$_0 = this.blocks_4giiw5$_0;\n }\n Object.defineProperty(BlockRealMatrix.prototype, 'blocks_0', {\n configurable: true,\n get: function () {\n if (this.blocks_4giiw5$_0 == null)\n return throwUPAE('blocks');\n return this.blocks_4giiw5$_0;\n },\n set: function (blocks) {\n this.blocks_4giiw5$_0 = blocks;\n }\n });\n BlockRealMatrix.prototype.create_omvvzo$ = function (rows, columns, blockData, copyArray) {\n var tmp$;\n this.rows_0 = rows;\n this.columns_0 = columns;\n this.blockRows_0 = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n this.blockColumns_0 = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blocksCopyList = ArrayList_init();\n if (!copyArray) {\n this.blocks_0 = blockData;\n }var index = 0;\n tmp$ = this.blockRows_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n var iHeight = this.blockHeight_0(iBlock);\n var jBlock = 0;\n while (jBlock < this.blockColumns_0) {\n if (blockData[index].length !== Kotlin.imul(iHeight, this.blockWidth_0(jBlock))) {\n throw IllegalStateException_init(''.toString());\n }if (copyArray) {\n blocksCopyList.add_11rb$(blockData[index].slice());\n }jBlock = jBlock + 1 | 0;\n index = index + 1 | 0;\n }\n }\n if (copyArray) {\n this.blocks_0 = copyToArray(blocksCopyList);\n }};\n BlockRealMatrix.prototype.createBlocksLayout_0 = function (rows, columns) {\n var blockRows = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blockColumns = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blocksList = ArrayList_init();\n var blockIndex = 0;\n for (var iBlock = 0; iBlock < blockRows; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var pEnd = JsMath.min(a, rows);\n var iHeight = pEnd - pStart | 0;\n for (var jBlock = 0; jBlock < blockColumns; jBlock++) {\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var qEnd = JsMath.min(a_0, columns);\n var jWidth = qEnd - qStart | 0;\n blocksList.add_11rb$(new Float64Array(Kotlin.imul(iHeight, jWidth)));\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return copyToArray(blocksList);\n };\n BlockRealMatrix.prototype.transpose = function () {\n var tmp$, tmp$_0;\n var nRows = this.getRowDimension_0();\n var nCols = this.getColumnDimension_0();\n var out = BlockRealMatrix_init(nCols, nRows);\n var blockIndex = 0;\n tmp$ = this.blockColumns_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n tmp$_0 = this.blockRows_0;\n for (var jBlock = 0; jBlock < tmp$_0; jBlock++) {\n var outBlock = out.blocks_0[blockIndex];\n var tBlock = this.blocks_0[Kotlin.imul(jBlock, this.blockColumns_0) + iBlock | 0];\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var b = this.columns_0;\n var pEnd = JsMath.min(a, b);\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var b_0 = this.rows_0;\n var qEnd = JsMath.min(a_0, b_0);\n var k = 0;\n for (var p = pStart; p < pEnd; p++) {\n var lInc = pEnd - pStart | 0;\n var l = p - pStart | 0;\n for (var q = qStart; q < qEnd; q++) {\n outBlock[k] = tBlock[l];\n k = k + 1 | 0;\n l = l + lInc | 0;\n }\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return out;\n };\n BlockRealMatrix.prototype.multiply_1dlv11$ = function (m) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (this.getColumnDimension_0() !== m.getRowDimension_0()) {\n throw IllegalStateException_init(('Matrix multiply dimension mismatch: ' + this.getColumnDimension_0() + ' x ' + m.getRowDimension_0()).toString());\n }var out = BlockRealMatrix_init(this.rows_0, m.columns_0);\n var blockIndex = 0;\n tmp$ = out.blockRows_0;\n for (var iBlock = 0; iBlock < tmp$; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var b = this.rows_0;\n var pEnd = JsMath.min(a, b);\n tmp$_0 = out.blockColumns_0;\n for (var jBlock = 0; jBlock < tmp$_0; jBlock++) {\n var jWidth = out.blockWidth_0(jBlock);\n var jWidth2 = jWidth + jWidth | 0;\n var jWidth3 = jWidth2 + jWidth | 0;\n var jWidth4 = jWidth3 + jWidth | 0;\n var outBlock = out.blocks_0[blockIndex];\n tmp$_1 = this.blockColumns_0;\n for (var kBlock = 0; kBlock < tmp$_1; kBlock++) {\n var kWidth = this.blockWidth_0(kBlock);\n var tBlock = this.blocks_0[Kotlin.imul(iBlock, this.blockColumns_0) + kBlock | 0];\n var mBlock = m.blocks_0[Kotlin.imul(kBlock, m.blockColumns_0) + jBlock | 0];\n var k = 0;\n for (var p = pStart; p < pEnd; p++) {\n var lStart = Kotlin.imul(p - pStart | 0, kWidth);\n var lEnd = lStart + kWidth | 0;\n for (var nStart = 0; nStart < jWidth; nStart++) {\n var sum = 0.0;\n var l = lStart;\n var n = nStart;\n while (l < (lEnd - 3 | 0)) {\n sum += tBlock[l] * mBlock[n] + tBlock[l + 1 | 0] * mBlock[n + jWidth | 0] + tBlock[l + 2 | 0] * mBlock[n + jWidth2 | 0] + tBlock[l + 3 | 0] * mBlock[n + jWidth3 | 0];\n l = l + 4 | 0;\n n = n + jWidth4 | 0;\n }\n while (l < lEnd) {\n sum = sum + tBlock[tmp$_2 = l, l = tmp$_2 + 1 | 0, tmp$_2] * mBlock[n];\n n = n + jWidth | 0;\n }\n outBlock[k] = outBlock[k] + sum;\n k = k + 1 | 0;\n }\n }\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return out;\n };\n BlockRealMatrix.prototype.getEntry_vux9f0$ = function (row, column) {\n if (row < 0 || row > this.getRowDimension_0()) {\n throw IllegalStateException_init(('row out of range: ' + row).toString());\n }if (column < 0 || column > this.getColumnDimension_0()) {\n throw IllegalStateException_init(('column out of range: ' + column).toString());\n }var iBlock = row / this.BLOCK_SIZE_0 | 0;\n var jBlock = column / this.BLOCK_SIZE_0 | 0;\n var k = Kotlin.imul(row - Kotlin.imul(iBlock, this.BLOCK_SIZE_0) | 0, this.blockWidth_0(jBlock)) + (column - Kotlin.imul(jBlock, this.BLOCK_SIZE_0)) | 0;\n return this.blocks_0[Kotlin.imul(iBlock, this.blockColumns_0) + jBlock | 0][k];\n };\n BlockRealMatrix.prototype.getRowDimension_0 = function () {\n return this.rows_0;\n };\n BlockRealMatrix.prototype.getColumnDimension_0 = function () {\n return this.columns_0;\n };\n BlockRealMatrix.prototype.blockWidth_0 = function (blockColumn) {\n return blockColumn === (this.blockColumns_0 - 1 | 0) ? this.columns_0 - Kotlin.imul(blockColumn, this.BLOCK_SIZE_0) | 0 : this.BLOCK_SIZE_0;\n };\n BlockRealMatrix.prototype.blockHeight_0 = function (blockRow) {\n return blockRow === (this.blockRows_0 - 1 | 0) ? this.rows_0 - Kotlin.imul(blockRow, this.BLOCK_SIZE_0) | 0 : this.BLOCK_SIZE_0;\n };\n BlockRealMatrix.prototype.toBlocksLayout_n8oub7$ = function (rawData) {\n var rows = rawData.length;\n var columns = rawData[0].length;\n var blockRows = (rows + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n var blockColumns = (columns + this.BLOCK_SIZE_0 - 1 | 0) / this.BLOCK_SIZE_0 | 0;\n for (var i = 0; i !== rawData.length; ++i) {\n var length = rawData[i].length;\n if (length !== columns) {\n throw IllegalStateException_init(('Wrong dimension: ' + columns + ', ' + length).toString());\n }}\n var blocksList = ArrayList_init();\n var blockIndex = 0;\n for (var iBlock = 0; iBlock < blockRows; iBlock++) {\n var pStart = Kotlin.imul(iBlock, this.BLOCK_SIZE_0);\n var a = pStart + this.BLOCK_SIZE_0 | 0;\n var pEnd = JsMath.min(a, rows);\n var iHeight = pEnd - pStart | 0;\n for (var jBlock = 0; jBlock < blockColumns; jBlock++) {\n var qStart = Kotlin.imul(jBlock, this.BLOCK_SIZE_0);\n var a_0 = qStart + this.BLOCK_SIZE_0 | 0;\n var qEnd = JsMath.min(a_0, columns);\n var jWidth = qEnd - qStart | 0;\n var block = new Float64Array(Kotlin.imul(iHeight, jWidth));\n blocksList.add_11rb$(block);\n var index = 0;\n for (var p = pStart; p < pEnd; p++) {\n arrayCopy(rawData[p], block, index, qStart, qEnd);\n index = index + jWidth | 0;\n }\n blockIndex = blockIndex + 1 | 0;\n }\n }\n return copyToArray(blocksList);\n };\n BlockRealMatrix.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BlockRealMatrix',\n interfaces: []\n };\n function BlockRealMatrix_init(rows, columns, $this) {\n $this = $this || Object.create(BlockRealMatrix.prototype);\n BlockRealMatrix.call($this);\n $this.rows_0 = rows;\n $this.columns_0 = columns;\n $this.blockRows_0 = (rows + $this.BLOCK_SIZE_0 - 1 | 0) / $this.BLOCK_SIZE_0 | 0;\n $this.blockColumns_0 = (columns + $this.BLOCK_SIZE_0 - 1 | 0) / $this.BLOCK_SIZE_0 | 0;\n $this.blocks_0 = $this.createBlocksLayout_0(rows, columns);\n return $this;\n }\n function BlockRealMatrix_init_0(rawData, $this) {\n $this = $this || Object.create(BlockRealMatrix.prototype);\n BlockRealMatrix.call($this);\n $this.create_omvvzo$(rawData.length, rawData[0].length, $this.toBlocksLayout_n8oub7$(rawData), false);\n return $this;\n }\n function BracketedUnivariateSolver() {\n }\n BracketedUnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'BracketedUnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function BrentSolver() {\n BrentSolver$Companion_getInstance();\n }\n BrentSolver.prototype.doSolve = function () {\n var min = this.min;\n var max = this.max;\n var initial = this.startValue;\n var functionValueAccuracy = this.functionValueAccuracy;\n this.verifySequence_yvo9jy$(min, initial, max);\n var yInitial = this.computeObjectiveValue_14dthe$(initial);\n if (JsMath.abs(yInitial) <= functionValueAccuracy) {\n return initial;\n }var yMin = this.computeObjectiveValue_14dthe$(min);\n if (JsMath.abs(yMin) <= functionValueAccuracy) {\n return min;\n }if (yInitial * yMin < 0) {\n return this.brent_0(min, initial, yMin, yInitial);\n }var yMax = this.computeObjectiveValue_14dthe$(max);\n if (JsMath.abs(yMax) <= functionValueAccuracy) {\n return max;\n }if (yInitial * yMax < 0) {\n return this.brent_0(initial, max, yInitial, yMax);\n }throw IllegalStateException_init(('NoBracketing - min: ' + min + ', max: ' + max + ', yMin: ' + yMin + ', yMax: ' + yMax).toString());\n };\n BrentSolver.prototype.brent_0 = function (lo, hi, fLo, fHi) {\n var a = lo;\n var fa = fLo;\n var b = hi;\n var fb = fHi;\n var c = a;\n var fc = fa;\n var d = b - a;\n var e = d;\n var t = this.absoluteAccuracy;\n var eps = this.relativeAccuracy;\n while (true) {\n var x = fc;\n var tmp$ = JsMath.abs(x);\n var x_0 = fb;\n if (tmp$ < JsMath.abs(x_0)) {\n a = b;\n b = c;\n c = a;\n fa = fb;\n fb = fc;\n fc = fa;\n }var tmp$_0 = 2.0 * eps;\n var x_1 = b;\n var tol = tmp$_0 * JsMath.abs(x_1) + t;\n var m = 0.5 * (c - b);\n if (JsMath.abs(m) <= tol || Precision_getInstance().equals_syxxoe$(fb, 0.0)) {\n return b;\n }var x_2 = e;\n var tmp$_1 = JsMath.abs(x_2) < tol;\n if (!tmp$_1) {\n var x_3 = fa;\n var tmp$_2 = JsMath.abs(x_3);\n var x_4 = fb;\n tmp$_1 = tmp$_2 <= JsMath.abs(x_4);\n }if (tmp$_1) {\n d = m;\n e = d;\n } else {\n var s = fb / fa;\n var p;\n var q;\n if (a === c) {\n p = 2.0 * m * s;\n q = 1 - s;\n } else {\n q = fa / fc;\n var r = fb / fc;\n p = s * (2.0 * m * q * (q - r) - (b - a) * (r - 1));\n q = (q - 1) * (r - 1) * (s - 1);\n }\n if (p > 0) {\n q = -q;\n } else {\n p = -p;\n }\n s = e;\n e = d;\n var tmp$_3 = p;\n var tmp$_4 = 1.5 * m * q;\n var x_5 = tol * q;\n var tmp$_5 = tmp$_3 >= tmp$_4 - JsMath.abs(x_5);\n if (!tmp$_5) {\n var tmp$_6 = p;\n var x_6 = 0.5 * s * q;\n tmp$_5 = tmp$_6 >= JsMath.abs(x_6);\n }if (tmp$_5) {\n d = m;\n e = d;\n } else {\n d = p / q;\n }\n }\n a = b;\n fa = fb;\n var x_7 = d;\n if (JsMath.abs(x_7) > tol) {\n b += d;\n } else if (m > 0) {\n b += tol;\n } else {\n b -= tol;\n }\n fb = this.computeObjectiveValue_14dthe$(b);\n if (fb > 0 && fc > 0 || (fb <= 0 && fc <= 0)) {\n c = a;\n fc = fa;\n d = b - a;\n e = d;\n }}\n };\n function BrentSolver$Companion() {\n BrentSolver$Companion_instance = this;\n this.DEFAULT_ABSOLUTE_ACCURACY_0 = 1.0E-6;\n }\n BrentSolver$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var BrentSolver$Companion_instance = null;\n function BrentSolver$Companion_getInstance() {\n if (BrentSolver$Companion_instance === null) {\n new BrentSolver$Companion();\n }return BrentSolver$Companion_instance;\n }\n BrentSolver.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BrentSolver',\n interfaces: [AbstractUnivariateSolver]\n };\n function BrentSolver_init(absoluteAccuracy, $this) {\n if (absoluteAccuracy === void 0)\n absoluteAccuracy = BrentSolver$Companion_getInstance().DEFAULT_ABSOLUTE_ACCURACY_0;\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init(absoluteAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function BrentSolver_init_0(relativeAccuracy, absoluteAccuracy, $this) {\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init_0(relativeAccuracy, absoluteAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function BrentSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this) {\n $this = $this || Object.create(BrentSolver.prototype);\n AbstractUnivariateSolver_init_1(relativeAccuracy, absoluteAccuracy, functionValueAccuracy, $this);\n BrentSolver.call($this);\n return $this;\n }\n function ContinuedFraction() {\n ContinuedFraction$Companion_getInstance();\n }\n ContinuedFraction.prototype.evaluate_12fank$ = function (x, maxIterations) {\n return this.evaluate_syxxoe$(x, ContinuedFraction$Companion_getInstance().DEFAULT_EPSILON_0, maxIterations);\n };\n ContinuedFraction.prototype.evaluate_syxxoe$ = function (x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = ContinuedFraction$Companion_getInstance().DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var p0 = 1.0;\n var p1 = this.getA_5wr77w$(0, x);\n var q0 = 0.0;\n var q1 = 1.0;\n var c = p1 / q1;\n var n = 0;\n var relativeError = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n while (n < maxIterations && relativeError > epsilon) {\n n = n + 1 | 0;\n var a = this.getA_5wr77w$(n, x);\n var b = this.getB_5wr77w$(n, x);\n var p2 = a * p1 + b * p0;\n var q2 = a * q1 + b * q0;\n var infinite = false;\n if (isInfinite(p2) || isInfinite(q2)) {\n var scaleFactor = 1.0;\n var lastScaleFactor = 1.0;\n var maxPower = 5;\n var scale = JsMath.max(a, b);\n if (scale <= 0) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }infinite = true;\n for (var i = 0; i < maxPower; i++) {\n lastScaleFactor = scaleFactor;\n scaleFactor *= scale;\n if (a !== 0.0 && a > b) {\n p2 = p1 / lastScaleFactor + b / scaleFactor * p0;\n q2 = q1 / lastScaleFactor + b / scaleFactor * q0;\n } else if (b !== 0.0) {\n p2 = a / scaleFactor * p1 + p0 / lastScaleFactor;\n q2 = a / scaleFactor * q1 + q0 / lastScaleFactor;\n }infinite = isInfinite(p2) || isInfinite(q2);\n if (!infinite) {\n break;\n }}\n }if (infinite) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }var r = p2 / q2;\n if (isNaN_0(r)) {\n throw IllegalStateException_init('ConvergenceException'.toString());\n }var x_0 = r / c - 1.0;\n relativeError = JsMath.abs(x_0);\n c = p2 / q2;\n p0 = p1;\n p1 = p2;\n q0 = q1;\n q1 = q2;\n }\n if (n >= maxIterations) {\n throw IllegalStateException_init('MaxCountExceeded'.toString());\n }return c;\n };\n function ContinuedFraction$Companion() {\n ContinuedFraction$Companion_instance = this;\n this.DEFAULT_EPSILON_0 = 1.0E-8;\n }\n ContinuedFraction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContinuedFraction$Companion_instance = null;\n function ContinuedFraction$Companion_getInstance() {\n if (ContinuedFraction$Companion_instance === null) {\n new ContinuedFraction$Companion();\n }return ContinuedFraction$Companion_instance;\n }\n ContinuedFraction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuedFraction',\n interfaces: []\n };\n function mean(xs) {\n return average(xs);\n }\n function correlationPearson(xs, ys) {\n if (!(xs.length === ys.length)) {\n var message = 'Two series must have the same size.';\n throw IllegalArgumentException_init(message.toString());\n }if (!!(xs.length === 0)) {\n var message_0 = \"Can't correlate empty sequences.\";\n throw IllegalArgumentException_init(message_0.toString());\n }var mx = mean(xs);\n var my = mean(ys);\n var cov = 0.0;\n var d2x = 0.0;\n var d2y = 0.0;\n for (var i = 0; i !== xs.length; ++i) {\n var dx = xs[i] - mx;\n var dy = ys[i] - my;\n cov += dx * dy;\n d2x += JsMath.pow(dx, 2);\n d2y += JsMath.pow(dy, 2);\n }\n if (!(d2x !== 0.0 && d2y !== 0.0)) {\n var message_1 = 'Correlation is not defined for sequences with zero variation.';\n throw IllegalArgumentException_init(message_1.toString());\n }var x = d2x * d2y;\n return cov / JsMath.sqrt(x);\n }\n function ForsythePolynomialGenerator(knots) {\n ForsythePolynomialGenerator$Companion_getInstance();\n this.knots_0 = knots;\n this.ps_0 = null;\n if (!!(this.knots_0.length === 0)) {\n var message = 'The knots list must not be empty';\n throw IllegalArgumentException_init(message.toString());\n }this.ps_0 = arrayListOf([new PolynomialFunction(new Float64Array([1.0])), new PolynomialFunction(new Float64Array([-average(this.knots_0), 1.0]))]);\n }\n ForsythePolynomialGenerator.prototype.alphaBeta_0 = function (i) {\n var tmp$, tmp$_0;\n if (!(i === this.ps_0.size)) {\n var message = 'Alpha must be calculated sequentially.';\n throw IllegalArgumentException_init(message.toString());\n }var p = last(this.ps_0);\n var pp = this.ps_0.get_za3lpa$(this.ps_0.size - 2 | 0);\n var sxp = 0.0;\n var sp2 = 0.0;\n var spp2 = 0.0;\n tmp$ = this.knots_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var x = tmp$[tmp$_0];\n var $receiver = p.value_14dthe$(x);\n var pv2 = JsMath.pow($receiver, 2);\n var $receiver_0 = pp.value_14dthe$(x);\n var ppv2 = JsMath.pow($receiver_0, 2);\n sxp += x * pv2;\n sp2 += pv2;\n spp2 += ppv2;\n }\n return new Pair_0(sxp / sp2, sp2 / spp2);\n };\n ForsythePolynomialGenerator.prototype.getPolynomial_za3lpa$ = function (n) {\n var tmp$;\n if (!(n >= 0)) {\n var message = 'Degree of Forsythe polynomial must not be negative';\n throw IllegalArgumentException_init(message.toString());\n }if (!(n < this.knots_0.length)) {\n var message_0 = 'Degree of Forsythe polynomial must not exceed knots.size - 1';\n throw IllegalArgumentException_init(message_0.toString());\n }if (n >= this.ps_0.size) {\n var sz = this.ps_0.size;\n tmp$ = n + 1 | 0;\n for (var k = sz; k <= tmp$; k++) {\n var tmp$_0 = this.alphaBeta_0(k);\n var a = tmp$_0.component1()\n , b = tmp$_0.component2();\n var pPrev = last(this.ps_0);\n var pPrevPrev = this.ps_0.get_za3lpa$(this.ps_0.size - 2 | 0);\n var p = ForsythePolynomialGenerator$Companion_getInstance().X.times_3j0b7h$(pPrev).minus_3j0b7h$(times(a, pPrev)).minus_3j0b7h$(times(b, pPrevPrev));\n this.ps_0.add_11rb$(p);\n }\n }return this.ps_0.get_za3lpa$(n);\n };\n function ForsythePolynomialGenerator$Companion() {\n ForsythePolynomialGenerator$Companion_instance = this;\n this.X = new PolynomialFunction(new Float64Array([0.0, 1.0]));\n }\n ForsythePolynomialGenerator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ForsythePolynomialGenerator$Companion_instance = null;\n function ForsythePolynomialGenerator$Companion_getInstance() {\n if (ForsythePolynomialGenerator$Companion_instance === null) {\n new ForsythePolynomialGenerator$Companion();\n }return ForsythePolynomialGenerator$Companion_instance;\n }\n ForsythePolynomialGenerator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ForsythePolynomialGenerator',\n interfaces: []\n };\n function Gamma() {\n Gamma_instance = this;\n this.GAMMA = 0.5772156649015329;\n this.DEFAULT_EPSILON_0 = 1.0E-14;\n this.LANCZOS_0 = new Float64Array([0.9999999999999971, 57.15623566586292, -59.59796035547549, 14.136097974741746, -0.4919138160976202, 3.399464998481189E-5, 4.652362892704858E-5, -9.837447530487956E-5, 1.580887032249125E-4, -2.1026444172410488E-4, 2.1743961811521265E-4, -1.643181065367639E-4, 8.441822398385275E-5, -2.6190838401581408E-5, 3.6899182659531625E-6]);\n var x = 2.0 * math.PI;\n this.HALF_LOG_2_PI_0 = 0.5 * JsMath.log(x);\n this.C_LIMIT_0 = 49.0;\n this.S_LIMIT_0 = 1.0E-5;\n }\n Gamma.prototype.logGamma_14dthe$ = function (x) {\n var ret;\n if (isNaN_0(x) || x <= 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else {\n var g = 607.0 / 128.0;\n var sum = 0.0;\n for (var i = this.LANCZOS_0.length - 1 | 0; i >= 1; i--) {\n sum = sum + this.LANCZOS_0[i] / (x + i);\n }\n sum = sum + this.LANCZOS_0[0];\n var tmp = x + g + 0.5;\n var tmp$ = (x + 0.5) * JsMath.log(tmp) - tmp + this.HALF_LOG_2_PI_0;\n var x_0 = sum / x;\n ret = tmp$ + JsMath.log(x_0);\n }\n return ret;\n };\n Gamma.prototype.regularizedGammaP_88ee24$ = function (a, x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(x) || a <= 0.0 || x < 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x === 0.0) {\n ret = 0.0;\n } else if (x >= a + 1) {\n ret = 1.0 - this.regularizedGammaQ_88ee24$(a, x, epsilon, maxIterations);\n } else {\n var n = 0.0;\n var an = 1.0 / a;\n var sum = an;\n while (true) {\n var x_0 = an / sum;\n if (!(JsMath.abs(x_0) > epsilon && n < maxIterations && sum < kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY))\n break;\n n = n + 1.0;\n an = an * (x / (a + n));\n sum = sum + an;\n }\n if (n >= maxIterations) {\n throw IllegalStateException_init(('MaxCountExceeded - maxIterations: ' + maxIterations).toString());\n } else if (isInfinite(sum)) {\n ret = 1.0;\n } else {\n var x_1 = -x + a * JsMath.log(x) - this.logGamma_14dthe$(a);\n ret = JsMath.exp(x_1) * sum;\n }\n }\n return ret;\n };\n function Gamma$regularizedGammaQ$ObjectLiteral(closure$a) {\n this.closure$a = closure$a;\n ContinuedFraction.call(this);\n }\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.getA_5wr77w$ = function (n, x) {\n return 2.0 * n + 1.0 - this.closure$a + x;\n };\n Gamma$regularizedGammaQ$ObjectLiteral.prototype.getB_5wr77w$ = function (n, x) {\n return n * (this.closure$a - n);\n };\n Gamma$regularizedGammaQ$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContinuedFraction]\n };\n Gamma.prototype.regularizedGammaQ_88ee24$ = function (a, x, epsilon, maxIterations) {\n if (epsilon === void 0)\n epsilon = this.DEFAULT_EPSILON_0;\n if (maxIterations === void 0)\n maxIterations = 2147483647;\n var ret;\n if (isNaN_0(a) || isNaN_0(x) || a <= 0.0 || x < 0.0) {\n ret = kotlin_js_internal_DoubleCompanionObject.NaN;\n } else if (x === 0.0) {\n ret = 1.0;\n } else if (x < a + 1.0) {\n ret = 1.0 - this.regularizedGammaP_88ee24$(a, x, epsilon, maxIterations);\n } else {\n var cf = new Gamma$regularizedGammaQ$ObjectLiteral(a);\n ret = 1.0 / cf.evaluate_syxxoe$(x, epsilon, maxIterations);\n var x_0 = -x + a * JsMath.log(x) - this.logGamma_14dthe$(a);\n ret = JsMath.exp(x_0) * ret;\n }\n return ret;\n };\n Gamma.prototype.digamma_14dthe$ = function (x) {\n if (x > 0 && x <= this.S_LIMIT_0) {\n return -this.GAMMA - 1 / x;\n }if (x >= this.C_LIMIT_0) {\n var inv = 1 / (x * x);\n return JsMath.log(x) - 0.5 / x - inv * (1.0 / 12 + inv * (1.0 / 120 - inv / 252));\n }return this.digamma_14dthe$(x + 1) - 1 / x;\n };\n Gamma.prototype.trigamma_14dthe$ = function (x) {\n if (x > 0 && x <= this.S_LIMIT_0) {\n return 1 / (x * x);\n }if (x >= this.C_LIMIT_0) {\n var inv = 1 / (x * x);\n return 1 / x + inv / 2 + inv / x * (1.0 / 6 - inv * (1.0 / 30 + inv / 42));\n }return this.trigamma_14dthe$(x + 1) + 1 / (x * x);\n };\n Gamma.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Gamma',\n interfaces: []\n };\n var Gamma_instance = null;\n function Gamma_getInstance() {\n if (Gamma_instance === null) {\n new Gamma();\n }return Gamma_instance;\n }\n function Incrementor(maximalCount, maxCountCallback) {\n if (maximalCount === void 0)\n maximalCount = 0;\n if (maxCountCallback === void 0)\n maxCountCallback = new Incrementor_init$ObjectLiteral();\n this.maximalCount = maximalCount;\n this.maxCountCallback_0 = maxCountCallback;\n this.count_k39d42$_0 = 0;\n }\n Object.defineProperty(Incrementor.prototype, 'count', {\n configurable: true,\n get: function () {\n return this.count_k39d42$_0;\n },\n set: function (count) {\n this.count_k39d42$_0 = count;\n }\n });\n Incrementor.prototype.canIncrement = function () {\n return this.count < this.maximalCount;\n };\n Incrementor.prototype.incrementCount_za3lpa$ = function (value) {\n for (var i = 0; i < value; i++) {\n this.incrementCount();\n }\n };\n Incrementor.prototype.incrementCount = function () {\n if ((this.count = this.count + 1 | 0, this.count) > this.maximalCount) {\n this.maxCountCallback_0.trigger_za3lpa$(this.maximalCount);\n }};\n Incrementor.prototype.resetCount = function () {\n this.count = 0;\n };\n function Incrementor$MaxCountExceededCallback() {\n }\n Incrementor$MaxCountExceededCallback.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MaxCountExceededCallback',\n interfaces: []\n };\n function Incrementor_init$ObjectLiteral() {\n }\n Incrementor_init$ObjectLiteral.prototype.trigger_za3lpa$ = function (maximalCount) {\n throw IllegalStateException_init(('MaxCountExceeded: ' + maximalCount).toString());\n };\n Incrementor_init$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Incrementor$MaxCountExceededCallback]\n };\n Incrementor.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Incrementor',\n interfaces: []\n };\n function LoessInterpolator(bandwidth, robustnessIters, accuracy) {\n LoessInterpolator$Companion_getInstance();\n if (bandwidth === void 0)\n bandwidth = LoessInterpolator$Companion_getInstance().DEFAULT_BANDWIDTH;\n if (robustnessIters === void 0)\n robustnessIters = 2;\n if (accuracy === void 0)\n accuracy = LoessInterpolator$Companion_getInstance().DEFAULT_ACCURACY;\n this.bandwidth_0 = bandwidth;\n this.robustnessIters_0 = robustnessIters;\n this.accuracy_0 = accuracy;\n if (this.bandwidth_0 <= 0 || this.bandwidth_0 > 1) {\n throw IllegalStateException_init(('Out of range of bandwidth value: ' + this.bandwidth_0 + ' should be > 0 and <= 1').toString());\n }if (this.robustnessIters_0 < 0) {\n throw IllegalStateException_init(('Not positive Robutness iterationa: ' + this.robustnessIters_0).toString());\n }}\n LoessInterpolator.prototype.interpolate_g9g6do$ = function (xval, yval) {\n return (new SplineInterpolator()).interpolate_g9g6do$(xval, this.smooth_0(xval, yval));\n };\n LoessInterpolator.prototype.smooth_1 = function (xval, yval, weights) {\n var tmp$, tmp$_0, tmp$_1;\n if (xval.length !== yval.length) {\n throw IllegalStateException_init(('Dimension mismatch of interpolation points: ' + xval.length + ' != ' + yval.length).toString());\n }var n = xval.length;\n if (n === 0) {\n throw IllegalStateException_init('No data to interpolate'.toString());\n }this.checkAllFiniteReal_0(xval);\n this.checkAllFiniteReal_0(yval);\n this.checkAllFiniteReal_0(weights);\n MathArrays_getInstance().checkOrder_gf7tl1$(xval);\n if (n === 1) {\n return new Float64Array([yval[0]]);\n }if (n === 2) {\n return new Float64Array([yval[0], yval[1]]);\n }var bandwidthInPoints = numberToInt(this.bandwidth_0 * n);\n if (bandwidthInPoints < 2) {\n throw IllegalStateException_init((\"LOESS 'bandwidthInPoints' is too small: \" + bandwidthInPoints + ' < 2').toString());\n }var res = new Float64Array(n);\n var residuals = new Float64Array(n);\n var sortedResiduals = new Float64Array(n);\n var robustnessWeights = new Float64Array(n);\n fill(robustnessWeights, 1.0);\n tmp$ = this.robustnessIters_0;\n for (var iter = 0; iter <= tmp$; iter++) {\n var bandwidthInterval = new Int32Array([0, bandwidthInPoints - 1 | 0]);\n for (var i = 0; i < n; i++) {\n var x = xval[i];\n if (i > 0) {\n this.updateBandwidthInterval_0(xval, weights, i, bandwidthInterval);\n }var ileft = bandwidthInterval[0];\n var iright = bandwidthInterval[1];\n var edge;\n if (xval[i] - xval[ileft] > xval[iright] - xval[i]) {\n tmp$_0 = ileft;\n } else {\n tmp$_0 = iright;\n }\n edge = tmp$_0;\n var sumWeights = 0.0;\n var sumX = 0.0;\n var sumXSquared = 0.0;\n var sumY = 0.0;\n var sumXY = 0.0;\n var x_0 = 1.0 / (xval[edge] - x);\n var denom = JsMath.abs(x_0);\n for (var k = ileft; k <= iright; k++) {\n var xk = xval[k];\n var yk = yval[k];\n var dist = k < i ? x - xk : xk - x;\n var w = this.tricube_0(dist * denom) * robustnessWeights[k] * weights[k];\n var xkw = xk * w;\n sumWeights += w;\n sumX += xkw;\n sumXSquared += xk * xkw;\n sumY += yk * w;\n sumXY += yk * xkw;\n }\n var meanX = sumX / sumWeights;\n var meanY = sumY / sumWeights;\n var meanXY = sumXY / sumWeights;\n var meanXSquared = sumXSquared / sumWeights;\n var beta;\n var x_1 = meanXSquared - meanX * meanX;\n var x_2 = JsMath.abs(x_1);\n if (JsMath.sqrt(x_2) < this.accuracy_0) {\n tmp$_1 = 0.0;\n } else {\n tmp$_1 = (meanXY - meanX * meanY) / (meanXSquared - meanX * meanX);\n }\n beta = tmp$_1;\n var alpha = meanY - beta * meanX;\n res[i] = beta * x + alpha;\n var x_3 = yval[i] - res[i];\n residuals[i] = JsMath.abs(x_3);\n }\n if (iter === this.robustnessIters_0) {\n break;\n }arrayCopy(residuals, sortedResiduals, 0, 0, n);\n sort(sortedResiduals);\n var medianResidual = sortedResiduals[n / 2 | 0];\n if (JsMath.abs(medianResidual) < this.accuracy_0) {\n break;\n }for (var i_0 = 0; i_0 < n; i_0++) {\n var arg = residuals[i_0] / (6 * medianResidual);\n if (arg >= 1) {\n robustnessWeights[i_0] = 0.0;\n } else {\n var w_0 = 1 - arg * arg;\n robustnessWeights[i_0] = w_0 * w_0;\n }\n }\n }\n return res;\n };\n LoessInterpolator.prototype.updateBandwidthInterval_0 = function (xval, weights, i, bandwidthInterval) {\n var left = bandwidthInterval[0];\n var right = bandwidthInterval[1];\n var nextRight = this.nextNonzero_0(weights, right);\n if (nextRight < xval.length && xval[nextRight] - xval[i] < xval[i] - xval[left]) {\n var nextLeft = this.nextNonzero_0(weights, bandwidthInterval[0]);\n bandwidthInterval[0] = nextLeft;\n bandwidthInterval[1] = nextRight;\n }};\n LoessInterpolator.prototype.tricube_0 = function (x) {\n var absX = JsMath.abs(x);\n if (absX >= 1.0) {\n return 0.0;\n }var tmp = 1 - absX * absX * absX;\n return tmp * tmp * tmp;\n };\n LoessInterpolator.prototype.nextNonzero_0 = function (weights, i) {\n var j = i + 1 | 0;\n while (j < weights.length && weights[j] === 0.0) {\n j = j + 1 | 0;\n }\n return j;\n };\n LoessInterpolator.prototype.smooth_0 = function (xval, yval) {\n if (xval.length !== yval.length) {\n throw IllegalStateException_init(('Dimension mismatch: ' + xval.length + ' != ' + yval.length).toString());\n }var unitWeights = new Float64Array(xval.length);\n fill(unitWeights, 1.0);\n return this.smooth_1(xval, yval, unitWeights);\n };\n LoessInterpolator.prototype.checkFinite_0 = function (x) {\n if (isInfinite(x) || isNaN_0(x)) {\n throw IllegalStateException_init(('Argument ' + x + ' is not a finite number').toString());\n }};\n LoessInterpolator.prototype.checkAllFiniteReal_0 = function (values) {\n for (var i = 0; i !== values.length; ++i) {\n this.checkFinite_0(values[i]);\n }\n };\n function LoessInterpolator$Companion() {\n LoessInterpolator$Companion_instance = this;\n this.DEFAULT_BANDWIDTH = 0.3;\n this.DEFAULT_ROBUSTNESS_ITERS = 2;\n this.DEFAULT_ACCURACY = 1.0E-12;\n }\n LoessInterpolator$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LoessInterpolator$Companion_instance = null;\n function LoessInterpolator$Companion_getInstance() {\n if (LoessInterpolator$Companion_instance === null) {\n new LoessInterpolator$Companion();\n }return LoessInterpolator$Companion_instance;\n }\n LoessInterpolator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LoessInterpolator',\n interfaces: []\n };\n function MathArrays() {\n MathArrays_instance = this;\n }\n function MathArrays$OrderDirection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MathArrays$OrderDirection_initFields() {\n MathArrays$OrderDirection_initFields = function () {\n };\n MathArrays$OrderDirection$INCREASING_instance = new MathArrays$OrderDirection('INCREASING', 0);\n MathArrays$OrderDirection$DECREASING_instance = new MathArrays$OrderDirection('DECREASING', 1);\n }\n var MathArrays$OrderDirection$INCREASING_instance;\n function MathArrays$OrderDirection$INCREASING_getInstance() {\n MathArrays$OrderDirection_initFields();\n return MathArrays$OrderDirection$INCREASING_instance;\n }\n var MathArrays$OrderDirection$DECREASING_instance;\n function MathArrays$OrderDirection$DECREASING_getInstance() {\n MathArrays$OrderDirection_initFields();\n return MathArrays$OrderDirection$DECREASING_instance;\n }\n MathArrays$OrderDirection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderDirection',\n interfaces: [Enum]\n };\n function MathArrays$OrderDirection$values() {\n return [MathArrays$OrderDirection$INCREASING_getInstance(), MathArrays$OrderDirection$DECREASING_getInstance()];\n }\n MathArrays$OrderDirection.values = MathArrays$OrderDirection$values;\n function MathArrays$OrderDirection$valueOf(name) {\n switch (name) {\n case 'INCREASING':\n return MathArrays$OrderDirection$INCREASING_getInstance();\n case 'DECREASING':\n return MathArrays$OrderDirection$DECREASING_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.base.stat.math3.MathArrays.OrderDirection.' + name);\n }\n }\n MathArrays$OrderDirection.valueOf_61zpoe$ = MathArrays$OrderDirection$valueOf;\n MathArrays.prototype.checkOrder_j8c91m$ = function (val, dir, strict, abort) {\n var tmp$;\n var previous = val[0];\n var max = val.length;\n var index;\n index = 1;\n ITEM: while (index < max) {\n if (equals(dir, MathArrays$OrderDirection$INCREASING_getInstance()))\n if (strict) {\n if (val[index] <= previous) {\n break ITEM;\n }} else {\n if (val[index] < previous) {\n break ITEM;\n }}\n else if (equals(dir, MathArrays$OrderDirection$DECREASING_getInstance()))\n if (strict) {\n if (val[index] >= previous) {\n break ITEM;\n }} else {\n if (val[index] > previous) {\n break ITEM;\n }}\n else {\n throw IllegalStateException_init(''.toString());\n }\n previous = val[index];\n index = index + 1 | 0;\n }\n if (index === max) {\n return true;\n }if (abort) {\n throw IllegalStateException_init('Non monotonic sequence'.toString());\n } else {\n tmp$ = false;\n }\n return tmp$;\n };\n MathArrays.prototype.checkOrder_hixecd$ = function (val, dir, strict) {\n this.checkOrder_j8c91m$(val, dir, strict, true);\n };\n MathArrays.prototype.checkOrder_gf7tl1$ = function (val) {\n this.checkOrder_hixecd$(val, MathArrays$OrderDirection$INCREASING_getInstance(), true);\n };\n MathArrays.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MathArrays',\n interfaces: []\n };\n var MathArrays_instance = null;\n function MathArrays_getInstance() {\n if (MathArrays_instance === null) {\n new MathArrays();\n }return MathArrays_instance;\n }\n function Percentile() {\n Percentile_instance = this;\n this.MIN_SELECT_SIZE_0 = 15;\n this.MAX_CACHED_LEVELS_0 = 10;\n }\n Percentile.prototype.evaluate_pw9xcd$ = function (values, p) {\n this.test_0(values, 0, 0, false);\n return this.evaluate_0(values, 0, values.length, p);\n };\n Percentile.prototype.test_0 = function (values, begin, length, allowEmpty) {\n var tmp$;\n if (values == null) {\n throw IllegalStateException_init('Input array'.toString());\n }if (begin < 0) {\n throw IllegalStateException_init('start postion < 0'.toString());\n }if (length < 0) {\n throw IllegalStateException_init('length < 0'.toString());\n }if ((begin + length | 0) > values.length) {\n throw IllegalStateException_init('subarray ends after array end'.toString());\n }if (length === 0 && !allowEmpty) {\n tmp$ = false;\n } else\n tmp$ = true;\n return tmp$;\n };\n Percentile.prototype.evaluate_0 = function (values, begin, length, p) {\n this.test_0(values, begin, length, false);\n if (p > 100 || p <= 0) {\n throw IllegalStateException_init(('out of bounds quantile value: ' + p + ', must be in (0, 100]').toString());\n }if (length === 0) {\n return kotlin_js_internal_DoubleCompanionObject.NaN;\n }if (length === 1) {\n return values[begin];\n }var n = length;\n var pos = p * (n + 1) / 100;\n var fpos = JsMath.floor(pos);\n var intPos = numberToInt(fpos);\n var dif = pos - fpos;\n var work = new Float64Array(length);\n arrayCopy(values, work, 0, begin, length);\n var pivotsHeap = new Int32Array(1023);\n fill_0(pivotsHeap, -1);\n if (pos < 1) {\n return this.select_0(work, pivotsHeap, 0);\n }if (pos >= n) {\n return this.select_0(work, pivotsHeap, length - 1 | 0);\n }var lower = this.select_0(work, pivotsHeap, intPos - 1 | 0);\n var upper = this.select_0(work, pivotsHeap, intPos);\n return lower + dif * (upper - lower);\n };\n Percentile.prototype.select_0 = function (work, pivotsHeap, k) {\n var begin = 0;\n var end = work.length;\n var node = 0;\n while ((end - begin | 0) > 15) {\n var pivot;\n if (node < pivotsHeap.length && pivotsHeap[node] >= 0) {\n pivot = pivotsHeap[node];\n } else {\n pivot = this.partition_0(work, begin, end, this.medianOf3_0(work, begin, end));\n if (node < pivotsHeap.length) {\n pivotsHeap[node] = pivot;\n }}\n if (k === pivot) {\n return work[k];\n } else if (k < pivot) {\n end = pivot;\n var a = (2 * node | 0) + 1 | 0;\n node = JsMath.min(a, pivotsHeap.length);\n } else {\n begin = pivot + 1 | 0;\n var a_0 = (2 * node | 0) + 2 | 0;\n node = JsMath.min(a_0, pivotsHeap.length);\n }\n }\n this.insertionSort_0(work, begin, end);\n return work[k];\n };\n Percentile.prototype.partition_0 = function (work, begin, end, pivot) {\n var tmp$, tmp$_0;\n var value = work[pivot];\n work[pivot] = work[begin];\n var i = begin + 1 | 0;\n var j = end - 1 | 0;\n while (i < j) {\n while (i < j && work[j] >= value) {\n j = j - 1 | 0;\n }\n while (i < j && work[i] <= value) {\n i = i + 1 | 0;\n }\n if (i < j) {\n var tmp = work[i];\n work[tmp$ = i, i = tmp$ + 1 | 0, tmp$] = work[j];\n work[tmp$_0 = j, j = tmp$_0 - 1 | 0, tmp$_0] = tmp;\n }}\n if (i >= end || work[i] > value) {\n i = i - 1 | 0;\n }work[begin] = work[i];\n work[i] = value;\n return i;\n };\n Percentile.prototype.medianOf3_0 = function (work, begin, end) {\n var tmp$;\n var inclusiveEnd = end - 1 | 0;\n var middle = begin + ((inclusiveEnd - begin | 0) / 2 | 0) | 0;\n var wBegin = work[begin];\n var wMiddle = work[middle];\n var wEnd = work[inclusiveEnd];\n if (wBegin < wMiddle) {\n if (wMiddle < wEnd) {\n tmp$ = middle;\n } else {\n tmp$ = wBegin < wEnd ? inclusiveEnd : begin;\n }\n } else {\n if (wBegin < wEnd) {\n tmp$ = begin;\n } else {\n tmp$ = wMiddle < wEnd ? inclusiveEnd : middle;\n }\n }\n return tmp$;\n };\n Percentile.prototype.insertionSort_0 = function (work, begin, end) {\n for (var j = begin + 1 | 0; j < end; j++) {\n var saved = work[j];\n var i = j - 1 | 0;\n while (i >= begin && saved < work[i]) {\n work[i + 1 | 0] = work[i];\n i = i - 1 | 0;\n }\n work[i + 1 | 0] = saved;\n }\n };\n Percentile.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Percentile',\n interfaces: []\n };\n var Percentile_instance = null;\n function Percentile_getInstance() {\n if (Percentile_instance === null) {\n new Percentile();\n }return Percentile_instance;\n }\n function PolynomialFunction(c) {\n this.coefficients_0 = null;\n var tmp$ = c == null;\n if (!tmp$) {\n tmp$ = c.length === 0;\n }if (tmp$) {\n throw IllegalStateException_init('Empty polynomials coefficients array'.toString());\n }var n = c.length;\n while (n > 1 && c[n - 1 | 0] === 0.0) {\n n = n - 1 | 0;\n }\n this.coefficients_0 = new Float64Array(n);\n arrayCopy(c, this.coefficients_0, 0, 0, n);\n }\n PolynomialFunction.prototype.value_14dthe$ = function (x) {\n return this.evaluate_0(this.coefficients_0, x);\n };\n PolynomialFunction.prototype.evaluate_0 = function (coefficients, argument) {\n if (coefficients == null) {\n throw IllegalStateException_init('Null argument: coefficients of the polynomial to evaluate'.toString());\n }var n = coefficients.length;\n if (n === 0) {\n throw IllegalStateException_init('Empty polynomials coefficients array'.toString());\n }var result = coefficients[n - 1 | 0];\n for (var j = n - 2 | 0; j >= 0; j--) {\n result = argument * result + coefficients[j];\n }\n return result;\n };\n PolynomialFunction.prototype.unaryPlus = function () {\n return new PolynomialFunction(this.coefficients_0);\n };\n PolynomialFunction.prototype.unaryMinus = function () {\n var tmp$;\n var dd = new Float64Array(this.coefficients_0.length);\n tmp$ = this.coefficients_0;\n for (var i = 0; i !== tmp$.length; ++i) {\n var c = tmp$[i];\n dd[i] = -c;\n }\n return new PolynomialFunction(dd);\n };\n PolynomialFunction.prototype.apply_op_0 = function (other, op) {\n var sz = collect.Comparables.max_sdesaw$(this.coefficients_0.length, other.coefficients_0.length);\n var nc = new Float64Array(sz);\n for (var i = 0; i < sz; i++) {\n var a = i < this.coefficients_0.length ? this.coefficients_0[i] : 0.0;\n var b = i < other.coefficients_0.length ? other.coefficients_0[i] : 0.0;\n nc[i] = op(a, b);\n }\n return new PolynomialFunction(nc);\n };\n function PolynomialFunction$plus$lambda(x, y) {\n return x + y;\n }\n PolynomialFunction.prototype.plus_3j0b7h$ = function (other) {\n return this.apply_op_0(other, PolynomialFunction$plus$lambda);\n };\n function PolynomialFunction$minus$lambda(x, y) {\n return x - y;\n }\n PolynomialFunction.prototype.minus_3j0b7h$ = function (other) {\n return this.apply_op_0(other, PolynomialFunction$minus$lambda);\n };\n PolynomialFunction.prototype.multiply_14dthe$ = function (a) {\n var tmp$;\n var dd = new Float64Array(this.coefficients_0.length);\n tmp$ = this.coefficients_0;\n for (var i = 0; i !== tmp$.length; ++i) {\n var c = tmp$[i];\n dd[i] = a * c;\n }\n return new PolynomialFunction(dd);\n };\n PolynomialFunction.prototype.times_3j0b7h$ = function (other) {\n var nd = this.coefficients_0.length + other.coefficients_0.length - 1 | 0;\n var nc = new Float64Array(nd);\n for (var i = 0; i < nd; i++) {\n for (var j = 0; j <= i; j++) {\n var a = j < this.coefficients_0.length ? this.coefficients_0[j] : 0.0;\n var k = i - j | 0;\n var b = k < other.coefficients_0.length ? other.coefficients_0[k] : 0.0;\n nc[i] = nc[i] + a * b;\n }\n }\n return new PolynomialFunction(nc);\n };\n PolynomialFunction.prototype.degree = function () {\n var tmp$ = collect.Comparables;\n var $receiver = this.coefficients_0;\n var indexOfLast$result;\n indexOfLast$break: do {\n var tmp$_0;\n tmp$_0 = reversed_0(get_indices($receiver)).iterator();\n while (tmp$_0.hasNext()) {\n var index = tmp$_0.next();\n if ($receiver[index] !== 0.0) {\n indexOfLast$result = index;\n break indexOfLast$break;\n }}\n indexOfLast$result = -1;\n }\n while (false);\n return tmp$.max_sdesaw$(0, indexOfLast$result);\n };\n PolynomialFunction.prototype.compareTo_3j0b7h$ = function (other) {\n var d1 = this.degree();\n var d2 = other.degree();\n var n = collect.Comparables.min_sdesaw$(d1, d2) + 1 | 0;\n for (var i = 0; i < n; i++) {\n var a = this.coefficients_0[i];\n var b = other.coefficients_0[i];\n var res = Kotlin.compareTo(a, b);\n if (res !== 0)\n return res;\n }\n return Kotlin.primitiveCompareTo(d1, d2);\n };\n PolynomialFunction.prototype.equals = function (other) {\n if (other == null || !Kotlin.isType(other, PolynomialFunction))\n return false;\n return this.compareTo_3j0b7h$(other) === 0;\n };\n PolynomialFunction.prototype.hashCode = function () {\n return hashCode(this.coefficients_0);\n };\n PolynomialFunction.prototype.toString = function () {\n var sb = StringBuilder_init();\n for (var i = get_lastIndex(this.coefficients_0); i >= 0; i--) {\n if (this.coefficients_0[i] !== 0.0) {\n if (!(sb.length === 0))\n sb.append_pdl1vj$(' + ');\n sb.append_pdl1vj$(this.coefficients_0[i].toString());\n if (i > 0)\n sb.append_pdl1vj$('x');\n if (i > 1)\n sb.append_pdl1vj$('^').append_s8jyv4$(i);\n }}\n return sb.toString();\n };\n PolynomialFunction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialFunction',\n interfaces: []\n };\n function times($receiver, p) {\n return p.multiply_14dthe$($receiver);\n }\n function PolynomialSplineFunction(_knots, _polynomials) {\n this.knots = null;\n this.polynomials = null;\n this.n_0 = 0;\n if (_knots == null) {\n throw IllegalStateException_init('Null argument '.toString());\n }if (_knots.length < 2) {\n throw IllegalStateException_init(('Spline partition must have at least 2 points, got ' + _knots.length).toString());\n }if ((_knots.length - 1 | 0) !== _polynomials.length) {\n throw IllegalStateException_init(('Dimensions mismatch: ' + _polynomials.length + ' polynomial functions != ' + _knots.length + ' segment delimiters').toString());\n }MathArrays_getInstance().checkOrder_gf7tl1$(_knots);\n this.n_0 = _knots.length - 1 | 0;\n this.knots = _knots;\n this.polynomials = Kotlin.newArray(this.n_0, null);\n arrayCopy(_polynomials, this.polynomials, 0, 0, this.n_0);\n }\n PolynomialSplineFunction.prototype.value_14dthe$ = function (v) {\n var tmp$;\n if (v < this.knots[0] || v > this.knots[this.n_0]) {\n throw IllegalStateException_init((v.toString() + ' out of [' + this.knots[0] + ', ' + this.knots[this.n_0] + '] range').toString());\n }var i = binarySearch(toMutableList_0(this.knots), v);\n if (i < 0) {\n i = (-i | 0) - 2 | 0;\n }if (i >= this.polynomials.length) {\n i = i - 1 | 0;\n }return (tmp$ = this.polynomials[i]) != null ? tmp$.value_14dthe$(v - this.knots[i]) : null;\n };\n PolynomialSplineFunction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialSplineFunction',\n interfaces: []\n };\n function Precision() {\n Precision_instance = this;\n this.SGN_MASK_0 = L_2147483648;\n this.SGN_MASK_FLOAT_0 = -2147483648;\n }\n Precision.prototype.compareTo_yvo9jy$ = function (x, y, eps) {\n if (this.equals_yvo9jy$(x, y, eps)) {\n return 0;\n } else if (x < y) {\n return -1;\n }return 1;\n };\n Precision.prototype.compareTo_syxxoe$ = function (x, y, maxUlps) {\n if (this.equals_syxxoe$(x, y, maxUlps)) {\n return 0;\n } else if (x < y) {\n return -1;\n }return 1;\n };\n Precision.prototype.equalsIncludingNaN_dleff0$ = function (x, y) {\n return isNaN_1(x) && isNaN_1(y) || this.equals_a5xegy$(x, y, 1);\n };\n Precision.prototype.equals_y2kzbl$ = function (x, y, eps) {\n var tmp$ = this.equals_a5xegy$(x, y, 1);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equalsIncludingNaN_y2kzbl$ = function (x, y, eps) {\n var tmp$ = this.equalsIncludingNaN_dleff0$(x, y);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equals_a5xegy$ = function (x, y, maxUlps) {\n if (maxUlps === void 0)\n maxUlps = 1;\n var xInt = toBits(x);\n var yInt = toBits(y);\n if (xInt < 0) {\n xInt = this.SGN_MASK_FLOAT_0 - xInt | 0;\n }if (yInt < 0) {\n yInt = this.SGN_MASK_FLOAT_0 - yInt | 0;\n }var isEqual = abs(xInt - yInt | 0) <= maxUlps;\n return isEqual && !isNaN_1(x) && !isNaN_1(y);\n };\n Precision.prototype.equalsIncludingNaN_a5xegy$ = function (x, y, maxUlps) {\n return isNaN_1(x) && isNaN_1(y) || this.equals_a5xegy$(x, y, maxUlps);\n };\n Precision.prototype.equalsIncludingNaN_lu1900$ = function (x, y) {\n return isNaN_0(x) && isNaN_0(y) || this.equals_syxxoe$(x, y, 1);\n };\n Precision.prototype.equals_yvo9jy$ = function (x, y, eps) {\n var tmp$ = this.equals_syxxoe$(x, y, 1);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equalsIncludingNaN_yvo9jy$ = function (x, y, eps) {\n var tmp$ = this.equalsIncludingNaN_lu1900$(x, y);\n if (!tmp$) {\n var x_0 = y - x;\n tmp$ = JsMath.abs(x_0) <= eps;\n }return tmp$;\n };\n Precision.prototype.equals_syxxoe$ = function (x, y, maxUlps) {\n if (maxUlps === void 0)\n maxUlps = 1;\n var xInt = toBits_0(x);\n var yInt = toBits_0(y);\n if (xInt.toNumber() < 0) {\n xInt = this.SGN_MASK_0.subtract(xInt);\n }if (yInt.toNumber() < 0) {\n yInt = this.SGN_MASK_0.subtract(yInt);\n }var isEqual = abs_0(xInt.subtract(yInt)).toNumber() <= maxUlps;\n return isEqual && !isNaN_0(x) && !isNaN_0(y);\n };\n Precision.prototype.equalsIncludingNaN_syxxoe$ = function (x, y, maxUlps) {\n return isNaN_0(x) && isNaN_0(y) || this.equals_syxxoe$(x, y, maxUlps);\n };\n Precision.prototype.representableDelta_lu1900$ = function (x, originalDelta) {\n return x + originalDelta - x;\n };\n Precision.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Precision',\n interfaces: []\n };\n var Precision_instance = null;\n function Precision_getInstance() {\n if (Precision_instance === null) {\n new Precision();\n }return Precision_instance;\n }\n function RealDistribution() {\n }\n RealDistribution.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'RealDistribution',\n interfaces: []\n };\n function SplineInterpolator() {\n }\n SplineInterpolator.prototype.interpolate_g9g6do$ = function (x, y) {\n if (x.length !== y.length) {\n throw IllegalStateException_init(('Dimension mismatch ' + x.length + ' != ' + y.length).toString());\n }if (x.length < 3) {\n throw IllegalStateException_init(('Too small value of points number: ' + x.length + ' < 3').toString());\n }var n = x.length - 1 | 0;\n MathArrays_getInstance().checkOrder_gf7tl1$(x);\n var h = new Float64Array(n);\n for (var i = 0; i < n; i++) {\n h[i] = x[i + 1 | 0] - x[i];\n }\n var mu = new Float64Array(n);\n var z = new Float64Array(n + 1 | 0);\n mu[0] = 0.0;\n z[0] = 0.0;\n for (var i_0 = 1; i_0 < n; i_0++) {\n var g = 2.0 * (x[i_0 + 1 | 0] - x[i_0 - 1 | 0]) - h[i_0 - 1 | 0] * mu[i_0 - 1 | 0];\n mu[i_0] = h[i_0] / g;\n z[i_0] = (3.0 * (y[i_0 + 1 | 0] * h[i_0 - 1 | 0] - y[i_0] * (x[i_0 + 1 | 0] - x[i_0 - 1 | 0]) + y[i_0 - 1 | 0] * h[i_0]) / (h[i_0 - 1 | 0] * h[i_0]) - h[i_0 - 1 | 0] * z[i_0 - 1 | 0]) / g;\n }\n var b = new Float64Array(n);\n var c = new Float64Array(n + 1 | 0);\n var d = new Float64Array(n);\n z[n] = 0.0;\n c[n] = 0.0;\n for (var j = n - 1 | 0; j >= 0; j--) {\n c[j] = z[j] - mu[j] * c[j + 1 | 0];\n b[j] = (y[j + 1 | 0] - y[j]) / h[j] - h[j] * (c[j + 1 | 0] + 2.0 * c[j]) / 3.0;\n d[j] = (c[j + 1 | 0] - c[j]) / (3.0 * h[j]);\n }\n var polynomials = Kotlin.newArray(n, null);\n var coefficients = new Float64Array(4);\n for (var i_1 = 0; i_1 < n; i_1++) {\n coefficients[0] = y[i_1];\n coefficients[1] = b[i_1];\n coefficients[2] = c[i_1];\n coefficients[3] = d[i_1];\n polynomials[i_1] = new PolynomialFunction(coefficients);\n }\n return new PolynomialSplineFunction(x, polynomials);\n };\n SplineInterpolator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SplineInterpolator',\n interfaces: []\n };\n function TDistribution(degreesOfFreedom, solverAbsoluteAccuracy) {\n TDistribution$Companion_getInstance();\n if (solverAbsoluteAccuracy === void 0)\n solverAbsoluteAccuracy = TDistribution$Companion_getInstance().DEFAULT_INVERSE_ABSOLUTE_ACCURACY;\n AbstractRealDistribution.call(this);\n this.degreesOfFreedom_0 = degreesOfFreedom;\n this.solverAbsoluteAccuracy_l8ezvu$_0 = solverAbsoluteAccuracy;\n if (this.degreesOfFreedom_0 <= 0) {\n throw IllegalStateException_init(('NotStrictlyPositive - DEGREES_OF_FREEDOM: ' + this.degreesOfFreedom_0).toString());\n }}\n Object.defineProperty(TDistribution.prototype, 'solverAbsoluteAccuracy', {\n get: function () {\n return this.solverAbsoluteAccuracy_l8ezvu$_0;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'numericalMean', {\n configurable: true,\n get: function () {\n var tmp$;\n var df = this.degreesOfFreedom_0;\n if (df > 1) {\n tmp$ = 0.0;\n } else\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n return tmp$;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'numericalVariance', {\n configurable: true,\n get: function () {\n var tmp$;\n var df = this.degreesOfFreedom_0;\n if (df > 2) {\n return df / (df - 2);\n }if (df > 1 && df <= 2) {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n } else\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n return tmp$;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'supportLowerBound', {\n configurable: true,\n get: function () {\n return kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'supportUpperBound', {\n configurable: true,\n get: function () {\n return kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportLowerBoundInclusive', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportUpperBoundInclusive', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(TDistribution.prototype, 'isSupportConnected', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n TDistribution.prototype.probability_14dthe$ = function (x) {\n return 0.0;\n };\n TDistribution.prototype.density_14dthe$ = function (x) {\n var n = this.degreesOfFreedom_0;\n var nPlus1Over2 = (n + 1) / 2;\n var tmp$ = Gamma_getInstance().logGamma_14dthe$(nPlus1Over2);\n var x_0 = math.PI;\n var tmp$_0 = tmp$ - 0.5 * (JsMath.log(x_0) + JsMath.log(n)) - Gamma_getInstance().logGamma_14dthe$(n / 2);\n var x_1 = 1 + x * x / n;\n var x_2 = tmp$_0 - nPlus1Over2 * JsMath.log(x_1);\n return JsMath.exp(x_2);\n };\n TDistribution.prototype.cumulativeProbability_14dthe$ = function (x) {\n var ret;\n if (x === 0.0) {\n ret = 0.5;\n } else {\n var t = Beta_getInstance().regularizedBeta_tychlm$(this.degreesOfFreedom_0 / (this.degreesOfFreedom_0 + x * x), 0.5 * this.degreesOfFreedom_0, 0.5);\n if (x < 0.0) {\n ret = 0.5 * t;\n } else {\n ret = 1.0 - 0.5 * t;\n }\n }\n return ret;\n };\n function TDistribution$Companion() {\n TDistribution$Companion_instance = this;\n this.DEFAULT_INVERSE_ABSOLUTE_ACCURACY = 1.0E-9;\n this.serialVersionUID_0 = L_5852615386664158222;\n }\n TDistribution$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TDistribution$Companion_instance = null;\n function TDistribution$Companion_getInstance() {\n if (TDistribution$Companion_instance === null) {\n new TDistribution$Companion();\n }return TDistribution$Companion_instance;\n }\n TDistribution.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TDistribution',\n interfaces: [AbstractRealDistribution]\n };\n function UnivariateFunction() {\n }\n UnivariateFunction.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UnivariateFunction',\n interfaces: []\n };\n function UnivariateSolver() {\n }\n UnivariateSolver.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'UnivariateSolver',\n interfaces: [BaseUnivariateSolver]\n };\n function UnivariateSolverUtils() {\n UnivariateSolverUtils_instance = this;\n }\n UnivariateSolverUtils.prototype.solve_ljmp9$ = function (function_0, x0, x1) {\n var solver = BrentSolver_init();\n return solver.solve_rmnly1$(2147483647, function_0, x0, x1);\n };\n UnivariateSolverUtils.prototype.solve_wb66u3$ = function (function_0, x0, x1, absoluteAccuracy) {\n var solver = BrentSolver_init(absoluteAccuracy);\n return solver.solve_rmnly1$(2147483647, function_0, x0, x1);\n };\n UnivariateSolverUtils.prototype.forceSide_i33h9z$ = function (maxEval, f, bracketing, baseRoot, min, max, allowedSolution) {\n if (allowedSolution === AllowedSolution$ANY_SIDE_getInstance()) {\n return baseRoot;\n }var tmp$ = bracketing.absoluteAccuracy;\n var x = baseRoot * bracketing.relativeAccuracy;\n var b = JsMath.abs(x);\n var step = JsMath.max(tmp$, b);\n var b_0 = baseRoot - step;\n var xLo = JsMath.max(min, b_0);\n var fLo = f.value_14dthe$(xLo);\n var b_1 = baseRoot + step;\n var xHi = JsMath.min(max, b_1);\n var fHi = f.value_14dthe$(xHi);\n var remainingEval = maxEval - 2 | 0;\n while (remainingEval > 0) {\n if (fLo >= 0 && fHi <= 0 || (fLo <= 0 && fHi >= 0)) {\n return bracketing.solve_epddgp$(remainingEval, f, xLo, xHi, baseRoot, allowedSolution);\n }var changeLo = false;\n var changeHi = false;\n if (fLo < fHi) {\n if (fLo >= 0) {\n changeLo = true;\n } else {\n changeHi = true;\n }\n } else if (fLo > fHi) {\n if (fLo <= 0) {\n changeLo = true;\n } else {\n changeHi = true;\n }\n } else {\n changeLo = true;\n changeHi = true;\n }\n if (changeLo) {\n var b_2 = xLo - step;\n xLo = JsMath.max(min, b_2);\n fLo = f.value_14dthe$(xLo);\n remainingEval = remainingEval - 1 | 0;\n }if (changeHi) {\n var b_3 = xHi + step;\n xHi = JsMath.min(max, b_3);\n fHi = f.value_14dthe$(xHi);\n remainingEval = remainingEval - 1 | 0;\n }}\n throw IllegalStateException_init('NoBracketing'.toString());\n };\n UnivariateSolverUtils.prototype.bracket_cflw21$ = function (function_0, initial, lowerBound, upperBound, maximumIterations) {\n if (maximumIterations === void 0)\n maximumIterations = 2147483647;\n if (maximumIterations <= 0) {\n throw IllegalStateException_init('NotStrictlyPositive'.toString());\n }this.verifySequence_yvo9jy$(lowerBound, initial, upperBound);\n var a = initial;\n var b = initial;\n var fa;\n var fb;\n var numIterations = 0;\n do {\n var a_0 = a - 1.0;\n a = JsMath.max(a_0, lowerBound);\n var a_1 = b + 1.0;\n b = JsMath.min(a_1, upperBound);\n fa = function_0.value_14dthe$(a);\n fb = function_0.value_14dthe$(b);\n numIterations = numIterations + 1 | 0;\n }\n while (fa * fb > 0.0 && numIterations < maximumIterations && (a > lowerBound || b < upperBound));\n if (fa * fb > 0.0) {\n throw IllegalStateException_init('NoBracketing'.toString());\n }return new Float64Array([a, b]);\n };\n UnivariateSolverUtils.prototype.midpoint_lu1900$ = function (a, b) {\n return (a + b) * 0.5;\n };\n UnivariateSolverUtils.prototype.isBracketing_ljmp9$ = function (function_0, lower, upper) {\n var fLo = function_0.value_14dthe$(lower);\n var fHi = function_0.value_14dthe$(upper);\n return fLo >= 0 && fHi <= 0 || (fLo <= 0 && fHi >= 0);\n };\n UnivariateSolverUtils.prototype.isSequence_yvo9jy$ = function (start, mid, end) {\n return start < mid && mid < end;\n };\n UnivariateSolverUtils.prototype.verifyInterval_lu1900$ = function (lower, upper) {\n if (lower >= upper) {\n throw IllegalStateException_init('NumberIsTooLarge'.toString());\n }};\n UnivariateSolverUtils.prototype.verifySequence_yvo9jy$ = function (lower, initial, upper) {\n this.verifyInterval_lu1900$(lower, initial);\n this.verifyInterval_lu1900$(initial, upper);\n };\n UnivariateSolverUtils.prototype.verifyBracketing_ljmp9$ = function (function_0, lower, upper) {\n this.verifyInterval_lu1900$(lower, upper);\n if (!this.isBracketing_ljmp9$(function_0, lower, upper)) {\n throw IllegalStateException_init('NoBracketing'.toString());\n }};\n UnivariateSolverUtils.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'UnivariateSolverUtils',\n interfaces: []\n };\n var UnivariateSolverUtils_instance = null;\n function UnivariateSolverUtils_getInstance() {\n if (UnivariateSolverUtils_instance === null) {\n new UnivariateSolverUtils();\n }return UnivariateSolverUtils_instance;\n }\n function EvalResult(y, ymin, ymax, se) {\n this.y = y;\n this.ymin = ymin;\n this.ymax = ymax;\n this.se = se;\n }\n EvalResult.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EvalResult',\n interfaces: []\n };\n EvalResult.prototype.component1 = function () {\n return this.y;\n };\n EvalResult.prototype.component2 = function () {\n return this.ymin;\n };\n EvalResult.prototype.component3 = function () {\n return this.ymax;\n };\n EvalResult.prototype.component4 = function () {\n return this.se;\n };\n EvalResult.prototype.copy_6y0v78$ = function (y, ymin, ymax, se) {\n return new EvalResult(y === void 0 ? this.y : y, ymin === void 0 ? this.ymin : ymin, ymax === void 0 ? this.ymax : ymax, se === void 0 ? this.se : se);\n };\n EvalResult.prototype.toString = function () {\n return 'EvalResult(y=' + Kotlin.toString(this.y) + (', ymin=' + Kotlin.toString(this.ymin)) + (', ymax=' + Kotlin.toString(this.ymax)) + (', se=' + Kotlin.toString(this.se)) + ')';\n };\n EvalResult.prototype.hashCode = function () {\n var result = 0;\n result = result * 31 + Kotlin.hashCode(this.y) | 0;\n result = result * 31 + Kotlin.hashCode(this.ymin) | 0;\n result = result * 31 + Kotlin.hashCode(this.ymax) | 0;\n result = result * 31 + Kotlin.hashCode(this.se) | 0;\n return result;\n };\n EvalResult.prototype.equals = function (other) {\n return this === other || (other !== null && (typeof other === 'object' && (Object.getPrototypeOf(this) === Object.getPrototypeOf(other) && (Kotlin.equals(this.y, other.y) && Kotlin.equals(this.ymin, other.ymin) && Kotlin.equals(this.ymax, other.ymax) && Kotlin.equals(this.se, other.se)))));\n };\n function LinearRegression(xs, ys, confidenceLevel) {\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.beta1_0 = 0;\n this.beta0_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n var tmp$ = allFinite(xs, ys);\n var xVals = tmp$.component1()\n , yVals = tmp$.component2();\n this.n_0 = xVals.length;\n this.meanX_0 = average(xVals);\n var tmp$_0;\n var sum = 0;\n for (tmp$_0 = 0; tmp$_0 !== xVals.length; ++tmp$_0) {\n var element = xVals[tmp$_0];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var meanY = average(yVals);\n var tmp$_1;\n var sum_0 = 0;\n for (tmp$_1 = 0; tmp$_1 !== yVals.length; ++tmp$_1) {\n var element_0 = yVals[tmp$_1];\n var $receiver_0 = element_0 - meanY;\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sumYY = sum_0;\n var tmp$_2;\n var sum_1 = 0;\n tmp$_2 = zip_0(xVals, yVals).iterator();\n while (tmp$_2.hasNext()) {\n var element_1 = tmp$_2.next();\n var x = element_1.component1()\n , y = element_1.component2();\n sum_1 += (x - this.meanX_0) * (y - meanY);\n }\n var sumXY = sum_1;\n this.beta1_0 = sumXY / this.sumXX_0;\n this.beta0_0 = meanY - this.beta1_0 * this.meanX_0;\n var b = sumYY - sumXY * sumXY / this.sumXX_0;\n var sse = JsMath.max(0.0, b);\n var x_0 = sse / (this.n_0 - 2 | 0);\n this.sy_0 = JsMath.sqrt(x_0);\n var alpha = 1.0 - confidenceLevel;\n this.tcritical_0 = (new TDistribution(this.n_0 - 2.0)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n }\n LinearRegression.prototype.value_0 = function (x) {\n return this.beta1_0 * x + this.beta0_0;\n };\n LinearRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = this.value_0(x);\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n LinearRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearRegression',\n interfaces: [RegressionEvaluator]\n };\n function LocalPolynomialRegression(xs, ys, confidenceLevel, bandwidth) {\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.bandwidth_0 = bandwidth;\n this.canCompute = false;\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n this.polynomial_6goixr$_0 = this.polynomial_6goixr$_0;\n var tmp$;\n var tmp$_0 = averageByX_0(xs, ys);\n var xVals = tmp$_0.component1()\n , yVals = tmp$_0.component2();\n this.n_0 = xVals.length;\n var degreesOfFreedom = this.n_0 - 2.0;\n var bandwidthInPoints = numberToInt(this.bandwidth_0 * this.n_0);\n var bandwidthInPointsOk = bandwidthInPoints >= 2;\n this.canCompute = (this.n_0 >= 3 && degreesOfFreedom > 0 && bandwidthInPointsOk);\n this.meanX_0 = average(xVals);\n var tmp$_1;\n var sum = 0;\n for (tmp$_1 = 0; tmp$_1 !== xVals.length; ++tmp$_1) {\n var element = xVals[tmp$_1];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var meanY = average(yVals);\n var tmp$_2;\n var sum_0 = 0;\n for (tmp$_2 = 0; tmp$_2 !== yVals.length; ++tmp$_2) {\n var element_0 = yVals[tmp$_2];\n var $receiver_0 = element_0 - meanY;\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sumYY = sum_0;\n var tmp$_3;\n var sum_1 = 0;\n tmp$_3 = zip_0(xVals, yVals).iterator();\n while (tmp$_3.hasNext()) {\n var element_1 = tmp$_3.next();\n var x = element_1.component1()\n , y = element_1.component2();\n sum_1 += (x - this.meanX_0) * (y - meanY);\n }\n var sumXY = sum_1;\n var b = sumYY - sumXY * sumXY / this.sumXX_0;\n var sse = JsMath.max(0.0, b);\n var x_0 = sse / (this.n_0 - 2 | 0);\n this.sy_0 = JsMath.sqrt(x_0);\n if (this.canCompute) {\n this.polynomial_0 = this.getPoly_0(xVals, yVals);\n }if (this.canCompute) {\n var alpha = 1.0 - confidenceLevel;\n tmp$ = (new TDistribution(degreesOfFreedom)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n } else {\n tmp$ = kotlin_js_internal_DoubleCompanionObject.NaN;\n }\n this.tcritical_0 = tmp$;\n }\n Object.defineProperty(LocalPolynomialRegression.prototype, 'polynomial_0', {\n configurable: true,\n get: function () {\n if (this.polynomial_6goixr$_0 == null)\n return throwUPAE('polynomial');\n return this.polynomial_6goixr$_0;\n },\n set: function (polynomial) {\n this.polynomial_6goixr$_0 = polynomial;\n }\n });\n LocalPolynomialRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = ensureNotNull(this.polynomial_0.value_14dthe$(x));\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n LocalPolynomialRegression.prototype.getPoly_0 = function (xVals, yVals) {\n return (new LoessInterpolator(this.bandwidth_0, 4)).interpolate_g9g6do$(xVals, yVals);\n };\n LocalPolynomialRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LocalPolynomialRegression',\n interfaces: [RegressionEvaluator]\n };\n function PolynomialRegression(xs, ys, confidenceLevel, deg) {\n PolynomialRegression$Companion_getInstance();\n RegressionEvaluator.call(this, xs, ys, confidenceLevel);\n this.p_0 = null;\n this.n_0 = 0;\n this.meanX_0 = 0;\n this.sumXX_0 = 0;\n this.sy_0 = 0;\n this.tcritical_0 = 0;\n if (!(deg >= 2)) {\n var message = 'Degree of polynomial must be at least 2';\n throw IllegalArgumentException_init(message.toString());\n }var tmp$ = averageByX_0(xs, ys);\n var xVals = tmp$.component1()\n , yVals = tmp$.component2();\n this.n_0 = xVals.length;\n if (!(this.n_0 > deg)) {\n var message_0 = 'The number of valid data points must be greater than deg';\n throw IllegalArgumentException_init(message_0.toString());\n }this.p_0 = this.calcPolynomial_0(deg, xVals, yVals);\n this.meanX_0 = average(xVals);\n var tmp$_0;\n var sum = 0;\n for (tmp$_0 = 0; tmp$_0 !== xVals.length; ++tmp$_0) {\n var element = xVals[tmp$_0];\n var $receiver = element - this.meanX_0;\n sum += JsMath.pow($receiver, 2);\n }\n this.sumXX_0 = sum;\n var df = (this.n_0 - deg | 0) - 1.0;\n var tmp$_1;\n var sum_0 = 0;\n tmp$_1 = zip_0(xVals, yVals).iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n var x = element_0.component1()\n , y = element_0.component2();\n var $receiver_0 = y - this.p_0.value_14dthe$(x);\n sum_0 += JsMath.pow($receiver_0, 2);\n }\n var sse = sum_0;\n var x_0 = sse / df;\n this.sy_0 = JsMath.sqrt(x_0);\n var alpha = 1.0 - confidenceLevel;\n this.tcritical_0 = (new TDistribution(df)).inverseCumulativeProbability_14dthe$(1.0 - alpha / 2.0);\n }\n PolynomialRegression.prototype.calcPolynomial_0 = function (deg, xVals, yVals) {\n var fpg = new ForsythePolynomialGenerator(xVals);\n var res = new PolynomialFunction(new Float64Array([0.0]));\n for (var i = 0; i <= deg; i++) {\n var p = fpg.getPolynomial_za3lpa$(i);\n var s = this.coefficient_0(p, xVals, yVals);\n res = res.plus_3j0b7h$(times(s, p));\n }\n return res;\n };\n PolynomialRegression.prototype.coefficient_0 = function (p, xVals, yVals) {\n var ww = 0.0;\n var w = 0.0;\n for (var i = 0; i < xVals.length; i++) {\n var x = xVals[i];\n var y = yVals[i];\n var pval = p.value_14dthe$(x);\n ww += pval * pval;\n w += y * pval;\n }\n return w / ww;\n };\n PolynomialRegression.prototype.evalX_14dthe$ = function (x) {\n var $receiver = x - this.meanX_0;\n var dxSquare = JsMath.pow($receiver, 2);\n var tmp$ = this.sy_0;\n var x_0 = 1.0 / this.n_0 + dxSquare / this.sumXX_0;\n var se = tmp$ * JsMath.sqrt(x_0);\n var halfConfidenceInterval = this.tcritical_0 * se;\n var yHat = this.p_0.value_14dthe$(x);\n return new EvalResult(yHat, yHat - halfConfidenceInterval, yHat + halfConfidenceInterval, se);\n };\n function PolynomialRegression$Companion() {\n PolynomialRegression$Companion_instance = this;\n }\n PolynomialRegression$Companion.prototype.canBeComputed_fgqkrm$ = function (xs, ys, deg) {\n var xVals = averageByX_0(xs, ys).component1();\n return xVals.length > deg;\n };\n PolynomialRegression$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolynomialRegression$Companion_instance = null;\n function PolynomialRegression$Companion_getInstance() {\n if (PolynomialRegression$Companion_instance === null) {\n new PolynomialRegression$Companion();\n }return PolynomialRegression$Companion_instance;\n }\n PolynomialRegression.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolynomialRegression',\n interfaces: [RegressionEvaluator]\n };\n function RegressionEvaluator(xs, ys, confidenceLevel) {\n if (!rangeTo(0.01, 0.99).contains_mef7kx$(confidenceLevel)) {\n var message = 'Confidence level is out of range [0.01-0.99]. CL:' + confidenceLevel;\n throw IllegalArgumentException_init(message.toString());\n }if (!(xs.size === ys.size)) {\n var message_0 = 'X/Y must have same size. X:' + toString(xs.size) + ' Y:' + toString(ys.size);\n throw IllegalArgumentException_init(message_0.toString());\n }}\n RegressionEvaluator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RegressionEvaluator',\n interfaces: []\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function RegressionUtil() {\n RegressionUtil_instance = this;\n }\n RegressionUtil.prototype.sampling_v81hsd$ = function (data, m) {\n var tmp$;\n var index = this.sampleInt_0(data.size, m);\n var result = ArrayList_init();\n for (tmp$ = 0; tmp$ !== index.length; ++tmp$) {\n var i = index[tmp$];\n result.add_11rb$(data.get_za3lpa$(i));\n }\n return result;\n };\n RegressionUtil.prototype.sampleInt_0 = function (n, m) {\n if (n < m || m < 0) {\n throw IllegalStateException_init(('Sample ' + m + ' data from ' + n + ' data is impossible!').toString());\n }var perm = new Int32Array(n);\n for (var i = 0; i < n; i++) {\n perm[i] = i;\n }\n var result = new Int32Array(m);\n for (var j = 0; j < m; j++) {\n var r = j + numberToInt(Random.Default.nextDouble() * (n - j | 0)) | 0;\n result[j] = perm[r];\n perm[r] = perm[j];\n }\n return result;\n };\n RegressionUtil.prototype.percentile_av4ikl$ = function (data, p) {\n return Percentile_getInstance().evaluate_pw9xcd$(toDoubleArray(data), p * 100);\n };\n RegressionUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'RegressionUtil',\n interfaces: []\n };\n var RegressionUtil_instance = null;\n function RegressionUtil_getInstance() {\n if (RegressionUtil_instance === null) {\n new RegressionUtil();\n }return RegressionUtil_instance;\n }\n function allFinite(xs, ys) {\n var tmp$;\n var tx = ArrayList_init();\n var ty = ArrayList_init();\n tmp$ = zip_1(asSequence(xs), asSequence(ys)).iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var x = tmp$_0.component1()\n , y = tmp$_0.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n tx.add_11rb$(ensureNotNull(x));\n ty.add_11rb$(ensureNotNull(y));\n }}\n return new Pair_0(toDoubleArray(tx), toDoubleArray(ty));\n }\n function finitePairs(xs, ys) {\n var tmp$;\n var res = ArrayList_init();\n tmp$ = zip_1(asSequence(xs), asSequence(ys)).iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var x = tmp$_0.component1()\n , y = tmp$_0.component2();\n if (data.SeriesUtil.allFinite_jma9l8$(x, y)) {\n res.add_11rb$(new Pair_0(ensureNotNull(x), ensureNotNull(y)));\n }}\n return res;\n }\n function averageByX(lst) {\n var tmp$;\n if (lst.isEmpty())\n return new Pair_0(ArrayList_init(), ArrayList_init());\n var tx = ArrayList_init();\n var ty = ArrayList_init();\n var tmp$_0 = first(lst);\n var prevX = tmp$_0.component1()\n , sumY = tmp$_0.component2();\n var countY = 1;\n tmp$ = drop(asSequence(lst), 1).iterator();\n while (tmp$.hasNext()) {\n var tmp$_1 = tmp$.next();\n var x = tmp$_1.component1()\n , y = tmp$_1.component2();\n if (x === prevX) {\n sumY += y;\n countY = countY + 1 | 0;\n } else {\n tx.add_11rb$(prevX);\n ty.add_11rb$(sumY / countY);\n prevX = x;\n sumY = y;\n countY = 1;\n }\n }\n tx.add_11rb$(prevX);\n ty.add_11rb$(sumY / countY);\n return new Pair_0(tx, ty);\n }\n function averageByX$lambda(it) {\n return it.first;\n }\n function averageByX_0(xs, ys) {\n var tp = finitePairs(xs, ys);\n if (tp.size > 1) {\n sortWith(tp, new Comparator(compareBy$lambda_0(averageByX$lambda)));\n }var res = averageByX(tp);\n return new Pair_0(toDoubleArray(res.first), toDoubleArray(res.second));\n }\n function MutableDouble(myValue) {\n this.myValue_0 = myValue;\n }\n MutableDouble.prototype.getAndAdd_14dthe$ = function (v) {\n var prevValue = this.myValue_0;\n this.myValue_0 = prevValue + v;\n return prevValue;\n };\n MutableDouble.prototype.get = function () {\n return this.myValue_0;\n };\n MutableDouble.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MutableDouble',\n interfaces: []\n };\n function MutableInteger(myValue) {\n this.myValue_0 = myValue;\n }\n Object.defineProperty(MutableInteger.prototype, 'andIncrement', {\n configurable: true,\n get: function () {\n return this.getAndAdd_za3lpa$(1);\n }\n });\n MutableInteger.prototype.get = function () {\n return this.myValue_0;\n };\n MutableInteger.prototype.getAndAdd_za3lpa$ = function (v) {\n var prevValue = this.myValue_0;\n this.myValue_0 = prevValue + v | 0;\n return prevValue;\n };\n MutableInteger.prototype.increment = function () {\n this.getAndAdd_za3lpa$(1);\n };\n MutableInteger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MutableInteger',\n interfaces: []\n };\n function SamplingUtil() {\n SamplingUtil_instance = this;\n }\n SamplingUtil.prototype.sampleWithoutReplacement_o7ew15$ = function (popSize, sampleSize, rand, onPick, onDrop) {\n var pick = sampleSize <= (popSize / 2 | 0);\n var indexCount = pick ? sampleSize : popSize - sampleSize | 0;\n var indexSet = HashSet_init_1();\n while (indexSet.size < indexCount) {\n indexSet.add_11rb$(rand.nextInt_za3lpa$(popSize));\n }\n return pick ? onPick(indexSet) : onDrop(indexSet);\n };\n function SamplingUtil$sampleWithoutReplacement$lambda(closure$data) {\n return function (it) {\n return closure$data.selectIndices_p1n9e9$(it);\n };\n }\n function SamplingUtil$sampleWithoutReplacement$lambda_0(closure$data) {\n return function (it) {\n return closure$data.dropIndices_p1n9e9$(it);\n };\n }\n SamplingUtil.prototype.sampleWithoutReplacement_egh5ya$ = function (sampleSize, rand, data) {\n return this.sampleWithoutReplacement_o7ew15$(data.rowCount(), sampleSize, rand, SamplingUtil$sampleWithoutReplacement$lambda(data), SamplingUtil$sampleWithoutReplacement$lambda_0(data));\n };\n SamplingUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SamplingUtil',\n interfaces: []\n };\n var SamplingUtil_instance = null;\n function SamplingUtil_getInstance() {\n if (SamplingUtil_instance === null) {\n new SamplingUtil();\n }return SamplingUtil_instance;\n }\n Object.defineProperty(Aes, 'Companion', {\n get: Aes$Companion_getInstance\n });\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n var package$base = package$plot.base || (package$plot.base = {});\n package$base.Aes = Aes;\n package$base.Aesthetics = Aesthetics;\n package$base.ContinuousTransform = ContinuousTransform;\n package$base.CoordinateSystem = CoordinateSystem;\n DataFrame.OrderSpec = DataFrame$OrderSpec;\n Object.defineProperty(DataFrame$Variable$Source, 'ORIGIN', {\n get: DataFrame$Variable$Source$ORIGIN_getInstance\n });\n Object.defineProperty(DataFrame$Variable$Source, 'TRANSFORM', {\n get: DataFrame$Variable$Source$TRANSFORM_getInstance\n });\n Object.defineProperty(DataFrame$Variable$Source, 'STAT', {\n get: DataFrame$Variable$Source$STAT_getInstance\n });\n DataFrame$Variable.Source = DataFrame$Variable$Source;\n Object.defineProperty(DataFrame$Variable, 'Companion', {\n get: DataFrame$Variable$Companion_getInstance\n });\n DataFrame.Variable = DataFrame$Variable;\n Object.defineProperty(DataFrame, 'Companion', {\n get: DataFrame$Companion_getInstance\n });\n Object.defineProperty(DataFrame$Builder, 'Companion', {\n get: DataFrame$Builder$Companion_getInstance\n });\n DataFrame.Builder_init = DataFrame$DataFrame$Builder_init;\n DataFrame.Builder_init_dhhkv7$ = DataFrame$DataFrame$Builder_init_0;\n DataFrame.Builder = DataFrame$Builder;\n package$base.DataFrame = DataFrame;\n package$base.DataPointAesthetics = DataPointAesthetics;\n package$base.DiscreteTransform = DiscreteTransform;\n package$base.Geom = Geom;\n package$base.GeomContext = GeomContext;\n Object.defineProperty(GeomKind, 'PATH', {\n get: GeomKind$PATH_getInstance\n });\n Object.defineProperty(GeomKind, 'LINE', {\n get: GeomKind$LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'SMOOTH', {\n get: GeomKind$SMOOTH_getInstance\n });\n Object.defineProperty(GeomKind, 'BAR', {\n get: GeomKind$BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'HISTOGRAM', {\n get: GeomKind$HISTOGRAM_getInstance\n });\n Object.defineProperty(GeomKind, 'TILE', {\n get: GeomKind$TILE_getInstance\n });\n Object.defineProperty(GeomKind, 'BIN_2D', {\n get: GeomKind$BIN_2D_getInstance\n });\n Object.defineProperty(GeomKind, 'MAP', {\n get: GeomKind$MAP_getInstance\n });\n Object.defineProperty(GeomKind, 'ERROR_BAR', {\n get: GeomKind$ERROR_BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'CROSS_BAR', {\n get: GeomKind$CROSS_BAR_getInstance\n });\n Object.defineProperty(GeomKind, 'LINE_RANGE', {\n get: GeomKind$LINE_RANGE_getInstance\n });\n Object.defineProperty(GeomKind, 'POINT_RANGE', {\n get: GeomKind$POINT_RANGE_getInstance\n });\n Object.defineProperty(GeomKind, 'POLYGON', {\n get: GeomKind$POLYGON_getInstance\n });\n Object.defineProperty(GeomKind, 'AB_LINE', {\n get: GeomKind$AB_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'H_LINE', {\n get: GeomKind$H_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'V_LINE', {\n get: GeomKind$V_LINE_getInstance\n });\n Object.defineProperty(GeomKind, 'BOX_PLOT', {\n get: GeomKind$BOX_PLOT_getInstance\n });\n Object.defineProperty(GeomKind, 'LIVE_MAP', {\n get: GeomKind$LIVE_MAP_getInstance\n });\n Object.defineProperty(GeomKind, 'POINT', {\n get: GeomKind$POINT_getInstance\n });\n Object.defineProperty(GeomKind, 'RIBBON', {\n get: GeomKind$RIBBON_getInstance\n });\n Object.defineProperty(GeomKind, 'AREA', {\n get: GeomKind$AREA_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY', {\n get: GeomKind$DENSITY_getInstance\n });\n Object.defineProperty(GeomKind, 'CONTOUR', {\n get: GeomKind$CONTOUR_getInstance\n });\n Object.defineProperty(GeomKind, 'CONTOURF', {\n get: GeomKind$CONTOURF_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY2D', {\n get: GeomKind$DENSITY2D_getInstance\n });\n Object.defineProperty(GeomKind, 'DENSITY2DF', {\n get: GeomKind$DENSITY2DF_getInstance\n });\n Object.defineProperty(GeomKind, 'JITTER', {\n get: GeomKind$JITTER_getInstance\n });\n Object.defineProperty(GeomKind, 'FREQPOLY', {\n get: GeomKind$FREQPOLY_getInstance\n });\n Object.defineProperty(GeomKind, 'STEP', {\n get: GeomKind$STEP_getInstance\n });\n Object.defineProperty(GeomKind, 'RECT', {\n get: GeomKind$RECT_getInstance\n });\n Object.defineProperty(GeomKind, 'SEGMENT', {\n get: GeomKind$SEGMENT_getInstance\n });\n Object.defineProperty(GeomKind, 'TEXT', {\n get: GeomKind$TEXT_getInstance\n });\n Object.defineProperty(GeomKind, 'RASTER', {\n get: GeomKind$RASTER_getInstance\n });\n Object.defineProperty(GeomKind, 'IMAGE', {\n get: GeomKind$IMAGE_getInstance\n });\n package$base.GeomKind = GeomKind;\n Object.defineProperty(package$base, 'GeomMeta', {\n get: GeomMeta_getInstance\n });\n package$base.PositionAdjustment = PositionAdjustment;\n Scale.Builder = Scale$Builder;\n package$base.Scale = Scale;\n package$base.Stat = Stat;\n package$base.StatContext = StatContext;\n package$base.Transform = Transform;\n var package$aes = package$base.aes || (package$base.aes = {});\n Object.defineProperty(package$aes, 'AesInitValue', {\n get: AesInitValue_getInstance\n });\n Object.defineProperty(package$aes, 'AesScaling', {\n get: AesScaling_getInstance\n });\n package$aes.AesVisitor = AesVisitor;\n Object.defineProperty(AestheticsBuilder, 'Companion', {\n get: AestheticsBuilder$Companion_getInstance\n });\n package$aes.AestheticsBuilder = AestheticsBuilder;\n Object.defineProperty(AestheticsDefaults, 'Companion', {\n get: AestheticsDefaults$Companion_getInstance\n });\n package$aes.AestheticsDefaults = AestheticsDefaults;\n Object.defineProperty(package$aes, 'AestheticsUtil', {\n get: AestheticsUtil_getInstance\n });\n package$aes.TypedIndexFunctionMap = TypedIndexFunctionMap;\n var package$coord = package$base.coord || (package$base.coord = {});\n Object.defineProperty(package$coord, 'Coords', {\n get: Coords_getInstance\n });\n package$coord.DefaultCoordinateSystem = DefaultCoordinateSystem;\n package$coord.Projection = Projection;\n var package$data = package$base.data || (package$base.data = {});\n Object.defineProperty(package$data, 'DataFrameUtil', {\n get: DataFrameUtil_getInstance\n });\n Object.defineProperty(package$data, 'Dummies', {\n get: Dummies_getInstance\n });\n Object.defineProperty(package$data, 'TransformVar', {\n get: TransformVar_getInstance\n });\n Object.defineProperty(ABLineGeom, 'Companion', {\n get: ABLineGeom$Companion_getInstance\n });\n var package$geom = package$base.geom || (package$base.geom = {});\n package$geom.ABLineGeom = ABLineGeom;\n Object.defineProperty(AreaGeom, 'Companion', {\n get: AreaGeom$Companion_getInstance\n });\n package$geom.AreaGeom = AreaGeom;\n Object.defineProperty(BarGeom, 'Companion', {\n get: BarGeom$Companion_getInstance\n });\n package$geom.BarGeom = BarGeom;\n Object.defineProperty(Bin2dGeom, 'Companion', {\n get: Bin2dGeom$Companion_getInstance\n });\n package$geom.Bin2dGeom = Bin2dGeom;\n Object.defineProperty(BoxplotGeom, 'Companion', {\n get: BoxplotGeom$Companion_getInstance\n });\n package$geom.BoxplotGeom = BoxplotGeom;\n Object.defineProperty(ContourGeom, 'Companion', {\n get: ContourGeom$Companion_getInstance\n });\n package$geom.ContourGeom = ContourGeom;\n Object.defineProperty(ContourfGeom, 'Companion', {\n get: ContourfGeom$Companion_getInstance\n });\n package$geom.ContourfGeom = ContourfGeom;\n Object.defineProperty(CrossBarGeom, 'Companion', {\n get: CrossBarGeom$Companion_getInstance\n });\n package$geom.CrossBarGeom = CrossBarGeom;\n Object.defineProperty(Density2dGeom, 'Companion', {\n get: Density2dGeom$Companion_getInstance\n });\n package$geom.Density2dGeom = Density2dGeom;\n Object.defineProperty(Density2dfGeom, 'Companion', {\n get: Density2dfGeom$Companion_getInstance\n });\n package$geom.Density2dfGeom = Density2dfGeom;\n Object.defineProperty(DensityGeom, 'Companion', {\n get: DensityGeom$Companion_getInstance\n });\n package$geom.DensityGeom = DensityGeom;\n Object.defineProperty(ErrorBarGeom, 'Companion', {\n get: ErrorBarGeom$Companion_getInstance\n });\n package$geom.ErrorBarGeom = ErrorBarGeom;\n Object.defineProperty(FilledCircleLegendKeyElementFactory, 'Companion', {\n get: FilledCircleLegendKeyElementFactory$Companion_getInstance\n });\n package$geom.FilledCircleLegendKeyElementFactory = FilledCircleLegendKeyElementFactory;\n package$geom.FilledSquareLegendKeyElementFactory = FilledSquareLegendKeyElementFactory;\n Object.defineProperty(FreqpolyGeom, 'Companion', {\n get: FreqpolyGeom$Companion_getInstance\n });\n package$geom.FreqpolyGeom = FreqpolyGeom;\n Object.defineProperty(GeomBase, 'Companion', {\n get: GeomBase$Companion_getInstance\n });\n package$geom.GeomBase = GeomBase;\n Object.defineProperty(HLineGeom, 'Companion', {\n get: HLineGeom$Companion_getInstance\n });\n package$geom.HLineGeom = HLineGeom;\n Object.defineProperty(HistogramGeom, 'Companion', {\n get: HistogramGeom$Companion_getInstance\n });\n package$geom.HistogramGeom = HistogramGeom;\n Object.defineProperty(ImageGeom, 'Companion', {\n get: ImageGeom$Companion_getInstance\n });\n package$geom.ImageGeom = ImageGeom;\n Object.defineProperty(JitterGeom, 'Companion', {\n get: JitterGeom$Companion_getInstance\n });\n package$geom.JitterGeom = JitterGeom;\n Object.defineProperty(LineGeom, 'Companion', {\n get: LineGeom$Companion_getInstance\n });\n package$geom.LineGeom = LineGeom;\n Object.defineProperty(LineRangeGeom, 'Companion', {\n get: LineRangeGeom$Companion_getInstance\n });\n package$geom.LineRangeGeom = LineRangeGeom;\n Object.defineProperty(LiveMapGeom, 'Companion', {\n get: LiveMapGeom$Companion_getInstance\n });\n package$geom.LiveMapGeom = LiveMapGeom;\n LiveMapProvider.LiveMapData = LiveMapProvider$LiveMapData;\n package$geom.LiveMapProvider = LiveMapProvider;\n Object.defineProperty(MapGeom, 'Companion', {\n get: MapGeom$Companion_getInstance\n });\n package$geom.MapGeom = MapGeom;\n Object.defineProperty(PathGeom, 'Companion', {\n get: PathGeom$Companion_getInstance\n });\n package$geom.PathGeom = PathGeom;\n Object.defineProperty(PieGeom, 'Companion', {\n get: PieGeom$Companion_getInstance\n });\n package$geom.PieGeom = PieGeom;\n Object.defineProperty(PointGeom, 'Companion', {\n get: PointGeom$Companion_getInstance\n });\n package$geom.PointGeom = PointGeom;\n package$geom.PointLegendKeyElementFactory = PointLegendKeyElementFactory;\n Object.defineProperty(PointRangeGeom, 'Companion', {\n get: PointRangeGeom$Companion_getInstance\n });\n package$geom.PointRangeGeom = PointRangeGeom;\n Object.defineProperty(PolygonGeom, 'Companion', {\n get: PolygonGeom$Companion_getInstance\n });\n package$geom.PolygonGeom = PolygonGeom;\n Object.defineProperty(RasterGeom, 'Companion', {\n get: RasterGeom$Companion_getInstance\n });\n package$geom.RasterGeom = RasterGeom;\n Object.defineProperty(RectGeom, 'Companion', {\n get: RectGeom$Companion_getInstance\n });\n package$geom.RectGeom = RectGeom;\n Object.defineProperty(RibbonGeom, 'Companion', {\n get: RibbonGeom$Companion_getInstance\n });\n package$geom.RibbonGeom = RibbonGeom;\n Object.defineProperty(SegmentGeom, 'Companion', {\n get: SegmentGeom$Companion_getInstance\n });\n package$geom.SegmentGeom = SegmentGeom;\n Object.defineProperty(SmoothGeom, 'Companion', {\n get: SmoothGeom$Companion_getInstance\n });\n package$geom.SmoothGeom = SmoothGeom;\n Object.defineProperty(StepGeom$Direction, 'HV', {\n get: StepGeom$Direction$HV_getInstance\n });\n Object.defineProperty(StepGeom$Direction, 'VH', {\n get: StepGeom$Direction$VH_getInstance\n });\n Object.defineProperty(StepGeom$Direction, 'Companion', {\n get: StepGeom$Direction$Companion_getInstance\n });\n StepGeom.Direction = StepGeom$Direction;\n Object.defineProperty(StepGeom, 'Companion', {\n get: StepGeom$Companion_getInstance\n });\n package$geom.StepGeom = StepGeom;\n Object.defineProperty(TextGeom, 'Companion', {\n get: TextGeom$Companion_getInstance\n });\n package$geom.TextGeom = TextGeom;\n package$geom.TextLegendKeyElementFactory = TextLegendKeyElementFactory;\n Object.defineProperty(TileGeom, 'Companion', {\n get: TileGeom$Companion_getInstance\n });\n package$geom.TileGeom = TileGeom;\n Object.defineProperty(VLineGeom, 'Companion', {\n get: VLineGeom$Companion_getInstance\n });\n package$geom.VLineGeom = VLineGeom;\n var package$legend = package$geom.legend || (package$geom.legend = {});\n package$legend.CompositeLegendKeyElementFactory = CompositeLegendKeyElementFactory;\n package$legend.GenericLegendKeyElementFactory = GenericLegendKeyElementFactory;\n package$legend.HLineLegendKeyElementFactory = HLineLegendKeyElementFactory;\n package$legend.VLineLegendKeyElementFactory = VLineLegendKeyElementFactory;\n Object.defineProperty(ArrowSpec$End, 'LAST', {\n get: ArrowSpec$End$LAST_getInstance\n });\n Object.defineProperty(ArrowSpec$End, 'FIRST', {\n get: ArrowSpec$End$FIRST_getInstance\n });\n Object.defineProperty(ArrowSpec$End, 'BOTH', {\n get: ArrowSpec$End$BOTH_getInstance\n });\n ArrowSpec.End = ArrowSpec$End;\n Object.defineProperty(ArrowSpec$Type, 'OPEN', {\n get: ArrowSpec$Type$OPEN_getInstance\n });\n Object.defineProperty(ArrowSpec$Type, 'CLOSED', {\n get: ArrowSpec$Type$CLOSED_getInstance\n });\n ArrowSpec.Type = ArrowSpec$Type;\n var package$util = package$geom.util || (package$geom.util = {});\n package$util.ArrowSpec = ArrowSpec;\n Object.defineProperty(package$util, 'BarTooltipHelper', {\n get: BarTooltipHelper_getInstance\n });\n Object.defineProperty(package$util, 'CrossBarHelper', {\n get: CrossBarHelper_getInstance\n });\n package$util.DataPointAestheticsDelegate = DataPointAestheticsDelegate;\n package$util.GeomCoord = GeomCoord;\n GeomHelper.SvgElementHelper = GeomHelper$SvgElementHelper;\n Object.defineProperty(GeomHelper, 'Companion', {\n get: GeomHelper$Companion_getInstance\n });\n package$util.GeomHelper = GeomHelper;\n Object.defineProperty(package$util, 'GeomUtil', {\n get: GeomUtil_getInstance\n });\n Object.defineProperty(package$util, 'HintColorUtil', {\n get: HintColorUtil_getInstance\n });\n HintsCollection$HintConfigFactory.HintConfig = HintsCollection$HintConfigFactory$HintConfig;\n HintsCollection.HintConfigFactory = HintsCollection$HintConfigFactory;\n package$util.HintsCollection = HintsCollection;\n Object.defineProperty(LinePathConstructor, 'Companion', {\n get: LinePathConstructor$Companion_getInstance\n });\n package$util.LinePathConstructor = LinePathConstructor;\n LinesHelper.PathInfo = LinesHelper$PathInfo;\n package$util.LinesHelper = LinesHelper;\n package$util.MappedAesthetics = MappedAesthetics;\n package$util.MultiPointData = MultiPointData;\n MultiPointDataConstructor.prototype.PointCollector = MultiPointDataConstructor$PointCollector;\n Object.defineProperty(package$util, 'MultiPointDataConstructor', {\n get: MultiPointDataConstructor_getInstance\n });\n package$util.RectTargetCollectorHelper = RectTargetCollectorHelper;\n package$util.RectanglesHelper = RectanglesHelper;\n var package$interact = package$base.interact || (package$base.interact = {});\n package$interact.ContextualMapping = ContextualMapping;\n package$interact.DataContext = DataContext;\n package$interact.GeomTarget = GeomTarget;\n Object.defineProperty(GeomTargetCollector$TooltipParams, 'Companion', {\n get: GeomTargetCollector$TooltipParams$Companion_getInstance\n });\n GeomTargetCollector.TooltipParams = GeomTargetCollector$TooltipParams;\n package$interact.GeomTargetCollector = GeomTargetCollector;\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'X', {\n get: GeomTargetLocator$LookupSpace$X_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'XY', {\n get: GeomTargetLocator$LookupSpace$XY_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupSpace, 'NONE', {\n get: GeomTargetLocator$LookupSpace$NONE_getInstance\n });\n GeomTargetLocator.LookupSpace = GeomTargetLocator$LookupSpace;\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'HOVER', {\n get: GeomTargetLocator$LookupStrategy$HOVER_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'NEAREST', {\n get: GeomTargetLocator$LookupStrategy$NEAREST_getInstance\n });\n Object.defineProperty(GeomTargetLocator$LookupStrategy, 'NONE', {\n get: GeomTargetLocator$LookupStrategy$NONE_getInstance\n });\n GeomTargetLocator.LookupStrategy = GeomTargetLocator$LookupStrategy;\n Object.defineProperty(GeomTargetLocator$LookupSpec, 'Companion', {\n get: GeomTargetLocator$LookupSpec$Companion_getInstance\n });\n GeomTargetLocator.LookupSpec = GeomTargetLocator$LookupSpec;\n GeomTargetLocator.LookupResult = GeomTargetLocator$LookupResult;\n package$interact.GeomTargetLocator = GeomTargetLocator;\n Object.defineProperty(HitShape$Kind, 'POINT', {\n get: HitShape$Kind$POINT_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'RECT', {\n get: HitShape$Kind$RECT_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'POLYGON', {\n get: HitShape$Kind$POLYGON_getInstance\n });\n Object.defineProperty(HitShape$Kind, 'PATH', {\n get: HitShape$Kind$PATH_getInstance\n });\n HitShape.Kind = HitShape$Kind;\n HitShape.DoubleCircle = HitShape$DoubleCircle;\n Object.defineProperty(HitShape, 'Companion', {\n get: HitShape$Companion_getInstance\n });\n package$interact.HitShape = HitShape;\n MappedDataAccess.MappedData = MappedDataAccess$MappedData;\n package$interact.MappedDataAccess = MappedDataAccess;\n package$interact.NullGeomTargetCollector = NullGeomTargetCollector;\n Object.defineProperty(TipLayoutHint$StemLength, 'NORMAL', {\n get: TipLayoutHint$StemLength$NORMAL_getInstance\n });\n Object.defineProperty(TipLayoutHint$StemLength, 'SHORT', {\n get: TipLayoutHint$StemLength$SHORT_getInstance\n });\n Object.defineProperty(TipLayoutHint$StemLength, 'NONE', {\n get: TipLayoutHint$StemLength$NONE_getInstance\n });\n TipLayoutHint.StemLength = TipLayoutHint$StemLength;\n Object.defineProperty(TipLayoutHint$Kind, 'VERTICAL_TOOLTIP', {\n get: TipLayoutHint$Kind$VERTICAL_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'HORIZONTAL_TOOLTIP', {\n get: TipLayoutHint$Kind$HORIZONTAL_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'CURSOR_TOOLTIP', {\n get: TipLayoutHint$Kind$CURSOR_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'X_AXIS_TOOLTIP', {\n get: TipLayoutHint$Kind$X_AXIS_TOOLTIP_getInstance\n });\n Object.defineProperty(TipLayoutHint$Kind, 'Y_AXIS_TOOLTIP', {\n get: TipLayoutHint$Kind$Y_AXIS_TOOLTIP_getInstance\n });\n TipLayoutHint.Kind = TipLayoutHint$Kind;\n Object.defineProperty(TipLayoutHint, 'Companion', {\n get: TipLayoutHint$Companion_getInstance\n });\n package$interact.TipLayoutHint = TipLayoutHint;\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'TOP', {\n get: TooltipAnchor$VerticalAnchor$TOP_getInstance\n });\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'BOTTOM', {\n get: TooltipAnchor$VerticalAnchor$BOTTOM_getInstance\n });\n Object.defineProperty(TooltipAnchor$VerticalAnchor, 'MIDDLE', {\n get: TooltipAnchor$VerticalAnchor$MIDDLE_getInstance\n });\n TooltipAnchor.VerticalAnchor = TooltipAnchor$VerticalAnchor;\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'LEFT', {\n get: TooltipAnchor$HorizontalAnchor$LEFT_getInstance\n });\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'RIGHT', {\n get: TooltipAnchor$HorizontalAnchor$RIGHT_getInstance\n });\n Object.defineProperty(TooltipAnchor$HorizontalAnchor, 'CENTER', {\n get: TooltipAnchor$HorizontalAnchor$CENTER_getInstance\n });\n TooltipAnchor.HorizontalAnchor = TooltipAnchor$HorizontalAnchor;\n package$interact.TooltipAnchor = TooltipAnchor;\n TooltipLineSpec.DataPoint = TooltipLineSpec$DataPoint;\n package$interact.TooltipLineSpec = TooltipLineSpec;\n Object.defineProperty(LivemapConstants$DisplayMode, 'POINT', {\n get: LivemapConstants$DisplayMode$POINT_getInstance\n });\n Object.defineProperty(LivemapConstants$DisplayMode, 'PIE', {\n get: LivemapConstants$DisplayMode$PIE_getInstance\n });\n Object.defineProperty(LivemapConstants$DisplayMode, 'BAR', {\n get: LivemapConstants$DisplayMode$BAR_getInstance\n });\n LivemapConstants.DisplayMode = LivemapConstants$DisplayMode;\n Object.defineProperty(LivemapConstants$Theme, 'COLOR', {\n get: LivemapConstants$Theme$COLOR_getInstance\n });\n Object.defineProperty(LivemapConstants$Theme, 'LIGHT', {\n get: LivemapConstants$Theme$LIGHT_getInstance\n });\n Object.defineProperty(LivemapConstants$Theme, 'DARK', {\n get: LivemapConstants$Theme$DARK_getInstance\n });\n LivemapConstants.Theme = LivemapConstants$Theme;\n Object.defineProperty(LivemapConstants$Projection, 'EPSG3857', {\n get: LivemapConstants$Projection$EPSG3857_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'EPSG4326', {\n get: LivemapConstants$Projection$EPSG4326_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'AZIMUTHAL', {\n get: LivemapConstants$Projection$AZIMUTHAL_getInstance\n });\n Object.defineProperty(LivemapConstants$Projection, 'CONIC', {\n get: LivemapConstants$Projection$CONIC_getInstance\n });\n LivemapConstants.Projection = LivemapConstants$Projection;\n var package$livemap = package$base.livemap || (package$base.livemap = {});\n package$livemap.LivemapConstants = LivemapConstants;\n package$livemap.LiveMapOptions = LiveMapOptions;\n var package$pos = package$base.pos || (package$base.pos = {});\n package$pos.DodgePos = DodgePos;\n package$pos.FillPos = FillPos;\n package$pos.JitterDodgePos = JitterDodgePos;\n Object.defineProperty(JitterPos, 'Companion', {\n get: JitterPos$Companion_getInstance\n });\n package$pos.JitterPos = JitterPos;\n Object.defineProperty(NudgePos, 'Companion', {\n get: NudgePos$Companion_getInstance\n });\n package$pos.NudgePos = NudgePos;\n Object.defineProperty(PositionAdjustments$Meta, 'IDENTITY', {\n get: PositionAdjustments$Meta$IDENTITY_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'DODGE', {\n get: PositionAdjustments$Meta$DODGE_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'STACK', {\n get: PositionAdjustments$Meta$STACK_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'FILL', {\n get: PositionAdjustments$Meta$FILL_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'JITTER', {\n get: PositionAdjustments$Meta$JITTER_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'NUDGE', {\n get: PositionAdjustments$Meta$NUDGE_getInstance\n });\n Object.defineProperty(PositionAdjustments$Meta, 'JITTER_DODGE', {\n get: PositionAdjustments$Meta$JITTER_DODGE_getInstance\n });\n PositionAdjustments.prototype.Meta = PositionAdjustments$Meta;\n Object.defineProperty(PositionAdjustments$StackingStrategy, 'SUM_POSITIVE_NEGATIVE', {\n get: PositionAdjustments$StackingStrategy$SUM_POSITIVE_NEGATIVE_getInstance\n });\n Object.defineProperty(PositionAdjustments$StackingStrategy, 'SPLIT_POSITIVE_NEGATIVE', {\n get: PositionAdjustments$StackingStrategy$SPLIT_POSITIVE_NEGATIVE_getInstance\n });\n PositionAdjustments.prototype.StackingStrategy = PositionAdjustments$StackingStrategy;\n Object.defineProperty(package$pos, 'PositionAdjustments', {\n get: PositionAdjustments_getInstance\n });\n Object.defineProperty(StackPos, 'Companion', {\n get: StackPos$Companion_getInstance\n });\n package$pos.StackPos = StackPos;\n var package$render = package$base.render || (package$base.render = {});\n package$render.LegendKeyElementFactory = LegendKeyElementFactory;\n package$render.SvgRoot = SvgRoot;\n var package$linetype = package$render.linetype || (package$render.linetype = {});\n package$linetype.LineType = LineType;\n Object.defineProperty(NamedLineType, 'BLANK', {\n get: NamedLineType$BLANK_getInstance\n });\n Object.defineProperty(NamedLineType, 'SOLID', {\n get: NamedLineType$SOLID_getInstance\n });\n Object.defineProperty(NamedLineType, 'DASHED', {\n get: NamedLineType$DASHED_getInstance\n });\n Object.defineProperty(NamedLineType, 'DOTTED', {\n get: NamedLineType$DOTTED_getInstance\n });\n Object.defineProperty(NamedLineType, 'DOTDASH', {\n get: NamedLineType$DOTDASH_getInstance\n });\n Object.defineProperty(NamedLineType, 'LONGDASH', {\n get: NamedLineType$LONGDASH_getInstance\n });\n Object.defineProperty(NamedLineType, 'TWODASH', {\n get: NamedLineType$TWODASH_getInstance\n });\n package$linetype.NamedLineType = NamedLineType;\n Object.defineProperty(NamedShape, 'STICK_SQUARE', {\n get: NamedShape$STICK_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE', {\n get: NamedShape$STICK_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_UP', {\n get: NamedShape$STICK_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_PLUS', {\n get: NamedShape$STICK_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CROSS', {\n get: NamedShape$STICK_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_DIAMOND', {\n get: NamedShape$STICK_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_DOWN', {\n get: NamedShape$STICK_TRIANGLE_DOWN_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_CROSS', {\n get: NamedShape$STICK_SQUARE_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_STAR', {\n get: NamedShape$STICK_STAR_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_DIAMOND_PLUS', {\n get: NamedShape$STICK_DIAMOND_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE_PLUS', {\n get: NamedShape$STICK_CIRCLE_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_TRIANGLE_UP_DOWN', {\n get: NamedShape$STICK_TRIANGLE_UP_DOWN_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_PLUS', {\n get: NamedShape$STICK_SQUARE_PLUS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_CIRCLE_CROSS', {\n get: NamedShape$STICK_CIRCLE_CROSS_getInstance\n });\n Object.defineProperty(NamedShape, 'STICK_SQUARE_TRIANGLE_UP', {\n get: NamedShape$STICK_SQUARE_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_SQUARE', {\n get: NamedShape$SOLID_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_CIRCLE', {\n get: NamedShape$SOLID_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_TRIANGLE_UP', {\n get: NamedShape$SOLID_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_DIAMOND', {\n get: NamedShape$SOLID_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'SOLID_CIRCLE_2', {\n get: NamedShape$SOLID_CIRCLE_2_getInstance\n });\n Object.defineProperty(NamedShape, 'BULLET', {\n get: NamedShape$BULLET_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_CIRCLE', {\n get: NamedShape$FILLED_CIRCLE_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_SQUARE', {\n get: NamedShape$FILLED_SQUARE_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_DIAMOND', {\n get: NamedShape$FILLED_DIAMOND_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_TRIANGLE_UP', {\n get: NamedShape$FILLED_TRIANGLE_UP_getInstance\n });\n Object.defineProperty(NamedShape, 'FILLED_TRIANGLE_DOWN', {\n get: NamedShape$FILLED_TRIANGLE_DOWN_getInstance\n });\n var package$point = package$render.point || (package$render.point = {});\n package$point.NamedShape = NamedShape;\n package$point.PointShape = PointShape;\n Object.defineProperty(package$point, 'PointShapeSvg', {\n get: PointShapeSvg_getInstance\n });\n Object.defineProperty(package$point, 'TinyPointShape', {\n get: TinyPointShape_getInstance\n });\n package$point.UpdatableShape = UpdatableShape;\n var package$symbol = package$point.symbol || (package$point.symbol = {});\n package$symbol.CircleGlyph = CircleGlyph;\n Object.defineProperty(CrossGlyph, 'Companion', {\n get: CrossGlyph$Companion_getInstance\n });\n package$symbol.CrossGlyph = CrossGlyph;\n package$symbol.DiamondGlyph = DiamondGlyph;\n package$symbol.Glyph = Glyph;\n package$symbol.GlyphPair = GlyphPair;\n Object.defineProperty(package$symbol, 'GlyphUtil', {\n get: GlyphUtil_getInstance\n });\n Object.defineProperty(package$symbol, 'Glyphs', {\n get: Glyphs_getInstance\n });\n package$symbol.MultiShapeGlyph = MultiShapeGlyph;\n package$symbol.PlusGlyph = PlusGlyph;\n package$symbol.SingletonGlyph_init_i91tmr$ = SingletonGlyph_init;\n package$symbol.SingletonGlyph_init_e1sv3v$ = SingletonGlyph_init_0;\n package$symbol.SingletonGlyph = SingletonGlyph;\n package$symbol.SquareGlyph = SquareGlyph;\n Object.defineProperty(TriangleGlyph, 'Companion', {\n get: TriangleGlyph$Companion_getInstance\n });\n package$symbol.TriangleGlyph = TriangleGlyph;\n package$symbol.TwoShapeGlyph = TwoShapeGlyph;\n var package$svg = package$render.svg || (package$render.svg = {});\n package$svg.GroupComponent = GroupComponent;\n Object.defineProperty(LinePath, 'Companion', {\n get: LinePath$Companion_getInstance\n });\n package$svg.LinePath = LinePath;\n Object.defineProperty(package$svg, 'StrokeDashArraySupport', {\n get: StrokeDashArraySupport_getInstance\n });\n Object.defineProperty(SvgComponent, 'Companion', {\n get: SvgComponent$Companion_getInstance\n });\n package$svg.SvgComponent = SvgComponent;\n Object.defineProperty(package$svg, 'SvgUID', {\n get: SvgUID_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'LEFT', {\n get: TextLabel$HorizontalAnchor$LEFT_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'RIGHT', {\n get: TextLabel$HorizontalAnchor$RIGHT_getInstance\n });\n Object.defineProperty(TextLabel$HorizontalAnchor, 'MIDDLE', {\n get: TextLabel$HorizontalAnchor$MIDDLE_getInstance\n });\n TextLabel.HorizontalAnchor = TextLabel$HorizontalAnchor;\n Object.defineProperty(TextLabel$VerticalAnchor, 'TOP', {\n get: TextLabel$VerticalAnchor$TOP_getInstance\n });\n Object.defineProperty(TextLabel$VerticalAnchor, 'BOTTOM', {\n get: TextLabel$VerticalAnchor$BOTTOM_getInstance\n });\n Object.defineProperty(TextLabel$VerticalAnchor, 'CENTER', {\n get: TextLabel$VerticalAnchor$CENTER_getInstance\n });\n TextLabel.VerticalAnchor = TextLabel$VerticalAnchor;\n package$svg.TextLabel = TextLabel;\n var package$scale = package$base.scale || (package$base.scale = {});\n package$scale.AbstractScale = AbstractScale;\n package$scale.BreaksGenerator = BreaksGenerator;\n package$scale.ContinuousScale_init_lo18em$ = ContinuousScale_init;\n package$scale.ContinuousScale = ContinuousScale;\n package$scale.DiscreteScale_init_l9mre7$ = DiscreteScale_init;\n package$scale.DiscreteScale = DiscreteScale;\n Object.defineProperty(package$scale, 'MapperUtil', {\n get: MapperUtil_getInstance\n });\n Object.defineProperty(package$scale, 'Mappers', {\n get: Mappers_getInstance\n });\n Object.defineProperty(ScaleBreaks, 'Companion', {\n get: ScaleBreaks$Companion_getInstance\n });\n package$scale.ScaleBreaks = ScaleBreaks;\n Object.defineProperty(package$scale, 'ScaleUtil', {\n get: ScaleUtil_getInstance\n });\n Object.defineProperty(package$scale, 'Scales', {\n get: Scales_getInstance\n });\n var package$breaks = package$scale.breaks || (package$scale.breaks = {});\n package$breaks.BreaksHelperBase = BreaksHelperBase;\n package$breaks.DateTimeBreaksHelper = DateTimeBreaksHelper;\n Object.defineProperty(LinearBreaksHelper, 'Companion', {\n get: LinearBreaksHelper$Companion_getInstance\n });\n package$breaks.LinearBreaksHelper = LinearBreaksHelper;\n package$breaks.NumericBreakFormatter = NumericBreakFormatter;\n package$breaks.QuantizeScale = QuantizeScale;\n Object.defineProperty(package$breaks, 'ScaleBreaksUtil', {\n get: ScaleBreaksUtil_getInstance\n });\n package$breaks.TimeScaleTickFormatterFactory = TimeScaleTickFormatterFactory;\n package$breaks.WithFiniteOrderedOutput = WithFiniteOrderedOutput;\n var package$transform = package$scale.transform || (package$scale.transform = {});\n package$transform.DateTimeBreaksGen = DateTimeBreaksGen;\n package$transform.FunTransform = FunTransform;\n package$transform.IdentityTransform = IdentityTransform;\n Object.defineProperty(LinearBreaksGen, 'Companion', {\n get: LinearBreaksGen$Companion_getInstance\n });\n package$transform.LinearBreaksGen = LinearBreaksGen;\n Object.defineProperty(Log10Transform, 'Companion', {\n get: Log10Transform$Companion_getInstance\n });\n package$transform.Log10Transform = Log10Transform;\n Object.defineProperty(NonlinearBreaksGen, 'Companion', {\n get: NonlinearBreaksGen$Companion_getInstance\n });\n package$transform.NonlinearBreaksGen = NonlinearBreaksGen;\n package$transform.ReverseTransform = ReverseTransform;\n package$transform.SqrtTransform = SqrtTransform;\n Transforms.prototype.BreaksGeneratorForTransformedDomain = Transforms$BreaksGeneratorForTransformedDomain;\n Object.defineProperty(package$transform, 'Transforms', {\n get: Transforms_getInstance\n });\n Object.defineProperty(AbstractDensity2dStat, 'Companion', {\n get: AbstractDensity2dStat$Companion_getInstance\n });\n var package$stat = package$base.stat || (package$base.stat = {});\n package$stat.AbstractDensity2dStat = AbstractDensity2dStat;\n package$stat.BaseStat = BaseStat;\n Object.defineProperty(Bin2dStat, 'Companion', {\n get: Bin2dStat$Companion_getInstance\n });\n Bin2dStat.Bins2dData = Bin2dStat$Bins2dData;\n Bin2dStat.Bins2dWeightedCounts = Bin2dStat$Bins2dWeightedCounts;\n package$stat.Bin2dStat = Bin2dStat;\n Object.defineProperty(BinStat$XPosKind, 'NONE', {\n get: BinStat$XPosKind$NONE_getInstance\n });\n Object.defineProperty(BinStat$XPosKind, 'CENTER', {\n get: BinStat$XPosKind$CENTER_getInstance\n });\n Object.defineProperty(BinStat$XPosKind, 'BOUNDARY', {\n get: BinStat$XPosKind$BOUNDARY_getInstance\n });\n BinStat.XPosKind = BinStat$XPosKind;\n Object.defineProperty(BinStat, 'Companion', {\n get: BinStat$Companion_getInstance\n });\n package$stat.BinStat = BinStat;\n BinStatUtil.prototype.BinOptions = BinStatUtil$BinOptions;\n BinStatUtil.prototype.CountAndWidth = BinStatUtil$CountAndWidth;\n BinStatUtil.prototype.BinsData = BinStatUtil$BinsData;\n Object.defineProperty(package$stat, 'BinStatUtil', {\n get: BinStatUtil_getInstance\n });\n Object.defineProperty(BoxplotStat, 'Companion', {\n get: BoxplotStat$Companion_getInstance\n });\n package$stat.BoxplotStat = BoxplotStat;\n Object.defineProperty(Contour, 'Companion', {\n get: Contour$Companion_getInstance\n });\n package$stat.Contour = Contour;\n Object.defineProperty(ContourFillHelper, 'Companion', {\n get: ContourFillHelper$Companion_getInstance\n });\n package$stat.ContourFillHelper = ContourFillHelper;\n Object.defineProperty(ContourStat, 'Companion', {\n get: ContourStat$Companion_getInstance\n });\n package$stat.ContourStat = ContourStat;\n Object.defineProperty(package$stat, 'ContourStatUtil', {\n get: ContourStatUtil_getInstance\n });\n Object.defineProperty(ContourfStat, 'Companion', {\n get: ContourfStat$Companion_getInstance\n });\n package$stat.ContourfStat = ContourfStat;\n Object.defineProperty(CorrelationStat$Method, 'PEARSON', {\n get: CorrelationStat$Method$PEARSON_getInstance\n });\n Object.defineProperty(CorrelationStat$Method, 'SPEARMAN', {\n get: CorrelationStat$Method$SPEARMAN_getInstance\n });\n Object.defineProperty(CorrelationStat$Method, 'KENDALL', {\n get: CorrelationStat$Method$KENDALL_getInstance\n });\n CorrelationStat.Method = CorrelationStat$Method;\n Object.defineProperty(CorrelationStat$Type, 'FULL', {\n get: CorrelationStat$Type$FULL_getInstance\n });\n Object.defineProperty(CorrelationStat$Type, 'UPPER', {\n get: CorrelationStat$Type$UPPER_getInstance\n });\n Object.defineProperty(CorrelationStat$Type, 'LOWER', {\n get: CorrelationStat$Type$LOWER_getInstance\n });\n CorrelationStat.Type = CorrelationStat$Type;\n Object.defineProperty(CorrelationStat, 'Companion', {\n get: CorrelationStat$Companion_getInstance\n });\n package$stat.CorrelationStat = CorrelationStat;\n Object.defineProperty(package$stat, 'CorrelationUtil', {\n get: CorrelationUtil_getInstance\n });\n Object.defineProperty(CountStat, 'Companion', {\n get: CountStat$Companion_getInstance\n });\n package$stat.CountStat = CountStat;\n package$stat.Density2dStat = Density2dStat;\n package$stat.Density2dfStat = Density2dfStat;\n Object.defineProperty(DensityStat$Kernel, 'GAUSSIAN', {\n get: DensityStat$Kernel$GAUSSIAN_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'RECTANGULAR', {\n get: DensityStat$Kernel$RECTANGULAR_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'TRIANGULAR', {\n get: DensityStat$Kernel$TRIANGULAR_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'BIWEIGHT', {\n get: DensityStat$Kernel$BIWEIGHT_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'EPANECHNIKOV', {\n get: DensityStat$Kernel$EPANECHNIKOV_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'OPTCOSINE', {\n get: DensityStat$Kernel$OPTCOSINE_getInstance\n });\n Object.defineProperty(DensityStat$Kernel, 'COSINE', {\n get: DensityStat$Kernel$COSINE_getInstance\n });\n DensityStat.Kernel = DensityStat$Kernel;\n Object.defineProperty(DensityStat$BandWidthMethod, 'NRD0', {\n get: DensityStat$BandWidthMethod$NRD0_getInstance\n });\n Object.defineProperty(DensityStat$BandWidthMethod, 'NRD', {\n get: DensityStat$BandWidthMethod$NRD_getInstance\n });\n DensityStat.BandWidthMethod = DensityStat$BandWidthMethod;\n Object.defineProperty(DensityStat, 'Companion', {\n get: DensityStat$Companion_getInstance\n });\n package$stat.DensityStat = DensityStat;\n Object.defineProperty(package$stat, 'DensityStatUtil', {\n get: DensityStatUtil_getInstance\n });\n package$stat.FiveNumberSummary_init_d3e2cz$ = FiveNumberSummary_init;\n package$stat.FiveNumberSummary_init_1lq62i$ = FiveNumberSummary_init_0;\n package$stat.FiveNumberSummary = FiveNumberSummary;\n package$stat.MultiOrdering = MultiOrdering;\n package$stat.SimpleStatContext = SimpleStatContext;\n Object.defineProperty(SmoothStat$Method, 'LM', {\n get: SmoothStat$Method$LM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'GLM', {\n get: SmoothStat$Method$GLM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'GAM', {\n get: SmoothStat$Method$GAM_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'LOESS', {\n get: SmoothStat$Method$LOESS_getInstance\n });\n Object.defineProperty(SmoothStat$Method, 'RLM', {\n get: SmoothStat$Method$RLM_getInstance\n });\n SmoothStat.Method = SmoothStat$Method;\n Object.defineProperty(SmoothStat, 'Companion', {\n get: SmoothStat$Companion_getInstance\n });\n package$stat.SmoothStat = SmoothStat;\n Object.defineProperty(package$stat, 'Stats', {\n get: Stats_getInstance\n });\n Object.defineProperty(AbstractRealDistribution, 'Companion', {\n get: AbstractRealDistribution$Companion_getInstance\n });\n var package$math3 = package$stat.math3 || (package$stat.math3 = {});\n package$math3.AbstractRealDistribution = AbstractRealDistribution;\n package$math3.AbstractUnivariateSolver_init_14dthe$ = AbstractUnivariateSolver_init;\n package$math3.AbstractUnivariateSolver_init_lu1900$ = AbstractUnivariateSolver_init_0;\n package$math3.AbstractUnivariateSolver_init_yvo9jy$ = AbstractUnivariateSolver_init_1;\n package$math3.AbstractUnivariateSolver = AbstractUnivariateSolver;\n Object.defineProperty(AllowedSolution, 'ANY_SIDE', {\n get: AllowedSolution$ANY_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'LEFT_SIDE', {\n get: AllowedSolution$LEFT_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'RIGHT_SIDE', {\n get: AllowedSolution$RIGHT_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'BELOW_SIDE', {\n get: AllowedSolution$BELOW_SIDE_getInstance\n });\n Object.defineProperty(AllowedSolution, 'ABOVE_SIDE', {\n get: AllowedSolution$ABOVE_SIDE_getInstance\n });\n package$math3.AllowedSolution = AllowedSolution;\n Object.defineProperty(BaseAbstractUnivariateSolver, 'Companion', {\n get: BaseAbstractUnivariateSolver$Companion_getInstance\n });\n package$math3.BaseAbstractUnivariateSolver_init_8vzwiz$ = BaseAbstractUnivariateSolver_init;\n package$math3.BaseAbstractUnivariateSolver = BaseAbstractUnivariateSolver;\n package$math3.BaseUnivariateSolver = BaseUnivariateSolver;\n Object.defineProperty(package$math3, 'Beta', {\n get: Beta_getInstance\n });\n package$math3.BlockRealMatrix_init_vux9f0$ = BlockRealMatrix_init;\n package$math3.BlockRealMatrix_init_n8oub7$ = BlockRealMatrix_init_0;\n package$math3.BlockRealMatrix = BlockRealMatrix;\n package$math3.BracketedUnivariateSolver = BracketedUnivariateSolver;\n Object.defineProperty(BrentSolver, 'Companion', {\n get: BrentSolver$Companion_getInstance\n });\n package$math3.BrentSolver_init_14dthe$ = BrentSolver_init;\n package$math3.BrentSolver_init_lu1900$ = BrentSolver_init_0;\n package$math3.BrentSolver_init_yvo9jy$ = BrentSolver_init_1;\n package$math3.BrentSolver = BrentSolver;\n Object.defineProperty(ContinuedFraction, 'Companion', {\n get: ContinuedFraction$Companion_getInstance\n });\n package$math3.ContinuedFraction = ContinuedFraction;\n package$math3.mean_gf7tl1$ = mean;\n package$math3.correlationPearson_g9g6do$ = correlationPearson;\n Object.defineProperty(ForsythePolynomialGenerator, 'Companion', {\n get: ForsythePolynomialGenerator$Companion_getInstance\n });\n package$math3.ForsythePolynomialGenerator = ForsythePolynomialGenerator;\n Object.defineProperty(package$math3, 'Gamma', {\n get: Gamma_getInstance\n });\n Incrementor.MaxCountExceededCallback = Incrementor$MaxCountExceededCallback;\n package$math3.Incrementor = Incrementor;\n Object.defineProperty(LoessInterpolator, 'Companion', {\n get: LoessInterpolator$Companion_getInstance\n });\n package$math3.LoessInterpolator = LoessInterpolator;\n Object.defineProperty(MathArrays$OrderDirection, 'INCREASING', {\n get: MathArrays$OrderDirection$INCREASING_getInstance\n });\n Object.defineProperty(MathArrays$OrderDirection, 'DECREASING', {\n get: MathArrays$OrderDirection$DECREASING_getInstance\n });\n MathArrays.prototype.OrderDirection = MathArrays$OrderDirection;\n Object.defineProperty(package$math3, 'MathArrays', {\n get: MathArrays_getInstance\n });\n Object.defineProperty(package$math3, 'Percentile', {\n get: Percentile_getInstance\n });\n package$math3.PolynomialFunction = PolynomialFunction;\n package$math3.times_gax024$ = times;\n package$math3.PolynomialSplineFunction = PolynomialSplineFunction;\n Object.defineProperty(package$math3, 'Precision', {\n get: Precision_getInstance\n });\n package$math3.RealDistribution = RealDistribution;\n package$math3.SplineInterpolator = SplineInterpolator;\n Object.defineProperty(TDistribution, 'Companion', {\n get: TDistribution$Companion_getInstance\n });\n package$math3.TDistribution = TDistribution;\n package$math3.UnivariateFunction = UnivariateFunction;\n package$math3.UnivariateSolver = UnivariateSolver;\n Object.defineProperty(package$math3, 'UnivariateSolverUtils', {\n get: UnivariateSolverUtils_getInstance\n });\n var package$regression = package$stat.regression || (package$stat.regression = {});\n package$regression.EvalResult = EvalResult;\n package$regression.LinearRegression = LinearRegression;\n package$regression.LocalPolynomialRegression = LocalPolynomialRegression;\n Object.defineProperty(PolynomialRegression, 'Companion', {\n get: PolynomialRegression$Companion_getInstance\n });\n package$regression.PolynomialRegression = PolynomialRegression;\n package$regression.RegressionEvaluator = RegressionEvaluator;\n Object.defineProperty(package$regression, 'RegressionUtil', {\n get: RegressionUtil_getInstance\n });\n package$regression.allFinite_10sy24$ = allFinite;\n package$regression.averageByX_10sy24$ = averageByX_0;\n var package$util_0 = package$base.util || (package$base.util = {});\n package$util_0.MutableDouble = MutableDouble;\n package$util_0.MutableInteger = MutableInteger;\n Object.defineProperty(package$util_0, 'SamplingUtil', {\n get: SamplingUtil_getInstance\n });\n AestheticsBuilder$MyDataPointAesthetics.prototype.defined_896ixz$ = DataPointAesthetics.prototype.defined_896ixz$;\n DefaultCoordinateSystem.prototype.isPointInLimits_k2qmv6$ = CoordinateSystem.prototype.isPointInLimits_k2qmv6$;\n DefaultCoordinateSystem.prototype.isRectInLimits_fd842m$ = CoordinateSystem.prototype.isRectInLimits_fd842m$;\n DefaultCoordinateSystem.prototype.isPathInLimits_f6t8kh$ = CoordinateSystem.prototype.isPathInLimits_f6t8kh$;\n DefaultCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$;\n DataPointAestheticsDelegate.prototype.defined_896ixz$ = DataPointAesthetics.prototype.defined_896ixz$;\n ErrorBarGeom$MyLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n FilledSquareLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n GenericLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n CrossBarLegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$ = LegendKeyElementFactory.prototype.minimumKeySize_l6g9mh$;\n NullGeomTargetCollector.prototype.addPoint_cnsimy$ = GeomTargetCollector.prototype.addPoint_cnsimy$;\n NullGeomTargetCollector.prototype.addRectangle_bxzvr8$ = GeomTargetCollector.prototype.addRectangle_bxzvr8$;\n NullGeomTargetCollector.prototype.addPath_sa5m83$ = GeomTargetCollector.prototype.addPath_sa5m83$;\n NullGeomTargetCollector.prototype.addPolygon_sa5m83$ = GeomTargetCollector.prototype.addPolygon_sa5m83$;\n Object.defineProperty(DodgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(FillPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(JitterDodgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(JitterPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(NudgePos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n Object.defineProperty(StackPos.prototype, 'isIdentity', Object.getOwnPropertyDescriptor(PositionAdjustment.prototype, 'isIdentity'));\n FunTransform.prototype.createApplicableDomain_yrwdxb$ = ContinuousTransform.prototype.createApplicableDomain_yrwdxb$;\n BaseStat.prototype.apply_kdy6bf$ = Stat.prototype.apply_kdy6bf$;\n Kotlin.defineModule('lets-plot-plot-base-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/regex/RegexExtensions.kt?c518","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/collections.kt?4ea3","webpack://LetsPlot/./kotlin-dce-dev/js/src/generated/_ArraysJs.kt?eaa5","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Sets.kt?72fd","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/./kotlin-dce-dev/runtime/arrayUtils.kt?7b24","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/SmoothStat.kt?7c46","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AbstractRealDistribution.kt?ba90","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Precision.kt?5144","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/TDistribution.kt?c7fe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/Aes.kt?8728","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/ContinuousTransform.kt?2dfa","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/CoordinateSystem.kt?8d7b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DataFrame.kt?df88","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DataPointAesthetics.kt?c580","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/DiscreteTransform.kt?6dca","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/GeomKind.kt?293a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/GeomMeta.kt?067c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/PositionAdjustment.kt?e192","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/Stat.kt?4a27","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesInitValue.kt?c3bd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesScaling.kt?4c71","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AesVisitor.kt?1c22","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsBuilder.kt?944d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsDefaults.kt?e3ac","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/AestheticsUtil.kt?9b58","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/aes/TypedIndexFunctionMap.kt?bf9b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/coord/Coords.kt?5830","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/coord/DefaultCoordinateSystem.kt?9625","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/DataFrameUtil.kt?9bbf","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/Dummies.kt?9be2","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/data/TransformVar.kt?edd7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ABLineGeom.kt?df41","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/AreaGeom.kt?8e6e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/BarGeom.kt?7377","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Bin2dGeom.kt?dfa2","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/BoxplotGeom.kt?dadc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ContourGeom.kt?036e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ContourfGeom.kt?34a7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/CrossBarGeom.kt?3778","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Density2dGeom.kt?9ae3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/Density2dfGeom.kt?fcc8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/DensityGeom.kt?b1fe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ErrorBarGeom.kt?047a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FilledCircleLegendKeyElementFactory.kt?58d8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FilledSquareLegendKeyElementFactory.kt?0054","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/FreqpolyGeom.kt?81ce","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/GeomBase.kt?5d97","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/HLineGeom.kt?1383","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/HistogramGeom.kt?8b2c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/ImageGeom.kt?228f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/JitterGeom.kt?5b94","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LineGeom.kt?0b0a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LineRangeGeom.kt?e195","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LiveMapGeom.kt?ec04","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/LiveMapProvider.kt?11d3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/MapGeom.kt?ddd6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PathGeom.kt?cff4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PieGeom.kt?2576","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointGeom.kt?b4c8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointLegendKeyElementFactory.kt?01ff","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PointRangeGeom.kt?ab23","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/PolygonGeom.kt?7098","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RasterGeom.kt?f1dd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RectGeom.kt?c31f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/RibbonGeom.kt?cb22","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/SegmentGeom.kt?ec3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/SmoothGeom.kt?cfd6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/StepGeom.kt?fbc0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TextGeom.kt?0059","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TextLegendKeyElementFactory.kt?2f2b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/TileGeom.kt?f47a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/VLineGeom.kt?200c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/CompositeLegendKeyElementFactory.kt?3ec9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/GenericLegendKeyElementFactory.kt?7ef1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/HLineLegendKeyElementFactory.kt?2d5a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/legend/VLineLegendKeyElementFactory.kt?f68f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/ArrowSpec.kt?a3d4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/BarTooltipHelper.kt?a4cc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/CrossBarHelper.kt?beb4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/DataPointAestheticsDelegate.kt?c6e6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomCoord.kt?8d6b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomHelper.kt?6341","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/GeomUtil.kt?9dfe","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/HintColorUtil.kt?9cdc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/HintsCollection.kt?daea","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/LinePathConstructor.kt?72dd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/LinesHelper.kt?71fd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MappedAesthetics.kt?6d62","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MultiPointData.kt?95f3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/MultiPointDataConstructor.kt?73cb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/RectTargetCollectorHelper.kt?cfb9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/geom/util/RectanglesHelper.kt?8be6","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/ContextualMapping.kt?02c0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/DataContext.kt?963c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTarget.kt?6e3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTargetCollector.kt?811e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/GeomTargetLocator.kt?d61c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/HitShape.kt?1ceb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/MappedDataAccess.kt?fc6b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/NullGeomTargetCollector.kt?840f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TipLayoutHint.kt?ccb3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TooltipAnchor.kt?41b4","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/interact/TooltipLineSpec.kt?f604","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/livemap/LiveMapConstants.kt?175c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/livemap/LiveMapOptions.kt?931a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/DodgePos.kt?d8e1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/FillPos.kt?05e9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/JitterDodgePos.kt?ce83","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/JitterPos.kt?8738","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/NudgePos.kt?4007","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/PositionAdjustments.kt?c624","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/pos/StackPos.kt?9b3a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/LegendKeyElementFactory.kt?c96c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/linetype/NamedLineType.kt?b1ab","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/NamedShape.kt?0732","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/PointShapeSvg.kt?d2b2","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/TinyPointShape.kt?172f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/CircleGlyph.kt?fb44","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/CrossGlyph.kt?5e61","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/DiamondGlyph.kt?ecd9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/GlyphPair.kt?7db5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/GlyphUtil.kt?9fe5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/Glyphs.kt?a9c9","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/MultiShapeGlyph.kt?0058","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/PlusGlyph.kt?b054","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/SingletonGlyph.kt?ebd3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/SquareGlyph.kt?444a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/TriangleGlyph.kt?03be","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/point/symbol/TwoShapeGlyph.kt?0f95","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/GroupComponent.kt?ff2b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/LinePath.kt?712e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/StrokeDashArraySupport.kt?ade8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/SvgComponent.kt?532b","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/SvgUID.kt?db3c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/render/svg/TextLabel.kt?dfd8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/AbstractScale.kt?f6da","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ContinuousScale.kt?5f80","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/DiscreteScale.kt?6278","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/MapperUtil.kt?3014","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/Mappers.kt?4d4f","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ScaleBreaks.kt?f0e3","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/ScaleUtil.kt?92ef","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/Scales.kt?adfd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/BreaksHelperBase.kt?b5f0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/DateTimeBreaksHelper.kt?4f9d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/LinearBreaksHelper.kt?37ec","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/NumericBreakFormatter.kt?7aad","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/QuantizeScale.kt?b64c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/ScaleBreaksUtil.kt?6a0c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/breaks/TimeScaleTickFormatterFactory.kt?ca96","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/DateTimeBreaksGen.kt?d034","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/FunTransform.kt?2ab0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/IdentityTransform.kt?0db0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/LinearBreaksGen.kt?4776","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/Log10Transform.kt?c338","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/NonlinearBreaksGen.kt?849c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/ReverseTransform.kt?382d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/SqrtTransform.kt?8eca","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/scale/transform/Transforms.kt?b3c5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/AbstractDensity2dStat.kt?e0bc","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BaseStat.kt?5213","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Bin2dStat.kt?6772","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BinStat.kt?b273","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BinStatUtil.kt?609d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/BoxplotStat.kt?0218","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Contour.kt?f77d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourFillHelper.kt?a1e1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourStat.kt?c564","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourStatUtil.kt?f70a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/ContourfStat.kt?82c7","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CorrelationStat.kt?e116","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CorrelationUtil.kt?5453","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/CountStat.kt?0579","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Density2dStat.kt?aeda","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Density2dfStat.kt?05a8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/DensityStat.kt?4c4e","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/DensityStatUtil.kt?5534","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/FiveNumberSummary.kt?e434","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/MultiOrdering.kt?6800","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/SimpleStatContext.kt?f655","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/Stats.kt?ad45","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AbstractUnivariateSolver.kt?d821","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/AllowedSolution.kt?7261","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BaseAbstractUnivariateSolver.kt?c4e0","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Beta.kt?6641","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BlockRealMatrix.kt?a1fb","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/BrentSolver.kt?cca1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/ContinuedFraction.kt?c04a","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Correlation.kt?967c","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/ForsythePolynomialGenerator.kt?0296","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Gamma.kt?03ee","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Incrementor.kt?d8b5","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/LoessInterpolator.kt?bae1","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/MathArrays.kt?4356","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/Percentile.kt?4070","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/PolynomialFunction.kt?2951","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/PolynomialSplineFunction.kt?5c81","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/SplineInterpolator.kt?ecd8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/math3/UnivariateSolverUtils.kt?ea94","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/EvalResult.kt?c1c8","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/LinearRegression.kt?d1cd","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/LocalPolynomialRegression.kt?825d","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/PolynomialRegression.kt?5683","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/RegressionEvaluator.kt?0854","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/stat/regression/RegressionUtil.kt?55de","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/MutableDouble.kt?3647","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/MutableInteger.kt?6d36","webpack://LetsPlot/../plot-base-portable/src/commonMain/kotlin/jetbrains/datalore/plot/base/util/SamplingUtil.kt?b752"],"names":[],"mappings":"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AAI,SAAU,mBAAV,QAAJ,C;ME5LxB,IAAI,CF6LY,uBAAU,SAAU,QAApB,CE7LhB,C;QACI,cF4L4C,uD;QE3L5C,MAAM,8BAAyB,OAAQ,WAAjC,C;OF8LG,gBADA,IADL,iBAAI,SAAU,SAAd,CACK,EAAI,wBAAW,SAAU,QAArB,CAAJ,C;MnB6uCN,kBAAU,oB;MA8BD,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QmB1wCO,IAAC,QnB2wCE,OmB3wCF,a;QnB2wCpB,UmB3wC8B,K;QlBgI3B,Y;QADP,cD6oCe,WC7oCH,WD6oCwB,GC7oCxB,C;QACL,IAAI,eAAJ,C;UACH,aD2oCuC,gB;UAA5B,WC1oCX,aD0oCgC,GC1oChC,EAAS,MAAT,C;UACA,iB;;UAEA,kB;;QDuoCA,mB;qBACA,I;QmB7wCyC,IAAI,UnB6wCrB,OmB7wCqB,a;QnB6wCxC,YAAL,IAAK,EmB7wCoD,OnB6wCpD,C;;MC7jCF,oBAAY,qBAAoB,YD+jChC,WC/jC4C,KAAZ,CAApB,C;MDgyBH,U;MAAA,SA+RT,WCjnCA,QDk1BS,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;qBCl1Ba,a;QAAkB,aDm1Bf,SCn1Be,I;QkB7JtB,IAAI,WnBg/B4B,SCl6BO,M;;QDyczD,oBAAS,gB;QA2FA,U;QAAA,SmBlnB8D,QnBknB9D,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UAAM,sBAAc,UAAd,C;YAAwB,aAAY,WAAI,SAAJ,C;;QA8X1C,YCn1Ba,aDm1Bb,UmBh/BuD,uBnBmnBhE,amBnnBgE,CnBg/BvD,C;;MmB/+BH,clB4JgB,akB5JhB,C;;MAEmB,WAAxB,iBAAI,SAAU,SAAd,CAAwB,EAAI,iBAAI,SAAU,QAAd,CAAJ,C;;IAEvB,sB;InBkhBF,oBAAS,gB;IA2FA,U;IAAA,+B;IAAhB,OAAgB,gBAAhB,C;MAAgB,6B;MAAM,ImB7mBJ,kBnB6mBkB,SmB7mBG,OAArB,KAAgC,kBnB6mBd,SmB7mBmC,MAArB,CnB6mB5B,C;QAAwB,aAAY,WAAI,SAAJ,C;;ImB3mBjD,kBADA,WnB6mBF,amB7mBE,EAAW,WAAU,yCAAV,EAA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A,iD;IACA,uD;IACA,uD;IACA,yD;IACA,2D;IACA,6D;IACA,qD;IACA,yD;IACA,iD;IACA,iD;IACA,uD;IACA,iD;IACA,qD;IACA,mD;;;EAjCA,qC;IAAA,qB;IAAA,6B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,oC;IAAA,qB;IAAA,4B;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,oC;IAAA,qB;IAAA,4B;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,2C;IAAA,qB;IAAA,mC;;;EACA,4C;IAAA,qB;IAAA,oC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,sC;IAAA,qB;IAAA,8B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,0C;IAAA,qB;IAAA,kC;;;EACA,2C;IAAA,qB;IAAA,mC;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,yC;IAAA,qB;IAAA,iC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,wC;IAAA,qB;IAAA,gC;;;EACA,qC;IAAA,qB;IAAA,6B;;;EACA,uC;IAAA,qB;IAAA,+B;;;EACA,sC;IAAA,qB;IAAA,8B;;;;;;;EAlCJ,2B;IAAA,qjC;;;EAAA,gC;IAAA,a;MAAA,Y;QAAA,kC;MAAA,Y;QAAA,kC;MAAA,c;QAAA,oC;MAAA,W;QAAA,iC;MAAA,iB;QAAA,uC;MAAA,Y;QAAA,kC;MAAA,c;QAAA,oC;MAAA,W;QAAA,iC;MAAA,iB;QAAA,uC;MAAA,iB;QAAA,uC;MAAA,kB;QAAA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","file":"./kotlin-dce-dev/lets-plot-plot-base-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\n/**\n * Converts the string into a regular expression [Regex] with the default options.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(): Regex = Regex(this)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified single [option].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(option: RegexOption): Regex = Regex(this, option)\n\n/**\n * Converts the string into a regular expression [Regex] with the specified set of [options].\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.toRegex(options: Set<RegexOption>): Regex = Regex(this, options)\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\nimport kotlin.comparisons.naturalOrder\nimport kotlin.random.Random\n\n/**\n * Returns the array if it's not `null`, or an empty array otherwise.\n * @sample samples.collections.Arrays.Usage.arrayOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Array<out T>?.orEmpty(): Array<out T> = this ?: emptyArray<T>()\n\n/**\n * Returns a *typed* array containing all of the elements of this collection.\n *\n * Allocates an array of runtime type `T` having its size equal to the size of this collection\n * and populates the array with the elements of this collection.\n * @sample samples.collections.Collections.Collections.collectionToTypedArray\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun <T> Collection<T>.toTypedArray(): Array<T> = copyToArray(this)\n\n@JsName(\"copyToArray\")\n@PublishedApi\ninternal fun <T> copyToArray(collection: Collection<T>): Array<T> {\n    return if (collection.asDynamic().toArray !== undefined)\n        collection.asDynamic().toArray().unsafeCast<Array<T>>()\n    else\n        copyToArrayImpl(collection).unsafeCast<Array<T>>()\n}\n\n@JsName(\"copyToArrayImpl\")\ninternal actual fun copyToArrayImpl(collection: Collection<*>): Array<Any?> {\n    val array = emptyArray<Any?>()\n    val iterator = collection.iterator()\n    while (iterator.hasNext())\n        array.asDynamic().push(iterator.next())\n    return array\n}\n\n@JsName(\"copyToExistingArrayImpl\")\ninternal actual fun <T> copyToArrayImpl(collection: Collection<*>, array: Array<T>): Array<T> {\n    if (array.size < collection.size)\n        return copyToArrayImpl(collection).unsafeCast<Array<T>>()\n\n    val iterator = collection.iterator()\n    var index = 0\n    while (iterator.hasNext()) {\n        array[index++] = iterator.next().unsafeCast<T>()\n    }\n    if (index < array.size) {\n        array[index] = null.unsafeCast<T>()\n    }\n    return array\n}\n\n\n/**\n * Returns an immutable list containing only the specified object [element].\n */\npublic fun <T> listOf(element: T): List<T> = arrayListOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E> {\n    return ArrayList<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E> {\n    checkBuilderCapacity(capacity)\n    return ArrayList<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable set containing only the specified object [element].\n */\npublic fun <T> setOf(element: T): Set<T> = hashSetOf(element)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    return LinkedHashSet<E>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Returns an immutable map, mapping only the specified key to the\n * specified value.\n */\npublic fun <K, V> mapOf(pair: Pair<K, V>): Map<K, V> = hashMapOf(pair)\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>().apply(builderAction).build()\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal actual inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    return LinkedHashMap<K, V>(capacity).apply(builderAction).build()\n}\n\n\n/**\n * Fills the list with the provided [value].\n *\n * Each element in the list gets replaced with the [value].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.fill(value: T): Unit {\n    for (index in 0..lastIndex) {\n        this[index] = value\n    }\n}\n\n/**\n * Randomly shuffles elements in this list.\n *\n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> MutableList<T>.shuffle(): Unit = shuffle(Random)\n\n/**\n * Returns a new list with the elements of this list randomly shuffled.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun <T> Iterable<T>.shuffled(): List<T> = toMutableList().apply { shuffle() }\n\n/**\n * Sorts elements in the list in-place according to their natural sort order.\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableList\n */\npublic actual fun <T : Comparable<T>> MutableList<T>.sort(): Unit {\n    collectionsSort(this, naturalOrder())\n}\n\n/**\n * Sorts elements in the list in-place according to the order specified with [comparator].\n *\n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n *\n * @sample samples.collections.Collections.Sorting.sortMutableListWith\n */\npublic actual fun <T> MutableList<T>.sortWith(comparator: Comparator<in T>): Unit {\n    collectionsSort(this, comparator)\n}\n\nprivate fun <T> collectionsSort(list: MutableList<T>, comparator: Comparator<in T>) {\n    if (list.size <= 1) return\n\n    val array = copyToArray(list)\n    sortArrayWith(array, comparator)\n\n    for (i in 0 until array.size) {\n        list[i] = array[i]\n    }\n}\n\ninternal actual fun <T> arrayOfNulls(reference: Array<T>, size: Int): Array<T> {\n    return arrayOfNulls<Any>(size).unsafeCast<Array<T>>()\n}\n\n@SinceKotlin(\"1.3\")\n@PublishedApi\n@JsName(\"arrayCopy\")\ninternal fun <T> arrayCopy(source: Array<out T>, destination: Array<in T>, destinationOffset: Int, startIndex: Int, endIndex: Int) {\n    AbstractList.checkRangeIndexes(startIndex, endIndex, source.size)\n    val rangeSize = endIndex - startIndex\n    AbstractList.checkRangeIndexes(destinationOffset, destinationOffset + rangeSize, destination.size)\n\n    if (js(\"ArrayBuffer\").isView(destination) && js(\"ArrayBuffer\").isView(source)) {\n        val subrange = source.asDynamic().subarray(startIndex, endIndex)\n        destination.asDynamic().set(subrange, destinationOffset)\n    } else {\n        if (source !== destination || destinationOffset <= startIndex) {\n            for (index in 0 until rangeSize) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        } else {\n            for (index in rangeSize - 1 downTo 0) {\n                destination[destinationOffset + index] = source[startIndex + index]\n            }\n        }\n    }\n}\n\n// no singleton map implementation in js, return map as is\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<K, V>.toSingletonMapOrSelf(): Map<K, V> = this\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <K, V> Map<out K, V>.toSingletonMap(): Map<K, V> = this.toMutableMap()\n\n\n@Suppress(\"NOTHING_TO_INLINE\")\ninternal actual inline fun <T> Array<out T>.copyToArrayOfAny(isVarargs: Boolean): Array<out Any?> =\n    if (isVarargs)\n    // no need to copy vararg array in JS\n        this\n    else\n        this.copyOf()\n\n\n\n@PublishedApi\ninternal actual fun checkIndexOverflow(index: Int): Int {\n    if (index < 0) {\n        throwIndexOverflow()\n    }\n    return index\n}\n\n@PublishedApi\ninternal actual fun checkCountOverflow(count: Int): Int {\n    if (count < 0) {\n        throwCountOverflow()\n    }\n    return count\n}\n\n\n/**\n * JS map and set implementations do not make use of capacities or load factors.\n */\n@PublishedApi\ninternal actual fun mapCapacity(expectedSize: Int) = expectedSize\n\n/**\n * Checks a collection builder function capacity argument.\n * In JS no validation is made in Map/Set constructor yet.\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@PublishedApi\ninternal fun checkBuilderCapacity(capacity: Int) {\n    require(capacity >= 0) { \"capacity must be non-negative.\" }\n}","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.js.*\nimport primitiveArrayConcat\nimport withType\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun <T> Array<out T>.elementAt(index: Int): T {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun ByteArray.elementAt(index: Int): Byte {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun ShortArray.elementAt(index: Int): Short {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun IntArray.elementAt(index: Int): Int {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun LongArray.elementAt(index: Int): Long {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun FloatArray.elementAt(index: Int): Float {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun DoubleArray.elementAt(index: Int): Double {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun BooleanArray.elementAt(index: Int): Boolean {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic actual fun CharArray.elementAt(index: Int): Char {\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"index: $index, size: $size}\") }\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic actual fun <T> Array<out T>.asList(): List<T> {\n    return ArrayList<T>(this.unsafeCast<Array<Any?>>())\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun ByteArray.asList(): List<Byte> {\n    return this.unsafeCast<Array<Byte>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun ShortArray.asList(): List<Short> {\n    return this.unsafeCast<Array<Short>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun IntArray.asList(): List<Int> {\n    return this.unsafeCast<Array<Int>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun LongArray.asList(): List<Long> {\n    return this.unsafeCast<Array<Long>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun FloatArray.asList(): List<Float> {\n    return this.unsafeCast<Array<Float>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun DoubleArray.asList(): List<Double> {\n    return this.unsafeCast<Array<Double>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\n@kotlin.internal.InlineOnly\npublic actual inline fun BooleanArray.asList(): List<Boolean> {\n    return this.unsafeCast<Array<Boolean>>().asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic actual fun CharArray.asList(): List<Char> {\n    return object : AbstractList<Char>(), RandomAccess {\n        override val size: Int get() = this@asList.size\n        override fun isEmpty(): Boolean = this@asList.isEmpty()\n        override fun contains(element: Char): Boolean = this@asList.contains(element)\n        override fun get(index: Int): Char {\n            AbstractList.checkElementIndex(index, size)\n            return this@asList[index]\n        }\n        override fun indexOf(element: Char): Int {\n            @Suppress(\"USELESS_CAST\")\n            if ((element as Any?) !is Char) return -1\n            return this@asList.indexOf(element)\n        }\n        override fun lastIndexOf(element: Char): Int {\n            @Suppress(\"USELESS_CAST\")\n            if ((element as Any?) !is Char) return -1\n            return this@asList.lastIndexOf(element)\n        }\n    }\n}\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean {\n    return this.contentDeepEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepEquals\")\npublic actual infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual fun <T> Array<out T>.contentDeepHashCode(): Int {\n    return this.contentDeepHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepHashCode\")\npublic actual fun <T> Array<out T>?.contentDeepHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic actual fun <T> Array<out T>.contentDeepToString(): String {\n    return this.contentDeepToString()\n}\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayDeepToString\")\npublic actual fun <T> Array<out T>?.contentDeepToString(): String {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun ByteArray.contentEquals(other: ByteArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun ShortArray.contentEquals(other: ShortArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun IntArray.contentEquals(other: IntArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun LongArray.contentEquals(other: LongArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun FloatArray.contentEquals(other: FloatArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual infix fun CharArray.contentEquals(other: CharArray): Boolean {\n    return this.contentEquals(other)\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun IntArray?.contentEquals(other: IntArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun LongArray?.contentEquals(other: LongArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayEquals\")\npublic actual infix fun CharArray?.contentEquals(other: CharArray?): Boolean {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun <T> Array<out T>.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ByteArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ShortArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun IntArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun LongArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun FloatArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun DoubleArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun BooleanArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun CharArray.contentHashCode(): Int {\n    return this.contentHashCode()\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun <T> Array<out T>?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun ByteArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun ShortArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun IntArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun LongArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun FloatArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun DoubleArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun BooleanArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayHashCode\")\npublic actual fun CharArray?.contentHashCode(): Int {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun <T> Array<out T>.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ByteArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun ShortArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun IntArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun LongArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun FloatArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun DoubleArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun BooleanArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic actual fun CharArray.contentToString(): String {\n    return this.contentToString()\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun <T> Array<out T>?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun ByteArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun ShortArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun IntArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun LongArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun FloatArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun DoubleArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun BooleanArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\n@library(\"arrayToString\")\npublic actual fun CharArray?.contentToString(): String {\n    definedExternally\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T> {\n    arrayCopy(this, destination, destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray {\n    arrayCopy(this.unsafeCast<Array<Byte>>(), destination.unsafeCast<Array<Byte>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray {\n    arrayCopy(this.unsafeCast<Array<Short>>(), destination.unsafeCast<Array<Short>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray {\n    arrayCopy(this.unsafeCast<Array<Int>>(), destination.unsafeCast<Array<Int>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray {\n    arrayCopy(this.unsafeCast<Array<Long>>(), destination.unsafeCast<Array<Long>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray {\n    arrayCopy(this.unsafeCast<Array<Float>>(), destination.unsafeCast<Array<Float>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray {\n    arrayCopy(this.unsafeCast<Array<Double>>(), destination.unsafeCast<Array<Double>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray {\n    arrayCopy(this.unsafeCast<Array<Boolean>>(), destination.unsafeCast<Array<Boolean>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual inline fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray {\n    arrayCopy(this.unsafeCast<Array<Char>>(), destination.unsafeCast<Array<Char>>(), destinationOffset, startIndex, endIndex)\n    return destination\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline fun <T> Array<out T>.copyOf(): Array<T> {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun ByteArray.copyOf(): ByteArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun ShortArray.copyOf(): ShortArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun IntArray.copyOf(): IntArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun LongArray.copyOf(): LongArray {\n    return withType(\"LongArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun FloatArray.copyOf(): FloatArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun DoubleArray.copyOf(): DoubleArray {\n    return this.asDynamic().slice()\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun BooleanArray.copyOf(): BooleanArray {\n    return withType(\"BooleanArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic actual fun CharArray.copyOf(): CharArray {\n    return withType(\"CharArray\", this.asDynamic().slice())\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun ByteArray.copyOf(newSize: Int): ByteArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, ByteArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun ShortArray.copyOf(newSize: Int): ShortArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, ShortArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun IntArray.copyOf(newSize: Int): IntArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, IntArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun LongArray.copyOf(newSize: Int): LongArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"LongArray\", arrayCopyResize(this, newSize, 0L))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun FloatArray.copyOf(newSize: Int): FloatArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, FloatArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun DoubleArray.copyOf(newSize: Int): DoubleArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return fillFrom(this, DoubleArray(newSize))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun BooleanArray.copyOf(newSize: Int): BooleanArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"BooleanArray\", arrayCopyResize(this, newSize, false))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic actual fun CharArray.copyOf(newSize: Int): CharArray {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return withType(\"CharArray\", fillFrom(this, CharArray(newSize)))\n}\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual fun <T> Array<out T>.copyOf(newSize: Int): Array<T?> {\n    require(newSize >= 0) { \"Invalid new array size: $newSize.\" }\n    return arrayCopyResize(this, newSize, null)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual fun <T> Array<out T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T> {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"LongArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return this.asDynamic().slice(fromIndex, toIndex)\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"BooleanArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic actual fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    return withType(\"CharArray\", this.asDynamic().slice(fromIndex, toIndex))\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    this.asDynamic().fill(element, fromIndex, toIndex);\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline operator fun <T> Array<out T>.plus(element: T): Array<T> {\n    return this.asDynamic().concat(arrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ByteArray.plus(element: Byte): ByteArray {\n    return plus(byteArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ShortArray.plus(element: Short): ShortArray {\n    return plus(shortArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun IntArray.plus(element: Int): IntArray {\n    return plus(intArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun LongArray.plus(element: Long): LongArray {\n    return plus(longArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun FloatArray.plus(element: Float): FloatArray {\n    return plus(floatArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun DoubleArray.plus(element: Double): DoubleArray {\n    return plus(doubleArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun BooleanArray.plus(element: Boolean): BooleanArray {\n    return plus(booleanArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun CharArray.plus(element: Char): CharArray {\n    return plus(charArrayOf(element))\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\")\npublic actual operator fun <T> Array<out T>.plus(elements: Collection<T>): Array<T> {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun ShortArray.plus(elements: Collection<Short>): ShortArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun IntArray.plus(elements: Collection<Int>): IntArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun LongArray.plus(elements: Collection<Long>): LongArray {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun FloatArray.plus(elements: Collection<Float>): FloatArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray {\n    return arrayPlusCollection(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic actual operator fun CharArray.plus(elements: Collection<Char>): CharArray {\n    return fillFromCollection(this.copyOf(size + elements.size), this.size, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline operator fun <T> Array<out T>.plus(elements: Array<out T>): Array<T> {\n    return this.asDynamic().concat(elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ByteArray.plus(elements: ByteArray): ByteArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun ShortArray.plus(elements: ShortArray): ShortArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun IntArray.plus(elements: IntArray): IntArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun LongArray.plus(elements: LongArray): LongArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun FloatArray.plus(elements: FloatArray): FloatArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline operator fun CharArray.plus(elements: CharArray): CharArray {\n    return primitiveArrayConcat(this, elements)\n}\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"ACTUAL_WITHOUT_EXPECT\", \"NOTHING_TO_INLINE\")\npublic actual inline fun <T> Array<out T>.plusElement(element: T): Array<T> {\n    return this.asDynamic().concat(arrayOf(element))\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun IntArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic actual fun LongArray.sort(): Unit {\n    if (size > 1) sort { a: Long, b: Long -> a.compareTo(b) }\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun ByteArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun ShortArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun DoubleArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun FloatArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\n@library(\"primitiveArraySort\")\npublic actual fun CharArray.sort(): Unit {\n    definedExternally\n}\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic actual fun <T : Comparable<T>> Array<out T>.sort(): Unit {\n    if (size > 1) sortArray(this)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sort(comparison: (a: T, b: T) -> Int): Unit {\n    if (size > 1) sortArrayWith(this, comparison)\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this, fromIndex, toIndex, naturalOrder())\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<ByteArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<ShortArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<IntArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this.unsafeCast<Array<Long>>(), fromIndex, toIndex, naturalOrder())\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<FloatArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<DoubleArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val subarray = this.asDynamic().subarray(fromIndex, toIndex).unsafeCast<CharArray>()\n    subarray.sort()\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sort(noinline comparison: (a: Byte, b: Byte) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sort(noinline comparison: (a: Short, b: Short) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sort(noinline comparison: (a: Int, b: Int) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sort(noinline comparison: (a: Long, b: Long) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sort(noinline comparison: (a: Float, b: Float) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sort(noinline comparison: (a: Double, b: Double) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparison] function.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sort(noinline comparison: (a: Char, b: Char) -> Int): Unit {\n    asDynamic().sort(comparison)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic actual fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit {\n    if (size > 1) sortArrayWith(this, comparator)\n}\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    sortArrayWith(this, fromIndex, toIndex, comparator)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun ByteArray.toTypedArray(): Array<Byte> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun ShortArray.toTypedArray(): Array<Short> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun IntArray.toTypedArray(): Array<Int> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun LongArray.toTypedArray(): Array<Long> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun FloatArray.toTypedArray(): Array<Float> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun DoubleArray.toTypedArray(): Array<Double> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun BooleanArray.toTypedArray(): Array<Boolean> {\n    return js(\"[]\").slice.call(this)\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic actual fun CharArray.toTypedArray(): Array<Char> {\n    return Array(size) { index -> this[index] }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"SetsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\ninternal object EmptySet : Set<Nothing>, Serializable {\n    private const val serialVersionUID: Long = 3406603774387020532\n\n    override fun equals(other: Any?): Boolean = other is Set<*> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n\n    private fun readResolve(): Any = EmptySet\n}\n\n\n/**\n * Returns an empty read-only set.  The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.emptyReadOnlySet\n */\npublic fun <T> emptySet(): Set<T> = EmptySet\n\n/**\n * Returns a new read-only set with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.readOnlySet\n */\npublic fun <T> setOf(vararg elements: T): Set<T> = if (elements.size > 0) elements.toSet() else emptySet()\n\n/**\n * Returns an empty read-only set.  The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.emptyReadOnlySet\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> setOf(): Set<T> = emptySet()\n\n/**\n * Returns an empty new [MutableSet].\n *\n * The returned set preserves the element iteration order.\n * @sample samples.collections.Collections.Sets.emptyMutableSet\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableSetOf(): MutableSet<T> = LinkedHashSet()\n\n/**\n * Returns a new [MutableSet] with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * @sample samples.collections.Collections.Sets.mutableSet\n */\npublic fun <T> mutableSetOf(vararg elements: T): MutableSet<T> = elements.toCollection(LinkedHashSet(mapCapacity(elements.size)))\n\n/** Returns an empty new [HashSet]. */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> hashSetOf(): HashSet<T> = HashSet()\n\n/** Returns a new [HashSet] with the given elements. */\npublic fun <T> hashSetOf(vararg elements: T): HashSet<T> = elements.toCollection(HashSet(mapCapacity(elements.size)))\n\n/**\n * Returns an empty new [LinkedHashSet].\n * @sample samples.collections.Collections.Sets.emptyLinkedHashSet\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> linkedSetOf(): LinkedHashSet<T> = LinkedHashSet()\n\n/**\n * Returns a new [LinkedHashSet] with the given elements.\n * Elements of the set are iterated in the order they were specified.\n * @sample samples.collections.Collections.Sets.linkedHashSet\n */\npublic fun <T> linkedSetOf(vararg elements: T): LinkedHashSet<T> = elements.toCollection(LinkedHashSet(mapCapacity(elements.size)))\n\n/**\n * Returns a new read-only set either with single given element, if it is not null, or empty set if the element is null.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.setOfNotNull\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Any> setOfNotNull(element: T?): Set<T> = if (element != null) setOf(element) else emptySet()\n\n/**\n * Returns a new read-only set only with those given elements, that are not null.\n * Elements of the set are iterated in the order they were specified.\n * The returned set is serializable (JVM).\n * @sample samples.collections.Collections.Sets.setOfNotNull\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Any> setOfNotNull(vararg elements: T?): Set<T> {\n    return elements.filterNotNullTo(LinkedHashSet())\n}\n\n/**\n * Builds a new read-only [Set] by populating a [MutableSet] using the given [builderAction]\n * and returning a read-only set with the same elements.\n *\n * The set passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Elements of the set are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Sets.buildSetSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildSet(@BuilderInference builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildSetInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildSetInternal(builderAction: MutableSet<E>.() -> Unit): Set<E>\n\n/**\n * Builds a new read-only [Set] by populating a [MutableSet] using the given [builderAction]\n * and returning a read-only set with the same elements.\n *\n * The set passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * Elements of the set are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Sets.buildSetSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildSet(capacity: Int, @BuilderInference builderAction: MutableSet<E>.() -> Unit): Set<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildSetInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildSetInternal(capacity: Int, builderAction: MutableSet<E>.() -> Unit): Set<E>\n\n\n/** Returns this Set if it's not `null` and the empty set otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Set<T>?.orEmpty(): Set<T> = this ?: emptySet()\n\ninternal fun <T> Set<T>.optimizeReadOnlySet() = when (size) {\n    0 -> emptySet()\n    1 -> setOf(iterator().next())\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n// a package is omitted to get declarations directly under the module\n\n@PublishedApi\nexternal internal fun <T> Array(size: Int): Array<T>\n\n@JsName(\"newArray\")\nfun <T> newArray(size: Int, initValue: T) = fillArrayVal(Array<T>(size), initValue)\n\n@JsName(\"newArrayF\")\ninline fun <T> arrayWithFun(size: Int, init: (Int) -> T) = fillArrayFun(Array<T>(size), init)\n\n@JsName(\"fillArray\")\ninline fun <T> fillArrayFun(array: Array<T>, init: (Int) -> T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = init(i)\n    }\n    return array\n}\n\n@JsName(\"booleanArray\")\nfun booleanArray(size: Int, init: dynamic): Array<Boolean> {\n    val result: dynamic = Array<Boolean>(size)\n    result.`$type$` = \"BooleanArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, false)\n        false -> result\n        else -> fillArrayFun<Boolean>(result, init)\n    }\n}\n\n@JsName(\"booleanArrayF\")\ninline fun booleanArrayWithFun(size: Int, init: (Int) -> Boolean): Array<Boolean> = fillArrayFun(booleanArray(size, false), init)\n\n@JsName(\"charArray\")\n@Suppress(\"UNUSED_PARAMETER\")\nfun charArray(size: Int, init: dynamic): Array<Char> {\n    val result = js(\"new Uint16Array(size)\")\n    result.`$type$` = \"CharArray\"\n    return when (init) {\n        null, true, false -> result // For consistency\n        else -> fillArrayFun<Char>(result, init)\n    }\n}\n\n@JsName(\"charArrayF\")\ninline fun charArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = charArray(size, null)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"untypedCharArrayF\")\ninline fun untypedCharArrayWithFun(size: Int, init: (Int) -> Char): Array<Char> {\n    val array = Array<Char>(size)\n    for (i in 0..array.size - 1) {\n        @Suppress(\"UNUSED_VARIABLE\") // used in js block\n        val value = init(i)\n        js(\"array[i] = value;\")\n    }\n    return array\n}\n\n@JsName(\"longArray\")\nfun longArray(size: Int, init: dynamic): Array<Long> {\n    val result: dynamic = Array<Long>(size)\n    result.`$type$` = \"LongArray\"\n    return when (init) {\n        null, true -> fillArrayVal(result, 0L)\n        false -> result\n        else -> fillArrayFun<Long>(result, init)\n    }\n}\n\n@JsName(\"longArrayF\")\ninline fun longArrayWithFun(size: Int, init: (Int) -> Long): Array<Long> = fillArrayFun(longArray(size, false), init)\n\nprivate fun <T> fillArrayVal(array: Array<T>, initValue: T): Array<T> {\n    for (i in 0..array.size - 1) {\n        array[i] = initValue\n    }\n    return array\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.regression.LinearRegression\nimport jetbrains.datalore.plot.base.stat.regression.LocalPolynomialRegression\nimport jetbrains.datalore.plot.base.stat.regression.PolynomialRegression\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.random.Random\n\n\n/**\n *\n * method - smoothing method: lm, glm, gam, loess, rlm\n * (For datasets with n < 1000 default is loess. For datasets with 1000 or more observations defaults to gam)\n * formula - formula to use in smoothing function\n * ( eg. y ~ x, y ~ poly(x, 2), y ~ log(x))\n * se (TRUE ) - display confidence interval around smooth?\n * n (80) - number of points to evaluate smoother at\n *\n *\n * span (0.75) - controls the amount of smoothing for the default loess smoother.\n * fullrange (FALSE) - should the fit span the full range of the plot, or just the data\n * level (0.95) - level of confidence interval to use\n * method.args - ist of additional arguments passed on to the modelling function defined by method\n *\n *\n * Adds columns:\n *\n * y    - predicted value\n * ymin - lower pointwise confidence interval around the mean\n * ymax - upper pointwise confidence interval around the mean\n * se   - standard error\n */\nclass SmoothStat constructor(\n    private val smootherPointCount: Int,\n    private val smoothingMethod: Method,\n    private val confidenceLevel: Double,\n    private val displayConfidenceInterval: Boolean,\n    private val span: Double,\n    private val polynomialDegree: Int,\n    private val loessCriticalSize: Int,\n    private val samplingSeed: Long\n) : BaseStat(DEF_MAPPING) {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return super.hasDefaultMapping(aes) ||\n                aes == Aes.YMIN && displayConfidenceInterval ||\n                aes == Aes.YMAX && displayConfidenceInterval\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        if (aes == Aes.YMIN) {\n            return Stats.Y_MIN\n        }\n        return if (aes == Aes.YMAX) {\n            Stats.Y_MAX\n        } else super.getDefaultMapping(aes)\n    }\n\n    enum class Method {\n        LM, // linear model\n        GLM,\n        GAM,\n        LOESS,\n        RLM\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )  // also conditional Y_MIN / Y_MAX\n        const val DEF_EVAL_POINT_COUNT = 80\n        val DEF_SMOOTHING_METHOD = Method.LM\n        const val DEF_CONFIDENCE_LEVEL = 0.95    // 95 %\n        const val DEF_DISPLAY_CONFIDENCE_INTERVAL = true\n        const val DEF_SPAN = 0.5\n        const val DEF_DEG = 1\n        const val DEF_LOESS_CRITICAL_SIZE = 1_000\n        const val DEF_SAMPLING_SEED = 37L\n    }\n\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf<Aes<*>>(Aes.Y)\n    }\n\n    fun needSampling(rowCount: Int): Boolean {\n        if (smoothingMethod != Method.LOESS) {\n            return false\n        }\n\n        if (rowCount <= loessCriticalSize) {\n            return false\n        }\n\n        return true\n    }\n\n    private fun applySampling(data: DataFrame, messageConsumer: (s: String) -> Unit): DataFrame {\n        val msg = \"LOESS drew a random sample with max_n=$loessCriticalSize, seed=$samplingSeed\"\n        messageConsumer(msg)\n\n        return SamplingUtil.sampleWithoutReplacement(loessCriticalSize, Random(samplingSeed), data)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n\n        if (needSampling(data.rowCount())) {\n            data = applySampling(data, messageConsumer)\n        }\n\n        val valuesY = data.getNumeric(TransformVar.Y)\n        if (valuesY.size < 3) {  // at least 3 data points required\n            return withEmptyStatValues()\n        }\n\n        val valuesX: List<Double?>\n        if (data.has(TransformVar.X)) {\n            valuesX = data.getNumeric(TransformVar.X)\n        } else {\n            valuesX = ArrayList()\n            for (i in valuesY.indices) {\n                valuesX.add(i.toDouble())\n            }\n        }\n\n        SeriesUtil.range(valuesX) ?: return withEmptyStatValues()\n\n        // do stat for each group separately\n\n        val statX: List<Double>\n        val statY: List<Double>\n        val statMinY: List<Double>\n        val statMaxY: List<Double>\n        val statSE: List<Double>\n\n        val statValues = applySmoothing(valuesX, valuesY)\n\n        statX = statValues[Stats.X]!!\n        statY = statValues[Stats.Y]!!\n        statMinY = statValues[Stats.Y_MIN]!!\n        statMaxY = statValues[Stats.Y_MAX]!!\n        statSE = statValues[Stats.SE]!!\n\n        val statData = DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.Y, statY)\n\n        if (displayConfidenceInterval) {\n            statData.putNumeric(Stats.Y_MIN, statMinY)\n                .putNumeric(Stats.Y_MAX, statMaxY)\n                .putNumeric(Stats.SE, statSE)\n        }\n\n        return statData.build()\n    }\n\n    /* About five methods\n   * Linear Regression: DONE\n   * Loess: DONE, SE used bootstrap method, but too many strikes. Refer to www.netlib.org/a/cloess.ps Page 45\n   * Generalized Linear Model: https://spark.apache.org/docs/latest/ml-classification-regression.html#generalized-linear-regression\n   * Robust Linear Model: Unfortunately no Java Library\n   * Generalized Additive Model: Unknown\n   * */\n\n    private fun applySmoothing(valuesX: List<Double?>, valuesY: List<Double?>): Map<DataFrame.Variable, List<Double>> {\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statMinY = ArrayList<Double>()\n        val statMaxY = ArrayList<Double>()\n        val statSE = ArrayList<Double>()\n\n        val result = HashMap<DataFrame.Variable, List<Double>>()\n        result[Stats.X] = statX\n        result[Stats.Y] = statY\n        result[Stats.Y_MIN] = statMinY\n        result[Stats.Y_MAX] = statMaxY\n        result[Stats.SE] = statSE\n\n        val regression = when (smoothingMethod) {\n            Method.LM -> {\n                require(polynomialDegree >= 1) { \"Degree of polynomial regression must be at least 1\" }\n                if (polynomialDegree == 1) {\n                    LinearRegression(valuesX, valuesY, confidenceLevel)\n                } else {\n                    if (PolynomialRegression.canBeComputed(valuesX, valuesY, polynomialDegree)) {\n                        PolynomialRegression(valuesX, valuesY, confidenceLevel, polynomialDegree)\n                    } else {\n                        return result   // empty stat data\n                    }\n                }\n            }\n            Method.LOESS -> {\n                val evaluator = LocalPolynomialRegression(valuesX, valuesY, confidenceLevel, span)\n                if (evaluator.canCompute) {\n                    evaluator\n                } else {\n                    return result   // empty stat data\n                }\n            }\n            else -> throw IllegalArgumentException(\n                \"Unsupported smoother method: $smoothingMethod (only 'lm' and 'loess' methods are currently available)\"\n            )\n        }\n\n        val rangeX = SeriesUtil.range(valuesX) ?: return result\n\n        val startX = rangeX.lowerEnd\n        val spanX = rangeX.upperEnd - startX\n        val stepX = spanX / (smootherPointCount - 1)\n\n        for (i in 0 until smootherPointCount) {\n            val x = startX + i * stepX\n            val eval = regression.evalX(x.coerceIn(rangeX.lowerEnd, rangeX.upperEnd))\n            statX.add(x)\n            statY.add(eval.y)\n            statMinY.add(eval.ymin)\n            statMaxY.add(eval.ymax)\n            statSE.add(eval.se)\n        }\n        return result\n    }\n}\n\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.sqrt\n\n/**\n * Base class for probability distributions on the reals.\n * Default implementations are provided for some of the methods\n * that do not vary from distribution to distribution.\n *\n * @version $Id: AbstractRealDistribution.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 3.0\n */\nabstract class AbstractRealDistribution\n/** Default constructor.  */\nprotected constructor() : RealDistribution {\n\n    /** Solver absolute accuracy for inverse cumulative computation  */\n    /**\n     * Returns the solver absolute accuracy for inverse cumulative computation.\n     * You can override this method in order to use a Brent solver with an\n     * absolute accuracy different from the default.\n     *\n     * @return the maximum absolute error in inverse cumulative probability estimates\n     */\n    protected open val solverAbsoluteAccuracy =\n        SOLVER_DEFAULT_ABSOLUTE_ACCURACY\n\n    /**\n     * {@inheritDoc}\n     *\n     * The default implementation uses the identity\n     *\n     * `P(x0 < X <= x1) = P(X <= x1) - P(X <= x0)`\n     */\n    override fun cumulativeProbability(x0: Double, x1: Double): Double {\n        if (x0 > x1) {\n            error(\"NumberIsTooLarge - x0:$x0, x1:$x1\")\n        }\n        return cumulativeProbability(x1) - cumulativeProbability(x0)\n    }\n\n    /**\n     * {@inheritDoc}\n     *\n     * The default implementation returns\n     *\n     *  * [.getSupportLowerBound] for `p = 0`,\n     *  * [.getSupportUpperBound] for `p = 1`.\n     *\n     */\n    override fun inverseCumulativeProbability(p: Double): Double {\n        /*\n         * IMPLEMENTATION NOTES\n         * --------------------\n         * Where applicable, use is made of the one-sided Chebyshev inequality\n         * to bracket the root. This inequality states that\n         * P(X - mu >= k * sig) <= 1 / (1 + k^2),\n         * mu: mean, sig: standard deviation. Equivalently\n         * 1 - P(X < mu + k * sig) <= 1 / (1 + k^2),\n         * F(mu + k * sig) >= k^2 / (1 + k^2).\n         *\n         * For k = sqrt(p / (1 - p)), we find\n         * F(mu + k * sig) >= p,\n         * and (mu + k * sig) is an upper-bound for the root.\n         *\n         * Then, introducing Y = -X, mean(Y) = -mu, sd(Y) = sig, and\n         * P(Y >= -mu + k * sig) <= 1 / (1 + k^2),\n         * P(-X >= -mu + k * sig) <= 1 / (1 + k^2),\n         * P(X <= mu - k * sig) <= 1 / (1 + k^2),\n         * F(mu - k * sig) <= 1 / (1 + k^2).\n         *\n         * For k = sqrt((1 - p) / p), we find\n         * F(mu - k * sig) <= p,\n         * and (mu - k * sig) is a lower-bound for the root.\n         *\n         * In cases where the Chebyshev inequality does not apply, geometric\n         * progressions 1, 2, 4, ... and -1, -2, -4, ... are used to bracket\n         * the root.\n         */\n        if (p < 0.0 || p > 1.0) {\n            error(\"OutOfRange [0, 1] - p$p\")\n        }\n\n        var lowerBound = supportLowerBound\n        if (p == 0.0) {\n            return lowerBound\n        }\n\n        var upperBound = supportUpperBound\n        if (p == 1.0) {\n            return upperBound\n        }\n\n        val mu = numericalMean\n        val sig = sqrt(numericalVariance)\n        val chebyshevApplies: Boolean\n        chebyshevApplies = !(mu.isInfinite() || mu.isNaN() || sig.isInfinite() || sig.isNaN())\n\n        if (lowerBound == Double.NEGATIVE_INFINITY) {\n            if (chebyshevApplies) {\n                lowerBound = mu - sig * sqrt((1.0 - p) / p)\n            } else {\n                lowerBound = -1.0\n                while (cumulativeProbability(lowerBound) >= p) {\n                    lowerBound *= 2.0\n                }\n            }\n        }\n\n        if (upperBound == Double.POSITIVE_INFINITY) {\n            if (chebyshevApplies) {\n                upperBound = mu + sig * sqrt(p / (1.0 - p))\n            } else {\n                upperBound = 1.0\n                while (cumulativeProbability(upperBound) < p) {\n                    upperBound *= 2.0\n                }\n            }\n        }\n\n        val toSolve = object : UnivariateFunction {\n            override fun value(x: Double): Double {\n                return cumulativeProbability(x) - p\n            }\n        }\n\n        val x = UnivariateSolverUtils.solve(\n            toSolve,\n            lowerBound,\n            upperBound,\n            solverAbsoluteAccuracy\n        )\n\n        if (!isSupportConnected) {\n            /* Test for plateau. */\n            val dx = solverAbsoluteAccuracy\n            if (x - dx >= supportLowerBound) {\n                val px = cumulativeProbability(x)\n                if (cumulativeProbability(x - dx) == px) {\n                    upperBound = x\n                    while (upperBound - lowerBound > dx) {\n                        val midPoint = 0.5 * (lowerBound + upperBound)\n                        if (cumulativeProbability(midPoint) < px) {\n                            lowerBound = midPoint\n                        } else {\n                            upperBound = midPoint\n                        }\n                    }\n                    return upperBound\n                }\n            }\n        }\n        return x\n    }\n\n    companion object {\n        /** Default accuracy.  */\n        val SOLVER_DEFAULT_ABSOLUTE_ACCURACY = 1e-6\n\n        /** Serializable version identifier  */\n        private const val serialVersionUID = -38038050983108802L\n    }\n}\n\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\n\n\n/**\n * Utilities for comparing numbers.\n *\n * @since 3.0\n * @version $Id$\n */\nobject Precision {\n    /** Offset to order signed double numbers lexicographically.  */\n    private val SGN_MASK: Long = 1.shl(63)\n    /** Offset to order signed double numbers lexicographically.  */\n    private val SGN_MASK_FLOAT = 1.shl(31)\n\n    /**\n     * Compares two numbers given some amount of allowed error.\n     *\n     * @param x the first number\n     * @param y the second number\n     * @param eps the amount of error to allow when checking for equality\n     * @return  * 0 if  [equals(x, y, eps)][.equals]\n     *  * &lt; 0 if ![equals(x, y, eps)][.equals] &amp;&amp; x &lt; y\n     *  * > 0 if ![equals(x, y, eps)][.equals] &amp;&amp; x > y\n     */\n    fun compareTo(x: Double, y: Double, eps: Double): Int {\n        if (equals(x, y, eps)) {\n            return 0\n        } else if (x < y) {\n            return -1\n        }\n        return 1\n    }\n\n    /**\n     * Compares two numbers given some amount of allowed error.\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return  * 0 if  [equals(x, y, maxUlps)][.equals]\n     *  * &lt; 0 if ![equals(x, y, maxUlps)][.equals] &amp;&amp; x &lt; y\n     *  * > 0 if ![equals(x, y, maxUlps)][.equals] &amp;&amp; x > y\n     */\n    fun compareTo(x: Double, y: Double, maxUlps: Int): Int {\n        if (equals(x, y, maxUlps)) {\n            return 0\n        } else if (x < y) {\n            return -1\n        }\n        return 1\n    }\n\n    /**\n     * Returns true if both arguments are NaN or neither is NaN and they are\n     * equal as defined by [equals(x, y, 1)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @return `true` if the values are equal or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, 1)\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other.\n     * @since 2.2\n     */\n    fun equals(x: Float, y: Float, eps: Float): Boolean {\n        return equals(x, y, 1) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are NaN or are equal or within the range\n     * of allowed error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other,\n     * or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float, eps: Float): Boolean {\n        return equalsIncludingNaN(x, y) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if there are fewer than `maxUlps` floating\n     * point values between `x` and `y`.\n     * @since 2.2\n     */\n    @JvmOverloads\n    fun equals(x: Float, y: Float, maxUlps: Int = 1): Boolean {\n        var xInt = x.toBits()\n        var yInt = y.toBits()\n\n        // Make lexicographically ordered as a two's-complement integer.\n        if (xInt < 0) {\n            xInt = SGN_MASK_FLOAT - xInt\n        }\n        if (yInt < 0) {\n            yInt = SGN_MASK_FLOAT - yInt\n        }\n\n        val isEqual = abs(xInt - yInt) <= maxUlps\n\n        return isEqual && !x.isNaN() && !y.isNaN()\n    }\n\n    /**\n     * Returns true if both arguments are NaN or if they are equal as defined\n     * by [equals(x, y, maxUlps)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if both arguments are NaN or if there are less than\n     * `maxUlps` floating point values between `x` and `y`.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Float, y: Float, maxUlps: Int): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, maxUlps)\n    }\n\n    /**\n     * Returns true if both arguments are NaN or neither is NaN and they are\n     * equal as defined by [equals(x, y, 1)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @return `true` if the values are equal or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, 1)\n    }\n\n    /**\n     * Returns `true` if there is no double value strictly between the\n     * arguments or the difference between them is within the range of allowed\n     * error (inclusive).\n     *\n     * @param x First value.\n     * @param y Second value.\n     * @param eps Amount of allowed absolute error.\n     * @return `true` if the values are two adjacent floating point\n     * numbers or they are within range of each other.\n     */\n    fun equals(x: Double, y: Double, eps: Double): Boolean {\n        return equals(x, y, 1) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are NaN or are equal or within the range\n     * of allowed error (inclusive).\n     *\n     * @param x first value\n     * @param y second value\n     * @param eps the amount of absolute error to allow.\n     * @return `true` if the values are equal or within range of each other,\n     * or both are NaN.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double, eps: Double): Boolean {\n        return equalsIncludingNaN(x, y) || abs(y - x) <= eps\n    }\n\n    /**\n     * Returns true if both arguments are equal or within the range of allowed\n     * error (inclusive).\n     * Two float numbers are considered equal if there are `(maxUlps - 1)`\n     * (or fewer) floating point numbers between them, i.e. two adjacent floating\n     * point numbers are considered equal.\n     * Adapted from [\n * Bruce Dawson](https://www.cygnus-software.com/papers/comparingfloats/comparingfloats.htm)\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if there are fewer than `maxUlps` floating\n     * point values between `x` and `y`.\n     */\n    @JvmOverloads\n    fun equals(x: Double, y: Double, maxUlps: Int = 1): Boolean {\n        var xInt = x.toBits()\n        var yInt = y.toBits()\n\n        // Make lexicographically ordered as a two's-complement integer.\n        if (xInt < 0) {\n            xInt = SGN_MASK - xInt\n        }\n        if (yInt < 0) {\n            yInt = SGN_MASK - yInt\n        }\n\n        val isEqual = abs(xInt - yInt) <= maxUlps\n\n        return isEqual && !x.isNaN() && !y.isNaN()\n    }\n\n    /**\n     * Returns true if both arguments are NaN or if they are equal as defined\n     * by [equals(x, y, maxUlps)][.equals].\n     *\n     * @param x first value\n     * @param y second value\n     * @param maxUlps `(maxUlps - 1)` is the number of floating point\n     * values between `x` and `y`.\n     * @return `true` if both arguments are NaN or if there are less than\n     * `maxUlps` floating point values between `x` and `y`.\n     * @since 2.2\n     */\n    fun equalsIncludingNaN(x: Double, y: Double, maxUlps: Int): Boolean {\n        return x.isNaN() && y.isNaN() || equals(x, y, maxUlps)\n    }\n\n\n    /**\n     * Computes a number `delta` close to `originalDelta` with\n     * the property that <pre>`\n     * x + delta - x\n    `</pre> *\n     * is exactly machine-representable.\n     * This is useful when computing numerical derivatives, in order to reduce\n     * roundoff errors.\n     *\n     * @param x Value.\n     * @param originalDelta Offset value.\n     * @return a number `delta` so that `x + delta` and `x`\n     * differ by a representable floating number.\n     */\n    fun representableDelta(\n        x: Double,\n        originalDelta: Double\n    ): Double {\n        return x + originalDelta - x\n    }\n}\n/**\n * Private constructor.\n */\n/**\n * Returns true iff they are equal as defined by\n * [equals(x, y, 1)][.equals].\n *\n * @param x first value\n * @param y second value\n * @return `true` if the values are equal.\n */\n/**\n * Returns true iff they are equal as defined by\n * [equals(x, y, 1)][.equals].\n *\n * @param x first value\n * @param y second value\n * @return `true` if the values are equal.\n */\n/**\n * Rounds the given value to the specified number of decimal places.\n * The value is rounded using the [BigDecimal.ROUND_HALF_UP] method.\n *\n * @param x Value to round.\n * @param scale Number of digits to the right of the decimal point.\n * @return the rounded value.\n * @since 1.1 (previously in `MathUtils`, moved as of version 3.0)\n */\n/**\n * Rounds the given value to the specified number of decimal places.\n * The value is rounded using the [BigDecimal.ROUND_HALF_UP] method.\n *\n * @param x Value to round.\n * @param scale Number of digits to the right of the decimal point.\n * @return the rounded value.\n * @since 1.1 (previously in `MathUtils`, moved as of version 3.0)\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n\n/**\n * Implementation of Student's t-distribution.\n *\n * @see \"[&apos;Student's t-distribution\n * @see \"[Student's t-distribution\n * @version $Id: TDistribution.java 1244107 2012-02-14 16:17:55Z erans $\n](mathworld.wolfram.com/Studentst-Distribution.html)](https://en.wikipedia.org/wiki/Student&apos;s_t-distribution) */\nclass TDistribution\n/**\n * Create a t distribution using the given degrees of freedom and the\n * specified inverse cumulative probability absolute accuracy.\n *\n * @param degreesOfFreedom Degrees of freedom.\n * @param inverseCumAccuracy the maximum absolute error in inverse\n * cumulative probability estimates\n * (defaults to [.DEFAULT_INVERSE_ABSOLUTE_ACCURACY]).\n * @throws NotStrictlyPositiveException if `degreesOfFreedom <= 0`\n * @since 2.1\n */\n@JvmOverloads constructor(\n    /** The degrees of freedom.  */\n    /**\n     * Access the degrees of freedom.\n     *\n     * @return the degrees of freedom.\n     */\n    private val degreesOfFreedom: Double,\n    /** Inverse cumulative probability accuracy.  */\n    /** {@inheritDoc}  */\n    override val solverAbsoluteAccuracy: Double = DEFAULT_INVERSE_ABSOLUTE_ACCURACY\n) : AbstractRealDistribution() {\n\n    /**\n     * {@inheritDoc}\n     *\n     * For degrees of freedom parameter `df`, the mean is\n     *\n     *  * if `df > 1` then `0`,\n     *  * else undefined (`Double.NaN`).\n     *\n     */\n    override val numericalMean: Double\n        get() {\n            val df = degreesOfFreedom\n\n            return if (df > 1) {\n                0.0\n            } else Double.NaN\n\n        }\n\n    /**\n     * {@inheritDoc}\n     *\n     * For degrees of freedom parameter `df`, the variance is\n     *\n     *  * if `df > 2` then `df / (df - 2)`,\n     *  * if `1 < df <= 2` then positive infinity\n     * (`Double.POSITIVE_INFINITY`),\n     *  * else undefined (`Double.NaN`).\n     *\n     */\n    override val numericalVariance: Double\n        get() {\n            val df = degreesOfFreedom\n\n            if (df > 2) {\n                return df / (df - 2)\n            }\n\n            return if (df > 1 && df <= 2) {\n                Double.POSITIVE_INFINITY\n            } else Double.NaN\n\n        }\n\n    /**\n     * {@inheritDoc}\n     *\n     * The lower bound of the support is always negative infinity no matter the\n     * parameters.\n     *\n     * @return lower bound of the support (always\n     * `Double.NEGATIVE_INFINITY`)\n     */\n    override val supportLowerBound: Double\n        get() = Double.NEGATIVE_INFINITY\n\n    /**\n     * {@inheritDoc}\n     *\n     * The upper bound of the support is always positive infinity no matter the\n     * parameters.\n     *\n     * @return upper bound of the support (always\n     * `Double.POSITIVE_INFINITY`)\n     */\n    override val supportUpperBound: Double\n        get() = Double.POSITIVE_INFINITY\n\n    /** {@inheritDoc}  */\n    override val isSupportLowerBoundInclusive: Boolean\n        get() = false\n\n    /** {@inheritDoc}  */\n    override val isSupportUpperBoundInclusive: Boolean\n        get() = false\n\n    /**\n     * {@inheritDoc}\n     *\n     * The support of this distribution is connected.\n     *\n     * @return `true`\n     */\n    override val isSupportConnected: Boolean\n        get() = true\n\n    init {\n        if (degreesOfFreedom <= 0) {\n            error(\"NotStrictlyPositive - DEGREES_OF_FREEDOM: $degreesOfFreedom\")\n        }\n    }\n\n    /**\n     * {@inheritDoc}\n     *\n     * For this distribution `P(X = x)` always evaluates to 0.\n     *\n     * @return 0\n     */\n    override fun probability(x: Double): Double {\n        return 0.0\n    }\n\n    /** {@inheritDoc}  */\n    override fun density(x: Double): Double {\n        val n = degreesOfFreedom\n        val nPlus1Over2 = (n + 1) / 2\n        return exp(\n            Gamma.logGamma(nPlus1Over2) -\n                    0.5 * (ln(PI) + ln(n)) -\n                    Gamma.logGamma(n / 2) -\n                    nPlus1Over2 * ln(1 + x * x / n)\n        )\n    }\n\n    /** {@inheritDoc}  */\n    override fun cumulativeProbability(x: Double): Double {\n        val ret: Double\n        if (x == 0.0) {\n            ret = 0.5\n        } else {\n            val t = Beta.regularizedBeta(\n                degreesOfFreedom / (degreesOfFreedom + x * x),\n                0.5 * degreesOfFreedom,\n                0.5\n            )\n            if (x < 0.0) {\n                ret = 0.5 * t\n            } else {\n                ret = 1.0 - 0.5 * t\n            }\n        }\n\n        return ret\n    }\n\n    companion object {\n        /**\n         * Default inverse cumulative probability accuracy.\n         * @since 2.1\n         */\n        val DEFAULT_INVERSE_ABSOLUTE_ACCURACY = 1e-9\n        /** Serializable version identifier  */\n        private val serialVersionUID = -5852615386664158222L\n    }\n}\n/**\n * Create a t distribution using the given degrees of freedom.\n *\n * @param degreesOfFreedom Degrees of freedom.\n * @throws NotStrictlyPositiveException if `degreesOfFreedom <= 0`\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables.filter\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\nclass Aes<T> private constructor(val name: String, val isNumeric: Boolean = true) : TypedKey<T> {\n\n    val isColor: Boolean\n        get() = isColor(this)\n\n    init {\n        values.add(this)\n    }\n\n    override fun toString(): String {\n        return \"aes '$name'\"\n    }\n\n    companion object {\n        private val values = ArrayList<Aes<*>>()\n\n        val X: Aes<Double> = Aes(\"x\")\n        val Y: Aes<Double> = Aes(\"y\")\n        val Z: Aes<Double> = Aes(\"z\")\n\n        val COLOR: Aes<Color> = Aes(\"color\", false)\n        val FILL: Aes<Color> = Aes(\"fill\", false)\n        val ALPHA: Aes<Double> = Aes(\"alpha\")\n        val SHAPE: Aes<PointShape> = Aes(\"shape\", false)\n        val LINETYPE: Aes<LineType> = Aes(\"linetype\", false)\n\n        val SIZE: Aes<Double> = Aes(\"size\")\n        val WIDTH: Aes<Double> = Aes(\"width\")\n        val HEIGHT: Aes<Double> = Aes(\"height\")\n        val WEIGHT: Aes<Double> = Aes(\"weight\")\n        val INTERCEPT: Aes<Double> = Aes(\"intercept\")\n        val SLOPE: Aes<Double> = Aes(\"slope\")\n        val XINTERCEPT: Aes<Double> = Aes(\"xintercept\")\n        val YINTERCEPT: Aes<Double> = Aes(\"yintercept\")\n        val LOWER: Aes<Double> = Aes(\"lower\")\n        val MIDDLE: Aes<Double> = Aes(\"middle\")\n        val UPPER: Aes<Double> = Aes(\"upper\")\n\n        val XMIN: Aes<Double> = Aes(\"xmin\")\n        val XMAX: Aes<Double> = Aes(\"xmax\")\n        val YMIN: Aes<Double> = Aes(\"ymin\")\n        val YMAX: Aes<Double> = Aes(\"ymax\")\n        val XEND: Aes<Double> = Aes(\"xend\")\n        val YEND: Aes<Double> = Aes(\"yend\")\n\n        val FRAME: Aes<String> = Aes(\"frame\", false)\n\n        val SPEED: Aes<Double> = Aes(\"speed\")\n        val FLOW: Aes<Double> = Aes(\"flow\")\n\n        val LABEL: Aes<Any?> = Aes(\"label\", false)\n        val FAMILY: Aes<String> = Aes(\"family\", false)\n        val FONTFACE: Aes<String> = Aes(\"fontface\", false)\n\n        // text horizontal justification (numbers [0..1] or predefined strings = new Aes<>(); not positional)\n        val HJUST = Aes<Any>(\"hjust\", false)\n\n        // text vertical justification (numbers [0..1] or predefined strings, not positional)\n        val VJUST = Aes<Any>(\"vjust\", false)\n\n        val ANGLE: Aes<Double> = Aes(\"angle\")\n\n        val SYM_X: Aes<Double> = Aes(\"sym_x\")\n        val SYM_Y: Aes<Double> = Aes(\"sym_y\")\n\n\n        fun numeric(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            // safe to cast all 'numeric' aesthetics are 'Double'\n            @Suppress(\"UNCHECKED_CAST\")\n            return filter(unfiltered) { aes -> aes.isNumeric } as Iterable<Aes<Double>>\n        }\n\n        fun isPositional(aes: Aes<*>): Boolean {\n            return isPositionalXY(aes) ||\n                    // SLOPE must be positional or\n                    // `geom_abline(slope=number)` will not work.\n                    // it should draw the same line as:\n                    // `geom_abline(slope=number, intersept=0)`\n                    // See: PlotUtil.createLayerAesthetics()\n                    aes == SLOPE\n        }\n\n        fun isPositionalXY(aes: Aes<*>): Boolean {\n            return isPositionalX(aes) ||\n                    isPositionalY(aes)\n        }\n\n        fun isPositionalX(aes: Aes<*>): Boolean {\n            return aes == X ||\n                    aes == XINTERCEPT ||\n                    aes == XMIN ||\n                    aes == XMAX ||\n                    aes == XEND\n        }\n\n        fun isPositionalY(aes: Aes<*>): Boolean {\n            return aes == Y ||\n                    aes == YMIN ||\n                    aes == YMAX ||\n                    aes == INTERCEPT ||\n                    aes == YINTERCEPT ||\n                    aes == LOWER ||\n                    aes == MIDDLE ||\n                    aes == UPPER ||\n                    aes == YEND\n        }\n\n        fun isColor(aes: Aes<*>): Boolean {\n            return aes == COLOR || aes == FILL\n        }\n\n        fun isAffectingScaleX(aes: Aes<*>): Boolean {\n            return isPositionalX(aes) // && aes != XINTERCEPT\n        }\n\n        fun isAffectingScaleY(aes: Aes<*>): Boolean {\n            return isPositionalY(aes) &&\n                    // \"INTERCEPT\" is \"positional Y\" because it must use the same 'mapper' as other \"positional Y\"-s,\n                    // but its range of values is not taken in account when computing the Y-mapper.\n                    aes != INTERCEPT // &&\n//                    aes != YINTERCEPT\n        }\n\n        fun affectingScaleX(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            val numeric = numeric(unfiltered)\n            return filter(numeric) { isAffectingScaleX(it) }\n        }\n\n        fun affectingScaleY(unfiltered: Iterable<Aes<*>>): Iterable<Aes<Double>> {\n            val numeric = numeric(unfiltered)\n            return filter(numeric) { isAffectingScaleY(it) }\n        }\n\n        fun noGuideNeeded(aes: Aes<*>): Boolean {\n            return aes == FRAME ||\n                    aes == SPEED ||\n                    aes == FLOW ||\n                    aes == LABEL ||\n                    aes == SLOPE ||\n                    aes == WIDTH ||\n                    aes == HEIGHT ||\n                    aes == HJUST ||\n                    aes == VJUST ||\n                    aes == ANGLE ||\n                    aes == FAMILY ||\n                    aes == FONTFACE ||\n                    aes == SYM_X ||\n                    aes == SYM_Y ||\n                    isPositional(aes)\n        }\n\n        fun values(): List<Aes<*>> {\n            return values\n        }\n\n        fun allPositional(): List<Aes<Double>> {\n            @Suppress(\"UNCHECKED_CAST\")\n            return values.filter { isPositional(it) } as List<Aes<Double>>\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\ninterface ContinuousTransform : Transform {\n    fun hasDomainLimits(): Boolean\n    fun isInDomain(v: Double?): Boolean\n    fun apply(v: Double?): Double?\n    override fun applyInverse(v: Double?): Double?\n    fun applyInverse(l: List<Double?>): List<Double?>\n    fun createApplicableDomain(middle: Double? = null): ClosedRange<Double>\n    fun toApplicableDomain(range: ClosedRange<Double>): ClosedRange<Double>\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninterface CoordinateSystem {\n    fun toClient(p: DoubleVector): DoubleVector\n\n    fun fromClient(p: DoubleVector): DoubleVector\n\n    fun isPointInLimits(p: DoubleVector, isClient: Boolean = true): Boolean\n\n    fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean = true): Boolean\n\n    fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean = true): Boolean\n\n    fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean = true): Boolean\n\n    val xClientLimit: ClosedRange<Double>?\n\n    val yClientLimit: ClosedRange<Double>?\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.jvm.JvmOverloads\n\nclass DataFrame private constructor(builder: Builder) {\n    private val myVectorByVar: Map<Variable, List<*>>\n    private val myIsNumeric: MutableMap<Variable, Boolean>\n\n    // volatile variables (yet)\n    private val myRanges = HashMap<Variable, ClosedRange<Double>?>()\n    private val myDistinctValues = HashMap<Variable, Set<Any>>()\n\n    class OrderSpec(\n        val variable: Variable,\n        val orderBy: Variable,\n        val direction: Int,\n        val aggregateOperation: ((List<Double?>) -> Double?)? = null\n    )\n\n    private val myOrderSpecs: List<OrderSpec>\n\n    val isEmpty: Boolean\n        get() = myVectorByVar.isEmpty()\n\n    init {\n        assertAllSeriesAreSameSize(builder.myVectorByVar)\n        myVectorByVar = HashMap(builder.myVectorByVar)\n        myIsNumeric = HashMap(builder.myIsNumeric)\n        myOrderSpecs = builder.myOrderSpecs\n        myOrderSpecs.forEach { orderSpec ->\n            myDistinctValues[orderSpec.variable] = getOrderedDistinctValues(orderSpec)\n        }\n    }\n\n    private fun assertAllSeriesAreSameSize(vectorByVar: Map<Variable, List<*>>) {\n        if (vectorByVar.size > 1) {\n            val entries = vectorByVar.entries.iterator()\n            val first = entries.next()\n            val size = first.value.size\n            while (entries.hasNext()) {\n                val next = entries.next()\n                if (next.value.size != size) {\n                    throw IllegalArgumentException(\n                        \"All data series in data frame must have equal size\\n\" + dumpSizes(\n                            vectorByVar\n                        )\n                    )\n                }\n            }\n        }\n    }\n\n    private fun dumpSizes(vectorByVar: Map<Variable, List<*>>): String {\n        val sb = StringBuilder()\n        for ((key, value) in vectorByVar) {\n            sb.append(key.name)\n                .append(\" : \")\n                .append(value.size)\n                .append('\\n')\n        }\n        return sb.toString()\n    }\n\n    fun rowCount(): Int {\n        return if (myVectorByVar.isEmpty()) 0 else myVectorByVar.entries.iterator().next().value.size\n    }\n\n    fun has(variable: Variable): Boolean {\n        return myVectorByVar.containsKey(variable)\n    }\n\n    fun isEmpty(variable: Variable): Boolean {\n        return get(variable).isEmpty()\n    }\n\n    fun hasNoOrEmpty(variable: Variable): Boolean {\n        return !has(variable) || isEmpty(variable)\n    }\n\n    operator fun get(variable: Variable): List<*> {\n        assertDefined(variable)\n        return myVectorByVar[variable]!!\n    }\n\n    fun getNumeric(variable: Variable): List<Double?> {\n        assertDefined(variable)\n        val list = myVectorByVar[variable]\n        if (list!!.isEmpty()) {\n            return emptyList()\n        }\n\n        assertNumeric(variable)\n        @Suppress(\"UNCHECKED_CAST\")\n        return list as List<Double?>\n    }\n\n    fun distinctValues(variable: Variable): Collection<Any> {\n        assertDefined(variable)\n        return myDistinctValues.getOrPut(variable) {\n            val values = LinkedHashSet(get(variable)).apply {\n                this.remove(null)\n            }\n            @Suppress(\"UNCHECKED_CAST\")\n            return values as Collection<Any>\n        }\n    }\n\n    fun variables(): Set<Variable> {\n        return myVectorByVar.keys\n    }\n\n    fun isNumeric(variable: Variable): Boolean {\n        assertDefined(variable)\n        if (!myIsNumeric.containsKey(variable)) {\n            val checkedDoubles = SeriesUtil.checkedDoubles(get(variable))\n            myIsNumeric[variable] = checkedDoubles.notEmptyAndCanBeCast()\n        }\n        return myIsNumeric[variable]!!\n    }\n\n    fun range(variable: Variable): ClosedRange<Double>? {\n        if (!myRanges.containsKey(variable)) {\n            val v = getNumeric(variable)\n            val r = SeriesUtil.range(v)\n            myRanges[variable] = r\n        }\n        return myRanges[variable]\n    }\n\n    fun builder(): Builder {\n        return Builder(this)\n    }\n\n    private fun assertDefined(variable: Variable) {\n        if (!has(variable)) {\n            val e = IllegalArgumentException(\"Undefined variable: '$variable'\")\n            LOG.error(e) { e.message!! }\n            throw e\n        }\n    }\n\n    private fun assertNumeric(variable: Variable) {\n        if (!isNumeric(variable)) {\n            val e = IllegalArgumentException(\"Not a numeric variable: '$variable'\")\n            LOG.error(e) { e.message!! }\n            throw e\n        }\n    }\n\n    fun selectIndices(indices: List<Int>): DataFrame {\n        return buildModified { serie -> SeriesUtil.pickAtIndices(serie, indices) }\n    }\n\n    fun selectIndices(indices: Set<Int>): DataFrame {\n        return buildModified { serie -> SeriesUtil.pickAtIndices(serie, indices) }\n    }\n\n    fun dropIndices(indices: Set<Int>): DataFrame {\n        return if (indices.isEmpty()) this else buildModified { serie -> SeriesUtil.skipAtIndices(serie, indices) }\n    }\n\n    private fun buildModified(serieFun: (List<*>) -> List<*>): DataFrame {\n        val builder = this.builder()\n        for (variable in myVectorByVar.keys) {\n            val serie = myVectorByVar[variable]\n            val modifiedSerie = serieFun(serie!!)\n            builder.putIntern(variable, modifiedSerie)\n        }\n        return builder.build()\n    }\n\n    class Variable @JvmOverloads constructor(\n        val name: String,\n        val source: Source = Source.ORIGIN,\n        val label: String = name\n    ) {\n\n        val isOrigin: Boolean\n            get() = source == Source.ORIGIN\n\n        val isStat: Boolean\n            get() = source == Source.STAT\n\n        val isTransform: Boolean\n            get() = source == Source.TRANSFORM\n\n        override fun toString(): String {\n            // important\n            return name\n        }\n\n        fun toSummaryString(): String {\n            return \"$name, '$label' [$source]\"\n        }\n\n        enum class Source {\n            ORIGIN, TRANSFORM, STAT\n        }\n\n        companion object {\n\n            @JvmOverloads\n            fun createOriginal(name: String, label: String = name): Variable {\n                return Variable(\n                    name,\n                    Source.ORIGIN,\n                    label\n                )\n            }\n        }\n    }\n\n    private fun getOrderedDistinctValues(orderSpec: OrderSpec): Set<Any> {\n        fun isValueComparable(value: Any?) = value != null && (value !is Double || value.isFinite())\n\n        val orderedValues = if (orderSpec.aggregateOperation != null) {\n            require(isNumeric(orderSpec.orderBy)) { \"Can't apply aggregate operation to non-numeric values\" }\n            get(orderSpec.variable)\n                .zip(getNumeric(orderSpec.orderBy))\n                .groupBy({ (value) -> value }) { (_, byValue) -> byValue }\n                .mapValues { (_, byValues) -> orderSpec.aggregateOperation.invoke(byValues.filter(::isValueComparable)) }\n                .toList()\n        } else {\n            get(orderSpec.variable).zip(get(orderSpec.orderBy))\n        }\n            .filter { isValueComparable(it.second) && isValueComparable(it.first)}\n            .sortedWith(compareBy({ it.second as Comparable<*> }, { it.first as Comparable<*> }))\n            .mapNotNull { it.first }\n\n        // the values corresponding to non-comparable values will be placed at the end of the result\n        val nonComparableAppendix = get(orderSpec.variable).zip(get(orderSpec.orderBy))\n            .filterNot { isValueComparable(it.second) }\n            .mapNotNull { it.first }\n\n        return (if (orderSpec.direction < 0) {\n            orderedValues.reversed()\n        } else {\n            orderedValues\n        } + nonComparableAppendix).toSet()\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(DataFrame::class)\n    }\n\n    class Builder {\n        internal val myVectorByVar = HashMap<Variable, List<*>>()\n        internal val myIsNumeric = HashMap<Variable, Boolean>()\n        internal val myOrderSpecs = ArrayList<OrderSpec>()\n\n        constructor()\n\n        constructor(data: DataFrame) {\n            myVectorByVar.putAll(data.myVectorByVar)\n            myIsNumeric.putAll(data.myIsNumeric)\n            myOrderSpecs.addAll(data.myOrderSpecs)\n        }\n\n        fun put(variable: Variable, v: List<*>): Builder {\n            putIntern(variable, v)\n            myIsNumeric.remove(variable)  // unknown state\n            return this\n        }\n\n        fun putNumeric(variable: Variable, v: List<Double?>): Builder {\n            putIntern(variable, v)\n            myIsNumeric[variable] = true\n            return this\n        }\n\n        fun putDiscrete(variable: Variable, v: List<*>): Builder {\n            putIntern(variable, v)\n            myIsNumeric[variable] = false\n            return this\n        }\n\n        internal fun putIntern(variable: Variable, v: List<*>) {\n            myVectorByVar[variable] = ArrayList(v)\n        }\n\n        fun remove(variable: Variable): Builder {\n            myVectorByVar.remove(variable)\n            myIsNumeric.remove(variable)\n            return this\n        }\n\n        fun addOrderSpecs(orderSpecs: List<OrderSpec>): Builder {\n            orderSpecs.forEach(::addOrderSpec)\n            return this\n        }\n\n        fun addOrderSpec(orderSpec: OrderSpec): Builder {\n            val currentOrderSpec = myOrderSpecs.find { it.variable == orderSpec.variable }\n            // If multiple specifications for the variable - choose a more specific one:\n            if (currentOrderSpec?.aggregateOperation == null) {\n                myOrderSpecs.remove(currentOrderSpec)\n                myOrderSpecs.add(orderSpec)\n            }\n            return this\n        }\n\n        fun build(): DataFrame {\n            return DataFrame(this)\n        }\n\n        companion object {\n            fun emptyFrame(): DataFrame {\n                return Builder().build()\n            }\n        }\n    }\n}","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\ninterface DataPointAesthetics {\n    fun index(): Int\n\n    fun x(): Double?\n\n    fun y(): Double?\n\n    fun z(): Double?\n\n    fun ymin(): Double?\n\n    fun ymax(): Double?\n\n    fun color(): Color?\n\n    fun fill(): Color?\n\n    fun alpha(): Double?\n\n    fun shape(): PointShape?\n\n    fun lineType(): LineType\n\n    fun size(): Double?\n\n    fun width(): Double?\n\n    fun height(): Double?\n\n    fun weight(): Double?\n\n    fun intercept(): Double?\n\n    fun slope(): Double?\n\n    fun interceptX(): Double?\n\n    fun interceptY(): Double?\n\n    fun lower(): Double?\n\n    fun middle(): Double?\n\n    fun upper(): Double?\n\n    fun frame(): String\n\n    fun speed(): Double?\n\n    fun flow(): Double?\n\n    fun xmin(): Double?\n\n    fun xmax(): Double?\n\n    fun xend(): Double?\n\n    fun yend(): Double?\n\n    fun label(): Any?\n\n    fun family(): String\n\n    fun fontface(): String\n\n    fun hjust(): Any\n\n    fun vjust(): Any\n\n    fun angle(): Double?\n\n    fun symX(): Double?\n\n    fun symY(): Double?\n\n    fun group(): Int?\n\n    fun numeric(aes: Aes<Double>): Double?\n\n    operator fun <T> get(aes: Aes<T>): T?\n\n    fun defined(aes: Aes<*>): Boolean {\n        if (aes.isNumeric) {\n            val number = get(aes)\n            return number != null && (number as Double).isFinite()\n        }\n        return true\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.gcommon.collect.TreeMap\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport kotlin.math.abs\n\nfinal class DiscreteTransform(\n    val domainValues: Collection<Any>,\n    val domainLimits: List<Any>\n) : Transform {\n\n    private val numberByDomainValue = LinkedHashMap<Any, Double>()\n    private val domainValueByNumber: TreeMap<Double, Any> = TreeMap()\n\n    init {\n        val effectiveDomain = if (domainLimits.isEmpty()) {\n            domainValues\n        } else {\n            domainLimits.intersect(domainValues)\n        }\n\n        numberByDomainValue.putAll(\n            MapperUtil.mapDiscreteDomainValuesToNumbers(effectiveDomain)\n        )\n\n        for ((domainValue, number) in numberByDomainValue) {\n            domainValueByNumber.put(number, domainValue)\n        }\n    }\n\n    fun hasDomainLimits(): Boolean {\n        return domainLimits.isNotEmpty()\n    }\n\n    fun isInDomain(v: Any?): Boolean {\n        return numberByDomainValue.containsKey(v)\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return l.map { asNumber(it) }\n    }\n\n    override fun applyInverse(v: Double?): Any? {\n        return fromNumber(v)\n    }\n\n    private fun asNumber(input: Any?): Double? {\n        if (input == null) {\n            return null\n        }\n        if (numberByDomainValue.containsKey(input)) {\n            return numberByDomainValue[input]\n        }\n\n        throw IllegalStateException(\n            \"value $input is not in the domain: ${numberByDomainValue.keys}\"\n        )\n    }\n\n    private fun fromNumber(v: Double?): Any? {\n        if (v == null) {\n            return null\n        }\n\n        if (domainValueByNumber.containsKey(v)) {\n            return domainValueByNumber[v]\n        }\n\n        // look-up the closest key (number)\n        val ceilingKey = domainValueByNumber.ceilingKey(v)\n        val floorKey = domainValueByNumber.floorKey(v)\n        var keyNumber: Double? = null\n        if (ceilingKey != null || floorKey != null) {\n            keyNumber = when {\n                ceilingKey == null -> floorKey\n                floorKey == null -> ceilingKey\n                else -> {\n                    val ceilingDist = abs(ceilingKey - v)\n                    val floorDist = abs(floorKey - v)\n                    if (ceilingDist < floorDist) ceilingKey else floorKey\n                }\n            }\n        }\n        return if (keyNumber != null) domainValueByNumber[keyNumber] else null\n    }\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nenum class GeomKind {\n    PATH,\n    LINE,\n    SMOOTH,\n    BAR,\n    HISTOGRAM,\n    TILE,\n    BIN_2D,\n    MAP,\n    ERROR_BAR,\n    CROSS_BAR,\n    LINE_RANGE,\n    POINT_RANGE,\n    POLYGON,\n    AB_LINE,\n    H_LINE,\n    V_LINE,\n    BOX_PLOT,\n    LIVE_MAP,\n    POINT,\n    RIBBON,\n    AREA,\n    DENSITY,\n    CONTOUR,\n    CONTOURF,\n    DENSITY2D,\n    DENSITY2DF,\n    JITTER,\n    FREQPOLY,\n    STEP,\n    RECT,\n    SEGMENT,\n    TEXT,\n    RASTER,\n    IMAGE\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport kotlin.native.concurrent.ThreadLocal\n\n// In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n// See:  https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n// Required mutations:\n//      -   `renderedAesByGeom` map\n@ThreadLocal\nobject GeomMeta {\n    private val renderedAesByGeom = HashMap<GeomKind, List<Aes<*>>>()\n\n    fun renders(geomKind: GeomKind): List<Aes<*>> {\n        if (!renderedAesByGeom.containsKey(geomKind)) {\n            renderedAesByGeom[geomKind] =\n                renderedAesList(geomKind)\n        }\n        return renderedAesByGeom[geomKind]!!\n    }\n\n    private val POINT = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA,\n        Aes.SHAPE\n        // strokeWidth\n    )\n\n    private val PATH = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE, // path width\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.ALPHA,\n        Aes.SPEED,\n        Aes.FLOW\n    )\n\n    private val POLYGON = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE, // path width\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA\n    )\n\n    private val AREA = listOf(\n        Aes.X, Aes.Y,\n        Aes.SIZE,\n        Aes.LINETYPE,\n        Aes.COLOR,\n        Aes.FILL,\n        Aes.ALPHA\n    )\n\n\n    private fun renderedAesList(geomKind: GeomKind): List<Aes<*>> {\n        return when (geomKind) {\n            GeomKind.POINT -> POINT\n            GeomKind.PATH -> PATH\n            GeomKind.LINE -> PATH\n\n            GeomKind.SMOOTH -> listOf(\n                Aes.X, Aes.Y,\n                Aes.YMIN, Aes.YMAX,\n\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.BAR -> listOf(\n                Aes.X,\n                Aes.Y,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                Aes.WIDTH,\n                Aes.SIZE\n            )\n\n            GeomKind.HISTOGRAM -> listOf(\n                Aes.X, Aes.Y,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                //Aes.WEIGHT,    // ToDo: this is actually handled by 'stat' (bin,count)\n                Aes.WIDTH,\n                Aes.SIZE\n            )\n\n            GeomKind.TILE,\n            GeomKind.BIN_2D -> listOf(\n                Aes.X, Aes.Y,\n                Aes.WIDTH,\n                Aes.HEIGHT,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.ERROR_BAR -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.WIDTH,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.CROSS_BAR -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX, Aes.MIDDLE,\n                Aes.WIDTH,\n\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE\n            )\n\n            GeomKind.LINE_RANGE -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.LINETYPE,\n                Aes.SIZE\n            )\n\n            GeomKind.POINT_RANGE -> listOf(\n                Aes.X, Aes.Y,\n                Aes.YMIN, Aes.YMAX,\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE\n            )\n\n            GeomKind.CONTOUR -> PATH\n            GeomKind.CONTOURF -> POLYGON\n            GeomKind.POLYGON -> POLYGON\n            GeomKind.MAP -> listOf(\n                // auto-wired to 'x' or 'long' and to 'y' or 'lat'\n                Aes.X, Aes.Y,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.AB_LINE -> listOf(\n                Aes.INTERCEPT, Aes.SLOPE,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n\n            GeomKind.H_LINE -> listOf(\n                Aes.YINTERCEPT,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n            GeomKind.V_LINE -> listOf(\n                Aes.XINTERCEPT,\n                Aes.SIZE, // path width\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA\n            )\n\n            GeomKind.BOX_PLOT -> listOf(\n                Aes.LOWER, // NaN for 'outlier' data-point\n                Aes.MIDDLE, // NaN for 'outlier' data-point\n                Aes.UPPER, // NaN for 'outlier' data-point\n\n                Aes.X,\n                Aes.Y, // NaN for 'box' data-point (used for outliers)\n                Aes.YMAX,\n                Aes.YMIN,\n\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.LINETYPE,\n                Aes.SHAPE,\n                Aes.SIZE, // line width\n                Aes.WIDTH\n            )\n\n            GeomKind.RIBBON -> listOf(\n                Aes.X,\n                Aes.YMIN, Aes.YMAX,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.AREA -> AREA\n            GeomKind.DENSITY -> AREA\n            GeomKind.DENSITY2D -> PATH\n            GeomKind.DENSITY2DF -> POLYGON\n            GeomKind.JITTER -> POINT\n            GeomKind.FREQPOLY -> PATH\n            GeomKind.STEP -> PATH\n            GeomKind.RECT -> listOf(\n                Aes.XMIN, Aes.XMAX,\n                Aes.YMIN, Aes.YMAX,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.SEGMENT -> listOf(\n                Aes.X, Aes.Y,\n                Aes.XEND, Aes.YEND,\n                Aes.SIZE,\n                Aes.LINETYPE,\n                Aes.COLOR,\n                Aes.ALPHA,\n                Aes.SPEED,\n                Aes.FLOW\n            )\n\n            GeomKind.TEXT -> listOf(\n                Aes.X, Aes.Y,\n                Aes.SIZE,\n                Aes.COLOR,\n                Aes.ALPHA,\n                Aes.LABEL,\n                Aes.FAMILY,\n                Aes.FONTFACE,\n                Aes.HJUST,\n                Aes.VJUST,\n                Aes.ANGLE\n            )\n\n            GeomKind.LIVE_MAP -> listOf( // ToDo: not static - depends on 'display mode'\n                Aes.ALPHA,\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.SIZE,\n                Aes.SHAPE,\n                Aes.FRAME,\n                Aes.X,\n                Aes.Y,\n                Aes.SYM_X,\n                Aes.SYM_Y\n            )\n\n            GeomKind.RASTER -> listOf(\n                Aes.X, Aes.Y,\n                Aes.WIDTH, // not rendered but required for correct x aes range computation\n                Aes.HEIGHT, // -- the same --\n                Aes.FILL,\n                Aes.ALPHA\n            )\n\n            GeomKind.IMAGE -> listOf(\n                Aes.XMIN,\n                Aes.XMAX,\n                Aes.YMIN,\n                Aes.YMAX\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninterface PositionAdjustment {\n    val isIdentity: Boolean\n        get() = false\n\n    fun handlesGroups(): Boolean\n\n    fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base\n\ninterface Stat {\n    fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit = {}): DataFrame\n\n    fun consumes(): List<Aes<*>>\n\n    fun hasDefaultMapping(aes: Aes<*>): Boolean\n\n    fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.plot.base.render.point.NamedShape\n\nobject AesInitValue {\n\n    private val VALUE_MAP = TypedKeyHashMap()\n\n    init {\n        VALUE_MAP[X] = 0.0\n        VALUE_MAP[Y] = 0.0\n        VALUE_MAP[Z] = 0.0\n        VALUE_MAP[YMIN] = Double.NaN\n        VALUE_MAP[YMAX] = Double.NaN\n        VALUE_MAP[COLOR] = Color.PACIFIC_BLUE\n        VALUE_MAP[FILL] = Color.PACIFIC_BLUE\n        VALUE_MAP[ALPHA] = 1.0\n        VALUE_MAP[SHAPE] = NamedShape.SOLID_CIRCLE\n        VALUE_MAP[LINETYPE] = NamedLineType.SOLID\n        VALUE_MAP[SIZE] = 0.5  // Line thickness. Should be redefined for other shapes\n        VALUE_MAP[WIDTH] = 1.0\n        VALUE_MAP[HEIGHT] = 1.0\n        VALUE_MAP[WEIGHT] = 1.0\n        VALUE_MAP[INTERCEPT] = 0.0\n        VALUE_MAP[SLOPE] = 1.0\n        VALUE_MAP[XINTERCEPT] = 0.0\n        VALUE_MAP[YINTERCEPT] = 0.0\n        VALUE_MAP[LOWER] = Double.NaN\n        VALUE_MAP[MIDDLE] = Double.NaN\n        VALUE_MAP[UPPER] = Double.NaN\n        VALUE_MAP[FRAME] = \"empty frame\"\n        VALUE_MAP[SPEED] = 10.0\n        VALUE_MAP[FLOW] = 0.1\n        VALUE_MAP[XMIN] = Double.NaN\n        VALUE_MAP[XMAX] = Double.NaN\n        VALUE_MAP[XEND] = Double.NaN\n        VALUE_MAP[YEND] = Double.NaN\n        VALUE_MAP[LABEL] = \"\"\n        VALUE_MAP[FAMILY] = \"sans-serif\"\n        VALUE_MAP[FONTFACE] = \"plain\"\n        VALUE_MAP[HJUST] = 0.5  // 'middle'\n        VALUE_MAP[VJUST] = 0.5  // 'middle'\n        VALUE_MAP[ANGLE] = 0.0\n        VALUE_MAP[SYM_X] = 0.0\n        VALUE_MAP[SYM_Y] = 0.0\n    }\n\n    /**\n     * For test only (must br TRUE for any Aes)\n     */\n    fun has(aes: Aes<*>): Boolean {\n        return VALUE_MAP.containsKey(aes)\n    }\n\n    operator fun <T> get(aes: Aes<T>): T {\n        return VALUE_MAP.get<T>(aes)\n    }\n\n    operator fun <T> get(aes: TypedKey<T>): T {\n        return VALUE_MAP.get<T>(aes)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject AesScaling {\n    const val UNIT_SHAPE_SIZE = 2.2\n\n    fun strokeWidth(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2.0\n    }\n\n    fun circleDiameter(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * UNIT_SHAPE_SIZE\n    }\n\n    fun circleDiameterSmaller(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 1.5\n    }\n\n    fun sizeFromCircleDiameter(diameter: Double): Double {\n        // px -> aes Units\n        return diameter / UNIT_SHAPE_SIZE\n    }\n\n    fun textSize(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2\n    }\n\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\n\nabstract class AesVisitor<T> {\n    fun visit(aes: Aes<*>): T {\n        return if (aes.isNumeric) {\n            // Safe cast because all 'numeric' aesthetics are <Double>\n            @Suppress(\"UNCHECKED_CAST\")\n            visitNumeric(aes as Aes<Double>)\n        } else visitIntern(aes)\n    }\n\n    /**\n     * Descendants can override\n     *\n     * @param aes\n     */\n    @Suppress(\"MemberVisibilityCanBePrivate\")\n    protected fun visitNumeric(aes: Aes<Double>): T {\n        return visitIntern(aes)\n    }\n\n    private fun visitIntern(aes: Aes<*>): T {\n        if (aes == X) {\n            return x()\n        }\n        if (aes == Y) {\n            return y()\n        }\n        if (aes == Z) {\n            return z()\n        }\n        if (aes == YMIN) {\n            return ymin()\n        }\n        if (aes == YMAX) {\n            return ymax()\n        }\n        if (aes == COLOR) {\n            return color()\n        }\n        if (aes == FILL) {\n            return fill()\n        }\n        if (aes == ALPHA) {\n            return alpha()\n        }\n        if (aes == SHAPE) {\n            return shape()\n        }\n        if (aes == SIZE) {\n            return size()\n        }\n        if (aes == LINETYPE) {\n            return lineType()\n        }\n        if (aes == WIDTH) {\n            return width()\n        }\n        if (aes == HEIGHT) {\n            return height()\n        }\n        if (aes == WEIGHT) {\n            return weight()\n        }\n        if (aes == INTERCEPT) {\n            return intercept()\n        }\n        if (aes == SLOPE) {\n            return slope()\n        }\n        if (aes == XINTERCEPT) {\n            return interceptX()\n        }\n        if (aes == YINTERCEPT) {\n            return interceptY()\n        }\n        if (aes == LOWER) {\n            return lower()\n        }\n        if (aes == MIDDLE) {\n            return middle()\n        }\n        if (aes == UPPER) {\n            return upper()\n        }\n        if (aes == FRAME) {\n            return frame()\n        }\n        if (aes == SPEED) {\n            return speed()\n        }\n        if (aes == FLOW) {\n            return flow()\n        }\n        if (aes == XMIN) {\n            return xmin()\n        }\n        if (aes == XMAX) {\n            return xmax()\n        }\n        if (aes == XEND) {\n            return xend()\n        }\n        if (aes == YEND) {\n            return yend()\n        }\n        if (aes == LABEL) {\n            return label()\n        }\n        if (aes == FAMILY) {\n            return family()\n        }\n        if (aes == FONTFACE) {\n            return fontface()\n        }\n        if (aes == HJUST) {\n            return hjust()\n        }\n        if (aes == VJUST) {\n            return vjust()\n        }\n        if (aes == ANGLE) {\n            return angle()\n        }\n\n        if (aes == SYM_X) {\n            return symX()\n        }\n\n        if (aes == SYM_Y) {\n            return symY()\n        }\n\n        throw IllegalArgumentException(\"Unexpected aes: $aes\")\n    }\n\n    protected abstract fun x(): T\n\n    protected abstract fun y(): T\n\n    protected abstract fun z(): T\n\n    protected abstract fun ymin(): T\n\n    protected abstract fun ymax(): T\n\n    protected abstract fun color(): T\n\n    protected abstract fun fill(): T\n\n    protected abstract fun alpha(): T\n\n    protected abstract fun shape(): T\n\n    protected abstract fun lineType(): T\n\n    protected abstract fun size(): T\n\n    protected abstract fun width(): T\n\n    protected abstract fun height(): T\n\n    protected abstract fun weight(): T\n\n    protected abstract fun intercept(): T\n\n    protected abstract fun slope(): T\n\n    protected abstract fun interceptX(): T\n\n    protected abstract fun interceptY(): T\n\n    protected abstract fun lower(): T\n\n    protected abstract fun middle(): T\n\n    protected abstract fun upper(): T\n\n    protected abstract fun frame(): T\n\n    protected abstract fun speed(): T\n\n    protected abstract fun flow(): T\n\n    protected abstract fun xmin(): T\n\n    protected abstract fun xmax(): T\n\n    protected abstract fun xend(): T\n\n    protected abstract fun yend(): T\n\n    protected abstract fun label(): T\n\n    protected abstract fun family(): T\n\n    protected abstract fun fontface(): T\n\n    protected abstract fun hjust(): T\n\n    protected abstract fun vjust(): T\n\n    protected abstract fun angle(): T\n\n    protected abstract fun symX(): T\n\n    protected abstract fun symY(): T\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.function.Function\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Sets\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.jvm.JvmOverloads\n\nclass AestheticsBuilder @JvmOverloads constructor(private var myDataPointCount: Int = 0) {\n\n    private val myIndexFunctionMap: MutableMap<Aes<*>, (Int) -> Any?>\n    private var myGroup = constant(0)\n    private val myConstantAes = Sets.newHashSet(Aes.values())  // initially contains all Aes;\n    private val myOverallRangeByNumericAes = HashMap<Aes<Double>, ClosedRange<Double>>()\n\n    init {\n        myIndexFunctionMap = HashMap()\n        for (aes in Aes.values()) {\n            // Safe cast because AesInitValue.get(aes) is guaranteed to return correct type.\n            myIndexFunctionMap[aes] =\n                constant(\n                    AesInitValue[aes]\n                )\n        }\n    }\n\n    fun dataPointCount(v: Int): AestheticsBuilder {\n        myDataPointCount = v\n        return this\n    }\n\n    fun overallRange(aes: Aes<Double>, range: ClosedRange<Double>): AestheticsBuilder {\n        // It's full range (length px) of x/y axis\n        myOverallRangeByNumericAes[aes] = range\n        return this\n    }\n\n    fun x(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(X, v)\n    }\n\n    fun y(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(Y, v)\n    }\n\n    fun color(v: (Int) -> Color?): AestheticsBuilder {\n        return aes(COLOR, v)\n    }\n\n    fun fill(v: (Int) -> Color?): AestheticsBuilder {\n        return aes(FILL, v)\n    }\n\n    fun alpha(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(ALPHA, v)\n    }\n\n    fun shape(v: (Int) -> PointShape?): AestheticsBuilder {\n        return aes(SHAPE, v)\n    }\n\n    fun lineType(v: (Int) -> LineType?): AestheticsBuilder {\n        return aes(LINETYPE, v)\n    }\n\n    fun size(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SIZE, v)\n    }\n\n    fun width(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(WIDTH, v)\n    }\n\n    fun weight(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(WEIGHT, v)\n    }\n\n    fun frame(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FRAME, v)\n    }\n\n    fun speed(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SPEED, v)\n    }\n\n    fun flow(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(FLOW, v)\n    }\n\n    fun group(v: (Int) -> Int): AestheticsBuilder {\n        myGroup = v\n        return this\n    }\n\n    fun label(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(LABEL, v)\n    }\n\n    fun family(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FAMILY, v)\n    }\n\n    fun fontface(v: (Int) -> String?): AestheticsBuilder {\n        return aes(FONTFACE, v)\n    }\n\n    fun hjust(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(HJUST, v)\n    }\n\n    fun vjust(v: (Int) -> Any?): AestheticsBuilder {\n        return aes(VJUST, v)\n    }\n\n    fun angle(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(ANGLE, v)\n    }\n\n    fun xmin(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(XMIN, v)\n    }\n\n    fun xmax(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(XMAX, v)\n    }\n\n    fun ymin(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(YMIN, v)\n    }\n\n    fun ymax(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(YMAX, v)\n    }\n\n    fun symX(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SYM_X, v)\n    }\n\n    fun symY(v: (Int) -> Double?): AestheticsBuilder {\n        return aes(SYM_Y, v)\n    }\n\n    fun <T> constantAes(aes: Aes<T>, v: T): AestheticsBuilder {\n        myConstantAes.add(aes)\n        myIndexFunctionMap[aes] = constant(v)\n        return this\n    }\n\n    fun <T> aes(aes: Aes<T>, v: (Int) -> T?): AestheticsBuilder {\n        myConstantAes.remove(aes)\n        myIndexFunctionMap[aes] = v\n        return this\n    }\n\n    fun build(): Aesthetics {\n        return MyAesthetics(this)\n    }\n\n\n    private class MyAesthetics internal constructor(b: AestheticsBuilder) : Aesthetics {\n        private val myDataPointCount: Int = b.myDataPointCount\n        private val myIndexFunctionMap =\n            TypedIndexFunctionMap(b.myIndexFunctionMap)\n        val group = b.myGroup\n        private val myConstantAes: Set<Aes<*>>\n        private val myOverallRangeByNumericAes: Map<Aes<Double>, ClosedRange<Double>>\n\n        private val myResolutionByAes = HashMap<Aes<*>, Double>()\n        private val myRangeByNumericAes = HashMap<Aes<Double>, ClosedRange<Double>?>()\n\n        override val isEmpty: Boolean\n            get() = myDataPointCount == 0\n\n        init {\n            myConstantAes = HashSet(b.myConstantAes)\n            myOverallRangeByNumericAes = HashMap(b.myOverallRangeByNumericAes)\n        }\n\n        fun <T> aes(aes: Aes<T>): (Int) -> T {\n            return myIndexFunctionMap[aes]\n        }\n\n        override fun dataPointAt(index: Int): DataPointAesthetics {\n            return MyDataPointAesthetics(\n                index,\n                this\n            )\n        }\n\n        override fun dataPointCount(): Int {\n            return myDataPointCount\n        }\n\n        override fun dataPoints(): Iterable<DataPointAesthetics> {\n            val self = this\n            return object : Iterable<DataPointAesthetics> {\n                override fun iterator(): Iterator<DataPointAesthetics> =\n                    MyDataPointsIterator(\n                        myDataPointCount,\n                        self\n                    )\n            }\n        }\n\n        override fun range(aes: Aes<Double>): ClosedRange<Double>? {\n            if (!myRangeByNumericAes.containsKey(aes)) {\n                val r = when {\n                    myDataPointCount <= 0 ->\n                        ClosedRange(0.0, 0.0)\n                    myConstantAes.contains(aes) -> {\n                        // constant should not be null\n                        val v = numericValues(aes).iterator().next()!!\n                        if (v.isFinite()) {\n                            ClosedRange(v, v)\n                        } else null\n                    }\n                    else -> {\n                        val values = numericValues(aes)\n                        SeriesUtil.range(values)\n                    }\n                }\n                myRangeByNumericAes[aes] = r\n            }\n\n            return myRangeByNumericAes[aes]\n        }\n\n        override fun overallRange(aes: Aes<Double>): ClosedRange<Double> {\n            return myOverallRangeByNumericAes[aes] ?: error(\"Overall range is unknown for $aes\")\n        }\n\n        override fun resolution(aes: Aes<Double>, naValue: Double): Double {\n            if (!myResolutionByAes.containsKey(aes)) {\n                val resolution: Double =\n                    when {\n                        myConstantAes.contains(aes) -> 0.0\n                        else -> {\n                            val values = numericValues(aes)\n                            SeriesUtil.resolution(values, naValue)\n                        }\n                    }\n                myResolutionByAes[aes] = resolution\n            }\n\n            return myResolutionByAes[aes]!!\n        }\n\n        override fun numericValues(aes: Aes<Double>): Iterable<Double?> {\n            require(aes.isNumeric) { \"Numeric aes is expected: $aes\" }\n            return object : Iterable<Double> {\n                override fun iterator(): Iterator<Double> {\n                    return AesIterator(\n                        myDataPointCount,\n                        aes(aes)\n                    )\n                }\n            }\n        }\n\n        override fun groups(): Iterable<Int> {\n            return object : Iterable<Int> {\n                override fun iterator(): Iterator<Int> {\n                    return AesIterator(\n                        myDataPointCount,\n                        group\n                    )\n                }\n            }\n        }\n    }\n\n    private class MyDataPointsIterator internal constructor(\n        private val myLength: Int,\n        private val myAesthetics: MyAesthetics\n    ) : Iterator<DataPointAesthetics> {\n        private var myIndex = 0\n\n        override fun hasNext(): Boolean {\n            return myIndex < myLength\n        }\n\n        override fun next(): DataPointAesthetics {\n            if (hasNext()) {\n                return myAesthetics.dataPointAt(myIndex++)\n            }\n            throw NoSuchElementException(\"index=$myIndex\")\n        }\n    }\n\n    private class AesIterator<T> internal constructor(private val myLength: Int, private val myAes: (Int) -> T) :\n        Iterator<T> {\n        private var myIndex = 0\n\n        override fun hasNext(): Boolean {\n            return myIndex < myLength\n        }\n\n        override fun next(): T {\n            if (hasNext()) {\n                return myAes(myIndex++)\n            }\n            throw NoSuchElementException(\"index=$myIndex\")\n        }\n    }\n\n\n    private class MyDataPointAesthetics(\n        private val myIndex: Int?,\n        private val myAesthetics: MyAesthetics\n    ) : DataPointAesthetics {\n\n        override fun index(): Int {\n            return myIndex!!\n        }\n\n        override fun x(): Double? {\n            return get(X)\n        }\n\n        override fun y(): Double? {\n            return get(Y)\n        }\n\n        override fun z(): Double? {\n            return get(Z)\n        }\n\n        override fun ymin(): Double? {\n            return get(YMIN)\n        }\n\n        override fun ymax(): Double? {\n            return get(YMAX)\n        }\n\n        override fun color(): Color {\n            return get(COLOR)\n        }\n\n        override fun fill(): Color {\n            return get(FILL)\n        }\n\n        override fun alpha(): Double? {\n            return get(ALPHA)\n        }\n\n        override fun shape(): PointShape {\n            return get(SHAPE)\n        }\n\n        override fun lineType(): LineType {\n            return get(LINETYPE)\n        }\n\n        override fun size(): Double? {\n            return get(SIZE)\n        }\n\n        override fun width(): Double? {\n            return get(WIDTH)\n        }\n\n        override fun height(): Double? {\n            return get(HEIGHT)\n        }\n\n        override fun weight(): Double? {\n            return get(WEIGHT)\n        }\n\n        override fun intercept(): Double? {\n            return get(INTERCEPT)\n        }\n\n        override fun slope(): Double? {\n            return get(SLOPE)\n        }\n\n        override fun interceptX(): Double? {\n            return get(XINTERCEPT)\n        }\n\n        override fun interceptY(): Double? {\n            return get(YINTERCEPT)\n        }\n\n        override fun lower(): Double? {\n            return get(LOWER)\n        }\n\n        override fun middle(): Double? {\n            return get(MIDDLE)\n        }\n\n        override fun upper(): Double? {\n            return get(UPPER)\n        }\n\n        override fun frame(): String {\n            return get(FRAME)\n        }\n\n        override fun speed(): Double? {\n            return get(SPEED)\n        }\n\n        override fun flow(): Double? {\n            return get(FLOW)\n        }\n\n        override fun xmin(): Double? {\n            return get(XMIN)\n        }\n\n        override fun xmax(): Double? {\n            return get(XMAX)\n        }\n\n        override fun xend(): Double? {\n            return get(XEND)\n        }\n\n        override fun yend(): Double? {\n            return get(YEND)\n        }\n\n        override fun label(): Any? {\n            return get(LABEL)\n        }\n\n        override fun family(): String {\n            return get(FAMILY)\n        }\n\n        override fun fontface(): String {\n            return get(FONTFACE)\n        }\n\n        override fun hjust(): Any {\n            return get(HJUST)\n        }\n\n        override fun vjust(): Any {\n            return get(VJUST)\n        }\n\n        override fun angle(): Double? {\n            return get(ANGLE)\n        }\n\n        override fun symX(): Double? {\n            return get(SYM_X)\n        }\n\n        override fun symY(): Double? {\n            return get(SYM_Y)\n        }\n\n        override fun group(): Int? {\n            return myAesthetics.group(myIndex!!)\n        }\n\n        override fun numeric(aes: Aes<Double>): Double? {\n            return get(aes)\n        }\n\n        override fun <T> get(aes: Aes<T>): T {\n            return myAesthetics.aes(aes)(myIndex!!)\n        }\n    }\n\n\n    private class ArrayAes<ValueT> internal constructor(private val myVal: Array<out ValueT>) : Function<Int, ValueT> {\n        override fun apply(value: Int): ValueT {\n            return myVal[value]\n        }\n    }\n\n    private class MapperAes<ValueT> internal constructor(\n        private val myL: List<Double>,\n        private val myF: ((Double) -> ValueT)\n    ) : Function<Int, ValueT> {\n        override fun apply(value: Int): ValueT {\n            return myF(myL[value])\n        }\n    }\n\n    companion object {\n        fun <T> constant(v: T): (Int) -> T = { v }\n\n        fun <T> array(v: Array<T>): (Int) -> T {\n            return { value -> v[value] }\n        }\n\n//        fun <T> array(vararg v: T): (Int) -> T {\n//            return { value -> v[value] }\n//        }\n\n        fun <T> collection(v: Collection<T>): (Int) -> T {\n            return { value -> Iterables[v, value] }\n        }\n\n        fun <T> listMapper(v: List<Double?>, f: (Double?) -> T?): (Int) -> T? {\n            return { value -> f(v[value]) }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants\n\nopen class AestheticsDefaults {\n\n    private val myDefaults = TypedKeyHashMap().apply {\n        for (aes in Aes.values()) {\n            // Safe cast because AesInitValue.get(aes) is guaranteed to return correct type.\n            @Suppress(\"UNCHECKED_CAST\")\n            put(aes as Aes<Any>, AesInitValue[aes])\n        }\n    }\n    private val myDefaultsInLegend = TypedKeyHashMap()\n\n    protected fun <T> update(aes: Aes<T>, defaultValue: T): AestheticsDefaults {\n        myDefaults.put(aes, defaultValue)\n        return this\n    }\n\n    protected fun <T> updateInLegend(aes: Aes<T>, defaultValue: T): AestheticsDefaults {\n        myDefaultsInLegend.put(aes, defaultValue)\n        return this\n    }\n\n\n    open fun rangeIncludesZero(aes: Aes<*>): Boolean {\n        return false\n    }\n\n    fun <T> defaultValue(aes: Aes<T>): T {\n        return myDefaults[aes]\n    }\n\n    fun <T> defaultValueInLegend(aes: Aes<T>): T {\n        return if (myDefaultsInLegend.containsKey(aes)) {\n            myDefaultsInLegend[aes]\n        } else defaultValue(aes)\n    }\n\n    companion object {\n        fun point(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 2.0)\n                .updateInLegend(Aes.SIZE, 5.0)\n        }\n\n        fun path(): AestheticsDefaults {\n            return base()\n        }\n\n        fun line(): AestheticsDefaults {\n            return path()\n        }\n\n        fun abline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun hline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun vline(): AestheticsDefaults {\n            return path()\n        }\n\n        fun smooth(): AestheticsDefaults {\n            return path()\n                .update(Aes.COLOR, Color.MAGENTA)\n                .update(Aes.FILL, Color.BLACK)\n        }\n\n        fun bar(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n                .update(Aes.WIDTH, 0.9)\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun histogram(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun tile(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun bin2d(): AestheticsDefaults {\n            return tile()\n        }\n\n        fun errorBar(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.COLOR, Color.BLACK)\n        }\n\n        fun crossBar(): AestheticsDefaults {\n            return AestheticsDefaults()\n                .update(Aes.WIDTH, 0.9)\n                .update(Aes.COLOR, Color.BLACK)\n                .update(Aes.FILL, Color.WHITE)\n        }\n\n        fun lineRange(): AestheticsDefaults {\n            return path()\n        }\n\n        fun pointRange(): AestheticsDefaults {\n            return path()\n        }\n\n        fun polygon(): AestheticsDefaults {\n            return base()\n                .update(Aes.COLOR, Color.TRANSPARENT)    // no outline (transparent)\n        }\n\n        fun map(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 0.2)                    // outline thickness\n                .update(Aes.COLOR, Color.GRAY)\n                .update(Aes.FILL, Color.TRANSPARENT)\n        }\n\n        fun boxplot(): AestheticsDefaults {\n            return crossBar()\n        }\n\n        fun livemap(displayMode: LivemapConstants.DisplayMode): AestheticsDefaults {\n            return when (displayMode) {\n                LivemapConstants.DisplayMode.POINT -> point()\n                    .updateInLegend(Aes.SIZE, 5.0)\n                LivemapConstants.DisplayMode.BAR -> base()\n                    .update(Aes.SIZE, 40.0)\n                    .update(Aes.COLOR, Color.TRANSPARENT)\n                LivemapConstants.DisplayMode.PIE -> base()\n                    .update(Aes.SIZE, 20.0)\n                    .update(Aes.COLOR, Color.TRANSPARENT)\n                    .updateInLegend(Aes.SIZE, 5.0)\n            }\n        }\n\n        fun ribbon(): AestheticsDefaults {\n            return base()\n        }\n\n        fun area(): AestheticsDefaults {\n            return object : AestheticsDefaults() {\n                override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n                    return aes == Aes.Y || super.rangeIncludesZero(aes)\n                }\n            }\n        }\n\n        fun density(): AestheticsDefaults {\n            return area()\n                .update(Aes.FILL, Color.TRANSPARENT)\n        }\n\n        fun contour(): AestheticsDefaults {\n            return path()\n        }\n\n        fun contourf(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 0.0)\n        }\n\n        fun density2d(): AestheticsDefaults {\n            return contour()\n        }\n\n        fun density2df(): AestheticsDefaults {\n            return contourf()\n        }\n\n        fun jitter(): AestheticsDefaults {\n            return point()\n        }\n\n        fun freqpoly(): AestheticsDefaults {\n            return path()\n        }\n\n        fun step(): AestheticsDefaults {\n            return path()\n        }\n\n        fun rect(): AestheticsDefaults {\n            return polygon()\n        }\n\n        fun segment(): AestheticsDefaults {\n            return path()\n        }\n\n        fun text(): AestheticsDefaults {\n            return base()\n                .update(Aes.SIZE, 7.0)\n                .update(Aes.COLOR, Color.parseHex(\"#3d3d3d\")) // dark gray\n        }\n\n\n        fun raster(): AestheticsDefaults {\n            return base()\n        }\n\n        fun image(): AestheticsDefaults {\n            return base()\n        }\n\n        private fun base(): AestheticsDefaults {\n            return AestheticsDefaults()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors.solid\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.point.UpdatableShape\nimport jetbrains.datalore.vis.svg.SvgShape\nimport jetbrains.datalore.vis.svg.SvgUtils\n\nobject AestheticsUtil {\n    //affects bar, smooth, area and ribbon\n    internal const val ALPHA_CONTROLS_BOTH = false\n\n    fun fill(filled: Boolean, solid: Boolean, p: DataPointAesthetics): Color {\n        if (filled) {\n            return p.fill()!!\n        } else if (solid) {\n            return p.color()!!\n        }\n        return Color.TRANSPARENT\n    }\n\n    fun decorate(shape: UpdatableShape, filled: Boolean, solid: Boolean, p: DataPointAesthetics, strokeWidth: Double) {\n        val fill = fill(filled, solid, p)\n        val stroke = p.color()!!\n\n        var fillAlpha = 0.0\n        if (filled || solid) {\n            fillAlpha = alpha(fill, p)\n        }\n\n        var strokeAlpha = 0.0\n        if (strokeWidth > 0) {\n            strokeAlpha = alpha(stroke, p)\n        }\n\n        shape.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    fun alpha(color: Color, p: DataPointAesthetics): Double {\n        return if (solid(color)) {    // only apply 'aes' alpha to solid colors\n            p.alpha()!!\n        } else SvgUtils.alpha2opacity(color.alpha)\n\n        // else, override with color's alpha\n    }\n\n    fun strokeWidth(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2.0\n    }\n//\n//    fun circleDiameter(p: DataPointAesthetics): Double {\n//        // aes Units -> px\n//        return p.size()!! * 2.2\n//    }\n//\n//    fun circleDiameterSmaller(p: DataPointAesthetics): Double {\n//        // aes Units -> px\n//        return p.size()!! * 1.5\n//    }\n//\n//    fun sizeFromCircleDiameter(diameter: Double): Double {\n//        // px -> aes Units\n//        return diameter / 2.2\n//    }\n//\n    fun textSize(p: DataPointAesthetics): Double {\n        // aes Units -> px\n        return p.size()!! * 2\n    }\n\n    fun updateStroke(shape: SvgShape, p: DataPointAesthetics, applyAlpha: Boolean) {\n        shape.strokeColor().set(p.color())\n        if (solid(p.color()!!) && applyAlpha) {\n            shape.strokeOpacity().set(p.alpha())\n        }\n    }\n\n    fun updateFill(shape: SvgShape, p: DataPointAesthetics) {\n        shape.fillColor().set(p.fill())\n        if (solid(p.fill()!!)) {\n            shape.fillOpacity().set(p.alpha())\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.aes\n\nimport jetbrains.datalore.plot.base.Aes\n\ninternal class TypedIndexFunctionMap(indexFunctionMap: Map<Aes<*>, (Int) -> Any?>) {\n    private var myMap: Map<Aes<*>, (Int) -> Any?> = indexFunctionMap\n\n    operator fun <T> get(aes: Aes<T>): (Int) -> T {\n        // Safe cast if 'put' is used responsibly.\n        @Suppress(\"UNCHECKED_CAST\")\n        return myMap[aes] as ((Int) -> T)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\n\nobject Coords {\n    fun create(\n        xRange: ClosedRange<Double>,\n        yRange: ClosedRange<Double>,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordinateSystem {\n        val origin = DoubleVector(\n            originX(xRange),\n            originY(yRange)\n        )\n        return create(origin, xLim, yLim)\n    }\n\n    fun create(\n        origin: DoubleVector,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordinateSystem {\n        return DefaultCoordinateSystem(\n            toClientOffsetX(origin.x),\n            toClientOffsetY(origin.y),\n            fromClientOffsetX(origin.x),\n            fromClientOffsetY(origin.y),\n            xLim,\n            yLim\n        )\n    }\n\n    fun toClientOffsetX(xRange: ClosedRange<Double>): (Double) -> Double {\n        return toClientOffsetX(\n            originX(\n                xRange\n            )\n        )\n    }\n\n    fun toClientOffsetY(yRange: ClosedRange<Double>): (Double) -> Double {\n        return toClientOffsetY(\n            originY(\n                yRange\n            )\n        )\n    }\n\n    private fun originX(xRange: ClosedRange<Double>): Double {\n        return -xRange.lowerEnd\n    }\n\n    private fun originY(yRange: ClosedRange<Double>): Double {\n        return yRange.upperEnd\n    }\n\n    private fun toClientOffsetX(originX: Double): (Double) -> Double {\n        return { x -> originX + x }\n    }\n\n    private fun fromClientOffsetX(originX: Double): (Double) -> Double {\n        return { x -> x - originX }\n    }\n\n    private fun toClientOffsetY(originY: Double): (Double) -> Double {\n        // y-axis is inverted\n        return { y -> originY - y }\n    }\n\n    private fun fromClientOffsetY(originY: Double): (Double) -> Double {\n        // y-axis is inverted\n        return { y -> originY - y }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleRectangles\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.geom.util.GeomCoord\n\ninternal class DefaultCoordinateSystem(\n    private val myToClientOffsetX: (Double) -> Double,\n    private val myToClientOffsetY: (Double) -> Double,\n    private val myFromClientOffsetX: (Double) -> Double,\n    private val myFromClientOffsetY: (Double) -> Double,\n    private val xLim: ClosedRange<Double>?,\n    private val yLim: ClosedRange<Double>?\n) :\n    CoordinateSystem {\n\n    override fun toClient(p: DoubleVector): DoubleVector {\n        return DoubleVector(myToClientOffsetX(p.x), myToClientOffsetY(p.y))\n    }\n\n    override fun fromClient(p: DoubleVector): DoubleVector {\n        return DoubleVector(myFromClientOffsetX(p.x), myFromClientOffsetY(p.y))\n    }\n\n    override fun isPointInLimits(p: DoubleVector, isClient: Boolean): Boolean {\n        val coord = if (isClient) fromClient(p) else p\n        return (xLim?.contains(coord.x) ?: true) && (yLim?.contains(coord.y) ?: true)\n    }\n\n    override fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean): Boolean {\n        val r = if (isClient) GeomCoord(this).fromClient(rect) else rect\n        return (xLim?.encloses(r.xRange()) ?: true) && (yLim?.encloses(r.yRange()) ?: true)\n    }\n\n    override fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean): Boolean {\n        return path.any { point -> isPointInLimits(point, isClient) }\n    }\n\n    override fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean): Boolean {\n        val bbox = DoubleRectangles.boundingBox(polygon)\n        return isRectInLimits(bbox, isClient)\n    }\n\n    override val xClientLimit: ClosedRange<Double>?\n        get() = xLim?.let { range -> convertRange(range, myToClientOffsetX) }\n\n    override val yClientLimit: ClosedRange<Double>?\n        get() = yLim?.let { range -> convertRange(range, myToClientOffsetY) }\n\n    private fun convertRange(range: ClosedRange<Double>, transform: (Double) -> Double): ClosedRange<Double> {\n        val l = transform(range.lowerEnd)\n        val u = transform(range.upperEnd)\n        return ClosedRange(\n            min(l, u),\n            max(l, u),\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.stat.Stats\nimport kotlin.jvm.JvmOverloads\n\nobject DataFrameUtil {\n    fun transformVarFor(aes: Aes<*>): DataFrame.Variable {\n        return TransformVar.forAes(aes)\n    }\n\n    fun applyTransform(data: DataFrame, `var`: DataFrame.Variable, aes: Aes<*>, scale: Scale<*>): DataFrame {\n        val transformVar = transformVarFor(aes)\n        return applyTransform(data, `var`, transformVar, scale)\n    }\n\n    private fun applyTransform(\n        data: DataFrame,\n        variable: DataFrame.Variable,\n        transformVar: DataFrame.Variable,\n        scale: Scale<*>\n    ): DataFrame {\n//        val transformSource = getTransformSource(data, variable, scale)\n//        val transformResult = scale.transform.apply(transformSource)\n\n        var transformed = scale.applyTransform(\n            data[variable],\n            checkLimits = true\n        )\n        return data.builder()\n            .putNumeric(transformVar, transformed)\n            .build()\n    }\n\n//    private fun getTransformSource(data: DataFrame, variable: DataFrame.Variable, scale: Scale<*>): List<*> {\n//        var transformSource = data[variable]\n//        return ScaleUtil.cleanUpTransformSource(transformSource, scale)\n//    }\n\n    fun hasVariable(data: DataFrame, varName: String): Boolean {\n        for (`var` in data.variables()) {\n            if (varName == `var`.name) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun findVariableOrFail(data: DataFrame, varName: String): DataFrame.Variable {\n        for (variable in data.variables()) {\n            if (varName == variable.name) {\n                return variable\n            }\n        }\n        throw IllegalArgumentException(\n            \"Variable not found: '$varName'. Variables in data frame: ${\n                data.variables().map { \"'${it.name}'\" }\n            }\"\n        )\n    }\n\n    fun isNumeric(data: DataFrame, varName: String): Boolean {\n        return data.isNumeric(findVariableOrFail(data, varName))\n    }\n\n    fun sortedCopy(variables: Iterable<DataFrame.Variable>): List<DataFrame.Variable> {\n        val ordering = Ordering.from(Comparator<DataFrame.Variable> { o1, o2 -> o1.name.compareTo(o2.name) })\n        return ordering.sortedCopy(variables)\n    }\n\n    fun variables(df: DataFrame): Map<String, DataFrame.Variable> {\n        return df.variables().associateBy(DataFrame.Variable::name)\n    }\n\n    fun appendReplace(df0: DataFrame, df1: DataFrame): DataFrame {\n        fun DataFrame.Builder.put(destVars: Collection<DataFrame.Variable>, df: DataFrame) = apply {\n            destVars.forEach { destVar ->\n                val srcVar = findVariableOrFail(df, destVar.name)\n                when (df.isNumeric(srcVar)) {\n                    true -> putNumeric(destVar, df.getNumeric(srcVar))\n                    false -> putDiscrete(destVar, df[srcVar])\n                }\n            }\n        }\n\n        return DataFrame.Builder()\n            .put(df0.variables().filter { it.name !in variables(df1) }, df0) // df0 - df1, keep vars from df0\n            .put(df0.variables().filter { it.name in variables(df1) }, df1)  // df0 & df1, keep vars from df0\n            .put(df1.variables().filter { it.name !in variables(df0) }, df1) // df1 - df0, new vars from df1\n            .build()\n    }\n\n    fun toMap(df: DataFrame): Map<String, List<*>> {\n        val result = HashMap<String, List<*>>()\n        val variables = df.variables()\n        for (`var` in variables) {\n            result[`var`.name] = df[`var`]\n        }\n        return result\n    }\n\n    fun fromMap(map: Map<*, *>): DataFrame {\n        val frameBuilder = DataFrame.Builder()\n        for ((key, value) in map) {\n            require(key is String) {\n                \"Map to data-frame: key expected a String but was \" + key!!::class.simpleName + \" : \" + key\n            }\n            require(value is List<*>) {\n                \"Map to data-frame: value expected a List but was \" + value!!::class.simpleName + \" : \" + value\n            }\n            frameBuilder.put(createVariable(key), value)\n        }\n        return frameBuilder.build()\n    }\n\n    @JvmOverloads\n    fun createVariable(name: String, label: String = name): DataFrame.Variable {\n        return when {\n            TransformVar.isTransformVar(name) -> TransformVar[name]\n            Stats.isStatVar(name) -> Stats.statVar(name)\n            Dummies.isDummyVar(name) -> Dummies.newDummy(name)\n            else -> DataFrame.Variable(name, DataFrame.Variable.Source.ORIGIN, label)\n        }\n    }\n\n    fun getSummaryText(df: DataFrame): String {\n        val sb = StringBuilder()\n        for (variable in df.variables()) {\n            sb.append(variable.toSummaryString())\n                .append(\" numeric: \" + df.isNumeric(variable))\n                .append(\" size: \" + df[variable].size)\n                .append('\\n')\n        }\n        return sb.toString()\n    }\n\n    fun removeAllExcept(df: DataFrame, keepNames: Set<String>): DataFrame {\n        val b = df.builder()\n        for (variable in df.variables()) {\n            if (!keepNames.contains(variable.name)) {\n                b.remove(variable)\n            }\n        }\n        return b.build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.DataFrame\n\nobject Dummies {\n\n    private const val PREFIX = \"__\"\n\n    fun isDummyVar(varName: String): Boolean {\n        if (!Strings.isNullOrEmpty(varName) && varName.length > PREFIX.length && varName.startsWith(\n                PREFIX\n            )\n        ) {\n            val numStr = varName.substring(PREFIX.length)\n            return numStr.matches(\"[0-9]+\".toRegex())\n        }\n        return false\n    }\n\n    fun dummyNames(count: Int): List<String> {\n        val l = ArrayList<String>()\n        for (i in 0 until count) {\n            l.add(PREFIX + i)\n        }\n        return l\n    }\n\n    fun newDummy(varName: String): DataFrame.Variable {\n        require(isDummyVar(varName)) { \"Not a dummy var name\" }\n        // no label\n        return DataFrame.Variable(varName, DataFrame.Variable.Source.ORIGIN, \"\")\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.data\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable.Source.TRANSFORM\nimport jetbrains.datalore.plot.base.aes.AesVisitor\n\nobject TransformVar {\n    val X = DataFrame.Variable(\"transform.X\", TRANSFORM)\n    val Y = DataFrame.Variable(\"transform.Y\", TRANSFORM)\n    val Z = DataFrame.Variable(\"transform.Z\", TRANSFORM)\n    val YMIN = DataFrame.Variable(\"transform.YMIN\", TRANSFORM)\n    val YMAX = DataFrame.Variable(\"transform.YMAX\", TRANSFORM)\n    val COLOR = DataFrame.Variable(\"transform.COLOR\", TRANSFORM)\n    val FILL = DataFrame.Variable(\"transform.FILL\", TRANSFORM)\n    val ALPHA = DataFrame.Variable(\"transform.ALPHA\", TRANSFORM)\n    val SHAPE = DataFrame.Variable(\"transform.SHAPE\", TRANSFORM)\n    val LINETYPE = DataFrame.Variable(\"transform.LINETYPE\", TRANSFORM)\n    val SIZE = DataFrame.Variable(\"transform.SIZE\", TRANSFORM)\n    val WIDTH = DataFrame.Variable(\"transform.WIDTH\", TRANSFORM)\n    val HEIGHT = DataFrame.Variable(\"transform.HEIGHT\", TRANSFORM)\n    val WEIGHT = DataFrame.Variable(\"transform.WEIGHT\", TRANSFORM)\n    val INTERCEPT = DataFrame.Variable(\"transform.INTERCEPT\", TRANSFORM)\n    val SLOPE = DataFrame.Variable(\"transform.SLOPE\", TRANSFORM)\n    val XINTERCEPT = DataFrame.Variable(\"transform.XINTERCEPT\", TRANSFORM)\n    val YINTERCEPT = DataFrame.Variable(\"transform.YINTERCEPT\", TRANSFORM)\n    val LOWER = DataFrame.Variable(\"transform.LOWER\", TRANSFORM)\n    val MIDDLE = DataFrame.Variable(\"transform.MIDDLE\", TRANSFORM)\n    val UPPER = DataFrame.Variable(\"transform.UPPER\", TRANSFORM)\n    val FRAME = DataFrame.Variable(\"transform.FRAME\", TRANSFORM)\n    val SPEED = DataFrame.Variable(\"transform.SPEED\", TRANSFORM)\n    val FLOW = DataFrame.Variable(\"transform.FLOW\", TRANSFORM)\n    val XMIN = DataFrame.Variable(\"transform.XMIN\", TRANSFORM)\n    val XMAX = DataFrame.Variable(\"transform.XMAX\", TRANSFORM)\n    val XEND = DataFrame.Variable(\"transform.XEND\", TRANSFORM)\n    val YEND = DataFrame.Variable(\"transform.YEND\", TRANSFORM)\n    val LABEL = DataFrame.Variable(\"transform.LABEL\", TRANSFORM)\n    val FONT_FAMILY = DataFrame.Variable(\"transform.FONT_FAMILY\", TRANSFORM)\n    val FONT_FACE = DataFrame.Variable(\"transform.FONT_FACE\", TRANSFORM)\n    val HJUST = DataFrame.Variable(\"transform.HJUST\", TRANSFORM)\n    val VJUST = DataFrame.Variable(\"transform.VJUST\", TRANSFORM)\n    val ANGLE = DataFrame.Variable(\"transform.ANGLE\", TRANSFORM)\n    val SYM_X = DataFrame.Variable(\"transform.SYM_X\", TRANSFORM)\n    val SYM_Y = DataFrame.Variable(\"transform.SYM_Y\", TRANSFORM)\n\n    private val VAR_BY_AES = TransformVarByAes()\n    private val VARS: Map<String, DataFrame.Variable>\n\n    init {\n        val varByName = HashMap<String, DataFrame.Variable>()\n        for (aes in Aes.values()) {\n            val `var` = VAR_BY_AES.visit(aes)\n            varByName[`var`.name] = `var`\n        }\n\n        VARS = varByName\n    }\n\n    fun isTransformVar(varName: String): Boolean {\n        return VARS.containsKey(varName)\n    }\n\n    operator fun get(varName: String): DataFrame.Variable {\n        check(VARS.containsKey(varName)) { \"Unknown transform variable $varName\" }\n        return VARS[varName]!!\n    }\n\n    fun forAes(aes: Aes<*>): DataFrame.Variable {\n        return VAR_BY_AES.visit(aes)\n    }\n\n    private class TransformVarByAes : AesVisitor<DataFrame.Variable>() {\n\n        override fun x(): DataFrame.Variable {\n            return X\n        }\n\n        override fun y(): DataFrame.Variable {\n            return Y\n        }\n\n        override fun z(): DataFrame.Variable {\n            return Z\n        }\n\n        override fun ymin(): DataFrame.Variable {\n            return YMIN\n        }\n\n        override fun ymax(): DataFrame.Variable {\n            return YMAX\n        }\n\n        override fun color(): DataFrame.Variable {\n            return COLOR\n        }\n\n        override fun fill(): DataFrame.Variable {\n            return FILL\n        }\n\n        override fun alpha(): DataFrame.Variable {\n            return ALPHA\n        }\n\n        override fun shape(): DataFrame.Variable {\n            return SHAPE\n        }\n\n        override fun lineType(): DataFrame.Variable {\n            return LINETYPE\n        }\n\n        override fun size(): DataFrame.Variable {\n            return SIZE\n        }\n\n        override fun width(): DataFrame.Variable {\n            return WIDTH\n        }\n\n        override fun height(): DataFrame.Variable {\n            return HEIGHT\n        }\n\n        override fun weight(): DataFrame.Variable {\n            return WEIGHT\n        }\n\n        override fun intercept(): DataFrame.Variable {\n            return INTERCEPT\n        }\n\n        override fun slope(): DataFrame.Variable {\n            return SLOPE\n        }\n\n        override fun interceptX(): DataFrame.Variable {\n            return XINTERCEPT\n        }\n\n        override fun interceptY(): DataFrame.Variable {\n            return YINTERCEPT\n        }\n\n        override fun lower(): DataFrame.Variable {\n            return LOWER\n        }\n\n        override fun middle(): DataFrame.Variable {\n            return MIDDLE\n        }\n\n        override fun upper(): DataFrame.Variable {\n            return UPPER\n        }\n\n        override fun frame(): DataFrame.Variable {\n            return FRAME\n        }\n\n        override fun speed(): DataFrame.Variable {\n            return SPEED\n        }\n\n        override fun flow(): DataFrame.Variable {\n            return FLOW\n        }\n\n        override fun xmin(): DataFrame.Variable {\n            return XMIN\n        }\n\n        override fun xmax(): DataFrame.Variable {\n            return XMAX\n        }\n\n        override fun xend(): DataFrame.Variable {\n            return XEND\n        }\n\n        override fun yend(): DataFrame.Variable {\n            return YEND\n        }\n\n        override fun label(): DataFrame.Variable {\n            return LABEL\n        }\n\n        override fun family(): DataFrame.Variable {\n            return FONT_FAMILY\n        }\n\n        override fun fontface(): DataFrame.Variable {\n            return FONT_FACE\n        }\n\n        override fun hjust(): DataFrame.Variable {\n            return HJUST\n        }\n\n        override fun vjust(): DataFrame.Variable {\n            return VJUST\n        }\n\n        override fun angle(): DataFrame.Variable {\n            return ANGLE\n        }\n\n        override fun symX(): DataFrame.Variable {\n            return SYM_X\n        }\n\n        override fun symY(): DataFrame.Variable {\n            return SYM_Y\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass ABLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n            .createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n        val boundaries = Iterables.toList(viewPort.parts)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.intercept()\n            val slope = p.slope()\n            if (SeriesUtil.allFinite(intercept, slope)) {\n                val p1 = DoubleVector(viewPort.left, intercept!! + viewPort.left * slope!!)\n                val p2 = DoubleVector(viewPort.right, p1.y + viewPort.dimension.x * slope)\n                val s = DoubleSegment(p1, p2)\n\n                val lineEnds = HashSet<DoubleVector>(2)\n                for (boundary in boundaries) {\n                    val intersection = boundary.intersection(s)\n                    if (intersection != null) {\n                        lineEnds.add(intersection)\n                        if (lineEnds.size == 2) {\n                            break\n                        }\n                    }\n                }\n\n                if (lineEnds.size == 2) {\n                    val it = lineEnds.iterator()\n                    val line = helper.createLine(it.next(), it.next(), p)\n                    lines.add(line)\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromFill\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nopen class AreaGeom : GeomBase() {\n\n    protected fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.ordered_X(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n\n        val helper = LinesHelper(pos, coord, ctx)\n        val paths = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_Y, GeomUtil.TO_LOCATION_X_ZERO)\n        paths.reverse()\n        appendNodes(paths, root)\n\n        //if you want to retain the side edges of area: comment out the following codes,\n        // and switch decorate method in LinesHelper.createbands\n        helper.setAlphaEnabled(false)\n        val lines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_Y)\n        appendNodes(lines, root)\n\n        buildHints(aesthetics, pos, coord, ctx)\n    }\n\n    private fun buildHints(aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val dataPoints = dataPoints(aesthetics).filter { p ->\n            val x = p.x()\n            val y = p.y()\n            SeriesUtil.allFinite(x, y) && coord.isPointInLimits(DoubleVector(x!!,y!!), isClient = false)\n        }\n        val multiPointDataList = MultiPointDataConstructor.createMultiPointDataByGroup(\n            dataPoints,\n            singlePointAppender { p -> toClient(geomHelper, p) },\n            reducer(0.999, false)\n        )\n\n        val targetCollector = getGeomTargetCollector(ctx)\n        for (multiPointData in multiPointDataList) {\n            targetCollector.addPath(\n                multiPointData.points,\n                multiPointData.localToGlobalIndex,\n                setupTooltipParams(multiPointData.aes)\n            )\n        }\n    }\n\n    protected open fun setupTooltipParams(aes: DataPointAesthetics): TooltipParams {\n        return params().setColor(fromFill(aes))\n    }\n\n    private fun toClient(geomHelper: GeomHelper, p: DataPointAesthetics): DoubleVector? {\n        val coord = GeomUtil.TO_LOCATION_X_Y(p)\n        return if (coord != null) {\n            geomHelper.toClient(coord, p)\n        } else {\n            null\n        }\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nopen class BarGeom : GeomBase() {\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val rectangles = helper.createRectangles(\n            rectangleByDataPoint(\n                ctx\n            )\n        )\n        rectangles.reverse()\n        rectangles.forEach { root.add(it) }\n\n//        RectTargetCollectorHelper(\n//            helper,\n//            rectangleByDataPoint(ctx),\n//            { HintColorUtil.fromFill(it) })\n//            .collectTo(ctx.targetCollector)\n        BarTooltipHelper.collectRectangleTargets(\n            emptyList(),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx),\n            { HintColorUtil.fromFill(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                val x = p.x()\n                val y = p.y()\n                val w = p.width()\n                if (!SeriesUtil.allFinite(x, y, w))\n                    null\n                else\n                    GeomUtil.rectangleByDataPoint(p, ctx)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Bin2dGeom : TileGeom() {\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.geom.util.*\nimport jetbrains.datalore.plot.base.interact.NullGeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass BoxplotGeom : GeomBase() {\n\n    var fattenMidline: Double = 1.0\n\n    var outlierColor: Color? = null\n    var outlierFill: Color? = null\n    var outlierShape: PointShape? = null\n    var outlierSize: Double? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildBoxes(\n            root, aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx)\n        )\n        buildLines(root, aesthetics, pos, coord, ctx)\n        buildOutliers(root, aesthetics, pos, coord, ctx)\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.UPPER, Aes.MIDDLE, Aes.LOWER, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    private fun buildLines(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildMidlines(root, aesthetics, pos, coord, ctx, fattenMidline)\n\n        val helper = GeomHelper(pos, coord, ctx)\n        val elementHelper = helper.createSvgElementHelper()\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X)) {\n            val x = p.x()!!\n            val lines = ArrayList<SvgLineElement>()\n\n            // lower whisker\n            if (p.defined(Aes.LOWER) && p.defined(Aes.YMIN)) {\n                val hinge = p.lower()!!\n                val fence = p.ymin()!!\n                // whisker line\n                lines.add(\n                    elementHelper.createLine(\n                        DoubleVector(x, hinge),\n                        DoubleVector(x, fence),\n                        p\n                    )\n                )\n                // fence line\n                /*\n        lines.add(elementHelper.createLine(\n            new DoubleVector(x - halfFenceWidth, fence),\n            new DoubleVector(x + halfFenceWidth, fence),\n            p));\n        */\n            }\n\n            // upper whisker\n            if (p.defined(Aes.UPPER) && p.defined(Aes.YMAX)) {\n                val hinge = p.upper()!!\n                val fence = p.ymax()!!\n                // whisker line\n                lines.add(\n                    elementHelper.createLine(\n                        DoubleVector(x, hinge),\n                        DoubleVector(x, fence),\n                        p\n                    )\n                )\n                // fence line\n                /*\n        lines.add(elementHelper.createLine(\n            new DoubleVector(x - halfFenceWidth, fence),\n            new DoubleVector(x + halfFenceWidth, fence),\n            p));\n        */\n\n                lines.forEach { root.add(it) }\n            }\n        }\n    }\n\n    private fun buildOutliers(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val outlierAesthetics = getOutliersAesthetics(aesthetics)\n        PointGeom()\n            .buildIntern(root, outlierAesthetics, pos, coord, ctx.withTargetCollector(NullGeomTargetCollector()))\n    }\n\n    private fun getOutliersAesthetics(aesthetics: Aesthetics): Aesthetics {\n        return MappedAesthetics(aesthetics) { p ->\n            toOutlierDataPointAesthetics(p)\n        }\n    }\n\n    /**\n     * The geom `Aesthetics` contains both: reqular data-points and \"outlier\" data-points.\n     * Regular data-point do not yave Y defined. We use this feature to feature to\n     * detect regular data-points and ignore them.\n     */\n    private fun toOutlierDataPointAesthetics(p: DataPointAesthetics): DataPointAesthetics {\n        if (!p.defined(Aes.Y)) {\n            // not an \"outlier\" data-point\n            return p\n        }\n\n        return object : DataPointAestheticsDelegate(p) {\n            override operator fun <T> get(aes: Aes<T>): T? = getIntern(aes)\n\n            override fun color(): Color? = getIntern(Aes.COLOR)\n            override fun fill(): Color? = getIntern(Aes.FILL)\n            override fun shape(): PointShape? = getIntern(Aes.SHAPE)\n            override fun size(): Double? = getIntern(Aes.SIZE)\n\n            private fun <T> getIntern(aes: Aes<T>): T? {\n                val value: Any? = when (aes) {\n                    Aes.COLOR -> outlierColor ?: super.color()\n                    Aes.FILL -> outlierFill ?: super.fill()\n                    Aes.SHAPE -> outlierShape ?: super.shape()\n                    Aes.SIZE -> outlierSize ?: OUTLIER_DEF_SIZE  // 'size' of 'super' is line thickness on box-plot\n                    else -> super.get(aes)\n                }\n                @Suppress(\"UNCHECKED_CAST\")\n                return value as T?\n            }\n        }\n    }\n\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private val LEGEND_FACTORY = CrossBarHelper.legendFactory(true)\n        private val OUTLIER_DEF_SIZE = AestheticsDefaults.point().defaultValue(Aes.SIZE)\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.LOWER) &&\n                    p.defined(Aes.UPPER) &&\n                    p.defined(Aes.WIDTH)\n                ) {\n                    val x = p.x()!!\n                    val lower = p.lower()!!\n                    val upper = p.upper()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, lower)\n                    val dimensions = DoubleVector(width, upper - lower)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nopen class ContourGeom : PathGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = PathGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PathGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nopen class ContourfGeom : PolygonGeom() {\n    companion object {\n\n//        val RENDERS = PolygonGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PolygonGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.CrossBarHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass CrossBarGeom : GeomBase() {\n    var fattenMidline: Double = 2.5\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        CrossBarHelper.buildBoxes(\n            root, aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx, false)\n        )\n        CrossBarHelper.buildMidlines(root, aesthetics, pos, coord, ctx, fattenMidline)\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(ctx, true),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private val LEGEND_FACTORY = CrossBarHelper.legendFactory(false)\n\n        private fun rectangleByDataPoint(\n            ctx: GeomContext,\n            isHintRect: Boolean\n        ): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (!isHintRect &&\n                    p.defined(Aes.X) &&\n                    p.defined(Aes.YMIN) &&\n                    p.defined(Aes.YMAX) &&\n                    p.defined(Aes.WIDTH)\n                ) {\n                    val x = p.x()!!\n                    val ymin = p.ymin()!!\n                    val ymax = p.ymax()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, ymin)\n                    val dimensions = DoubleVector(width, ymax - ymin)\n                    DoubleRectangle(origin, dimensions)\n                } else if (isHintRect &&\n                    p.defined(Aes.X) &&\n                    p.defined(Aes.MIDDLE)\n                ) {\n                    val x = p.x()!!\n                    val middle = p.middle()!!\n                    val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n                    val origin = DoubleVector(x - width / 2, middle)\n                    val dimensions = DoubleVector(width, 0.0)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Density2dGeom : ContourGeom() {\n    companion object {\n//        val RENDERS = ContourGeom.RENDERS\n\n        val HANDLES_GROUPS = ContourGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass Density2dfGeom : ContourfGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = ContourfGeom.RENDERS\n\n        val HANDLES_GROUPS = ContourfGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColor\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\n\nclass DensityGeom : AreaGeom() {\n\n    override fun setupTooltipParams(aes: DataPointAesthetics): TooltipParams {\n        return params().setColor(fromColor(aes))\n    }\n\n    companion object {\n//        val RENDERS: List<Aes<*>> = AreaGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            AreaGeom.HANDLES_GROUPS\n    }\n\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColor\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.HORIZONTAL_TOOLTIP\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass ErrorBarGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = MyLegendKeyElementFactory()\n\n    private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = LinesHelper(pos, coord, ctx)\n        val dataPoints = dataPoints(aesthetics)\n        val geomHelper = GeomHelper(pos, coord, ctx)\n\n        for (p in dataPoints) {\n            val x = p.x()\n            val ymin = p.ymin()\n            val ymax = p.ymax()\n            if (!SeriesUtil.allFinite(x, ymin, ymax)) {\n                continue\n            }\n            var width = p.width()!!\n            width *= ctx.getResolution(Aes.X)\n            val height = ymax!! - ymin!!\n\n            val r = DoubleRectangle(x!! - width / 2, ymin, width, height)\n\n            val g = errorBarShape(\n                helper.toClient(\n                    r,\n                    p\n                ), p\n            )\n            root.add(g)\n\n            buildHints(\n                DoubleRectangle(r.left, r.center.y, r.width, 0.0),\n                p,\n                ctx,\n                geomHelper\n            )\n        }\n    }\n\n    private fun buildHints(rect: DoubleRectangle, p: DataPointAesthetics, ctx: GeomContext, geomHelper: GeomHelper) {\n        val clientRect = geomHelper.toClient(rect, p)\n\n        val hint = HintConfigFactory()\n            .defaultObjectRadius(clientRect.width / 2.0)\n            .defaultX(p.x()!!)\n            .defaultKind(HORIZONTAL_TOOLTIP)\n\n        val hints = HintsCollection(p, geomHelper)\n            .addHint(hint.create(Aes.YMAX))\n            .addHint(hint.create(Aes.YMIN))\n            .hints\n\n        ctx.targetCollector.addRectangle(\n            p.index(), clientRect,\n            params()\n                .setTipLayoutHints(hints)\n                .setColor(fromColor(p))\n        )\n    }\n\n    private class MyLegendKeyElementFactory :\n        LegendKeyElementFactory {\n\n        override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n            val strokeWidth = AesScaling.strokeWidth(p)\n\n            val width = p.width()!! * (size.x - strokeWidth)\n            val height = size.y - strokeWidth\n            val x = (size.x - width) / 2\n            val y = strokeWidth / 2\n            return errorBarShape(\n                DoubleRectangle(\n                    x,\n                    y,\n                    width,\n                    height\n                ), p\n            )\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun errorBarShape(r: DoubleRectangle, p: DataPointAesthetics): SvgGElement {\n            val left = r.left\n            val top = r.top\n            val right = r.right\n            val bottom = r.bottom\n            val center = left + r.width / 2\n            val shapeLines = ArrayList<SvgLineElement>()\n            shapeLines.add(SvgLineElement(left, top, right, top))\n            shapeLines.add(SvgLineElement(left, bottom, right, bottom))\n            shapeLines.add(SvgLineElement(center, top, center, bottom))\n\n            val g = SvgGElement()\n            for (shapeLine in shapeLines) {\n                GeomHelper.decorate(shapeLine, p)\n                g.children().add(shapeLine)\n            }\n            return g\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\ninternal class FilledCircleLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val location = DoubleVector(size.x / 2, size.y / 2)\n//        val slimObject = SHAPE.create(location, p)\n        val slimObject = PointShapeSvg.create(\n            SHAPE, location, p)\n        val slimGroup = SvgSlimElements.g(1)\n        slimObject.appendTo(slimGroup)\n        return GeomBase.Companion.wrap(slimGroup)\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val shapeSize = SHAPE.size(p)\n        val strokeWidth = SHAPE.strokeWidth(p)\n        val size = shapeSize + strokeWidth + 2.0\n        return DoubleVector(size, size)\n    }\n\n    companion object {\n        private val SHAPE = NamedShape.FILLED_CIRCLE\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nclass FilledSquareLegendKeyElementFactory :\n    LegendKeyElementFactory {\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val rect = SvgRectElement(0.0, 0.0, size.x, size.y)\n        AestheticsUtil.updateFill(rect, p)\n        val g = SvgGElement()\n        g.children().add(rect)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass FreqpolyGeom : LineGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = LineGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            LineGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.GenericLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.LinePath\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimObject\n\nabstract class GeomBase : Geom {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = GenericLegendKeyElementFactory()\n\n    override fun build(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        buildIntern(root, aesthetics, pos, coord, ctx)\n    }\n\n    protected fun getGeomTargetCollector(ctx: GeomContext): GeomTargetCollector {\n        return ctx.targetCollector\n    }\n\n    protected abstract fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    )\n\n    companion object {\n        fun wrap(slimGroup: SvgSlimGroup): SvgGElement {\n            val g = SvgGElement()\n            g.isPrebuiltSubtree = true\n            g.children().add(slimGroup.asDummySvgNode())\n            return g\n        }\n\n        fun wrap(o: SvgSlimObject): SvgGElement {\n            val slimGroup = SvgSlimElements.g(1)\n            o.appendTo(slimGroup)\n            return wrap(slimGroup)\n        }\n\n        fun aesViewPort(aesthetics: Aesthetics): DoubleRectangle {\n            return rect(\n                aesthetics.overallRange(Aes.X),\n                aesthetics.overallRange(Aes.Y)\n            )\n        }\n\n        fun aesBoundingBox(aesthetics: Aesthetics): DoubleRectangle {\n            return rect(\n                aesthetics.range(Aes.X)!!,\n                aesthetics.range(Aes.Y)!!\n            )\n        }\n\n        private fun rect(rangeX: ClosedRange<Double>, rangeY: ClosedRange<Double>): DoubleRectangle {\n            return DoubleRectangle(\n                rangeX.lowerEnd, rangeY.lowerEnd,\n                SeriesUtil.span(rangeX), SeriesUtil.span(rangeY)\n            )\n        }\n\n        fun appendNodes(paths: List<LinePath>, root: SvgRoot) {\n            for (path in paths) {\n                root.add(path.rootGroup)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.legend.HLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\nclass HLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.interceptY()\n            if (SeriesUtil.isFinite(intercept)) {\n                if (viewPort.yRange().contains(intercept!!)) {\n                    val start = DoubleVector(viewPort.left, intercept)\n                    val end = DoubleVector(viewPort.right, intercept)\n                    val line = helper.createLine(start, end, p)\n                    lines.add(line)\n\n                    val h = AesScaling.strokeWidth(p)\n                    val origin = DoubleVector(start.x, intercept - h/2 - 2.0)\n                    val dimensions = DoubleVector(viewPort.dimension.x, h + 4.0)\n                    val rect = DoubleRectangle(origin, dimensions)\n                    ctx.targetCollector.addRectangle(\n                        p.index(),\n                        geomHelper.toClient(rect, p),\n                        GeomTargetCollector.TooltipParams.params()\n                            .setColor(HintColorUtil.fromColor(p)),\n                        TipLayoutHint.Kind.CURSOR_TOOLTIP\n                    )\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        val LEGEND_KEY_ELEMENT_FACTORY: LegendKeyElementFactory =\n            HLineLegendKeyElementFactory()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass HistogramGeom : BarGeom() {\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//                //Aes.WEIGHT,    // ToDo: this is actually handled by 'stat' (bin,count)\n//                Aes.WIDTH,\n//                Aes.SIZE\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.vis.svg.SvgImageElement\n\n/**\n * Creates SvgImageElement and assign 'imageUrl' value to 'href' attribute.\n */\nclass ImageGeom(private val imageUrl: String) : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        if (aesthetics.isEmpty) return\n        val p = aesthetics.dataPointAt(0)\n        val boundsAes = DoubleRectangle.span(\n                DoubleVector(p.xmin()!!, p.ymin()!!),\n                DoubleVector(p.xmax()!!, p.ymax()!!))\n\n        // translate to client coordinates\n        val helper = GeomHelper(pos, coord, ctx)\n        val boundsClient = helper.toClient(boundsAes, p)\n\n        val svgImageElement = SvgImageElement(\n            boundsClient.origin.x, boundsClient.origin.y,\n            boundsClient.dimension.x, boundsClient.dimension.y\n        )\n        svgImageElement.href().set(imageUrl)\n        root.add(svgImageElement)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.XMIN,\n//                Aes.XMAX,\n//                Aes.YMIN,\n//                Aes.YMAX\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass JitterGeom : PointGeom() {\n    companion object {\n//        val RENDERS: List<Aes<*>> = PointGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PointGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\n\nopen class LineGeom : PathGeom() {\n\n    override fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.ordered_X(super.dataPoints(aesthetics))\n    }\n\n    companion object {\n//        val RENDERS = PathGeom.RENDERS\n\n        const val HANDLES_GROUPS =\n            PathGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport kotlin.math.max\n\nclass LineRangeGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = VLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.YMIN, Aes.YMAX)) {\n            val x = p.x()!!\n            val ymin = p.ymin()!!\n            val ymax = p.ymax()!!\n\n            val start = DoubleVector(x, ymin)\n            val end = DoubleVector(x, ymax)\n            val line = helper.createLine(start, end, p)\n            root.add(line)\n        }\n\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        fun rectangleByDataPoint(): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.YMIN) &&\n                    p.defined(Aes.YMAX)\n                ) {\n                    val x = p.x()!!\n                    val ymin = p.ymin()!!\n                    val ymax = p.ymax()!!\n                    val width = max(AesScaling.strokeWidth(p), 2.0) * 2.0\n                    val height = ymax - ymin\n\n                    val origin = DoubleVector(x - width / 2, ymax - height / 2)\n                    val dimensions = DoubleVector(width, 0.0 )\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.GenericLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\n\nclass LiveMapGeom(private val myDisplayMode: DisplayMode) : Geom {\n    private lateinit var myMapProvider: LiveMapProvider\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() {\n            return when (myDisplayMode) {\n                DisplayMode.POINT -> PointLegendKeyElementFactory()\n                DisplayMode.PIE -> FilledCircleLegendKeyElementFactory()\n                else -> GenericLegendKeyElementFactory()\n            }\n        }\n\n    override fun build(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        throw IllegalStateException(\"Not applicable to live map\")\n    }\n\n    fun setLiveMapProvider(liveMapProvider: LiveMapProvider) {\n        myMapProvider = liveMapProvider\n    }\n\n    fun createCanvasFigure(bounds: DoubleRectangle): LiveMapProvider.LiveMapData {\n        return myMapProvider.createLiveMap(bounds)\n    }\n\n    companion object {\n\n        // ToDo: not static, depends on 'display mode'\n//        val RENDERS = listOf(\n//                Aes.ALPHA,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.SIZE,\n//                Aes.SHAPE,\n//                Aes.FRAME,\n//                Aes.X,\n//                Aes.Y\n//        )\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\n\ninterface LiveMapProvider {\n    fun createLiveMap(bounds: DoubleRectangle): LiveMapData\n\n    class LiveMapData(\n        val canvasFigure: SomeFig,\n        val targetLocator: GeomTargetLocator\n    )\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nclass MapGeom : PolygonGeom() {\n    companion object {\n//        val RENDERS = listOf(\n//\n//                // auto-wired to 'x' or 'long' and to 'y' or 'lat'\n//                Aes.X,\n//                Aes.Y,\n//\n//                Aes.SIZE, // path width\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinePathConstructor\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nopen class PathGeom : GeomBase() {\n\n    var animation: Any? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    protected open fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X_Y(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n\n        val dataPoints = dataPoints(aesthetics)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val linesHelper = LinesHelper(pos, coord, ctx)\n\n        val geomConstructor = LinePathConstructor(\n            targetCollector,\n            dataPoints,\n            linesHelper,\n            false\n        )\n        appendNodes(\n            geomConstructor.construct(withHints = false),\n            root\n        )\n        buildHints(aesthetics, coord, linesHelper, targetCollector)\n    }\n\n    private fun buildHints(\n        aesthetics: Aesthetics,\n        coord: CoordinateSystem,\n        linesHelper: LinesHelper,\n        targetCollector: GeomTargetCollector\n    ) {\n        val dataPoints = dataPoints(aesthetics).filter { p ->\n            val x = p.x()\n            val y = p.y()\n            SeriesUtil.allFinite(x, y) && coord.isPointInLimits(DoubleVector(x!!,y!!), isClient = false)\n        }\n\n        LinePathConstructor(\n            targetCollector,\n            dataPoints,\n            linesHelper,\n            false\n        ).buildHints()\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.get\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.LinePath\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport kotlin.math.PI\n\n/**\n * This is working code but wasn't included to ggplot.\n * Mostly exists to preserve this code.\n */\ninternal class PieGeom(private val myCenter: DoubleVector, private val myRadius: Double) : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val helper = PieHelper(pos, coord, ctx)\n        val segments = helper.createSegments(aesthetics, myCenter, myRadius)\n        appendNodes(segments, root)\n    }\n\n    private class PieHelper internal constructor(pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) : LinesHelper(pos, coord, ctx) {\n\n        internal fun createSegments(aesthetics: Aesthetics, center: DoubleVector, radius: Double): List<LinePath> {\n            val result = ArrayList<LinePath>()\n\n            //DoubleVector basis = new Point(radius, 0);  // x\n            val basis = DoubleVector(0.0, -radius)   // y\n\n            var curAngle = Double.NaN\n            for (p in dataPoints(aesthetics)) {\n                val segmentSize =\n                    shareToRad(p.y()!!)\n\n                // for better presentation: first segment lays to the right of 12 o'clock, and all\n                // segments are added counterclockwise.\n                if (curAngle.isNaN()) {\n                    curAngle = segmentSize\n                }\n\n                // we use negative angles because of screen coordinates and counterclockwise order of segments\n                val angle = -segmentSize\n\n                val builder = SvgPathDataBuilder(true)\n                builder.moveTo(center)\n                builder.lineTo(center.add(basis.rotate(curAngle)))\n                val arcTo = center.add(basis.rotate(curAngle + angle))\n                builder.ellipticalArc(radius, radius, 0.0, -angle > PI, false, arcTo)\n                builder.closePath()\n\n                curAngle += angle\n\n                val path = LinePath(builder)\n                decorate(path, p, true)\n                result.add(path)\n            }\n\n            return result\n        }\n    }\n\n    companion object {\n        val RENDERS = listOf(\n                Aes.X, // optional, can specify order of segments in pie\n                Aes.Y, // angle width of segments\n                Aes.COLOR,\n                Aes.FILL,\n                Aes.ALPHA,\n                Aes.WIDTH,\n                Aes.SIZE\n        )\n\n        const val HANDLES_GROUPS = false\n\n        private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n            val withX = GeomUtil.with_X_Y(aesthetics.dataPoints())\n            return if (Iterables.isEmpty(withX) || allEqualX(\n                    withX,\n                    get(withX, 0).x()\n                )\n            ) {\n                GeomUtil.ordered_Y(GeomUtil.with_Y(aesthetics.dataPoints()), true)\n            } else GeomUtil.ordered_X(withX)\n        }\n\n        private fun allEqualX(hasX: Iterable<DataPointAesthetics>, `val`: Double?): Boolean {\n            for (p in hasX) {\n                if (p.x() != `val`) {\n                    return false\n                }\n            }\n            return true\n        }\n\n        private fun shareToRad(share: Double): Double {\n            // don't allow sum to be more than 99.99 % of full circle (otherwise arc will disappear)\n            return 0.9999 * 2.0 * PI * share\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil.fromColorValue\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\nopen class PointGeom : GeomBase() {\n\n    var animation: Any? = null\n    var sizeUnit: String? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = PointLegendKeyElementFactory()\n\n    public override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val targetCollector = getGeomTargetCollector(ctx)\n\n        val count = aesthetics.dataPointCount()\n        val slimGroup = SvgSlimElements.g(count)\n        val sizeUnitRatio = getSizeUnitRatio(ctx)\n\n        for (i in 0 until count) {\n            val p = aesthetics.dataPointAt(i)\n            val x = p.x()\n            val y = p.y()\n\n            if (SeriesUtil.allFinite(x, y)) {\n                val location = helper.toClient(DoubleVector(x!!, y!!), p)\n\n                val shape = p.shape()!!\n\n                targetCollector.addPoint(\n                    i, location, sizeUnitRatio * shape.size(p) / 2,\n                    tooltipParams(p)\n                )\n                val o = PointShapeSvg.create(shape, location, p, sizeUnitRatio)\n                o.appendTo(slimGroup)\n            }\n        }\n        root.add(wrap(slimGroup))\n    }\n\n    private fun getSizeUnitRatio(ctx: GeomContext): Double {\n        return if (sizeUnit != null) {\n            val unitRes = ctx.getUnitResolution(GeomHelper.getSizeUnitAes(sizeUnit!!))\n            // TODO: Need refactoring: It's better to use NamedShape.FILLED_CIRCLE.size(1.0)\n            // but Shape.size() can't be used because it takes DataPointAesthetics as param\n            unitRes / AesScaling.UNIT_SHAPE_SIZE\n        } else {\n            1.0\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        fun tooltipParams(p: DataPointAesthetics): TooltipParams {\n            var color = Color.TRANSPARENT\n            if (p.shape() == TinyPointShape) {\n                color = p.color()!!\n            } else if (p.shape() is NamedShape) {\n                val shape = p.shape() as NamedShape\n                color = AestheticsUtil.fill(shape.isFilled, shape.isSolid, p)\n            }\n\n            return params().setColor(fromColorValue(color, p.alpha()!!))\n        }\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninternal class PointLegendKeyElementFactory(private val fatten: Double = 1.0) :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val location = DoubleVector(size.x / 2, size.y / 2)\n        val shape = p.shape()!!\n        val slimObject = PointShapeSvg.create(shape, location, p, fatten)\n        return GeomBase.Companion.wrap(slimObject)\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val shape = p.shape()!!\n        val shapeSize = shape.size(p) * fatten\n        val strokeWidth = shape.strokeWidth(p)\n        val size = shapeSize + strokeWidth + 2.0\n        return DoubleVector(size, size)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.legend.CompositeLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.legend.VLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.BarTooltipHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.point.PointShapeSvg\n\nclass PointRangeGeom : GeomBase() {\n    var fattenMidPoint: Double =\n        DEF_FATTEN\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = CompositeLegendKeyElementFactory(\n            VLineLegendKeyElementFactory(),\n            PointLegendKeyElementFactory(DEF_FATTEN)\n        )\n\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.Y, Aes.YMIN, Aes.YMAX)) {\n            val x = p.x()!!\n            val y = p.y()!!\n            val ymin = p.ymin()!!\n            val ymax = p.ymax()!!\n\n            // vertical line\n            val start = DoubleVector(x, ymin)\n            val end = DoubleVector(x, ymax)\n            val line = helper.createLine(start, end, p)\n            root.add(line)\n\n            // mid-point\n            val location = geomHelper.toClient(DoubleVector(x, y), p)\n            val shape = p.shape()!!\n            val o = PointShapeSvg.create(shape, location, p, fattenMidPoint)\n            root.add(wrap(o))\n//            ctx.targetCollector.addPoint(\n//                p.index(),\n//                location,\n//                shape.size(p) * fattenMidline / 2,\n//                PointGeom.tooltipParams(p)\n//            )\n        }\n\n        BarTooltipHelper.collectRectangleTargets(\n            listOf(Aes.YMAX, Aes.YMIN),\n            aesthetics, pos, coord, ctx,\n            rectangleByDataPoint(fattenMidPoint),\n            { HintColorUtil.fromColor(it) }\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        const val DEF_FATTEN = 5.0\n\n        fun rectangleByDataPoint(fatten: Double): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                if (p.defined(Aes.X) &&\n                    p.defined(Aes.Y)\n                ) {\n                    val x = p.x()!!\n                    val y = p.y()!!\n\n                    val shape = p.shape()!!\n                    val shapeSize = shape.size(p) * fatten\n                    val strokeWidth = shape.strokeWidth(p)\n                    val width = shapeSize + strokeWidth\n\n                    val origin = DoubleVector(x - width / 2, y)\n                    val dimensions = DoubleVector(width, 0.0)\n                    DoubleRectangle(origin, dimensions)\n                } else {\n                    null\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.LinePathConstructor\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nopen class PolygonGeom : GeomBase() {\n\n    protected fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        return GeomUtil.with_X_Y(aesthetics.dataPoints())\n    }\n\n    override fun buildIntern(\n        root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val dataPoints = dataPoints(aesthetics)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val linesHelper = LinesHelper(pos, coord, ctx)\n\n        val geomConstructor =\n            LinePathConstructor(\n                targetCollector,\n                dataPoints,\n                linesHelper,\n                true\n            )\n        appendNodes(\n            geomConstructor.construct(withHints = true),\n            root\n        )\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.with_X_Y\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgImageElementEx\nimport jetbrains.datalore.vis.svg.SvgImageElementEx.Bitmap\nimport jetbrains.datalore.vis.svg.SvgUtils\nimport kotlin.math.abs\nimport kotlin.math.min\nimport kotlin.math.round\n\nclass RasterGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = FilledSquareLegendKeyElementFactory()\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val iter = with_X_Y(aesthetics.dataPoints()).iterator()\n        if (!iter.hasNext()) {\n            return\n        }\n        val randomP = iter.next()\n        val helper = GeomHelper(pos, coord, ctx)\n\n        // Find size of image (row x col)\n        val boundsXY =\n            aesBoundingBox(aesthetics)\n        val stepX = ctx.getResolution(Aes.X)\n        val stepY = ctx.getResolution(Aes.Y)\n        require(stepX > SeriesUtil.TINY) { \"x-step is too small: $stepX\" }\n        require(stepY > SeriesUtil.TINY) { \"y-step is too small: $stepY\" }\n        val width = (round(boundsXY.dimension.x / stepX) + 1)\n        val height = (round(boundsXY.dimension.y / stepY) + 1)\n\n        if (width * height > 5000000) {\n            val center = boundsXY.center\n            val lines =\n                arrayOf(\"Raster image size\", \"[$width X $height]\", \"exceeds capability\", \"of\", \"your imaging device\")\n            val fontSize = 12.0\n            val lineHeight = fontSize + 4\n            var y = center.y + lineHeight * lines.size / 2.0\n            for (line in lines) {\n                val label = TextLabel(line)\n                label.textColor().set(Color.DARK_MAGENTA)\n                label.textOpacity().set(0.5)\n                label.setFontSize(fontSize)\n                label.setFontWeight(\"bold\")\n                label.setHorizontalAnchor(HorizontalAnchor.MIDDLE)\n                label.setVerticalAnchor(VerticalAnchor.CENTER)\n                val loc = helper.toClient(center.x, y, randomP)\n                label.moveTo(loc)\n                root.add(label.rootGroup)\n                y -= lineHeight\n            }\n\n            return\n        }\n\n        val cols = round(width).toInt()\n        val rows = round(height).toInt()\n\n        // translate to client coordinates\n        // expand bounds by 1/2 step before the translation to adjust for the size of 'image pixel'\n        val halfStep = DoubleVector(stepX * 0.5, stepY * 0.5)\n        val corner0 = helper.toClient(boundsXY.origin.subtract(halfStep), randomP)\n        val corner2 = helper.toClient(boundsXY.origin.add(boundsXY.dimension).add(halfStep), randomP)\n        val invertedX = corner2.x < corner0.x\n        val invertedY = corner2.y < corner0.y\n\n        // Fill image data array with RGB values\n        val x0 = boundsXY.origin.x\n        val y0 = boundsXY.origin.y\n\n        val argbValues = IntArray(cols * rows)\n        for (p in with_X_Y(aesthetics.dataPoints())) {\n            val x = p.x()\n            val y = p.y()\n            val alpha = p.alpha()\n            val color = p.fill()\n\n            var col = round((x!! - x0) / stepX).toInt()\n            var row = round((y!! - y0) / stepY).toInt()\n\n            if (invertedX) {\n                col = cols - (col + 1)\n            }\n\n            if (invertedY) {\n                row = rows - (row + 1)\n            }\n\n            argbValues[row * cols + col] = SvgUtils.toARGB(color!!, alpha!!)\n        }\n\n        val bitmap = Bitmap(cols, rows, argbValues)\n        val svgImageElement = SvgImageElementEx(\n            min(corner0.x, corner2.x), min(corner0.y, corner2.y),\n            abs(corner0.x - corner2.x), abs(corner0.y - corner2.y),\n            bitmap\n        )\n        root.add(svgImageElement)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.Y,\n//                Aes.WIDTH, // not rendered but required for correct x aes range computation\n//                Aes.HEIGHT, // -- the same --\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = false\n    }\n}// ToDo: hjust, vjust [0..1] def .5\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectTargetCollectorHelper\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.CURSOR_TOOLTIP\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass RectGeom : GeomBase() {\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        helper.createRectangles(Companion::rectangleByDataPoint).forEach(root::add)\n        RectTargetCollectorHelper(\n            rectanglesHelper = helper,\n            rectangleByDataPoint = Companion::rectangleByDataPoint,\n            fillByDataPoint = HintColorUtil::fromFill,\n            tooltipKind = CURSOR_TOOLTIP\n        ).collectTo(ctx.targetCollector)\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.XMIN,\n//                Aes.XMAX,\n//                Aes.YMIN,\n//                Aes.YMAX,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA,\n//        )\n        //rectangle groups are used in geom_livemap\n        const val HANDLES_GROUPS = true\n\n        private fun rectangleByDataPoint(p: DataPointAesthetics): DoubleRectangle? {\n            val xmin = p.xmin()\n            val xmax = p.xmax()\n            val ymin = p.ymin()\n            val ymax = p.ymax()\n            return if (SeriesUtil.allFinite(xmin, xmax, ymin, ymax)) {\n                DoubleRectangle.span(DoubleVector(xmin!!, ymin!!), DoubleVector(xmax!!, ymax!!))\n            }\n            else {\n                null\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass RibbonGeom : GeomBase() {\n\n    private fun dataPoints(aesthetics: Aesthetics): Iterable<DataPointAesthetics> {\n        val data = GeomUtil.withDefined(aesthetics.dataPoints(), Aes.X, Aes.YMIN, Aes.YMAX)\n        return GeomUtil.ordered_X(data)\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n        val helper = LinesHelper(pos, coord, ctx)\n        val paths = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_YMAX, GeomUtil.TO_LOCATION_X_YMIN)\n        appendNodes(paths, root)\n\n        //if you want to retain the side edges of ribbon: comment out the following codes, and switch decorate method in LinesHelper.createbands\n        helper.setAlphaEnabled(false)\n        val lines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_YMAX)\n        lines.addAll(helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_YMIN))\n        appendNodes(lines, root)\n\n        buildHints(aesthetics, pos, coord, ctx)\n    }\n\n    private fun buildHints(aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val targetCollector = ctx.targetCollector\n        val helper = GeomHelper(pos, coord, ctx)\n        for (p in aesthetics.dataPoints()) {\n            addTarget(p, targetCollector, GeomUtil.TO_LOCATION_X_YMAX, helper)\n        }\n    }\n\n    private fun addTarget(\n        p: DataPointAesthetics,\n        collector: GeomTargetCollector,\n        toLocation: (DataPointAesthetics) -> DoubleVector?,\n        helper: GeomHelper\n    ) {\n        val coord = toLocation(p)\n        if (coord != null) {\n            val hint = HintsCollection.HintConfigFactory()\n                .defaultObjectRadius(0.0)\n                .defaultX(p.x()!!)\n                .defaultKind(TipLayoutHint.Kind.HORIZONTAL_TOOLTIP)\n                .defaultColor(\n                    p.fill()!!,\n                    alpha = null\n                )\n\n            val hintsCollection = HintsCollection(p, helper)\n                .addHint(hint.create(Aes.YMAX))\n                .addHint(hint.create(Aes.YMIN))\n\n            collector.addPoint(\n                p.index(),\n                helper.toClient(coord, p),\n                0.0,\n                params().setTipLayoutHints(hintsCollection.hints)\n            )\n        }\n    }\n\n    companion object {\n//        val RENDERS = listOf(\n//                Aes.X,\n//                Aes.YMIN,\n//                Aes.YMAX,\n//                Aes.SIZE,\n//                Aes.LINETYPE,\n//                Aes.COLOR,\n//                Aes.FILL,\n//                Aes.ALPHA\n//        )\n\n        const val HANDLES_GROUPS = true\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.ArrowSpec\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper.Companion.decorate\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.PI\nimport kotlin.math.atan2\n\nclass SegmentGeom : GeomBase() {\n\n    var arrowSpec: ArrowSpec? = null\n    var animation: Any? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val targetCollector = getGeomTargetCollector(ctx)\n        val helper = GeomHelper(pos, coord, ctx)\n            .createSvgElementHelper()\n\n        for (p in aesthetics.dataPoints()) {\n            if (SeriesUtil.allFinite(p.x(), p.y(), p.xend(), p.yend())) {\n                val start = DoubleVector(p.x()!!, p.y()!!)\n                val end = DoubleVector(p.xend()!!, p.yend()!!)\n                val line = helper.createLine(start, end, p)\n                root.add(line)\n\n                targetCollector.addPath(\n                    listOf(coord.toClient(start), coord.toClient(end)),\n                    { p.index() },\n                    GeomTargetCollector.TooltipParams.params()\n                        .setColor(HintColorUtil.fromColor(p))\n                )\n\n                if (arrowSpec != null) {\n                    val clientX1 = line.x1().get()!!\n                    val clientY1 = line.y1().get()!!\n                    val clientX2 = line.x2().get()!!\n                    val clientY2 = line.y2().get()!!\n\n                    val abscissa = clientX2 - clientX1\n                    val ordinate = clientY2 - clientY1\n                    if (abscissa != 0.0 || ordinate != 0.0) {\n                        // Compute the angle that the vector defined by this segment makes with the\n                        // X-axis (radians)\n                        val polarAngle = atan2(ordinate, abscissa)\n\n                        val arrowAes = arrowSpec!!.toArrowAes(p)\n                        if (arrowSpec!!.isOnLastEnd) {\n                            val arrow = arrowSpec!!.createElement(polarAngle, clientX2, clientY2)\n                            decorate(arrow, arrowAes)\n                            root.add(arrow)\n                        }\n                        if (arrowSpec!!.isOnFirstEnd) {\n                            val arrow = arrowSpec!!.createElement(polarAngle + PI, clientX1, clientY1)\n                            decorate(arrow, arrowAes)\n                            root.add(arrow)\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.ordered_X\nimport jetbrains.datalore.plot.base.geom.util.GeomUtil.with_X_Y\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.HORIZONTAL_TOOLTIP\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass SmoothGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = HLineGeom.LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val dataPoints = ordered_X(with_X_Y(aesthetics.dataPoints()))\n        val helper = LinesHelper(pos, coord, ctx)\n\n        // Regression line\n        helper.setAlphaEnabled(false)\n        val regressionLines = helper.createLines(dataPoints, GeomUtil.TO_LOCATION_X_Y)\n        appendNodes(regressionLines, root)\n\n        // Confidence interval\n        helper.setAlphaFilter(PROPORTION)\n        helper.setWidthFilter(ZERO)\n        val bands = helper.createBands(dataPoints, GeomUtil.TO_LOCATION_X_YMAX, GeomUtil.TO_LOCATION_X_YMIN)\n        appendNodes(bands, root)\n\n        buildHints(dataPoints, pos, coord, ctx)\n    }\n\n    private fun buildHints(\n        dataPoints: Iterable<DataPointAesthetics>,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n\n        for (p in dataPoints) {\n            val xCoord = p.x()!!\n            val objectRadius = 0.0\n\n            val hint = HintConfigFactory()\n                .defaultObjectRadius(objectRadius)\n                .defaultX(xCoord)\n                .defaultKind(HORIZONTAL_TOOLTIP)\n                .defaultColor(\n                    p.fill()!!,\n                    PROPORTION(p.alpha())\n                )\n\n            val hintsCollection = HintsCollection(p, helper)\n                .addHint(hint.create(Aes.YMAX))\n                .addHint(hint.create(Aes.YMIN))\n                .addHint(hint.create(Aes.Y).color(p.color()!!))\n\n            val clientCoord = helper.toClient(p.x(), p.y(), p)\n            ctx.targetCollector.addPoint(\n                p.index(), clientCoord, objectRadius,\n                params()\n                    .setTipLayoutHints(hintsCollection.hints)\n            )\n        }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = true\n\n        private val PROPORTION = { v: Double? -> if (v == null) null else v / 10 }\n        private val ZERO = { _: Double? -> 0.0 }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.geom.util.LinesHelper\nimport jetbrains.datalore.plot.base.render.SvgRoot\n\nclass StepGeom : LineGeom() {\n    private var myDirection = DEF_DIRECTION\n\n    fun setDirection(dir: String) {\n        myDirection = Direction.toDirection(dir)\n    }\n\n    override fun buildIntern(root: SvgRoot, aesthetics: Aesthetics, pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) {\n        val dataPoints = dataPoints(aesthetics)\n        val helper = LinesHelper(pos, coord, ctx)\n        val pathInfos = helper.createSteps(dataPoints, myDirection)\n        for (pathInfo in pathInfos) {\n            root.add(pathInfo.path.rootGroup)\n        }\n    }\n\n    enum class Direction {\n        HV, VH;\n\n\n        companion object {\n\n            fun toDirection(str: String): Direction {\n                return when (str) {\n                    \"hv\", \"HV\" -> HV\n                    \"vh\", \"VH\" -> VH\n                    else -> throw IllegalArgumentException(\"Direction $str is not allowed, only accept 'hv' or 'vh'\")\n                }\n            }\n        }\n    }\n\n    companion object {\n        // default\n        val DEF_DIRECTION = Direction.HV\n//        val RENDERS = LineGeom.RENDERS\n        const  val HANDLES_GROUPS =\n    LineGeom.HANDLES_GROUPS\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass TextGeom : GeomBase() {\n    var formatter: StringFormat? = null\n    var naValue = DEF_NA_VALUE\n    var sizeUnit: String? = null\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = TextLegendKeyElementFactory()\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val targetCollector = getGeomTargetCollector(ctx)\n        val sizeUnitRatio = getSizeUnitRatio(ctx)\n        for (p in aesthetics.dataPoints()) {\n            val x = p.x()\n            val y = p.y()\n            val text = toString(p.label())\n            if (SeriesUtil.allFinite(x, y) && !Strings.isNullOrEmpty(text)) {\n                val label = TextLabel(text)\n                GeomHelper.decorate(label, p, sizeUnitRatio)\n\n                val loc = helper.toClient(x, y, p)\n                label.moveTo(loc)\n                root.add(label.rootGroup)\n\n                // The geom_text tooltip is similar to the geom_tile:\n                // it looks better when the text is on a tile in corr_plot (but the color will be different from the geom_tile tooltip)\n                targetCollector.addPoint(\n                    p.index(),\n                    loc,\n                    sizeUnitRatio * AesScaling.textSize(p) / 2,\n                    GeomTargetCollector.TooltipParams.params()\n                        .setColor(HintColorUtil.fromColor(p)),\n                    TipLayoutHint.Kind.CURSOR_TOOLTIP\n                )\n            }\n        }\n    }\n\n    // This implementation is oversimplified.\n    // Current implementation works for label_format ='.2f'\n    // and values between -1.0 and 1.0.\n    private fun getSizeUnitRatio(ctx: GeomContext): Double {\n        return if ( sizeUnit != null)  {\n            val textWidth = 6.0\n            val unitRes = ctx.getUnitResolution(GeomHelper.getSizeUnitAes(sizeUnit!!))\n            unitRes / textWidth\n        } else {\n            1.0\n        }\n    }\n\n    private fun toString(label: Any?): String {\n        return when {\n            label == null -> naValue\n            formatter != null -> formatter!!.format(label)\n            else -> label.toString()\n        }\n    }\n\n    companion object {\n        const val DEF_NA_VALUE = \"n/a\"\n        const val HANDLES_GROUPS = false\n    }\n}\n\n// How 'just' and 'angle' works together\n// https://stackoverflow.com/questions/7263849/what-do-hjust-and-vjust-do-when-making-a-plot-using-ggplot\n// ToDo: lineheight (aes)\n// ToDo: nudge_x, nudge_y\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninternal class TextLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val label = TextLabel(\"a\")\n        GeomHelper.decorate(label, p)\n        label.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n        label.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n        label.moveTo(size.x / 2, size.y / 2)\n        val g = SvgGElement()\n        g.children().add(label.rootGroup)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(4.0, strokeWidth + 4)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.geom.util.RectTargetCollectorHelper\nimport jetbrains.datalore.plot.base.geom.util.RectanglesHelper\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * geom_tile uses the center of the tile and its size (x, y, width, height).\n */\nopen class TileGeom : GeomBase() {\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val slimGroup = helper.createSlimRectangles(\n            rectangleByDataPoint(ctx)\n        )\n        root.add(wrap(slimGroup))\n\n        RectTargetCollectorHelper(\n            helper,\n            rectangleByDataPoint(ctx),\n            { p: DataPointAesthetics ->\n                HintColorUtil.fromFill(\n                    p\n                )\n            },\n            TipLayoutHint.Kind.CURSOR_TOOLTIP\n        )\n            .collectTo(ctx.targetCollector)\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n\n        private fun rectangleByDataPoint(ctx: GeomContext): (DataPointAesthetics) -> DoubleRectangle? {\n            return { p ->\n                val x = p.x()\n                val y = p.y()\n                val w = p.width()\n                val h = p.height()\n\n                var rect: DoubleRectangle? = null\n                if (SeriesUtil.allFinite(x, y, w, h)) {\n                    val width = w!! * ctx.getResolution(Aes.X)\n                    val height = h!! * ctx.getResolution(Aes.Y)\n\n                    val origin = DoubleVector(x!! - width / 2, y!! - height / 2)\n                    val dimensions = DoubleVector(width, height)\n                    rect = DoubleRectangle(origin, dimensions)\n                }\n                rect\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.legend.VLineLegendKeyElementFactory\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.geom.util.HintColorUtil\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport kotlin.math.max\n\nclass VLineGeom : GeomBase() {\n\n    override val legendKeyElementFactory: LegendKeyElementFactory\n        get() = LEGEND_KEY_ELEMENT_FACTORY\n\n    override fun buildIntern(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext\n    ) {\n        val geomHelper = GeomHelper(pos, coord, ctx)\n        val helper = geomHelper.createSvgElementHelper()\n        helper.setStrokeAlphaEnabled(true)\n\n        val viewPort = aesViewPort(aesthetics)\n\n        val lines = ArrayList<SvgLineElement>()\n        for (p in aesthetics.dataPoints()) {\n            val intercept = p.interceptX()\n            if (SeriesUtil.isFinite(intercept)) {\n                if (viewPort.xRange().contains(intercept!!)) {\n                    val start = DoubleVector(intercept, viewPort.top)\n                    val end = DoubleVector(intercept, viewPort.bottom)\n                    val line = helper.createLine(start, end, p)\n                    lines.add(line)\n\n                    val width = max(AesScaling.strokeWidth(p), 2.0) * 2.0\n                    val origin = DoubleVector(intercept - width / 2, end.y)\n                    val dimensions = DoubleVector(width, 0.0)\n                    val rect = DoubleRectangle(origin, dimensions)\n                    ctx.targetCollector.addRectangle(\n                        p.index(),\n                        geomHelper.toClient(rect, p),\n                        GeomTargetCollector.TooltipParams.params()\n                            .setColor(HintColorUtil.fromColor(p))\n                    )\n                }\n            }\n        }\n\n        lines.forEach { root.add(it) }\n    }\n\n    companion object {\n        const val HANDLES_GROUPS = false\n        val LEGEND_KEY_ELEMENT_FACTORY: LegendKeyElementFactory =\n            VLineLegendKeyElementFactory()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport kotlin.math.max\n\nclass CompositeLegendKeyElementFactory(vararg factories: LegendKeyElementFactory) :\n    LegendKeyElementFactory {\n    private val factories = factories\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n        for (factory in factories) {\n            g.children().add(factory.createKeyElement(p, size))\n        }\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n//        var minWidth = 0.0\n//        var minHeight = 0.0\n//        for (factory in factories) {\n//            val keySize = factory.minimumKeySize(p)\n//            minWidth = max(minWidth, keySize.x)\n//            minHeight = max(minHeight, keySize.y)\n//        }\n//        return DoubleVector(minWidth, minHeight)\n        return super.minimumKeySize(p)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nclass GenericLegendKeyElementFactory : LegendKeyElementFactory {\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        // background rect (to show fill)\n        val rect = SvgRectElement(0.0, 0.0, size.x, size.y)\n        AestheticsUtil.updateFill(rect, p)\n\n        // slash-line (to show stroke)\n        val line = SvgLineElement(0.0, size.y, size.x, 0.0)\n        GeomHelper.decorate(line, p)\n\n        val g = SvgGElement()\n        g.children().add(rect)\n        g.children().add(line)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\ninternal class HLineLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val line = SvgLineElement(0.0, size.y / 2, size.x, size.y / 2)\n        GeomHelper.decorate(line, p)\n        val g = SvgGElement()\n        g.children().add(line)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(4.0, strokeWidth + 4)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.legend\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.geom.util.GeomHelper\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\n\ninternal class VLineLegendKeyElementFactory :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val line = SvgLineElement(size.x / 2, 0.0, size.x / 2, size.y)\n        GeomHelper.decorate(line, p)\n        val g = SvgGElement()\n        g.children().add(line)\n        return g\n    }\n\n    override fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        return DoubleVector(strokeWidth + 4, 4.0)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport jetbrains.datalore.vis.svg.SvgPathElement\nimport kotlin.math.cos\nimport kotlin.math.sin\n\nclass ArrowSpec\n/**\n * @param angle  The angle of the arrow head in radians (smaller numbers produce narrower, pointier arrows).\n * Essentially describes the width of the arrow head.\n * @param length The length of the arrow head (px).\n */\n(val angle: Double, val length: Double, val end: End, val type: Type) {\n\n    val isOnFirstEnd: Boolean\n        get() = end == End.FIRST || end == End.BOTH\n\n    val isOnLastEnd: Boolean\n        get() = end == End.LAST || end == End.BOTH\n\n    /**\n     * @param polarAngle Angle between X-axis and the arrowed vector.\n     */\n    fun createElement(polarAngle: Double, x: Double, y: Double): SvgPathElement {\n        val xs = doubleArrayOf(x - length * cos(polarAngle - angle), x, x - length * cos(polarAngle + angle))\n        val ys = doubleArrayOf(y - length * sin(polarAngle - angle), y, y - length * sin(polarAngle + angle))\n\n        val b = SvgPathDataBuilder(true)\n                .moveTo(xs[0], ys[0])\n\n        for (i in 1..2) {\n            b.lineTo(xs[i], ys[i], true)\n        }\n\n        if (type == Type.CLOSED) {\n            b.closePath()\n        }\n\n        return SvgPathElement(b.build())\n    }\n\n    fun toArrowAes(p: DataPointAesthetics): DataPointAesthetics {\n        return object : DataPointAestheticsDelegate(p) {\n            private val myFilled = type == Type.CLOSED\n\n            override fun fill(): Color? {\n                return if (myFilled) {\n                    color()\n                } else Color.TRANSPARENT\n            }\n\n            override fun lineType(): LineType {\n                return if (myFilled) {\n                    NamedLineType.SOLID // avoid ugly patterns if linetype is other than 'solid'\n                } else super.lineType()\n            }\n        }\n    }\n\n    enum class End {\n        LAST, FIRST, BOTH\n    }\n\n    enum class Type {\n        OPEN, CLOSED\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nobject BarTooltipHelper {\n    fun collectRectangleTargets(\n        hintAesList: List<Aes<Double>>,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        rectFactory: (DataPointAesthetics) -> DoubleRectangle?,\n        colorFactory: (DataPointAesthetics) -> Color\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n\n        for (p in aesthetics.dataPoints()) {\n            val rect = rectFactory(p) ?: continue\n\n            val clientRect = helper.toClient(DoubleRectangle(0.0, 0.0, rect.width, 0.0), p)\n            val objectRadius = clientRect.width / 2.0\n\n            val xCoord = rect.center.x\n            val hintFactory = HintsCollection.HintConfigFactory()\n                .defaultObjectRadius(objectRadius)\n                .defaultX(xCoord)\n                .defaultKind(TipLayoutHint.Kind.HORIZONTAL_TOOLTIP)\n\n            val hintConfigs = hintAesList\n                .fold(HintsCollection(p, helper)) { acc, aes ->\n                    acc.addHint(hintFactory.create(aes))\n                }\n\n            ctx.targetCollector.addRectangle(\n                p.index(),\n                helper.toClient(rect, p),\n                GeomTargetCollector.TooltipParams.params()\n                    .setTipLayoutHints(hintConfigs.hints)\n//                    .setColor(HintColorUtil.fromColor(p))\n                    .setColor(colorFactory(p))\n            )\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nobject CrossBarHelper {\n    fun buildBoxes(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        rectFactory: (DataPointAesthetics) -> DoubleRectangle?\n    ) {\n        // rectangles\n        val helper =\n            RectanglesHelper(aesthetics, pos, coord, ctx)\n        val rectangles = helper.createRectangles(rectFactory)\n        rectangles.forEach { root.add(it) }\n    }\n\n    fun buildMidlines(\n        root: SvgRoot,\n        aesthetics: Aesthetics,\n        pos: PositionAdjustment,\n        coord: CoordinateSystem,\n        ctx: GeomContext,\n        fatten: Double\n    ) {\n        val helper = GeomHelper(pos, coord, ctx)\n        val elementHelper = helper.createSvgElementHelper()\n\n        for (p in GeomUtil.withDefined(\n            aesthetics.dataPoints(),\n            Aes.X,\n            Aes.WIDTH,\n            Aes.MIDDLE\n        )) {\n            val x = p.x()!!\n            val middle = p.middle()!!\n            val width = GeomUtil.widthPx(p, ctx, 2.0)\n\n            val line = elementHelper.createLine(\n                DoubleVector(x - width / 2, middle),\n                DoubleVector(x + width / 2, middle),\n                p\n            )\n\n            // adjust thickness\n            val thickness = line.strokeWidth().get()!!\n            line.strokeWidth().set(thickness * fatten)\n\n            root.add(line)\n        }\n    }\n\n    fun legendFactory(whiskers: Boolean): LegendKeyElementFactory =\n        CrossBarLegendKeyElementFactory(whiskers)\n}\n\nprivate class CrossBarLegendKeyElementFactory(val whiskers: Boolean) :\n    LegendKeyElementFactory {\n\n    override fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement {\n        val whiskerSize = .2\n\n        val strokeWidth = AesScaling.strokeWidth(p)\n        val width = (size.x - strokeWidth) * .8 // a bit narrower\n        val height = size.y - strokeWidth\n        val x = (size.x - width) / 2\n        val y = strokeWidth / 2\n\n\n        // box\n        var boxHeight = height\n        var boxY = y\n        if (whiskers) {\n            boxHeight = height * (1 - 2 * whiskerSize)\n            boxY = y + height * whiskerSize\n        }\n\n        val rect = SvgRectElement(\n            x,\n            boxY,\n            width,\n            boxHeight\n        )\n        GeomHelper.decorate(rect, p)\n\n        // lines\n        val middleY = y + height * .5\n        val middle = SvgLineElement(x, middleY, x + width, middleY)\n        GeomHelper.decorate(middle, p)\n\n        val g = SvgGElement()\n        g.children().add(rect)\n        g.children().add(middle)\n\n        if (whiskers) {\n            val middleX = x + width * .5\n            val lowerWhisker =\n                SvgLineElement(middleX, y + height * (1 - whiskerSize), middleX, y + height)\n            GeomHelper.decorate(lowerWhisker, p)\n            val upperWhisker = SvgLineElement(middleX, y, middleX, y + height * whiskerSize)\n            GeomHelper.decorate(upperWhisker, p)\n            g.children().add(lowerWhisker)\n            g.children().add(upperWhisker)\n        }\n\n        return g\n    }\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.point.PointShape\n\nopen class DataPointAestheticsDelegate(private val p: DataPointAesthetics) :\n    DataPointAesthetics {\n\n    override fun index(): Int {\n        return p.index()\n    }\n\n    override fun x(): Double? {\n        return p.x()\n    }\n\n    override fun y(): Double? {\n        return p.y()\n    }\n\n    override fun z(): Double? {\n        return p.z()\n    }\n\n    override fun ymin(): Double? {\n        return p.ymin()\n    }\n\n    override fun ymax(): Double? {\n        return p.ymax()\n    }\n\n    override fun color(): Color? {\n        return p.color()\n    }\n\n    override fun fill(): Color? {\n        return p.fill()\n    }\n\n    override fun alpha(): Double? {\n        return p.alpha()\n    }\n\n    override fun shape(): PointShape? {\n        return p.shape()\n    }\n\n    override fun lineType(): LineType {\n        return p.lineType()\n    }\n\n    override fun size(): Double? {\n        return p.size()\n    }\n\n    override fun width(): Double? {\n        return p.width()\n    }\n\n    override fun height(): Double? {\n        return p.height()\n    }\n\n    override fun weight(): Double? {\n        return p.weight()\n    }\n\n    override fun intercept(): Double? {\n        return p.intercept()\n    }\n\n    override fun slope(): Double? {\n        return p.slope()\n    }\n\n    override fun interceptX(): Double? {\n        return p.interceptX()\n    }\n\n    override fun interceptY(): Double? {\n        return p.interceptY()\n    }\n\n    override fun lower(): Double? {\n        return p.lower()\n    }\n\n    override fun middle(): Double? {\n        return p.middle()\n    }\n\n    override fun upper(): Double? {\n        return p.upper()\n    }\n\n    override fun frame(): String {\n        return p.frame()\n    }\n\n    override fun speed(): Double? {\n        return p.speed()\n    }\n\n    override fun flow(): Double? {\n        return p.flow()\n    }\n\n    override fun xmin(): Double? {\n        return p.xmin()\n    }\n\n    override fun xmax(): Double? {\n        return p.xmax()\n    }\n\n    override fun xend(): Double? {\n        return p.xend()\n    }\n\n    override fun yend(): Double? {\n        return p.yend()\n    }\n\n    override fun label(): Any? {\n        return p.label()\n    }\n\n    override fun family(): String {\n        return p.family()\n    }\n\n    override fun fontface(): String {\n        return p.fontface()\n    }\n\n    override fun hjust(): Any {\n        return p.hjust()\n    }\n\n    override fun vjust(): Any {\n        return p.vjust()\n    }\n\n    override fun angle(): Double? {\n        return p.angle()\n    }\n\n    override fun symX(): Double? {\n        return p.symX()\n    }\n\n    override fun symY(): Double? {\n        return p.symY()\n    }\n\n    override fun group(): Int? {\n        return p.group()\n    }\n\n    override fun numeric(aes: Aes<Double>): Double? {\n        return p.numeric(aes)\n    }\n\n    override fun <T> get(aes: Aes<T>): T? {\n        return p[aes]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass GeomCoord(private val myCoord: CoordinateSystem) {\n\n    fun toClient(p: DoubleVector): DoubleVector {\n        return myCoord.toClient(p)\n    }\n\n    internal fun fromClient(location: DoubleVector): DoubleVector {\n        return myCoord.fromClient(location)\n    }\n\n    fun toClient(r: DoubleRectangle): DoubleRectangle {\n        return translateRect(r) { coord -> myCoord.toClient(coord) }\n    }\n\n    fun fromClient(r: DoubleRectangle): DoubleRectangle {\n        return translateRect(r) { coord -> myCoord.fromClient(coord) }\n    }\n\n    private fun translateRect(r: DoubleRectangle, toLocation: (DoubleVector) -> DoubleVector): DoubleRectangle {\n        @Suppress(\"NAME_SHADOWING\")\n        var r = r\n        val xy1 = r.origin\n        val xy2 = DoubleVector(r.right, r.bottom)\n\n        val xy1cl = toLocation(xy1)\n        val xy2cl = toLocation(xy2)\n        if (xy1 != xy1cl || xy2 != xy2cl) {\n            val xMin = min(xy1cl.x, xy2cl.x)\n            val yMin = min(xy1cl.y, xy2cl.y)\n            val xMax = max(xy1cl.x, xy2cl.x)\n            val yMax = max(xy1cl.y, xy2cl.y)\n\n            r = DoubleRectangle(xMin, yMin, xMax - xMin, yMax - yMin)\n        }\n        return r\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil.ALPHA_CONTROLS_BOTH\nimport jetbrains.datalore.plot.base.render.svg.StrokeDashArraySupport\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.SvgElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgShape\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nopen class GeomHelper(private val myPos: PositionAdjustment, coord: CoordinateSystem, protected val ctx: GeomContext) {\n    private val myGeomCoord: GeomCoord =\n        GeomCoord(coord)\n\n    fun toClient(location: DoubleVector, p: DataPointAesthetics): DoubleVector {\n        return myGeomCoord.toClient(adjust(location, p, myPos, ctx))\n    }\n\n    fun toClient(x: Double?, y: Double?, p: DataPointAesthetics): DoubleVector {\n        // ToDo: don't create new object (optimization)\n        val location = DoubleVector(x!!, y!!)\n        return myGeomCoord.toClient(adjust(location, p, myPos, ctx))\n    }\n\n    fun toClient(r: DoubleRectangle, p: DataPointAesthetics): DoubleRectangle {\n        var clientRect = myGeomCoord.toClient(adjust(r, p, myPos, ctx))\n        // do not allow zero height or width (shape becomes invisible)\n        if (clientRect.width == 0.0) {\n            clientRect = DoubleRectangle(clientRect.origin.x, clientRect.origin.y, 0.1, clientRect.height)\n        }\n        if (clientRect.height == 0.0) {\n            clientRect = DoubleRectangle(clientRect.origin.x, clientRect.origin.y, clientRect.width, 0.1)\n        }\n        return clientRect\n    }\n\n    fun fromClient(location: DoubleVector): DoubleVector {\n        return myGeomCoord.fromClient(location)\n    }\n\n    private fun adjust(\n        location: DoubleVector,\n        p: DataPointAesthetics,\n        pos: PositionAdjustment,\n        ctx: GeomContext\n    ): DoubleVector {\n        return pos.translate(location, p, ctx)\n    }\n\n    internal fun toClientRect(\n        p: DataPointAesthetics,\n        aesMapper: (DataPointAesthetics) -> DoubleRectangle?\n    ): DoubleRectangle? {\n        val r = aesMapper(p) ?: return null\n        return toClient(r, p)\n    }\n\n    private fun adjust(\n        r: DoubleRectangle,\n        p: DataPointAesthetics,\n        pos: PositionAdjustment,\n        ctx: GeomContext\n    ): DoubleRectangle {\n        val leftTop = pos.translate(r.origin, p, ctx)\n        val rightBottom = pos.translate(r.origin.add(r.dimension), p, ctx)\n        return DoubleRectangle.span(leftTop, rightBottom)\n    }\n\n    protected fun project(\n        dataPoints: Iterable<DataPointAesthetics>,\n        projection: (DataPointAesthetics) -> DoubleVector?\n    ): List<DoubleVector> {\n        val points = ArrayList<DoubleVector>()\n        for (p in dataPoints) {\n            val location = projection(p)\n            if (location != null) {\n                val pp = toClient(location, p)\n                points.add(pp)\n            }\n        }\n        return points\n    }\n\n    internal fun toClientLocation(aesMapper: (DataPointAesthetics) -> DoubleVector?): (DataPointAesthetics) -> DoubleVector? {\n        return { aes ->\n            val location = aesMapper(aes)\n            if (location != null) {\n                toClient(location, aes)\n            } else {\n                null\n            }\n        }\n    }\n\n    fun createSvgElementHelper(): SvgElementHelper {\n        return SvgElementHelper()\n    }\n\n    fun toClient(locations: List<DoubleVector>, p: DataPointAesthetics): List<DoubleVector> {\n        val localLocations = ArrayList<DoubleVector>()\n        for (location in locations) {\n            localLocations.add(toClient(location, p))\n        }\n        return localLocations\n    }\n\n    inner class SvgElementHelper {\n        private var myStrokeAlphaEnabled = false\n\n        fun setStrokeAlphaEnabled(b: Boolean) {\n            myStrokeAlphaEnabled = b\n        }\n\n        fun createLine(start: DoubleVector, end: DoubleVector, p: DataPointAesthetics): SvgLineElement {\n            @Suppress(\"NAME_SHADOWING\")\n            val start = toClient(start, p)\n            @Suppress(\"NAME_SHADOWING\")\n            val end = toClient(end, p)\n            val line = SvgLineElement(\n                start.x, start.y,\n                end.x, end.y\n            )\n            decorate(line, p, myStrokeAlphaEnabled)\n            return line\n        }\n    }\n\n    companion object {\n        val HJUST_MAP: Map<Any, TextLabel.HorizontalAnchor> = mapOf(\n            \"right\" to TextLabel.HorizontalAnchor.RIGHT,\n            \"middle\" to TextLabel.HorizontalAnchor.MIDDLE,\n            \"left\" to TextLabel.HorizontalAnchor.LEFT,\n            0.0 to TextLabel.HorizontalAnchor.RIGHT,\n            0.5 to TextLabel.HorizontalAnchor.MIDDLE,\n            1.0 to TextLabel.HorizontalAnchor.LEFT\n        )\n        val VJUST_MAP: Map<Any, TextLabel.VerticalAnchor> = mapOf(\n            \"bottom\" to TextLabel.VerticalAnchor.BOTTOM,\n            \"center\" to TextLabel.VerticalAnchor.CENTER,\n            \"top\" to TextLabel.VerticalAnchor.TOP,\n            0.0 to TextLabel.VerticalAnchor.BOTTOM,\n            0.5 to TextLabel.VerticalAnchor.CENTER,\n            1.0 to TextLabel.VerticalAnchor.TOP\n        )\n        private val FONT_WEIGHT_SET = setOf(\n            \"bold\", \"bolder\", \"lighter\"     // 'normal' is default\n        )\n        private val FONT_STYLE_SET = setOf(\n            \"italic\", \"oblique\"                 // 'normal' is default\n        )\n        private val FONT_FAMILY_MAP = mapOf(\n            \"sans\" to \"sans-serif\",\n            \"serif\" to \"serif\",\n            \"mono\" to \"monospace\"\n        )\n\n        fun decorate(label: TextLabel, p: DataPointAesthetics, scale: Double = 1.0) {\n\n            label.textColor().set(p.color())\n            label.textOpacity().set(p.alpha())\n            label.setFontSize(AesScaling.textSize(p) * scale)\n\n            // family\n            var family = p.family()\n            if (FONT_FAMILY_MAP.containsKey(family)) {   // otherwise - use value as provided by user\n                family = FONT_FAMILY_MAP.get(family)!!\n            }\n            label.setFontFamily(family)\n\n            // fontface\n            // ignore 'plain' / 'normal' as it is default values\n            val fontface = p.fontface()\n            if (!Strings.isNullOrEmpty(fontface)) {\n                for (s in fontface.split(\" \".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray()) {\n                    if (FONT_WEIGHT_SET.contains(s)) {\n                        label.setFontWeight(s)\n                    } else if (FONT_STYLE_SET.contains(s)) {\n                        label.setFontStyle(s)\n                    }\n                }\n            }\n\n            // text justification\n            val hAnchor =\n                textLabelAnchor(\n                    p.hjust(),\n                    HJUST_MAP,\n                    TextLabel.HorizontalAnchor.MIDDLE\n                )\n            val vAnchor =\n                textLabelAnchor(\n                    p.vjust(),\n                    VJUST_MAP,\n                    TextLabel.VerticalAnchor.CENTER\n                )\n\n            if (hAnchor !== TextLabel.HorizontalAnchor.LEFT) {  // 'left' is default\n                label.setHorizontalAnchor(hAnchor)\n            }\n            if (vAnchor !== TextLabel.VerticalAnchor.BOTTOM) {  // 'bottom' is default\n                label.setVerticalAnchor(vAnchor)\n            }\n\n            var angle = p.angle()!!\n            if (angle != 0.0) {\n                // ggplot angle: counter clockwise\n                // SVG angle: clockwise\n                angle = 360 - angle % 360\n                label.rotate(angle)\n            }\n        }\n\n        fun <T> textLabelAnchor(o: Any, conversionMap: Map<Any, T>, def: T): T {\n            return conversionMap.getOrElse(o, { def })\n        }\n\n        fun decorate(node: SvgNode, p: DataPointAesthetics, applyAlphaToAll: Boolean = ALPHA_CONTROLS_BOTH) {\n            if (node is SvgShape) {\n                decorateShape(\n                    node as SvgShape,\n                    p,\n                    applyAlphaToAll\n                )\n            }\n\n            if (node is SvgElement) {\n                val lineType = p.lineType()\n                if (!(lineType.isBlank || lineType.isSolid)) {\n                    StrokeDashArraySupport.apply(node, AesScaling.strokeWidth(p), lineType.dashArray)\n                }\n            }\n        }\n\n        private fun decorateShape(shape: SvgShape, p: DataPointAesthetics, applyAlphaToAll: Boolean) {\n            AestheticsUtil.updateStroke(shape, p, applyAlphaToAll)\n            AestheticsUtil.updateFill(shape, p)\n            shape.strokeWidth().set(AesScaling.strokeWidth(p))\n        }\n\n        internal fun decorateSlimShape(shape: SvgSlimShape, p: DataPointAesthetics) {\n            val stroke = p.color()!!\n            val strokeAlpha = AestheticsUtil.alpha(stroke, p)\n\n            val fill = p.fill()!!\n            val fillAlpha = AestheticsUtil.alpha(fill, p)\n\n            shape.setFill(fill, fillAlpha)\n            shape.setStroke(stroke, strokeAlpha)\n            shape.setStrokeWidth(AesScaling.strokeWidth(p))\n        }\n\n        fun getSizeUnitAes(sizeUnitName: String): Aes<Double> {\n            return when (sizeUnitName.lowercase()) {\n                \"x\" -> Aes.X\n                \"y\" -> Aes.Y\n                else -> error(\"Size unit value must be either 'x' or 'y', but was $sizeUnitName.\")\n            }\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\n\n\nobject GeomUtil {\n    val TO_LOCATION_X_Y = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.y()\n        )\n    }\n    val TO_LOCATION_X_YMIN = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.ymin()\n        )\n    }\n    val TO_LOCATION_X_YMAX = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            p.ymax()\n        )\n    }\n    val TO_LOCATION_X_ZERO = { p: DataPointAesthetics ->\n        toLocationOrNull(\n            p.x(),\n            0.0\n        )\n    }\n    val TO_RECTANGLE = { p: DataPointAesthetics ->\n        if (SeriesUtil.allFinite(p.xmin(), p.ymin(), p.xmax(), p.ymax())) {\n            rectToGeometry(\n                p.xmin()!!,\n                p.ymin()!!,\n                p.xmax()!!,\n                p.ymax()!!\n            )\n        } else {\n            emptyList()\n        }\n    }\n    private val ORDERING_X = Ordering.from(object : Comparator<DataPointAesthetics?> {\n        override fun compare(a: DataPointAesthetics?, b: DataPointAesthetics?): Int {\n            val x1 = a?.x()\n            val x2 = b?.x()\n            if (x1 == null || x2 == null)\n                return 0\n            else\n                return x1.compareTo(x2)\n        }\n    })\n    private val ORDERING_Y = Ordering.from(object : Comparator<DataPointAesthetics?> {\n        override fun compare(a: DataPointAesthetics?, b: DataPointAesthetics?): Int {\n            val y1 = a?.y()\n            val y2 = b?.y()\n            if (y1 == null || y2 == null)\n                return 0\n            else\n                return y1.compareTo(y2)\n        }\n    })\n    private val WITH_X_Y = { pointAes: DataPointAesthetics -> SeriesUtil.allFinite(pointAes.x(), pointAes.y()) }\n    private val WITH_X = { pointAes: DataPointAesthetics -> SeriesUtil.isFinite(pointAes.x()) }\n    private val WITH_Y = { pointAes: DataPointAesthetics -> SeriesUtil.isFinite(pointAes.y()) }\n\n    private fun toLocationOrNull(x: Double?, y: Double?): DoubleVector? {\n        return if (SeriesUtil.isFinite(x) && SeriesUtil.isFinite(y)) {\n            DoubleVector(x!!, y!!)\n        } else null\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_X_Y(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_X_Y.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_X(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_X.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun with_Y(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> WITH_Y.invoke(p) }\n    }\n\n    @Suppress(\"FunctionName\")\n    fun ordered_X(dataPoints: Iterable<DataPointAesthetics>): Iterable<DataPointAesthetics> {\n        if (ORDERING_X.isOrdered(dataPoints)) {\n            return dataPoints\n        }\n        return ORDERING_X.sortedCopy(dataPoints)\n    }\n\n    fun ordered_Y(dataPoints: Iterable<DataPointAesthetics>, reversed: Boolean): Iterable<DataPointAesthetics> {\n        val ordering = if (reversed) ORDERING_Y.reverse() else ORDERING_Y\n        if (ordering.isOrdered(dataPoints)) {\n            return dataPoints\n        }\n        return ordering.sortedCopy(dataPoints)\n    }\n\n    fun widthPx(p: DataPointAesthetics, ctx: GeomContext, minWidth: Double): Double {\n        val w = p.width()\n        val width = w!! * ctx.getResolution(Aes.X)\n        return max(width, minWidth)\n    }\n\n    fun withDefined(dataPoints: Iterable<DataPointAesthetics>, aes: Aes<*>): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>,\n        aes2: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) && p.defined(aes2) }\n    }\n\n    fun withDefined(\n        dataPoints: Iterable<DataPointAesthetics>,\n        aes0: Aes<*>,\n        aes1: Aes<*>,\n        aes2: Aes<*>,\n        aes3: Aes<*>\n    ): Iterable<DataPointAesthetics> {\n        return dataPoints.filter { p -> p.defined(aes0) && p.defined(aes1) && p.defined(aes2) && p.defined(aes3) }\n    }\n\n    fun rectangleByDataPoint(p: DataPointAesthetics, ctx: GeomContext): DoubleRectangle {\n        val x = p.x()!!\n        val y = p.y()!!\n        val width = widthPx(p, ctx, 2.0)\n\n        val origin: DoubleVector\n        val dimensions: DoubleVector\n        if (y >= 0) {\n            origin = DoubleVector(x - width / 2, 0.0)\n            dimensions = DoubleVector(width, y)\n        } else {\n            origin = DoubleVector(x - width / 2, y)\n            dimensions = DoubleVector(width, -y)\n        }\n\n        return DoubleRectangle(origin, dimensions)\n    }\n\n    fun createGroups(dataPoints: Iterable<DataPointAesthetics>): Map<Int, List<DataPointAesthetics>> {\n        val pointsByGroup = HashMap<Int, MutableList<DataPointAesthetics>>()\n        for (p in dataPoints) {\n            val group = p.group()!!\n            if (!pointsByGroup.containsKey(group)) {\n                pointsByGroup[group] = ArrayList()\n            }\n            pointsByGroup[group]!!.add(p)\n        }\n\n        return pointsByGroup\n    }\n\n    fun rectToGeometry(minX: Double, minY: Double, maxX: Double, maxY: Double): List<DoubleVector> {\n        return listOf(\n            DoubleVector(minX, minY),\n            DoubleVector(minX, maxY),\n            DoubleVector(maxX, maxY),\n            DoubleVector(maxX, minY),\n            DoubleVector(minX, minY)\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors.solid\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject HintColorUtil {\n    fun fromColor(p: DataPointAesthetics): Color {\n        return fromColorValue(\n            p.color()!!,\n            p.alpha()!!\n        )\n    }\n\n    fun fromFill(p: DataPointAesthetics): Color {\n        return fromColorValue(\n            p.fill()!!,\n            p.alpha()!!\n        )\n    }\n\n    fun fromColorValue(color: Color, alpha: Double): Color {\n        val intAlpha = (255 * alpha).toInt()\n        return if (solid(color)) {\n            color.changeAlpha(intAlpha)\n        } else color\n\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.HintsCollection.HintConfigFactory.HintConfig\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind\n\n\nclass HintsCollection(private val myPoint: DataPointAesthetics, private val myHelper: GeomHelper) {\n    private val myHints = HashMap<Aes<*>, TipLayoutHint>()\n\n    val hints: MutableMap<Aes<*>, TipLayoutHint>\n        get() = myHints\n\n    fun addHint(hintConfig: HintConfig): HintsCollection {\n        val coord = getCoord(hintConfig)\n\n        if (coord != null) {\n            hints[hintConfig.aes] = createHint(hintConfig, coord)\n        }\n\n        return this\n    }\n\n    private fun getCoord(hintConfig: HintConfig): DoubleVector? {\n        if (hintConfig.x == null) {\n            throw IllegalArgumentException(\"x coord is not set\")\n        }\n\n        val aes = hintConfig.aes\n        return if (!myPoint.defined(aes)) {\n            null\n        } else myHelper.toClient(DoubleVector(hintConfig.x!!, myPoint.get<Double>(aes)!!), myPoint)\n\n    }\n\n    private fun createHint(hintConfig: HintConfig, coord: DoubleVector): TipLayoutHint {\n        val objectRadius = hintConfig.objectRadius\n        val color = hintConfig.color\n\n        if (objectRadius == null) {\n            throw IllegalArgumentException(\"object radius is not set\")\n        }\n\n        return when (hintConfig.kind) {\n            Kind.VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(coord, objectRadius, color)\n\n            Kind.HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(coord, objectRadius, color)\n\n            Kind.CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(coord, color)\n\n            else -> throw IllegalArgumentException(\"Unknown hint kind: \" + hintConfig.kind)\n        }\n    }\n\n    class HintConfigFactory {\n\n        private var myDefaultObjectRadius: Double? = null\n        private var myDefaultX: Double? = null\n        private var myDefaultColor: Color? = null\n        private var myDefaultKind: Kind? = null\n\n        fun defaultObjectRadius(defaultObjectRadius: Double): HintConfigFactory {\n            myDefaultObjectRadius = defaultObjectRadius\n            return this\n        }\n\n        fun defaultX(defaultX: Double): HintConfigFactory {\n            myDefaultX = defaultX\n            return this\n        }\n\n        fun defaultColor(v: Color, alpha: Double?): HintConfigFactory {\n            if (alpha != null) {\n                myDefaultColor = v.changeAlpha((255 * alpha).toInt())\n            } else {\n                myDefaultColor = v\n            }\n            return this\n        }\n\n        fun create(aes: Aes<Double>): HintConfig {\n            return HintConfig(aes)\n        }\n\n        fun defaultKind(kind: Kind): HintConfigFactory {\n            myDefaultKind = kind\n            return this\n        }\n\n        inner class HintConfig internal constructor(val aes: Aes<Double>) {\n            val kind: Kind?\n            var objectRadius: Double? = null\n                private set\n            var x: Double? = null\n                private set\n            internal var color: Color? = null\n                private set\n\n            init {\n                objectRadius = myDefaultObjectRadius\n                x = myDefaultX\n                kind = myDefaultKind\n                color = myDefaultColor\n            }\n\n            fun objectRadius(v: Double): HintConfig {\n                objectRadius = v\n                return this\n            }\n\n            fun x(v: Double): HintConfig {\n                x = v\n                return this\n            }\n\n            fun color(v: Color): HintConfig {\n                color = v\n                return this\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.render.svg.LinePath\n\nclass LinePathConstructor(\n    private val myTargetCollector: GeomTargetCollector,\n    private val myDataPoints: Iterable<DataPointAesthetics>,\n    private val myLinesHelper: LinesHelper,\n    private val myClosePath: Boolean\n) {\n\n    fun construct(withHints: Boolean): List<LinePath> {\n        val linePaths = ArrayList<LinePath>()\n        val multiPointDataList = createMultiPointDataByGroup()\n        for (multiPointData in multiPointDataList) {\n           linePaths.addAll(myLinesHelper.createPaths(multiPointData.aes, multiPointData.points, myClosePath))\n        }\n        if (withHints) {\n            buildHints(multiPointDataList)\n        }\n        return linePaths\n    }\n\n    fun buildHints() = buildHints(createMultiPointDataByGroup())\n\n    private fun buildHints(multiPointDataList: List<MultiPointData>) {\n        for (multiPointData in multiPointDataList) {\n            if (myClosePath) {\n                myTargetCollector.addPolygon(\n                    multiPointData.points,\n                    multiPointData.localToGlobalIndex,\n                    params().setColor(\n                        HintColorUtil.fromFill(\n                            multiPointData.aes\n                        )\n                    )\n                )\n            } else {\n                myTargetCollector.addPath(\n                    multiPointData.points,\n                    multiPointData.localToGlobalIndex,\n                    params().setColor(\n                        HintColorUtil.fromColor(\n                            multiPointData.aes\n                        )\n                    )\n                )\n            }\n        }\n    }\n\n    private fun createMultiPointDataByGroup(): List<MultiPointData> {\n        return MultiPointDataConstructor.createMultiPointDataByGroup(\n            myDataPoints,\n            singlePointAppender { p -> myLinesHelper.toClient(GeomUtil.TO_LOCATION_X_Y(p)!!, p) },\n            reducer(DROP_POINT_DISTANCE, myClosePath)\n        )\n    }\n\n    companion object {\n        private const val DROP_POINT_DISTANCE = 0.999\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Colors.withOpacity\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.geom.StepGeom\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.reducer\nimport jetbrains.datalore.plot.base.geom.util.MultiPointDataConstructor.singlePointAppender\nimport jetbrains.datalore.plot.base.render.svg.LinePath\n\nopen class LinesHelper(pos: PositionAdjustment, coord: CoordinateSystem, ctx: GeomContext) :\n    GeomHelper(pos, coord, ctx) {\n\n    private var myAlphaFilter = { v: Double? -> v }\n    private var myWidthFilter = { v: Double? -> v }\n    private var myAlphaEnabled = true\n\n    private fun insertPathSeparators(rings: Iterable<List<DoubleVector>>): List<DoubleVector?> {\n        val result = ArrayList<DoubleVector?>()\n        for (ring in rings) {\n            if (!result.isEmpty()) {\n                result.add(LinePath.END_OF_SUBPATH) // this is polygon's path separator understood by PathLine component\n            }\n\n            result.addAll(ring)\n        }\n\n        return result\n    }\n\n    fun setAlphaEnabled(b: Boolean) {\n        this.myAlphaEnabled = b\n    }\n\n    fun createLines(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocation: (DataPointAesthetics) -> DoubleVector?\n    ): MutableList<LinePath> {\n        return createPaths(dataPoints, toLocation, false)\n    }\n\n    private fun createPaths(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocation: (DataPointAesthetics) -> DoubleVector?,\n        closePath: Boolean\n    ): MutableList<LinePath> {\n        val paths = ArrayList<LinePath>()\n        val multiPointDataList =\n            MultiPointDataConstructor.createMultiPointDataByGroup(\n                dataPoints,\n                singlePointAppender(toClientLocation { toLocation(it) }),\n                reducer(0.999, closePath)\n            )\n\n        // draw line for each group\n        for (multiPointData in multiPointDataList) {\n            paths.addAll(createPaths(multiPointData.aes, multiPointData.points, closePath))\n        }\n\n        return paths\n    }\n\n    internal fun createPaths(aes: DataPointAesthetics, points: List<DoubleVector>, closePath: Boolean): List<LinePath> {\n        val paths = ArrayList<LinePath>()\n        if (closePath) {\n            paths.add(LinePath.polygon(insertPathSeparators(splitRings(points))))\n        } else {\n            paths.add(LinePath.line(points))\n        }\n        paths.forEach { path -> decorate(path, aes, closePath) }\n        return paths\n    }\n\n    internal fun createSteps(dataPoints: Iterable<DataPointAesthetics>, dir: StepGeom.Direction): List<PathInfo> {\n        val pathInfos = ArrayList<PathInfo>()\n        val multiPointDataList =\n            MultiPointDataConstructor.createMultiPointDataByGroup(\n                dataPoints,\n                singlePointAppender(toClientLocation(GeomUtil.TO_LOCATION_X_Y)),\n                reducer(0.999, false)\n            )\n\n        // draw step for each group\n        for (multiPointData in multiPointDataList) {\n            val points = multiPointData.points\n            if (!points.isEmpty()) {\n                val newPoints = ArrayList<DoubleVector>()\n                var prev: DoubleVector? = null\n                for (point in points) {\n                    if (prev != null) {\n                        val x = if (dir === StepGeom.Direction.HV) point.x else prev.x\n                        val y = if (dir === StepGeom.Direction.HV) prev.y else point.y\n                        newPoints.add(DoubleVector(x, y))\n                    }\n                    newPoints.add(point)\n                    prev = point\n                }\n\n                val path = LinePath.line(newPoints)\n                decorate(path, multiPointData.aes, false)\n                pathInfos.add(\n                    PathInfo(\n                        path\n                    )\n                )\n            }\n        }\n\n        return pathInfos\n    }\n\n    fun createBands(\n        dataPoints: Iterable<DataPointAesthetics>,\n        toLocationUpper: (DataPointAesthetics) -> DoubleVector?,\n        toLocationLower: (DataPointAesthetics) -> DoubleVector?\n    ): MutableList<LinePath> {\n\n        val lines = ArrayList<LinePath>()\n        val pointsByGroup = GeomUtil.createGroups(dataPoints)\n\n        // draw line for each group\n        for (group in Ordering.natural<Int>().sortedCopy(pointsByGroup.keys)) {\n            val groupDataPoints = pointsByGroup[group]\n            // upper margin points\n            val points = ArrayList(project(groupDataPoints!!) { toLocationUpper(it) })\n\n            // lower margin point in reversed order\n//            val lowerPoints = ImmutableList.reverse(groupDataPoints)\n            val lowerPoints = groupDataPoints.reversed()\n            points.addAll(project(lowerPoints) { toLocationLower(it) })\n\n            if (!points.isEmpty()) {\n                val path = LinePath.polygon(points)\n                //decorate(path, groupDataPoints.get(0), true);\n                decorateFillingPart(path, groupDataPoints[0])\n                lines.add(path)\n            }\n        }\n        return lines\n    }\n\n    protected fun decorate(path: LinePath, p: DataPointAesthetics, filled: Boolean) {\n\n        val stroke = p.color()\n        val strokeAlpha = myAlphaFilter(AestheticsUtil.alpha(stroke!!, p))!!\n        path.color().set(withOpacity(stroke, strokeAlpha))\n        if (!AestheticsUtil.ALPHA_CONTROLS_BOTH && (filled || !myAlphaEnabled)) {\n            path.color().set(stroke)\n        }\n\n        if (filled) {\n            decorateFillingPart(path, p)\n        }\n\n        val size = myWidthFilter(AesScaling.strokeWidth(p))!!\n        path.width().set(size)\n\n        val lineType = p.lineType()\n        if (!(lineType.isBlank || lineType.isSolid)) {\n            path.dashArray().set(lineType.dashArray)\n        }\n    }\n\n    private fun decorateFillingPart(path: LinePath, p: DataPointAesthetics) {\n        val fill = p.fill()\n        val fillAlpha = myAlphaFilter(AestheticsUtil.alpha(fill!!, p))!!\n        path.fill().set(withOpacity(fill, fillAlpha))\n    }\n\n    fun setAlphaFilter(alphaFilter: (Double?) -> Double?) {\n        myAlphaFilter = alphaFilter\n    }\n\n    fun setWidthFilter(widthFilter: (Double?) -> Double?) {\n        myWidthFilter = widthFilter\n    }\n\n    // ToDo: get rid of PathInfo class\n    class PathInfo internal constructor(val path: LinePath)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nclass MappedAesthetics(\n    private val myAesthetics: Aesthetics,\n    private val myPointAestheticsMapper: (DataPointAesthetics) -> DataPointAesthetics\n) : Aesthetics {\n\n    override val isEmpty: Boolean\n        get() = myAesthetics.isEmpty\n\n    override fun dataPointAt(index: Int): DataPointAesthetics {\n        return myPointAestheticsMapper(myAesthetics.dataPointAt(index))\n    }\n\n    override fun dataPointCount(): Int {\n        return myAesthetics.dataPointCount()\n    }\n\n    override fun dataPoints(): Iterable<DataPointAesthetics> {\n        val source = myAesthetics.dataPoints()\n        return source.map { myPointAestheticsMapper(it) }\n    }\n\n    override fun range(aes: Aes<Double>): ClosedRange<Double> {\n        throw IllegalStateException(\"MappedAesthetics.range: not implemented $aes\")\n    }\n\n    override fun overallRange(aes: Aes<Double>): ClosedRange<Double> {\n        throw IllegalStateException(\"MappedAesthetics.overallRange: not implemented $aes\")\n    }\n\n    override fun resolution(aes: Aes<Double>, naValue: Double): Double {\n        throw IllegalStateException(\"MappedAesthetics.resolution: not implemented $aes\")\n    }\n\n    override fun numericValues(aes: Aes<Double>): Iterable<Double?> {\n        throw IllegalStateException(\"MappedAesthetics.numericValues: not implemented $aes\")\n    }\n\n    override fun groups(): Iterable<Int> {\n        return myAesthetics.groups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nclass MultiPointData internal constructor(\n    val aes: DataPointAesthetics,\n    val points: List<DoubleVector>,\n    val localToGlobalIndex: (Int) -> Int,\n    val group: Int)\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport kotlin.math.abs\n\nobject MultiPointDataConstructor {\n    fun collector(): () -> PointCollector {\n        return { SimplePointCollector() }\n    }\n\n    fun reducer(dropPointDistance: Double, isPolygon: Boolean): () -> PointCollector {\n        return {\n            PointReducer(\n                dropPointDistance,\n                isPolygon\n            )\n        }\n    }\n\n    fun singlePointAppender(\n            toPoint: (DataPointAesthetics) -> DoubleVector?):\n            (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit {\n        return { aes, coordinateConsumer -> coordinateConsumer(toPoint(aes)) }\n    }\n\n    fun multiPointAppender(\n            toPath: (DataPointAesthetics) -> List<DoubleVector>): (DataPointAesthetics, (DoubleVector) -> Unit) -> Unit {\n        return { aes, coordinateConsumer -> toPath(aes).forEach(coordinateConsumer) }\n    }\n\n    fun createMultiPointDataByGroup(\n        dataPoints: Iterable<DataPointAesthetics>,\n        coordinateAppender: (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit,\n        pointCollectorSupplier: () -> PointCollector\n    ): List<MultiPointData> {\n        val multiPointDataCombiners = HashMap<Int, MultiPointDataCombiner>()\n\n        for (p in dataPoints) {\n            val group = p.group()\n            if (!multiPointDataCombiners.containsKey(group)) {\n                multiPointDataCombiners[group!!] =\n                    MultiPointDataCombiner(\n                        coordinateAppender,\n                        pointCollectorSupplier()\n                    )\n            }\n\n            multiPointDataCombiners[group]!!.add(p)\n        }\n\n        val result = ArrayList<MultiPointData>()\n\n        val sortedGroup = natural<Int>().sortedCopy(multiPointDataCombiners.keys)\n        for (group in sortedGroup) {\n            val multiPointData = multiPointDataCombiners[group]!!.create(group)\n\n            if (multiPointData.points.isNotEmpty()) {\n                result.add(multiPointData)\n            }\n        }\n\n        return result\n    }\n\n    interface PointCollector {\n\n        val points: Pair<List<DoubleVector>, List<Int>>\n        fun add(coord: DoubleVector?, index: Int)\n    }\n\n    private class MultiPointDataCombiner internal constructor(\n        private val myCoordinateAppender: (DataPointAesthetics, (DoubleVector?) -> Unit) -> Unit,\n        private val myPointCollector: PointCollector\n    ) {\n\n        private var myFirstAes: DataPointAesthetics? = null\n\n        internal fun add(aes: DataPointAesthetics) {\n            if (myFirstAes == null) {\n                myFirstAes = aes\n            }\n            myCoordinateAppender(aes) { myPointCollector.add(it, aes.index()) }\n        }\n\n        internal fun create(group: Int): MultiPointData {\n            val points = myPointCollector.points\n            return MultiPointData(\n                myFirstAes!!,\n                points.first,\n                { points.second[it] },\n                group\n            )\n        }\n    }\n\n    private class SimplePointCollector internal constructor() :\n        PointCollector {\n        private val myPoints = ArrayList<DoubleVector>()\n        private val myIndexes = ArrayList<Int>()\n\n        override val points: Pair<List<DoubleVector>, List<Int>>\n            get() = Pair(myPoints, myIndexes)\n\n        override fun add(coord: DoubleVector?, index: Int) {\n            myPoints.add(coord!!)\n            myIndexes.add(index)\n        }\n    }\n\n    private class PointReducer internal constructor(private val myDropPointDistance: Double, private val myPolygon: Boolean) :\n        PointCollector {\n\n        private val myReducedPoints = ArrayList<DoubleVector>()\n        private val myReducedIndexes = ArrayList<Int>()\n        private var myLastAdded: DoubleVector? = null\n        private var myLastPostponed: Pair<DoubleVector, Int>? = null\n        private var myRegionStart: Pair<DoubleVector?, Int?>? = null\n\n        override// Add last postponed to avoid disconnected contours\n        val points: Pair<List<DoubleVector>, List<Int>>\n            get() {\n                if (myLastPostponed != null) {\n                    addPoint(myLastPostponed!!.first, myLastPostponed!!.second)\n                    myLastPostponed = null\n                }\n\n                return Pair(myReducedPoints, myReducedIndexes)\n            }\n\n        private fun isCloserThan(p0: DoubleVector, p1: DoubleVector, distance: Double): Boolean {\n            return abs(p0.x - p1.x) < distance && abs(p0.y - p1.y) < distance\n        }\n\n        override fun add(coord: DoubleVector?, index: Int) {\n            if (coord == null) {\n                return\n            }\n\n            if (myLastAdded == null) {\n                storePoint(coord, index)\n                return\n            }\n\n            if (needPostpone(coord)) {\n                postponePoint(coord, index)\n            } else {\n                // add all\n                if (myLastPostponed != null) {\n                    addPoint(myLastPostponed!!.first, myLastPostponed!!.second)\n                    myLastPostponed = null\n                }\n                storePoint(coord, index)\n            }\n        }\n\n        private fun needPostpone(loc: DoubleVector): Boolean {\n            val closeToAdded = areTooClose(myLastAdded, loc)\n            val closeToPostponed = myLastPostponed == null || areTooClose(myLastPostponed!!.first, loc)\n            val regionClosePoint = isRegionStart(loc)\n\n            return closeToAdded && closeToPostponed && !regionClosePoint\n        }\n\n        private fun postponePoint(loc: DoubleVector, index: Int) {\n            myLastPostponed = Pair(loc, index)\n        }\n\n        private fun storePoint(loc: DoubleVector, index: Int) {\n            addPoint(loc, index)\n            myLastAdded = loc\n\n            processRegionStart(loc, index)\n        }\n\n        private fun processRegionStart(loc: DoubleVector?, index: Int?) {\n            if (!myPolygon) {\n                return\n            }\n\n            if (myRegionStart == null) {\n                myRegionStart = Pair(loc, index)\n                return\n            }\n\n            if (isRegionStart(loc)) {\n                // Region is closed. Wait next start point.\n                myRegionStart = null\n                myLastAdded = null\n            }\n        }\n\n        private fun isRegionStart(loc: DoubleVector?): Boolean {\n            if (!myPolygon) {\n                return false\n            }\n\n            return if (myRegionStart == null) {\n                false\n            } else myRegionStart!!.first == loc\n\n        }\n\n        private fun addPoint(loc: DoubleVector, index: Int) {\n            myReducedPoints.add(loc)\n            myReducedIndexes.add(index)\n        }\n\n        private fun areTooClose(p1: DoubleVector?, p2: DoubleVector): Boolean {\n            return isCloserThan(p1!!, p2, myDropPointDistance)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams.Companion.params\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nclass RectTargetCollectorHelper(\n    private val rectanglesHelper: RectanglesHelper,\n    private val rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?,\n    private val fillByDataPoint: (DataPointAesthetics) -> Color,\n    private val tooltipKind: TipLayoutHint.Kind\n) {\n\n    fun collectTo(targetCollector: GeomTargetCollector) {\n        rectanglesHelper.iterateRectangleGeometry(rectangleByDataPoint)\n        { p, rectangle ->\n            targetCollector.addRectangle(p.index(), rectangle, tooltipParams(p), tooltipKind)\n        }\n    }\n\n    private fun tooltipParams(p: DataPointAesthetics): TooltipParams {\n        val params = params()\n        params.setColor(fillByDataPoint(p))\n        return params\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.geom.util\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\n\nclass RectanglesHelper(\n    private val myAesthetics: Aesthetics,\n    pos: PositionAdjustment,\n    coord: CoordinateSystem,\n    ctx: GeomContext\n) : GeomHelper(pos, coord, ctx) {\n\n    fun createRectangles(rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?): MutableList<SvgNode> {\n        val result = ArrayList<SvgNode>()\n\n        for (index in 0 until myAesthetics.dataPointCount()) {\n            val p = myAesthetics.dataPointAt(index)\n            val clientRect = toClientRect(p, rectangleByDataPoint) ?: continue\n\n            val svgRect = SvgRectElement(clientRect)\n            decorate(svgRect, p)\n\n            result.add(svgRect)\n        }\n\n        return result\n    }\n\n    fun iterateRectangleGeometry(\n        rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?,\n        iterator: (DataPointAesthetics, DoubleRectangle) -> Unit\n    ) {\n        for (index in 0 until myAesthetics.dataPointCount()) {\n            val p = myAesthetics.dataPointAt(index)\n            val rect = toClientRect(p, rectangleByDataPoint)\n\n            rect?.let {\n                iterator(p, rect)\n            }\n        }\n    }\n\n\n    fun createSlimRectangles(rectangleByDataPoint: (DataPointAesthetics) -> DoubleRectangle?): SvgSlimGroup {\n        val pointCount = myAesthetics.dataPointCount()\n        val group = SvgSlimElements.g(pointCount)\n\n        for (index in 0 until pointCount) {\n            val p = myAesthetics.dataPointAt(index)\n            val clientRect = toClientRect(p, rectangleByDataPoint) ?: continue\n\n            val slimShape = SvgSlimElements.rect(clientRect.left, clientRect.top, clientRect.width, clientRect.height)\n            decorateSlimShape(\n                slimShape,\n                p\n            )\n            slimShape.appendTo(group)\n        }\n\n        return group\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.values.Color\n\n// `open` for Mockito tests\nopen class ContextualMapping(\n    private val tooltipLines: List<TooltipLineSpec>,\n    val tooltipAnchor: TooltipAnchor?,\n    val tooltipMinWidth: Double?,\n    val tooltipColor: Color?,\n    val ignoreInvisibleTargets: Boolean,\n    val hasGeneralTooltip: Boolean,\n    val hasAxisTooltip: Boolean,\n    val isCrosshairEnabled: Boolean\n) {\n    fun getDataPoints(index: Int): List<TooltipLineSpec.DataPoint> {\n        return tooltipLines.mapNotNull { it.getDataPoint(index) }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.DataFrame\n\ndata class DataContext(\n    val dataFrame: DataFrame,\n    val mappedDataAccess: MappedDataAccess\n)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\n\n// `open` - for Mockito tests\nopen class GeomTarget(\n    val hitIndex: Int,\n    open val tipLayoutHint: TipLayoutHint,\n    open val aesTipLayoutHints: Map<Aes<*>, TipLayoutHint>)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind\n\ninterface GeomTargetCollector {\n\n    fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.VERTICAL_TOOLTIP\n    )\n\n    fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.HORIZONTAL_TOOLTIP\n    )\n\n    fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.HORIZONTAL_TOOLTIP\n    )\n\n    fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: Kind = Kind.CURSOR_TOOLTIP\n    )\n\n    class TooltipParams {\n\n        private var myTipLayoutHints = emptyMap<Aes<*>, TipLayoutHint>()\n        private var myColor = Color.GRAY\n        private var myStemLength = TipLayoutHint.StemLength.NORMAL\n\n        fun getTipLayoutHints(): Map<Aes<*>, TipLayoutHint> {\n            return myTipLayoutHints\n        }\n\n        fun setTipLayoutHints(tipLayoutHints: Map<Aes<*>, TipLayoutHint>): TooltipParams {\n            myTipLayoutHints = tipLayoutHints\n            return this\n        }\n\n        fun getColor(): Color {\n            return myColor\n        }\n\n        fun setColor(color: Color): TooltipParams {\n            myColor = color\n            return this\n        }\n\n        fun getStemLength(): TipLayoutHint.StemLength {\n            return myStemLength\n        }\n\n        fun setStemLength(stemLength: TipLayoutHint.StemLength): TooltipParams {\n            myStemLength = stemLength\n            return this\n        }\n\n        companion object {\n            fun params(): TooltipParams {\n                return TooltipParams()\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\n\ninterface GeomTargetLocator {\n\n    fun search(coord: DoubleVector): LookupResult?\n\n    enum class LookupSpace {\n        X, XY, NONE\n    }\n\n    enum class LookupStrategy {\n        HOVER, NEAREST, NONE\n    }\n\n    class LookupSpec(val lookupSpace: LookupSpace, val lookupStrategy: LookupStrategy) {\n        companion object {\n            val NONE = LookupSpec(\n                LookupSpace.NONE,\n                LookupStrategy.NONE\n            )\n        }\n    }\n\n    // `open` for Mockito test\n    open class LookupResult(\n        val targets: List<GeomTarget>,\n        open val distance: Double,\n        open val geomKind: GeomKind,\n        open val contextualMapping: ContextualMapping,\n        val isCrosshairEnabled: Boolean\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nopen class HitShape private constructor(val kind: Kind, private val shape: Any) {\n\n    val point: DoubleCircle\n        get() = shape as DoubleCircle\n\n    val rect: DoubleRectangle\n        get() = shape as DoubleRectangle\n\n    open val points: List<DoubleVector>\n        get() = throw IllegalStateException(\"Not applicable to $kind\")\n\n    enum class Kind {\n        POINT, RECT, POLYGON, PATH\n    }\n\n    class DoubleCircle(val center: DoubleVector, val radius: Double)\n\n    companion object {\n        fun point(p: DoubleVector, radius: Double): HitShape {\n            return HitShape(Kind.POINT, DoubleCircle(p, radius))\n        }\n\n        fun rect(r: DoubleRectangle): HitShape {\n            return HitShape(Kind.RECT, r)\n        }\n\n        fun path(points: List<DoubleVector>): HitShape {\n            return shapeWithPath(Kind.PATH, points)\n        }\n\n        fun polygon(points: List<DoubleVector>): HitShape {\n            return shapeWithPath(Kind.POLYGON, points)\n        }\n\n        private fun shapeWithPath(kind: Kind, points: List<DoubleVector>): HitShape {\n            return object : HitShape(kind, points) {\n                override val points: List<DoubleVector>\n                    get() = points\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\ninterface MappedDataAccess {\n\n    val mappedAes: Set<Aes<*>>\n\n    val scaleByAes: (Aes<*>) -> Scale<*>\n\n    fun isMapped(aes: Aes<*>): Boolean\n\n    fun <T> getMappedData(aes: Aes<T>, index: Int): MappedData<T>\n\n    fun <T> getOriginalValue(aes: Aes<T>, index: Int): Any?\n\n    fun getMappedDataLabel(aes: Aes<*>): String\n\n    fun isMappedDataContinuous(aes: Aes<*>): Boolean\n\n    class MappedData<T>(\n        val label: String,\n        val value: String,\n        val isContinuous: Boolean\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\n\nclass NullGeomTargetCollector : GeomTargetCollector {\n    override fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n\n    override fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\n\n// `open` - for Mockito tests\nopen class TipLayoutHint(\n    open val kind: Kind,\n    open val coord: DoubleVector?,\n    open val objectRadius: Double,\n    open val color: Color?,\n    open val stemLength: StemLength\n) {\n\n    enum class StemLength(val value: Double) {\n        NORMAL(12.0),\n        SHORT(5.0),\n        NONE(0.0)\n    }\n\n    override fun toString(): String {\n        return \"$kind\"\n    }\n\n\n    enum class Kind {\n        VERTICAL_TOOLTIP,\n        HORIZONTAL_TOOLTIP,\n        CURSOR_TOOLTIP,\n        X_AXIS_TOOLTIP,\n        Y_AXIS_TOOLTIP\n    }\n\n\n    companion object {\n\n        fun verticalTooltip(coord: DoubleVector?, objectRadius: Double, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                Kind.VERTICAL_TOOLTIP,\n                coord,\n                objectRadius,\n                color,\n                stemLength\n            )\n        }\n\n        fun horizontalTooltip(coord: DoubleVector?, objectRadius: Double, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                Kind.HORIZONTAL_TOOLTIP,\n                coord,\n                objectRadius,\n                color,\n                stemLength\n            )\n        }\n\n        fun cursorTooltip(coord: DoubleVector?, color: Color?, stemLength: StemLength = StemLength.NORMAL): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.CURSOR_TOOLTIP,\n                coord = coord,\n                objectRadius = 0.0,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n\n        fun xAxisTooltip(coord: DoubleVector?, color: Color?, axisRadius: Double = 0.0, stemLength: StemLength = StemLength.NONE): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.X_AXIS_TOOLTIP,\n                coord = coord,\n                objectRadius = axisRadius,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n\n        fun yAxisTooltip(coord: DoubleVector?, color: Color?, axisRadius: Double = 0.0, stemLength: StemLength = StemLength.NONE): TipLayoutHint {\n            return TipLayoutHint(\n                kind = Kind.Y_AXIS_TOOLTIP,\n                coord = coord,\n                objectRadius = axisRadius,\n                color = color,\n                stemLength = stemLength\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nclass TooltipAnchor(\n    val verticalAnchor: VerticalAnchor,\n    val horizontalAnchor: HorizontalAnchor\n) {\n    enum class VerticalAnchor {\n        TOP,\n        BOTTOM,\n        MIDDLE\n    }\n\n    enum class HorizontalAnchor {\n        LEFT,\n        RIGHT,\n        CENTER;\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as TooltipAnchor\n\n        if (verticalAnchor != other.verticalAnchor) return false\n        if (horizontalAnchor != other.horizontalAnchor) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = verticalAnchor.hashCode()\n        result = 31 * result + horizontalAnchor.hashCode()\n        return result\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.interact\n\nimport jetbrains.datalore.plot.base.Aes\n\ninterface TooltipLineSpec {\n    fun getDataPoint(index: Int): DataPoint?\n\n    class DataPoint(\n        val label: String?,\n        val value: String,\n        val aes: Aes<*>?,\n        val isAxis: Boolean,\n        val isOutlier: Boolean\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.livemap\n\ninterface LivemapConstants {\n    enum class DisplayMode {\n        POINT,\n        PIE,\n        BAR\n    }\n\n    enum class Theme {\n        COLOR,\n        LIGHT,\n        DARK\n    }\n\n    enum class Projection {\n        EPSG3857,\n        EPSG4326,\n        AZIMUTHAL,\n        CONIC\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.livemap\n\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode\nimport jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection\n\nclass LiveMapOptions(\n    val zoom: Int?,\n    val location: Any?,\n    val stroke: Double?,\n    val interactive: Boolean,\n    val displayMode: DisplayMode,\n    val scaled: Boolean,\n    val clustering: Boolean,\n    val labels: Boolean,\n    val projection: Projection,\n    val geodesic: Boolean,\n    val geocodingService: Map<*, *>,\n    val tileProvider: Map<*, *>,\n    val devParams: Map<*, *>\n)","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class DodgePos(\n    aesthetics: Aesthetics,\n    private val myGroupCount: Int,\n    private val myWidth: Double?\n) : PositionAdjustment {\n\n    private val myDodgingNeeded: Boolean\n    private fun isDodgingNeeded(aesthetics: Aesthetics): Boolean {\n        // if for some X there are more then just 1 group, then dodging is needed\n        val groupByX = HashMap<Double, Int?>()\n        for (i in 0 until aesthetics.dataPointCount()) {\n            val p = aesthetics.dataPointAt(i)\n            if (p.defined(Aes.X)) {\n                val x = p.x()!!\n                val group = p.group()\n                if (groupByX.containsKey(x)) {\n                    if (groupByX[x] != group) {\n                        // >1 group for this X\n                        return true\n                    }\n                } else {\n                    groupByX[x] = group\n                }\n            }\n        }\n        return false\n    }\n\n    init {\n        myDodgingNeeded = isDodgingNeeded(aesthetics)\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        if (myDodgingNeeded) {\n            val dataResolution = ctx.getResolution(Aes.X)\n            val width = myWidth ?: p.width()\n\n            if (!SeriesUtil.isFinite(width)) {\n                return v\n            }\n\n            val slotIndex = p.group()!!\n            val median = (myGroupCount - 1) / 2.0\n            val xOffset = (slotIndex - median) * dataResolution * width!!\n            val xCenter = p.x()!!\n            val xScaler = 1.0 / myGroupCount\n\n            val newX = (v.x + xOffset - xCenter) * xScaler + xCenter\n\n            return DoubleVector(newX, v.y)\n        }\n        return v\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.DODGE.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class FillPos(aes: Aesthetics) : PositionAdjustment {\n\n    private val myStackPosHelper: PositionAdjustment =\n        StackPos.splitPositiveNegative(aes)\n    private val myScalerByIndex: Map<Int, Double> = mapIndexToScaler(aes)\n\n    private fun mapIndexToScaler(aes: Aesthetics): Map<Int, Double> {\n        val posMaxByBin = HashMap<Double, Double>()\n        val negMaxByBin = HashMap<Double, Double>()\n        for (i in 0 until aes.dataPointCount()) {\n            val dataPoint = aes.dataPointAt(i)\n            val x = dataPoint.x()\n            if (SeriesUtil.isFinite(x)) {\n                if (!posMaxByBin.containsKey(x)) {\n                    posMaxByBin[x!!] = 0.0\n                    negMaxByBin[x] = 0.0\n                }\n\n                val y = dataPoint.y()\n                if (SeriesUtil.isFinite(y)) {\n                    if (y!! >= 0) {\n                        posMaxByBin[x!!] = posMaxByBin[x]!! + y\n                    } else {\n                        negMaxByBin[x!!] = negMaxByBin[x]!! - y\n                    }\n                }\n            }\n        }\n        val scalerByIndex = HashMap<Int, Double>()\n        // Double max = max(Collections.max(posMaxByBin.values()), Collections.max(negMaxByBin.values()));\n        for (i in 0 until aes.dataPointCount()) {\n            val dataPoint = aes.dataPointAt(i)\n            val x = dataPoint.x()\n            val y = dataPoint.y()\n            if (posMaxByBin.containsKey(x) && SeriesUtil.isFinite(y)) {\n                if (y!! >= 0 && posMaxByBin[x]!! > 0) {\n                    scalerByIndex[i] = 1.0 / posMaxByBin[x]!!\n                } else if (y < 0 && negMaxByBin[x]!! > 0) {\n                    scalerByIndex[i] = 1.0 / negMaxByBin[x]!!\n                } else {\n                    scalerByIndex[i] = 1.0\n                }\n            } else {\n                scalerByIndex[i] = 1.0\n            }\n        }\n        return scalerByIndex\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val newLoc = myStackPosHelper.translate(v, p, ctx)\n        return DoubleVector(newLoc.x, newLoc.y * myScalerByIndex[p.index()]!! * ctx.getUnitResolution(Aes.Y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.FILL.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\nclass JitterDodgePos(aesthetics: Aesthetics, groupCount: Int, width: Double?, jitterWidth: Double?, jitterHeight: Double?) :\n    PositionAdjustment {\n    private val myJitterPosHelper: PositionAdjustment\n    private val myDodgePosHelper: PositionAdjustment\n\n    init {\n        myJitterPosHelper = JitterPos(jitterWidth, jitterHeight)\n        myDodgePosHelper = DodgePos(aesthetics, groupCount, width)\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val afterJitter = myJitterPosHelper.translate(v, p, ctx)\n        return myDodgePosHelper.translate(afterJitter, p, ctx)\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.JITTER_DODGE.handlesGroups()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport kotlin.random.Random\n\ninternal class JitterPos(width: Double?, height: Double?) : PositionAdjustment {\n\n    //uniform distribution\n    private val myWidth: Double\n    private val myHeight: Double\n\n    init {\n        myWidth = width ?: DEF_JITTER_WIDTH\n        myHeight = height ?: DEF_JITTER_HEIGHT\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        val x = (2 * Random.nextDouble() - 1) * myWidth * ctx.getResolution(Aes.X)\n        val y = (2 * Random.nextDouble() - 1) * myHeight * ctx.getResolution(Aes.Y)\n        return v.add(DoubleVector(x, y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.JITTER.handlesGroups()\n    }\n\n    companion object {\n\n        val DEF_JITTER_WIDTH = 0.4\n        val DEF_JITTER_HEIGHT = 0.4\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\ninternal class NudgePos(width: Double?, height: Double?) : PositionAdjustment {\n\n    private val myWidth: Double\n    private val myHeight: Double\n\n    init {\n        myWidth = width ?: DEF_NUDGE_WIDTH\n        myHeight = height ?: DEF_NUDGE_HEIGHT\n    }\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        //ToDo: getResolution needs to be changed later. In R, the points move in another way when data is continuous.\n        val x = myWidth * ctx.getUnitResolution(Aes.X)\n        val y = myHeight * ctx.getUnitResolution(Aes.Y)\n        return v.add(DoubleVector(x, y))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.NUDGE.handlesGroups()\n    }\n\n    companion object {\n        val DEF_NUDGE_WIDTH = 0.0\n        val DEF_NUDGE_HEIGHT = 0.0\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\n\nobject PositionAdjustments {\n\n    fun identity(): PositionAdjustment {\n        return object : PositionAdjustment {\n\n            override val isIdentity: Boolean\n                get() = true\n\n            override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n                return v\n            }\n\n            override fun handlesGroups(): Boolean {\n                return Meta.IDENTITY.handlesGroups()\n            }\n        }\n    }\n\n    /**\n     * @param aesthetics\n     * @param groupCount\n     * @param width      NULL - default\n     * @return\n     */\n    fun dodge(aesthetics: Aesthetics, groupCount: Int, width: Double?): PositionAdjustment {\n        return DodgePos(aesthetics, groupCount, width)\n    }\n\n    fun stack(aes: Aesthetics, strategy: StackingStrategy): PositionAdjustment {\n        return when (strategy) {\n            StackingStrategy.SPLIT_POSITIVE_NEGATIVE -> StackPos.splitPositiveNegative(aes)\n            StackingStrategy.SUM_POSITIVE_NEGATIVE -> StackPos.sumPositiveNegative(aes)\n        }\n    }\n\n    fun fill(aesthetics: Aesthetics): PositionAdjustment {\n        return FillPos(aesthetics)\n    }\n\n    fun jitter(width: Double?, height: Double?): PositionAdjustment {\n        return JitterPos(width, height)\n    }\n\n    fun nudge(width: Double?, height: Double?): PositionAdjustment {\n        return NudgePos(width, height)\n    }\n\n    fun jitterDodge(\n        aesthetics: Aesthetics,\n        groupCount: Int,\n        width: Double?,\n        jitterWidth: Double?,\n        jitterHeight: Double?\n    ): PositionAdjustment {\n        return JitterDodgePos(aesthetics, groupCount, width, jitterWidth, jitterHeight)\n    }\n\n    enum class Meta(private val myHandlesGroups: Boolean) {\n        IDENTITY(false),\n        DODGE(true),\n        STACK(true),\n        FILL(true),\n        JITTER(false),\n        NUDGE(false),\n        JITTER_DODGE(true);\n\n        fun handlesGroups(): Boolean {\n            return myHandlesGroups\n        }\n    }\n\n    enum class StackingStrategy {\n        SUM_POSITIVE_NEGATIVE,\n        SPLIT_POSITIVE_NEGATIVE\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.pos\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal abstract class StackPos(aes: Aesthetics) :\n    PositionAdjustment {\n\n    private val myOffsetByIndex: Map<Int, Double>\n\n    init {\n        myOffsetByIndex = mapIndexToOffset(aes)\n    }\n\n    protected abstract fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double>\n\n    override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {\n        return v.add(DoubleVector(0.0, myOffsetByIndex[p.index()]!!))\n    }\n\n    override fun handlesGroups(): Boolean {\n        return PositionAdjustments.Meta.STACK.handlesGroups()\n    }\n\n    private class SplitPositiveNegative internal constructor(aes: Aesthetics) : StackPos(aes) {\n\n        override fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double> {\n            val offsetByIndex = HashMap<Int, Double>()\n            val negPosBaseByBin = HashMap<Double, Pair<MutableDouble, MutableDouble>>()\n            for (i in 0 until aes.dataPointCount()) {\n                val dataPoint = aes.dataPointAt(i)\n                val x = dataPoint.x()\n                if (SeriesUtil.isFinite(x)) {\n                    if (!negPosBaseByBin.containsKey(x)) {\n                        negPosBaseByBin[x!!] = Pair(\n                            MutableDouble(0.0),\n                            MutableDouble(0.0)\n                        )\n                    }\n\n                    val y = dataPoint.y()\n                    if (SeriesUtil.isFinite(y)) {\n                        val pair = negPosBaseByBin[x]!!\n                        val offset: Double\n                        if (y!! >= 0) {\n                            offset = pair.second.getAndAdd(y)\n                        } else {\n                            offset = pair.first.getAndAdd(y)\n                        }\n                        offsetByIndex[i] = offset\n                    }\n                }\n            }\n\n            return offsetByIndex\n        }\n\n    }\n\n    private class SumPositiveNegative internal constructor(aes: Aesthetics) : StackPos(aes) {\n\n        override fun mapIndexToOffset(aes: Aesthetics): Map<Int, Double> {\n            val offsetByIndex = HashMap<Int, Double>()\n            val baseByBin = HashMap<Double, MutableDouble>()\n            for (i in 0 until aes.dataPointCount()) {\n                val dataPointAes = aes.dataPointAt(i)\n                val x = dataPointAes.x()!!\n                if (SeriesUtil.isFinite(x)) {\n                    if (!baseByBin.containsKey(x)) {\n                        baseByBin[x] = MutableDouble(0.0)\n                    }\n\n                    val y = dataPointAes.y()!!\n                    if (SeriesUtil.isFinite(y)) {\n                        val base = baseByBin[x]!!\n                        val offset = base.getAndAdd(y)\n                        offsetByIndex[i] = offset\n                    }\n                }\n            }\n\n            return offsetByIndex\n        }\n    }\n\n    companion object {\n        fun splitPositiveNegative(aes: Aesthetics): PositionAdjustment {\n            return SplitPositiveNegative(aes)\n        }\n\n        fun sumPositiveNegative(aes: Aesthetics): PositionAdjustment {\n            return SumPositiveNegative(aes)\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.vis.svg.SvgGElement\n\ninterface LegendKeyElementFactory {\n    fun createKeyElement(p: DataPointAesthetics, size: DoubleVector): SvgGElement\n\n    fun minimumKeySize(p: DataPointAesthetics): DoubleVector {\n        val strokeWidth = AesScaling.strokeWidth(p)\n        val size = 2 * strokeWidth + 4\n        return DoubleVector(size, size)\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.linetype\n\nenum class NamedLineType(val code: Int, private val myDashArray: List<Double>?) :\n    LineType {\n    // 0 = blank, 1 = solid, 2 = dashed, 3 = dotted, 4 = dotdash, 5 = longdash, 6 = twodash\n    BLANK(0, null) {\n        override val isBlank: Boolean\n            get() = true\n    },\n    SOLID(1, null) {\n        override val isSolid: Boolean\n            get() = true\n    },\n    DASHED(2, listOf(4.3, 4.3)),\n    DOTTED(3, listOf(1.0, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    DOTDASH(4, listOf(1.0, 3.2, 4.3, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    LONGDASH(5, listOf(7.4, 3.2)),\n    @Suppress(\"SpellCheckingInspection\")\n    TWODASH(6, listOf(2.4, 2.4, 6.4, 2.4));\n\n    override val isSolid: Boolean\n        get() = false\n\n    override val isBlank: Boolean\n        get() = false\n\n    override val dashArray: List<Double>\n        get() {\n            if (!(isSolid || isBlank)) {\n                return myDashArray!!\n            }\n            throw IllegalStateException(\"No dash array in \" + name.lowercase() + \" linetype\")\n        }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AesScaling\n\n\n// redundant `final` in overridden members are necessary due to kotlin-native issue:\n// `Not in vtable error` #2865\n// https://github.com/JetBrains/kotlin-native/issues/2865\nenum class NamedShape(\n    @Suppress(\"RedundantModalityModifier\")\n    final override val code: Int,\n    val isSolid: Boolean = false,\n    val isFilled: Boolean = false,\n    private val isSmall: Boolean = false\n) : PointShape {\n\n    STICK_SQUARE(0),\n    STICK_CIRCLE(1),\n    STICK_TRIANGLE_UP(2),\n    STICK_PLUS(3),\n    STICK_CROSS(4),\n    STICK_DIAMOND(5),\n    STICK_TRIANGLE_DOWN(6),\n    STICK_SQUARE_CROSS(7),\n    STICK_STAR(8),\n    STICK_DIAMOND_PLUS(9),\n    STICK_CIRCLE_PLUS(10),\n    STICK_TRIANGLE_UP_DOWN(11),\n    STICK_SQUARE_PLUS(12),\n    STICK_CIRCLE_CROSS(13),\n    STICK_SQUARE_TRIANGLE_UP(14),\n\n    SOLID_SQUARE(15, true, false),\n    SOLID_CIRCLE(16, true, false),\n    SOLID_TRIANGLE_UP(17, true, false),\n    SOLID_DIAMOND(18, true, false, true),\n\n    SOLID_CIRCLE_2(19, true, false), // same as SOLID_CIRCLE\n    BULLET(20, true, false, true), // same as SOLID_CIRCLE but smaller\n\n    FILLED_CIRCLE(21, false, true),\n    FILLED_SQUARE(22, false, true),\n    FILLED_DIAMOND(23, false, true),\n    FILLED_TRIANGLE_UP(24, false, true),\n    FILLED_TRIANGLE_DOWN(25, false, true);\n\n    val isHollow: Boolean\n        get() = !(isFilled || isSolid)\n\n\n    @Suppress(\"RedundantModalityModifier\")\n    final override fun size(dataPoint: DataPointAesthetics): Double {\n        return if (isSmall)\n            AesScaling.circleDiameterSmaller(dataPoint)\n        else\n            AesScaling.circleDiameter(dataPoint)\n    }\n\n    @Suppress(\"RedundantModalityModifier\")\n    final override fun strokeWidth(dataPoint: DataPointAesthetics): Double {\n        // 'size' aes is used for other purpose and\n        // no 'stroke width' aes (?)\n        return if (isSolid)\n            0.0\n        else\n            1.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsUtil\nimport jetbrains.datalore.plot.base.render.point.NamedShape.*\nimport jetbrains.datalore.plot.base.render.point.symbol.Glyph\nimport jetbrains.datalore.plot.base.render.point.symbol.Glyphs\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimObject\n\nobject PointShapeSvg {\n    fun create(shape: PointShape, location: DoubleVector, p: DataPointAesthetics, fatten: Double = 1.0): SvgSlimObject {\n        if (shape == TinyPointShape) {\n            return createTinyDotShape(\n                location,\n                p\n            )\n        }\n        if (shape is NamedShape) {\n            return createNamedShape(\n                shape,\n                location,\n                p,\n                fatten\n            )\n        }\n        throw IllegalArgumentException(\"Unsupported point shape code ${shape.code} ${shape::class.simpleName}\")\n    }\n\n    private fun createTinyDotShape(location: DoubleVector, p: DataPointAesthetics): SvgSlimObject {\n        val r = SvgSlimElements.rect(location.x - 0.5, location.y - 0.5, 1.0, 1.0)\n        val color = p.color()!!\n        val alpha = AestheticsUtil.alpha(color, p)\n        r.setFill(color, alpha)\n        r.setStrokeWidth(0.0)\n        return r\n    }\n\n    private fun createNamedShape(\n        shape: NamedShape,\n        location: DoubleVector,\n        p: DataPointAesthetics,\n        fatten: Double\n    ): SvgSlimObject {\n        val glyph = createSlimGlyph(\n            shape,\n            location,\n            shape.size(p) * fatten\n        )\n        AestheticsUtil.decorate(glyph, shape.isFilled, shape.isSolid, p, shape.strokeWidth(p))\n        return glyph\n    }\n\n    private fun createSlimGlyph(shape: NamedShape, location: DoubleVector, size: Double): Glyph {\n        when (shape) {\n            STICK_SQUARE, SOLID_SQUARE, FILLED_SQUARE -> return Glyphs.square(location, size)\n\n            STICK_CIRCLE, SOLID_CIRCLE, SOLID_CIRCLE_2     // same as SOLID_CIRCLE\n                , BULLET             // same as SOLID_CIRCLE but smaller\n                , FILLED_CIRCLE -> return Glyphs.circle(location, size)\n\n            STICK_TRIANGLE_UP, SOLID_TRIANGLE_UP, FILLED_TRIANGLE_UP -> return Glyphs.triangleUp(location, size)\n\n            STICK_TRIANGLE_DOWN, FILLED_TRIANGLE_DOWN -> return Glyphs.triangleDown(location, size)\n\n            STICK_DIAMOND, SOLID_DIAMOND, FILLED_DIAMOND -> return Glyphs.diamond(location, size)\n\n            STICK_PLUS -> return Glyphs.stickPlus(location, size)\n            STICK_CROSS -> return Glyphs.stickCross(location, size)\n            STICK_SQUARE_CROSS -> return Glyphs.stickSquareCross(location, size)\n            STICK_STAR -> return Glyphs.stickStar(location, size)\n            STICK_DIAMOND_PLUS -> return Glyphs.stickDiamondPlus(location, size)\n            STICK_CIRCLE_PLUS -> return Glyphs.stickCirclePlus(location, size)\n            STICK_TRIANGLE_UP_DOWN -> return Glyphs.stickTriangleUpDown(location, size)\n            STICK_SQUARE_PLUS -> return Glyphs.stickSquarePlus(location, size)\n            STICK_CIRCLE_CROSS -> return Glyphs.stickCircleCross(location, size)\n            STICK_SQUARE_TRIANGLE_UP -> return Glyphs.stickSquareTriangleUp(location, size)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point\n\nimport jetbrains.datalore.plot.base.DataPointAesthetics\n\nobject TinyPointShape : PointShape {\n\n    override val code: Int\n        get() = 46 // ASCII dot `.`\n\n    override fun size(dataPoint: DataPointAesthetics): Double {\n        return 1.0\n    }\n\n    override fun strokeWidth(dataPoint: DataPointAesthetics): Double {\n        return 0.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nclass CircleGlyph(location: DoubleVector, width: Double) : SingletonGlyph(location, width) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        return SvgSlimElements.circle(location.x, location.y, width / 2)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.cos\n\ninternal class CrossGlyph @JvmOverloads constructor(location: DoubleVector, size: Double, inscribedInCircle: Boolean = true) : TwoShapeGlyph() {\n\n    init {\n        val cx = location.x\n        val cy = location.y\n        val w = if (inscribedInCircle)\n            size * CIRCLE_WIDTH_ADJUST_RATIO\n        else\n            size\n        val half = w / 2 // half width of inner square\n\n        val backSlashLine = SvgSlimElements.line(\n                cx - half,\n                cy - half,\n                cx + half,\n                cy + half)\n        val slashLine = SvgSlimElements.line(\n                cx - half,\n                cy + half,\n                cx + half,\n                cy - half)\n\n        setShapes(backSlashLine, slashLine)\n    }\n\n    companion object {\n        val CIRCLE_WIDTH_ADJUST_RATIO = cos(PI / 4)   // cos(45)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nclass DiamondGlyph(location: DoubleVector, width: Double) : SingletonGlyph(location, width) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        val half = width / 2\n        val x = doubleArrayOf(half, width, half, 0.0)\n        val y = doubleArrayOf(0.0, half, width, half)\n        val ox = location.x - half\n        val oy = location.y - half\n        for (i in 0..3) {\n            x[i] = ox + x[i]\n            y[i] = oy + y[i]\n        }\n\n        val pathData = GlyphUtil.buildPathData(\n            x.asList(),\n            y.asList()\n        )\n        return SvgSlimElements.path(pathData)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\n\ninternal class GlyphPair(private val myG1: Glyph, private val myG2: Glyph) :\n    Glyph {\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        myG1.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n        myG2.update(fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myG1.appendTo(g)\n        myG2.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.vis.svg.SvgPathData\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\n\ninternal object GlyphUtil {\n    fun buildPathData(xs: Collection<Double>, ys: Collection<Double>): SvgPathData {\n        require(xs.size == ys.size) { \"Sizes of X/Y collections must be equal\" }\n\n        if (xs.isEmpty()) {\n            return SvgPathData.EMPTY\n        }\n\n        val builder = SvgPathDataBuilder(true)\n            .moveTo(Iterables[xs, 0], Iterables[ys, 0])\n            .interpolatePoints(xs, ys, SvgPathDataBuilder.Interpolation.LINEAR)\n            .closePath()\n\n        return builder.build()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nobject Glyphs {\n    fun square(location: DoubleVector, width: Double): Glyph {\n        return SquareGlyph(location, width)\n    }\n\n    fun circle(location: DoubleVector, width: Double): Glyph {\n        return CircleGlyph(location, width)\n    }\n\n    fun diamond(location: DoubleVector, width: Double): Glyph {\n        return DiamondGlyph(location, width)\n    }\n\n    fun triangleUp(location: DoubleVector, width: Double): Glyph {\n        return TriangleGlyph(location, width, true)\n    }\n\n    fun triangleDown(location: DoubleVector, width: Double): Glyph {\n        return TriangleGlyph(location, width, false)\n    }\n\n    fun stickPlus(location: DoubleVector, width: Double): Glyph {\n        return PlusGlyph(location, width)\n    }\n\n    fun stickCross(location: DoubleVector, width: Double): Glyph {\n        return CrossGlyph(location, width)\n    }\n\n    fun stickSquareCross(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            CrossGlyph(location, size, false)\n        )\n    }\n\n    fun stickStar(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            PlusGlyph(location, size),\n            CrossGlyph(location, size)\n        )\n    }\n\n    fun stickDiamondPlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            DiamondGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickCirclePlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            CircleGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickTriangleUpDown(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            TriangleGlyph(location, size, true),\n            TriangleGlyph(location, size, false)\n        )\n    }\n\n    fun stickSquarePlus(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            PlusGlyph(location, size)\n        )\n    }\n\n    fun stickCircleCross(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            CircleGlyph(location, size),\n            CrossGlyph(location, size)\n        )\n    }\n\n    fun stickSquareTriangleUp(location: DoubleVector, size: Double): Glyph {\n        return GlyphPair(\n            SquareGlyph(location, size),\n            TriangleGlyph(\n                location,\n                size,\n                true,\n                true\n            )\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal abstract class MultiShapeGlyph : Glyph {\n    protected fun update(shape: SvgSlimShape?, fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        shape?.setFill(fill, fillAlpha)\n        shape?.setStroke(stroke, strokeAlpha)\n        shape?.setStrokeWidth(strokeWidth)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\n\ninternal class PlusGlyph(location: DoubleVector, size: Double) : TwoShapeGlyph() {\n\n    init {\n        val half = size / 2\n        val ox = location.x - half\n        val oy = location.y - half\n        val hLine = SvgSlimElements.line(\n                0 + ox,\n                half + oy,\n                size + ox,\n                half + oy)\n        val vLine = SvgSlimElements.line(\n                half + ox,\n                0 + oy,\n                half + ox,\n                size + oy)\n\n        setShapes(hLine, vLine)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nabstract class SingletonGlyph : Glyph {\n    private val myShape: SvgSlimShape\n\n    protected constructor(shape: SvgSlimShape) {\n        myShape = shape\n    }\n\n    protected constructor(location: DoubleVector, width: Double) {\n        myShape = createShape(location, width)\n    }\n\n    protected abstract fun createShape(location: DoubleVector, width: Double): SvgSlimShape\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        myShape.setFill(fill, fillAlpha)\n        myShape.setStroke(stroke, strokeAlpha)\n        myShape.setStrokeWidth(strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myShape.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal class SquareGlyph(location: DoubleVector, size: Double) : SingletonGlyph(location, size) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        return SvgSlimElements.rect(\n                location.x - width / 2,\n                location.y - width / 2,\n                width,\n                width)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.vis.svg.slim.SvgSlimElements\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.sin\n\ninternal class TriangleGlyph @JvmOverloads constructor(location: DoubleVector, size: Double, pointingUp: Boolean, inscribedInSquare: Boolean = false) : SingletonGlyph(\n    createTriangleShape(\n        location,\n        size,\n        pointingUp,\n        inscribedInSquare\n    )\n) {\n\n    override fun createShape(location: DoubleVector, width: Double): SvgSlimShape {\n        throw IllegalStateException(\"Not applicable\")\n    }\n\n    companion object {\n        // equilateral triangle\n        private val SIDE_TO_HEIGHT_RATIO = sin(PI / 3)\n        private const val VERTICAL_OFFSET_RATIO = 1.0 / 12\n\n        private fun createTriangleShape(\n                location: DoubleVector, size: Double, pointingUp: Boolean, inscribedInSquare: Boolean): SvgSlimShape {\n            val half = size / 2\n            val height = if (inscribedInSquare)\n                size\n            else\n                SIDE_TO_HEIGHT_RATIO * size\n\n            val vOffset = if (inscribedInSquare)\n                0.0\n            else\n                height * VERTICAL_OFFSET_RATIO\n\n            val x: DoubleArray\n            val y: DoubleArray\n            var dy = (size - height) / 2\n            if (pointingUp) {\n                dy -= vOffset\n                x = doubleArrayOf(half, size, 0.0)\n                y = doubleArrayOf(0.0 + dy, height + dy, height + dy)\n            } else {\n                dy += vOffset\n                x = doubleArrayOf(0.0, size, half)\n                y = doubleArrayOf(0.0 + dy, 0.0 + dy, height + dy)\n            }\n\n            val ox = location.x - half\n            val oy = location.y - half\n            for (i in 0..2) {\n                x[i] = ox + x[i]\n                y[i] = oy + y[i]\n            }\n\n            val pathData =\n                GlyphUtil.buildPathData(\n                    x.asList(),\n                    y.asList()\n                )\n            return SvgSlimElements.path(pathData)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.point.symbol\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.slim.SvgSlimGroup\nimport jetbrains.datalore.vis.svg.slim.SvgSlimShape\n\ninternal abstract class TwoShapeGlyph : MultiShapeGlyph() {\n    private var myS1: SvgSlimShape? = null\n    private var myS2: SvgSlimShape? = null\n\n    protected fun setShapes(s1: SvgSlimShape, s2: SvgSlimShape) {\n        myS1 = s1\n        myS2 = s2\n    }\n\n    override fun update(fill: Color, fillAlpha: Double, stroke: Color, strokeAlpha: Double, strokeWidth: Double) {\n        update(myS1, fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n        update(myS2, fill, fillAlpha, stroke, strokeAlpha, strokeWidth)\n    }\n\n    override fun appendTo(g: SvgSlimGroup) {\n        myS1!!.appendTo(g)\n        myS2!!.appendTo(g)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nclass GroupComponent : SvgComponent() {\n    override fun buildComponent() {\n        // empty\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.SvgColors\nimport jetbrains.datalore.vis.svg.SvgPathDataBuilder\nimport jetbrains.datalore.vis.svg.SvgPathElement\n\n/**\n * Poly-line\n */\nclass LinePath(builder: SvgPathDataBuilder) : SvgComponent() {\n\n    private val myPath: SvgPathElement\n    private var myDashArray: List<Double>? = null\n\n    init {\n        myPath = SvgPathElement(builder.build())\n        myPath.fill().set(SvgColors.NONE)\n        val lineWidth = 1.0\n        myPath.strokeWidth().set(lineWidth)\n\n        add(myPath)\n    }\n\n    /*\n  private void build(List<DoubleVector> points, boolean isPolygon) {\n    SvgPathDataBuilder builder = new SvgPathDataBuilder(true);\n\n    List<DoubleVector> curSegment = new ArrayList<>();\n    boolean interpolate = false;\n    for (DoubleVector point : points) {\n      if (point == END_OF_SUBPATH) {\n        buildSegment(builder, curSegment, interpolate);\n        if (isPolygon) {\n          builder.closePath();\n        }\n        curSegment = new ArrayList<>();\n      } else {\n        curSegment.add(point);\n      }\n    }\n    buildSegment(builder, curSegment, interpolate);\n    if (isPolygon) {\n      builder.closePath();\n    }\n\n    myPath = new SvgPathElement(builder.build());\n    myPath.fill().set(SvgColor.NONE);\n    double lineWidth = 1.;\n    myPath.strokeWidth().set(lineWidth);\n\n    add(myPath);\n  }\n  */\n\n    override fun buildComponent() {\n\n    }\n\n    fun color(): WritableProperty<Color?> {\n        return myPath.strokeColor()\n    }\n\n    fun fill(): WritableProperty<Color?> {\n        return myPath.fillColor()\n    }\n\n    fun width(): WritableProperty<Double> {\n        return object : WritableProperty<Double> {\n            override fun set(value: Double) {\n                myPath.strokeWidth().set(value)\n                updatePathDashArray()\n            }\n        }\n    }\n\n    fun dashArray(): WritableProperty<List<Double>> {\n        return object : WritableProperty<List<Double>> {\n            override fun set(value: List<Double>) {\n                myDashArray = ArrayList(value)\n                updatePathDashArray()\n            }\n        }\n    }\n\n    private fun updatePathDashArray() {\n        if (!(myDashArray == null || myDashArray!!.isEmpty())) {\n            val w = myPath.strokeWidth().get()\n            val width = w ?: 1.0\n            StrokeDashArraySupport.apply(\n                myPath,\n                width,\n                myDashArray!!\n            )\n        }\n    }\n\n    companion object {\n        val END_OF_SUBPATH: DoubleVector? = null  // End of Sub Path\n\n        fun line(points: Iterable<DoubleVector>): LinePath {\n            return LinePath(\n                pathBuilder(\n                    points,\n                    false\n                )\n            )\n        }\n\n        fun polygon(points: Iterable<DoubleVector?>): LinePath {\n            return LinePath(\n                pathBuilder(\n                    points,\n                    true\n                )\n            )\n        }\n\n        private fun pathBuilder(points: Iterable<DoubleVector?>, isPolygon: Boolean): SvgPathDataBuilder {\n            val builder = SvgPathDataBuilder(true)\n\n            var curSegment: MutableList<DoubleVector> = ArrayList()\n            val interpolate = false\n            for (point in points) {\n                if (point === END_OF_SUBPATH) {\n                    buildSegment(\n                        builder,\n                        curSegment,\n                        interpolate\n                    )\n                    if (isPolygon) {\n                        builder.closePath()\n                    }\n                    curSegment = ArrayList()\n                } else {\n                    curSegment.add(point!!)\n                }\n            }\n            buildSegment(\n                builder,\n                curSegment,\n                interpolate\n            )\n            if (isPolygon) {\n                builder.closePath()\n            }\n\n            return builder\n        }\n\n        private fun buildSegment(builder: SvgPathDataBuilder, curSegment: List<DoubleVector>, interpolate: Boolean) {\n            if (curSegment.isEmpty()) {\n                return\n            }\n            builder.moveTo(curSegment[0])\n            builder.interpolatePoints(\n                curSegment,\n                if (interpolate) SvgPathDataBuilder.Interpolation.CARDINAL else SvgPathDataBuilder.Interpolation.LINEAR\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.vis.svg.SvgConstants\nimport jetbrains.datalore.vis.svg.SvgElement\n\n/**\n * The counterpart of SVG 'stroke-dasharray' attribute but\n * length of alternating dashes and gaps\n * is defined as multiples of line width\n */\nobject StrokeDashArraySupport {\n    fun apply(element: SvgElement, strokeWidth: Double, dashArray: List<Double>) {\n        val sb = StringBuilder()\n        for (relativeLength in dashArray) {\n            val length = relativeLength * strokeWidth\n            if (sb.length > 0) {\n                sb.append(',')\n            }\n            sb.append(length.toString())\n        }\n        element.getAttribute(SvgConstants.SVG_STROKE_DASHARRAY_ATTRIBUTE).set(sb.toString())\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.vis.svg.*\nimport jetbrains.datalore.vis.svg.SvgGraphicsElement.Companion.CLIP_BOUNDS_JFX\n\nabstract class SvgComponent {\n    private var myIsBuilt: Boolean = false\n    private var myIsBuilding: Boolean = false\n    private val myRootGroup = SvgGElement()\n    private val myChildComponents = ArrayList<SvgComponent>()\n    private var myOrigin = DoubleVector.ZERO\n    private var myRotationAngle = 0.0\n    private var myCompositeRegistration = CompositeRegistration()\n\n    protected val childComponents: List<SvgComponent>\n        get() {\n            require(myIsBuilt) { \"Plot has not yet built\" }\n            return ArrayList(myChildComponents)\n        }\n\n    val rootGroup: SvgGElement\n        get() {\n            ensureBuilt()\n            return myRootGroup\n        }\n\n    fun ensureBuilt() {\n        if (!(myIsBuilt || myIsBuilding)) {\n            buildComponentIntern()\n        }\n    }\n\n    private fun buildComponentIntern() {\n        try {\n            myIsBuilding = true\n            buildComponent()\n        } finally {\n            myIsBuilding = false\n            myIsBuilt = true\n        }\n    }\n\n    protected abstract fun buildComponent()\n\n    protected fun <EventT> rebuildHandler(): EventHandler<EventT> {\n        return object : EventHandler<EventT> {\n            override fun onEvent(event: EventT) {\n                needRebuild()\n            }\n        }\n    }\n\n    protected fun needRebuild() {\n        if (myIsBuilt) {\n            clear()\n            buildComponentIntern()\n        }\n    }\n\n    protected fun reg(r: Registration) {\n        myCompositeRegistration.add(r)\n    }\n\n    fun clear() {\n        myIsBuilt = false\n        for (child in myChildComponents) {\n            child.clear()\n        }\n        myChildComponents.clear()\n        myRootGroup.children().clear()\n        myCompositeRegistration.remove()\n        myCompositeRegistration = CompositeRegistration()\n    }\n\n    fun add(child: SvgComponent) {\n        myChildComponents.add(child)\n        add(child.rootGroup)\n    }\n\n    fun add(node: SvgNode) {\n        myRootGroup.children().add(node)\n    }\n\n    fun moveTo(p: DoubleVector) {\n        myOrigin = p\n        myRootGroup.transform().set(\n            buildTransform(\n                myOrigin,\n                myRotationAngle\n            )\n        )\n    }\n\n    fun moveTo(x: Double, y: Double) {\n        moveTo(DoubleVector(x, y))\n    }\n\n    /**\n     * @param angle in degrees\n     */\n    fun rotate(angle: Double) {\n        myRotationAngle = angle\n        myRootGroup.transform().set(\n            buildTransform(\n                myOrigin,\n                myRotationAngle\n            )\n        )\n    }\n\n    fun toRelativeCoordinates(location: DoubleVector): DoubleVector {\n        return rootGroup.pointToTransformedCoordinates(location)\n    }\n\n    fun toAbsoluteCoordinates(location: DoubleVector): DoubleVector {\n        return rootGroup.pointToAbsoluteCoordinates(location)\n    }\n\n    fun clipBounds(rect: DoubleRectangle) {\n        val clipPathElement = SvgClipPathElement().apply {\n            id().set(SvgUID.get(CLIP_PATH_ID_PREFIX))\n            children().add(SvgRectElement().apply {\n                x().set(rect.left)\n                y().set(rect.top)\n                width().set(rect.width)\n                height().set(rect.height)\n            }\n            )\n        }\n        val defs = SvgDefsElement().apply {\n            children().add(clipPathElement)\n        }\n        add(defs)\n\n        rootGroup.clipPath().set(SvgIRI(clipPathElement.id().get()!!))\n        rootGroup.setAttribute(CLIP_BOUNDS_JFX, rect) // JFX workaround\n    }\n\n    fun addClassName(className: String) {\n        myRootGroup.addClass(className)\n    }\n\n    companion object {\n        const val CLIP_PATH_ID_PREFIX = \"\" // No prefix\n\n        fun buildTransform(origin: DoubleVector, rotationAngle: Double): SvgTransform {\n            val transformBuilder = SvgTransformBuilder()\n            if (origin != DoubleVector.ZERO) {\n                transformBuilder.translate(origin.x, origin.y)\n            }\n            if (rotationAngle != 0.0) {\n                transformBuilder.rotate(rotationAngle)\n            }\n            return transformBuilder.build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.random.RandomString.randomString\nimport kotlin.native.concurrent.ThreadLocal\n\n// In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n// See:  https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n// Required mutations:\n//      -   `suffixGen`\n@ThreadLocal\nobject SvgUID {\n    private var suffixGen: () -> Any = { randomString(6) }\n\n    fun setUpForTest() {\n        val incrementalId = IncrementalId()\n        suffixGen = { incrementalId.next() }\n    }\n\n    fun get(prefix: String): String {\n        return \"$prefix${suffixGen()}\"\n    }\n\n    private class IncrementalId {\n        private var nextIndex = 0\n        fun next() = (\"clip-${nextIndex++}\")\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.render.svg\n\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.vis.svg.SvgConstants\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_STYLE_ATTRIBUTE\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_ANCHOR_END\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_ANCHOR_MIDDLE\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_DY_CENTER\nimport jetbrains.datalore.vis.svg.SvgConstants.SVG_TEXT_DY_TOP\nimport jetbrains.datalore.vis.svg.SvgTextElement\n\nclass TextLabel(text: String) : SvgComponent() {\n    private val myText: SvgTextElement = SvgTextElement(text)\n    private var myTextColor: Color? = null\n    private var myFontSize = 0.0\n    private var myFontWeight: String? = null\n    private var myFontFamily: String? = null\n    private var myFontStyle: String? = null\n\n    init {\n        rootGroup.children().add(myText)\n    }\n\n    override fun buildComponent() {\n\n    }\n\n    fun textColor(): WritableProperty<Color?> {\n        return object : WritableProperty<Color?> {\n            override fun set(value: Color?) {\n                // set attribute for svg->canvas mapping to work\n                myText.fillColor()\n\n                // duplicate in 'style' to override styles of container\n                myTextColor = value\n                updateStyleAttribute()\n            }\n        }\n    }\n\n    fun textOpacity(): WritableProperty<Double?> {\n        return myText.fillOpacity()\n    }\n\n    fun x(): Property<Double?> {\n        return myText.x()\n    }\n\n    fun y(): Property<Double?> {\n        return myText.y()\n    }\n\n    fun setHorizontalAnchor(anchor: HorizontalAnchor) {\n        myText.setAttribute(SvgConstants.SVG_TEXT_ANCHOR_ATTRIBUTE, toTextAnchor(anchor))\n    }\n\n    fun setVerticalAnchor(anchor: VerticalAnchor) {\n        // replace \"dominant-baseline\" with \"dy\" because \"dominant-baseline\" is not supported by Batik\n        //    myText.setAttribute(\"dominant-baseline\", toDominantBaseline(anchor));\n        myText.setAttribute(SvgConstants.SVG_TEXT_DY_ATTRIBUTE, toDY(anchor))\n    }\n\n    fun setFontSize(px: Double) {\n        myFontSize = px\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param cssName : normal, bold, bolder, lighter\n     */\n    fun setFontWeight(cssName: String?) {\n        myFontWeight = cssName\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param cssName : normal, italic, oblique\n     */\n    fun setFontStyle(cssName: String?) {\n        myFontStyle = cssName\n        updateStyleAttribute()\n    }\n\n    /**\n     * @param fontFamily : for example 'sans-serif' or 'Times New Roman'\n     */\n    fun setFontFamily(fontFamily: String?) {\n        myFontFamily = fontFamily\n        updateStyleAttribute()\n    }\n\n    private fun updateStyleAttribute() {\n        val sb = StringBuilder()\n        if (myTextColor != null) {\n            sb.append(\"fill:\").append(myTextColor!!.toHexColor()).append(';')\n        }\n\n        if (myFontSize > 0 && myFontFamily != null) {\n            // use font shorthand because this format is expected by svg -> canvas mapper\n            // font: [style] [weight] size family;\n            val fnt = StringBuilder()\n            if (!myFontStyle.isNullOrEmpty()) {\n                fnt.append(myFontStyle!!).append(' ')\n            }\n            if (!myFontWeight.isNullOrEmpty()) {\n                fnt.append(myFontWeight!!).append(' ')\n            }\n            fnt.append(myFontSize).append(\"px \")\n            fnt.append(myFontFamily!!).append(\";\")\n\n            sb.append(\"font:\").append(fnt)\n        } else {\n            // set each property separately\n            if (!myFontStyle.isNullOrBlank()) {\n                sb.append(\"font-style:\").append(myFontStyle!!).append(';')\n            }\n            if (!myFontWeight.isNullOrEmpty()) {\n                sb.append(\"font-weight:\").append(myFontWeight!!).append(';')\n            }\n            if (myFontSize > 0) {\n                sb.append(\"font-size:\").append(myFontSize).append(\"px;\")\n            }\n            if (!myFontFamily.isNullOrEmpty()) {\n                sb.append(\"font-family:\").append(myFontFamily!!).append(';')\n            }\n        }\n\n        myText.setAttribute(SVG_STYLE_ATTRIBUTE, sb.toString())\n    }\n\n    private fun toTextAnchor(anchor: HorizontalAnchor): String? {\n        return when (anchor) {\n            HorizontalAnchor.LEFT -> null // default - \"start\";\n            HorizontalAnchor.MIDDLE -> SVG_TEXT_ANCHOR_MIDDLE\n            HorizontalAnchor.RIGHT -> SVG_TEXT_ANCHOR_END\n        }\n    }\n\n    private fun toDominantBaseline(anchor: VerticalAnchor): String? {\n        return when (anchor) {\n            VerticalAnchor.TOP -> \"hanging\"\n            VerticalAnchor.CENTER -> \"central\"\n            VerticalAnchor.BOTTOM -> null // default - \"alphabetic\";\n        }\n    }\n\n    private fun toDY(anchor: VerticalAnchor): String? {\n        return when (anchor) {\n            VerticalAnchor.TOP -> SVG_TEXT_DY_TOP\n            VerticalAnchor.CENTER -> SVG_TEXT_DY_CENTER\n            VerticalAnchor.BOTTOM -> null // default\n        }\n    }\n\n    enum class HorizontalAnchor {\n        LEFT, RIGHT, MIDDLE\n    }\n\n    enum class VerticalAnchor {\n        TOP, BOTTOM, CENTER\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.Scale\n\ninternal abstract class AbstractScale<DomainT, T> : Scale<T> {\n\n    private val definedBreaks: List<DomainT>?\n    private val definedLabels: List<String>?\n\n    final override val name: String\n    final override val mapper: ((Double?) -> T?)\n    final override var multiplicativeExpand = 0.0\n        protected set\n    final override var additiveExpand = 0.0\n        protected set\n    final override val labelFormatter: ((Any) -> String)?\n\n    override val isContinuous: Boolean\n        get() = false\n\n    override val isContinuousDomain: Boolean\n        get() = false\n\n    protected constructor(name: String, mapper: ((Double?) -> T?), breaks: List<DomainT>? = null) {\n        this.name = name\n        this.mapper = mapper\n        this.definedBreaks = breaks\n        definedLabels = null\n        labelFormatter = null\n    }\n\n    protected constructor(b: AbstractBuilder<DomainT, T>) {\n        name = b.myName\n        definedBreaks = b.myBreaks\n        definedLabels = b.myLabels\n        labelFormatter = b.myLabelFormatter\n        mapper = b.myMapper\n\n        multiplicativeExpand = b.myMultiplicativeExpand\n        additiveExpand = b.myAdditiveExpand\n    }\n\n    override fun hasBreaks(): Boolean {\n        return definedBreaks != null\n    }\n\n    protected open fun getBreaksIntern(): List<Any> {\n        check(hasBreaks()) { \"No breaks defined for scale $name\" }\n        @Suppress(\"UNCHECKED_CAST\")\n        return definedBreaks as List<Any>\n    }\n\n    protected open fun getLabelsIntern(): List<String> {\n        check(definedLabels != null) { \"No labels defined for scale $name\" }\n        return definedLabels\n    }\n\n    override fun applyTransform(source: List<*>, checkLimits: Boolean): List<Double?> {\n        @Suppress(\"NAME_SHADOWING\")\n        var source: List<Any?> = source\n\n        // Replace values outside 'scale limits' with null-s.\n        if (checkLimits && hasDomainLimits()) {\n            source = source.map { if (it == null || isInDomainLimits(it)) it else null }\n        }\n\n        // Replace values outside of domain of 'continuous transform' with null-s.\n        if (transform is ContinuousTransform) {\n            val continuousTransform = transform as ContinuousTransform\n            if (continuousTransform.hasDomainLimits()) {\n                source = source.map { if (continuousTransform.isInDomain(it as Double?)) it else null }\n            }\n        }\n\n        return transform.apply(source)\n    }\n\n    override fun getScaleBreaks(): ScaleBreaks {\n        if (!hasBreaks()) {\n            return ScaleBreaks.EMPTY\n        }\n\n        val breakValuesIntern = getBreaksIntern()\n        val labels = getLabels(breakValuesIntern)\n        val transformed = applyTransform(breakValuesIntern, checkLimits = false)\n\n        // drop NULLs which can occure after transform.\n        val keepIndices: Set<Int> = transformed\n            .mapIndexed { i, v -> if (v == null) null else i }\n            .filterNotNull()\n            .toSet()\n\n        return ScaleBreaks(\n            domainValues = breakValuesIntern.filterIndexed { i, _ -> i in keepIndices },\n            transformedValues = transformed.filterNotNull(),\n            labels = labels.filterIndexed { i, _ -> i in keepIndices }\n        )\n    }\n\n    private fun getLabels(breaks: List<Any>): List<String> {\n        if (definedLabels != null) {\n            val labels = getLabelsIntern()\n            return when {\n                labels.isEmpty() -> List(breaks.size) { \"\" }\n                breaks.size <= labels.size -> labels.subList(0, breaks.size)\n                else -> List(breaks.size) { i -> labels[i % labels.size] }\n            }\n        }\n\n        // generate labels\n        val formatter: (Any) -> String = labelFormatter ?: { v: Any -> v.toString() }\n        return breaks.map { formatter(it) }\n    }\n\n    protected abstract class AbstractBuilder<DomainT, T>(scale: AbstractScale<DomainT, T>) : Scale.Builder<T> {\n        internal val myName: String = scale.name\n\n        internal var myBreaks: List<DomainT>? = scale.definedBreaks\n        internal var myLabels: List<String>? = scale.definedLabels\n        internal var myLabelFormatter: ((Any) -> String)? = scale.labelFormatter\n        internal var myMapper: (Double?) -> T? = scale.mapper\n\n        internal var myMultiplicativeExpand: Double = scale.multiplicativeExpand\n        internal var myAdditiveExpand: Double = scale.additiveExpand\n\n        override fun breaks(l: List<Any>): Scale.Builder<T> {\n            myBreaks = l.map {\n                @Suppress(\"UNCHECKED_CAST\")\n                it as DomainT\n            }\n            return this\n        }\n\n        override fun labels(l: List<String>): Scale.Builder<T> {\n            myLabels = l\n            return this\n        }\n\n        override fun labelFormatter(v: (Any) -> String): Scale.Builder<T> {\n            myLabelFormatter = v\n            return this\n        }\n\n        override fun mapper(m: (Double?) -> T?): Scale.Builder<T> {\n            myMapper = m\n            return this\n        }\n\n        override fun multiplicativeExpand(v: Double): Scale.Builder<T> {\n            myMultiplicativeExpand = v\n            return this\n        }\n\n        override fun additiveExpand(v: Double): Scale.Builder<T> {\n            myAdditiveExpand = v\n            return this\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\nimport jetbrains.datalore.plot.base.scale.transform.Transforms\nimport jetbrains.datalore.plot.base.scale.transform.Transforms.createBreaksGeneratorForTransformedDomain\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\ninternal class ContinuousScale<T> : AbstractScale<Double, T> {\n\n    private val continuousTransform: ContinuousTransform\n    private val customBreaksGenerator: BreaksGenerator?\n\n    override val isContinuous: Boolean\n    override val isContinuousDomain: Boolean = true\n    val continuousDomainLimits: Pair<Double, Double>\n\n    override val transform: Transform\n        get() = continuousTransform\n\n    constructor(\n        name: String,\n        mapper: ((Double?) -> T?),\n        continuousOutput: Boolean\n    ) : super(name, mapper) {\n        isContinuous = continuousOutput\n        continuousDomainLimits = Pair(Double.NEGATIVE_INFINITY, Double.POSITIVE_INFINITY)\n        continuousTransform = Transforms.IDENTITY\n        customBreaksGenerator = null\n\n        // see: https://ggplot2.tidyverse.org/reference/scale_continuous.html\n        // defaults for continuous scale.\n        multiplicativeExpand = 0.05\n        additiveExpand = 0.0\n    }\n\n    private constructor(b: MyBuilder<T>) : super(b) {\n        continuousTransform = b.myContinuousTransform\n        customBreaksGenerator = b.myCustomBreaksGenerator\n        isContinuous = b.myContinuousOutput\n        val lower = if (SeriesUtil.isFinite(b.myLowerLimit)) b.myLowerLimit!! else Double.NEGATIVE_INFINITY\n        val upper = if (SeriesUtil.isFinite(b.myUpperLimit)) b.myUpperLimit!! else Double.POSITIVE_INFINITY\n        continuousDomainLimits = Pair(\n            min(lower, upper),\n            max(lower, upper)\n        )\n    }\n\n    override fun getBreaksGenerator(): BreaksGenerator {\n        return if (customBreaksGenerator != null) {\n            Transforms.BreaksGeneratorForTransformedDomain(continuousTransform, customBreaksGenerator)\n        } else {\n            createBreaksGeneratorForTransformedDomain(continuousTransform, labelFormatter)\n        }\n    }\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        return if (v is Number) {\n            val d = v.toDouble()\n            d.isFinite() && d >= continuousDomainLimits.first && d <= continuousDomainLimits.second\n        } else {\n            false\n        }\n    }\n\n    override fun hasDomainLimits(): Boolean {\n        return continuousDomainLimits.first.isFinite() || continuousDomainLimits.second.isFinite()\n    }\n\n    override fun with(): Scale.Builder<T> {\n        return MyBuilder(this)\n    }\n\n\n    private class MyBuilder<T>(scale: ContinuousScale<T>) : AbstractBuilder<Double, T>(scale) {\n        var myContinuousTransform: ContinuousTransform = scale.continuousTransform\n        var myCustomBreaksGenerator: BreaksGenerator? = scale.customBreaksGenerator\n        var myLowerLimit: Double? = scale.continuousDomainLimits.first\n        var myUpperLimit: Double? = scale.continuousDomainLimits.second\n\n        val myContinuousOutput: Boolean = scale.isContinuous\n\n        override fun lowerLimit(v: Double): Scale.Builder<T> {\n            require(v.isFinite()) { \"`lower` can't be $v\" }\n            myLowerLimit = v\n            return this\n        }\n\n        override fun upperLimit(v: Double): Scale.Builder<T> {\n            require(v.isFinite()) { \"`upper` can't be $v\" }\n            myUpperLimit = v\n            return this\n        }\n\n        override fun limits(domainValues: List<Any>): Scale.Builder<T> {\n            throw IllegalArgumentException(\"Can't apply discrete limits to scale with continuous domain\")\n        }\n\n        override fun continuousTransform(v: ContinuousTransform): Scale.Builder<T> {\n            myContinuousTransform = v\n            return this\n        }\n\n        override fun breaksGenerator(v: BreaksGenerator): Scale.Builder<T> {\n            myCustomBreaksGenerator = v\n            return this\n        }\n\n        override fun build(): Scale<T> {\n            return ContinuousScale(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.DiscreteTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\n\ninternal class DiscreteScale<T> : AbstractScale<Any, T> {\n\n    private val discreteTransform: DiscreteTransform\n\n    override val transform: Transform\n        get() = discreteTransform\n\n    constructor(\n        name: String,\n        domainValues: Collection<Any>,\n        mapper: ((Double?) -> T?)\n    ) : super(name, mapper, breaks = domainValues.toList()) {\n        discreteTransform = DiscreteTransform(domainValues, emptyList())\n\n        // see: https://ggplot2.tidyverse.org/reference/scale_continuous.html\n        // defaults for discrete scale.\n        multiplicativeExpand = 0.0\n        additiveExpand = 0.6\n    }\n\n    private constructor(b: MyBuilder<T>) : super(b) {\n        discreteTransform = DiscreteTransform(b.myDomainValues, b.myDomainLimits)\n    }\n\n    override fun getBreaksGenerator(): BreaksGenerator {\n        throw IllegalStateException(\"No breaks generator for discrete scale '$name'\")\n    }\n\n    override fun hasDomainLimits(): Boolean {\n        return discreteTransform.hasDomainLimits()\n    }\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        return discreteTransform.isInDomain(v)\n    }\n\n    protected override fun getBreaksIntern(): List<Any> {\n        return if (!hasDomainLimits()) {\n            super.getBreaksIntern()\n        } else {\n            // Filter and preserve the order defined by limits.\n            val breaksSet = super.getBreaksIntern().toSet()\n            discreteTransform.domainLimits.filter { it in breaksSet }\n        }\n    }\n\n    override fun getLabelsIntern(): List<String> {\n        val labels = super.getLabelsIntern()\n        return if (!hasDomainLimits() || labels.isEmpty()) {\n            labels\n        } else {\n            val breaks = super.getBreaksIntern()\n            val breakLabels = breaks.mapIndexed { i, _ -> labels[i % labels.size] }\n\n            // Filter and preserve the order defined by limits.\n            val labelByBreak = breaks.zip(breakLabels).toMap()\n            discreteTransform.domainLimits\n                .filter { labelByBreak.containsKey(it) }\n                .map { labelByBreak.getValue(it) }\n        }\n    }\n\n    override fun with(): Scale.Builder<T> {\n        return MyBuilder(this)\n    }\n\n    private class MyBuilder<T>(scale: DiscreteScale<T>) : AbstractBuilder<Any, T>(scale) {\n        internal val myDomainValues: Collection<Any> = scale.discreteTransform.domainValues\n        internal var myDomainLimits: List<Any> = scale.discreteTransform.domainLimits\n\n        override fun breaksGenerator(v: BreaksGenerator): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun lowerLimit(v: Double): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun upperLimit(v: Double): Scale.Builder<T> {\n            throw IllegalStateException(\"Not applicable to scale with discrete domain\")\n        }\n\n        override fun limits(domainValues: List<Any>): Scale.Builder<T> {\n            myDomainLimits = domainValues\n            return this\n        }\n\n        override fun continuousTransform(v: ContinuousTransform): Scale.Builder<T> {\n            // ignore\n            return this\n        }\n\n        override fun build(): Scale<T> {\n            return DiscreteScale(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject MapperUtil {\n    fun map(r: ClosedRange<Double>, mapper: (Double?) -> Double?): ClosedRange<Double> {\n        val a = mapper(r.lowerEnd)!!\n        val b = mapper(r.upperEnd)!!\n        return ClosedRange(min(a, b), max(a, b))\n    }\n\n    fun mapDiscreteDomainValuesToNumbers(values: Collection<*>): Map<Any, Double> {\n        return mapDiscreteDomainValuesToIndices(values)\n    }\n\n    private fun mapDiscreteDomainValuesToIndices(values: Collection<*>): Map<Any, Double> {\n        val result = LinkedHashMap<Any, Double>()\n        var index = 0\n        for (v in values) {\n            if (v != null && !result.containsKey(v)) {\n                result[v] = index++.toDouble()\n            }\n        }\n        return result\n    }\n\n    fun rangeWithLimitsAfterTransform(\n        dataRange: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): ClosedRange<Double> {\n        val lower = if (lowerLimit != null && lowerLimit.isFinite()) {\n            lowerLimit\n        } else {\n            dataRange.lowerEnd\n        }\n        check(trans.isInDomain(lower)) {\n            \"[${trans::class.simpleName}] Lower end $lower is outside of transform's domain.\"\n        }\n\n        val upper = if (upperLimit != null && upperLimit.isFinite()) {\n            upperLimit\n        } else {\n            dataRange.upperEnd\n        }\n        check(trans.isInDomain(upper)) {\n            \"[${trans::class.simpleName}] Lower end $upper is outside of transform's domain.\"\n        }\n\n        val limits = listOf(lower, upper)\n        return ClosedRange.encloseAll(trans.apply(limits))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.function.Function\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.breaks.QuantizeScale\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.round\n\nobject Mappers {\n    val IDENTITY = { v: Double? -> v }\n\n    fun <T> undefined(): (Double?) -> T = { throw IllegalStateException(\"Undefined mapper\") }\n\n    fun <T> nullable(f: (Double?) -> T, ifNull: T): (Double?) -> T {\n        return { n ->\n            if (n == null) {\n                ifNull\n            } else {\n                f(n)\n            }\n        }\n    }\n\n    fun constant(v: Double): (Double?) -> Double = { v }\n\n    fun mul(domain: ClosedRange<Double>, rangeSpan: Double): (Double?) -> Double? {\n        val factor = rangeSpan / (domain.upperEnd - domain.lowerEnd)\n        check(!(factor.isInfinite() || factor.isNaN())) { \"Can't create mapper with ratio: $factor\" }\n        return mul(factor)\n    }\n\n    fun mul(factor: Double): (Double?) -> Double? {\n        return { v ->\n            if (v != null) {\n                factor * v\n            } else null\n        }\n    }\n\n    fun linear(domain: ClosedRange<Double>, range: ClosedRange<Double>, reverse: Boolean = false): (Double?) -> Double {\n        return linear(\n            domain,\n            rangeLow = if (reverse) range.upperEnd else range.lowerEnd,\n            rangeHigh = if (reverse) range.lowerEnd else range.upperEnd,\n            Double.NaN\n        )\n    }\n\n    fun linear(domain: ClosedRange<Double>, range: ClosedRange<Double>, defaultValue: Double): (Double?) -> Double {\n        return linear(\n            domain,\n            range.lowerEnd,\n            range.upperEnd,\n            defaultValue\n        )\n    }\n\n    fun linear(\n        domain: ClosedRange<Double>,\n        rangeLow: Double,\n        rangeHigh: Double,\n        defaultValue: Double\n    ): (Double?) -> Double {\n        val slop = (rangeHigh - rangeLow) / (domain.upperEnd - domain.lowerEnd)\n        if (!SeriesUtil.isFinite(slop)) {\n            // no slop\n            val v = (rangeHigh - rangeLow) / 2 + rangeLow\n            return constant(v)\n        }\n        val intersect = rangeLow - domain.lowerEnd * slop\n        return { input ->\n            if (SeriesUtil.isFinite(input))\n                input!! * slop + intersect\n            else\n                defaultValue\n        }\n    }\n\n    fun discreteToContinuous(\n        domainValues: Collection<*>,\n        outputRange: ClosedRange<Double>,\n        naValue: Double\n    ): (Double?) -> Double? {\n        val numberByDomainValue =\n            MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val dataRange = SeriesUtil.range(numberByDomainValue.values) ?: return IDENTITY\n        return linear(dataRange, outputRange, naValue)\n    }\n\n    fun <T> discrete(outputValues: List<T?>, defaultOutputValue: T): (Double?) -> T? {\n        val f = DiscreteFun(outputValues, defaultOutputValue)\n        return { f.apply(it) }\n    }\n\n    fun <T> quantized(\n        domain: ClosedRange<Double>?,\n        outputValues: Collection<T>,\n        defaultOutputValue: T\n    ): (Double?) -> T {\n        if (domain == null) {\n            return { defaultOutputValue }\n        }\n\n        // todo: extract quantizer\n        val quantizer = QuantizeScale<T>()\n        quantizer.domain(domain.lowerEnd, domain.upperEnd)\n        quantizer.range(outputValues)\n\n        val f = QuantizedFun(quantizer, defaultOutputValue)\n        return { f.apply(it) }\n    }\n\n    private class DiscreteFun<T>(\n        private val myOutputValues: List<T?>,\n        private val myDefaultOutputValue: T\n    ) : Function<Double?, T?> {\n\n        override fun apply(value: Double?): T? {\n            if (!SeriesUtil.isFinite(value)) {\n                return myDefaultOutputValue\n            }\n            // ToDo: index-based discrete fun won't work for discrete numeric onput (see: MapperUtil#mapDiscreteDomainValuesToNumbers())\n            var index = round(value!!).toInt()\n            index %= myOutputValues.size\n            if (index < 0) {\n                index += myOutputValues.size\n            }\n            return myOutputValues[index]\n        }\n    }\n\n    private class QuantizedFun<T> internal constructor(\n        private val myQuantizer: QuantizeScale<T>,\n        private val myDefaultOutputValue: T\n    ) : Function<Double?, T> {\n        override fun apply(value: Double?): T {\n            return if (!SeriesUtil.isFinite(value)) myDefaultOutputValue else myQuantizer.quantize(value!!)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nclass ScaleBreaks(\n    val domainValues: List<Any>,\n    val transformedValues: List<Double>,\n    val labels: List<String>\n) {\n    val isEmpty: Boolean\n        get() = domainValues.isEmpty()\n\n    val size: Int\n        get() = domainValues.size\n\n    init {\n        require(domainValues.size == transformedValues.size) {\n            \"Scale breaks size: ${domainValues.size} transformed size: ${transformedValues.size} but expected to be the same\"\n        }\n        require(domainValues.size == labels.size) {\n            \"Scale breaks size: ${domainValues.size} labels size: ${labels.size} but expected to be the same\"\n        }\n    }\n\n    companion object {\n        val EMPTY: ScaleBreaks = ScaleBreaks(emptyList(), emptyList(), emptyList())\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ScaleUtil {\n\n    fun labelByBreak(scale: Scale<*>): Map<Any, String> {\n        val scaleBreaks = scale.getScaleBreaks()\n        return scaleBreaks.domainValues.zip(scaleBreaks.labels).toMap()\n    }\n\n    fun map(range: ClosedRange<Double>, scale: Scale<Double>): ClosedRange<Double> {\n        return MapperUtil.map(range, scale.mapper)\n    }\n\n    fun <T> map(l: List<Double?>, scale: Scale<T>): List<T?> {\n        val mapper = scale.mapper\n        return l.map {\n            mapper(it)\n        }\n    }\n\n    fun inverseTransformToContinuousDomain(l: List<Double?>, scale: Scale<*>): List<Double?> {\n        check(scale.isContinuousDomain) { \"Not continuous numeric domain: $scale\" }\n        return (scale.transform as ContinuousTransform).applyInverse(l)\n    }\n\n    fun inverseTransform(l: List<Double?>, scale: Scale<*>): List<*> {\n        val transform = scale.transform\n        return if (transform is ContinuousTransform) {\n            transform.applyInverse(l)\n        } else {\n            l.map { transform.applyInverse(it) }\n        }\n    }\n\n    fun transformedDefinedLimits(scale: Scale<*>): Pair<Double, Double> {\n        scale as ContinuousScale\n        val (lower, upper) = scale.continuousDomainLimits\n        val transform = scale.transform as ContinuousTransform\n        val (transformedLower, transformedUpper) = Pair(\n            if (transform.isInDomain(lower)) transform.apply(lower)!! else Double.NaN,\n            if (transform.isInDomain(upper)) transform.apply(upper)!! else Double.NaN\n        )\n\n        return if (SeriesUtil.allFinite(transformedLower, transformedUpper)) {\n            Pair(\n                min(transformedLower, transformedUpper),\n                max(transformedLower, transformedUpper)\n            )\n        } else {\n            Pair(transformedLower, transformedUpper)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\nobject Scales {\n    fun <T> continuousDomain(\n        name: String,\n        aes: Aes<T>\n    ): Scale<T> {\n        return ContinuousScale<T>(\n            name,\n            Mappers.undefined(),\n            aes.isNumeric\n        )\n    }\n\n    fun continuousDomainNumericRange(\n        name: String\n    ): Scale<Double> {\n        return ContinuousScale<Double>(\n            name,\n            Mappers.undefined(),\n            true\n        )\n    }\n\n    fun <T> continuousDomain(\n        name: String,\n        mapper: (Double?) -> T?,\n        continuousRange: Boolean\n    ): Scale<T> {\n        return ContinuousScale<T>(name, mapper, continuousRange)\n    }\n\n    fun <T> discreteDomain(name: String, domainValues: Collection<Any>): Scale<T> {\n        return discreteDomain(\n            name,\n            domainValues,\n            Mappers.undefined()\n        )\n    }\n\n    fun <T> discreteDomain(name: String, domainValues: Collection<Any>, mapper: ((Double?) -> T?)): Scale<T> {\n        return DiscreteScale(name, domainValues, mapper)\n    }\n\n    fun <T> pureDiscrete(\n        name: String,\n        domainValues: List<Any>,\n        outputValues: List<T>,\n        defaultOutputValue: T\n    ): Scale<T> {\n        return discreteDomain<T>(name, domainValues)\n            .with()\n            .mapper(Mappers.discrete(outputValues, defaultOutputValue))\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nabstract class BreaksHelperBase(\n    start: Double,\n    end: Double,\n    targetCount: Int\n) {\n    abstract val breaks: List<Double>\n\n    protected val normalStart: Double\n    protected val normalEnd: Double\n    protected val span: Double\n    protected val targetStep: Double\n    protected val isReversed: Boolean\n\n    init {\n        require(start.isFinite()) { \"range start $start\" }\n        require(end.isFinite()) { \"range end $end\" }\n        require(targetCount > 0) { \"'count' must be positive: $targetCount\" }\n        var span = end - start\n        var reversed = false\n        if (span < 0) {\n            span = -span\n            reversed = true\n        }\n\n        this.span = span\n        targetStep = this.span / targetCount\n        isReversed = reversed\n        normalStart = if (reversed) end else start\n        normalEnd = if (reversed) start else end\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.plot.common.time.TimeUtil\nimport jetbrains.datalore.plot.common.time.interval.NiceTimeInterval\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\nimport jetbrains.datalore.plot.common.time.interval.YearInterval\nimport kotlin.math.round\n\nclass DateTimeBreaksHelper(\n    rangeStart: Double,\n    rangeEnd: Double,\n    count: Int,\n    minInterval: TimeInterval? = null\n) : BreaksHelperBase(rangeStart, rangeEnd, count) {\n\n    override val breaks: List<Double>\n    val formatter: (Any) -> String\n\n    init {\n\n        val step = targetStep\n        if (step < 1000) {        // milliseconds\n            formatter = TimeScaleTickFormatterFactory(minInterval).getFormatter(step)\n            // compute step so that it is multiple of automatic time steps\n            breaks = LinearBreaksHelper(rangeStart, rangeEnd, count).breaks\n\n        } else {\n\n            val start = normalStart\n            val end = normalEnd\n\n            var ticks: MutableList<Double>? = null\n            if (minInterval != null) {\n                ticks = minInterval.range(start, end).toMutableList()\n            }\n\n            if (ticks != null && ticks.size <= count) {\n                // same or smaller interval requested -> stay with min interval\n                formatter = minInterval!!.tickFormatter\n                // otherwise - larger step requested -> compute ticks\n            } else if (step > YearInterval.MS) {        // years\n                formatter = YearInterval.TICK_FORMATTER\n                ticks = ArrayList()\n                val startDateTime = TimeUtil.asDateTimeUTC(start)\n                var startYear = startDateTime.year\n                if (startDateTime.isAfter(TimeUtil.yearStart(startYear))) {\n                    startYear++\n                }\n                val endYear = TimeUtil.asDateTimeUTC(end).year\n                val helper = LinearBreaksHelper(\n                    startYear.toDouble(),\n                    endYear.toDouble(),\n                    count\n                )\n                for (tickYear in helper.breaks) {\n                    val tickDate = TimeUtil.yearStart(round(tickYear).toInt())\n                    ticks.add(TimeUtil.asInstantUTC(tickDate).toDouble())\n                }\n            } else {\n                val interval = NiceTimeInterval.forMillis(step)\n                formatter = interval.tickFormatter\n                ticks = interval.range(start, end).toMutableList()\n            }\n\n            if (isReversed) {\n                ticks.reverse()\n            }\n            breaks = ticks\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport kotlin.math.*\n\nclass LinearBreaksHelper(\n    rangeStart: Double,\n    rangeEnd: Double,\n    count: Int,\n    precise: Boolean = false\n) : BreaksHelperBase(rangeStart, rangeEnd, count) {\n    override val breaks: List<Double>\n\n    init {\n        check(count > 0) { \"Can't compute breaks for count: $count\" }\n\n        val step = if (precise) {\n            this.targetStep\n        } else {\n            computeNiceStep(this.span, count)\n        }\n\n        val breaks = if (precise) {\n            (0 until count).map { normalStart + step / 2 + it * step }\n        } else {\n            computeNiceBreaks(normalStart, normalEnd, step)\n        }\n\n        this.breaks = if (breaks.isEmpty()) {\n            listOf(normalStart)\n        } else if (isReversed) {\n            breaks.asReversed()\n        } else {\n            breaks\n        }\n    }\n\n    companion object {\n        private fun computeNiceStep(\n            span: Double,\n            count: Int\n        ): Double {\n            // compute step so that it is multiple of 10, 5 or 2.\n            val stepRaw = span / count\n            val step10Power = floor(log10(stepRaw))\n            val step = 10.0.pow(step10Power)\n            val error = step * count / span\n            return when {\n                error <= 0.15 -> step * 10.0\n                error <= 0.35 -> step * 5.0\n                error <= 0.75 -> step * 2.0\n                else -> step\n            }\n        }\n\n        private fun computeNiceBreaks(\n            start: Double,\n            end: Double,\n            step: Double\n        ): List<Double> {\n            if (step == 0.0) return emptyList()\n\n            // extend range to allow for FP errors\n            val delta = step / 10000\n            val startE = start - delta\n            val endE = end + delta\n\n            val breaks = ArrayList<Double>()\n            var tick = ceil(startE / step) * step\n            if (start >= 0 && startE < 0) {\n                // avoid negative zero\n                tick = 0.0\n            }\n            while (tick <= endE) {\n                // don't allow ticks to go beyond the range\n                tick = min(tick, end)\n\n                breaks.add(tick)\n                tick += step\n            }\n\n            return breaks\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\nimport kotlin.math.abs\nimport kotlin.math.ceil\nimport kotlin.math.log10\n\nclass NumericBreakFormatter(value: Double, step: Double, allowMetricPrefix: Boolean) {\n    private var formatter: NumberFormat\n\n    init {\n        @Suppress(\"NAME_SHADOWING\")\n        var value = if (value == 0.0) {\n            // Use very small value instead because log10(0) -> -Infinity.\n            Double.MIN_VALUE * 10\n        } else {\n            abs(value)\n        }\n\n        @Suppress(\"NAME_SHADOWING\")\n        var step = if (step == 0.0) {\n            value / 10\n        } else {\n            abs(step)\n        }\n\n\n        var type = \"f\"\n        var delimiter = \"\"\n\n        val domain10Power = log10(abs(value))\n        val step10Power = log10(step)\n\n        var precision = -step10Power\n        var scientificNotation = false\n        if (domain10Power < 0 && step10Power < -4) {\n            scientificNotation = true\n            type = \"e\"\n            precision = domain10Power - step10Power\n        } else if (domain10Power > 7 && step10Power > 2) {\n            scientificNotation = true\n            precision = domain10Power - step10Power\n        }\n\n        if (precision < 0) {\n            precision = 0.0\n            type = \"d\"\n        }\n        // round-up precision ulless it's very close to smaller int.\n        precision = ceil(precision - 0.001)\n\n        if (scientificNotation) {\n            type = if (domain10Power > 0 && allowMetricPrefix) {\n                // generate 'engineering notation', in which the exponent is a multiple of three\n                \"s\"\n            } else {\n                \"e\"\n            }\n        } else {\n            delimiter = \",\"\n        }\n\n        formatter = NumberFormat(\"$delimiter.${precision.toInt()}$type\")\n    }\n\n    fun apply(value: Any): String = formatter.apply(value as Number)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport kotlin.math.max\nimport kotlin.math.min\n\n\n// ToDo: seem like `WithFiniteOrderedOutput` never used\nclass QuantizeScale<T> : WithFiniteOrderedOutput<T> {\n    private var myHasDomain: Boolean = false\n    private var myDomainStart: Double = 0.0\n    private var myDomainEnd: Double = 0.0\n    private lateinit var myOutputValues: List<T>\n\n    override val outputValues: List<T>\n        get() = myOutputValues\n\n    //return Arrays.asList(ClosedRangeOpen(myDomainStart, myDomainEnd));\n    //    double error = bucketSize / 10;   // prevent creating of 1 extra bucket\n    /*\n    double upperBound = myDomainStart;\n    while (upperBound < myDomainEnd - error) {\n      double lowerBound = upperBound;\n      upperBound = lowerBound + bucketSize;\n      ClosedRange<Double> bucket = ClosedRangeOpen(lowerBound, upperBound);\n      list.add(bucket);\n    }\n*///ClosedRange<Double> bucket = ClosedRangeOpen(myDomainStart + bucketSize * i, myDomainStart + bucketSize * (i + 1));\n    // ToDo: move inside the cycle\n    // last bucket - closed\n    val domainQuantized: List<ClosedRange<Double>>\n        get() {\n            if (myDomainStart == myDomainEnd) {\n                return listOf(ClosedRange(myDomainStart, myDomainEnd))\n            }\n\n            val list = ArrayList<ClosedRange<Double>>()\n            val numBuckets = myOutputValues.size\n            val bucketSize = bucketSize()\n            for (i in 0 until numBuckets - 1) {\n                val bucket = ClosedRange(myDomainStart + bucketSize * i, myDomainStart + bucketSize * (i + 1))\n                list.add(bucket)\n            }\n            val bucket = ClosedRange(myDomainStart + bucketSize * (numBuckets - 1), myDomainEnd)\n            list.add(bucket)\n            return list\n        }\n\n    /**\n     * Set the scale's input domain.\n     */\n    fun domain(start: Double, end: Double): QuantizeScale<T> {\n        require(start <= end) { \"Domain start must be less then domain end: $start > $end\" }\n        myHasDomain = true\n        myDomainStart = start\n        myDomainEnd = end\n        return this\n    }\n\n    /**\n     * Scale's output 'quantized' values\n     */\n    fun range(values: Collection<T>): QuantizeScale<T> {\n        myOutputValues = ArrayList(values)\n        return this\n    }\n\n    fun quantize(v: Double): T {\n        val i = outputIndex(v)\n        return myOutputValues[i]\n    }\n\n    private fun outputIndex(v: Double): Int {\n        check(myHasDomain) { \"Domain not defined.\" }\n        check(::myOutputValues.isInitialized && myOutputValues.isNotEmpty()) { \"Output values are not defined.\" }\n        val bucketSize = bucketSize()\n        val index = ((v - myDomainStart) / bucketSize).toInt()\n        val maxIndex = myOutputValues.size - 1\n        return max(0, min(maxIndex, index))\n    }\n\n    override fun getOutputValueIndex(domainValue: Any): Int {\n        return if (domainValue is Number) {\n            outputIndex(domainValue.toDouble())\n        } else -1\n    }\n\n    override fun getOutputValue(domainValue: Any): T? {\n        return if (domainValue is Number) {\n            quantize(domainValue.toDouble())\n        } else null\n    }\n\n    private fun bucketSize(): Double {\n        return (myDomainEnd - myDomainStart) / myOutputValues.size\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Scale\n\n\nobject ScaleBreaksUtil {\n    fun <TargetT> withBreaks(\n        scale: Scale<TargetT>,\n        transformedDomain: ClosedRange<Double>,\n        breakCount: Int\n    ): Scale<TargetT> {\n        val scaleBreaks = scale.getBreaksGenerator().generateBreaks(transformedDomain, breakCount)\n        val breaks = scaleBreaks.domainValues\n        val labels = scaleBreaks.labels\n        return scale.with()\n            .breaks(breaks)\n            .labels(labels)\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.breaks\n\nimport jetbrains.datalore.plot.common.text.Formatter\nimport jetbrains.datalore.plot.common.time.interval.NiceTimeInterval\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\nimport jetbrains.datalore.plot.common.time.interval.YearInterval\n\ninternal class TimeScaleTickFormatterFactory(\n    private val minInterval: TimeInterval?\n) {\n\n    fun getFormatter(step: Double): (Any) -> String {\n        return Formatter.time(formatPattern(step))\n    }\n\n    private fun formatPattern(step: Double): String {\n        if (step < 1000) {        // milliseconds\n            return TimeInterval.milliseconds(1).tickFormatPattern\n        }\n\n        if (minInterval != null) {\n            // check if we have to hold on minimal interval formatter\n            val stepCount = 100\n            val start = 0.0\n            val end = step * stepCount\n            val intervalCount = minInterval.range(start, end).size\n            if (stepCount >= intervalCount) {\n                // step is smaller than min interval -> stay with min interval\n                return minInterval.tickFormatPattern\n            }\n        }\n\n        if (step > YearInterval.MS) {        // years\n            return YearInterval.TICK_FORMAT\n        }\n\n        val interval = NiceTimeInterval.forMillis(step)\n        return interval.tickFormatPattern\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.DateTimeBreaksHelper\n\nclass DateTimeBreaksGen(\n    private val labelFormatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val helper = breaksHelper(domain, targetCount)\n        val ticks = helper.breaks\n        val labelFormatter = labelFormatter ?: helper.formatter\n        val labels = ArrayList<String>()\n        for (tick in ticks) {\n            labels.add(labelFormatter(tick))\n        }\n        return ScaleBreaks(ticks, ticks, labels)\n    }\n\n    private fun breaksHelper(\n        domainAfterTransform: ClosedRange<Double>,\n        targetCount: Int\n    ): DateTimeBreaksHelper {\n        return DateTimeBreaksHelper(\n            domainAfterTransform.lowerEnd,\n            domainAfterTransform.upperEnd,\n            targetCount\n        )\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return labelFormatter ?: breaksHelper(domain, targetCount).formatter\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nabstract class FunTransform(\n    private val transformFun: (Double) -> Double,\n    private val inverseFun: (Double) -> Double\n) : ContinuousTransform {\n    override fun apply(v: Double?): Double? {\n        return if (v != null) {\n            transformFun(v)\n        } else {\n            null\n        }\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return safeCastToDoubles(l).map { apply(it) }\n    }\n\n    override fun applyInverse(v: Double?): Double? {\n        return if (v != null) {\n            inverseFun(v)\n        } else {\n            null\n        }\n    }\n\n    override fun applyInverse(l: List<Double?>): List<Double?> {\n        return l.map { applyInverse(it) }\n    }\n\n    protected fun safeCastToDoubles(list: List<*>): List<Double?> {\n        val checkedDoubles = SeriesUtil.checkedDoubles(list)\n        require(checkedDoubles.canBeCast()) { \"Not a collections of Double(s)\" }\n        return checkedDoubles.cast()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class IdentityTransform : FunTransform({ v -> v }, { v -> v }) {\n    override fun hasDomainLimits(): Boolean = false\n\n    override fun isInDomain(v: Double?) = SeriesUtil.isFinite(v)\n\n    override fun createApplicableDomain(middle: Double?): ClosedRange<Double> {\n        if (middle == null) {\n            return createApplicableDomain(0.0)\n        }\n\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = if (middle.isFinite()) middle else 0.0\n        return ClosedRange(middle - 0.5, middle + 0.5)\n    }\n\n    override fun toApplicableDomain(range: ClosedRange<Double>): ClosedRange<Double> {\n        return range\n    }\n\n    override fun apply(l: List<*>): List<Double?> {\n        return safeCastToDoubles(l)\n    }\n\n    override fun applyInverse(l: List<Double?>): List<Double?> {\n        return l\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.LinearBreaksHelper\nimport jetbrains.datalore.plot.base.scale.breaks.NumericBreakFormatter\nimport kotlin.math.abs\nimport kotlin.math.max\n\ninternal class LinearBreaksGen(\n    private val formatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val breaks = generateBreakValues(domain, targetCount)\n        val fmt = formatter ?: createFormatter(breaks)\n        val labels = breaks.map { fmt(it) }\n        return ScaleBreaks(breaks, breaks, labels)\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return formatter ?: createFormatter(generateBreakValues(domain, targetCount))\n    }\n\n    companion object {\n        internal fun generateBreakValues(domain: ClosedRange<Double>, targetCount: Int): List<Double> {\n            val helper = LinearBreaksHelper(\n                domain.lowerEnd,\n                domain.upperEnd,\n                targetCount\n            )\n            return helper.breaks\n        }\n\n        private fun createFormatter(breakValues: List<Double>): (Any) -> String {\n            val (referenceValue, step) = when {\n                breakValues.isEmpty() -> Pair(0.0, 0.5)\n                else -> {\n                    val v = max(abs(breakValues.first()), abs(breakValues.last()))\n                    val s = when {\n                        breakValues.size == 1 -> v / 10\n                        else -> abs(breakValues[1] - breakValues[0])\n                    }\n                    Pair(v, s)\n                }\n            }\n\n            val formatter = NumericBreakFormatter(\n                referenceValue,\n                step,\n                allowMetricPrefix = true\n            )\n            return formatter::apply\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.log10\nimport kotlin.math.max\nimport kotlin.math.pow\n\ninternal class Log10Transform : FunTransform(\n    transformFun = { v -> log10(v) },\n    inverseFun = { v -> 10.0.pow(v) }\n) {\n    override fun hasDomainLimits() = true\n\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v) && v!! >= LOWER_LIM_DOMAIN\n    }\n\n    private fun isZero(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v) && v!! >= 0.0 && v < LOWER_LIM_DOMAIN\n    }\n\n    override fun apply(v: Double?): Double? {\n        return trimInfinity(super.apply(v))\n    }\n\n    override fun createApplicableDomain(middle: Double?): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = when {\n            isInDomain(middle) -> max(middle!!, LOWER_LIM_DOMAIN)\n            isZero(middle) -> LOWER_LIM_DOMAIN  // Special case.\n            else -> 1.0\n        }\n\n        val lower = if (middle < 1) {\n            middle / 2\n        } else {\n            middle - 0.5\n        }\n        return ClosedRange(max(lower, LOWER_LIM_DOMAIN), middle + 0.5)\n    }\n\n    override fun toApplicableDomain(range: ClosedRange<Double>): ClosedRange<Double> {\n        val lower = max(range.lowerEnd, LOWER_LIM_DOMAIN)\n        val upper = max(range.upperEnd, lower)\n        return ClosedRange(lower, upper)\n    }\n\n    companion object {\n        internal const val LOWER_LIM_TRANSFOTMED: Double = -Double.MAX_VALUE / 10\n        internal const val LOWER_LIM_DOMAIN: Double = Double.MIN_VALUE * 10\n\n        /**\n         * Avoid transforming 0.0 -> -Infinity\n         */\n        private fun trimInfinity(v: Double?): Double? {\n            return when {\n                v == null -> null\n                v.isNaN() -> Double.NaN\n                else -> max(LOWER_LIM_TRANSFOTMED, v)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.NumericBreakFormatter\nimport kotlin.math.abs\nimport kotlin.math.min\n\ninternal class NonlinearBreaksGen(\n    private val transform: ContinuousTransform,\n    private val formatter: ((Any) -> String)? = null\n) : BreaksGenerator {\n\n    override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n        val breakValues = generateBreakValues(domain, targetCount, transform)\n        val breakFormatters = if (formatter != null) {\n            List(breakValues.size) { formatter }\n        } else {\n            createFormatters(breakValues)\n        }\n\n        val labels = breakValues.mapIndexed() { i, v -> breakFormatters[i](v) }\n        return ScaleBreaks(breakValues, breakValues, labels)\n    }\n\n    override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n        return formatter ?: createMultiFormatter(generateBreakValues(domain, targetCount, transform))\n    }\n\n    companion object {\n        private fun generateBreakValues(\n            domain: ClosedRange<Double>,\n            targetCount: Int,\n            transform: ContinuousTransform\n        ): List<Double> {\n            val transformedDomain = MapperUtil.map(domain) { transform.apply(it) }\n            val transformedBreakValues: List<Double> =\n                LinearBreaksGen.generateBreakValues(transformedDomain, targetCount)\n\n            // Transform back to data space.\n            return transform.applyInverse(transformedBreakValues).filterNotNull()\n        }\n\n        private fun createMultiFormatter(breakValues: List<Double>): (Any) -> String {\n            val breakFormatters = createFormatters(breakValues)\n            return MultiFormatter(breakValues, breakFormatters)::apply\n        }\n\n        private fun createFormatters(breakValues: List<Double>): List<(Any) -> String> {\n            if (breakValues.isEmpty()) return emptyList()\n            if (breakValues.size == 1) {\n                val domainValue = breakValues[0]\n                val step = domainValue / 10\n                return listOf(createFormatter(domainValue, step))\n            }\n\n            // format each tick with its own formatter\n            @Suppress(\"UnnecessaryVariable\")\n            val formatters: List<(Any) -> String> = breakValues.mapIndexed { i, currValue ->\n                val step = abs(\n                    when (i) {\n                        0 -> currValue - breakValues[i + 1]\n                        else -> currValue - breakValues[i - 1]\n                    }\n                )\n                createFormatter(currValue, step)\n            }\n            return formatters\n        }\n\n        private fun createFormatter(domainValue: Double, step: Double): (Any) -> String {\n            return NumericBreakFormatter(\n                domainValue,\n                step,\n                true\n            )::apply\n        }\n    }\n\n    private class MultiFormatter(\n        val breakValues: List<Double>,\n        val breakFormatters: List<(Any) -> String>\n    ) {\n        init {\n            check(breakValues.size == breakFormatters.size) {\n                \"MultiFormatter: breakValues.size=${breakValues.size} but breakFormatters.size=${breakFormatters.size}\"\n            }\n            if (breakValues.size > 1) {\n                val ordered = breakValues\n                    .mapIndexed { i, v -> if (i == 0) 0.0 else v - breakValues[i - 1] }\n                    .all { it >= 0.0 }\n                check(ordered) { \"MultiFormatter: values must be sorted in ascending order. Were: $breakValues.\" }\n            }\n        }\n\n        fun apply(v: Any): String {\n            v as Double\n            return when {\n                breakValues.isEmpty() -> v.toString()\n                else -> {\n                    val i = abs(breakValues.binarySearch(v))\n                    val ii = min(i, breakValues.size - 1)\n                    breakFormatters[ii](v)\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class ReverseTransform : FunTransform({ v -> -v }, { v -> -v }) {\n    override fun hasDomainLimits() = false\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v)\n    }\n\n    override fun createApplicableDomain(middle: Double?): ClosedRange<Double> {\n        return Transforms.IDENTITY.createApplicableDomain(middle)\n    }\n\n    override fun toApplicableDomain(range: ClosedRange<Double>): ClosedRange<Double> {\n        return Transforms.IDENTITY.toApplicableDomain(range)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.sqrt\n\ninternal class SqrtTransform : FunTransform(\n    transformFun = { v -> sqrt(v) },\n    inverseFun = { v -> v * v }\n) {\n    override fun hasDomainLimits() = true\n\n    override fun isInDomain(v: Double?): Boolean {\n        return SeriesUtil.isFinite(v) && v!! >= 0.0\n    }\n\n    override fun createApplicableDomain(middle: Double?): ClosedRange<Double> {\n        @Suppress(\"NAME_SHADOWING\")\n        val middle = when {\n            isInDomain(middle) -> max(middle!!, 0.0)\n            else -> 1.0\n        }\n\n        return ClosedRange(max(middle - 0.5, 0.0), middle + 0.5)\n    }\n\n    override fun toApplicableDomain(range: ClosedRange<Double>): ClosedRange<Double> {\n        val lower = max(range.lowerEnd, 0.0)\n        val upper = max(range.upperEnd, 0.0)\n        return ClosedRange(lower, upper)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.scale.transform\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nobject Transforms {\n    val IDENTITY: ContinuousTransform = IdentityTransform()\n    val REVERSE: ContinuousTransform = ReverseTransform()\n    val SQRT: ContinuousTransform = SqrtTransform()\n    val LOG10: ContinuousTransform = Log10Transform()\n\n    fun createBreaksGeneratorForTransformedDomain(\n        transform: ContinuousTransform,\n        labelFormatter: ((Any) -> String)? = null\n    ): BreaksGenerator {\n        val breaksGenerator: BreaksGenerator = when (transform) {\n            IDENTITY -> LinearBreaksGen(labelFormatter)\n            REVERSE -> LinearBreaksGen(labelFormatter)\n            SQRT -> NonlinearBreaksGen(SQRT, labelFormatter)\n            LOG10 -> NonlinearBreaksGen(LOG10, labelFormatter)\n            else -> throw IllegalStateException(\"Unexpected 'transform' type: ${transform::class.simpleName}\")\n        }\n\n        return BreaksGeneratorForTransformedDomain(transform, breaksGenerator)\n    }\n\n    fun ensureApplicableDomain(\n        dataRange: ClosedRange<Double>?,\n        transform: ContinuousTransform\n    ): ClosedRange<Double> {\n        if (dataRange == null) {\n            return transform.createApplicableDomain()\n        }\n\n        val domain = transform.toApplicableDomain(dataRange)\n        return when {\n            SeriesUtil.isSubTiny(domain) ->\n                transform.createApplicableDomain(domain.upperEnd)\n            else ->\n                domain\n        }\n    }\n\n\n    class BreaksGeneratorForTransformedDomain(\n        private val transform: ContinuousTransform,\n        val breaksGenerator: BreaksGenerator\n    ) : BreaksGenerator {\n        override fun labelFormatter(domain: ClosedRange<Double>, targetCount: Int): (Any) -> String {\n            val domainBeforeTransform = MapperUtil.map(domain) {\n                transform.applyInverse(it)\n            }\n            return breaksGenerator.labelFormatter(domainBeforeTransform, targetCount)\n        }\n\n        override fun generateBreaks(domain: ClosedRange<Double>, targetCount: Int): ScaleBreaks {\n            val domainBeforeTransform = MapperUtil.map(domain) {\n                transform.applyInverse(it)\n            }\n            val scaleBreaks = breaksGenerator.generateBreaks(domainBeforeTransform, targetCount)\n            val originalBreaks = scaleBreaks.domainValues\n            val transformedBreaks = transform.apply(originalBreaks).map {\n                it as Double // Should not contain NULLs\n            }\n\n            return ScaleBreaks(originalBreaks, transformedBreaks, scaleBreaks.labels)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\n\nabstract class AbstractDensity2dStat(\n    private val bandWidthX: Double?,\n    private val bandWidthY: Double?,\n    private val bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    protected val adjust: Double,\n    private val kernel: DensityStat.Kernel,\n    protected val nX: Int,\n    protected val nY: Int,\n    protected val isContour: Boolean,\n    private val binCount: Int,\n    private val binWidth: Double\n\n) : BaseStat(DEF_MAPPING) {\n\n    //    var adjust = DEF_ADJUST\n//    var nx = DEF_N\n//        set(n) {\n//            if (n > MAX_N) {\n//                throw IllegalArgumentException(\"The input Nx \" + n + \" > \" + MAX_N + \"is too large!\")\n//            }\n//            field = n\n//        }\n//    var ny = DEF_N\n//        set(n) {\n//            if (n > MAX_N) {\n//                throw IllegalArgumentException(\"The input Ny \" + n + \" > \" + MAX_N + \"is too large!\")\n//            }\n//            field = n\n//        }\n//    var isContour = DEF_CONTOUR\n//    var bandWidthMethod: DensityStat.BandWidthMethod =\n//        DensityStat.BandWidthMethod.NRD\n//        set(bw) {\n//            field = bw\n//            bandWidths = null\n//        }\n//    private var myBinCount = DEF_BIN_COUNT\n//    private var myBinWidth: Double = 0.toDouble()\n\n//    protected val bandWidths: DoubleArray\n\n    protected val kernelFun: ((Double) -> Double) = DensityStatUtil.kernel(kernel)\n\n    protected val binOptions: BinStatUtil.BinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    init {\n        require(nX <= MAX_N) { \"The input nX = $nX  > $MAX_N is too large!\" }\n        require(nY <= MAX_N) { \"The input nY = $nY  > $MAX_N is too large!\" }\n    }\n\n    fun getBandWidthX(xs: List<Double?>): Double {\n        return bandWidthX ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            xs\n        )\n    }\n\n    fun getBandWidthY(ys: List<Double?>): Double {\n        return bandWidthY ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            ys\n        )\n    }\n\n//    fun setBinCount(bin: Int) {\n//        myBinCount = bin\n//    }\n\n//    fun setBinWidth(bin: Double) {\n//        myBinWidth = bin\n//    }\n\n//    fun setBandWidthX(bw: Double) {\n//        //myBW = BandWidth.DOUBLE;\n//        bandWidths = DoubleArray(2)\n//        bandWidths?.set(0, bw)\n//    }\n\n//    fun setBandWidthY(bw: Double) {\n//        //myBW = BandWidth.DOUBLE;\n//        bandWidths?.set(1, bw)\n//    }\n\n//    fun setKernel(kernel: DensityStat.Kernel) {\n//        this.kernel = DensityStatUtil.kernel(kernel)\n//    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        // ToDo: ???\n        throw IllegalStateException(\"'density2d' statistic can't be executed on the client side\")\n    }\n\n    companion object {\n        //        const val DEF_KERNEL = \"gaussian\"\n        val DEF_KERNEL = DensityStat.Kernel.GAUSSIAN\n        const val DEF_ADJUST = 1.0\n        const val DEF_N = 100\n\n        //        const val DEF_BW = \"nrd\"\n        val DEF_BW = DensityStat.BandWidthMethod.NRD0\n        const val DEF_CONTOUR = true\n        const val DEF_BIN_COUNT = 10\n        const val DEF_BIN_WIDTH = 0.0\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n        private const val MAX_N = 999\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Stat\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nabstract class BaseStat(private val defaultMappings: Map<Aes<*>, DataFrame.Variable>) : Stat {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return defaultMappings.containsKey(aes)\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        if (defaultMappings.containsKey(aes)) {\n            return defaultMappings[aes]!!\n        }\n        throw IllegalArgumentException(\"Stat \" + this::class.simpleName + \" has no default mapping for aes: \" + aes)\n    }\n\n    protected fun hasRequiredValues(data: DataFrame, vararg aes: Aes<*>): Boolean {\n        for (requiredAes in aes) {\n            val variable = TransformVar.forAes(requiredAes)\n            if (data.hasNoOrEmpty(variable)) {\n                return false\n            }\n        }\n        return true\n    }\n\n    protected fun withEmptyStatValues(): DataFrame {\n        val newData = DataFrame.Builder()\n        for (aes in Aes.values()) {\n            if (hasDefaultMapping(aes)) {\n                newData.put(getDefaultMapping(aes), emptyList<Any>())\n            }\n        }\n        return newData.build()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil.expand\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isSubTiny\nimport kotlin.math.floor\n\n/**\n * Default stat for geom_bin2d\n *\n * @param binCountX Number of bins (overridden by binWidth).\n * @param binCountY Number of bins (overridden by binWidth).\n * @param binWidthX Used to compute binCount such that bins covers the range of the data.\n * @param binWidthY Used to compute binCount such that bins covers the range of the data.\n * @param drop if TRUE removes all cells with 0 counts.\n *\n * Computed values:\n *\n * count - number of points in bin\n * density - density of points in bin, scaled to integrate to 1\n * ncount - count, scaled to maximum of 1\n * ndensity - density, scaled to maximum of 1\n */\nclass Bin2dStat(\n    binCountX: Int = DEF_BINS,\n    binCountY: Int = DEF_BINS,\n    binWidthX: Double? = DEF_BINWIDTH,\n    binWidthY: Double? = DEF_BINWIDTH,\n    private val drop: Boolean = DEF_DROP\n) : BaseStat(DEF_MAPPING) {\n    private val binOptionsX = BinStatUtil.BinOptions(binCountX, binWidthX)\n    private val binOptionsY = BinStatUtil.BinOptions(binCountY, binWidthY)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n        if (xRange == null || yRange == null) {\n            return withEmptyStatValues()\n        }\n\n        // initial bin width and count\n\n        val xRangeInit = adjustRangeInitial(xRange)\n        val yRangeInit = adjustRangeInitial(yRange)\n\n        val xCountAndWidthInit = BinStatUtil.binCountAndWidth(SeriesUtil.span(xRangeInit), binOptionsX)\n        val yCountAndWidthInit = BinStatUtil.binCountAndWidth(SeriesUtil.span(yRangeInit), binOptionsY)\n\n        // final bin width and count\n\n        val xRangeFinal = adjustRangeFinal(xRange, xCountAndWidthInit.width)\n        val yRangeFinal = adjustRangeFinal(yRange, yCountAndWidthInit.width)\n\n        val xCountAndWidthFinal = BinStatUtil.binCountAndWidth(SeriesUtil.span(xRangeFinal), binOptionsX)\n        val yCountAndWidthFinal = BinStatUtil.binCountAndWidth(SeriesUtil.span(yRangeFinal), binOptionsY)\n\n        val countTotal = xCountAndWidthFinal.count * yCountAndWidthFinal.count\n        val densityNormalizingFactor =\n            densityNormalizingFactor(SeriesUtil.span(xRangeFinal), SeriesUtil.span(yRangeFinal), countTotal)\n\n        val binsData = computeBins(\n            data.getNumeric(TransformVar.X),\n            data.getNumeric(TransformVar.Y),\n            xRangeFinal.lowerEnd,\n            yRangeFinal.lowerEnd,\n            xCountAndWidthFinal.count,\n            yCountAndWidthFinal.count,\n            xCountAndWidthFinal.width,\n            yCountAndWidthFinal.width,\n            BinStatUtil.weightAtIndex(data),\n            densityNormalizingFactor\n        )\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, binsData.x)\n            .putNumeric(Stats.Y, binsData.y)\n            .putNumeric(Stats.COUNT, binsData.count)\n            .putNumeric(Stats.DENSITY, binsData.density)\n            .build()\n    }\n\n    private fun computeBins(\n        xValues: List<Double?>,\n        yValues: List<Double?>,\n        xStart: Double,\n        yStart: Double,\n        binCountX: Int,\n        binCountY: Int,\n        binWidth: Double,\n        binHeight: Double,\n        weightAtIndex: (Int) -> Double,\n        densityNormalizingFactor: Double\n    ): Bins2dData {\n\n        var totalCount = 0.0\n        val countByBinIndexKey = HashMap<Pair<Int, Int>, MutableDouble>()\n        for (dataIndex in xValues.indices) {\n            val x = xValues[dataIndex]\n            val y = yValues[dataIndex]\n            if (!SeriesUtil.allFinite(x, y)) {\n                continue\n            }\n            val weight = weightAtIndex(dataIndex)\n            totalCount += weight\n            val binIndexX = floor((x!! - xStart) / binWidth).toInt()\n            val binIndexY = floor((y!! - yStart) / binHeight).toInt()\n            val binIndexKey = Pair(binIndexX, binIndexY)\n            if (!countByBinIndexKey.containsKey(binIndexKey)) {\n                countByBinIndexKey[binIndexKey] = MutableDouble(0.0)\n            }\n            countByBinIndexKey[binIndexKey]!!.getAndAdd(weight)\n        }\n\n        val xs = ArrayList<Double>()\n        val ys = ArrayList<Double>()\n        val counts = ArrayList<Double>()\n        val densities = ArrayList<Double>()\n\n        val x0 = xStart + binWidth / 2\n        val y0 = yStart + binHeight / 2\n        for (xIndex in 0 until binCountX) {\n            for (yIndex in 0 until binCountY) {\n                val binIndexKey = Pair(xIndex, yIndex)\n                var count = 0.0\n                if (countByBinIndexKey.containsKey(binIndexKey)) {\n                    count = countByBinIndexKey[binIndexKey]!!.get()\n                }\n\n                if (drop && count == 0.0) {\n                    continue\n                }\n\n                xs.add(x0 + xIndex * binWidth)\n                ys.add(y0 + yIndex * binHeight)\n                counts.add(count)\n                val density = count / totalCount * densityNormalizingFactor\n                densities.add(density)\n            }\n        }\n\n        return Bins2dData(xs, ys, counts, densities)\n    }\n\n\n    companion object {\n\n        const val DEF_BINS = 30\n        val DEF_BINWIDTH: Double? = null\n        const val DEF_DROP = true\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.FILL to Stats.COUNT\n        )\n\n        private fun adjustRangeInitial(r: ClosedRange<Double>): ClosedRange<Double> {\n            // span can't be 0\n            return ensureApplicableRange(r)\n        }\n\n        private fun adjustRangeFinal(r: ClosedRange<Double>, binWidth: Double): ClosedRange<Double> {\n            return if (isSubTiny(r)) {\n                // 0 span allways becomes 1\n                expand(r, 0.5, 0.5)\n            } else {\n                // Expand range by half of bin width (arbitrary choise - can be any positive num) to\n                // avoid data-points on the marginal bin margines.\n                val exp = binWidth / 2.0\n                expand(r, exp, exp)\n            }\n        }\n\n        private fun densityNormalizingFactor(\n            xSpan: Double,\n            ySpan: Double,\n            count: Int\n        ): Double {\n            // density should integrate to 1.0\n            val area = xSpan * ySpan\n            val binArea = area / count\n            return 1.0 / binArea\n        }\n    }\n\n    class Bins2dData(\n        internal val x: List<Double>,\n        internal val y: List<Double>,\n        internal val count: List<Double>,\n        internal val density: List<Double>\n    )\n\n    class Bins2dWeightedCounts(\n        internal val total: Double,\n        internal val countByBinXY: Map<Pair<Double, Double>, Double>\n    )\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.abs\n\n/**\n * Default stat for geom_histogram\n *\n * @param binCount Number of bins (overridden by binWidth)\n * @param binWidth Used to compute binCount such that bins covers the range of the data\n * @param xPosKind Specifies a way in which bin x-position is interpreted (center, boundary)\n * @param xPos Bin x-position.\n *\n * Computed values:\n *\n * count - number of points in bin\n * density - density of points in bin, scaled to integrate to 1\n * ncount - count, scaled to maximum of 1\n * ndensity - density, scaled to maximum of 1\n */\nclass BinStat(\n    binCount: Int,\n    binWidth: Double?,\n    private val xPosKind: XPosKind,\n    private val xPos: Double\n) : BaseStat(DEF_MAPPING) {\n    private val binOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val statX = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val rangeX = statCtx.overallXRange()\n        if (rangeX != null) { // null means all input values are null\n            val binsData = computeStatSeries(data, rangeX, data.getNumeric(TransformVar.X))\n            statX.addAll(binsData.x)\n            statCount.addAll(binsData.count)\n            statDensity.addAll(binsData.density)\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.COUNT, statCount)\n            .putNumeric(Stats.DENSITY, statDensity)\n            .build()\n    }\n\n    private fun computeStatSeries(\n        data: DataFrame,\n        rangeX: ClosedRange<Double>,\n        valuesX: List<Double?>\n    ): BinStatUtil.BinsData {\n        var startX: Double? = rangeX.lowerEnd\n        var spanX = rangeX.upperEnd - startX!!\n\n        // initial bin count/width\n        var b: BinStatUtil.CountAndWidth = BinStatUtil.binCountAndWidth(spanX, binOptions)\n\n        // adjusted bin count/width\n        // extend the data range by 0.7 of binWidth on each ends (to allow limited horizontal adjustments)\n        startX -= b.width * 0.7\n        spanX += b.width * 1.4\n        b = BinStatUtil.binCountAndWidth(spanX, binOptions)\n        val binCount = b.count\n        val binWidth = b.width\n\n        // optional horizontal adjustment (+/-0.5 bin width max)\n        if (xPosKind != XPosKind.NONE) {\n            var minDelta = Double.MAX_VALUE\n            val x = xPos\n\n            for (i in 0 until binCount) {\n                val binLeft = startX + i * binWidth\n                val delta: Double\n                if (xPosKind == XPosKind.CENTER) {\n                    delta = x - (binLeft + binWidth / 2)\n                } else {       // BOUNDARY\n                    if (i == 0) {\n                        minDelta = x - startX // init still\n                    }\n                    delta = x - (binLeft + binWidth)\n                }\n\n                if (abs(delta) < abs(minDelta)) {\n                    minDelta = delta\n                }\n            }\n\n            // max offset: +/-0.5 bin width\n            val offset = minDelta % (binWidth / 2)\n            startX += offset\n        }\n\n        // density plot area should be == 1\n        val normalBinWidth = SeriesUtil.span(rangeX) / binCount\n        val densityNormalizingFactor = if (normalBinWidth > 0)\n            1.0 / normalBinWidth\n        else\n            1.0\n\n        // compute bins\n\n        val binsData = BinStatUtil.computeBins(\n            valuesX,\n            startX,\n            binCount,\n            binWidth,\n            BinStatUtil.weightAtIndex(data),\n            densityNormalizingFactor\n        )\n        check(binsData.x.size == binCount)\n        { \"Internal: stat data size=\" + binsData.x.size + \" expected bin count=\" + binCount }\n\n        return binsData\n    }\n\n    enum class XPosKind {\n        NONE, CENTER, BOUNDARY\n    }\n\n    companion object {\n        const val DEF_BIN_COUNT = 30\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.COUNT\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject BinStatUtil {\n    private const val MAX_BIN_COUNT = 500\n\n    fun weightAtIndex(data: DataFrame): (Int) -> Double {\n        if (data.has(TransformVar.WEIGHT)) {\n            val weights = data.getNumeric(TransformVar.WEIGHT)\n            return { index ->\n                val weight = weights[index]\n                SeriesUtil.asFinite(weight, 0.0)\n            }\n        }\n        return { 1.0 }\n    }\n\n    // ToDo: need to deal fith n/a values (see DensityStat)\n    fun weightVector(dataLength: Int, data: DataFrame): List<Double?> {\n        return if (data.has(TransformVar.WEIGHT)) {\n            data.getNumeric(TransformVar.WEIGHT)\n        } else List(dataLength) { 1.0 }\n    }\n\n    fun binCountAndWidth(dataRange: Double, binOptions: BinOptions): CountAndWidth {\n        var binCount = binOptions.binCount\n        val binWidth: Double\n        if (binOptions.hasBinWidth()) {\n            binWidth = binOptions.binWidth!!\n            var count = dataRange / binWidth\n            count = min(MAX_BIN_COUNT.toDouble(), count)\n            binCount = ceil(count).toInt()\n        } else {\n            binWidth = dataRange / binCount\n        }\n        return CountAndWidth(binCount, binWidth)\n    }\n\n    fun computeBins(\n        valuesX: List<Double?>,\n        startX: Double,\n        binCount: Int,\n        binWidth: Double,\n        weightAtIndex: (Int) -> Double,\n        densityNormalizingFactor: Double\n    ): BinsData {\n\n        var totalCount = 0.0\n        val countByBinIndex = HashMap<Int, MutableDouble>()\n//        val dataIndicesByBinIndex = HashMap<Int, MutableList<Int>>()\n        for (dataIndex in valuesX.indices) {\n            val x = valuesX[dataIndex]\n            if (!SeriesUtil.isFinite(x)) {\n                continue\n            }\n            val weight = weightAtIndex(dataIndex)\n            totalCount += weight\n            val binIndex = floor((x!! - startX) / binWidth).toInt()\n            if (!countByBinIndex.containsKey(binIndex)) {\n                countByBinIndex[binIndex] = MutableDouble(0.0)\n            }\n            countByBinIndex[binIndex]!!.getAndAdd(weight)\n\n//            if (!dataIndicesByBinIndex.containsKey(binIndex)) {\n//                dataIndicesByBinIndex[binIndex] = ArrayList()\n//            }\n\n//            dataIndicesByBinIndex[binIndex]!!.add(dataIndex)\n        }\n\n        val x = ArrayList<Double>()\n        val counts = ArrayList<Double>()\n        val densities = ArrayList<Double>()\n\n        val x0 = startX + binWidth / 2\n        for (i in 0 until binCount) {\n            x.add(x0 + i * binWidth)\n\n            var count = 0.0\n            // some bins are left empty (not excluded from map)\n            if (countByBinIndex.containsKey(i)) {\n                count = countByBinIndex[i]!!.get()\n            }\n\n            counts.add(count)\n            val density = count / totalCount * densityNormalizingFactor\n            densities.add(density)\n        }\n\n//        return BinsData(x, counts, densities, dataIndicesByBinIndex)\n        return BinsData(x, counts, densities)\n    }\n\n    class BinOptions(\n        binCount: Int, val binWidth: Double?  // optional\n    ) {\n        val binCount: Int = min(MAX_BIN_COUNT, max(1, binCount))\n\n        fun hasBinWidth(): Boolean {\n            return binWidth != null && binWidth > 0\n        }\n    }\n\n    class CountAndWidth(val count: Int, val width: Double)\n\n    class BinsData(\n        internal val x: List<Double>,\n        internal val count: List<Double>,\n        internal val density: List<Double>\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.sqrt\n\n/**\n * Calculate components of box and whisker plot.\n *\n * Creates a \"stat\" dataframe contaning:\n *  a) \"box\" data-points\n *      x\n *      y = NaN\n *      width    - width of box\n *      ymin     - lower whisker = smallest observation greater than or equal to lower hinge - 1.5 * IQR\n *      lower    - lower hinge, 25% quantile\n *      middle   - median, 50% quantile\n *      upper    - upper hinge, 75% quantile\n *      ymax     - upper whisker = largest observation less than or equal to upper hinge + 1.5 * IQR\n *\n *  b) \"outlier\" data-points\n *      x, y, width\n *      ymin, lower... = NaN\n *\n * Not implemented:\n * notchlower   - lower edge of notch = median - 1.58 * IQR / sqrt(n)\n * notchupper   - upper edge of notch = median + 1.58 * IQR / sqrt(n)\n */\nclass BoxplotStat(\n    private val whiskerIQRRatio: Double,    // ggplot: 'coef'\n    private val computeWidth: Boolean       // ggplot: 'varWidth'\n) : BaseStat(DEF_MAPPING) {\n\n    override fun hasDefaultMapping(aes: Aes<*>): Boolean {\n        return super.hasDefaultMapping(aes) ||\n                aes == WIDTH && computeWidth\n    }\n\n    override fun getDefaultMapping(aes: Aes<*>): DataFrame.Variable {\n        return if (aes == WIDTH) {\n            Stats.WIDTH\n        } else {\n            super.getDefaultMapping(aes)\n        }\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val ys = data.getNumeric(TransformVar.Y)\n        val xs = if (data.has(TransformVar.X)) {\n            data.getNumeric(TransformVar.X)\n        } else {\n            List<Double>(ys.size) { 0.0 }\n        }\n\n        val statData = buildStat(xs, ys, whiskerIQRRatio)\n\n        val statCount = statData.remove(Stats.COUNT)\n        val maxCountPerBin = statCount?.maxOrNull()?.toInt() ?: 0\n        if (maxCountPerBin == 0) {\n            return withEmptyStatValues()\n        }\n        if (computeWidth) {\n            // 'width' is in range 0..1\n            val norm = sqrt(maxCountPerBin.toDouble())\n            val statWidth = statCount!!.map { count -> sqrt(count) / norm }\n            statData[Stats.WIDTH] = statWidth\n        }\n\n        val builder = DataFrame.Builder()\n        for ((variable, series) in statData) {\n            builder.putNumeric(variable, series)\n        }\n        return builder.build()\n    }\n\n    companion object {\n        const val DEF_WHISKER_IQR_RATIO = 1.5\n        const val DEF_COMPUTE_WIDTH = false\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.YMIN to Stats.Y_MIN,\n            Aes.YMAX to Stats.Y_MAX,\n            Aes.LOWER to Stats.LOWER,\n            Aes.MIDDLE to Stats.MIDDLE,\n            Aes.UPPER to Stats.UPPER\n        )\n\n        fun buildStat(\n            xs: List<Double?>,\n            ys: List<Double?>,\n            whiskerIQRRatio: Double\n        ): MutableMap<DataFrame.Variable, List<Double>> {\n\n            val xyPairs = xs.zip(ys).filter { (x, y) ->\n                SeriesUtil.allFinite(x, y)\n            }\n            if (xyPairs.isEmpty()) {\n                return mutableMapOf()\n            }\n\n            val binnedData: MutableMap<Double, MutableList<Double>> = HashMap()\n            for ((x, y) in xyPairs) {\n                binnedData.getOrPut(x!!) { ArrayList() }.add(y!!)\n            }\n\n            val statX = ArrayList<Double>()\n            val statY = ArrayList<Double>()\n            val statMiddle = ArrayList<Double>()\n            val statLower = ArrayList<Double>()\n            val statUpper = ArrayList<Double>()\n            val statMin = ArrayList<Double>()\n            val statMax = ArrayList<Double>()\n\n            val statCount = ArrayList<Double>()\n\n            for ((x, bin) in binnedData) {\n                val count = bin.size.toDouble()\n\n                val summary = FiveNumberSummary(bin)\n                val middle = summary.median\n                val lowerHinge = summary.firstQuartile\n                val upperHinge = summary.thirdQuartile\n                val IQR = upperHinge - lowerHinge\n                val lowerFence = lowerHinge - IQR * whiskerIQRRatio\n                val upperFence = upperHinge + IQR * whiskerIQRRatio\n\n                var lowerWhisker = lowerFence\n                var upperWhisker = upperFence\n                if (SeriesUtil.allFinite(lowerFence, upperFence)) {\n                    val boxed = bin.filter { y -> y >= lowerFence && y <= upperFence }\n                    val range = SeriesUtil.range(boxed)\n                    if (range != null) {\n                        lowerWhisker = range.lowerEnd\n                        upperWhisker = range.upperEnd\n                    }\n                }\n\n                // add outliers first\n                val outliers = bin.filter { y -> y < lowerFence || y > upperFence }\n                for (y in outliers) {\n                    // 'outlier' data-point\n                    statX.add(x)\n                    statY.add(y)\n                    // no 'box' data\n                    statMiddle.add(Double.NaN)\n                    statLower.add(Double.NaN)\n                    statUpper.add(Double.NaN)\n                    statMin.add(Double.NaN)\n                    statMax.add(Double.NaN)\n\n                    statCount.add(count)\n\n                    // Note: outliers will also need 'width' value,\n                    // for the 'dodge' positioning to work correctly for all data-points.\n                }\n\n                // add 'box' data-point\n                statX.add(x)\n                statY.add(Double.NaN)  // no Y for 'box' data-point\n                statMiddle.add(middle)\n                statLower.add(lowerHinge)\n                statUpper.add(upperHinge)\n                statMin.add(lowerWhisker)\n                statMax.add(upperWhisker)\n\n                statCount.add(count)\n            }\n\n            return mutableMapOf(\n                Stats.X to statX,\n                Stats.Y to statY,\n                Stats.MIDDLE to statMiddle,\n                Stats.LOWER to statLower,\n                Stats.UPPER to statUpper,\n                Stats.Y_MIN to statMin,\n                Stats.Y_MAX to statMax,\n                Stats.COUNT to statCount,\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataFrame\n\ninternal class Contour private constructor() {\n\n    private val myContourX = ArrayList<Double>()\n    private val myContourY = ArrayList<Double>()\n    private val myContourLevel = ArrayList<Double>()\n    private val myContourGroup = ArrayList<Double>()\n\n    private var myGroup = 0.0\n\n    private val dataFrame: DataFrame\n        get() = DataFrame.Builder()\n                .putNumeric(Stats.X, myContourX)\n                .putNumeric(Stats.Y, myContourY)\n                .putNumeric(Stats.LEVEL, myContourLevel)\n                .putNumeric(Stats.GROUP, myContourGroup)\n                .build()\n\n    fun add(polygon: List<DoubleVector>, fillLevel: Double) {\n        for (p in polygon) {\n            myContourX.add(p.x)\n            myContourY.add(p.y)\n            myContourLevel.add(fillLevel)\n            myContourGroup.add(myGroup)\n        }\n        // each polygon in its own group\n        myGroup += 1.0\n    }\n\n    companion object {\n\n        fun getPathDataFrame(\n                levels: List<Double>, pathListByLevel: Map<Double, List<List<DoubleVector>>>): DataFrame {\n            val contour = Contour()\n            for (level in levels) {\n                val paths = pathListByLevel[level]!!\n                for (path in paths) {\n                    contour.add(path, level)\n                }\n            }\n            return contour.dataFrame\n        }\n\n        fun getPolygonDataFrame(\n                fillLevels: List<Double>, polygonListByFillLevel: Map<Double, List<DoubleVector>>): DataFrame {\n            val contour = Contour()\n\n            for (fillLevel in fillLevels) {\n                val polygon = polygonListByFillLevel[fillLevel]!!\n                contour.add(polygon, fillLevel)\n            }\n\n            return contour.dataFrame\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.stat.ContourStatUtil.removePathByEndpoints\n\nclass ContourFillHelper(xRange: ClosedRange<Double>, yRange: ClosedRange<Double>) {\n\n    private val myLowLeft: DoubleVector\n    private val myLowRight: DoubleVector\n    private val myUpLeft: DoubleVector\n    private val myUpRight: DoubleVector\n\n    init {\n        val xMin = xRange.lowerEnd\n        val xMax = xRange.upperEnd\n        val yMin = yRange.lowerEnd\n        val yMax = yRange.upperEnd\n        myLowLeft = DoubleVector(xMin, yMin)\n        myLowRight = DoubleVector(xMax, yMin)\n        myUpLeft = DoubleVector(xMin, yMax)\n        myUpRight = DoubleVector(xMax, yMax)\n    }\n\n    fun createPolygons(\n            pathByLevels: Map<Double, List<List<DoubleVector>>>, levels: List<Double>, fillLevels: List<Double>): Map<Double, List<DoubleVector>> {\n\n        val result = HashMap<Double, List<DoubleVector>>()\n\n        //getBoundary\n        val allPaths = ArrayList<List<DoubleVector>>()\n        for (level in pathByLevels.values) {\n            allPaths.addAll(level)\n        }\n\n        val cornerPoints = ArrayList<DoubleVector>()\n        val outerMap = createOuterMap(allPaths, cornerPoints)\n\n\n        val n = pathByLevels.keys.size\n\n        // The designated area is always to the left\n        for (i in 0 until n + 1) {\n            var polygonPieces: MutableList<List<DoubleVector>> = ArrayList()\n            val value = ArrayList<DoubleVector>()\n            if (i > 0) {\n                polygonPieces.addAll(\n                    reverseAll(\n                        pathByLevels[levels[i - 1]]!!\n                    )\n                )\n            }\n            if (i < n) {\n                polygonPieces.addAll(pathByLevels[levels[i]]!!)\n            }\n            polygonPieces = createClosedPolygonLevels(polygonPieces, outerMap, cornerPoints)\n            for (path in polygonPieces) {\n                value.addAll(path)\n            }\n            result[fillLevels[i]] = value\n        }\n        return result\n    }\n\n    private fun createClosedPolygonLevels(\n            openLevels: List<List<DoubleVector>>, outerMap: Map<DoubleVector, DoubleVector>, cornerPoints: List<DoubleVector>): MutableList<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n\n        val donePath = HashSet<MutableList<DoubleVector>>()\n        //Add boundary part to each openPath\n        for (level in openLevels) {\n            val levelCopy = ArrayList(level)\n            val p0 = levelCopy[0]\n            var p1 = levelCopy[levelCopy.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                result.add(levelCopy)\n                continue\n            }\n            //p1 remains to be the end of levelCopy\n            var pi2 = outerMap[p1]!!\n            levelCopy.add(pi2)\n            p1 = pi2\n            while (cornerPoints.contains(p1)) {\n                pi2 = outerMap[p1]!!\n                levelCopy.add(pi2)\n                p1 = pi2\n            }\n            donePath.add(levelCopy)\n        }\n\n        val pathByEndPoint = HashMap<DoubleVector, MutableList<DoubleVector>>()\n\n        for (path in donePath) {\n            val p0 = path[0]\n            val p1 = path[path.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                result.add(path)\n                continue\n            }\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n                removePathByEndpoints(path0, pathByEndPoint)\n                removePathByEndpoints(path1, pathByEndPoint)\n\n                val longPath: MutableList<DoubleVector>\n                if (path0 === path1) {\n                    //a cycle is formed\n                    path0!!.addAll(path.subList(1, path.size))\n                    result.add(path0)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath = path0\n                    longPath.addAll(path.subList(1, path.size - 1))\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath = path1!!\n                    longPath.addAll(0, path.subList(0, path.size - 1))\n                } else { //path0!=null\n                    longPath = path0\n                    longPath.addAll(path.subList(1, path.size))\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                pathByEndPoint[path[0]] = path\n                pathByEndPoint[path[path.size - 1]] = path\n            }\n        }\n\n        if (!pathByEndPoint.keys.isEmpty()) {\n            throw IllegalArgumentException(\"Some paths are not cleared yet there is something wrong!\" + pathByEndPoint.keys.size)\n        }\n\n        // check\n        for (path in result) {\n            if (path[0] != path[path.size - 1]) {\n                throw IllegalArgumentException(\"The polygons are not entirely closed!\")\n            }\n        }\n        return result\n    }\n\n    //counterclockwise\n    //update corner points for record\n    private fun createOuterMap(paths: List<List<DoubleVector>>, cornerPoints: MutableList<DoubleVector>): Map<DoubleVector, DoubleVector> {\n        val points = ArrayList<DoubleVector>()\n        for (path in paths) {\n            if (path[0] != path[path.size - 1]) {\n                points.add(path[0])\n                points.add(path[path.size - 1])\n            }\n        }\n\n        val result = HashMap<DoubleVector, DoubleVector>()\n\n        val list = ArrayList<MutableList<DoubleVector>>()\n        for (i in 0..3) {\n            list.add(ArrayList())\n        }\n\n        for (point in points) {\n            val kind = getKind(point)\n            when (kind) {\n                BorderKind.DOWN -> list[0].add(point)\n                BorderKind.RIGHT -> list[1].add(point)\n                BorderKind.UP -> list[2].add(point)\n                BorderKind.LEFT -> list[3].add(point)\n            }\n        }\n\n        list[0].sortWith(Comparator { o1, o2 -> o1.x.compareTo(o2.x) })\n        list[1].sortWith(Comparator { o1, o2 -> o1.y.compareTo(o2.y) })\n        list[2].sortWith(Comparator { o1, o2 -> o2.x.compareTo(o1.x) })\n        list[3].sortWith(Comparator { o1, o2 -> o2.y.compareTo(o1.y) })\n\n        // According to getKind: myLowLeft -> DOWN; myLowRight -> DOWN; myUpRight -> RIGHT; myUpLeft -> LEFT\n        val prepareMap = ArrayList<DoubleVector>()\n        if (!list[0].contains(myLowLeft)) {\n            prepareMap.add(myLowLeft)\n            cornerPoints.add(myLowLeft)\n        }\n        prepareMap.addAll(list[0])\n        if (!list[0].contains(myLowRight)) {\n            prepareMap.add(myLowRight)\n            cornerPoints.add(myLowRight)\n        }\n        prepareMap.addAll(list[1])\n        if (!list[1].contains(myUpRight)) {\n            prepareMap.add(myUpRight)\n            cornerPoints.add(myUpRight)\n        }\n        prepareMap.addAll(list[2])\n        if (!list[3].contains(myUpLeft)) {\n            prepareMap.add(myUpLeft)\n            cornerPoints.add(myUpLeft)\n        }\n        prepareMap.addAll(list[3])\n        prepareMap.add(prepareMap[0])\n        for (i in 0 until prepareMap.size - 1) {\n            result[prepareMap[i]] = prepareMap[i + 1]\n        }\n\n        return result\n    }\n\n    private fun getKind(point: DoubleVector): BorderKind {\n        return if (belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.DOWN\n        } else if (belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && !belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.RIGHT\n        } else if (!belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && !belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.UP\n        } else if (!belowOrOnLine(\n                myLowLeft,\n                myUpRight,\n                point\n            ) && belowOrOnLine(\n                myUpLeft,\n                myLowRight,\n                point\n            )\n        ) {\n            BorderKind.LEFT\n        } else {\n            throw IllegalArgumentException(\"The Contour Point is not on the border $point\")\n        }\n    }\n\n    private enum class BorderKind {\n        DOWN, RIGHT, UP, LEFT\n    }\n\n    companion object {\n\n        fun computeFillLevels(zRange: ClosedRange<Double>, levels: List<Double>): List<Double> {\n            val fillLevels = ArrayList<Double>()\n            fillLevels.add(zRange.lowerEnd)\n            for (i in 0 until levels.size - 1) {\n                fillLevels.add((levels[i] + levels[i + 1]) / 2.0)\n            }\n            fillLevels.add(zRange.upperEnd)\n            return fillLevels\n        }\n\n        private fun <E> reverseAll(list: List<List<E>>): List<List<E>> {\n            val result = ArrayList<List<E>>()\n            for (item in list) {\n                val copy = ArrayList(item)\n                copy.reverse()\n                result.add(copy)\n            }\n            return result\n        }\n\n        // a.x<b.x\n        private fun belowOrOnLine(a: DoubleVector, b: DoubleVector, test: DoubleVector): Boolean {\n            val value = test.subtract(a)\n            val standard = b.subtract(a)\n\n            return standard.y * value.x - value.y * standard.x >= 0\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\n\n/**\n * see doc for geom_contour/stat_contour\n *\n *\n * see also examples: https://www.inside-r.org/packages/cran/ggplot2/docs/stat_contour\n *\n *\n *\n *\n * Defaults:\n *\n *\n * geom = \"path\"\n * position = \"identity\"\n *\n *\n * Other params:\n *\n *\n * bins (def - 10) - Number of bins (overridden by binwidth)\n * binwidth - distance between contours.\n *\n *\n *\n *\n * Adds columns:\n *\n *\n * level - height of contour\n */\nclass ContourStat(binCount: Int, binWidth: Double?) : BaseStat(DEF_MAPPING) {\n\n    private val myBinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.Z)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y, Aes.Z)) {\n            return withEmptyStatValues()\n        }\n\n        val levels = ContourStatUtil.computeLevels(data, myBinOptions)\n            ?: return DataFrame.Builder.emptyFrame()\n\n        val pathListByLevel = ContourStatUtil.computeContours(data, levels)\n\n        // transform paths to x/y data\n        return Contour.getPathDataFrame(levels, pathListByLevel)\n    }\n\n    companion object {\n        const val DEF_BIN_COUNT = 10\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isSubTiny\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ContourStatUtil {\n    private val xLoc = doubleArrayOf(0.0, 1.0, 1.0, 0.0, .5)\n    private val yLoc = doubleArrayOf(0.0, 0.0, 1.0, 1.0, .5)\n\n    /**\n     * @param xs - series defining x-coordinates of data-points\n     * @return Pair(col, row) or fail if not a regular grid\n     */\n    internal fun estimateRegularGridShape(xs: List<Double?>): Pair<Int, Int> {\n        // num of columns\n        // regular X/Y grid is expected\n        var colCount = 0\n        var x0: Double? = null\n        for (x in xs) {\n            if (x0 == null) {\n                x0 = x\n            } else if (x == x0) {\n                break\n            }\n            colCount++\n        }\n\n        if (colCount <= 1) {\n            throw IllegalArgumentException(\"Data grid must be at least 2 columns wide (was $colCount)\")\n        }\n        val rowCount = xs.size / colCount\n        if (rowCount <= 1) {\n            throw IllegalArgumentException(\"Data grid must be at least 2 rows tall (was $rowCount)\")\n        }\n\n        return Pair(colCount, rowCount)\n    }\n\n    fun computeLevels(data: DataFrame, binOptions: BinStatUtil.BinOptions): List<Double>? {\n        if (!(data.has(TransformVar.X) && data.has(TransformVar.Y) && data.has(\n                TransformVar.Z\n            ))\n        ) {\n            return null\n        }\n        val zRange = data.range(TransformVar.Z)\n        return computeLevels(zRange, binOptions)\n    }\n\n    fun computeLevels(zRange: ClosedRange<Double>?, binOptions: BinStatUtil.BinOptions): List<Double>? {\n        if (zRange == null || isSubTiny(zRange)) return null\n\n        val b = BinStatUtil.binCountAndWidth(SeriesUtil.span(zRange), binOptions)\n        val levels = ArrayList<Double>()\n        for (i in 0 until b.count) {\n            var level = i * b.width + zRange.lowerEnd\n            level += b.width / 2   // shift all levels half-step to make 1-st level contour visible\n            levels.add(level)\n        }\n        return levels\n    }\n\n    internal fun computeContours(data: DataFrame, levels: List<Double>): Map<Double, List<List<DoubleVector>>> {\n        val xVector = data.getNumeric(TransformVar.X)\n        val zVector = data.getNumeric(TransformVar.Z)\n\n        val shape = estimateRegularGridShape(xVector)\n        val colCount = shape.first\n        val rowCount = shape.second\n\n        val xRange = data.range(TransformVar.X)!!\n        val yRange = data.range(TransformVar.Y)!!\n\n        return computeContours(\n            xRange,\n            yRange,\n            colCount,\n            rowCount,\n            zVector,\n            levels\n        )\n    }\n\n    fun computeContours(\n        xRange: ClosedRange<Double>,\n        yRange: ClosedRange<Double>,\n        colCount: Int,\n        rowCount: Int,\n        data: List<Double?>,\n        levels: List<Double>\n    ): Map<Double, List<List<DoubleVector>>> {\n\n        val xStep = SeriesUtil.span(xRange) / (colCount - 1)\n        val yStep = SeriesUtil.span(yRange) / (rowCount - 1)\n        val origin = DoubleVector(xRange.lowerEnd, yRange.lowerEnd)\n\n        val pathListByLevel = HashMap<Double, List<List<DoubleVector>>>()\n        for (level in levels) {\n            val levelSegments =\n                computeSegments(colCount, rowCount, data, level)\n            val paths = joinSegments(levelSegments)\n            // checkEdges(paths, colCount, rowCount); // debug use\n            var pathsReal =\n                convertPaths(paths, xStep, yStep, origin, level)\n            pathsReal = confirmPaths(pathsReal)\n            pathListByLevel[level] = pathsReal\n        }\n\n        return pathListByLevel\n    }\n\n    private fun joinSegments(segments: List<Pair<Edge, Edge>>): List<List<Edge>> {\n        val pathList = ArrayList<List<Edge>>()\n\n        val pathByEndPoint = HashMap<Edge, MutableList<Edge>>()\n\n        for (segment in segments) {\n            val p0 = segment.first\n            val p1 = segment.second\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n\n                if (path0 != null) {\n                    pathByEndPoint.remove(path0[0])\n                    pathByEndPoint.remove(path0[path0.size - 1])\n                }\n                if (path1 != null) {\n                    pathByEndPoint.remove(path1[0])\n                    pathByEndPoint.remove(path1[path1.size - 1])\n                }\n\n                val longPath: MutableList<Edge>\n                if (path0 === path1) {\n                    //a cycle is formed\n                    path0!!.add(segment.second)\n                    pathList.add(path0)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath = path0\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath = path1!!\n                    longPath.add(0, segment.first)\n                } else { // path0!=null\n                    longPath = path0\n                    longPath.add(segment.second)\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                val path = ArrayList<Edge>()\n                path.add(segment.first)\n                path.add(segment.second)\n                pathByEndPoint[segment.first] = path\n                pathByEndPoint[segment.second] = path\n            }\n        }\n\n        // collect paths (don't duplicate)\n        val pathSet = HashSet(pathByEndPoint.values)\n        for (path in pathSet) {\n            pathList.add(path)\n        }\n        return pathList\n    }\n\n    private fun convertPaths(\n        paths: List<List<Edge>>,\n        xStep: Double,\n        yStep: Double,\n        origin: DoubleVector,\n        level: Double?\n    ): List<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n\n        for (path in paths) {\n            val temp = ArrayList<DoubleVector>()\n            var lastPoint: DoubleVector? = null\n            for (edge in path) {\n                var intersect = edge.intersect(level!!)\n                intersect = DoubleVector(xStep * intersect.x, yStep * intersect.y).add(origin)\n                // in case two adjacent double vectors are the same\n                if (intersect == lastPoint) {\n                    continue\n                }\n                temp.add(intersect)\n                lastPoint = intersect\n            }\n            // in case of slight computational error in loops\n            if (path[0] == path[path.size - 1] && temp[0] != temp[temp.size - 1]) {\n                temp[temp.size - 1] = temp[0]\n            }\n            if (temp.size > 1) {\n                result.add(temp)\n            }\n        }\n\n        return result\n    }\n\n    private fun confirmPaths(paths: List<List<DoubleVector>>): List<List<DoubleVector>> {\n        // join paths that share the same end points\n        val newPaths = ArrayList<List<DoubleVector>>()\n\n        val pathByEndPoint = HashMap<DoubleVector, List<DoubleVector>>()\n\n        for (path in paths) {\n            val p0 = path[0]\n            val p1 = path[path.size - 1]\n            //if cycle\n            if (p0 == p1) {\n                newPaths.add(path)\n                continue\n            }\n\n            if (pathByEndPoint.containsKey(p0) || pathByEndPoint.containsKey(p1)) {\n                //remove need to be modified paths\n                val path0 = pathByEndPoint[p0]\n                val path1 = pathByEndPoint[p1]\n                removePathByEndpoints(path0, pathByEndPoint)\n                removePathByEndpoints(path1, pathByEndPoint)\n\n                val longPath = ArrayList<DoubleVector>()\n                if (path0 === path1) {\n                    //a cycle is formed\n                    longPath.addAll(path0!!)\n                    longPath.addAll(path.subList(1, path.size))\n                    newPaths.add(longPath)\n                    continue\n                } else if (path0 != null && path1 != null) {\n                    longPath.addAll(path0)\n                    longPath.addAll(path.subList(1, path.size - 1))\n                    longPath.addAll(path1)\n                } else if (path0 == null) { //path1!=null\n                    longPath.addAll(path1!!)\n                    longPath.addAll(0, path.subList(0, path.size - 1))\n                } else { //path0!=null\n                    longPath.addAll(path0)\n                    longPath.addAll(path.subList(1, path.size))\n                }\n\n                pathByEndPoint[longPath[0]] = longPath\n                pathByEndPoint[longPath[longPath.size - 1]] = longPath\n            } else {\n                pathByEndPoint[path[0]] = path\n                pathByEndPoint[path[path.size - 1]] = path\n            }\n        }\n\n        val pathSet = HashSet(pathByEndPoint.values)\n        for (path in pathSet) {\n            newPaths.add(path)\n        }\n\n        // prevent the degenerated polygons from providing weird outputs\n        val result = ArrayList<List<DoubleVector>>()\n        for (path in newPaths) {\n            result.addAll(pathSeparator(path))\n        }\n        return result\n    }\n\n    internal fun <T : List<DoubleVector>> removePathByEndpoints(\n        path: List<DoubleVector>?,\n        pathByEndPoint: MutableMap<DoubleVector, T>\n    ) {\n        if (path != null) {\n            pathByEndPoint.remove(path[0])\n            pathByEndPoint.remove(path[path.size - 1])\n        }\n    }\n\n    private fun pathSeparator(path: List<DoubleVector>): List<List<DoubleVector>> {\n        val result = ArrayList<List<DoubleVector>>()\n        var startIndex = 0\n        for (nextIndex in 1 until path.size - 1) {\n            if (path[startIndex] == path[nextIndex]) {\n                result.add(path.subList(startIndex, nextIndex + 1))\n                startIndex = nextIndex\n            }\n        }\n        if (startIndex == 0) {\n            return listOf(path)\n        } else {\n            result.add(path.subList(startIndex, path.size))\n            return result\n        }\n    }\n\n    private fun computeSegments(\n        colCount: Int,\n        rowCount: Int,\n        data: List<Double?>,\n        level: Double\n    ): List<Pair<Edge, Edge>> {\n\n        val segments = ArrayList<Pair<Edge, Edge>>()\n        for (row in 0 until rowCount - 1) {\n            for (col in 0 until colCount - 1) {\n                val i0 = row * colCount + col\n                val i1 = row * colCount + col + 1 // next right\n                val i2 = (row + 1) * colCount + col + 1 // next right & up\n                val i3 = (row + 1) * colCount + col // next up\n\n                val v = DoubleArray(5)\n                v[0] = data[i0]!!\n                v[1] = data[i1]!!\n                v[2] = data[i2]!!\n                v[3] = data[i3]!!\n\n                var min = v[0]\n                var max = v[0]\n                for (i in 1..3) {\n                    min = min(min, v[i])\n                    max = max(max, v[i])\n                }\n\n                if (min == max) {\n                    // special case: all points are in the same plane - drop\n                    continue\n                }\n\n                // v[4] = (v[0] + v[1] + v[2] + v[3]) / 4;   // center  (average of corners)\n                v[4] = (v[0] + v[1] + v[2] + v[3] - min - max) / 2   // center  (average of corners)\n\n                if (level > min && level <= max) {\n\n                    val cellSegments =\n                        computeSegmentsForGridCell(level, v, col, row)\n                    segments.addAll(cellSegments)\n                }\n            }\n        }\n\n        return segments\n    }\n\n    private fun computeSegmentsForGridCell(\n        level: Double?,\n        value5: DoubleArray,\n        col: Int,\n        row: Int\n    ): List<Pair<Edge, Edge>> {\n        // triangles:\n        // [0] 0-1-4\n        // [1] 1-2-4\n        // [2] 2-3-4\n        // [3] 3-0-4\n        // check each edge of each triangle - find edges that cross the level 'plane'\n\n        val result = ArrayList<Pair<Edge, Edge>>()\n        val points = ArrayList<TripleVector>()\n        var tempVector: MutableList<TripleVector>\n        for (i in 0..4) {\n            points.add(\n                TripleVector(\n                    col + xLoc[i],\n                    row + yLoc[i],\n                    value5[i]\n                )\n            )\n        }\n\n        // All triangles are counterclockwise\n        for (i in 0..3) {\n            val i1 = (i + 1) % 4\n            tempVector = ArrayList()\n            tempVector.add(points[i])\n            tempVector.add(points[i1])\n            tempVector.add(points[4])\n            val temp = intersectionSegment(tempVector, level)\n            if (temp != null) {\n                result.add(temp)\n            }\n        }\n        return result\n    }\n\n    private fun intersectionSegment(vectors: List<TripleVector>, level: Double?): Pair<Edge, Edge>? {\n        // input: a counterclockwise triangle\n        // output: a segment, such that the higher part is always to the right\n        val type = vectors[0].getType(level!!) * 100 + vectors[1].getType(level) * 10 + vectors[2].getType(level)\n        val start: Edge\n        val end: Edge\n        when (type) {\n            100 -> {\n                start = Edge(vectors[2], vectors[0])\n                end = Edge(vectors[0], vectors[1])\n            }\n            10 -> {\n                start = Edge(vectors[0], vectors[1])\n                end = Edge(vectors[1], vectors[2])\n            }\n            1 -> {\n                start = Edge(vectors[1], vectors[2])\n                end = Edge(vectors[2], vectors[0])\n            }\n            110 -> {\n                start = Edge(vectors[0], vectors[2])\n                end = Edge(vectors[2], vectors[1])\n            }\n            101 -> {\n                start = Edge(vectors[2], vectors[1])\n                end = Edge(vectors[1], vectors[0])\n            }\n            11 -> {\n                start = Edge(vectors[1], vectors[0])\n                end = Edge(vectors[0], vectors[2])\n            }\n            else -> return null\n        }\n        return Pair(start, end)\n    }\n\n    // to check if all the side edges are on the boarder **Debug Use**\n    private fun checkEdges(paths: List<List<Edge>>, colCount: Int, rowCount: Int) {\n        for (path in paths) {\n            if (path[0] != path[path.size - 1]) {\n                checkEdge(path[0], colCount, rowCount)\n                checkEdge(path[path.size - 1], colCount, rowCount)\n            }\n        }\n    }\n\n    private fun checkEdge(edge: Edge, colCount: Int, rowCount: Int) {\n        val a = edge.myA\n        val b = edge.myB\n        if (a.myX == 0 && b.myX == 0) {\n            return\n        }\n        if (a.myY == 0 && b.myY == 0) {\n            return\n        }\n        if (a.myX == colCount - 1 && b.myX == colCount - 1) {\n            return\n        }\n        if (a.myY == rowCount - 1 && b.myY == rowCount - 1) {\n            return\n        }\n        throw IllegalArgumentException(\"Check Edge Failed\")\n    }\n\n    private class TripleVector internal constructor(x: Double, y: Double, val z: Double) {\n        val myX: Int\n        val myY: Int\n        private val myIsCenter: Int\n\n        val coord: DoubleVector\n            get() = DoubleVector(x, y)\n\n        val x: Double\n            get() = this.myX + 0.5 * myIsCenter\n\n        val y: Double\n            get() = this.myY + 0.5 * myIsCenter\n\n        init {\n            this.myX = x.toInt()\n            this.myY = y.toInt()\n            this.myIsCenter = if (x % 1 == 0.0) 0 else 1\n        }\n\n        override fun equals(other: Any?): Boolean {\n            if (this === other) return true\n            if (other == null || this::class != other::class) return false\n            val that = other as TripleVector?\n            return myX == that!!.myX && myY == that.myY && myIsCenter == that.myIsCenter\n        }\n\n        override fun hashCode(): Int {\n            return arrayOf(myX, myY, myIsCenter).hashCode()\n        }\n\n        fun getType(level: Double): Int {\n            return if (z >= level) {\n                1\n            } else {\n                0\n            }\n        }\n    }\n\n    private class Edge internal constructor(val myA: TripleVector, val myB: TripleVector) {\n\n        override fun equals(other: Any?): Boolean {\n            if (other !is Edge) {\n                return false\n            }\n            val obj = other as Edge?\n            return this.myA == obj!!.myA && this.myB == obj.myB || this.myA == obj.myB && this.myB == obj.myA\n        }\n\n        override fun hashCode(): Int {\n            return myA.coord.hashCode() + myB.coord.hashCode()\n        }\n\n        fun intersect(level: Double): DoubleVector {\n            val z0 = myA.z\n            val z1 = myB.z\n\n            if (level == z0) {\n                return myA.coord\n            }\n            if (level == z1) {\n                return myB.coord\n            }\n\n            val ratio = (z1 - z0) / (level - z0)\n            val x0 = myA.x\n            val y0 = myA.y\n            val x1 = myB.x\n            val y1 = myB.y\n            val x = x0 + (x1 - x0) / ratio\n            val y = y0 + (y1 - y0) / ratio\n            return DoubleVector(x, y)\n        }\n    }\n}// **Debug Use**\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nclass ContourfStat(binCount: Int, binWidth: Double?) : BaseStat(DEF_MAPPING) {\n\n    private val myBinOptions = BinStatUtil.BinOptions(binCount, binWidth)\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.Y, Aes.Z)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y, Aes.Z)) {\n            return withEmptyStatValues()\n        }\n\n        val levels = ContourStatUtil.computeLevels(data, myBinOptions)\n            ?: return DataFrame.Builder.emptyFrame()\n\n        val pathListByLevel = ContourStatUtil.computeContours(data, levels)\n\n        val xRange = data.range(TransformVar.X)!!\n        val yRange = data.range(TransformVar.Y)!!\n        val zRange = data.range(TransformVar.Z)!!\n        val helper = ContourFillHelper(xRange, yRange)\n        val fillLevels = ContourFillHelper.computeFillLevels(zRange, levels)\n        val polygonListByFillLevel = helper.createPolygons(pathListByLevel, levels, fillLevels)\n\n        return Contour.getPolygonDataFrame(\n            fillLevels,\n            polygonListByFillLevel\n        )\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.stat.CorrelationUtil.correlationMatrix\nimport jetbrains.datalore.plot.base.stat.math3.correlationPearson\nimport kotlin.math.abs\n\n/**\n * Computes correlation between numeric variables in data.\n * Creates a data-frame with the following variables:\n *   - '..x..' : X coordinates\n *   - '..y..' : Y coordinates\n *   - '..corr..' : correlation (in range -1..1)\n *   - '..corr_abs..' : absolute value of correlation (in range 0..1)\n */\nclass CorrelationStat(\n    val correlationMethod: Method,\n    val type: Type,\n    val fillDiagonal: Boolean,\n    val threshold: Double\n) : BaseStat(DEF_MAPPING) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        require(correlationMethod == Method.PEARSON) {\n            \"Unsupported correlation method: $correlationMethod (only Pearson is currently available)\"\n        }\n\n        require(threshold in 0.0..1.0) {\n            \"Threshold value:  $threshold must be in interval [0.0, 1.0]\"\n        }\n\n        val cm = correlationMatrix(data, type, fillDiagonal, ::correlationPearson, threshold)\n        val values = cm.getNumeric(Stats.CORR)\n        val abs: List<Double?> = values.map { it?.let(::abs) }\n\n        return cm.builder().putNumeric(Stats.CORR_ABS, abs).build()\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf()\n    }\n\n    enum class Method {\n        PEARSON,\n        SPEARMAN,\n        KENDALL\n    }\n\n    enum class Type {\n        FULL,\n        UPPER,\n        LOWER\n    }\n\n    companion object {\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.Y,\n            Aes.COLOR to Stats.CORR,\n            Aes.FILL to Stats.CORR,\n            Aes.LABEL to Stats.CORR\n        )\n\n        val DEF_CORRELATION_METHOD = Method.PEARSON\n        val DEF_TYPE = Type.FULL\n        const val DEF_FILL_DIAGONAL = true\n        const val DEF_THRESHOLD = 0.0\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil.isNumeric\nimport jetbrains.datalore.plot.base.stat.regression.allFinite\nimport kotlin.math.abs\nimport kotlin.Pair as Pair\n\nobject CorrelationUtil {\n\n    fun correlation(\n        lxs: List<Double?>, lys: List<Double?>,\n        correlationFunction: (DoubleArray, DoubleArray) -> Double\n    ): Double {\n        val (xs, ys) = allFinite(lxs, lys)\n        return correlationFunction(xs, ys)\n    }\n\n    private fun createComparator(vars: List<DataFrame.Variable>): Comparator<String> {\n        val indexMap = vars.withIndex().map { it.value.label to it.index }.toMap()\n\n        return Comparator { a: String, b: String ->\n            val lhsWeight = indexMap[a] ?: error(\"Unknown variable label ${a}.\")\n            val rhsWeight = indexMap[b] ?: error(\"Unknown variable label ${b}.\")\n            return@Comparator lhsWeight - rhsWeight\n        }\n    }\n\n    fun correlationMatrix(\n        data: DataFrame,\n        type: CorrelationStat.Type,\n        fillDiagonal: Boolean,\n        correlationFunction: (DoubleArray, DoubleArray) -> Double,\n        threshold: Double = CorrelationStat.DEF_THRESHOLD\n    ): DataFrame {\n        val numerics = data.variables().filter { isNumeric(data, it.name) }\n        val knownVars = mutableSetOf<String>()\n        val corrData = mutableMapOf<Pair<String, String>, Double>()\n\n        fun addCorrelation(varX: String, varY: String, v: Double) {\n            if (abs(v) >= threshold) {\n                knownVars.add(varX)\n                knownVars.add(varY)\n                corrData[varX to varY] = v\n            }\n        }\n\n        for ((i, vx) in numerics.withIndex()) {\n            val xs = data.getNumeric(vx)\n\n            if (fillDiagonal) {    // values on main diagonal does not require calculations\n                addCorrelation(vx.label, vx.label, 1.0)\n            }\n\n            for (j in 0 until i) {\n                val vy = numerics[j]\n                val ys = data.getNumeric(vy)\n                val c = correlation(xs, ys, correlationFunction)\n\n                if (type == CorrelationStat.Type.FULL || type == CorrelationStat.Type.LOWER) {\n                    addCorrelation(vx.label, vy.label, c)\n                }\n\n                if (type == CorrelationStat.Type.FULL || type == CorrelationStat.Type.UPPER) {\n                    addCorrelation(vy.label, vx.label, c)\n                }\n            }\n        }\n\n        val var1 = arrayListOf<String>()\n        val var2 = arrayListOf<String>()\n        val corr = arrayListOf<Double?>()\n\n        // put all correlation matrix values (including nulls)\n        // to result dataframe in proper order, to keep matrix shape.\n        val sortedVars = knownVars.sortedWith(createComparator(numerics))\n\n        for (x in sortedVars) {\n            for (y in sortedVars) {\n                var1.add(x)\n                var2.add(y)\n                corr.add(corrData[x to y])\n            }\n        }\n\n        return DataFrame.Builder()\n            .putDiscrete(Stats.X, var1)\n            .putDiscrete(Stats.Y, var2)\n            .putNumeric(Stats.CORR, corr)\n            .build()\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * Counts the number of cases at each x position.\n * (or if the weight aesthetic is supplied, the sum of the weights)\n */\ninternal class CountStat : BaseStat(DEF_MAPPING) {\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val valuesX = data.getNumeric(TransformVar.X)\n        val weight = BinStatUtil.weightVector(valuesX.size, data)\n\n        val statX = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n\n        val countByX = countByX(valuesX, weight)\n        for (x in countByX.keys) {\n            statX.add(x)\n            statCount.add(countByX[x]!!.get())\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.COUNT, statCount)\n            .build()\n    }\n\n    companion object {\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.COUNT\n        )\n\n        private fun countByX(valuesX: List<Double?>, weight: List<Double?>): Map<Double, MutableDouble> {\n            val result = LinkedHashMap<Double, MutableDouble>()\n            for (i in valuesX.indices) {\n                val x = valuesX[i]\n                if (SeriesUtil.isFinite(x)) {\n                    if (!result.containsKey(x!!)) {\n                        result[x] = MutableDouble(0.0)\n                    }\n                    result[x]!!.getAndAdd(SeriesUtil.asFinite(weight[i], 0.0))\n                }\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.math3.BlockRealMatrix\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass Density2dStat constructor(\n    bandWidthX: Double?,\n    bandWidthY: Double?,\n    bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    adjust: Double,\n    kernel: DensityStat.Kernel,\n    nX: Int,\n    nY: Int,\n    isContour: Boolean,\n    binCount: Int,\n    binWidth: Double\n\n) : AbstractDensity2dStat(\n    bandWidthX = bandWidthX,\n    bandWidthY = bandWidthY,\n    bandWidthMethod = bandWidthMethod,\n    adjust = adjust,\n    kernel = kernel,\n    nX = nX,\n    nY = nY,\n    isContour = isContour,\n    binCount = binCount,\n    binWidth = binWidth\n) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xVector = data.getNumeric(TransformVar.X)\n        val yVector = data.getNumeric(TransformVar.Y)\n\n        // if no data, return empty\n        if (xVector.isEmpty()) {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        // if length of x and y doesn't match, throw error\n        if (xVector.size != yVector.size) {\n            throw RuntimeException(\"len(x)= \" + xVector.size + \" and len(y)= \" + yVector.size + \" doesn't match!\")\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val bandWidth = DoubleArray(2)\n//        bandWidth[0] = if (bandWidths != null) bandWidths!![0] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            xVector\n//        )\n        bandWidth[0] = getBandWidthX(xVector)\n//        bandWidth[1] = if (bandWidths != null) bandWidths!![1] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            yVector\n//        )\n        bandWidth[1] = getBandWidthY(yVector)\n\n        val stepsX = DensityStatUtil.createStepValues(xRange!!, nX)\n        val stepsY = DensityStatUtil.createStepValues(yRange!!, nY)\n\n        // weight aesthetics\n        val groupWeight = BinStatUtil.weightVector(xVector.size, data)\n\n        val matrixX = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                xVector,\n                stepsX,\n                kernelFun,\n                bandWidth[0],\n                adjust,\n                groupWeight\n            )\n        )\n        val matrixY = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                yVector,\n                stepsY,\n                kernelFun,\n                bandWidth[1],\n                adjust,\n                groupWeight\n            )\n        )\n        // size: nY * nX\n        val matrixFinal = matrixY.multiply(matrixX.transpose())\n\n        for (row in 0 until nY) {\n            for (col in 0 until nX) {\n                statX.add(stepsX[col])\n                statY.add(stepsY[row])\n                statDensity.add(matrixFinal.getEntry(row, col) / SeriesUtil.sum(groupWeight))\n                //newGroups.add((double) (int) group);\n            }\n        }\n\n        if (isContour) {\n            val zRange = SeriesUtil.range(statDensity)\n            val levels = ContourStatUtil.computeLevels(zRange, binOptions)\n                ?: return DataFrame.Builder.emptyFrame()\n\n            val pathListByLevel = ContourStatUtil.computeContours(\n                xRange,\n                yRange,\n                nX,\n                nY,\n                statDensity,\n                levels\n            )\n\n            return Contour.getPathDataFrame(levels, pathListByLevel)\n        } else {\n            return DataFrame.Builder()\n                .putNumeric(Stats.X, statX)\n                .putNumeric(Stats.Y, statY)\n                .putNumeric(Stats.DENSITY, statDensity)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.math3.BlockRealMatrix\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass Density2dfStat(\n    bandWidthX: Double?,\n    bandWidthY: Double?,\n    bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n    adjust: Double,\n    kernel: DensityStat.Kernel,\n    nX: Int,\n    nY: Int,\n    isContour: Boolean,\n    binCount: Int,\n    binWidth: Double\n\n) : AbstractDensity2dStat(\n    bandWidthX = bandWidthX,\n    bandWidthY = bandWidthY,\n    bandWidthMethod = bandWidthMethod,\n    adjust = adjust,\n    kernel = kernel,\n    nX = nX,\n    nY = nY,\n    isContour = isContour,\n    binCount = binCount,\n    binWidth = binWidth\n) {\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X, Aes.Y)) {\n            return withEmptyStatValues()\n        }\n\n        val xVector = data.getNumeric(TransformVar.X)\n        val yVector = data.getNumeric(TransformVar.Y)\n\n        // if no data, return empty\n        if (xVector.isEmpty()) {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        // if length of x and y doesn't match, throw error\n        if (xVector.size != yVector.size) {\n            throw RuntimeException(\"len(x)= \" + xVector.size + \" and len(y)= \" + yVector.size + \" doesn't match!\")\n        }\n\n        val xRange = statCtx.overallXRange()\n        val yRange = statCtx.overallYRange()\n\n        val statX = ArrayList<Double>()\n        val statY = ArrayList<Double>()\n        val statDensity = ArrayList<Double>()\n\n        val bandWidth = DoubleArray(2)\n//        bandWidth[0] = if (bandWidths != null) bandWidths!![0] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            xVector\n//        )\n        bandWidth[0] = getBandWidthX(xVector)\n\n//        bandWidth[1] = if (bandWidths != null) bandWidths!![1] else DensityStatUtil.bandWidth(\n//            bandWidthMethod,\n//            yVector\n//        )\n        bandWidth[1] = getBandWidthY(yVector)\n\n        val stepsX = DensityStatUtil.createStepValues(xRange!!, nX)\n        val stepsY = DensityStatUtil.createStepValues(yRange!!, nY)\n\n        // weight aesthetics\n        val groupWeight = BinStatUtil.weightVector(xVector.size, data)\n\n        val matrixX = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                xVector,\n                stepsX,\n                kernelFun,\n                bandWidth[0],\n                adjust,\n                groupWeight\n            )\n        )\n        val matrixY = BlockRealMatrix(\n            DensityStatUtil.createRawMatrix(\n                yVector,\n                stepsY,\n                kernelFun,\n                bandWidth[1],\n                adjust,\n                groupWeight\n            )\n        )\n        // size: nY * nX\n        val matrixFinal = matrixY.multiply(matrixX.transpose())\n\n        for (row in 0 until nY) {\n            for (col in 0 until nX) {\n                statX.add(stepsX[col])\n                statY.add(stepsY[row])\n                statDensity.add(matrixFinal.getEntry(row, col) / SeriesUtil.sum(groupWeight))\n            }\n        }\n\n        if (isContour) {\n            // ToDo: change zrange into the range of z over entire dataset\n            val zRange = SeriesUtil.range(statDensity)\n            val levels = ContourStatUtil.computeLevels(zRange, binOptions)\n                ?: return DataFrame.Builder.emptyFrame()\n\n            val pathListByLevel = ContourStatUtil.computeContours(\n                xRange,\n                yRange,\n                nX,\n                nY,\n                statDensity,\n                levels\n            )\n            val helper = ContourFillHelper(xRange, yRange)\n            val fillLevels =\n                ContourFillHelper.computeFillLevels(zRange!!, levels)\n            val polygonListByFillLevel = helper.createPolygons(pathListByLevel, levels, fillLevels)\n\n            return Contour.getPolygonDataFrame(\n                fillLevels.subList(\n                    1,\n                    fillLevels.size\n                ), polygonListByFillLevel\n            )\n        } else {\n            return DataFrame.Builder()\n                .putNumeric(Stats.X, statX)\n                .putNumeric(Stats.Y, statY)\n                .putNumeric(Stats.DENSITY, statDensity)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.DensityStat.BandWidthMethod.NRD0\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * Computes kernel density estimate for 'n' values evenly distributed throughout the range of the input series.\n *\n * If size of the input series exceeds the 'fullScalMax' value, then the less accurate but more efficient computation replaces\n * highly inefficient 'full scan' computation.\n */\nclass DensityStat(\n    private val bandWidth: Double?,\n    private val bandWidthMethod: BandWidthMethod,  // Used is `bandWidth` is not set.\n    private val adjust: Double,\n    private val kernel: Kernel,\n    private val n: Int,\n    private val fullScalMax: Int\n) : BaseStat(DEF_MAPPING) {\n\n    init {\n        require(n <= MAX_N) { \"The input n = $n  > $MAX_N is too large!\" }\n    }\n\n    override fun consumes(): List<Aes<*>> {\n        return listOf(Aes.X, Aes.WEIGHT)\n    }\n\n    override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n        if (!hasRequiredValues(data, Aes.X)) {\n            return withEmptyStatValues()\n        }\n\n        val xs: List<Double>\n        val weights: List<Double>\n        if (data.has(TransformVar.WEIGHT)) {\n            val filtered = SeriesUtil.filterFinite(\n                data.getNumeric(TransformVar.X),\n                data.getNumeric(TransformVar.WEIGHT)\n            )\n            val xsFiltered = filtered[0]\n            val weightsFiltered = filtered[1]\n\n            val (xsSorted, weightsSorted) = xsFiltered\n                .zip(weightsFiltered).sortedBy { it.first }\n                .unzip()\n            xs = xsSorted\n            weights = weightsSorted\n\n        } else {\n            xs = data.getNumeric(TransformVar.X)\n                .filterNotNull().filter { it.isFinite() }\n                .sorted()\n            weights = List(xs.size) { 1.0 }\n        }\n\n        if (xs.isEmpty()) return withEmptyStatValues()\n\n        val rangeX = statCtx.overallXRange() ?: ClosedRange(-0.5, 0.5)\n\n        val statX = DensityStatUtil.createStepValues(rangeX, n)\n        val statDensity = ArrayList<Double>()\n        val statCount = ArrayList<Double>()\n        val statScaled = ArrayList<Double>()\n\n        val bandWidth = bandWidth ?: DensityStatUtil.bandWidth(\n            bandWidthMethod,\n            xs\n        )\n\n        val kernelFun: (Double) -> Double = DensityStatUtil.kernel(kernel)\n        val densityFunction: (Double) -> Double = when (xs.size <= fullScalMax) {\n            true -> DensityStatUtil.densityFunctionFullScan(\n                xs,\n                weights,\n                kernelFun,\n                bandWidth,\n                adjust\n            )\n            false -> DensityStatUtil.densityFunctionFast(\n                xs,\n                weights,\n                kernelFun,\n                bandWidth,\n                adjust\n            )\n        }\n\n        val nTotal = weights.sum()\n        for (x in statX) {\n            val d = densityFunction(x)\n            statCount.add(d)\n            statDensity.add(d / nTotal)\n        }\n\n        val maxm = statCount.maxOrNull()!!\n        for (d in statCount) {\n            statScaled.add(d / maxm)\n        }\n\n        return DataFrame.Builder()\n            .putNumeric(Stats.X, statX)\n            .putNumeric(Stats.DENSITY, statDensity)\n            .putNumeric(Stats.COUNT, statCount)\n            .putNumeric(Stats.SCALED, statScaled)\n            .build()\n    }\n\n    enum class Kernel {\n        GAUSSIAN,\n        RECTANGULAR,\n        TRIANGULAR,\n        BIWEIGHT,\n        EPANECHNIKOV,\n        OPTCOSINE,\n        COSINE\n    }\n\n    enum class BandWidthMethod {\n        NRD0,\n        NRD\n    }\n\n    companion object {\n        val DEF_KERNEL = Kernel.GAUSSIAN\n        const val DEF_ADJUST = 1.0\n        const val DEF_N = 512\n        val DEF_BW = NRD0\n        const val DEF_FULL_SCAN_MAX = 5000\n\n        private val DEF_MAPPING: Map<Aes<*>, DataFrame.Variable> = mapOf(\n            Aes.X to Stats.X,\n            Aes.Y to Stats.DENSITY\n        )\n\n        private const val MAX_N = 1024\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.*\n\nobject DensityStatUtil {\n\n    private const val DEF_STEP_SIZE = 0.5\n\n    private fun stdDev(data: List<Double>): Double {\n        var sum = 0.0\n        var counter = 0.0\n\n        for (i in data) {\n            sum += i\n        }\n        val mean = sum / data.size\n        for (i in data) {\n            counter += (i - mean).pow(2.0)\n        }\n        return sqrt(counter / data.size)\n    }\n\n    fun bandWidth(bw: DensityStat.BandWidthMethod, valuesX: List<Double?>): Double {\n        val mySize = valuesX.size\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val valuesXFinite = valuesX.filter { SeriesUtil.isFinite(it) } as List<Double>\n        val dataSummary = FiveNumberSummary(valuesXFinite)\n        val myIQR = dataSummary.thirdQuartile - dataSummary.firstQuartile\n        val myStdD = stdDev(valuesXFinite)\n\n        when (bw) {\n            DensityStat.BandWidthMethod.NRD0 -> {\n                if (myIQR > 0) {\n                    return 0.9 * min(myStdD, myIQR / 1.34) * mySize.toDouble().pow(-0.2)\n                }\n                if (myStdD > 0) {\n                    return 0.9 * myStdD * mySize.toDouble().pow(-0.2)\n                }\n            }\n            DensityStat.BandWidthMethod.NRD -> {\n                if (myIQR > 0) {\n                    return 1.06 * min(myStdD, myIQR / 1.34) * mySize.toDouble().pow(-0.2)\n                }\n                if (myStdD > 0) {\n                    return 1.06 * myStdD * mySize.toDouble().pow(-0.2)\n                }\n            }\n        }\n        return 1.0\n    }\n\n    fun kernel(ker: DensityStat.Kernel): (Double) -> Double {\n        return when (ker) {\n            DensityStat.Kernel.GAUSSIAN -> { value -> 1 / sqrt(2 * PI) * exp(-0.5 * value.pow(2.0)) }\n            DensityStat.Kernel.RECTANGULAR -> { value -> if (abs(value) <= 1) 0.5 else 0.0 }\n            DensityStat.Kernel.TRIANGULAR -> { value -> if (abs(value) <= 1) 1 - abs(value) else 0.0 }\n            DensityStat.Kernel.BIWEIGHT -> { value -> if (abs(value) <= 1) .9375 * (1 - value * value).pow(2.0) else 0.0 }\n            DensityStat.Kernel.EPANECHNIKOV -> { value -> if (abs(value) <= 1) .75 * (1 - value * value) else 0.0 }\n            DensityStat.Kernel.OPTCOSINE -> { value -> if (abs(value) <= 1) PI / 4 * cos(PI / 2 * value) else 0.0 }\n            else //case COSINE\n            -> { value -> if (abs(value) <= 1) (cos(PI * value) + 1) / 2 else 0.0 }\n        }\n    }\n\n    internal fun densityFunctionFullScan(\n        xs: List<Double>,\n        weights: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double\n    ): (Double) -> Double {\n        val h = bw * ad\n        return { x ->\n            var sum = 0.0\n            for (i in xs.indices) {\n                sum += ker((x - xs[i]) / h) * weights[i]\n            }\n            sum / h\n        }\n    }\n\n    internal fun densityFunctionFast(\n        xs: List<Double>,  // must be ordered!\n        weights: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double\n    ): (Double) -> Double {\n        val h = bw * ad\n        val cutoff = h * 5\n\n        return { x ->\n            var sum = 0.0\n            var from = xs.binarySearch(x - cutoff)\n            if (from < 0) {\n                from = -from - 1\n            }\n            var to = xs.binarySearch(x + cutoff)\n            if (to < 0) {\n                to = -to - 1\n            }\n\n            for (i in (from until to)) {\n                sum += ker((x - xs[i]) / h) * weights[i]\n            }\n            sum / h\n        }\n    }\n\n    fun createStepValues(range: ClosedRange<Double>, n: Int): List<Double> {\n        val x = ArrayList<Double>()\n        var min = range.lowerEnd\n        var max = range.upperEnd\n        val step: Double\n\n        if (max == min) {\n            max += DEF_STEP_SIZE\n            min -= DEF_STEP_SIZE\n        }\n        step = (max - min) / (n - 1)\n        for (i in 0 until n) {\n            x.add(min + step * i)\n        }\n        return x\n    }\n\n    fun toKernel(method: String): DensityStat.Kernel {\n        return when (method) {\n            \"gaussian\" -> DensityStat.Kernel.GAUSSIAN\n            \"rectangular\", \"uniform\" -> DensityStat.Kernel.RECTANGULAR\n            \"triangular\" -> DensityStat.Kernel.TRIANGULAR\n            \"biweight\", \"quartic\" -> DensityStat.Kernel.BIWEIGHT\n            \"epanechikov\", \"parabolic\" -> DensityStat.Kernel.EPANECHNIKOV\n            \"optcosine\" -> DensityStat.Kernel.OPTCOSINE\n            \"cosine\" -> DensityStat.Kernel.COSINE\n            else -> throw IllegalArgumentException(\n                \"Unsupported kernel method: '$method'.\\n\" +\n                        \"Use one of: gaussian, rectangular, triangular, biweight, epanechikov, optcosine, cos.\"\n            )\n        }\n    }\n\n    fun toBandWidthMethod(bw: String): DensityStat.BandWidthMethod {\n        return when (bw) {\n            \"nrd0\" -> DensityStat.BandWidthMethod.NRD0\n            \"nrd\" -> DensityStat.BandWidthMethod.NRD\n            else -> throw IllegalArgumentException(\n                \"Unsupported bandwidth method: '$bw'.\\n\" +\n                        \"Use one of: nrd0, nrd.\"\n            )\n        }\n    }\n\n    fun createRawMatrix(\n        values: List<Double?>,\n        list: List<Double>,\n        ker: (Double) -> Double,\n        bw: Double,\n        ad: Double,\n        weight: List<Double?>\n    ): Array<DoubleArray> {\n        val a = bw * ad\n        val n = values.size\n        val x = list.size\n        val result = Array(x) { DoubleArray(n) }\n\n        for (row in 0 until x) {\n            for (col in 0 until n) {\n                result[row][col] = ker((list[row] - values[col]!!) / a) * sqrt(weight[col]!!) / a\n            }\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.round\n\n/**\n * For a set of data, the minimum, first quartile, median, third quartile, and maximum.\n * Note: A boxplot is a visual display of the five-number summary.\n */\ninternal class FiveNumberSummary {\n\n    val min: Double\n    val max: Double\n    val median: Double\n    val firstQuartile: Double\n    // 25 %\n    val thirdQuartile: Double    // 75 %\n\n    private fun medianAtPointer(l: List<Double>, pointer: Double): Double {\n        val rint = round(pointer)\n        return if (pointer == rint) {\n            l[pointer.toInt()]\n        } else (l[ceil(pointer).toInt()] + l[floor(pointer).toInt()]) / 2.0\n    }\n\n    constructor(data: List<Double>) {\n        val sorted = Ordering.natural<Double>().sortedCopy(data)\n        if (sorted.isEmpty()) {\n            thirdQuartile = Double.NaN\n            firstQuartile = thirdQuartile\n            median = firstQuartile\n            max = median\n            min = max\n        } else if (sorted.size == 1) {\n            thirdQuartile = sorted.get(0)\n            firstQuartile = thirdQuartile\n            median = firstQuartile\n            max = median\n            min = max\n        } else {\n            val maxIndex = sorted.size - 1\n\n            min = sorted.get(0)\n            max = sorted.get(maxIndex)\n            median = medianAtPointer(sorted, maxIndex * .5)\n            firstQuartile = medianAtPointer(sorted, maxIndex * .25)\n            thirdQuartile = medianAtPointer(sorted, maxIndex * .75)\n        }\n    }\n\n    constructor(min: Double, max: Double, median: Double, firstQuartile: Double, thirdQuartile: Double) {\n        this.min = min\n        this.max = max\n        this.median = median\n        this.firstQuartile = firstQuartile\n        this.thirdQuartile = thirdQuartile\n    }\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n        val that = other as FiveNumberSummary?\n        return that!!.min.compareTo(min) == 0 &&\n                that.max.compareTo(max) == 0 &&\n                that.median.compareTo(median) == 0 &&\n                that.firstQuartile.compareTo(firstQuartile) == 0 &&\n                that.thirdQuartile.compareTo(thirdQuartile) == 0\n    }\n\n    override fun hashCode(): Int {\n        return arrayOf(min, max, median, firstQuartile, thirdQuartile).hashCode()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\ninternal class MultiOrdering<K : Comparable<K>>(private val myKeys: List<K?>) {\n    private val myIndices: MutableList<Int>\n\n    init {\n        myIndices = ArrayList(myKeys.size)\n        for (i in myKeys.indices) {\n            myIndices.add(i)\n        }\n\n        myIndices.sortWith(Comparator { i: Int?, j: Int? ->\n            val keyI = myKeys[i!!]\n            val keyJ = myKeys[j!!]\n            when {\n                keyI === keyJ -> 0\n                keyI == null -> -1\n                keyJ == null -> 1\n                else -> keyI.compareTo(keyJ)\n            }\n        })\n    }\n\n    fun <T> sortedCopy(l: List<T?>): List<T?> {\n        require(l.size == myIndices.size) { \"Expected size \" + myIndices.size + \" but was size \" + l.size }\n        val copy = ArrayList<T?>(myIndices.size)\n        for (oldIndex in myIndices) {\n            val v = l[oldIndex]\n            copy.add(v)\n        }\n        return copy\n    }\n\n    fun sortedCopyOfKeys(): List<K?> {\n        return sortedCopy(myKeys)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.StatContext\nimport jetbrains.datalore.plot.base.data.TransformVar\n\nclass SimpleStatContext(private val myDataFrame: DataFrame) :\n    StatContext {\n\n    override fun overallXRange(): ClosedRange<Double>? {\n        return myDataFrame.range(TransformVar.X)\n    }\n\n    override fun overallYRange(): ClosedRange<Double>? {\n        return myDataFrame.range(TransformVar.Y)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable.Source.STAT\nimport jetbrains.datalore.plot.base.Stat\nimport jetbrains.datalore.plot.base.StatContext\n\nobject Stats {\n    // stat variables can be referenced by name ..name.. (p 54)\n    val X = DataFrame.Variable(\"..x..\", STAT, \"x\")\n    val Y = DataFrame.Variable(\"..y..\", STAT, \"y\")\n    val COUNT = DataFrame.Variable(\"..count..\", STAT, \"count\")\n    val DENSITY = DataFrame.Variable(\"..density..\", STAT, \"density\")\n    val Y_MIN = DataFrame.Variable(\"..ymin..\", STAT, \"y min\")\n    val Y_MAX = DataFrame.Variable(\"..ymax..\", STAT, \"y max\")\n    val SE = DataFrame.Variable(\"..se..\", STAT, \"standard error\")\n    val LEVEL = DataFrame.Variable(\"..level..\", STAT, \"level\")\n\n    val LOWER = DataFrame.Variable(\"..lower..\", STAT, \"lower\")\n    val MIDDLE = DataFrame.Variable(\"..middle..\", STAT, \"middle\")\n    val UPPER = DataFrame.Variable(\"..upper..\", STAT, \"upper\")\n    val WIDTH = DataFrame.Variable(\"..width..\", STAT, \"width\")\n\n    val CORR = DataFrame.Variable(\"..corr..\", STAT, \"corr\")\n    val CORR_ABS = DataFrame.Variable(\"..corr_abs..\", STAT, \"corr_abs\")\n\n    val SCALED = DataFrame.Variable(\"..scaled..\", STAT, \"scaled\")\n\n    val GROUP = DataFrame.Variable(\"..group..\", STAT, \"group\")\n\n    val IDENTITY: Stat = IdentityStat()\n\n    private val VARS: Map<String, DataFrame.Variable> = run {\n        val variableList = listOf(\n            X,\n            Y,\n            COUNT,\n            DENSITY,\n            Y_MIN,\n            Y_MAX,\n            SE,\n            LEVEL,\n            LOWER,\n            MIDDLE,\n            UPPER,\n            WIDTH,\n            SCALED,\n            GROUP,\n            CORR,\n            CORR_ABS\n        )\n\n        val result = HashMap<String, DataFrame.Variable>()\n        for (variable in variableList) {\n            result[variable.name] = variable\n        }\n        result\n    }\n\n    fun isStatVar(varName: String): Boolean {\n        return VARS.containsKey(varName)\n    }\n\n    fun statVar(varName: String): DataFrame.Variable {\n        require(VARS.containsKey(varName)) { \"Unknown stat variable $varName\" }\n        return VARS[varName]!!\n    }\n\n    fun defaultMapping(stat: Stat): Map<Aes<*>, DataFrame.Variable> {\n        val map = HashMap<Aes<*>, DataFrame.Variable>()\n        for (aes in Aes.values()) {\n            if (stat.hasDefaultMapping(aes)) {\n                val variable = stat.getDefaultMapping(aes)\n                map[aes] = variable\n            }\n        }\n        return map\n    }\n\n    fun count(): Stat {\n        return CountStat()\n    }\n\n    fun bin(\n        binCount: Int = BinStat.DEF_BIN_COUNT,\n        binWidth: Double? = null,\n        center: Double? = null,\n        boundary: Double? = null\n    ): BinStat {\n        var xPosKind = BinStat.XPosKind.NONE\n        var xPosValue = 0.0\n        if (boundary != null) {\n            xPosKind = BinStat.XPosKind.BOUNDARY\n            xPosValue = boundary\n        } else if (center != null) {\n            xPosKind = BinStat.XPosKind.CENTER\n            xPosValue = center\n        }\n\n        return BinStat(\n            binCount = binCount,\n            binWidth = binWidth,\n            xPosKind = xPosKind,\n            xPos = xPosValue\n        )\n    }\n\n    fun smooth(\n        smootherPointCount: Int = SmoothStat.DEF_EVAL_POINT_COUNT,\n        smoothingMethod: SmoothStat.Method = SmoothStat.DEF_SMOOTHING_METHOD,\n        confidenceLevel: Double = SmoothStat.DEF_CONFIDENCE_LEVEL,\n        displayConfidenceInterval: Boolean = SmoothStat.DEF_DISPLAY_CONFIDENCE_INTERVAL,\n        span: Double = SmoothStat.DEF_SPAN,\n        polynomialDegree: Int = SmoothStat.DEF_DEG,\n        loessCriticalSize: Int = SmoothStat.DEF_LOESS_CRITICAL_SIZE,\n        samplingSeed: Long = SmoothStat.DEF_SAMPLING_SEED\n    ): SmoothStat {\n        return SmoothStat(\n            smootherPointCount = smootherPointCount,\n            smoothingMethod = smoothingMethod,\n            confidenceLevel = confidenceLevel,\n            displayConfidenceInterval = displayConfidenceInterval,\n            span = span,\n            polynomialDegree = polynomialDegree,\n            loessCriticalSize = loessCriticalSize,\n            samplingSeed = samplingSeed\n        )\n    }\n\n    fun corr(\n        correlationMethod: CorrelationStat.Method = CorrelationStat.DEF_CORRELATION_METHOD,\n        type: CorrelationStat.Type = CorrelationStat.DEF_TYPE,\n        fillDiagonal: Boolean = CorrelationStat.DEF_FILL_DIAGONAL,\n        threshold: Double = CorrelationStat.DEF_THRESHOLD\n    ): CorrelationStat {\n        return CorrelationStat(\n            correlationMethod = correlationMethod,\n            type = type,\n            fillDiagonal = fillDiagonal,\n            threshold = threshold\n        )\n    }\n\n    fun contour(\n        binCount: Int = ContourStat.DEF_BIN_COUNT,\n        binWidth: Double? = null\n    ): ContourStat {\n        return ContourStat(\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun contourf(\n        binCount: Int = ContourStat.DEF_BIN_COUNT,\n        binWidth: Double? = null\n    ): ContourfStat {\n        return ContourfStat(\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun boxplot(\n        whiskerIQRRatio: Double = BoxplotStat.DEF_WHISKER_IQR_RATIO,\n        computeWidth: Boolean = BoxplotStat.DEF_COMPUTE_WIDTH\n    ): BoxplotStat {\n        return BoxplotStat(whiskerIQRRatio, computeWidth)\n    }\n\n    fun density(\n        bandWidth: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod = DensityStat.DEF_BW,\n        adjust: Double = DensityStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = DensityStat.DEF_KERNEL,\n        n: Int = DensityStat.DEF_N,\n        fullScalMax: Int = DensityStat.DEF_FULL_SCAN_MAX\n    ): DensityStat {\n        return DensityStat(\n            bandWidth = bandWidth,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            n = n,\n            fullScalMax = fullScalMax\n        )\n    }\n\n    fun density2d(\n        bandWidthX: Double? = null,\n        bandWidthY: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod = AbstractDensity2dStat.DEF_BW,  // Used is `bandWidth` is not set.\n        adjust: Double = AbstractDensity2dStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = AbstractDensity2dStat.DEF_KERNEL,\n        nX: Int = AbstractDensity2dStat.DEF_N,\n        nY: Int = AbstractDensity2dStat.DEF_N,\n        isContour: Boolean = AbstractDensity2dStat.DEF_CONTOUR,\n        binCount: Int = AbstractDensity2dStat.DEF_BIN_COUNT,\n        binWidth: Double = AbstractDensity2dStat.DEF_BIN_WIDTH\n    ): AbstractDensity2dStat {\n        return Density2dStat(\n            bandWidthX = bandWidthX,\n            bandWidthY = bandWidthY,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            nX = nX,\n            nY = nY,\n            isContour = isContour,\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    fun density2df(\n        bandWidthX: Double? = null,\n        bandWidthY: Double? = null,\n        bandWidthMethod: DensityStat.BandWidthMethod,  // Used is `bandWidth` is not set.\n        adjust: Double = AbstractDensity2dStat.DEF_ADJUST,\n        kernel: DensityStat.Kernel = AbstractDensity2dStat.DEF_KERNEL,\n        nX: Int = AbstractDensity2dStat.DEF_N,\n        nY: Int = AbstractDensity2dStat.DEF_N,\n        isContour: Boolean = AbstractDensity2dStat.DEF_CONTOUR,\n        binCount: Int = AbstractDensity2dStat.DEF_BIN_COUNT,\n        binWidth: Double = AbstractDensity2dStat.DEF_BIN_WIDTH\n    ): AbstractDensity2dStat {\n        return Density2dfStat(\n            bandWidthX = bandWidthX,\n            bandWidthY = bandWidthY,\n            bandWidthMethod = bandWidthMethod,\n            adjust = adjust,\n            kernel = kernel,\n            nX = nX,\n            nY = nY,\n            isContour = isContour,\n            binCount = binCount,\n            binWidth = binWidth\n        )\n    }\n\n    private class IdentityStat internal constructor() : BaseStat(emptyMap()) {\n\n        override fun apply(data: DataFrame, statCtx: StatContext, messageConsumer: (s: String) -> Unit): DataFrame {\n            return DataFrame.Builder.emptyFrame()\n        }\n\n        override fun consumes(): List<Aes<*>> {\n            return emptyList()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Base class for solvers.\n *\n * @version $Id$\n * @since 3.0\n */\nabstract class AbstractUnivariateSolver : BaseAbstractUnivariateSolver<UnivariateFunction>,\n    UnivariateSolver {\n    /**\n     * Construct a solver with given absolute accuracy.\n     *\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(absoluteAccuracy: Double) : super(absoluteAccuracy) {}\n\n    /**\n     * Construct a solver with given accuracies.\n     *\n     * @param relativeAccuracy Maximum relative error.\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver with given accuracies.\n     *\n     * @param relativeAccuracy Maximum relative error.\n     * @param absoluteAccuracy Maximum absolute error.\n     * @param functionValueAccuracy Maximum function value error.\n     */\n    protected constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double,\n        functionValueAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n    }\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/** The kinds of solutions that a [ (bracketed univariate real) root-finding algorithm][BracketedUnivariateSolver] may accept as solutions.\n * This basically controls whether or not under-approximations and\n * over-approximations are allowed.\n *\n *\n * If all solutions are accepted ([.ANY_SIDE]), then the solution\n * that the root-finding algorithm returns for a given root may be equal to the\n * actual root, but it may also be an approximation that is slightly smaller\n * or slightly larger than the actual root. Root-finding algorithms generally\n * only guarantee that the returned solution is within the requested\n * tolerances. In certain cases however, in particular for\n * [state events][org.apache.commons.math3.ode.events.EventHandler] of\n * [ODE solvers][org.apache.commons.math3.ode.ODEIntegrator], it\n * may be necessary to guarantee that a solution is returned that lies on a\n * specific side the solution.\n *\n * @see BracketedUnivariateSolver\n *\n * @since 3.0\n * @version $Id$\n */\nenum class AllowedSolution {\n    /** There are no additional side restriction on the solutions for\n     * root-finding. That is, both under-approximations and over-approximations\n     * are allowed. So, if a function f(x) has a root at x = x0, then the\n     * root-finding result s may be smaller than x0, equal to x0, or greater\n     * than x0.\n     */\n    ANY_SIDE,\n\n    /** Only solutions that are less than or equal to the actual root are\n     * acceptable as solutions for root-finding. In other words,\n     * over-approximations are not allowed. So, if a function f(x) has a root\n     * at x = x0, then the root-finding result s must satisfy s &lt;= x0.\n     */\n    LEFT_SIDE,\n\n    /** Only solutions that are greater than or equal to the actual root are\n     * acceptable as solutions for root-finding. In other words,\n     * under-approximations are not allowed. So, if a function f(x) has a root\n     * at x = x0, then the root-finding result s must satisfy s &gt;= x0.\n     */\n    RIGHT_SIDE,\n\n    /** Only solutions for which values are less than or equal to zero are\n     * acceptable as solutions for root-finding. So, if a function f(x) has\n     * a root at x = x0, then the root-finding result s must satisfy f(s) &lt;= 0.\n     */\n    BELOW_SIDE,\n\n    /** Only solutions for which values are greater than or equal to zero are\n     * acceptable as solutions for root-finding. So, if a function f(x) has\n     * a root at x = x0, then the root-finding result s must satisfy f(s) &gt;= 0.\n     */\n    ABOVE_SIDE\n\n}\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\n\n\n/**\n * Provide a default implementation for several functions useful to generic\n * solvers.\n *\n * @param <FUNC> Type of function to solve.\n *\n * @version $Id$\n * @since 2.0\n</FUNC> */\nabstract class BaseAbstractUnivariateSolver<FUNC : UnivariateFunction>\n/**\n * Construct a solver with given accuracies.\n *\n * @param relativeAccuracy Maximum relative error.\n * @param absoluteAccuracy Maximum absolute error.\n * @param functionValueAccuracy Maximum function value error.\n */\n@JvmOverloads protected constructor(\n    /** Relative accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val relativeAccuracy: Double,\n    /** Absolute accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val absoluteAccuracy: Double,\n    /** Function value accuracy.  */\n    /**\n     * {@inheritDoc}\n     */\n    override val functionValueAccuracy: Double = DEFAULT_FUNCTION_VALUE_ACCURACY\n) : BaseUnivariateSolver<FUNC> {\n    /** Evaluations counter.  */\n    private val myEvaluations = Incrementor()\n    /** Lower end of search interval.  */\n    /**\n     * @return the lower end of the search interval.\n     */\n    var min: Double = 0.toDouble()\n        private set\n    /** Higher end of search interval.  */\n    /**\n     * @return the higher end of the search interval.\n     */\n    var max: Double = 0.toDouble()\n        private set\n    /** Initial guess.  */\n    /**\n     * @return the initial guess.\n     */\n    var startValue: Double = 0.toDouble()\n        private set\n    /** Function to solve.  */\n    private var function: FUNC? = null\n\n    /** {@inheritDoc}  */\n    override val maxEvaluations: Int\n        get() = myEvaluations.maximalCount\n\n    /**\n     * Construct a solver with given absolute accuracy.\n     *\n     * @param absoluteAccuracy Maximum absolute error.\n     */\n    protected constructor(absoluteAccuracy: Double) : this(\n        DEFAULT_RELATIVE_ACCURACY,\n        absoluteAccuracy,\n        DEFAULT_FUNCTION_VALUE_ACCURACY\n    ) {\n    }\n\n    override val evaluations = myEvaluations.count\n\n    /**\n     * Compute the objective function value.\n     *\n     * @param point Point at which the objective function must be evaluated.\n     * @return the objective function value at specified point.\n     * @throws TooManyEvaluationsException if the maximal number of evaluations\n     * is exceeded.\n     */\n    protected fun computeObjectiveValue(point: Double): Double {\n        incrementEvaluationCount()\n        return function!!.value(point)\n    }\n\n    /**\n     * Prepare for computation.\n     * Subclasses must call this method if they override any of the\n     * `solve` methods.\n     *\n     * @param f Function to solve.\n     * @param min Lower bound for the interval.\n     * @param max Upper bound for the interval.\n     * @param startValue Start value to use.\n     * @param maxEval Maximum number of evaluations.\n     */\n    protected fun setup(\n        maxEval: Int,\n        f: FUNC,\n        min: Double, max: Double,\n        startValue: Double\n    ) {\n\n        // Reset.\n        this.min = min\n        this.max = max\n        this.startValue = startValue\n        function = f\n        myEvaluations.maximalCount = maxEval\n        myEvaluations.resetCount()\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, min: Double, max: Double, startValue: Double): Double {\n        // Initialization.\n        setup(maxEval, f, min, max, startValue)\n\n        // Perform computation.\n        return doSolve()\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, min: Double, max: Double): Double {\n        return solve(maxEval, f, min, max, min + 0.5 * (max - min))\n    }\n\n    /** {@inheritDoc}  */\n    override fun solve(maxEval: Int, f: FUNC, startValue: Double): Double {\n        return solve(maxEval, f, Double.NaN, Double.NaN, startValue)\n    }\n\n    /**\n     * Method for implementing actual optimization algorithms in derived\n     * classes.\n     *\n     * @return the root.\n     * @throws TooManyEvaluationsException if the maximal number of evaluations\n     * is exceeded.\n     * @throws NoBracketingException if the initial search interval does not bracket\n     * a root and the solver requires it.\n     */\n    protected abstract fun doSolve(): Double\n\n    /**\n     * Check whether the function takes opposite signs at the endpoints.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @return `true` if the function values have opposite signs at the\n     * given points.\n     */\n    protected fun isBracketing(\n        lower: Double,\n        upper: Double\n    ): Boolean {\n        return UnivariateSolverUtils.isBracketing(function!!, lower, upper)\n    }\n\n    /**\n     * Check whether the arguments form a (strictly) increasing sequence.\n     *\n     * @param start First number.\n     * @param mid Second number.\n     * @param end Third number.\n     * @return `true` if the arguments form an increasing sequence.\n     */\n    protected fun isSequence(\n        start: Double,\n        mid: Double,\n        end: Double\n    ): Boolean {\n        return UnivariateSolverUtils.isSequence(start, mid, end)\n    }\n\n    /**\n     * Check that the endpoints specify an interval.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws org.apache.commons.math3.exception.NumberIsTooLargeException\n     * if `lower >= upper`.\n     */\n    protected fun verifyInterval(\n        lower: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifyInterval(lower, upper)\n    }\n\n    /**\n     * Check that `lower < initial < upper`.\n     *\n     * @param lower Lower endpoint.\n     * @param initial Initial value.\n     * @param upper Upper endpoint.\n     * @throws org.apache.commons.math3.exception.NumberIsTooLargeException\n     * if `lower >= initial` or `initial >= upper`.\n     */\n    protected fun verifySequence(\n        lower: Double,\n        initial: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifySequence(lower, initial, upper)\n    }\n\n    /**\n     * Check that the endpoints specify an interval and the function takes\n     * opposite signs at the endpoints.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NoBracketingException if\n     * the function has the same sign at the endpoints.\n     */\n    protected fun verifyBracketing(\n        lower: Double,\n        upper: Double\n    ) {\n        UnivariateSolverUtils.verifyBracketing(function!!, lower, upper)\n    }\n\n    /**\n     * Increment the evaluation count by one.\n     * Method [.computeObjectiveValue] calls this method internally.\n     * It is provided for subclasses that do not exclusively use\n     * `computeObjectiveValue` to solve the function.\n     * See e.g. [AbstractDifferentiableUnivariateSolver].\n     */\n    protected fun incrementEvaluationCount() {\n        myEvaluations.incrementCount()\n\n    }\n\n    companion object {\n        /** Default relative accuracy.  */\n        private val DEFAULT_RELATIVE_ACCURACY = 1e-14\n        /** Default function value accuracy.  */\n        private val DEFAULT_FUNCTION_VALUE_ACCURACY = 1e-15\n    }\n}\n/**\n * Construct a solver with given accuracies.\n *\n * @param relativeAccuracy Maximum relative error.\n * @param absoluteAccuracy Maximum absolute error.\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n\n/**\n * This is a utility class that provides computation methods related to the\n * Beta family of functions.\n *\n * @version $Id: Beta.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject Beta {\n    /** Maximum allowed numerical error.  */\n    private val DEFAULT_EPSILON = 10e-15\n\n    /**\n     * Returns the regularized beta function I(x, a, b).\n     *\n     * @param x the value.\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized beta function I(x, a, b)\n     * @throws org.apache.commons.math3.exception.MaxCountExceededException\n     * if the algorithm fails to converge.\n     */\n    fun regularizedBeta(\n        x: Double,\n        a: Double, b: Double,\n        maxIterations: Int\n    ): Double {\n        return regularizedBeta(\n            x,\n            a,\n            b,\n            DEFAULT_EPSILON,\n            maxIterations\n        )\n    }\n\n    /**\n     * Returns the regularized beta function I(x, a, b).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Beta Function](mathworld.wolfram.com/RegularizedBetaFunction.html).\n     *  *\n     * [\n * Regularized Beta Function](functions.wolfram.com/06.21.10.0001.01).\n     *\n     *\n     * @param x the value.\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized beta function I(x, a, b)\n     * @throws org.apache.commons.math3.exception.MaxCountExceededException\n     * if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedBeta(\n        x: Double,\n        a: Double, b: Double,\n        epsilon: Double = DEFAULT_EPSILON, maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (x.isNaN() ||\n            a.isNaN() ||\n            b.isNaN() ||\n            x < 0 ||\n            x > 1 ||\n            a <= 0.0 ||\n            b <= 0.0\n        ) {\n            ret = Double.NaN\n        } else if (x > (a + 1.0) / (a + b + 2.0)) {\n            ret = 1.0 - regularizedBeta(\n                1.0 - x,\n                b,\n                a,\n                epsilon,\n                maxIterations\n            )\n        } else {\n            val fraction = object : ContinuedFraction() {\n\n                override fun getB(n: Int, x: Double): Double {\n                    @Suppress(\"NAME_SHADOWING\")\n                    val ret: Double\n                    val m: Double\n                    if (n % 2 == 0) { // even\n                        m = n / 2.0\n                        ret = m * (b - m) * x / ((a + 2 * m - 1) * (a + 2 * m))\n                    } else {\n                        m = (n - 1.0) / 2.0\n                        ret = -((a + m) * (a + b + m) * x) / ((a + 2 * m) * (a + 2 * m + 1.0))\n                    }\n                    return ret\n                }\n\n                override fun getA(n: Int, x: Double): Double {\n                    return 1.0\n                }\n            }\n            ret = exp(\n                a * ln(x) + b * ln(1.0 - x) -\n                        ln(a) - logBeta(a, b, epsilon, maxIterations)\n            ) * 1.0 / fraction.evaluate(x, epsilon, maxIterations)\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the natural logarithm of the beta function B(a, b).\n     *\n     * The implementation of this method is based on:\n     *\n     *  * [\n * Beta Function](mathworld.wolfram.com/BetaFunction.html), equation (1).\n     *\n     *\n     * @param a Parameter `a`.\n     * @param b Parameter `b`.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return log(B(a, b)).\n     */\n    @JvmOverloads\n    fun logBeta(\n        a: Double, b: Double,\n        @Suppress(\"UNUSED_PARAMETER\") epsilon: Double = DEFAULT_EPSILON,\n        @Suppress(\"UNUSED_PARAMETER\") maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (a.isNaN() ||\n            b.isNaN() ||\n            a <= 0.0 ||\n            b <= 0.0\n        ) {\n            ret = Double.NaN\n        } else {\n            ret = Gamma.logGamma(a) + Gamma.logGamma(\n                b\n            ) - Gamma.logGamma(a + b)\n        }\n\n        return ret\n    }\n}\n/**\n * Default constructor.  Prohibit instantiation.\n */\n/**\n * Returns the\n * [\n * regularized beta function](mathworld.wolfram.com/RegularizedBetaFunction.html) I(x, a, b).\n *\n * @param x Value.\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @return the regularized beta function I(x, a, b).\n * @throws org.apache.commons.math3.exception.MaxCountExceededException\n * if the algorithm fails to converge.\n */\n/**\n * Returns the\n * [\n * regularized beta function](mathworld.wolfram.com/RegularizedBetaFunction.html) I(x, a, b).\n *\n * @param x Value.\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @param epsilon When the absolute value of the nth item in the\n * series is less than epsilon the approximation ceases to calculate\n * further elements in the series.\n * @return the regularized beta function I(x, a, b)\n * @throws org.apache.commons.math3.exception.MaxCountExceededException\n * if the algorithm fails to converge.\n */\n/**\n * Returns the natural logarithm of the beta function B(a, b).\n *\n * @param a Parameter `a`.\n * @param b Parameter `b`.\n * @return log(B(a, b)).\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.min\n\nclass BlockRealMatrix {\n    /** Block size.  */\n    private val BLOCK_SIZE = 52\n    /** Number of rows of the matrix.  */\n    private var rows: Int = 0\n    /** Number of columns of the matrix.  */\n    private var columns: Int = 0\n    /** Number of block rows of the matrix.  */\n    private var blockRows: Int = 0\n    /** Number of block columns of the matrix.  */\n    private var blockColumns: Int = 0\n    /** Blocks of matrix entries.  */\n    private lateinit var blocks: Array<DoubleArray>\n    /**\n     * Create a new matrix with the supplied row and column dimensions.\n     *\n     * @param rows  the number of rows in the new matrix\n     * @param columns  the number of columns in the new matrix\n     * @throws org.apache.commons.math3.exception.NotStrictlyPositiveException\n     * if row or column dimension is not positive.\n     */\n    constructor(rows: Int, columns: Int) {\n        this.rows = rows\n        this.columns = columns\n\n        // number of blocks\n        blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        // allocate storage blocks, taking care of smaller ones at right and bottom\n        blocks = createBlocksLayout(rows, columns)\n    }\n\n    /**\n     * Create a new dense matrix copying entries from raw layout data.\n     *\n     * The input array *must* already be in raw layout.\n     *\n     * Calling this constructor is equivalent to call:\n     * <pre>matrix = new BlockRealMatrix(rawData.length, rawData[0].length,\n     * toBlocksLayout(rawData), false);</pre>\n     *\n     *\n     * @param rawData data for new matrix, in raw layout\n     * @throws DimensionMismatchException if the shape of `blockData` is\n     * inconsistent with block layout.\n     * @see .BlockRealMatrix\n     */\n    constructor(rawData: Array<DoubleArray>) {\n\n        create(rawData.size, rawData[0].size, toBlocksLayout(rawData), false)\n    }\n\n    /**\n     * Create a new dense matrix copying entries from block layout data.\n     *\n     * The input array *must* already be in blocks layout.\n     *\n     * @param rows Number of rows in the new matrix.\n     * @param columns Number of columns in the new matrix.\n     * @param blockData data for new matrix\n     * @param copyArray Whether the input array will be copied or referenced.\n     * @throws DimensionMismatchException if the shape of `blockData` is\n     * inconsistent with block layout.\n     * @see .createBlocksLayout\n     * @see .toBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    fun create(\n        rows: Int, columns: Int,\n        blockData: Array<DoubleArray>, copyArray: Boolean\n    ) {\n        this.rows = rows\n        this.columns = columns\n\n        // number of blocks\n        blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        val blocksCopyList = ArrayList<DoubleArray>()\n        if (copyArray) {\n            // allocate storage blocks, taking care of smaller ones at right and bottom\n        } else {\n            // reference existing array\n            blocks = blockData\n        }\n\n        var index = 0\n        for (iBlock in 0 until blockRows) {\n            val iHeight = blockHeight(iBlock)\n            var jBlock = 0\n            while (jBlock < blockColumns) {\n                if (blockData[index].size != iHeight * blockWidth(jBlock)) {\n                    error(\"\")\n                    //throw DimensionMismatchException(\n                    //    blockData[index].size,\n                    //    iHeight * blockWidth(jBlock)\n                    //)\n                }\n                if (copyArray) {\n                    blocksCopyList.add(blockData[index].copyOf())\n                    //blocks[index] = blockData[index].copyOf()\n                }\n                ++jBlock\n                ++index\n            }\n        }\n\n        if (copyArray) {\n            blocks = blocksCopyList.toTypedArray()\n        }\n    }\n\n    /**\n     * Create a data array in blocks layout.\n     *\n     *\n     * This method can be used to create the array argument of the [ ][.BlockRealMatrix] constructor.\n     *\n     * @param rows Number of rows in the new matrix.\n     * @param columns Number of columns in the new matrix.\n     * @return a new data array in blocks layout.\n     * @see .toBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    private fun createBlocksLayout(rows: Int, columns: Int): Array<DoubleArray> {\n        val blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        val blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        val blocksList = ArrayList<DoubleArray>()\n        var blockIndex = 0\n        for (iBlock in 0 until blockRows) {\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n            val iHeight = pEnd - pStart\n            for (jBlock in 0 until blockColumns) {\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, columns)\n                val jWidth = qEnd - qStart\n                blocksList.add(DoubleArray(iHeight * jWidth))\n                ++blockIndex\n            }\n        }\n\n        return blocksList.toTypedArray()\n    }\n\n    fun transpose(): BlockRealMatrix {\n        val nRows = getRowDimension()\n        val nCols = getColumnDimension()\n        val out = BlockRealMatrix(nCols, nRows)\n\n        // perform transpose block-wise, to ensure good cache behavior\n        var blockIndex = 0\n        for (iBlock in 0 until blockColumns) {\n            for (jBlock in 0 until blockRows) {\n                // transpose current block\n                val outBlock = out.blocks[blockIndex]\n                val tBlock = blocks[jBlock * blockColumns + iBlock]\n                val pStart = iBlock * BLOCK_SIZE\n                val pEnd = min(pStart + BLOCK_SIZE, columns)\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, rows)\n                var k = 0\n                for (p in pStart until pEnd) {\n                    val lInc = pEnd - pStart\n                    var l = p - pStart\n                    for (q in qStart until qEnd) {\n                        outBlock[k] = tBlock[l]\n                        ++k\n                        l += lInc\n                    }\n                }\n                // go to next block\n                ++blockIndex\n            }\n        }\n\n        return out\n    }\n\n    /**\n     * Returns the result of postmultiplying this by `m`.\n     *\n     * @param m Matrix to postmultiply by.\n     * @return `this` * m.\n     * @throws MatrixDimensionMismatchException if the matrices are not\n     * compatible.\n     */\n    fun multiply(m: BlockRealMatrix): BlockRealMatrix {\n        // safety check\n        if (this.getColumnDimension() != m.getRowDimension()) {\n            error(\"Matrix multiply dimension mismatch: ${this.getColumnDimension()} x ${m.getRowDimension()}\")\n        }\n\n        val out = BlockRealMatrix(rows, m.columns)\n\n        // perform multiplication block-wise, to ensure good cache behavior\n        var blockIndex = 0\n        for (iBlock in 0 until out.blockRows) {\n\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n\n            for (jBlock in 0 until out.blockColumns) {\n                val jWidth = out.blockWidth(jBlock)\n                val jWidth2 = jWidth + jWidth\n                val jWidth3 = jWidth2 + jWidth\n                val jWidth4 = jWidth3 + jWidth\n\n                // select current block\n                val outBlock = out.blocks[blockIndex]\n\n                // perform multiplication on current block\n                for (kBlock in 0 until blockColumns) {\n                    val kWidth = blockWidth(kBlock)\n                    val tBlock = blocks[iBlock * blockColumns + kBlock]\n                    val mBlock = m.blocks[kBlock * m.blockColumns + jBlock]\n                    var k = 0\n                    for (p in pStart until pEnd) {\n                        val lStart = (p - pStart) * kWidth\n                        val lEnd = lStart + kWidth\n                        for (nStart in 0 until jWidth) {\n                            var sum = 0.0\n                            var l = lStart\n                            var n = nStart\n                            while (l < lEnd - 3) {\n                                sum += tBlock[l] * mBlock[n] +\n                                        tBlock[l + 1] * mBlock[n + jWidth] +\n                                        tBlock[l + 2] * mBlock[n + jWidth2] +\n                                        tBlock[l + 3] * mBlock[n + jWidth3]\n                                l += 4\n                                n += jWidth4\n                            }\n                            while (l < lEnd) {\n                                sum += tBlock[l++] * mBlock[n]\n                                n += jWidth\n                            }\n                            outBlock[k] += sum\n                            ++k\n                        }\n                    }\n                }\n                // go to next block\n                ++blockIndex\n            }\n        }\n\n        return out\n    }\n\n\n    /** {@inheritDoc}  */\n    fun getEntry(row: Int, column: Int): Double {\n        //MatrixUtils.checkMatrixIndex(this, row, column)\n        if (row < 0 || row > getRowDimension()) error(\"row out of range: $row\")\n        if (column < 0 || column > getColumnDimension()) error(\"column out of range: $column\")\n\n        val iBlock = row / BLOCK_SIZE\n        val jBlock = column / BLOCK_SIZE\n        val k = (row - iBlock * BLOCK_SIZE) * blockWidth(jBlock) + (column - jBlock * BLOCK_SIZE)\n        return blocks[iBlock * blockColumns + jBlock][k]\n    }\n\n    private fun getRowDimension(): Int {\n        return rows\n    }\n\n    /** {@inheritDoc}  */\n    private fun getColumnDimension(): Int {\n        return columns\n    }\n\n    /**\n     * Get the width of a block.\n     * @param blockColumn column index (in block sense) of the block\n     * @return width (number of columns) of the block\n     */\n    private fun blockWidth(blockColumn: Int): Int {\n        return if (blockColumn == blockColumns - 1) columns - blockColumn * BLOCK_SIZE else BLOCK_SIZE\n    }\n\n    /**\n     * Get the height of a block.\n     * @param blockRow row index (in block sense) of the block\n     * @return height (number of rows) of the block\n     */\n    private fun blockHeight(blockRow: Int): Int {\n        return if (blockRow == blockRows - 1) rows - blockRow * BLOCK_SIZE else BLOCK_SIZE\n    }\n\n    /**\n     * Convert a data array from raw layout to blocks layout.\n     *\n     *\n     * Raw layout is the straightforward layout where element at row i and\n     * column j is in array element `rawData[i][j]`. Blocks layout\n     * is the layout used in [BlockRealMatrix] instances, where the matrix\n     * is split in square blocks (except at right and bottom side where blocks may\n     * be rectangular to fit matrix size) and each block is stored in a flattened\n     * one-dimensional array.\n     *\n     *\n     *\n     * This method creates an array in blocks layout from an input array in raw layout.\n     * It can be used to provide the array argument of the [ ][.BlockRealMatrix] constructor.\n     *\n     * @param rawData Data array in raw layout.\n     * @return a new data array containing the same entries but in blocks layout.\n     * @throws DimensionMismatchException if `rawData` is not rectangular.\n     * @see .createBlocksLayout\n     * @see .BlockRealMatrix\n     */\n    fun toBlocksLayout(rawData: Array<DoubleArray>): Array<DoubleArray> {\n        val rows = rawData.size\n        val columns = rawData[0].size\n        val blockRows = (rows + BLOCK_SIZE - 1) / BLOCK_SIZE\n        val blockColumns = (columns + BLOCK_SIZE - 1) / BLOCK_SIZE\n\n        // safety checks\n        for (i in rawData.indices) {\n            val length = rawData[i].size\n            if (length != columns) {\n                error(\"Wrong dimension: $columns, $length\")\n            }\n        }\n\n        // convert array\n        val blocksList = ArrayList<DoubleArray>()\n        var blockIndex = 0\n        for (iBlock in 0 until blockRows) {\n            val pStart = iBlock * BLOCK_SIZE\n            val pEnd = min(pStart + BLOCK_SIZE, rows)\n            val iHeight = pEnd - pStart\n            for (jBlock in 0 until blockColumns) {\n                val qStart = jBlock * BLOCK_SIZE\n                val qEnd = min(qStart + BLOCK_SIZE, columns)\n                val jWidth = qEnd - qStart\n\n                // allocate new block\n                val block = DoubleArray(iHeight * jWidth)\n                blocksList.add(block)\n\n                // copy data\n                var index = 0\n                for (p in pStart until pEnd) {\n                    rawData[p].copyInto(block, index, qStart, qEnd)\n                    //System.arraycopy(rawData[p], qStart, block, index, jWidth)\n                    index += jWidth\n                }\n                ++blockIndex\n            }\n        }\n\n        return blocksList.toTypedArray()\n    }\n}","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\n\n/**\n * This class implements the [\n * Brent algorithm](mathworld.wolfram.com/BrentsMethod.html) for finding zeros of real univariate functions.\n * The function should be continuous but not necessarily smooth.\n * The `solve` method returns a zero `x` of the function `f`\n * in the given interval `[a, b]` to within a tolerance\n * `6 eps abs(x) + t` where `eps` is the relative accuracy and\n * `t` is the absolute accuracy.\n * The given interval must bracket the root.\n *\n * @version $Id: BrentSolver.java 1244107 2012-02-14 16:17:55Z erans $\n */\nclass BrentSolver : AbstractUnivariateSolver {\n    /**\n     * Construct a solver.\n     *\n     * @param absoluteAccuracy Absolute accuracy.\n     */\n    @JvmOverloads\n    constructor(absoluteAccuracy: Double = DEFAULT_ABSOLUTE_ACCURACY) : super(absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver.\n     *\n     * @param relativeAccuracy Relative accuracy.\n     * @param absoluteAccuracy Absolute accuracy.\n     */\n    constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy) {\n    }\n\n    /**\n     * Construct a solver.\n     *\n     * @param relativeAccuracy Relative accuracy.\n     * @param absoluteAccuracy Absolute accuracy.\n     * @param functionValueAccuracy Function value accuracy.\n     */\n    constructor(\n        relativeAccuracy: Double,\n        absoluteAccuracy: Double,\n        functionValueAccuracy: Double\n    ) : super(relativeAccuracy, absoluteAccuracy, functionValueAccuracy) {\n    }\n\n    /**\n     * {@inheritDoc}\n     */\n    override fun doSolve(): Double {\n        val min = min\n        val max = max\n        val initial = startValue\n        val functionValueAccuracy = functionValueAccuracy\n\n        verifySequence(min, initial, max)\n\n        // Return the initial guess if it is good enough.\n        val yInitial = computeObjectiveValue(initial)\n        if (abs(yInitial) <= functionValueAccuracy) {\n            return initial\n        }\n\n        // Return the first endpoint if it is good enough.\n        val yMin = computeObjectiveValue(min)\n        if (abs(yMin) <= functionValueAccuracy) {\n            return min\n        }\n\n        // Reduce interval if min and initial bracket the root.\n        if (yInitial * yMin < 0) {\n            return brent(min, initial, yMin, yInitial)\n        }\n\n        // Return the second endpoint if it is good enough.\n        val yMax = computeObjectiveValue(max)\n        if (abs(yMax) <= functionValueAccuracy) {\n            return max\n        }\n\n        // Reduce interval if initial and max bracket the root.\n        if (yInitial * yMax < 0) {\n            return brent(initial, max, yInitial, yMax)\n        }\n\n        error(\"NoBracketing - min: $min, max: $max, yMin: $yMin, yMax: $yMax\")\n    }\n\n    /**\n     * Search for a zero inside the provided interval.\n     * This implementation is based on the algorithm described at page 58 of\n     * the book\n     * <quote>\n     * **Algorithms for Minimization Without Derivatives**\n     * <it>Richard P. Brent</it>\n     * Dover 0-486-41998-3\n    </quote> *\n     *\n     * @param lo Lower bound of the search interval.\n     * @param hi Higher bound of the search interval.\n     * @param fLo Function value at the lower bound of the search interval.\n     * @param fHi Function value at the higher bound of the search interval.\n     * @return the value where the function is zero.\n     */\n    private fun brent(\n        lo: Double, hi: Double,\n        fLo: Double, fHi: Double\n    ): Double {\n        var a = lo\n        var fa = fLo\n        var b = hi\n        var fb = fHi\n        var c = a\n        var fc = fa\n        var d = b - a\n        var e = d\n\n        val t = absoluteAccuracy\n        val eps = relativeAccuracy\n\n        while (true) {\n            if (abs(fc) < abs(fb)) {\n                a = b\n                b = c\n                c = a\n                fa = fb\n                fb = fc\n                fc = fa\n            }\n\n            val tol = 2.0 * eps * abs(b) + t\n            val m = 0.5 * (c - b)\n\n            if (abs(m) <= tol || Precision.equals(fb, 0.0)) {\n                return b\n            }\n            if (abs(e) < tol || abs(fa) <= abs(fb)) {\n                // Force bisection.\n                d = m\n                e = d\n            } else {\n                var s = fb / fa\n                var p: Double\n                var q: Double\n                // The equality test (a == c) is intentional,\n                // it is part of the original Brent's method and\n                // it should NOT be replaced by proximity test.\n                if (a == c) {\n                    // Linear interpolation.\n                    p = 2.0 * m * s\n                    q = 1 - s\n                } else {\n                    // Inverse quadratic interpolation.\n                    q = fa / fc\n                    val r = fb / fc\n                    p = s * (2.0 * m * q * (q - r) - (b - a) * (r - 1))\n                    q = (q - 1) * (r - 1) * (s - 1)\n                }\n                if (p > 0) {\n                    q = -q\n                } else {\n                    p = -p\n                }\n                s = e\n                e = d\n                if (p >= 1.5 * m * q - abs(tol * q) || p >= abs(0.5 * s * q)) {\n                    // Inverse quadratic interpolation gives a value\n                    // in the wrong direction, or progress is slow.\n                    // Fall back to bisection.\n                    d = m\n                    e = d\n                } else {\n                    d = p / q\n                }\n            }\n            a = b\n            fa = fb\n\n            if (abs(d) > tol) {\n                b += d\n            } else if (m > 0) {\n                b += tol\n            } else {\n                b -= tol\n            }\n            fb = computeObjectiveValue(b)\n            if (fb > 0 && fc > 0 || fb <= 0 && fc <= 0) {\n                c = a\n                fc = fa\n                d = b - a\n                e = d\n            }\n        }\n    }\n\n    companion object {\n\n        /** Default absolute accuracy.  */\n        private val DEFAULT_ABSOLUTE_ACCURACY = 1e-6\n    }\n}\n/**\n * Construct a solver with default accuracy (1e-6).\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\nimport kotlin.math.max\n\n\n/**\n * Provides a generic means to evaluate continued fractions.  Subclasses simply\n * provided the a and b coefficients to evaluate the continued fraction.\n *\n *\n *\n * References:\n *\n *  * [\n * Continued Fraction](mathworld.wolfram.com/ContinuedFraction.html)\n *\n *\n *\n * @version $Id: ContinuedFraction.java 1244107 2012-02-14 16:17:55Z erans $\n */\nabstract class ContinuedFraction\n/**\n * Default constructor.\n */\nprotected constructor() {\n\n    /**\n     * Access the n-th a coefficient of the continued fraction.  Since a can be\n     * a function of the evaluation point, x, that is passed in as well.\n     * @param n the coefficient index to retrieve.\n     * @param x the evaluation point.\n     * @return the n-th a coefficient.\n     */\n    protected abstract fun getA(n: Int, x: Double): Double\n\n    /**\n     * Access the n-th b coefficient of the continued fraction.  Since b can be\n     * a function of the evaluation point, x, that is passed in as well.\n     * @param n the coefficient index to retrieve.\n     * @param x the evaluation point.\n     * @return the n-th b coefficient.\n     */\n    protected abstract fun getB(n: Int, x: Double): Double\n\n    /**\n     * Evaluates the continued fraction at the value x.\n     * @param x the evaluation point.\n     * @param maxIterations maximum number of convergents\n     * @return the value of the continued fraction evaluated at x.\n     * @throws ConvergenceException if the algorithm fails to converge.\n     */\n    fun evaluate(x: Double, maxIterations: Int): Double {\n        return evaluate(x,\n            DEFAULT_EPSILON, maxIterations)\n    }\n\n    /**\n     *\n     *\n     * Evaluates the continued fraction at the value x.\n     *\n     *\n     *\n     *\n     * The implementation of this method is based on equations 14-17 of:\n     *\n     *  *\n     * Eric W. Weisstein. \"Continued Fraction.\" From MathWorld--A Wolfram Web\n     * Resource. [\n * mathworld.wolfram.com/ContinuedFraction.html](mathworld.wolfram.com/ContinuedFraction.html)\n     *\n     *\n     * The recurrence relationship defined in those equations can result in\n     * very large intermediate results which can result in numerical overflow.\n     * As a means to combat these overflow conditions, the intermediate results\n     * are scaled whenever they threaten to become numerically unstable.\n     *\n     * @param x the evaluation point.\n     * @param epsilon maximum error allowed.\n     * @param maxIterations maximum number of convergents\n     * @return the value of the continued fraction evaluated at x.\n     * @throws ConvergenceException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun evaluate(x: Double, epsilon: Double = DEFAULT_EPSILON, maxIterations: Int = Int.MAX_VALUE): Double {\n        var p0 = 1.0\n        var p1 = getA(0, x)\n        var q0 = 0.0\n        var q1 = 1.0\n        var c = p1 / q1\n        var n = 0\n        var relativeError = Double.MAX_VALUE\n        while (n < maxIterations && relativeError > epsilon) {\n            ++n\n            val a = getA(n, x)\n            val b = getB(n, x)\n            var p2 = a * p1 + b * p0\n            var q2 = a * q1 + b * q0\n            var infinite = false\n            if (p2.isInfinite() || q2.isInfinite()) {\n                /*\n                 * Need to scale. Try successive powers of the larger of a or b\n                 * up to 5th power. Throw ConvergenceException if one or both\n                 * of p2, q2 still overflow.\n                 */\n                var scaleFactor = 1.0\n                @Suppress(\"VARIABLE_WITH_REDUNDANT_INITIALIZER\")\n                var lastScaleFactor = 1.0\n                val maxPower = 5\n                val scale = max(a, b)\n                if (scale <= 0) {  // Can't scale\n                    error(\"ConvergenceException\")\n                    //LocalizedFormats.CONTINUED_FRACTION_INFINITY_DIVERGENCE,\n                    //x\n                }\n                infinite = true\n                for (i in 0 until maxPower) {\n                    lastScaleFactor = scaleFactor\n                    scaleFactor *= scale\n                    if (a != 0.0 && a > b) {\n                        p2 = p1 / lastScaleFactor + b / scaleFactor * p0\n                        q2 = q1 / lastScaleFactor + b / scaleFactor * q0\n                    } else if (b != 0.0) {\n                        p2 = a / scaleFactor * p1 + p0 / lastScaleFactor\n                        q2 = a / scaleFactor * q1 + q0 / lastScaleFactor\n                    }\n                    infinite = p2.isInfinite() || q2.isInfinite()\n                    if (!infinite) {\n                        break\n                    }\n                }\n            }\n\n            if (infinite) {\n                // Scaling failed\n                error(\"ConvergenceException\")\n                //LocalizedFormats.CONTINUED_FRACTION_INFINITY_DIVERGENCE,\n                //x\n            }\n\n            val r = p2 / q2\n\n            if (r.isNaN()) {\n                error(\"ConvergenceException\")\n                //LocalizedFormats.CONTINUED_FRACTION_NAN_DIVERGENCE,\n                //x\n            }\n            relativeError = abs(r / c - 1.0)\n\n            // prepare for next iteration\n            c = p2 / q2\n            p0 = p1\n            p1 = p2\n            q0 = q1\n            q1 = q2\n        }\n\n        if (n >= maxIterations) {\n            error(\"MaxCountExceeded\")\n            //LocalizedFormats.NON_CONVERGENT_CONTINUED_FRACTION,\n            //maxIterations, x\n        }\n\n        return c\n    }\n\n    companion object {\n        /** Maximum allowed numerical error.  */\n        private val DEFAULT_EPSILON = 10e-9\n    }\n}\n/**\n * Evaluates the continued fraction at the value x.\n * @param x the evaluation point.\n * @return the value of the continued fraction evaluated at x.\n * @throws ConvergenceException if the algorithm fails to converge.\n */\n/**\n * Evaluates the continued fraction at the value x.\n * @param x the evaluation point.\n * @param epsilon maximum error allowed.\n * @return the value of the continued fraction evaluated at x.\n * @throws ConvergenceException if the algorithm fails to converge.\n */\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\n\nfun mean(xs: DoubleArray) = xs.average()\n\nfun correlationPearson(xs: DoubleArray, ys: DoubleArray): Double {\n    require(xs.size == ys.size) { \"Two series must have the same size.\" }\n    require(xs.isNotEmpty()) { \"Can't correlate empty sequences.\" }\n\n    val mx = mean(xs)\n    val my = mean(ys)\n\n    var cov = 0.0\n    var d2x = 0.0\n    var d2y = 0.0\n\n    for (i in xs.indices) {\n        val dx = xs[i] - mx\n        val dy = ys[i] - my\n\n        cov += dx * dy\n        d2x += dx.pow(2)\n        d2y += dy.pow(2)\n    }\n\n    require(d2x != 0.0 && d2y != 0.0) { \"Correlation is not defined for sequences with zero variation.\" }\n\n    return cov.div(sqrt(d2x * d2y))\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.pow\n\nclass ForsythePolynomialGenerator(private val knots: DoubleArray) {\n    private val ps: ArrayList<PolynomialFunction>\n\n    init {\n        require(knots.isNotEmpty()) { \"The knots list must not be empty\" }\n\n        ps = arrayListOf(\n            PolynomialFunction(doubleArrayOf(1.0)),\n            PolynomialFunction(doubleArrayOf(-knots.average(), 1.0))\n        )\n    }\n\n    private fun alphaBeta(i: Int): Pair<Double, Double> {\n        require(i == ps.size) { \"Alpha must be calculated sequentially.\" }\n\n        val p = ps.last()\n        val pp = ps[ps.size - 2]\n        var sxp = 0.0\n        var sp2 = 0.0\n        var spp2 = 0.0\n\n        for (x in knots) {\n            val pv2 = p.value(x).pow(2)\n            val ppv2 = pp.value(x).pow(2)\n            sxp += x * pv2\n            sp2 += pv2\n            spp2 += ppv2\n        }\n\n        return Pair(sxp / sp2, sp2 / spp2)\n    }\n\n    fun getPolynomial(n: Int): PolynomialFunction {\n\n        require(n >= 0) { \"Degree of Forsythe polynomial must not be negative\" }\n\n        require(n < knots.size) { \"Degree of Forsythe polynomial must not exceed knots.size - 1\" }\n\n        if (n >= ps.size) {\n            val sz = ps.size\n\n            for (k in sz..n + 1) {\n                val (a, b) = alphaBeta(k)\n                val pPrev = ps.last()\n                val pPrevPrev = ps[ps.size - 2]\n                val p = X * pPrev - a * pPrev - b * pPrevPrev\n                ps.add(p)\n            }\n        }\n\n        return ps[n]\n    }\n\n    companion object {\n        val X = PolynomialFunction(doubleArrayOf(0.0, 1.0))\n    }\n}\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.PI\nimport kotlin.math.abs\nimport kotlin.math.exp\nimport kotlin.math.ln\n\n/**\n * This is a utility class that provides computation methods related to the\n * Gamma family of functions.\n *\n * @version $Id: Gamma.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject Gamma {\n    /**\n     * [Euler-Mascheroni constant](https://en.wikipedia.org/wiki/Euler-Mascheroni_constant)\n     * @since 2.0\n     */\n    val GAMMA = 0.577215664901532860606512090082\n    /** Maximum allowed numerical error.  */\n    private val DEFAULT_EPSILON = 10e-15\n    /** Lanczos coefficients  */\n    private val LANCZOS = doubleArrayOf(\n        0.99999999999999709182,\n        57.156235665862923517,\n        -59.597960355475491248,\n        14.136097974741747174,\n        -0.49191381609762019978,\n        .33994649984811888699e-4,\n        .46523628927048575665e-4,\n        -.98374475304879564677e-4,\n        .15808870322491248884e-3,\n        -.21026444172410488319e-3,\n        .21743961811521264320e-3,\n        -.16431810653676389022e-3,\n        .84418223983852743293e-4,\n        -.26190838401581408670e-4,\n        .36899182659531622704e-5\n    )\n    /** Avoid repeated computation of log of 2 PI in logGamma  */\n    private val HALF_LOG_2_PI = 0.5 * ln(2.0 * PI)\n    // limits for switching algorithm in digamma\n    /** C limit.  */\n    private val C_LIMIT = 49.0\n    /** S limit.  */\n    private val S_LIMIT = 1e-5\n\n    /**\n     * Returns the natural logarithm of the gamma function &#915;(x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  * [\n * Gamma Function](mathworld.wolfram.com/GammaFunction.html), equation (28).\n     *  * [\n * Lanczos Approximation](mathworld.wolfram.com/LanczosApproximation.html), equations (1) through (5).\n     *  * [Paul Godfrey, A note on\n * the computation of the convergent Lanczos complex Gamma approximation\n](https://my.fit.edu/~gabdo/gamma.txt) *\n     *\n     *\n     * @param x Value.\n     * @return log(&#915;(x))\n     */\n    fun logGamma(x: Double): Double {\n        val ret: Double\n\n        if (x.isNaN() || x <= 0.0) {\n            ret = Double.NaN\n        } else {\n            val g = 607.0 / 128.0\n\n            var sum = 0.0\n            for (i in LANCZOS.size - 1 downTo 1) {\n                sum = sum + LANCZOS[i] / (x + i)\n            }\n            sum = sum + LANCZOS[0]\n\n            val tmp = x + g + .5\n            ret = (x + .5) * ln(tmp) - tmp +\n                    HALF_LOG_2_PI + ln(sum / x)\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the regularized gamma function P(a, x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Gamma Function](mathworld.wolfram.com/RegularizedGammaFunction.html), equation (1)\n     *\n     *  *\n     * [\n * Incomplete Gamma Function](mathworld.wolfram.com/IncompleteGammaFunction.html), equation (4).\n     *\n     *  *\n     * [\n * Confluent Hypergeometric Function of the First Kind](mathworld.wolfram.com/ConfluentHypergeometricFunctionoftheFirstKind.html), equation (1).\n     *\n     *\n     *\n     * @param a the a parameter.\n     * @param x the value.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized gamma function P(a, x)\n     * @throws MaxCountExceededException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedGammaP(\n        a: Double,\n        x: Double,\n        epsilon: Double = DEFAULT_EPSILON,\n        maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        val ret: Double\n\n        if (a.isNaN() || x.isNaN() || a <= 0.0 || x < 0.0) {\n            ret = Double.NaN\n        } else if (x == 0.0) {\n            ret = 0.0\n        } else if (x >= a + 1) {\n            // use regularizedGammaQ because it should converge faster in this\n            // case.\n            ret = 1.0 - regularizedGammaQ(a, x, epsilon, maxIterations)\n        } else {\n            // calculate series\n            var n = 0.0 // current element index\n            var an = 1.0 / a // n-th element in the series\n            var sum = an // partial sum\n            while (abs(an / sum) > epsilon &&\n                n < maxIterations &&\n                sum < Double.POSITIVE_INFINITY\n            ) {\n                // compute next element in the series\n                n = n + 1.0\n                an = an * (x / (a + n))\n\n                // update partial sum\n                sum = sum + an\n            }\n            if (n >= maxIterations) {\n                error(\"MaxCountExceeded - maxIterations: $maxIterations\")\n            } else if (sum.isInfinite()) {\n                ret = 1.0\n            } else {\n                ret = exp(-x + a * ln(x) - logGamma(a)) * sum\n            }\n        }\n\n        return ret\n    }\n\n    /**\n     * Returns the regularized gamma function Q(a, x) = 1 - P(a, x).\n     *\n     * The implementation of this method is based on:\n     *\n     *  *\n     * [\n * Regularized Gamma Function](mathworld.wolfram.com/RegularizedGammaFunction.html), equation (1).\n     *\n     *  *\n     * [\n * Regularized incomplete gamma function: Continued fraction representations\n * (formula 06.08.10.0003)](functions.wolfram.com/GammaBetaErf/GammaRegularized/10/0003/)\n     *\n     *\n     *\n     * @param a the a parameter.\n     * @param x the value.\n     * @param epsilon When the absolute value of the nth item in the\n     * series is less than epsilon the approximation ceases to calculate\n     * further elements in the series.\n     * @param maxIterations Maximum number of \"iterations\" to complete.\n     * @return the regularized gamma function P(a, x)\n     * @throws MaxCountExceededException if the algorithm fails to converge.\n     */\n    @JvmOverloads\n    fun regularizedGammaQ(\n        a: Double,\n        x: Double,\n        epsilon: Double = DEFAULT_EPSILON,\n        maxIterations: Int = Int.MAX_VALUE\n    ): Double {\n        var ret: Double\n\n        if (a.isNaN() || x.isNaN() || a <= 0.0 || x < 0.0) {\n            ret = Double.NaN\n        } else if (x == 0.0) {\n            ret = 1.0\n        } else if (x < a + 1.0) {\n            // use regularizedGammaP because it should converge faster in this\n            // case.\n            ret = 1.0 - regularizedGammaP(a, x, epsilon, maxIterations)\n        } else {\n            // create continued fraction\n            val cf = object : ContinuedFraction() {\n\n                override fun getA(n: Int, x: Double): Double {\n                    return 2.0 * n + 1.0 - a + x\n                }\n\n                override fun getB(n: Int, x: Double): Double {\n                    return n * (a - n)\n                }\n            }\n\n            ret = 1.0 / cf.evaluate(x, epsilon, maxIterations)\n            ret = exp(-x + a * ln(x) - logGamma(a)) * ret\n        }\n\n        return ret\n    }\n\n\n    /**\n     *\n     * Computes the digamma function of x.\n     *\n     *\n     * This is an independently written implementation of the algorithm described in\n     * Jose Bernardo, Algorithm AS 103: Psi (Digamma) Function, Applied Statistics, 1976.\n     *\n     *\n     * Some of the constants have been changed to increase accuracy at the moderate expense\n     * of run-time.  The result should be accurate to within 10^-8 absolute tolerance for\n     * x >= 10^-5 and within 10^-8 relative tolerance for x > 0.\n     *\n     *\n     * Performance for large negative values of x will be quite expensive (proportional to\n     * |x|).  Accuracy for negative values of x should be about 10^-8 absolute for results\n     * less than 10^5 and 10^-8 relative for results larger than that.\n     *\n     * @param x Argument.\n     * @return digamma(x) to within 10-8 relative or absolute error whichever is smaller.\n     * @see [Digamma](https://en.wikipedia.org/wiki/Digamma_function)\n     *\n     * @see [Bernardo&apos;s original article ](https://www.uv.es/~bernardo/1976AppStatist.pdf)\n     *\n     * @since 2.0\n     */\n    fun digamma(x: Double): Double {\n        if (x > 0 && x <= S_LIMIT) {\n            // use method 5 from Bernardo AS103\n            // accurate to O(x)\n            return -GAMMA - 1 / x\n        }\n\n        if (x >= C_LIMIT) {\n            // use method 4 (accurate to O(1/x^8)\n            val inv = 1 / (x * x)\n            //            1       1        1         1\n            // log(x) -  --- - ------ + ------- - -------\n            //           2 x   12 x^2   120 x^4   252 x^6\n            return ln(x) - 0.5 / x - inv * (1.0 / 12 + inv * (1.0 / 120 - inv / 252))\n        }\n\n        return digamma(x + 1) - 1 / x\n    }\n\n    /**\n     * Computes the trigamma function of x.\n     * This function is derived by taking the derivative of the implementation\n     * of digamma.\n     *\n     * @param x Argument.\n     * @return trigamma(x) to within 10-8 relative or absolute error whichever is smaller\n     * @see [Trigamma](https://en.wikipedia.org/wiki/Trigamma_function)\n     *\n     * @see Gamma.digamma\n     * @since 2.0\n     */\n    fun trigamma(x: Double): Double {\n        if (x > 0 && x <= S_LIMIT) {\n            return 1 / (x * x)\n        }\n\n        if (x >= C_LIMIT) {\n            val inv = 1 / (x * x)\n            //  1    1      1       1       1\n            //  - + ---- + ---- - ----- + -----\n            //  x      2      3       5       7\n            //      2 x    6 x    30 x    42 x\n            return 1 / x + inv / 2 + inv / x * (1.0 / 6 - inv * (1.0 / 30 + inv / 42))\n        }\n\n        return trigamma(x + 1) + 1 / (x * x)\n    }\n}\n/**\n * Default constructor.  Prohibit instantiation.\n */\n/**\n * Returns the regularized gamma function P(a, x).\n *\n * @param a Parameter.\n * @param x Value.\n * @return the regularized gamma function P(a, x).\n * @throws MaxCountExceededException if the algorithm fails to converge.\n */\n/**\n * Returns the regularized gamma function Q(a, x) = 1 - P(a, x).\n *\n * @param a the a parameter.\n * @param x the value.\n * @return the regularized gamma function Q(a, x)\n * @throws MaxCountExceededException if the algorithm fails to converge.\n */\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport jetbrains.datalore.plot.base.stat.math3.Incrementor.MaxCountExceededCallback\nimport kotlin.jvm.JvmOverloads\n\n\n/**\n * Utility that increments a counter until a maximum is reached, at\n * which point, the instance will by default throw a\n * [MaxCountExceededException].\n * However, the user is able to override this behaviour by defining a\n * custom [callback][MaxCountExceededCallback], in order to e.g.\n * select which exception must be thrown.\n *\n * @version $Id$\n * @since 3.0\n */\nclass Incrementor\n/**\n * Defines a maximal count and a callback method to be triggered at\n * counter exhaustion.\n *\n * @param max Maximal count.\n * @param cb Function to be called when the maximal count has been reached.\n */\n@JvmOverloads constructor(\n    /**\n     * Upper limit for the counter.\n     */\n    /**\n     * Gets the upper limit of the counter.\n     *\n     * @return the counter upper limit.\n     */\n    /**\n     * Sets the upper limit for the counter.\n     * This does not automatically reset the current count to zero (see\n     * [.resetCount]).\n     *\n     * @param max Upper limit of the counter.\n     */\n    var maximalCount: Int = 0,\n    /**\n     * Function called at counter exhaustion.\n     */\n    private val maxCountCallback: MaxCountExceededCallback = object : MaxCountExceededCallback {\n        /** {@inheritDoc}  */\n        override fun trigger(maximalCount: Int) {\n            error(\"MaxCountExceeded: $maximalCount\")\n        }\n    }\n) {\n    /**\n     * Current count.\n     */\n    /**\n     * Gets the current count.\n     *\n     * @return the current count.\n     */\n    var count = 0\n        private set\n\n    /**\n     * Checks whether a single increment is allowed.\n     *\n     * @return `false` if the next call to [ incrementCount][.incrementCount] will trigger a `MaxCountExceededException`,\n     * `true` otherwise.\n     */\n    fun canIncrement(): Boolean {\n        return count < maximalCount\n    }\n\n    /**\n     * Performs multiple increments.\n     * See the other [incrementCount][.incrementCount] method).\n     *\n     * @param value Number of increments.\n     * @throws MaxCountExceededException at counter exhaustion.\n     */\n    fun incrementCount(value: Int) {\n        for (i in 0 until value) {\n            incrementCount()\n        }\n    }\n\n    /**\n     * Adds one to the current iteration count.\n     * At counter exhaustion, this method will call the\n     * [trigger][MaxCountExceededCallback.trigger] method of the\n     * callback object passed to the\n     * [constructor][.Incrementor].\n     * If not explictly set, a default callback is used that will throw\n     * a `MaxCountExceededException`.\n     *\n     * @throws MaxCountExceededException at counter exhaustion, unless a\n     * custom [callback][MaxCountExceededCallback] has been set at\n     * construction.\n     */\n    fun incrementCount() {\n        if (++count > maximalCount) {\n            maxCountCallback.trigger(maximalCount)\n        }\n    }\n\n    /**\n     * Resets the counter to 0.\n     */\n    fun resetCount() {\n        count = 0\n    }\n\n    /**\n     * Defines a method to be called at counter exhaustion.\n     * The [trigger][.trigger] method should usually throw an exception.\n     */\n    interface MaxCountExceededCallback {\n        /**\n         * Function called when the maximal count has been reached.\n         *\n         * @param maximalCount Maximal count.\n         */\n        fun trigger(maximalCount: Int)\n    }\n}\n/**\n * Default constructor.\n * For the new instance to be useful, the maximal count must be set\n * by calling [setMaximalCount][.setMaximalCount].\n */\n/**\n * Defines a maximal count.\n *\n * @param max Maximal count.\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n *  Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.abs\nimport kotlin.math.sqrt\n\n/**\n * Implements the <a href=\"http://en.wikipedia.org/wiki/Local_regression\">\n * Local Regression Algorithm</a> (also Loess, Lowess) for interpolation of\n * real univariate functions.\n * <p/>\n * For reference, see\n * <a href=\"http://www.math.tau.ac.il/~yekutiel/MA seminar/Cleveland 1979.pdf\">\n * William S. Cleveland - Robust Locally Weighted Regression and Smoothing\n * Scatterplots</a>\n * <p/>\n * This class implements both the loess method and serves as an interpolation\n * adapter to it, allowing one to build a spline on the obtained loess fit.\n *\n * @version $Id: LoessInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 2.0\n */\n\n/**\n * Implements the <a href=\"http://en.wikipedia.org/wiki/Local_regression\">\n * Local Regression Algorithm</a> (also Loess, Lowess) for interpolation of\n * real univariate functions.\n * <p/>\n * For reference, see\n * <a href=\"http://www.math.tau.ac.il/~yekutiel/MA seminar/Cleveland 1979.pdf\">\n * William S. Cleveland - Robust Locally Weighted Regression and Smoothing\n * Scatterplots</a>\n * <p/>\n * This class implements both the loess method and serves as an interpolation\n * adapter to it, allowing one to build a spline on the obtained loess fit.\n *\n * @version $Id: LoessInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n * @since 2.0\n */\n\nclass LoessInterpolator(\n    private val bandwidth: Double = DEFAULT_BANDWIDTH,\n    private val robustnessIters: Int = DEFAULT_ROBUSTNESS_ITERS,\n    private val accuracy: Double = DEFAULT_ACCURACY\n) {\n\n    /**\n     * Construct a new {@link LoessInterpolator}\n     * with given bandwidth, number of robustness iterations and accuracy.\n     *\n     * @param bandwidth The bandwidth parameter: when computing the loess fit at\n     * a particular point, this fraction of source points closest\n     * to the current point is taken into account for computing\n     * a least-squares regression.\n     * A sensible value is usually 0.25 to 0.5.\n     * A sensible value is usually 0.25 to 0.5, the default value is\n     * {@link #DEFAULT_BANDWIDTH}.\n     * @param robustnessIters The number of robustness iterations parameter:\n     * this many robustness iterations are done.\n     * A sensible value is usually 0 (just the initial fit without any\n     * robustness iterations) to 4, the default value is\n     * {@link #DEFAULT_ROBUSTNESS_ITERS}.\n     * @param accuracy If the median residual at a certain robustness iteration\n     * is less than this amount, no more iterations are done.\n     *\n     * @throws OutOfRangeException if bandwidth does not lie in the interval [0,1].\n     * @throws NotPositiveException if {@code robustnessIters} is negative.\n     * @see #LoessInterpolator(double, int)\n     * @since 2.1\n     */\n\n    init {\n        if (bandwidth <= 0 || bandwidth > 1)\n            error(\"Out of range of bandwidth value: $bandwidth should be > 0 and <= 1\")\n\n        if (robustnessIters < 0)\n            error(\"Not positive Robutness iterationa: $robustnessIters\")\n    }\n\n    /**\n     * Compute an interpolating function by performing a loess fit\n     * on the data at the original abscissae and then building a cubic spline\n     * with a\n     * [org.apache.commons.math3.analysis.interpolation.SplineInterpolator]\n     * on the resulting fit.\n     *\n     * @param xval the arguments for the interpolation points\n     * @param yval the values for the interpolation points\n     * @return A cubic spline built upon a loess fit to the data at the original abscissae\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     */\n    fun interpolate(xval: DoubleArray, yval: DoubleArray): PolynomialSplineFunction {\n        return SplineInterpolator().interpolate(xval, smooth(xval, yval))\n    }\n\n    /**\n     * Compute a weighted loess fit on the data at the original abscissae.\n     *\n     * @param xval Arguments for the interpolation points.\n     * @param yval Values for the interpolation points.\n     * @param weights point weights: coefficients by which the robustness weight\n     * of a point is multiplied.\n     * @return the values of the loess fit at corresponding original abscissae.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     * @since 2.1\n     */\n    private fun smooth(xval: DoubleArray, yval: DoubleArray, weights: DoubleArray): DoubleArray {\n        if (xval.size != yval.size) {\n            error(\"Dimension mismatch of interpolation points: ${xval.size} != ${yval.size}\")\n        }\n        val n = xval.size\n        if (n == 0) {\n            error(\"No data to interpolate\")\n        }\n        checkAllFiniteReal(xval)\n        checkAllFiniteReal(yval)\n        checkAllFiniteReal(weights)\n        MathArrays.checkOrder(xval)\n        if (n == 1) {\n            return doubleArrayOf(yval[0])\n        }\n        if (n == 2) {\n            return doubleArrayOf(yval[0], yval[1])\n        }\n        val bandwidthInPoints = (bandwidth * n).toInt()\n        if (bandwidthInPoints < 2) {\n            error(\"LOESS 'bandwidthInPoints' is too small: $bandwidthInPoints < 2\")\n        }\n        val res = DoubleArray(n)\n        val residuals = DoubleArray(n)\n        val sortedResiduals = DoubleArray(n)\n        val robustnessWeights = DoubleArray(n)\n        // Do an initial fit and 'robustnessIters' robustness iterations.\n        // This is equivalent to doing 'robustnessIters+1' robustness iterations\n        // starting with all robustness weights set to 1.\n        robustnessWeights.fill(1.0)\n        for (iter in 0..robustnessIters) {\n            val bandwidthInterval = intArrayOf(0, bandwidthInPoints - 1)\n            // At each x, compute a local weighted linear regression\n            for (i in 0 until n) {\n                val x = xval[i]\n                // Find out the interval of source points on which\n                // a regression is to be made.\n                if (i > 0) {\n                    updateBandwidthInterval(\n                        xval,\n                        weights,\n                        i,\n                        bandwidthInterval\n                    )\n                }\n                val ileft = bandwidthInterval[0]\n                val iright = bandwidthInterval[1]\n                // Compute the point of the bandwidth interval that is\n                // farthest from x\n                val edge: Int\n                edge = if (xval[i] - xval[ileft] > xval[iright] - xval[i]) {\n                    ileft\n                } else {\n                    iright\n                }\n                // Compute a least-squares linear fit weighted by\n                // the product of robustness weights and the tricube\n                // weight function.\n                // See http://en.wikipedia.org/wiki/Linear_regression\n                // (section \"Univariate linear case\")\n                // and http://en.wikipedia.org/wiki/Weighted_least_squares\n                // (section \"Weighted least squares\")\n                var sumWeights = 0.0\n                var sumX = 0.0\n                var sumXSquared = 0.0\n                var sumY = 0.0\n                var sumXY = 0.0\n                val denom: Double = abs(1.0 / (xval[edge] - x))\n                for (k in ileft..iright) {\n                    val xk = xval[k]\n                    val yk = yval[k]\n                    val dist = if (k < i) x - xk else xk - x\n                    val w: Double = tricube(dist * denom) * robustnessWeights[k] * weights[k]\n                    val xkw = xk * w\n                    sumWeights += w\n                    sumX += xkw\n                    sumXSquared += xk * xkw\n                    sumY += yk * w\n                    sumXY += yk * xkw\n                }\n                val meanX = sumX / sumWeights\n                val meanY = sumY / sumWeights\n                val meanXY = sumXY / sumWeights\n                val meanXSquared = sumXSquared / sumWeights\n                val beta: Double\n                beta = if (sqrt(abs(meanXSquared - meanX * meanX)) < accuracy) {\n                    0.0\n                } else {\n                    (meanXY - meanX * meanY) / (meanXSquared - meanX * meanX)\n                }\n                val alpha = meanY - beta * meanX\n                res[i] = beta * x + alpha\n                residuals[i] = abs(yval[i] - res[i])\n            }\n            // No need to recompute the robustness weights at the last\n            // iteration, they won't be needed anymore\n            if (iter == robustnessIters) {\n                break\n            }\n            // Recompute the robustness weights.\n            // Find the median residual.\n            // An arraycopy and a sort are completely tractable here,\n            // because the preceding loop is a lot more expensive\n            residuals.copyInto(sortedResiduals, 0, 0, n)\n            sortedResiduals.sort()\n\n            val medianResidual = sortedResiduals[n / 2]\n            if (abs(medianResidual) < accuracy) {\n                break\n            }\n            for (i in 0 until n) {\n                val arg = residuals[i] / (6 * medianResidual)\n                if (arg >= 1) {\n                    robustnessWeights[i] = 0.0\n                } else {\n                    val w = 1 - arg * arg\n                    robustnessWeights[i] = w * w\n                }\n            }\n        }\n        return res\n    }\n\n\n    /**\n     * Given an index interval into xval that embraces a certain number of\n     * points closest to `xval[i-1]`, update the interval so that it\n     * embraces the same number of points closest to `xval[i]`,\n     * ignoring zero weights.\n     *\n     * @param xval Arguments array.\n     * @param weights Weights array.\n     * @param i Index around which the new interval should be computed.\n     * @param bandwidthInterval a two-element array {left, right} such that:\n     * `(left==0 or xval[i] - xval[left-1] > xval[right] - xval[i])`\n     * and\n     * `(right==xval.length-1 or xval[right+1] - xval[i] > xval[i] - xval[left])`.\n     * The array will be updated.\n     */\n    private fun updateBandwidthInterval(\n        xval: DoubleArray, weights: DoubleArray,\n        i: Int,\n        bandwidthInterval: IntArray\n    ) {\n        val left = bandwidthInterval[0]\n        val right = bandwidthInterval[1]\n        // The right edge should be adjusted if the next point to the right\n        // is closer to xval[i] than the leftmost point of the current interval\n        val nextRight: Int = nextNonzero(weights, right)\n        if (nextRight < xval.size && xval[nextRight] - xval[i] < xval[i] - xval[left]) {\n            val nextLeft: Int = nextNonzero(\n                weights, bandwidthInterval[0]\n            )\n            bandwidthInterval[0] = nextLeft\n            bandwidthInterval[1] = nextRight\n        }\n    }\n\n\n    /**\n     * Compute the\n     * [tricube](http://en.wikipedia.org/wiki/Local_regression#Weight_function)\n     * weight function\n     *\n     * @param x Argument.\n     * @return `(1 - |x|<sup>3</sup>)<sup>3</sup>` for |x| &lt; 1, 0 otherwise.\n     */\n    private fun tricube(x: Double): Double {\n        val absX: Double = abs(x)\n        if (absX >= 1.0) {\n            return 0.0\n        }\n        val tmp = 1 - absX * absX * absX\n        return tmp * tmp * tmp\n    }\n\n    /**\n     * Return the smallest index `j` such that\n     * `j > i && (j == weights.length || weights[j] != 0)`.\n     *\n     * @param weights Weights array.\n     * @param i Index from which to start search.\n     * @return the smallest compliant index.\n     */\n    private fun nextNonzero(weights: DoubleArray, i: Int): Int {\n        var j = i + 1\n        while (j < weights.size && weights[j] == 0.0) {\n            ++j\n        }\n        return j\n    }\n\n    /**\n     * Compute a loess fit on the data at the original abscissae.\n     *\n     * @param xval the arguments for the interpolation points\n     * @param yval the values for the interpolation points\n     * @return values of the loess fit at corresponding original abscissae\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `xval` not sorted in strictly increasing order.\n     * @throws DimensionMismatchException if `xval` and `yval` have\n     * different sizes.\n     * @throws NoDataException if `xval` or `yval` has zero size.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException if\n     * any of the arguments and values are not finite real numbers.\n     * @throws NumberIsTooSmallException if the bandwidth is too small to\n     * accomodate the size of the input data (i.e. the bandwidth must be\n     * larger than 2/n).\n     */\n    private fun smooth(xval: DoubleArray, yval: DoubleArray): DoubleArray {\n        if (xval.size != yval.size) {\n            error(\"Dimension mismatch: ${xval.size} != ${yval.size}\")\n        }\n        val unitWeights = DoubleArray(xval.size)\n        unitWeights.fill(1.0)\n        return smooth(xval, yval, unitWeights)\n    }\n\n    /**\n     * Check that the argument is a real number.\n     *\n     * @param x Argument.\n     * @throws NotFiniteNumberException if `x` is not a\n     * finite real number.\n     */\n    private fun checkFinite(x: Double) {\n        if (x.isInfinite() || x.isNaN()) {\n            error(\"Argument $x is not a finite number\")\n        }\n    }\n\n    /**\n     * Check that all elements of an array are finite real numbers.\n     *\n     * @param values Values array.\n     * @throws org.apache.commons.math3.exception.NotFiniteNumberException\n     * if one of the values is not a finite real number.\n     */\n    private fun checkAllFiniteReal(values: DoubleArray) {\n        for (i in values.indices) {\n            checkFinite(values[i])\n        }\n    }\n\n    companion object {\n        /** Default value of the bandwidth parameter.  */\n        const val DEFAULT_BANDWIDTH = 0.3\n\n        /** Default value of the number of robustness iterations.  */\n        const val DEFAULT_ROBUSTNESS_ITERS = 2\n\n        /**\n         * Default value for accuracy.\n         * @since 2.1\n         */\n        const val DEFAULT_ACCURACY = 1e-12\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n/**\n * Arrays utilities.\n *\n * @since 3.0\n * @version $Id$\n */\n\nobject MathArrays {\n\n    /**\n     * Specification of ordering direction.\n     */\n    enum class OrderDirection {\n        /** Constant for increasing direction.  */\n        INCREASING,\n        /** Constant for decreasing direction.  */\n        DECREASING\n    }\n\n    /**\n     * Check that the given array is sorted.\n     *\n     * @param val Values.\n     * @param dir Ordering direction.\n     * @param strict Whether the order should be strict.\n     * @param abort Whether to throw an exception if the check fails.\n     * @return `true` if the array is sorted.\n     * @throws NonMonotonicSequenceException if the array is not sorted\n     * and `abort` is `true`.\n     */\n    fun checkOrder(\n        `val`: DoubleArray, dir: OrderDirection?,\n        strict: Boolean, abort: Boolean\n    ): Boolean {\n        var previous = `val`[0]\n        val max = `val`.size\n        var index: Int\n        index = 1\n        ITEM@ while (index < max) {\n            when (dir) {\n                OrderDirection.INCREASING -> if (strict) {\n                    if (`val`[index] <= previous) {\n                        break@ITEM\n                    }\n                } else {\n                    if (`val`[index] < previous) {\n                        break@ITEM\n                    }\n                }\n                OrderDirection.DECREASING -> if (strict) {\n                    if (`val`[index] >= previous) {\n                        break@ITEM\n                    }\n                } else {\n                    if (`val`[index] > previous) {\n                        break@ITEM\n                    }\n                }\n                else -> error(\"\")\n            }\n            previous = `val`[index]\n            index++\n        }\n        if (index == max) { // Loop completed.\n            return true\n        }\n        // Loop early exit means wrong ordering.\n        return if (abort) {\n            error(\"Non monotonic sequence\")\n        } else {\n            false\n        }\n    }\n\n    /**\n     * Check that the given array is sorted.\n     *\n     * @param val Values.\n     * @param dir Ordering direction.\n     * @param strict Whether the order should be strict.\n     * @throws NonMonotonicSequenceException if the array is not sorted.\n     * @since 2.2\n     */\n    fun checkOrder(\n        `val`: DoubleArray, dir: OrderDirection?,\n        strict: Boolean\n    ) {\n        checkOrder(`val`, dir, strict, true)\n    }\n\n    /**\n     * Check that the given array is sorted in strictly increasing order.\n     *\n     * @param val Values.\n     * @throws NonMonotonicSequenceException if the array is not sorted.\n     * @since 2.2\n     */\n    fun checkOrder(`val`: DoubleArray) {\n        checkOrder(`val`, OrderDirection.INCREASING, true)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.math.floor\nimport kotlin.math.min\n\n\n/**\n * Provides percentile computation.\n * <p>\n * There are several commonly used methods for estimating percentiles (a.k.a.\n * quantiles) based on sample data.  For large samples, the different methods\n * agree closely, but when sample sizes are small, different methods will give\n * significantly different results.  The algorithm implemented here works as follows:\n * <ol>\n * <li>Let <code>n</code> be the length of the (sorted) array and\n * <code>0 < p <= 100</code> be the desired percentile.</li>\n * <li>If <code> n = 1 </code> return the unique array element (regardless of\n * the value of <code>p</code>); otherwise </li>\n * <li>Compute the estimated percentile position\n * <code> pos = p * (n + 1) / 100</code> and the difference, <code>d</code>\n * between <code>pos</code> and <code>floor(pos)</code> (i.e. the fractional\n * part of <code>pos</code>).</li>\n * <li> If <code>pos < 1</code> return the smallest element in the array.</li>\n * <li> Else if <code>pos >= n</code> return the largest element in the array.</li>\n * <li> Else let <code>lower</code> be the element in position\n * <code>floor(pos)</code> in the array and let <code>upper</code> be the\n * next element in the array.  Return <code>lower + d * (upper - lower)</code>\n * </li>\n * </ol></p>\n * <p>\n * To compute percentiles, the data must be at least partially ordered.  Input\n * arrays are copied and recursively partitioned using an ordering definition.\n * The ordering used by <code>Arrays.sort(double[])</code> is the one determined\n * by {@link java.lang.Double#compareTo(Double)}.  This ordering makes\n * <code>Double.NaN</code> larger than any other value (including\n * <code>Double.POSITIVE_INFINITY</code>).  Therefore, for example, the median\n * (50th percentile) of\n * <code>{0, 1, 2, 3, 4, Double.NaN}</code> evaluates to <code>2.5.</code></p>\n * <p>\n * Since percentile estimation usually involves interpolation between array\n * elements, arrays containing  <code>NaN</code> or infinite values will often\n * result in <code>NaN</code> or infinite values returned.</p>\n * <p>\n * Since 2.2, Percentile uses only selection instead of complete sorting\n * and caches selection algorithm state between calls to the various\n * {@code evaluate} methods. This greatly improves efficiency, both for a single\n * percentile and multiple percentile computations. To maximize performance when\n * multiple percentiles are computed based on the same data, users should set the\n * data array once using either one of the {@link #evaluate(double[], double)} or\n * {@link #setData(double[])} methods and thereafter {@link #evaluate(double)}\n * with just the percentile provided.\n * </p>\n * <p>\n * <strong>Note that this implementation is not synchronized.</strong> If\n * multiple threads access an instance of this class concurrently, and at least\n * one of the threads invokes the <code>increment()</code> or\n * <code>clear()</code> method, it must be synchronized externally.</p>\n *\n * @version $Id: Percentile.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nobject Percentile {\n\n    /** Minimum size under which we use a simple insertion sort rather than Hoare's select.  */\n    private const val MIN_SELECT_SIZE = 15\n\n    /** Maximum number of partitioning pivots cached (each level double the number of pivots).  */\n    private const val MAX_CACHED_LEVELS = 10\n\n    /**\n     * Returns an estimate of the `p`th percentile of the values\n     * in the `values` array.\n     *\n     * Calls to this method do not modify the internal `quantile`\n     * state of this statistic.\n     *\n     *  * Returns `Double.NaN` if `values` has length `0`\n     *  * Returns (for any value of `p`) `values[0]`\n     * if `values` has length `1`\n     *  * Throws `IllegalArgumentException` if `values`\n     * is null or p is not a valid quantile value (p must be greater than 0\n     * and less than or equal to 100)\n     *\n     * See [Percentile] for a description of the percentile estimation\n     * algorithm used.\n     *\n     * @param values input array of values\n     * @param p the percentile value to compute\n     * @return the percentile value or Double.NaN if the array is empty\n     * @throws IllegalArgumentException if `values` is null\n     * or p is invalid\n     */\n    fun evaluate(values: DoubleArray, p: Double): Double {\n        test(values, 0, 0, false)\n        return evaluate(values, 0, values.size, p)\n    }\n\n    /**\n     * This method is used by `evaluate(double[], int, int)` methods\n     * to verify that the input parameters designate a subarray of positive length.\n     *\n     * returns `true` iff the parameters designate a subarray of\n     * non-negative length\n     *  * throws `IllegalArgumentException` if the array is null or\n     * or the indices are invalid\n     *  * returns `false` if the array is non-null, but\n     * `length` is 0 unless `allowEmpty` is `true`\n     *\n     * @param values the input array\n     * @param begin index of the first array element to include\n     * @param length the number of elements to include\n     * @param allowEmpty if `true` then zero length arrays are allowed\n     * @return true if the parameters are valid\n     * @throws IllegalArgumentException if the indices are invalid or the array is null\n     * @since 3.0\n     */\n     private fun test(values: DoubleArray?, begin: Int, length: Int, allowEmpty: Boolean): Boolean {\n        if (values == null) {\n            error(\"Input array\")\n        }\n        if (begin < 0) {\n            error(\"start postion < 0\")\n        }\n        if (length < 0) {\n            error(\"length < 0\")\n        }\n        if (begin + length > values.size) {\n            error(\"subarray ends after array end\")\n        }\n        return if (length == 0 && !allowEmpty) {\n            false\n        } else true\n    }\n\n    /**\n     * Returns an estimate of the `p`th percentile of the values\n     * in the `values` array, starting with the element in (0-based)\n     * position `begin` in the array and including `length`\n     * values.\n     *\n     * Calls to this method do not modify the internal `quantile`\n     * state of this statistic.\n     *\n     *  * Returns `Double.NaN` if `length = 0`\n     *  * Returns (for any value of `p`) `values[begin]`\n     * if `length = 1 `\n     *  * Throws `IllegalArgumentException` if `values`\n     * is null , `begin` or `length` is invalid, or\n     * `p` is not a valid quantile value (p must be greater than 0\n     * and less than or equal to 100)\n     *\n     * See [Percentile] for a description of the percentile estimation\n     * algorithm used.\n     *\n     * @param values array of input values\n     * @param p  the percentile to compute\n     * @param begin  the first (0-based) element to include in the computation\n     * @param length  the number of array elements to include\n     * @return  the percentile value\n     * @throws IllegalArgumentException if the parameters are not valid or the\n     * input array is null\n     */\n    private fun evaluate(values: DoubleArray, begin: Int, length: Int, p: Double): Double {\n\n        test(values, begin, length, false)\n\n        if (p > 100 || p <= 0) {\n            error(\"out of bounds quantile value: $p, must be in (0, 100]\")\n        }\n        if (length == 0) {\n            return Double.NaN\n        }\n        if (length == 1) {\n            return values[begin] // always return single value for n = 1\n        }\n        val n = length.toDouble()\n        val pos = p * (n + 1) / 100\n        val fpos: Double = floor(pos)\n        val intPos = fpos.toInt()\n        val dif = pos - fpos\n\n        val work = DoubleArray(length)\n        values.copyInto(work, 0, begin, length)\n\n        val pivotsHeap = IntArray((0x1 shl MAX_CACHED_LEVELS) - 1)\n        pivotsHeap.fill(-1)\n\n        if (pos < 1) {\n            return select(work, pivotsHeap, 0)\n        }\n        if (pos >= n) {\n            return select(work, pivotsHeap, length - 1)\n        }\n        val lower: Double = select(work, pivotsHeap, intPos - 1)\n        val upper: Double = select(work, pivotsHeap, intPos)\n        return lower + dif * (upper - lower)\n    }\n\n    /**\n     * Select the k<sup>th</sup> smallest element from work array\n     * @param work work array (will be reorganized during the call)\n     * @param pivotsHeap set of pivot index corresponding to elements that\n     * are already at their sorted location, stored as an implicit heap\n     * (i.e. a sorted binary tree stored in a flat array, where the\n     * children of a node at index n are at indices 2n+1 for the left\n     * child and 2n+2 for the right child, with 0-based indices)\n     * @param k index of the desired element\n     * @return k<sup>th</sup> smallest element\n     */\n    private fun select(work: DoubleArray, pivotsHeap: IntArray, k: Int): Double {\n        var begin = 0\n        var end = work.size\n        var node = 0\n        while (end - begin > MIN_SELECT_SIZE) {\n            val pivot: Int\n            if (node < pivotsHeap.size && pivotsHeap[node] >= 0) { // the pivot has already been found in a previous call\n                                                                   // and the array has already been partitioned around it\n                pivot = pivotsHeap[node]\n            } else { // select a pivot and partition work array around it\n                pivot = partition(work, begin, end, medianOf3(work, begin, end))\n                if (node < pivotsHeap.size) {\n                    pivotsHeap[node] = pivot\n                }\n            }\n            if (k == pivot) { // the pivot was exactly the element we wanted\n                return work[k]\n            } else if (k < pivot) { // the element is in the left partition\n                end = pivot\n                node = min(2 * node + 1, pivotsHeap.size) // the min is here to avoid integer overflow\n            } else { // the element is in the right partition\n                begin = pivot + 1\n                node = min(2 * node + 2, pivotsHeap.size) // the min is here to avoid integer overflow\n            }\n        }\n        // the element is somewhere in the small sub-array\n        // sort the sub-array using insertion sort\n        insertionSort(work, begin, end)\n        return work[k]\n    }\n\n\n    /**\n     * Partition an array slice around a pivot\n     *\n     * Partitioning exchanges array elements such that all elements\n     * smaller than pivot are before it and all elements larger than\n     * pivot are after it\n     *\n     * @param work data array\n     * @param begin index of the first element of the slice\n     * @param end index after the last element of the slice\n     * @param pivot initial index of the pivot\n     * @return index of the pivot after partition\n     */\n    private fun partition(work: DoubleArray, begin: Int, end: Int, pivot: Int): Int {\n        val value = work[pivot]\n        work[pivot] = work[begin]\n        var i = begin + 1\n        var j = end - 1\n        while (i < j) {\n            while (i < j && work[j] >= value) {\n                --j\n            }\n            while (i < j && work[i] <= value) {\n                ++i\n            }\n            if (i < j) {\n                val tmp = work[i]\n                work[i++] = work[j]\n                work[j--] = tmp\n            }\n        }\n        if (i >= end || work[i] > value) {\n            --i\n        }\n        work[begin] = work[i]\n        work[i] = value\n        return i\n    }\n\n    /** Select a pivot index as the median of three\n     * @param work data array\n     * @param begin index of the first element of the slice\n     * @param end index after the last element of the slice\n     * @return the index of the median element chosen between the\n     * first, the middle and the last element of the array slice\n     */\n    private fun medianOf3(work: DoubleArray, begin: Int, end: Int): Int {\n        val inclusiveEnd = end - 1\n        val middle = begin + (inclusiveEnd - begin) / 2\n        val wBegin = work[begin]\n        val wMiddle = work[middle]\n        val wEnd = work[inclusiveEnd]\n        return if (wBegin < wMiddle) {\n            if (wMiddle < wEnd) {\n                middle\n            } else {\n                if (wBegin < wEnd) inclusiveEnd else begin\n            }\n        } else {\n            if (wBegin < wEnd) {\n                begin\n            } else {\n                if (wMiddle < wEnd) inclusiveEnd else middle\n            }\n        }\n    }\n\n    /**\n     * Sort in place a (small) array slice using insertion sort\n     * @param work array to sort\n     * @param begin index of the first element of the slice to sort\n     * @param end index after the last element of the slice to sort\n     */\n    private fun insertionSort(work: DoubleArray, begin: Int, end: Int) {\n        for (j in begin + 1 until end) {\n            val saved = work[j]\n            var i = j - 1\n            while (i >= begin && saved < work[i]) {\n                work[i + 1] = work[i]\n                i--\n            }\n            work[i + 1] = saved\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport jetbrains.datalore.base.gcommon.collect.Comparables.min\nimport jetbrains.datalore.base.gcommon.collect.Comparables.max\nimport kotlin.math.abs\n\n/**\n * Immutable representation of a real polynomial function with real coefficients.\n * <p>\n * <a href=\"http://mathworld.wolfram.com/HornersMethod.html\">Horner's Method</a>\n * is used to evaluate the function.</p>\n *\n * @version $Id: PolynomialFunction.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass PolynomialFunction(c: DoubleArray?) {\n\n    /**\n     * The coefficients of the polynomial, ordered by degree -- i.e.,\n     * coefficients[0] is the constant term and coefficients[n] is the\n     * coefficient of x^n where n is the degree of the polynomial.\n     */\n    private var coefficients: DoubleArray\n\n    /**\n     * Construct a polynomial with the given coefficients.  The first element\n     * of the coefficients array is the constant term.  Higher degree\n     * coefficients follow in sequence.  The degree of the resulting polynomial\n     * is the index of the last non-null element of the array, or 0 if all elements\n     * are null.\n     *\n     * The constructor makes a copy of the input array and assigns the copy to\n     * the coefficients property.\n     *\n     * @param c Polynomial coefficients.\n     * @throws NullArgumentException if `c` is `null`.\n     * @throws NoDataException if `c` is empty.\n     */\n    init {\n        if (c == null || c.isEmpty()) {\n            error(\"Empty polynomials coefficients array\")\n        }\n\n        var n = c.size\n        while (n > 1 && c[n - 1] == 0.0) {\n            --n\n        }\n        coefficients = DoubleArray(n)\n        c.copyInto(coefficients, 0, 0, n)\n    }\n\n    /**\n     * Compute the value of the function for the given argument.\n     *\n     * The value returned is <br></br>\n     * `coefficients[n] * x^n + ... + coefficients[1] * x  + coefficients[0]`\n     *\n     * @param x Argument for which the function value should be computed.\n     * @return the value of the polynomial at the given point.\n     * @see UnivariateFunction.value\n     */\n    fun value(x: Double): Double {\n        return evaluate(coefficients, x)\n    }\n\n    /**\n     * Uses Horner's Method to evaluate the polynomial with the given coefficients at\n     * the argument.\n     *\n     * @param coefficients Coefficients of the polynomial to evaluate.\n     * @param argument Input value.\n     * @return the value of the polynomial.\n     * @throws NoDataException if `coefficients` is empty.\n     * @throws NullArgumentException if `coefficients` is `null`.\n     */\n    private fun evaluate(coefficients: DoubleArray?, argument: Double): Double {\n\n        if (coefficients == null)\n            error(\"Null argument: coefficients of the polynomial to evaluate\")\n\n        val n = coefficients.size\n        if (n == 0) {\n            error(\"Empty polynomials coefficients array\")\n        }\n        var result = coefficients[n - 1]\n        for (j in n - 2 downTo 0) {\n            result = argument * result + coefficients[j]\n        }\n        return result\n    }\n\n    operator fun unaryPlus() = PolynomialFunction(coefficients)\n\n    operator fun unaryMinus(): PolynomialFunction {\n        val dd = DoubleArray(coefficients.size)\n\n        for ((i, c) in coefficients.withIndex()) {\n            dd[i] = -c\n        }\n\n        return PolynomialFunction(dd)\n    }\n\n    private fun apply_op(other: PolynomialFunction, op: (Double, Double) -> Double): PolynomialFunction {\n        val sz = max(coefficients.size, other.coefficients.size)\n        val nc = DoubleArray(sz)\n\n        for (i in (0 until sz)) {\n            val a = if (i < coefficients.size) coefficients[i] else 0.0\n            val b = if (i < other.coefficients.size) other.coefficients[i] else 0.0\n            nc[i] = op(a, b)\n        }\n\n        return PolynomialFunction(nc)\n    }\n\n    operator fun plus(other: PolynomialFunction): PolynomialFunction {\n        return apply_op(other) { x, y -> x + y }\n    }\n\n    operator fun minus(other: PolynomialFunction): PolynomialFunction {\n        return apply_op(other) { x, y -> x - y }\n    }\n\n    fun multiply(a: Double): PolynomialFunction {\n        val dd = DoubleArray(coefficients.size)\n\n        for ((i, c) in coefficients.withIndex()) {\n            dd[i] = a * c\n        }\n\n        return PolynomialFunction(dd)\n    }\n\n    operator fun times(other: PolynomialFunction): PolynomialFunction {\n        val nd = coefficients.size + other.coefficients.size - 1\n        val nc = DoubleArray(nd)\n\n        for (i in (0 until nd)) {\n            for (j in (0..i)) {\n                val a = if (j < coefficients.size) coefficients[j] else 0.0\n                val k = i - j\n                val b = if (k < other.coefficients.size) other.coefficients[k] else 0.0\n                nc[i] += a * b\n            }\n        }\n\n        return PolynomialFunction(nc)\n    }\n\n    fun degree(): Int = max(0, coefficients.indexOfLast { it != 0.0 })\n\n    operator fun compareTo(other: PolynomialFunction): Int {\n        val d1 = degree()\n        val d2 = other.degree()\n        val n = min(d1, d2) + 1\n\n        for (i in 0 until n) {\n            val a = coefficients[i]\n            val b = other.coefficients[i]\n\n            val res = a.compareTo(b)\n\n            if (res != 0)\n                return res\n        }\n\n        return d1.compareTo(d2)\n    }\n\n    override operator fun equals(other: Any?): Boolean {\n        if (other == null || other !is PolynomialFunction)\n            return false\n\n        return compareTo(other) == 0\n    }\n\n    override fun hashCode(): Int {\n        return coefficients.hashCode()\n    }\n\n    override fun toString(): String {\n        val sb = StringBuilder()\n\n        for (i in coefficients.lastIndex downTo 0) {\n\n            if (coefficients[i] != 0.0) {\n\n                if (!sb.isEmpty())\n                    sb.append(\" + \")\n\n                sb.append(coefficients[i].toString())\n\n                if (i > 0)\n                    sb.append(\"x\")\n\n                if (i > 1)\n                    sb.append(\"^\").append(i)\n            }\n        }\n\n        return sb.toString()\n    }\n}\n\noperator fun Double.times(p: PolynomialFunction): PolynomialFunction {\n    return p.multiply(this)\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Represents a polynomial spline function.\n * <p>\n * A <strong>polynomial spline function</strong> consists of a set of\n * <i>interpolating polynomials</i> and an ascending array of domain\n * <i>knot points</i>, determining the intervals over which the spline function\n * is defined by the constituent polynomials.  The polynomials are assumed to\n * have been computed to match the values of another function at the knot\n * points.  The value consistency constraints are not currently enforced by\n * <code>PolynomialSplineFunction</code> itself, but are assumed to hold among\n * the polynomials and knot points passed to the constructor.</p>\n * <p>\n * N.B.:  The polynomials in the <code>polynomials</code> property must be\n * centered on the knot points to compute the spline function values.\n * See below.</p>\n * <p>\n * The domain of the polynomial spline function is\n * <code>[smallest knot, largest knot]</code>.  Attempts to evaluate the\n * function at values outside of this range generate IllegalArgumentExceptions.\n * </p>\n * <p>\n * The value of the polynomial spline function for an argument <code>x</code>\n * is computed as follows:\n * <ol>\n * <li>The knot array is searched to find the segment to which <code>x</code>\n * belongs.  If <code>x</code> is less than the smallest knot point or greater\n * than the largest one, an <code>IllegalArgumentException</code>\n * is thrown.</li>\n * <li> Let <code>j</code> be the index of the largest knot point that is less\n * than or equal to <code>x</code>.  The value returned is <br>\n * <code>polynomials[j](x - knot[j])</code></li></ol></p>\n *\n * @version $Id: PolynomialSplineFunction.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass PolynomialSplineFunction(_knots: DoubleArray?, _polynomials: Array<PolynomialFunction?>)\n{\n    /**\n     * Spline segment interval delimiters (knots).\n     * Size is n + 1 for n segments.\n     */\n    val knots: DoubleArray\n\n    /**\n     * The polynomial functions that make up the spline.  The first element\n     * determines the value of the spline over the first subinterval, the\n     * second over the second, etc.   Spline function values are determined by\n     * evaluating these functions at `(x - knot[i])` where i is the\n     * knot segment to which x belongs.\n     */\n    val polynomials: Array<PolynomialFunction?>\n\n    /**\n     * Number of spline segments. It is equal to the number of polynomials and\n     * to the number of partition points - 1.\n     */\n    private val n : Int\n\n    /**\n     * Construct a polynomial spline function with the given segment delimiters\n     * and interpolating polynomials.\n     * The constructor copies both arrays and assigns the copies to the knots\n     * and polynomials properties, respectively.\n     *\n     * @param _knots Spline segment interval delimiters.\n     * @param _polynomials Polynomial functions that make up the spline.\n     * @throws NullArgumentException if either of the input arrays is {@code null}.\n     * @throws NumberIsTooSmallException if knots has length less than 2.\n     * @throws DimensionMismatchException if {@code polynomials.length != knots.length - 1}.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException if\n     * the {@code knots} array is not strictly increasing.\n     *\n     */\n    init {\n\n        if (_knots == null) {\n            error(\"Null argument \")\n        }\n        if (_knots.size < 2) {\n            error(\"Spline partition must have at least 2 points, got ${_knots.size}\")\n        }\n        if (_knots.size - 1 != _polynomials.size) {\n            error(\"Dimensions mismatch: ${_polynomials.size} polynomial functions !=  ${_knots.size} segment delimiters\")\n        }\n\n        MathArrays.checkOrder(_knots)\n\n        this.n = _knots.size - 1\n        this.knots = _knots\n\n        this.polynomials = arrayOfNulls<PolynomialFunction?>(n)\n        _polynomials.copyInto (this.polynomials, 0, 0, n)\n\n    }\n\n    /**\n     * Compute the value for the function.\n     * See [PolynomialSplineFunction] for details on the algorithm for\n     * computing the value of the function.\n     *\n     * @param v Point for which the function value should be computed.\n     * @return the value.\n     * @throws OutOfRangeException if `v` is outside of the domain of the\n     * spline function (smaller than the smallest knot point or larger than the\n     * largest knot point).\n     */\n    fun value(v: Double): Double? {\n        if (v < knots[0] || v > knots[n]) {\n            error(\"$v out of [${knots[0]}, ${knots[n]}] range\")\n        }\n\n        var i: Int =  knots.toMutableList().binarySearch(v)\n        if (i < 0) {\n            i = -i - 2\n        }\n        // This will handle the case where v is the last knot value\n        // There are only n-1 polynomials, so if v is the last knot\n        // then we will use the last polynomial to calculate the value.\n        if (i >= polynomials.size) {\n            i--\n        }\n        return polynomials[i]?.value(v - knots[i])\n    }\n\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\npackage jetbrains.datalore.plot.base.stat.math3\n\n\n/**\n * Computes a natural (also known as \"free\", \"unclamped\") cubic spline interpolation for the data set.\n *\n * The [.interpolate] method returns a [PolynomialSplineFunction]\n * consisting of n cubic polynomials, defined over the subintervals determined by the x values,\n * x[0] < x[i] ... < x[n].  The x values are referred to as \"knot points.\"\n *\n * The value of the PolynomialSplineFunction at a point x that is greater than or equal to the smallest\n * knot point and strictly less than the largest knot point is computed by finding the subinterval to which\n * x belongs and computing the value of the corresponding polynomial at `x - x[i] ` where\n * `i` is the index of the subinterval.  See [PolynomialSplineFunction] for more details.\n *\n * The interpolating polynomials satisfy:\n *  1. The value of the PolynomialSplineFunction at each of the input x values equals the\n * corresponding y value.\n *  1. Adjacent polynomials are equal through two derivatives at the knot points (i.e., adjacent polynomials\n * \"match up\" at the knot points, as do their first and second derivatives).\n *\n * The cubic spline interpolation algorithm implemented is as described in R.L. Burden, J.D. Faires,\n * <u>Numerical Analysis</u>, 4th Ed., 1989, PWS-Kent, ISBN 0-53491-585-X, pp 126-131.\n *\n *\n * @version $Id: SplineInterpolator.java 1244107 2012-02-14 16:17:55Z erans $\n */\n\nclass SplineInterpolator {\n    /**\n     * Computes an interpolating function for the data set.\n     * @param x the arguments for the interpolation points\n     * @param y the values for the interpolation points\n     * @return a function which interpolates the data set\n     * @throws DimensionMismatchException if `x` and `y`\n     * @throws DimensionMismatchException if `x` and `y`\n     * have different sizes.\n     * @throws org.apache.commons.math3.exception.NonMonotonicSequenceException\n     * if `x` is not sorted in strict increasing order.\n     * @throws NumberIsTooSmallException if the size of `x` is smaller\n     * than 3.\n     */\n    fun interpolate(x: DoubleArray, y: DoubleArray): PolynomialSplineFunction {\n        if (x.size != y.size) {\n            error(\"Dimension mismatch ${x.size} != ${y.size}\")\n        }\n        if (x.size < 3) {\n            error(\"Too small value of points number: ${x.size} < 3\")\n        }\n        // Number of intervals.  The number of data points is n + 1.\n        val n = x.size - 1\n        MathArrays.checkOrder(x)\n        // Differences between knot points\n        val h = DoubleArray(n)\n        for (i in 0 until n) {\n            h[i] = x[i + 1] - x[i]\n        }\n        val mu = DoubleArray(n)\n        val z = DoubleArray(n + 1)\n        mu[0] = 0.0\n        z[0] = 0.0\n\n        for (i in 1 until n) {\n            var g = 2.0 * (x[i + 1] - x[i - 1]) - h[i - 1] * mu[i - 1]\n            mu[i] = h[i] / g\n            z[i] =\n                (3.0 * (y[i + 1] * h[i - 1] - y[i] * (x[i + 1] - x[i - 1]) + y[i - 1] * h[i]) /\n                        (h[i - 1] * h[i]) - h[i - 1] * z[i - 1]) / g\n        }\n        // cubic spline coefficients --  b is linear, c quadratic, d is cubic (original y's are constants)\n        val b = DoubleArray(n)\n        val c = DoubleArray(n + 1)\n        val d = DoubleArray(n)\n        z[n] = 0.0\n        c[n] = 0.0\n        for (j in n - 1 downTo 0) {\n            c[j] = z[j] - mu[j] * c[j + 1]\n            b[j] = (y[j + 1] - y[j]) / h[j] - h[j] * (c[j + 1] + 2.0 * c[j]) / 3.0\n            d[j] = (c[j + 1] - c[j]) / (3.0 * h[j])\n        }\n        val polynomials: Array<PolynomialFunction?> = arrayOfNulls<PolynomialFunction>(n)\n        val coefficients = DoubleArray(4)\n        for (i in 0 until n) {\n            coefficients[0] = y[i]\n            coefficients[1] = b[i]\n            coefficients[2] = c[i]\n            coefficients[3] = d[i]\n            polynomials[i] = PolynomialFunction(coefficients)\n        }\n        return PolynomialSplineFunction(x, polynomials)\n    }\n}\n\n\n","/*\n * Copyright (c) 2019 JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n *\n * This file has been modified by JetBrains : Java code has been converted to Kotlin code.\n *\n * THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:\n *\n * Licensed to the Apache Software Foundation (ASF) under one or more\n * contributor license agreements.  See the NOTICE file distributed with\n * this work for additional information regarding copyright ownership.\n * The ASF licenses this file to You under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with\n * the License.  You may obtain a copy of the License at\n *\n *      https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\npackage jetbrains.datalore.plot.base.stat.math3\n\nimport kotlin.jvm.JvmOverloads\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\n\n/**\n * Utility routines for [UnivariateSolver] objects.\n *\n * @version $Id: UnivariateSolverUtils.java 1244107 2012-02-14 16:17:55Z erans $\n */\nobject UnivariateSolverUtils {\n\n    /**\n     * Convenience method to find a zero of a univariate real function.  A default\n     * solver is used.\n     *\n     * @param function Function.\n     * @param x0 Lower bound for the interval.\n     * @param x1 Upper bound for the interval.\n     * @return a value where the function is zero.\n     * @throws IllegalArgumentException if f is null or the endpoints do not\n     * specify a valid interval.\n     */\n    fun solve(function: UnivariateFunction, x0: Double, x1: Double): Double {\n        val solver = BrentSolver()\n        return solver.solve(Int.MAX_VALUE, function, x0, x1)\n    }\n\n    /**\n     * Convenience method to find a zero of a univariate real function.  A default\n     * solver is used.\n     *\n     * @param function Function.\n     * @param x0 Lower bound for the interval.\n     * @param x1 Upper bound for the interval.\n     * @param absoluteAccuracy Accuracy to be used by the solver.\n     * @return a value where the function is zero.\n     * @throws IllegalArgumentException if `function` is `null`,\n     * the endpoints do not specify a valid interval, or the absolute accuracy\n     * is not valid for the default solver.\n     */\n    fun solve(\n        function: UnivariateFunction,\n        x0: Double, x1: Double,\n        absoluteAccuracy: Double\n    ): Double {\n        val solver = BrentSolver(absoluteAccuracy)\n        return solver.solve(Int.MAX_VALUE, function, x0, x1)\n    }\n\n    /** Force a root found by a non-bracketing solver to lie on a specified side,\n     * as if the solver was a bracketing one.\n     * @param maxEval maximal number of new evaluations of the function\n     * (evaluations already done for finding the root should have already been subtracted\n     * from this number)\n     * @param f function to solve\n     * @param bracketing bracketing solver to use for shifting the root\n     * @param baseRoot original root found by a previous non-bracketing solver\n     * @param min minimal bound of the search interval\n     * @param max maximal bound of the search interval\n     * @param allowedSolution the kind of solutions that the root-finding algorithm may\n     * accept as solutions.\n     * @return a root approximation, on the specified side of the exact root\n     */\n    fun forceSide(\n        maxEval: Int, f: UnivariateFunction,\n        bracketing: BracketedUnivariateSolver<UnivariateFunction>,\n        baseRoot: Double, min: Double, max: Double,\n        allowedSolution: AllowedSolution\n    ): Double {\n\n        if (allowedSolution == AllowedSolution.ANY_SIDE) {\n            // no further bracketing required\n            return baseRoot\n        }\n\n        // find a very small interval bracketing the root\n        val step = max(\n            bracketing.absoluteAccuracy,\n            abs(baseRoot * bracketing.relativeAccuracy)\n        )\n        var xLo = max(min, baseRoot - step)\n        var fLo = f.value(xLo)\n        var xHi = min(max, baseRoot + step)\n        var fHi = f.value(xHi)\n        var remainingEval = maxEval - 2\n        while (remainingEval > 0) {\n\n            if (fLo >= 0 && fHi <= 0 || fLo <= 0 && fHi >= 0) {\n                // compute the root on the selected side\n                return bracketing.solve(remainingEval, f, xLo, xHi, baseRoot, allowedSolution)\n            }\n\n            // try increasing the interval\n            var changeLo = false\n            var changeHi = false\n            if (fLo < fHi) {\n                // increasing function\n                if (fLo >= 0) {\n                    changeLo = true\n                } else {\n                    changeHi = true\n                }\n            } else if (fLo > fHi) {\n                // decreasing function\n                if (fLo <= 0) {\n                    changeLo = true\n                } else {\n                    changeHi = true\n                }\n            } else {\n                // unknown variation\n                changeLo = true\n                changeHi = true\n            }\n\n            // update the lower bound\n            if (changeLo) {\n                xLo = max(min, xLo - step)\n                fLo = f.value(xLo)\n                remainingEval--\n            }\n\n            // update the higher bound\n            if (changeHi) {\n                xHi = min(max, xHi + step)\n                fHi = f.value(xHi)\n                remainingEval--\n            }\n\n        }\n\n        error(\"NoBracketing\")\n        //Exception - FAILED_BRACKETING xLo:$xLo, xHi: $xHi, fLo: $fLo, fHi: $fHi, maxEval: ${maxEval - remainingEval}, maxEval: $maxEval, baseRoot: $baseRoot, min: $min, max: $max\")\n    }\n\n    /**\n     * This method attempts to find two values a and b satisfying\n     *  *  ` lowerBound <= a < initial < b <= upperBound`\n     *  *  ` f(a) * f(b) <= 0 `\n     *\n     * If f is continuous on `[a,b],` this means that `a`\n     * and `b` bracket a root of f.\n     *\n     *\n     * The algorithm starts by setting\n     * `a := initial -1; b := initial +1,` examines the value of the\n     * function at `a` and `b` and keeps moving\n     * the endpoints out by one unit each time through a loop that terminates\n     * when one of the following happens:\n     *  *  ` f(a) * f(b) <= 0 ` --  success!\n     *  *  ` a = lower ` and ` b = upper`\n     * -- NoBracketingException\n     *  *  ` maximumIterations` iterations elapse\n     * -- NoBracketingException\n     *\n     * @param function Function.\n     * @param initial Initial midpoint of interval being expanded to\n     * bracket a root.\n     * @param lowerBound Lower bound (a is never lower than this value).\n     * @param upperBound Upper bound (b never is greater than this\n     * value).\n     * @param maximumIterations Maximum number of iterations to perform\n     * @return a two element array holding a and b.\n     * @throws NoBracketingException if the algorithm fails to find a and b\n     * satisfying the desired conditions.\n     * @throws IllegalArgumentException if function is null, maximumIterations\n     * is not positive, or initial is not between lowerBound and upperBound.\n     */\n    @JvmOverloads\n    fun bracket(\n        function: UnivariateFunction,\n        initial: Double,\n        lowerBound: Double, upperBound: Double,\n        maximumIterations: Int = Int.MAX_VALUE\n    ): DoubleArray {\n        if (maximumIterations <= 0) {\n            error(\"NotStrictlyPositive\")\n        }\n        verifySequence(lowerBound, initial, upperBound)\n\n        var a = initial\n        var b = initial\n        var fa: Double\n        var fb: Double\n        var numIterations = 0\n\n        do {\n            a = max(a - 1.0, lowerBound)\n            b = min(b + 1.0, upperBound)\n            fa = function.value(a)\n\n            fb = function.value(b)\n            ++numIterations\n        } while (fa * fb > 0.0 && numIterations < maximumIterations &&\n            (a > lowerBound || b < upperBound)\n        )\n\n        if (fa * fb > 0.0) {\n            error(\"NoBracketing\")\n            //LocalizedFormats.FAILED_BRACKETING,\n            //a, b, fa, fb,\n            //numIterations, maximumIterations, initial,\n            //lowerBound, upperBound\n        }\n\n        return doubleArrayOf(a, b)\n    }\n\n    /**\n     * Compute the midpoint of two values.\n     *\n     * @param a first value.\n     * @param b second value.\n     * @return the midpoint.\n     */\n    fun midpoint(a: Double, b: Double): Double {\n        return (a + b) * 0.5\n    }\n\n    /**\n     * Check whether the interval bounds bracket a root. That is, if the\n     * values at the endpoints are not equal to zero, then the function takes\n     * opposite signs at the endpoints.\n     *\n     * @param function Function.\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @return `true` if the function values have opposite signs at the\n     * given points.\n     */\n    fun isBracketing(\n        function: UnivariateFunction,\n        lower: Double,\n        upper: Double\n    ): Boolean {\n        val fLo = function.value(lower)\n        val fHi = function.value(upper)\n        return fLo >= 0 && fHi <= 0 || fLo <= 0 && fHi >= 0\n    }\n\n    /**\n     * Check whether the arguments form a (strictly) increasing sequence.\n     *\n     * @param start First number.\n     * @param mid Second number.\n     * @param end Third number.\n     * @return `true` if the arguments form an increasing sequence.\n     */\n    fun isSequence(\n        start: Double,\n        mid: Double,\n        end: Double\n    ): Boolean {\n        return start < mid && mid < end\n    }\n\n    /**\n     * Check that the endpoints specify an interval.\n     *\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NumberIsTooLargeException if `lower >= upper`.\n     */\n    fun verifyInterval(\n        lower: Double,\n        upper: Double\n    ) {\n        if (lower >= upper) {\n            error(\"NumberIsTooLarge\")\n            //LocalizedFormats.ENDPOINTS_NOT_AN_INTERVAL,\n            //lower, upper, false\n        }\n    }\n\n    /**\n     * Check that `lower < initial < upper`.\n     *\n     * @param lower Lower endpoint.\n     * @param initial Initial value.\n     * @param upper Upper endpoint.\n     * @throws NumberIsTooLargeException if `lower >= initial` or\n     * `initial >= upper`.\n     */\n    fun verifySequence(\n        lower: Double,\n        initial: Double,\n        upper: Double\n    ) {\n        verifyInterval(lower, initial)\n        verifyInterval(initial, upper)\n    }\n\n    /**\n     * Check that the endpoints specify an interval and the end points\n     * bracket a root.\n     *\n     * @param function Function.\n     * @param lower Lower endpoint.\n     * @param upper Upper endpoint.\n     * @throws NoBracketingException if function has the same sign at the\n     * endpoints.\n     */\n    fun verifyBracketing(\n        function: UnivariateFunction,\n        lower: Double,\n        upper: Double\n    ) {\n        verifyInterval(lower, upper)\n        if (!isBracketing(function, lower, upper)) {\n            error(\"NoBracketing\")\n            //lower, upper,\n            //function.value(lower),\n            //function.value(upper)\n        }\n    }\n}\n/**\n * Class contains only static methods.\n */\n/**\n * This method attempts to find two values a and b satisfying\n *  *  ` lowerBound <= a < initial < b <= upperBound`\n *  *  ` f(a) * f(b) < 0 `\n *\n * If f is continuous on `[a,b],` this means that `a`\n * and `b` bracket a root of f.\n *\n *\n * The algorithm starts by setting\n * `a := initial -1; b := initial +1,` examines the value of the\n * function at `a` and `b` and keeps moving\n * the endpoints out by one unit each time through a loop that terminates\n * when one of the following happens:\n *  *  ` f(a) * f(b) < 0 ` --  success!\n *  *  ` a = lower ` and ` b = upper`\n * -- NoBracketingException\n *  *  ` Integer.MAX_VALUE` iterations elapse\n * -- NoBracketingException\n *\n *\n *\n * **Note: ** this method can take\n * `Integer.MAX_VALUE` iterations to throw a\n * `ConvergenceException.`  Unless you are confident that there\n * is a root between `lowerBound` and `upperBound`\n * near `initial,` it is better to use\n * [.bracket],\n * explicitly specifying the maximum number of iterations.\n *\n * @param function Function.\n * @param initial Initial midpoint of interval being expanded to\n * bracket a root.\n * @param lowerBound Lower bound (a is never lower than this value)\n * @param upperBound Upper bound (b never is greater than this\n * value).\n * @return a two-element array holding a and b.\n * @throws NoBracketingException if a root cannot be bracketted.\n * @throws IllegalArgumentException if function is null, maximumIterations\n * is not positive, or initial is not between lowerBound and upperBound.\n */\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\ndata class EvalResult(\n    val y: Double,    // predicted value\n    val ymin: Double, // lower pointwise confidence interval around the mean\n    val ymax: Double, // upper pointwise confidence interval around the mean\n    val se: Double    // standard error\n)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport kotlin.math.max\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass LinearRegression(xs: List<Double?>, ys: List<Double?>, confidenceLevel: Double) :\n    RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val beta1: Double\n    private val beta0: Double\n    private val sy: Double // Standard error of estimate\n    private val tcritical: Double\n\n    init {\n        val (xVals, yVals) = allFinite(xs, ys)\n        n = xVals.size\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n\n        val meanY = yVals.average()\n        val sumYY = yVals.sumOf { (it - meanY).pow(2) }\n        val sumXY = xVals.zip(yVals).sumOf { (x, y) -> (x - meanX) * (y - meanY) }\n\n        beta1 = sumXY / sumXX\n        beta0 = meanY - beta1 * meanX\n\n        sy = run { // Standard error of estimate\n            val sse = max(0.0, sumYY - sumXY * sumXY / sumXX) // https://en.wikipedia.org/wiki/Residual_sum_of_squares\n            sqrt(sse / (n - 2)) // SE estimate\n        }\n\n        tcritical = run {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(n - 2.0).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        }\n    }\n\n    private fun value(x: Double): Double = beta1 * x + beta0\n\n    override fun evalX(x: Double): EvalResult {\n\n        // confidence interval for the conditional mean\n        // https://www.ma.utexas.edu/users/mks/statmistakes/CIvsPI.html\n        // https://onlinecourses.science.psu.edu/stat414/node/297\n\n        // https://www2.stat.duke.edu/~tjl13/s101/slides/unit6lec3H.pdf\n        // Stat symbols:\n        // https://brownmath.com/swt/symbol.htm\n\n\n        // standard error (of estimate?)\n        val se = run {// standard error of predicted means\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n        val yHat = value(x)\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.LoessInterpolator\nimport jetbrains.datalore.plot.base.stat.math3.PolynomialSplineFunction\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport kotlin.math.max\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass LocalPolynomialRegression(\n    xs: List<Double?>,\n    ys: List<Double?>,\n    confidenceLevel: Double,\n    private val bandwidth: Double\n) : RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    val canCompute: Boolean\n\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val sy: Double\n    private val tcritical: Double\n    private lateinit var polynomial: PolynomialSplineFunction\n\n    init {\n        val (xVals, yVals) = averageByX(xs, ys)\n\n        n = xVals.size\n        val degreesOfFreedom = n - 2.0\n\n        // See: LoessInterpolator.kt:168\n        val bandwidthInPoints = (bandwidth * n).toInt()\n        val bandwidthInPointsOk = bandwidthInPoints >= 2\n\n        canCompute = (n >= 3 && degreesOfFreedom > 0 && bandwidthInPointsOk)\n\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n\n        val meanY = yVals.average()\n        val sumYY = yVals.sumOf { (it - meanY).pow(2) }\n        val sumXY = xVals.zip(yVals).sumOf { (x, y) -> (x - meanX) * (y - meanY) }\n\n        sy = run {\n            val sse = max(0.0, sumYY - sumXY * sumXY / sumXX)\n            sqrt(sse / (n - 2))\n        }\n\n\n        if (canCompute) {\n            polynomial = getPoly(xVals, yVals)\n        }\n\n        tcritical = if (canCompute) {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(degreesOfFreedom).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        } else {\n            Double.NaN\n        }\n    }\n\n    override fun evalX(x: Double): EvalResult {\n\n        val se = run {\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n\n        val yHat = polynomial.value(x)!!\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n\n    private fun getPoly(xVals: DoubleArray, yVals: DoubleArray): PolynomialSplineFunction {\n        return LoessInterpolator(bandwidth, 4).interpolate(xVals, yVals)\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.ForsythePolynomialGenerator\nimport jetbrains.datalore.plot.base.stat.math3.PolynomialFunction\nimport jetbrains.datalore.plot.base.stat.math3.TDistribution\nimport jetbrains.datalore.plot.base.stat.math3.times\nimport kotlin.math.pow\nimport kotlin.math.sqrt\n\nclass PolynomialRegression(xs: List<Double?>, ys: List<Double?>, confidenceLevel: Double, deg: Int) :\n    RegressionEvaluator(xs, ys, confidenceLevel) {\n\n    private val p: PolynomialFunction\n    private val n: Int\n    private val meanX: Double\n    private val sumXX: Double\n    private val sy: Double\n    private val tcritical: Double\n\n    init {\n        require(deg >= 2) { \"Degree of polynomial must be at least 2\" }\n\n        val (xVals, yVals) = averageByX(xs, ys)\n        n = xVals.size\n\n        require(n > deg) { \"The number of valid data points must be greater than deg\" }\n\n        p = calcPolynomial(deg, xVals, yVals)\n\n        meanX = xVals.average()\n        sumXX = xVals.sumOf { (it - meanX).pow(2) }\n        val df = n - deg - 1.0\n\n        sy = run { // Standard error of estimate\n            val sse = xVals.zip(yVals).sumOf { (x, y) -> (y - p.value(x)).pow(2) }\n            sqrt(sse / (df))\n        }\n\n        tcritical = run {\n            val alpha = 1.0 - confidenceLevel\n            TDistribution(df).inverseCumulativeProbability(1.0 - alpha / 2.0)\n        }\n    }\n\n    private fun calcPolynomial(deg: Int, xVals: DoubleArray, yVals: DoubleArray): PolynomialFunction {\n        val fpg = ForsythePolynomialGenerator(xVals)\n        var res = PolynomialFunction(doubleArrayOf(0.0))\n\n        for (i in 0..deg) {\n            val p = fpg.getPolynomial(i)\n            val s = coefficient(p, xVals, yVals)\n            res += s * p\n        }\n\n        return res\n    }\n\n    private fun coefficient(p: PolynomialFunction, xVals: DoubleArray, yVals: DoubleArray): Double {\n        var ww = 0.0\n        var w = 0.0\n        for (i in 0 until xVals.size) {\n            val x = xVals[i]\n            val y = yVals[i]\n            val pval = p.value(x)\n\n            ww += pval * pval\n            w += y * pval\n        }\n\n        return w / ww\n    }\n\n    override fun evalX(x: Double): EvalResult {\n\n        val se = run { // standard error of predicted means\n            // x deviation squared\n            val dxSquare = (x - meanX).pow(2)\n            sy * sqrt(1.0 / n + dxSquare / sumXX)\n        }\n\n        // half-width of confidence interval for estimated mean y\n        val halfConfidenceInterval = tcritical * se\n\n        val yHat = p.value(x)\n\n        return EvalResult(\n            yHat,\n            yHat - halfConfidenceInterval,\n            yHat + halfConfidenceInterval,\n            se\n        )\n    }\n\n    companion object {\n        fun canBeComputed(xs: List<Double?>, ys: List<Double?>, deg: Int): Boolean {\n            // ToDo: duplicates the constructor code\n            val (xVals, _) = averageByX(xs, ys)\n            return xVals.size > deg\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nabstract class RegressionEvaluator protected constructor(\n    xs: List<Double?>,\n    ys: List<Double?>,\n    confidenceLevel: Double\n) {\n    init {\n        require(confidenceLevel in 0.01..0.99) { \"Confidence level is out of range [0.01-0.99]. CL:$confidenceLevel\" }\n        require(xs.size == ys.size) { \"X/Y must have same size. X:\" + xs.size + \" Y:\" + ys.size }\n    }\n\n    abstract fun evalX(x: Double): EvalResult\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.stat.regression\n\nimport jetbrains.datalore.plot.base.stat.math3.Percentile\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.random.Random\n\ninternal object RegressionUtil {\n\n    // sample m data randomly\n    fun <T> sampling(data: List<T>, m: Int): ArrayList<T> {\n        val index = sampleInt(data.size, m)\n        val result = ArrayList<T>()\n        for (i in index) {\n            result.add(data[i])\n        }\n        return result\n    }\n\n    // sample m int from 0..n-1\n    private fun sampleInt(n: Int, m: Int): IntArray {\n        if (n < m || m < 0) {\n            error(\"Sample $m data from $n data is impossible!\")\n        }\n        val perm = IntArray(n)\n        for (i in 0 until n) {\n            perm[i] = i\n        }\n\n        val result = IntArray(m)\n        for (j in 0 until m) {\n            val r = j + (Random.nextDouble() * (n - j)).toInt()\n            result[j] = perm[r]\n            perm[r] = perm[j]\n        }\n        return result\n    }\n\n    fun percentile(data: List<Double>, p: Double): Double {\n        return Percentile.evaluate(data.toDoubleArray(), p * 100)\n    }\n}\n\nfun allFinite(xs: List<Double?>, ys: List<Double?>): Pair<DoubleArray, DoubleArray> {\n    val tx = ArrayList<Double>()\n    val ty = ArrayList<Double>()\n\n    for ((x, y) in xs.asSequence().zip(ys.asSequence())) {\n        if (SeriesUtil.allFinite(x, y)) {\n            tx.add(x!!)\n            ty.add(y!!)\n        }\n    }\n\n    return Pair(tx.toDoubleArray(), ty.toDoubleArray())\n}\n\nprivate fun finitePairs(xs: List<Double?>, ys: List<Double?>): ArrayList<Pair<Double, Double>> {\n    val res = ArrayList<Pair<Double, Double>>()\n\n    for ((x, y) in xs.asSequence().zip(ys.asSequence())) {\n        if (SeriesUtil.allFinite(x, y)) {\n            res.add(Pair(x!!, y!!))\n        }\n    }\n\n    return res\n}\n\nprivate fun averageByX(lst: List<Pair<Double, Double>>): Pair<List<Double>, List<Double>> {\n\n    if (lst.isEmpty())\n        return Pair(ArrayList<Double>(), ArrayList<Double>())\n\n    val tx = ArrayList<Double>()\n    val ty = ArrayList<Double>()\n    var (prevX, sumY) = lst.first()\n    var countY = 1\n\n    for ((x, y) in lst.asSequence().drop(1)) {\n        if (x == prevX) {\n            sumY += y\n            ++countY\n        } else {\n            tx.add(prevX)\n            ty.add(sumY.div(countY))\n            prevX = x\n            sumY = y\n            countY = 1\n        }\n    }\n\n    tx.add(prevX)\n    ty.add(sumY.div(countY))\n\n    return Pair(tx, ty)\n}\n\nfun averageByX(xs: List<Double?>, ys: List<Double?>): Pair<DoubleArray, DoubleArray> {\n    val tp = finitePairs(xs, ys)\n    tp.sortBy { it.first }\n    val res = averageByX(tp)\n    return Pair(res.first.toDoubleArray(), res.second.toDoubleArray())\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nclass MutableDouble(private var myValue: Double) {\n\n    fun getAndAdd(v: Double): Double {\n        val prevValue = myValue\n        myValue = prevValue + v\n        return prevValue\n    }\n\n    fun get(): Double {\n        return myValue\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nclass MutableInteger(private var myValue: Int) {\n\n    val andIncrement: Int\n        get() = getAndAdd(1)\n\n    fun get(): Int {\n        return myValue\n    }\n\n    fun getAndAdd(v: Int): Int {\n        val prevValue = myValue\n        myValue = prevValue + v\n        return prevValue\n    }\n\n    fun increment() {\n        getAndAdd(1)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.base.util\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport kotlin.random.Random\n\nobject SamplingUtil {\n\n    fun <T> sampleWithoutReplacement(\n        popSize: Int, sampleSize: Int, rand: Random, onPick: (Set<Int>) -> T, onDrop: (Set<Int>) -> T\n    ): T {\n        val pick = sampleSize <= popSize / 2\n        val indexCount = if (pick) sampleSize else popSize - sampleSize\n\n        val indexSet = HashSet<Int>()\n\n        while (indexSet.size < indexCount) {\n            indexSet.add(rand.nextInt(popSize))\n        }\n\n        return if (pick) onPick(indexSet) else onDrop(indexSet)\n    }\n\n    fun sampleWithoutReplacement(sampleSize: Int, rand: Random, data: DataFrame): DataFrame {\n        return sampleWithoutReplacement(\n            data.rowCount(),\n            sampleSize,\n            rand,\n            { data.selectIndices(it) },\n            { data.dropIndices(it) }\n        )\n    }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-base-portable.js\n"); /***/ }), @@ -165,7 +165,7 @@ eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPAC \***********************************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-vis-svg-portable */ \"./kotlin-dce-dev/lets-plot-vis-svg-portable.js\"), __webpack_require__(/*! lets-plot-plot-common-portable */ \"./kotlin-dce-dev/lets-plot-plot-common-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_plot_base_portable, $module$lets_plot_base_portable, $module$lets_plot_vis_svg_portable, $module$lets_plot_plot_common_portable) {\n 'use strict';\n var data = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.data;\n var println = Kotlin.kotlin.io.println_s8jyv4$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var scale = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var CoordinateSystem = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.CoordinateSystem;\n var Scale = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.Scale;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var base = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.base;\n var TextLabel = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel;\n var TextLabel$HorizontalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor;\n var TextLabel$VerticalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor;\n var RuntimeException = Kotlin.kotlin.RuntimeException;\n var ensureNotNull = Kotlin.ensureNotNull;\n var EventHandler = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventHandler;\n var Registration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.Registration;\n var DoubleVector = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleVector;\n var SvgGElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGElement;\n var SvgEventSpec = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.event.SvgEventSpec;\n var SvgEventHandler = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.event.SvgEventHandler;\n var DoubleRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle;\n var SvgRectElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_wthzt5$;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var DoubleRectangle_init = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$;\n var getCallableRef = Kotlin.getCallableRef;\n var logging = $module$lets_plot_base_portable.jetbrains.datalore.base.logging;\n var getKClass = Kotlin.getKClass;\n var SvgComponent = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.SvgComponent;\n var ValueProperty = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property.ValueProperty;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var throwUPAE = Kotlin.throwUPAE;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var SvgCssResource = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgCssResource;\n var SvgRectElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement;\n var CompositeRegistration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.CompositeRegistration;\n var SvgSvgElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgSvgElement;\n var Unit = Kotlin.kotlin.Unit;\n var JsMath = Math;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var Aes = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.Aes;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var LiveMapGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LiveMapGeom;\n var throwCCE = Kotlin.throwCCE;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var lazy = Kotlin.kotlin.lazy_klfg04$;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var data_0 = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.data;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var emptyMap = Kotlin.kotlin.collections.emptyMap_q3lmfv$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_73mtqc$;\n var AestheticsBuilder = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes.AestheticsBuilder;\n var toString = Kotlin.toString;\n var ContinuousTransform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.ContinuousTransform;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var Map = Kotlin.kotlin.collections.Map;\n var SvgRoot = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.SvgRoot;\n var equals = Kotlin.equals;\n var hashCode = Kotlin.hashCode;\n var breaks = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.breaks;\n var NullGeomTargetCollector = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.NullGeomTargetCollector;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var toMap = Kotlin.kotlin.collections.toMap_6hr0sd$;\n var TypedKeyHashMap = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKeyHashMap;\n var stat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat;\n var SimpleStatContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.SimpleStatContext;\n var GeomTargetLocator$LookupSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpec;\n var GeomContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomContext;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var getValue = Kotlin.kotlin.collections.getValue_t9ocha$;\n var zip = Kotlin.kotlin.collections.zip_45mdf7$;\n var numberToInt = Kotlin.numberToInt;\n var flatten = Kotlin.kotlin.collections.flatten_u0ad8z$;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var Collection = Kotlin.kotlin.collections.Collection;\n var toList = Kotlin.kotlin.toList_tt9upe$;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var DataFrame$DataFrame$Builder_init = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder_init;\n var distinct = Kotlin.kotlin.collections.distinct_7wnvza$;\n var listOf = Kotlin.kotlin.collections.listOf_mh5how$;\n var plus = Kotlin.kotlin.collections.plus_mydzjv$;\n var List = Kotlin.kotlin.collections.List;\n var sortedDescending = Kotlin.kotlin.collections.sortedDescending_exjks8$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var pos = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos;\n var PositionAdjustments$StackingStrategy = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos.PositionAdjustments.StackingStrategy;\n var PositionAdjustments$Meta = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos.PositionAdjustments.Meta;\n var toMap_0 = Kotlin.kotlin.collections.toMap_abgq59$;\n var listOfNotNull = Kotlin.kotlin.collections.listOfNotNull_jurz7g$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var Pair_0 = Kotlin.kotlin.Pair;\n var checkIndexOverflow = Kotlin.kotlin.collections.checkIndexOverflow_za3lpa$;\n var wrapFunction = Kotlin.wrapFunction;\n var Comparator = Kotlin.kotlin.Comparator;\n var L37 = Kotlin.Long.fromInt(37);\n var base_0 = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base;\n var PointGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointGeom;\n var GeomKind = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomKind;\n var AestheticsDefaults = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes.AestheticsDefaults;\n var PathGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PathGeom;\n var LineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LineGeom;\n var SmoothGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.SmoothGeom;\n var BarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.BarGeom;\n var HistogramGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.HistogramGeom;\n var TileGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.TileGeom;\n var Bin2dGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Bin2dGeom;\n var ErrorBarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ErrorBarGeom;\n var CrossBarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.CrossBarGeom;\n var LineRangeGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LineRangeGeom;\n var PointRangeGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointRangeGeom;\n var ContourGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ContourGeom;\n var ContourfGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ContourfGeom;\n var PolygonGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PolygonGeom;\n var MapGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.MapGeom;\n var ABLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ABLineGeom;\n var HLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.HLineGeom;\n var VLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.VLineGeom;\n var BoxplotGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.BoxplotGeom;\n var RibbonGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RibbonGeom;\n var AreaGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.AreaGeom;\n var DensityGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.DensityGeom;\n var Density2dGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Density2dGeom;\n var Density2dfGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Density2dfGeom;\n var JitterGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.JitterGeom;\n var FreqpolyGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.FreqpolyGeom;\n var StepGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.StepGeom;\n var RectGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RectGeom;\n var SegmentGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.SegmentGeom;\n var TextGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.TextGeom;\n var RasterGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RasterGeom;\n var ImageGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ImageGeom;\n var MappedDataAccess = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.MappedDataAccess;\n var MappedDataAccess$MappedData = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.MappedDataAccess.MappedData;\n var coord = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.coord;\n var spatial = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial;\n var Projection = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.coord.Projection;\n var DataFrame$Builder = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder;\n var first_0 = Kotlin.kotlin.collections.first_7wnvza$;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var listOfNotNull_0 = Kotlin.kotlin.collections.listOfNotNull_issdgt$;\n var plus_0 = Kotlin.kotlin.collections.plus_q4559j$;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var LinkedHashSet_init = Kotlin.kotlin.collections.LinkedHashSet_init_287e2$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n var requireNoNulls = Kotlin.kotlin.collections.requireNoNulls_whsx6z$;\n var firstOrNull = Kotlin.kotlin.collections.firstOrNull_2p1efm$;\n var Comparable = Kotlin.kotlin.Comparable;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var DataFrame$OrderSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.OrderSpec;\n var Listeners = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.Listeners;\n var ListenerCaller = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.ListenerCaller;\n var MouseEventSource = $module$lets_plot_base_portable.jetbrains.datalore.base.event.MouseEventSource;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var SvgLineElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement_init_6y0v78$;\n var property = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property;\n var svg = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg;\n var SvgLineElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement;\n var EventSource = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventSource;\n var event = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var SvgRectElement_init_0 = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_6y0v78$;\n var NoSuchElementException_init = Kotlin.kotlin.NoSuchElementException_init;\n var isBlank = Kotlin.kotlin.text.isBlank_gw00vp$;\n var GroupComponent = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.GroupComponent;\n var SvgColors = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgColors;\n var ContextualMapping = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.ContextualMapping;\n var DataContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.DataContext;\n var GeomTargetLocator$LookupStrategy = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy;\n var GeomTargetLocator$LookupSpace = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace;\n var minus = Kotlin.kotlin.collections.minus_q4559j$;\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var lastOrNull = Kotlin.kotlin.collections.lastOrNull_2p1efm$;\n var contains = Kotlin.kotlin.collections.contains_2ws7j4$;\n var TipLayoutHint = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TipLayoutHint;\n var addAll = Kotlin.kotlin.collections.addAll_ipc267$;\n var HitShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.HitShape;\n var GeomTargetCollector = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetCollector;\n var GeomTargetLocator = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator;\n var GeomTargetLocator$LookupResult = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult;\n var TipLayoutHint$Kind = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var minOrNull = Kotlin.kotlin.collections.minOrNull_l63kqw$;\n var NoSuchElementException_init_0 = Kotlin.kotlin.NoSuchElementException;\n var IllegalStateException_init_0 = Kotlin.kotlin.IllegalStateException_init;\n var splitRings = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.splitRings_bemo1h$;\n var geometry = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry;\n var calculateArea = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.calculateArea_ytws2g$;\n var PolylineSimplifier = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.geometry.PolylineSimplifier;\n var GeomTarget = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTarget;\n var toRadians = $module$lets_plot_base_portable.jetbrains.datalore.base.math.toRadians_14dthe$;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var StringBuilder = Kotlin.kotlin.text.StringBuilder;\n var trimMargin = Kotlin.kotlin.text.trimMargin_rjktp$;\n var shuffle = Kotlin.kotlin.collections.shuffle_9jeydg$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var Random = Kotlin.kotlin.random.Random_s8cxhz$;\n var Random_0 = Kotlin.kotlin.random.Random;\n var util = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var sum = Kotlin.kotlin.collections.sum_l63kqw$;\n var MutableDouble = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util.MutableDouble;\n var MutableInteger = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util.MutableInteger;\n var get_indices = Kotlin.kotlin.collections.get_indices_gzk92b$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var map = Kotlin.kotlin.sequences.map_z5avom$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var sortedWith_0 = Kotlin.kotlin.sequences.sortedWith_vjgqpk$;\n var roundToInt = Kotlin.kotlin.math.roundToInt_yrwdxr$;\n var toList_0 = Kotlin.kotlin.sequences.toList_veqyi0$;\n var isClosed = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.isClosed_2p1efm$;\n var AbstractList = Kotlin.kotlin.collections.AbstractList;\n var joinToString = Kotlin.kotlin.collections.joinToString_fmv235$;\n var point = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point;\n var NamedLineType = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.linetype.NamedLineType;\n var aes = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes;\n var Function = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Function;\n var AssertionError_init = Kotlin.kotlin.AssertionError_init_pdl1vj$;\n var filterNotNull = Kotlin.kotlin.collections.filterNotNull_m3lr2h$;\n var reversed_0 = Kotlin.kotlin.collections.reversed_7wnvza$;\n var numberToDouble = Kotlin.numberToDouble;\n var StringFormat = $module$lets_plot_base_portable.jetbrains.datalore.base.stringFormat.StringFormat;\n var transform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.transform;\n var values = $module$lets_plot_base_portable.jetbrains.datalore.base.values;\n var HSV = $module$lets_plot_base_portable.jetbrains.datalore.base.values.HSV;\n var NamedShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape;\n var NamedShape$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape.values;\n var LinkedHashSet_init_0 = Kotlin.kotlin.collections.LinkedHashSet_init_mqih57$;\n var color = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color;\n var ColorPalette$Type = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Type;\n var ColorPalette$Qualitative = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative;\n var ColorPalette$Sequential$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Sequential.valueOf_61zpoe$;\n var ColorPalette$Diverging$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Diverging.valueOf_61zpoe$;\n var ColorPalette$Qualitative$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.valueOf_61zpoe$;\n var IllegalArgumentException = Kotlin.kotlin.IllegalArgumentException;\n var ColorPalette$Sequential$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Sequential.values;\n var ColorPalette$Diverging$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Diverging.values;\n var ColorPalette$Qualitative$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.values;\n var joinToString_0 = Kotlin.kotlin.collections.joinToString_cgipc5$;\n var rangeTo = Kotlin.kotlin.ranges.rangeTo_38ydlf$;\n var TooltipLineSpec$DataPoint = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint;\n var StringFormat$FormatType = $module$lets_plot_base_portable.jetbrains.datalore.base.stringFormat.StringFormat.FormatType;\n var single = Kotlin.kotlin.collections.single_2p1efm$;\n var TooltipLineSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipLineSpec;\n Plot$buildPlot$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n Plot$buildPlot$ObjectLiteral_0.prototype.constructor = Plot$buildPlot$ObjectLiteral_0;\n Plot.prototype = Object.create(SvgComponent.prototype);\n Plot.prototype.constructor = Plot;\n PlotBuilder$MyPlot.prototype = Object.create(Plot.prototype);\n PlotBuilder$MyPlot.prototype.constructor = PlotBuilder$MyPlot;\n PlotTile.prototype = Object.create(SvgComponent.prototype);\n PlotTile.prototype.constructor = PlotTile;\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype = Object.create(TransformedTargetLocator.prototype);\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.constructor = PlotTooltipHelper$TileInfo$TileTargetLocator;\n SvgLayerRenderer.prototype = Object.create(SvgComponent.prototype);\n SvgLayerRenderer.prototype.constructor = SvgLayerRenderer;\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype.constructor = ColorBarAssembler$createColorBar$ObjectLiteral;\n ColorBarOptions.prototype = Object.create(GuideOptions.prototype);\n ColorBarOptions.prototype.constructor = ColorBarOptions;\n GuideOptions$Companion$NONE$ObjectLiteral.prototype = Object.create(GuideOptions.prototype);\n GuideOptions$Companion$NONE$ObjectLiteral.prototype.constructor = GuideOptions$Companion$NONE$ObjectLiteral;\n LegendAssembler$createLegend$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n LegendAssembler$createLegend$ObjectLiteral.prototype.constructor = LegendAssembler$createLegend$ObjectLiteral;\n LegendOptions.prototype = Object.create(GuideOptions.prototype);\n LegendOptions.prototype.constructor = LegendOptions;\n PosProvider$Companion$wrap$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$wrap$ObjectLiteral.prototype.constructor = PosProvider$Companion$wrap$ObjectLiteral;\n PosProvider$Companion$barStack$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$barStack$ObjectLiteral.prototype.constructor = PosProvider$Companion$barStack$ObjectLiteral;\n PosProvider$Companion$dodge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$dodge$ObjectLiteral.prototype.constructor = PosProvider$Companion$dodge$ObjectLiteral;\n PosProvider$Companion$fill$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$fill$ObjectLiteral.prototype.constructor = PosProvider$Companion$fill$ObjectLiteral;\n PosProvider$Companion$jitter$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$jitter$ObjectLiteral.prototype.constructor = PosProvider$Companion$jitter$ObjectLiteral;\n PosProvider$Companion$nudge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$nudge$ObjectLiteral.prototype.constructor = PosProvider$Companion$nudge$ObjectLiteral;\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.constructor = PosProvider$Companion$jitterDodge$ObjectLiteral;\n FacetGrid.prototype = Object.create(PlotFacets.prototype);\n FacetGrid.prototype.constructor = FacetGrid;\n FacetWrap$Direction.prototype = Object.create(Enum.prototype);\n FacetWrap$Direction.prototype.constructor = FacetWrap$Direction;\n FacetWrap.prototype = Object.create(PlotFacets.prototype);\n FacetWrap.prototype.constructor = FacetWrap;\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype = Object.create(GeomProvider.prototype);\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.constructor = GeomProvider$GeomProviderBuilder$build$ObjectLiteral;\n CartesianCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n CartesianCoordProvider.prototype.constructor = CartesianCoordProvider;\n FixedRatioCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n FixedRatioCoordProvider.prototype.constructor = FixedRatioCoordProvider;\n ProjectionCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n ProjectionCoordProvider.prototype.constructor = ProjectionCoordProvider;\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype = Object.create(Registration.prototype);\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype.constructor = MouseEventPeer$addEventHandler$ObjectLiteral;\n AxisComponent.prototype = Object.create(SvgComponent.prototype);\n AxisComponent.prototype.constructor = AxisComponent;\n LegendBox.prototype = Object.create(SvgComponent.prototype);\n LegendBox.prototype.constructor = LegendBox;\n ColorBarComponent.prototype = Object.create(LegendBox.prototype);\n ColorBarComponent.prototype.constructor = ColorBarComponent;\n ColorBarComponentLayout.prototype = Object.create(LegendBoxLayout.prototype);\n ColorBarComponentLayout.prototype.constructor = ColorBarComponentLayout;\n ColorBarComponentLayout$HorizontalLayout.prototype = Object.create(ColorBarComponentLayout.prototype);\n ColorBarComponentLayout$HorizontalLayout.prototype.constructor = ColorBarComponentLayout$HorizontalLayout;\n ColorBarComponentLayout$VerticalLayout.prototype = Object.create(ColorBarComponentLayout.prototype);\n ColorBarComponentLayout$VerticalLayout.prototype.constructor = ColorBarComponentLayout$VerticalLayout;\n ColorBarComponentSpec.prototype = Object.create(LegendBoxSpec.prototype);\n ColorBarComponentSpec.prototype.constructor = ColorBarComponentSpec;\n LegendArrangement.prototype = Object.create(Enum.prototype);\n LegendArrangement.prototype.constructor = LegendArrangement;\n LegendComponent.prototype = Object.create(LegendBox.prototype);\n LegendComponent.prototype.constructor = LegendComponent;\n LegendComponentLayout.prototype = Object.create(LegendBoxLayout.prototype);\n LegendComponentLayout.prototype.constructor = LegendComponentLayout;\n LegendComponentLayout$MyHorizontal.prototype = Object.create(LegendComponentLayout.prototype);\n LegendComponentLayout$MyHorizontal.prototype.constructor = LegendComponentLayout$MyHorizontal;\n LegendComponentLayout$MyMultiRow.prototype = Object.create(LegendComponentLayout.prototype);\n LegendComponentLayout$MyMultiRow.prototype.constructor = LegendComponentLayout$MyMultiRow;\n LegendComponentLayout$MyHorizontalMultiRow.prototype = Object.create(LegendComponentLayout$MyMultiRow.prototype);\n LegendComponentLayout$MyHorizontalMultiRow.prototype.constructor = LegendComponentLayout$MyHorizontalMultiRow;\n LegendComponentLayout$MyVertical.prototype = Object.create(LegendComponentLayout$MyMultiRow.prototype);\n LegendComponentLayout$MyVertical.prototype.constructor = LegendComponentLayout$MyVertical;\n LegendComponentSpec.prototype = Object.create(LegendBoxSpec.prototype);\n LegendComponentSpec.prototype.constructor = LegendComponentSpec;\n LegendDirection.prototype = Object.create(Enum.prototype);\n LegendDirection.prototype.constructor = LegendDirection;\n Orientation.prototype = Object.create(Enum.prototype);\n Orientation.prototype.constructor = Orientation;\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.prototype = Object.create(Enum.prototype);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.prototype.constructor = MathUtil$ClosestPointChecker$COMPARISON_RESULT;\n LayerTargetLocator$Collector$CollectingStrategy.prototype = Object.create(Enum.prototype);\n LayerTargetLocator$Collector$CollectingStrategy.prototype.constructor = LayerTargetLocator$Collector$CollectingStrategy;\n PointTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PointTargetProjection.prototype.constructor = PointTargetProjection;\n RectTargetProjection.prototype = Object.create(TargetProjection.prototype);\n RectTargetProjection.prototype.constructor = RectTargetProjection;\n PolygonTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PolygonTargetProjection.prototype.constructor = PolygonTargetProjection;\n PathTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PathTargetProjection.prototype.constructor = PathTargetProjection;\n FacetGridPlotLayout.prototype = Object.create(PlotLayoutBase.prototype);\n FacetGridPlotLayout.prototype.constructor = FacetGridPlotLayout;\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype.constructor = LegendBoxInfo$Companion$EMPTY$ObjectLiteral;\n SingleTilePlotLayout.prototype = Object.create(PlotLayoutBase.prototype);\n SingleTilePlotLayout.prototype.constructor = SingleTilePlotLayout;\n HorizontalAxisLayouter.prototype = Object.create(AxisLayouter.prototype);\n HorizontalAxisLayouter.prototype.constructor = HorizontalAxisLayouter;\n VerticalAxisLayouter.prototype = Object.create(AxisLayouter.prototype);\n VerticalAxisLayouter.prototype.constructor = VerticalAxisLayouter;\n AbstractFixedBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n AbstractFixedBreaksLabelsLayout.prototype.constructor = AbstractFixedBreaksLabelsLayout;\n HorizontalFixedBreaksLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalFixedBreaksLabelsLayout.prototype.constructor = HorizontalFixedBreaksLabelsLayout;\n HorizontalFlexBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n HorizontalFlexBreaksLabelsLayout.prototype.constructor = HorizontalFlexBreaksLabelsLayout;\n HorizontalMultilineLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalMultilineLabelsLayout.prototype.constructor = HorizontalMultilineLabelsLayout;\n HorizontalSimpleLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalSimpleLabelsLayout.prototype.constructor = HorizontalSimpleLabelsLayout;\n HorizontalTiltedLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalTiltedLabelsLayout.prototype.constructor = HorizontalTiltedLabelsLayout;\n HorizontalVerticalLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalVerticalLabelsLayout.prototype.constructor = HorizontalVerticalLabelsLayout;\n VerticalFixedBreaksLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n VerticalFixedBreaksLabelsLayout.prototype.constructor = VerticalFixedBreaksLabelsLayout;\n VerticalFlexBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n VerticalFlexBreaksLabelsLayout.prototype.constructor = VerticalFlexBreaksLabelsLayout;\n PlotLabelSpec.prototype = Object.create(Enum.prototype);\n PlotLabelSpec.prototype.constructor = PlotLabelSpec;\n GroupSamplingBase.prototype = Object.create(SamplingBase.prototype);\n GroupSamplingBase.prototype.constructor = GroupSamplingBase;\n GroupRandomSampling.prototype = Object.create(GroupSamplingBase.prototype);\n GroupRandomSampling.prototype.constructor = GroupRandomSampling;\n GroupSystematicSampling.prototype = Object.create(GroupSamplingBase.prototype);\n GroupSystematicSampling.prototype.constructor = GroupSystematicSampling;\n PickSampling.prototype = Object.create(SamplingBase.prototype);\n PickSampling.prototype.constructor = PickSampling;\n RandomSampling.prototype = Object.create(SamplingBase.prototype);\n RandomSampling.prototype.constructor = RandomSampling;\n RandomStratifiedSampling.prototype = Object.create(SamplingBase.prototype);\n RandomStratifiedSampling.prototype.constructor = RandomStratifiedSampling;\n SystematicSampling.prototype = Object.create(SamplingBase.prototype);\n SystematicSampling.prototype.constructor = SystematicSampling;\n VertexSampling.prototype = Object.create(SamplingBase.prototype);\n VertexSampling.prototype.constructor = VertexSampling;\n VertexSampling$VertexVwSampling.prototype = Object.create(VertexSampling.prototype);\n VertexSampling$VertexVwSampling.prototype.constructor = VertexSampling$VertexVwSampling;\n VertexSampling$VertexDpSampling.prototype = Object.create(VertexSampling.prototype);\n VertexSampling$VertexDpSampling.prototype.constructor = VertexSampling$VertexDpSampling;\n VertexSampling$DoubleVectorComponentsList.prototype = Object.create(AbstractList.prototype);\n VertexSampling$DoubleVectorComponentsList.prototype.constructor = VertexSampling$DoubleVectorComponentsList;\n ContinuousOnlyMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ContinuousOnlyMapperProvider.prototype.constructor = ContinuousOnlyMapperProvider;\n DiscreteOnlyMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n DiscreteOnlyMapperProvider.prototype.constructor = DiscreteOnlyMapperProvider;\n IdentityDiscreteMapperProvider.prototype = Object.create(DiscreteOnlyMapperProvider.prototype);\n IdentityDiscreteMapperProvider.prototype.constructor = IdentityDiscreteMapperProvider;\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype = Object.create(IdentityDiscreteMapperProvider.prototype);\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype.constructor = DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral;\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype = Object.create(IdentityDiscreteMapperProvider.prototype);\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype.constructor = DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral;\n LinearNormalizingMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n LinearNormalizingMapperProvider.prototype.constructor = LinearNormalizingMapperProvider;\n AlphaMapperProvider.prototype = Object.create(LinearNormalizingMapperProvider.prototype);\n AlphaMapperProvider.prototype.constructor = AlphaMapperProvider;\n ColorBrewerMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ColorBrewerMapperProvider.prototype.constructor = ColorBrewerMapperProvider;\n ColorGradient2MapperProvider.prototype = Object.create(ContinuousOnlyMapperProvider.prototype);\n ColorGradient2MapperProvider.prototype.constructor = ColorGradient2MapperProvider;\n ColorGradientMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ColorGradientMapperProvider.prototype.constructor = ColorGradientMapperProvider;\n HSVColorMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n HSVColorMapperProvider.prototype.constructor = HSVColorMapperProvider;\n ColorHueMapperProvider.prototype = Object.create(HSVColorMapperProvider.prototype);\n ColorHueMapperProvider.prototype.constructor = ColorHueMapperProvider;\n DirectlyProportionalMapperProvider.prototype = Object.create(ContinuousOnlyMapperProvider.prototype);\n DirectlyProportionalMapperProvider.prototype.constructor = DirectlyProportionalMapperProvider;\n GreyscaleLightnessMapperProvider.prototype = Object.create(HSVColorMapperProvider.prototype);\n GreyscaleLightnessMapperProvider.prototype.constructor = GreyscaleLightnessMapperProvider;\n SizeAreaMapperProvider.prototype = Object.create(DirectlyProportionalMapperProvider.prototype);\n SizeAreaMapperProvider.prototype.constructor = SizeAreaMapperProvider;\n SizeMapperProvider.prototype = Object.create(LinearNormalizingMapperProvider.prototype);\n SizeMapperProvider.prototype.constructor = SizeMapperProvider;\n DefaultTheme$multiTile$ObjectLiteral.prototype = Object.create(DefaultTheme.prototype);\n DefaultTheme$multiTile$ObjectLiteral.prototype.constructor = DefaultTheme$multiTile$ObjectLiteral;\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype = Object.create(DefaultAxisTheme.prototype);\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype.constructor = DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral;\n function FeatureSwitch() {\n FeatureSwitch_instance = this;\n this.PLOT_DEBUG_DRAWING = false;\n this.LEGEND_DEBUG_DRAWING = false;\n this.PRINT_DEBUG_LOGS_0 = false;\n this.PRINT_ENCODED_DATA_SUMMARY_0 = false;\n this.USE_DATA_FRAME_ENCODING = true;\n }\n FeatureSwitch.prototype.printEncodedDataSummary_d0u64m$ = function (header, dataSpec) {\n if (this.PRINT_ENCODED_DATA_SUMMARY_0) {\n this.printEncodedDataSummary_0(header, data.DataFrameUtil.fromMap_bkhwtg$(dataSpec));\n }};\n FeatureSwitch.prototype.isDebugLogEnabled = function () {\n return this.PRINT_DEBUG_LOGS_0;\n };\n FeatureSwitch.prototype.printEncodedDataSummary_0 = function (header, df) {\n if (this.PRINT_ENCODED_DATA_SUMMARY_0) {\n var summary = data.DataFrameUtil.getSummaryText_dhhkv7$(df);\n println(header);\n println(summary);\n }};\n FeatureSwitch.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'FeatureSwitch',\n interfaces: []\n };\n var FeatureSwitch_instance = null;\n function FeatureSwitch_getInstance() {\n if (FeatureSwitch_instance === null) {\n new FeatureSwitch();\n }return FeatureSwitch_instance;\n }\n function AxisUtil() {\n AxisUtil_instance = this;\n }\n AxisUtil.prototype.applyLayoutInfo_4pg061$ = function (axis, info) {\n axis.tickLabelOffsets.set_11rb$(info.tickLabelAdditionalOffsets);\n axis.tickLabelRotationDegree.set_11rb$(info.tickLabelRotationAngle);\n if (info.tickLabelHorizontalAnchor != null) {\n axis.tickLabelHorizontalAnchor.set_11rb$(info.tickLabelHorizontalAnchor);\n }if (info.tickLabelVerticalAnchor != null) {\n axis.tickLabelVerticalAnchor.set_11rb$(info.tickLabelVerticalAnchor);\n }axis.tickLabelSmallFont.set_11rb$(info.tickLabelSmallFont);\n };\n AxisUtil.prototype.applyTheme_tna4q5$ = function (axis, theme) {\n axis.tickLabelsEnabled().set_11rb$(theme.showTickLabels());\n axis.tickMarksEnabled().set_11rb$(theme.showTickMarks());\n axis.axisLineEnabled().set_11rb$(theme.showLine());\n axis.lineWidth.set_11rb$(theme.lineWidth());\n axis.tickMarkLength.set_11rb$(theme.tickMarkLength());\n axis.tickMarkPadding.set_11rb$(theme.tickMarkPadding());\n axis.tickMarkWidth.set_11rb$(theme.tickMarkWidth());\n };\n AxisUtil.prototype.setBreaks_6e5l22$ = function (axis, scale_0, coord, isHorizontal) {\n axis.breaks.set_11rb$(scale.ScaleUtil.axisBreaks_2m8kky$(scale_0, coord, isHorizontal));\n axis.labels.set_11rb$(scale.ScaleUtil.labels_x4zrm4$(scale_0));\n };\n AxisUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AxisUtil',\n interfaces: []\n };\n var AxisUtil_instance = null;\n function AxisUtil_getInstance() {\n if (AxisUtil_instance === null) {\n new AxisUtil();\n }return AxisUtil_instance;\n }\n function BogusCoordinateSystem() {\n }\n BogusCoordinateSystem.prototype.toClient_gpjtzr$ = function (p) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.fromClient_gpjtzr$ = function (p) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPointInLimits_k2qmv6$$default = function (p, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isRectInLimits_fd842m$$default = function (rect, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPathInLimits_f6t8kh$$default = function (path, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$$default = function (polygon, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n Object.defineProperty(BogusCoordinateSystem.prototype, 'xClientLimit', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusCoordinateSystem.prototype, 'yClientLimit', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n }\n });\n BogusCoordinateSystem.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BogusCoordinateSystem',\n interfaces: [CoordinateSystem]\n };\n function BogusScale() {\n }\n Object.defineProperty(BogusScale.prototype, 'name', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'breaks', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'labels', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'labelFormatter', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'domainLimits', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'multiplicativeExpand', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'additiveExpand', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'mapper', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'breaksGenerator', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n BogusScale.prototype.hasBreaksGenerator = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.hasBreaks = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.hasLabels = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.hasDomainLimits = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.with = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BogusScale',\n interfaces: [Scale]\n };\n function GeomLayer() {\n }\n GeomLayer.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomLayer',\n interfaces: []\n };\n function GeomLayerListUtil() {\n GeomLayerListUtil_instance = this;\n }\n GeomLayerListUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomLayerListUtil',\n interfaces: []\n };\n var GeomLayerListUtil_instance = null;\n function GeomLayerListUtil_getInstance() {\n if (GeomLayerListUtil_instance === null) {\n new GeomLayerListUtil();\n }return GeomLayerListUtil_instance;\n }\n function LayerRendererUtil() {\n LayerRendererUtil_instance = this;\n }\n LayerRendererUtil.prototype.createLayerRendererData_knseyn$ = function (layer, sharedNumericMappers, overallNumericDomains) {\n var aestheticMappers = PlotUtil_getInstance().prepareLayerAestheticMappers_viiuew$(layer, sharedNumericMappers);\n var aesthetics = PlotUtil_getInstance().createLayerAesthetics_kpf4gp$(layer, aestheticMappers, overallNumericDomains);\n var pos = PlotUtil_getInstance().createLayerPos_2iooof$(layer, aesthetics);\n return new LayerRendererUtil$LayerRendererData(layer, aesthetics, aestheticMappers, pos);\n };\n function LayerRendererUtil$LayerRendererData(layer, aesthetics, aestheticMappers, pos) {\n this.aesthetics = aesthetics;\n this.aestheticMappers = aestheticMappers;\n this.pos = pos;\n this.geom = layer.geom;\n this.geomKind = layer.geomKind;\n this.dataAccess = layer.dataAccess;\n this.contextualMapping = layer.contextualMapping;\n }\n LayerRendererUtil$LayerRendererData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerRendererData',\n interfaces: []\n };\n LayerRendererUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LayerRendererUtil',\n interfaces: []\n };\n var LayerRendererUtil_instance = null;\n function LayerRendererUtil_getInstance() {\n if (LayerRendererUtil_instance === null) {\n new LayerRendererUtil();\n }return LayerRendererUtil_instance;\n }\n function Plot(theme) {\n Plot$Companion_getInstance();\n SvgComponent.call(this);\n this.theme_5sfato$_0 = theme;\n this.myPreferredSize_8a54qv$_0 = new ValueProperty(Plot$Companion_getInstance().DEF_PLOT_SIZE_0);\n this.myLaidOutSize_jqfjq$_0 = new ValueProperty(DoubleVector.Companion.ZERO);\n this.myTooltipHelper_3jkkzs$_0 = new PlotTooltipHelper();\n this.myLiveMapFigures_nd8qng$_0 = ArrayList_init();\n this.mouseEventPeer = new MouseEventPeer();\n }\n Object.defineProperty(Plot.prototype, 'liveMapFigures_8be2vx$', {\n configurable: true,\n get: function () {\n return this.myLiveMapFigures_nd8qng$_0;\n }\n });\n Plot.prototype.preferredSize_8be2vx$ = function () {\n return this.myPreferredSize_8a54qv$_0;\n };\n Plot.prototype.laidOutSize = function () {\n return this.myLaidOutSize_jqfjq$_0;\n };\n function Plot$buildComponent$lambda() {\n return 'buildPlot';\n }\n Plot.prototype.buildComponent = function () {\n var tmp$;\n try {\n this.buildPlot_wr1hxq$_0();\n } catch (e) {\n if (Kotlin.isType(e, RuntimeException)) {\n Plot$Companion_getInstance().LOG_0.error_l35kib$(e, Plot$buildComponent$lambda);\n var rootCause = base.Throwables.getRootCause_tcv7n7$(e);\n var messages = ['Error building plot: ' + Kotlin.getKClassFromExpression(rootCause).simpleName, rootCause.message != null ? \"'\" + rootCause.message + \"'\" : ''];\n var y = this.myPreferredSize_8a54qv$_0.get().y / 2 - 8;\n for (tmp$ = 0; tmp$ !== messages.length; ++tmp$) {\n var s = messages[tmp$];\n var errorLabel = new TextLabel(s);\n errorLabel.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n errorLabel.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n errorLabel.moveTo_lu1900$(this.myPreferredSize_8a54qv$_0.get().x / 2, y);\n this.rootGroup.children().add_11rb$(errorLabel.rootGroup);\n y += 16.0;\n }\n } else\n throw e;\n }\n };\n function Plot$buildPlot$ObjectLiteral(this$Plot) {\n this.this$Plot = this$Plot;\n }\n Plot$buildPlot$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var newValue = event.newValue;\n if (ensureNotNull(newValue).x > 0 && newValue.y > 0) {\n this.this$Plot.rebuildPlot_v06af3$_0();\n }};\n Plot$buildPlot$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n function Plot$buildPlot$ObjectLiteral_0(this$Plot) {\n this.this$Plot = this$Plot;\n Registration.call(this);\n }\n Plot$buildPlot$ObjectLiteral_0.prototype.doRemove = function () {\n this.this$Plot.myTooltipHelper_3jkkzs$_0.removeAllTileInfos();\n this.this$Plot.myLiveMapFigures_nd8qng$_0.clear();\n };\n Plot$buildPlot$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Plot.prototype.buildPlot_wr1hxq$_0 = function () {\n this.rootGroup.addClass_61zpoe$(Style_getInstance().PLOT);\n this.buildPlotComponents_8cuv6w$_0();\n this.reg_3xv6fb$(this.myPreferredSize_8a54qv$_0.addHandler_gxwwpc$(new Plot$buildPlot$ObjectLiteral(this)));\n this.reg_3xv6fb$(new Plot$buildPlot$ObjectLiteral_0(this));\n };\n Plot.prototype.rebuildPlot_v06af3$_0 = function () {\n this.clear();\n this.buildPlot_wr1hxq$_0();\n };\n Plot.prototype.createTile_rg9gwo$_0 = function (tilesOrigin, tileInfo, tileLayers, theme) {\n var xScale;\n var yScale;\n var coord;\n if (tileInfo.xAxisInfo != null && tileInfo.yAxisInfo != null) {\n var xDomain = ensureNotNull(tileInfo.xAxisInfo.axisDomain);\n var xAxisLength = tileInfo.xAxisInfo.axisLength;\n var yDomain = ensureNotNull(tileInfo.yAxisInfo.axisDomain);\n var yAxisLength = tileInfo.yAxisInfo.axisLength;\n xScale = this.coordProvider.buildAxisScaleX_hcz7zd$(this.scaleXProto, xDomain, xAxisLength, ensureNotNull(tileInfo.xAxisInfo.axisBreaks));\n yScale = this.coordProvider.buildAxisScaleY_hcz7zd$(this.scaleYProto, yDomain, yAxisLength, ensureNotNull(tileInfo.yAxisInfo.axisBreaks));\n coord = this.coordProvider.createCoordinateSystem_uncllg$(xDomain, xAxisLength, yDomain, yAxisLength);\n } else {\n xScale = new BogusScale();\n yScale = new BogusScale();\n coord = new BogusCoordinateSystem();\n }\n var tile = new PlotTile(tileLayers, xScale, yScale, tilesOrigin, tileInfo, coord, theme);\n tile.setShowAxis_6taknv$(this.isAxisEnabled);\n tile.debugDrawing().set_11rb$(Plot$Companion_getInstance().DEBUG_DRAWING_0);\n return tile;\n };\n Plot.prototype.createAxisTitle_depkt8$_0 = function (text, orientation, plotBounds, geomBounds) {\n var tmp$;\n var horizontalAnchor = TextLabel$HorizontalAnchor.MIDDLE;\n switch (orientation.name) {\n case 'LEFT':\n case 'RIGHT':\n case 'TOP':\n tmp$ = TextLabel$VerticalAnchor.TOP;\n break;\n case 'BOTTOM':\n tmp$ = TextLabel$VerticalAnchor.BOTTOM;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n var verticalAnchor = tmp$;\n var titleLocation;\n var rotation = 0.0;\n switch (orientation.name) {\n case 'LEFT':\n titleLocation = new DoubleVector(plotBounds.left + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y);\n rotation = -90.0;\n break;\n case 'RIGHT':\n titleLocation = new DoubleVector(plotBounds.right - PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y);\n rotation = 90.0;\n break;\n case 'TOP':\n titleLocation = new DoubleVector(geomBounds.center.x, plotBounds.top + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN);\n break;\n case 'BOTTOM':\n titleLocation = new DoubleVector(geomBounds.center.x, plotBounds.bottom - PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN);\n break;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n var titleLabel = new TextLabel(text);\n titleLabel.setHorizontalAnchor_ja80zo$(horizontalAnchor);\n titleLabel.setVerticalAnchor_yaudma$(verticalAnchor);\n titleLabel.moveTo_gpjtzr$(titleLocation);\n titleLabel.rotate_14dthe$(rotation);\n var titleElement = titleLabel.rootGroup;\n titleElement.addClass_61zpoe$(Style_getInstance().AXIS_TITLE);\n var parent = new SvgGElement();\n parent.addClass_61zpoe$(Style_getInstance().AXIS);\n parent.children().add_11rb$(titleElement);\n this.add_26jijc$(parent);\n };\n function Plot$onMouseMove$ObjectLiteral(closure$message) {\n this.closure$message = closure$message;\n }\n Plot$onMouseMove$ObjectLiteral.prototype.handle_42da0z$ = function (node, e) {\n println(this.closure$message);\n };\n Plot$onMouseMove$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [SvgEventHandler]\n };\n Plot.prototype.onMouseMove_hnimoe$_0 = function (e, message) {\n e.addEventHandler_mm8kk2$(SvgEventSpec.MOUSE_MOVE, new Plot$onMouseMove$ObjectLiteral(message));\n };\n Plot.prototype.buildPlotComponents_8cuv6w$_0 = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5;\n var preferredSize = this.myPreferredSize_8a54qv$_0.get();\n var overallRect = new DoubleRectangle(DoubleVector.Companion.ZERO, preferredSize);\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect = SvgRectElement_init(overallRect);\n rect.strokeColor().set_11rb$(Color.Companion.MAGENTA);\n rect.strokeWidth().set_11rb$(1.0);\n rect.fillOpacity().set_11rb$(0.0);\n this.onMouseMove_hnimoe$_0(rect, 'MAGENTA: preferred size: ' + overallRect);\n this.add_26jijc$(rect);\n }if (this.hasLiveMap()) {\n tmp$ = PlotLayoutUtil_getInstance().liveMapBounds_wthzt5$(overallRect);\n } else {\n tmp$ = overallRect;\n }\n var entirePlot = tmp$;\n if (this.hasTitle()) {\n var titleSize = PlotLayoutUtil_getInstance().titleDimensions_61zpoe$(this.title);\n tmp$_0 = new DoubleRectangle(entirePlot.origin.add_gpjtzr$(new DoubleVector(0.0, titleSize.y)), entirePlot.dimension.subtract_gpjtzr$(new DoubleVector(0.0, titleSize.y)));\n } else {\n tmp$_0 = entirePlot;\n }\n var withoutTitle = tmp$_0;\n var boxesLayoutResult = null;\n var legendTheme = this.theme_5sfato$_0.legend();\n if (legendTheme.position().isFixed) {\n var legendBoxesLayout = new LegendBoxesLayout(withoutTitle, legendTheme);\n boxesLayoutResult = legendBoxesLayout.doLayout_8sg693$(this.legendBoxInfos);\n tmp$_1 = boxesLayoutResult.plotInnerBoundsWithoutLegendBoxes;\n } else {\n tmp$_1 = withoutTitle;\n }\n var withoutTitleAndLegends = tmp$_1;\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_0 = SvgRectElement_init(withoutTitleAndLegends);\n rect_0.strokeColor().set_11rb$(Color.Companion.BLUE);\n rect_0.strokeWidth().set_11rb$(1.0);\n rect_0.fillOpacity().set_11rb$(0.0);\n this.onMouseMove_hnimoe$_0(rect_0, 'BLUE: plot without title and legends: ' + withoutTitleAndLegends);\n this.add_26jijc$(rect_0);\n }var geomAndAxis = withoutTitleAndLegends;\n if (this.isAxisEnabled) {\n if (this.hasAxisTitleLeft()) {\n var titleSize_0 = PlotLayoutUtil_getInstance().axisTitleDimensions_61zpoe$(this.axisTitleLeft);\n var thickness = titleSize_0.y + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil_getInstance().AXIS_TITLE_INNER_MARGIN;\n geomAndAxis = DoubleRectangle_init(geomAndAxis.left + thickness, geomAndAxis.top, geomAndAxis.width - thickness, geomAndAxis.height);\n }if (this.hasAxisTitleBottom()) {\n var titleSize_1 = PlotLayoutUtil_getInstance().axisTitleDimensions_61zpoe$(this.axisTitleBottom);\n var thickness_0 = titleSize_1.y + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil_getInstance().AXIS_TITLE_INNER_MARGIN;\n geomAndAxis = DoubleRectangle_init(geomAndAxis.left, geomAndAxis.top, geomAndAxis.width, geomAndAxis.height - thickness_0);\n }}var plotLayout = this.plotLayout();\n var plotInfo = plotLayout.doLayout_gpjtzr$(geomAndAxis.dimension);\n this.myLaidOutSize_jqfjq$_0.set_11rb$(preferredSize);\n if (plotInfo.tiles.isEmpty()) {\n return;\n }var geomAreaBounds = PlotLayoutUtil_getInstance().absoluteGeomBounds_vjhcds$(geomAndAxis.origin, plotInfo);\n if (legendTheme.position().isOverlay) {\n var legendBoxesLayout_0 = new LegendBoxesLayout(geomAreaBounds, legendTheme);\n boxesLayoutResult = legendBoxesLayout_0.doLayout_8sg693$(this.legendBoxInfos);\n }if (plotInfo.tiles.size > 1) {\n tmp$_2 = this.theme_5sfato$_0.multiTile();\n } else {\n tmp$_2 = this.theme_5sfato$_0;\n }\n var tileTheme = tmp$_2;\n var tilesOrigin = geomAndAxis.origin;\n tmp$_3 = plotInfo.tiles.iterator();\n while (tmp$_3.hasNext()) {\n var tileLayoutInfo = tmp$_3.next();\n var tileLayersIndex = tileLayoutInfo.trueIndex;\n var tile = this.createTile_rg9gwo$_0(tilesOrigin, tileLayoutInfo, this.tileLayers_za3lpa$(tileLayersIndex), tileTheme);\n var plotOriginAbsolute = tilesOrigin.add_gpjtzr$(tileLayoutInfo.plotOrigin);\n tile.moveTo_gpjtzr$(plotOriginAbsolute);\n this.add_8icvvv$(tile);\n if ((tmp$_4 = tile.liveMapFigure) != null) {\n getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_11rb$(p1);\n }.bind(null, this.myLiveMapFigures_nd8qng$_0))(tmp$_4);\n }var geomBoundsAbsolute = tileLayoutInfo.geomBounds.add_gpjtzr$(plotOriginAbsolute);\n this.myTooltipHelper_3jkkzs$_0.addTileInfo_t6qbjr$(geomBoundsAbsolute, tile.targetLocators);\n }\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_1 = SvgRectElement_init(geomAreaBounds);\n rect_1.strokeColor().set_11rb$(Color.Companion.RED);\n rect_1.strokeWidth().set_11rb$(1.0);\n rect_1.fillOpacity().set_11rb$(0.0);\n this.add_26jijc$(rect_1);\n }if (this.hasTitle()) {\n var titleLabel = new TextLabel(this.title);\n titleLabel.addClassName_61zpoe$(Style_getInstance().PLOT_TITLE);\n titleLabel.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.LEFT);\n titleLabel.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n var titleSize_2 = PlotLayoutUtil_getInstance().titleDimensions_61zpoe$(this.title);\n var titleBounds = DoubleRectangle_init(geomAreaBounds.origin.x, 0.0, titleSize_2.x, titleSize_2.y);\n titleLabel.moveTo_gpjtzr$(new DoubleVector(titleBounds.left, titleBounds.center.y));\n this.add_8icvvv$(titleLabel);\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_2 = SvgRectElement_init(titleBounds);\n rect_2.strokeColor().set_11rb$(Color.Companion.BLUE);\n rect_2.strokeWidth().set_11rb$(1.0);\n rect_2.fillOpacity().set_11rb$(0.0);\n this.add_26jijc$(rect_2);\n }}if (this.isAxisEnabled) {\n if (this.hasAxisTitleLeft()) {\n this.createAxisTitle_depkt8$_0(this.axisTitleLeft, Orientation$LEFT_getInstance(), withoutTitleAndLegends, geomAreaBounds);\n }if (this.hasAxisTitleBottom()) {\n this.createAxisTitle_depkt8$_0(this.axisTitleBottom, Orientation$BOTTOM_getInstance(), withoutTitleAndLegends, geomAreaBounds);\n }}if (boxesLayoutResult != null) {\n tmp$_5 = boxesLayoutResult.boxWithLocationList.iterator();\n while (tmp$_5.hasNext()) {\n var boxWithLocation = tmp$_5.next();\n var legendBox = boxWithLocation.legendBox.createLegendBox();\n legendBox.moveTo_gpjtzr$(boxWithLocation.location);\n this.add_8icvvv$(legendBox);\n }\n }};\n Plot.prototype.createTooltipSpecs_gpjtzr$ = function (plotCoord) {\n return this.myTooltipHelper_3jkkzs$_0.createTooltipSpecs_gpjtzr$(plotCoord);\n };\n Plot.prototype.getGeomBounds_gpjtzr$ = function (plotCoord) {\n return this.myTooltipHelper_3jkkzs$_0.getGeomBounds_gpjtzr$(plotCoord);\n };\n function Plot$Companion() {\n Plot$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(Plot));\n this.DEF_PLOT_SIZE_0 = new DoubleVector(600.0, 400.0);\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().PLOT_DEBUG_DRAWING;\n }\n Plot$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Plot$Companion_instance = null;\n function Plot$Companion_getInstance() {\n if (Plot$Companion_instance === null) {\n new Plot$Companion();\n }return Plot$Companion_instance;\n }\n Plot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Plot',\n interfaces: [SvgComponent]\n };\n function PlotBuilder(myTheme) {\n this.myTheme_0 = myTheme;\n this.myLayersByTile_0 = ArrayList_init();\n this.myTitle_0 = null;\n this.myCoordProvider_3t551e$_0 = this.myCoordProvider_3t551e$_0;\n this.myLayout_0 = null;\n this.myAxisTitleLeft_0 = null;\n this.myAxisTitleBottom_0 = null;\n this.myLegendBoxInfos_0 = ArrayList_init();\n this.myScaleXProto_s7k1di$_0 = this.myScaleXProto_s7k1di$_0;\n this.myScaleYProto_dj5r5h$_0 = this.myScaleYProto_dj5r5h$_0;\n this.myAxisEnabled_0 = true;\n this.myInteractionsEnabled_0 = true;\n this.hasLiveMap_0 = false;\n }\n Object.defineProperty(PlotBuilder.prototype, 'myCoordProvider_0', {\n configurable: true,\n get: function () {\n if (this.myCoordProvider_3t551e$_0 == null)\n return throwUPAE('myCoordProvider');\n return this.myCoordProvider_3t551e$_0;\n },\n set: function (myCoordProvider) {\n this.myCoordProvider_3t551e$_0 = myCoordProvider;\n }\n });\n Object.defineProperty(PlotBuilder.prototype, 'myScaleXProto_0', {\n configurable: true,\n get: function () {\n if (this.myScaleXProto_s7k1di$_0 == null)\n return throwUPAE('myScaleXProto');\n return this.myScaleXProto_s7k1di$_0;\n },\n set: function (myScaleXProto) {\n this.myScaleXProto_s7k1di$_0 = myScaleXProto;\n }\n });\n Object.defineProperty(PlotBuilder.prototype, 'myScaleYProto_0', {\n configurable: true,\n get: function () {\n if (this.myScaleYProto_dj5r5h$_0 == null)\n return throwUPAE('myScaleYProto');\n return this.myScaleYProto_dj5r5h$_0;\n },\n set: function (myScaleYProto) {\n this.myScaleYProto_dj5r5h$_0 = myScaleYProto;\n }\n });\n PlotBuilder.prototype.setTitle_pdl1vj$ = function (title) {\n this.myTitle_0 = title;\n };\n PlotBuilder.prototype.setAxisTitleLeft_61zpoe$ = function (v) {\n this.myAxisTitleLeft_0 = v;\n };\n PlotBuilder.prototype.setAxisTitleBottom_61zpoe$ = function (v) {\n this.myAxisTitleBottom_0 = v;\n };\n PlotBuilder.prototype.setCoordProvider_sdecqr$ = function (coordProvider) {\n this.myCoordProvider_0 = coordProvider;\n return this;\n };\n PlotBuilder.prototype.addTileLayers_relqli$ = function (tileLayers) {\n this.myLayersByTile_0.add_11rb$(ArrayList_init_0(tileLayers));\n return this;\n };\n PlotBuilder.prototype.setPlotLayout_vjneqj$ = function (layout) {\n this.myLayout_0 = layout;\n return this;\n };\n PlotBuilder.prototype.addLegendBoxInfo_29gouq$ = function (v) {\n this.myLegendBoxInfos_0.add_11rb$(v);\n return this;\n };\n PlotBuilder.prototype.scaleXProto_iu85h4$ = function (scaleXProto) {\n this.myScaleXProto_0 = scaleXProto;\n return this;\n };\n PlotBuilder.prototype.scaleYProto_iu85h4$ = function (scaleYProto) {\n this.myScaleYProto_0 = scaleYProto;\n return this;\n };\n PlotBuilder.prototype.axisEnabled_6taknv$ = function (b) {\n this.myAxisEnabled_0 = b;\n return this;\n };\n PlotBuilder.prototype.interactionsEnabled_6taknv$ = function (b) {\n this.myInteractionsEnabled_0 = b;\n return this;\n };\n PlotBuilder.prototype.setLiveMap_6taknv$ = function (b) {\n this.hasLiveMap_0 = b;\n return this;\n };\n PlotBuilder.prototype.build = function () {\n return new PlotBuilder$MyPlot(this);\n };\n function PlotBuilder$MyPlot(b) {\n Plot.call(this, b.myTheme_0);\n this.scaleXProto_rbtdab$_0 = b.myScaleXProto_0;\n this.scaleYProto_t0wegs$_0 = b.myScaleYProto_0;\n this.myTitle_0 = b.myTitle_0;\n this.myAxisTitleLeft_0 = b.myAxisTitleLeft_0;\n this.myAxisTitleBottom_0 = b.myAxisTitleBottom_0;\n this.myAxisXTitleEnabled_0 = b.myTheme_0.axisX().showTitle();\n this.myAxisYTitleEnabled_0 = b.myTheme_0.axisY().showTitle();\n this.coordProvider_o460zb$_0 = b.myCoordProvider_0;\n this.myLayersByTile_0 = null;\n this.myLayout_0 = null;\n this.myLegendBoxInfos_0 = null;\n this.hasLiveMap_0 = false;\n this.isAxisEnabled_70ondl$_0 = false;\n this.isInteractionsEnabled_dvtvmh$_0 = false;\n this.myLayersByTile_0 = ArrayList_init_0(b.myLayersByTile_0);\n this.myLayout_0 = b.myLayout_0;\n this.myLegendBoxInfos_0 = ArrayList_init_0(b.myLegendBoxInfos_0);\n this.hasLiveMap_0 = b.hasLiveMap_0;\n this.isAxisEnabled_70ondl$_0 = b.myAxisEnabled_0;\n this.isInteractionsEnabled_dvtvmh$_0 = b.myInteractionsEnabled_0;\n }\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'scaleXProto', {\n configurable: true,\n get: function () {\n return this.scaleXProto_rbtdab$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'scaleYProto', {\n configurable: true,\n get: function () {\n return this.scaleYProto_t0wegs$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'coordProvider', {\n configurable: true,\n get: function () {\n return this.coordProvider_o460zb$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'isAxisEnabled', {\n configurable: true,\n get: function () {\n return this.isAxisEnabled_70ondl$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'isInteractionsEnabled', {\n configurable: true,\n get: function () {\n return this.isInteractionsEnabled_dvtvmh$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'title', {\n configurable: true,\n get: function () {\n if (!this.hasTitle()) {\n var message = 'No title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myTitle_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'axisTitleLeft', {\n configurable: true,\n get: function () {\n if (!this.hasAxisTitleLeft()) {\n var message = 'No left axis title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myAxisTitleLeft_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'axisTitleBottom', {\n configurable: true,\n get: function () {\n if (!this.hasAxisTitleBottom()) {\n var message = 'No bottom axis title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myAxisTitleBottom_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'legendBoxInfos', {\n configurable: true,\n get: function () {\n return this.myLegendBoxInfos_0;\n }\n });\n PlotBuilder$MyPlot.prototype.hasTitle = function () {\n return !base.Strings.isNullOrEmpty_pdl1vj$(this.myTitle_0);\n };\n PlotBuilder$MyPlot.prototype.hasAxisTitleLeft = function () {\n return this.myAxisYTitleEnabled_0 && !base.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleLeft_0);\n };\n PlotBuilder$MyPlot.prototype.hasAxisTitleBottom = function () {\n return this.myAxisXTitleEnabled_0 && !base.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleBottom_0);\n };\n PlotBuilder$MyPlot.prototype.hasLiveMap = function () {\n return this.hasLiveMap_0;\n };\n PlotBuilder$MyPlot.prototype.tileLayers_za3lpa$ = function (tileIndex) {\n return this.myLayersByTile_0.get_za3lpa$(tileIndex);\n };\n PlotBuilder$MyPlot.prototype.plotLayout = function () {\n return ensureNotNull(this.myLayout_0);\n };\n PlotBuilder$MyPlot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyPlot',\n interfaces: [Plot]\n };\n PlotBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotBuilder',\n interfaces: []\n };\n function PlotContainerPortable(plot, preferredSize) {\n PlotContainerPortable$Companion_getInstance();\n this.plot = plot;\n this.preferredSize_sl52i3$_0 = preferredSize;\n this.svg = new SvgSvgElement();\n this.myContentBuilt_l8hvkk$_0 = false;\n this.myRegistrations_wwtuqx$_0 = new CompositeRegistration([]);\n this.svg.addClass_61zpoe$(Style_getInstance().PLOT_CONTAINER);\n this.setSvgSize_2l8z8v$_0(this.preferredSize_sl52i3$_0.get());\n this.plot.laidOutSize().addHandler_gxwwpc$(PlotContainerPortable$Companion_getInstance().sizePropHandler_0(PlotContainerPortable_init$lambda(this)));\n this.preferredSize_sl52i3$_0.addHandler_gxwwpc$(PlotContainerPortable$Companion_getInstance().sizePropHandler_0(PlotContainerPortable_init$lambda_0(this)));\n }\n Object.defineProperty(PlotContainerPortable.prototype, 'liveMapFigures', {\n configurable: true,\n get: function () {\n return this.plot.liveMapFigures_8be2vx$;\n }\n });\n Object.defineProperty(PlotContainerPortable.prototype, 'isLiveMap', {\n configurable: true,\n get: function () {\n return !this.plot.liveMapFigures_8be2vx$.isEmpty();\n }\n });\n PlotContainerPortable.prototype.ensureContentBuilt = function () {\n if (!this.myContentBuilt_l8hvkk$_0) {\n this.buildContent();\n }};\n PlotContainerPortable.prototype.revalidateContent_r8qzcp$_0 = function () {\n if (this.myContentBuilt_l8hvkk$_0) {\n this.clearContent();\n this.buildContent();\n }};\n function PlotContainerPortable$buildContent$ObjectLiteral() {\n }\n PlotContainerPortable$buildContent$ObjectLiteral.prototype.css = function () {\n return Style_getInstance().css;\n };\n PlotContainerPortable$buildContent$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [SvgCssResource]\n };\n PlotContainerPortable.prototype.buildContent = function () {\n if (!!this.myContentBuilt_l8hvkk$_0) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }this.myContentBuilt_l8hvkk$_0 = true;\n this.svg.setStyle_i8z0m3$(new PlotContainerPortable$buildContent$ObjectLiteral());\n var backdrop = new SvgRectElement();\n backdrop.addClass_61zpoe$(Style_getInstance().PLOT_BACKDROP);\n backdrop.setAttribute_jyasbz$('width', '100%');\n backdrop.setAttribute_jyasbz$('height', '100%');\n this.svg.children().add_11rb$(backdrop);\n this.plot.preferredSize_8be2vx$().set_11rb$(this.preferredSize_sl52i3$_0.get());\n this.svg.children().add_11rb$(this.plot.rootGroup);\n };\n PlotContainerPortable.prototype.clearContent = function () {\n if (this.myContentBuilt_l8hvkk$_0) {\n this.myContentBuilt_l8hvkk$_0 = false;\n this.svg.children().clear();\n this.plot.clear();\n this.myRegistrations_wwtuqx$_0.remove();\n this.myRegistrations_wwtuqx$_0 = new CompositeRegistration([]);\n }};\n PlotContainerPortable.prototype.reg_3xv6fb$ = function (registration) {\n this.myRegistrations_wwtuqx$_0.add_3xv6fb$(registration);\n };\n PlotContainerPortable.prototype.setSvgSize_2l8z8v$_0 = function (size) {\n this.svg.width().set_11rb$(size.x);\n this.svg.height().set_11rb$(size.y);\n };\n function PlotContainerPortable$Companion() {\n PlotContainerPortable$Companion_instance = this;\n }\n function PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral(closure$block) {\n this.closure$block = closure$block;\n }\n PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var newValue = event.newValue;\n if (newValue != null) {\n this.closure$block(newValue);\n }};\n PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n PlotContainerPortable$Companion.prototype.sizePropHandler_0 = function (block) {\n return new PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral(block);\n };\n PlotContainerPortable$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotContainerPortable$Companion_instance = null;\n function PlotContainerPortable$Companion_getInstance() {\n if (PlotContainerPortable$Companion_instance === null) {\n new PlotContainerPortable$Companion();\n }return PlotContainerPortable$Companion_instance;\n }\n function PlotContainerPortable_init$lambda(this$PlotContainerPortable) {\n return function (laidOutSize) {\n var a = this$PlotContainerPortable.preferredSize_sl52i3$_0.get().x;\n var b = laidOutSize.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this$PlotContainerPortable.preferredSize_sl52i3$_0.get().y;\n var b_0 = laidOutSize.y;\n var newSvgSize = new DoubleVector(tmp$, JsMath.max(a_0, b_0));\n this$PlotContainerPortable.setSvgSize_2l8z8v$_0(newSvgSize);\n return Unit;\n };\n }\n function PlotContainerPortable_init$lambda_0(this$PlotContainerPortable) {\n return function (newPreferredSize) {\n if (newPreferredSize.x > 0 && newPreferredSize.y > 0) {\n this$PlotContainerPortable.revalidateContent_r8qzcp$_0();\n }return Unit;\n };\n }\n PlotContainerPortable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotContainerPortable',\n interfaces: []\n };\n function PlotTile(layers, myScaleX, myScaleY, myTilesOrigin, myLayoutInfo, myCoord, myTheme) {\n SvgComponent.call(this);\n this.myScaleX_0 = myScaleX;\n this.myScaleY_0 = myScaleY;\n this.myTilesOrigin_0 = myTilesOrigin;\n this.myLayoutInfo_0 = myLayoutInfo;\n this.myCoord_0 = myCoord;\n this.myTheme_0 = myTheme;\n this.myDebugDrawing_0 = new ValueProperty(false);\n this.myLayers_0 = null;\n this.myTargetLocators_0 = ArrayList_init();\n this.myShowAxis_0 = false;\n this.liveMapFigure_y5x745$_0 = null;\n this.myLayers_0 = ArrayList_init_0(layers);\n this.moveTo_gpjtzr$(this.myLayoutInfo_0.getAbsoluteBounds_gpjtzr$(this.myTilesOrigin_0).origin);\n }\n Object.defineProperty(PlotTile.prototype, 'liveMapFigure', {\n configurable: true,\n get: function () {\n return this.liveMapFigure_y5x745$_0;\n },\n set: function (liveMapFigure) {\n this.liveMapFigure_y5x745$_0 = liveMapFigure;\n }\n });\n Object.defineProperty(PlotTile.prototype, 'targetLocators', {\n configurable: true,\n get: function () {\n return this.myTargetLocators_0;\n }\n });\n Object.defineProperty(PlotTile.prototype, 'isDebugDrawing_0', {\n configurable: true,\n get: function () {\n return this.myDebugDrawing_0.get();\n }\n });\n PlotTile.prototype.buildComponent = function () {\n var tmp$, tmp$_0, tmp$_1;\n var geomBounds = this.myLayoutInfo_0.geomBounds;\n if (this.myTheme_0.plot().showInnerFrame()) {\n var $receiver = SvgRectElement_init(geomBounds);\n $receiver.strokeColor().set_11rb$(this.myTheme_0.plot().innerFrameColor());\n $receiver.strokeWidth().set_11rb$(1.0);\n $receiver.fillOpacity().set_11rb$(0.0);\n var rect = $receiver;\n this.add_26jijc$(rect);\n }this.addFacetLabels_0(geomBounds, this.myTheme_0.facets());\n var $receiver_0 = this.myLayers_0;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_2;\n tmp$_2 = $receiver_0.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (element.isLiveMap) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var liveMapGeomLayer = firstOrNull$result;\n if (liveMapGeomLayer == null && this.myShowAxis_0) {\n this.addAxis_0(geomBounds);\n }if (this.isDebugDrawing_0) {\n var tileBounds = this.myLayoutInfo_0.bounds;\n var rect_0 = SvgRectElement_init(tileBounds);\n rect_0.fillColor().set_11rb$(Color.Companion.BLACK);\n rect_0.strokeWidth().set_11rb$(0.0);\n rect_0.fillOpacity().set_11rb$(0.1);\n this.add_26jijc$(rect_0);\n }if (this.isDebugDrawing_0) {\n var clipBounds = this.myLayoutInfo_0.clipBounds;\n var rect_1 = SvgRectElement_init(clipBounds);\n rect_1.fillColor().set_11rb$(Color.Companion.DARK_GREEN);\n rect_1.strokeWidth().set_11rb$(0.0);\n rect_1.fillOpacity().set_11rb$(0.3);\n this.add_26jijc$(rect_1);\n }if (this.isDebugDrawing_0) {\n var rect_2 = SvgRectElement_init(geomBounds);\n rect_2.fillColor().set_11rb$(Color.Companion.PINK);\n rect_2.strokeWidth().set_11rb$(1.0);\n rect_2.fillOpacity().set_11rb$(0.5);\n this.add_26jijc$(rect_2);\n }if (liveMapGeomLayer != null) {\n var realBounds = this.myLayoutInfo_0.getAbsoluteGeomBounds_gpjtzr$(this.myTilesOrigin_0);\n var liveMapData = createCanvasFigure(liveMapGeomLayer, realBounds);\n this.liveMapFigure = liveMapData.canvasFigure;\n this.myTargetLocators_0.add_11rb$(liveMapData.targetLocator);\n } else {\n var sharedNumericMappers = HashMap_init();\n var overallNumericDomains = HashMap_init();\n var xAxisInfo = this.myLayoutInfo_0.xAxisInfo;\n var yAxisInfo = this.myLayoutInfo_0.yAxisInfo;\n var mapperX = this.myScaleX_0.mapper;\n var mapperY = this.myScaleY_0.mapper;\n var key = Aes.Companion.X;\n sharedNumericMappers.put_xwzc9p$(key, mapperX);\n var key_0 = Aes.Companion.Y;\n sharedNumericMappers.put_xwzc9p$(key_0, mapperY);\n var key_1 = Aes.Companion.SLOPE;\n var value = scale.Mappers.mul_14dthe$(ensureNotNull(mapperY(1.0)) / ensureNotNull(mapperX(1.0)));\n sharedNumericMappers.put_xwzc9p$(key_1, value);\n var key_2 = Aes.Companion.X;\n var value_0 = ensureNotNull(ensureNotNull(xAxisInfo).axisDomain);\n overallNumericDomains.put_xwzc9p$(key_2, value_0);\n var key_3 = Aes.Companion.Y;\n var value_1 = ensureNotNull(ensureNotNull(yAxisInfo).axisDomain);\n overallNumericDomains.put_xwzc9p$(key_3, value_1);\n var geomLayerComponents = this.buildGeoms_0(sharedNumericMappers, overallNumericDomains, this.myCoord_0);\n tmp$ = geomLayerComponents.iterator();\n while (tmp$.hasNext()) {\n var layerComponent = tmp$.next();\n layerComponent.moveTo_gpjtzr$(geomBounds.origin);\n var xRange = (tmp$_0 = this.myCoord_0.xClientLimit) != null ? tmp$_0 : new ClosedRange(0.0, geomBounds.width);\n var yRange = (tmp$_1 = this.myCoord_0.yClientLimit) != null ? tmp$_1 : new ClosedRange(0.0, geomBounds.height);\n var clipRect = GeometryUtil_getInstance().doubleRange_gyv40k$(xRange, yRange);\n layerComponent.clipBounds_wthzt5$(clipRect);\n this.add_8icvvv$(layerComponent);\n }\n }\n };\n PlotTile.prototype.addFacetLabels_0 = function (geomBounds, theme) {\n var tmp$;\n var xLabels = this.myLayoutInfo_0.facetXLabels;\n if (!xLabels.isEmpty()) {\n var labelSize = FacetGridPlotLayout$Companion_getInstance().facetColLabelSize_14dthe$(geomBounds.width);\n var labelOrig = new DoubleVector(geomBounds.left + 0, geomBounds.top - FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(xLabels.size) + 6);\n var labelBounds = new DoubleRectangle(labelOrig, labelSize);\n tmp$ = xLabels.iterator();\n while (tmp$.hasNext()) {\n var xLabel = tmp$.next();\n var $receiver = SvgRectElement_init(labelBounds);\n $receiver.strokeWidth().set_11rb$(0.0);\n $receiver.fillColor().set_11rb$(theme.labelBackground());\n var rect = $receiver;\n this.add_26jijc$(rect);\n var x = labelBounds.center.x;\n var y = labelBounds.center.y;\n var lab = new TextLabel(xLabel);\n lab.moveTo_lu1900$(x, y);\n lab.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n lab.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n this.add_8icvvv$(lab);\n labelBounds = labelBounds.add_gpjtzr$(new DoubleVector(0.0, labelSize.y));\n }\n }if (this.myLayoutInfo_0.facetYLabel != null) {\n var hPad = 6;\n var vPad = 0;\n var labelBounds_0 = DoubleRectangle_init(geomBounds.right + hPad, geomBounds.top - vPad, FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT - (hPad * 2 | 0), geomBounds.height - (vPad * 2 | 0));\n var rect_0 = SvgRectElement_init(labelBounds_0);\n rect_0.strokeWidth().set_11rb$(0.0);\n rect_0.fillColor().set_11rb$(theme.labelBackground());\n this.add_26jijc$(rect_0);\n var x_0 = labelBounds_0.center.x;\n var y_0 = labelBounds_0.center.y;\n var lab_0 = new TextLabel(this.myLayoutInfo_0.facetYLabel);\n lab_0.moveTo_lu1900$(x_0, y_0);\n lab_0.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n lab_0.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n lab_0.rotate_14dthe$(90.0);\n this.add_8icvvv$(lab_0);\n }};\n PlotTile.prototype.addAxis_0 = function (geomBounds) {\n if (this.myLayoutInfo_0.xAxisShown) {\n var axis = this.buildAxis_0(this.myScaleX_0, ensureNotNull(this.myLayoutInfo_0.xAxisInfo), this.myCoord_0, this.myTheme_0.axisX());\n axis.moveTo_gpjtzr$(new DoubleVector(geomBounds.left, geomBounds.bottom));\n this.add_8icvvv$(axis);\n }if (this.myLayoutInfo_0.yAxisShown) {\n var axis_0 = this.buildAxis_0(this.myScaleY_0, ensureNotNull(this.myLayoutInfo_0.yAxisInfo), this.myCoord_0, this.myTheme_0.axisY());\n axis_0.moveTo_gpjtzr$(geomBounds.origin);\n this.add_8icvvv$(axis_0);\n }};\n PlotTile.prototype.buildAxis_0 = function (scale, info, coord, theme) {\n var axis = new AxisComponent(info.axisLength, ensureNotNull(info.orientation));\n AxisUtil_getInstance().setBreaks_6e5l22$(axis, scale, coord, info.orientation.isHorizontal);\n AxisUtil_getInstance().applyLayoutInfo_4pg061$(axis, info);\n AxisUtil_getInstance().applyTheme_tna4q5$(axis, theme);\n if (this.isDebugDrawing_0) {\n if (info.tickLabelsBounds != null) {\n var rect = SvgRectElement_init(info.tickLabelsBounds);\n rect.strokeColor().set_11rb$(Color.Companion.GREEN);\n rect.strokeWidth().set_11rb$(1.0);\n rect.fillOpacity().set_11rb$(0.0);\n axis.add_26jijc$(rect);\n }}return axis;\n };\n PlotTile.prototype.buildGeoms_0 = function (sharedNumericMappers, overallNumericDomains, coord) {\n var tmp$;\n var layerRenderers = ArrayList_init();\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var rendererData = LayerRendererUtil_getInstance().createLayerRendererData_knseyn$(layer, sharedNumericMappers, overallNumericDomains);\n var aestheticMappers = rendererData.aestheticMappers;\n var aesthetics = rendererData.aesthetics;\n var targetCollector = new LayerTargetCollectorWithLocator(layer.geomKind, layer.locatorLookupSpec, layer.contextualMapping, coord);\n this.myTargetLocators_0.add_11rb$(targetCollector);\n var ctx = GeomContextBuilder_init().aesthetics_luqwb2$(aesthetics).aestheticMappers_4iu3o$(aestheticMappers).geomTargetCollector_xrq6q$(targetCollector).build();\n var pos = rendererData.pos;\n var geom = layer.geom;\n layerRenderers.add_11rb$(new SvgLayerRenderer(aesthetics, geom, pos, coord, ctx));\n }\n return layerRenderers;\n };\n PlotTile.prototype.setShowAxis_6taknv$ = function (showAxis) {\n this.myShowAxis_0 = showAxis;\n };\n PlotTile.prototype.debugDrawing = function () {\n return this.myDebugDrawing_0;\n };\n PlotTile.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotTile',\n interfaces: [SvgComponent]\n };\n function createCanvasFigure($receiver, bounds) {\n var tmp$;\n return (Kotlin.isType(tmp$ = $receiver.geom, LiveMapGeom) ? tmp$ : throwCCE()).createCanvasFigure_wthzt5$(bounds);\n }\n function PlotTooltipHelper() {\n this.myTileInfos_0 = ArrayList_init();\n }\n PlotTooltipHelper.prototype.removeAllTileInfos = function () {\n this.myTileInfos_0.clear();\n };\n PlotTooltipHelper.prototype.addTileInfo_t6qbjr$ = function (geomBounds, targetLocators) {\n var tileInfo = new PlotTooltipHelper$TileInfo(geomBounds, targetLocators);\n this.myTileInfos_0.add_11rb$(tileInfo);\n };\n PlotTooltipHelper.prototype.createTooltipSpecs_gpjtzr$ = function (plotCoord) {\n var tmp$;\n tmp$ = this.findTileInfo_0(plotCoord);\n if (tmp$ == null) {\n return emptyList();\n }var tileInfo = tmp$;\n var lookupResults = tileInfo.findTargets_xoefl8$(plotCoord);\n return this.createTooltipSpecs_0(lookupResults, tileInfo.axisOrigin_8be2vx$);\n };\n PlotTooltipHelper.prototype.getGeomBounds_gpjtzr$ = function (plotCoord) {\n var tmp$;\n tmp$ = this.findTileInfo_0(plotCoord);\n if (tmp$ == null) {\n return null;\n }var tileInfo = tmp$;\n return tileInfo.geomBounds_8be2vx$;\n };\n PlotTooltipHelper.prototype.findTileInfo_0 = function (plotCoord) {\n var tmp$;\n tmp$ = this.myTileInfos_0.iterator();\n while (tmp$.hasNext()) {\n var tileInfo = tmp$.next();\n if (tileInfo.contains_xoefl8$(plotCoord)) {\n return tileInfo;\n }}\n return null;\n };\n PlotTooltipHelper.prototype.createTooltipSpecs_0 = function (lookupResults, axisOrigin) {\n var tooltipSpecs = ArrayList_init();\n var tmp$;\n tmp$ = lookupResults.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var factory = new TooltipSpecFactory(element.contextualMapping, axisOrigin);\n var tmp$_0;\n tmp$_0 = element.targets.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n tooltipSpecs.addAll_brywnq$(factory.create_62opr5$(element_0));\n }\n }\n return tooltipSpecs;\n };\n function PlotTooltipHelper$TileInfo(geomBounds, targetLocators) {\n this.geomBounds_8be2vx$ = geomBounds;\n var destination = ArrayList_init_1(collectionSizeOrDefault(targetLocators, 10));\n var tmp$;\n tmp$ = targetLocators.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new PlotTooltipHelper$TileInfo$TileTargetLocator(this, item));\n }\n this.myTargetLocators_0 = destination;\n }\n Object.defineProperty(PlotTooltipHelper$TileInfo.prototype, 'axisOrigin_8be2vx$', {\n configurable: true,\n get: function () {\n return new DoubleVector(this.geomBounds_8be2vx$.left, this.geomBounds_8be2vx$.bottom);\n }\n });\n PlotTooltipHelper$TileInfo.prototype.findTargets_xoefl8$ = function (plotCoord) {\n var $receiver = new LocatedTargetsPicker();\n var tmp$;\n tmp$ = this.myTargetLocators_0.iterator();\n while (tmp$.hasNext()) {\n var locator = tmp$.next();\n var result = locator.search_gpjtzr$(plotCoord);\n if (result != null) {\n $receiver.addLookupResult_9sakjw$(result, plotCoord);\n }}\n var targetsPicker = $receiver;\n return targetsPicker.picked;\n };\n PlotTooltipHelper$TileInfo.prototype.contains_xoefl8$ = function (plotCoord) {\n return this.geomBounds_8be2vx$.contains_gpjtzr$(plotCoord);\n };\n function PlotTooltipHelper$TileInfo$TileTargetLocator($outer, locator) {\n this.$outer = $outer;\n TransformedTargetLocator.call(this, locator);\n }\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToTargetCoord_gpjtzr$ = function (coord) {\n return coord.subtract_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin);\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToPlotCoord_gpjtzr$ = function (coord) {\n return coord.add_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin);\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToPlotDistance_14dthe$ = function (distance) {\n return distance;\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileTargetLocator',\n interfaces: [TransformedTargetLocator]\n };\n PlotTooltipHelper$TileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileInfo',\n interfaces: []\n };\n PlotTooltipHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotTooltipHelper',\n interfaces: []\n };\n function PlotUtil() {\n PlotUtil_instance = this;\n }\n function PlotUtil$createLayerPos$ObjectLiteral(closure$aes) {\n this.closure$aes = closure$aes;\n this.groupCount_uijr2l$_0 = lazy(PlotUtil$createLayerPos$ObjectLiteral$groupCount$lambda(closure$aes));\n }\n Object.defineProperty(PlotUtil$createLayerPos$ObjectLiteral.prototype, 'aesthetics', {\n configurable: true,\n get: function () {\n return this.closure$aes;\n }\n });\n Object.defineProperty(PlotUtil$createLayerPos$ObjectLiteral.prototype, 'groupCount', {\n configurable: true,\n get: function () {\n return this.groupCount_uijr2l$_0.value;\n }\n });\n function PlotUtil$createLayerPos$ObjectLiteral$groupCount$lambda(closure$aes) {\n return function () {\n var set = collect.Sets.newHashSet_yl67zr$(closure$aes.groups());\n return set.size;\n };\n }\n PlotUtil$createLayerPos$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProviderContext]\n };\n PlotUtil.prototype.createLayerPos_2iooof$ = function (layer, aes) {\n return layer.createPos_q7kk9g$(new PlotUtil$createLayerPos$ObjectLiteral(aes));\n };\n PlotUtil.prototype.computeLayerDryRunXYRanges_gl53zg$ = function (layer, aes) {\n var geomCtx = GeomContextBuilder_init().aesthetics_luqwb2$(aes).build();\n var rangesAfterPosAdjustment = this.computeLayerDryRunXYRangesAfterPosAdjustment_0(layer, aes, geomCtx);\n var tmp$ = this.computeLayerDryRunXYRangesAfterSizeExpand_0(layer, aes, geomCtx);\n var xRangeAfterSizeExpand = tmp$.component1()\n , yRangeAfterSizeExpand = tmp$.component2();\n var rangeX = rangesAfterPosAdjustment.first;\n if (rangeX == null) {\n rangeX = xRangeAfterSizeExpand;\n } else if (xRangeAfterSizeExpand != null) {\n rangeX = rangeX.span_d226ot$(xRangeAfterSizeExpand);\n }var rangeY = rangesAfterPosAdjustment.second;\n if (rangeY == null) {\n rangeY = yRangeAfterSizeExpand;\n } else if (yRangeAfterSizeExpand != null) {\n rangeY = rangeY.span_d226ot$(yRangeAfterSizeExpand);\n }return new Pair(rangeX, rangeY);\n };\n PlotUtil.prototype.combineRanges_0 = function (aesList, aesthetics) {\n var tmp$, tmp$_0;\n var result = null;\n tmp$ = aesList.iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var range = aesthetics.range_vktour$(aes);\n if (range != null) {\n result = (tmp$_0 = result != null ? result.span_d226ot$(range) : null) != null ? tmp$_0 : range;\n }}\n return result;\n };\n PlotUtil.prototype.computeLayerDryRunXYRangesAfterPosAdjustment_0 = function (layer, aes, geomCtx) {\n var tmp$, tmp$_0, tmp$_1;\n var posAesX = collect.Iterables.toList_yl67zr$(Aes.Companion.affectingScaleX_shhb9a$(layer.renderedAes()));\n var posAesY = collect.Iterables.toList_yl67zr$(Aes.Companion.affectingScaleY_shhb9a$(layer.renderedAes()));\n var pos = this.createLayerPos_2iooof$(layer, aes);\n if (pos.isIdentity) {\n var rangeX = this.combineRanges_0(posAesX, aes);\n var rangeY = this.combineRanges_0(posAesY, aes);\n return new Pair(rangeX, rangeY);\n }var adjustedMinX = 0.0;\n var adjustedMaxX = 0.0;\n var adjustedMinY = 0.0;\n var adjustedMaxY = 0.0;\n var rangesInited = false;\n var cardinality = Kotlin.imul(posAesX.size, posAesY.size);\n var px = Kotlin.newArray(cardinality, null);\n var py = Kotlin.newArray(cardinality, null);\n tmp$ = aes.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var i = -1;\n tmp$_0 = posAesX.iterator();\n while (tmp$_0.hasNext()) {\n var aesX = tmp$_0.next();\n var valX = p.numeric_vktour$(aesX);\n tmp$_1 = posAesY.iterator();\n while (tmp$_1.hasNext()) {\n var aesY = tmp$_1.next();\n var valY = p.numeric_vktour$(aesY);\n i = i + 1 | 0;\n px[i] = valX;\n py[i] = valY;\n }\n }\n while (i >= 0) {\n if (px[i] != null && py[i] != null) {\n var x = px[i];\n var y = py[i];\n if (data_0.SeriesUtil.isFinite_yrwdxb$(x) && data_0.SeriesUtil.isFinite_yrwdxb$(y)) {\n var newLoc = pos.translate_tshsjz$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), p, geomCtx);\n var adjustedX = newLoc.x;\n var adjustedY = newLoc.y;\n if (rangesInited) {\n var b = adjustedMinX;\n adjustedMinX = JsMath.min(adjustedX, b);\n var b_0 = adjustedMaxX;\n adjustedMaxX = JsMath.max(adjustedX, b_0);\n var b_1 = adjustedMinY;\n adjustedMinY = JsMath.min(adjustedY, b_1);\n var b_2 = adjustedMaxY;\n adjustedMaxY = JsMath.max(adjustedY, b_2);\n } else {\n adjustedMaxX = adjustedX;\n adjustedMinX = adjustedMaxX;\n adjustedMaxY = adjustedY;\n adjustedMinY = adjustedMaxY;\n rangesInited = true;\n }\n }}i = i - 1 | 0;\n }\n }\n var xRange = rangesInited ? new ClosedRange(adjustedMinX, adjustedMaxX) : null;\n var yRange = rangesInited ? new ClosedRange(adjustedMinY, adjustedMaxY) : null;\n return new Pair(xRange, yRange);\n };\n PlotUtil.prototype.computeLayerDryRunXYRangesAfterSizeExpand_0 = function (layer, aesthetics, geomCtx) {\n var renderedAes = layer.renderedAes();\n var computeExpandX = renderedAes.contains_11rb$(Aes.Companion.WIDTH);\n var computeExpandY = renderedAes.contains_11rb$(Aes.Companion.HEIGHT);\n var rangeX = computeExpandX ? this.computeLayerDryRunRangeAfterSizeExpand_0(Aes.Companion.X, Aes.Companion.WIDTH, aesthetics, geomCtx) : null;\n var rangeY = computeExpandY ? this.computeLayerDryRunRangeAfterSizeExpand_0(Aes.Companion.Y, Aes.Companion.HEIGHT, aesthetics, geomCtx) : null;\n return new Pair(rangeX, rangeY);\n };\n PlotUtil.prototype.computeLayerDryRunRangeAfterSizeExpand_0 = function (locationAes, sizeAes, aesthetics, geomCtx) {\n var tmp$;\n var locations = aesthetics.numericValues_vktour$(locationAes).iterator();\n var sizes = aesthetics.numericValues_vktour$(sizeAes).iterator();\n var resolution = geomCtx.getResolution_vktour$(locationAes);\n var minMax = new Float64Array([kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY, kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY]);\n tmp$ = aesthetics.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n if (!locations.hasNext()) {\n throw IllegalStateException_init('Index is out of bounds: ' + i + ' for ' + locationAes);\n }if (!sizes.hasNext()) {\n throw IllegalStateException_init('Index is out of bounds: ' + i + ' for ' + sizeAes);\n }var loc = locations.next();\n var size = sizes.next();\n if (data_0.SeriesUtil.isFinite_yrwdxb$(loc) && data_0.SeriesUtil.isFinite_yrwdxb$(size)) {\n var expand = resolution * (ensureNotNull(size) / 2);\n this.updateExpandedMinMax_0(ensureNotNull(loc), expand, minMax);\n }}\n return minMax[0] <= minMax[1] ? new ClosedRange(minMax[0], minMax[1]) : null;\n };\n PlotUtil.prototype.updateExpandedMinMax_0 = function (value, expand, expandedMinMax) {\n var a = value - expand;\n var b = expandedMinMax[0];\n expandedMinMax[0] = JsMath.min(a, b);\n var a_0 = value + expand;\n var b_0 = expandedMinMax[1];\n expandedMinMax[1] = JsMath.max(a_0, b_0);\n };\n PlotUtil.prototype.createLayerDryRunAesthetics_sqg2xh$ = function (layer) {\n var tmp$, tmp$_0, tmp$_1;\n var dryRunMapperByAes = HashMap_init();\n tmp$ = layer.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (aes.isNumeric) {\n tmp$_1 = Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE();\n var value = scale.Mappers.IDENTITY;\n dryRunMapperByAes.put_xwzc9p$(tmp$_1, value);\n }}\n var mappers = this.prepareLayerAestheticMappers_viiuew$(layer, dryRunMapperByAes);\n return this.createLayerAesthetics_kpf4gp$(layer, mappers, emptyMap());\n };\n PlotUtil.prototype.prepareLayerAestheticMappers_viiuew$ = function (layer, sharedNumericMappers) {\n var tmp$;\n var mappers = HashMap_init_0(sharedNumericMappers);\n tmp$ = layer.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var tmp$_0;\n var mapper = (Kotlin.isType(tmp$_0 = sharedNumericMappers, Map) ? tmp$_0 : throwCCE()).get_11rb$(aes);\n if (mapper == null) {\n if (Aes.Companion.isPositionalX_896ixz$(aes)) {\n mapper = sharedNumericMappers.get_11rb$(Aes.Companion.X);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes)) {\n mapper = sharedNumericMappers.get_11rb$(Aes.Companion.Y);\n }}if (mapper == null && layer.hasBinding_896ixz$(aes)) {\n mapper = layer.scaleMap.get_31786j$(aes).mapper;\n }if (mapper != null) {\n var value = mapper;\n mappers.put_xwzc9p$(aes, value);\n }}\n return mappers;\n };\n PlotUtil.prototype.createLayerAesthetics_kpf4gp$ = function (layer, sharedMappers, overallNumericDomains) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var aesBuilder = new AestheticsBuilder();\n aesBuilder.group_ddsh32$(layer.group);\n tmp$ = overallNumericDomains.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_4 = tmp$.next();\n var aes = tmp$_4.key;\n var domain = tmp$_4.value;\n if ((tmp$_0 = sharedMappers.get_11rb$(aes)) != null) {\n var tmp$_5, tmp$_6;\n var range = new ClosedRange(typeof (tmp$_5 = tmp$_0(domain.lowerEnd)) === 'number' ? tmp$_5 : throwCCE(), typeof (tmp$_6 = tmp$_0(domain.upperEnd)) === 'number' ? tmp$_6 : throwCCE());\n aesBuilder.overallRange_xlyz3f$(aes, range);\n }}\n var hasPositionalConstants = false;\n tmp$_1 = layer.renderedAes().iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n if (Aes.Companion.isPositional_896ixz$(aes_0) && layer.hasConstant_896ixz$(aes_0)) {\n hasPositionalConstants = true;\n break;\n }}\n var data_0 = layer.dataFrame;\n var dataPointCount = {v: null};\n tmp$_2 = layer.renderedAes().iterator();\n while (tmp$_2.hasNext()) {\n var aes_1 = tmp$_2.next();\n var aes_2 = Kotlin.isType(tmp$_3 = aes_1, Aes) ? tmp$_3 : throwCCE();\n var mapperOption = sharedMappers.get_11rb$(aes_2);\n if (layer.hasConstant_896ixz$(aes_2)) {\n var v = layer.getConstant_31786j$(aes_2);\n aesBuilder.constantAes_bbdhip$(aes_2, this.asAesValue_0(aes_2, v, mapperOption));\n } else {\n if (layer.hasBinding_896ixz$(aes_2)) {\n if (!(mapperOption != null)) {\n var message = 'No scale mapper defined for aesthetic ' + aes_2;\n throw IllegalStateException_init(message.toString());\n }var transformVar = data.DataFrameUtil.transformVarFor_896ixz$(aes_2);\n if (!data_0.has_8xm3sj$(transformVar)) {\n var message_0 = 'Undefined var ' + transformVar + ' for aesthetic ' + aes_2;\n throw IllegalStateException_init(message_0.toString());\n }var numericValues = data_0.getNumeric_8xm3sj$(transformVar);\n if (dataPointCount.v == null) {\n dataPointCount.v = numericValues.size;\n } else {\n if (!(dataPointCount.v === numericValues.size)) {\n var message_1 = '' + toString(aes_2) + ' expected data size=' + toString(dataPointCount.v) + ' was size=' + toString(numericValues.size);\n throw IllegalStateException_init(message_1.toString());\n }}\n if (dataPointCount.v === 0 && hasPositionalConstants) {\n aesBuilder.constantAes_bbdhip$(aes_2, layer.aestheticsDefaults.defaultValue_31786j$(aes_2));\n } else {\n var integerFunction = AestheticsBuilder.Companion.listMapper_sedzz5$(numericValues, mapperOption);\n aesBuilder.aes_u42xfl$(aes_2, integerFunction);\n }\n } else {\n var v_0 = layer.getDefault_31786j$(aes_2);\n aesBuilder.constantAes_bbdhip$(aes_2, this.asAesValue_0(aes_2, v_0, mapperOption));\n }\n }\n }\n if (dataPointCount.v != null && dataPointCount.v > 0) {\n aesBuilder.dataPointCount_za3lpa$(dataPointCount.v);\n } else if (hasPositionalConstants) {\n aesBuilder.dataPointCount_za3lpa$(1);\n }return aesBuilder.build();\n };\n PlotUtil.prototype.asAesValue_0 = function (aes, dataValue, mapperOption) {\n var tmp$, tmp$_0, tmp$_1;\n if (aes.isNumeric && mapperOption != null) {\n tmp$_0 = mapperOption(typeof (tmp$ = dataValue) === 'number' ? tmp$ : null);\n if (tmp$_0 == null) {\n throw IllegalArgumentException_init(\"Can't map \" + dataValue + ' to aesthetic ' + aes);\n }tmp$_1 = tmp$_0;\n } else\n tmp$_1 = dataValue;\n return tmp$_1;\n };\n PlotUtil.prototype.rangeWithExpand_cmjc6r$ = function (layer, aes, range) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (range == null)\n return null;\n var scale = layer.scaleMap.get_31786j$(aes);\n var mulExp = scale.multiplicativeExpand;\n var addExp = scale.additiveExpand;\n if (scale.isContinuousDomain) {\n tmp$_0 = Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE();\n } else {\n tmp$_0 = null;\n }\n var continuousTransform = tmp$_0;\n var lowerEndpoint = (tmp$_1 = continuousTransform != null ? continuousTransform.applyInverse_yrwdxb$(range.lowerEnd) : null) != null ? tmp$_1 : range.lowerEnd;\n var upperEndpoint = (tmp$_2 = continuousTransform != null ? continuousTransform.applyInverse_yrwdxb$(range.upperEnd) : null) != null ? tmp$_2 : range.upperEnd;\n var length = upperEndpoint - lowerEndpoint;\n var lowerExpand = addExp + length * mulExp;\n var upperExpand = lowerExpand;\n if (layer.rangeIncludesZero_896ixz$(aes)) {\n var tmp$_3 = lowerEndpoint === 0.0 || upperEndpoint === 0.0;\n if (!tmp$_3) {\n tmp$_3 = JsMath.sign(lowerEndpoint) === JsMath.sign(upperEndpoint);\n }if (tmp$_3) {\n if (lowerEndpoint >= 0) {\n lowerExpand = 0.0;\n } else {\n upperExpand = 0.0;\n }\n }}var it = lowerEndpoint - lowerExpand;\n var block$result;\n var tmp$_4;\n var transformed = (tmp$_4 = continuousTransform != null ? continuousTransform.apply_yrwdxb$(it) : null) != null ? tmp$_4 : it;\n if (isNaN_0(transformed)) {\n block$result = range.lowerEnd;\n } else {\n block$result = transformed;\n }\n var lowerEndWithExpand = block$result;\n var it_0 = upperEndpoint + upperExpand;\n var block$result_0;\n var tmp$_5;\n var transformed_0 = (tmp$_5 = continuousTransform != null ? continuousTransform.apply_yrwdxb$(it_0) : null) != null ? tmp$_5 : it_0;\n if (isNaN_0(transformed_0)) {\n block$result_0 = range.upperEnd;\n } else {\n block$result_0 = transformed_0;\n }\n var upperEndWithExpand = block$result_0;\n return new ClosedRange(lowerEndWithExpand, upperEndWithExpand);\n };\n PlotUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotUtil',\n interfaces: []\n };\n var PlotUtil_instance = null;\n function PlotUtil_getInstance() {\n if (PlotUtil_instance === null) {\n new PlotUtil();\n }return PlotUtil_instance;\n }\n function PosProviderContext() {\n }\n PosProviderContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PosProviderContext',\n interfaces: []\n };\n function SvgLayerRenderer(myAesthetics, myGeom, myPos, myCoord, myGeomContext) {\n SvgComponent.call(this);\n this.myAesthetics_0 = myAesthetics;\n this.myGeom_0 = myGeom;\n this.myPos_0 = myPos;\n this.myCoord_0 = myCoord;\n this.myGeomContext_0 = myGeomContext;\n }\n SvgLayerRenderer.prototype.buildComponent = function () {\n this.buildLayer_0();\n };\n SvgLayerRenderer.prototype.buildLayer_0 = function () {\n this.myGeom_0.build_uzv8ab$(this, this.myAesthetics_0, this.myPos_0, this.myCoord_0, this.myGeomContext_0);\n };\n SvgLayerRenderer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgLayerRenderer',\n interfaces: [SvgRoot, SvgComponent]\n };\n function VarBinding(variable, aes) {\n this.variable = variable;\n this.aes = aes;\n }\n VarBinding.prototype.toString = function () {\n return 'VarBinding{variable=' + this.variable + ', aes=' + this.aes;\n };\n VarBinding.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, VarBinding) ? tmp$_0 : throwCCE();\n if (!equals(this.variable, other.variable))\n return false;\n if (!equals(this.aes, other.aes))\n return false;\n return true;\n };\n VarBinding.prototype.hashCode = function () {\n var result = hashCode(this.variable);\n result = (31 * result | 0) + hashCode(this.aes) | 0;\n return result;\n };\n VarBinding.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VarBinding',\n interfaces: []\n };\n function ColorBarAssembler(legendTitle, domain, scale, theme) {\n ColorBarAssembler$Companion_getInstance();\n this.legendTitle_0 = legendTitle;\n this.domain_0 = domain;\n this.scale_0 = scale;\n this.theme_0 = theme;\n this.colorBarOptions_0 = null;\n }\n function ColorBarAssembler$createColorBar$ObjectLiteral(closure$spec, size) {\n this.closure$spec = closure$spec;\n LegendBoxInfo.call(this, size);\n }\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype.createLegendBox = function () {\n var c = new ColorBarComponent(this.closure$spec);\n c.debug = ColorBarAssembler$Companion_getInstance().DEBUG_DRAWING_0;\n return c;\n };\n ColorBarAssembler$createColorBar$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n ColorBarAssembler.prototype.createColorBar = function () {\n var tmp$;\n var scale_0 = this.scale_0;\n if (!scale_0.hasBreaks()) {\n scale_0 = breaks.ScaleBreaksUtil.withBreaks_qt1l9m$(scale_0, this.domain_0, 5);\n }var guideBreaks = ArrayList_init();\n var breaks_0 = scale.ScaleUtil.breaksTransformed_x4zrm4$(scale_0);\n var label = scale.ScaleUtil.labels_x4zrm4$(scale_0).iterator();\n tmp$ = breaks_0.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n guideBreaks.add_11rb$(new GuideBreak(v, label.next()));\n }\n if (guideBreaks.isEmpty()) {\n return LegendBoxInfo$Companion_getInstance().EMPTY;\n }var spec = ColorBarAssembler$Companion_getInstance().createColorBarSpec_9i99xq$(this.legendTitle_0, this.domain_0, guideBreaks, scale_0, this.theme_0, this.colorBarOptions_0);\n return new ColorBarAssembler$createColorBar$ObjectLiteral(spec, spec.size);\n };\n ColorBarAssembler.prototype.setOptions_p8ufd2$ = function (options) {\n this.colorBarOptions_0 = options;\n };\n function ColorBarAssembler$Companion() {\n ColorBarAssembler$Companion_instance = this;\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().LEGEND_DEBUG_DRAWING;\n }\n ColorBarAssembler$Companion.prototype.createColorBarSpec_9i99xq$ = function (title, domain, breaks, scale, theme, options) {\n if (options === void 0)\n options = null;\n var tmp$, tmp$_0;\n var legendDirection = LegendAssemblerUtil_getInstance().legendDirection_730mk3$(theme);\n var horizontal = legendDirection === LegendDirection$HORIZONTAL_getInstance();\n var width = options != null ? options.width : null;\n var height = options != null ? options.height : null;\n var barSize = ColorBarComponentSpec$Companion_getInstance().barAbsoluteSize_kkcal5$(horizontal, theme);\n if (width != null) {\n barSize = new DoubleVector(width, barSize.y);\n }if (height != null) {\n barSize = new DoubleVector(barSize.x, height);\n }var reverse = !horizontal;\n if (horizontal)\n tmp$ = ColorBarComponentLayout$Companion_getInstance().horizontal_v3yhow$(title, domain, breaks, barSize, reverse);\n else\n tmp$ = ColorBarComponentLayout$Companion_getInstance().vertical_v3yhow$(title, domain, breaks, barSize, reverse);\n var layout = tmp$;\n return new ColorBarComponentSpec(title, domain, breaks, scale, (tmp$_0 = options != null ? options.binCount : null) != null ? tmp$_0 : 20, theme, layout, reverse);\n };\n ColorBarAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarAssembler$Companion_instance = null;\n function ColorBarAssembler$Companion_getInstance() {\n if (ColorBarAssembler$Companion_instance === null) {\n new ColorBarAssembler$Companion();\n }return ColorBarAssembler$Companion_instance;\n }\n ColorBarAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarAssembler',\n interfaces: []\n };\n function ColorBarOptions() {\n GuideOptions.call(this);\n this.width = null;\n this.height = null;\n this.binCount = null;\n }\n ColorBarOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarOptions',\n interfaces: [GuideOptions]\n };\n function GeomContextBuilder() {\n this.myAesthetics_0 = null;\n this.myAestheticMappers_0 = null;\n this.myGeomTargetCollector_0 = new NullGeomTargetCollector();\n }\n GeomContextBuilder.prototype.aesthetics_luqwb2$ = function (aesthetics) {\n this.myAesthetics_0 = aesthetics;\n return this;\n };\n GeomContextBuilder.prototype.aestheticMappers_4iu3o$ = function (aestheticMappers) {\n this.myAestheticMappers_0 = aestheticMappers;\n return this;\n };\n GeomContextBuilder.prototype.geomTargetCollector_xrq6q$ = function (geomTargetCollector) {\n this.myGeomTargetCollector_0 = geomTargetCollector;\n return this;\n };\n GeomContextBuilder.prototype.build = function () {\n return new GeomContextBuilder$MyGeomContext(this);\n };\n function GeomContextBuilder$MyGeomContext(b) {\n this.myAesthetics = b.myAesthetics_0;\n this.myAestheticMappers = b.myAestheticMappers_0;\n this.targetCollector_2hnek9$_0 = b.myGeomTargetCollector_0;\n }\n Object.defineProperty(GeomContextBuilder$MyGeomContext.prototype, 'targetCollector', {\n configurable: true,\n get: function () {\n return this.targetCollector_2hnek9$_0;\n }\n });\n GeomContextBuilder$MyGeomContext.prototype.getResolution_vktour$ = function (aes) {\n var resolution = 0.0;\n if (this.myAesthetics != null) {\n resolution = this.myAesthetics.resolution_594811$(aes, 0.0);\n }if (resolution <= data_0.SeriesUtil.TINY) {\n resolution = this.getUnitResolution_vktour$(aes);\n }return resolution;\n };\n GeomContextBuilder$MyGeomContext.prototype.getUnitResolution_vktour$ = function (aes) {\n var tmp$, tmp$_0, tmp$_1;\n var mapper = (tmp$_0 = (tmp$ = this.myAestheticMappers) != null ? tmp$.get_11rb$(aes) : null) != null ? tmp$_0 : scale.Mappers.IDENTITY;\n return typeof (tmp$_1 = mapper(1.0)) === 'number' ? tmp$_1 : throwCCE();\n };\n GeomContextBuilder$MyGeomContext.prototype.withTargetCollector_xrq6q$ = function (targetCollector) {\n return GeomContextBuilder_init().aesthetics_luqwb2$(this.myAesthetics).aestheticMappers_4iu3o$(this.myAestheticMappers).geomTargetCollector_xrq6q$(targetCollector).build();\n };\n GeomContextBuilder$MyGeomContext.prototype.with = function () {\n return GeomContextBuilder_init_0(this);\n };\n GeomContextBuilder$MyGeomContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyGeomContext',\n interfaces: [ImmutableGeomContext]\n };\n GeomContextBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomContextBuilder',\n interfaces: [ImmutableGeomContext$Builder]\n };\n function GeomContextBuilder_init($this) {\n $this = $this || Object.create(GeomContextBuilder.prototype);\n GeomContextBuilder.call($this);\n return $this;\n }\n function GeomContextBuilder_init_0(ctx, $this) {\n $this = $this || Object.create(GeomContextBuilder.prototype);\n GeomContextBuilder.call($this);\n $this.myAesthetics_0 = ctx.myAesthetics;\n $this.myAestheticMappers_0 = ctx.myAestheticMappers;\n return $this;\n }\n function GeomLayerBuilder() {\n GeomLayerBuilder$Companion_getInstance();\n this.myBindings_0 = ArrayList_init();\n this.myConstantByAes_0 = new TypedKeyHashMap();\n this.myStat_mcjcnw$_0 = this.myStat_mcjcnw$_0;\n this.myPosProvider_gzkpo7$_0 = this.myPosProvider_gzkpo7$_0;\n this.myGeomProvider_h6nr63$_0 = this.myGeomProvider_h6nr63$_0;\n this.myGroupingVarName_0 = null;\n this.myPathIdVarName_0 = null;\n this.myScaleProviderByAes_0 = HashMap_init();\n this.myDataPreprocessor_0 = null;\n this.myLocatorLookupSpec_0 = GeomTargetLocator$LookupSpec.Companion.NONE;\n this.myContextualMappingProvider_0 = ContextualMappingProvider$Companion_getInstance().NONE;\n this.myIsLegendDisabled_0 = false;\n }\n Object.defineProperty(GeomLayerBuilder.prototype, 'myStat_0', {\n configurable: true,\n get: function () {\n if (this.myStat_mcjcnw$_0 == null)\n return throwUPAE('myStat');\n return this.myStat_mcjcnw$_0;\n },\n set: function (myStat) {\n this.myStat_mcjcnw$_0 = myStat;\n }\n });\n Object.defineProperty(GeomLayerBuilder.prototype, 'myPosProvider_0', {\n configurable: true,\n get: function () {\n if (this.myPosProvider_gzkpo7$_0 == null)\n return throwUPAE('myPosProvider');\n return this.myPosProvider_gzkpo7$_0;\n },\n set: function (myPosProvider) {\n this.myPosProvider_gzkpo7$_0 = myPosProvider;\n }\n });\n Object.defineProperty(GeomLayerBuilder.prototype, 'myGeomProvider_0', {\n configurable: true,\n get: function () {\n if (this.myGeomProvider_h6nr63$_0 == null)\n return throwUPAE('myGeomProvider');\n return this.myGeomProvider_h6nr63$_0;\n },\n set: function (myGeomProvider) {\n this.myGeomProvider_h6nr63$_0 = myGeomProvider;\n }\n });\n GeomLayerBuilder.prototype.stat_qbwusa$ = function (v) {\n this.myStat_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.pos_r08v3h$ = function (v) {\n this.myPosProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.geom_9dfz59$ = function (v) {\n this.myGeomProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.addBinding_14cn14$ = function (v) {\n this.myBindings_0.add_11rb$(v);\n return this;\n };\n GeomLayerBuilder.prototype.groupingVar_8xm3sj$ = function (v) {\n this.myGroupingVarName_0 = v.name;\n return this;\n };\n GeomLayerBuilder.prototype.groupingVarName_61zpoe$ = function (v) {\n this.myGroupingVarName_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.pathIdVarName_61zpoe$ = function (v) {\n this.myPathIdVarName_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.addConstantAes_bbdhip$ = function (aes, v) {\n this.myConstantByAes_0.put_ev6mlr$(aes, v);\n return this;\n };\n GeomLayerBuilder.prototype.addScaleProvider_jv3qxe$ = function (aes, scaleProvider) {\n this.myScaleProviderByAes_0.put_xwzc9p$(aes, scaleProvider);\n return this;\n };\n GeomLayerBuilder.prototype.locatorLookupSpec_271kgc$ = function (v) {\n this.myLocatorLookupSpec_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.contextualMappingProvider_td8fxc$ = function (v) {\n this.myContextualMappingProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.disableLegend_6taknv$ = function (v) {\n this.myIsLegendDisabled_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.build_fhj1j$ = function (data_0, scaleMap) {\n var tmp$, tmp$_0;\n var data_1 = data_0;\n if (this.myDataPreprocessor_0 != null) {\n data_1 = ensureNotNull(this.myDataPreprocessor_0)(data_1, scaleMap);\n }data_1 = DataProcessing_getInstance().transformOriginals_si9pes$(data_1, this.myBindings_0, scaleMap);\n var $receiver = this.myBindings_0;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n var tmp$_2 = destination.add_11rb$;\n var tmp$_3, tmp$_4;\n tmp$_4 = item.aes;\n if (item.variable.isOrigin) {\n var transformVar = data.DataFrameUtil.transformVarFor_896ixz$(item.aes);\n tmp$_3 = new VarBinding(transformVar, item.aes);\n } else {\n tmp$_3 = item;\n }\n tmp$_2.call(destination, to(tmp$_4, tmp$_3));\n }\n var replacementBindings = HashMap_init_0(toMap(destination));\n var bindingsToPut = ArrayList_init();\n tmp$ = replacementBindings.values.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (variable.isStat) {\n var aes = binding.aes;\n var scale = scaleMap.get_31786j$(aes);\n data_1 = data.DataFrameUtil.applyTransform_xaiv89$(data_1, variable, aes, scale);\n bindingsToPut.add_11rb$(new VarBinding(data.TransformVar.forAes_896ixz$(aes), aes));\n }}\n tmp$_0 = bindingsToPut.iterator();\n while (tmp$_0.hasNext()) {\n var binding_0 = tmp$_0.next();\n var key = binding_0.aes;\n replacementBindings.put_xwzc9p$(key, binding_0);\n }\n var dataAccess = new PointDataAccess(data_1, replacementBindings, scaleMap);\n return new GeomLayerBuilder$MyGeomLayer(data_1, this.myGeomProvider_0, this.myPosProvider_0, this.myGeomProvider_0.renders(), (new GroupingContext(data_1, this.myBindings_0, this.myGroupingVarName_0, this.myPathIdVarName_0, this.handlesGroups_0())).groupMapper, replacementBindings.values, this.myConstantByAes_0, scaleMap, dataAccess, this.myLocatorLookupSpec_0, this.myContextualMappingProvider_0.createContextualMapping_8fr62e$(dataAccess, data_1), this.myIsLegendDisabled_0);\n };\n GeomLayerBuilder.prototype.handlesGroups_0 = function () {\n return this.myGeomProvider_0.handlesGroups() || this.myPosProvider_0.handlesGroups();\n };\n function GeomLayerBuilder$MyGeomLayer(dataFrame, geomProvider, myPosProvider, renderedAes, group, varBindings, constantByAes, scaleMap, dataAccess, locatorLookupSpec, contextualMapping, isLegendDisabled) {\n this.dataFrame_uc8k26$_0 = dataFrame;\n this.myPosProvider_0 = myPosProvider;\n this.group_btwr86$_0 = group;\n this.scaleMap_9lvzv7$_0 = scaleMap;\n this.dataAccess_qkhg5r$_0 = dataAccess;\n this.locatorLookupSpec_65qeye$_0 = locatorLookupSpec;\n this.contextualMapping_1qd07s$_0 = contextualMapping;\n this.isLegendDisabled_1bnyfg$_0 = isLegendDisabled;\n this.geom_ipep5v$_0 = geomProvider.createGeom();\n this.geomKind_qyi6z5$_0 = geomProvider.geomKind;\n this.aestheticsDefaults_4lnusm$_0 = null;\n this.myRenderedAes_0 = null;\n this.myConstantByAes_0 = null;\n this.myVarBindingsByAes_0 = HashMap_init();\n var tmp$, tmp$_0;\n this.myRenderedAes_0 = ArrayList_init_0(renderedAes);\n this.aestheticsDefaults_4lnusm$_0 = geomProvider.aestheticsDefaults();\n this.myConstantByAes_0 = new TypedKeyHashMap();\n tmp$ = constantByAes.keys_287e2$().iterator();\n while (tmp$.hasNext()) {\n var key = tmp$.next();\n this.myConstantByAes_0.put_ev6mlr$(key, constantByAes.get_ex36zt$(key));\n }\n tmp$_0 = varBindings.iterator();\n while (tmp$_0.hasNext()) {\n var varBinding = tmp$_0.next();\n var $receiver = this.myVarBindingsByAes_0;\n var key_0 = varBinding.aes;\n $receiver.put_xwzc9p$(key_0, varBinding);\n }\n }\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'dataFrame', {\n get: function () {\n return this.dataFrame_uc8k26$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'group', {\n get: function () {\n return this.group_btwr86$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'scaleMap', {\n get: function () {\n return this.scaleMap_9lvzv7$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'dataAccess', {\n get: function () {\n return this.dataAccess_qkhg5r$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'locatorLookupSpec', {\n get: function () {\n return this.locatorLookupSpec_65qeye$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'contextualMapping', {\n get: function () {\n return this.contextualMapping_1qd07s$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'isLegendDisabled', {\n get: function () {\n return this.isLegendDisabled_1bnyfg$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'geom', {\n configurable: true,\n get: function () {\n return this.geom_ipep5v$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'geomKind', {\n configurable: true,\n get: function () {\n return this.geomKind_qyi6z5$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'aestheticsDefaults', {\n configurable: true,\n get: function () {\n return this.aestheticsDefaults_4lnusm$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return this.geom.legendKeyElementFactory;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'isLiveMap', {\n configurable: true,\n get: function () {\n return Kotlin.isType(this.geom, LiveMapGeom);\n }\n });\n GeomLayerBuilder$MyGeomLayer.prototype.renderedAes = function () {\n return this.myRenderedAes_0;\n };\n GeomLayerBuilder$MyGeomLayer.prototype.createPos_q7kk9g$ = function (ctx) {\n return this.myPosProvider_0.createPos_q7kk9g$(ctx);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.hasBinding_896ixz$ = function (aes) {\n return this.myVarBindingsByAes_0.containsKey_11rb$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getBinding_31786j$ = function (aes) {\n return ensureNotNull(this.myVarBindingsByAes_0.get_11rb$(aes));\n };\n GeomLayerBuilder$MyGeomLayer.prototype.hasConstant_896ixz$ = function (aes) {\n return this.myConstantByAes_0.containsKey_ex36zt$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getConstant_31786j$ = function (aes) {\n if (!this.hasConstant_896ixz$(aes)) {\n var message = 'Constant value is not defined for aes ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }return this.myConstantByAes_0.get_ex36zt$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getDefault_31786j$ = function (aes) {\n return this.aestheticsDefaults.defaultValue_31786j$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return this.aestheticsDefaults.rangeIncludesZero_896ixz$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.setLiveMapProvider_kld0fp$ = function (liveMapProvider) {\n if (Kotlin.isType(this.geom, LiveMapGeom)) {\n this.geom.setLiveMapProvider_kld0fp$(liveMapProvider);\n } else {\n throw IllegalStateException_init('Not Livemap: ' + Kotlin.getKClassFromExpression(this.geom).simpleName);\n }\n };\n GeomLayerBuilder$MyGeomLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyGeomLayer',\n interfaces: [GeomLayer]\n };\n function GeomLayerBuilder$Companion() {\n GeomLayerBuilder$Companion_instance = this;\n }\n function GeomLayerBuilder$Companion$demoAndTest$lambda(closure$builder) {\n return function (data, scaleMap) {\n var transformedData = DataProcessing_getInstance().transformOriginals_si9pes$(data, closure$builder.myBindings_0, scaleMap);\n var stat_0 = closure$builder.myStat_0;\n if (equals(stat_0, stat.Stats.IDENTITY))\n return transformedData;\n else {\n var statCtx = new SimpleStatContext(transformedData);\n var groupingContext = new GroupingContext(transformedData, closure$builder.myBindings_0, closure$builder.myGroupingVarName_0, closure$builder.myPathIdVarName_0, true);\n var dataAndGroupingContext = DataProcessing_getInstance().buildStatData_x40e2x$(transformedData, stat_0, closure$builder.myBindings_0, scaleMap, groupingContext, PlotFacets$Companion_getInstance().undefined(), statCtx, emptyList(), emptyList(), null, getCallableRef('println', function (p1) {\n return println(p1), Unit;\n }));\n return dataAndGroupingContext.data;\n }\n };\n }\n GeomLayerBuilder$Companion.prototype.demoAndTest = function () {\n var builder = new GeomLayerBuilder();\n builder.myDataPreprocessor_0 = GeomLayerBuilder$Companion$demoAndTest$lambda(builder);\n return builder;\n };\n GeomLayerBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomLayerBuilder$Companion_instance = null;\n function GeomLayerBuilder$Companion_getInstance() {\n if (GeomLayerBuilder$Companion_instance === null) {\n new GeomLayerBuilder$Companion();\n }return GeomLayerBuilder$Companion_instance;\n }\n GeomLayerBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomLayerBuilder',\n interfaces: []\n };\n function GuideOptions() {\n GuideOptions$Companion_getInstance();\n this.isReverse = false;\n }\n function GuideOptions$Companion() {\n GuideOptions$Companion_instance = this;\n this.NONE = new GuideOptions$Companion$NONE$ObjectLiteral();\n }\n function GuideOptions$Companion$NONE$ObjectLiteral() {\n GuideOptions.call(this);\n }\n GuideOptions$Companion$NONE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [GuideOptions]\n };\n GuideOptions$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GuideOptions$Companion_instance = null;\n function GuideOptions$Companion_getInstance() {\n if (GuideOptions$Companion_instance === null) {\n new GuideOptions$Companion();\n }return GuideOptions$Companion_instance;\n }\n GuideOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideOptions',\n interfaces: []\n };\n function ImmutableGeomContext() {\n }\n function ImmutableGeomContext$Builder() {\n }\n ImmutableGeomContext$Builder.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Builder',\n interfaces: []\n };\n ImmutableGeomContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ImmutableGeomContext',\n interfaces: [GeomContext]\n };\n function LegendAssembler(legendTitle, guideOptionsMap, theme) {\n LegendAssembler$Companion_getInstance();\n this.legendTitle_0 = legendTitle;\n this.guideOptionsMap_0 = guideOptionsMap;\n this.theme_0 = theme;\n this.legendLayers_0 = ArrayList_init();\n }\n LegendAssembler.prototype.addLayer_446ka8$ = function (keyFactory, varBindings, constantByAes, aestheticsDefaults, scaleByAes, transformedDataRangeByAes) {\n this.legendLayers_0.add_11rb$(new LegendAssembler$LegendLayer(keyFactory, varBindings, constantByAes, aestheticsDefaults, scaleByAes, transformedDataRangeByAes));\n };\n function LegendAssembler$createLegend$ObjectLiteral(closure$spec, size) {\n this.closure$spec = closure$spec;\n LegendBoxInfo.call(this, size);\n }\n LegendAssembler$createLegend$ObjectLiteral.prototype.createLegendBox = function () {\n var c = new LegendComponent(this.closure$spec);\n c.debug = LegendAssembler$Companion_getInstance().DEBUG_DRAWING_0;\n return c;\n };\n LegendAssembler$createLegend$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n LegendAssembler.prototype.createLegend = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var legendBreaksByLabel = LinkedHashMap_init();\n tmp$ = this.legendLayers_0.iterator();\n while (tmp$.hasNext()) {\n var legendLayer = tmp$.next();\n var keyElementFactory = legendLayer.keyElementFactory_8be2vx$;\n var dataPoints = legendLayer.keyAesthetics_8be2vx$.dataPoints().iterator();\n tmp$_0 = legendLayer.keyLabels_8be2vx$.iterator();\n while (tmp$_0.hasNext()) {\n var label = tmp$_0.next();\n var tmp$_5;\n var value = legendBreaksByLabel.get_11rb$(label);\n if (value == null) {\n var answer = new LegendBreak(label);\n legendBreaksByLabel.put_xwzc9p$(label, answer);\n tmp$_5 = answer;\n } else {\n tmp$_5 = value;\n }\n tmp$_5.addLayer_w0u015$(dataPoints.next(), keyElementFactory);\n }\n }\n var legendBreaks = ArrayList_init();\n tmp$_1 = legendBreaksByLabel.values.iterator();\n while (tmp$_1.hasNext()) {\n var legendBreak = tmp$_1.next();\n if (legendBreak.isEmpty) {\n continue;\n }legendBreaks.add_11rb$(legendBreak);\n }\n if (legendBreaks.isEmpty()) {\n return LegendBoxInfo$Companion_getInstance().EMPTY;\n }var legendOptionsList = ArrayList_init();\n tmp$_2 = this.legendLayers_0.iterator();\n while (tmp$_2.hasNext()) {\n var legendLayer_0 = tmp$_2.next();\n var aesList = legendLayer_0.aesList_8be2vx$;\n tmp$_3 = aesList.iterator();\n while (tmp$_3.hasNext()) {\n var aes = tmp$_3.next();\n if (Kotlin.isType(this.guideOptionsMap_0.get_11rb$(aes), LegendOptions)) {\n legendOptionsList.add_11rb$(Kotlin.isType(tmp$_4 = this.guideOptionsMap_0.get_11rb$(aes), LegendOptions) ? tmp$_4 : throwCCE());\n }}\n }\n var spec = LegendAssembler$Companion_getInstance().createLegendSpec_esqxbx$(this.legendTitle_0, legendBreaks, this.theme_0, LegendOptions$Companion_getInstance().combine_pmdc6s$(legendOptionsList));\n return new LegendAssembler$createLegend$ObjectLiteral(spec, spec.size);\n };\n function LegendAssembler$LegendLayer(keyElementFactory, varBindings, constantByAes, aestheticsDefaults, scaleMap, transformedDataRangeByAes) {\n this.keyElementFactory_8be2vx$ = keyElementFactory;\n this.varBindings_0 = varBindings;\n this.constantByAes_0 = constantByAes;\n this.aestheticsDefaults_0 = aestheticsDefaults;\n this.scaleMap_0 = scaleMap;\n this.keyAesthetics_8be2vx$ = null;\n this.keyLabels_8be2vx$ = null;\n var tmp$, tmp$_0;\n var aesValuesByLabel = LinkedHashMap_init();\n tmp$ = this.varBindings_0.iterator();\n while (tmp$.hasNext()) {\n var varBinding = tmp$.next();\n var aes = varBinding.aes;\n var scale_0 = this.scaleMap_0.get_31786j$(aes);\n if (!scale_0.hasBreaks()) {\n scale_0 = breaks.ScaleBreaksUtil.withBreaks_qt1l9m$(scale_0, getValue(transformedDataRangeByAes, aes), 5);\n }if (!scale_0.hasBreaks()) {\n var message = 'No breaks were defined for scale ' + aes;\n throw IllegalStateException_init(message.toString());\n }var aesValues = scale.ScaleUtil.transformAndMap_syim1y$(scale_0.breaks, scale_0);\n var labels = scale.ScaleUtil.labels_x4zrm4$(scale_0);\n tmp$_0 = zip(labels, aesValues).iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_1 = tmp$_0.next();\n var label = tmp$_1.component1()\n , aesValue = tmp$_1.component2();\n var tmp$_2;\n var value = aesValuesByLabel.get_11rb$(label);\n if (value == null) {\n var answer = HashMap_init();\n aesValuesByLabel.put_xwzc9p$(label, answer);\n tmp$_2 = answer;\n } else {\n tmp$_2 = value;\n }\n var $receiver = tmp$_2;\n var value_0 = ensureNotNull(aesValue);\n $receiver.put_xwzc9p$(aes, value_0);\n }\n }\n this.keyAesthetics_8be2vx$ = LegendAssemblerUtil_getInstance().mapToAesthetics_8kbmqf$(aesValuesByLabel.values, this.constantByAes_0, this.aestheticsDefaults_0);\n this.keyLabels_8be2vx$ = ArrayList_init_0(aesValuesByLabel.keys);\n }\n Object.defineProperty(LegendAssembler$LegendLayer.prototype, 'aesList_8be2vx$', {\n configurable: true,\n get: function () {\n var $receiver = this.varBindings_0;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item.aes);\n }\n return destination;\n }\n });\n LegendAssembler$LegendLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendLayer',\n interfaces: []\n };\n function LegendAssembler$Companion() {\n LegendAssembler$Companion_instance = this;\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().LEGEND_DEBUG_DRAWING;\n }\n function LegendAssembler$Companion$createLegendSpec$pretty(v) {\n var margin = 1.0;\n var x = v.x / 2;\n var tmp$ = JsMath.floor(x) * 2 + 1.0 + margin;\n var x_0 = v.y / 2;\n return new DoubleVector(tmp$, JsMath.floor(x_0) * 2 + 1.0 + margin);\n }\n LegendAssembler$Companion.prototype.createLegendSpec_esqxbx$ = function (title, breaks, theme, options) {\n if (options === void 0)\n options = new LegendOptions();\n var tmp$, tmp$_0, tmp$_1;\n var legendDirection = LegendAssemblerUtil_getInstance().legendDirection_730mk3$(theme);\n var pretty = LegendAssembler$Companion$createLegendSpec$pretty;\n var keySize = new DoubleVector(theme.keySize(), theme.keySize());\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var minimumKeySize = br.minimumKeySize;\n keySize = keySize.max_gpjtzr$(pretty(minimumKeySize));\n }\n var breakCount = breaks.size;\n var colCount;\n var rowCount;\n if (options.isByRow) {\n if (options.hasColCount()) {\n var a = options.colCount;\n tmp$_0 = JsMath.min(a, breakCount);\n } else if (options.hasRowCount()) {\n var x = breakCount / options.rowCount;\n tmp$_0 = numberToInt(JsMath.ceil(x));\n } else if (legendDirection === LegendDirection$HORIZONTAL_getInstance())\n tmp$_0 = breakCount;\n else\n tmp$_0 = 1;\n colCount = tmp$_0;\n var x_0 = breakCount / colCount;\n rowCount = numberToInt(JsMath.ceil(x_0));\n } else {\n if (options.hasRowCount()) {\n var a_0 = options.rowCount;\n tmp$_1 = JsMath.min(a_0, breakCount);\n } else if (options.hasColCount()) {\n var x_1 = breakCount / options.colCount;\n tmp$_1 = numberToInt(JsMath.ceil(x_1));\n } else if (legendDirection !== LegendDirection$HORIZONTAL_getInstance())\n tmp$_1 = breakCount;\n else\n tmp$_1 = 1;\n rowCount = tmp$_1;\n var x_2 = breakCount / rowCount;\n colCount = numberToInt(JsMath.ceil(x_2));\n }\n var layout;\n if (legendDirection === LegendDirection$HORIZONTAL_getInstance()) {\n if (options.hasRowCount() || (options.hasColCount() && options.colCount < breakCount)) {\n layout = LegendComponentLayout$Companion_getInstance().horizontalMultiRow_2y8ibu$(title, breaks, keySize);\n } else {\n layout = LegendComponentLayout$Companion_getInstance().horizontal_2y8ibu$(title, breaks, keySize);\n }\n } else {\n layout = LegendComponentLayout$Companion_getInstance().vertical_2y8ibu$(title, breaks, keySize);\n }\n layout.colCount = colCount;\n layout.rowCount = rowCount;\n layout.isFillByRow = options.isByRow;\n return new LegendComponentSpec(title, breaks, theme, layout, false);\n };\n LegendAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendAssembler$Companion_instance = null;\n function LegendAssembler$Companion_getInstance() {\n if (LegendAssembler$Companion_instance === null) {\n new LegendAssembler$Companion();\n }return LegendAssembler$Companion_instance;\n }\n LegendAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendAssembler',\n interfaces: []\n };\n function LegendAssemblerUtil() {\n LegendAssemblerUtil_instance = this;\n }\n LegendAssemblerUtil.prototype.mapToAesthetics_ml5orx$ = function (valuesByAes, constantByAes, aestheticsDefaults) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var builder = new AestheticsBuilder(0);\n tmp$ = Aes.Companion.values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n builder.constantAes_bbdhip$(Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE(), aestheticsDefaults.defaultValue_31786j$(aes));\n }\n tmp$_1 = valuesByAes.keys.iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n var values = ensureNotNull(valuesByAes.get_11rb$(aes_0));\n builder.aes_u42xfl$(aes_0, AestheticsBuilder.Companion.collection_mqih57$(values));\n builder.dataPointCount_za3lpa$(values.size);\n }\n tmp$_2 = constantByAes.keys.iterator();\n while (tmp$_2.hasNext()) {\n var aes_1 = tmp$_2.next();\n builder.constantAes_bbdhip$(aes_1, ensureNotNull(constantByAes.get_11rb$(aes_1)));\n }\n return builder.build();\n };\n function LegendAssemblerUtil$mapToAesthetics$lambda(closure$dataPoints, closure$aes) {\n return function (index) {\n return ensureNotNull(closure$dataPoints.get_za3lpa$(index).get_11rb$(closure$aes));\n };\n }\n LegendAssemblerUtil.prototype.mapToAesthetics_8kbmqf$ = function (valueByAesIterable, constantByAes, aestheticsDefaults) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var dataPoints = ArrayList_init();\n tmp$ = valueByAesIterable.iterator();\n while (tmp$.hasNext()) {\n var valueByAes = tmp$.next();\n var dataPoint = HashMap_init();\n tmp$_0 = Aes.Companion.values().iterator();\n while (tmp$_0.hasNext()) {\n var aes = tmp$_0.next();\n var value = ensureNotNull(aestheticsDefaults.defaultValueInLegend_31786j$(aes));\n dataPoint.put_xwzc9p$(aes, value);\n }\n tmp$_1 = constantByAes.keys.iterator();\n while (tmp$_1.hasNext()) {\n var constantAes = tmp$_1.next();\n if (equals(constantAes, Aes.Companion.SHAPE) || equals(constantAes, Aes.Companion.COLOR) || equals(constantAes, Aes.Companion.FILL)) {\n var value_0 = ensureNotNull(constantByAes.get_11rb$(constantAes));\n dataPoint.put_xwzc9p$(constantAes, value_0);\n }}\n tmp$_2 = valueByAes.keys.iterator();\n while (tmp$_2.hasNext()) {\n var aes_0 = tmp$_2.next();\n var value_1 = ensureNotNull(valueByAes.get_11rb$(aes_0));\n dataPoint.put_xwzc9p$(aes_0, value_1);\n }\n dataPoints.add_11rb$(dataPoint);\n }\n var builder = new AestheticsBuilder(dataPoints.size);\n tmp$_3 = Aes.Companion.values().iterator();\n while (tmp$_3.hasNext()) {\n var aes_1 = tmp$_3.next();\n builder.aes_u42xfl$(Kotlin.isType(tmp$_4 = aes_1, Aes) ? tmp$_4 : throwCCE(), LegendAssemblerUtil$mapToAesthetics$lambda(dataPoints, aes_1));\n }\n return builder.build();\n };\n LegendAssemblerUtil.prototype.legendDirection_730mk3$ = function (theme) {\n var legendDirection = theme.direction();\n if (legendDirection === LegendDirection$AUTO_getInstance()) {\n var legendPosition = theme.position();\n legendDirection = legendPosition === LegendPosition$Companion_getInstance().TOP || legendPosition === LegendPosition$Companion_getInstance().BOTTOM ? LegendDirection$HORIZONTAL_getInstance() : LegendDirection$VERTICAL_getInstance();\n }return legendDirection;\n };\n LegendAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LegendAssemblerUtil',\n interfaces: []\n };\n var LegendAssemblerUtil_instance = null;\n function LegendAssemblerUtil_getInstance() {\n if (LegendAssemblerUtil_instance === null) {\n new LegendAssemblerUtil();\n }return LegendAssemblerUtil_instance;\n }\n function LegendOptions() {\n LegendOptions$Companion_getInstance();\n GuideOptions.call(this);\n this.myColCount_0 = null;\n this.myRowCount_0 = null;\n this.isByRow = false;\n }\n Object.defineProperty(LegendOptions.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myColCount_0);\n },\n set: function (colCount) {\n this.myColCount_0 = JsMath.max(1, colCount);\n }\n });\n Object.defineProperty(LegendOptions.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myRowCount_0);\n },\n set: function (rowCount) {\n this.myRowCount_0 = JsMath.max(1, rowCount);\n }\n });\n LegendOptions.prototype.hasColCount = function () {\n return this.myColCount_0 != null;\n };\n LegendOptions.prototype.hasRowCount = function () {\n return this.myRowCount_0 != null;\n };\n function LegendOptions$Companion() {\n LegendOptions$Companion_instance = this;\n }\n LegendOptions$Companion.prototype.combine_pmdc6s$ = function (optionsList) {\n var tmp$;\n var result = new LegendOptions();\n tmp$ = optionsList.iterator();\n while (tmp$.hasNext()) {\n var options = tmp$.next();\n if (options.isByRow) {\n result.isByRow = true;\n }if (options.hasColCount()) {\n result.colCount = options.colCount;\n }if (options.hasRowCount()) {\n result.rowCount = options.rowCount;\n }}\n return result;\n };\n LegendOptions$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendOptions$Companion_instance = null;\n function LegendOptions$Companion_getInstance() {\n if (LegendOptions$Companion_instance === null) {\n new LegendOptions$Companion();\n }return LegendOptions$Companion_instance;\n }\n LegendOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendOptions',\n interfaces: [GuideOptions]\n };\n function PlotAssembler(scaleByAes, layersByTile, myCoordProvider, myTheme) {\n PlotAssembler$Companion_getInstance();\n this.scaleByAes_0 = scaleByAes;\n this.layersByTile = layersByTile;\n this.myCoordProvider_0 = myCoordProvider;\n this.myTheme_0 = myTheme;\n this.containsLiveMap = false;\n this.facets = PlotFacets$Companion_getInstance().undefined();\n this.myTitle_0 = null;\n this.myGuideOptionsMap_0 = HashMap_init();\n this.myAxisEnabled_0 = false;\n this.myLegendsEnabled_0 = true;\n this.myInteractionsEnabled_0 = true;\n var $receiver = flatten(this.layersByTile);\n var predicate = getPropertyCallableRef('isLiveMap', 1, function ($receiver) {\n return $receiver.isLiveMap;\n });\n var any$result;\n any$break: do {\n var tmp$;\n if (Kotlin.isType($receiver, Collection) && $receiver.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (predicate(element)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n this.containsLiveMap = any$result;\n this.myAxisEnabled_0 = !this.containsLiveMap;\n }\n PlotAssembler.prototype.setTitle_pdl1vj$ = function (title) {\n this.myTitle_0 = title;\n };\n PlotAssembler.prototype.hasLayers_0 = function () {\n var tmp$;\n tmp$ = this.layersByTile.iterator();\n while (tmp$.hasNext()) {\n var tileLayers = tmp$.next();\n if (!tileLayers.isEmpty()) {\n return true;\n }}\n return false;\n };\n PlotAssembler.prototype.createPlot = function () {\n if (!this.hasLayers_0()) {\n var message = 'No layers in plot';\n throw IllegalStateException_init(message.toString());\n }var legendsBoxInfos = this.myLegendsEnabled_0 ? PlotAssemblerUtil_getInstance().createLegends_fyi7ho$(this.layersByTile, this.myGuideOptionsMap_0, this.myTheme_0.legend()) : emptyList();\n var xScaleProto = this.scaleByAes_0.get_31786j$(Aes.Companion.X);\n var yScaleProto = this.scaleByAes_0.get_31786j$(Aes.Companion.Y);\n if (this.containsLiveMap) {\n var plotLayout = PlotAssemblerUtil_getInstance().createPlotLayout_3sq5f9$(new LiveMapTileLayout(), this.facets);\n return this.createXYPlot_0(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos, true);\n }var tmp$ = PlotAssemblerUtil_getInstance().computePlotDryRunXYRanges_7yawgb$(this.layersByTile);\n var xDomain = tmp$.component1()\n , yDomain = tmp$.component2();\n var xAxisLayout;\n var yAxisLayout;\n if (this.myAxisEnabled_0) {\n xAxisLayout = PlotAxisLayout$Companion_getInstance().bottom_eknalg$(xScaleProto, xDomain, yDomain, this.myCoordProvider_0, this.myTheme_0.axisX());\n yAxisLayout = PlotAxisLayout$Companion_getInstance().left_eknalg$(yScaleProto, xDomain, yDomain, this.myCoordProvider_0, this.myTheme_0.axisY());\n } else {\n xAxisLayout = EmptyAxisLayout$Companion_getInstance().bottom_gyv40k$(xDomain, yDomain);\n yAxisLayout = EmptyAxisLayout$Companion_getInstance().left_gyv40k$(xDomain, yDomain);\n }\n var plotLayout_0 = PlotAssemblerUtil_getInstance().createPlotLayout_3sq5f9$(new XYPlotTileLayout(xAxisLayout, yAxisLayout), this.facets);\n if (!this.myAxisEnabled_0) {\n plotLayout_0.setPadding_6y0v78$(0.0, 0.0, 0.0, 0.0);\n }return this.createXYPlot_0(xScaleProto, yScaleProto, plotLayout_0, legendsBoxInfos);\n };\n PlotAssembler.prototype.createXYPlot_0 = function (xScaleProto, yScaleProto, plotLayout, legendBoxInfos, hasLiveMap) {\n if (hasLiveMap === void 0)\n hasLiveMap = false;\n var tmp$, tmp$_0;\n var plotBuilder = new PlotBuilder(this.myTheme_0);\n plotBuilder.setTitle_pdl1vj$(this.myTitle_0);\n plotBuilder.scaleXProto_iu85h4$(xScaleProto);\n plotBuilder.scaleYProto_iu85h4$(yScaleProto);\n plotBuilder.setAxisTitleBottom_61zpoe$(xScaleProto.name);\n plotBuilder.setAxisTitleLeft_61zpoe$(yScaleProto.name);\n plotBuilder.setCoordProvider_sdecqr$(this.myCoordProvider_0);\n tmp$ = legendBoxInfos.iterator();\n while (tmp$.hasNext()) {\n var legendBoxInfo = tmp$.next();\n plotBuilder.addLegendBoxInfo_29gouq$(legendBoxInfo);\n }\n tmp$_0 = this.layersByTile.iterator();\n while (tmp$_0.hasNext()) {\n var panelLayers = tmp$_0.next();\n plotBuilder.addTileLayers_relqli$(panelLayers);\n }\n plotBuilder.setPlotLayout_vjneqj$(plotLayout);\n plotBuilder.axisEnabled_6taknv$(this.myAxisEnabled_0);\n plotBuilder.interactionsEnabled_6taknv$(this.myInteractionsEnabled_0);\n plotBuilder.setLiveMap_6taknv$(hasLiveMap);\n return plotBuilder.build();\n };\n PlotAssembler.prototype.setGuideOptionsMap_qayxze$ = function (guideOptionsMap) {\n this.myGuideOptionsMap_0 = guideOptionsMap;\n };\n PlotAssembler.prototype.disableAxis = function () {\n this.myAxisEnabled_0 = false;\n };\n PlotAssembler.prototype.disableLegends = function () {\n this.myLegendsEnabled_0 = false;\n };\n PlotAssembler.prototype.disableInteractions = function () {\n this.myInteractionsEnabled_0 = false;\n };\n function PlotAssembler$Companion() {\n PlotAssembler$Companion_instance = this;\n }\n PlotAssembler$Companion.prototype.singleTile_wqghlj$ = function (scaleByAes, plotLayers, coordProvider, theme) {\n var layersByTile = ArrayList_init();\n layersByTile.add_11rb$(plotLayers);\n return this.multiTile_bm7ueq$(scaleByAes, layersByTile, coordProvider, theme);\n };\n PlotAssembler$Companion.prototype.multiTile_bm7ueq$ = function (scaleByAes, layersByTile, coordProvider, theme) {\n return new PlotAssembler(scaleByAes, layersByTile, coordProvider, theme);\n };\n PlotAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotAssembler$Companion_instance = null;\n function PlotAssembler$Companion_getInstance() {\n if (PlotAssembler$Companion_instance === null) {\n new PlotAssembler$Companion();\n }return PlotAssembler$Companion_instance;\n }\n PlotAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotAssembler',\n interfaces: []\n };\n function PlotAssemblerUtil() {\n PlotAssemblerUtil_instance = this;\n }\n PlotAssemblerUtil.prototype.updateAesRangeMap_0 = function (aes, range, rangeByAes) {\n var range_0 = range;\n if (range_0 != null) {\n var wasRange = rangeByAes.get_11rb$(aes);\n if (wasRange != null) {\n range_0 = wasRange.span_d226ot$(range_0);\n }var value = range_0;\n rangeByAes.put_xwzc9p$(aes, value);\n }};\n PlotAssemblerUtil.prototype.updateRange_0 = function (range, wasRange) {\n var range_0 = range;\n if (range_0 != null) {\n if (wasRange != null) {\n range_0 = wasRange.span_d226ot$(range_0);\n }return range_0;\n }return wasRange;\n };\n PlotAssemblerUtil.prototype.updateRange_1 = function (values, wasRange) {\n if (!collect.Iterables.isEmpty_fakr2g$(values)) {\n var newRange = ClosedRange.Companion.encloseAll_17hg47$(values);\n if (wasRange != null) {\n newRange = wasRange.span_d226ot$(newRange);\n }return newRange;\n }return wasRange;\n };\n PlotAssemblerUtil.prototype.createLegends_fyi7ho$ = function (layersByPanel, guideOptionsMap, theme) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var planeCount = 0;\n if (!layersByPanel.isEmpty()) {\n planeCount = layersByPanel.get_za3lpa$(0).size;\n }var stitchedLayersList = ArrayList_init();\n tmp$ = planeCount;\n for (var i = 0; i < tmp$; i++) {\n var layersOnPlane = ArrayList_init();\n tmp$_0 = layersByPanel.iterator();\n while (tmp$_0.hasNext()) {\n var panelLayers = tmp$_0.next();\n layersOnPlane.add_11rb$(panelLayers.get_za3lpa$(i));\n }\n stitchedLayersList.add_11rb$(new StitchedPlotLayers(layersOnPlane));\n }\n var transformedDataRangeByAes = HashMap_init();\n tmp$_1 = stitchedLayersList.iterator();\n while (tmp$_1.hasNext()) {\n var stitchedPlotLayers = tmp$_1.next();\n var layerTransformedDomainByAes = PlotGuidesAssemblerUtil_getInstance().guideTransformedDomainByAes_rf697z$(stitchedPlotLayers, guideOptionsMap);\n tmp$_2 = layerTransformedDomainByAes.entries.iterator();\n while (tmp$_2.hasNext()) {\n var tmp$_3 = tmp$_2.next();\n var aes = tmp$_3.key;\n var transformedDomain = tmp$_3.value;\n this.updateAesRangeMap_0(aes, transformedDomain, transformedDataRangeByAes);\n }\n }\n return this.createLegends_0(stitchedLayersList, transformedDataRangeByAes, guideOptionsMap, theme);\n };\n PlotAssemblerUtil.prototype.createLegends_0 = function (stitchedLayersList, transformedDataRangeByAes, guideOptionsMap, theme) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5, tmp$_6;\n var legendAssemblerByTitle = LinkedHashMap_init();\n var colorBarAssemblerByTitle = LinkedHashMap_init();\n tmp$ = stitchedLayersList.iterator();\n while (tmp$.hasNext()) {\n var stitchedLayers = tmp$.next();\n var layerConstantByAes = HashMap_init();\n tmp$_0 = stitchedLayers.renderedAes().iterator();\n while (tmp$_0.hasNext()) {\n var aes = tmp$_0.next();\n if (stitchedLayers.hasConstant_896ixz$(aes)) {\n var value = ensureNotNull(stitchedLayers.getConstant_31786j$(aes));\n layerConstantByAes.put_xwzc9p$(aes, value);\n }}\n var layerBindingsByScaleName = LinkedHashMap_init();\n var aesList = PlotGuidesAssemblerUtil_getInstance().mappedRenderedAesToCreateGuides_rf697z$(stitchedLayers, guideOptionsMap);\n tmp$_1 = aesList.iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n var colorBar = false;\n var binding = stitchedLayers.getBinding_896ixz$(aes_0);\n var scale = stitchedLayers.getScale_896ixz$(aes_0);\n var scaleName = scale.name;\n if (guideOptionsMap.containsKey_11rb$(aes_0)) {\n var guideOptions = guideOptionsMap.get_11rb$(aes_0);\n if (Kotlin.isType(guideOptions, ColorBarOptions)) {\n PlotGuidesAssemblerUtil_getInstance().checkFitsColorBar_k9b7d3$(binding.aes, scale);\n colorBar = true;\n var colorScale = Kotlin.isType(tmp$_2 = scale, Scale) ? tmp$_2 : throwCCE();\n var value_0 = PlotGuidesAssemblerUtil_getInstance().createColorBarAssembler_mzqjql$(scaleName, binding.aes, transformedDataRangeByAes, colorScale, guideOptions, theme);\n colorBarAssemblerByTitle.put_xwzc9p$(scaleName, value_0);\n }} else if (PlotGuidesAssemblerUtil_getInstance().fitsColorBar_k9b7d3$(binding.aes, scale)) {\n colorBar = true;\n var colorScale_0 = Kotlin.isType(tmp$_3 = scale, Scale) ? tmp$_3 : throwCCE();\n var value_1 = PlotGuidesAssemblerUtil_getInstance().createColorBarAssembler_mzqjql$(scaleName, binding.aes, transformedDataRangeByAes, colorScale_0, null, theme);\n colorBarAssemblerByTitle.put_xwzc9p$(scaleName, value_1);\n }if (!colorBar) {\n var tmp$_7;\n var value_2 = layerBindingsByScaleName.get_11rb$(scaleName);\n if (value_2 == null) {\n var answer = ArrayList_init();\n layerBindingsByScaleName.put_xwzc9p$(scaleName, answer);\n tmp$_7 = answer;\n } else {\n tmp$_7 = value_2;\n }\n tmp$_7.add_11rb$(binding);\n }}\n tmp$_4 = layerBindingsByScaleName.keys.iterator();\n while (tmp$_4.hasNext()) {\n var scaleName_0 = tmp$_4.next();\n var tmp$_8;\n var value_3 = legendAssemblerByTitle.get_11rb$(scaleName_0);\n if (value_3 == null) {\n var answer_0 = new LegendAssembler(scaleName_0, guideOptionsMap, theme);\n legendAssemblerByTitle.put_xwzc9p$(scaleName_0, answer_0);\n tmp$_8 = answer_0;\n } else {\n tmp$_8 = value_3;\n }\n var legendAssembler = tmp$_8;\n var varBindings = ensureNotNull(layerBindingsByScaleName.get_11rb$(scaleName_0));\n var legendKeyFactory = stitchedLayers.legendKeyElementFactory;\n var aestheticsDefaults = stitchedLayers.aestheticsDefaults;\n legendAssembler.addLayer_446ka8$(legendKeyFactory, varBindings, layerConstantByAes, aestheticsDefaults, stitchedLayers.getScaleMap(), transformedDataRangeByAes);\n }\n }\n var legendBoxInfos = ArrayList_init();\n tmp$_5 = colorBarAssemblerByTitle.keys.iterator();\n while (tmp$_5.hasNext()) {\n var legendTitle = tmp$_5.next();\n var boxInfo = ensureNotNull(colorBarAssemblerByTitle.get_11rb$(legendTitle)).createColorBar();\n if (!boxInfo.isEmpty) {\n legendBoxInfos.add_11rb$(boxInfo);\n }}\n tmp$_6 = legendAssemblerByTitle.keys.iterator();\n while (tmp$_6.hasNext()) {\n var legendTitle_0 = tmp$_6.next();\n var boxInfo_0 = ensureNotNull(legendAssemblerByTitle.get_11rb$(legendTitle_0)).createLegend();\n if (!boxInfo_0.isEmpty) {\n legendBoxInfos.add_11rb$(boxInfo_0);\n }}\n return legendBoxInfos;\n };\n PlotAssemblerUtil.prototype.createPlotLayout_3sq5f9$ = function (tileLayout, facets) {\n if (!facets.isDefined) {\n return new SingleTilePlotLayout(tileLayout);\n }return new FacetGridPlotLayout(facets, tileLayout);\n };\n function PlotAssemblerUtil$computePlotDryRunXYRanges$initialRange(this$PlotAssemblerUtil) {\n return function (scale_0) {\n var initialRange = null;\n if (scale_0.isContinuousDomain) {\n var tmp$ = this$PlotAssemblerUtil;\n var $receiver = toList(scale.ScaleUtil.transformedDefinedLimits_x4zrm4$(scale_0));\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (isFinite(element))\n destination.add_11rb$(element);\n }\n initialRange = tmp$.updateRange_1(destination, initialRange);\n }if (scale_0.hasBreaks()) {\n initialRange = this$PlotAssemblerUtil.updateRange_1(scale.ScaleUtil.breaksTransformed_x4zrm4$(scale_0), initialRange);\n }return initialRange;\n };\n }\n function PlotAssemblerUtil$computePlotDryRunXYRanges$layerRange(this$PlotAssemblerUtil) {\n return function (layer, aes, initialRange, aestheticsRange) {\n var range = this$PlotAssemblerUtil.updateRange_0(aestheticsRange, initialRange);\n range = PlotUtil_getInstance().rangeWithExpand_cmjc6r$(layer, aes, range);\n if (layer.rangeIncludesZero_896ixz$(aes)) {\n range = this$PlotAssemblerUtil.updateRange_0(ClosedRange.Companion.singleton_f1zjgi$(0.0), range);\n }return range;\n };\n }\n PlotAssemblerUtil.prototype.computePlotDryRunXYRanges_7yawgb$ = function (layersByTile) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var dryRunAestheticsByTileLayer = HashMap_init();\n tmp$ = layersByTile.iterator();\n while (tmp$.hasNext()) {\n var tileLayers = tmp$.next();\n tmp$_0 = tileLayers.iterator();\n while (tmp$_0.hasNext()) {\n var layer = tmp$_0.next();\n var aesthetics = PlotUtil_getInstance().createLayerDryRunAesthetics_sqg2xh$(layer);\n dryRunAestheticsByTileLayer.put_xwzc9p$(layer, aesthetics);\n }\n }\n var initialRange = PlotAssemblerUtil$computePlotDryRunXYRanges$initialRange(this);\n var scaleMap = layersByTile.get_za3lpa$(0).get_za3lpa$(0).scaleMap;\n var xInitialRange = initialRange(scaleMap.get_31786j$(Aes.Companion.X));\n var yInitialRange = initialRange(scaleMap.get_31786j$(Aes.Companion.Y));\n var layerRange = PlotAssemblerUtil$computePlotDryRunXYRanges$layerRange(this);\n var xRangeOverall = null;\n var yRangeOverall = null;\n tmp$_1 = layersByTile.iterator();\n while (tmp$_1.hasNext()) {\n var layers = tmp$_1.next();\n tmp$_2 = layers.iterator();\n while (tmp$_2.hasNext()) {\n var layer_0 = tmp$_2.next();\n var aesthetics_0 = getValue(dryRunAestheticsByTileLayer, layer_0);\n var xyRanges = PlotUtil_getInstance().computeLayerDryRunXYRanges_gl53zg$(layer_0, aesthetics_0);\n var xRangeLayer = layerRange(layer_0, Aes.Companion.X, xInitialRange, xyRanges.first);\n var yRangeLayer = layerRange(layer_0, Aes.Companion.Y, yInitialRange, xyRanges.second);\n xRangeOverall = this.updateRange_0(xRangeLayer, xRangeOverall);\n yRangeOverall = this.updateRange_0(yRangeLayer, yRangeOverall);\n }\n }\n xRangeOverall = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(xRangeOverall);\n yRangeOverall = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(yRangeOverall);\n return new Pair(xRangeOverall, yRangeOverall);\n };\n PlotAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotAssemblerUtil',\n interfaces: []\n };\n var PlotAssemblerUtil_instance = null;\n function PlotAssemblerUtil_getInstance() {\n if (PlotAssemblerUtil_instance === null) {\n new PlotAssemblerUtil();\n }return PlotAssemblerUtil_instance;\n }\n function PlotFacets() {\n PlotFacets$Companion_getInstance();\n }\n function PlotFacets$Companion() {\n PlotFacets$Companion_instance = this;\n this.DEF_ORDER_DIR = 1;\n this.DEF_FORMATTER = PlotFacets$Companion$DEF_FORMATTER$lambda;\n }\n PlotFacets$Companion.prototype.undefined = function () {\n return new FacetGrid(null, null, emptyList(), emptyList(), 1, 1);\n };\n PlotFacets$Companion.prototype.dataByLevelTuple_w4sfrb$ = function (data_1, varNames, varLevels) {\n var tmp$, tmp$_0, tmp$_1;\n var nameLevelTuples = this.createNameLevelTuples_5cxrh4$(varNames, varLevels);\n var destination = ArrayList_init_1(collectionSizeOrDefault(varNames, 10));\n var tmp$_2;\n tmp$_2 = varNames.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(data.DataFrameUtil.findVariableOrFail_vede35$(data_1, item));\n }\n var vars = destination;\n var indicesByVarByLevel = HashMap_init();\n var i = 0;\n for (var tmp$_3 = vars.iterator(); tmp$_3.hasNext(); ++i) {\n var variable = tmp$_3.next();\n var tmp$_4;\n var levels = varLevels.get_za3lpa$(i);\n var indicesByLevel = HashMap_init();\n tmp$_4 = levels.iterator();\n while (tmp$_4.hasNext()) {\n var level = tmp$_4.next();\n var indices = data_0.SeriesUtil.matchingIndices_3vukww$(data_1.get_8xm3sj$(variable), level);\n indicesByLevel.put_xwzc9p$(level, indices);\n }\n var key = variable.name;\n indicesByVarByLevel.put_xwzc9p$(key, indicesByLevel);\n }\n var dataByLevelKey = ArrayList_init();\n tmp$ = nameLevelTuples.iterator();\n while (tmp$.hasNext()) {\n var nameLevelTuple = tmp$.next();\n var topName = first(nameLevelTuple).first;\n var topLevel = first(nameLevelTuple).second;\n var indices_0 = ArrayList_init_0(getValue(getValue(indicesByVarByLevel, topName), topLevel));\n tmp$_0 = nameLevelTuple.size;\n for (var i_0 = 1; i_0 < tmp$_0; i_0++) {\n var name = nameLevelTuple.get_za3lpa$(i_0).first;\n var level_0 = nameLevelTuple.get_za3lpa$(i_0).second;\n var levelIndices = getValue(getValue(indicesByVarByLevel, name), level_0);\n indices_0.retainAll_brywnq$(HashSet_init(levelIndices));\n }\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(nameLevelTuple, 10));\n var tmp$_5;\n tmp$_5 = nameLevelTuple.iterator();\n while (tmp$_5.hasNext()) {\n var item_0 = tmp$_5.next();\n destination_0.add_11rb$(item_0.second);\n }\n var levelKey = destination_0;\n var b = DataFrame$DataFrame$Builder_init();\n var variables = data_1.variables();\n tmp$_1 = variables.iterator();\n while (tmp$_1.hasNext()) {\n var variable_0 = tmp$_1.next();\n var source = data_1.get_8xm3sj$(variable_0);\n var target = data_0.SeriesUtil.pickAtIndices_ge51dg$(source, indices_0);\n b.put_2l962d$(variable_0, target);\n }\n var levelData = b.build();\n dataByLevelKey.add_11rb$(to(levelKey, levelData));\n }\n return dataByLevelKey;\n };\n PlotFacets$Companion.prototype.createNameLevelTuples_5cxrh4$ = function (varNames, varLevels) {\n if (!!varNames.isEmpty()) {\n var message = 'Empty list of facet variables.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(varNames.size === distinct(varNames).size)) {\n var message_0 = 'Facet variables must be distinct, were: ' + varNames + '.';\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(varNames.size === varLevels.size)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }return this.createNameLevelTuplesIntern_0(varNames, varLevels);\n };\n PlotFacets$Companion.prototype.createNameLevelTuplesIntern_0 = function (varNames, varLevels) {\n var tmp$, tmp$_0;\n var name = first(varNames);\n var levels = first(varLevels);\n var levelKeys = ArrayList_init();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n if (varNames.size > 1) {\n var subKeys = this.createNameLevelTuples_5cxrh4$(varNames.subList_vux9f0$(1, varNames.size), varLevels.subList_vux9f0$(1, varLevels.size));\n tmp$_0 = subKeys.iterator();\n while (tmp$_0.hasNext()) {\n var subKey = tmp$_0.next();\n levelKeys.add_11rb$(plus(listOf(to(name, level)), subKey));\n }\n } else {\n levelKeys.add_11rb$(listOf(to(name, level)));\n }\n }\n return levelKeys;\n };\n PlotFacets$Companion.prototype.reorderLevels_dyo1lv$ = function (varNames, varLevels, ordering) {\n var orderingByFacet = toMap(zip(varNames, ordering));\n var result = ArrayList_init();\n var i = 0;\n for (var tmp$ = varNames.iterator(); tmp$.hasNext(); ++i) {\n var name = tmp$.next();\n if (i >= varLevels.size)\n break;\n result.add_11rb$(this.reorderVarLevels_pbdvt$(name, varLevels.get_za3lpa$(i), getValue(orderingByFacet, name)));\n }\n return result;\n };\n PlotFacets$Companion.prototype.reorderVarLevels_pbdvt$ = function (name, levels, order) {\n var tmp$, tmp$_0;\n if (name == null)\n return levels;\n Kotlin.isType(tmp$ = levels, List) ? tmp$ : throwCCE();\n if (order < 0)\n tmp$_0 = sortedDescending(levels);\n else\n tmp$_0 = sorted(levels);\n return tmp$_0;\n };\n function PlotFacets$Companion$DEF_FORMATTER$lambda(it) {\n return it.toString();\n }\n PlotFacets$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotFacets$Companion_instance = null;\n function PlotFacets$Companion_getInstance() {\n if (PlotFacets$Companion_instance === null) {\n new PlotFacets$Companion();\n }return PlotFacets$Companion_instance;\n }\n function PlotFacets$FacetTileInfo(col, row, colLabs, rowLab, xAxis, yAxis, trueIndex) {\n this.col = col;\n this.row = row;\n this.colLabs = colLabs;\n this.rowLab = rowLab;\n this.xAxis = xAxis;\n this.yAxis = yAxis;\n this.trueIndex = trueIndex;\n }\n PlotFacets$FacetTileInfo.prototype.toString = function () {\n return 'FacetTileInfo(col=' + this.col + ', row=' + this.row + ', colLabs=' + this.colLabs + ', rowLab=' + toString(this.rowLab) + ')';\n };\n PlotFacets$FacetTileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetTileInfo',\n interfaces: []\n };\n PlotFacets.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotFacets',\n interfaces: []\n };\n function PlotGuidesAssemblerUtil() {\n PlotGuidesAssemblerUtil_instance = this;\n }\n PlotGuidesAssemblerUtil.prototype.mappedRenderedAesToCreateGuides_rf697z$ = function (layerTiles, guideOptionsMap) {\n var tmp$;\n if (layerTiles.isLegendDisabled) {\n return emptyList();\n }var result = ArrayList_init();\n tmp$ = layerTiles.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (Aes.Companion.noGuideNeeded_896ixz$(aes)) {\n continue;\n }if (layerTiles.hasConstant_896ixz$(aes)) {\n continue;\n }if (!layerTiles.hasBinding_896ixz$(aes)) {\n continue;\n }if (guideOptionsMap.containsKey_11rb$(aes)) {\n if (guideOptionsMap.get_11rb$(aes) === GuideOptions$Companion_getInstance().NONE) {\n continue;\n }}result.add_11rb$(aes);\n }\n return result;\n };\n PlotGuidesAssemblerUtil.prototype.guideTransformedDomainByAes_rf697z$ = function (stitchedLayers, guideOptionsMap) {\n var tmp$, tmp$_0;\n var transformedDomainByAes = HashMap_init();\n var aesSet = this.mappedRenderedAesToCreateGuides_rf697z$(stitchedLayers, guideOptionsMap);\n tmp$ = aesSet.iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var transformVariable = stitchedLayers.getBinding_896ixz$(aes).variable;\n if (!transformVariable.isTransform) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }var transformedDataRange = stitchedLayers.getDataRange_8xm3sj$(transformVariable);\n if (transformedDataRange != null) {\n var scale_0 = stitchedLayers.getScale_896ixz$(aes);\n if (scale_0.isContinuousDomain && scale_0.hasDomainLimits()) {\n var tmp$_1 = scale.ScaleUtil.transformedDefinedLimits_x4zrm4$(scale_0);\n var scaleLower = tmp$_1.component1()\n , scaleUpper = tmp$_1.component2();\n var lowerEnd = isFinite(scaleLower) ? scaleLower : transformedDataRange.lowerEnd;\n var upperEnd = isFinite(scaleUpper) ? scaleUpper : transformedDataRange.upperEnd;\n tmp$_0 = new ClosedRange(lowerEnd, upperEnd);\n } else {\n tmp$_0 = transformedDataRange;\n }\n var transformedDomain = tmp$_0;\n transformedDomainByAes.put_xwzc9p$(aes, transformedDomain);\n }}\n return transformedDomainByAes;\n };\n PlotGuidesAssemblerUtil.prototype.createColorBarAssembler_mzqjql$ = function (scaleName, aes, dataRangeByAes, scale_0, options, theme) {\n var domain = dataRangeByAes.get_11rb$(aes);\n var domainWithLims = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(data_0.SeriesUtil.ensureApplicableRange_4am1sd$(domain), scale_0.domainLimits.first, scale_0.domainLimits.second, scale_0.transform);\n var result = new ColorBarAssembler(scaleName, data_0.SeriesUtil.ensureApplicableRange_4am1sd$(domainWithLims), scale_0, theme);\n result.setOptions_p8ufd2$(options);\n return result;\n };\n PlotGuidesAssemblerUtil.prototype.fitsColorBar_k9b7d3$ = function (aes, scale) {\n return aes.isColor && scale.isContinuous;\n };\n PlotGuidesAssemblerUtil.prototype.checkFitsColorBar_k9b7d3$ = function (aes, scale) {\n if (!aes.isColor) {\n var message = 'Color-bar is not applicable to ' + aes + ' aesthetic';\n throw IllegalStateException_init(message.toString());\n }if (!scale.isContinuous) {\n var message_0 = 'Color-bar is only applicable when both domain and color palette are continuous';\n throw IllegalStateException_init(message_0.toString());\n }};\n PlotGuidesAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotGuidesAssemblerUtil',\n interfaces: []\n };\n var PlotGuidesAssemblerUtil_instance = null;\n function PlotGuidesAssemblerUtil_getInstance() {\n if (PlotGuidesAssemblerUtil_instance === null) {\n new PlotGuidesAssemblerUtil();\n }return PlotGuidesAssemblerUtil_instance;\n }\n function PosProvider() {\n PosProvider$Companion_getInstance();\n }\n function PosProvider$Companion() {\n PosProvider$Companion_instance = this;\n }\n function PosProvider$Companion$wrap$ObjectLiteral(closure$pos) {\n this.closure$pos = closure$pos;\n PosProvider.call(this);\n }\n PosProvider$Companion$wrap$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return this.closure$pos;\n };\n PosProvider$Companion$wrap$ObjectLiteral.prototype.handlesGroups = function () {\n return this.closure$pos.handlesGroups();\n };\n PosProvider$Companion$wrap$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.wrap_dkjclg$ = function (pos) {\n return new PosProvider$Companion$wrap$ObjectLiteral(pos);\n };\n function PosProvider$Companion$barStack$ObjectLiteral() {\n PosProvider.call(this);\n }\n PosProvider$Companion$barStack$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.stack_4vnpmn$(ctx.aesthetics, PositionAdjustments$StackingStrategy.SPLIT_POSITIVE_NEGATIVE);\n };\n PosProvider$Companion$barStack$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.STACK.handlesGroups();\n };\n PosProvider$Companion$barStack$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.barStack = function () {\n return new PosProvider$Companion$barStack$ObjectLiteral();\n };\n function PosProvider$Companion$dodge$ObjectLiteral(closure$width) {\n this.closure$width = closure$width;\n PosProvider.call(this);\n }\n PosProvider$Companion$dodge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n var aesthetics = ctx.aesthetics;\n var groupCount = ctx.groupCount;\n return pos.PositionAdjustments.dodge_vvhcz8$(aesthetics, groupCount, this.closure$width);\n };\n PosProvider$Companion$dodge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.DODGE.handlesGroups();\n };\n PosProvider$Companion$dodge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.dodge_yrwdxb$ = function (width) {\n if (width === void 0)\n width = null;\n return new PosProvider$Companion$dodge$ObjectLiteral(width);\n };\n function PosProvider$Companion$fill$ObjectLiteral() {\n PosProvider.call(this);\n }\n PosProvider$Companion$fill$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.fill_m7huy5$(ctx.aesthetics);\n };\n PosProvider$Companion$fill$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.FILL.handlesGroups();\n };\n PosProvider$Companion$fill$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.fill = function () {\n return new PosProvider$Companion$fill$ObjectLiteral();\n };\n function PosProvider$Companion$jitter$ObjectLiteral(closure$width, closure$height) {\n this.closure$width = closure$width;\n this.closure$height = closure$height;\n PosProvider.call(this);\n }\n PosProvider$Companion$jitter$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.jitter_jma9l8$(this.closure$width, this.closure$height);\n };\n PosProvider$Companion$jitter$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.JITTER.handlesGroups();\n };\n PosProvider$Companion$jitter$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.jitter_jma9l8$ = function (width, height) {\n return new PosProvider$Companion$jitter$ObjectLiteral(width, height);\n };\n function PosProvider$Companion$nudge$ObjectLiteral(closure$width, closure$height) {\n this.closure$width = closure$width;\n this.closure$height = closure$height;\n PosProvider.call(this);\n }\n PosProvider$Companion$nudge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.nudge_jma9l8$(this.closure$width, this.closure$height);\n };\n PosProvider$Companion$nudge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.NUDGE.handlesGroups();\n };\n PosProvider$Companion$nudge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.nudge_jma9l8$ = function (width, height) {\n return new PosProvider$Companion$nudge$ObjectLiteral(width, height);\n };\n function PosProvider$Companion$jitterDodge$ObjectLiteral(closure$width, closure$jitterWidth, closure$jitterHeight) {\n this.closure$width = closure$width;\n this.closure$jitterWidth = closure$jitterWidth;\n this.closure$jitterHeight = closure$jitterHeight;\n PosProvider.call(this);\n }\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n var aesthetics = ctx.aesthetics;\n var groupCount = ctx.groupCount;\n return pos.PositionAdjustments.jitterDodge_e2pc44$(aesthetics, groupCount, this.closure$width, this.closure$jitterWidth, this.closure$jitterHeight);\n };\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.JITTER_DODGE.handlesGroups();\n };\n PosProvider$Companion$jitterDodge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.jitterDodge_xjrefz$ = function (width, jitterWidth, jitterHeight) {\n return new PosProvider$Companion$jitterDodge$ObjectLiteral(width, jitterWidth, jitterHeight);\n };\n PosProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PosProvider$Companion_instance = null;\n function PosProvider$Companion_getInstance() {\n if (PosProvider$Companion_instance === null) {\n new PosProvider$Companion();\n }return PosProvider$Companion_instance;\n }\n PosProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PosProvider',\n interfaces: []\n };\n function StitchedPlotLayers(layers) {\n this.myLayers_0 = null;\n this.myLayers_0 = ArrayList_init_0(layers);\n }\n Object.defineProperty(StitchedPlotLayers.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).legendKeyElementFactory;\n }\n });\n Object.defineProperty(StitchedPlotLayers.prototype, 'aestheticsDefaults', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).aestheticsDefaults;\n }\n });\n Object.defineProperty(StitchedPlotLayers.prototype, 'isLegendDisabled', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).isLegendDisabled;\n }\n });\n StitchedPlotLayers.prototype.renderedAes = function () {\n var tmp$;\n if (this.myLayers_0.isEmpty()) {\n tmp$ = emptyList();\n } else\n tmp$ = this.myLayers_0.get_za3lpa$(0).renderedAes();\n return tmp$;\n };\n StitchedPlotLayers.prototype.hasBinding_896ixz$ = function (aes) {\n return !this.myLayers_0.isEmpty() && this.myLayers_0.get_za3lpa$(0).hasBinding_896ixz$(aes);\n };\n StitchedPlotLayers.prototype.hasConstant_896ixz$ = function (aes) {\n return !this.myLayers_0.isEmpty() && this.myLayers_0.get_za3lpa$(0).hasConstant_896ixz$(aes);\n };\n StitchedPlotLayers.prototype.getConstant_31786j$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).getConstant_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getBinding_896ixz$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).getBinding_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getScale_896ixz$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).scaleMap.get_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getScaleMap = function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).scaleMap;\n };\n StitchedPlotLayers.prototype.getDataRange_8xm3sj$ = function (var_0) {\n var tmp$;\n if (!this.isNumericData_8xm3sj$(var_0)) {\n var message = 'Not numeric data [' + var_0 + ']';\n throw IllegalStateException_init(message.toString());\n }var result = null;\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var range = layer.dataFrame.range_8xm3sj$(var_0);\n result = data_0.SeriesUtil.span_t7esj2$(result, range);\n }\n return result;\n };\n StitchedPlotLayers.prototype.isNumericData_8xm3sj$ = function (var_0) {\n var tmp$;\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n if (!layer.dataFrame.isNumeric_8xm3sj$(var_0)) {\n return false;\n }}\n return true;\n };\n StitchedPlotLayers.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StitchedPlotLayers',\n interfaces: []\n };\n function TypedScaleMap(map) {\n TypedScaleMap$Companion_getInstance();\n this.myMap_0 = toMap_0(map);\n }\n function TypedScaleMap$get$lambda$lambda(closure$message) {\n return function () {\n return closure$message;\n };\n }\n TypedScaleMap.prototype.get_31786j$ = function (aes) {\n var tmp$, tmp$_0;\n var tmp$_1;\n if ((tmp$_0 = Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), Scale) ? tmp$ : null) != null)\n tmp$_1 = tmp$_0;\n else {\n var message = 'No scale found for aes: ' + aes;\n TypedScaleMap$Companion_getInstance().LOG_0.error_l35kib$(IllegalStateException_init(message), TypedScaleMap$get$lambda$lambda(message));\n throw IllegalStateException_init(message.toString());\n }\n return tmp$_1;\n };\n TypedScaleMap.prototype.containsKey_896ixz$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n TypedScaleMap.prototype.keySet = function () {\n return this.myMap_0.keys;\n };\n function TypedScaleMap$Companion() {\n TypedScaleMap$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(TypedScaleMap));\n }\n TypedScaleMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TypedScaleMap$Companion_instance = null;\n function TypedScaleMap$Companion_getInstance() {\n if (TypedScaleMap$Companion_instance === null) {\n new TypedScaleMap$Companion();\n }return TypedScaleMap$Companion_instance;\n }\n TypedScaleMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedScaleMap',\n interfaces: []\n };\n function TypedScaleProviderMap(map) {\n this.myMap_0 = toMap_0(map);\n }\n TypedScaleProviderMap.prototype.get_31786j$ = function (aes) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), ScaleProvider) ? tmp$ : throwCCE();\n };\n TypedScaleProviderMap.prototype.containsKey_896ixz$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n TypedScaleProviderMap.prototype.keySet = function () {\n return this.myMap_0.keys;\n };\n TypedScaleProviderMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedScaleProviderMap',\n interfaces: []\n };\n function FacetGrid(xVar, yVar, xLevels, yLevels, xOrder, yOrder, xFormatter, yFormatter) {\n if (xFormatter === void 0)\n xFormatter = PlotFacets$Companion_getInstance().DEF_FORMATTER;\n if (yFormatter === void 0)\n yFormatter = PlotFacets$Companion_getInstance().DEF_FORMATTER;\n PlotFacets.call(this);\n this.xVar_0 = xVar;\n this.yVar_0 = yVar;\n this.xFormatter_0 = xFormatter;\n this.yFormatter_0 = yFormatter;\n this.isDefined_f95yff$_0 = this.xVar_0 != null || this.yVar_0 != null;\n this.xLevels_0 = PlotFacets$Companion_getInstance().reorderVarLevels_pbdvt$(this.xVar_0, xLevels, xOrder);\n this.yLevels_0 = PlotFacets$Companion_getInstance().reorderVarLevels_pbdvt$(this.yVar_0, yLevels, yOrder);\n var b = xLevels.size;\n this.colCount_bhcvpt$_0 = JsMath.max(1, b);\n var b_0 = yLevels.size;\n this.rowCount_8ohw8b$_0 = JsMath.max(1, b_0);\n this.numTiles_kasr4x$_0 = Kotlin.imul(this.colCount, this.rowCount);\n }\n Object.defineProperty(FacetGrid.prototype, 'isDefined', {\n configurable: true,\n get: function () {\n return this.isDefined_f95yff$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_bhcvpt$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_8ohw8b$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'numTiles', {\n configurable: true,\n get: function () {\n return this.numTiles_kasr4x$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'variables', {\n configurable: true,\n get: function () {\n return listOfNotNull([this.xVar_0, this.yVar_0]);\n }\n });\n FacetGrid.prototype.dataByTile_dhhkv7$ = function (data) {\n var tmp$;\n var tmp$_0, tmp$_1, tmp$_2;\n if (!this.isDefined) {\n var message = 'dataByTile() called on Undefined plot facets.';\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = listOfNotNull([this.xVar_0, this.yVar_0]);\n tmp$_0 = listOfNotNull([this.xVar_0 != null ? this.xLevels_0 : null, this.yVar_0 != null ? this.yLevels_0 : null]);\n var dataByLevelTupleList = PlotFacets$Companion_getInstance().dataByLevelTuple_w4sfrb$(data, tmp$, tmp$_0);\n var dataByLevelTuple = toMap(dataByLevelTupleList);\n var $receiver = this.xLevels_0;\n var colLevels = $receiver.isEmpty() ? listOf(null) : $receiver;\n var $receiver_0 = this.yLevels_0;\n var rowLevels = $receiver_0.isEmpty() ? listOf(null) : $receiver_0;\n var dataByTile = ArrayList_init();\n tmp$_1 = rowLevels.iterator();\n while (tmp$_1.hasNext()) {\n var rowLevel = tmp$_1.next();\n tmp$_2 = colLevels.iterator();\n while (tmp$_2.hasNext()) {\n var colLevel = tmp$_2.next();\n var levelTuple = listOfNotNull([colLevel, rowLevel]);\n var tileData = getValue(dataByLevelTuple, levelTuple);\n dataByTile.add_11rb$(tileData);\n }\n }\n return dataByTile;\n };\n FacetGrid.prototype.tileInfos = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var $receiver = this.xLevels_0;\n var $receiver_0 = $receiver.isEmpty() ? listOf(null) : $receiver;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_4;\n tmp$_4 = $receiver_0.iterator();\n while (tmp$_4.hasNext()) {\n var item = tmp$_4.next();\n destination.add_11rb$(item != null ? this.xFormatter_0(item) : null);\n }\n var colLabels = destination;\n var $receiver_1 = this.yLevels_0;\n var $receiver_2 = $receiver_1.isEmpty() ? listOf(null) : $receiver_1;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault($receiver_2, 10));\n var tmp$_5;\n tmp$_5 = $receiver_2.iterator();\n while (tmp$_5.hasNext()) {\n var item_0 = tmp$_5.next();\n destination_0.add_11rb$(item_0 != null ? this.yFormatter_0(item_0) : null);\n }\n var rowLabels = destination_0;\n var infos = ArrayList_init();\n tmp$ = this.rowCount;\n for (var row = 0; row < tmp$; row++) {\n var addColLab = row === 0;\n var hasXAxis = row === (this.rowCount - 1 | 0);\n tmp$_0 = this.colCount;\n for (var col = 0; col < tmp$_0; col++) {\n var addRowLab = col === (this.colCount - 1 | 0);\n var hasYAxis = col === 0;\n if (addColLab) {\n tmp$_3 = (tmp$_2 = (tmp$_1 = colLabels.get_za3lpa$(col)) != null ? listOf(tmp$_1) : null) != null ? tmp$_2 : emptyList();\n } else {\n tmp$_3 = emptyList();\n }\n var colLabs = tmp$_3;\n infos.add_11rb$(new PlotFacets$FacetTileInfo(col, row, colLabs, addRowLab ? rowLabels.get_za3lpa$(row) : null, hasXAxis, hasYAxis, infos.size));\n }\n }\n return infos;\n };\n FacetGrid.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetGrid',\n interfaces: [PlotFacets]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n var thenBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (this$thenBy, closure$selector) {\n return function (a, b) {\n var previousCompare = this$thenBy.compare(a, b);\n var tmp$;\n if (previousCompare !== 0)\n tmp$ = previousCompare;\n else {\n var selector = closure$selector;\n tmp$ = compareValues(selector(a), selector(b));\n }\n return tmp$;\n };\n };\n });\n function FacetWrap(facets, levels, nrow, ncol, direction, facetOrdering, facetFormatters) {\n FacetWrap$Companion_getInstance();\n PlotFacets.call(this);\n this.facets_0 = facets;\n this.nrow_0 = nrow;\n this.ncol_0 = ncol;\n this.direction_0 = direction;\n this.facetFormatters_0 = facetFormatters;\n this.isDefined_lws8hd$_0 = true;\n this.levels_0 = PlotFacets$Companion_getInstance().reorderLevels_dyo1lv$(this.facets_0, levels, facetOrdering);\n this.numTiles_a1ir1h$_0 = FacetWrap$Companion_getInstance().numTiles_0(this.facets_0, levels);\n this.shape_0 = FacetWrap$Companion_getInstance().shape_0(this.numTiles, this.ncol_0, this.nrow_0, this.direction_0);\n this.colCount_182vmd$_0 = this.shape_0.first;\n this.rowCount_1ks3v5$_0 = this.shape_0.second;\n this.variables_i11eyv$_0 = this.facets_0;\n }\n Object.defineProperty(FacetWrap.prototype, 'isDefined', {\n configurable: true,\n get: function () {\n return this.isDefined_lws8hd$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'numTiles', {\n configurable: true,\n get: function () {\n return this.numTiles_a1ir1h$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_182vmd$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_1ks3v5$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'variables', {\n configurable: true,\n get: function () {\n return this.variables_i11eyv$_0;\n }\n });\n FacetWrap.prototype.dataByTile_dhhkv7$ = function (data) {\n var tmp$;\n var dataByLevelTuple = PlotFacets$Companion_getInstance().dataByLevelTuple_w4sfrb$(data, this.variables, this.levels_0);\n var dataByTile = ArrayList_init();\n tmp$ = dataByLevelTuple.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var tileData = tmp$_0.component2();\n dataByTile.add_11rb$(tileData);\n }\n return dataByTile;\n };\n function FacetWrap$tileInfos$toCol(this$FacetWrap) {\n return function (index) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = index % this$FacetWrap.colCount;\n break;\n case 'V':\n tmp$ = index / this$FacetWrap.rowCount | 0;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$toRow(this$FacetWrap) {\n return function (index) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = index / this$FacetWrap.colCount | 0;\n break;\n case 'V':\n tmp$ = index % this$FacetWrap.rowCount;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$toIndex(this$FacetWrap) {\n return function (col, row) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = Kotlin.imul(row, this$FacetWrap.colCount) + col | 0;\n break;\n case 'V':\n tmp$ = Kotlin.imul(col, this$FacetWrap.rowCount) + row | 0;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$isBottom(closure$toIndex, this$FacetWrap) {\n return function (col, row) {\n var nextRowIndex = closure$toIndex(col, row + 1 | 0);\n return (row + 1 | 0) % this$FacetWrap.rowCount === 0 || nextRowIndex >= this$FacetWrap.numTiles;\n };\n }\n function FacetWrap$tileInfos$lambda(it) {\n return it.row;\n }\n function FacetWrap$tileInfos$lambda_0(it) {\n return it.col;\n }\n FacetWrap.prototype.tileInfos = function () {\n var levelTuples = PlotFacets$Companion_getInstance().createNameLevelTuples_5cxrh4$(this.facets_0, this.levels_0);\n var destination = ArrayList_init_1(collectionSizeOrDefault(levelTuples, 10));\n var tmp$;\n tmp$ = levelTuples.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(item, 10));\n var tmp$_1;\n tmp$_1 = item.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n destination_0.add_11rb$(item_0.second);\n }\n tmp$_0.call(destination, destination_0);\n }\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item_1 = tmp$_2.next();\n var tmp$_3 = destination_1.add_11rb$;\n var destination_2 = ArrayList_init_1(collectionSizeOrDefault(item_1, 10));\n var tmp$_4, tmp$_0_0;\n var index = 0;\n tmp$_4 = item_1.iterator();\n while (tmp$_4.hasNext()) {\n var item_2 = tmp$_4.next();\n destination_2.add_11rb$(this.facetFormatters_0.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index, index = tmp$_0_0 + 1 | 0, tmp$_0_0)))(item_2));\n }\n tmp$_3.call(destination_1, destination_2);\n }\n var tileLabels = destination_1;\n var toCol = FacetWrap$tileInfos$toCol(this);\n var toRow = FacetWrap$tileInfos$toRow(this);\n var toIndex = FacetWrap$tileInfos$toIndex(this);\n var isBottom = FacetWrap$tileInfos$isBottom(toIndex, this);\n var infos = ArrayList_init();\n var i = 0;\n for (var tmp$_5 = tileLabels.iterator(); tmp$_5.hasNext(); ++i) {\n var tileLabelTuple = tmp$_5.next();\n var col = toCol(i);\n var row = toRow(i);\n var hasXAxis = isBottom(col, row);\n var hasYAxis = col === 0;\n infos.add_11rb$(new PlotFacets$FacetTileInfo(col, row, tileLabelTuple, null, hasXAxis, hasYAxis, i));\n }\n return sortedWith(infos, new Comparator(thenBy$lambda(new Comparator(compareBy$lambda(FacetWrap$tileInfos$lambda)), FacetWrap$tileInfos$lambda_0)));\n };\n function FacetWrap$Direction(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function FacetWrap$Direction_initFields() {\n FacetWrap$Direction_initFields = function () {\n };\n FacetWrap$Direction$H_instance = new FacetWrap$Direction('H', 0);\n FacetWrap$Direction$V_instance = new FacetWrap$Direction('V', 1);\n }\n var FacetWrap$Direction$H_instance;\n function FacetWrap$Direction$H_getInstance() {\n FacetWrap$Direction_initFields();\n return FacetWrap$Direction$H_instance;\n }\n var FacetWrap$Direction$V_instance;\n function FacetWrap$Direction$V_getInstance() {\n FacetWrap$Direction_initFields();\n return FacetWrap$Direction$V_instance;\n }\n FacetWrap$Direction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Direction',\n interfaces: [Enum]\n };\n function FacetWrap$Direction$values() {\n return [FacetWrap$Direction$H_getInstance(), FacetWrap$Direction$V_getInstance()];\n }\n FacetWrap$Direction.values = FacetWrap$Direction$values;\n function FacetWrap$Direction$valueOf(name) {\n switch (name) {\n case 'H':\n return FacetWrap$Direction$H_getInstance();\n case 'V':\n return FacetWrap$Direction$V_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.assemble.facet.FacetWrap.Direction.' + name);\n }\n }\n FacetWrap$Direction.valueOf_61zpoe$ = FacetWrap$Direction$valueOf;\n function FacetWrap$Companion() {\n FacetWrap$Companion_instance = this;\n }\n FacetWrap$Companion.prototype.numTiles_0 = function (facets, levels) {\n if (!!facets.isEmpty()) {\n var message = 'List of facets is empty.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(distinct(facets).size === facets.size)) {\n var message_0 = 'Duplicated values in the facets list: ' + facets;\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(facets.size === levels.size)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }return PlotFacets$Companion_getInstance().createNameLevelTuples_5cxrh4$(facets, levels).size;\n };\n function FacetWrap$Companion$shape$lambda(closure$ncol) {\n return function () {\n return \"'ncol' must be positive, was \" + toString(closure$ncol);\n };\n }\n function FacetWrap$Companion$shape$lambda_0(closure$nrow) {\n return function () {\n return \"'nrow' must be positive, was \" + toString(closure$nrow);\n };\n }\n FacetWrap$Companion.prototype.shape_0 = function (tilesCount, ncol, nrow, dir) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!((tmp$ = ncol != null ? ncol > 0 : null) != null ? tmp$ : true)) {\n var message = FacetWrap$Companion$shape$lambda(ncol)();\n throw IllegalArgumentException_init(message.toString());\n }if (!((tmp$_0 = nrow != null ? nrow > 0 : null) != null ? tmp$_0 : true)) {\n var message_0 = FacetWrap$Companion$shape$lambda_0(nrow)();\n throw IllegalArgumentException_init(message_0.toString());\n }if (ncol != null) {\n var ncolActual = JsMath.min(ncol, tilesCount);\n var x = tilesCount / ncolActual;\n var nrowActual = numberToInt(JsMath.ceil(x));\n tmp$_1 = to(ncolActual, JsMath.max(1, nrowActual));\n } else if (nrow != null) {\n var nrowActual_0 = JsMath.min(nrow, tilesCount);\n var x_0 = tilesCount / nrowActual_0;\n var ncolActual_0 = numberToInt(JsMath.ceil(x_0));\n tmp$_1 = to(ncolActual_0, JsMath.max(1, nrowActual_0));\n } else {\n var b = tilesCount / 2 | 0;\n var b_0 = JsMath.max(1, b);\n var w = JsMath.min(4, b_0);\n var x_1 = tilesCount / w;\n var b_1 = numberToInt(JsMath.ceil(x_1));\n var h = JsMath.max(1, b_1);\n tmp$_1 = to(w, h);\n }\n var shape = tmp$_1;\n var w_0 = shape.component1()\n , h_0 = shape.component2();\n switch (dir.name) {\n case 'H':\n var x_2 = tilesCount / w_0;\n tmp$_2 = new Pair_0(w_0, numberToInt(JsMath.ceil(x_2)));\n break;\n case 'V':\n var x_3 = tilesCount / h_0;\n tmp$_2 = new Pair_0(numberToInt(JsMath.ceil(x_3)), h_0);\n break;\n default:tmp$_2 = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$_2;\n };\n FacetWrap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FacetWrap$Companion_instance = null;\n function FacetWrap$Companion_getInstance() {\n if (FacetWrap$Companion_instance === null) {\n new FacetWrap$Companion();\n }return FacetWrap$Companion_instance;\n }\n FacetWrap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetWrap',\n interfaces: [PlotFacets]\n };\n function DefaultSampling() {\n DefaultSampling_instance = this;\n this.SEED_0 = L37;\n this.SAFETY_SAMPLING = Samplings_getInstance().random_280ow0$(200000, this.SEED_0);\n this.POINT = Samplings_getInstance().random_280ow0$(50000, this.SEED_0);\n this.TILE = Samplings_getInstance().random_280ow0$(50000, this.SEED_0);\n this.BIN_2D = this.TILE;\n this.AB_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.H_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.V_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.JITTER = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.RECT = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.SEGMENT = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.TEXT = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.ERROR_BAR = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.CROSS_BAR = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.LINE_RANGE = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.POINT_RANGE = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.BAR = Samplings_getInstance().pick_za3lpa$(50);\n this.HISTOGRAM = Samplings_getInstance().systematic_za3lpa$(500);\n this.LINE = Samplings_getInstance().systematic_za3lpa$(5000);\n this.RIBBON = Samplings_getInstance().systematic_za3lpa$(5000);\n this.AREA = Samplings_getInstance().systematic_za3lpa$(5000);\n this.DENSITY = Samplings_getInstance().systematic_za3lpa$(5000);\n this.FREQPOLY = Samplings_getInstance().systematic_za3lpa$(5000);\n this.STEP = Samplings_getInstance().systematic_za3lpa$(5000);\n this.PATH = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.POLYGON = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.MAP = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.SMOOTH = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.CONTOUR = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.CONTOURF = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.DENSITY2D = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.DENSITY2DF = Samplings_getInstance().systematicGroup_za3lpa$(200);\n }\n DefaultSampling.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultSampling',\n interfaces: []\n };\n var DefaultSampling_instance = null;\n function DefaultSampling_getInstance() {\n if (DefaultSampling_instance === null) {\n new DefaultSampling();\n }return DefaultSampling_instance;\n }\n function GeomProvider(geomKind) {\n GeomProvider$Companion_getInstance();\n this.geomKind = geomKind;\n }\n Object.defineProperty(GeomProvider.prototype, 'preferredCoordinateSystem', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('No preferred coordinate system');\n }\n });\n GeomProvider.prototype.renders = function () {\n return base_0.GeomMeta.renders_7dhqpi$(this.geomKind);\n };\n function GeomProvider$GeomProviderBuilder(myKind, myAestheticsDefaults, myHandlesGroups, myGeomSupplier) {\n this.myKind_0 = myKind;\n this.myAestheticsDefaults_0 = myAestheticsDefaults;\n this.myHandlesGroups_0 = myHandlesGroups;\n this.myGeomSupplier_0 = myGeomSupplier;\n }\n function GeomProvider$GeomProviderBuilder$build$ObjectLiteral(this$GeomProviderBuilder, geomKind) {\n this.this$GeomProviderBuilder = this$GeomProviderBuilder;\n GeomProvider.call(this, geomKind);\n }\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.createGeom = function () {\n return this.this$GeomProviderBuilder.myGeomSupplier_0();\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.aestheticsDefaults = function () {\n return this.this$GeomProviderBuilder.myAestheticsDefaults_0;\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.handlesGroups = function () {\n return this.this$GeomProviderBuilder.myHandlesGroups_0;\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [GeomProvider]\n };\n GeomProvider$GeomProviderBuilder.prototype.build_8be2vx$ = function () {\n return new GeomProvider$GeomProviderBuilder$build$ObjectLiteral(this, this.myKind_0);\n };\n GeomProvider$GeomProviderBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomProviderBuilder',\n interfaces: []\n };\n function GeomProvider$Companion() {\n GeomProvider$Companion_instance = this;\n }\n function GeomProvider$Companion$point$lambda() {\n return new PointGeom();\n }\n GeomProvider$Companion.prototype.point = function () {\n return this.point_8j1y0m$(GeomProvider$Companion$point$lambda);\n };\n GeomProvider$Companion.prototype.point_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POINT, AestheticsDefaults.Companion.point(), PointGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$path$lambda() {\n return new PathGeom();\n }\n GeomProvider$Companion.prototype.path = function () {\n return this.path_8j1y0m$(GeomProvider$Companion$path$lambda);\n };\n GeomProvider$Companion.prototype.path_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.PATH, AestheticsDefaults.Companion.path(), PathGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$line$lambda() {\n return new LineGeom();\n }\n GeomProvider$Companion.prototype.line = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LINE, AestheticsDefaults.Companion.line(), LineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$line$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$smooth$lambda() {\n return new SmoothGeom();\n }\n GeomProvider$Companion.prototype.smooth = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.SMOOTH, AestheticsDefaults.Companion.smooth(), SmoothGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$smooth$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$bar$lambda() {\n return new BarGeom();\n }\n GeomProvider$Companion.prototype.bar = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BAR, AestheticsDefaults.Companion.bar(), BarGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$bar$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$histogram$lambda() {\n return new HistogramGeom();\n }\n GeomProvider$Companion.prototype.histogram = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.HISTOGRAM, AestheticsDefaults.Companion.histogram(), HistogramGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$histogram$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$tile$lambda() {\n return new TileGeom();\n }\n GeomProvider$Companion.prototype.tile = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.TILE, AestheticsDefaults.Companion.tile(), TileGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$tile$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$bin2d$lambda() {\n return new Bin2dGeom();\n }\n GeomProvider$Companion.prototype.bin2d = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BIN_2D, AestheticsDefaults.Companion.bin2d(), Bin2dGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$bin2d$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$errorBar$lambda() {\n return new ErrorBarGeom();\n }\n GeomProvider$Companion.prototype.errorBar = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.ERROR_BAR, AestheticsDefaults.Companion.errorBar(), ErrorBarGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$errorBar$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.crossBar_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CROSS_BAR, AestheticsDefaults.Companion.crossBar(), CrossBarGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$lineRange$lambda() {\n return new LineRangeGeom();\n }\n GeomProvider$Companion.prototype.lineRange = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LINE_RANGE, AestheticsDefaults.Companion.lineRange(), LineRangeGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$lineRange$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.pointRange_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POINT_RANGE, AestheticsDefaults.Companion.pointRange(), PointRangeGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$contour$lambda() {\n return new ContourGeom();\n }\n GeomProvider$Companion.prototype.contour = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CONTOUR, AestheticsDefaults.Companion.contour(), ContourGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$contour$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$contourf$lambda() {\n return new ContourfGeom();\n }\n GeomProvider$Companion.prototype.contourf = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CONTOURF, AestheticsDefaults.Companion.contourf(), ContourfGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$contourf$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$polygon$lambda() {\n return new PolygonGeom();\n }\n GeomProvider$Companion.prototype.polygon = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POLYGON, AestheticsDefaults.Companion.polygon(), PolygonGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$polygon$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$map$lambda() {\n return new MapGeom();\n }\n GeomProvider$Companion.prototype.map = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.MAP, AestheticsDefaults.Companion.map(), MapGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$map$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$abline$lambda() {\n return new ABLineGeom();\n }\n GeomProvider$Companion.prototype.abline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.AB_LINE, AestheticsDefaults.Companion.abline(), ABLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$abline$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$hline$lambda() {\n return new HLineGeom();\n }\n GeomProvider$Companion.prototype.hline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.H_LINE, AestheticsDefaults.Companion.hline(), HLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$hline$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$vline$lambda() {\n return new VLineGeom();\n }\n GeomProvider$Companion.prototype.vline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.V_LINE, AestheticsDefaults.Companion.vline(), VLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$vline$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.boxplot_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BOX_PLOT, AestheticsDefaults.Companion.boxplot(), BoxplotGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$livemap$lambda(closure$options) {\n return function () {\n return new LiveMapGeom(closure$options.displayMode);\n };\n }\n GeomProvider$Companion.prototype.livemap_d2y5pu$ = function (options) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LIVE_MAP, AestheticsDefaults.Companion.livemap_cx3y7u$(options.displayMode), LiveMapGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$livemap$lambda(options))).build_8be2vx$();\n };\n function GeomProvider$Companion$ribbon$lambda() {\n return new RibbonGeom();\n }\n GeomProvider$Companion.prototype.ribbon = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RIBBON, AestheticsDefaults.Companion.ribbon(), RibbonGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$ribbon$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$area$lambda() {\n return new AreaGeom();\n }\n GeomProvider$Companion.prototype.area = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.AREA, AestheticsDefaults.Companion.area(), AreaGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$area$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density$lambda() {\n return new DensityGeom();\n }\n GeomProvider$Companion.prototype.density = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY, AestheticsDefaults.Companion.density(), DensityGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density2d$lambda() {\n return new Density2dGeom();\n }\n GeomProvider$Companion.prototype.density2d = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY2D, AestheticsDefaults.Companion.density2d(), Density2dGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density2d$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density2df$lambda() {\n return new Density2dfGeom();\n }\n GeomProvider$Companion.prototype.density2df = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY2DF, AestheticsDefaults.Companion.density2df(), Density2dfGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density2df$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$jitter$lambda() {\n return new JitterGeom();\n }\n GeomProvider$Companion.prototype.jitter = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.JITTER, AestheticsDefaults.Companion.jitter(), JitterGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$jitter$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$freqpoly$lambda() {\n return new FreqpolyGeom();\n }\n GeomProvider$Companion.prototype.freqpoly = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.FREQPOLY, AestheticsDefaults.Companion.freqpoly(), FreqpolyGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$freqpoly$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.step_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.STEP, AestheticsDefaults.Companion.step(), StepGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$rect$lambda() {\n return new RectGeom();\n }\n GeomProvider$Companion.prototype.rect = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RECT, AestheticsDefaults.Companion.rect(), RectGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$rect$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.segment_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.SEGMENT, AestheticsDefaults.Companion.segment(), SegmentGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.text_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.TEXT, AestheticsDefaults.Companion.text(), TextGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$raster$lambda() {\n return new RasterGeom();\n }\n GeomProvider$Companion.prototype.raster = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RASTER, AestheticsDefaults.Companion.raster(), RasterGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$raster$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.image_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.IMAGE, AestheticsDefaults.Companion.image(), ImageGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n GeomProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomProvider$Companion_instance = null;\n function GeomProvider$Companion_getInstance() {\n if (GeomProvider$Companion_instance === null) {\n new GeomProvider$Companion();\n }return GeomProvider$Companion_instance;\n }\n GeomProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomProvider',\n interfaces: []\n };\n function PointDataAccess(data, bindings, scaleMap) {\n this.data_0 = data;\n this.mappedAes_tolgcu$_0 = HashSet_init(bindings.keys);\n this.scaleByAes_c9kkhw$_0 = PointDataAccess$scaleByAes$lambda(scaleMap);\n this.myBindings_0 = toMap_0(bindings);\n this.myFormatters_0 = HashMap_init();\n }\n Object.defineProperty(PointDataAccess.prototype, 'mappedAes', {\n configurable: true,\n get: function () {\n return this.mappedAes_tolgcu$_0;\n }\n });\n Object.defineProperty(PointDataAccess.prototype, 'scaleByAes', {\n configurable: true,\n get: function () {\n return this.scaleByAes_c9kkhw$_0;\n }\n });\n PointDataAccess.prototype.isMapped_896ixz$ = function (aes) {\n return this.myBindings_0.containsKey_11rb$(aes);\n };\n PointDataAccess.prototype.getMappedData_pkitv1$ = function (aes, index) {\n var originalValue = this.getOriginalValue_pkitv1$(aes, index);\n var scale = this.getScale_0(aes);\n var value = this.formatter_0(aes)(originalValue);\n return new MappedDataAccess$MappedData(scale.name, value, scale.isContinuous);\n };\n PointDataAccess.prototype.getOriginalValue_pkitv1$ = function (aes, index) {\n if (!this.isMapped_896ixz$(aes)) {\n var message = 'Not mapped: ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }var binding = getValue(this.myBindings_0, aes);\n var scale = this.getScale_0(aes);\n var value = this.data_0.getNumeric_8xm3sj$(binding.variable).get_za3lpa$(index);\n return scale.transform.applyInverse_yrwdxb$(value);\n };\n PointDataAccess.prototype.getMappedDataLabel_896ixz$ = function (aes) {\n return this.getScale_0(aes).name;\n };\n PointDataAccess.prototype.isMappedDataContinuous_896ixz$ = function (aes) {\n return this.getScale_0(aes).isContinuous;\n };\n PointDataAccess.prototype.getScale_0 = function (aes) {\n return this.scaleByAes(aes);\n };\n PointDataAccess.prototype.formatter_0 = function (aes) {\n var scale = this.getScale_0(aes);\n var $receiver = this.myFormatters_0;\n var tmp$;\n var value = $receiver.get_11rb$(aes);\n if (value == null) {\n var answer = this.createFormatter_0(aes, scale);\n $receiver.put_xwzc9p$(aes, answer);\n tmp$ = answer;\n } else {\n tmp$ = value;\n }\n return tmp$;\n };\n function PointDataAccess$createFormatter$lambda(closure$formatter) {\n return function (value) {\n var tmp$;\n var tmp$_0;\n tmp$_0 = value != null ? closure$formatter(value) : null;\n return (tmp$ = tmp$_0) != null ? tmp$ : 'n/a';\n };\n }\n function PointDataAccess$createFormatter$lambda_0(closure$labelsMap) {\n return function (value) {\n var tmp$;\n var tmp$_0;\n tmp$_0 = value != null ? getValue(closure$labelsMap, value) : null;\n return (tmp$ = tmp$_0) != null ? tmp$ : 'n/a';\n };\n }\n PointDataAccess.prototype.createFormatter_0 = function (aes, scale_0) {\n if (scale_0.isContinuousDomain) {\n var $receiver = getValue(this.myBindings_0, aes).variable;\n var $receiver_0 = getCallableRef('range', function ($receiver, p1) {\n return $receiver.range_8xm3sj$(p1);\n }.bind(null, this.data_0))($receiver);\n var domain = data_0.SeriesUtil.ensureApplicableRange_4am1sd$($receiver_0);\n var formatter = scale_0.breaksGenerator.labelFormatter_1tlvto$(domain, 100);\n return PointDataAccess$createFormatter$lambda(formatter);\n } else {\n var labelsMap = scale.ScaleUtil.labelByBreak_x4zrm4$(scale_0);\n return PointDataAccess$createFormatter$lambda_0(labelsMap);\n }\n };\n function PointDataAccess$scaleByAes$lambda(closure$scaleMap) {\n return function (it) {\n return closure$scaleMap.get_31786j$(it);\n };\n }\n PointDataAccess.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointDataAccess',\n interfaces: [MappedDataAccess]\n };\n function CartesianCoordProvider(xLim, yLim) {\n CoordProviderBase.call(this, xLim, yLim);\n }\n CartesianCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CartesianCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function CoordProvider() {\n }\n CoordProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CoordProvider',\n interfaces: []\n };\n function CoordProviderBase(xLim, yLim) {\n CoordProviderBase$Companion_getInstance();\n this.xLim_0 = xLim;\n this.yLim_0 = yLim;\n }\n CoordProviderBase.prototype.buildAxisScaleX_hcz7zd$ = function (scaleProto, domain, axisLength, breaks) {\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_0(scaleProto, domain, axisLength, breaks);\n };\n CoordProviderBase.prototype.buildAxisScaleY_hcz7zd$ = function (scaleProto, domain, axisLength, breaks) {\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_0(scaleProto, domain, axisLength, breaks);\n };\n CoordProviderBase.prototype.createCoordinateSystem_uncllg$ = function (xDomain, xAxisLength, yDomain, yAxisLength) {\n var tmp$, tmp$_0;\n var mapperX = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(xDomain, xAxisLength);\n var mapperY = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(yDomain, yAxisLength);\n return coord.Coords.create_wd6eaa$(scale.MapperUtil.map_rejkqi$(xDomain, mapperX), scale.MapperUtil.map_rejkqi$(yDomain, mapperY), (tmp$ = this.xLim_0) != null ? scale.MapperUtil.map_rejkqi$(tmp$, mapperX) : null, (tmp$_0 = this.yLim_0) != null ? scale.MapperUtil.map_rejkqi$(tmp$_0, mapperY) : null);\n };\n CoordProviderBase.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var tmp$, tmp$_0;\n return new Pair((tmp$ = this.xLim_0) != null ? tmp$ : xDomain, (tmp$_0 = this.yLim_0) != null ? tmp$_0 : yDomain);\n };\n function CoordProviderBase$Companion() {\n CoordProviderBase$Companion_instance = this;\n }\n CoordProviderBase$Companion.prototype.linearMapper_mdyssk$ = function (domain, axisLength) {\n return scale.Mappers.mul_mdyssk$(domain, axisLength);\n };\n CoordProviderBase$Companion.prototype.buildAxisScaleDefault_0 = function (scaleProto, domain, axisLength, breaks) {\n return this.buildAxisScaleDefault_8w5bx$(scaleProto, this.linearMapper_mdyssk$(domain, axisLength), breaks);\n };\n CoordProviderBase$Companion.prototype.buildAxisScaleDefault_8w5bx$ = function (scaleProto, axisMapper, breaks) {\n return scaleProto.with().breaks_pqjuzw$(breaks.domainValues).labels_mhpeer$(breaks.labels).mapper_1uitho$(axisMapper).build();\n };\n CoordProviderBase$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CoordProviderBase$Companion_instance = null;\n function CoordProviderBase$Companion_getInstance() {\n if (CoordProviderBase$Companion_instance === null) {\n new CoordProviderBase$Companion();\n }return CoordProviderBase$Companion_instance;\n }\n CoordProviderBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CoordProviderBase',\n interfaces: [CoordProvider]\n };\n function CoordProviders() {\n CoordProviders_instance = this;\n }\n CoordProviders.prototype.cartesian_t7esj2$ = function (xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new CartesianCoordProvider(xLim, yLim);\n };\n CoordProviders.prototype.fixed_vvp5j4$ = function (ratio, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new FixedRatioCoordProvider(ratio, xLim, yLim);\n };\n CoordProviders.prototype.map_t7esj2$ = function (xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new ProjectionCoordProvider(new MercatorProjectionX(), new MercatorProjectionY(), xLim, yLim);\n };\n CoordProviders.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CoordProviders',\n interfaces: []\n };\n var CoordProviders_instance = null;\n function CoordProviders_getInstance() {\n if (CoordProviders_instance === null) {\n new CoordProviders();\n }return CoordProviders_instance;\n }\n function FixedRatioCoordProvider(ratio, xLim, yLim) {\n CoordProviderBase.call(this, xLim, yLim);\n this.ratio_0 = ratio;\n }\n FixedRatioCoordProvider.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var adjusted = CoordProviderBase.prototype.adjustDomains_jz8wgn$.call(this, xDomain, yDomain, displaySize);\n var xDomain_0 = adjusted.first;\n var yDomain_0 = adjusted.second;\n var spanX = data_0.SeriesUtil.span_4fzjta$(xDomain_0);\n var spanY = data_0.SeriesUtil.span_4fzjta$(yDomain_0);\n if (spanX < data_0.SeriesUtil.TINY || spanY < data_0.SeriesUtil.TINY) {\n return new Pair(xDomain_0, yDomain_0);\n }var displayW = displaySize.x;\n var displayH = displaySize.y;\n if (this.ratio_0 > 1) {\n displayW *= this.ratio_0;\n } else {\n displayH *= 1 / this.ratio_0;\n }\n var ratioX = spanX / displayW;\n var ratioY = spanY / displayH;\n if (ratioX > ratioY) {\n var spanAdjusted = displayH * ratioX;\n yDomain_0 = data_0.SeriesUtil.expand_mdyssk$(yDomain_0, spanAdjusted);\n } else {\n var spanAdjusted_0 = displayW * ratioY;\n xDomain_0 = data_0.SeriesUtil.expand_mdyssk$(xDomain_0, spanAdjusted_0);\n }\n return new Pair(xDomain_0, yDomain_0);\n };\n FixedRatioCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FixedRatioCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function ProjectionCoordProvider(projectionX, projectionY, xLim, yLim) {\n ProjectionCoordProvider$Companion_getInstance();\n CoordProviderBase.call(this, xLim, yLim);\n this.projectionX_0 = projectionX;\n this.projectionY_0 = projectionY;\n }\n ProjectionCoordProvider.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var tmp$;\n var adjusted = CoordProviderBase.prototype.adjustDomains_jz8wgn$.call(this, xDomain, yDomain, displaySize);\n var xDomain_0 = this.projectionX_0.toValidDomain_4fzjta$(adjusted.first);\n var yDomain_0 = this.projectionY_0.toValidDomain_4fzjta$(adjusted.second);\n var spanX = data_0.SeriesUtil.span_4fzjta$(xDomain_0);\n var spanY = data_0.SeriesUtil.span_4fzjta$(yDomain_0);\n if (spanX > spanY) {\n var center = xDomain_0.lowerEnd + spanX / 2;\n var halfSpan = spanY / 2;\n tmp$ = new Pair(new ClosedRange(center - halfSpan, center + halfSpan), yDomain_0);\n } else {\n var center_0 = yDomain_0.lowerEnd + spanY / 2;\n var halfSpan_0 = spanX / 2;\n tmp$ = new Pair(xDomain_0, new ClosedRange(center_0 - halfSpan_0, center_0 + halfSpan_0));\n }\n var domainSquare = tmp$;\n var projectedXMin = this.projectionX_0.apply_14dthe$(domainSquare.first.lowerEnd);\n var projectedXMax = this.projectionX_0.apply_14dthe$(domainSquare.first.upperEnd);\n var projectedYMin = this.projectionY_0.apply_14dthe$(domainSquare.second.lowerEnd);\n var projectedYMax = this.projectionY_0.apply_14dthe$(domainSquare.second.upperEnd);\n var ratio = (projectedYMax - projectedYMin) / (projectedXMax - projectedXMin);\n var fixedCoord = new FixedRatioCoordProvider(ratio, null, null);\n return fixedCoord.adjustDomains_jz8wgn$(xDomain_0, yDomain_0, displaySize);\n };\n ProjectionCoordProvider.prototype.buildAxisScaleX_hcz7zd$ = function (scaleProto, domain, axisLength, breaks) {\n var tmp$;\n if (this.projectionX_0.nonlinear) {\n tmp$ = ProjectionCoordProvider$Companion_getInstance().buildAxisScaleWithProjection_0(this.projectionX_0, scaleProto, domain, axisLength, breaks);\n } else {\n tmp$ = CoordProviderBase.prototype.buildAxisScaleX_hcz7zd$.call(this, scaleProto, domain, axisLength, breaks);\n }\n return tmp$;\n };\n ProjectionCoordProvider.prototype.buildAxisScaleY_hcz7zd$ = function (scaleProto, domain, axisLength, breaks) {\n var tmp$;\n if (this.projectionY_0.nonlinear) {\n tmp$ = ProjectionCoordProvider$Companion_getInstance().buildAxisScaleWithProjection_0(this.projectionY_0, scaleProto, domain, axisLength, breaks);\n } else {\n tmp$ = CoordProviderBase.prototype.buildAxisScaleY_hcz7zd$.call(this, scaleProto, domain, axisLength, breaks);\n }\n return tmp$;\n };\n function ProjectionCoordProvider$Companion() {\n ProjectionCoordProvider$Companion_instance = this;\n }\n ProjectionCoordProvider$Companion.prototype.buildAxisScaleWithProjection_0 = function (projection, scaleProto, domain, axisLength, breaks) {\n var validDomain = projection.toValidDomain_4fzjta$(domain);\n var validDomainProjected = new ClosedRange(projection.apply_14dthe$(validDomain.lowerEnd), projection.apply_14dthe$(validDomain.upperEnd));\n var projectionInverse = scale.Mappers.linear_1jkouz$(validDomainProjected, validDomain);\n var linearMapper = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(domain, axisLength);\n var scaleMapper = this.twistScaleMapper_0(projection, projectionInverse, linearMapper);\n var validBreaks = this.validateBreaks_0(validDomain, breaks);\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_8w5bx$(scaleProto, scaleMapper, validBreaks);\n };\n ProjectionCoordProvider$Companion.prototype.validateBreaks_0 = function (validDomain, breaks) {\n var tmp$;\n var validIndices = ArrayList_init();\n var i = 0;\n tmp$ = breaks.domainValues.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (typeof v === 'number' && validDomain.contains_mef7kx$(v)) {\n validIndices.add_11rb$(i);\n }i = i + 1 | 0;\n }\n if (validIndices.size === breaks.domainValues.size) {\n return breaks;\n }var validDomainValues = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.domainValues, validIndices);\n var validLabels = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.labels, validIndices);\n var validTransformedValues = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.transformedValues, validIndices);\n return new GuideBreaks(validDomainValues, validTransformedValues, validLabels);\n };\n function ProjectionCoordProvider$Companion$twistScaleMapper$lambda(closure$projection, closure$projectionInverse, closure$scaleMapper) {\n return function (v) {\n var tmp$;\n if (v != null) {\n var closure$projection_0 = closure$projection;\n var closure$projectionInverse_0 = closure$projectionInverse;\n var closure$scaleMapper_0 = closure$scaleMapper;\n var projected = closure$projection_0.apply_14dthe$(v);\n var unProjected = closure$projectionInverse_0(projected);\n tmp$ = closure$scaleMapper_0(unProjected);\n } else\n tmp$ = null;\n return tmp$;\n };\n }\n ProjectionCoordProvider$Companion.prototype.twistScaleMapper_0 = function (projection, projectionInverse, scaleMapper) {\n return ProjectionCoordProvider$Companion$twistScaleMapper$lambda(projection, projectionInverse, scaleMapper);\n };\n ProjectionCoordProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ProjectionCoordProvider$Companion_instance = null;\n function ProjectionCoordProvider$Companion_getInstance() {\n if (ProjectionCoordProvider$Companion_instance === null) {\n new ProjectionCoordProvider$Companion();\n }return ProjectionCoordProvider$Companion_instance;\n }\n ProjectionCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ProjectionCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function MercatorProjectionX() {\n this.nonlinear_z5go4f$_0 = false;\n }\n Object.defineProperty(MercatorProjectionX.prototype, 'nonlinear', {\n configurable: true,\n get: function () {\n return this.nonlinear_z5go4f$_0;\n }\n });\n MercatorProjectionX.prototype.apply_14dthe$ = function (v) {\n return spatial.MercatorUtils.getMercatorX_14dthe$(v);\n };\n MercatorProjectionX.prototype.toValidDomain_4fzjta$ = function (domain) {\n return domain;\n };\n MercatorProjectionX.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MercatorProjectionX',\n interfaces: [Projection]\n };\n function MercatorProjectionY() {\n this.nonlinear_x0lz9c$_0 = true;\n }\n Object.defineProperty(MercatorProjectionY.prototype, 'nonlinear', {\n configurable: true,\n get: function () {\n return this.nonlinear_x0lz9c$_0;\n }\n });\n MercatorProjectionY.prototype.apply_14dthe$ = function (v) {\n return spatial.MercatorUtils.getMercatorY_14dthe$(v);\n };\n MercatorProjectionY.prototype.toValidDomain_4fzjta$ = function (domain) {\n if (spatial.MercatorUtils.VALID_LATITUDE_RANGE.isConnected_d226ot$(domain)) {\n return spatial.MercatorUtils.VALID_LATITUDE_RANGE.intersection_d226ot$(domain);\n }throw IllegalArgumentException_init('Illegal latitude range for mercator projection: ' + domain);\n };\n MercatorProjectionY.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MercatorProjectionY',\n interfaces: [Projection]\n };\n function DataProcessing() {\n DataProcessing_instance = this;\n }\n DataProcessing.prototype.transformOriginals_si9pes$ = function (data_0, bindings, scaleMap) {\n var tmp$;\n var data_1 = data_0;\n tmp$ = bindings.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (variable.isOrigin) {\n if (!data_1.has_8xm3sj$(variable)) {\n var message = 'Undefined variable ' + variable;\n throw IllegalStateException_init(message.toString());\n }data_1 = data.DataFrameUtil.applyTransform_xaiv89$(data_1, variable, binding.aes, scaleMap.get_31786j$(binding.aes));\n }}\n return data_1;\n };\n DataProcessing.prototype.buildStatData_x40e2x$ = function (data, stat_0, bindings, scaleMap, groupingContext, facets, statCtx, varsWithoutBinding, orderOptions, aggregateOperation, messageConsumer) {\n var tmp$, tmp$_0;\n if (stat_0 === stat.Stats.IDENTITY) {\n return new DataProcessing$DataAndGroupingContext(DataFrame$Builder.Companion.emptyFrame(), groupingContext);\n }var groups = groupingContext.groupMapper;\n var resultSeries;\n var groupSizeListAfterStat;\n if (groups === GroupUtil_getInstance().SINGLE_GROUP_8be2vx$) {\n var sd = this.applyStat_0(data, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer);\n groupSizeListAfterStat = listOf(sd.rowCount());\n var $receiver = sd.variables();\n var result = LinkedHashMap_init_0(coerceAtLeast(mapCapacity(collectionSizeOrDefault($receiver, 10)), 16));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n result.put_xwzc9p$(element, sd.get_8xm3sj$(element));\n }\n resultSeries = result;\n } else {\n var groupMerger = new GroupMerger();\n var lastStatGroupEnd = -1;\n tmp$ = this.splitByGroup_0(data, groups).iterator();\n while (tmp$.hasNext()) {\n var d = tmp$.next();\n var sd_0 = this.applyStat_0(d, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer);\n if (sd_0.isEmpty) {\n continue;\n }groupMerger.initOrderSpecs_37be8y$(orderOptions, sd_0.variables(), bindings, aggregateOperation);\n var curGroupSizeAfterStat = sd_0.rowCount();\n if (sd_0.has_8xm3sj$(stat.Stats.GROUP)) {\n var range = sd_0.range_8xm3sj$(stat.Stats.GROUP);\n if (range != null) {\n var start = lastStatGroupEnd + 1 | 0;\n var offset = start - numberToInt(range.lowerEnd) | 0;\n lastStatGroupEnd = numberToInt(range.upperEnd) + offset | 0;\n if (offset !== 0) {\n var newG = ArrayList_init();\n tmp$_0 = sd_0.getNumeric_8xm3sj$(stat.Stats.GROUP).iterator();\n while (tmp$_0.hasNext()) {\n var g = tmp$_0.next();\n newG.add_11rb$(ensureNotNull(g) + offset);\n }\n sd_0 = sd_0.builder().putNumeric_s1rqo9$(stat.Stats.GROUP, newG).build();\n }}} else {\n var groupingVar = groupingContext.optionalGroupingVar_8be2vx$;\n if (groupingVar != null) {\n var size = sd_0.get_8xm3sj$(first_0(sd_0.variables())).size;\n var v = d.get_8xm3sj$(groupingVar).get_za3lpa$(0);\n var tmp$_2 = sd_0.builder();\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(v);\n }\n sd_0 = tmp$_2.put_2l962d$(groupingVar, list).build();\n }}\n groupMerger.addGroup_s4jycv$(sd_0, curGroupSizeAfterStat);\n }\n resultSeries = groupMerger.getResultSeries();\n groupSizeListAfterStat = groupMerger.getGroupSizes();\n }\n var closure$resultSeries = resultSeries;\n var $receiver_0 = DataFrame$DataFrame$Builder_init();\n var tmp$_3;\n tmp$_3 = closure$resultSeries.keys.iterator();\n while (tmp$_3.hasNext()) {\n var variable = tmp$_3.next();\n $receiver_0.put_2l962d$(variable, ensureNotNull(closure$resultSeries.get_11rb$(variable)));\n }\n var destination = ArrayList_init_1(collectionSizeOrDefault(orderOptions, 10));\n var tmp$_4;\n tmp$_4 = orderOptions.iterator();\n while (tmp$_4.hasNext()) {\n var item = tmp$_4.next();\n destination.add_11rb$(OrderOptionUtil_getInstance().createOrderSpec_e64h97$(closure$resultSeries.keys, bindings, item, aggregateOperation));\n }\n var orderSpecs = destination;\n $receiver_0.addOrderSpecs_l2t0xf$(orderSpecs);\n var dataAfterStat = $receiver_0.build();\n var groupingContextAfterStat = GroupingContext$Companion_getInstance().withOrderedGroups_vi90cb$(dataAfterStat, groupSizeListAfterStat);\n return new DataProcessing$DataAndGroupingContext(dataAfterStat, groupingContextAfterStat);\n };\n DataProcessing.prototype.findOptionalVariable_hrxl0z$ = function (data_0, name) {\n return base.Strings.isNullOrEmpty_pdl1vj$(name) ? null : data.DataFrameUtil.findVariableOrFail_vede35$(data_0, ensureNotNull(name));\n };\n DataProcessing.prototype.splitByGroup_0 = function (data, groups) {\n var $receiver = GroupUtil_getInstance().indicesByGroup_wc9gac$(data.rowCount(), groups).values;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var $receiver_0 = data.variables();\n var tmp$_1;\n var accumulator = DataFrame$DataFrame$Builder_init();\n tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n var b = accumulator;\n var operation$result;\n var tmp$_2;\n tmp$_2 = data.isNumeric_8xm3sj$(element);\n if (tmp$_2 === true) {\n operation$result = b.putNumeric_s1rqo9$(element, data_0.SeriesUtil.pickAtIndices_ge51dg$(data.getNumeric_8xm3sj$(element), item));\n } else if (tmp$_2 === false) {\n operation$result = b.putDiscrete_2l962d$(element, data_0.SeriesUtil.pickAtIndices_ge51dg$(data.get_8xm3sj$(element), item));\n } else {\n operation$result = Kotlin.noWhenBranchMatched();\n }\n accumulator = operation$result;\n }\n tmp$_0.call(destination, accumulator);\n }\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_3;\n tmp$_3 = destination.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_0.add_11rb$(item_0.build());\n }\n return destination_0;\n };\n function DataProcessing$applyStat$addSeriesForVariable(closure$data, closure$statDataSize, closure$newInputSeries) {\n return function (variable) {\n var tmp$, tmp$_0;\n tmp$ = closure$data.isNumeric_8xm3sj$(variable);\n if (tmp$ === true)\n tmp$_0 = data_0.SeriesUtil.mean_l4tjj7$(closure$data.getNumeric_8xm3sj$(variable), null);\n else if (tmp$ === false)\n tmp$_0 = data_0.SeriesUtil.firstNotNull_rath1t$(closure$data.get_8xm3sj$(variable), null);\n else\n tmp$_0 = Kotlin.noWhenBranchMatched();\n var value = tmp$_0;\n var size = closure$statDataSize;\n var list = ArrayList_init_1(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(value);\n }\n var newInputSerie = list;\n closure$newInputSeries.put_xwzc9p$(variable, newInputSerie);\n };\n }\n DataProcessing.prototype.applyStat_0 = function (data_0, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, compMessageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var statData = stat_0.apply_kdy6bf$(data_0, statCtx, compMessageConsumer);\n var statVariables = statData.variables();\n if (statVariables.isEmpty()) {\n return statData;\n }var inverseTransformedStatSeries = this.inverseTransformContinuousStatData_0(statData, stat_0, bindings, scaleMap);\n var statDataSize = statData.get_8xm3sj$(statVariables.iterator().next()).size;\n var facetVars = HashSet_init_0();\n tmp$ = facets.variables.iterator();\n while (tmp$.hasNext()) {\n var facetVarName = tmp$.next();\n var facetVar = data.DataFrameUtil.findVariableOrFail_vede35$(data_0, facetVarName);\n facetVars.add_11rb$(facetVar);\n if (!data_0.get_8xm3sj$(facetVar).isEmpty()) {\n var facetLevel = data_0.get_8xm3sj$(facetVar).get_za3lpa$(0);\n var tmp$_5 = statData.builder();\n var list = ArrayList_init_1(statDataSize);\n for (var index = 0; index < statDataSize; index++) {\n list.add_11rb$(facetLevel);\n }\n statData = tmp$_5.put_2l962d$(facetVar, list).build();\n }}\n if (bindings.isEmpty()) {\n return statData;\n }var newInputSeries = HashMap_init();\n var addSeriesForVariable = DataProcessing$applyStat$addSeriesForVariable(data_0, statDataSize, newInputSeries);\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var binding = tmp$_0.next();\n var variable = binding.variable;\n if (variable.isStat || facetVars.contains_11rb$(variable)) {\n continue;\n }var aes = binding.aes;\n if (stat_0.hasDefaultMapping_896ixz$(aes)) {\n var defaultStatVar = stat_0.getDefaultMapping_896ixz$(aes);\n if (inverseTransformedStatSeries.containsKey_11rb$(defaultStatVar)) {\n tmp$_1 = getValue(inverseTransformedStatSeries, defaultStatVar);\n } else {\n var statSerie = statData.getNumeric_8xm3sj$(defaultStatVar);\n tmp$_1 = scale.ScaleUtil.inverseTransform_codrxm$(statSerie, scaleMap.get_31786j$(aes));\n }\n var newInputSerie = tmp$_1;\n newInputSeries.put_xwzc9p$(variable, newInputSerie);\n } else {\n if (!newInputSeries.containsKey_11rb$(variable)) {\n addSeriesForVariable(variable);\n }}\n }\n var predicate = getCallableRef('isStatVar', function ($receiver, p1) {\n return $receiver.isStatVar_61zpoe$(p1);\n }.bind(null, stat.Stats));\n var destination = ArrayList_init();\n var tmp$_6;\n tmp$_6 = varsWithoutBinding.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (!predicate(element))\n destination.add_11rb$(element);\n }\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var varName = tmp$_2.next();\n var variable_0 = data.DataFrameUtil.findVariableOrFail_vede35$(data_0, varName);\n if (!newInputSeries.containsKey_11rb$(variable_0)) {\n addSeriesForVariable(variable_0);\n }}\n var b = statData.builder();\n tmp$_3 = newInputSeries.keys.iterator();\n while (tmp$_3.hasNext()) {\n var variable_1 = tmp$_3.next();\n b.put_2l962d$(variable_1, getValue(newInputSeries, variable_1));\n }\n tmp$_4 = inverseTransformedStatSeries.keys.iterator();\n while (tmp$_4.hasNext()) {\n var variable_2 = tmp$_4.next();\n b.putNumeric_s1rqo9$(variable_2, getValue(inverseTransformedStatSeries, variable_2));\n }\n return b.build();\n };\n DataProcessing.prototype.inverseTransformContinuousStatData_0 = function (statData, stat, bindings, scaleMap) {\n var tmp$, tmp$_0, tmp$_1;\n var continuousScaleByAes = HashMap_init();\n var aesByMappedStatVar = HashMap_init();\n tmp$ = Aes.Companion.values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (stat.hasDefaultMapping_896ixz$(aes)) {\n var defaultStatVar = stat.getDefaultMapping_896ixz$(aes);\n aesByMappedStatVar.put_xwzc9p$(defaultStatVar, aes);\n }}\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var binding = tmp$_0.next();\n var aes_0 = binding.aes;\n var variable = binding.variable;\n if (variable.isStat) {\n aesByMappedStatVar.put_xwzc9p$(variable, aes_0);\n continue;\n }var scale_0 = scaleMap.get_31786j$(aes_0);\n if (scale_0.isContinuousDomain) {\n continuousScaleByAes.put_xwzc9p$(aes_0, scale_0);\n if (Aes.Companion.isPositionalX_896ixz$(aes_0) && !continuousScaleByAes.containsKey_11rb$(Aes.Companion.X)) {\n var key = Aes.Companion.X;\n continuousScaleByAes.put_xwzc9p$(key, scale_0);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes_0) && !continuousScaleByAes.containsKey_11rb$(Aes.Companion.Y)) {\n var key_0 = Aes.Companion.Y;\n continuousScaleByAes.put_xwzc9p$(key_0, scale_0);\n }}}\n var inverseTransformedStatSeries = HashMap_init();\n tmp$_1 = statData.variables().iterator();\n while (tmp$_1.hasNext()) {\n var statVar = tmp$_1.next();\n if (aesByMappedStatVar.containsKey_11rb$(statVar)) {\n var aes_1 = getValue(aesByMappedStatVar, statVar);\n var scale_1 = continuousScaleByAes.get_11rb$(aes_1);\n if (scale_1 == null) {\n if (Aes.Companion.isPositionalX_896ixz$(aes_1)) {\n scale_1 = continuousScaleByAes.get_11rb$(Aes.Companion.X);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes_1)) {\n scale_1 = continuousScaleByAes.get_11rb$(Aes.Companion.Y);\n }}if (scale_1 != null) {\n var statSerie = statData.getNumeric_8xm3sj$(statVar);\n var inverseTransformedStatSerie = scale.ScaleUtil.inverseTransformToContinuousDomain_codrxm$(statSerie, scale_1);\n inverseTransformedStatSeries.put_xwzc9p$(statVar, inverseTransformedStatSerie);\n }}}\n return inverseTransformedStatSeries;\n };\n DataProcessing.prototype.computeGroups_hut2k5$ = function (data, bindings, groupingVar, pathIdVar) {\n var tmp$, tmp$_0;\n var groupingVariables = plus_0(this.getGroupingVariables_0(data, bindings, groupingVar), listOfNotNull_0(pathIdVar));\n var currentGroups = {v: null};\n if (groupingVar != null) {\n currentGroups.v = this.computeGroups_0(data.get_8xm3sj$(groupingVar));\n }tmp$ = groupingVariables.iterator();\n while (tmp$.hasNext()) {\n var groupingVariable = tmp$.next();\n var values = data.get_8xm3sj$(groupingVariable);\n var groups = this.computeGroups_0(values);\n if (currentGroups.v == null) {\n currentGroups.v = groups;\n continue;\n }if (!(currentGroups.v.size === groups.size)) {\n var tmp$_1;\n var message = 'Data series used to compute groups must be equal in size (encountered sizes: ' + (toString((tmp$_1 = currentGroups.v) != null ? tmp$_1.size : null) + ', ' + groups.size + ' )');\n throw IllegalStateException_init(message.toString());\n }var dummies = this.computeDummyValues_0(currentGroups.v, groups);\n currentGroups.v = this.computeGroups_0(dummies);\n }\n if (currentGroups.v != null) {\n tmp$_0 = GroupUtil_getInstance().wrap_2wzaym$(currentGroups.v);\n } else {\n tmp$_0 = GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n }\n return tmp$_0;\n };\n DataProcessing.prototype.computeGroups_0 = function (values) {\n var tmp$, tmp$_0;\n var groups = ArrayList_init();\n var groupByVal = HashMap_init();\n var count = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!groupByVal.containsKey_11rb$(v)) {\n var value = (tmp$_0 = count, count = tmp$_0 + 1 | 0, tmp$_0);\n groupByVal.put_xwzc9p$(v, value);\n }groups.add_11rb$(ensureNotNull(groupByVal.get_11rb$(v)));\n }\n return groups;\n };\n DataProcessing.prototype.computeDummyValues_0 = function (list1, list2) {\n if (list1.isEmpty())\n return emptyList();\n var limit = 1000;\n var max = Ordering.Companion.natural_dahdeg$().max_m5x2f4$(collect.Iterables.concat_yxozss$(list1, list2));\n if (!(max < limit)) {\n var message = 'Too many groups: ' + max;\n throw IllegalStateException_init(message.toString());\n }var dummies = ArrayList_init();\n var it1 = list1.iterator();\n var it2 = list2.iterator();\n while (it1.hasNext()) {\n var v1 = it1.next();\n var v2 = it2.next();\n var dummy = Kotlin.imul(v1, limit) + v2 | 0;\n dummies.add_11rb$(dummy);\n }\n return dummies;\n };\n DataProcessing.prototype.getGroupingVariables_0 = function (data, bindings, explicitGroupingVar) {\n var tmp$;\n var result = LinkedHashSet_init();\n tmp$ = bindings.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (!result.contains_11rb$(variable)) {\n if (variable.isOrigin) {\n if (equals(variable, explicitGroupingVar) || this.isDefaultGroupingVariable_0(data, binding.aes, variable)) {\n result.add_11rb$(variable);\n }}}}\n return result;\n };\n DataProcessing.prototype.isDefaultGroupingVariable_0 = function (data, aes, variable) {\n return !(Aes.Companion.isPositional_896ixz$(aes) || data.isNumeric_8xm3sj$(variable));\n };\n function DataProcessing$DataAndGroupingContext(data, groupingContext) {\n this.data = data;\n this.groupingContext = groupingContext;\n }\n DataProcessing$DataAndGroupingContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataAndGroupingContext',\n interfaces: []\n };\n DataProcessing.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DataProcessing',\n interfaces: []\n };\n var DataProcessing_instance = null;\n function DataProcessing_getInstance() {\n if (DataProcessing_instance === null) {\n new DataProcessing();\n }return DataProcessing_instance;\n }\n function GroupMerger() {\n this.myOrderSpecs_0 = null;\n this.myOrderedGroups_0 = ArrayList_init();\n }\n GroupMerger.prototype.initOrderSpecs_37be8y$ = function (orderOptions, variables, bindings, aggregateOperation) {\n if (this.myOrderSpecs_0 != null)\n return;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = orderOptions.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_0;\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n if (equals(element_0.variable.name, element.variableName) && equals(element_0.aes, Aes.Companion.X)) {\n firstOrNull$result = element_0;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if (firstOrNull$result == null)\n destination.add_11rb$(element);\n }\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(OrderOptionUtil_getInstance().createOrderSpec_e64h97$(variables, bindings, item, aggregateOperation));\n }\n this.myOrderSpecs_0 = destination_0;\n };\n GroupMerger.prototype.getResultSeries = function () {\n var resultSeries = HashMap_init();\n var tmp$;\n tmp$ = this.myOrderedGroups_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n tmp$_0 = element.df.variables().iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n var tmp$_1;\n var value = resultSeries.get_11rb$(element_0);\n if (value == null) {\n var answer = ArrayList_init();\n resultSeries.put_xwzc9p$(element_0, answer);\n tmp$_1 = answer;\n } else {\n tmp$_1 = value;\n }\n tmp$_1.addAll_brywnq$(element.df.get_8xm3sj$(element_0));\n }\n }\n return resultSeries;\n };\n GroupMerger.prototype.getGroupSizes = function () {\n var $receiver = this.myOrderedGroups_0;\n var transform = getPropertyCallableRef('groupSize', 1, function ($receiver) {\n return $receiver.groupSize;\n });\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(transform(item));\n }\n return destination;\n };\n function GroupMerger$Group($outer, df, groupSize) {\n this.$outer = $outer;\n this.df = df;\n this.groupSize = groupSize;\n }\n function GroupMerger$Group$compareTo$compareGroupValue(v1, v2, dir) {\n var tmp$, tmp$_0;\n if (v1 == null && v2 == null)\n return 0;\n if (v1 == null)\n return 1;\n if (v2 == null)\n return -1;\n return Kotlin.imul(compareValues(Kotlin.isComparable(tmp$ = v1) ? tmp$ : throwCCE(), Kotlin.isComparable(tmp$_0 = v2) ? tmp$_0 : throwCCE()), dir);\n }\n function GroupMerger$Group$compareTo$getValue(df, variable, aggregateOperation) {\n if (aggregateOperation === void 0)\n aggregateOperation = null;\n var tmp$;\n if (aggregateOperation != null) {\n if (!df.isNumeric_8xm3sj$(variable)) {\n var message = \"Can't apply aggregate operation to non-numeric values\";\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = aggregateOperation(requireNoNulls(df.getNumeric_8xm3sj$(variable)));\n } else {\n tmp$ = firstOrNull(df.get_8xm3sj$(variable));\n }\n return tmp$;\n }\n GroupMerger$Group.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var compareGroupValue = GroupMerger$Group$compareTo$compareGroupValue;\n var getValue = GroupMerger$Group$compareTo$getValue;\n if ((tmp$ = this.$outer.myOrderSpecs_0) != null) {\n var tmp$_0;\n tmp$_0 = tmp$.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var cmp = compareGroupValue(getValue(this.df, element.orderBy, element.aggregateOperation), getValue(other.df, element.orderBy, element.aggregateOperation), element.direction);\n if (cmp === 0) {\n cmp = compareGroupValue(getValue(this.df, element.variable), getValue(other.df, element.variable), element.direction);\n }if (cmp !== 0) {\n return cmp;\n }}\n }return 0;\n };\n GroupMerger$Group.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Group',\n interfaces: [Comparable]\n };\n GroupMerger.prototype.addGroup_s4jycv$ = function (d, groupSize) {\n var group = new GroupMerger$Group(this, d, groupSize);\n var indexToInsert = this.findIndexToInsert_0(group);\n this.myOrderedGroups_0.add_wxm5ur$(indexToInsert, group);\n };\n GroupMerger.prototype.findIndexToInsert_0 = function (group) {\n var $receiver = this.myOrderSpecs_0;\n if ($receiver == null || $receiver.isEmpty()) {\n return this.myOrderedGroups_0.size;\n }var index = binarySearch(this.myOrderedGroups_0, group);\n if (index < 0)\n index = ~index;\n return index;\n };\n GroupMerger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupMerger',\n interfaces: []\n };\n function GroupUtil() {\n GroupUtil_instance = this;\n this.SINGLE_GROUP_8be2vx$ = GroupUtil$SINGLE_GROUP$lambda;\n }\n function GroupUtil$wrap$lambda(closure$l) {\n return function (index) {\n return index > 0 && index < closure$l.size ? numberToInt(ensureNotNull(closure$l.get_za3lpa$(index))) : 0;\n };\n }\n GroupUtil.prototype.wrap_2wzaym$ = function (l) {\n return GroupUtil$wrap$lambda(l);\n };\n function GroupUtil$wrap$lambda_0(closure$groupByPointIndex) {\n return function (it) {\n return ensureNotNull(closure$groupByPointIndex.get_11rb$(it));\n };\n }\n GroupUtil.prototype.wrap_orwq1h$ = function (groupByPointIndex) {\n return GroupUtil$wrap$lambda_0(groupByPointIndex);\n };\n GroupUtil.prototype.indicesByGroup_wc9gac$ = function (dataLength, groups) {\n var indicesByGroup = LinkedHashMap_init();\n for (var i = 0; i < dataLength; i++) {\n var group = groups(i);\n if (!indicesByGroup.containsKey_11rb$(group)) {\n var value = ArrayList_init();\n indicesByGroup.put_xwzc9p$(group, value);\n }ensureNotNull(indicesByGroup.get_11rb$(group)).add_11rb$(i);\n }\n return indicesByGroup;\n };\n function GroupUtil$SINGLE_GROUP$lambda(f) {\n return 0;\n }\n GroupUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GroupUtil',\n interfaces: []\n };\n var GroupUtil_instance = null;\n function GroupUtil_getInstance() {\n if (GroupUtil_instance === null) {\n new GroupUtil();\n }return GroupUtil_instance;\n }\n function GroupingContext(myData, bindings, groupingVarName, pathIdVarName, myExpectMultiple) {\n GroupingContext$Companion_getInstance();\n this.myData_0 = myData;\n this.myExpectMultiple_0 = myExpectMultiple;\n this.myBindings_0 = ArrayList_init_0(bindings);\n this.optionalGroupingVar_8be2vx$ = DataProcessing_getInstance().findOptionalVariable_hrxl0z$(this.myData_0, groupingVarName);\n this.pathIdVar_0 = DataProcessing_getInstance().findOptionalVariable_hrxl0z$(this.myData_0, pathIdVarName);\n this.myGroupSizeList_0 = null;\n this.myGroupMapper_0 = null;\n }\n function GroupingContext$get_GroupingContext$groupMapper$lambda(this$GroupingContext) {\n return function (index) {\n if (this$GroupingContext.myGroupMapper_0 == null) {\n this$GroupingContext.myGroupMapper_0 = this$GroupingContext.computeGroups_0();\n }return ensureNotNull(this$GroupingContext.myGroupMapper_0)(index);\n };\n }\n Object.defineProperty(GroupingContext.prototype, 'groupMapper', {\n configurable: true,\n get: function () {\n return GroupingContext$get_GroupingContext$groupMapper$lambda(this);\n }\n });\n GroupingContext.prototype.computeGroups_0 = function () {\n if (this.myData_0.has_8xm3sj$(stat.Stats.GROUP)) {\n var list = this.myData_0.getNumeric_8xm3sj$(stat.Stats.GROUP);\n return GroupUtil_getInstance().wrap_2wzaym$(list);\n } else if (this.myGroupSizeList_0 != null) {\n if (ensureNotNull(this.myGroupSizeList_0).size === this.myData_0.rowCount()) {\n return GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n } else {\n var groupByPointIndex = GroupingContext$Companion_getInstance().toIndexMap_0(ensureNotNull(this.myGroupSizeList_0));\n return GroupUtil_getInstance().wrap_orwq1h$(groupByPointIndex);\n }\n } else if (this.myExpectMultiple_0) {\n return DataProcessing_getInstance().computeGroups_hut2k5$(this.myData_0, this.myBindings_0, this.optionalGroupingVar_8be2vx$, this.pathIdVar_0);\n }return GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n };\n function GroupingContext$Companion() {\n GroupingContext$Companion_instance = this;\n }\n GroupingContext$Companion.prototype.withOrderedGroups_vi90cb$ = function (data, groupSizeList) {\n var groupingContext = new GroupingContext(data, emptyList(), null, null, false);\n groupingContext.myGroupSizeList_0 = ArrayList_init_0(groupSizeList);\n return groupingContext;\n };\n GroupingContext$Companion.prototype.toIndexMap_0 = function (groupSizeList) {\n var tmp$;\n var result = HashMap_init();\n var currentGroup = 0;\n var currentGroupIndexOffset = 0;\n tmp$ = groupSizeList.iterator();\n while (tmp$.hasNext()) {\n var groupSize = tmp$.next();\n for (var i = 0; i < groupSize; i++) {\n var key = currentGroupIndexOffset + i | 0;\n var value = currentGroup;\n result.put_xwzc9p$(key, value);\n }\n currentGroup = currentGroup + 1 | 0;\n currentGroupIndexOffset = currentGroupIndexOffset + groupSize | 0;\n }\n return result;\n };\n GroupingContext$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupingContext$Companion_instance = null;\n function GroupingContext$Companion_getInstance() {\n if (GroupingContext$Companion_instance === null) {\n new GroupingContext$Companion();\n }return GroupingContext$Companion_instance;\n }\n GroupingContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupingContext',\n interfaces: []\n };\n function OrderOptionUtil() {\n OrderOptionUtil_instance = this;\n }\n function OrderOptionUtil$OrderOption(variableName, byVariable, orderDir) {\n OrderOptionUtil$OrderOption$Companion_getInstance();\n this.variableName = variableName;\n this.byVariable = byVariable;\n this.orderDir_0 = orderDir;\n }\n OrderOptionUtil$OrderOption.prototype.getOrderDir = function () {\n var tmp$;\n return (tmp$ = this.orderDir_0) != null ? tmp$ : -1;\n };\n function OrderOptionUtil$OrderOption$Companion() {\n OrderOptionUtil$OrderOption$Companion_instance = this;\n }\n OrderOptionUtil$OrderOption$Companion.prototype.create_yyjhqb$ = function (variableName, orderBy, order) {\n var tmp$, tmp$_0;\n if (orderBy == null && order == null) {\n return null;\n }if (!(order == null || (Kotlin.isNumber(order) && listOf_0([-1, 1]).contains_11rb$(numberToInt(order))))) {\n var message = 'Unsupported `order` value: ' + toString(order) + '. Use 1 (ascending) or -1 (descending).';\n throw IllegalArgumentException_init(message.toString());\n }return new OrderOptionUtil$OrderOption(variableName, orderBy, (tmp$_0 = Kotlin.isNumber(tmp$ = order) ? tmp$ : null) != null ? numberToInt(tmp$_0) : null);\n };\n OrderOptionUtil$OrderOption$Companion.prototype.mergeWith_me9ya9$ = function ($receiver, other) {\n var tmp$, tmp$_0;\n if (!equals($receiver.variableName, other.variableName)) {\n var message = \"Can't merge order options for different variables: '\" + $receiver.variableName + \"' and '\" + other.variableName + \"'\";\n throw IllegalArgumentException_init(message.toString());\n }if (!($receiver.byVariable == null || other.byVariable == null || equals(other.byVariable, $receiver.byVariable))) {\n var message_0 = \"Multiple ordering options for the variable '\" + $receiver.variableName + \"' with different non-empty 'order_by' fields: '\" + toString($receiver.byVariable) + \"' and '\" + toString(other.byVariable) + \"'\";\n throw IllegalArgumentException_init(message_0.toString());\n }if (!($receiver.orderDir_0 == null || other.orderDir_0 == null || other.orderDir_0 == $receiver.orderDir_0)) {\n var message_1 = \"Multiple ordering options for the variable '\" + $receiver.variableName + \"' with different order direction: '\" + toString($receiver.orderDir_0) + \"' and '\" + toString(other.orderDir_0) + \"'\";\n throw IllegalArgumentException_init(message_1.toString());\n }return new OrderOptionUtil$OrderOption($receiver.variableName, (tmp$ = $receiver.byVariable) != null ? tmp$ : other.byVariable, (tmp$_0 = $receiver.orderDir_0) != null ? tmp$_0 : other.orderDir_0);\n };\n OrderOptionUtil$OrderOption$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var OrderOptionUtil$OrderOption$Companion_instance = null;\n function OrderOptionUtil$OrderOption$Companion_getInstance() {\n if (OrderOptionUtil$OrderOption$Companion_instance === null) {\n new OrderOptionUtil$OrderOption$Companion();\n }return OrderOptionUtil$OrderOption$Companion_instance;\n }\n OrderOptionUtil$OrderOption.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderOption',\n interfaces: []\n };\n function OrderOptionUtil$createOrderSpec$getVariableByName(closure$variables) {\n return function (varName) {\n var tmp$;\n var tmp$_0;\n var $receiver = closure$variables;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (equals(element.name, varName)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if ((tmp$ = firstOrNull$result) != null)\n tmp$_0 = tmp$;\n else {\n var tmp$_2 = \"Undefined variable '\" + varName + \"' in order options. Full variable list: \";\n var $receiver_0 = closure$variables;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_3;\n tmp$_3 = $receiver_0.iterator();\n while (tmp$_3.hasNext()) {\n var item = tmp$_3.next();\n destination.add_11rb$(\"'\" + item.name + \"'\");\n }\n throw IllegalStateException_init((tmp$_2 + destination).toString());\n }\n return tmp$_0;\n };\n }\n OrderOptionUtil.prototype.createOrderSpec_e64h97$ = function (variables, varBindings, orderOption, aggregateOperation) {\n var tmp$, tmp$_0, tmp$_1;\n var getVariableByName = OrderOptionUtil$createOrderSpec$getVariableByName(variables);\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_2;\n tmp$_2 = varBindings.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (equals(element.variable.name, orderOption.variableName) && equals(element.aes, Aes.Companion.X)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if (firstOrNull$result != null && SamplingUtil_getInstance().xVar_bbyvt0$(variables) != null) {\n tmp$ = ensureNotNull(SamplingUtil_getInstance().xVar_bbyvt0$(variables));\n } else {\n tmp$ = getVariableByName(orderOption.variableName);\n }\n var variable = tmp$;\n return new DataFrame$OrderSpec(variable, (tmp$_1 = (tmp$_0 = orderOption.byVariable) != null ? getVariableByName(tmp$_0) : null) != null ? tmp$_1 : getVariableByName(orderOption.variableName), orderOption.getOrderDir(), orderOption.byVariable != null && !equals(orderOption.byVariable, orderOption.variableName) ? aggregateOperation : null);\n };\n OrderOptionUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'OrderOptionUtil',\n interfaces: []\n };\n var OrderOptionUtil_instance = null;\n function OrderOptionUtil_getInstance() {\n if (OrderOptionUtil_instance === null) {\n new OrderOptionUtil();\n }return OrderOptionUtil_instance;\n }\n function MouseEventPeer() {\n this.myEventHandlers_0 = HashMap_init();\n this.myEventSources_0 = ArrayList_init();\n this.mySourceRegistrations_0 = HashMap_init();\n }\n function MouseEventPeer$addEventHandler$ObjectLiteral(closure$addReg, this$MouseEventPeer, closure$eventSpec) {\n this.closure$addReg = closure$addReg;\n this.this$MouseEventPeer = this$MouseEventPeer;\n this.closure$eventSpec = closure$eventSpec;\n Registration.call(this);\n }\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype.doRemove = function () {\n var tmp$;\n (tmp$ = this.closure$addReg) != null ? (tmp$.remove(), Unit) : null;\n if (ensureNotNull(this.this$MouseEventPeer.myEventHandlers_0.get_11rb$(this.closure$eventSpec)).isEmpty) {\n this.this$MouseEventPeer.myEventHandlers_0.remove_11rb$(this.closure$eventSpec);\n this.this$MouseEventPeer.onRemoveSpec_0(this.closure$eventSpec);\n }};\n MouseEventPeer$addEventHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n MouseEventPeer.prototype.addEventHandler_mfdhbe$ = function (eventSpec, eventHandler) {\n var tmp$;\n if (!this.myEventHandlers_0.containsKey_11rb$(eventSpec)) {\n var $receiver = this.myEventHandlers_0;\n var value = new Listeners();\n $receiver.put_xwzc9p$(eventSpec, value);\n this.onAddSpec_0(eventSpec);\n }var addReg = (tmp$ = this.myEventHandlers_0.get_11rb$(eventSpec)) != null ? tmp$.add_11rb$(eventHandler) : null;\n return new MouseEventPeer$addEventHandler$ObjectLiteral(addReg, this, eventSpec);\n };\n function MouseEventPeer$dispatch$ObjectLiteral(closure$mouseEvent) {\n this.closure$mouseEvent = closure$mouseEvent;\n }\n MouseEventPeer$dispatch$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$mouseEvent);\n };\n MouseEventPeer$dispatch$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n MouseEventPeer.prototype.dispatch_w7zfbj$ = function (eventSpec, mouseEvent) {\n var tmp$;\n if (this.myEventHandlers_0.containsKey_11rb$(eventSpec)) {\n (tmp$ = this.myEventHandlers_0.get_11rb$(eventSpec)) != null ? (tmp$.fire_kucmxw$(new MouseEventPeer$dispatch$ObjectLiteral(mouseEvent)), Unit) : null;\n }};\n MouseEventPeer.prototype.addEventSource_u4bej9$ = function (eventSource) {\n var tmp$;\n tmp$ = this.myEventHandlers_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.startHandleSpecInSource_0(eventSource, element);\n }\n this.myEventSources_0.add_11rb$(eventSource);\n };\n MouseEventPeer.prototype.onAddSpec_0 = function (eventSpec) {\n var tmp$;\n tmp$ = this.myEventSources_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.startHandleSpecInSource_0(element, eventSpec);\n }\n };\n function MouseEventPeer$startHandleSpecInSource$ObjectLiteral(closure$eventSpec, this$MouseEventPeer) {\n this.closure$eventSpec = closure$eventSpec;\n this.this$MouseEventPeer = this$MouseEventPeer;\n }\n MouseEventPeer$startHandleSpecInSource$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.this$MouseEventPeer.dispatch_w7zfbj$(this.closure$eventSpec, event);\n };\n MouseEventPeer$startHandleSpecInSource$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n MouseEventPeer.prototype.startHandleSpecInSource_0 = function (eventSource, eventSpec) {\n var tmp$;\n var registration = eventSource.addEventHandler_mfdhbe$(eventSpec, new MouseEventPeer$startHandleSpecInSource$ObjectLiteral(eventSpec, this));\n if (!this.mySourceRegistrations_0.containsKey_11rb$(eventSpec)) {\n var $receiver = this.mySourceRegistrations_0;\n var value = new CompositeRegistration([]);\n $receiver.put_xwzc9p$(eventSpec, value);\n }(tmp$ = this.mySourceRegistrations_0.get_11rb$(eventSpec)) != null ? tmp$.add_3xv6fb$(registration) : null;\n };\n MouseEventPeer.prototype.onRemoveSpec_0 = function (eventSpec) {\n var tmp$;\n if (this.mySourceRegistrations_0.containsKey_11rb$(eventSpec)) {\n (tmp$ = this.mySourceRegistrations_0.remove_11rb$(eventSpec)) != null ? (tmp$.dispose(), Unit) : null;\n }};\n MouseEventPeer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEventPeer',\n interfaces: [MouseEventSource]\n };\n function AxisComponent(length, orientation) {\n SvgComponent.call(this);\n this.breaks = new ValueProperty(null);\n this.labels = new ValueProperty(null);\n this.tickLabelRotationDegree = new ValueProperty(0.0);\n this.tickLabelHorizontalAnchor = null;\n this.tickLabelVerticalAnchor = null;\n this.tickLabelSmallFont = new ValueProperty(false);\n this.tickLabelOffsets = new ValueProperty(null);\n this.gridLineColor = new ValueProperty(Color.Companion.LIGHT_GRAY);\n this.lineWidth = new ValueProperty(1.0);\n this.gridLineWidth = new ValueProperty(1.0);\n this.gridLineLength = new ValueProperty(0.0);\n this.tickMarkWidth = new ValueProperty(1.0);\n this.tickMarkLength = new ValueProperty(6.0);\n this.tickMarkPadding = new ValueProperty(3.0);\n this.length_0 = new ValueProperty(null);\n this.orientation_0 = new ValueProperty(null);\n this.myTickMarksEnabled_0 = new ValueProperty(true);\n this.myTickLabelsEnabled_0 = new ValueProperty(true);\n this.myAxisLineEnabled_0 = new ValueProperty(true);\n this.lineColor_0 = new ValueProperty(Color.Companion.BLACK);\n this.tickColor_0 = new ValueProperty(Color.Companion.BLACK);\n this.length_0.set_11rb$(length);\n this.orientation_0.set_11rb$(orientation);\n this.tickLabelHorizontalAnchor = new ValueProperty(this.defTickLabelHorizontalAnchor_0(orientation));\n this.tickLabelVerticalAnchor = new ValueProperty(this.defTickLabelVerticalAnchor_0(orientation));\n var asPropertyChangedEventSource = AxisComponent_init$asPropertyChangedEventSource;\n event.EventSources.composite_xw2ruy$([asPropertyChangedEventSource(this.length_0), asPropertyChangedEventSource(this.orientation_0), asPropertyChangedEventSource(this.breaks), asPropertyChangedEventSource(this.labels), asPropertyChangedEventSource(this.gridLineLength), asPropertyChangedEventSource(this.tickLabelOffsets), asPropertyChangedEventSource(this.tickLabelHorizontalAnchor), asPropertyChangedEventSource(this.tickLabelVerticalAnchor), asPropertyChangedEventSource(this.tickLabelRotationDegree), asPropertyChangedEventSource(this.tickLabelSmallFont)]).addHandler_gxwwpc$(this.rebuildHandler_287e2$());\n }\n AxisComponent.prototype.defTickLabelHorizontalAnchor_0 = function (orientation) {\n var tmp$;\n switch (orientation.name) {\n case 'LEFT':\n tmp$ = TextLabel$HorizontalAnchor.RIGHT;\n break;\n case 'RIGHT':\n tmp$ = TextLabel$HorizontalAnchor.LEFT;\n break;\n case 'TOP':\n case 'BOTTOM':\n tmp$ = TextLabel$HorizontalAnchor.MIDDLE;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n AxisComponent.prototype.defTickLabelVerticalAnchor_0 = function (orientation) {\n switch (orientation.name) {\n case 'LEFT':\n case 'RIGHT':\n return TextLabel$VerticalAnchor.CENTER;\n case 'TOP':\n return TextLabel$VerticalAnchor.BOTTOM;\n case 'BOTTOM':\n return TextLabel$VerticalAnchor.TOP;\n default:throw RuntimeException_init('Unexpected orientation:' + orientation);\n }\n };\n AxisComponent.prototype.buildComponent = function () {\n this.buildAxis_0();\n };\n AxisComponent.prototype.buildAxis_0 = function () {\n var tmp$, tmp$_0, tmp$_1;\n var rootElement = this.rootGroup;\n rootElement.addClass_61zpoe$(Style_getInstance().AXIS);\n if (this.tickLabelSmallFont.get()) {\n rootElement.addClass_61zpoe$(Style_getInstance().SMALL_TICK_FONT);\n }var l = ensureNotNull(this.length_0.get());\n var x1;\n var y1;\n var x2;\n var y2;\n var start;\n var end;\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance()) || equals(tmp$, Orientation$RIGHT_getInstance())) {\n x2 = 0.0;\n x1 = x2;\n start = 0.0;\n y1 = start;\n end = l;\n y2 = end;\n } else if (equals(tmp$, Orientation$TOP_getInstance()) || equals(tmp$, Orientation$BOTTOM_getInstance())) {\n start = 0.0;\n x1 = start;\n end = l;\n x2 = end;\n y2 = 0.0;\n y1 = y2;\n } else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n var axisLine = null;\n if (this.axisLineEnabled().get()) {\n axisLine = SvgLineElement_init(x1, y1, x2, y2);\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.lineWidth, axisLine.strokeWidth()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.lineColor_0, axisLine.strokeColor()));\n }var gridLineMinPos = start + 3;\n var gridLineMaxPos = end - 3;\n if (this.breaksEnabled_0()) {\n var breaks = this.breaks.get();\n if (!(breaks == null || breaks.isEmpty())) {\n var labels = this.labels.get();\n if (labels == null || labels.isEmpty()) {\n labels = ArrayList_init();\n for (var i = 0; i !== breaks.size; ++i) {\n labels.add_11rb$('');\n }\n }var i_0 = 0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var br = tmp$_0.next();\n var addGridLine = br >= gridLineMinPos && br <= gridLineMaxPos;\n var label = labels.get_za3lpa$(i_0 % labels.size);\n var labelOffset = this.tickLabelOffset_0(i_0);\n i_0 = i_0 + 1 | 0;\n var group = this.buildTick_0(label, labelOffset, addGridLine ? this.gridLineLength.get() : 0.0);\n tmp$_1 = this.orientation_0.get();\n if (equals(tmp$_1, Orientation$LEFT_getInstance()) || equals(tmp$_1, Orientation$RIGHT_getInstance()))\n svg.SvgUtils.transformTranslate_pw34rw$(group, 0.0, br);\n else if (equals(tmp$_1, Orientation$TOP_getInstance()) || equals(tmp$_1, Orientation$BOTTOM_getInstance()))\n svg.SvgUtils.transformTranslate_pw34rw$(group, br, 0.0);\n else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n rootElement.children().add_11rb$(group);\n }\n }}if (axisLine != null) {\n rootElement.children().add_11rb$(axisLine);\n }};\n AxisComponent.prototype.buildTick_0 = function (label, labelOffset, gridLineLength) {\n var tmp$;\n var tickMark = null;\n if (this.tickMarksEnabled().get()) {\n tickMark = new SvgLineElement();\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickMarkWidth, tickMark.strokeWidth()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0, tickMark.strokeColor()));\n }var tickLabel = null;\n if (this.tickLabelsEnabled().get()) {\n tickLabel = new TextLabel(label);\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0, tickLabel.textColor()));\n }var gridLine = null;\n if (gridLineLength > 0) {\n gridLine = new SvgLineElement();\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineColor, gridLine.strokeColor()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineWidth, gridLine.strokeWidth()));\n }var markLength = this.tickMarkLength.get();\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(-markLength);\n tickMark.y2().set_11rb$(0.0);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(gridLineLength);\n gridLine.y2().set_11rb$(0.0);\n }} else if (equals(tmp$, Orientation$RIGHT_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(markLength);\n tickMark.y2().set_11rb$(0.0);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(-gridLineLength);\n gridLine.y2().set_11rb$(0.0);\n }} else if (equals(tmp$, Orientation$TOP_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(0.0);\n tickMark.y2().set_11rb$(-markLength);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(0.0);\n gridLine.y2().set_11rb$(gridLineLength);\n }} else if (equals(tmp$, Orientation$BOTTOM_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(0.0);\n tickMark.y2().set_11rb$(markLength);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(0.0);\n gridLine.y2().set_11rb$(-gridLineLength);\n }} else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n var g = new SvgGElement();\n if (gridLine != null) {\n g.children().add_11rb$(gridLine);\n }if (tickMark != null) {\n g.children().add_11rb$(tickMark);\n }if (tickLabel != null) {\n tickLabel.moveTo_lu1900$(labelOffset.x, labelOffset.y);\n tickLabel.setHorizontalAnchor_ja80zo$(this.tickLabelHorizontalAnchor.get());\n tickLabel.setVerticalAnchor_yaudma$(this.tickLabelVerticalAnchor.get());\n tickLabel.rotate_14dthe$(this.tickLabelRotationDegree.get());\n g.children().add_11rb$(tickLabel.rootGroup);\n }g.addClass_61zpoe$(Style_getInstance().TICK);\n return g;\n };\n AxisComponent.prototype.tickMarkLength_0 = function () {\n var tmp$;\n if (this.myTickMarksEnabled_0.get()) {\n tmp$ = this.tickMarkLength.get();\n } else {\n tmp$ = 0.0;\n }\n return tmp$;\n };\n AxisComponent.prototype.tickLabelDistance_0 = function () {\n return this.tickMarkLength_0() + this.tickMarkPadding.get();\n };\n AxisComponent.prototype.tickLabelBaseOffset_0 = function () {\n var tmp$, tmp$_0;\n var distance = this.tickLabelDistance_0();\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance()))\n tmp$_0 = new DoubleVector(-distance, 0.0);\n else if (equals(tmp$, Orientation$RIGHT_getInstance()))\n tmp$_0 = new DoubleVector(distance, 0.0);\n else if (equals(tmp$, Orientation$TOP_getInstance()))\n tmp$_0 = new DoubleVector(0.0, -distance);\n else if (equals(tmp$, Orientation$BOTTOM_getInstance()))\n tmp$_0 = new DoubleVector(0.0, distance);\n else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n return tmp$_0;\n };\n AxisComponent.prototype.tickLabelOffset_0 = function (tickIndex) {\n var additionalOffsets = this.tickLabelOffsets.get();\n var additionalOffset = additionalOffsets != null ? additionalOffsets.get_za3lpa$(tickIndex) : DoubleVector.Companion.ZERO;\n return this.tickLabelBaseOffset_0().add_gpjtzr$(additionalOffset);\n };\n AxisComponent.prototype.breaksEnabled_0 = function () {\n return this.myTickMarksEnabled_0.get() || this.myTickLabelsEnabled_0.get();\n };\n AxisComponent.prototype.tickMarksEnabled = function () {\n return this.myTickMarksEnabled_0;\n };\n AxisComponent.prototype.tickLabelsEnabled = function () {\n return this.myTickLabelsEnabled_0;\n };\n AxisComponent.prototype.axisLineEnabled = function () {\n return this.myAxisLineEnabled_0;\n };\n function AxisComponent_init$asPropertyChangedEventSource($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, EventSource) ? tmp$ : throwCCE();\n }\n AxisComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisComponent',\n interfaces: [SvgComponent]\n };\n function ColorBarComponent(spec) {\n LegendBox.call(this);\n this.spec_xr0de$_0 = spec;\n }\n Object.defineProperty(ColorBarComponent.prototype, 'spec', {\n get: function () {\n return this.spec_xr0de$_0;\n }\n });\n ColorBarComponent.prototype.appendGuideContent_26jijc$ = function (contentRoot) {\n var tmp$, tmp$_0;\n var layout = this.spec.layout;\n var guideBarGroup = new SvgGElement();\n var barBounds = layout.barBounds;\n var horizontal = layout.isHorizontal;\n this.addColorBar_0(guideBarGroup, this.spec.domain, this.spec.scale, this.spec.binCount, barBounds, layout.barLengthExpand, horizontal, this.spec.reverse);\n if (horizontal)\n tmp$ = barBounds.height;\n else\n tmp$ = barBounds.width;\n var barThickness = tmp$;\n var tickLength = barThickness / 5;\n var breakInfos = layout.breakInfos_8be2vx$.iterator();\n tmp$_0 = this.spec.breaks.iterator();\n while (tmp$_0.hasNext()) {\n var br = tmp$_0.next();\n var brInfo = breakInfos.next();\n var tickLocation = brInfo.tickLocation;\n var tickMarkPoints = ArrayList_init();\n if (horizontal) {\n var tickX = barBounds.left + tickLocation;\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.top));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.top + tickLength));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.bottom - tickLength));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.bottom));\n } else {\n var tickY = barBounds.top + tickLocation;\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.left, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.left + tickLength, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.right - tickLength, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.right, tickY));\n }\n this.addTickMark_0(guideBarGroup, tickMarkPoints.get_za3lpa$(0), tickMarkPoints.get_za3lpa$(1));\n this.addTickMark_0(guideBarGroup, tickMarkPoints.get_za3lpa$(2), tickMarkPoints.get_za3lpa$(3));\n var label = new TextLabel(br.label);\n label.setHorizontalAnchor_ja80zo$(brInfo.labelHorizontalAnchor);\n label.setVerticalAnchor_yaudma$(brInfo.labelVerticalAnchor);\n label.moveTo_lu1900$(brInfo.labelLocation.x, brInfo.labelLocation.y + barBounds.top);\n guideBarGroup.children().add_11rb$(label.rootGroup);\n }\n guideBarGroup.children().add_11rb$(LegendBox$Companion_getInstance().createBorder_a5dgib$(barBounds, this.spec.theme.backgroundFill(), 1.0));\n if (this.debug) {\n var graphBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, layout.graphSize);\n guideBarGroup.children().add_11rb$(LegendBox$Companion_getInstance().createBorder_a5dgib$(graphBounds, Color.Companion.DARK_BLUE, 1.0));\n }contentRoot.children().add_11rb$(guideBarGroup);\n return layout.size;\n };\n ColorBarComponent.prototype.addColorBar_0 = function (g, domain, scale_0, numBins, barBounds, barLengthExpand, horizontal, reverse_0) {\n var tmp$;\n var domainSpan = data_0.SeriesUtil.span_4fzjta$(domain);\n var stepCount = JsMath.max(2, numBins);\n var step = domainSpan / stepCount;\n var v = domain.lowerEnd + step / 2;\n var domainValues = ArrayList_init();\n for (var i = 0; i < stepCount; i++) {\n domainValues.add_11rb$(v + step * i);\n }\n if (reverse_0) {\n reverse(domainValues);\n }var colors = scale.ScaleUtil.map_9ksyxk$(domainValues, scale_0);\n if (horizontal)\n tmp$ = barBounds.width;\n else\n tmp$ = barBounds.height;\n var barLength = tmp$;\n var effectiveBarLength = barLength - barLengthExpand * 2;\n var segmentStep = effectiveBarLength / stepCount;\n var segmentLeft = barBounds.left;\n var segmentRight = barBounds.right;\n var segmentBottom = barBounds.bottom;\n var segmentTop = barBounds.top;\n var i_0 = 0;\n for (var tmp$_0 = colors.iterator(); tmp$_0.hasNext(); ++i_0) {\n var color = tmp$_0.next();\n var r = SvgRectElement_init_0(segmentLeft, segmentTop, segmentRight - segmentLeft, segmentBottom - segmentTop);\n r.strokeWidth().set_11rb$(0.0);\n r.fillColor().set_11rb$(color);\n g.children().add_11rb$(r);\n if (horizontal) {\n segmentLeft += segmentStep;\n } else {\n segmentTop += segmentStep;\n }\n if (i_0 === 0) {\n if (horizontal) {\n segmentLeft += barLengthExpand;\n } else {\n segmentTop += barLengthExpand;\n }\n }}\n };\n ColorBarComponent.prototype.addTickMark_0 = function (g, p0, p1) {\n var line = SvgLineElement_init(p0.x, p0.y, p1.x, p1.y);\n line.strokeWidth().set_11rb$(1.0);\n line.strokeColor().set_11rb$(this.spec.theme.backgroundFill());\n g.children().add_11rb$(line);\n };\n ColorBarComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponent',\n interfaces: [LegendBox]\n };\n function ColorBarComponentLayout(title, domain, breaks, guideBarSize, legendDirection, reverse) {\n ColorBarComponentLayout$Companion_getInstance();\n LegendBoxLayout.call(this, title, legendDirection);\n this.guideBarSize = guideBarSize;\n this.barBounds_qhvd9h$_0 = null;\n this.barLengthExpand = 2.0;\n this.breakInfos_8be2vx$ = null;\n var guideBarLength = this.guideBarLength;\n var targetRange = new ClosedRange(0.0 + this.barLengthExpand, guideBarLength - this.barLengthExpand);\n var mapper = scale.Mappers.linear_1jkouz$(domain, targetRange, reverse);\n var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$;\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var tickLocation = mapper(item.domainValue);\n tmp$_0.call(destination, this.createBreakInfo_14dthe$(tickLocation));\n }\n this.breakInfos_8be2vx$ = destination;\n this.barBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, this.guideBarSize);\n }\n Object.defineProperty(ColorBarComponentLayout.prototype, 'barBounds', {\n configurable: true,\n get: function () {\n return this.barBounds_qhvd9h$_0;\n },\n set: function (barBounds) {\n this.barBounds_qhvd9h$_0 = barBounds;\n }\n });\n function ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, labelHorizontalAnchor, labelVerticalAnchor) {\n this.tickLocation = tickLocation;\n this.labelLocation = labelLocation;\n this.labelHorizontalAnchor = labelHorizontalAnchor;\n this.labelVerticalAnchor = labelVerticalAnchor;\n }\n ColorBarComponentLayout$BreakInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreakInfo',\n interfaces: []\n };\n function ColorBarComponentLayout$HorizontalLayout(title, domain, breaks, barSize, reverse) {\n ColorBarComponentLayout.call(this, title, domain, breaks, barSize, LegendDirection$HORIZONTAL_getInstance(), reverse);\n this.graphSize_4lks14$_0 = null;\n this.graphSize_4lks14$_0 = new DoubleVector(this.guideBarSize.x, this.guideBarSize.y + this.labelDistance_0 + LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n }\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n return this.graphSize_4lks14$_0;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'labelDistance_0', {\n configurable: true,\n get: function () {\n return LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height() / 3;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'guideBarLength', {\n configurable: true,\n get: function () {\n return this.guideBarSize.x;\n }\n });\n ColorBarComponentLayout$HorizontalLayout.prototype.createBreakInfo_14dthe$ = function (tickLocation) {\n var labelLocation = new DoubleVector(tickLocation, this.guideBarSize.y + this.labelDistance_0);\n return new ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, TextLabel$HorizontalAnchor.MIDDLE, TextLabel$VerticalAnchor.TOP);\n };\n ColorBarComponentLayout$HorizontalLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalLayout',\n interfaces: [ColorBarComponentLayout]\n };\n function ColorBarComponentLayout$VerticalLayout(title, domain, breaks, barSize, reverse) {\n ColorBarComponentLayout.call(this, title, domain, breaks, barSize, LegendDirection$VERTICAL_getInstance(), reverse);\n this.graphSize_ld8mnu$_0 = null;\n if (!!breaks.isEmpty()) {\n var message = 'Colorbar VerticalLayout received empty breaks list.';\n throw IllegalStateException_init(message.toString());\n }var destination = ArrayList_init_1(collectionSizeOrDefault(breaks, 10));\n var tmp$;\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item.label.length);\n }\n var iterator = destination.iterator();\n if (!iterator.hasNext())\n throw NoSuchElementException_init();\n var it = iterator.next();\n var maxValue = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(it);\n while (iterator.hasNext()) {\n var it_0 = iterator.next();\n var v = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(it_0);\n maxValue = JsMath.max(maxValue, v);\n }\n var maxLabelWidth = maxValue;\n this.graphSize_ld8mnu$_0 = new DoubleVector(this.guideBarSize.x + this.labelDistance_0 + maxLabelWidth, this.guideBarSize.y);\n }\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n return this.graphSize_ld8mnu$_0;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'labelDistance_0', {\n configurable: true,\n get: function () {\n return LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(1) / 2;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'guideBarLength', {\n configurable: true,\n get: function () {\n return this.guideBarSize.y;\n }\n });\n ColorBarComponentLayout$VerticalLayout.prototype.createBreakInfo_14dthe$ = function (tickLocation) {\n var labelLocation = new DoubleVector(this.guideBarSize.x + this.labelDistance_0, tickLocation);\n return new ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, TextLabel$HorizontalAnchor.LEFT, TextLabel$VerticalAnchor.CENTER);\n };\n ColorBarComponentLayout$VerticalLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalLayout',\n interfaces: [ColorBarComponentLayout]\n };\n function ColorBarComponentLayout$Companion() {\n ColorBarComponentLayout$Companion_instance = this;\n }\n ColorBarComponentLayout$Companion.prototype.horizontal_v3yhow$ = function (title, domain, breaks, barSize, reverse) {\n return new ColorBarComponentLayout$HorizontalLayout(title, domain, breaks, barSize, reverse);\n };\n ColorBarComponentLayout$Companion.prototype.vertical_v3yhow$ = function (title, domain, breaks, barSize, reverse) {\n return new ColorBarComponentLayout$VerticalLayout(title, domain, breaks, barSize, reverse);\n };\n ColorBarComponentLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarComponentLayout$Companion_instance = null;\n function ColorBarComponentLayout$Companion_getInstance() {\n if (ColorBarComponentLayout$Companion_instance === null) {\n new ColorBarComponentLayout$Companion();\n }return ColorBarComponentLayout$Companion_instance;\n }\n ColorBarComponentLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponentLayout',\n interfaces: [LegendBoxLayout]\n };\n function ColorBarComponentSpec(title, domain, breaks, scale, binCount, theme, layout, reverse) {\n ColorBarComponentSpec$Companion_getInstance();\n LegendBoxSpec.call(this, title, theme, reverse);\n this.domain = domain;\n this.breaks = breaks;\n this.scale = scale;\n this.binCount = binCount;\n this.layout_smwmum$_0 = layout;\n }\n Object.defineProperty(ColorBarComponentSpec.prototype, 'layout', {\n get: function () {\n return this.layout_smwmum$_0;\n }\n });\n function ColorBarComponentSpec$Companion() {\n ColorBarComponentSpec$Companion_instance = this;\n this.DEF_NUM_BIN = 20;\n this.DEF_BAR_THICKNESS_0 = 1.0;\n this.DEF_BAR_LENGTH_0 = 5.0;\n }\n ColorBarComponentSpec$Companion.prototype.barAbsoluteSize_kkcal5$ = function (horizontal, theme) {\n var tmp$;\n if (horizontal)\n tmp$ = new DoubleVector(this.DEF_BAR_LENGTH_0 * theme.keySize(), this.DEF_BAR_THICKNESS_0 * theme.keySize());\n else\n tmp$ = new DoubleVector(this.DEF_BAR_THICKNESS_0 * theme.keySize(), this.DEF_BAR_LENGTH_0 * theme.keySize());\n return tmp$;\n };\n ColorBarComponentSpec$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarComponentSpec$Companion_instance = null;\n function ColorBarComponentSpec$Companion_getInstance() {\n if (ColorBarComponentSpec$Companion_instance === null) {\n new ColorBarComponentSpec$Companion();\n }return ColorBarComponentSpec$Companion_instance;\n }\n ColorBarComponentSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponentSpec',\n interfaces: [LegendBoxSpec]\n };\n function LegendArrangement(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LegendArrangement_initFields() {\n LegendArrangement_initFields = function () {\n };\n LegendArrangement$HORIZONTAL_instance = new LegendArrangement('HORIZONTAL', 0);\n LegendArrangement$VERTICAL_instance = new LegendArrangement('VERTICAL', 1);\n }\n var LegendArrangement$HORIZONTAL_instance;\n function LegendArrangement$HORIZONTAL_getInstance() {\n LegendArrangement_initFields();\n return LegendArrangement$HORIZONTAL_instance;\n }\n var LegendArrangement$VERTICAL_instance;\n function LegendArrangement$VERTICAL_getInstance() {\n LegendArrangement_initFields();\n return LegendArrangement$VERTICAL_instance;\n }\n LegendArrangement.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendArrangement',\n interfaces: [Enum]\n };\n function LegendArrangement$values() {\n return [LegendArrangement$HORIZONTAL_getInstance(), LegendArrangement$VERTICAL_getInstance()];\n }\n LegendArrangement.values = LegendArrangement$values;\n function LegendArrangement$valueOf(name) {\n switch (name) {\n case 'HORIZONTAL':\n return LegendArrangement$HORIZONTAL_getInstance();\n case 'VERTICAL':\n return LegendArrangement$VERTICAL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.LegendArrangement.' + name);\n }\n }\n LegendArrangement.valueOf_61zpoe$ = LegendArrangement$valueOf;\n function LegendBox() {\n LegendBox$Companion_getInstance();\n SvgComponent.call(this);\n this.debug = false;\n }\n Object.defineProperty(LegendBox.prototype, 'title_aaysjy$_0', {\n configurable: true,\n get: function () {\n return this.spec.title;\n }\n });\n Object.defineProperty(LegendBox.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.spec.size;\n }\n });\n LegendBox.prototype.hasTitle_kmjss0$_0 = function () {\n return this.spec.hasTitle();\n };\n LegendBox.prototype.buildComponent = function () {\n this.addClassName_61zpoe$(Style_getInstance().LEGEND);\n var outerBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, this.spec.size);\n this.addRectangle_7omvup$(this.spec.innerBounds, this.spec.theme.backgroundFill());\n var innerGroup = new SvgGElement();\n innerGroup.transform().set_11rb$(SvgComponent.Companion.buildTransform_e1sv3v$(this.spec.contentOrigin, 0.0));\n var l = this.spec.layout;\n if (this.hasTitle_kmjss0$_0()) {\n var label = this.createTitleLabel_d65hob$_0(l.titleLocation, l.titleHorizontalAnchor, l.titleVerticalAnchor);\n innerGroup.children().add_11rb$(label.rootGroup);\n }var graphGroup = new SvgGElement();\n graphGroup.transform().set_11rb$(SvgComponent.Companion.buildTransform_e1sv3v$(l.graphOrigin, 0.0));\n this.appendGuideContent_26jijc$(graphGroup);\n innerGroup.children().add_11rb$(graphGroup);\n if (this.debug) {\n this.addBorder_a5dgib$(outerBounds, Color.Companion.CYAN, 1.0);\n var rect = SvgRectElement_init(this.spec.innerBounds);\n rect.fillColor().set_11rb$(Color.Companion.BLACK);\n rect.strokeWidth().set_11rb$(0.0);\n rect.fillOpacity().set_11rb$(0.1);\n this.add_26jijc$(rect);\n this.addBorder_a5dgib$(this.spec.contentBounds, Color.Companion.DARK_MAGENTA, 1.0);\n this.addBorder_a5dgib$(l.titleBounds.add_gpjtzr$(this.spec.contentOrigin), Color.Companion.MAGENTA, 1.0);\n }this.add_26jijc$(innerGroup);\n };\n LegendBox.prototype.addBorder_a5dgib$ = function (bounds, strokeColor, strokeWidth) {\n this.add_26jijc$(LegendBox$Companion_getInstance().createBorder_a5dgib$(bounds, strokeColor, strokeWidth));\n };\n LegendBox.prototype.addRectangle_7omvup$ = function (bounds, fillColor) {\n this.add_26jijc$(LegendBox$Companion_getInstance().createRectangle_0(bounds, fillColor));\n };\n LegendBox.prototype.createTitleLabel_d65hob$_0 = function (origin, horizontalAnchor, verticalAnchor) {\n var label = new TextLabel(this.title_aaysjy$_0);\n label.addClassName_61zpoe$(Style_getInstance().LEGEND_TITLE);\n label.setHorizontalAnchor_ja80zo$(horizontalAnchor);\n label.setVerticalAnchor_yaudma$(verticalAnchor);\n label.moveTo_gpjtzr$(origin);\n return label;\n };\n function LegendBox$Companion() {\n LegendBox$Companion_instance = this;\n }\n LegendBox$Companion.prototype.createBorder_a5dgib$ = function (bounds, strokeColor, strokeWidth) {\n var rect = SvgRectElement_init(bounds);\n rect.strokeColor().set_11rb$(strokeColor);\n rect.strokeWidth().set_11rb$(strokeWidth);\n rect.fillOpacity().set_11rb$(0.0);\n return rect;\n };\n LegendBox$Companion.prototype.createRectangle_0 = function (bounds, fillColor) {\n var rect = SvgRectElement_init(bounds);\n rect.fillColor().set_11rb$(fillColor);\n return rect;\n };\n LegendBox$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBox$Companion_instance = null;\n function LegendBox$Companion_getInstance() {\n if (LegendBox$Companion_instance === null) {\n new LegendBox$Companion();\n }return LegendBox$Companion_instance;\n }\n LegendBox.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBox',\n interfaces: [SvgComponent]\n };\n function LegendBoxLayout(title, legendDirection) {\n LegendBoxLayout$Companion_getInstance();\n this.title_47v7cs$_0 = title;\n this.isHorizontal = legendDirection === LegendDirection$HORIZONTAL_getInstance();\n this.titleHorizontalAnchor = TextLabel$HorizontalAnchor.LEFT;\n var tmp$;\n if (this.isHorizontal) {\n tmp$ = TextLabel$VerticalAnchor.CENTER;\n } else {\n tmp$ = TextLabel$VerticalAnchor.TOP;\n }\n this.titleVerticalAnchor = tmp$;\n }\n Object.defineProperty(LegendBoxLayout.prototype, 'titleBounds', {\n configurable: true,\n get: function () {\n var origin = this.titleLocation;\n var size = LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0);\n if (this.isHorizontal) {\n origin = new DoubleVector(origin.x, origin.y - size.y / 2);\n }return new DoubleRectangle(origin, size);\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'graphOrigin', {\n configurable: true,\n get: function () {\n if (this.isHorizontal)\n return new DoubleVector(LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0).x, 0.0);\n else\n return new DoubleVector(0.0, LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0).y);\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'size', {\n configurable: true,\n get: function () {\n var graphBounds = new DoubleRectangle(this.graphOrigin, this.graphSize);\n var titleAndContent = (new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO)).union_wthzt5$(this.titleBounds).union_wthzt5$(graphBounds);\n return titleAndContent.dimension;\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'titleLocation', {\n configurable: true,\n get: function () {\n if (this.isHorizontal) {\n var graphSize = this.graphSize;\n return new DoubleVector(0.0, graphSize.y / 2);\n } else {\n var y = -LegendBoxLayout$Companion_getInstance().TITLE_SPEC_0.height() / 3;\n return new DoubleVector(0.0, y);\n }\n }\n });\n function LegendBoxLayout$Companion() {\n LegendBoxLayout$Companion_instance = this;\n this.TITLE_SPEC_0 = PlotLabelSpec$LEGEND_TITLE_getInstance();\n this.LABEL_SPEC_8be2vx$ = PlotLabelSpec$LEGEND_ITEM_getInstance();\n }\n LegendBoxLayout$Companion.prototype.titleSize_0 = function (s) {\n var tmp$;\n if (isBlank(s))\n tmp$ = DoubleVector.Companion.ZERO;\n else\n tmp$ = this.TITLE_SPEC_0.dimensions_za3lpa$(s.length);\n return tmp$;\n };\n LegendBoxLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBoxLayout$Companion_instance = null;\n function LegendBoxLayout$Companion_getInstance() {\n if (LegendBoxLayout$Companion_instance === null) {\n new LegendBoxLayout$Companion();\n }return LegendBoxLayout$Companion_instance;\n }\n LegendBoxLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxLayout',\n interfaces: []\n };\n function LegendBoxSpec(title, theme, reverse) {\n this.title = title;\n this.theme = theme;\n this.reverse = reverse;\n this.contentOrigin = null;\n this.fullContentExtend_5hau13$_0 = null;\n this.innerOrigin_3w1y5t$_0 = null;\n this.innerContentExtend_wllzuc$_0 = null;\n var contentExpand = this.theme.margin() + this.theme.padding();\n this.contentOrigin = new DoubleVector(contentExpand, contentExpand);\n this.fullContentExtend_5hau13$_0 = new DoubleVector(contentExpand * 2, contentExpand * 2);\n this.innerOrigin_3w1y5t$_0 = new DoubleVector(this.theme.margin(), this.theme.margin());\n this.innerContentExtend_wllzuc$_0 = new DoubleVector(this.theme.padding() * 2, this.theme.padding() * 2);\n }\n Object.defineProperty(LegendBoxSpec.prototype, 'contentSize_cb71ch$_0', {\n configurable: true,\n get: function () {\n return this.layout.size;\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.contentSize_cb71ch$_0.add_gpjtzr$(this.fullContentExtend_5hau13$_0);\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'innerBounds', {\n configurable: true,\n get: function () {\n return new DoubleRectangle(this.innerOrigin_3w1y5t$_0, this.contentSize_cb71ch$_0.add_gpjtzr$(this.innerContentExtend_wllzuc$_0));\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'contentBounds', {\n configurable: true,\n get: function () {\n return new DoubleRectangle(this.contentOrigin, this.contentSize_cb71ch$_0);\n }\n });\n LegendBoxSpec.prototype.hasTitle = function () {\n return !isBlank(this.title);\n };\n LegendBoxSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxSpec',\n interfaces: []\n };\n function LegendBreak(label) {\n LegendBreak$Companion_getInstance();\n this.label = label;\n this.myLayers_0 = ArrayList_init();\n }\n Object.defineProperty(LegendBreak.prototype, 'minimumKeySize', {\n configurable: true,\n get: function () {\n var tmp$;\n var minSize = DoubleVector.Companion.ZERO;\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var layerMinKeySize = layer.keyElementFactory.minimumKeySize_l6g9mh$(layer.dataPoint);\n minSize = minSize.max_gpjtzr$(layerMinKeySize);\n }\n return minSize;\n }\n });\n Object.defineProperty(LegendBreak.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myLayers_0.isEmpty();\n }\n });\n LegendBreak.prototype.addLayer_w0u015$ = function (dataPoint, keyElementFactory) {\n this.myLayers_0.add_11rb$(new LegendBreak$LegendBreakLayer(dataPoint, keyElementFactory));\n };\n LegendBreak.prototype.createKeyElement_gpjtzr$ = function (size) {\n var tmp$;\n var g = new SvgGElement();\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var keyElement = layer.keyElementFactory.createKeyElement_s1fn0c$(layer.dataPoint, size);\n g.children().add_11rb$(keyElement);\n }\n return g;\n };\n function LegendBreak$LegendBreakLayer(dataPoint, keyElementFactory) {\n this.dataPoint = dataPoint;\n this.keyElementFactory = keyElementFactory;\n }\n LegendBreak$LegendBreakLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBreakLayer',\n interfaces: []\n };\n function LegendBreak$Companion() {\n LegendBreak$Companion_instance = this;\n }\n LegendBreak$Companion.prototype.simple_998ysp$ = function (label, dataPoint, keyElementFactory) {\n var br = new LegendBreak(label);\n br.addLayer_w0u015$(dataPoint, keyElementFactory);\n return br;\n };\n LegendBreak$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBreak$Companion_instance = null;\n function LegendBreak$Companion_getInstance() {\n if (LegendBreak$Companion_instance === null) {\n new LegendBreak$Companion();\n }return LegendBreak$Companion_instance;\n }\n LegendBreak.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBreak',\n interfaces: []\n };\n function LegendComponent(spec) {\n LegendBox.call(this);\n this.spec_8zhhsr$_0 = spec;\n }\n Object.defineProperty(LegendComponent.prototype, 'spec', {\n get: function () {\n return this.spec_8zhhsr$_0;\n }\n });\n LegendComponent.prototype.appendGuideContent_26jijc$ = function (contentRoot) {\n var tmp$;\n var layout = this.spec.layout;\n var keyLabelBoxes = layout.keyLabelBoxes.iterator();\n var labelBoxes = layout.labelBoxes.iterator();\n tmp$ = this.spec.breaks_8be2vx$.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var keyLabelBox = keyLabelBoxes.next();\n var labelBox = labelBoxes.next();\n var breakElement = this.createBreakElement_0(br, layout.keySize, keyLabelBox, labelBox);\n contentRoot.children().add_11rb$(breakElement);\n }\n return layout.size;\n };\n LegendComponent.prototype.createBreakElement_0 = function (br, keySize, keyLabelBox, labelBox) {\n var breakComponent = new GroupComponent();\n breakComponent.add_26jijc$(this.createKeyElement_0(br, keySize));\n var label = new TextLabel(br.label);\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.LEFT);\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n label.moveTo_gpjtzr$(labelBox.origin.add_gpjtzr$(new DoubleVector(0.0, labelBox.height / 2)));\n breakComponent.add_8icvvv$(label);\n breakComponent.moveTo_gpjtzr$(keyLabelBox.origin);\n return breakComponent.rootGroup;\n };\n LegendComponent.prototype.createKeyElement_0 = function (legendBreak, size) {\n var g = new SvgGElement();\n var innerSize = new DoubleVector(size.x - 2, size.y - 2);\n var backgroundFill = this.spec.theme.backgroundFill();\n var backgroundRect = SvgRectElement_init_0(1.0, 1.0, innerSize.x, innerSize.y);\n backgroundRect.strokeWidth().set_11rb$(1.0);\n backgroundRect.strokeColor().set_11rb$(backgroundFill);\n backgroundRect.fillColor().set_11rb$(backgroundFill);\n g.children().add_11rb$(backgroundRect);\n var keyElement = legendBreak.createKeyElement_gpjtzr$(innerSize);\n var keyElementTransform = SvgComponent.Companion.buildTransform_e1sv3v$(new DoubleVector(1.0, 1.0), 0.0);\n keyElement.transform().set_11rb$(keyElementTransform);\n g.children().add_11rb$(keyElement);\n var frame = SvgRectElement_init_0(0.0, 0.0, size.x, size.y);\n frame.strokeWidth().set_11rb$(1.0);\n frame.strokeColor().set_11rb$(backgroundFill);\n frame.fill().set_11rb$(SvgColors.NONE);\n g.children().add_11rb$(frame);\n return g;\n };\n LegendComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponent',\n interfaces: [LegendBox]\n };\n function LegendComponentLayout(title, breaks, keySize, legendDirection) {\n LegendComponentLayout$Companion_getInstance();\n LegendBoxLayout.call(this, title, legendDirection);\n this.breaks = breaks;\n this.keySize = keySize;\n this.myContentSize_8rvo9o$_0 = null;\n this.myKeyLabelBoxes_uk7fn2$_0 = ArrayList_init();\n this.myLabelBoxes_9jhh53$_0 = ArrayList_init();\n this.isFillByRow = false;\n this.rowCount_kvp0d1$_0 = 0;\n this.colCount_nojzuj$_0 = 0;\n }\n Object.defineProperty(LegendComponentLayout.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_kvp0d1$_0;\n },\n set: function (rowCount) {\n if (!(rowCount > 0)) {\n var message = 'Row count must be greater than 0, was ' + rowCount;\n throw IllegalStateException_init(message.toString());\n }this.rowCount_kvp0d1$_0 = rowCount;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_nojzuj$_0;\n },\n set: function (colCount) {\n if (!(colCount > 0)) {\n var message = 'Col count must be greater than 0, was ' + colCount;\n throw IllegalStateException_init(message.toString());\n }this.colCount_nojzuj$_0 = colCount;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return ensureNotNull(this.myContentSize_8rvo9o$_0);\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'keyLabelBoxes', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return this.myKeyLabelBoxes_uk7fn2$_0;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'labelBoxes', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return this.myLabelBoxes_9jhh53$_0;\n }\n });\n LegendComponentLayout.prototype.ensureInited_chkycd$_0 = function () {\n if (this.myContentSize_8rvo9o$_0 == null) {\n this.doLayout_zctv6z$_0();\n }};\n LegendComponentLayout.prototype.doLayout_zctv6z$_0 = function () {\n var tmp$;\n var labelHeight = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height();\n var labelLeftMargin = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(1) / 2;\n var labelHOffset = this.keySize.x + labelLeftMargin;\n var labelVOffset = (this.keySize.y - labelHeight) / 2;\n var contentOrigin = DoubleVector.Companion.ZERO;\n var breakBoxBounds = null;\n tmp$ = this.breaks;\n for (var i = 0; i !== tmp$.size; ++i) {\n var tmp$_0;\n var labelSize = this.labelSize_za3lpa$(i);\n var breakBoxSize = new DoubleVector(labelHOffset + labelSize.x, this.keySize.y);\n breakBoxBounds = new DoubleRectangle((tmp$_0 = breakBoxBounds != null ? this.breakBoxOrigin_b4d9xv$(i, breakBoxBounds) : null) != null ? tmp$_0 : contentOrigin, breakBoxSize);\n this.myKeyLabelBoxes_uk7fn2$_0.add_11rb$(breakBoxBounds);\n this.myLabelBoxes_9jhh53$_0.add_11rb$(DoubleRectangle_init(labelHOffset, labelVOffset, labelSize.x, labelSize.y));\n }\n this.myContentSize_8rvo9o$_0 = GeometryUtil_getInstance().union_a7nkjf$(new DoubleRectangle(contentOrigin, DoubleVector.Companion.ZERO), this.myKeyLabelBoxes_uk7fn2$_0).dimension;\n };\n function LegendComponentLayout$MyHorizontal(title, breaks, keySize) {\n LegendComponentLayout.call(this, title, breaks, keySize, LegendDirection$HORIZONTAL_getInstance());\n this.colCount = breaks.size;\n this.rowCount = 1;\n }\n LegendComponentLayout$MyHorizontal.prototype.breakBoxOrigin_b4d9xv$ = function (index, prevBreakBoxBounds) {\n return new DoubleVector(prevBreakBoxBounds.right, 0.0);\n };\n LegendComponentLayout$MyHorizontal.prototype.labelSize_za3lpa$ = function (index) {\n var label = this.breaks.get_za3lpa$(index).label;\n return new DoubleVector(LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(label.length), LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n };\n LegendComponentLayout$MyHorizontal.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyHorizontal',\n interfaces: [LegendComponentLayout]\n };\n function LegendComponentLayout$MyHorizontalMultiRow(title, breaks, keySize) {\n LegendComponentLayout$MyMultiRow.call(this, title, breaks, keySize, LegendDirection$HORIZONTAL_getInstance());\n this.colCount = breaks.size;\n this.rowCount = 1;\n }\n LegendComponentLayout$MyHorizontalMultiRow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyHorizontalMultiRow',\n interfaces: [LegendComponentLayout$MyMultiRow]\n };\n function LegendComponentLayout$MyVertical(title, breaks, keySize) {\n LegendComponentLayout$MyMultiRow.call(this, title, breaks, keySize, LegendDirection$VERTICAL_getInstance());\n this.colCount = 1;\n this.rowCount = breaks.size;\n }\n LegendComponentLayout$MyVertical.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyVertical',\n interfaces: [LegendComponentLayout$MyMultiRow]\n };\n function LegendComponentLayout$MyMultiRow(title, breaks, keySize, legendDirection) {\n LegendComponentLayout.call(this, title, breaks, keySize, legendDirection);\n this.myMaxLabelWidth_0 = 0.0;\n var tmp$;\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var a = this.myMaxLabelWidth_0;\n var b = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(br.label.length);\n this.myMaxLabelWidth_0 = JsMath.max(a, b);\n }\n }\n LegendComponentLayout$MyMultiRow.prototype.breakBoxOrigin_b4d9xv$ = function (index, prevBreakBoxBounds) {\n var tmp$, tmp$_0;\n if (this.isFillByRow) {\n if (index % this.colCount === 0) {\n tmp$ = new DoubleVector(0.0, prevBreakBoxBounds.bottom);\n } else\n tmp$ = new DoubleVector(prevBreakBoxBounds.right, prevBreakBoxBounds.top);\n return tmp$;\n }if (index % this.rowCount === 0) {\n tmp$_0 = new DoubleVector(prevBreakBoxBounds.right, 0.0);\n } else\n tmp$_0 = new DoubleVector(prevBreakBoxBounds.left, prevBreakBoxBounds.bottom);\n return tmp$_0;\n };\n LegendComponentLayout$MyMultiRow.prototype.labelSize_za3lpa$ = function (index) {\n return new DoubleVector(this.myMaxLabelWidth_0, LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n };\n LegendComponentLayout$MyMultiRow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyMultiRow',\n interfaces: [LegendComponentLayout]\n };\n function LegendComponentLayout$Companion() {\n LegendComponentLayout$Companion_instance = this;\n }\n LegendComponentLayout$Companion.prototype.horizontal_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyHorizontal(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.prototype.horizontalMultiRow_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyHorizontalMultiRow(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.prototype.vertical_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyVertical(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendComponentLayout$Companion_instance = null;\n function LegendComponentLayout$Companion_getInstance() {\n if (LegendComponentLayout$Companion_instance === null) {\n new LegendComponentLayout$Companion();\n }return LegendComponentLayout$Companion_instance;\n }\n LegendComponentLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponentLayout',\n interfaces: [LegendBoxLayout]\n };\n function LegendComponentSpec(title, breaks, theme, layout, reverse) {\n LegendBoxSpec.call(this, title, theme, reverse);\n this.breaks_8be2vx$ = breaks;\n this.layout_ebqbgv$_0 = layout;\n }\n Object.defineProperty(LegendComponentSpec.prototype, 'layout', {\n get: function () {\n return this.layout_ebqbgv$_0;\n }\n });\n LegendComponentSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponentSpec',\n interfaces: [LegendBoxSpec]\n };\n function LegendDirection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LegendDirection_initFields() {\n LegendDirection_initFields = function () {\n };\n LegendDirection$HORIZONTAL_instance = new LegendDirection('HORIZONTAL', 0);\n LegendDirection$VERTICAL_instance = new LegendDirection('VERTICAL', 1);\n LegendDirection$AUTO_instance = new LegendDirection('AUTO', 2);\n }\n var LegendDirection$HORIZONTAL_instance;\n function LegendDirection$HORIZONTAL_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$HORIZONTAL_instance;\n }\n var LegendDirection$VERTICAL_instance;\n function LegendDirection$VERTICAL_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$VERTICAL_instance;\n }\n var LegendDirection$AUTO_instance;\n function LegendDirection$AUTO_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$AUTO_instance;\n }\n LegendDirection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendDirection',\n interfaces: [Enum]\n };\n function LegendDirection$values() {\n return [LegendDirection$HORIZONTAL_getInstance(), LegendDirection$VERTICAL_getInstance(), LegendDirection$AUTO_getInstance()];\n }\n LegendDirection.values = LegendDirection$values;\n function LegendDirection$valueOf(name) {\n switch (name) {\n case 'HORIZONTAL':\n return LegendDirection$HORIZONTAL_getInstance();\n case 'VERTICAL':\n return LegendDirection$VERTICAL_getInstance();\n case 'AUTO':\n return LegendDirection$AUTO_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.LegendDirection.' + name);\n }\n }\n LegendDirection.valueOf_61zpoe$ = LegendDirection$valueOf;\n function LegendJustification(x, y) {\n LegendJustification$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n function LegendJustification$Companion() {\n LegendJustification$Companion_instance = this;\n this.CENTER = new LegendJustification(0.5, 0.5);\n }\n LegendJustification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendJustification$Companion_instance = null;\n function LegendJustification$Companion_getInstance() {\n if (LegendJustification$Companion_instance === null) {\n new LegendJustification$Companion();\n }return LegendJustification$Companion_instance;\n }\n LegendJustification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendJustification',\n interfaces: []\n };\n function LegendPosition(x, y) {\n LegendPosition$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n Object.defineProperty(LegendPosition.prototype, 'isFixed', {\n configurable: true,\n get: function () {\n return this === LegendPosition$Companion_getInstance().LEFT || this === LegendPosition$Companion_getInstance().RIGHT || this === LegendPosition$Companion_getInstance().TOP || this === LegendPosition$Companion_getInstance().BOTTOM;\n }\n });\n Object.defineProperty(LegendPosition.prototype, 'isHidden', {\n configurable: true,\n get: function () {\n return this === LegendPosition$Companion_getInstance().NONE;\n }\n });\n Object.defineProperty(LegendPosition.prototype, 'isOverlay', {\n configurable: true,\n get: function () {\n return !(this.isFixed || this.isHidden);\n }\n });\n function LegendPosition$Companion() {\n LegendPosition$Companion_instance = this;\n this.RIGHT = new LegendPosition(1.0, 0.5);\n this.LEFT = new LegendPosition(0.0, 0.5);\n this.TOP = new LegendPosition(0.5, 1.0);\n this.BOTTOM = new LegendPosition(0.5, 1.0);\n this.NONE = new LegendPosition(kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN);\n }\n LegendPosition$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendPosition$Companion_instance = null;\n function LegendPosition$Companion_getInstance() {\n if (LegendPosition$Companion_instance === null) {\n new LegendPosition$Companion();\n }return LegendPosition$Companion_instance;\n }\n LegendPosition.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendPosition',\n interfaces: []\n };\n function Orientation(name, ordinal, myValue) {\n Enum.call(this);\n this.myValue_3zu241$_0 = myValue;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Orientation_initFields() {\n Orientation_initFields = function () {\n };\n Orientation$LEFT_instance = new Orientation('LEFT', 0, 'LEFT');\n Orientation$RIGHT_instance = new Orientation('RIGHT', 1, 'RIGHT');\n Orientation$TOP_instance = new Orientation('TOP', 2, 'TOP');\n Orientation$BOTTOM_instance = new Orientation('BOTTOM', 3, 'BOTTOM');\n }\n var Orientation$LEFT_instance;\n function Orientation$LEFT_getInstance() {\n Orientation_initFields();\n return Orientation$LEFT_instance;\n }\n var Orientation$RIGHT_instance;\n function Orientation$RIGHT_getInstance() {\n Orientation_initFields();\n return Orientation$RIGHT_instance;\n }\n var Orientation$TOP_instance;\n function Orientation$TOP_getInstance() {\n Orientation_initFields();\n return Orientation$TOP_instance;\n }\n var Orientation$BOTTOM_instance;\n function Orientation$BOTTOM_getInstance() {\n Orientation_initFields();\n return Orientation$BOTTOM_instance;\n }\n Object.defineProperty(Orientation.prototype, 'isHorizontal', {\n configurable: true,\n get: function () {\n return this === Orientation$TOP_getInstance() || this === Orientation$BOTTOM_getInstance();\n }\n });\n Orientation.prototype.toString = function () {\n return 'Orientation{' + \"myValue='\" + this.myValue_3zu241$_0 + String.fromCharCode(39) + String.fromCharCode(125);\n };\n Orientation.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Orientation',\n interfaces: [Enum]\n };\n function Orientation$values() {\n return [Orientation$LEFT_getInstance(), Orientation$RIGHT_getInstance(), Orientation$TOP_getInstance(), Orientation$BOTTOM_getInstance()];\n }\n Orientation.values = Orientation$values;\n function Orientation$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return Orientation$LEFT_getInstance();\n case 'RIGHT':\n return Orientation$RIGHT_getInstance();\n case 'TOP':\n return Orientation$TOP_getInstance();\n case 'BOTTOM':\n return Orientation$BOTTOM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.Orientation.' + name);\n }\n }\n Orientation.valueOf_61zpoe$ = Orientation$valueOf;\n function ContextualMappingProvider() {\n ContextualMappingProvider$Companion_getInstance();\n }\n function ContextualMappingProvider$Companion() {\n ContextualMappingProvider$Companion_instance = this;\n this.NONE = new ContextualMappingProvider$Companion$NONE$ObjectLiteral();\n }\n function ContextualMappingProvider$Companion$NONE$ObjectLiteral() {\n }\n ContextualMappingProvider$Companion$NONE$ObjectLiteral.prototype.createContextualMapping_8fr62e$ = function (dataAccess, dataFrame) {\n return new ContextualMapping(emptyList(), null, null, null, false, false, false, false);\n };\n ContextualMappingProvider$Companion$NONE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContextualMappingProvider]\n };\n ContextualMappingProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContextualMappingProvider$Companion_instance = null;\n function ContextualMappingProvider$Companion_getInstance() {\n if (ContextualMappingProvider$Companion_instance === null) {\n new ContextualMappingProvider$Companion();\n }return ContextualMappingProvider$Companion_instance;\n }\n ContextualMappingProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ContextualMappingProvider',\n interfaces: []\n };\n function GeomInteraction(builder) {\n GeomInteraction$Companion_getInstance();\n this.myLocatorLookupSpace_0 = builder.locatorLookupSpace;\n this.myLocatorLookupStrategy_0 = builder.locatorLookupStrategy;\n this.myTooltipLines_0 = builder.tooltipLines;\n this.myTooltipProperties_0 = builder.tooltipProperties;\n this.myIgnoreInvisibleTargets_0 = builder.isIgnoringInvisibleTargets();\n this.myIsCrosshairEnabled_0 = builder.isCrosshairEnabled;\n }\n GeomInteraction.prototype.createLookupSpec = function () {\n return new GeomTargetLocator$LookupSpec(this.myLocatorLookupSpace_0, this.myLocatorLookupStrategy_0);\n };\n GeomInteraction.prototype.createContextualMapping_8fr62e$ = function (dataAccess, dataFrame) {\n var tmp$ = GeomInteraction$Companion_getInstance();\n var $receiver = this.myTooltipLines_0;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(TooltipLine_init(item));\n }\n return tmp$.createContextualMapping_0(destination, dataAccess, dataFrame, this.myTooltipProperties_0, this.myIgnoreInvisibleTargets_0, this.myIsCrosshairEnabled_0);\n };\n function GeomInteraction$Companion() {\n GeomInteraction$Companion_instance = this;\n }\n GeomInteraction$Companion.prototype.createTestContextualMapping_fdc7hd$ = function (aesListForTooltip, axisAes, outliers, dataAccess, dataFrame, userDefinedValueSources) {\n if (userDefinedValueSources === void 0)\n userDefinedValueSources = null;\n var defaultTooltipLines = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(aesListForTooltip, axisAes, outliers, userDefinedValueSources);\n return this.createContextualMapping_0(defaultTooltipLines, dataAccess, dataFrame, TooltipSpecification$TooltipProperties$Companion_getInstance().NONE, false, false);\n };\n GeomInteraction$Companion.prototype.createContextualMapping_0 = function (tooltipLines, dataAccess, dataFrame, tooltipProperties, ignoreInvisibleTargets, isCrosshairEnabled) {\n var dataContext = new DataContext(dataFrame, dataAccess);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = tooltipLines.iterator();\n loop_label: while (tmp$.hasNext()) {\n var element = tmp$.next();\n var $receiver = element.fields;\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n if (Kotlin.isType(element_0, MappingValue))\n destination_0.add_11rb$(element_0);\n }\n var dataAesList = destination_0;\n var all$result;\n all$break: do {\n var tmp$_1;\n if (Kotlin.isType(dataAesList, Collection) && dataAesList.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$_1 = dataAesList.iterator();\n while (tmp$_1.hasNext()) {\n var element_1 = tmp$_1.next();\n if (!dataAccess.isMapped_896ixz$(element_1.aes)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n if (all$result)\n destination.add_11rb$(element);\n }\n var mappedTooltipLines = destination;\n var tmp$_2;\n tmp$_2 = mappedTooltipLines.iterator();\n while (tmp$_2.hasNext()) {\n var element_2 = tmp$_2.next();\n element_2.initDataContext_rxi9tf$(dataContext);\n }\n var any$result;\n any$break: do {\n var tmp$_3;\n if (Kotlin.isType(mappedTooltipLines, Collection) && mappedTooltipLines.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_3 = mappedTooltipLines.iterator();\n loop_label: while (tmp$_3.hasNext()) {\n var element_3 = tmp$_3.next();\n var $receiver_0 = element_3.fields;\n var predicate = getPropertyCallableRef('isOutlier', 1, function ($receiver) {\n return $receiver.isOutlier;\n });\n var none$result;\n none$break: do {\n var tmp$_4;\n if (Kotlin.isType($receiver_0, Collection) && $receiver_0.isEmpty()) {\n none$result = true;\n break none$break;\n }tmp$_4 = $receiver_0.iterator();\n while (tmp$_4.hasNext()) {\n var element_4 = tmp$_4.next();\n if (predicate(element_4)) {\n none$result = false;\n break none$break;\n }}\n none$result = true;\n }\n while (false);\n if (none$result) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n var hasGeneralTooltip = any$result;\n var any$result_0;\n any$break: do {\n var tmp$_5;\n if (Kotlin.isType(mappedTooltipLines, Collection) && mappedTooltipLines.isEmpty()) {\n any$result_0 = false;\n break any$break;\n }tmp$_5 = mappedTooltipLines.iterator();\n loop_label: while (tmp$_5.hasNext()) {\n var element_5 = tmp$_5.next();\n var $receiver_1 = element_5.fields;\n var predicate_0 = getPropertyCallableRef('isAxis', 1, function ($receiver) {\n return $receiver.isAxis;\n });\n var any$result_1;\n any$break_0: do {\n var tmp$_6;\n if (Kotlin.isType($receiver_1, Collection) && $receiver_1.isEmpty()) {\n any$result_1 = false;\n break any$break_0;\n }tmp$_6 = $receiver_1.iterator();\n while (tmp$_6.hasNext()) {\n var element_6 = tmp$_6.next();\n if (predicate_0(element_6)) {\n any$result_1 = true;\n break any$break_0;\n }}\n any$result_1 = false;\n }\n while (false);\n if (any$result_1) {\n any$result_0 = true;\n break any$break;\n }}\n any$result_0 = false;\n }\n while (false);\n var hasAxisTooltip = any$result_0;\n return new ContextualMapping(mappedTooltipLines, tooltipProperties.anchor, tooltipProperties.minWidth, tooltipProperties.color, ignoreInvisibleTargets, hasGeneralTooltip, hasAxisTooltip, isCrosshairEnabled);\n };\n GeomInteraction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomInteraction$Companion_instance = null;\n function GeomInteraction$Companion_getInstance() {\n if (GeomInteraction$Companion_instance === null) {\n new GeomInteraction$Companion();\n }return GeomInteraction$Companion_instance;\n }\n GeomInteraction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomInteraction',\n interfaces: [ContextualMappingProvider]\n };\n function GeomInteractionBuilder(mySupportedAesList) {\n GeomInteractionBuilder$Companion_getInstance();\n this.mySupportedAesList_0 = mySupportedAesList;\n this.myIgnoreInvisibleTargets_0 = false;\n this.locatorLookupSpace_3dt62f$_0 = this.locatorLookupSpace_3dt62f$_0;\n this.locatorLookupStrategy_gpx4i$_0 = this.locatorLookupStrategy_gpx4i$_0;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = false;\n this.myAxisTooltipVisibilityFromConfig_0 = null;\n this.myAxisAesFromFunctionKind_0 = null;\n this.myTooltipAxisAes_vm9teg$_0 = this.myTooltipAxisAes_vm9teg$_0;\n this.myTooltipAes_um80ux$_0 = this.myTooltipAes_um80ux$_0;\n this.myTooltipOutlierAesList_r7qit3$_0 = this.myTooltipOutlierAesList_r7qit3$_0;\n this.myTooltipConstantsAesList_0 = null;\n this.myUserTooltipSpec_0 = null;\n this.myIsCrosshairEnabled_0 = false;\n }\n Object.defineProperty(GeomInteractionBuilder.prototype, 'locatorLookupSpace', {\n configurable: true,\n get: function () {\n if (this.locatorLookupSpace_3dt62f$_0 == null)\n return throwUPAE('locatorLookupSpace');\n return this.locatorLookupSpace_3dt62f$_0;\n },\n set: function (locatorLookupSpace) {\n this.locatorLookupSpace_3dt62f$_0 = locatorLookupSpace;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'locatorLookupStrategy', {\n configurable: true,\n get: function () {\n if (this.locatorLookupStrategy_gpx4i$_0 == null)\n return throwUPAE('locatorLookupStrategy');\n return this.locatorLookupStrategy_gpx4i$_0;\n },\n set: function (locatorLookupStrategy) {\n this.locatorLookupStrategy_gpx4i$_0 = locatorLookupStrategy;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipAxisAes_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipAxisAes_vm9teg$_0 == null)\n return throwUPAE('myTooltipAxisAes');\n return this.myTooltipAxisAes_vm9teg$_0;\n },\n set: function (myTooltipAxisAes) {\n this.myTooltipAxisAes_vm9teg$_0 = myTooltipAxisAes;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipAes_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipAes_um80ux$_0 == null)\n return throwUPAE('myTooltipAes');\n return this.myTooltipAes_um80ux$_0;\n },\n set: function (myTooltipAes) {\n this.myTooltipAes_um80ux$_0 = myTooltipAes;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipOutlierAesList_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipOutlierAesList_r7qit3$_0 == null)\n return throwUPAE('myTooltipOutlierAesList');\n return this.myTooltipOutlierAesList_r7qit3$_0;\n },\n set: function (myTooltipOutlierAesList) {\n this.myTooltipOutlierAesList_r7qit3$_0 = myTooltipOutlierAesList;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'getAxisFromFunctionKind', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.myAxisAesFromFunctionKind_0) != null ? tmp$ : emptyList();\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'isAxisTooltipEnabled', {\n configurable: true,\n get: function () {\n return this.myAxisTooltipVisibilityFromConfig_0 == null ? this.myAxisTooltipVisibilityFromFunctionKind_0 : ensureNotNull(this.myAxisTooltipVisibilityFromConfig_0);\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'tooltipLines', {\n configurable: true,\n get: function () {\n return this.prepareTooltipValueSources_0();\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'tooltipProperties', {\n configurable: true,\n get: function () {\n var tmp$, tmp$_0;\n return (tmp$_0 = (tmp$ = this.myUserTooltipSpec_0) != null ? tmp$.tooltipProperties : null) != null ? tmp$_0 : TooltipSpecification$TooltipProperties$Companion_getInstance().NONE;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'isCrosshairEnabled', {\n configurable: true,\n get: function () {\n return this.myIsCrosshairEnabled_0;\n }\n });\n GeomInteractionBuilder.prototype.showAxisTooltip_6taknv$ = function (isTrue) {\n this.myAxisTooltipVisibilityFromConfig_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipAes_3lrecq$ = function (aes) {\n this.myTooltipAes_0 = aes;\n return this;\n };\n GeomInteractionBuilder.prototype.axisAes_3lrecq$ = function (axisAes) {\n this.myTooltipAxisAes_0 = axisAes;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipOutliers_3lrecq$ = function (aes) {\n this.myTooltipOutlierAesList_0 = aes;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipConstants_ayg7dr$ = function (constantsMap) {\n this.myTooltipConstantsAesList_0 = constantsMap;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipLinesSpec_uvmyj9$ = function (tooltipSpec) {\n this.myUserTooltipSpec_0 = tooltipSpec;\n return this;\n };\n GeomInteractionBuilder.prototype.setIsCrosshairEnabled_6taknv$ = function (isTrue) {\n this.myIsCrosshairEnabled_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.multilayerLookupStrategy = function () {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NEAREST;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.XY;\n return this;\n };\n GeomInteractionBuilder.prototype.univariateFunction_7k7ojo$ = function (lookupStrategy) {\n this.myAxisAesFromFunctionKind_0 = GeomInteractionBuilder$Companion_getInstance().AES_X_0;\n this.locatorLookupStrategy = lookupStrategy;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.X;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.bivariateFunction_6taknv$ = function (area) {\n this.myAxisAesFromFunctionKind_0 = GeomInteractionBuilder$Companion_getInstance().AES_XY_0;\n if (area) {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.HOVER;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = false;\n } else {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NEAREST;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n }\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.XY;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.none = function () {\n this.myAxisAesFromFunctionKind_0 = ArrayList_init_0(this.mySupportedAesList_0);\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NONE;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.NONE;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.initDefaultTooltips_0 = function () {\n this.myTooltipAxisAes_0 = !this.isAxisTooltipEnabled ? emptyList() : this.getAxisFromFunctionKind;\n this.myTooltipAes_0 = minus(this.mySupportedAesList_0, this.getAxisFromFunctionKind);\n this.myTooltipOutlierAesList_0 = emptyList();\n };\n GeomInteractionBuilder.prototype.prepareTooltipValueSources_0 = function () {\n var tmp$;\n if (this.myUserTooltipSpec_0 == null)\n tmp$ = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0, this.myTooltipAxisAes_0, this.myTooltipOutlierAesList_0, null, this.myTooltipConstantsAesList_0);\n else if (ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns == null)\n tmp$ = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0, this.myTooltipAxisAes_0, this.myTooltipOutlierAesList_0, ensureNotNull(this.myUserTooltipSpec_0).valueSources, this.myTooltipConstantsAesList_0);\n else if (ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns).isEmpty())\n tmp$ = emptyList();\n else {\n var geomOutliers = toMutableList(this.myTooltipOutlierAesList_0);\n var tmp$_0;\n tmp$_0 = ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns).iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var $receiver = element.fields;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (Kotlin.isType(element_0, MappingValue))\n destination.add_11rb$(element_0);\n }\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(item.aes);\n }\n var userDataAesList = destination_0;\n geomOutliers.removeAll_brywnq$(userDataAesList);\n }\n var $receiver_0 = this.myTooltipAxisAes_0;\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_3;\n tmp$_3 = $receiver_0.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_1.add_11rb$(new MappingValue(item_0, true, true));\n }\n var axisValueSources = destination_1;\n var destination_2 = ArrayList_init_1(collectionSizeOrDefault(geomOutliers, 10));\n var tmp$_4;\n tmp$_4 = geomOutliers.iterator();\n while (tmp$_4.hasNext()) {\n var item_1 = tmp$_4.next();\n var tmp$_5 = destination_2.add_11rb$;\n var tmp$_6;\n var $receiver_1 = ensureNotNull(this.myUserTooltipSpec_0).valueSources;\n var destination_3 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = $receiver_1.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (Kotlin.isType(element_1, MappingValue))\n destination_3.add_11rb$(element_1);\n }\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_8;\n tmp$_8 = destination_3.iterator();\n while (tmp$_8.hasNext()) {\n var element_2 = tmp$_8.next();\n if (equals(element_2.aes, item_1)) {\n firstOrNull$result = element_2;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var formatted = firstOrNull$result;\n tmp$_5.call(destination_2, (tmp$_6 = formatted != null ? formatted.toOutlier() : null) != null ? tmp$_6 : new MappingValue(item_1, true));\n }\n var geomOutlierValueSources = destination_2;\n var tmp$_9 = ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns);\n var $receiver_2 = plus(axisValueSources, geomOutlierValueSources);\n var transform = getCallableRef('defaultLineForValueSource', function ($receiver, p1) {\n return $receiver.defaultLineForValueSource_u47np3$(p1);\n }.bind(null, TooltipLine$Companion_getInstance()));\n var destination_4 = ArrayList_init_1(collectionSizeOrDefault($receiver_2, 10));\n var tmp$_10;\n tmp$_10 = $receiver_2.iterator();\n while (tmp$_10.hasNext()) {\n var item_2 = tmp$_10.next();\n destination_4.add_11rb$(transform(item_2));\n }\n tmp$ = plus(tmp$_9, destination_4);\n }\n return tmp$;\n };\n GeomInteractionBuilder.prototype.build = function () {\n return new GeomInteraction(this);\n };\n GeomInteractionBuilder.prototype.ignoreInvisibleTargets_6taknv$ = function (isTrue) {\n this.myIgnoreInvisibleTargets_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.isIgnoringInvisibleTargets = function () {\n return this.myIgnoreInvisibleTargets_0;\n };\n function GeomInteractionBuilder$Companion() {\n GeomInteractionBuilder$Companion_instance = this;\n this.AREA_GEOM = true;\n this.NON_AREA_GEOM = false;\n this.AES_X_0 = listOf(Aes.Companion.X);\n this.AES_XY_0 = listOf_0([Aes.Companion.X, Aes.Companion.Y]);\n }\n GeomInteractionBuilder$Companion.prototype.defaultValueSourceTooltipLines_dnbe1t$ = function (aesListForTooltip, axisAes, outliers, userDefinedValueSources, constantsMap) {\n if (userDefinedValueSources === void 0)\n userDefinedValueSources = null;\n if (constantsMap === void 0)\n constantsMap = null;\n var tmp$;\n var destination = ArrayList_init_1(collectionSizeOrDefault(axisAes, 10));\n var tmp$_0;\n tmp$_0 = axisAes.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(new MappingValue(item, true, true));\n }\n var axisValueSources = destination;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(outliers, 10));\n var tmp$_1;\n tmp$_1 = outliers.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n var tmp$_2 = destination_0.add_11rb$;\n var tmp$_3, tmp$_4;\n var tmp$_5;\n if (userDefinedValueSources != null) {\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = userDefinedValueSources.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (Kotlin.isType(element, MappingValue))\n destination_1.add_11rb$(element);\n }\n tmp$_5 = destination_1;\n } else\n tmp$_5 = null;\n var tmp$_7;\n if ((tmp$_3 = tmp$_5) != null) {\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_8;\n tmp$_8 = tmp$_3.iterator();\n while (tmp$_8.hasNext()) {\n var element_0 = tmp$_8.next();\n if (equals(element_0.aes, item_0)) {\n firstOrNull$result = element_0;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n tmp$_7 = firstOrNull$result;\n } else\n tmp$_7 = null;\n var userDefined = tmp$_7;\n tmp$_2.call(destination_0, (tmp$_4 = userDefined != null ? userDefined.toOutlier() : null) != null ? tmp$_4 : new MappingValue(item_0, true));\n }\n var outlierValueSources = destination_0;\n var destination_2 = ArrayList_init_1(collectionSizeOrDefault(aesListForTooltip, 10));\n var tmp$_9;\n tmp$_9 = aesListForTooltip.iterator();\n while (tmp$_9.hasNext()) {\n var item_1 = tmp$_9.next();\n var tmp$_10 = destination_2.add_11rb$;\n var tmp$_11;\n var tmp$_12;\n if (userDefinedValueSources != null) {\n var destination_3 = ArrayList_init();\n var tmp$_13;\n tmp$_13 = userDefinedValueSources.iterator();\n while (tmp$_13.hasNext()) {\n var element_1 = tmp$_13.next();\n if (Kotlin.isType(element_1, MappingValue))\n destination_3.add_11rb$(element_1);\n }\n tmp$_12 = destination_3;\n } else\n tmp$_12 = null;\n var tmp$_14;\n if ((tmp$_11 = tmp$_12) != null) {\n var firstOrNull$result_0;\n firstOrNull$break: do {\n var tmp$_15;\n tmp$_15 = tmp$_11.iterator();\n while (tmp$_15.hasNext()) {\n var element_2 = tmp$_15.next();\n if (equals(element_2.aes, item_1)) {\n firstOrNull$result_0 = element_2;\n break firstOrNull$break;\n }}\n firstOrNull$result_0 = null;\n }\n while (false);\n tmp$_14 = firstOrNull$result_0;\n } else\n tmp$_14 = null;\n var userDefined_0 = tmp$_14;\n tmp$_10.call(destination_2, userDefined_0 != null ? userDefined_0 : new MappingValue(item_1));\n }\n var aesValueSources = destination_2;\n var tmp$_16;\n if (constantsMap != null) {\n var destination_4 = ArrayList_init_1(constantsMap.size);\n var tmp$_17;\n tmp$_17 = constantsMap.entries.iterator();\n while (tmp$_17.hasNext()) {\n var item_2 = tmp$_17.next();\n var tmp$_18 = destination_4.add_11rb$;\n var value = item_2.value;\n tmp$_18.call(destination_4, new ConstantValue(value, null));\n }\n tmp$_16 = destination_4;\n } else\n tmp$_16 = null;\n var constantValues = (tmp$ = tmp$_16) != null ? tmp$ : emptyList();\n var $receiver = plus(plus(plus(aesValueSources, axisValueSources), outlierValueSources), constantValues);\n var transform = getCallableRef('defaultLineForValueSource', function ($receiver, p1) {\n return $receiver.defaultLineForValueSource_u47np3$(p1);\n }.bind(null, TooltipLine$Companion_getInstance()));\n var destination_5 = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_19;\n tmp$_19 = $receiver.iterator();\n while (tmp$_19.hasNext()) {\n var item_3 = tmp$_19.next();\n destination_5.add_11rb$(transform(item_3));\n }\n return destination_5;\n };\n GeomInteractionBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomInteractionBuilder$Companion_instance = null;\n function GeomInteractionBuilder$Companion_getInstance() {\n if (GeomInteractionBuilder$Companion_instance === null) {\n new GeomInteractionBuilder$Companion();\n }return GeomInteractionBuilder$Companion_instance;\n }\n GeomInteractionBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomInteractionBuilder',\n interfaces: []\n };\n function MathUtil() {\n MathUtil_instance = this;\n }\n MathUtil.prototype.polygonContainsCoordinate_sz9prc$ = function (points, coord) {\n var tmp$;\n var intersectionCount = 0;\n tmp$ = points.size;\n for (var i = 1; i < tmp$; i++) {\n var start = points.get_za3lpa$(i - 1 | 0);\n var end = points.get_za3lpa$(i);\n if (start.y >= coord.y && end.y >= coord.y || (start.y < coord.y && end.y < coord.y)) {\n continue;\n }var x = start.x + (coord.y - start.y) * (end.x - start.x) / (end.y - start.y);\n if (x <= coord.x) {\n intersectionCount = intersectionCount + 1 | 0;\n }}\n return intersectionCount % 2 !== 0;\n };\n MathUtil.prototype.liesOnSegment_e9v9yt$ = function (p1, p2, c, epsilon) {\n return (new DoubleSegment(p1, p2)).distance_gpjtzr$(c) < epsilon;\n };\n MathUtil.prototype.areEqual_f1g2it$ = function (p1, p2, epsilon) {\n return p1.subtract_gpjtzr$(p2).length() < epsilon;\n };\n MathUtil.prototype.areEqual_hln2n9$ = function (a, b, epsilon) {\n var x = a - b;\n return JsMath.abs(x) < epsilon;\n };\n MathUtil.prototype.distance_l9poh5$ = function (p1, p2) {\n return (new DoubleSegment(p1, p2)).length();\n };\n MathUtil.prototype.subtractX_l3ea4i$ = function (v, x) {\n return new DoubleVector(v.x - x, v.y);\n };\n MathUtil.prototype.addX_l3ea4i$ = function (v, x) {\n return new DoubleVector(v.x + x, v.y);\n };\n MathUtil.prototype.leftEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.top), new DoubleVector(rect.left, rect.bottom));\n };\n MathUtil.prototype.topEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.top), new DoubleVector(rect.right, rect.top));\n };\n MathUtil.prototype.rightEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.right, rect.top), new DoubleVector(rect.right, rect.bottom));\n };\n MathUtil.prototype.bottomEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.bottom), new DoubleVector(rect.right, rect.bottom));\n };\n function MathUtil$ClosestPointChecker(target) {\n this.target = target;\n this.distance_pberzz$_0 = -1.0;\n this.coord_ovwx85$_0 = null;\n }\n Object.defineProperty(MathUtil$ClosestPointChecker.prototype, 'distance', {\n configurable: true,\n get: function () {\n return this.distance_pberzz$_0;\n },\n set: function (distance) {\n this.distance_pberzz$_0 = distance;\n }\n });\n Object.defineProperty(MathUtil$ClosestPointChecker.prototype, 'coord', {\n configurable: true,\n get: function () {\n return this.coord_ovwx85$_0;\n },\n set: function (coord) {\n this.coord_ovwx85$_0 = coord;\n }\n });\n MathUtil$ClosestPointChecker.prototype.check_gpjtzr$ = function (coord) {\n var cmpResult = this.compare_gpjtzr$(coord);\n return cmpResult === MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance() || cmpResult === MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n };\n MathUtil$ClosestPointChecker.prototype.compare_gpjtzr$ = function (coord) {\n var newDistance = MathUtil_getInstance().distance_l9poh5$(this.target, coord);\n if (this.distance < 0) {\n this.setNewClosestCoord_0(coord, newDistance);\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n }if (this.distance < newDistance) {\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n }if (this.distance === newDistance) {\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n }this.setNewClosestCoord_0(coord, newDistance);\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n };\n MathUtil$ClosestPointChecker.prototype.setNewClosestCoord_0 = function (coord, distance) {\n this.distance = distance;\n this.coord = coord;\n };\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields = function () {\n };\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('NEW_CLOSER', 0);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('NEW_FARTHER', 1);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('EQUAL', 2);\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance;\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance;\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance;\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'COMPARISON_RESULT',\n interfaces: [Enum]\n };\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$values() {\n return [MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance(), MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance(), MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance()];\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.values = MathUtil$ClosestPointChecker$COMPARISON_RESULT$values;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$valueOf(name) {\n switch (name) {\n case 'NEW_CLOSER':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n case 'NEW_FARTHER':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n case 'EQUAL':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker.COMPARISON_RESULT.' + name);\n }\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.valueOf_61zpoe$ = MathUtil$ClosestPointChecker$COMPARISON_RESULT$valueOf;\n MathUtil$ClosestPointChecker.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ClosestPointChecker',\n interfaces: []\n };\n function MathUtil$MathUtil$ClosestPointChecker_init(x, y, $this) {\n $this = $this || Object.create(MathUtil$ClosestPointChecker.prototype);\n MathUtil$ClosestPointChecker.call($this, new DoubleVector(x, y));\n return $this;\n }\n function MathUtil$DoubleRange(myStart, myLength) {\n MathUtil$DoubleRange$Companion_getInstance();\n this.myStart_0 = myStart;\n this.myLength_0 = myLength;\n if (this.myLength_0 < 0) {\n throw IllegalStateException_init('Length should be positive');\n }}\n MathUtil$DoubleRange.prototype.length = function () {\n return this.myLength_0;\n };\n MathUtil$DoubleRange.prototype.overlaps_oqgc3u$ = function (v) {\n return this.start() <= v.end() && v.start() <= this.end();\n };\n MathUtil$DoubleRange.prototype.inside_oqgc3u$ = function (v) {\n return this.start() >= v.start() && this.end() <= v.end();\n };\n MathUtil$DoubleRange.prototype.contains_14dthe$ = function (value) {\n return value >= this.start() && value <= this.end();\n };\n MathUtil$DoubleRange.prototype.start = function () {\n return this.myStart_0;\n };\n MathUtil$DoubleRange.prototype.end = function () {\n return this.myStart_0 + this.length();\n };\n MathUtil$DoubleRange.prototype.move_14dthe$ = function (delta) {\n return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() + delta, this.length());\n };\n MathUtil$DoubleRange.prototype.moveLeft_14dthe$ = function (delta) {\n if (delta < 0) {\n throw IllegalStateException_init('Value should be positive');\n }return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() - delta, this.length());\n };\n MathUtil$DoubleRange.prototype.moveRight_14dthe$ = function (delta) {\n if (delta < 0) {\n throw IllegalStateException_init('Value should be positive');\n }return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() + delta, this.length());\n };\n function MathUtil$DoubleRange$Companion() {\n MathUtil$DoubleRange$Companion_instance = this;\n }\n MathUtil$DoubleRange$Companion.prototype.withStartAndEnd_lu1900$ = function (start, end) {\n var rangeStart = JsMath.min(start, end);\n var rangeLength = JsMath.max(start, end) - rangeStart;\n return new MathUtil$DoubleRange(rangeStart, rangeLength);\n };\n MathUtil$DoubleRange$Companion.prototype.withStartAndLength_lu1900$ = function (start, length) {\n return new MathUtil$DoubleRange(start, length);\n };\n MathUtil$DoubleRange$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MathUtil$DoubleRange$Companion_instance = null;\n function MathUtil$DoubleRange$Companion_getInstance() {\n if (MathUtil$DoubleRange$Companion_instance === null) {\n new MathUtil$DoubleRange$Companion();\n }return MathUtil$DoubleRange$Companion_instance;\n }\n MathUtil$DoubleRange.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleRange',\n interfaces: []\n };\n MathUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MathUtil',\n interfaces: []\n };\n var MathUtil_instance = null;\n function MathUtil_getInstance() {\n if (MathUtil_instance === null) {\n new MathUtil();\n }return MathUtil_instance;\n }\n function TooltipSpec(layoutHint, lines, fill, isOutlier, anchor, minWidth, isCrosshairEnabled) {\n if (anchor === void 0)\n anchor = null;\n if (minWidth === void 0)\n minWidth = null;\n if (isCrosshairEnabled === void 0)\n isCrosshairEnabled = false;\n this.layoutHint = layoutHint;\n this.fill = fill;\n this.isOutlier = isOutlier;\n this.anchor = anchor;\n this.minWidth = minWidth;\n this.isCrosshairEnabled = isCrosshairEnabled;\n this.lines = ArrayList_init_0(lines);\n }\n TooltipSpec.prototype.toString = function () {\n var tmp$ = 'TooltipSpec(' + this.layoutHint + ', lines=';\n var $receiver = this.lines;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item.toString());\n }\n return tmp$ + destination + ')';\n };\n function TooltipSpec$Line(label, value) {\n TooltipSpec$Line$Companion_getInstance();\n this.label = label;\n this.value = value;\n }\n TooltipSpec$Line.prototype.toString = function () {\n var $receiver = this.label;\n return $receiver == null || $receiver.length === 0 ? this.value : toString(this.label) + ': ' + this.value;\n };\n function TooltipSpec$Line$Companion() {\n TooltipSpec$Line$Companion_instance = this;\n }\n TooltipSpec$Line$Companion.prototype.withValue_61zpoe$ = function (value) {\n return new TooltipSpec$Line(null, value);\n };\n TooltipSpec$Line$Companion.prototype.withLabelAndValue_f5e6j7$ = function (label, value) {\n return new TooltipSpec$Line(label, value);\n };\n TooltipSpec$Line$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpec$Line$Companion_instance = null;\n function TooltipSpec$Line$Companion_getInstance() {\n if (TooltipSpec$Line$Companion_instance === null) {\n new TooltipSpec$Line$Companion();\n }return TooltipSpec$Line$Companion_instance;\n }\n TooltipSpec$Line.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Line',\n interfaces: []\n };\n TooltipSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpec',\n interfaces: []\n };\n function TooltipSpecFactory(contextualMapping, axisOrigin) {\n this.contextualMapping_0 = contextualMapping;\n this.axisOrigin_0 = axisOrigin;\n }\n TooltipSpecFactory.prototype.create_62opr5$ = function (geomTarget) {\n return ArrayList_init_0((new TooltipSpecFactory$Helper(this, geomTarget)).createTooltipSpecs_8be2vx$());\n };\n function TooltipSpecFactory$Helper($outer, myGeomTarget) {\n this.$outer = $outer;\n this.myGeomTarget_0 = myGeomTarget;\n this.myDataPoints_0 = this.$outer.contextualMapping_0.getDataPoints_za3lpa$(this.hitIndex_0());\n this.myTooltipAnchor_0 = this.$outer.contextualMapping_0.tooltipAnchor;\n this.myTooltipMinWidth_0 = this.$outer.contextualMapping_0.tooltipMinWidth;\n this.myTooltipColor_0 = this.$outer.contextualMapping_0.tooltipColor;\n this.myIsCrosshairEnabled_0 = this.$outer.contextualMapping_0.isCrosshairEnabled;\n }\n TooltipSpecFactory$Helper.prototype.createTooltipSpecs_8be2vx$ = function () {\n var tooltipSpecs = ArrayList_init();\n addAll(tooltipSpecs, this.outlierTooltipSpec_0());\n addAll(tooltipSpecs, this.generalTooltipSpec_0());\n addAll(tooltipSpecs, this.axisTooltipSpec_0());\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.hitIndex_0 = function () {\n return this.myGeomTarget_0.hitIndex;\n };\n TooltipSpecFactory$Helper.prototype.tipLayoutHint_0 = function () {\n return this.myGeomTarget_0.tipLayoutHint;\n };\n TooltipSpecFactory$Helper.prototype.outlierHints_0 = function () {\n return this.myGeomTarget_0.aesTipLayoutHints;\n };\n TooltipSpecFactory$Helper.prototype.hintColors_0 = function () {\n var $receiver = this.myGeomTarget_0.aesTipLayoutHints;\n var destination = ArrayList_init_1($receiver.size);\n var tmp$;\n tmp$ = $receiver.entries.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(to(item.key, item.value.color));\n }\n return toMap(destination);\n };\n TooltipSpecFactory$Helper.prototype.outlierTooltipSpec_0 = function () {\n var tooltipSpecs = ArrayList_init();\n var outlierDataPoints = this.outlierDataPoints_0();\n var tmp$;\n tmp$ = this.outlierHints_0().entries.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var aes = element.key;\n var hint = element.value;\n var tmp$_0;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = outlierDataPoints.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (equals(aes, element_0.aes))\n destination.add_11rb$(element_0);\n }\n var transform = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(transform(item));\n }\n var transform_0 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault(destination_0, 10));\n var tmp$_3;\n tmp$_3 = destination_0.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_1.add_11rb$(transform_0(item_0));\n }\n var linesForAes = destination_1;\n if (!linesForAes.isEmpty()) {\n tooltipSpecs.add_11rb$(new TooltipSpec(hint, linesForAes, (tmp$_0 = hint.color) != null ? tmp$_0 : ensureNotNull(this.tipLayoutHint_0().color), true));\n }}\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.axisTooltipSpec_0 = function () {\n var tooltipSpecs = ArrayList_init();\n var tmp$ = Aes.Companion.X;\n var $receiver = this.axisDataPoints_0();\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (equals(Aes.Companion.X, element.aes))\n destination.add_11rb$(element);\n }\n var transform = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(transform(item));\n }\n var transform_0 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_1 = ArrayList_init_1(collectionSizeOrDefault(destination_0, 10));\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_1.add_11rb$(transform_0(item_0));\n }\n var tmp$_3 = to(tmp$, destination_1);\n var tmp$_4 = Aes.Companion.Y;\n var $receiver_0 = this.axisDataPoints_0();\n var destination_2 = ArrayList_init();\n var tmp$_5;\n tmp$_5 = $receiver_0.iterator();\n while (tmp$_5.hasNext()) {\n var element_0 = tmp$_5.next();\n if (equals(Aes.Companion.Y, element_0.aes))\n destination_2.add_11rb$(element_0);\n }\n var transform_1 = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_3 = ArrayList_init_1(collectionSizeOrDefault(destination_2, 10));\n var tmp$_6;\n tmp$_6 = destination_2.iterator();\n while (tmp$_6.hasNext()) {\n var item_1 = tmp$_6.next();\n destination_3.add_11rb$(transform_1(item_1));\n }\n var transform_2 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_4 = ArrayList_init_1(collectionSizeOrDefault(destination_3, 10));\n var tmp$_7;\n tmp$_7 = destination_3.iterator();\n while (tmp$_7.hasNext()) {\n var item_2 = tmp$_7.next();\n destination_4.add_11rb$(transform_2(item_2));\n }\n var axis = mapOf([tmp$_3, to(tmp$_4, destination_4)]);\n var tmp$_8;\n tmp$_8 = axis.entries.iterator();\n while (tmp$_8.hasNext()) {\n var element_1 = tmp$_8.next();\n var aes = element_1.key;\n var lines = element_1.value;\n if (!lines.isEmpty()) {\n var layoutHint = this.createHintForAxis_0(aes);\n tooltipSpecs.add_11rb$(new TooltipSpec(layoutHint, lines, ensureNotNull(layoutHint.color), true));\n }}\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.generalTooltipSpec_0 = function () {\n var tmp$, tmp$_0, tmp$_1;\n var generalDataPoints = this.generalDataPoints_0();\n var destination = ArrayList_init_1(collectionSizeOrDefault(generalDataPoints, 10));\n var tmp$_2;\n tmp$_2 = generalDataPoints.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(TooltipSpec$Line$Companion_getInstance().withLabelAndValue_f5e6j7$(item.label, item.value));\n }\n var generalLines = destination;\n var $receiver = this.hintColors_0();\n var tmp$_3;\n var result = LinkedHashMap_init();\n tmp$_3 = $receiver.entries.iterator();\n while (tmp$_3.hasNext()) {\n var entry = tmp$_3.next();\n var aes = entry.key;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(generalDataPoints, 10));\n var tmp$_4;\n tmp$_4 = generalDataPoints.iterator();\n while (tmp$_4.hasNext()) {\n var item_0 = tmp$_4.next();\n destination_0.add_11rb$(item_0.aes);\n }\n if (destination_0.contains_11rb$(aes)) {\n result.put_xwzc9p$(entry.key, entry.value);\n }}\n var aesHintColors = result;\n var tmp$_5;\n if ((tmp$ = aesHintColors.get_11rb$(Aes.Companion.Y)) != null)\n tmp$_5 = tmp$;\n else {\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = aesHintColors.entries.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n var tmp$_0_0;\n if ((tmp$_0_0 = element.value) != null) {\n destination_1.add_11rb$(tmp$_0_0);\n }}\n tmp$_5 = lastOrNull(destination_1);\n }\n var colorFromHints = tmp$_5;\n if (this.myTooltipColor_0 != null)\n tmp$_0 = this.myTooltipColor_0;\n else if (colorFromHints != null)\n tmp$_0 = colorFromHints;\n else\n tmp$_0 = ensureNotNull(this.tipLayoutHint_0().color);\n var tooltipColor = tmp$_0;\n if (!generalLines.isEmpty()) {\n tmp$_1 = listOf(new TooltipSpec(this.tipLayoutHint_0(), generalLines, tooltipColor, false, this.myTooltipAnchor_0, this.myTooltipMinWidth_0, this.myIsCrosshairEnabled_0));\n } else {\n tmp$_1 = emptyList();\n }\n return tmp$_1;\n };\n TooltipSpecFactory$Helper.prototype.outlierDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.isOutlier && !element.isAxis)\n destination.add_11rb$(element);\n }\n return destination;\n };\n TooltipSpecFactory$Helper.prototype.axisDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var predicate = getPropertyCallableRef('isAxis', 1, function ($receiver) {\n return $receiver.isAxis;\n });\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (predicate(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n TooltipSpecFactory$Helper.prototype.generalDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var predicate = getPropertyCallableRef('isOutlier', 1, function ($receiver) {\n return $receiver.isOutlier;\n });\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!predicate(element))\n destination.add_11rb$(element);\n }\n var nonOutlierDataPoints = destination;\n var $receiver_0 = this.outlierDataPoints_0();\n var transform = getPropertyCallableRef('aes', 1, function ($receiver) {\n return $receiver.aes;\n });\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver_0.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n var tmp$_0_0;\n if ((tmp$_0_0 = transform(element_0)) != null) {\n destination_0.add_11rb$(tmp$_0_0);\n }}\n var outliers = destination_0;\n var transform_0 = getPropertyCallableRef('aes', 1, function ($receiver) {\n return $receiver.aes;\n });\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = nonOutlierDataPoints.iterator();\n while (tmp$_1.hasNext()) {\n var element_1 = tmp$_1.next();\n var tmp$_0_1;\n if ((tmp$_0_1 = transform_0(element_1)) != null) {\n destination_1.add_11rb$(tmp$_0_1);\n }}\n var generalAesList = minus(destination_1, outliers);\n var destination_2 = ArrayList_init();\n var tmp$_2;\n tmp$_2 = nonOutlierDataPoints.iterator();\n while (tmp$_2.hasNext()) {\n var element_2 = tmp$_2.next();\n var predicate$result;\n var tmp$_3;\n tmp$_3 = element_2.aes;\n if (tmp$_3 == null) {\n predicate$result = true;\n } else if (contains(generalAesList, tmp$_3)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination_2.add_11rb$(element_2);\n }\n return destination_2;\n };\n TooltipSpecFactory$Helper.prototype.createHintForAxis_0 = function (aes) {\n var tmp$;\n if (equals(aes, Aes.Companion.X))\n tmp$ = TipLayoutHint.Companion.xAxisTooltip_cgf2ia$(new DoubleVector(ensureNotNull(this.tipLayoutHint_0().coord).x, this.$outer.axisOrigin_0.y), Defaults$Common$Tooltip_getInstance().AXIS_TOOLTIP_COLOR, Defaults$Common$Tooltip_getInstance().AXIS_RADIUS);\n else if (equals(aes, Aes.Companion.Y))\n tmp$ = TipLayoutHint.Companion.yAxisTooltip_cgf2ia$(new DoubleVector(this.$outer.axisOrigin_0.x, ensureNotNull(this.tipLayoutHint_0().coord).y), Defaults$Common$Tooltip_getInstance().AXIS_TOOLTIP_COLOR, Defaults$Common$Tooltip_getInstance().AXIS_RADIUS);\n else {\n throw IllegalStateException_init(('Not an axis aes: ' + aes).toString());\n }\n return tmp$;\n };\n TooltipSpecFactory$Helper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Helper',\n interfaces: []\n };\n TooltipSpecFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpecFactory',\n interfaces: []\n };\n function LayerTargetCollectorWithLocator(geomKind, lookupSpec, contextualMapping, coordinateSystem) {\n this.geomKind_0 = geomKind;\n this.lookupSpec_0 = lookupSpec;\n this.contextualMapping_0 = contextualMapping;\n this.coordinateSystem_0 = coordinateSystem;\n this.myTargets_0 = ArrayList_init();\n this.myLocator_0 = null;\n }\n function LayerTargetCollectorWithLocator$addPoint$lambda(closure$index) {\n return function (it) {\n return closure$index;\n };\n }\n LayerTargetCollectorWithLocator.prototype.addPoint_cnsimy$$default = function (index, point, radius, tooltipParams, tooltipKind) {\n if (this.contextualMapping_0.ignoreInvisibleTargets) {\n if (radius === 0.0 || tooltipParams.getColor().alpha === 0) {\n return;\n }}if (!this.coordinateSystem_0.isPointInLimits_k2qmv6$(point)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.point_e1sv3v$(point, radius), LayerTargetCollectorWithLocator$addPoint$lambda(index), tooltipParams, tooltipKind));\n };\n function LayerTargetCollectorWithLocator$addRectangle$lambda(closure$index) {\n return function (it) {\n return closure$index;\n };\n }\n LayerTargetCollectorWithLocator.prototype.addRectangle_bxzvr8$$default = function (index, rectangle, tooltipParams, tooltipKind) {\n if (this.contextualMapping_0.ignoreInvisibleTargets) {\n if (rectangle.width === 0.0 || rectangle.height === 0.0 || tooltipParams.getColor().alpha === 0) {\n return;\n }}if (!this.coordinateSystem_0.isRectInLimits_fd842m$(rectangle)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.rect_wthzt5$(rectangle), LayerTargetCollectorWithLocator$addRectangle$lambda(index), tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addPath_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n if (!this.coordinateSystem_0.isPathInLimits_f6t8kh$(points)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.path_ytws2g$(points), localToGlobalIndex, tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addPolygon_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n if (!this.coordinateSystem_0.isPolygonInLimits_f6t8kh$(points)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.polygon_ytws2g$(points), localToGlobalIndex, tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addTarget_0 = function (targetPrototype) {\n this.myTargets_0.add_11rb$(targetPrototype);\n this.myLocator_0 = null;\n };\n LayerTargetCollectorWithLocator.prototype.search_gpjtzr$ = function (coord) {\n if (this.myLocator_0 == null) {\n this.myLocator_0 = new LayerTargetLocator(this.geomKind_0, this.lookupSpec_0, this.contextualMapping_0, this.myTargets_0);\n }return ensureNotNull(this.myLocator_0).search_gpjtzr$(coord);\n };\n LayerTargetCollectorWithLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerTargetCollectorWithLocator',\n interfaces: [GeomTargetLocator, GeomTargetCollector]\n };\n function LayerTargetLocator(geomKind, lookupSpec, contextualMapping, targetPrototypes) {\n this.geomKind_0 = geomKind;\n this.lookupSpec_0 = lookupSpec;\n this.contextualMapping_0 = contextualMapping;\n this.myTargets_0 = ArrayList_init();\n this.myTargetDetector_0 = new TargetDetector(this.lookupSpec_0.lookupSpace, this.lookupSpec_0.lookupStrategy);\n this.mySimpleGeometry_0 = setOf([GeomKind.RECT, GeomKind.POLYGON]);\n var tmp$, tmp$_0;\n if (this.mySimpleGeometry_0.contains_11rb$(this.geomKind_0))\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n else if (this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.X && this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.NEAREST)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance();\n else if (this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.X)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n else if (this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.HOVER)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n else if (this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.NONE || this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.NONE)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance();\n else {\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n }\n this.myCollectingStrategy_0 = tmp$;\n var toProjection = LayerTargetLocator_init$toProjection(this);\n tmp$_0 = targetPrototypes.iterator();\n while (tmp$_0.hasNext()) {\n var prototype = tmp$_0.next();\n this.myTargets_0.add_11rb$(new LayerTargetLocator$Target(toProjection(prototype), prototype));\n }\n }\n LayerTargetLocator.prototype.addLookupResults_0 = function (collector, targets) {\n if (collector.size() === 0) {\n return;\n }var tmp$ = collector.collection();\n var b = collector.closestPointChecker.distance;\n targets.add_11rb$(new GeomTargetLocator$LookupResult(tmp$, JsMath.max(0.0, b), this.geomKind_0, this.contextualMapping_0, this.contextualMapping_0.isCrosshairEnabled));\n };\n LayerTargetLocator.prototype.search_gpjtzr$ = function (coord) {\n var tmp$;\n if (this.myTargets_0.isEmpty()) {\n return null;\n }var rectCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var pointCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var pathCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var polygonCollector = new LayerTargetLocator$Collector(coord, LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance(), this.lookupSpec_0.lookupSpace);\n tmp$ = this.myTargets_0.iterator();\n while (tmp$.hasNext()) {\n var target = tmp$.next();\n switch (target.prototype.hitShape_8be2vx$.kind.name) {\n case 'RECT':\n this.processRect_0(coord, target, rectCollector);\n break;\n case 'POINT':\n this.processPoint_0(coord, target, pointCollector);\n break;\n case 'PATH':\n this.processPath_0(coord, target, pathCollector);\n break;\n case 'POLYGON':\n this.processPolygon_0(coord, target, polygonCollector);\n break;\n }\n }\n var lookupResults = ArrayList_init();\n this.addLookupResults_0(pathCollector, lookupResults);\n this.addLookupResults_0(rectCollector, lookupResults);\n this.addLookupResults_0(pointCollector, lookupResults);\n this.addLookupResults_0(polygonCollector, lookupResults);\n return this.getClosestTarget_0(lookupResults);\n };\n LayerTargetLocator.prototype.getClosestTarget_0 = function (lookupResults) {\n var tmp$;\n if (lookupResults.isEmpty()) {\n return null;\n }var closestTargets = lookupResults.get_za3lpa$(0);\n if (!(closestTargets.distance >= 0)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = lookupResults.iterator();\n while (tmp$.hasNext()) {\n var lookupResult = tmp$.next();\n if (lookupResult.distance < closestTargets.distance) {\n closestTargets = lookupResult;\n }}\n return closestTargets;\n };\n LayerTargetLocator.prototype.processRect_0 = function (coord, target, resultCollector) {\n var tmp$;\n if (this.myTargetDetector_0.checkRect_fqo6rd$(coord, target.rectProjection, resultCollector.closestPointChecker)) {\n var rect = target.prototype.hitShape_8be2vx$.rect;\n if (equals(target.prototype.tooltipKind_8be2vx$, TipLayoutHint$Kind.CURSOR_TOOLTIP))\n tmp$ = rect.height / 2.0;\n else\n tmp$ = 0.0;\n var yOffset = tmp$;\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(rect.origin.add_gpjtzr$(new DoubleVector(rect.width / 2, yOffset)), this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPolygon_0 = function (coord, target, resultCollector) {\n if (this.myTargetDetector_0.checkPolygon_q60eo3$(coord, target.polygonProjection, resultCollector.closestPointChecker)) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(coord, this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPoint_0 = function (coord, target, resultCollector) {\n if (this.myTargetDetector_0.checkPoint_w0b42b$(coord, target.pointProjection, resultCollector.closestPointChecker)) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(target.prototype.hitShape_8be2vx$.point.center, this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPath_0 = function (coord, target, resultCollector) {\n var pointChecker = this.myCollectingStrategy_0 === LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance() ? new MathUtil$ClosestPointChecker(coord) : resultCollector.closestPointChecker;\n var hitPoint = this.myTargetDetector_0.checkPath_z3141m$(coord, target.pathProjection, pointChecker);\n if (hitPoint != null) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(hitPoint.originalCoord, hitPoint.index));\n }};\n LayerTargetLocator.prototype.getKeyForSingleObjectGeometry_0 = function (prototype) {\n return prototype.indexMapper_8be2vx$(0);\n };\n function LayerTargetLocator$Target(targetProjection, prototype) {\n this.targetProjection_0 = targetProjection;\n this.prototype = prototype;\n }\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'pointProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PointTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'rectProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, RectTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'polygonProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PolygonTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'pathProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PathTargetProjection) ? tmp$ : throwCCE();\n }\n });\n LayerTargetLocator$Target.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Target',\n interfaces: []\n };\n function LayerTargetLocator$Collector(cursor, myStrategy, lookupSpace) {\n this.myStrategy_0 = myStrategy;\n this.result_0 = ArrayList_init();\n var tmp$;\n if (lookupSpace === GeomTargetLocator$LookupSpace.X) {\n tmp$ = new MathUtil$ClosestPointChecker(new DoubleVector(cursor.x, 0.0));\n } else {\n tmp$ = new MathUtil$ClosestPointChecker(cursor);\n }\n this.closestPointChecker = tmp$;\n this.myLastAddedDistance_0 = -1.0;\n }\n LayerTargetLocator$Collector.prototype.collect_11rb$ = function (data) {\n switch (this.myStrategy_0.name) {\n case 'APPEND':\n this.add_0(data);\n break;\n case 'REPLACE':\n this.replace_0(data);\n break;\n case 'APPEND_IF_EQUAL':\n if (this.myLastAddedDistance_0 === this.closestPointChecker.distance) {\n this.add_0(data);\n } else {\n this.replace_0(data);\n }\n\n break;\n case 'IGNORE':\n return;\n }\n };\n LayerTargetLocator$Collector.prototype.collection = function () {\n return this.result_0;\n };\n LayerTargetLocator$Collector.prototype.size = function () {\n return this.result_0.size;\n };\n LayerTargetLocator$Collector.prototype.add_0 = function (data) {\n this.result_0.add_11rb$(data);\n this.myLastAddedDistance_0 = this.closestPointChecker.distance;\n };\n LayerTargetLocator$Collector.prototype.replace_0 = function (locationData) {\n this.result_0.clear();\n this.result_0.add_11rb$(locationData);\n this.myLastAddedDistance_0 = this.closestPointChecker.distance;\n };\n function LayerTargetLocator$Collector$CollectingStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LayerTargetLocator$Collector$CollectingStrategy_initFields() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields = function () {\n };\n LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance = new LayerTargetLocator$Collector$CollectingStrategy('APPEND', 0);\n LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance = new LayerTargetLocator$Collector$CollectingStrategy('REPLACE', 1);\n LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance = new LayerTargetLocator$Collector$CollectingStrategy('APPEND_IF_EQUAL', 2);\n LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance = new LayerTargetLocator$Collector$CollectingStrategy('IGNORE', 3);\n }\n var LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance;\n }\n LayerTargetLocator$Collector$CollectingStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectingStrategy',\n interfaces: [Enum]\n };\n function LayerTargetLocator$Collector$CollectingStrategy$values() {\n return [LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance()];\n }\n LayerTargetLocator$Collector$CollectingStrategy.values = LayerTargetLocator$Collector$CollectingStrategy$values;\n function LayerTargetLocator$Collector$CollectingStrategy$valueOf(name) {\n switch (name) {\n case 'APPEND':\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n case 'REPLACE':\n return LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n case 'APPEND_IF_EQUAL':\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance();\n case 'IGNORE':\n return LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.interact.loc.LayerTargetLocator.Collector.CollectingStrategy.' + name);\n }\n }\n LayerTargetLocator$Collector$CollectingStrategy.valueOf_61zpoe$ = LayerTargetLocator$Collector$CollectingStrategy$valueOf;\n LayerTargetLocator$Collector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Collector',\n interfaces: []\n };\n function LayerTargetLocator_init$toProjection(this$LayerTargetLocator) {\n return function (prototype) {\n var tmp$;\n switch (prototype.hitShape_8be2vx$.kind.name) {\n case 'POINT':\n tmp$ = PointTargetProjection$Companion_getInstance().create_p1yge$(prototype.hitShape_8be2vx$.point.center, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'RECT':\n tmp$ = RectTargetProjection$Companion_getInstance().create_tb1cvm$(prototype.hitShape_8be2vx$.rect, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'POLYGON':\n tmp$ = PolygonTargetProjection$Companion_getInstance().create_a95qp$(prototype.hitShape_8be2vx$.points, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'PATH':\n tmp$ = PathTargetProjection$Companion_getInstance().create_zb7j6l$(prototype.hitShape_8be2vx$.points, prototype.indexMapper_8be2vx$, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n LayerTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerTargetLocator',\n interfaces: [GeomTargetLocator]\n };\n function LocatedTargetsPicker() {\n LocatedTargetsPicker$Companion_getInstance();\n this.myPicked_0 = ArrayList_init();\n this.myMinDistance_0 = 0.0;\n this.myAllLookupResults_0 = ArrayList_init();\n }\n Object.defineProperty(LocatedTargetsPicker.prototype, 'picked', {\n configurable: true,\n get: function () {\n return this.chooseBestResult_0();\n }\n });\n LocatedTargetsPicker.prototype.addLookupResult_9sakjw$ = function (result, coord) {\n if (coord === void 0)\n coord = null;\n var lookupResult = LocatedTargetsPicker$Companion_getInstance().filterResults_0(result, coord);\n var distance = LocatedTargetsPicker$Companion_getInstance().distance_0(lookupResult, coord);\n if (!lookupResult.isCrosshairEnabled && distance > LocatedTargetsPicker$Companion_getInstance().CUTOFF_DISTANCE_8be2vx$) {\n return;\n }if (this.myPicked_0.isEmpty() || this.myMinDistance_0 > distance) {\n this.myPicked_0.clear();\n this.myPicked_0.add_11rb$(lookupResult);\n this.myMinDistance_0 = distance;\n } else if (this.myMinDistance_0 === distance && LocatedTargetsPicker$Companion_getInstance().isSameUnivariateGeom_0(this.myPicked_0.get_za3lpa$(0), lookupResult))\n this.myPicked_0.add_11rb$(lookupResult);\n else if (this.myMinDistance_0 === distance) {\n this.myPicked_0.clear();\n this.myPicked_0.add_11rb$(lookupResult);\n }this.myAllLookupResults_0.add_11rb$(lookupResult);\n };\n function LocatedTargetsPicker$chooseBestResult$hasGeneralTooltip(lookupResult) {\n return lookupResult.contextualMapping.hasGeneralTooltip;\n }\n function LocatedTargetsPicker$chooseBestResult$hasAxisTooltip(lookupResult) {\n return lookupResult.contextualMapping.hasAxisTooltip || listOf_0([GeomKind.V_LINE, GeomKind.H_LINE]).contains_11rb$(lookupResult.geomKind);\n }\n LocatedTargetsPicker.prototype.chooseBestResult_0 = function () {\n var tmp$;\n var hasGeneralTooltip = LocatedTargetsPicker$chooseBestResult$hasGeneralTooltip;\n var hasAxisTooltip = LocatedTargetsPicker$chooseBestResult$hasAxisTooltip;\n var $receiver = this.myPicked_0;\n var any$result;\n any$break: do {\n var tmp$_0;\n if (Kotlin.isType($receiver, Collection) && $receiver.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (hasGeneralTooltip(element) && hasAxisTooltip(element)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n if (any$result)\n tmp$ = this.myPicked_0;\n else {\n var $receiver_0 = this.myAllLookupResults_0;\n var none$result;\n none$break: do {\n var tmp$_1;\n if (Kotlin.isType($receiver_0, Collection) && $receiver_0.isEmpty()) {\n none$result = true;\n break none$break;\n }tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (hasGeneralTooltip(element_0)) {\n none$result = false;\n break none$break;\n }}\n none$result = true;\n }\n while (false);\n if (none$result)\n tmp$ = this.myPicked_0;\n else {\n var $receiver_1 = this.myAllLookupResults_0;\n var any$result_0;\n any$break: do {\n var tmp$_2;\n if (Kotlin.isType($receiver_1, Collection) && $receiver_1.isEmpty()) {\n any$result_0 = false;\n break any$break;\n }tmp$_2 = $receiver_1.iterator();\n while (tmp$_2.hasNext()) {\n var element_1 = tmp$_2.next();\n if (hasGeneralTooltip(element_1) && hasAxisTooltip(element_1)) {\n any$result_0 = true;\n break any$break;\n }}\n any$result_0 = false;\n }\n while (false);\n if (any$result_0) {\n var $receiver_2 = this.myAllLookupResults_0;\n var last$result;\n last$break: do {\n var iterator = $receiver_2.listIterator_za3lpa$($receiver_2.size);\n while (iterator.hasPrevious()) {\n var element_2 = iterator.previous();\n if (hasGeneralTooltip(element_2) && hasAxisTooltip(element_2)) {\n last$result = element_2;\n break last$break;\n }}\n throw new NoSuchElementException_init_0('List contains no element matching the predicate.');\n }\n while (false);\n tmp$ = listOf(last$result);\n } else {\n var $receiver_3 = this.myAllLookupResults_0;\n var lastOrNull$result;\n lastOrNull$break: do {\n var iterator_0 = $receiver_3.listIterator_za3lpa$($receiver_3.size);\n while (iterator_0.hasPrevious()) {\n var element_3 = iterator_0.previous();\n if (hasGeneralTooltip(element_3)) {\n lastOrNull$result = element_3;\n break lastOrNull$break;\n }}\n lastOrNull$result = null;\n }\n while (false);\n var withGeneralTooltip = lastOrNull$result;\n var $receiver_4 = this.myAllLookupResults_0;\n var lastOrNull$result_0;\n lastOrNull$break: do {\n var iterator_1 = $receiver_4.listIterator_za3lpa$($receiver_4.size);\n while (iterator_1.hasPrevious()) {\n var element_4 = iterator_1.previous();\n if (hasAxisTooltip(element_4)) {\n lastOrNull$result_0 = element_4;\n break lastOrNull$break;\n }}\n lastOrNull$result_0 = null;\n }\n while (false);\n var withAxisTooltip = lastOrNull$result_0;\n tmp$ = listOfNotNull([withGeneralTooltip, withAxisTooltip]);\n }\n }\n }\n return tmp$;\n };\n function LocatedTargetsPicker$Companion() {\n LocatedTargetsPicker$Companion_instance = this;\n this.CUTOFF_DISTANCE_8be2vx$ = 30.0;\n this.FAKE_DISTANCE_8be2vx$ = 15.0;\n this.UNIVARIATE_GEOMS_0 = listOf_0([GeomKind.DENSITY, GeomKind.FREQPOLY, GeomKind.BOX_PLOT, GeomKind.HISTOGRAM, GeomKind.LINE, GeomKind.AREA, GeomKind.BAR, GeomKind.ERROR_BAR, GeomKind.CROSS_BAR, GeomKind.LINE_RANGE, GeomKind.POINT_RANGE]);\n this.UNIVARIATE_LINES_0 = listOf_0([GeomKind.DENSITY, GeomKind.FREQPOLY, GeomKind.LINE, GeomKind.AREA, GeomKind.SEGMENT]);\n }\n LocatedTargetsPicker$Companion.prototype.distance_0 = function (locatedTargetList, coord) {\n var tmp$, tmp$_0;\n var distance = locatedTargetList.distance;\n if (distance === 0.0) {\n if (!locatedTargetList.isCrosshairEnabled || coord == null) {\n tmp$_0 = this.FAKE_DISTANCE_8be2vx$;\n } else {\n var $receiver = locatedTargetList.targets;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (element.tipLayoutHint.coord != null)\n destination.add_11rb$(element);\n }\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(MathUtil_getInstance().distance_l9poh5$(coord, ensureNotNull(item.tipLayoutHint.coord)));\n }\n tmp$_0 = (tmp$ = minOrNull(destination_0)) != null ? tmp$ : this.FAKE_DISTANCE_8be2vx$;\n }\n } else {\n tmp$_0 = distance;\n }\n return tmp$_0;\n };\n LocatedTargetsPicker$Companion.prototype.isSameUnivariateGeom_0 = function (lft, rgt) {\n return lft.geomKind === rgt.geomKind && this.UNIVARIATE_GEOMS_0.contains_11rb$(rgt.geomKind);\n };\n LocatedTargetsPicker$Companion.prototype.filterResults_0 = function (lookupResult, coord) {\n if (coord == null || !this.UNIVARIATE_LINES_0.contains_11rb$(lookupResult.geomKind)) {\n return lookupResult;\n }var $receiver = lookupResult.targets;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.tipLayoutHint.coord != null)\n destination.add_11rb$(element);\n }\n var geomTargets = destination;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(geomTargets, 10));\n var tmp$_0;\n tmp$_0 = geomTargets.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination_0.add_11rb$(ensureNotNull(item.tipLayoutHint.coord).subtract_gpjtzr$(coord).x);\n }\n var minByOrNull$result;\n minByOrNull$break: do {\n var iterator = destination_0.iterator();\n if (!iterator.hasNext()) {\n minByOrNull$result = null;\n break minByOrNull$break;\n }var minElem = iterator.next();\n if (!iterator.hasNext()) {\n minByOrNull$result = minElem;\n break minByOrNull$break;\n }var it = minElem;\n var minValue = JsMath.abs(it);\n do {\n var e = iterator.next();\n var v = JsMath.abs(e);\n if (Kotlin.compareTo(minValue, v) > 0) {\n minElem = e;\n minValue = v;\n }}\n while (iterator.hasNext());\n minByOrNull$result = minElem;\n }\n while (false);\n var minXToTarget = minByOrNull$result;\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = geomTargets.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (ensureNotNull(element_0.tipLayoutHint.coord).subtract_gpjtzr$(coord).x === minXToTarget)\n destination_1.add_11rb$(element_0);\n }\n var tmp$_2;\n var set = HashSet_init_0();\n var list = ArrayList_init();\n tmp$_2 = destination_1.iterator();\n while (tmp$_2.hasNext()) {\n var e_0 = tmp$_2.next();\n var key = e_0.hitIndex;\n if (set.add_11rb$(key))\n list.add_11rb$(e_0);\n }\n var newTargets = list;\n return new GeomTargetLocator$LookupResult(newTargets, lookupResult.distance, lookupResult.geomKind, lookupResult.contextualMapping, lookupResult.isCrosshairEnabled);\n };\n LocatedTargetsPicker$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LocatedTargetsPicker$Companion_instance = null;\n function LocatedTargetsPicker$Companion_getInstance() {\n if (LocatedTargetsPicker$Companion_instance === null) {\n new LocatedTargetsPicker$Companion();\n }return LocatedTargetsPicker$Companion_instance;\n }\n LocatedTargetsPicker.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LocatedTargetsPicker',\n interfaces: []\n };\n function TargetDetector(locatorLookupSpace, locatorLookupStrategy) {\n TargetDetector$Companion_getInstance();\n this.locatorLookupSpace_0 = locatorLookupSpace;\n this.locatorLookupStrategy_0 = locatorLookupStrategy;\n }\n function TargetDetector$checkPath$lambda(closure$pathPoints) {\n return function (index) {\n return closure$pathPoints.get_za3lpa$(index).projection().x();\n };\n }\n TargetDetector.prototype.checkPath_z3141m$ = function (cursorCoord, pathProjection, closestPointChecker) {\n var tmp$, tmp$_0, tmp$_1;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n if (this.locatorLookupStrategy_0 === GeomTargetLocator$LookupStrategy.NONE) {\n return null;\n }\n var pathPoints = pathProjection.points;\n if (pathPoints.isEmpty()) {\n return null;\n }\n var resultIndex = TargetDetector$Companion_getInstance().binarySearch_0(cursorCoord.x, pathPoints.size, TargetDetector$checkPath$lambda(pathPoints));\n var bestPoint = pathPoints.get_za3lpa$(resultIndex);\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n if (cursorCoord.x < pathPoints.get_za3lpa$(0).projection().x() || cursorCoord.x > pathPoints.get_za3lpa$(pathPoints.size - 1 | 0).projection().x()) {\n tmp$ = null;\n } else\n tmp$ = bestPoint;\n break;\n case 'NEAREST':\n tmp$ = bestPoint;\n break;\n default:throw IllegalStateException_init('Unknown lookup strategy: ' + this.locatorLookupStrategy_0);\n }\n\n return tmp$;\n case 'XY':\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$_0 = pathProjection.points.iterator();\n while (tmp$_0.hasNext()) {\n var pathPoint = tmp$_0.next();\n var targetPointCoord = pathPoint.projection().xy();\n if (MathUtil_getInstance().areEqual_f1g2it$(targetPointCoord, cursorCoord, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0)) {\n return pathPoint;\n }}\n\n return null;\n case 'NEAREST':\n var nearestPoint = null;\n tmp$_1 = pathProjection.points.iterator();\n while (tmp$_1.hasNext()) {\n var pathPoint_0 = tmp$_1.next();\n var targetPointCoord_0 = pathPoint_0.projection().xy();\n if (closestPointChecker.check_gpjtzr$(targetPointCoord_0)) {\n nearestPoint = pathPoint_0;\n }}\n\n return nearestPoint;\n case 'NONE':\n return null;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n\n break;\n case 'NONE':\n return null;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkPoint_w0b42b$ = function (cursorCoord, pointProjection, closestPointChecker) {\n var tmp$, tmp$_0;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var x = pointProjection.x();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$ = MathUtil_getInstance().areEqual_hln2n9$(x, cursorCoord.x, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0);\n break;\n case 'NEAREST':\n tmp$ = closestPointChecker.check_gpjtzr$(new DoubleVector(x, 0.0));\n break;\n case 'NONE':\n tmp$ = false;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n\n return tmp$;\n case 'XY':\n var targetPointCoord = pointProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$_0 = MathUtil_getInstance().areEqual_f1g2it$(targetPointCoord, cursorCoord, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0);\n break;\n case 'NEAREST':\n tmp$_0 = closestPointChecker.check_gpjtzr$(targetPointCoord);\n break;\n case 'NONE':\n tmp$_0 = false;\n break;\n default:tmp$_0 = Kotlin.noWhenBranchMatched();\n break;\n }\n\n return tmp$_0;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkRect_fqo6rd$ = function (cursorCoord, rectProjection, closestPointChecker) {\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var range = rectProjection.x();\n return this.rangeBasedLookup_0(cursorCoord, closestPointChecker, range);\n case 'XY':\n var rect = rectProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n return rect.contains_gpjtzr$(cursorCoord);\n case 'NEAREST':\n if (rect.contains_gpjtzr$(cursorCoord)) {\n return closestPointChecker.check_gpjtzr$(cursorCoord);\n }\n var x = cursorCoord.x < rect.left ? rect.left : rect.right;\n var y = cursorCoord.y < rect.top ? rect.top : rect.bottom;\n x = rect.xRange().contains_mef7kx$(cursorCoord.x) ? cursorCoord.x : x;\n y = rect.yRange().contains_mef7kx$(cursorCoord.y) ? cursorCoord.y : y;\n return closestPointChecker.check_gpjtzr$(new DoubleVector(x, y));\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkPolygon_q60eo3$ = function (cursorCoord, polygonProjection, closestPointChecker) {\n var tmp$;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var range = polygonProjection.x();\n return this.rangeBasedLookup_0(cursorCoord, closestPointChecker, range);\n case 'XY':\n var polygon = polygonProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n case 'NEAREST':\n var counter = 0;\n tmp$ = polygon.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (ring.bbox.contains_gpjtzr$(cursorCoord) && MathUtil_getInstance().polygonContainsCoordinate_sz9prc$(ring.edges, cursorCoord)) {\n counter = counter + 1 | 0;\n }}\n\n return counter % 2 !== 0;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n\n break;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.rangeBasedLookup_0 = function (cursorCoord, closestPointChecker, range) {\n var tmp$;\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n return range.contains_14dthe$(cursorCoord.x);\n case 'NEAREST':\n if (!range.contains_14dthe$(cursorCoord.x - TargetDetector$Companion_getInstance().RECT_X_NEAREST_EPSILON_0) && !range.contains_14dthe$(cursorCoord.x + TargetDetector$Companion_getInstance().RECT_X_NEAREST_EPSILON_0)) {\n tmp$ = false;\n } else\n tmp$ = closestPointChecker.compare_gpjtzr$(new DoubleVector(range.start() + range.length() / 2, cursorCoord.y)) !== MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n return tmp$;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n function TargetDetector$Companion() {\n TargetDetector$Companion_instance = this;\n this.POINT_AREA_EPSILON_0 = 0.1;\n this.POINT_X_NEAREST_EPSILON_0 = 2.0;\n this.RECT_X_NEAREST_EPSILON_0 = 2.0;\n }\n TargetDetector$Companion.prototype.binarySearch_0 = function (value, length, indexer) {\n var tmp$;\n if (value < indexer(0)) {\n return 0;\n }if (value > indexer(length - 1 | 0)) {\n return length - 1 | 0;\n }var lo = 0;\n var hi = length - 1 | 0;\n while (lo <= hi) {\n var mid = (hi + lo | 0) / 2 | 0;\n var midValue = indexer(mid);\n if (value < midValue)\n hi = mid - 1 | 0;\n else if (value > midValue)\n lo = mid + 1 | 0;\n else\n return mid;\n }\n if (indexer(lo) - value < value - indexer(hi)) {\n tmp$ = lo;\n } else {\n tmp$ = hi;\n }\n return tmp$;\n };\n TargetDetector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TargetDetector$Companion_instance = null;\n function TargetDetector$Companion_getInstance() {\n if (TargetDetector$Companion_instance === null) {\n new TargetDetector$Companion();\n }return TargetDetector$Companion_instance;\n }\n TargetDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetDetector',\n interfaces: []\n };\n function TargetProjection() {\n }\n TargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetProjection',\n interfaces: []\n };\n function PointTargetProjection(data) {\n PointTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n PointTargetProjection.prototype.x = function () {\n var tmp$;\n return typeof (tmp$ = this.data) === 'number' ? tmp$ : throwCCE();\n };\n PointTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, DoubleVector) ? tmp$ : throwCCE();\n };\n function PointTargetProjection$Companion() {\n PointTargetProjection$Companion_instance = this;\n }\n PointTargetProjection$Companion.prototype.create_p1yge$ = function (p, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PointTargetProjection(p.x);\n break;\n case 'XY':\n tmp$ = new PointTargetProjection(p);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PointTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointTargetProjection$Companion_instance = null;\n function PointTargetProjection$Companion_getInstance() {\n if (PointTargetProjection$Companion_instance === null) {\n new PointTargetProjection$Companion();\n }return PointTargetProjection$Companion_instance;\n }\n PointTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointTargetProjection',\n interfaces: [TargetProjection]\n };\n function RectTargetProjection(data) {\n RectTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n RectTargetProjection.prototype.x = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, MathUtil$DoubleRange) ? tmp$ : throwCCE();\n };\n RectTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, DoubleRectangle) ? tmp$ : throwCCE();\n };\n function RectTargetProjection$Companion() {\n RectTargetProjection$Companion_instance = this;\n }\n RectTargetProjection$Companion.prototype.create_tb1cvm$ = function (rect, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new RectTargetProjection(MathUtil$DoubleRange$Companion_getInstance().withStartAndEnd_lu1900$(rect.left, rect.right));\n break;\n case 'XY':\n tmp$ = new RectTargetProjection(rect);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n RectTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RectTargetProjection$Companion_instance = null;\n function RectTargetProjection$Companion_getInstance() {\n if (RectTargetProjection$Companion_instance === null) {\n new RectTargetProjection$Companion();\n }return RectTargetProjection$Companion_instance;\n }\n RectTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectTargetProjection',\n interfaces: [TargetProjection]\n };\n function PolygonTargetProjection(data) {\n PolygonTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n PolygonTargetProjection.prototype.x = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, MathUtil$DoubleRange) ? tmp$ : throwCCE();\n };\n PolygonTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, List) ? tmp$ : throwCCE();\n };\n function PolygonTargetProjection$Companion() {\n PolygonTargetProjection$Companion_instance = this;\n this.AREA_LIMIT_TO_REMOVE_POLYGON_0 = 25.0;\n this.POINTS_COUNT_TO_SKIP_SIMPLIFICATION_0 = 20.0;\n this.AREA_TOLERANCE_RATIO_0 = 0.1;\n this.MAX_TOLERANCE_0 = 40.0;\n this.isLogEnabled_0 = false;\n }\n PolygonTargetProjection$Companion.prototype.create_a95qp$ = function (points, lookupSpace) {\n var tmp$;\n var rings = splitRings(points);\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PolygonTargetProjection(this.mapToX_0(rings));\n break;\n case 'XY':\n tmp$ = new PolygonTargetProjection(this.mapToXY_0(rings));\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PolygonTargetProjection$Companion.prototype.mapToX_0 = function (rings) {\n var tmp$, tmp$_0;\n var min = rings.get_za3lpa$(0).get_za3lpa$(0).x;\n var max = min;\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n tmp$_0 = ring.iterator();\n while (tmp$_0.hasNext()) {\n var point = tmp$_0.next();\n var a = min;\n var b = point.x;\n min = JsMath.min(a, b);\n var a_0 = max;\n var b_0 = point.x;\n max = JsMath.max(a_0, b_0);\n }\n }\n return MathUtil$DoubleRange$Companion_getInstance().withStartAndEnd_lu1900$(min, max);\n };\n PolygonTargetProjection$Companion.prototype.mapToXY_0 = function (rings) {\n var tmp$;\n var polygon = ArrayList_init();\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (ring.size < 4) {\n continue;\n }var bbox = geometry.DoubleRectangles.boundingBox_qdtdbw$(ring);\n var area = calculateArea(ring);\n var simplifiedRing;\n if (ring.size > this.POINTS_COUNT_TO_SKIP_SIMPLIFICATION_0) {\n var a = area * this.AREA_TOLERANCE_RATIO_0;\n var b = this.MAX_TOLERANCE_0;\n var tolerance = JsMath.min(a, b);\n simplifiedRing = PolylineSimplifier.Companion.visvalingamWhyatt_ytws2g$(ring).setWeightLimit_14dthe$(tolerance).points;\n if (this.isLogEnabled_0) {\n this.log_0('Simp: ' + toString(ring.size) + ' -> ' + toString(simplifiedRing.size) + ', tolerance=' + toString(tolerance) + ', bbox=' + toString(bbox) + ', area=' + toString(area));\n }} else {\n if (this.isLogEnabled_0) {\n this.log_0('Keep: size: ' + toString(ring.size) + ', bbox=' + toString(bbox) + ', area=' + toString(area));\n }simplifiedRing = ring;\n }\n if (simplifiedRing.size < 4) {\n continue;\n }polygon.add_11rb$(new PolygonTargetProjection$RingXY(simplifiedRing, bbox));\n }\n return polygon;\n };\n PolygonTargetProjection$Companion.prototype.log_0 = function (str) {\n println(str);\n };\n PolygonTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolygonTargetProjection$Companion_instance = null;\n function PolygonTargetProjection$Companion_getInstance() {\n if (PolygonTargetProjection$Companion_instance === null) {\n new PolygonTargetProjection$Companion();\n }return PolygonTargetProjection$Companion_instance;\n }\n function PolygonTargetProjection$RingXY(edges, bbox) {\n this.edges = edges;\n this.bbox = bbox;\n }\n PolygonTargetProjection$RingXY.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RingXY',\n interfaces: []\n };\n PolygonTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolygonTargetProjection',\n interfaces: [TargetProjection]\n };\n function PathTargetProjection(data) {\n PathTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n this.points = this.data;\n }\n function PathTargetProjection$PathPoint(myPointTargetProjection, originalCoord, index) {\n PathTargetProjection$PathPoint$Companion_getInstance();\n this.myPointTargetProjection_0 = myPointTargetProjection;\n this.originalCoord = originalCoord;\n this.index = index;\n }\n PathTargetProjection$PathPoint.prototype.projection = function () {\n return this.myPointTargetProjection_0;\n };\n function PathTargetProjection$PathPoint$Companion() {\n PathTargetProjection$PathPoint$Companion_instance = this;\n }\n PathTargetProjection$PathPoint$Companion.prototype.create_hdp8xa$ = function (p, index, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PathTargetProjection$PathPoint(PointTargetProjection$Companion_getInstance().create_p1yge$(p, lookupSpace), p, index);\n break;\n case 'XY':\n tmp$ = new PathTargetProjection$PathPoint(PointTargetProjection$Companion_getInstance().create_p1yge$(p, lookupSpace), p, index);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PathTargetProjection$PathPoint$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathTargetProjection$PathPoint$Companion_instance = null;\n function PathTargetProjection$PathPoint$Companion_getInstance() {\n if (PathTargetProjection$PathPoint$Companion_instance === null) {\n new PathTargetProjection$PathPoint$Companion();\n }return PathTargetProjection$PathPoint$Companion_instance;\n }\n PathTargetProjection$PathPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathPoint',\n interfaces: []\n };\n function PathTargetProjection$Companion() {\n PathTargetProjection$Companion_instance = this;\n }\n PathTargetProjection$Companion.prototype.create_zb7j6l$ = function (points, indexMapper, lookupSpace) {\n var pointsLocation = ArrayList_init();\n var i = 0;\n for (var tmp$ = points.iterator(); tmp$.hasNext(); ++i) {\n var point = tmp$.next();\n pointsLocation.add_11rb$(PathTargetProjection$PathPoint$Companion_getInstance().create_hdp8xa$(point, indexMapper(i), lookupSpace));\n }\n return new PathTargetProjection(pointsLocation);\n };\n PathTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathTargetProjection$Companion_instance = null;\n function PathTargetProjection$Companion_getInstance() {\n if (PathTargetProjection$Companion_instance === null) {\n new PathTargetProjection$Companion();\n }return PathTargetProjection$Companion_instance;\n }\n PathTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathTargetProjection',\n interfaces: [TargetProjection]\n };\n function undefinedLookupSpaceError() {\n throw IllegalStateException_init('Undefined geom lookup space');\n }\n function TargetPrototype(hitShape, indexMapper, tooltipParams, tooltipKind) {\n TargetPrototype$Companion_getInstance();\n this.hitShape_8be2vx$ = hitShape;\n this.indexMapper_8be2vx$ = indexMapper;\n this.tooltipParams_0 = tooltipParams;\n this.tooltipKind_8be2vx$ = tooltipKind;\n }\n TargetPrototype.prototype.createGeomTarget_x7nr8i$ = function (hitCoord, hitIndex) {\n return new GeomTarget(hitIndex, TargetPrototype$Companion_getInstance().createTipLayoutHint_17pt0e$(hitCoord, this.hitShape_8be2vx$, this.tooltipParams_0.getColor(), this.tooltipKind_8be2vx$, this.tooltipParams_0.getStemLength()), this.tooltipParams_0.getTipLayoutHints());\n };\n function TargetPrototype$Companion() {\n TargetPrototype$Companion_instance = this;\n }\n TargetPrototype$Companion.prototype.createTipLayoutHint_17pt0e$ = function (hitCoord, hitShape, fill, tooltipKind, stemLength) {\n var tmp$;\n switch (hitShape.kind.name) {\n case 'POINT':\n switch (tooltipKind.name) {\n case 'VERTICAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.verticalTooltip_6lq1u6$(hitCoord, hitShape.point.radius, fill, stemLength);\n break;\n case 'CURSOR_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n break;\n default:throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for POINT').toString());\n }\n\n break;\n case 'RECT':\n switch (tooltipKind.name) {\n case 'VERTICAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.verticalTooltip_6lq1u6$(hitCoord, 0.0, fill, stemLength);\n break;\n case 'HORIZONTAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.horizontalTooltip_6lq1u6$(hitCoord, hitShape.rect.width / 2, fill, stemLength);\n break;\n case 'CURSOR_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n break;\n default:throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for RECT').toString());\n }\n\n break;\n case 'PATH':\n if (equals(tooltipKind, TipLayoutHint$Kind.HORIZONTAL_TOOLTIP))\n tmp$ = TipLayoutHint.Companion.horizontalTooltip_6lq1u6$(hitCoord, 0.0, fill, stemLength);\n else {\n throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for PATH').toString());\n }\n\n break;\n case 'POLYGON':\n if (equals(tooltipKind, TipLayoutHint$Kind.CURSOR_TOOLTIP))\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n else {\n throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for POLYGON').toString());\n }\n\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TargetPrototype$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TargetPrototype$Companion_instance = null;\n function TargetPrototype$Companion_getInstance() {\n if (TargetPrototype$Companion_instance === null) {\n new TargetPrototype$Companion();\n }return TargetPrototype$Companion_instance;\n }\n TargetPrototype.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetPrototype',\n interfaces: []\n };\n function TransformedTargetLocator(targetLocator) {\n this.targetLocator_q7bze5$_0 = targetLocator;\n }\n TransformedTargetLocator.prototype.search_gpjtzr$ = function (coord) {\n var tmp$;\n var targetCoord = this.convertToTargetCoord_gpjtzr$(coord);\n tmp$ = this.targetLocator_q7bze5$_0.search_gpjtzr$(targetCoord);\n if (tmp$ == null) {\n return null;\n }var result = tmp$;\n return this.convertLookupResult_rz45e2$_0(result);\n };\n TransformedTargetLocator.prototype.convertLookupResult_rz45e2$_0 = function (lookupResult) {\n return new GeomTargetLocator$LookupResult(this.convertGeomTargets_cu5hhh$_0(lookupResult.targets), this.convertToPlotDistance_14dthe$(lookupResult.distance), lookupResult.geomKind, lookupResult.contextualMapping, lookupResult.contextualMapping.isCrosshairEnabled);\n };\n function TransformedTargetLocator$convertGeomTargets$lambda(this$TransformedTargetLocator) {\n return function (geomTarget) {\n return new GeomTarget(geomTarget.hitIndex, this$TransformedTargetLocator.convertTipLayoutHint_jnrdzl$_0(geomTarget.tipLayoutHint), this$TransformedTargetLocator.convertTipLayoutHints_dshtp8$_0(geomTarget.aesTipLayoutHints));\n };\n }\n TransformedTargetLocator.prototype.convertGeomTargets_cu5hhh$_0 = function (geomTargets) {\n return ArrayList_init_0(collect.Lists.transform_l7riir$(geomTargets, TransformedTargetLocator$convertGeomTargets$lambda(this)));\n };\n TransformedTargetLocator.prototype.convertTipLayoutHint_jnrdzl$_0 = function (hint) {\n return new TipLayoutHint(hint.kind, ensureNotNull(this.safeConvertToPlotCoord_eoxeor$_0(hint.coord)), this.convertToPlotDistance_14dthe$(hint.objectRadius), hint.color, hint.stemLength);\n };\n TransformedTargetLocator.prototype.convertTipLayoutHints_dshtp8$_0 = function (tipLayoutHints) {\n var result = HashMap_init();\n var tmp$;\n tmp$ = tipLayoutHints.entries.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var aes = element.key;\n var hint = element.value;\n var value = this.convertTipLayoutHint_jnrdzl$_0(hint);\n result.put_xwzc9p$(aes, value);\n }\n return result;\n };\n TransformedTargetLocator.prototype.safeConvertToPlotCoord_eoxeor$_0 = function (coord) {\n return coord == null ? null : this.convertToPlotCoord_gpjtzr$(coord);\n };\n TransformedTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TransformedTargetLocator',\n interfaces: [GeomTargetLocator]\n };\n function AxisLayout() {\n }\n AxisLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisLayout',\n interfaces: []\n };\n function AxisLayoutInfo(b) {\n this.axisBreaks = null;\n this.axisLength = 0;\n this.orientation = null;\n this.axisDomain = null;\n this.tickLabelsBounds = null;\n this.tickLabelRotationAngle = 0;\n this.tickLabelHorizontalAnchor = null;\n this.tickLabelVerticalAnchor = null;\n this.tickLabelAdditionalOffsets = null;\n this.tickLabelSmallFont = false;\n this.tickLabelsBoundsMax_8be2vx$ = null;\n if (!(b.myAxisBreaks != null)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(b.myOrientation != null)) {\n var message_0 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(b.myTickLabelsBounds != null)) {\n var message_1 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_1.toString());\n }if (!(b.myAxisDomain != null)) {\n var message_2 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_2.toString());\n }this.axisBreaks = b.myAxisBreaks;\n this.axisLength = b.myAxisLength;\n this.orientation = b.myOrientation;\n this.axisDomain = b.myAxisDomain;\n this.tickLabelsBounds = b.myTickLabelsBounds;\n this.tickLabelRotationAngle = b.myTickLabelRotationAngle;\n this.tickLabelHorizontalAnchor = b.myLabelHorizontalAnchor;\n this.tickLabelVerticalAnchor = b.myLabelVerticalAnchor;\n this.tickLabelAdditionalOffsets = b.myLabelAdditionalOffsets;\n this.tickLabelSmallFont = b.myTickLabelSmallFont;\n this.tickLabelsBoundsMax_8be2vx$ = b.myMaxTickLabelsBounds;\n }\n AxisLayoutInfo.prototype.withAxisLength_14dthe$ = function (axisLength) {\n var b = new AxisLayoutInfo$Builder();\n b.myAxisBreaks = this.axisBreaks;\n b.myAxisLength = axisLength;\n b.myOrientation = this.orientation;\n b.myAxisDomain = this.axisDomain;\n b.myTickLabelsBounds = this.tickLabelsBounds;\n b.myTickLabelRotationAngle = this.tickLabelRotationAngle;\n b.myLabelHorizontalAnchor = this.tickLabelHorizontalAnchor;\n b.myLabelVerticalAnchor = this.tickLabelVerticalAnchor;\n b.myLabelAdditionalOffsets = this.tickLabelAdditionalOffsets;\n b.myTickLabelSmallFont = this.tickLabelSmallFont;\n b.myMaxTickLabelsBounds = this.tickLabelsBoundsMax_8be2vx$;\n return b;\n };\n AxisLayoutInfo.prototype.axisBounds = function () {\n return ensureNotNull(this.tickLabelsBounds).union_wthzt5$(DoubleRectangle_init(0.0, 0.0, 0.0, 0.0));\n };\n function AxisLayoutInfo$Builder() {\n this.myAxisLength = 0;\n this.myOrientation = null;\n this.myAxisDomain = null;\n this.myMaxTickLabelsBounds = null;\n this.myTickLabelSmallFont = false;\n this.myLabelAdditionalOffsets = null;\n this.myLabelHorizontalAnchor = null;\n this.myLabelVerticalAnchor = null;\n this.myTickLabelRotationAngle = 0.0;\n this.myTickLabelsBounds = null;\n this.myAxisBreaks = null;\n }\n AxisLayoutInfo$Builder.prototype.build = function () {\n return new AxisLayoutInfo(this);\n };\n AxisLayoutInfo$Builder.prototype.axisLength_14dthe$ = function (d) {\n this.myAxisLength = d;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.orientation_9y97dg$ = function (o) {\n this.myOrientation = o;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.axisDomain_4fzjta$ = function (r) {\n this.myAxisDomain = r;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelsBoundsMax_myx2hi$ = function (r) {\n this.myMaxTickLabelsBounds = r;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelSmallFont_6taknv$ = function (b) {\n this.myTickLabelSmallFont = b;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelAdditionalOffsets_eajcfd$ = function (labelAdditionalOffsets) {\n this.myLabelAdditionalOffsets = labelAdditionalOffsets;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelHorizontalAnchor_tk0ev1$ = function (labelHorizontalAnchor) {\n this.myLabelHorizontalAnchor = labelHorizontalAnchor;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelVerticalAnchor_24j3ht$ = function (labelVerticalAnchor) {\n this.myLabelVerticalAnchor = labelVerticalAnchor;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelRotationAngle_14dthe$ = function (rotationAngle) {\n this.myTickLabelRotationAngle = rotationAngle;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelsBounds_myx2hi$ = function (rectangle) {\n this.myTickLabelsBounds = rectangle;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.axisBreaks_bysjzy$ = function (breaks) {\n this.myAxisBreaks = breaks;\n return this;\n };\n AxisLayoutInfo$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n AxisLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLayoutInfo',\n interfaces: []\n };\n function EmptyAxisLayout(xDomain, yDomain, myOrientation) {\n EmptyAxisLayout$Companion_getInstance();\n this.myOrientation_0 = myOrientation;\n this.myAxisDomain_0 = null;\n this.myAxisDomain_0 = this.myOrientation_0.isHorizontal ? xDomain : yDomain;\n }\n EmptyAxisLayout.prototype.initialThickness = function () {\n return 0.0;\n };\n EmptyAxisLayout.prototype.doLayout_o2m17x$ = function (displaySize, maxTickLabelsBoundsStretched) {\n var axisLength = this.myOrientation_0.isHorizontal ? displaySize.x : displaySize.y;\n var tickLabelsBounds = this.myOrientation_0.isHorizontal ? DoubleRectangle_init(0.0, 0.0, axisLength, 0.0) : DoubleRectangle_init(0.0, 0.0, 0.0, axisLength);\n var breaks = new GuideBreaks(emptyList(), emptyList(), emptyList());\n var builder = (new AxisLayoutInfo$Builder()).axisBreaks_bysjzy$(breaks).axisLength_14dthe$(axisLength).orientation_9y97dg$(this.myOrientation_0).axisDomain_4fzjta$(this.myAxisDomain_0).tickLabelsBounds_myx2hi$(tickLabelsBounds);\n return builder.build();\n };\n function EmptyAxisLayout$Companion() {\n EmptyAxisLayout$Companion_instance = this;\n }\n EmptyAxisLayout$Companion.prototype.bottom_gyv40k$ = function (xDomain, yDomain) {\n return new EmptyAxisLayout(xDomain, yDomain, Orientation$BOTTOM_getInstance());\n };\n EmptyAxisLayout$Companion.prototype.left_gyv40k$ = function (xDomain, yDomain) {\n return new EmptyAxisLayout(xDomain, yDomain, Orientation$LEFT_getInstance());\n };\n EmptyAxisLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var EmptyAxisLayout$Companion_instance = null;\n function EmptyAxisLayout$Companion_getInstance() {\n if (EmptyAxisLayout$Companion_instance === null) {\n new EmptyAxisLayout$Companion();\n }return EmptyAxisLayout$Companion_instance;\n }\n EmptyAxisLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EmptyAxisLayout',\n interfaces: [AxisLayout]\n };\n function FacetGridPlotLayout(facets, tileLayout) {\n FacetGridPlotLayout$Companion_getInstance();\n PlotLayoutBase.call(this);\n this.facets_0 = facets;\n this.tileLayout_0 = tileLayout;\n this.totalPanelHorizontalPadding_0 = FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0 * (this.facets_0.colCount - 1 | 0);\n this.totalPanelVerticalPadding_0 = FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0 * (this.facets_0.rowCount - 1 | 0);\n this.setPadding_6y0v78$(10.0, 10.0, 0.0, 0.0);\n if (!this.facets_0.isDefined) {\n var message = 'Undefined facets.';\n throw IllegalArgumentException_init(message.toString());\n }}\n FacetGridPlotLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var tilesAreaSize = new DoubleVector(preferredSize.x - (this.paddingLeft_0 + this.paddingRight_0), preferredSize.y - (this.paddingTop_0 + this.paddingBottom_0));\n var facetTiles = this.facets_0.tileInfos();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_3;\n tmp$_3 = facetTiles.iterator();\n while (tmp$_3.hasNext()) {\n var element = tmp$_3.next();\n if (!element.colLabs.isEmpty()) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var tileColLabCounts = (tmp$_1 = (tmp$_0 = (tmp$ = firstOrNull$result) != null ? tmp$.colLabs : null) != null ? tmp$_0.size : null) != null ? tmp$_1 : 0;\n var destination = ArrayList_init();\n var tmp$_4;\n tmp$_4 = facetTiles.iterator();\n while (tmp$_4.hasNext()) {\n var element_0 = tmp$_4.next();\n if (!element_0.colLabs.isEmpty())\n destination.add_11rb$(element_0);\n }\n var tmp$_5;\n var set = HashSet_init_0();\n var list = ArrayList_init();\n tmp$_5 = destination.iterator();\n while (tmp$_5.hasNext()) {\n var e = tmp$_5.next();\n var key = e.row;\n if (set.add_11rb$(key))\n list.add_11rb$(e);\n }\n var tileWithColLabInRowCount = list.size;\n var totalAddedHeight = FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(tileColLabCounts) * tileWithColLabInRowCount;\n var any$result;\n any$break: do {\n var tmp$_6;\n if (Kotlin.isType(facetTiles, Collection) && facetTiles.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_6 = facetTiles.iterator();\n while (tmp$_6.hasNext()) {\n var element_1 = tmp$_6.next();\n if (element_1.rowLab != null) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n var labsInRow = any$result ? 1 : 0;\n var labsTotalDim = new DoubleVector(labsInRow * FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT, totalAddedHeight);\n tilesAreaSize = tilesAreaSize.subtract_gpjtzr$(labsTotalDim);\n var tileWidth = (tilesAreaSize.x - this.totalPanelHorizontalPadding_0) / this.facets_0.colCount;\n var tileHeight = (tilesAreaSize.y - this.totalPanelVerticalPadding_0) / this.facets_0.rowCount;\n var tileInfo = this.layoutTile_0(tileWidth, tileHeight);\n for (var i = 0; i <= 1; i++) {\n var tilesAreaSizeNew = this.tilesAreaSize_0(tileInfo);\n var widthDiff = tilesAreaSize.x - tilesAreaSizeNew.x;\n var heightDiff = tilesAreaSize.y - tilesAreaSizeNew.y;\n var tmp$_7 = JsMath.abs(widthDiff) <= this.facets_0.colCount;\n if (tmp$_7) {\n tmp$_7 = JsMath.abs(heightDiff) <= this.facets_0.rowCount;\n }if (tmp$_7) {\n break;\n }var geomWidth = tileInfo.geomWidth_8be2vx$() + widthDiff / this.facets_0.colCount;\n var newPanelWidth = geomWidth + tileInfo.axisThicknessY_8be2vx$();\n var geomHeight = tileInfo.geomHeight_8be2vx$() + heightDiff / this.facets_0.rowCount;\n var newPanelHeight = geomHeight + tileInfo.axisThicknessX_8be2vx$();\n tileInfo = this.layoutTile_0(newPanelWidth, newPanelHeight);\n }\n var axisThicknessX = tileInfo.axisThicknessX_8be2vx$();\n var axisThicknessY = tileInfo.axisThicknessY_8be2vx$();\n var geomWidth_0 = tileInfo.geomWidth_8be2vx$();\n var geomHeight_0 = tileInfo.geomHeight_8be2vx$();\n var tilesAreaBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n var tilesAreaOffset = new DoubleVector(this.paddingLeft_0, this.paddingTop_0);\n var tileInfos = ArrayList_init();\n var offsetX = 0.0;\n var offsetY = 0.0;\n var currRow = 0;\n var prevHeight = 0.0;\n tmp$_2 = facetTiles.iterator();\n while (tmp$_2.hasNext()) {\n var facetTile = tmp$_2.next();\n var width = geomWidth_0;\n var geomX = 0.0;\n if (facetTile.yAxis) {\n width += axisThicknessY;\n geomX = axisThicknessY;\n }if (facetTile.rowLab != null) {\n width += FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT;\n }var height = geomHeight_0;\n var geomY;\n if (facetTile.xAxis && facetTile.row === (this.facets_0.rowCount - 1 | 0)) {\n height += axisThicknessX;\n }var addedHeight = FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(facetTile.colLabs.size);\n height += addedHeight;\n geomY = addedHeight;\n var bounds = DoubleRectangle_init(0.0, 0.0, width, height);\n var geomBounds = DoubleRectangle_init(geomX, geomY, geomWidth_0, geomHeight_0);\n var row = facetTile.row;\n if (row > currRow) {\n currRow = row;\n offsetY += prevHeight + FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0;\n }prevHeight = height;\n var col = facetTile.col;\n if (col === 0) {\n offsetX = 0.0;\n }var offset = new DoubleVector(offsetX, offsetY);\n offsetX += width + FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0;\n var info = TileLayoutInfo_init(bounds, geomBounds, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds), tileInfo.layoutInfo_8be2vx$.xAxisInfo, tileInfo.layoutInfo_8be2vx$.yAxisInfo, facetTile.xAxis, facetTile.yAxis, facetTile.trueIndex).withOffset_gpjtzr$(tilesAreaOffset.add_gpjtzr$(offset)).withFacetLabels_5hkr16$(facetTile.colLabs, facetTile.rowLab);\n tileInfos.add_11rb$(info);\n tilesAreaBounds = tilesAreaBounds.union_wthzt5$(info.getAbsoluteBounds_gpjtzr$(tilesAreaOffset));\n }\n var plotSize = new DoubleVector(tilesAreaBounds.right + this.paddingRight_0, tilesAreaBounds.height + this.paddingBottom_0);\n return new PlotLayoutInfo(tileInfos, plotSize);\n };\n FacetGridPlotLayout.prototype.layoutTile_0 = function (tileWidth, tileHeight) {\n var layoutInfo = this.tileLayout_0.doLayout_gpjtzr$(new DoubleVector(tileWidth, tileHeight));\n return new FacetGridPlotLayout$MyTileInfo(layoutInfo);\n };\n FacetGridPlotLayout.prototype.tilesAreaSize_0 = function (tileInfo) {\n var w = tileInfo.geomWidth_8be2vx$() * this.facets_0.colCount + this.totalPanelHorizontalPadding_0 + tileInfo.axisThicknessY_8be2vx$();\n var h = tileInfo.geomHeight_8be2vx$() * this.facets_0.rowCount + this.totalPanelVerticalPadding_0 + tileInfo.axisThicknessX_8be2vx$();\n return new DoubleVector(w, h);\n };\n function FacetGridPlotLayout$MyTileInfo(layoutInfo) {\n this.layoutInfo_8be2vx$ = layoutInfo;\n }\n FacetGridPlotLayout$MyTileInfo.prototype.axisThicknessX_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.bounds.bottom - this.layoutInfo_8be2vx$.geomBounds.bottom;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.axisThicknessY_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.left - this.layoutInfo_8be2vx$.bounds.left;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.geomWidth_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.width;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.geomHeight_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.height;\n };\n FacetGridPlotLayout$MyTileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyTileInfo',\n interfaces: []\n };\n function FacetGridPlotLayout$Companion() {\n FacetGridPlotLayout$Companion_instance = this;\n this.FACET_TAB_HEIGHT = 30.0;\n this.FACET_H_PADDING = 0;\n this.FACET_V_PADDING = 6;\n this.PANEL_PADDING_0 = 10.0;\n }\n FacetGridPlotLayout$Companion.prototype.facetColLabelSize_14dthe$ = function (colWidth) {\n return new DoubleVector(colWidth - 0, this.FACET_TAB_HEIGHT - 6 * 2.0);\n };\n FacetGridPlotLayout$Companion.prototype.facetColHeadHeight_za3lpa$ = function (labCount) {\n var tmp$;\n if (labCount > 0) {\n tmp$ = this.facetColLabelSize_14dthe$(0.0).y * labCount + 12;\n } else {\n tmp$ = 0.0;\n }\n return tmp$;\n };\n FacetGridPlotLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FacetGridPlotLayout$Companion_instance = null;\n function FacetGridPlotLayout$Companion_getInstance() {\n if (FacetGridPlotLayout$Companion_instance === null) {\n new FacetGridPlotLayout$Companion();\n }return FacetGridPlotLayout$Companion_instance;\n }\n FacetGridPlotLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetGridPlotLayout',\n interfaces: [PlotLayoutBase]\n };\n function GeometryUtil() {\n GeometryUtil_instance = this;\n }\n GeometryUtil.prototype.union_te9coj$ = function (first, optionalSecond) {\n var tmp$;\n if (optionalSecond == null) {\n tmp$ = first;\n } else\n tmp$ = first.union_wthzt5$(optionalSecond);\n return tmp$;\n };\n GeometryUtil.prototype.union_a7nkjf$ = function (head, c) {\n var tmp$;\n var result = head;\n tmp$ = c.iterator();\n while (tmp$.hasNext()) {\n var r = tmp$.next();\n result = result.union_wthzt5$(r);\n }\n return result;\n };\n GeometryUtil.prototype.doubleRange_gyv40k$ = function (xRange, yRange) {\n var xOrigin = xRange.lowerEnd;\n var yOrigin = yRange.lowerEnd;\n var xSpan = xRange.upperEnd - xRange.lowerEnd;\n var ySpan = yRange.upperEnd - yRange.lowerEnd;\n return DoubleRectangle_init(xOrigin, yOrigin, xSpan, ySpan);\n };\n GeometryUtil.prototype.changeWidth_j6cmed$ = function (r, width) {\n return DoubleRectangle_init(r.origin.x, r.origin.y, width, r.dimension.y);\n };\n GeometryUtil.prototype.changeWidthKeepRight_j6cmed$ = function (r, width) {\n return DoubleRectangle_init(r.right - width, r.origin.y, width, r.dimension.y);\n };\n GeometryUtil.prototype.changeHeight_j6cmed$ = function (r, height) {\n return DoubleRectangle_init(r.origin.x, r.origin.y, r.dimension.x, height);\n };\n GeometryUtil.prototype.changeHeightKeepBottom_j6cmed$ = function (r, height) {\n return DoubleRectangle_init(r.origin.x, r.bottom - height, r.dimension.x, height);\n };\n GeometryUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeometryUtil',\n interfaces: []\n };\n var GeometryUtil_instance = null;\n function GeometryUtil_getInstance() {\n if (GeometryUtil_instance === null) {\n new GeometryUtil();\n }return GeometryUtil_instance;\n }\n function LegendBoxInfo(size) {\n LegendBoxInfo$Companion_getInstance();\n this.size_8be2vx$ = size;\n }\n Object.defineProperty(LegendBoxInfo.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n function LegendBoxInfo$Companion() {\n LegendBoxInfo$Companion_instance = this;\n this.EMPTY = new LegendBoxInfo$Companion$EMPTY$ObjectLiteral(DoubleVector.Companion.ZERO);\n }\n function LegendBoxInfo$Companion$EMPTY$ObjectLiteral(size) {\n LegendBoxInfo.call(this, size);\n }\n Object.defineProperty(LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype.createLegendBox = function () {\n throw IllegalStateException_init('Empty legend box info');\n };\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n LegendBoxInfo$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBoxInfo$Companion_instance = null;\n function LegendBoxInfo$Companion_getInstance() {\n if (LegendBoxInfo$Companion_instance === null) {\n new LegendBoxInfo$Companion();\n }return LegendBoxInfo$Companion_instance;\n }\n LegendBoxInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxInfo',\n interfaces: []\n };\n function LegendBoxesLayout(myPlotBounds, myTheme) {\n this.myPlotBounds_0 = myPlotBounds;\n this.myTheme_0 = myTheme;\n }\n LegendBoxesLayout.prototype.doLayout_8sg693$ = function (infos) {\n var legendPosition = this.myTheme_0.position();\n var legendJustification = this.myTheme_0.justification();\n var legendArrangement = LegendArrangement$VERTICAL_getInstance();\n var plotCenter = this.myPlotBounds_0.center;\n var plotInnerBoundsWithoutLegendBoxes = this.myPlotBounds_0;\n var boxWithLocationList = legendArrangement === LegendArrangement$VERTICAL_getInstance() ? LegendBoxesLayoutUtil_getInstance().verticalStack_8sg693$(infos) : LegendBoxesLayoutUtil_getInstance().horizontalStack_8sg693$(infos);\n var boxesSize = LegendBoxesLayoutUtil_getInstance().size_9w4uif$(boxWithLocationList);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT) || equals(legendPosition, LegendPosition$Companion_getInstance().RIGHT)) {\n var b = plotInnerBoundsWithoutLegendBoxes.width - boxesSize.x;\n var plotWidth = JsMath.max(0.0, b);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT)) {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeWidthKeepRight_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotWidth);\n } else {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeWidth_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotWidth);\n }\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP) || equals(legendPosition, LegendPosition$Companion_getInstance().BOTTOM)) {\n var b_0 = plotInnerBoundsWithoutLegendBoxes.height - boxesSize.y;\n var plotHeight = JsMath.max(0.0, b_0);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP)) {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeHeightKeepBottom_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotHeight);\n } else {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeHeight_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotHeight);\n }\n }var legendOrigin;\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT)) {\n legendOrigin = new DoubleVector(plotInnerBoundsWithoutLegendBoxes.left - boxesSize.x, plotCenter.y - boxesSize.y / 2);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().RIGHT)) {\n legendOrigin = new DoubleVector(plotInnerBoundsWithoutLegendBoxes.right, plotCenter.y - boxesSize.y / 2);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP)) {\n legendOrigin = new DoubleVector(plotCenter.x - boxesSize.x / 2, plotInnerBoundsWithoutLegendBoxes.top - boxesSize.y);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().BOTTOM)) {\n legendOrigin = new DoubleVector(plotCenter.x - boxesSize.x / 2, plotInnerBoundsWithoutLegendBoxes.bottom);\n } else {\n legendOrigin = LegendBoxesLayoutUtil_getInstance().overlayLegendOrigin_tmgej$(plotInnerBoundsWithoutLegendBoxes, boxesSize, legendPosition, legendJustification);\n }\n var resultBoxWithLocationList = LegendBoxesLayoutUtil_getInstance().moveAll_cpge3q$(legendOrigin, boxWithLocationList);\n return new LegendBoxesLayout$Result(plotInnerBoundsWithoutLegendBoxes, resultBoxWithLocationList);\n };\n function LegendBoxesLayout$Result(plotInnerBoundsWithoutLegendBoxes, locations) {\n this.plotInnerBoundsWithoutLegendBoxes = plotInnerBoundsWithoutLegendBoxes;\n this.boxWithLocationList = ArrayList_init_0(locations);\n }\n LegendBoxesLayout$Result.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Result',\n interfaces: []\n };\n function LegendBoxesLayout$BoxWithLocation(legendBox, location) {\n this.legendBox = legendBox;\n this.location = location;\n }\n LegendBoxesLayout$BoxWithLocation.prototype.size_8be2vx$ = function () {\n return this.legendBox.size_8be2vx$;\n };\n LegendBoxesLayout$BoxWithLocation.prototype.bounds_8be2vx$ = function () {\n return new DoubleRectangle(this.location, this.legendBox.size_8be2vx$);\n };\n LegendBoxesLayout$BoxWithLocation.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxWithLocation',\n interfaces: []\n };\n LegendBoxesLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxesLayout',\n interfaces: []\n };\n function LegendBoxesLayoutUtil() {\n LegendBoxesLayoutUtil_instance = this;\n }\n LegendBoxesLayoutUtil.prototype.verticalStack_8sg693$ = function (boxInfos) {\n var tmp$;\n var result = ArrayList_init();\n var y = 0.0;\n tmp$ = boxInfos.iterator();\n while (tmp$.hasNext()) {\n var info = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(info, new DoubleVector(0.0, y)));\n y += info.size_8be2vx$.y;\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.horizontalStack_8sg693$ = function (boxInfos) {\n var tmp$;\n var result = ArrayList_init();\n var x = 0.0;\n tmp$ = boxInfos.iterator();\n while (tmp$.hasNext()) {\n var info = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(info, new DoubleVector(x, 0.0)));\n x += info.size_8be2vx$.x;\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.moveAll_cpge3q$ = function (delta, boxWithLocationList) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = boxWithLocationList.iterator();\n while (tmp$.hasNext()) {\n var boxWithLocation = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(boxWithLocation.legendBox, boxWithLocation.location.add_gpjtzr$(delta)));\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.size_9w4uif$ = function (boxWithLocationList) {\n var tmp$, tmp$_0, tmp$_1;\n var bounds = null;\n tmp$ = boxWithLocationList.iterator();\n while (tmp$.hasNext()) {\n var boxWithLocation = tmp$.next();\n bounds = (tmp$_0 = bounds != null ? bounds.union_wthzt5$(boxWithLocation.bounds_8be2vx$()) : null) != null ? tmp$_0 : boxWithLocation.bounds_8be2vx$();\n }\n return (tmp$_1 = bounds != null ? bounds.dimension : null) != null ? tmp$_1 : DoubleVector.Companion.ZERO;\n };\n LegendBoxesLayoutUtil.prototype.overlayLegendOrigin_tmgej$ = function (plotBounds, legendSize, legendPosition, legendJustification) {\n var plotSize = plotBounds.dimension;\n var absolutePosition = new DoubleVector(plotBounds.left + plotSize.x * legendPosition.x, plotBounds.bottom - plotSize.y * legendPosition.y);\n var originOffset = new DoubleVector(-legendSize.x * legendJustification.x, legendSize.y * legendJustification.y - legendSize.y);\n return absolutePosition.add_gpjtzr$(originOffset);\n };\n LegendBoxesLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LegendBoxesLayoutUtil',\n interfaces: []\n };\n var LegendBoxesLayoutUtil_instance = null;\n function LegendBoxesLayoutUtil_getInstance() {\n if (LegendBoxesLayoutUtil_instance === null) {\n new LegendBoxesLayoutUtil();\n }return LegendBoxesLayoutUtil_instance;\n }\n function LiveMapTileLayout() {\n }\n LiveMapTileLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var geomBounds = XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(0.0, 0.0, preferredSize);\n geomBounds = geomBounds.union_wthzt5$(new DoubleRectangle(geomBounds.origin, XYPlotLayoutUtil_getInstance().GEOM_MIN_SIZE));\n var geomWithAxisBounds = geomBounds;\n return TileLayoutInfo_init(geomWithAxisBounds, geomBounds, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds), null, null, void 0, void 0, 0);\n };\n LiveMapTileLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapTileLayout',\n interfaces: [TileLayout]\n };\n function PlotAxisLayout(scale, domainX, domainY, coordProvider, theme, orientation) {\n PlotAxisLayout$Companion_getInstance();\n this.scale_0 = scale;\n this.domainX_0 = domainX;\n this.domainY_0 = domainY;\n this.coordProvider_0 = coordProvider;\n this.theme_0 = theme;\n this.orientation_0 = orientation;\n }\n PlotAxisLayout.prototype.initialThickness = function () {\n var tmp$;\n if (this.theme_0.showTickMarks() || this.theme_0.showTickLabels()) {\n var v = this.theme_0.tickLabelDistance();\n if (this.theme_0.showTickLabels()) {\n tmp$ = v + PlotAxisLayout$Companion_getInstance().initialTickLabelSize_0(this.orientation_0);\n } else {\n tmp$ = v;\n }\n return tmp$;\n }return 0.0;\n };\n PlotAxisLayout.prototype.doLayout_o2m17x$ = function (displaySize, maxTickLabelsBoundsStretched) {\n var layouter = this.createLayouter_0(displaySize);\n return layouter.doLayout_p1d3jc$(PlotAxisLayout$Companion_getInstance().axisLength_0(displaySize, this.orientation_0), maxTickLabelsBoundsStretched);\n };\n PlotAxisLayout.prototype.createLayouter_0 = function (displaySize) {\n var domains = this.coordProvider_0.adjustDomains_jz8wgn$(this.domainX_0, this.domainY_0, displaySize);\n var axisDomain = PlotAxisLayout$Companion_getInstance().axisDomain_0(domains, this.orientation_0);\n var breaksProvider = AxisBreaksUtil_getInstance().createAxisBreaksProvider_oftday$(this.scale_0, axisDomain);\n return AxisLayouter$Companion_getInstance().create_4ebi60$(this.orientation_0, axisDomain, breaksProvider, this.theme_0);\n };\n function PlotAxisLayout$Companion() {\n PlotAxisLayout$Companion_instance = this;\n this.TICK_LABEL_SPEC_0 = PlotLabelSpec$AXIS_TICK_getInstance();\n }\n PlotAxisLayout$Companion.prototype.bottom_eknalg$ = function (scale, xDomain, yDomain, coordProvider, theme) {\n return new PlotAxisLayout(scale, xDomain, yDomain, coordProvider, theme, Orientation$BOTTOM_getInstance());\n };\n PlotAxisLayout$Companion.prototype.left_eknalg$ = function (scale, xDomain, yDomain, coordProvider, theme) {\n return new PlotAxisLayout(scale, xDomain, yDomain, coordProvider, theme, Orientation$LEFT_getInstance());\n };\n PlotAxisLayout$Companion.prototype.initialTickLabelSize_0 = function (orientation) {\n return orientation.isHorizontal ? this.TICK_LABEL_SPEC_0.height() : this.TICK_LABEL_SPEC_0.width_za3lpa$(1);\n };\n PlotAxisLayout$Companion.prototype.axisLength_0 = function (displaySize, orientation) {\n return orientation.isHorizontal ? displaySize.x : displaySize.y;\n };\n PlotAxisLayout$Companion.prototype.axisDomain_0 = function (xyDomains, orientation) {\n return orientation.isHorizontal ? xyDomains.first : xyDomains.second;\n };\n PlotAxisLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotAxisLayout$Companion_instance = null;\n function PlotAxisLayout$Companion_getInstance() {\n if (PlotAxisLayout$Companion_instance === null) {\n new PlotAxisLayout$Companion();\n }return PlotAxisLayout$Companion_instance;\n }\n PlotAxisLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotAxisLayout',\n interfaces: [AxisLayout]\n };\n function PlotLayout() {\n }\n PlotLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PlotLayout',\n interfaces: []\n };\n function PlotLayoutBase() {\n this.paddingTop_72hspu$_0 = 0.0;\n this.paddingRight_oc6xpz$_0 = 0.0;\n this.paddingBottom_phgrg6$_0 = 0.0;\n this.paddingLeft_66kgx2$_0 = 0.0;\n }\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingTop_0', {\n configurable: true,\n get: function () {\n return this.paddingTop_72hspu$_0;\n },\n set: function (paddingTop) {\n this.paddingTop_72hspu$_0 = paddingTop;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingRight_0', {\n configurable: true,\n get: function () {\n return this.paddingRight_oc6xpz$_0;\n },\n set: function (paddingRight) {\n this.paddingRight_oc6xpz$_0 = paddingRight;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingBottom_0', {\n configurable: true,\n get: function () {\n return this.paddingBottom_phgrg6$_0;\n },\n set: function (paddingBottom) {\n this.paddingBottom_phgrg6$_0 = paddingBottom;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingLeft_0', {\n configurable: true,\n get: function () {\n return this.paddingLeft_66kgx2$_0;\n },\n set: function (paddingLeft) {\n this.paddingLeft_66kgx2$_0 = paddingLeft;\n }\n });\n PlotLayoutBase.prototype.setPadding_6y0v78$ = function (top, right, bottom, left) {\n this.paddingTop_0 = top;\n this.paddingRight_0 = right;\n this.paddingBottom_0 = bottom;\n this.paddingLeft_0 = left;\n };\n PlotLayoutBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLayoutBase',\n interfaces: [PlotLayout]\n };\n function PlotLayoutInfo(tiles, size) {\n this.size = size;\n this.tiles = ArrayList_init_0(tiles);\n }\n PlotLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLayoutInfo',\n interfaces: []\n };\n function PlotLayoutUtil() {\n PlotLayoutUtil_instance = this;\n this.AXIS_TITLE_OUTER_MARGIN = 4.0;\n this.AXIS_TITLE_INNER_MARGIN = 4.0;\n this.TITLE_V_MARGIN_0 = 4.0;\n this.LIVE_MAP_PLOT_PADDING_0 = new DoubleVector(10.0, 0.0);\n this.LIVE_MAP_PLOT_MARGIN_0 = new DoubleVector(10.0, 10.0);\n }\n PlotLayoutUtil.prototype.titleDimensions_61zpoe$ = function (text) {\n if (base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n return DoubleVector.Companion.ZERO;\n }var labelSpec = PlotLabelSpec$PLOT_TITLE_getInstance();\n return new DoubleVector(labelSpec.width_za3lpa$(text.length), labelSpec.height() + 2 * this.TITLE_V_MARGIN_0);\n };\n PlotLayoutUtil.prototype.axisTitleDimensions_61zpoe$ = function (text) {\n if (base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n return DoubleVector.Companion.ZERO;\n }var labelSpec = PlotLabelSpec$AXIS_TITLE_getInstance();\n return new DoubleVector(labelSpec.width_za3lpa$(text.length), labelSpec.height());\n };\n PlotLayoutUtil.prototype.absoluteGeomBounds_vjhcds$ = function (origin, plotLayoutInfo) {\n var tmp$, tmp$_0;\n if (!!plotLayoutInfo.tiles.isEmpty()) {\n var message = 'Plot is empty';\n throw IllegalArgumentException_init(message.toString());\n }var result = null;\n tmp$ = plotLayoutInfo.tiles.iterator();\n while (tmp$.hasNext()) {\n var tile = tmp$.next();\n var geomBounds = tile.getAbsoluteGeomBounds_gpjtzr$(origin);\n result = (tmp$_0 = result != null ? result.union_wthzt5$(geomBounds) : null) != null ? tmp$_0 : geomBounds;\n }\n return ensureNotNull(result);\n };\n PlotLayoutUtil.prototype.liveMapBounds_wthzt5$ = function (container) {\n return new DoubleRectangle(container.origin.add_gpjtzr$(this.LIVE_MAP_PLOT_PADDING_0), container.dimension.subtract_gpjtzr$(this.LIVE_MAP_PLOT_MARGIN_0));\n };\n PlotLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotLayoutUtil',\n interfaces: []\n };\n var PlotLayoutUtil_instance = null;\n function PlotLayoutUtil_getInstance() {\n if (PlotLayoutUtil_instance === null) {\n new PlotLayoutUtil();\n }return PlotLayoutUtil_instance;\n }\n function SingleTilePlotLayout(myTileLayout) {\n PlotLayoutBase.call(this);\n this.myTileLayout_0 = myTileLayout;\n this.setPadding_6y0v78$(10.0, 10.0, 0.0, 0.0);\n }\n SingleTilePlotLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tilePreferredSize = new DoubleVector(preferredSize.x - (this.paddingLeft_0 + this.paddingRight_0), preferredSize.y - (this.paddingTop_0 + this.paddingBottom_0));\n var tileInfo = this.myTileLayout_0.doLayout_gpjtzr$(tilePreferredSize);\n tileInfo = tileInfo.withOffset_gpjtzr$(new DoubleVector(this.paddingLeft_0, this.paddingTop_0));\n var plotSize = tileInfo.bounds.dimension;\n plotSize = plotSize.add_gpjtzr$(new DoubleVector(this.paddingRight_0, this.paddingBottom_0));\n return new PlotLayoutInfo(listOf(tileInfo), plotSize);\n };\n SingleTilePlotLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SingleTilePlotLayout',\n interfaces: [PlotLayoutBase]\n };\n function TileLayout() {\n }\n TileLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TileLayout',\n interfaces: []\n };\n function TileLayoutInfo(plotOrigin, bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, facetXLabels, facetYLabel, trueIndex) {\n this.plotOrigin = plotOrigin;\n this.bounds = bounds;\n this.geomBounds = geomBounds;\n this.clipBounds = clipBounds;\n this.xAxisInfo = xAxisInfo;\n this.yAxisInfo = yAxisInfo;\n this.facetXLabels = facetXLabels;\n this.facetYLabel = facetYLabel;\n this.trueIndex = trueIndex;\n this.xAxisShown = (this.xAxisInfo != null && xAxisShown);\n this.yAxisShown = (this.yAxisInfo != null && yAxisShown);\n }\n TileLayoutInfo.prototype.withOffset_gpjtzr$ = function (offset) {\n return new TileLayoutInfo(offset, this.bounds, this.geomBounds, this.clipBounds, this.xAxisInfo, this.yAxisInfo, this.xAxisShown, this.yAxisShown, this.facetXLabels, this.facetYLabel, this.trueIndex);\n };\n TileLayoutInfo.prototype.getAbsoluteBounds_gpjtzr$ = function (tilesOrigin) {\n var offset = tilesOrigin.add_gpjtzr$(this.plotOrigin);\n return this.bounds.add_gpjtzr$(offset);\n };\n TileLayoutInfo.prototype.getAbsoluteGeomBounds_gpjtzr$ = function (tilesOrigin) {\n var offset = tilesOrigin.add_gpjtzr$(this.plotOrigin);\n return this.geomBounds.add_gpjtzr$(offset);\n };\n TileLayoutInfo.prototype.withFacetLabels_5hkr16$ = function (xLabels, yLabel) {\n return new TileLayoutInfo(this.plotOrigin, this.bounds, this.geomBounds, this.clipBounds, this.xAxisInfo, this.yAxisInfo, this.xAxisShown, this.yAxisShown, xLabels, yLabel, this.trueIndex);\n };\n TileLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileLayoutInfo',\n interfaces: []\n };\n function TileLayoutInfo_init(bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, trueIndex, $this) {\n if (xAxisShown === void 0)\n xAxisShown = true;\n if (yAxisShown === void 0)\n yAxisShown = true;\n $this = $this || Object.create(TileLayoutInfo.prototype);\n TileLayoutInfo.call($this, DoubleVector.Companion.ZERO, bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, emptyList(), null, trueIndex);\n return $this;\n }\n function XYPlotLayoutUtil() {\n XYPlotLayoutUtil_instance = this;\n this.GEOM_MARGIN = 0.0;\n this.CLIP_EXTEND_0 = 5.0;\n this.GEOM_MIN_SIZE = new DoubleVector(50.0, 50.0);\n }\n XYPlotLayoutUtil.prototype.geomBounds_pym7oz$ = function (xAxisThickness, yAxisThickness, plotSize) {\n var marginLeftTop = new DoubleVector(yAxisThickness, this.GEOM_MARGIN);\n var marginRightBottom = new DoubleVector(this.GEOM_MARGIN, xAxisThickness);\n var geomSize = plotSize.subtract_gpjtzr$(marginLeftTop).subtract_gpjtzr$(marginRightBottom);\n if (geomSize.x < this.GEOM_MIN_SIZE.x) {\n geomSize = new DoubleVector(this.GEOM_MIN_SIZE.x, geomSize.y);\n }if (geomSize.y < this.GEOM_MIN_SIZE.y) {\n geomSize = new DoubleVector(geomSize.x, this.GEOM_MIN_SIZE.y);\n }return new DoubleRectangle(marginLeftTop, geomSize);\n };\n XYPlotLayoutUtil.prototype.clipBounds_wthzt5$ = function (geomBounds) {\n return new DoubleRectangle(geomBounds.origin.subtract_gpjtzr$(new DoubleVector(this.CLIP_EXTEND_0, this.CLIP_EXTEND_0)), new DoubleVector(geomBounds.dimension.x + 2 * this.CLIP_EXTEND_0, geomBounds.dimension.y + 2 * this.CLIP_EXTEND_0));\n };\n XYPlotLayoutUtil.prototype.maxTickLabelsBounds_m3y558$ = function (axisOrientation, stretch, geomBounds, plotSize) {\n var tmp$;\n var geomPaddung = 10.0;\n var maxGeomBounds = DoubleRectangle_init(geomPaddung, geomPaddung, plotSize.x - 2 * geomPaddung, plotSize.y - 2 * geomPaddung);\n switch (axisOrientation.name) {\n case 'TOP':\n case 'BOTTOM':\n var leftSpace = geomBounds.left - maxGeomBounds.left + stretch;\n var rightSpace = maxGeomBounds.right - geomBounds.right + stretch;\n var height = 1.0E42;\n if (equals(axisOrientation, Orientation$TOP_getInstance()))\n tmp$ = -height;\n else\n tmp$ = 0.0;\n var top = tmp$;\n var left = -leftSpace;\n var width = leftSpace + rightSpace + geomBounds.width;\n return DoubleRectangle_init(left, top, width, height);\n default:throw IllegalArgumentException_init('Orientation not supported: ' + axisOrientation);\n }\n };\n XYPlotLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'XYPlotLayoutUtil',\n interfaces: []\n };\n var XYPlotLayoutUtil_instance = null;\n function XYPlotLayoutUtil_getInstance() {\n if (XYPlotLayoutUtil_instance === null) {\n new XYPlotLayoutUtil();\n }return XYPlotLayoutUtil_instance;\n }\n function XYPlotTileLayout(xAxisLayout, yAxisLayout) {\n XYPlotTileLayout$Companion_getInstance();\n this.xAxisLayout_0 = xAxisLayout;\n this.yAxisLayout_0 = yAxisLayout;\n }\n XYPlotTileLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tmp$ = XYPlotTileLayout$Companion_getInstance().computeAxisInfos_0(this.xAxisLayout_0, this.yAxisLayout_0, preferredSize);\n var xAxisInfo = {v: tmp$.component1()}\n , yAxisInfo = tmp$.component2();\n var geomBounds = {v: XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisInfo.v.axisBounds().dimension.y, yAxisInfo.axisBounds().dimension.x, preferredSize)};\n var maxTickLabelsBounds = XYPlotLayoutUtil_getInstance().maxTickLabelsBounds_m3y558$(Orientation$BOTTOM_getInstance(), 0.0, geomBounds.v, preferredSize);\n var tickLabelsBounds = xAxisInfo.v.tickLabelsBounds;\n var leftOverflow = maxTickLabelsBounds.left - ensureNotNull(tickLabelsBounds).origin.x;\n var rightOverflow = tickLabelsBounds.origin.x + tickLabelsBounds.dimension.x - maxTickLabelsBounds.right;\n if (leftOverflow > 0) {\n geomBounds.v = DoubleRectangle_init(geomBounds.v.origin.x + leftOverflow, geomBounds.v.origin.y, geomBounds.v.dimension.x - leftOverflow, geomBounds.v.dimension.y);\n }if (rightOverflow > 0) {\n geomBounds.v = DoubleRectangle_init(geomBounds.v.origin.x, geomBounds.v.origin.y, geomBounds.v.dimension.x - rightOverflow, geomBounds.v.dimension.y);\n }geomBounds.v = geomBounds.v.union_wthzt5$(new DoubleRectangle(geomBounds.v.origin, XYPlotLayoutUtil_getInstance().GEOM_MIN_SIZE));\n var geomWithAxisBounds = XYPlotTileLayout$Companion_getInstance().tileBounds_0(xAxisInfo.v.axisBounds(), yAxisInfo.axisBounds(), geomBounds.v);\n xAxisInfo.v = xAxisInfo.v.withAxisLength_14dthe$(geomBounds.v.width).build();\n yAxisInfo = yAxisInfo.withAxisLength_14dthe$(geomBounds.v.height).build();\n return TileLayoutInfo_init(geomWithAxisBounds, geomBounds.v, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds.v), xAxisInfo.v, yAxisInfo, void 0, void 0, 0);\n };\n function XYPlotTileLayout$Companion() {\n XYPlotTileLayout$Companion_instance = this;\n this.AXIS_STRETCH_RATIO_0 = 0.1;\n }\n XYPlotTileLayout$Companion.prototype.tileBounds_0 = function (xAxisBounds, yAxisBounds, geomBounds) {\n var leftTop = new DoubleVector(geomBounds.left - yAxisBounds.width, geomBounds.top - XYPlotLayoutUtil_getInstance().GEOM_MARGIN);\n var rightBottom = new DoubleVector(geomBounds.right + XYPlotLayoutUtil_getInstance().GEOM_MARGIN, geomBounds.bottom + xAxisBounds.height);\n return new DoubleRectangle(leftTop, rightBottom.subtract_gpjtzr$(leftTop));\n };\n XYPlotTileLayout$Companion.prototype.computeAxisInfos_0 = function (xAxisLayout, yAxisLayout, plotSize) {\n var xAxisThickness = xAxisLayout.initialThickness();\n var yAxisInfo = this.computeYAxisInfo_0(yAxisLayout, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisThickness, yAxisLayout.initialThickness(), plotSize));\n var yAxisThickness = yAxisInfo.axisBounds().dimension.x;\n var xAxisInfo = this.computeXAxisInfo_0(xAxisLayout, plotSize, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisThickness, yAxisThickness, plotSize));\n if (xAxisInfo.axisBounds().dimension.y > xAxisThickness) {\n yAxisInfo = this.computeYAxisInfo_0(yAxisLayout, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisInfo.axisBounds().dimension.y, yAxisThickness, plotSize));\n }return new Pair_0(xAxisInfo, yAxisInfo);\n };\n XYPlotTileLayout$Companion.prototype.computeXAxisInfo_0 = function (axisLayout, plotSize, geomBounds) {\n var axisLength = geomBounds.dimension.x;\n var stretch = axisLength * this.AXIS_STRETCH_RATIO_0;\n var maxTickLabelsBounds = XYPlotLayoutUtil_getInstance().maxTickLabelsBounds_m3y558$(Orientation$BOTTOM_getInstance(), stretch, geomBounds, plotSize);\n return axisLayout.doLayout_o2m17x$(geomBounds.dimension, maxTickLabelsBounds);\n };\n XYPlotTileLayout$Companion.prototype.computeYAxisInfo_0 = function (axisLayout, geomBounds) {\n return axisLayout.doLayout_o2m17x$(geomBounds.dimension, null);\n };\n XYPlotTileLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var XYPlotTileLayout$Companion_instance = null;\n function XYPlotTileLayout$Companion_getInstance() {\n if (XYPlotTileLayout$Companion_instance === null) {\n new XYPlotTileLayout$Companion();\n }return XYPlotTileLayout$Companion_instance;\n }\n XYPlotTileLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'XYPlotTileLayout',\n interfaces: [TileLayout]\n };\n function AdaptableAxisBreaksProvider(domainAfterTransform, breaksGenerator) {\n this.domainAfterTransform_0 = domainAfterTransform;\n this.breaksGenerator_0 = breaksGenerator;\n }\n Object.defineProperty(AdaptableAxisBreaksProvider.prototype, 'isFixedBreaks', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(AdaptableAxisBreaksProvider.prototype, 'fixedBreaks', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Not a fixed breaks provider');\n }\n });\n AdaptableAxisBreaksProvider.prototype.getBreaks_5wr77w$ = function (targetCount, axisLength) {\n var scaleBreaks = this.breaksGenerator_0.generateBreaks_1tlvto$(this.domainAfterTransform_0, targetCount);\n return new GuideBreaks(scaleBreaks.domainValues, scaleBreaks.transformValues, scaleBreaks.labels);\n };\n AdaptableAxisBreaksProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AdaptableAxisBreaksProvider',\n interfaces: [AxisBreaksProvider]\n };\n function AxisBreaksProvider() {\n }\n AxisBreaksProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisBreaksProvider',\n interfaces: []\n };\n function AxisBreaksUtil() {\n AxisBreaksUtil_instance = this;\n }\n AxisBreaksUtil.prototype.createAxisBreaksProvider_oftday$ = function (scale_0, axisDomain) {\n if (scale_0.hasBreaks())\n return new FixedAxisBreaksProvider(scale_0.breaks, scale.ScaleUtil.breaksTransformed_x4zrm4$(scale_0), scale.ScaleUtil.labels_x4zrm4$(scale_0));\n else\n return new AdaptableAxisBreaksProvider(axisDomain, scale_0.breaksGenerator);\n };\n AxisBreaksUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AxisBreaksUtil',\n interfaces: []\n };\n var AxisBreaksUtil_instance = null;\n function AxisBreaksUtil_getInstance() {\n if (AxisBreaksUtil_instance === null) {\n new AxisBreaksUtil();\n }return AxisBreaksUtil_instance;\n }\n function AxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter$Companion_getInstance();\n this.orientation = orientation;\n this.domainRange = domainRange;\n this.labelsLayout = labelsLayout;\n }\n AxisLayouter.prototype.doLayout_p1d3jc$ = function (axisLength, maxTickLabelsBounds) {\n var labelsInfo = this.labelsLayout.doLayout_s0wrr0$(axisLength, this.toAxisMapper_14dthe$(axisLength), maxTickLabelsBounds);\n var labelsBounds = labelsInfo.bounds;\n var builder = (new AxisLayoutInfo$Builder()).axisBreaks_bysjzy$(labelsInfo.breaks).axisLength_14dthe$(axisLength).orientation_9y97dg$(this.orientation).axisDomain_4fzjta$(this.domainRange).tickLabelsBoundsMax_myx2hi$(maxTickLabelsBounds).tickLabelSmallFont_6taknv$(labelsInfo.smallFont).tickLabelAdditionalOffsets_eajcfd$(labelsInfo.labelAdditionalOffsets).tickLabelHorizontalAnchor_tk0ev1$(labelsInfo.labelHorizontalAnchor).tickLabelVerticalAnchor_24j3ht$(labelsInfo.labelVerticalAnchor).tickLabelRotationAngle_14dthe$(labelsInfo.labelRotationAngle).tickLabelsBounds_myx2hi$(labelsBounds);\n return builder.build();\n };\n AxisLayouter.prototype.toScaleMapper_14dthe$ = function (axisLength) {\n return scale.Mappers.mul_mdyssk$(this.domainRange, axisLength);\n };\n function AxisLayouter$Companion() {\n AxisLayouter$Companion_instance = this;\n }\n AxisLayouter$Companion.prototype.create_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n if (orientation.isHorizontal) {\n var labelsLayout;\n if (breaksProvider.isFixedBreaks) {\n labelsLayout = AxisLabelsLayout$Companion_getInstance().horizontalFixedBreaks_rldrnc$(orientation, axisDomain, breaksProvider.fixedBreaks, theme);\n } else {\n labelsLayout = AxisLabelsLayout$Companion_getInstance().horizontalFlexBreaks_4ebi60$(orientation, axisDomain, breaksProvider, theme);\n }\n return new HorizontalAxisLayouter(orientation, axisDomain, labelsLayout);\n }var labelsLayout_0;\n if (breaksProvider.isFixedBreaks) {\n labelsLayout_0 = AxisLabelsLayout$Companion_getInstance().verticalFixedBreaks_rldrnc$(orientation, axisDomain, breaksProvider.fixedBreaks, theme);\n } else {\n labelsLayout_0 = AxisLabelsLayout$Companion_getInstance().verticalFlexBreaks_4ebi60$(orientation, axisDomain, breaksProvider, theme);\n }\n return new VerticalAxisLayouter(orientation, axisDomain, labelsLayout_0);\n };\n AxisLayouter$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AxisLayouter$Companion_instance = null;\n function AxisLayouter$Companion_getInstance() {\n if (AxisLayouter$Companion_instance === null) {\n new AxisLayouter$Companion();\n }return AxisLayouter$Companion_instance;\n }\n AxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLayouter',\n interfaces: []\n };\n function FixedAxisBreaksProvider(domainBreaks, transformedBreaks, labels) {\n this.fixedBreaks_cixykn$_0 = new GuideBreaks(domainBreaks, transformedBreaks, labels);\n }\n Object.defineProperty(FixedAxisBreaksProvider.prototype, 'fixedBreaks', {\n configurable: true,\n get: function () {\n return this.fixedBreaks_cixykn$_0;\n }\n });\n Object.defineProperty(FixedAxisBreaksProvider.prototype, 'isFixedBreaks', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n FixedAxisBreaksProvider.prototype.getBreaks_5wr77w$ = function (targetCount, axisLength) {\n return this.fixedBreaks;\n };\n FixedAxisBreaksProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FixedAxisBreaksProvider',\n interfaces: [AxisBreaksProvider]\n };\n function GuideBreaks(domainValues, transformedValues, labels) {\n this.domainValues = null;\n this.transformedValues = null;\n this.labels = null;\n if (!(domainValues.size === transformedValues.size)) {\n var message = 'Scale breaks size: ' + toString(domainValues.size) + ' transformed size: ' + toString(transformedValues.size) + ' but expected to be the same';\n throw IllegalArgumentException_init(message.toString());\n }if (!(domainValues.size === labels.size)) {\n var message_0 = 'Scale breaks size: ' + toString(domainValues.size) + ' labels size: ' + toString(labels.size) + ' but expected to be the same';\n throw IllegalArgumentException_init(message_0.toString());\n }this.domainValues = ArrayList_init_0(domainValues);\n this.transformedValues = ArrayList_init_0(transformedValues);\n this.labels = ArrayList_init_0(labels);\n }\n Object.defineProperty(GuideBreaks.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.transformedValues.isEmpty();\n }\n });\n GuideBreaks.prototype.size = function () {\n return this.transformedValues.size;\n };\n GuideBreaks.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideBreaks',\n interfaces: []\n };\n function HorizontalAxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter.call(this, orientation, domainRange, labelsLayout);\n }\n function HorizontalAxisLayouter$toAxisMapper$lambda(closure$scaleMapper, closure$cartesianX) {\n return function (v) {\n var mapped = closure$scaleMapper(v);\n return mapped != null ? closure$cartesianX(mapped) : null;\n };\n }\n HorizontalAxisLayouter.prototype.toAxisMapper_14dthe$ = function (axisLength) {\n var scaleMapper = this.toScaleMapper_14dthe$(axisLength);\n var cartesianX = coord.Coords.toClientOffsetX_4fzjta$(new ClosedRange(0.0, axisLength));\n return HorizontalAxisLayouter$toAxisMapper$lambda(scaleMapper, cartesianX);\n };\n HorizontalAxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAxisLayouter',\n interfaces: [AxisLayouter]\n };\n function VerticalAxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter.call(this, orientation, domainRange, labelsLayout);\n }\n function VerticalAxisLayouter$toAxisMapper$lambda(closure$scaleMapper, closure$cartesianY) {\n return function (v) {\n var mapped = closure$scaleMapper(v);\n return mapped != null ? closure$cartesianY(mapped) : null;\n };\n }\n VerticalAxisLayouter.prototype.toAxisMapper_14dthe$ = function (axisLength) {\n var scaleMapper = this.toScaleMapper_14dthe$(axisLength);\n var cartesianY = coord.Coords.toClientOffsetY_4fzjta$(new ClosedRange(0.0, axisLength));\n return VerticalAxisLayouter$toAxisMapper$lambda(scaleMapper, cartesianY);\n };\n VerticalAxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAxisLayouter',\n interfaces: [AxisLayouter]\n };\n function AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout$Companion_getInstance();\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.breaks_0 = breaks;\n }\n AbstractFixedBreaksLabelsLayout.prototype.labelBounds_0 = function (labelLocation, labelLength) {\n var dim = this.labelSpec.dimensions_za3lpa$(labelLength);\n var labelBounds = this.labelBounds_gpjtzr$(dim);\n return labelBounds.add_gpjtzr$(labelLocation);\n };\n AbstractFixedBreaksLabelsLayout.prototype.labelsBounds_c3fefx$ = function (tickPositions, tickLabels, toTickLocation) {\n var tmp$;\n var boundsList = this.labelBoundsList_c3fefx$(tickPositions, this.breaks_0.labels, toTickLocation);\n var bounds = null;\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n bounds = GeometryUtil_getInstance().union_te9coj$(labelBounds, bounds);\n }\n return bounds;\n };\n AbstractFixedBreaksLabelsLayout.prototype.labelBoundsList_c3fefx$ = function (tickPositions, tickLabels, toTickLocation) {\n var tmp$;\n var result = ArrayList_init();\n var labels = tickLabels.iterator();\n tmp$ = tickPositions.iterator();\n while (tmp$.hasNext()) {\n var pos = tmp$.next();\n var label = labels.next();\n var bounds = this.labelBounds_0(toTickLocation(pos), label.length);\n result.add_11rb$(bounds);\n }\n return result;\n };\n AbstractFixedBreaksLabelsLayout.prototype.createAxisLabelsLayoutInfoBuilder_fd842m$ = function (bounds, overlap) {\n return (new AxisLabelsLayoutInfo$Builder()).breaks_buc0yr$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(bounds)).smallFont_6taknv$(false).overlap_6taknv$(overlap);\n };\n AbstractFixedBreaksLabelsLayout.prototype.noLabelsLayoutInfo_c0p8fa$ = function (axisLength, orientation) {\n if (orientation.isHorizontal) {\n var bounds = DoubleRectangle_init(axisLength / 2, 0.0, 0.0, 0.0);\n bounds = this.applyLabelsOffset_w7e9pi$(bounds);\n return (new AxisLabelsLayoutInfo$Builder()).breaks_buc0yr$(this.breaks_0).bounds_wthzt5$(bounds).smallFont_6taknv$(false).overlap_6taknv$(false).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n }throw IllegalStateException_init('Not implemented for ' + orientation);\n };\n function AbstractFixedBreaksLabelsLayout$Companion() {\n AbstractFixedBreaksLabelsLayout$Companion_instance = this;\n this.HORIZONTAL_TICK_LOCATION = AbstractFixedBreaksLabelsLayout$Companion$HORIZONTAL_TICK_LOCATION$lambda;\n }\n function AbstractFixedBreaksLabelsLayout$Companion$HORIZONTAL_TICK_LOCATION$lambda(x) {\n return new DoubleVector(x, 0.0);\n }\n AbstractFixedBreaksLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractFixedBreaksLabelsLayout$Companion_instance = null;\n function AbstractFixedBreaksLabelsLayout$Companion_getInstance() {\n if (AbstractFixedBreaksLabelsLayout$Companion_instance === null) {\n new AbstractFixedBreaksLabelsLayout$Companion();\n }return AbstractFixedBreaksLabelsLayout$Companion_instance;\n }\n AbstractFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractFixedBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n AxisLabelsLayout$Companion_getInstance();\n this.orientation = orientation;\n this.axisDomain = axisDomain;\n this.labelSpec = labelSpec;\n this.theme = theme;\n }\n Object.defineProperty(AxisLabelsLayout.prototype, 'isHorizontal', {\n configurable: true,\n get: function () {\n return this.orientation.isHorizontal;\n }\n });\n AxisLabelsLayout.prototype.mapToAxis_d2cc22$ = function (breaks, axisMapper) {\n return BreakLabelsLayoutUtil_getInstance().mapToAxis_lhkzxb$(breaks, this.axisDomain, axisMapper);\n };\n AxisLabelsLayout.prototype.applyLabelsOffset_w7e9pi$ = function (labelsBounds) {\n return BreakLabelsLayoutUtil_getInstance().applyLabelsOffset_tsgpmr$(labelsBounds, this.theme.tickLabelDistance(), this.orientation);\n };\n function AxisLabelsLayout$Companion() {\n AxisLabelsLayout$Companion_instance = this;\n this.TICK_LABEL_SPEC = PlotLabelSpec$AXIS_TICK_getInstance();\n this.INITIAL_TICK_LABEL_LENGTH = 4;\n this.MIN_TICK_LABEL_DISTANCE = 20.0;\n this.TICK_LABEL_SPEC_SMALL = PlotLabelSpec$AXIS_TICK_SMALL_getInstance();\n }\n AxisLabelsLayout$Companion.prototype.horizontalFlexBreaks_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!breaksProvider.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }return new HorizontalFlexBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaksProvider, theme);\n };\n AxisLabelsLayout$Companion.prototype.horizontalFixedBreaks_rldrnc$ = function (orientation, axisDomain, breaks, theme) {\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }return new HorizontalFixedBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaks, theme);\n };\n AxisLabelsLayout$Companion.prototype.verticalFlexBreaks_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!breaksProvider.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }return new VerticalFlexBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaksProvider, theme);\n };\n AxisLabelsLayout$Companion.prototype.verticalFixedBreaks_rldrnc$ = function (orientation, axisDomain, breaks, theme) {\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }return new VerticalFixedBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaks, theme);\n };\n AxisLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AxisLabelsLayout$Companion_instance = null;\n function AxisLabelsLayout$Companion_getInstance() {\n if (AxisLabelsLayout$Companion_instance === null) {\n new AxisLabelsLayout$Companion();\n }return AxisLabelsLayout$Companion_instance;\n }\n AxisLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLabelsLayout',\n interfaces: []\n };\n function AxisLabelsLayoutInfo(b) {\n this.breaks = null;\n this.bounds = null;\n this.smallFont = false;\n this.labelAdditionalOffsets = null;\n this.labelHorizontalAnchor = null;\n this.labelVerticalAnchor = null;\n this.labelRotationAngle = 0;\n this.isOverlap_8be2vx$ = false;\n this.breaks = b.myBreaks_8be2vx$;\n this.smallFont = b.mySmallFont_8be2vx$;\n this.bounds = b.myBounds_8be2vx$;\n this.isOverlap_8be2vx$ = b.myOverlap_8be2vx$;\n this.labelAdditionalOffsets = b.myLabelAdditionalOffsets_8be2vx$ == null ? null : ArrayList_init_0(ensureNotNull(b.myLabelAdditionalOffsets_8be2vx$));\n this.labelHorizontalAnchor = b.myLabelHorizontalAnchor_8be2vx$;\n this.labelVerticalAnchor = b.myLabelVerticalAnchor_8be2vx$;\n this.labelRotationAngle = b.myLabelRotationAngle_8be2vx$;\n }\n function AxisLabelsLayoutInfo$Builder() {\n this.myBreaks_8be2vx$ = null;\n this.myBounds_8be2vx$ = null;\n this.mySmallFont_8be2vx$ = false;\n this.myOverlap_8be2vx$ = false;\n this.myLabelAdditionalOffsets_8be2vx$ = null;\n this.myLabelHorizontalAnchor_8be2vx$ = null;\n this.myLabelVerticalAnchor_8be2vx$ = null;\n this.myLabelRotationAngle_8be2vx$ = 0.0;\n }\n AxisLabelsLayoutInfo$Builder.prototype.breaks_buc0yr$ = function (breaks) {\n this.myBreaks_8be2vx$ = breaks;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.bounds_wthzt5$ = function (bounds) {\n this.myBounds_8be2vx$ = bounds;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.smallFont_6taknv$ = function (b) {\n this.mySmallFont_8be2vx$ = b;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.overlap_6taknv$ = function (b) {\n this.myOverlap_8be2vx$ = b;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelAdditionalOffsets_eajcfd$ = function (l) {\n this.myLabelAdditionalOffsets_8be2vx$ = l;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelHorizontalAnchor_ja80zo$ = function (anchor) {\n this.myLabelHorizontalAnchor_8be2vx$ = anchor;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelVerticalAnchor_yaudma$ = function (anchor) {\n this.myLabelVerticalAnchor_8be2vx$ = anchor;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelRotationAngle_14dthe$ = function (angle) {\n this.myLabelRotationAngle_8be2vx$ = angle;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.build = function () {\n return new AxisLabelsLayoutInfo(this);\n };\n AxisLabelsLayoutInfo$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n AxisLabelsLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLabelsLayoutInfo',\n interfaces: []\n };\n function BreakLabelsLayoutUtil() {\n BreakLabelsLayoutUtil_instance = this;\n }\n BreakLabelsLayoutUtil.prototype.getFlexBreaks_73ga93$ = function (breaksProvider, maxCount, axisLength) {\n if (!!breaksProvider.isFixedBreaks) {\n var message = 'fixed breaks not expected';\n throw IllegalArgumentException_init(message.toString());\n }if (!(maxCount > 0)) {\n var message_0 = 'maxCount=' + maxCount;\n throw IllegalArgumentException_init(message_0.toString());\n }var breaks = breaksProvider.getBreaks_5wr77w$(maxCount, axisLength);\n if (maxCount === 1 && !breaks.isEmpty) {\n return new GuideBreaks(breaks.domainValues.subList_vux9f0$(0, 1), breaks.transformedValues.subList_vux9f0$(0, 1), breaks.labels.subList_vux9f0$(0, 1));\n }var count = maxCount;\n while (breaks.size() > maxCount) {\n var b = (breaks.size() - maxCount | 0) / 2 | 0;\n var delta = JsMath.max(1, b);\n count = count - delta | 0;\n breaks = breaksProvider.getBreaks_5wr77w$(count, axisLength);\n }\n return breaks;\n };\n BreakLabelsLayoutUtil.prototype.maxLength_mhpeer$ = function (labels) {\n var tmp$;\n var max = 0;\n tmp$ = labels.iterator();\n while (tmp$.hasNext()) {\n var label = tmp$.next();\n var a = max;\n var b = label.length;\n max = JsMath.max(a, b);\n }\n return max;\n };\n BreakLabelsLayoutUtil.prototype.horizontalCenteredLabelBounds_gpjtzr$ = function (labelSize) {\n return DoubleRectangle_init(-labelSize.x / 2.0, 0.0, labelSize.x, labelSize.y);\n };\n BreakLabelsLayoutUtil.prototype.doLayoutVerticalAxisLabels_ii702u$ = function (orientation, breaks, axisDomain, axisMapper, theme) {\n var tmp$;\n if (theme.showTickLabels()) {\n var labelsBounds = this.verticalAxisLabelsBounds_0(breaks, axisDomain, axisMapper);\n tmp$ = this.applyLabelsOffset_tsgpmr$(labelsBounds, theme.tickLabelDistance(), orientation);\n } else if (theme.showTickMarks()) {\n var labelsBounds_0 = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n tmp$ = this.applyLabelsOffset_tsgpmr$(labelsBounds_0, theme.tickLabelDistance(), orientation);\n } else\n tmp$ = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n var axisBounds = tmp$;\n return (new AxisLabelsLayoutInfo$Builder()).breaks_buc0yr$(breaks).bounds_wthzt5$(axisBounds).build();\n };\n BreakLabelsLayoutUtil.prototype.mapToAxis_lhkzxb$ = function (breaks, axisDomain, axisMapper) {\n var tmp$;\n var axisMin = axisDomain.lowerEnd;\n var axisBreaks = ArrayList_init();\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n var mapped = axisMapper(v - axisMin);\n axisBreaks.add_11rb$(ensureNotNull(mapped));\n }\n return axisBreaks;\n };\n BreakLabelsLayoutUtil.prototype.applyLabelsOffset_tsgpmr$ = function (labelsBounds, offset, orientation) {\n var tmp$;\n var labelsBounds_0 = labelsBounds;\n switch (orientation.name) {\n case 'LEFT':\n tmp$ = new DoubleVector(-offset, 0.0);\n break;\n case 'RIGHT':\n tmp$ = new DoubleVector(offset, 0.0);\n break;\n case 'TOP':\n tmp$ = new DoubleVector(0.0, -offset);\n break;\n case 'BOTTOM':\n tmp$ = new DoubleVector(0.0, offset);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n var offsetVector = tmp$;\n if (orientation === Orientation$RIGHT_getInstance() || orientation === Orientation$BOTTOM_getInstance()) {\n labelsBounds_0 = labelsBounds_0.add_gpjtzr$(offsetVector);\n } else if (orientation === Orientation$LEFT_getInstance() || orientation === Orientation$TOP_getInstance()) {\n labelsBounds_0 = labelsBounds_0.add_gpjtzr$(offsetVector).subtract_gpjtzr$(new DoubleVector(labelsBounds_0.width, 0.0));\n }return labelsBounds_0;\n };\n BreakLabelsLayoutUtil.prototype.verticalAxisLabelsBounds_0 = function (breaks, axisDomain, axisMapper) {\n var maxLength = this.maxLength_mhpeer$(breaks.labels);\n var maxLabelWidth = AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.width_za3lpa$(maxLength);\n var y1 = 0.0;\n var y2 = 0.0;\n if (!breaks.isEmpty) {\n var axisBreaks = this.mapToAxis_lhkzxb$(breaks.transformedValues, axisDomain, axisMapper);\n var a = axisBreaks.get_za3lpa$(0);\n var b = collect.Iterables.getLast_yl67zr$(axisBreaks);\n y1 = JsMath.min(a, b);\n var a_0 = axisBreaks.get_za3lpa$(0);\n var b_0 = collect.Iterables.getLast_yl67zr$(axisBreaks);\n y2 = JsMath.max(a_0, b_0);\n y1 -= AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() / 2;\n y2 += AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() / 2;\n }var origin = new DoubleVector(0.0, y1);\n var dimensions = new DoubleVector(maxLabelWidth, y2 - y1);\n return new DoubleRectangle(origin, dimensions);\n };\n BreakLabelsLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BreakLabelsLayoutUtil',\n interfaces: []\n };\n var BreakLabelsLayoutUtil_instance = null;\n function BreakLabelsLayoutUtil_getInstance() {\n if (BreakLabelsLayoutUtil_instance === null) {\n new BreakLabelsLayoutUtil();\n }return BreakLabelsLayoutUtil_instance;\n }\n function HorizontalFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }}\n HorizontalFixedBreaksLabelsLayout.prototype.overlap_0 = function (labelsInfo, maxTickLabelsBounds) {\n return labelsInfo.isOverlap_8be2vx$ || (maxTickLabelsBounds != null && !(maxTickLabelsBounds.xRange().encloses_d226ot$(ensureNotNull(labelsInfo.bounds).xRange()) && maxTickLabelsBounds.yRange().encloses_d226ot$(labelsInfo.bounds.yRange())));\n };\n HorizontalFixedBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n if (!this.theme.showTickLabels()) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }var labelsInfo = this.simpleLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.multilineLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.tiltedLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.verticalLayout_0(this.labelSpec).doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.verticalLayout_0(AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC_SMALL).doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n }}}}return labelsInfo;\n };\n HorizontalFixedBreaksLabelsLayout.prototype.simpleLayout_0 = function () {\n return new HorizontalSimpleLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.multilineLayout_0 = function () {\n return new HorizontalMultilineLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme, 2);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.tiltedLayout_0 = function () {\n return new HorizontalTiltedLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.verticalLayout_0 = function (labelSpec) {\n return new HorizontalVerticalLabelsLayout(this.orientation, this.axisDomain, labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n throw IllegalStateException_init('Not implemented here');\n };\n HorizontalFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalFixedBreaksLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalFlexBreaksLabelsLayout(orientation, axisDomain, labelSpec, myBreaksProvider, theme) {\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.myBreaksProvider_0 = myBreaksProvider;\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.myBreaksProvider_0.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n HorizontalFlexBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var targetBreakCount = HorizontalSimpleLabelsLayout$Companion_getInstance().estimateBreakCountInitial_14dthe$(axisLength);\n var breaks = this.getBreaks_0(targetBreakCount, axisLength);\n var labelsInfo = this.doLayoutLabels_0(breaks, axisLength, axisMapper, maxLabelsBounds);\n while (labelsInfo.isOverlap_8be2vx$) {\n var newTargetBreakCount = HorizontalSimpleLabelsLayout$Companion_getInstance().estimateBreakCount_g5yaez$(breaks.labels, axisLength);\n if (newTargetBreakCount >= targetBreakCount) {\n break;\n }targetBreakCount = newTargetBreakCount;\n breaks = this.getBreaks_0(targetBreakCount, axisLength);\n labelsInfo = this.doLayoutLabels_0(breaks, axisLength, axisMapper, maxLabelsBounds);\n }\n return labelsInfo;\n };\n HorizontalFlexBreaksLabelsLayout.prototype.doLayoutLabels_0 = function (breaks, axisLength, axisMapper, maxLabelsBounds) {\n var layout = new HorizontalSimpleLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, breaks, this.theme);\n return layout.doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n };\n HorizontalFlexBreaksLabelsLayout.prototype.getBreaks_0 = function (maxCount, axisLength) {\n return BreakLabelsLayoutUtil_getInstance().getFlexBreaks_73ga93$(this.myBreaksProvider_0, maxCount, axisLength);\n };\n HorizontalFlexBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalFlexBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function HorizontalMultilineLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme, myMaxLines) {\n HorizontalMultilineLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n this.myMaxLines_0 = myMaxLines;\n this.myShelfIndexForTickIndex_0 = ArrayList_init();\n }\n Object.defineProperty(HorizontalMultilineLabelsLayout.prototype, 'labelAdditionalOffsets_0', {\n configurable: true,\n get: function () {\n var tmp$;\n var h = this.labelSpec.height() * HorizontalMultilineLabelsLayout$Companion_getInstance().LINE_HEIGHT_0;\n var result = ArrayList_init();\n tmp$ = this.breaks_0.size();\n for (var i = 0; i < tmp$; i++) {\n result.add_11rb$(new DoubleVector(0.0, this.myShelfIndexForTickIndex_0.get_za3lpa$(i) * h));\n }\n return result;\n }\n });\n HorizontalMultilineLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var tmp$, tmp$_0;\n var boundsByShelfIndex = HashMap_init();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var boundsList = this.labelBoundsList_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n var shelfIndex = 0;\n while (true) {\n if (!boundsByShelfIndex.containsKey_11rb$(shelfIndex)) {\n var key = shelfIndex;\n boundsByShelfIndex.put_xwzc9p$(key, labelBounds);\n this.myShelfIndexForTickIndex_0.add_11rb$(shelfIndex);\n break;\n }var shelfBounds = ensureNotNull(boundsByShelfIndex.get_11rb$(shelfIndex));\n if (!shelfBounds.xRange().isConnected_d226ot$(new ClosedRange(labelBounds.left - 60, labelBounds.right + 60))) {\n this.myShelfIndexForTickIndex_0.add_11rb$(shelfIndex);\n shelfBounds = shelfBounds.union_wthzt5$(labelBounds);\n var key_0 = shelfIndex;\n var value = shelfBounds;\n boundsByShelfIndex.put_xwzc9p$(key_0, value);\n break;\n }shelfIndex = shelfIndex + 1 | 0;\n }\n }\n var bounds = boundsByShelfIndex.isEmpty() ? new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO) : ensureNotNull(boundsByShelfIndex.get_11rb$(0));\n var h = this.labelSpec.height() * HorizontalMultilineLabelsLayout$Companion_getInstance().LINE_HEIGHT_0;\n tmp$_0 = boundsByShelfIndex.size;\n for (var i = 0; i < tmp$_0; i++) {\n var shelfBounds_0 = ensureNotNull(boundsByShelfIndex.get_11rb$(i));\n bounds = bounds.union_wthzt5$(shelfBounds_0.add_gpjtzr$(new DoubleVector(0.0, i * h)));\n }\n var linesCount = boundsByShelfIndex.size;\n return (new AxisLabelsLayoutInfo$Builder()).breaks_buc0yr$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(bounds)).smallFont_6taknv$(false).overlap_6taknv$(linesCount > this.myMaxLines_0).labelAdditionalOffsets_eajcfd$(this.labelAdditionalOffsets_0).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n };\n HorizontalMultilineLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n return BreakLabelsLayoutUtil_getInstance().horizontalCenteredLabelBounds_gpjtzr$(labelNormalSize);\n };\n function HorizontalMultilineLabelsLayout$Companion() {\n HorizontalMultilineLabelsLayout$Companion_instance = this;\n this.LINE_HEIGHT_0 = 1.2;\n this.MIN_DISTANCE_0 = 60;\n }\n HorizontalMultilineLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalMultilineLabelsLayout$Companion_instance = null;\n function HorizontalMultilineLabelsLayout$Companion_getInstance() {\n if (HorizontalMultilineLabelsLayout$Companion_instance === null) {\n new HorizontalMultilineLabelsLayout$Companion();\n }return HorizontalMultilineLabelsLayout$Companion_instance;\n }\n HorizontalMultilineLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalMultilineLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalSimpleLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalSimpleLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n HorizontalSimpleLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var tmp$;\n if (this.breaks_0.isEmpty) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }if (!this.theme.showTickLabels()) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }var bounds = null;\n var overlap = false;\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var boundsList = this.labelBoundsList_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n overlap = overlap || (bounds != null && bounds.xRange().isConnected_d226ot$(data_0.SeriesUtil.expand_wws5xy$(labelBounds.xRange(), AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE / 2, AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE / 2.0)));\n bounds = GeometryUtil_getInstance().union_te9coj$(labelBounds, bounds);\n }\n return (new AxisLabelsLayoutInfo$Builder()).breaks_buc0yr$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(ensureNotNull(bounds))).smallFont_6taknv$(false).overlap_6taknv$(overlap).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n };\n HorizontalSimpleLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n return BreakLabelsLayoutUtil_getInstance().horizontalCenteredLabelBounds_gpjtzr$(labelNormalSize);\n };\n function HorizontalSimpleLabelsLayout$Companion() {\n HorizontalSimpleLabelsLayout$Companion_instance = this;\n }\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCountInitial_14dthe$ = function (axisLength) {\n return this.estimateBreakCount_0(AxisLabelsLayout$Companion_getInstance().INITIAL_TICK_LABEL_LENGTH, axisLength);\n };\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCount_g5yaez$ = function (labels, axisLength) {\n var maxLength = BreakLabelsLayoutUtil_getInstance().maxLength_mhpeer$(labels);\n return this.estimateBreakCount_0(maxLength, axisLength);\n };\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCount_0 = function (labelLength, axisLength) {\n var tickDistance = AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.width_za3lpa$(labelLength) + AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE;\n var b = axisLength / tickDistance;\n return numberToInt(JsMath.max(1.0, b));\n };\n HorizontalSimpleLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalSimpleLabelsLayout$Companion_instance = null;\n function HorizontalSimpleLabelsLayout$Companion_getInstance() {\n if (HorizontalSimpleLabelsLayout$Companion_instance === null) {\n new HorizontalSimpleLabelsLayout$Companion();\n }return HorizontalSimpleLabelsLayout$Companion_instance;\n }\n HorizontalSimpleLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalSimpleLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalTiltedLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalTiltedLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n Object.defineProperty(HorizontalTiltedLabelsLayout.prototype, 'labelHorizontalAnchor_0', {\n configurable: true,\n get: function () {\n if (this.orientation === Orientation$BOTTOM_getInstance()) {\n return TextLabel$HorizontalAnchor.RIGHT;\n }throw RuntimeException_init('Not implemented');\n }\n });\n Object.defineProperty(HorizontalTiltedLabelsLayout.prototype, 'labelVerticalAnchor_0', {\n configurable: true,\n get: function () {\n return TextLabel$VerticalAnchor.TOP;\n }\n });\n HorizontalTiltedLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var height = this.labelSpec.height();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var overlap = false;\n if (this.breaks_0.size() >= 2) {\n var x = (height + HorizontalTiltedLabelsLayout$Companion_getInstance().MIN_DISTANCE_0) / HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var minTickDistance = JsMath.abs(x);\n var x_0 = ticks.get_za3lpa$(0) - ticks.get_za3lpa$(1);\n var tickDistance = JsMath.abs(x_0);\n overlap = tickDistance < minTickDistance;\n }var bounds = this.labelsBounds_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n return this.createAxisLabelsLayoutInfoBuilder_fd842m$(ensureNotNull(bounds), overlap).labelHorizontalAnchor_ja80zo$(this.labelHorizontalAnchor_0).labelVerticalAnchor_yaudma$(this.labelVerticalAnchor_0).labelRotationAngle_14dthe$(HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0).build();\n };\n HorizontalTiltedLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n if (!(HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 >= -90 && HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 <= 0 && this.labelHorizontalAnchor_0 === TextLabel$HorizontalAnchor.RIGHT && this.labelVerticalAnchor_0 === TextLabel$VerticalAnchor.TOP)) {\n throw RuntimeException_init('Not implemented');\n }var x = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var tmp$ = JsMath.abs(x);\n var x_0 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var w = tmp$ + 2 * JsMath.abs(x_0);\n var x_1 = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var tmp$_0 = JsMath.abs(x_1);\n var x_2 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var h = tmp$_0 + JsMath.abs(x_2);\n var x_3 = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var tmp$_1 = JsMath.abs(x_3);\n var x_4 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var x_5 = -(tmp$_1 + JsMath.abs(x_4));\n var y = 0.0;\n return DoubleRectangle_init(x_5, y, w, h);\n };\n function HorizontalTiltedLabelsLayout$Companion() {\n HorizontalTiltedLabelsLayout$Companion_instance = this;\n this.MIN_DISTANCE_0 = 5.0;\n this.ROTATION_DEGREE_0 = -30.0;\n var x = toRadians(this.ROTATION_DEGREE_0);\n this.SIN_0 = JsMath.sin(x);\n var x_0 = toRadians(this.ROTATION_DEGREE_0);\n this.COS_0 = JsMath.cos(x_0);\n }\n HorizontalTiltedLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalTiltedLabelsLayout$Companion_instance = null;\n function HorizontalTiltedLabelsLayout$Companion_getInstance() {\n if (HorizontalTiltedLabelsLayout$Companion_instance === null) {\n new HorizontalTiltedLabelsLayout$Companion();\n }return HorizontalTiltedLabelsLayout$Companion_instance;\n }\n HorizontalTiltedLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalTiltedLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalVerticalLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalVerticalLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n Object.defineProperty(HorizontalVerticalLabelsLayout.prototype, 'labelHorizontalAnchor', {\n configurable: true,\n get: function () {\n if (this.orientation === Orientation$BOTTOM_getInstance()) {\n return TextLabel$HorizontalAnchor.LEFT;\n }throw RuntimeException_init('Not implemented');\n }\n });\n Object.defineProperty(HorizontalVerticalLabelsLayout.prototype, 'labelVerticalAnchor', {\n configurable: true,\n get: function () {\n return TextLabel$VerticalAnchor.CENTER;\n }\n });\n HorizontalVerticalLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var height = this.labelSpec.height();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var overlap = false;\n if (this.breaks_0.size() >= 2) {\n var minTickDistance = height + HorizontalVerticalLabelsLayout$Companion_getInstance().MIN_DISTANCE_0;\n var x = ticks.get_za3lpa$(0) - ticks.get_za3lpa$(1);\n var tickDistance = JsMath.abs(x);\n overlap = tickDistance < minTickDistance;\n }var bounds = this.labelsBounds_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n return this.createAxisLabelsLayoutInfoBuilder_fd842m$(ensureNotNull(bounds), overlap).labelHorizontalAnchor_ja80zo$(this.labelHorizontalAnchor).labelVerticalAnchor_yaudma$(this.labelVerticalAnchor).labelRotationAngle_14dthe$(HorizontalVerticalLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0).build();\n };\n HorizontalVerticalLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n if (!(HorizontalVerticalLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 === 90.0 && this.labelHorizontalAnchor === TextLabel$HorizontalAnchor.LEFT && this.labelVerticalAnchor === TextLabel$VerticalAnchor.CENTER)) {\n throw RuntimeException_init('Not implemented');\n }var w = labelNormalSize.y;\n var h = labelNormalSize.x;\n var x = -w / 2;\n var y = 0.0;\n return DoubleRectangle_init(x, y, w, h);\n };\n function HorizontalVerticalLabelsLayout$Companion() {\n HorizontalVerticalLabelsLayout$Companion_instance = this;\n this.MIN_DISTANCE_0 = 5.0;\n this.ROTATION_DEGREE_0 = 90.0;\n }\n HorizontalVerticalLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalVerticalLabelsLayout$Companion_instance = null;\n function HorizontalVerticalLabelsLayout$Companion_getInstance() {\n if (HorizontalVerticalLabelsLayout$Companion_instance === null) {\n new HorizontalVerticalLabelsLayout$Companion();\n }return HorizontalVerticalLabelsLayout$Companion_instance;\n }\n HorizontalVerticalLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalVerticalLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function VerticalFixedBreaksLabelsLayout(orientation, axisDomain, tickLabelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, tickLabelSpec, breaks, theme);\n }\n VerticalFixedBreaksLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n throw IllegalStateException_init('Not implemented here');\n };\n VerticalFixedBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n return BreakLabelsLayoutUtil_getInstance().doLayoutVerticalAxisLabels_ii702u$(this.orientation, this.breaks_0, this.axisDomain, axisMapper, this.theme);\n };\n VerticalFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalFixedBreaksLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function VerticalFlexBreaksLabelsLayout(orientation, axisDomain, labelSpec, myBreaksProvider, theme) {\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.myBreaksProvider_0 = myBreaksProvider;\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.myBreaksProvider_0.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n VerticalFlexBreaksLabelsLayout.prototype.maxTickCount_0 = function (axisLength) {\n var x = axisLength / (AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() + AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE);\n return numberToInt(JsMath.ceil(x));\n };\n VerticalFlexBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n if (!(axisLength > 0)) {\n var message = 'axis length: ' + axisLength;\n throw IllegalArgumentException_init(message.toString());\n }var maxTickCount = this.maxTickCount_0(axisLength);\n var breaks = this.getBreaks_0(maxTickCount, axisLength);\n return BreakLabelsLayoutUtil_getInstance().doLayoutVerticalAxisLabels_ii702u$(this.orientation, breaks, this.axisDomain, axisMapper, this.theme);\n };\n VerticalFlexBreaksLabelsLayout.prototype.getBreaks_0 = function (maxCount, axisLength) {\n return BreakLabelsLayoutUtil_getInstance().getFlexBreaks_73ga93$(this.myBreaksProvider_0, maxCount, axisLength);\n };\n VerticalFlexBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalFlexBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function Defaults() {\n Defaults_instance = this;\n this.DARK_GRAY = '#3d3d3d';\n this.GRAY = Color.Companion.GRAY.toHexColor();\n this.LIGHT_GRAY = Color.Companion.LIGHT_GRAY.toHexColor();\n this.X_LIGHT_GRAY = Color.Companion.VERY_LIGHT_GRAY.toHexColor();\n this.XX_LIGHT_GRAY = '#e0e0e0';\n this.BACKDROP_COLOR = 'white';\n this.TEXT_COLOR = this.DARK_GRAY;\n this.FONT_LARGE = 16;\n this.FONT_MEDIUM = 12;\n this.FONT_SMALL = 10;\n this.FONT_X_SMALL = 8;\n this.FONT_FAMILY_NORMAL = '\"Lucida Grande\", sans-serif';\n this.FONT_FAMILY_MONOSPACED = '\"Courier New\", Courier, monospace';\n }\n function Defaults$Common() {\n }\n function Defaults$Common$Title() {\n Defaults$Common$Title_instance = this;\n this.FONT_SIZE = 16;\n this.FONT_SIZE_CSS = '' + toString(16) + 'px';\n }\n Defaults$Common$Title.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Title',\n interfaces: []\n };\n var Defaults$Common$Title_instance = null;\n function Defaults$Common$Title_getInstance() {\n if (Defaults$Common$Title_instance === null) {\n new Defaults$Common$Title();\n }return Defaults$Common$Title_instance;\n }\n function Defaults$Common$Legend() {\n Defaults$Common$Legend_instance = this;\n this.TITLE_FONT_SIZE = 12;\n this.ITEM_FONT_SIZE = 10;\n this.OUTLINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().XX_LIGHT_GRAY);\n }\n Defaults$Common$Legend.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Legend',\n interfaces: []\n };\n var Defaults$Common$Legend_instance = null;\n function Defaults$Common$Legend_getInstance() {\n if (Defaults$Common$Legend_instance === null) {\n new Defaults$Common$Legend();\n }return Defaults$Common$Legend_instance;\n }\n function Defaults$Common$Tooltip() {\n Defaults$Common$Tooltip_instance = this;\n this.MAX_POINTER_FOOTING_LENGTH = 12.0;\n this.POINTER_FOOTING_TO_SIDE_LENGTH_RATIO = 0.4;\n this.MARGIN_BETWEEN_TOOLTIPS = 5.0;\n this.DATA_TOOLTIP_FONT_SIZE = 12;\n this.LINE_INTERVAL = 3.0;\n this.H_CONTENT_PADDING = 4.0;\n this.V_CONTENT_PADDING = 4.0;\n this.LABEL_VALUE_INTERVAL = 8.0;\n this.BORDER_WIDTH = 4.0;\n this.DARK_TEXT_COLOR = Color.Companion.BLACK;\n this.LIGHT_TEXT_COLOR = Color.Companion.WHITE;\n this.AXIS_TOOLTIP_FONT_SIZE = 12;\n this.AXIS_TOOLTIP_COLOR = Defaults$Plot$Axis_getInstance().LINE_COLOR;\n this.AXIS_RADIUS = 1.5;\n }\n Defaults$Common$Tooltip.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Tooltip',\n interfaces: []\n };\n var Defaults$Common$Tooltip_instance = null;\n function Defaults$Common$Tooltip_getInstance() {\n if (Defaults$Common$Tooltip_instance === null) {\n new Defaults$Common$Tooltip();\n }return Defaults$Common$Tooltip_instance;\n }\n Defaults$Common.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Common',\n interfaces: []\n };\n function Defaults$Table() {\n }\n function Defaults$Table$Head() {\n Defaults$Table$Head_instance = this;\n this.FONT_SIZE = 12;\n this.FONT_SIZE_CSS = '' + toString(12) + 'px';\n }\n Defaults$Table$Head.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Head',\n interfaces: []\n };\n var Defaults$Table$Head_instance = null;\n function Defaults$Table$Head_getInstance() {\n if (Defaults$Table$Head_instance === null) {\n new Defaults$Table$Head();\n }return Defaults$Table$Head_instance;\n }\n function Defaults$Table$Data() {\n Defaults$Table$Data_instance = this;\n this.FONT_SIZE = 12;\n this.FONT_SIZE_CSS = '' + toString(12) + 'px';\n }\n Defaults$Table$Data.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Data',\n interfaces: []\n };\n var Defaults$Table$Data_instance = null;\n function Defaults$Table$Data_getInstance() {\n if (Defaults$Table$Data_instance === null) {\n new Defaults$Table$Data();\n }return Defaults$Table$Data_instance;\n }\n Defaults$Table.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Table',\n interfaces: []\n };\n function Defaults$Plot() {\n }\n function Defaults$Plot$Axis() {\n Defaults$Plot$Axis_instance = this;\n this.TITLE_FONT_SIZE = 12;\n this.TICK_FONT_SIZE = 10;\n this.TICK_FONT_SIZE_SMALL = 8;\n this.LINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().DARK_GRAY);\n this.TICK_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().DARK_GRAY);\n this.GRID_LINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().X_LIGHT_GRAY);\n this.LINE_WIDTH = 1.0;\n this.TICK_LINE_WIDTH = 1.0;\n this.GRID_LINE_WIDTH = 1.0;\n }\n Defaults$Plot$Axis.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Axis',\n interfaces: []\n };\n var Defaults$Plot$Axis_instance = null;\n function Defaults$Plot$Axis_getInstance() {\n if (Defaults$Plot$Axis_instance === null) {\n new Defaults$Plot$Axis();\n }return Defaults$Plot$Axis_instance;\n }\n Defaults$Plot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Plot',\n interfaces: []\n };\n Defaults.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Defaults',\n interfaces: []\n };\n var Defaults_instance = null;\n function Defaults_getInstance() {\n if (Defaults_instance === null) {\n new Defaults();\n }return Defaults_instance;\n }\n function LabelCss() {\n LabelCss_instance = this;\n }\n LabelCss.prototype.get_diyz8p$ = function (labelSpec, selector) {\n var css = StringBuilder_init();\n css.append_pdl1vj$(selector).append_pdl1vj$(' {').append_pdl1vj$(labelSpec.isMonospaced ? '\\n font-family: ' + Defaults_getInstance().FONT_FAMILY_MONOSPACED + ';' : '\\n').append_pdl1vj$('\\n font-size: ').append_s8jyv4$(labelSpec.fontSize).append_pdl1vj$('px;').append_pdl1vj$(labelSpec.isBold ? '\\n font-weight: bold;' : '').append_pdl1vj$('\\n}\\n');\n return css.toString();\n };\n LabelCss.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LabelCss',\n interfaces: []\n };\n var LabelCss_instance = null;\n function LabelCss_getInstance() {\n if (LabelCss_instance === null) {\n new LabelCss();\n }return LabelCss_instance;\n }\n function Serializable() {\n }\n Serializable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Serializable',\n interfaces: []\n };\n function LabelMetrics() {\n LabelMetrics$Companion_getInstance();\n this.fontSize_yu4fth$_0 = 0;\n this.isBold_4ltcm$_0 = false;\n this.isMonospaced_kwm1y$_0 = false;\n }\n Object.defineProperty(LabelMetrics.prototype, 'fontSize', {\n configurable: true,\n get: function () {\n return this.fontSize_yu4fth$_0;\n }\n });\n Object.defineProperty(LabelMetrics.prototype, 'isBold', {\n configurable: true,\n get: function () {\n return this.isBold_4ltcm$_0;\n }\n });\n Object.defineProperty(LabelMetrics.prototype, 'isMonospaced', {\n configurable: true,\n get: function () {\n return this.isMonospaced_kwm1y$_0;\n }\n });\n LabelMetrics.prototype.dimensions_za3lpa$ = function (labelLength) {\n return new DoubleVector(this.width_za3lpa$(labelLength), this.height());\n };\n LabelMetrics.prototype.width_za3lpa$ = function (labelLength) {\n var tmp$;\n var ratio = LabelMetrics$Companion_getInstance().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0;\n if (this.isMonospaced) {\n ratio = LabelMetrics$Companion_getInstance().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0;\n }var width = labelLength * this.fontSize * ratio + 2 * LabelMetrics$Companion_getInstance().LABEL_PADDING_0;\n if (this.isBold) {\n tmp$ = width * LabelMetrics$Companion_getInstance().FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0;\n } else\n tmp$ = width;\n return tmp$;\n };\n LabelMetrics.prototype.height = function () {\n return this.fontSize + 2 * LabelMetrics$Companion_getInstance().LABEL_PADDING_0;\n };\n function LabelMetrics$Companion() {\n LabelMetrics$Companion_instance = this;\n this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0 = 0.67;\n this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0 = 0.6;\n this.FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0 = 1.075;\n this.LABEL_PADDING_0 = 0.0;\n }\n LabelMetrics$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LabelMetrics$Companion_instance = null;\n function LabelMetrics$Companion_getInstance() {\n if (LabelMetrics$Companion_instance === null) {\n new LabelMetrics$Companion();\n }return LabelMetrics$Companion_instance;\n }\n LabelMetrics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LabelMetrics',\n interfaces: [Serializable, LabelSpec]\n };\n function LabelMetrics_init($this) {\n $this = $this || Object.create(LabelMetrics.prototype);\n LabelMetrics.call($this);\n $this.fontSize_yu4fth$_0 = 0.0;\n $this.isBold_4ltcm$_0 = false;\n $this.isMonospaced_kwm1y$_0 = false;\n return $this;\n }\n function LabelMetrics_init_0(fontSize, bold, monospaced, $this) {\n if (bold === void 0)\n bold = false;\n if (monospaced === void 0)\n monospaced = false;\n $this = $this || Object.create(LabelMetrics.prototype);\n LabelMetrics.call($this);\n $this.fontSize_yu4fth$_0 = fontSize;\n $this.isBold_4ltcm$_0 = bold;\n $this.isMonospaced_kwm1y$_0 = monospaced;\n return $this;\n }\n function LabelSpec() {\n }\n LabelSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LabelSpec',\n interfaces: []\n };\n function PlotLabelSpec(name, ordinal, fontSize, bold, monospaced) {\n if (bold === void 0)\n bold = false;\n if (monospaced === void 0)\n monospaced = false;\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n this.myLabelMetrics_3i33aj$_0 = null;\n this.myLabelMetrics_3i33aj$_0 = LabelMetrics_init_0(fontSize, bold, monospaced);\n }\n function PlotLabelSpec_initFields() {\n PlotLabelSpec_initFields = function () {\n };\n PlotLabelSpec$PLOT_TITLE_instance = new PlotLabelSpec('PLOT_TITLE', 0, 16, true);\n PlotLabelSpec$AXIS_TICK_instance = new PlotLabelSpec('AXIS_TICK', 1, 10);\n PlotLabelSpec$AXIS_TICK_SMALL_instance = new PlotLabelSpec('AXIS_TICK_SMALL', 2, 8);\n PlotLabelSpec$AXIS_TITLE_instance = new PlotLabelSpec('AXIS_TITLE', 3, 12);\n PlotLabelSpec$LEGEND_TITLE_instance = new PlotLabelSpec('LEGEND_TITLE', 4, 12, true);\n PlotLabelSpec$LEGEND_ITEM_instance = new PlotLabelSpec('LEGEND_ITEM', 5, 10);\n }\n var PlotLabelSpec$PLOT_TITLE_instance;\n function PlotLabelSpec$PLOT_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$PLOT_TITLE_instance;\n }\n var PlotLabelSpec$AXIS_TICK_instance;\n function PlotLabelSpec$AXIS_TICK_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TICK_instance;\n }\n var PlotLabelSpec$AXIS_TICK_SMALL_instance;\n function PlotLabelSpec$AXIS_TICK_SMALL_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TICK_SMALL_instance;\n }\n var PlotLabelSpec$AXIS_TITLE_instance;\n function PlotLabelSpec$AXIS_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TITLE_instance;\n }\n var PlotLabelSpec$LEGEND_TITLE_instance;\n function PlotLabelSpec$LEGEND_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$LEGEND_TITLE_instance;\n }\n var PlotLabelSpec$LEGEND_ITEM_instance;\n function PlotLabelSpec$LEGEND_ITEM_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$LEGEND_ITEM_instance;\n }\n Object.defineProperty(PlotLabelSpec.prototype, 'isBold', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.isBold;\n }\n });\n Object.defineProperty(PlotLabelSpec.prototype, 'isMonospaced', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.isMonospaced;\n }\n });\n Object.defineProperty(PlotLabelSpec.prototype, 'fontSize', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.fontSize;\n }\n });\n PlotLabelSpec.prototype.dimensions_za3lpa$ = function (labelLength) {\n return this.myLabelMetrics_3i33aj$_0.dimensions_za3lpa$(labelLength);\n };\n PlotLabelSpec.prototype.width_za3lpa$ = function (labelLength) {\n return this.myLabelMetrics_3i33aj$_0.width_za3lpa$(labelLength);\n };\n PlotLabelSpec.prototype.height = function () {\n return this.myLabelMetrics_3i33aj$_0.height();\n };\n PlotLabelSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLabelSpec',\n interfaces: [LabelSpec, Enum]\n };\n function PlotLabelSpec$values() {\n return [PlotLabelSpec$PLOT_TITLE_getInstance(), PlotLabelSpec$AXIS_TICK_getInstance(), PlotLabelSpec$AXIS_TICK_SMALL_getInstance(), PlotLabelSpec$AXIS_TITLE_getInstance(), PlotLabelSpec$LEGEND_TITLE_getInstance(), PlotLabelSpec$LEGEND_ITEM_getInstance()];\n }\n PlotLabelSpec.values = PlotLabelSpec$values;\n function PlotLabelSpec$valueOf(name) {\n switch (name) {\n case 'PLOT_TITLE':\n return PlotLabelSpec$PLOT_TITLE_getInstance();\n case 'AXIS_TICK':\n return PlotLabelSpec$AXIS_TICK_getInstance();\n case 'AXIS_TICK_SMALL':\n return PlotLabelSpec$AXIS_TICK_SMALL_getInstance();\n case 'AXIS_TITLE':\n return PlotLabelSpec$AXIS_TITLE_getInstance();\n case 'LEGEND_TITLE':\n return PlotLabelSpec$LEGEND_TITLE_getInstance();\n case 'LEGEND_ITEM':\n return PlotLabelSpec$LEGEND_ITEM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.presentation.PlotLabelSpec.' + name);\n }\n }\n PlotLabelSpec.valueOf_61zpoe$ = PlotLabelSpec$valueOf;\n function Style() {\n Style_instance = this;\n this.JFX_PLOT_STYLESHEET = '/svgMapper/jfx/plot.css';\n this.PLOT_CONTAINER = 'plt-container';\n this.PLOT = 'plt-plot';\n this.PLOT_TITLE = 'plt-plot-title';\n this.PLOT_TRANSPARENT = 'plt-transparent';\n this.PLOT_BACKDROP = 'plt-backdrop';\n this.AXIS = 'plt-axis';\n this.AXIS_TITLE = 'plt-axis-title';\n this.TICK = 'tick';\n this.SMALL_TICK_FONT = 'small-tick-font';\n this.BACK = 'back';\n this.LEGEND = 'plt_legend';\n this.LEGEND_TITLE = 'legend-title';\n this.PLOT_DATA_TOOLTIP = 'plt-data-tooltip';\n this.PLOT_AXIS_TOOLTIP = 'plt-axis-tooltip';\n this.CSS_0 = trimMargin('\\n |.plt-container {\\n |\\tfont-family: \"Lucida Grande\", sans-serif;\\n |\\tcursor: crosshair;\\n |\\tuser-select: none;\\n |\\t-webkit-user-select: none;\\n |\\t-moz-user-select: none;\\n |\\t-ms-user-select: none;\\n |}\\n |.plt-backdrop {\\n | fill: white;\\n |}\\n |.plt-transparent .plt-backdrop {\\n | visibility: hidden;\\n |}\\n |text {\\n |\\tfont-size: 12px;\\n |\\tfill: #3d3d3d;\\n |\\t\\n |\\ttext-rendering: optimizeLegibility;\\n |}\\n |.plt-data-tooltip text {\\n |\\tfont-size: 12px;\\n |}\\n |.plt-axis-tooltip text {\\n |\\tfont-size: 12px;\\n |}\\n |.plt-axis line {\\n |\\tshape-rendering: crispedges;\\n |}\\n ');\n }\n Object.defineProperty(Style.prototype, 'css', {\n configurable: true,\n get: function () {\n var tmp$, tmp$_0;\n var css = new StringBuilder(this.CSS_0.toString());\n css.append_s8itvh$(10);\n tmp$ = PlotLabelSpec$values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var labelSpec = tmp$[tmp$_0];\n var selector = this.selector_0(labelSpec);\n css.append_pdl1vj$(LabelCss_getInstance().get_diyz8p$(labelSpec, selector));\n }\n return css.toString();\n }\n });\n Style.prototype.selector_0 = function (labelSpec) {\n var tmp$;\n switch (labelSpec.name) {\n case 'PLOT_TITLE':\n tmp$ = '.plt-plot-title';\n break;\n case 'AXIS_TICK':\n tmp$ = '.plt-axis .tick text';\n break;\n case 'AXIS_TICK_SMALL':\n tmp$ = '.plt-axis.small-tick-font .tick text';\n break;\n case 'AXIS_TITLE':\n tmp$ = '.plt-axis-title text';\n break;\n case 'LEGEND_TITLE':\n tmp$ = '.plt_legend .legend-title text';\n break;\n case 'LEGEND_ITEM':\n tmp$ = '.plt_legend text';\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n Style.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Style',\n interfaces: []\n };\n var Style_instance = null;\n function Style_getInstance() {\n if (Style_instance === null) {\n new Style();\n }return Style_instance;\n }\n function GroupAwareSampling() {\n }\n GroupAwareSampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GroupAwareSampling',\n interfaces: [Sampling]\n };\n function PointSampling() {\n }\n PointSampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointSampling',\n interfaces: [Sampling]\n };\n function Sampling() {\n }\n Sampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Sampling',\n interfaces: []\n };\n function Samplings() {\n Samplings_instance = this;\n this.RANDOM = RandomSampling$Companion_getInstance().ALIAS;\n this.PICK = PickSampling$Companion_getInstance().ALIAS;\n this.SYSTEMATIC = SystematicSampling$Companion_getInstance().ALIAS;\n this.RANDOM_GROUP = GroupRandomSampling$Companion_getInstance().ALIAS;\n this.SYSTEMATIC_GROUP = GroupSystematicSampling$Companion_getInstance().ALIAS;\n this.RANDOM_STRATIFIED = RandomStratifiedSampling$Companion_getInstance().ALIAS_8be2vx$;\n this.VERTEX_VW = VertexSampling$VertexVwSampling$Companion_getInstance().ALIAS;\n this.VERTEX_DP = VertexSampling$VertexDpSampling$Companion_getInstance().ALIAS;\n this.NONE = new Samplings$NoneSampling();\n }\n Samplings.prototype.random_280ow0$ = function (sampleSize, seed) {\n return new RandomSampling(sampleSize, seed);\n };\n Samplings.prototype.pick_za3lpa$ = function (sampleSize) {\n return new PickSampling(sampleSize);\n };\n Samplings.prototype.vertexDp_za3lpa$ = function (sampleSize) {\n return new VertexSampling$VertexDpSampling(sampleSize);\n };\n Samplings.prototype.vertexVw_za3lpa$ = function (sampleSize) {\n return new VertexSampling$VertexVwSampling(sampleSize);\n };\n Samplings.prototype.systematic_za3lpa$ = function (sampleSize) {\n return new SystematicSampling(sampleSize);\n };\n Samplings.prototype.randomGroup_280ow0$ = function (sampleSize, seed) {\n return new GroupRandomSampling(sampleSize, seed);\n };\n Samplings.prototype.systematicGroup_za3lpa$ = function (sampleSize) {\n return new GroupSystematicSampling(sampleSize);\n };\n Samplings.prototype.randomStratified_vcwos1$ = function (sampleSize, seed, minSubSample) {\n return new RandomStratifiedSampling(sampleSize, seed, minSubSample);\n };\n function Samplings$NoneSampling() {\n }\n Object.defineProperty(Samplings$NoneSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'none';\n }\n });\n Samplings$NoneSampling.prototype.isApplicable_dhhkv7$ = function (population) {\n return false;\n };\n Samplings$NoneSampling.prototype.apply_dhhkv7$ = function (population) {\n return population;\n };\n Samplings$NoneSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NoneSampling',\n interfaces: [PointSampling]\n };\n Samplings.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Samplings',\n interfaces: []\n };\n var Samplings_instance = null;\n function Samplings_getInstance() {\n if (Samplings_instance === null) {\n new Samplings();\n }return Samplings_instance;\n }\n function GroupRandomSampling(sampleSize, mySeed) {\n GroupRandomSampling$Companion_getInstance();\n GroupSamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n }\n Object.defineProperty(GroupRandomSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + GroupRandomSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + ')';\n }\n });\n GroupRandomSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var distinctGroups = SamplingUtil_getInstance().distinctGroups_ejae6o$(groupMapper, population.rowCount());\n shuffle(distinctGroups, this.createRandom_0());\n var pickedGroups = toSet(take(distinctGroups, this.sampleSize));\n return this.doSelect_z69lec$(population, pickedGroups, groupMapper);\n };\n GroupRandomSampling.prototype.createRandom_0 = function () {\n var tmp$, tmp$_0;\n return (tmp$_0 = (tmp$ = this.mySeed_0) != null ? Random(tmp$) : null) != null ? tmp$_0 : Random_0.Default;\n };\n function GroupRandomSampling$Companion() {\n GroupRandomSampling$Companion_instance = this;\n this.ALIAS = 'group_random';\n }\n GroupRandomSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupRandomSampling$Companion_instance = null;\n function GroupRandomSampling$Companion_getInstance() {\n if (GroupRandomSampling$Companion_instance === null) {\n new GroupRandomSampling$Companion();\n }return GroupRandomSampling$Companion_instance;\n }\n GroupRandomSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupRandomSampling',\n interfaces: [GroupSamplingBase]\n };\n function GroupSamplingBase(sampleSize) {\n SamplingBase.call(this, sampleSize);\n }\n GroupSamplingBase.prototype.isApplicable_se5qvl$ = function (population, groupMapper) {\n return this.isApplicable_ijg2gx$(population, groupMapper, SamplingUtil_getInstance().groupCount_ejae6o$(groupMapper, population.rowCount()));\n };\n GroupSamplingBase.prototype.isApplicable_ijg2gx$ = function (population, groupMapper, groupCount) {\n return groupCount > this.sampleSize;\n };\n GroupSamplingBase.prototype.doSelect_z69lec$ = function (population, pickedGroups, groupMapper) {\n var tmp$;\n var indicesByGroup = GroupUtil_getInstance().indicesByGroup_wc9gac$(population.rowCount(), groupMapper);\n var pickedIndices = ArrayList_init();\n tmp$ = pickedGroups.iterator();\n while (tmp$.hasNext()) {\n var group = tmp$.next();\n pickedIndices.addAll_brywnq$(ensureNotNull(indicesByGroup.get_11rb$(group)));\n }\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n GroupSamplingBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupSamplingBase',\n interfaces: [GroupAwareSampling, SamplingBase]\n };\n function GroupSystematicSampling(sampleSize) {\n GroupSystematicSampling$Companion_getInstance();\n GroupSamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(GroupSystematicSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + GroupSystematicSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n GroupSystematicSampling.prototype.isApplicable_ijg2gx$ = function (population, groupMapper, groupCount) {\n return GroupSamplingBase.prototype.isApplicable_ijg2gx$.call(this, population, groupMapper, groupCount) && SystematicSampling$Companion_getInstance().computeStep_vux9f0$(groupCount, this.sampleSize) >= 2;\n };\n GroupSystematicSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var distinctGroups = SamplingUtil_getInstance().distinctGroups_ejae6o$(groupMapper, population.rowCount());\n var step = SystematicSampling$Companion_getInstance().computeStep_vux9f0$(distinctGroups.size, this.sampleSize);\n var pickedGroups = HashSet_init_0();\n var i = 0;\n while (i < distinctGroups.size) {\n pickedGroups.add_11rb$(distinctGroups.get_za3lpa$(i));\n i = i + step | 0;\n }\n return this.doSelect_z69lec$(population, pickedGroups, groupMapper);\n };\n function GroupSystematicSampling$Companion() {\n GroupSystematicSampling$Companion_instance = this;\n this.ALIAS = 'group_systematic';\n }\n GroupSystematicSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupSystematicSampling$Companion_instance = null;\n function GroupSystematicSampling$Companion_getInstance() {\n if (GroupSystematicSampling$Companion_instance === null) {\n new GroupSystematicSampling$Companion();\n }return GroupSystematicSampling$Companion_instance;\n }\n GroupSystematicSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupSystematicSampling',\n interfaces: [GroupSamplingBase]\n };\n function PickSampling(sampleSize) {\n PickSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(PickSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + PickSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n PickSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var xVar = SamplingUtil_getInstance().xVar_dhhkv7$(population);\n var xFactors = population.distinctValues_8xm3sj$(xVar);\n if (xFactors.size <= this.sampleSize) {\n return population;\n }var pickX = toSet(take(xFactors, this.sampleSize));\n var xValues = population.get_8xm3sj$(xVar);\n var pickedIndices = ArrayList_init();\n var index = 0;\n for (var tmp$ = xValues.iterator(); tmp$.hasNext(); ++index) {\n var v = tmp$.next();\n if (contains(pickX, v)) {\n pickedIndices.add_11rb$(index);\n }}\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n function PickSampling$Companion() {\n PickSampling$Companion_instance = this;\n this.ALIAS = 'pick';\n }\n PickSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PickSampling$Companion_instance = null;\n function PickSampling$Companion_getInstance() {\n if (PickSampling$Companion_instance === null) {\n new PickSampling$Companion();\n }return PickSampling$Companion_instance;\n }\n PickSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PickSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function RandomSampling(sampleSize, mySeed) {\n RandomSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n }\n Object.defineProperty(RandomSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + RandomSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + ')';\n }\n });\n RandomSampling.prototype.apply_dhhkv7$ = function (population) {\n var tmp$, tmp$_0;\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var rand = (tmp$_0 = (tmp$ = this.mySeed_0) != null ? Random(tmp$) : null) != null ? tmp$_0 : Random_0.Default;\n return util.SamplingUtil.sampleWithoutReplacement_egh5ya$(this.sampleSize, rand, population);\n };\n function RandomSampling$Companion() {\n RandomSampling$Companion_instance = this;\n this.ALIAS = 'random';\n }\n RandomSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RandomSampling$Companion_instance = null;\n function RandomSampling$Companion_getInstance() {\n if (RandomSampling$Companion_instance === null) {\n new RandomSampling$Companion();\n }return RandomSampling$Companion_instance;\n }\n RandomSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function RandomStratifiedSampling(sampleSize, mySeed, myMinSubsampleSize) {\n RandomStratifiedSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n this.myMinSubsampleSize_0 = myMinSubsampleSize;\n }\n Object.defineProperty(RandomStratifiedSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + RandomStratifiedSampling$Companion_getInstance().ALIAS_8be2vx$ + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + (this.myMinSubsampleSize_0 != null ? ', min_subsample=' + toString(this.myMinSubsampleSize_0) : '') + ')';\n }\n });\n RandomStratifiedSampling.prototype.isApplicable_se5qvl$ = function (population, groupMapper) {\n return population.rowCount() > this.sampleSize;\n };\n function RandomStratifiedSampling$apply$lambda(closure$groupIndices) {\n return function (indexSet) {\n var $receiver = until(0, closure$groupIndices.size);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (indexSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n }\n function RandomStratifiedSampling$apply$lambda_0(closure$groupIndices) {\n return function (indexSet) {\n var $receiver = until(0, closure$groupIndices.size);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!indexSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n }\n RandomStratifiedSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var indicesByGroup = GroupUtil_getInstance().indicesByGroup_wc9gac$(population.rowCount(), groupMapper);\n var minSubSampleSize = (tmp$ = this.myMinSubsampleSize_0) != null ? tmp$ : 2;\n var b = minSubSampleSize;\n minSubSampleSize = JsMath.max(0, b);\n var popSize = population.rowCount();\n var pickIndices = ArrayList_init();\n var rand = (tmp$_1 = (tmp$_0 = this.mySeed_0) != null ? Random(tmp$_0) : null) != null ? tmp$_1 : Random_0.Default;\n tmp$_2 = indicesByGroup.keys.iterator();\n while (tmp$_2.hasNext()) {\n var group = tmp$_2.next();\n var groupIndices = ensureNotNull(indicesByGroup.get_11rb$(group));\n var stratumSize = groupIndices.size;\n var ratio = stratumSize / popSize;\n var stratumSampleSize = numberToInt(round(this.sampleSize * ratio));\n var a = stratumSampleSize;\n var b_0 = minSubSampleSize;\n stratumSampleSize = JsMath.max(a, b_0);\n if (stratumSampleSize >= stratumSize) {\n pickIndices.addAll_brywnq$(groupIndices);\n } else {\n var sampleGroupIndices = util.SamplingUtil.sampleWithoutReplacement_o7ew15$(stratumSize, stratumSampleSize, rand, RandomStratifiedSampling$apply$lambda(groupIndices), RandomStratifiedSampling$apply$lambda_0(groupIndices));\n tmp$_3 = sampleGroupIndices.iterator();\n while (tmp$_3.hasNext()) {\n var i = tmp$_3.next();\n pickIndices.add_11rb$(groupIndices.get_za3lpa$(i));\n }\n }\n }\n return population.selectIndices_pqoyrt$(pickIndices);\n };\n function RandomStratifiedSampling$Companion() {\n RandomStratifiedSampling$Companion_instance = this;\n this.ALIAS_8be2vx$ = 'random_stratified';\n this.DEF_MIN_SUBSAMPLE_SIZE_0 = 2;\n }\n RandomStratifiedSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RandomStratifiedSampling$Companion_instance = null;\n function RandomStratifiedSampling$Companion_getInstance() {\n if (RandomStratifiedSampling$Companion_instance === null) {\n new RandomStratifiedSampling$Companion();\n }return RandomStratifiedSampling$Companion_instance;\n }\n RandomStratifiedSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomStratifiedSampling',\n interfaces: [GroupAwareSampling, SamplingBase]\n };\n function SamplingBase(sampleSize) {\n this.sampleSize = sampleSize;\n if (!(this.sampleSize > 0)) {\n var message = 'Sample size must be greater than zero, but was: ' + toString(this.sampleSize);\n throw IllegalStateException_init(message.toString());\n }}\n SamplingBase.prototype.isApplicable_dhhkv7$ = function (population) {\n return population.rowCount() > this.sampleSize;\n };\n SamplingBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SamplingBase',\n interfaces: [Sampling]\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function SamplingUtil() {\n SamplingUtil_instance = this;\n }\n SamplingUtil.prototype.groupCount_ejae6o$ = function (groupMapper, size) {\n var $receiver = until(0, size);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(groupMapper(item));\n }\n return distinct(destination).size;\n };\n SamplingUtil.prototype.distinctGroups_ejae6o$ = function (groupMapper, size) {\n var $receiver = until(0, size);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(groupMapper(item));\n }\n return toMutableList(distinct(destination));\n };\n SamplingUtil.prototype.xVar_bbyvt0$ = function (variables) {\n var tmp$;\n if (variables.contains_11rb$(stat.Stats.X))\n tmp$ = stat.Stats.X;\n else if (variables.contains_11rb$(data.TransformVar.X))\n tmp$ = data.TransformVar.X;\n else\n tmp$ = null;\n return tmp$;\n };\n SamplingUtil.prototype.xVar_dhhkv7$ = function (data) {\n var tmp$;\n tmp$ = this.xVar_bbyvt0$(data.variables());\n if (tmp$ == null) {\n throw IllegalStateException_init(\"Can't apply sampling: couldn't deduce the (X) variable.\");\n }return tmp$;\n };\n SamplingUtil.prototype.yVar_dhhkv7$ = function (data_0) {\n if (data_0.has_8xm3sj$(stat.Stats.Y)) {\n return stat.Stats.Y;\n } else if (data_0.has_8xm3sj$(data.TransformVar.Y)) {\n return data.TransformVar.Y;\n }throw IllegalStateException_init(\"Can't apply sampling: couldn't deduce the (Y) variable.\");\n };\n SamplingUtil.prototype.splitRings_dhhkv7$ = function (population) {\n var tmp$, tmp$_0;\n var rings = ArrayList_init();\n var lastPoint = null;\n var start = -1;\n var xValues = Kotlin.isType(tmp$ = population.get_8xm3sj$(this.xVar_dhhkv7$(population)), List) ? tmp$ : throwCCE();\n var yValues = Kotlin.isType(tmp$_0 = population.get_8xm3sj$(this.yVar_dhhkv7$(population)), List) ? tmp$_0 : throwCCE();\n var points = new VertexSampling$DoubleVectorComponentsList(xValues, yValues);\n for (var i = 0; i !== points.size; ++i) {\n var point = points.get_za3lpa$(i);\n if (start < 0) {\n start = i;\n lastPoint = point;\n } else if (equals(lastPoint, point)) {\n rings.add_11rb$(points.subList_vux9f0$(start, i + 1 | 0));\n start = -1;\n lastPoint = null;\n }}\n if (start >= 0) {\n rings.add_11rb$(points.subList_vux9f0$(start, points.size));\n }return rings;\n };\n function SamplingUtil$calculateRingLimits$lambda(closure$rings) {\n return function (it) {\n return new Pair(it, calculateArea(closure$rings.get_za3lpa$(it)));\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_0(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingArea_0(it);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_1(closure$totalArea, closure$areaProceed, closure$totalPointsLimit, closure$pointsProceed, closure$rings, this$SamplingUtil) {\n return function (p) {\n var a = roundToInt(p.second / (closure$totalArea - closure$areaProceed.get()) * (closure$totalPointsLimit - closure$pointsProceed.get() | 0));\n var b = closure$rings.get_za3lpa$(this$SamplingUtil.getRingIndex_3gcxfl$(p)).size;\n var limit = JsMath.min(a, b);\n if (limit >= 4) {\n closure$areaProceed.getAndAdd_14dthe$(this$SamplingUtil.getRingArea_0(p));\n closure$pointsProceed.getAndAdd_za3lpa$(limit);\n } else {\n limit = 0;\n }\n return new Pair(this$SamplingUtil.getRingIndex_3gcxfl$(p), limit);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_2(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingIndex_3gcxfl$(it);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_3(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingLimit_66os8t$(it);\n };\n }\n SamplingUtil.prototype.calculateRingLimits_rmr3bv$ = function (rings, totalPointsLimit) {\n var destination = ArrayList_init_1(collectionSizeOrDefault(rings, 10));\n var tmp$;\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(calculateArea(item));\n }\n var totalArea = sum(destination);\n var areaProceed = new MutableDouble(0.0);\n var pointsProceed = new MutableInteger(0);\n return toList_0(map(sortedWith_0(map(sortedWith_0(map(asSequence(get_indices(rings)), SamplingUtil$calculateRingLimits$lambda(rings)), reversed(new Comparator(compareBy$lambda_0(SamplingUtil$calculateRingLimits$lambda_0(this))))), SamplingUtil$calculateRingLimits$lambda_1(totalArea, areaProceed, totalPointsLimit, pointsProceed, rings, this)), new Comparator(compareBy$lambda_0(SamplingUtil$calculateRingLimits$lambda_2(this)))), SamplingUtil$calculateRingLimits$lambda_3(this)));\n };\n SamplingUtil.prototype.getRingIndex_3gcxfl$ = function (pair) {\n return pair.first;\n };\n SamplingUtil.prototype.getRingArea_0 = function (pair) {\n return pair.second;\n };\n SamplingUtil.prototype.getRingLimit_66os8t$ = function (pair) {\n return pair.second;\n };\n SamplingUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SamplingUtil',\n interfaces: []\n };\n var SamplingUtil_instance = null;\n function SamplingUtil_getInstance() {\n if (SamplingUtil_instance === null) {\n new SamplingUtil();\n }return SamplingUtil_instance;\n }\n function SystematicSampling(sampleSize) {\n SystematicSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(SystematicSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + SystematicSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n SystematicSampling.prototype.isApplicable_dhhkv7$ = function (population) {\n return SamplingBase.prototype.isApplicable_dhhkv7$.call(this, population) && this.computeStep_0(population.rowCount()) >= 2;\n };\n SystematicSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var popSize = population.rowCount();\n var step = this.computeStep_0(popSize);\n var pickedIndices = ArrayList_init();\n var i = 0;\n while (i < popSize) {\n pickedIndices.add_11rb$(i);\n i = i + step | 0;\n }\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n SystematicSampling.prototype.computeStep_0 = function (popSize) {\n return numberToInt(round(popSize / (this.sampleSize - 1 | 0)));\n };\n function SystematicSampling$Companion() {\n SystematicSampling$Companion_instance = this;\n this.ALIAS = 'systematic';\n }\n SystematicSampling$Companion.prototype.computeStep_vux9f0$ = function (popSize, sampleSize) {\n return numberToInt(round((popSize - 1 | 0) / (sampleSize - 1 | 0)));\n };\n SystematicSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SystematicSampling$Companion_instance = null;\n function SystematicSampling$Companion_getInstance() {\n if (SystematicSampling$Companion_instance === null) {\n new SystematicSampling$Companion();\n }return SystematicSampling$Companion_instance;\n }\n SystematicSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SystematicSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function VertexSampling(sampleSize) {\n VertexSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n VertexSampling.prototype.simplify_0 = function (points, limit) {\n var tmp$;\n if (limit === 0) {\n tmp$ = emptyList();\n } else {\n tmp$ = this.simplifyInternal_11hmxm$(points, limit);\n }\n return tmp$;\n };\n VertexSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var rings = SamplingUtil_getInstance().splitRings_dhhkv7$(population);\n var limits = rings.size === 1 && !isClosed(rings.get_za3lpa$(0)) ? listOf(this.sampleSize) : SamplingUtil_getInstance().calculateRingLimits_rmr3bv$(rings, this.sampleSize);\n var indices = ArrayList_init();\n var ringBase = new MutableInteger(0);\n var $receiver = until(0, limits.size);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new Pair(item, limits.get_za3lpa$(item)));\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var tmp$_1;\n tmp$_1 = this.simplify_0(rings.get_za3lpa$(SamplingUtil_getInstance().getRingIndex_3gcxfl$(element)), SamplingUtil_getInstance().getRingLimit_66os8t$(element)).iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n indices.add_11rb$(ringBase.get() + element_0 | 0);\n }\n ringBase.getAndAdd_za3lpa$(rings.get_za3lpa$(SamplingUtil_getInstance().getRingIndex_3gcxfl$(element)).size);\n }\n return population.selectIndices_pqoyrt$(indices);\n };\n function VertexSampling$VertexVwSampling(sampleSize) {\n VertexSampling$VertexVwSampling$Companion_getInstance();\n VertexSampling.call(this, sampleSize);\n }\n Object.defineProperty(VertexSampling$VertexVwSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + VertexSampling$VertexVwSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n VertexSampling$VertexVwSampling.prototype.simplifyInternal_11hmxm$ = function (points, limit) {\n return PolylineSimplifier.Companion.visvalingamWhyatt_ytws2g$(points).setCountLimit_za3lpa$(limit).indices;\n };\n function VertexSampling$VertexVwSampling$Companion() {\n VertexSampling$VertexVwSampling$Companion_instance = this;\n this.ALIAS = 'vertex_vw';\n }\n VertexSampling$VertexVwSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$VertexVwSampling$Companion_instance = null;\n function VertexSampling$VertexVwSampling$Companion_getInstance() {\n if (VertexSampling$VertexVwSampling$Companion_instance === null) {\n new VertexSampling$VertexVwSampling$Companion();\n }return VertexSampling$VertexVwSampling$Companion_instance;\n }\n VertexSampling$VertexVwSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexVwSampling',\n interfaces: [VertexSampling]\n };\n function VertexSampling$VertexDpSampling(sampleSize) {\n VertexSampling$VertexDpSampling$Companion_getInstance();\n VertexSampling.call(this, sampleSize);\n }\n Object.defineProperty(VertexSampling$VertexDpSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + VertexSampling$VertexDpSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n VertexSampling$VertexDpSampling.prototype.simplifyInternal_11hmxm$ = function (points, limit) {\n return PolylineSimplifier.Companion.douglasPeucker_ytws2g$(points).setCountLimit_za3lpa$(limit).indices;\n };\n function VertexSampling$VertexDpSampling$Companion() {\n VertexSampling$VertexDpSampling$Companion_instance = this;\n this.ALIAS = 'vertex_dp';\n }\n VertexSampling$VertexDpSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$VertexDpSampling$Companion_instance = null;\n function VertexSampling$VertexDpSampling$Companion_getInstance() {\n if (VertexSampling$VertexDpSampling$Companion_instance === null) {\n new VertexSampling$VertexDpSampling$Companion();\n }return VertexSampling$VertexDpSampling$Companion_instance;\n }\n VertexSampling$VertexDpSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexDpSampling',\n interfaces: [VertexSampling]\n };\n function VertexSampling$DoubleVectorComponentsList(myXValues, myYValues) {\n AbstractList.call(this);\n this.myXValues_0 = myXValues;\n this.myYValues_0 = myYValues;\n }\n Object.defineProperty(VertexSampling$DoubleVectorComponentsList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myXValues_0.size;\n }\n });\n VertexSampling$DoubleVectorComponentsList.prototype.get_za3lpa$ = function (index) {\n return VertexSampling$Companion_getInstance().createPoint_0(this.myXValues_0.get_za3lpa$(index), this.myYValues_0.get_za3lpa$(index));\n };\n VertexSampling$DoubleVectorComponentsList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleVectorComponentsList',\n interfaces: [AbstractList]\n };\n function VertexSampling$Companion() {\n VertexSampling$Companion_instance = this;\n }\n VertexSampling$Companion.prototype.createPoint_0 = function (x, y) {\n var tmp$, tmp$_0;\n if (!!(typeof x === 'string' || typeof y === 'string')) {\n var message = 'String coords are not supported yet';\n throw IllegalArgumentException_init(message.toString());\n }if (!data_0.SeriesUtil.allFinite_jma9l8$(typeof (tmp$ = x) === 'number' ? tmp$ : throwCCE(), typeof (tmp$_0 = y) === 'number' ? tmp$_0 : throwCCE())) {\n var message_0 = 'Invalid coord';\n throw IllegalArgumentException_init(message_0.toString());\n }return new DoubleVector(x, y);\n };\n VertexSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$Companion_instance = null;\n function VertexSampling$Companion_getInstance() {\n if (VertexSampling$Companion_instance === null) {\n new VertexSampling$Companion();\n }return VertexSampling$Companion_instance;\n }\n VertexSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function ContinuousOnlyMapperProvider(naValue) {\n MapperProviderBase.call(this, naValue);\n }\n function ContinuousOnlyMapperProvider$createDiscreteMapper$lambda(it) {\n return \"'\" + toString(it) + \"'\";\n }\n ContinuousOnlyMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var domainRepr = joinToString(domainValues, void 0, void 0, void 0, 3, void 0, ContinuousOnlyMapperProvider$createDiscreteMapper$lambda);\n throw IllegalStateException_init('[' + toString(Kotlin.getKClassFromExpression(this).simpleName) + \"] Can't create mapper for discrete domain: \" + domainRepr);\n };\n ContinuousOnlyMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuousOnlyMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function DefaultMapperProvider() {\n DefaultMapperProvider_instance = this;\n this.PROVIDER_MAP_0 = new DefaultMapperProvider$TypedMapperProviderMap();\n }\n DefaultMapperProvider.prototype.get_31786j$ = function (aes) {\n return this.PROVIDER_MAP_0.get_lkzxyg$(aes);\n };\n DefaultMapperProvider.prototype.hasDefault_5adj56$ = function (aes) {\n return this.PROVIDER_MAP_0.containsKey_5adj56$(aes);\n };\n function DefaultMapperProvider$TypedMapperProviderMap() {\n DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance();\n this.myMap_0 = HashMap_init();\n var tmp$;\n tmp$ = Aes.Companion.allPositional().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n this.put_0(aes, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_UNDEFINED_0);\n }\n this.put_0(Aes.Companion.X, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.Y, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.Z, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YMIN, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YMAX, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.COLOR, DefaultMapperProviderUtil_getInstance().createColorMapperProvider_8be2vx$());\n this.put_0(Aes.Companion.FILL, DefaultMapperProviderUtil_getInstance().createColorMapperProvider_8be2vx$());\n this.put_0(Aes.Companion.ALPHA, AlphaMapperProvider$Companion_getInstance().DEFAULT);\n this.put_0(Aes.Companion.SHAPE, DefaultMapperProviderUtil_getInstance().createWithDiscreteOutput_rath1t$(ShapeMapper_getInstance().allShapes(), ShapeMapper_getInstance().NA_VALUE));\n this.put_0(Aes.Companion.LINETYPE, DefaultMapperProviderUtil_getInstance().createWithDiscreteOutput_rath1t$(LineTypeMapper_getInstance().allLineTypes(), LineTypeMapper_getInstance().NA_VALUE));\n this.put_0(Aes.Companion.SIZE, SizeMapperProvider$Companion_getInstance().DEFAULT);\n this.put_0(Aes.Companion.WIDTH, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.HEIGHT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.WEIGHT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.INTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SLOPE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XINTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YINTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.LOWER, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.MIDDLE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.UPPER, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.FRAME, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FRAME));\n this.put_0(Aes.Companion.SPEED, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.FLOW, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XMIN, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XMAX, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XEND, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YEND, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.LABEL, DefaultMapperProviderUtil_getInstance().createObjectIdentity_bv5adw$(Aes.Companion.LABEL));\n this.put_0(Aes.Companion.FAMILY, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FAMILY));\n this.put_0(Aes.Companion.FONTFACE, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FONTFACE));\n this.put_0(Aes.Companion.HJUST, DefaultMapperProviderUtil_getInstance().createObjectIdentityDiscrete_e4pcbt$(Aes.Companion.HJUST));\n this.put_0(Aes.Companion.VJUST, DefaultMapperProviderUtil_getInstance().createObjectIdentityDiscrete_e4pcbt$(Aes.Companion.VJUST));\n this.put_0(Aes.Companion.ANGLE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SYM_X, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SYM_Y, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n }\n DefaultMapperProvider$TypedMapperProviderMap.prototype.get_lkzxyg$ = function (aes) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), MapperProvider) ? tmp$ : throwCCE();\n };\n DefaultMapperProvider$TypedMapperProviderMap.prototype.put_0 = function (aes, value) {\n this.myMap_0.put_xwzc9p$(aes, value);\n };\n DefaultMapperProvider$TypedMapperProviderMap.prototype.containsKey_5adj56$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n function DefaultMapperProvider$TypedMapperProviderMap$Companion() {\n DefaultMapperProvider$TypedMapperProviderMap$Companion_instance = this;\n this.NUMERIC_UNDEFINED_0 = new DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral();\n this.NUMERIC_IDENTITY_0 = new DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral();\n }\n function DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral() {\n }\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().UNDEFINED;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().UNDEFINED;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n function DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral() {\n }\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().IDENTITY;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().IDENTITY;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DefaultMapperProvider$TypedMapperProviderMap$Companion_instance = null;\n function DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance() {\n if (DefaultMapperProvider$TypedMapperProviderMap$Companion_instance === null) {\n new DefaultMapperProvider$TypedMapperProviderMap$Companion();\n }return DefaultMapperProvider$TypedMapperProviderMap$Companion_instance;\n }\n DefaultMapperProvider$TypedMapperProviderMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedMapperProviderMap',\n interfaces: []\n };\n DefaultMapperProvider.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultMapperProvider',\n interfaces: []\n };\n var DefaultMapperProvider_instance = null;\n function DefaultMapperProvider_getInstance() {\n if (DefaultMapperProvider_instance === null) {\n new DefaultMapperProvider();\n }return DefaultMapperProvider_instance;\n }\n function DefaultMapperProviderUtil() {\n DefaultMapperProviderUtil_instance = this;\n }\n function DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral(closure$discrete, closure$continuous) {\n this.closure$discrete = closure$discrete;\n this.closure$continuous = closure$continuous;\n }\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.closure$discrete.createDiscreteMapper_7f6uoc$(domainValues);\n };\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return this.closure$continuous.createContinuousMapper_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n };\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createColorMapperProvider_8be2vx$ = function () {\n var discrete = new ColorBrewerMapperProvider(null, null, null, Color.Companion.GRAY);\n var continuous = ColorGradientMapperProvider$Companion_getInstance().DEFAULT;\n return new DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral(discrete, continuous);\n };\n function DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral(closure$outputValues, closure$naValue) {\n this.closure$outputValues = closure$outputValues;\n this.closure$naValue = closure$naValue;\n }\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, this.closure$outputValues, this.closure$naValue);\n };\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().continuousToDiscrete_fooeq8$(scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans), this.closure$outputValues, this.closure$naValue);\n };\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createWithDiscreteOutput_rath1t$ = function (outputValues, naValue) {\n return new DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral(outputValues, naValue);\n };\n function DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral(inputConverter, naValue) {\n IdentityDiscreteMapperProvider.call(this, inputConverter, naValue);\n }\n function DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral$createContinuousMapper$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral$createContinuousMapper$lambda);\n };\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [IdentityDiscreteMapperProvider]\n };\n function DefaultMapperProviderUtil$createObjectIdentity$DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral_init$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil.prototype.createObjectIdentity_bv5adw$ = function (aes) {\n return new DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral(DefaultMapperProviderUtil$createObjectIdentity$DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral_init$lambda, null);\n };\n function DefaultMapperProviderUtil$createObjectIdentityDiscrete$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil.prototype.createObjectIdentityDiscrete_e4pcbt$ = function (aes) {\n var converter = DefaultMapperProviderUtil$createObjectIdentityDiscrete$lambda;\n return this.createIdentityMapperProvider_0(aes, converter, null);\n };\n function DefaultMapperProviderUtil$createStringIdentity$lambda(it) {\n return it != null ? it.toString() : null;\n }\n function DefaultMapperProviderUtil$createStringIdentity$lambda_0(it) {\n return it != null ? it.toString() : null;\n }\n DefaultMapperProviderUtil.prototype.createStringIdentity_kc1el2$ = function (aes) {\n var converter = DefaultMapperProviderUtil$createStringIdentity$lambda;\n var continuousMapper = DefaultMapperProviderUtil$createStringIdentity$lambda_0;\n return this.createIdentityMapperProvider_0(aes, converter, continuousMapper);\n };\n function DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral(closure$continuousMapper, closure$aes, inputConverter, naValue) {\n this.closure$continuousMapper = closure$continuousMapper;\n this.closure$aes = closure$aes;\n IdentityDiscreteMapperProvider.call(this, inputConverter, naValue);\n }\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n if (this.closure$continuousMapper != null) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(this.closure$continuousMapper);\n }throw IllegalStateException_init(\"Can't create \" + this.closure$aes + ' mapper for continuous domain ' + domain);\n };\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [IdentityDiscreteMapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createIdentityMapperProvider_0 = function (aes, converter, continuousMapper) {\n return new DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral(continuousMapper, aes, converter, DefaultNaValue_getInstance().get_31786j$(aes));\n };\n DefaultMapperProviderUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultMapperProviderUtil',\n interfaces: []\n };\n var DefaultMapperProviderUtil_instance = null;\n function DefaultMapperProviderUtil_getInstance() {\n if (DefaultMapperProviderUtil_instance === null) {\n new DefaultMapperProviderUtil();\n }return DefaultMapperProviderUtil_instance;\n }\n function DefaultNaValue() {\n DefaultNaValue_instance = this;\n this.VALUE_MAP_0 = new TypedKeyHashMap();\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.X, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.Y, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.Z, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YMIN, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YMAX, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.COLOR, Color.Companion.GRAY);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FILL, Color.Companion.GRAY);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.ALPHA, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SHAPE, point.TinyPointShape);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LINETYPE, NamedLineType.SOLID);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SIZE, aes.AesScaling.sizeFromCircleDiameter_14dthe$(1.0));\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.WIDTH, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.HEIGHT, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.WEIGHT, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.INTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SLOPE, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XINTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YINTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LOWER, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.MIDDLE, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.UPPER, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FRAME, 'empty frame');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SPEED, 10.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FLOW, 0.1);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XMIN, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XMAX, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XEND, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YEND, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LABEL, '-');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FAMILY, 'sans-serif');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FONTFACE, 'plain');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.HJUST, 0.5);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.VJUST, 0.5);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.ANGLE, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SYM_X, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SYM_Y, 0.0);\n }\n DefaultNaValue.prototype.has_896ixz$ = function (aes) {\n return this.VALUE_MAP_0.containsKey_ex36zt$(aes);\n };\n DefaultNaValue.prototype.get_31786j$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n DefaultNaValue.prototype.get_ex36zt$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n DefaultNaValue.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultNaValue',\n interfaces: []\n };\n var DefaultNaValue_instance = null;\n function DefaultNaValue_getInstance() {\n if (DefaultNaValue_instance === null) {\n new DefaultNaValue();\n }return DefaultNaValue_instance;\n }\n function DiscreteOnlyMapperProvider(naValue) {\n MapperProviderBase.call(this, naValue);\n }\n DiscreteOnlyMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n throw IllegalStateException_init('[' + toString(Kotlin.getKClassFromExpression(this).simpleName) + \"] Can't create mapper for continuous domain \" + domain);\n };\n DiscreteOnlyMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteOnlyMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function GuideBreak(domainValue, label) {\n this.domainValue = domainValue;\n this.label = label;\n }\n GuideBreak.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideBreak',\n interfaces: []\n };\n function GuideMapper() {\n }\n GuideMapper.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GuideMapper',\n interfaces: [Function]\n };\n function MapperProvider() {\n }\n MapperProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MapperProvider',\n interfaces: []\n };\n function ScaleProvider() {\n }\n ScaleProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ScaleProvider',\n interfaces: []\n };\n function ScaleProviderBuilder(aes) {\n this.aes_0 = aes;\n this._mapperProvider_0 = null;\n this.myName_0 = null;\n this.myBreaks_0 = null;\n this.myLabels_0 = null;\n this.myLabelFormat_0 = null;\n this.myMultiplicativeExpand_0 = null;\n this.myAdditiveExpand_0 = null;\n this.myLimits_0 = null;\n this.myContinuousTransform_0 = transform.Transforms.IDENTITY;\n this.myBreaksGenerator_0 = null;\n this.myDiscreteDomain_0 = false;\n this.myDiscreteDomainReverse_0 = false;\n }\n Object.defineProperty(ScaleProviderBuilder.prototype, 'mapperProvider', {\n configurable: true,\n get: function () {\n var tmp$;\n if (this._mapperProvider_0 == null) {\n this._mapperProvider_0 = DefaultMapperProvider_getInstance().get_31786j$(this.aes_0);\n }tmp$ = this._mapperProvider_0;\n if (tmp$ == null) {\n throw AssertionError_init('Set to null by another thread');\n }return tmp$;\n },\n set: function (p) {\n this._mapperProvider_0 = p;\n }\n });\n ScaleProviderBuilder.prototype.mapperProvider_dw300d$ = function (mapperProvider) {\n this.mapperProvider = mapperProvider;\n return this;\n };\n ScaleProviderBuilder.prototype.name_61zpoe$ = function (name) {\n this.myName_0 = name;\n return this;\n };\n ScaleProviderBuilder.prototype.breaks_pqjuzw$ = function (breaks) {\n this.myBreaks_0 = breaks;\n return this;\n };\n ScaleProviderBuilder.prototype.minorBreaks_NI_d3e2cz$ = function (minorBreaks) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.labels_mhpeer$ = function (labels) {\n this.myLabels_0 = ArrayList_init_0(labels);\n return this;\n };\n ScaleProviderBuilder.prototype.labelFormat_pdl1vj$ = function (format) {\n this.myLabelFormat_0 = format;\n return this;\n };\n ScaleProviderBuilder.prototype.multiplicativeExpand_14dthe$ = function (v) {\n this.myMultiplicativeExpand_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.additiveExpand_14dthe$ = function (v) {\n this.myAdditiveExpand_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.limits_9ma18$ = function (v) {\n this.myLimits_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.rescaler_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.oob_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n this.myContinuousTransform_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n this.myBreaksGenerator_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.guide_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.discreteDomain_6taknv$ = function (b) {\n this.myDiscreteDomain_0 = b;\n return this;\n };\n ScaleProviderBuilder.prototype.discreteDomainReverse_6taknv$ = function (b) {\n this.myDiscreteDomainReverse_0 = b;\n return this;\n };\n ScaleProviderBuilder.prototype.build = function () {\n return new ScaleProviderBuilder$MyScaleProvider(this);\n };\n function ScaleProviderBuilder$MyScaleProvider(b) {\n this.myName_0 = b.myName_0;\n var tmp$, tmp$_0, tmp$_1;\n this.myLabels_0 = (tmp$ = b.myLabels_0) != null ? ArrayList_init_0(tmp$) : null;\n this.myLabelFormat_0 = b.myLabelFormat_0;\n this.myMultiplicativeExpand_0 = b.myMultiplicativeExpand_0;\n this.myAdditiveExpand_0 = b.myAdditiveExpand_0;\n this.discreteDomainReverse_0 = b.myDiscreteDomainReverse_0;\n this.myBreaksGenerator_0 = b.myBreaksGenerator_0;\n this.myAes_0 = b.aes_0;\n this.discreteDomain_sylt8i$_0 = b.myDiscreteDomain_0;\n this.mapperProvider_yqrzmx$_0 = b.mapperProvider;\n this.breaks_h22v6v$_0 = (tmp$_0 = b.myBreaks_0) != null ? ArrayList_init_0(tmp$_0) : null;\n this.limits_hmyn8j$_0 = (tmp$_1 = b.myLimits_0) != null ? ArrayList_init_0(tmp$_1) : null;\n this.continuousTransform_hc6st8$_0 = b.myContinuousTransform_0;\n }\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'discreteDomain', {\n configurable: true,\n get: function () {\n return this.discreteDomain_sylt8i$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'mapperProvider', {\n configurable: true,\n get: function () {\n return this.mapperProvider_yqrzmx$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_h22v6v$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'limits', {\n configurable: true,\n get: function () {\n return this.limits_hmyn8j$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'continuousTransform', {\n configurable: true,\n get: function () {\n return this.continuousTransform_hc6st8$_0;\n }\n });\n ScaleProviderBuilder$MyScaleProvider.prototype.scaleName_0 = function (variable) {\n var tmp$;\n return (tmp$ = this.myName_0) != null ? tmp$ : variable.label;\n };\n ScaleProviderBuilder$MyScaleProvider.prototype.createScale_4d40sm$ = function (defaultName, discreteDomain) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var name = (tmp$ = this.myName_0) != null ? tmp$ : defaultName;\n var scale_0;\n var domainValues = filterNotNull(discreteDomain);\n if (discreteDomain.isEmpty()) {\n tmp$_0 = this.absentMapper_0(defaultName);\n } else {\n tmp$_0 = getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_11rb$(p1);\n }.bind(null, this.mapperProvider.createDiscreteMapper_7f6uoc$(domainValues)));\n }\n var mapper = tmp$_0;\n if (this.discreteDomainReverse_0) {\n domainValues = reversed_0(domainValues);\n }scale_0 = scale.Scales.discreteDomain_l9mre7$(name, domainValues, mapper);\n var tmp$_3;\n if ((tmp$_2 = (tmp$_1 = this.limits) != null ? filterNotNull(tmp$_1) : null) != null) {\n var block$result;\n if (this.discreteDomainReverse_0) {\n block$result = reversed_0(tmp$_2);\n } else {\n block$result = tmp$_2;\n }\n tmp$_3 = block$result;\n } else\n tmp$_3 = null;\n var discreteLimits = tmp$_3;\n if (discreteLimits != null) {\n scale_0 = scale_0.with().limits_pqjuzw$(discreteLimits).build();\n }return this.completeScale_0(scale_0);\n };\n function ScaleProviderBuilder$MyScaleProvider$createScale$lambda(closure$mapper) {\n return function (v) {\n return closure$mapper.apply_11rb$(v);\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.createScale_phlls$ = function (defaultName, continuousDomain) {\n var tmp$, tmp$_0, tmp$_1;\n var name = (tmp$ = this.myName_0) != null ? tmp$ : defaultName;\n var scale_0;\n var dataRange = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(continuousDomain);\n var lowerLimit = null;\n var upperLimit = null;\n if (this.limits != null) {\n var lower = true;\n tmp$_0 = this.limits.iterator();\n while (tmp$_0.hasNext()) {\n var limit = tmp$_0.next();\n if (Kotlin.isNumber(limit)) {\n var v = numberToDouble(limit);\n if (isFinite(v)) {\n if (lower) {\n lowerLimit = v;\n } else {\n upperLimit = v;\n }\n }}lower = false;\n }\n }var mapper = this.mapperProvider.createContinuousMapper_1g0x2p$(dataRange, lowerLimit, upperLimit, this.continuousTransform);\n var continuousRange = mapper.isContinuous || this.myAes_0.isNumeric;\n scale_0 = scale.Scales.continuousDomain_lo18em$(name, ScaleProviderBuilder$MyScaleProvider$createScale$lambda(mapper), continuousRange);\n if (Kotlin.isType(mapper, WithGuideBreaks)) {\n Kotlin.isType(tmp$_1 = mapper, WithGuideBreaks) ? tmp$_1 : throwCCE();\n scale_0 = scale_0.with().breaks_pqjuzw$(mapper.breaks).labelFormatter_h0j1qz$(mapper.formatter).build();\n }scale_0 = scale_0.with().continuousTransform_gxz7zd$(this.continuousTransform).build();\n if (this.myBreaksGenerator_0 != null) {\n scale_0 = scale_0.with().breaksGenerator_6q5k0b$(this.myBreaksGenerator_0).build();\n }if (this.limits != null) {\n var with_0 = scale_0.with();\n if (lowerLimit != null) {\n with_0.lowerLimit_14dthe$(lowerLimit);\n }if (upperLimit != null) {\n with_0.upperLimit_14dthe$(upperLimit);\n }scale_0 = with_0.build();\n }return this.completeScale_0(scale_0);\n };\n ScaleProviderBuilder$MyScaleProvider.prototype.completeScale_0 = function (scale) {\n var with_0 = scale.with();\n if (this.breaks != null) {\n with_0.breaks_pqjuzw$(this.breaks);\n }if (this.myLabels_0 != null) {\n with_0.labels_mhpeer$(this.myLabels_0);\n }if (this.myLabelFormat_0 != null) {\n with_0.labelFormatter_h0j1qz$(getCallableRef('format', function ($receiver, p1) {\n return $receiver.format_za3rmp$(p1);\n }.bind(null, StringFormat.Companion.create_w8bwfu$(this.myLabelFormat_0))));\n }if (this.myMultiplicativeExpand_0 != null) {\n with_0.multiplicativeExpand_14dthe$(this.myMultiplicativeExpand_0);\n }if (this.myAdditiveExpand_0 != null) {\n with_0.additiveExpand_14dthe$(this.myAdditiveExpand_0);\n }return with_0.build();\n };\n function ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda(closure$var) {\n return function (v) {\n throw IllegalStateException_init(\"Mapper for empty data series '\" + closure$var.name + \"' was invoked with arg \" + toString(v));\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.absentMapper_1 = function (var_0) {\n return ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda(var_0);\n };\n function ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda_0(closure$label) {\n return function (v) {\n throw IllegalStateException_init(\"Mapper for empty data series '\" + closure$label + \"' was invoked with arg \" + toString(v));\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.absentMapper_0 = function (label) {\n return ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda_0(label);\n };\n ScaleProviderBuilder$MyScaleProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyScaleProvider',\n interfaces: [ScaleProvider]\n };\n ScaleProviderBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ScaleProviderBuilder',\n interfaces: []\n };\n function ScaleProviderHelper() {\n ScaleProviderHelper_instance = this;\n }\n ScaleProviderHelper.prototype.getOrCreateDefault_w8zkza$ = function (aes, providers) {\n var tmp$, tmp$_0;\n if (Aes.Companion.isPositionalX_896ixz$(aes))\n tmp$ = Aes.Companion.X;\n else if (Aes.Companion.isPositionalY_896ixz$(aes))\n tmp$ = Aes.Companion.Y;\n else\n tmp$ = aes;\n var realAes = tmp$;\n return (tmp$_0 = providers.get_11rb$(realAes)) != null ? tmp$_0 : this.createDefault_31786j$(realAes);\n };\n ScaleProviderHelper.prototype.createDefault_31786j$ = function (aes) {\n return (new ScaleProviderBuilder(aes)).build();\n };\n ScaleProviderHelper.prototype.createDefault_1va84n$ = function (aes, name) {\n return (new ScaleProviderBuilder(aes)).name_61zpoe$(name).build();\n };\n ScaleProviderHelper.prototype.create_bqnakv$ = function (name, aes, mapperProvider) {\n return (new ScaleProviderBuilder(aes)).mapperProvider_dw300d$(mapperProvider).name_61zpoe$(name).build();\n };\n ScaleProviderHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleProviderHelper',\n interfaces: []\n };\n var ScaleProviderHelper_instance = null;\n function ScaleProviderHelper_getInstance() {\n if (ScaleProviderHelper_instance === null) {\n new ScaleProviderHelper();\n }return ScaleProviderHelper_instance;\n }\n function WithGuideBreaks() {\n }\n WithGuideBreaks.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WithGuideBreaks',\n interfaces: []\n };\n function ColorMapper() {\n ColorMapper_instance = this;\n this.NA_VALUE = Color.Companion.GRAY;\n this.DEF_GRADIENT_LOW = Color.Companion.parseHex_61zpoe$('#132B43');\n this.DEF_GRADIENT_HIGH = Color.Companion.parseHex_61zpoe$('#56B1F7');\n }\n ColorMapper.prototype.gradientDefault_4fzjta$ = function (domain) {\n return this.gradient_e4qimg$(domain, this.DEF_GRADIENT_LOW, this.DEF_GRADIENT_HIGH, this.NA_VALUE);\n };\n ColorMapper.prototype.gradient_e4qimg$ = function (domain, low, high, naColor) {\n return this.gradientHSV_kw8gff$(domain, values.Colors.hsvFromRgb_98b62m$(low), values.Colors.hsvFromRgb_98b62m$(high), true, naColor);\n };\n ColorMapper.prototype.gradientHSV_kw8gff$ = function (domain, lowHSV, highHSV, autoHueDirection, naColor) {\n return this.gradientHSV_cr3zp$(domain, new HSV(lowHSV[0], lowHSV[1], lowHSV[2]), new HSV(highHSV[0], highHSV[1], highHSV[2]), autoHueDirection, naColor);\n };\n function ColorMapper$gradientHSV$lambda(closure$domain, closure$naColor, closure$mapperH, closure$mapperS, closure$mapperV) {\n return function (input) {\n if (input == null || !closure$domain.contains_mef7kx$(input)) {\n return closure$naColor;\n } else {\n var hue = closure$mapperH(input) % 360;\n var H = hue >= 0 ? hue : 360 + hue;\n var S = closure$mapperS(input);\n var V = closure$mapperV(input);\n return values.Colors.rgbFromHsv_yvo9jy$(H, S, V);\n }\n };\n }\n ColorMapper.prototype.gradientHSV_cr3zp$ = function (domain, lowHSV, highHSV, autoHueDirection, naColor) {\n var lowHue = lowHSV.h;\n var highHue = highHSV.h;\n var lowS = lowHSV.s;\n var highS = highHSV.s;\n if (lowS < 1.0E-4) {\n lowHue = highHue;\n }if (highS < 1.0E-4) {\n highHue = lowHue;\n }if (autoHueDirection) {\n var x = highHue - lowHue;\n var dH = JsMath.abs(x);\n if (dH > 180) {\n if (highHue >= lowHue) {\n lowHue += 360.0;\n } else {\n highHue += 360.0;\n }\n }}var mapperH = scale.Mappers.linear_yl4mmw$(domain, lowHue, highHue, kotlin_js_internal_DoubleCompanionObject.NaN);\n var mapperS = scale.Mappers.linear_yl4mmw$(domain, lowS, highS, kotlin_js_internal_DoubleCompanionObject.NaN);\n var mapperV = scale.Mappers.linear_yl4mmw$(domain, lowHSV.v, highHSV.v, kotlin_js_internal_DoubleCompanionObject.NaN);\n return ColorMapper$gradientHSV$lambda(domain, naColor, mapperH, mapperS, mapperV);\n };\n ColorMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorMapper',\n interfaces: []\n };\n var ColorMapper_instance = null;\n function ColorMapper_getInstance() {\n if (ColorMapper_instance === null) {\n new ColorMapper();\n }return ColorMapper_instance;\n }\n function GuideMapperAdapter(mapper, isContinuous) {\n this.mapper_0 = mapper;\n this.isContinuous_zgpeec$_0 = isContinuous;\n }\n Object.defineProperty(GuideMapperAdapter.prototype, 'isContinuous', {\n get: function () {\n return this.isContinuous_zgpeec$_0;\n }\n });\n GuideMapperAdapter.prototype.apply_11rb$ = function (value) {\n return this.mapper_0(value);\n };\n GuideMapperAdapter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideMapperAdapter',\n interfaces: [GuideMapper]\n };\n function GuideMapperWithGuideBreaks(mapper, breaks, formatter) {\n this.mapper_0 = mapper;\n this.breaks_3tqv0$_0 = breaks;\n this.formatter_dkp6z6$_0 = formatter;\n this.isContinuous_jvxsgv$_0 = false;\n }\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'breaks', {\n get: function () {\n return this.breaks_3tqv0$_0;\n }\n });\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'formatter', {\n get: function () {\n return this.formatter_dkp6z6$_0;\n }\n });\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return this.isContinuous_jvxsgv$_0;\n }\n });\n GuideMapperWithGuideBreaks.prototype.apply_11rb$ = function (value) {\n return this.mapper_0(value);\n };\n GuideMapperWithGuideBreaks.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideMapperWithGuideBreaks',\n interfaces: [WithGuideBreaks, GuideMapper]\n };\n function GuideMappers() {\n GuideMappers_instance = this;\n this.IDENTITY = new GuideMapperAdapter(scale.Mappers.IDENTITY, false);\n this.UNDEFINED = new GuideMapperAdapter(scale.Mappers.undefined_287e2$(), false);\n }\n GuideMappers.prototype.discreteToDiscrete_udkttt$ = function (data, variable, outputValues, naValue) {\n var domainValues = data.distinctValues_8xm3sj$(variable);\n return this.discreteToDiscrete_pkbp8v$(domainValues, outputValues, naValue);\n };\n function GuideMappers$discreteToDiscrete$lambda(v) {\n return v.toString();\n }\n GuideMappers.prototype.discreteToDiscrete_pkbp8v$ = function (domainValues, outputValues, naValue) {\n var mapper = scale.Mappers.discrete_rath1t$(outputValues, naValue);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return new GuideMapperWithGuideBreaks(mapper, destination, GuideMappers$discreteToDiscrete$lambda);\n };\n GuideMappers.prototype.continuousToDiscrete_fooeq8$ = function (domain, outputValues, naValue) {\n var mapper = scale.Mappers.quantized_hd8s0$(domain, outputValues, naValue);\n return this.asNotContinuous_rjdepr$(mapper);\n };\n function GuideMappers$discreteToContinuous$lambda(v) {\n return v.toString();\n }\n GuideMappers.prototype.discreteToContinuous_83ntpg$ = function (domainValues, outputRange, naValue) {\n var mapper = scale.Mappers.discreteToContinuous_83ntpg$(domainValues, outputRange, naValue);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return new GuideMapperWithGuideBreaks(mapper, destination, GuideMappers$discreteToContinuous$lambda);\n };\n GuideMappers.prototype.continuousToContinuous_lww37m$ = function (domain, range, naValue) {\n return this.asContinuous_rjdepr$(scale.Mappers.linear_lww37m$(domain, range, naValue));\n };\n GuideMappers.prototype.asNotContinuous_rjdepr$ = function (mapper) {\n return new GuideMapperAdapter(mapper, false);\n };\n GuideMappers.prototype.asContinuous_rjdepr$ = function (mapper) {\n return new GuideMapperAdapter(mapper, true);\n };\n GuideMappers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GuideMappers',\n interfaces: []\n };\n var GuideMappers_instance = null;\n function GuideMappers_getInstance() {\n if (GuideMappers_instance === null) {\n new GuideMappers();\n }return GuideMappers_instance;\n }\n function LineTypeMapper() {\n LineTypeMapper_instance = this;\n this.NA_VALUE = NamedLineType.SOLID;\n }\n LineTypeMapper.prototype.allLineTypes = function () {\n return listOf_0([NamedLineType.SOLID, NamedLineType.DASHED, NamedLineType.DOTTED, NamedLineType.DOTDASH, NamedLineType.LONGDASH, NamedLineType.TWODASH]);\n };\n LineTypeMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LineTypeMapper',\n interfaces: []\n };\n var LineTypeMapper_instance = null;\n function LineTypeMapper_getInstance() {\n if (LineTypeMapper_instance === null) {\n new LineTypeMapper();\n }return LineTypeMapper_instance;\n }\n function ShapeMapper() {\n ShapeMapper_instance = this;\n this.NA_VALUE = point.TinyPointShape;\n }\n ShapeMapper.prototype.allShapes = function () {\n var bestSix = listOf_0([NamedShape.SOLID_CIRCLE, NamedShape.SOLID_TRIANGLE_UP, NamedShape.SOLID_SQUARE, NamedShape.STICK_PLUS, NamedShape.STICK_SQUARE_CROSS, NamedShape.STICK_STAR]);\n var theRest = LinkedHashSet_init_0(listOf_0(NamedShape$values().slice()));\n theRest.removeAll_brywnq$(bestSix);\n var shapes = ArrayList_init_0(bestSix);\n shapes.addAll_brywnq$(theRest);\n return shapes;\n };\n ShapeMapper.prototype.hollowShapes = function () {\n var tmp$;\n var bestThreeHollow = listOf_0([NamedShape.STICK_CIRCLE, NamedShape.STICK_TRIANGLE_UP, NamedShape.STICK_SQUARE]);\n var theRest = LinkedHashSet_init_0(listOf_0(NamedShape$values().slice()));\n theRest.removeAll_brywnq$(bestThreeHollow);\n var shapes = ArrayList_init_0(bestThreeHollow);\n tmp$ = theRest.iterator();\n while (tmp$.hasNext()) {\n var shape = tmp$.next();\n if (shape.isHollow) {\n shapes.add_11rb$(shape);\n }}\n return shapes;\n };\n ShapeMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ShapeMapper',\n interfaces: []\n };\n var ShapeMapper_instance = null;\n function ShapeMapper_getInstance() {\n if (ShapeMapper_instance === null) {\n new ShapeMapper();\n }return ShapeMapper_instance;\n }\n function AlphaMapperProvider(range, naValue) {\n AlphaMapperProvider$Companion_getInstance();\n LinearNormalizingMapperProvider.call(this, range, naValue);\n }\n function AlphaMapperProvider$Companion() {\n AlphaMapperProvider$Companion_instance = this;\n this.DEF_RANGE_0 = new ClosedRange(0.1, 1.0);\n this.DEFAULT = new AlphaMapperProvider(this.DEF_RANGE_0, DefaultNaValue_getInstance().get_31786j$(Aes.Companion.ALPHA));\n }\n AlphaMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AlphaMapperProvider$Companion_instance = null;\n function AlphaMapperProvider$Companion_getInstance() {\n if (AlphaMapperProvider$Companion_instance === null) {\n new AlphaMapperProvider$Companion();\n }return AlphaMapperProvider$Companion_instance;\n }\n AlphaMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AlphaMapperProvider',\n interfaces: [LinearNormalizingMapperProvider]\n };\n function ColorBrewerMapperProvider(paletteTypeName, paletteNameOrIndex, direction, naValue) {\n ColorBrewerMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n this.paletteTypeName_0 = paletteTypeName;\n this.paletteNameOrIndex_0 = paletteNameOrIndex;\n this.direction_0 = direction;\n var tmp$;\n if (!((tmp$ = this.paletteNameOrIndex_0 != null ? typeof this.paletteNameOrIndex_0 === 'string' || Kotlin.isNumber(this.paletteNameOrIndex_0) : null) != null ? tmp$ : true)) {\n var message = ColorBrewerMapperProvider_init$lambda(this)();\n throw IllegalArgumentException_init(message.toString());\n }if (Kotlin.isNumber(this.paletteNameOrIndex_0)) {\n if (!(this.paletteTypeName_0 != null)) {\n var message_0 = \"brewer palette type required: 'seq', 'div' or 'qual'.\";\n throw IllegalArgumentException_init(message_0.toString());\n }}}\n ColorBrewerMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var colorScheme = this.colorScheme_0(true, domainValues.size);\n var colors = this.colors_0(colorScheme, domainValues.size);\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, colors, this.naValue);\n };\n ColorBrewerMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var colorScheme = this.colorScheme_0(false);\n var colors = this.colors_0(colorScheme, colorScheme.maxColors);\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n return GuideMappers_getInstance().continuousToDiscrete_fooeq8$(domain_0, colors, this.naValue);\n };\n ColorBrewerMapperProvider.prototype.colors_0 = function (colorScheme, count) {\n var tmp$, tmp$_0, tmp$_1;\n var colors = color.PaletteUtil.schemeColors_7q5c77$(colorScheme, count);\n tmp$_0 = (tmp$ = this.direction_0 != null ? this.direction_0 < 0 : null) != null ? tmp$ : false;\n if (tmp$_0 === true)\n tmp$_1 = collect.Lists.reverse_bemo1h$(colors);\n else if (tmp$_0 === false)\n tmp$_1 = colors;\n else\n tmp$_1 = Kotlin.noWhenBranchMatched();\n return tmp$_1;\n };\n ColorBrewerMapperProvider.prototype.colorScheme_0 = function (discrete, colorCount) {\n if (colorCount === void 0)\n colorCount = null;\n var tmp$, tmp$_0;\n if (typeof this.paletteNameOrIndex_0 === 'string') {\n var palType = color.PaletteUtil.paletteTypeByPaletteName_61zpoe$(this.paletteNameOrIndex_0);\n if (!(palType != null)) {\n var message = ColorBrewerMapperProvider$Companion_getInstance().cantFindPaletteError_0(this.paletteNameOrIndex_0);\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = palType;\n } else if (this.paletteTypeName_0 != null)\n tmp$ = ColorBrewerMapperProvider$Companion_getInstance().paletteType_0(this.paletteTypeName_0);\n else if (discrete)\n tmp$ = ColorPalette$Type.QUALITATIVE;\n else\n tmp$ = ColorPalette$Type.SEQUENTIAL;\n var paletteType = tmp$;\n if (Kotlin.isNumber(this.paletteNameOrIndex_0))\n tmp$_0 = color.PaletteUtil.colorSchemeByIndex_vfydh1$(paletteType, numberToInt(this.paletteNameOrIndex_0));\n else if (typeof this.paletteNameOrIndex_0 === 'string')\n tmp$_0 = ColorBrewerMapperProvider$Companion_getInstance().colorSchemeByName_0(paletteType, this.paletteNameOrIndex_0);\n else if (paletteType === ColorPalette$Type.QUALITATIVE)\n tmp$_0 = colorCount != null && colorCount <= ColorPalette$Qualitative.Set2.maxColors ? ColorPalette$Qualitative.Set2 : ColorPalette$Qualitative.Set3;\n else\n tmp$_0 = color.PaletteUtil.colorSchemeByIndex_vfydh1$(paletteType, 0);\n return tmp$_0;\n };\n function ColorBrewerMapperProvider$Companion() {\n ColorBrewerMapperProvider$Companion_instance = this;\n }\n ColorBrewerMapperProvider$Companion.prototype.paletteType_0 = function (name) {\n var tmp$;\n if (name == null) {\n return ColorPalette$Type.SEQUENTIAL;\n }switch (name) {\n case 'seq':\n tmp$ = ColorPalette$Type.SEQUENTIAL;\n break;\n case 'div':\n tmp$ = ColorPalette$Type.DIVERGING;\n break;\n case 'qual':\n tmp$ = ColorPalette$Type.QUALITATIVE;\n break;\n default:throw IllegalArgumentException_init(\"Palette type expected one of 'seq' (sequential), 'div' (diverging) or 'qual' (qualitative) but was: '\" + toString(name) + \"'\");\n }\n return tmp$;\n };\n ColorBrewerMapperProvider$Companion.prototype.colorSchemeByName_0 = function (paletteType, paletteName) {\n var tmp$;\n try {\n switch (paletteType.name) {\n case 'SEQUENTIAL':\n tmp$ = ColorPalette$Sequential$valueOf(paletteName);\n break;\n case 'DIVERGING':\n tmp$ = ColorPalette$Diverging$valueOf(paletteName);\n break;\n case 'QUALITATIVE':\n tmp$ = ColorPalette$Qualitative$valueOf(paletteName);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n } catch (ignore) {\n if (Kotlin.isType(ignore, IllegalArgumentException)) {\n throw IllegalArgumentException_init(this.cantFindPaletteError_0(paletteName));\n } else\n throw ignore;\n }\n };\n ColorBrewerMapperProvider$Companion.prototype.cantFindPaletteError_0 = function (paletteName) {\n return trimMargin('\\n' + \" |Brewer palette '\" + paletteName + \"' was not found. \" + '\\n' + ' |Valid palette names are: ' + '\\n' + \" | Type 'seq' (sequential): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Sequential$values()) + ' ' + '\\n' + \" | Type 'div' (diverging): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Diverging$values()) + ' ' + '\\n' + \" | Type 'qual' (qualitative): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Qualitative$values()) + ' ' + '\\n' + ' ');\n };\n function ColorBrewerMapperProvider$Companion$names$lambda(it) {\n return \"'\" + it.name + \"'\";\n }\n ColorBrewerMapperProvider$Companion.prototype.names_0 = function (enums) {\n return joinToString_0(enums, ', ', void 0, void 0, void 0, void 0, ColorBrewerMapperProvider$Companion$names$lambda);\n };\n ColorBrewerMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBrewerMapperProvider$Companion_instance = null;\n function ColorBrewerMapperProvider$Companion_getInstance() {\n if (ColorBrewerMapperProvider$Companion_instance === null) {\n new ColorBrewerMapperProvider$Companion();\n }return ColorBrewerMapperProvider$Companion_instance;\n }\n function ColorBrewerMapperProvider_init$lambda(this$ColorBrewerMapperProvider) {\n return function () {\n return 'palette: expected a name or index but was: ' + toString(Kotlin.getKClassFromExpression(ensureNotNull(this$ColorBrewerMapperProvider.paletteNameOrIndex_0)).simpleName);\n };\n }\n ColorBrewerMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBrewerMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function ColorGradient2MapperProvider(low, mid, high, midpoint, naValue) {\n ColorGradient2MapperProvider$Companion_getInstance();\n ContinuousOnlyMapperProvider.call(this, naValue);\n this.myLow_0 = null;\n this.myMid_0 = null;\n this.myHigh_0 = null;\n this.myMidpoint_0 = null;\n this.myLow_0 = low != null ? low : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_LOW_0;\n this.myMid_0 = mid != null ? mid : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_MID_0;\n this.myHigh_0 = high != null ? high : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_HIGH_0;\n this.myMidpoint_0 = midpoint != null ? midpoint : 0.0;\n }\n function ColorGradient2MapperProvider$createContinuousMapper$getMapper(closure$rangeMap) {\n return function (v) {\n var tmp$;\n var f_ = null;\n if (data_0.SeriesUtil.isFinite_yrwdxb$(v)) {\n var f_span = kotlin_js_internal_DoubleCompanionObject.NaN;\n tmp$ = closure$rangeMap.keys.iterator();\n while (tmp$.hasNext()) {\n var range = tmp$.next();\n if (range.contains_mef7kx$(ensureNotNull(v))) {\n var span = range.upperEnd - range.lowerEnd;\n if (f_ == null || f_span === 0.0) {\n f_ = closure$rangeMap.get_11rb$(range);\n f_span = span;\n } else if (span < f_span && span > 0) {\n f_ = closure$rangeMap.get_11rb$(range);\n f_span = span;\n }}}\n }return f_;\n };\n }\n function ColorGradient2MapperProvider$createContinuousMapper$lambda(closure$getMapper, this$ColorGradient2MapperProvider) {\n return function (input) {\n var tmp$;\n var mapper = closure$getMapper(input);\n return (tmp$ = mapper != null ? mapper(input) : null) != null ? tmp$ : this$ColorGradient2MapperProvider.naValue;\n };\n }\n ColorGradient2MapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n var tmp$ = domain_0.lowerEnd;\n var a = ensureNotNull(this.myMidpoint_0);\n var b = domain_0.lowerEnd;\n var lowDomain = new ClosedRange(tmp$, JsMath.max(a, b));\n var a_0 = this.myMidpoint_0;\n var b_0 = domain_0.upperEnd;\n var highDomain = new ClosedRange(JsMath.min(a_0, b_0), domain_0.upperEnd);\n var lowMapper = ColorMapper_getInstance().gradient_e4qimg$(lowDomain, this.myLow_0, this.myMid_0, this.naValue);\n var highMapper = ColorMapper_getInstance().gradient_e4qimg$(highDomain, this.myMid_0, this.myHigh_0, this.naValue);\n var rangeMap = mapOf([to(lowDomain, lowMapper), to(highDomain, highMapper)]);\n var getMapper = ColorGradient2MapperProvider$createContinuousMapper$getMapper(rangeMap);\n var mapperFun = ColorGradient2MapperProvider$createContinuousMapper$lambda(getMapper, this);\n return GuideMappers_getInstance().asContinuous_rjdepr$(mapperFun);\n };\n function ColorGradient2MapperProvider$Companion() {\n ColorGradient2MapperProvider$Companion_instance = this;\n this.DEF_GRADIENT_LOW_0 = Color.Companion.parseHex_61zpoe$('#964540');\n this.DEF_GRADIENT_MID_0 = Color.Companion.WHITE;\n this.DEF_GRADIENT_HIGH_0 = Color.Companion.parseHex_61zpoe$('#3B3D96');\n }\n ColorGradient2MapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorGradient2MapperProvider$Companion_instance = null;\n function ColorGradient2MapperProvider$Companion_getInstance() {\n if (ColorGradient2MapperProvider$Companion_instance === null) {\n new ColorGradient2MapperProvider$Companion();\n }return ColorGradient2MapperProvider$Companion_instance;\n }\n ColorGradient2MapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorGradient2MapperProvider',\n interfaces: [ContinuousOnlyMapperProvider]\n };\n function ColorGradientMapperProvider(low, high, naValue) {\n ColorGradientMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n this.low_0 = low != null ? low : ColorMapper_getInstance().DEF_GRADIENT_LOW;\n this.high_0 = high != null ? high : ColorMapper_getInstance().DEF_GRADIENT_HIGH;\n }\n ColorGradientMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var domainValuesAsNumbers = scale.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n var mapperDomain = ensureNotNull(data_0.SeriesUtil.range_l63ks6$(domainValuesAsNumbers.values));\n var gradient = ColorMapper_getInstance().gradient_e4qimg$(mapperDomain, this.low_0, this.high_0, this.naValue);\n return GuideMappers_getInstance().asNotContinuous_rjdepr$(gradient);\n };\n ColorGradientMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n var gradient = ColorMapper_getInstance().gradient_e4qimg$(domain_0, this.low_0, this.high_0, this.naValue);\n return GuideMappers_getInstance().asContinuous_rjdepr$(gradient);\n };\n function ColorGradientMapperProvider$Companion() {\n ColorGradientMapperProvider$Companion_instance = this;\n this.DEFAULT = new ColorGradientMapperProvider(null, null, ColorMapper_getInstance().NA_VALUE);\n }\n ColorGradientMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorGradientMapperProvider$Companion_instance = null;\n function ColorGradientMapperProvider$Companion_getInstance() {\n if (ColorGradientMapperProvider$Companion_instance === null) {\n new ColorGradientMapperProvider$Companion();\n }return ColorGradientMapperProvider$Companion_instance;\n }\n ColorGradientMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorGradientMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function ColorHueMapperProvider(hueRange, chroma, luminance, startHue, direction, naValue) {\n ColorHueMapperProvider$Companion_getInstance();\n HSVColorMapperProvider.call(this, naValue);\n this.myFromHSV_0 = null;\n this.myToHSV_0 = null;\n this.myHSVIntervals_0 = null;\n var tmp$;\n var hueRange_0 = ColorHueMapperProvider$Companion_getInstance().normalizeHueRange_0(hueRange);\n var clockwise = direction == null || direction !== -1.0;\n var fromHue = clockwise ? hueRange_0.lowerEnd : hueRange_0.upperEnd;\n var toHue = clockwise ? hueRange_0.upperEnd : hueRange_0.lowerEnd;\n var startHue_0 = startHue != null ? startHue : ColorHueMapperProvider$Companion_getInstance().DEF_START_HUE_0;\n if (hueRange_0.contains_mef7kx$(startHue_0) && startHue_0 - hueRange_0.lowerEnd > 1 && hueRange_0.upperEnd - startHue_0 > 1) {\n tmp$ = listOf_0([to(startHue_0, toHue), to(fromHue, startHue_0)]);\n } else {\n tmp$ = listOf(to(fromHue, toHue));\n }\n var hueIntervals = tmp$;\n var saturation = (chroma != null ? chroma % 100 : ColorHueMapperProvider$Companion_getInstance().DEF_SATURATION_0) / 100;\n var value = (luminance != null ? luminance % 100 : ColorHueMapperProvider$Companion_getInstance().DEF_VALUE_0) / 100;\n var destination = ArrayList_init_1(collectionSizeOrDefault(hueIntervals, 10));\n var tmp$_0;\n tmp$_0 = hueIntervals.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(to(new HSV(item.first, saturation, value), new HSV(item.second, saturation, value)));\n }\n this.myHSVIntervals_0 = destination;\n this.myFromHSV_0 = new HSV(fromHue, saturation, value);\n this.myToHSV_0 = new HSV(toHue, saturation, value);\n }\n ColorHueMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.createDiscreteMapper_q8tf2k$(domainValues, this.myFromHSV_0, this.myToHSV_0);\n };\n ColorHueMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n return this.createContinuousMapper_ytjjc$(domain_0, this.myHSVIntervals_0);\n };\n function ColorHueMapperProvider$Companion() {\n ColorHueMapperProvider$Companion_instance = this;\n this.DEF_SATURATION_0 = 50.0;\n this.DEF_VALUE_0 = 90.0;\n this.DEF_START_HUE_0 = 0.0;\n this.DEF_HUE_RANGE_0 = new ClosedRange(15.0, 375.0);\n this.DEFAULT = new ColorHueMapperProvider(null, null, null, null, null, Color.Companion.GRAY);\n }\n ColorHueMapperProvider$Companion.prototype.normalizeHueRange_0 = function (hueRange) {\n var tmp$;\n if (hueRange == null || hueRange.size !== 2) {\n tmp$ = this.DEF_HUE_RANGE_0;\n } else {\n var a = hueRange.get_za3lpa$(0);\n var b = hueRange.get_za3lpa$(1);\n var tmp$_0 = JsMath.min(a, b);\n var a_0 = hueRange.get_za3lpa$(0);\n var b_0 = hueRange.get_za3lpa$(1);\n tmp$ = new ClosedRange(tmp$_0, JsMath.max(a_0, b_0));\n }\n return tmp$;\n };\n ColorHueMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorHueMapperProvider$Companion_instance = null;\n function ColorHueMapperProvider$Companion_getInstance() {\n if (ColorHueMapperProvider$Companion_instance === null) {\n new ColorHueMapperProvider$Companion();\n }return ColorHueMapperProvider$Companion_instance;\n }\n ColorHueMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorHueMapperProvider',\n interfaces: [HSVColorMapperProvider]\n };\n function DirectlyProportionalMapperProvider(max, naValue) {\n ContinuousOnlyMapperProvider.call(this, naValue);\n this.max_ks8piw$_0 = max;\n }\n DirectlyProportionalMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var dataMax = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans).upperEnd;\n return GuideMappers_getInstance().continuousToContinuous_lww37m$(new ClosedRange(0.0, dataMax), new ClosedRange(0.0, this.max_ks8piw$_0), this.naValue);\n };\n DirectlyProportionalMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DirectlyProportionalMapperProvider',\n interfaces: [ContinuousOnlyMapperProvider]\n };\n function GreyscaleLightnessMapperProvider(start, end, naValue) {\n GreyscaleLightnessMapperProvider$Companion_getInstance();\n HSVColorMapperProvider.call(this, naValue);\n this.myFromHSV_0 = null;\n this.myToHSV_0 = null;\n var value0 = start != null ? start : GreyscaleLightnessMapperProvider$Companion_getInstance().DEF_START_0;\n var value1 = end != null ? end : GreyscaleLightnessMapperProvider$Companion_getInstance().DEF_END_0;\n if (!rangeTo(0.0, 1.0).contains_mef7kx$(value0)) {\n var message = \"Value of 'start' must be in range: [0,1]: \" + toString(start);\n throw IllegalArgumentException_init(message.toString());\n }if (!rangeTo(0.0, 1.0).contains_mef7kx$(value1)) {\n var message_0 = \"Value of 'end' must be in range: [0,1]: \" + toString(end);\n throw IllegalArgumentException_init(message_0.toString());\n }this.myFromHSV_0 = new HSV(0.0, 0.0, value0);\n this.myToHSV_0 = new HSV(0.0, 0.0, value1);\n }\n GreyscaleLightnessMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.createDiscreteMapper_q8tf2k$(domainValues, this.myFromHSV_0, this.myToHSV_0);\n };\n GreyscaleLightnessMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n return this.createContinuousMapper_ytjjc$(domain_0, listOf(to(this.myFromHSV_0, this.myToHSV_0)));\n };\n function GreyscaleLightnessMapperProvider$Companion() {\n GreyscaleLightnessMapperProvider$Companion_instance = this;\n this.DEF_START_0 = 0.2;\n this.DEF_END_0 = 0.8;\n }\n GreyscaleLightnessMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GreyscaleLightnessMapperProvider$Companion_instance = null;\n function GreyscaleLightnessMapperProvider$Companion_getInstance() {\n if (GreyscaleLightnessMapperProvider$Companion_instance === null) {\n new GreyscaleLightnessMapperProvider$Companion();\n }return GreyscaleLightnessMapperProvider$Companion_instance;\n }\n GreyscaleLightnessMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GreyscaleLightnessMapperProvider',\n interfaces: [HSVColorMapperProvider]\n };\n function HSVColorMapperProvider(naValue) {\n HSVColorMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n }\n HSVColorMapperProvider.prototype.createDiscreteMapper_q8tf2k$ = function (domainValues, fromHSV, toHSV) {\n var domainValuesAsNumbers = scale.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n var mapperDomain = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(data_0.SeriesUtil.range_l63ks6$(domainValuesAsNumbers.values));\n var newFromHue = fromHSV.h;\n var newToHue = toHSV.h;\n if (domainValues.size > 1) {\n var x = toHSV.h % 360 - fromHSV.h % 360;\n var hueDiff = JsMath.abs(x);\n var step = (toHSV.h - fromHSV.h) / domainValues.size;\n if (hueDiff < JsMath.abs(step) / 2) {\n newFromHue = fromHSV.h + step / 2;\n newToHue = toHSV.h - step / 2;\n }}var gradient = ColorMapper_getInstance().gradientHSV_cr3zp$(mapperDomain, new HSV(newFromHue, fromHSV.s, fromHSV.v), new HSV(newToHue, toHSV.s, toHSV.v), false, this.naValue);\n return GuideMappers_getInstance().asNotContinuous_rjdepr$(gradient);\n };\n HSVColorMapperProvider.prototype.createContinuousMapper_ytjjc$ = function (domain, hsvIntervals) {\n var tmp$;\n switch (hsvIntervals.size) {\n case 0:\n throw IllegalArgumentException_init('Empty HSV intervals.');\n case 1:\n tmp$ = ColorMapper_getInstance().gradientHSV_cr3zp$(domain, hsvIntervals.get_za3lpa$(0).first, hsvIntervals.get_za3lpa$(0).second, false, this.naValue);\n break;\n default:tmp$ = HSVColorMapperProvider$Companion_getInstance().createCompositeColorMapper_0(domain, hsvIntervals, false, this.naValue);\n break;\n }\n var gradientMapper = tmp$;\n return GuideMappers_getInstance().asContinuous_rjdepr$(gradientMapper);\n };\n function HSVColorMapperProvider$Companion() {\n HSVColorMapperProvider$Companion_instance = this;\n }\n function HSVColorMapperProvider$Companion$createCompositeColorMapper$lambda(closure$naColor, closure$colorMappersPerSubDomain) {\n return function (v) {\n var tmp$, tmp$_0;\n if (v == null) {\n return closure$naColor;\n } else {\n var $receiver = closure$colorMappersPerSubDomain;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (element.first.contains_mef7kx$(v)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var mapper = (tmp$ = firstOrNull$result) != null ? tmp$.second : null;\n return (tmp$_0 = mapper != null ? mapper(v) : null) != null ? tmp$_0 : closure$naColor;\n }\n };\n }\n HSVColorMapperProvider$Companion.prototype.createCompositeColorMapper_0 = function (domain, hsvIntervals, autoHueDirection, naColor) {\n var colorMappersPerSubDomain = this.createColorMappersPerSubDomain_0(domain, hsvIntervals, autoHueDirection, naColor);\n return HSVColorMapperProvider$Companion$createCompositeColorMapper$lambda(naColor, colorMappersPerSubDomain);\n };\n HSVColorMapperProvider$Companion.prototype.createColorMappersPerSubDomain_0 = function (domain, hsvIntervals, autoHueDirection, naColor) {\n var subDomains = this.splitContinuousDomain_0(domain, hsvIntervals);\n var $receiver = zip(subDomains, hsvIntervals);\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var domain_0 = item.first;\n var hsvInterval = item.second;\n destination.add_11rb$(new Pair_0(domain_0, ColorMapper_getInstance().gradientHSV_cr3zp$(domain_0, hsvInterval.first, hsvInterval.second, autoHueDirection, naColor)));\n }\n return destination;\n };\n HSVColorMapperProvider$Companion.prototype.splitContinuousDomain_0 = function (domain, hsvIntervals) {\n var tmp$;\n var domainSize = domain.upperEnd - domain.lowerEnd;\n var destination = ArrayList_init_1(collectionSizeOrDefault(hsvIntervals, 10));\n var tmp$_0;\n tmp$_0 = hsvIntervals.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n var tmp$_1 = destination.add_11rb$;\n var x = item.first.h - item.second.h;\n tmp$_1.call(destination, JsMath.abs(x));\n }\n var hueIntervalSizeList = destination;\n var hueIntervalsTotalSize = sum(hueIntervalSizeList);\n var domainToHueIntevalRatio = domainSize / hueIntervalsTotalSize;\n var subDomains = ArrayList_init();\n var lowerEnd = domain.lowerEnd;\n tmp$ = hueIntervalSizeList.iterator();\n while (tmp$.hasNext()) {\n var hueIntervalSize = tmp$.next();\n var upperEnd = lowerEnd + hueIntervalSize * domainToHueIntevalRatio;\n subDomains.add_11rb$(new ClosedRange(lowerEnd, upperEnd));\n lowerEnd = upperEnd;\n }\n return subDomains;\n };\n HSVColorMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HSVColorMapperProvider$Companion_instance = null;\n function HSVColorMapperProvider$Companion_getInstance() {\n if (HSVColorMapperProvider$Companion_instance === null) {\n new HSVColorMapperProvider$Companion();\n }return HSVColorMapperProvider$Companion_instance;\n }\n HSVColorMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HSVColorMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function IdentityDiscreteMapperProvider(inputConverter, naValue) {\n DiscreteOnlyMapperProvider.call(this, naValue);\n this.inputConverter_lfub5e$_0 = inputConverter;\n }\n IdentityDiscreteMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var tmp$, tmp$_0;\n var outputValues = ArrayList_init();\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var inputValue = tmp$.next();\n if (inputValue == null) {\n outputValues.add_11rb$(this.naValue);\n } else {\n tmp$_0 = this.inputConverter_lfub5e$_0(inputValue);\n if (tmp$_0 == null) {\n throw IllegalStateException_init(\"Can't map input value \" + toString(inputValue) + ' to output type');\n }var outputValue = tmp$_0;\n outputValues.add_11rb$(outputValue);\n }\n }\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, outputValues, this.naValue);\n };\n IdentityDiscreteMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityDiscreteMapperProvider',\n interfaces: [DiscreteOnlyMapperProvider]\n };\n function IdentityMapperProvider(discreteMapperProvider, continuousMapper) {\n this.discreteMapperProvider_0 = discreteMapperProvider;\n this.continuousMapper_0 = continuousMapper;\n }\n IdentityMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.discreteMapperProvider_0.createDiscreteMapper_7f6uoc$(domainValues);\n };\n IdentityMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(this.continuousMapper_0);\n };\n IdentityMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityMapperProvider',\n interfaces: [MapperProvider]\n };\n function LinearNormalizingMapperProvider(outputRange, naValue) {\n MapperProviderBase.call(this, naValue);\n this.outputRange_73yg7w$_0 = outputRange;\n }\n LinearNormalizingMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().discreteToContinuous_83ntpg$(domainValues, this.outputRange_73yg7w$_0, this.naValue);\n };\n LinearNormalizingMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var dataRange = scale.MapperUtil.rangeWithLimitsAfterTransform_5yamkg$(domain, lowerLimit, upperLimit, trans);\n return GuideMappers_getInstance().continuousToContinuous_lww37m$(dataRange, this.outputRange_73yg7w$_0, this.naValue);\n };\n LinearNormalizingMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearNormalizingMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function MapperProviderBase(naValue) {\n this.naValue = naValue;\n }\n MapperProviderBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapperProviderBase',\n interfaces: [MapperProvider]\n };\n function SizeAreaMapperProvider(max, naValue) {\n SizeAreaMapperProvider$Companion_getInstance();\n DirectlyProportionalMapperProvider.call(this, max != null ? max : SizeAreaMapperProvider$Companion_getInstance().DEF_MAX, naValue);\n }\n function SizeAreaMapperProvider$Companion() {\n SizeAreaMapperProvider$Companion_instance = this;\n this.DEF_MAX = aes.AesScaling.sizeFromCircleDiameter_14dthe$(21.0);\n }\n SizeAreaMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SizeAreaMapperProvider$Companion_instance = null;\n function SizeAreaMapperProvider$Companion_getInstance() {\n if (SizeAreaMapperProvider$Companion_instance === null) {\n new SizeAreaMapperProvider$Companion();\n }return SizeAreaMapperProvider$Companion_instance;\n }\n SizeAreaMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SizeAreaMapperProvider',\n interfaces: [DirectlyProportionalMapperProvider]\n };\n function SizeMapperProvider(range, naValue) {\n SizeMapperProvider$Companion_getInstance();\n LinearNormalizingMapperProvider.call(this, range, naValue);\n }\n function SizeMapperProvider$Companion() {\n SizeMapperProvider$Companion_instance = this;\n this.DEF_RANGE_0 = new ClosedRange(aes.AesScaling.sizeFromCircleDiameter_14dthe$(3.0), aes.AesScaling.sizeFromCircleDiameter_14dthe$(21.0));\n this.DEFAULT = new SizeMapperProvider(this.DEF_RANGE_0, DefaultNaValue_getInstance().get_31786j$(Aes.Companion.SIZE));\n }\n SizeMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SizeMapperProvider$Companion_instance = null;\n function SizeMapperProvider$Companion_getInstance() {\n if (SizeMapperProvider$Companion_instance === null) {\n new SizeMapperProvider$Companion();\n }return SizeMapperProvider$Companion_instance;\n }\n SizeMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SizeMapperProvider',\n interfaces: [LinearNormalizingMapperProvider]\n };\n function AxisTheme() {\n }\n AxisTheme.prototype.tickLabelDistance = function () {\n var result = this.tickMarkPadding();\n if (this.showTickMarks()) {\n result += this.tickMarkLength();\n }return result;\n };\n AxisTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisTheme',\n interfaces: []\n };\n function DefaultAxisTheme() {\n }\n DefaultAxisTheme.prototype.showLine = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTickMarks = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTickLabels = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTitle = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTooltip = function () {\n return true;\n };\n DefaultAxisTheme.prototype.lineWidth = function () {\n return Defaults$Plot$Axis_getInstance().LINE_WIDTH;\n };\n DefaultAxisTheme.prototype.tickMarkWidth = function () {\n return Defaults$Plot$Axis_getInstance().TICK_LINE_WIDTH;\n };\n DefaultAxisTheme.prototype.tickMarkLength = function () {\n return 6.0;\n };\n DefaultAxisTheme.prototype.tickMarkPadding = function () {\n return 3.0;\n };\n DefaultAxisTheme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultAxisTheme',\n interfaces: [AxisTheme]\n };\n function DefaultTheme() {\n DefaultTheme$Companion_getInstance();\n }\n DefaultTheme.prototype.axisX = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_0;\n };\n DefaultTheme.prototype.axisY = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_0;\n };\n DefaultTheme.prototype.legend = function () {\n return DefaultTheme$Companion_getInstance().LEGEND_THEME_0;\n };\n DefaultTheme.prototype.facets = function () {\n return DefaultTheme$Companion_getInstance().FACETS_THEME_0;\n };\n DefaultTheme.prototype.plot = function () {\n return DefaultTheme$Companion_getInstance().PLOT_THEME_0;\n };\n function DefaultTheme$multiTile$ObjectLiteral() {\n DefaultTheme.call(this);\n }\n DefaultTheme$multiTile$ObjectLiteral.prototype.axisX = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.prototype.axisY = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.prototype.plot = function () {\n return DefaultTheme$Companion_getInstance().PLOT_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DefaultTheme]\n };\n DefaultTheme.prototype.multiTile = function () {\n return new DefaultTheme$multiTile$ObjectLiteral();\n };\n function DefaultTheme$Companion() {\n DefaultTheme$Companion_instance = this;\n this.AXIS_THEME_0 = new DefaultAxisTheme();\n this.AXIS_THEME_MULTI_TILE_0 = new DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral();\n this.LEGEND_THEME_0 = new DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral();\n this.FACETS_THEME_0 = new DefaultTheme$Companion$FACETS_THEME$ObjectLiteral();\n this.PLOT_THEME_0 = new DefaultTheme$Companion$PLOT_THEME$ObjectLiteral();\n this.PLOT_THEME_MULTI_TILE_0 = new DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral();\n }\n function DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral() {\n DefaultAxisTheme.call(this);\n }\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype.showLine = function () {\n return false;\n };\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DefaultAxisTheme]\n };\n function DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.keySize = function () {\n return 23.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.margin = function () {\n return 5.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.padding = function () {\n return 5.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.position = function () {\n return LegendPosition$Companion_getInstance().RIGHT;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.justification = function () {\n return LegendJustification$Companion_getInstance().CENTER;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.direction = function () {\n return LegendDirection$AUTO_getInstance();\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.backgroundFill = function () {\n return Color.Companion.WHITE;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendTheme]\n };\n function DefaultTheme$Companion$FACETS_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$FACETS_THEME$ObjectLiteral.prototype.labelBackground = function () {\n return values.Colors.lighter_o14uds$(Color.Companion.VERY_LIGHT_GRAY, 0.9);\n };\n DefaultTheme$Companion$FACETS_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [FacetsTheme]\n };\n function DefaultTheme$Companion$PLOT_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.prototype.showInnerFrame = function () {\n return false;\n };\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.prototype.innerFrameColor = function () {\n throw IllegalStateException_init(\"The `innerFrameColor()` method shouldn't be used.\");\n };\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PlotTheme]\n };\n function DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral() {\n }\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.prototype.showInnerFrame = function () {\n return true;\n };\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.prototype.innerFrameColor = function () {\n return values.Colors.lighter_o14uds$(Color.Companion.VERY_LIGHT_GRAY, 0.9);\n };\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PlotTheme]\n };\n DefaultTheme$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DefaultTheme$Companion_instance = null;\n function DefaultTheme$Companion_getInstance() {\n if (DefaultTheme$Companion_instance === null) {\n new DefaultTheme$Companion();\n }return DefaultTheme$Companion_instance;\n }\n DefaultTheme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultTheme',\n interfaces: [Theme]\n };\n function FacetsTheme() {\n }\n FacetsTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'FacetsTheme',\n interfaces: []\n };\n function LegendTheme() {\n }\n LegendTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LegendTheme',\n interfaces: []\n };\n function PlotTheme() {\n }\n PlotTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PlotTheme',\n interfaces: []\n };\n function Theme() {\n }\n Theme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Theme',\n interfaces: []\n };\n function ConstantValue(value, format) {\n if (format === void 0)\n format = null;\n this.value_0 = value;\n this.format_0 = format;\n var tmp$;\n if (this.format_0 != null) {\n tmp$ = StringFormat.Companion.create_w8bwfu$(this.format_0).format_za3rmp$(this.value_0);\n } else {\n tmp$ = this.value_0.toString();\n }\n this.myDataValue_0 = tmp$;\n this.isOutlier_efnf0i$_0 = false;\n this.isAxis_i12u4n$_0 = false;\n }\n Object.defineProperty(ConstantValue.prototype, 'isOutlier', {\n configurable: true,\n get: function () {\n return this.isOutlier_efnf0i$_0;\n }\n });\n Object.defineProperty(ConstantValue.prototype, 'isAxis', {\n configurable: true,\n get: function () {\n return this.isAxis_i12u4n$_0;\n }\n });\n ConstantValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n };\n ConstantValue.prototype.getDataPoint_za3lpa$ = function (index) {\n return new TooltipLineSpec$DataPoint('', this.myDataValue_0, null, false, false);\n };\n ConstantValue.prototype.copy = function () {\n return new ConstantValue(this.value_0, this.format_0);\n };\n ConstantValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ConstantValue',\n interfaces: [ValueSource]\n };\n function DataFrameValue(name, format) {\n if (format === void 0)\n format = null;\n this.name_0 = name;\n this.format_0 = format;\n this.myDataFrame_v9hm26$_0 = this.myDataFrame_v9hm26$_0;\n this.myVariable_u4q8p$_0 = this.myVariable_u4q8p$_0;\n this.myFormatter_0 = this.format_0 != null ? StringFormat.Companion.forOneArg_86f9bg$(this.format_0, void 0, this.name_0) : null;\n this.isOutlier_h13ss7$_0 = false;\n this.isAxis_5xgnmk$_0 = false;\n }\n Object.defineProperty(DataFrameValue.prototype, 'myDataFrame_0', {\n configurable: true,\n get: function () {\n if (this.myDataFrame_v9hm26$_0 == null)\n return throwUPAE('myDataFrame');\n return this.myDataFrame_v9hm26$_0;\n },\n set: function (myDataFrame) {\n this.myDataFrame_v9hm26$_0 = myDataFrame;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'myVariable_0', {\n configurable: true,\n get: function () {\n if (this.myVariable_u4q8p$_0 == null)\n return throwUPAE('myVariable');\n return this.myVariable_u4q8p$_0;\n },\n set: function (myVariable) {\n this.myVariable_u4q8p$_0 = myVariable;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'isOutlier', {\n configurable: true,\n get: function () {\n return this.isOutlier_h13ss7$_0;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'isAxis', {\n configurable: true,\n get: function () {\n return this.isAxis_5xgnmk$_0;\n }\n });\n DataFrameValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n if (!(this.myDataFrame_v9hm26$_0 == null)) {\n var message = 'Data context can be initialized only once';\n throw IllegalArgumentException_init(message.toString());\n }this.myDataFrame_0 = dataContext.dataFrame;\n this.myVariable_0 = data.DataFrameUtil.findVariableOrFail_vede35$(this.myDataFrame_0, this.name_0);\n };\n DataFrameValue.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$, tmp$_0, tmp$_1;\n tmp$ = this.myDataFrame_0.get_8xm3sj$(this.myVariable_0).get_za3lpa$(index);\n if (tmp$ == null) {\n return null;\n }var originalValue = tmp$;\n return new TooltipLineSpec$DataPoint(this.name_0, (tmp$_1 = (tmp$_0 = this.myFormatter_0) != null ? tmp$_0.format_za3rmp$(originalValue) : null) != null ? tmp$_1 : originalValue.toString(), null, false, false);\n };\n DataFrameValue.prototype.copy = function () {\n return new DataFrameValue(this.name_0, this.format_0);\n };\n DataFrameValue.prototype.getVariableName = function () {\n return this.name_0;\n };\n DataFrameValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataFrameValue',\n interfaces: [ValueSource]\n };\n function MappingValue(aes, isOutlier, isAxis, format) {\n if (isOutlier === void 0)\n isOutlier = false;\n if (isAxis === void 0)\n isAxis = false;\n if (format === void 0)\n format = null;\n this.aes = aes;\n this.isOutlier_cyn2n6$_0 = isOutlier;\n this.isAxis_ohfp7r$_0 = isAxis;\n this.format_0 = format;\n this.myDataAccess_biypgq$_0 = this.myDataAccess_biypgq$_0;\n this.myDataLabel_0 = null;\n this.myFormatter_0 = this.format_0 != null ? StringFormat.Companion.forOneArg_86f9bg$(this.format_0, void 0, this.aes.name) : null;\n }\n Object.defineProperty(MappingValue.prototype, 'isOutlier', {\n get: function () {\n return this.isOutlier_cyn2n6$_0;\n }\n });\n Object.defineProperty(MappingValue.prototype, 'isAxis', {\n get: function () {\n return this.isAxis_ohfp7r$_0;\n }\n });\n Object.defineProperty(MappingValue.prototype, 'myDataAccess_0', {\n configurable: true,\n get: function () {\n if (this.myDataAccess_biypgq$_0 == null)\n return throwUPAE('myDataAccess');\n return this.myDataAccess_biypgq$_0;\n },\n set: function (myDataAccess) {\n this.myDataAccess_biypgq$_0 = myDataAccess;\n }\n });\n MappingValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n var tmp$;\n if (!(this.myDataAccess_biypgq$_0 == null)) {\n var message = 'Data context can be initialized only once';\n throw IllegalArgumentException_init(message.toString());\n }this.myDataAccess_0 = dataContext.mappedDataAccess;\n if (!this.myDataAccess_0.isMapped_896ixz$(this.aes)) {\n var message_0 = this.aes.toString() + ' have to be mapped';\n throw IllegalArgumentException_init(message_0.toString());\n }var $receiver = listOf_0([Aes.Companion.X, Aes.Companion.Y]);\n var predicate = getCallableRef('isMapped', function ($receiver, p1) {\n return $receiver.isMapped_896ixz$(p1);\n }.bind(null, this.myDataAccess_0));\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (predicate(element))\n destination.add_11rb$(element);\n }\n var transform = getCallableRef('getMappedDataLabel', function ($receiver, p1) {\n return $receiver.getMappedDataLabel_896ixz$(p1);\n }.bind(null, this.myDataAccess_0));\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(transform(item));\n }\n var axisLabels = destination_0;\n var dataLabel = this.myDataAccess_0.getMappedDataLabel_896ixz$(this.aes);\n if (this.isAxis)\n tmp$ = null;\n else {\n if (dataLabel.length === 0)\n tmp$ = '';\n else if (axisLabels.contains_11rb$(dataLabel))\n tmp$ = '';\n else\n tmp$ = dataLabel;\n }\n this.myDataLabel_0 = tmp$;\n };\n MappingValue.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$, tmp$_0, tmp$_1;\n var originalValue = this.myDataAccess_0.getOriginalValue_pkitv1$(this.aes, index);\n var tmp$_2;\n if (originalValue != null) {\n var tmp$_3;\n tmp$_2 = (tmp$_3 = this.myFormatter_0) != null ? tmp$_3.format_za3rmp$(originalValue) : null;\n } else\n tmp$_2 = null;\n var formattedValue = (tmp$ = tmp$_2) != null ? tmp$ : this.myDataAccess_0.getMappedData_pkitv1$(this.aes, index).value;\n var tmp$_4 = this.isOutlier;\n if (tmp$_4) {\n var $receiver = this.myDataLabel_0;\n tmp$_4 = !($receiver == null || $receiver.length === 0);\n }if (tmp$_4 && !equals((tmp$_0 = this.myFormatter_0) != null ? tmp$_0.formatType : null, StringFormat$FormatType.STRING_FORMAT)) {\n tmp$_1 = toString(this.myDataLabel_0) + ': ' + formattedValue;\n } else {\n tmp$_1 = formattedValue;\n }\n var value = tmp$_1;\n return new TooltipLineSpec$DataPoint(this.isOutlier ? null : this.myDataLabel_0, value, this.aes, this.isAxis, this.isOutlier);\n };\n MappingValue.prototype.copy = function () {\n return new MappingValue(this.aes, this.isOutlier, this.isAxis, this.format_0);\n };\n MappingValue.prototype.toOutlier = function () {\n return new MappingValue(this.aes, true, this.isAxis, this.format_0);\n };\n MappingValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappingValue',\n interfaces: [ValueSource]\n };\n function TooltipLine(label, pattern, fields) {\n TooltipLine$Companion_getInstance();\n this.label_0 = label;\n this.pattern_0 = pattern;\n this.fields = fields;\n this.myLineFormatter_0 = StringFormat.Companion.forNArgs_8vq31k$(this.pattern_0, StringFormat$FormatType.STRING_FORMAT, this.fields.size, 'fields');\n }\n TooltipLine.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n var tmp$;\n tmp$ = this.fields.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n element.initDataContext_rxi9tf$(dataContext);\n }\n };\n function TooltipLine$getDataPoint$lambda(it) {\n var tmp$;\n return (tmp$ = it.label) != null ? tmp$ : '';\n }\n TooltipLine.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$;\n var $receiver = this.fields;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n var tmp$_1 = destination.add_11rb$;\n var tmp$_2;\n tmp$_2 = item.getDataPoint_za3lpa$(index);\n if (tmp$_2 == null) {\n return null;\n }tmp$_1.call(destination, tmp$_2);\n }\n var dataValues = destination;\n if (dataValues.size === 1) {\n var dataValue = single(dataValues);\n tmp$ = new TooltipLineSpec$DataPoint(this.chooseLabel_0(dataValue.label), this.myLineFormatter_0.format_za3rmp$(dataValue.value), dataValue.aes, dataValue.isAxis, dataValue.isOutlier);\n } else {\n var tmp$_3 = this.chooseLabel_0(joinToString(dataValues, ', ', void 0, void 0, void 0, void 0, TooltipLine$getDataPoint$lambda));\n var tmp$_4 = this.myLineFormatter_0;\n var destination_0 = ArrayList_init_1(collectionSizeOrDefault(dataValues, 10));\n var tmp$_5;\n tmp$_5 = dataValues.iterator();\n while (tmp$_5.hasNext()) {\n var item_0 = tmp$_5.next();\n destination_0.add_11rb$(item_0.value);\n }\n tmp$ = new TooltipLineSpec$DataPoint(tmp$_3, tmp$_4.format_pqjuzw$(destination_0), null, false, false);\n }\n return tmp$;\n };\n TooltipLine.prototype.chooseLabel_0 = function (dataLabel) {\n var tmp$;\n if (equals(this.label_0, TooltipLine$Companion_getInstance().DEFAULT_LABEL_SPECIFIER_0))\n tmp$ = dataLabel;\n else\n tmp$ = this.label_0;\n return tmp$;\n };\n function TooltipLine$Companion() {\n TooltipLine$Companion_instance = this;\n this.DEFAULT_LABEL_SPECIFIER_0 = '@';\n }\n TooltipLine$Companion.prototype.defaultLineForValueSource_u47np3$ = function (valueSource) {\n return new TooltipLine(this.DEFAULT_LABEL_SPECIFIER_0, StringFormat.Companion.valueInLinePattern(), listOf(valueSource));\n };\n TooltipLine$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipLine$Companion_instance = null;\n function TooltipLine$Companion_getInstance() {\n if (TooltipLine$Companion_instance === null) {\n new TooltipLine$Companion();\n }return TooltipLine$Companion_instance;\n }\n TooltipLine.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipLine',\n interfaces: [TooltipLineSpec]\n };\n function TooltipLine_init(other, $this) {\n $this = $this || Object.create(TooltipLine.prototype);\n var tmp$ = other.label_0;\n var tmp$_0 = other.pattern_0;\n var $receiver = other.fields;\n var destination = ArrayList_init_1(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination.add_11rb$(item.copy());\n }\n TooltipLine.call($this, tmp$, tmp$_0, destination);\n return $this;\n }\n function TooltipSpecification(valueSources, tooltipLinePatterns, tooltipProperties) {\n TooltipSpecification$Companion_getInstance();\n this.valueSources = valueSources;\n this.tooltipLinePatterns = tooltipLinePatterns;\n this.tooltipProperties = tooltipProperties;\n }\n function TooltipSpecification$TooltipProperties(anchor, minWidth, color) {\n TooltipSpecification$TooltipProperties$Companion_getInstance();\n this.anchor = anchor;\n this.minWidth = minWidth;\n this.color = color;\n }\n function TooltipSpecification$TooltipProperties$Companion() {\n TooltipSpecification$TooltipProperties$Companion_instance = this;\n this.NONE = new TooltipSpecification$TooltipProperties(null, null, null);\n }\n TooltipSpecification$TooltipProperties$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpecification$TooltipProperties$Companion_instance = null;\n function TooltipSpecification$TooltipProperties$Companion_getInstance() {\n if (TooltipSpecification$TooltipProperties$Companion_instance === null) {\n new TooltipSpecification$TooltipProperties$Companion();\n }return TooltipSpecification$TooltipProperties$Companion_instance;\n }\n TooltipSpecification$TooltipProperties.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipProperties',\n interfaces: []\n };\n function TooltipSpecification$Companion() {\n TooltipSpecification$Companion_instance = this;\n }\n TooltipSpecification$Companion.prototype.withoutTooltip = function () {\n return new TooltipSpecification(emptyList(), emptyList(), TooltipSpecification$TooltipProperties$Companion_getInstance().NONE);\n };\n TooltipSpecification$Companion.prototype.defaultTooltip = function () {\n return new TooltipSpecification(emptyList(), null, TooltipSpecification$TooltipProperties$Companion_getInstance().NONE);\n };\n TooltipSpecification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpecification$Companion_instance = null;\n function TooltipSpecification$Companion_getInstance() {\n if (TooltipSpecification$Companion_instance === null) {\n new TooltipSpecification$Companion();\n }return TooltipSpecification$Companion_instance;\n }\n TooltipSpecification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpecification',\n interfaces: []\n };\n function ValueSource() {\n }\n ValueSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ValueSource',\n interfaces: []\n };\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n Object.defineProperty(package$plot, 'FeatureSwitch', {\n get: FeatureSwitch_getInstance\n });\n var package$builder = package$plot.builder || (package$plot.builder = {});\n Object.defineProperty(package$builder, 'AxisUtil', {\n get: AxisUtil_getInstance\n });\n package$builder.BogusCoordinateSystem = BogusCoordinateSystem;\n package$builder.BogusScale = BogusScale;\n package$builder.GeomLayer = GeomLayer;\n Object.defineProperty(package$builder, 'GeomLayerListUtil', {\n get: GeomLayerListUtil_getInstance\n });\n LayerRendererUtil.prototype.LayerRendererData = LayerRendererUtil$LayerRendererData;\n Object.defineProperty(package$builder, 'LayerRendererUtil', {\n get: LayerRendererUtil_getInstance\n });\n Object.defineProperty(Plot, 'Companion', {\n get: Plot$Companion_getInstance\n });\n package$builder.Plot = Plot;\n package$builder.PlotBuilder = PlotBuilder;\n Object.defineProperty(PlotContainerPortable, 'Companion', {\n get: PlotContainerPortable$Companion_getInstance\n });\n package$builder.PlotContainerPortable = PlotContainerPortable;\n package$builder.PlotTile = PlotTile;\n package$builder.PlotTooltipHelper = PlotTooltipHelper;\n Object.defineProperty(package$builder, 'PlotUtil', {\n get: PlotUtil_getInstance\n });\n package$builder.PosProviderContext = PosProviderContext;\n package$builder.SvgLayerRenderer = SvgLayerRenderer;\n package$builder.VarBinding = VarBinding;\n Object.defineProperty(ColorBarAssembler, 'Companion', {\n get: ColorBarAssembler$Companion_getInstance\n });\n var package$assemble = package$builder.assemble || (package$builder.assemble = {});\n package$assemble.ColorBarAssembler = ColorBarAssembler;\n package$assemble.ColorBarOptions = ColorBarOptions;\n package$assemble.GeomContextBuilder_init = GeomContextBuilder_init;\n package$assemble.GeomContextBuilder = GeomContextBuilder;\n Object.defineProperty(GeomLayerBuilder, 'Companion', {\n get: GeomLayerBuilder$Companion_getInstance\n });\n package$assemble.GeomLayerBuilder = GeomLayerBuilder;\n Object.defineProperty(GuideOptions, 'Companion', {\n get: GuideOptions$Companion_getInstance\n });\n package$assemble.GuideOptions = GuideOptions;\n ImmutableGeomContext.Builder = ImmutableGeomContext$Builder;\n package$assemble.ImmutableGeomContext = ImmutableGeomContext;\n Object.defineProperty(LegendAssembler, 'Companion', {\n get: LegendAssembler$Companion_getInstance\n });\n package$assemble.LegendAssembler = LegendAssembler;\n Object.defineProperty(package$assemble, 'LegendAssemblerUtil', {\n get: LegendAssemblerUtil_getInstance\n });\n Object.defineProperty(LegendOptions, 'Companion', {\n get: LegendOptions$Companion_getInstance\n });\n package$assemble.LegendOptions = LegendOptions;\n Object.defineProperty(PlotAssembler, 'Companion', {\n get: PlotAssembler$Companion_getInstance\n });\n package$assemble.PlotAssembler = PlotAssembler;\n Object.defineProperty(package$assemble, 'PlotAssemblerUtil', {\n get: PlotAssemblerUtil_getInstance\n });\n Object.defineProperty(PlotFacets, 'Companion', {\n get: PlotFacets$Companion_getInstance\n });\n PlotFacets.FacetTileInfo = PlotFacets$FacetTileInfo;\n package$assemble.PlotFacets = PlotFacets;\n Object.defineProperty(package$assemble, 'PlotGuidesAssemblerUtil', {\n get: PlotGuidesAssemblerUtil_getInstance\n });\n Object.defineProperty(PosProvider, 'Companion', {\n get: PosProvider$Companion_getInstance\n });\n package$assemble.PosProvider = PosProvider;\n package$assemble.StitchedPlotLayers = StitchedPlotLayers;\n Object.defineProperty(TypedScaleMap, 'Companion', {\n get: TypedScaleMap$Companion_getInstance\n });\n package$assemble.TypedScaleMap = TypedScaleMap;\n package$assemble.TypedScaleProviderMap = TypedScaleProviderMap;\n var package$facet = package$assemble.facet || (package$assemble.facet = {});\n package$facet.FacetGrid = FacetGrid;\n Object.defineProperty(FacetWrap$Direction, 'H', {\n get: FacetWrap$Direction$H_getInstance\n });\n Object.defineProperty(FacetWrap$Direction, 'V', {\n get: FacetWrap$Direction$V_getInstance\n });\n FacetWrap.Direction = FacetWrap$Direction;\n Object.defineProperty(FacetWrap, 'Companion', {\n get: FacetWrap$Companion_getInstance\n });\n package$facet.FacetWrap = FacetWrap;\n var package$geom = package$assemble.geom || (package$assemble.geom = {});\n Object.defineProperty(package$geom, 'DefaultSampling', {\n get: DefaultSampling_getInstance\n });\n Object.defineProperty(GeomProvider, 'Companion', {\n get: GeomProvider$Companion_getInstance\n });\n package$geom.GeomProvider = GeomProvider;\n package$geom.PointDataAccess = PointDataAccess;\n var package$coord = package$builder.coord || (package$builder.coord = {});\n package$coord.CartesianCoordProvider = CartesianCoordProvider;\n package$coord.CoordProvider = CoordProvider;\n Object.defineProperty(CoordProviderBase, 'Companion', {\n get: CoordProviderBase$Companion_getInstance\n });\n package$coord.CoordProviderBase = CoordProviderBase;\n Object.defineProperty(package$coord, 'CoordProviders', {\n get: CoordProviders_getInstance\n });\n package$coord.FixedRatioCoordProvider = FixedRatioCoordProvider;\n Object.defineProperty(ProjectionCoordProvider, 'Companion', {\n get: ProjectionCoordProvider$Companion_getInstance\n });\n package$coord.ProjectionCoordProvider = ProjectionCoordProvider;\n var package$map = package$coord.map || (package$coord.map = {});\n package$map.MercatorProjectionX = MercatorProjectionX;\n package$map.MercatorProjectionY = MercatorProjectionY;\n DataProcessing.prototype.DataAndGroupingContext = DataProcessing$DataAndGroupingContext;\n var package$data = package$builder.data || (package$builder.data = {});\n Object.defineProperty(package$data, 'DataProcessing', {\n get: DataProcessing_getInstance\n });\n GroupMerger.Group = GroupMerger$Group;\n package$data.GroupMerger = GroupMerger;\n Object.defineProperty(package$data, 'GroupUtil', {\n get: GroupUtil_getInstance\n });\n Object.defineProperty(GroupingContext, 'Companion', {\n get: GroupingContext$Companion_getInstance\n });\n package$data.GroupingContext = GroupingContext;\n Object.defineProperty(OrderOptionUtil$OrderOption, 'Companion', {\n get: OrderOptionUtil$OrderOption$Companion_getInstance\n });\n OrderOptionUtil.prototype.OrderOption = OrderOptionUtil$OrderOption;\n Object.defineProperty(package$data, 'OrderOptionUtil', {\n get: OrderOptionUtil_getInstance\n });\n var package$event = package$builder.event || (package$builder.event = {});\n package$event.MouseEventPeer = MouseEventPeer;\n var package$guide = package$builder.guide || (package$builder.guide = {});\n package$guide.AxisComponent = AxisComponent;\n package$guide.ColorBarComponent = ColorBarComponent;\n ColorBarComponentLayout.BreakInfo = ColorBarComponentLayout$BreakInfo;\n Object.defineProperty(ColorBarComponentLayout, 'Companion', {\n get: ColorBarComponentLayout$Companion_getInstance\n });\n package$guide.ColorBarComponentLayout = ColorBarComponentLayout;\n Object.defineProperty(ColorBarComponentSpec, 'Companion', {\n get: ColorBarComponentSpec$Companion_getInstance\n });\n package$guide.ColorBarComponentSpec = ColorBarComponentSpec;\n Object.defineProperty(LegendArrangement, 'HORIZONTAL', {\n get: LegendArrangement$HORIZONTAL_getInstance\n });\n Object.defineProperty(LegendArrangement, 'VERTICAL', {\n get: LegendArrangement$VERTICAL_getInstance\n });\n package$guide.LegendArrangement = LegendArrangement;\n Object.defineProperty(LegendBox, 'Companion', {\n get: LegendBox$Companion_getInstance\n });\n package$guide.LegendBox = LegendBox;\n Object.defineProperty(LegendBoxLayout, 'Companion', {\n get: LegendBoxLayout$Companion_getInstance\n });\n package$guide.LegendBoxLayout = LegendBoxLayout;\n package$guide.LegendBoxSpec = LegendBoxSpec;\n Object.defineProperty(LegendBreak, 'Companion', {\n get: LegendBreak$Companion_getInstance\n });\n package$guide.LegendBreak = LegendBreak;\n package$guide.LegendComponent = LegendComponent;\n Object.defineProperty(LegendComponentLayout, 'Companion', {\n get: LegendComponentLayout$Companion_getInstance\n });\n package$guide.LegendComponentLayout = LegendComponentLayout;\n package$guide.LegendComponentSpec = LegendComponentSpec;\n Object.defineProperty(LegendDirection, 'HORIZONTAL', {\n get: LegendDirection$HORIZONTAL_getInstance\n });\n Object.defineProperty(LegendDirection, 'VERTICAL', {\n get: LegendDirection$VERTICAL_getInstance\n });\n Object.defineProperty(LegendDirection, 'AUTO', {\n get: LegendDirection$AUTO_getInstance\n });\n package$guide.LegendDirection = LegendDirection;\n Object.defineProperty(LegendJustification, 'Companion', {\n get: LegendJustification$Companion_getInstance\n });\n package$guide.LegendJustification = LegendJustification;\n Object.defineProperty(LegendPosition, 'Companion', {\n get: LegendPosition$Companion_getInstance\n });\n package$guide.LegendPosition = LegendPosition;\n Object.defineProperty(Orientation, 'LEFT', {\n get: Orientation$LEFT_getInstance\n });\n Object.defineProperty(Orientation, 'RIGHT', {\n get: Orientation$RIGHT_getInstance\n });\n Object.defineProperty(Orientation, 'TOP', {\n get: Orientation$TOP_getInstance\n });\n Object.defineProperty(Orientation, 'BOTTOM', {\n get: Orientation$BOTTOM_getInstance\n });\n package$guide.Orientation = Orientation;\n Object.defineProperty(ContextualMappingProvider, 'Companion', {\n get: ContextualMappingProvider$Companion_getInstance\n });\n var package$interact = package$builder.interact || (package$builder.interact = {});\n package$interact.ContextualMappingProvider = ContextualMappingProvider;\n Object.defineProperty(GeomInteraction, 'Companion', {\n get: GeomInteraction$Companion_getInstance\n });\n package$interact.GeomInteraction = GeomInteraction;\n Object.defineProperty(GeomInteractionBuilder, 'Companion', {\n get: GeomInteractionBuilder$Companion_getInstance\n });\n package$interact.GeomInteractionBuilder = GeomInteractionBuilder;\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'NEW_CLOSER', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance\n });\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'NEW_FARTHER', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance\n });\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'EQUAL', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance\n });\n MathUtil$ClosestPointChecker.COMPARISON_RESULT = MathUtil$ClosestPointChecker$COMPARISON_RESULT;\n MathUtil.prototype.ClosestPointChecker_init_lu1900$ = MathUtil$MathUtil$ClosestPointChecker_init;\n MathUtil.prototype.ClosestPointChecker = MathUtil$ClosestPointChecker;\n Object.defineProperty(MathUtil$DoubleRange, 'Companion', {\n get: MathUtil$DoubleRange$Companion_getInstance\n });\n MathUtil.prototype.DoubleRange = MathUtil$DoubleRange;\n Object.defineProperty(package$interact, 'MathUtil', {\n get: MathUtil_getInstance\n });\n Object.defineProperty(TooltipSpec$Line, 'Companion', {\n get: TooltipSpec$Line$Companion_getInstance\n });\n TooltipSpec.Line = TooltipSpec$Line;\n package$interact.TooltipSpec = TooltipSpec;\n package$interact.TooltipSpecFactory = TooltipSpecFactory;\n var package$loc = package$interact.loc || (package$interact.loc = {});\n package$loc.LayerTargetCollectorWithLocator = LayerTargetCollectorWithLocator;\n LayerTargetLocator.Target = LayerTargetLocator$Target;\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'APPEND', {\n get: LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'REPLACE', {\n get: LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'APPEND_IF_EQUAL', {\n get: LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'IGNORE', {\n get: LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance\n });\n LayerTargetLocator$Collector.CollectingStrategy = LayerTargetLocator$Collector$CollectingStrategy;\n LayerTargetLocator.Collector = LayerTargetLocator$Collector;\n package$loc.LayerTargetLocator = LayerTargetLocator;\n Object.defineProperty(LocatedTargetsPicker, 'Companion', {\n get: LocatedTargetsPicker$Companion_getInstance\n });\n package$loc.LocatedTargetsPicker = LocatedTargetsPicker;\n Object.defineProperty(TargetDetector, 'Companion', {\n get: TargetDetector$Companion_getInstance\n });\n package$loc.TargetDetector = TargetDetector;\n package$loc.TargetProjection = TargetProjection;\n Object.defineProperty(PointTargetProjection, 'Companion', {\n get: PointTargetProjection$Companion_getInstance\n });\n package$loc.PointTargetProjection = PointTargetProjection;\n Object.defineProperty(RectTargetProjection, 'Companion', {\n get: RectTargetProjection$Companion_getInstance\n });\n package$loc.RectTargetProjection = RectTargetProjection;\n Object.defineProperty(PolygonTargetProjection, 'Companion', {\n get: PolygonTargetProjection$Companion_getInstance\n });\n PolygonTargetProjection.RingXY = PolygonTargetProjection$RingXY;\n package$loc.PolygonTargetProjection = PolygonTargetProjection;\n Object.defineProperty(PathTargetProjection$PathPoint, 'Companion', {\n get: PathTargetProjection$PathPoint$Companion_getInstance\n });\n PathTargetProjection.PathPoint = PathTargetProjection$PathPoint;\n Object.defineProperty(PathTargetProjection, 'Companion', {\n get: PathTargetProjection$Companion_getInstance\n });\n package$loc.PathTargetProjection = PathTargetProjection;\n Object.defineProperty(TargetPrototype, 'Companion', {\n get: TargetPrototype$Companion_getInstance\n });\n package$loc.TargetPrototype = TargetPrototype;\n package$loc.TransformedTargetLocator = TransformedTargetLocator;\n var package$layout = package$builder.layout || (package$builder.layout = {});\n package$layout.AxisLayout = AxisLayout;\n AxisLayoutInfo.Builder = AxisLayoutInfo$Builder;\n package$layout.AxisLayoutInfo = AxisLayoutInfo;\n Object.defineProperty(EmptyAxisLayout, 'Companion', {\n get: EmptyAxisLayout$Companion_getInstance\n });\n package$layout.EmptyAxisLayout = EmptyAxisLayout;\n Object.defineProperty(FacetGridPlotLayout, 'Companion', {\n get: FacetGridPlotLayout$Companion_getInstance\n });\n package$layout.FacetGridPlotLayout = FacetGridPlotLayout;\n Object.defineProperty(package$layout, 'GeometryUtil', {\n get: GeometryUtil_getInstance\n });\n Object.defineProperty(LegendBoxInfo, 'Companion', {\n get: LegendBoxInfo$Companion_getInstance\n });\n package$layout.LegendBoxInfo = LegendBoxInfo;\n LegendBoxesLayout.Result = LegendBoxesLayout$Result;\n LegendBoxesLayout.BoxWithLocation = LegendBoxesLayout$BoxWithLocation;\n package$layout.LegendBoxesLayout = LegendBoxesLayout;\n Object.defineProperty(package$layout, 'LegendBoxesLayoutUtil', {\n get: LegendBoxesLayoutUtil_getInstance\n });\n package$layout.LiveMapTileLayout = LiveMapTileLayout;\n Object.defineProperty(PlotAxisLayout, 'Companion', {\n get: PlotAxisLayout$Companion_getInstance\n });\n package$layout.PlotAxisLayout = PlotAxisLayout;\n package$layout.PlotLayout = PlotLayout;\n package$layout.PlotLayoutBase = PlotLayoutBase;\n package$layout.PlotLayoutInfo = PlotLayoutInfo;\n Object.defineProperty(package$layout, 'PlotLayoutUtil', {\n get: PlotLayoutUtil_getInstance\n });\n package$layout.SingleTilePlotLayout = SingleTilePlotLayout;\n package$layout.TileLayout = TileLayout;\n package$layout.TileLayoutInfo_init_aeujc5$ = TileLayoutInfo_init;\n package$layout.TileLayoutInfo = TileLayoutInfo;\n Object.defineProperty(package$layout, 'XYPlotLayoutUtil', {\n get: XYPlotLayoutUtil_getInstance\n });\n Object.defineProperty(XYPlotTileLayout, 'Companion', {\n get: XYPlotTileLayout$Companion_getInstance\n });\n package$layout.XYPlotTileLayout = XYPlotTileLayout;\n var package$axis = package$layout.axis || (package$layout.axis = {});\n package$axis.AdaptableAxisBreaksProvider = AdaptableAxisBreaksProvider;\n package$axis.AxisBreaksProvider = AxisBreaksProvider;\n Object.defineProperty(package$axis, 'AxisBreaksUtil', {\n get: AxisBreaksUtil_getInstance\n });\n Object.defineProperty(AxisLayouter, 'Companion', {\n get: AxisLayouter$Companion_getInstance\n });\n package$axis.AxisLayouter = AxisLayouter;\n package$axis.FixedAxisBreaksProvider = FixedAxisBreaksProvider;\n package$axis.GuideBreaks = GuideBreaks;\n package$axis.HorizontalAxisLayouter = HorizontalAxisLayouter;\n package$axis.VerticalAxisLayouter = VerticalAxisLayouter;\n Object.defineProperty(AbstractFixedBreaksLabelsLayout, 'Companion', {\n get: AbstractFixedBreaksLabelsLayout$Companion_getInstance\n });\n var package$label = package$axis.label || (package$axis.label = {});\n package$label.AbstractFixedBreaksLabelsLayout = AbstractFixedBreaksLabelsLayout;\n Object.defineProperty(AxisLabelsLayout, 'Companion', {\n get: AxisLabelsLayout$Companion_getInstance\n });\n package$label.AxisLabelsLayout = AxisLabelsLayout;\n AxisLabelsLayoutInfo.Builder = AxisLabelsLayoutInfo$Builder;\n package$label.AxisLabelsLayoutInfo = AxisLabelsLayoutInfo;\n Object.defineProperty(package$label, 'BreakLabelsLayoutUtil', {\n get: BreakLabelsLayoutUtil_getInstance\n });\n package$label.HorizontalFixedBreaksLabelsLayout = HorizontalFixedBreaksLabelsLayout;\n package$label.HorizontalFlexBreaksLabelsLayout = HorizontalFlexBreaksLabelsLayout;\n Object.defineProperty(HorizontalMultilineLabelsLayout, 'Companion', {\n get: HorizontalMultilineLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalMultilineLabelsLayout = HorizontalMultilineLabelsLayout;\n Object.defineProperty(HorizontalSimpleLabelsLayout, 'Companion', {\n get: HorizontalSimpleLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalSimpleLabelsLayout = HorizontalSimpleLabelsLayout;\n Object.defineProperty(HorizontalTiltedLabelsLayout, 'Companion', {\n get: HorizontalTiltedLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalTiltedLabelsLayout = HorizontalTiltedLabelsLayout;\n Object.defineProperty(HorizontalVerticalLabelsLayout, 'Companion', {\n get: HorizontalVerticalLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalVerticalLabelsLayout = HorizontalVerticalLabelsLayout;\n package$label.VerticalFixedBreaksLabelsLayout = VerticalFixedBreaksLabelsLayout;\n package$label.VerticalFlexBreaksLabelsLayout = VerticalFlexBreaksLabelsLayout;\n Object.defineProperty(Defaults$Common, 'Title', {\n get: Defaults$Common$Title_getInstance\n });\n Object.defineProperty(Defaults$Common, 'Legend', {\n get: Defaults$Common$Legend_getInstance\n });\n Object.defineProperty(Defaults$Common, 'Tooltip', {\n get: Defaults$Common$Tooltip_getInstance\n });\n Defaults.prototype.Common = Defaults$Common;\n Object.defineProperty(Defaults$Table, 'Head', {\n get: Defaults$Table$Head_getInstance\n });\n Object.defineProperty(Defaults$Table, 'Data', {\n get: Defaults$Table$Data_getInstance\n });\n Defaults.prototype.Table = Defaults$Table;\n Object.defineProperty(Defaults$Plot, 'Axis', {\n get: Defaults$Plot$Axis_getInstance\n });\n Defaults.prototype.Plot = Defaults$Plot;\n var package$presentation = package$builder.presentation || (package$builder.presentation = {});\n Object.defineProperty(package$presentation, 'Defaults', {\n get: Defaults_getInstance\n });\n Object.defineProperty(package$presentation, 'LabelCss', {\n get: LabelCss_getInstance\n });\n package$presentation.Serializable = Serializable;\n Object.defineProperty(LabelMetrics, 'Companion', {\n get: LabelMetrics$Companion_getInstance\n });\n package$presentation.LabelMetrics_init = LabelMetrics_init;\n package$presentation.LabelMetrics_init_7trt9e$ = LabelMetrics_init_0;\n package$presentation.LabelMetrics = LabelMetrics;\n package$presentation.LabelSpec = LabelSpec;\n Object.defineProperty(PlotLabelSpec, 'PLOT_TITLE', {\n get: PlotLabelSpec$PLOT_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TICK', {\n get: PlotLabelSpec$AXIS_TICK_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TICK_SMALL', {\n get: PlotLabelSpec$AXIS_TICK_SMALL_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TITLE', {\n get: PlotLabelSpec$AXIS_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'LEGEND_TITLE', {\n get: PlotLabelSpec$LEGEND_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'LEGEND_ITEM', {\n get: PlotLabelSpec$LEGEND_ITEM_getInstance\n });\n package$presentation.PlotLabelSpec = PlotLabelSpec;\n Object.defineProperty(package$presentation, 'Style', {\n get: Style_getInstance\n });\n var package$sampling = package$builder.sampling || (package$builder.sampling = {});\n package$sampling.GroupAwareSampling = GroupAwareSampling;\n package$sampling.PointSampling = PointSampling;\n package$sampling.Sampling = Sampling;\n Object.defineProperty(package$sampling, 'Samplings', {\n get: Samplings_getInstance\n });\n Object.defineProperty(GroupRandomSampling, 'Companion', {\n get: GroupRandomSampling$Companion_getInstance\n });\n var package$method = package$sampling.method || (package$sampling.method = {});\n package$method.GroupRandomSampling = GroupRandomSampling;\n package$method.GroupSamplingBase = GroupSamplingBase;\n Object.defineProperty(GroupSystematicSampling, 'Companion', {\n get: GroupSystematicSampling$Companion_getInstance\n });\n package$method.GroupSystematicSampling = GroupSystematicSampling;\n Object.defineProperty(PickSampling, 'Companion', {\n get: PickSampling$Companion_getInstance\n });\n package$method.PickSampling = PickSampling;\n Object.defineProperty(RandomSampling, 'Companion', {\n get: RandomSampling$Companion_getInstance\n });\n package$method.RandomSampling = RandomSampling;\n Object.defineProperty(RandomStratifiedSampling, 'Companion', {\n get: RandomStratifiedSampling$Companion_getInstance\n });\n package$method.RandomStratifiedSampling = RandomStratifiedSampling;\n package$method.SamplingBase = SamplingBase;\n Object.defineProperty(package$method, 'SamplingUtil', {\n get: SamplingUtil_getInstance\n });\n Object.defineProperty(SystematicSampling, 'Companion', {\n get: SystematicSampling$Companion_getInstance\n });\n package$method.SystematicSampling = SystematicSampling;\n Object.defineProperty(VertexSampling$VertexVwSampling, 'Companion', {\n get: VertexSampling$VertexVwSampling$Companion_getInstance\n });\n VertexSampling.VertexVwSampling = VertexSampling$VertexVwSampling;\n Object.defineProperty(VertexSampling$VertexDpSampling, 'Companion', {\n get: VertexSampling$VertexDpSampling$Companion_getInstance\n });\n VertexSampling.VertexDpSampling = VertexSampling$VertexDpSampling;\n VertexSampling.DoubleVectorComponentsList = VertexSampling$DoubleVectorComponentsList;\n Object.defineProperty(VertexSampling, 'Companion', {\n get: VertexSampling$Companion_getInstance\n });\n package$method.VertexSampling = VertexSampling;\n var package$scale = package$builder.scale || (package$builder.scale = {});\n package$scale.ContinuousOnlyMapperProvider = ContinuousOnlyMapperProvider;\n Object.defineProperty(package$scale, 'DefaultMapperProvider', {\n get: DefaultMapperProvider_getInstance\n });\n Object.defineProperty(package$scale, 'DefaultMapperProviderUtil', {\n get: DefaultMapperProviderUtil_getInstance\n });\n Object.defineProperty(package$scale, 'DefaultNaValue', {\n get: DefaultNaValue_getInstance\n });\n package$scale.DiscreteOnlyMapperProvider = DiscreteOnlyMapperProvider;\n package$scale.GuideBreak = GuideBreak;\n package$scale.GuideMapper = GuideMapper;\n package$scale.MapperProvider = MapperProvider;\n package$scale.ScaleProvider = ScaleProvider;\n package$scale.ScaleProviderBuilder = ScaleProviderBuilder;\n Object.defineProperty(package$scale, 'ScaleProviderHelper', {\n get: ScaleProviderHelper_getInstance\n });\n package$scale.WithGuideBreaks = WithGuideBreaks;\n var package$mapper = package$scale.mapper || (package$scale.mapper = {});\n Object.defineProperty(package$mapper, 'ColorMapper', {\n get: ColorMapper_getInstance\n });\n package$mapper.GuideMapperAdapter = GuideMapperAdapter;\n package$mapper.GuideMapperWithGuideBreaks = GuideMapperWithGuideBreaks;\n Object.defineProperty(package$mapper, 'GuideMappers', {\n get: GuideMappers_getInstance\n });\n Object.defineProperty(package$mapper, 'LineTypeMapper', {\n get: LineTypeMapper_getInstance\n });\n Object.defineProperty(package$mapper, 'ShapeMapper', {\n get: ShapeMapper_getInstance\n });\n Object.defineProperty(AlphaMapperProvider, 'Companion', {\n get: AlphaMapperProvider$Companion_getInstance\n });\n var package$provider = package$scale.provider || (package$scale.provider = {});\n package$provider.AlphaMapperProvider = AlphaMapperProvider;\n Object.defineProperty(ColorBrewerMapperProvider, 'Companion', {\n get: ColorBrewerMapperProvider$Companion_getInstance\n });\n package$provider.ColorBrewerMapperProvider = ColorBrewerMapperProvider;\n Object.defineProperty(ColorGradient2MapperProvider, 'Companion', {\n get: ColorGradient2MapperProvider$Companion_getInstance\n });\n package$provider.ColorGradient2MapperProvider = ColorGradient2MapperProvider;\n Object.defineProperty(ColorGradientMapperProvider, 'Companion', {\n get: ColorGradientMapperProvider$Companion_getInstance\n });\n package$provider.ColorGradientMapperProvider = ColorGradientMapperProvider;\n Object.defineProperty(ColorHueMapperProvider, 'Companion', {\n get: ColorHueMapperProvider$Companion_getInstance\n });\n package$provider.ColorHueMapperProvider = ColorHueMapperProvider;\n package$provider.DirectlyProportionalMapperProvider = DirectlyProportionalMapperProvider;\n Object.defineProperty(GreyscaleLightnessMapperProvider, 'Companion', {\n get: GreyscaleLightnessMapperProvider$Companion_getInstance\n });\n package$provider.GreyscaleLightnessMapperProvider = GreyscaleLightnessMapperProvider;\n Object.defineProperty(HSVColorMapperProvider, 'Companion', {\n get: HSVColorMapperProvider$Companion_getInstance\n });\n package$provider.HSVColorMapperProvider = HSVColorMapperProvider;\n package$provider.IdentityDiscreteMapperProvider = IdentityDiscreteMapperProvider;\n package$provider.IdentityMapperProvider = IdentityMapperProvider;\n package$provider.LinearNormalizingMapperProvider = LinearNormalizingMapperProvider;\n package$provider.MapperProviderBase = MapperProviderBase;\n Object.defineProperty(SizeAreaMapperProvider, 'Companion', {\n get: SizeAreaMapperProvider$Companion_getInstance\n });\n package$provider.SizeAreaMapperProvider = SizeAreaMapperProvider;\n Object.defineProperty(SizeMapperProvider, 'Companion', {\n get: SizeMapperProvider$Companion_getInstance\n });\n package$provider.SizeMapperProvider = SizeMapperProvider;\n var package$theme = package$builder.theme || (package$builder.theme = {});\n package$theme.AxisTheme = AxisTheme;\n package$theme.DefaultAxisTheme = DefaultAxisTheme;\n Object.defineProperty(DefaultTheme, 'Companion', {\n get: DefaultTheme$Companion_getInstance\n });\n package$theme.DefaultTheme = DefaultTheme;\n package$theme.FacetsTheme = FacetsTheme;\n package$theme.LegendTheme = LegendTheme;\n package$theme.PlotTheme = PlotTheme;\n package$theme.Theme = Theme;\n var package$tooltip = package$builder.tooltip || (package$builder.tooltip = {});\n package$tooltip.ConstantValue = ConstantValue;\n package$tooltip.DataFrameValue = DataFrameValue;\n package$tooltip.MappingValue = MappingValue;\n Object.defineProperty(TooltipLine, 'Companion', {\n get: TooltipLine$Companion_getInstance\n });\n package$tooltip.TooltipLine_init_3f4yhq$ = TooltipLine_init;\n package$tooltip.TooltipLine = TooltipLine;\n Object.defineProperty(TooltipSpecification$TooltipProperties, 'Companion', {\n get: TooltipSpecification$TooltipProperties$Companion_getInstance\n });\n TooltipSpecification.TooltipProperties = TooltipSpecification$TooltipProperties;\n Object.defineProperty(TooltipSpecification, 'Companion', {\n get: TooltipSpecification$Companion_getInstance\n });\n package$tooltip.TooltipSpecification = TooltipSpecification;\n package$tooltip.ValueSource = ValueSource;\n BogusCoordinateSystem.prototype.isPointInLimits_k2qmv6$ = CoordinateSystem.prototype.isPointInLimits_k2qmv6$;\n BogusCoordinateSystem.prototype.isRectInLimits_fd842m$ = CoordinateSystem.prototype.isRectInLimits_fd842m$;\n BogusCoordinateSystem.prototype.isPathInLimits_f6t8kh$ = CoordinateSystem.prototype.isPathInLimits_f6t8kh$;\n BogusCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$;\n LayerTargetCollectorWithLocator.prototype.addPoint_cnsimy$ = GeomTargetCollector.prototype.addPoint_cnsimy$;\n LayerTargetCollectorWithLocator.prototype.addRectangle_bxzvr8$ = GeomTargetCollector.prototype.addRectangle_bxzvr8$;\n LayerTargetCollectorWithLocator.prototype.addPath_sa5m83$ = GeomTargetCollector.prototype.addPath_sa5m83$;\n LayerTargetCollectorWithLocator.prototype.addPolygon_sa5m83$ = GeomTargetCollector.prototype.addPolygon_sa5m83$;\n DefaultAxisTheme.prototype.tickLabelDistance = AxisTheme.prototype.tickLabelDistance;\n Kotlin.defineModule('lets-plot-plot-builder-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/DefaultSampling.kt?779d","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/FeatureSwitch.kt?8601","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/AxisUtil.kt?d9ab","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/BogusCoordinateSystem.kt?564a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/BogusScale.kt?7ba9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/GeomLayerListUtil.kt?06d5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/LayerRendererUtil.kt?ca26","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/Plot.kt?575c","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotBuilder.kt?e078","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotContainerPortable.kt?c34a","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotTile.kt?fdff","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotTooltipHelper.kt?06fc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotUtil.kt?38bb","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Lazy.kt?28a8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/SvgLayerRenderer.kt?9cef","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/VarBinding.kt?05c8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/ColorBarAssembler.kt?ad66","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/ColorBarOptions.kt?0887","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GeomContextBuilder.kt?0505","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GeomLayerBuilder.kt?7d80","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GuideOptions.kt?9356","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendAssembler.kt?d321","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendAssemblerUtil.kt?30b6","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendOptions.kt?7bc0","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotAssembler.kt?b390","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotAssemblerUtil.kt?c7d9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotFacets.kt?a9ae","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotGuidesAssemblerUtil.kt?6ca1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PosProvider.kt?c9d4","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/StitchedPlotLayers.kt?4b2e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/TypedScaleMap.kt?609b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/TypedScaleProviderMap.kt?de36","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/facet/FacetGrid.kt?4031","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/facet/FacetWrap.kt?5e9c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/GeomProvider.kt?f06c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/PointDataAccess.kt?8666","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CartesianCoordProvider.kt?0c76","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CoordProviderBase.kt?d4c7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CoordProviders.kt?996f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/FixedRatioCoordProvider.kt?715d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/ProjectionCoordProvider.kt?547b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/map/MercatorProjectionX.kt?ebb7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/map/MercatorProjectionY.kt?6c7d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/DataProcessing.kt?9db8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupMerger.kt?b981","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupUtil.kt?4405","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupingContext.kt?306d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/OrderOptionUtil.kt?417f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/event/MouseEventPeer.kt?6f65","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/AxisComponent.kt?382d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponent.kt?b9a3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponentLayout.kt?d405","webpack://LetsPlot/./kotlin-dce-dev/js/src/generated/_ComparisonsJs.kt?5791","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponentSpec.kt?6ddb","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendArrangement.kt?1c59","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBox.kt?2224","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBoxLayout.kt?d6b7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBoxSpec.kt?9c59","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBreak.kt?9dc3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponent.kt?3d12","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponentLayout.kt?a2c4","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponentSpec.kt?73e2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendDirection.kt?84f0","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendJustification.kt?7539","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendPosition.kt?9047","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/Orientation.kt?00da","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/ContextualMappingProvider.kt?ce13","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/GeomInteraction.kt?65cf","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/GeomInteractionBuilder.kt?6272","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Maps.kt?a3e9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/MathUtil.kt?cd11","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/TooltipSpec.kt?b76a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/TooltipSpecFactory.kt?319d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LayerTargetCollectorWithLocator.kt?58cd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LayerTargetLocator.kt?3373","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LocatedTargetsPicker.kt?b261","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetDetector.kt?5acd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetProjection.kt?220f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetPrototype.kt?fb28","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TransformedTargetLocator.kt?ebcc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/AxisLayoutInfo.kt?52b8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/EmptyAxisLayout.kt?4f46","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/FacetGridPlotLayout.kt?9fce","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/GeometryUtil.kt?84b2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxInfo.kt?42da","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxesLayout.kt?9035","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxesLayoutUtil.kt?d34d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LiveMapTileLayout.kt?9804","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotAxisLayout.kt?32ba","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutBase.kt?3dfa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutInfo.kt?41d6","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutUtil.kt?cda3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/SingleTilePlotLayout.kt?74ee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/TileLayoutInfo.kt?94a7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/XYPlotLayoutUtil.kt?4dee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/XYPlotTileLayout.kt?5086","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AdaptableAxisBreaksProvider.kt?fd84","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AxisBreaksUtil.kt?4866","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AxisLayouter.kt?6fcc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/FixedAxisBreaksProvider.kt?5de1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/GuideBreaks.kt?7aba","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/HorizontalAxisLayouter.kt?896e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/VerticalAxisLayouter.kt?620f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AbstractFixedBreaksLabelsLayout.kt?26fa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AxisLabelsLayout.kt?597e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AxisLabelsLayoutInfo.kt?0e85","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/BreakLabelsLayoutUtil.kt?d1c8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalFixedBreaksLabelsLayout.kt?1f58","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalFlexBreaksLabelsLayout.kt?5330","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalMultilineLabelsLayout.kt?4262","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalSimpleLabelsLayout.kt?d3e5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalTiltedLabelsLayout.kt?35b7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalVerticalLabelsLayout.kt?5961","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/VerticalFixedBreaksLabelsLayout.kt?d2c1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/VerticalFlexBreaksLabelsLayout.kt?2b73","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/Defaults.kt?d7a1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/LabelCss.kt?1c7a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/LabelMetrics.kt?8368","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/PlotLabelSpec.kt?e9e3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/Style.kt?ffe7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/Samplings.kt?699c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupRandomSampling.kt?ae6d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupSamplingBase.kt?675b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupSystematicSampling.kt?d00d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/PickSampling.kt?8773","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/RandomSampling.kt?eef9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/RandomStratifiedSampling.kt?884b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SamplingBase.kt?3924","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SamplingUtil.kt?5316","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SystematicSampling.kt?2907","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/VertexSampling.kt?cb0b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ContinuousOnlyMapperProvider.kt?4677","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultMapperProvider.kt?0057","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultMapperProviderUtil.kt?8b9d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultNaValue.kt?f35a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DiscreteOnlyMapperProvider.kt?3731","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/GuideBreak.kt?4a3f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ScaleProviderBuilder.kt?80a5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ScaleProviderHelper.kt?cf54","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/ColorMapper.kt?c3e5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMapperAdapter.kt?5115","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMapperWithGuideBreaks.kt?8aaa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMappers.kt?7aab","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/LineTypeMapper.kt?6f3e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/ShapeMapper.kt?40e8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/AlphaMapperProvider.kt?69aa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorBrewerMapperProvider.kt?7117","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorGradient2MapperProvider.kt?5c55","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorGradientMapperProvider.kt?b95c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorHueMapperProvider.kt?e638","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/DirectlyProportionalMapperProvider.kt?aee1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/GreyscaleLightnessMapperProvider.kt?663c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/HSVColorMapperProvider.kt?69a1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/IdentityDiscreteMapperProvider.kt?76fb","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/IdentityMapperProvider.kt?1203","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/LinearNormalizingMapperProvider.kt?358d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/MapperProviderBase.kt?7f66","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/SizeAreaMapperProvider.kt?e4a5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/SizeMapperProvider.kt?2f2c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/AxisTheme.kt?91ed","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/DefaultAxisTheme.kt?7bf2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/DefaultTheme.kt?fc02","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/ConstantValue.kt?a9bc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/DataFrameValue.kt?ca9f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/MappingValue.kt?c3c2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/TooltipLine.kt?1074","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/TooltipSpecification.kt?de66"],"names":[],"mappings":"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FA,Q;IAAA,O0EnwBiB,Y1EmwBjB,W;gBAAhB,OAAgB,cAAhB,C;MAAgB,yB;M0ElwB0B,gB1EkwBN,O0ElwBD,O;M1EysB5B,oBAAmB,gB;MASV,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;QAAM,IAAI,sCAAJ,C;UAAkB,aAAY,WAAI,SAAJ,C;;M0EltBxC,kB1EmtBL,a;M0EltBiB,c;;Q1EmmDR,U;QADhB,IAAI,c0ElmDQ,W1EkmDR,iB0ElmDQ,W1EkmDc,UAA1B,C;UAAqC,aAAO,I;UAAP,e;SACrB,S0EnmDJ,W1EmmDI,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UAAM,IAAI,C0EnmD4B,4B1EmmDjB,S0EnmDoC,IAAnB,C1EmmDhC,C;YAAyB,aAAO,K;YAAP,e;;QAC/C,aAAO,I;;;MAn2Be,e;QAAwB,WAAY,WAAI,OAAJ,C;;I0EnwBlD,yB1EowBD,W;IAi+BS,U;IAAA,S0EjuDR,kB1EiuDQ,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,6B;MAAa,S0EjuDW,qC;;IAEW,c;;M1EonDnC,U;MADhB,IAAI,c0EnnD4B,kB1EmnD5B,iB0EnnD4B,kB1EmnDN,UAA1B,C;QAAqC,aAAO,K;QAAP,e;OACrB,S0EpnDgB,kB1EonDhB,W;kBAAhB,OAAgB,gBAAhB,C;QAAgB,6B;Q0EnnDQ,kB1EmnDY,S0EnnDnB,O;QAAO,uDAAK,qB;iBAAa,mB;SAAlB,C;QAAA,e;;U1E00ER,U;UADhB,IAAI,0CAAsB,qBAA1B,C;YAAqC,cAAO,I;YAAP,gB;WACrB,+B;UAAhB,OAAgB,gBAAhB,C;YAAgB,6B;YAAM,IAAI,UAAU,SAAV,CAAJ,C;cAAwB,cAAO,K;cAAP,gB;;UAC9C,cAAO,I;;;QAxtBe,gB;UAAwB,aAAO,I;UAAP,e;;MAC9C,aAAO,K;;;I0ErnDC,kC;IAGwC,gB;;M1EinDhC,U;MADhB,IAAI,c0EhnDyB,kB1EgnDzB,iB0EhnDyB,kB1EgnDH,UAA1B,C;QAAqC,eAAO,K;QAAP,e;OACrB,S0EjnDa,kB1EinDb,W;kBAAhB,OAAgB,gBAAhB,C;QAAgB,6B;Q0EhnDQ,kB1EgnDY,S0Eh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AC9C,4B;MAAA,eAAkC,I;IAWb,Q;I3EozCtB,kBAAM,iBAAa,wB2E7zCK,O3E6zCL,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S2Ep4CkB,O3Eo4ClB,W;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,WAAY,W2Er4CoC,iB3Eq4CtB,I2Er4CsB,EAA8B,IAA9B,EAA6C,IAA7C,C3Eq4CpC,C;;I2Er4CR,uB3Es4CD,W;IAzEA,oBAAM,iBAAa,wB2E5zCQ,Q3E4zCR,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S2En4CqB,Q3Em4CrB,W;IAAb,OAAa,gBAAb,C;MAAa,0B;mBACT,a;M2En4C0B,kB;MAAA,U;MAAA,oC;Q3E8kBvB,oBAAmB,gB;QASV,U;QAAA,2C;QAAhB,OAAgB,gBAAhB,C;UAAgB,2B;UAAM,IAAI,oCAAJ,C;YAAkB,aAAY,WAAI,OAAJ,C;;Q2EvlBtB,S3EwlBvB,a;;Q2ExlBuB,a;MAAA,U;MAAA,8B;Q3EzCvB,sB;;UAuHS,U;UAAA,0B;UAAhB,OAAgB,gBAAhB,C;YAAgB,6B;YAAM,I2E9E0E,O3E8E5D,S2E9E+D,IAAH,E3Em4ClE,M2En4CkE,C3E8E1E,C;cAAwB,qBAAO,S;cAAP,uB;;UAC9C,qBAAO,I;;;Q2E/EuB,S3EzC9B,kB;;Q2EyC8B,a;MAAlB,wB;M3Em4CI,YAAZ,aAAY,E2El4CJ,mFAA4B,iB3Ek4CV,M2El4CU,EAA8B,IAA9B,C3Ek4CxB,C;;I2Ep4CR,0B3Eq4CD,a;IAzEA,oBAAM,iBAAa,wB2ExzCI,iB3EwzCJ,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S2E/3CiB,iB3E+3CjB,W;IAAb,OAAa,gBAAb,C;MAAa,0B;oBACT,a;M2E/3C0B,W;MAAA,W;MAAA,oC;Q3E0kBvB,oBAAmB,gB;QASV,W;QAAA,4C;QAAhB,OAAgB,iBAAhB,C;UAAgB,8B;UAAM,IAAI,sCAAJ,C;YAAkB,aAAY,WAAI,SAAJ,C;;Q2EnlBtB,U3EolBvB,a;;Q2EplBuB,c;MAAA,W;MAAA,gC;Q3E7CvB,wB;;UAuHS,W;UAAA,4B;UAAhB,OAAgB,iBAAhB,C;YAAgB,8B;YAAM,I2E1E0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","file":"./kotlin-dce-dev/lets-plot-plot-builder-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.builder.sampling.Samplings.pick\nimport jetbrains.datalore.plot.builder.sampling.Samplings.random\nimport jetbrains.datalore.plot.builder.sampling.Samplings.systematic\nimport jetbrains.datalore.plot.builder.sampling.Samplings.systematicGroup\nimport jetbrains.datalore.plot.builder.sampling.Samplings.vertexDp\n\n/*\n None:\n      livemap\n      raster\n      image\n */\nobject DefaultSampling {\n    private const val SEED = 37L\n\n    val SAFETY_SAMPLING = random(200000, SEED)\n\n    // point-like\n    val POINT = random(50000, SEED)   // optimized\n    val TILE = random(50000, SEED)    // optimized\n    val BIN_2D = TILE\n    val AB_LINE = random(5000, SEED)\n    val H_LINE = random(5000, SEED)\n    val V_LINE = random(5000, SEED)\n    val JITTER = random(5000, SEED)\n    val RECT = random(5000, SEED)\n    val SEGMENT = random(5000, SEED)\n    val TEXT = random(500, SEED)\n\n    // range\n    val ERROR_BAR = random(500, SEED)\n    val CROSS_BAR = random(500, SEED)\n    // val BOX_PLOT = random(500, SEED) - tmp disabled (see GeomProto)\n    val LINE_RANGE = random(500, SEED)\n    val POINT_RANGE = random(500, SEED)\n\n    // bars\n    val BAR = pick(50)\n    val HISTOGRAM = systematic(500)\n\n    // lines\n    val LINE = systematic(5000)\n    val RIBBON = systematic(5000)\n    val AREA = systematic(5000)\n    val DENSITY = systematic(5000)\n    val FREQPOLY = systematic(5000)\n    val STEP = systematic(5000)\n\n    // polygons\n    val PATH = vertexDp(20000)\n    val POLYGON = vertexDp(20000)\n    val MAP = vertexDp(20000)\n\n    // groups\n    val SMOOTH = systematicGroup(200)\n    val CONTOUR = systematicGroup(200)\n    val CONTOURF = systematicGroup(200)\n    val DENSITY2D = systematicGroup(200)\n    val DENSITY2DF = systematicGroup(200)\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\n\nobject FeatureSwitch {\n    const val PLOT_DEBUG_DRAWING = false\n    const val LEGEND_DEBUG_DRAWING = false\n    private const val PRINT_DEBUG_LOGS = false\n\n    private const val PRINT_ENCODED_DATA_SUMMARY = false\n\n    const val USE_DATA_FRAME_ENCODING = true\n\n    fun printEncodedDataSummary(header: String, dataSpec: Map<String, Any>) {\n        @Suppress(\"ConstantConditionIf\")\n        if (PRINT_ENCODED_DATA_SUMMARY) {\n            printEncodedDataSummary(\n                header,\n                DataFrameUtil.fromMap(dataSpec)\n            )\n        }\n    }\n\n    fun isDebugLogEnabled(): Boolean {\n        return PRINT_DEBUG_LOGS\n    }\n\n    private fun printEncodedDataSummary(header: String, df: DataFrame) {\n        @Suppress(\"ConstantConditionIf\")\n        if (PRINT_ENCODED_DATA_SUMMARY) {\n            //ToDo:\n            //Preconditions.checkState(!GWT.isClient(), \"Not expected on client\")\n            val summary = DataFrameUtil.getSummaryText(df)\n            println(header)\n            println(summary)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.builder.guide.AxisComponent\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nobject AxisUtil {\n    fun applyLayoutInfo(axis: AxisComponent, info: AxisLayoutInfo) {\n        axis.tickLabelOffsets.set(info.tickLabelAdditionalOffsets)\n        axis.tickLabelRotationDegree.set(info.tickLabelRotationAngle)\n        if (info.tickLabelHorizontalAnchor != null) {\n            axis.tickLabelHorizontalAnchor.set(info.tickLabelHorizontalAnchor)\n        }\n        if (info.tickLabelVerticalAnchor != null) {\n            axis.tickLabelVerticalAnchor.set(info.tickLabelVerticalAnchor)\n        }\n        axis.tickLabelSmallFont.set(info.tickLabelSmallFont)\n    }\n\n    fun applyTheme(axis: AxisComponent, theme: AxisTheme) {\n        axis.tickLabelsEnabled().set(theme.showTickLabels())\n        axis.tickMarksEnabled().set(theme.showTickMarks())\n        axis.axisLineEnabled().set(theme.showLine())\n\n        axis.lineWidth.set(theme.lineWidth())\n        axis.tickMarkLength.set(theme.tickMarkLength())\n        axis.tickMarkPadding.set(theme.tickMarkPadding())\n        axis.tickMarkWidth.set(theme.tickMarkWidth())\n    }\n\n    fun setBreaks(axis: AxisComponent, scale: Scale<Double>, coord: CoordinateSystem, isHorizontal: Boolean) {\n        axis.breaks.set(ScaleUtil.axisBreaks(scale, coord, isHorizontal))\n        axis.labels.set(ScaleUtil.labels(scale))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\n\ninternal class BogusCoordinateSystem : CoordinateSystem {\n    override fun toClient(p: DoubleVector): DoubleVector {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun fromClient(p: DoubleVector): DoubleVector {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPointInLimits(p: DoubleVector, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override val xClientLimit: ClosedRange<Double>\n        get() = throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n\n    override val yClientLimit: ClosedRange<Double>\n        get() = throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\n\ninternal class BogusScale : Scale<Double> {\n    override val name: String\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val breaks: List<Any>\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val labels: MutableList<String>\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val labelFormatter: ((Any) -> String)?\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val isContinuous: Boolean\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val isContinuousDomain: Boolean\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val domainLimits: Pair<Double, Double>\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val multiplicativeExpand: Double\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val additiveExpand: Double\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val transform: Transform\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val mapper: (Double?) -> Double?\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val breaksGenerator: BreaksGenerator\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override fun hasBreaksGenerator(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun hasBreaks(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun hasLabels(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun hasDomainLimits(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun with(): Scale.Builder<Double> {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nobject GeomLayerListUtil {\n\n//    fun anyBoundXScale(\n//        scaleMap: TypedScaleMap,\n//        layersByTile: List<List<GeomLayer>>\n//    ): Scale<Double>? {\n//        for (layer in layersByTile[0]) {\n//            if (layer.hasBinding(Aes.X)) {\n//                return scaleMap[Aes.X]\n//            }\n//        }\n//        return null\n//    }\n\n//    fun anyBoundYScale(\n//        scaleByAes: TypedScaleMap,\n//        layersByTile: List<List<GeomLayer>>\n//    ): Scale<Double>? {\n//        for (layer in layersByTile[0]) {\n//            if (layer.hasBinding(Aes.Y)) {\n//                return scaleByAes[Aes.Y]\n//            }\n//        }\n//        return null\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\n\nobject LayerRendererUtil {\n\n    fun createLayerRendererData(layer: GeomLayer,\n                                sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>,\n                                overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>\n    ): LayerRendererData {\n\n        val aestheticMappers =\n            PlotUtil.prepareLayerAestheticMappers(layer, sharedNumericMappers)\n        val aesthetics = PlotUtil.createLayerAesthetics(\n            layer,\n            aestheticMappers,\n            overallNumericDomains\n        )\n        val pos = PlotUtil.createLayerPos(layer, aesthetics)\n        return LayerRendererData(\n            layer,\n            aesthetics,\n            aestheticMappers,\n            pos\n        )\n    }\n\n    class LayerRendererData(\n        layer: GeomLayer,\n        val aesthetics: Aesthetics,\n        val aestheticMappers: Map<Aes<*>, (Double?) -> Any?>,\n        val pos: PositionAdjustment\n    ) {\n        val geom: Geom = layer.geom\n        val geomKind: GeomKind = layer.geomKind\n        val dataAccess: MappedDataAccess = layer.dataAccess\n        val contextualMapping: ContextualMapping = layer.contextualMapping\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.event.Event\nimport jetbrains.datalore.base.gcommon.base.Throwables\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ReadableProperty\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.FeatureSwitch.PLOT_DEBUG_DRAWING\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.event.MouseEventPeer\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.interact.TooltipSpec\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.layout.PlotLayoutUtil.liveMapBounds\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.vis.svg.SvgElement\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.event.SvgEventHandler\nimport jetbrains.datalore.vis.svg.event.SvgEventSpec\n\nabstract class Plot(private val theme: Theme) : SvgComponent() {\n\n    private val myPreferredSize = ValueProperty(DEF_PLOT_SIZE)\n    private val myLaidOutSize = ValueProperty(DoubleVector.ZERO)\n    private val myTooltipHelper = PlotTooltipHelper()\n    private val myLiveMapFigures = ArrayList<SomeFig>()\n\n    val mouseEventPeer = MouseEventPeer()\n\n    protected abstract val scaleXProto: Scale<Double>\n\n    protected abstract val scaleYProto: Scale<Double>\n\n    protected abstract val title: String\n\n    protected abstract val axisTitleLeft: String\n\n    protected abstract val axisTitleBottom: String\n\n    protected abstract val coordProvider: CoordProvider\n\n    protected abstract val legendBoxInfos: List<LegendBoxInfo>\n\n    protected abstract val isAxisEnabled: Boolean\n\n    abstract val isInteractionsEnabled: Boolean\n\n    internal val liveMapFigures: List<SomeFig>\n        get() = myLiveMapFigures\n\n    internal fun preferredSize(): WritableProperty<DoubleVector> {\n        return myPreferredSize\n    }\n\n    fun laidOutSize(): ReadableProperty<DoubleVector> {\n        return myLaidOutSize\n    }\n\n    protected abstract fun hasTitle(): Boolean\n\n    protected abstract fun hasAxisTitleLeft(): Boolean\n\n    protected abstract fun hasAxisTitleBottom(): Boolean\n\n    protected abstract fun hasLiveMap(): Boolean\n\n    protected abstract fun tileLayers(tileIndex: Int): List<GeomLayer>\n\n    protected abstract fun plotLayout(): PlotLayout\n\n    override fun buildComponent() {\n        try {\n            buildPlot()\n        } catch (e: RuntimeException) {\n            LOG.error(e) { \"buildPlot\" }\n\n            val rootCause = Throwables.getRootCause(e)\n            val messages = arrayOf(\n                \"Error building plot: \" + rootCause::class.simpleName, if (rootCause.message != null)\n                    \"'\" + rootCause.message + \"'\"\n                else\n                    \"<no message>\"\n            )\n            var y = myPreferredSize.get().y / 2 - 8\n            for (s in messages) {\n                val errorLabel = TextLabel(s)\n                errorLabel.setHorizontalAnchor(HorizontalAnchor.MIDDLE)\n                errorLabel.setVerticalAnchor(VerticalAnchor.CENTER)\n                errorLabel.moveTo(myPreferredSize.get().x / 2, y)\n                rootGroup.children().add(errorLabel.rootGroup)\n                y += 16.0\n            }\n        }\n    }\n\n    private fun buildPlot() {\n        rootGroup.addClass(Style.PLOT)\n        buildPlotComponents()\n        reg(myPreferredSize.addHandler(object : EventHandler<PropertyChangeEvent<out DoubleVector>> {\n            override fun onEvent(event: PropertyChangeEvent<out DoubleVector>) {\n                val newValue = event.newValue\n                if (newValue!!.x > 0 && newValue.y > 0) {\n                    rebuildPlot()\n                }\n            }\n        }))\n\n        reg(object : Registration() {\n            override fun doRemove() {\n                myTooltipHelper.removeAllTileInfos()\n                myLiveMapFigures.clear()\n            }\n        })\n    }\n\n    private fun rebuildPlot() {\n        clear()\n        buildPlot()\n    }\n\n\n    private fun createTile(\n        tilesOrigin: DoubleVector,\n        tileInfo: TileLayoutInfo,\n        tileLayers: List<GeomLayer>,\n        theme: Theme\n    ): PlotTile {\n\n        val xScale: Scale<Double>\n        val yScale: Scale<Double>\n        val coord: CoordinateSystem\n        if (tileInfo.xAxisInfo != null && tileInfo.yAxisInfo != null) {\n            val xDomain = tileInfo.xAxisInfo.axisDomain!!\n            val xAxisLength = tileInfo.xAxisInfo.axisLength\n\n            val yDomain = tileInfo.yAxisInfo.axisDomain!!\n            val yAxisLength = tileInfo.yAxisInfo.axisLength\n\n            // set-up scales and coordinate system\n            xScale = coordProvider.buildAxisScaleX(scaleXProto, xDomain, xAxisLength, tileInfo.xAxisInfo.axisBreaks!!)\n            yScale = coordProvider.buildAxisScaleY(scaleYProto, yDomain, yAxisLength, tileInfo.yAxisInfo.axisBreaks!!)\n            coord = coordProvider.createCoordinateSystem(xDomain, xAxisLength, yDomain, yAxisLength)\n        } else {\n            // bogus scales and coordinate system (live map doesn't need them)\n            xScale = BogusScale()\n            yScale = BogusScale()\n            coord = BogusCoordinateSystem()\n        }\n\n        val tile = PlotTile(tileLayers, xScale, yScale, tilesOrigin, tileInfo, coord, theme)\n        tile.setShowAxis(isAxisEnabled)\n        tile.debugDrawing().set(DEBUG_DRAWING)\n\n        return tile\n    }\n\n    private fun createAxisTitle(\n        text: String,\n        orientation: Orientation,\n        plotBounds: DoubleRectangle,\n        geomBounds: DoubleRectangle\n    ) {\n        val horizontalAnchor = HorizontalAnchor.MIDDLE\n        val verticalAnchor: VerticalAnchor = when (orientation) {\n            Orientation.LEFT, Orientation.RIGHT, Orientation.TOP -> VerticalAnchor.TOP\n            Orientation.BOTTOM -> VerticalAnchor.BOTTOM\n        }\n\n        val titleLocation: DoubleVector\n        var rotation = 0.0\n        when (orientation) {\n            Orientation.LEFT -> {\n                titleLocation =\n                    DoubleVector(plotBounds.left + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y)\n                rotation = -90.0\n            }\n            Orientation.RIGHT -> {\n                titleLocation =\n                    DoubleVector(plotBounds.right - PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y)\n                rotation = 90.0\n            }\n            Orientation.TOP -> titleLocation =\n                DoubleVector(geomBounds.center.x, plotBounds.top + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN)\n            Orientation.BOTTOM -> titleLocation =\n                DoubleVector(geomBounds.center.x, plotBounds.bottom - PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN)\n        }\n\n        val titleLabel = TextLabel(text)\n        titleLabel.setHorizontalAnchor(horizontalAnchor)\n        titleLabel.setVerticalAnchor(verticalAnchor)\n        titleLabel.moveTo(titleLocation)\n        titleLabel.rotate(rotation)\n\n        val titleElement = titleLabel.rootGroup\n        titleElement.addClass(Style.AXIS_TITLE)\n\n        // hack: we have style: \".axis .title text\" and we don't want to break backward-compatibility with 'census' charts\n        val parent = SvgGElement()\n        parent.addClass(Style.AXIS)\n\n        parent.children().add(titleElement)\n\n        add(parent)\n    }\n\n    private fun onMouseMove(e: SvgElement, message: String) {\n        e.addEventHandler(SvgEventSpec.MOUSE_MOVE, object :\n            SvgEventHandler<Event> {\n            override fun handle(node: SvgNode, e: Event) {\n                println(message)\n            }\n        })\n    }\n\n    private fun buildPlotComponents() {\n        val preferredSize = myPreferredSize.get()\n        val overallRect = DoubleRectangle(DoubleVector.ZERO, preferredSize)\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(overallRect)\n            rect.strokeColor().set(Color.MAGENTA)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            onMouseMove(rect, \"MAGENTA: preferred size: $overallRect\")\n            add(rect)\n        }\n\n        // compute geom bounds\n        val entirePlot = if (hasLiveMap()) {\n            liveMapBounds(overallRect)\n        } else {\n            overallRect\n        }\n\n        // subtract title size\n        val withoutTitle = if (hasTitle()) {\n            val titleSize = PlotLayoutUtil.titleDimensions(title)\n            DoubleRectangle(\n                entirePlot.origin.add(DoubleVector(0.0, titleSize.y)),\n                entirePlot.dimension.subtract(DoubleVector(0.0, titleSize.y))\n            )\n        } else {\n            entirePlot\n        }\n\n        // adjust for legend boxes\n        var boxesLayoutResult: LegendBoxesLayout.Result? = null\n        val legendTheme = theme.legend()\n        val withoutTitleAndLegends = if (legendTheme.position().isFixed) {\n            val legendBoxesLayout =\n                LegendBoxesLayout(withoutTitle, legendTheme)\n            boxesLayoutResult = legendBoxesLayout.doLayout(legendBoxInfos)\n            boxesLayoutResult.plotInnerBoundsWithoutLegendBoxes\n        } else {\n            withoutTitle\n        }\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(withoutTitleAndLegends)\n            rect.strokeColor().set(Color.BLUE)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            onMouseMove(rect, \"BLUE: plot without title and legends: $withoutTitleAndLegends\")\n            add(rect)\n        }\n\n        // subtract left axis title width\n        var geomAndAxis = withoutTitleAndLegends\n        if (isAxisEnabled) {\n            if (hasAxisTitleLeft()) {\n                val titleSize = PlotLayoutUtil.axisTitleDimensions(axisTitleLeft)\n                val thickness =\n                    titleSize.y + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil.AXIS_TITLE_INNER_MARGIN\n                geomAndAxis = DoubleRectangle(\n                    geomAndAxis.left + thickness, geomAndAxis.top,\n                    geomAndAxis.width - thickness, geomAndAxis.height\n                )\n            }\n\n            // subtract bottom axis title height\n            if (hasAxisTitleBottom()) {\n                val titleSize = PlotLayoutUtil.axisTitleDimensions(axisTitleBottom)\n                val thickness =\n                    titleSize.y + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil.AXIS_TITLE_INNER_MARGIN\n                geomAndAxis = DoubleRectangle(\n                    geomAndAxis.left, geomAndAxis.top,\n                    geomAndAxis.width, geomAndAxis.height - thickness\n                )\n            }\n        }\n\n        // Layout plot inners\n        val plotLayout = plotLayout()\n        val plotInfo = plotLayout.doLayout(geomAndAxis.dimension)\n        this.myLaidOutSize.set(preferredSize)\n\n        if (plotInfo.tiles.isEmpty()) {\n            return\n        }\n\n        val geomAreaBounds = PlotLayoutUtil.absoluteGeomBounds(geomAndAxis.origin, plotInfo)\n        if (legendTheme.position().isOverlay) {\n            // put 'overlay' in 'geom' bounds\n            val legendBoxesLayout = LegendBoxesLayout(geomAreaBounds, legendTheme)\n            boxesLayoutResult = legendBoxesLayout.doLayout(legendBoxInfos)\n        }\n\n        // build tiles\n        val tileTheme = if(plotInfo.tiles.size > 1) {\n            theme.multiTile()\n        } else {\n            theme\n        }\n\n        val tilesOrigin = geomAndAxis.origin\n        for (tileLayoutInfo in plotInfo.tiles) {\n//        for (i in plotInfo.tiles.indices) {\n//            val tileLayoutInfo = plotInfo.tiles[i]\n            val tileLayersIndex = tileLayoutInfo.trueIndex\n\n//            println(\"plot offset: \" + tileInfo.plotOffset)\n//            println(\"     bounds: \" + tileInfo.bounds)\n//            println(\"geom bounds: \" + tileInfo.geomBounds)\n//            println(\"clip bounds: \" + tileInfo.clipBounds)\n            val tile = createTile(tilesOrigin, tileLayoutInfo, tileLayers(tileLayersIndex), tileTheme)\n\n            val plotOriginAbsolute = tilesOrigin.add(tileLayoutInfo.plotOrigin)\n            tile.moveTo(plotOriginAbsolute)\n\n            add(tile)\n\n            tile.liveMapFigure?.let(myLiveMapFigures::add)\n\n            val geomBoundsAbsolute = tileLayoutInfo.geomBounds.add(plotOriginAbsolute)\n            myTooltipHelper.addTileInfo(geomBoundsAbsolute, tile.targetLocators)\n        }\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(geomAreaBounds)\n            rect.strokeColor().set(Color.RED)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            add(rect)\n        }\n\n        // add plot title\n        if (hasTitle()) {\n            val titleLabel = TextLabel(title)\n            titleLabel.addClassName(Style.PLOT_TITLE)\n            titleLabel.setHorizontalAnchor(HorizontalAnchor.LEFT)\n            titleLabel.setVerticalAnchor(VerticalAnchor.CENTER)\n\n            val titleSize = PlotLayoutUtil.titleDimensions(title)\n            val titleBounds = DoubleRectangle(geomAreaBounds.origin.x, 0.0, titleSize.x, titleSize.y)\n            titleLabel.moveTo(DoubleVector(titleBounds.left, titleBounds.center.y))\n            add(titleLabel)\n\n            @Suppress(\"ConstantConditionIf\")\n            if (DEBUG_DRAWING) {\n                val rect = SvgRectElement(titleBounds)\n                rect.strokeColor().set(Color.BLUE)\n                rect.strokeWidth().set(1.0)\n                rect.fillOpacity().set(0.0)\n                add(rect)\n            }\n        }\n\n        // add axis titles\n        if (isAxisEnabled) {\n            if (hasAxisTitleLeft()) {\n                createAxisTitle(\n                    axisTitleLeft,\n                    Orientation.LEFT,\n                    withoutTitleAndLegends,\n                    geomAreaBounds\n                )\n            }\n            if (hasAxisTitleBottom()) {\n                createAxisTitle(\n                    axisTitleBottom,\n                    Orientation.BOTTOM,\n                    withoutTitleAndLegends,\n                    geomAreaBounds\n                )\n            }\n        }\n\n        // add legends\n        if (boxesLayoutResult != null) {\n            for (boxWithLocation in boxesLayoutResult.boxWithLocationList) {\n                val legendBox = boxWithLocation.legendBox.createLegendBox()\n                legendBox.moveTo(boxWithLocation.location)\n                add(legendBox)\n            }\n        }\n    }\n\n    fun createTooltipSpecs(plotCoord: DoubleVector): List<TooltipSpec> {\n        return myTooltipHelper.createTooltipSpecs(plotCoord)\n    }\n\n    fun getGeomBounds(plotCoord: DoubleVector): DoubleRectangle? {\n        return myTooltipHelper.getGeomBounds(plotCoord)\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(Plot::class)\n\n        private val DEF_PLOT_SIZE = DoubleVector(600.0, 400.0)\n        private const val DEBUG_DRAWING = PLOT_DEBUG_DRAWING\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.layout.PlotLayout\nimport jetbrains.datalore.plot.builder.theme.Theme\n\nclass PlotBuilder(private val myTheme: Theme) {\n    private val myLayersByTile = ArrayList<List<GeomLayer>>()\n    private var myTitle: String? = null\n    private lateinit var myCoordProvider: CoordProvider\n    private var myLayout: PlotLayout? = null\n    private var myAxisTitleLeft: String? = null\n    private var myAxisTitleBottom: String? = null\n    private val myLegendBoxInfos = ArrayList<LegendBoxInfo>()\n    private lateinit var myScaleXProto: Scale<Double>\n    private lateinit var myScaleYProto: Scale<Double>\n    private var myAxisEnabled = true\n    private var myInteractionsEnabled = true\n    private var hasLiveMap = false\n\n    fun setTitle(title: String?) {\n        myTitle = title\n    }\n\n    fun setAxisTitleLeft(v: String) {\n        myAxisTitleLeft = v\n    }\n\n    fun setAxisTitleBottom(v: String) {\n        myAxisTitleBottom = v\n    }\n\n    fun setCoordProvider(coordProvider: CoordProvider): PlotBuilder {\n        myCoordProvider = coordProvider\n        return this\n    }\n\n    fun addTileLayers(tileLayers: List<GeomLayer>): PlotBuilder {\n        myLayersByTile.add(ArrayList(tileLayers))\n        return this\n    }\n\n    fun setPlotLayout(layout: PlotLayout): PlotBuilder {\n        myLayout = layout\n        return this\n    }\n\n    fun addLegendBoxInfo(v: LegendBoxInfo): PlotBuilder {\n        myLegendBoxInfos.add(v)\n        return this\n    }\n\n    fun scaleXProto(scaleXProto: Scale<Double>): PlotBuilder {\n        myScaleXProto = scaleXProto\n        return this\n    }\n\n    fun scaleYProto(scaleYProto: Scale<Double>): PlotBuilder {\n        myScaleYProto = scaleYProto\n        return this\n    }\n\n    fun axisEnabled(b: Boolean): PlotBuilder {\n        myAxisEnabled = b\n        return this\n    }\n\n    fun interactionsEnabled(b: Boolean): PlotBuilder {\n        myInteractionsEnabled = b\n        return this\n    }\n\n    fun setLiveMap(b: Boolean): PlotBuilder {\n        hasLiveMap = b\n        return this\n    }\n\n    fun build(): Plot {\n        return MyPlot(this)\n    }\n\n    private class MyPlot(b: PlotBuilder) : Plot(b.myTheme) {\n        override val scaleXProto: Scale<Double> = b.myScaleXProto\n        override val scaleYProto: Scale<Double> = b.myScaleYProto\n\n        private val myTitle: String? = b.myTitle\n        private val myAxisTitleLeft: String? = b.myAxisTitleLeft\n        private val myAxisTitleBottom: String? = b.myAxisTitleBottom\n        private val myAxisXTitleEnabled: Boolean = b.myTheme.axisX().showTitle()\n        private val myAxisYTitleEnabled: Boolean = b.myTheme.axisY().showTitle()\n\n        override val coordProvider: CoordProvider = b.myCoordProvider\n\n        private val myLayersByTile: List<List<GeomLayer>>\n        private val myLayout: PlotLayout?\n        private val myLegendBoxInfos: List<LegendBoxInfo>\n        private val hasLiveMap: Boolean\n\n        override val isAxisEnabled: Boolean\n        override val isInteractionsEnabled: Boolean\n\n        override val title: String\n            get() {\n                require(hasTitle()) { \"No title\" }\n                return myTitle!!\n            }\n\n        override val axisTitleLeft: String\n            get() {\n                require(hasAxisTitleLeft()) { \"No left axis title\" }\n                return myAxisTitleLeft!!\n            }\n\n        override val axisTitleBottom: String\n            get() {\n                require(hasAxisTitleBottom()) { \"No bottom axis title\" }\n                return myAxisTitleBottom!!\n            }\n\n        override val legendBoxInfos: List<LegendBoxInfo>\n            get() = myLegendBoxInfos\n\n        init {\n            myLayersByTile = ArrayList(b.myLayersByTile)\n            myLayout = b.myLayout\n            myLegendBoxInfos = ArrayList(b.myLegendBoxInfos)\n\n            hasLiveMap = b.hasLiveMap\n\n            isAxisEnabled = b.myAxisEnabled\n            isInteractionsEnabled = b.myInteractionsEnabled\n        }\n\n        override fun hasTitle(): Boolean {\n            return !Strings.isNullOrEmpty(myTitle)\n        }\n\n        override fun hasAxisTitleLeft(): Boolean {\n            return myAxisYTitleEnabled && !Strings.isNullOrEmpty(myAxisTitleLeft)\n        }\n\n        override fun hasAxisTitleBottom(): Boolean {\n            return myAxisXTitleEnabled && !Strings.isNullOrEmpty(myAxisTitleBottom)\n        }\n\n        override fun hasLiveMap(): Boolean {\n            return hasLiveMap\n        }\n\n        override fun tileLayers(tileIndex: Int): List<GeomLayer> {\n            return myLayersByTile[tileIndex]\n        }\n\n        override fun plotLayout(): PlotLayout {\n            return myLayout!!\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ReadableProperty\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.plot.builder.presentation.Style.PLOT_BACKDROP\nimport jetbrains.datalore.vis.svg.SvgCssResource\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.SvgSvgElement\nimport kotlin.math.max\n\n/**\n *  This class only handles static SVG. (no interactions)\n */\nopen class PlotContainerPortable(\n    protected val plot: Plot,\n    private val preferredSize: ReadableProperty<DoubleVector>\n) {\n\n    val svg: SvgSvgElement = SvgSvgElement()\n\n    val liveMapFigures: List<SomeFig>\n        get() = plot.liveMapFigures\n\n    val isLiveMap: Boolean\n        get() = plot.liveMapFigures.isNotEmpty()\n\n    private var myContentBuilt: Boolean = false\n    private var myRegistrations = CompositeRegistration()\n\n    init {\n        svg.addClass(Style.PLOT_CONTAINER)\n        setSvgSize(preferredSize.get())\n\n        plot.laidOutSize().addHandler(sizePropHandler { laidOutSize ->\n            val newSvgSize = DoubleVector(\n                max(preferredSize.get().x, laidOutSize.x),\n                max(preferredSize.get().y, laidOutSize.y)\n            )\n            setSvgSize(newSvgSize)\n        })\n\n        preferredSize.addHandler(sizePropHandler { newPreferredSize ->\n            if (newPreferredSize.x > 0 && newPreferredSize.y > 0) {\n                revalidateContent()\n            }\n        })\n    }\n\n    fun ensureContentBuilt() {\n        if (!myContentBuilt) {\n            buildContent()\n        }\n    }\n\n    private fun revalidateContent() {\n        if (myContentBuilt) {\n            clearContent()\n            buildContent()\n        }\n    }\n\n    protected open fun buildContent() {\n        check(!myContentBuilt)\n        myContentBuilt = true\n\n        svg.setStyle(object : SvgCssResource {\n            override fun css(): String {\n                return Style.css\n            }\n        })\n\n        // Add Plot background.\n\n        // Batik doesn't seem to support any styling (via 'style' element or 'style' attribute)\n        // of root <svg>-element.\n        // Therefore the 'backdrop' rectungle is necessary.\n        val backdrop = SvgRectElement()\n        backdrop.addClass(PLOT_BACKDROP)\n\n        // Jfx Scene ignores these values (percentage is not supported).\n        // In the case of Jfx Scene the 'backdrop' rectungle has visibility=hidden\n        // and styling of the root <svg>-element is used.\n        // (see: 'resources/svgMapper/jfx/plot.css' in plot-builder)\n        backdrop.setAttribute(\"width\", \"100%\")\n        backdrop.setAttribute(\"height\", \"100%\")\n\n        // This works for DOM / Batik but ignored by JFX Scene\n        // Also, 'width'/'height' attributes are required by Batik.\n        // (or it fails with org.apache.batik.bridge.BridgeException)\n//        backdrop.setAttribute(SVG_STYLE_ATTRIBUTE, \"width: 100%; height: 100%\")\n\n        svg.children().add(backdrop)\n\n        plot.preferredSize().set(preferredSize.get())\n        svg.children().add(plot.rootGroup)\n    }\n\n    open fun clearContent() {\n        if (myContentBuilt) {\n            myContentBuilt = false\n\n            svg.children().clear()\n            plot.clear()\n            myRegistrations.remove()\n            myRegistrations = CompositeRegistration()\n        }\n    }\n\n    protected fun reg(registration: Registration) {\n        myRegistrations.add(registration)\n    }\n\n    private fun setSvgSize(size: DoubleVector) {\n        svg.width().set(size.x)\n        svg.height().set(size.y)\n    }\n\n    companion object {\n        private fun sizePropHandler(block: (newValue: DoubleVector) -> Unit): EventHandler<PropertyChangeEvent<out DoubleVector>> {\n            return object : EventHandler<PropertyChangeEvent<out DoubleVector>> {\n                override fun onEvent(event: PropertyChangeEvent<out DoubleVector>) {\n                    val newValue = event.newValue\n                    if (newValue != null) {\n                        block.invoke(newValue)\n                    }\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.geom.LiveMapGeom\nimport jetbrains.datalore.plot.base.geom.LiveMapProvider\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.assemble.GeomContextBuilder\nimport jetbrains.datalore.plot.builder.guide.AxisComponent\nimport jetbrains.datalore.plot.builder.interact.loc.LayerTargetCollectorWithLocator\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_H_PADDING\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_TAB_HEIGHT\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_V_PADDING\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.facetColHeadHeight\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.facetColLabelSize\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.layout.TileLayoutInfo\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport jetbrains.datalore.plot.builder.theme.FacetsTheme\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\ninternal class PlotTile(\n    layers: List<GeomLayer>,\n    private val myScaleX: Scale<Double>,\n    private val myScaleY: Scale<Double>,\n    private val myTilesOrigin: DoubleVector,\n    private val myLayoutInfo: TileLayoutInfo,\n    private val myCoord: CoordinateSystem,\n    private val myTheme: Theme\n) : SvgComponent() {\n\n    private val myDebugDrawing = ValueProperty(false)\n    private val myLayers: List<GeomLayer>\n    private val myTargetLocators = ArrayList<GeomTargetLocator>()\n    private var myShowAxis: Boolean = false\n\n    var liveMapFigure: SomeFig? = null\n        private set\n\n    val targetLocators: List<GeomTargetLocator>\n        get() = myTargetLocators\n\n    private val isDebugDrawing: Boolean\n        get() = myDebugDrawing.get()\n\n    init {\n        myLayers = ArrayList(layers)\n\n        moveTo(myLayoutInfo.getAbsoluteBounds(myTilesOrigin).origin)\n    }\n\n    override fun buildComponent() {\n        /*\n    // Don't set this flag: it was harmless when we were using SvgNodeSubtreeGeneratingSynchronizer but with new\n    // SvgNodeSubtreeBufferGeneratingSynchronizer this leads to having all svg event handlers ignored\n    // because the entire plot panel will be generated to a string buffer.\n    // We want event handlers to be called on SvgElement-s\n    getRootGroup().setPrebuiltSubtree(true);\n    */\n\n        val geomBounds = myLayoutInfo.geomBounds\n\n        if (myTheme.plot().showInnerFrame()) {\n            val rect = SvgRectElement(geomBounds).apply {\n                strokeColor().set(myTheme.plot().innerFrameColor())\n                strokeWidth().set(1.0)\n                fillOpacity().set(0.0)\n            }\n            add(rect)\n        }\n\n        addFacetLabels(geomBounds, myTheme.facets())\n\n        val liveMapGeomLayer = myLayers.firstOrNull { it.isLiveMap }\n        if (liveMapGeomLayer == null && myShowAxis) {\n            addAxis(geomBounds)\n        }\n\n        if (isDebugDrawing) {\n            val tileBounds = myLayoutInfo.bounds\n            val rect = SvgRectElement(tileBounds)\n            rect.fillColor().set(Color.BLACK)\n            rect.strokeWidth().set(0.0)\n            rect.fillOpacity().set(0.1)\n            add(rect)\n        }\n\n        if (isDebugDrawing) {\n            val clipBounds = myLayoutInfo.clipBounds\n            val rect = SvgRectElement(clipBounds)\n            rect.fillColor().set(Color.DARK_GREEN)\n            rect.strokeWidth().set(0.0)\n            rect.fillOpacity().set(0.3)\n            add(rect)\n        }\n\n        if (isDebugDrawing) {\n            val rect = SvgRectElement(geomBounds)\n            rect.fillColor().set(Color.PINK)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.5)\n            add(rect)\n        }\n\n        // render geoms\n\n        if (liveMapGeomLayer != null) {\n            val realBounds = myLayoutInfo.getAbsoluteGeomBounds(myTilesOrigin)\n\n            val liveMapData = liveMapGeomLayer.createCanvasFigure(realBounds)\n\n            liveMapFigure = liveMapData.canvasFigure\n            myTargetLocators.add(liveMapData.targetLocator)\n        } else {\n            // normal plot tile\n            val sharedNumericMappers = HashMap<Aes<Double>, (Double?) -> Double?>()\n            val overallNumericDomains = HashMap<Aes<Double>, ClosedRange<Double>>()\n\n            val xAxisInfo = myLayoutInfo.xAxisInfo\n            val yAxisInfo = myLayoutInfo.yAxisInfo\n            val mapperX = myScaleX.mapper\n            val mapperY = myScaleY.mapper\n\n            sharedNumericMappers[Aes.X] = mapperX\n            sharedNumericMappers[Aes.Y] = mapperY\n            sharedNumericMappers[Aes.SLOPE] = Mappers.mul(mapperY(1.0)!! / mapperX(1.0)!!)\n\n            overallNumericDomains[Aes.X] = xAxisInfo!!.axisDomain!!\n            overallNumericDomains[Aes.Y] = yAxisInfo!!.axisDomain!!\n\n            val geomLayerComponents = buildGeoms(sharedNumericMappers, overallNumericDomains, myCoord)\n            for (layerComponent in geomLayerComponents) {\n                layerComponent.moveTo(geomBounds.origin)\n\n                val xRange = myCoord.xClientLimit ?: ClosedRange(0.0, geomBounds.width)\n                val yRange = myCoord.yClientLimit ?: ClosedRange(0.0, geomBounds.height)\n                val clipRect = GeometryUtil.doubleRange(xRange, yRange)\n\n                layerComponent.clipBounds(clipRect)\n                add(layerComponent)\n            }\n        }\n    }\n\n    private fun addFacetLabels(geomBounds: DoubleRectangle, theme: FacetsTheme) {\n        // facet X label (on top of geom area)\n        val xLabels = myLayoutInfo.facetXLabels\n        if (xLabels.isNotEmpty()) {\n            val labelSize = facetColLabelSize(geomBounds.width)\n            val labelOrig = DoubleVector(\n                geomBounds.left + FACET_H_PADDING,\n                geomBounds.top - facetColHeadHeight(xLabels.size) + FACET_V_PADDING\n            )\n            var labelBounds = DoubleRectangle(\n                labelOrig, labelSize\n            )\n            for (xLabel in xLabels) {\n                val rect = SvgRectElement(labelBounds).apply {\n                    strokeWidth().set(0.0)\n                    fillColor().set(theme.labelBackground())\n\n//                    strokeWidth().set(1.0)\n//                    strokeColor().set(Color.BLACK)\n//                    fillOpacity().set(0.0)\n                }\n                add(rect)\n\n                val x = labelBounds.center.x\n                val y = labelBounds.center.y\n                val lab = TextLabel(xLabel)\n                lab.moveTo(x, y)\n                lab.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                lab.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n                add(lab)\n\n                labelBounds = labelBounds.add(DoubleVector(0.0, labelSize.y))\n            }\n        }\n\n        // facet Y label (to the right from geom area)\n        if (myLayoutInfo.facetYLabel != null) {\n\n            val hPad = FACET_V_PADDING\n            val vPad = FACET_H_PADDING\n\n            val labelBounds = DoubleRectangle(\n                geomBounds.right + hPad, geomBounds.top - vPad,\n                FACET_TAB_HEIGHT - hPad * 2, geomBounds.height - vPad * 2\n            )\n            val rect = SvgRectElement(labelBounds)\n            rect.strokeWidth().set(0.0)\n            rect.fillColor().set(theme.labelBackground())\n            add(rect)\n\n            val x = labelBounds.center.x\n            val y = labelBounds.center.y\n\n            val lab = TextLabel(myLayoutInfo.facetYLabel)\n            lab.moveTo(x, y)\n            lab.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n            lab.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n            lab.rotate(90.0)\n            add(lab)\n        }\n    }\n\n    private fun addAxis(geomBounds: DoubleRectangle) {\n        // X axis (below geom area)\n        if (myLayoutInfo.xAxisShown) {\n            val axis = buildAxis(myScaleX, myLayoutInfo.xAxisInfo!!, myCoord, myTheme.axisX())\n            axis.moveTo(DoubleVector(geomBounds.left, geomBounds.bottom))\n            add(axis)\n        }\n        // Y axis (to the left from geom area, axis elements have negative x-positions)\n        if (myLayoutInfo.yAxisShown) {\n            val axis = buildAxis(myScaleY, myLayoutInfo.yAxisInfo!!, myCoord, myTheme.axisY())\n            axis.moveTo(geomBounds.origin)\n            add(axis)\n        }\n    }\n\n    private fun buildAxis(\n        scale: Scale<Double>,\n        info: AxisLayoutInfo,\n        coord: CoordinateSystem,\n        theme: AxisTheme\n    ): AxisComponent {\n        val axis =\n            AxisComponent(info.axisLength, info.orientation!!)\n        AxisUtil.setBreaks(axis, scale, coord, info.orientation.isHorizontal)\n        AxisUtil.applyLayoutInfo(axis, info)\n        AxisUtil.applyTheme(axis, theme)\n        if (isDebugDrawing) {\n            if (info.tickLabelsBounds != null) {\n                val rect = SvgRectElement(info.tickLabelsBounds)\n                rect.strokeColor().set(Color.GREEN)\n                rect.strokeWidth().set(1.0)\n                rect.fillOpacity().set(0.0)\n                axis.add(rect)\n            }\n        }\n        return axis\n    }\n\n    private fun buildGeoms(\n        sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>,\n        overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>,\n        coord: CoordinateSystem\n    ): List<SvgComponent> {\n\n        val layerRenderers = ArrayList<SvgComponent>()\n        for (layer in myLayers) {\n            val rendererData = LayerRendererUtil.createLayerRendererData(\n                layer,\n                sharedNumericMappers,\n                overallNumericDomains\n            )\n\n            val aestheticMappers = rendererData.aestheticMappers\n            val aesthetics = rendererData.aesthetics\n\n            val targetCollector = LayerTargetCollectorWithLocator(\n                layer.geomKind,\n                layer.locatorLookupSpec,\n                layer.contextualMapping,\n                coord\n            )\n            myTargetLocators.add(targetCollector)\n\n            val ctx = GeomContextBuilder()\n                .aesthetics(aesthetics)\n                .aestheticMappers(aestheticMappers)\n                .geomTargetCollector(targetCollector)\n                .build()\n\n            val pos = rendererData.pos\n            val geom = layer.geom\n\n            layerRenderers.add(SvgLayerRenderer(aesthetics, geom, pos, coord, ctx))\n        }\n        return layerRenderers\n    }\n\n    fun setShowAxis(showAxis: Boolean) {\n        myShowAxis = showAxis\n    }\n\n    fun debugDrawing(): Property<Boolean> {\n        return myDebugDrawing\n    }\n}\n\nprivate fun GeomLayer.createCanvasFigure(bounds: DoubleRectangle): LiveMapProvider.LiveMapData {\n    return (geom as LiveMapGeom).createCanvasFigure(bounds)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult\nimport jetbrains.datalore.plot.builder.interact.TooltipSpec\nimport jetbrains.datalore.plot.builder.interact.TooltipSpecFactory\nimport jetbrains.datalore.plot.builder.interact.loc.LocatedTargetsPicker\nimport jetbrains.datalore.plot.builder.interact.loc.TransformedTargetLocator\n\ninternal class PlotTooltipHelper {\n    private val myTileInfos = ArrayList<TileInfo>()\n\n    fun removeAllTileInfos() {\n        myTileInfos.clear()\n    }\n\n    fun addTileInfo(geomBounds: DoubleRectangle, targetLocators: List<GeomTargetLocator>) {\n        val tileInfo = TileInfo(\n            geomBounds,\n            targetLocators\n        )\n        myTileInfos.add(tileInfo)\n    }\n\n    fun createTooltipSpecs(plotCoord: DoubleVector): List<TooltipSpec> {\n        val tileInfo = findTileInfo(plotCoord) ?: return emptyList()\n\n        val lookupResults = tileInfo.findTargets(plotCoord)\n        return createTooltipSpecs(lookupResults, tileInfo.axisOrigin)\n    }\n\n    fun getGeomBounds(plotCoord: DoubleVector): DoubleRectangle? {\n        val tileInfo = findTileInfo(plotCoord) ?: return null\n        return tileInfo.geomBounds\n    }\n\n    private fun findTileInfo(plotCoord: DoubleVector): TileInfo? {\n        for (tileInfo in myTileInfos) {\n            if (tileInfo.contains(plotCoord)) {\n                return tileInfo\n            }\n        }\n\n        return null\n    }\n\n    private fun createTooltipSpecs(lookupResults: List<LookupResult>, axisOrigin: DoubleVector): List<TooltipSpec> {\n        val tooltipSpecs = ArrayList<TooltipSpec>()\n\n        lookupResults.forEach { result ->\n            val factory = TooltipSpecFactory(result.contextualMapping, axisOrigin)\n            result.targets.forEach { geomTarget -> tooltipSpecs.addAll(factory.create(geomTarget)) }\n        }\n\n        return tooltipSpecs\n    }\n\n\n    private class TileInfo(\n        internal val geomBounds: DoubleRectangle,\n        targetLocators: List<GeomTargetLocator>\n    ) {\n\n        private val myTargetLocators = targetLocators.map { TileTargetLocator(it) }\n\n        internal val axisOrigin: DoubleVector\n            get() = DoubleVector(geomBounds.left, geomBounds.bottom)\n\n        internal fun findTargets(plotCoord: DoubleVector): List<LookupResult> {\n            val targetsPicker = LocatedTargetsPicker().apply {\n                for (locator in myTargetLocators) {\n                    val result = locator.search(plotCoord)\n                    if (result != null) {\n                        addLookupResult(result, plotCoord)\n                    }\n                }\n            }\n            return targetsPicker.picked\n        }\n\n        internal operator fun contains(plotCoord: DoubleVector): Boolean {\n            return geomBounds.contains(plotCoord)\n        }\n\n        private inner class TileTargetLocator(locator: GeomTargetLocator) : TransformedTargetLocator(locator) {\n\n            override fun convertToTargetCoord(coord: DoubleVector): DoubleVector {\n                return coord.subtract(geomBounds.origin)\n            }\n\n            override fun convertToPlotCoord(coord: DoubleVector): DoubleVector {\n                return coord.add(geomBounds.origin)\n            }\n\n            override fun convertToPlotDistance(distance: Double): Double {\n                return distance\n            }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Sets\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder.Companion.listMapper\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.assemble.GeomContextBuilder\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isFinite\nimport kotlin.math.max\nimport kotlin.math.min\nimport kotlin.math.sign\n\nobject PlotUtil {\n    internal fun createLayerPos(layer: GeomLayer, aes: Aesthetics): PositionAdjustment {\n        return layer.createPos(object : PosProviderContext {\n            override val aesthetics: Aesthetics\n                get() = aes\n\n            override val groupCount: Int\n                    by lazy {\n                        val set = Sets.newHashSet(aes.groups())\n                        set.size\n                    }\n        })\n    }\n\n    fun computeLayerDryRunXYRanges(\n        layer: GeomLayer, aes: Aesthetics\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val geomCtx = GeomContextBuilder().aesthetics(aes).build()\n\n        val rangesAfterPosAdjustment =\n            computeLayerDryRunXYRangesAfterPosAdjustment(layer, aes, geomCtx)\n        val (xRangeAfterSizeExpand, yRangeAfterSizeExpand) =\n            computeLayerDryRunXYRangesAfterSizeExpand(layer, aes, geomCtx)\n\n        var rangeX = rangesAfterPosAdjustment.first\n        if (rangeX == null) {\n            rangeX = xRangeAfterSizeExpand\n        } else if (xRangeAfterSizeExpand != null) {\n            rangeX = rangeX.span(xRangeAfterSizeExpand)\n        }\n\n        var rangeY = rangesAfterPosAdjustment.second\n        if (rangeY == null) {\n            rangeY = yRangeAfterSizeExpand\n        } else if (yRangeAfterSizeExpand != null) {\n            rangeY = rangeY.span(yRangeAfterSizeExpand)\n        }\n\n        return Pair(rangeX, rangeY)\n    }\n\n    private fun combineRanges(aesList: List<Aes<Double>>, aesthetics: Aesthetics): ClosedRange<Double>? {\n        var result: ClosedRange<Double>? = null\n        for (aes in aesList) {\n            val range = aesthetics.range(aes)\n            if (range != null) {\n                result = result?.span(range) ?: range\n            }\n        }\n        return result\n    }\n\n    private fun computeLayerDryRunXYRangesAfterPosAdjustment(\n        layer: GeomLayer, aes: Aesthetics, geomCtx: GeomContext\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val posAesX = Iterables.toList(Aes.affectingScaleX(layer.renderedAes()))\n        val posAesY = Iterables.toList(Aes.affectingScaleY(layer.renderedAes()))\n\n        val pos = createLayerPos(layer, aes)\n        if (pos.isIdentity) {\n            // simplified ranges\n            val rangeX = combineRanges(posAesX, aes)\n            val rangeY = combineRanges(posAesY, aes)\n            return Pair(rangeX, rangeY)\n        }\n\n        var adjustedMinX = 0.0\n        var adjustedMaxX = 0.0\n        var adjustedMinY = 0.0\n        var adjustedMaxY = 0.0\n        var rangesInited = false\n\n        val cardinality = posAesX.size * posAesY.size\n        val px = arrayOfNulls<Double>(cardinality)\n        val py = arrayOfNulls<Double>(cardinality)\n        for (p in aes.dataPoints()) {\n            var i = -1\n            for (aesX in posAesX) {\n                val valX = p.numeric(aesX)\n                for (aesY in posAesY) {\n                    val valY = p.numeric(aesY)\n                    i++\n                    px[i] = valX\n                    py[i] = valY\n                }\n            }\n\n            while (i >= 0) {\n                if (px[i] != null && py[i] != null) {\n                    val x = px[i]\n                    val y = py[i]\n                    if (isFinite(x) && isFinite(y)) {\n                        val newLoc = pos.translate(DoubleVector(x!!, y!!), p, geomCtx)\n                        val adjustedX = newLoc.x\n                        val adjustedY = newLoc.y\n                        if (rangesInited) {\n                            adjustedMinX = min(adjustedX, adjustedMinX)\n                            adjustedMaxX = max(adjustedX, adjustedMaxX)\n                            adjustedMinY = min(adjustedY, adjustedMinY)\n                            adjustedMaxY = max(adjustedY, adjustedMaxY)\n                        } else {\n                            adjustedMaxX = adjustedX\n                            adjustedMinX = adjustedMaxX\n                            adjustedMaxY = adjustedY\n                            adjustedMinY = adjustedMaxY\n                            rangesInited = true\n                        }\n                    }\n                }\n                i--\n            }\n        }\n\n        // X range\n        val xRange = if (rangesInited)\n            ClosedRange(adjustedMinX, adjustedMaxX)\n        else\n            null\n\n        val yRange = if (rangesInited)\n            ClosedRange(adjustedMinY, adjustedMaxY)\n        else\n            null\n        return Pair(xRange, yRange)\n    }\n\n    private fun computeLayerDryRunXYRangesAfterSizeExpand(\n        layer: GeomLayer,\n        aesthetics: Aesthetics,\n        geomCtx: GeomContext\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val renderedAes = layer.renderedAes()\n        val computeExpandX = renderedAes.contains(Aes.WIDTH)\n        val computeExpandY = renderedAes.contains(Aes.HEIGHT)\n        val rangeX = if (computeExpandX)\n            computeLayerDryRunRangeAfterSizeExpand(\n                Aes.X,\n                Aes.WIDTH,\n                aesthetics,\n                geomCtx\n            )\n        else\n            null\n        val rangeY = if (computeExpandY)\n            computeLayerDryRunRangeAfterSizeExpand(\n                Aes.Y,\n                Aes.HEIGHT,\n                aesthetics,\n                geomCtx\n            )\n        else\n            null\n\n        return Pair(rangeX, rangeY)\n    }\n\n    private fun computeLayerDryRunRangeAfterSizeExpand(\n        locationAes: Aes<Double>, sizeAes: Aes<Double>, aesthetics: Aesthetics, geomCtx: GeomContext\n    ): ClosedRange<Double>? {\n        val locations = aesthetics.numericValues(locationAes).iterator()\n        val sizes = aesthetics.numericValues(sizeAes).iterator()\n\n        val resolution = geomCtx.getResolution(locationAes)\n        val minMax = doubleArrayOf(Double.POSITIVE_INFINITY, Double.NEGATIVE_INFINITY)\n\n        for (i in 0 until aesthetics.dataPointCount()) {\n            if (!locations.hasNext()) {\n                throw IllegalStateException(\"Index is out of bounds: $i for $locationAes\")\n            }\n            if (!sizes.hasNext()) {\n                throw IllegalStateException(\"Index is out of bounds: $i for $sizeAes\")\n            }\n            val loc = locations.next()\n            val size = sizes.next()\n            if (isFinite(loc) && isFinite(size)) {\n                val expand = resolution * (size!! / 2)\n                updateExpandedMinMax(loc!!, expand, minMax)\n            }\n        }\n\n        return if (minMax[0] <= minMax[1])\n            ClosedRange(minMax[0], minMax[1])\n        else\n            null\n    }\n\n    private fun updateExpandedMinMax(value: Double, expand: Double, expandedMinMax: DoubleArray) {\n        expandedMinMax[0] = min(value - expand, expandedMinMax[0])\n        expandedMinMax[1] = max(value + expand, expandedMinMax[1])\n    }\n\n    fun createLayerDryRunAesthetics(layer: GeomLayer): Aesthetics {\n        val dryRunMapperByAes = HashMap<Aes<Double>, (Double?) -> Double?>()\n        for (aes in layer.renderedAes()) {\n            if (aes.isNumeric) {\n                // safe cast: 'numeric' aes is always <Double>\n                @Suppress(\"UNCHECKED_CAST\")\n                dryRunMapperByAes[aes as Aes<Double>] = Mappers.IDENTITY\n            }\n        }\n\n        val mappers = prepareLayerAestheticMappers(layer, dryRunMapperByAes)\n        return createLayerAesthetics(layer, mappers, emptyMap())\n    }\n\n    internal fun prepareLayerAestheticMappers(\n        layer: GeomLayer,\n        sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>\n    ): Map<Aes<*>, (Double?) -> Any?> {\n\n        val mappers = HashMap<Aes<*>, (Double?) -> Any?>(sharedNumericMappers)\n        for (aes in layer.renderedAes()) {\n            var mapper: ((Double?) -> Any?)? = sharedNumericMappers[aes]\n            if (mapper == null) {\n                // positional aes share their mappers\n                if (Aes.isPositionalX(aes)) {\n                    mapper = sharedNumericMappers[Aes.X]\n                } else if (Aes.isPositionalY(aes)) {\n                    mapper = sharedNumericMappers[Aes.Y]\n                }\n            }\n            if (mapper == null && layer.hasBinding(aes)) {\n                mapper = layer.scaleMap[aes].mapper\n            }\n\n            if (mapper != null) {\n                mappers[aes] = mapper\n            }\n        }\n        return mappers\n    }\n\n    internal fun createLayerAesthetics(\n        layer: GeomLayer,\n        sharedMappers: Map<Aes<*>, (Double?) -> Any?>,\n        overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>\n    ): Aesthetics {\n\n        val aesBuilder = AestheticsBuilder()\n        aesBuilder.group(layer.group)\n        for ((aes, domain) in overallNumericDomains) {\n            sharedMappers[aes]?.let { mapper ->\n                val range = ClosedRange(\n                    mapper(domain.lowerEnd) as Double,\n                    mapper(domain.upperEnd) as Double\n                )\n                aesBuilder.overallRange(aes, range)\n            }\n        }\n\n        var hasPositionalConstants = false\n        for (aes in layer.renderedAes()) {\n            if (Aes.isPositional(aes) && layer.hasConstant(aes)) {\n                hasPositionalConstants = true\n                break\n            }\n        }\n\n        val data = layer.dataFrame\n        var dataPointCount: Int? = null\n        for (aes in layer.renderedAes()) {\n            @Suppress(\"UNCHECKED_CAST\", \"NAME_SHADOWING\")\n            val aes = aes as Aes<Any>\n\n            val mapperOption = sharedMappers[aes]\n            if (layer.hasConstant(aes)) {\n                // Constant overrides binding\n                val v = layer.getConstant(aes)\n                aesBuilder.constantAes(aes, asAesValue(aes, v, mapperOption))\n            } else {\n                // No constant - look-up aes mapping\n                if (layer.hasBinding(aes)) {\n                    check(mapperOption != null) { \"No scale mapper defined for aesthetic $aes\" }\n\n                    // variable at this point must be either STAT or TRANSFORM (but not ORIGIN)\n                    val transformVar = DataFrameUtil.transformVarFor(aes)\n                    check(data.has(transformVar)) { \"Undefined var $transformVar for aesthetic $aes\" }\n                    val numericValues = data.getNumeric(transformVar)\n\n                    if (dataPointCount == null) {\n                        dataPointCount = numericValues.size\n                    } else {\n                        check(dataPointCount == numericValues.size)\n                        { \"\" + aes + \" expected data size=\" + dataPointCount + \" was size=\" + numericValues.size }\n                    }\n\n                    if (dataPointCount == 0 && hasPositionalConstants) {\n                        // put constant instead of empty list\n                        aesBuilder.constantAes(aes, layer.aestheticsDefaults.defaultValue(aes))\n                    } else {\n                        val integerFunction = listMapper(numericValues, mapperOption)\n                        aesBuilder.aes(aes, integerFunction)\n                    }\n                } else {\n                    // apply default\n                    val v = layer.getDefault(aes)\n                    aesBuilder.constantAes(\n                        aes,\n                        asAesValue(aes, v, mapperOption)\n                    )\n                }\n            }\n        }\n\n        if (dataPointCount != null && dataPointCount > 0) {\n            aesBuilder.dataPointCount(dataPointCount)\n        } else if (hasPositionalConstants) {\n            // some geoms (point, abline etc.) can be plotted with only constants\n            aesBuilder.dataPointCount(1)\n        }\n\n        return aesBuilder.build()\n    }\n\n    private fun <T> asAesValue(aes: Aes<*>, dataValue: T, mapperOption: ((Double?) -> T?)?): T {\n        return if (aes.isNumeric && mapperOption != null) {\n            mapperOption(dataValue as? Double)\n                ?: throw IllegalArgumentException(\"Can't map $dataValue to aesthetic $aes\")\n        } else dataValue\n    }\n\n    /**\n     * Expand X/Y-range to ensure that the data is placed some distance away from the axes.\n     */\n    fun rangeWithExpand(\n        layer: GeomLayer,\n        aes: Aes<Double>,\n        range: ClosedRange<Double>?\n    ): ClosedRange<Double>? {\n        if (range == null) return null\n\n        val scale = layer.scaleMap[aes]\n        val mulExp = scale.multiplicativeExpand\n        val addExp = scale.additiveExpand\n\n        // Compute expands in terms of the original data.\n        // Otherwise can easily run into Infinities then using 'log10' transform\n        val continuousTransform: ContinuousTransform? = if (scale.isContinuousDomain) {\n            scale.transform as ContinuousTransform\n        } else {\n            null\n        }\n\n        val lowerEndpoint = continuousTransform?.applyInverse(range.lowerEnd) ?: range.lowerEnd\n        val upperEndpoint = continuousTransform?.applyInverse(range.upperEnd) ?: range.upperEnd\n\n        val length = upperEndpoint - lowerEndpoint\n        var lowerExpand = addExp + length * mulExp\n        var upperExpand = lowerExpand\n        if (layer.rangeIncludesZero(aes)) {\n            // zero-based plots (like bar) - do not 'expand' on the zero-end\n            if (lowerEndpoint == 0.0 ||\n                upperEndpoint == 0.0 ||\n                sign(lowerEndpoint) == sign(upperEndpoint)\n            ) {\n                if (lowerEndpoint >= 0) {\n                    lowerExpand = 0.0\n                } else {\n                    upperExpand = 0.0\n                }\n            }\n        }\n\n        val lowerEndWithExpand = (lowerEndpoint - lowerExpand).let {\n            val transformed = continuousTransform?.apply(it) ?: it\n            if (transformed.isNaN()) {\n                range.lowerEnd\n            } else {\n                transformed\n            }\n        }\n        val upperEndWithExpand = (upperEndpoint + upperExpand).let {\n            val transformed = continuousTransform?.apply(it) ?: it\n            if (transformed.isNaN()) {\n                range.upperEnd\n            } else {\n                transformed\n            }\n        }\n        return ClosedRange(lowerEndWithExpand, upperEndWithExpand)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmName(\"LazyKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin\n\nimport kotlin.reflect.KProperty\n\n/**\n * Represents a value with lazy initialization.\n *\n * To create an instance of [Lazy] use the [lazy] function.\n */\npublic interface Lazy<out T> {\n    /**\n     * Gets the lazily initialized value of the current Lazy instance.\n     * Once the value was initialized it must not change during the rest of lifetime of this Lazy instance.\n     */\n    public val value: T\n\n    /**\n     * Returns `true` if a value for this Lazy instance has been already initialized, and `false` otherwise.\n     * Once this function has returned `true` it stays `true` for the rest of lifetime of this Lazy instance.\n     */\n    public fun isInitialized(): Boolean\n}\n\n/**\n * Creates a new instance of the [Lazy] that is already initialized with the specified [value].\n */\npublic fun <T> lazyOf(value: T): Lazy<T> = InitializedLazyImpl(value)\n\n/**\n * An extension to delegate a read-only property of type [T] to an instance of [Lazy].\n *\n * This extension allows to use instances of Lazy for property delegation:\n * `val property: String by lazy { initializer }`\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Lazy<T>.getValue(thisRef: Any?, property: KProperty<*>): T = value\n\n/**\n * Specifies how a [Lazy] instance synchronizes initialization among multiple threads.\n */\npublic enum class LazyThreadSafetyMode {\n\n    /**\n     * Locks are used to ensure that only a single thread can initialize the [Lazy] instance.\n     */\n    SYNCHRONIZED,\n\n    /**\n     * Initializer function can be called several times on concurrent access to uninitialized [Lazy] instance value,\n     * but only the first returned value will be used as the value of [Lazy] instance.\n     */\n    PUBLICATION,\n\n    /**\n     * No locks are used to synchronize an access to the [Lazy] instance value; if the instance is accessed from multiple threads, its behavior is undefined.\n     *\n     * This mode should not be used unless the [Lazy] instance is guaranteed never to be initialized from more than one thread.\n     */\n    NONE,\n}\n\n\ninternal object UNINITIALIZED_VALUE\n\n// internal to be called from lazy in JS\ninternal class UnsafeLazyImpl<out T>(initializer: () -> T) : Lazy<T>, Serializable {\n    private var initializer: (() -> T)? = initializer\n    private var _value: Any? = UNINITIALIZED_VALUE\n\n    override val value: T\n        get() {\n            if (_value === UNINITIALIZED_VALUE) {\n                _value = initializer!!()\n                initializer = null\n            }\n            @Suppress(\"UNCHECKED_CAST\")\n            return _value as T\n        }\n\n    override fun isInitialized(): Boolean = _value !== UNINITIALIZED_VALUE\n\n    override fun toString(): String = if (isInitialized()) value.toString() else \"Lazy value not initialized yet.\"\n\n    private fun writeReplace(): Any = InitializedLazyImpl(value)\n}\n\ninternal class InitializedLazyImpl<out T>(override val value: T) : Lazy<T>, Serializable {\n\n    override fun isInitialized(): Boolean = true\n\n    override fun toString(): String = value.toString()\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\n\nclass SvgLayerRenderer(\n    private val myAesthetics: Aesthetics,\n    private val myGeom: Geom,\n    private val myPos: PositionAdjustment,\n    private val myCoord: CoordinateSystem,\n    private val myGeomContext: GeomContext\n) : SvgComponent(), SvgRoot {\n\n    override fun buildComponent() {\n        buildLayer()\n    }\n\n    private fun buildLayer() {\n        myGeom.build(this, myAesthetics, myPos, myCoord, myGeomContext)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\n\nclass VarBinding(\n    val variable: DataFrame.Variable,\n    val aes: Aes<*>\n) {\n    override fun toString() = \"VarBinding{variable=${variable}, aes=${aes}\"\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as VarBinding\n\n        if (variable != other.variable) return false\n        if (aes != other.aes) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = variable.hashCode()\n        result = 31 * result + aes.hashCode()\n        return result\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.scale.breaks.ScaleBreaksUtil\nimport jetbrains.datalore.plot.builder.guide.*\nimport jetbrains.datalore.plot.builder.guide.ColorBarComponentSpec.Companion.DEF_NUM_BIN\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.scale.GuideBreak\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass ColorBarAssembler(\n    private val legendTitle: String,\n    private val domain: ClosedRange<Double>,\n    private val scale: Scale<Color>,\n    private val theme: LegendTheme\n) {\n\n    private var colorBarOptions: ColorBarOptions? = null\n\n    fun createColorBar(): LegendBoxInfo {\n        var scale = scale\n        if (!scale.hasBreaks()) {\n            scale = ScaleBreaksUtil.withBreaks(scale, domain, 5)\n        }\n\n        val guideBreaks = ArrayList<GuideBreak<Double>>()\n        val breaks = ScaleUtil.breaksTransformed(scale)\n        val label = ScaleUtil.labels(scale).iterator()\n        for (v in breaks) {\n            guideBreaks.add(GuideBreak(v, label.next()))\n        }\n\n        if (guideBreaks.isEmpty()) {\n            return LegendBoxInfo.EMPTY\n        }\n\n        val spec = createColorBarSpec(\n            legendTitle,\n            domain,\n            guideBreaks,\n            scale,\n            theme,\n            colorBarOptions\n        )\n\n        return object : LegendBoxInfo(spec.size) {\n            override fun createLegendBox(): LegendBox {\n                val c = ColorBarComponent(spec)\n                c.debug = DEBUG_DRAWING\n                return c\n            }\n        }\n    }\n\n    internal fun setOptions(options: ColorBarOptions?) {\n        colorBarOptions = options\n    }\n\n    companion object {\n        private const val DEBUG_DRAWING = jetbrains.datalore.plot.FeatureSwitch.LEGEND_DEBUG_DRAWING\n\n        fun createColorBarSpec(\n            title: String,\n            domain: ClosedRange<Double>,\n            breaks: List<GuideBreak<Double>>,\n            scale: Scale<Color>,\n            theme: LegendTheme,\n            options: ColorBarOptions? = null\n        ): ColorBarComponentSpec {\n\n            val legendDirection = LegendAssemblerUtil.legendDirection(theme)\n            val horizontal: Boolean = legendDirection == LegendDirection.HORIZONTAL\n\n            val width = options?.width\n            val height = options?.height\n            var barSize = ColorBarComponentSpec.barAbsoluteSize(horizontal, theme)\n            if (width != null) {\n                barSize = DoubleVector(width, barSize.y)\n            }\n            if (height != null) {\n                barSize = DoubleVector(barSize.x, height)\n            }\n\n            val reverse = !horizontal\n\n            val layout = when {\n                horizontal -> ColorBarComponentLayout.horizontal(title, domain, breaks, barSize, reverse)\n                else -> ColorBarComponentLayout.vertical(title, domain, breaks, barSize, reverse)\n            }\n\n            return ColorBarComponentSpec(\n                title,\n                domain,\n                breaks,\n                scale,\n                binCount = options?.binCount ?: DEF_NUM_BIN,\n                theme,\n                layout,\n                reverse\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nclass ColorBarOptions : GuideOptions() {\n    var width: Double? = null\n    var height: Double? = null\n    var binCount: Int? = null\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.NullGeomTargetCollector\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass GeomContextBuilder : ImmutableGeomContext.Builder {\n    private var myAesthetics: Aesthetics? = null\n    private var myAestheticMappers: Map<Aes<*>, (Double?) -> Any?>? = null\n    private var myGeomTargetCollector: GeomTargetCollector =\n        NullGeomTargetCollector()\n\n    constructor()\n\n    private constructor(ctx: MyGeomContext) {\n        myAesthetics = ctx.myAesthetics\n        myAestheticMappers = ctx.myAestheticMappers\n    }\n\n    override fun aesthetics(aesthetics: Aesthetics?): ImmutableGeomContext.Builder {\n        myAesthetics = aesthetics\n        return this\n    }\n\n    override fun aestheticMappers(aestheticMappers: Map<Aes<*>, (Double?) -> Any?>?): ImmutableGeomContext.Builder {\n        myAestheticMappers = aestheticMappers\n        return this\n    }\n\n    override fun geomTargetCollector(geomTargetCollector: GeomTargetCollector): ImmutableGeomContext.Builder {\n        myGeomTargetCollector = geomTargetCollector\n        return this\n    }\n\n    override fun build(): ImmutableGeomContext {\n        return MyGeomContext(this)\n    }\n\n\n    private class MyGeomContext(b: GeomContextBuilder) :\n        ImmutableGeomContext {\n        val myAesthetics = b.myAesthetics\n        val myAestheticMappers = b.myAestheticMappers\n        override val targetCollector = b.myGeomTargetCollector\n\n        override fun getResolution(aes: Aes<Double>): Double {\n            var resolution = 0.0\n            if (myAesthetics != null) {\n                resolution = myAesthetics.resolution(aes, 0.0)\n            }\n            if (resolution <= SeriesUtil.TINY) {\n                resolution = getUnitResolution(aes)\n            }\n\n            return resolution\n        }\n\n        override fun getUnitResolution(aes: Aes<Double>): Double {\n            val mapper = myAestheticMappers?.get(aes) ?: Mappers.IDENTITY\n            return mapper(1.0) as Double\n        }\n\n        override fun withTargetCollector(targetCollector: GeomTargetCollector): GeomContext {\n            return GeomContextBuilder()\n                .aesthetics(myAesthetics)\n                .aestheticMappers(myAestheticMappers)\n                .geomTargetCollector(targetCollector)\n                .build()\n        }\n\n        override fun with(): ImmutableGeomContext.Builder {\n            return GeomContextBuilder(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.geom.LiveMapGeom\nimport jetbrains.datalore.plot.base.geom.LiveMapProvider\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpec\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.stat.SimpleStatContext\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.PosProviderContext\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.geom.GeomProvider\nimport jetbrains.datalore.plot.builder.assemble.geom.PointDataAccess\nimport jetbrains.datalore.plot.builder.data.DataProcessing\nimport jetbrains.datalore.plot.builder.data.GroupingContext\nimport jetbrains.datalore.plot.builder.interact.ContextualMappingProvider\nimport jetbrains.datalore.plot.builder.scale.ScaleProvider\n\nclass GeomLayerBuilder {\n    private val myBindings = ArrayList<VarBinding>()\n    private val myConstantByAes = TypedKeyHashMap()\n    private lateinit var myStat: Stat\n    private lateinit var myPosProvider: PosProvider\n    private lateinit var myGeomProvider: GeomProvider\n    private var myGroupingVarName: String? = null\n    private var myPathIdVarName: String? = null\n    private val myScaleProviderByAes = HashMap<Aes<*>, ScaleProvider<*>>()\n\n    private var myDataPreprocessor: ((DataFrame, TypedScaleMap) -> DataFrame)? = null\n    private var myLocatorLookupSpec: LookupSpec = LookupSpec.NONE\n    private var myContextualMappingProvider: ContextualMappingProvider = ContextualMappingProvider.NONE\n\n    private var myIsLegendDisabled: Boolean = false\n\n    fun stat(v: Stat): GeomLayerBuilder {\n        myStat = v\n        return this\n    }\n\n    fun pos(v: PosProvider): GeomLayerBuilder {\n        myPosProvider = v\n        return this\n    }\n\n    fun geom(v: GeomProvider): GeomLayerBuilder {\n        myGeomProvider = v\n        return this\n    }\n\n    fun addBinding(v: VarBinding): GeomLayerBuilder {\n        myBindings.add(v)\n        return this\n    }\n\n    fun groupingVar(v: DataFrame.Variable): GeomLayerBuilder {\n        myGroupingVarName = v.name\n        return this\n    }\n\n    fun groupingVarName(v: String): GeomLayerBuilder {\n        myGroupingVarName = v\n        return this\n    }\n\n    fun pathIdVarName(v: String): GeomLayerBuilder {\n        myPathIdVarName = v\n        return this\n    }\n\n    fun <T> addConstantAes(aes: Aes<T>, v: T): GeomLayerBuilder {\n        myConstantByAes.put(aes, v)\n        return this\n    }\n\n    fun <T> addScaleProvider(aes: Aes<T>, scaleProvider: ScaleProvider<T>): GeomLayerBuilder {\n        myScaleProviderByAes[aes] = scaleProvider\n        return this\n    }\n\n    fun locatorLookupSpec(v: LookupSpec): GeomLayerBuilder {\n        myLocatorLookupSpec = v\n        return this\n    }\n\n    fun contextualMappingProvider(v: ContextualMappingProvider): GeomLayerBuilder {\n        myContextualMappingProvider = v\n        return this\n    }\n\n    fun disableLegend(v: Boolean): GeomLayerBuilder {\n        myIsLegendDisabled = v\n        return this\n    }\n\n    fun build(data: DataFrame, scaleMap: TypedScaleMap): GeomLayer {\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n        if (myDataPreprocessor != null) {\n            data = myDataPreprocessor!!(data, scaleMap)\n        }\n\n        // make sure 'original' series are transformed\n        data = DataProcessing.transformOriginals(data, myBindings, scaleMap)\n\n        val replacementBindings = HashMap(\n            // No 'origin' variables beyond this point.\n            // Replace all 'origin' variables in bindings with 'transform' variables\n            myBindings.map {\n                it.aes to if (it.variable.isOrigin) {\n                    val transformVar = DataFrameUtil.transformVarFor(it.aes)\n                    VarBinding(transformVar, it.aes)\n                } else {\n                    it\n                }\n            }.toMap()\n        )\n\n        // add 'transform' variable for each 'stat' variable\n        val bindingsToPut = ArrayList<VarBinding>()\n        for (binding in replacementBindings.values) {\n            val variable = binding.variable\n            if (variable.isStat) {\n                val aes = binding.aes\n                val scale = scaleMap[aes]\n                data = DataFrameUtil.applyTransform(data, variable, aes, scale)\n                bindingsToPut.add(VarBinding(TransformVar.forAes(aes), aes))\n            }\n        }\n\n        // replace 'stat' vars with 'transform' vars in bindings\n        for (binding in bindingsToPut) {\n            replacementBindings[binding.aes] = binding\n        }\n\n        // (!) Positional aes scales have undefined `mapper` at this time because\n        // dimensions of plot are not yet known.\n        // Data Access shouldn't use aes mapper (!)\n        val dataAccess = PointDataAccess(data, replacementBindings, scaleMap)\n\n        return MyGeomLayer(\n            data,\n            myGeomProvider,\n            myPosProvider,\n            myGeomProvider.renders(),\n            GroupingContext(data, myBindings, myGroupingVarName, myPathIdVarName, handlesGroups()).groupMapper,\n            replacementBindings.values,\n            myConstantByAes,\n            scaleMap,\n            dataAccess,\n            myLocatorLookupSpec,\n            myContextualMappingProvider.createContextualMapping(dataAccess, data),\n            myIsLegendDisabled\n        )\n    }\n\n    private fun handlesGroups(): Boolean {\n        return myGeomProvider.handlesGroups() || myPosProvider.handlesGroups()\n    }\n\n\n    private class MyGeomLayer(\n        override val dataFrame: DataFrame,\n        geomProvider: GeomProvider,\n        private val myPosProvider: PosProvider,\n        renderedAes: List<Aes<*>>,\n        override val group: (Int) -> Int,\n        varBindings: Collection<VarBinding>,\n        constantByAes: TypedKeyHashMap,\n        override val scaleMap: TypedScaleMap,\n        override val dataAccess: MappedDataAccess,\n        override val locatorLookupSpec: LookupSpec,\n        override val contextualMapping: ContextualMapping,\n        override val isLegendDisabled: Boolean\n    ) : GeomLayer {\n\n        override val geom: Geom = geomProvider.createGeom()\n        override val geomKind: GeomKind = geomProvider.geomKind\n        override val aestheticsDefaults: AestheticsDefaults\n\n        private val myRenderedAes: List<Aes<*>>\n        private val myConstantByAes: TypedKeyHashMap\n        private val myVarBindingsByAes = HashMap<Aes<*>, VarBinding>()\n\n        override val legendKeyElementFactory: LegendKeyElementFactory\n            get() = geom.legendKeyElementFactory\n\n        override val isLiveMap: Boolean\n            get() = geom is LiveMapGeom\n\n        init {\n            myRenderedAes = ArrayList(renderedAes)\n\n            // constant value by aes (default + specified)\n            aestheticsDefaults = geomProvider.aestheticsDefaults()\n            myConstantByAes = TypedKeyHashMap()\n\n            for (key in constantByAes.keys<Any>()) {\n                myConstantByAes.put(key, constantByAes[key])\n            }\n\n            for (varBinding in varBindings) {\n                myVarBindingsByAes[varBinding.aes] = varBinding\n            }\n        }\n\n        override fun renderedAes(): List<Aes<*>> {\n            return myRenderedAes\n        }\n\n        override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n            return myPosProvider.createPos(ctx)\n        }\n\n        override fun hasBinding(aes: Aes<*>): Boolean {\n            return myVarBindingsByAes.containsKey(aes)\n        }\n\n        override fun <T> getBinding(aes: Aes<T>): VarBinding {\n            return myVarBindingsByAes[aes]!!\n        }\n\n        override fun hasConstant(aes: Aes<*>): Boolean {\n            return myConstantByAes.containsKey(aes)\n        }\n\n        override fun <T> getConstant(aes: Aes<T>): T {\n            require(hasConstant(aes)) { \"Constant value is not defined for aes $aes\" }\n            return myConstantByAes[aes]\n        }\n\n        override fun <T> getDefault(aes: Aes<T>): T {\n            return aestheticsDefaults.defaultValue(aes)\n        }\n\n        override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n            return aestheticsDefaults.rangeIncludesZero(aes)\n        }\n\n        override fun setLiveMapProvider(liveMapProvider: LiveMapProvider) {\n            if (geom is LiveMapGeom) {\n                geom.setLiveMapProvider(liveMapProvider)\n            } else {\n                throw IllegalStateException(\"Not Livemap: \" + geom::class.simpleName)\n            }\n        }\n    }\n\n    companion object {\n\n        fun demoAndTest(): GeomLayerBuilder {\n            val builder = GeomLayerBuilder()\n            builder.myDataPreprocessor = { data, scaleMap ->\n                val transformedData = DataProcessing.transformOriginals(data, builder.myBindings, scaleMap)\n                when (val stat = builder.myStat) {\n                    Stats.IDENTITY -> transformedData\n                    else -> {\n                        val statCtx = SimpleStatContext(transformedData)\n                        val groupingContext =\n                            GroupingContext(\n                                transformedData,\n                                builder.myBindings,\n                                builder.myGroupingVarName,\n                                builder.myPathIdVarName,\n                                true\n                            )\n                        val dataAndGroupingContext = DataProcessing.buildStatData(\n                            transformedData,\n                            stat,\n                            builder.myBindings,\n                            scaleMap,\n                            groupingContext,\n                            PlotFacets.undefined(),\n                            statCtx,\n                            varsWithoutBinding = emptyList(),\n                            orderOptions = emptyList(),\n                            aggregateOperation = null,\n                            ::println\n                        )\n\n                        dataAndGroupingContext.data\n                    }\n                }\n            }\n\n            return builder\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport kotlin.native.concurrent.ThreadLocal\n\nabstract class GuideOptions {\n\n    var isReverse: Boolean = false\n\n    // In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n    // @link https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n    // Required mutations:\n    //      -   `isReverse` in the 'outer' class\n    @ThreadLocal\n    companion object {\n        val NONE: GuideOptions = object : GuideOptions() {}\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.scale.breaks.ScaleBreaksUtil\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.LegendAssemblerUtil.mapToAesthetics\nimport jetbrains.datalore.plot.builder.guide.*\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.min\n\nclass LegendAssembler(\n    private val legendTitle: String,\n    private val guideOptionsMap: Map<Aes<*>, GuideOptions>,\n    private val theme: LegendTheme\n) {\n\n    private val legendLayers = ArrayList<LegendLayer>()\n\n    fun addLayer(\n        keyFactory: LegendKeyElementFactory,\n        varBindings: List<VarBinding>,\n        constantByAes: Map<Aes<*>, Any>,\n        aestheticsDefaults: AestheticsDefaults,\n        scaleByAes: TypedScaleMap,\n        transformedDataRangeByAes: Map<Aes<*>, ClosedRange<Double>>\n    ) {\n\n        legendLayers.add(\n            LegendLayer(\n                keyFactory,\n                varBindings,\n                constantByAes,\n                aestheticsDefaults,\n                scaleByAes,\n                transformedDataRangeByAes\n            )\n        )\n    }\n\n    fun createLegend(): LegendBoxInfo {\n        val legendBreaksByLabel = LinkedHashMap<String, LegendBreak>()\n        for (legendLayer in legendLayers) {\n            val keyElementFactory = legendLayer.keyElementFactory\n            val dataPoints = legendLayer.keyAesthetics.dataPoints().iterator()\n            for (label in legendLayer.keyLabels) {\n                legendBreaksByLabel.getOrPut(label) { LegendBreak(label) }\n                    .addLayer(dataPoints.next(), keyElementFactory)\n            }\n        }\n\n        val legendBreaks = ArrayList<LegendBreak>()\n        for (legendBreak in legendBreaksByLabel.values) {\n            if (legendBreak.isEmpty) {\n                continue\n            }\n            legendBreaks.add(legendBreak)\n        }\n\n\n        if (legendBreaks.isEmpty()) {\n            return LegendBoxInfo.EMPTY\n        }\n\n        // legend options\n        val legendOptionsList = ArrayList<LegendOptions>()\n        for (legendLayer in legendLayers) {\n            val aesList = legendLayer.aesList\n            for (aes in aesList) {\n                if (guideOptionsMap[aes] is LegendOptions) {\n                    legendOptionsList.add(guideOptionsMap[aes] as LegendOptions)\n                }\n            }\n        }\n\n        val spec =\n            createLegendSpec(\n                legendTitle, legendBreaks, theme,\n                LegendOptions.combine(\n                    legendOptionsList\n                )\n            )\n\n        return object : LegendBoxInfo(spec.size) {\n            override fun createLegendBox(): LegendBox {\n                val c = LegendComponent(spec)\n                c.debug = DEBUG_DRAWING\n                return c\n            }\n        }\n    }\n\n\n    private class LegendLayer(\n        internal val keyElementFactory: LegendKeyElementFactory,\n        private val varBindings: List<VarBinding>,\n        private val constantByAes: Map<Aes<*>, Any>,\n        private val aestheticsDefaults: AestheticsDefaults,\n        private val scaleMap: TypedScaleMap,\n        transformedDataRangeByAes: Map<Aes<*>, ClosedRange<Double>>\n    ) {\n\n        internal val keyAesthetics: Aesthetics\n        internal val keyLabels: List<String>\n\n        internal val aesList: List<Aes<*>>\n            get() = varBindings.map { it.aes }\n\n        init {\n            val aesValuesByLabel = LinkedHashMap<String, MutableMap<Aes<*>, Any>>()\n            for (varBinding in varBindings) {\n                val aes = varBinding.aes\n                var scale = scaleMap[aes]\n                if (!scale.hasBreaks()) {\n                    scale = ScaleBreaksUtil.withBreaks(scale, transformedDataRangeByAes.getValue(aes), 5)\n                }\n                check(scale.hasBreaks()) { \"No breaks were defined for scale $aes\" }\n\n                val aesValues = ScaleUtil.transformAndMap(scale.breaks, scale)\n                val labels = ScaleUtil.labels(scale)\n                for ((label, aesValue) in labels.zip(aesValues)) {\n                    aesValuesByLabel.getOrPut(label) { HashMap() }[aes] = aesValue!!\n                }\n            }\n\n            // build 'key' aesthetics\n            keyAesthetics = mapToAesthetics(aesValuesByLabel.values, constantByAes, aestheticsDefaults)\n            keyLabels = ArrayList(aesValuesByLabel.keys)\n        }\n    }\n\n    companion object {\n        private const val DEBUG_DRAWING = jetbrains.datalore.plot.FeatureSwitch.LEGEND_DEBUG_DRAWING\n\n        fun createLegendSpec(\n            title: String,\n            breaks: List<LegendBreak>,\n            theme: LegendTheme,\n            options: LegendOptions = LegendOptions()\n        ): LegendComponentSpec {\n\n            val legendDirection = LegendAssemblerUtil.legendDirection(theme)\n\n            // key size\n            fun pretty(v: DoubleVector): DoubleVector {\n                val margin = 1.0\n                return DoubleVector(\n                    floor(v.x / 2) * 2 + 1.0 + margin,\n                    floor(v.y / 2) * 2 + 1.0 + margin\n                )\n            }\n\n            var keySize = DoubleVector(theme.keySize(), theme.keySize())\n            for (br in breaks) {\n                val minimumKeySize = br.minimumKeySize\n                keySize = keySize.max(pretty(minimumKeySize))\n            }\n\n            // row, col count\n            val breakCount = breaks.size\n            val colCount: Int\n            val rowCount: Int\n            if (options.isByRow) {\n                colCount = when {\n                    options.hasColCount() -> min(options.colCount, breakCount)\n                    options.hasRowCount() -> ceil(breakCount / options.rowCount.toDouble()).toInt()\n                    legendDirection === LegendDirection.HORIZONTAL -> breakCount\n                    else -> 1\n                }\n                rowCount = ceil(breakCount / colCount.toDouble()).toInt()\n            } else {\n                // by column\n                rowCount = when {\n                    options.hasRowCount() -> min(options.rowCount, breakCount)\n                    options.hasColCount() -> ceil(breakCount / options.colCount.toDouble()).toInt()\n                    legendDirection !== LegendDirection.HORIZONTAL -> breakCount\n                    else -> 1\n                }\n                colCount = ceil(breakCount / rowCount.toDouble()).toInt()\n            }\n\n            val layout: LegendComponentLayout\n            @Suppress(\"LiftReturnOrAssignment\")\n            if (legendDirection === LegendDirection.HORIZONTAL) {\n                if (options.hasRowCount() || options.hasColCount() && options.colCount < breakCount) {\n                    layout = LegendComponentLayout.horizontalMultiRow(\n                        title,\n                        breaks,\n                        keySize\n                    )\n                } else {\n                    layout = LegendComponentLayout.horizontal(title, breaks, keySize)\n                }\n            } else {\n                layout = LegendComponentLayout.vertical(title, breaks, keySize)\n            }\n\n            layout.colCount = colCount\n            layout.rowCount = rowCount\n            layout.isFillByRow = options.isByRow\n\n            return LegendComponentSpec(\n                title,\n                breaks,\n                theme,\n                layout,\n                reverse = false\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.builder.guide.LegendDirection\nimport jetbrains.datalore.plot.builder.guide.LegendPosition\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\ninternal object LegendAssemblerUtil {\n    fun <T> mapToAesthetics(\n        valuesByAes: Map<Aes<T>, List<T>>, constantByAes: Map<Aes<T>, T>, aestheticsDefaults: AestheticsDefaults\n    ): Aesthetics {\n        val builder = AestheticsBuilder(0)\n        for (aes in Aes.values()) {\n            @Suppress(\"UNCHECKED_CAST\")\n            builder.constantAes(aes as Aes<Any>, aestheticsDefaults.defaultValue(aes))\n        }\n        for (aes in valuesByAes.keys) {\n            val values = valuesByAes[aes]!!\n            builder.aes(aes, AestheticsBuilder.collection(values))\n            builder.dataPointCount(values.size)\n        }\n        for (aes in constantByAes.keys) {\n            builder.constantAes<T>(aes, constantByAes[aes]!!)\n        }\n        return builder.build()\n    }\n\n\n    fun mapToAesthetics(\n        valueByAesIterable: Collection<Map<Aes<*>, Any>>,\n        constantByAes: Map<Aes<*>, Any>,\n        aestheticsDefaults: AestheticsDefaults\n    ): Aesthetics {\n        val dataPoints = ArrayList<Map<Aes<*>, Any>>()\n        for (valueByAes in valueByAesIterable) {\n            val dataPoint = HashMap<Aes<*>, Any>()\n            for (aes in Aes.values()) {\n                dataPoint[aes] = aestheticsDefaults.defaultValueInLegend(aes)!!\n            }\n\n            // Derive some aesthetics from constants\n            for (constantAes in constantByAes.keys) {\n                when (constantAes) {\n                    Aes.SHAPE,\n                    Aes.COLOR,\n                    Aes.FILL -> dataPoint[constantAes] = constantByAes[constantAes]!!\n                }\n            }\n\n            for (aes in valueByAes.keys) {\n                dataPoint[aes] = valueByAes[aes]!!\n            }\n\n            dataPoints.add(dataPoint)\n        }\n\n        val builder = AestheticsBuilder(dataPoints.size)\n        for (aes in Aes.values()) {\n            @Suppress(\"UNCHECKED_CAST\")\n            builder.aes(aes as Aes<Any>) { index -> dataPoints[index][aes]!! }\n        }\n        return builder.build()\n    }\n\n    fun legendDirection(theme: LegendTheme): LegendDirection {\n        var legendDirection = theme.direction()\n        if (legendDirection === LegendDirection.AUTO) {\n            val legendPosition = theme.position()\n            legendDirection =\n                if (legendPosition === LegendPosition.TOP || legendPosition === LegendPosition.BOTTOM)\n                    LegendDirection.HORIZONTAL\n                else\n                    LegendDirection.VERTICAL\n        }\n        return legendDirection\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport kotlin.math.max\n\nclass LegendOptions : GuideOptions() {\n\n    private var myColCount: Int? = null\n    private var myRowCount: Int? = null\n    var isByRow: Boolean = false\n\n    var colCount: Int\n        get() = myColCount!!\n        set(colCount) {\n            myColCount = max(1, colCount)\n        }\n\n    var rowCount: Int\n        get() = myRowCount!!\n        set(rowCount) {\n            myRowCount = max(1, rowCount)\n        }\n\n    fun hasColCount(): Boolean {\n        return myColCount != null\n    }\n\n    fun hasRowCount(): Boolean {\n        return myRowCount != null\n    }\n\n    companion object {\n        fun combine(optionsList: List<LegendOptions>): LegendOptions {\n            val result = LegendOptions()\n            for (options in optionsList) {\n                if (options.isByRow) {\n                    result.isByRow = true\n                }\n                if (options.hasColCount()) {\n                    result.colCount = options.colCount\n                }\n                if (options.hasRowCount()) {\n                    result.rowCount = options.rowCount\n                }\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkState\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.Plot\nimport jetbrains.datalore.plot.builder.PlotBuilder\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass PlotAssembler private constructor(\n    private val scaleByAes: TypedScaleMap,\n    val layersByTile: List<List<GeomLayer>>,\n    private val myCoordProvider: CoordProvider,\n    private val myTheme: Theme\n) {\n\n    val containsLiveMap: Boolean\n\n    var facets: PlotFacets = PlotFacets.undefined()\n    private var myTitle: String? = null\n    private var myGuideOptionsMap: Map<Aes<*>, GuideOptions> = HashMap()\n    private var myAxisEnabled: Boolean\n    private var myLegendsEnabled = true\n    private var myInteractionsEnabled = true\n\n    init {\n        containsLiveMap = layersByTile.flatten().any(GeomLayer::isLiveMap)\n        myAxisEnabled = !containsLiveMap  // no axis on livemap\n    }\n\n    fun setTitle(title: String?) {\n        myTitle = title\n    }\n\n    private fun hasLayers(): Boolean {\n        for (tileLayers in layersByTile) {\n            if (tileLayers.isNotEmpty()) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun createPlot(): Plot {\n        check(hasLayers()) { \"No layers in plot\" }\n\n        val legendsBoxInfos = if (myLegendsEnabled)\n            PlotAssemblerUtil.createLegends(\n                layersByTile,\n                myGuideOptionsMap,\n                myTheme.legend()\n            )\n        else\n            emptyList()\n\n        // share first X/Y scale among all layers\n        var xScaleProto = scaleByAes[Aes.X]\n        var yScaleProto = scaleByAes[Aes.Y]\n\n        if (containsLiveMap) {\n            // build 'live map' plot:\n            //  - skip X/Y scale training\n            //  - ignore coord provider\n            //  - plot layout without axes\n            val plotLayout = PlotAssemblerUtil.createPlotLayout(\n                LiveMapTileLayout(),\n                facets\n            )\n            return createXYPlot(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos, hasLiveMap = true)\n        }\n\n        // train X/Y scales\n        val (xDomain, yDomain) = PlotAssemblerUtil.computePlotDryRunXYRanges(layersByTile)\n\n        val xAxisLayout: AxisLayout\n        val yAxisLayout: AxisLayout\n        if (myAxisEnabled) {\n            xAxisLayout = PlotAxisLayout.bottom(xScaleProto, xDomain, yDomain, myCoordProvider, myTheme.axisX())\n            yAxisLayout = PlotAxisLayout.left(yScaleProto, xDomain, yDomain, myCoordProvider, myTheme.axisY())\n        } else {\n            xAxisLayout = EmptyAxisLayout.bottom(xDomain, yDomain)\n            yAxisLayout = EmptyAxisLayout.left(xDomain, yDomain)\n        }\n\n        val plotLayout = PlotAssemblerUtil.createPlotLayout(\n            XYPlotTileLayout(xAxisLayout, yAxisLayout),\n            facets\n        )\n        if (!myAxisEnabled) {\n            plotLayout.setPadding(0.0, 0.0, 0.0, 0.0)\n        }\n\n        return createXYPlot(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos)\n    }\n\n\n    private fun createXYPlot(\n        xScaleProto: Scale<Double>,\n        yScaleProto: Scale<Double>,\n        plotLayout: PlotLayout,\n        legendBoxInfos: List<LegendBoxInfo>,\n        hasLiveMap: Boolean = false\n    ): Plot {\n\n        val plotBuilder = PlotBuilder(myTheme)\n        plotBuilder.setTitle(myTitle)\n        plotBuilder.scaleXProto(xScaleProto)\n        plotBuilder.scaleYProto(yScaleProto)\n        plotBuilder.setAxisTitleBottom(xScaleProto.name)\n        plotBuilder.setAxisTitleLeft(yScaleProto.name)\n        plotBuilder.setCoordProvider(myCoordProvider)\n        for (legendBoxInfo in legendBoxInfos) {\n            plotBuilder.addLegendBoxInfo(legendBoxInfo)\n        }\n        for (panelLayers in layersByTile) {\n            plotBuilder.addTileLayers(panelLayers)\n        }\n\n        plotBuilder.setPlotLayout(plotLayout)\n        plotBuilder.axisEnabled(myAxisEnabled)\n        plotBuilder.interactionsEnabled(myInteractionsEnabled)\n        plotBuilder.setLiveMap(hasLiveMap)\n        return plotBuilder.build()\n    }\n\n    fun setGuideOptionsMap(guideOptionsMap: Map<Aes<*>, GuideOptions>) {\n        myGuideOptionsMap = guideOptionsMap\n    }\n\n    fun disableAxis() {\n        myAxisEnabled = false\n    }\n\n    fun disableLegends() {\n        myLegendsEnabled = false\n    }\n\n    fun disableInteractions() {\n        myInteractionsEnabled = false\n    }\n\n    companion object {\n        fun singleTile(\n            scaleByAes: TypedScaleMap,\n            plotLayers: List<GeomLayer>,\n            coordProvider: CoordProvider,\n            theme: Theme\n        ): PlotAssembler {\n            val layersByTile = ArrayList<List<GeomLayer>>()\n            layersByTile.add(plotLayers)\n            return multiTile(\n                scaleByAes,\n                layersByTile,\n                coordProvider,\n                theme\n            )\n        }\n\n        fun multiTile(\n            scaleByAes: TypedScaleMap,\n            layersByTile: List<List<GeomLayer>>,\n            coordProvider: CoordProvider,\n            theme: Theme\n        ): PlotAssembler {\n            return PlotAssembler(scaleByAes, layersByTile, coordProvider, theme)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.PlotUtil\nimport jetbrains.datalore.plot.builder.PlotUtil.computeLayerDryRunXYRanges\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.checkFitsColorBar\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.createColorBarAssembler\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.fitsColorBar\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.guideTransformedDomainByAes\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.mappedRenderedAesToCreateGuides\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal object PlotAssemblerUtil {\n\n    private fun updateAesRangeMap(\n        aes: Aes<*>,\n        range: ClosedRange<Double>?,\n        rangeByAes: MutableMap<Aes<*>, ClosedRange<Double>>\n    ) {\n        @Suppress(\"NAME_SHADOWING\")\n        var range = range\n        if (range != null) {\n            val wasRange = rangeByAes[aes]\n            if (wasRange != null) {\n                range = wasRange.span(range)\n            }\n            rangeByAes[aes] = range\n        }\n    }\n\n    private fun updateRange(range: ClosedRange<Double>?, wasRange: ClosedRange<Double>?): ClosedRange<Double>? {\n        @Suppress(\"NAME_SHADOWING\")\n        var range = range\n        if (range != null) {\n            if (wasRange != null) {\n                range = wasRange.span(range)\n            }\n            return range\n        }\n        return wasRange\n    }\n\n    private fun updateRange(values: Iterable<Double>, wasRange: ClosedRange<Double>?): ClosedRange<Double>? {\n        if (!Iterables.isEmpty(values)) {\n            var newRange = ClosedRange.encloseAll(values)\n            if (wasRange != null) {\n                newRange = wasRange.span(newRange)\n            }\n            return newRange\n        }\n        return wasRange\n    }\n\n    fun createLegends(\n        layersByPanel: List<List<GeomLayer>>,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>,\n        theme: LegendTheme\n    ): List<LegendBoxInfo> {\n\n        // stitch together layers from all panels\n        var planeCount = 0\n        if (layersByPanel.isNotEmpty()) {\n            planeCount = layersByPanel[0].size\n        }\n\n        val stitchedLayersList = ArrayList<StitchedPlotLayers>()\n        for (i in 0 until planeCount) {\n            val layersOnPlane = ArrayList<GeomLayer>()\n\n            // collect layer[i] chunks from all panels\n            for (panelLayers in layersByPanel) {\n                layersOnPlane.add(panelLayers[i])\n            }\n\n            stitchedLayersList.add(\n                StitchedPlotLayers(\n                    layersOnPlane\n                )\n            )\n        }\n\n        val transformedDataRangeByAes = HashMap<Aes<*>, ClosedRange<Double>>()\n        for (stitchedPlotLayers in stitchedLayersList) {\n            val layerTransformedDomainByAes = guideTransformedDomainByAes(stitchedPlotLayers, guideOptionsMap)\n            for ((aes, transformedDomain) in layerTransformedDomainByAes) {\n                updateAesRangeMap(\n                    aes,\n                    transformedDomain,\n                    transformedDataRangeByAes\n                )\n            }\n        }\n\n        return createLegends(\n            stitchedLayersList,\n            transformedDataRangeByAes,\n            guideOptionsMap,\n            theme\n        )\n    }\n\n    private fun createLegends(\n        stitchedLayersList: List<StitchedPlotLayers>,\n        transformedDataRangeByAes: Map<Aes<*>, ClosedRange<Double>>,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>,\n        theme: LegendTheme\n    ): List<LegendBoxInfo> {\n\n        val legendAssemblerByTitle = LinkedHashMap<String, LegendAssembler>()\n        val colorBarAssemblerByTitle = LinkedHashMap<String, ColorBarAssembler>()\n\n        for (stitchedLayers in stitchedLayersList) {\n            val layerConstantByAes = HashMap<Aes<*>, Any>()\n            for (aes in stitchedLayers.renderedAes()) {\n                if (stitchedLayers.hasConstant(aes)) {\n                    layerConstantByAes[aes] = stitchedLayers.getConstant(aes)!!\n                }\n            }\n\n            val layerBindingsByScaleName = LinkedHashMap<String, MutableList<VarBinding>>()\n            val aesList = mappedRenderedAesToCreateGuides(stitchedLayers, guideOptionsMap)\n            for (aes in aesList) {\n                var colorBar = false\n                val binding = stitchedLayers.getBinding(aes)\n                val scale = stitchedLayers.getScale(aes)\n                val scaleName = scale.name\n                if (guideOptionsMap.containsKey(aes)) {\n                    val guideOptions = guideOptionsMap[aes]\n                    if (guideOptions is ColorBarOptions) {\n                        checkFitsColorBar(binding.aes, scale)\n                        colorBar = true\n                        @Suppress(\"UNCHECKED_CAST\")\n                        val colorScale = scale as Scale<Color>\n                        colorBarAssemblerByTitle[scaleName] = createColorBarAssembler(\n                            scaleName, binding.aes,\n                            transformedDataRangeByAes, colorScale, guideOptions, theme\n                        )\n                    }\n                } else if (fitsColorBar(binding.aes, scale)) {\n                    colorBar = true\n                    @Suppress(\"UNCHECKED_CAST\")\n                    val colorScale = scale as Scale<Color>\n                    colorBarAssemblerByTitle[scaleName] = createColorBarAssembler(\n                        scaleName, binding.aes,\n                        transformedDataRangeByAes, colorScale, null, theme\n                    )\n                }\n\n                if (!colorBar) {\n                    layerBindingsByScaleName.getOrPut(scaleName) { ArrayList() }.add(binding)\n                }\n            }\n\n            for (scaleName in layerBindingsByScaleName.keys) {\n                val legendAssembler = legendAssemblerByTitle.getOrPut(scaleName) {\n                    LegendAssembler(\n                        scaleName,\n                        guideOptionsMap,\n                        theme\n                    )\n                }\n\n                val varBindings = layerBindingsByScaleName[scaleName]!!\n                val legendKeyFactory = stitchedLayers.legendKeyElementFactory\n                val aestheticsDefaults = stitchedLayers.aestheticsDefaults\n                legendAssembler.addLayer(\n                    legendKeyFactory,\n                    varBindings,\n                    layerConstantByAes,\n                    aestheticsDefaults,\n                    stitchedLayers.getScaleMap(),\n                    transformedDataRangeByAes\n                )\n            }\n        }\n\n        val legendBoxInfos = ArrayList<LegendBoxInfo>()\n        for (legendTitle in colorBarAssemblerByTitle.keys) {\n            val boxInfo = colorBarAssemblerByTitle[legendTitle]!!.createColorBar()\n            if (!boxInfo.isEmpty) {\n                legendBoxInfos.add(boxInfo)\n            }\n        }\n\n        for (legendTitle in legendAssemblerByTitle.keys) {\n            val boxInfo = legendAssemblerByTitle[legendTitle]!!.createLegend()\n            if (!boxInfo.isEmpty) {\n                legendBoxInfos.add(boxInfo)\n            }\n        }\n        return legendBoxInfos\n    }\n\n    fun createPlotLayout(tileLayout: TileLayout, facets: PlotFacets): PlotLayout {\n        if (!facets.isDefined) {\n            return SingleTilePlotLayout(tileLayout)\n        }\n\n        return FacetGridPlotLayout(\n            facets,\n            tileLayout\n        )\n    }\n\n\n    fun computePlotDryRunXYRanges(layersByTile: List<List<GeomLayer>>): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n        // 'dry run' aesthetics use 'identity' mappers for positional aes (because the plot size is not yet determined)\n        val dryRunAestheticsByTileLayer = HashMap<GeomLayer, Aesthetics>()\n        for (tileLayers in layersByTile) {\n            for (layer in tileLayers) {\n                val aesthetics = PlotUtil.createLayerDryRunAesthetics(layer)\n                dryRunAestheticsByTileLayer[layer] = aesthetics\n            }\n        }\n\n        fun initialRange(scale: Scale<Double>): ClosedRange<Double>? {\n            var initialRange: ClosedRange<Double>? = null\n\n            // Take in account:\n            // - scales domain if defined\n            // - scales breaks if defined\n            if (scale.isContinuousDomain) {\n                initialRange = updateRange(\n                    ScaleUtil.transformedDefinedLimits(scale).toList().filter { it.isFinite() },\n                    initialRange\n                )\n            }\n\n            if (scale.hasBreaks()) {\n                initialRange = updateRange(\n                    ScaleUtil.breaksTransformed(scale),\n                    initialRange\n                )\n            }\n            return initialRange\n        }\n\n        // the \"scale map\" is shared by all layers.\n        val scaleMap = layersByTile[0][0].scaleMap\n        var xInitialRange: ClosedRange<Double>? = initialRange(scaleMap[Aes.X])\n        var yInitialRange: ClosedRange<Double>? = initialRange(scaleMap[Aes.Y])\n\n        fun layerRange(\n            layer: GeomLayer,\n            aes: Aes<Double>,\n            initialRange: ClosedRange<Double>?,\n            aestheticsRange: ClosedRange<Double>?,\n        ): ClosedRange<Double>? {\n            var range: ClosedRange<Double>? = updateRange(aestheticsRange, initialRange)\n            range = PlotUtil.rangeWithExpand(layer, aes, range)\n            // include zero if necessary\n            if (layer.rangeIncludesZero(aes)) {\n                range = updateRange(ClosedRange.singleton(0.0), range)\n            }\n            return range\n        }\n\n        var xRangeOverall: ClosedRange<Double>? = null\n        var yRangeOverall: ClosedRange<Double>? = null\n        for (layers in layersByTile) {\n            for (layer in layers) {\n                // use dry-run aesthetics to estimate ranges\n                val aesthetics = dryRunAestheticsByTileLayer.getValue(layer)\n                // adjust X/Y range with 'pos adjustment' and 'expands'\n                val xyRanges = computeLayerDryRunXYRanges(layer, aesthetics)\n\n                val xRangeLayer = layerRange(layer, Aes.X, xInitialRange, xyRanges.first)\n                val yRangeLayer = layerRange(layer, Aes.Y, yInitialRange, xyRanges.second)\n\n                xRangeOverall = updateRange(xRangeLayer, xRangeOverall)\n                yRangeOverall = updateRange(yRangeLayer, yRangeOverall)\n            }\n        }\n\n        // validate XY ranges\n        xRangeOverall = SeriesUtil.ensureApplicableRange(xRangeOverall)\n        yRangeOverall = SeriesUtil.ensureApplicableRange(yRangeOverall)\n        return Pair(\n            xRangeOverall,\n            yRangeOverall\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.builder.assemble.facet.FacetGrid\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nabstract class PlotFacets {\n\n    abstract val isDefined: Boolean\n    abstract val colCount: Int\n    abstract val rowCount: Int\n    abstract val numTiles: Int\n    abstract val variables: List<String>\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    abstract fun dataByTile(data: DataFrame): List<DataFrame>\n\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    abstract fun tileInfos(): List<FacetTileInfo>\n\n\n    companion object {\n        const val DEF_ORDER_DIR = 1\n        val DEF_FORMATTER: (Any) -> String = { it.toString() }\n\n        fun undefined(): PlotFacets {\n            return FacetGrid(null, null, emptyList<Any>(), emptyList<Any>(), 1, 1)\n        }\n\n        fun dataByLevelTuple(\n            data: DataFrame,\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<Pair<List<Any>, DataFrame>> {\n            // This also checks invariants.\n            val nameLevelTuples = createNameLevelTuples(varNames, varLevels)\n\n            val vars = varNames.map { DataFrameUtil.findVariableOrFail(data, it) }\n\n            val indicesByVarByLevel = HashMap<String, Map<Any, List<Int>>>()\n            for ((i, variable) in vars.withIndex()) {\n                val levels = varLevels[i]\n\n                val indicesByLevel = HashMap<Any, List<Int>>()\n                for (level in levels) {\n                    val indices = SeriesUtil.matchingIndices(data[variable], level)\n                    indicesByLevel[level] = indices\n                }\n\n                indicesByVarByLevel[variable.name] = indicesByLevel\n            }\n\n            val dataByLevelKey = ArrayList<Pair<List<Any>, DataFrame>>()\n            for (nameLevelTuple in nameLevelTuples) {\n                val topName = nameLevelTuple.first().first\n                val topLevel = nameLevelTuple.first().second\n                val indices = ArrayList(indicesByVarByLevel.getValue(topName).getValue(topLevel))\n                for (i in 1 until nameLevelTuple.size) {\n                    val name = nameLevelTuple[i].first\n                    val level = nameLevelTuple[i].second\n                    val levelIndices = indicesByVarByLevel.getValue(name).getValue(level)\n                    indices.retainAll(HashSet(levelIndices))\n                }\n\n                val levelKey = nameLevelTuple.map { it.second }\n\n                // build the data subset\n                val b = DataFrame.Builder()\n                val variables = data.variables()\n                for (variable in variables) {\n                    val source = data[variable]\n                    val target = SeriesUtil.pickAtIndices(source, indices)\n                    b.put(variable, target)\n                }\n\n                val levelData = b.build()\n                dataByLevelKey.add(levelKey to levelData)\n            }\n\n            return dataByLevelKey\n        }\n\n        fun createNameLevelTuples(\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<List<Pair<String, Any>>> {\n            require(varNames.isNotEmpty()) { \"Empty list of facet variables.\" }\n            require(varNames.size == varNames.distinct().size) { \"Facet variables must be distinct, were: $varNames.\" }\n            check(varNames.size == varLevels.size)\n            return createNameLevelTuplesIntern(varNames, varLevels)\n        }\n\n        private fun createNameLevelTuplesIntern(\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<List<Pair<String, Any>>> {\n            val name = varNames.first()\n            val levels = varLevels.first()\n\n            val levelKeys = ArrayList<List<Pair<String, Any>>>()\n            for (level in levels) {\n                if (varNames.size > 1) {\n                    val subKeys = createNameLevelTuples(\n                        varNames.subList(1, varNames.size),\n                        varLevels.subList(1, varLevels.size)\n                    )\n                    for (subKey in subKeys) {\n                        levelKeys.add(listOf(name to level) + subKey)\n                    }\n                } else {\n                    // exit\n                    levelKeys.add(listOf(name to level))\n                }\n            }\n\n            return levelKeys\n        }\n\n        fun reorderLevels(\n            varNames: List<String>,\n            varLevels: List<List<Any>>,\n            ordering: List<Int>\n        ): List<List<Any>> {\n            val orderingByFacet = varNames.zip(ordering).toMap()\n\n            val result = ArrayList<List<Any>>()\n            for ((i, name) in varNames.withIndex()) {\n                if (i >= varLevels.size) break\n                result.add(reorderVarLevels(name, varLevels[i], orderingByFacet.getValue(name)))\n            }\n\n            return result\n        }\n\n        fun reorderVarLevels(\n            name: String?,\n            levels: List<Any>,\n            order: Int\n        ): List<Any> {\n            if (name == null) return levels\n\n            // We expect either a list of Doubles or a list of Strings.\n            @Suppress(\"UNCHECKED_CAST\", \"NAME_SHADOWING\")\n            levels as List<Comparable<Any>>\n\n            return when {\n                order < 0 -> levels.sortedDescending()\n                else -> levels.sorted()\n            }\n        }\n    }\n\n    class FacetTileInfo(\n        val col: Int,\n        val row: Int,\n        val colLabs: List<String>,\n        val rowLab: String?,\n        val xAxis: Boolean,\n        val yAxis: Boolean,\n        val trueIndex: Int     // tile index before re-ordering (in facet wrap)\n    ) {\n        override fun toString(): String {\n            return \"FacetTileInfo(col=$col, row=$row, colLabs=$colLabs, rowLab=$rowLab)\"\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\n\ninternal object PlotGuidesAssemblerUtil {\n    fun mappedRenderedAesToCreateGuides(\n        layerTiles: StitchedPlotLayers,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>\n    ): List<Aes<*>> {\n        if (layerTiles.isLegendDisabled) {\n            // ToDo: add support for\n            // show_legend = True     : show all aesthetics in legend\n            // show_legend = [.. list of aesthetics to show ..]     : show selected aesthetics in legend\n            // see: https://ggplot2.tidyverse.org/reference/geom_point.html\n            return emptyList()\n        }\n\n        val result = ArrayList<Aes<*>>()\n        for (aes in layerTiles.renderedAes()) {\n            if (Aes.noGuideNeeded(aes)) {\n                continue\n            }\n            if (layerTiles.hasConstant(aes)) {\n                // constants mask aes mappings\n                continue\n            }\n            if (!layerTiles.hasBinding(aes)) {\n                continue\n            }\n            if (guideOptionsMap.containsKey(aes)) {\n                if (guideOptionsMap[aes] === GuideOptions.NONE) {\n                    continue\n                }\n            }\n\n            result.add(aes)\n        }\n\n        return result\n    }\n\n    fun guideTransformedDomainByAes(\n        stitchedLayers: StitchedPlotLayers,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>\n    ): Map<Aes<*>, ClosedRange<Double>> {\n        val transformedDomainByAes = HashMap<Aes<*>, ClosedRange<Double>>()\n        val aesSet = mappedRenderedAesToCreateGuides(\n            stitchedLayers,\n            guideOptionsMap\n        )\n\n        for (aes in aesSet) {\n            // Should be only 'tarnsform' variables in bindings at this point.\n            val transformVariable = stitchedLayers.getBinding(aes).variable\n            check(transformVariable.isTransform)\n\n            val transformedDataRange = stitchedLayers.getDataRange(transformVariable)\n            if (transformedDataRange != null) {\n                val scale = stitchedLayers.getScale(aes)\n\n                val transformedDomain =\n                    if (scale.isContinuousDomain && scale.hasDomainLimits()) {\n                        val (scaleLower, scaleUpper) = ScaleUtil.transformedDefinedLimits(scale)\n                        val lowerEnd = if (scaleLower.isFinite()) scaleLower else transformedDataRange.lowerEnd\n                        val upperEnd = if (scaleUpper.isFinite()) scaleUpper else transformedDataRange.upperEnd\n                        ClosedRange<Double>(lowerEnd, upperEnd)\n                    } else {\n                        transformedDataRange\n                    }\n\n\n                transformedDomainByAes[aes] = transformedDomain\n            }\n        }\n\n        return transformedDomainByAes\n    }\n\n    fun createColorBarAssembler(\n        scaleName: String,\n        aes: Aes<*>, dataRangeByAes: Map<Aes<*>, ClosedRange<Double>>,\n        scale: Scale<Color>,\n        options: ColorBarOptions?,\n        theme: LegendTheme\n    ): ColorBarAssembler {\n\n        val domain = dataRangeByAes[aes]\n\n        // ToDo: this duplicates implementation code in MapperProvider.createContinuousMapper()\n        val domainWithLims = MapperUtil.rangeWithLimitsAfterTransform(\n            ensureApplicableRange(domain),\n            scale.domainLimits.first,\n            scale.domainLimits.second,\n            scale.transform\n        )\n\n        val result = ColorBarAssembler(\n            scaleName,\n            ensureApplicableRange(domainWithLims),\n            scale,\n            theme\n        )\n        result.setOptions(options)\n        return result\n    }\n\n    fun fitsColorBar(aes: Aes<*>, scale: Scale<*>): Boolean {\n        return aes.isColor && scale.isContinuous\n    }\n\n    fun checkFitsColorBar(aes: Aes<*>, scale: Scale<*>) {\n        check(aes.isColor) { \"Color-bar is not applicable to $aes aesthetic\" }\n        check(scale.isContinuous) { \"Color-bar is only applicable when both domain and color palette are continuous\" }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.pos.PositionAdjustments\nimport jetbrains.datalore.plot.builder.PosProviderContext\nimport kotlin.jvm.JvmOverloads\n\nabstract class PosProvider {\n\n    abstract fun createPos(ctx: PosProviderContext): PositionAdjustment\n\n    abstract fun handlesGroups(): Boolean\n\n    companion object {\n\n        fun wrap(pos: PositionAdjustment): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return pos\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return pos.handlesGroups()\n                }\n            }\n        }\n\n        fun barStack(): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.stack(ctx.aesthetics, PositionAdjustments.StackingStrategy.SPLIT_POSITIVE_NEGATIVE)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.STACK.handlesGroups()\n                }\n            }\n        }\n\n        @JvmOverloads\n        fun dodge(width: Double? = null): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    val aesthetics = ctx.aesthetics\n                    val groupCount = ctx.groupCount\n                    return PositionAdjustments.dodge(aesthetics, groupCount, width)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.DODGE.handlesGroups()\n                }\n            }\n        }\n\n        fun fill(): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.fill(ctx.aesthetics)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.FILL.handlesGroups()\n                }\n            }\n        }\n\n        fun jitter(width: Double?, height: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.jitter(width, height)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.JITTER.handlesGroups()\n                }\n            }\n        }\n\n        fun nudge(width: Double?, height: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.nudge(width, height)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.NUDGE.handlesGroups()\n                }\n            }\n        }\n\n        /*\n  public static PosProvider jitterDodge(Double jitterWidth, Double jitterHeight) {\n    return jitterDodge(null, jitterWidth, jitterHeight);\n  }\n  */\n\n        fun jitterDodge(width: Double?, jitterWidth: Double?, jitterHeight: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    val aesthetics = ctx.aesthetics\n                    val groupCount = ctx.groupCount\n                    return PositionAdjustments.jitterDodge(aesthetics, groupCount, width, jitterWidth, jitterHeight)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.JITTER_DODGE.handlesGroups()\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class StitchedPlotLayers(layers: List<jetbrains.datalore.plot.builder.GeomLayer>) {\n    private val myLayers: List<jetbrains.datalore.plot.builder.GeomLayer>\n\n    val legendKeyElementFactory: LegendKeyElementFactory\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].legendKeyElementFactory\n        }\n\n    val aestheticsDefaults: AestheticsDefaults\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].aestheticsDefaults\n        }\n\n    val isLegendDisabled: Boolean\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].isLegendDisabled\n        }\n\n    init {\n        myLayers = ArrayList(layers)\n    }\n\n    fun renderedAes(): List<Aes<*>> {\n        return if (myLayers.isEmpty()) {\n            emptyList()\n        } else myLayers[0].renderedAes()\n    }\n\n    fun hasBinding(aes: Aes<*>): Boolean {\n        return myLayers.isNotEmpty() && myLayers[0].hasBinding(aes)\n    }\n\n    fun hasConstant(aes: Aes<*>): Boolean {\n        return myLayers.isNotEmpty() && myLayers[0].hasConstant(aes)\n    }\n\n    fun <T> getConstant(aes: Aes<T>): T {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].getConstant(aes)\n    }\n\n    fun getBinding(aes: Aes<*>): VarBinding {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].getBinding(aes)\n    }\n\n    fun getScale(aes: Aes<*>): Scale<*> {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].scaleMap[aes]\n    }\n\n    fun getScaleMap(): TypedScaleMap {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].scaleMap\n    }\n\n    fun getDataRange(`var`: DataFrame.Variable): ClosedRange<Double>? {\n        check(isNumericData(`var`)) { \"Not numeric data [$`var`]\" }\n        var result: ClosedRange<Double>? = null\n        for (layer in myLayers) {\n            val range = layer.dataFrame.range(`var`)\n            result = SeriesUtil.span(result, range)\n        }\n        return result\n    }\n\n    fun isNumericData(`var`: DataFrame.Variable): Boolean {\n        check(myLayers.isNotEmpty())\n        for (layer in myLayers) {\n            if (!layer.dataFrame.isNumeric(`var`)) {\n                return false\n            }\n        }\n        return true\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\nclass TypedScaleMap constructor(map: Map<Aes<*>, Scale<*>>) {\n    private var myMap: Map<Aes<*>, Scale<*>> = map.toMap()\n\n    operator fun <T> get(aes: Aes<T>): Scale<T> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return (myMap[aes] as? Scale<T>) ?: run {\n            val message = \"No scale found for aes: $aes\"\n            LOG.error(IllegalStateException(message)) { message }\n            error(message)\n        }\n    }\n\n    fun containsKey(aes: Aes<*>): Boolean {\n        return myMap.containsKey(aes)\n    }\n\n    fun keySet(): Set<Aes<*>> {\n        return myMap.keys\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(TypedScaleMap::class)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.builder.scale.ScaleProvider\n\nclass TypedScaleProviderMap constructor(map: Map<Aes<*>, ScaleProvider<*>>) {\n    private var myMap: Map<Aes<*>, ScaleProvider<*>> = map.toMap()\n\n    operator fun <T> get(aes: Aes<T>): ScaleProvider<T> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return myMap[aes] as ScaleProvider<T>\n    }\n\n    fun containsKey(aes: Aes<*>): Boolean {\n        return myMap.containsKey(aes)\n    }\n\n    fun keySet(): Set<Aes<*>> {\n        return myMap.keys\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.facet\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.max\n\nclass FacetGrid(\n    private val xVar: String?,\n    private val yVar: String?,\n    xLevels: List<Any>,\n    yLevels: List<Any>,\n    xOrder: Int,\n    yOrder: Int,\n    private val xFormatter: (Any) -> String = DEF_FORMATTER,\n    private val yFormatter: (Any) -> String = DEF_FORMATTER,\n) : PlotFacets() {\n\n    override val isDefined: Boolean = xVar != null || yVar != null\n    private val xLevels: List<Any> = reorderVarLevels(xVar, xLevels, xOrder)\n    private val yLevels: List<Any> = reorderVarLevels(yVar, yLevels, yOrder)\n    override val colCount: Int = max(1, xLevels.size)\n    override val rowCount: Int = max(1, yLevels.size)\n    override val numTiles = colCount * rowCount\n    override val variables: List<String>\n        get() = listOfNotNull(xVar, yVar)\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun dataByTile(data: DataFrame): List<DataFrame> {\n        require(isDefined) { \"dataByTile() called on Undefined plot facets.\" }\n\n        val dataByLevelTupleList = dataByLevelTuple(\n            data,\n            listOfNotNull(\n                xVar,\n                yVar,\n            ),\n            listOfNotNull(\n                xVar?.let { xLevels },\n                yVar?.let { yLevels },\n            )\n        )\n        val dataByLevelTuple = dataByLevelTupleList.toMap()\n\n        val colLevels = xLevels.ifEmpty { listOf(null) }\n        val rowLevels = yLevels.ifEmpty { listOf(null) }\n\n        val dataByTile: MutableList<DataFrame> = ArrayList()\n        // Enumerate tiles by-row.\n        for (rowLevel in rowLevels) {\n            for (colLevel in colLevels) {\n                val levelTuple = listOfNotNull(colLevel, rowLevel)\n                val tileData = dataByLevelTuple.getValue(levelTuple)\n                dataByTile.add(tileData)\n            }\n        }\n\n        return dataByTile\n    }\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun tileInfos(): List<FacetTileInfo> {\n        val colLabels = (xLevels.ifEmpty { listOf(null) }).map {\n            it?.let { xFormatter(it) }\n        }\n        val rowLabels = (yLevels.ifEmpty { listOf(null) }).map {\n            it?.let { yFormatter(it) }\n        }\n\n        val infos = ArrayList<FacetTileInfo>()\n        for (row in 0 until rowCount) {\n            val addColLab = row == 0\n            val hasXAxis = row == rowCount - 1\n            for (col in 0 until colCount) {\n                val addRowLab = col == colCount - 1\n                val hasYAxis = col == 0\n\n                val colLabs = if (addColLab) {\n                    colLabels[col]?.let { listOf(it) } ?: emptyList()\n                } else {\n                    emptyList<String>()\n                }\n\n                infos.add(\n                    FacetTileInfo(\n                        col, row,\n                        colLabs,\n                        if (addRowLab) rowLabels[row] else null,\n                        hasXAxis, hasYAxis,\n                        trueIndex = infos.size\n                    )\n                )\n            }\n        }\n\n        return infos\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.facet\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.ceil\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass FacetWrap(\n    private val facets: List<String>,\n    levels: List<List<Any>>,\n    private val nrow: Int?,\n    private val ncol: Int?,\n    private val direction: Direction,\n    facetOrdering: List<Int>,\n    private val facetFormatters: List<(Any) -> String>,\n) : PlotFacets() {\n\n    override val isDefined: Boolean = true\n    private val levels: List<List<Any>> = reorderLevels(facets, levels, facetOrdering)\n    override val numTiles = numTiles(facets, levels)\n    private val shape = shape(numTiles, ncol, nrow, direction)\n    override val colCount: Int = shape.first\n    override val rowCount: Int = shape.second\n    override val variables: List<String> = facets\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun dataByTile(data: DataFrame): List<DataFrame> {\n        val dataByLevelTuple = dataByLevelTuple(\n            data,\n            variables,\n            levels\n        )\n\n        val dataByTile: MutableList<DataFrame> = ArrayList()\n        for ((_, tileData) in dataByLevelTuple) {\n            dataByTile.add(tileData)\n        }\n        return dataByTile\n    }\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun tileInfos(): List<FacetTileInfo> {\n\n        val levelTuples = createNameLevelTuples(facets, levels)\n        val tileLabels = levelTuples\n            .map { it.map { pair -> pair.second } }                    // get rid of 'pair'\n            .map { it.mapIndexed { i, level -> facetFormatters[i](level) } }                // to string tuples\n\n        fun toCol(index: Int): Int {\n            return when (direction) {\n                Direction.H -> index % colCount\n                Direction.V -> index / rowCount\n            }\n        }\n\n        fun toRow(index: Int): Int {\n            return when (direction) {\n                Direction.H -> index / colCount\n                Direction.V -> index % rowCount\n            }\n        }\n\n        fun toIndex(col: Int, row: Int): Int {\n            return when (direction) {\n                Direction.H -> row * colCount + col\n                Direction.V -> col * rowCount + row\n            }\n        }\n\n        fun isBottom(col: Int, row: Int): Boolean {\n            val nextRowIndex = toIndex(col, row + 1)\n            return (row + 1) % rowCount == 0 || nextRowIndex >= numTiles\n        }\n\n        val infos = ArrayList<FacetTileInfo>()\n        for ((i, tileLabelTuple) in tileLabels.withIndex()) {\n            val col = toCol(i)\n            val row = toRow(i)\n//            val nextRowIndex = toIndex(col, row + 1)\n//            val hasXAxis = nextRowIndex >= numTiles\n            val hasXAxis = isBottom(col, row)\n            val hasYAxis = col == 0\n\n            infos.add(\n                FacetTileInfo(\n                    col, row,\n                    colLabs = tileLabelTuple,\n                    null,\n                    hasXAxis, hasYAxis,\n                    trueIndex = i\n                )\n            )\n        }\n\n        // Enumeration is always 'by row'.\n        return infos.sortedWith(compareBy<FacetTileInfo> { it.row }.thenBy { it.col })\n    }\n\n    enum class Direction {\n        H, V\n    }\n\n    companion object {\n        private fun numTiles(\n            facets: List<String>,\n            levels: List<List<Any>>,\n        ): Int {\n            require(facets.isNotEmpty()) { \"List of facets is empty.\" }\n            require(facets.distinct().size == facets.size) { \"Duplicated values in the facets list: $facets\" }\n            check(facets.size == levels.size)\n            return createNameLevelTuples(facets, levels).size\n        }\n\n        private fun shape(tilesCount: Int, ncol: Int?, nrow: Int?, dir: Direction): Pair<Int, Int> {\n            require(ncol?.let { ncol > 0 } ?: true) { \"'ncol' must be positive, was $ncol\" }\n            require(nrow?.let { nrow > 0 } ?: true) { \"'nrow' must be positive, was $nrow\" }\n            val shape = when {\n                ncol != null -> {\n                    val ncolActual = min(ncol, tilesCount)\n                    val nrowActual = ceil(tilesCount.toDouble() / ncolActual).toInt()\n                    ncolActual to max(1, nrowActual)\n                }\n                nrow != null -> {\n                    val nrowActual = min(nrow, tilesCount)\n                    val ncolActual = ceil(tilesCount.toDouble() / nrowActual).toInt()\n                    ncolActual to max(1, nrowActual)\n                }\n                else -> {\n                    val w = min(4, max(1, tilesCount / 2))\n                    val h = max(1, ceil(tilesCount.toDouble() / w).toInt())\n                    w to h\n                }\n            }\n\n            val (w, h) = shape\n            return when (dir) {\n                Direction.H -> {\n                    // filling by rows\n                    Pair(\n                        w,\n                        ceil(tilesCount.toDouble() / w).toInt()\n                    )\n                }\n                Direction.V -> {\n                    // filling by cols\n                    Pair(\n                        ceil(tilesCount.toDouble() / h).toInt(),\n                        h\n                    )\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Geom\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.GeomMeta\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.geom.*\nimport jetbrains.datalore.plot.base.livemap.LiveMapOptions\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\n\nabstract class GeomProvider private constructor(val geomKind: GeomKind) {\n\n    open val preferredCoordinateSystem: CoordProvider\n        get() = throw IllegalStateException(\"No preferred coordinate system\")\n\n    fun renders(): List<Aes<*>> {\n        return GeomMeta.renders(geomKind)\n    }\n\n    abstract fun createGeom(): Geom\n\n    abstract fun aestheticsDefaults(): AestheticsDefaults\n\n    abstract fun handlesGroups(): Boolean\n\n    private class GeomProviderBuilder internal constructor(\n        private val myKind: GeomKind,\n        private val myAestheticsDefaults: AestheticsDefaults,\n        private val myHandlesGroups: Boolean,\n        private val myGeomSupplier: () -> Geom\n    ) {\n        internal fun build(): GeomProvider {\n            return object : GeomProvider(myKind) {\n\n                override fun createGeom(): Geom {\n                    return myGeomSupplier()\n                }\n\n                override fun aestheticsDefaults(): AestheticsDefaults {\n                    return myAestheticsDefaults\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return myHandlesGroups\n                }\n            }\n        }\n    }\n\n    companion object {\n\n        fun point(): GeomProvider {\n            return point { PointGeom() }\n        }\n\n        fun point(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POINT,\n                AestheticsDefaults.point(),\n                PointGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun path(): GeomProvider {\n            return path { PathGeom() }\n        }\n\n        fun path(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.PATH,\n                AestheticsDefaults.path(),\n                PathGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun line(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LINE,\n                AestheticsDefaults.line(),\n                LineGeom.HANDLES_GROUPS\n            ) { LineGeom() }.build()\n        }\n\n        fun smooth(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.SMOOTH,\n                AestheticsDefaults.smooth(),\n                SmoothGeom.HANDLES_GROUPS\n            ) { SmoothGeom() }.build()\n        }\n\n        fun bar(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BAR,\n                AestheticsDefaults.bar(),\n                BarGeom.HANDLES_GROUPS\n            ) { BarGeom() }.build()\n        }\n\n        fun histogram(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.HISTOGRAM,\n                AestheticsDefaults.histogram(),\n                HistogramGeom.HANDLES_GROUPS\n            ) { HistogramGeom() }.build()\n        }\n\n        fun tile(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.TILE,\n                AestheticsDefaults.tile(),\n                TileGeom.HANDLES_GROUPS\n            ) { TileGeom() }.build()\n        }\n\n        fun bin2d(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BIN_2D,\n                AestheticsDefaults.bin2d(),\n                Bin2dGeom.HANDLES_GROUPS\n            ) { Bin2dGeom() }.build()\n        }\n\n        fun errorBar(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.ERROR_BAR,\n                AestheticsDefaults.errorBar(),\n                ErrorBarGeom.HANDLES_GROUPS\n            ) { ErrorBarGeom() }.build()\n        }\n\n        fun crossBar(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CROSS_BAR,\n                AestheticsDefaults.crossBar(),\n                CrossBarGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun lineRange(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LINE_RANGE,\n                AestheticsDefaults.lineRange(),\n                LineRangeGeom.HANDLES_GROUPS\n            ) { LineRangeGeom() }.build()\n        }\n\n        fun pointRange(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POINT_RANGE,\n                AestheticsDefaults.pointRange(),\n                PointRangeGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun contour(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CONTOUR,\n                AestheticsDefaults.contour(),\n                ContourGeom.HANDLES_GROUPS\n            ) { ContourGeom() }.build()\n        }\n\n        fun contourf(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CONTOURF,\n                AestheticsDefaults.contourf(),\n                ContourfGeom.HANDLES_GROUPS\n            ) { ContourfGeom() }.build()\n        }\n\n        fun polygon(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POLYGON,\n                AestheticsDefaults.polygon(),\n                PolygonGeom.HANDLES_GROUPS\n            ) { PolygonGeom() }.build()\n        }\n\n        fun map(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.MAP,\n                AestheticsDefaults.map(),\n                MapGeom.HANDLES_GROUPS\n            ) { MapGeom() }.build()\n        }\n\n        fun abline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.AB_LINE,\n                AestheticsDefaults.abline(),\n                ABLineGeom.HANDLES_GROUPS\n            ) { ABLineGeom() }.build()\n        }\n\n        fun hline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.H_LINE,\n                AestheticsDefaults.hline(),\n                HLineGeom.HANDLES_GROUPS\n            ) { HLineGeom() }.build()\n        }\n\n        fun vline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.V_LINE,\n                AestheticsDefaults.vline(),\n                VLineGeom.HANDLES_GROUPS\n            ) { VLineGeom() }.build()\n        }\n\n        fun boxplot(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BOX_PLOT,\n                AestheticsDefaults.boxplot(),\n                BoxplotGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun livemap(\n            options: LiveMapOptions\n        ): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LIVE_MAP,\n                AestheticsDefaults.livemap(options.displayMode),\n                LiveMapGeom.HANDLES_GROUPS,\n                myGeomSupplier = { LiveMapGeom(options.displayMode) }\n            ).build()\n        }\n\n        fun ribbon(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RIBBON,\n                AestheticsDefaults.ribbon(),\n                RibbonGeom.HANDLES_GROUPS\n            ) { RibbonGeom() }.build()\n        }\n\n        fun area(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.AREA,\n                AestheticsDefaults.area(),\n                AreaGeom.HANDLES_GROUPS\n            ) { AreaGeom() }.build()\n        }\n\n        fun density(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY,\n                AestheticsDefaults.density(),\n                DensityGeom.HANDLES_GROUPS\n            ) { DensityGeom() }.build()\n        }\n\n        fun density2d(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY2D,\n                AestheticsDefaults.density2d(),\n                Density2dGeom.HANDLES_GROUPS\n            ) { Density2dGeom() }.build()\n        }\n\n        fun density2df(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY2DF,\n                AestheticsDefaults.density2df(),\n                Density2dfGeom.HANDLES_GROUPS\n            ) { Density2dfGeom() }.build()\n        }\n\n        fun jitter(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.JITTER,\n                AestheticsDefaults.jitter(),\n                JitterGeom.HANDLES_GROUPS\n            ) { JitterGeom() }.build()\n        }\n\n        fun freqpoly(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.FREQPOLY,\n                AestheticsDefaults.freqpoly(),\n                FreqpolyGeom.HANDLES_GROUPS\n            ) { FreqpolyGeom() }.build()\n        }\n\n        fun step(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.STEP,\n                AestheticsDefaults.step(),\n                StepGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun rect(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RECT,\n                AestheticsDefaults.rect(),\n                RectGeom.HANDLES_GROUPS\n            ) { RectGeom() }.build()\n        }\n\n        fun segment(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.SEGMENT,\n                AestheticsDefaults.segment(),\n                SegmentGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun text(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.TEXT,\n                AestheticsDefaults.text(),\n                TextGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun raster(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RASTER,\n                AestheticsDefaults.raster(),\n                RasterGeom.HANDLES_GROUPS\n            ) { RasterGeom() }.build()\n        }\n\n        fun image(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.IMAGE,\n                AestheticsDefaults.image(),\n                ImageGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.scale.ScaleUtil.labelByBreak\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.TypedScaleMap\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\n\ninternal class PointDataAccess(\n    private val data: DataFrame,\n    bindings: Map<Aes<*>, VarBinding>,\n    scaleMap: TypedScaleMap\n) : MappedDataAccess {\n\n    override val mappedAes: Set<Aes<*>> = HashSet(bindings.keys)\n    override val scaleByAes: (Aes<*>) -> Scale<*> = { scaleMap[it] }\n    private val myBindings: Map<Aes<*>, VarBinding> = bindings.toMap()\n    private val myFormatters = HashMap<Aes<*>, (Any?) -> String>()\n\n    override fun isMapped(aes: Aes<*>) = myBindings.containsKey(aes)\n\n    override fun <T> getMappedData(aes: Aes<T>, index: Int): MappedDataAccess.MappedData<T> {\n        val originalValue = getOriginalValue(aes, index)\n        val scale = getScale(aes)\n        val value = formatter(aes).invoke(originalValue)\n        return MappedDataAccess.MappedData(\n            label = scale.name,\n            value = value,\n            isContinuous = scale.isContinuous\n        )\n    }\n\n    override fun <T> getOriginalValue(aes: Aes<T>, index: Int): Any? {\n        require(isMapped(aes)) { \"Not mapped: $aes\" }\n\n        val binding = myBindings.getValue(aes)\n        val scale = getScale(aes)\n\n        return binding.variable\n            .let { variable -> data.getNumeric(variable)[index] }\n            .let { value -> scale.transform.applyInverse(value) }\n    }\n\n    override fun getMappedDataLabel(aes: Aes<*>): String = getScale(aes).name\n\n    override fun isMappedDataContinuous(aes: Aes<*>): Boolean = getScale(aes).isContinuous\n\n    private fun getScale(aes: Aes<*>): Scale<*> {\n        return scaleByAes(aes)\n    }\n\n    private fun <T> formatter(aes: Aes<T>): (Any?) -> String {\n        val scale = getScale(aes)\n        return myFormatters.getOrPut(aes, defaultValue = { createFormatter(aes, scale) })\n    }\n\n    private fun createFormatter(aes: Aes<*>, scale: Scale<*>): (Any?) -> String {\n        if (scale.isContinuousDomain) {\n            // only 'stat' or 'transform' vars here\n            val domain = myBindings\n                .getValue(aes)\n                .variable\n                .run(data::range)\n                .run(::ensureApplicableRange)\n\n            val formatter = scale.breaksGenerator.labelFormatter(domain, 100)\n            return { value -> value?.let { formatter.invoke(it) } ?: \"n/a\" }\n        } else {\n            val labelsMap = labelByBreak(scale)\n            return { value -> value?.let { labelsMap.getValue(it) } ?: \"n/a\" }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\ninternal class CartesianCoordProvider(\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim)","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\n\ninternal abstract class CoordProviderBase(\n    private val xLim: ClosedRange<Double>?,\n    private val yLim: ClosedRange<Double>?\n) : CoordProvider {\n\n    override fun buildAxisScaleX(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: GuideBreaks\n    ): Scale<Double> {\n        return buildAxisScaleDefault(\n            scaleProto,\n            domain,\n            axisLength,\n            breaks\n        )\n    }\n\n    override fun buildAxisScaleY(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: GuideBreaks\n    ): Scale<Double> {\n        return buildAxisScaleDefault(\n            scaleProto,\n            domain,\n            axisLength,\n            breaks\n        )\n    }\n\n    override fun createCoordinateSystem(\n        xDomain: ClosedRange<Double>,\n        xAxisLength: Double,\n        yDomain: ClosedRange<Double>,\n        yAxisLength: Double\n    ): CoordinateSystem {\n        val mapperX = linearMapper(xDomain, xAxisLength)\n        val mapperY = linearMapper(yDomain, yAxisLength)\n        return Coords.create(\n            MapperUtil.map(\n                xDomain,\n                mapperX\n            ),\n            MapperUtil.map(\n                yDomain,\n                mapperY\n            ),\n            xLim?.let { MapperUtil.map(it, mapperX) },\n            yLim?.let { MapperUtil.map(it, mapperY) }\n        )\n    }\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n        return Pair(xLim ?: xDomain, yLim ?: yDomain)\n    }\n\n    companion object {\n        fun linearMapper(domain: ClosedRange<Double>, axisLength: Double): (Double?) -> Double? {\n            return Mappers.mul(domain, axisLength)\n        }\n\n        private fun buildAxisScaleDefault(\n            scaleProto: Scale<Double>,\n            domain: ClosedRange<Double>,\n            axisLength: Double,\n            breaks: GuideBreaks\n        ): Scale<Double> {\n            return buildAxisScaleDefault(\n                scaleProto,\n                linearMapper(domain, axisLength),\n                breaks\n            )\n        }\n\n        fun buildAxisScaleDefault(\n            scaleProto: Scale<Double>,\n            axisMapper: (Double?) -> Double?,\n            breaks: GuideBreaks\n        ): Scale<Double> {\n            return scaleProto.with()\n                .breaks(breaks.domainValues)\n                .labels(breaks.labels)\n                .mapper(axisMapper)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.builder.coord.map.MercatorProjectionX\nimport jetbrains.datalore.plot.builder.coord.map.MercatorProjectionY\n\nobject CoordProviders {\n    fun cartesian(xLim: ClosedRange<Double>? = null, yLim: ClosedRange<Double>? = null): CoordProvider {\n        return CartesianCoordProvider(xLim, yLim)\n    }\n\n    fun fixed(\n        ratio: Double,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordProvider {\n        return FixedRatioCoordProvider(ratio, xLim, yLim)\n    }\n\n    fun map(\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordProvider {\n        // Only Mercator so far.\n        return ProjectionCoordProvider(\n            MercatorProjectionX(),\n            MercatorProjectionY(),\n            xLim,\n            yLim\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * A fixed scale coordinate system forces a specified ratio between the physical representation of data units on the axes.\n * The ratio represents the number of units on the y-axis equivalent to one unit on the x-axis.\n * ratio = 1, ensures that one unit on the x-axis is the same length as one unit on the y-axis.\n * Ratios higher than one make units on the y axis longer than units on the x-axis, and vice versa.\n */\ninternal open class FixedRatioCoordProvider(\n    private val ratio: Double,\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim) {\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n\n        // account for limits\n        val adjusted = super.adjustDomains(xDomain, yDomain, displaySize)\n\n        @Suppress(\"NAME_SHADOWING\")\n        var xDomain = adjusted.first\n\n        @Suppress(\"NAME_SHADOWING\")\n        var yDomain = adjusted.second\n\n        val spanX = SeriesUtil.span(xDomain)\n        val spanY = SeriesUtil.span(yDomain)\n        if (spanX < SeriesUtil.TINY || spanY < SeriesUtil.TINY) {\n            return Pair(xDomain, yDomain) // don't touch\n        }\n\n        // fit the data into the display\n        var displayW = displaySize.x\n        var displayH = displaySize.y\n\n        // Distort display size to account for 'ratio'\n        // ratio == 1 -> X-units equal Y-units\n        // ratio > 1 -> Y-units are longer\n        // ratio < 1 -> X-units are longer\n        if (ratio > 1) {\n            displayW *= ratio\n        } else {\n            displayH *= 1 / ratio\n        }\n\n        val ratioX = spanX / displayW\n        val ratioY = spanY / displayH\n\n        // Take bigger ratio and apply to ortogonal domain (axis) so that\n        // ratio: (data range) / (axis length) is the same for both X and Y.\n        if (ratioX > ratioY) {\n            val spanAdjusted = displayH * ratioX\n            yDomain = SeriesUtil.expand(yDomain, spanAdjusted)\n        } else {\n            val spanAdjusted = displayW * ratioY\n            xDomain = SeriesUtil.expand(xDomain, spanAdjusted)\n        }\n\n        return Pair(xDomain, yDomain)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.coord.Projection\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class ProjectionCoordProvider(\n    private val projectionX: Projection,\n    private val projectionY: Projection,\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim) {\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n\n        // account for limits\n        val adjusted = super.adjustDomains(xDomain, yDomain, displaySize)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val xDomain = projectionX.toValidDomain(adjusted.first)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val yDomain = projectionY.toValidDomain(adjusted.second)\n\n        // compute projected ratio\n        val spanX = SeriesUtil.span(xDomain)\n        val spanY = SeriesUtil.span(yDomain)\n        val domainSquare: Pair<ClosedRange<Double>, ClosedRange<Double>> =\n            if (spanX > spanY) {\n                val center = xDomain.lowerEnd + spanX / 2\n                val halfSpan = spanY / 2\n                Pair(\n                    ClosedRange(center - halfSpan, center + halfSpan),\n                    yDomain\n                )\n            } else {\n                val center = yDomain.lowerEnd + spanY / 2\n                val halfSpan = spanX / 2\n                Pair(\n                    xDomain,\n                    ClosedRange(center - halfSpan, center + halfSpan)\n                )\n            }\n\n        val projectedXMin = projectionX.apply(domainSquare.first.lowerEnd)\n        val projectedXMax = projectionX.apply(domainSquare.first.upperEnd)\n        val projectedYMin = projectionY.apply(domainSquare.second.lowerEnd)\n        val projectedYMax = projectionY.apply(domainSquare.second.upperEnd)\n\n        val ratio = (projectedYMax - projectedYMin) / (projectedXMax - projectedXMin)\n        val fixedCoord = FixedRatioCoordProvider(ratio, null, null)\n        return fixedCoord.adjustDomains(xDomain, yDomain, displaySize)\n    }\n\n    override fun buildAxisScaleX(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: GuideBreaks\n    ): Scale<Double> {\n        return if (projectionX.nonlinear) {\n            buildAxisScaleWithProjection(\n                projectionX,\n                scaleProto,\n                domain,\n                axisLength,\n                breaks\n            )\n        } else {\n            super.buildAxisScaleX(scaleProto, domain, axisLength, breaks)\n        }\n    }\n\n    override fun buildAxisScaleY(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: GuideBreaks\n    ): Scale<Double> {\n        return if (projectionY.nonlinear) {\n            buildAxisScaleWithProjection(\n                projectionY,\n                scaleProto,\n                domain,\n                axisLength,\n                breaks\n            )\n        } else {\n            super.buildAxisScaleY(scaleProto, domain, axisLength, breaks)\n        }\n    }\n\n    companion object {\n        private fun buildAxisScaleWithProjection(\n            projection: Projection, scaleProto: Scale<Double>,\n            domain: ClosedRange<Double>,\n            axisLength: Double,\n            breaks: GuideBreaks\n        ): Scale<Double> {\n\n            val validDomain = projection.toValidDomain(domain)\n            val validDomainProjected = ClosedRange(\n                projection.apply(validDomain.lowerEnd),\n                projection.apply(validDomain.upperEnd)\n            )\n\n            val projectionInverse = Mappers.linear(validDomainProjected, validDomain)\n\n            val linearMapper = linearMapper(\n                domain,\n                axisLength\n            )\n            val scaleMapper = twistScaleMapper(\n                projection,\n                projectionInverse,\n                linearMapper\n            )\n            val validBreaks = validateBreaks(\n                validDomain,\n                breaks\n            )\n            return buildAxisScaleDefault(\n                scaleProto,\n                scaleMapper,\n                validBreaks\n            )\n        }\n\n        private fun validateBreaks(validDomain: ClosedRange<Double>, breaks: GuideBreaks): GuideBreaks {\n            val validIndices = ArrayList<Int>()\n            var i = 0\n            for (v in breaks.domainValues) {\n                if (v is Double && validDomain.contains(v)) {\n                    validIndices.add(i)\n                }\n                i++\n            }\n\n            if (validIndices.size == breaks.domainValues.size) {\n                return breaks\n            }\n\n            val validDomainValues = SeriesUtil.pickAtIndices(breaks.domainValues, validIndices)\n            val validLabels = SeriesUtil.pickAtIndices(breaks.labels, validIndices)\n            val validTransformedValues = SeriesUtil.pickAtIndices(breaks.transformedValues, validIndices)\n            return GuideBreaks(\n                validDomainValues,\n                validTransformedValues,\n                validLabels\n            )\n        }\n\n        private fun twistScaleMapper(\n            projection: Projection, projectionInverse: (Double) -> Double,\n            scaleMapper: (Double?) -> Double?\n        ): (Double?) -> Double? {\n            return { v ->\n                v?.run {\n                    val projected = projection.apply(v)\n                    val unProjected = projectionInverse(projected)\n                    scaleMapper(unProjected)\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord.map\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.MercatorUtils.getMercatorX\nimport jetbrains.datalore.plot.base.coord.Projection\n\n// ToDo: duplicates jetbrains.livemap.core.projections.MercatorProjection\nclass MercatorProjectionX : Projection {\n    override val nonlinear = false\n\n    override fun apply(v: Double): Double {\n        return getMercatorX(v)\n    }\n\n    override fun toValidDomain(domain: ClosedRange<Double>): ClosedRange<Double> {\n        return domain\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord.map\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.MercatorUtils.VALID_LATITUDE_RANGE\nimport jetbrains.datalore.base.spatial.MercatorUtils.getMercatorY\nimport jetbrains.datalore.plot.base.coord.Projection\n\nclass MercatorProjectionY : Projection {\n    override val nonlinear = true\n\n    override fun apply(v: Double): Double {\n        return getMercatorY(v)\n    }\n\n    override fun toValidDomain(domain: ClosedRange<Double>): ClosedRange<Double> {\n        if (VALID_LATITUDE_RANGE.isConnected(domain)) {\n            return VALID_LATITUDE_RANGE.intersection(domain)\n        }\n        throw IllegalArgumentException(\"Illegal latitude range for mercator projection: $domain\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.base.function.Consumer\nimport jetbrains.datalore.base.gcommon.base.Strings.isNullOrEmpty\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.DataFrame.Builder\nimport jetbrains.datalore.plot.base.DataFrame.Builder.Companion.emptyFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport jetbrains.datalore.plot.builder.assemble.TypedScaleMap\nimport jetbrains.datalore.plot.builder.data.GroupUtil.indicesByGroup\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.pickAtIndices\n\nobject DataProcessing {\n\n    fun transformOriginals(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap\n    ): DataFrame {\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (variable.isOrigin) {\n                check(data.has(variable)) { \"Undefined variable $variable\" }\n                data = DataFrameUtil.applyTransform(\n                    data,\n                    variable,\n                    binding.aes,\n                    scaleMap[binding.aes]\n                )\n            }\n        }\n\n        return data\n    }\n\n    fun buildStatData(\n        data: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap,\n        groupingContext: GroupingContext,\n        facets: PlotFacets,\n        statCtx: StatContext,\n        varsWithoutBinding: List<String>,\n        orderOptions: List<OrderOptionUtil.OrderOption>,\n        aggregateOperation: ((List<Double?>) -> Double?)?,\n        messageConsumer: Consumer<String>\n    ): DataAndGroupingContext {\n        if (stat === Stats.IDENTITY) {\n            return DataAndGroupingContext(emptyFrame(), groupingContext)\n        }\n\n        val groups = groupingContext.groupMapper\n\n        val resultSeries: Map<Variable, List<Any?>>\n        val groupSizeListAfterStat: List<Int>\n\n        // if only one group no need to modify\n        if (groups === GroupUtil.SINGLE_GROUP) {\n            val sd = applyStat(data, stat, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer)\n            groupSizeListAfterStat = listOf(sd.rowCount())\n            resultSeries = sd.variables().associateWith { variable -> sd[variable] }\n        } else { // add offset to each group\n            val groupMerger = GroupMerger()\n            var lastStatGroupEnd = -1\n            for (d in splitByGroup(data, groups)) {\n                var sd = applyStat(d, stat, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer)\n                if (sd.isEmpty) {\n                    continue\n                }\n                groupMerger.initOrderSpecs(orderOptions, sd.variables(), bindings, aggregateOperation)\n\n                val curGroupSizeAfterStat = sd.rowCount()\n\n                // update 'stat group' to avoid collisions as stat is applied independently to each original data group\n                if (sd.has(Stats.GROUP)) {\n                    val range = sd.range(Stats.GROUP)\n                    if (range != null) {\n                        val start = lastStatGroupEnd + 1\n                        val offset = start - range.lowerEnd.toInt()\n                        lastStatGroupEnd = range.upperEnd.toInt() + offset\n                        if (offset != 0) {\n                            val newG = ArrayList<Double>()\n                            for (g in sd.getNumeric(Stats.GROUP)) {\n                                newG.add(g!! + offset)\n                            }\n                            sd = sd.builder().putNumeric(Stats.GROUP, newG).build()\n                        }\n                    }\n                } else { // if stat has ..group.. then groupingVar won't be checked, so no need to update\n                    val groupingVar = groupingContext.optionalGroupingVar\n                    if (groupingVar != null) {\n                        val size = sd[sd.variables().first()].size\n                        val v = d[groupingVar][0]\n                        sd = sd.builder().put(groupingVar, List(size) { v }).build()\n                    }\n                }\n\n                // Add group's data\n                groupMerger.addGroup(sd, curGroupSizeAfterStat)\n            }\n            // Get merged series\n            resultSeries = groupMerger.getResultSeries()\n            groupSizeListAfterStat = groupMerger.getGroupSizes()\n        }\n\n        val dataAfterStat = Builder().run {\n            // put results\n            for (variable in resultSeries.keys) {\n                put(variable, resultSeries[variable]!!)\n            }\n\n            // set ordering specifications\n            val orderSpecs = orderOptions.map { orderOption ->\n                OrderOptionUtil.createOrderSpec(resultSeries.keys, bindings, orderOption, aggregateOperation)\n            }\n            addOrderSpecs(orderSpecs)\n\n            // build DataFrame\n            build()\n        }\n\n        val groupingContextAfterStat = GroupingContext.withOrderedGroups(\n            dataAfterStat,\n            groupSizeListAfterStat\n        )\n\n        return DataAndGroupingContext(\n            dataAfterStat,\n            groupingContextAfterStat\n        )\n    }\n\n    internal fun findOptionalVariable(data: DataFrame, name: String?): Variable? {\n        return if (isNullOrEmpty(name))\n            null\n        else\n            DataFrameUtil.findVariableOrFail(data, name!!)\n    }\n\n    private fun splitByGroup(data: DataFrame, groups: (Int) -> Int): List<DataFrame> {\n        return indicesByGroup(data.rowCount(), groups).values.map { indices ->\n            data.variables().fold(Builder()) { b, variable ->\n                when (data.isNumeric(variable)) {\n                    true -> b.putNumeric(variable, pickAtIndices(data.getNumeric(variable), indices))\n                    false -> b.putDiscrete(variable, pickAtIndices(data[variable], indices))\n                }\n            }\n        }.map(Builder::build)\n    }\n\n    /**\n     * Server-side only\n     */\n\n    private fun applyStat(\n        data: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap,\n        facets: PlotFacets,\n        statCtx: StatContext,\n        varsWithoutBinding: List<String>,\n        compMessageConsumer: Consumer<String>\n    ): DataFrame {\n\n        var statData = stat.apply(data, statCtx, compMessageConsumer)\n\n        val statVariables = statData.variables()\n        if (statVariables.isEmpty()) {\n            return statData\n        }\n\n        // generate new 'input' series to match stat series\n\n        val inverseTransformedStatSeries =\n            inverseTransformContinuousStatData(\n                statData,\n                stat,\n                bindings,\n                scaleMap\n            )\n\n        // generate new series for facet variables\n\n        val statDataSize = statData[statVariables.iterator().next()].size\n        val facetVars = HashSet<Variable>()\n        for (facetVarName in facets.variables) {\n            val facetVar = DataFrameUtil.findVariableOrFail(data, facetVarName)\n            facetVars.add(facetVar)\n            if (data[facetVar].isNotEmpty()) {\n                val facetLevel = data[facetVar][0]\n                // generate series for 'facet' variable\n                statData = statData\n                    .builder()\n                    .put(facetVar, List(statDataSize) { facetLevel })\n                    .build()\n            }\n        }\n\n        // generate new series for input variables\n\n        if (bindings.isEmpty()) {\n            return statData\n        }\n\n        val newInputSeries = HashMap<Variable, List<*>>()\n\n        fun addSeriesForVariable(variable: Variable) {\n            val value = when (data.isNumeric(variable)) {\n                true -> SeriesUtil.mean(data.getNumeric(variable), defaultValue = null)\n                false -> SeriesUtil.firstNotNull(data[variable], defaultValue = null)\n            }\n            val newInputSerie = List(statDataSize) { value }\n            newInputSeries[variable] = newInputSerie\n        }\n\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (variable.isStat || facetVars.contains(variable)) {\n                continue\n            }\n\n            val aes = binding.aes\n            if (stat.hasDefaultMapping(aes)) {\n                val defaultStatVar = stat.getDefaultMapping(aes)\n                val newInputSerie: List<*> =\n                    if (inverseTransformedStatSeries.containsKey(defaultStatVar)) {\n                        inverseTransformedStatSeries.getValue(defaultStatVar)\n                    } else {\n                        val statSerie = statData.getNumeric(defaultStatVar)\n                        ScaleUtil.inverseTransform(statSerie, scaleMap[aes])\n                    }\n                newInputSeries[variable] = newInputSerie\n            } else {\n                // Do not override series obtained via 'default stat var'\n                if (!newInputSeries.containsKey(variable)) {\n                    addSeriesForVariable(variable)\n                }\n            }\n        }\n        // series for variables without bindings\n        for (varName in varsWithoutBinding.filterNot(Stats::isStatVar)) {\n            val variable = DataFrameUtil.findVariableOrFail(data, varName)\n            if (!newInputSeries.containsKey(variable)) {\n                addSeriesForVariable(variable)\n            }\n        }\n\n        val b = statData.builder()\n        for (variable in newInputSeries.keys) {\n            b.put(variable, newInputSeries.getValue(variable))\n        }\n        // also update stat series\n        for (variable in inverseTransformedStatSeries.keys) {\n            b.putNumeric(variable, inverseTransformedStatSeries.getValue(variable))\n        }\n\n        return b.build()\n    }\n\n    private fun inverseTransformContinuousStatData(\n        statData: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap\n    ): Map<Variable, List<Double?>> {\n        // inverse transform stat data with continuous domain.\n        val continuousScaleByAes = HashMap<Aes<*>, Scale<*>>()\n        val aesByMappedStatVar = HashMap<Variable, Aes<*>>()\n        for (aes in Aes.values()) {\n            if (stat.hasDefaultMapping(aes)) {\n                val defaultStatVar = stat.getDefaultMapping(aes)\n                aesByMappedStatVar[defaultStatVar] = aes\n            }\n        }\n\n        for (binding in bindings) {\n            val aes = binding.aes\n            val variable = binding.variable\n            if (variable.isStat) {\n                aesByMappedStatVar[variable] = aes\n                // ignore 'stat' var becaue ..?\n                continue\n            }\n\n            val scale = scaleMap[aes]\n            if (scale.isContinuousDomain) {\n                continuousScaleByAes[aes] = scale\n                if (Aes.isPositionalX(aes) && !continuousScaleByAes.containsKey(Aes.X)) {\n                    continuousScaleByAes[Aes.X] = scale\n                } else if (Aes.isPositionalY(aes) && !continuousScaleByAes.containsKey(Aes.Y)) {\n                    continuousScaleByAes[Aes.Y] = scale\n                }\n            }\n        }\n\n        val inverseTransformedStatSeries = HashMap<Variable, List<Double?>>()\n        for (statVar in statData.variables()) {\n            if (aesByMappedStatVar.containsKey(statVar)) {\n                val aes = aesByMappedStatVar.getValue(statVar)\n                var scale: Scale<*>? = continuousScaleByAes[aes]\n                if (scale == null) {\n                    if (Aes.isPositionalX(aes)) {\n                        scale = continuousScaleByAes[Aes.X]\n                    } else if (Aes.isPositionalY(aes)) {\n                        scale = continuousScaleByAes[Aes.Y]\n                    }\n                }\n\n                if (scale != null) {\n                    val statSerie = statData.getNumeric(statVar)\n                    val inverseTransformedStatSerie = ScaleUtil.inverseTransformToContinuousDomain(statSerie, scale)\n                    inverseTransformedStatSeries[statVar] = inverseTransformedStatSerie\n                }\n            }\n        }\n        return inverseTransformedStatSeries\n    }\n\n    internal fun computeGroups(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        groupingVar: Variable?,\n        pathIdVar: Variable?\n    ): (Int) -> Int {\n        val groupingVariables = getGroupingVariables(data, bindings, groupingVar) + listOfNotNull(pathIdVar)\n\n        var currentGroups: List<Int>? = null\n        if (groupingVar != null) {\n            currentGroups = computeGroups(data[groupingVar])\n        }\n\n        for (groupingVariable in groupingVariables) {\n            val values = data[groupingVariable]\n            val groups = computeGroups(values)\n            if (currentGroups == null) {\n                currentGroups = groups\n                continue\n            }\n\n            check(currentGroups.size == groups.size) {\n                \"Data series used to compute groups must be equal in size (encountered sizes: \" +\n                        \"${currentGroups?.size}, ${groups.size} )\"\n            }\n            val dummies = computeDummyValues(currentGroups, groups)\n            currentGroups = computeGroups(dummies)\n        }\n\n        return if (currentGroups != null) {\n            GroupUtil.wrap(currentGroups)\n        } else {\n            GroupUtil.SINGLE_GROUP\n        }\n    }\n\n    private fun computeGroups(values: List<*>): List<Int> {\n        val groups = ArrayList<Int>()\n        val groupByVal = HashMap<Any?, Int>()\n        var count = 0\n        for (v in values) {\n            if (!groupByVal.containsKey(v)) {\n                groupByVal[v] = count++\n            }\n            groups.add(groupByVal.get(v)!!)\n        }\n        return groups\n    }\n\n    private fun computeDummyValues(list1: List<Int>, list2: List<Int>): List<Int> {\n        if (list1.isEmpty()) return emptyList()\n\n        val limit = 1000\n\n        val max = natural<Int>().max(Iterables.concat(list1, list2))\n        check(max < limit) { \"Too many groups: $max\" }\n        val dummies = ArrayList<Int>()\n        val it1 = list1.iterator()\n        val it2 = list2.iterator()\n        while (it1.hasNext()) {\n            val v1 = it1.next()\n            val v2 = it2.next()\n            val dummy = v1 * limit + v2\n            dummies.add(dummy)\n        }\n        return dummies\n    }\n\n    private fun getGroupingVariables(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        explicitGroupingVar: Variable?\n    ): Iterable<Variable> {\n\n        // all 'origin' discrete vars (but not positional) + explicitGroupingVar\n        val result = LinkedHashSet<Variable>()\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (!result.contains(variable)) {\n                if (variable.isOrigin) {\n                    if (variable == explicitGroupingVar || isDefaultGroupingVariable(data, binding.aes, variable)) {\n                        result.add(variable)\n                    }\n                }\n            }\n        }\n        return result\n    }\n\n    private fun isDefaultGroupingVariable(\n        data: DataFrame,\n        aes: Aes<*>,\n        variable: Variable\n    ) = !(Aes.isPositional(aes) || data.isNumeric(variable))\n\n    class DataAndGroupingContext internal constructor(val data: DataFrame, val groupingContext: GroupingContext)\n\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.VarBinding\n\ninternal class GroupMerger {\n    private var myOrderSpecs: List<DataFrame.OrderSpec>? = null\n    private val myOrderedGroups = ArrayList<Group>()\n\n    fun initOrderSpecs(\n        orderOptions: List<OrderOptionUtil.OrderOption>,\n        variables: Set<DataFrame.Variable>,\n        bindings: List<VarBinding>,\n        aggregateOperation: ((List<Double?>) -> Double?)?\n    ) {\n        if (myOrderSpecs != null) return\n        myOrderSpecs = orderOptions\n            .filter { orderOption ->\n                // no need to reorder groups by X\n                bindings.find { it.variable.name == orderOption.variableName && it.aes == Aes.X } == null\n            }\n            .map { OrderOptionUtil.createOrderSpec(variables, bindings, it, aggregateOperation) }\n    }\n\n    fun getResultSeries(): HashMap<DataFrame.Variable, MutableList<Any?>> {\n        val resultSeries = HashMap<DataFrame.Variable, MutableList<Any?>>()\n        myOrderedGroups.forEach { group ->\n            group.df.variables().forEach { variable ->\n                resultSeries.getOrPut(variable, ::ArrayList).addAll(group.df[variable])\n            }\n        }\n        return resultSeries\n    }\n\n    fun getGroupSizes(): List<Int> {\n        return myOrderedGroups.map(Group::groupSize)\n    }\n\n    inner class Group(\n        val df: DataFrame,\n        val groupSize: Int\n    ) : Comparable<Group> {\n        override fun compareTo(other: Group): Int {\n            fun compareGroupValue(v1: Any?, v2: Any?, dir: Int): Int {\n                // null value is always greater - will be at the end of the result\n                if (v1 == null && v2 == null ) return 0\n                if (v1 == null) return 1\n                if (v2 == null) return -1\n                return compareValues(v1 as Comparable<*>, v2 as Comparable<*>) * dir\n            }\n            fun getValue(\n                df: DataFrame,\n                variable: DataFrame.Variable,\n                aggregateOperation: ((List<Double?>) -> Double?)? = null\n            ): Any? {\n                return if (aggregateOperation != null) {\n                    require(df.isNumeric(variable)) { \"Can't apply aggregate operation to non-numeric values\" }\n                    aggregateOperation.invoke(df.getNumeric(variable).requireNoNulls())\n                } else {\n                    // group has no more than one unique element\n                    df[variable].firstOrNull()\n                }\n            }\n\n            myOrderSpecs?.forEach { spec ->\n                var cmp = compareGroupValue(\n                    getValue(df, spec.orderBy, spec.aggregateOperation),\n                    getValue(other.df, spec.orderBy, spec.aggregateOperation),\n                    spec.direction\n                )\n                if (cmp == 0) {\n                    // ensure the order as in the legend\n                    cmp = compareGroupValue(\n                        getValue(df, spec.variable),\n                        getValue(other.df, spec.variable),\n                        spec.direction\n                    )\n                }\n                if (cmp != 0) {\n                    return cmp\n                }\n            }\n            return 0\n        }\n    }\n\n    fun addGroup(d: DataFrame, groupSize: Int) {\n        val group = Group(d, groupSize)\n        val indexToInsert = findIndexToInsert(group)\n        myOrderedGroups.add(indexToInsert, group)\n    }\n\n    private fun findIndexToInsert(group: Group): Int {\n        if (myOrderSpecs.isNullOrEmpty()) {\n            return myOrderedGroups.size\n        }\n        var index = myOrderedGroups.binarySearch(group)\n        if (index < 0) index = index.inv()\n        return index\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nobject GroupUtil {\n    internal val SINGLE_GROUP = { _: Int -> 0 }\n\n    fun wrap(l: List<Number?>): (Int) -> Int {\n        return { index ->\n            if (index > 0 && index < l.size)\n                l[index]!!.toInt()\n            else\n                0\n        }\n    }\n\n    fun wrap(groupByPointIndex: Map<Int, Int>): (Int) -> Int {\n        return { groupByPointIndex[it]!! }\n    }\n\n    fun indicesByGroup(dataLength: Int, groups: (Int) -> Int): Map<Int, List<Int>> {\n        val indicesByGroup = LinkedHashMap<Int, MutableList<Int>>()\n        for (i in 0 until dataLength) {\n            val group = groups(i)\n            if (!indicesByGroup.containsKey(group)) {\n                indicesByGroup[group] = ArrayList()\n            }\n            indicesByGroup[group]!!.add(i)\n        }\n\n        return indicesByGroup\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.data.DataProcessing.findOptionalVariable\n\nclass GroupingContext(\n    private val myData: DataFrame,\n    bindings: List<VarBinding>,\n    groupingVarName: String?,\n    pathIdVarName: String?,\n    private val myExpectMultiple: Boolean\n) {\n\n    private val myBindings: List<VarBinding> = ArrayList(bindings)\n    internal val optionalGroupingVar: Variable? = findOptionalVariable(myData, groupingVarName)\n    private val pathIdVar: Variable? = findOptionalVariable(myData, pathIdVarName)\n\n    private var myGroupSizeList: List<Int>? = null\n    private var myGroupMapper: ((Int) -> Int)? = null\n\n    //myGroupMapper = DataProcessing.computeGroups(myData, myBindings, myOptionalGroupingVar, myExpectMultiple);\n    val groupMapper: (Int) -> Int\n        get() = { index ->\n            if (myGroupMapper == null) {\n                myGroupMapper = computeGroups()\n            }\n            myGroupMapper!!(index)\n        }\n\n    private fun computeGroups(): (Int) -> Int {\n        if (myData.has(Stats.GROUP)) {\n            val list = myData.getNumeric(Stats.GROUP)\n            return GroupUtil.wrap(list)\n        } else if (myGroupSizeList != null) {\n            if (myGroupSizeList!!.size == myData.rowCount()) {\n                return GroupUtil.SINGLE_GROUP\n            } else {\n                val groupByPointIndex =\n                    toIndexMap(myGroupSizeList!!)\n                return GroupUtil.wrap(groupByPointIndex)\n            }\n        } else if (myExpectMultiple) {\n            return DataProcessing.computeGroups(\n                myData,\n                myBindings,\n                optionalGroupingVar,\n                pathIdVar\n            )\n        }\n        return GroupUtil.SINGLE_GROUP\n    }\n\n    companion object {\n        internal fun withOrderedGroups(data: DataFrame, groupSizeList: List<Int>): GroupingContext {\n            val groupingContext = GroupingContext(data, emptyList(), null, null, false)\n            groupingContext.myGroupSizeList = ArrayList(groupSizeList)\n            return groupingContext\n        }\n\n        private fun toIndexMap(groupSizeList: List<Int>): Map<Int, Int> {\n            val result = HashMap<Int, Int>()\n            var currentGroup = 0\n            var currentGroupIndexOffset = 0\n            for (groupSize in groupSizeList) {\n                for (i in 0 until groupSize) {\n                    result[currentGroupIndexOffset + i] = currentGroup\n                }\n                currentGroup++\n                currentGroupIndexOffset += groupSize\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil\n\nobject OrderOptionUtil {\n    class OrderOption internal constructor(\n        val variableName: String,\n        val byVariable: String?,\n        private val orderDir: Int?\n    ) {\n        fun getOrderDir(): Int = orderDir ?: -1 // descending by default\n\n        companion object {\n            fun create(\n                variableName: String,\n                orderBy: String?,\n                order: Any?\n            ): OrderOption? {\n                if (orderBy == null && order == null) {\n                    return null\n                }\n                require(order == null || (order is Number && order.toInt() in listOf(-1, 1))) {\n                    \"Unsupported `order` value: $order. Use 1 (ascending) or -1 (descending).\"\n                }\n\n                return OrderOption(variableName, orderBy, (order as? Number)?.toInt())\n            }\n\n            fun OrderOption.mergeWith(other: OrderOption): OrderOption {\n                require(variableName == other.variableName) {\n                    \"Can't merge order options for different variables: '$variableName' and '${other.variableName}'\"\n                }\n                require(byVariable == null || other.byVariable == null || other.byVariable == byVariable) {\n                    \"Multiple ordering options for the variable '$variableName' with different non-empty 'order_by' fields: '$byVariable' and '${other.byVariable}'\"\n                }\n                require(orderDir == null || other.orderDir == null || other.orderDir == orderDir) {\n                    \"Multiple ordering options for the variable '$variableName' with different order direction: '$orderDir' and '${other.orderDir}'\"\n                }\n                return OrderOption(\n                    variableName,\n                    byVariable ?: other.byVariable,\n                    orderDir ?: other.orderDir\n                )\n            }\n        }\n    }\n\n    fun createOrderSpec(\n        variables: Set<DataFrame.Variable>,\n        varBindings: List<VarBinding>,\n        orderOption: OrderOption,\n        aggregateOperation: ((List<Double?>) -> Double?)?\n    ): DataFrame.OrderSpec {\n        fun getVariableByName(varName: String): DataFrame.Variable {\n            return variables.find { it.name == varName }\n                ?: error(\"Undefined variable '$varName' in order options. Full variable list: ${variables.map { \"'${it.name}'\" }}\")\n        }\n\n        val variable =\n            if (varBindings.find { it.variable.name == orderOption.variableName && it.aes == Aes.X } != null &&\n                SamplingUtil.xVar(variables) != null\n            ) {\n                // Apply ordering to the X variable which is used for sampling\n                SamplingUtil.xVar(variables)!!\n            } else {\n                getVariableByName(orderOption.variableName)\n            }\n\n        return DataFrame.OrderSpec(\n            variable,\n            orderOption.byVariable?.let(::getVariableByName) ?: getVariableByName(orderOption.variableName),\n            orderOption.getOrderDir(),\n            aggregateOperation.takeIf {\n                // Use the aggregation for ordering by the specified 'order_by' variable\n                orderOption.byVariable != null && orderOption.byVariable != orderOption.variableName\n            }\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.event\n\nimport jetbrains.datalore.base.event.MouseEvent\nimport jetbrains.datalore.base.event.MouseEventSource\nimport jetbrains.datalore.base.event.MouseEventSpec\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\n\nclass MouseEventPeer : MouseEventSource {\n    private val myEventHandlers = HashMap<MouseEventSpec, Listeners<EventHandler<MouseEvent>>>()\n    private val myEventSources = ArrayList<MouseEventSource>()\n    private val mySourceRegistrations = HashMap<MouseEventSpec, CompositeRegistration>()\n\n    override fun addEventHandler(eventSpec: MouseEventSpec, eventHandler: EventHandler<MouseEvent>): Registration {\n        if (!myEventHandlers.containsKey(eventSpec)) {\n            myEventHandlers[eventSpec] = Listeners()\n            onAddSpec(eventSpec)\n        }\n\n        val addReg = myEventHandlers[eventSpec]?.add(eventHandler)\n        return object : Registration() {\n            override fun doRemove() {\n                addReg?.remove()\n                if (myEventHandlers[eventSpec]!!.isEmpty) {\n                    myEventHandlers.remove(eventSpec)\n                    onRemoveSpec(eventSpec)\n                }\n            }\n        }\n    }\n\n    fun dispatch(eventSpec: MouseEventSpec, mouseEvent: MouseEvent) {\n        if (myEventHandlers.containsKey(eventSpec)) {\n            myEventHandlers[eventSpec]?.fire(object : ListenerCaller<EventHandler<MouseEvent>> {\n                override fun call(l: EventHandler<MouseEvent>) {\n                    l.onEvent(mouseEvent)\n                }\n            })\n        }\n    }\n\n    fun addEventSource(eventSource: MouseEventSource) {\n        myEventHandlers.keys.forEach { eventSpec -> startHandleSpecInSource(eventSource, eventSpec) }\n        myEventSources.add(eventSource)\n    }\n\n    private fun onAddSpec(eventSpec: MouseEventSpec) {\n        myEventSources.forEach { eventSource -> startHandleSpecInSource(eventSource, eventSpec) }\n    }\n\n    private fun startHandleSpecInSource(eventSource: MouseEventSource, eventSpec: MouseEventSpec) {\n        val registration = eventSource.addEventHandler(eventSpec, object : EventHandler<MouseEvent> {\n            override fun onEvent(event: MouseEvent) {\n                dispatch(eventSpec, event)\n            }\n        })\n\n        if (!mySourceRegistrations.containsKey(eventSpec)) {\n            mySourceRegistrations[eventSpec] = CompositeRegistration()\n        }\n        mySourceRegistrations[eventSpec]?.add(registration)\n    }\n\n    private fun onRemoveSpec(eventSpec: MouseEventSpec) {\n        if (mySourceRegistrations.containsKey(eventSpec)) {\n            mySourceRegistrations.remove(eventSpec)?.dispose()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventSource\nimport jetbrains.datalore.base.observable.event.EventSources\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.PropertyBinding.bindOneWay\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor.*\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor.*\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgUtils.transformTranslate\n\nclass AxisComponent(length: Double, orientation: Orientation) : SvgComponent() {\n\n    val breaks: Property<List<Double>?> = ValueProperty(null)\n    val labels: Property<List<String>?> = ValueProperty(null)\n    // layout\n    val tickLabelRotationDegree: Property<Double> = ValueProperty(0.0)\n    val tickLabelHorizontalAnchor: Property<TextLabel.HorizontalAnchor>\n    // todo: minorBreaks\n    val tickLabelVerticalAnchor: Property<TextLabel.VerticalAnchor>\n    val tickLabelSmallFont: Property<Boolean> = ValueProperty(false)\n    val tickLabelOffsets: Property<List<DoubleVector>?> = ValueProperty(null)  // optional\n    val gridLineColor: Property<Color> = ValueProperty(Color.LIGHT_GRAY)\n    val lineWidth: Property<Double> = ValueProperty(1.0)\n    val gridLineWidth: Property<Double> = ValueProperty(1.0)\n    val gridLineLength: Property<Double> = ValueProperty(0.0)\n    val tickMarkWidth: Property<Double> = ValueProperty(1.0)\n    val tickMarkLength: Property<Double> = ValueProperty(6.0)\n    val tickMarkPadding: Property<Double> = ValueProperty(3.0)\n    private val length = ValueProperty<Double?>(null)\n    private val orientation = ValueProperty<Orientation?>(null)\n    // theme\n    private val myTickMarksEnabled = ValueProperty(true)\n    private val myTickLabelsEnabled = ValueProperty(true)\n    private val myAxisLineEnabled = ValueProperty(true)\n    private val lineColor = ValueProperty(Color.BLACK)\n    private val tickColor = ValueProperty(Color.BLACK)\n\n    private fun defTickLabelHorizontalAnchor(orientation: Orientation): TextLabel.HorizontalAnchor {\n        return when (orientation) {\n            Orientation.LEFT -> RIGHT\n            Orientation.RIGHT -> LEFT\n            Orientation.TOP, Orientation.BOTTOM -> MIDDLE\n        }\n    }\n\n    private fun defTickLabelVerticalAnchor(orientation: Orientation): TextLabel.VerticalAnchor {\n        when (orientation) {\n            Orientation.LEFT, Orientation.RIGHT -> return CENTER\n            Orientation.TOP -> return BOTTOM\n            Orientation.BOTTOM -> return TOP\n            else -> throw RuntimeException(\"Unexpected orientation:$orientation\")\n        }\n    }\n\n    init {\n        this.length.set(length)\n        this.orientation.set(orientation)\n\n        tickLabelHorizontalAnchor = ValueProperty(defTickLabelHorizontalAnchor(orientation))\n        tickLabelVerticalAnchor = ValueProperty(defTickLabelVerticalAnchor(orientation))\n\n        @Suppress(\"UNCHECKED_CAST\")\n        fun <T> EventSource<in PropertyChangeEvent<T>>.asPropertyChangedEventSource() = this as EventSource<PropertyChangeEvent<*>>\n\n        EventSources.composite(\n            this.length.asPropertyChangedEventSource(),\n            this.orientation.asPropertyChangedEventSource(),\n            breaks.asPropertyChangedEventSource(),\n            labels.asPropertyChangedEventSource(),\n            gridLineLength.asPropertyChangedEventSource(),\n            tickLabelOffsets.asPropertyChangedEventSource(),\n            tickLabelHorizontalAnchor.asPropertyChangedEventSource(),\n            tickLabelVerticalAnchor.asPropertyChangedEventSource(),\n            tickLabelRotationDegree.asPropertyChangedEventSource(),\n            tickLabelSmallFont.asPropertyChangedEventSource()\n        ).addHandler(rebuildHandler())\n    }\n\n    override fun buildComponent() {\n        buildAxis()\n    }\n\n    private fun buildAxis() {\n        val rootElement = rootGroup\n        rootElement.addClass(Style.AXIS)\n        if (tickLabelSmallFont.get()) {\n            rootElement.addClass(Style.SMALL_TICK_FONT)\n        }\n\n        val l = length.get()!!\n        val x1: Double\n        val y1: Double\n        val x2: Double\n        val y2: Double\n        val start: Double\n        val end: Double\n        when (orientation.get()) {\n            Orientation.LEFT, Orientation.RIGHT -> {\n                x2 = 0.0\n                x1 = x2\n                start = 0.0\n                y1 = start\n                end = l\n                y2 = end\n            }\n            Orientation.TOP, Orientation.BOTTOM -> {\n                start = 0.0\n                x1 = start\n                end = l\n                x2 = end\n                y2 = 0.0\n                y1 = y2\n            }\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n\n        var axisLine: SvgLineElement? = null\n        if (axisLineEnabled().get()) {\n            axisLine = SvgLineElement(x1, y1, x2, y2)\n            reg(bindOneWay(lineWidth, axisLine.strokeWidth()))\n            reg(bindOneWay(lineColor, axisLine.strokeColor()))\n        }\n\n        // do not draw grid lines then it's too close to axis ends.\n        val gridLineMinPos = start + 3\n        val gridLineMaxPos = end - 3\n\n        if (breaksEnabled()) {\n            // add ticks before axis line\n            val breaks = this.breaks.get()\n            if (!(breaks == null || breaks.isEmpty())) {\n\n                var labels: List<String>? = this.labels.get()\n                if (labels == null || labels.isEmpty()) {\n                    labels = ArrayList()\n                    for (i in breaks.indices) {\n                        labels.add(\"\")\n                    }\n                }\n\n                var i = 0\n                for (br in breaks) {\n                    val addGridLine = br >= gridLineMinPos && br <= gridLineMaxPos\n                    val label = labels[i % labels.size]\n                    val labelOffset = tickLabelOffset(i)\n                    i++\n                    val group = buildTick(\n                            label,\n                            labelOffset,\n                            if (addGridLine) gridLineLength.get() else 0.0)\n\n                    when (orientation.get()) {\n                        Orientation.LEFT, Orientation.RIGHT -> transformTranslate(group, 0.0, br)\n                        Orientation.TOP, Orientation.BOTTOM -> transformTranslate(group, br, 0.0)\n                        else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n                    }\n\n                    rootElement.children().add(group)\n                }\n            }\n        }\n\n        // axis line\n        if (axisLine != null) {\n            rootElement.children().add(axisLine)\n        }\n    }\n\n    private fun buildTick(label: String, labelOffset: DoubleVector, gridLineLength: Double): SvgGElement {\n\n        var tickMark: SvgLineElement? = null\n        if (tickMarksEnabled().get()) {\n            tickMark = SvgLineElement()\n            reg(bindOneWay(tickMarkWidth, tickMark.strokeWidth()))\n            reg(bindOneWay(tickColor, tickMark.strokeColor()))\n        }\n\n        var tickLabel: TextLabel? = null\n        if (tickLabelsEnabled().get()) {\n            tickLabel = TextLabel(label)\n            reg(bindOneWay(tickColor, tickLabel.textColor()))\n        }\n\n        var gridLine: SvgLineElement? = null // optional;\n        if (gridLineLength > 0) {\n            gridLine = SvgLineElement()\n            reg(bindOneWay(gridLineColor, gridLine.strokeColor()))\n            reg(bindOneWay(gridLineWidth, gridLine.strokeWidth()))\n        }\n\n        val markLength = tickMarkLength.get()\n        when (orientation.get()) {\n            Orientation.LEFT -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(-markLength)\n                    tickMark.y2().set(0.0)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(gridLineLength)\n                    gridLine.y2().set(0.0)\n                }\n            }\n            Orientation.RIGHT -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(markLength)\n                    tickMark.y2().set(0.0)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(-gridLineLength)\n                    gridLine.y2().set(0.0)\n                }\n            }\n            Orientation.TOP -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(0.0)\n                    tickMark.y2().set(-markLength)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(0.0)\n                    gridLine.y2().set(gridLineLength)\n                }\n            }\n            Orientation.BOTTOM -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(0.0)\n                    tickMark.y2().set(markLength)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(0.0)\n                    gridLine.y2().set(-gridLineLength)\n                }\n            }\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n\n        val g = SvgGElement()\n        if (gridLine != null) {\n            g.children().add(gridLine)\n        }\n\n        if (tickMark != null) {\n            g.children().add(tickMark)\n        }\n\n        if (tickLabel != null) {\n            tickLabel.moveTo(labelOffset.x, labelOffset.y)\n            tickLabel.setHorizontalAnchor(tickLabelHorizontalAnchor.get())\n            tickLabel.setVerticalAnchor(tickLabelVerticalAnchor.get())\n            tickLabel.rotate(tickLabelRotationDegree.get())\n            g.children().add(tickLabel.rootGroup)\n        }\n\n        g.addClass(Style.TICK)\n        return g\n    }\n\n    private fun tickMarkLength(): Double {\n        return if (myTickMarksEnabled.get()) {\n            tickMarkLength.get()\n        } else {\n            0.0\n        }\n    }\n\n    private fun tickLabelDistance(): Double {\n        return tickMarkLength() + tickMarkPadding.get()\n    }\n\n    private fun tickLabelBaseOffset(): DoubleVector {\n        val distance = tickLabelDistance()\n        return when (orientation.get()) {\n            Orientation.LEFT -> DoubleVector(-distance, 0.0)\n            Orientation.RIGHT -> DoubleVector(distance, 0.0)\n            Orientation.TOP -> DoubleVector(0.0, -distance)\n            Orientation.BOTTOM -> DoubleVector(0.0, distance)\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n    }\n\n    private fun tickLabelOffset(tickIndex: Int): DoubleVector {\n        val additionalOffsets = tickLabelOffsets.get()\n        val additionalOffset = if (additionalOffsets != null) additionalOffsets[tickIndex] else DoubleVector.ZERO\n        return tickLabelBaseOffset().add(additionalOffset)\n    }\n\n    private fun breaksEnabled(): Boolean {\n        return myTickMarksEnabled.get() || myTickLabelsEnabled.get()\n    }\n\n    fun tickMarksEnabled(): Property<Boolean> {\n        return myTickMarksEnabled\n    }\n\n    fun tickLabelsEnabled(): Property<Boolean> {\n        return myTickLabelsEnabled\n    }\n\n    fun axisLineEnabled(): Property<Boolean> {\n        return myAxisLineEnabled\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport kotlin.math.max\n\nclass ColorBarComponent(\n    override val spec: ColorBarComponentSpec\n) : LegendBox() {\n\n    override fun appendGuideContent(contentRoot: SvgNode): DoubleVector {\n        val layout = spec.layout\n\n        val guideBarGroup = SvgGElement()\n\n        // bar\n        val barBounds = layout.barBounds\n        val horizontal = layout.isHorizontal\n        addColorBar(\n            guideBarGroup,\n            spec.domain, spec.scale, spec.binCount, barBounds,\n            layout.barLengthExpand,\n            horizontal, spec.reverse\n        )\n\n        // Ticks and labels\n        val barThickness = when {\n            horizontal -> barBounds.height\n            else -> barBounds.width\n        }\n        val tickLength = barThickness / 5\n\n        val breakInfos = layout.breakInfos.iterator()\n        for (br in spec.breaks) {\n            val brInfo = breakInfos.next()\n\n            val tickLocation = brInfo.tickLocation\n            val tickMarkPoints = ArrayList<DoubleVector>()\n            if (horizontal) {\n                val tickX = barBounds.left + tickLocation\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.top))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.top + tickLength))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.bottom - tickLength))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.bottom))\n            } else {\n                val tickY = barBounds.top + tickLocation\n                tickMarkPoints.add(DoubleVector(barBounds.left, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.left + tickLength, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.right - tickLength, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.right, tickY))\n            }\n\n            addTickMark(guideBarGroup, tickMarkPoints[0], tickMarkPoints[1])\n            addTickMark(guideBarGroup, tickMarkPoints[2], tickMarkPoints[3])\n\n            val label = TextLabel(br.label)\n            label.setHorizontalAnchor(brInfo.labelHorizontalAnchor)\n            label.setVerticalAnchor(brInfo.labelVerticalAnchor)\n            label.moveTo(brInfo.labelLocation.x, brInfo.labelLocation.y + barBounds.top)\n            guideBarGroup.children().add(label.rootGroup)\n        }\n\n        // add white frame\n        guideBarGroup.children().add(\n            createBorder(\n                barBounds,\n                spec.theme.backgroundFill(),\n                1.0\n            )\n        )\n\n        if (debug) {\n            // frame bar and labels\n            val graphBounds = DoubleRectangle(DoubleVector.ZERO, layout.graphSize)\n            guideBarGroup.children().add(\n                createBorder(\n                    graphBounds,\n                    Color.DARK_BLUE,\n                    1.0\n                )\n            )\n        }\n\n        contentRoot.children().add(guideBarGroup)\n        return layout.size\n    }\n\n    private fun addColorBar(\n        g: SvgGElement,\n        domain: ClosedRange<Double>,\n        scale: Scale<Color>,\n        numBins: Int,\n        barBounds: DoubleRectangle,\n        barLengthExpand: Double,\n        horizontal: Boolean,\n        reverse: Boolean\n    ) {\n\n        val domainSpan = SeriesUtil.span(domain)\n        val stepCount = max(2, numBins)\n        val step = domainSpan / stepCount\n        val v = domain.lowerEnd + step / 2\n        val domainValues = ArrayList<Double>()\n        for (i in 0 until stepCount) {\n            domainValues.add(v + step * i)\n        }\n        if (reverse) {\n            domainValues.reverse()\n        }\n\n        val colors = ScaleUtil.map(domainValues, scale)\n        val barLength = when {\n            horizontal -> barBounds.width\n            else -> barBounds.height\n        }\n        val effectiveBarLength = barLength - barLengthExpand * 2\n        val segmentStep = effectiveBarLength / stepCount\n\n        var segmentLeft = barBounds.left\n        val segmentRight = barBounds.right\n        val segmentBottom = barBounds.bottom\n        var segmentTop = barBounds.top\n\n        for ((i, color) in colors.withIndex()) {\n            val r = SvgRectElement(\n                segmentLeft,\n                segmentTop,\n                segmentRight - segmentLeft,\n                segmentBottom - segmentTop\n            )\n            r.strokeWidth().set(0.0)\n            r.fillColor().set(color)\n            g.children().add(r)\n\n            if (horizontal) {\n                segmentLeft += segmentStep\n            } else {\n                segmentTop += segmentStep\n            }\n            if (i == 0) {\n                // first segment is a bit longer.\n                if (horizontal) {\n                    segmentLeft += barLengthExpand\n                } else {\n                    segmentTop += barLengthExpand\n                }\n            }\n        }\n    }\n\n    private fun addTickMark(g: SvgGElement, p0: DoubleVector, p1: DoubleVector) {\n        val line = SvgLineElement(p0.x, p0.y, p1.x, p1.y)\n        line.strokeWidth().set(1.0)\n        line.strokeColor().set(spec.theme.backgroundFill());\n        g.children().add(line)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.scale.GuideBreak\n\nabstract class ColorBarComponentLayout(\n    title: String,\n    domain: ClosedRange<Double>,\n    breaks: List<GuideBreak<Double>>,\n    protected val guideBarSize: DoubleVector,\n    legendDirection: LegendDirection,\n    reverse: Boolean\n) : LegendBoxLayout(\n    title,\n    legendDirection\n) {\n\n    var barBounds: DoubleRectangle private set\n\n    // num of pix added on each end of the bar (to avoid terminal ticks to lay on the border)\n    val barLengthExpand: Double = 2.0\n\n    protected abstract val guideBarLength: Double\n    internal val breakInfos: List<BreakInfo>\n\n    init {\n        val guideBarLength = guideBarLength\n        val targetRange = ClosedRange(0.0 + barLengthExpand, guideBarLength - barLengthExpand)\n        val mapper = Mappers.linear(domain, targetRange, reverse)\n        breakInfos = breaks.map {\n            val tickLocation = mapper(it.domainValue)\n            createBreakInfo(tickLocation)\n        }\n        barBounds = DoubleRectangle(DoubleVector.ZERO, guideBarSize)\n    }\n\n    internal abstract fun createBreakInfo(tickLocation: Double): BreakInfo\n\n    internal class BreakInfo(\n        val tickLocation: Double, val labelLocation: DoubleVector,\n        val labelHorizontalAnchor: TextLabel.HorizontalAnchor, val labelVerticalAnchor: TextLabel.VerticalAnchor\n    )\n\n    private class HorizontalLayout(\n        title: String,\n        domain: ClosedRange<Double>,\n        breaks: List<GuideBreak<Double>>,\n        barSize: DoubleVector,\n        reverse: Boolean\n    ) : ColorBarComponentLayout(\n        title, domain, breaks, barSize,\n        LegendDirection.HORIZONTAL,\n        reverse\n    ) {\n\n        override val graphSize: DoubleVector\n        private val labelDistance: Double get() = LABEL_SPEC.height() / 3\n        override val guideBarLength: Double get() = guideBarSize.x\n\n        init {\n            // Bar + labels bounds\n            graphSize = DoubleVector(guideBarSize.x, guideBarSize.y + labelDistance + LABEL_SPEC.height())\n        }\n\n        override fun createBreakInfo(tickLocation: Double): BreakInfo {\n            val labelLocation = DoubleVector(tickLocation, guideBarSize.y + labelDistance)\n            return BreakInfo(\n                tickLocation,\n                labelLocation,\n                TextLabel.HorizontalAnchor.MIDDLE,\n                TextLabel.VerticalAnchor.TOP\n            )\n        }\n    }\n\n    private class VerticalLayout(\n        title: String,\n        domain: ClosedRange<Double>,\n        breaks: List<GuideBreak<Double>>,\n        barSize: DoubleVector,\n        reverse: Boolean\n    ) : ColorBarComponentLayout(\n        title, domain, breaks, barSize,\n        LegendDirection.VERTICAL,\n        reverse\n    ) {\n\n        override val graphSize: DoubleVector\n        private val labelDistance: Double get() = LABEL_SPEC.width(1) / 2\n        override val guideBarLength: Double get() = guideBarSize.y\n\n        init {\n            check(breaks.isNotEmpty()) { \"Colorbar VerticalLayout received empty breaks list.\" }\n            val maxLabelWidth: Double = breaks.map { it.label.length }\n                .maxOf { LABEL_SPEC.width(it) }\n\n            // Bar + labels bounds\n            graphSize = DoubleVector(guideBarSize.x + labelDistance + maxLabelWidth, guideBarSize.y)\n        }\n\n        override fun createBreakInfo(tickLocation: Double): BreakInfo {\n            val labelLocation = DoubleVector(guideBarSize.x + labelDistance, tickLocation)\n            return BreakInfo(\n                tickLocation,\n                labelLocation,\n                TextLabel.HorizontalAnchor.LEFT,\n                TextLabel.VerticalAnchor.CENTER\n            )\n        }\n    }\n\n    companion object {\n        fun horizontal(\n            title: String,\n            domain: ClosedRange<Double>,\n            breaks: List<GuideBreak<Double>>,\n            barSize: DoubleVector,\n            reverse: Boolean\n        ): ColorBarComponentLayout {\n            return HorizontalLayout(\n                title,\n                domain,\n                breaks,\n                barSize,\n                reverse\n            )\n        }\n\n        fun vertical(\n            title: String,\n            domain: ClosedRange<Double>,\n            breaks: List<GuideBreak<Double>>,\n            barSize: DoubleVector,\n            reverse: Boolean\n        ): ColorBarComponentLayout {\n            return VerticalLayout(\n                title,\n                domain,\n                breaks,\n                barSize,\n                reverse\n            )\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.comparisons\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.js.*\n\n/**\n * Returns the greater of two values.\n * \n * If values are equal, returns the first one.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, b: T): T {\n    return if (a >= b) a else b\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Byte, b: Byte): Byte {\n    return maxOf(a.toInt(), b.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Short, b: Short): Short {\n    return maxOf(a.toInt(), b.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Int, b: Int): Int {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun maxOf(a: Long, b: Long): Long {\n    return if (a >= b) a else b\n}\n\n/**\n * Returns the greater of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Float, b: Float): Float {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Double, b: Double): Double {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of three values.\n * \n * If there are multiple equal maximal values, returns the first of them.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, b: T, c: T): T {\n    return maxOf(a, maxOf(b, c))\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Byte, b: Byte, c: Byte): Byte {\n    return JsMath.max(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Short, b: Short, c: Short): Short {\n    return JsMath.max(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Int, b: Int, c: Int): Int {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Long, b: Long, c: Long): Long {\n    return maxOf(a, maxOf(b, c))\n}\n\n/**\n * Returns the greater of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Float, b: Float, c: Float): Float {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Double, b: Double, c: Double): Double {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If there are multiple equal maximal values, returns the first of them.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, vararg other: T): T {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Byte, vararg other: Byte): Byte {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Short, vararg other: Short): Short {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Int, vararg other: Int): Int {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Long, vararg other: Long): Long {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Float, vararg other: Float): Float {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Double, vararg other: Double): Double {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If values are equal, returns the first one.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> minOf(a: T, b: T): T {\n    return if (a <= b) a else b\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Byte, b: Byte): Byte {\n    return minOf(a.toInt(), b.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Short, b: Short): Short {\n    return minOf(a.toInt(), b.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Int, b: Int): Int {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun minOf(a: Long, b: Long): Long {\n    return if (a <= b) a else b\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Float, b: Float): Float {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Double, b: Double): Double {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If there are multiple equal minimal values, returns the first of them.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> minOf(a: T, b: T, c: T): T {\n    return minOf(a, minOf(b, c))\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Byte, b: Byte, c: Byte): Byte {\n    return JsMath.min(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Short, b: Short, c: Short): Short {\n    return JsMath.min(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Int, b: Int, c: Int): Int {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Long, b: Long, c: Long): Long {\n    return minOf(a, minOf(b, c))\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Float, b: Float, c: Float): Float {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Double, b: Double, c: Double): Double {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If there are multiple equal minimal values, returns the first of them.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun <T : Comparable<T>> minOf(a: T, vararg other: T): T {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Byte, vararg other: Byte): Byte {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Short, vararg other: Short): Short {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Int, vararg other: Int): Int {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Long, vararg other: Long): Long {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Float, vararg other: Float): Float {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Double, vararg other: Double): Double {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.scale.GuideBreak\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass ColorBarComponentSpec(\n    title: String,\n    val domain: ClosedRange<Double>,\n    val breaks: List<GuideBreak<Double>>,\n    val scale: Scale<Color>,\n    val binCount: Int,\n    theme: LegendTheme,\n    override val layout: ColorBarComponentLayout,\n    reverse: Boolean\n) : LegendBoxSpec(title, theme, reverse) {\n\n    companion object {\n        const val DEF_NUM_BIN = 20\n\n        private const val DEF_BAR_THICKNESS = 1.0  // in 'key-size' multiples\n        private const val DEF_BAR_LENGTH = 5.0   // in 'key-size' multiples\n\n        internal fun barAbsoluteSize(horizontal: Boolean, theme: LegendTheme): DoubleVector {\n            return when {\n                horizontal -> DoubleVector(\n                    DEF_BAR_LENGTH * theme.keySize(),\n                    DEF_BAR_THICKNESS * theme.keySize()\n                )\n                else -> DoubleVector(\n                    DEF_BAR_THICKNESS * theme.keySize(),\n                    DEF_BAR_LENGTH * theme.keySize()\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * theme legend.box\n * arrangement of multiple legends (\"horizontal\" or \"vertical\")\n */\nenum class LegendArrangement {\n    HORIZONTAL,\n    VERTICAL\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nabstract class LegendBox : SvgComponent() {\n\n    var debug: Boolean = false\n    abstract val spec: LegendBoxSpec\n\n    private val title: String\n        get() = spec.title\n\n    val size: DoubleVector\n        get() = spec.size\n\n    private fun hasTitle(): Boolean {\n        return spec.hasTitle()\n    }\n\n    override fun buildComponent() {\n        addClassName(Style.LEGEND)\n\n        val outerBounds = DoubleRectangle(DoubleVector.ZERO, spec.size)\n        addRectangle(spec.innerBounds, spec.theme.backgroundFill())\n//        addBorder(spec.innerBounds, OUTLINE_COLOR, 1.0)\n\n        val innerGroup = SvgGElement()\n        innerGroup.transform().set(buildTransform(spec.contentOrigin, 0.0))\n\n        val l = spec.layout\n        if (hasTitle()) {\n            val label = createTitleLabel(\n                l.titleLocation,\n                l.titleHorizontalAnchor,\n                l.titleVerticalAnchor\n            )\n            innerGroup.children().add(label.rootGroup)\n        }\n\n        val graphGroup = SvgGElement()\n        graphGroup.transform().set(buildTransform(l.graphOrigin, 0.0))\n        appendGuideContent(graphGroup)\n        innerGroup.children().add(graphGroup)\n\n        if (debug) {\n            run {\n                // outer bounds\n                addBorder(outerBounds, Color.CYAN, 1.0)\n            }\n            run {\n                // inner bounds\n                val rect = SvgRectElement(spec.innerBounds)\n                rect.fillColor().set(Color.BLACK)\n                rect.strokeWidth().set(0.0)\n                rect.fillOpacity().set(0.1)\n                add(rect)\n            }\n            run {\n                // content bounds\n                addBorder(spec.contentBounds, Color.DARK_MAGENTA, 1.0)\n            }\n            run {\n                // title bounds\n                addBorder(l.titleBounds.add(spec.contentOrigin), Color.MAGENTA, 1.0)\n            }\n        }\n\n        add(innerGroup)\n    }\n\n    protected fun addBorder(bounds: DoubleRectangle, strokeColor: Color, strokeWidth: Double) {\n        add(\n            createBorder(\n                bounds,\n                strokeColor,\n                strokeWidth\n            )\n        )\n    }\n\n    protected fun addRectangle(bounds: DoubleRectangle, fillColor: Color) {\n        add(\n            createRectangle(\n                bounds,\n                fillColor\n            )\n        )\n    }\n\n    protected abstract fun appendGuideContent(contentRoot: SvgNode): DoubleVector\n\n    private fun createTitleLabel(\n        origin: DoubleVector,\n        horizontalAnchor: TextLabel.HorizontalAnchor,\n        verticalAnchor: TextLabel.VerticalAnchor\n    ): TextLabel {\n        val label = TextLabel(title)\n        label.addClassName(Style.LEGEND_TITLE)\n        label.setHorizontalAnchor(horizontalAnchor)\n        label.setVerticalAnchor(verticalAnchor)\n        label.moveTo(origin)\n        return label\n    }\n\n    companion object {\n        fun createBorder(bounds: DoubleRectangle, strokeColor: Color, strokeWidth: Double): SvgRectElement {\n            // ToDo: to util\n            val rect = SvgRectElement(bounds)\n            rect.strokeColor().set(strokeColor)\n            rect.strokeWidth().set(strokeWidth)\n            rect.fillOpacity().set(0.0)\n            return rect\n        }\n\n        protected fun createRectangle(bounds: DoubleRectangle, fillColor: Color): SvgRectElement {\n            // ToDo: to util\n            val rect = SvgRectElement(bounds)\n            rect.fillColor().set(fillColor)\n            return rect\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\n\nabstract class LegendBoxLayout(\n    private val title: String,\n    legendDirection: LegendDirection\n) {\n\n    abstract val graphSize: DoubleVector\n    val isHorizontal = legendDirection === LegendDirection.HORIZONTAL\n    val titleHorizontalAnchor = TextLabel.HorizontalAnchor.LEFT\n    val titleVerticalAnchor = if (isHorizontal) {\n        TextLabel.VerticalAnchor.CENTER\n    } else {\n        TextLabel.VerticalAnchor.TOP\n    }\n\n    val titleBounds: DoubleRectangle\n        get() {\n            var origin = titleLocation\n            val size = titleSize(title)\n            if (isHorizontal) {\n                origin = DoubleVector(origin.x, origin.y - size.y / 2)\n            }\n            return DoubleRectangle(origin, size)\n        }\n\n    val graphOrigin: DoubleVector\n        get() = when {\n            isHorizontal ->\n                DoubleVector(titleSize(title).x, 0.0)\n            else ->\n                DoubleVector(0.0, titleSize(title).y)\n        }\n\n    val size: DoubleVector\n        get() {\n            val graphBounds = DoubleRectangle(graphOrigin, graphSize)\n            val titleAndContent = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n                .union(titleBounds)\n                .union(graphBounds)\n            return titleAndContent.dimension\n        }\n\n    val titleLocation: DoubleVector\n        get() = if (isHorizontal) {\n            val graphSize = graphSize\n            DoubleVector(0.0, graphSize.y / 2)\n        } else {\n            // make some distance from the contents\n            val y = -TITLE_SPEC.height() / 3\n            DoubleVector(0.0, y)\n        }\n\n    companion object {\n        private val TITLE_SPEC = PlotLabelSpec.LEGEND_TITLE\n        internal val LABEL_SPEC = PlotLabelSpec.LEGEND_ITEM\n\n        private fun titleSize(s: String): DoubleVector {\n            return when {\n                s.isBlank() -> DoubleVector.ZERO\n                else -> TITLE_SPEC.dimensions(s.length)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nabstract class LegendBoxSpec(\n    val title: String,\n    val theme: LegendTheme,\n    val reverse: Boolean\n) {\n\n    abstract val layout: LegendBoxLayout\n    val contentOrigin: DoubleVector\n\n    private val fullContentExtend: DoubleVector\n    private val innerOrigin: DoubleVector\n    private val innerContentExtend: DoubleVector\n\n    private val contentSize: DoubleVector\n        get() = layout.size\n\n    val size: DoubleVector\n        get() = contentSize.add(fullContentExtend)\n\n    val innerBounds: DoubleRectangle\n        get() = DoubleRectangle(innerOrigin, contentSize.add(innerContentExtend))\n\n    val contentBounds: DoubleRectangle\n        get() = DoubleRectangle(contentOrigin, contentSize)\n\n    init {\n        val contentExpand = theme.margin() + theme.padding()\n        contentOrigin = DoubleVector(contentExpand, contentExpand)\n        fullContentExtend = DoubleVector(contentExpand * 2, contentExpand * 2)\n\n        innerOrigin = DoubleVector(theme.margin(), theme.margin())\n        innerContentExtend = DoubleVector(theme.padding() * 2, theme.padding() * 2)\n    }\n\n    fun hasTitle(): Boolean {\n        return title.isNotBlank()\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\n\nclass LegendBreak(val label: String) {\n    private val myLayers = ArrayList<LegendBreakLayer>()\n\n    val minimumKeySize: DoubleVector\n        get() {\n            var minSize = DoubleVector.ZERO\n            for (layer in myLayers) {\n                val layerMinKeySize = layer.keyElementFactory.minimumKeySize(layer.dataPoint)\n                minSize = minSize.max(layerMinKeySize)\n            }\n            return minSize\n        }\n\n    val isEmpty: Boolean\n        get() = myLayers.isEmpty()\n\n    fun addLayer(dataPoint: DataPointAesthetics, keyElementFactory: LegendKeyElementFactory) {\n        myLayers.add(\n            LegendBreakLayer(\n                dataPoint,\n                keyElementFactory\n            )\n        )\n    }\n\n    fun createKeyElement(size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n\n        for (layer in myLayers) {\n            val keyElement = layer.keyElementFactory.createKeyElement(layer.dataPoint, size)\n            g.children().add(keyElement)\n        }\n\n        return g\n    }\n\n    private class LegendBreakLayer(\n        val dataPoint: DataPointAesthetics,\n        val keyElementFactory: LegendKeyElementFactory\n    )\n\n    companion object {\n        fun simple(\n            label: String,\n            dataPoint: DataPointAesthetics,\n            keyElementFactory: LegendKeyElementFactory\n        ): LegendBreak {\n            val br = LegendBreak(label)\n            br.addLayer(dataPoint, keyElementFactory)\n            return br\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.GroupComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.*\n\nclass LegendComponent(\n    override val spec: LegendComponentSpec\n) : LegendBox() {\n\n    override fun appendGuideContent(contentRoot: SvgNode): DoubleVector {\n        val layout = spec.layout\n\n        val keyLabelBoxes = layout.keyLabelBoxes.iterator()\n        val labelBoxes = layout.labelBoxes.iterator()\n        for (br in spec.breaks) {\n            val keyLabelBox = keyLabelBoxes.next()\n            val labelBox = labelBoxes.next()\n            val breakElement = createBreakElement(br, layout.keySize, keyLabelBox, labelBox)\n            contentRoot.children().add(breakElement)\n        }\n        return layout.size\n    }\n\n    private fun createBreakElement(\n        br: LegendBreak,\n        keySize: DoubleVector,\n        keyLabelBox: DoubleRectangle,\n        labelBox: DoubleRectangle\n    ): SvgElement {\n        val breakComponent = GroupComponent()\n\n        // key element\n        breakComponent.add(createKeyElement(br, keySize))\n\n        // add label at position as was layout\n        val label = TextLabel(br.label)\n        label.setHorizontalAnchor(TextLabel.HorizontalAnchor.LEFT)\n        label.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n        label.moveTo(labelBox.origin.add(DoubleVector(0.0, labelBox.height / 2)))\n        breakComponent.add(label)\n\n        breakComponent.moveTo(keyLabelBox.origin)\n        return breakComponent.rootGroup\n    }\n\n    private fun createKeyElement(legendBreak: LegendBreak, size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n\n        val innerSize = DoubleVector(size.x - 2, size.y - 2)\n\n        val backgroundFill = spec.theme.backgroundFill()\n\n        // common background\n        val backgroundRect = SvgRectElement(1.0, 1.0, innerSize.x, innerSize.y)\n        backgroundRect.strokeWidth().set(1.0)\n        backgroundRect.strokeColor().set(backgroundFill)\n        backgroundRect.fillColor().set(backgroundFill)\n\n        g.children().add(backgroundRect)\n\n        // key\n        val keyElement = legendBreak.createKeyElement(innerSize)\n        val keyElementTransform = buildTransform(DoubleVector(1.0, 1.0), 0.0)\n        keyElement.transform().set(keyElementTransform)\n\n        g.children().add(keyElement)\n\n        // white frame\n        val frame = SvgRectElement(0.0, 0.0, size.x, size.y)\n        frame.strokeWidth().set(1.0)\n        frame.strokeColor().set(backgroundFill)\n        frame.fill().set(SvgColors.NONE)\n\n        g.children().add(frame)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport kotlin.math.max\n\nabstract class LegendComponentLayout(\n    title: String,\n    protected val breaks: List<LegendBreak>,\n    val keySize: DoubleVector,\n    legendDirection: LegendDirection\n) : LegendBoxLayout(title, legendDirection) {\n\n    private var myContentSize: DoubleVector? = null\n    private val myKeyLabelBoxes = ArrayList<DoubleRectangle>()\n    private val myLabelBoxes = ArrayList<DoubleRectangle>()\n\n    var isFillByRow = false\n    var rowCount = 0\n        set(rowCount) {\n            check(rowCount > 0) { \"Row count must be greater than 0, was $rowCount\" }\n            field = rowCount\n        }\n    var colCount = 0\n        set(colCount) {\n            check(colCount > 0) { \"Col count must be greater than 0, was $colCount\" }\n            field = colCount\n        }\n\n    override val graphSize: DoubleVector\n        get() {\n            ensureInited()\n            return myContentSize!!\n        }\n\n    val keyLabelBoxes: List<DoubleRectangle>\n        get() {\n            ensureInited()\n            return myKeyLabelBoxes\n        }\n\n    val labelBoxes: List<DoubleRectangle>\n        get() {\n            ensureInited()\n            return myLabelBoxes\n        }\n\n    private fun ensureInited() {\n        if (myContentSize == null) {\n            doLayout()\n        }\n    }\n\n    private fun doLayout() {\n        val labelHeight = LABEL_SPEC.height()\n        val labelLeftMargin = LABEL_SPEC.width(1) / 2\n        val labelHOffset = keySize.x + labelLeftMargin\n        val labelVOffset = (keySize.y - labelHeight) / 2\n\n        val contentOrigin = DoubleVector.ZERO\n        var breakBoxBounds: DoubleRectangle? = null\n        for (i in breaks.indices) {\n            val labelSize = labelSize(i)\n            val breakBoxSize = DoubleVector(labelHOffset + labelSize.x, keySize.y)\n            breakBoxBounds = DoubleRectangle(\n                breakBoxBounds?.let { breakBoxOrigin(i, it) } ?: contentOrigin,\n                breakBoxSize\n            )\n\n            myKeyLabelBoxes.add(breakBoxBounds)\n            myLabelBoxes.add(\n                DoubleRectangle(\n                    labelHOffset, labelVOffset,\n                    labelSize.x, labelSize.y\n                )\n            )\n        }\n\n        myContentSize = GeometryUtil.union(DoubleRectangle(contentOrigin, DoubleVector.ZERO), myKeyLabelBoxes).dimension\n    }\n\n    protected abstract fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector\n\n    protected abstract fun labelSize(index: Int): DoubleVector\n\n    private class MyHorizontal internal constructor(title: String, breaks: List<LegendBreak>, keySize: DoubleVector) :\n        LegendComponentLayout(\n            title, breaks, keySize,\n            LegendDirection.HORIZONTAL\n        ) {\n        init {\n            colCount = breaks.size\n            rowCount = 1\n        }\n\n        override fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector {\n            return DoubleVector(prevBreakBoxBounds.right, 0.0)\n        }\n\n        override fun labelSize(index: Int): DoubleVector {\n            val label = breaks[index].label\n            return DoubleVector(LABEL_SPEC.width(label.length), LABEL_SPEC.height())\n        }\n    }\n\n    private class MyHorizontalMultiRow internal constructor(\n        title: String,\n        breaks: List<LegendBreak>,\n        keySize: DoubleVector\n    ) : MyMultiRow(\n        title, breaks, keySize,\n        LegendDirection.HORIZONTAL\n    ) {\n        init {\n            colCount = breaks.size\n            rowCount = 1\n        }\n    }\n\n    private class MyVertical internal constructor(title: String, breaks: List<LegendBreak>, keySize: DoubleVector) :\n        MyMultiRow(\n            title, breaks, keySize,\n            LegendDirection.VERTICAL\n        ) {\n        init {\n            colCount = 1\n            rowCount = breaks.size\n        }\n    }\n\n    private abstract class MyMultiRow internal constructor(\n        title: String,\n        breaks: List<LegendBreak>,\n        keySize: DoubleVector,\n        legendDirection: LegendDirection\n    ) : LegendComponentLayout(title, breaks, keySize, legendDirection) {\n        private var myMaxLabelWidth = 0.0\n\n        init {\n            for (br in breaks) {\n                myMaxLabelWidth = max(myMaxLabelWidth, LABEL_SPEC.width(br.label.length))\n            }\n        }\n\n        override fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector {\n            if (isFillByRow) {\n                return if (index % colCount == 0) {\n                    DoubleVector(0.0, prevBreakBoxBounds.bottom)\n                } else DoubleVector(prevBreakBoxBounds.right, prevBreakBoxBounds.top)\n            }\n\n            // fill by column\n            return if (index % rowCount == 0) {\n                DoubleVector(prevBreakBoxBounds.right, 0.0)\n            } else DoubleVector(prevBreakBoxBounds.left, prevBreakBoxBounds.bottom)\n\n        }\n\n        override fun labelSize(index: Int): DoubleVector {\n            return DoubleVector(myMaxLabelWidth, LABEL_SPEC.height())\n        }\n    }\n\n    companion object {\n        fun horizontal(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyHorizontal(\n                title,\n                breaks,\n                keySize\n            )\n        }\n\n        fun horizontalMultiRow(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyHorizontalMultiRow(\n                title,\n                breaks,\n                keySize\n            )\n        }\n\n        fun vertical(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyVertical(\n                title,\n                breaks,\n                keySize\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass LegendComponentSpec(\n    title: String,\n    internal val breaks: List<LegendBreak>,\n    theme: LegendTheme,\n    override val layout: LegendComponentLayout,\n    reverse: Boolean\n) : LegendBoxSpec(title, theme, reverse)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * theme legend.direction\n * layout of items in legends (\"horizontal\" or \"vertical\")\n */\nenum class LegendDirection {\n    HORIZONTAL,\n    VERTICAL,\n    AUTO\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * anchor point for positioning legend inside plot (\"center\" or two-element numeric vector)\n */\nclass LegendJustification(val x: Double, val y: Double) {\n    companion object {\n        val CENTER = LegendJustification(0.5, 0.5)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * the position of legends (\"none\", \"left\", \"right\", \"bottom\", \"top\", or two-element numeric vector)\n */\nclass LegendPosition(val x: Double, val y: Double) {\n\n    val isFixed: Boolean\n        get() = this === LEFT || this === RIGHT ||\n                this === TOP || this === BOTTOM\n\n    val isHidden: Boolean\n        get() = this === NONE\n\n    val isOverlay: Boolean\n        get() = !(isFixed || isHidden)\n\n    companion object {\n        val RIGHT = LegendPosition(1.0, 0.5)\n        val LEFT = LegendPosition(0.0, 0.5)\n        val TOP = LegendPosition(0.5, 1.0)\n        val BOTTOM = LegendPosition(0.5, 1.0)\n        val NONE = LegendPosition(Double.NaN, Double.NaN)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nenum class Orientation(private val myValue: String) {\n    LEFT(\"LEFT\"),\n    RIGHT(\"RIGHT\"),\n    TOP(\"TOP\"),\n    BOTTOM(\"BOTTOM\");\n\n    val isHorizontal: Boolean\n        get() = this == TOP || this == BOTTOM\n\n    override fun toString(): String {\n        return \"Orientation{\" +\n                \"myValue='\" + myValue + '\\''.toString() +\n                '}'.toString()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\n\ninterface ContextualMappingProvider {\n    fun createContextualMapping(dataAccess: MappedDataAccess, dataFrame: DataFrame): ContextualMapping\n\n    companion object {\n        val NONE = object : ContextualMappingProvider {\n            override fun createContextualMapping(dataAccess: MappedDataAccess, dataFrame: DataFrame): ContextualMapping {\n                return ContextualMapping(\n                    tooltipLines = emptyList(),\n                    tooltipAnchor = null,\n                    tooltipMinWidth = null,\n                    tooltipColor = null,\n                    ignoreInvisibleTargets = false,\n                    hasGeneralTooltip = false,\n                    hasAxisTooltip = false,\n                    isCrosshairEnabled = false\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.*\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.builder.tooltip.MappingValue\nimport jetbrains.datalore.plot.builder.tooltip.TooltipLine\nimport jetbrains.datalore.plot.builder.tooltip.TooltipSpecification.TooltipProperties\nimport jetbrains.datalore.plot.builder.tooltip.ValueSource\n\nclass GeomInteraction(builder: GeomInteractionBuilder) :\n    ContextualMappingProvider {\n\n    private val myLocatorLookupSpace: LookupSpace = builder.locatorLookupSpace\n    private val myLocatorLookupStrategy: LookupStrategy = builder.locatorLookupStrategy\n    private val myTooltipLines: List<TooltipLine> = builder.tooltipLines\n    private val myTooltipProperties: TooltipProperties = builder.tooltipProperties\n    private val myIgnoreInvisibleTargets = builder.isIgnoringInvisibleTargets()\n    private val myIsCrosshairEnabled: Boolean = builder.isCrosshairEnabled\n\n    fun createLookupSpec(): LookupSpec {\n        return LookupSpec(myLocatorLookupSpace, myLocatorLookupStrategy)\n    }\n\n    override fun createContextualMapping(\n        dataAccess: MappedDataAccess,\n        dataFrame: DataFrame\n    ): ContextualMapping {\n        return createContextualMapping(\n            myTooltipLines.map(::TooltipLine),  // clone tooltip lines to not share DataContext between plots when facet is used\n                                                // (issue #247 - With facet_grid tooltip shows data from last plot on all plots)\n            dataAccess,\n            dataFrame,\n            myTooltipProperties,\n            myIgnoreInvisibleTargets,\n            myIsCrosshairEnabled\n        )\n    }\n\n    companion object {\n        // For tests\n        fun createTestContextualMapping(\n            aesListForTooltip: List<Aes<*>>,\n            axisAes: List<Aes<*>>,\n            outliers: List<Aes<*>>,\n            dataAccess: MappedDataAccess,\n            dataFrame: DataFrame,\n            userDefinedValueSources: List<ValueSource>? = null\n        ): ContextualMapping {\n            val defaultTooltipLines = GeomInteractionBuilder.defaultValueSourceTooltipLines(\n                aesListForTooltip,\n                axisAes,\n                outliers,\n                userDefinedValueSources\n            )\n            return createContextualMapping(\n                defaultTooltipLines,\n                dataAccess,\n                dataFrame,\n                TooltipProperties.NONE,\n                ignoreInvisibleTargets = false,\n                isCrosshairEnabled = false\n            )\n        }\n\n        private fun createContextualMapping(\n            tooltipLines: List<TooltipLine>,\n            dataAccess: MappedDataAccess,\n            dataFrame: DataFrame,\n            tooltipProperties: TooltipProperties,\n            ignoreInvisibleTargets: Boolean,\n            isCrosshairEnabled: Boolean\n        ): ContextualMapping {\n            val dataContext = DataContext(dataFrame = dataFrame, mappedDataAccess = dataAccess)\n\n            val mappedTooltipLines = tooltipLines.filter { line ->\n                val dataAesList = line.fields.filterIsInstance<MappingValue>()\n                dataAesList.all { mappedAes -> dataAccess.isMapped(mappedAes.aes) }\n            }\n            mappedTooltipLines.forEach { it.initDataContext(dataContext) }\n\n            val hasGeneralTooltip = mappedTooltipLines.any { line ->\n                line.fields.none(ValueSource::isOutlier)\n            }\n            val hasAxisTooltip = mappedTooltipLines.any { line ->\n                line.fields.any(ValueSource::isAxis)\n            }\n\n            return ContextualMapping(\n                mappedTooltipLines,\n                tooltipProperties.anchor,\n                tooltipProperties.minWidth,\n                tooltipProperties.color,\n                ignoreInvisibleTargets,\n                hasGeneralTooltip,\n                hasAxisTooltip,\n                isCrosshairEnabled\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy\nimport jetbrains.datalore.plot.builder.tooltip.TooltipSpecification\nimport jetbrains.datalore.plot.builder.tooltip.TooltipLine\nimport jetbrains.datalore.plot.builder.tooltip.ValueSource\nimport jetbrains.datalore.plot.builder.tooltip.MappingValue\nimport jetbrains.datalore.plot.builder.tooltip.ConstantValue\n\nclass GeomInteractionBuilder(private val mySupportedAesList: List<Aes<*>>) {\n    private var myIgnoreInvisibleTargets: Boolean = false\n    lateinit var locatorLookupSpace: LookupSpace\n        private set\n    lateinit var locatorLookupStrategy: LookupStrategy\n        private set\n    private var myAxisTooltipVisibilityFromFunctionKind: Boolean = false\n    private var myAxisTooltipVisibilityFromConfig: Boolean? = null\n    private var myAxisAesFromFunctionKind: List<Aes<*>>? = null\n    private lateinit var myTooltipAxisAes: List<Aes<*>>\n    private lateinit var myTooltipAes: List<Aes<*>>\n    private lateinit var myTooltipOutlierAesList: List<Aes<*>>\n    private var myTooltipConstantsAesList: Map<Aes<*>, Any>? = null\n    private var myUserTooltipSpec: TooltipSpecification? = null\n    private var myIsCrosshairEnabled: Boolean = false\n\n    val getAxisFromFunctionKind: List<Aes<*>>\n        get() = myAxisAesFromFunctionKind ?: emptyList()\n\n    val isAxisTooltipEnabled: Boolean\n        get() = if (myAxisTooltipVisibilityFromConfig == null)\n            myAxisTooltipVisibilityFromFunctionKind\n        else\n            myAxisTooltipVisibilityFromConfig!!\n\n    val tooltipLines: List<TooltipLine>\n        get() = prepareTooltipValueSources()\n\n    val tooltipProperties: TooltipSpecification.TooltipProperties\n        get() = myUserTooltipSpec?.tooltipProperties ?: TooltipSpecification.TooltipProperties.NONE\n\n    val isCrosshairEnabled: Boolean\n        get() = myIsCrosshairEnabled\n\n    fun showAxisTooltip(isTrue: Boolean): GeomInteractionBuilder {\n        myAxisTooltipVisibilityFromConfig = isTrue\n        return this\n    }\n\n    fun tooltipAes(aes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipAes = aes\n        return this\n    }\n\n    fun axisAes(axisAes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipAxisAes = axisAes\n        return this\n    }\n\n    fun tooltipOutliers(aes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipOutlierAesList = aes\n        return this\n    }\n\n    fun tooltipConstants(constantsMap:  Map<Aes<*>, Any>): GeomInteractionBuilder {\n        myTooltipConstantsAesList = constantsMap\n        return this\n    }\n\n    fun tooltipLinesSpec(tooltipSpec: TooltipSpecification): GeomInteractionBuilder {\n        myUserTooltipSpec = tooltipSpec\n        return this\n    }\n\n    fun setIsCrosshairEnabled(isTrue: Boolean): GeomInteractionBuilder {\n        myIsCrosshairEnabled = isTrue\n        return this\n    }\n\n    fun multilayerLookupStrategy(): GeomInteractionBuilder {\n        locatorLookupStrategy = LookupStrategy.NEAREST\n        locatorLookupSpace = LookupSpace.XY\n        return this\n    }\n\n    fun univariateFunction(lookupStrategy: LookupStrategy): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = AES_X\n        locatorLookupStrategy = lookupStrategy\n        myAxisTooltipVisibilityFromFunctionKind = true\n        locatorLookupSpace = LookupSpace.X\n        initDefaultTooltips()\n        return this\n    }\n\n    fun bivariateFunction(area: Boolean): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = AES_XY\n\n        if (area) {\n            locatorLookupStrategy = LookupStrategy.HOVER\n            myAxisTooltipVisibilityFromFunctionKind = false\n        } else {\n            locatorLookupStrategy = LookupStrategy.NEAREST\n            myAxisTooltipVisibilityFromFunctionKind = true\n        }\n        locatorLookupSpace = LookupSpace.XY\n        initDefaultTooltips()\n        return this\n    }\n\n    fun none(): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = ArrayList(mySupportedAesList)\n        locatorLookupStrategy = LookupStrategy.NONE\n        myAxisTooltipVisibilityFromFunctionKind = true\n        locatorLookupSpace = LookupSpace.NONE\n        initDefaultTooltips()\n        return this\n    }\n\n    private fun initDefaultTooltips() {\n        myTooltipAxisAes = if (!isAxisTooltipEnabled) emptyList() else getAxisFromFunctionKind\n        myTooltipAes = mySupportedAesList - getAxisFromFunctionKind\n        myTooltipOutlierAesList = emptyList()\n    }\n\n    private fun prepareTooltipValueSources(): List<TooltipLine> {\n\n        return when {\n            myUserTooltipSpec == null -> {\n                // No user tooltip specification => use default tooltips\n                defaultValueSourceTooltipLines(\n                    myTooltipAes,\n                    myTooltipAxisAes,\n                    myTooltipOutlierAesList,\n                    userDefinedValueSources = null,\n                    constantsMap = myTooltipConstantsAesList\n                )\n            }\n            myUserTooltipSpec!!.tooltipLinePatterns == null -> {\n                // No user line patterns => use default tooltips with the given formatted valueSources\n                defaultValueSourceTooltipLines(\n                    myTooltipAes,\n                    myTooltipAxisAes,\n                    myTooltipOutlierAesList,\n                    myUserTooltipSpec!!.valueSources,\n                    myTooltipConstantsAesList\n                )\n            }\n            myUserTooltipSpec!!.tooltipLinePatterns!!.isEmpty() -> {\n                // User list is empty => not show tooltips\n                emptyList()\n            }\n            else -> {\n                // Form value sources: user list + axis + outliers\n                val geomOutliers = myTooltipOutlierAesList.toMutableList()\n\n                // Remove outlier tooltip if the mappedAes is used in the general tooltip\n                myUserTooltipSpec!!.tooltipLinePatterns!!.forEach { line ->\n                    val userDataAesList = line.fields.filterIsInstance<MappingValue>().map { it.aes }\n                    geomOutliers.removeAll(userDataAesList)\n                }\n                val axisValueSources = myTooltipAxisAes.map { aes -> MappingValue(aes, isOutlier = true, isAxis = true) }\n                val geomOutlierValueSources = geomOutliers.map { aes ->\n                    val formatted = myUserTooltipSpec!!.valueSources.filterIsInstance<MappingValue>().find { it.aes == aes }\n                    formatted?.toOutlier() ?: MappingValue(aes, isOutlier = true)\n                }\n\n                myUserTooltipSpec!!.tooltipLinePatterns!! + (axisValueSources + geomOutlierValueSources).map(TooltipLine.Companion::defaultLineForValueSource)\n            }\n        }\n    }\n\n    fun build(): GeomInteraction {\n        return GeomInteraction(this)\n    }\n\n    fun ignoreInvisibleTargets(isTrue: Boolean): GeomInteractionBuilder {\n        myIgnoreInvisibleTargets = isTrue\n        return this\n    }\n\n    fun isIgnoringInvisibleTargets(): Boolean {\n        return myIgnoreInvisibleTargets\n    }\n\n\n    companion object {\n        const val AREA_GEOM = true\n        const val NON_AREA_GEOM = false\n\n        private val AES_X = listOf(Aes.X)\n        private val AES_XY = listOf(Aes.X, Aes.Y)\n\n        fun defaultValueSourceTooltipLines(\n            aesListForTooltip: List<Aes<*>>,\n            axisAes: List<Aes<*>>,\n            outliers: List<Aes<*>>,\n            userDefinedValueSources: List<ValueSource>? = null,\n            constantsMap: Map<Aes<*>, Any>? = null\n        ): List<TooltipLine> {\n            val axisValueSources = axisAes.map { aes -> MappingValue(aes, isOutlier = true, isAxis = true) }\n            val outlierValueSources = outliers.map { aes ->\n                val userDefined = userDefinedValueSources?.filterIsInstance<MappingValue>()?.find { it.aes == aes }\n                userDefined?.toOutlier() ?: MappingValue(aes, isOutlier = true)\n            }\n            val aesValueSources = aesListForTooltip.map { aes ->\n                val userDefined = userDefinedValueSources?.filterIsInstance<MappingValue>()?.find { it.aes == aes }\n                userDefined ?: MappingValue(aes)\n            }\n            val constantValues = constantsMap?.map { (_, value) -> ConstantValue(value, format = null) } ?: emptyList()\n            return (aesValueSources + axisValueSources + outlierValueSources + constantValues).map(TooltipLine.Companion::defaultLineForValueSource)\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to entries of this map in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Any> Map<out K, V>.firstNotNullOf(transform: (Map.Entry<K, V>) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the map was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to entries of this map in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Any> Map<out K, V>.firstNotNullOfOrNull(transform: (Map.Entry<K, V>) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns a [List] containing all key-value pairs.\n */\npublic fun <K, V> Map<out K, V>.toList(): List<Pair<K, V>> {\n    if (size == 0)\n        return emptyList()\n    val iterator = entries.iterator()\n    if (!iterator.hasNext())\n        return emptyList()\n    val first = iterator.next()\n    if (!iterator.hasNext())\n        return listOf(first.toPair())\n    val result = ArrayList<Pair<K, V>>(size)\n    result.add(first.toPair())\n    do {\n        result.add(iterator.next().toPair())\n    } while (iterator.hasNext())\n    return result\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each entry of original map.\n * \n * @sample samples.collections.Maps.Transformations.flatMap\n */\npublic inline fun <K, V, R> Map<out K, V>.flatMap(transform: (Map.Entry<K, V>) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each entry of original map.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <K, V, R> Map<out K, V>.flatMap(transform: (Map.Entry<K, V>) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each entry of original map, to the given [destination].\n */\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.flatMapTo(destination: C, transform: (Map.Entry<K, V>) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each entry of original map, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.flatMapTo(destination: C, transform: (Map.Entry<K, V>) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each entry in the original map.\n * \n * @sample samples.collections.Maps.Transformations.mapToList\n */\npublic inline fun <K, V, R> Map<out K, V>.map(transform: (Map.Entry<K, V>) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each entry in the original map.\n * \n * @sample samples.collections.Maps.Transformations.mapNotNull\n */\npublic inline fun <K, V, R : Any> Map<out K, V>.mapNotNull(transform: (Map.Entry<K, V>) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each entry in the original map\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <K, V, R : Any, C : MutableCollection<in R>> Map<out K, V>.mapNotNullTo(destination: C, transform: (Map.Entry<K, V>) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each entry of the original map\n * and appends the results to the given [destination].\n */\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.mapTo(destination: C, transform: (Map.Entry<K, V>) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns `true` if all entries match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <K, V> Map<out K, V>.all(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if map has at least one entry.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <K, V> Map<out K, V>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one entry matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <K, V> Map<out K, V>.any(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of entries in this map.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of entries matching the given [predicate].\n */\npublic inline fun <K, V> Map<out K, V>.count(predicate: (Map.Entry<K, V>) -> Boolean): Int {\n    if (isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Performs the given [action] on each entry.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <K, V> Map<out K, V>.forEach(action: (Map.Entry<K, V>) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxBy(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first entry yielding the largest value of the given function or `null` if there are no entries.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxByOrNull(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return entries.maxByOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> Double): Double {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> Float): Float {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> R): R {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> Double): Double? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> Float): Float? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.maxOfWith(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R {\n    return entries.maxOfWith(comparator, selector)\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.maxOfWithOrNull(comparator, selector)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxWith(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first entry having the largest value according to the provided [comparator] or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxWithOrNull(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return entries.maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minBy(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first entry yielding the smallest value of the given function or `null` if there are no entries.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minByOrNull(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return entries.minByOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> Double): Double {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> Float): Float {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> R): R {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> Double): Double? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> Float): Float? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.minOfWith(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R {\n    return entries.minOfWith(comparator, selector)\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.minOfWithOrNull(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.minOfWithOrNull(comparator, selector)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <K, V> Map<out K, V>.minWith(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first entry having the smallest value according to the provided [comparator] or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minWithOrNull(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return entries.minWithOrNull(comparator)\n}\n\n/**\n * Returns `true` if the map has no entries.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <K, V> Map<out K, V>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no entries match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <K, V> Map<out K, V>.none(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each entry and returns the map itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <K, V, M : Map<out K, V>> M.onEach(action: (Map.Entry<K, V>) -> Unit): M {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each entry, providing sequential index with the entry,\n * and returns the map itself afterwards.\n * @param [action] function that takes the index of an entry and the entry itself\n * and performs the action on the entry.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : Map<out K, V>> M.onEachIndexed(action: (index: Int, Map.Entry<K, V>) -> Unit): M {\n    return apply { entries.forEachIndexed(action) }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original map returning its entries when being iterated.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.asIterable(): Iterable<Map.Entry<K, V>> {\n    return entries\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original map returning its entries when being iterated.\n */\npublic fun <K, V> Map<out K, V>.asSequence(): Sequence<Map.Entry<K, V>> {\n    return entries.asSequence()\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject MathUtil {\n\n    internal fun polygonContainsCoordinate(points: List<DoubleVector>, coord: DoubleVector): Boolean {\n        var intersectionCount = 0\n\n        for (i in 1 until points.size) {\n            val start = points[i - 1]\n            val end = points[i]\n\n            if (start.y >= coord.y && end.y >= coord.y || start.y < coord.y && end.y < coord.y) {\n                continue\n            }\n\n            val x = start.x + (coord.y - start.y) * (end.x - start.x) / (end.y - start.y)\n\n            if (x <= coord.x) {\n                intersectionCount++\n            }\n        }\n\n        return intersectionCount % 2 != 0\n    }\n\n    fun liesOnSegment(p1: DoubleVector, p2: DoubleVector, c: DoubleVector, epsilon: Double): Boolean {\n        return DoubleSegment(p1, p2).distance(c) < epsilon\n    }\n\n    internal fun areEqual(p1: DoubleVector, p2: DoubleVector, epsilon: Double): Boolean {\n        return p1.subtract(p2).length() < epsilon\n    }\n\n    internal fun areEqual(a: Double, b: Double, epsilon: Double): Boolean {\n        return abs(a - b) < epsilon\n    }\n\n    internal fun distance(p1: DoubleVector, p2: DoubleVector): Double {\n        return DoubleSegment(p1, p2).length()\n    }\n\n    internal fun subtractX(v: DoubleVector, x: Double): DoubleVector {\n        return DoubleVector(v.x - x, v.y)\n    }\n\n    internal fun addX(v: DoubleVector, x: Double): DoubleVector {\n        return DoubleVector(v.x + x, v.y)\n    }\n\n    fun leftEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.top),\n                DoubleVector(rect.left, rect.bottom)\n        )\n    }\n\n    fun topEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.top),\n                DoubleVector(rect.right, rect.top)\n        )\n    }\n\n    fun rightEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.right, rect.top),\n                DoubleVector(rect.right, rect.bottom)\n        )\n    }\n\n    fun bottomEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.bottom),\n                DoubleVector(rect.right, rect.bottom)\n        )\n    }\n\n\n    class ClosestPointChecker internal constructor(val target: DoubleVector) {\n        var distance = -1.0\n            private set\n        var coord: DoubleVector? = null\n            private set\n\n        constructor(x: Double, y: Double) : this(DoubleVector(x, y))\n\n        fun check(coord: DoubleVector): Boolean {\n            val cmpResult = compare(coord)\n            return cmpResult == COMPARISON_RESULT.NEW_CLOSER || cmpResult == COMPARISON_RESULT.EQUAL\n        }\n\n        fun compare(coord: DoubleVector): COMPARISON_RESULT {\n            val newDistance = distance(target, coord)\n            if (distance < 0) {\n                setNewClosestCoord(coord, newDistance)\n                return COMPARISON_RESULT.NEW_CLOSER\n            }\n\n            if (distance < newDistance) {\n                return COMPARISON_RESULT.NEW_FARTHER\n            }\n\n            if (distance == newDistance) {\n                return COMPARISON_RESULT.EQUAL\n            }\n\n            setNewClosestCoord(coord, newDistance)\n            return COMPARISON_RESULT.NEW_CLOSER\n        }\n\n        private fun setNewClosestCoord(coord: DoubleVector, distance: Double) {\n            this.distance = distance\n            this.coord = coord\n        }\n\n        enum class COMPARISON_RESULT {\n            NEW_CLOSER,\n            NEW_FARTHER,\n            EQUAL\n        }\n    }\n\n    class DoubleRange private constructor(private val myStart: Double, private val myLength: Double) {\n\n        init {\n            if (myLength < 0) {\n                throw IllegalStateException(\"Length should be positive\")\n            }\n        }\n\n        fun length(): Double {\n            return myLength\n        }\n\n        fun overlaps(v: DoubleRange): Boolean {\n            return start() <= v.end() && v.start() <= end()\n        }\n\n        fun inside(v: DoubleRange): Boolean {\n            return start() >= v.start() && end() <= v.end()\n        }\n\n        operator fun contains(value: Double): Boolean {\n            return value >= start() && value <= end()\n        }\n\n        fun start(): Double {\n            return myStart\n        }\n\n        fun end(): Double {\n            return myStart + length()\n        }\n\n        fun move(delta: Double): DoubleRange {\n            return withStartAndLength(\n                start() + delta,\n                length()\n            )\n        }\n\n        fun moveLeft(delta: Double): DoubleRange {\n            if (delta < 0) {\n                throw IllegalStateException(\"Value should be positive\")\n            }\n\n            return withStartAndLength(\n                start() - delta,\n                length()\n            )\n        }\n\n        fun moveRight(delta: Double): DoubleRange {\n            if (delta < 0) {\n                throw IllegalStateException(\"Value should be positive\")\n            }\n\n            return withStartAndLength(\n                start() + delta,\n                length()\n            )\n        }\n\n        companion object {\n            fun withStartAndEnd(start: Double, end: Double): DoubleRange {\n                val rangeStart = min(start, end)\n                val rangeLength = max(start, end) - rangeStart\n                return DoubleRange(rangeStart, rangeLength)\n            }\n\n            fun withStartAndLength(start: Double, length: Double): DoubleRange {\n                return DoubleRange(start, length)\n            }\n        }\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TooltipAnchor\n\nclass TooltipSpec(\n    val layoutHint: TipLayoutHint,\n    lines: List<Line>,\n    val fill: Color,\n    val isOutlier: Boolean,\n    val anchor: TooltipAnchor? = null,\n    val minWidth: Double? = null,\n    val isCrosshairEnabled: Boolean = false\n) {\n    val lines: List<Line> = ArrayList(lines)\n\n    override fun toString(): String {\n        return \"TooltipSpec($layoutHint, lines=${lines.map(Line::toString)})\"\n    }\n\n    class Line(val label: String?, val value: String) {\n        override fun toString(): String {\n            return if (label.isNullOrEmpty()) value else \"${label}: $value\"\n        }\n\n        companion object {\n            fun withValue(value: String) = Line(label = null, value = value)\n            fun withLabelAndValue(label: String?, value: String) = Line(label, value)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_RADIUS\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_TOOLTIP_COLOR\n\nclass TooltipSpecFactory(\n    private val contextualMapping: ContextualMapping,\n    private val axisOrigin: DoubleVector\n) {\n    fun create(geomTarget: GeomTarget): List<TooltipSpec> {\n        return ArrayList(Helper(geomTarget).createTooltipSpecs())\n    }\n\n    private inner class Helper(private val myGeomTarget: GeomTarget) {\n        private val myDataPoints = contextualMapping.getDataPoints(hitIndex())\n        private val myTooltipAnchor = contextualMapping.tooltipAnchor\n        private val myTooltipMinWidth = contextualMapping.tooltipMinWidth\n        private val myTooltipColor = contextualMapping.tooltipColor\n        private val myIsCrosshairEnabled = contextualMapping.isCrosshairEnabled\n\n        internal fun createTooltipSpecs(): List<TooltipSpec> {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            tooltipSpecs += outlierTooltipSpec()\n            tooltipSpecs += generalTooltipSpec()\n            tooltipSpecs += axisTooltipSpec()\n            return tooltipSpecs\n        }\n\n        private fun hitIndex(): Int {\n            return myGeomTarget.hitIndex\n        }\n\n        private fun tipLayoutHint(): TipLayoutHint {\n            return myGeomTarget.tipLayoutHint\n        }\n\n        private fun outlierHints(): Map<Aes<*>, TipLayoutHint> {\n            return myGeomTarget.aesTipLayoutHints\n        }\n\n        private fun hintColors(): Map<Aes<*>, Color?> {\n            return myGeomTarget.aesTipLayoutHints.map { it.key to it.value.color }.toMap()\n        }\n\n        private fun outlierTooltipSpec(): List<TooltipSpec> {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            val outlierDataPoints = outlierDataPoints()\n            outlierHints().forEach { (aes, hint) ->\n                val linesForAes = outlierDataPoints\n                    .filter { aes == it.aes }\n                    .map(DataPoint::value)\n                    .map(TooltipSpec.Line.Companion::withValue)\n                if (linesForAes.isNotEmpty()) {\n                    tooltipSpecs.add(\n                        TooltipSpec(\n                            layoutHint = hint,\n                            lines = linesForAes,\n                            fill = hint.color ?: tipLayoutHint().color!!,\n                            isOutlier = true\n                        )\n                    )\n                }\n            }\n            return tooltipSpecs\n        }\n\n\n        private fun axisTooltipSpec(): List<TooltipSpec>  {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            val axis = mapOf(\n                Aes.X to axisDataPoints().filter { Aes.X == it.aes }.map(DataPoint::value).map(TooltipSpec.Line.Companion::withValue),\n                Aes.Y to axisDataPoints().filter { Aes.Y == it.aes }.map(DataPoint::value).map(TooltipSpec.Line.Companion::withValue)\n            )\n            axis.forEach { (aes, lines) ->\n                if (lines.isNotEmpty()) {\n                    val layoutHint = createHintForAxis(aes)\n                    tooltipSpecs.add(\n                        TooltipSpec(\n                            layoutHint = layoutHint,\n                            lines = lines,\n                            fill = layoutHint.color!!,\n                            isOutlier = true\n                        )\n                    )\n                }\n            }\n            return tooltipSpecs\n        }\n\n        private fun generalTooltipSpec(): List<TooltipSpec> {\n            val generalDataPoints = generalDataPoints()\n            val generalLines = generalDataPoints.map { TooltipSpec.Line.withLabelAndValue(it.label, it.value) }\n            val aesHintColors = hintColors()\n                .filterKeys { aes -> aes in generalDataPoints.map { it.aes } }\n            val colorFromHints = aesHintColors[Aes.Y] ?: aesHintColors.mapNotNull { it.value }.lastOrNull()\n            val tooltipColor = when {\n                myTooltipColor != null -> myTooltipColor\n                colorFromHints != null -> colorFromHints\n                else -> tipLayoutHint().color!!\n            }\n            return if (generalLines.isNotEmpty()) {\n                listOf(\n                    TooltipSpec(\n                        tipLayoutHint(),\n                        lines = generalLines,\n                        fill = tooltipColor,\n                        isOutlier = false,\n                        anchor = myTooltipAnchor,\n                        minWidth = myTooltipMinWidth,\n                        isCrosshairEnabled = myIsCrosshairEnabled\n                    )\n                )\n            } else {\n                emptyList()\n            }\n        }\n\n        private fun outlierDataPoints(): List<DataPoint> {\n            return myDataPoints.filter { it.isOutlier && !it.isAxis }\n        }\n\n        private fun axisDataPoints(): List<DataPoint> {\n            return myDataPoints.filter(DataPoint::isAxis)\n        }\n\n        private fun generalDataPoints(): List<DataPoint> {\n            val nonOutlierDataPoints = myDataPoints.filterNot(DataPoint::isOutlier)\n            val outliers = outlierDataPoints().mapNotNull(DataPoint::aes)\n            val generalAesList = nonOutlierDataPoints.mapNotNull(DataPoint::aes) - outliers\n            return nonOutlierDataPoints.filter { dataPoint ->\n                when (dataPoint.aes){\n                    null -> true                // get all not aes (variables, text)\n                    in generalAesList -> true   // get all existed in prepared aes list (mapped aes)\n                    else -> false               // skip others (axis)\n                }\n            }\n        }\n\n        private fun createHintForAxis(aes: Aes<*>): TipLayoutHint {\n            return when(aes) {\n                 Aes.X -> TipLayoutHint.xAxisTooltip(\n                     coord = DoubleVector(tipLayoutHint().coord!!.x, axisOrigin.y),\n                     color = AXIS_TOOLTIP_COLOR,\n                     axisRadius = AXIS_RADIUS\n                 )\n                Aes.Y -> TipLayoutHint.yAxisTooltip(\n                    coord = DoubleVector(axisOrigin.x, tipLayoutHint().coord!!.y),\n                    color = AXIS_TOOLTIP_COLOR,\n                    axisRadius = AXIS_RADIUS\n                )\n                else -> error(\"Not an axis aes: $aes\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.*\n\nclass LayerTargetCollectorWithLocator(\n    private val geomKind: GeomKind,\n    private val lookupSpec: GeomTargetLocator.LookupSpec,\n    private val contextualMapping: ContextualMapping,\n    private val coordinateSystem: CoordinateSystem\n) : GeomTargetCollector, GeomTargetLocator {\n\n    private val myTargets = ArrayList<TargetPrototype>()\n    private var myLocator: GeomTargetLocator? = null\n\n    override fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (contextualMapping.ignoreInvisibleTargets) {\n            if (radius == 0.0 || tooltipParams.getColor().alpha == 0) {\n                return;\n            }\n        }\n        if (!coordinateSystem.isPointInLimits(point)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.point(point, radius),\n                { index },\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (contextualMapping.ignoreInvisibleTargets) {\n            if (rectangle.width == 0.0 || rectangle.height == 0.0 || tooltipParams.getColor().alpha == 0) {\n                return\n            }\n        }\n        if (!coordinateSystem.isRectInLimits(rectangle)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.rect(rectangle),\n                { index },\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (!coordinateSystem.isPathInLimits(points)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.path(points),\n                localToGlobalIndex,\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (!coordinateSystem.isPolygonInLimits(points)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.polygon(points),\n                localToGlobalIndex,\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    private fun addTarget(targetPrototype: TargetPrototype) {\n        myTargets.add(targetPrototype)\n        myLocator = null\n    }\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        if (myLocator == null) {\n            myLocator = LayerTargetLocator(\n                geomKind,\n                lookupSpec,\n                contextualMapping,\n                myTargets\n            )\n        }\n        return myLocator!!.search(coord)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkArgument\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.HitShape.Kind.*\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.CURSOR_TOOLTIP\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker\nimport kotlin.math.max\n\ninternal class LayerTargetLocator(\n    private val geomKind: GeomKind,\n    private val lookupSpec: GeomTargetLocator.LookupSpec,\n    private val contextualMapping: ContextualMapping,\n    targetPrototypes: List<TargetPrototype>\n) :\n    GeomTargetLocator {\n\n    private val myTargets = ArrayList<Target>()\n    private val myTargetDetector: TargetDetector =\n        TargetDetector(lookupSpec.lookupSpace, lookupSpec.lookupStrategy)\n\n    private val mySimpleGeometry = setOf(GeomKind.RECT, GeomKind.POLYGON)\n\n    private val myCollectingStrategy: Collector.CollectingStrategy =\n        when {\n            geomKind in mySimpleGeometry -> {\n                // fix overlapping tooltips under cursor\n                Collector.CollectingStrategy.REPLACE\n            }\n            lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.X && lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.NEAREST -> {\n                // collect all with a minimum distance from cursor\n                Collector.CollectingStrategy.APPEND_IF_EQUAL\n            }\n            lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.X -> {\n                Collector.CollectingStrategy.APPEND\n            }\n            lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.HOVER -> {\n                Collector.CollectingStrategy.APPEND\n            }\n            lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.NONE || lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.NONE -> {\n                Collector.CollectingStrategy.IGNORE\n            }\n            else -> {\n                Collector.CollectingStrategy.REPLACE\n            }\n        }\n\n    init {\n        fun toProjection(prototype: TargetPrototype): TargetProjection {\n            return when (prototype.hitShape.kind) {\n                POINT -> PointTargetProjection.create(\n                    prototype.hitShape.point.center,\n                    lookupSpec.lookupSpace\n                )\n\n                RECT -> RectTargetProjection.create(\n                    prototype.hitShape.rect,\n                    lookupSpec.lookupSpace\n                )\n\n                POLYGON -> PolygonTargetProjection.create(\n                    prototype.hitShape.points,\n                    lookupSpec.lookupSpace\n                )\n\n                PATH -> PathTargetProjection.create(\n                    prototype.hitShape.points,\n                    prototype.indexMapper,\n                    lookupSpec.lookupSpace\n                )\n            }\n        }\n\n        for (prototype in targetPrototypes) {\n            myTargets.add(\n                Target(\n                    toProjection(prototype),\n                    prototype\n                )\n            )\n        }\n    }\n\n    private fun addLookupResults(\n        collector: Collector<GeomTarget>,\n        targets: MutableList<GeomTargetLocator.LookupResult>\n    ) {\n        if (collector.size() == 0) {\n            return\n        }\n\n        targets.add(\n            GeomTargetLocator.LookupResult(\n                collector.collection(),\n                // Distance can be negative when lookup space is X\n                // In this case use 0.0 as a distance - we have a direct hit.\n                max(0.0, collector.closestPointChecker.distance),\n                geomKind,\n                contextualMapping,\n                contextualMapping.isCrosshairEnabled\n            )\n        )\n    }\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        if (myTargets.isEmpty()) {\n            return null\n        }\n\n        val rectCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n        val pointCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n        val pathCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n\n        // Should always replace because of polygon with holes - only top should have tooltip.\n        val polygonCollector = Collector<GeomTarget>(\n            coord,\n            Collector.CollectingStrategy.REPLACE,\n            lookupSpec.lookupSpace\n        )\n\n        for (target in myTargets) {\n            when (target.prototype.hitShape.kind) {\n                RECT -> processRect(coord, target, rectCollector)\n\n                POINT -> processPoint(coord, target, pointCollector)\n\n                PATH -> processPath(coord, target, pathCollector)\n\n                POLYGON -> processPolygon(coord, target, polygonCollector)\n            }\n        }\n\n        val lookupResults = ArrayList<GeomTargetLocator.LookupResult>()\n\n        addLookupResults(pathCollector, lookupResults)\n        addLookupResults(rectCollector, lookupResults)\n        addLookupResults(pointCollector, lookupResults)\n        addLookupResults(polygonCollector, lookupResults)\n\n        return getClosestTarget(lookupResults)\n    }\n\n    private fun getClosestTarget(lookupResults: List<GeomTargetLocator.LookupResult>): GeomTargetLocator.LookupResult? {\n        if (lookupResults.isEmpty()) {\n            return null\n        }\n\n        var closestTargets: GeomTargetLocator.LookupResult = lookupResults[0]\n        require(closestTargets.distance >= 0)\n\n        for (lookupResult in lookupResults) {\n            if (lookupResult.distance < closestTargets.distance) {\n                closestTargets = lookupResult\n            }\n        }\n        return closestTargets\n    }\n\n    private fun processRect(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkRect(coord, target.rectProjection, resultCollector.closestPointChecker)) {\n\n            val rect = target.prototype.hitShape.rect\n            val yOffset = when (target.prototype.tooltipKind) {\n                CURSOR_TOOLTIP -> rect.height / 2.0\n                else -> 0.0\n            }\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    rect.origin.add(DoubleVector(rect.width / 2, yOffset)),\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPolygon(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkPolygon(coord, target.polygonProjection, resultCollector.closestPointChecker)) {\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    coord,\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPoint(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkPoint(coord, target.pointProjection, resultCollector.closestPointChecker)) {\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    target.prototype.hitShape.point.center,\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPath(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        // When searching single point from all targets (REPLACE) - should search nearest projection between every path target.\n        // When searching points for every target (APPEND) - should reset nearest point between every path target.\n        val pointChecker = if (myCollectingStrategy == Collector.CollectingStrategy.APPEND)\n            ClosestPointChecker(coord)\n        else\n            resultCollector.closestPointChecker\n\n        val hitPoint = myTargetDetector.checkPath(coord, target.pathProjection, pointChecker)\n        if (hitPoint != null) {\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    hitPoint.originalCoord,\n                    hitPoint.index\n                )\n            )\n        }\n    }\n\n    private fun getKeyForSingleObjectGeometry(prototype: TargetPrototype): Int {\n        return prototype.indexMapper(0)\n    }\n\n    internal class Target(private val targetProjection: TargetProjection, val prototype: TargetPrototype) {\n\n        val pointProjection: PointTargetProjection\n            get() = targetProjection as PointTargetProjection\n\n        val rectProjection: RectTargetProjection\n            get() = targetProjection as RectTargetProjection\n\n        val polygonProjection: PolygonTargetProjection\n            get() = targetProjection as PolygonTargetProjection\n\n        val pathProjection: PathTargetProjection\n            get() = targetProjection as PathTargetProjection\n    }\n\n    internal class Collector<T>(\n        cursor: DoubleVector,\n        private val myStrategy: CollectingStrategy,\n        lookupSpace: GeomTargetLocator.LookupSpace\n    ) {\n        private val result = ArrayList<T>()\n        val closestPointChecker: ClosestPointChecker = if (lookupSpace == GeomTargetLocator.LookupSpace.X) {\n            ClosestPointChecker(DoubleVector(cursor.x, 0.0))\n        } else {\n            ClosestPointChecker(cursor)\n        }\n        private var myLastAddedDistance: Double = -1.0\n\n        fun collect(data: T) {\n            when (myStrategy) {\n                CollectingStrategy.APPEND -> add(data)\n                CollectingStrategy.REPLACE -> replace(data)\n                CollectingStrategy.APPEND_IF_EQUAL -> {\n                    if (myLastAddedDistance == closestPointChecker.distance) {\n                        add(data)\n                    } else {\n                        replace(data)\n                    }\n                }\n                CollectingStrategy.IGNORE -> return\n            }\n        }\n\n        fun collection(): List<T> {\n            return result\n        }\n\n        fun size(): Int {\n            return result.size\n        }\n\n        private fun add(data: T) {\n            result.add(data)\n            myLastAddedDistance = closestPointChecker.distance\n        }\n\n        private fun replace(locationData: T) {\n            result.clear()\n            result.add(locationData)\n            myLastAddedDistance = closestPointChecker.distance\n        }\n\n        internal enum class CollectingStrategy {\n            APPEND,\n            REPLACE,\n            APPEND_IF_EQUAL,\n            IGNORE\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult\nimport jetbrains.datalore.plot.builder.interact.MathUtil\nimport kotlin.math.abs\n\ninternal class LocatedTargetsPicker {\n    private val myPicked = ArrayList<LookupResult>()\n    private var myMinDistance = 0.0\n    private val myAllLookupResults = ArrayList<LookupResult>()\n\n    val picked: List<LookupResult>\n        get() = chooseBestResult()\n\n    fun addLookupResult(result: LookupResult, coord: DoubleVector? = null) {\n        val lookupResult = filterResults(result, coord)\n\n        val distance = distance(lookupResult, coord)\n        if (!lookupResult.isCrosshairEnabled && distance > CUTOFF_DISTANCE) {\n            return\n        }\n\n        when {\n            myPicked.isEmpty() || myMinDistance > distance -> {\n                myPicked.clear()\n                myPicked.add(lookupResult)\n                myMinDistance = distance\n            }\n            myMinDistance == distance && isSameUnivariateGeom(myPicked[0], lookupResult) -> {\n                myPicked.add(lookupResult)\n            }\n            myMinDistance == distance -> {\n                myPicked.clear()\n                myPicked.add(lookupResult)\n            }\n        }\n        myAllLookupResults.add(lookupResult)\n    }\n\n    private fun chooseBestResult(): List<LookupResult> {\n        fun hasGeneralTooltip(lookupResult: LookupResult) = lookupResult.contextualMapping.hasGeneralTooltip\n        fun hasAxisTooltip(lookupResult: LookupResult): Boolean {\n            return lookupResult.contextualMapping.hasAxisTooltip ||\n                    // actually hline/vline have axis info in the general tooltip\n                    lookupResult.geomKind in listOf(GeomKind.V_LINE, GeomKind.H_LINE)\n        }\n\n        return when {\n            myPicked.any { hasGeneralTooltip(it) && hasAxisTooltip(it) } -> myPicked\n            myAllLookupResults.none { hasGeneralTooltip(it) } -> myPicked\n            myAllLookupResults.any { hasGeneralTooltip(it) && hasAxisTooltip(it) } -> {\n                listOf(myAllLookupResults.last { hasGeneralTooltip(it) && hasAxisTooltip(it) })\n            }\n            else -> {\n                val withGeneralTooltip = myAllLookupResults.lastOrNull { hasGeneralTooltip(it) }\n                val withAxisTooltip = myAllLookupResults.lastOrNull { hasAxisTooltip(it) }\n                listOfNotNull(withGeneralTooltip, withAxisTooltip)\n            }\n        }\n    }\n\n    companion object {\n        internal const val CUTOFF_DISTANCE = 30.0\n        internal const val FAKE_DISTANCE = 15.0\n        private val UNIVARIATE_GEOMS = listOf(\n            GeomKind.DENSITY,\n            GeomKind.FREQPOLY,\n            GeomKind.BOX_PLOT,\n            GeomKind.HISTOGRAM,\n            GeomKind.LINE,\n            GeomKind.AREA,\n            GeomKind.BAR,\n            GeomKind.ERROR_BAR,\n            GeomKind.CROSS_BAR,\n            GeomKind.LINE_RANGE,\n            GeomKind.POINT_RANGE\n        )\n\n        private val UNIVARIATE_LINES = listOf(\n            GeomKind.DENSITY,\n            GeomKind.FREQPOLY,\n            GeomKind.LINE,\n            GeomKind.AREA,\n            GeomKind.SEGMENT\n        )\n\n        private fun distance(locatedTargetList: LookupResult, coord: DoubleVector?): Double {\n            val distance = locatedTargetList.distance\n            // Special case for geoms like histogram, when mouse inside a rect or only X projection is used (so a distance\n            // between cursor is zero). Fake the distance to give a chance for tooltips from other layers.\n            return if (distance == 0.0) {\n                if (!locatedTargetList.isCrosshairEnabled || coord == null) {\n                    FAKE_DISTANCE\n                } else {\n                    // use XY distance for tooltips with crosshair to avoid giving them priority\n                    locatedTargetList.targets\n                        .filter { it.tipLayoutHint.coord != null }\n                        .map { target -> MathUtil.distance(coord, target.tipLayoutHint.coord!!) }\n                        .minOrNull()\n                        ?: FAKE_DISTANCE\n                }\n            } else {\n                distance\n            }\n        }\n\n        private fun isSameUnivariateGeom(lft: LookupResult, rgt: LookupResult): Boolean {\n            return lft.geomKind === rgt.geomKind && UNIVARIATE_GEOMS.contains(rgt.geomKind)\n        }\n\n        private fun filterResults(lookupResult: LookupResult, coord: DoubleVector?): LookupResult {\n            if (coord == null || lookupResult.geomKind !in UNIVARIATE_LINES) {\n                return lookupResult\n            }\n\n            // Get closest targets and remove duplicates\n            val geomTargets = lookupResult.targets.filter { it.tipLayoutHint.coord != null }\n\n            val minXToTarget = geomTargets\n                .map { target -> target.tipLayoutHint.coord!!.subtract(coord).x }\n                .minByOrNull { abs(it) }\n\n            val newTargets = geomTargets\n                .filter { target ->\n                    target.tipLayoutHint.coord!!.subtract(coord).x == minXToTarget\n                }\n                .distinctBy { it.hitIndex }\n\n            return LookupResult(\n                targets = newTargets,\n                distance = lookupResult.distance,\n                geomKind = lookupResult.geomKind,\n                contextualMapping = lookupResult.contextualMapping,\n                isCrosshairEnabled = lookupResult.isCrosshairEnabled\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy\nimport jetbrains.datalore.plot.builder.interact.MathUtil\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker.COMPARISON_RESULT\nimport jetbrains.datalore.plot.builder.interact.MathUtil.DoubleRange\nimport jetbrains.datalore.plot.builder.interact.loc.PathTargetProjection.PathPoint\n\ninternal class TargetDetector(\n        private val locatorLookupSpace: LookupSpace,\n        private val locatorLookupStrategy: LookupStrategy\n) {\n    fun checkPath(cursorCoord: DoubleVector, pathProjection: PathTargetProjection, closestPointChecker: ClosestPointChecker): PathPoint? {\n\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                if (locatorLookupStrategy === LookupStrategy.NONE) {\n                    return null\n                }\n\n                val pathPoints = pathProjection.points\n                if (pathPoints.isEmpty()) {\n                    return null\n                }\n\n                val resultIndex = binarySearch(\n                    cursorCoord.x,\n                    pathPoints.size\n                ) { index ->\n                    pathPoints[index].projection().x()\n                }\n                val bestPoint = pathPoints[resultIndex]\n\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> {\n                        if (cursorCoord.x < pathPoints[0].projection().x() || cursorCoord.x > pathPoints[pathPoints.size - 1].projection().x()) {\n                            null\n                        } else bestPoint\n                    }\n\n                    LookupStrategy.NEAREST -> bestPoint\n\n                    else -> throw IllegalStateException(\"Unknown lookup strategy: $locatorLookupStrategy\")\n                }\n            }\n\n            LookupSpace.XY -> {\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER -> {\n                        for (pathPoint in pathProjection.points) {\n                            val targetPointCoord = pathPoint.projection().xy()\n                            if (MathUtil.areEqual(targetPointCoord, cursorCoord,\n                                    POINT_AREA_EPSILON\n                                )) {\n                                return pathPoint\n                            }\n                        }\n                        return null\n                    }\n\n                    LookupStrategy.NEAREST -> {\n                        var nearestPoint: PathPoint? = null\n                        for (pathPoint in pathProjection.points) {\n                            val targetPointCoord = pathPoint.projection().xy()\n                            if (closestPointChecker.check(targetPointCoord)) {\n                                nearestPoint = pathPoint\n                            }\n                        }\n                        return nearestPoint\n                    }\n\n                    LookupStrategy.NONE -> return null\n                }\n            }\n\n            LookupSpace.NONE -> return null\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkPoint(cursorCoord: DoubleVector, pointProjection: PointTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val x = pointProjection.x()\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> MathUtil.areEqual(x, cursorCoord.x,\n                        POINT_AREA_EPSILON\n                    )\n                    LookupStrategy.NEAREST -> {\n                        closestPointChecker.check(DoubleVector(x, 0.0))\n                    }\n                    LookupStrategy.NONE -> false\n                }\n            }\n\n            LookupSpace.XY -> {\n                val targetPointCoord = pointProjection.xy()\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> MathUtil.areEqual(targetPointCoord, cursorCoord, POINT_AREA_EPSILON)\n                    LookupStrategy.NEAREST -> closestPointChecker.check(targetPointCoord)\n                    LookupStrategy.NONE -> false\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkRect(cursorCoord: DoubleVector, rectProjection: RectTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val range = rectProjection.x()\n                return rangeBasedLookup(cursorCoord, closestPointChecker, range)\n            }\n\n            LookupSpace.XY -> {\n                val rect = rectProjection.xy()\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER -> return rect.contains(cursorCoord)\n\n                    LookupStrategy.NEAREST -> {\n                        if (rect.contains(cursorCoord)) {\n                            return closestPointChecker.check(cursorCoord)\n                        }\n\n                        var x = if (cursorCoord.x < rect.left) rect.left else rect.right\n                        var y = if (cursorCoord.y < rect.top) rect.top else rect.bottom\n\n                        x = if (rect.xRange().contains(cursorCoord.x)) cursorCoord.x else x\n                        y = if (rect.yRange().contains(cursorCoord.y)) cursorCoord.y else y\n\n                        return closestPointChecker.check(DoubleVector(x, y))\n                    }\n\n                    LookupStrategy.NONE -> return false\n\n                    else -> throw IllegalStateException()\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkPolygon(cursorCoord: DoubleVector, polygonProjection: PolygonTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val range = polygonProjection.x()\n                return rangeBasedLookup(cursorCoord, closestPointChecker, range)\n            }\n\n            LookupSpace.XY -> {\n                val polygon = polygonProjection.xy()\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER, LookupStrategy.NEAREST -> {\n                        // Doesn't support nearest strategy. Target can be found only by hovering a cursor above the polygon.\n                        var counter = 0\n                        for (ring in polygon) {\n                            if (ring.bbox.contains(cursorCoord) && MathUtil.polygonContainsCoordinate(ring.edges, cursorCoord)) {\n                                counter++\n                            }\n                        }\n                        return counter % 2 != 0\n                    }\n\n                    LookupStrategy.NONE -> return false\n\n                    else -> throw IllegalStateException()\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    private fun rangeBasedLookup(cursorCoord: DoubleVector, closestPointChecker: ClosestPointChecker, range: DoubleRange): Boolean {\n        when (locatorLookupStrategy) {\n\n            LookupStrategy.HOVER -> return range.contains(cursorCoord.x)\n\n            LookupStrategy.NEAREST -> {\n                //Too far\n                return if (!range.contains(cursorCoord.x - RECT_X_NEAREST_EPSILON) && !range.contains(cursorCoord.x + RECT_X_NEAREST_EPSILON)) {\n                    false\n                } else closestPointChecker.compare(DoubleVector(range.start() + range.length() / 2, cursorCoord.y)) !== COMPARISON_RESULT.NEW_FARTHER\n\n            }\n\n            LookupStrategy.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    companion object {\n        private const val POINT_AREA_EPSILON = 0.1\n        private const val POINT_X_NEAREST_EPSILON = 2.0\n        private const val RECT_X_NEAREST_EPSILON = 2.0\n\n        private fun binarySearch(value: Double, length: Int, indexer: (Int) -> Double): Int {\n\n            if (value < indexer(0)) {\n                return 0\n            }\n            if (value > indexer(length - 1)) {\n                return length - 1\n            }\n\n            var lo = 0\n            var hi = length - 1\n\n            while (lo <= hi) {\n                val mid = (hi + lo) / 2\n                val midValue = indexer(mid)\n\n                when {\n                    value < midValue -> hi = mid - 1\n                    value > midValue -> lo = mid + 1\n                    else -> return mid\n                }\n            }\n\n            return if (indexer(lo) - value < value - indexer(hi)) {\n                lo\n            } else {\n                hi\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.algorithms.calculateArea\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleRectangles.boundingBox\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace.*\nimport jetbrains.datalore.plot.builder.interact.MathUtil.DoubleRange\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier\nimport kotlin.math.max\nimport kotlin.math.min\n\n\ninternal open class TargetProjection\n\ninternal class PointTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): Double {\n        return data as Double\n    }\n\n    fun xy(): DoubleVector {\n        return data as DoubleVector\n    }\n\n    companion object {\n        fun create(p: DoubleVector, lookupSpace: LookupSpace): PointTargetProjection {\n            return when (lookupSpace) {\n                X -> PointTargetProjection(p.x)\n                XY -> PointTargetProjection(p)\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n    }\n}\n\ninternal class RectTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): DoubleRange {\n        return data as DoubleRange\n    }\n\n    fun xy(): DoubleRectangle {\n        return data as DoubleRectangle\n    }\n\n    companion object {\n        fun create(rect: DoubleRectangle, lookupSpace: LookupSpace): RectTargetProjection {\n            return when (lookupSpace) {\n                X -> RectTargetProjection(DoubleRange.withStartAndEnd(rect.left, rect.right))\n                XY -> RectTargetProjection(rect)\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n    }\n}\n\ninternal class PolygonTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): DoubleRange {\n        return data as DoubleRange\n    }\n\n    fun xy(): List<RingXY> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return data as List<RingXY>\n    }\n\n    companion object {\n        private const val AREA_LIMIT_TO_REMOVE_POLYGON = 25.0\n        private const val POINTS_COUNT_TO_SKIP_SIMPLIFICATION = 20.0\n        private const val AREA_TOLERANCE_RATIO = 0.1\n        private const val MAX_TOLERANCE = 40.0\n\n        fun create(points: List<DoubleVector>, lookupSpace: LookupSpace): PolygonTargetProjection {\n            val rings = splitRings(points)\n\n            return when (lookupSpace) {\n                X -> PolygonTargetProjection(mapToX(rings))\n                XY -> PolygonTargetProjection(mapToXY(rings))\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n\n        private fun mapToX(rings: List<List<DoubleVector>>): DoubleRange {\n            var min = rings[0][0].x\n            var max = min\n            for (ring in rings) {\n                for (point in ring) {\n                    min = min(min, point.x)\n                    max = max(max, point.x)\n                }\n            }\n            return DoubleRange.withStartAndEnd(min, max)\n        }\n\n        private fun mapToXY(rings: List<List<DoubleVector>>): List<RingXY> {\n            val polygon = ArrayList<RingXY>()\n\n            for (ring in rings) {\n                if (ring.size < 4) {\n                    continue\n                }\n\n\n                val bbox = boundingBox(ring)\n                val area = calculateArea(ring)\n\n                val simplifiedRing: List<DoubleVector>\n\n                if (ring.size > POINTS_COUNT_TO_SKIP_SIMPLIFICATION) {\n                    val tolerance = min(area * AREA_TOLERANCE_RATIO, MAX_TOLERANCE)\n                    simplifiedRing = PolylineSimplifier.visvalingamWhyatt(ring).setWeightLimit(tolerance).points\n\n                    @Suppress(\"ConstantConditionIf\")\n                    if (isLogEnabled) {\n                        log(\"Simp: \" + ring.size + \" -> \" + simplifiedRing.size +\n                                \", tolerance=\" + tolerance +\n                                \", bbox=\" + bbox +\n                                \", area=\" + area\n                        )\n                    }\n                } else {\n                    @Suppress(\"ConstantConditionIf\")\n                    if (isLogEnabled) {\n                        log(\"Keep: size: \" + ring.size +\n                                \", bbox=\" + bbox +\n                                \", area=\" + area\n                        )\n                    }\n                    simplifiedRing = ring\n                }\n\n                if (simplifiedRing.size < 4) {\n                    continue\n                }\n\n                polygon.add(RingXY(simplifiedRing, bbox))\n            }\n\n            return polygon\n        }\n\n        private fun log(str: String) {\n            println(str)\n        }\n\n        private const val isLogEnabled = false\n    }\n\n    internal class RingXY(val edges: List<DoubleVector>, val bbox: DoubleRectangle)\n}\n\ninternal class PathTargetProjection(val data: List<PathPoint>) : TargetProjection() {\n\n    val points: List<PathPoint> = data\n\n    internal class PathPoint private constructor(\n            private val myPointTargetProjection: PointTargetProjection,\n            val originalCoord: DoubleVector,\n            val index: Int) {\n\n        fun projection(): PointTargetProjection {\n            return myPointTargetProjection\n        }\n\n        companion object {\n            fun create(p: DoubleVector, index: Int, lookupSpace: LookupSpace): PathPoint {\n                return when (lookupSpace) {\n                    X -> PathPoint(PointTargetProjection.create(p, lookupSpace), p, index)\n                    XY -> PathPoint(PointTargetProjection.create(p, lookupSpace), p, index)\n                    NONE -> undefinedLookupSpaceError()\n                }\n            }\n        }\n    }\n\n    companion object {\n        fun create(points: List<DoubleVector>, indexMapper: (Int) -> Int, lookupSpace: LookupSpace): PathTargetProjection {\n            val pointsLocation = ArrayList<PathPoint>()\n            for ((i, point) in points.withIndex()) {\n                pointsLocation.add(PathPoint.create(point, indexMapper(i), lookupSpace))\n            }\n\n            return PathTargetProjection(pointsLocation)\n        }\n    }\n}\n\nprivate fun undefinedLookupSpaceError(): Nothing {\n    throw IllegalStateException(\"Undefined geom lookup space\")\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.HitShape\nimport jetbrains.datalore.plot.base.interact.HitShape.Kind.*\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.*\n\nclass TargetPrototype(\n    internal val hitShape: HitShape,\n    internal val indexMapper: (Int) -> Int,\n    private val tooltipParams: TooltipParams,\n    internal val tooltipKind: TipLayoutHint.Kind\n) {\n\n    internal fun createGeomTarget(hitCoord: DoubleVector, hitIndex: Int): GeomTarget {\n        return GeomTarget(\n            hitIndex,\n            createTipLayoutHint(hitCoord, hitShape, tooltipParams.getColor(), tooltipKind, tooltipParams.getStemLength()),\n            tooltipParams.getTipLayoutHints()\n        )\n    }\n\n    companion object {\n        fun createTipLayoutHint(\n            hitCoord: DoubleVector,\n            hitShape: HitShape,\n            fill: Color,\n            tooltipKind: TipLayoutHint.Kind,\n            stemLength: TipLayoutHint.StemLength\n        ): TipLayoutHint {\n\n            return when (hitShape.kind) {\n                POINT -> when (tooltipKind) {\n                    VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(hitCoord, hitShape.point.radius, fill, stemLength)\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for POINT\")\n                }\n\n                RECT -> when (tooltipKind) {\n                    VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(hitCoord, 0.0, fill, stemLength)\n                    HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(hitCoord, hitShape.rect.width / 2, fill, stemLength)\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for RECT\")\n                }\n\n                PATH -> when (tooltipKind) {\n                    HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(hitCoord, 0.0, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for PATH\")\n                }\n\n                POLYGON -> when (tooltipKind) {\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for POLYGON\")\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.gcommon.collect.Lists\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nabstract class TransformedTargetLocator(private val targetLocator: GeomTargetLocator) :\n    GeomTargetLocator {\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        val targetCoord = convertToTargetCoord(coord)\n        val result = targetLocator.search(targetCoord) ?: return null\n        return convertLookupResult(result)\n    }\n\n    private fun convertLookupResult(lookupResult: GeomTargetLocator.LookupResult): GeomTargetLocator.LookupResult {\n        return GeomTargetLocator.LookupResult(\n                convertGeomTargets(lookupResult.targets),\n                convertToPlotDistance(lookupResult.distance),\n                lookupResult.geomKind,\n                lookupResult.contextualMapping,\n                lookupResult.contextualMapping.isCrosshairEnabled\n        )\n    }\n\n    private fun convertGeomTargets(geomTargets: List<GeomTarget>): List<GeomTarget> {\n        return ArrayList(Lists.transform(geomTargets) { geomTarget ->\n            GeomTarget(\n                geomTarget.hitIndex,\n                convertTipLayoutHint(geomTarget.tipLayoutHint),\n                convertTipLayoutHints(geomTarget.aesTipLayoutHints)\n            )\n        })\n    }\n\n    private fun convertTipLayoutHint(hint: TipLayoutHint): TipLayoutHint {\n        return TipLayoutHint(\n            hint.kind,\n            safeConvertToPlotCoord(hint.coord)!!,\n            convertToPlotDistance(hint.objectRadius),\n            hint.color,\n            hint.stemLength\n        )\n    }\n\n    private fun convertTipLayoutHints(tipLayoutHints: Map<Aes<*>, TipLayoutHint>): Map<Aes<*>, TipLayoutHint> {\n        val result = HashMap<Aes<*>, TipLayoutHint>()\n        tipLayoutHints.forEach { (aes, hint) -> result[aes] = convertTipLayoutHint(hint) }\n        return result\n    }\n\n    private fun safeConvertToPlotCoord(coord: DoubleVector?): DoubleVector? {\n        return if (coord == null) null else convertToPlotCoord(coord)\n    }\n\n    protected abstract fun convertToTargetCoord(coord: DoubleVector): DoubleVector\n\n    protected abstract fun convertToPlotCoord(coord: DoubleVector): DoubleVector\n\n    protected abstract fun convertToPlotDistance(distance: Double): Double\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\n\nclass AxisLayoutInfo private constructor(b: Builder) {\n    val axisBreaks: GuideBreaks?\n    val axisLength: Double\n    val orientation: jetbrains.datalore.plot.builder.guide.Orientation?\n    val axisDomain: ClosedRange<Double>?\n\n    val tickLabelsBounds: DoubleRectangle?\n    val tickLabelRotationAngle: Double\n    val tickLabelHorizontalAnchor: TextLabel.HorizontalAnchor?    // optional\n    val tickLabelVerticalAnchor: TextLabel.VerticalAnchor?        // optional\n    val tickLabelAdditionalOffsets: List<DoubleVector>?           // optional\n    val tickLabelSmallFont: Boolean\n    internal val tickLabelsBoundsMax: DoubleRectangle?                     // debug\n\n    init {\n        require(b.myAxisBreaks != null)\n        require(b.myOrientation != null)\n        require(b.myTickLabelsBounds != null)\n        require(b.myAxisDomain != null)\n\n        this.axisBreaks = b.myAxisBreaks\n        this.axisLength = b.myAxisLength\n        this.orientation = b.myOrientation\n        this.axisDomain = b.myAxisDomain\n\n        this.tickLabelsBounds = b.myTickLabelsBounds\n        this.tickLabelRotationAngle = b.myTickLabelRotationAngle\n        this.tickLabelHorizontalAnchor = b.myLabelHorizontalAnchor\n        this.tickLabelVerticalAnchor = b.myLabelVerticalAnchor\n        this.tickLabelAdditionalOffsets = b.myLabelAdditionalOffsets\n        this.tickLabelSmallFont = b.myTickLabelSmallFont\n        this.tickLabelsBoundsMax = b.myMaxTickLabelsBounds\n    }\n\n    fun withAxisLength(axisLength: Double): Builder {\n        //checkState(axisDomain != null);\n\n        val b = Builder()\n        b.myAxisBreaks = axisBreaks\n        b.myAxisLength = axisLength\n\n        b.myOrientation = this.orientation\n        b.myAxisDomain = this.axisDomain\n\n        b.myTickLabelsBounds = this.tickLabelsBounds\n        b.myTickLabelRotationAngle = this.tickLabelRotationAngle\n        b.myLabelHorizontalAnchor = this.tickLabelHorizontalAnchor\n        b.myLabelVerticalAnchor = this.tickLabelVerticalAnchor\n        b.myLabelAdditionalOffsets = this.tickLabelAdditionalOffsets\n        b.myTickLabelSmallFont = this.tickLabelSmallFont\n        b.myMaxTickLabelsBounds = this.tickLabelsBoundsMax\n        return b\n    }\n\n    fun axisBounds(): DoubleRectangle {\n        return tickLabelsBounds!!.union(DoubleRectangle(0.0, 0.0, 0.0, 0.0))\n    }\n\n    class Builder {\n        var myAxisLength: Double = 0.toDouble()\n        var myOrientation: jetbrains.datalore.plot.builder.guide.Orientation? = null\n        var myAxisDomain: ClosedRange<Double>? = null\n        var myMaxTickLabelsBounds: DoubleRectangle? = null\n        var myTickLabelSmallFont = false\n        var myLabelAdditionalOffsets: List<DoubleVector>? = null\n        var myLabelHorizontalAnchor: TextLabel.HorizontalAnchor? = null\n        var myLabelVerticalAnchor: TextLabel.VerticalAnchor? = null\n        var myTickLabelRotationAngle = 0.0\n        var myTickLabelsBounds: DoubleRectangle? = null\n        var myAxisBreaks: GuideBreaks? = null\n\n        fun build(): AxisLayoutInfo {\n            return AxisLayoutInfo(this)\n        }\n\n        fun axisLength(d: Double): Builder {\n            myAxisLength = d\n            return this\n        }\n\n        fun orientation(o: jetbrains.datalore.plot.builder.guide.Orientation): Builder {\n            myOrientation = o\n            return this\n        }\n\n        fun axisDomain(r: ClosedRange<Double>): Builder {\n            myAxisDomain = r\n            return this\n        }\n\n        fun tickLabelsBoundsMax(r: DoubleRectangle?): Builder {\n            myMaxTickLabelsBounds = r\n            return this\n        }\n\n        fun tickLabelSmallFont(b: Boolean): Builder {\n            myTickLabelSmallFont = b\n            return this\n        }\n\n        fun tickLabelAdditionalOffsets(labelAdditionalOffsets: List<DoubleVector>?): Builder {\n            myLabelAdditionalOffsets = labelAdditionalOffsets\n            return this\n        }\n\n        fun tickLabelHorizontalAnchor(labelHorizontalAnchor: TextLabel.HorizontalAnchor?): Builder {\n            myLabelHorizontalAnchor = labelHorizontalAnchor\n            return this\n        }\n\n        fun tickLabelVerticalAnchor(labelVerticalAnchor: TextLabel.VerticalAnchor?): Builder {\n            myLabelVerticalAnchor = labelVerticalAnchor\n            return this\n        }\n\n        fun tickLabelRotationAngle(rotationAngle: Double): Builder {\n            myTickLabelRotationAngle = rotationAngle\n            return this\n        }\n\n        fun tickLabelsBounds(rectangle: DoubleRectangle?): Builder {\n            myTickLabelsBounds = rectangle\n            return this\n        }\n\n        fun axisBreaks(breaks: GuideBreaks?): Builder {\n            myAxisBreaks = breaks\n            return this\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\n\nclass EmptyAxisLayout private constructor(xDomain: ClosedRange<Double>, yDomain: ClosedRange<Double>, private val myOrientation: jetbrains.datalore.plot.builder.guide.Orientation) :\n    AxisLayout {\n\n    private val myAxisDomain: ClosedRange<Double>\n\n    init {\n        myAxisDomain = if (myOrientation.isHorizontal) xDomain else yDomain\n    }\n\n    override fun initialThickness(): Double {\n        return 0.0\n    }\n\n    override fun doLayout(displaySize: DoubleVector, maxTickLabelsBoundsStretched: DoubleRectangle?): AxisLayoutInfo {\n        val axisLength = if (myOrientation.isHorizontal) displaySize.x else displaySize.y\n        val tickLabelsBounds = if (myOrientation.isHorizontal   // relative to axis component\n        )\n            DoubleRectangle(0.0, 0.0, axisLength, 0.0)\n        else\n            DoubleRectangle(0.0, 0.0, 0.0, axisLength)\n        val breaks = GuideBreaks(\n            emptyList<Any>(),\n            emptyList(),\n            emptyList()\n        )\n\n        val builder = AxisLayoutInfo.Builder()\n                .axisBreaks(breaks)\n                .axisLength(axisLength)\n                .orientation(myOrientation)\n                .axisDomain(myAxisDomain)\n                .tickLabelsBounds(tickLabelsBounds)\n\n        return builder.build()\n    }\n\n    companion object {\n        fun bottom(xDomain: ClosedRange<Double>, yDomain: ClosedRange<Double>): AxisLayout {\n            return EmptyAxisLayout(\n                xDomain,\n                yDomain,\n                jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\n            )\n        }\n\n        fun left(xDomain: ClosedRange<Double>, yDomain: ClosedRange<Double>): AxisLayout {\n            return EmptyAxisLayout(\n                xDomain,\n                yDomain,\n                jetbrains.datalore.plot.builder.guide.Orientation.LEFT\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.abs\n\ninternal class FacetGridPlotLayout(\n    private val facets: PlotFacets,\n    private val tileLayout: TileLayout\n) : PlotLayoutBase() {\n    private val totalPanelHorizontalPadding: Double = PANEL_PADDING * (facets.colCount - 1)\n    private val totalPanelVerticalPadding: Double = PANEL_PADDING * (facets.rowCount - 1)\n\n    init {\n        setPadding(10.0, 10.0, 0.0, 0.0)\n\n        require(facets.isDefined) { \"Undefined facets.\" }\n    }\n\n    override fun doLayout(preferredSize: DoubleVector): PlotLayoutInfo {\n        var tilesAreaSize = DoubleVector(\n            preferredSize.x - (paddingLeft + paddingRight),\n            preferredSize.y - (paddingTop + paddingBottom)\n        )\n\n        val facetTiles = facets.tileInfos()\n        val tileColLabCounts = facetTiles.firstOrNull { it.colLabs.isNotEmpty() }?.colLabs?.size ?: 0\n        val tileWithColLabInRowCount = facetTiles\n            .filter { it.colLabs.isNotEmpty() }\n            .distinctBy { it.row }.count()\n\n        val totalAddedHeight = facetColHeadHeight(tileColLabCounts) * tileWithColLabInRowCount\n\n        val labsInRow = if (facetTiles.any { it.rowLab != null }) 1 else 0\n        val labsTotalDim = DoubleVector(labsInRow * FACET_TAB_HEIGHT, totalAddedHeight)\n        tilesAreaSize = tilesAreaSize.subtract(labsTotalDim)\n\n        // rough estimate (without axis. The final size will be smaller)\n        val tileWidth = (tilesAreaSize.x - totalPanelHorizontalPadding) / facets.colCount\n        val tileHeight = (tilesAreaSize.y - totalPanelVerticalPadding) / facets.rowCount\n\n        // initial layout\n        var tileInfo = layoutTile(tileWidth, tileHeight)\n\n        // do 1 or 2 times\n        for (i in 0..1) {\n            // adjust geom size\n            val tilesAreaSizeNew = tilesAreaSize(tileInfo)\n            val widthDiff = tilesAreaSize.x - tilesAreaSizeNew.x\n            val heightDiff = tilesAreaSize.y - tilesAreaSizeNew.y\n\n            // error 1 px per tile is ok\n            if (abs(widthDiff) <= facets.colCount && abs(heightDiff) <= facets.rowCount) {\n                break\n            }\n\n            val geomWidth = tileInfo.geomWidth() + widthDiff / facets.colCount\n            val newPanelWidth = geomWidth + tileInfo.axisThicknessY()\n            val geomHeight = tileInfo.geomHeight() + heightDiff / facets.rowCount\n            val newPanelHeight = geomHeight + tileInfo.axisThicknessX()\n\n            // re-layout\n            tileInfo = layoutTile(newPanelWidth, newPanelHeight)\n        }\n\n        // create final plot tiles layout infos\n\n        val axisThicknessX = tileInfo.axisThicknessX()\n        val axisThicknessY = tileInfo.axisThicknessY()\n        val geomWidth = tileInfo.geomWidth()\n        val geomHeight = tileInfo.geomHeight()\n\n        var tilesAreaBounds = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        val tilesAreaOffset = DoubleVector(paddingLeft, paddingTop)\n        val tileInfos = ArrayList<TileLayoutInfo>()\n\n        var offsetX = 0.0\n        var offsetY = 0.0\n        var currRow = 0\n        var prevHeight = 0.0\n\n        for (facetTile in facetTiles) {\n            var width = geomWidth\n            var geomX = 0.0\n            if (facetTile.yAxis) {\n                width += axisThicknessY\n                geomX = axisThicknessY\n            }\n            if (facetTile.rowLab != null) {\n                width += FACET_TAB_HEIGHT\n            }\n\n            var height = geomHeight\n            var geomY: Double\n            if (facetTile.xAxis && facetTile.row == facets.rowCount - 1) {   // bottom row only\n                height += axisThicknessX\n            }\n            val addedHeight = facetColHeadHeight(facetTile.colLabs.size)\n            height += addedHeight\n            geomY = addedHeight\n\n            val bounds = DoubleRectangle(0.0, 0.0, width, height)\n            val geomBounds = DoubleRectangle(geomX, geomY, geomWidth, geomHeight)\n\n            val row = facetTile.row\n            if (row > currRow) {\n                currRow = row\n                offsetY += prevHeight + PANEL_PADDING\n            }\n            prevHeight = height\n\n            val col = facetTile.col\n            if (col == 0) {\n                offsetX = 0.0\n            }\n\n            val offset = DoubleVector(offsetX, offsetY)\n            offsetX += width + PANEL_PADDING\n\n            val info = TileLayoutInfo(\n                bounds,\n                geomBounds,\n                XYPlotLayoutUtil.clipBounds(geomBounds),\n                tileInfo.layoutInfo.xAxisInfo,\n                tileInfo.layoutInfo.yAxisInfo,\n                xAxisShown = facetTile.xAxis,\n                yAxisShown = facetTile.yAxis,\n                trueIndex = facetTile.trueIndex\n            )\n                .withOffset(tilesAreaOffset.add(offset))\n                .withFacetLabels(facetTile.colLabs, facetTile.rowLab)\n\n            tileInfos.add(info)\n\n            tilesAreaBounds = tilesAreaBounds.union(info.getAbsoluteBounds(tilesAreaOffset))\n        }\n\n        val plotSize = DoubleVector(\n            tilesAreaBounds.right + paddingRight,\n            tilesAreaBounds.height + paddingBottom\n        )\n\n        return PlotLayoutInfo(tileInfos, plotSize)\n    }\n\n    private fun layoutTile(tileWidth: Double, tileHeight: Double): MyTileInfo {\n        val layoutInfo = tileLayout.doLayout(DoubleVector(tileWidth, tileHeight))\n        return MyTileInfo(layoutInfo)\n    }\n\n    private fun tilesAreaSize(tileInfo: MyTileInfo): DoubleVector {\n        val w = tileInfo.geomWidth() * facets.colCount + totalPanelHorizontalPadding + tileInfo.axisThicknessY()\n        val h = tileInfo.geomHeight() * facets.rowCount + totalPanelVerticalPadding + tileInfo.axisThicknessX()\n        return DoubleVector(w, h)\n    }\n\n    private class MyTileInfo internal constructor(internal val layoutInfo: TileLayoutInfo) {\n\n        internal fun axisThicknessX(): Double {\n            return layoutInfo.bounds.bottom - layoutInfo.geomBounds.bottom\n        }\n\n        internal fun axisThicknessY(): Double {\n            return layoutInfo.geomBounds.left - layoutInfo.bounds.left\n        }\n\n        internal fun geomWidth(): Double {\n            return layoutInfo.geomBounds.width\n        }\n\n        internal fun geomHeight(): Double {\n            return layoutInfo.geomBounds.height\n        }\n    }\n\n    companion object {\n        const val FACET_TAB_HEIGHT = 30.0\n        const val FACET_H_PADDING = 0\n        const val FACET_V_PADDING = 6 //5\n\n        private const val PANEL_PADDING = 10.0\n\n        fun facetColLabelSize(colWidth: Double): DoubleVector {\n            return DoubleVector(colWidth - FACET_H_PADDING * 2, FACET_TAB_HEIGHT - FACET_V_PADDING * 2.0)\n        }\n\n        fun facetColHeadHeight(labCount: Int): Double {\n            return if (labCount > 0) {\n                facetColLabelSize(0.0).y * labCount + FACET_V_PADDING * 2\n            } else {\n                0.0\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\n\nobject GeometryUtil {\n    fun union(first: DoubleRectangle, optionalSecond: DoubleRectangle?): DoubleRectangle {\n        return if (optionalSecond == null) {\n            first\n        } else first.union(optionalSecond)\n    }\n\n    fun union(head: DoubleRectangle, c: Collection<DoubleRectangle>): DoubleRectangle {\n        var result = head\n        for (r in c) {\n            result = result.union(r)\n        }\n        return result\n    }\n\n    fun doubleRange(xRange: ClosedRange<Double>, yRange: ClosedRange<Double>): DoubleRectangle {\n        val xOrigin = xRange.lowerEnd\n        val yOrigin = yRange.lowerEnd\n        val xSpan = xRange.upperEnd - xRange.lowerEnd\n        val ySpan = yRange.upperEnd - yRange.lowerEnd\n        return DoubleRectangle(xOrigin, yOrigin, xSpan, ySpan)\n    }\n\n    fun changeWidth(r: DoubleRectangle, width: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.origin.y,\n                width,\n                r.dimension.y\n        )\n    }\n\n    fun changeWidthKeepRight(r: DoubleRectangle, width: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.right - width,\n                r.origin.y,\n                width,\n                r.dimension.y\n        )\n    }\n\n    fun changeHeight(r: DoubleRectangle, height: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.origin.y,\n                r.dimension.x,\n                height\n        )\n    }\n\n    fun changeHeightKeepBottom(r: DoubleRectangle, height: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.bottom - height,\n                r.dimension.x,\n                height\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nabstract class LegendBoxInfo protected constructor(internal val size: DoubleVector) {\n\n    open val isEmpty: Boolean\n        get() = false\n\n    abstract fun createLegendBox(): jetbrains.datalore.plot.builder.guide.LegendBox\n\n    companion object {\n        val EMPTY: LegendBoxInfo = object : LegendBoxInfo(DoubleVector.ZERO) {\n            override val isEmpty: Boolean\n                get() = true\n\n            override fun createLegendBox(): jetbrains.datalore.plot.builder.guide.LegendBox {\n                throw IllegalStateException(\"Empty legend box info\")\n            }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport kotlin.math.max\n\nclass LegendBoxesLayout(private val myPlotBounds: DoubleRectangle, private val myTheme: LegendTheme) {\n\n    fun doLayout(infos: List<LegendBoxInfo>): Result {\n        val legendPosition = myTheme.position()\n        val legendJustification = myTheme.justification()\n\n        // ToDo: theme legend.box option\n        val legendArrangement = jetbrains.datalore.plot.builder.guide.LegendArrangement.VERTICAL\n\n        val plotCenter = myPlotBounds.center\n        var plotInnerBoundsWithoutLegendBoxes = myPlotBounds\n\n        val boxWithLocationList = if (legendArrangement === jetbrains.datalore.plot.builder.guide.LegendArrangement.VERTICAL)\n            LegendBoxesLayoutUtil.verticalStack(infos)\n        else\n            LegendBoxesLayoutUtil.horizontalStack(infos)\n\n        val boxesSize =\n            LegendBoxesLayoutUtil.size(boxWithLocationList)\n\n        // adjust plot bounds\n        if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT || legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.RIGHT) {\n            val plotWidth = max(0.0, plotInnerBoundsWithoutLegendBoxes.width - boxesSize.x)\n            if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT) {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeWidthKeepRight(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotWidth\n                    )\n            } else {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeWidth(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotWidth\n                    )\n            }\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP || legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.BOTTOM) {\n            val plotHeight = max(0.0, plotInnerBoundsWithoutLegendBoxes.height - boxesSize.y)\n            if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP) {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeHeightKeepBottom(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotHeight\n                    )\n            } else {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeHeight(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotHeight\n                    )\n            }\n        }\n\n        val legendOrigin: DoubleVector\n        if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT) {\n            legendOrigin = DoubleVector(\n                    plotInnerBoundsWithoutLegendBoxes.left - boxesSize.x,\n                    plotCenter.y - boxesSize.y / 2)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.RIGHT) {\n            legendOrigin = DoubleVector(\n                    plotInnerBoundsWithoutLegendBoxes.right,\n                    plotCenter.y - boxesSize.y / 2)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP) {\n            legendOrigin = DoubleVector(\n                    plotCenter.x - boxesSize.x / 2,\n                    plotInnerBoundsWithoutLegendBoxes.top - boxesSize.y)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.BOTTOM) {\n            legendOrigin = DoubleVector(\n                    plotCenter.x - boxesSize.x / 2,\n                    plotInnerBoundsWithoutLegendBoxes.bottom)\n        } else {\n            legendOrigin =\n                LegendBoxesLayoutUtil.overlayLegendOrigin(\n                    plotInnerBoundsWithoutLegendBoxes,\n                    boxesSize,\n                    legendPosition,\n                    legendJustification\n                )\n        }\n\n        val resultBoxWithLocationList =\n            LegendBoxesLayoutUtil.moveAll(\n                legendOrigin,\n                boxWithLocationList\n            )\n        return Result(\n            plotInnerBoundsWithoutLegendBoxes,\n            resultBoxWithLocationList\n        )\n    }\n\n    class Result(val plotInnerBoundsWithoutLegendBoxes: DoubleRectangle, locations: List<BoxWithLocation>) {\n        val boxWithLocationList: List<BoxWithLocation> = ArrayList(locations)\n    }\n\n    class BoxWithLocation internal constructor(val legendBox: LegendBoxInfo, val location: DoubleVector) {\n\n        internal fun size(): DoubleVector {\n            return legendBox.size\n        }\n\n        internal fun bounds(): DoubleRectangle {\n            return DoubleRectangle(location, legendBox.size)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninternal object LegendBoxesLayoutUtil {\n    fun verticalStack(boxInfos: List<LegendBoxInfo>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        var y = 0.0\n        for (info in boxInfos) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    info,\n                    DoubleVector(0.0, y)\n                )\n            )\n            y += info.size.y\n        }\n        return result\n    }\n\n    fun horizontalStack(boxInfos: List<LegendBoxInfo>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        var x = 0.0\n        for (info in boxInfos) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    info,\n                    DoubleVector(x, 0.0)\n                )\n            )\n            x += info.size.x\n        }\n        return result\n    }\n\n    fun moveAll(delta: DoubleVector, boxWithLocationList: List<LegendBoxesLayout.BoxWithLocation>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        for (boxWithLocation in boxWithLocationList) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    boxWithLocation.legendBox,\n                    boxWithLocation.location.add(delta)\n                )\n            )\n        }\n        return result\n    }\n\n    fun size(boxWithLocationList: List<LegendBoxesLayout.BoxWithLocation>): DoubleVector {\n        var bounds: DoubleRectangle? = null\n        for (boxWithLocation in boxWithLocationList) {\n            bounds = bounds?.union(boxWithLocation.bounds()) ?: boxWithLocation.bounds()\n        }\n\n        return bounds?.dimension ?: DoubleVector.ZERO\n    }\n\n    fun overlayLegendOrigin(\n        plotBounds: DoubleRectangle, legendSize: DoubleVector, legendPosition: jetbrains.datalore.plot.builder.guide.LegendPosition, legendJustification: jetbrains.datalore.plot.builder.guide.LegendJustification\n    ): DoubleVector {\n        val plotSize = plotBounds.dimension\n\n        // [0,0] -> bottom-left, [1,1] -> top, right\n        val absolutePosition = DoubleVector(\n                plotBounds.left + plotSize.x * legendPosition.x,\n                plotBounds.bottom - plotSize.y * legendPosition.y\n        )\n\n        // legendJustification: [0,0] -> bottom-left, [1,1] -> top, right\n        val originOffset = DoubleVector(\n                -legendSize.x * legendJustification.x,\n                legendSize.y * legendJustification.y - legendSize.y\n        )\n\n        return absolutePosition.add(originOffset)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MIN_SIZE\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.clipBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.geomBounds\n\ninternal class LiveMapTileLayout : TileLayout {\n\n    override fun doLayout(preferredSize: DoubleVector): TileLayoutInfo {\n        var geomBounds = geomBounds(\n            0.0,\n            0.0,\n            preferredSize\n        )\n        geomBounds = geomBounds.union(\n            DoubleRectangle(\n                geomBounds.origin,\n                GEOM_MIN_SIZE\n            )\n        )\n        val geomWithAxisBounds = geomBounds\n        return TileLayoutInfo(\n            geomWithAxisBounds,\n            geomBounds,\n            clipBounds(geomBounds),\n            null, null,\n            trueIndex = 0\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksUtil\nimport jetbrains.datalore.plot.builder.layout.axis.AxisLayouter\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nclass PlotAxisLayout private constructor(\n    private val scale: Scale<Double>,\n    private val domainX: ClosedRange<Double>,\n    private val domainY: ClosedRange<Double>,\n    private val coordProvider: CoordProvider,\n    private val theme: AxisTheme,\n    private val orientation: Orientation\n) : AxisLayout {\n\n    override fun initialThickness(): Double {\n        if (theme.showTickMarks() || theme.showTickLabels()) {\n            val v = theme.tickLabelDistance()\n            return if (theme.showTickLabels()) {\n                v + initialTickLabelSize(orientation)\n            } else {\n                v\n            }\n        }\n        return 0.0\n    }\n\n    override fun doLayout(displaySize: DoubleVector, maxTickLabelsBoundsStretched: DoubleRectangle?): AxisLayoutInfo {\n        val layouter = createLayouter(displaySize)\n        return layouter.doLayout(\n            axisLength(displaySize, orientation),\n            maxTickLabelsBoundsStretched\n        )\n    }\n\n    private fun createLayouter(displaySize: DoubleVector): AxisLayouter {\n        val domains = coordProvider.adjustDomains(domainX, domainY, displaySize)\n        val axisDomain = axisDomain(\n            domains,\n            orientation\n        )\n\n        val breaksProvider = AxisBreaksUtil.createAxisBreaksProvider(scale, axisDomain)\n        return AxisLayouter.create(orientation, axisDomain, breaksProvider, theme)\n    }\n\n    companion object {\n        private val TICK_LABEL_SPEC = PlotLabelSpec.AXIS_TICK\n\n        fun bottom(\n            scale: Scale<Double>,\n            xDomain: ClosedRange<Double>,\n            yDomain: ClosedRange<Double>,\n            coordProvider: CoordProvider,\n            theme: AxisTheme\n        ): AxisLayout {\n            return PlotAxisLayout(\n                scale, xDomain, yDomain, coordProvider,\n                theme,\n                Orientation.BOTTOM\n            )\n        }\n\n        fun left(\n            scale: Scale<Double>,\n            xDomain: ClosedRange<Double>,\n            yDomain: ClosedRange<Double>,\n            coordProvider: CoordProvider,\n            theme: AxisTheme\n        ): AxisLayout {\n            return PlotAxisLayout(\n                scale, xDomain, yDomain, coordProvider,\n                theme,\n                Orientation.LEFT\n            )\n        }\n\n        private fun initialTickLabelSize(orientation: Orientation): Double {\n            return if (orientation.isHorizontal)\n                TICK_LABEL_SPEC.height()\n            else\n                TICK_LABEL_SPEC.width(1)\n        }\n\n        private fun axisLength(displaySize: DoubleVector, orientation: Orientation): Double {\n            return if (orientation.isHorizontal)\n                displaySize.x\n            else\n                displaySize.y\n        }\n\n        private fun axisDomain(\n            xyDomains: Pair<ClosedRange<Double>, ClosedRange<Double>>,\n            orientation: Orientation\n        ): ClosedRange<Double> {\n            return if (orientation.isHorizontal)\n                xyDomains.first\n            else\n                xyDomains.second\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\ninternal abstract class PlotLayoutBase : PlotLayout {\n    protected var paddingTop: Double = 0.0\n        private set\n    protected var paddingRight: Double = 0.0\n        private set\n    protected var paddingBottom: Double = 0.0\n        private set\n    protected var paddingLeft: Double = 0.0\n        private set\n\n    override fun setPadding(top: Double, right: Double, bottom: Double, left: Double) {\n        paddingTop = top\n        paddingRight = right\n        paddingBottom = bottom\n        paddingLeft = left\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nclass PlotLayoutInfo(tiles: List<TileLayoutInfo>, val size: DoubleVector) {\n    val tiles: List<TileLayoutInfo> = ArrayList(tiles)\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.base.Strings.isNullOrEmpty\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\n\nobject PlotLayoutUtil {\n    const val AXIS_TITLE_OUTER_MARGIN = 4.0\n    const val AXIS_TITLE_INNER_MARGIN = 4.0\n    private const val TITLE_V_MARGIN = 4.0\n    private val LIVE_MAP_PLOT_PADDING = DoubleVector(10.0, 0.0)\n    private val LIVE_MAP_PLOT_MARGIN = DoubleVector(10.0, 10.0)\n\n    fun titleDimensions(text: String): DoubleVector {\n        if (isNullOrEmpty(text)) {\n            return DoubleVector.ZERO\n        }\n\n        val labelSpec = PlotLabelSpec.PLOT_TITLE\n        return DoubleVector(\n            labelSpec.width(text.length),\n            labelSpec.height() + 2 * TITLE_V_MARGIN\n        )\n    }\n\n    fun axisTitleDimensions(text: String): DoubleVector {\n        if (isNullOrEmpty(text)) {\n            return DoubleVector.ZERO\n        }\n\n        val labelSpec = PlotLabelSpec.AXIS_TITLE\n        return DoubleVector(\n            labelSpec.width(text.length),\n            labelSpec.height()\n        )\n    }\n\n    fun absoluteGeomBounds(origin: DoubleVector, plotLayoutInfo: PlotLayoutInfo): DoubleRectangle {\n        require(plotLayoutInfo.tiles.isNotEmpty()) { \"Plot is empty\" }\n\n        var result: DoubleRectangle? = null\n        for (tile in plotLayoutInfo.tiles) {\n            val geomBounds = tile.getAbsoluteGeomBounds(origin)\n            result = result?.union(geomBounds) ?: geomBounds\n        }\n        return result!!\n    }\n\n    fun liveMapBounds(container: DoubleRectangle): DoubleRectangle {\n        return DoubleRectangle(\n            container.origin.add(LIVE_MAP_PLOT_PADDING),\n            container.dimension.subtract(LIVE_MAP_PLOT_MARGIN)\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninternal class SingleTilePlotLayout(private val myTileLayout: TileLayout) : PlotLayoutBase() {\n\n    init {\n        setPadding(10.0, 10.0, 0.0, 0.0)\n    }\n\n    override fun doLayout(preferredSize: DoubleVector): PlotLayoutInfo {\n        val tilePreferredSize = DoubleVector(\n                preferredSize.x - (paddingLeft + paddingRight),\n                preferredSize.y - (paddingTop + paddingBottom))\n\n        var tileInfo = myTileLayout.doLayout(tilePreferredSize)\n        tileInfo = tileInfo.withOffset(DoubleVector(paddingLeft, paddingTop))\n\n        var plotSize = tileInfo.bounds.dimension\n        plotSize = plotSize.add(DoubleVector(paddingRight, paddingBottom))\n\n        return PlotLayoutInfo(listOf(tileInfo), plotSize)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nclass TileLayoutInfo private constructor(\n    // 'plot' means : geom area + axis (but not titles, facet labels or legends)\n    val plotOrigin: DoubleVector,     // tile 'plot' origin relative to overall 'plot' origin\n\n    // relative to plot tile\n    val bounds: DoubleRectangle,      // plotting area + optional elements (axis, axis tick labels)\n    val geomBounds: DoubleRectangle,  // actual plotting area\n    val clipBounds: DoubleRectangle,  // geom shapes outside this bounds will be cut-off\n\n    // Params xAxisInfo/yAxisInfo can be NULL.\n    // In this case any mapping of positional Aes should be dropped (live map plot).\n    val xAxisInfo: AxisLayoutInfo?,\n    val yAxisInfo: AxisLayoutInfo?,\n\n    xAxisShown: Boolean,\n    yAxisShown: Boolean,\n\n    val facetXLabels: List<String>,\n    val facetYLabel: String?,\n\n    val trueIndex: Int     // tile index before re-ordering (in facet wrap)\n) {\n    val xAxisShown: Boolean = xAxisInfo != null && xAxisShown\n    val yAxisShown: Boolean = yAxisInfo != null && yAxisShown\n\n    constructor(\n        bounds: DoubleRectangle,\n        geomBounds: DoubleRectangle,\n        clipBounds: DoubleRectangle,\n        xAxisInfo: AxisLayoutInfo?,\n        yAxisInfo: AxisLayoutInfo?,\n        xAxisShown: Boolean = true,\n        yAxisShown: Boolean = true,\n        trueIndex: Int\n    ) : this(\n        DoubleVector.ZERO,\n        bounds,\n        geomBounds,\n        clipBounds,\n        xAxisInfo,\n        yAxisInfo,\n        xAxisShown = xAxisShown,\n        yAxisShown = yAxisShown,\n        facetXLabels = emptyList(),\n        facetYLabel = null,\n        trueIndex\n    )\n\n    fun withOffset(offset: DoubleVector): TileLayoutInfo {\n        return TileLayoutInfo(\n            offset,\n            bounds,\n            geomBounds,\n            clipBounds,\n            xAxisInfo, yAxisInfo,\n            xAxisShown, yAxisShown,\n            facetXLabels, facetYLabel,\n            trueIndex\n        )\n    }\n\n    fun getAbsoluteBounds(tilesOrigin: DoubleVector): DoubleRectangle {\n        val offset = tilesOrigin.add(plotOrigin)\n        return bounds.add(offset)\n    }\n\n    fun getAbsoluteGeomBounds(tilesOrigin: DoubleVector): DoubleRectangle {\n        val offset = tilesOrigin.add(plotOrigin)\n        return geomBounds.add(offset)\n    }\n\n    fun withFacetLabels(xLabels: List<String>, yLabel: String?): TileLayoutInfo {\n        return TileLayoutInfo(\n            this.plotOrigin,\n            this.bounds,\n            this.geomBounds,\n            this.clipBounds,\n            this.xAxisInfo, this.yAxisInfo,\n            this.xAxisShown, this.yAxisShown,\n            xLabels, yLabel,\n            trueIndex\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation\n\ninternal object XYPlotLayoutUtil {\n    const val GEOM_MARGIN = 0.0          // min space around geom area\n    private const val CLIP_EXTEND = 5.0\n    val GEOM_MIN_SIZE = DoubleVector(50.0, 50.0)\n\n    fun geomBounds(xAxisThickness: Double, yAxisThickness: Double, plotSize: DoubleVector): DoubleRectangle {\n        val marginLeftTop = DoubleVector(yAxisThickness, GEOM_MARGIN)\n        val marginRightBottom = DoubleVector(GEOM_MARGIN, xAxisThickness)\n        var geomSize = plotSize\n            .subtract(marginLeftTop)\n            .subtract(marginRightBottom)\n\n        if (geomSize.x < GEOM_MIN_SIZE.x) {\n            geomSize = DoubleVector(GEOM_MIN_SIZE.x, geomSize.y)\n        }\n        if (geomSize.y < GEOM_MIN_SIZE.y) {\n            geomSize = DoubleVector(geomSize.x, GEOM_MIN_SIZE.y)\n        }\n        return DoubleRectangle(marginLeftTop, geomSize)\n    }\n\n    fun clipBounds(geomBounds: DoubleRectangle): DoubleRectangle {\n        return DoubleRectangle(\n            geomBounds.origin.subtract(\n                DoubleVector(\n                    CLIP_EXTEND,\n                    CLIP_EXTEND\n                )\n            ),\n            DoubleVector(\n                geomBounds.dimension.x + 2 * CLIP_EXTEND,\n                geomBounds.dimension.y + 2 * CLIP_EXTEND\n            )\n        )\n    }\n\n    fun maxTickLabelsBounds(\n        axisOrientation: Orientation,\n        stretch: Double,\n        geomBounds: DoubleRectangle,\n        plotSize: DoubleVector\n    ): DoubleRectangle {\n        val geomPaddung = 10.0          // min space around geom area (labels should not touch geom area).\n\n        val maxGeomBounds = DoubleRectangle(\n            geomPaddung, geomPaddung,\n            plotSize.x - 2 * geomPaddung,\n            plotSize.y - 2 * geomPaddung\n        )\n        when (axisOrientation) {\n            Orientation.TOP,\n            Orientation.BOTTOM -> {\n                val leftSpace = geomBounds.left - maxGeomBounds.left + stretch\n                val rightSpace = maxGeomBounds.right - geomBounds.right + stretch\n\n                val height = 1E42   // just very large number\n                val top = when (axisOrientation) {\n                    Orientation.TOP -> -height\n                    else -> 0.0\n                }\n\n                val left = -leftSpace\n                val width = leftSpace + rightSpace + geomBounds.width\n                return DoubleRectangle(left, top, width, height)\n            }\n\n            else -> throw IllegalArgumentException(\"Orientation not supported: $axisOrientation\")\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MARGIN\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MIN_SIZE\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.clipBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.geomBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.maxTickLabelsBounds\n\ninternal class XYPlotTileLayout(\n    private val xAxisLayout: AxisLayout,\n    private val yAxisLayout: AxisLayout\n) : TileLayout {\n\n    override fun doLayout(preferredSize: DoubleVector): TileLayoutInfo {\n\n        var (xAxisInfo, yAxisInfo) = computeAxisInfos(\n            xAxisLayout,\n            yAxisLayout,\n            preferredSize\n        )\n\n        var geomBounds = geomBounds(\n            xAxisThickness = xAxisInfo.axisBounds().dimension.y,\n            yAxisThickness = yAxisInfo.axisBounds().dimension.x,\n            preferredSize\n        )\n\n        // X-axis labels bounds may exceed axis length - adjust\n        run {\n            val maxTickLabelsBounds = maxTickLabelsBounds(\n                Orientation.BOTTOM,\n                0.0,\n                geomBounds,\n                preferredSize\n            )\n            val tickLabelsBounds = xAxisInfo.tickLabelsBounds\n            val leftOverflow = maxTickLabelsBounds.left - tickLabelsBounds!!.origin.x\n            val rightOverflow = tickLabelsBounds.origin.x + tickLabelsBounds.dimension.x - maxTickLabelsBounds.right\n            if (leftOverflow > 0) {\n                geomBounds = DoubleRectangle(\n                    geomBounds.origin.x + leftOverflow,\n                    geomBounds.origin.y,\n                    geomBounds.dimension.x - leftOverflow,\n                    geomBounds.dimension.y\n                )\n            }\n            if (rightOverflow > 0) {\n                geomBounds = DoubleRectangle(\n                    geomBounds.origin.x,\n                    geomBounds.origin.y,\n                    geomBounds.dimension.x - rightOverflow,\n                    geomBounds.dimension.y\n                )\n            }\n        }\n\n        geomBounds = geomBounds.union(\n            DoubleRectangle(geomBounds.origin, GEOM_MIN_SIZE)\n        )\n\n        // Combine geom area and x/y axis\n        val geomWithAxisBounds =\n            tileBounds(\n                xAxisInfo.axisBounds(),\n                yAxisInfo.axisBounds(),\n                geomBounds\n            )\n\n        // sync axis info with new (may be) geom area size\n        xAxisInfo = xAxisInfo.withAxisLength(geomBounds.width).build()\n        yAxisInfo = yAxisInfo.withAxisLength(geomBounds.height).build()\n\n        return TileLayoutInfo(\n            geomWithAxisBounds,\n            geomBounds,\n            clipBounds(geomBounds),\n            xAxisInfo,\n            yAxisInfo,\n            trueIndex = 0\n        )\n    }\n\n    companion object {\n        private const val AXIS_STRETCH_RATIO = 0.1  // allow 10% axis flexibility (on each end)\n\n        private fun tileBounds(\n            xAxisBounds: DoubleRectangle,\n            yAxisBounds: DoubleRectangle,\n            geomBounds: DoubleRectangle\n        ): DoubleRectangle {\n            // Can't just union bounds because\n            // x-axis has zero origin\n            // y-axis has negative origin\n            val leftTop = DoubleVector(\n                geomBounds.left - yAxisBounds.width,\n                geomBounds.top - GEOM_MARGIN\n            )\n            val rightBottom = DoubleVector(\n                geomBounds.right + GEOM_MARGIN,\n                geomBounds.bottom + xAxisBounds.height\n            )\n            return DoubleRectangle(leftTop, rightBottom.subtract(leftTop))\n        }\n\n        private fun computeAxisInfos(\n            xAxisLayout: AxisLayout,\n            yAxisLayout: AxisLayout,\n            plotSize: DoubleVector\n        ): Pair<AxisLayoutInfo, AxisLayoutInfo> {\n            val xAxisThickness = xAxisLayout.initialThickness()\n            var yAxisInfo = computeYAxisInfo(\n                yAxisLayout,\n                geomBounds(\n                    xAxisThickness,\n                    yAxisLayout.initialThickness(),\n                    plotSize\n                )\n            )\n\n            val yAxisThickness = yAxisInfo.axisBounds().dimension.x\n            var xAxisInfo = computeXAxisInfo(\n                xAxisLayout,\n                plotSize, geomBounds(\n                    xAxisThickness,\n                    yAxisThickness,\n                    plotSize\n                )\n            )\n\n            if (xAxisInfo.axisBounds().dimension.y > xAxisThickness) {\n                // Re-layout y-axis if x-axis became thicker than its 'original thickness'.\n                yAxisInfo = computeYAxisInfo(\n                    yAxisLayout,\n                    geomBounds(\n                        xAxisInfo.axisBounds().dimension.y,\n                        yAxisThickness,\n                        plotSize\n                    )\n                )\n            }\n\n            return Pair(xAxisInfo, yAxisInfo)\n        }\n\n        private fun computeXAxisInfo(\n            axisLayout: AxisLayout,\n            plotSize: DoubleVector,\n            geomBounds: DoubleRectangle\n        ): AxisLayoutInfo {\n            val axisLength = geomBounds.dimension.x\n            val stretch = axisLength * AXIS_STRETCH_RATIO\n            val maxTickLabelsBounds = maxTickLabelsBounds(\n                Orientation.BOTTOM,\n                stretch,\n                geomBounds,\n                plotSize\n            )\n            return axisLayout.doLayout(geomBounds.dimension, maxTickLabelsBounds)\n        }\n\n        private fun computeYAxisInfo(\n            axisLayout: AxisLayout,\n            geomBounds: DoubleRectangle\n        ): AxisLayoutInfo {\n            return axisLayout.doLayout(geomBounds.dimension, null)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\n\ninternal class AdaptableAxisBreaksProvider(\n    private val domainAfterTransform: ClosedRange<Double>,\n    private val breaksGenerator: BreaksGenerator\n) : AxisBreaksProvider {\n\n    override val isFixedBreaks: Boolean\n        get() = false\n\n    override val fixedBreaks: GuideBreaks\n        get() = throw IllegalStateException(\"Not a fixed breaks provider\")\n\n    override fun getBreaks(targetCount: Int, axisLength: Double): GuideBreaks {\n        val scaleBreaks = breaksGenerator.generateBreaks(domainAfterTransform, targetCount)\n        return GuideBreaks(\n            scaleBreaks.domainValues,\n            scaleBreaks.transformValues,\n            scaleBreaks.labels\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil.breaksTransformed\nimport jetbrains.datalore.plot.base.scale.ScaleUtil.labels\n\nobject AxisBreaksUtil {\n    fun createAxisBreaksProvider(scale: Scale<Double>, axisDomain: ClosedRange<Double>): AxisBreaksProvider = when {\n        scale.hasBreaks() -> FixedAxisBreaksProvider(\n            scale.breaks,\n            breaksTransformed(scale),\n            labels(scale)\n        )\n        else -> AdaptableAxisBreaksProvider(\n            axisDomain,\n            scale.breaksGenerator\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nabstract class AxisLayouter protected constructor(val orientation: jetbrains.datalore.plot.builder.guide.Orientation, val domainRange: ClosedRange<Double>, val labelsLayout: AxisLabelsLayout) {\n\n    fun doLayout(axisLength: Double, maxTickLabelsBounds: DoubleRectangle?): AxisLayoutInfo {\n        val labelsInfo = labelsLayout.doLayout(axisLength, toAxisMapper(axisLength), maxTickLabelsBounds)\n        val labelsBounds = labelsInfo.bounds\n\n        val builder = AxisLayoutInfo.Builder()\n                .axisBreaks(labelsInfo.breaks)\n                .axisLength(axisLength)\n                .orientation(orientation)\n                .axisDomain(domainRange)\n                .tickLabelsBoundsMax(maxTickLabelsBounds)\n                // todo: add 1 labels info object\n                .tickLabelSmallFont(labelsInfo.smallFont)\n                .tickLabelAdditionalOffsets(labelsInfo.labelAdditionalOffsets)\n                .tickLabelHorizontalAnchor(labelsInfo.labelHorizontalAnchor)\n                .tickLabelVerticalAnchor(labelsInfo.labelVerticalAnchor)\n                .tickLabelRotationAngle(labelsInfo.labelRotationAngle)\n                .tickLabelsBounds(labelsBounds)\n\n        return builder.build()\n    }\n\n    protected abstract fun toAxisMapper(axisLength: Double): (Double?) -> Double?\n\n    protected fun toScaleMapper(axisLength: Double): (Double?) -> Double? {\n        return Mappers.mul(domainRange, axisLength)\n    }\n\n    companion object {\n        fun create(orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n                   axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme): AxisLayouter {\n\n            if (orientation.isHorizontal) {\n                val labelsLayout: AxisLabelsLayout\n                if (breaksProvider.isFixedBreaks) {\n                    labelsLayout = AxisLabelsLayout.horizontalFixedBreaks(orientation, axisDomain, breaksProvider.fixedBreaks, theme)\n                } else {\n                    labelsLayout = AxisLabelsLayout.horizontalFlexBreaks(orientation, axisDomain, breaksProvider, theme)\n                }\n                return HorizontalAxisLayouter(\n                    orientation,\n                    axisDomain,\n                    labelsLayout\n                )\n            }\n\n            // vertical\n            val labelsLayout: AxisLabelsLayout\n            if (breaksProvider.isFixedBreaks) {\n                labelsLayout = AxisLabelsLayout.verticalFixedBreaks(orientation, axisDomain, breaksProvider.fixedBreaks, theme)\n            } else {\n                labelsLayout = AxisLabelsLayout.verticalFlexBreaks(orientation, axisDomain, breaksProvider, theme)\n            }\n            return VerticalAxisLayouter(\n                orientation,\n                axisDomain,\n                labelsLayout\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nclass FixedAxisBreaksProvider(domainBreaks: List<Any>, transformedBreaks: List<Double>, labels: List<String>) :\n    AxisBreaksProvider {\n    override val fixedBreaks: GuideBreaks =\n        GuideBreaks(\n            domainBreaks,\n            transformedBreaks,\n            labels\n        )\n\n    override val isFixedBreaks: Boolean\n        get() = true\n\n    override fun getBreaks(targetCount: Int, axisLength: Double): GuideBreaks {\n        return fixedBreaks\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nclass GuideBreaks(domainValues: List<Any>, transformedValues: List<Double>, labels: List<String>) {\n    val domainValues: List<Any>\n    val transformedValues: List<Double>\n    val labels: List<String>\n\n    val isEmpty: Boolean\n        get() = transformedValues.isEmpty()\n\n    init {\n        require(domainValues.size == transformedValues.size)\n        { \"Scale breaks size: \" + domainValues.size + \" transformed size: \" + transformedValues.size + \" but expected to be the same\" }\n        require(domainValues.size == labels.size)\n        { \"Scale breaks size: \" + domainValues.size + \" labels size: \" + labels.size + \" but expected to be the same\" }\n        this.domainValues = ArrayList(domainValues)\n        this.transformedValues = ArrayList(transformedValues)\n        this.labels = ArrayList(labels)\n    }\n\n    fun size(): Int {\n        return transformedValues.size\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\n\nclass HorizontalAxisLayouter(orientation: jetbrains.datalore.plot.builder.guide.Orientation, domainRange: ClosedRange<Double>, labelsLayout: AxisLabelsLayout) : AxisLayouter(orientation, domainRange, labelsLayout) {\n\n    override fun toAxisMapper(axisLength: Double): (Double?) -> Double? {\n        val scaleMapper = toScaleMapper(axisLength)\n        val cartesianX = Coords.toClientOffsetX(ClosedRange(0.0, axisLength))\n        return { v ->\n            val mapped = scaleMapper(v)\n            if (mapped != null) cartesianX(mapped) else null\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\n\nclass VerticalAxisLayouter(orientation: jetbrains.datalore.plot.builder.guide.Orientation, domainRange: ClosedRange<Double>, labelsLayout: AxisLabelsLayout) : AxisLayouter(orientation, domainRange, labelsLayout) {\n\n    override fun toAxisMapper(axisLength: Double): (Double?) -> Double? {\n        val scaleMapper = toScaleMapper(axisLength)\n        val cartesianY = Coords.toClientOffsetY(ClosedRange(0.0, axisLength))\n        return { v ->\n            val mapped = scaleMapper(v)\n            if (mapped != null) cartesianY(mapped) else null\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal abstract class AbstractFixedBreaksLabelsLayout(orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n                                                        axisDomain: ClosedRange<Double>, labelSpec: PlotLabelSpec, protected val breaks: GuideBreaks, theme: AxisTheme) : AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    private fun labelBounds(labelLocation: DoubleVector, labelLength: Int): DoubleRectangle {\n        val dim = labelSpec.dimensions(labelLength)\n        val labelBounds = labelBounds(dim)\n        return labelBounds.add(labelLocation)\n    }\n\n    protected abstract fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle\n\n    fun labelsBounds(\n        tickPositions: List<Double>,\n        @Suppress(\"UNUSED_PARAMETER\") tickLabels: List<String>,\n        toTickLocation: (Double) -> DoubleVector\n    ): DoubleRectangle? {\n        val boundsList = labelBoundsList(tickPositions, breaks.labels, toTickLocation)\n        var bounds: DoubleRectangle? = null\n        for (labelBounds in boundsList) {\n            bounds = GeometryUtil.union(labelBounds, bounds)\n        }\n        return bounds\n    }\n\n    fun labelBoundsList(tickPositions: List<Double>, tickLabels: List<String>, toTickLocation: (Double) -> DoubleVector): List<DoubleRectangle> {\n        val result = ArrayList<DoubleRectangle>()\n        val labels = tickLabels.iterator()\n        for (pos in tickPositions) {\n            val label = labels.next()\n            val bounds = labelBounds(toTickLocation(pos), label.length)\n            result.add(bounds)\n        }\n        return result\n    }\n\n\n    fun createAxisLabelsLayoutInfoBuilder(bounds: DoubleRectangle, overlap: Boolean): AxisLabelsLayoutInfo.Builder {\n        return AxisLabelsLayoutInfo.Builder()\n                .breaks(breaks)\n                .bounds(applyLabelsOffset(bounds))\n                .smallFont(false)\n                .overlap(overlap)\n    }\n\n    fun noLabelsLayoutInfo(axisLength: Double, orientation: jetbrains.datalore.plot.builder.guide.Orientation): AxisLabelsLayoutInfo {\n        if (orientation.isHorizontal) {\n            var bounds = DoubleRectangle(axisLength / 2, 0.0, 0.0, 0.0) // empty bounds in the middle of the axis;\n            bounds = applyLabelsOffset(bounds)\n            return AxisLabelsLayoutInfo.Builder()\n                    .breaks(breaks)\n                    .bounds(bounds)\n                    .smallFont(false)\n                    .overlap(false)\n                    .labelAdditionalOffsets(null)\n                    .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                    .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n                    .build()\n        }\n\n        throw IllegalStateException(\"Not implemented for $orientation\")\n    }\n\n    companion object {\n        val HORIZONTAL_TICK_LOCATION = { x: Double -> DoubleVector(x, 0.0) }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nabstract class AxisLabelsLayout protected constructor(\n    val orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    val axisDomain: ClosedRange<Double>,\n    val labelSpec: PlotLabelSpec,\n    val theme: AxisTheme\n) {\n\n    protected val isHorizontal: Boolean\n        get() = orientation.isHorizontal\n\n    abstract fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo\n\n    internal fun mapToAxis(\n        breaks: List<Double>,\n        axisMapper: (Double?) -> Double?\n    ): List<Double> {\n\n        return BreakLabelsLayoutUtil.mapToAxis(\n            breaks,\n            axisDomain,\n            axisMapper\n        )\n    }\n\n    internal fun applyLabelsOffset(labelsBounds: DoubleRectangle): DoubleRectangle {\n        return BreakLabelsLayoutUtil.applyLabelsOffset(\n            labelsBounds,\n            theme.tickLabelDistance(),\n            orientation\n        )\n    }\n\n    companion object {\n        val TICK_LABEL_SPEC = PlotLabelSpec.AXIS_TICK\n        val INITIAL_TICK_LABEL_LENGTH = 4 // symbols\n        val MIN_TICK_LABEL_DISTANCE = 20.0  // px\n        val TICK_LABEL_SPEC_SMALL = PlotLabelSpec.AXIS_TICK_SMALL\n\n        fun horizontalFlexBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(orientation.isHorizontal) { orientation.toString() }\n            require(!breaksProvider.isFixedBreaks) { \"fixed breaks\" }\n            return HorizontalFlexBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaksProvider,\n                theme\n            )\n        }\n\n        fun horizontalFixedBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaks: GuideBreaks, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(orientation.isHorizontal) { orientation.toString() }\n            return HorizontalFixedBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaks,\n                theme\n            )\n        }\n\n        fun verticalFlexBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(!orientation.isHorizontal) { orientation.toString() }\n            require(!breaksProvider.isFixedBreaks) { \"fixed breaks\" }\n            return VerticalFlexBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaksProvider,\n                theme\n            )\n        }\n\n        fun verticalFixedBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>,\n            breaks: GuideBreaks,\n            theme: AxisTheme\n        ): AxisLabelsLayout {\n            require(!orientation.isHorizontal) { orientation.toString() }\n            return VerticalFixedBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaks,\n                theme\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\n\nclass AxisLabelsLayoutInfo private constructor(b: Builder) {\n    val breaks: GuideBreaks?\n    val bounds: DoubleRectangle?\n    val smallFont: Boolean\n    val labelAdditionalOffsets: List<DoubleVector>?\n    val labelHorizontalAnchor: TextLabel.HorizontalAnchor?\n    val labelVerticalAnchor: TextLabel.VerticalAnchor?\n    val labelRotationAngle: Double\n    internal val isOverlap: Boolean\n\n\n    init {\n        this.breaks = b.myBreaks\n        this.smallFont = b.mySmallFont\n        this.bounds = b.myBounds\n        this.isOverlap = b.myOverlap\n        this.labelAdditionalOffsets = if (b.myLabelAdditionalOffsets == null)\n            null\n        else\n            ArrayList(b.myLabelAdditionalOffsets!!)\n        this.labelHorizontalAnchor = b.myLabelHorizontalAnchor\n        this.labelVerticalAnchor = b.myLabelVerticalAnchor\n        this.labelRotationAngle = b.myLabelRotationAngle\n    }\n\n    class Builder {\n        internal var myBreaks: GuideBreaks? = null\n        internal var myBounds: DoubleRectangle? = null\n        internal var mySmallFont: Boolean = false\n        internal var myOverlap: Boolean = false\n        internal var myLabelAdditionalOffsets: List<DoubleVector>? = null\n        internal var myLabelHorizontalAnchor: TextLabel.HorizontalAnchor? = null\n        internal var myLabelVerticalAnchor: TextLabel.VerticalAnchor? = null\n        internal var myLabelRotationAngle = 0.0\n\n        fun breaks(breaks: GuideBreaks): Builder {\n            myBreaks = breaks\n            return this\n        }\n\n        fun bounds(bounds: DoubleRectangle): Builder {\n            myBounds = bounds\n            return this\n        }\n\n        fun smallFont(b: Boolean): Builder {\n            mySmallFont = b\n            return this\n        }\n\n        fun overlap(b: Boolean): Builder {\n            myOverlap = b\n            return this\n        }\n\n        fun labelAdditionalOffsets(l: List<DoubleVector>?): Builder {\n            myLabelAdditionalOffsets = l\n            return this\n        }\n\n        fun labelHorizontalAnchor(anchor: TextLabel.HorizontalAnchor): Builder {\n            myLabelHorizontalAnchor = anchor\n            return this\n        }\n\n        fun labelVerticalAnchor(anchor: TextLabel.VerticalAnchor): Builder {\n            myLabelVerticalAnchor = anchor\n            return this\n        }\n\n        fun labelRotationAngle(angle: Double): Builder {\n            myLabelRotationAngle = angle\n            return this\n        }\n\n        fun build(): AxisLabelsLayoutInfo {\n            return AxisLabelsLayoutInfo(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation.*\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.max\nimport kotlin.math.min\n\ninternal object BreakLabelsLayoutUtil {\n    fun getFlexBreaks(breaksProvider: AxisBreaksProvider, maxCount: Int, axisLength: Double): GuideBreaks {\n        require(!breaksProvider.isFixedBreaks) { \"fixed breaks not expected\" }\n        require(maxCount > 0) { \"maxCount=$maxCount\" }\n        var breaks = breaksProvider.getBreaks(maxCount, axisLength)\n\n        if (maxCount == 1 && !breaks.isEmpty) {\n            return GuideBreaks(\n                breaks.domainValues.subList(\n                    0,\n                    1\n                ), breaks.transformedValues.subList(0, 1), breaks.labels.subList(0, 1)\n            )\n        }\n        var count = maxCount\n        while (breaks.size() > maxCount) {\n            val delta = max(1, (breaks.size() - maxCount) / 2)\n            count -= delta\n            breaks = breaksProvider.getBreaks(count, axisLength)\n        }\n        return breaks\n    }\n\n    fun maxLength(labels: List<String>): Int {\n        var max = 0\n        for (label in labels) {\n            max = max(max, label.length)\n        }\n        return max\n    }\n\n    fun horizontalCenteredLabelBounds(labelSize: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(-labelSize.x / 2.0, 0.0, labelSize.x, labelSize.y)\n    }\n\n    fun doLayoutVerticalAxisLabels(\n        orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n        breaks: GuideBreaks,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?,\n        theme: AxisTheme\n    ): AxisLabelsLayoutInfo {\n\n        val axisBounds = when {\n            theme.showTickLabels() -> {\n                val labelsBounds =\n                    verticalAxisLabelsBounds(\n                        breaks,\n                        axisDomain,\n                        axisMapper\n                    )\n                applyLabelsOffset(\n                    labelsBounds,\n                    theme.tickLabelDistance(),\n                    orientation\n                )\n            }\n            theme.showTickMarks() -> {\n                val labelsBounds = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n                applyLabelsOffset(\n                    labelsBounds,\n                    theme.tickLabelDistance(),\n                    orientation\n                )\n            }\n            else -> DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        }\n\n        return AxisLabelsLayoutInfo.Builder()\n            .breaks(breaks)\n            .bounds(axisBounds)     // label bounds actually\n            .build()\n    }\n\n    fun mapToAxis(\n        breaks: List<Double>,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?\n    ): List<Double> {\n        val axisMin = axisDomain.lowerEnd\n        val axisBreaks = ArrayList<Double>()\n        for (v in breaks) {\n            val mapped = axisMapper(v - axisMin)\n            axisBreaks.add(mapped!!)\n        }\n        return axisBreaks\n    }\n\n    fun applyLabelsOffset(\n        labelsBounds: DoubleRectangle,\n        offset: Double,\n        orientation: jetbrains.datalore.plot.builder.guide.Orientation\n    ): DoubleRectangle {\n        @Suppress(\"NAME_SHADOWING\")\n        var labelsBounds = labelsBounds\n        val offsetVector = when (orientation) {\n            LEFT -> DoubleVector(-offset, 0.0)\n            RIGHT -> DoubleVector(offset, 0.0)\n            TOP -> DoubleVector(0.0, -offset)\n            BOTTOM -> DoubleVector(0.0, offset)\n        }\n\n        if (orientation === RIGHT || orientation === BOTTOM) {\n            labelsBounds = labelsBounds.add(offsetVector)\n        } else if (orientation === LEFT || orientation === TOP) {\n            labelsBounds = labelsBounds.add(offsetVector).subtract(DoubleVector(labelsBounds.width, 0.0))\n        }\n\n        return labelsBounds\n    }\n\n\n    private fun verticalAxisLabelsBounds(\n        breaks: GuideBreaks,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?\n    ): DoubleRectangle {\n        val maxLength =\n            maxLength(breaks.labels)\n        val maxLabelWidth = AxisLabelsLayout.TICK_LABEL_SPEC.width(maxLength)\n        var y1 = 0.0\n        var y2 = 0.0\n        if (!breaks.isEmpty) {\n            val axisBreaks =\n                mapToAxis(\n                    breaks.transformedValues,\n                    axisDomain,\n                    axisMapper\n                )\n\n            y1 = min(axisBreaks[0], Iterables.getLast(axisBreaks))\n            y2 = max(axisBreaks[0], Iterables.getLast(axisBreaks))\n            y1 -= AxisLabelsLayout.TICK_LABEL_SPEC.height() / 2\n            y2 += AxisLabelsLayout.TICK_LABEL_SPEC.height() / 2\n        }\n\n        val origin = DoubleVector(0.0, y1)\n        val dimensions = DoubleVector(maxLabelWidth, y2 - y1)\n        return DoubleRectangle(origin, dimensions)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalFixedBreaksLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(\n    orientation,\n    axisDomain,\n    labelSpec,\n    breaks,\n    theme\n) {\n    init {\n        require(orientation.isHorizontal) { orientation.toString() }\n    }\n\n    private fun overlap(labelsInfo: AxisLabelsLayoutInfo, maxTickLabelsBounds: DoubleRectangle?): Boolean {\n        return labelsInfo.isOverlap || maxTickLabelsBounds != null && !(maxTickLabelsBounds.xRange()\n            .encloses(labelsInfo.bounds!!.xRange()) && maxTickLabelsBounds.yRange()\n            .encloses(labelsInfo.bounds.yRange()))\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n        if (!theme.showTickLabels()) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        var labelsInfo = simpleLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n        if (overlap(labelsInfo, maxLabelsBounds)) {\n            labelsInfo = multilineLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n            if (overlap(labelsInfo, maxLabelsBounds)) {\n                labelsInfo = tiltedLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n                if (overlap(labelsInfo, maxLabelsBounds)) {\n                    labelsInfo = verticalLayout(labelSpec).doLayout(axisLength, axisMapper, maxLabelsBounds)\n                    if (overlap(labelsInfo, maxLabelsBounds)) {\n                        labelsInfo =\n                            verticalLayout(TICK_LABEL_SPEC_SMALL).doLayout(axisLength, axisMapper, maxLabelsBounds)\n                    }\n                }\n            }\n        }\n        return labelsInfo\n    }\n\n    private fun simpleLayout(): AxisLabelsLayout {\n        return HorizontalSimpleLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    private fun multilineLayout(): AxisLabelsLayout {\n        return HorizontalMultilineLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme,\n            2\n        )\n    }\n\n    private fun tiltedLayout(): AxisLabelsLayout {\n        return HorizontalTiltedLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    private fun verticalLayout(labelSpec: PlotLabelSpec): AxisLabelsLayout {\n        return HorizontalVerticalLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        throw IllegalStateException(\"Not implemented here\")\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalFlexBreaksLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    private val myBreaksProvider: AxisBreaksProvider,\n    theme: AxisTheme\n) :\n    AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    init {\n        require(orientation.isHorizontal) { orientation.toString() }\n        require(!myBreaksProvider.isFixedBreaks) { \"fixed breaks\" }\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        var targetBreakCount =\n            HorizontalSimpleLabelsLayout.estimateBreakCountInitial(\n                axisLength\n            )\n        var breaks = getBreaks(targetBreakCount, axisLength)\n        var labelsInfo = doLayoutLabels(breaks, axisLength, axisMapper, maxLabelsBounds)\n\n        while (labelsInfo.isOverlap) {\n            // reduce tick count\n            val newTargetBreakCount =\n                HorizontalSimpleLabelsLayout.estimateBreakCount(\n                    breaks.labels,\n                    axisLength\n                )\n            if (newTargetBreakCount >= targetBreakCount) {\n                // paranoid - highly impossible.\n                break\n            }\n            targetBreakCount = newTargetBreakCount\n            breaks = getBreaks(targetBreakCount, axisLength)\n            labelsInfo = doLayoutLabels(breaks, axisLength, axisMapper, maxLabelsBounds)\n        }\n\n        return labelsInfo\n    }\n\n    private fun doLayoutLabels(\n        breaks: GuideBreaks,\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        val layout = HorizontalSimpleLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n        return layout.doLayout(axisLength, axisMapper, maxLabelsBounds)\n    }\n\n    private fun getBreaks(maxCount: Int, axisLength: Double): GuideBreaks {\n        return BreakLabelsLayoutUtil.getFlexBreaks(\n            myBreaksProvider,\n            maxCount,\n            axisLength\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalMultilineLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme,\n    private val myMaxLines: Int) :\n        AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    private val myShelfIndexForTickIndex = ArrayList<Int>()\n\n    private val labelAdditionalOffsets: List<DoubleVector>\n        get() {\n            val h = labelSpec.height() * LINE_HEIGHT\n            val result = ArrayList<DoubleVector>()\n            for (i in 0 until breaks.size()) {\n                result.add(DoubleVector(0.0, myShelfIndexForTickIndex[i] * h))\n            }\n            return result\n        }\n\n    override fun doLayout(\n            axisLength: Double,\n            axisMapper: (Double?) -> Double?,\n            maxLabelsBounds: DoubleRectangle?): AxisLabelsLayoutInfo {\n\n        val boundsByShelfIndex = HashMap<Int, DoubleRectangle>()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        val boundsList = labelBoundsList(ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n\n        for (labelBounds in boundsList) {\n            // find shelf with no overlap\n            var shelfIndex = 0\n            while (true) {\n                if (!boundsByShelfIndex.containsKey(shelfIndex)) {\n                    boundsByShelfIndex[shelfIndex] = labelBounds\n                    myShelfIndexForTickIndex.add(shelfIndex)\n                    break\n                }\n\n                var shelfBounds = boundsByShelfIndex[shelfIndex]!!\n                // not overlapped?\n                if (!shelfBounds.xRange().isConnected(ClosedRange(labelBounds.left - MIN_DISTANCE, labelBounds.right + MIN_DISTANCE))) {\n                    myShelfIndexForTickIndex.add(shelfIndex)\n                    shelfBounds = shelfBounds.union(labelBounds)\n                    boundsByShelfIndex[shelfIndex] = shelfBounds\n                    break\n                }\n\n                shelfIndex++\n            }\n        }\n\n        var bounds = if (boundsByShelfIndex.isEmpty())\n            DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        else\n            boundsByShelfIndex[0]!!\n        val h = labelSpec.height() * LINE_HEIGHT\n        for (i in 0 until boundsByShelfIndex.size) {\n            val shelfBounds = boundsByShelfIndex[i]!!\n            bounds = bounds.union(shelfBounds.add(DoubleVector(0.0, i * h)))\n        }\n\n        val linesCount = boundsByShelfIndex.size\n        return AxisLabelsLayoutInfo.Builder()\n                .breaks(breaks)\n                .bounds(applyLabelsOffset(bounds))\n                .smallFont(false)\n                .overlap(linesCount > myMaxLines)\n                .labelAdditionalOffsets(labelAdditionalOffsets)\n                .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n                .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        return BreakLabelsLayoutUtil.horizontalCenteredLabelBounds(\n            labelNormalSize\n        )\n    }\n\n    companion object {\n        private const val LINE_HEIGHT = 1.2\n        private const val MIN_DISTANCE = 60\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\n\ninternal class HorizontalSimpleLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme) :\n        AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    override fun doLayout(\n            axisLength: Double,\n            axisMapper: (Double?) -> Double?,\n            maxLabelsBounds: DoubleRectangle?): AxisLabelsLayoutInfo {\n\n        if (breaks.isEmpty) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        if (!theme.showTickLabels()) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        var bounds: DoubleRectangle? = null\n        var overlap = false\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n\n        val boundsList = labelBoundsList(ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        for (labelBounds in boundsList) {\n            overlap = overlap || bounds != null && bounds.xRange().isConnected(\n                    SeriesUtil.expand(labelBounds.xRange(), MIN_TICK_LABEL_DISTANCE / 2, MIN_TICK_LABEL_DISTANCE / 2.0))\n            bounds = GeometryUtil.union(labelBounds, bounds)\n        }\n\n        return AxisLabelsLayoutInfo.Builder()\n                .breaks(breaks)\n                .bounds(applyLabelsOffset(bounds!!))\n                .smallFont(false)\n                .overlap(overlap)\n                .labelAdditionalOffsets(null)\n                .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n                .build()\n    }\n\n    /*\n  private AxisLabelsLayoutInfo noLabelsLayoutInfo(double axisLength) {\n    DoubleRectangle bounds = new DoubleRectangle(axisLength / 2, 0, 0, 0); // empty bounds in the middle of the axis;\n    bounds = BreakLabelsLayoutUtil.applyLabelsOffset(bounds, myTheme.tickLabelDistance(), getOrientation());\n    return new AxisLabelsLayoutInfo.Builder()\n        .breaks(getBreaks())\n        //.bounds(applyLabelsOffset(bounds))\n        .bounds(bounds)\n        .smallFont(false)\n        .overlap(false)\n        .labelAdditionalOffsets(null)\n        .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n        .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n        .build();\n  }\n  */\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        return BreakLabelsLayoutUtil.horizontalCenteredLabelBounds(\n            labelNormalSize\n        )\n    }\n\n    companion object {\n        fun estimateBreakCountInitial(axisLength: Double): Int {\n            return estimateBreakCount(\n                INITIAL_TICK_LABEL_LENGTH,\n                axisLength\n            )\n        }\n\n        fun estimateBreakCount(labels: List<String>, axisLength: Double): Int {\n            val maxLength =\n                BreakLabelsLayoutUtil.maxLength(\n                    labels\n                )\n            return estimateBreakCount(\n                maxLength,\n                axisLength\n            )\n        }\n\n        private fun estimateBreakCount(labelLength: Int, axisLength: Double): Int {\n            val tickDistance = TICK_LABEL_SPEC.width(labelLength) + MIN_TICK_LABEL_DISTANCE\n            return max(1.0, axisLength / tickDistance).toInt()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.math.toRadians\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.abs\nimport kotlin.math.cos\nimport kotlin.math.sin\n\ninternal class HorizontalTiltedLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme) :\n        AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    private val labelHorizontalAnchor: TextLabel.HorizontalAnchor\n        get() {\n            if (orientation === BOTTOM) {\n                return TextLabel.HorizontalAnchor.RIGHT\n            }\n            throw RuntimeException(\"Not implemented\")\n        }\n\n    private val labelVerticalAnchor: TextLabel.VerticalAnchor\n        get() = TextLabel.VerticalAnchor.TOP\n\n    override fun doLayout(\n            axisLength: Double,\n            axisMapper: (Double?) -> Double?,\n            maxLabelsBounds: DoubleRectangle?): AxisLabelsLayoutInfo {\n\n        val height = labelSpec.height()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        var overlap = false\n        if (breaks.size() >= 2) {\n            val minTickDistance = abs((height + MIN_DISTANCE) / SIN)\n            val tickDistance = abs(ticks[0] - ticks[1])\n            overlap = tickDistance < minTickDistance\n        }\n\n        val bounds = labelsBounds(ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        return createAxisLabelsLayoutInfoBuilder(bounds!!, overlap)\n                .labelHorizontalAnchor(labelHorizontalAnchor)\n                .labelVerticalAnchor(labelVerticalAnchor)\n                .labelRotationAngle(ROTATION_DEGREE)\n                .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        // only works for RIGHT-TOP anchor ang angle 0..-90\n        if (!(ROTATION_DEGREE >= -90 && ROTATION_DEGREE <= 0\n                        && labelHorizontalAnchor === TextLabel.HorizontalAnchor.RIGHT\n                        && labelVerticalAnchor === TextLabel.VerticalAnchor.TOP)) {\n            throw RuntimeException(\"Not implemented\")\n        }\n\n\n        val w = abs(labelNormalSize.x * COS) + 2 * abs(labelNormalSize.y * SIN)\n        val h = abs(labelNormalSize.x * SIN) + abs(labelNormalSize.y * COS)\n        val x = -(abs(labelNormalSize.x * COS) + abs(labelNormalSize.y * SIN))\n        val y = 0.0\n\n        return DoubleRectangle(x, y, w, h)\n    }\n\n    companion object {\n        private const val MIN_DISTANCE = 5.0\n        private const val ROTATION_DEGREE = -30.0\n\n        private val SIN = sin(toRadians(ROTATION_DEGREE))\n        private val COS = cos(toRadians(ROTATION_DEGREE))\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.abs\n\ninternal class HorizontalVerticalLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme) :\n        AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    val labelHorizontalAnchor: TextLabel.HorizontalAnchor\n        get() {\n            if (orientation === BOTTOM) {\n                return TextLabel.HorizontalAnchor.LEFT\n            }\n            throw RuntimeException(\"Not implemented\")\n        }\n\n    val labelVerticalAnchor: TextLabel.VerticalAnchor\n        get() = TextLabel.VerticalAnchor.CENTER\n\n    override fun doLayout(\n            axisLength: Double,\n            axisMapper: (Double?) -> Double?,\n            maxLabelsBounds: DoubleRectangle?): AxisLabelsLayoutInfo {\n\n        val height = labelSpec.height()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        var overlap = false\n        if (breaks.size() >= 2) {\n            val minTickDistance = height + MIN_DISTANCE\n            val tickDistance = abs(ticks[0] - ticks[1])\n            overlap = tickDistance < minTickDistance\n        }\n\n        val bounds = labelsBounds(ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        return createAxisLabelsLayoutInfoBuilder(bounds!!, overlap)\n                .labelHorizontalAnchor(labelHorizontalAnchor)\n                .labelVerticalAnchor(labelVerticalAnchor)\n                .labelRotationAngle(ROTATION_DEGREE)\n                .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        if (!(ROTATION_DEGREE == 90.0\n                        && labelHorizontalAnchor === TextLabel.HorizontalAnchor.LEFT\n                        && labelVerticalAnchor === TextLabel.VerticalAnchor.CENTER)) {\n            throw RuntimeException(\"Not implemented\")\n        }\n        val w = labelNormalSize.y\n        val h = labelNormalSize.x\n        val x = -w / 2\n        val y = 0.0\n        return DoubleRectangle(x, y, w, h)\n    }\n\n    companion object {\n        private const val MIN_DISTANCE = 5.0\n        private const val ROTATION_DEGREE = 90.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class VerticalFixedBreaksLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    tickLabelSpec: PlotLabelSpec,\n    breaks: GuideBreaks,\n    theme: AxisTheme) :\n        AbstractFixedBreaksLabelsLayout(orientation, axisDomain, tickLabelSpec, breaks, theme) {\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        throw IllegalStateException(\"Not implemented here\")\n    }\n\n    override fun doLayout(\n            axisLength: Double,\n            axisMapper: (Double?) -> Double?,\n            maxLabelsBounds: DoubleRectangle?): AxisLabelsLayoutInfo {\n\n        return BreakLabelsLayoutUtil.doLayoutVerticalAxisLabels(\n            orientation, breaks,\n            axisDomain,\n            axisMapper,\n            theme\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.layout.axis.GuideBreaks\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.ceil\n\ninternal class VerticalFlexBreaksLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    private val myBreaksProvider: AxisBreaksProvider,\n    theme: AxisTheme\n) :\n    AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    private fun maxTickCount(axisLength: Double): Int {\n        return ceil(axisLength / (TICK_LABEL_SPEC.height() + MIN_TICK_LABEL_DISTANCE)).toInt()\n    }\n\n    init {\n        require(!orientation.isHorizontal) { orientation.toString() }\n        require(!myBreaksProvider.isFixedBreaks) { \"fixed breaks\" }\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        require(axisLength > 0) { \"axis length: $axisLength\" }\n        val maxTickCount = maxTickCount(axisLength)\n        val breaks = getBreaks(maxTickCount, axisLength)\n\n        return BreakLabelsLayoutUtil.doLayoutVerticalAxisLabels(\n            orientation, breaks,\n            axisDomain,\n            axisMapper,\n            theme\n        )\n    }\n\n    protected fun getBreaks(maxCount: Int, axisLength: Double): GuideBreaks {\n        return BreakLabelsLayoutUtil.getFlexBreaks(\n            myBreaksProvider,\n            maxCount,\n            axisLength\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot.Axis\n\nobject Defaults {\n    // HEX colors only (because of using of parseHex())\n    const val DARK_GRAY = \"#3d3d3d\"\n    val GRAY = Color.GRAY.toHexColor()\n    val LIGHT_GRAY = Color.LIGHT_GRAY.toHexColor()\n    val X_LIGHT_GRAY = Color.VERY_LIGHT_GRAY.toHexColor()\n    const val XX_LIGHT_GRAY = \"#e0e0e0\"\n\n    const val BACKDROP_COLOR = \"white\"\n\n    const val TEXT_COLOR = DARK_GRAY\n\n    const val FONT_LARGE = 16\n    const val FONT_MEDIUM = 12\n    const val FONT_SMALL = 10\n    const val FONT_X_SMALL = 8\n\n    const val FONT_FAMILY_NORMAL = \"\\\"Lucida Grande\\\", sans-serif\"\n    const val FONT_FAMILY_MONOSPACED = \"\\\"Courier New\\\", Courier, monospace\"\n\n    class Common {\n        object Title {\n            const val FONT_SIZE = FONT_LARGE\n            val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n\n        object Legend {\n            const val TITLE_FONT_SIZE =\n                FONT_MEDIUM\n            const val ITEM_FONT_SIZE =\n                FONT_SMALL\n            val OUTLINE_COLOR = Color.parseHex(XX_LIGHT_GRAY)\n        }\n\n        object Tooltip {\n            const val MAX_POINTER_FOOTING_LENGTH = 12.0\n            const val POINTER_FOOTING_TO_SIDE_LENGTH_RATIO = 0.4\n\n            const val MARGIN_BETWEEN_TOOLTIPS = 5.0\n            const val DATA_TOOLTIP_FONT_SIZE = FONT_MEDIUM\n            const val LINE_INTERVAL = 3.0\n            const val H_CONTENT_PADDING = 4.0\n            const val V_CONTENT_PADDING = 4.0\n            const val LABEL_VALUE_INTERVAL = 8.0\n\n            const val BORDER_WIDTH = 4.0\n\n            val DARK_TEXT_COLOR = Color.BLACK\n            val LIGHT_TEXT_COLOR = Color.WHITE\n\n            const val AXIS_TOOLTIP_FONT_SIZE = DATA_TOOLTIP_FONT_SIZE\n            val AXIS_TOOLTIP_COLOR = Axis.LINE_COLOR\n            const val AXIS_RADIUS = 1.5 // fix a tooltip border overlapping an axis\n        }\n    }\n\n    class Table {\n        object Head {\n            const val FONT_SIZE = FONT_MEDIUM\n            const val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n\n        object Data {\n            const val FONT_SIZE = FONT_MEDIUM\n            const val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n    }\n\n    class Plot {\n        object Axis {\n            const val TITLE_FONT_SIZE =\n                FONT_MEDIUM\n            const val TICK_FONT_SIZE =\n                FONT_SMALL\n            const val TICK_FONT_SIZE_SMALL =\n                FONT_X_SMALL\n\n            val LINE_COLOR = Color.parseHex(DARK_GRAY)\n            val TICK_COLOR = Color.parseHex(DARK_GRAY)\n            val GRID_LINE_COLOR = Color.parseHex(X_LIGHT_GRAY)\n\n            // Bug in WebKit (?) : combination of style\n            //    shape-rendering: crispedges;\n            // and stroke-width less than 1\n            // makes horizontal line disappear\n            /*\n      public static final double LINE_WIDTH = 0.8;\n      public static final double TICK_LINE_WIDTH = 0.8;\n      public static final double GRID_LINE_WIDTH = 0.8;\n*/\n            const val LINE_WIDTH = 1.0\n            const val TICK_LINE_WIDTH = 1.0\n            const val GRID_LINE_WIDTH = 1.0\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nobject LabelCss {\n    operator fun get(labelSpec: LabelSpec, selector: String): String {\n        val css = StringBuilder()\n        css\n                .append(selector).append(\" {\")\n                .append(if (labelSpec.isMonospaced)\n                    \"\\n  font-family: \" + Defaults.FONT_FAMILY_MONOSPACED + \";\"\n                else\n                    \"\\n\")\n                .append(\"\\n  font-size: \").append(labelSpec.fontSize).append(\"px;\")\n                .append(if (labelSpec.isBold) \"\\n  font-weight: bold;\" else \"\")\n                //      .append(\"\\n  fill: red;\")\n                .append(\"\\n}\\n\")\n        return css.toString()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.jvm.JvmOverloads\n\n//ToDo:\ninterface Serializable\n\nclass LabelMetrics : LabelSpec,\n    Serializable {\n\n    override val fontSize: Double\n    override val isBold: Boolean\n    override val isMonospaced: Boolean\n\n    /**\n     * for Serializable\n     */\n    constructor() {\n        this.fontSize = 0.0\n        isBold = false\n        isMonospaced = false\n    }\n\n    /**\n     * @param fontSize in 'px' (same meaning as in CSS)\n     */\n    @JvmOverloads\n    constructor(fontSize: Double, bold: Boolean = false, monospaced: Boolean = false) {\n        this.fontSize = fontSize\n        isBold = bold\n        isMonospaced = monospaced\n    }\n\n    override fun dimensions(labelLength: Int): DoubleVector {\n        return DoubleVector(width(labelLength), height())\n    }\n\n    override fun width(labelLength: Int): Double {\n        var ratio =\n            FONT_SIZE_TO_GLYPH_WIDTH_RATIO\n        if (isMonospaced) {\n            ratio =\n                FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED\n        }\n\n        val width = labelLength.toDouble() * fontSize * ratio + 2 * LABEL_PADDING\n        return if (isBold) {\n            width * FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO\n        } else width\n    }\n\n    override fun height(): Double {\n        return fontSize + 2 * LABEL_PADDING\n    }\n\n    companion object {\n        private const val FONT_SIZE_TO_GLYPH_WIDTH_RATIO = 0.67 //0.48; // 0.42;\n        private const val FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED = 0.6\n        private const val FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO = 1.075\n        private const val LABEL_PADDING = 0.0 //2;\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot\n\nenum class PlotLabelSpec(fontSize: Double, bold: Boolean = false, monospaced: Boolean = false) :\n    LabelSpec {\n    PLOT_TITLE(Defaults.Common.Title.FONT_SIZE.toDouble(), true),\n\n    AXIS_TICK(Plot.Axis.TICK_FONT_SIZE.toDouble()),\n    AXIS_TICK_SMALL(Plot.Axis.TICK_FONT_SIZE_SMALL.toDouble()),\n    AXIS_TITLE(Plot.Axis.TITLE_FONT_SIZE.toDouble()),\n\n    LEGEND_TITLE(Defaults.Common.Legend.TITLE_FONT_SIZE.toDouble(), true),\n    LEGEND_ITEM(Defaults.Common.Legend.ITEM_FONT_SIZE.toDouble());\n\n    private val myLabelMetrics: LabelMetrics\n\n    override val isBold: Boolean\n        get() = myLabelMetrics.isBold\n\n    override val isMonospaced: Boolean\n        get() = myLabelMetrics.isMonospaced\n\n    override val fontSize: Double\n        get() = myLabelMetrics.fontSize\n\n    init {\n        myLabelMetrics =\n            LabelMetrics(fontSize, bold, monospaced)\n    }\n\n    override fun dimensions(labelLength: Int): DoubleVector {\n        return myLabelMetrics.dimensions(labelLength)\n    }\n\n    override fun width(labelLength: Int): Double {\n        return myLabelMetrics.width(labelLength)\n    }\n\n    override fun height(): Double {\n        return myLabelMetrics.height()\n    }\n}\n/**\n * @param fontSize in 'px' (same meaning as in CSS)\n */\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.plot.builder.presentation.Defaults.BACKDROP_COLOR\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_TOOLTIP_FONT_SIZE\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.DATA_TOOLTIP_FONT_SIZE\nimport jetbrains.datalore.plot.builder.presentation.Defaults.FONT_FAMILY_NORMAL\nimport jetbrains.datalore.plot.builder.presentation.Defaults.FONT_MEDIUM\nimport jetbrains.datalore.plot.builder.presentation.Defaults.TEXT_COLOR\n\n/**\n * Duplicating stylesheet for JavaFX platform is defined in\n * plot-builder/src/jvmMain/resources/svgMapper/jfx/plot.css\n */\nobject Style {\n    const val JFX_PLOT_STYLESHEET = \"/svgMapper/jfx/plot.css\"\n\n    // classes\n    const val PLOT_CONTAINER = \"plt-container\"\n    const val PLOT = \"plt-plot\"\n    const val PLOT_TITLE = \"plt-plot-title\"\n\n    const val PLOT_TRANSPARENT = \"plt-transparent\"\n    const val PLOT_BACKDROP = \"plt-backdrop\"\n\n    const val AXIS = \"plt-axis\"\n\n    const val AXIS_TITLE = \"plt-axis-title\"\n    const val TICK = \"tick\"\n    const val SMALL_TICK_FONT = \"small-tick-font\"\n\n    const val BACK = \"back\"\n\n    const val LEGEND = \"plt_legend\"\n    const val LEGEND_TITLE = \"legend-title\"\n\n    const val PLOT_DATA_TOOLTIP = \"plt-data-tooltip\"\n    const val PLOT_AXIS_TOOLTIP = \"plt-axis-tooltip\"\n\n    private val CSS = \"\"\"\n        |.$PLOT_CONTAINER {\n        |\tfont-family: $FONT_FAMILY_NORMAL;\n        |\tcursor: crosshair;\n        |\tuser-select: none;\n        |\t-webkit-user-select: none;\n        |\t-moz-user-select: none;\n        |\t-ms-user-select: none;\n        |}\n        |.$PLOT_BACKDROP {\n        |   fill: $BACKDROP_COLOR;\n        |}\n        |.$PLOT_TRANSPARENT .$PLOT_BACKDROP {\n        |   visibility: hidden;\n        |}\n        |text {\n        |\tfont-size: ${FONT_MEDIUM}px;\n        |\tfill: $TEXT_COLOR;\n        |\t\n        |\ttext-rendering: optimizeLegibility;\n        |}\n        |.$PLOT_DATA_TOOLTIP text {\n        |\tfont-size: ${DATA_TOOLTIP_FONT_SIZE}px;\n        |}\n        |.$PLOT_AXIS_TOOLTIP text {\n        |\tfont-size: ${AXIS_TOOLTIP_FONT_SIZE}px;\n        |}\n        |.$AXIS line {\n        |\tshape-rendering: crispedges;\n        |}\n    \"\"\".trimMargin()\n\n    val css: String\n        get() {\n            val css = StringBuilder(CSS.toString())\n            css.append('\\n')\n            for (labelSpec in PlotLabelSpec.values()) {\n                val selector = selector(labelSpec)\n                css.append(LabelCss[labelSpec, selector])\n            }\n            return css.toString()\n        }\n\n    private fun selector(labelSpec: PlotLabelSpec): String {\n        return when (labelSpec) {\n            PlotLabelSpec.PLOT_TITLE -> \".$PLOT_TITLE\"\n            PlotLabelSpec.AXIS_TICK -> \".$AXIS .$TICK text\"\n            PlotLabelSpec.AXIS_TICK_SMALL -> \".$AXIS.$SMALL_TICK_FONT .$TICK text\"\n            PlotLabelSpec.AXIS_TITLE -> \".$AXIS_TITLE text\"\n            PlotLabelSpec.LEGEND_TITLE -> \".$LEGEND .$LEGEND_TITLE text\"\n            PlotLabelSpec.LEGEND_ITEM -> \".$LEGEND text\"\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.method.*\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.VertexDpSampling\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.VertexVwSampling\n\nobject Samplings {\n    const val RANDOM = RandomSampling.ALIAS\n    const val PICK = PickSampling.ALIAS\n    const val SYSTEMATIC = SystematicSampling.ALIAS\n    const val RANDOM_GROUP = GroupRandomSampling.ALIAS\n    const val SYSTEMATIC_GROUP = GroupSystematicSampling.ALIAS\n    const val RANDOM_STRATIFIED = RandomStratifiedSampling.ALIAS\n    const val VERTEX_VW = VertexVwSampling.ALIAS\n    const val VERTEX_DP = VertexDpSampling.ALIAS\n\n    val NONE: PointSampling =\n        NoneSampling()\n\n    fun random(sampleSize: Int, seed: Long?): PointSampling {\n        return RandomSampling(sampleSize, seed)\n    }\n\n    fun pick(sampleSize: Int): PointSampling {\n        return PickSampling(sampleSize)\n    }\n\n    fun vertexDp(sampleSize: Int): Sampling {\n        return VertexDpSampling(sampleSize)\n    }\n\n    fun vertexVw(sampleSize: Int): Sampling {\n        return VertexVwSampling(sampleSize)\n    }\n\n    fun systematic(sampleSize: Int): Sampling {\n        return SystematicSampling(sampleSize)\n    }\n\n    fun randomGroup(sampleSize: Int, seed: Long?): Sampling {\n        return GroupRandomSampling(sampleSize, seed)\n    }\n\n    fun systematicGroup(sampleSize: Int): Sampling {\n        return GroupSystematicSampling(sampleSize)\n    }\n\n    fun randomStratified(sampleSize: Int, seed: Long?, minSubSample: Int?): Sampling {\n        return RandomStratifiedSampling(sampleSize, seed, minSubSample)\n    }\n\n    private class NoneSampling : PointSampling {\n\n        override val expressionText: String\n            get() = \"none\"\n\n        override fun isApplicable(population: DataFrame): Boolean {\n            return false\n        }\n\n        override fun apply(population: DataFrame): DataFrame {\n            return population\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport kotlin.random.Random\n\ninternal class GroupRandomSampling(sampleSize: Int, private val mySeed: Long?) : GroupSamplingBase(sampleSize) {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                \")\"\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val distinctGroups = SamplingUtil.distinctGroups(\n            groupMapper,\n            population.rowCount()\n        )\n\n        distinctGroups.shuffle(createRandom())\n        val pickedGroups = distinctGroups.take(sampleSize).toSet()\n        return doSelect(population, pickedGroups, groupMapper)\n    }\n\n    private fun createRandom(): Random {\n        return mySeed?.let { Random(it) } ?: Random.Default\n    }\n\n    companion object {\n        const val ALIAS = \"group_random\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.data.GroupUtil\nimport jetbrains.datalore.plot.builder.sampling.GroupAwareSampling\n\ninternal abstract class GroupSamplingBase(sampleSize: Int) : SamplingBase(sampleSize),\n    GroupAwareSampling {\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int): Boolean {\n        return isApplicable(population, groupMapper,\n            SamplingUtil.groupCount(groupMapper, population.rowCount())\n        )\n    }\n\n    open fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int, groupCount: Int): Boolean {\n        return groupCount > sampleSize\n    }\n\n    fun doSelect(population: DataFrame, pickedGroups: Set<Int>, groupMapper: (Int) -> Int): DataFrame {\n        val indicesByGroup = GroupUtil.indicesByGroup(population.rowCount(), groupMapper)\n\n        val pickedIndices = ArrayList<Int>()\n        for (group in pickedGroups) {\n            pickedIndices.addAll(indicesByGroup.get(group)!!)\n        }\n        return population.selectIndices(pickedIndices)\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.method.SystematicSampling.Companion.computeStep\n\ninternal class GroupSystematicSampling(sampleSize: Int) : GroupSamplingBase(sampleSize) {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                \")\"\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int, groupCount: Int): Boolean {\n        return super.isApplicable(population, groupMapper, groupCount) && computeStep(groupCount, sampleSize) >= 2\n    }\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val distinctGroups = SamplingUtil.distinctGroups(\n            groupMapper,\n            population.rowCount()\n        )\n        val step = computeStep(distinctGroups.size, sampleSize)\n\n        val pickedGroups = HashSet<Int>()\n        var i = 0\n        while (i < distinctGroups.size) {\n            pickedGroups.add(distinctGroups[i])\n            i += step\n        }\n\n        return doSelect(population, pickedGroups, groupMapper)\n    }\n\n    companion object {\n        const val ALIAS = \"group_systematic\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkArgument\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.xVar\n\n/**\n * Picks first N data points with unique X-values. In addition scoops all data-points with X-values\n * which are already being accepted to the sample (to account for grouping)\n */\ninternal class PickSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize + \")\"\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n\n        val xVar = xVar(population)\n        val xFactors = population.distinctValues(xVar)\n        if (xFactors.size <= sampleSize) {\n            return population\n        }\n\n        val pickX = xFactors.take(sampleSize).toSet()\n\n        val xValues = population[xVar]\n        val pickedIndices = ArrayList<Int>()\n        for ((index, v) in xValues.withIndex()) {\n            if (v in pickX) {\n                pickedIndices.add(index)\n            }\n        }\n\n        return population.selectIndices(pickedIndices)\n    }\n\n    companion object {\n        const val ALIAS = \"pick\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport kotlin.random.Random\n\n/**\n * Take any point with equal probability without replacement\n */\ninternal class RandomSampling(sampleSize: Int, private val mySeed: Long?) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                \")\"\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n        val rand = mySeed?.let { Random(it) } ?: Random.Default\n\n        return SamplingUtil.sampleWithoutReplacement(sampleSize, rand, population)\n    }\n\n    companion object {\n        const val ALIAS = \"random\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.data.GroupUtil\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport jetbrains.datalore.plot.builder.sampling.GroupAwareSampling\nimport kotlin.math.max\nimport kotlin.math.round\nimport kotlin.random.Random\n\ninternal class RandomStratifiedSampling(\n        sampleSize: Int,\n        private val mySeed: Long?,\n        private val myMinSubsampleSize: Int?) : SamplingBase(sampleSize),\n    GroupAwareSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                (if (myMinSubsampleSize != null) \", min_subsample=$myMinSubsampleSize\" else \"\") +\n                \")\"\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int): Boolean {\n        return population.rowCount() > sampleSize\n    }\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val indicesByGroup = GroupUtil.indicesByGroup(population.rowCount(), groupMapper)\n\n        var minSubSampleSize = myMinSubsampleSize ?: DEF_MIN_SUBSAMPLE_SIZE\n        minSubSampleSize = max(0, minSubSampleSize)\n        val popSize = population.rowCount()\n\n        val pickIndices = ArrayList<Int>()\n        val rand = mySeed?.let { Random(it) } ?: Random.Default\n        for (group in indicesByGroup.keys) {\n            val groupIndices = indicesByGroup[group]!!\n            val stratumSize = groupIndices.size\n            // proportionate allocation\n            val ratio = stratumSize.toDouble() / popSize\n\n            var stratumSampleSize = round(sampleSize * ratio).toInt()\n            stratumSampleSize = max(stratumSampleSize, minSubSampleSize)\n\n            if (stratumSampleSize >= stratumSize) {\n                pickIndices.addAll(groupIndices)\n            } else {\n\n                val sampleGroupIndices =\n                    SamplingUtil.sampleWithoutReplacement(stratumSize,\n                        stratumSampleSize,\n                        rand,\n                        { indexSet ->\n                            (0 until groupIndices.size)\n                                .filter { indexSet.contains(it) }\n                        },\n                        { indexSet ->\n                            (0 until groupIndices.size)\n                                .filter { i -> !indexSet.contains(i) }\n                        })\n\n                for (i in sampleGroupIndices) {\n                    pickIndices.add(groupIndices[i])\n                }\n            }\n        }\n\n        return population.selectIndices(pickIndices)\n    }\n\n    companion object {\n        internal const val ALIAS = \"random_stratified\"\n        private const val DEF_MIN_SUBSAMPLE_SIZE = 2 // min needed to draw a line\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.Sampling\n\ninternal abstract class SamplingBase(val sampleSize: Int) : Sampling {\n\n    init {\n        check(this.sampleSize > 0) { \"Sample size must be greater than zero, but was: \" + this.sampleSize }\n    }\n\n    open fun isApplicable(population: DataFrame): Boolean {\n        return population.rowCount() > sampleSize\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.algorithms.calculateArea\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.base.util.MutableInteger\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.DoubleVectorComponentsList\nimport kotlin.math.min\nimport kotlin.math.roundToInt\n\ninternal object SamplingUtil {\n\n    fun groupCount(groupMapper: (Int) -> Int, size: Int): Int {\n        return (0 until size).map { groupMapper(it) }.distinct().count()\n    }\n\n    fun distinctGroups(groupMapper: (Int) -> Int, size: Int): MutableList<Int> {\n        return (0 until size).map { groupMapper(it) }.distinct().toMutableList()\n    }\n\n    fun xVar(variables: Set<Variable>): Variable? {\n        return when {\n            Stats.X in variables -> Stats.X\n            TransformVar.X in variables -> TransformVar.X\n            else -> null\n        }\n    }\n    fun xVar(data: DataFrame): Variable {\n        return xVar(data.variables())\n            ?: throw IllegalStateException(\"Can't apply sampling: couldn't deduce the (X) variable.\")\n    }\n\n    fun yVar(data: DataFrame): Variable {\n        if (data.has(Stats.Y)) {\n            return Stats.Y\n        } else if (data.has(TransformVar.Y)) {\n            return TransformVar.Y\n        }\n        throw IllegalStateException(\"Can't apply sampling: couldn't deduce the (Y) variable.\")\n    }\n\n    fun splitRings(population: DataFrame): List<List<DoubleVector>> {\n        val rings = ArrayList<List<DoubleVector>>()\n        var lastPoint: DoubleVector? = null\n        var start = -1\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val xValues = population[xVar(population)] as List<Any>\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val yValues = population[yVar(population)] as List<Any>\n        val points = DoubleVectorComponentsList(xValues, yValues)\n        for (i in points.indices) {\n            val point = points[i]\n            if (start < 0) {\n                start = i\n                lastPoint = point\n            } else if (lastPoint == point) {\n                rings.add(points.subList(start, i + 1))\n                start = -1\n                lastPoint = null\n            }\n        }\n        if (start >= 0) {\n            // not closed\n            rings.add(points.subList(start, points.size))\n        }\n        return rings\n    }\n\n    fun calculateRingLimits(rings: List<List<DoubleVector>>, totalPointsLimit: Int): List<Int> {\n        val totalArea = rings.map { calculateArea(it) }.sum()\n\n        val areaProceed = MutableDouble(0.0)\n        val pointsProceed = MutableInteger(0)\n\n        return rings.indices\n            .asSequence()\n            .map { Pair(it, calculateArea(rings[it])) }\n            .sortedWith(compareBy<Pair<*, Double>> {\n                getRingArea(\n                    it\n                )\n            }.reversed())\n            .map { p ->\n                var limit = min(\n                    (p.second / (totalArea - areaProceed.get()) * (totalPointsLimit - pointsProceed.get())).roundToInt(),\n                    rings[getRingIndex(p)].size\n                )\n\n                if (limit >= 4) {\n                    areaProceed.getAndAdd(getRingArea(p))\n                    pointsProceed.getAndAdd(limit)\n                } else {\n                    limit = 0\n                }\n\n                Pair(getRingIndex(p), limit)\n            }\n            .sortedWith(compareBy { getRingIndex(it) })\n            .map { getRingLimit(it) }\n            .toList()\n    }\n\n    fun getRingIndex(pair: Pair<Int, *>): Int {\n        return pair.first\n    }\n\n    private fun getRingArea(pair: Pair<*, Double>): Double {\n        return pair.second\n    }\n\n    fun getRingLimit(pair: Pair<*, Int>): Int {\n        return pair.second\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport kotlin.math.round\n\n/**\n * Take points at indices selected at regular intervals starting from index 0\n */\ninternal class SystematicSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                \")\"\n\n    override fun isApplicable(population: DataFrame): Boolean {\n        return super.isApplicable(population) && computeStep(population.rowCount()) >= 2\n    }\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n        val popSize = population.rowCount()\n\n        val step = computeStep(popSize)\n        val pickedIndices = ArrayList<Int>()\n        var i = 0\n        while (i < popSize) {\n            pickedIndices.add(i)\n            i += step\n        }\n\n        return population.selectIndices(pickedIndices)\n    }\n\n    private fun computeStep(popSize: Int): Int {\n        return round(popSize.toDouble() / (sampleSize - 1)).toInt()\n    }\n\n    companion object {\n        const val ALIAS = \"systematic\"\n\n        fun computeStep(popSize: Int, sampleSize: Int): Int {\n            return round((popSize - 1).toDouble() / (sampleSize - 1)).toInt()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.algorithms.isClosed\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.util.MutableInteger\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.calculateRingLimits\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.getRingIndex\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.getRingLimit\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.splitRings\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier\n\ninternal abstract class VertexSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    private fun simplify(points: List<DoubleVector>, limit: Int): List<Int> {\n        return if (limit == 0) {\n            emptyList()\n        } else {\n            simplifyInternal(points, limit)\n        }\n    }\n\n    internal abstract fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int>\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n\n        val rings = splitRings(population)\n        val limits = if (rings.size == 1 && !rings[0].isClosed())\n            listOf(sampleSize)\n        else\n            calculateRingLimits(rings, sampleSize)\n\n        val indices = ArrayList<Int>()\n        val ringBase = MutableInteger(0)\n\n        (0 until limits.size)\n                .map { Pair(it, limits[it]) }\n                .forEach { p ->\n                    simplify(rings[getRingIndex(p)], getRingLimit(p))\n                            .forEach { index -> indices.add(ringBase.get() + index) }\n                    ringBase.getAndAdd(rings[getRingIndex(p)].size)\n                }\n\n        return population.selectIndices(indices)\n    }\n\n    internal class VertexVwSampling(sampleSize: Int) : VertexSampling(sampleSize) {\n\n        override val expressionText: String\n            get() = \"sampling_\" + ALIAS + \"(\" +\n                    \"n=\" + sampleSize + \")\"\n\n        override fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int> {\n            return PolylineSimplifier.visvalingamWhyatt(points).setCountLimit(limit).indices\n        }\n\n        companion object {\n            const val ALIAS = \"vertex_vw\"\n        }\n    }\n\n    internal class VertexDpSampling(sampleSize: Int) : VertexSampling(sampleSize) {\n\n        override val expressionText: String\n            get() = \"sampling_\" + ALIAS + \"(\" +\n                    \"n=\" + sampleSize + \")\"\n\n        override fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int> {\n            return PolylineSimplifier.douglasPeucker(points).setCountLimit(limit).indices\n        }\n\n        companion object {\n            const val ALIAS = \"vertex_dp\"\n        }\n    }\n\n    internal class DoubleVectorComponentsList(private val myXValues: List<Any>, private val myYValues: List<Any>) : AbstractList<DoubleVector>() {\n        override val size: Int\n            get() = myXValues.size\n\n        override fun get(index: Int): DoubleVector {\n            return createPoint(\n                myXValues[index],\n                myYValues[index]\n            )\n        }\n    }\n\n    companion object {\n        private fun createPoint(x: Any, y: Any): DoubleVector {\n            require(!(x is String || y is String)) { \"String coords are not supported yet\" }\n            require(SeriesUtil.allFinite(x as Double, y as Double)) { \"Invalid coord\" }\n            return DoubleVector(x, y)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.plot.builder.scale.provider.MapperProviderBase\n\nabstract class ContinuousOnlyMapperProvider<T>(naValue: T) : MapperProviderBase<T>(naValue) {\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        val domainRepr = domainValues.joinToString(limit = 3) { \"'$it'\" }\n        throw IllegalStateException(\"[${this::class.simpleName}] Can't create mapper for discrete domain: $domainRepr\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createColorMapperProvider\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createObjectIdentity\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createObjectIdentityDiscrete\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createStringIdentity\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createWithDiscreteOutput\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.builder.scale.mapper.LineTypeMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ShapeMapper\nimport jetbrains.datalore.plot.builder.scale.provider.AlphaMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.SizeMapperProvider\n\n\nobject DefaultMapperProvider {\n\n    private val PROVIDER_MAP = TypedMapperProviderMap()\n\n    operator fun <T> get(aes: Aes<T>): MapperProvider<T> {\n        return PROVIDER_MAP[aes]\n    }\n\n    /**\n     * For tests\n     */\n    internal fun hasDefault(aes: Aes<*>): Boolean {\n        return PROVIDER_MAP.containsKey(aes)\n    }\n\n    private class TypedMapperProviderMap internal constructor() {\n\n        private var myMap: MutableMap<Aes<*>, MapperProvider<*>> = HashMap()\n\n        init {\n            for (aes in Aes.allPositional()) {\n                put(aes, NUMERIC_UNDEFINED)\n            }\n\n            this.put(X, NUMERIC_IDENTITY)\n            this.put(Y, NUMERIC_IDENTITY)\n\n            this.put(Z, NUMERIC_IDENTITY)\n            this.put(YMIN, NUMERIC_IDENTITY)\n            this.put(YMAX, NUMERIC_IDENTITY)\n            this.put(COLOR, createColorMapperProvider())\n            this.put(FILL, createColorMapperProvider())\n            this.put(ALPHA, AlphaMapperProvider.DEFAULT)\n            this.put(SHAPE, createWithDiscreteOutput(ShapeMapper.allShapes(), ShapeMapper.NA_VALUE))\n            this.put(LINETYPE, createWithDiscreteOutput(LineTypeMapper.allLineTypes(), LineTypeMapper.NA_VALUE))\n\n            this.put(SIZE, SizeMapperProvider.DEFAULT)\n            this.put(WIDTH, NUMERIC_IDENTITY)\n            this.put(HEIGHT, NUMERIC_IDENTITY)\n            this.put(WEIGHT, NUMERIC_IDENTITY)\n            this.put(INTERCEPT, NUMERIC_IDENTITY)\n            this.put(SLOPE, NUMERIC_IDENTITY)\n            this.put(XINTERCEPT, NUMERIC_IDENTITY)\n            this.put(YINTERCEPT, NUMERIC_IDENTITY)\n            this.put(LOWER, NUMERIC_IDENTITY)\n            this.put(MIDDLE, NUMERIC_IDENTITY)\n            this.put(UPPER, NUMERIC_IDENTITY)\n\n            this.put(FRAME, createStringIdentity(FRAME))\n\n            this.put(SPEED, NUMERIC_IDENTITY)\n            this.put(FLOW, NUMERIC_IDENTITY)\n\n            this.put(XMIN, NUMERIC_IDENTITY)\n            this.put(XMAX, NUMERIC_IDENTITY)\n            this.put(XEND, NUMERIC_IDENTITY)\n            this.put(YEND, NUMERIC_IDENTITY)\n\n            this.put(LABEL, createObjectIdentity(LABEL))\n            this.put(FAMILY, createStringIdentity(FAMILY))\n            this.put(FONTFACE, createStringIdentity(FONTFACE))\n\n            // text horizontal justification (numbers [0..1] or predefined strings, DOUBLE_CVT; not positional)\n            this.put(HJUST, createObjectIdentityDiscrete(HJUST))\n\n            // text vertical justification (numbers [0..1] or predefined strings, not positional)\n            this.put(VJUST, createObjectIdentityDiscrete(VJUST))\n            this.put(ANGLE, NUMERIC_IDENTITY)\n\n            this.put(SYM_X, NUMERIC_IDENTITY)\n            this.put(SYM_Y, NUMERIC_IDENTITY)\n        }\n\n        internal operator fun <T> get(aes: Aes<T>): MapperProvider<T> {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myMap[aes] as MapperProvider<T>\n        }\n\n        private fun <T> put(aes: Aes<T>, value: MapperProvider<T>) {\n            myMap[aes] = value\n        }\n\n        internal fun containsKey(aes: Aes<*>): Boolean {\n            return myMap.containsKey(aes)\n        }\n\n        companion object {\n            // For most of numeric (positional) aesthetics the initial mapper is UNDEFINED mapper as we don't yet know the range of positional aesthetics.\n            private val NUMERIC_UNDEFINED: MapperProvider<Double> = object : MapperProvider<Double> {\n                override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n                    return GuideMappers.UNDEFINED\n                }\n\n                override fun createContinuousMapper(\n                    domain: ClosedRange<Double>,\n                    lowerLimit: Double?,\n                    upperLimit: Double?,\n                    trans: ContinuousTransform\n                ): GuideMapper<Double> {\n                    return GuideMappers.UNDEFINED\n                }\n            }\n\n            private val NUMERIC_IDENTITY: MapperProvider<Double> = object : MapperProvider<Double> {\n                override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n                    return GuideMappers.IDENTITY\n                }\n\n                override fun createContinuousMapper(\n                    domain: ClosedRange<Double>,\n                    lowerLimit: Double?,\n                    upperLimit: Double?,\n                    trans: ContinuousTransform\n                ): GuideMapper<Double> {\n                    return GuideMappers.IDENTITY\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.builder.scale.provider.ColorBrewerMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.ColorGradientMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.IdentityDiscreteMapperProvider\n\nobject DefaultMapperProviderUtil {\n\n    internal fun createColorMapperProvider(): MapperProvider<Color> {\n        val discrete = ColorBrewerMapperProvider(null, null, null, Color.GRAY)\n        val continuous = ColorGradientMapperProvider.DEFAULT\n        return object : MapperProvider<Color> {\n            override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n                return discrete.createDiscreteMapper(domainValues)\n            }\n\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<Color> {\n                return continuous.createContinuousMapper(domain, lowerLimit, upperLimit, trans)\n            }\n        }\n    }\n\n    fun <T> createWithDiscreteOutput(outputValues: List<T>, naValue: T): MapperProvider<T> {\n        return object : MapperProvider<T> {\n            override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n                return GuideMappers.discreteToDiscrete(domainValues, outputValues, naValue)\n            }\n\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<T> {\n                return GuideMappers.continuousToDiscrete(\n                    MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans),\n                    outputValues, naValue\n                )\n            }\n        }\n    }\n\n    @Suppress(\"UNUSED_PARAMETER\")\n    internal fun createObjectIdentity(aes: Aes<Any?>): MapperProvider<Any?> {\n        return object : IdentityDiscreteMapperProvider<Any?>({ it }, null) {\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<Any?> {\n                return GuideMappers.asContinuous { it }\n            }\n        }\n    }\n\n    internal fun createObjectIdentityDiscrete(aes: Aes<Any>): MapperProvider<Any> {\n        val converter: (Any?) -> Any? = { it }\n        return createIdentityMapperProvider(aes, converter, null)\n    }\n\n    internal fun createStringIdentity(aes: Aes<String>): MapperProvider<String> {\n        val converter = { it: Any? -> it?.toString() }\n        val continuousMapper = { it: Double? -> it?.toString() }\n        return createIdentityMapperProvider(\n            aes,\n            converter,\n            continuousMapper\n        )\n    }\n\n    private fun <T> createIdentityMapperProvider(\n        aes: Aes<T>,\n        converter: (Any?) -> T?,\n        continuousMapper: ((Double?) -> T?)?\n    ): MapperProvider<T> {\n        return object : IdentityDiscreteMapperProvider<T>(converter, DefaultNaValue[aes]) {\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<T> {\n                if (continuousMapper != null) {\n                    return GuideMappers.asContinuous(continuousMapper)\n                }\n                throw IllegalStateException(\"Can't create $aes mapper for continuous domain $domain\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\n\nobject DefaultNaValue {\n    private val VALUE_MAP = TypedKeyHashMap()\n\n    init {\n        VALUE_MAP.put(X, 0.0)\n        VALUE_MAP.put(Y, 0.0)\n        VALUE_MAP.put(Z, 0.0)\n        VALUE_MAP.put(YMIN, 0.0)\n        VALUE_MAP.put(YMAX, 0.0)\n        VALUE_MAP.put(COLOR, Color.GRAY)\n        VALUE_MAP.put(FILL, Color.GRAY)\n        VALUE_MAP.put(ALPHA, 0.0)\n        VALUE_MAP.put(SHAPE, TinyPointShape)\n        VALUE_MAP.put(LINETYPE, NamedLineType.SOLID)\n        VALUE_MAP.put(SIZE, AesScaling.sizeFromCircleDiameter(1.0))\n        VALUE_MAP.put(WIDTH, 1.0)\n        VALUE_MAP.put(HEIGHT, 1.0)\n        VALUE_MAP.put(WEIGHT, 1.0)\n        VALUE_MAP.put(INTERCEPT, 0.0)\n        VALUE_MAP.put(SLOPE, 1.0)\n        VALUE_MAP.put(XINTERCEPT, 0.0)\n        VALUE_MAP.put(YINTERCEPT, 0.0)\n        VALUE_MAP.put(LOWER, 0.0)\n        VALUE_MAP.put(MIDDLE, 0.0)\n        VALUE_MAP.put(UPPER, 0.0)\n        VALUE_MAP.put(FRAME, \"empty frame\")\n        VALUE_MAP.put(SPEED, 10.0)\n        VALUE_MAP.put(FLOW, 0.1)\n        VALUE_MAP.put(XMIN, 0.0)\n        VALUE_MAP.put(XMAX, 0.0)\n        VALUE_MAP.put(XEND, 0.0)\n        VALUE_MAP.put(YEND, 0.0)\n        VALUE_MAP.put(LABEL, \"-\")\n        VALUE_MAP.put(FAMILY, \"sans-serif\")\n        VALUE_MAP.put(FONTFACE, \"plain\")\n        VALUE_MAP.put(HJUST, 0.5)  // 'middle'\n        VALUE_MAP.put(VJUST, 0.5)  // 'middle'\n        VALUE_MAP.put(ANGLE, 0.0)\n        VALUE_MAP.put(SYM_X, 0.0)\n        VALUE_MAP.put(SYM_Y, 0.0)\n    }\n\n    /**\n     * For test only (must br TRUE for any Aes)\n     */\n    fun has(aes: Aes<*>): Boolean {\n        return VALUE_MAP.containsKey(aes)\n    }\n\n    operator fun <T> get(aes: Aes<T>): T {\n        return VALUE_MAP[aes]\n    }\n\n    operator fun <T> get(aes: TypedKey<T>): T {\n        return VALUE_MAP[aes]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.provider.MapperProviderBase\n\nabstract class DiscreteOnlyMapperProvider<T>(naValue: T) : MapperProviderBase<T>(naValue) {\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<T> {\n        throw IllegalStateException(\"[${this::class.simpleName}] Can't create mapper for continuous domain $domain\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nclass GuideBreak<DomainT>(val domainValue: DomainT?, val label: String)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.Scales\nimport jetbrains.datalore.plot.base.scale.transform.Transforms\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\n\nclass ScaleProviderBuilder<T>(private val aes: Aes<T>) {\n\n    private var _mapperProvider: MapperProvider<T>? = null\n    private var myName: String? = null\n    private var myBreaks: List<Any>? = null\n    private var myLabels: List<String>? = null\n    private var myLabelFormat: String? = null\n    private var myMultiplicativeExpand: Double? = null\n    private var myAdditiveExpand: Double? = null\n    private var myLimits: List<Any?>? = null\n    private var myContinuousTransform: ContinuousTransform = Transforms.IDENTITY\n    private var myBreaksGenerator: BreaksGenerator? = null\n\n    private var myDiscreteDomain = false\n    private var myDiscreteDomainReverse = false\n\n    var mapperProvider: MapperProvider<T>\n        get() {\n            if (_mapperProvider == null) {\n                _mapperProvider = DefaultMapperProvider[aes]\n            }\n            return _mapperProvider ?: throw AssertionError(\"Set to null by another thread\")\n        }\n        set(p: MapperProvider<T>) {\n            _mapperProvider = p\n        }\n\n    fun mapperProvider(mapperProvider: MapperProvider<T>): ScaleProviderBuilder<T> {\n        this.mapperProvider = mapperProvider\n        return this\n    }\n\n    fun name(name: String): ScaleProviderBuilder<T> {\n        myName = name\n        return this\n    }\n\n    fun breaks(breaks: List<Any>): ScaleProviderBuilder<T> {\n        myBreaks = breaks\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun minorBreaks_NI(\n        @Suppress(\"UNUSED_PARAMETER\") minorBreaks: List<Double>\n    ): ScaleProviderBuilder<T> {\n        // continuous scale\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun labels(labels: List<String>): ScaleProviderBuilder<T> {\n        myLabels = ArrayList(labels)\n        return this\n    }\n\n    fun labelFormat(format: String?): ScaleProviderBuilder<T> {\n        myLabelFormat = format\n        return this\n    }\n\n    fun multiplicativeExpand(v: Double): ScaleProviderBuilder<T> {\n        myMultiplicativeExpand = v\n        return this\n    }\n\n    fun additiveExpand(v: Double): ScaleProviderBuilder<T> {\n        myAdditiveExpand = v\n        return this\n    }\n\n    fun limits(v: List<*>): ScaleProviderBuilder<T> {\n        // Limits for continuous scale : list(min, max)\n        // Limits for discrete scale : list (\"a\", \"b\", \"c\")\n        myLimits = v\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun rescaler_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    @Suppress(\"FunctionName\")\n    fun oob_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun continuousTransform(v: ContinuousTransform): ScaleProviderBuilder<T> {\n        myContinuousTransform = v\n        return this\n    }\n\n    fun breaksGenerator(v: BreaksGenerator): ScaleProviderBuilder<T> {\n        myBreaksGenerator = v\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun guide_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        // Name of guide object, or object itself.\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun discreteDomain(b: Boolean): ScaleProviderBuilder<T> {\n        myDiscreteDomain = b\n        return this\n    }\n\n    fun discreteDomainReverse(b: Boolean): ScaleProviderBuilder<T> {\n        myDiscreteDomainReverse = b\n        return this\n    }\n\n    fun build(): ScaleProvider<T> {\n        return MyScaleProvider(this)\n    }\n\n    private class MyScaleProvider<T>(b: ScaleProviderBuilder<T>) : ScaleProvider<T> {\n\n        private val myName: String? = b.myName\n\n        private val myLabels: List<String>? = b.myLabels?.let { ArrayList(it) }\n        private val myLabelFormat: String? = b.myLabelFormat\n        private val myMultiplicativeExpand: Double? = b.myMultiplicativeExpand\n        private val myAdditiveExpand: Double? = b.myAdditiveExpand\n        private val discreteDomainReverse: Boolean = b.myDiscreteDomainReverse\n        private val myBreaksGenerator: BreaksGenerator? = b.myBreaksGenerator\n        private val myAes: Aes<T> = b.aes\n\n        override val discreteDomain: Boolean = b.myDiscreteDomain\n        override val mapperProvider: MapperProvider<T> = b.mapperProvider\n        override val breaks: List<Any>? = b.myBreaks?.let { ArrayList(it) }\n        override val limits: List<Any?>? = b.myLimits?.let { ArrayList(it) }\n\n        override val continuousTransform: ContinuousTransform = b.myContinuousTransform\n\n        private fun scaleName(variable: DataFrame.Variable): String {\n            return myName ?: variable.label\n        }\n\n        override fun createScale(defaultName: String, discreteDomain: Collection<*>): Scale<T> {\n            val name = myName ?: defaultName\n            var scale: Scale<T>\n\n            // discrete domain\n            var domainValues = discreteDomain.filterNotNull()\n\n            val mapper = if (discreteDomain.isEmpty()) {\n                absentMapper(defaultName)\n            } else {\n                mapperProvider.createDiscreteMapper(domainValues)::apply\n            }\n\n            if (discreteDomainReverse) {\n                domainValues = domainValues.reversed()\n            }\n\n            scale = Scales.discreteDomain(\n                name,\n                domainValues,\n                mapper\n            )\n\n            val discreteLimits = limits?.filterNotNull()?.let {\n                if (discreteDomainReverse) {\n                    it.reversed()\n                } else {\n                    it\n                }\n            }\n            if (discreteLimits != null) {\n                scale = scale.with()\n                    .limits(discreteLimits)\n                    .build()\n            }\n\n            return completeScale(scale)\n        }\n\n        override fun createScale(defaultName: String, continuousDomain: ClosedRange<Double>): Scale<T> {\n            val name = myName ?: defaultName\n            var scale: Scale<T>\n\n            // continuous (numeric) domain\n            val dataRange = ensureApplicableRange(continuousDomain)\n\n            var lowerLimit: Double? = null\n            var upperLimit: Double? = null\n            if (limits != null) {\n                var lower = true\n                for (limit in limits) {\n                    if (limit is Number) {\n                        val v = limit.toDouble()\n                        if (v.isFinite()) {\n                            if (lower) {\n                                lowerLimit = v\n                            } else {\n                                upperLimit = v\n                            }\n                        }\n                    }\n                    lower = false\n                }\n            }\n\n            val mapper = mapperProvider.createContinuousMapper(\n                dataRange,\n                lowerLimit,\n                upperLimit,\n                continuousTransform\n            )\n            val continuousRange = mapper.isContinuous || myAes.isNumeric\n\n            scale = Scales.continuousDomain(name, { v -> mapper.apply(v) }, continuousRange)\n\n            // ToDo: need to 'inverse transform' breaks.\n            if (mapper is WithGuideBreaks<*>) {\n                @Suppress(\"UNCHECKED_CAST\")\n                mapper as WithGuideBreaks<Any>\n                scale = scale.with()\n                    .breaks(mapper.breaks)\n                    .labelFormatter(mapper.formatter)\n                    .build()\n            }\n\n            scale = scale.with()\n                .continuousTransform(continuousTransform)\n                .build()\n\n            if (myBreaksGenerator != null) {\n                scale = scale.with()\n                    .breaksGenerator(myBreaksGenerator)\n                    .build()\n            }\n\n            if (limits != null) {\n                val with = scale.with()\n                if (lowerLimit != null) {\n                    with.lowerLimit(lowerLimit)\n                }\n                if (upperLimit != null) {\n                    with.upperLimit(upperLimit)\n                }\n                scale = with.build()\n            }\n\n            return completeScale(scale)\n        }\n\n\n        private fun completeScale(scale: Scale<T>): Scale<T> {\n            val with = scale.with()\n            if (breaks != null) {\n                with.breaks(breaks)\n            }\n            if (myLabels != null) {\n                with.labels(myLabels)\n            }\n            if (myLabelFormat != null) {\n                with.labelFormatter(StringFormat.create(myLabelFormat)::format)\n            }\n            if (myMultiplicativeExpand != null) {\n                with.multiplicativeExpand(myMultiplicativeExpand)\n            }\n            if (myAdditiveExpand != null) {\n                with.additiveExpand(myAdditiveExpand)\n            }\n            return with.build()\n        }\n\n        private fun absentMapper(`var`: DataFrame.Variable): (Double?) -> T {\n            // mapper for empty data is a special case - should never be used\n            return { v -> throw IllegalStateException(\"Mapper for empty data series '\" + `var`.name + \"' was invoked with arg \" + v) }\n        }\n\n        private fun absentMapper(label: String): (Double?) -> T {\n            // mapper for empty data is a special case - should never be used\n            return { v -> throw IllegalStateException(\"Mapper for empty data series '$label' was invoked with arg \" + v) }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.plot.base.Aes\n\nobject ScaleProviderHelper {\n    fun getOrCreateDefault(aes: Aes<*>, providers: Map<Aes<*>, ScaleProvider<*>>): ScaleProvider<*> {\n        val realAes = when {\n            Aes.isPositionalX(aes) -> Aes.X\n            Aes.isPositionalY(aes) -> Aes.Y\n            else -> aes\n        }\n\n        return providers[realAes] ?: createDefault(realAes)\n    }\n\n    fun <T> createDefault(aes: Aes<T>): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes).build()\n    }\n\n    fun <T> createDefault(aes: Aes<T>, name: String): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes)\n            .name(name)\n            .build()\n    }\n\n    fun <T> create(name: String, aes: Aes<T>, mapperProvider: MapperProvider<T>): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes)\n            .mapperProvider(mapperProvider)\n            .name(name)\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport kotlin.math.abs\n\nobject ColorMapper {\n    val NA_VALUE = Color.GRAY\n\n    // https://ggplot2.tidyverse.org/current/scale_gradient.html\n    val DEF_GRADIENT_LOW = Color.parseHex(\"#132B43\")\n    val DEF_GRADIENT_HIGH = Color.parseHex(\"#56B1F7\")\n\n    fun gradientDefault(domain: ClosedRange<Double>): (Double?) -> Color {\n        return gradient(\n            domain,\n            DEF_GRADIENT_LOW,\n            DEF_GRADIENT_HIGH,\n            NA_VALUE\n        )\n    }\n\n    fun gradient(domain: ClosedRange<Double>, low: Color, high: Color, naColor: Color): (Double?) -> Color {\n        return gradientHSV(\n            domain,\n            Colors.hsvFromRgb(low),\n            Colors.hsvFromRgb(high),\n            true,\n            naColor\n        )\n    }\n\n    /**\n     * @deprecated\n     */\n    fun gradientHSV(\n        domain: ClosedRange<Double>,\n        lowHSV: DoubleArray,\n        highHSV: DoubleArray,\n        autoHueDirection: Boolean,\n        naColor: Color\n    ): (Double?) -> Color {\n        return gradientHSV(\n            domain,\n            HSV(lowHSV[0], lowHSV[1], lowHSV[2]),\n            HSV(highHSV[0], highHSV[1], highHSV[2]),\n            autoHueDirection,\n            naColor\n        )\n    }\n\n    fun gradientHSV(\n        domain: ClosedRange<Double>,\n        lowHSV: HSV,\n        highHSV: HSV,\n        autoHueDirection: Boolean,\n        naColor: Color\n    ): (Double?) -> Color {\n\n        var lowHue = lowHSV.h\n        var highHue = highHSV.h\n\n        val lowS = lowHSV.s\n        val highS = highHSV.s\n\n        // No hue if saturation is near zero\n        if (lowS < 0.0001) {\n            lowHue = highHue\n        }\n        if (highS < 0.0001) {\n            highHue = lowHue\n        }\n\n        if (autoHueDirection) {\n            val dH = abs(highHue - lowHue)\n            if (dH > 180) {\n                if (highHue >= lowHue) {\n                    lowHue += 360.0\n                } else {\n                    highHue += 360.0\n                }\n            }\n        }\n\n        val mapperH = Mappers.linear(domain, lowHue, highHue, Double.NaN)\n        val mapperS = Mappers.linear(domain, lowS, highS, Double.NaN)\n        val mapperV = Mappers.linear(domain, lowHSV.v, highHSV.v, Double.NaN)\n\n        return { input ->\n            if (input == null || !domain.contains(input)) {\n                naColor\n            } else {\n                val hue = mapperH(input) % 360\n                val H = if (hue >= 0) hue else 360 + hue\n                val S = mapperS(input)\n                val V = mapperV(input)\n                Colors.rgbFromHsv(H, S, V)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\ninternal class GuideMapperAdapter<T> constructor(\n    private val mapper: (Double?) -> T?,\n    override val isContinuous: Boolean\n) : GuideMapper<T> {\n\n    override fun apply(value: Double?): T? {\n        return mapper(value)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.WithGuideBreaks\n\ninternal class GuideMapperWithGuideBreaks<DomainT, TargetT>(\n    private val mapper: (Double?) -> TargetT?,\n    override val breaks: List<DomainT>,\n    override val formatter: (DomainT) -> String\n) : GuideMapper<TargetT>,\n    WithGuideBreaks<DomainT> {\n\n    override val isContinuous = false\n\n    override fun apply(value: Double?): TargetT? {\n        return mapper(value)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\nobject GuideMappers {\n    val IDENTITY: GuideMapper<Double> =\n        GuideMapperAdapter(Mappers.IDENTITY, isContinuous = false) // ToDo: why isContinuous = false?\n    val UNDEFINED: GuideMapper<Double> =\n        GuideMapperAdapter(Mappers.undefined(), false)\n\n    fun <TargetT> discreteToDiscrete(\n        data: DataFrame,\n        variable: DataFrame.Variable,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n\n        val domainValues = data.distinctValues(variable)\n        return discreteToDiscrete(\n            domainValues,\n            outputValues,\n            naValue\n        )\n    }\n\n    fun <TargetT> discreteToDiscrete(\n        domainValues: Collection<*>,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n\n        val mapper = Mappers.discrete(outputValues, naValue)\n        return GuideMapperWithGuideBreaks(\n            mapper,\n            domainValues.mapNotNull { it }\n        ) { v: Any -> v.toString() }\n    }\n\n    fun <TargetT> continuousToDiscrete(\n        domain: ClosedRange<Double>?,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n        // quantized\n        val mapper = Mappers.quantized(domain, outputValues, naValue)\n        return asNotContinuous(mapper)\n    }\n\n    fun discreteToContinuous(\n        domainValues: Collection<*>,\n        outputRange: ClosedRange<Double>,\n        naValue: Double\n    ): GuideMapper<Double> {\n\n        val mapper = Mappers.discreteToContinuous(domainValues, outputRange, naValue)\n        return GuideMapperWithGuideBreaks(\n            mapper,\n            domainValues.mapNotNull { it }\n        ) { v: Any -> v.toString() }\n    }\n\n    fun continuousToContinuous(\n        domain: ClosedRange<Double>,\n        range: ClosedRange<Double>,\n        naValue: Double\n    ): GuideMapper<Double> {\n        return asContinuous(\n            Mappers.linear(\n                domain,\n                range,\n                naValue\n            )\n        )\n    }\n\n    fun <T> asNotContinuous(mapper: (Double?) -> T): GuideMapper<T> {\n        return GuideMapperAdapter(mapper, false)\n    }\n\n    fun <T> asContinuous(mapper: (Double?) -> T?): GuideMapper<T> {\n        return GuideMapperAdapter(mapper, true)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\n\nobject LineTypeMapper {\n    val NA_VALUE: LineType = NamedLineType.SOLID\n\n    fun allLineTypes(): List<LineType> {\n        return listOf(\n                NamedLineType.SOLID,\n                NamedLineType.DASHED,\n                NamedLineType.DOTTED,\n                NamedLineType.DOTDASH,\n                NamedLineType.LONGDASH,\n                NamedLineType.TWODASH\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\n\nobject ShapeMapper {\n    val NA_VALUE = TinyPointShape\n\n    fun allShapes(): List<PointShape> {\n        val bestSix: List<PointShape> = listOf(\n                NamedShape.SOLID_CIRCLE,\n                NamedShape.SOLID_TRIANGLE_UP,\n                NamedShape.SOLID_SQUARE,\n                NamedShape.STICK_PLUS,\n                NamedShape.STICK_SQUARE_CROSS,\n                NamedShape.STICK_STAR\n        )\n\n        val theRest = LinkedHashSet<PointShape>(listOf(*NamedShape.values()))\n        theRest.removeAll(bestSix)\n\n        val shapes = ArrayList(bestSix)\n        shapes.addAll(theRest)\n        return shapes\n    }\n\n    /**\n     * see: scale_shape(..., solid = FALSE)\n     */\n    fun hollowShapes(): List<PointShape> {\n        val bestThreeHollow = listOf(\n                NamedShape.STICK_CIRCLE,\n                NamedShape.STICK_TRIANGLE_UP,\n                NamedShape.STICK_SQUARE\n        )\n\n        val theRest = LinkedHashSet(listOf(*NamedShape.values()))\n        theRest.removeAll(bestThreeHollow)\n\n        val shapes = ArrayList(bestThreeHollow)\n        for (shape in theRest) {\n            if (shape.isHollow) {\n                shapes.add(shape)\n            }\n        }\n        return shapes\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.builder.scale.DefaultNaValue\n\nclass AlphaMapperProvider(\n    range: ClosedRange<Double>,\n    naValue: Double\n) : LinearNormalizingMapperProvider(range, naValue) {\n\n    companion object {\n        private val DEF_RANGE = ClosedRange(0.1, 1.0)\n\n        val DEFAULT = AlphaMapperProvider(\n            DEF_RANGE,\n            DefaultNaValue[ALPHA]\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Lists\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.color.ColorPalette\nimport jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.Set2\nimport jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.Set3\nimport jetbrains.datalore.plot.common.color.ColorPalette.Type.*\nimport jetbrains.datalore.plot.common.color.ColorScheme\nimport jetbrains.datalore.plot.common.color.PaletteUtil\nimport jetbrains.datalore.plot.common.color.PaletteUtil.colorSchemeByIndex\n\n\n/**\n * @param paletteTypeName - One of seq (sequential), div (diverging) or qual (qualitative)\n * @param paletteNameOrIndex - If a string, will use that named palette.\n * If a number, will index into the list of palettes of appropriate type\n * @param direction - Sets the order of colors in the scale. If 1, the default, colors are as output by brewer.pal.\n * If -1, the order of colors is reversed\n * @param naValue\n */\nclass ColorBrewerMapperProvider(\n    private val paletteTypeName: String?,\n    private val paletteNameOrIndex: Any?,\n    private val direction: Double?,\n    naValue: Color\n) : MapperProviderBase<Color>(naValue) {\n\n    init {\n        require(paletteNameOrIndex?.let {\n            paletteNameOrIndex is String || paletteNameOrIndex is Number\n        } ?: true) {\n            \"palette: expected a name or index but was: ${paletteNameOrIndex!!::class.simpleName}\"\n        }\n\n        if (paletteNameOrIndex is Number) {\n            require(paletteTypeName != null) { \"brewer palette type required: 'seq', 'div' or 'qual'.\" }\n        }\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        val colorScheme = colorScheme(true, domainValues.size)\n        val colors = colors(colorScheme, domainValues.size)\n        return GuideMappers.discreteToDiscrete(domainValues, colors, naValue)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        val colorScheme = colorScheme(false)\n        val colors = colors(colorScheme, colorScheme.maxColors)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return GuideMappers.continuousToDiscrete(domain, colors, naValue)\n    }\n\n    private fun colors(colorScheme: ColorScheme, count: Int): List<Color> {\n        val colors: List<Color> = PaletteUtil.schemeColors(colorScheme, count)\n        return when (direction?.let { direction < 0 } ?: false) {\n            true -> Lists.reverse(colors)\n            false -> colors\n        }\n    }\n\n    private fun colorScheme(discrete: Boolean, colorCount: Int? = null): ColorScheme {\n        val paletteType = when {\n            paletteNameOrIndex is String -> {\n                val palType = PaletteUtil.paletteTypeByPaletteName(paletteNameOrIndex)\n                require(palType != null) { cantFindPaletteError(paletteNameOrIndex) }\n                palType\n            }\n            paletteTypeName != null -> paletteType(paletteTypeName)\n            discrete -> QUALITATIVE\n            else -> SEQUENTIAL\n        }\n\n        return when {\n            paletteNameOrIndex is Number -> colorSchemeByIndex(paletteType, paletteNameOrIndex.toInt())\n            paletteNameOrIndex is String -> colorSchemeByName(paletteType, paletteNameOrIndex)\n            paletteType == QUALITATIVE -> {\n                if (colorCount != null && colorCount <= Set2.maxColors) Set2\n                else Set3\n            }\n            else -> colorSchemeByIndex(paletteType, 0)\n        }\n    }\n\n\n    companion object {\n        private fun paletteType(name: String?): ColorPalette.Type {\n            if (name == null) {\n                return SEQUENTIAL\n            }\n            return when (name) {\n                \"seq\" -> SEQUENTIAL\n                \"div\" -> DIVERGING\n                \"qual\" -> QUALITATIVE\n                else -> throw IllegalArgumentException(\n                    \"Palette type expected one of 'seq' (sequential), 'div' (diverging) or 'qual' (qualitative) but was: '$name'\"\n                )\n            }\n        }\n\n        private fun colorSchemeByName(paletteType: ColorPalette.Type, paletteName: String): ColorScheme {\n            try {\n                return when (paletteType) {\n                    SEQUENTIAL -> ColorPalette.Sequential.valueOf(paletteName)\n                    DIVERGING -> ColorPalette.Diverging.valueOf(paletteName)\n                    QUALITATIVE -> ColorPalette.Qualitative.valueOf(paletteName)\n                }\n            } catch (ignore: IllegalArgumentException) {\n                // Enum type has no constant with the specified name error.\n                // Replace generic error massage with specific one\n                throw IllegalArgumentException(cantFindPaletteError(paletteName))\n            }\n        }\n\n        private fun cantFindPaletteError(paletteName: String): String {\n            return \"\"\"\n                |Brewer palette '$paletteName' was not found. \n                |Valid palette names are: \n                |   Type 'seq' (sequential): \n                |       ${names(ColorPalette.Sequential.values())}       \n                |   Type 'div' (diverging): \n                |       ${names(ColorPalette.Diverging.values())}       \n                |   Type 'qual' (qualitative): \n                |       ${names(ColorPalette.Qualitative.values())}       \n            \"\"\".trimMargin()\n        }\n\n        private fun <T : Enum<T>> names(enums: Array<T>): String {\n            return enums.joinToString(\", \") { \"'${it.name}'\" }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.ContinuousOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass ColorGradient2MapperProvider(\n    low: Color?, mid: Color?, high: Color?, midpoint: Double?, naValue: Color\n) : ContinuousOnlyMapperProvider<Color>(naValue) {\n\n    private val myLow: Color\n    private val myMid: Color\n    private val myHigh: Color\n    private val myMidpoint: Double?\n\n    init {\n        myLow = low ?: DEF_GRADIENT_LOW\n        myMid = mid ?: DEF_GRADIENT_MID\n        myHigh = high ?: DEF_GRADIENT_HIGH\n        myMidpoint = midpoint ?: 0.0\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n\n        val lowDomain = ClosedRange(domain.lowerEnd, max(myMidpoint!!, domain.lowerEnd))\n        val highDomain = ClosedRange(min(myMidpoint, domain.upperEnd), domain.upperEnd)\n\n        val lowMapper = ColorMapper.gradient(lowDomain, myLow, myMid, naValue)\n        val highMapper = ColorMapper.gradient(highDomain, myMid, myHigh, naValue)\n\n        val rangeMap = mapOf(\n            lowDomain to lowMapper,\n            highDomain to highMapper\n        )\n\n        fun getMapper(v: Double?): ((Double?) -> Color)? {\n            var f_: ((Double?) -> Color)? = null\n            if (SeriesUtil.isFinite(v)) {\n                var f_span = Double.NaN\n                for (range in rangeMap.keys) {\n                    if (range.contains(v!!)) {\n                        val span = range.upperEnd - range.lowerEnd\n                        // try to avoid 0-length ranges\n                        // but prefer shorter ranges\n                        if (f_ == null || f_span == 0.0) {\n                            f_ = rangeMap.get(range)\n                            f_span = span\n                        } else if (span < f_span && span > 0) {\n                            f_ = rangeMap.get(range)\n                            f_span = span\n                        }\n                    }\n                }\n            }\n            return f_\n        }\n\n        val mapperFun: (Double?) -> Color = { input: Double? ->\n            val mapper = getMapper(input)\n            mapper?.invoke(input) ?: naValue\n        }\n\n        return GuideMappers.asContinuous(mapperFun)\n    }\n\n    companion object {\n        // https://ggplot2.tidyverse.org/current/scale_gradient.html\n        private val DEF_GRADIENT_LOW = Color.parseHex(\"#964540\") // muted(\"red\")\n        private val DEF_GRADIENT_MID = Color.WHITE\n        private val DEF_GRADIENT_HIGH = Color.parseHex(\"#3B3D96\") // muted(\"blue\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n\nclass ColorGradientMapperProvider(low: Color?, high: Color?, naValue: Color) : MapperProviderBase<Color>(naValue) {\n\n    private val low: Color = low ?: ColorMapper.DEF_GRADIENT_LOW\n    private val high: Color = high ?: ColorMapper.DEF_GRADIENT_HIGH\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        val domainValuesAsNumbers = MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val mapperDomain = SeriesUtil.range(domainValuesAsNumbers.values)!!\n        val gradient = ColorMapper.gradient(mapperDomain, low, high, naValue)\n        return GuideMappers.asNotContinuous(gradient)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        val gradient = ColorMapper.gradient(domain, low, high, naValue)\n        return GuideMappers.asContinuous(gradient)\n    }\n\n    companion object {\n        val DEFAULT = ColorGradientMapperProvider(\n            null,\n            null,\n            ColorMapper.NA_VALUE\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass ColorHueMapperProvider(\n    hueRange: List<Double>?,\n    chroma: Double?,\n    luminance: Double?,\n    startHue: Double?,\n    direction: Double?,\n    naValue: Color\n) : HSVColorMapperProvider(naValue) {\n\n    private val myFromHSV: HSV\n    private val myToHSV: HSV\n    private val myHSVIntervals: List<Pair<HSV, HSV>>\n\n    init {\n        @Suppress(\"NAME_SHADOWING\")\n        val hueRange = normalizeHueRange(hueRange)\n        val clockwise = direction == null || direction != -1.0\n\n        val fromHue = if (clockwise) hueRange.lowerEnd else hueRange.upperEnd\n        val toHue = if (clockwise) hueRange.upperEnd else hueRange.lowerEnd\n\n        @Suppress(\"NAME_SHADOWING\")\n        val startHue = startHue ?: DEF_START_HUE\n\n        val hueIntervals = if (hueRange.contains(startHue) &&\n            startHue - hueRange.lowerEnd > 1 && hueRange.upperEnd - startHue > 1\n        ) {\n            listOf(\n                startHue to toHue,\n                fromHue to startHue\n            )\n        } else {\n            listOf(\n                fromHue to toHue\n            )\n        }\n\n        val saturation = (if (chroma != null) chroma % 100 else DEF_SATURATION) / 100\n        val value = (if (luminance != null) luminance % 100 else DEF_VALUE) / 100\n\n        // for continuous data\n        myHSVIntervals = hueIntervals.map { HSV(it.first, saturation, value) to HSV(it.second, saturation, value) }\n\n        // for discrete data: 'startHue' is ignored (intervals not used)\n        myFromHSV = HSV(fromHue, saturation, value)\n        myToHSV = HSV(toHue, saturation, value)\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        return createDiscreteMapper(domainValues, myFromHSV, myToHSV)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return createContinuousMapper(domain, myHSVIntervals)\n    }\n\n    companion object {\n        private const val DEF_SATURATION = 50.0\n        private const val DEF_VALUE = 90.0\n        private const val DEF_START_HUE = 0.0\n        private val DEF_HUE_RANGE = ClosedRange<Double>(15.0, 375.0) // ggplot2 (R): c(0, 360) + 15\n\n        val DEFAULT = ColorHueMapperProvider(\n            null,\n            null,\n            null,\n            null,\n            null,\n            Color.GRAY\n        )\n\n        private fun normalizeHueRange(hueRange: List<Double>?): ClosedRange<Double> {\n            return if (hueRange == null || hueRange.size != 2) {\n                DEF_HUE_RANGE\n            } else {\n                ClosedRange<Double>(\n                    min(hueRange[0], hueRange[1]),\n                    max(hueRange[0], hueRange[1])\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.ContinuousOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\n/**\n * @param naValue value used when size is not defined\n */\nopen class DirectlyProportionalMapperProvider(\n    private val max: Double,\n    naValue: Double\n) : ContinuousOnlyMapperProvider<Double>(naValue) {\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Double> {\n        val dataMax = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans).upperEnd\n        return GuideMappers.continuousToContinuous(ClosedRange(0.0, dataMax), ClosedRange(0.0, max), naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\nclass GreyscaleLightnessMapperProvider(\n    start: Double?,\n    end: Double?,\n    naValue: Color\n) : HSVColorMapperProvider(naValue) {\n\n    private val myFromHSV: HSV\n    private val myToHSV: HSV\n\n    init {\n        val value0 = start ?: DEF_START\n        val value1 = end ?: DEF_END\n\n        require(value0 in (0.0..1.0)) { \"Value of 'start' must be in range: [0,1]: $start\" }\n        require(value1 in (0.0..1.0)) { \"Value of 'end' must be in range: [0,1]: $end\" }\n\n        myFromHSV = HSV(0.0, 0.0, value0)\n        myToHSV = HSV(0.0, 0.0, value1)\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        return createDiscreteMapper(domainValues, myFromHSV, myToHSV)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return createContinuousMapper(\n            domain,\n            listOf(myFromHSV to myToHSV)\n        )\n    }\n\n    companion object {\n        private const val DEF_START = 0.2\n        private const val DEF_END = 0.8\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\nimport kotlin.math.abs\n\nabstract class HSVColorMapperProvider(naValue: Color) : MapperProviderBase<Color>(naValue) {\n\n    protected fun createDiscreteMapper(\n        domainValues: Collection<*>,\n        fromHSV: HSV,\n        toHSV: HSV\n    ): GuideMapper<Color> {\n        val domainValuesAsNumbers = MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val mapperDomain = ensureApplicableRange(SeriesUtil.range(domainValuesAsNumbers.values))\n\n        var newFromHue = fromHSV.h\n        var newToHue = toHSV.h\n        if (domainValues.size > 1) {\n            // if 'from' and 'to' hue are too close - ajust the 'toHue'\n            val hueDiff = abs(toHSV.h % 360 - fromHSV.h % 360)\n            val step = (toHSV.h - fromHSV.h) / domainValues.size\n            if (hueDiff < abs(step) / 2) {\n                newFromHue = fromHSV.h + step / 2\n                newToHue = toHSV.h - step / 2\n            }\n        }\n\n        val gradient = ColorMapper.gradientHSV(\n            mapperDomain,\n            HSV(newFromHue, fromHSV.s, fromHSV.v),\n            HSV(newToHue, toHSV.s, toHSV.v),\n            false, naValue\n        )\n        return GuideMappers.asNotContinuous(gradient)\n    }\n\n    protected fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        hsvIntervals: List<Pair<HSV, HSV>>\n    ): GuideMapper<Color> {\n        val gradientMapper = when (hsvIntervals.size) {\n            0 -> throw IllegalArgumentException(\"Empty HSV intervals.\")\n            1 -> ColorMapper.gradientHSV(domain, hsvIntervals[0].first, hsvIntervals[0].second, false, naValue)\n            else -> createCompositeColorMapper(domain, hsvIntervals, false, naValue)\n        }\n\n        return GuideMappers.asContinuous(gradientMapper)\n    }\n\n\n    companion object {\n        private fun createCompositeColorMapper(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>,\n            autoHueDirection: Boolean,\n            naColor: Color\n        ): (Double?) -> Color {\n            val colorMappersPerSubDomain =\n                createColorMappersPerSubDomain(domain, hsvIntervals, autoHueDirection, naColor)\n\n            return { v: Double? ->\n                if (v == null) {\n                    naColor\n                } else {\n                    val mapper = colorMappersPerSubDomain.find { it.first.contains(v) }?.second\n                    mapper?.invoke(v) ?: naColor\n                }\n            }\n        }\n\n        private fun createColorMappersPerSubDomain(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>,\n            autoHueDirection: Boolean,\n            naColor: Color\n        ): List<Pair<ClosedRange<Double>, (Double?) -> Color>> {\n            val subDomains = splitContinuousDomain(domain, hsvIntervals)\n\n            return subDomains.zip(hsvIntervals).map {\n                @Suppress(\"NAME_SHADOWING\")\n                val domain = it.first\n                val hsvInterval = it.second\n                Pair(\n                    domain,\n                    ColorMapper.gradientHSV(domain, hsvInterval.first, hsvInterval.second, autoHueDirection, naColor)\n                )\n            }\n        }\n\n        private fun splitContinuousDomain(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>\n        ): List<ClosedRange<Double>> {\n            val domainSize = domain.upperEnd - domain.lowerEnd\n            val hueIntervalSizeList = hsvIntervals.map {\n                abs(it.first.h - it.second.h)\n            }\n            val hueIntervalsTotalSize = hueIntervalSizeList.sum()\n\n            val domainToHueIntevalRatio = domainSize / hueIntervalsTotalSize\n\n            val subDomains = ArrayList<ClosedRange<Double>>()\n            var lowerEnd = domain.lowerEnd\n            for (hueIntervalSize in hueIntervalSizeList) {\n                val upperEnd = lowerEnd + hueIntervalSize * domainToHueIntevalRatio\n                subDomains.add(ClosedRange(lowerEnd, upperEnd))\n                lowerEnd = upperEnd\n            }\n            return subDomains\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.builder.scale.DiscreteOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nopen class IdentityDiscreteMapperProvider<T>(\n    private val inputConverter: (Any?) -> T?,\n    naValue: T\n) : DiscreteOnlyMapperProvider<T>(naValue) {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        val outputValues = ArrayList<T>()\n        for (inputValue in domainValues) {\n            if (inputValue == null) {\n                outputValues.add(naValue)\n            } else {\n                val outputValue = inputConverter(inputValue)\n                    ?: throw IllegalStateException(\"Can't map input value $inputValue to output type\")\n                outputValues.add(outputValue)\n            }\n        }\n        return GuideMappers.discreteToDiscrete(domainValues, outputValues, naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.MapperProvider\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nclass IdentityMapperProvider<T>(\n    private val discreteMapperProvider: IdentityDiscreteMapperProvider<T>,\n    private val continuousMapper: (Double?) -> T?\n) : MapperProvider<T> {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        return discreteMapperProvider.createDiscreteMapper(domainValues)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<T> {\n        return GuideMappers.asContinuous(continuousMapper)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nopen class LinearNormalizingMapperProvider(\n    private val outputRange: ClosedRange<Double>,\n    naValue: Double\n) : MapperProviderBase<Double>(naValue) {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n        return GuideMappers.discreteToContinuous(domainValues, outputRange, naValue)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Double> {\n        val dataRange = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return GuideMappers.continuousToContinuous(dataRange, outputRange, naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.builder.scale.MapperProvider\n\nabstract class MapperProviderBase<T>(protected val naValue: T) : MapperProvider<T>\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.base.aes.AesScaling\n\nclass SizeAreaMapperProvider(\n    max: Double?,\n    naValue: Double\n) : DirectlyProportionalMapperProvider(max ?: DEF_MAX, naValue) {\n\n    companion object {\n        val DEF_MAX = AesScaling.sizeFromCircleDiameter(21.0)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.builder.scale.DefaultNaValue\n\nclass SizeMapperProvider(\n    range: ClosedRange<Double>,\n    naValue: Double\n) : LinearNormalizingMapperProvider(range, naValue) {\n\n    companion object {\n        private val DEF_RANGE = ClosedRange(\n            AesScaling.sizeFromCircleDiameter(3.0),\n            AesScaling.sizeFromCircleDiameter(21.0)\n        )\n\n        val DEFAULT = SizeMapperProvider(\n            DEF_RANGE,\n            DefaultNaValue[SIZE]\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\ninterface AxisTheme {\n    fun showLine(): Boolean\n\n    fun showTickMarks(): Boolean\n\n    fun showTickLabels(): Boolean\n\n    fun showTitle(): Boolean\n\n    fun showTooltip(): Boolean\n\n    fun lineWidth(): Double\n\n    fun tickMarkWidth(): Double\n\n    fun tickMarkLength(): Double\n\n    fun tickMarkPadding(): Double\n\n    fun tickLabelDistance(): Double {\n        var result = tickMarkPadding()  // little space always\n        if (showTickMarks()) {\n            result += tickMarkLength()\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot\n\nopen class DefaultAxisTheme : AxisTheme {\n    override fun showLine(): Boolean {\n        return true\n    }\n\n    override fun showTickMarks(): Boolean {\n        return true\n    }\n\n    override fun showTickLabels(): Boolean {\n        return true\n    }\n\n    override fun showTitle(): Boolean {\n        return true\n    }\n\n    override fun showTooltip(): Boolean {\n        return true\n    }\n\n    override fun lineWidth(): Double {\n        return Plot.Axis.LINE_WIDTH\n    }\n\n    override fun tickMarkWidth(): Double {\n        return Plot.Axis.TICK_LINE_WIDTH\n    }\n\n    override fun tickMarkLength(): Double {\n        return 6.0\n    }\n\n    override fun tickMarkPadding(): Double {\n        return 3.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors\nimport jetbrains.datalore.plot.builder.guide.LegendDirection\nimport jetbrains.datalore.plot.builder.guide.LegendJustification\nimport jetbrains.datalore.plot.builder.guide.LegendPosition\n\n\nopen class DefaultTheme : Theme {\n\n    override fun axisX(): AxisTheme {\n        return AXIS_THEME\n    }\n\n    override fun axisY(): AxisTheme {\n        return AXIS_THEME\n    }\n\n    override fun legend(): LegendTheme {\n        return LEGEND_THEME\n    }\n\n    override fun facets(): FacetsTheme {\n        return FACETS_THEME\n    }\n\n    override fun plot(): PlotTheme {\n        return PLOT_THEME\n    }\n\n    override fun multiTile(): Theme {\n        return object : DefaultTheme() {\n            override fun axisX(): AxisTheme {\n                return AXIS_THEME_MULTI_TILE\n            }\n\n            override fun axisY(): AxisTheme {\n                return AXIS_THEME_MULTI_TILE\n            }\n\n            override fun plot(): PlotTheme {\n                return PLOT_THEME_MULTI_TILE\n            }\n        }\n    }\n\n    companion object {\n        private val AXIS_THEME = DefaultAxisTheme()\n\n        private val AXIS_THEME_MULTI_TILE: AxisTheme = object : DefaultAxisTheme() {\n            override fun showLine(): Boolean {\n                return false  // replaced by inner frame\n            }\n        }\n\n        private val LEGEND_THEME: LegendTheme = object : LegendTheme {\n            override fun keySize(): Double {\n                return 23.0\n            }\n\n            override fun margin(): Double {\n                return 5.0\n            }\n\n            override fun padding(): Double {\n                return 5.0\n            }\n\n            override fun position(): LegendPosition {\n                return LegendPosition.RIGHT\n            }\n\n            override fun justification(): LegendJustification {\n                return LegendJustification.CENTER\n            }\n\n            override fun direction(): LegendDirection {\n                return LegendDirection.AUTO\n            }\n\n            override fun backgroundFill(): Color {\n                return Color.WHITE\n            }\n        }\n\n        private val FACETS_THEME: FacetsTheme = object : FacetsTheme {\n            override fun labelBackground(): Color {\n                return Colors.lighter(Color.VERY_LIGHT_GRAY, 0.9)\n            }\n        }\n\n        private val PLOT_THEME: PlotTheme = object : PlotTheme {\n            override fun showInnerFrame(): Boolean {\n                return false\n            }\n\n            override fun innerFrameColor(): Color {\n                throw IllegalStateException(\"The `innerFrameColor()` method shouldn't be used.\")\n            }\n        }\n\n        private val PLOT_THEME_MULTI_TILE: PlotTheme = object : PlotTheme {\n            override fun showInnerFrame(): Boolean {\n                return true\n            }\n\n            override fun innerFrameColor(): Color {\n                return Colors.lighter(Color.VERY_LIGHT_GRAY, 0.9)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass ConstantValue(\n    private val value: Any,\n    private val format: String? = null\n) : ValueSource {\n\n    private val myDataValue = if (format != null) {\n        StringFormat.create(format).format(value)\n    } else {\n        value.toString()\n    }\n\n    override val isOutlier: Boolean = false\n    override val isAxis: Boolean = false\n\n    override fun initDataContext(dataContext: DataContext) {\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        return DataPoint(\n            label = \"\",\n            value = myDataValue,\n            aes = null,\n            isAxis = false,\n            isOutlier = false\n        )\n    }\n\n    override fun copy(): ConstantValue {\n        return ConstantValue(\n            value,\n            format\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass DataFrameValue(\n    private val name: String,\n    private val format: String? = null\n) : ValueSource {\n\n    private lateinit var myDataFrame: DataFrame\n    private lateinit var myVariable: DataFrame.Variable\n    private val myFormatter = format?.let {\n//        StringFormat(format).also {\n//            require(it.argsNumber == 1) { \"Wrong number of arguments in pattern \\'$format\\' to format \\'$name\\'. Expected 1 argument instead of ${it.argsNumber}\" }\n//        }\n        StringFormat.forOneArg(format, formatFor = name)\n    }\n\n    override val isOutlier: Boolean = false\n    override val isAxis: Boolean = false\n\n    override fun initDataContext(dataContext: DataContext) {\n        require(!::myDataFrame.isInitialized) { \"Data context can be initialized only once\" }\n        myDataFrame = dataContext.dataFrame\n\n        myVariable = DataFrameUtil.findVariableOrFail(myDataFrame, name)\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val originalValue = myDataFrame[myVariable][index] ?: return null\n        return DataPoint(\n            label = name,\n            value = myFormatter?.format(originalValue) ?: originalValue.toString(),\n            aes = null,\n            isAxis = false,\n            isOutlier = false\n        )\n    }\n\n    override fun copy(): DataFrameValue {\n        return DataFrameValue(name, format)\n    }\n\n    fun getVariableName(): String {\n        return name\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass MappingValue(\n    val aes: Aes<*>,\n    override val isOutlier: Boolean = false,\n    override val isAxis: Boolean = false,\n    private val format: String? = null\n) : ValueSource {\n\n    private lateinit var myDataAccess: MappedDataAccess\n    private var myDataLabel: String? = null\n    private val myFormatter = format?.let {\n//        StringFormat(format).also {\n//            require(it.argsNumber == 1) { \"Wrong number of arguments in pattern \\'$format\\' to format \\'${aes.name}\\'. Expected 1 argument instead of ${it.argsNumber}\" }\n//        }\n        StringFormat.forOneArg(format, formatFor = aes.name)\n    }\n\n    override fun initDataContext(dataContext: DataContext) {\n        require(!::myDataAccess.isInitialized) { \"Data context can be initialized only once\" }\n        myDataAccess = dataContext.mappedDataAccess\n\n        require(myDataAccess.isMapped(aes)) { \"$aes have to be mapped\" }\n\n        val axisLabels = listOf(Aes.X, Aes.Y)\n            .filter(myDataAccess::isMapped)\n            .map(myDataAccess::getMappedDataLabel)\n        val dataLabel = myDataAccess.getMappedDataLabel(aes)\n        myDataLabel = when {\n            isAxis -> null\n            dataLabel.isEmpty() -> \"\"\n            dataLabel in axisLabels -> \"\"\n            else -> dataLabel\n        }\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val originalValue = myDataAccess.getOriginalValue(aes, index)\n        val formattedValue =\n            originalValue?.let { myFormatter?.format(it) } ?: myDataAccess.getMappedData(aes, index).value\n\n        // for outliers: myDataLabel is a part of the value, but pattern format removes this part\n        val value = if (isOutlier && !myDataLabel.isNullOrEmpty() &&\n            myFormatter?.formatType != StringFormat.FormatType.STRING_FORMAT\n        ) {\n            \"$myDataLabel: $formattedValue\"\n        } else {\n            formattedValue\n        }\n\n        return DataPoint(\n            label = if (isOutlier) null else myDataLabel,\n            value = value,\n            aes = aes,\n            isAxis = isAxis,\n            isOutlier = isOutlier\n        )\n    }\n\n    override fun copy(): MappingValue {\n        return MappingValue(\n            aes = aes,\n            isOutlier = isOutlier,\n            isAxis = isAxis,\n            format = format\n        )\n    }\n\n    fun toOutlier(): MappingValue {\n        return MappingValue(\n            aes = aes,\n            isOutlier = true,\n            isAxis = isAxis,\n            format = format\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.base.stringFormat.StringFormat.FormatType.STRING_FORMAT\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass TooltipLine(\n    private val label: String?,\n    private val pattern: String,\n    val fields: List<ValueSource>\n) : TooltipLineSpec {\n    constructor(other: TooltipLine) : this(other.label, other.pattern, other.fields.map(ValueSource::copy))\n\n    //    private val myLineFormatter = StringFormat(pattern, STRING_FORMAT).also {\n//        require(it.argsNumber == fields.size) { \"Wrong number of arguments in pattern \\'$pattern\\' to format fields. Expected ${fields.size} arguments instead of ${it.argsNumber}\" }\n//    }\n    private val myLineFormatter = StringFormat.forNArgs(pattern, STRING_FORMAT, fields.size, \"fields\")\n\n    fun initDataContext(dataContext: DataContext) {\n        fields.forEach { it.initDataContext(dataContext) }\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val dataValues = fields.map { dataValue ->\n            dataValue.getDataPoint(index) ?: return null\n        }\n        return if (dataValues.size == 1) {\n            val dataValue = dataValues.single()\n            DataPoint(\n                label = chooseLabel(dataValue.label),\n                value = myLineFormatter.format(dataValue.value),\n                aes = dataValue.aes,\n                isAxis = dataValue.isAxis,\n                isOutlier = dataValue.isOutlier\n            )\n        } else {\n            DataPoint(\n                label = chooseLabel(dataValues.joinToString(\", \") { it.label ?: \"\" }),\n                value = myLineFormatter.format(dataValues.map { it.value }),\n                aes = null,\n                isAxis = false,\n                isOutlier = false\n            )\n        }\n    }\n\n    private fun chooseLabel(dataLabel: String?): String? {\n        return when (label) {\n            DEFAULT_LABEL_SPECIFIER -> dataLabel    // use default label (from data)\n            else -> label                     // use the given label (can be null)\n        }\n    }\n\n    companion object {\n        fun defaultLineForValueSource(valueSource: ValueSource): TooltipLine = TooltipLine(\n            label = DEFAULT_LABEL_SPECIFIER,\n            pattern = StringFormat.valueInLinePattern(),\n            fields = listOf(valueSource)\n        )\n\n        private const val DEFAULT_LABEL_SPECIFIER = \"@\"\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.TooltipAnchor\n\nclass TooltipSpecification(\n    val valueSources: List<ValueSource>,\n    val tooltipLinePatterns: List<TooltipLine>?,\n    val tooltipProperties: TooltipProperties\n) {\n    class TooltipProperties(\n        val anchor: TooltipAnchor?,\n        val minWidth: Double?,\n        val color: Color?\n    ) {\n        companion object {\n            val NONE = TooltipProperties(\n                anchor = null,\n                minWidth = null,\n                color = null\n            )\n        }\n    }\n\n    companion object {\n        fun withoutTooltip() = TooltipSpecification(\n            valueSources = emptyList(),\n            tooltipLinePatterns = emptyList(),\n            tooltipProperties = TooltipProperties.NONE\n        )\n\n        fun defaultTooltip() = TooltipSpecification(\n            valueSources = emptyList(),\n            tooltipLinePatterns = null,\n            tooltipProperties = TooltipProperties.NONE\n        )\n    }\n}"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-builder-portable.js\n"); +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-vis-svg-portable */ \"./kotlin-dce-dev/lets-plot-vis-svg-portable.js\"), __webpack_require__(/*! lets-plot-plot-common-portable */ \"./kotlin-dce-dev/lets-plot-plot-common-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_plot_base_portable, $module$lets_plot_base_portable, $module$lets_plot_vis_svg_portable, $module$lets_plot_plot_common_portable) {\n 'use strict';\n var data = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.data;\n var println = Kotlin.kotlin.io.println_s8jyv4$;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var scale = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale;\n var throwCCE = Kotlin.throwCCE;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var DoubleVector = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleVector;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var toString = Kotlin.toString;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var CoordinateSystem = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.CoordinateSystem;\n var Scale = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.Scale;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var base = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.base;\n var TextLabel = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel;\n var TextLabel$HorizontalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor;\n var TextLabel$VerticalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor;\n var RuntimeException = Kotlin.kotlin.RuntimeException;\n var ensureNotNull = Kotlin.ensureNotNull;\n var EventHandler = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventHandler;\n var Registration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.Registration;\n var SvgGElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgGElement;\n var SvgEventSpec = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.event.SvgEventSpec;\n var SvgEventHandler = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.event.SvgEventHandler;\n var DoubleRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle;\n var SvgRectElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_wthzt5$;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var DoubleRectangle_init = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$;\n var getCallableRef = Kotlin.getCallableRef;\n var logging = $module$lets_plot_base_portable.jetbrains.datalore.base.logging;\n var getKClass = Kotlin.getKClass;\n var SvgComponent = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.SvgComponent;\n var ValueProperty = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property.ValueProperty;\n var throwUPAE = Kotlin.throwUPAE;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var SvgCssResource = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgCssResource;\n var SvgRectElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement;\n var CompositeRegistration = $module$lets_plot_base_portable.jetbrains.datalore.base.registration.CompositeRegistration;\n var SvgSvgElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgSvgElement;\n var Unit = Kotlin.kotlin.Unit;\n var JsMath = Math;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var Aes = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.Aes;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var LiveMapGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LiveMapGeom;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var lazy = Kotlin.kotlin.lazy_klfg04$;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var data_0 = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.data;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var emptyMap = Kotlin.kotlin.collections.emptyMap_q3lmfv$;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_73mtqc$;\n var AestheticsBuilder = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes.AestheticsBuilder;\n var ContinuousTransform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.ContinuousTransform;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var Map = Kotlin.kotlin.collections.Map;\n var SvgRoot = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.SvgRoot;\n var equals = Kotlin.equals;\n var hashCode = Kotlin.hashCode;\n var breaks = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.breaks;\n var NullGeomTargetCollector = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.NullGeomTargetCollector;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var toMap = Kotlin.kotlin.collections.toMap_6hr0sd$;\n var TypedKeyHashMap = $module$lets_plot_base_portable.jetbrains.datalore.base.typedKey.TypedKeyHashMap;\n var stat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat;\n var SimpleStatContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.SimpleStatContext;\n var GeomTargetLocator$LookupSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpec;\n var GeomContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomContext;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var getValue = Kotlin.kotlin.collections.getValue_t9ocha$;\n var zip = Kotlin.kotlin.collections.zip_45mdf7$;\n var numberToInt = Kotlin.numberToInt;\n var flatten = Kotlin.kotlin.collections.flatten_u0ad8z$;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var Collection = Kotlin.kotlin.collections.Collection;\n var toList = Kotlin.kotlin.toList_tt9upe$;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var DataFrame$DataFrame$Builder_init = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder_init;\n var distinct = Kotlin.kotlin.collections.distinct_7wnvza$;\n var listOf = Kotlin.kotlin.collections.listOf_mh5how$;\n var plus = Kotlin.kotlin.collections.plus_mydzjv$;\n var List = Kotlin.kotlin.collections.List;\n var sortedDescending = Kotlin.kotlin.collections.sortedDescending_exjks8$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var Pair_0 = Kotlin.kotlin.Pair;\n var transform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.transform;\n var pos = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos;\n var PositionAdjustments$StackingStrategy = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos.PositionAdjustments.StackingStrategy;\n var PositionAdjustments$Meta = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos.PositionAdjustments.Meta;\n var toMap_0 = Kotlin.kotlin.collections.toMap_abgq59$;\n var listOfNotNull = Kotlin.kotlin.collections.listOfNotNull_jurz7g$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var checkIndexOverflow = Kotlin.kotlin.collections.checkIndexOverflow_za3lpa$;\n var wrapFunction = Kotlin.wrapFunction;\n var Comparator = Kotlin.kotlin.Comparator;\n var L37 = Kotlin.Long.fromInt(37);\n var base_0 = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base;\n var PointGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointGeom;\n var GeomKind = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomKind;\n var AestheticsDefaults = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes.AestheticsDefaults;\n var PathGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PathGeom;\n var LineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LineGeom;\n var SmoothGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.SmoothGeom;\n var BarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.BarGeom;\n var HistogramGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.HistogramGeom;\n var TileGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.TileGeom;\n var Bin2dGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Bin2dGeom;\n var ErrorBarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ErrorBarGeom;\n var CrossBarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.CrossBarGeom;\n var LineRangeGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.LineRangeGeom;\n var PointRangeGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointRangeGeom;\n var ContourGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ContourGeom;\n var ContourfGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ContourfGeom;\n var PolygonGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PolygonGeom;\n var MapGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.MapGeom;\n var ABLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ABLineGeom;\n var HLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.HLineGeom;\n var VLineGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.VLineGeom;\n var BoxplotGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.BoxplotGeom;\n var RibbonGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RibbonGeom;\n var AreaGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.AreaGeom;\n var DensityGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.DensityGeom;\n var Density2dGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Density2dGeom;\n var Density2dfGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.Density2dfGeom;\n var JitterGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.JitterGeom;\n var FreqpolyGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.FreqpolyGeom;\n var StepGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.StepGeom;\n var RectGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RectGeom;\n var SegmentGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.SegmentGeom;\n var TextGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.TextGeom;\n var RasterGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.RasterGeom;\n var ImageGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ImageGeom;\n var MappedDataAccess = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.MappedDataAccess;\n var MappedDataAccess$MappedData = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.MappedDataAccess.MappedData;\n var coord = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.coord;\n var ScaleBreaks = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.ScaleBreaks;\n var spatial = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial;\n var Projection = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.coord.Projection;\n var DataFrame$Builder = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder;\n var first_0 = Kotlin.kotlin.collections.first_7wnvza$;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var listOfNotNull_0 = Kotlin.kotlin.collections.listOfNotNull_issdgt$;\n var plus_0 = Kotlin.kotlin.collections.plus_q4559j$;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var LinkedHashSet_init = Kotlin.kotlin.collections.LinkedHashSet_init_287e2$;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n var requireNoNulls = Kotlin.kotlin.collections.requireNoNulls_whsx6z$;\n var firstOrNull = Kotlin.kotlin.collections.firstOrNull_2p1efm$;\n var Comparable = Kotlin.kotlin.Comparable;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_jhx6be$;\n var listOf_0 = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var DataFrame$OrderSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.OrderSpec;\n var Listeners = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.Listeners;\n var ListenerCaller = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.ListenerCaller;\n var MouseEventSource = $module$lets_plot_base_portable.jetbrains.datalore.base.event.MouseEventSource;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var SvgLineElement_init = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement_init_6y0v78$;\n var property = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property;\n var svg = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg;\n var SvgLineElement = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgLineElement;\n var EventSource = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event.EventSource;\n var event = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.event;\n var reverse = Kotlin.kotlin.collections.reverse_vvxzk3$;\n var SvgRectElement_init_0 = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgRectElement_init_6y0v78$;\n var NoSuchElementException_init = Kotlin.kotlin.NoSuchElementException_init;\n var isBlank = Kotlin.kotlin.text.isBlank_gw00vp$;\n var GroupComponent = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.svg.GroupComponent;\n var SvgColors = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svg.SvgColors;\n var ContextualMapping = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.ContextualMapping;\n var DataContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.DataContext;\n var GeomTargetLocator$LookupStrategy = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy;\n var GeomTargetLocator$LookupSpace = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace;\n var minus = Kotlin.kotlin.collections.minus_q4559j$;\n var toMutableList = Kotlin.kotlin.collections.toMutableList_4c7yge$;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var lastOrNull = Kotlin.kotlin.collections.lastOrNull_2p1efm$;\n var contains = Kotlin.kotlin.collections.contains_2ws7j4$;\n var TipLayoutHint = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TipLayoutHint;\n var addAll = Kotlin.kotlin.collections.addAll_ipc267$;\n var HitShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.HitShape;\n var GeomTargetCollector = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetCollector;\n var GeomTargetLocator = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator;\n var GeomTargetLocator$LookupResult = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult;\n var TipLayoutHint$Kind = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var minOrNull = Kotlin.kotlin.collections.minOrNull_l63kqw$;\n var NoSuchElementException_init_0 = Kotlin.kotlin.NoSuchElementException;\n var IllegalStateException_init_0 = Kotlin.kotlin.IllegalStateException_init;\n var splitRings = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.splitRings_bemo1h$;\n var geometry = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry;\n var calculateArea = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.calculateArea_ytws2g$;\n var PolylineSimplifier = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.geometry.PolylineSimplifier;\n var GeomTarget = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTarget;\n var toRadians = $module$lets_plot_base_portable.jetbrains.datalore.base.math.toRadians_14dthe$;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init;\n var StringBuilder = Kotlin.kotlin.text.StringBuilder;\n var trimMargin = Kotlin.kotlin.text.trimMargin_rjktp$;\n var shuffle = Kotlin.kotlin.collections.shuffle_9jeydg$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var Random = Kotlin.kotlin.random.Random_s8cxhz$;\n var Random_0 = Kotlin.kotlin.random.Random;\n var util = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var sum = Kotlin.kotlin.collections.sum_l63kqw$;\n var MutableDouble = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util.MutableDouble;\n var MutableInteger = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.util.MutableInteger;\n var get_indices = Kotlin.kotlin.collections.get_indices_gzk92b$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var map = Kotlin.kotlin.sequences.map_z5avom$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var sortedWith_0 = Kotlin.kotlin.sequences.sortedWith_vjgqpk$;\n var roundToInt = Kotlin.kotlin.math.roundToInt_yrwdxr$;\n var toList_0 = Kotlin.kotlin.sequences.toList_veqyi0$;\n var isClosed = $module$lets_plot_base_portable.jetbrains.datalore.base.algorithms.isClosed_2p1efm$;\n var AbstractList = Kotlin.kotlin.collections.AbstractList;\n var joinToString = Kotlin.kotlin.collections.joinToString_fmv235$;\n var point = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point;\n var NamedLineType = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.linetype.NamedLineType;\n var aes = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.aes;\n var Function = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Function;\n var AssertionError_init = Kotlin.kotlin.AssertionError_init_pdl1vj$;\n var filterNotNull = Kotlin.kotlin.collections.filterNotNull_m3lr2h$;\n var reversed_0 = Kotlin.kotlin.collections.reversed_7wnvza$;\n var numberToDouble = Kotlin.numberToDouble;\n var StringFormat = $module$lets_plot_base_portable.jetbrains.datalore.base.stringFormat.StringFormat;\n var values = $module$lets_plot_base_portable.jetbrains.datalore.base.values;\n var HSV = $module$lets_plot_base_portable.jetbrains.datalore.base.values.HSV;\n var NamedShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape;\n var NamedShape$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape.values;\n var LinkedHashSet_init_0 = Kotlin.kotlin.collections.LinkedHashSet_init_mqih57$;\n var color = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color;\n var ColorPalette$Type = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Type;\n var ColorPalette$Qualitative = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative;\n var ColorPalette$Sequential$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Sequential.valueOf_61zpoe$;\n var ColorPalette$Diverging$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Diverging.valueOf_61zpoe$;\n var ColorPalette$Qualitative$valueOf = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.valueOf_61zpoe$;\n var IllegalArgumentException = Kotlin.kotlin.IllegalArgumentException;\n var ColorPalette$Sequential$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Sequential.values;\n var ColorPalette$Diverging$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Diverging.values;\n var ColorPalette$Qualitative$values = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.values;\n var joinToString_0 = Kotlin.kotlin.collections.joinToString_cgipc5$;\n var rangeTo = Kotlin.kotlin.ranges.rangeTo_38ydlf$;\n var TooltipLineSpec$DataPoint = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint;\n var StringFormat$FormatType = $module$lets_plot_base_portable.jetbrains.datalore.base.stringFormat.StringFormat.FormatType;\n var single = Kotlin.kotlin.collections.single_2p1efm$;\n var TooltipLineSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipLineSpec;\n Plot$buildPlot$ObjectLiteral_0.prototype = Object.create(Registration.prototype);\n Plot$buildPlot$ObjectLiteral_0.prototype.constructor = Plot$buildPlot$ObjectLiteral_0;\n Plot.prototype = Object.create(SvgComponent.prototype);\n Plot.prototype.constructor = Plot;\n PlotBuilder$MyPlot.prototype = Object.create(Plot.prototype);\n PlotBuilder$MyPlot.prototype.constructor = PlotBuilder$MyPlot;\n PlotTile.prototype = Object.create(SvgComponent.prototype);\n PlotTile.prototype.constructor = PlotTile;\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype = Object.create(TransformedTargetLocator.prototype);\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.constructor = PlotTooltipHelper$TileInfo$TileTargetLocator;\n SvgLayerRenderer.prototype = Object.create(SvgComponent.prototype);\n SvgLayerRenderer.prototype.constructor = SvgLayerRenderer;\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype.constructor = ColorBarAssembler$createColorBar$ObjectLiteral;\n ColorBarOptions.prototype = Object.create(GuideOptions.prototype);\n ColorBarOptions.prototype.constructor = ColorBarOptions;\n GuideOptions$Companion$NONE$ObjectLiteral.prototype = Object.create(GuideOptions.prototype);\n GuideOptions$Companion$NONE$ObjectLiteral.prototype.constructor = GuideOptions$Companion$NONE$ObjectLiteral;\n LegendAssembler$createLegend$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n LegendAssembler$createLegend$ObjectLiteral.prototype.constructor = LegendAssembler$createLegend$ObjectLiteral;\n LegendOptions.prototype = Object.create(GuideOptions.prototype);\n LegendOptions.prototype.constructor = LegendOptions;\n PosProvider$Companion$wrap$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$wrap$ObjectLiteral.prototype.constructor = PosProvider$Companion$wrap$ObjectLiteral;\n PosProvider$Companion$barStack$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$barStack$ObjectLiteral.prototype.constructor = PosProvider$Companion$barStack$ObjectLiteral;\n PosProvider$Companion$dodge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$dodge$ObjectLiteral.prototype.constructor = PosProvider$Companion$dodge$ObjectLiteral;\n PosProvider$Companion$fill$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$fill$ObjectLiteral.prototype.constructor = PosProvider$Companion$fill$ObjectLiteral;\n PosProvider$Companion$jitter$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$jitter$ObjectLiteral.prototype.constructor = PosProvider$Companion$jitter$ObjectLiteral;\n PosProvider$Companion$nudge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$nudge$ObjectLiteral.prototype.constructor = PosProvider$Companion$nudge$ObjectLiteral;\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype = Object.create(PosProvider.prototype);\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.constructor = PosProvider$Companion$jitterDodge$ObjectLiteral;\n FacetGrid.prototype = Object.create(PlotFacets.prototype);\n FacetGrid.prototype.constructor = FacetGrid;\n FacetWrap$Direction.prototype = Object.create(Enum.prototype);\n FacetWrap$Direction.prototype.constructor = FacetWrap$Direction;\n FacetWrap.prototype = Object.create(PlotFacets.prototype);\n FacetWrap.prototype.constructor = FacetWrap;\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype = Object.create(GeomProvider.prototype);\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.constructor = GeomProvider$GeomProviderBuilder$build$ObjectLiteral;\n CartesianCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n CartesianCoordProvider.prototype.constructor = CartesianCoordProvider;\n FixedRatioCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n FixedRatioCoordProvider.prototype.constructor = FixedRatioCoordProvider;\n ProjectionCoordProvider.prototype = Object.create(CoordProviderBase.prototype);\n ProjectionCoordProvider.prototype.constructor = ProjectionCoordProvider;\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype = Object.create(Registration.prototype);\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype.constructor = MouseEventPeer$addEventHandler$ObjectLiteral;\n AxisComponent.prototype = Object.create(SvgComponent.prototype);\n AxisComponent.prototype.constructor = AxisComponent;\n LegendBox.prototype = Object.create(SvgComponent.prototype);\n LegendBox.prototype.constructor = LegendBox;\n ColorBarComponent.prototype = Object.create(LegendBox.prototype);\n ColorBarComponent.prototype.constructor = ColorBarComponent;\n ColorBarComponentLayout.prototype = Object.create(LegendBoxLayout.prototype);\n ColorBarComponentLayout.prototype.constructor = ColorBarComponentLayout;\n ColorBarComponentLayout$HorizontalLayout.prototype = Object.create(ColorBarComponentLayout.prototype);\n ColorBarComponentLayout$HorizontalLayout.prototype.constructor = ColorBarComponentLayout$HorizontalLayout;\n ColorBarComponentLayout$VerticalLayout.prototype = Object.create(ColorBarComponentLayout.prototype);\n ColorBarComponentLayout$VerticalLayout.prototype.constructor = ColorBarComponentLayout$VerticalLayout;\n ColorBarComponentSpec.prototype = Object.create(LegendBoxSpec.prototype);\n ColorBarComponentSpec.prototype.constructor = ColorBarComponentSpec;\n LegendArrangement.prototype = Object.create(Enum.prototype);\n LegendArrangement.prototype.constructor = LegendArrangement;\n LegendComponent.prototype = Object.create(LegendBox.prototype);\n LegendComponent.prototype.constructor = LegendComponent;\n LegendComponentLayout.prototype = Object.create(LegendBoxLayout.prototype);\n LegendComponentLayout.prototype.constructor = LegendComponentLayout;\n LegendComponentLayout$MyHorizontal.prototype = Object.create(LegendComponentLayout.prototype);\n LegendComponentLayout$MyHorizontal.prototype.constructor = LegendComponentLayout$MyHorizontal;\n LegendComponentLayout$MyMultiRow.prototype = Object.create(LegendComponentLayout.prototype);\n LegendComponentLayout$MyMultiRow.prototype.constructor = LegendComponentLayout$MyMultiRow;\n LegendComponentLayout$MyHorizontalMultiRow.prototype = Object.create(LegendComponentLayout$MyMultiRow.prototype);\n LegendComponentLayout$MyHorizontalMultiRow.prototype.constructor = LegendComponentLayout$MyHorizontalMultiRow;\n LegendComponentLayout$MyVertical.prototype = Object.create(LegendComponentLayout$MyMultiRow.prototype);\n LegendComponentLayout$MyVertical.prototype.constructor = LegendComponentLayout$MyVertical;\n LegendComponentSpec.prototype = Object.create(LegendBoxSpec.prototype);\n LegendComponentSpec.prototype.constructor = LegendComponentSpec;\n LegendDirection.prototype = Object.create(Enum.prototype);\n LegendDirection.prototype.constructor = LegendDirection;\n Orientation.prototype = Object.create(Enum.prototype);\n Orientation.prototype.constructor = Orientation;\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.prototype = Object.create(Enum.prototype);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.prototype.constructor = MathUtil$ClosestPointChecker$COMPARISON_RESULT;\n LayerTargetLocator$Collector$CollectingStrategy.prototype = Object.create(Enum.prototype);\n LayerTargetLocator$Collector$CollectingStrategy.prototype.constructor = LayerTargetLocator$Collector$CollectingStrategy;\n PointTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PointTargetProjection.prototype.constructor = PointTargetProjection;\n RectTargetProjection.prototype = Object.create(TargetProjection.prototype);\n RectTargetProjection.prototype.constructor = RectTargetProjection;\n PolygonTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PolygonTargetProjection.prototype.constructor = PolygonTargetProjection;\n PathTargetProjection.prototype = Object.create(TargetProjection.prototype);\n PathTargetProjection.prototype.constructor = PathTargetProjection;\n FacetGridPlotLayout.prototype = Object.create(PlotLayoutBase.prototype);\n FacetGridPlotLayout.prototype.constructor = FacetGridPlotLayout;\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype = Object.create(LegendBoxInfo.prototype);\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype.constructor = LegendBoxInfo$Companion$EMPTY$ObjectLiteral;\n SingleTilePlotLayout.prototype = Object.create(PlotLayoutBase.prototype);\n SingleTilePlotLayout.prototype.constructor = SingleTilePlotLayout;\n HorizontalAxisLayouter.prototype = Object.create(AxisLayouter.prototype);\n HorizontalAxisLayouter.prototype.constructor = HorizontalAxisLayouter;\n VerticalAxisLayouter.prototype = Object.create(AxisLayouter.prototype);\n VerticalAxisLayouter.prototype.constructor = VerticalAxisLayouter;\n AbstractFixedBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n AbstractFixedBreaksLabelsLayout.prototype.constructor = AbstractFixedBreaksLabelsLayout;\n HorizontalFixedBreaksLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalFixedBreaksLabelsLayout.prototype.constructor = HorizontalFixedBreaksLabelsLayout;\n HorizontalFlexBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n HorizontalFlexBreaksLabelsLayout.prototype.constructor = HorizontalFlexBreaksLabelsLayout;\n HorizontalMultilineLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalMultilineLabelsLayout.prototype.constructor = HorizontalMultilineLabelsLayout;\n HorizontalSimpleLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalSimpleLabelsLayout.prototype.constructor = HorizontalSimpleLabelsLayout;\n HorizontalTiltedLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalTiltedLabelsLayout.prototype.constructor = HorizontalTiltedLabelsLayout;\n HorizontalVerticalLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n HorizontalVerticalLabelsLayout.prototype.constructor = HorizontalVerticalLabelsLayout;\n VerticalFixedBreaksLabelsLayout.prototype = Object.create(AbstractFixedBreaksLabelsLayout.prototype);\n VerticalFixedBreaksLabelsLayout.prototype.constructor = VerticalFixedBreaksLabelsLayout;\n VerticalFlexBreaksLabelsLayout.prototype = Object.create(AxisLabelsLayout.prototype);\n VerticalFlexBreaksLabelsLayout.prototype.constructor = VerticalFlexBreaksLabelsLayout;\n PlotLabelSpec.prototype = Object.create(Enum.prototype);\n PlotLabelSpec.prototype.constructor = PlotLabelSpec;\n GroupSamplingBase.prototype = Object.create(SamplingBase.prototype);\n GroupSamplingBase.prototype.constructor = GroupSamplingBase;\n GroupRandomSampling.prototype = Object.create(GroupSamplingBase.prototype);\n GroupRandomSampling.prototype.constructor = GroupRandomSampling;\n GroupSystematicSampling.prototype = Object.create(GroupSamplingBase.prototype);\n GroupSystematicSampling.prototype.constructor = GroupSystematicSampling;\n PickSampling.prototype = Object.create(SamplingBase.prototype);\n PickSampling.prototype.constructor = PickSampling;\n RandomSampling.prototype = Object.create(SamplingBase.prototype);\n RandomSampling.prototype.constructor = RandomSampling;\n RandomStratifiedSampling.prototype = Object.create(SamplingBase.prototype);\n RandomStratifiedSampling.prototype.constructor = RandomStratifiedSampling;\n SystematicSampling.prototype = Object.create(SamplingBase.prototype);\n SystematicSampling.prototype.constructor = SystematicSampling;\n VertexSampling.prototype = Object.create(SamplingBase.prototype);\n VertexSampling.prototype.constructor = VertexSampling;\n VertexSampling$VertexVwSampling.prototype = Object.create(VertexSampling.prototype);\n VertexSampling$VertexVwSampling.prototype.constructor = VertexSampling$VertexVwSampling;\n VertexSampling$VertexDpSampling.prototype = Object.create(VertexSampling.prototype);\n VertexSampling$VertexDpSampling.prototype.constructor = VertexSampling$VertexDpSampling;\n VertexSampling$DoubleVectorComponentsList.prototype = Object.create(AbstractList.prototype);\n VertexSampling$DoubleVectorComponentsList.prototype.constructor = VertexSampling$DoubleVectorComponentsList;\n ContinuousOnlyMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ContinuousOnlyMapperProvider.prototype.constructor = ContinuousOnlyMapperProvider;\n DiscreteOnlyMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n DiscreteOnlyMapperProvider.prototype.constructor = DiscreteOnlyMapperProvider;\n IdentityDiscreteMapperProvider.prototype = Object.create(DiscreteOnlyMapperProvider.prototype);\n IdentityDiscreteMapperProvider.prototype.constructor = IdentityDiscreteMapperProvider;\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype = Object.create(IdentityDiscreteMapperProvider.prototype);\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype.constructor = DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral;\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype = Object.create(IdentityDiscreteMapperProvider.prototype);\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype.constructor = DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral;\n LinearNormalizingMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n LinearNormalizingMapperProvider.prototype.constructor = LinearNormalizingMapperProvider;\n AlphaMapperProvider.prototype = Object.create(LinearNormalizingMapperProvider.prototype);\n AlphaMapperProvider.prototype.constructor = AlphaMapperProvider;\n ColorBrewerMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ColorBrewerMapperProvider.prototype.constructor = ColorBrewerMapperProvider;\n ColorGradient2MapperProvider.prototype = Object.create(ContinuousOnlyMapperProvider.prototype);\n ColorGradient2MapperProvider.prototype.constructor = ColorGradient2MapperProvider;\n ColorGradientMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n ColorGradientMapperProvider.prototype.constructor = ColorGradientMapperProvider;\n HSVColorMapperProvider.prototype = Object.create(MapperProviderBase.prototype);\n HSVColorMapperProvider.prototype.constructor = HSVColorMapperProvider;\n ColorHueMapperProvider.prototype = Object.create(HSVColorMapperProvider.prototype);\n ColorHueMapperProvider.prototype.constructor = ColorHueMapperProvider;\n DirectlyProportionalMapperProvider.prototype = Object.create(ContinuousOnlyMapperProvider.prototype);\n DirectlyProportionalMapperProvider.prototype.constructor = DirectlyProportionalMapperProvider;\n GreyscaleLightnessMapperProvider.prototype = Object.create(HSVColorMapperProvider.prototype);\n GreyscaleLightnessMapperProvider.prototype.constructor = GreyscaleLightnessMapperProvider;\n SizeAreaMapperProvider.prototype = Object.create(DirectlyProportionalMapperProvider.prototype);\n SizeAreaMapperProvider.prototype.constructor = SizeAreaMapperProvider;\n SizeMapperProvider.prototype = Object.create(LinearNormalizingMapperProvider.prototype);\n SizeMapperProvider.prototype.constructor = SizeMapperProvider;\n DefaultTheme$multiTile$ObjectLiteral.prototype = Object.create(DefaultTheme.prototype);\n DefaultTheme$multiTile$ObjectLiteral.prototype.constructor = DefaultTheme$multiTile$ObjectLiteral;\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype = Object.create(DefaultAxisTheme.prototype);\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype.constructor = DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral;\n function FeatureSwitch() {\n FeatureSwitch_instance = this;\n this.PLOT_DEBUG_DRAWING = false;\n this.LEGEND_DEBUG_DRAWING = false;\n this.PRINT_DEBUG_LOGS_0 = false;\n this.PRINT_ENCODED_DATA_SUMMARY_0 = false;\n this.USE_DATA_FRAME_ENCODING = true;\n }\n FeatureSwitch.prototype.printEncodedDataSummary_d0u64m$ = function (header, dataSpec) {\n if (this.PRINT_ENCODED_DATA_SUMMARY_0) {\n this.printEncodedDataSummary_0(header, data.DataFrameUtil.fromMap_bkhwtg$(dataSpec));\n }};\n FeatureSwitch.prototype.isDebugLogEnabled = function () {\n return this.PRINT_DEBUG_LOGS_0;\n };\n FeatureSwitch.prototype.printEncodedDataSummary_0 = function (header, df) {\n if (this.PRINT_ENCODED_DATA_SUMMARY_0) {\n var summary = data.DataFrameUtil.getSummaryText_dhhkv7$(df);\n println(header);\n println(summary);\n }};\n FeatureSwitch.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'FeatureSwitch',\n interfaces: []\n };\n var FeatureSwitch_instance = null;\n function FeatureSwitch_getInstance() {\n if (FeatureSwitch_instance === null) {\n new FeatureSwitch();\n }return FeatureSwitch_instance;\n }\n function AxisUtil() {\n AxisUtil_instance = this;\n }\n AxisUtil.prototype.applyLayoutInfo_4pg061$ = function (axis, info) {\n axis.tickLabelOffsets.set_11rb$(info.tickLabelAdditionalOffsets);\n axis.tickLabelRotationDegree.set_11rb$(info.tickLabelRotationAngle);\n if (info.tickLabelHorizontalAnchor != null) {\n axis.tickLabelHorizontalAnchor.set_11rb$(info.tickLabelHorizontalAnchor);\n }if (info.tickLabelVerticalAnchor != null) {\n axis.tickLabelVerticalAnchor.set_11rb$(info.tickLabelVerticalAnchor);\n }axis.tickLabelSmallFont.set_11rb$(info.tickLabelSmallFont);\n };\n AxisUtil.prototype.applyTheme_tna4q5$ = function (axis, theme) {\n axis.tickLabelsEnabled().set_11rb$(theme.showTickLabels());\n axis.tickMarksEnabled().set_11rb$(theme.showTickMarks());\n axis.axisLineEnabled().set_11rb$(theme.showLine());\n axis.lineWidth.set_11rb$(theme.lineWidth());\n axis.tickMarkLength.set_11rb$(theme.tickMarkLength());\n axis.tickMarkPadding.set_11rb$(theme.tickMarkPadding());\n axis.tickMarkWidth.set_11rb$(theme.tickMarkWidth());\n };\n AxisUtil.prototype.setBreaks_6e5l22$ = function (axis, scale, coord, horizontal) {\n var scaleBreaks = scale.getScaleBreaks();\n var mappedBreaks = this.toAxisCoord_0(scaleBreaks, scale, coord, horizontal);\n axis.breaks.set_11rb$(mappedBreaks);\n axis.labels.set_11rb$(scaleBreaks.labels);\n };\n AxisUtil.prototype.toAxisCoord_0 = function (scaleBreaks, scale_0, coord, horizontal) {\n var tmp$, tmp$_0;\n var $receiver = scale.ScaleUtil.map_9ksyxk$(scaleBreaks.transformedValues, scale_0);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n var tmp$_2;\n destination.add_11rb$(typeof (tmp$_2 = item) === 'number' ? tmp$_2 : throwCCE());\n }\n var breaksMapped = destination;\n var axisBreaks = ArrayList_init();\n tmp$ = breaksMapped.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n if (horizontal === true)\n tmp$_0 = new DoubleVector(br, 0.0);\n else if (horizontal === false)\n tmp$_0 = new DoubleVector(0.0, br);\n else\n tmp$_0 = Kotlin.noWhenBranchMatched();\n var mappedBrPoint = tmp$_0;\n var axisBrPoint = coord.toClient_gpjtzr$(mappedBrPoint);\n var axisBr = horizontal ? axisBrPoint.x : axisBrPoint.y;\n axisBreaks.add_11rb$(axisBr);\n if (!isFinite(axisBr)) {\n throw IllegalStateException_init(\"Illegal axis '\" + scale_0.name + \"' break position \" + toString(axisBr) + ' at index ' + toString(axisBreaks.size - 1 | 0) + '\\nsource breaks : ' + toString(scaleBreaks.domainValues) + '\\ntranslated breaks: ' + toString(breaksMapped) + '\\naxis breaks : ' + toString(axisBreaks));\n }}\n return axisBreaks;\n };\n AxisUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AxisUtil',\n interfaces: []\n };\n var AxisUtil_instance = null;\n function AxisUtil_getInstance() {\n if (AxisUtil_instance === null) {\n new AxisUtil();\n }return AxisUtil_instance;\n }\n function BogusCoordinateSystem() {\n }\n BogusCoordinateSystem.prototype.toClient_gpjtzr$ = function (p) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.fromClient_gpjtzr$ = function (p) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPointInLimits_k2qmv6$$default = function (p, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isRectInLimits_fd842m$$default = function (rect, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPathInLimits_f6t8kh$$default = function (path, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n BogusCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$$default = function (polygon, isClient) {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n };\n Object.defineProperty(BogusCoordinateSystem.prototype, 'xClientLimit', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusCoordinateSystem.prototype, 'yClientLimit', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus coordinate system is not supposed to be used.');\n }\n });\n BogusCoordinateSystem.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BogusCoordinateSystem',\n interfaces: [CoordinateSystem]\n };\n function BogusScale() {\n }\n Object.defineProperty(BogusScale.prototype, 'name', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'labelFormatter', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'isContinuousDomain', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'multiplicativeExpand', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'additiveExpand', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'transform', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n Object.defineProperty(BogusScale.prototype, 'mapper', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n }\n });\n BogusScale.prototype.hasBreaks = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.hasDomainLimits = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.isInDomainLimits_za3rmp$ = function (v) {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.getScaleBreaks = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.applyTransform_yzw12z$ = function (source, checkLimits) {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.getBreaksGenerator = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.prototype.with = function () {\n throw IllegalStateException_init('Bogus scale is not supposed to be used.');\n };\n BogusScale.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BogusScale',\n interfaces: [Scale]\n };\n function GeomLayer() {\n }\n GeomLayer.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GeomLayer',\n interfaces: []\n };\n function GeomLayerListUtil() {\n GeomLayerListUtil_instance = this;\n }\n GeomLayerListUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeomLayerListUtil',\n interfaces: []\n };\n var GeomLayerListUtil_instance = null;\n function GeomLayerListUtil_getInstance() {\n if (GeomLayerListUtil_instance === null) {\n new GeomLayerListUtil();\n }return GeomLayerListUtil_instance;\n }\n function LayerRendererUtil() {\n LayerRendererUtil_instance = this;\n }\n LayerRendererUtil.prototype.createLayerRendererData_knseyn$ = function (layer, sharedNumericMappers, overallNumericDomains) {\n var aestheticMappers = PlotUtil_getInstance().prepareLayerAestheticMappers_viiuew$(layer, sharedNumericMappers);\n var aesthetics = PlotUtil_getInstance().createLayerAesthetics_kpf4gp$(layer, aestheticMappers, overallNumericDomains);\n var pos = PlotUtil_getInstance().createLayerPos_2iooof$(layer, aesthetics);\n return new LayerRendererUtil$LayerRendererData(layer, aesthetics, aestheticMappers, pos);\n };\n function LayerRendererUtil$LayerRendererData(layer, aesthetics, aestheticMappers, pos) {\n this.aesthetics = aesthetics;\n this.aestheticMappers = aestheticMappers;\n this.pos = pos;\n this.geom = layer.geom;\n this.geomKind = layer.geomKind;\n this.dataAccess = layer.dataAccess;\n this.contextualMapping = layer.contextualMapping;\n }\n LayerRendererUtil$LayerRendererData.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerRendererData',\n interfaces: []\n };\n LayerRendererUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LayerRendererUtil',\n interfaces: []\n };\n var LayerRendererUtil_instance = null;\n function LayerRendererUtil_getInstance() {\n if (LayerRendererUtil_instance === null) {\n new LayerRendererUtil();\n }return LayerRendererUtil_instance;\n }\n function Plot(theme) {\n Plot$Companion_getInstance();\n SvgComponent.call(this);\n this.theme_5sfato$_0 = theme;\n this.myPreferredSize_8a54qv$_0 = new ValueProperty(Plot$Companion_getInstance().DEF_PLOT_SIZE_0);\n this.myLaidOutSize_jqfjq$_0 = new ValueProperty(DoubleVector.Companion.ZERO);\n this.myTooltipHelper_3jkkzs$_0 = new PlotTooltipHelper();\n this.myLiveMapFigures_nd8qng$_0 = ArrayList_init();\n this.mouseEventPeer = new MouseEventPeer();\n }\n Object.defineProperty(Plot.prototype, 'liveMapFigures_8be2vx$', {\n configurable: true,\n get: function () {\n return this.myLiveMapFigures_nd8qng$_0;\n }\n });\n Plot.prototype.preferredSize_8be2vx$ = function () {\n return this.myPreferredSize_8a54qv$_0;\n };\n Plot.prototype.laidOutSize = function () {\n return this.myLaidOutSize_jqfjq$_0;\n };\n function Plot$buildComponent$lambda() {\n return 'buildPlot';\n }\n Plot.prototype.buildComponent = function () {\n var tmp$;\n try {\n this.buildPlot_wr1hxq$_0();\n } catch (e) {\n if (Kotlin.isType(e, RuntimeException)) {\n Plot$Companion_getInstance().LOG_0.error_l35kib$(e, Plot$buildComponent$lambda);\n var rootCause = base.Throwables.getRootCause_tcv7n7$(e);\n var messages = ['Error building plot: ' + Kotlin.getKClassFromExpression(rootCause).simpleName, rootCause.message != null ? \"'\" + rootCause.message + \"'\" : ''];\n var y = this.myPreferredSize_8a54qv$_0.get().y / 2 - 8;\n for (tmp$ = 0; tmp$ !== messages.length; ++tmp$) {\n var s = messages[tmp$];\n var errorLabel = new TextLabel(s);\n errorLabel.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n errorLabel.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n errorLabel.moveTo_lu1900$(this.myPreferredSize_8a54qv$_0.get().x / 2, y);\n this.rootGroup.children().add_11rb$(errorLabel.rootGroup);\n y += 16.0;\n }\n } else\n throw e;\n }\n };\n function Plot$buildPlot$ObjectLiteral(this$Plot) {\n this.this$Plot = this$Plot;\n }\n Plot$buildPlot$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var newValue = event.newValue;\n if (ensureNotNull(newValue).x > 0 && newValue.y > 0) {\n this.this$Plot.rebuildPlot_v06af3$_0();\n }};\n Plot$buildPlot$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n function Plot$buildPlot$ObjectLiteral_0(this$Plot) {\n this.this$Plot = this$Plot;\n Registration.call(this);\n }\n Plot$buildPlot$ObjectLiteral_0.prototype.doRemove = function () {\n this.this$Plot.myTooltipHelper_3jkkzs$_0.removeAllTileInfos();\n this.this$Plot.myLiveMapFigures_nd8qng$_0.clear();\n };\n Plot$buildPlot$ObjectLiteral_0.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n Plot.prototype.buildPlot_wr1hxq$_0 = function () {\n this.rootGroup.addClass_61zpoe$(Style_getInstance().PLOT);\n this.buildPlotComponents_8cuv6w$_0();\n this.reg_3xv6fb$(this.myPreferredSize_8a54qv$_0.addHandler_gxwwpc$(new Plot$buildPlot$ObjectLiteral(this)));\n this.reg_3xv6fb$(new Plot$buildPlot$ObjectLiteral_0(this));\n };\n Plot.prototype.rebuildPlot_v06af3$_0 = function () {\n this.clear();\n this.buildPlot_wr1hxq$_0();\n };\n Plot.prototype.createTile_rg9gwo$_0 = function (tilesOrigin, tileInfo, tileLayers, theme) {\n var xScale;\n var yScale;\n var coord;\n if (tileInfo.xAxisInfo != null && tileInfo.yAxisInfo != null) {\n var xDomain = ensureNotNull(tileInfo.xAxisInfo.axisDomain);\n var xAxisLength = tileInfo.xAxisInfo.axisLength;\n var yDomain = ensureNotNull(tileInfo.yAxisInfo.axisDomain);\n var yAxisLength = tileInfo.yAxisInfo.axisLength;\n xScale = this.coordProvider.buildAxisScaleX_ny58zc$(this.scaleXProto, xDomain, xAxisLength, ensureNotNull(tileInfo.xAxisInfo.axisBreaks));\n yScale = this.coordProvider.buildAxisScaleY_ny58zc$(this.scaleYProto, yDomain, yAxisLength, ensureNotNull(tileInfo.yAxisInfo.axisBreaks));\n coord = this.coordProvider.createCoordinateSystem_uncllg$(xDomain, xAxisLength, yDomain, yAxisLength);\n } else {\n xScale = new BogusScale();\n yScale = new BogusScale();\n coord = new BogusCoordinateSystem();\n }\n var tile = new PlotTile(tileLayers, xScale, yScale, tilesOrigin, tileInfo, coord, theme);\n tile.setShowAxis_6taknv$(this.isAxisEnabled);\n tile.debugDrawing().set_11rb$(Plot$Companion_getInstance().DEBUG_DRAWING_0);\n return tile;\n };\n Plot.prototype.createAxisTitle_depkt8$_0 = function (text, orientation, plotBounds, geomBounds) {\n var tmp$;\n var horizontalAnchor = TextLabel$HorizontalAnchor.MIDDLE;\n switch (orientation.name) {\n case 'LEFT':\n case 'RIGHT':\n case 'TOP':\n tmp$ = TextLabel$VerticalAnchor.TOP;\n break;\n case 'BOTTOM':\n tmp$ = TextLabel$VerticalAnchor.BOTTOM;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n var verticalAnchor = tmp$;\n var titleLocation;\n var rotation = 0.0;\n switch (orientation.name) {\n case 'LEFT':\n titleLocation = new DoubleVector(plotBounds.left + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y);\n rotation = -90.0;\n break;\n case 'RIGHT':\n titleLocation = new DoubleVector(plotBounds.right - PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y);\n rotation = 90.0;\n break;\n case 'TOP':\n titleLocation = new DoubleVector(geomBounds.center.x, plotBounds.top + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN);\n break;\n case 'BOTTOM':\n titleLocation = new DoubleVector(geomBounds.center.x, plotBounds.bottom - PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN);\n break;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n var titleLabel = new TextLabel(text);\n titleLabel.setHorizontalAnchor_ja80zo$(horizontalAnchor);\n titleLabel.setVerticalAnchor_yaudma$(verticalAnchor);\n titleLabel.moveTo_gpjtzr$(titleLocation);\n titleLabel.rotate_14dthe$(rotation);\n var titleElement = titleLabel.rootGroup;\n titleElement.addClass_61zpoe$(Style_getInstance().AXIS_TITLE);\n var parent = new SvgGElement();\n parent.addClass_61zpoe$(Style_getInstance().AXIS);\n parent.children().add_11rb$(titleElement);\n this.add_26jijc$(parent);\n };\n function Plot$onMouseMove$ObjectLiteral(closure$message) {\n this.closure$message = closure$message;\n }\n Plot$onMouseMove$ObjectLiteral.prototype.handle_42da0z$ = function (node, e) {\n println(this.closure$message);\n };\n Plot$onMouseMove$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [SvgEventHandler]\n };\n Plot.prototype.onMouseMove_hnimoe$_0 = function (e, message) {\n e.addEventHandler_mm8kk2$(SvgEventSpec.MOUSE_MOVE, new Plot$onMouseMove$ObjectLiteral(message));\n };\n Plot.prototype.buildPlotComponents_8cuv6w$_0 = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5;\n var preferredSize = this.myPreferredSize_8a54qv$_0.get();\n var overallRect = new DoubleRectangle(DoubleVector.Companion.ZERO, preferredSize);\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect = SvgRectElement_init(overallRect);\n rect.strokeColor().set_11rb$(Color.Companion.MAGENTA);\n rect.strokeWidth().set_11rb$(1.0);\n rect.fillOpacity().set_11rb$(0.0);\n this.onMouseMove_hnimoe$_0(rect, 'MAGENTA: preferred size: ' + overallRect);\n this.add_26jijc$(rect);\n }if (this.hasLiveMap()) {\n tmp$ = PlotLayoutUtil_getInstance().liveMapBounds_wthzt5$(overallRect);\n } else {\n tmp$ = overallRect;\n }\n var entirePlot = tmp$;\n if (this.hasTitle()) {\n var titleSize = PlotLayoutUtil_getInstance().titleDimensions_61zpoe$(this.title);\n tmp$_0 = new DoubleRectangle(entirePlot.origin.add_gpjtzr$(new DoubleVector(0.0, titleSize.y)), entirePlot.dimension.subtract_gpjtzr$(new DoubleVector(0.0, titleSize.y)));\n } else {\n tmp$_0 = entirePlot;\n }\n var withoutTitle = tmp$_0;\n var boxesLayoutResult = null;\n var legendTheme = this.theme_5sfato$_0.legend();\n if (legendTheme.position().isFixed) {\n var legendBoxesLayout = new LegendBoxesLayout(withoutTitle, legendTheme);\n boxesLayoutResult = legendBoxesLayout.doLayout_8sg693$(this.legendBoxInfos);\n tmp$_1 = boxesLayoutResult.plotInnerBoundsWithoutLegendBoxes;\n } else {\n tmp$_1 = withoutTitle;\n }\n var withoutTitleAndLegends = tmp$_1;\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_0 = SvgRectElement_init(withoutTitleAndLegends);\n rect_0.strokeColor().set_11rb$(Color.Companion.BLUE);\n rect_0.strokeWidth().set_11rb$(1.0);\n rect_0.fillOpacity().set_11rb$(0.0);\n this.onMouseMove_hnimoe$_0(rect_0, 'BLUE: plot without title and legends: ' + withoutTitleAndLegends);\n this.add_26jijc$(rect_0);\n }var geomAndAxis = withoutTitleAndLegends;\n if (this.isAxisEnabled) {\n if (this.hasAxisTitleLeft()) {\n var titleSize_0 = PlotLayoutUtil_getInstance().axisTitleDimensions_61zpoe$(this.axisTitleLeft);\n var thickness = titleSize_0.y + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil_getInstance().AXIS_TITLE_INNER_MARGIN;\n geomAndAxis = DoubleRectangle_init(geomAndAxis.left + thickness, geomAndAxis.top, geomAndAxis.width - thickness, geomAndAxis.height);\n }if (this.hasAxisTitleBottom()) {\n var titleSize_1 = PlotLayoutUtil_getInstance().axisTitleDimensions_61zpoe$(this.axisTitleBottom);\n var thickness_0 = titleSize_1.y + PlotLayoutUtil_getInstance().AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil_getInstance().AXIS_TITLE_INNER_MARGIN;\n geomAndAxis = DoubleRectangle_init(geomAndAxis.left, geomAndAxis.top, geomAndAxis.width, geomAndAxis.height - thickness_0);\n }}var plotLayout = this.plotLayout();\n var plotInfo = plotLayout.doLayout_gpjtzr$(geomAndAxis.dimension);\n this.myLaidOutSize_jqfjq$_0.set_11rb$(preferredSize);\n if (plotInfo.tiles.isEmpty()) {\n return;\n }var geomAreaBounds = PlotLayoutUtil_getInstance().absoluteGeomBounds_vjhcds$(geomAndAxis.origin, plotInfo);\n if (legendTheme.position().isOverlay) {\n var legendBoxesLayout_0 = new LegendBoxesLayout(geomAreaBounds, legendTheme);\n boxesLayoutResult = legendBoxesLayout_0.doLayout_8sg693$(this.legendBoxInfos);\n }if (plotInfo.tiles.size > 1) {\n tmp$_2 = this.theme_5sfato$_0.multiTile();\n } else {\n tmp$_2 = this.theme_5sfato$_0;\n }\n var tileTheme = tmp$_2;\n var tilesOrigin = geomAndAxis.origin;\n tmp$_3 = plotInfo.tiles.iterator();\n while (tmp$_3.hasNext()) {\n var tileLayoutInfo = tmp$_3.next();\n var tileLayersIndex = tileLayoutInfo.trueIndex;\n var tile = this.createTile_rg9gwo$_0(tilesOrigin, tileLayoutInfo, this.tileLayers_za3lpa$(tileLayersIndex), tileTheme);\n var plotOriginAbsolute = tilesOrigin.add_gpjtzr$(tileLayoutInfo.plotOrigin);\n tile.moveTo_gpjtzr$(plotOriginAbsolute);\n this.add_8icvvv$(tile);\n if ((tmp$_4 = tile.liveMapFigure) != null) {\n getCallableRef('add', function ($receiver, p1) {\n return $receiver.add_11rb$(p1);\n }.bind(null, this.myLiveMapFigures_nd8qng$_0))(tmp$_4);\n }var geomBoundsAbsolute = tileLayoutInfo.geomBounds.add_gpjtzr$(plotOriginAbsolute);\n this.myTooltipHelper_3jkkzs$_0.addTileInfo_t6qbjr$(geomBoundsAbsolute, tile.targetLocators);\n }\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_1 = SvgRectElement_init(geomAreaBounds);\n rect_1.strokeColor().set_11rb$(Color.Companion.RED);\n rect_1.strokeWidth().set_11rb$(1.0);\n rect_1.fillOpacity().set_11rb$(0.0);\n this.add_26jijc$(rect_1);\n }if (this.hasTitle()) {\n var titleLabel = new TextLabel(this.title);\n titleLabel.addClassName_61zpoe$(Style_getInstance().PLOT_TITLE);\n titleLabel.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.LEFT);\n titleLabel.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n var titleSize_2 = PlotLayoutUtil_getInstance().titleDimensions_61zpoe$(this.title);\n var titleBounds = DoubleRectangle_init(geomAreaBounds.origin.x, 0.0, titleSize_2.x, titleSize_2.y);\n titleLabel.moveTo_gpjtzr$(new DoubleVector(titleBounds.left, titleBounds.center.y));\n this.add_8icvvv$(titleLabel);\n if (Plot$Companion_getInstance().DEBUG_DRAWING_0) {\n var rect_2 = SvgRectElement_init(titleBounds);\n rect_2.strokeColor().set_11rb$(Color.Companion.BLUE);\n rect_2.strokeWidth().set_11rb$(1.0);\n rect_2.fillOpacity().set_11rb$(0.0);\n this.add_26jijc$(rect_2);\n }}if (this.isAxisEnabled) {\n if (this.hasAxisTitleLeft()) {\n this.createAxisTitle_depkt8$_0(this.axisTitleLeft, Orientation$LEFT_getInstance(), withoutTitleAndLegends, geomAreaBounds);\n }if (this.hasAxisTitleBottom()) {\n this.createAxisTitle_depkt8$_0(this.axisTitleBottom, Orientation$BOTTOM_getInstance(), withoutTitleAndLegends, geomAreaBounds);\n }}if (boxesLayoutResult != null) {\n tmp$_5 = boxesLayoutResult.boxWithLocationList.iterator();\n while (tmp$_5.hasNext()) {\n var boxWithLocation = tmp$_5.next();\n var legendBox = boxWithLocation.legendBox.createLegendBox();\n legendBox.moveTo_gpjtzr$(boxWithLocation.location);\n this.add_8icvvv$(legendBox);\n }\n }};\n Plot.prototype.createTooltipSpecs_gpjtzr$ = function (plotCoord) {\n return this.myTooltipHelper_3jkkzs$_0.createTooltipSpecs_gpjtzr$(plotCoord);\n };\n Plot.prototype.getGeomBounds_gpjtzr$ = function (plotCoord) {\n return this.myTooltipHelper_3jkkzs$_0.getGeomBounds_gpjtzr$(plotCoord);\n };\n function Plot$Companion() {\n Plot$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(Plot));\n this.DEF_PLOT_SIZE_0 = new DoubleVector(600.0, 400.0);\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().PLOT_DEBUG_DRAWING;\n }\n Plot$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var Plot$Companion_instance = null;\n function Plot$Companion_getInstance() {\n if (Plot$Companion_instance === null) {\n new Plot$Companion();\n }return Plot$Companion_instance;\n }\n Plot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Plot',\n interfaces: [SvgComponent]\n };\n function PlotBuilder(myTheme) {\n this.myTheme_0 = myTheme;\n this.myLayersByTile_0 = ArrayList_init();\n this.myTitle_0 = null;\n this.myCoordProvider_3t551e$_0 = this.myCoordProvider_3t551e$_0;\n this.myLayout_0 = null;\n this.myAxisTitleLeft_0 = null;\n this.myAxisTitleBottom_0 = null;\n this.myLegendBoxInfos_0 = ArrayList_init();\n this.myScaleXProto_s7k1di$_0 = this.myScaleXProto_s7k1di$_0;\n this.myScaleYProto_dj5r5h$_0 = this.myScaleYProto_dj5r5h$_0;\n this.myAxisEnabled_0 = true;\n this.myInteractionsEnabled_0 = true;\n this.hasLiveMap_0 = false;\n }\n Object.defineProperty(PlotBuilder.prototype, 'myCoordProvider_0', {\n configurable: true,\n get: function () {\n if (this.myCoordProvider_3t551e$_0 == null)\n return throwUPAE('myCoordProvider');\n return this.myCoordProvider_3t551e$_0;\n },\n set: function (myCoordProvider) {\n this.myCoordProvider_3t551e$_0 = myCoordProvider;\n }\n });\n Object.defineProperty(PlotBuilder.prototype, 'myScaleXProto_0', {\n configurable: true,\n get: function () {\n if (this.myScaleXProto_s7k1di$_0 == null)\n return throwUPAE('myScaleXProto');\n return this.myScaleXProto_s7k1di$_0;\n },\n set: function (myScaleXProto) {\n this.myScaleXProto_s7k1di$_0 = myScaleXProto;\n }\n });\n Object.defineProperty(PlotBuilder.prototype, 'myScaleYProto_0', {\n configurable: true,\n get: function () {\n if (this.myScaleYProto_dj5r5h$_0 == null)\n return throwUPAE('myScaleYProto');\n return this.myScaleYProto_dj5r5h$_0;\n },\n set: function (myScaleYProto) {\n this.myScaleYProto_dj5r5h$_0 = myScaleYProto;\n }\n });\n PlotBuilder.prototype.setTitle_pdl1vj$ = function (title) {\n this.myTitle_0 = title;\n };\n PlotBuilder.prototype.setAxisTitleLeft_61zpoe$ = function (v) {\n this.myAxisTitleLeft_0 = v;\n };\n PlotBuilder.prototype.setAxisTitleBottom_61zpoe$ = function (v) {\n this.myAxisTitleBottom_0 = v;\n };\n PlotBuilder.prototype.setCoordProvider_sdecqr$ = function (coordProvider) {\n this.myCoordProvider_0 = coordProvider;\n return this;\n };\n PlotBuilder.prototype.addTileLayers_relqli$ = function (tileLayers) {\n this.myLayersByTile_0.add_11rb$(ArrayList_init_1(tileLayers));\n return this;\n };\n PlotBuilder.prototype.setPlotLayout_vjneqj$ = function (layout) {\n this.myLayout_0 = layout;\n return this;\n };\n PlotBuilder.prototype.addLegendBoxInfo_29gouq$ = function (v) {\n this.myLegendBoxInfos_0.add_11rb$(v);\n return this;\n };\n PlotBuilder.prototype.scaleXProto_iu85h4$ = function (scaleXProto) {\n this.myScaleXProto_0 = scaleXProto;\n return this;\n };\n PlotBuilder.prototype.scaleYProto_iu85h4$ = function (scaleYProto) {\n this.myScaleYProto_0 = scaleYProto;\n return this;\n };\n PlotBuilder.prototype.axisEnabled_6taknv$ = function (b) {\n this.myAxisEnabled_0 = b;\n return this;\n };\n PlotBuilder.prototype.interactionsEnabled_6taknv$ = function (b) {\n this.myInteractionsEnabled_0 = b;\n return this;\n };\n PlotBuilder.prototype.setLiveMap_6taknv$ = function (b) {\n this.hasLiveMap_0 = b;\n return this;\n };\n PlotBuilder.prototype.build = function () {\n return new PlotBuilder$MyPlot(this);\n };\n function PlotBuilder$MyPlot(b) {\n Plot.call(this, b.myTheme_0);\n this.scaleXProto_rbtdab$_0 = b.myScaleXProto_0;\n this.scaleYProto_t0wegs$_0 = b.myScaleYProto_0;\n this.myTitle_0 = b.myTitle_0;\n this.myAxisTitleLeft_0 = b.myAxisTitleLeft_0;\n this.myAxisTitleBottom_0 = b.myAxisTitleBottom_0;\n this.myAxisXTitleEnabled_0 = b.myTheme_0.axisX().showTitle();\n this.myAxisYTitleEnabled_0 = b.myTheme_0.axisY().showTitle();\n this.coordProvider_o460zb$_0 = b.myCoordProvider_0;\n this.myLayersByTile_0 = null;\n this.myLayout_0 = null;\n this.myLegendBoxInfos_0 = null;\n this.hasLiveMap_0 = false;\n this.isAxisEnabled_70ondl$_0 = false;\n this.isInteractionsEnabled_dvtvmh$_0 = false;\n this.myLayersByTile_0 = ArrayList_init_1(b.myLayersByTile_0);\n this.myLayout_0 = b.myLayout_0;\n this.myLegendBoxInfos_0 = ArrayList_init_1(b.myLegendBoxInfos_0);\n this.hasLiveMap_0 = b.hasLiveMap_0;\n this.isAxisEnabled_70ondl$_0 = b.myAxisEnabled_0;\n this.isInteractionsEnabled_dvtvmh$_0 = b.myInteractionsEnabled_0;\n }\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'scaleXProto', {\n configurable: true,\n get: function () {\n return this.scaleXProto_rbtdab$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'scaleYProto', {\n configurable: true,\n get: function () {\n return this.scaleYProto_t0wegs$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'coordProvider', {\n configurable: true,\n get: function () {\n return this.coordProvider_o460zb$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'isAxisEnabled', {\n configurable: true,\n get: function () {\n return this.isAxisEnabled_70ondl$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'isInteractionsEnabled', {\n configurable: true,\n get: function () {\n return this.isInteractionsEnabled_dvtvmh$_0;\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'title', {\n configurable: true,\n get: function () {\n if (!this.hasTitle()) {\n var message = 'No title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myTitle_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'axisTitleLeft', {\n configurable: true,\n get: function () {\n if (!this.hasAxisTitleLeft()) {\n var message = 'No left axis title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myAxisTitleLeft_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'axisTitleBottom', {\n configurable: true,\n get: function () {\n if (!this.hasAxisTitleBottom()) {\n var message = 'No bottom axis title';\n throw IllegalArgumentException_init(message.toString());\n }return ensureNotNull(this.myAxisTitleBottom_0);\n }\n });\n Object.defineProperty(PlotBuilder$MyPlot.prototype, 'legendBoxInfos', {\n configurable: true,\n get: function () {\n return this.myLegendBoxInfos_0;\n }\n });\n PlotBuilder$MyPlot.prototype.hasTitle = function () {\n return !base.Strings.isNullOrEmpty_pdl1vj$(this.myTitle_0);\n };\n PlotBuilder$MyPlot.prototype.hasAxisTitleLeft = function () {\n return this.myAxisYTitleEnabled_0 && !base.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleLeft_0);\n };\n PlotBuilder$MyPlot.prototype.hasAxisTitleBottom = function () {\n return this.myAxisXTitleEnabled_0 && !base.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleBottom_0);\n };\n PlotBuilder$MyPlot.prototype.hasLiveMap = function () {\n return this.hasLiveMap_0;\n };\n PlotBuilder$MyPlot.prototype.tileLayers_za3lpa$ = function (tileIndex) {\n return this.myLayersByTile_0.get_za3lpa$(tileIndex);\n };\n PlotBuilder$MyPlot.prototype.plotLayout = function () {\n return ensureNotNull(this.myLayout_0);\n };\n PlotBuilder$MyPlot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyPlot',\n interfaces: [Plot]\n };\n PlotBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotBuilder',\n interfaces: []\n };\n function PlotContainerPortable(plot, preferredSize) {\n PlotContainerPortable$Companion_getInstance();\n this.plot = plot;\n this.preferredSize_sl52i3$_0 = preferredSize;\n this.svg = new SvgSvgElement();\n this.myContentBuilt_l8hvkk$_0 = false;\n this.myRegistrations_wwtuqx$_0 = new CompositeRegistration([]);\n this.svg.addClass_61zpoe$(Style_getInstance().PLOT_CONTAINER);\n this.setSvgSize_2l8z8v$_0(this.preferredSize_sl52i3$_0.get());\n this.plot.laidOutSize().addHandler_gxwwpc$(PlotContainerPortable$Companion_getInstance().sizePropHandler_0(PlotContainerPortable_init$lambda(this)));\n this.preferredSize_sl52i3$_0.addHandler_gxwwpc$(PlotContainerPortable$Companion_getInstance().sizePropHandler_0(PlotContainerPortable_init$lambda_0(this)));\n }\n Object.defineProperty(PlotContainerPortable.prototype, 'liveMapFigures', {\n configurable: true,\n get: function () {\n return this.plot.liveMapFigures_8be2vx$;\n }\n });\n Object.defineProperty(PlotContainerPortable.prototype, 'isLiveMap', {\n configurable: true,\n get: function () {\n return !this.plot.liveMapFigures_8be2vx$.isEmpty();\n }\n });\n PlotContainerPortable.prototype.ensureContentBuilt = function () {\n if (!this.myContentBuilt_l8hvkk$_0) {\n this.buildContent();\n }};\n PlotContainerPortable.prototype.revalidateContent_r8qzcp$_0 = function () {\n if (this.myContentBuilt_l8hvkk$_0) {\n this.clearContent();\n this.buildContent();\n }};\n function PlotContainerPortable$buildContent$ObjectLiteral() {\n }\n PlotContainerPortable$buildContent$ObjectLiteral.prototype.css = function () {\n return Style_getInstance().css;\n };\n PlotContainerPortable$buildContent$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [SvgCssResource]\n };\n PlotContainerPortable.prototype.buildContent = function () {\n if (!!this.myContentBuilt_l8hvkk$_0) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }this.myContentBuilt_l8hvkk$_0 = true;\n this.svg.setStyle_i8z0m3$(new PlotContainerPortable$buildContent$ObjectLiteral());\n var backdrop = new SvgRectElement();\n backdrop.addClass_61zpoe$(Style_getInstance().PLOT_BACKDROP);\n backdrop.setAttribute_jyasbz$('width', '100%');\n backdrop.setAttribute_jyasbz$('height', '100%');\n this.svg.children().add_11rb$(backdrop);\n this.plot.preferredSize_8be2vx$().set_11rb$(this.preferredSize_sl52i3$_0.get());\n this.svg.children().add_11rb$(this.plot.rootGroup);\n };\n PlotContainerPortable.prototype.clearContent = function () {\n if (this.myContentBuilt_l8hvkk$_0) {\n this.myContentBuilt_l8hvkk$_0 = false;\n this.svg.children().clear();\n this.plot.clear();\n this.myRegistrations_wwtuqx$_0.remove();\n this.myRegistrations_wwtuqx$_0 = new CompositeRegistration([]);\n }};\n PlotContainerPortable.prototype.reg_3xv6fb$ = function (registration) {\n this.myRegistrations_wwtuqx$_0.add_3xv6fb$(registration);\n };\n PlotContainerPortable.prototype.setSvgSize_2l8z8v$_0 = function (size) {\n this.svg.width().set_11rb$(size.x);\n this.svg.height().set_11rb$(size.y);\n };\n function PlotContainerPortable$Companion() {\n PlotContainerPortable$Companion_instance = this;\n }\n function PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral(closure$block) {\n this.closure$block = closure$block;\n }\n PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n var newValue = event.newValue;\n if (newValue != null) {\n this.closure$block(newValue);\n }};\n PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n PlotContainerPortable$Companion.prototype.sizePropHandler_0 = function (block) {\n return new PlotContainerPortable$Companion$sizePropHandler$ObjectLiteral(block);\n };\n PlotContainerPortable$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotContainerPortable$Companion_instance = null;\n function PlotContainerPortable$Companion_getInstance() {\n if (PlotContainerPortable$Companion_instance === null) {\n new PlotContainerPortable$Companion();\n }return PlotContainerPortable$Companion_instance;\n }\n function PlotContainerPortable_init$lambda(this$PlotContainerPortable) {\n return function (laidOutSize) {\n var a = this$PlotContainerPortable.preferredSize_sl52i3$_0.get().x;\n var b = laidOutSize.x;\n var tmp$ = JsMath.max(a, b);\n var a_0 = this$PlotContainerPortable.preferredSize_sl52i3$_0.get().y;\n var b_0 = laidOutSize.y;\n var newSvgSize = new DoubleVector(tmp$, JsMath.max(a_0, b_0));\n this$PlotContainerPortable.setSvgSize_2l8z8v$_0(newSvgSize);\n return Unit;\n };\n }\n function PlotContainerPortable_init$lambda_0(this$PlotContainerPortable) {\n return function (newPreferredSize) {\n if (newPreferredSize.x > 0 && newPreferredSize.y > 0) {\n this$PlotContainerPortable.revalidateContent_r8qzcp$_0();\n }return Unit;\n };\n }\n PlotContainerPortable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotContainerPortable',\n interfaces: []\n };\n function PlotTile(layers, myScaleX, myScaleY, myTilesOrigin, myLayoutInfo, myCoord, myTheme) {\n SvgComponent.call(this);\n this.myScaleX_0 = myScaleX;\n this.myScaleY_0 = myScaleY;\n this.myTilesOrigin_0 = myTilesOrigin;\n this.myLayoutInfo_0 = myLayoutInfo;\n this.myCoord_0 = myCoord;\n this.myTheme_0 = myTheme;\n this.myDebugDrawing_0 = new ValueProperty(false);\n this.myLayers_0 = null;\n this.myTargetLocators_0 = ArrayList_init();\n this.myShowAxis_0 = false;\n this.liveMapFigure_y5x745$_0 = null;\n this.myLayers_0 = ArrayList_init_1(layers);\n this.moveTo_gpjtzr$(this.myLayoutInfo_0.getAbsoluteBounds_gpjtzr$(this.myTilesOrigin_0).origin);\n }\n Object.defineProperty(PlotTile.prototype, 'liveMapFigure', {\n configurable: true,\n get: function () {\n return this.liveMapFigure_y5x745$_0;\n },\n set: function (liveMapFigure) {\n this.liveMapFigure_y5x745$_0 = liveMapFigure;\n }\n });\n Object.defineProperty(PlotTile.prototype, 'targetLocators', {\n configurable: true,\n get: function () {\n return this.myTargetLocators_0;\n }\n });\n Object.defineProperty(PlotTile.prototype, 'isDebugDrawing_0', {\n configurable: true,\n get: function () {\n return this.myDebugDrawing_0.get();\n }\n });\n PlotTile.prototype.buildComponent = function () {\n var tmp$, tmp$_0, tmp$_1;\n var geomBounds = this.myLayoutInfo_0.geomBounds;\n if (this.myTheme_0.plot().showInnerFrame()) {\n var $receiver = SvgRectElement_init(geomBounds);\n $receiver.strokeColor().set_11rb$(this.myTheme_0.plot().innerFrameColor());\n $receiver.strokeWidth().set_11rb$(1.0);\n $receiver.fillOpacity().set_11rb$(0.0);\n var rect = $receiver;\n this.add_26jijc$(rect);\n }this.addFacetLabels_0(geomBounds, this.myTheme_0.facets());\n var $receiver_0 = this.myLayers_0;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_2;\n tmp$_2 = $receiver_0.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (element.isLiveMap) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var liveMapGeomLayer = firstOrNull$result;\n if (liveMapGeomLayer == null && this.myShowAxis_0) {\n this.addAxis_0(geomBounds);\n }if (this.isDebugDrawing_0) {\n var tileBounds = this.myLayoutInfo_0.bounds;\n var rect_0 = SvgRectElement_init(tileBounds);\n rect_0.fillColor().set_11rb$(Color.Companion.BLACK);\n rect_0.strokeWidth().set_11rb$(0.0);\n rect_0.fillOpacity().set_11rb$(0.1);\n this.add_26jijc$(rect_0);\n }if (this.isDebugDrawing_0) {\n var clipBounds = this.myLayoutInfo_0.clipBounds;\n var rect_1 = SvgRectElement_init(clipBounds);\n rect_1.fillColor().set_11rb$(Color.Companion.DARK_GREEN);\n rect_1.strokeWidth().set_11rb$(0.0);\n rect_1.fillOpacity().set_11rb$(0.3);\n this.add_26jijc$(rect_1);\n }if (this.isDebugDrawing_0) {\n var rect_2 = SvgRectElement_init(geomBounds);\n rect_2.fillColor().set_11rb$(Color.Companion.PINK);\n rect_2.strokeWidth().set_11rb$(1.0);\n rect_2.fillOpacity().set_11rb$(0.5);\n this.add_26jijc$(rect_2);\n }if (liveMapGeomLayer != null) {\n var realBounds = this.myLayoutInfo_0.getAbsoluteGeomBounds_gpjtzr$(this.myTilesOrigin_0);\n var liveMapData = createCanvasFigure(liveMapGeomLayer, realBounds);\n this.liveMapFigure = liveMapData.canvasFigure;\n this.myTargetLocators_0.add_11rb$(liveMapData.targetLocator);\n } else {\n var sharedNumericMappers = HashMap_init();\n var overallNumericDomains = HashMap_init();\n var xAxisInfo = this.myLayoutInfo_0.xAxisInfo;\n var yAxisInfo = this.myLayoutInfo_0.yAxisInfo;\n var mapperX = this.myScaleX_0.mapper;\n var mapperY = this.myScaleY_0.mapper;\n var key = Aes.Companion.X;\n sharedNumericMappers.put_xwzc9p$(key, mapperX);\n var key_0 = Aes.Companion.Y;\n sharedNumericMappers.put_xwzc9p$(key_0, mapperY);\n var key_1 = Aes.Companion.SLOPE;\n var value = scale.Mappers.mul_14dthe$(ensureNotNull(mapperY(1.0)) / ensureNotNull(mapperX(1.0)));\n sharedNumericMappers.put_xwzc9p$(key_1, value);\n var key_2 = Aes.Companion.X;\n var value_0 = ensureNotNull(ensureNotNull(xAxisInfo).axisDomain);\n overallNumericDomains.put_xwzc9p$(key_2, value_0);\n var key_3 = Aes.Companion.Y;\n var value_1 = ensureNotNull(ensureNotNull(yAxisInfo).axisDomain);\n overallNumericDomains.put_xwzc9p$(key_3, value_1);\n var geomLayerComponents = this.buildGeoms_0(sharedNumericMappers, overallNumericDomains, this.myCoord_0);\n tmp$ = geomLayerComponents.iterator();\n while (tmp$.hasNext()) {\n var layerComponent = tmp$.next();\n layerComponent.moveTo_gpjtzr$(geomBounds.origin);\n var xRange = (tmp$_0 = this.myCoord_0.xClientLimit) != null ? tmp$_0 : new ClosedRange(0.0, geomBounds.width);\n var yRange = (tmp$_1 = this.myCoord_0.yClientLimit) != null ? tmp$_1 : new ClosedRange(0.0, geomBounds.height);\n var clipRect = GeometryUtil_getInstance().doubleRange_gyv40k$(xRange, yRange);\n layerComponent.clipBounds_wthzt5$(clipRect);\n this.add_8icvvv$(layerComponent);\n }\n }\n };\n PlotTile.prototype.addFacetLabels_0 = function (geomBounds, theme) {\n var tmp$;\n var xLabels = this.myLayoutInfo_0.facetXLabels;\n if (!xLabels.isEmpty()) {\n var labelSize = FacetGridPlotLayout$Companion_getInstance().facetColLabelSize_14dthe$(geomBounds.width);\n var labelOrig = new DoubleVector(geomBounds.left + 0, geomBounds.top - FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(xLabels.size) + 6);\n var labelBounds = new DoubleRectangle(labelOrig, labelSize);\n tmp$ = xLabels.iterator();\n while (tmp$.hasNext()) {\n var xLabel = tmp$.next();\n var $receiver = SvgRectElement_init(labelBounds);\n $receiver.strokeWidth().set_11rb$(0.0);\n $receiver.fillColor().set_11rb$(theme.labelBackground());\n var rect = $receiver;\n this.add_26jijc$(rect);\n var x = labelBounds.center.x;\n var y = labelBounds.center.y;\n var lab = new TextLabel(xLabel);\n lab.moveTo_lu1900$(x, y);\n lab.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n lab.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n this.add_8icvvv$(lab);\n labelBounds = labelBounds.add_gpjtzr$(new DoubleVector(0.0, labelSize.y));\n }\n }if (this.myLayoutInfo_0.facetYLabel != null) {\n var hPad = 6;\n var vPad = 0;\n var labelBounds_0 = DoubleRectangle_init(geomBounds.right + hPad, geomBounds.top - vPad, FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT - (hPad * 2 | 0), geomBounds.height - (vPad * 2 | 0));\n var rect_0 = SvgRectElement_init(labelBounds_0);\n rect_0.strokeWidth().set_11rb$(0.0);\n rect_0.fillColor().set_11rb$(theme.labelBackground());\n this.add_26jijc$(rect_0);\n var x_0 = labelBounds_0.center.x;\n var y_0 = labelBounds_0.center.y;\n var lab_0 = new TextLabel(this.myLayoutInfo_0.facetYLabel);\n lab_0.moveTo_lu1900$(x_0, y_0);\n lab_0.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE);\n lab_0.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n lab_0.rotate_14dthe$(90.0);\n this.add_8icvvv$(lab_0);\n }};\n PlotTile.prototype.addAxis_0 = function (geomBounds) {\n if (this.myLayoutInfo_0.xAxisShown) {\n var axis = this.buildAxis_0(this.myScaleX_0, ensureNotNull(this.myLayoutInfo_0.xAxisInfo), this.myCoord_0, this.myTheme_0.axisX());\n axis.moveTo_gpjtzr$(new DoubleVector(geomBounds.left, geomBounds.bottom));\n this.add_8icvvv$(axis);\n }if (this.myLayoutInfo_0.yAxisShown) {\n var axis_0 = this.buildAxis_0(this.myScaleY_0, ensureNotNull(this.myLayoutInfo_0.yAxisInfo), this.myCoord_0, this.myTheme_0.axisY());\n axis_0.moveTo_gpjtzr$(geomBounds.origin);\n this.add_8icvvv$(axis_0);\n }};\n PlotTile.prototype.buildAxis_0 = function (scale, info, coord, theme) {\n var axis = new AxisComponent(info.axisLength, ensureNotNull(info.orientation));\n AxisUtil_getInstance().setBreaks_6e5l22$(axis, scale, coord, info.orientation.isHorizontal);\n AxisUtil_getInstance().applyLayoutInfo_4pg061$(axis, info);\n AxisUtil_getInstance().applyTheme_tna4q5$(axis, theme);\n if (this.isDebugDrawing_0) {\n if (info.tickLabelsBounds != null) {\n var rect = SvgRectElement_init(info.tickLabelsBounds);\n rect.strokeColor().set_11rb$(Color.Companion.GREEN);\n rect.strokeWidth().set_11rb$(1.0);\n rect.fillOpacity().set_11rb$(0.0);\n axis.add_26jijc$(rect);\n }}return axis;\n };\n PlotTile.prototype.buildGeoms_0 = function (sharedNumericMappers, overallNumericDomains, coord) {\n var tmp$;\n var layerRenderers = ArrayList_init();\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var rendererData = LayerRendererUtil_getInstance().createLayerRendererData_knseyn$(layer, sharedNumericMappers, overallNumericDomains);\n var aestheticMappers = rendererData.aestheticMappers;\n var aesthetics = rendererData.aesthetics;\n var targetCollector = new LayerTargetCollectorWithLocator(layer.geomKind, layer.locatorLookupSpec, layer.contextualMapping, coord);\n this.myTargetLocators_0.add_11rb$(targetCollector);\n var ctx = GeomContextBuilder_init().aesthetics_luqwb2$(aesthetics).aestheticMappers_4iu3o$(aestheticMappers).geomTargetCollector_xrq6q$(targetCollector).build();\n var pos = rendererData.pos;\n var geom = layer.geom;\n layerRenderers.add_11rb$(new SvgLayerRenderer(aesthetics, geom, pos, coord, ctx));\n }\n return layerRenderers;\n };\n PlotTile.prototype.setShowAxis_6taknv$ = function (showAxis) {\n this.myShowAxis_0 = showAxis;\n };\n PlotTile.prototype.debugDrawing = function () {\n return this.myDebugDrawing_0;\n };\n PlotTile.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotTile',\n interfaces: [SvgComponent]\n };\n function createCanvasFigure($receiver, bounds) {\n var tmp$;\n return (Kotlin.isType(tmp$ = $receiver.geom, LiveMapGeom) ? tmp$ : throwCCE()).createCanvasFigure_wthzt5$(bounds);\n }\n function PlotTooltipHelper() {\n this.myTileInfos_0 = ArrayList_init();\n }\n PlotTooltipHelper.prototype.removeAllTileInfos = function () {\n this.myTileInfos_0.clear();\n };\n PlotTooltipHelper.prototype.addTileInfo_t6qbjr$ = function (geomBounds, targetLocators) {\n var tileInfo = new PlotTooltipHelper$TileInfo(geomBounds, targetLocators);\n this.myTileInfos_0.add_11rb$(tileInfo);\n };\n PlotTooltipHelper.prototype.createTooltipSpecs_gpjtzr$ = function (plotCoord) {\n var tmp$;\n tmp$ = this.findTileInfo_0(plotCoord);\n if (tmp$ == null) {\n return emptyList();\n }var tileInfo = tmp$;\n var lookupResults = tileInfo.findTargets_xoefl8$(plotCoord);\n return this.createTooltipSpecs_0(lookupResults, tileInfo.axisOrigin_8be2vx$);\n };\n PlotTooltipHelper.prototype.getGeomBounds_gpjtzr$ = function (plotCoord) {\n var tmp$;\n tmp$ = this.findTileInfo_0(plotCoord);\n if (tmp$ == null) {\n return null;\n }var tileInfo = tmp$;\n return tileInfo.geomBounds_8be2vx$;\n };\n PlotTooltipHelper.prototype.findTileInfo_0 = function (plotCoord) {\n var tmp$;\n tmp$ = this.myTileInfos_0.iterator();\n while (tmp$.hasNext()) {\n var tileInfo = tmp$.next();\n if (tileInfo.contains_xoefl8$(plotCoord)) {\n return tileInfo;\n }}\n return null;\n };\n PlotTooltipHelper.prototype.createTooltipSpecs_0 = function (lookupResults, axisOrigin) {\n var tooltipSpecs = ArrayList_init();\n var tmp$;\n tmp$ = lookupResults.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var factory = new TooltipSpecFactory(element.contextualMapping, axisOrigin);\n var tmp$_0;\n tmp$_0 = element.targets.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n tooltipSpecs.addAll_brywnq$(factory.create_62opr5$(element_0));\n }\n }\n return tooltipSpecs;\n };\n function PlotTooltipHelper$TileInfo(geomBounds, targetLocators) {\n this.geomBounds_8be2vx$ = geomBounds;\n var destination = ArrayList_init_0(collectionSizeOrDefault(targetLocators, 10));\n var tmp$;\n tmp$ = targetLocators.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new PlotTooltipHelper$TileInfo$TileTargetLocator(this, item));\n }\n this.myTargetLocators_0 = destination;\n }\n Object.defineProperty(PlotTooltipHelper$TileInfo.prototype, 'axisOrigin_8be2vx$', {\n configurable: true,\n get: function () {\n return new DoubleVector(this.geomBounds_8be2vx$.left, this.geomBounds_8be2vx$.bottom);\n }\n });\n PlotTooltipHelper$TileInfo.prototype.findTargets_xoefl8$ = function (plotCoord) {\n var $receiver = new LocatedTargetsPicker();\n var tmp$;\n tmp$ = this.myTargetLocators_0.iterator();\n while (tmp$.hasNext()) {\n var locator = tmp$.next();\n var result = locator.search_gpjtzr$(plotCoord);\n if (result != null) {\n $receiver.addLookupResult_9sakjw$(result, plotCoord);\n }}\n var targetsPicker = $receiver;\n return targetsPicker.picked;\n };\n PlotTooltipHelper$TileInfo.prototype.contains_xoefl8$ = function (plotCoord) {\n return this.geomBounds_8be2vx$.contains_gpjtzr$(plotCoord);\n };\n function PlotTooltipHelper$TileInfo$TileTargetLocator($outer, locator) {\n this.$outer = $outer;\n TransformedTargetLocator.call(this, locator);\n }\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToTargetCoord_gpjtzr$ = function (coord) {\n return coord.subtract_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin);\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToPlotCoord_gpjtzr$ = function (coord) {\n return coord.add_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin);\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.prototype.convertToPlotDistance_14dthe$ = function (distance) {\n return distance;\n };\n PlotTooltipHelper$TileInfo$TileTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileTargetLocator',\n interfaces: [TransformedTargetLocator]\n };\n PlotTooltipHelper$TileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileInfo',\n interfaces: []\n };\n PlotTooltipHelper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotTooltipHelper',\n interfaces: []\n };\n function PlotUtil() {\n PlotUtil_instance = this;\n }\n function PlotUtil$createLayerPos$ObjectLiteral(closure$aes) {\n this.closure$aes = closure$aes;\n this.groupCount_uijr2l$_0 = lazy(PlotUtil$createLayerPos$ObjectLiteral$groupCount$lambda(closure$aes));\n }\n Object.defineProperty(PlotUtil$createLayerPos$ObjectLiteral.prototype, 'aesthetics', {\n configurable: true,\n get: function () {\n return this.closure$aes;\n }\n });\n Object.defineProperty(PlotUtil$createLayerPos$ObjectLiteral.prototype, 'groupCount', {\n configurable: true,\n get: function () {\n return this.groupCount_uijr2l$_0.value;\n }\n });\n function PlotUtil$createLayerPos$ObjectLiteral$groupCount$lambda(closure$aes) {\n return function () {\n var set = collect.Sets.newHashSet_yl67zr$(closure$aes.groups());\n return set.size;\n };\n }\n PlotUtil$createLayerPos$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProviderContext]\n };\n PlotUtil.prototype.createLayerPos_2iooof$ = function (layer, aes) {\n return layer.createPos_q7kk9g$(new PlotUtil$createLayerPos$ObjectLiteral(aes));\n };\n PlotUtil.prototype.computeLayerDryRunXYRanges_gl53zg$ = function (layer, aes) {\n var geomCtx = GeomContextBuilder_init().aesthetics_luqwb2$(aes).build();\n var rangesAfterPosAdjustment = this.computeLayerDryRunXYRangesAfterPosAdjustment_0(layer, aes, geomCtx);\n var tmp$ = this.computeLayerDryRunXYRangesAfterSizeExpand_0(layer, aes, geomCtx);\n var xRangeAfterSizeExpand = tmp$.component1()\n , yRangeAfterSizeExpand = tmp$.component2();\n var rangeX = rangesAfterPosAdjustment.first;\n if (rangeX == null) {\n rangeX = xRangeAfterSizeExpand;\n } else if (xRangeAfterSizeExpand != null) {\n rangeX = rangeX.span_d226ot$(xRangeAfterSizeExpand);\n }var rangeY = rangesAfterPosAdjustment.second;\n if (rangeY == null) {\n rangeY = yRangeAfterSizeExpand;\n } else if (yRangeAfterSizeExpand != null) {\n rangeY = rangeY.span_d226ot$(yRangeAfterSizeExpand);\n }return new Pair(rangeX, rangeY);\n };\n PlotUtil.prototype.combineRanges_0 = function (aesList, aesthetics) {\n var tmp$, tmp$_0;\n var result = null;\n tmp$ = aesList.iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var range = aesthetics.range_vktour$(aes);\n if (range != null) {\n result = (tmp$_0 = result != null ? result.span_d226ot$(range) : null) != null ? tmp$_0 : range;\n }}\n return result;\n };\n PlotUtil.prototype.computeLayerDryRunXYRangesAfterPosAdjustment_0 = function (layer, aes, geomCtx) {\n var tmp$, tmp$_0, tmp$_1;\n var posAesX = collect.Iterables.toList_yl67zr$(Aes.Companion.affectingScaleX_shhb9a$(layer.renderedAes()));\n var posAesY = collect.Iterables.toList_yl67zr$(Aes.Companion.affectingScaleY_shhb9a$(layer.renderedAes()));\n var pos = this.createLayerPos_2iooof$(layer, aes);\n if (pos.isIdentity) {\n var rangeX = this.combineRanges_0(posAesX, aes);\n var rangeY = this.combineRanges_0(posAesY, aes);\n return new Pair(rangeX, rangeY);\n }var adjustedMinX = 0.0;\n var adjustedMaxX = 0.0;\n var adjustedMinY = 0.0;\n var adjustedMaxY = 0.0;\n var rangesInited = false;\n var cardinality = Kotlin.imul(posAesX.size, posAesY.size);\n var px = Kotlin.newArray(cardinality, null);\n var py = Kotlin.newArray(cardinality, null);\n tmp$ = aes.dataPoints().iterator();\n while (tmp$.hasNext()) {\n var p = tmp$.next();\n var i = -1;\n tmp$_0 = posAesX.iterator();\n while (tmp$_0.hasNext()) {\n var aesX = tmp$_0.next();\n var valX = p.numeric_vktour$(aesX);\n tmp$_1 = posAesY.iterator();\n while (tmp$_1.hasNext()) {\n var aesY = tmp$_1.next();\n var valY = p.numeric_vktour$(aesY);\n i = i + 1 | 0;\n px[i] = valX;\n py[i] = valY;\n }\n }\n while (i >= 0) {\n if (px[i] != null && py[i] != null) {\n var x = px[i];\n var y = py[i];\n if (data_0.SeriesUtil.isFinite_yrwdxb$(x) && data_0.SeriesUtil.isFinite_yrwdxb$(y)) {\n var newLoc = pos.translate_tshsjz$(new DoubleVector(ensureNotNull(x), ensureNotNull(y)), p, geomCtx);\n var adjustedX = newLoc.x;\n var adjustedY = newLoc.y;\n if (rangesInited) {\n var b = adjustedMinX;\n adjustedMinX = JsMath.min(adjustedX, b);\n var b_0 = adjustedMaxX;\n adjustedMaxX = JsMath.max(adjustedX, b_0);\n var b_1 = adjustedMinY;\n adjustedMinY = JsMath.min(adjustedY, b_1);\n var b_2 = adjustedMaxY;\n adjustedMaxY = JsMath.max(adjustedY, b_2);\n } else {\n adjustedMaxX = adjustedX;\n adjustedMinX = adjustedMaxX;\n adjustedMaxY = adjustedY;\n adjustedMinY = adjustedMaxY;\n rangesInited = true;\n }\n }}i = i - 1 | 0;\n }\n }\n var xRange = rangesInited ? new ClosedRange(adjustedMinX, adjustedMaxX) : null;\n var yRange = rangesInited ? new ClosedRange(adjustedMinY, adjustedMaxY) : null;\n return new Pair(xRange, yRange);\n };\n PlotUtil.prototype.computeLayerDryRunXYRangesAfterSizeExpand_0 = function (layer, aesthetics, geomCtx) {\n var renderedAes = layer.renderedAes();\n var computeExpandX = renderedAes.contains_11rb$(Aes.Companion.WIDTH);\n var computeExpandY = renderedAes.contains_11rb$(Aes.Companion.HEIGHT);\n var rangeX = computeExpandX ? this.computeLayerDryRunRangeAfterSizeExpand_0(Aes.Companion.X, Aes.Companion.WIDTH, aesthetics, geomCtx) : null;\n var rangeY = computeExpandY ? this.computeLayerDryRunRangeAfterSizeExpand_0(Aes.Companion.Y, Aes.Companion.HEIGHT, aesthetics, geomCtx) : null;\n return new Pair(rangeX, rangeY);\n };\n PlotUtil.prototype.computeLayerDryRunRangeAfterSizeExpand_0 = function (locationAes, sizeAes, aesthetics, geomCtx) {\n var tmp$;\n var locations = aesthetics.numericValues_vktour$(locationAes).iterator();\n var sizes = aesthetics.numericValues_vktour$(sizeAes).iterator();\n var resolution = geomCtx.getResolution_vktour$(locationAes);\n var minMax = new Float64Array([kotlin_js_internal_DoubleCompanionObject.POSITIVE_INFINITY, kotlin_js_internal_DoubleCompanionObject.NEGATIVE_INFINITY]);\n tmp$ = aesthetics.dataPointCount();\n for (var i = 0; i < tmp$; i++) {\n if (!locations.hasNext()) {\n throw IllegalStateException_init('Index is out of bounds: ' + i + ' for ' + locationAes);\n }if (!sizes.hasNext()) {\n throw IllegalStateException_init('Index is out of bounds: ' + i + ' for ' + sizeAes);\n }var loc = locations.next();\n var size = sizes.next();\n if (data_0.SeriesUtil.isFinite_yrwdxb$(loc) && data_0.SeriesUtil.isFinite_yrwdxb$(size)) {\n var expand = resolution * (ensureNotNull(size) / 2);\n this.updateExpandedMinMax_0(ensureNotNull(loc), expand, minMax);\n }}\n return minMax[0] <= minMax[1] ? new ClosedRange(minMax[0], minMax[1]) : null;\n };\n PlotUtil.prototype.updateExpandedMinMax_0 = function (value, expand, expandedMinMax) {\n var a = value - expand;\n var b = expandedMinMax[0];\n expandedMinMax[0] = JsMath.min(a, b);\n var a_0 = value + expand;\n var b_0 = expandedMinMax[1];\n expandedMinMax[1] = JsMath.max(a_0, b_0);\n };\n PlotUtil.prototype.createLayerDryRunAesthetics_sqg2xh$ = function (layer) {\n var tmp$, tmp$_0, tmp$_1;\n var dryRunMapperByAes = HashMap_init();\n tmp$ = layer.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (aes.isNumeric) {\n tmp$_1 = Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE();\n var value = scale.Mappers.IDENTITY;\n dryRunMapperByAes.put_xwzc9p$(tmp$_1, value);\n }}\n var mappers = this.prepareLayerAestheticMappers_viiuew$(layer, dryRunMapperByAes);\n return this.createLayerAesthetics_kpf4gp$(layer, mappers, emptyMap());\n };\n PlotUtil.prototype.prepareLayerAestheticMappers_viiuew$ = function (layer, sharedNumericMappers) {\n var tmp$;\n var mappers = HashMap_init_0(sharedNumericMappers);\n tmp$ = layer.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var tmp$_0;\n var mapper = (Kotlin.isType(tmp$_0 = sharedNumericMappers, Map) ? tmp$_0 : throwCCE()).get_11rb$(aes);\n if (mapper == null) {\n if (Aes.Companion.isPositionalX_896ixz$(aes)) {\n mapper = sharedNumericMappers.get_11rb$(Aes.Companion.X);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes)) {\n mapper = sharedNumericMappers.get_11rb$(Aes.Companion.Y);\n }}if (mapper == null && layer.hasBinding_896ixz$(aes)) {\n mapper = layer.scaleMap.get_31786j$(aes).mapper;\n }if (mapper != null) {\n var value = mapper;\n mappers.put_xwzc9p$(aes, value);\n }}\n return mappers;\n };\n PlotUtil.prototype.createLayerAesthetics_kpf4gp$ = function (layer, sharedMappers, overallNumericDomains) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var aesBuilder = new AestheticsBuilder();\n aesBuilder.group_ddsh32$(layer.group);\n tmp$ = overallNumericDomains.entries.iterator();\n while (tmp$.hasNext()) {\n var tmp$_4 = tmp$.next();\n var aes = tmp$_4.key;\n var domain = tmp$_4.value;\n if ((tmp$_0 = sharedMappers.get_11rb$(aes)) != null) {\n var tmp$_5, tmp$_6;\n var range = new ClosedRange(typeof (tmp$_5 = tmp$_0(domain.lowerEnd)) === 'number' ? tmp$_5 : throwCCE(), typeof (tmp$_6 = tmp$_0(domain.upperEnd)) === 'number' ? tmp$_6 : throwCCE());\n aesBuilder.overallRange_xlyz3f$(aes, range);\n }}\n var hasPositionalConstants = false;\n tmp$_1 = layer.renderedAes().iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n if (Aes.Companion.isPositional_896ixz$(aes_0) && layer.hasConstant_896ixz$(aes_0)) {\n hasPositionalConstants = true;\n break;\n }}\n var data_0 = layer.dataFrame;\n var dataPointCount = {v: null};\n tmp$_2 = layer.renderedAes().iterator();\n while (tmp$_2.hasNext()) {\n var aes_1 = tmp$_2.next();\n var aes_2 = Kotlin.isType(tmp$_3 = aes_1, Aes) ? tmp$_3 : throwCCE();\n var mapperOption = sharedMappers.get_11rb$(aes_2);\n if (layer.hasConstant_896ixz$(aes_2)) {\n var v = layer.getConstant_31786j$(aes_2);\n aesBuilder.constantAes_bbdhip$(aes_2, this.asAesValue_0(aes_2, v, mapperOption));\n } else {\n if (layer.hasBinding_896ixz$(aes_2)) {\n if (!(mapperOption != null)) {\n var message = 'No scale mapper defined for aesthetic ' + aes_2;\n throw IllegalStateException_init(message.toString());\n }var transformVar = data.DataFrameUtil.transformVarFor_896ixz$(aes_2);\n if (!data_0.has_8xm3sj$(transformVar)) {\n var message_0 = 'Undefined var ' + transformVar + ' for aesthetic ' + aes_2;\n throw IllegalStateException_init(message_0.toString());\n }var numericValues = data_0.getNumeric_8xm3sj$(transformVar);\n if (dataPointCount.v == null) {\n dataPointCount.v = numericValues.size;\n } else {\n if (!(dataPointCount.v === numericValues.size)) {\n var message_1 = '' + toString(aes_2) + ' expected data size=' + toString(dataPointCount.v) + ' was size=' + toString(numericValues.size);\n throw IllegalStateException_init(message_1.toString());\n }}\n if (dataPointCount.v === 0 && hasPositionalConstants) {\n aesBuilder.constantAes_bbdhip$(aes_2, layer.aestheticsDefaults.defaultValue_31786j$(aes_2));\n } else {\n var integerFunction = AestheticsBuilder.Companion.listMapper_sedzz5$(numericValues, mapperOption);\n aesBuilder.aes_u42xfl$(aes_2, integerFunction);\n }\n } else {\n var v_0 = layer.getDefault_31786j$(aes_2);\n aesBuilder.constantAes_bbdhip$(aes_2, this.asAesValue_0(aes_2, v_0, mapperOption));\n }\n }\n }\n if (dataPointCount.v != null && dataPointCount.v > 0) {\n aesBuilder.dataPointCount_za3lpa$(dataPointCount.v);\n } else if (hasPositionalConstants) {\n aesBuilder.dataPointCount_za3lpa$(1);\n }return aesBuilder.build();\n };\n PlotUtil.prototype.asAesValue_0 = function (aes, dataValue, mapperOption) {\n var tmp$, tmp$_0, tmp$_1;\n if (aes.isNumeric && mapperOption != null) {\n tmp$_0 = mapperOption(typeof (tmp$ = dataValue) === 'number' ? tmp$ : null);\n if (tmp$_0 == null) {\n throw IllegalArgumentException_init(\"Can't map \" + dataValue + ' to aesthetic ' + aes);\n }tmp$_1 = tmp$_0;\n } else\n tmp$_1 = dataValue;\n return tmp$_1;\n };\n PlotUtil.prototype.rangeWithExpand_einsbb$ = function (range, scale, includeZero) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (range == null)\n return null;\n var mulExp = scale.multiplicativeExpand;\n var addExp = scale.additiveExpand;\n if (scale.isContinuousDomain) {\n tmp$_0 = Kotlin.isType(tmp$ = scale.transform, ContinuousTransform) ? tmp$ : throwCCE();\n } else {\n tmp$_0 = null;\n }\n var continuousTransform = tmp$_0;\n var lowerEndpoint = (tmp$_1 = continuousTransform != null ? continuousTransform.applyInverse_yrwdxb$(range.lowerEnd) : null) != null ? tmp$_1 : range.lowerEnd;\n var upperEndpoint = (tmp$_2 = continuousTransform != null ? continuousTransform.applyInverse_yrwdxb$(range.upperEnd) : null) != null ? tmp$_2 : range.upperEnd;\n var length = upperEndpoint - lowerEndpoint;\n var lowerExpand = addExp + length * mulExp;\n var upperExpand = lowerExpand;\n if (includeZero) {\n var tmp$_3 = lowerEndpoint === 0.0 || upperEndpoint === 0.0;\n if (!tmp$_3) {\n tmp$_3 = JsMath.sign(lowerEndpoint) === JsMath.sign(upperEndpoint);\n }if (tmp$_3) {\n if (lowerEndpoint >= 0) {\n lowerExpand = 0.0;\n } else {\n upperExpand = 0.0;\n }\n }}var it = lowerEndpoint - lowerExpand;\n var block$result;\n var tmp$_4;\n var transformed = (tmp$_4 = continuousTransform != null ? continuousTransform.apply_yrwdxb$(it) : null) != null ? tmp$_4 : it;\n if (isNaN_0(transformed)) {\n block$result = range.lowerEnd;\n } else {\n block$result = transformed;\n }\n var lowerEndWithExpand = block$result;\n var it_0 = upperEndpoint + upperExpand;\n var block$result_0;\n var tmp$_5;\n var transformed_0 = (tmp$_5 = continuousTransform != null ? continuousTransform.apply_yrwdxb$(it_0) : null) != null ? tmp$_5 : it_0;\n if (isNaN_0(transformed_0)) {\n block$result_0 = range.upperEnd;\n } else {\n block$result_0 = transformed_0;\n }\n var upperEndWithExpand = block$result_0;\n return new ClosedRange(lowerEndWithExpand, upperEndWithExpand);\n };\n PlotUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotUtil',\n interfaces: []\n };\n var PlotUtil_instance = null;\n function PlotUtil_getInstance() {\n if (PlotUtil_instance === null) {\n new PlotUtil();\n }return PlotUtil_instance;\n }\n function PosProviderContext() {\n }\n PosProviderContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PosProviderContext',\n interfaces: []\n };\n function SvgLayerRenderer(myAesthetics, myGeom, myPos, myCoord, myGeomContext) {\n SvgComponent.call(this);\n this.myAesthetics_0 = myAesthetics;\n this.myGeom_0 = myGeom;\n this.myPos_0 = myPos;\n this.myCoord_0 = myCoord;\n this.myGeomContext_0 = myGeomContext;\n }\n SvgLayerRenderer.prototype.buildComponent = function () {\n this.buildLayer_0();\n };\n SvgLayerRenderer.prototype.buildLayer_0 = function () {\n this.myGeom_0.build_uzv8ab$(this, this.myAesthetics_0, this.myPos_0, this.myCoord_0, this.myGeomContext_0);\n };\n SvgLayerRenderer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SvgLayerRenderer',\n interfaces: [SvgRoot, SvgComponent]\n };\n function VarBinding(variable, aes) {\n this.variable = variable;\n this.aes = aes;\n }\n VarBinding.prototype.toString = function () {\n return 'VarBinding{variable=' + this.variable + ', aes=' + this.aes;\n };\n VarBinding.prototype.equals = function (other) {\n var tmp$, tmp$_0;\n if (this === other)\n return true;\n if (other == null || !((tmp$ = Kotlin.getKClassFromExpression(this)) != null ? tmp$.equals(Kotlin.getKClassFromExpression(other)) : null))\n return false;\n Kotlin.isType(tmp$_0 = other, VarBinding) ? tmp$_0 : throwCCE();\n if (!equals(this.variable, other.variable))\n return false;\n if (!equals(this.aes, other.aes))\n return false;\n return true;\n };\n VarBinding.prototype.hashCode = function () {\n var result = hashCode(this.variable);\n result = (31 * result | 0) + hashCode(this.aes) | 0;\n return result;\n };\n VarBinding.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VarBinding',\n interfaces: []\n };\n function ColorBarAssembler(legendTitle, transformedDomain, scale, theme) {\n ColorBarAssembler$Companion_getInstance();\n this.legendTitle_0 = legendTitle;\n this.transformedDomain_0 = transformedDomain;\n this.scale_0 = scale;\n this.theme_0 = theme;\n this.colorBarOptions_0 = null;\n }\n function ColorBarAssembler$createColorBar$ObjectLiteral(closure$spec, size) {\n this.closure$spec = closure$spec;\n LegendBoxInfo.call(this, size);\n }\n ColorBarAssembler$createColorBar$ObjectLiteral.prototype.createLegendBox = function () {\n var c = new ColorBarComponent(this.closure$spec);\n c.debug = ColorBarAssembler$Companion_getInstance().DEBUG_DRAWING_0;\n return c;\n };\n ColorBarAssembler$createColorBar$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n ColorBarAssembler.prototype.createColorBar = function () {\n var scale = this.scale_0;\n if (!scale.hasBreaks()) {\n scale = breaks.ScaleBreaksUtil.withBreaks_qt1l9m$(scale, this.transformedDomain_0, 5);\n }var scaleBreaks = scale.getScaleBreaks();\n if (scaleBreaks.isEmpty) {\n return LegendBoxInfo$Companion_getInstance().EMPTY;\n }var spec = ColorBarAssembler$Companion_getInstance().createColorBarSpec_6r6r64$(this.legendTitle_0, this.transformedDomain_0, scaleBreaks, scale, this.theme_0, this.colorBarOptions_0);\n return new ColorBarAssembler$createColorBar$ObjectLiteral(spec, spec.size);\n };\n ColorBarAssembler.prototype.setOptions_p8ufd2$ = function (options) {\n this.colorBarOptions_0 = options;\n };\n function ColorBarAssembler$Companion() {\n ColorBarAssembler$Companion_instance = this;\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().LEGEND_DEBUG_DRAWING;\n }\n ColorBarAssembler$Companion.prototype.createColorBarSpec_6r6r64$ = function (title, transformedDomain, breaks, scale, theme, options) {\n if (options === void 0)\n options = null;\n var tmp$, tmp$_0;\n var legendDirection = LegendAssemblerUtil_getInstance().legendDirection_730mk3$(theme);\n var horizontal = legendDirection === LegendDirection$HORIZONTAL_getInstance();\n var width = options != null ? options.width : null;\n var height = options != null ? options.height : null;\n var barSize = ColorBarComponentSpec$Companion_getInstance().barAbsoluteSize_kkcal5$(horizontal, theme);\n if (width != null) {\n barSize = new DoubleVector(width, barSize.y);\n }if (height != null) {\n barSize = new DoubleVector(barSize.x, height);\n }var reverse = !horizontal;\n if (horizontal)\n tmp$ = ColorBarComponentLayout$Companion_getInstance().horizontal_dwxw1i$(title, transformedDomain, breaks, barSize, reverse);\n else\n tmp$ = ColorBarComponentLayout$Companion_getInstance().vertical_dwxw1i$(title, transformedDomain, breaks, barSize, reverse);\n var layout = tmp$;\n return new ColorBarComponentSpec(title, transformedDomain, breaks, scale, (tmp$_0 = options != null ? options.binCount : null) != null ? tmp$_0 : 20, theme, layout, reverse);\n };\n ColorBarAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarAssembler$Companion_instance = null;\n function ColorBarAssembler$Companion_getInstance() {\n if (ColorBarAssembler$Companion_instance === null) {\n new ColorBarAssembler$Companion();\n }return ColorBarAssembler$Companion_instance;\n }\n ColorBarAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarAssembler',\n interfaces: []\n };\n function ColorBarOptions() {\n GuideOptions.call(this);\n this.width = null;\n this.height = null;\n this.binCount = null;\n }\n ColorBarOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarOptions',\n interfaces: [GuideOptions]\n };\n function GeomContextBuilder() {\n this.myAesthetics_0 = null;\n this.myAestheticMappers_0 = null;\n this.myGeomTargetCollector_0 = new NullGeomTargetCollector();\n }\n GeomContextBuilder.prototype.aesthetics_luqwb2$ = function (aesthetics) {\n this.myAesthetics_0 = aesthetics;\n return this;\n };\n GeomContextBuilder.prototype.aestheticMappers_4iu3o$ = function (aestheticMappers) {\n this.myAestheticMappers_0 = aestheticMappers;\n return this;\n };\n GeomContextBuilder.prototype.geomTargetCollector_xrq6q$ = function (geomTargetCollector) {\n this.myGeomTargetCollector_0 = geomTargetCollector;\n return this;\n };\n GeomContextBuilder.prototype.build = function () {\n return new GeomContextBuilder$MyGeomContext(this);\n };\n function GeomContextBuilder$MyGeomContext(b) {\n this.myAesthetics = b.myAesthetics_0;\n this.myAestheticMappers = b.myAestheticMappers_0;\n this.targetCollector_2hnek9$_0 = b.myGeomTargetCollector_0;\n }\n Object.defineProperty(GeomContextBuilder$MyGeomContext.prototype, 'targetCollector', {\n configurable: true,\n get: function () {\n return this.targetCollector_2hnek9$_0;\n }\n });\n GeomContextBuilder$MyGeomContext.prototype.getResolution_vktour$ = function (aes) {\n var resolution = 0.0;\n if (this.myAesthetics != null) {\n resolution = this.myAesthetics.resolution_594811$(aes, 0.0);\n }if (resolution <= data_0.SeriesUtil.TINY) {\n resolution = this.getUnitResolution_vktour$(aes);\n }return resolution;\n };\n GeomContextBuilder$MyGeomContext.prototype.getUnitResolution_vktour$ = function (aes) {\n var tmp$, tmp$_0, tmp$_1;\n var mapper = (tmp$_0 = (tmp$ = this.myAestheticMappers) != null ? tmp$.get_11rb$(aes) : null) != null ? tmp$_0 : scale.Mappers.IDENTITY;\n return typeof (tmp$_1 = mapper(1.0)) === 'number' ? tmp$_1 : throwCCE();\n };\n GeomContextBuilder$MyGeomContext.prototype.withTargetCollector_xrq6q$ = function (targetCollector) {\n return GeomContextBuilder_init().aesthetics_luqwb2$(this.myAesthetics).aestheticMappers_4iu3o$(this.myAestheticMappers).geomTargetCollector_xrq6q$(targetCollector).build();\n };\n GeomContextBuilder$MyGeomContext.prototype.with = function () {\n return GeomContextBuilder_init_0(this);\n };\n GeomContextBuilder$MyGeomContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyGeomContext',\n interfaces: [ImmutableGeomContext]\n };\n GeomContextBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomContextBuilder',\n interfaces: [ImmutableGeomContext$Builder]\n };\n function GeomContextBuilder_init($this) {\n $this = $this || Object.create(GeomContextBuilder.prototype);\n GeomContextBuilder.call($this);\n return $this;\n }\n function GeomContextBuilder_init_0(ctx, $this) {\n $this = $this || Object.create(GeomContextBuilder.prototype);\n GeomContextBuilder.call($this);\n $this.myAesthetics_0 = ctx.myAesthetics;\n $this.myAestheticMappers_0 = ctx.myAestheticMappers;\n return $this;\n }\n function GeomLayerBuilder() {\n GeomLayerBuilder$Companion_getInstance();\n this.myBindings_0 = ArrayList_init();\n this.myConstantByAes_0 = new TypedKeyHashMap();\n this.myStat_mcjcnw$_0 = this.myStat_mcjcnw$_0;\n this.myPosProvider_gzkpo7$_0 = this.myPosProvider_gzkpo7$_0;\n this.myGeomProvider_h6nr63$_0 = this.myGeomProvider_h6nr63$_0;\n this.myGroupingVarName_0 = null;\n this.myPathIdVarName_0 = null;\n this.myScaleProviderByAes_0 = HashMap_init();\n this.myDataPreprocessor_0 = null;\n this.myLocatorLookupSpec_0 = GeomTargetLocator$LookupSpec.Companion.NONE;\n this.myContextualMappingProvider_0 = ContextualMappingProvider$Companion_getInstance().NONE;\n this.myIsLegendDisabled_0 = false;\n }\n Object.defineProperty(GeomLayerBuilder.prototype, 'myStat_0', {\n configurable: true,\n get: function () {\n if (this.myStat_mcjcnw$_0 == null)\n return throwUPAE('myStat');\n return this.myStat_mcjcnw$_0;\n },\n set: function (myStat) {\n this.myStat_mcjcnw$_0 = myStat;\n }\n });\n Object.defineProperty(GeomLayerBuilder.prototype, 'myPosProvider_0', {\n configurable: true,\n get: function () {\n if (this.myPosProvider_gzkpo7$_0 == null)\n return throwUPAE('myPosProvider');\n return this.myPosProvider_gzkpo7$_0;\n },\n set: function (myPosProvider) {\n this.myPosProvider_gzkpo7$_0 = myPosProvider;\n }\n });\n Object.defineProperty(GeomLayerBuilder.prototype, 'myGeomProvider_0', {\n configurable: true,\n get: function () {\n if (this.myGeomProvider_h6nr63$_0 == null)\n return throwUPAE('myGeomProvider');\n return this.myGeomProvider_h6nr63$_0;\n },\n set: function (myGeomProvider) {\n this.myGeomProvider_h6nr63$_0 = myGeomProvider;\n }\n });\n GeomLayerBuilder.prototype.stat_qbwusa$ = function (v) {\n this.myStat_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.pos_r08v3h$ = function (v) {\n this.myPosProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.geom_9dfz59$ = function (v) {\n this.myGeomProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.addBinding_14cn14$ = function (v) {\n this.myBindings_0.add_11rb$(v);\n return this;\n };\n GeomLayerBuilder.prototype.groupingVar_8xm3sj$ = function (v) {\n this.myGroupingVarName_0 = v.name;\n return this;\n };\n GeomLayerBuilder.prototype.groupingVarName_61zpoe$ = function (v) {\n this.myGroupingVarName_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.pathIdVarName_61zpoe$ = function (v) {\n this.myPathIdVarName_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.addConstantAes_bbdhip$ = function (aes, v) {\n this.myConstantByAes_0.put_ev6mlr$(aes, v);\n return this;\n };\n GeomLayerBuilder.prototype.addScaleProvider_jv3qxe$ = function (aes, scaleProvider) {\n this.myScaleProviderByAes_0.put_xwzc9p$(aes, scaleProvider);\n return this;\n };\n GeomLayerBuilder.prototype.locatorLookupSpec_271kgc$ = function (v) {\n this.myLocatorLookupSpec_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.contextualMappingProvider_td8fxc$ = function (v) {\n this.myContextualMappingProvider_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.disableLegend_6taknv$ = function (v) {\n this.myIsLegendDisabled_0 = v;\n return this;\n };\n GeomLayerBuilder.prototype.build_fhj1j$ = function (data_0, scaleMap) {\n var tmp$, tmp$_0;\n var data_1 = data_0;\n if (this.myDataPreprocessor_0 != null) {\n data_1 = ensureNotNull(this.myDataPreprocessor_0)(data_1, scaleMap);\n }data_1 = DataProcessing_getInstance().transformOriginals_si9pes$(data_1, this.myBindings_0, scaleMap);\n var $receiver = this.myBindings_0;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n var tmp$_2 = destination.add_11rb$;\n var tmp$_3, tmp$_4;\n tmp$_4 = item.aes;\n if (item.variable.isOrigin) {\n var transformVar = data.DataFrameUtil.transformVarFor_896ixz$(item.aes);\n tmp$_3 = new VarBinding(transformVar, item.aes);\n } else {\n tmp$_3 = item;\n }\n tmp$_2.call(destination, to(tmp$_4, tmp$_3));\n }\n var replacementBindings = HashMap_init_0(toMap(destination));\n var bindingsToPut = ArrayList_init();\n tmp$ = replacementBindings.values.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (variable.isStat) {\n var aes = binding.aes;\n var scale = scaleMap.get_31786j$(aes);\n data_1 = data.DataFrameUtil.applyTransform_xaiv89$(data_1, variable, aes, scale);\n bindingsToPut.add_11rb$(new VarBinding(data.TransformVar.forAes_896ixz$(aes), aes));\n }}\n tmp$_0 = bindingsToPut.iterator();\n while (tmp$_0.hasNext()) {\n var binding_0 = tmp$_0.next();\n var key = binding_0.aes;\n replacementBindings.put_xwzc9p$(key, binding_0);\n }\n var dataAccess = new PointDataAccess(data_1, replacementBindings, scaleMap);\n return new GeomLayerBuilder$MyGeomLayer(data_1, this.myGeomProvider_0, this.myPosProvider_0, this.myGeomProvider_0.renders(), (new GroupingContext(data_1, this.myBindings_0, this.myGroupingVarName_0, this.myPathIdVarName_0, this.handlesGroups_0())).groupMapper, replacementBindings.values, this.myConstantByAes_0, scaleMap, dataAccess, this.myLocatorLookupSpec_0, this.myContextualMappingProvider_0.createContextualMapping_8fr62e$(dataAccess, data_1), this.myIsLegendDisabled_0);\n };\n GeomLayerBuilder.prototype.handlesGroups_0 = function () {\n return this.myGeomProvider_0.handlesGroups() || this.myPosProvider_0.handlesGroups();\n };\n function GeomLayerBuilder$MyGeomLayer(dataFrame, geomProvider, myPosProvider, renderedAes, group, varBindings, constantByAes, scaleMap, dataAccess, locatorLookupSpec, contextualMapping, isLegendDisabled) {\n this.dataFrame_uc8k26$_0 = dataFrame;\n this.myPosProvider_0 = myPosProvider;\n this.group_btwr86$_0 = group;\n this.scaleMap_9lvzv7$_0 = scaleMap;\n this.dataAccess_qkhg5r$_0 = dataAccess;\n this.locatorLookupSpec_65qeye$_0 = locatorLookupSpec;\n this.contextualMapping_1qd07s$_0 = contextualMapping;\n this.isLegendDisabled_1bnyfg$_0 = isLegendDisabled;\n this.geom_ipep5v$_0 = geomProvider.createGeom();\n this.geomKind_qyi6z5$_0 = geomProvider.geomKind;\n this.aestheticsDefaults_4lnusm$_0 = null;\n this.myRenderedAes_0 = null;\n this.myConstantByAes_0 = null;\n this.myVarBindingsByAes_0 = HashMap_init();\n var tmp$, tmp$_0;\n this.myRenderedAes_0 = ArrayList_init_1(renderedAes);\n this.aestheticsDefaults_4lnusm$_0 = geomProvider.aestheticsDefaults();\n this.myConstantByAes_0 = new TypedKeyHashMap();\n tmp$ = constantByAes.keys_287e2$().iterator();\n while (tmp$.hasNext()) {\n var key = tmp$.next();\n this.myConstantByAes_0.put_ev6mlr$(key, constantByAes.get_ex36zt$(key));\n }\n tmp$_0 = varBindings.iterator();\n while (tmp$_0.hasNext()) {\n var varBinding = tmp$_0.next();\n var $receiver = this.myVarBindingsByAes_0;\n var key_0 = varBinding.aes;\n $receiver.put_xwzc9p$(key_0, varBinding);\n }\n }\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'dataFrame', {\n get: function () {\n return this.dataFrame_uc8k26$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'group', {\n get: function () {\n return this.group_btwr86$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'scaleMap', {\n get: function () {\n return this.scaleMap_9lvzv7$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'dataAccess', {\n get: function () {\n return this.dataAccess_qkhg5r$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'locatorLookupSpec', {\n get: function () {\n return this.locatorLookupSpec_65qeye$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'contextualMapping', {\n get: function () {\n return this.contextualMapping_1qd07s$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'isLegendDisabled', {\n get: function () {\n return this.isLegendDisabled_1bnyfg$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'geom', {\n configurable: true,\n get: function () {\n return this.geom_ipep5v$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'geomKind', {\n configurable: true,\n get: function () {\n return this.geomKind_qyi6z5$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'aestheticsDefaults', {\n configurable: true,\n get: function () {\n return this.aestheticsDefaults_4lnusm$_0;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n return this.geom.legendKeyElementFactory;\n }\n });\n Object.defineProperty(GeomLayerBuilder$MyGeomLayer.prototype, 'isLiveMap', {\n configurable: true,\n get: function () {\n return Kotlin.isType(this.geom, LiveMapGeom);\n }\n });\n GeomLayerBuilder$MyGeomLayer.prototype.renderedAes = function () {\n return this.myRenderedAes_0;\n };\n GeomLayerBuilder$MyGeomLayer.prototype.createPos_q7kk9g$ = function (ctx) {\n return this.myPosProvider_0.createPos_q7kk9g$(ctx);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.hasBinding_896ixz$ = function (aes) {\n return this.myVarBindingsByAes_0.containsKey_11rb$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getBinding_31786j$ = function (aes) {\n return ensureNotNull(this.myVarBindingsByAes_0.get_11rb$(aes));\n };\n GeomLayerBuilder$MyGeomLayer.prototype.hasConstant_896ixz$ = function (aes) {\n return this.myConstantByAes_0.containsKey_ex36zt$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getConstant_31786j$ = function (aes) {\n if (!this.hasConstant_896ixz$(aes)) {\n var message = 'Constant value is not defined for aes ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }return this.myConstantByAes_0.get_ex36zt$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.getDefault_31786j$ = function (aes) {\n return this.aestheticsDefaults.defaultValue_31786j$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.rangeIncludesZero_896ixz$ = function (aes) {\n return this.aestheticsDefaults.rangeIncludesZero_896ixz$(aes);\n };\n GeomLayerBuilder$MyGeomLayer.prototype.setLiveMapProvider_kld0fp$ = function (liveMapProvider) {\n if (Kotlin.isType(this.geom, LiveMapGeom)) {\n this.geom.setLiveMapProvider_kld0fp$(liveMapProvider);\n } else {\n throw IllegalStateException_init('Not Livemap: ' + Kotlin.getKClassFromExpression(this.geom).simpleName);\n }\n };\n GeomLayerBuilder$MyGeomLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyGeomLayer',\n interfaces: [GeomLayer]\n };\n function GeomLayerBuilder$Companion() {\n GeomLayerBuilder$Companion_instance = this;\n }\n function GeomLayerBuilder$Companion$demoAndTest$lambda(closure$builder) {\n return function (data, scaleMap) {\n var transformedData = DataProcessing_getInstance().transformOriginals_si9pes$(data, closure$builder.myBindings_0, scaleMap);\n var stat_0 = closure$builder.myStat_0;\n if (equals(stat_0, stat.Stats.IDENTITY))\n return transformedData;\n else {\n var statCtx = new SimpleStatContext(transformedData);\n var groupingContext = new GroupingContext(transformedData, closure$builder.myBindings_0, closure$builder.myGroupingVarName_0, closure$builder.myPathIdVarName_0, true);\n var dataAndGroupingContext = DataProcessing_getInstance().buildStatData_x40e2x$(transformedData, stat_0, closure$builder.myBindings_0, scaleMap, groupingContext, PlotFacets$Companion_getInstance().undefined(), statCtx, emptyList(), emptyList(), null, getCallableRef('println', function (p1) {\n return println(p1), Unit;\n }));\n return dataAndGroupingContext.data;\n }\n };\n }\n GeomLayerBuilder$Companion.prototype.demoAndTest = function () {\n var builder = new GeomLayerBuilder();\n builder.myDataPreprocessor_0 = GeomLayerBuilder$Companion$demoAndTest$lambda(builder);\n return builder;\n };\n GeomLayerBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomLayerBuilder$Companion_instance = null;\n function GeomLayerBuilder$Companion_getInstance() {\n if (GeomLayerBuilder$Companion_instance === null) {\n new GeomLayerBuilder$Companion();\n }return GeomLayerBuilder$Companion_instance;\n }\n GeomLayerBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomLayerBuilder',\n interfaces: []\n };\n function GuideOptions() {\n GuideOptions$Companion_getInstance();\n this.isReverse = false;\n }\n function GuideOptions$Companion() {\n GuideOptions$Companion_instance = this;\n this.NONE = new GuideOptions$Companion$NONE$ObjectLiteral();\n }\n function GuideOptions$Companion$NONE$ObjectLiteral() {\n GuideOptions.call(this);\n }\n GuideOptions$Companion$NONE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [GuideOptions]\n };\n GuideOptions$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GuideOptions$Companion_instance = null;\n function GuideOptions$Companion_getInstance() {\n if (GuideOptions$Companion_instance === null) {\n new GuideOptions$Companion();\n }return GuideOptions$Companion_instance;\n }\n GuideOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideOptions',\n interfaces: []\n };\n function ImmutableGeomContext() {\n }\n function ImmutableGeomContext$Builder() {\n }\n ImmutableGeomContext$Builder.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Builder',\n interfaces: []\n };\n ImmutableGeomContext.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ImmutableGeomContext',\n interfaces: [GeomContext]\n };\n function LegendAssembler(legendTitle, guideOptionsMap, theme) {\n LegendAssembler$Companion_getInstance();\n this.legendTitle_0 = legendTitle;\n this.guideOptionsMap_0 = guideOptionsMap;\n this.theme_0 = theme;\n this.legendLayers_0 = ArrayList_init();\n }\n LegendAssembler.prototype.addLayer_446ka8$ = function (keyFactory, varBindings, constantByAes, aestheticsDefaults, scaleByAes, transformedDomainByAes) {\n this.legendLayers_0.add_11rb$(new LegendAssembler$LegendLayer(keyFactory, varBindings, constantByAes, aestheticsDefaults, scaleByAes, transformedDomainByAes));\n };\n function LegendAssembler$createLegend$ObjectLiteral(closure$spec, size) {\n this.closure$spec = closure$spec;\n LegendBoxInfo.call(this, size);\n }\n LegendAssembler$createLegend$ObjectLiteral.prototype.createLegendBox = function () {\n var c = new LegendComponent(this.closure$spec);\n c.debug = LegendAssembler$Companion_getInstance().DEBUG_DRAWING_0;\n return c;\n };\n LegendAssembler$createLegend$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n LegendAssembler.prototype.createLegend = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var legendBreaksByLabel = LinkedHashMap_init();\n tmp$ = this.legendLayers_0.iterator();\n while (tmp$.hasNext()) {\n var legendLayer = tmp$.next();\n var keyElementFactory = legendLayer.keyElementFactory_8be2vx$;\n var dataPoints = legendLayer.keyAesthetics_8be2vx$.dataPoints().iterator();\n tmp$_0 = legendLayer.keyLabels_8be2vx$.iterator();\n while (tmp$_0.hasNext()) {\n var label = tmp$_0.next();\n var tmp$_5;\n var value = legendBreaksByLabel.get_11rb$(label);\n if (value == null) {\n var answer = new LegendBreak(label);\n legendBreaksByLabel.put_xwzc9p$(label, answer);\n tmp$_5 = answer;\n } else {\n tmp$_5 = value;\n }\n tmp$_5.addLayer_w0u015$(dataPoints.next(), keyElementFactory);\n }\n }\n var legendBreaks = ArrayList_init();\n tmp$_1 = legendBreaksByLabel.values.iterator();\n while (tmp$_1.hasNext()) {\n var legendBreak = tmp$_1.next();\n if (legendBreak.isEmpty) {\n continue;\n }legendBreaks.add_11rb$(legendBreak);\n }\n if (legendBreaks.isEmpty()) {\n return LegendBoxInfo$Companion_getInstance().EMPTY;\n }var legendOptionsList = ArrayList_init();\n tmp$_2 = this.legendLayers_0.iterator();\n while (tmp$_2.hasNext()) {\n var legendLayer_0 = tmp$_2.next();\n var aesList = legendLayer_0.aesList_8be2vx$;\n tmp$_3 = aesList.iterator();\n while (tmp$_3.hasNext()) {\n var aes = tmp$_3.next();\n if (Kotlin.isType(this.guideOptionsMap_0.get_11rb$(aes), LegendOptions)) {\n legendOptionsList.add_11rb$(Kotlin.isType(tmp$_4 = this.guideOptionsMap_0.get_11rb$(aes), LegendOptions) ? tmp$_4 : throwCCE());\n }}\n }\n var spec = LegendAssembler$Companion_getInstance().createLegendSpec_esqxbx$(this.legendTitle_0, legendBreaks, this.theme_0, LegendOptions$Companion_getInstance().combine_pmdc6s$(legendOptionsList));\n return new LegendAssembler$createLegend$ObjectLiteral(spec, spec.size);\n };\n function LegendAssembler$LegendLayer(keyElementFactory, varBindings, constantByAes, aestheticsDefaults, scaleMap, transformedDomainByAes) {\n this.keyElementFactory_8be2vx$ = keyElementFactory;\n this.varBindings_0 = varBindings;\n this.constantByAes_0 = constantByAes;\n this.aestheticsDefaults_0 = aestheticsDefaults;\n this.scaleMap_0 = scaleMap;\n this.keyAesthetics_8be2vx$ = null;\n this.keyLabels_8be2vx$ = null;\n var tmp$, tmp$_0;\n var aesValuesByLabel = LinkedHashMap_init();\n tmp$ = this.varBindings_0.iterator();\n while (tmp$.hasNext()) {\n var varBinding = tmp$.next();\n var aes = varBinding.aes;\n var scale_0 = this.scaleMap_0.get_31786j$(aes);\n if (!scale_0.hasBreaks()) {\n scale_0 = breaks.ScaleBreaksUtil.withBreaks_qt1l9m$(scale_0, getValue(transformedDomainByAes, aes), 5);\n }if (!scale_0.hasBreaks()) {\n var message = 'No breaks were defined for scale ' + aes;\n throw IllegalStateException_init(message.toString());\n }var scaleBreaks = scale_0.getScaleBreaks();\n var aesValues = scale.ScaleUtil.map_9ksyxk$(scaleBreaks.transformedValues, scale_0);\n var labels = scaleBreaks.labels;\n tmp$_0 = zip(labels, aesValues).iterator();\n while (tmp$_0.hasNext()) {\n var tmp$_1 = tmp$_0.next();\n var label = tmp$_1.component1()\n , aesValue = tmp$_1.component2();\n var tmp$_2;\n var value = aesValuesByLabel.get_11rb$(label);\n if (value == null) {\n var answer = HashMap_init();\n aesValuesByLabel.put_xwzc9p$(label, answer);\n tmp$_2 = answer;\n } else {\n tmp$_2 = value;\n }\n var $receiver = tmp$_2;\n var value_0 = ensureNotNull(aesValue);\n $receiver.put_xwzc9p$(aes, value_0);\n }\n }\n this.keyAesthetics_8be2vx$ = LegendAssemblerUtil_getInstance().mapToAesthetics_8kbmqf$(aesValuesByLabel.values, this.constantByAes_0, this.aestheticsDefaults_0);\n this.keyLabels_8be2vx$ = ArrayList_init_1(aesValuesByLabel.keys);\n }\n Object.defineProperty(LegendAssembler$LegendLayer.prototype, 'aesList_8be2vx$', {\n configurable: true,\n get: function () {\n var $receiver = this.varBindings_0;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item.aes);\n }\n return destination;\n }\n });\n LegendAssembler$LegendLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendLayer',\n interfaces: []\n };\n function LegendAssembler$Companion() {\n LegendAssembler$Companion_instance = this;\n this.DEBUG_DRAWING_0 = FeatureSwitch_getInstance().LEGEND_DEBUG_DRAWING;\n }\n function LegendAssembler$Companion$createLegendSpec$pretty(v) {\n var margin = 1.0;\n var x = v.x / 2;\n var tmp$ = JsMath.floor(x) * 2 + 1.0 + margin;\n var x_0 = v.y / 2;\n return new DoubleVector(tmp$, JsMath.floor(x_0) * 2 + 1.0 + margin);\n }\n LegendAssembler$Companion.prototype.createLegendSpec_esqxbx$ = function (title, breaks, theme, options) {\n if (options === void 0)\n options = new LegendOptions();\n var tmp$, tmp$_0, tmp$_1;\n var legendDirection = LegendAssemblerUtil_getInstance().legendDirection_730mk3$(theme);\n var pretty = LegendAssembler$Companion$createLegendSpec$pretty;\n var keySize = new DoubleVector(theme.keySize(), theme.keySize());\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var minimumKeySize = br.minimumKeySize;\n keySize = keySize.max_gpjtzr$(pretty(minimumKeySize));\n }\n var breakCount = breaks.size;\n var colCount;\n var rowCount;\n if (options.isByRow) {\n if (options.hasColCount()) {\n var a = options.colCount;\n tmp$_0 = JsMath.min(a, breakCount);\n } else if (options.hasRowCount()) {\n var x = breakCount / options.rowCount;\n tmp$_0 = numberToInt(JsMath.ceil(x));\n } else if (legendDirection === LegendDirection$HORIZONTAL_getInstance())\n tmp$_0 = breakCount;\n else\n tmp$_0 = 1;\n colCount = tmp$_0;\n var x_0 = breakCount / colCount;\n rowCount = numberToInt(JsMath.ceil(x_0));\n } else {\n if (options.hasRowCount()) {\n var a_0 = options.rowCount;\n tmp$_1 = JsMath.min(a_0, breakCount);\n } else if (options.hasColCount()) {\n var x_1 = breakCount / options.colCount;\n tmp$_1 = numberToInt(JsMath.ceil(x_1));\n } else if (legendDirection !== LegendDirection$HORIZONTAL_getInstance())\n tmp$_1 = breakCount;\n else\n tmp$_1 = 1;\n rowCount = tmp$_1;\n var x_2 = breakCount / rowCount;\n colCount = numberToInt(JsMath.ceil(x_2));\n }\n var layout;\n if (legendDirection === LegendDirection$HORIZONTAL_getInstance()) {\n if (options.hasRowCount() || (options.hasColCount() && options.colCount < breakCount)) {\n layout = LegendComponentLayout$Companion_getInstance().horizontalMultiRow_2y8ibu$(title, breaks, keySize);\n } else {\n layout = LegendComponentLayout$Companion_getInstance().horizontal_2y8ibu$(title, breaks, keySize);\n }\n } else {\n layout = LegendComponentLayout$Companion_getInstance().vertical_2y8ibu$(title, breaks, keySize);\n }\n layout.colCount = colCount;\n layout.rowCount = rowCount;\n layout.isFillByRow = options.isByRow;\n return new LegendComponentSpec(title, breaks, theme, layout, false);\n };\n LegendAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendAssembler$Companion_instance = null;\n function LegendAssembler$Companion_getInstance() {\n if (LegendAssembler$Companion_instance === null) {\n new LegendAssembler$Companion();\n }return LegendAssembler$Companion_instance;\n }\n LegendAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendAssembler',\n interfaces: []\n };\n function LegendAssemblerUtil() {\n LegendAssemblerUtil_instance = this;\n }\n LegendAssemblerUtil.prototype.mapToAesthetics_ml5orx$ = function (valuesByAes, constantByAes, aestheticsDefaults) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var builder = new AestheticsBuilder(0);\n tmp$ = Aes.Companion.values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n builder.constantAes_bbdhip$(Kotlin.isType(tmp$_0 = aes, Aes) ? tmp$_0 : throwCCE(), aestheticsDefaults.defaultValue_31786j$(aes));\n }\n tmp$_1 = valuesByAes.keys.iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n var values = ensureNotNull(valuesByAes.get_11rb$(aes_0));\n builder.aes_u42xfl$(aes_0, AestheticsBuilder.Companion.collection_mqih57$(values));\n builder.dataPointCount_za3lpa$(values.size);\n }\n tmp$_2 = constantByAes.keys.iterator();\n while (tmp$_2.hasNext()) {\n var aes_1 = tmp$_2.next();\n builder.constantAes_bbdhip$(aes_1, ensureNotNull(constantByAes.get_11rb$(aes_1)));\n }\n return builder.build();\n };\n function LegendAssemblerUtil$mapToAesthetics$lambda(closure$dataPoints, closure$aes) {\n return function (index) {\n return ensureNotNull(closure$dataPoints.get_za3lpa$(index).get_11rb$(closure$aes));\n };\n }\n LegendAssemblerUtil.prototype.mapToAesthetics_8kbmqf$ = function (valueByAesIterable, constantByAes, aestheticsDefaults) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var dataPoints = ArrayList_init();\n tmp$ = valueByAesIterable.iterator();\n while (tmp$.hasNext()) {\n var valueByAes = tmp$.next();\n var dataPoint = HashMap_init();\n tmp$_0 = Aes.Companion.values().iterator();\n while (tmp$_0.hasNext()) {\n var aes = tmp$_0.next();\n var value = ensureNotNull(aestheticsDefaults.defaultValueInLegend_31786j$(aes));\n dataPoint.put_xwzc9p$(aes, value);\n }\n tmp$_1 = constantByAes.keys.iterator();\n while (tmp$_1.hasNext()) {\n var constantAes = tmp$_1.next();\n if (equals(constantAes, Aes.Companion.SHAPE) || equals(constantAes, Aes.Companion.COLOR) || equals(constantAes, Aes.Companion.FILL)) {\n var value_0 = ensureNotNull(constantByAes.get_11rb$(constantAes));\n dataPoint.put_xwzc9p$(constantAes, value_0);\n }}\n tmp$_2 = valueByAes.keys.iterator();\n while (tmp$_2.hasNext()) {\n var aes_0 = tmp$_2.next();\n var value_1 = ensureNotNull(valueByAes.get_11rb$(aes_0));\n dataPoint.put_xwzc9p$(aes_0, value_1);\n }\n dataPoints.add_11rb$(dataPoint);\n }\n var builder = new AestheticsBuilder(dataPoints.size);\n tmp$_3 = Aes.Companion.values().iterator();\n while (tmp$_3.hasNext()) {\n var aes_1 = tmp$_3.next();\n builder.aes_u42xfl$(Kotlin.isType(tmp$_4 = aes_1, Aes) ? tmp$_4 : throwCCE(), LegendAssemblerUtil$mapToAesthetics$lambda(dataPoints, aes_1));\n }\n return builder.build();\n };\n LegendAssemblerUtil.prototype.legendDirection_730mk3$ = function (theme) {\n var legendDirection = theme.direction();\n if (legendDirection === LegendDirection$AUTO_getInstance()) {\n var legendPosition = theme.position();\n legendDirection = legendPosition === LegendPosition$Companion_getInstance().TOP || legendPosition === LegendPosition$Companion_getInstance().BOTTOM ? LegendDirection$HORIZONTAL_getInstance() : LegendDirection$VERTICAL_getInstance();\n }return legendDirection;\n };\n LegendAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LegendAssemblerUtil',\n interfaces: []\n };\n var LegendAssemblerUtil_instance = null;\n function LegendAssemblerUtil_getInstance() {\n if (LegendAssemblerUtil_instance === null) {\n new LegendAssemblerUtil();\n }return LegendAssemblerUtil_instance;\n }\n function LegendOptions() {\n LegendOptions$Companion_getInstance();\n GuideOptions.call(this);\n this.myColCount_0 = null;\n this.myRowCount_0 = null;\n this.isByRow = false;\n }\n Object.defineProperty(LegendOptions.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myColCount_0);\n },\n set: function (colCount) {\n this.myColCount_0 = JsMath.max(1, colCount);\n }\n });\n Object.defineProperty(LegendOptions.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myRowCount_0);\n },\n set: function (rowCount) {\n this.myRowCount_0 = JsMath.max(1, rowCount);\n }\n });\n LegendOptions.prototype.hasColCount = function () {\n return this.myColCount_0 != null;\n };\n LegendOptions.prototype.hasRowCount = function () {\n return this.myRowCount_0 != null;\n };\n function LegendOptions$Companion() {\n LegendOptions$Companion_instance = this;\n }\n LegendOptions$Companion.prototype.combine_pmdc6s$ = function (optionsList) {\n var tmp$;\n var result = new LegendOptions();\n tmp$ = optionsList.iterator();\n while (tmp$.hasNext()) {\n var options = tmp$.next();\n if (options.isByRow) {\n result.isByRow = true;\n }if (options.hasColCount()) {\n result.colCount = options.colCount;\n }if (options.hasRowCount()) {\n result.rowCount = options.rowCount;\n }}\n return result;\n };\n LegendOptions$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendOptions$Companion_instance = null;\n function LegendOptions$Companion_getInstance() {\n if (LegendOptions$Companion_instance === null) {\n new LegendOptions$Companion();\n }return LegendOptions$Companion_instance;\n }\n LegendOptions.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendOptions',\n interfaces: [GuideOptions]\n };\n function PlotAssembler(scaleByAes, layersByTile, myCoordProvider, myTheme) {\n PlotAssembler$Companion_getInstance();\n this.scaleByAes_0 = scaleByAes;\n this.layersByTile = layersByTile;\n this.myCoordProvider_0 = myCoordProvider;\n this.myTheme_0 = myTheme;\n this.containsLiveMap = false;\n this.facets = PlotFacets$Companion_getInstance().undefined();\n this.myTitle_0 = null;\n this.myGuideOptionsMap_0 = HashMap_init();\n this.myAxisEnabled_0 = false;\n this.myLegendsEnabled_0 = true;\n this.myInteractionsEnabled_0 = true;\n var $receiver = flatten(this.layersByTile);\n var predicate = getPropertyCallableRef('isLiveMap', 1, function ($receiver) {\n return $receiver.isLiveMap;\n });\n var any$result;\n any$break: do {\n var tmp$;\n if (Kotlin.isType($receiver, Collection) && $receiver.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (predicate(element)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n this.containsLiveMap = any$result;\n this.myAxisEnabled_0 = !this.containsLiveMap;\n }\n PlotAssembler.prototype.setTitle_pdl1vj$ = function (title) {\n this.myTitle_0 = title;\n };\n PlotAssembler.prototype.hasLayers_0 = function () {\n var tmp$;\n tmp$ = this.layersByTile.iterator();\n while (tmp$.hasNext()) {\n var tileLayers = tmp$.next();\n if (!tileLayers.isEmpty()) {\n return true;\n }}\n return false;\n };\n PlotAssembler.prototype.createPlot = function () {\n if (!this.hasLayers_0()) {\n var message = 'No layers in plot';\n throw IllegalArgumentException_init(message.toString());\n }var legendsBoxInfos = this.myLegendsEnabled_0 ? PlotAssemblerUtil_getInstance().createLegends_fyi7ho$(this.layersByTile, this.myGuideOptionsMap_0, this.myTheme_0.legend()) : emptyList();\n var xScaleProto = this.scaleByAes_0.get_31786j$(Aes.Companion.X);\n var yScaleProto = this.scaleByAes_0.get_31786j$(Aes.Companion.Y);\n if (this.containsLiveMap) {\n var plotLayout = PlotAssemblerUtil_getInstance().createPlotLayout_3sq5f9$(new LiveMapTileLayout(), this.facets);\n return this.createXYPlot_0(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos, true);\n }var tmp$ = PlotAssemblerUtil_getInstance().computePlotDryRunXYRanges_7yawgb$(this.layersByTile);\n var xDomain = tmp$.component1()\n , yDomain = tmp$.component2();\n var xAxisLayout;\n var yAxisLayout;\n if (this.myAxisEnabled_0) {\n xAxisLayout = PlotAxisLayout$Companion_getInstance().bottom_eknalg$(xScaleProto, xDomain, yDomain, this.myCoordProvider_0, this.myTheme_0.axisX());\n yAxisLayout = PlotAxisLayout$Companion_getInstance().left_eknalg$(yScaleProto, xDomain, yDomain, this.myCoordProvider_0, this.myTheme_0.axisY());\n } else {\n xAxisLayout = EmptyAxisLayout$Companion_getInstance().bottom_gyv40k$(xDomain, yDomain);\n yAxisLayout = EmptyAxisLayout$Companion_getInstance().left_gyv40k$(xDomain, yDomain);\n }\n var plotLayout_0 = PlotAssemblerUtil_getInstance().createPlotLayout_3sq5f9$(new XYPlotTileLayout(xAxisLayout, yAxisLayout), this.facets);\n if (!this.myAxisEnabled_0) {\n plotLayout_0.setPadding_6y0v78$(0.0, 0.0, 0.0, 0.0);\n }return this.createXYPlot_0(xScaleProto, yScaleProto, plotLayout_0, legendsBoxInfos);\n };\n PlotAssembler.prototype.createXYPlot_0 = function (xScaleProto, yScaleProto, plotLayout, legendBoxInfos, hasLiveMap) {\n if (hasLiveMap === void 0)\n hasLiveMap = false;\n var tmp$, tmp$_0;\n var plotBuilder = new PlotBuilder(this.myTheme_0);\n plotBuilder.setTitle_pdl1vj$(this.myTitle_0);\n plotBuilder.scaleXProto_iu85h4$(xScaleProto);\n plotBuilder.scaleYProto_iu85h4$(yScaleProto);\n plotBuilder.setAxisTitleBottom_61zpoe$(xScaleProto.name);\n plotBuilder.setAxisTitleLeft_61zpoe$(yScaleProto.name);\n plotBuilder.setCoordProvider_sdecqr$(this.myCoordProvider_0);\n tmp$ = legendBoxInfos.iterator();\n while (tmp$.hasNext()) {\n var legendBoxInfo = tmp$.next();\n plotBuilder.addLegendBoxInfo_29gouq$(legendBoxInfo);\n }\n tmp$_0 = this.layersByTile.iterator();\n while (tmp$_0.hasNext()) {\n var panelLayers = tmp$_0.next();\n plotBuilder.addTileLayers_relqli$(panelLayers);\n }\n plotBuilder.setPlotLayout_vjneqj$(plotLayout);\n plotBuilder.axisEnabled_6taknv$(this.myAxisEnabled_0);\n plotBuilder.interactionsEnabled_6taknv$(this.myInteractionsEnabled_0);\n plotBuilder.setLiveMap_6taknv$(hasLiveMap);\n return plotBuilder.build();\n };\n PlotAssembler.prototype.setGuideOptionsMap_qayxze$ = function (guideOptionsMap) {\n this.myGuideOptionsMap_0 = guideOptionsMap;\n };\n PlotAssembler.prototype.disableAxis = function () {\n this.myAxisEnabled_0 = false;\n };\n PlotAssembler.prototype.disableLegends = function () {\n this.myLegendsEnabled_0 = false;\n };\n PlotAssembler.prototype.disableInteractions = function () {\n this.myInteractionsEnabled_0 = false;\n };\n function PlotAssembler$Companion() {\n PlotAssembler$Companion_instance = this;\n }\n PlotAssembler$Companion.prototype.singleTile_wqghlj$ = function (scaleByAes, plotLayers, coordProvider, theme) {\n var layersByTile = ArrayList_init();\n layersByTile.add_11rb$(plotLayers);\n return this.multiTile_bm7ueq$(scaleByAes, layersByTile, coordProvider, theme);\n };\n PlotAssembler$Companion.prototype.multiTile_bm7ueq$ = function (scaleByAes, layersByTile, coordProvider, theme) {\n return new PlotAssembler(scaleByAes, layersByTile, coordProvider, theme);\n };\n PlotAssembler$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotAssembler$Companion_instance = null;\n function PlotAssembler$Companion_getInstance() {\n if (PlotAssembler$Companion_instance === null) {\n new PlotAssembler$Companion();\n }return PlotAssembler$Companion_instance;\n }\n PlotAssembler.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotAssembler',\n interfaces: []\n };\n function PlotAssemblerUtil() {\n PlotAssemblerUtil_instance = this;\n }\n PlotAssemblerUtil.prototype.updateAesRangeMap_0 = function (aes, range, rangeByAes) {\n var range_0 = range;\n if (range_0 != null) {\n var wasRange = rangeByAes.get_11rb$(aes);\n if (wasRange != null) {\n range_0 = wasRange.span_d226ot$(range_0);\n }var value = range_0;\n rangeByAes.put_xwzc9p$(aes, value);\n }};\n PlotAssemblerUtil.prototype.updateRange_0 = function (range, wasRange) {\n var range_0 = range;\n if (range_0 != null) {\n if (wasRange != null) {\n range_0 = wasRange.span_d226ot$(range_0);\n }return range_0;\n }return wasRange;\n };\n PlotAssemblerUtil.prototype.updateRange_1 = function (values, wasRange) {\n if (!collect.Iterables.isEmpty_fakr2g$(values)) {\n var newRange = ClosedRange.Companion.encloseAll_17hg47$(values);\n if (wasRange != null) {\n newRange = wasRange.span_d226ot$(newRange);\n }return newRange;\n }return wasRange;\n };\n PlotAssemblerUtil.prototype.createLegends_fyi7ho$ = function (layersByPanel, guideOptionsMap, theme) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var planeCount = 0;\n if (!layersByPanel.isEmpty()) {\n planeCount = layersByPanel.get_za3lpa$(0).size;\n }var stitchedLayersList = ArrayList_init();\n tmp$ = planeCount;\n for (var i = 0; i < tmp$; i++) {\n var layersOnPlane = ArrayList_init();\n tmp$_0 = layersByPanel.iterator();\n while (tmp$_0.hasNext()) {\n var panelLayers = tmp$_0.next();\n layersOnPlane.add_11rb$(panelLayers.get_za3lpa$(i));\n }\n stitchedLayersList.add_11rb$(new StitchedPlotLayers(layersOnPlane));\n }\n var transformedDomainByAes = HashMap_init();\n tmp$_1 = stitchedLayersList.iterator();\n while (tmp$_1.hasNext()) {\n var stitchedPlotLayers = tmp$_1.next();\n var layerTransformedDomainByAes = PlotGuidesAssemblerUtil_getInstance().guideTransformedDomainByAes_rf697z$(stitchedPlotLayers, guideOptionsMap);\n tmp$_2 = layerTransformedDomainByAes.entries.iterator();\n while (tmp$_2.hasNext()) {\n var tmp$_3 = tmp$_2.next();\n var aes = tmp$_3.key;\n var transformedDomain = tmp$_3.value;\n this.updateAesRangeMap_0(aes, transformedDomain, transformedDomainByAes);\n }\n }\n return this.createLegends_0(stitchedLayersList, transformedDomainByAes, guideOptionsMap, theme);\n };\n PlotAssemblerUtil.prototype.createLegends_0 = function (stitchedLayersList, transformedDomainByAes, guideOptionsMap, theme) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4, tmp$_5, tmp$_6;\n var legendAssemblerByTitle = LinkedHashMap_init();\n var colorBarAssemblerByTitle = LinkedHashMap_init();\n tmp$ = stitchedLayersList.iterator();\n while (tmp$.hasNext()) {\n var stitchedLayers = tmp$.next();\n var layerConstantByAes = HashMap_init();\n tmp$_0 = stitchedLayers.renderedAes().iterator();\n while (tmp$_0.hasNext()) {\n var aes = tmp$_0.next();\n if (stitchedLayers.hasConstant_896ixz$(aes)) {\n var value = ensureNotNull(stitchedLayers.getConstant_31786j$(aes));\n layerConstantByAes.put_xwzc9p$(aes, value);\n }}\n var layerBindingsByScaleName = LinkedHashMap_init();\n var aesList = PlotGuidesAssemblerUtil_getInstance().mappedRenderedAesToCreateGuides_rf697z$(stitchedLayers, guideOptionsMap);\n tmp$_1 = aesList.iterator();\n while (tmp$_1.hasNext()) {\n var aes_0 = tmp$_1.next();\n var colorBar = false;\n var binding = stitchedLayers.getBinding_896ixz$(aes_0);\n var scale = stitchedLayers.getScale_896ixz$(aes_0);\n var scaleName = scale.name;\n if (guideOptionsMap.containsKey_11rb$(aes_0)) {\n var guideOptions = guideOptionsMap.get_11rb$(aes_0);\n if (Kotlin.isType(guideOptions, ColorBarOptions)) {\n PlotGuidesAssemblerUtil_getInstance().checkFitsColorBar_k9b7d3$(binding.aes, scale);\n colorBar = true;\n var colorScale = Kotlin.isType(tmp$_2 = scale, Scale) ? tmp$_2 : throwCCE();\n var value_0 = PlotGuidesAssemblerUtil_getInstance().createColorBarAssembler_mzqjql$(scaleName, binding.aes, transformedDomainByAes, colorScale, guideOptions, theme);\n colorBarAssemblerByTitle.put_xwzc9p$(scaleName, value_0);\n }} else if (PlotGuidesAssemblerUtil_getInstance().fitsColorBar_k9b7d3$(binding.aes, scale)) {\n colorBar = true;\n var colorScale_0 = Kotlin.isType(tmp$_3 = scale, Scale) ? tmp$_3 : throwCCE();\n var value_1 = PlotGuidesAssemblerUtil_getInstance().createColorBarAssembler_mzqjql$(scaleName, binding.aes, transformedDomainByAes, colorScale_0, null, theme);\n colorBarAssemblerByTitle.put_xwzc9p$(scaleName, value_1);\n }if (!colorBar) {\n var tmp$_7;\n var value_2 = layerBindingsByScaleName.get_11rb$(scaleName);\n if (value_2 == null) {\n var answer = ArrayList_init();\n layerBindingsByScaleName.put_xwzc9p$(scaleName, answer);\n tmp$_7 = answer;\n } else {\n tmp$_7 = value_2;\n }\n tmp$_7.add_11rb$(binding);\n }}\n tmp$_4 = layerBindingsByScaleName.keys.iterator();\n while (tmp$_4.hasNext()) {\n var scaleName_0 = tmp$_4.next();\n var tmp$_8;\n var value_3 = legendAssemblerByTitle.get_11rb$(scaleName_0);\n if (value_3 == null) {\n var answer_0 = new LegendAssembler(scaleName_0, guideOptionsMap, theme);\n legendAssemblerByTitle.put_xwzc9p$(scaleName_0, answer_0);\n tmp$_8 = answer_0;\n } else {\n tmp$_8 = value_3;\n }\n var legendAssembler = tmp$_8;\n var varBindings = ensureNotNull(layerBindingsByScaleName.get_11rb$(scaleName_0));\n var legendKeyFactory = stitchedLayers.legendKeyElementFactory;\n var aestheticsDefaults = stitchedLayers.aestheticsDefaults;\n legendAssembler.addLayer_446ka8$(legendKeyFactory, varBindings, layerConstantByAes, aestheticsDefaults, stitchedLayers.getScaleMap(), transformedDomainByAes);\n }\n }\n var legendBoxInfos = ArrayList_init();\n tmp$_5 = colorBarAssemblerByTitle.keys.iterator();\n while (tmp$_5.hasNext()) {\n var legendTitle = tmp$_5.next();\n var boxInfo = ensureNotNull(colorBarAssemblerByTitle.get_11rb$(legendTitle)).createColorBar();\n if (!boxInfo.isEmpty) {\n legendBoxInfos.add_11rb$(boxInfo);\n }}\n tmp$_6 = legendAssemblerByTitle.keys.iterator();\n while (tmp$_6.hasNext()) {\n var legendTitle_0 = tmp$_6.next();\n var boxInfo_0 = ensureNotNull(legendAssemblerByTitle.get_11rb$(legendTitle_0)).createLegend();\n if (!boxInfo_0.isEmpty) {\n legendBoxInfos.add_11rb$(boxInfo_0);\n }}\n return legendBoxInfos;\n };\n PlotAssemblerUtil.prototype.createPlotLayout_3sq5f9$ = function (tileLayout, facets) {\n if (!facets.isDefined) {\n return new SingleTilePlotLayout(tileLayout);\n }return new FacetGridPlotLayout(facets, tileLayout);\n };\n PlotAssemblerUtil.prototype.computePlotDryRunXYRanges_7yawgb$ = function (layersByTile) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var dryRunAestheticsByTileLayer = HashMap_init();\n tmp$ = layersByTile.iterator();\n while (tmp$.hasNext()) {\n var tileLayers = tmp$.next();\n tmp$_0 = tileLayers.iterator();\n while (tmp$_0.hasNext()) {\n var layer = tmp$_0.next();\n var aesthetics = PlotUtil_getInstance().createLayerDryRunAesthetics_sqg2xh$(layer);\n dryRunAestheticsByTileLayer.put_xwzc9p$(layer, aesthetics);\n }\n }\n var layers0 = layersByTile.get_za3lpa$(0);\n var scaleMap = layers0.get_za3lpa$(0).scaleMap;\n var xScale = scaleMap.get_31786j$(Aes.Companion.X);\n var yScale = scaleMap.get_31786j$(Aes.Companion.Y);\n var xInitialRange = PlotAssemblerUtil$RangeUtil_getInstance().initialRange_iu85h4$(xScale);\n var yInitialRange = PlotAssemblerUtil$RangeUtil_getInstance().initialRange_iu85h4$(yScale);\n var xRangeOverall = null;\n var yRangeOverall = null;\n tmp$_1 = layersByTile.iterator();\n while (tmp$_1.hasNext()) {\n var tileLayers_0 = tmp$_1.next();\n tmp$_2 = tileLayers_0.iterator();\n while (tmp$_2.hasNext()) {\n var layer_0 = tmp$_2.next();\n var aesthetics_0 = getValue(dryRunAestheticsByTileLayer, layer_0);\n var xyRanges = PlotUtil_getInstance().computeLayerDryRunXYRanges_gl53zg$(layer_0, aesthetics_0);\n var xRangeLayer = this.updateRange_0(xInitialRange, xyRanges.first);\n var yRangeLayer = this.updateRange_0(yInitialRange, xyRanges.second);\n xRangeOverall = this.updateRange_0(xRangeLayer, xRangeOverall);\n yRangeOverall = this.updateRange_0(yRangeLayer, yRangeOverall);\n }\n }\n xRangeOverall = PlotAssemblerUtil$RangeUtil_getInstance().expandRange_orhr76$(xRangeOverall, Aes.Companion.X, xScale, layers0);\n yRangeOverall = PlotAssemblerUtil$RangeUtil_getInstance().expandRange_orhr76$(yRangeOverall, Aes.Companion.Y, yScale, layers0);\n xRangeOverall = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(xRangeOverall);\n yRangeOverall = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(yRangeOverall);\n return new Pair(xRangeOverall, yRangeOverall);\n };\n function PlotAssemblerUtil$RangeUtil() {\n PlotAssemblerUtil$RangeUtil_instance = this;\n }\n PlotAssemblerUtil$RangeUtil.prototype.initialRange_iu85h4$ = function (scale_0) {\n var initialRange = null;\n if (scale_0.isContinuousDomain) {\n var tmp$ = PlotAssemblerUtil_getInstance();\n var $receiver = toList(scale.ScaleUtil.transformedDefinedLimits_x4zrm4$(scale_0));\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (isFinite(element))\n destination.add_11rb$(element);\n }\n initialRange = tmp$.updateRange_1(destination, initialRange);\n }if (scale_0.hasBreaks()) {\n var scaleBreaks = scale_0.getScaleBreaks();\n initialRange = PlotAssemblerUtil_getInstance().updateRange_1(scaleBreaks.transformedValues, initialRange);\n }return initialRange;\n };\n PlotAssemblerUtil$RangeUtil.prototype.expandRange_orhr76$ = function (range, aes, scale, layers) {\n var tmp$;\n var any$result;\n any$break: do {\n var tmp$_0;\n if (Kotlin.isType(layers, Collection) && layers.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_0 = layers.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (element.rangeIncludesZero_896ixz$(aes)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n var includeZero = any$result;\n if (includeZero === true)\n tmp$ = PlotAssemblerUtil_getInstance().updateRange_0(ClosedRange.Companion.singleton_f1zjgi$(0.0), range);\n else if (includeZero === false)\n tmp$ = range;\n else\n tmp$ = Kotlin.noWhenBranchMatched();\n var range_0 = tmp$;\n return PlotUtil_getInstance().rangeWithExpand_einsbb$(range_0, scale, includeZero);\n };\n PlotAssemblerUtil$RangeUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'RangeUtil',\n interfaces: []\n };\n var PlotAssemblerUtil$RangeUtil_instance = null;\n function PlotAssemblerUtil$RangeUtil_getInstance() {\n if (PlotAssemblerUtil$RangeUtil_instance === null) {\n new PlotAssemblerUtil$RangeUtil();\n }return PlotAssemblerUtil$RangeUtil_instance;\n }\n PlotAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotAssemblerUtil',\n interfaces: []\n };\n var PlotAssemblerUtil_instance = null;\n function PlotAssemblerUtil_getInstance() {\n if (PlotAssemblerUtil_instance === null) {\n new PlotAssemblerUtil();\n }return PlotAssemblerUtil_instance;\n }\n function PlotFacets() {\n PlotFacets$Companion_getInstance();\n }\n function PlotFacets$Companion() {\n PlotFacets$Companion_instance = this;\n this.DEF_ORDER_DIR = 1;\n this.DEF_FORMATTER = PlotFacets$Companion$DEF_FORMATTER$lambda;\n }\n PlotFacets$Companion.prototype.undefined = function () {\n return new FacetGrid(null, null, emptyList(), emptyList(), 1, 1);\n };\n PlotFacets$Companion.prototype.dataByLevelTuple_w4sfrb$ = function (data, varNames, varLevels) {\n var tmp$, tmp$_0, tmp$_1;\n var nameLevelTuples = this.createNameLevelTuples_5cxrh4$(varNames, varLevels);\n var indicesByVarByLevel = this.dataIndicesByVarByLevel_0(data, varNames, varLevels);\n var dataByLevelKey = ArrayList_init();\n tmp$ = nameLevelTuples.iterator();\n while (tmp$.hasNext()) {\n var nameLevelTuple = tmp$.next();\n var topName = first(nameLevelTuple).first;\n var topLevel = first(nameLevelTuple).second;\n var indices = ArrayList_init_1(getValue(getValue(indicesByVarByLevel, topName), topLevel));\n tmp$_0 = nameLevelTuple.size;\n for (var i = 1; i < tmp$_0; i++) {\n var name = nameLevelTuple.get_za3lpa$(i).first;\n var level = nameLevelTuple.get_za3lpa$(i).second;\n var levelIndices = getValue(getValue(indicesByVarByLevel, name), level);\n indices.retainAll_brywnq$(HashSet_init(levelIndices));\n }\n var destination = ArrayList_init_0(collectionSizeOrDefault(nameLevelTuple, 10));\n var tmp$_2;\n tmp$_2 = nameLevelTuple.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(item.second);\n }\n var levelKey = destination;\n var b = DataFrame$DataFrame$Builder_init();\n var variables = data.variables();\n tmp$_1 = variables.iterator();\n while (tmp$_1.hasNext()) {\n var variable = tmp$_1.next();\n var source = data.get_8xm3sj$(variable);\n var target = data_0.SeriesUtil.pickAtIndices_ge51dg$(source, indices);\n b.put_2l962d$(variable, target);\n }\n var levelData = b.build();\n dataByLevelKey.add_11rb$(to(levelKey, levelData));\n }\n return dataByLevelKey;\n };\n PlotFacets$Companion.prototype.dataIndicesByVarByLevel_0 = function (data_1, varNames, varLevels) {\n var indicesByVarByLevel = HashMap_init();\n var i = 0;\n for (var tmp$ = varNames.iterator(); tmp$.hasNext(); ++i) {\n var varName = tmp$.next();\n var tmp$_0, tmp$_1;\n var levels = varLevels.get_za3lpa$(i);\n var indicesByLevel = HashMap_init();\n tmp$_0 = levels.iterator();\n while (tmp$_0.hasNext()) {\n var level = tmp$_0.next();\n if (data_1.isEmpty)\n tmp$_1 = emptyList();\n else {\n var variable = data.DataFrameUtil.findVariableOrFail_vede35$(data_1, varName);\n tmp$_1 = data_0.SeriesUtil.matchingIndices_3vukww$(data_1.get_8xm3sj$(variable), level);\n }\n var indices = tmp$_1;\n indicesByLevel.put_xwzc9p$(level, indices);\n }\n indicesByVarByLevel.put_xwzc9p$(varName, indicesByLevel);\n }\n return indicesByVarByLevel;\n };\n PlotFacets$Companion.prototype.createNameLevelTuples_5cxrh4$ = function (varNames, varLevels) {\n if (!!varNames.isEmpty()) {\n var message = 'Empty list of facet variables.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(varNames.size === distinct(varNames).size)) {\n var message_0 = 'Facet variables must be distinct, were: ' + varNames + '.';\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(varNames.size === varLevels.size)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }return this.createNameLevelTuplesIntern_0(varNames, varLevels);\n };\n PlotFacets$Companion.prototype.createNameLevelTuplesIntern_0 = function (varNames, varLevels) {\n var tmp$, tmp$_0;\n var name = first(varNames);\n var levels = first(varLevels);\n var levelKeys = ArrayList_init();\n tmp$ = levels.iterator();\n while (tmp$.hasNext()) {\n var level = tmp$.next();\n if (varNames.size > 1) {\n var subKeys = this.createNameLevelTuples_5cxrh4$(varNames.subList_vux9f0$(1, varNames.size), varLevels.subList_vux9f0$(1, varLevels.size));\n tmp$_0 = subKeys.iterator();\n while (tmp$_0.hasNext()) {\n var subKey = tmp$_0.next();\n levelKeys.add_11rb$(plus(listOf(to(name, level)), subKey));\n }\n } else {\n levelKeys.add_11rb$(listOf(to(name, level)));\n }\n }\n return levelKeys;\n };\n PlotFacets$Companion.prototype.reorderLevels_dyo1lv$ = function (varNames, varLevels, ordering) {\n var orderingByFacet = toMap(zip(varNames, ordering));\n var result = ArrayList_init();\n var i = 0;\n for (var tmp$ = varNames.iterator(); tmp$.hasNext(); ++i) {\n var name = tmp$.next();\n if (i >= varLevels.size)\n break;\n result.add_11rb$(this.reorderVarLevels_pbdvt$(name, varLevels.get_za3lpa$(i), getValue(orderingByFacet, name)));\n }\n return result;\n };\n PlotFacets$Companion.prototype.reorderVarLevels_pbdvt$ = function (name, levels, order) {\n var tmp$, tmp$_0;\n if (name == null)\n return levels;\n Kotlin.isType(tmp$ = levels, List) ? tmp$ : throwCCE();\n if (order < 0)\n tmp$_0 = sortedDescending(levels);\n else\n tmp$_0 = sorted(levels);\n return tmp$_0;\n };\n function PlotFacets$Companion$DEF_FORMATTER$lambda(it) {\n return it.toString();\n }\n PlotFacets$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotFacets$Companion_instance = null;\n function PlotFacets$Companion_getInstance() {\n if (PlotFacets$Companion_instance === null) {\n new PlotFacets$Companion();\n }return PlotFacets$Companion_instance;\n }\n function PlotFacets$FacetTileInfo(col, row, colLabs, rowLab, xAxis, yAxis, trueIndex) {\n this.col = col;\n this.row = row;\n this.colLabs = colLabs;\n this.rowLab = rowLab;\n this.xAxis = xAxis;\n this.yAxis = yAxis;\n this.trueIndex = trueIndex;\n }\n PlotFacets$FacetTileInfo.prototype.toString = function () {\n return 'FacetTileInfo(col=' + this.col + ', row=' + this.row + ', colLabs=' + this.colLabs + ', rowLab=' + toString(this.rowLab) + ')';\n };\n PlotFacets$FacetTileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetTileInfo',\n interfaces: []\n };\n PlotFacets.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotFacets',\n interfaces: []\n };\n function PlotGuidesAssemblerUtil() {\n PlotGuidesAssemblerUtil_instance = this;\n }\n PlotGuidesAssemblerUtil.prototype.mappedRenderedAesToCreateGuides_rf697z$ = function (layerTiles, guideOptionsMap) {\n var tmp$;\n if (layerTiles.isLegendDisabled) {\n return emptyList();\n }var result = ArrayList_init();\n tmp$ = layerTiles.renderedAes().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (Aes.Companion.noGuideNeeded_896ixz$(aes)) {\n continue;\n }if (layerTiles.hasConstant_896ixz$(aes)) {\n continue;\n }if (!layerTiles.hasBinding_896ixz$(aes)) {\n continue;\n }if (guideOptionsMap.containsKey_11rb$(aes)) {\n if (guideOptionsMap.get_11rb$(aes) === GuideOptions$Companion_getInstance().NONE) {\n continue;\n }}result.add_11rb$(aes);\n }\n return result;\n };\n PlotGuidesAssemblerUtil.prototype.guideTransformedDomainByAes_rf697z$ = function (stitchedLayers, guideOptionsMap) {\n var tmp$;\n var transformedDomainByAes = HashMap_init();\n var aesSet = this.mappedRenderedAesToCreateGuides_rf697z$(stitchedLayers, guideOptionsMap);\n tmp$ = aesSet.iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n var transformVariable = stitchedLayers.getBinding_896ixz$(aes).variable;\n if (!transformVariable.isTransform) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }var transformedDataRange = stitchedLayers.getDataRange_8xm3sj$(transformVariable);\n var scale = stitchedLayers.getScale_896ixz$(aes);\n if (scale.isContinuousDomain) {\n var value = this.refineTransformedDataRangeForContinuousDomain_0(transformedDataRange, scale);\n transformedDomainByAes.put_xwzc9p$(aes, value);\n } else if (transformedDataRange != null) {\n transformedDomainByAes.put_xwzc9p$(aes, transformedDataRange);\n }}\n return transformedDomainByAes;\n };\n PlotGuidesAssemblerUtil.prototype.refineTransformedDataRangeForContinuousDomain_0 = function (transformedDataRange, scale_0) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n if (transformedDataRange == null)\n tmp$ = new Pair_0(kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN);\n else\n tmp$ = new Pair_0(transformedDataRange.lowerEnd, transformedDataRange.upperEnd);\n var tmp$_4 = tmp$;\n var dataLower = tmp$_4.component1()\n , dataUpper = tmp$_4.component2();\n if (scale_0.hasDomainLimits() === true)\n tmp$_0 = scale.ScaleUtil.transformedDefinedLimits_x4zrm4$(scale_0);\n else\n tmp$_0 = new Pair_0(kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN);\n var tmp$_5 = tmp$_0;\n var scaleLower = tmp$_5.component1()\n , scaleUpper = tmp$_5.component2();\n var lowerEnd = isFinite(scaleLower) ? scaleLower : dataLower;\n var upperEnd = isFinite(scaleUpper) ? scaleUpper : dataUpper;\n if (isFinite(lowerEnd) && isFinite(upperEnd))\n tmp$_1 = new ClosedRange(lowerEnd, upperEnd);\n else if (isFinite(lowerEnd))\n tmp$_1 = new ClosedRange(lowerEnd, lowerEnd);\n else if (isFinite(upperEnd))\n tmp$_1 = new ClosedRange(upperEnd, upperEnd);\n else\n tmp$_1 = null;\n var newRange = tmp$_1;\n tmp$_3 = Kotlin.isType(tmp$_2 = scale_0.transform, ContinuousTransform) ? tmp$_2 : throwCCE();\n return transform.Transforms.ensureApplicableDomain_wa8y5m$(newRange, tmp$_3);\n };\n PlotGuidesAssemblerUtil.prototype.createColorBarAssembler_mzqjql$ = function (scaleName, aes, transformedDomainByAes, scale, options, theme) {\n var transformedDomain = transformedDomainByAes.get_11rb$(aes);\n if (transformedDomain == null) {\n var message = 'Domain for continuous data must not be null';\n throw IllegalStateException_init(message.toString());\n }var result = new ColorBarAssembler(scaleName, transformedDomain, scale, theme);\n result.setOptions_p8ufd2$(options);\n return result;\n };\n PlotGuidesAssemblerUtil.prototype.fitsColorBar_k9b7d3$ = function (aes, scale) {\n return aes.isColor && scale.isContinuous;\n };\n PlotGuidesAssemblerUtil.prototype.checkFitsColorBar_k9b7d3$ = function (aes, scale) {\n if (!aes.isColor) {\n var message = 'Color-bar is not applicable to ' + aes + ' aesthetic';\n throw IllegalStateException_init(message.toString());\n }if (!scale.isContinuous) {\n var message_0 = 'Color-bar is only applicable when both domain and color palette are continuous';\n throw IllegalStateException_init(message_0.toString());\n }};\n PlotGuidesAssemblerUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotGuidesAssemblerUtil',\n interfaces: []\n };\n var PlotGuidesAssemblerUtil_instance = null;\n function PlotGuidesAssemblerUtil_getInstance() {\n if (PlotGuidesAssemblerUtil_instance === null) {\n new PlotGuidesAssemblerUtil();\n }return PlotGuidesAssemblerUtil_instance;\n }\n function PosProvider() {\n PosProvider$Companion_getInstance();\n }\n function PosProvider$Companion() {\n PosProvider$Companion_instance = this;\n }\n function PosProvider$Companion$wrap$ObjectLiteral(closure$pos) {\n this.closure$pos = closure$pos;\n PosProvider.call(this);\n }\n PosProvider$Companion$wrap$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return this.closure$pos;\n };\n PosProvider$Companion$wrap$ObjectLiteral.prototype.handlesGroups = function () {\n return this.closure$pos.handlesGroups();\n };\n PosProvider$Companion$wrap$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.wrap_dkjclg$ = function (pos) {\n return new PosProvider$Companion$wrap$ObjectLiteral(pos);\n };\n function PosProvider$Companion$barStack$ObjectLiteral() {\n PosProvider.call(this);\n }\n PosProvider$Companion$barStack$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.stack_4vnpmn$(ctx.aesthetics, PositionAdjustments$StackingStrategy.SPLIT_POSITIVE_NEGATIVE);\n };\n PosProvider$Companion$barStack$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.STACK.handlesGroups();\n };\n PosProvider$Companion$barStack$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.barStack = function () {\n return new PosProvider$Companion$barStack$ObjectLiteral();\n };\n function PosProvider$Companion$dodge$ObjectLiteral(closure$width) {\n this.closure$width = closure$width;\n PosProvider.call(this);\n }\n PosProvider$Companion$dodge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n var aesthetics = ctx.aesthetics;\n var groupCount = ctx.groupCount;\n return pos.PositionAdjustments.dodge_vvhcz8$(aesthetics, groupCount, this.closure$width);\n };\n PosProvider$Companion$dodge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.DODGE.handlesGroups();\n };\n PosProvider$Companion$dodge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.dodge_yrwdxb$ = function (width) {\n if (width === void 0)\n width = null;\n return new PosProvider$Companion$dodge$ObjectLiteral(width);\n };\n function PosProvider$Companion$fill$ObjectLiteral() {\n PosProvider.call(this);\n }\n PosProvider$Companion$fill$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.fill_m7huy5$(ctx.aesthetics);\n };\n PosProvider$Companion$fill$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.FILL.handlesGroups();\n };\n PosProvider$Companion$fill$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.fill = function () {\n return new PosProvider$Companion$fill$ObjectLiteral();\n };\n function PosProvider$Companion$jitter$ObjectLiteral(closure$width, closure$height) {\n this.closure$width = closure$width;\n this.closure$height = closure$height;\n PosProvider.call(this);\n }\n PosProvider$Companion$jitter$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.jitter_jma9l8$(this.closure$width, this.closure$height);\n };\n PosProvider$Companion$jitter$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.JITTER.handlesGroups();\n };\n PosProvider$Companion$jitter$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.jitter_jma9l8$ = function (width, height) {\n return new PosProvider$Companion$jitter$ObjectLiteral(width, height);\n };\n function PosProvider$Companion$nudge$ObjectLiteral(closure$width, closure$height) {\n this.closure$width = closure$width;\n this.closure$height = closure$height;\n PosProvider.call(this);\n }\n PosProvider$Companion$nudge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n return pos.PositionAdjustments.nudge_jma9l8$(this.closure$width, this.closure$height);\n };\n PosProvider$Companion$nudge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.NUDGE.handlesGroups();\n };\n PosProvider$Companion$nudge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.nudge_jma9l8$ = function (width, height) {\n return new PosProvider$Companion$nudge$ObjectLiteral(width, height);\n };\n function PosProvider$Companion$jitterDodge$ObjectLiteral(closure$width, closure$jitterWidth, closure$jitterHeight) {\n this.closure$width = closure$width;\n this.closure$jitterWidth = closure$jitterWidth;\n this.closure$jitterHeight = closure$jitterHeight;\n PosProvider.call(this);\n }\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.createPos_q7kk9g$ = function (ctx) {\n var aesthetics = ctx.aesthetics;\n var groupCount = ctx.groupCount;\n return pos.PositionAdjustments.jitterDodge_e2pc44$(aesthetics, groupCount, this.closure$width, this.closure$jitterWidth, this.closure$jitterHeight);\n };\n PosProvider$Companion$jitterDodge$ObjectLiteral.prototype.handlesGroups = function () {\n return PositionAdjustments$Meta.JITTER_DODGE.handlesGroups();\n };\n PosProvider$Companion$jitterDodge$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PosProvider]\n };\n PosProvider$Companion.prototype.jitterDodge_xjrefz$ = function (width, jitterWidth, jitterHeight) {\n return new PosProvider$Companion$jitterDodge$ObjectLiteral(width, jitterWidth, jitterHeight);\n };\n PosProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PosProvider$Companion_instance = null;\n function PosProvider$Companion_getInstance() {\n if (PosProvider$Companion_instance === null) {\n new PosProvider$Companion();\n }return PosProvider$Companion_instance;\n }\n PosProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PosProvider',\n interfaces: []\n };\n function StitchedPlotLayers(layers) {\n this.myLayers_0 = null;\n this.myLayers_0 = ArrayList_init_1(layers);\n }\n Object.defineProperty(StitchedPlotLayers.prototype, 'legendKeyElementFactory', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).legendKeyElementFactory;\n }\n });\n Object.defineProperty(StitchedPlotLayers.prototype, 'aestheticsDefaults', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).aestheticsDefaults;\n }\n });\n Object.defineProperty(StitchedPlotLayers.prototype, 'isLegendDisabled', {\n configurable: true,\n get: function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).isLegendDisabled;\n }\n });\n StitchedPlotLayers.prototype.renderedAes = function () {\n var tmp$;\n if (this.myLayers_0.isEmpty()) {\n tmp$ = emptyList();\n } else\n tmp$ = this.myLayers_0.get_za3lpa$(0).renderedAes();\n return tmp$;\n };\n StitchedPlotLayers.prototype.hasBinding_896ixz$ = function (aes) {\n return !this.myLayers_0.isEmpty() && this.myLayers_0.get_za3lpa$(0).hasBinding_896ixz$(aes);\n };\n StitchedPlotLayers.prototype.hasConstant_896ixz$ = function (aes) {\n return !this.myLayers_0.isEmpty() && this.myLayers_0.get_za3lpa$(0).hasConstant_896ixz$(aes);\n };\n StitchedPlotLayers.prototype.getConstant_31786j$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).getConstant_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getBinding_896ixz$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).getBinding_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getScale_896ixz$ = function (aes) {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).scaleMap.get_31786j$(aes);\n };\n StitchedPlotLayers.prototype.getScaleMap = function () {\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }return this.myLayers_0.get_za3lpa$(0).scaleMap;\n };\n StitchedPlotLayers.prototype.getDataRange_8xm3sj$ = function (variable) {\n var tmp$;\n if (!this.isNumericData_0(variable)) {\n var message = 'Not numeric data [' + variable + ']';\n throw IllegalStateException_init(message.toString());\n }var result = null;\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var range = layer.dataFrame.range_8xm3sj$(variable);\n result = data_0.SeriesUtil.span_t7esj2$(result, range);\n }\n return result;\n };\n StitchedPlotLayers.prototype.isNumericData_0 = function (variable) {\n var tmp$;\n if (!!this.myLayers_0.isEmpty()) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n if (!layer.dataFrame.isNumeric_8xm3sj$(variable)) {\n return false;\n }}\n return true;\n };\n StitchedPlotLayers.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'StitchedPlotLayers',\n interfaces: []\n };\n function TypedScaleMap(map) {\n TypedScaleMap$Companion_getInstance();\n this.myMap_0 = toMap_0(map);\n }\n function TypedScaleMap$get$lambda$lambda(closure$message) {\n return function () {\n return closure$message;\n };\n }\n TypedScaleMap.prototype.get_31786j$ = function (aes) {\n var tmp$, tmp$_0;\n var tmp$_1;\n if ((tmp$_0 = Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), Scale) ? tmp$ : null) != null)\n tmp$_1 = tmp$_0;\n else {\n var message = 'No scale found for aes: ' + aes;\n TypedScaleMap$Companion_getInstance().LOG_0.error_l35kib$(IllegalStateException_init(message), TypedScaleMap$get$lambda$lambda(message));\n throw IllegalStateException_init(message.toString());\n }\n return tmp$_1;\n };\n TypedScaleMap.prototype.containsKey_896ixz$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n TypedScaleMap.prototype.keySet = function () {\n return this.myMap_0.keys;\n };\n function TypedScaleMap$Companion() {\n TypedScaleMap$Companion_instance = this;\n this.LOG_0 = logging.PortableLogging.logger_xo1ogr$(getKClass(TypedScaleMap));\n }\n TypedScaleMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TypedScaleMap$Companion_instance = null;\n function TypedScaleMap$Companion_getInstance() {\n if (TypedScaleMap$Companion_instance === null) {\n new TypedScaleMap$Companion();\n }return TypedScaleMap$Companion_instance;\n }\n TypedScaleMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedScaleMap',\n interfaces: []\n };\n function TypedScaleProviderMap(map) {\n this.myMap_0 = toMap_0(map);\n }\n TypedScaleProviderMap.prototype.get_31786j$ = function (aes) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), ScaleProvider) ? tmp$ : throwCCE();\n };\n TypedScaleProviderMap.prototype.containsKey_896ixz$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n TypedScaleProviderMap.prototype.keySet = function () {\n return this.myMap_0.keys;\n };\n TypedScaleProviderMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedScaleProviderMap',\n interfaces: []\n };\n function FacetGrid(xVar, yVar, xLevels, yLevels, xOrder, yOrder, xFormatter, yFormatter) {\n if (xFormatter === void 0)\n xFormatter = PlotFacets$Companion_getInstance().DEF_FORMATTER;\n if (yFormatter === void 0)\n yFormatter = PlotFacets$Companion_getInstance().DEF_FORMATTER;\n PlotFacets.call(this);\n this.xVar_0 = xVar;\n this.yVar_0 = yVar;\n this.xFormatter_0 = xFormatter;\n this.yFormatter_0 = yFormatter;\n this.isDefined_f95yff$_0 = this.xVar_0 != null || this.yVar_0 != null;\n this.xLevels_0 = PlotFacets$Companion_getInstance().reorderVarLevels_pbdvt$(this.xVar_0, xLevels, xOrder);\n this.yLevels_0 = PlotFacets$Companion_getInstance().reorderVarLevels_pbdvt$(this.yVar_0, yLevels, yOrder);\n var b = xLevels.size;\n this.colCount_bhcvpt$_0 = JsMath.max(1, b);\n var b_0 = yLevels.size;\n this.rowCount_8ohw8b$_0 = JsMath.max(1, b_0);\n this.numTiles_kasr4x$_0 = Kotlin.imul(this.colCount, this.rowCount);\n }\n Object.defineProperty(FacetGrid.prototype, 'isDefined', {\n configurable: true,\n get: function () {\n return this.isDefined_f95yff$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_bhcvpt$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_8ohw8b$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'numTiles', {\n configurable: true,\n get: function () {\n return this.numTiles_kasr4x$_0;\n }\n });\n Object.defineProperty(FacetGrid.prototype, 'variables', {\n configurable: true,\n get: function () {\n return listOfNotNull([this.xVar_0, this.yVar_0]);\n }\n });\n FacetGrid.prototype.dataByTile_dhhkv7$ = function (data) {\n var tmp$;\n var tmp$_0, tmp$_1, tmp$_2;\n if (!this.isDefined) {\n var message = 'dataByTile() called on Undefined plot facets.';\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = listOfNotNull([this.xVar_0, this.yVar_0]);\n tmp$_0 = listOfNotNull([this.xVar_0 != null ? this.xLevels_0 : null, this.yVar_0 != null ? this.yLevels_0 : null]);\n var dataByLevelTupleList = PlotFacets$Companion_getInstance().dataByLevelTuple_w4sfrb$(data, tmp$, tmp$_0);\n var dataByLevelTuple = toMap(dataByLevelTupleList);\n var $receiver = this.xLevels_0;\n var colLevels = $receiver.isEmpty() ? listOf(null) : $receiver;\n var $receiver_0 = this.yLevels_0;\n var rowLevels = $receiver_0.isEmpty() ? listOf(null) : $receiver_0;\n var dataByTile = ArrayList_init();\n tmp$_1 = rowLevels.iterator();\n while (tmp$_1.hasNext()) {\n var rowLevel = tmp$_1.next();\n tmp$_2 = colLevels.iterator();\n while (tmp$_2.hasNext()) {\n var colLevel = tmp$_2.next();\n var levelTuple = listOfNotNull([colLevel, rowLevel]);\n var tileData = getValue(dataByLevelTuple, levelTuple);\n dataByTile.add_11rb$(tileData);\n }\n }\n return dataByTile;\n };\n FacetGrid.prototype.tileInfos = function () {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n var $receiver = this.xLevels_0;\n var $receiver_0 = $receiver.isEmpty() ? listOf(null) : $receiver;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_4;\n tmp$_4 = $receiver_0.iterator();\n while (tmp$_4.hasNext()) {\n var item = tmp$_4.next();\n destination.add_11rb$(item != null ? this.xFormatter_0(item) : null);\n }\n var colLabels = destination;\n var $receiver_1 = this.yLevels_0;\n var $receiver_2 = $receiver_1.isEmpty() ? listOf(null) : $receiver_1;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault($receiver_2, 10));\n var tmp$_5;\n tmp$_5 = $receiver_2.iterator();\n while (tmp$_5.hasNext()) {\n var item_0 = tmp$_5.next();\n destination_0.add_11rb$(item_0 != null ? this.yFormatter_0(item_0) : null);\n }\n var rowLabels = destination_0;\n var infos = ArrayList_init();\n tmp$ = this.rowCount;\n for (var row = 0; row < tmp$; row++) {\n var addColLab = row === 0;\n var hasXAxis = row === (this.rowCount - 1 | 0);\n tmp$_0 = this.colCount;\n for (var col = 0; col < tmp$_0; col++) {\n var addRowLab = col === (this.colCount - 1 | 0);\n var hasYAxis = col === 0;\n if (addColLab) {\n tmp$_3 = (tmp$_2 = (tmp$_1 = colLabels.get_za3lpa$(col)) != null ? listOf(tmp$_1) : null) != null ? tmp$_2 : emptyList();\n } else {\n tmp$_3 = emptyList();\n }\n var colLabs = tmp$_3;\n infos.add_11rb$(new PlotFacets$FacetTileInfo(col, row, colLabs, addRowLab ? rowLabels.get_za3lpa$(row) : null, hasXAxis, hasYAxis, infos.size));\n }\n }\n return infos;\n };\n FacetGrid.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetGrid',\n interfaces: [PlotFacets]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n var thenBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (this$thenBy, closure$selector) {\n return function (a, b) {\n var previousCompare = this$thenBy.compare(a, b);\n var tmp$;\n if (previousCompare !== 0)\n tmp$ = previousCompare;\n else {\n var selector = closure$selector;\n tmp$ = compareValues(selector(a), selector(b));\n }\n return tmp$;\n };\n };\n });\n function FacetWrap(facets, levels, nrow, ncol, direction, facetOrdering, facetFormatters) {\n FacetWrap$Companion_getInstance();\n PlotFacets.call(this);\n this.facets_0 = facets;\n this.nrow_0 = nrow;\n this.ncol_0 = ncol;\n this.direction_0 = direction;\n this.facetFormatters_0 = facetFormatters;\n this.isDefined_lws8hd$_0 = true;\n this.levels_0 = PlotFacets$Companion_getInstance().reorderLevels_dyo1lv$(this.facets_0, levels, facetOrdering);\n this.numTiles_a1ir1h$_0 = FacetWrap$Companion_getInstance().numTiles_0(this.facets_0, levels);\n this.shape_0 = FacetWrap$Companion_getInstance().shape_0(this.numTiles, this.ncol_0, this.nrow_0, this.direction_0);\n this.colCount_182vmd$_0 = this.shape_0.first;\n this.rowCount_1ks3v5$_0 = this.shape_0.second;\n this.variables_i11eyv$_0 = this.facets_0;\n }\n Object.defineProperty(FacetWrap.prototype, 'isDefined', {\n configurable: true,\n get: function () {\n return this.isDefined_lws8hd$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'numTiles', {\n configurable: true,\n get: function () {\n return this.numTiles_a1ir1h$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_182vmd$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_1ks3v5$_0;\n }\n });\n Object.defineProperty(FacetWrap.prototype, 'variables', {\n configurable: true,\n get: function () {\n return this.variables_i11eyv$_0;\n }\n });\n FacetWrap.prototype.dataByTile_dhhkv7$ = function (data) {\n var tmp$;\n var dataByLevelTuple = PlotFacets$Companion_getInstance().dataByLevelTuple_w4sfrb$(data, this.variables, this.levels_0);\n var dataByTile = ArrayList_init();\n tmp$ = dataByLevelTuple.iterator();\n while (tmp$.hasNext()) {\n var tmp$_0 = tmp$.next();\n var tileData = tmp$_0.component2();\n dataByTile.add_11rb$(tileData);\n }\n return dataByTile;\n };\n function FacetWrap$tileInfos$toCol(this$FacetWrap) {\n return function (index) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = index % this$FacetWrap.colCount;\n break;\n case 'V':\n tmp$ = index / this$FacetWrap.rowCount | 0;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$toRow(this$FacetWrap) {\n return function (index) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = index / this$FacetWrap.colCount | 0;\n break;\n case 'V':\n tmp$ = index % this$FacetWrap.rowCount;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$toIndex(this$FacetWrap) {\n return function (col, row) {\n var tmp$;\n switch (this$FacetWrap.direction_0.name) {\n case 'H':\n tmp$ = Kotlin.imul(row, this$FacetWrap.colCount) + col | 0;\n break;\n case 'V':\n tmp$ = Kotlin.imul(col, this$FacetWrap.rowCount) + row | 0;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n function FacetWrap$tileInfos$isBottom(closure$toIndex, this$FacetWrap) {\n return function (col, row) {\n var nextRowIndex = closure$toIndex(col, row + 1 | 0);\n return (row + 1 | 0) % this$FacetWrap.rowCount === 0 || nextRowIndex >= this$FacetWrap.numTiles;\n };\n }\n function FacetWrap$tileInfos$lambda(it) {\n return it.row;\n }\n function FacetWrap$tileInfos$lambda_0(it) {\n return it.col;\n }\n FacetWrap.prototype.tileInfos = function () {\n var levelTuples = PlotFacets$Companion_getInstance().createNameLevelTuples_5cxrh4$(this.facets_0, this.levels_0);\n var destination = ArrayList_init_0(collectionSizeOrDefault(levelTuples, 10));\n var tmp$;\n tmp$ = levelTuples.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(item, 10));\n var tmp$_1;\n tmp$_1 = item.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n destination_0.add_11rb$(item_0.second);\n }\n tmp$_0.call(destination, destination_0);\n }\n var destination_1 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item_1 = tmp$_2.next();\n var tmp$_3 = destination_1.add_11rb$;\n var destination_2 = ArrayList_init_0(collectionSizeOrDefault(item_1, 10));\n var tmp$_4, tmp$_0_0;\n var index = 0;\n tmp$_4 = item_1.iterator();\n while (tmp$_4.hasNext()) {\n var item_2 = tmp$_4.next();\n destination_2.add_11rb$(this.facetFormatters_0.get_za3lpa$(checkIndexOverflow((tmp$_0_0 = index, index = tmp$_0_0 + 1 | 0, tmp$_0_0)))(item_2));\n }\n tmp$_3.call(destination_1, destination_2);\n }\n var tileLabels = destination_1;\n var toCol = FacetWrap$tileInfos$toCol(this);\n var toRow = FacetWrap$tileInfos$toRow(this);\n var toIndex = FacetWrap$tileInfos$toIndex(this);\n var isBottom = FacetWrap$tileInfos$isBottom(toIndex, this);\n var infos = ArrayList_init();\n var i = 0;\n for (var tmp$_5 = tileLabels.iterator(); tmp$_5.hasNext(); ++i) {\n var tileLabelTuple = tmp$_5.next();\n var col = toCol(i);\n var row = toRow(i);\n var hasXAxis = isBottom(col, row);\n var hasYAxis = col === 0;\n infos.add_11rb$(new PlotFacets$FacetTileInfo(col, row, tileLabelTuple, null, hasXAxis, hasYAxis, i));\n }\n return sortedWith(infos, new Comparator(thenBy$lambda(new Comparator(compareBy$lambda(FacetWrap$tileInfos$lambda)), FacetWrap$tileInfos$lambda_0)));\n };\n function FacetWrap$Direction(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function FacetWrap$Direction_initFields() {\n FacetWrap$Direction_initFields = function () {\n };\n FacetWrap$Direction$H_instance = new FacetWrap$Direction('H', 0);\n FacetWrap$Direction$V_instance = new FacetWrap$Direction('V', 1);\n }\n var FacetWrap$Direction$H_instance;\n function FacetWrap$Direction$H_getInstance() {\n FacetWrap$Direction_initFields();\n return FacetWrap$Direction$H_instance;\n }\n var FacetWrap$Direction$V_instance;\n function FacetWrap$Direction$V_getInstance() {\n FacetWrap$Direction_initFields();\n return FacetWrap$Direction$V_instance;\n }\n FacetWrap$Direction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Direction',\n interfaces: [Enum]\n };\n function FacetWrap$Direction$values() {\n return [FacetWrap$Direction$H_getInstance(), FacetWrap$Direction$V_getInstance()];\n }\n FacetWrap$Direction.values = FacetWrap$Direction$values;\n function FacetWrap$Direction$valueOf(name) {\n switch (name) {\n case 'H':\n return FacetWrap$Direction$H_getInstance();\n case 'V':\n return FacetWrap$Direction$V_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.assemble.facet.FacetWrap.Direction.' + name);\n }\n }\n FacetWrap$Direction.valueOf_61zpoe$ = FacetWrap$Direction$valueOf;\n function FacetWrap$Companion() {\n FacetWrap$Companion_instance = this;\n }\n FacetWrap$Companion.prototype.numTiles_0 = function (facets, levels) {\n if (!!facets.isEmpty()) {\n var message = 'List of facets is empty.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(distinct(facets).size === facets.size)) {\n var message_0 = 'Duplicated values in the facets list: ' + facets;\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(facets.size === levels.size)) {\n var message_1 = 'Check failed.';\n throw IllegalStateException_init(message_1.toString());\n }return PlotFacets$Companion_getInstance().createNameLevelTuples_5cxrh4$(facets, levels).size;\n };\n function FacetWrap$Companion$shape$lambda(closure$ncol) {\n return function () {\n return \"'ncol' must be positive, was \" + toString(closure$ncol);\n };\n }\n function FacetWrap$Companion$shape$lambda_0(closure$nrow) {\n return function () {\n return \"'nrow' must be positive, was \" + toString(closure$nrow);\n };\n }\n FacetWrap$Companion.prototype.shape_0 = function (tilesCount, ncol, nrow, dir) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!((tmp$ = ncol != null ? ncol > 0 : null) != null ? tmp$ : true)) {\n var message = FacetWrap$Companion$shape$lambda(ncol)();\n throw IllegalArgumentException_init(message.toString());\n }if (!((tmp$_0 = nrow != null ? nrow > 0 : null) != null ? tmp$_0 : true)) {\n var message_0 = FacetWrap$Companion$shape$lambda_0(nrow)();\n throw IllegalArgumentException_init(message_0.toString());\n }if (ncol != null) {\n var ncolActual = JsMath.min(ncol, tilesCount);\n var x = tilesCount / ncolActual;\n var nrowActual = numberToInt(JsMath.ceil(x));\n tmp$_1 = to(ncolActual, JsMath.max(1, nrowActual));\n } else if (nrow != null) {\n var nrowActual_0 = JsMath.min(nrow, tilesCount);\n var x_0 = tilesCount / nrowActual_0;\n var ncolActual_0 = numberToInt(JsMath.ceil(x_0));\n tmp$_1 = to(ncolActual_0, JsMath.max(1, nrowActual_0));\n } else {\n var b = tilesCount / 2 | 0;\n var b_0 = JsMath.max(1, b);\n var w = JsMath.min(4, b_0);\n var x_1 = tilesCount / w;\n var b_1 = numberToInt(JsMath.ceil(x_1));\n var h = JsMath.max(1, b_1);\n tmp$_1 = to(w, h);\n }\n var shape = tmp$_1;\n var w_0 = shape.component1()\n , h_0 = shape.component2();\n switch (dir.name) {\n case 'H':\n var x_2 = tilesCount / w_0;\n tmp$_2 = new Pair_0(w_0, numberToInt(JsMath.ceil(x_2)));\n break;\n case 'V':\n var x_3 = tilesCount / h_0;\n tmp$_2 = new Pair_0(numberToInt(JsMath.ceil(x_3)), h_0);\n break;\n default:tmp$_2 = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$_2;\n };\n FacetWrap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FacetWrap$Companion_instance = null;\n function FacetWrap$Companion_getInstance() {\n if (FacetWrap$Companion_instance === null) {\n new FacetWrap$Companion();\n }return FacetWrap$Companion_instance;\n }\n FacetWrap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetWrap',\n interfaces: [PlotFacets]\n };\n function DefaultSampling() {\n DefaultSampling_instance = this;\n this.SEED_0 = L37;\n this.SAFETY_SAMPLING = Samplings_getInstance().random_280ow0$(200000, this.SEED_0);\n this.POINT = Samplings_getInstance().random_280ow0$(50000, this.SEED_0);\n this.TILE = Samplings_getInstance().random_280ow0$(50000, this.SEED_0);\n this.BIN_2D = this.TILE;\n this.AB_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.H_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.V_LINE = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.JITTER = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.RECT = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.SEGMENT = Samplings_getInstance().random_280ow0$(5000, this.SEED_0);\n this.TEXT = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.ERROR_BAR = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.CROSS_BAR = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.LINE_RANGE = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.POINT_RANGE = Samplings_getInstance().random_280ow0$(500, this.SEED_0);\n this.BAR = Samplings_getInstance().pick_za3lpa$(50);\n this.HISTOGRAM = Samplings_getInstance().systematic_za3lpa$(500);\n this.LINE = Samplings_getInstance().systematic_za3lpa$(5000);\n this.RIBBON = Samplings_getInstance().systematic_za3lpa$(5000);\n this.AREA = Samplings_getInstance().systematic_za3lpa$(5000);\n this.DENSITY = Samplings_getInstance().systematic_za3lpa$(5000);\n this.FREQPOLY = Samplings_getInstance().systematic_za3lpa$(5000);\n this.STEP = Samplings_getInstance().systematic_za3lpa$(5000);\n this.PATH = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.POLYGON = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.MAP = Samplings_getInstance().vertexDp_za3lpa$(20000);\n this.SMOOTH = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.CONTOUR = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.CONTOURF = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.DENSITY2D = Samplings_getInstance().systematicGroup_za3lpa$(200);\n this.DENSITY2DF = Samplings_getInstance().systematicGroup_za3lpa$(200);\n }\n DefaultSampling.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultSampling',\n interfaces: []\n };\n var DefaultSampling_instance = null;\n function DefaultSampling_getInstance() {\n if (DefaultSampling_instance === null) {\n new DefaultSampling();\n }return DefaultSampling_instance;\n }\n function GeomProvider(geomKind) {\n GeomProvider$Companion_getInstance();\n this.geomKind = geomKind;\n }\n Object.defineProperty(GeomProvider.prototype, 'preferredCoordinateSystem', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('No preferred coordinate system');\n }\n });\n GeomProvider.prototype.renders = function () {\n return base_0.GeomMeta.renders_7dhqpi$(this.geomKind);\n };\n function GeomProvider$GeomProviderBuilder(myKind, myAestheticsDefaults, myHandlesGroups, myGeomSupplier) {\n this.myKind_0 = myKind;\n this.myAestheticsDefaults_0 = myAestheticsDefaults;\n this.myHandlesGroups_0 = myHandlesGroups;\n this.myGeomSupplier_0 = myGeomSupplier;\n }\n function GeomProvider$GeomProviderBuilder$build$ObjectLiteral(this$GeomProviderBuilder, geomKind) {\n this.this$GeomProviderBuilder = this$GeomProviderBuilder;\n GeomProvider.call(this, geomKind);\n }\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.createGeom = function () {\n return this.this$GeomProviderBuilder.myGeomSupplier_0();\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.aestheticsDefaults = function () {\n return this.this$GeomProviderBuilder.myAestheticsDefaults_0;\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.prototype.handlesGroups = function () {\n return this.this$GeomProviderBuilder.myHandlesGroups_0;\n };\n GeomProvider$GeomProviderBuilder$build$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [GeomProvider]\n };\n GeomProvider$GeomProviderBuilder.prototype.build_8be2vx$ = function () {\n return new GeomProvider$GeomProviderBuilder$build$ObjectLiteral(this, this.myKind_0);\n };\n GeomProvider$GeomProviderBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomProviderBuilder',\n interfaces: []\n };\n function GeomProvider$Companion() {\n GeomProvider$Companion_instance = this;\n }\n function GeomProvider$Companion$point$lambda() {\n return new PointGeom();\n }\n GeomProvider$Companion.prototype.point = function () {\n return this.point_8j1y0m$(GeomProvider$Companion$point$lambda);\n };\n GeomProvider$Companion.prototype.point_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POINT, AestheticsDefaults.Companion.point(), PointGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$path$lambda() {\n return new PathGeom();\n }\n GeomProvider$Companion.prototype.path = function () {\n return this.path_8j1y0m$(GeomProvider$Companion$path$lambda);\n };\n GeomProvider$Companion.prototype.path_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.PATH, AestheticsDefaults.Companion.path(), PathGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$line$lambda() {\n return new LineGeom();\n }\n GeomProvider$Companion.prototype.line = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LINE, AestheticsDefaults.Companion.line(), LineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$line$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$smooth$lambda() {\n return new SmoothGeom();\n }\n GeomProvider$Companion.prototype.smooth = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.SMOOTH, AestheticsDefaults.Companion.smooth(), SmoothGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$smooth$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$bar$lambda() {\n return new BarGeom();\n }\n GeomProvider$Companion.prototype.bar = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BAR, AestheticsDefaults.Companion.bar(), BarGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$bar$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$histogram$lambda() {\n return new HistogramGeom();\n }\n GeomProvider$Companion.prototype.histogram = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.HISTOGRAM, AestheticsDefaults.Companion.histogram(), HistogramGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$histogram$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$tile$lambda() {\n return new TileGeom();\n }\n GeomProvider$Companion.prototype.tile = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.TILE, AestheticsDefaults.Companion.tile(), TileGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$tile$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$bin2d$lambda() {\n return new Bin2dGeom();\n }\n GeomProvider$Companion.prototype.bin2d = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BIN_2D, AestheticsDefaults.Companion.bin2d(), Bin2dGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$bin2d$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$errorBar$lambda() {\n return new ErrorBarGeom();\n }\n GeomProvider$Companion.prototype.errorBar = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.ERROR_BAR, AestheticsDefaults.Companion.errorBar(), ErrorBarGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$errorBar$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.crossBar_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CROSS_BAR, AestheticsDefaults.Companion.crossBar(), CrossBarGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$lineRange$lambda() {\n return new LineRangeGeom();\n }\n GeomProvider$Companion.prototype.lineRange = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LINE_RANGE, AestheticsDefaults.Companion.lineRange(), LineRangeGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$lineRange$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.pointRange_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POINT_RANGE, AestheticsDefaults.Companion.pointRange(), PointRangeGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$contour$lambda() {\n return new ContourGeom();\n }\n GeomProvider$Companion.prototype.contour = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CONTOUR, AestheticsDefaults.Companion.contour(), ContourGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$contour$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$contourf$lambda() {\n return new ContourfGeom();\n }\n GeomProvider$Companion.prototype.contourf = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.CONTOURF, AestheticsDefaults.Companion.contourf(), ContourfGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$contourf$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$polygon$lambda() {\n return new PolygonGeom();\n }\n GeomProvider$Companion.prototype.polygon = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.POLYGON, AestheticsDefaults.Companion.polygon(), PolygonGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$polygon$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$map$lambda() {\n return new MapGeom();\n }\n GeomProvider$Companion.prototype.map = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.MAP, AestheticsDefaults.Companion.map(), MapGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$map$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$abline$lambda() {\n return new ABLineGeom();\n }\n GeomProvider$Companion.prototype.abline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.AB_LINE, AestheticsDefaults.Companion.abline(), ABLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$abline$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$hline$lambda() {\n return new HLineGeom();\n }\n GeomProvider$Companion.prototype.hline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.H_LINE, AestheticsDefaults.Companion.hline(), HLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$hline$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$vline$lambda() {\n return new VLineGeom();\n }\n GeomProvider$Companion.prototype.vline = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.V_LINE, AestheticsDefaults.Companion.vline(), VLineGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$vline$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.boxplot_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.BOX_PLOT, AestheticsDefaults.Companion.boxplot(), BoxplotGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$livemap$lambda(closure$options) {\n return function () {\n return new LiveMapGeom(closure$options.displayMode);\n };\n }\n GeomProvider$Companion.prototype.livemap_d2y5pu$ = function (options) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.LIVE_MAP, AestheticsDefaults.Companion.livemap_cx3y7u$(options.displayMode), LiveMapGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$livemap$lambda(options))).build_8be2vx$();\n };\n function GeomProvider$Companion$ribbon$lambda() {\n return new RibbonGeom();\n }\n GeomProvider$Companion.prototype.ribbon = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RIBBON, AestheticsDefaults.Companion.ribbon(), RibbonGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$ribbon$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$area$lambda() {\n return new AreaGeom();\n }\n GeomProvider$Companion.prototype.area = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.AREA, AestheticsDefaults.Companion.area(), AreaGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$area$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density$lambda() {\n return new DensityGeom();\n }\n GeomProvider$Companion.prototype.density = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY, AestheticsDefaults.Companion.density(), DensityGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density2d$lambda() {\n return new Density2dGeom();\n }\n GeomProvider$Companion.prototype.density2d = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY2D, AestheticsDefaults.Companion.density2d(), Density2dGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density2d$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$density2df$lambda() {\n return new Density2dfGeom();\n }\n GeomProvider$Companion.prototype.density2df = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.DENSITY2DF, AestheticsDefaults.Companion.density2df(), Density2dfGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$density2df$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$jitter$lambda() {\n return new JitterGeom();\n }\n GeomProvider$Companion.prototype.jitter = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.JITTER, AestheticsDefaults.Companion.jitter(), JitterGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$jitter$lambda)).build_8be2vx$();\n };\n function GeomProvider$Companion$freqpoly$lambda() {\n return new FreqpolyGeom();\n }\n GeomProvider$Companion.prototype.freqpoly = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.FREQPOLY, AestheticsDefaults.Companion.freqpoly(), FreqpolyGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$freqpoly$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.step_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.STEP, AestheticsDefaults.Companion.step(), StepGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$rect$lambda() {\n return new RectGeom();\n }\n GeomProvider$Companion.prototype.rect = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RECT, AestheticsDefaults.Companion.rect(), RectGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$rect$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.segment_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.SEGMENT, AestheticsDefaults.Companion.segment(), SegmentGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.text_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.TEXT, AestheticsDefaults.Companion.text(), TextGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n function GeomProvider$Companion$raster$lambda() {\n return new RasterGeom();\n }\n GeomProvider$Companion.prototype.raster = function () {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.RASTER, AestheticsDefaults.Companion.raster(), RasterGeom.Companion.HANDLES_GROUPS, GeomProvider$Companion$raster$lambda)).build_8be2vx$();\n };\n GeomProvider$Companion.prototype.image_8j1y0m$ = function (supplier) {\n return (new GeomProvider$GeomProviderBuilder(GeomKind.IMAGE, AestheticsDefaults.Companion.image(), ImageGeom.Companion.HANDLES_GROUPS, supplier)).build_8be2vx$();\n };\n GeomProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomProvider$Companion_instance = null;\n function GeomProvider$Companion_getInstance() {\n if (GeomProvider$Companion_instance === null) {\n new GeomProvider$Companion();\n }return GeomProvider$Companion_instance;\n }\n GeomProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomProvider',\n interfaces: []\n };\n function PointDataAccess(data, bindings, scaleMap) {\n this.data_0 = data;\n this.mappedAes_tolgcu$_0 = HashSet_init(bindings.keys);\n this.scaleByAes_c9kkhw$_0 = PointDataAccess$scaleByAes$lambda(scaleMap);\n this.myBindings_0 = toMap_0(bindings);\n this.myFormatters_0 = HashMap_init();\n }\n Object.defineProperty(PointDataAccess.prototype, 'mappedAes', {\n configurable: true,\n get: function () {\n return this.mappedAes_tolgcu$_0;\n }\n });\n Object.defineProperty(PointDataAccess.prototype, 'scaleByAes', {\n configurable: true,\n get: function () {\n return this.scaleByAes_c9kkhw$_0;\n }\n });\n PointDataAccess.prototype.isMapped_896ixz$ = function (aes) {\n return this.myBindings_0.containsKey_11rb$(aes);\n };\n PointDataAccess.prototype.getMappedData_pkitv1$ = function (aes, index) {\n var originalValue = this.getOriginalValue_pkitv1$(aes, index);\n var scale = this.getScale_0(aes);\n var value = this.formatter_0(aes)(originalValue);\n return new MappedDataAccess$MappedData(scale.name, value, scale.isContinuous);\n };\n PointDataAccess.prototype.getOriginalValue_pkitv1$ = function (aes, index) {\n if (!this.isMapped_896ixz$(aes)) {\n var message = 'Not mapped: ' + aes;\n throw IllegalArgumentException_init(message.toString());\n }var binding = getValue(this.myBindings_0, aes);\n var scale = this.getScale_0(aes);\n var value = this.data_0.getNumeric_8xm3sj$(binding.variable).get_za3lpa$(index);\n return scale.transform.applyInverse_yrwdxb$(value);\n };\n PointDataAccess.prototype.getMappedDataLabel_896ixz$ = function (aes) {\n return this.getScale_0(aes).name;\n };\n PointDataAccess.prototype.isMappedDataContinuous_896ixz$ = function (aes) {\n return this.getScale_0(aes).isContinuous;\n };\n PointDataAccess.prototype.getScale_0 = function (aes) {\n return this.scaleByAes(aes);\n };\n PointDataAccess.prototype.formatter_0 = function (aes) {\n var scale = this.getScale_0(aes);\n var $receiver = this.myFormatters_0;\n var tmp$;\n var value = $receiver.get_11rb$(aes);\n if (value == null) {\n var answer = this.createFormatter_0(aes, scale);\n $receiver.put_xwzc9p$(aes, answer);\n tmp$ = answer;\n } else {\n tmp$ = value;\n }\n return tmp$;\n };\n function PointDataAccess$createFormatter$lambda(closure$formatter) {\n return function (value) {\n var tmp$;\n var tmp$_0;\n tmp$_0 = value != null ? closure$formatter(value) : null;\n return (tmp$ = tmp$_0) != null ? tmp$ : 'n/a';\n };\n }\n function PointDataAccess$createFormatter$lambda_0(closure$labelsMap) {\n return function (value) {\n var tmp$;\n var tmp$_0;\n tmp$_0 = value != null ? getValue(closure$labelsMap, value) : null;\n return (tmp$ = tmp$_0) != null ? tmp$ : 'n/a';\n };\n }\n PointDataAccess.prototype.createFormatter_0 = function (aes, scale_0) {\n if (scale_0.isContinuousDomain) {\n var $receiver = getValue(this.myBindings_0, aes).variable;\n var $receiver_0 = getCallableRef('range', function ($receiver, p1) {\n return $receiver.range_8xm3sj$(p1);\n }.bind(null, this.data_0))($receiver);\n var domain = data_0.SeriesUtil.ensureApplicableRange_4am1sd$($receiver_0);\n var formatter = scale_0.getBreaksGenerator().labelFormatter_1tlvto$(domain, 100);\n return PointDataAccess$createFormatter$lambda(formatter);\n } else {\n var labelsMap = scale.ScaleUtil.labelByBreak_x4zrm4$(scale_0);\n return PointDataAccess$createFormatter$lambda_0(labelsMap);\n }\n };\n function PointDataAccess$scaleByAes$lambda(closure$scaleMap) {\n return function (it) {\n return closure$scaleMap.get_31786j$(it);\n };\n }\n PointDataAccess.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointDataAccess',\n interfaces: [MappedDataAccess]\n };\n function CartesianCoordProvider(xLim, yLim) {\n CoordProviderBase.call(this, xLim, yLim);\n }\n CartesianCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CartesianCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function CoordProvider() {\n }\n CoordProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'CoordProvider',\n interfaces: []\n };\n function CoordProviderBase(xLim, yLim) {\n CoordProviderBase$Companion_getInstance();\n this.xLim_0 = xLim;\n this.yLim_0 = yLim;\n }\n CoordProviderBase.prototype.buildAxisScaleX_ny58zc$ = function (scaleProto, domain, axisLength, breaks) {\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_0(scaleProto, domain, axisLength, breaks);\n };\n CoordProviderBase.prototype.buildAxisScaleY_ny58zc$ = function (scaleProto, domain, axisLength, breaks) {\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_0(scaleProto, domain, axisLength, breaks);\n };\n CoordProviderBase.prototype.createCoordinateSystem_uncllg$ = function (xDomain, xAxisLength, yDomain, yAxisLength) {\n var tmp$, tmp$_0;\n var mapperX = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(xDomain, xAxisLength);\n var mapperY = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(yDomain, yAxisLength);\n return coord.Coords.create_wd6eaa$(scale.MapperUtil.map_rejkqi$(xDomain, mapperX), scale.MapperUtil.map_rejkqi$(yDomain, mapperY), (tmp$ = this.xLim_0) != null ? scale.MapperUtil.map_rejkqi$(tmp$, mapperX) : null, (tmp$_0 = this.yLim_0) != null ? scale.MapperUtil.map_rejkqi$(tmp$_0, mapperY) : null);\n };\n CoordProviderBase.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var tmp$, tmp$_0;\n return new Pair((tmp$ = this.xLim_0) != null ? tmp$ : xDomain, (tmp$_0 = this.yLim_0) != null ? tmp$_0 : yDomain);\n };\n function CoordProviderBase$Companion() {\n CoordProviderBase$Companion_instance = this;\n }\n CoordProviderBase$Companion.prototype.linearMapper_mdyssk$ = function (domain, axisLength) {\n return scale.Mappers.mul_mdyssk$(domain, axisLength);\n };\n CoordProviderBase$Companion.prototype.buildAxisScaleDefault_0 = function (scaleProto, domain, axisLength, breaks) {\n return this.buildAxisScaleDefault_82iy2c$(scaleProto, this.linearMapper_mdyssk$(domain, axisLength), breaks);\n };\n CoordProviderBase$Companion.prototype.buildAxisScaleDefault_82iy2c$ = function (scaleProto, axisMapper, breaks) {\n return scaleProto.with().breaks_pqjuzw$(breaks.domainValues).labels_mhpeer$(breaks.labels).mapper_1uitho$(axisMapper).build();\n };\n CoordProviderBase$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var CoordProviderBase$Companion_instance = null;\n function CoordProviderBase$Companion_getInstance() {\n if (CoordProviderBase$Companion_instance === null) {\n new CoordProviderBase$Companion();\n }return CoordProviderBase$Companion_instance;\n }\n CoordProviderBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CoordProviderBase',\n interfaces: [CoordProvider]\n };\n function CoordProviders() {\n CoordProviders_instance = this;\n }\n CoordProviders.prototype.cartesian_t7esj2$ = function (xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new CartesianCoordProvider(xLim, yLim);\n };\n CoordProviders.prototype.fixed_vvp5j4$ = function (ratio, xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new FixedRatioCoordProvider(ratio, xLim, yLim);\n };\n CoordProviders.prototype.map_t7esj2$ = function (xLim, yLim) {\n if (xLim === void 0)\n xLim = null;\n if (yLim === void 0)\n yLim = null;\n return new ProjectionCoordProvider(new MercatorProjectionX(), new MercatorProjectionY(), xLim, yLim);\n };\n CoordProviders.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'CoordProviders',\n interfaces: []\n };\n var CoordProviders_instance = null;\n function CoordProviders_getInstance() {\n if (CoordProviders_instance === null) {\n new CoordProviders();\n }return CoordProviders_instance;\n }\n function FixedRatioCoordProvider(ratio, xLim, yLim) {\n CoordProviderBase.call(this, xLim, yLim);\n this.ratio_0 = ratio;\n }\n FixedRatioCoordProvider.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var adjusted = CoordProviderBase.prototype.adjustDomains_jz8wgn$.call(this, xDomain, yDomain, displaySize);\n var xDomain_0 = adjusted.first;\n var yDomain_0 = adjusted.second;\n var spanX = data_0.SeriesUtil.span_4fzjta$(xDomain_0);\n var spanY = data_0.SeriesUtil.span_4fzjta$(yDomain_0);\n if (spanX < data_0.SeriesUtil.TINY || spanY < data_0.SeriesUtil.TINY) {\n return new Pair(xDomain_0, yDomain_0);\n }var displayW = displaySize.x;\n var displayH = displaySize.y;\n if (this.ratio_0 > 1) {\n displayW *= this.ratio_0;\n } else {\n displayH *= 1 / this.ratio_0;\n }\n var ratioX = spanX / displayW;\n var ratioY = spanY / displayH;\n if (ratioX > ratioY) {\n var spanAdjusted = displayH * ratioX;\n yDomain_0 = data_0.SeriesUtil.expand_mdyssk$(yDomain_0, spanAdjusted);\n } else {\n var spanAdjusted_0 = displayW * ratioY;\n xDomain_0 = data_0.SeriesUtil.expand_mdyssk$(xDomain_0, spanAdjusted_0);\n }\n return new Pair(xDomain_0, yDomain_0);\n };\n FixedRatioCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FixedRatioCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function ProjectionCoordProvider(projectionX, projectionY, xLim, yLim) {\n ProjectionCoordProvider$Companion_getInstance();\n CoordProviderBase.call(this, xLim, yLim);\n this.projectionX_0 = projectionX;\n this.projectionY_0 = projectionY;\n }\n ProjectionCoordProvider.prototype.adjustDomains_jz8wgn$ = function (xDomain, yDomain, displaySize) {\n var tmp$;\n var adjusted = CoordProviderBase.prototype.adjustDomains_jz8wgn$.call(this, xDomain, yDomain, displaySize);\n var xDomain_0 = this.projectionX_0.toValidDomain_4fzjta$(adjusted.first);\n var yDomain_0 = this.projectionY_0.toValidDomain_4fzjta$(adjusted.second);\n var spanX = data_0.SeriesUtil.span_4fzjta$(xDomain_0);\n var spanY = data_0.SeriesUtil.span_4fzjta$(yDomain_0);\n if (spanX > spanY) {\n var center = xDomain_0.lowerEnd + spanX / 2;\n var halfSpan = spanY / 2;\n tmp$ = new Pair(new ClosedRange(center - halfSpan, center + halfSpan), yDomain_0);\n } else {\n var center_0 = yDomain_0.lowerEnd + spanY / 2;\n var halfSpan_0 = spanX / 2;\n tmp$ = new Pair(xDomain_0, new ClosedRange(center_0 - halfSpan_0, center_0 + halfSpan_0));\n }\n var domainSquare = tmp$;\n var projectedXMin = this.projectionX_0.apply_14dthe$(domainSquare.first.lowerEnd);\n var projectedXMax = this.projectionX_0.apply_14dthe$(domainSquare.first.upperEnd);\n var projectedYMin = this.projectionY_0.apply_14dthe$(domainSquare.second.lowerEnd);\n var projectedYMax = this.projectionY_0.apply_14dthe$(domainSquare.second.upperEnd);\n var ratio = (projectedYMax - projectedYMin) / (projectedXMax - projectedXMin);\n var fixedCoord = new FixedRatioCoordProvider(ratio, null, null);\n return fixedCoord.adjustDomains_jz8wgn$(xDomain_0, yDomain_0, displaySize);\n };\n ProjectionCoordProvider.prototype.buildAxisScaleX_ny58zc$ = function (scaleProto, domain, axisLength, breaks) {\n var tmp$;\n if (this.projectionX_0.nonlinear) {\n tmp$ = ProjectionCoordProvider$Companion_getInstance().buildAxisScaleWithProjection_0(this.projectionX_0, scaleProto, domain, axisLength, breaks);\n } else {\n tmp$ = CoordProviderBase.prototype.buildAxisScaleX_ny58zc$.call(this, scaleProto, domain, axisLength, breaks);\n }\n return tmp$;\n };\n ProjectionCoordProvider.prototype.buildAxisScaleY_ny58zc$ = function (scaleProto, domain, axisLength, breaks) {\n var tmp$;\n if (this.projectionY_0.nonlinear) {\n tmp$ = ProjectionCoordProvider$Companion_getInstance().buildAxisScaleWithProjection_0(this.projectionY_0, scaleProto, domain, axisLength, breaks);\n } else {\n tmp$ = CoordProviderBase.prototype.buildAxisScaleY_ny58zc$.call(this, scaleProto, domain, axisLength, breaks);\n }\n return tmp$;\n };\n function ProjectionCoordProvider$Companion() {\n ProjectionCoordProvider$Companion_instance = this;\n }\n ProjectionCoordProvider$Companion.prototype.buildAxisScaleWithProjection_0 = function (projection, scaleProto, domain, axisLength, breaks) {\n var validDomain = projection.toValidDomain_4fzjta$(domain);\n var validDomainProjected = new ClosedRange(projection.apply_14dthe$(validDomain.lowerEnd), projection.apply_14dthe$(validDomain.upperEnd));\n var projectionInverse = scale.Mappers.linear_1jkouz$(validDomainProjected, validDomain);\n var linearMapper = CoordProviderBase$Companion_getInstance().linearMapper_mdyssk$(domain, axisLength);\n var scaleMapper = this.twistScaleMapper_0(projection, projectionInverse, linearMapper);\n var validBreaks = this.validateBreaks_0(validDomain, breaks);\n return CoordProviderBase$Companion_getInstance().buildAxisScaleDefault_82iy2c$(scaleProto, scaleMapper, validBreaks);\n };\n ProjectionCoordProvider$Companion.prototype.validateBreaks_0 = function (validDomain, breaks) {\n var tmp$;\n var validIndices = ArrayList_init();\n var i = 0;\n tmp$ = breaks.domainValues.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (typeof v === 'number' && validDomain.contains_mef7kx$(v)) {\n validIndices.add_11rb$(i);\n }i = i + 1 | 0;\n }\n if (validIndices.size === breaks.domainValues.size) {\n return breaks;\n }var validDomainValues = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.domainValues, validIndices);\n var validLabels = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.labels, validIndices);\n var validTransformedValues = data_0.SeriesUtil.pickAtIndices_ge51dg$(breaks.transformedValues, validIndices);\n return new ScaleBreaks(validDomainValues, validTransformedValues, validLabels);\n };\n function ProjectionCoordProvider$Companion$twistScaleMapper$lambda(closure$projection, closure$projectionInverse, closure$scaleMapper) {\n return function (v) {\n var tmp$;\n if (v != null) {\n var closure$projection_0 = closure$projection;\n var closure$projectionInverse_0 = closure$projectionInverse;\n var closure$scaleMapper_0 = closure$scaleMapper;\n var projected = closure$projection_0.apply_14dthe$(v);\n var unProjected = closure$projectionInverse_0(projected);\n tmp$ = closure$scaleMapper_0(unProjected);\n } else\n tmp$ = null;\n return tmp$;\n };\n }\n ProjectionCoordProvider$Companion.prototype.twistScaleMapper_0 = function (projection, projectionInverse, scaleMapper) {\n return ProjectionCoordProvider$Companion$twistScaleMapper$lambda(projection, projectionInverse, scaleMapper);\n };\n ProjectionCoordProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ProjectionCoordProvider$Companion_instance = null;\n function ProjectionCoordProvider$Companion_getInstance() {\n if (ProjectionCoordProvider$Companion_instance === null) {\n new ProjectionCoordProvider$Companion();\n }return ProjectionCoordProvider$Companion_instance;\n }\n ProjectionCoordProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ProjectionCoordProvider',\n interfaces: [CoordProviderBase]\n };\n function MercatorProjectionX() {\n this.nonlinear_z5go4f$_0 = false;\n }\n Object.defineProperty(MercatorProjectionX.prototype, 'nonlinear', {\n configurable: true,\n get: function () {\n return this.nonlinear_z5go4f$_0;\n }\n });\n MercatorProjectionX.prototype.apply_14dthe$ = function (v) {\n return spatial.MercatorUtils.getMercatorX_14dthe$(v);\n };\n MercatorProjectionX.prototype.toValidDomain_4fzjta$ = function (domain) {\n return domain;\n };\n MercatorProjectionX.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MercatorProjectionX',\n interfaces: [Projection]\n };\n function MercatorProjectionY() {\n this.nonlinear_x0lz9c$_0 = true;\n }\n Object.defineProperty(MercatorProjectionY.prototype, 'nonlinear', {\n configurable: true,\n get: function () {\n return this.nonlinear_x0lz9c$_0;\n }\n });\n MercatorProjectionY.prototype.apply_14dthe$ = function (v) {\n return spatial.MercatorUtils.getMercatorY_14dthe$(v);\n };\n MercatorProjectionY.prototype.toValidDomain_4fzjta$ = function (domain) {\n if (spatial.MercatorUtils.VALID_LATITUDE_RANGE.isConnected_d226ot$(domain)) {\n return spatial.MercatorUtils.VALID_LATITUDE_RANGE.intersection_d226ot$(domain);\n }throw IllegalArgumentException_init('Illegal latitude range for mercator projection: ' + domain);\n };\n MercatorProjectionY.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MercatorProjectionY',\n interfaces: [Projection]\n };\n function DataProcessing() {\n DataProcessing_instance = this;\n }\n DataProcessing.prototype.transformOriginals_si9pes$ = function (data_0, bindings, scaleMap) {\n var tmp$;\n var data_1 = data_0;\n tmp$ = bindings.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (variable.isOrigin) {\n if (!data_1.has_8xm3sj$(variable)) {\n var message = 'Undefined variable ' + variable;\n throw IllegalStateException_init(message.toString());\n }data_1 = data.DataFrameUtil.applyTransform_xaiv89$(data_1, variable, binding.aes, scaleMap.get_31786j$(binding.aes));\n }}\n return data_1;\n };\n DataProcessing.prototype.buildStatData_x40e2x$ = function (data, stat_0, bindings, scaleMap, groupingContext, facets, statCtx, varsWithoutBinding, orderOptions, aggregateOperation, messageConsumer) {\n var tmp$, tmp$_0;\n if (stat_0 === stat.Stats.IDENTITY) {\n return new DataProcessing$DataAndGroupingContext(DataFrame$Builder.Companion.emptyFrame(), groupingContext);\n }var groups = groupingContext.groupMapper;\n var resultSeries;\n var groupSizeListAfterStat;\n if (groups === GroupUtil_getInstance().SINGLE_GROUP_8be2vx$) {\n var sd = this.applyStat_0(data, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer);\n groupSizeListAfterStat = listOf(sd.rowCount());\n var $receiver = sd.variables();\n var result = LinkedHashMap_init_0(coerceAtLeast(mapCapacity(collectionSizeOrDefault($receiver, 10)), 16));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n result.put_xwzc9p$(element, sd.get_8xm3sj$(element));\n }\n resultSeries = result;\n } else {\n var groupMerger = new GroupMerger();\n var lastStatGroupEnd = -1;\n tmp$ = this.splitByGroup_0(data, groups).iterator();\n while (tmp$.hasNext()) {\n var d = tmp$.next();\n var sd_0 = this.applyStat_0(d, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer);\n if (sd_0.isEmpty) {\n continue;\n }groupMerger.initOrderSpecs_37be8y$(orderOptions, sd_0.variables(), bindings, aggregateOperation);\n var curGroupSizeAfterStat = sd_0.rowCount();\n if (sd_0.has_8xm3sj$(stat.Stats.GROUP)) {\n var range = sd_0.range_8xm3sj$(stat.Stats.GROUP);\n if (range != null) {\n var start = lastStatGroupEnd + 1 | 0;\n var offset = start - numberToInt(range.lowerEnd) | 0;\n lastStatGroupEnd = numberToInt(range.upperEnd) + offset | 0;\n if (offset !== 0) {\n var newG = ArrayList_init();\n tmp$_0 = sd_0.getNumeric_8xm3sj$(stat.Stats.GROUP).iterator();\n while (tmp$_0.hasNext()) {\n var g = tmp$_0.next();\n newG.add_11rb$(ensureNotNull(g) + offset);\n }\n sd_0 = sd_0.builder().putNumeric_s1rqo9$(stat.Stats.GROUP, newG).build();\n }}} else {\n var groupingVar = groupingContext.optionalGroupingVar_8be2vx$;\n if (groupingVar != null) {\n var size = sd_0.get_8xm3sj$(first_0(sd_0.variables())).size;\n var v = d.get_8xm3sj$(groupingVar).get_za3lpa$(0);\n var tmp$_2 = sd_0.builder();\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(v);\n }\n sd_0 = tmp$_2.put_2l962d$(groupingVar, list).build();\n }}\n groupMerger.addGroup_s4jycv$(sd_0, curGroupSizeAfterStat);\n }\n resultSeries = groupMerger.getResultSeries();\n groupSizeListAfterStat = groupMerger.getGroupSizes();\n }\n var closure$resultSeries = resultSeries;\n var $receiver_0 = DataFrame$DataFrame$Builder_init();\n var tmp$_3;\n tmp$_3 = closure$resultSeries.keys.iterator();\n while (tmp$_3.hasNext()) {\n var variable = tmp$_3.next();\n $receiver_0.put_2l962d$(variable, ensureNotNull(closure$resultSeries.get_11rb$(variable)));\n }\n var destination = ArrayList_init_0(collectionSizeOrDefault(orderOptions, 10));\n var tmp$_4;\n tmp$_4 = orderOptions.iterator();\n while (tmp$_4.hasNext()) {\n var item = tmp$_4.next();\n destination.add_11rb$(OrderOptionUtil_getInstance().createOrderSpec_e64h97$(closure$resultSeries.keys, bindings, item, aggregateOperation));\n }\n var orderSpecs = destination;\n $receiver_0.addOrderSpecs_l2t0xf$(orderSpecs);\n var dataAfterStat = $receiver_0.build();\n var groupingContextAfterStat = GroupingContext$Companion_getInstance().withOrderedGroups_vi90cb$(dataAfterStat, groupSizeListAfterStat);\n return new DataProcessing$DataAndGroupingContext(dataAfterStat, groupingContextAfterStat);\n };\n DataProcessing.prototype.findOptionalVariable_hrxl0z$ = function (data_0, name) {\n return base.Strings.isNullOrEmpty_pdl1vj$(name) ? null : data.DataFrameUtil.findVariableOrFail_vede35$(data_0, ensureNotNull(name));\n };\n DataProcessing.prototype.splitByGroup_0 = function (data, groups) {\n var $receiver = GroupUtil_getInstance().indicesByGroup_wc9gac$(data.rowCount(), groups).values;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var $receiver_0 = data.variables();\n var tmp$_1;\n var accumulator = DataFrame$DataFrame$Builder_init();\n tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n var b = accumulator;\n var operation$result;\n var tmp$_2;\n tmp$_2 = data.isNumeric_8xm3sj$(element);\n if (tmp$_2 === true) {\n operation$result = b.putNumeric_s1rqo9$(element, data_0.SeriesUtil.pickAtIndices_ge51dg$(data.getNumeric_8xm3sj$(element), item));\n } else if (tmp$_2 === false) {\n operation$result = b.putDiscrete_2l962d$(element, data_0.SeriesUtil.pickAtIndices_ge51dg$(data.get_8xm3sj$(element), item));\n } else {\n operation$result = Kotlin.noWhenBranchMatched();\n }\n accumulator = operation$result;\n }\n tmp$_0.call(destination, accumulator);\n }\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_3;\n tmp$_3 = destination.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_0.add_11rb$(item_0.build());\n }\n return destination_0;\n };\n function DataProcessing$applyStat$addSeriesForVariable(closure$data, closure$statDataSize, closure$newInputSeries) {\n return function (variable) {\n var tmp$, tmp$_0;\n tmp$ = closure$data.isNumeric_8xm3sj$(variable);\n if (tmp$ === true)\n tmp$_0 = data_0.SeriesUtil.mean_l4tjj7$(closure$data.getNumeric_8xm3sj$(variable), null);\n else if (tmp$ === false)\n tmp$_0 = data_0.SeriesUtil.firstNotNull_rath1t$(closure$data.get_8xm3sj$(variable), null);\n else\n tmp$_0 = Kotlin.noWhenBranchMatched();\n var value = tmp$_0;\n var size = closure$statDataSize;\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(value);\n }\n var newInputSerie = list;\n closure$newInputSeries.put_xwzc9p$(variable, newInputSerie);\n };\n }\n DataProcessing.prototype.applyStat_0 = function (data_0, stat_0, bindings, scaleMap, facets, statCtx, varsWithoutBinding, compMessageConsumer) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3, tmp$_4;\n var statData = stat_0.apply_kdy6bf$(data_0, statCtx, compMessageConsumer);\n var statVariables = statData.variables();\n if (statVariables.isEmpty()) {\n return statData;\n }var inverseTransformedStatSeries = this.inverseTransformContinuousStatData_0(statData, stat_0, bindings, scaleMap);\n var statDataSize = statData.get_8xm3sj$(statVariables.iterator().next()).size;\n var facetVars = HashSet_init_0();\n tmp$ = facets.variables.iterator();\n while (tmp$.hasNext()) {\n var facetVarName = tmp$.next();\n var facetVar = data.DataFrameUtil.findVariableOrFail_vede35$(data_0, facetVarName);\n facetVars.add_11rb$(facetVar);\n if (!data_0.get_8xm3sj$(facetVar).isEmpty()) {\n var facetLevel = data_0.get_8xm3sj$(facetVar).get_za3lpa$(0);\n var tmp$_5 = statData.builder();\n var list = ArrayList_init_0(statDataSize);\n for (var index = 0; index < statDataSize; index++) {\n list.add_11rb$(facetLevel);\n }\n statData = tmp$_5.put_2l962d$(facetVar, list).build();\n }}\n if (bindings.isEmpty()) {\n return statData;\n }var newInputSeries = HashMap_init();\n var addSeriesForVariable = DataProcessing$applyStat$addSeriesForVariable(data_0, statDataSize, newInputSeries);\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var binding = tmp$_0.next();\n var variable = binding.variable;\n if (variable.isStat || facetVars.contains_11rb$(variable)) {\n continue;\n }var aes = binding.aes;\n if (stat_0.hasDefaultMapping_896ixz$(aes)) {\n var defaultStatVar = stat_0.getDefaultMapping_896ixz$(aes);\n if (inverseTransformedStatSeries.containsKey_11rb$(defaultStatVar)) {\n tmp$_1 = getValue(inverseTransformedStatSeries, defaultStatVar);\n } else {\n var statSerie = statData.getNumeric_8xm3sj$(defaultStatVar);\n tmp$_1 = scale.ScaleUtil.inverseTransform_codrxm$(statSerie, scaleMap.get_31786j$(aes));\n }\n var newInputSerie = tmp$_1;\n newInputSeries.put_xwzc9p$(variable, newInputSerie);\n } else {\n if (!newInputSeries.containsKey_11rb$(variable)) {\n addSeriesForVariable(variable);\n }}\n }\n var predicate = getCallableRef('isStatVar', function ($receiver, p1) {\n return $receiver.isStatVar_61zpoe$(p1);\n }.bind(null, stat.Stats));\n var destination = ArrayList_init();\n var tmp$_6;\n tmp$_6 = varsWithoutBinding.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (!predicate(element))\n destination.add_11rb$(element);\n }\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var varName = tmp$_2.next();\n var variable_0 = data.DataFrameUtil.findVariableOrFail_vede35$(data_0, varName);\n if (!newInputSeries.containsKey_11rb$(variable_0)) {\n addSeriesForVariable(variable_0);\n }}\n var b = statData.builder();\n tmp$_3 = newInputSeries.keys.iterator();\n while (tmp$_3.hasNext()) {\n var variable_1 = tmp$_3.next();\n b.put_2l962d$(variable_1, getValue(newInputSeries, variable_1));\n }\n tmp$_4 = inverseTransformedStatSeries.keys.iterator();\n while (tmp$_4.hasNext()) {\n var variable_2 = tmp$_4.next();\n b.putNumeric_s1rqo9$(variable_2, getValue(inverseTransformedStatSeries, variable_2));\n }\n return b.build();\n };\n DataProcessing.prototype.inverseTransformContinuousStatData_0 = function (statData, stat, bindings, scaleMap) {\n var tmp$, tmp$_0, tmp$_1;\n var continuousScaleByAes = HashMap_init();\n var aesByMappedStatVar = HashMap_init();\n tmp$ = Aes.Companion.values().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n if (stat.hasDefaultMapping_896ixz$(aes)) {\n var defaultStatVar = stat.getDefaultMapping_896ixz$(aes);\n aesByMappedStatVar.put_xwzc9p$(defaultStatVar, aes);\n }}\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var binding = tmp$_0.next();\n var aes_0 = binding.aes;\n var variable = binding.variable;\n if (variable.isStat) {\n aesByMappedStatVar.put_xwzc9p$(variable, aes_0);\n continue;\n }var scale_0 = scaleMap.get_31786j$(aes_0);\n if (scale_0.isContinuousDomain) {\n continuousScaleByAes.put_xwzc9p$(aes_0, scale_0);\n if (Aes.Companion.isPositionalX_896ixz$(aes_0) && !continuousScaleByAes.containsKey_11rb$(Aes.Companion.X)) {\n var key = Aes.Companion.X;\n continuousScaleByAes.put_xwzc9p$(key, scale_0);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes_0) && !continuousScaleByAes.containsKey_11rb$(Aes.Companion.Y)) {\n var key_0 = Aes.Companion.Y;\n continuousScaleByAes.put_xwzc9p$(key_0, scale_0);\n }}}\n var inverseTransformedStatSeries = HashMap_init();\n tmp$_1 = statData.variables().iterator();\n while (tmp$_1.hasNext()) {\n var statVar = tmp$_1.next();\n if (aesByMappedStatVar.containsKey_11rb$(statVar)) {\n var aes_1 = getValue(aesByMappedStatVar, statVar);\n var scale_1 = continuousScaleByAes.get_11rb$(aes_1);\n if (scale_1 == null) {\n if (Aes.Companion.isPositionalX_896ixz$(aes_1)) {\n scale_1 = continuousScaleByAes.get_11rb$(Aes.Companion.X);\n } else if (Aes.Companion.isPositionalY_896ixz$(aes_1)) {\n scale_1 = continuousScaleByAes.get_11rb$(Aes.Companion.Y);\n }}if (scale_1 != null) {\n var statSerie = statData.getNumeric_8xm3sj$(statVar);\n var inverseTransformedStatSerie = scale.ScaleUtil.inverseTransformToContinuousDomain_codrxm$(statSerie, scale_1);\n inverseTransformedStatSeries.put_xwzc9p$(statVar, inverseTransformedStatSerie);\n }}}\n return inverseTransformedStatSeries;\n };\n DataProcessing.prototype.computeGroups_hut2k5$ = function (data, bindings, groupingVar, pathIdVar) {\n var tmp$, tmp$_0;\n var groupingVariables = plus_0(this.getGroupingVariables_0(data, bindings, groupingVar), listOfNotNull_0(pathIdVar));\n var currentGroups = {v: null};\n if (groupingVar != null) {\n currentGroups.v = this.computeGroups_0(data.get_8xm3sj$(groupingVar));\n }tmp$ = groupingVariables.iterator();\n while (tmp$.hasNext()) {\n var groupingVariable = tmp$.next();\n var values = data.get_8xm3sj$(groupingVariable);\n var groups = this.computeGroups_0(values);\n if (currentGroups.v == null) {\n currentGroups.v = groups;\n continue;\n }if (!(currentGroups.v.size === groups.size)) {\n var tmp$_1;\n var message = 'Data series used to compute groups must be equal in size (encountered sizes: ' + (toString((tmp$_1 = currentGroups.v) != null ? tmp$_1.size : null) + ', ' + groups.size + ' )');\n throw IllegalStateException_init(message.toString());\n }var dummies = this.computeDummyValues_0(currentGroups.v, groups);\n currentGroups.v = this.computeGroups_0(dummies);\n }\n if (currentGroups.v != null) {\n tmp$_0 = GroupUtil_getInstance().wrap_2wzaym$(currentGroups.v);\n } else {\n tmp$_0 = GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n }\n return tmp$_0;\n };\n DataProcessing.prototype.computeGroups_0 = function (values) {\n var tmp$, tmp$_0;\n var groups = ArrayList_init();\n var groupByVal = HashMap_init();\n var count = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (!groupByVal.containsKey_11rb$(v)) {\n var value = (tmp$_0 = count, count = tmp$_0 + 1 | 0, tmp$_0);\n groupByVal.put_xwzc9p$(v, value);\n }groups.add_11rb$(ensureNotNull(groupByVal.get_11rb$(v)));\n }\n return groups;\n };\n DataProcessing.prototype.computeDummyValues_0 = function (list1, list2) {\n if (list1.isEmpty())\n return emptyList();\n var limit = 1000;\n var max = Ordering.Companion.natural_dahdeg$().max_m5x2f4$(collect.Iterables.concat_yxozss$(list1, list2));\n if (!(max < limit)) {\n var message = 'Too many groups: ' + max;\n throw IllegalStateException_init(message.toString());\n }var dummies = ArrayList_init();\n var it1 = list1.iterator();\n var it2 = list2.iterator();\n while (it1.hasNext()) {\n var v1 = it1.next();\n var v2 = it2.next();\n var dummy = Kotlin.imul(v1, limit) + v2 | 0;\n dummies.add_11rb$(dummy);\n }\n return dummies;\n };\n DataProcessing.prototype.getGroupingVariables_0 = function (data, bindings, explicitGroupingVar) {\n var tmp$;\n var result = LinkedHashSet_init();\n tmp$ = bindings.iterator();\n while (tmp$.hasNext()) {\n var binding = tmp$.next();\n var variable = binding.variable;\n if (!result.contains_11rb$(variable)) {\n if (variable.isOrigin) {\n if (equals(variable, explicitGroupingVar) || this.isDefaultGroupingVariable_0(data, binding.aes, variable)) {\n result.add_11rb$(variable);\n }}}}\n return result;\n };\n DataProcessing.prototype.isDefaultGroupingVariable_0 = function (data, aes, variable) {\n return !(Aes.Companion.isPositional_896ixz$(aes) || data.isNumeric_8xm3sj$(variable));\n };\n function DataProcessing$DataAndGroupingContext(data, groupingContext) {\n this.data = data;\n this.groupingContext = groupingContext;\n }\n DataProcessing$DataAndGroupingContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataAndGroupingContext',\n interfaces: []\n };\n DataProcessing.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DataProcessing',\n interfaces: []\n };\n var DataProcessing_instance = null;\n function DataProcessing_getInstance() {\n if (DataProcessing_instance === null) {\n new DataProcessing();\n }return DataProcessing_instance;\n }\n function GroupMerger() {\n this.myOrderSpecs_0 = null;\n this.myOrderedGroups_0 = ArrayList_init();\n }\n GroupMerger.prototype.initOrderSpecs_37be8y$ = function (orderOptions, variables, bindings, aggregateOperation) {\n if (this.myOrderSpecs_0 != null)\n return;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = orderOptions.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_0;\n tmp$_0 = bindings.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n if (equals(element_0.variable.name, element.variableName) && equals(element_0.aes, Aes.Companion.X)) {\n firstOrNull$result = element_0;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if (firstOrNull$result == null)\n destination.add_11rb$(element);\n }\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(OrderOptionUtil_getInstance().createOrderSpec_e64h97$(variables, bindings, item, aggregateOperation));\n }\n this.myOrderSpecs_0 = destination_0;\n };\n GroupMerger.prototype.getResultSeries = function () {\n var resultSeries = HashMap_init();\n var tmp$;\n tmp$ = this.myOrderedGroups_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n tmp$_0 = element.df.variables().iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n var tmp$_1;\n var value = resultSeries.get_11rb$(element_0);\n if (value == null) {\n var answer = ArrayList_init();\n resultSeries.put_xwzc9p$(element_0, answer);\n tmp$_1 = answer;\n } else {\n tmp$_1 = value;\n }\n tmp$_1.addAll_brywnq$(element.df.get_8xm3sj$(element_0));\n }\n }\n return resultSeries;\n };\n GroupMerger.prototype.getGroupSizes = function () {\n var $receiver = this.myOrderedGroups_0;\n var transform = getPropertyCallableRef('groupSize', 1, function ($receiver) {\n return $receiver.groupSize;\n });\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(transform(item));\n }\n return destination;\n };\n function GroupMerger$Group($outer, df, groupSize) {\n this.$outer = $outer;\n this.df = df;\n this.groupSize = groupSize;\n }\n function GroupMerger$Group$compareTo$compareGroupValue(v1, v2, dir) {\n var tmp$, tmp$_0;\n if (v1 == null && v2 == null)\n return 0;\n if (v1 == null)\n return 1;\n if (v2 == null)\n return -1;\n return Kotlin.imul(compareValues(Kotlin.isComparable(tmp$ = v1) ? tmp$ : throwCCE(), Kotlin.isComparable(tmp$_0 = v2) ? tmp$_0 : throwCCE()), dir);\n }\n function GroupMerger$Group$compareTo$getValue(df, variable, aggregateOperation) {\n if (aggregateOperation === void 0)\n aggregateOperation = null;\n var tmp$;\n if (aggregateOperation != null) {\n if (!df.isNumeric_8xm3sj$(variable)) {\n var message = \"Can't apply aggregate operation to non-numeric values\";\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = aggregateOperation(requireNoNulls(df.getNumeric_8xm3sj$(variable)));\n } else {\n tmp$ = firstOrNull(df.get_8xm3sj$(variable));\n }\n return tmp$;\n }\n GroupMerger$Group.prototype.compareTo_11rb$ = function (other) {\n var tmp$;\n var compareGroupValue = GroupMerger$Group$compareTo$compareGroupValue;\n var getValue = GroupMerger$Group$compareTo$getValue;\n if ((tmp$ = this.$outer.myOrderSpecs_0) != null) {\n var tmp$_0;\n tmp$_0 = tmp$.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var cmp = compareGroupValue(getValue(this.df, element.orderBy, element.aggregateOperation), getValue(other.df, element.orderBy, element.aggregateOperation), element.direction);\n if (cmp === 0) {\n cmp = compareGroupValue(getValue(this.df, element.variable), getValue(other.df, element.variable), element.direction);\n }if (cmp !== 0) {\n return cmp;\n }}\n }return 0;\n };\n GroupMerger$Group.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Group',\n interfaces: [Comparable]\n };\n GroupMerger.prototype.addGroup_s4jycv$ = function (d, groupSize) {\n var group = new GroupMerger$Group(this, d, groupSize);\n var indexToInsert = this.findIndexToInsert_0(group);\n this.myOrderedGroups_0.add_wxm5ur$(indexToInsert, group);\n };\n GroupMerger.prototype.findIndexToInsert_0 = function (group) {\n var $receiver = this.myOrderSpecs_0;\n if ($receiver == null || $receiver.isEmpty()) {\n return this.myOrderedGroups_0.size;\n }var index = binarySearch(this.myOrderedGroups_0, group);\n if (index < 0)\n index = ~index;\n return index;\n };\n GroupMerger.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupMerger',\n interfaces: []\n };\n function GroupUtil() {\n GroupUtil_instance = this;\n this.SINGLE_GROUP_8be2vx$ = GroupUtil$SINGLE_GROUP$lambda;\n }\n function GroupUtil$wrap$lambda(closure$l) {\n return function (index) {\n return index > 0 && index < closure$l.size ? numberToInt(ensureNotNull(closure$l.get_za3lpa$(index))) : 0;\n };\n }\n GroupUtil.prototype.wrap_2wzaym$ = function (l) {\n return GroupUtil$wrap$lambda(l);\n };\n function GroupUtil$wrap$lambda_0(closure$groupByPointIndex) {\n return function (it) {\n return ensureNotNull(closure$groupByPointIndex.get_11rb$(it));\n };\n }\n GroupUtil.prototype.wrap_orwq1h$ = function (groupByPointIndex) {\n return GroupUtil$wrap$lambda_0(groupByPointIndex);\n };\n GroupUtil.prototype.indicesByGroup_wc9gac$ = function (dataLength, groups) {\n var indicesByGroup = LinkedHashMap_init();\n for (var i = 0; i < dataLength; i++) {\n var group = groups(i);\n if (!indicesByGroup.containsKey_11rb$(group)) {\n var value = ArrayList_init();\n indicesByGroup.put_xwzc9p$(group, value);\n }ensureNotNull(indicesByGroup.get_11rb$(group)).add_11rb$(i);\n }\n return indicesByGroup;\n };\n function GroupUtil$SINGLE_GROUP$lambda(f) {\n return 0;\n }\n GroupUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GroupUtil',\n interfaces: []\n };\n var GroupUtil_instance = null;\n function GroupUtil_getInstance() {\n if (GroupUtil_instance === null) {\n new GroupUtil();\n }return GroupUtil_instance;\n }\n function GroupingContext(myData, bindings, groupingVarName, pathIdVarName, myExpectMultiple) {\n GroupingContext$Companion_getInstance();\n this.myData_0 = myData;\n this.myExpectMultiple_0 = myExpectMultiple;\n this.myBindings_0 = ArrayList_init_1(bindings);\n this.optionalGroupingVar_8be2vx$ = DataProcessing_getInstance().findOptionalVariable_hrxl0z$(this.myData_0, groupingVarName);\n this.pathIdVar_0 = DataProcessing_getInstance().findOptionalVariable_hrxl0z$(this.myData_0, pathIdVarName);\n this.myGroupSizeList_0 = null;\n this.myGroupMapper_0 = null;\n }\n function GroupingContext$get_GroupingContext$groupMapper$lambda(this$GroupingContext) {\n return function (index) {\n if (this$GroupingContext.myGroupMapper_0 == null) {\n this$GroupingContext.myGroupMapper_0 = this$GroupingContext.computeGroups_0();\n }return ensureNotNull(this$GroupingContext.myGroupMapper_0)(index);\n };\n }\n Object.defineProperty(GroupingContext.prototype, 'groupMapper', {\n configurable: true,\n get: function () {\n return GroupingContext$get_GroupingContext$groupMapper$lambda(this);\n }\n });\n GroupingContext.prototype.computeGroups_0 = function () {\n if (this.myData_0.has_8xm3sj$(stat.Stats.GROUP)) {\n var list = this.myData_0.getNumeric_8xm3sj$(stat.Stats.GROUP);\n return GroupUtil_getInstance().wrap_2wzaym$(list);\n } else if (this.myGroupSizeList_0 != null) {\n if (ensureNotNull(this.myGroupSizeList_0).size === this.myData_0.rowCount()) {\n return GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n } else {\n var groupByPointIndex = GroupingContext$Companion_getInstance().toIndexMap_0(ensureNotNull(this.myGroupSizeList_0));\n return GroupUtil_getInstance().wrap_orwq1h$(groupByPointIndex);\n }\n } else if (this.myExpectMultiple_0) {\n return DataProcessing_getInstance().computeGroups_hut2k5$(this.myData_0, this.myBindings_0, this.optionalGroupingVar_8be2vx$, this.pathIdVar_0);\n }return GroupUtil_getInstance().SINGLE_GROUP_8be2vx$;\n };\n function GroupingContext$Companion() {\n GroupingContext$Companion_instance = this;\n }\n GroupingContext$Companion.prototype.withOrderedGroups_vi90cb$ = function (data, groupSizeList) {\n var groupingContext = new GroupingContext(data, emptyList(), null, null, false);\n groupingContext.myGroupSizeList_0 = ArrayList_init_1(groupSizeList);\n return groupingContext;\n };\n GroupingContext$Companion.prototype.toIndexMap_0 = function (groupSizeList) {\n var tmp$;\n var result = HashMap_init();\n var currentGroup = 0;\n var currentGroupIndexOffset = 0;\n tmp$ = groupSizeList.iterator();\n while (tmp$.hasNext()) {\n var groupSize = tmp$.next();\n for (var i = 0; i < groupSize; i++) {\n var key = currentGroupIndexOffset + i | 0;\n var value = currentGroup;\n result.put_xwzc9p$(key, value);\n }\n currentGroup = currentGroup + 1 | 0;\n currentGroupIndexOffset = currentGroupIndexOffset + groupSize | 0;\n }\n return result;\n };\n GroupingContext$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupingContext$Companion_instance = null;\n function GroupingContext$Companion_getInstance() {\n if (GroupingContext$Companion_instance === null) {\n new GroupingContext$Companion();\n }return GroupingContext$Companion_instance;\n }\n GroupingContext.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupingContext',\n interfaces: []\n };\n function OrderOptionUtil() {\n OrderOptionUtil_instance = this;\n }\n function OrderOptionUtil$OrderOption(variableName, byVariable, orderDir) {\n OrderOptionUtil$OrderOption$Companion_getInstance();\n this.variableName = variableName;\n this.byVariable = byVariable;\n this.orderDir_0 = orderDir;\n }\n OrderOptionUtil$OrderOption.prototype.getOrderDir = function () {\n var tmp$;\n return (tmp$ = this.orderDir_0) != null ? tmp$ : -1;\n };\n function OrderOptionUtil$OrderOption$Companion() {\n OrderOptionUtil$OrderOption$Companion_instance = this;\n }\n OrderOptionUtil$OrderOption$Companion.prototype.create_yyjhqb$ = function (variableName, orderBy, order) {\n var tmp$, tmp$_0;\n if (orderBy == null && order == null) {\n return null;\n }if (!(order == null || (Kotlin.isNumber(order) && listOf_0([-1, 1]).contains_11rb$(numberToInt(order))))) {\n var message = 'Unsupported `order` value: ' + toString(order) + '. Use 1 (ascending) or -1 (descending).';\n throw IllegalArgumentException_init(message.toString());\n }return new OrderOptionUtil$OrderOption(variableName, orderBy, (tmp$_0 = Kotlin.isNumber(tmp$ = order) ? tmp$ : null) != null ? numberToInt(tmp$_0) : null);\n };\n OrderOptionUtil$OrderOption$Companion.prototype.mergeWith_me9ya9$ = function ($receiver, other) {\n var tmp$, tmp$_0;\n if (!equals($receiver.variableName, other.variableName)) {\n var message = \"Can't merge order options for different variables: '\" + $receiver.variableName + \"' and '\" + other.variableName + \"'\";\n throw IllegalArgumentException_init(message.toString());\n }if (!($receiver.byVariable == null || other.byVariable == null || equals(other.byVariable, $receiver.byVariable))) {\n var message_0 = \"Multiple ordering options for the variable '\" + $receiver.variableName + \"' with different non-empty 'order_by' fields: '\" + toString($receiver.byVariable) + \"' and '\" + toString(other.byVariable) + \"'\";\n throw IllegalArgumentException_init(message_0.toString());\n }if (!($receiver.orderDir_0 == null || other.orderDir_0 == null || other.orderDir_0 == $receiver.orderDir_0)) {\n var message_1 = \"Multiple ordering options for the variable '\" + $receiver.variableName + \"' with different order direction: '\" + toString($receiver.orderDir_0) + \"' and '\" + toString(other.orderDir_0) + \"'\";\n throw IllegalArgumentException_init(message_1.toString());\n }return new OrderOptionUtil$OrderOption($receiver.variableName, (tmp$ = $receiver.byVariable) != null ? tmp$ : other.byVariable, (tmp$_0 = $receiver.orderDir_0) != null ? tmp$_0 : other.orderDir_0);\n };\n OrderOptionUtil$OrderOption$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var OrderOptionUtil$OrderOption$Companion_instance = null;\n function OrderOptionUtil$OrderOption$Companion_getInstance() {\n if (OrderOptionUtil$OrderOption$Companion_instance === null) {\n new OrderOptionUtil$OrderOption$Companion();\n }return OrderOptionUtil$OrderOption$Companion_instance;\n }\n OrderOptionUtil$OrderOption.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'OrderOption',\n interfaces: []\n };\n function OrderOptionUtil$createOrderSpec$getVariableByName(closure$variables) {\n return function (varName) {\n var tmp$;\n var tmp$_0;\n var $receiver = closure$variables;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (equals(element.name, varName)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if ((tmp$ = firstOrNull$result) != null)\n tmp$_0 = tmp$;\n else {\n var tmp$_2 = \"Undefined variable '\" + varName + \"' in order options. Full variable list: \";\n var $receiver_0 = closure$variables;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_3;\n tmp$_3 = $receiver_0.iterator();\n while (tmp$_3.hasNext()) {\n var item = tmp$_3.next();\n destination.add_11rb$(\"'\" + item.name + \"'\");\n }\n throw IllegalStateException_init((tmp$_2 + destination).toString());\n }\n return tmp$_0;\n };\n }\n OrderOptionUtil.prototype.createOrderSpec_e64h97$ = function (variables, varBindings, orderOption, aggregateOperation) {\n var tmp$, tmp$_0, tmp$_1;\n var getVariableByName = OrderOptionUtil$createOrderSpec$getVariableByName(variables);\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_2;\n tmp$_2 = varBindings.iterator();\n while (tmp$_2.hasNext()) {\n var element = tmp$_2.next();\n if (equals(element.variable.name, orderOption.variableName) && equals(element.aes, Aes.Companion.X)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n if (firstOrNull$result != null && SamplingUtil_getInstance().xVar_bbyvt0$(variables) != null) {\n tmp$ = ensureNotNull(SamplingUtil_getInstance().xVar_bbyvt0$(variables));\n } else {\n tmp$ = getVariableByName(orderOption.variableName);\n }\n var variable = tmp$;\n return new DataFrame$OrderSpec(variable, (tmp$_1 = (tmp$_0 = orderOption.byVariable) != null ? getVariableByName(tmp$_0) : null) != null ? tmp$_1 : getVariableByName(orderOption.variableName), orderOption.getOrderDir(), orderOption.byVariable != null && !equals(orderOption.byVariable, orderOption.variableName) ? aggregateOperation : null);\n };\n OrderOptionUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'OrderOptionUtil',\n interfaces: []\n };\n var OrderOptionUtil_instance = null;\n function OrderOptionUtil_getInstance() {\n if (OrderOptionUtil_instance === null) {\n new OrderOptionUtil();\n }return OrderOptionUtil_instance;\n }\n function MouseEventPeer() {\n this.myEventHandlers_0 = HashMap_init();\n this.myEventSources_0 = ArrayList_init();\n this.mySourceRegistrations_0 = HashMap_init();\n }\n function MouseEventPeer$addEventHandler$ObjectLiteral(closure$addReg, this$MouseEventPeer, closure$eventSpec) {\n this.closure$addReg = closure$addReg;\n this.this$MouseEventPeer = this$MouseEventPeer;\n this.closure$eventSpec = closure$eventSpec;\n Registration.call(this);\n }\n MouseEventPeer$addEventHandler$ObjectLiteral.prototype.doRemove = function () {\n var tmp$;\n (tmp$ = this.closure$addReg) != null ? (tmp$.remove(), Unit) : null;\n if (ensureNotNull(this.this$MouseEventPeer.myEventHandlers_0.get_11rb$(this.closure$eventSpec)).isEmpty) {\n this.this$MouseEventPeer.myEventHandlers_0.remove_11rb$(this.closure$eventSpec);\n this.this$MouseEventPeer.onRemoveSpec_0(this.closure$eventSpec);\n }};\n MouseEventPeer$addEventHandler$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [Registration]\n };\n MouseEventPeer.prototype.addEventHandler_mfdhbe$ = function (eventSpec, eventHandler) {\n var tmp$;\n if (!this.myEventHandlers_0.containsKey_11rb$(eventSpec)) {\n var $receiver = this.myEventHandlers_0;\n var value = new Listeners();\n $receiver.put_xwzc9p$(eventSpec, value);\n this.onAddSpec_0(eventSpec);\n }var addReg = (tmp$ = this.myEventHandlers_0.get_11rb$(eventSpec)) != null ? tmp$.add_11rb$(eventHandler) : null;\n return new MouseEventPeer$addEventHandler$ObjectLiteral(addReg, this, eventSpec);\n };\n function MouseEventPeer$dispatch$ObjectLiteral(closure$mouseEvent) {\n this.closure$mouseEvent = closure$mouseEvent;\n }\n MouseEventPeer$dispatch$ObjectLiteral.prototype.call_11rb$ = function (l) {\n l.onEvent_11rb$(this.closure$mouseEvent);\n };\n MouseEventPeer$dispatch$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ListenerCaller]\n };\n MouseEventPeer.prototype.dispatch_w7zfbj$ = function (eventSpec, mouseEvent) {\n var tmp$;\n if (this.myEventHandlers_0.containsKey_11rb$(eventSpec)) {\n (tmp$ = this.myEventHandlers_0.get_11rb$(eventSpec)) != null ? (tmp$.fire_kucmxw$(new MouseEventPeer$dispatch$ObjectLiteral(mouseEvent)), Unit) : null;\n }};\n MouseEventPeer.prototype.addEventSource_u4bej9$ = function (eventSource) {\n var tmp$;\n tmp$ = this.myEventHandlers_0.keys.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.startHandleSpecInSource_0(eventSource, element);\n }\n this.myEventSources_0.add_11rb$(eventSource);\n };\n MouseEventPeer.prototype.onAddSpec_0 = function (eventSpec) {\n var tmp$;\n tmp$ = this.myEventSources_0.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.startHandleSpecInSource_0(element, eventSpec);\n }\n };\n function MouseEventPeer$startHandleSpecInSource$ObjectLiteral(closure$eventSpec, this$MouseEventPeer) {\n this.closure$eventSpec = closure$eventSpec;\n this.this$MouseEventPeer = this$MouseEventPeer;\n }\n MouseEventPeer$startHandleSpecInSource$ObjectLiteral.prototype.onEvent_11rb$ = function (event) {\n this.this$MouseEventPeer.dispatch_w7zfbj$(this.closure$eventSpec, event);\n };\n MouseEventPeer$startHandleSpecInSource$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [EventHandler]\n };\n MouseEventPeer.prototype.startHandleSpecInSource_0 = function (eventSource, eventSpec) {\n var tmp$;\n var registration = eventSource.addEventHandler_mfdhbe$(eventSpec, new MouseEventPeer$startHandleSpecInSource$ObjectLiteral(eventSpec, this));\n if (!this.mySourceRegistrations_0.containsKey_11rb$(eventSpec)) {\n var $receiver = this.mySourceRegistrations_0;\n var value = new CompositeRegistration([]);\n $receiver.put_xwzc9p$(eventSpec, value);\n }(tmp$ = this.mySourceRegistrations_0.get_11rb$(eventSpec)) != null ? tmp$.add_3xv6fb$(registration) : null;\n };\n MouseEventPeer.prototype.onRemoveSpec_0 = function (eventSpec) {\n var tmp$;\n if (this.mySourceRegistrations_0.containsKey_11rb$(eventSpec)) {\n (tmp$ = this.mySourceRegistrations_0.remove_11rb$(eventSpec)) != null ? (tmp$.dispose(), Unit) : null;\n }};\n MouseEventPeer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MouseEventPeer',\n interfaces: [MouseEventSource]\n };\n function AxisComponent(length, orientation) {\n SvgComponent.call(this);\n this.breaks = new ValueProperty(null);\n this.labels = new ValueProperty(null);\n this.tickLabelRotationDegree = new ValueProperty(0.0);\n this.tickLabelHorizontalAnchor = null;\n this.tickLabelVerticalAnchor = null;\n this.tickLabelSmallFont = new ValueProperty(false);\n this.tickLabelOffsets = new ValueProperty(null);\n this.gridLineColor = new ValueProperty(Color.Companion.LIGHT_GRAY);\n this.lineWidth = new ValueProperty(1.0);\n this.gridLineWidth = new ValueProperty(1.0);\n this.gridLineLength = new ValueProperty(0.0);\n this.tickMarkWidth = new ValueProperty(1.0);\n this.tickMarkLength = new ValueProperty(6.0);\n this.tickMarkPadding = new ValueProperty(3.0);\n this.length_0 = new ValueProperty(null);\n this.orientation_0 = new ValueProperty(null);\n this.myTickMarksEnabled_0 = new ValueProperty(true);\n this.myTickLabelsEnabled_0 = new ValueProperty(true);\n this.myAxisLineEnabled_0 = new ValueProperty(true);\n this.lineColor_0 = new ValueProperty(Color.Companion.BLACK);\n this.tickColor_0 = new ValueProperty(Color.Companion.BLACK);\n this.length_0.set_11rb$(length);\n this.orientation_0.set_11rb$(orientation);\n this.tickLabelHorizontalAnchor = new ValueProperty(this.defTickLabelHorizontalAnchor_0(orientation));\n this.tickLabelVerticalAnchor = new ValueProperty(this.defTickLabelVerticalAnchor_0(orientation));\n var asPropertyChangedEventSource = AxisComponent_init$asPropertyChangedEventSource;\n event.EventSources.composite_xw2ruy$([asPropertyChangedEventSource(this.length_0), asPropertyChangedEventSource(this.orientation_0), asPropertyChangedEventSource(this.breaks), asPropertyChangedEventSource(this.labels), asPropertyChangedEventSource(this.gridLineLength), asPropertyChangedEventSource(this.tickLabelOffsets), asPropertyChangedEventSource(this.tickLabelHorizontalAnchor), asPropertyChangedEventSource(this.tickLabelVerticalAnchor), asPropertyChangedEventSource(this.tickLabelRotationDegree), asPropertyChangedEventSource(this.tickLabelSmallFont)]).addHandler_gxwwpc$(this.rebuildHandler_287e2$());\n }\n AxisComponent.prototype.defTickLabelHorizontalAnchor_0 = function (orientation) {\n var tmp$;\n switch (orientation.name) {\n case 'LEFT':\n tmp$ = TextLabel$HorizontalAnchor.RIGHT;\n break;\n case 'RIGHT':\n tmp$ = TextLabel$HorizontalAnchor.LEFT;\n break;\n case 'TOP':\n case 'BOTTOM':\n tmp$ = TextLabel$HorizontalAnchor.MIDDLE;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n AxisComponent.prototype.defTickLabelVerticalAnchor_0 = function (orientation) {\n switch (orientation.name) {\n case 'LEFT':\n case 'RIGHT':\n return TextLabel$VerticalAnchor.CENTER;\n case 'TOP':\n return TextLabel$VerticalAnchor.BOTTOM;\n case 'BOTTOM':\n return TextLabel$VerticalAnchor.TOP;\n default:throw RuntimeException_init('Unexpected orientation:' + orientation);\n }\n };\n AxisComponent.prototype.buildComponent = function () {\n this.buildAxis_0();\n };\n AxisComponent.prototype.buildAxis_0 = function () {\n var tmp$, tmp$_0, tmp$_1;\n var rootElement = this.rootGroup;\n rootElement.addClass_61zpoe$(Style_getInstance().AXIS);\n if (this.tickLabelSmallFont.get()) {\n rootElement.addClass_61zpoe$(Style_getInstance().SMALL_TICK_FONT);\n }var l = ensureNotNull(this.length_0.get());\n var x1;\n var y1;\n var x2;\n var y2;\n var start;\n var end;\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance()) || equals(tmp$, Orientation$RIGHT_getInstance())) {\n x2 = 0.0;\n x1 = x2;\n start = 0.0;\n y1 = start;\n end = l;\n y2 = end;\n } else if (equals(tmp$, Orientation$TOP_getInstance()) || equals(tmp$, Orientation$BOTTOM_getInstance())) {\n start = 0.0;\n x1 = start;\n end = l;\n x2 = end;\n y2 = 0.0;\n y1 = y2;\n } else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n var axisLine = null;\n if (this.axisLineEnabled().get()) {\n axisLine = SvgLineElement_init(x1, y1, x2, y2);\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.lineWidth, axisLine.strokeWidth()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.lineColor_0, axisLine.strokeColor()));\n }var gridLineMinPos = start + 3;\n var gridLineMaxPos = end - 3;\n if (this.breaksEnabled_0()) {\n var breaks = this.breaks.get();\n if (!(breaks == null || breaks.isEmpty())) {\n var labels = this.labels.get();\n if (labels == null || labels.isEmpty()) {\n labels = ArrayList_init();\n for (var i = 0; i !== breaks.size; ++i) {\n labels.add_11rb$('');\n }\n }var i_0 = 0;\n tmp$_0 = breaks.iterator();\n while (tmp$_0.hasNext()) {\n var br = tmp$_0.next();\n var addGridLine = br >= gridLineMinPos && br <= gridLineMaxPos;\n var label = labels.get_za3lpa$(i_0 % labels.size);\n var labelOffset = this.tickLabelOffset_0(i_0);\n i_0 = i_0 + 1 | 0;\n var group = this.buildTick_0(label, labelOffset, addGridLine ? this.gridLineLength.get() : 0.0);\n tmp$_1 = this.orientation_0.get();\n if (equals(tmp$_1, Orientation$LEFT_getInstance()) || equals(tmp$_1, Orientation$RIGHT_getInstance()))\n svg.SvgUtils.transformTranslate_pw34rw$(group, 0.0, br);\n else if (equals(tmp$_1, Orientation$TOP_getInstance()) || equals(tmp$_1, Orientation$BOTTOM_getInstance()))\n svg.SvgUtils.transformTranslate_pw34rw$(group, br, 0.0);\n else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n rootElement.children().add_11rb$(group);\n }\n }}if (axisLine != null) {\n rootElement.children().add_11rb$(axisLine);\n }};\n AxisComponent.prototype.buildTick_0 = function (label, labelOffset, gridLineLength) {\n var tmp$;\n var tickMark = null;\n if (this.tickMarksEnabled().get()) {\n tickMark = new SvgLineElement();\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickMarkWidth, tickMark.strokeWidth()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0, tickMark.strokeColor()));\n }var tickLabel = null;\n if (this.tickLabelsEnabled().get()) {\n tickLabel = new TextLabel(label);\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0, tickLabel.textColor()));\n }var gridLine = null;\n if (gridLineLength > 0) {\n gridLine = new SvgLineElement();\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineColor, gridLine.strokeColor()));\n this.reg_3xv6fb$(property.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineWidth, gridLine.strokeWidth()));\n }var markLength = this.tickMarkLength.get();\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(-markLength);\n tickMark.y2().set_11rb$(0.0);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(gridLineLength);\n gridLine.y2().set_11rb$(0.0);\n }} else if (equals(tmp$, Orientation$RIGHT_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(markLength);\n tickMark.y2().set_11rb$(0.0);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(-gridLineLength);\n gridLine.y2().set_11rb$(0.0);\n }} else if (equals(tmp$, Orientation$TOP_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(0.0);\n tickMark.y2().set_11rb$(-markLength);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(0.0);\n gridLine.y2().set_11rb$(gridLineLength);\n }} else if (equals(tmp$, Orientation$BOTTOM_getInstance())) {\n if (tickMark != null) {\n tickMark.x2().set_11rb$(0.0);\n tickMark.y2().set_11rb$(markLength);\n }if (gridLine != null) {\n gridLine.x2().set_11rb$(0.0);\n gridLine.y2().set_11rb$(-gridLineLength);\n }} else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n var g = new SvgGElement();\n if (gridLine != null) {\n g.children().add_11rb$(gridLine);\n }if (tickMark != null) {\n g.children().add_11rb$(tickMark);\n }if (tickLabel != null) {\n tickLabel.moveTo_lu1900$(labelOffset.x, labelOffset.y);\n tickLabel.setHorizontalAnchor_ja80zo$(this.tickLabelHorizontalAnchor.get());\n tickLabel.setVerticalAnchor_yaudma$(this.tickLabelVerticalAnchor.get());\n tickLabel.rotate_14dthe$(this.tickLabelRotationDegree.get());\n g.children().add_11rb$(tickLabel.rootGroup);\n }g.addClass_61zpoe$(Style_getInstance().TICK);\n return g;\n };\n AxisComponent.prototype.tickMarkLength_0 = function () {\n var tmp$;\n if (this.myTickMarksEnabled_0.get()) {\n tmp$ = this.tickMarkLength.get();\n } else {\n tmp$ = 0.0;\n }\n return tmp$;\n };\n AxisComponent.prototype.tickLabelDistance_0 = function () {\n return this.tickMarkLength_0() + this.tickMarkPadding.get();\n };\n AxisComponent.prototype.tickLabelBaseOffset_0 = function () {\n var tmp$, tmp$_0;\n var distance = this.tickLabelDistance_0();\n tmp$ = this.orientation_0.get();\n if (equals(tmp$, Orientation$LEFT_getInstance()))\n tmp$_0 = new DoubleVector(-distance, 0.0);\n else if (equals(tmp$, Orientation$RIGHT_getInstance()))\n tmp$_0 = new DoubleVector(distance, 0.0);\n else if (equals(tmp$, Orientation$TOP_getInstance()))\n tmp$_0 = new DoubleVector(0.0, -distance);\n else if (equals(tmp$, Orientation$BOTTOM_getInstance()))\n tmp$_0 = new DoubleVector(0.0, distance);\n else\n throw RuntimeException_init('Unexpected orientation:' + toString(this.orientation_0.get()));\n return tmp$_0;\n };\n AxisComponent.prototype.tickLabelOffset_0 = function (tickIndex) {\n var additionalOffsets = this.tickLabelOffsets.get();\n var additionalOffset = additionalOffsets != null ? additionalOffsets.get_za3lpa$(tickIndex) : DoubleVector.Companion.ZERO;\n return this.tickLabelBaseOffset_0().add_gpjtzr$(additionalOffset);\n };\n AxisComponent.prototype.breaksEnabled_0 = function () {\n return this.myTickMarksEnabled_0.get() || this.myTickLabelsEnabled_0.get();\n };\n AxisComponent.prototype.tickMarksEnabled = function () {\n return this.myTickMarksEnabled_0;\n };\n AxisComponent.prototype.tickLabelsEnabled = function () {\n return this.myTickLabelsEnabled_0;\n };\n AxisComponent.prototype.axisLineEnabled = function () {\n return this.myAxisLineEnabled_0;\n };\n function AxisComponent_init$asPropertyChangedEventSource($receiver) {\n var tmp$;\n return Kotlin.isType(tmp$ = $receiver, EventSource) ? tmp$ : throwCCE();\n }\n AxisComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisComponent',\n interfaces: [SvgComponent]\n };\n function ColorBarComponent(spec) {\n LegendBox.call(this);\n this.spec_xr0de$_0 = spec;\n }\n Object.defineProperty(ColorBarComponent.prototype, 'spec', {\n get: function () {\n return this.spec_xr0de$_0;\n }\n });\n ColorBarComponent.prototype.appendGuideContent_26jijc$ = function (contentRoot) {\n var tmp$, tmp$_0;\n var layout = this.spec.layout;\n var guideBarGroup = new SvgGElement();\n var barBounds = layout.barBounds;\n var horizontal = layout.isHorizontal;\n this.addColorBar_0(guideBarGroup, this.spec.domain, this.spec.scale, this.spec.binCount, barBounds, layout.barLengthExpand, horizontal, this.spec.reverse);\n if (horizontal)\n tmp$ = barBounds.height;\n else\n tmp$ = barBounds.width;\n var barThickness = tmp$;\n var tickLength = barThickness / 5;\n var breakInfos = layout.breakInfos_8be2vx$.iterator();\n tmp$_0 = this.spec.breaks.labels.iterator();\n while (tmp$_0.hasNext()) {\n var brLabel = tmp$_0.next();\n var brInfo = breakInfos.next();\n var tickLocation = brInfo.tickLocation;\n var tickMarkPoints = ArrayList_init();\n if (horizontal) {\n var tickX = barBounds.left + tickLocation;\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.top));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.top + tickLength));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.bottom - tickLength));\n tickMarkPoints.add_11rb$(new DoubleVector(tickX, barBounds.bottom));\n } else {\n var tickY = barBounds.top + tickLocation;\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.left, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.left + tickLength, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.right - tickLength, tickY));\n tickMarkPoints.add_11rb$(new DoubleVector(barBounds.right, tickY));\n }\n this.addTickMark_0(guideBarGroup, tickMarkPoints.get_za3lpa$(0), tickMarkPoints.get_za3lpa$(1));\n this.addTickMark_0(guideBarGroup, tickMarkPoints.get_za3lpa$(2), tickMarkPoints.get_za3lpa$(3));\n var label = new TextLabel(brLabel);\n label.setHorizontalAnchor_ja80zo$(brInfo.labelHorizontalAnchor);\n label.setVerticalAnchor_yaudma$(brInfo.labelVerticalAnchor);\n label.moveTo_lu1900$(brInfo.labelLocation.x, brInfo.labelLocation.y + barBounds.top);\n guideBarGroup.children().add_11rb$(label.rootGroup);\n }\n guideBarGroup.children().add_11rb$(LegendBox$Companion_getInstance().createBorder_a5dgib$(barBounds, this.spec.theme.backgroundFill(), 1.0));\n if (this.debug) {\n var graphBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, layout.graphSize);\n guideBarGroup.children().add_11rb$(LegendBox$Companion_getInstance().createBorder_a5dgib$(graphBounds, Color.Companion.DARK_BLUE, 1.0));\n }contentRoot.children().add_11rb$(guideBarGroup);\n return layout.size;\n };\n ColorBarComponent.prototype.addColorBar_0 = function (g, domain, scale_0, numBins, barBounds, barLengthExpand, horizontal, reverse_0) {\n var tmp$;\n var domainSpan = data_0.SeriesUtil.span_4fzjta$(domain);\n var stepCount = JsMath.max(2, numBins);\n var step = domainSpan / stepCount;\n var v = domain.lowerEnd + step / 2;\n var domainValues = ArrayList_init();\n for (var i = 0; i < stepCount; i++) {\n domainValues.add_11rb$(v + step * i);\n }\n if (reverse_0) {\n reverse(domainValues);\n }var colors = scale.ScaleUtil.map_9ksyxk$(domainValues, scale_0);\n if (horizontal)\n tmp$ = barBounds.width;\n else\n tmp$ = barBounds.height;\n var barLength = tmp$;\n var effectiveBarLength = barLength - barLengthExpand * 2;\n var segmentStep = effectiveBarLength / stepCount;\n var segmentLeft = barBounds.left;\n var segmentRight = barBounds.right;\n var segmentBottom = barBounds.bottom;\n var segmentTop = barBounds.top;\n var i_0 = 0;\n for (var tmp$_0 = colors.iterator(); tmp$_0.hasNext(); ++i_0) {\n var color = tmp$_0.next();\n var r = SvgRectElement_init_0(segmentLeft, segmentTop, segmentRight - segmentLeft, segmentBottom - segmentTop);\n r.strokeWidth().set_11rb$(0.0);\n r.fillColor().set_11rb$(color);\n g.children().add_11rb$(r);\n if (horizontal) {\n segmentLeft += segmentStep;\n } else {\n segmentTop += segmentStep;\n }\n if (i_0 === 0) {\n if (horizontal) {\n segmentLeft += barLengthExpand;\n } else {\n segmentTop += barLengthExpand;\n }\n }}\n };\n ColorBarComponent.prototype.addTickMark_0 = function (g, p0, p1) {\n var line = SvgLineElement_init(p0.x, p0.y, p1.x, p1.y);\n line.strokeWidth().set_11rb$(1.0);\n line.strokeColor().set_11rb$(this.spec.theme.backgroundFill());\n g.children().add_11rb$(line);\n };\n ColorBarComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponent',\n interfaces: [LegendBox]\n };\n function ColorBarComponentLayout(title, domain, breaks, guideBarSize, legendDirection, reverse) {\n ColorBarComponentLayout$Companion_getInstance();\n LegendBoxLayout.call(this, title, legendDirection);\n this.guideBarSize = guideBarSize;\n this.barBounds_qhvd9h$_0 = null;\n this.barLengthExpand = 2.0;\n this.breakInfos_8be2vx$ = null;\n var guideBarLength = this.guideBarLength;\n var targetRange = new ClosedRange(0.0 + this.barLengthExpand, guideBarLength - this.barLengthExpand);\n var mapper = scale.Mappers.linear_1jkouz$(domain, targetRange, reverse);\n var $receiver = breaks.transformedValues;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var tmp$_0 = destination.add_11rb$;\n var tickLocation = mapper(item);\n tmp$_0.call(destination, this.createBreakInfo_14dthe$(tickLocation));\n }\n this.breakInfos_8be2vx$ = destination;\n this.barBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, this.guideBarSize);\n }\n Object.defineProperty(ColorBarComponentLayout.prototype, 'barBounds', {\n configurable: true,\n get: function () {\n return this.barBounds_qhvd9h$_0;\n },\n set: function (barBounds) {\n this.barBounds_qhvd9h$_0 = barBounds;\n }\n });\n function ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, labelHorizontalAnchor, labelVerticalAnchor) {\n this.tickLocation = tickLocation;\n this.labelLocation = labelLocation;\n this.labelHorizontalAnchor = labelHorizontalAnchor;\n this.labelVerticalAnchor = labelVerticalAnchor;\n }\n ColorBarComponentLayout$BreakInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BreakInfo',\n interfaces: []\n };\n function ColorBarComponentLayout$HorizontalLayout(title, domain, breaks, barSize, reverse) {\n ColorBarComponentLayout.call(this, title, domain, breaks, barSize, LegendDirection$HORIZONTAL_getInstance(), reverse);\n this.graphSize_4lks14$_0 = null;\n this.graphSize_4lks14$_0 = new DoubleVector(this.guideBarSize.x, this.guideBarSize.y + this.labelDistance_0 + LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n }\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n return this.graphSize_4lks14$_0;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'labelDistance_0', {\n configurable: true,\n get: function () {\n return LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height() / 3;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$HorizontalLayout.prototype, 'guideBarLength', {\n configurable: true,\n get: function () {\n return this.guideBarSize.x;\n }\n });\n ColorBarComponentLayout$HorizontalLayout.prototype.createBreakInfo_14dthe$ = function (tickLocation) {\n var labelLocation = new DoubleVector(tickLocation, this.guideBarSize.y + this.labelDistance_0);\n return new ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, TextLabel$HorizontalAnchor.MIDDLE, TextLabel$VerticalAnchor.TOP);\n };\n ColorBarComponentLayout$HorizontalLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalLayout',\n interfaces: [ColorBarComponentLayout]\n };\n function ColorBarComponentLayout$VerticalLayout(title, domain, breaks, barSize, reverse) {\n ColorBarComponentLayout.call(this, title, domain, breaks, barSize, LegendDirection$VERTICAL_getInstance(), reverse);\n this.graphSize_ld8mnu$_0 = null;\n if (!!breaks.isEmpty) {\n var message = 'Colorbar VerticalLayout received empty breaks list.';\n throw IllegalStateException_init(message.toString());\n }var $receiver = breaks.labels;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(item.length);\n }\n var iterator = destination.iterator();\n if (!iterator.hasNext())\n throw NoSuchElementException_init();\n var it = iterator.next();\n var maxValue = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(it);\n while (iterator.hasNext()) {\n var it_0 = iterator.next();\n var v = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(it_0);\n maxValue = JsMath.max(maxValue, v);\n }\n var maxLabelWidth = maxValue;\n this.graphSize_ld8mnu$_0 = new DoubleVector(this.guideBarSize.x + this.labelDistance_0 + maxLabelWidth, this.guideBarSize.y);\n }\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n return this.graphSize_ld8mnu$_0;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'labelDistance_0', {\n configurable: true,\n get: function () {\n return LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(1) / 2;\n }\n });\n Object.defineProperty(ColorBarComponentLayout$VerticalLayout.prototype, 'guideBarLength', {\n configurable: true,\n get: function () {\n return this.guideBarSize.y;\n }\n });\n ColorBarComponentLayout$VerticalLayout.prototype.createBreakInfo_14dthe$ = function (tickLocation) {\n var labelLocation = new DoubleVector(this.guideBarSize.x + this.labelDistance_0, tickLocation);\n return new ColorBarComponentLayout$BreakInfo(tickLocation, labelLocation, TextLabel$HorizontalAnchor.LEFT, TextLabel$VerticalAnchor.CENTER);\n };\n ColorBarComponentLayout$VerticalLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalLayout',\n interfaces: [ColorBarComponentLayout]\n };\n function ColorBarComponentLayout$Companion() {\n ColorBarComponentLayout$Companion_instance = this;\n }\n ColorBarComponentLayout$Companion.prototype.horizontal_dwxw1i$ = function (title, domain, breaks, barSize, reverse) {\n return new ColorBarComponentLayout$HorizontalLayout(title, domain, breaks, barSize, reverse);\n };\n ColorBarComponentLayout$Companion.prototype.vertical_dwxw1i$ = function (title, domain, breaks, barSize, reverse) {\n return new ColorBarComponentLayout$VerticalLayout(title, domain, breaks, barSize, reverse);\n };\n ColorBarComponentLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarComponentLayout$Companion_instance = null;\n function ColorBarComponentLayout$Companion_getInstance() {\n if (ColorBarComponentLayout$Companion_instance === null) {\n new ColorBarComponentLayout$Companion();\n }return ColorBarComponentLayout$Companion_instance;\n }\n ColorBarComponentLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponentLayout',\n interfaces: [LegendBoxLayout]\n };\n function ColorBarComponentSpec(title, domain, breaks, scale, binCount, theme, layout, reverse) {\n ColorBarComponentSpec$Companion_getInstance();\n LegendBoxSpec.call(this, title, theme, reverse);\n this.domain = domain;\n this.breaks = breaks;\n this.scale = scale;\n this.binCount = binCount;\n this.layout_smwmum$_0 = layout;\n }\n Object.defineProperty(ColorBarComponentSpec.prototype, 'layout', {\n get: function () {\n return this.layout_smwmum$_0;\n }\n });\n function ColorBarComponentSpec$Companion() {\n ColorBarComponentSpec$Companion_instance = this;\n this.DEF_NUM_BIN = 20;\n this.DEF_BAR_THICKNESS_0 = 1.0;\n this.DEF_BAR_LENGTH_0 = 5.0;\n }\n ColorBarComponentSpec$Companion.prototype.barAbsoluteSize_kkcal5$ = function (horizontal, theme) {\n var tmp$;\n if (horizontal)\n tmp$ = new DoubleVector(this.DEF_BAR_LENGTH_0 * theme.keySize(), this.DEF_BAR_THICKNESS_0 * theme.keySize());\n else\n tmp$ = new DoubleVector(this.DEF_BAR_THICKNESS_0 * theme.keySize(), this.DEF_BAR_LENGTH_0 * theme.keySize());\n return tmp$;\n };\n ColorBarComponentSpec$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBarComponentSpec$Companion_instance = null;\n function ColorBarComponentSpec$Companion_getInstance() {\n if (ColorBarComponentSpec$Companion_instance === null) {\n new ColorBarComponentSpec$Companion();\n }return ColorBarComponentSpec$Companion_instance;\n }\n ColorBarComponentSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBarComponentSpec',\n interfaces: [LegendBoxSpec]\n };\n function LegendArrangement(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LegendArrangement_initFields() {\n LegendArrangement_initFields = function () {\n };\n LegendArrangement$HORIZONTAL_instance = new LegendArrangement('HORIZONTAL', 0);\n LegendArrangement$VERTICAL_instance = new LegendArrangement('VERTICAL', 1);\n }\n var LegendArrangement$HORIZONTAL_instance;\n function LegendArrangement$HORIZONTAL_getInstance() {\n LegendArrangement_initFields();\n return LegendArrangement$HORIZONTAL_instance;\n }\n var LegendArrangement$VERTICAL_instance;\n function LegendArrangement$VERTICAL_getInstance() {\n LegendArrangement_initFields();\n return LegendArrangement$VERTICAL_instance;\n }\n LegendArrangement.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendArrangement',\n interfaces: [Enum]\n };\n function LegendArrangement$values() {\n return [LegendArrangement$HORIZONTAL_getInstance(), LegendArrangement$VERTICAL_getInstance()];\n }\n LegendArrangement.values = LegendArrangement$values;\n function LegendArrangement$valueOf(name) {\n switch (name) {\n case 'HORIZONTAL':\n return LegendArrangement$HORIZONTAL_getInstance();\n case 'VERTICAL':\n return LegendArrangement$VERTICAL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.LegendArrangement.' + name);\n }\n }\n LegendArrangement.valueOf_61zpoe$ = LegendArrangement$valueOf;\n function LegendBox() {\n LegendBox$Companion_getInstance();\n SvgComponent.call(this);\n this.debug = false;\n }\n Object.defineProperty(LegendBox.prototype, 'title_aaysjy$_0', {\n configurable: true,\n get: function () {\n return this.spec.title;\n }\n });\n Object.defineProperty(LegendBox.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.spec.size;\n }\n });\n LegendBox.prototype.hasTitle_kmjss0$_0 = function () {\n return this.spec.hasTitle();\n };\n LegendBox.prototype.buildComponent = function () {\n this.addClassName_61zpoe$(Style_getInstance().LEGEND);\n var outerBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, this.spec.size);\n this.addRectangle_7omvup$(this.spec.innerBounds, this.spec.theme.backgroundFill());\n var innerGroup = new SvgGElement();\n innerGroup.transform().set_11rb$(SvgComponent.Companion.buildTransform_e1sv3v$(this.spec.contentOrigin, 0.0));\n var l = this.spec.layout;\n if (this.hasTitle_kmjss0$_0()) {\n var label = this.createTitleLabel_d65hob$_0(l.titleLocation, l.titleHorizontalAnchor, l.titleVerticalAnchor);\n innerGroup.children().add_11rb$(label.rootGroup);\n }var graphGroup = new SvgGElement();\n graphGroup.transform().set_11rb$(SvgComponent.Companion.buildTransform_e1sv3v$(l.graphOrigin, 0.0));\n this.appendGuideContent_26jijc$(graphGroup);\n innerGroup.children().add_11rb$(graphGroup);\n if (this.debug) {\n this.addBorder_a5dgib$(outerBounds, Color.Companion.CYAN, 1.0);\n var rect = SvgRectElement_init(this.spec.innerBounds);\n rect.fillColor().set_11rb$(Color.Companion.BLACK);\n rect.strokeWidth().set_11rb$(0.0);\n rect.fillOpacity().set_11rb$(0.1);\n this.add_26jijc$(rect);\n this.addBorder_a5dgib$(this.spec.contentBounds, Color.Companion.DARK_MAGENTA, 1.0);\n this.addBorder_a5dgib$(l.titleBounds.add_gpjtzr$(this.spec.contentOrigin), Color.Companion.MAGENTA, 1.0);\n }this.add_26jijc$(innerGroup);\n };\n LegendBox.prototype.addBorder_a5dgib$ = function (bounds, strokeColor, strokeWidth) {\n this.add_26jijc$(LegendBox$Companion_getInstance().createBorder_a5dgib$(bounds, strokeColor, strokeWidth));\n };\n LegendBox.prototype.addRectangle_7omvup$ = function (bounds, fillColor) {\n this.add_26jijc$(LegendBox$Companion_getInstance().createRectangle_0(bounds, fillColor));\n };\n LegendBox.prototype.createTitleLabel_d65hob$_0 = function (origin, horizontalAnchor, verticalAnchor) {\n var label = new TextLabel(this.title_aaysjy$_0);\n label.addClassName_61zpoe$(Style_getInstance().LEGEND_TITLE);\n label.setHorizontalAnchor_ja80zo$(horizontalAnchor);\n label.setVerticalAnchor_yaudma$(verticalAnchor);\n label.moveTo_gpjtzr$(origin);\n return label;\n };\n function LegendBox$Companion() {\n LegendBox$Companion_instance = this;\n }\n LegendBox$Companion.prototype.createBorder_a5dgib$ = function (bounds, strokeColor, strokeWidth) {\n var rect = SvgRectElement_init(bounds);\n rect.strokeColor().set_11rb$(strokeColor);\n rect.strokeWidth().set_11rb$(strokeWidth);\n rect.fillOpacity().set_11rb$(0.0);\n return rect;\n };\n LegendBox$Companion.prototype.createRectangle_0 = function (bounds, fillColor) {\n var rect = SvgRectElement_init(bounds);\n rect.fillColor().set_11rb$(fillColor);\n return rect;\n };\n LegendBox$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBox$Companion_instance = null;\n function LegendBox$Companion_getInstance() {\n if (LegendBox$Companion_instance === null) {\n new LegendBox$Companion();\n }return LegendBox$Companion_instance;\n }\n LegendBox.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBox',\n interfaces: [SvgComponent]\n };\n function LegendBoxLayout(title, legendDirection) {\n LegendBoxLayout$Companion_getInstance();\n this.title_47v7cs$_0 = title;\n this.isHorizontal = legendDirection === LegendDirection$HORIZONTAL_getInstance();\n this.titleHorizontalAnchor = TextLabel$HorizontalAnchor.LEFT;\n var tmp$;\n if (this.isHorizontal) {\n tmp$ = TextLabel$VerticalAnchor.CENTER;\n } else {\n tmp$ = TextLabel$VerticalAnchor.TOP;\n }\n this.titleVerticalAnchor = tmp$;\n }\n Object.defineProperty(LegendBoxLayout.prototype, 'titleBounds', {\n configurable: true,\n get: function () {\n var origin = this.titleLocation;\n var size = LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0);\n if (this.isHorizontal) {\n origin = new DoubleVector(origin.x, origin.y - size.y / 2);\n }return new DoubleRectangle(origin, size);\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'graphOrigin', {\n configurable: true,\n get: function () {\n if (this.isHorizontal)\n return new DoubleVector(LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0).x, 0.0);\n else\n return new DoubleVector(0.0, LegendBoxLayout$Companion_getInstance().titleSize_0(this.title_47v7cs$_0).y);\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'size', {\n configurable: true,\n get: function () {\n var graphBounds = new DoubleRectangle(this.graphOrigin, this.graphSize);\n var titleAndContent = (new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO)).union_wthzt5$(this.titleBounds).union_wthzt5$(graphBounds);\n return titleAndContent.dimension;\n }\n });\n Object.defineProperty(LegendBoxLayout.prototype, 'titleLocation', {\n configurable: true,\n get: function () {\n if (this.isHorizontal) {\n var graphSize = this.graphSize;\n return new DoubleVector(0.0, graphSize.y / 2);\n } else {\n var y = -LegendBoxLayout$Companion_getInstance().TITLE_SPEC_0.height() / 3;\n return new DoubleVector(0.0, y);\n }\n }\n });\n function LegendBoxLayout$Companion() {\n LegendBoxLayout$Companion_instance = this;\n this.TITLE_SPEC_0 = PlotLabelSpec$LEGEND_TITLE_getInstance();\n this.LABEL_SPEC_8be2vx$ = PlotLabelSpec$LEGEND_ITEM_getInstance();\n }\n LegendBoxLayout$Companion.prototype.titleSize_0 = function (s) {\n var tmp$;\n if (isBlank(s))\n tmp$ = DoubleVector.Companion.ZERO;\n else\n tmp$ = this.TITLE_SPEC_0.dimensions_za3lpa$(s.length);\n return tmp$;\n };\n LegendBoxLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBoxLayout$Companion_instance = null;\n function LegendBoxLayout$Companion_getInstance() {\n if (LegendBoxLayout$Companion_instance === null) {\n new LegendBoxLayout$Companion();\n }return LegendBoxLayout$Companion_instance;\n }\n LegendBoxLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxLayout',\n interfaces: []\n };\n function LegendBoxSpec(title, theme, reverse) {\n this.title = title;\n this.theme = theme;\n this.reverse = reverse;\n this.contentOrigin = null;\n this.fullContentExtend_5hau13$_0 = null;\n this.innerOrigin_3w1y5t$_0 = null;\n this.innerContentExtend_wllzuc$_0 = null;\n var contentExpand = this.theme.margin() + this.theme.padding();\n this.contentOrigin = new DoubleVector(contentExpand, contentExpand);\n this.fullContentExtend_5hau13$_0 = new DoubleVector(contentExpand * 2, contentExpand * 2);\n this.innerOrigin_3w1y5t$_0 = new DoubleVector(this.theme.margin(), this.theme.margin());\n this.innerContentExtend_wllzuc$_0 = new DoubleVector(this.theme.padding() * 2, this.theme.padding() * 2);\n }\n Object.defineProperty(LegendBoxSpec.prototype, 'contentSize_cb71ch$_0', {\n configurable: true,\n get: function () {\n return this.layout.size;\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.contentSize_cb71ch$_0.add_gpjtzr$(this.fullContentExtend_5hau13$_0);\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'innerBounds', {\n configurable: true,\n get: function () {\n return new DoubleRectangle(this.innerOrigin_3w1y5t$_0, this.contentSize_cb71ch$_0.add_gpjtzr$(this.innerContentExtend_wllzuc$_0));\n }\n });\n Object.defineProperty(LegendBoxSpec.prototype, 'contentBounds', {\n configurable: true,\n get: function () {\n return new DoubleRectangle(this.contentOrigin, this.contentSize_cb71ch$_0);\n }\n });\n LegendBoxSpec.prototype.hasTitle = function () {\n return !isBlank(this.title);\n };\n LegendBoxSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxSpec',\n interfaces: []\n };\n function LegendBreak(label) {\n LegendBreak$Companion_getInstance();\n this.label = label;\n this.myLayers_0 = ArrayList_init();\n }\n Object.defineProperty(LegendBreak.prototype, 'minimumKeySize', {\n configurable: true,\n get: function () {\n var tmp$;\n var minSize = DoubleVector.Companion.ZERO;\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var layerMinKeySize = layer.keyElementFactory.minimumKeySize_l6g9mh$(layer.dataPoint);\n minSize = minSize.max_gpjtzr$(layerMinKeySize);\n }\n return minSize;\n }\n });\n Object.defineProperty(LegendBreak.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return this.myLayers_0.isEmpty();\n }\n });\n LegendBreak.prototype.addLayer_w0u015$ = function (dataPoint, keyElementFactory) {\n this.myLayers_0.add_11rb$(new LegendBreak$LegendBreakLayer(dataPoint, keyElementFactory));\n };\n LegendBreak.prototype.createKeyElement_gpjtzr$ = function (size) {\n var tmp$;\n var g = new SvgGElement();\n tmp$ = this.myLayers_0.iterator();\n while (tmp$.hasNext()) {\n var layer = tmp$.next();\n var keyElement = layer.keyElementFactory.createKeyElement_s1fn0c$(layer.dataPoint, size);\n g.children().add_11rb$(keyElement);\n }\n return g;\n };\n function LegendBreak$LegendBreakLayer(dataPoint, keyElementFactory) {\n this.dataPoint = dataPoint;\n this.keyElementFactory = keyElementFactory;\n }\n LegendBreak$LegendBreakLayer.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBreakLayer',\n interfaces: []\n };\n function LegendBreak$Companion() {\n LegendBreak$Companion_instance = this;\n }\n LegendBreak$Companion.prototype.simple_998ysp$ = function (label, dataPoint, keyElementFactory) {\n var br = new LegendBreak(label);\n br.addLayer_w0u015$(dataPoint, keyElementFactory);\n return br;\n };\n LegendBreak$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBreak$Companion_instance = null;\n function LegendBreak$Companion_getInstance() {\n if (LegendBreak$Companion_instance === null) {\n new LegendBreak$Companion();\n }return LegendBreak$Companion_instance;\n }\n LegendBreak.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBreak',\n interfaces: []\n };\n function LegendComponent(spec) {\n LegendBox.call(this);\n this.spec_8zhhsr$_0 = spec;\n }\n Object.defineProperty(LegendComponent.prototype, 'spec', {\n get: function () {\n return this.spec_8zhhsr$_0;\n }\n });\n LegendComponent.prototype.appendGuideContent_26jijc$ = function (contentRoot) {\n var tmp$;\n var layout = this.spec.layout;\n var keyLabelBoxes = layout.keyLabelBoxes.iterator();\n var labelBoxes = layout.labelBoxes.iterator();\n tmp$ = this.spec.breaks_8be2vx$.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var keyLabelBox = keyLabelBoxes.next();\n var labelBox = labelBoxes.next();\n var breakElement = this.createBreakElement_0(br, layout.keySize, keyLabelBox, labelBox);\n contentRoot.children().add_11rb$(breakElement);\n }\n return layout.size;\n };\n LegendComponent.prototype.createBreakElement_0 = function (br, keySize, keyLabelBox, labelBox) {\n var breakComponent = new GroupComponent();\n breakComponent.add_26jijc$(this.createKeyElement_0(br, keySize));\n var label = new TextLabel(br.label);\n label.setHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.LEFT);\n label.setVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.CENTER);\n label.moveTo_gpjtzr$(labelBox.origin.add_gpjtzr$(new DoubleVector(0.0, labelBox.height / 2)));\n breakComponent.add_8icvvv$(label);\n breakComponent.moveTo_gpjtzr$(keyLabelBox.origin);\n return breakComponent.rootGroup;\n };\n LegendComponent.prototype.createKeyElement_0 = function (legendBreak, size) {\n var g = new SvgGElement();\n var innerSize = new DoubleVector(size.x - 2, size.y - 2);\n var backgroundFill = this.spec.theme.backgroundFill();\n var backgroundRect = SvgRectElement_init_0(1.0, 1.0, innerSize.x, innerSize.y);\n backgroundRect.strokeWidth().set_11rb$(1.0);\n backgroundRect.strokeColor().set_11rb$(backgroundFill);\n backgroundRect.fillColor().set_11rb$(backgroundFill);\n g.children().add_11rb$(backgroundRect);\n var keyElement = legendBreak.createKeyElement_gpjtzr$(innerSize);\n var keyElementTransform = SvgComponent.Companion.buildTransform_e1sv3v$(new DoubleVector(1.0, 1.0), 0.0);\n keyElement.transform().set_11rb$(keyElementTransform);\n g.children().add_11rb$(keyElement);\n var frame = SvgRectElement_init_0(0.0, 0.0, size.x, size.y);\n frame.strokeWidth().set_11rb$(1.0);\n frame.strokeColor().set_11rb$(backgroundFill);\n frame.fill().set_11rb$(SvgColors.NONE);\n g.children().add_11rb$(frame);\n return g;\n };\n LegendComponent.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponent',\n interfaces: [LegendBox]\n };\n function LegendComponentLayout(title, breaks, keySize, legendDirection) {\n LegendComponentLayout$Companion_getInstance();\n LegendBoxLayout.call(this, title, legendDirection);\n this.breaks = breaks;\n this.keySize = keySize;\n this.myContentSize_8rvo9o$_0 = null;\n this.myKeyLabelBoxes_uk7fn2$_0 = ArrayList_init();\n this.myLabelBoxes_9jhh53$_0 = ArrayList_init();\n this.isFillByRow = false;\n this.rowCount_kvp0d1$_0 = 0;\n this.colCount_nojzuj$_0 = 0;\n }\n Object.defineProperty(LegendComponentLayout.prototype, 'rowCount', {\n configurable: true,\n get: function () {\n return this.rowCount_kvp0d1$_0;\n },\n set: function (rowCount) {\n if (!(rowCount > 0)) {\n var message = 'Row count must be greater than 0, was ' + rowCount;\n throw IllegalStateException_init(message.toString());\n }this.rowCount_kvp0d1$_0 = rowCount;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'colCount', {\n configurable: true,\n get: function () {\n return this.colCount_nojzuj$_0;\n },\n set: function (colCount) {\n if (!(colCount > 0)) {\n var message = 'Col count must be greater than 0, was ' + colCount;\n throw IllegalStateException_init(message.toString());\n }this.colCount_nojzuj$_0 = colCount;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'graphSize', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return ensureNotNull(this.myContentSize_8rvo9o$_0);\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'keyLabelBoxes', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return this.myKeyLabelBoxes_uk7fn2$_0;\n }\n });\n Object.defineProperty(LegendComponentLayout.prototype, 'labelBoxes', {\n configurable: true,\n get: function () {\n this.ensureInited_chkycd$_0();\n return this.myLabelBoxes_9jhh53$_0;\n }\n });\n LegendComponentLayout.prototype.ensureInited_chkycd$_0 = function () {\n if (this.myContentSize_8rvo9o$_0 == null) {\n this.doLayout_zctv6z$_0();\n }};\n LegendComponentLayout.prototype.doLayout_zctv6z$_0 = function () {\n var tmp$;\n var labelHeight = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height();\n var labelLeftMargin = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(1) / 2;\n var labelHOffset = this.keySize.x + labelLeftMargin;\n var labelVOffset = (this.keySize.y - labelHeight) / 2;\n var contentOrigin = DoubleVector.Companion.ZERO;\n var breakBoxBounds = null;\n tmp$ = this.breaks;\n for (var i = 0; i !== tmp$.size; ++i) {\n var tmp$_0;\n var labelSize = this.labelSize_za3lpa$(i);\n var breakBoxSize = new DoubleVector(labelHOffset + labelSize.x, this.keySize.y);\n breakBoxBounds = new DoubleRectangle((tmp$_0 = breakBoxBounds != null ? this.breakBoxOrigin_b4d9xv$(i, breakBoxBounds) : null) != null ? tmp$_0 : contentOrigin, breakBoxSize);\n this.myKeyLabelBoxes_uk7fn2$_0.add_11rb$(breakBoxBounds);\n this.myLabelBoxes_9jhh53$_0.add_11rb$(DoubleRectangle_init(labelHOffset, labelVOffset, labelSize.x, labelSize.y));\n }\n this.myContentSize_8rvo9o$_0 = GeometryUtil_getInstance().union_a7nkjf$(new DoubleRectangle(contentOrigin, DoubleVector.Companion.ZERO), this.myKeyLabelBoxes_uk7fn2$_0).dimension;\n };\n function LegendComponentLayout$MyHorizontal(title, breaks, keySize) {\n LegendComponentLayout.call(this, title, breaks, keySize, LegendDirection$HORIZONTAL_getInstance());\n this.colCount = breaks.size;\n this.rowCount = 1;\n }\n LegendComponentLayout$MyHorizontal.prototype.breakBoxOrigin_b4d9xv$ = function (index, prevBreakBoxBounds) {\n return new DoubleVector(prevBreakBoxBounds.right, 0.0);\n };\n LegendComponentLayout$MyHorizontal.prototype.labelSize_za3lpa$ = function (index) {\n var label = this.breaks.get_za3lpa$(index).label;\n return new DoubleVector(LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(label.length), LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n };\n LegendComponentLayout$MyHorizontal.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyHorizontal',\n interfaces: [LegendComponentLayout]\n };\n function LegendComponentLayout$MyHorizontalMultiRow(title, breaks, keySize) {\n LegendComponentLayout$MyMultiRow.call(this, title, breaks, keySize, LegendDirection$HORIZONTAL_getInstance());\n this.colCount = breaks.size;\n this.rowCount = 1;\n }\n LegendComponentLayout$MyHorizontalMultiRow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyHorizontalMultiRow',\n interfaces: [LegendComponentLayout$MyMultiRow]\n };\n function LegendComponentLayout$MyVertical(title, breaks, keySize) {\n LegendComponentLayout$MyMultiRow.call(this, title, breaks, keySize, LegendDirection$VERTICAL_getInstance());\n this.colCount = 1;\n this.rowCount = breaks.size;\n }\n LegendComponentLayout$MyVertical.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyVertical',\n interfaces: [LegendComponentLayout$MyMultiRow]\n };\n function LegendComponentLayout$MyMultiRow(title, breaks, keySize, legendDirection) {\n LegendComponentLayout.call(this, title, breaks, keySize, legendDirection);\n this.myMaxLabelWidth_0 = 0.0;\n var tmp$;\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var br = tmp$.next();\n var a = this.myMaxLabelWidth_0;\n var b = LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.width_za3lpa$(br.label.length);\n this.myMaxLabelWidth_0 = JsMath.max(a, b);\n }\n }\n LegendComponentLayout$MyMultiRow.prototype.breakBoxOrigin_b4d9xv$ = function (index, prevBreakBoxBounds) {\n var tmp$, tmp$_0;\n if (this.isFillByRow) {\n if (index % this.colCount === 0) {\n tmp$ = new DoubleVector(0.0, prevBreakBoxBounds.bottom);\n } else\n tmp$ = new DoubleVector(prevBreakBoxBounds.right, prevBreakBoxBounds.top);\n return tmp$;\n }if (index % this.rowCount === 0) {\n tmp$_0 = new DoubleVector(prevBreakBoxBounds.right, 0.0);\n } else\n tmp$_0 = new DoubleVector(prevBreakBoxBounds.left, prevBreakBoxBounds.bottom);\n return tmp$_0;\n };\n LegendComponentLayout$MyMultiRow.prototype.labelSize_za3lpa$ = function (index) {\n return new DoubleVector(this.myMaxLabelWidth_0, LegendBoxLayout$Companion_getInstance().LABEL_SPEC_8be2vx$.height());\n };\n LegendComponentLayout$MyMultiRow.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyMultiRow',\n interfaces: [LegendComponentLayout]\n };\n function LegendComponentLayout$Companion() {\n LegendComponentLayout$Companion_instance = this;\n }\n LegendComponentLayout$Companion.prototype.horizontal_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyHorizontal(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.prototype.horizontalMultiRow_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyHorizontalMultiRow(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.prototype.vertical_2y8ibu$ = function (title, breaks, keySize) {\n return new LegendComponentLayout$MyVertical(title, breaks, keySize);\n };\n LegendComponentLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendComponentLayout$Companion_instance = null;\n function LegendComponentLayout$Companion_getInstance() {\n if (LegendComponentLayout$Companion_instance === null) {\n new LegendComponentLayout$Companion();\n }return LegendComponentLayout$Companion_instance;\n }\n LegendComponentLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponentLayout',\n interfaces: [LegendBoxLayout]\n };\n function LegendComponentSpec(title, breaks, theme, layout, reverse) {\n LegendBoxSpec.call(this, title, theme, reverse);\n this.breaks_8be2vx$ = breaks;\n this.layout_ebqbgv$_0 = layout;\n }\n Object.defineProperty(LegendComponentSpec.prototype, 'layout', {\n get: function () {\n return this.layout_ebqbgv$_0;\n }\n });\n LegendComponentSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendComponentSpec',\n interfaces: [LegendBoxSpec]\n };\n function LegendDirection(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LegendDirection_initFields() {\n LegendDirection_initFields = function () {\n };\n LegendDirection$HORIZONTAL_instance = new LegendDirection('HORIZONTAL', 0);\n LegendDirection$VERTICAL_instance = new LegendDirection('VERTICAL', 1);\n LegendDirection$AUTO_instance = new LegendDirection('AUTO', 2);\n }\n var LegendDirection$HORIZONTAL_instance;\n function LegendDirection$HORIZONTAL_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$HORIZONTAL_instance;\n }\n var LegendDirection$VERTICAL_instance;\n function LegendDirection$VERTICAL_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$VERTICAL_instance;\n }\n var LegendDirection$AUTO_instance;\n function LegendDirection$AUTO_getInstance() {\n LegendDirection_initFields();\n return LegendDirection$AUTO_instance;\n }\n LegendDirection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendDirection',\n interfaces: [Enum]\n };\n function LegendDirection$values() {\n return [LegendDirection$HORIZONTAL_getInstance(), LegendDirection$VERTICAL_getInstance(), LegendDirection$AUTO_getInstance()];\n }\n LegendDirection.values = LegendDirection$values;\n function LegendDirection$valueOf(name) {\n switch (name) {\n case 'HORIZONTAL':\n return LegendDirection$HORIZONTAL_getInstance();\n case 'VERTICAL':\n return LegendDirection$VERTICAL_getInstance();\n case 'AUTO':\n return LegendDirection$AUTO_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.LegendDirection.' + name);\n }\n }\n LegendDirection.valueOf_61zpoe$ = LegendDirection$valueOf;\n function LegendJustification(x, y) {\n LegendJustification$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n function LegendJustification$Companion() {\n LegendJustification$Companion_instance = this;\n this.CENTER = new LegendJustification(0.5, 0.5);\n }\n LegendJustification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendJustification$Companion_instance = null;\n function LegendJustification$Companion_getInstance() {\n if (LegendJustification$Companion_instance === null) {\n new LegendJustification$Companion();\n }return LegendJustification$Companion_instance;\n }\n LegendJustification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendJustification',\n interfaces: []\n };\n function LegendPosition(x, y) {\n LegendPosition$Companion_getInstance();\n this.x = x;\n this.y = y;\n }\n Object.defineProperty(LegendPosition.prototype, 'isFixed', {\n configurable: true,\n get: function () {\n return this === LegendPosition$Companion_getInstance().LEFT || this === LegendPosition$Companion_getInstance().RIGHT || this === LegendPosition$Companion_getInstance().TOP || this === LegendPosition$Companion_getInstance().BOTTOM;\n }\n });\n Object.defineProperty(LegendPosition.prototype, 'isHidden', {\n configurable: true,\n get: function () {\n return this === LegendPosition$Companion_getInstance().NONE;\n }\n });\n Object.defineProperty(LegendPosition.prototype, 'isOverlay', {\n configurable: true,\n get: function () {\n return !(this.isFixed || this.isHidden);\n }\n });\n function LegendPosition$Companion() {\n LegendPosition$Companion_instance = this;\n this.RIGHT = new LegendPosition(1.0, 0.5);\n this.LEFT = new LegendPosition(0.0, 0.5);\n this.TOP = new LegendPosition(0.5, 1.0);\n this.BOTTOM = new LegendPosition(0.5, 1.0);\n this.NONE = new LegendPosition(kotlin_js_internal_DoubleCompanionObject.NaN, kotlin_js_internal_DoubleCompanionObject.NaN);\n }\n LegendPosition$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendPosition$Companion_instance = null;\n function LegendPosition$Companion_getInstance() {\n if (LegendPosition$Companion_instance === null) {\n new LegendPosition$Companion();\n }return LegendPosition$Companion_instance;\n }\n LegendPosition.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendPosition',\n interfaces: []\n };\n function Orientation(name, ordinal, myValue) {\n Enum.call(this);\n this.myValue_3zu241$_0 = myValue;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function Orientation_initFields() {\n Orientation_initFields = function () {\n };\n Orientation$LEFT_instance = new Orientation('LEFT', 0, 'LEFT');\n Orientation$RIGHT_instance = new Orientation('RIGHT', 1, 'RIGHT');\n Orientation$TOP_instance = new Orientation('TOP', 2, 'TOP');\n Orientation$BOTTOM_instance = new Orientation('BOTTOM', 3, 'BOTTOM');\n }\n var Orientation$LEFT_instance;\n function Orientation$LEFT_getInstance() {\n Orientation_initFields();\n return Orientation$LEFT_instance;\n }\n var Orientation$RIGHT_instance;\n function Orientation$RIGHT_getInstance() {\n Orientation_initFields();\n return Orientation$RIGHT_instance;\n }\n var Orientation$TOP_instance;\n function Orientation$TOP_getInstance() {\n Orientation_initFields();\n return Orientation$TOP_instance;\n }\n var Orientation$BOTTOM_instance;\n function Orientation$BOTTOM_getInstance() {\n Orientation_initFields();\n return Orientation$BOTTOM_instance;\n }\n Object.defineProperty(Orientation.prototype, 'isHorizontal', {\n configurable: true,\n get: function () {\n return this === Orientation$TOP_getInstance() || this === Orientation$BOTTOM_getInstance();\n }\n });\n Orientation.prototype.toString = function () {\n return 'Orientation{' + \"myValue='\" + this.myValue_3zu241$_0 + String.fromCharCode(39) + String.fromCharCode(125);\n };\n Orientation.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Orientation',\n interfaces: [Enum]\n };\n function Orientation$values() {\n return [Orientation$LEFT_getInstance(), Orientation$RIGHT_getInstance(), Orientation$TOP_getInstance(), Orientation$BOTTOM_getInstance()];\n }\n Orientation.values = Orientation$values;\n function Orientation$valueOf(name) {\n switch (name) {\n case 'LEFT':\n return Orientation$LEFT_getInstance();\n case 'RIGHT':\n return Orientation$RIGHT_getInstance();\n case 'TOP':\n return Orientation$TOP_getInstance();\n case 'BOTTOM':\n return Orientation$BOTTOM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.guide.Orientation.' + name);\n }\n }\n Orientation.valueOf_61zpoe$ = Orientation$valueOf;\n function ContextualMappingProvider() {\n ContextualMappingProvider$Companion_getInstance();\n }\n function ContextualMappingProvider$Companion() {\n ContextualMappingProvider$Companion_instance = this;\n this.NONE = new ContextualMappingProvider$Companion$NONE$ObjectLiteral();\n }\n function ContextualMappingProvider$Companion$NONE$ObjectLiteral() {\n }\n ContextualMappingProvider$Companion$NONE$ObjectLiteral.prototype.createContextualMapping_8fr62e$ = function (dataAccess, dataFrame) {\n return new ContextualMapping(emptyList(), null, null, null, false, false, false, false);\n };\n ContextualMappingProvider$Companion$NONE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [ContextualMappingProvider]\n };\n ContextualMappingProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ContextualMappingProvider$Companion_instance = null;\n function ContextualMappingProvider$Companion_getInstance() {\n if (ContextualMappingProvider$Companion_instance === null) {\n new ContextualMappingProvider$Companion();\n }return ContextualMappingProvider$Companion_instance;\n }\n ContextualMappingProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ContextualMappingProvider',\n interfaces: []\n };\n function GeomInteraction(builder) {\n GeomInteraction$Companion_getInstance();\n this.myLocatorLookupSpace_0 = builder.locatorLookupSpace;\n this.myLocatorLookupStrategy_0 = builder.locatorLookupStrategy;\n this.myTooltipLines_0 = builder.tooltipLines;\n this.myTooltipProperties_0 = builder.tooltipProperties;\n this.myIgnoreInvisibleTargets_0 = builder.isIgnoringInvisibleTargets();\n this.myIsCrosshairEnabled_0 = builder.isCrosshairEnabled;\n }\n GeomInteraction.prototype.createLookupSpec = function () {\n return new GeomTargetLocator$LookupSpec(this.myLocatorLookupSpace_0, this.myLocatorLookupStrategy_0);\n };\n GeomInteraction.prototype.createContextualMapping_8fr62e$ = function (dataAccess, dataFrame) {\n var tmp$ = GeomInteraction$Companion_getInstance();\n var $receiver = this.myTooltipLines_0;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(TooltipLine_init(item));\n }\n return tmp$.createContextualMapping_0(destination, dataAccess, dataFrame, this.myTooltipProperties_0, this.myIgnoreInvisibleTargets_0, this.myIsCrosshairEnabled_0);\n };\n function GeomInteraction$Companion() {\n GeomInteraction$Companion_instance = this;\n }\n GeomInteraction$Companion.prototype.createTestContextualMapping_fdc7hd$ = function (aesListForTooltip, axisAes, outliers, dataAccess, dataFrame, userDefinedValueSources) {\n if (userDefinedValueSources === void 0)\n userDefinedValueSources = null;\n var defaultTooltipLines = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(aesListForTooltip, axisAes, outliers, userDefinedValueSources);\n return this.createContextualMapping_0(defaultTooltipLines, dataAccess, dataFrame, TooltipSpecification$TooltipProperties$Companion_getInstance().NONE, false, false);\n };\n GeomInteraction$Companion.prototype.createContextualMapping_0 = function (tooltipLines, dataAccess, dataFrame, tooltipProperties, ignoreInvisibleTargets, isCrosshairEnabled) {\n var dataContext = new DataContext(dataFrame, dataAccess);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = tooltipLines.iterator();\n loop_label: while (tmp$.hasNext()) {\n var element = tmp$.next();\n var $receiver = element.fields;\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n if (Kotlin.isType(element_0, MappingValue))\n destination_0.add_11rb$(element_0);\n }\n var dataAesList = destination_0;\n var all$result;\n all$break: do {\n var tmp$_1;\n if (Kotlin.isType(dataAesList, Collection) && dataAesList.isEmpty()) {\n all$result = true;\n break all$break;\n }tmp$_1 = dataAesList.iterator();\n while (tmp$_1.hasNext()) {\n var element_1 = tmp$_1.next();\n if (!dataAccess.isMapped_896ixz$(element_1.aes)) {\n all$result = false;\n break all$break;\n }}\n all$result = true;\n }\n while (false);\n if (all$result)\n destination.add_11rb$(element);\n }\n var mappedTooltipLines = destination;\n var tmp$_2;\n tmp$_2 = mappedTooltipLines.iterator();\n while (tmp$_2.hasNext()) {\n var element_2 = tmp$_2.next();\n element_2.initDataContext_rxi9tf$(dataContext);\n }\n var any$result;\n any$break: do {\n var tmp$_3;\n if (Kotlin.isType(mappedTooltipLines, Collection) && mappedTooltipLines.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_3 = mappedTooltipLines.iterator();\n loop_label: while (tmp$_3.hasNext()) {\n var element_3 = tmp$_3.next();\n var $receiver_0 = element_3.fields;\n var predicate = getPropertyCallableRef('isOutlier', 1, function ($receiver) {\n return $receiver.isOutlier;\n });\n var none$result;\n none$break: do {\n var tmp$_4;\n if (Kotlin.isType($receiver_0, Collection) && $receiver_0.isEmpty()) {\n none$result = true;\n break none$break;\n }tmp$_4 = $receiver_0.iterator();\n while (tmp$_4.hasNext()) {\n var element_4 = tmp$_4.next();\n if (predicate(element_4)) {\n none$result = false;\n break none$break;\n }}\n none$result = true;\n }\n while (false);\n if (none$result) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n var hasGeneralTooltip = any$result;\n var any$result_0;\n any$break: do {\n var tmp$_5;\n if (Kotlin.isType(mappedTooltipLines, Collection) && mappedTooltipLines.isEmpty()) {\n any$result_0 = false;\n break any$break;\n }tmp$_5 = mappedTooltipLines.iterator();\n loop_label: while (tmp$_5.hasNext()) {\n var element_5 = tmp$_5.next();\n var $receiver_1 = element_5.fields;\n var predicate_0 = getPropertyCallableRef('isAxis', 1, function ($receiver) {\n return $receiver.isAxis;\n });\n var any$result_1;\n any$break_0: do {\n var tmp$_6;\n if (Kotlin.isType($receiver_1, Collection) && $receiver_1.isEmpty()) {\n any$result_1 = false;\n break any$break_0;\n }tmp$_6 = $receiver_1.iterator();\n while (tmp$_6.hasNext()) {\n var element_6 = tmp$_6.next();\n if (predicate_0(element_6)) {\n any$result_1 = true;\n break any$break_0;\n }}\n any$result_1 = false;\n }\n while (false);\n if (any$result_1) {\n any$result_0 = true;\n break any$break;\n }}\n any$result_0 = false;\n }\n while (false);\n var hasAxisTooltip = any$result_0;\n return new ContextualMapping(mappedTooltipLines, tooltipProperties.anchor, tooltipProperties.minWidth, tooltipProperties.color, ignoreInvisibleTargets, hasGeneralTooltip, hasAxisTooltip, isCrosshairEnabled);\n };\n GeomInteraction$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomInteraction$Companion_instance = null;\n function GeomInteraction$Companion_getInstance() {\n if (GeomInteraction$Companion_instance === null) {\n new GeomInteraction$Companion();\n }return GeomInteraction$Companion_instance;\n }\n GeomInteraction.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomInteraction',\n interfaces: [ContextualMappingProvider]\n };\n function GeomInteractionBuilder(mySupportedAesList) {\n GeomInteractionBuilder$Companion_getInstance();\n this.mySupportedAesList_0 = mySupportedAesList;\n this.myIgnoreInvisibleTargets_0 = false;\n this.locatorLookupSpace_3dt62f$_0 = this.locatorLookupSpace_3dt62f$_0;\n this.locatorLookupStrategy_gpx4i$_0 = this.locatorLookupStrategy_gpx4i$_0;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = false;\n this.myAxisTooltipVisibilityFromConfig_0 = null;\n this.myAxisAesFromFunctionKind_0 = null;\n this.myTooltipAxisAes_vm9teg$_0 = this.myTooltipAxisAes_vm9teg$_0;\n this.myTooltipAes_um80ux$_0 = this.myTooltipAes_um80ux$_0;\n this.myTooltipOutlierAesList_r7qit3$_0 = this.myTooltipOutlierAesList_r7qit3$_0;\n this.myTooltipConstantsAesList_0 = null;\n this.myUserTooltipSpec_0 = null;\n this.myIsCrosshairEnabled_0 = false;\n }\n Object.defineProperty(GeomInteractionBuilder.prototype, 'locatorLookupSpace', {\n configurable: true,\n get: function () {\n if (this.locatorLookupSpace_3dt62f$_0 == null)\n return throwUPAE('locatorLookupSpace');\n return this.locatorLookupSpace_3dt62f$_0;\n },\n set: function (locatorLookupSpace) {\n this.locatorLookupSpace_3dt62f$_0 = locatorLookupSpace;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'locatorLookupStrategy', {\n configurable: true,\n get: function () {\n if (this.locatorLookupStrategy_gpx4i$_0 == null)\n return throwUPAE('locatorLookupStrategy');\n return this.locatorLookupStrategy_gpx4i$_0;\n },\n set: function (locatorLookupStrategy) {\n this.locatorLookupStrategy_gpx4i$_0 = locatorLookupStrategy;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipAxisAes_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipAxisAes_vm9teg$_0 == null)\n return throwUPAE('myTooltipAxisAes');\n return this.myTooltipAxisAes_vm9teg$_0;\n },\n set: function (myTooltipAxisAes) {\n this.myTooltipAxisAes_vm9teg$_0 = myTooltipAxisAes;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipAes_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipAes_um80ux$_0 == null)\n return throwUPAE('myTooltipAes');\n return this.myTooltipAes_um80ux$_0;\n },\n set: function (myTooltipAes) {\n this.myTooltipAes_um80ux$_0 = myTooltipAes;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'myTooltipOutlierAesList_0', {\n configurable: true,\n get: function () {\n if (this.myTooltipOutlierAesList_r7qit3$_0 == null)\n return throwUPAE('myTooltipOutlierAesList');\n return this.myTooltipOutlierAesList_r7qit3$_0;\n },\n set: function (myTooltipOutlierAesList) {\n this.myTooltipOutlierAesList_r7qit3$_0 = myTooltipOutlierAesList;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'getAxisFromFunctionKind', {\n configurable: true,\n get: function () {\n var tmp$;\n return (tmp$ = this.myAxisAesFromFunctionKind_0) != null ? tmp$ : emptyList();\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'isAxisTooltipEnabled', {\n configurable: true,\n get: function () {\n return this.myAxisTooltipVisibilityFromConfig_0 == null ? this.myAxisTooltipVisibilityFromFunctionKind_0 : ensureNotNull(this.myAxisTooltipVisibilityFromConfig_0);\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'tooltipLines', {\n configurable: true,\n get: function () {\n return this.prepareTooltipValueSources_0();\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'tooltipProperties', {\n configurable: true,\n get: function () {\n var tmp$, tmp$_0;\n return (tmp$_0 = (tmp$ = this.myUserTooltipSpec_0) != null ? tmp$.tooltipProperties : null) != null ? tmp$_0 : TooltipSpecification$TooltipProperties$Companion_getInstance().NONE;\n }\n });\n Object.defineProperty(GeomInteractionBuilder.prototype, 'isCrosshairEnabled', {\n configurable: true,\n get: function () {\n return this.myIsCrosshairEnabled_0;\n }\n });\n GeomInteractionBuilder.prototype.showAxisTooltip_6taknv$ = function (isTrue) {\n this.myAxisTooltipVisibilityFromConfig_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipAes_3lrecq$ = function (aes) {\n this.myTooltipAes_0 = aes;\n return this;\n };\n GeomInteractionBuilder.prototype.axisAes_3lrecq$ = function (axisAes) {\n this.myTooltipAxisAes_0 = axisAes;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipOutliers_3lrecq$ = function (aes) {\n this.myTooltipOutlierAesList_0 = aes;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipConstants_ayg7dr$ = function (constantsMap) {\n this.myTooltipConstantsAesList_0 = constantsMap;\n return this;\n };\n GeomInteractionBuilder.prototype.tooltipLinesSpec_uvmyj9$ = function (tooltipSpec) {\n this.myUserTooltipSpec_0 = tooltipSpec;\n return this;\n };\n GeomInteractionBuilder.prototype.setIsCrosshairEnabled_6taknv$ = function (isTrue) {\n this.myIsCrosshairEnabled_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.multilayerLookupStrategy = function () {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NEAREST;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.XY;\n return this;\n };\n GeomInteractionBuilder.prototype.univariateFunction_7k7ojo$ = function (lookupStrategy) {\n this.myAxisAesFromFunctionKind_0 = GeomInteractionBuilder$Companion_getInstance().AES_X_0;\n this.locatorLookupStrategy = lookupStrategy;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.X;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.bivariateFunction_6taknv$ = function (area) {\n this.myAxisAesFromFunctionKind_0 = GeomInteractionBuilder$Companion_getInstance().AES_XY_0;\n if (area) {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.HOVER;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = false;\n } else {\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NEAREST;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n }\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.XY;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.none = function () {\n this.myAxisAesFromFunctionKind_0 = ArrayList_init_1(this.mySupportedAesList_0);\n this.locatorLookupStrategy = GeomTargetLocator$LookupStrategy.NONE;\n this.myAxisTooltipVisibilityFromFunctionKind_0 = true;\n this.locatorLookupSpace = GeomTargetLocator$LookupSpace.NONE;\n this.initDefaultTooltips_0();\n return this;\n };\n GeomInteractionBuilder.prototype.initDefaultTooltips_0 = function () {\n this.myTooltipAxisAes_0 = !this.isAxisTooltipEnabled ? emptyList() : this.getAxisFromFunctionKind;\n this.myTooltipAes_0 = minus(this.mySupportedAesList_0, this.getAxisFromFunctionKind);\n this.myTooltipOutlierAesList_0 = emptyList();\n };\n GeomInteractionBuilder.prototype.prepareTooltipValueSources_0 = function () {\n var tmp$;\n if (this.myUserTooltipSpec_0 == null)\n tmp$ = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0, this.myTooltipAxisAes_0, this.myTooltipOutlierAesList_0, null, this.myTooltipConstantsAesList_0);\n else if (ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns == null)\n tmp$ = GeomInteractionBuilder$Companion_getInstance().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0, this.myTooltipAxisAes_0, this.myTooltipOutlierAesList_0, ensureNotNull(this.myUserTooltipSpec_0).valueSources, this.myTooltipConstantsAesList_0);\n else if (ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns).isEmpty())\n tmp$ = emptyList();\n else {\n var geomOutliers = toMutableList(this.myTooltipOutlierAesList_0);\n var tmp$_0;\n tmp$_0 = ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns).iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var $receiver = element.fields;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (Kotlin.isType(element_0, MappingValue))\n destination.add_11rb$(element_0);\n }\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(item.aes);\n }\n var userDataAesList = destination_0;\n geomOutliers.removeAll_brywnq$(userDataAesList);\n }\n var $receiver_0 = this.myTooltipAxisAes_0;\n var destination_1 = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_3;\n tmp$_3 = $receiver_0.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_1.add_11rb$(new MappingValue(item_0, true, true));\n }\n var axisValueSources = destination_1;\n var destination_2 = ArrayList_init_0(collectionSizeOrDefault(geomOutliers, 10));\n var tmp$_4;\n tmp$_4 = geomOutliers.iterator();\n while (tmp$_4.hasNext()) {\n var item_1 = tmp$_4.next();\n var tmp$_5 = destination_2.add_11rb$;\n var tmp$_6;\n var $receiver_1 = ensureNotNull(this.myUserTooltipSpec_0).valueSources;\n var destination_3 = ArrayList_init();\n var tmp$_7;\n tmp$_7 = $receiver_1.iterator();\n while (tmp$_7.hasNext()) {\n var element_1 = tmp$_7.next();\n if (Kotlin.isType(element_1, MappingValue))\n destination_3.add_11rb$(element_1);\n }\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_8;\n tmp$_8 = destination_3.iterator();\n while (tmp$_8.hasNext()) {\n var element_2 = tmp$_8.next();\n if (equals(element_2.aes, item_1)) {\n firstOrNull$result = element_2;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var formatted = firstOrNull$result;\n tmp$_5.call(destination_2, (tmp$_6 = formatted != null ? formatted.toOutlier() : null) != null ? tmp$_6 : new MappingValue(item_1, true));\n }\n var geomOutlierValueSources = destination_2;\n var tmp$_9 = ensureNotNull(ensureNotNull(this.myUserTooltipSpec_0).tooltipLinePatterns);\n var $receiver_2 = plus(axisValueSources, geomOutlierValueSources);\n var transform = getCallableRef('defaultLineForValueSource', function ($receiver, p1) {\n return $receiver.defaultLineForValueSource_u47np3$(p1);\n }.bind(null, TooltipLine$Companion_getInstance()));\n var destination_4 = ArrayList_init_0(collectionSizeOrDefault($receiver_2, 10));\n var tmp$_10;\n tmp$_10 = $receiver_2.iterator();\n while (tmp$_10.hasNext()) {\n var item_2 = tmp$_10.next();\n destination_4.add_11rb$(transform(item_2));\n }\n tmp$ = plus(tmp$_9, destination_4);\n }\n return tmp$;\n };\n GeomInteractionBuilder.prototype.build = function () {\n return new GeomInteraction(this);\n };\n GeomInteractionBuilder.prototype.ignoreInvisibleTargets_6taknv$ = function (isTrue) {\n this.myIgnoreInvisibleTargets_0 = isTrue;\n return this;\n };\n GeomInteractionBuilder.prototype.isIgnoringInvisibleTargets = function () {\n return this.myIgnoreInvisibleTargets_0;\n };\n function GeomInteractionBuilder$Companion() {\n GeomInteractionBuilder$Companion_instance = this;\n this.AREA_GEOM = true;\n this.NON_AREA_GEOM = false;\n this.AES_X_0 = listOf(Aes.Companion.X);\n this.AES_XY_0 = listOf_0([Aes.Companion.X, Aes.Companion.Y]);\n }\n GeomInteractionBuilder$Companion.prototype.defaultValueSourceTooltipLines_dnbe1t$ = function (aesListForTooltip, axisAes, outliers, userDefinedValueSources, constantsMap) {\n if (userDefinedValueSources === void 0)\n userDefinedValueSources = null;\n if (constantsMap === void 0)\n constantsMap = null;\n var tmp$;\n var destination = ArrayList_init_0(collectionSizeOrDefault(axisAes, 10));\n var tmp$_0;\n tmp$_0 = axisAes.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(new MappingValue(item, true, true));\n }\n var axisValueSources = destination;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(outliers, 10));\n var tmp$_1;\n tmp$_1 = outliers.iterator();\n while (tmp$_1.hasNext()) {\n var item_0 = tmp$_1.next();\n var tmp$_2 = destination_0.add_11rb$;\n var tmp$_3, tmp$_4;\n var tmp$_5;\n if (userDefinedValueSources != null) {\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = userDefinedValueSources.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n if (Kotlin.isType(element, MappingValue))\n destination_1.add_11rb$(element);\n }\n tmp$_5 = destination_1;\n } else\n tmp$_5 = null;\n var tmp$_7;\n if ((tmp$_3 = tmp$_5) != null) {\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_8;\n tmp$_8 = tmp$_3.iterator();\n while (tmp$_8.hasNext()) {\n var element_0 = tmp$_8.next();\n if (equals(element_0.aes, item_0)) {\n firstOrNull$result = element_0;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n tmp$_7 = firstOrNull$result;\n } else\n tmp$_7 = null;\n var userDefined = tmp$_7;\n tmp$_2.call(destination_0, (tmp$_4 = userDefined != null ? userDefined.toOutlier() : null) != null ? tmp$_4 : new MappingValue(item_0, true));\n }\n var outlierValueSources = destination_0;\n var destination_2 = ArrayList_init_0(collectionSizeOrDefault(aesListForTooltip, 10));\n var tmp$_9;\n tmp$_9 = aesListForTooltip.iterator();\n while (tmp$_9.hasNext()) {\n var item_1 = tmp$_9.next();\n var tmp$_10 = destination_2.add_11rb$;\n var tmp$_11;\n var tmp$_12;\n if (userDefinedValueSources != null) {\n var destination_3 = ArrayList_init();\n var tmp$_13;\n tmp$_13 = userDefinedValueSources.iterator();\n while (tmp$_13.hasNext()) {\n var element_1 = tmp$_13.next();\n if (Kotlin.isType(element_1, MappingValue))\n destination_3.add_11rb$(element_1);\n }\n tmp$_12 = destination_3;\n } else\n tmp$_12 = null;\n var tmp$_14;\n if ((tmp$_11 = tmp$_12) != null) {\n var firstOrNull$result_0;\n firstOrNull$break: do {\n var tmp$_15;\n tmp$_15 = tmp$_11.iterator();\n while (tmp$_15.hasNext()) {\n var element_2 = tmp$_15.next();\n if (equals(element_2.aes, item_1)) {\n firstOrNull$result_0 = element_2;\n break firstOrNull$break;\n }}\n firstOrNull$result_0 = null;\n }\n while (false);\n tmp$_14 = firstOrNull$result_0;\n } else\n tmp$_14 = null;\n var userDefined_0 = tmp$_14;\n tmp$_10.call(destination_2, userDefined_0 != null ? userDefined_0 : new MappingValue(item_1));\n }\n var aesValueSources = destination_2;\n var tmp$_16;\n if (constantsMap != null) {\n var destination_4 = ArrayList_init_0(constantsMap.size);\n var tmp$_17;\n tmp$_17 = constantsMap.entries.iterator();\n while (tmp$_17.hasNext()) {\n var item_2 = tmp$_17.next();\n var tmp$_18 = destination_4.add_11rb$;\n var value = item_2.value;\n tmp$_18.call(destination_4, new ConstantValue(value, null));\n }\n tmp$_16 = destination_4;\n } else\n tmp$_16 = null;\n var constantValues = (tmp$ = tmp$_16) != null ? tmp$ : emptyList();\n var $receiver = plus(plus(plus(aesValueSources, axisValueSources), outlierValueSources), constantValues);\n var transform = getCallableRef('defaultLineForValueSource', function ($receiver, p1) {\n return $receiver.defaultLineForValueSource_u47np3$(p1);\n }.bind(null, TooltipLine$Companion_getInstance()));\n var destination_5 = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_19;\n tmp$_19 = $receiver.iterator();\n while (tmp$_19.hasNext()) {\n var item_3 = tmp$_19.next();\n destination_5.add_11rb$(transform(item_3));\n }\n return destination_5;\n };\n GeomInteractionBuilder$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GeomInteractionBuilder$Companion_instance = null;\n function GeomInteractionBuilder$Companion_getInstance() {\n if (GeomInteractionBuilder$Companion_instance === null) {\n new GeomInteractionBuilder$Companion();\n }return GeomInteractionBuilder$Companion_instance;\n }\n GeomInteractionBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GeomInteractionBuilder',\n interfaces: []\n };\n function MathUtil() {\n MathUtil_instance = this;\n }\n MathUtil.prototype.polygonContainsCoordinate_sz9prc$ = function (points, coord) {\n var tmp$;\n var intersectionCount = 0;\n tmp$ = points.size;\n for (var i = 1; i < tmp$; i++) {\n var start = points.get_za3lpa$(i - 1 | 0);\n var end = points.get_za3lpa$(i);\n if (start.y >= coord.y && end.y >= coord.y || (start.y < coord.y && end.y < coord.y)) {\n continue;\n }var x = start.x + (coord.y - start.y) * (end.x - start.x) / (end.y - start.y);\n if (x <= coord.x) {\n intersectionCount = intersectionCount + 1 | 0;\n }}\n return intersectionCount % 2 !== 0;\n };\n MathUtil.prototype.liesOnSegment_e9v9yt$ = function (p1, p2, c, epsilon) {\n return (new DoubleSegment(p1, p2)).distance_gpjtzr$(c) < epsilon;\n };\n MathUtil.prototype.areEqual_f1g2it$ = function (p1, p2, epsilon) {\n return p1.subtract_gpjtzr$(p2).length() < epsilon;\n };\n MathUtil.prototype.areEqual_hln2n9$ = function (a, b, epsilon) {\n var x = a - b;\n return JsMath.abs(x) < epsilon;\n };\n MathUtil.prototype.distance_l9poh5$ = function (p1, p2) {\n return (new DoubleSegment(p1, p2)).length();\n };\n MathUtil.prototype.subtractX_l3ea4i$ = function (v, x) {\n return new DoubleVector(v.x - x, v.y);\n };\n MathUtil.prototype.addX_l3ea4i$ = function (v, x) {\n return new DoubleVector(v.x + x, v.y);\n };\n MathUtil.prototype.leftEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.top), new DoubleVector(rect.left, rect.bottom));\n };\n MathUtil.prototype.topEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.top), new DoubleVector(rect.right, rect.top));\n };\n MathUtil.prototype.rightEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.right, rect.top), new DoubleVector(rect.right, rect.bottom));\n };\n MathUtil.prototype.bottomEdgeOf_wthzt5$ = function (rect) {\n return new DoubleSegment(new DoubleVector(rect.left, rect.bottom), new DoubleVector(rect.right, rect.bottom));\n };\n function MathUtil$ClosestPointChecker(target) {\n this.target = target;\n this.distance_pberzz$_0 = -1.0;\n this.coord_ovwx85$_0 = null;\n }\n Object.defineProperty(MathUtil$ClosestPointChecker.prototype, 'distance', {\n configurable: true,\n get: function () {\n return this.distance_pberzz$_0;\n },\n set: function (distance) {\n this.distance_pberzz$_0 = distance;\n }\n });\n Object.defineProperty(MathUtil$ClosestPointChecker.prototype, 'coord', {\n configurable: true,\n get: function () {\n return this.coord_ovwx85$_0;\n },\n set: function (coord) {\n this.coord_ovwx85$_0 = coord;\n }\n });\n MathUtil$ClosestPointChecker.prototype.check_gpjtzr$ = function (coord) {\n var cmpResult = this.compare_gpjtzr$(coord);\n return cmpResult === MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance() || cmpResult === MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n };\n MathUtil$ClosestPointChecker.prototype.compare_gpjtzr$ = function (coord) {\n var newDistance = MathUtil_getInstance().distance_l9poh5$(this.target, coord);\n if (this.distance < 0) {\n this.setNewClosestCoord_0(coord, newDistance);\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n }if (this.distance < newDistance) {\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n }if (this.distance === newDistance) {\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n }this.setNewClosestCoord_0(coord, newDistance);\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n };\n MathUtil$ClosestPointChecker.prototype.setNewClosestCoord_0 = function (coord, distance) {\n this.distance = distance;\n this.coord = coord;\n };\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields = function () {\n };\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('NEW_CLOSER', 0);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('NEW_FARTHER', 1);\n MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance = new MathUtil$ClosestPointChecker$COMPARISON_RESULT('EQUAL', 2);\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_instance;\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_instance;\n }\n var MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance() {\n MathUtil$ClosestPointChecker$COMPARISON_RESULT_initFields();\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_instance;\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'COMPARISON_RESULT',\n interfaces: [Enum]\n };\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$values() {\n return [MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance(), MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance(), MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance()];\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.values = MathUtil$ClosestPointChecker$COMPARISON_RESULT$values;\n function MathUtil$ClosestPointChecker$COMPARISON_RESULT$valueOf(name) {\n switch (name) {\n case 'NEW_CLOSER':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance();\n case 'NEW_FARTHER':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n case 'EQUAL':\n return MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker.COMPARISON_RESULT.' + name);\n }\n }\n MathUtil$ClosestPointChecker$COMPARISON_RESULT.valueOf_61zpoe$ = MathUtil$ClosestPointChecker$COMPARISON_RESULT$valueOf;\n MathUtil$ClosestPointChecker.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ClosestPointChecker',\n interfaces: []\n };\n function MathUtil$MathUtil$ClosestPointChecker_init(x, y, $this) {\n $this = $this || Object.create(MathUtil$ClosestPointChecker.prototype);\n MathUtil$ClosestPointChecker.call($this, new DoubleVector(x, y));\n return $this;\n }\n function MathUtil$DoubleRange(myStart, myLength) {\n MathUtil$DoubleRange$Companion_getInstance();\n this.myStart_0 = myStart;\n this.myLength_0 = myLength;\n if (this.myLength_0 < 0) {\n throw IllegalStateException_init('Length should be positive');\n }}\n MathUtil$DoubleRange.prototype.length = function () {\n return this.myLength_0;\n };\n MathUtil$DoubleRange.prototype.overlaps_oqgc3u$ = function (v) {\n return this.start() <= v.end() && v.start() <= this.end();\n };\n MathUtil$DoubleRange.prototype.inside_oqgc3u$ = function (v) {\n return this.start() >= v.start() && this.end() <= v.end();\n };\n MathUtil$DoubleRange.prototype.contains_14dthe$ = function (value) {\n return value >= this.start() && value <= this.end();\n };\n MathUtil$DoubleRange.prototype.start = function () {\n return this.myStart_0;\n };\n MathUtil$DoubleRange.prototype.end = function () {\n return this.myStart_0 + this.length();\n };\n MathUtil$DoubleRange.prototype.move_14dthe$ = function (delta) {\n return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() + delta, this.length());\n };\n MathUtil$DoubleRange.prototype.moveLeft_14dthe$ = function (delta) {\n if (delta < 0) {\n throw IllegalStateException_init('Value should be positive');\n }return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() - delta, this.length());\n };\n MathUtil$DoubleRange.prototype.moveRight_14dthe$ = function (delta) {\n if (delta < 0) {\n throw IllegalStateException_init('Value should be positive');\n }return MathUtil$DoubleRange$Companion_getInstance().withStartAndLength_lu1900$(this.start() + delta, this.length());\n };\n function MathUtil$DoubleRange$Companion() {\n MathUtil$DoubleRange$Companion_instance = this;\n }\n MathUtil$DoubleRange$Companion.prototype.withStartAndEnd_lu1900$ = function (start, end) {\n var rangeStart = JsMath.min(start, end);\n var rangeLength = JsMath.max(start, end) - rangeStart;\n return new MathUtil$DoubleRange(rangeStart, rangeLength);\n };\n MathUtil$DoubleRange$Companion.prototype.withStartAndLength_lu1900$ = function (start, length) {\n return new MathUtil$DoubleRange(start, length);\n };\n MathUtil$DoubleRange$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var MathUtil$DoubleRange$Companion_instance = null;\n function MathUtil$DoubleRange$Companion_getInstance() {\n if (MathUtil$DoubleRange$Companion_instance === null) {\n new MathUtil$DoubleRange$Companion();\n }return MathUtil$DoubleRange$Companion_instance;\n }\n MathUtil$DoubleRange.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleRange',\n interfaces: []\n };\n MathUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MathUtil',\n interfaces: []\n };\n var MathUtil_instance = null;\n function MathUtil_getInstance() {\n if (MathUtil_instance === null) {\n new MathUtil();\n }return MathUtil_instance;\n }\n function TooltipSpec(layoutHint, lines, fill, isOutlier, anchor, minWidth, isCrosshairEnabled) {\n if (anchor === void 0)\n anchor = null;\n if (minWidth === void 0)\n minWidth = null;\n if (isCrosshairEnabled === void 0)\n isCrosshairEnabled = false;\n this.layoutHint = layoutHint;\n this.fill = fill;\n this.isOutlier = isOutlier;\n this.anchor = anchor;\n this.minWidth = minWidth;\n this.isCrosshairEnabled = isCrosshairEnabled;\n this.lines = ArrayList_init_1(lines);\n }\n TooltipSpec.prototype.toString = function () {\n var tmp$ = 'TooltipSpec(' + this.layoutHint + ', lines=';\n var $receiver = this.lines;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(item.toString());\n }\n return tmp$ + destination + ')';\n };\n function TooltipSpec$Line(label, value) {\n TooltipSpec$Line$Companion_getInstance();\n this.label = label;\n this.value = value;\n }\n TooltipSpec$Line.prototype.toString = function () {\n var $receiver = this.label;\n return $receiver == null || $receiver.length === 0 ? this.value : toString(this.label) + ': ' + this.value;\n };\n function TooltipSpec$Line$Companion() {\n TooltipSpec$Line$Companion_instance = this;\n }\n TooltipSpec$Line$Companion.prototype.withValue_61zpoe$ = function (value) {\n return new TooltipSpec$Line(null, value);\n };\n TooltipSpec$Line$Companion.prototype.withLabelAndValue_f5e6j7$ = function (label, value) {\n return new TooltipSpec$Line(label, value);\n };\n TooltipSpec$Line$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpec$Line$Companion_instance = null;\n function TooltipSpec$Line$Companion_getInstance() {\n if (TooltipSpec$Line$Companion_instance === null) {\n new TooltipSpec$Line$Companion();\n }return TooltipSpec$Line$Companion_instance;\n }\n TooltipSpec$Line.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Line',\n interfaces: []\n };\n TooltipSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpec',\n interfaces: []\n };\n function TooltipSpecFactory(contextualMapping, axisOrigin) {\n this.contextualMapping_0 = contextualMapping;\n this.axisOrigin_0 = axisOrigin;\n }\n TooltipSpecFactory.prototype.create_62opr5$ = function (geomTarget) {\n return ArrayList_init_1((new TooltipSpecFactory$Helper(this, geomTarget)).createTooltipSpecs_8be2vx$());\n };\n function TooltipSpecFactory$Helper($outer, myGeomTarget) {\n this.$outer = $outer;\n this.myGeomTarget_0 = myGeomTarget;\n this.myDataPoints_0 = this.$outer.contextualMapping_0.getDataPoints_za3lpa$(this.hitIndex_0());\n this.myTooltipAnchor_0 = this.$outer.contextualMapping_0.tooltipAnchor;\n this.myTooltipMinWidth_0 = this.$outer.contextualMapping_0.tooltipMinWidth;\n this.myTooltipColor_0 = this.$outer.contextualMapping_0.tooltipColor;\n this.myIsCrosshairEnabled_0 = this.$outer.contextualMapping_0.isCrosshairEnabled;\n }\n TooltipSpecFactory$Helper.prototype.createTooltipSpecs_8be2vx$ = function () {\n var tooltipSpecs = ArrayList_init();\n addAll(tooltipSpecs, this.outlierTooltipSpec_0());\n addAll(tooltipSpecs, this.generalTooltipSpec_0());\n addAll(tooltipSpecs, this.axisTooltipSpec_0());\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.hitIndex_0 = function () {\n return this.myGeomTarget_0.hitIndex;\n };\n TooltipSpecFactory$Helper.prototype.tipLayoutHint_0 = function () {\n return this.myGeomTarget_0.tipLayoutHint;\n };\n TooltipSpecFactory$Helper.prototype.outlierHints_0 = function () {\n return this.myGeomTarget_0.aesTipLayoutHints;\n };\n TooltipSpecFactory$Helper.prototype.hintColors_0 = function () {\n var $receiver = this.myGeomTarget_0.aesTipLayoutHints;\n var destination = ArrayList_init_0($receiver.size);\n var tmp$;\n tmp$ = $receiver.entries.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(to(item.key, item.value.color));\n }\n return toMap(destination);\n };\n TooltipSpecFactory$Helper.prototype.outlierTooltipSpec_0 = function () {\n var tooltipSpecs = ArrayList_init();\n var outlierDataPoints = this.outlierDataPoints_0();\n var tmp$;\n tmp$ = this.outlierHints_0().entries.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var aes = element.key;\n var hint = element.value;\n var tmp$_0;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = outlierDataPoints.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (equals(aes, element_0.aes))\n destination.add_11rb$(element_0);\n }\n var transform = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(transform(item));\n }\n var transform_0 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_1 = ArrayList_init_0(collectionSizeOrDefault(destination_0, 10));\n var tmp$_3;\n tmp$_3 = destination_0.iterator();\n while (tmp$_3.hasNext()) {\n var item_0 = tmp$_3.next();\n destination_1.add_11rb$(transform_0(item_0));\n }\n var linesForAes = destination_1;\n if (!linesForAes.isEmpty()) {\n tooltipSpecs.add_11rb$(new TooltipSpec(hint, linesForAes, (tmp$_0 = hint.color) != null ? tmp$_0 : ensureNotNull(this.tipLayoutHint_0().color), true));\n }}\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.axisTooltipSpec_0 = function () {\n var tooltipSpecs = ArrayList_init();\n var tmp$ = Aes.Companion.X;\n var $receiver = this.axisDataPoints_0();\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (equals(Aes.Companion.X, element.aes))\n destination.add_11rb$(element);\n }\n var transform = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(transform(item));\n }\n var transform_0 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_1 = ArrayList_init_0(collectionSizeOrDefault(destination_0, 10));\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_1.add_11rb$(transform_0(item_0));\n }\n var tmp$_3 = to(tmp$, destination_1);\n var tmp$_4 = Aes.Companion.Y;\n var $receiver_0 = this.axisDataPoints_0();\n var destination_2 = ArrayList_init();\n var tmp$_5;\n tmp$_5 = $receiver_0.iterator();\n while (tmp$_5.hasNext()) {\n var element_0 = tmp$_5.next();\n if (equals(Aes.Companion.Y, element_0.aes))\n destination_2.add_11rb$(element_0);\n }\n var transform_1 = getPropertyCallableRef('value', 1, function ($receiver) {\n return $receiver.value;\n });\n var destination_3 = ArrayList_init_0(collectionSizeOrDefault(destination_2, 10));\n var tmp$_6;\n tmp$_6 = destination_2.iterator();\n while (tmp$_6.hasNext()) {\n var item_1 = tmp$_6.next();\n destination_3.add_11rb$(transform_1(item_1));\n }\n var transform_2 = getCallableRef('withValue', function ($receiver, p1) {\n return $receiver.withValue_61zpoe$(p1);\n }.bind(null, TooltipSpec$Line$Companion_getInstance()));\n var destination_4 = ArrayList_init_0(collectionSizeOrDefault(destination_3, 10));\n var tmp$_7;\n tmp$_7 = destination_3.iterator();\n while (tmp$_7.hasNext()) {\n var item_2 = tmp$_7.next();\n destination_4.add_11rb$(transform_2(item_2));\n }\n var axis = mapOf([tmp$_3, to(tmp$_4, destination_4)]);\n var tmp$_8;\n tmp$_8 = axis.entries.iterator();\n while (tmp$_8.hasNext()) {\n var element_1 = tmp$_8.next();\n var aes = element_1.key;\n var lines = element_1.value;\n if (!lines.isEmpty()) {\n var layoutHint = this.createHintForAxis_0(aes);\n tooltipSpecs.add_11rb$(new TooltipSpec(layoutHint, lines, ensureNotNull(layoutHint.color), true));\n }}\n return tooltipSpecs;\n };\n TooltipSpecFactory$Helper.prototype.generalTooltipSpec_0 = function () {\n var tmp$, tmp$_0, tmp$_1;\n var generalDataPoints = this.generalDataPoints_0();\n var destination = ArrayList_init_0(collectionSizeOrDefault(generalDataPoints, 10));\n var tmp$_2;\n tmp$_2 = generalDataPoints.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination.add_11rb$(TooltipSpec$Line$Companion_getInstance().withLabelAndValue_f5e6j7$(item.label, item.value));\n }\n var generalLines = destination;\n var $receiver = this.hintColors_0();\n var tmp$_3;\n var result = LinkedHashMap_init();\n tmp$_3 = $receiver.entries.iterator();\n while (tmp$_3.hasNext()) {\n var entry = tmp$_3.next();\n var aes = entry.key;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(generalDataPoints, 10));\n var tmp$_4;\n tmp$_4 = generalDataPoints.iterator();\n while (tmp$_4.hasNext()) {\n var item_0 = tmp$_4.next();\n destination_0.add_11rb$(item_0.aes);\n }\n if (destination_0.contains_11rb$(aes)) {\n result.put_xwzc9p$(entry.key, entry.value);\n }}\n var aesHintColors = result;\n var tmp$_5;\n if ((tmp$ = aesHintColors.get_11rb$(Aes.Companion.Y)) != null)\n tmp$_5 = tmp$;\n else {\n var destination_1 = ArrayList_init();\n var tmp$_6;\n tmp$_6 = aesHintColors.entries.iterator();\n while (tmp$_6.hasNext()) {\n var element = tmp$_6.next();\n var tmp$_0_0;\n if ((tmp$_0_0 = element.value) != null) {\n destination_1.add_11rb$(tmp$_0_0);\n }}\n tmp$_5 = lastOrNull(destination_1);\n }\n var colorFromHints = tmp$_5;\n if (this.myTooltipColor_0 != null)\n tmp$_0 = this.myTooltipColor_0;\n else if (colorFromHints != null)\n tmp$_0 = colorFromHints;\n else\n tmp$_0 = ensureNotNull(this.tipLayoutHint_0().color);\n var tooltipColor = tmp$_0;\n if (!generalLines.isEmpty()) {\n tmp$_1 = listOf(new TooltipSpec(this.tipLayoutHint_0(), generalLines, tooltipColor, false, this.myTooltipAnchor_0, this.myTooltipMinWidth_0, this.myIsCrosshairEnabled_0));\n } else {\n tmp$_1 = emptyList();\n }\n return tmp$_1;\n };\n TooltipSpecFactory$Helper.prototype.outlierDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.isOutlier && !element.isAxis)\n destination.add_11rb$(element);\n }\n return destination;\n };\n TooltipSpecFactory$Helper.prototype.axisDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var predicate = getPropertyCallableRef('isAxis', 1, function ($receiver) {\n return $receiver.isAxis;\n });\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (predicate(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n TooltipSpecFactory$Helper.prototype.generalDataPoints_0 = function () {\n var $receiver = this.myDataPoints_0;\n var predicate = getPropertyCallableRef('isOutlier', 1, function ($receiver) {\n return $receiver.isOutlier;\n });\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!predicate(element))\n destination.add_11rb$(element);\n }\n var nonOutlierDataPoints = destination;\n var $receiver_0 = this.outlierDataPoints_0();\n var transform = getPropertyCallableRef('aes', 1, function ($receiver) {\n return $receiver.aes;\n });\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver_0.iterator();\n while (tmp$_0.hasNext()) {\n var element_0 = tmp$_0.next();\n var tmp$_0_0;\n if ((tmp$_0_0 = transform(element_0)) != null) {\n destination_0.add_11rb$(tmp$_0_0);\n }}\n var outliers = destination_0;\n var transform_0 = getPropertyCallableRef('aes', 1, function ($receiver) {\n return $receiver.aes;\n });\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = nonOutlierDataPoints.iterator();\n while (tmp$_1.hasNext()) {\n var element_1 = tmp$_1.next();\n var tmp$_0_1;\n if ((tmp$_0_1 = transform_0(element_1)) != null) {\n destination_1.add_11rb$(tmp$_0_1);\n }}\n var generalAesList = minus(destination_1, outliers);\n var destination_2 = ArrayList_init();\n var tmp$_2;\n tmp$_2 = nonOutlierDataPoints.iterator();\n while (tmp$_2.hasNext()) {\n var element_2 = tmp$_2.next();\n var predicate$result;\n var tmp$_3;\n tmp$_3 = element_2.aes;\n if (tmp$_3 == null) {\n predicate$result = true;\n } else if (contains(generalAesList, tmp$_3)) {\n predicate$result = true;\n } else {\n predicate$result = false;\n }\n if (predicate$result)\n destination_2.add_11rb$(element_2);\n }\n return destination_2;\n };\n TooltipSpecFactory$Helper.prototype.createHintForAxis_0 = function (aes) {\n var tmp$;\n if (equals(aes, Aes.Companion.X))\n tmp$ = TipLayoutHint.Companion.xAxisTooltip_cgf2ia$(new DoubleVector(ensureNotNull(this.tipLayoutHint_0().coord).x, this.$outer.axisOrigin_0.y), Defaults$Common$Tooltip_getInstance().AXIS_TOOLTIP_COLOR, Defaults$Common$Tooltip_getInstance().AXIS_RADIUS);\n else if (equals(aes, Aes.Companion.Y))\n tmp$ = TipLayoutHint.Companion.yAxisTooltip_cgf2ia$(new DoubleVector(this.$outer.axisOrigin_0.x, ensureNotNull(this.tipLayoutHint_0().coord).y), Defaults$Common$Tooltip_getInstance().AXIS_TOOLTIP_COLOR, Defaults$Common$Tooltip_getInstance().AXIS_RADIUS);\n else {\n throw IllegalStateException_init(('Not an axis aes: ' + aes).toString());\n }\n return tmp$;\n };\n TooltipSpecFactory$Helper.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Helper',\n interfaces: []\n };\n TooltipSpecFactory.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpecFactory',\n interfaces: []\n };\n function LayerTargetCollectorWithLocator(geomKind, lookupSpec, contextualMapping, coordinateSystem) {\n this.geomKind_0 = geomKind;\n this.lookupSpec_0 = lookupSpec;\n this.contextualMapping_0 = contextualMapping;\n this.coordinateSystem_0 = coordinateSystem;\n this.myTargets_0 = ArrayList_init();\n this.myLocator_0 = null;\n }\n function LayerTargetCollectorWithLocator$addPoint$lambda(closure$index) {\n return function (it) {\n return closure$index;\n };\n }\n LayerTargetCollectorWithLocator.prototype.addPoint_cnsimy$$default = function (index, point, radius, tooltipParams, tooltipKind) {\n if (this.contextualMapping_0.ignoreInvisibleTargets) {\n if (radius === 0.0 || tooltipParams.getColor().alpha === 0) {\n return;\n }}if (!this.coordinateSystem_0.isPointInLimits_k2qmv6$(point)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.point_e1sv3v$(point, radius), LayerTargetCollectorWithLocator$addPoint$lambda(index), tooltipParams, tooltipKind));\n };\n function LayerTargetCollectorWithLocator$addRectangle$lambda(closure$index) {\n return function (it) {\n return closure$index;\n };\n }\n LayerTargetCollectorWithLocator.prototype.addRectangle_bxzvr8$$default = function (index, rectangle, tooltipParams, tooltipKind) {\n if (this.contextualMapping_0.ignoreInvisibleTargets) {\n if (rectangle.width === 0.0 || rectangle.height === 0.0 || tooltipParams.getColor().alpha === 0) {\n return;\n }}if (!this.coordinateSystem_0.isRectInLimits_fd842m$(rectangle)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.rect_wthzt5$(rectangle), LayerTargetCollectorWithLocator$addRectangle$lambda(index), tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addPath_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n if (!this.coordinateSystem_0.isPathInLimits_f6t8kh$(points)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.path_ytws2g$(points), localToGlobalIndex, tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addPolygon_sa5m83$$default = function (points, localToGlobalIndex, tooltipParams, tooltipKind) {\n if (!this.coordinateSystem_0.isPolygonInLimits_f6t8kh$(points)) {\n return;\n }this.addTarget_0(new TargetPrototype(HitShape.Companion.polygon_ytws2g$(points), localToGlobalIndex, tooltipParams, tooltipKind));\n };\n LayerTargetCollectorWithLocator.prototype.addTarget_0 = function (targetPrototype) {\n this.myTargets_0.add_11rb$(targetPrototype);\n this.myLocator_0 = null;\n };\n LayerTargetCollectorWithLocator.prototype.search_gpjtzr$ = function (coord) {\n if (this.myLocator_0 == null) {\n this.myLocator_0 = new LayerTargetLocator(this.geomKind_0, this.lookupSpec_0, this.contextualMapping_0, this.myTargets_0);\n }return ensureNotNull(this.myLocator_0).search_gpjtzr$(coord);\n };\n LayerTargetCollectorWithLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerTargetCollectorWithLocator',\n interfaces: [GeomTargetLocator, GeomTargetCollector]\n };\n function LayerTargetLocator(geomKind, lookupSpec, contextualMapping, targetPrototypes) {\n this.geomKind_0 = geomKind;\n this.lookupSpec_0 = lookupSpec;\n this.contextualMapping_0 = contextualMapping;\n this.myTargets_0 = ArrayList_init();\n this.myTargetDetector_0 = new TargetDetector(this.lookupSpec_0.lookupSpace, this.lookupSpec_0.lookupStrategy);\n this.mySimpleGeometry_0 = setOf([GeomKind.RECT, GeomKind.POLYGON]);\n var tmp$, tmp$_0;\n if (this.mySimpleGeometry_0.contains_11rb$(this.geomKind_0))\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n else if (this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.X && this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.NEAREST)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance();\n else if (this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.X)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n else if (this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.HOVER)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n else if (this.lookupSpec_0.lookupStrategy === GeomTargetLocator$LookupStrategy.NONE || this.lookupSpec_0.lookupSpace === GeomTargetLocator$LookupSpace.NONE)\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance();\n else {\n tmp$ = LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n }\n this.myCollectingStrategy_0 = tmp$;\n var toProjection = LayerTargetLocator_init$toProjection(this);\n tmp$_0 = targetPrototypes.iterator();\n while (tmp$_0.hasNext()) {\n var prototype = tmp$_0.next();\n this.myTargets_0.add_11rb$(new LayerTargetLocator$Target(toProjection(prototype), prototype));\n }\n }\n LayerTargetLocator.prototype.addLookupResults_0 = function (collector, targets) {\n if (collector.size() === 0) {\n return;\n }var tmp$ = collector.collection();\n var b = collector.closestPointChecker.distance;\n targets.add_11rb$(new GeomTargetLocator$LookupResult(tmp$, JsMath.max(0.0, b), this.geomKind_0, this.contextualMapping_0, this.contextualMapping_0.isCrosshairEnabled));\n };\n LayerTargetLocator.prototype.search_gpjtzr$ = function (coord) {\n var tmp$;\n if (this.myTargets_0.isEmpty()) {\n return null;\n }var rectCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var pointCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var pathCollector = new LayerTargetLocator$Collector(coord, this.myCollectingStrategy_0, this.lookupSpec_0.lookupSpace);\n var polygonCollector = new LayerTargetLocator$Collector(coord, LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance(), this.lookupSpec_0.lookupSpace);\n tmp$ = this.myTargets_0.iterator();\n while (tmp$.hasNext()) {\n var target = tmp$.next();\n switch (target.prototype.hitShape_8be2vx$.kind.name) {\n case 'RECT':\n this.processRect_0(coord, target, rectCollector);\n break;\n case 'POINT':\n this.processPoint_0(coord, target, pointCollector);\n break;\n case 'PATH':\n this.processPath_0(coord, target, pathCollector);\n break;\n case 'POLYGON':\n this.processPolygon_0(coord, target, polygonCollector);\n break;\n }\n }\n var lookupResults = ArrayList_init();\n this.addLookupResults_0(pathCollector, lookupResults);\n this.addLookupResults_0(rectCollector, lookupResults);\n this.addLookupResults_0(pointCollector, lookupResults);\n this.addLookupResults_0(polygonCollector, lookupResults);\n return this.getClosestTarget_0(lookupResults);\n };\n LayerTargetLocator.prototype.getClosestTarget_0 = function (lookupResults) {\n var tmp$;\n if (lookupResults.isEmpty()) {\n return null;\n }var closestTargets = lookupResults.get_za3lpa$(0);\n if (!(closestTargets.distance >= 0)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = lookupResults.iterator();\n while (tmp$.hasNext()) {\n var lookupResult = tmp$.next();\n if (lookupResult.distance < closestTargets.distance) {\n closestTargets = lookupResult;\n }}\n return closestTargets;\n };\n LayerTargetLocator.prototype.processRect_0 = function (coord, target, resultCollector) {\n var tmp$;\n if (this.myTargetDetector_0.checkRect_fqo6rd$(coord, target.rectProjection, resultCollector.closestPointChecker)) {\n var rect = target.prototype.hitShape_8be2vx$.rect;\n if (equals(target.prototype.tooltipKind_8be2vx$, TipLayoutHint$Kind.CURSOR_TOOLTIP))\n tmp$ = rect.height / 2.0;\n else\n tmp$ = 0.0;\n var yOffset = tmp$;\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(rect.origin.add_gpjtzr$(new DoubleVector(rect.width / 2, yOffset)), this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPolygon_0 = function (coord, target, resultCollector) {\n if (this.myTargetDetector_0.checkPolygon_q60eo3$(coord, target.polygonProjection, resultCollector.closestPointChecker)) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(coord, this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPoint_0 = function (coord, target, resultCollector) {\n if (this.myTargetDetector_0.checkPoint_w0b42b$(coord, target.pointProjection, resultCollector.closestPointChecker)) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(target.prototype.hitShape_8be2vx$.point.center, this.getKeyForSingleObjectGeometry_0(target.prototype)));\n }};\n LayerTargetLocator.prototype.processPath_0 = function (coord, target, resultCollector) {\n var pointChecker = this.myCollectingStrategy_0 === LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance() ? new MathUtil$ClosestPointChecker(coord) : resultCollector.closestPointChecker;\n var hitPoint = this.myTargetDetector_0.checkPath_z3141m$(coord, target.pathProjection, pointChecker);\n if (hitPoint != null) {\n resultCollector.collect_11rb$(target.prototype.createGeomTarget_x7nr8i$(hitPoint.originalCoord, hitPoint.index));\n }};\n LayerTargetLocator.prototype.getKeyForSingleObjectGeometry_0 = function (prototype) {\n return prototype.indexMapper_8be2vx$(0);\n };\n function LayerTargetLocator$Target(targetProjection, prototype) {\n this.targetProjection_0 = targetProjection;\n this.prototype = prototype;\n }\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'pointProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PointTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'rectProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, RectTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'polygonProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PolygonTargetProjection) ? tmp$ : throwCCE();\n }\n });\n Object.defineProperty(LayerTargetLocator$Target.prototype, 'pathProjection', {\n configurable: true,\n get: function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.targetProjection_0, PathTargetProjection) ? tmp$ : throwCCE();\n }\n });\n LayerTargetLocator$Target.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Target',\n interfaces: []\n };\n function LayerTargetLocator$Collector(cursor, myStrategy, lookupSpace) {\n this.myStrategy_0 = myStrategy;\n this.result_0 = ArrayList_init();\n var tmp$;\n if (lookupSpace === GeomTargetLocator$LookupSpace.X) {\n tmp$ = new MathUtil$ClosestPointChecker(new DoubleVector(cursor.x, 0.0));\n } else {\n tmp$ = new MathUtil$ClosestPointChecker(cursor);\n }\n this.closestPointChecker = tmp$;\n this.myLastAddedDistance_0 = -1.0;\n }\n LayerTargetLocator$Collector.prototype.collect_11rb$ = function (data) {\n switch (this.myStrategy_0.name) {\n case 'APPEND':\n this.add_0(data);\n break;\n case 'REPLACE':\n this.replace_0(data);\n break;\n case 'APPEND_IF_EQUAL':\n if (this.myLastAddedDistance_0 === this.closestPointChecker.distance) {\n this.add_0(data);\n } else {\n this.replace_0(data);\n }\n\n break;\n case 'IGNORE':\n return;\n }\n };\n LayerTargetLocator$Collector.prototype.collection = function () {\n return this.result_0;\n };\n LayerTargetLocator$Collector.prototype.size = function () {\n return this.result_0.size;\n };\n LayerTargetLocator$Collector.prototype.add_0 = function (data) {\n this.result_0.add_11rb$(data);\n this.myLastAddedDistance_0 = this.closestPointChecker.distance;\n };\n LayerTargetLocator$Collector.prototype.replace_0 = function (locationData) {\n this.result_0.clear();\n this.result_0.add_11rb$(locationData);\n this.myLastAddedDistance_0 = this.closestPointChecker.distance;\n };\n function LayerTargetLocator$Collector$CollectingStrategy(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function LayerTargetLocator$Collector$CollectingStrategy_initFields() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields = function () {\n };\n LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance = new LayerTargetLocator$Collector$CollectingStrategy('APPEND', 0);\n LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance = new LayerTargetLocator$Collector$CollectingStrategy('REPLACE', 1);\n LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance = new LayerTargetLocator$Collector$CollectingStrategy('APPEND_IF_EQUAL', 2);\n LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance = new LayerTargetLocator$Collector$CollectingStrategy('IGNORE', 3);\n }\n var LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$REPLACE_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_instance;\n }\n var LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance;\n function LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance() {\n LayerTargetLocator$Collector$CollectingStrategy_initFields();\n return LayerTargetLocator$Collector$CollectingStrategy$IGNORE_instance;\n }\n LayerTargetLocator$Collector$CollectingStrategy.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CollectingStrategy',\n interfaces: [Enum]\n };\n function LayerTargetLocator$Collector$CollectingStrategy$values() {\n return [LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance(), LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance()];\n }\n LayerTargetLocator$Collector$CollectingStrategy.values = LayerTargetLocator$Collector$CollectingStrategy$values;\n function LayerTargetLocator$Collector$CollectingStrategy$valueOf(name) {\n switch (name) {\n case 'APPEND':\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance();\n case 'REPLACE':\n return LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance();\n case 'APPEND_IF_EQUAL':\n return LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance();\n case 'IGNORE':\n return LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.interact.loc.LayerTargetLocator.Collector.CollectingStrategy.' + name);\n }\n }\n LayerTargetLocator$Collector$CollectingStrategy.valueOf_61zpoe$ = LayerTargetLocator$Collector$CollectingStrategy$valueOf;\n LayerTargetLocator$Collector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Collector',\n interfaces: []\n };\n function LayerTargetLocator_init$toProjection(this$LayerTargetLocator) {\n return function (prototype) {\n var tmp$;\n switch (prototype.hitShape_8be2vx$.kind.name) {\n case 'POINT':\n tmp$ = PointTargetProjection$Companion_getInstance().create_p1yge$(prototype.hitShape_8be2vx$.point.center, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'RECT':\n tmp$ = RectTargetProjection$Companion_getInstance().create_tb1cvm$(prototype.hitShape_8be2vx$.rect, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'POLYGON':\n tmp$ = PolygonTargetProjection$Companion_getInstance().create_a95qp$(prototype.hitShape_8be2vx$.points, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n case 'PATH':\n tmp$ = PathTargetProjection$Companion_getInstance().create_zb7j6l$(prototype.hitShape_8be2vx$.points, prototype.indexMapper_8be2vx$, this$LayerTargetLocator.lookupSpec_0.lookupSpace);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n }\n LayerTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LayerTargetLocator',\n interfaces: [GeomTargetLocator]\n };\n function LocatedTargetsPicker() {\n LocatedTargetsPicker$Companion_getInstance();\n this.myPicked_0 = ArrayList_init();\n this.myMinDistance_0 = 0.0;\n this.myAllLookupResults_0 = ArrayList_init();\n }\n Object.defineProperty(LocatedTargetsPicker.prototype, 'picked', {\n configurable: true,\n get: function () {\n return this.chooseBestResult_0();\n }\n });\n LocatedTargetsPicker.prototype.addLookupResult_9sakjw$ = function (result, coord) {\n if (coord === void 0)\n coord = null;\n var lookupResult = LocatedTargetsPicker$Companion_getInstance().filterResults_0(result, coord);\n var distance = LocatedTargetsPicker$Companion_getInstance().distance_0(lookupResult, coord);\n if (!lookupResult.isCrosshairEnabled && distance > LocatedTargetsPicker$Companion_getInstance().CUTOFF_DISTANCE_8be2vx$) {\n return;\n }if (this.myPicked_0.isEmpty() || this.myMinDistance_0 > distance) {\n this.myPicked_0.clear();\n this.myPicked_0.add_11rb$(lookupResult);\n this.myMinDistance_0 = distance;\n } else if (this.myMinDistance_0 === distance && LocatedTargetsPicker$Companion_getInstance().isSameUnivariateGeom_0(this.myPicked_0.get_za3lpa$(0), lookupResult))\n this.myPicked_0.add_11rb$(lookupResult);\n else if (this.myMinDistance_0 === distance) {\n this.myPicked_0.clear();\n this.myPicked_0.add_11rb$(lookupResult);\n }this.myAllLookupResults_0.add_11rb$(lookupResult);\n };\n function LocatedTargetsPicker$chooseBestResult$hasGeneralTooltip(lookupResult) {\n return lookupResult.contextualMapping.hasGeneralTooltip;\n }\n function LocatedTargetsPicker$chooseBestResult$hasAxisTooltip(lookupResult) {\n return lookupResult.contextualMapping.hasAxisTooltip || listOf_0([GeomKind.V_LINE, GeomKind.H_LINE]).contains_11rb$(lookupResult.geomKind);\n }\n LocatedTargetsPicker.prototype.chooseBestResult_0 = function () {\n var tmp$;\n var hasGeneralTooltip = LocatedTargetsPicker$chooseBestResult$hasGeneralTooltip;\n var hasAxisTooltip = LocatedTargetsPicker$chooseBestResult$hasAxisTooltip;\n var $receiver = this.myPicked_0;\n var any$result;\n any$break: do {\n var tmp$_0;\n if (Kotlin.isType($receiver, Collection) && $receiver.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (hasGeneralTooltip(element) && hasAxisTooltip(element)) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n if (any$result)\n tmp$ = this.myPicked_0;\n else {\n var $receiver_0 = this.myAllLookupResults_0;\n var none$result;\n none$break: do {\n var tmp$_1;\n if (Kotlin.isType($receiver_0, Collection) && $receiver_0.isEmpty()) {\n none$result = true;\n break none$break;\n }tmp$_1 = $receiver_0.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (hasGeneralTooltip(element_0)) {\n none$result = false;\n break none$break;\n }}\n none$result = true;\n }\n while (false);\n if (none$result)\n tmp$ = this.myPicked_0;\n else {\n var $receiver_1 = this.myAllLookupResults_0;\n var any$result_0;\n any$break: do {\n var tmp$_2;\n if (Kotlin.isType($receiver_1, Collection) && $receiver_1.isEmpty()) {\n any$result_0 = false;\n break any$break;\n }tmp$_2 = $receiver_1.iterator();\n while (tmp$_2.hasNext()) {\n var element_1 = tmp$_2.next();\n if (hasGeneralTooltip(element_1) && hasAxisTooltip(element_1)) {\n any$result_0 = true;\n break any$break;\n }}\n any$result_0 = false;\n }\n while (false);\n if (any$result_0) {\n var $receiver_2 = this.myAllLookupResults_0;\n var last$result;\n last$break: do {\n var iterator = $receiver_2.listIterator_za3lpa$($receiver_2.size);\n while (iterator.hasPrevious()) {\n var element_2 = iterator.previous();\n if (hasGeneralTooltip(element_2) && hasAxisTooltip(element_2)) {\n last$result = element_2;\n break last$break;\n }}\n throw new NoSuchElementException_init_0('List contains no element matching the predicate.');\n }\n while (false);\n tmp$ = listOf(last$result);\n } else {\n var $receiver_3 = this.myAllLookupResults_0;\n var lastOrNull$result;\n lastOrNull$break: do {\n var iterator_0 = $receiver_3.listIterator_za3lpa$($receiver_3.size);\n while (iterator_0.hasPrevious()) {\n var element_3 = iterator_0.previous();\n if (hasGeneralTooltip(element_3)) {\n lastOrNull$result = element_3;\n break lastOrNull$break;\n }}\n lastOrNull$result = null;\n }\n while (false);\n var withGeneralTooltip = lastOrNull$result;\n var $receiver_4 = this.myAllLookupResults_0;\n var lastOrNull$result_0;\n lastOrNull$break: do {\n var iterator_1 = $receiver_4.listIterator_za3lpa$($receiver_4.size);\n while (iterator_1.hasPrevious()) {\n var element_4 = iterator_1.previous();\n if (hasAxisTooltip(element_4)) {\n lastOrNull$result_0 = element_4;\n break lastOrNull$break;\n }}\n lastOrNull$result_0 = null;\n }\n while (false);\n var withAxisTooltip = lastOrNull$result_0;\n tmp$ = listOfNotNull([withGeneralTooltip, withAxisTooltip]);\n }\n }\n }\n return tmp$;\n };\n function LocatedTargetsPicker$Companion() {\n LocatedTargetsPicker$Companion_instance = this;\n this.CUTOFF_DISTANCE_8be2vx$ = 30.0;\n this.FAKE_DISTANCE_8be2vx$ = 15.0;\n this.UNIVARIATE_GEOMS_0 = listOf_0([GeomKind.DENSITY, GeomKind.FREQPOLY, GeomKind.BOX_PLOT, GeomKind.HISTOGRAM, GeomKind.LINE, GeomKind.AREA, GeomKind.BAR, GeomKind.ERROR_BAR, GeomKind.CROSS_BAR, GeomKind.LINE_RANGE, GeomKind.POINT_RANGE]);\n this.UNIVARIATE_LINES_0 = listOf_0([GeomKind.DENSITY, GeomKind.FREQPOLY, GeomKind.LINE, GeomKind.AREA, GeomKind.SEGMENT]);\n }\n LocatedTargetsPicker$Companion.prototype.distance_0 = function (locatedTargetList, coord) {\n var tmp$, tmp$_0;\n var distance = locatedTargetList.distance;\n if (distance === 0.0) {\n if (!locatedTargetList.isCrosshairEnabled || coord == null) {\n tmp$_0 = this.FAKE_DISTANCE_8be2vx$;\n } else {\n var $receiver = locatedTargetList.targets;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (element.tipLayoutHint.coord != null)\n destination.add_11rb$(element);\n }\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_2;\n tmp$_2 = destination.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n destination_0.add_11rb$(MathUtil_getInstance().distance_l9poh5$(coord, ensureNotNull(item.tipLayoutHint.coord)));\n }\n tmp$_0 = (tmp$ = minOrNull(destination_0)) != null ? tmp$ : this.FAKE_DISTANCE_8be2vx$;\n }\n } else {\n tmp$_0 = distance;\n }\n return tmp$_0;\n };\n LocatedTargetsPicker$Companion.prototype.isSameUnivariateGeom_0 = function (lft, rgt) {\n return lft.geomKind === rgt.geomKind && this.UNIVARIATE_GEOMS_0.contains_11rb$(rgt.geomKind);\n };\n LocatedTargetsPicker$Companion.prototype.filterResults_0 = function (lookupResult, coord) {\n if (coord == null || !this.UNIVARIATE_LINES_0.contains_11rb$(lookupResult.geomKind)) {\n return lookupResult;\n }var $receiver = lookupResult.targets;\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (element.tipLayoutHint.coord != null)\n destination.add_11rb$(element);\n }\n var geomTargets = destination;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(geomTargets, 10));\n var tmp$_0;\n tmp$_0 = geomTargets.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination_0.add_11rb$(ensureNotNull(item.tipLayoutHint.coord).subtract_gpjtzr$(coord).x);\n }\n var minByOrNull$result;\n minByOrNull$break: do {\n var iterator = destination_0.iterator();\n if (!iterator.hasNext()) {\n minByOrNull$result = null;\n break minByOrNull$break;\n }var minElem = iterator.next();\n if (!iterator.hasNext()) {\n minByOrNull$result = minElem;\n break minByOrNull$break;\n }var it = minElem;\n var minValue = JsMath.abs(it);\n do {\n var e = iterator.next();\n var v = JsMath.abs(e);\n if (Kotlin.compareTo(minValue, v) > 0) {\n minElem = e;\n minValue = v;\n }}\n while (iterator.hasNext());\n minByOrNull$result = minElem;\n }\n while (false);\n var minXToTarget = minByOrNull$result;\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = geomTargets.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (ensureNotNull(element_0.tipLayoutHint.coord).subtract_gpjtzr$(coord).x === minXToTarget)\n destination_1.add_11rb$(element_0);\n }\n var tmp$_2;\n var set = HashSet_init_0();\n var list = ArrayList_init();\n tmp$_2 = destination_1.iterator();\n while (tmp$_2.hasNext()) {\n var e_0 = tmp$_2.next();\n var key = e_0.hitIndex;\n if (set.add_11rb$(key))\n list.add_11rb$(e_0);\n }\n var newTargets = list;\n return new GeomTargetLocator$LookupResult(newTargets, lookupResult.distance, lookupResult.geomKind, lookupResult.contextualMapping, lookupResult.isCrosshairEnabled);\n };\n LocatedTargetsPicker$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LocatedTargetsPicker$Companion_instance = null;\n function LocatedTargetsPicker$Companion_getInstance() {\n if (LocatedTargetsPicker$Companion_instance === null) {\n new LocatedTargetsPicker$Companion();\n }return LocatedTargetsPicker$Companion_instance;\n }\n LocatedTargetsPicker.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LocatedTargetsPicker',\n interfaces: []\n };\n function TargetDetector(locatorLookupSpace, locatorLookupStrategy) {\n TargetDetector$Companion_getInstance();\n this.locatorLookupSpace_0 = locatorLookupSpace;\n this.locatorLookupStrategy_0 = locatorLookupStrategy;\n }\n function TargetDetector$checkPath$lambda(closure$pathPoints) {\n return function (index) {\n return closure$pathPoints.get_za3lpa$(index).projection().x();\n };\n }\n TargetDetector.prototype.checkPath_z3141m$ = function (cursorCoord, pathProjection, closestPointChecker) {\n var tmp$, tmp$_0, tmp$_1;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n if (this.locatorLookupStrategy_0 === GeomTargetLocator$LookupStrategy.NONE) {\n return null;\n }\n var pathPoints = pathProjection.points;\n if (pathPoints.isEmpty()) {\n return null;\n }\n var resultIndex = TargetDetector$Companion_getInstance().binarySearch_0(cursorCoord.x, pathPoints.size, TargetDetector$checkPath$lambda(pathPoints));\n var bestPoint = pathPoints.get_za3lpa$(resultIndex);\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n if (cursorCoord.x < pathPoints.get_za3lpa$(0).projection().x() || cursorCoord.x > pathPoints.get_za3lpa$(pathPoints.size - 1 | 0).projection().x()) {\n tmp$ = null;\n } else\n tmp$ = bestPoint;\n break;\n case 'NEAREST':\n tmp$ = bestPoint;\n break;\n default:throw IllegalStateException_init('Unknown lookup strategy: ' + this.locatorLookupStrategy_0);\n }\n\n return tmp$;\n case 'XY':\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$_0 = pathProjection.points.iterator();\n while (tmp$_0.hasNext()) {\n var pathPoint = tmp$_0.next();\n var targetPointCoord = pathPoint.projection().xy();\n if (MathUtil_getInstance().areEqual_f1g2it$(targetPointCoord, cursorCoord, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0)) {\n return pathPoint;\n }}\n\n return null;\n case 'NEAREST':\n var nearestPoint = null;\n tmp$_1 = pathProjection.points.iterator();\n while (tmp$_1.hasNext()) {\n var pathPoint_0 = tmp$_1.next();\n var targetPointCoord_0 = pathPoint_0.projection().xy();\n if (closestPointChecker.check_gpjtzr$(targetPointCoord_0)) {\n nearestPoint = pathPoint_0;\n }}\n\n return nearestPoint;\n case 'NONE':\n return null;\n default:Kotlin.noWhenBranchMatched();\n break;\n }\n\n break;\n case 'NONE':\n return null;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkPoint_w0b42b$ = function (cursorCoord, pointProjection, closestPointChecker) {\n var tmp$, tmp$_0;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var x = pointProjection.x();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$ = MathUtil_getInstance().areEqual_hln2n9$(x, cursorCoord.x, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0);\n break;\n case 'NEAREST':\n tmp$ = closestPointChecker.check_gpjtzr$(new DoubleVector(x, 0.0));\n break;\n case 'NONE':\n tmp$ = false;\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n\n return tmp$;\n case 'XY':\n var targetPointCoord = pointProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n tmp$_0 = MathUtil_getInstance().areEqual_f1g2it$(targetPointCoord, cursorCoord, TargetDetector$Companion_getInstance().POINT_AREA_EPSILON_0);\n break;\n case 'NEAREST':\n tmp$_0 = closestPointChecker.check_gpjtzr$(targetPointCoord);\n break;\n case 'NONE':\n tmp$_0 = false;\n break;\n default:tmp$_0 = Kotlin.noWhenBranchMatched();\n break;\n }\n\n return tmp$_0;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkRect_fqo6rd$ = function (cursorCoord, rectProjection, closestPointChecker) {\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var range = rectProjection.x();\n return this.rangeBasedLookup_0(cursorCoord, closestPointChecker, range);\n case 'XY':\n var rect = rectProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n return rect.contains_gpjtzr$(cursorCoord);\n case 'NEAREST':\n if (rect.contains_gpjtzr$(cursorCoord)) {\n return closestPointChecker.check_gpjtzr$(cursorCoord);\n }\n var x = cursorCoord.x < rect.left ? rect.left : rect.right;\n var y = cursorCoord.y < rect.top ? rect.top : rect.bottom;\n x = rect.xRange().contains_mef7kx$(cursorCoord.x) ? cursorCoord.x : x;\n y = rect.yRange().contains_mef7kx$(cursorCoord.y) ? cursorCoord.y : y;\n return closestPointChecker.check_gpjtzr$(new DoubleVector(x, y));\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.checkPolygon_q60eo3$ = function (cursorCoord, polygonProjection, closestPointChecker) {\n var tmp$;\n switch (this.locatorLookupSpace_0.name) {\n case 'X':\n var range = polygonProjection.x();\n return this.rangeBasedLookup_0(cursorCoord, closestPointChecker, range);\n case 'XY':\n var polygon = polygonProjection.xy();\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n case 'NEAREST':\n var counter = 0;\n tmp$ = polygon.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (ring.bbox.contains_gpjtzr$(cursorCoord) && MathUtil_getInstance().polygonContainsCoordinate_sz9prc$(ring.edges, cursorCoord)) {\n counter = counter + 1 | 0;\n }}\n\n return counter % 2 !== 0;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n\n break;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n TargetDetector.prototype.rangeBasedLookup_0 = function (cursorCoord, closestPointChecker, range) {\n var tmp$;\n switch (this.locatorLookupStrategy_0.name) {\n case 'HOVER':\n return range.contains_14dthe$(cursorCoord.x);\n case 'NEAREST':\n if (!range.contains_14dthe$(cursorCoord.x - TargetDetector$Companion_getInstance().RECT_X_NEAREST_EPSILON_0) && !range.contains_14dthe$(cursorCoord.x + TargetDetector$Companion_getInstance().RECT_X_NEAREST_EPSILON_0)) {\n tmp$ = false;\n } else\n tmp$ = closestPointChecker.compare_gpjtzr$(new DoubleVector(range.start() + range.length() / 2, cursorCoord.y)) !== MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance();\n return tmp$;\n case 'NONE':\n return false;\n default:throw IllegalStateException_init_0();\n }\n };\n function TargetDetector$Companion() {\n TargetDetector$Companion_instance = this;\n this.POINT_AREA_EPSILON_0 = 0.1;\n this.POINT_X_NEAREST_EPSILON_0 = 2.0;\n this.RECT_X_NEAREST_EPSILON_0 = 2.0;\n }\n TargetDetector$Companion.prototype.binarySearch_0 = function (value, length, indexer) {\n var tmp$;\n if (value < indexer(0)) {\n return 0;\n }if (value > indexer(length - 1 | 0)) {\n return length - 1 | 0;\n }var lo = 0;\n var hi = length - 1 | 0;\n while (lo <= hi) {\n var mid = (hi + lo | 0) / 2 | 0;\n var midValue = indexer(mid);\n if (value < midValue)\n hi = mid - 1 | 0;\n else if (value > midValue)\n lo = mid + 1 | 0;\n else\n return mid;\n }\n if (indexer(lo) - value < value - indexer(hi)) {\n tmp$ = lo;\n } else {\n tmp$ = hi;\n }\n return tmp$;\n };\n TargetDetector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TargetDetector$Companion_instance = null;\n function TargetDetector$Companion_getInstance() {\n if (TargetDetector$Companion_instance === null) {\n new TargetDetector$Companion();\n }return TargetDetector$Companion_instance;\n }\n TargetDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetDetector',\n interfaces: []\n };\n function TargetProjection() {\n }\n TargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetProjection',\n interfaces: []\n };\n function PointTargetProjection(data) {\n PointTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n PointTargetProjection.prototype.x = function () {\n var tmp$;\n return typeof (tmp$ = this.data) === 'number' ? tmp$ : throwCCE();\n };\n PointTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, DoubleVector) ? tmp$ : throwCCE();\n };\n function PointTargetProjection$Companion() {\n PointTargetProjection$Companion_instance = this;\n }\n PointTargetProjection$Companion.prototype.create_p1yge$ = function (p, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PointTargetProjection(p.x);\n break;\n case 'XY':\n tmp$ = new PointTargetProjection(p);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PointTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PointTargetProjection$Companion_instance = null;\n function PointTargetProjection$Companion_getInstance() {\n if (PointTargetProjection$Companion_instance === null) {\n new PointTargetProjection$Companion();\n }return PointTargetProjection$Companion_instance;\n }\n PointTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PointTargetProjection',\n interfaces: [TargetProjection]\n };\n function RectTargetProjection(data) {\n RectTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n RectTargetProjection.prototype.x = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, MathUtil$DoubleRange) ? tmp$ : throwCCE();\n };\n RectTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, DoubleRectangle) ? tmp$ : throwCCE();\n };\n function RectTargetProjection$Companion() {\n RectTargetProjection$Companion_instance = this;\n }\n RectTargetProjection$Companion.prototype.create_tb1cvm$ = function (rect, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new RectTargetProjection(MathUtil$DoubleRange$Companion_getInstance().withStartAndEnd_lu1900$(rect.left, rect.right));\n break;\n case 'XY':\n tmp$ = new RectTargetProjection(rect);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n RectTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RectTargetProjection$Companion_instance = null;\n function RectTargetProjection$Companion_getInstance() {\n if (RectTargetProjection$Companion_instance === null) {\n new RectTargetProjection$Companion();\n }return RectTargetProjection$Companion_instance;\n }\n RectTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RectTargetProjection',\n interfaces: [TargetProjection]\n };\n function PolygonTargetProjection(data) {\n PolygonTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n }\n PolygonTargetProjection.prototype.x = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, MathUtil$DoubleRange) ? tmp$ : throwCCE();\n };\n PolygonTargetProjection.prototype.xy = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = this.data, List) ? tmp$ : throwCCE();\n };\n function PolygonTargetProjection$Companion() {\n PolygonTargetProjection$Companion_instance = this;\n this.AREA_LIMIT_TO_REMOVE_POLYGON_0 = 25.0;\n this.POINTS_COUNT_TO_SKIP_SIMPLIFICATION_0 = 20.0;\n this.AREA_TOLERANCE_RATIO_0 = 0.1;\n this.MAX_TOLERANCE_0 = 40.0;\n this.isLogEnabled_0 = false;\n }\n PolygonTargetProjection$Companion.prototype.create_a95qp$ = function (points, lookupSpace) {\n var tmp$;\n var rings = splitRings(points);\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PolygonTargetProjection(this.mapToX_0(rings));\n break;\n case 'XY':\n tmp$ = new PolygonTargetProjection(this.mapToXY_0(rings));\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PolygonTargetProjection$Companion.prototype.mapToX_0 = function (rings) {\n var tmp$, tmp$_0;\n var min = rings.get_za3lpa$(0).get_za3lpa$(0).x;\n var max = min;\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n tmp$_0 = ring.iterator();\n while (tmp$_0.hasNext()) {\n var point = tmp$_0.next();\n var a = min;\n var b = point.x;\n min = JsMath.min(a, b);\n var a_0 = max;\n var b_0 = point.x;\n max = JsMath.max(a_0, b_0);\n }\n }\n return MathUtil$DoubleRange$Companion_getInstance().withStartAndEnd_lu1900$(min, max);\n };\n PolygonTargetProjection$Companion.prototype.mapToXY_0 = function (rings) {\n var tmp$;\n var polygon = ArrayList_init();\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var ring = tmp$.next();\n if (ring.size < 4) {\n continue;\n }var bbox = geometry.DoubleRectangles.boundingBox_qdtdbw$(ring);\n var area = calculateArea(ring);\n var simplifiedRing;\n if (ring.size > this.POINTS_COUNT_TO_SKIP_SIMPLIFICATION_0) {\n var a = area * this.AREA_TOLERANCE_RATIO_0;\n var b = this.MAX_TOLERANCE_0;\n var tolerance = JsMath.min(a, b);\n simplifiedRing = PolylineSimplifier.Companion.visvalingamWhyatt_ytws2g$(ring).setWeightLimit_14dthe$(tolerance).points;\n if (this.isLogEnabled_0) {\n this.log_0('Simp: ' + toString(ring.size) + ' -> ' + toString(simplifiedRing.size) + ', tolerance=' + toString(tolerance) + ', bbox=' + toString(bbox) + ', area=' + toString(area));\n }} else {\n if (this.isLogEnabled_0) {\n this.log_0('Keep: size: ' + toString(ring.size) + ', bbox=' + toString(bbox) + ', area=' + toString(area));\n }simplifiedRing = ring;\n }\n if (simplifiedRing.size < 4) {\n continue;\n }polygon.add_11rb$(new PolygonTargetProjection$RingXY(simplifiedRing, bbox));\n }\n return polygon;\n };\n PolygonTargetProjection$Companion.prototype.log_0 = function (str) {\n println(str);\n };\n PolygonTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolygonTargetProjection$Companion_instance = null;\n function PolygonTargetProjection$Companion_getInstance() {\n if (PolygonTargetProjection$Companion_instance === null) {\n new PolygonTargetProjection$Companion();\n }return PolygonTargetProjection$Companion_instance;\n }\n function PolygonTargetProjection$RingXY(edges, bbox) {\n this.edges = edges;\n this.bbox = bbox;\n }\n PolygonTargetProjection$RingXY.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RingXY',\n interfaces: []\n };\n PolygonTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolygonTargetProjection',\n interfaces: [TargetProjection]\n };\n function PathTargetProjection(data) {\n PathTargetProjection$Companion_getInstance();\n TargetProjection.call(this);\n this.data = data;\n this.points = this.data;\n }\n function PathTargetProjection$PathPoint(myPointTargetProjection, originalCoord, index) {\n PathTargetProjection$PathPoint$Companion_getInstance();\n this.myPointTargetProjection_0 = myPointTargetProjection;\n this.originalCoord = originalCoord;\n this.index = index;\n }\n PathTargetProjection$PathPoint.prototype.projection = function () {\n return this.myPointTargetProjection_0;\n };\n function PathTargetProjection$PathPoint$Companion() {\n PathTargetProjection$PathPoint$Companion_instance = this;\n }\n PathTargetProjection$PathPoint$Companion.prototype.create_hdp8xa$ = function (p, index, lookupSpace) {\n var tmp$;\n switch (lookupSpace.name) {\n case 'X':\n tmp$ = new PathTargetProjection$PathPoint(PointTargetProjection$Companion_getInstance().create_p1yge$(p, lookupSpace), p, index);\n break;\n case 'XY':\n tmp$ = new PathTargetProjection$PathPoint(PointTargetProjection$Companion_getInstance().create_p1yge$(p, lookupSpace), p, index);\n break;\n case 'NONE':\n tmp$ = undefinedLookupSpaceError();\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n PathTargetProjection$PathPoint$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathTargetProjection$PathPoint$Companion_instance = null;\n function PathTargetProjection$PathPoint$Companion_getInstance() {\n if (PathTargetProjection$PathPoint$Companion_instance === null) {\n new PathTargetProjection$PathPoint$Companion();\n }return PathTargetProjection$PathPoint$Companion_instance;\n }\n PathTargetProjection$PathPoint.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathPoint',\n interfaces: []\n };\n function PathTargetProjection$Companion() {\n PathTargetProjection$Companion_instance = this;\n }\n PathTargetProjection$Companion.prototype.create_zb7j6l$ = function (points, indexMapper, lookupSpace) {\n var pointsLocation = ArrayList_init();\n var i = 0;\n for (var tmp$ = points.iterator(); tmp$.hasNext(); ++i) {\n var point = tmp$.next();\n pointsLocation.add_11rb$(PathTargetProjection$PathPoint$Companion_getInstance().create_hdp8xa$(point, indexMapper(i), lookupSpace));\n }\n return new PathTargetProjection(pointsLocation);\n };\n PathTargetProjection$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PathTargetProjection$Companion_instance = null;\n function PathTargetProjection$Companion_getInstance() {\n if (PathTargetProjection$Companion_instance === null) {\n new PathTargetProjection$Companion();\n }return PathTargetProjection$Companion_instance;\n }\n PathTargetProjection.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PathTargetProjection',\n interfaces: [TargetProjection]\n };\n function undefinedLookupSpaceError() {\n throw IllegalStateException_init('Undefined geom lookup space');\n }\n function TargetPrototype(hitShape, indexMapper, tooltipParams, tooltipKind) {\n TargetPrototype$Companion_getInstance();\n this.hitShape_8be2vx$ = hitShape;\n this.indexMapper_8be2vx$ = indexMapper;\n this.tooltipParams_0 = tooltipParams;\n this.tooltipKind_8be2vx$ = tooltipKind;\n }\n TargetPrototype.prototype.createGeomTarget_x7nr8i$ = function (hitCoord, hitIndex) {\n return new GeomTarget(hitIndex, TargetPrototype$Companion_getInstance().createTipLayoutHint_17pt0e$(hitCoord, this.hitShape_8be2vx$, this.tooltipParams_0.getColor(), this.tooltipKind_8be2vx$, this.tooltipParams_0.getStemLength()), this.tooltipParams_0.getTipLayoutHints());\n };\n function TargetPrototype$Companion() {\n TargetPrototype$Companion_instance = this;\n }\n TargetPrototype$Companion.prototype.createTipLayoutHint_17pt0e$ = function (hitCoord, hitShape, fill, tooltipKind, stemLength) {\n var tmp$;\n switch (hitShape.kind.name) {\n case 'POINT':\n switch (tooltipKind.name) {\n case 'VERTICAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.verticalTooltip_6lq1u6$(hitCoord, hitShape.point.radius, fill, stemLength);\n break;\n case 'CURSOR_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n break;\n default:throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for POINT').toString());\n }\n\n break;\n case 'RECT':\n switch (tooltipKind.name) {\n case 'VERTICAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.verticalTooltip_6lq1u6$(hitCoord, 0.0, fill, stemLength);\n break;\n case 'HORIZONTAL_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.horizontalTooltip_6lq1u6$(hitCoord, hitShape.rect.width / 2, fill, stemLength);\n break;\n case 'CURSOR_TOOLTIP':\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n break;\n default:throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for RECT').toString());\n }\n\n break;\n case 'PATH':\n if (equals(tooltipKind, TipLayoutHint$Kind.HORIZONTAL_TOOLTIP))\n tmp$ = TipLayoutHint.Companion.horizontalTooltip_6lq1u6$(hitCoord, 0.0, fill, stemLength);\n else {\n throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for PATH').toString());\n }\n\n break;\n case 'POLYGON':\n if (equals(tooltipKind, TipLayoutHint$Kind.CURSOR_TOOLTIP))\n tmp$ = TipLayoutHint.Companion.cursorTooltip_itpcqk$(hitCoord, fill, stemLength);\n else {\n throw IllegalStateException_init(('Wrong TipLayoutHint.kind = ' + tooltipKind + ' for POLYGON').toString());\n }\n\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n TargetPrototype$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TargetPrototype$Companion_instance = null;\n function TargetPrototype$Companion_getInstance() {\n if (TargetPrototype$Companion_instance === null) {\n new TargetPrototype$Companion();\n }return TargetPrototype$Companion_instance;\n }\n TargetPrototype.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TargetPrototype',\n interfaces: []\n };\n function TransformedTargetLocator(targetLocator) {\n this.targetLocator_q7bze5$_0 = targetLocator;\n }\n TransformedTargetLocator.prototype.search_gpjtzr$ = function (coord) {\n var tmp$;\n var targetCoord = this.convertToTargetCoord_gpjtzr$(coord);\n tmp$ = this.targetLocator_q7bze5$_0.search_gpjtzr$(targetCoord);\n if (tmp$ == null) {\n return null;\n }var result = tmp$;\n return this.convertLookupResult_rz45e2$_0(result);\n };\n TransformedTargetLocator.prototype.convertLookupResult_rz45e2$_0 = function (lookupResult) {\n return new GeomTargetLocator$LookupResult(this.convertGeomTargets_cu5hhh$_0(lookupResult.targets), this.convertToPlotDistance_14dthe$(lookupResult.distance), lookupResult.geomKind, lookupResult.contextualMapping, lookupResult.contextualMapping.isCrosshairEnabled);\n };\n function TransformedTargetLocator$convertGeomTargets$lambda(this$TransformedTargetLocator) {\n return function (geomTarget) {\n return new GeomTarget(geomTarget.hitIndex, this$TransformedTargetLocator.convertTipLayoutHint_jnrdzl$_0(geomTarget.tipLayoutHint), this$TransformedTargetLocator.convertTipLayoutHints_dshtp8$_0(geomTarget.aesTipLayoutHints));\n };\n }\n TransformedTargetLocator.prototype.convertGeomTargets_cu5hhh$_0 = function (geomTargets) {\n return ArrayList_init_1(collect.Lists.transform_l7riir$(geomTargets, TransformedTargetLocator$convertGeomTargets$lambda(this)));\n };\n TransformedTargetLocator.prototype.convertTipLayoutHint_jnrdzl$_0 = function (hint) {\n return new TipLayoutHint(hint.kind, ensureNotNull(this.safeConvertToPlotCoord_eoxeor$_0(hint.coord)), this.convertToPlotDistance_14dthe$(hint.objectRadius), hint.color, hint.stemLength);\n };\n TransformedTargetLocator.prototype.convertTipLayoutHints_dshtp8$_0 = function (tipLayoutHints) {\n var result = HashMap_init();\n var tmp$;\n tmp$ = tipLayoutHints.entries.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var aes = element.key;\n var hint = element.value;\n var value = this.convertTipLayoutHint_jnrdzl$_0(hint);\n result.put_xwzc9p$(aes, value);\n }\n return result;\n };\n TransformedTargetLocator.prototype.safeConvertToPlotCoord_eoxeor$_0 = function (coord) {\n return coord == null ? null : this.convertToPlotCoord_gpjtzr$(coord);\n };\n TransformedTargetLocator.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TransformedTargetLocator',\n interfaces: [GeomTargetLocator]\n };\n function AxisLayout() {\n }\n AxisLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisLayout',\n interfaces: []\n };\n function AxisLayoutInfo(b) {\n this.axisBreaks = null;\n this.axisLength = 0;\n this.orientation = null;\n this.axisDomain = null;\n this.tickLabelsBounds = null;\n this.tickLabelRotationAngle = 0;\n this.tickLabelHorizontalAnchor = null;\n this.tickLabelVerticalAnchor = null;\n this.tickLabelAdditionalOffsets = null;\n this.tickLabelSmallFont = false;\n this.tickLabelsBoundsMax_0 = null;\n if (!(b.myAxisBreaks != null)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }if (!(b.myOrientation != null)) {\n var message_0 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_0.toString());\n }if (!(b.myTickLabelsBounds != null)) {\n var message_1 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_1.toString());\n }if (!(b.myAxisDomain != null)) {\n var message_2 = 'Failed requirement.';\n throw IllegalArgumentException_init(message_2.toString());\n }this.axisBreaks = b.myAxisBreaks;\n this.axisLength = b.myAxisLength;\n this.orientation = b.myOrientation;\n this.axisDomain = b.myAxisDomain;\n this.tickLabelsBounds = b.myTickLabelsBounds;\n this.tickLabelRotationAngle = b.myTickLabelRotationAngle;\n this.tickLabelHorizontalAnchor = b.myLabelHorizontalAnchor;\n this.tickLabelVerticalAnchor = b.myLabelVerticalAnchor;\n this.tickLabelAdditionalOffsets = b.myLabelAdditionalOffsets;\n this.tickLabelSmallFont = b.myTickLabelSmallFont;\n this.tickLabelsBoundsMax_0 = b.myMaxTickLabelsBounds;\n }\n AxisLayoutInfo.prototype.withAxisLength_14dthe$ = function (axisLength) {\n var b = new AxisLayoutInfo$Builder();\n b.myAxisBreaks = this.axisBreaks;\n b.myAxisLength = axisLength;\n b.myOrientation = this.orientation;\n b.myAxisDomain = this.axisDomain;\n b.myTickLabelsBounds = this.tickLabelsBounds;\n b.myTickLabelRotationAngle = this.tickLabelRotationAngle;\n b.myLabelHorizontalAnchor = this.tickLabelHorizontalAnchor;\n b.myLabelVerticalAnchor = this.tickLabelVerticalAnchor;\n b.myLabelAdditionalOffsets = this.tickLabelAdditionalOffsets;\n b.myTickLabelSmallFont = this.tickLabelSmallFont;\n b.myMaxTickLabelsBounds = this.tickLabelsBoundsMax_0;\n return b;\n };\n AxisLayoutInfo.prototype.axisBounds = function () {\n return ensureNotNull(this.tickLabelsBounds).union_wthzt5$(DoubleRectangle_init(0.0, 0.0, 0.0, 0.0));\n };\n function AxisLayoutInfo$Builder() {\n this.myAxisLength = 0;\n this.myOrientation = null;\n this.myAxisDomain = null;\n this.myMaxTickLabelsBounds = null;\n this.myTickLabelSmallFont = false;\n this.myLabelAdditionalOffsets = null;\n this.myLabelHorizontalAnchor = null;\n this.myLabelVerticalAnchor = null;\n this.myTickLabelRotationAngle = 0.0;\n this.myTickLabelsBounds = null;\n this.myAxisBreaks = null;\n }\n AxisLayoutInfo$Builder.prototype.build = function () {\n return new AxisLayoutInfo(this);\n };\n AxisLayoutInfo$Builder.prototype.axisLength_14dthe$ = function (d) {\n this.myAxisLength = d;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.orientation_9y97dg$ = function (o) {\n this.myOrientation = o;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.axisDomain_4fzjta$ = function (r) {\n this.myAxisDomain = r;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelsBoundsMax_myx2hi$ = function (r) {\n this.myMaxTickLabelsBounds = r;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelSmallFont_6taknv$ = function (b) {\n this.myTickLabelSmallFont = b;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelAdditionalOffsets_eajcfd$ = function (labelAdditionalOffsets) {\n this.myLabelAdditionalOffsets = labelAdditionalOffsets;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelHorizontalAnchor_tk0ev1$ = function (labelHorizontalAnchor) {\n this.myLabelHorizontalAnchor = labelHorizontalAnchor;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelVerticalAnchor_24j3ht$ = function (labelVerticalAnchor) {\n this.myLabelVerticalAnchor = labelVerticalAnchor;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelRotationAngle_14dthe$ = function (rotationAngle) {\n this.myTickLabelRotationAngle = rotationAngle;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.tickLabelsBounds_myx2hi$ = function (rectangle) {\n this.myTickLabelsBounds = rectangle;\n return this;\n };\n AxisLayoutInfo$Builder.prototype.axisBreaks_hbp697$ = function (breaks) {\n this.myAxisBreaks = breaks;\n return this;\n };\n AxisLayoutInfo$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n AxisLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLayoutInfo',\n interfaces: []\n };\n function EmptyAxisLayout(xDomain, yDomain, myOrientation) {\n EmptyAxisLayout$Companion_getInstance();\n this.myOrientation_0 = myOrientation;\n this.myAxisDomain_0 = null;\n this.myAxisDomain_0 = this.myOrientation_0.isHorizontal ? xDomain : yDomain;\n }\n EmptyAxisLayout.prototype.initialThickness = function () {\n return 0.0;\n };\n EmptyAxisLayout.prototype.doLayout_o2m17x$ = function (displaySize, maxTickLabelsBoundsStretched) {\n var tmp$;\n var axisLength = this.myOrientation_0.isHorizontal ? displaySize.x : displaySize.y;\n if (this.myOrientation_0.isHorizontal) {\n tmp$ = DoubleRectangle_init(0.0, 0.0, axisLength, 0.0);\n } else {\n tmp$ = DoubleRectangle_init(0.0, 0.0, 0.0, axisLength);\n }\n var tickLabelsBounds = tmp$;\n var builder = (new AxisLayoutInfo$Builder()).axisBreaks_hbp697$(ScaleBreaks.Companion.EMPTY).axisLength_14dthe$(axisLength).orientation_9y97dg$(this.myOrientation_0).axisDomain_4fzjta$(this.myAxisDomain_0).tickLabelsBounds_myx2hi$(tickLabelsBounds);\n return builder.build();\n };\n function EmptyAxisLayout$Companion() {\n EmptyAxisLayout$Companion_instance = this;\n }\n EmptyAxisLayout$Companion.prototype.bottom_gyv40k$ = function (xDomain, yDomain) {\n return new EmptyAxisLayout(xDomain, yDomain, Orientation$BOTTOM_getInstance());\n };\n EmptyAxisLayout$Companion.prototype.left_gyv40k$ = function (xDomain, yDomain) {\n return new EmptyAxisLayout(xDomain, yDomain, Orientation$LEFT_getInstance());\n };\n EmptyAxisLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var EmptyAxisLayout$Companion_instance = null;\n function EmptyAxisLayout$Companion_getInstance() {\n if (EmptyAxisLayout$Companion_instance === null) {\n new EmptyAxisLayout$Companion();\n }return EmptyAxisLayout$Companion_instance;\n }\n EmptyAxisLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'EmptyAxisLayout',\n interfaces: [AxisLayout]\n };\n function FacetGridPlotLayout(facets, tileLayout) {\n FacetGridPlotLayout$Companion_getInstance();\n PlotLayoutBase.call(this);\n this.facets_0 = facets;\n this.tileLayout_0 = tileLayout;\n this.totalPanelHorizontalPadding_0 = FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0 * (this.facets_0.colCount - 1 | 0);\n this.totalPanelVerticalPadding_0 = FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0 * (this.facets_0.rowCount - 1 | 0);\n this.setPadding_6y0v78$(10.0, 10.0, 0.0, 0.0);\n if (!this.facets_0.isDefined) {\n var message = 'Undefined facets.';\n throw IllegalArgumentException_init(message.toString());\n }}\n FacetGridPlotLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var tilesAreaSize = new DoubleVector(preferredSize.x - (this.paddingLeft_0 + this.paddingRight_0), preferredSize.y - (this.paddingTop_0 + this.paddingBottom_0));\n var facetTiles = this.facets_0.tileInfos();\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_3;\n tmp$_3 = facetTiles.iterator();\n while (tmp$_3.hasNext()) {\n var element = tmp$_3.next();\n if (!element.colLabs.isEmpty()) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var tileColLabCounts = (tmp$_1 = (tmp$_0 = (tmp$ = firstOrNull$result) != null ? tmp$.colLabs : null) != null ? tmp$_0.size : null) != null ? tmp$_1 : 0;\n var destination = ArrayList_init();\n var tmp$_4;\n tmp$_4 = facetTiles.iterator();\n while (tmp$_4.hasNext()) {\n var element_0 = tmp$_4.next();\n if (!element_0.colLabs.isEmpty())\n destination.add_11rb$(element_0);\n }\n var tmp$_5;\n var set = HashSet_init_0();\n var list = ArrayList_init();\n tmp$_5 = destination.iterator();\n while (tmp$_5.hasNext()) {\n var e = tmp$_5.next();\n var key = e.row;\n if (set.add_11rb$(key))\n list.add_11rb$(e);\n }\n var tileWithColLabInRowCount = list.size;\n var totalAddedHeight = FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(tileColLabCounts) * tileWithColLabInRowCount;\n var any$result;\n any$break: do {\n var tmp$_6;\n if (Kotlin.isType(facetTiles, Collection) && facetTiles.isEmpty()) {\n any$result = false;\n break any$break;\n }tmp$_6 = facetTiles.iterator();\n while (tmp$_6.hasNext()) {\n var element_1 = tmp$_6.next();\n if (element_1.rowLab != null) {\n any$result = true;\n break any$break;\n }}\n any$result = false;\n }\n while (false);\n var labsInRow = any$result ? 1 : 0;\n var labsTotalDim = new DoubleVector(labsInRow * FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT, totalAddedHeight);\n tilesAreaSize = tilesAreaSize.subtract_gpjtzr$(labsTotalDim);\n var tileWidth = (tilesAreaSize.x - this.totalPanelHorizontalPadding_0) / this.facets_0.colCount;\n var tileHeight = (tilesAreaSize.y - this.totalPanelVerticalPadding_0) / this.facets_0.rowCount;\n var tileInfo = this.layoutTile_0(tileWidth, tileHeight);\n for (var i = 0; i <= 1; i++) {\n var tilesAreaSizeNew = this.tilesAreaSize_0(tileInfo);\n var widthDiff = tilesAreaSize.x - tilesAreaSizeNew.x;\n var heightDiff = tilesAreaSize.y - tilesAreaSizeNew.y;\n var tmp$_7 = JsMath.abs(widthDiff) <= this.facets_0.colCount;\n if (tmp$_7) {\n tmp$_7 = JsMath.abs(heightDiff) <= this.facets_0.rowCount;\n }if (tmp$_7) {\n break;\n }var geomWidth = tileInfo.geomWidth_8be2vx$() + widthDiff / this.facets_0.colCount;\n var newPanelWidth = geomWidth + tileInfo.axisThicknessY_8be2vx$();\n var geomHeight = tileInfo.geomHeight_8be2vx$() + heightDiff / this.facets_0.rowCount;\n var newPanelHeight = geomHeight + tileInfo.axisThicknessX_8be2vx$();\n tileInfo = this.layoutTile_0(newPanelWidth, newPanelHeight);\n }\n var axisThicknessX = tileInfo.axisThicknessX_8be2vx$();\n var axisThicknessY = tileInfo.axisThicknessY_8be2vx$();\n var geomWidth_0 = tileInfo.geomWidth_8be2vx$();\n var geomHeight_0 = tileInfo.geomHeight_8be2vx$();\n var tilesAreaBounds = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n var tilesAreaOffset = new DoubleVector(this.paddingLeft_0, this.paddingTop_0);\n var tileInfos = ArrayList_init();\n var offsetX = 0.0;\n var offsetY = 0.0;\n var currRow = 0;\n var prevHeight = 0.0;\n tmp$_2 = facetTiles.iterator();\n while (tmp$_2.hasNext()) {\n var facetTile = tmp$_2.next();\n var width = geomWidth_0;\n var geomX = 0.0;\n if (facetTile.yAxis) {\n width += axisThicknessY;\n geomX = axisThicknessY;\n }if (facetTile.rowLab != null) {\n width += FacetGridPlotLayout$Companion_getInstance().FACET_TAB_HEIGHT;\n }var height = geomHeight_0;\n var geomY;\n if (facetTile.xAxis && facetTile.row === (this.facets_0.rowCount - 1 | 0)) {\n height += axisThicknessX;\n }var addedHeight = FacetGridPlotLayout$Companion_getInstance().facetColHeadHeight_za3lpa$(facetTile.colLabs.size);\n height += addedHeight;\n geomY = addedHeight;\n var bounds = DoubleRectangle_init(0.0, 0.0, width, height);\n var geomBounds = DoubleRectangle_init(geomX, geomY, geomWidth_0, geomHeight_0);\n var row = facetTile.row;\n if (row > currRow) {\n currRow = row;\n offsetY += prevHeight + FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0;\n }prevHeight = height;\n var col = facetTile.col;\n if (col === 0) {\n offsetX = 0.0;\n }var offset = new DoubleVector(offsetX, offsetY);\n offsetX += width + FacetGridPlotLayout$Companion_getInstance().PANEL_PADDING_0;\n var info = TileLayoutInfo_init(bounds, geomBounds, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds), tileInfo.layoutInfo_8be2vx$.xAxisInfo, tileInfo.layoutInfo_8be2vx$.yAxisInfo, facetTile.xAxis, facetTile.yAxis, facetTile.trueIndex).withOffset_gpjtzr$(tilesAreaOffset.add_gpjtzr$(offset)).withFacetLabels_5hkr16$(facetTile.colLabs, facetTile.rowLab);\n tileInfos.add_11rb$(info);\n tilesAreaBounds = tilesAreaBounds.union_wthzt5$(info.getAbsoluteBounds_gpjtzr$(tilesAreaOffset));\n }\n var plotSize = new DoubleVector(tilesAreaBounds.right + this.paddingRight_0, tilesAreaBounds.height + this.paddingBottom_0);\n return new PlotLayoutInfo(tileInfos, plotSize);\n };\n FacetGridPlotLayout.prototype.layoutTile_0 = function (tileWidth, tileHeight) {\n var layoutInfo = this.tileLayout_0.doLayout_gpjtzr$(new DoubleVector(tileWidth, tileHeight));\n return new FacetGridPlotLayout$MyTileInfo(layoutInfo);\n };\n FacetGridPlotLayout.prototype.tilesAreaSize_0 = function (tileInfo) {\n var w = tileInfo.geomWidth_8be2vx$() * this.facets_0.colCount + this.totalPanelHorizontalPadding_0 + tileInfo.axisThicknessY_8be2vx$();\n var h = tileInfo.geomHeight_8be2vx$() * this.facets_0.rowCount + this.totalPanelVerticalPadding_0 + tileInfo.axisThicknessX_8be2vx$();\n return new DoubleVector(w, h);\n };\n function FacetGridPlotLayout$MyTileInfo(layoutInfo) {\n this.layoutInfo_8be2vx$ = layoutInfo;\n }\n FacetGridPlotLayout$MyTileInfo.prototype.axisThicknessX_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.bounds.bottom - this.layoutInfo_8be2vx$.geomBounds.bottom;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.axisThicknessY_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.left - this.layoutInfo_8be2vx$.bounds.left;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.geomWidth_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.width;\n };\n FacetGridPlotLayout$MyTileInfo.prototype.geomHeight_8be2vx$ = function () {\n return this.layoutInfo_8be2vx$.geomBounds.height;\n };\n FacetGridPlotLayout$MyTileInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyTileInfo',\n interfaces: []\n };\n function FacetGridPlotLayout$Companion() {\n FacetGridPlotLayout$Companion_instance = this;\n this.FACET_TAB_HEIGHT = 30.0;\n this.FACET_H_PADDING = 0;\n this.FACET_V_PADDING = 6;\n this.PANEL_PADDING_0 = 10.0;\n }\n FacetGridPlotLayout$Companion.prototype.facetColLabelSize_14dthe$ = function (colWidth) {\n return new DoubleVector(colWidth - 0, this.FACET_TAB_HEIGHT - 6 * 2.0);\n };\n FacetGridPlotLayout$Companion.prototype.facetColHeadHeight_za3lpa$ = function (labCount) {\n var tmp$;\n if (labCount > 0) {\n tmp$ = this.facetColLabelSize_14dthe$(0.0).y * labCount + 12;\n } else {\n tmp$ = 0.0;\n }\n return tmp$;\n };\n FacetGridPlotLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var FacetGridPlotLayout$Companion_instance = null;\n function FacetGridPlotLayout$Companion_getInstance() {\n if (FacetGridPlotLayout$Companion_instance === null) {\n new FacetGridPlotLayout$Companion();\n }return FacetGridPlotLayout$Companion_instance;\n }\n FacetGridPlotLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FacetGridPlotLayout',\n interfaces: [PlotLayoutBase]\n };\n function GeometryUtil() {\n GeometryUtil_instance = this;\n }\n GeometryUtil.prototype.union_te9coj$ = function (first, optionalSecond) {\n var tmp$;\n if (optionalSecond == null) {\n tmp$ = first;\n } else\n tmp$ = first.union_wthzt5$(optionalSecond);\n return tmp$;\n };\n GeometryUtil.prototype.union_a7nkjf$ = function (head, c) {\n var tmp$;\n var result = head;\n tmp$ = c.iterator();\n while (tmp$.hasNext()) {\n var r = tmp$.next();\n result = result.union_wthzt5$(r);\n }\n return result;\n };\n GeometryUtil.prototype.doubleRange_gyv40k$ = function (xRange, yRange) {\n var xOrigin = xRange.lowerEnd;\n var yOrigin = yRange.lowerEnd;\n var xSpan = xRange.upperEnd - xRange.lowerEnd;\n var ySpan = yRange.upperEnd - yRange.lowerEnd;\n return DoubleRectangle_init(xOrigin, yOrigin, xSpan, ySpan);\n };\n GeometryUtil.prototype.changeWidth_j6cmed$ = function (r, width) {\n return DoubleRectangle_init(r.origin.x, r.origin.y, width, r.dimension.y);\n };\n GeometryUtil.prototype.changeWidthKeepRight_j6cmed$ = function (r, width) {\n return DoubleRectangle_init(r.right - width, r.origin.y, width, r.dimension.y);\n };\n GeometryUtil.prototype.changeHeight_j6cmed$ = function (r, height) {\n return DoubleRectangle_init(r.origin.x, r.origin.y, r.dimension.x, height);\n };\n GeometryUtil.prototype.changeHeightKeepBottom_j6cmed$ = function (r, height) {\n return DoubleRectangle_init(r.origin.x, r.bottom - height, r.dimension.x, height);\n };\n GeometryUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GeometryUtil',\n interfaces: []\n };\n var GeometryUtil_instance = null;\n function GeometryUtil_getInstance() {\n if (GeometryUtil_instance === null) {\n new GeometryUtil();\n }return GeometryUtil_instance;\n }\n function LegendBoxInfo(size) {\n LegendBoxInfo$Companion_getInstance();\n this.size_8be2vx$ = size;\n }\n Object.defineProperty(LegendBoxInfo.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n function LegendBoxInfo$Companion() {\n LegendBoxInfo$Companion_instance = this;\n this.EMPTY = new LegendBoxInfo$Companion$EMPTY$ObjectLiteral(DoubleVector.Companion.ZERO);\n }\n function LegendBoxInfo$Companion$EMPTY$ObjectLiteral(size) {\n LegendBoxInfo.call(this, size);\n }\n Object.defineProperty(LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype, 'isEmpty', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.prototype.createLegendBox = function () {\n throw IllegalStateException_init('Empty legend box info');\n };\n LegendBoxInfo$Companion$EMPTY$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendBoxInfo]\n };\n LegendBoxInfo$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LegendBoxInfo$Companion_instance = null;\n function LegendBoxInfo$Companion_getInstance() {\n if (LegendBoxInfo$Companion_instance === null) {\n new LegendBoxInfo$Companion();\n }return LegendBoxInfo$Companion_instance;\n }\n LegendBoxInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxInfo',\n interfaces: []\n };\n function LegendBoxesLayout(myPlotBounds, myTheme) {\n this.myPlotBounds_0 = myPlotBounds;\n this.myTheme_0 = myTheme;\n }\n LegendBoxesLayout.prototype.doLayout_8sg693$ = function (infos) {\n var legendPosition = this.myTheme_0.position();\n var legendJustification = this.myTheme_0.justification();\n var legendArrangement = LegendArrangement$VERTICAL_getInstance();\n var plotCenter = this.myPlotBounds_0.center;\n var plotInnerBoundsWithoutLegendBoxes = this.myPlotBounds_0;\n var boxWithLocationList = legendArrangement === LegendArrangement$VERTICAL_getInstance() ? LegendBoxesLayoutUtil_getInstance().verticalStack_8sg693$(infos) : LegendBoxesLayoutUtil_getInstance().horizontalStack_8sg693$(infos);\n var boxesSize = LegendBoxesLayoutUtil_getInstance().size_9w4uif$(boxWithLocationList);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT) || equals(legendPosition, LegendPosition$Companion_getInstance().RIGHT)) {\n var b = plotInnerBoundsWithoutLegendBoxes.width - boxesSize.x;\n var plotWidth = JsMath.max(0.0, b);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT)) {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeWidthKeepRight_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotWidth);\n } else {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeWidth_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotWidth);\n }\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP) || equals(legendPosition, LegendPosition$Companion_getInstance().BOTTOM)) {\n var b_0 = plotInnerBoundsWithoutLegendBoxes.height - boxesSize.y;\n var plotHeight = JsMath.max(0.0, b_0);\n if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP)) {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeHeightKeepBottom_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotHeight);\n } else {\n plotInnerBoundsWithoutLegendBoxes = GeometryUtil_getInstance().changeHeight_j6cmed$(plotInnerBoundsWithoutLegendBoxes, plotHeight);\n }\n }var legendOrigin;\n if (equals(legendPosition, LegendPosition$Companion_getInstance().LEFT)) {\n legendOrigin = new DoubleVector(plotInnerBoundsWithoutLegendBoxes.left - boxesSize.x, plotCenter.y - boxesSize.y / 2);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().RIGHT)) {\n legendOrigin = new DoubleVector(plotInnerBoundsWithoutLegendBoxes.right, plotCenter.y - boxesSize.y / 2);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().TOP)) {\n legendOrigin = new DoubleVector(plotCenter.x - boxesSize.x / 2, plotInnerBoundsWithoutLegendBoxes.top - boxesSize.y);\n } else if (equals(legendPosition, LegendPosition$Companion_getInstance().BOTTOM)) {\n legendOrigin = new DoubleVector(plotCenter.x - boxesSize.x / 2, plotInnerBoundsWithoutLegendBoxes.bottom);\n } else {\n legendOrigin = LegendBoxesLayoutUtil_getInstance().overlayLegendOrigin_tmgej$(plotInnerBoundsWithoutLegendBoxes, boxesSize, legendPosition, legendJustification);\n }\n var resultBoxWithLocationList = LegendBoxesLayoutUtil_getInstance().moveAll_cpge3q$(legendOrigin, boxWithLocationList);\n return new LegendBoxesLayout$Result(plotInnerBoundsWithoutLegendBoxes, resultBoxWithLocationList);\n };\n function LegendBoxesLayout$Result(plotInnerBoundsWithoutLegendBoxes, locations) {\n this.plotInnerBoundsWithoutLegendBoxes = plotInnerBoundsWithoutLegendBoxes;\n this.boxWithLocationList = ArrayList_init_1(locations);\n }\n LegendBoxesLayout$Result.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Result',\n interfaces: []\n };\n function LegendBoxesLayout$BoxWithLocation(legendBox, location) {\n this.legendBox = legendBox;\n this.location = location;\n }\n LegendBoxesLayout$BoxWithLocation.prototype.size_8be2vx$ = function () {\n return this.legendBox.size_8be2vx$;\n };\n LegendBoxesLayout$BoxWithLocation.prototype.bounds_8be2vx$ = function () {\n return new DoubleRectangle(this.location, this.legendBox.size_8be2vx$);\n };\n LegendBoxesLayout$BoxWithLocation.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'BoxWithLocation',\n interfaces: []\n };\n LegendBoxesLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LegendBoxesLayout',\n interfaces: []\n };\n function LegendBoxesLayoutUtil() {\n LegendBoxesLayoutUtil_instance = this;\n }\n LegendBoxesLayoutUtil.prototype.verticalStack_8sg693$ = function (boxInfos) {\n var tmp$;\n var result = ArrayList_init();\n var y = 0.0;\n tmp$ = boxInfos.iterator();\n while (tmp$.hasNext()) {\n var info = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(info, new DoubleVector(0.0, y)));\n y += info.size_8be2vx$.y;\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.horizontalStack_8sg693$ = function (boxInfos) {\n var tmp$;\n var result = ArrayList_init();\n var x = 0.0;\n tmp$ = boxInfos.iterator();\n while (tmp$.hasNext()) {\n var info = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(info, new DoubleVector(x, 0.0)));\n x += info.size_8be2vx$.x;\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.moveAll_cpge3q$ = function (delta, boxWithLocationList) {\n var tmp$;\n var result = ArrayList_init();\n tmp$ = boxWithLocationList.iterator();\n while (tmp$.hasNext()) {\n var boxWithLocation = tmp$.next();\n result.add_11rb$(new LegendBoxesLayout$BoxWithLocation(boxWithLocation.legendBox, boxWithLocation.location.add_gpjtzr$(delta)));\n }\n return result;\n };\n LegendBoxesLayoutUtil.prototype.size_9w4uif$ = function (boxWithLocationList) {\n var tmp$, tmp$_0, tmp$_1;\n var bounds = null;\n tmp$ = boxWithLocationList.iterator();\n while (tmp$.hasNext()) {\n var boxWithLocation = tmp$.next();\n bounds = (tmp$_0 = bounds != null ? bounds.union_wthzt5$(boxWithLocation.bounds_8be2vx$()) : null) != null ? tmp$_0 : boxWithLocation.bounds_8be2vx$();\n }\n return (tmp$_1 = bounds != null ? bounds.dimension : null) != null ? tmp$_1 : DoubleVector.Companion.ZERO;\n };\n LegendBoxesLayoutUtil.prototype.overlayLegendOrigin_tmgej$ = function (plotBounds, legendSize, legendPosition, legendJustification) {\n var plotSize = plotBounds.dimension;\n var absolutePosition = new DoubleVector(plotBounds.left + plotSize.x * legendPosition.x, plotBounds.bottom - plotSize.y * legendPosition.y);\n var originOffset = new DoubleVector(-legendSize.x * legendJustification.x, legendSize.y * legendJustification.y - legendSize.y);\n return absolutePosition.add_gpjtzr$(originOffset);\n };\n LegendBoxesLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LegendBoxesLayoutUtil',\n interfaces: []\n };\n var LegendBoxesLayoutUtil_instance = null;\n function LegendBoxesLayoutUtil_getInstance() {\n if (LegendBoxesLayoutUtil_instance === null) {\n new LegendBoxesLayoutUtil();\n }return LegendBoxesLayoutUtil_instance;\n }\n function LiveMapTileLayout() {\n }\n LiveMapTileLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var geomBounds = XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(0.0, 0.0, preferredSize);\n geomBounds = geomBounds.union_wthzt5$(new DoubleRectangle(geomBounds.origin, XYPlotLayoutUtil_getInstance().GEOM_MIN_SIZE));\n var geomWithAxisBounds = geomBounds;\n return TileLayoutInfo_init(geomWithAxisBounds, geomBounds, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds), null, null, void 0, void 0, 0);\n };\n LiveMapTileLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LiveMapTileLayout',\n interfaces: [TileLayout]\n };\n function PlotAxisLayout(scale, domainX, domainY, coordProvider, theme, orientation) {\n PlotAxisLayout$Companion_getInstance();\n this.scale_0 = scale;\n this.domainX_0 = domainX;\n this.domainY_0 = domainY;\n this.coordProvider_0 = coordProvider;\n this.theme_0 = theme;\n this.orientation_0 = orientation;\n }\n PlotAxisLayout.prototype.initialThickness = function () {\n var tmp$;\n if (this.theme_0.showTickMarks() || this.theme_0.showTickLabels()) {\n var v = this.theme_0.tickLabelDistance();\n if (this.theme_0.showTickLabels()) {\n tmp$ = v + PlotAxisLayout$Companion_getInstance().initialTickLabelSize_0(this.orientation_0);\n } else {\n tmp$ = v;\n }\n return tmp$;\n }return 0.0;\n };\n PlotAxisLayout.prototype.doLayout_o2m17x$ = function (displaySize, maxTickLabelsBoundsStretched) {\n var layouter = this.createLayouter_0(displaySize);\n return layouter.doLayout_p1d3jc$(PlotAxisLayout$Companion_getInstance().axisLength_0(displaySize, this.orientation_0), maxTickLabelsBoundsStretched);\n };\n PlotAxisLayout.prototype.createLayouter_0 = function (displaySize) {\n var domains = this.coordProvider_0.adjustDomains_jz8wgn$(this.domainX_0, this.domainY_0, displaySize);\n var axisDomain = PlotAxisLayout$Companion_getInstance().axisDomain_0(domains, this.orientation_0);\n var breaksProvider = AxisBreaksUtil_getInstance().createAxisBreaksProvider_oftday$(this.scale_0, axisDomain);\n return AxisLayouter$Companion_getInstance().create_4ebi60$(this.orientation_0, axisDomain, breaksProvider, this.theme_0);\n };\n function PlotAxisLayout$Companion() {\n PlotAxisLayout$Companion_instance = this;\n this.TICK_LABEL_SPEC_0 = PlotLabelSpec$AXIS_TICK_getInstance();\n }\n PlotAxisLayout$Companion.prototype.bottom_eknalg$ = function (scale, xDomain, yDomain, coordProvider, theme) {\n return new PlotAxisLayout(scale, xDomain, yDomain, coordProvider, theme, Orientation$BOTTOM_getInstance());\n };\n PlotAxisLayout$Companion.prototype.left_eknalg$ = function (scale, xDomain, yDomain, coordProvider, theme) {\n return new PlotAxisLayout(scale, xDomain, yDomain, coordProvider, theme, Orientation$LEFT_getInstance());\n };\n PlotAxisLayout$Companion.prototype.initialTickLabelSize_0 = function (orientation) {\n return orientation.isHorizontal ? this.TICK_LABEL_SPEC_0.height() : this.TICK_LABEL_SPEC_0.width_za3lpa$(1);\n };\n PlotAxisLayout$Companion.prototype.axisLength_0 = function (displaySize, orientation) {\n return orientation.isHorizontal ? displaySize.x : displaySize.y;\n };\n PlotAxisLayout$Companion.prototype.axisDomain_0 = function (xyDomains, orientation) {\n return orientation.isHorizontal ? xyDomains.first : xyDomains.second;\n };\n PlotAxisLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PlotAxisLayout$Companion_instance = null;\n function PlotAxisLayout$Companion_getInstance() {\n if (PlotAxisLayout$Companion_instance === null) {\n new PlotAxisLayout$Companion();\n }return PlotAxisLayout$Companion_instance;\n }\n PlotAxisLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotAxisLayout',\n interfaces: [AxisLayout]\n };\n function PlotLayout() {\n }\n PlotLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PlotLayout',\n interfaces: []\n };\n function PlotLayoutBase() {\n this.paddingTop_72hspu$_0 = 0.0;\n this.paddingRight_oc6xpz$_0 = 0.0;\n this.paddingBottom_phgrg6$_0 = 0.0;\n this.paddingLeft_66kgx2$_0 = 0.0;\n }\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingTop_0', {\n configurable: true,\n get: function () {\n return this.paddingTop_72hspu$_0;\n },\n set: function (paddingTop) {\n this.paddingTop_72hspu$_0 = paddingTop;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingRight_0', {\n configurable: true,\n get: function () {\n return this.paddingRight_oc6xpz$_0;\n },\n set: function (paddingRight) {\n this.paddingRight_oc6xpz$_0 = paddingRight;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingBottom_0', {\n configurable: true,\n get: function () {\n return this.paddingBottom_phgrg6$_0;\n },\n set: function (paddingBottom) {\n this.paddingBottom_phgrg6$_0 = paddingBottom;\n }\n });\n Object.defineProperty(PlotLayoutBase.prototype, 'paddingLeft_0', {\n configurable: true,\n get: function () {\n return this.paddingLeft_66kgx2$_0;\n },\n set: function (paddingLeft) {\n this.paddingLeft_66kgx2$_0 = paddingLeft;\n }\n });\n PlotLayoutBase.prototype.setPadding_6y0v78$ = function (top, right, bottom, left) {\n this.paddingTop_0 = top;\n this.paddingRight_0 = right;\n this.paddingBottom_0 = bottom;\n this.paddingLeft_0 = left;\n };\n PlotLayoutBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLayoutBase',\n interfaces: [PlotLayout]\n };\n function PlotLayoutInfo(tiles, size) {\n this.size = size;\n this.tiles = ArrayList_init_1(tiles);\n }\n PlotLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLayoutInfo',\n interfaces: []\n };\n function PlotLayoutUtil() {\n PlotLayoutUtil_instance = this;\n this.AXIS_TITLE_OUTER_MARGIN = 4.0;\n this.AXIS_TITLE_INNER_MARGIN = 4.0;\n this.TITLE_V_MARGIN_0 = 4.0;\n this.LIVE_MAP_PLOT_PADDING_0 = new DoubleVector(10.0, 0.0);\n this.LIVE_MAP_PLOT_MARGIN_0 = new DoubleVector(10.0, 10.0);\n }\n PlotLayoutUtil.prototype.titleDimensions_61zpoe$ = function (text) {\n if (base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n return DoubleVector.Companion.ZERO;\n }var labelSpec = PlotLabelSpec$PLOT_TITLE_getInstance();\n return new DoubleVector(labelSpec.width_za3lpa$(text.length), labelSpec.height() + 2 * this.TITLE_V_MARGIN_0);\n };\n PlotLayoutUtil.prototype.axisTitleDimensions_61zpoe$ = function (text) {\n if (base.Strings.isNullOrEmpty_pdl1vj$(text)) {\n return DoubleVector.Companion.ZERO;\n }var labelSpec = PlotLabelSpec$AXIS_TITLE_getInstance();\n return new DoubleVector(labelSpec.width_za3lpa$(text.length), labelSpec.height());\n };\n PlotLayoutUtil.prototype.absoluteGeomBounds_vjhcds$ = function (origin, plotLayoutInfo) {\n var tmp$, tmp$_0;\n if (!!plotLayoutInfo.tiles.isEmpty()) {\n var message = 'Plot is empty';\n throw IllegalArgumentException_init(message.toString());\n }var result = null;\n tmp$ = plotLayoutInfo.tiles.iterator();\n while (tmp$.hasNext()) {\n var tile = tmp$.next();\n var geomBounds = tile.getAbsoluteGeomBounds_gpjtzr$(origin);\n result = (tmp$_0 = result != null ? result.union_wthzt5$(geomBounds) : null) != null ? tmp$_0 : geomBounds;\n }\n return ensureNotNull(result);\n };\n PlotLayoutUtil.prototype.liveMapBounds_wthzt5$ = function (container) {\n return new DoubleRectangle(container.origin.add_gpjtzr$(this.LIVE_MAP_PLOT_PADDING_0), container.dimension.subtract_gpjtzr$(this.LIVE_MAP_PLOT_MARGIN_0));\n };\n PlotLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PlotLayoutUtil',\n interfaces: []\n };\n var PlotLayoutUtil_instance = null;\n function PlotLayoutUtil_getInstance() {\n if (PlotLayoutUtil_instance === null) {\n new PlotLayoutUtil();\n }return PlotLayoutUtil_instance;\n }\n function SingleTilePlotLayout(myTileLayout) {\n PlotLayoutBase.call(this);\n this.myTileLayout_0 = myTileLayout;\n this.setPadding_6y0v78$(10.0, 10.0, 0.0, 0.0);\n }\n SingleTilePlotLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tilePreferredSize = new DoubleVector(preferredSize.x - (this.paddingLeft_0 + this.paddingRight_0), preferredSize.y - (this.paddingTop_0 + this.paddingBottom_0));\n var tileInfo = this.myTileLayout_0.doLayout_gpjtzr$(tilePreferredSize);\n tileInfo = tileInfo.withOffset_gpjtzr$(new DoubleVector(this.paddingLeft_0, this.paddingTop_0));\n var plotSize = tileInfo.bounds.dimension;\n plotSize = plotSize.add_gpjtzr$(new DoubleVector(this.paddingRight_0, this.paddingBottom_0));\n return new PlotLayoutInfo(listOf(tileInfo), plotSize);\n };\n SingleTilePlotLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SingleTilePlotLayout',\n interfaces: [PlotLayoutBase]\n };\n function TileLayout() {\n }\n TileLayout.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'TileLayout',\n interfaces: []\n };\n function TileLayoutInfo(plotOrigin, bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, facetXLabels, facetYLabel, trueIndex) {\n this.plotOrigin = plotOrigin;\n this.bounds = bounds;\n this.geomBounds = geomBounds;\n this.clipBounds = clipBounds;\n this.xAxisInfo = xAxisInfo;\n this.yAxisInfo = yAxisInfo;\n this.facetXLabels = facetXLabels;\n this.facetYLabel = facetYLabel;\n this.trueIndex = trueIndex;\n this.xAxisShown = (this.xAxisInfo != null && xAxisShown);\n this.yAxisShown = (this.yAxisInfo != null && yAxisShown);\n }\n TileLayoutInfo.prototype.withOffset_gpjtzr$ = function (offset) {\n return new TileLayoutInfo(offset, this.bounds, this.geomBounds, this.clipBounds, this.xAxisInfo, this.yAxisInfo, this.xAxisShown, this.yAxisShown, this.facetXLabels, this.facetYLabel, this.trueIndex);\n };\n TileLayoutInfo.prototype.getAbsoluteBounds_gpjtzr$ = function (tilesOrigin) {\n var offset = tilesOrigin.add_gpjtzr$(this.plotOrigin);\n return this.bounds.add_gpjtzr$(offset);\n };\n TileLayoutInfo.prototype.getAbsoluteGeomBounds_gpjtzr$ = function (tilesOrigin) {\n var offset = tilesOrigin.add_gpjtzr$(this.plotOrigin);\n return this.geomBounds.add_gpjtzr$(offset);\n };\n TileLayoutInfo.prototype.withFacetLabels_5hkr16$ = function (xLabels, yLabel) {\n return new TileLayoutInfo(this.plotOrigin, this.bounds, this.geomBounds, this.clipBounds, this.xAxisInfo, this.yAxisInfo, this.xAxisShown, this.yAxisShown, xLabels, yLabel, this.trueIndex);\n };\n TileLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TileLayoutInfo',\n interfaces: []\n };\n function TileLayoutInfo_init(bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, trueIndex, $this) {\n if (xAxisShown === void 0)\n xAxisShown = true;\n if (yAxisShown === void 0)\n yAxisShown = true;\n $this = $this || Object.create(TileLayoutInfo.prototype);\n TileLayoutInfo.call($this, DoubleVector.Companion.ZERO, bounds, geomBounds, clipBounds, xAxisInfo, yAxisInfo, xAxisShown, yAxisShown, emptyList(), null, trueIndex);\n return $this;\n }\n function XYPlotLayoutUtil() {\n XYPlotLayoutUtil_instance = this;\n this.GEOM_MARGIN = 0.0;\n this.CLIP_EXTEND_0 = 5.0;\n this.GEOM_MIN_SIZE = new DoubleVector(50.0, 50.0);\n }\n XYPlotLayoutUtil.prototype.geomBounds_pym7oz$ = function (xAxisThickness, yAxisThickness, plotSize) {\n var marginLeftTop = new DoubleVector(yAxisThickness, this.GEOM_MARGIN);\n var marginRightBottom = new DoubleVector(this.GEOM_MARGIN, xAxisThickness);\n var geomSize = plotSize.subtract_gpjtzr$(marginLeftTop).subtract_gpjtzr$(marginRightBottom);\n if (geomSize.x < this.GEOM_MIN_SIZE.x) {\n geomSize = new DoubleVector(this.GEOM_MIN_SIZE.x, geomSize.y);\n }if (geomSize.y < this.GEOM_MIN_SIZE.y) {\n geomSize = new DoubleVector(geomSize.x, this.GEOM_MIN_SIZE.y);\n }return new DoubleRectangle(marginLeftTop, geomSize);\n };\n XYPlotLayoutUtil.prototype.clipBounds_wthzt5$ = function (geomBounds) {\n return new DoubleRectangle(geomBounds.origin.subtract_gpjtzr$(new DoubleVector(this.CLIP_EXTEND_0, this.CLIP_EXTEND_0)), new DoubleVector(geomBounds.dimension.x + 2 * this.CLIP_EXTEND_0, geomBounds.dimension.y + 2 * this.CLIP_EXTEND_0));\n };\n XYPlotLayoutUtil.prototype.maxTickLabelsBounds_m3y558$ = function (axisOrientation, stretch, geomBounds, plotSize) {\n var tmp$;\n var geomPaddung = 10.0;\n var maxGeomBounds = DoubleRectangle_init(geomPaddung, geomPaddung, plotSize.x - 2 * geomPaddung, plotSize.y - 2 * geomPaddung);\n switch (axisOrientation.name) {\n case 'TOP':\n case 'BOTTOM':\n var leftSpace = geomBounds.left - maxGeomBounds.left + stretch;\n var rightSpace = maxGeomBounds.right - geomBounds.right + stretch;\n var height = 1.0E42;\n if (equals(axisOrientation, Orientation$TOP_getInstance()))\n tmp$ = -height;\n else\n tmp$ = 0.0;\n var top = tmp$;\n var left = -leftSpace;\n var width = leftSpace + rightSpace + geomBounds.width;\n return DoubleRectangle_init(left, top, width, height);\n default:throw IllegalArgumentException_init('Orientation not supported: ' + axisOrientation);\n }\n };\n XYPlotLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'XYPlotLayoutUtil',\n interfaces: []\n };\n var XYPlotLayoutUtil_instance = null;\n function XYPlotLayoutUtil_getInstance() {\n if (XYPlotLayoutUtil_instance === null) {\n new XYPlotLayoutUtil();\n }return XYPlotLayoutUtil_instance;\n }\n function XYPlotTileLayout(xAxisLayout, yAxisLayout) {\n XYPlotTileLayout$Companion_getInstance();\n this.xAxisLayout_0 = xAxisLayout;\n this.yAxisLayout_0 = yAxisLayout;\n }\n XYPlotTileLayout.prototype.doLayout_gpjtzr$ = function (preferredSize) {\n var tmp$ = XYPlotTileLayout$Companion_getInstance().computeAxisInfos_0(this.xAxisLayout_0, this.yAxisLayout_0, preferredSize);\n var xAxisInfo = {v: tmp$.component1()}\n , yAxisInfo = tmp$.component2();\n var geomBounds = {v: XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisInfo.v.axisBounds().dimension.y, yAxisInfo.axisBounds().dimension.x, preferredSize)};\n var maxTickLabelsBounds = XYPlotLayoutUtil_getInstance().maxTickLabelsBounds_m3y558$(Orientation$BOTTOM_getInstance(), 0.0, geomBounds.v, preferredSize);\n var tickLabelsBounds = xAxisInfo.v.tickLabelsBounds;\n var leftOverflow = maxTickLabelsBounds.left - ensureNotNull(tickLabelsBounds).origin.x;\n var rightOverflow = tickLabelsBounds.origin.x + tickLabelsBounds.dimension.x - maxTickLabelsBounds.right;\n if (leftOverflow > 0) {\n geomBounds.v = DoubleRectangle_init(geomBounds.v.origin.x + leftOverflow, geomBounds.v.origin.y, geomBounds.v.dimension.x - leftOverflow, geomBounds.v.dimension.y);\n }if (rightOverflow > 0) {\n geomBounds.v = DoubleRectangle_init(geomBounds.v.origin.x, geomBounds.v.origin.y, geomBounds.v.dimension.x - rightOverflow, geomBounds.v.dimension.y);\n }geomBounds.v = geomBounds.v.union_wthzt5$(new DoubleRectangle(geomBounds.v.origin, XYPlotLayoutUtil_getInstance().GEOM_MIN_SIZE));\n var geomWithAxisBounds = XYPlotTileLayout$Companion_getInstance().tileBounds_0(xAxisInfo.v.axisBounds(), yAxisInfo.axisBounds(), geomBounds.v);\n xAxisInfo.v = xAxisInfo.v.withAxisLength_14dthe$(geomBounds.v.width).build();\n yAxisInfo = yAxisInfo.withAxisLength_14dthe$(geomBounds.v.height).build();\n return TileLayoutInfo_init(geomWithAxisBounds, geomBounds.v, XYPlotLayoutUtil_getInstance().clipBounds_wthzt5$(geomBounds.v), xAxisInfo.v, yAxisInfo, void 0, void 0, 0);\n };\n function XYPlotTileLayout$Companion() {\n XYPlotTileLayout$Companion_instance = this;\n this.AXIS_STRETCH_RATIO_0 = 0.1;\n }\n XYPlotTileLayout$Companion.prototype.tileBounds_0 = function (xAxisBounds, yAxisBounds, geomBounds) {\n var leftTop = new DoubleVector(geomBounds.left - yAxisBounds.width, geomBounds.top - XYPlotLayoutUtil_getInstance().GEOM_MARGIN);\n var rightBottom = new DoubleVector(geomBounds.right + XYPlotLayoutUtil_getInstance().GEOM_MARGIN, geomBounds.bottom + xAxisBounds.height);\n return new DoubleRectangle(leftTop, rightBottom.subtract_gpjtzr$(leftTop));\n };\n XYPlotTileLayout$Companion.prototype.computeAxisInfos_0 = function (xAxisLayout, yAxisLayout, plotSize) {\n var xAxisThickness = xAxisLayout.initialThickness();\n var yAxisInfo = this.computeYAxisInfo_0(yAxisLayout, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisThickness, yAxisLayout.initialThickness(), plotSize));\n var yAxisThickness = yAxisInfo.axisBounds().dimension.x;\n var xAxisInfo = this.computeXAxisInfo_0(xAxisLayout, plotSize, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisThickness, yAxisThickness, plotSize));\n if (xAxisInfo.axisBounds().dimension.y > xAxisThickness) {\n yAxisInfo = this.computeYAxisInfo_0(yAxisLayout, XYPlotLayoutUtil_getInstance().geomBounds_pym7oz$(xAxisInfo.axisBounds().dimension.y, yAxisThickness, plotSize));\n }return new Pair_0(xAxisInfo, yAxisInfo);\n };\n XYPlotTileLayout$Companion.prototype.computeXAxisInfo_0 = function (axisLayout, plotSize, geomBounds) {\n var axisLength = geomBounds.dimension.x;\n var stretch = axisLength * this.AXIS_STRETCH_RATIO_0;\n var maxTickLabelsBounds = XYPlotLayoutUtil_getInstance().maxTickLabelsBounds_m3y558$(Orientation$BOTTOM_getInstance(), stretch, geomBounds, plotSize);\n return axisLayout.doLayout_o2m17x$(geomBounds.dimension, maxTickLabelsBounds);\n };\n XYPlotTileLayout$Companion.prototype.computeYAxisInfo_0 = function (axisLayout, geomBounds) {\n return axisLayout.doLayout_o2m17x$(geomBounds.dimension, null);\n };\n XYPlotTileLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var XYPlotTileLayout$Companion_instance = null;\n function XYPlotTileLayout$Companion_getInstance() {\n if (XYPlotTileLayout$Companion_instance === null) {\n new XYPlotTileLayout$Companion();\n }return XYPlotTileLayout$Companion_instance;\n }\n XYPlotTileLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'XYPlotTileLayout',\n interfaces: [TileLayout]\n };\n function AdaptableAxisBreaksProvider(domainAfterTransform, breaksGenerator) {\n this.domainAfterTransform_0 = domainAfterTransform;\n this.breaksGenerator_0 = breaksGenerator;\n }\n Object.defineProperty(AdaptableAxisBreaksProvider.prototype, 'isFixedBreaks', {\n configurable: true,\n get: function () {\n return false;\n }\n });\n Object.defineProperty(AdaptableAxisBreaksProvider.prototype, 'fixedBreaks', {\n configurable: true,\n get: function () {\n throw IllegalStateException_init('Not a fixed breaks provider');\n }\n });\n AdaptableAxisBreaksProvider.prototype.getBreaks_5wr77w$ = function (targetCount, axisLength) {\n var scaleBreaks = this.breaksGenerator_0.generateBreaks_1tlvto$(this.domainAfterTransform_0, targetCount);\n return scaleBreaks;\n };\n AdaptableAxisBreaksProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AdaptableAxisBreaksProvider',\n interfaces: [AxisBreaksProvider]\n };\n function AxisBreaksProvider() {\n }\n AxisBreaksProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisBreaksProvider',\n interfaces: []\n };\n function AxisBreaksUtil() {\n AxisBreaksUtil_instance = this;\n }\n AxisBreaksUtil.prototype.createAxisBreaksProvider_oftday$ = function (scale, axisDomain) {\n if (scale.hasBreaks())\n return new FixedAxisBreaksProvider(scale.getScaleBreaks());\n else {\n return new AdaptableAxisBreaksProvider(axisDomain, scale.getBreaksGenerator());\n }\n };\n AxisBreaksUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'AxisBreaksUtil',\n interfaces: []\n };\n var AxisBreaksUtil_instance = null;\n function AxisBreaksUtil_getInstance() {\n if (AxisBreaksUtil_instance === null) {\n new AxisBreaksUtil();\n }return AxisBreaksUtil_instance;\n }\n function AxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter$Companion_getInstance();\n this.orientation = orientation;\n this.domainRange_jxchw$_0 = domainRange;\n this.labelsLayout_ft0nu6$_0 = labelsLayout;\n }\n AxisLayouter.prototype.doLayout_p1d3jc$ = function (axisLength, maxTickLabelsBounds) {\n var labelsInfo = this.labelsLayout_ft0nu6$_0.doLayout_s0wrr0$(axisLength, this.toAxisMapper_14dthe$(axisLength), maxTickLabelsBounds);\n var labelsBounds = labelsInfo.bounds;\n var builder = (new AxisLayoutInfo$Builder()).axisBreaks_hbp697$(labelsInfo.breaks).axisLength_14dthe$(axisLength).orientation_9y97dg$(this.orientation).axisDomain_4fzjta$(this.domainRange_jxchw$_0).tickLabelsBoundsMax_myx2hi$(maxTickLabelsBounds).tickLabelSmallFont_6taknv$(labelsInfo.smallFont).tickLabelAdditionalOffsets_eajcfd$(labelsInfo.labelAdditionalOffsets).tickLabelHorizontalAnchor_tk0ev1$(labelsInfo.labelHorizontalAnchor).tickLabelVerticalAnchor_24j3ht$(labelsInfo.labelVerticalAnchor).tickLabelRotationAngle_14dthe$(labelsInfo.labelRotationAngle).tickLabelsBounds_myx2hi$(labelsBounds);\n return builder.build();\n };\n AxisLayouter.prototype.toScaleMapper_14dthe$ = function (axisLength) {\n return scale.Mappers.mul_mdyssk$(this.domainRange_jxchw$_0, axisLength);\n };\n function AxisLayouter$Companion() {\n AxisLayouter$Companion_instance = this;\n }\n AxisLayouter$Companion.prototype.create_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n var tmp$, tmp$_0;\n if (orientation.isHorizontal) {\n if (breaksProvider.isFixedBreaks) {\n tmp$ = AxisLabelsLayout$Companion_getInstance().horizontalFixedBreaks_3unth9$(orientation, axisDomain, breaksProvider.fixedBreaks, theme);\n } else {\n tmp$ = AxisLabelsLayout$Companion_getInstance().horizontalFlexBreaks_4ebi60$(orientation, axisDomain, breaksProvider, theme);\n }\n var labelsLayout = tmp$;\n return new HorizontalAxisLayouter(orientation, axisDomain, labelsLayout);\n }if (breaksProvider.isFixedBreaks) {\n tmp$_0 = AxisLabelsLayout$Companion_getInstance().verticalFixedBreaks_3unth9$(orientation, axisDomain, breaksProvider.fixedBreaks, theme);\n } else {\n tmp$_0 = AxisLabelsLayout$Companion_getInstance().verticalFlexBreaks_4ebi60$(orientation, axisDomain, breaksProvider, theme);\n }\n var labelsLayout_0 = tmp$_0;\n return new VerticalAxisLayouter(orientation, axisDomain, labelsLayout_0);\n };\n AxisLayouter$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AxisLayouter$Companion_instance = null;\n function AxisLayouter$Companion_getInstance() {\n if (AxisLayouter$Companion_instance === null) {\n new AxisLayouter$Companion();\n }return AxisLayouter$Companion_instance;\n }\n AxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLayouter',\n interfaces: []\n };\n function FixedAxisBreaksProvider(fixedBreaks) {\n this.fixedBreaks_cixykn$_0 = fixedBreaks;\n }\n Object.defineProperty(FixedAxisBreaksProvider.prototype, 'fixedBreaks', {\n get: function () {\n return this.fixedBreaks_cixykn$_0;\n }\n });\n Object.defineProperty(FixedAxisBreaksProvider.prototype, 'isFixedBreaks', {\n configurable: true,\n get: function () {\n return true;\n }\n });\n FixedAxisBreaksProvider.prototype.getBreaks_5wr77w$ = function (targetCount, axisLength) {\n return this.fixedBreaks;\n };\n FixedAxisBreaksProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'FixedAxisBreaksProvider',\n interfaces: [AxisBreaksProvider]\n };\n function HorizontalAxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter.call(this, orientation, domainRange, labelsLayout);\n }\n function HorizontalAxisLayouter$toAxisMapper$lambda(closure$scaleMapper, closure$cartesianX) {\n return function (v) {\n var mapped = closure$scaleMapper(v);\n return mapped != null ? closure$cartesianX(mapped) : null;\n };\n }\n HorizontalAxisLayouter.prototype.toAxisMapper_14dthe$ = function (axisLength) {\n var scaleMapper = this.toScaleMapper_14dthe$(axisLength);\n var cartesianX = coord.Coords.toClientOffsetX_4fzjta$(new ClosedRange(0.0, axisLength));\n return HorizontalAxisLayouter$toAxisMapper$lambda(scaleMapper, cartesianX);\n };\n HorizontalAxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalAxisLayouter',\n interfaces: [AxisLayouter]\n };\n function VerticalAxisLayouter(orientation, domainRange, labelsLayout) {\n AxisLayouter.call(this, orientation, domainRange, labelsLayout);\n }\n function VerticalAxisLayouter$toAxisMapper$lambda(closure$scaleMapper, closure$cartesianY) {\n return function (v) {\n var mapped = closure$scaleMapper(v);\n return mapped != null ? closure$cartesianY(mapped) : null;\n };\n }\n VerticalAxisLayouter.prototype.toAxisMapper_14dthe$ = function (axisLength) {\n var scaleMapper = this.toScaleMapper_14dthe$(axisLength);\n var cartesianY = coord.Coords.toClientOffsetY_4fzjta$(new ClosedRange(0.0, axisLength));\n return VerticalAxisLayouter$toAxisMapper$lambda(scaleMapper, cartesianY);\n };\n VerticalAxisLayouter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalAxisLayouter',\n interfaces: [AxisLayouter]\n };\n function AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout$Companion_getInstance();\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.breaks_0 = breaks;\n }\n AbstractFixedBreaksLabelsLayout.prototype.labelBounds_0 = function (labelLocation, labelLength) {\n var dim = this.labelSpec.dimensions_za3lpa$(labelLength);\n var labelBounds = this.labelBounds_gpjtzr$(dim);\n return labelBounds.add_gpjtzr$(labelLocation);\n };\n AbstractFixedBreaksLabelsLayout.prototype.labelsBounds_c3fefx$ = function (tickPositions, tickLabels, toTickLocation) {\n var tmp$;\n var boundsList = this.labelBoundsList_c3fefx$(tickPositions, this.breaks_0.labels, toTickLocation);\n var bounds = null;\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n bounds = GeometryUtil_getInstance().union_te9coj$(labelBounds, bounds);\n }\n return bounds;\n };\n AbstractFixedBreaksLabelsLayout.prototype.labelBoundsList_c3fefx$ = function (tickPositions, tickLabels, toTickLocation) {\n var tmp$;\n var result = ArrayList_init();\n var labels = tickLabels.iterator();\n tmp$ = tickPositions.iterator();\n while (tmp$.hasNext()) {\n var pos = tmp$.next();\n var label = labels.next();\n var bounds = this.labelBounds_0(toTickLocation(pos), label.length);\n result.add_11rb$(bounds);\n }\n return result;\n };\n AbstractFixedBreaksLabelsLayout.prototype.createAxisLabelsLayoutInfoBuilder_fd842m$ = function (bounds, overlap) {\n return (new AxisLabelsLayoutInfo$Builder()).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(bounds)).smallFont_6taknv$(false).overlap_6taknv$(overlap);\n };\n AbstractFixedBreaksLabelsLayout.prototype.noLabelsLayoutInfo_c0p8fa$ = function (axisLength, orientation) {\n if (orientation.isHorizontal) {\n var bounds = DoubleRectangle_init(axisLength / 2, 0.0, 0.0, 0.0);\n bounds = this.applyLabelsOffset_w7e9pi$(bounds);\n return (new AxisLabelsLayoutInfo$Builder()).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(bounds).smallFont_6taknv$(false).overlap_6taknv$(false).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n }throw IllegalStateException_init('Not implemented for ' + orientation);\n };\n function AbstractFixedBreaksLabelsLayout$Companion() {\n AbstractFixedBreaksLabelsLayout$Companion_instance = this;\n this.HORIZONTAL_TICK_LOCATION = AbstractFixedBreaksLabelsLayout$Companion$HORIZONTAL_TICK_LOCATION$lambda;\n }\n function AbstractFixedBreaksLabelsLayout$Companion$HORIZONTAL_TICK_LOCATION$lambda(x) {\n return new DoubleVector(x, 0.0);\n }\n AbstractFixedBreaksLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AbstractFixedBreaksLabelsLayout$Companion_instance = null;\n function AbstractFixedBreaksLabelsLayout$Companion_getInstance() {\n if (AbstractFixedBreaksLabelsLayout$Companion_instance === null) {\n new AbstractFixedBreaksLabelsLayout$Companion();\n }return AbstractFixedBreaksLabelsLayout$Companion_instance;\n }\n AbstractFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AbstractFixedBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n AxisLabelsLayout$Companion_getInstance();\n this.orientation = orientation;\n this.axisDomain = axisDomain;\n this.labelSpec = labelSpec;\n this.theme = theme;\n }\n Object.defineProperty(AxisLabelsLayout.prototype, 'isHorizontal', {\n configurable: true,\n get: function () {\n return this.orientation.isHorizontal;\n }\n });\n AxisLabelsLayout.prototype.mapToAxis_d2cc22$ = function (breaks, axisMapper) {\n return BreakLabelsLayoutUtil_getInstance().mapToAxis_lhkzxb$(breaks, this.axisDomain, axisMapper);\n };\n AxisLabelsLayout.prototype.applyLabelsOffset_w7e9pi$ = function (labelsBounds) {\n return BreakLabelsLayoutUtil_getInstance().applyLabelsOffset_tsgpmr$(labelsBounds, this.theme.tickLabelDistance(), this.orientation);\n };\n function AxisLabelsLayout$Companion() {\n AxisLabelsLayout$Companion_instance = this;\n this.TICK_LABEL_SPEC = PlotLabelSpec$AXIS_TICK_getInstance();\n this.INITIAL_TICK_LABEL_LENGTH = 4;\n this.MIN_TICK_LABEL_DISTANCE = 20.0;\n this.TICK_LABEL_SPEC_SMALL = PlotLabelSpec$AXIS_TICK_SMALL_getInstance();\n }\n AxisLabelsLayout$Companion.prototype.horizontalFlexBreaks_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!breaksProvider.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }return new HorizontalFlexBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaksProvider, theme);\n };\n AxisLabelsLayout$Companion.prototype.horizontalFixedBreaks_3unth9$ = function (orientation, axisDomain, breaks, theme) {\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }return new HorizontalFixedBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaks, theme);\n };\n AxisLabelsLayout$Companion.prototype.verticalFlexBreaks_4ebi60$ = function (orientation, axisDomain, breaksProvider, theme) {\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!breaksProvider.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }return new VerticalFlexBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaksProvider, theme);\n };\n AxisLabelsLayout$Companion.prototype.verticalFixedBreaks_3unth9$ = function (orientation, axisDomain, breaks, theme) {\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }return new VerticalFixedBreaksLabelsLayout(orientation, axisDomain, this.TICK_LABEL_SPEC, breaks, theme);\n };\n AxisLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AxisLabelsLayout$Companion_instance = null;\n function AxisLabelsLayout$Companion_getInstance() {\n if (AxisLabelsLayout$Companion_instance === null) {\n new AxisLabelsLayout$Companion();\n }return AxisLabelsLayout$Companion_instance;\n }\n AxisLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLabelsLayout',\n interfaces: []\n };\n function AxisLabelsLayoutInfo(b) {\n this.breaks = null;\n this.bounds = null;\n this.smallFont = false;\n this.labelAdditionalOffsets = null;\n this.labelHorizontalAnchor = null;\n this.labelVerticalAnchor = null;\n this.labelRotationAngle = 0;\n this.isOverlap_8be2vx$ = false;\n this.breaks = b.myBreaks_8be2vx$;\n this.smallFont = b.mySmallFont_8be2vx$;\n this.bounds = b.myBounds_8be2vx$;\n this.isOverlap_8be2vx$ = b.myOverlap_8be2vx$;\n this.labelAdditionalOffsets = b.myLabelAdditionalOffsets_8be2vx$ == null ? null : ArrayList_init_1(ensureNotNull(b.myLabelAdditionalOffsets_8be2vx$));\n this.labelHorizontalAnchor = b.myLabelHorizontalAnchor_8be2vx$;\n this.labelVerticalAnchor = b.myLabelVerticalAnchor_8be2vx$;\n this.labelRotationAngle = b.myLabelRotationAngle_8be2vx$;\n }\n function AxisLabelsLayoutInfo$Builder() {\n this.myBreaks_8be2vx$ = null;\n this.myBounds_8be2vx$ = null;\n this.mySmallFont_8be2vx$ = false;\n this.myOverlap_8be2vx$ = false;\n this.myLabelAdditionalOffsets_8be2vx$ = null;\n this.myLabelHorizontalAnchor_8be2vx$ = null;\n this.myLabelVerticalAnchor_8be2vx$ = null;\n this.myLabelRotationAngle_8be2vx$ = 0.0;\n }\n AxisLabelsLayoutInfo$Builder.prototype.breaks_d6t06k$ = function (breaks) {\n this.myBreaks_8be2vx$ = breaks;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.bounds_wthzt5$ = function (bounds) {\n this.myBounds_8be2vx$ = bounds;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.smallFont_6taknv$ = function (b) {\n this.mySmallFont_8be2vx$ = b;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.overlap_6taknv$ = function (b) {\n this.myOverlap_8be2vx$ = b;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelAdditionalOffsets_eajcfd$ = function (l) {\n this.myLabelAdditionalOffsets_8be2vx$ = l;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelHorizontalAnchor_ja80zo$ = function (anchor) {\n this.myLabelHorizontalAnchor_8be2vx$ = anchor;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelVerticalAnchor_yaudma$ = function (anchor) {\n this.myLabelVerticalAnchor_8be2vx$ = anchor;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.labelRotationAngle_14dthe$ = function (angle) {\n this.myLabelRotationAngle_8be2vx$ = angle;\n return this;\n };\n AxisLabelsLayoutInfo$Builder.prototype.build = function () {\n return new AxisLabelsLayoutInfo(this);\n };\n AxisLabelsLayoutInfo$Builder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Builder',\n interfaces: []\n };\n AxisLabelsLayoutInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AxisLabelsLayoutInfo',\n interfaces: []\n };\n function BreakLabelsLayoutUtil() {\n BreakLabelsLayoutUtil_instance = this;\n }\n BreakLabelsLayoutUtil.prototype.getFlexBreaks_73ga93$ = function (breaksProvider, maxCount, axisLength) {\n if (!!breaksProvider.isFixedBreaks) {\n var message = 'fixed breaks not expected';\n throw IllegalArgumentException_init(message.toString());\n }if (!(maxCount > 0)) {\n var message_0 = 'maxCount=' + maxCount;\n throw IllegalArgumentException_init(message_0.toString());\n }var breaks = breaksProvider.getBreaks_5wr77w$(maxCount, axisLength);\n if (maxCount === 1 && !breaks.isEmpty) {\n return new ScaleBreaks(breaks.domainValues.subList_vux9f0$(0, 1), breaks.transformedValues.subList_vux9f0$(0, 1), breaks.labels.subList_vux9f0$(0, 1));\n }var count = maxCount;\n while (breaks.size > maxCount) {\n var b = (breaks.size - maxCount | 0) / 2 | 0;\n var delta = JsMath.max(1, b);\n count = count - delta | 0;\n breaks = breaksProvider.getBreaks_5wr77w$(count, axisLength);\n }\n return breaks;\n };\n BreakLabelsLayoutUtil.prototype.maxLength_mhpeer$ = function (labels) {\n var tmp$;\n var max = 0;\n tmp$ = labels.iterator();\n while (tmp$.hasNext()) {\n var label = tmp$.next();\n var a = max;\n var b = label.length;\n max = JsMath.max(a, b);\n }\n return max;\n };\n BreakLabelsLayoutUtil.prototype.horizontalCenteredLabelBounds_gpjtzr$ = function (labelSize) {\n return DoubleRectangle_init(-labelSize.x / 2.0, 0.0, labelSize.x, labelSize.y);\n };\n BreakLabelsLayoutUtil.prototype.doLayoutVerticalAxisLabels_7l1gh9$ = function (orientation, breaks, axisDomain, axisMapper, theme) {\n var tmp$;\n if (theme.showTickLabels()) {\n var labelsBounds = this.verticalAxisLabelsBounds_0(breaks, axisDomain, axisMapper);\n tmp$ = this.applyLabelsOffset_tsgpmr$(labelsBounds, theme.tickLabelDistance(), orientation);\n } else if (theme.showTickMarks()) {\n var labelsBounds_0 = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n tmp$ = this.applyLabelsOffset_tsgpmr$(labelsBounds_0, theme.tickLabelDistance(), orientation);\n } else\n tmp$ = new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO);\n var axisBounds = tmp$;\n return (new AxisLabelsLayoutInfo$Builder()).breaks_d6t06k$(breaks).bounds_wthzt5$(axisBounds).build();\n };\n BreakLabelsLayoutUtil.prototype.mapToAxis_lhkzxb$ = function (breaks, axisDomain, axisMapper) {\n var tmp$;\n var axisMin = axisDomain.lowerEnd;\n var axisBreaks = ArrayList_init();\n tmp$ = breaks.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n var mapped = axisMapper(v - axisMin);\n axisBreaks.add_11rb$(ensureNotNull(mapped));\n }\n return axisBreaks;\n };\n BreakLabelsLayoutUtil.prototype.applyLabelsOffset_tsgpmr$ = function (labelsBounds, offset, orientation) {\n var tmp$;\n var labelsBounds_0 = labelsBounds;\n switch (orientation.name) {\n case 'LEFT':\n tmp$ = new DoubleVector(-offset, 0.0);\n break;\n case 'RIGHT':\n tmp$ = new DoubleVector(offset, 0.0);\n break;\n case 'TOP':\n tmp$ = new DoubleVector(0.0, -offset);\n break;\n case 'BOTTOM':\n tmp$ = new DoubleVector(0.0, offset);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n var offsetVector = tmp$;\n if (orientation === Orientation$RIGHT_getInstance() || orientation === Orientation$BOTTOM_getInstance()) {\n labelsBounds_0 = labelsBounds_0.add_gpjtzr$(offsetVector);\n } else if (orientation === Orientation$LEFT_getInstance() || orientation === Orientation$TOP_getInstance()) {\n labelsBounds_0 = labelsBounds_0.add_gpjtzr$(offsetVector).subtract_gpjtzr$(new DoubleVector(labelsBounds_0.width, 0.0));\n }return labelsBounds_0;\n };\n BreakLabelsLayoutUtil.prototype.verticalAxisLabelsBounds_0 = function (breaks, axisDomain, axisMapper) {\n var maxLength = this.maxLength_mhpeer$(breaks.labels);\n var maxLabelWidth = AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.width_za3lpa$(maxLength);\n var y1 = 0.0;\n var y2 = 0.0;\n if (!breaks.isEmpty) {\n var axisBreaks = this.mapToAxis_lhkzxb$(breaks.transformedValues, axisDomain, axisMapper);\n var a = axisBreaks.get_za3lpa$(0);\n var b = collect.Iterables.getLast_yl67zr$(axisBreaks);\n y1 = JsMath.min(a, b);\n var a_0 = axisBreaks.get_za3lpa$(0);\n var b_0 = collect.Iterables.getLast_yl67zr$(axisBreaks);\n y2 = JsMath.max(a_0, b_0);\n y1 -= AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() / 2;\n y2 += AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() / 2;\n }var origin = new DoubleVector(0.0, y1);\n var dimensions = new DoubleVector(maxLabelWidth, y2 - y1);\n return new DoubleRectangle(origin, dimensions);\n };\n BreakLabelsLayoutUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'BreakLabelsLayoutUtil',\n interfaces: []\n };\n var BreakLabelsLayoutUtil_instance = null;\n function BreakLabelsLayoutUtil_getInstance() {\n if (BreakLabelsLayoutUtil_instance === null) {\n new BreakLabelsLayoutUtil();\n }return BreakLabelsLayoutUtil_instance;\n }\n function HorizontalFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }}\n HorizontalFixedBreaksLabelsLayout.prototype.overlap_0 = function (labelsInfo, maxTickLabelsBounds) {\n return labelsInfo.isOverlap_8be2vx$ || (maxTickLabelsBounds != null && !(maxTickLabelsBounds.xRange().encloses_d226ot$(ensureNotNull(labelsInfo.bounds).xRange()) && maxTickLabelsBounds.yRange().encloses_d226ot$(labelsInfo.bounds.yRange())));\n };\n HorizontalFixedBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n if (!this.theme.showTickLabels()) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }var labelsInfo = this.simpleLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.multilineLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.tiltedLayout_0().doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.verticalLayout_0(this.labelSpec).doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n if (this.overlap_0(labelsInfo, maxLabelsBounds)) {\n labelsInfo = this.verticalLayout_0(AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC_SMALL).doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n }}}}return labelsInfo;\n };\n HorizontalFixedBreaksLabelsLayout.prototype.simpleLayout_0 = function () {\n return new HorizontalSimpleLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.multilineLayout_0 = function () {\n return new HorizontalMultilineLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme, 2);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.tiltedLayout_0 = function () {\n return new HorizontalTiltedLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.verticalLayout_0 = function (labelSpec) {\n return new HorizontalVerticalLabelsLayout(this.orientation, this.axisDomain, labelSpec, this.breaks_0, this.theme);\n };\n HorizontalFixedBreaksLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n throw IllegalStateException_init('Not implemented here');\n };\n HorizontalFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalFixedBreaksLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalFlexBreaksLabelsLayout(orientation, axisDomain, labelSpec, myBreaksProvider, theme) {\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.myBreaksProvider_0 = myBreaksProvider;\n if (!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.myBreaksProvider_0.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n HorizontalFlexBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var targetBreakCount = HorizontalSimpleLabelsLayout$Companion_getInstance().estimateBreakCountInitial_14dthe$(axisLength);\n var breaks = this.getBreaks_0(targetBreakCount, axisLength);\n var labelsInfo = this.doLayoutLabels_0(breaks, axisLength, axisMapper, maxLabelsBounds);\n while (labelsInfo.isOverlap_8be2vx$) {\n var newTargetBreakCount = HorizontalSimpleLabelsLayout$Companion_getInstance().estimateBreakCount_g5yaez$(breaks.labels, axisLength);\n if (newTargetBreakCount >= targetBreakCount) {\n break;\n }targetBreakCount = newTargetBreakCount;\n breaks = this.getBreaks_0(targetBreakCount, axisLength);\n labelsInfo = this.doLayoutLabels_0(breaks, axisLength, axisMapper, maxLabelsBounds);\n }\n return labelsInfo;\n };\n HorizontalFlexBreaksLabelsLayout.prototype.doLayoutLabels_0 = function (breaks, axisLength, axisMapper, maxLabelsBounds) {\n var layout = new HorizontalSimpleLabelsLayout(this.orientation, this.axisDomain, this.labelSpec, breaks, this.theme);\n return layout.doLayout_s0wrr0$(axisLength, axisMapper, maxLabelsBounds);\n };\n HorizontalFlexBreaksLabelsLayout.prototype.getBreaks_0 = function (maxCount, axisLength) {\n return BreakLabelsLayoutUtil_getInstance().getFlexBreaks_73ga93$(this.myBreaksProvider_0, maxCount, axisLength);\n };\n HorizontalFlexBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalFlexBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function HorizontalMultilineLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme, myMaxLines) {\n HorizontalMultilineLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n this.myMaxLines_0 = myMaxLines;\n this.myShelfIndexForTickIndex_0 = ArrayList_init();\n }\n Object.defineProperty(HorizontalMultilineLabelsLayout.prototype, 'labelAdditionalOffsets_0', {\n configurable: true,\n get: function () {\n var tmp$;\n var h = this.labelSpec.height() * HorizontalMultilineLabelsLayout$Companion_getInstance().LINE_HEIGHT_0;\n var result = ArrayList_init();\n tmp$ = this.breaks_0.size;\n for (var i = 0; i < tmp$; i++) {\n result.add_11rb$(new DoubleVector(0.0, this.myShelfIndexForTickIndex_0.get_za3lpa$(i) * h));\n }\n return result;\n }\n });\n HorizontalMultilineLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var tmp$, tmp$_0;\n var boundsByShelfIndex = HashMap_init();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var boundsList = this.labelBoundsList_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n var shelfIndex = 0;\n while (true) {\n if (!boundsByShelfIndex.containsKey_11rb$(shelfIndex)) {\n var key = shelfIndex;\n boundsByShelfIndex.put_xwzc9p$(key, labelBounds);\n this.myShelfIndexForTickIndex_0.add_11rb$(shelfIndex);\n break;\n }var shelfBounds = ensureNotNull(boundsByShelfIndex.get_11rb$(shelfIndex));\n if (!shelfBounds.xRange().isConnected_d226ot$(new ClosedRange(labelBounds.left - 60, labelBounds.right + 60))) {\n this.myShelfIndexForTickIndex_0.add_11rb$(shelfIndex);\n shelfBounds = shelfBounds.union_wthzt5$(labelBounds);\n var key_0 = shelfIndex;\n var value = shelfBounds;\n boundsByShelfIndex.put_xwzc9p$(key_0, value);\n break;\n }shelfIndex = shelfIndex + 1 | 0;\n }\n }\n var bounds = boundsByShelfIndex.isEmpty() ? new DoubleRectangle(DoubleVector.Companion.ZERO, DoubleVector.Companion.ZERO) : ensureNotNull(boundsByShelfIndex.get_11rb$(0));\n var h = this.labelSpec.height() * HorizontalMultilineLabelsLayout$Companion_getInstance().LINE_HEIGHT_0;\n tmp$_0 = boundsByShelfIndex.size;\n for (var i = 0; i < tmp$_0; i++) {\n var shelfBounds_0 = ensureNotNull(boundsByShelfIndex.get_11rb$(i));\n bounds = bounds.union_wthzt5$(shelfBounds_0.add_gpjtzr$(new DoubleVector(0.0, i * h)));\n }\n var linesCount = boundsByShelfIndex.size;\n return (new AxisLabelsLayoutInfo$Builder()).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(bounds)).smallFont_6taknv$(false).overlap_6taknv$(linesCount > this.myMaxLines_0).labelAdditionalOffsets_eajcfd$(this.labelAdditionalOffsets_0).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n };\n HorizontalMultilineLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n return BreakLabelsLayoutUtil_getInstance().horizontalCenteredLabelBounds_gpjtzr$(labelNormalSize);\n };\n function HorizontalMultilineLabelsLayout$Companion() {\n HorizontalMultilineLabelsLayout$Companion_instance = this;\n this.LINE_HEIGHT_0 = 1.2;\n this.MIN_DISTANCE_0 = 60;\n }\n HorizontalMultilineLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalMultilineLabelsLayout$Companion_instance = null;\n function HorizontalMultilineLabelsLayout$Companion_getInstance() {\n if (HorizontalMultilineLabelsLayout$Companion_instance === null) {\n new HorizontalMultilineLabelsLayout$Companion();\n }return HorizontalMultilineLabelsLayout$Companion_instance;\n }\n HorizontalMultilineLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalMultilineLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalSimpleLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalSimpleLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n HorizontalSimpleLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var tmp$;\n if (this.breaks_0.isEmpty) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }if (!this.theme.showTickLabels()) {\n return this.noLabelsLayoutInfo_c0p8fa$(axisLength, this.orientation);\n }var bounds = null;\n var overlap = false;\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var boundsList = this.labelBoundsList_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n tmp$ = boundsList.iterator();\n while (tmp$.hasNext()) {\n var labelBounds = tmp$.next();\n overlap = overlap || (bounds != null && bounds.xRange().isConnected_d226ot$(data_0.SeriesUtil.expand_wws5xy$(labelBounds.xRange(), AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE / 2, AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE / 2.0)));\n bounds = GeometryUtil_getInstance().union_te9coj$(labelBounds, bounds);\n }\n return (new AxisLabelsLayoutInfo$Builder()).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(ensureNotNull(bounds))).smallFont_6taknv$(false).overlap_6taknv$(overlap).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(TextLabel$HorizontalAnchor.MIDDLE).labelVerticalAnchor_yaudma$(TextLabel$VerticalAnchor.TOP).build();\n };\n HorizontalSimpleLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n return BreakLabelsLayoutUtil_getInstance().horizontalCenteredLabelBounds_gpjtzr$(labelNormalSize);\n };\n function HorizontalSimpleLabelsLayout$Companion() {\n HorizontalSimpleLabelsLayout$Companion_instance = this;\n }\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCountInitial_14dthe$ = function (axisLength) {\n return this.estimateBreakCount_0(4, axisLength);\n };\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCount_g5yaez$ = function (labels, axisLength) {\n var maxLength = BreakLabelsLayoutUtil_getInstance().maxLength_mhpeer$(labels);\n return this.estimateBreakCount_0(maxLength, axisLength);\n };\n HorizontalSimpleLabelsLayout$Companion.prototype.estimateBreakCount_0 = function (labelLength, axisLength) {\n var tickDistance = AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.width_za3lpa$(labelLength) + AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE;\n var b = axisLength / tickDistance;\n return numberToInt(JsMath.max(1.0, b));\n };\n HorizontalSimpleLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalSimpleLabelsLayout$Companion_instance = null;\n function HorizontalSimpleLabelsLayout$Companion_getInstance() {\n if (HorizontalSimpleLabelsLayout$Companion_instance === null) {\n new HorizontalSimpleLabelsLayout$Companion();\n }return HorizontalSimpleLabelsLayout$Companion_instance;\n }\n HorizontalSimpleLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalSimpleLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalTiltedLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalTiltedLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n Object.defineProperty(HorizontalTiltedLabelsLayout.prototype, 'labelHorizontalAnchor_0', {\n configurable: true,\n get: function () {\n if (this.orientation === Orientation$BOTTOM_getInstance()) {\n return TextLabel$HorizontalAnchor.RIGHT;\n }throw RuntimeException_init('Not implemented');\n }\n });\n Object.defineProperty(HorizontalTiltedLabelsLayout.prototype, 'labelVerticalAnchor_0', {\n configurable: true,\n get: function () {\n return TextLabel$VerticalAnchor.TOP;\n }\n });\n HorizontalTiltedLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var height = this.labelSpec.height();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var overlap = false;\n if (this.breaks_0.size >= 2) {\n var x = (height + HorizontalTiltedLabelsLayout$Companion_getInstance().MIN_DISTANCE_0) / HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var minTickDistance = JsMath.abs(x);\n var x_0 = ticks.get_za3lpa$(0) - ticks.get_za3lpa$(1);\n var tickDistance = JsMath.abs(x_0);\n overlap = tickDistance < minTickDistance;\n }var bounds = this.labelsBounds_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n return this.createAxisLabelsLayoutInfoBuilder_fd842m$(ensureNotNull(bounds), overlap).labelHorizontalAnchor_ja80zo$(this.labelHorizontalAnchor_0).labelVerticalAnchor_yaudma$(this.labelVerticalAnchor_0).labelRotationAngle_14dthe$(HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0).build();\n };\n HorizontalTiltedLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n if (!(HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 >= -90 && HorizontalTiltedLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 <= 0 && this.labelHorizontalAnchor_0 === TextLabel$HorizontalAnchor.RIGHT && this.labelVerticalAnchor_0 === TextLabel$VerticalAnchor.TOP)) {\n throw RuntimeException_init('Not implemented');\n }var x = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var tmp$ = JsMath.abs(x);\n var x_0 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var w = tmp$ + 2 * JsMath.abs(x_0);\n var x_1 = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var tmp$_0 = JsMath.abs(x_1);\n var x_2 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var h = tmp$_0 + JsMath.abs(x_2);\n var x_3 = labelNormalSize.x * HorizontalTiltedLabelsLayout$Companion_getInstance().COS_0;\n var tmp$_1 = JsMath.abs(x_3);\n var x_4 = labelNormalSize.y * HorizontalTiltedLabelsLayout$Companion_getInstance().SIN_0;\n var x_5 = -(tmp$_1 + JsMath.abs(x_4));\n var y = 0.0;\n return DoubleRectangle_init(x_5, y, w, h);\n };\n function HorizontalTiltedLabelsLayout$Companion() {\n HorizontalTiltedLabelsLayout$Companion_instance = this;\n this.MIN_DISTANCE_0 = 5.0;\n this.ROTATION_DEGREE_0 = -30.0;\n var x = toRadians(this.ROTATION_DEGREE_0);\n this.SIN_0 = JsMath.sin(x);\n var x_0 = toRadians(this.ROTATION_DEGREE_0);\n this.COS_0 = JsMath.cos(x_0);\n }\n HorizontalTiltedLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalTiltedLabelsLayout$Companion_instance = null;\n function HorizontalTiltedLabelsLayout$Companion_getInstance() {\n if (HorizontalTiltedLabelsLayout$Companion_instance === null) {\n new HorizontalTiltedLabelsLayout$Companion();\n }return HorizontalTiltedLabelsLayout$Companion_instance;\n }\n HorizontalTiltedLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalTiltedLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function HorizontalVerticalLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n HorizontalVerticalLabelsLayout$Companion_getInstance();\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, labelSpec, breaks, theme);\n }\n Object.defineProperty(HorizontalVerticalLabelsLayout.prototype, 'labelHorizontalAnchor', {\n configurable: true,\n get: function () {\n if (this.orientation === Orientation$BOTTOM_getInstance()) {\n return TextLabel$HorizontalAnchor.LEFT;\n }throw RuntimeException_init('Not implemented');\n }\n });\n Object.defineProperty(HorizontalVerticalLabelsLayout.prototype, 'labelVerticalAnchor', {\n configurable: true,\n get: function () {\n return TextLabel$VerticalAnchor.CENTER;\n }\n });\n HorizontalVerticalLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n var height = this.labelSpec.height();\n var ticks = this.mapToAxis_d2cc22$(this.breaks_0.transformedValues, axisMapper);\n var overlap = false;\n if (this.breaks_0.size >= 2) {\n var minTickDistance = height + HorizontalVerticalLabelsLayout$Companion_getInstance().MIN_DISTANCE_0;\n var x = ticks.get_za3lpa$(0) - ticks.get_za3lpa$(1);\n var tickDistance = JsMath.abs(x);\n overlap = tickDistance < minTickDistance;\n }var bounds = this.labelsBounds_c3fefx$(ticks, this.breaks_0.labels, AbstractFixedBreaksLabelsLayout$Companion_getInstance().HORIZONTAL_TICK_LOCATION);\n return this.createAxisLabelsLayoutInfoBuilder_fd842m$(ensureNotNull(bounds), overlap).labelHorizontalAnchor_ja80zo$(this.labelHorizontalAnchor).labelVerticalAnchor_yaudma$(this.labelVerticalAnchor).labelRotationAngle_14dthe$(HorizontalVerticalLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0).build();\n };\n HorizontalVerticalLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n if (!(HorizontalVerticalLabelsLayout$Companion_getInstance().ROTATION_DEGREE_0 === 90.0 && this.labelHorizontalAnchor === TextLabel$HorizontalAnchor.LEFT && this.labelVerticalAnchor === TextLabel$VerticalAnchor.CENTER)) {\n throw RuntimeException_init('Not implemented');\n }var w = labelNormalSize.y;\n var h = labelNormalSize.x;\n var x = -w / 2;\n var y = 0.0;\n return DoubleRectangle_init(x, y, w, h);\n };\n function HorizontalVerticalLabelsLayout$Companion() {\n HorizontalVerticalLabelsLayout$Companion_instance = this;\n this.MIN_DISTANCE_0 = 5.0;\n this.ROTATION_DEGREE_0 = 90.0;\n }\n HorizontalVerticalLabelsLayout$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HorizontalVerticalLabelsLayout$Companion_instance = null;\n function HorizontalVerticalLabelsLayout$Companion_getInstance() {\n if (HorizontalVerticalLabelsLayout$Companion_instance === null) {\n new HorizontalVerticalLabelsLayout$Companion();\n }return HorizontalVerticalLabelsLayout$Companion_instance;\n }\n HorizontalVerticalLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HorizontalVerticalLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function VerticalFixedBreaksLabelsLayout(orientation, axisDomain, tickLabelSpec, breaks, theme) {\n AbstractFixedBreaksLabelsLayout.call(this, orientation, axisDomain, tickLabelSpec, breaks, theme);\n }\n VerticalFixedBreaksLabelsLayout.prototype.labelBounds_gpjtzr$ = function (labelNormalSize) {\n throw IllegalStateException_init('Not implemented here');\n };\n VerticalFixedBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n return BreakLabelsLayoutUtil_getInstance().doLayoutVerticalAxisLabels_7l1gh9$(this.orientation, this.breaks_0, this.axisDomain, axisMapper, this.theme);\n };\n VerticalFixedBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalFixedBreaksLabelsLayout',\n interfaces: [AbstractFixedBreaksLabelsLayout]\n };\n function VerticalFlexBreaksLabelsLayout(orientation, axisDomain, labelSpec, myBreaksProvider, theme) {\n AxisLabelsLayout.call(this, orientation, axisDomain, labelSpec, theme);\n this.myBreaksProvider_0 = myBreaksProvider;\n if (!!orientation.isHorizontal) {\n var message = orientation.toString();\n throw IllegalArgumentException_init(message.toString());\n }if (!!this.myBreaksProvider_0.isFixedBreaks) {\n var message_0 = 'fixed breaks';\n throw IllegalArgumentException_init(message_0.toString());\n }}\n VerticalFlexBreaksLabelsLayout.prototype.maxTickCount_0 = function (axisLength) {\n var x = axisLength / (AxisLabelsLayout$Companion_getInstance().TICK_LABEL_SPEC.height() + AxisLabelsLayout$Companion_getInstance().MIN_TICK_LABEL_DISTANCE);\n return numberToInt(JsMath.ceil(x));\n };\n VerticalFlexBreaksLabelsLayout.prototype.doLayout_s0wrr0$ = function (axisLength, axisMapper, maxLabelsBounds) {\n if (!(axisLength > 0)) {\n var message = 'axis length: ' + axisLength;\n throw IllegalArgumentException_init(message.toString());\n }var maxTickCount = this.maxTickCount_0(axisLength);\n var breaks = this.getBreaks_0(maxTickCount, axisLength);\n return BreakLabelsLayoutUtil_getInstance().doLayoutVerticalAxisLabels_7l1gh9$(this.orientation, breaks, this.axisDomain, axisMapper, this.theme);\n };\n VerticalFlexBreaksLabelsLayout.prototype.getBreaks_0 = function (maxCount, axisLength) {\n return BreakLabelsLayoutUtil_getInstance().getFlexBreaks_73ga93$(this.myBreaksProvider_0, maxCount, axisLength);\n };\n VerticalFlexBreaksLabelsLayout.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VerticalFlexBreaksLabelsLayout',\n interfaces: [AxisLabelsLayout]\n };\n function Defaults() {\n Defaults_instance = this;\n this.DARK_GRAY = '#3d3d3d';\n this.GRAY = Color.Companion.GRAY.toHexColor();\n this.LIGHT_GRAY = Color.Companion.LIGHT_GRAY.toHexColor();\n this.X_LIGHT_GRAY = Color.Companion.VERY_LIGHT_GRAY.toHexColor();\n this.XX_LIGHT_GRAY = '#e0e0e0';\n this.BACKDROP_COLOR = 'white';\n this.TEXT_COLOR = this.DARK_GRAY;\n this.FONT_LARGE = 16;\n this.FONT_MEDIUM = 12;\n this.FONT_SMALL = 10;\n this.FONT_X_SMALL = 8;\n this.FONT_FAMILY_NORMAL = '\"Lucida Grande\", sans-serif';\n this.FONT_FAMILY_MONOSPACED = '\"Courier New\", Courier, monospace';\n }\n function Defaults$Common() {\n }\n function Defaults$Common$Title() {\n Defaults$Common$Title_instance = this;\n this.FONT_SIZE = 16;\n this.FONT_SIZE_CSS = '' + toString(16) + 'px';\n }\n Defaults$Common$Title.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Title',\n interfaces: []\n };\n var Defaults$Common$Title_instance = null;\n function Defaults$Common$Title_getInstance() {\n if (Defaults$Common$Title_instance === null) {\n new Defaults$Common$Title();\n }return Defaults$Common$Title_instance;\n }\n function Defaults$Common$Legend() {\n Defaults$Common$Legend_instance = this;\n this.TITLE_FONT_SIZE = 12;\n this.ITEM_FONT_SIZE = 10;\n this.OUTLINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().XX_LIGHT_GRAY);\n }\n Defaults$Common$Legend.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Legend',\n interfaces: []\n };\n var Defaults$Common$Legend_instance = null;\n function Defaults$Common$Legend_getInstance() {\n if (Defaults$Common$Legend_instance === null) {\n new Defaults$Common$Legend();\n }return Defaults$Common$Legend_instance;\n }\n function Defaults$Common$Tooltip() {\n Defaults$Common$Tooltip_instance = this;\n this.MAX_POINTER_FOOTING_LENGTH = 12.0;\n this.POINTER_FOOTING_TO_SIDE_LENGTH_RATIO = 0.4;\n this.MARGIN_BETWEEN_TOOLTIPS = 5.0;\n this.DATA_TOOLTIP_FONT_SIZE = 12;\n this.LINE_INTERVAL = 3.0;\n this.H_CONTENT_PADDING = 4.0;\n this.V_CONTENT_PADDING = 4.0;\n this.LABEL_VALUE_INTERVAL = 8.0;\n this.BORDER_WIDTH = 4.0;\n this.DARK_TEXT_COLOR = Color.Companion.BLACK;\n this.LIGHT_TEXT_COLOR = Color.Companion.WHITE;\n this.AXIS_TOOLTIP_FONT_SIZE = 12;\n this.AXIS_TOOLTIP_COLOR = Defaults$Plot$Axis_getInstance().LINE_COLOR;\n this.AXIS_RADIUS = 1.5;\n }\n Defaults$Common$Tooltip.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Tooltip',\n interfaces: []\n };\n var Defaults$Common$Tooltip_instance = null;\n function Defaults$Common$Tooltip_getInstance() {\n if (Defaults$Common$Tooltip_instance === null) {\n new Defaults$Common$Tooltip();\n }return Defaults$Common$Tooltip_instance;\n }\n Defaults$Common.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Common',\n interfaces: []\n };\n function Defaults$Table() {\n }\n function Defaults$Table$Head() {\n Defaults$Table$Head_instance = this;\n this.FONT_SIZE = 12;\n this.FONT_SIZE_CSS = '' + toString(12) + 'px';\n }\n Defaults$Table$Head.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Head',\n interfaces: []\n };\n var Defaults$Table$Head_instance = null;\n function Defaults$Table$Head_getInstance() {\n if (Defaults$Table$Head_instance === null) {\n new Defaults$Table$Head();\n }return Defaults$Table$Head_instance;\n }\n function Defaults$Table$Data() {\n Defaults$Table$Data_instance = this;\n this.FONT_SIZE = 12;\n this.FONT_SIZE_CSS = '' + toString(12) + 'px';\n }\n Defaults$Table$Data.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Data',\n interfaces: []\n };\n var Defaults$Table$Data_instance = null;\n function Defaults$Table$Data_getInstance() {\n if (Defaults$Table$Data_instance === null) {\n new Defaults$Table$Data();\n }return Defaults$Table$Data_instance;\n }\n Defaults$Table.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Table',\n interfaces: []\n };\n function Defaults$Plot() {\n }\n function Defaults$Plot$Axis() {\n Defaults$Plot$Axis_instance = this;\n this.TITLE_FONT_SIZE = 12;\n this.TICK_FONT_SIZE = 10;\n this.TICK_FONT_SIZE_SMALL = 8;\n this.LINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().DARK_GRAY);\n this.TICK_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().DARK_GRAY);\n this.GRID_LINE_COLOR = Color.Companion.parseHex_61zpoe$(Defaults_getInstance().X_LIGHT_GRAY);\n this.LINE_WIDTH = 1.0;\n this.TICK_LINE_WIDTH = 1.0;\n this.GRID_LINE_WIDTH = 1.0;\n }\n Defaults$Plot$Axis.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Axis',\n interfaces: []\n };\n var Defaults$Plot$Axis_instance = null;\n function Defaults$Plot$Axis_getInstance() {\n if (Defaults$Plot$Axis_instance === null) {\n new Defaults$Plot$Axis();\n }return Defaults$Plot$Axis_instance;\n }\n Defaults$Plot.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Plot',\n interfaces: []\n };\n Defaults.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Defaults',\n interfaces: []\n };\n var Defaults_instance = null;\n function Defaults_getInstance() {\n if (Defaults_instance === null) {\n new Defaults();\n }return Defaults_instance;\n }\n function LabelCss() {\n LabelCss_instance = this;\n }\n LabelCss.prototype.get_diyz8p$ = function (labelSpec, selector) {\n var css = StringBuilder_init();\n css.append_pdl1vj$(selector).append_pdl1vj$(' {').append_pdl1vj$(labelSpec.isMonospaced ? '\\n font-family: ' + Defaults_getInstance().FONT_FAMILY_MONOSPACED + ';' : '\\n').append_pdl1vj$('\\n font-size: ').append_s8jyv4$(labelSpec.fontSize).append_pdl1vj$('px;').append_pdl1vj$(labelSpec.isBold ? '\\n font-weight: bold;' : '').append_pdl1vj$('\\n}\\n');\n return css.toString();\n };\n LabelCss.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LabelCss',\n interfaces: []\n };\n var LabelCss_instance = null;\n function LabelCss_getInstance() {\n if (LabelCss_instance === null) {\n new LabelCss();\n }return LabelCss_instance;\n }\n function Serializable() {\n }\n Serializable.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Serializable',\n interfaces: []\n };\n function LabelMetrics() {\n LabelMetrics$Companion_getInstance();\n this.fontSize_yu4fth$_0 = 0;\n this.isBold_4ltcm$_0 = false;\n this.isMonospaced_kwm1y$_0 = false;\n }\n Object.defineProperty(LabelMetrics.prototype, 'fontSize', {\n configurable: true,\n get: function () {\n return this.fontSize_yu4fth$_0;\n }\n });\n Object.defineProperty(LabelMetrics.prototype, 'isBold', {\n configurable: true,\n get: function () {\n return this.isBold_4ltcm$_0;\n }\n });\n Object.defineProperty(LabelMetrics.prototype, 'isMonospaced', {\n configurable: true,\n get: function () {\n return this.isMonospaced_kwm1y$_0;\n }\n });\n LabelMetrics.prototype.dimensions_za3lpa$ = function (labelLength) {\n return new DoubleVector(this.width_za3lpa$(labelLength), this.height());\n };\n LabelMetrics.prototype.width_za3lpa$ = function (labelLength) {\n var tmp$;\n var ratio = LabelMetrics$Companion_getInstance().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0;\n if (this.isMonospaced) {\n ratio = LabelMetrics$Companion_getInstance().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0;\n }var width = labelLength * this.fontSize * ratio + 2 * LabelMetrics$Companion_getInstance().LABEL_PADDING_0;\n if (this.isBold) {\n tmp$ = width * LabelMetrics$Companion_getInstance().FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0;\n } else\n tmp$ = width;\n return tmp$;\n };\n LabelMetrics.prototype.height = function () {\n return this.fontSize + 2 * LabelMetrics$Companion_getInstance().LABEL_PADDING_0;\n };\n function LabelMetrics$Companion() {\n LabelMetrics$Companion_instance = this;\n this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0 = 0.67;\n this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0 = 0.6;\n this.FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0 = 1.075;\n this.LABEL_PADDING_0 = 0.0;\n }\n LabelMetrics$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var LabelMetrics$Companion_instance = null;\n function LabelMetrics$Companion_getInstance() {\n if (LabelMetrics$Companion_instance === null) {\n new LabelMetrics$Companion();\n }return LabelMetrics$Companion_instance;\n }\n LabelMetrics.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LabelMetrics',\n interfaces: [Serializable, LabelSpec]\n };\n function LabelMetrics_init($this) {\n $this = $this || Object.create(LabelMetrics.prototype);\n LabelMetrics.call($this);\n $this.fontSize_yu4fth$_0 = 0.0;\n $this.isBold_4ltcm$_0 = false;\n $this.isMonospaced_kwm1y$_0 = false;\n return $this;\n }\n function LabelMetrics_init_0(fontSize, bold, monospaced, $this) {\n if (bold === void 0)\n bold = false;\n if (monospaced === void 0)\n monospaced = false;\n $this = $this || Object.create(LabelMetrics.prototype);\n LabelMetrics.call($this);\n $this.fontSize_yu4fth$_0 = fontSize;\n $this.isBold_4ltcm$_0 = bold;\n $this.isMonospaced_kwm1y$_0 = monospaced;\n return $this;\n }\n function LabelSpec() {\n }\n LabelSpec.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LabelSpec',\n interfaces: []\n };\n function PlotLabelSpec(name, ordinal, fontSize, bold, monospaced) {\n if (bold === void 0)\n bold = false;\n if (monospaced === void 0)\n monospaced = false;\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n this.myLabelMetrics_3i33aj$_0 = null;\n this.myLabelMetrics_3i33aj$_0 = LabelMetrics_init_0(fontSize, bold, monospaced);\n }\n function PlotLabelSpec_initFields() {\n PlotLabelSpec_initFields = function () {\n };\n PlotLabelSpec$PLOT_TITLE_instance = new PlotLabelSpec('PLOT_TITLE', 0, 16, true);\n PlotLabelSpec$AXIS_TICK_instance = new PlotLabelSpec('AXIS_TICK', 1, 10);\n PlotLabelSpec$AXIS_TICK_SMALL_instance = new PlotLabelSpec('AXIS_TICK_SMALL', 2, 8);\n PlotLabelSpec$AXIS_TITLE_instance = new PlotLabelSpec('AXIS_TITLE', 3, 12);\n PlotLabelSpec$LEGEND_TITLE_instance = new PlotLabelSpec('LEGEND_TITLE', 4, 12, true);\n PlotLabelSpec$LEGEND_ITEM_instance = new PlotLabelSpec('LEGEND_ITEM', 5, 10);\n }\n var PlotLabelSpec$PLOT_TITLE_instance;\n function PlotLabelSpec$PLOT_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$PLOT_TITLE_instance;\n }\n var PlotLabelSpec$AXIS_TICK_instance;\n function PlotLabelSpec$AXIS_TICK_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TICK_instance;\n }\n var PlotLabelSpec$AXIS_TICK_SMALL_instance;\n function PlotLabelSpec$AXIS_TICK_SMALL_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TICK_SMALL_instance;\n }\n var PlotLabelSpec$AXIS_TITLE_instance;\n function PlotLabelSpec$AXIS_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$AXIS_TITLE_instance;\n }\n var PlotLabelSpec$LEGEND_TITLE_instance;\n function PlotLabelSpec$LEGEND_TITLE_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$LEGEND_TITLE_instance;\n }\n var PlotLabelSpec$LEGEND_ITEM_instance;\n function PlotLabelSpec$LEGEND_ITEM_getInstance() {\n PlotLabelSpec_initFields();\n return PlotLabelSpec$LEGEND_ITEM_instance;\n }\n Object.defineProperty(PlotLabelSpec.prototype, 'isBold', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.isBold;\n }\n });\n Object.defineProperty(PlotLabelSpec.prototype, 'isMonospaced', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.isMonospaced;\n }\n });\n Object.defineProperty(PlotLabelSpec.prototype, 'fontSize', {\n configurable: true,\n get: function () {\n return this.myLabelMetrics_3i33aj$_0.fontSize;\n }\n });\n PlotLabelSpec.prototype.dimensions_za3lpa$ = function (labelLength) {\n return this.myLabelMetrics_3i33aj$_0.dimensions_za3lpa$(labelLength);\n };\n PlotLabelSpec.prototype.width_za3lpa$ = function (labelLength) {\n return this.myLabelMetrics_3i33aj$_0.width_za3lpa$(labelLength);\n };\n PlotLabelSpec.prototype.height = function () {\n return this.myLabelMetrics_3i33aj$_0.height();\n };\n PlotLabelSpec.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotLabelSpec',\n interfaces: [LabelSpec, Enum]\n };\n function PlotLabelSpec$values() {\n return [PlotLabelSpec$PLOT_TITLE_getInstance(), PlotLabelSpec$AXIS_TICK_getInstance(), PlotLabelSpec$AXIS_TICK_SMALL_getInstance(), PlotLabelSpec$AXIS_TITLE_getInstance(), PlotLabelSpec$LEGEND_TITLE_getInstance(), PlotLabelSpec$LEGEND_ITEM_getInstance()];\n }\n PlotLabelSpec.values = PlotLabelSpec$values;\n function PlotLabelSpec$valueOf(name) {\n switch (name) {\n case 'PLOT_TITLE':\n return PlotLabelSpec$PLOT_TITLE_getInstance();\n case 'AXIS_TICK':\n return PlotLabelSpec$AXIS_TICK_getInstance();\n case 'AXIS_TICK_SMALL':\n return PlotLabelSpec$AXIS_TICK_SMALL_getInstance();\n case 'AXIS_TITLE':\n return PlotLabelSpec$AXIS_TITLE_getInstance();\n case 'LEGEND_TITLE':\n return PlotLabelSpec$LEGEND_TITLE_getInstance();\n case 'LEGEND_ITEM':\n return PlotLabelSpec$LEGEND_ITEM_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.builder.presentation.PlotLabelSpec.' + name);\n }\n }\n PlotLabelSpec.valueOf_61zpoe$ = PlotLabelSpec$valueOf;\n function Style() {\n Style_instance = this;\n this.JFX_PLOT_STYLESHEET = '/svgMapper/jfx/plot.css';\n this.PLOT_CONTAINER = 'plt-container';\n this.PLOT = 'plt-plot';\n this.PLOT_TITLE = 'plt-plot-title';\n this.PLOT_TRANSPARENT = 'plt-transparent';\n this.PLOT_BACKDROP = 'plt-backdrop';\n this.AXIS = 'plt-axis';\n this.AXIS_TITLE = 'plt-axis-title';\n this.TICK = 'tick';\n this.SMALL_TICK_FONT = 'small-tick-font';\n this.BACK = 'back';\n this.LEGEND = 'plt_legend';\n this.LEGEND_TITLE = 'legend-title';\n this.PLOT_DATA_TOOLTIP = 'plt-data-tooltip';\n this.PLOT_AXIS_TOOLTIP = 'plt-axis-tooltip';\n this.CSS_0 = trimMargin('\\n |.plt-container {\\n |\\tfont-family: \"Lucida Grande\", sans-serif;\\n |\\tcursor: crosshair;\\n |\\tuser-select: none;\\n |\\t-webkit-user-select: none;\\n |\\t-moz-user-select: none;\\n |\\t-ms-user-select: none;\\n |}\\n |.plt-backdrop {\\n | fill: white;\\n |}\\n |.plt-transparent .plt-backdrop {\\n | visibility: hidden;\\n |}\\n |text {\\n |\\tfont-size: 12px;\\n |\\tfill: #3d3d3d;\\n |\\t\\n |\\ttext-rendering: optimizeLegibility;\\n |}\\n |.plt-data-tooltip text {\\n |\\tfont-size: 12px;\\n |}\\n |.plt-axis-tooltip text {\\n |\\tfont-size: 12px;\\n |}\\n |.plt-axis line {\\n |\\tshape-rendering: crispedges;\\n |}\\n ');\n }\n Object.defineProperty(Style.prototype, 'css', {\n configurable: true,\n get: function () {\n var tmp$, tmp$_0;\n var css = new StringBuilder(this.CSS_0.toString());\n css.append_s8itvh$(10);\n tmp$ = PlotLabelSpec$values();\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var labelSpec = tmp$[tmp$_0];\n var selector = this.selector_0(labelSpec);\n css.append_pdl1vj$(LabelCss_getInstance().get_diyz8p$(labelSpec, selector));\n }\n return css.toString();\n }\n });\n Style.prototype.selector_0 = function (labelSpec) {\n var tmp$;\n switch (labelSpec.name) {\n case 'PLOT_TITLE':\n tmp$ = '.plt-plot-title';\n break;\n case 'AXIS_TICK':\n tmp$ = '.plt-axis .tick text';\n break;\n case 'AXIS_TICK_SMALL':\n tmp$ = '.plt-axis.small-tick-font .tick text';\n break;\n case 'AXIS_TITLE':\n tmp$ = '.plt-axis-title text';\n break;\n case 'LEGEND_TITLE':\n tmp$ = '.plt_legend .legend-title text';\n break;\n case 'LEGEND_ITEM':\n tmp$ = '.plt_legend text';\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n Style.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Style',\n interfaces: []\n };\n var Style_instance = null;\n function Style_getInstance() {\n if (Style_instance === null) {\n new Style();\n }return Style_instance;\n }\n function GroupAwareSampling() {\n }\n GroupAwareSampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GroupAwareSampling',\n interfaces: [Sampling]\n };\n function PointSampling() {\n }\n PointSampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PointSampling',\n interfaces: [Sampling]\n };\n function Sampling() {\n }\n Sampling.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Sampling',\n interfaces: []\n };\n function Samplings() {\n Samplings_instance = this;\n this.RANDOM = RandomSampling$Companion_getInstance().ALIAS;\n this.PICK = PickSampling$Companion_getInstance().ALIAS;\n this.SYSTEMATIC = SystematicSampling$Companion_getInstance().ALIAS;\n this.RANDOM_GROUP = GroupRandomSampling$Companion_getInstance().ALIAS;\n this.SYSTEMATIC_GROUP = GroupSystematicSampling$Companion_getInstance().ALIAS;\n this.RANDOM_STRATIFIED = RandomStratifiedSampling$Companion_getInstance().ALIAS_8be2vx$;\n this.VERTEX_VW = VertexSampling$VertexVwSampling$Companion_getInstance().ALIAS;\n this.VERTEX_DP = VertexSampling$VertexDpSampling$Companion_getInstance().ALIAS;\n this.NONE = new Samplings$NoneSampling();\n }\n Samplings.prototype.random_280ow0$ = function (sampleSize, seed) {\n return new RandomSampling(sampleSize, seed);\n };\n Samplings.prototype.pick_za3lpa$ = function (sampleSize) {\n return new PickSampling(sampleSize);\n };\n Samplings.prototype.vertexDp_za3lpa$ = function (sampleSize) {\n return new VertexSampling$VertexDpSampling(sampleSize);\n };\n Samplings.prototype.vertexVw_za3lpa$ = function (sampleSize) {\n return new VertexSampling$VertexVwSampling(sampleSize);\n };\n Samplings.prototype.systematic_za3lpa$ = function (sampleSize) {\n return new SystematicSampling(sampleSize);\n };\n Samplings.prototype.randomGroup_280ow0$ = function (sampleSize, seed) {\n return new GroupRandomSampling(sampleSize, seed);\n };\n Samplings.prototype.systematicGroup_za3lpa$ = function (sampleSize) {\n return new GroupSystematicSampling(sampleSize);\n };\n Samplings.prototype.randomStratified_vcwos1$ = function (sampleSize, seed, minSubSample) {\n return new RandomStratifiedSampling(sampleSize, seed, minSubSample);\n };\n function Samplings$NoneSampling() {\n }\n Object.defineProperty(Samplings$NoneSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'none';\n }\n });\n Samplings$NoneSampling.prototype.isApplicable_dhhkv7$ = function (population) {\n return false;\n };\n Samplings$NoneSampling.prototype.apply_dhhkv7$ = function (population) {\n return population;\n };\n Samplings$NoneSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'NoneSampling',\n interfaces: [PointSampling]\n };\n Samplings.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Samplings',\n interfaces: []\n };\n var Samplings_instance = null;\n function Samplings_getInstance() {\n if (Samplings_instance === null) {\n new Samplings();\n }return Samplings_instance;\n }\n function GroupRandomSampling(sampleSize, mySeed) {\n GroupRandomSampling$Companion_getInstance();\n GroupSamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n }\n Object.defineProperty(GroupRandomSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + GroupRandomSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + ')';\n }\n });\n GroupRandomSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var distinctGroups = SamplingUtil_getInstance().distinctGroups_ejae6o$(groupMapper, population.rowCount());\n shuffle(distinctGroups, this.createRandom_0());\n var pickedGroups = toSet(take(distinctGroups, this.sampleSize));\n return this.doSelect_z69lec$(population, pickedGroups, groupMapper);\n };\n GroupRandomSampling.prototype.createRandom_0 = function () {\n var tmp$, tmp$_0;\n return (tmp$_0 = (tmp$ = this.mySeed_0) != null ? Random(tmp$) : null) != null ? tmp$_0 : Random_0.Default;\n };\n function GroupRandomSampling$Companion() {\n GroupRandomSampling$Companion_instance = this;\n this.ALIAS = 'group_random';\n }\n GroupRandomSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupRandomSampling$Companion_instance = null;\n function GroupRandomSampling$Companion_getInstance() {\n if (GroupRandomSampling$Companion_instance === null) {\n new GroupRandomSampling$Companion();\n }return GroupRandomSampling$Companion_instance;\n }\n GroupRandomSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupRandomSampling',\n interfaces: [GroupSamplingBase]\n };\n function GroupSamplingBase(sampleSize) {\n SamplingBase.call(this, sampleSize);\n }\n GroupSamplingBase.prototype.isApplicable_se5qvl$ = function (population, groupMapper) {\n return this.isApplicable_ijg2gx$(population, groupMapper, SamplingUtil_getInstance().groupCount_ejae6o$(groupMapper, population.rowCount()));\n };\n GroupSamplingBase.prototype.isApplicable_ijg2gx$ = function (population, groupMapper, groupCount) {\n return groupCount > this.sampleSize;\n };\n GroupSamplingBase.prototype.doSelect_z69lec$ = function (population, pickedGroups, groupMapper) {\n var tmp$;\n var indicesByGroup = GroupUtil_getInstance().indicesByGroup_wc9gac$(population.rowCount(), groupMapper);\n var pickedIndices = ArrayList_init();\n tmp$ = pickedGroups.iterator();\n while (tmp$.hasNext()) {\n var group = tmp$.next();\n pickedIndices.addAll_brywnq$(ensureNotNull(indicesByGroup.get_11rb$(group)));\n }\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n GroupSamplingBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupSamplingBase',\n interfaces: [GroupAwareSampling, SamplingBase]\n };\n function GroupSystematicSampling(sampleSize) {\n GroupSystematicSampling$Companion_getInstance();\n GroupSamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(GroupSystematicSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + GroupSystematicSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n GroupSystematicSampling.prototype.isApplicable_ijg2gx$ = function (population, groupMapper, groupCount) {\n return GroupSamplingBase.prototype.isApplicable_ijg2gx$.call(this, population, groupMapper, groupCount) && SystematicSampling$Companion_getInstance().computeStep_vux9f0$(groupCount, this.sampleSize) >= 2;\n };\n GroupSystematicSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var distinctGroups = SamplingUtil_getInstance().distinctGroups_ejae6o$(groupMapper, population.rowCount());\n var step = SystematicSampling$Companion_getInstance().computeStep_vux9f0$(distinctGroups.size, this.sampleSize);\n var pickedGroups = HashSet_init_0();\n var i = 0;\n while (i < distinctGroups.size) {\n pickedGroups.add_11rb$(distinctGroups.get_za3lpa$(i));\n i = i + step | 0;\n }\n return this.doSelect_z69lec$(population, pickedGroups, groupMapper);\n };\n function GroupSystematicSampling$Companion() {\n GroupSystematicSampling$Companion_instance = this;\n this.ALIAS = 'group_systematic';\n }\n GroupSystematicSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GroupSystematicSampling$Companion_instance = null;\n function GroupSystematicSampling$Companion_getInstance() {\n if (GroupSystematicSampling$Companion_instance === null) {\n new GroupSystematicSampling$Companion();\n }return GroupSystematicSampling$Companion_instance;\n }\n GroupSystematicSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GroupSystematicSampling',\n interfaces: [GroupSamplingBase]\n };\n function PickSampling(sampleSize) {\n PickSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(PickSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + PickSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n PickSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var xVar = SamplingUtil_getInstance().xVar_dhhkv7$(population);\n var xFactors = population.distinctValues_8xm3sj$(xVar);\n if (xFactors.size <= this.sampleSize) {\n return population;\n }var pickX = toSet(take(xFactors, this.sampleSize));\n var xValues = population.get_8xm3sj$(xVar);\n var pickedIndices = ArrayList_init();\n var index = 0;\n for (var tmp$ = xValues.iterator(); tmp$.hasNext(); ++index) {\n var v = tmp$.next();\n if (contains(pickX, v)) {\n pickedIndices.add_11rb$(index);\n }}\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n function PickSampling$Companion() {\n PickSampling$Companion_instance = this;\n this.ALIAS = 'pick';\n }\n PickSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PickSampling$Companion_instance = null;\n function PickSampling$Companion_getInstance() {\n if (PickSampling$Companion_instance === null) {\n new PickSampling$Companion();\n }return PickSampling$Companion_instance;\n }\n PickSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PickSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function RandomSampling(sampleSize, mySeed) {\n RandomSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n }\n Object.defineProperty(RandomSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + RandomSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + ')';\n }\n });\n RandomSampling.prototype.apply_dhhkv7$ = function (population) {\n var tmp$, tmp$_0;\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var rand = (tmp$_0 = (tmp$ = this.mySeed_0) != null ? Random(tmp$) : null) != null ? tmp$_0 : Random_0.Default;\n return util.SamplingUtil.sampleWithoutReplacement_egh5ya$(this.sampleSize, rand, population);\n };\n function RandomSampling$Companion() {\n RandomSampling$Companion_instance = this;\n this.ALIAS = 'random';\n }\n RandomSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RandomSampling$Companion_instance = null;\n function RandomSampling$Companion_getInstance() {\n if (RandomSampling$Companion_instance === null) {\n new RandomSampling$Companion();\n }return RandomSampling$Companion_instance;\n }\n RandomSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function RandomStratifiedSampling(sampleSize, mySeed, myMinSubsampleSize) {\n RandomStratifiedSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n this.mySeed_0 = mySeed;\n this.myMinSubsampleSize_0 = myMinSubsampleSize;\n }\n Object.defineProperty(RandomStratifiedSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + RandomStratifiedSampling$Companion_getInstance().ALIAS_8be2vx$ + '(' + 'n=' + toString(this.sampleSize) + (this.mySeed_0 != null ? ', seed=' + toString(this.mySeed_0) : '') + (this.myMinSubsampleSize_0 != null ? ', min_subsample=' + toString(this.myMinSubsampleSize_0) : '') + ')';\n }\n });\n RandomStratifiedSampling.prototype.isApplicable_se5qvl$ = function (population, groupMapper) {\n return population.rowCount() > this.sampleSize;\n };\n function RandomStratifiedSampling$apply$lambda(closure$groupIndices) {\n return function (indexSet) {\n var $receiver = until(0, closure$groupIndices.size);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (indexSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n }\n function RandomStratifiedSampling$apply$lambda_0(closure$groupIndices) {\n return function (indexSet) {\n var $receiver = until(0, closure$groupIndices.size);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n if (!indexSet.contains_11rb$(element))\n destination.add_11rb$(element);\n }\n return destination;\n };\n }\n RandomStratifiedSampling.prototype.apply_se5qvl$ = function (population, groupMapper) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2, tmp$_3;\n if (!this.isApplicable_se5qvl$(population, groupMapper)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var indicesByGroup = GroupUtil_getInstance().indicesByGroup_wc9gac$(population.rowCount(), groupMapper);\n var minSubSampleSize = (tmp$ = this.myMinSubsampleSize_0) != null ? tmp$ : 2;\n var b = minSubSampleSize;\n minSubSampleSize = JsMath.max(0, b);\n var popSize = population.rowCount();\n var pickIndices = ArrayList_init();\n var rand = (tmp$_1 = (tmp$_0 = this.mySeed_0) != null ? Random(tmp$_0) : null) != null ? tmp$_1 : Random_0.Default;\n tmp$_2 = indicesByGroup.keys.iterator();\n while (tmp$_2.hasNext()) {\n var group = tmp$_2.next();\n var groupIndices = ensureNotNull(indicesByGroup.get_11rb$(group));\n var stratumSize = groupIndices.size;\n var ratio = stratumSize / popSize;\n var stratumSampleSize = numberToInt(round(this.sampleSize * ratio));\n var a = stratumSampleSize;\n var b_0 = minSubSampleSize;\n stratumSampleSize = JsMath.max(a, b_0);\n if (stratumSampleSize >= stratumSize) {\n pickIndices.addAll_brywnq$(groupIndices);\n } else {\n var sampleGroupIndices = util.SamplingUtil.sampleWithoutReplacement_o7ew15$(stratumSize, stratumSampleSize, rand, RandomStratifiedSampling$apply$lambda(groupIndices), RandomStratifiedSampling$apply$lambda_0(groupIndices));\n tmp$_3 = sampleGroupIndices.iterator();\n while (tmp$_3.hasNext()) {\n var i = tmp$_3.next();\n pickIndices.add_11rb$(groupIndices.get_za3lpa$(i));\n }\n }\n }\n return population.selectIndices_pqoyrt$(pickIndices);\n };\n function RandomStratifiedSampling$Companion() {\n RandomStratifiedSampling$Companion_instance = this;\n this.ALIAS_8be2vx$ = 'random_stratified';\n this.DEF_MIN_SUBSAMPLE_SIZE_0 = 2;\n }\n RandomStratifiedSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RandomStratifiedSampling$Companion_instance = null;\n function RandomStratifiedSampling$Companion_getInstance() {\n if (RandomStratifiedSampling$Companion_instance === null) {\n new RandomStratifiedSampling$Companion();\n }return RandomStratifiedSampling$Companion_instance;\n }\n RandomStratifiedSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RandomStratifiedSampling',\n interfaces: [GroupAwareSampling, SamplingBase]\n };\n function SamplingBase(sampleSize) {\n this.sampleSize = sampleSize;\n if (!(this.sampleSize > 0)) {\n var message = 'Sample size must be greater than zero, but was: ' + toString(this.sampleSize);\n throw IllegalStateException_init(message.toString());\n }}\n SamplingBase.prototype.isApplicable_dhhkv7$ = function (population) {\n return population.rowCount() > this.sampleSize;\n };\n SamplingBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SamplingBase',\n interfaces: [Sampling]\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function SamplingUtil() {\n SamplingUtil_instance = this;\n }\n SamplingUtil.prototype.groupCount_ejae6o$ = function (groupMapper, size) {\n var $receiver = until(0, size);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(groupMapper(item));\n }\n return distinct(destination).size;\n };\n SamplingUtil.prototype.distinctGroups_ejae6o$ = function (groupMapper, size) {\n var $receiver = until(0, size);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(groupMapper(item));\n }\n return toMutableList(distinct(destination));\n };\n SamplingUtil.prototype.xVar_bbyvt0$ = function (variables) {\n var tmp$;\n if (variables.contains_11rb$(stat.Stats.X))\n tmp$ = stat.Stats.X;\n else if (variables.contains_11rb$(data.TransformVar.X))\n tmp$ = data.TransformVar.X;\n else\n tmp$ = null;\n return tmp$;\n };\n SamplingUtil.prototype.xVar_dhhkv7$ = function (data) {\n var tmp$;\n tmp$ = this.xVar_bbyvt0$(data.variables());\n if (tmp$ == null) {\n throw IllegalStateException_init(\"Can't apply sampling: couldn't deduce the (X) variable.\");\n }return tmp$;\n };\n SamplingUtil.prototype.yVar_dhhkv7$ = function (data_0) {\n if (data_0.has_8xm3sj$(stat.Stats.Y)) {\n return stat.Stats.Y;\n } else if (data_0.has_8xm3sj$(data.TransformVar.Y)) {\n return data.TransformVar.Y;\n }throw IllegalStateException_init(\"Can't apply sampling: couldn't deduce the (Y) variable.\");\n };\n SamplingUtil.prototype.splitRings_dhhkv7$ = function (population) {\n var tmp$, tmp$_0;\n var rings = ArrayList_init();\n var lastPoint = null;\n var start = -1;\n var xValues = Kotlin.isType(tmp$ = population.get_8xm3sj$(this.xVar_dhhkv7$(population)), List) ? tmp$ : throwCCE();\n var yValues = Kotlin.isType(tmp$_0 = population.get_8xm3sj$(this.yVar_dhhkv7$(population)), List) ? tmp$_0 : throwCCE();\n var points = new VertexSampling$DoubleVectorComponentsList(xValues, yValues);\n for (var i = 0; i !== points.size; ++i) {\n var point = points.get_za3lpa$(i);\n if (start < 0) {\n start = i;\n lastPoint = point;\n } else if (equals(lastPoint, point)) {\n rings.add_11rb$(points.subList_vux9f0$(start, i + 1 | 0));\n start = -1;\n lastPoint = null;\n }}\n if (start >= 0) {\n rings.add_11rb$(points.subList_vux9f0$(start, points.size));\n }return rings;\n };\n function SamplingUtil$calculateRingLimits$lambda(closure$rings) {\n return function (it) {\n return new Pair(it, calculateArea(closure$rings.get_za3lpa$(it)));\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_0(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingArea_0(it);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_1(closure$totalArea, closure$areaProceed, closure$totalPointsLimit, closure$pointsProceed, closure$rings, this$SamplingUtil) {\n return function (p) {\n var a = roundToInt(p.second / (closure$totalArea - closure$areaProceed.get()) * (closure$totalPointsLimit - closure$pointsProceed.get() | 0));\n var b = closure$rings.get_za3lpa$(this$SamplingUtil.getRingIndex_3gcxfl$(p)).size;\n var limit = JsMath.min(a, b);\n if (limit >= 4) {\n closure$areaProceed.getAndAdd_14dthe$(this$SamplingUtil.getRingArea_0(p));\n closure$pointsProceed.getAndAdd_za3lpa$(limit);\n } else {\n limit = 0;\n }\n return new Pair(this$SamplingUtil.getRingIndex_3gcxfl$(p), limit);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_2(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingIndex_3gcxfl$(it);\n };\n }\n function SamplingUtil$calculateRingLimits$lambda_3(this$SamplingUtil) {\n return function (it) {\n return this$SamplingUtil.getRingLimit_66os8t$(it);\n };\n }\n SamplingUtil.prototype.calculateRingLimits_rmr3bv$ = function (rings, totalPointsLimit) {\n var destination = ArrayList_init_0(collectionSizeOrDefault(rings, 10));\n var tmp$;\n tmp$ = rings.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(calculateArea(item));\n }\n var totalArea = sum(destination);\n var areaProceed = new MutableDouble(0.0);\n var pointsProceed = new MutableInteger(0);\n return toList_0(map(sortedWith_0(map(sortedWith_0(map(asSequence(get_indices(rings)), SamplingUtil$calculateRingLimits$lambda(rings)), reversed(new Comparator(compareBy$lambda_0(SamplingUtil$calculateRingLimits$lambda_0(this))))), SamplingUtil$calculateRingLimits$lambda_1(totalArea, areaProceed, totalPointsLimit, pointsProceed, rings, this)), new Comparator(compareBy$lambda_0(SamplingUtil$calculateRingLimits$lambda_2(this)))), SamplingUtil$calculateRingLimits$lambda_3(this)));\n };\n SamplingUtil.prototype.getRingIndex_3gcxfl$ = function (pair) {\n return pair.first;\n };\n SamplingUtil.prototype.getRingArea_0 = function (pair) {\n return pair.second;\n };\n SamplingUtil.prototype.getRingLimit_66os8t$ = function (pair) {\n return pair.second;\n };\n SamplingUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SamplingUtil',\n interfaces: []\n };\n var SamplingUtil_instance = null;\n function SamplingUtil_getInstance() {\n if (SamplingUtil_instance === null) {\n new SamplingUtil();\n }return SamplingUtil_instance;\n }\n function SystematicSampling(sampleSize) {\n SystematicSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n Object.defineProperty(SystematicSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + SystematicSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n SystematicSampling.prototype.isApplicable_dhhkv7$ = function (population) {\n return SamplingBase.prototype.isApplicable_dhhkv7$.call(this, population) && this.computeStep_0(population.rowCount()) >= 2;\n };\n SystematicSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var popSize = population.rowCount();\n var step = this.computeStep_0(popSize);\n var pickedIndices = ArrayList_init();\n var i = 0;\n while (i < popSize) {\n pickedIndices.add_11rb$(i);\n i = i + step | 0;\n }\n return population.selectIndices_pqoyrt$(pickedIndices);\n };\n SystematicSampling.prototype.computeStep_0 = function (popSize) {\n return numberToInt(round(popSize / (this.sampleSize - 1 | 0)));\n };\n function SystematicSampling$Companion() {\n SystematicSampling$Companion_instance = this;\n this.ALIAS = 'systematic';\n }\n SystematicSampling$Companion.prototype.computeStep_vux9f0$ = function (popSize, sampleSize) {\n return numberToInt(round((popSize - 1 | 0) / (sampleSize - 1 | 0)));\n };\n SystematicSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SystematicSampling$Companion_instance = null;\n function SystematicSampling$Companion_getInstance() {\n if (SystematicSampling$Companion_instance === null) {\n new SystematicSampling$Companion();\n }return SystematicSampling$Companion_instance;\n }\n SystematicSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SystematicSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function VertexSampling(sampleSize) {\n VertexSampling$Companion_getInstance();\n SamplingBase.call(this, sampleSize);\n }\n VertexSampling.prototype.simplify_0 = function (points, limit) {\n var tmp$;\n if (limit === 0) {\n tmp$ = emptyList();\n } else {\n tmp$ = this.simplifyInternal_11hmxm$(points, limit);\n }\n return tmp$;\n };\n VertexSampling.prototype.apply_dhhkv7$ = function (population) {\n if (!this.isApplicable_dhhkv7$(population)) {\n var message = 'Failed requirement.';\n throw IllegalArgumentException_init(message.toString());\n }var rings = SamplingUtil_getInstance().splitRings_dhhkv7$(population);\n var limits = rings.size === 1 && !isClosed(rings.get_za3lpa$(0)) ? listOf(this.sampleSize) : SamplingUtil_getInstance().calculateRingLimits_rmr3bv$(rings, this.sampleSize);\n var indices = ArrayList_init();\n var ringBase = new MutableInteger(0);\n var $receiver = until(0, limits.size);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new Pair(item, limits.get_za3lpa$(item)));\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var tmp$_1;\n tmp$_1 = this.simplify_0(rings.get_za3lpa$(SamplingUtil_getInstance().getRingIndex_3gcxfl$(element)), SamplingUtil_getInstance().getRingLimit_66os8t$(element)).iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n indices.add_11rb$(ringBase.get() + element_0 | 0);\n }\n ringBase.getAndAdd_za3lpa$(rings.get_za3lpa$(SamplingUtil_getInstance().getRingIndex_3gcxfl$(element)).size);\n }\n return population.selectIndices_pqoyrt$(indices);\n };\n function VertexSampling$VertexVwSampling(sampleSize) {\n VertexSampling$VertexVwSampling$Companion_getInstance();\n VertexSampling.call(this, sampleSize);\n }\n Object.defineProperty(VertexSampling$VertexVwSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + VertexSampling$VertexVwSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n VertexSampling$VertexVwSampling.prototype.simplifyInternal_11hmxm$ = function (points, limit) {\n return PolylineSimplifier.Companion.visvalingamWhyatt_ytws2g$(points).setCountLimit_za3lpa$(limit).indices;\n };\n function VertexSampling$VertexVwSampling$Companion() {\n VertexSampling$VertexVwSampling$Companion_instance = this;\n this.ALIAS = 'vertex_vw';\n }\n VertexSampling$VertexVwSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$VertexVwSampling$Companion_instance = null;\n function VertexSampling$VertexVwSampling$Companion_getInstance() {\n if (VertexSampling$VertexVwSampling$Companion_instance === null) {\n new VertexSampling$VertexVwSampling$Companion();\n }return VertexSampling$VertexVwSampling$Companion_instance;\n }\n VertexSampling$VertexVwSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexVwSampling',\n interfaces: [VertexSampling]\n };\n function VertexSampling$VertexDpSampling(sampleSize) {\n VertexSampling$VertexDpSampling$Companion_getInstance();\n VertexSampling.call(this, sampleSize);\n }\n Object.defineProperty(VertexSampling$VertexDpSampling.prototype, 'expressionText', {\n configurable: true,\n get: function () {\n return 'sampling_' + VertexSampling$VertexDpSampling$Companion_getInstance().ALIAS + '(' + 'n=' + toString(this.sampleSize) + ')';\n }\n });\n VertexSampling$VertexDpSampling.prototype.simplifyInternal_11hmxm$ = function (points, limit) {\n return PolylineSimplifier.Companion.douglasPeucker_ytws2g$(points).setCountLimit_za3lpa$(limit).indices;\n };\n function VertexSampling$VertexDpSampling$Companion() {\n VertexSampling$VertexDpSampling$Companion_instance = this;\n this.ALIAS = 'vertex_dp';\n }\n VertexSampling$VertexDpSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$VertexDpSampling$Companion_instance = null;\n function VertexSampling$VertexDpSampling$Companion_getInstance() {\n if (VertexSampling$VertexDpSampling$Companion_instance === null) {\n new VertexSampling$VertexDpSampling$Companion();\n }return VertexSampling$VertexDpSampling$Companion_instance;\n }\n VertexSampling$VertexDpSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexDpSampling',\n interfaces: [VertexSampling]\n };\n function VertexSampling$DoubleVectorComponentsList(myXValues, myYValues) {\n AbstractList.call(this);\n this.myXValues_0 = myXValues;\n this.myYValues_0 = myYValues;\n }\n Object.defineProperty(VertexSampling$DoubleVectorComponentsList.prototype, 'size', {\n configurable: true,\n get: function () {\n return this.myXValues_0.size;\n }\n });\n VertexSampling$DoubleVectorComponentsList.prototype.get_za3lpa$ = function (index) {\n return VertexSampling$Companion_getInstance().createPoint_0(this.myXValues_0.get_za3lpa$(index), this.myYValues_0.get_za3lpa$(index));\n };\n VertexSampling$DoubleVectorComponentsList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DoubleVectorComponentsList',\n interfaces: [AbstractList]\n };\n function VertexSampling$Companion() {\n VertexSampling$Companion_instance = this;\n }\n VertexSampling$Companion.prototype.createPoint_0 = function (x, y) {\n var tmp$, tmp$_0;\n if (!!(typeof x === 'string' || typeof y === 'string')) {\n var message = 'String coords are not supported yet';\n throw IllegalArgumentException_init(message.toString());\n }if (!data_0.SeriesUtil.allFinite_jma9l8$(typeof (tmp$ = x) === 'number' ? tmp$ : throwCCE(), typeof (tmp$_0 = y) === 'number' ? tmp$_0 : throwCCE())) {\n var message_0 = 'Invalid coord';\n throw IllegalArgumentException_init(message_0.toString());\n }return new DoubleVector(x, y);\n };\n VertexSampling$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VertexSampling$Companion_instance = null;\n function VertexSampling$Companion_getInstance() {\n if (VertexSampling$Companion_instance === null) {\n new VertexSampling$Companion();\n }return VertexSampling$Companion_instance;\n }\n VertexSampling.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VertexSampling',\n interfaces: [PointSampling, SamplingBase]\n };\n function ContinuousOnlyMapperProvider(naValue) {\n MapperProviderBase.call(this, naValue);\n }\n function ContinuousOnlyMapperProvider$createDiscreteMapper$lambda(it) {\n return \"'\" + toString(it) + \"'\";\n }\n ContinuousOnlyMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var domainRepr = joinToString(domainValues, void 0, void 0, void 0, 3, void 0, ContinuousOnlyMapperProvider$createDiscreteMapper$lambda);\n throw IllegalStateException_init('[' + toString(Kotlin.getKClassFromExpression(this).simpleName) + \"] Can't create mapper for discrete domain: \" + domainRepr);\n };\n ContinuousOnlyMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ContinuousOnlyMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function DefaultMapperProvider() {\n DefaultMapperProvider_instance = this;\n this.PROVIDER_MAP_0 = new DefaultMapperProvider$TypedMapperProviderMap();\n }\n DefaultMapperProvider.prototype.get_31786j$ = function (aes) {\n return this.PROVIDER_MAP_0.get_lkzxyg$(aes);\n };\n DefaultMapperProvider.prototype.hasDefault_5adj56$ = function (aes) {\n return this.PROVIDER_MAP_0.containsKey_5adj56$(aes);\n };\n function DefaultMapperProvider$TypedMapperProviderMap() {\n DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance();\n this.myMap_0 = HashMap_init();\n var tmp$;\n tmp$ = Aes.Companion.allPositional().iterator();\n while (tmp$.hasNext()) {\n var aes = tmp$.next();\n this.put_0(aes, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_UNDEFINED_0);\n }\n this.put_0(Aes.Companion.X, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.Y, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.Z, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YMIN, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YMAX, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.COLOR, DefaultMapperProviderUtil_getInstance().createColorMapperProvider_8be2vx$());\n this.put_0(Aes.Companion.FILL, DefaultMapperProviderUtil_getInstance().createColorMapperProvider_8be2vx$());\n this.put_0(Aes.Companion.ALPHA, AlphaMapperProvider$Companion_getInstance().DEFAULT);\n this.put_0(Aes.Companion.SHAPE, DefaultMapperProviderUtil_getInstance().createWithDiscreteOutput_rath1t$(ShapeMapper_getInstance().allShapes(), ShapeMapper_getInstance().NA_VALUE));\n this.put_0(Aes.Companion.LINETYPE, DefaultMapperProviderUtil_getInstance().createWithDiscreteOutput_rath1t$(LineTypeMapper_getInstance().allLineTypes(), LineTypeMapper_getInstance().NA_VALUE));\n this.put_0(Aes.Companion.SIZE, SizeMapperProvider$Companion_getInstance().DEFAULT);\n this.put_0(Aes.Companion.WIDTH, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.HEIGHT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.WEIGHT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.INTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SLOPE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XINTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YINTERCEPT, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.LOWER, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.MIDDLE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.UPPER, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.FRAME, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FRAME));\n this.put_0(Aes.Companion.SPEED, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.FLOW, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XMIN, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XMAX, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.XEND, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.YEND, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.LABEL, DefaultMapperProviderUtil_getInstance().createObjectIdentity_bv5adw$(Aes.Companion.LABEL));\n this.put_0(Aes.Companion.FAMILY, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FAMILY));\n this.put_0(Aes.Companion.FONTFACE, DefaultMapperProviderUtil_getInstance().createStringIdentity_kc1el2$(Aes.Companion.FONTFACE));\n this.put_0(Aes.Companion.HJUST, DefaultMapperProviderUtil_getInstance().createObjectIdentityDiscrete_e4pcbt$(Aes.Companion.HJUST));\n this.put_0(Aes.Companion.VJUST, DefaultMapperProviderUtil_getInstance().createObjectIdentityDiscrete_e4pcbt$(Aes.Companion.VJUST));\n this.put_0(Aes.Companion.ANGLE, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SYM_X, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n this.put_0(Aes.Companion.SYM_Y, DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance().NUMERIC_IDENTITY_0);\n }\n DefaultMapperProvider$TypedMapperProviderMap.prototype.get_lkzxyg$ = function (aes) {\n var tmp$;\n return Kotlin.isType(tmp$ = this.myMap_0.get_11rb$(aes), MapperProvider) ? tmp$ : throwCCE();\n };\n DefaultMapperProvider$TypedMapperProviderMap.prototype.put_0 = function (aes, value) {\n this.myMap_0.put_xwzc9p$(aes, value);\n };\n DefaultMapperProvider$TypedMapperProviderMap.prototype.containsKey_5adj56$ = function (aes) {\n return this.myMap_0.containsKey_11rb$(aes);\n };\n function DefaultMapperProvider$TypedMapperProviderMap$Companion() {\n DefaultMapperProvider$TypedMapperProviderMap$Companion_instance = this;\n this.NUMERIC_UNDEFINED_0 = new DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral();\n this.NUMERIC_IDENTITY_0 = new DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral();\n }\n function DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral() {\n }\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().UNDEFINED;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().UNDEFINED;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_UNDEFINED$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n function DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral() {\n }\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().IDENTITY;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().IDENTITY;\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion$NUMERIC_IDENTITY$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProvider$TypedMapperProviderMap$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DefaultMapperProvider$TypedMapperProviderMap$Companion_instance = null;\n function DefaultMapperProvider$TypedMapperProviderMap$Companion_getInstance() {\n if (DefaultMapperProvider$TypedMapperProviderMap$Companion_instance === null) {\n new DefaultMapperProvider$TypedMapperProviderMap$Companion();\n }return DefaultMapperProvider$TypedMapperProviderMap$Companion_instance;\n }\n DefaultMapperProvider$TypedMapperProviderMap.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TypedMapperProviderMap',\n interfaces: []\n };\n DefaultMapperProvider.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultMapperProvider',\n interfaces: []\n };\n var DefaultMapperProvider_instance = null;\n function DefaultMapperProvider_getInstance() {\n if (DefaultMapperProvider_instance === null) {\n new DefaultMapperProvider();\n }return DefaultMapperProvider_instance;\n }\n function DefaultMapperProviderUtil() {\n DefaultMapperProviderUtil_instance = this;\n }\n function DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral(closure$discrete, closure$continuous) {\n this.closure$discrete = closure$discrete;\n this.closure$continuous = closure$continuous;\n }\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.closure$discrete.createDiscreteMapper_7f6uoc$(domainValues);\n };\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return this.closure$continuous.createContinuousMapper_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n };\n DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createColorMapperProvider_8be2vx$ = function () {\n var discrete = new ColorBrewerMapperProvider(null, null, null, Color.Companion.GRAY);\n var continuous = ColorGradientMapperProvider$Companion_getInstance().DEFAULT;\n return new DefaultMapperProviderUtil$createColorMapperProvider$ObjectLiteral(discrete, continuous);\n };\n function DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral(closure$outputValues, closure$naValue) {\n this.closure$outputValues = closure$outputValues;\n this.closure$naValue = closure$naValue;\n }\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, this.closure$outputValues, this.closure$naValue);\n };\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().continuousToDiscrete_fooeq8$(scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans), this.closure$outputValues, this.closure$naValue);\n };\n DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [MapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createWithDiscreteOutput_rath1t$ = function (outputValues, naValue) {\n return new DefaultMapperProviderUtil$createWithDiscreteOutput$ObjectLiteral(outputValues, naValue);\n };\n function DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral(inputConverter, naValue) {\n IdentityDiscreteMapperProvider.call(this, inputConverter, naValue);\n }\n function DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral$createContinuousMapper$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral$createContinuousMapper$lambda);\n };\n DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [IdentityDiscreteMapperProvider]\n };\n function DefaultMapperProviderUtil$createObjectIdentity$DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral_init$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil.prototype.createObjectIdentity_bv5adw$ = function (aes) {\n return new DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral(DefaultMapperProviderUtil$createObjectIdentity$DefaultMapperProviderUtil$createObjectIdentity$ObjectLiteral_init$lambda, null);\n };\n function DefaultMapperProviderUtil$createObjectIdentityDiscrete$lambda(it) {\n return it;\n }\n DefaultMapperProviderUtil.prototype.createObjectIdentityDiscrete_e4pcbt$ = function (aes) {\n var converter = DefaultMapperProviderUtil$createObjectIdentityDiscrete$lambda;\n return this.createIdentityMapperProvider_0(aes, converter, null);\n };\n function DefaultMapperProviderUtil$createStringIdentity$lambda(it) {\n return it != null ? it.toString() : null;\n }\n function DefaultMapperProviderUtil$createStringIdentity$lambda_0(it) {\n return it != null ? it.toString() : null;\n }\n DefaultMapperProviderUtil.prototype.createStringIdentity_kc1el2$ = function (aes) {\n var converter = DefaultMapperProviderUtil$createStringIdentity$lambda;\n var continuousMapper = DefaultMapperProviderUtil$createStringIdentity$lambda_0;\n return this.createIdentityMapperProvider_0(aes, converter, continuousMapper);\n };\n function DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral(closure$continuousMapper, closure$aes, inputConverter, naValue) {\n this.closure$continuousMapper = closure$continuousMapper;\n this.closure$aes = closure$aes;\n IdentityDiscreteMapperProvider.call(this, inputConverter, naValue);\n }\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n if (this.closure$continuousMapper != null) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(this.closure$continuousMapper);\n }throw IllegalStateException_init(\"Can't create \" + this.closure$aes + ' mapper for continuous domain ' + domain);\n };\n DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [IdentityDiscreteMapperProvider]\n };\n DefaultMapperProviderUtil.prototype.createIdentityMapperProvider_0 = function (aes, converter, continuousMapper) {\n return new DefaultMapperProviderUtil$createIdentityMapperProvider$ObjectLiteral(continuousMapper, aes, converter, DefaultNaValue_getInstance().get_31786j$(aes));\n };\n DefaultMapperProviderUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultMapperProviderUtil',\n interfaces: []\n };\n var DefaultMapperProviderUtil_instance = null;\n function DefaultMapperProviderUtil_getInstance() {\n if (DefaultMapperProviderUtil_instance === null) {\n new DefaultMapperProviderUtil();\n }return DefaultMapperProviderUtil_instance;\n }\n function DefaultNaValue() {\n DefaultNaValue_instance = this;\n this.VALUE_MAP_0 = new TypedKeyHashMap();\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.X, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.Y, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.Z, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YMIN, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YMAX, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.COLOR, Color.Companion.GRAY);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FILL, Color.Companion.GRAY);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.ALPHA, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SHAPE, point.TinyPointShape);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LINETYPE, NamedLineType.SOLID);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SIZE, aes.AesScaling.sizeFromCircleDiameter_14dthe$(1.0));\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.WIDTH, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.HEIGHT, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.WEIGHT, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.INTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SLOPE, 1.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XINTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YINTERCEPT, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LOWER, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.MIDDLE, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.UPPER, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FRAME, 'empty frame');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SPEED, 10.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FLOW, 0.1);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XMIN, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XMAX, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.XEND, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.YEND, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.LABEL, '-');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FAMILY, 'sans-serif');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.FONTFACE, 'plain');\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.HJUST, 0.5);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.VJUST, 0.5);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.ANGLE, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SYM_X, 0.0);\n this.VALUE_MAP_0.put_ev6mlr$(Aes.Companion.SYM_Y, 0.0);\n }\n DefaultNaValue.prototype.has_896ixz$ = function (aes) {\n return this.VALUE_MAP_0.containsKey_ex36zt$(aes);\n };\n DefaultNaValue.prototype.get_31786j$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n DefaultNaValue.prototype.get_ex36zt$ = function (aes) {\n return this.VALUE_MAP_0.get_ex36zt$(aes);\n };\n DefaultNaValue.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DefaultNaValue',\n interfaces: []\n };\n var DefaultNaValue_instance = null;\n function DefaultNaValue_getInstance() {\n if (DefaultNaValue_instance === null) {\n new DefaultNaValue();\n }return DefaultNaValue_instance;\n }\n function DiscreteOnlyMapperProvider(naValue) {\n MapperProviderBase.call(this, naValue);\n }\n DiscreteOnlyMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n throw IllegalStateException_init('[' + toString(Kotlin.getKClassFromExpression(this).simpleName) + \"] Can't create mapper for continuous domain \" + domain);\n };\n DiscreteOnlyMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DiscreteOnlyMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function GuideMapper() {\n }\n GuideMapper.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'GuideMapper',\n interfaces: [Function]\n };\n function MapperProvider() {\n }\n MapperProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'MapperProvider',\n interfaces: []\n };\n function ScaleProvider() {\n }\n ScaleProvider.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ScaleProvider',\n interfaces: []\n };\n function ScaleProviderBuilder(aes) {\n this.aes_0 = aes;\n this._mapperProvider_0 = null;\n this.myName_0 = null;\n this.myBreaks_0 = null;\n this.myLabels_0 = null;\n this.myLabelFormat_0 = null;\n this.myMultiplicativeExpand_0 = null;\n this.myAdditiveExpand_0 = null;\n this.myLimits_0 = null;\n this.myContinuousTransform_0 = transform.Transforms.IDENTITY;\n this.myBreaksGenerator_0 = null;\n this.myDiscreteDomain_0 = false;\n this.myDiscreteDomainReverse_0 = false;\n }\n Object.defineProperty(ScaleProviderBuilder.prototype, 'mapperProvider', {\n configurable: true,\n get: function () {\n var tmp$;\n if (this._mapperProvider_0 == null) {\n this._mapperProvider_0 = DefaultMapperProvider_getInstance().get_31786j$(this.aes_0);\n }tmp$ = this._mapperProvider_0;\n if (tmp$ == null) {\n throw AssertionError_init('Set to null by another thread');\n }return tmp$;\n },\n set: function (p) {\n this._mapperProvider_0 = p;\n }\n });\n ScaleProviderBuilder.prototype.mapperProvider_dw300d$ = function (mapperProvider) {\n this.mapperProvider = mapperProvider;\n return this;\n };\n ScaleProviderBuilder.prototype.name_61zpoe$ = function (name) {\n this.myName_0 = name;\n return this;\n };\n ScaleProviderBuilder.prototype.breaks_pqjuzw$ = function (breaks) {\n this.myBreaks_0 = breaks;\n return this;\n };\n ScaleProviderBuilder.prototype.minorBreaks_NI_d3e2cz$ = function (minorBreaks) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.labels_mhpeer$ = function (labels) {\n this.myLabels_0 = ArrayList_init_1(labels);\n return this;\n };\n ScaleProviderBuilder.prototype.labelFormat_pdl1vj$ = function (format) {\n this.myLabelFormat_0 = format;\n return this;\n };\n ScaleProviderBuilder.prototype.multiplicativeExpand_14dthe$ = function (v) {\n this.myMultiplicativeExpand_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.additiveExpand_14dthe$ = function (v) {\n this.myAdditiveExpand_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.limits_9ma18$ = function (v) {\n this.myLimits_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.rescaler_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.oob_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.continuousTransform_gxz7zd$ = function (v) {\n this.myContinuousTransform_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.breaksGenerator_6q5k0b$ = function (v) {\n this.myBreaksGenerator_0 = v;\n return this;\n };\n ScaleProviderBuilder.prototype.guide_NI_za3rmp$ = function (v) {\n throw IllegalStateException_init('Not implemented');\n };\n ScaleProviderBuilder.prototype.discreteDomain_6taknv$ = function (b) {\n this.myDiscreteDomain_0 = b;\n return this;\n };\n ScaleProviderBuilder.prototype.discreteDomainReverse_6taknv$ = function (b) {\n this.myDiscreteDomainReverse_0 = b;\n return this;\n };\n ScaleProviderBuilder.prototype.build = function () {\n return new ScaleProviderBuilder$MyScaleProvider(this);\n };\n function ScaleProviderBuilder$MyScaleProvider(b) {\n this.myName_0 = b.myName_0;\n var tmp$, tmp$_0, tmp$_1;\n this.myLabels_0 = (tmp$ = b.myLabels_0) != null ? ArrayList_init_1(tmp$) : null;\n this.myLabelFormat_0 = b.myLabelFormat_0;\n this.myMultiplicativeExpand_0 = b.myMultiplicativeExpand_0;\n this.myAdditiveExpand_0 = b.myAdditiveExpand_0;\n this.discreteDomainReverse_0 = b.myDiscreteDomainReverse_0;\n this.myBreaksGenerator_0 = b.myBreaksGenerator_0;\n this.myAes_0 = b.aes_0;\n this.discreteDomain_sylt8i$_0 = b.myDiscreteDomain_0;\n this.mapperProvider_yqrzmx$_0 = b.mapperProvider;\n this.breaks_h22v6v$_0 = (tmp$_0 = b.myBreaks_0) != null ? ArrayList_init_1(tmp$_0) : null;\n this.limits_hmyn8j$_0 = (tmp$_1 = b.myLimits_0) != null ? ArrayList_init_1(tmp$_1) : null;\n this.continuousTransform_hc6st8$_0 = b.myContinuousTransform_0;\n }\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'discreteDomain', {\n configurable: true,\n get: function () {\n return this.discreteDomain_sylt8i$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'mapperProvider', {\n configurable: true,\n get: function () {\n return this.mapperProvider_yqrzmx$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'breaks', {\n configurable: true,\n get: function () {\n return this.breaks_h22v6v$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'limits', {\n configurable: true,\n get: function () {\n return this.limits_hmyn8j$_0;\n }\n });\n Object.defineProperty(ScaleProviderBuilder$MyScaleProvider.prototype, 'continuousTransform', {\n configurable: true,\n get: function () {\n return this.continuousTransform_hc6st8$_0;\n }\n });\n ScaleProviderBuilder$MyScaleProvider.prototype.scaleName_0 = function (variable) {\n var tmp$;\n return (tmp$ = this.myName_0) != null ? tmp$ : variable.label;\n };\n ScaleProviderBuilder$MyScaleProvider.prototype.createScale_4d40sm$ = function (defaultName, discreteDomain) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n var name = (tmp$ = this.myName_0) != null ? tmp$ : defaultName;\n var scale_0;\n var domainValues = filterNotNull(discreteDomain);\n if (discreteDomain.isEmpty()) {\n tmp$_0 = this.absentMapper_0(defaultName);\n } else {\n tmp$_0 = getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_11rb$(p1);\n }.bind(null, this.mapperProvider.createDiscreteMapper_7f6uoc$(domainValues)));\n }\n var mapper = tmp$_0;\n if (this.discreteDomainReverse_0) {\n domainValues = reversed_0(domainValues);\n }scale_0 = scale.Scales.discreteDomain_l9mre7$(name, domainValues, mapper);\n var tmp$_3;\n if ((tmp$_2 = (tmp$_1 = this.limits) != null ? filterNotNull(tmp$_1) : null) != null) {\n var block$result;\n if (this.discreteDomainReverse_0) {\n block$result = reversed_0(tmp$_2);\n } else {\n block$result = tmp$_2;\n }\n tmp$_3 = block$result;\n } else\n tmp$_3 = null;\n var discreteLimits = tmp$_3;\n if (discreteLimits != null) {\n scale_0 = scale_0.with().limits_pqjuzw$(discreteLimits).build();\n }return this.completeScale_0(scale_0);\n };\n function ScaleProviderBuilder$MyScaleProvider$createScale$lambda(closure$mapper) {\n return function (v) {\n return closure$mapper.apply_11rb$(v);\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.createScale_phlls$ = function (defaultName, continuousDomain) {\n var tmp$, tmp$_0, tmp$_1;\n var name = (tmp$ = this.myName_0) != null ? tmp$ : defaultName;\n var scale_0;\n var dataRange = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(continuousDomain);\n var lowerLimit = null;\n var upperLimit = null;\n if (this.limits != null) {\n var lower = true;\n tmp$_0 = this.limits.iterator();\n while (tmp$_0.hasNext()) {\n var limit = tmp$_0.next();\n if (Kotlin.isNumber(limit)) {\n var v = numberToDouble(limit);\n if (isFinite(v)) {\n if (lower) {\n lowerLimit = v;\n } else {\n upperLimit = v;\n }\n }}lower = false;\n }\n }var mapper = this.mapperProvider.createContinuousMapper_1g0x2p$(dataRange, lowerLimit, upperLimit, this.continuousTransform);\n var continuousRange = mapper.isContinuous || this.myAes_0.isNumeric;\n scale_0 = scale.Scales.continuousDomain_lo18em$(name, ScaleProviderBuilder$MyScaleProvider$createScale$lambda(mapper), continuousRange);\n if (Kotlin.isType(mapper, WithGuideBreaks)) {\n Kotlin.isType(tmp$_1 = mapper, WithGuideBreaks) ? tmp$_1 : throwCCE();\n scale_0 = scale_0.with().breaks_pqjuzw$(mapper.breaks).labelFormatter_h0j1qz$(mapper.formatter).build();\n }scale_0 = scale_0.with().continuousTransform_gxz7zd$(this.continuousTransform).build();\n if (this.myBreaksGenerator_0 != null) {\n scale_0 = scale_0.with().breaksGenerator_6q5k0b$(this.myBreaksGenerator_0).build();\n }if (this.limits != null) {\n var with_0 = scale_0.with();\n if (lowerLimit != null) {\n with_0.lowerLimit_14dthe$(lowerLimit);\n }if (upperLimit != null) {\n with_0.upperLimit_14dthe$(upperLimit);\n }scale_0 = with_0.build();\n }return this.completeScale_0(scale_0);\n };\n ScaleProviderBuilder$MyScaleProvider.prototype.completeScale_0 = function (scale) {\n var with_0 = scale.with();\n if (this.breaks != null) {\n with_0.breaks_pqjuzw$(this.breaks);\n }if (this.myLabels_0 != null) {\n with_0.labels_mhpeer$(this.myLabels_0);\n }if (this.myLabelFormat_0 != null) {\n with_0.labelFormatter_h0j1qz$(getCallableRef('format', function ($receiver, p1) {\n return $receiver.format_za3rmp$(p1);\n }.bind(null, StringFormat.Companion.create_w8bwfu$(this.myLabelFormat_0))));\n }if (this.myMultiplicativeExpand_0 != null) {\n with_0.multiplicativeExpand_14dthe$(this.myMultiplicativeExpand_0);\n }if (this.myAdditiveExpand_0 != null) {\n with_0.additiveExpand_14dthe$(this.myAdditiveExpand_0);\n }return with_0.build();\n };\n function ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda(closure$var) {\n return function (v) {\n throw IllegalStateException_init(\"Mapper for empty data series '\" + closure$var.name + \"' was invoked with arg \" + toString(v));\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.absentMapper_1 = function (var_0) {\n return ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda(var_0);\n };\n function ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda_0(closure$label) {\n return function (v) {\n throw IllegalStateException_init(\"Mapper for empty data series '\" + closure$label + \"' was invoked with arg \" + toString(v));\n };\n }\n ScaleProviderBuilder$MyScaleProvider.prototype.absentMapper_0 = function (label) {\n return ScaleProviderBuilder$MyScaleProvider$absentMapper$lambda_0(label);\n };\n ScaleProviderBuilder$MyScaleProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyScaleProvider',\n interfaces: [ScaleProvider]\n };\n ScaleProviderBuilder.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ScaleProviderBuilder',\n interfaces: []\n };\n function ScaleProviderHelper() {\n ScaleProviderHelper_instance = this;\n }\n ScaleProviderHelper.prototype.getOrCreateDefault_w8zkza$ = function (aes, providers) {\n var tmp$, tmp$_0;\n if (Aes.Companion.isPositionalX_896ixz$(aes))\n tmp$ = Aes.Companion.X;\n else if (Aes.Companion.isPositionalY_896ixz$(aes))\n tmp$ = Aes.Companion.Y;\n else\n tmp$ = aes;\n var realAes = tmp$;\n return (tmp$_0 = providers.get_11rb$(realAes)) != null ? tmp$_0 : this.createDefault_31786j$(realAes);\n };\n ScaleProviderHelper.prototype.createDefault_31786j$ = function (aes) {\n return (new ScaleProviderBuilder(aes)).build();\n };\n ScaleProviderHelper.prototype.createDefault_1va84n$ = function (aes, name) {\n return (new ScaleProviderBuilder(aes)).name_61zpoe$(name).build();\n };\n ScaleProviderHelper.prototype.create_bqnakv$ = function (name, aes, mapperProvider) {\n return (new ScaleProviderBuilder(aes)).mapperProvider_dw300d$(mapperProvider).name_61zpoe$(name).build();\n };\n ScaleProviderHelper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ScaleProviderHelper',\n interfaces: []\n };\n var ScaleProviderHelper_instance = null;\n function ScaleProviderHelper_getInstance() {\n if (ScaleProviderHelper_instance === null) {\n new ScaleProviderHelper();\n }return ScaleProviderHelper_instance;\n }\n function WithGuideBreaks() {\n }\n WithGuideBreaks.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'WithGuideBreaks',\n interfaces: []\n };\n function ColorMapper() {\n ColorMapper_instance = this;\n this.NA_VALUE = Color.Companion.GRAY;\n this.DEF_GRADIENT_LOW = Color.Companion.parseHex_61zpoe$('#132B43');\n this.DEF_GRADIENT_HIGH = Color.Companion.parseHex_61zpoe$('#56B1F7');\n }\n ColorMapper.prototype.gradientDefault_4fzjta$ = function (domain) {\n return this.gradient_e4qimg$(domain, this.DEF_GRADIENT_LOW, this.DEF_GRADIENT_HIGH, this.NA_VALUE);\n };\n ColorMapper.prototype.gradient_e4qimg$ = function (domain, low, high, naColor) {\n return this.gradientHSV_kw8gff$(domain, values.Colors.hsvFromRgb_98b62m$(low), values.Colors.hsvFromRgb_98b62m$(high), true, naColor);\n };\n ColorMapper.prototype.gradientHSV_kw8gff$ = function (domain, lowHSV, highHSV, autoHueDirection, naColor) {\n return this.gradientHSV_cr3zp$(domain, new HSV(lowHSV[0], lowHSV[1], lowHSV[2]), new HSV(highHSV[0], highHSV[1], highHSV[2]), autoHueDirection, naColor);\n };\n function ColorMapper$gradientHSV$lambda(closure$domain, closure$naColor, closure$mapperH, closure$mapperS, closure$mapperV) {\n return function (input) {\n if (input == null || !closure$domain.contains_mef7kx$(input)) {\n return closure$naColor;\n } else {\n var hue = closure$mapperH(input) % 360;\n var H = hue >= 0 ? hue : 360 + hue;\n var S = closure$mapperS(input);\n var V = closure$mapperV(input);\n return values.Colors.rgbFromHsv_yvo9jy$(H, S, V);\n }\n };\n }\n ColorMapper.prototype.gradientHSV_cr3zp$ = function (domain, lowHSV, highHSV, autoHueDirection, naColor) {\n var lowHue = lowHSV.h;\n var highHue = highHSV.h;\n var lowS = lowHSV.s;\n var highS = highHSV.s;\n if (lowS < 1.0E-4) {\n lowHue = highHue;\n }if (highS < 1.0E-4) {\n highHue = lowHue;\n }if (autoHueDirection) {\n var x = highHue - lowHue;\n var dH = JsMath.abs(x);\n if (dH > 180) {\n if (highHue >= lowHue) {\n lowHue += 360.0;\n } else {\n highHue += 360.0;\n }\n }}var mapperH = scale.Mappers.linear_yl4mmw$(domain, lowHue, highHue, kotlin_js_internal_DoubleCompanionObject.NaN);\n var mapperS = scale.Mappers.linear_yl4mmw$(domain, lowS, highS, kotlin_js_internal_DoubleCompanionObject.NaN);\n var mapperV = scale.Mappers.linear_yl4mmw$(domain, lowHSV.v, highHSV.v, kotlin_js_internal_DoubleCompanionObject.NaN);\n return ColorMapper$gradientHSV$lambda(domain, naColor, mapperH, mapperS, mapperV);\n };\n ColorMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorMapper',\n interfaces: []\n };\n var ColorMapper_instance = null;\n function ColorMapper_getInstance() {\n if (ColorMapper_instance === null) {\n new ColorMapper();\n }return ColorMapper_instance;\n }\n function GuideMapperAdapter(mapper, isContinuous) {\n this.mapper_0 = mapper;\n this.isContinuous_zgpeec$_0 = isContinuous;\n }\n Object.defineProperty(GuideMapperAdapter.prototype, 'isContinuous', {\n get: function () {\n return this.isContinuous_zgpeec$_0;\n }\n });\n GuideMapperAdapter.prototype.apply_11rb$ = function (value) {\n return this.mapper_0(value);\n };\n GuideMapperAdapter.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideMapperAdapter',\n interfaces: [GuideMapper]\n };\n function GuideMapperWithGuideBreaks(mapper, breaks, formatter) {\n this.mapper_0 = mapper;\n this.breaks_3tqv0$_0 = breaks;\n this.formatter_dkp6z6$_0 = formatter;\n this.isContinuous_jvxsgv$_0 = false;\n }\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'breaks', {\n get: function () {\n return this.breaks_3tqv0$_0;\n }\n });\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'formatter', {\n get: function () {\n return this.formatter_dkp6z6$_0;\n }\n });\n Object.defineProperty(GuideMapperWithGuideBreaks.prototype, 'isContinuous', {\n configurable: true,\n get: function () {\n return this.isContinuous_jvxsgv$_0;\n }\n });\n GuideMapperWithGuideBreaks.prototype.apply_11rb$ = function (value) {\n return this.mapper_0(value);\n };\n GuideMapperWithGuideBreaks.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GuideMapperWithGuideBreaks',\n interfaces: [WithGuideBreaks, GuideMapper]\n };\n function GuideMappers() {\n GuideMappers_instance = this;\n this.IDENTITY = new GuideMapperAdapter(scale.Mappers.IDENTITY, false);\n this.UNDEFINED = new GuideMapperAdapter(scale.Mappers.undefined_287e2$(), false);\n }\n GuideMappers.prototype.discreteToDiscrete_udkttt$ = function (data, variable, outputValues, naValue) {\n var domainValues = data.distinctValues_8xm3sj$(variable);\n return this.discreteToDiscrete_pkbp8v$(domainValues, outputValues, naValue);\n };\n function GuideMappers$discreteToDiscrete$lambda(v) {\n return v.toString();\n }\n GuideMappers.prototype.discreteToDiscrete_pkbp8v$ = function (domainValues, outputValues, naValue) {\n var mapper = scale.Mappers.discrete_rath1t$(outputValues, naValue);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return new GuideMapperWithGuideBreaks(mapper, destination, GuideMappers$discreteToDiscrete$lambda);\n };\n GuideMappers.prototype.continuousToDiscrete_fooeq8$ = function (domain, outputValues, naValue) {\n var mapper = scale.Mappers.quantized_hd8s0$(domain, outputValues, naValue);\n return this.asNotContinuous_rjdepr$(mapper);\n };\n function GuideMappers$discreteToContinuous$lambda(v) {\n return v.toString();\n }\n GuideMappers.prototype.discreteToContinuous_83ntpg$ = function (domainValues, outputRange, naValue) {\n var mapper = scale.Mappers.discreteToContinuous_83ntpg$(domainValues, outputRange, naValue);\n var destination = ArrayList_init();\n var tmp$;\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n var tmp$_0;\n if ((tmp$_0 = element) != null) {\n destination.add_11rb$(tmp$_0);\n }}\n return new GuideMapperWithGuideBreaks(mapper, destination, GuideMappers$discreteToContinuous$lambda);\n };\n GuideMappers.prototype.continuousToContinuous_lww37m$ = function (domain, range, naValue) {\n return this.asContinuous_rjdepr$(scale.Mappers.linear_lww37m$(domain, range, naValue));\n };\n GuideMappers.prototype.asNotContinuous_rjdepr$ = function (mapper) {\n return new GuideMapperAdapter(mapper, false);\n };\n GuideMappers.prototype.asContinuous_rjdepr$ = function (mapper) {\n return new GuideMapperAdapter(mapper, true);\n };\n GuideMappers.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'GuideMappers',\n interfaces: []\n };\n var GuideMappers_instance = null;\n function GuideMappers_getInstance() {\n if (GuideMappers_instance === null) {\n new GuideMappers();\n }return GuideMappers_instance;\n }\n function LineTypeMapper() {\n LineTypeMapper_instance = this;\n this.NA_VALUE = NamedLineType.SOLID;\n }\n LineTypeMapper.prototype.allLineTypes = function () {\n return listOf_0([NamedLineType.SOLID, NamedLineType.DASHED, NamedLineType.DOTTED, NamedLineType.DOTDASH, NamedLineType.LONGDASH, NamedLineType.TWODASH]);\n };\n LineTypeMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'LineTypeMapper',\n interfaces: []\n };\n var LineTypeMapper_instance = null;\n function LineTypeMapper_getInstance() {\n if (LineTypeMapper_instance === null) {\n new LineTypeMapper();\n }return LineTypeMapper_instance;\n }\n function ShapeMapper() {\n ShapeMapper_instance = this;\n this.NA_VALUE = point.TinyPointShape;\n }\n ShapeMapper.prototype.allShapes = function () {\n var bestSix = listOf_0([NamedShape.SOLID_CIRCLE, NamedShape.SOLID_TRIANGLE_UP, NamedShape.SOLID_SQUARE, NamedShape.STICK_PLUS, NamedShape.STICK_SQUARE_CROSS, NamedShape.STICK_STAR]);\n var theRest = LinkedHashSet_init_0(listOf_0(NamedShape$values().slice()));\n theRest.removeAll_brywnq$(bestSix);\n var shapes = ArrayList_init_1(bestSix);\n shapes.addAll_brywnq$(theRest);\n return shapes;\n };\n ShapeMapper.prototype.hollowShapes = function () {\n var tmp$;\n var bestThreeHollow = listOf_0([NamedShape.STICK_CIRCLE, NamedShape.STICK_TRIANGLE_UP, NamedShape.STICK_SQUARE]);\n var theRest = LinkedHashSet_init_0(listOf_0(NamedShape$values().slice()));\n theRest.removeAll_brywnq$(bestThreeHollow);\n var shapes = ArrayList_init_1(bestThreeHollow);\n tmp$ = theRest.iterator();\n while (tmp$.hasNext()) {\n var shape = tmp$.next();\n if (shape.isHollow) {\n shapes.add_11rb$(shape);\n }}\n return shapes;\n };\n ShapeMapper.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ShapeMapper',\n interfaces: []\n };\n var ShapeMapper_instance = null;\n function ShapeMapper_getInstance() {\n if (ShapeMapper_instance === null) {\n new ShapeMapper();\n }return ShapeMapper_instance;\n }\n function AlphaMapperProvider(range, naValue) {\n AlphaMapperProvider$Companion_getInstance();\n LinearNormalizingMapperProvider.call(this, range, naValue);\n }\n function AlphaMapperProvider$Companion() {\n AlphaMapperProvider$Companion_instance = this;\n this.DEF_RANGE_0 = new ClosedRange(0.1, 1.0);\n this.DEFAULT = new AlphaMapperProvider(this.DEF_RANGE_0, DefaultNaValue_getInstance().get_31786j$(Aes.Companion.ALPHA));\n }\n AlphaMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var AlphaMapperProvider$Companion_instance = null;\n function AlphaMapperProvider$Companion_getInstance() {\n if (AlphaMapperProvider$Companion_instance === null) {\n new AlphaMapperProvider$Companion();\n }return AlphaMapperProvider$Companion_instance;\n }\n AlphaMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'AlphaMapperProvider',\n interfaces: [LinearNormalizingMapperProvider]\n };\n function ColorBrewerMapperProvider(paletteTypeName, paletteNameOrIndex, direction, naValue) {\n ColorBrewerMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n this.paletteTypeName_0 = paletteTypeName;\n this.paletteNameOrIndex_0 = paletteNameOrIndex;\n this.direction_0 = direction;\n var tmp$;\n if (!((tmp$ = this.paletteNameOrIndex_0 != null ? typeof this.paletteNameOrIndex_0 === 'string' || Kotlin.isNumber(this.paletteNameOrIndex_0) : null) != null ? tmp$ : true)) {\n var message = ColorBrewerMapperProvider_init$lambda(this)();\n throw IllegalArgumentException_init(message.toString());\n }if (Kotlin.isNumber(this.paletteNameOrIndex_0)) {\n if (!(this.paletteTypeName_0 != null)) {\n var message_0 = \"brewer palette type required: 'seq', 'div' or 'qual'.\";\n throw IllegalArgumentException_init(message_0.toString());\n }}}\n ColorBrewerMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var colorScheme = this.colorScheme_0(true, domainValues.size);\n var colors = this.colors_0(colorScheme, domainValues.size);\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, colors, this.naValue);\n };\n ColorBrewerMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var colorScheme = this.colorScheme_0(false);\n var colors = this.colors_0(colorScheme, colorScheme.maxColors);\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n return GuideMappers_getInstance().continuousToDiscrete_fooeq8$(domain_0, colors, this.naValue);\n };\n ColorBrewerMapperProvider.prototype.colors_0 = function (colorScheme, count) {\n var tmp$, tmp$_0, tmp$_1;\n var colors = color.PaletteUtil.schemeColors_7q5c77$(colorScheme, count);\n tmp$_0 = (tmp$ = this.direction_0 != null ? this.direction_0 < 0 : null) != null ? tmp$ : false;\n if (tmp$_0 === true)\n tmp$_1 = collect.Lists.reverse_bemo1h$(colors);\n else if (tmp$_0 === false)\n tmp$_1 = colors;\n else\n tmp$_1 = Kotlin.noWhenBranchMatched();\n return tmp$_1;\n };\n ColorBrewerMapperProvider.prototype.colorScheme_0 = function (discrete, colorCount) {\n if (colorCount === void 0)\n colorCount = null;\n var tmp$, tmp$_0;\n if (typeof this.paletteNameOrIndex_0 === 'string') {\n var palType = color.PaletteUtil.paletteTypeByPaletteName_61zpoe$(this.paletteNameOrIndex_0);\n if (!(palType != null)) {\n var message = ColorBrewerMapperProvider$Companion_getInstance().cantFindPaletteError_0(this.paletteNameOrIndex_0);\n throw IllegalArgumentException_init(message.toString());\n }tmp$ = palType;\n } else if (this.paletteTypeName_0 != null)\n tmp$ = ColorBrewerMapperProvider$Companion_getInstance().paletteType_0(this.paletteTypeName_0);\n else if (discrete)\n tmp$ = ColorPalette$Type.QUALITATIVE;\n else\n tmp$ = ColorPalette$Type.SEQUENTIAL;\n var paletteType = tmp$;\n if (Kotlin.isNumber(this.paletteNameOrIndex_0))\n tmp$_0 = color.PaletteUtil.colorSchemeByIndex_vfydh1$(paletteType, numberToInt(this.paletteNameOrIndex_0));\n else if (typeof this.paletteNameOrIndex_0 === 'string')\n tmp$_0 = ColorBrewerMapperProvider$Companion_getInstance().colorSchemeByName_0(paletteType, this.paletteNameOrIndex_0);\n else if (paletteType === ColorPalette$Type.QUALITATIVE)\n tmp$_0 = colorCount != null && colorCount <= ColorPalette$Qualitative.Set2.maxColors ? ColorPalette$Qualitative.Set2 : ColorPalette$Qualitative.Set3;\n else\n tmp$_0 = color.PaletteUtil.colorSchemeByIndex_vfydh1$(paletteType, 0);\n return tmp$_0;\n };\n function ColorBrewerMapperProvider$Companion() {\n ColorBrewerMapperProvider$Companion_instance = this;\n }\n ColorBrewerMapperProvider$Companion.prototype.paletteType_0 = function (name) {\n var tmp$;\n if (name == null) {\n return ColorPalette$Type.SEQUENTIAL;\n }switch (name) {\n case 'seq':\n tmp$ = ColorPalette$Type.SEQUENTIAL;\n break;\n case 'div':\n tmp$ = ColorPalette$Type.DIVERGING;\n break;\n case 'qual':\n tmp$ = ColorPalette$Type.QUALITATIVE;\n break;\n default:throw IllegalArgumentException_init(\"Palette type expected one of 'seq' (sequential), 'div' (diverging) or 'qual' (qualitative) but was: '\" + toString(name) + \"'\");\n }\n return tmp$;\n };\n ColorBrewerMapperProvider$Companion.prototype.colorSchemeByName_0 = function (paletteType, paletteName) {\n var tmp$;\n try {\n switch (paletteType.name) {\n case 'SEQUENTIAL':\n tmp$ = ColorPalette$Sequential$valueOf(paletteName);\n break;\n case 'DIVERGING':\n tmp$ = ColorPalette$Diverging$valueOf(paletteName);\n break;\n case 'QUALITATIVE':\n tmp$ = ColorPalette$Qualitative$valueOf(paletteName);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n } catch (ignore) {\n if (Kotlin.isType(ignore, IllegalArgumentException)) {\n throw IllegalArgumentException_init(this.cantFindPaletteError_0(paletteName));\n } else\n throw ignore;\n }\n };\n ColorBrewerMapperProvider$Companion.prototype.cantFindPaletteError_0 = function (paletteName) {\n return trimMargin('\\n' + \" |Brewer palette '\" + paletteName + \"' was not found. \" + '\\n' + ' |Valid palette names are: ' + '\\n' + \" | Type 'seq' (sequential): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Sequential$values()) + ' ' + '\\n' + \" | Type 'div' (diverging): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Diverging$values()) + ' ' + '\\n' + \" | Type 'qual' (qualitative): \" + '\\n' + ' | ' + this.names_0(ColorPalette$Qualitative$values()) + ' ' + '\\n' + ' ');\n };\n function ColorBrewerMapperProvider$Companion$names$lambda(it) {\n return \"'\" + it.name + \"'\";\n }\n ColorBrewerMapperProvider$Companion.prototype.names_0 = function (enums) {\n return joinToString_0(enums, ', ', void 0, void 0, void 0, void 0, ColorBrewerMapperProvider$Companion$names$lambda);\n };\n ColorBrewerMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorBrewerMapperProvider$Companion_instance = null;\n function ColorBrewerMapperProvider$Companion_getInstance() {\n if (ColorBrewerMapperProvider$Companion_instance === null) {\n new ColorBrewerMapperProvider$Companion();\n }return ColorBrewerMapperProvider$Companion_instance;\n }\n function ColorBrewerMapperProvider_init$lambda(this$ColorBrewerMapperProvider) {\n return function () {\n return 'palette: expected a name or index but was: ' + toString(Kotlin.getKClassFromExpression(ensureNotNull(this$ColorBrewerMapperProvider.paletteNameOrIndex_0)).simpleName);\n };\n }\n ColorBrewerMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorBrewerMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function ColorGradient2MapperProvider(low, mid, high, midpoint, naValue) {\n ColorGradient2MapperProvider$Companion_getInstance();\n ContinuousOnlyMapperProvider.call(this, naValue);\n this.myLow_0 = null;\n this.myMid_0 = null;\n this.myHigh_0 = null;\n this.myMidpoint_0 = null;\n this.myLow_0 = low != null ? low : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_LOW_0;\n this.myMid_0 = mid != null ? mid : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_MID_0;\n this.myHigh_0 = high != null ? high : ColorGradient2MapperProvider$Companion_getInstance().DEF_GRADIENT_HIGH_0;\n this.myMidpoint_0 = midpoint != null ? midpoint : 0.0;\n }\n function ColorGradient2MapperProvider$createContinuousMapper$getMapper(closure$rangeMap) {\n return function (v) {\n var tmp$;\n var f_ = null;\n if (data_0.SeriesUtil.isFinite_yrwdxb$(v)) {\n var f_span = kotlin_js_internal_DoubleCompanionObject.NaN;\n tmp$ = closure$rangeMap.keys.iterator();\n while (tmp$.hasNext()) {\n var range = tmp$.next();\n if (range.contains_mef7kx$(ensureNotNull(v))) {\n var span = range.upperEnd - range.lowerEnd;\n if (f_ == null || f_span === 0.0) {\n f_ = closure$rangeMap.get_11rb$(range);\n f_span = span;\n } else if (span < f_span && span > 0) {\n f_ = closure$rangeMap.get_11rb$(range);\n f_span = span;\n }}}\n }return f_;\n };\n }\n function ColorGradient2MapperProvider$createContinuousMapper$lambda(closure$getMapper, this$ColorGradient2MapperProvider) {\n return function (input) {\n var tmp$;\n var mapper = closure$getMapper(input);\n return (tmp$ = mapper != null ? mapper(input) : null) != null ? tmp$ : this$ColorGradient2MapperProvider.naValue;\n };\n }\n ColorGradient2MapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n var tmp$ = domain_0.lowerEnd;\n var a = ensureNotNull(this.myMidpoint_0);\n var b = domain_0.lowerEnd;\n var lowDomain = new ClosedRange(tmp$, JsMath.max(a, b));\n var a_0 = this.myMidpoint_0;\n var b_0 = domain_0.upperEnd;\n var highDomain = new ClosedRange(JsMath.min(a_0, b_0), domain_0.upperEnd);\n var lowMapper = ColorMapper_getInstance().gradient_e4qimg$(lowDomain, this.myLow_0, this.myMid_0, this.naValue);\n var highMapper = ColorMapper_getInstance().gradient_e4qimg$(highDomain, this.myMid_0, this.myHigh_0, this.naValue);\n var rangeMap = mapOf([to(lowDomain, lowMapper), to(highDomain, highMapper)]);\n var getMapper = ColorGradient2MapperProvider$createContinuousMapper$getMapper(rangeMap);\n var mapperFun = ColorGradient2MapperProvider$createContinuousMapper$lambda(getMapper, this);\n return GuideMappers_getInstance().asContinuous_rjdepr$(mapperFun);\n };\n function ColorGradient2MapperProvider$Companion() {\n ColorGradient2MapperProvider$Companion_instance = this;\n this.DEF_GRADIENT_LOW_0 = Color.Companion.parseHex_61zpoe$('#964540');\n this.DEF_GRADIENT_MID_0 = Color.Companion.WHITE;\n this.DEF_GRADIENT_HIGH_0 = Color.Companion.parseHex_61zpoe$('#3B3D96');\n }\n ColorGradient2MapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorGradient2MapperProvider$Companion_instance = null;\n function ColorGradient2MapperProvider$Companion_getInstance() {\n if (ColorGradient2MapperProvider$Companion_instance === null) {\n new ColorGradient2MapperProvider$Companion();\n }return ColorGradient2MapperProvider$Companion_instance;\n }\n ColorGradient2MapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorGradient2MapperProvider',\n interfaces: [ContinuousOnlyMapperProvider]\n };\n function ColorGradientMapperProvider(low, high, naValue) {\n ColorGradientMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n this.low_0 = low != null ? low : ColorMapper_getInstance().DEF_GRADIENT_LOW;\n this.high_0 = high != null ? high : ColorMapper_getInstance().DEF_GRADIENT_HIGH;\n }\n ColorGradientMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var domainValuesAsNumbers = scale.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n var mapperDomain = ensureNotNull(data_0.SeriesUtil.range_l63ks6$(domainValuesAsNumbers.values));\n var gradient = ColorMapper_getInstance().gradient_e4qimg$(mapperDomain, this.low_0, this.high_0, this.naValue);\n return GuideMappers_getInstance().asNotContinuous_rjdepr$(gradient);\n };\n ColorGradientMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n var gradient = ColorMapper_getInstance().gradient_e4qimg$(domain_0, this.low_0, this.high_0, this.naValue);\n return GuideMappers_getInstance().asContinuous_rjdepr$(gradient);\n };\n function ColorGradientMapperProvider$Companion() {\n ColorGradientMapperProvider$Companion_instance = this;\n this.DEFAULT = new ColorGradientMapperProvider(null, null, ColorMapper_getInstance().NA_VALUE);\n }\n ColorGradientMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorGradientMapperProvider$Companion_instance = null;\n function ColorGradientMapperProvider$Companion_getInstance() {\n if (ColorGradientMapperProvider$Companion_instance === null) {\n new ColorGradientMapperProvider$Companion();\n }return ColorGradientMapperProvider$Companion_instance;\n }\n ColorGradientMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorGradientMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function ColorHueMapperProvider(hueRange, chroma, luminance, startHue, direction, naValue) {\n ColorHueMapperProvider$Companion_getInstance();\n HSVColorMapperProvider.call(this, naValue);\n this.myFromHSV_0 = null;\n this.myToHSV_0 = null;\n this.myHSVIntervals_0 = null;\n var tmp$;\n var hueRange_0 = ColorHueMapperProvider$Companion_getInstance().normalizeHueRange_0(hueRange);\n var clockwise = direction == null || direction !== -1.0;\n var fromHue = clockwise ? hueRange_0.lowerEnd : hueRange_0.upperEnd;\n var toHue = clockwise ? hueRange_0.upperEnd : hueRange_0.lowerEnd;\n var startHue_0 = startHue != null ? startHue : ColorHueMapperProvider$Companion_getInstance().DEF_START_HUE_0;\n if (hueRange_0.contains_mef7kx$(startHue_0) && startHue_0 - hueRange_0.lowerEnd > 1 && hueRange_0.upperEnd - startHue_0 > 1) {\n tmp$ = listOf_0([to(startHue_0, toHue), to(fromHue, startHue_0)]);\n } else {\n tmp$ = listOf(to(fromHue, toHue));\n }\n var hueIntervals = tmp$;\n var saturation = (chroma != null ? chroma % 100 : ColorHueMapperProvider$Companion_getInstance().DEF_SATURATION_0) / 100;\n var value = (luminance != null ? luminance % 100 : ColorHueMapperProvider$Companion_getInstance().DEF_VALUE_0) / 100;\n var destination = ArrayList_init_0(collectionSizeOrDefault(hueIntervals, 10));\n var tmp$_0;\n tmp$_0 = hueIntervals.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n destination.add_11rb$(to(new HSV(item.first, saturation, value), new HSV(item.second, saturation, value)));\n }\n this.myHSVIntervals_0 = destination;\n this.myFromHSV_0 = new HSV(fromHue, saturation, value);\n this.myToHSV_0 = new HSV(toHue, saturation, value);\n }\n ColorHueMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.createDiscreteMapper_q8tf2k$(domainValues, this.myFromHSV_0, this.myToHSV_0);\n };\n ColorHueMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n return this.createContinuousMapper_ytjjc$(domain_0, this.myHSVIntervals_0);\n };\n function ColorHueMapperProvider$Companion() {\n ColorHueMapperProvider$Companion_instance = this;\n this.DEF_SATURATION_0 = 50.0;\n this.DEF_VALUE_0 = 90.0;\n this.DEF_START_HUE_0 = 0.0;\n this.DEF_HUE_RANGE_0 = new ClosedRange(15.0, 375.0);\n this.DEFAULT = new ColorHueMapperProvider(null, null, null, null, null, Color.Companion.GRAY);\n }\n ColorHueMapperProvider$Companion.prototype.normalizeHueRange_0 = function (hueRange) {\n var tmp$;\n if (hueRange == null || hueRange.size !== 2) {\n tmp$ = this.DEF_HUE_RANGE_0;\n } else {\n var a = hueRange.get_za3lpa$(0);\n var b = hueRange.get_za3lpa$(1);\n var tmp$_0 = JsMath.min(a, b);\n var a_0 = hueRange.get_za3lpa$(0);\n var b_0 = hueRange.get_za3lpa$(1);\n tmp$ = new ClosedRange(tmp$_0, JsMath.max(a_0, b_0));\n }\n return tmp$;\n };\n ColorHueMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var ColorHueMapperProvider$Companion_instance = null;\n function ColorHueMapperProvider$Companion_getInstance() {\n if (ColorHueMapperProvider$Companion_instance === null) {\n new ColorHueMapperProvider$Companion();\n }return ColorHueMapperProvider$Companion_instance;\n }\n ColorHueMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ColorHueMapperProvider',\n interfaces: [HSVColorMapperProvider]\n };\n function DirectlyProportionalMapperProvider(max, naValue) {\n ContinuousOnlyMapperProvider.call(this, naValue);\n this.max_ks8piw$_0 = max;\n }\n DirectlyProportionalMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var dataMax = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans).upperEnd;\n return GuideMappers_getInstance().continuousToContinuous_lww37m$(new ClosedRange(0.0, dataMax), new ClosedRange(0.0, this.max_ks8piw$_0), this.naValue);\n };\n DirectlyProportionalMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DirectlyProportionalMapperProvider',\n interfaces: [ContinuousOnlyMapperProvider]\n };\n function GreyscaleLightnessMapperProvider(start, end, naValue) {\n GreyscaleLightnessMapperProvider$Companion_getInstance();\n HSVColorMapperProvider.call(this, naValue);\n this.myFromHSV_0 = null;\n this.myToHSV_0 = null;\n var value0 = start != null ? start : GreyscaleLightnessMapperProvider$Companion_getInstance().DEF_START_0;\n var value1 = end != null ? end : GreyscaleLightnessMapperProvider$Companion_getInstance().DEF_END_0;\n if (!rangeTo(0.0, 1.0).contains_mef7kx$(value0)) {\n var message = \"Value of 'start' must be in range: [0,1]: \" + toString(start);\n throw IllegalArgumentException_init(message.toString());\n }if (!rangeTo(0.0, 1.0).contains_mef7kx$(value1)) {\n var message_0 = \"Value of 'end' must be in range: [0,1]: \" + toString(end);\n throw IllegalArgumentException_init(message_0.toString());\n }this.myFromHSV_0 = new HSV(0.0, 0.0, value0);\n this.myToHSV_0 = new HSV(0.0, 0.0, value1);\n }\n GreyscaleLightnessMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.createDiscreteMapper_q8tf2k$(domainValues, this.myFromHSV_0, this.myToHSV_0);\n };\n GreyscaleLightnessMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var domain_0 = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n return this.createContinuousMapper_ytjjc$(domain_0, listOf(to(this.myFromHSV_0, this.myToHSV_0)));\n };\n function GreyscaleLightnessMapperProvider$Companion() {\n GreyscaleLightnessMapperProvider$Companion_instance = this;\n this.DEF_START_0 = 0.2;\n this.DEF_END_0 = 0.8;\n }\n GreyscaleLightnessMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var GreyscaleLightnessMapperProvider$Companion_instance = null;\n function GreyscaleLightnessMapperProvider$Companion_getInstance() {\n if (GreyscaleLightnessMapperProvider$Companion_instance === null) {\n new GreyscaleLightnessMapperProvider$Companion();\n }return GreyscaleLightnessMapperProvider$Companion_instance;\n }\n GreyscaleLightnessMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'GreyscaleLightnessMapperProvider',\n interfaces: [HSVColorMapperProvider]\n };\n function HSVColorMapperProvider(naValue) {\n HSVColorMapperProvider$Companion_getInstance();\n MapperProviderBase.call(this, naValue);\n }\n HSVColorMapperProvider.prototype.createDiscreteMapper_q8tf2k$ = function (domainValues, fromHSV, toHSV) {\n var domainValuesAsNumbers = scale.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(domainValues);\n var mapperDomain = data_0.SeriesUtil.ensureApplicableRange_4am1sd$(data_0.SeriesUtil.range_l63ks6$(domainValuesAsNumbers.values));\n var newFromHue = fromHSV.h;\n var newToHue = toHSV.h;\n if (domainValues.size > 1) {\n var x = toHSV.h % 360 - fromHSV.h % 360;\n var hueDiff = JsMath.abs(x);\n var step = (toHSV.h - fromHSV.h) / domainValues.size;\n if (hueDiff < JsMath.abs(step) / 2) {\n newFromHue = fromHSV.h + step / 2;\n newToHue = toHSV.h - step / 2;\n }}var gradient = ColorMapper_getInstance().gradientHSV_cr3zp$(mapperDomain, new HSV(newFromHue, fromHSV.s, fromHSV.v), new HSV(newToHue, toHSV.s, toHSV.v), false, this.naValue);\n return GuideMappers_getInstance().asNotContinuous_rjdepr$(gradient);\n };\n HSVColorMapperProvider.prototype.createContinuousMapper_ytjjc$ = function (domain, hsvIntervals) {\n var tmp$;\n switch (hsvIntervals.size) {\n case 0:\n throw IllegalArgumentException_init('Empty HSV intervals.');\n case 1:\n tmp$ = ColorMapper_getInstance().gradientHSV_cr3zp$(domain, hsvIntervals.get_za3lpa$(0).first, hsvIntervals.get_za3lpa$(0).second, false, this.naValue);\n break;\n default:tmp$ = HSVColorMapperProvider$Companion_getInstance().createCompositeColorMapper_0(domain, hsvIntervals, false, this.naValue);\n break;\n }\n var gradientMapper = tmp$;\n return GuideMappers_getInstance().asContinuous_rjdepr$(gradientMapper);\n };\n function HSVColorMapperProvider$Companion() {\n HSVColorMapperProvider$Companion_instance = this;\n }\n function HSVColorMapperProvider$Companion$createCompositeColorMapper$lambda(closure$naColor, closure$colorMappersPerSubDomain) {\n return function (v) {\n var tmp$, tmp$_0;\n if (v == null) {\n return closure$naColor;\n } else {\n var $receiver = closure$colorMappersPerSubDomain;\n var firstOrNull$result;\n firstOrNull$break: do {\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n if (element.first.contains_mef7kx$(v)) {\n firstOrNull$result = element;\n break firstOrNull$break;\n }}\n firstOrNull$result = null;\n }\n while (false);\n var mapper = (tmp$ = firstOrNull$result) != null ? tmp$.second : null;\n return (tmp$_0 = mapper != null ? mapper(v) : null) != null ? tmp$_0 : closure$naColor;\n }\n };\n }\n HSVColorMapperProvider$Companion.prototype.createCompositeColorMapper_0 = function (domain, hsvIntervals, autoHueDirection, naColor) {\n var colorMappersPerSubDomain = this.createColorMappersPerSubDomain_0(domain, hsvIntervals, autoHueDirection, naColor);\n return HSVColorMapperProvider$Companion$createCompositeColorMapper$lambda(naColor, colorMappersPerSubDomain);\n };\n HSVColorMapperProvider$Companion.prototype.createColorMappersPerSubDomain_0 = function (domain, hsvIntervals, autoHueDirection, naColor) {\n var subDomains = this.splitContinuousDomain_0(domain, hsvIntervals);\n var $receiver = zip(subDomains, hsvIntervals);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n var domain_0 = item.first;\n var hsvInterval = item.second;\n destination.add_11rb$(new Pair_0(domain_0, ColorMapper_getInstance().gradientHSV_cr3zp$(domain_0, hsvInterval.first, hsvInterval.second, autoHueDirection, naColor)));\n }\n return destination;\n };\n HSVColorMapperProvider$Companion.prototype.splitContinuousDomain_0 = function (domain, hsvIntervals) {\n var tmp$;\n var domainSize = domain.upperEnd - domain.lowerEnd;\n var destination = ArrayList_init_0(collectionSizeOrDefault(hsvIntervals, 10));\n var tmp$_0;\n tmp$_0 = hsvIntervals.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n var tmp$_1 = destination.add_11rb$;\n var x = item.first.h - item.second.h;\n tmp$_1.call(destination, JsMath.abs(x));\n }\n var hueIntervalSizeList = destination;\n var hueIntervalsTotalSize = sum(hueIntervalSizeList);\n var domainToHueIntevalRatio = domainSize / hueIntervalsTotalSize;\n var subDomains = ArrayList_init();\n var lowerEnd = domain.lowerEnd;\n tmp$ = hueIntervalSizeList.iterator();\n while (tmp$.hasNext()) {\n var hueIntervalSize = tmp$.next();\n var upperEnd = lowerEnd + hueIntervalSize * domainToHueIntevalRatio;\n subDomains.add_11rb$(new ClosedRange(lowerEnd, upperEnd));\n lowerEnd = upperEnd;\n }\n return subDomains;\n };\n HSVColorMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var HSVColorMapperProvider$Companion_instance = null;\n function HSVColorMapperProvider$Companion_getInstance() {\n if (HSVColorMapperProvider$Companion_instance === null) {\n new HSVColorMapperProvider$Companion();\n }return HSVColorMapperProvider$Companion_instance;\n }\n HSVColorMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'HSVColorMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function IdentityDiscreteMapperProvider(inputConverter, naValue) {\n DiscreteOnlyMapperProvider.call(this, naValue);\n this.inputConverter_lfub5e$_0 = inputConverter;\n }\n IdentityDiscreteMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n var tmp$, tmp$_0;\n var outputValues = ArrayList_init();\n tmp$ = domainValues.iterator();\n while (tmp$.hasNext()) {\n var inputValue = tmp$.next();\n if (inputValue == null) {\n outputValues.add_11rb$(this.naValue);\n } else {\n tmp$_0 = this.inputConverter_lfub5e$_0(inputValue);\n if (tmp$_0 == null) {\n throw IllegalStateException_init(\"Can't map input value \" + toString(inputValue) + ' to output type');\n }var outputValue = tmp$_0;\n outputValues.add_11rb$(outputValue);\n }\n }\n return GuideMappers_getInstance().discreteToDiscrete_pkbp8v$(domainValues, outputValues, this.naValue);\n };\n IdentityDiscreteMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityDiscreteMapperProvider',\n interfaces: [DiscreteOnlyMapperProvider]\n };\n function IdentityMapperProvider(discreteMapperProvider, continuousMapper) {\n this.discreteMapperProvider_0 = discreteMapperProvider;\n this.continuousMapper_0 = continuousMapper;\n }\n IdentityMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return this.discreteMapperProvider_0.createDiscreteMapper_7f6uoc$(domainValues);\n };\n IdentityMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n return GuideMappers_getInstance().asContinuous_rjdepr$(this.continuousMapper_0);\n };\n IdentityMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'IdentityMapperProvider',\n interfaces: [MapperProvider]\n };\n function LinearNormalizingMapperProvider(outputRange, naValue) {\n MapperProviderBase.call(this, naValue);\n this.outputRange_73yg7w$_0 = outputRange;\n }\n LinearNormalizingMapperProvider.prototype.createDiscreteMapper_7f6uoc$ = function (domainValues) {\n return GuideMappers_getInstance().discreteToContinuous_83ntpg$(domainValues, this.outputRange_73yg7w$_0, this.naValue);\n };\n LinearNormalizingMapperProvider.prototype.createContinuousMapper_1g0x2p$ = function (domain, lowerLimit, upperLimit, trans) {\n var dataRange = scale.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(domain, lowerLimit, upperLimit, trans);\n return GuideMappers_getInstance().continuousToContinuous_lww37m$(dataRange, this.outputRange_73yg7w$_0, this.naValue);\n };\n LinearNormalizingMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'LinearNormalizingMapperProvider',\n interfaces: [MapperProviderBase]\n };\n function MapperProviderBase(naValue) {\n this.naValue = naValue;\n }\n MapperProviderBase.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MapperProviderBase',\n interfaces: [MapperProvider]\n };\n function SizeAreaMapperProvider(max, naValue) {\n SizeAreaMapperProvider$Companion_getInstance();\n DirectlyProportionalMapperProvider.call(this, max != null ? max : SizeAreaMapperProvider$Companion_getInstance().DEF_MAX, naValue);\n }\n function SizeAreaMapperProvider$Companion() {\n SizeAreaMapperProvider$Companion_instance = this;\n this.DEF_MAX = aes.AesScaling.sizeFromCircleDiameter_14dthe$(21.0);\n }\n SizeAreaMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SizeAreaMapperProvider$Companion_instance = null;\n function SizeAreaMapperProvider$Companion_getInstance() {\n if (SizeAreaMapperProvider$Companion_instance === null) {\n new SizeAreaMapperProvider$Companion();\n }return SizeAreaMapperProvider$Companion_instance;\n }\n SizeAreaMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SizeAreaMapperProvider',\n interfaces: [DirectlyProportionalMapperProvider]\n };\n function SizeMapperProvider(range, naValue) {\n SizeMapperProvider$Companion_getInstance();\n LinearNormalizingMapperProvider.call(this, range, naValue);\n }\n function SizeMapperProvider$Companion() {\n SizeMapperProvider$Companion_instance = this;\n this.DEF_RANGE_0 = new ClosedRange(aes.AesScaling.sizeFromCircleDiameter_14dthe$(3.0), aes.AesScaling.sizeFromCircleDiameter_14dthe$(21.0));\n this.DEFAULT = new SizeMapperProvider(this.DEF_RANGE_0, DefaultNaValue_getInstance().get_31786j$(Aes.Companion.SIZE));\n }\n SizeMapperProvider$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SizeMapperProvider$Companion_instance = null;\n function SizeMapperProvider$Companion_getInstance() {\n if (SizeMapperProvider$Companion_instance === null) {\n new SizeMapperProvider$Companion();\n }return SizeMapperProvider$Companion_instance;\n }\n SizeMapperProvider.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SizeMapperProvider',\n interfaces: [LinearNormalizingMapperProvider]\n };\n function AxisTheme() {\n }\n AxisTheme.prototype.tickLabelDistance = function () {\n var result = this.tickMarkPadding();\n if (this.showTickMarks()) {\n result += this.tickMarkLength();\n }return result;\n };\n AxisTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'AxisTheme',\n interfaces: []\n };\n function DefaultAxisTheme() {\n }\n DefaultAxisTheme.prototype.showLine = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTickMarks = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTickLabels = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTitle = function () {\n return true;\n };\n DefaultAxisTheme.prototype.showTooltip = function () {\n return true;\n };\n DefaultAxisTheme.prototype.lineWidth = function () {\n return Defaults$Plot$Axis_getInstance().LINE_WIDTH;\n };\n DefaultAxisTheme.prototype.tickMarkWidth = function () {\n return Defaults$Plot$Axis_getInstance().TICK_LINE_WIDTH;\n };\n DefaultAxisTheme.prototype.tickMarkLength = function () {\n return 6.0;\n };\n DefaultAxisTheme.prototype.tickMarkPadding = function () {\n return 3.0;\n };\n DefaultAxisTheme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultAxisTheme',\n interfaces: [AxisTheme]\n };\n function DefaultTheme() {\n DefaultTheme$Companion_getInstance();\n }\n DefaultTheme.prototype.axisX = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_0;\n };\n DefaultTheme.prototype.axisY = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_0;\n };\n DefaultTheme.prototype.legend = function () {\n return DefaultTheme$Companion_getInstance().LEGEND_THEME_0;\n };\n DefaultTheme.prototype.facets = function () {\n return DefaultTheme$Companion_getInstance().FACETS_THEME_0;\n };\n DefaultTheme.prototype.plot = function () {\n return DefaultTheme$Companion_getInstance().PLOT_THEME_0;\n };\n function DefaultTheme$multiTile$ObjectLiteral() {\n DefaultTheme.call(this);\n }\n DefaultTheme$multiTile$ObjectLiteral.prototype.axisX = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.prototype.axisY = function () {\n return DefaultTheme$Companion_getInstance().AXIS_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.prototype.plot = function () {\n return DefaultTheme$Companion_getInstance().PLOT_THEME_MULTI_TILE_0;\n };\n DefaultTheme$multiTile$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DefaultTheme]\n };\n DefaultTheme.prototype.multiTile = function () {\n return new DefaultTheme$multiTile$ObjectLiteral();\n };\n function DefaultTheme$Companion() {\n DefaultTheme$Companion_instance = this;\n this.AXIS_THEME_0 = new DefaultAxisTheme();\n this.AXIS_THEME_MULTI_TILE_0 = new DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral();\n this.LEGEND_THEME_0 = new DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral();\n this.FACETS_THEME_0 = new DefaultTheme$Companion$FACETS_THEME$ObjectLiteral();\n this.PLOT_THEME_0 = new DefaultTheme$Companion$PLOT_THEME$ObjectLiteral();\n this.PLOT_THEME_MULTI_TILE_0 = new DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral();\n }\n function DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral() {\n DefaultAxisTheme.call(this);\n }\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.prototype.showLine = function () {\n return false;\n };\n DefaultTheme$Companion$AXIS_THEME_MULTI_TILE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [DefaultAxisTheme]\n };\n function DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.keySize = function () {\n return 23.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.margin = function () {\n return 5.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.padding = function () {\n return 5.0;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.position = function () {\n return LegendPosition$Companion_getInstance().RIGHT;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.justification = function () {\n return LegendJustification$Companion_getInstance().CENTER;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.direction = function () {\n return LegendDirection$AUTO_getInstance();\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.prototype.backgroundFill = function () {\n return Color.Companion.WHITE;\n };\n DefaultTheme$Companion$LEGEND_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [LegendTheme]\n };\n function DefaultTheme$Companion$FACETS_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$FACETS_THEME$ObjectLiteral.prototype.labelBackground = function () {\n return values.Colors.lighter_o14uds$(Color.Companion.VERY_LIGHT_GRAY, 0.9);\n };\n DefaultTheme$Companion$FACETS_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [FacetsTheme]\n };\n function DefaultTheme$Companion$PLOT_THEME$ObjectLiteral() {\n }\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.prototype.showInnerFrame = function () {\n return false;\n };\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.prototype.innerFrameColor = function () {\n throw IllegalStateException_init(\"The `innerFrameColor()` method shouldn't be used.\");\n };\n DefaultTheme$Companion$PLOT_THEME$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PlotTheme]\n };\n function DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral() {\n }\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.prototype.showInnerFrame = function () {\n return true;\n };\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.prototype.innerFrameColor = function () {\n return values.Colors.lighter_o14uds$(Color.Companion.VERY_LIGHT_GRAY, 0.9);\n };\n DefaultTheme$Companion$PLOT_THEME_MULTI_TILE$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [PlotTheme]\n };\n DefaultTheme$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var DefaultTheme$Companion_instance = null;\n function DefaultTheme$Companion_getInstance() {\n if (DefaultTheme$Companion_instance === null) {\n new DefaultTheme$Companion();\n }return DefaultTheme$Companion_instance;\n }\n DefaultTheme.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DefaultTheme',\n interfaces: [Theme]\n };\n function FacetsTheme() {\n }\n FacetsTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'FacetsTheme',\n interfaces: []\n };\n function LegendTheme() {\n }\n LegendTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'LegendTheme',\n interfaces: []\n };\n function PlotTheme() {\n }\n PlotTheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'PlotTheme',\n interfaces: []\n };\n function Theme() {\n }\n Theme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'Theme',\n interfaces: []\n };\n function ConstantValue(value, format) {\n if (format === void 0)\n format = null;\n this.value_0 = value;\n this.format_0 = format;\n var tmp$;\n if (this.format_0 != null) {\n tmp$ = StringFormat.Companion.create_w8bwfu$(this.format_0).format_za3rmp$(this.value_0);\n } else {\n tmp$ = this.value_0.toString();\n }\n this.myDataValue_0 = tmp$;\n this.isOutlier_efnf0i$_0 = false;\n this.isAxis_i12u4n$_0 = false;\n }\n Object.defineProperty(ConstantValue.prototype, 'isOutlier', {\n configurable: true,\n get: function () {\n return this.isOutlier_efnf0i$_0;\n }\n });\n Object.defineProperty(ConstantValue.prototype, 'isAxis', {\n configurable: true,\n get: function () {\n return this.isAxis_i12u4n$_0;\n }\n });\n ConstantValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n };\n ConstantValue.prototype.getDataPoint_za3lpa$ = function (index) {\n return new TooltipLineSpec$DataPoint('', this.myDataValue_0, null, false, false);\n };\n ConstantValue.prototype.copy = function () {\n return new ConstantValue(this.value_0, this.format_0);\n };\n ConstantValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'ConstantValue',\n interfaces: [ValueSource]\n };\n function DataFrameValue(name, format) {\n if (format === void 0)\n format = null;\n this.name_0 = name;\n this.format_0 = format;\n this.myDataFrame_v9hm26$_0 = this.myDataFrame_v9hm26$_0;\n this.myVariable_u4q8p$_0 = this.myVariable_u4q8p$_0;\n this.myFormatter_0 = this.format_0 != null ? StringFormat.Companion.forOneArg_86f9bg$(this.format_0, void 0, this.name_0) : null;\n this.isOutlier_h13ss7$_0 = false;\n this.isAxis_5xgnmk$_0 = false;\n }\n Object.defineProperty(DataFrameValue.prototype, 'myDataFrame_0', {\n configurable: true,\n get: function () {\n if (this.myDataFrame_v9hm26$_0 == null)\n return throwUPAE('myDataFrame');\n return this.myDataFrame_v9hm26$_0;\n },\n set: function (myDataFrame) {\n this.myDataFrame_v9hm26$_0 = myDataFrame;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'myVariable_0', {\n configurable: true,\n get: function () {\n if (this.myVariable_u4q8p$_0 == null)\n return throwUPAE('myVariable');\n return this.myVariable_u4q8p$_0;\n },\n set: function (myVariable) {\n this.myVariable_u4q8p$_0 = myVariable;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'isOutlier', {\n configurable: true,\n get: function () {\n return this.isOutlier_h13ss7$_0;\n }\n });\n Object.defineProperty(DataFrameValue.prototype, 'isAxis', {\n configurable: true,\n get: function () {\n return this.isAxis_5xgnmk$_0;\n }\n });\n DataFrameValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n if (!(this.myDataFrame_v9hm26$_0 == null)) {\n var message = 'Data context can be initialized only once';\n throw IllegalArgumentException_init(message.toString());\n }this.myDataFrame_0 = dataContext.dataFrame;\n this.myVariable_0 = data.DataFrameUtil.findVariableOrFail_vede35$(this.myDataFrame_0, this.name_0);\n };\n DataFrameValue.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$, tmp$_0, tmp$_1;\n tmp$ = this.myDataFrame_0.get_8xm3sj$(this.myVariable_0).get_za3lpa$(index);\n if (tmp$ == null) {\n return null;\n }var originalValue = tmp$;\n return new TooltipLineSpec$DataPoint(this.name_0, (tmp$_1 = (tmp$_0 = this.myFormatter_0) != null ? tmp$_0.format_za3rmp$(originalValue) : null) != null ? tmp$_1 : originalValue.toString(), null, false, false);\n };\n DataFrameValue.prototype.copy = function () {\n return new DataFrameValue(this.name_0, this.format_0);\n };\n DataFrameValue.prototype.getVariableName = function () {\n return this.name_0;\n };\n DataFrameValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataFrameValue',\n interfaces: [ValueSource]\n };\n function MappingValue(aes, isOutlier, isAxis, format) {\n if (isOutlier === void 0)\n isOutlier = false;\n if (isAxis === void 0)\n isAxis = false;\n if (format === void 0)\n format = null;\n this.aes = aes;\n this.isOutlier_cyn2n6$_0 = isOutlier;\n this.isAxis_ohfp7r$_0 = isAxis;\n this.format_0 = format;\n this.myDataAccess_biypgq$_0 = this.myDataAccess_biypgq$_0;\n this.myDataLabel_0 = null;\n this.myFormatter_0 = this.format_0 != null ? StringFormat.Companion.forOneArg_86f9bg$(this.format_0, void 0, this.aes.name) : null;\n }\n Object.defineProperty(MappingValue.prototype, 'isOutlier', {\n get: function () {\n return this.isOutlier_cyn2n6$_0;\n }\n });\n Object.defineProperty(MappingValue.prototype, 'isAxis', {\n get: function () {\n return this.isAxis_ohfp7r$_0;\n }\n });\n Object.defineProperty(MappingValue.prototype, 'myDataAccess_0', {\n configurable: true,\n get: function () {\n if (this.myDataAccess_biypgq$_0 == null)\n return throwUPAE('myDataAccess');\n return this.myDataAccess_biypgq$_0;\n },\n set: function (myDataAccess) {\n this.myDataAccess_biypgq$_0 = myDataAccess;\n }\n });\n MappingValue.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n var tmp$;\n if (!(this.myDataAccess_biypgq$_0 == null)) {\n var message = 'Data context can be initialized only once';\n throw IllegalArgumentException_init(message.toString());\n }this.myDataAccess_0 = dataContext.mappedDataAccess;\n if (!this.myDataAccess_0.isMapped_896ixz$(this.aes)) {\n var message_0 = this.aes.toString() + ' have to be mapped';\n throw IllegalArgumentException_init(message_0.toString());\n }var $receiver = listOf_0([Aes.Companion.X, Aes.Companion.Y]);\n var predicate = getCallableRef('isMapped', function ($receiver, p1) {\n return $receiver.isMapped_896ixz$(p1);\n }.bind(null, this.myDataAccess_0));\n var destination = ArrayList_init();\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (predicate(element))\n destination.add_11rb$(element);\n }\n var transform = getCallableRef('getMappedDataLabel', function ($receiver, p1) {\n return $receiver.getMappedDataLabel_896ixz$(p1);\n }.bind(null, this.myDataAccess_0));\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(destination, 10));\n var tmp$_1;\n tmp$_1 = destination.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination_0.add_11rb$(transform(item));\n }\n var axisLabels = destination_0;\n var dataLabel = this.myDataAccess_0.getMappedDataLabel_896ixz$(this.aes);\n if (this.isAxis)\n tmp$ = null;\n else {\n if (dataLabel.length === 0)\n tmp$ = '';\n else if (axisLabels.contains_11rb$(dataLabel))\n tmp$ = '';\n else\n tmp$ = dataLabel;\n }\n this.myDataLabel_0 = tmp$;\n };\n MappingValue.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$, tmp$_0, tmp$_1;\n var originalValue = this.myDataAccess_0.getOriginalValue_pkitv1$(this.aes, index);\n var tmp$_2;\n if (originalValue != null) {\n var tmp$_3;\n tmp$_2 = (tmp$_3 = this.myFormatter_0) != null ? tmp$_3.format_za3rmp$(originalValue) : null;\n } else\n tmp$_2 = null;\n var formattedValue = (tmp$ = tmp$_2) != null ? tmp$ : this.myDataAccess_0.getMappedData_pkitv1$(this.aes, index).value;\n var tmp$_4 = this.isOutlier;\n if (tmp$_4) {\n var $receiver = this.myDataLabel_0;\n tmp$_4 = !($receiver == null || $receiver.length === 0);\n }if (tmp$_4 && !equals((tmp$_0 = this.myFormatter_0) != null ? tmp$_0.formatType : null, StringFormat$FormatType.STRING_FORMAT)) {\n tmp$_1 = toString(this.myDataLabel_0) + ': ' + formattedValue;\n } else {\n tmp$_1 = formattedValue;\n }\n var value = tmp$_1;\n return new TooltipLineSpec$DataPoint(this.isOutlier ? null : this.myDataLabel_0, value, this.aes, this.isAxis, this.isOutlier);\n };\n MappingValue.prototype.copy = function () {\n return new MappingValue(this.aes, this.isOutlier, this.isAxis, this.format_0);\n };\n MappingValue.prototype.toOutlier = function () {\n return new MappingValue(this.aes, true, this.isAxis, this.format_0);\n };\n MappingValue.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MappingValue',\n interfaces: [ValueSource]\n };\n function TooltipLine(label, pattern, fields) {\n TooltipLine$Companion_getInstance();\n this.label_0 = label;\n this.pattern_0 = pattern;\n this.fields = fields;\n this.myLineFormatter_0 = StringFormat.Companion.forNArgs_8vq31k$(this.pattern_0, StringFormat$FormatType.STRING_FORMAT, this.fields.size, 'fields');\n }\n TooltipLine.prototype.initDataContext_rxi9tf$ = function (dataContext) {\n var tmp$;\n tmp$ = this.fields.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n element.initDataContext_rxi9tf$(dataContext);\n }\n };\n function TooltipLine$getDataPoint$lambda(it) {\n var tmp$;\n return (tmp$ = it.label) != null ? tmp$ : '';\n }\n TooltipLine.prototype.getDataPoint_za3lpa$ = function (index) {\n var tmp$;\n var $receiver = this.fields;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_0;\n tmp$_0 = $receiver.iterator();\n while (tmp$_0.hasNext()) {\n var item = tmp$_0.next();\n var tmp$_1 = destination.add_11rb$;\n var tmp$_2;\n tmp$_2 = item.getDataPoint_za3lpa$(index);\n if (tmp$_2 == null) {\n return null;\n }tmp$_1.call(destination, tmp$_2);\n }\n var dataValues = destination;\n if (dataValues.size === 1) {\n var dataValue = single(dataValues);\n tmp$ = new TooltipLineSpec$DataPoint(this.chooseLabel_0(dataValue.label), this.myLineFormatter_0.format_za3rmp$(dataValue.value), dataValue.aes, dataValue.isAxis, dataValue.isOutlier);\n } else {\n var tmp$_3 = this.chooseLabel_0(joinToString(dataValues, ', ', void 0, void 0, void 0, void 0, TooltipLine$getDataPoint$lambda));\n var tmp$_4 = this.myLineFormatter_0;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault(dataValues, 10));\n var tmp$_5;\n tmp$_5 = dataValues.iterator();\n while (tmp$_5.hasNext()) {\n var item_0 = tmp$_5.next();\n destination_0.add_11rb$(item_0.value);\n }\n tmp$ = new TooltipLineSpec$DataPoint(tmp$_3, tmp$_4.format_pqjuzw$(destination_0), null, false, false);\n }\n return tmp$;\n };\n TooltipLine.prototype.chooseLabel_0 = function (dataLabel) {\n var tmp$;\n if (equals(this.label_0, TooltipLine$Companion_getInstance().DEFAULT_LABEL_SPECIFIER_0))\n tmp$ = dataLabel;\n else\n tmp$ = this.label_0;\n return tmp$;\n };\n function TooltipLine$Companion() {\n TooltipLine$Companion_instance = this;\n this.DEFAULT_LABEL_SPECIFIER_0 = '@';\n }\n TooltipLine$Companion.prototype.defaultLineForValueSource_u47np3$ = function (valueSource) {\n return new TooltipLine(this.DEFAULT_LABEL_SPECIFIER_0, StringFormat.Companion.valueInLinePattern(), listOf(valueSource));\n };\n TooltipLine$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipLine$Companion_instance = null;\n function TooltipLine$Companion_getInstance() {\n if (TooltipLine$Companion_instance === null) {\n new TooltipLine$Companion();\n }return TooltipLine$Companion_instance;\n }\n TooltipLine.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipLine',\n interfaces: [TooltipLineSpec]\n };\n function TooltipLine_init(other, $this) {\n $this = $this || Object.create(TooltipLine.prototype);\n var tmp$ = other.label_0;\n var tmp$_0 = other.pattern_0;\n var $receiver = other.fields;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var item = tmp$_1.next();\n destination.add_11rb$(item.copy());\n }\n TooltipLine.call($this, tmp$, tmp$_0, destination);\n return $this;\n }\n function TooltipSpecification(valueSources, tooltipLinePatterns, tooltipProperties) {\n TooltipSpecification$Companion_getInstance();\n this.valueSources = valueSources;\n this.tooltipLinePatterns = tooltipLinePatterns;\n this.tooltipProperties = tooltipProperties;\n }\n function TooltipSpecification$TooltipProperties(anchor, minWidth, color) {\n TooltipSpecification$TooltipProperties$Companion_getInstance();\n this.anchor = anchor;\n this.minWidth = minWidth;\n this.color = color;\n }\n function TooltipSpecification$TooltipProperties$Companion() {\n TooltipSpecification$TooltipProperties$Companion_instance = this;\n this.NONE = new TooltipSpecification$TooltipProperties(null, null, null);\n }\n TooltipSpecification$TooltipProperties$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpecification$TooltipProperties$Companion_instance = null;\n function TooltipSpecification$TooltipProperties$Companion_getInstance() {\n if (TooltipSpecification$TooltipProperties$Companion_instance === null) {\n new TooltipSpecification$TooltipProperties$Companion();\n }return TooltipSpecification$TooltipProperties$Companion_instance;\n }\n TooltipSpecification$TooltipProperties.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipProperties',\n interfaces: []\n };\n function TooltipSpecification$Companion() {\n TooltipSpecification$Companion_instance = this;\n }\n TooltipSpecification$Companion.prototype.withoutTooltip = function () {\n return new TooltipSpecification(emptyList(), emptyList(), TooltipSpecification$TooltipProperties$Companion_getInstance().NONE);\n };\n TooltipSpecification$Companion.prototype.defaultTooltip = function () {\n return new TooltipSpecification(emptyList(), null, TooltipSpecification$TooltipProperties$Companion_getInstance().NONE);\n };\n TooltipSpecification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TooltipSpecification$Companion_instance = null;\n function TooltipSpecification$Companion_getInstance() {\n if (TooltipSpecification$Companion_instance === null) {\n new TooltipSpecification$Companion();\n }return TooltipSpecification$Companion_instance;\n }\n TooltipSpecification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TooltipSpecification',\n interfaces: []\n };\n function ValueSource() {\n }\n ValueSource.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ValueSource',\n interfaces: []\n };\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n Object.defineProperty(package$plot, 'FeatureSwitch', {\n get: FeatureSwitch_getInstance\n });\n var package$builder = package$plot.builder || (package$plot.builder = {});\n Object.defineProperty(package$builder, 'AxisUtil', {\n get: AxisUtil_getInstance\n });\n package$builder.BogusCoordinateSystem = BogusCoordinateSystem;\n package$builder.BogusScale = BogusScale;\n package$builder.GeomLayer = GeomLayer;\n Object.defineProperty(package$builder, 'GeomLayerListUtil', {\n get: GeomLayerListUtil_getInstance\n });\n LayerRendererUtil.prototype.LayerRendererData = LayerRendererUtil$LayerRendererData;\n Object.defineProperty(package$builder, 'LayerRendererUtil', {\n get: LayerRendererUtil_getInstance\n });\n Object.defineProperty(Plot, 'Companion', {\n get: Plot$Companion_getInstance\n });\n package$builder.Plot = Plot;\n package$builder.PlotBuilder = PlotBuilder;\n Object.defineProperty(PlotContainerPortable, 'Companion', {\n get: PlotContainerPortable$Companion_getInstance\n });\n package$builder.PlotContainerPortable = PlotContainerPortable;\n package$builder.PlotTile = PlotTile;\n package$builder.PlotTooltipHelper = PlotTooltipHelper;\n Object.defineProperty(package$builder, 'PlotUtil', {\n get: PlotUtil_getInstance\n });\n package$builder.PosProviderContext = PosProviderContext;\n package$builder.SvgLayerRenderer = SvgLayerRenderer;\n package$builder.VarBinding = VarBinding;\n Object.defineProperty(ColorBarAssembler, 'Companion', {\n get: ColorBarAssembler$Companion_getInstance\n });\n var package$assemble = package$builder.assemble || (package$builder.assemble = {});\n package$assemble.ColorBarAssembler = ColorBarAssembler;\n package$assemble.ColorBarOptions = ColorBarOptions;\n package$assemble.GeomContextBuilder_init = GeomContextBuilder_init;\n package$assemble.GeomContextBuilder = GeomContextBuilder;\n Object.defineProperty(GeomLayerBuilder, 'Companion', {\n get: GeomLayerBuilder$Companion_getInstance\n });\n package$assemble.GeomLayerBuilder = GeomLayerBuilder;\n Object.defineProperty(GuideOptions, 'Companion', {\n get: GuideOptions$Companion_getInstance\n });\n package$assemble.GuideOptions = GuideOptions;\n ImmutableGeomContext.Builder = ImmutableGeomContext$Builder;\n package$assemble.ImmutableGeomContext = ImmutableGeomContext;\n Object.defineProperty(LegendAssembler, 'Companion', {\n get: LegendAssembler$Companion_getInstance\n });\n package$assemble.LegendAssembler = LegendAssembler;\n Object.defineProperty(package$assemble, 'LegendAssemblerUtil', {\n get: LegendAssemblerUtil_getInstance\n });\n Object.defineProperty(LegendOptions, 'Companion', {\n get: LegendOptions$Companion_getInstance\n });\n package$assemble.LegendOptions = LegendOptions;\n Object.defineProperty(PlotAssembler, 'Companion', {\n get: PlotAssembler$Companion_getInstance\n });\n package$assemble.PlotAssembler = PlotAssembler;\n Object.defineProperty(package$assemble, 'PlotAssemblerUtil', {\n get: PlotAssemblerUtil_getInstance\n });\n Object.defineProperty(PlotFacets, 'Companion', {\n get: PlotFacets$Companion_getInstance\n });\n PlotFacets.FacetTileInfo = PlotFacets$FacetTileInfo;\n package$assemble.PlotFacets = PlotFacets;\n Object.defineProperty(package$assemble, 'PlotGuidesAssemblerUtil', {\n get: PlotGuidesAssemblerUtil_getInstance\n });\n Object.defineProperty(PosProvider, 'Companion', {\n get: PosProvider$Companion_getInstance\n });\n package$assemble.PosProvider = PosProvider;\n package$assemble.StitchedPlotLayers = StitchedPlotLayers;\n Object.defineProperty(TypedScaleMap, 'Companion', {\n get: TypedScaleMap$Companion_getInstance\n });\n package$assemble.TypedScaleMap = TypedScaleMap;\n package$assemble.TypedScaleProviderMap = TypedScaleProviderMap;\n var package$facet = package$assemble.facet || (package$assemble.facet = {});\n package$facet.FacetGrid = FacetGrid;\n Object.defineProperty(FacetWrap$Direction, 'H', {\n get: FacetWrap$Direction$H_getInstance\n });\n Object.defineProperty(FacetWrap$Direction, 'V', {\n get: FacetWrap$Direction$V_getInstance\n });\n FacetWrap.Direction = FacetWrap$Direction;\n Object.defineProperty(FacetWrap, 'Companion', {\n get: FacetWrap$Companion_getInstance\n });\n package$facet.FacetWrap = FacetWrap;\n var package$geom = package$assemble.geom || (package$assemble.geom = {});\n Object.defineProperty(package$geom, 'DefaultSampling', {\n get: DefaultSampling_getInstance\n });\n Object.defineProperty(GeomProvider, 'Companion', {\n get: GeomProvider$Companion_getInstance\n });\n package$geom.GeomProvider = GeomProvider;\n package$geom.PointDataAccess = PointDataAccess;\n var package$coord = package$builder.coord || (package$builder.coord = {});\n package$coord.CartesianCoordProvider = CartesianCoordProvider;\n package$coord.CoordProvider = CoordProvider;\n Object.defineProperty(CoordProviderBase, 'Companion', {\n get: CoordProviderBase$Companion_getInstance\n });\n package$coord.CoordProviderBase = CoordProviderBase;\n Object.defineProperty(package$coord, 'CoordProviders', {\n get: CoordProviders_getInstance\n });\n package$coord.FixedRatioCoordProvider = FixedRatioCoordProvider;\n Object.defineProperty(ProjectionCoordProvider, 'Companion', {\n get: ProjectionCoordProvider$Companion_getInstance\n });\n package$coord.ProjectionCoordProvider = ProjectionCoordProvider;\n var package$map = package$coord.map || (package$coord.map = {});\n package$map.MercatorProjectionX = MercatorProjectionX;\n package$map.MercatorProjectionY = MercatorProjectionY;\n DataProcessing.prototype.DataAndGroupingContext = DataProcessing$DataAndGroupingContext;\n var package$data = package$builder.data || (package$builder.data = {});\n Object.defineProperty(package$data, 'DataProcessing', {\n get: DataProcessing_getInstance\n });\n GroupMerger.Group = GroupMerger$Group;\n package$data.GroupMerger = GroupMerger;\n Object.defineProperty(package$data, 'GroupUtil', {\n get: GroupUtil_getInstance\n });\n Object.defineProperty(GroupingContext, 'Companion', {\n get: GroupingContext$Companion_getInstance\n });\n package$data.GroupingContext = GroupingContext;\n Object.defineProperty(OrderOptionUtil$OrderOption, 'Companion', {\n get: OrderOptionUtil$OrderOption$Companion_getInstance\n });\n OrderOptionUtil.prototype.OrderOption = OrderOptionUtil$OrderOption;\n Object.defineProperty(package$data, 'OrderOptionUtil', {\n get: OrderOptionUtil_getInstance\n });\n var package$event = package$builder.event || (package$builder.event = {});\n package$event.MouseEventPeer = MouseEventPeer;\n var package$guide = package$builder.guide || (package$builder.guide = {});\n package$guide.AxisComponent = AxisComponent;\n package$guide.ColorBarComponent = ColorBarComponent;\n ColorBarComponentLayout.BreakInfo = ColorBarComponentLayout$BreakInfo;\n Object.defineProperty(ColorBarComponentLayout, 'Companion', {\n get: ColorBarComponentLayout$Companion_getInstance\n });\n package$guide.ColorBarComponentLayout = ColorBarComponentLayout;\n Object.defineProperty(ColorBarComponentSpec, 'Companion', {\n get: ColorBarComponentSpec$Companion_getInstance\n });\n package$guide.ColorBarComponentSpec = ColorBarComponentSpec;\n Object.defineProperty(LegendArrangement, 'HORIZONTAL', {\n get: LegendArrangement$HORIZONTAL_getInstance\n });\n Object.defineProperty(LegendArrangement, 'VERTICAL', {\n get: LegendArrangement$VERTICAL_getInstance\n });\n package$guide.LegendArrangement = LegendArrangement;\n Object.defineProperty(LegendBox, 'Companion', {\n get: LegendBox$Companion_getInstance\n });\n package$guide.LegendBox = LegendBox;\n Object.defineProperty(LegendBoxLayout, 'Companion', {\n get: LegendBoxLayout$Companion_getInstance\n });\n package$guide.LegendBoxLayout = LegendBoxLayout;\n package$guide.LegendBoxSpec = LegendBoxSpec;\n Object.defineProperty(LegendBreak, 'Companion', {\n get: LegendBreak$Companion_getInstance\n });\n package$guide.LegendBreak = LegendBreak;\n package$guide.LegendComponent = LegendComponent;\n Object.defineProperty(LegendComponentLayout, 'Companion', {\n get: LegendComponentLayout$Companion_getInstance\n });\n package$guide.LegendComponentLayout = LegendComponentLayout;\n package$guide.LegendComponentSpec = LegendComponentSpec;\n Object.defineProperty(LegendDirection, 'HORIZONTAL', {\n get: LegendDirection$HORIZONTAL_getInstance\n });\n Object.defineProperty(LegendDirection, 'VERTICAL', {\n get: LegendDirection$VERTICAL_getInstance\n });\n Object.defineProperty(LegendDirection, 'AUTO', {\n get: LegendDirection$AUTO_getInstance\n });\n package$guide.LegendDirection = LegendDirection;\n Object.defineProperty(LegendJustification, 'Companion', {\n get: LegendJustification$Companion_getInstance\n });\n package$guide.LegendJustification = LegendJustification;\n Object.defineProperty(LegendPosition, 'Companion', {\n get: LegendPosition$Companion_getInstance\n });\n package$guide.LegendPosition = LegendPosition;\n Object.defineProperty(Orientation, 'LEFT', {\n get: Orientation$LEFT_getInstance\n });\n Object.defineProperty(Orientation, 'RIGHT', {\n get: Orientation$RIGHT_getInstance\n });\n Object.defineProperty(Orientation, 'TOP', {\n get: Orientation$TOP_getInstance\n });\n Object.defineProperty(Orientation, 'BOTTOM', {\n get: Orientation$BOTTOM_getInstance\n });\n package$guide.Orientation = Orientation;\n Object.defineProperty(ContextualMappingProvider, 'Companion', {\n get: ContextualMappingProvider$Companion_getInstance\n });\n var package$interact = package$builder.interact || (package$builder.interact = {});\n package$interact.ContextualMappingProvider = ContextualMappingProvider;\n Object.defineProperty(GeomInteraction, 'Companion', {\n get: GeomInteraction$Companion_getInstance\n });\n package$interact.GeomInteraction = GeomInteraction;\n Object.defineProperty(GeomInteractionBuilder, 'Companion', {\n get: GeomInteractionBuilder$Companion_getInstance\n });\n package$interact.GeomInteractionBuilder = GeomInteractionBuilder;\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'NEW_CLOSER', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_CLOSER_getInstance\n });\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'NEW_FARTHER', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$NEW_FARTHER_getInstance\n });\n Object.defineProperty(MathUtil$ClosestPointChecker$COMPARISON_RESULT, 'EQUAL', {\n get: MathUtil$ClosestPointChecker$COMPARISON_RESULT$EQUAL_getInstance\n });\n MathUtil$ClosestPointChecker.COMPARISON_RESULT = MathUtil$ClosestPointChecker$COMPARISON_RESULT;\n MathUtil.prototype.ClosestPointChecker_init_lu1900$ = MathUtil$MathUtil$ClosestPointChecker_init;\n MathUtil.prototype.ClosestPointChecker = MathUtil$ClosestPointChecker;\n Object.defineProperty(MathUtil$DoubleRange, 'Companion', {\n get: MathUtil$DoubleRange$Companion_getInstance\n });\n MathUtil.prototype.DoubleRange = MathUtil$DoubleRange;\n Object.defineProperty(package$interact, 'MathUtil', {\n get: MathUtil_getInstance\n });\n Object.defineProperty(TooltipSpec$Line, 'Companion', {\n get: TooltipSpec$Line$Companion_getInstance\n });\n TooltipSpec.Line = TooltipSpec$Line;\n package$interact.TooltipSpec = TooltipSpec;\n package$interact.TooltipSpecFactory = TooltipSpecFactory;\n var package$loc = package$interact.loc || (package$interact.loc = {});\n package$loc.LayerTargetCollectorWithLocator = LayerTargetCollectorWithLocator;\n LayerTargetLocator.Target = LayerTargetLocator$Target;\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'APPEND', {\n get: LayerTargetLocator$Collector$CollectingStrategy$APPEND_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'REPLACE', {\n get: LayerTargetLocator$Collector$CollectingStrategy$REPLACE_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'APPEND_IF_EQUAL', {\n get: LayerTargetLocator$Collector$CollectingStrategy$APPEND_IF_EQUAL_getInstance\n });\n Object.defineProperty(LayerTargetLocator$Collector$CollectingStrategy, 'IGNORE', {\n get: LayerTargetLocator$Collector$CollectingStrategy$IGNORE_getInstance\n });\n LayerTargetLocator$Collector.CollectingStrategy = LayerTargetLocator$Collector$CollectingStrategy;\n LayerTargetLocator.Collector = LayerTargetLocator$Collector;\n package$loc.LayerTargetLocator = LayerTargetLocator;\n Object.defineProperty(LocatedTargetsPicker, 'Companion', {\n get: LocatedTargetsPicker$Companion_getInstance\n });\n package$loc.LocatedTargetsPicker = LocatedTargetsPicker;\n Object.defineProperty(TargetDetector, 'Companion', {\n get: TargetDetector$Companion_getInstance\n });\n package$loc.TargetDetector = TargetDetector;\n package$loc.TargetProjection = TargetProjection;\n Object.defineProperty(PointTargetProjection, 'Companion', {\n get: PointTargetProjection$Companion_getInstance\n });\n package$loc.PointTargetProjection = PointTargetProjection;\n Object.defineProperty(RectTargetProjection, 'Companion', {\n get: RectTargetProjection$Companion_getInstance\n });\n package$loc.RectTargetProjection = RectTargetProjection;\n Object.defineProperty(PolygonTargetProjection, 'Companion', {\n get: PolygonTargetProjection$Companion_getInstance\n });\n PolygonTargetProjection.RingXY = PolygonTargetProjection$RingXY;\n package$loc.PolygonTargetProjection = PolygonTargetProjection;\n Object.defineProperty(PathTargetProjection$PathPoint, 'Companion', {\n get: PathTargetProjection$PathPoint$Companion_getInstance\n });\n PathTargetProjection.PathPoint = PathTargetProjection$PathPoint;\n Object.defineProperty(PathTargetProjection, 'Companion', {\n get: PathTargetProjection$Companion_getInstance\n });\n package$loc.PathTargetProjection = PathTargetProjection;\n Object.defineProperty(TargetPrototype, 'Companion', {\n get: TargetPrototype$Companion_getInstance\n });\n package$loc.TargetPrototype = TargetPrototype;\n package$loc.TransformedTargetLocator = TransformedTargetLocator;\n var package$layout = package$builder.layout || (package$builder.layout = {});\n package$layout.AxisLayout = AxisLayout;\n AxisLayoutInfo.Builder = AxisLayoutInfo$Builder;\n package$layout.AxisLayoutInfo = AxisLayoutInfo;\n Object.defineProperty(EmptyAxisLayout, 'Companion', {\n get: EmptyAxisLayout$Companion_getInstance\n });\n package$layout.EmptyAxisLayout = EmptyAxisLayout;\n Object.defineProperty(FacetGridPlotLayout, 'Companion', {\n get: FacetGridPlotLayout$Companion_getInstance\n });\n package$layout.FacetGridPlotLayout = FacetGridPlotLayout;\n Object.defineProperty(package$layout, 'GeometryUtil', {\n get: GeometryUtil_getInstance\n });\n Object.defineProperty(LegendBoxInfo, 'Companion', {\n get: LegendBoxInfo$Companion_getInstance\n });\n package$layout.LegendBoxInfo = LegendBoxInfo;\n LegendBoxesLayout.Result = LegendBoxesLayout$Result;\n LegendBoxesLayout.BoxWithLocation = LegendBoxesLayout$BoxWithLocation;\n package$layout.LegendBoxesLayout = LegendBoxesLayout;\n Object.defineProperty(package$layout, 'LegendBoxesLayoutUtil', {\n get: LegendBoxesLayoutUtil_getInstance\n });\n package$layout.LiveMapTileLayout = LiveMapTileLayout;\n Object.defineProperty(PlotAxisLayout, 'Companion', {\n get: PlotAxisLayout$Companion_getInstance\n });\n package$layout.PlotAxisLayout = PlotAxisLayout;\n package$layout.PlotLayout = PlotLayout;\n package$layout.PlotLayoutBase = PlotLayoutBase;\n package$layout.PlotLayoutInfo = PlotLayoutInfo;\n Object.defineProperty(package$layout, 'PlotLayoutUtil', {\n get: PlotLayoutUtil_getInstance\n });\n package$layout.SingleTilePlotLayout = SingleTilePlotLayout;\n package$layout.TileLayout = TileLayout;\n package$layout.TileLayoutInfo_init_aeujc5$ = TileLayoutInfo_init;\n package$layout.TileLayoutInfo = TileLayoutInfo;\n Object.defineProperty(package$layout, 'XYPlotLayoutUtil', {\n get: XYPlotLayoutUtil_getInstance\n });\n Object.defineProperty(XYPlotTileLayout, 'Companion', {\n get: XYPlotTileLayout$Companion_getInstance\n });\n package$layout.XYPlotTileLayout = XYPlotTileLayout;\n var package$axis = package$layout.axis || (package$layout.axis = {});\n package$axis.AdaptableAxisBreaksProvider = AdaptableAxisBreaksProvider;\n package$axis.AxisBreaksProvider = AxisBreaksProvider;\n Object.defineProperty(package$axis, 'AxisBreaksUtil', {\n get: AxisBreaksUtil_getInstance\n });\n Object.defineProperty(AxisLayouter, 'Companion', {\n get: AxisLayouter$Companion_getInstance\n });\n package$axis.AxisLayouter = AxisLayouter;\n package$axis.FixedAxisBreaksProvider = FixedAxisBreaksProvider;\n package$axis.HorizontalAxisLayouter = HorizontalAxisLayouter;\n package$axis.VerticalAxisLayouter = VerticalAxisLayouter;\n Object.defineProperty(AbstractFixedBreaksLabelsLayout, 'Companion', {\n get: AbstractFixedBreaksLabelsLayout$Companion_getInstance\n });\n var package$label = package$axis.label || (package$axis.label = {});\n package$label.AbstractFixedBreaksLabelsLayout = AbstractFixedBreaksLabelsLayout;\n Object.defineProperty(AxisLabelsLayout, 'Companion', {\n get: AxisLabelsLayout$Companion_getInstance\n });\n package$label.AxisLabelsLayout = AxisLabelsLayout;\n AxisLabelsLayoutInfo.Builder = AxisLabelsLayoutInfo$Builder;\n package$label.AxisLabelsLayoutInfo = AxisLabelsLayoutInfo;\n Object.defineProperty(package$label, 'BreakLabelsLayoutUtil', {\n get: BreakLabelsLayoutUtil_getInstance\n });\n package$label.HorizontalFixedBreaksLabelsLayout = HorizontalFixedBreaksLabelsLayout;\n package$label.HorizontalFlexBreaksLabelsLayout = HorizontalFlexBreaksLabelsLayout;\n Object.defineProperty(HorizontalMultilineLabelsLayout, 'Companion', {\n get: HorizontalMultilineLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalMultilineLabelsLayout = HorizontalMultilineLabelsLayout;\n Object.defineProperty(HorizontalSimpleLabelsLayout, 'Companion', {\n get: HorizontalSimpleLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalSimpleLabelsLayout = HorizontalSimpleLabelsLayout;\n Object.defineProperty(HorizontalTiltedLabelsLayout, 'Companion', {\n get: HorizontalTiltedLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalTiltedLabelsLayout = HorizontalTiltedLabelsLayout;\n Object.defineProperty(HorizontalVerticalLabelsLayout, 'Companion', {\n get: HorizontalVerticalLabelsLayout$Companion_getInstance\n });\n package$label.HorizontalVerticalLabelsLayout = HorizontalVerticalLabelsLayout;\n package$label.VerticalFixedBreaksLabelsLayout = VerticalFixedBreaksLabelsLayout;\n package$label.VerticalFlexBreaksLabelsLayout = VerticalFlexBreaksLabelsLayout;\n Object.defineProperty(Defaults$Common, 'Title', {\n get: Defaults$Common$Title_getInstance\n });\n Object.defineProperty(Defaults$Common, 'Legend', {\n get: Defaults$Common$Legend_getInstance\n });\n Object.defineProperty(Defaults$Common, 'Tooltip', {\n get: Defaults$Common$Tooltip_getInstance\n });\n Defaults.prototype.Common = Defaults$Common;\n Object.defineProperty(Defaults$Table, 'Head', {\n get: Defaults$Table$Head_getInstance\n });\n Object.defineProperty(Defaults$Table, 'Data', {\n get: Defaults$Table$Data_getInstance\n });\n Defaults.prototype.Table = Defaults$Table;\n Object.defineProperty(Defaults$Plot, 'Axis', {\n get: Defaults$Plot$Axis_getInstance\n });\n Defaults.prototype.Plot = Defaults$Plot;\n var package$presentation = package$builder.presentation || (package$builder.presentation = {});\n Object.defineProperty(package$presentation, 'Defaults', {\n get: Defaults_getInstance\n });\n Object.defineProperty(package$presentation, 'LabelCss', {\n get: LabelCss_getInstance\n });\n package$presentation.Serializable = Serializable;\n Object.defineProperty(LabelMetrics, 'Companion', {\n get: LabelMetrics$Companion_getInstance\n });\n package$presentation.LabelMetrics_init = LabelMetrics_init;\n package$presentation.LabelMetrics_init_7trt9e$ = LabelMetrics_init_0;\n package$presentation.LabelMetrics = LabelMetrics;\n package$presentation.LabelSpec = LabelSpec;\n Object.defineProperty(PlotLabelSpec, 'PLOT_TITLE', {\n get: PlotLabelSpec$PLOT_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TICK', {\n get: PlotLabelSpec$AXIS_TICK_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TICK_SMALL', {\n get: PlotLabelSpec$AXIS_TICK_SMALL_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'AXIS_TITLE', {\n get: PlotLabelSpec$AXIS_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'LEGEND_TITLE', {\n get: PlotLabelSpec$LEGEND_TITLE_getInstance\n });\n Object.defineProperty(PlotLabelSpec, 'LEGEND_ITEM', {\n get: PlotLabelSpec$LEGEND_ITEM_getInstance\n });\n package$presentation.PlotLabelSpec = PlotLabelSpec;\n Object.defineProperty(package$presentation, 'Style', {\n get: Style_getInstance\n });\n var package$sampling = package$builder.sampling || (package$builder.sampling = {});\n package$sampling.GroupAwareSampling = GroupAwareSampling;\n package$sampling.PointSampling = PointSampling;\n package$sampling.Sampling = Sampling;\n Object.defineProperty(package$sampling, 'Samplings', {\n get: Samplings_getInstance\n });\n Object.defineProperty(GroupRandomSampling, 'Companion', {\n get: GroupRandomSampling$Companion_getInstance\n });\n var package$method = package$sampling.method || (package$sampling.method = {});\n package$method.GroupRandomSampling = GroupRandomSampling;\n package$method.GroupSamplingBase = GroupSamplingBase;\n Object.defineProperty(GroupSystematicSampling, 'Companion', {\n get: GroupSystematicSampling$Companion_getInstance\n });\n package$method.GroupSystematicSampling = GroupSystematicSampling;\n Object.defineProperty(PickSampling, 'Companion', {\n get: PickSampling$Companion_getInstance\n });\n package$method.PickSampling = PickSampling;\n Object.defineProperty(RandomSampling, 'Companion', {\n get: RandomSampling$Companion_getInstance\n });\n package$method.RandomSampling = RandomSampling;\n Object.defineProperty(RandomStratifiedSampling, 'Companion', {\n get: RandomStratifiedSampling$Companion_getInstance\n });\n package$method.RandomStratifiedSampling = RandomStratifiedSampling;\n package$method.SamplingBase = SamplingBase;\n Object.defineProperty(package$method, 'SamplingUtil', {\n get: SamplingUtil_getInstance\n });\n Object.defineProperty(SystematicSampling, 'Companion', {\n get: SystematicSampling$Companion_getInstance\n });\n package$method.SystematicSampling = SystematicSampling;\n Object.defineProperty(VertexSampling$VertexVwSampling, 'Companion', {\n get: VertexSampling$VertexVwSampling$Companion_getInstance\n });\n VertexSampling.VertexVwSampling = VertexSampling$VertexVwSampling;\n Object.defineProperty(VertexSampling$VertexDpSampling, 'Companion', {\n get: VertexSampling$VertexDpSampling$Companion_getInstance\n });\n VertexSampling.VertexDpSampling = VertexSampling$VertexDpSampling;\n VertexSampling.DoubleVectorComponentsList = VertexSampling$DoubleVectorComponentsList;\n Object.defineProperty(VertexSampling, 'Companion', {\n get: VertexSampling$Companion_getInstance\n });\n package$method.VertexSampling = VertexSampling;\n var package$scale = package$builder.scale || (package$builder.scale = {});\n package$scale.ContinuousOnlyMapperProvider = ContinuousOnlyMapperProvider;\n Object.defineProperty(package$scale, 'DefaultMapperProvider', {\n get: DefaultMapperProvider_getInstance\n });\n Object.defineProperty(package$scale, 'DefaultMapperProviderUtil', {\n get: DefaultMapperProviderUtil_getInstance\n });\n Object.defineProperty(package$scale, 'DefaultNaValue', {\n get: DefaultNaValue_getInstance\n });\n package$scale.DiscreteOnlyMapperProvider = DiscreteOnlyMapperProvider;\n package$scale.GuideMapper = GuideMapper;\n package$scale.MapperProvider = MapperProvider;\n package$scale.ScaleProvider = ScaleProvider;\n package$scale.ScaleProviderBuilder = ScaleProviderBuilder;\n Object.defineProperty(package$scale, 'ScaleProviderHelper', {\n get: ScaleProviderHelper_getInstance\n });\n package$scale.WithGuideBreaks = WithGuideBreaks;\n var package$mapper = package$scale.mapper || (package$scale.mapper = {});\n Object.defineProperty(package$mapper, 'ColorMapper', {\n get: ColorMapper_getInstance\n });\n package$mapper.GuideMapperAdapter = GuideMapperAdapter;\n package$mapper.GuideMapperWithGuideBreaks = GuideMapperWithGuideBreaks;\n Object.defineProperty(package$mapper, 'GuideMappers', {\n get: GuideMappers_getInstance\n });\n Object.defineProperty(package$mapper, 'LineTypeMapper', {\n get: LineTypeMapper_getInstance\n });\n Object.defineProperty(package$mapper, 'ShapeMapper', {\n get: ShapeMapper_getInstance\n });\n Object.defineProperty(AlphaMapperProvider, 'Companion', {\n get: AlphaMapperProvider$Companion_getInstance\n });\n var package$provider = package$scale.provider || (package$scale.provider = {});\n package$provider.AlphaMapperProvider = AlphaMapperProvider;\n Object.defineProperty(ColorBrewerMapperProvider, 'Companion', {\n get: ColorBrewerMapperProvider$Companion_getInstance\n });\n package$provider.ColorBrewerMapperProvider = ColorBrewerMapperProvider;\n Object.defineProperty(ColorGradient2MapperProvider, 'Companion', {\n get: ColorGradient2MapperProvider$Companion_getInstance\n });\n package$provider.ColorGradient2MapperProvider = ColorGradient2MapperProvider;\n Object.defineProperty(ColorGradientMapperProvider, 'Companion', {\n get: ColorGradientMapperProvider$Companion_getInstance\n });\n package$provider.ColorGradientMapperProvider = ColorGradientMapperProvider;\n Object.defineProperty(ColorHueMapperProvider, 'Companion', {\n get: ColorHueMapperProvider$Companion_getInstance\n });\n package$provider.ColorHueMapperProvider = ColorHueMapperProvider;\n package$provider.DirectlyProportionalMapperProvider = DirectlyProportionalMapperProvider;\n Object.defineProperty(GreyscaleLightnessMapperProvider, 'Companion', {\n get: GreyscaleLightnessMapperProvider$Companion_getInstance\n });\n package$provider.GreyscaleLightnessMapperProvider = GreyscaleLightnessMapperProvider;\n Object.defineProperty(HSVColorMapperProvider, 'Companion', {\n get: HSVColorMapperProvider$Companion_getInstance\n });\n package$provider.HSVColorMapperProvider = HSVColorMapperProvider;\n package$provider.IdentityDiscreteMapperProvider = IdentityDiscreteMapperProvider;\n package$provider.IdentityMapperProvider = IdentityMapperProvider;\n package$provider.LinearNormalizingMapperProvider = LinearNormalizingMapperProvider;\n package$provider.MapperProviderBase = MapperProviderBase;\n Object.defineProperty(SizeAreaMapperProvider, 'Companion', {\n get: SizeAreaMapperProvider$Companion_getInstance\n });\n package$provider.SizeAreaMapperProvider = SizeAreaMapperProvider;\n Object.defineProperty(SizeMapperProvider, 'Companion', {\n get: SizeMapperProvider$Companion_getInstance\n });\n package$provider.SizeMapperProvider = SizeMapperProvider;\n var package$theme = package$builder.theme || (package$builder.theme = {});\n package$theme.AxisTheme = AxisTheme;\n package$theme.DefaultAxisTheme = DefaultAxisTheme;\n Object.defineProperty(DefaultTheme, 'Companion', {\n get: DefaultTheme$Companion_getInstance\n });\n package$theme.DefaultTheme = DefaultTheme;\n package$theme.FacetsTheme = FacetsTheme;\n package$theme.LegendTheme = LegendTheme;\n package$theme.PlotTheme = PlotTheme;\n package$theme.Theme = Theme;\n var package$tooltip = package$builder.tooltip || (package$builder.tooltip = {});\n package$tooltip.ConstantValue = ConstantValue;\n package$tooltip.DataFrameValue = DataFrameValue;\n package$tooltip.MappingValue = MappingValue;\n Object.defineProperty(TooltipLine, 'Companion', {\n get: TooltipLine$Companion_getInstance\n });\n package$tooltip.TooltipLine_init_3f4yhq$ = TooltipLine_init;\n package$tooltip.TooltipLine = TooltipLine;\n Object.defineProperty(TooltipSpecification$TooltipProperties, 'Companion', {\n get: TooltipSpecification$TooltipProperties$Companion_getInstance\n });\n TooltipSpecification.TooltipProperties = TooltipSpecification$TooltipProperties;\n Object.defineProperty(TooltipSpecification, 'Companion', {\n get: TooltipSpecification$Companion_getInstance\n });\n package$tooltip.TooltipSpecification = TooltipSpecification;\n package$tooltip.ValueSource = ValueSource;\n BogusCoordinateSystem.prototype.isPointInLimits_k2qmv6$ = CoordinateSystem.prototype.isPointInLimits_k2qmv6$;\n BogusCoordinateSystem.prototype.isRectInLimits_fd842m$ = CoordinateSystem.prototype.isRectInLimits_fd842m$;\n BogusCoordinateSystem.prototype.isPathInLimits_f6t8kh$ = CoordinateSystem.prototype.isPathInLimits_f6t8kh$;\n BogusCoordinateSystem.prototype.isPolygonInLimits_f6t8kh$ = CoordinateSystem.prototype.isPolygonInLimits_f6t8kh$;\n LayerTargetCollectorWithLocator.prototype.addPoint_cnsimy$ = GeomTargetCollector.prototype.addPoint_cnsimy$;\n LayerTargetCollectorWithLocator.prototype.addRectangle_bxzvr8$ = GeomTargetCollector.prototype.addRectangle_bxzvr8$;\n LayerTargetCollectorWithLocator.prototype.addPath_sa5m83$ = GeomTargetCollector.prototype.addPath_sa5m83$;\n LayerTargetCollectorWithLocator.prototype.addPolygon_sa5m83$ = GeomTargetCollector.prototype.addPolygon_sa5m83$;\n DefaultAxisTheme.prototype.tickLabelDistance = AxisTheme.prototype.tickLabelDistance;\n Kotlin.defineModule('lets-plot-plot-builder-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/DefaultSampling.kt?779d","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/MutableCollections.kt?9c58","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/FeatureSwitch.kt?8601","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/AxisUtil.kt?d9ab","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/BogusCoordinateSystem.kt?564a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/BogusScale.kt?7ba9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/GeomLayerListUtil.kt?06d5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/LayerRendererUtil.kt?ca26","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/Plot.kt?575c","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotBuilder.kt?e078","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotContainerPortable.kt?c34a","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotTile.kt?fdff","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotTooltipHelper.kt?06fc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/PlotUtil.kt?38bb","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Lazy.kt?28a8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/SvgLayerRenderer.kt?9cef","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/VarBinding.kt?05c8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/ColorBarAssembler.kt?ad66","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/ColorBarOptions.kt?0887","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GeomContextBuilder.kt?0505","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GeomLayerBuilder.kt?7d80","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/GuideOptions.kt?9356","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendAssembler.kt?d321","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendAssemblerUtil.kt?30b6","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/LegendOptions.kt?7bc0","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotAssembler.kt?b390","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotAssemblerUtil.kt?c7d9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotFacets.kt?a9ae","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PlotGuidesAssemblerUtil.kt?6ca1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/PosProvider.kt?c9d4","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/StitchedPlotLayers.kt?4b2e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/TypedScaleMap.kt?609b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/TypedScaleProviderMap.kt?de36","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/facet/FacetGrid.kt?4031","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/facet/FacetWrap.kt?5e9c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/GeomProvider.kt?f06c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/assemble/geom/PointDataAccess.kt?8666","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CartesianCoordProvider.kt?0c76","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CoordProviderBase.kt?d4c7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/CoordProviders.kt?996f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/FixedRatioCoordProvider.kt?715d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/ProjectionCoordProvider.kt?547b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/map/MercatorProjectionX.kt?ebb7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/coord/map/MercatorProjectionY.kt?6c7d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/DataProcessing.kt?9db8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupMerger.kt?b981","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupUtil.kt?4405","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/GroupingContext.kt?306d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/data/OrderOptionUtil.kt?417f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/event/MouseEventPeer.kt?6f65","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/AxisComponent.kt?382d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponent.kt?b9a3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponentLayout.kt?d405","webpack://LetsPlot/./kotlin-dce-dev/js/src/generated/_ComparisonsJs.kt?5791","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/ColorBarComponentSpec.kt?6ddb","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendArrangement.kt?1c59","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBox.kt?2224","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBoxLayout.kt?d6b7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBoxSpec.kt?9c59","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/text/Strings.kt?2d51","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendBreak.kt?9dc3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponent.kt?3d12","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponentLayout.kt?a2c4","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendComponentSpec.kt?73e2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendDirection.kt?84f0","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendJustification.kt?7539","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/LegendPosition.kt?9047","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/guide/Orientation.kt?00da","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/ContextualMappingProvider.kt?ce13","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/GeomInteraction.kt?65cf","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/GeomInteractionBuilder.kt?6272","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Maps.kt?a3e9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/MathUtil.kt?cd11","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/TooltipSpec.kt?b76a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/TooltipSpecFactory.kt?319d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LayerTargetCollectorWithLocator.kt?58cd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LayerTargetLocator.kt?3373","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/LocatedTargetsPicker.kt?b261","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetDetector.kt?5acd","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetProjection.kt?220f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TargetPrototype.kt?fb28","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/interact/loc/TransformedTargetLocator.kt?ebcc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/AxisLayoutInfo.kt?52b8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/EmptyAxisLayout.kt?4f46","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/FacetGridPlotLayout.kt?9fce","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/GeometryUtil.kt?84b2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxInfo.kt?42da","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxesLayout.kt?9035","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LegendBoxesLayoutUtil.kt?d34d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/LiveMapTileLayout.kt?9804","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotAxisLayout.kt?32ba","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutBase.kt?3dfa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutInfo.kt?41d6","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/PlotLayoutUtil.kt?cda3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/SingleTilePlotLayout.kt?74ee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/TileLayoutInfo.kt?94a7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/XYPlotLayoutUtil.kt?4dee","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/XYPlotTileLayout.kt?5086","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AdaptableAxisBreaksProvider.kt?fd84","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AxisBreaksUtil.kt?4866","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/AxisLayouter.kt?6fcc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/FixedAxisBreaksProvider.kt?5de1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/HorizontalAxisLayouter.kt?896e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/VerticalAxisLayouter.kt?620f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AbstractFixedBreaksLabelsLayout.kt?26fa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AxisLabelsLayout.kt?597e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/AxisLabelsLayoutInfo.kt?0e85","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/BreakLabelsLayoutUtil.kt?d1c8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalFixedBreaksLabelsLayout.kt?1f58","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalFlexBreaksLabelsLayout.kt?5330","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalMultilineLabelsLayout.kt?4262","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalSimpleLabelsLayout.kt?d3e5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalTiltedLabelsLayout.kt?35b7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/HorizontalVerticalLabelsLayout.kt?5961","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/VerticalFixedBreaksLabelsLayout.kt?d2c1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/layout/axis/label/VerticalFlexBreaksLabelsLayout.kt?2b73","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/Defaults.kt?d7a1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/LabelCss.kt?1c7a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/LabelMetrics.kt?8368","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/PlotLabelSpec.kt?e9e3","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/presentation/Style.kt?ffe7","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/Samplings.kt?699c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupRandomSampling.kt?ae6d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupSamplingBase.kt?675b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/GroupSystematicSampling.kt?d00d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/PickSampling.kt?8773","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/RandomSampling.kt?eef9","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/RandomStratifiedSampling.kt?884b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SamplingBase.kt?3924","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SamplingUtil.kt?5316","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/SystematicSampling.kt?2907","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/sampling/method/VertexSampling.kt?cb0b","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ContinuousOnlyMapperProvider.kt?4677","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultMapperProvider.kt?0057","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultMapperProviderUtil.kt?8b9d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DefaultNaValue.kt?f35a","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/DiscreteOnlyMapperProvider.kt?3731","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ScaleProviderBuilder.kt?80a5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/ScaleProviderHelper.kt?cf54","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/ColorMapper.kt?c3e5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMapperAdapter.kt?5115","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMapperWithGuideBreaks.kt?8aaa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/GuideMappers.kt?7aab","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/LineTypeMapper.kt?6f3e","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/mapper/ShapeMapper.kt?40e8","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/AlphaMapperProvider.kt?69aa","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorBrewerMapperProvider.kt?7117","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorGradient2MapperProvider.kt?5c55","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorGradientMapperProvider.kt?b95c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/ColorHueMapperProvider.kt?e638","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/DirectlyProportionalMapperProvider.kt?aee1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/GreyscaleLightnessMapperProvider.kt?663c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/HSVColorMapperProvider.kt?69a1","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/IdentityDiscreteMapperProvider.kt?76fb","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/IdentityMapperProvider.kt?1203","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/LinearNormalizingMapperProvider.kt?358d","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/MapperProviderBase.kt?7f66","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/SizeAreaMapperProvider.kt?e4a5","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/scale/provider/SizeMapperProvider.kt?2f2c","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/AxisTheme.kt?91ed","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/DefaultAxisTheme.kt?7bf2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/theme/DefaultTheme.kt?fc02","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/ConstantValue.kt?a9bc","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/DataFrameValue.kt?ca9f","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/MappingValue.kt?c3c2","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/TooltipLine.kt?1074","webpack://LetsPlot/../plot-builder-portable/src/commonMain/kotlin/jetbrains/datalore/plot/builder/tooltip/TooltipSpecification.kt?de66"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;gCAmgDA,yD;yBAAA,gD;;;;;;;;;;;;;;;;;;;;;;;;;;;sCC1+CA,mD;;;;;;eC4VA,I;;;;;;;;;;;;;;;;YC1IA,6B;;;;;;;;;;;;;;;;;;;mBH29CA,oC;;;;;;;;;;;;;;;;;;;;;2BA1JA,oD;qBI98CA,mB;mBAAA,wB;YC1E6B,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBLotC7B,6C;sBAAA,0C;6BAAA,mD;;;;;;;;;;;;;;;;;;;;oCA8oBA,yC;;;;;;;;;;;;;;;eMh0DA,wC;;;;;;;;sCNkYA,oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EO9aA,yB;IAAA,6B;IACI,0BAA+B,K;IAC/B,4BAAiC,K;IACjC,0BAAqC,K;IAErC,oCAA+C,K;IAE/C,+BAAoC,I;;4DAEpC,4B;IAEI,IAAI,iCAAJ,C;MACI,+BACI,MADJ,EAEI,kBAAc,iBAAQ,QAAR,CAFlB,C;KAKR,C;8CAEA,Y;IACI,OAAO,uB;EACX,C;sDAEA,sB;IAEI,IAAI,iCAAJ,C;MAGI,cAAc,kBAAc,wBAAe,EAAf,C;MAC5B,QAAQ,MAAR,C;MACA,QAAQ,OAAR,C;KAER,C;;;;;;;EAhCJ,qC;IAAA,oC;MAAA,mB;KAAA,6B;;ECMA,oB;IAAA,wB;;+CACI,sB;IACI,IAAK,iBAAiB,WAAI,IAAK,2BAAT,C;IACtB,IAAK,wBAAwB,WAAI,IAAK,uBAAT,C;IAC7B,IAAI,IAAK,0BAAL,IAAkC,IAAtC,C;MACI,IAAK,0BAA0B,WAAI,IAAK,0BAAT,C;KAEnC,IAAI,IAAK,wBAAL,IAAgC,IAApC,C;MACI,IAAK,wBAAwB,WAAI,IAAK,wBAAT,C;KAEjC,IAAK,mBAAmB,WAAI,IAAK,mBAAT,C;EAC5B,C;0CAEA,uB;IACI,IAAK,oBAAoB,WAAI,KAAM,iBAAV,C;IACzB,IAAK,mBAAmB,WAAI,KAAM,gBAAV,C;IACxB,IAAK,kBAAkB,WAAI,KAAM,WAAV,C;IAEvB,IAAK,UAAU,WAAI,KAAM,YAAV,C;IACf,IAAK,eAAe,WAAI,KAAM,iBAAV,C;IACpB,IAAK,gBAAgB,WAAI,KAAM,kBAAV,C;IACrB,IAAK,cAAc,WAAI,KAAM,gBAAV,C;EACvB,C;yCAEA,0C;IACI,kBAAkB,KAAM,iB;IACxB,mBAAmB,mBAAY,WAAZ,EAAyB,KAAzB,EAAgC,KAAhC,EAAuC,UAAvC,C;IAEnB,IAAK,OAAO,WAAI,YAAJ,C;IACZ,IAAK,OAAO,WAAI,WAAY,OAAhB,C;EAChB,C;qCAEA,mD;IAWe,UACa,M;IAN+C,gBAApD,eAAU,aAAI,WAAY,kBAAhB,EAAmC,OAAnC,C;IRo9C1B,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,6B;IAAb,OAAa,gBAAb,C;MAAa,wB;MQzhDL,U;MR0hDJ,WAAY,WQ1hDR,iBR0hDsB,IQ1hDtB,oCR0hDQ,C;;IQ5hDZ,mBR6hDG,W;IQzhDH,iBAAiB,gB;IACN,8B;IAAX,OAAW,cAAX,C;MAAW,oB;MAEH,IADsB,UACtB,U;QAAQ,0BAAa,EAAb,EAAiB,GAAjB,C;WACR,IAFsB,UAEtB,W;QAAS,0BAAa,GAAb,EAAkB,EAAlB,C;;;MAFb,0B;MAKA,kBAAkB,KAAM,kBAAS,aAAT,C;MACxB,aAAiB,UAAJ,GACT,WAAY,EADH,GAGT,WAAY,E;MAEhB,UAAW,WAAI,MAAJ,C;MACX,IAAI,CAAQ,SAAP,MAAO,CAAZ,C;QACI,MAAM,2BACF,mBAAmB,OAAM,KAAzB,GAAgC,mBAAhC,YAAsD,MAAtD,IACQ,YADR,YACwB,UAAW,KAAX,GAAkB,CAAlB,IADxB,IAEQ,uBAFR,YAEkC,WAAY,aAF9C,IAGQ,uBAHR,YAGkC,YAHlC,IAIQ,uBAJR,YAIkC,UAJlC,CADE,C;;IASd,OAAO,U;EACX,C;;;;;;;EAnEJ,gC;IAAA,+B;MAAA,c;KAAA,wB;;ECJA,iC;;qDACI,a;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;uDAEA,a;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;oEAEA,uB;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;mEAEA,0B;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;mEAEA,0B;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;sEAEA,6B;IACI,MAAM,2BAAsB,qDAAtB,C;EACV,C;;;SAGI,Y;MAAQ,MAAM,2BAAsB,qDAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,qDAAtB,C;;;;;;;;EC7BtB,sB;;;;SAEQ,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;;;SAGd,Y;MAAQ,MAAM,2BAAsB,yCAAtB,C;;;mCAElB,Y;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;yCAEA,Y;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;kDAEA,a;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;wCAEA,Y;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;gDAEA,+B;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;4CAEA,Y;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;8BAEA,Y;IACI,MAAM,2BAAsB,yCAAtB,C;EACV,C;;;;;;;;;;;;;ECxDJ,6B;IAAA,iC;;;;;;;;EAAA,yC;IAAA,wC;MAAA,uB;KAAA,iC;;ECKA,6B;IAAA,iC;;gEAEI,8D;IAKI,uBACI,sBAAS,sCAA6B,KAA7B,EAAoC,oBAApC,C;IACb,iBAAiB,sBAAS,+BACtB,KADsB,EAEtB,gBAFsB,EAGtB,qBAHsB,C;IAK1B,UAAU,sBAAS,wBAAe,KAAf,EAAsB,UAAtB,C;IACnB,OAAO,wCACH,KADG,EAEH,UAFG,EAGH,gBAHG,EAIH,GAJG,C;EAMX,C;EAEuB,uF;IAEnB,4B;IACA,wC;IACA,c;IAEA,YAAiB,KAAM,K;IACvB,gBAAyB,KAAM,S;IAC/B,kBAAmC,KAAM,W;IACzC,yBAA2C,KAAM,kB;;;;;;;;;;;;;EAhCzD,yC;IAAA,wC;MAAA,uB;KAAA,iC;;EC8BmB,qB;IAoYf,4B;IApY4C,uB;IAA5B,4B;IAEhB,iCAA8B,kBAAc,4CAAd,C;IAC9B,8BAA4B,kBAAc,sBAAa,KAA3B,C;IAC5B,iCAA8B,uB;IAC9B,kCAA+B,gB;IAE/B,sBAAqB,oB;;;;SAqBjB,Y;MAAQ,sC;;;yCAEZ,Y;IACI,OAAO,8B;EACX,C;+BAEA,Y;IACI,OAAO,2B;EACX,C;EAkBqB,sC;IAAE,kB;EAAY,C;kCAJnC,Y;IAckB,Q;;MAZV,0B;;MACF,uC;QACE,kCAAI,eAAM,CAAN,EAAS,0BAAT,C;QAEJ,gBAAgB,eAAW,sBAAa,CAAb,C;QAC3B,eAAe,CACX,0BAA2C,+BAAjB,SAAiB,YADhC,EACgD,SAAU,QAAV,QAAJ,GACnD,MAAM,SAAU,QAAhB,GAA0B,GADyB,GAGnD,cAJO,C;QAMf,QAAQ,8BAAgB,MAAM,EAAtB,GAA0B,CAA1B,GAA8B,C;QACtC,wBAAU,QAAV,gB;UAAU,gBAAV,M;UACI,iBAAiB,cAAU,CAAV,C;UACjB,UAAW,+D;UACX,UAAW,2D;UACX,UAAW,gBAAO,8BAAgB,MAAM,EAAtB,GAA0B,CAAjC,EAAoC,CAApC,C;UACX,cAAU,WAAW,WAAI,UAAW,UAAf,C;UACrB,KAAK,I;;;QAnBb,O;;EAsBJ,C;EAKmC,iD;IAAA,0B;;yDAC3B,iB;IACI,eAAe,KAAM,S;IACrB,IAAI,uBAAW,EAAX,GAAe,CAAf,IAAoB,QAAS,EAAT,GAAa,CAArC,C;MACI,sC;KAER,C;;;;;EAGA,mD;IAAA,0B;IAAS,uB;;sDACT,Y;IACI,wCAAgB,qB;IAChB,yCAAiB,Q;EACrB,C;;;;;uCAhBR,Y;IACI,cAAU,kBAAS,mBAAM,KAAf,C;IACV,oC;IACA,iBAAI,8BAAgB,2DAApB,C;IASA,0D;EAMJ,C;yCAEA,Y;IACI,Y;IACA,0B;EACJ,C;wCAGA,oD;IAOI,U;IACA,U;IACA,S;IACA,IAAI,QAAS,UAAT,YAA8B,QAAS,UAAT,QAAlC,C;MACI,cAAc,sBAAS,UAAU,WAAnB,C;MACd,kBAAkB,QAAS,UAAU,W;MAErC,cAAc,sBAAS,UAAU,WAAnB,C;MACd,kBAAkB,QAAS,UAAU,W;MAGrC,SAAS,kBAAc,yBAAgB,gBAAhB,EAA6B,OAA7B,EAAsC,WAAtC,EAAmD,sBAAS,UAAU,WAAnB,CAAnD,C;MACvB,SAAS,kBAAc,yBAAgB,gBAAhB,EAA6B,OAA7B,EAAsC,WAAtC,EAAmD,sBAAS,UAAU,WAAnB,CAAnD,C;MACvB,QAAQ,kBAAc,gCAAuB,OAAvB,EAAgC,WAAhC,EAA6C,OAA7C,EAAsD,WAAtD,C;;MAGtB,SAAS,gB;MACT,SAAS,gB;MACT,QAAQ,2B;;IAGZ,WAAW,aAAS,UAAT,EAAqB,MAArB,EAA6B,MAA7B,EAAqC,WAArC,EAAkD,QAAlD,EAA4D,KAA5D,EAAmE,KAAnE,C;IACX,IAAK,qBAAY,kBAAZ,C;IACL,IAAK,eAAe,WAAI,4CAAJ,C;IAEpB,OAAO,I;EACX,C;6CAEA,qD;IAO+C,IAAN,I;IADrC,wD;IACqC,QAAM,WAAN,M;WACjC,M;WAAA,O;WAAA,K;;QAAA,K;WACA,Q;;QAAA,K;;QAFiC,K;;IAArC,yB;IAKA,iB;IACA,eAAe,G;IACf,QAAM,WAAN,M;WACI,M;QACI,gBACI,iBAAa,UAAW,KAAX,GAAkB,4BAAe,wBAA9C,EAAuE,UAAW,OAAO,EAAzF,C;QACJ,WAAW,CAAC,I;QAHhB,K;WAKA,O;QACI,gBACI,iBAAa,UAAW,MAAX,GAAmB,4BAAe,wBAA/C,EAAwE,UAAW,OAAO,EAA1F,C;QACJ,WAAW,I;QAHf,K;WAKA,K;QAAmB,gBACf,iBAAa,UAAW,OAAO,EAA/B,EAAkC,UAAW,IAAX,GAAiB,4BAAe,wBAAlE,C;QADJ,K;WAEA,Q;QAAsB,gBAClB,iBAAa,UAAW,OAAO,EAA/B,EAAkC,UAAW,OAAX,GAAoB,4BAAe,wBAArE,C;QADJ,K;;QAbJ,K;;IAiBA,iBAAiB,cAAU,IAAV,C;IACjB,UAAW,6BAAoB,gBAApB,C;IACX,UAAW,2BAAkB,cAAlB,C;IACX,UAAW,gBAAO,aAAP,C;IACX,UAAW,gBAAO,QAAP,C;IAEX,mBAAmB,UAAW,U;IAC9B,YAAa,kBAAS,mBAAM,WAAf,C;IAGb,aAAa,iB;IACb,MAAO,kBAAS,mBAAM,KAAf,C;IAEP,MAAO,WAAW,WAAI,YAAJ,C;IAElB,iBAAI,MAAJ,C;EACJ,C;EAG+C,yD;IAAA,sC;;4DAEvC,mB;IACI,QAAQ,oBAAR,C;EACJ,C;;;;;yCALR,sB;IACI,CAAE,8F;EAMN,C;iDAEA,Y;IAeqB,UAOE,MAPF,EAoBY,MApBZ,EAiFD,MAjFC,EAwFM,MAxFN,EAwGR,MAxGQ,EAmKW,M;IAjL5B,oBAAoB,8BAAgB,M;IACpC,kBAAkB,oBAAgB,sBAAa,KAA7B,EAAmC,aAAnC,C;IAGlB,IAAI,4CAAJ,C;MACI,WAAW,oBAAe,WAAf,C;MACX,IAAK,cAAc,WAAI,eAAM,QAAV,C;MACnB,IAAK,cAAc,WAAI,GAAJ,C;MACnB,IAAK,cAAc,WAAI,GAAJ,C;MACnB,2BAAY,IAAZ,EAAkB,8BAA2B,WAA7C,C;MACA,iBAAI,IAAJ,C;KAIa,IAAI,iBAAJ,C;MACb,0DAAc,WAAd,C;;MAEA,kB;;IAHJ,qB;IAOmB,IAAI,eAAJ,C;MACf,gBAAgB,4BAAe,yBAAgB,UAAhB,C;MAC/B,6BACI,UAAW,OAAO,aAAI,iBAAa,GAAb,EAAkB,SAAU,EAA5B,CAAJ,CADtB,EAEI,UAAW,UAAU,kBAAS,iBAAa,GAAb,EAAkB,SAAU,EAA5B,CAAT,CAFzB,C;;MAKA,mB;;IAPJ,yB;IAWA,wBAAmD,I;IACnD,kBAAkB,oBAAM,S;IACK,IAAI,WAAY,WAAW,QAA3B,C;MACzB,wBACI,sBAAkB,YAAlB,EAAgC,WAAhC,C;MACJ,oBAAoB,iBAAkB,kBAAS,mBAAT,C;MACpB,SAAlB,iBAAkB,kC;;MAElB,qB;;IANJ,mC;IAUA,IAAI,4CAAJ,C;MACI,aAAW,oBAAe,sBAAf,C;MACX,MAAK,cAAc,WAAI,eAAM,KAAV,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,2BAAY,MAAZ,EAAkB,2CAAwC,sBAA1D,C;MACA,iBAAI,MAAJ,C;KAIJ,kBAAkB,sB;IAClB,IAAI,kBAAJ,C;MACI,IAAI,uBAAJ,C;QACI,kBAAgB,4BAAe,6BAAoB,kBAApB,C;QAC/B,gBACI,WAAU,EAAV,GAAc,4BAAe,wBAA7B,GAAuD,4BAAe,wB;QAC1E,cAAc,qBACV,WAAY,KAAZ,GAAmB,SADT,EACoB,WAAY,IADhC,EAEV,WAAY,MAAZ,GAAoB,SAFV,EAEqB,WAAY,OAFjC,C;OAOlB,IAAI,yBAAJ,C;QACI,kBAAgB,4BAAe,6BAAoB,oBAApB,C;QAC/B,kBACI,WAAU,EAAV,GAAc,4BAAe,wBAA7B,GAAuD,4BAAe,wB;QAC1E,cAAc,qBACV,WAAY,KADF,EACQ,WAAY,IADpB,EAEV,WAAY,MAFF,EAES,WAAY,OAAZ,GAAqB,WAF9B,C;QAQtB,iBAAiB,iB;IACjB,eAAe,UAAW,kBAAS,WAAY,UAArB,C;IAC1B,IAAK,uBAAc,WAAI,aAAJ,C;IAEnB,IAAI,QAAS,MAAM,UAAnB,C;MACI,M;KAGJ,qBAAqB,4BAAe,4BAAmB,WAAY,OAA/B,EAAuC,QAAvC,C;IACpC,IAAI,WAAY,WAAW,UAA3B,C;MAEI,0BAAwB,sBAAkB,cAAlB,EAAkC,WAAlC,C;MACxB,oBAAoB,mBAAkB,kBAAS,mBAAT,C;KAI1B,IAAG,QAAS,MAAM,KAAf,GAAsB,CAAzB,C;MACN,SAAN,oBAAM,Y;;MAEN,6B;;IAHJ,sB;IAMA,kBAAkB,WAAY,O;IACP,iBAAS,MAAT,W;IAAvB,OAAuB,gBAAvB,C;MAAuB,kC;MAGnB,sBAAsB,cAAe,U;MAMrC,WAAW,0BAAW,WAAX,EAAwB,cAAxB,EAAwC,wBAAW,eAAX,CAAxC,EAAqE,SAArE,C;MAEX,yBAAyB,WAAY,aAAI,cAAe,WAAnB,C;MACrC,IAAK,gBAAO,kBAAP,C;MAEL,iBAAI,IAAJ,C;MAEA,KAAK,SAAL,IAAK,cAAL,U;QCpPD,sBDoPyB,yB;;SCpPzB,YDoPyB,+BCpPzB,U;ODsPC,yBAAyB,cAAe,WAAW,aAAI,kBAAJ,C;MACnD,8BAAgB,qBAAY,kBAAZ,EAAgC,IAAK,eAArC,C;;IAIpB,IAAI,4CAAJ,C;MACI,aAAW,oBAAe,cAAf,C;MACX,MAAK,cAAc,WAAI,eAAM,IAAV,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,iBAAI,MAAJ,C;KAIJ,IAAI,eAAJ,C;MACI,iBAAiB,cAAU,UAAV,C;MACjB,UAAW,sBAAa,mBAAM,WAAnB,C;MACX,UAAW,6D;MACX,UAAW,2D;MAEX,kBAAgB,4BAAe,yBAAgB,UAAhB,C;MAC/B,kBAAkB,qBAAgB,cAAe,OAAO,EAAtC,EAAyC,GAAzC,EAA8C,WAAU,EAAxD,EAA2D,WAAU,EAArE,C;MAClB,UAAW,gBAAO,iBAAa,WAAY,KAAzB,EAA+B,WAAY,OAAO,EAAlD,CAAP,C;MACX,iBAAI,UAAJ,C;MAGA,IAAI,4CAAJ,C;QACI,aAAW,oBAAe,WAAf,C;QACX,MAAK,cAAc,WAAI,eAAM,KAAV,C;QACnB,MAAK,cAAc,WAAI,GAAJ,C;QACnB,MAAK,cAAc,WAAI,GAAJ,C;QACnB,iBAAI,MAAJ,C;QAKR,IAAI,kBAAJ,C;MACI,IAAI,uBAAJ,C;QACI,+BACI,kBADJ,kCAGI,sBAHJ,EAII,cAJJ,C;OAOJ,IAAI,yBAAJ,C;QACI,+BACI,oBADJ,oCAGI,sBAHJ,EAII,cAJJ,C;QAUR,IAAI,yBAAJ,C;MAC4B,0BAAkB,oBAAlB,W;MAAxB,OAAwB,gBAAxB,C;QAAwB,mC;QACpB,gBAAgB,eAAgB,UAAU,kB;QAC1C,SAAU,gBAAO,eAAgB,SAAvB,C;QACV,iBAAI,SAAJ,C;;KAGZ,C;8CAEA,qB;IACI,OAAO,8BAAgB,4BAAmB,SAAnB,C;EAC3B,C;yCAEA,qB;IACI,OAAO,8BAAgB,uBAAc,SAAd,C;EAC3B,C;EAEA,0B;IAAA,8B;IACI,aAAkB,uBAAgB,gC;IAElC,uBAA4B,iBAAa,KAAb,EAAoB,KAApB,C;IAC5B,uBAAkC,8C;;;;;;;;EAJtC,sC;IAAA,qC;MAAA,oB;KAAA,8B;;;;;;;EEhaa,8B;IAAC,wB;IACd,wBAA6B,gB;IAC7B,iBAA+B,I;IAC/B,+D;IACA,kBAAoC,I;IACpC,yBAAuC,I;IACvC,2BAAyC,I;IACzC,0BAA+B,gB;IAC/B,2D;IACA,2D;IACA,uBAA4B,I;IAC5B,+BAAoC,I;IACpC,oBAAyB,K;;;;SATzB,Y;;;MAAA,qC;;SAAA,2B;MAAA,gD;;;;;SAKA,Y;;;MAAA,mC;;SAAA,yB;MAAA,4C;;;;;SACA,Y;;;MAAA,mC;;SAAA,yB;MAAA,4C;;;2CAKA,iB;IACI,iBAAU,K;EACd,C;mDAEA,a;IACI,yBAAkB,C;EACtB,C;qDAEA,a;IACI,2BAAoB,C;EACxB,C;mDAEA,yB;IACI,yBAAkB,a;IAClB,OAAO,I;EACX,C;gDAEA,sB;IACI,qBAAe,WAAI,iBAAU,UAAV,CAAJ,C;IACf,OAAO,I;EACX,C;gDAEA,kB;IACI,kBAAW,M;IACX,OAAO,I;EACX,C;mDAEA,a;IACI,uBAAiB,WAAI,CAAJ,C;IACjB,OAAO,I;EACX,C;8CAEA,uB;IACI,uBAAgB,W;IAChB,OAAO,I;EACX,C;8CAEA,uB;IACI,uBAAgB,W;IAChB,OAAO,I;EACX,C;8CAEA,a;IACI,uBAAgB,C;IAChB,OAAO,I;EACX,C;sDAEA,a;IACI,+BAAwB,C;IACxB,OAAO,I;EACX,C;6CAEA,a;IACI,oBAAa,C;IACb,OAAO,I;EACX,C;gCAEA,Y;IACI,OAAO,uBAAO,IAAP,C;EACX,C;EAEoB,+B;IAAmB,gBAAK,CAAE,UAAP,C;IACnC,6BAA0C,CAAE,gB;IAC5C,6BAA0C,CAAE,gB;IAE5C,iBAA+B,CAAE,U;IACjC,yBAAuC,CAAE,kB;IACzC,2BAAyC,CAAE,oB;IAC3C,6BAA2C,CAAE,UAAQ,QAAQ,Y;IAC7D,6BAA2C,CAAE,UAAQ,QAAQ,Y;IAE7D,+BAA4C,CAAE,kB;IAE9C,4B;IACA,sB;IACA,8B;IACA,yB;IAEA,oC;IACA,4C;IAwBI,wBAAiB,iBAAU,CAAE,iBAAZ,C;IACjB,kBAAW,CAAE,W;IACb,0BAAmB,iBAAU,CAAE,mBAAZ,C;IAEnB,oBAAa,CAAE,a;IAEf,+BAAgB,CAAE,gB;IAClB,uCAAwB,CAAE,wB;;;;SAhD9B,Y;MAAA,iC;;;;;SACA,Y;MAAA,iC;;;;;SAQA,Y;MAAA,mC;;;;;SAOA,Y;MAAA,mC;;;;;SACA,Y;MAAA,2C;;;;;SAGI,Y;Md3ER,IAAI,Cc4EgB,ed5EpB,C;QACI,cc2E8B,U;Qd1E9B,MAAM,8BAAyB,OAAQ,WAAjC,C;Oc2EE,OAAO,6B;IACX,C;;;;SAGA,Y;MdjFR,IAAI,CckFgB,uBdlFpB,C;QACI,cciFsC,oB;QdhFtC,MAAM,8BAAyB,OAAQ,WAAjC,C;OciFE,OAAO,qC;IACX,C;;;;SAGA,Y;MdvFR,IAAI,CcwFgB,yBdxFpB,C;QACI,ccuFwC,sB;QdtFxC,MAAM,8BAAyB,OAAQ,WAAjC,C;OcuFE,OAAO,uC;IACX,C;;;;SAGA,Y;MAAQ,8B;;;0CAaZ,Y;IACI,OAAO,CAAC,YAAQ,uBAAc,cAAd,C;EACpB,C;kDAEA,Y;IACI,OAAO,8BAAuB,CAAC,YAAQ,uBAAc,sBAAd,C;EAC3C,C;oDAEA,Y;IACI,OAAO,8BAAuB,CAAC,YAAQ,uBAAc,wBAAd,C;EAC3C,C;4CAEA,Y;IACI,OAAO,iB;EACX,C;oDAEA,qB;IACI,OAAO,kCAAe,SAAf,C;EACX,C;4CAEA,Y;IACI,OAAO,8B;EACX,C;;;;;;;;;;;EC3IwB,oD;IAwG5B,6C;IAvGA,gB;IACA,4C;IAGA,WAAyB,mB;IAQzB,gCAAsC,K;IACtC,iCAA8B,6B;IAG1B,QAAI,kBAAS,mBAAM,eAAf,C;IACJ,0BAAW,4BAAc,MAAzB,C;IAEA,SAAK,cAAc,oBAAW,gEAAgB,uCAAhB,CAAX,C;IAQnB,4BAAc,oBAAW,gEAAgB,yCAAhB,CAAX,C;;;;SApBd,Y;MAAQ,gBAAK,uB;;;;;SAGb,Y;MAAQ,OCgM4C,CDhM5C,SAAK,uBCgMwC,U;;;uDDxKzD,Y;IACI,IAAI,CAAC,6BAAL,C;MACI,mB;KAER,C;gEAEA,Y;IACI,IAAI,6BAAJ,C;MACI,mB;MACA,mB;KAER,C;EAMiB,4D;;mEACT,Y;IACI,OAAO,mBAAM,I;EACjB,C;;;;;iDAPR,Y;IfuBA,IAAI,CetBM,CAAC,6BfsBX,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KevBN,gCAAiB,I;IAEjB,QAAI,yE;IAWJ,eAAe,oB;IACf,QAAS,kBAAS,iCAAT,C;IAMT,QAAS,sBAAa,OAAb,EAAsB,MAAtB,C;IACT,QAAS,sBAAa,QAAb,EAAuB,MAAvB,C;IAOT,QAAI,WAAW,WAAI,QAAJ,C;IAEf,SAAK,wBAAgB,WAAI,4BAAc,MAAlB,C;IACrB,QAAI,WAAW,WAAI,SAAK,UAAT,C;EACnB,C;iDAEA,Y;IACI,IAAI,6BAAJ,C;MACI,gCAAiB,K;MAEjB,QAAI,WAAW,Q;MACf,SAAK,Q;MACL,8BAAgB,S;MAChB,iCAAkB,6B;KAE1B,C;gDAEA,wB;IACI,8BAAgB,aAAI,YAAJ,C;EACpB,C;yDAEA,gB;IACI,QAAI,QAAQ,WAAI,IAAK,EAAT,C;IACZ,QAAI,SAAS,WAAI,IAAK,EAAT,C;EACjB,C;EAEA,2C;IAAA,+C;;EAEe,sF;IAAA,kC;;0FACH,iB;IACI,eAAe,KAAM,S;IACrB,IAAI,YAAY,IAAhB,C;MACI,kBAAM,CAAO,QAAP,C;KAEd,C;;;;;gEAPR,iB;IACI,+E;EAQJ,C;;;;;;;EAVJ,uD;IAAA,sD;MAAA,qC;KAAA,+C;;EApFkD,uE;IAAA,8B;MAEtC,QAAI,kDAAc,MAAM,E;MAAxB,QAA2B,WAAY,E;MAAvC,Wd8U6C,MAAW,KAAI,CAAJ,EAAO,CAAP,C;Mc7UxD,UAAI,kDAAc,MAAM,E;MAAxB,UAA2B,WAAY,E;MAF3C,iBAAiB,uBd+UgC,MAAW,KAAI,GAAJ,EAAO,GAAP,Cc/U3C,C;MAIjB,gDAAW,UAAX,C;MACJ,W;IAAA,C;;EAEyC,yE;IAAA,mC;MACrC,IAAI,gBAAiB,EAAjB,GAAqB,CAArB,IAA0B,gBAAiB,EAAjB,GAAqB,CAAnD,C;QACI,wD;OAER,W;IAAA,C;;;;;;;EEjBe,6F;IAQnB,uB;IANA,0B;IACA,0B;IACA,oC;IACA,kC;IACA,wB;IACA,wB;IAGA,wBAA6B,kBAAc,KAAd,C;IAC7B,sB;IACA,0BAA+B,gB;IAC/B,oBAAkC,K;IAElC,+BAA8B,I;IAU1B,kBAAW,iBAAU,MAAV,C;IAEX,oBAAO,mBAAa,2BAAkB,oBAAlB,CAAiC,OAArD,C;;;;SAZJ,Y;MAAA,mC;;SAAA,yB;MAAA,4C;;;;;SAII,Y;MAAQ,8B;;;;;SAGR,Y;MAAQ,4BAAe,M;;;sCAQ3B,Y;IAgF+B,UAGE,MAHF,EAIE,M;IA3E7B,iBAAiB,mBAAa,W;IAE9B,IAAI,cAAQ,OAAO,iBAAnB,C;MAC0C,gBAA3B,oBAAe,UAAf,C;MJCnB,SIAY,cAAc,WAAI,cAAQ,OAAO,kBAAnB,C;MJA1B,SICY,cAAc,WAAI,GAAJ,C;MJD1B,SIEY,cAAc,WAAI,GAAJ,C;MAHlB,WJED,S;MIGC,iBAAI,IAAJ,C;KAGJ,sBAAe,UAAf,EAA2B,cAAQ,SAAnC,C;IAEgC,kBAAT,e;IAAS,sB;;MlBkMpB,U;MAAA,+B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAAM,IAAc,OkBlMiB,UlBkM/B,C;UAAwB,qBAAO,O;UAAP,uB;;MAC9C,qBAAO,I;;;IkBnMH,yC;IACA,IAAI,4BAA4B,iBAAhC,C;MACI,eAAQ,UAAR,C;KAGJ,IAAI,qBAAJ,C;MACI,iBAAiB,mBAAa,O;MAC9B,aAAW,oBAAe,UAAf,C;MACX,MAAK,YAAY,WAAI,eAAM,MAAV,C;MACjB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,iBAAI,MAAJ,C;KAGJ,IAAI,qBAAJ,C;MACI,iBAAiB,mBAAa,W;MAC9B,aAAW,oBAAe,UAAf,C;MACX,MAAK,YAAY,WAAI,eAAM,WAAV,C;MACjB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,iBAAI,MAAJ,C;KAGJ,IAAI,qBAAJ,C;MACI,aAAW,oBAAe,UAAf,C;MACX,MAAK,YAAY,WAAI,eAAM,KAAV,C;MACjB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,cAAc,WAAI,GAAJ,C;MACnB,iBAAI,MAAJ,C;KAKJ,IAAI,wBAAJ,C;MACI,iBAAiB,mBAAa,+BAAsB,oBAAtB,C;MAE9B,kBAAmC,mBAAjB,gBAAiB,EAAmB,UAAnB,C;MAEnC,qBAAgB,WAAY,a;MAC5B,uBAAiB,WAAI,WAAY,cAAhB,C;;MAGjB,2BAA2B,c;MAC3B,4BAA4B,c;MAE5B,gBAAgB,mBAAa,U;MAC7B,gBAAgB,mBAAa,U;MAC7B,cAAc,eAAS,O;MACvB,cAAc,eAAS,O;MAEvB,UAAqB,aAAI,E;MAAzB,oBf0GR,aAAI,GAAJ,Ee1GsC,Of0GtC,C;MezGQ,YAAqB,aAAI,E;MAAzB,oBfyGR,aAAI,KAAJ,EezGsC,OfyGtC,C;MexGQ,YAAqB,aAAI,M;MAAzB,YAAkC,aAAQ,aAAI,sBAAQ,GAAR,KAAiB,sBAAQ,GAAR,EAArB,C;MAA1C,oBfwGR,aAAI,KAAJ,EAAS,KAAT,C;MetGQ,YAAsB,aAAI,E;MAA1B,cAA+B,sCAAY,WAAZ,C;MAA/B,qBfsGR,aAAI,KAAJ,EAAS,OAAT,C;MerGQ,YAAsB,aAAI,E;MAA1B,cAA+B,sCAAY,WAAZ,C;MAA/B,qBfqGR,aAAI,KAAJ,EAAS,OAAT,C;MenGQ,0BAA0B,kBAAW,oBAAX,EAAiC,qBAAjC,EAAwD,cAAxD,C;MACH,qC;MAAvB,OAAuB,cAAvB,C;QAAuB,gC;QACnB,cAAe,gBAAO,UAAW,OAAlB,C;QAEf,aAAa,CAAQ,SAAR,cAAQ,aAAR,qBAAwB,gBAAY,GAAZ,EAAiB,UAAW,MAA5B,C;QACrC,aAAa,CAAQ,SAAR,cAAQ,aAAR,qBAAwB,gBAAY,GAAZ,EAAiB,UAAW,OAA5B,C;QACrC,eAAe,0BAAa,qBAAY,MAAZ,EAAoB,MAApB,C;QAE5B,cAAe,oBAAW,QAAX,C;QACf,iBAAI,cAAJ,C;;;EAGZ,C;wCAEA,6B;IAYuB,Q;IAVnB,cAAc,mBAAa,a;IAC3B,ID8DoD,CC9DhD,OD8DiD,UC9DrD,C;MACI,gBAAgB,sEAAkB,UAAW,MAA7B,C;MAChB,gBAAgB,iBACZ,UAAW,KAAX,GAAkB,CADN,EAEZ,UAAW,IAAX,GAAiB,uEAAmB,OAAQ,KAA3B,CAAjB,GAAoD,CAFxC,C;MAIhB,kBAAkB,oBACd,SADc,EACH,SADG,C;MAGH,yB;MAAf,OAAe,cAAf,C;QAAe,wB;QAC4B,gBAA5B,oBAAe,WAAf,C;QJ7FvB,SI8FgB,cAAc,WAAI,GAAJ,C;QJ9F9B,SI+FgB,YAAY,WAAU,uBAAV,C;QAFhB,WJ5FL,S;QIoGK,iBAAI,IAAJ,C;QAEA,QAAQ,WAAY,OAAO,E;QAC3B,QAAQ,WAAY,OAAO,E;QAC3B,UAAU,cAAU,MAAV,C;QACV,GAAI,gBAAO,CAAP,EAAU,CAAV,C;QACJ,GAAI,+D;QACJ,GAAI,2D;QACJ,iBAAI,GAAJ,C;QAEA,cAAc,WAAY,aAAI,iBAAa,GAAb,EAAkB,SAAU,EAA5B,CAAJ,C;;KAKlC,IAAI,mBAAa,YAAb,QAAJ,C;MAEI,WAAW,C;MACX,WAAW,C;MAEX,oBAAkB,qBACd,UAAW,MAAX,GAAmB,IADL,EACW,UAAW,IAAX,GAAiB,IAD5B,EAEd,gEAAmB,OAAO,CAAP,IAAnB,CAFc,EAEe,UAAW,OAAX,IAAoB,OAAO,CAAP,IAApB,CAFf,C;MAIlB,aAAW,oBAAe,aAAf,C;MACX,MAAK,cAAc,WAAI,GAAJ,C;MACnB,MAAK,YAAY,WAAI,KAAM,kBAAV,C;MACjB,iBAAI,MAAJ,C;MAEA,UAAQ,aAAY,OAAO,E;MAC3B,UAAQ,aAAY,OAAO,E;MAE3B,YAAU,cAAU,mBAAa,YAAvB,C;MACV,KAAI,gBAAO,GAAP,EAAU,GAAV,C;MACJ,KAAI,+D;MACJ,KAAI,2D;MACJ,KAAI,gBAAO,IAAP,C;MACJ,iBAAI,KAAJ,C;KAER,C;iCAEA,sB;IAEI,IAAI,mBAAa,WAAjB,C;MACI,WAAW,iBAAU,eAAV,EAAoB,iCAAa,UAAb,CAApB,EAA8C,cAA9C,EAAuD,cAAQ,QAA/D,C;MACX,IAAK,gBAAO,iBAAa,UAAW,KAAxB,EAA8B,UAAW,OAAzC,CAAP,C;MACL,iBAAI,IAAJ,C;KAGJ,IAAI,mBAAa,WAAjB,C;MACI,aAAW,iBAAU,eAAV,EAAoB,iCAAa,UAAb,CAApB,EAA8C,cAA9C,EAAuD,cAAQ,QAA/D,C;MACX,MAAK,gBAAO,UAAW,OAAlB,C;MACL,iBAAI,MAAJ,C;KAER,C;mCAEA,qC;IAMI,WAAW,kBAAc,IAAK,WAAnB,EAA+B,kBAAK,YAAL,CAA/B,C;IACX,sBAAS,mBAAU,IAAV,EAAgB,KAAhB,EAAuB,KAAvB,EAA8B,IAAK,YAAY,aAA/C,C;IACT,sBAAS,yBAAgB,IAAhB,EAAsB,IAAtB,C;IACT,sBAAS,oBAAW,IAAX,EAAiB,KAAjB,C;IACT,IAAI,qBAAJ,C;MACI,IAAI,IAAK,iBAAL,IAAyB,IAA7B,C;QACI,WAAW,oBAAe,IAAK,iBAApB,C;QACX,IAAK,cAAc,WAAI,eAAM,MAAV,C;QACnB,IAAK,cAAc,WAAI,GAAJ,C;QACnB,IAAK,cAAc,WAAI,GAAJ,C;QACnB,IAAK,aAAI,IAAJ,C;QAGb,OAAO,I;EACX,C;oCAEA,8D;IAOkB,Q;IADd,qBAAqB,gB;IACP,iC;IAAd,OAAc,cAAd,C;MAAc,uB;MACV,mBAAmB,+BAAkB,iCACjC,KADiC,EAEjC,oBAFiC,EAGjC,qBAHiC,C;MAMrC,uBAAuB,YAAa,iB;MACpC,iBAAiB,YAAa,W;MAE9B,sBAAsB,oCAClB,KAAM,SADY,EAElB,KAAM,kBAFY,EAGlB,KAAM,kBAHY,EAIlB,KAJkB,C;MAMtB,uBAAiB,WAAI,eAAJ,C;MAEjB,UAAU,yBACL,oBAAW,UAAX,CACA,yBAAiB,gBAAjB,CACA,4BAAoB,eAApB,CACA,Q;MAEL,UAAU,YAAa,I;MACvB,WAAW,KAAM,K;MAEjB,cAAe,WAAI,qBAAiB,UAAjB,EAA6B,IAA7B,EAAmC,GAAnC,EAAwC,KAAxC,EAA+C,GAA/C,CAAJ,C;;IAEnB,OAAO,c;EACX,C;2CAEA,oB;IACI,oBAAa,Q;EACjB,C;oCAEA,Y;IACI,OAAO,qB;EACX,C;;;;;;EAGJ,+C;IACY,Q;IAAR,OAA6B,CAArB,qEAAqB,6BAAmB,MAAnB,C;EACjC,C;ECvSA,6B;IACI,qBAA0B,gB;;mDAE1B,Y;IACI,kBAAY,Q;EAChB,C;oDAEA,sC;IACI,eAAe,+BACX,UADW,EAEX,cAFW,C;IAIf,kBAAY,WAAI,QAAJ,C;EAChB,C;2DAEA,qB;IACmB,Q;IAAA,2BAAa,SAAb,C;IAAA,iB;MAA2B,OAAO,W;KAAjD,eAAe,I;IAEf,oBAAoB,QAAS,qBAAY,SAAZ,C;IAC7B,OAAO,0BAAmB,aAAnB,EAAkC,QAAS,mBAA3C,C;EACX,C;sDAEA,qB;IACmB,Q;IAAA,2BAAa,SAAb,C;IAAA,iB;MAA2B,OAAO,I;KAAjD,eAAe,I;IACf,OAAO,QAAS,mB;EACpB,C;+CAEA,qB;IACqB,Q;IAAA,oC;IAAjB,OAAiB,cAAjB,C;MAAiB,0B;MACb,IAAI,QAAS,kBAAS,SAAT,CAAb,C;QACI,OAAO,Q;;IAIf,OAAO,I;EACX,C;qDAEA,qC;IACI,mBAAmB,gB;InBkwDP,Q;IAAA,OmBhwDZ,anBgwDY,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MmB/vDR,cAAc,uBnB+vDO,OmB/vDmB,kBAA1B,a;MnB+vDN,U;MAAA,SAAa,OmB9vDd,QnB8vDC,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;QmB9vD4C,4BAAe,uBnB8vD9C,SmB9vD8C,CAAf,C;;;IAGxD,OAAO,Y;EACX,C;EAGsB,gE;IAClB,oC;InBw8CG,kBAAM,iBAAa,wBmBp8CS,cnBo8CT,EAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,OmB3gDsB,cnB2gDtB,W;IAAb,OAAa,cAAb,C;MAAa,sB;MACT,WAAY,WmB5gDwC,uDnB4gD1B,ImB5gD0B,CnB4gDxC,C;;ImB5gDZ,0BnB6gDG,W;;;;SmB1gDC,Y;MAAQ,wBAAa,uBAAW,KAAxB,EAA8B,uBAAW,OAAzC,C;;;6DAEZ,qB;IAC+C,gBAAvB,0B;IACA,Q;IAAA,yC;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MACZ,aAAa,OAAQ,0B;MACrB,IAAI,cAAJ,C;QLGhB,SKFoB,yBAAgB,MAAhB,Y;;IAJZ,oBLOD,S;IKCC,OAAO,aAAc,O;EACzB,C;0DAEA,qB;IACI,OAAO,uBAAW,kBAAS,SAAT,C;EACtB,C;EAEqC,uE;IAArC,oB;IAAoE,oCAAyB,OAAzB,C;;wFAEhE,iB;IACI,OAAO,KAAM,kBAAS,8BAAW,OAApB,C;EACjB,C;sFAEA,iB;IACI,OAAO,KAAM,aAAI,8BAAW,OAAf,C;EACjB,C;yFAEA,oB;IACI,OAAO,Q;EACX,C;;;;;;;;;;;;;;;;EChFZ,oB;IAAA,wB;;EAE+B,4D;IAAA,8B;IAInB,4BACW,KAAK,oEAAL,C;;;;SAHP,Y;MAAQ,uB;;;;;SAEZ,Y;aCcgF,+B;;;EDbhE,8E;IAAA,mB;MACJ,UAAU,YAAK,oBAAW,WAAI,SAAf,C;MAAf,OACA,GAAI,K;IACR,C;;;;;;8CAThB,sB;IACI,OAAO,KAAM,kE;EAUjB,C;0DAEA,sB;IAGI,cAAc,yBAAqB,oBAAW,GAAX,CAAgB,Q;IAEnD,+BACI,oDAA6C,KAA7C,EAAoD,GAApD,EAAyD,OAAzD,C;eAEA,iDAA0C,KAA1C,EAAiD,GAAjD,EAAsD,OAAtD,C;IADJ,IAAK,yCAAL;MAA4B,yC;IAG5B,aAAa,wBAAyB,M;IACtC,IAAI,UAAU,IAAd,C;MACI,SAAS,qB;WACN,IAAI,yBAAyB,IAA7B,C;MACH,SAAS,MAAO,cAAK,qBAAL,C;KAGpB,aAAa,wBAAyB,O;IACtC,IAAI,UAAU,IAAd,C;MACI,SAAS,qB;WACN,IAAI,yBAAyB,IAA7B,C;MACH,SAAS,MAAO,cAAK,qBAAL,C;KAGpB,OAAO,SAAK,MAAL,EAAa,MAAb,C;EACX,C;uCAEA,+B;IAEgB,UAGK,M;IAJjB,aAAmC,I;IACvB,yB;IAAZ,OAAY,cAAZ,C;MAAY,qB;MACR,YAAY,UAAW,eAAM,GAAN,C;MACvB,IAAI,SAAS,IAAb,C;QACI,SAAS,+CAAa,KAAb,6BAAuB,K;;IAGxC,OAAO,M;EACX,C;sEAEA,+B;IAuBc,UAEO,MAFP,EAIW,M;IAxBrB,cAAc,iBAAU,gBAAO,aAAI,yBAAgB,KAAM,cAAtB,CAAX,C;IACxB,cAAc,iBAAU,gBAAO,aAAI,yBAAgB,KAAM,cAAtB,CAAX,C;IAExB,UAAU,4BAAe,KAAf,EAAsB,GAAtB,C;IACV,IAAI,GAAI,WAAR,C;MAEI,aAAa,qBAAc,OAAd,EAAuB,GAAvB,C;MACb,aAAa,qBAAc,OAAd,EAAuB,GAAvB,C;MACb,OAAO,SAAK,MAAL,EAAa,MAAb,C;KAGX,mBAAmB,G;IACnB,mBAAmB,G;IACnB,mBAAmB,G;IACnB,mBAAmB,G;IACnB,mBAAmB,K;IAEnB,kBAAkB,mBAAQ,KAAR,EAAe,OAAQ,KAAvB,C;IAClB,SAAS,gBAAqB,WAArB,O;IACT,SAAS,gBAAqB,WAArB,O;IACC,UAAI,aAAJ,W;IAAV,OAAU,cAAV,C;MAAU,mB;MACN,QAAQ,E;MACK,2B;MAAb,OAAa,gBAAb,C;QAAa,wB;QACT,WAAW,CAAE,iBAAQ,IAAR,C;QACA,2B;QAAb,OAAa,gBAAb,C;UAAa,wB;UACT,WAAW,CAAE,iBAAQ,IAAR,C;UACb,a;UACA,GAAG,CAAH,IAAQ,I;UACR,GAAG,CAAH,IAAQ,I;;;MAIhB,OAAO,KAAK,CAAZ,C;QACI,IAAI,GAAG,CAAH,aAAiB,GAAG,CAAH,SAArB,C;UACI,QAAQ,GAAG,CAAH,C;UACR,QAAQ,GAAG,CAAH,C;UACR,IAAI,mCAAS,CAAT,KAAe,mCAAS,CAAT,CAAnB,C;YACI,aAAa,GAAI,mBAAU,iBAAa,gBAAb,EAAkB,gBAAlB,CAAV,EAAkC,CAAlC,EAAqC,OAArC,C;YACjB,gBAAgB,MAAO,E;YACvB,gBAAgB,MAAO,E;YACvB,IAAI,YAAJ,C;cACmB,QAAe,Y;cAA9B,elB4PiC,MAAW,KkB5PzB,SlB4PyB,EAAO,CAAP,C;ckB3P7B,UAAe,Y;cAA9B,elBoQiC,MAAW,KkBpQzB,SlBoQyB,EAAO,GAAP,C;ckBnQ7B,UAAe,Y;cAA9B,elB0PiC,MAAW,KkB1PzB,SlB0PyB,EAAO,GAAP,C;ckBzP7B,UAAe,Y;cAA9B,elBkQiC,MAAW,KkBlQzB,SlBkQyB,EAAO,GAAP,C;;ckBhQ5C,eAAe,S;cACf,eAAe,Y;cACf,eAAe,S;cACf,eAAe,Y;cACf,eAAe,I;;YAI3B,a;;;IAKR,aAAiB,YAAJ,GACT,gBAAY,YAAZ,EAA0B,YAA1B,CADS,GAGT,I;IAEJ,aAAiB,YAAJ,GACT,gBAAY,YAAZ,EAA0B,YAA1B,CADS,GAGT,I;IACJ,OAAO,SAAK,MAAL,EAAa,MAAb,C;EACX,C;mEAEA,sC;IAKI,kBAAkB,KAAM,c;IACxB,qBAAqB,WAAY,gBAAS,aAAI,MAAb,C;IACjC,qBAAqB,WAAY,gBAAS,aAAI,OAAb,C;IACjC,aAAiB,cAAJ,GACT,8CACI,aAAI,EADR,EAEI,aAAI,MAFR,EAGI,UAHJ,EAII,OAJJ,CADS,GAQT,I;IACJ,aAAiB,cAAJ,GACT,8CACI,aAAI,EADR,EAEI,aAAI,OAFR,EAGI,UAHJ,EAII,OAJJ,CADS,GAQT,I;IAEJ,OAAO,SAAK,MAAL,EAAa,MAAb,C;EACX,C;gEAEA,qD;IASiC,Q;IAN7B,gBAAgB,UAAW,uBAAc,WAAd,CAA2B,W;IACtD,YAAY,UAAW,uBAAc,OAAd,CAAuB,W;IAE9C,iBAAiB,OAAQ,uBAAc,WAAd,C;IACzB,aAAa,kBAAc,wCAAO,kBAArB,EAAwC,wCAAO,kBAA/C,E;IAEgB,OAAX,UAAW,iB;IAA7B,aAAU,CAAV,gB;MACI,IAAI,CAAC,SAAU,UAAf,C;QACI,MAAM,2BAAsB,6BAA0B,CAA1B,aAAiC,WAAvD,C;OAEV,IAAI,CAAC,KAAM,UAAX,C;QACI,MAAM,2BAAsB,6BAA0B,CAA1B,aAAiC,OAAvD,C;OAEV,UAAU,SAAU,O;MACpB,WAAW,KAAM,O;MACjB,IAAI,mCAAS,GAAT,KAAiB,mCAAS,IAAT,CAArB,C;QACI,aAAa,cAAc,sBAAS,CAAvB,C;QACb,4BAAqB,kBAArB,EAA4B,MAA5B,EAAoC,MAApC,C;;IAIR,OAAW,OAAO,CAAP,KAAa,OAAO,CAAP,CAAjB,GACH,gBAAY,OAAO,CAAP,CAAZ,EAAuB,OAAO,CAAP,CAAvB,CADG,GAGH,I;EACR,C;8CAEA,yC;IACwB,QAAI,QAAQ,M;IAAZ,QAAoB,eAAe,CAAf,C;IAAxC,eAAe,CAAf,IlBiKqD,MAAW,KAAI,CAAJ,EAAO,CAAP,C;IkBhK5C,UAAI,QAAQ,M;IAAZ,UAAoB,eAAe,CAAf,C;IAAxC,eAAe,CAAf,IlByKqD,MAAW,KAAI,GAAJ,EAAO,GAAP,C;EkBxKpE,C;2DAEA,iB;IAEgB,UAIc,MAJd,EAIc,M;IAL1B,wBAAwB,c;IACZ,YAAM,cAAN,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MACR,IAAI,GAAI,UAAR,C;QAGsB,+D;QAAlB,YAAwC,aAAQ,S;QAAhD,iBjB2BZ,qBAAS,KAAT,C;;IiBvBI,cAAc,0CAA6B,KAA7B,EAAoC,iBAApC,C;IACd,OAAO,mCAAsB,KAAtB,EAA6B,OAA7B,EAAsC,UAAtC,C;EACX,C;4DAEA,uC;IAMgB,Q;IADZ,cAAc,eAAmC,oBAAnC,C;IACF,YAAM,cAAN,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MjBMa,U;MiBLrB,ajBKwC,CAAnB,uBiBLc,oBjBKd,4BAAmB,YiBLgB,GjBKhB,C;MiBJxC,IAAI,cAAJ,C;QAEI,IAAI,aAAI,uBAAc,GAAd,CAAR,C;UACI,SAAS,+BAAqB,aAAI,EAAzB,C;eACN,IAAI,aAAI,uBAAc,GAAd,CAAR,C;UACH,SAAS,+BAAqB,aAAI,EAAzB,C;UAGjB,IAAI,kBAAkB,KAAM,oBAAW,GAAX,CAA5B,C;QACI,SAAS,KAAM,SAAN,aAAe,GAAf,CAAoB,O;OAGjC,IAAI,cAAJ,C;QACI,YAAe,M;QAAf,OjBFZ,aiBEoB,GjBFpB,EAAS,KAAT,C;;IiBKI,OAAO,O;EACX,C;qDAEA,uD;IAQ0B,UAClB,MADkB,EAWV,MAXU,EAoBV,MApBU,EAsBR,M;IAxBd,iBAAiB,uB;IACjB,UAAW,eAAM,KAAM,MAAZ,C;IACW,4BjB2G0D,QAAQ,W;IiB3GxF,OAAsB,cAAtB,C;MAAsB,wB;MAAhB,UjB8BsD,U;MiB9BjD,ajB2CiD,Y;MiB1CxD,sCAAc,GAAd,W;QAEQ,kB;QADJ,YAAY,gBACR,wBAAc,eAAd,qCADQ,EAER,wBAAc,eAAd,qCAFQ,C;QAID,qCAAkB,KAAlB,C;;IAInB,6BAA6B,K;IACjB,cAAM,cAAN,W;IAAZ,OAAY,gBAAZ,C;MAAY,yB;MACR,IAAI,aAAI,sBAAa,KAAb,CAAJ,IAAyB,KAAM,qBAAY,KAAZ,CAAnC,C;QACI,yBAAyB,I;QACzB,K;;IAIR,aAAW,KAAM,U;IACjB,yBAA2B,IAA3B,C;IACY,cAAM,cAAN,W;IAAZ,OAAY,gBAAZ,C;MAAY,yB;MACR,YACU,wD;MAEV,mBAAmB,wBAAc,KAAd,C;MACnB,IAAI,KAAM,qBAAY,KAAZ,CAAV,C;QAEI,QAAQ,KAAM,qBAAY,KAAZ,C;QACd,UAAW,qBAAY,KAAZ,EAAiB,kBAAW,KAAX,EAAgB,CAAhB,EAAmB,YAAnB,CAAjB,C;;QAGX,IAAI,KAAM,oBAAW,KAAX,CAAV,C;UnBvMZ,IAAI,EmBwMkB,oBnBxMlB,CAAJ,C;YACI,cmBuM0C,gD;YnBtM1C,MAAM,2BAAsB,OAAQ,WAA9B,C;WmByMM,mBAAmB,kBAAc,yBAAgB,KAAhB,C;UnB3MjD,IAAI,CmB4MkB,MAAK,aAAI,YAAJ,CnB5M3B,C;YACI,gBmB2M4C,2D;YnB1M5C,MAAM,2BAAsB,SAAQ,WAA9B,C;WmB2MM,oBAAoB,MAAK,oBAAW,YAAX,C;UAEzB,IAAI,wBAAJ,C;YACI,mBAAiB,aAAc,K;;YnBhNnD,IAAI,EmBkNsB,qBAAkB,aAAc,KnBlNtD,CAAJ,C;cACI,gBmBkNkB,uBAAW,sBAAX,YAAoC,gBAApC,IAAqD,YAArD,YAAkF,kBAAlF,C;cnBjNlB,MAAM,2BAAsB,SAAQ,WAA9B,C;;UmBoNM,IAAI,qBAAkB,CAAlB,IAAuB,sBAA3B,C;YAEI,UAAW,qBAAY,KAAZ,EAAiB,KAAM,mBAAmB,sBAAa,KAAb,CAA1C,C;;YAEX,sBAAsB,+CAAW,aAAX,EAA0B,YAA1B,C;YACtB,UAAW,aAAI,KAAJ,EAAS,eAAT,C;;;UAIf,UAAQ,KAAM,oBAAW,KAAX,C;UACd,UAAW,qBACP,KADO,EAEP,kBAAW,KAAX,EAAgB,GAAhB,EAAmB,YAAnB,CAFO,C;;;;IAQvB,IAAI,4BAA0B,mBAAiB,CAA/C,C;MACI,UAAW,wBAAe,gBAAf,C;WACR,IAAI,sBAAJ,C;MAEH,UAAW,wBAAe,CAAf,C;KAGf,OAAO,UAAW,Q;EACtB,C;oCAEA,wC;IAEqB,UAAb,MAAa,EADV,M;IAAA,IAAI,GAAI,UAAJ,IAAiB,oBAArB,C;MACH,sBAAa,oDAAb,C;MAAA,mB;QACO,MAAM,8BAAyB,eAAY,SAAZ,sBAAoC,GAA7D,C;OADb,e;;MAEG,kB;IAHP,a;EAIJ,C;+CAEA,qC;IAgBQ,IAAM,IAAN,EAD4C,MAC5C,EAKgB,MALhB,EAMgB,M;IAdpB,IAAI,SAAS,IAAb,C;MAAmB,OAAO,I;IAE1B,aAAa,KAAM,qB;IACnB,aAAa,KAAM,e;IAI6B,IAAI,KAAM,mBAAV,C;MAC5C,uBAAM,OAAN,KAAM,UAAN,0C;;MAEA,a;;IAHJ,gC;IAMA,oBAAoB,iFAAkC,KAAM,SAAxC,6BAAqD,KAAM,S;IAC/E,oBAAoB,iFAAkC,KAAM,SAAxC,6BAAqD,KAAM,S;IAE/E,aAAa,gBAAgB,a;IAC7B,kBAAkB,SAAS,SAAS,M;IACpC,kBAAkB,W;IAClB,IAAI,WAAJ,C;MAEQ,+BAAiB,GAAjB,IACA,kBAAiB,G;MADjB,Y;QAEA,SlBdmC,MAAW,MkBczC,alBdyC,CkBc9C,KlBdmC,MAAW,MkBclB,alBdkB,C;OkBYlD,W;QAII,IAAI,iBAAiB,CAArB,C;UACI,cAAc,G;;UAEd,cAAc,G;;QN7QvB,SMkRuB,gBAAgB,W;INlRvC,gB;IMmRmB,U;IAAlB,kBAAkB,0EAA2B,EAA3B,6BAAkC,E;IACpD,IAAgB,QAAZ,WAAY,CAAhB,C;MADA,eAEU,c;;MAFV,eAII,W;;IALR,qC;INlRG,WM0RuB,gBAAgB,W;IN1RvC,kB;IM2RmB,U;IAAlB,oBAAkB,0EAA2B,IAA3B,6BAAkC,I;IACpD,IAAgB,QAAZ,aAAY,CAAhB,C;MADA,iBAEU,c;;MAFV,iBAII,a;;IALR,uC;IAQA,OAAO,gBAAY,kBAAZ,EAAgC,kBAAhC,C;EACX,C;;;;;;;EA3XJ,gC;IAAA,+B;MAAA,c;KAAA,wB;;;;;;;;;EEZsB,+E;IAMlB,uB;IALA,kC;IACA,sB;IACA,oB;IACA,wB;IACA,oC;;8CAGA,Y;IACI,mB;EACJ,C;4CAEA,Y;IACI,aAAO,eAAM,IAAN,EAAY,mBAAZ,EAA0B,YAA1B,EAAiC,cAAjC,EAA0C,oBAA1C,C;EACX,C;;;;;;ECfY,mC;IACZ,wB;IACA,c;;kCAEA,Y;IAA0B,gCAAuB,aAAvB,cAAwC,Q;;gCAElE,iB;cAII,M;IAHA,IAAI,SAAS,KAAb,C;MAAoB,OAAO,I;IAC3B,IAAI,iBAAiB,qGAAe,KAAf,UAArB,C;MAAkD,OAAO,K;IAEzD,+D;IAEA,IAAI,uBAAY,KAAM,SAAlB,CAAJ,C;MAAgC,OAAO,K;IACvC,IAAI,kBAAO,KAAM,IAAb,CAAJ,C;MAAsB,OAAO,K;IAE7B,OAAO,I;EACX,C;kCAEA,Y;IACI,aAAsB,SAAT,aAAS,C;IACtB,SAAS,MAAK,MAAL,QAAkB,SAAJ,QAAI,CAAlB,I;IACT,OAAO,M;EACX,C;;;;;;ECdmB,yE;IA0CnB,yC;IAzCA,gC;IACA,4C;IACA,oB;IACA,oB;IAGA,yBAAgD,I;;EAsBrC,4E;IAAA,gC;IAAS,8B;;6EACZ,Y;IACI,QAAQ,sBAAkB,iBAAlB,C;IACR,UAAU,yD;IACV,OAAO,C;EACX,C;;;;;+CAzBR,Y;IACI,YAAY,Y;IACZ,IAAI,CAAC,KAAM,YAAX,C;MACI,QAAQ,sBAAgB,oBAAW,KAAX,EAAkB,wBAAlB,EAAqC,CAArC,C;KAG5B,kBAAkB,KAAM,iB;IACxB,IAAI,WAAY,QAAhB,C;MACI,OAAO,qCAAc,M;KAGzB,WAAW,qEACP,kBADO,EAEP,wBAFO,EAGP,WAHO,EAIP,KAJO,EAKP,YALO,EAMP,sBANO,C;IASX,gEAA8B,IAAK,KAAnC,C;EAOJ,C;mDAEA,mB;IACI,yBAAkB,O;EACtB,C;EAEA,uC;IAAA,2C;IACI,uBAAwE,gD;;qEAExE,mE;IAMI,uB;MAAA,UAA4B,I;IAkBf,UAUE,M;IAzBf,sBAAsB,iCAAoB,yBAAgB,KAAhB,C;IAC1C,iBAA0B,4D;IAE1B,YAAY,sC;IACZ,aAAa,uC;IACb,cAAc,6CAAsB,yBAAgB,UAAhB,EAA4B,KAA5B,C;IACpC,IAAI,aAAJ,C;MACI,UAAU,iBAAa,KAAb,EAAoB,OAAQ,EAA5B,C;KAEd,IAAI,cAAJ,C;MACI,UAAU,iBAAa,OAAQ,EAArB,EAAwB,MAAxB,C;KAGd,cAAc,CAAC,U;IAGX,e;MAAsC,OAAxB,+CAAwB,oBAAW,KAAX,EAAkB,iBAAlB,EAAqC,MAArC,EAA6C,OAA7C,EAAsD,OAAtD,C;;MACN,OAAxB,+CAAwB,kBAAS,KAAT,EAAgB,iBAAhB,EAAmC,MAAnC,EAA2C,OAA3C,EAAoD,OAApD,C;IAFpC,iB;IAKA,OAAO,0BACH,KADG,EAEH,iBAFG,EAGH,MAHG,EAIH,KAJG,EAKQ,wEAAqB,EAL7B,EAMH,KANG,EAOH,MAPG,EAQH,OARG,C;EAUX,C;;;;;;;EA1CJ,mD;IAAA,kD;MAAA,iC;KAAA,2C;;;;;;;ECrDJ,2B;IAAwB,uB;IACpB,aAAqB,I;IACrB,cAAsB,I;IACtB,gBAAqB,I;;;;;;;;ICMrB,sBAAwC,I;IACxC,4BAAkE,I;IAClE,+BACI,6B;;oDASJ,sB;IACI,sBAAe,U;IACf,OAAO,I;EACX,C;yDAEA,4B;IACI,4BAAqB,gB;IACrB,OAAO,I;EACX,C;4DAEA,+B;IACI,+BAAwB,mB;IACxB,OAAO,I;EACX,C;uCAEA,Y;IACI,OAAO,qCAAc,IAAd,C;EACX,C;EAG2B,6C;IAEvB,oBAAmB,CAAE,e;IACrB,0BAAyB,CAAE,qB;IAC3B,iCAA+B,CAAE,wB;;;;SAAjC,Y;MAAA,qC;;;qEAEA,e;IACI,iBAAiB,G;IACjB,IAAI,yBAAJ,C;MACI,aAAa,iBAAa,oBAAW,GAAX,EAAgB,GAAhB,C;KAE9B,IAAI,cAAc,iBAAW,KAA7B,C;MACI,aAAa,+BAAkB,GAAlB,C;KAGjB,OAAO,U;EACX,C;yEAEA,e;IACiB,kBACN,M;IADP,aAAa,oEAAwB,GAAxB,6BAAgC,aAAQ,S;IACrD,OAAO,wBAAO,GAAP,qC;EACX,C;0EAEA,2B;IACI,OAAO,yBACF,oBAAW,iBAAX,CACA,yBAAiB,uBAAjB,CACA,4BAAoB,eAApB,CACA,Q;EACT,C;oDAEA,Y;IACI,OAAO,0BAAmB,IAAnB,C;EACX,C;;;;;;;;;;;EA5DJ,wC;IAAA,4D;IANJ,8B;IAMI,Y;;EAEA,+C;IAAA,4D;IARJ,8B;IASQ,uBAAe,GAAI,a;IACnB,6BAAqB,GAAI,mB;IAF7B,Y;;ECOJ,4B;IAqOI,wC;IApOA,oBAAyB,gB;IACzB,yBAA8B,qB;IAC9B,6C;IACA,2D;IACA,6D;IACA,2BAAyC,I;IACzC,yBAAuC,I;IACvC,8BAAmC,c;IAEnC,4BAA6E,I;IAC7E,6BAA8C,sCAAW,K;IACzD,qCAAqE,iDAA0B,K;IAE/F,4BAA0C,K;;;;SAX1C,Y;;;MAAA,4B;;SAAA,kB;MAAA,8B;;;;;SACA,Y;;;MAAA,mC;;SAAA,yB;MAAA,4C;;;;;SACA,Y;;;MAAA,oC;;SAAA,0B;MAAA,8C;;;4CAWA,a;IACI,gBAAS,C;IACT,OAAO,I;EACX,C;2CAEA,a;IACI,uBAAgB,C;IAChB,OAAO,I;EACX,C;4CAEA,a;IACI,wBAAiB,C;IACjB,OAAO,I;EACX,C;kDAEA,a;IACI,iBAAW,WAAI,CAAJ,C;IACX,OAAO,I;EACX,C;mDAEA,a;IACI,2BAAoB,CAAE,K;IACtB,OAAO,I;EACX,C;uDAEA,a;IACI,2BAAoB,C;IACpB,OAAO,I;EACX,C;qDAEA,a;IACI,yBAAkB,C;IAClB,OAAO,I;EACX,C;sDAEA,kB;IACI,sBAAgB,aAAI,GAAJ,EAAS,CAAT,C;IAChB,OAAO,I;EACX,C;wDAEA,8B;IACI,2BxBgKJ,awBhKyB,GxBgKzB,EwBhKgC,axBgKhC,C;IwB/JI,OAAO,I;EACX,C;yDAEA,a;IACI,6BAAsB,C;IACtB,OAAO,I;EACX,C;iEAEA,a;IACI,qCAA8B,C;IAC9B,OAAO,I;EACX,C;qDAEA,a;IACI,4BAAqB,C;IACrB,OAAO,I;EACX,C;4CAEA,4B;IAyBoB,UAWA,M;IAnChB,aACW,M;IACX,IAAI,iCAAJ,C;MACI,SAAO,yCAAqB,MAArB,EAA2B,QAA3B,C;KAIX,SAAO,4BAAe,4BAAmB,MAAnB,EAAyB,iBAAzB,EAAqC,QAArC,C;IAKP,gBAAX,iB;I3Bm5CD,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,6B;IAAb,OAAa,gBAAb,C;MAAa,wB;mBACT,W;M2B19CkB,kB;MAAP,S3B09Ce,I2B19Cf,I;MAAO,I3B09CQ,I2B19CD,SAAS,SAAhB,C;QACN,mBAAmB,kBAAc,yB3By9CnB,I2Bz9CsC,IAAnB,C;QACjC,wBAAW,YAAX,E3Bw9Cc,I2Bx9Cc,IAA5B,C;;QAEA,S3Bs9Cc,I;;MAAd,YAAZ,WAAY,E2B19CJ,kB3B09CI,C;;I2B99CZ,0BAA0B,eAUpB,M3Bq9CH,W2Br9CG,CAVoB,C;IAc1B,oBAAoB,gB;IACJ,0BAAoB,OAApB,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MACZ,eAAe,OAAQ,S;MACvB,IAAI,QAAS,OAAb,C;QACI,UAAU,OAAQ,I;QAClB,YAAY,qBAAS,GAAT,C;QACZ,SAAO,kBAAc,wBAAe,MAAf,EAAqB,QAArB,EAA+B,GAA/B,EAAoC,KAApC,C;QACrB,aAAc,WAAI,eAAW,iBAAa,gBAAO,GAAP,CAAxB,EAAqC,GAArC,CAAJ,C;;IAKN,iC;IAAhB,OAAgB,gBAAhB,C;MAAgB,6B;MACZ,UAAoB,SAAQ,I;MAA5B,mBxBwGR,aAAI,GAAJ,EwBxG2C,SxBwG3C,C;;IwBlGI,iBAAiB,oBAAgB,MAAhB,EAAsB,mBAAtB,EAA2C,QAA3C,C;IAEjB,OAAO,iCACH,MADG,EAEH,qBAFG,EAGH,oBAHG,EAIH,qBAAe,UAJZ,EAKoF,CAAvF,oBAAgB,MAAhB,EAAsB,iBAAtB,EAAkC,wBAAlC,EAAqD,sBAArD,EAAsE,sBAAtE,CAAuF,aALpF,EAMH,mBAAoB,OANjB,EAOH,sBAPG,EAQH,QARG,EASH,UATG,EAUH,0BAVG,EAWH,kCAA4B,iCAAwB,UAAxB,EAAoC,MAApC,CAXzB,EAYH,yBAZG,C;EAcX,C;+CAEA,Y;IACI,OAAO,qBAAe,gBAAf,IAAkC,oBAAc,gB;EAC3D,C;EAGyB,4M;IACrB,oC;IAEA,oC;IAEA,4B;IAGA,kC;IACA,sC;IACA,oD;IACA,oD;IACA,kD;IAGA,sBAA0B,YAAa,a;IACvC,0BAAkC,YAAa,S;IAC/C,wC;IAEA,2B;IACA,6B;IACA,4BAAiC,c;IAejB,UAIO,M;IAVnB,uBAAgB,iBAAU,WAAV,C;IAGhB,oCAAqB,YAAa,qB;IAClC,yBAAkB,qB;IAEN,oBAAc,cAAd,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MACR,sBAAgB,aAAI,GAAJ,EAAS,0BAAc,GAAd,CAAT,C;;IAGD,+B;IAAnB,OAAmB,gBAAnB,C;MAAmB,8B;MACf,yC;MAAA,YAAmB,UAAW,I;MxBkC1C,sBAAI,KAAJ,EwBlCiD,UxBkCjD,C;;;;SwB1EI,Y;MAAA,+B;;;;SAIA,Y;MAAA,2B;;;;SAGA,Y;MAAA,8B;;;;SACA,Y;MAAA,gC;;;;SACA,Y;MAAA,uC;;;;SACA,Y;MAAA,uC;;;;SACA,Y;MAAA,sC;;;;;SAGA,Y;MAAA,0B;;;;;SACA,Y;MAAA,8B;;;;;SACA,Y;MAAA,wC;;;;;SAOI,Y;MAAQ,gBAAK,wB;;;;;SAGb,Y;MAAQ,4C;;;uDAkBZ,Y;IACI,OAAO,oB;EACX,C;6DAEA,e;IACI,OAAO,oBAAc,mBAAU,GAAV,C;EACzB,C;8DAEA,e;IACI,OAAO,yBAAmB,mBAAY,GAAZ,C;EAC9B,C;8DAEA,e;IACI,OAAO,kDAAmB,GAAnB,E;EACX,C;+DAEA,e;IACI,OAAO,sBAAgB,qBAAY,GAAZ,C;EAC3B,C;+DAEA,e;I1B1MJ,IAAI,C0B2MY,yBAAY,GAAZ,C1B3MhB,C;MACI,c0B0MgC,8C;M1BzMhC,MAAM,8BAAyB,OAAQ,WAAjC,C;K0B0MF,OAAO,mCAAgB,GAAhB,C;EACX,C;8DAEA,e;IACI,OAAO,uBAAmB,sBAAa,GAAb,C;EAC9B,C;qEAEA,e;IACI,OAAO,uBAAmB,2BAAkB,GAAlB,C;EAC9B,C;sEAEA,2B;IACI,IAAI,qCAAJ,C;MACI,SAAK,4BAAmB,eAAnB,C;;MAEL,MAAM,2BAAsB,kBAA8B,+BAAZ,SAAY,YAApD,C;;EAEd,C;;;;;;EAGJ,sC;IAAA,0C;;EAIqC,wE;IAAA,iC;MACzB,sBAAsB,4BAAe,4BAAmB,IAAnB,EAAyB,eAAQ,aAAjC,EAA6C,QAA7C,C;MAC/B,aAAW,eAAQ,S;MACrB,6BAAM,SAAN,E;QAFJ,OAEsB,e;;QAEd,cAAc,sBAAkB,eAAlB,C;QACd,sBACI,oBACI,eADJ,EAEI,eAAQ,aAFZ,EAGI,eAAQ,oBAHZ,EAII,eAAQ,kBAJZ,EAKI,IALJ,C;QAOJ,6BAA6B,4BAAe,uBACxC,eADwC,EAExC,MAFwC,EAGxC,eAAQ,aAHgC,EAIxC,QAJwC,EAKxC,eALwC,EAMxC,kCAAW,YAN6B,EAOxC,OAPwC,EAQnB,WARmB,EASzB,WATyB,EAUnB,IAVmB,4BAWxC,c;;SAXwC,E;QAbpD,OA2BQ,sBAAuB,K;;IAGnC,C;;qDAjCJ,Y;IACI,cAAc,sB;IACd,+BAA6B,sD;IAiC7B,OAAO,O;EACX,C;;;;;;;EAtCJ,kD;IAAA,iD;MAAA,gC;KAAA,0C;;;;;;;EC1PJ,wB;IAII,oC;IAFA,iBAAyB,K;;EAEzB,kC;IAAA,sC;IAMI,2D;;EAAyB,qD;IAAS,uB;;;;;;;;;;;;EANtC,8C;IAAA,6C;MAAA,4B;KAAA,sC;;;;;;;;;;;;;;;;;;;;;ECWiB,8D;IA2HjB,uC;IA1HA,gC;IACA,wC;IACA,oB;IAGA,sBAA2B,gB;;+CAE3B,0G;IASI,mBAAa,WACT,gCACI,UADJ,EAEI,WAFJ,EAGI,aAHJ,EAII,kBAJJ,EAKI,UALJ,EAMI,sBANJ,CADS,C;EAUjB,C;EA6CW,wE;IAAA,gC;IAAS,8B;;yEACZ,Y;IACI,QAAQ,oBAAgB,iBAAhB,C;IACR,UAAU,uD;IACV,OAAO,C;EACX,C;;;;;2CAhDR,Y;IAEwB,UAGF,MAHE,EAUA,MAVA,EAwBA,MAxBA,EA0BJ,MA1BI,EA4Bc,M;IA7BlC,0BAA0B,oB;IACN,qC;IAApB,OAAoB,cAApB,C;MAAoB,6B;MAChB,wBAAwB,WAAY,0B;MACpC,iBAAiB,WAAY,sBAAc,aAAa,W;MAC1C,oBAAY,kBAAZ,W;MAAd,OAAc,gBAAd,C;QAAc,yB;Q1BySf,U;QADP,Y0BvSY,mB1BuSA,W0BvS6B,K1BuS7B,C;QACL,IAAI,aAAJ,C;UACH,a0BzS8C,sB;UAAtC,mB1B0SR,a0B1SqC,K1B0SrC,EAAS,MAAT,C;UACA,e;;UAEA,c;;QALJ,M0BvSiB,kBAAS,UAAW,OAApB,EAA4B,iBAA5B,C;;;IAIb,mBAAmB,gB;IACC,4BAAoB,OAApB,W;IAApB,OAAoB,gBAApB,C;MAAoB,+B;MAChB,IAAI,WAAY,QAAhB,C;QACI,Q;OAEJ,YAAa,WAAI,WAAJ,C;;IAIjB,IAAI,YAAa,UAAjB,C;MACI,OAAO,qCAAc,M;KAIzB,wBAAwB,gB;IACJ,uC;IAApB,OAAoB,gBAApB,C;MAAoB,iC;MAChB,cAAc,aAAY,gB;MACd,2B;MAAZ,OAAY,gBAAZ,C;QAAY,uB;QACR,IAAI,+CAAgB,GAAhB,iBAAJ,C;UACI,iBAAkB,WAAI,wDAAgB,GAAhB,uCAAJ,C;;;IAK9B,WACI,iEACI,kBADJ,EACiB,YADjB,EAC+B,YAD/B,EAEI,qCAAc,iBACV,iBADU,CAFlB,C;IAOJ,4DAA8B,IAAK,KAAnC,C;EAOJ,C;EAGyB,0I;IACrB,kD;IACA,gC;IACA,oC;IACA,8C;IACA,0B;IAIA,iC;IACA,6B;IAOuB,UAaW,M;IAd9B,uBAAuB,oB;IACJ,oC;IAAnB,OAAmB,cAAnB,C;MAAmB,4B;MACf,UAAU,UAAW,I;MACrB,cAAY,4BAAS,GAAT,C;MACZ,IAAI,CAAC,OAAM,YAAX,C;QACI,UAAQ,sBAAgB,oBAAW,OAAX,EAAyC,SAAvB,sBAAuB,EAAS,GAAT,CAAzC,EAAwD,CAAxD,C;O5BhCxC,IAAI,C4BkCc,OAAM,Y5BlCxB,C;QACI,c4BiCmC,yC;Q5BhCnC,MAAM,2BAAsB,OAAQ,WAA9B,C;O4BoCE,kBAAkB,OAAM,iB;MACxB,gBAAgB,eAAU,aAAI,WAAY,kBAAhB,EAAmC,OAAnC,C;MAC1B,aAAa,WAAY,O;MACC,SAAO,IAAP,MAAO,EAAI,SAAJ,CAAP,W;MAA1B,OAA0B,gBAA1B,C;QAA0B,0B;QAArB,IAAC,2BAAD;UAAQ,8B;Q1B2NlB,U;QADP,Y0BzNgB,gB1ByNJ,W0BzN8B,K1ByN9B,C;QACL,IAAI,aAAJ,C;UACH,a0B3N+C,c;UAAnC,gB1B4NZ,a0B5NsC,K1B4NtC,EAAS,MAAT,C;UACA,e;;UAEA,c;;Q0B/NY,gB1B0NhB,M;Q0B1NgB,cAAsD,uB;Q1B8GtE,sB0B9G+D,G1B8G/D,EAAS,OAAT,C;;;I0BzGQ,6BAAgB,0DAAgB,gBAAiB,OAAjC,EAAyC,oBAAzC,EAAwD,yBAAxD,C;IAChB,yBAAY,iBAAU,gBAAiB,KAA3B,C;;;;SAxBZ,Y;MAAoB,gBAAZ,kB;M7Bm5CT,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;MAuEA,Q;MAAA,2B;MAAb,OAAa,cAAb,C;QAAa,sB;QACT,WAAY,WAAc,I6B39CO,I7B29CrB,C;;M6B39CA,O7B49CT,W;;;;;;;;E6Bh8CP,qC;IAAA,yC;IACI,uBAAwE,gD;;EAWpE,8D;IAEI,aAAa,G;IAET,QAAM,CAAE,EAAF,GAAM,C;IAAZ,W3BkJgC,MAAW,OAAM,CAAN,C2BlJ3C,GAAiB,CAAjB,GAAqB,GAArB,GAA2B,M;IAC3B,UAAM,CAAE,EAAF,GAAM,C;IAFhB,OAAO,uB3BmJ6B,MAAW,OAAM,GAAN,C2BjJ3C,GAAiB,CAAjB,GAAqB,GAArB,GAA2B,MAFxB,C;EAIX,C;iEAhBJ,yC;IAII,uB;MAAA,UAAyB,mB;IAed,UAUI,MAVJ,EAmBI,M;IA/Bf,sBAAsB,iCAAoB,yBAAgB,KAAhB,C;IAE1C,8D;IASA,cAAc,iBAAa,KAAM,UAAnB,EAA8B,KAAM,UAApC,C;IACH,wB;IAAX,OAAW,cAAX,C;MAAW,oB;MACP,qBAAqB,EAAG,e;MACxB,UAAU,OAAQ,aAAI,OAAO,cAAP,CAAJ,C;;IAItB,iBAAiB,MAAO,K;IACxB,Y;IACA,Y;IACA,IAAI,OAAQ,QAAZ,C;MAEQ,WAAQ,cAAR,C;QAAyB,QAAI,OAAQ,S;QAAZ,S3B00BO,MAAW,KAAI,CAAJ,E2B10BI,U3B00BJ,C;a2Bz0B3C,WAAQ,cAAR,C;QAAyB,QAAK,aAAa,OAAiB,S;QAAY,qB3BoHzC,MAAW,MAAK,CAAL,C2BpH8B,C;aACxE,iE;QAAkD,mB;;QAC1C,U;MAJZ,iB;MAMW,UAAK,aAAsB,Q;MAAtC,WAAkD,Y3BgHf,MAAW,MAAK,GAAL,C2BhHI,C;;MAI9C,WAAQ,cAAR,C;QAAyB,UAAI,OAAQ,S;QAAZ,S3Bi0BO,MAAW,KAAI,GAAJ,E2Bj0BI,U3Bi0BJ,C;a2Bh0B3C,WAAQ,cAAR,C;QAAyB,UAAK,aAAa,OAAiB,S;QAAY,qB3B2GzC,MAAW,MAAK,GAAL,C2B3G8B,C;aACxE,iE;QAAkD,mB;;QAC1C,U;MAJZ,iB;MAMW,UAAK,aAAsB,Q;MAAtC,WAAkD,Y3BuGf,MAAW,MAAK,GAAL,C2BvGI,C;;IAGtD,U;IAEA,IAAI,4DAAJ,C;MACI,IAAI,OAAQ,cAAR,KAAyB,OAAQ,cAAR,IAAyB,OAAQ,SAAR,GAAmB,UAArE,CAAJ,C;QACI,SAAS,6CAAsB,4BAC3B,KAD2B,EAE3B,MAF2B,EAG3B,OAH2B,C;;QAM/B,SAAS,6CAAsB,oBAAW,KAAX,EAAkB,MAAlB,EAA0B,OAA1B,C;;;MAGnC,SAAS,6CAAsB,kBAAS,KAAT,EAAgB,MAAhB,EAAwB,OAAxB,C;;IAGnC,kBAAkB,Q;IAClB,kBAAkB,Q;IAClB,qBAAqB,OAAQ,Q;IAE7B,OAAO,wBACH,KADG,EAEH,MAFG,EAGH,KAHG,EAIH,MAJG,EAKO,KALP,C;EAOX,C;;;;;;;EA7EJ,iD;IAAA,gD;MAAA,+B;KAAA,yC;;;;;;;ECpIJ,+B;IAAA,mC;;0DACI,0D;IAIgB,UAEY,MAFZ,EAIA,MAJA,EASA,M;IAVZ,cAAc,sBAAkB,CAAlB,C;IACF,oBAAI,SAAJ,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MAER,OAAQ,qBAAY,sDAAZ,EAA6B,kBAAmB,sBAAa,GAAb,CAAhD,C;;IAEA,oBAAY,KAAZ,W;IAAZ,OAAY,gBAAZ,C;MAAY,yB;MACR,aAAa,oCAAY,KAAZ,E;MACb,OAAQ,aAAI,KAAJ,EAAS,2BAAkB,oBAAW,MAAX,CAA3B,C;MACR,OAAQ,wBAAe,MAAO,KAAtB,C;;IAEA,sBAAc,KAAd,W;IAAZ,OAAY,gBAAZ,C;MAAY,yB;MACR,OAAQ,qBAAe,KAAf,EAAoB,sCAAc,KAAd,EAApB,C;;IAEZ,OAAO,OAAQ,Q;EACnB,C;EAkCqC,qF;IAAA,wB;MAAW,oDAAW,KAAX,YAAkB,WAAlB,E;IAAyB,C;;0DA/BzE,iE;IAMuB,UAEH,MAFG,EAOK,MAPL,EAeH,MAfG,EAuBP,MAvBO,EAyBH,M;IA1BhB,iBAAiB,gB;IACE,oC;IAAnB,OAAmB,cAAnB,C;MAAmB,4B;MACf,gBAAgB,c;MACJ,sBAAI,SAAJ,W;MAAZ,OAAY,gBAAZ,C;QAAY,uB;QACR,YAAiB,gCAAmB,8BAAqB,GAArB,CAAnB,C;QAAjB,S3B0MZ,a2B1MsB,G3B0MtB,EAAS,KAAT,C;;M2BtM4B,sBAAc,KAAd,W;MAApB,OAAoB,gBAApB,C;QAAoB,+B;QAEZ,WADE,WACF,eAAI,MAAJ,YADE,WACF,EACA,aAAI,MADJ,YADE,WACF,EAEA,aAAI,KAFJ,E;UAEY,cAAyB,sCAAc,WAAd,E;UAAzB,S3BkM5B,a2BlMsC,W3BkMtC,EAAS,OAAT,C;;M2B9LoB,mBAAW,KAAX,W;MAAZ,OAAY,gBAAZ,C;QAAY,yB;QACR,cAAiB,mCAAW,KAAX,E;QAAjB,S3B6LZ,a2B7LsB,K3B6LtB,EAAS,OAAT,C;;M2B1LQ,UAAW,WAAI,SAAJ,C;;IAGf,cAAc,sBAAkB,UAAW,KAA7B,C;IACF,sBAAI,SAAJ,W;IAAZ,OAAY,gBAAZ,C;MAAY,yB;MAER,OAAQ,aAAI,wDAAJ,EAAqB,6DAArB,C;;IAEZ,OAAO,OAAQ,Q;EACnB,C;0DAEA,iB;IACI,sBAAsB,KAAM,Y;IAC5B,IAAI,sDAAJ,C;MACI,qBAAqB,KAAM,W;MAC3B,kBACQ,mBAAmB,sCAAe,IAAlC,IAAyC,mBAAmB,sCAAe,OAA/E,oF;KAKR,OAAO,e;EACX,C;;;;;;;EApEJ,2C;IAAA,0C;MAAA,yB;KAAA,mC;;ECNA,yB;IA0BI,qC;IA1BkB,uB;IAElB,oBAA+B,I;IAC/B,oBAA+B,I;IAC/B,eAAuB,K;;;;SAGnB,Y;MAAQ,uC;;SACR,oB;MACI,oB7Bm/BwC,MAAW,K6Bn/BlC,C7Bm/BkC,E6Bn/B/B,Q7Bm/B+B,C;I6Bl/BvD,C;;;;SAGA,Y;MAAQ,uC;;SACR,oB;MACI,oB7B6+BwC,MAAW,K6B7+BlC,C7B6+BkC,E6B7+B/B,Q7B6+B+B,C;I6B5+BvD,C;;wCAEJ,Y;IACI,OAAO,yB;EACX,C;wCAEA,Y;IACI,OAAO,yB;EACX,C;EAEA,mC;IAAA,uC;;sDACI,uB;IAEoB,Q;IADhB,aAAa,mB;IACG,6B;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MACZ,IAAI,OAAQ,QAAZ,C;QACI,iBAAiB,I;OAErB,IAAI,OAAQ,cAAZ,C;QACI,kBAAkB,OAAQ,S;OAE9B,IAAI,OAAQ,cAAZ,C;QACI,kBAAkB,OAAQ,S;;IAGlC,OAAO,M;EACX,C;;;;;;;EAfJ,+C;IAAA,8C;MAAA,6B;KAAA,uC;;;;;;;ECjBgB,2E;IAoIhB,qC;IAnIA,8B;IACA,gC;IACA,wC;IACA,wB;IAGA,4B;IAEA,cAAyB,kCAAW,Y;IACpC,iBAA+B,I;IAC/B,2BAA2D,c;IAC3D,4B;IACA,0BAA+B,I;IAC/B,+BAAoC,I;IAGS,gBAAV,QAAb,iBAAa,C;IAAU,uDAAI,qB;aAAW,mB;KAAf,C;IAAA,c;;MhC0qD7B,Q;MADhB,IAAI,wCAAsB,mBAA1B,C;QAAqC,aAAO,K;QAAP,e;OACrB,2B;MAAhB,OAAgB,cAAhB,C;QAAgB,yB;QAAM,IAAI,UAAU,OAAV,CAAJ,C;UAAwB,aAAO,I;UAAP,e;;MAC9C,aAAO,K;;;IgC3qDH,iC;IACA,uBAAgB,CAAC,oB;;6CAGrB,iB;IACI,iBAAU,K;EACd,C;wCAEA,Y;IACuB,Q;IAAA,mC;IAAnB,OAAmB,cAAnB,C;MAAmB,4B;MACf,IfsLgD,CetL5C,UfsL6C,UetLjD,C;QACI,OAAO,I;;IAGf,OAAO,K;EACX,C;uCAEA,Y;I/BjBA,IAAI,C+BkBQ,kB/BlBZ,C;MACI,c+BiBuB,mB;M/BhBvB,MAAM,8BAAyB,OAAQ,WAAjC,C;K+BkBN,sBAA0B,uBAAJ,GAClB,+BAAkB,uBACd,iBADc,EAEd,wBAFc,EAGd,cAAQ,SAHM,CADA,GAOlB,W;IAGJ,kBAAkB,8BAAW,aAAI,EAAf,C;IAClB,kBAAkB,8BAAW,aAAI,EAAf,C;IAElB,IAAI,oBAAJ,C;MAKI,iBAAiB,+BAAkB,0BAC/B,uBAD+B,EAE/B,WAF+B,C;MAInC,OAAO,oBAAa,WAAb,EAA0B,WAA1B,EAAuC,UAAvC,EAAmD,eAAnD,EAAiF,IAAjF,C;gBAIc,+BAAkB,mCAA0B,iBAA1B,C;IAA3C,IAAK,2BAAL;MAAc,2B;IAEd,e;IACA,e;IACA,IAAI,oBAAJ,C;MACI,cAAc,sCAAe,gBAAO,WAAP,EAAoB,OAApB,EAA6B,OAA7B,EAAsC,sBAAtC,EAAuD,cAAQ,QAA/D,C;MAC7B,cAAc,sCAAe,cAAK,WAAL,EAAkB,OAAlB,EAA2B,OAA3B,EAAoC,sBAApC,EAAqD,cAAQ,QAA7D,C;;MAE7B,cAAc,uCAAgB,gBAAO,OAAP,EAAgB,OAAhB,C;MAC9B,cAAc,uCAAgB,cAAK,OAAL,EAAc,OAAd,C;;IAGlC,mBAAiB,+BAAkB,0BAC/B,qBAAiB,WAAjB,EAA8B,WAA9B,CAD+B,EAE/B,WAF+B,C;IAInC,IAAI,CAAC,oBAAL,C;MACI,YAAW,oBAAW,GAAX,EAAgB,GAAhB,EAAqB,GAArB,EAA0B,GAA1B,C;KAGf,OAAO,oBAAa,WAAb,EAA0B,WAA1B,EAAuC,YAAvC,EAAmD,eAAnD,C;EACX,C;2CAGA,4E;IAKI,0B;MAAA,aAAsB,K;IAUA,UAGF,M;IAVpB,kBAAkB,gBAAY,cAAZ,C;IAClB,WAAY,kBAAS,cAAT,C;IACZ,WAAY,qBAAY,WAAZ,C;IACZ,WAAY,qBAAY,WAAZ,C;IACZ,WAAY,4BAAmB,WAAY,KAA/B,C;IACZ,WAAY,0BAAiB,WAAY,KAA7B,C;IACZ,WAAY,0BAAiB,sBAAjB,C;IACU,gC;IAAtB,OAAsB,cAAtB,C;MAAsB,+B;MAClB,WAAY,0BAAiB,aAAjB,C;;IAEI,qC;IAApB,OAAoB,gBAApB,C;MAAoB,+B;MAChB,WAAY,uBAAc,WAAd,C;;IAGhB,WAAY,uBAAc,UAAd,C;IACZ,WAAY,qBAAY,oBAAZ,C;IACZ,WAAY,6BAAoB,4BAApB,C;IACZ,WAAY,oBAAW,UAAX,C;IACZ,OAAO,WAAY,Q;EACvB,C;uDAEA,2B;IACI,2BAAoB,e;EACxB,C;wCAEA,Y;IACI,uBAAgB,K;EACpB,C;2CAEA,Y;IACI,0BAAmB,K;EACvB,C;gDAEA,Y;IACI,+BAAwB,K;EAC5B,C;EAEA,mC;IAAA,uC;;yDACI,wD;IAMI,mBAAmB,gB;IACnB,YAAa,WAAI,UAAJ,C;IACb,OAAO,uBACH,UADG,EAEH,YAFG,EAGH,aAHG,EAIH,KAJG,C;EAMX,C;wDAEA,0D;IAMI,OAAO,kBAAc,UAAd,EAA0B,YAA1B,EAAwC,aAAxC,EAAuD,KAAvD,C;EACX,C;;;;;;;EAxBJ,+C;IAAA,8C;MAAA,6B;KAAA,uC;;;;;;;EC1HJ,6B;IAAA,iC;;oDAEI,kC;IAKI,cACY,K;IACZ,IAAI,WAAS,IAAb,C;MACI,eAAe,qBAAW,GAAX,C;MACf,IAAI,YAAY,IAAhB,C;QACI,UAAQ,QAAS,cAAK,OAAL,C;OAErB,YAAkB,O;MAAlB,U9B6MR,a8B7MmB,G9B6MnB,EAAS,KAAT,C;K8B3MA,C;8CAEA,2B;IACI,cACY,K;IACZ,IAAI,WAAS,IAAb,C;MACI,IAAI,YAAY,IAAhB,C;QACI,UAAQ,QAAS,cAAK,OAAL,C;OAErB,OAAO,O;KAEX,OAAO,Q;EACX,C;8CAEA,4B;IACI,IAAI,CAAC,iBAAU,iBAAQ,MAAR,CAAf,C;MACI,eAAe,qBAAY,oBAAW,MAAX,C;MAC3B,IAAI,YAAY,IAAhB,C;QACI,WAAW,QAAS,cAAK,QAAL,C;OAExB,OAAO,Q;KAEX,OAAO,Q;EACX,C;sDAEA,iD;IAasB,UAIM,MAJN,EAgBS,MAhBT,EAkBmB,M;IAxBrC,iBAAiB,C;IACjB,IhBsJoD,CgBtJhD,ahBsJiD,UgBtJrD,C;MACI,aAAa,0BAAc,CAAd,CAAiB,K;KAGlC,yBAAyB,gB;IACP,iB;IAAlB,aAAU,CAAV,gB;MACI,oBAAoB,gB;MAGA,iC;MAApB,OAAoB,gBAApB,C;QAAoB,+B;QAChB,aAAc,WAAI,wBAAY,CAAZ,CAAJ,C;;MAGlB,kBAAmB,WACf,uBACI,aADJ,CADe,C;;IAOvB,6BAA6B,c;IACF,sC;IAA3B,OAA2B,gBAA3B,C;MAA2B,sC;MACvB,kCAAkC,0EAA4B,kBAA5B,EAAgD,eAAhD,C;MACD,oC9B8Q2C,QAAQ,W;M8B9QpF,OAAiC,gBAAjC,C;QAAiC,0B;QAA3B,U9BiMkD,U;Q8BjM7C,wB9B8M6C,Y;Q8B7MpD,yBACI,GADJ,EAEI,iBAFJ,EAGI,sBAHJ,C;;;IAQR,OAAO,qBACH,kBADG,EAEH,sBAFG,EAGH,eAHG,EAIH,KAJG,C;EAMX,C;gDAEA,8E;IAU2B,UAEP,MAFO,EAUP,MAVO,EAqBU,MArBV,EA8BM,MA9BN,EA0CD,MA1CC,EAkEH,MAlEG,EAyEH,M;IA5EpB,6BAA6B,oB;IAC7B,+BAA+B,oB;IAER,oC;IAAvB,OAAuB,cAAvB,C;MAAuB,gC;MACnB,yBAAyB,c;MACb,uBAAe,cAAf,W;MAAZ,OAAY,gBAAZ,C;QAAY,uB;QACR,IAAI,cAAe,qBAAY,GAAZ,CAAnB,C;UACI,YAA0B,4BAAe,qBAAY,GAAZ,CAAf,C;UAA1B,kB9BoHhB,a8BpHmC,G9BoHnC,EAAS,KAAT,C;;M8BhHQ,+BAA+B,oB;MAC/B,cAAc,8EAAgC,cAAhC,EAAgD,eAAhD,C;MACF,2B;MAAZ,OAAY,gBAAZ,C;QAAY,yB;QACR,eAAe,K;QACf,cAAc,cAAe,oBAAW,KAAX,C;QAC7B,YAAY,cAAe,kBAAS,KAAT,C;QAC3B,gBAAgB,KAAM,K;QACtB,IAAI,eAAgB,mBAAY,KAAZ,CAApB,C;UACI,mBAAmB,0BAAgB,KAAhB,C;UACnB,IAAI,4CAAJ,C;YACI,gEAAkB,OAAQ,IAA1B,EAA+B,KAA/B,C;YACA,WAAW,I;YACX,iBACiB,0D;YACjB,cAAsC,sEAClC,SADkC,EACvB,OAAQ,IADe,EAElC,sBAFkC,EAEV,UAFU,EAEE,YAFF,EAEgB,KAFhB,C;YAAtC,wB9BkGpB,a8BlG6C,S9BkG7C,EAAS,OAAT,C;kB8B7FmB,IAAI,2DAAa,OAAQ,IAArB,EAA0B,KAA1B,CAAJ,C;UACH,WAAW,I;UACX,mBACiB,0D;UACjB,cAAsC,sEAClC,SADkC,EACvB,OAAQ,IADe,EAElC,sBAFkC,EAEV,YAFU,EAEE,IAFF,EAEQ,KAFR,C;UAAtC,wB9ByFhB,a8BzFyC,S9ByFzC,EAAS,OAAT,C;S8BnFY,IAAI,CAAC,QAAL,C;U9B+LL,U;UADP,c8B7LgB,wB9B6LJ,W8B7LsC,S9B6LtC,C;UACL,IAAI,eAAJ,C;YACH,a8B/L2D,gB;YAA/C,wB9BgMZ,a8BhM8C,S9BgM9C,EAAS,MAAT,C;YACA,e;;YAEA,gB;;UALJ,M8B9L6E,WAAI,OAAJ,C;;MAInD,iCAAyB,KAAzB,W;MAAlB,OAAkB,gBAAlB,C;QAAkB,+B;Q9B0LnB,U;QADP,c8BxLkC,sB9BwLtB,W8BxLsD,W9BwLtD,C;QACL,IAAI,eAAJ,C;UACH,e8BzLY,wD;UADkB,sB9B2L9B,a8B3L8D,W9B2L9D,EAAS,QAAT,C;UACA,iB;;UAEA,gB;;Q8B9LQ,sB9ByLZ,M;Q8BjLY,kBAAkB,iDAAyB,WAAzB,E;QAClB,uBAAuB,cAAe,wB;QACtC,yBAAyB,cAAe,mB;QACxC,eAAgB,kBACZ,gBADY,EAEZ,WAFY,EAGZ,kBAHY,EAIZ,kBAJY,EAKZ,cAAe,cALH,EAMZ,sBANY,C;;;IAWxB,qBAAqB,gB;IACD,iCAAyB,KAAzB,W;IAApB,OAAoB,gBAApB,C;MAAoB,+B;MAChB,cAAc,iDAAyB,WAAzB,EAAwC,iB;MACtD,IAAI,CAAC,OAAQ,QAAb,C;QACI,cAAe,WAAI,OAAJ,C;;IAIH,+BAAuB,KAAvB,W;IAApB,OAAoB,gBAApB,C;MAAoB,iC;MAChB,gBAAc,+CAAuB,aAAvB,EAAsC,e;MACpD,IAAI,CAAC,SAAQ,QAAb,C;QACI,cAAe,WAAI,SAAJ,C;;IAGvB,OAAO,c;EACX,C;yDAEA,8B;IACI,IAAI,CAAC,MAAO,UAAZ,C;MACI,OAAO,yBAAqB,UAArB,C;KAGX,OAAO,wBACH,MADG,EAEH,UAFG,C;EAIX,C;kEAGA,wB;IAGuB,UACD,MADC,EAiBA,MAjBA,EAkBD,M;IAnBlB,kCAAkC,c;IACf,8B;IAAnB,OAAmB,cAAnB,C;MAAmB,4B;MACD,8B;MAAd,OAAc,gBAAd,C;QAAc,yB;QACV,iBAAiB,sBAAS,qCAA4B,KAA5B,C;QAC1B,2B9BoBZ,a8BpBwC,K9BoBxC,E8BpBiD,U9BoBjD,C;;;I8BfI,cAAc,yBAAa,CAAb,C;IACd,eAAe,oBAAQ,CAAR,CAAW,S;IAC1B,aAAa,qBAAS,aAAI,EAAb,C;IACb,aAAa,qBAAS,aAAI,EAAb,C;IACb,oBAA0C,yCAAU,sBAAa,MAAb,C;IACpD,oBAA0C,yCAAU,sBAAa,MAAb,C;IAEpD,oBAA0C,I;IAC1C,oBAA0C,I;IACvB,gC;IAAnB,OAAmB,gBAAnB,C;MAAmB,gC;MACD,gC;MAAd,OAAc,gBAAd,C;QAAc,2B;QAEV,mBAA6C,SAA5B,2BAA4B,EAAS,OAAT,C;QAE7C,eAAe,0DAA2B,OAA3B,EAAkC,YAAlC,C;QAEf,kBAAkB,mBAAY,aAAZ,EAA2B,QAAS,MAApC,C;QAClB,kBAAkB,mBAAY,aAAZ,EAA2B,QAAS,OAApC,C;QAElB,gBAAgB,mBAAY,WAAZ,EAAyB,aAAzB,C;QAChB,gBAAgB,mBAAY,WAAZ,EAAyB,aAAzB,C;;;IAKxB,gBAAgB,yCAAU,qBAAY,aAAZ,EAA2B,aAAI,EAA/B,EAAkC,MAAlC,EAA0C,OAA1C,C;IAC1B,gBAAgB,yCAAU,qBAAY,aAAZ,EAA2B,aAAI,EAA/B,EAAkC,MAAlC,EAA0C,OAA1C,C;IAG1B,gBAAgB,iBAAW,+BAAsB,aAAtB,C;IAC3B,gBAAgB,iBAAW,+BAAsB,aAAtB,C;IAC3B,OAAO,SACH,aADG,EAEH,aAFG,C;EAIX,C;EAEA,uC;IAAA,2C;;+DACI,mB;IACI,mBAAyC,I;IAKzC,IAAI,OAAM,mBAAV,C;;MAE2D,gBAAT,OAA1C,eAAU,kCAAyB,OAAzB,CAAgC,C;MjCqenD,kBAAS,gB;MA2FA,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAAM,IiChkByD,SjCgkB3C,OiChkB2C,CjCgkBzD,C;UAAwB,WAAY,WAAI,OAAJ,C;;MiCjkB9C,eAAe,mBjCkkBpB,WiClkBoB,EAEX,YAFW,C;KAMnB,IAAI,OAAM,YAAV,C;MACI,kBAAkB,OAAM,iB;MACxB,eAAe,8CAEX,WAAY,kBAFD,EAGX,YAHW,C;KAMnB,OAAO,Y;EACX,C;8DAEA,qC;IASsB,IAAN,I;IAHa,c;;MjCi6CjB,U;MADhB,IAAI,ciCh6CsB,MjCg6CtB,iBiCh6CsB,MjCg6CA,UAA1B,C;QAAqC,aAAO,K;QAAP,e;OACrB,SiCj6CU,MjCi6CV,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAAM,IAAc,OiCj6CM,+BjCi6CpB,C;UAAwB,aAAO,I;UAAP,e;;MAC9C,aAAO,K;;;IiCl6CC,4B;IAII,IADc,WACd,U;MAAQ,qDAAY,qBAAY,mBAAU,GAAV,CAAxB,EAAwC,KAAxC,C;SACR,IAFc,WAEd,W;MAAS,Y;;;IAHb,kB;IAMA,OAAO,sBAAS,yBAAgB,OAAhB,EAAuB,KAAvB,EAA8B,WAA9B,C;EACpB,C;;;;;;;EAxCJ,mD;IAAA,kD;MAAA,iC;KAAA,2C;;;;;;;;EAjPJ,yC;IAAA,wC;MAAA,uB;KAAA,iC;;EChBA,sB;IAwBI,kC;;EAAA,gC;IAAA,oC;IACI,qBAA0B,C;IAC1B,qBAAqC,yC;;6CAErC,Y;IACI,OAAO,cAAU,IAAV,EAAgB,IAAhB,EAAsB,WAAtB,EAAwC,WAAxC,EAA0D,CAA1D,EAA6D,CAA7D,C;EACX,C;4DAEA,qC;IAW2B,UAIc,MAJd,EAgBF,M;IArBrB,sBAAsB,mCAAsB,QAAtB,EAAgC,SAAhC,C;IAEtB,0BAA0B,+BAAwB,IAAxB,EAA8B,QAA9B,EAAwC,SAAxC,C;IAE1B,qBAAqB,gB;IACE,iC;IAAvB,OAAuB,cAAvB,C;MAAuB,gC;MACnB,cAA6B,MAAf,cAAe,CAAQ,M;MACrC,eAA8B,MAAf,cAAe,CAAQ,O;MACtC,cAAc,iBAAgD,SAAlB,SAApB,mBAAoB,EAAS,OAAT,CAAkB,EAAS,QAAT,CAAhD,C;MACmB,SAAf,cAAe,K;MAAjC,aAAU,CAAV,kB;QACI,WAAW,2BAAe,CAAf,CAAkB,M;QAC7B,YAAY,2BAAe,CAAf,CAAkB,O;QAC9B,mBAAsD,SAAf,SAApB,mBAAoB,EAAS,IAAT,CAAe,EAAS,KAAT,C;QACtD,OAAQ,mBAAU,aAAQ,YAAR,CAAV,C;;MlC28CjB,kBAAM,iBAAa,wBkCx8CC,clCw8CD,EAAwB,EAAxB,CAAb,C;MAuEA,U;MAAA,SkC/gDc,clC+gDd,W;MAAb,OAAa,gBAAb,C;QAAa,wB;QACT,WAAY,WAAc,IkChhDqB,OlCghDnC,C;;MkChhDJ,elCihDL,W;MkC9gDK,QAAkB,kC;MAClB,gBAAgB,IAAK,Y;MACJ,6B;MAAjB,OAAiB,gBAAjB,C;QAAiB,4B;QACb,aAAa,iBAAK,QAAL,C;QACb,aAAa,iBAAW,uBAAc,MAAd,EAAsB,OAAtB,C;QACxB,CAAE,aAAI,QAAJ,EAAc,MAAd,C;;MAGN,gBAAgB,CAAE,Q;MAClB,cAAe,WAAI,aAAY,SAAZ,CAAJ,C;;IAGnB,OAAO,c;EACX,C;6DAEA,uC;IAMI,0BAA0B,c;IAC1B,S;IAAA,gBAAqB,QAArB,iC;MAAA,yB;MAIkB,YACI,M;MAJlB,aAAa,sBAAU,CAAV,C;MAEb,qBAAqB,c;MACP,0B;MAAd,OAAc,gBAAd,C;QAAc,yB;QAGN,UAAK,QAAL,C;UAAgB,oB;;UAEZ,eAAe,kBAAc,4BAAmB,MAAnB,EAAyB,OAAzB,C;UAClB,SAAX,iBAAW,yBAAgB,mBAAK,QAAL,CAAhB,EAAgC,KAAhC,C;;QALnB,oB;QAQA,c/B+IhB,a+B/I+B,K/B+I/B,E+B/IwC,O/B+IxC,C;;M+B5IY,mB/B4IZ,a+B5IgC,O/B4IhC,E+B5I2C,c/B4I3C,C;;I+BzIQ,OAAO,mB;EACX,C;iEAEA,+B;IjC9EJ,IAAI,CgBgMoD,CiB9GxC,QjB8GyC,UhBhMzD,C;MACI,ciCiFqC,gC;MjChFrC,MAAM,8BAAyB,OAAQ,WAAjC,C;KAFV,IAAI,EiCmFY,QAAS,KAAT,KAA0B,SAAT,QAAS,CAAW,KjCnFjD,CAAJ,C;MACI,gBiCkFyD,2D;MjCjFzD,MAAM,8BAAyB,SAAQ,WAAjC,C;KA0DV,IAAI,EiCwBU,QAAS,KAAT,KAAiB,SAAU,KjCxBrC,CAAJ,C;MACI,gBAdW,e;MAeX,MAAM,2BAAsB,SAAQ,WAA9B,C;KiCuBF,OAAO,mCAA4B,QAA5B,EAAsC,SAAtC,C;EACX,C;iEAEA,+B;IAQkB,UAMS,M;IAVvB,WAAoB,MAAT,QAAS,C;IACpB,aAAuB,MAAV,SAAU,C;IAEvB,gBAAgB,gB;IACF,wB;IAAd,OAAc,cAAd,C;MAAc,uB;MACV,IAAI,QAAS,KAAT,GAAgB,CAApB,C;QACI,cAAc,mCACV,QAAS,iBAAQ,CAAR,EAAW,QAAS,KAApB,CADC,EAEV,SAAU,iBAAQ,CAAR,EAAW,SAAU,KAArB,CAFA,C;QAIC,2B;QAAf,OAAe,gBAAf,C;UAAe,0B;UACX,SAAU,WAAI,YAAO,SAAQ,KAAR,CAAP,GAAwB,MAAxB,CAAJ,C;;;QAId,SAAU,WAAI,OAAO,SAAQ,KAAR,CAAP,CAAJ,C;;;IAIlB,OAAO,S;EACX,C;yDAEA,yC;IAKI,sBAA6C,MAAd,IAAT,QAAS,EAAI,QAAJ,CAAc,C;IAE7C,aAAa,gB;IACb,S;IAAA,gBAAkB,QAAlB,iC;MAAA,sB;MACI,IAAI,KAAK,SAAU,KAAnB,C;QAAyB,K;MACzB,MAAO,WAAI,6BAAiB,IAAjB,EAAuB,sBAAU,CAAV,CAAvB,EAAqD,SAAhB,eAAgB,EAAS,IAAT,CAArD,CAAJ,C;;IAGX,OAAO,M;EACX,C;2DAEA,+B;IASI,UAEO,M;IANP,IAAI,YAAJ,C;MAAkB,OAAO,M;IAIzB,sD;IAGI,YAAQ,CAAR,C;MAAoB,0BAAP,MAAO,C;;MACL,gBAAP,MAAO,C;IAFnB,a;EAIJ,C;EA9IqC,uD;IAAE,SAAG,W;EAAW,C;;;;;;;EAFzD,4C;IAAA,2C;MAAA,0B;KAAA,oC;;EAmJmB,sF;IACf,c;IACA,c;IACA,sB;IACA,oB;IACA,kB;IACA,kB;IACA,0B;;gDAEA,Y;IACI,OAAO,uBAAoB,QAApB,cAA8B,QAA9B,kBAA4C,YAA5C,0BAA6D,WAA7D,O;EACX,C;;;;;;;;;;;EClLR,mC;IAAA,uC;;8EACI,uC;IAagB,Q;IATZ,IAAI,UAAW,iBAAf,C;MAKI,OAAO,W;KAGX,aAAa,gB;IACD,iBAAW,cAAX,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MACR,IAAI,aAAI,uBAAc,GAAd,CAAR,C;QACI,Q;OAEJ,IAAI,UAAW,qBAAY,GAAZ,CAAf,C;QAEI,Q;OAEJ,IAAI,CAAC,UAAW,oBAAW,GAAX,CAAhB,C;QACI,Q;OAEJ,IAAI,eAAgB,mBAAY,GAAZ,CAApB,C;QACI,IAAI,0BAAgB,GAAhB,MAAyB,oCAAa,KAA1C,C;UACI,Q;UAIR,MAAO,WAAI,GAAJ,C;;IAGX,OAAO,M;EACX,C;0EAEA,2C;IAUgB,Q;IANZ,6BAA6B,c;IAC7B,aAAa,6CACT,cADS,EAET,eAFS,C;IAKD,wB;IAAZ,OAAY,cAAZ,C;MAAY,qB;MAER,wBAAwB,cAAe,oBAAW,GAAX,CAAgB,S;MlC8B/D,IAAI,CkC7BU,iBAAkB,YlC6BhC,C;QACI,cAdW,e;QAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;OkC7BF,2BAA2B,cAAe,sBAAa,iBAAb,C;MAC1C,YAAY,cAAe,kBAAS,GAAT,C;MAC3B,IAAI,KAAM,mBAAV,C;QACI,YAA8B,qDAA8C,oBAA9C,EAAoE,KAApE,C;QAA9B,sBhCgLZ,agChLmC,GhCgLnC,EAAS,KAAT,C;agC/Ke,IAAI,wBAAwB,IAA5B,C;QACH,sBhC8KZ,agC9KmC,GhC8KnC,EgC9K0C,oBhC8K1C,C;;IgCzJI,OAAO,sB;EACX,C;sFAEA,yC;IAIuC,IAAN,IAAM,EAIJ,MAJI,EAYpB,MAZoB,EAmBW,MAnBX,EAmBK,M;IAlBpC,IAD+B,oBAC/B,S;MAAQ,kBAAK,wCAAO,IAAZ,EAAiB,wCAAO,IAAxB,C;;MACA,kBAAK,oBAAqB,SAA1B,EAAoC,oBAAqB,SAAzD,C;;IAFZ,IAAK,+BAAL;MAAgB,+B;IAKZ,IADiC,OAAM,kBACvC,U;MAAkB,SAAV,eAAU,kCAAyB,OAAzB,C;;MACV,oBAAK,wCAAO,IAAZ,EAAiB,wCAAO,IAAxB,C;;IAFZ,IAAK,gCAAL;MAAiB,gC;IAKjB,eAA8B,SAAX,UAAW,CAAf,GAA2B,UAA3B,GAA2C,S;IAC1D,eAA8B,SAAX,UAAW,CAAf,GAA2B,UAA3B,GAA2C,S;IAGtD,IAAS,SAAT,QAAS,CAAT,IAAgC,SAAT,QAAS,CAAhC,C;MAA8C,yBAAY,QAAZ,EAAsB,QAAtB,C;SAC9C,IAAS,SAAT,QAAS,CAAT,C;MAAuB,yBAAY,QAAZ,EAAsB,QAAtB,C;SACvB,IAAS,SAAT,QAAS,CAAT,C;MAAuB,yBAAY,QAAZ,EAAsB,QAAtB,C;;MACf,a;IAJZ,qB;IAOwC,uBAAM,SAAN,OAAM,UAAN,4C;IAAxC,OAAO,oDAAuB,QAAvB,S;EACX,C;sEAEA,yE;IASI,wBAAwB,iCAAuB,GAAvB,C;IlCL5B,IkCMiB,iBlCNb,QAAJ,C;MACI,ckCKkC,6C;MlCJlC,MAAM,2BAAsB,OAAQ,WAA9B,C;KkCeN,aAAa,sBACT,SADS,EAGT,iBAHS,EAIT,KAJS,EAKT,KALS,C;IAOb,MAAO,oBAAW,OAAX,C;IACP,OAAO,M;EACX,C;2DAEA,sB;IACI,OAAO,GAAI,QAAJ,IAAe,KAAM,a;EAChC,C;gEAEA,sB;IlChEA,IAAI,CkCiEM,GAAI,QlCjEd,C;MACI,ckCgEqB,sD;MlC/DrB,MAAM,2BAAsB,OAAQ,WAA9B,C;KAFV,IAAI,CkCkEM,KAAM,alClEhB,C;MACI,gBkCiE4B,gF;MlChE5B,MAAM,2BAAsB,SAAQ,WAA9B,C;KkCiEV,C;;;;;;;EAlJJ,+C;IAAA,8C;MAAA,6B;KAAA,uC;;ECJA,uB;IAMI,mC;;EAAA,iC;IAAA,qC;;EAGe,+D;IAAA,8B;IAAS,sB;;yEACZ,e;IACI,OAAO,gB;EACX,C;qEAEA,Y;IACI,OAAO,gBAAI,gB;EACf,C;;;;;iDARR,e;IACI,wD;EASJ,C;EAGW,wD;IAAS,sB;;6EACZ,e;IACI,OAAO,uBAAoB,eAAM,GAAI,WAAV,+D;EAC/B,C;yEAEA,Y;IACI,OAAsC,8C;EAC1C,C;;;;;6CARR,Y;IACI,yD;EASJ,C;EAIW,kE;IAAA,kC;IAAS,sB;;0EACZ,e;IACI,iBAAiB,GAAI,W;IACrB,iBAAiB,GAAI,W;IACrB,OAAO,uBAAoB,eAAM,UAAN,EAAkB,UAAlB,EAA8B,kBAA9B,C;EAC/B,C;sEAEA,Y;IACI,OAAsC,8C;EAC1C,C;;;;;kDAXR,iB;IACU,qB;MAAA,QAAiB,I;IACvB,2D;EAWJ,C;EAGW,oD;IAAS,sB;;yEACZ,e;IACI,OAAO,uBAAoB,cAAK,GAAI,WAAT,C;EAC/B,C;qEAEA,Y;IACI,OAAqC,6C;EACzC,C;;;;;yCARR,Y;IACI,qD;EASJ,C;EAGW,mF;IAAA,kC;IAAA,oC;IAAS,sB;;2EACZ,e;IACI,OAAO,uBAAoB,gBAAO,kBAAP,EAAc,mBAAd,C;EAC/B,C;uEAEA,Y;IACI,OAAuC,+C;EAC3C,C;;;;;mDARR,yB;IACI,oE;EASJ,C;EAGW,kF;IAAA,kC;IAAA,oC;IAAS,sB;;0EACZ,e;IACI,OAAO,uBAAoB,eAAM,kBAAN,EAAa,mBAAb,C;EAC/B,C;sEAEA,Y;IACI,OAAsC,8C;EAC1C,C;;;;;kDARR,yB;IACI,mE;EASJ,C;EASW,mH;IAAA,kC;IAAA,8C;IAAA,gD;IAAS,sB;;gFACZ,e;IACI,iBAAiB,GAAI,W;IACrB,iBAAiB,GAAI,W;IACrB,OAAO,uBAAoB,qBAAY,UAAZ,EAAwB,UAAxB,EAAoC,kBAApC,EAA2C,wBAA3C,EAAwD,yBAAxD,C;EAC/B,C;4EAEA,Y;IACI,OAA6C,qD;EACjD,C;;;;;wDAVR,4C;IACI,4F;EAWJ,C;;;;;;;EA/FJ,6C;IAAA,4C;MAAA,2B;KAAA,qC;;;;;;;ECF6B,oC;IAC7B,sB;IAqBI,kBAAW,iBAAU,MAAV,C;;;;SAlBX,Y;MpC2EJ,IAAI,CgBoIoD,CoB9M1C,epB8M2C,UhBpIzD,C;QACI,cAdW,e;QAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;OoC3EF,OAAO,4BAAS,CAAT,CAAY,wB;IACvB,C;;;;SAGA,Y;MpCqEJ,IAAI,CgBoIoD,CoBxM1C,epBwM2C,UhBpIzD,C;QACI,cAdW,e;QAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;OoCrEF,OAAO,4BAAS,CAAT,CAAY,mB;IACvB,C;;;;SAGA,Y;MpC+DJ,IAAI,CgBoIoD,CoBlM1C,epBkM2C,UhBpIzD,C;QACI,cAdW,e;QAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;OoC/DF,OAAO,4BAAS,CAAT,CAAY,iB;IACvB,C;;6CAMJ,Y;IACW,Q;IAAA,IAAI,eAAS,UAAb,C;MACH,kB;;MACe,OAAZ,4BAAS,CAAT,CAAY,c;IAFnB,W;EAGJ,C;oDAEA,e;IACI,OpBmLoD,CoBnL7C,epBmL8C,UoBnL9C,IAAyB,4BAAS,CAAT,CAAY,oBAAW,GAAX,C;EAChD,C;qDAEA,e;IACI,OpB+KoD,CoB/K7C,epB+K8C,UoB/K9C,IAAyB,4BAAS,CAAT,CAAY,qBAAY,GAAZ,C;EAChD,C;qDAEA,e;IpCwCA,IAAI,CgBoIoD,CoB3K9C,epB2K+C,UhBpIzD,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KoCxCN,OAAO,4BAAS,CAAT,CAAY,qBAAY,GAAZ,C;EACvB,C;oDAEA,e;IpCmCA,IAAI,CgBoIoD,CoBtK9C,epBsK+C,UhBpIzD,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KoCnCN,OAAO,4BAAS,CAAT,CAAY,oBAAW,GAAX,C;EACvB,C;kDAEA,e;IpC8BA,IAAI,CgBoIoD,CoBjK9C,epBiK+C,UhBpIzD,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KoC9BN,OAAO,4BAAS,CAAT,CAAY,SAAZ,aAAqB,GAArB,C;EACX,C;6CAEA,Y;IpCyBA,IAAI,CgBoIoD,CoB5J9C,epB4J+C,UhBpIzD,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KoCzBN,OAAO,4BAAS,CAAT,CAAY,S;EACvB,C;sDAEA,oB;IAGkB,Q;IpCiBlB,IAAI,CoCnBM,qBAAc,QAAd,CpCmBV,C;MACI,coCpBiC,qC;MpCqBjC,MAAM,2BAAsB,OAAQ,WAA9B,C;KoCpBN,aAAmC,I;IACrB,iC;IAAd,OAAc,cAAd,C;MAAc,uB;MACV,YAAY,KAAM,UAAU,eAAM,QAAN,C;MAC5B,SAAS,iBAAW,cAAK,MAAL,EAAa,KAAb,C;;IAExB,OAAO,M;EACX,C;iDAEA,oB;IAEkB,Q;IpCQlB,IAAI,CgBoIoD,CoB7I9C,epB6I+C,UhBpIzD,C;MACI,cAdW,e;MAeX,MAAM,2BAAsB,OAAQ,WAA9B,C;KoCVQ,iC;IAAd,OAAc,cAAd,C;MAAc,uB;MACV,IAAI,CAAC,KAAM,UAAU,mBAAU,QAAV,CAArB,C;QACI,OAAO,K;;IAGf,OAAO,I;EACX,C;;;;;;EClFgB,4B;IAoBhB,qC;IAnBA,eAA+C,QAAJ,GAAI,C;;EAMG,0D;IAAA,mB;MAAE,sB;IAAQ,C;;wCAJ5D,e;IAEY,gB;IAAD,U;IAAA,KAAC,qDAAM,GAAN,uBAAD,U;MAAA,e;;MACH,cAAc,gC;MACd,2CAAI,eAAM,2BAAsB,OAAtB,CAAN,EAAsC,wCAAtC,C;MrC4HiC,MAAM,2BqC3HrC,OrC2HmE,WAA9B,C;;IqC9H/C,a;EAKJ,C;gDAEA,e;IACI,OAAO,YAAM,mBAAY,GAAZ,C;EACjB,C;mCAEA,Y;IACI,OAAO,YAAM,K;EACjB,C;EAEA,mC;IAAA,uC;IACI,aAAkB,uBAAgB,yC;;;;;;;;EADtC,+C;IAAA,8C;MAAA,6B;KAAA,uC;;;;;;;ECrBwB,oC;IACxB,eAAuD,QAAJ,GAAI,C;;gDAEvD,e;IAEW,Q;IAAP,OAAO,4CAAM,GAAN,qC;EACX,C;wDAEA,e;IACI,OAAO,YAAM,mBAAY,GAAZ,C;EACjB,C;2CAEA,Y;IACI,OAAO,YAAM,K;EACjB,C;;;;;;ECbW,yF;IAOX,0B;MAAA,aAA0C,gD;IAC1C,0B;MAAA,aAA0C,gD;IAC1C,qB;IARA,kB;IACA,kB;IAKA,8B;IACA,8B;IAGA,2BAAkC,uBAAgB,mB;IAClD,iBAAiC,2DAAiB,WAAjB,EAAuB,OAAvB,EAAgC,MAAhC,C;IACjC,iBAAiC,2DAAiB,WAAjB,EAAuB,OAAvB,EAAgC,MAAhC,C;IACJ,QAAO,OAAQ,K;IAA5C,0BtC4+BgD,MAAW,KsC5+B1B,CtC4+B0B,EAAO,CAAP,C;IsC3+B9B,UAAO,OAAQ,K;IAA5C,0BtC2+BgD,MAAW,KsC3+B1B,CtC2+B0B,EAAO,GAAP,C;IsC1+B3D,0BAAwB,2BAAW,aAAX,C;;;;SALxB,Y;MAAA,+B;;;;;SAGA,Y;MAAA,8B;;;;;SACA,Y;MAAA,8B;;;;;SACA,Y;MAAA,8B;;;;;SAEI,Y;MAAQ,sBAAc,WAAd,EAAoB,WAApB,E;;;2CAEZ,gB;QAUQ,I;QAIA,M,EAYa,M,EACI,M;IvCvBzB,IAAI,CuCEQ,cvCFZ,C;MACI,cuCCqB,+C;MvCArB,MAAM,8BAAyB,OAAQ,WAAjC,C;KuCIF,sBACI,WADJ,EAEI,WAFJ,E;IAIA,wBACI,WADJ,WACgB,cADhB,SAEI,WAFJ,WAEgB,cAFhB,S;IANJ,2BAA2B,4DACvB,IADuB,e;IAW3B,uBAA4C,MAArB,oBAAqB,C;IAEpB,gBAAR,c;IAAhB,gBvBsNA,mBuBtNA,GAAkC,OAAO,IAAP,CAAlC,GvBsN+B,S;IuBrNP,kBAAR,c;IAAhB,gBvBqNA,qBuBrNA,GAAkC,OAAO,IAAP,CAAlC,GvBqN+B,W;IuBnN/B,iBAAyC,gB;IAExB,6B;IAAjB,OAAiB,gBAAjB,C;MAAiB,4B;MACI,6B;MAAjB,OAAiB,gBAAjB,C;QAAiB,4B;QACb,iBAAiB,eAAc,QAAd,EAAwB,QAAxB,E;QACjB,eAAgC,SAAjB,gBAAiB,EAAS,UAAT,C;QAChC,UAAW,WAAI,QAAJ,C;;;IAInB,OAAO,U;EACX,C;kCAEA,Y;IAcwB,UAGI,MAHJ,EAQR,MARQ,EAQR,MARQ,EAOE,M;IAfG,gBAAR,c;IAAkC,kBvBgMnD,mBuBhMmD,GAAhB,OAAO,IAAP,CAAgB,GvBgMpB,S;IjBgwC5B,kBAAM,iBAAa,qCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,+B;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,WAAY,WAAc,IAAd,WwCvgDE,kBxCugDY,IwCvgDZ,CxCugDF,Q;;IwCxgDZ,gBxCygDG,W;IwCtgDsB,kBAAR,c;IAAkC,kBvB6LnD,qBuB7LmD,GAAhB,OAAO,IAAP,CAAgB,GvB6LpB,W;IjBgwC5B,oBAAM,iBAAa,qCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,+B;IAAb,OAAa,gBAAb,C;MAAa,0B;MACT,aAAY,WAAc,MAAd,WwCpgDE,kBxCogDY,MwCpgDZ,CxCogDF,Q;;IwCrgDZ,gBxCsgDG,a;IwClgDH,YAAY,gB;IACQ,oB;IAApB,eAAY,CAAZ,oB;MACI,gBAAgB,QAAO,C;MACvB,eAAe,SAAO,gBAAW,CAAX,IAAP,C;MACK,sB;MAApB,eAAY,CAAZ,sB;QACI,gBAAgB,SAAO,gBAAW,CAAX,IAAP,C;QAChB,eAAe,QAAO,C;QAER,IAAI,SAAJ,C;UACV,mDAAU,GAAV,aAAsB,cAAtB,4BAAsC,W;;UAEtC,oB;;QAHJ,oB;QAMA,KAAM,WACF,6BACI,GADJ,EACS,GADT,EAEI,OAFJ,EAGQ,SAAJ,GAAe,sBAAU,GAAV,CAAf,GAAmC,IAHvC,EAII,QAJJ,EAIc,QAJd,EAKgB,KAAM,KALtB,CADE,C;;;IAYd,OAAO,K;EACX,C;;;;;;EpCdJ,uBAOe,yB;IArEf,mE;WAqEe,4B;MAAA,uB;QAAU,eAAsB,gB;QAAtB,OA5Dd,cAAc,SA4DgB,CA5DhB,CAAd,EAA2B,SA4DM,CA5DN,CAA3B,C;;;GA4DI,C;EAiCf,oBAQe,yB;IA9Gf,mE;WA8Ge,yC;MAAA,uB;QACP,sBAAsB,WAAY,SAAQ,CAAR,EAAW,CAAX,C;QAClC,Q;QAAA,IAAI,oBAAmB,CAAvB,C;UAAA,OAA0B,e;;UAAqB,eAAsB,gB;UAArE,OAvGG,cAAc,SAuG8C,CAvG9C,CAAd,EAA2B,SAuGoC,CAvGpC,CAA3B,C;;QAsGH,W;;;GADO,C;EqCjIA,0F;IAuGX,iC;IA/FA,qB;IAPA,sB;IAEA,kB;IACA,kB;IACA,4B;IAEA,wC;IAGA,2BAAkC,I;IAClC,gBAAsC,yDAAc,aAAd,EAAsB,MAAtB,EAA8B,aAA9B,C;IACtC,0BAAwB,6CAAS,aAAT,EAAiB,MAAjB,C;IACxB,eAAoB,0CAAM,aAAN,EAAgB,WAAhB,EAAsB,WAAtB,EAA4B,gBAA5B,C;IACpB,0BAA6B,YAAM,M;IACnC,0BAA6B,YAAM,O;IACnC,2BAAuC,a;;;;SANvC,Y;MAAA,+B;;;;;SAEA,Y;MAAA,8B;;;;;SAEA,Y;MAAA,8B;;;;;SACA,Y;MAAA,8B;;;;;SACA,Y;MAAA,+B;;;2CAEA,gB;IAa0B,Q;IAPtB,uBAAuB,4DACnB,IADmB,EAEnB,cAFmB,EAGnB,aAHmB,C;IAMvB,iBAAyC,gB;IACnB,kC;IAAtB,OAAsB,cAAtB,C;MAAsB,wB;MAAjB,IAAI,8B;MACL,UAAW,WAAI,QAAJ,C;;IAEf,OAAO,U;EACX,C;EAcI,mD;IAAA,wB;MACiB,IAAN,I;MAAA,QAAM,0BAAN,M;aACH,G;UAAe,eAAQ,uB;UAAvB,K;aACA,G;UAAe,eAAQ,uBAAR,I;UAAf,K;;UAFG,K;;MAAP,W;IAIJ,C;;EAEA,mD;IAAA,wB;MACiB,IAAN,I;MAAA,QAAM,0BAAN,M;aACH,G;UAAe,eAAQ,uBAAR,I;UAAf,K;aACA,G;UAAe,eAAQ,uB;UAAvB,K;;UAFG,K;;MAAP,W;IAIJ,C;;EAEA,qD;IAAA,2B;MACiB,IAAN,I;MAAA,QAAM,0BAAN,M;aACH,G;UAAe,wBAAM,uBAAN,IAAiB,GAAjB,I;UAAf,K;aACA,G;UAAe,wBAAM,uBAAN,IAAiB,GAAjB,I;UAAf,K;;UAFG,K;;MAAP,W;IAIJ,C;;EAEA,uE;IAAA,2B;MACI,mBAAmB,gBAAQ,GAAR,EAAa,MAAM,CAAN,IAAb,C;MACnB,OAAO,CAAC,MAAM,CAAN,IAAD,IAAY,uBAAZ,KAAwB,CAAxB,IAA6B,gBAAgB,uB;IACxD,C;;EAuBiD,wC;IAAE,SAAG,I;EAAI,C;EAAS,0C;IAAE,SAAG,I;EAAI,C;kCA3DhF,Y;IAOI,kBAAkB,iEAAsB,aAAtB,EAA8B,aAA9B,C;IzCi9Cf,kBAAM,iBAAa,wByCh9CL,WzCg9CK,EAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,OyCvhDQ,WzCuhDR,W;IAAb,OAAa,cAAb,C;MAAa,sB;mBACT,W;MAxEG,oBAAM,iBAAa,wBAwEI,IAxEJ,EAAwB,EAAxB,CAAb,C;MAuEA,U;MAAA,SACiB,IADjB,W;MAAb,OAAa,gBAAb,C;QAAa,0B;QACT,aAAY,WAAc,MyCvhDO,OzCuhDrB,C;;MAAA,YAAZ,WAAY,EACT,aADS,C;;IAxET,oBAAM,iBAAa,wBAyEnB,WAzEmB,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,SAEN,WAFM,W;IAAb,OAAa,gBAAb,C;MAAa,0B;mBACT,a;MA9DG,oBAAa,iBAAa,wBA8DH,MA9DG,EAAwB,EAAxB,CAAb,C;MAgCP,oB;MADb,YAAY,C;MACC,SA8BiB,MA9BjB,W;MAAb,OAAa,gBAAb,C;QAAa,0B;QACT,aAAY,WyCz/C2B,mCzCy/Cb,oBAAmB,gBAAnB,EAAmB,wBAAnB,YyCz/Ca,EzCy/CgB,MyCz/ChB,CzCy/C3B,C;;MA6BA,YAAZ,aAAY,EA5BT,aA4BS,C;;IyCxhDZ,iBzCyhDG,a;IyCrhDH,2C;IAOA,2C;IAOA,+C;IAOA,0D;IAKA,YAAY,gB;IACZ,S;IAAA,kBAA4B,UAA5B,mC;MAAA,kC;MACI,UAAU,MAAM,CAAN,C;MACV,UAAU,MAAM,CAAN,C;MAGV,eAAe,SAAS,GAAT,EAAc,GAAd,C;MACf,eAAe,QAAO,C;MAEtB,KAAM,WACF,6BACI,GADJ,EACS,GADT,EAEc,cAFd,EAGI,IAHJ,EAII,QAJJ,EAIc,QAJd,EAKgB,CALhB,CADE,C;;IAYV,OAAa,WAAN,KAAM,ErCiCjB,eAAW,cAzCX,eAAW,iBqCQ0C,0BrCR1C,CAAX,CAyCW,EqCjC4D,4BrCiC5D,CAAX,CqCjCiB,C;EACjB,C;EAEA,4C;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,0C;IAAA,6C;;IACI,gE;IAAG,gE;;;EAAH,6C;IAAA,gC;IAAA,qC;;;EAAG,6C;IAAA,gC;IAAA,qC;;;;;;;EADP,sC;IAAA,iF;;;EAAA,2C;IAAA,a;MAAA,S;QAAA,0C;MAAA,S;QAAA,0C;MAAA,+G;;;;EAIA,+B;IAAA,mC;;6CACI,0B;IxClFJ,IAAI,CgBgMoD,CwB1GxC,MxB0GyC,UhBhMzD,C;MACI,cwCqFmC,0B;MxCpFnC,MAAM,8BAAyB,OAAQ,WAAjC,C;KAFV,IAAI,EwCuFmB,SAAP,MAAO,CAAW,KAAlB,KAA0B,MAAO,KxCvF7C,CAAJ,C;MACI,gBwCsFqD,iD;MxCrFrD,MAAM,8BAAyB,SAAQ,WAAjC,C;KA0DV,IAAI,EwC4BU,MAAO,KAAP,KAAe,MAAO,KxC5BhC,CAAJ,C;MACI,gBAdW,e;MAeX,MAAM,2BAAsB,SAAQ,WAA9B,C;KwC2BF,OAAO,iEAAsB,MAAtB,EAA8B,MAA9B,CAAsC,K;EACjD,C;EAG4C,wD;IAAA,mB;MAAE,kDAA+B,YAA/B,C;IAAqC,C;;EACvC,0D;IAAA,mB;MAAE,kDAA+B,YAA/B,C;IAAqC,C;;0CAFnF,uC;IACY,UACA,MADA,EAEI,MAFJ,EAqBD,M;IxClHf,IAAI,EwC6FY,uBAAY,OAAO,CAAnB,0BAA0B,IxC7FtC,CAAJ,C;MACI,cwC4F4C,sCxC5F9B,E;MACd,MAAM,8BAAyB,OAAQ,WAAjC,C;KAFV,IAAI,EwC8FY,yBAAY,OAAO,CAAnB,4BAA0B,IxC9FtC,CAAJ,C;MACI,gBwC6F4C,wCxC7F9B,E;MACd,MAAM,8BAAyB,SAAQ,WAAjC,C;KwC8FE,iB;MACI,iBvC03BgC,MAAW,KuC13BtB,IvC03BsB,EuC13BhB,UvC03BgB,C;MuCz3B1B,QAAgB,UAAX,GAAwB,U;MAA9C,iBAA0D,YvCoK3B,MAAW,MAAK,CAAL,CuCpKgB,C;MAC1D,wBvC+3BgC,MAAW,KuC/3BzB,CvC+3ByB,EuC/3BtB,UvC+3BsB,CuC/3B3C,C;WAEJ,iB;MACI,mBvCq3BgC,MAAW,KuCr3BtB,IvCq3BsB,EuCr3BhB,UvCq3BgB,C;MuCp3B1B,UAAgB,UAAX,GAAwB,Y;MAA9C,mBAA0D,YvC+J3B,MAAW,MAAK,GAAL,CuC/JgB,C;MAC1D,0BvC03BgC,MAAW,KuC13BzB,CvC03ByB,EuC13BtB,YvC03BsB,CuC13B3C,C;;MAGe,QAAO,aAAa,CAAb,I;MAAd,UvCu3BwB,MAAW,KuCv3BxB,CvCu3BwB,EAAO,CAAP,C;MuCv3B3C,QvCg3BgC,MAAW,KuCh3B/B,CvCg3B+B,EAAO,GAAP,C;MuC/2B5B,UAAgB,UAAX,GAAwB,C;MAApC,UAAuC,YvC0JhB,MAAW,MAAK,GAAL,CuC1JK,C;MAA/C,QvCs3BgC,MAAW,KuCt3B/B,CvCs3B+B,EAAO,GAAP,C;MuCr3B3C,eAAK,CAAL,C;;IAdR,kB;IAkBA,IAAK,MAAQ,KAAR,aAAL;MAAQ,MAAK,KAAL,a;IACD,QAAM,GAAN,M;WACH,G;QAIQ,UAAgB,UAAX,GAAwB,G;QAFjC,oBACI,GADJ,EAEoC,YvC+IL,MAAW,MAAK,GAAL,CuC/IN,CAFpC,C;QAFJ,K;WAOA,G;QAGQ,UAAgB,UAAX,GAAwB,G;QADjC,oBACoC,YvCyIL,MAAW,MAAK,GAAL,CuCzIN,CADpC,EAEI,GAFJ,C;QAFJ,K;;QARG,K;;IAAP,a;EAgBJ,C;;;;;;;EAjDJ,2C;IAAA,0C;MAAA,yB;KAAA,mC;;;;;;;EpCvGJ,2B;IAAA,+B;IAOI,iB;IAEA,uBAAsB,uCAAO,MAAP,EAAe,WAAf,C;IAEtB,aACY,uCAAO,KAAP,EAAc,WAAd,C;IACZ,YAAW,uCAAO,KAAP,EAAc,WAAd,C;IACX,cAAa,S;IACb,eAAc,uCAAO,IAAP,EAAa,WAAb,C;IACd,cAAa,uCAAO,IAAP,EAAa,WAAb,C;IACb,cAAa,uCAAO,IAAP,EAAa,WAAb,C;IACb,cAAa,uCAAO,IAAP,EAAa,WAAb,C;IACb,YAAW,uCAAO,IAAP,EAAa,WAAb,C;IACX,eAAc,uCAAO,IAAP,EAAa,WAAb,C;IACd,YAAW,uCAAO,GAAP,EAAY,WAAZ,C;IAEX,iBACgB,uCAAO,GAAP,EAAY,WAAZ,C;IAChB,iBAAgB,uCAAO,GAAP,EAAY,WAAZ,C;IAChB,kBACiB,uCAAO,GAAP,EAAY,WAAZ,C;IACjB,mBAAkB,uCAAO,GAAP,EAAY,WAAZ,C;IAElB,WACU,qCAAK,EAAL,C;IACV,iBAAgB,2CAAW,GAAX,C;IAEhB,YACW,2CAAW,IAAX,C;IACX,cAAa,2CAAW,IAAX,C;IACb,YAAW,2CAAW,IAAX,C;IACX,eAAc,2CAAW,IAAX,C;IACd,gBAAe,2CAAW,IAAX,C;IACf,YAAW,2CAAW,IAAX,C;IAEX,YACW,yCAAS,KAAT,C;IACX,eAAc,yCAAS,KAAT,C;IACd,WAAU,yCAAS,KAAT,C;IAEV,cACa,gDAAgB,GAAhB,C;IACb,eAAc,gDAAgB,GAAhB,C;IACd,gBAAe,gDAAgB,GAAhB,C;IACf,iBAAgB,gDAAgB,GAAhB,C;IAChB,kBAAiB,gDAAgB,GAAhB,C;;;;;;;;EApDrB,uC;IAAA,sC;MAAA,qB;KAAA,+B;;EqCG4B,gC;IAuCxB,oC;IAvC4C,wB;;;;SAGxC,Y;MAAQ,MAAM,2BAAsB,gCAAtB,C;;;mCAElB,Y;IACI,OAAO,eAAS,iBAAQ,aAAR,C;EACpB,C;EAQkC,yG;IAC9B,sB;IACA,kD;IACA,wC;IACA,sC;;EAGW,kG;IAAA,wD;IAAS,iC;;8EAEZ,Y;IACI,OAAO,gD;EACX,C;sFAEA,Y;IACI,OAAO,oD;EACX,C;iFAEA,Y;IACI,OAAO,+C;EACX,C;;;;;6DAbR,Y;IACI,sEAA6B,aAA7B,C;EAcJ,C;;;;;;EAGJ,kC;IAAA,sC;;EAGqB,+C;IAAE,sB;EAAY,C;2CAD/B,Y;IACI,OAAO,mBAAM,mCAAN,C;EACX,C;mDAEA,oB;IACI,OAKE,CALK,qDAEH,4BAAmB,QAFhB,EAGH,mBAAU,eAHP,EAIH,QAJG,CAKL,iB;EACN,C;EAGgB,8C;IAAE,qB;EAAW,C;0CAD7B,Y;IACI,OAAO,kBAAK,kCAAL,C;EACX,C;kDAEA,oB;IACI,OAKE,CALK,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIH,QAJG,CAKL,iB;EACN,C;EAOM,8C;IAAE,qB;EAAW,C;0CALnB,Y;IACI,OAIiB,CAJV,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIL,kCAJK,CAIU,iB;EACrB,C;EAOM,gD;IAAE,uB;EAAa,C;4CALrB,Y;IACI,OAImB,CAJZ,sDAEH,4BAAmB,SAFhB,EAGH,oBAAW,eAHR,EAIL,oCAJK,CAIY,iB;EACvB,C;EAOM,6C;IAAE,oB;EAAU,C;yCALlB,Y;IACI,OAIgB,CAJT,mDAEH,4BAAmB,MAFhB,EAGH,iBAAQ,eAHL,EAIL,iCAJK,CAIS,iB;EACpB,C;EAOM,mD;IAAE,0B;EAAgB,C;+CALxB,Y;IACI,OAIsB,CAJf,yDAEH,4BAAmB,YAFhB,EAGH,uBAAc,eAHX,EAIL,uCAJK,CAIe,iB;EAC1B,C;EAOM,8C;IAAE,qB;EAAW,C;0CALnB,Y;IACI,OAIiB,CAJV,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIL,kCAJK,CAIU,iB;EACrB,C;EAOM,+C;IAAE,sB;EAAY,C;2CALpB,Y;IACI,OAIkB,CAJX,sDAEH,4BAAmB,QAFhB,EAGH,mBAAU,eAHP,EAIL,mCAJK,CAIW,iB;EACtB,C;EAOM,kD;IAAE,yB;EAAe,C;8CALvB,Y;IACI,OAIqB,CAJd,yDAEH,4BAAmB,WAFhB,EAGH,sBAAa,eAHV,EAIL,sCAJK,CAIc,iB;EACzB,C;sDAEA,oB;IACI,OAKE,CALK,yDAEH,4BAAmB,WAFhB,EAGH,sBAAa,eAHV,EAIH,QAJG,CAKL,iB;EACN,C;EAOM,mD;IAAE,0B;EAAgB,C;+CALxB,Y;IACI,OAIsB,CAJf,0DAEH,4BAAmB,YAFhB,EAGH,uBAAc,eAHX,EAIL,uCAJK,CAIe,iB;EAC1B,C;wDAEA,oB;IACI,OAKE,CALK,2DAEH,4BAAmB,aAFhB,EAGH,wBAAe,eAHZ,EAIH,QAJG,CAKL,iB;EACN,C;EAOM,iD;IAAE,wB;EAAc,C;6CALtB,Y;IACI,OAIoB,CAJb,uDAEH,4BAAmB,UAFhB,EAGH,qBAAY,eAHT,EAIL,qCAJK,CAIa,iB;EACxB,C;EAOM,kD;IAAE,yB;EAAe,C;8CALvB,Y;IACI,OAIqB,CAJd,wDAEH,4BAAmB,WAFhB,EAGH,sBAAa,eAHV,EAIL,sCAJK,CAIc,iB;EACzB,C;EAOM,iD;IAAE,wB;EAAc,C;6CALtB,Y;IACI,OAIoB,CAJb,uDAEH,4BAAmB,UAFhB,EAGH,qBAAY,eAHT,EAIL,qCAJK,CAIa,iB;EACxB,C;EAOM,6C;IAAE,oB;EAAU,C;yCALlB,Y;IACI,OAIgB,CAJT,mDAEH,4BAAmB,MAFhB,EAGH,iBAAQ,eAHL,EAIL,iCAJK,CAIS,iB;EACpB,C;EAOM,gD;IAAE,uB;EAAa,C;4CALrB,Y;IACI,OAImB,CAJZ,uDAEH,4BAAmB,SAFhB,EAGH,oBAAW,eAHR,EAIL,oCAJK,CAIY,iB;EACvB,C;EAOM,+C;IAAE,sB;EAAY,C;2CALpB,Y;IACI,OAIkB,CAJX,sDAEH,4BAAmB,QAFhB,EAGH,mBAAU,eAHP,EAIL,mCAJK,CAIW,iB;EACtB,C;EAOM,+C;IAAE,sB;EAAY,C;2CALpB,Y;IACI,OAIkB,CAJX,sDAEH,4BAAmB,QAFhB,EAGH,mBAAU,eAHP,EAIL,mCAJK,CAIW,iB;EACtB,C;qDAEA,oB;IACI,OAKE,CALK,wDAEH,4BAAmB,UAFhB,EAGH,qBAAY,eAHT,EAIH,QAJG,CAKL,iB;EACN,C;EASyB,gE;IAAA,mB;MAAE,uBAAY,eAAQ,YAApB,C;IAAiC,C;;qDAP5D,mB;IAGI,OAKE,CALK,wDAEH,4BAAmB,iBAAQ,OAAQ,YAAhB,CAFhB,EAGH,qBAAY,eAHT,EAIc,8CAJd,CAKL,iB;EACN,C;EAOM,gD;IAAE,uB;EAAa,C;4CALrB,Y;IACI,OAImB,CAJZ,sDAEH,4BAAmB,SAFhB,EAGH,oBAAW,eAHR,EAIL,oCAJK,CAIY,iB;EACvB,C;EAOM,8C;IAAE,qB;EAAW,C;0CALnB,Y;IACI,OAIiB,CAJV,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIL,kCAJK,CAIU,iB;EACrB,C;EAOM,iD;IAAE,wB;EAAc,C;6CALtB,Y;IACI,OAIoB,CAJb,uDAEH,4BAAmB,UAFhB,EAGH,qBAAY,eAHT,EAIL,qCAJK,CAIa,iB;EACxB,C;EAOM,mD;IAAE,0B;EAAgB,C;+CALxB,Y;IACI,OAIsB,CAJf,yDAEH,4BAAmB,YAFhB,EAGH,uBAAc,eAHX,EAIL,uCAJK,CAIe,iB;EAC1B,C;EAOM,oD;IAAE,2B;EAAiB,C;gDALzB,Y;IACI,OAIuB,CAJhB,0DAEH,4BAAmB,aAFhB,EAGH,wBAAe,eAHZ,EAIL,wCAJK,CAIgB,iB;EAC3B,C;EAOM,gD;IAAE,uB;EAAa,C;4CALrB,Y;IACI,OAImB,CAJZ,sDAEH,4BAAmB,SAFhB,EAGH,oBAAW,eAHR,EAIL,oCAJK,CAIY,iB;EACvB,C;EAOM,kD;IAAE,yB;EAAe,C;8CALvB,Y;IACI,OAIqB,CAJd,wDAEH,4BAAmB,WAFhB,EAGH,sBAAa,eAHV,EAIL,sCAJK,CAIc,iB;EACzB,C;kDAEA,oB;IACI,OAKE,CALK,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIH,QAJG,CAKL,iB;EACN,C;EAOM,8C;IAAE,qB;EAAW,C;0CALnB,Y;IACI,OAIiB,CAJV,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIL,kCAJK,CAIU,iB;EACrB,C;qDAEA,oB;IACI,OAKE,CALK,uDAEH,4BAAmB,UAFhB,EAGH,qBAAY,eAHT,EAIH,QAJG,CAKL,iB;EACN,C;kDAEA,oB;IACI,OAKE,CALK,oDAEH,4BAAmB,OAFhB,EAGH,kBAAS,eAHN,EAIH,QAJG,CAKL,iB;EACN,C;EAOM,gD;IAAE,uB;EAAa,C;4CALrB,Y;IACI,OAImB,CAJZ,sDAEH,4BAAmB,SAFhB,EAGH,oBAAW,eAHR,EAIL,oCAJK,CAIY,iB;EACvB,C;mDAEA,oB;IACI,OAKE,CALK,qDAEH,4BAAmB,QAFhB,EAGH,mBAAU,eAHP,EAIH,QAJG,CAKL,iB;EACN,C;;;;;;;EApSJ,8C;IAAA,6C;MAAA,4B;KAAA,sC;;;;;;;ECvC0B,mD;IAC1B,kB;IAKA,2BAAsC,aAAQ,QAAS,KAAjB,C;IACtC,4BAAgD,2C;IAChD,oBAA2D,QAAT,QAAS,C;IAC3D,sBAA2B,c;;;;SAH3B,Y;MAAA,+B;;;;;SACA,Y;MAAA,gC;;;+CAIA,e;IAAqC,wBAAW,mBAAY,GAAZ,C;;oDAEhD,sB;IACI,oBAAoB,8BAAiB,GAAjB,EAAsB,KAAtB,C;IACpB,YAAY,gBAAS,GAAT,C;IACZ,YAAY,iBAAU,GAAV,CAAe,CAAO,aAAP,C;IAC3B,OAAwB,gCACZ,KAAM,KADM,EAEZ,KAFY,EAGL,KAAM,aAHD,C;EAK5B,C;uDAEA,sB;I1CLA,IAAI,C0CMQ,sBAAS,GAAT,C1CNZ,C;MACI,c0CKyB,oB;M1CJzB,MAAM,8BAAyB,OAAQ,WAAjC,C;K0CMN,cAAyB,SAAX,iBAAW,EAAS,GAAT,C;IACzB,YAAY,gBAAS,GAAT,C;I7BmET,Y6BhEoB,WAAK,oBADrB,OAAQ,SACa,CAAL,mB;IADvB,OAE0B,eAAU,sBAAa,KAAb,C;EACxC,C;yDAEA,e;IAAuD,uBAAS,GAAT,CAAc,K;;6DAErE,e;IAA4D,uBAAS,GAAT,CAAc,a;;yCAE1E,e;IACI,OAAO,gBAAW,GAAX,C;EACX,C;0CAEA,e;IACI,YAAY,gBAAS,GAAT,C;IACQ,gBAAb,mB;IxCsSJ,Q;IADP,YAAY,oBwCrSqB,GxCqSrB,C;IACL,IAAI,aAAJ,C;MACH,awCvSmD,kC;MxCwSnD,sBwCxS6B,GxCwS7B,EAAS,MAAT,C;MACA,a;;MAEA,Y;;IwC3SA,OxCsSJ,I;EwCrSA,C;EAYe,mE;IAAA,wB;MAAW,Q;MAAA,U;eAAA,K,WAAuB,kBAAvB,KAAuB,C;MAAvB,wCAAuC,K;IAAM,C;;EAGxD,qE;IAAA,wB;MAAW,Q;MAAA,U;eAAA,K,WAAuB,4BAAvB,KAAuB,C;MAAvB,wCAAyC,K;IAAM,C;;gDAbzE,wB;IACI,IAAI,OAAM,mBAAV,C;MAKS,gBAFA,SADQ,iBACR,EAAS,GAAT,CACA,S;MAEA,kB7BfN,wB6BcU,yB;;O7BdV,Y6BcU,W7BdV,a;M6BWC,6D7BXD,Y;M6BiBC,gBAAgB,OAAM,qBAAqB,wBAAe,MAAf,EAAuB,GAAvB,C;MAC3C,OAAO,iD;;MAEP,gBAAgB,qCAAa,OAAb,C;MAChB,OAAO,mD;;EAEf,C;EAxDgD,6D;IAAA,qB;MAAE,oCAAS,EAAT,C;IAAa,C;;;;;;;ECd9B,4C;IAGjC,6BAAkB,IAAlB,EAAwB,IAAxB,C;;;;;;;;;;;;;;ECKqC,uC;IA+DrC,yC;IA9DA,kB;IACA,kB;;wDAGA,kD;IAMI,OAAO,kEACH,UADG,EAEH,MAFG,EAGH,UAHG,EAIH,MAJG,C;EAMX,C;wDAEA,kD;IAMI,OAAO,kEACH,UADG,EAEH,MAFG,EAGH,UAHG,EAIH,MAJG,C;EAMX,C;+DAEA,sD;IASmB,IAQX,IARW,EASX,M;IAZJ,cAAc,+DAAa,OAAb,EAAsB,WAAtB,C;IACd,cAAc,+DAAa,OAAb,EAAsB,WAAtB,C;IACd,OAAO,YAAO,gBACV,gBAAW,aACP,OADO,EAEP,OAFO,CADD,EAKV,gBAAW,aACP,OADO,EAEP,OAFO,CALD,GASV,kBATU,YASE,gBAAW,2BATb,UAUV,oBAVU,YAUE,gBAAW,6BAVb,Q;EAYlB,C;sDAEA,yC;IAKgB,UAAiB,M;IAA7B,OAAO,SAAK,sCAAQ,OAAb,EAAsB,0CAAQ,OAA9B,C;EACX,C;EAEA,uC;IAAA,2C;;+DACI,8B;IACI,OAAO,aAAQ,aAAI,MAAJ,EAAY,UAAZ,C;EACnB,C;kEAEA,kD;IAMI,OAAO,mCACH,UADG,EAEH,0BAAa,MAAb,EAAqB,UAArB,CAFG,EAGH,MAHG,C;EAKX,C;wEAEA,0C;IAKI,OAAO,UAAW,OACb,gBAAO,MAAO,aAAd,CACA,gBAAO,MAAO,OAAd,CACA,gBAAO,UAAP,CACA,Q;EACT,C;;;;;;;EA5BJ,mD;IAAA,kD;MAAA,iC;KAAA,2C;;;;;;;ECrEJ,0B;IAAA,8B;;+CACI,sB;IAAc,oB;MAAA,OAA6B,I;IAAM,oB;MAAA,OAA6B,I;IAC1E,OAAO,2BAAuB,IAAvB,EAA6B,IAA7B,C;EACX,C;2CAEA,6B;IAEI,oB;MAAA,OAA6B,I;IAC7B,oB;MAAA,OAA6B,I;IAE7B,OAAO,4BAAwB,KAAxB,EAA+B,IAA/B,EAAqC,IAArC,C;EACX,C;yCAEA,sB;IACI,oB;MAAA,OAA6B,I;IAC7B,oB;MAAA,OAA6B,I;IAG7B,OAAO,4BACH,yBADG,EAEH,yBAFG,EAGH,IAHG,EAIH,IAJG,C;EAMX,C;;;;;;;EAxBJ,sC;IAAA,qC;MAAA,oB;KAAA,8B;;ECO2C,oD;IAIvC,6BAAkB,IAAlB,EAAwB,IAAxB,C;IAHA,oB;;4DAKA,yC;IAOI,eAAqB,6DAAc,OAAd,EAAuB,OAAvB,EAAgC,WAAhC,C;IAErB,gBACc,QAAS,M;IAEvB,gBACc,QAAS,O;IAEvB,YAAY,iBAAW,cAAK,SAAL,C;IACvB,YAAY,iBAAW,cAAK,SAAL,C;IACvB,IAAI,QAAQ,iBAAW,KAAnB,IAA2B,QAAQ,iBAAW,KAAlD,C;MACI,OAAO,SAAK,SAAL,EAAc,SAAd,C;KAIX,eAAe,WAAY,E;IAC3B,eAAe,WAAY,E;IAM3B,IAAI,eAAQ,CAAZ,C;MACI,YAAY,Y;;MAEZ,YAAY,IAAI,Y;;IAGpB,aAAa,QAAQ,Q;IACrB,aAAa,QAAQ,Q;IAIrB,IAAI,SAAS,MAAb,C;MACI,mBAAmB,WAAW,M;MAC9B,YAAU,iBAAW,gBAAO,SAAP,EAAgB,YAAhB,C;;MAErB,qBAAmB,WAAW,M;MAC9B,YAAU,iBAAW,gBAAO,SAAP,EAAgB,cAAhB,C;;IAGzB,OAAO,SAAK,SAAL,EAAc,SAAd,C;EACX,C;;;;;;ECzDkC,uE;IA0FlC,+C;IArFA,6BAAkB,IAAlB,EAAwB,IAAxB,C;IAJA,gC;IACA,gC;;4DAKA,yC;IAmBQ,Q;IAZJ,eAAqB,6DAAc,OAAd,EAAuB,OAAvB,EAAgC,WAAhC,C;IAErB,gBACc,kBAAY,uBAAc,QAAS,MAAvB,C;IAE1B,gBACc,kBAAY,uBAAc,QAAS,OAAvB,C;IAG1B,YAAY,iBAAW,cAAK,SAAL,C;IACvB,YAAY,iBAAW,cAAK,SAAL,C;IAEnB,IAAI,QAAQ,KAAZ,C;MACI,aAAa,SAAQ,SAAR,GAAmB,QAAQ,C;MACxC,eAAe,QAAQ,C;MACvB,gBACI,gBAAY,SAAS,QAArB,EAA+B,SAAS,QAAxC,CADJ,EAEI,SAFJ,C;;MAKA,eAAa,SAAQ,SAAR,GAAmB,QAAQ,C;MACxC,iBAAe,QAAQ,C;MACvB,gBACI,SADJ,EAEI,gBAAY,WAAS,UAArB,EAA+B,WAAS,UAAxC,CAFJ,C;;IAXR,uB;IAiBA,oBAAoB,kBAAY,eAAM,YAAa,MAAM,SAAzB,C;IAChC,oBAAoB,kBAAY,eAAM,YAAa,MAAM,SAAzB,C;IAChC,oBAAoB,kBAAY,eAAM,YAAa,OAAO,SAA1B,C;IAChC,oBAAoB,kBAAY,eAAM,YAAa,OAAO,SAA1B,C;IAEhC,YAAY,CAAC,gBAAgB,aAAjB,KAAmC,gBAAgB,aAAnD,C;IACZ,iBAAiB,4BAAwB,KAAxB,EAA+B,IAA/B,EAAqC,IAArC,C;IACjB,OAAO,UAAW,uBAAc,SAAd,EAAuB,SAAvB,EAAgC,WAAhC,C;EACtB,C;8DAEA,kD;IAMW,Q;IAAA,IAAI,kBAAY,UAAhB,C;MACH,sFACI,kBADJ,EAEI,UAFJ,EAGI,MAHJ,EAII,UAJJ,EAKI,MALJ,C;;MAQM,sEAAgB,UAAhB,EAA4B,MAA5B,EAAoC,UAApC,EAAgD,MAAhD,C;;IATV,W;EAWJ,C;8DAEA,kD;IAMW,Q;IAAA,IAAI,kBAAY,UAAhB,C;MACH,sFACI,kBADJ,EAEI,UAFJ,EAGI,MAHJ,EAII,UAJJ,EAKI,MALJ,C;;MAQM,sEAAgB,UAAhB,EAA4B,MAA5B,EAAoC,UAApC,EAAgD,MAAhD,C;;IATV,W;EAWJ,C;EAEA,6C;IAAA,iD;;+EACI,8D;IAOI,kBAAkB,UAAW,uBAAc,MAAd,C;IAC7B,2BAA2B,gBACvB,UAAW,eAAM,WAAY,SAAlB,CADY,EAEvB,UAAW,eAAM,WAAY,SAAlB,CAFY,C;IAK3B,wBAAwB,aAAQ,gBAAO,oBAAP,EAA6B,WAA7B,C;IAEhC,mBAAmB,+DACf,MADe,EAEf,UAFe,C;IAInB,kBAAkB,wBACd,UADc,EAEd,iBAFc,EAGd,YAHc,C;IAKlB,kBAAkB,sBAAe,WAAf,EAA4B,MAA5B,C;IAClB,OAAO,wEACH,UADG,EAEH,WAFG,EAGH,WAHG,C;EAKX,C;iEAEA,+B;IAGc,Q;IAFV,mBAAmB,gB;IACnB,QAAQ,C;IACE,aAAO,aAAP,W;IAAV,OAAU,cAAV,C;MAAU,mB;MACN,IAAI,yBAAe,WAAY,kBAAS,CAAT,CAA/B,C;QACI,YAAa,WAAI,CAAJ,C;OAEjB,a;;IAGJ,IAAI,YAAa,KAAb,KAAqB,MAAO,aAAa,KAA7C,C;MACI,OAAO,M;KAGX,wBAAwB,iBAAW,uBAAc,MAAO,aAArB,EAAmC,YAAnC,C;IACnC,kBAAkB,iBAAW,uBAAc,MAAO,OAArB,EAA6B,YAA7B,C;IAC7B,6BAA6B,iBAAW,uBAAc,MAAO,kBAArB,EAAwC,YAAxC,C;IACxC,OAAO,gBACH,iBADG,EAEH,sBAFG,EAGH,WAHG,C;EAKX,C;EAMW,uI;IAAA,oB;MACH,Q;MAAA,c;QAAO,6C;QAAA,2D;QAAA,+C;QACH,gBAAgB,oBAAW,iB;QAC3B,kBAAkB,4BAAkB,SAAlB,C;QAFtB,OAGI,sBAAY,WAAZ,C;;QAHJ,W;MAAA,W;IAKJ,C;;mEAVJ,sD;IAII,OAAO,qG;EAOX,C;;;;;;;EApEJ,yD;IAAA,wD;MAAA,uC;KAAA,iD;;;;;;;EC/FJ,+B;IAEI,2BAAyB,K;;;;SAAzB,Y;MAAA,+B;;;gDAEA,a;IACI,OAAO,2CAAa,CAAb,C;EACX,C;wDAEA,kB;IACI,OAAO,M;EACX,C;;;;;;ECTJ,+B;IACI,2BAAyB,I;;;;SAAzB,Y;MAAA,+B;;;gDAEA,a;IACI,OAAO,2CAAa,CAAb,C;EACX,C;wDAEA,kB;IACI,IAAI,0CAAqB,qBAAY,MAAZ,CAAzB,C;MACI,OAAO,0CAAqB,sBAAa,MAAb,C;KAEhC,MAAM,8BAAyB,qDAAkD,MAA3E,C;EACV,C;;;;;;ECCJ,0B;IAAA,8B;;wDAEI,sC;IAOoB,Q;IAFhB,aACW,M;IACK,0B;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MACZ,eAAe,OAAQ,S;MACvB,IAAI,QAAS,SAAb,C;QlD2DR,IAAI,CkD1Dc,MAAK,aAAI,QAAJ,ClD0DvB,C;UACI,ckD3DoC,gC;UlD4DpC,MAAM,2BAAsB,OAAQ,WAA9B,C;SkD3DE,SAAO,kBAAc,wBACjB,MADiB,EAEjB,QAFiB,EAGjB,OAAQ,IAHS,EAIjB,qBAAS,OAAQ,IAAjB,CAJiB,C;;IAS7B,OAAO,M;EACX,C;mDAEA,qJ;IA8BkB,UAkBgB,M;IAnC9B,IAAI,WAAS,UAAM,SAAnB,C;MACI,OAAO,0CAAuB,wCAAvB,EAAqC,eAArC,C;KAGX,aAAa,eAAgB,Y;IAE7B,gB;IACA,0B;IAGA,IAAI,WAAW,uBAAU,qBAAzB,C;MACI,SAAS,iBAAU,IAAV,EAAgB,MAAhB,EAAsB,QAAtB,EAAgC,QAAhC,EAA0C,MAA1C,EAAkD,OAAlD,EAA2D,kBAA3D,EAA+E,eAA/E,C;MACT,yBAAyB,OAAO,EAAG,WAAV,C;MACK,gBAAf,EAAG,Y;MnDwqC1B,aAAa,qBAA6D,cAAzC,YAAY,mCAAwB,EAAxB,CAAZ,CAAyC,EAAc,EAAd,CAA7D,C;MAcG,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAbO,MAcP,aAAI,OAAJ,EmDvrCkD,enDurCvB,OmDvrCuB,CnDurClD,C;;MmDvrCR,enDyqCe,M;;MmDvqCf,kBAAkB,iB;MAClB,uBAAuB,E;MACb,2BAAa,IAAb,EAAmB,MAAnB,Y;MAAV,OAAU,cAAV,C;QAAU,mB;QACN,WAAS,iBAAU,CAAV,EAAa,MAAb,EAAmB,QAAnB,EAA6B,QAA7B,EAAuC,MAAvC,EAA+C,OAA/C,EAAwD,kBAAxD,EAA4E,eAA5E,C;QACT,IAAI,IAAG,QAAP,C;UACI,Q;SAEJ,WAAY,wBAAe,YAAf,EAA6B,IAAG,YAAhC,EAA6C,QAA7C,EAAuD,kBAAvD,C;QAEZ,4BAA4B,IAAG,W;QAG/B,IAAI,IAAG,aAAI,UAAM,MAAV,CAAP,C;UACI,YAAY,IAAG,eAAM,UAAM,MAAZ,C;UACf,IAAI,SAAS,IAAb,C;YACI,YAAY,mBAAmB,CAAnB,I;YACZ,aAAa,QAAuB,YAAf,KAAM,SAAS,CAAvB,I;YACb,mBAAkC,YAAf,KAAM,SAAS,CAAf,GAAyB,MAAzB,I;YACnB,IAAI,WAAU,CAAd,C;cACI,WAAW,gB;cACD,aAAG,oBAAW,UAAM,MAAjB,CAAH,W;cAAV,OAAU,gBAAV,C;gBAAU,qB;gBACN,IAAK,WAAI,mBAAM,MAAV,C;;cAET,OAAK,IAAG,UAAU,oBAAW,UAAM,MAAjB,EAAwB,IAAxB,CAA8B,Q;;UAIxD,kBAAkB,eAAgB,4B;UAClC,IAAI,mBAAJ,C;YACI,WAAW,iBAAkB,QAAf,IAAG,YAAY,CAAlB,CAA2B,K;YACtC,QAAQ,cAAE,WAAF,cAAe,CAAf,C;YACA,aAAH,IAAG,U;YlC2C5B,WAAW,iBkC3CiD,IlC2CjD,C;YHCX,iBAAc,CAAd,UqC5C4D,IrC4C5D,U;cGA6B,iB;;YkC5CT,OAAkB,mBAAI,WAAJ,ElC6C/B,IkC7C+B,CAAmC,Q;;QAK7D,WAAY,kBAAS,IAAT,EAAa,qBAAb,C;;MAGhB,eAAe,WAAY,kB;MAC3B,yBAAyB,WAAY,gB;;IAGP,uC;IrCjE/B,kBqCiEiB,kC;IAEC,U;IAAA,6BAAa,KAAb,W;IAAjB,OAAiB,gBAAjB,C;MAAiB,4B;MACb,wBAAI,QAAJ,EAAc,6CAAa,QAAb,EAAd,C;;InD84CL,kBAAM,iBAAa,sCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,gC;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,WAAY,WmDj9CJ,6BAAgB,yBAA6B,yBAA7B,YnDi9CE,ImDj9CF,qBnDi9CZ,C;;ImDl9CR,iBnDm9CD,W;ImDh9CC,kCAAc,UAAd,C;IAVJ,oBAaI,mB;IAGJ,+BAA+B,uCAAgB,2BAC3C,aAD2C,EAE3C,sBAF2C,C;IAK/C,OAAO,0CACH,aADG,EAEH,wBAFG,C;EAIX,C;0DAEA,wB;IACI,OAAW,mCAAc,IAAd,CAAJ,GACH,IADG,GAGH,kBAAc,4BAAmB,MAAnB,EAAyB,mBAAzB,C;EACtB,C;4CAEA,wB;IAC0D,gBAA/C,+CAAe,IAAK,WAApB,EAAgC,MAAhC,CAAwC,O;InD82C5C,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,2B;IAAb,OAAa,cAAb,C;MAAa,sB;mBACT,W;MmDr7CqB,kBAAZ,gB;MnD0lDG,U;MADhB,kBmDzlD8B,kC;MnD0lDd,+B;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAAoB,QAAU,W;QAAV,oB;QmDzlDb,U;QAAA,gCnDylDoC,OmDzlDpC,C;QACP,oB;UADJ,mBACY,CAAE,oBnDwlDiC,OmDxlDjC,EAAqB,wCAAmB,wBnDwlDP,OmDxlDO,CAAnB,EnDm7CjB,ImDn7CiB,CAArB,C;eACV,qB;UAFJ,mBAEa,CAAE,qBnDulDgC,OmDvlDhC,EAAsB,wCAAc,iBnDulDJ,OmDvlDI,CAAd,EnDk7CnB,ImDl7CmB,CAAtB,C;;UAFf,+C;;QnDylDU,8B;;MArKN,YAAZ,WAAY,EAsKT,WAtKS,C;;IAxET,oBAAM,iBAAa,wBAyEnB,WAzEmB,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,SAEN,WAFM,W;IAAb,OAAa,gBAAb,C;MAAa,0B;MACT,aAAY,WAAc,cAAd,C;;ImDt7CZ,OnDu7CG,a;EmD/6CP,C;EA0DI,mH;IAAA,2B;MAC2B,UAAX,M;MAAW,OAAL,YAAK,mBAAU,QAAV,C;MACnB,kB;QAAmB,SAAX,iBAAW,cAAK,YAAK,oBAAW,QAAX,CAAV,EAA+C,IAA/C,C;WACnB,mB;QAAoB,SAAX,iBAAW,sBAAa,yBAAK,QAAL,CAAb,EAA4C,IAA5C,C;;;MAFxB,kB;MAIoB,WAAK,oB;MlC3EjC,WAAW,iBAduE,IAcvE,C;MHCX,iBAAc,CAAd,UGfkF,IHelF,U;QGA6B,qB;;MkC0ErB,oBlCzED,I;MkC0EC,sBhDmBR,agDnBuB,QhDmBvB,EgDnBmC,ahDmBnC,C;IgDlBI,C;;yCA/DJ,wG;IAmCyB,UA8BL,MA9BK,EAwCT,MAxCS,EAuDL,MAvDK,EA+DJ,MA/DI,EAmEJ,M;IAxFjB,eAAe,MAAK,eAAM,MAAN,EAAY,OAAZ,EAAqB,mBAArB,C;IAEpB,oBAAoB,QAAS,Y;IAC7B,IAAI,aAAc,UAAlB,C;MACI,OAAO,Q;KAKX,mCACI,0CACI,QADJ,EAEI,MAFJ,EAGI,QAHJ,EAII,QAJJ,C;IASJ,mBAAmB,qBAAS,aAAc,WAAW,OAAlC,CAA0C,K;IAC7D,gBAAgB,gB;IACK,aAAO,UAAP,W;IAArB,OAAqB,cAArB,C;MAAqB,8B;MACjB,eAAe,kBAAc,4BAAmB,MAAnB,EAAyB,YAAzB,C;MAC7B,SAAU,WAAI,QAAJ,C;MACV,IlCuBgD,CkCvB5C,mBAAK,QAAL,ClCuB6C,UkCvBjD,C;QACI,iBAAiB,mBAAK,QAAL,cAAe,CAAf,C;QAGZ,aADM,QACN,U;QlCxDjB,WAAW,iBkCyDyB,YlCzDzB,C;QHCX,iBAAc,CAAd,UqCwDoC,YrCxDpC,U;UGA6B,0B;;QkCsDjB,WAEK,mBAAI,QAAJ,ElCvDV,IkCuDU,CACA,Q;;IAMb,IAAI,QAAS,UAAb,C;MACI,OAAO,Q;KAGX,qBAAqB,c;IAErB,8G;IASgB,4B;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MACZ,eAAe,OAAQ,S;MACvB,IAAI,QAAS,OAAT,IAAmB,SAAU,gBAAS,QAAT,CAAjC,C;QACI,Q;OAGJ,UAAU,OAAQ,I;MAClB,IAAI,MAAK,2BAAkB,GAAlB,CAAT,C;QACI,qBAAqB,MAAK,2BAAkB,GAAlB,C;QAEtB,IAAI,4BAA6B,mBAAY,cAAZ,CAAjC,C;UACiC,kBAA7B,4BAA6B,EAAS,cAAT,C;;UAE7B,gBAAgB,QAAS,oBAAW,cAAX,C;UACf,SAAV,eAAU,0BAAiB,SAAjB,EAA4B,qBAAS,GAAT,CAA5B,C;;QALlB,0B;QAOA,chDAZ,agDA2B,QhDA3B,EgDAuC,ahDAvC,C;;QgDGY,IAAI,CAAC,cAAe,mBAAY,QAAZ,CAApB,C;UACI,qBAAqB,QAArB,C;;;IAKuB,4CAAU,yB;;KAAV,YAAU,UAAV,E;InDgjBhC,kBAAY,gB;IA4BH,U;IAAA,SmD5kBI,kBnD4kBJ,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MAAM,IAAI,CA5BS,SA4BR,CAAU,OAAV,CAAL,C;QAAyB,WAAY,WAAI,OAAJ,C;;ImD5kBvC,SnD6kBb,WmD7kBa,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MACZ,iBAAe,kBAAc,4BAAmB,MAAnB,EAAyB,OAAzB,C;MAC7B,IAAI,CAAC,cAAe,mBAAY,UAAZ,CAApB,C;QACI,qBAAqB,UAArB,C;;IAIR,QAAQ,QAAS,U;IACA,uBAAe,KAAf,W;IAAjB,OAAiB,gBAAjB,C;MAAiB,8B;MACb,CAAE,aAAI,UAAJ,EAA6B,SAAf,cAAe,EAAS,UAAT,CAA7B,C;;IAGW,qCAA6B,KAA7B,W;IAAjB,OAAiB,gBAAjB,C;MAAiB,8B;MACb,CAAE,oBAAW,UAAX,EAAkD,SAA7B,4BAA6B,EAAS,UAAT,CAAlD,C;;IAGN,OAAO,CAAE,Q;EACb,C;kEAEA,8C;IASgB,UAOI,MAPJ,EA4BI,M;IA9BhB,2BAA2B,c;IAC3B,yBAAyB,c;IACb,oBAAI,SAAJ,W;IAAZ,OAAY,cAAZ,C;MAAY,qB;MACR,IAAI,IAAK,2BAAkB,GAAlB,CAAT,C;QACI,qBAAqB,IAAK,2BAAkB,GAAlB,C;QAC1B,kBhDxCZ,agDwC+B,chDxC/B,EgDwCiD,GhDxCjD,C;;IgD4CoB,4B;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MACZ,YAAU,OAAQ,I;MAClB,eAAe,OAAQ,S;MACvB,IAAI,QAAS,OAAb,C;QACI,kBhDhDZ,agDgD+B,QhDhD/B,EgDgD2C,KhDhD3C,C;QgDkDY,Q;OAGJ,cAAY,qBAAS,KAAT,C;MACZ,IAAI,OAAM,mBAAV,C;QACI,oBhDvDZ,agDuDiC,KhDvDjC,EgDuDwC,OhDvDxC,C;QgDwDY,IAAI,aAAI,uBAAc,KAAd,CAAJ,IAA0B,CAAC,oBAAqB,mBAAY,aAAI,EAAhB,CAApD,C;UACI,UAAqB,aAAI,E;UAAzB,oBhDzDhB,aAAI,GAAJ,EgDyD8C,OhDzD9C,C;egD0DmB,IAAI,aAAI,uBAAc,KAAd,CAAJ,IAA0B,CAAC,oBAAqB,mBAAY,aAAI,EAAhB,CAApD,C;UACH,YAAqB,aAAI,E;UAAzB,oBhD3DhB,aAAI,KAAJ,EgD2D8C,OhD3D9C,C;;IgDgEI,mCAAmC,c;IACnB,iBAAS,YAAT,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MACZ,IAAI,kBAAmB,mBAAY,OAAZ,CAAvB,C;QACI,YAA6B,SAAnB,kBAAmB,EAAS,OAAT,C;QAC7B,cAAuB,+BAAqB,KAArB,C;QACvB,IAAI,eAAJ,C;UACI,IAAI,aAAI,uBAAc,KAAd,CAAR,C;YACI,UAAQ,+BAAqB,aAAI,EAAzB,C;iBACL,IAAI,aAAI,uBAAc,KAAd,CAAR,C;YACH,UAAQ,+BAAqB,aAAI,EAAzB,C;YAIhB,IAAI,eAAJ,C;UACI,gBAAgB,QAAS,oBAAW,OAAX,C;UACzB,kCAAkC,eAAU,4CAAmC,SAAnC,EAA8C,OAA9C,C;UAC5C,4BhDhFhB,agDgF6C,OhDhF7C,EgDgFwD,2BhDhFxD,C;;IgDoFI,OAAO,4B;EACX,C;mDAEA,kD;IAa6B,UAgBlB,M;IAvBP,wBAAwB,mCAAqB,IAArB,EAA2B,QAA3B,EAAqC,WAArC,GAAoD,gBAAc,SAAd,CAApD,C;IAExB,wBAAgC,IAAhC,C;IACA,IAAI,mBAAJ,C;MACI,kBAAgB,qBAAc,iBAAK,WAAL,CAAd,C;KAGK,mC;IAAzB,OAAyB,cAAzB,C;MAAyB,kC;MACrB,aAAa,iBAAK,gBAAL,C;MACb,aAAa,qBAAc,MAAd,C;MACb,IAAI,uBAAJ,C;QACI,kBAAgB,M;QAChB,Q;OlDjQZ,IAAI,EkDoQU,eAAc,KAAd,KAAsB,MAAO,KlDpQvC,CAAJ,C;QkDsQuB,U;QlDrQnB,ckDoQQ,mFACQ,SAAG,uDAAH,WAAkC,WAAlC,OADR,C;QlDnQR,MAAM,2BAAsB,OAAQ,WAA9B,C;OkDsQF,cAAc,0BAAmB,eAAnB,EAAkC,MAAlC,C;MACd,kBAAgB,qBAAc,OAAd,C;;IAGb,IAAI,uBAAJ,C;MACO,SAAV,uBAAU,cAAK,eAAL,C;;MAEA,SAAV,uBAAU,qB;;IAHd,a;EAKJ,C;6CAEA,kB;IAIc,UAEc,M;IALxB,aAAa,gB;IACb,iBAAiB,c;IACjB,YAAY,C;IACF,wB;IAAV,OAAU,cAAV,C;MAAU,mB;MACN,IAAI,CAAC,UAAW,mBAAY,CAAZ,CAAhB,C;QACI,aAAgB,cAAhB,EAAgB,sBAAhB,S;QAAA,UhDjIZ,agDiIuB,ChDjIvB,EAAS,KAAT,C;OgDmIQ,MAAO,WAAI,wBAAW,WAAI,CAAJ,CAAX,CAAJ,C;;IAEX,OAAO,M;EACX,C;kDAEA,wB;IACI,IAAI,KAAM,UAAV,C;MAAqB,OAAO,W;IAE5B,YAAY,I;IAEZ,UAAU,oCAAe,aAAI,iBAAU,gBAAO,KAAP,EAAc,KAAd,CAAd,C;IlDrS7B,IAAI,EkDsSM,MAAM,KlDtSZ,CAAJ,C;MACI,ckDqSqB,yB;MlDpSrB,MAAM,2BAAsB,OAAQ,WAA9B,C;KkDqSN,cAAc,gB;IACd,UAAU,KAAM,W;IAChB,UAAU,KAAM,W;IAChB,OAAO,GAAI,UAAX,C;MACI,SAAS,GAAI,O;MACb,SAAS,GAAI,O;MACb,YAAY,gBAAK,KAAL,IAAa,EAAb,I;MACZ,OAAQ,WAAI,KAAJ,C;;IAEZ,OAAO,O;EACX,C;oDAEA,+C;IAQoB,Q;IADhB,aAAa,oB;IACG,0B;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MACZ,eAAe,OAAQ,S;MACvB,IAAI,CAAC,MAAO,gBAAS,QAAT,CAAZ,C;QACI,IAAI,QAAS,SAAb,C;UACI,IAAI,iBAAY,mBAAZ,KAAmC,iCAA0B,IAA1B,EAAgC,OAAQ,IAAxC,EAA6C,QAA7C,CAAvC,C;YACI,MAAO,WAAI,QAAJ,C;;IAKvB,OAAO,M;EACX,C;yDAEA,+B;IAII,SAAE,aAAI,sBAAa,GAAb,CAAJ,IAAyB,IAAK,mBAAU,QAAV,CAAhC,C;;EAEyB,sE;IAAqB,gB;IAAqB,sC;;;;;;;;;;;;;EApZ3E,sC;IAAA,qC;MAAA,oB;KAAA,8B;;ECdA,uB;IACI,sBAAuD,I;IACvD,yBAA8B,gB;;iDAE9B,iE;IAMI,IAAI,2BAAJ,C;MAA0B,M;IpDsuBvB,kBAAS,gB;IA2FA,Q;IAAA,OoDh0BG,YpDg0BH,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MAhrBT,sB;;QAuHS,U;QAAA,4B;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UAAM,IoDpQM,OpDoQQ,SoDpQL,SAAS,KAAZ,EpD6zBQ,OoD7zBwB,aAAhC,KAAgD,OpDoQxC,SoDpQ2C,IAAH,EAAU,aAAI,EAAd,CpDoQtD,C;YAAwB,qBAAO,S;YAAP,uB;;QAC9C,qBAAO,I;;;MAwjBe,IAhrBtB,kBoD7IY,IAAqF,IpD6zB3E,C;QAAwB,WAAY,WAAI,OAAJ,C;;IAorBnD,oBAAM,iBAAa,wBAnrBnB,WAmrBmB,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,SA1vBN,WA0vBM,W;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,aAAY,WoDvjDD,6BAAgB,8CpDujDD,IoDvjDC,qBpDujDf,C;;IoD5jDZ,sBpD6jDG,a;EoDvjDP,C;0CAEA,Y;IACI,mBAAmB,c;IpDyxDP,Q;IAAA,OoDxxDZ,sBpDwxDY,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MAAA,U;MAAA,SAAa,OoDvxDf,GAAG,YpDuxDD,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;QGr9CT,U;QADP,YAAY,uBHs9CiB,SGt9CjB,C;QACL,IAAI,aAAJ,C;UACH,6B;UACA,yBHm9CyB,SGn9CzB,EAAS,MAAT,C;UACA,e;;UAEA,c;;QALJ,MiDjUyD,gBpDsxD5B,OoDtxDyC,GAAN,apDsxDnC,SoDtxDmC,CAAP,C;;;IAGrD,OAAO,Y;EACX,C;wCAEA,Y;IAC2B,gBAAhB,sB;IAAgB,uDAAI,qB;aAAO,mB;KAAX,C;IpDi+CpB,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,2B;IAAb,OAAa,cAAb,C;MAAa,sB;MACT,WAAY,WAxEwC,SAwEpC,CAAU,IAAV,CAAJ,C;;IoDziDZ,OpD0iDG,W;EoDziDP,C;EAEiB,kD;IAAjB,oB;IACI,Y;IACA,0B;;EAGI,oE;IAKyB,UAAqB,M;IAH1C,IAAI,cAAc,UAAlB,C;MAA+B,OAAO,C;IACtC,IAAI,UAAJ,C;MAAgB,OAAO,C;IACvB,IAAI,UAAJ,C;MAAgB,OAAO,E;IACvB,OAAO,0BAAc,kDAAd,EAAmC,sDAAnC,GAA0D,GAA1D,C;EACX,C;EACA,gF;IAGI,kC;MAAA,qBAAoD,I;IAE7C,Q;IAAA,IAAI,0BAAJ,C;MnD1BnB,IAAI,CmD2BoB,EAAG,mBAAU,QAAV,CnD3B3B,C;QACI,cmD0B8C,uD;QnDzB9C,MAAM,8BAAyB,OAAQ,WAAjC,C;OmD0ByB,OAAnB,kBAAmB,CAA+B,eAAxB,EAAG,oBAAW,QAAX,CAAqB,CAA/B,C;;MAGN,mBAAb,eAAG,QAAH,CAAa,C;;IALjB,W;EAOJ,C;gDApBJ,iB;IAsBI,Q;IArBA,qE;IAOA,mD;IAcA,gD;MpDkvDQ,U;MAAA,wB;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QoDjvDJ,UAAU,kBACN,SAAS,OAAT,EpDgvDa,OoDhvDK,QAAlB,EpDgvDa,OoDhvDmB,mBAAhC,CADM,EAEN,SAAe,QAAf,EpD+uDa,OoD/uDW,QAAxB,EpD+uDa,OoD/uDyB,mBAAtC,CAFM,EpDivDO,OoD9uDR,UAHC,C;QAKV,IAAI,QAAO,CAAX,C;UAEI,MAAM,kBACF,SAAS,OAAT,EpDyuDS,OoDzuDS,SAAlB,CADE,EAEF,SAAe,QAAf,EpDwuDS,OoDxuDe,SAAxB,CAFE,EpD0uDO,OoDvuDJ,UAHH,C;SAMV,IAAI,QAAO,CAAX,C;UACI,OAAO,G;;KAGf,OAAO,C;EACX,C;;;;;;2CAGJ,wB;IACI,YAAY,4BAAM,CAAN,EAAS,SAAT,C;IACZ,oBAAoB,yBAAkB,KAAlB,C;IACpB,sBAAgB,aAAI,aAAJ,EAAmB,KAAnB,C;EACpB,C;8CAEA,iB;IACqB,gBAAb,mB;IAAJ,InC6IG,qBAAgB,SAAK,UmC7IxB,C;MACI,OAAO,sBAAgB,K;KAE3B,YAA4B,aAAhB,sBAAgB,EAAa,KAAb,C;IAC5B,IAAI,QAAQ,CAAZ,C;MAAe,QAAc,CAAN,K;IACvB,OAAO,K;EACX,C;;;;;;EClGJ,qB;IAAA,yB;IACI,4BAA4B,6B;;EAGjB,0C;IAAA,wB;MACH,OAAI,QAAQ,CAAR,IAAa,QAAQ,SAAE,KAA3B,GACe,YAAX,oCAAE,KAAF,EAAW,CADf,GAGI,C;IACR,C;;qCANJ,a;IACI,OAAO,wB;EAMX,C;EAGW,4D;IAAA,qB;MAAE,yDAAkB,EAAlB,E;IAAwB,C;;qCADrC,6B;IACI,OAAO,0C;EACX,C;+CAEA,8B;IACI,qBAAqB,oB;IACrB,aAAU,CAAV,MAAkB,UAAlB,M;MACI,YAAY,OAAO,CAAP,C;MACZ,IAAI,CAAC,cAAe,mBAAY,KAAZ,CAApB,C;QACI,YAAwB,gB;QAAxB,clD2NZ,akD3N2B,KlD2N3B,EAAS,KAAT,C;OkDzNQ,uCAAe,KAAf,EAAwB,WAAI,CAAJ,C;;IAG5B,OAAO,c;EACX,C;EA1B4B,0C;IAAY,Q;EAAE,C;;;;;;;EAD9C,iC;IAAA,gC;MAAA,e;KAAA,yB;;ECMqB,6F;IA+CjB,uC;IA9CA,sB;IAIA,0C;IAGA,oBAA2C,iBAAU,QAAV,C;IAC3C,mCAA8C,0DAAqB,aAArB,EAA6B,eAA7B,C;IAC9C,mBAAmC,0DAAqB,aAArB,EAA6B,aAA7B,C;IAEnC,yBAA0C,I;IAC1C,uBAA6C,I;;EAIjC,sF;IAAA,wB;MACJ,IAAI,4CAAJ,C;QACI,uCAAgB,sC;OADpB,OAGA,oDAAgB,KAAhB,C;IACJ,C;;;;SALA,Y;MAAQ,mE;;;8CAOZ,Y;IACI,IAAI,aAAO,aAAI,UAAM,MAAV,CAAX,C;MACI,WAAW,aAAO,oBAAW,UAAM,MAAjB,C;MAClB,OAAO,uBAAU,cAAK,IAAL,C;WACd,IAAI,8BAAJ,C;MACH,IAAI,qCAAkB,KAAlB,KAA0B,aAAO,WAArC,C;QACI,OAAO,uBAAU,qB;;QAEjB,wBACI,qDAAW,qCAAX,C;QACJ,OAAO,uBAAU,cAAK,iBAAL,C;;WAElB,IAAI,uBAAJ,C;MACH,OAAO,4BAAe,uBAClB,aADkB,EAElB,iBAFkB,EAGlB,gCAHkB,EAIlB,gBAJkB,C;KAO1B,OAAO,uBAAU,qB;EACrB,C;EAEA,qC;IAAA,yC;;kEACI,+B;IACI,sBAAsB,oBAAgB,IAAhB,EAAsB,WAAtB,EAAmC,IAAnC,EAAyC,IAAzC,EAA+C,KAA/C,C;IACtB,oCAAkC,iBAAU,aAAV,C;IAClC,OAAO,e;EACX,C;qDAEA,yB;IAIsB,Q;IAHlB,aAAa,c;IACb,mBAAmB,C;IACnB,8BAA8B,C;IACZ,+B;IAAlB,OAAkB,cAAlB,C;MAAkB,2B;MACd,aAAU,CAAV,MAAkB,SAAlB,M;QACI,UAAO,0BAA0B,CAA1B,I;QAAP,YAAsC,Y;QAAtC,MnD8KhB,aAAI,GAAJ,EAAS,KAAT,C;;MmD5KY,mC;MACA,oDAA2B,SAA3B,I;;IAEJ,OAAO,M;EACX,C;;;;;;;EAnBJ,iD;IAAA,gD;MAAA,+B;KAAA,yC;;;;;;;ECjDJ,2B;IAAA,+B;;EACsB,yE;IAOd,mD;IANA,gC;IACA,4B;IACA,0B;;sDAEA,Y;IAAyB,Q;IAAA,iDAAY,E;;EAErC,iD;IAAA,qD;;mEACI,wC;IAY+C,gB;IAP3C,IAAI,mBAAmB,aAAvB,C;MACI,OAAO,I;KtDSvB,IAAI,EsDPgB,kBAAkB,0BAAoC,UAAO,EAAP,EAAW,CAAX,EAAjB,gBAAM,YAAN,KAAM,CAAN,CAArC,CtDOhB,CAAJ,C;MACI,csDPY,2F;MtDQZ,MAAM,8BAAyB,OAAQ,WAAjC,C;KsDLE,OAAO,gCAAY,YAAZ,EAA0B,OAA1B,EAAmC,CAAC,oDAAD,sCAAnC,C;EACX,C;sEAEA,4B;IAWQ,IACA,IADA,EAEA,M;ItDbhB,IAAI,CsDCgB,+BAAgB,KAAM,aAAtB,CtDDpB,C;MACI,csDCY,yDAAsD,sBAAtD,eAAiF,kBAAjF,M;MtDAZ,MAAM,8BAAyB,OAAQ,WAAjC,C;KAFV,IAAI,EsDIgB,gCAAsB,KAAM,WAAN,QAAtB,IAAkD,YAAM,WAAN,EAAoB,oBAApB,CtDJlE,CAAJ,C;MACI,gBsDIY,iDAA8C,sBAA9C,gEAA0G,oBAA1G,yBAAmI,gBAAnI,O;MtDHZ,MAAM,8BAAyB,SAAQ,WAAjC,C;KAFV,IAAI,EsDOgB,gCAAoB,KAAM,WAAN,QAApB,IAA8C,KAAM,WAAN,IAAkB,oBtDPhF,CAAJ,C;MACI,gBsDOY,iDAA8C,sBAA9C,oDAA8F,oBAA9F,yBAAqH,gBAArH,O;MtDNZ,MAAM,8BAAyB,SAAQ,WAAjC,C;KsDQE,OAAO,gCACH,sBADG,EAEH,+CAAc,KAAM,WAFjB,EAGH,mDAAY,KAAM,WAHf,C;EAKX,C;;;;;;;EA/BJ,6D;IAAA,4D;MAAA,2C;KAAA,qD;;;;;;;EAyCA,8E;IAAA,0B;MACqB,Q;MAAV,U;MAAU,gBAAV,iB;MvDyGR,sB;;QAuHS,U;QAAA,6B;QAAhB,OAAgB,gBAAhB,C;UAAgB,2B;UAAM,IuDhOU,OvDgOI,OuDhOD,KAAH,UvDgOV,C;YAAwB,qBAAO,O;YAAP,uB;;QAC9C,qBAAO,I;;;MuDjOQ,KAAU,OvDyGzB,kBuDzGe,U;QAAA,a;;8CAC4B,O;QAA2D,kBAAV,iB;QvD48CrF,kBAAM,iBAAa,qCAAwB,EAAxB,CAAb,C;QAuEA,U;QAAA,+B;QAAb,OAAa,gBAAb,C;UAAa,wB;UACT,WAAY,WuDphD4F,MvDohD9E,IuDphDqF,KAAP,MvDohD5F,C;;QCp8C6B,MAAM,2BAA8B,CsDhF5D,SvDqhDd,WCr8C0E,YAA9B,C;;MsDjF3C,a;IAEJ,C;;sDATJ,mE;IAYQ,UAWY,MAXZ,EAWA,M;IAjBJ,oF;IvD0GG,sB;;MAuHS,U;MAAA,SuD3NJ,WvD2NI,W;MAAhB,OAAgB,gBAAhB,C;QAAgB,2B;QAAM,IuD3NS,OvD2NK,OuD3NF,SAAS,KAAZ,EAAgC,wBAAhC,KAAgD,OvD2N3C,OuD3N8C,IAAH,EAAU,aAAI,EAAd,CvD2NzD,C;UAAwB,qBAAO,O;UAAP,uB;;MAC9C,qBAAO,I;;;IuD5NC,IvDoGR,kBuDpGY,IAAwF,IAAxF,IACA,0BAAa,cAAK,SAAL,CAAb,QADJ,C;MAII,+CAAa,cAAK,SAAL,CAAb,C;;MAEA,yBAAkB,WAAY,aAA9B,C;;IAPR,mB;IAUA,OAAiB,wBACb,QADa,EAEb,WAAY,SAAZ,WAAY,WAAZ,iEAAoD,kBAAkB,WAAY,aAA9B,CAFvC,EAGb,WAAY,cAHC,EAMG,sBAAZ,YAAkC,QAAY,sBAAZ,EAAsC,wBAAtC,CzC4CvC,GyC9CC,kBzC8CD,GAA+B,IyClDjB,C;EASrB,C;;;;;;;EAzEJ,uC;IAAA,sC;MAAA,qB;KAAA,+B;;ECKA,0B;IACI,yBAA8B,c;IAC9B,wBAA6B,gB;IAC7B,+BAAoC,c;;EASzB,8G;IAAA,oC;IAAA,8C;IAAA,0C;IAAS,uB;;oEACZ,Y;IACI,Q;IAAA,mE;IACA,IAAI,mEAAgB,sBAAhB,EAA6B,QAAjC,C;MACI,0CAAgB,cAAO,sBAAP,C;MAChB,wCAAa,sBAAb,C;KAER,C;;;;;qDAdR,mC;IAMiB,Q;IALb,IAAI,CAAC,sBAAgB,mBAAY,SAAZ,CAArB,C;MACI,sC;MAAA,YAA6B,e;MrDgOrC,sBqDhOwB,SrDgOxB,EAAS,KAAT,C;MqD/NQ,iBAAU,SAAV,C;KAGJ,aAAa,yCAAgB,SAAhB,4BAAgC,YAAhC,Q;IACb,gF;EASJ,C;EAIyC,mE;IAAA,4C;;+DAC7B,a;IACI,CAAE,eAAQ,uBAAR,C;EACN,C;;;;;8CALZ,iC;IAEQ,Q;IADJ,IAAI,sBAAgB,mBAAY,SAAZ,CAApB,C;MACI,yCAAgB,SAAhB,oG;KAMR,C;oDAEA,uB;IxDuwDgB,Q;IAAA,OwDtwDZ,sBAAgB,KxDswDJ,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MwDtwDgC,4CxDswDnB,OwDtwDmB,C;;IAC5C,qBAAe,WAAI,WAAJ,C;EACnB,C;yCAEA,qB;IxDkwDgB,Q;IAAA,OwDjwDZ,qBxDiwDY,W;IAAhB,OAAgB,cAAhB,C;MAAgB,yB;MwDjwD4B,+BxDiwDf,OwDjwDe,Y;;EAC5C,C;EAG8D,sG;IAAA,0C;IAAA,8C;;iFACtD,iB;IACI,0CAAS,sBAAT,EAAoB,KAApB,C;EACJ,C;;;;;uDAJR,kC;IAUI,Q;IATA,mBAAmB,WAAY,yBAAgB,SAAhB,4E;IAM/B,IAAI,CAAC,4BAAsB,mBAAY,SAAZ,CAA3B,C;MACI,4C;MAAA,YAAmC,6B;MrDqL3C,sBqDrL8B,SrDqL9B,EAAS,KAAT,C;KqDnLI,+CAAsB,SAAtB,8BAAsC,YAAtC,Q;EACJ,C;4CAEA,qB;IAE8B,Q;IAD1B,IAAI,4BAAsB,mBAAY,SAAZ,CAA1B,C;MACI,CAAsB,OAAtB,4BAAsB,cAAO,SAAP,CAAtB,yC;KAER,C;;;;;;ECnDe,4C;IAA6C,uB;IAE5D,cAAsC,kBAAc,IAAd,C;IACtC,cAAsC,kBAAc,IAAd,C;IACtC,+BACgD,kBAAc,GAAd,C;IAChD,qC;IACA,mC;IAEA,0BAA4C,kBAAc,KAAd,C;IAC5C,wBAAsD,kBAAc,IAAd,C;IACtD,qBAAqC,kBAAc,eAAM,WAApB,C;IACrC,iBAAkC,kBAAc,GAAd,C;IAClC,qBAAsC,kBAAc,GAAd,C;IACtC,sBAAuC,kBAAc,GAAd,C;IACvC,qBAAsC,kBAAc,GAAd,C;IACtC,sBAAuC,kBAAc,GAAd,C;IACvC,uBAAwC,kBAAc,GAAd,C;IACxC,gBAAqB,kBAAuB,IAAvB,C;IACrB,qBAA0B,kBAA4B,IAA5B,C;IAC1B,4BACiC,kBAAc,IAAd,C;IACjC,6BAAkC,kBAAc,IAAd,C;IAClC,2BAAgC,kBAAc,IAAd,C;IAChC,mBAAwB,kBAAc,eAAM,MAApB,C;IACxB,mBAAwB,kBAAc,eAAM,MAApB,C;IAoBpB,IAAK,SAAO,WAAI,MAAJ,C;IACZ,IAAK,cAAY,WAAI,WAAJ,C;IAEjB,iCAA4B,kBAAc,oCAA6B,WAA7B,CAAd,C;IAC5B,+BAA0B,kBAAc,kCAA2B,WAA3B,CAAd,C;IAE1B,kF;IAGA,kBAAa,oBACG,6BAAZ,IAAK,SAAO,CADH,EAEQ,6BAAjB,IAAK,cAAY,CAFR,EAGF,6BAAP,WAAO,CAHE,EAIF,6BAAP,WAAO,CAJE,EAKM,6BAAf,mBAAe,CALN,EAMQ,6BAAjB,qBAAiB,CANR,EAOiB,6BAA1B,8BAA0B,CAPjB,EAQe,6BAAxB,4BAAwB,CARf,EASe,6BAAxB,4BAAwB,CATf,EAUU,6BAAnB,uBAAmB,CAVV,EAWX,oBAAW,4BAAX,C;;2DAtCN,uB;IACiB,IAAN,I;IAAA,QAAM,WAAN,M;WACH,M;QAAoB,uC;QAApB,K;WACA,O;QAAqB,sC;QAArB,K;WACA,K;WAAA,Q;QAAuC,wC;QAAvC,K;;QAHG,K;;IAAP,W;EAKJ,C;yDAEA,uB;IACI,QAAM,WAAN,M;WACI,M;WAAA,O;QAAuC,OAAO,+B;WAC9C,K;QAAmB,OAAO,+B;WAC1B,Q;QAAsB,OAAO,4B;cACrB,MAAM,sBAAiB,4BAAyB,WAA1C,C;;EAEtB,C;2CA0BA,Y;IACI,kB;EACJ,C;wCAEA,Y;IAcsB,UA6CC,MA7CD,EAuDY,M;IApE9B,kBAAkB,c;IAClB,WAAY,kBAAS,mBAAM,KAAf,C;IACZ,IAAI,uBAAmB,MAAvB,C;MACI,WAAY,kBAAS,mBAAM,gBAAf,C;KAGhB,QAAQ,2BAAO,MAAP,C;IACR,M;IACA,M;IACA,M;IACA,M;IACA,S;IACA,O;IACkB,OAAZ,kBAAY,M;IACd,kG;MACI,KAAK,G;MACL,KAAK,E;MACL,QAAQ,G;MACR,KAAK,K;MACL,MAAM,C;MACN,KAAK,G;WAET,kG;MACI,QAAQ,G;MACR,KAAK,K;MACL,MAAM,C;MACN,KAAK,G;MACL,KAAK,G;MACL,KAAK,E;;MAED,MAAM,sBAAiB,qCAA4B,kBAAY,MAAxC,CAAjB,C;IAGlB,eAAgC,I;IAChC,IAAI,sBAAkB,MAAtB,C;MACI,WAAW,oBAAe,EAAf,EAAmB,EAAnB,EAAuB,EAAvB,EAA2B,EAA3B,C;MACX,iBAAI,4CAAW,cAAX,EAAsB,QAAS,cAA/B,CAAJ,C;MACA,iBAAI,4CAAW,gBAAX,EAAsB,QAAS,cAA/B,CAAJ,C;KAIJ,qBAAqB,QAAQ,C;IAC7B,qBAAqB,MAAM,C;IAE3B,IAAI,sBAAJ,C;MAEI,aAAa,IAAK,OAAO,M;MACzB,IAAI,EAAE,kBAAkB,MAAO,UAA3B,CAAJ,C;QAEI,aAA4B,IAAK,OAAO,M;QACxC,IAAI,kBAAkB,MAAO,UAA7B,C;UACI,SAAS,gB;UACT,sBAAU,MAAV,W;YACI,MAAO,WAAI,EAAJ,C;;SAIf,UAAQ,C;QACG,0B;QAAX,OAAW,gBAAX,C;UAAW,sB;UACP,kBAAkB,MAAM,cAAN,IAAwB,MAAM,c;UAChD,YAAY,mBAAO,MAAI,MAAO,KAAlB,C;UACZ,kBAAkB,uBAAgB,GAAhB,C;UAClB,iB;UACA,YAAY,iBACJ,KADI,EAEJ,WAFI,EAGA,WAAJ,GAAiB,mBAAe,MAAhC,GAA2C,GAHvC,C;UAKM,SAAZ,kBAAY,M;UACd,sG;YAAuC,wCAAmB,KAAnB,EAA0B,GAA1B,EAA+B,EAA/B,C;eACvC,sG;YAAuC,wCAAmB,KAAnB,EAA0B,EAA1B,EAA8B,GAA9B,C;;YAC/B,MAAM,sBAAiB,qCAA4B,kBAAY,MAAxC,CAAjB,C;UAGlB,WAAY,WAAW,WAAI,KAAJ,C;;QAMnC,IAAI,gBAAJ,C;MACI,WAAY,WAAW,WAAI,QAAJ,C;KAE/B,C;wCAEA,8C;IAuBsB,Q;IArBlB,eAAgC,I;IAChC,IAAI,uBAAmB,MAAvB,C;MACI,WAAW,oB;MACX,iBAAI,4CAAW,kBAAX,EAA0B,QAAS,cAAnC,CAAJ,C;MACA,iBAAI,4CAAW,gBAAX,EAAsB,QAAS,cAA/B,CAAJ,C;KAGJ,gBAA4B,I;IAC5B,IAAI,wBAAoB,MAAxB,C;MACI,YAAY,cAAU,KAAV,C;MACZ,iBAAI,4CAAW,gBAAX,EAAsB,SAAU,YAAhC,CAAJ,C;KAGJ,eAAgC,I;IAChC,IAAI,iBAAiB,CAArB,C;MACI,WAAW,oB;MACX,iBAAI,4CAAW,kBAAX,EAA0B,QAAS,cAAnC,CAAJ,C;MACA,iBAAI,4CAAW,kBAAX,EAA0B,QAAS,cAAnC,CAAJ,C;KAGJ,iBAAiB,mBAAe,M;IACd,OAAZ,kBAAY,M;IACd,iD;MACI,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,CAAC,UAAL,C;QACd,QAAS,KAAK,WAAI,GAAJ,C;OAElB,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,cAAJ,C;QACd,QAAS,KAAK,WAAI,GAAJ,C;cAGtB,kD;MACI,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,UAAJ,C;QACd,QAAS,KAAK,WAAI,GAAJ,C;OAElB,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,CAAC,cAAL,C;QACd,QAAS,KAAK,WAAI,GAAJ,C;cAGtB,gD;MACI,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,GAAJ,C;QACd,QAAS,KAAK,WAAI,CAAC,UAAL,C;OAElB,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,GAAJ,C;QACd,QAAS,KAAK,WAAI,cAAJ,C;cAGtB,mD;MACI,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,GAAJ,C;QACd,QAAS,KAAK,WAAI,UAAJ,C;OAElB,IAAI,gBAAJ,C;QACI,QAAS,KAAK,WAAI,GAAJ,C;QACd,QAAS,KAAK,WAAI,CAAC,cAAL,C;;MAGd,MAAM,sBAAiB,qCAA4B,kBAAY,MAAxC,CAAjB,C;IAGlB,QAAQ,iB;IACR,IAAI,gBAAJ,C;MACI,CAAE,WAAW,WAAI,QAAJ,C;KAGjB,IAAI,gBAAJ,C;MACI,CAAE,WAAW,WAAI,QAAJ,C;KAGjB,IAAI,iBAAJ,C;MACI,SAAU,gBAAO,WAAY,EAAnB,EAAsB,WAAY,EAAlC,C;MACV,SAAU,6BAAoB,8BAA0B,MAA9C,C;MACV,SAAU,2BAAkB,4BAAwB,MAA1C,C;MACV,SAAU,gBAAO,4BAAwB,MAA/B,C;MACV,CAAE,WAAW,WAAI,SAAU,UAAd,C;KAGjB,CAAE,kBAAS,mBAAM,KAAf,C;IACF,OAAO,C;EACX,C;6CAEA,Y;IACW,Q;IAAA,IAAI,yBAAmB,MAAvB,C;MACY,OAAf,mBAAe,M;;MAEf,U;;IAHJ,W;EAKJ,C;gDAEA,Y;IACI,OAAO,0BAAmB,oBAAgB,M;EAC9C,C;kDAEA,Y;IAE6B,UAAlB,M;IADP,eAAe,0B;IACU,OAAZ,kBAAY,M;IACrB,iD;MAAoB,0BAAa,CAAC,QAAd,EAAwB,GAAxB,C;SACpB,kD;MAAqB,0BAAa,QAAb,EAAuB,GAAvB,C;SACrB,gD;MAAmB,0BAAa,GAAb,EAAkB,CAAC,QAAnB,C;SACnB,mD;MAAsB,0BAAa,GAAb,EAAkB,QAAlB,C;;MACd,MAAM,sBAAiB,qCAA4B,kBAAY,MAAxC,CAAjB,C;IALlB,a;EAOJ,C;8CAEA,qB;IACI,wBAAwB,qBAAiB,M;IACzC,uBAA2B,yBAAJ,GAA+B,8BAAkB,SAAlB,CAA/B,GAAiE,sBAAa,K;IACrG,OAAO,4BAAsB,aAAI,gBAAJ,C;EACjC,C;4CAEA,Y;IACI,OAAO,yBAAmB,MAAnB,IAA4B,0BAAoB,M;EAC3D,C;6CAEA,Y;IACI,OAAO,yB;EACX,C;8CAEA,Y;IACI,OAAO,0B;EACX,C;4CAEA,Y;IACI,OAAO,wB;EACX,C;EA9OI,oE;IACgF,Q;IAAA,uE;;;;;;;ECvDjE,iC;IAEnB,oB;IADA,yB;;;SAAA,Y;MAAA,yB;;;2DAGA,uB;IAgBuB,UAOH,M;IAtBhB,aAAa,SAAK,O;IAElB,oBAAoB,iB;IAGpB,gBAAgB,MAAO,U;IACvB,iBAAiB,MAAO,a;IACxB,mBACI,aADJ,EAEI,SAAK,OAFT,EAEiB,SAAK,MAFtB,EAE6B,SAAK,SAFlC,EAE4C,SAF5C,EAGI,MAAO,gBAHX,EAII,UAJJ,EAIgB,SAAK,QAJrB,C;IASI,e;MAAwB,OAAV,SAAU,O;;MACN,OAAV,SAAU,M;IAFtB,uB;IAIA,iBAAiB,eAAe,C;IAEhC,iBAAiB,MAAO,mBAAW,W;IACnB,kBAAK,OAAO,OAAZ,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,2B;MACZ,aAAa,UAAW,O;MAExB,mBAAmB,MAAO,a;MAC1B,qBAAqB,gB;MACrB,IAAI,UAAJ,C;QACI,YAAY,SAAU,KAAV,GAAiB,Y;QAC7B,cAAe,WAAI,iBAAa,KAAb,EAAoB,SAAU,IAA9B,CAAJ,C;QACf,cAAe,WAAI,iBAAa,KAAb,EAAoB,SAAU,IAAV,GAAgB,UAApC,CAAJ,C;QACf,cAAe,WAAI,iBAAa,KAAb,EAAoB,SAAU,OAAV,GAAmB,UAAvC,CAAJ,C;QACf,cAAe,WAAI,iBAAa,KAAb,EAAoB,SAAU,OAA9B,CAAJ,C;;QAEf,YAAY,SAAU,IAAV,GAAgB,Y;QAC5B,cAAe,WAAI,iBAAa,SAAU,KAAvB,EAA6B,KAA7B,CAAJ,C;QACf,cAAe,WAAI,iBAAa,SAAU,KAAV,GAAiB,UAA9B,EAA0C,KAA1C,CAAJ,C;QACf,cAAe,WAAI,iBAAa,SAAU,MAAV,GAAkB,UAA/B,EAA2C,KAA3C,CAAJ,C;QACf,cAAe,WAAI,iBAAa,SAAU,MAAvB,EAA8B,KAA9B,CAAJ,C;;MAGnB,mBAAY,aAAZ,EAA2B,2BAAe,CAAf,CAA3B,EAA8C,2BAAe,CAAf,CAA9C,C;MACA,mBAAY,aAAZ,EAA2B,2BAAe,CAAf,CAA3B,EAA8C,2BAAe,CAAf,CAA9C,C;MAEA,YAAY,cAAU,OAAV,C;MACZ,KAAM,6BAAoB,MAAO,sBAA3B,C;MACN,KAAM,2BAAkB,MAAO,oBAAzB,C;MACN,KAAM,gBAAO,MAAO,cAAc,EAA5B,EAA+B,MAAO,cAAc,EAArB,GAAyB,SAAU,IAAlE,C;MACN,aAAc,WAAW,WAAI,KAAM,UAAV,C;;IAI7B,aAAc,WAAW,WACrB,uDACI,SADJ,EAEI,SAAK,MAAM,iBAFf,EAGI,GAHJ,CADqB,C;IAQzB,IAAI,UAAJ,C;MAEI,kBAAkB,oBAAgB,sBAAa,KAA7B,EAAmC,MAAO,UAA1C,C;MAClB,aAAc,WAAW,WACrB,uDACI,WADJ,EAEI,eAAM,UAFV,EAGI,GAHJ,CADqB,C;KAS7B,WAAY,WAAW,WAAI,aAAJ,C;IACvB,OAAO,MAAO,K;EAClB,C;8CAEA,0F;IAgBsB,IAQF,I;IAbhB,iBAAiB,iBAAW,cAAK,MAAL,C;IAC5B,gBxDm5B4C,MAAW,KwDn5BnC,CxDm5BmC,EwDn5BhC,OxDm5BgC,C;IwDl5BvD,WAAW,aAAa,S;IACxB,QAAQ,MAAO,SAAP,GAAkB,OAAO,C;IACjC,mBAAmB,gB;IACnB,aAAU,CAAV,MAAkB,SAAlB,M;MACI,YAAa,WAAI,IAAI,OAAO,CAAf,C;;IAEjB,IAAI,SAAJ,C;MACiB,QAAb,YAAa,C;KAGjB,aAAa,eAAU,aAAI,YAAJ,EAAkB,OAAlB,C;IAEnB,e;MAAwB,OAAV,SAAU,M;;MACN,OAAV,SAAU,O;IAFtB,oB;IAIA,yBAAyB,YAAY,kBAAkB,C;IACvD,kBAAkB,qBAAqB,S;IAEvC,kBAAkB,SAAU,K;IAC5B,mBAAmB,SAAU,M;IAC7B,oBAAoB,SAAU,O;IAC9B,iBAAiB,SAAU,I;IAE3B,W;IAAA,kBAAmB,MAAnB,qC;MAAA,yB;MACI,QAAQ,sBACJ,WADI,EAEJ,UAFI,EAGJ,eAAe,WAHX,EAIJ,gBAAgB,UAJZ,C;MAMR,CAAE,cAAc,WAAI,GAAJ,C;MAChB,CAAE,YAAY,WAAI,KAAJ,C;MACd,CAAE,WAAW,WAAI,CAAJ,C;MAEb,IAAI,UAAJ,C;QACI,eAAe,W;;QAEf,cAAc,W;;MAElB,IAAI,QAAK,CAAT,C;QAEI,IAAI,UAAJ,C;UACI,eAAe,e;;UAEf,cAAc,e;;;EAI9B,C;8CAEA,qB;IACI,WAAW,oBAAe,EAAG,EAAlB,EAAqB,EAAG,EAAxB,EAA2B,EAAG,EAA9B,EAAiC,EAAG,EAApC,C;IACX,IAAK,cAAc,WAAI,GAAJ,C;IACnB,IAAK,cAAc,WAAI,SAAK,MAAM,iBAAf,C;IACnB,CAAE,WAAW,WAAI,IAAJ,C;EACjB,C;;;;;;EC5JkC,gG;IA0GlC,+C;IAnGA,2BACA,KADA,EAEA,eAFA,C;IAHA,gC;IAQA,+B;IAEA,uBAC8B,G;IAG9B,8B;IAGI,qBAAqB,mB;IACrB,kBAAkB,gBAAY,MAAM,oBAAlB,EAAmC,iBAAiB,oBAApD,C;IAClB,aAAa,aAAQ,gBAAO,MAAP,EAAe,WAAf,EAA4B,OAA5B,C;IACiB,gBAAzB,MAAO,kB;I3Do+CjB,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,2B;IAAb,OAAa,cAAb,C;MAAa,sB;mBACT,W;M2D3iDI,mBAAmB,O3D2iDG,I2D3iDH,C;M3D2iDX,YAAZ,WAAY,E2D1iDR,6BAAgB,YAAhB,C3D0iDQ,C;;I2D5iDZ,0B3D6iDG,W;I2DziDH,iBAAY,oBAAgB,sBAAa,KAA7B,EAAmC,iBAAnC,C;;;;SAhBhB,Y;MAAA,+B;;SAAA,qB;MAAA,oC;;;EAqBwB,oH;IACpB,gC;IAA0B,kC;IAC1B,kD;IAAuD,8C;;;;;;;EAG7B,2F;IAM1B,mCACA,KADA,EACO,MADP,EACe,MADf,EACuB,OADvB,4CAGA,OAHA,C;IAMA,+B;IAMI,2BAAY,iBAAa,iBAAa,EAA1B,EAA6B,iBAAa,EAAb,GAAiB,oBAAjB,GAAiC,0DAAW,SAAzE,C;;;;SANhB,Y;MAAA,+B;;;;;SACkC,Y;MAAQ,iEAAW,SAAX,GAAsB,C;;;;;SAC5B,Y;MAAQ,wBAAa,E;;;+EAOzD,wB;IACI,oBAAoB,iBAAa,YAAb,EAA2B,iBAAa,EAAb,GAAiB,oBAA5C,C;IACpB,OAAO,sCACH,YADG,EAEH,aAFG,kE;EAMX,C;;;;;;EAGwB,yF;IAMxB,mCACA,KADA,EACO,MADP,EACe,MADf,EACuB,OADvB,0CAGA,OAHA,C;IAMA,+B;I1DDJ,IAAI,C0DMU,CAAC,MAAO,Q1DNtB,C;MACI,c0DK6B,qD;M1DJ7B,MAAM,2BAAsB,OAAQ,WAA9B,C;K0DKwC,gBAAd,MAAO,O;I3Do6CpC,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,Q;IAAA,2B;IAAb,OAAa,cAAb,C;MAAa,sB;MACT,WAAY,WAAc,I2D5+C6B,O3D4+C3C,C;;IAiThB,eAhTO,WAgTQ,W;IACf,IAAI,CAAC,QAAS,UAAd,C;MAAyB,MAAM,6B;IAChB,SAAS,QAAS,O;IAAjC,e2D9xDqB,0DAAW,eAAM,EAAN,C;I3D+xDhC,OAAO,QAAS,UAAhB,C;MACY,WAAS,QAAS,O;MAA1B,Q2DhyDiB,0DAAW,eAAM,IAAN,C;M3DiyD5B,W4DzzDG,MAAO,K5DyzDO,Q4DzzDP,E5DyzDiB,C4DzzDjB,C;;IDuBN,oB3DoyDD,Q;I2DhyDC,2BAAY,iBAAa,iBAAa,EAAb,GAAiB,oBAAjB,GAAiC,aAA9C,EAA6D,iBAAa,EAA1E,C;;;;SAVhB,Y;MAAA,+B;;;;;SACkC,Y;MAAQ,iEAAW,eAAM,CAAN,CAAX,GAAsB,C;;;;;SAC5B,Y;MAAQ,wBAAa,E;;;6EAWzD,wB;IACI,oBAAoB,iBAAa,iBAAa,EAAb,GAAiB,oBAA9B,EAA6C,YAA7C,C;IACpB,OAAO,sCACH,YADG,EAEH,aAFG,mE;EAMX,C;;;;;;EAGJ,6C;IAAA,iD;;mEACI,mD;IAOI,OAAO,6CACH,KADG,EAEH,MAFG,EAGH,MAHG,EAIH,OAJG,EAKH,OALG,C;EAOX,C;iEAEA,mD;IAOI,OAAO,2CACH,KADG,EAEH,MAFG,EAGH,MAHG,EAIH,OAJG,EAKH,OALG,C;EAOX,C;;;;;;;EA/BJ,yD;IAAA,wD;MAAA,uC;KAAA,iD;;;;;;;EE1GuB,+F;IAWvB,6C;IAFA,yBAAc,KAAd,EAAqB,KAArB,EAA4B,OAA5B,C;IAPA,oB;IACA,oB;IACA,kB;IACA,wB;IAEA,8B;;;SAAA,Y;MAAA,4B;;;EAIA,2C;IAAA,+C;IACI,mBAAwB,E;IAExB,2BAAsC,G;IACtC,wBAAmC,G;;sEAEnC,6B;IACW,Q;IACH,e;MAAc,wBACV,wBAAiB,KAAM,UADb,EAEV,2BAAoB,KAAM,UAFhB,C;;MAIN,wBACJ,2BAAoB,KAAM,UADtB,EAEJ,wBAAiB,KAAM,UAFnB,C;IALZ,W;EAUJ,C;;;;;;;EAjBJ,uD;IAAA,sD;MAAA,qC;KAAA,+C;;;;;;;EClBJ,0C;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,wC;IAAA,2C;;IAKI,8E;IACA,0E;;;EADA,oD;IAAA,8B;IAAA,4C;;;EACA,kD;IAAA,8B;IAAA,0C;;;;;;;EANJ,oC;IAAA,6F;;;EAAA,yC;IAAA,a;MAAA,kB;QAAA,iD;MAAA,gB;QAAA,+C;MAAA,oG;;;;ECUA,qB;IAoGI,iC;IApGuB,uB;IAEvB,aAAqB,K;;;;SAIjB,Y;MAAQ,gBAAK,M;;;;;SAGb,Y;MAAQ,gBAAK,K;;;2CAEjB,Y;IACI,OAAO,SAAK,W;EAChB,C;uCAEA,Y;IACI,0BAAa,mBAAM,OAAnB,C;IAEA,kBAAkB,oBAAgB,sBAAa,KAA7B,EAAmC,SAAK,KAAxC,C;IAClB,0BAAa,SAAK,YAAlB,EAA+B,SAAK,MAAM,iBAA1C,C;IAGA,iBAAiB,iB;IACjB,UAAW,YAAY,WAAI,8CAAe,SAAK,cAApB,EAAmC,GAAnC,CAAJ,C;IAEvB,QAAQ,SAAK,O;IACb,IAAI,yBAAJ,C;MACI,YAAY,gCACR,CAAE,cADM,EAER,CAAE,sBAFM,EAGR,CAAE,oBAHM,C;MAKZ,UAAW,WAAW,WAAI,KAAM,UAAV,C;KAG1B,iBAAiB,iB;IACjB,UAAW,YAAY,WAAI,8CAAe,CAAE,YAAjB,EAA8B,GAA9B,CAAJ,C;IACvB,gCAAmB,UAAnB,C;IACA,UAAW,WAAW,WAAI,UAAJ,C;IAEtB,IAAI,UAAJ,C;MAGQ,oCAAuB,eAAM,KAA7B,EAAmC,GAAnC,C;MAIA,WAAW,oBAAe,SAAK,YAApB,C;MACX,IAAK,YAAY,WAAI,eAAM,MAAV,C;MACjB,IAAK,cAAc,WAAI,GAAJ,C;MACnB,IAAK,cAAc,WAAI,GAAJ,C;MACnB,iBAAI,IAAJ,C;MAIA,uBAAU,SAAK,cAAf,EAA8B,eAAM,aAApC,EAAkD,GAAlD,C;MAIA,uBAAY,aAAY,aAAI,SAAK,cAAT,CAAxB,EAAiD,eAAM,QAAvD,EAAgE,GAAhE,C;KAIR,iBAAI,UAAJ,C;EACJ,C;0CAEA,4C;IACI,iBACI,uDACI,MADJ,EAEI,WAFJ,EAGI,WAHJ,CADJ,C;EAOJ,C;6CAEA,6B;IACI,iBACI,oDACI,MADJ,EAEI,SAFJ,CADJ,C;EAMJ,C;mDAIA,oD;IAKI,YAAY,cAAU,oBAAV,C;IACZ,KAAM,sBAAa,mBAAM,aAAnB,C;IACN,KAAM,6BAAoB,gBAApB,C;IACN,KAAM,2BAAkB,cAAlB,C;IACN,KAAM,gBAAO,MAAP,C;IACN,OAAO,K;EACX,C;EAEA,+B;IAAA,mC;;uDACI,4C;IAEI,WAAW,oBAAe,MAAf,C;IACX,IAAK,cAAc,WAAI,WAAJ,C;IACnB,IAAK,cAAc,WAAI,WAAJ,C;IACnB,IAAK,cAAc,WAAI,GAAJ,C;IACnB,OAAO,I;EACX,C;oDAEA,6B;IAEI,WAAW,oBAAe,MAAf,C;IACX,IAAK,YAAY,WAAI,SAAJ,C;IACjB,OAAO,I;EACX,C;;;;;;;EAfJ,2C;IAAA,0C;MAAA,yB;KAAA,mC;;;;;;;ECzG0B,iD;IAmD1B,uC;IAlDA,4B;IAKA,oBAAmB,4D;IACnB,4D;IAC0B,Q;IAAA,IAAI,iBAAJ,C;;;;;IAA1B,+B;;;;SAOI,Y;MACI,aAAa,kB;MACb,WAAW,oDAAU,oBAAV,C;MACX,IAAI,iBAAJ,C;QACI,SAAS,iBAAa,MAAO,EAApB,EAAuB,MAAO,EAAP,GAAW,IAAK,EAAL,GAAS,CAA3C,C;OAEb,OAAO,oBAAgB,MAAhB,EAAwB,IAAxB,C;IACX,C;;;;SAGA,Y;MACI,sB;QADI,OAEA,iBAAa,oDAAU,oBAAV,CAAiB,EAA9B,EAAiC,GAAjC,C;;QAFA,OAIA,iBAAa,GAAb,EAAkB,oDAAU,oBAAV,CAAiB,EAAnC,C;;;;;SAIR,Y;MACI,kBAAkB,oBAAgB,gBAAhB,EAA6B,cAA7B,C;MAClB,sBACK,CADiB,oBAAgB,sBAAa,KAA7B,EAAmC,sBAAa,KAAhD,CACjB,gBAAM,gBAAN,CACA,eAAM,WAAN,C;MACL,OAAO,eAAgB,U;IAC3B,C;;;;SAGA,Y;MAAQ,IAAI,iBAAJ,C;QACJ,gBAAgB,c;QADZ,OAEJ,iBAAa,GAAb,EAAkB,SAAU,EAAV,GAAc,CAAhC,C;;QAGA,QAAQ,CAAC,oDAAW,SAAZ,GAAuB,C;QAL3B,OAMJ,iBAAa,GAAb,EAAkB,CAAlB,C;;;;EAGR,qC;IAAA,yC;IACI,4D;IACA,iE;;oDAEA,a;IACW,Q;IACH,IAAE,QAAF,CAAE,CAAF,C;MAA4B,OAAb,sBAAa,K;;MACT,OAAX,iBAAW,oBAAW,CAAE,OAAb,C;IAFvB,W;EAIJ,C;;;;;;;EATJ,iD;IAAA,gD;MAAA,+B;KAAA,yC;;;;;;;ECpDwB,8C;IACxB,kB;IACA,kB;IACA,sB;IAIA,yB;IAEA,uC;IACA,iC;IACA,wC;IAeI,oBAAoB,UAAM,SAAN,GAAiB,UAAM,U;IAC3C,qBAAgB,iBAAa,aAAb,EAA4B,aAA5B,C;IAChB,mCAAoB,iBAAa,gBAAgB,CAA7B,EAAgC,gBAAgB,CAAhD,C;IAEpB,6BAAc,iBAAa,UAAM,SAAnB,EAA6B,UAAM,SAAnC,C;IACd,oCAAqB,iBAAa,UAAM,UAAN,GAAkB,CAA/B,EAAkC,UAAM,UAAN,GAAkB,CAApD,C;;;;SAjBrB,Y;MAAQ,kBAAO,K;;;;;SAGf,Y;MAAQ,iCAAY,aAAI,gCAAJ,C;;;;;SAGpB,Y;MAAQ,2BAAgB,0BAAhB,EAA6B,0BAAY,aAAI,iCAAJ,CAAzC,C;;;;;SAGR,Y;MAAQ,2BAAgB,kBAAhB,EAA+B,0BAA/B,C;;;qCAWZ,Y;IACI,OC6Q+C,CAAC,QD7QzC,UC6QyC,C;ED5QpD,C;;;;;;EEnCa,4B;IAyCb,mC;IAzCc,kB;IACd,kBAAuB,gB;;;;SAGnB,Y;MAEkB,Q;MADd,cAAc,sBAAa,K;MACb,iC;MAAd,OAAc,cAAd,C;QAAc,uB;QACV,sBAAsB,KAAM,kBAAkB,wBAAe,KAAM,UAArB,C;QAC9C,UAAU,OAAQ,aAAI,eAAJ,C;;MAEtB,OAAO,O;IACX,C;;;;SAGA,Y;MAAQ,sBAAS,U;;;2CAErB,wC;IACI,eAAS,WACL,iCACI,SADJ,EAEI,iBAFJ,CADK,C;EAMb,C;mDAEA,gB;IAGkB,Q;IAFd,QAAQ,iB;IAEM,iC;IAAd,OAAc,cAAd,C;MAAc,uB;MACV,iBAAiB,KAAM,kBAAkB,0BAAiB,KAAM,UAAvB,EAAkC,IAAlC,C;MACzC,CAAE,WAAW,WAAI,UAAJ,C;;IAGjB,OAAO,C;EACX,C;EAE8B,oE;IAC1B,0B;IACA,0C;;;;;;;EAGJ,iC;IAAA,qC;;mDACI,+C;IAKI,SAAS,gBAAY,KAAZ,C;IACT,EAAG,kBAAS,SAAT,EAAoB,iBAApB,C;IACH,OAAO,E;EACX,C;;;;;;;EATJ,6C;IAAA,4C;MAAA,2B;KAAA,qC;;;;;;;ECxCiB,+B;IAEjB,oB;IADA,0B;;;SAAA,Y;MAAA,0B;;;yDAGA,uB;IAKe,Q;IAJX,aAAa,SAAK,O;IAElB,oBAAoB,MAAO,cAAc,W;IACzC,iBAAiB,MAAO,WAAW,W;IACxB,gBAAK,eAAL,W;IAAX,OAAW,cAAX,C;MAAW,oB;MACP,kBAAkB,aAAc,O;MAChC,eAAe,UAAW,O;MAC1B,mBAAmB,0BAAmB,EAAnB,EAAuB,MAAO,QAA9B,EAAuC,WAAvC,EAAoD,QAApD,C;MACnB,WAAY,WAAW,WAAI,YAAJ,C;;IAE3B,OAAO,MAAO,K;EAClB,C;mDAEA,8C;IAMI,qBAAqB,oB;IAGrB,cAAe,aAAI,wBAAiB,EAAjB,EAAqB,OAArB,CAAJ,C;IAGf,YAAY,cAAU,EAAG,MAAb,C;IACZ,KAAM,6D;IACN,KAAM,2D;IACN,KAAM,gBAAO,QAAS,OAAO,aAAI,iBAAa,GAAb,EAAkB,QAAS,OAAT,GAAkB,CAApC,CAAJ,CAAvB,C;IACN,cAAe,aAAI,KAAJ,C;IAEf,cAAe,gBAAO,WAAY,OAAnB,C;IACf,OAAO,cAAe,U;EAC1B,C;iDAEA,6B;IACI,QAAQ,iB;IAER,gBAAgB,iBAAa,IAAK,EAAL,GAAS,CAAtB,EAAyB,IAAK,EAAL,GAAS,CAAlC,C;IAEhB,qBAAqB,SAAK,MAAM,iB;IAGhC,qBAAqB,sBAAe,GAAf,EAAoB,GAApB,EAAyB,SAAU,EAAnC,EAAsC,SAAU,EAAhD,C;IACrB,cAAe,cAAc,WAAI,GAAJ,C;IAC7B,cAAe,cAAc,WAAI,cAAJ,C;IAC7B,cAAe,YAAY,WAAI,cAAJ,C;IAE3B,CAAE,WAAW,WAAI,cAAJ,C;IAGb,iBAAiB,WAAY,0BAAiB,SAAjB,C;IAC7B,0BAA0B,8CAAe,iBAAa,GAAb,EAAkB,GAAlB,CAAf,EAAuC,GAAvC,C;IAC1B,UAAW,YAAY,WAAI,mBAAJ,C;IAEvB,CAAE,WAAW,WAAI,UAAJ,C;IAGb,YAAY,sBAAe,GAAf,EAAoB,GAApB,EAAyB,IAAK,EAA9B,EAAiC,IAAK,EAAtC,C;IACZ,KAAM,cAAc,WAAI,GAAJ,C;IACpB,KAAM,cAAc,WAAI,cAAJ,C;IACpB,KAAM,OAAO,0B;IAEb,CAAE,WAAW,WAAI,KAAJ,C;IACb,OAAO,C;EACX,C;;;;;;ECvEgC,wE;IA6JhC,6C;IAxJA,2BAAgB,KAAhB,EAAuB,eAAvB,C;IAHA,oB;IACA,sB;IAIA,+BAA2C,I;IAC3C,iCAA8B,gB;IAC9B,8BAA2B,gB;IAE3B,mBAAkB,K;IAClB,0BAAe,C;IAKf,0BAAe,C;;;;SALf,Y;MAAA,8B;;SACI,oB;MpEsEJ,IAAI,EoErEU,WAAW,CpEqErB,CAAJ,C;QACI,coEtE0B,mD;QpEuE1B,MAAM,2BAAsB,OAAQ,WAA9B,C;OoEtEF,0BAAQ,Q;IACZ,C;;;;SACJ,Y;MAAA,8B;;SACI,oB;MpEiEJ,IAAI,EoEhEU,WAAW,CpEgErB,CAAJ,C;QACI,coEjE0B,mD;QpEkE1B,MAAM,2BAAsB,OAAQ,WAA9B,C;OoEjEF,0BAAQ,Q;IACZ,C;;;;SAGA,Y;MACI,6B;MACA,OAAO,2C;IACX,C;;;;SAGA,Y;MACI,6B;MACA,OAAO,8B;IACX,C;;;;SAGA,Y;MACI,6B;MACA,OAAO,2B;IACX,C;;2DAEJ,Y;IACI,IAAI,gCAAiB,IAArB,C;MACI,yB;KAER,C;uDAEA,Y;IAQc,Q;IAPV,kBAAkB,0DAAW,S;IAC7B,sBAAsB,0DAAW,eAAM,CAAN,CAAX,GAAsB,C;IAC5C,mBAAmB,YAAQ,EAAR,GAAY,e;IAC/B,mBAAmB,CAAC,YAAQ,EAAR,GAAY,WAAb,IAA4B,C;IAE/C,oBAAoB,sBAAa,K;IACjC,qBAAuC,I;IAC7B,kB;IAAV,qC;MAIQ,U;MAHJ,gBAAgB,uBAAU,CAAV,C;MAChB,mBAAmB,iBAAa,eAAe,SAAU,EAAtC,EAAyC,YAAQ,EAAjD,C;MACnB,iBAAiB,oBACb,mCAAsB,+BAAtB,cAAsB,CAAtB,4BAAiD,aADpC,EAEb,YAFa,C;MAKjB,8BAAgB,WAAI,cAAJ,C;MAChB,2BAAa,WACT,qBACI,YADJ,EACkB,YADlB,EAEI,SAAU,EAFd,EAEiB,SAAU,EAF3B,CADS,C;;IAQjB,+BAAgB,0BAAa,eAAM,oBAAgB,aAAhB,EAA+B,sBAAa,KAA5C,CAAN,EAAyD,8BAAzD,CAA0E,U;EAC3G,C;EAM2B,oE;IACvB,iCACI,KADJ,EACW,MADX,EACmB,OADnB,2C;IAKI,gBAAW,MAAO,K;IAClB,gBAAW,C;;wEAGf,qC;IACI,OAAO,iBAAa,kBAAmB,MAAhC,EAAuC,GAAvC,C;EACX,C;mEAEA,iB;IACI,YAAY,wBAAO,KAAP,CAAc,M;IAC1B,OAAO,iBAAa,0DAAW,eAAM,KAAM,OAAZ,CAAxB,EAA6C,0DAAW,SAAxD,C;EACX,C;;;;;;EAG+B,4E;IAI/B,4CACA,KADA,EACO,MADP,EACe,OADf,2C;IAKI,gBAAW,MAAO,K;IAClB,gBAAW,C;;;;;;;EAIM,kE;IACrB,4CACI,KADJ,EACW,MADX,EACmB,OADnB,yC;IAKI,gBAAW,C;IACX,gBAAW,MAAO,K;;;;;;;EAIQ,mF;IAK9B,iCAAsB,KAAtB,EAA6B,MAA7B,EAAqC,OAArC,EAA8C,eAA9C,C;IACA,yBAA8B,G;IAGf,Q;IAAA,wB;IAAX,OAAW,cAAX,C;MAAW,oB;MACW,QAAI,sB;MAAJ,QAAqB,0DAAW,eAAM,EAAG,MAAM,OAAf,C;MAAlD,yBnE0O6C,MAAW,KAAI,CAAJ,EAAO,CAAP,C;;;sEmEtOhE,qC;IAEe,UAMJ,M;IAPP,IAAI,gBAAJ,C;MACW,IAAI,QAAQ,aAAR,KAAoB,CAAxB,C;QACH,wBAAa,GAAb,EAAkB,kBAAmB,OAArC,C;;QACG,wBAAa,kBAAmB,MAAhC,EAAuC,kBAAmB,IAA1D,C;MAFP,W;KAMG,IAAI,QAAQ,aAAR,KAAoB,CAAxB,C;MACH,0BAAa,kBAAmB,MAAhC,EAAuC,GAAvC,C;;MACG,0BAAa,kBAAmB,KAAhC,EAAsC,kBAAmB,OAAzD,C;IAFP,a;EAIJ,C;iEAEA,iB;IACI,OAAO,iBAAa,sBAAb,EAA8B,0DAAW,SAAzC,C;EACX,C;;;;;;EAGJ,2C;IAAA,+C;;iEACI,kC;IACI,OAAO,uCACH,KADG,EAEH,MAFG,EAGH,OAHG,C;EAKX,C;yEAEA,kC;IACI,OAAO,+CACH,KADG,EAEH,MAFG,EAGH,OAHG,C;EAKX,C;+DAEA,kC;IACI,OAAO,qCACH,KADG,EAEH,MAFG,EAGH,OAHG,C;EAKX,C;;;;;;;EAvBJ,uD;IAAA,sD;MAAA,qC;KAAA,+C;;;;;;;EChKqB,oE;IAMrB,yBAAc,KAAd,EAAqB,KAArB,EAA4B,OAA5B,C;IAJA,4B;IAEA,8B;;;SAAA,Y;MAAA,4B;;;;;;;;ECNJ,wC;IAAA,e;IAAA,iB;IAAA,uB;;EAAA,sC;IAAA,yC;;IAKI,0E;IACA,sE;IACA,8D;;;EAFA,kD;IAAA,4B;IAAA,0C;;;EACA,gD;IAAA,4B;IAAA,wC;;;EACA,4C;IAAA,4B;IAAA,oC;;;;;;;EAPJ,kC;IAAA,6H;;;EAAA,uC;IAAA,a;MAAA,kB;QAAA,+C;MAAA,gB;QAAA,6C;MAAA,Y;QAAA,yC;MAAA,kG;;;;ECGyB,mC;IACrB,2C;IADsB,U;IAAe,U;;EACrC,yC;IAAA,6C;IACI,cAAa,wBAAoB,GAApB,EAAyB,GAAzB,C;;;;;;;;EADjB,qD;IAAA,oD;MAAA,mC;KAAA,6C;;;;;;;ECDgB,8B;IAYhB,sC;IAZiB,U;IAAe,U;;;;SAG5B,Y;MAAQ,gBAAS,2CAAT,IAAiB,SAAS,4CAA1B,IACA,SAAS,0CADT,IACgB,SAAS,6C;;;;;SAGjC,Y;MAAQ,gBAAS,2C;;;;;SAGjB,Y;MAAQ,SAAE,gBAAW,aAAb,C;;;EAEZ,oC;IAAA,wC;IACI,aAAY,mBAAe,GAAf,EAAoB,GAApB,C;IACZ,YAAW,mBAAe,GAAf,EAAoB,GAApB,C;IACX,WAAU,mBAAe,GAAf,EAAoB,GAApB,C;IACV,cAAa,mBAAe,GAAf,EAAoB,GAApB,C;IACb,YAAW,mBAAe,wCAAO,IAAtB,EAA2B,wCAAO,IAAlC,C;;;;;;;;EALf,gD;IAAA,+C;MAAA,8B;KAAA,wC;;;;;;;ECfkB,6C;IAAtB,e;IAAuB,gC;IAAvB,iB;IAAA,uB;;EAAA,kC;IAAA,qC;;IACI,uDAAK,MAAL,C;IACA,yDAAM,OAAN,C;IACA,qDAAI,KAAJ,C;IACA,2DAAO,QAAP,C;;;EAHA,wC;IAAA,wB;IAAA,gC;;;EACA,yC;IAAA,wB;IAAA,iC;;;EACA,uC;IAAA,wB;IAAA,+B;;;EACA,0C;IAAA,wB;IAAA,kC;;;;SAGI,Y;MAAQ,gBAAQ,6BAAR,IAAe,SAAQ,gC;;;mCAEnC,Y;IACI,OAAO,iBACC,WADD,GACe,sBADf,GAC8B,oBAAL,EAAK,CAD9B,GAEK,oBAAJ,GAAI,C;EAChB,C;;;;;;EAbJ,8B;IAAA,yI;;;EAAA,mC;IAAA,a;MAAA,Y;QAAA,qC;MAAA,a;QAAA,sC;MAAA,W;QAAA,oC;MAAA,c;QAAA,uC;MAAA,8F;;;;;ICOI,iD;;EAAA,+C;IAAA,mD;IACI,wE;;EAAW,kE;;qGACP,iC;IACI,OAAO,sBACY,WADZ,EAEa,IAFb,EAGe,IAHf,EAIY,IAJZ,EAKsB,KALtB,EAMiB,KANjB,EAOc,KAPd,EAQkB,KARlB,C;EAUX,C;;;;;;;;;;;EAbR,2D;IAAA,0D;MAAA,yC;KAAA,mD;;;;;;;ECIiB,kC;IA6BjB,uC;IA1BA,8BAAgD,OAAQ,mB;IACxD,iCAAsD,OAAQ,sB;IAC9D,wBAAgD,OAAQ,a;IACxD,6BAAqD,OAAQ,kB;IAC7D,kCAAuC,OAAQ,6B;IAC/C,8BAA4C,OAAQ,mB;;+CAEpD,Y;IACI,OAAO,iCAAW,2BAAX,EAAiC,8BAAjC,C;EACX,C;8DAEA,iC;;IAKuB,gBAAf,qB;I5Eq+CD,kBAAM,iBAAa,mCAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,6B;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,WAAY,4BAAc,KAAd,C;;I4E9iDZ,OAAO,+B5E+iDJ,W4E/iDI,EAGH,UAHG,EAIH,SAJG,EAKH,0BALG,EAMH,+BANG,EAOH,2BAPG,C;EASX,C;EAEA,qC;IAAA,yC;;4EACI,gG;IAOI,uC;MAAA,0BAA8C,I;IAE9C,0BAA0B,8CAAuB,wCAC7C,iBAD6C,EAE7C,OAF6C,EAG7C,QAH6C,EAI7C,uBAJ6C,C;IAMjD,OAAO,+BACH,mBADG,EAEH,UAFG,EAGH,SAHG,EAIH,8DAAkB,KAJf,EAKsB,KALtB,EAMkB,KANlB,C;EAQX,C;kEAEA,8G;IAQI,kBAAkB,gBAAwB,SAAxB,EAAsD,UAAtD,C;I5E0qBnB,kBAAS,gB;IA2FA,Q;IAAA,O4EnwBiB,Y5EmwBjB,W;gBAAhB,OAAgB,cAAhB,C;MAAgB,yB;M4ElwB0B,gB5EkwBN,O4ElwBD,O;M5EysB5B,oBAAmB,gB;MASV,U;MAAA,6B;MAAhB,OAAgB,gBAAhB,C;QAAgB,6B;QAAM,IAAI,sCAAJ,C;UAAkB,aAAY,WAAI,SAAJ,C;;M4EltBxC,kB5EmtBL,a;M4EltBiB,c;;Q5EmmDR,U;QADhB,IAAI,c4ElmDQ,W5EkmDR,iB4ElmDQ,W5EkmDc,UAA1B,C;UAAqC,aAAO,I;UAAP,e;SACrB,S4EnmDJ,W5EmmDI,W;QAAhB,OAAgB,gBAAhB,C;UAAgB,6B;UAAM,IAAI,C4EnmD4B,4B5EmmDjB,S4EnmDoC,IAAnB,C5EmmDhC,C;YAAyB,aAAO,K;YAAP,e;;QAC/C,aAAO,I;;;MAn2Be,e;QAAwB,WAAY,WAAI,OAAJ,C;;I4EnwBlD,yB5EowBD,W;IAi+BS,U;IAAA,S4EjuDR,kB5EiuDQ,W;IAAhB,OAAgB,gBAAhB,C;MAAgB,6B;MAAa,S4EjuDW,qC;;IAEW,c;;M5EonDnC,U;MADhB,IAAI,c4EnnD4B,kB5EmnD5B,iB4EnnD4B,kB5EmnDN,UAA1B,C;QAAqC,aAAO,K;QAAP,e;OACrB,S4EpnDgB,kB5EonDhB,W;kBAAhB,OAAgB,gBAAhB,C;QAAgB,6B;Q4EnnDQ,kB5EmnDY,S4EnnDnB,O;QAAO,uDAAK,qB;iBAAa,mB;SAAlB,C;QAAA,e;;U5E00ER,U;UADhB,IAAI,0CAAsB,qBAA1B,C;YAAqC,cAAO,I;YAAP,gB;WACrB,+B;UAAhB,OAAgB,gBAAhB,C;YAAgB,6B;YAAM,IAAI,UAAU,SAAV,CAAJ,C;cAAwB,cAAO,K;cAAP,gB;;UAC9C,cAAO,I;;;QAxtBe,gB;UAAwB,aAAO,I;UAAP,e;;MAC9C,aAAO,K;;;I4ErnDC,kC;IAGwC,gB;;M5EinDhC,U;MADhB,IAAI,c4EhnDyB,kB5EgnDzB,iB4EhnDyB,kB5EgnDH,UAA1B,C;QAAqC,eAAO,K;QAAP,e;OACrB,S4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B,UAAO,aAAI,EAAX,EAAc,aAAI,EAAlB,E;;sFAErB,uF;IAII,uC;MAAA,0BAA8C,I;IAC9C,4B;MAAA,eAAkC,I;IAWb,Q;I7EozCtB,kBAAM,iBAAa,wB6E7zCK,O7E6zCL,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S6Ep4CkB,O7Eo4ClB,W;IAAb,OAAa,gBAAb,C;MAAa,wB;MACT,WAAY,W6Er4CoC,iB7Eq4CtB,I6Er4CsB,EAA8B,IAA9B,EAA6C,IAA7C,C7Eq4CpC,C;;I6Er4CR,uB7Es4CD,W;IAzEA,oBAAM,iBAAa,wB6E5zCQ,Q7E4zCR,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S6En4CqB,Q7Em4CrB,W;IAAb,OAAa,gBAAb,C;MAAa,0B;mBACT,a;M6En4C0B,kB;MAAA,U;MAAA,oC;Q7E8kBvB,oBAAmB,gB;QASV,U;QAAA,2C;QAAhB,OAAgB,gBAAhB,C;UAAgB,2B;UAAM,IAAI,oCAAJ,C;YAAkB,aAAY,WAAI,OAAJ,C;;Q6EvlBtB,S7EwlBvB,a;;Q6ExlBuB,a;MAAA,U;MAAA,8B;Q7EzCvB,sB;;UAuHS,U;UAAA,0B;UAAhB,OAAgB,gBAAhB,C;YAAgB,6B;YAAM,I6E9E0E,O7E8E5D,S6E9E+D,IAAH,E7Em4ClE,M6En4CkE,C7E8E1E,C;cAAwB,qBAAO,S;cAAP,uB;;UAC9C,qBAAO,I;;;Q6E/EuB,S7EzC9B,kB;;Q6EyC8B,a;MAAlB,wB;M7Em4CI,YAAZ,aAAY,E6El4CJ,mFAA4B,iB7Ek4CV,M6El4CU,EAA8B,IAA9B,C7Ek4CxB,C;;I6Ep4CR,0B7Eq4CD,a;IAzEA,oBAAM,iBAAa,wB6ExzCI,iB7EwzCJ,EAAwB,EAAxB,CAAb,C;IAuEA,U;IAAA,S6E/3CiB,iB7E+3CjB,W;IAAb,OAAa,gBAAb,C;MAAa,0B;oBACT,a;M6E/3C0B,W;MAAA,W;MAAA,oC;Q7E0kBvB,oBAAmB,gB;QASV,W;QAAA,4C;QAAhB,OAAgB,iBAAhB,C;UAAgB,8B;UAAM,IAAI,sCAAJ,C;YAAkB,aAAY,WAAI,SAAJ,C;;Q6EnlBtB,U7EolBvB,a;;Q6EplBuB,c;MAAA,W;MAAA,gC;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","file":"./kotlin-dce-dev/lets-plot-plot-builder-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.builder.sampling.Samplings.pick\nimport jetbrains.datalore.plot.builder.sampling.Samplings.random\nimport jetbrains.datalore.plot.builder.sampling.Samplings.systematic\nimport jetbrains.datalore.plot.builder.sampling.Samplings.systematicGroup\nimport jetbrains.datalore.plot.builder.sampling.Samplings.vertexDp\n\n/*\n None:\n      livemap\n      raster\n      image\n */\nobject DefaultSampling {\n    private const val SEED = 37L\n\n    val SAFETY_SAMPLING = random(200000, SEED)\n\n    // point-like\n    val POINT = random(50000, SEED)   // optimized\n    val TILE = random(50000, SEED)    // optimized\n    val BIN_2D = TILE\n    val AB_LINE = random(5000, SEED)\n    val H_LINE = random(5000, SEED)\n    val V_LINE = random(5000, SEED)\n    val JITTER = random(5000, SEED)\n    val RECT = random(5000, SEED)\n    val SEGMENT = random(5000, SEED)\n    val TEXT = random(500, SEED)\n\n    // range\n    val ERROR_BAR = random(500, SEED)\n    val CROSS_BAR = random(500, SEED)\n    // val BOX_PLOT = random(500, SEED) - tmp disabled (see GeomProto)\n    val LINE_RANGE = random(500, SEED)\n    val POINT_RANGE = random(500, SEED)\n\n    // bars\n    val BAR = pick(50)\n    val HISTOGRAM = systematic(500)\n\n    // lines\n    val LINE = systematic(5000)\n    val RIBBON = systematic(5000)\n    val AREA = systematic(5000)\n    val DENSITY = systematic(5000)\n    val FREQPOLY = systematic(5000)\n    val STEP = systematic(5000)\n\n    // polygons\n    val PATH = vertexDp(20000)\n    val POLYGON = vertexDp(20000)\n    val MAP = vertexDp(20000)\n\n    // groups\n    val SMOOTH = systematicGroup(200)\n    val CONTOUR = systematicGroup(200)\n    val CONTOURF = systematicGroup(200)\n    val DENSITY2D = systematicGroup(200)\n    val DENSITY2DF = systematicGroup(200)\n}","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\nimport kotlin.random.Random\n\n/**\n * Removes a single instance of the specified element from this\n * collection, if it is present.\n *\n * Allows to overcome type-safety restriction of `remove` that requires to pass an element of type `E`.\n *\n * @return `true` if the element has been successfully removed; `false` if it was not present in the collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.remove(element: T): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).remove(element)\n\n/**\n * Removes all of this collection's elements that are also contained in the specified collection.\n\n * Allows to overcome type-safety restriction of `removeAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any of the specified elements was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.removeAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).removeAll(elements)\n\n/**\n * Retains only the elements in this collection that are contained in the specified collection.\n *\n * Allows to overcome type-safety restriction of `retainAll` that requires to pass a collection of type `Collection<E>`.\n *\n * @return `true` if any element was removed from the collection, `false` if the collection was not modified.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> MutableCollection<out T>.retainAll(elements: Collection<T>): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableCollection<T>).retainAll(elements)\n\n/**\n * Adds the specified [element] to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(element: T) {\n    this.add(element)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Iterable<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] array to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Array<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.plusAssign(elements: Sequence<T>) {\n    this.addAll(elements)\n}\n\n/**\n * Removes a single instance of the specified [element] from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(element: T) {\n    this.remove(element)\n}\n\n/**\n * Removes all elements contained in the given [elements] collection from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Iterable<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] array from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Array<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Removes all elements contained in the given [elements] sequence from this mutable collection.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> MutableCollection<in T>.minusAssign(elements: Sequence<T>) {\n    this.removeAll(elements)\n}\n\n/**\n * Adds all elements of the given [elements] collection to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Iterable<T>): Boolean {\n    when (elements) {\n        is Collection -> return addAll(elements)\n        else -> {\n            var result: Boolean = false\n            for (item in elements)\n                if (add(item)) result = true\n            return result\n        }\n    }\n}\n\n/**\n * Adds all elements of the given [elements] sequence to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Sequence<T>): Boolean {\n    var result: Boolean = false\n    for (item in elements) {\n        if (add(item)) result = true\n    }\n    return result\n}\n\n/**\n * Adds all elements of the given [elements] array to this [MutableCollection].\n */\npublic fun <T> MutableCollection<in T>.addAll(elements: Array<out T>): Boolean {\n    return addAll(elements.asList())\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Iterable<T>): Boolean {\n    return removeAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    return set.isNotEmpty() && removeAll(set)\n}\n\n/**\n * Removes all elements from this [MutableCollection] that are also contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.removeAll(elements: Array<out T>): Boolean {\n    return elements.isNotEmpty() && removeAll(elements.toHashSet())\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] collection.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Iterable<T>): Boolean {\n    return retainAll(elements.convertToSetForSetOperationWith(this))\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] array.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Array<out T>): Boolean {\n    if (elements.isNotEmpty())\n        return retainAll(elements.toHashSet())\n    else\n        return retainNothing()\n}\n\n/**\n * Retains only elements of this [MutableCollection] that are contained in the given [elements] sequence.\n */\npublic fun <T> MutableCollection<in T>.retainAll(elements: Sequence<T>): Boolean {\n    val set = elements.toHashSet()\n    if (set.isNotEmpty())\n        return retainAll(set)\n    else\n        return retainNothing()\n}\n\nprivate fun MutableCollection<*>.retainNothing(): Boolean {\n    val result = isNotEmpty()\n    clear()\n    return result\n}\n\n\n/**\n * Removes all elements from this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableIterable] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableIterable<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableIterable<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    var result = false\n    with(iterator()) {\n        while (hasNext())\n            if (predicate(next()) == predicateResultToRemove) {\n                remove()\n                result = true\n            }\n    }\n    return result\n}\n\n\n/**\n * Removes the element at the specified [index] from this list.\n * In Kotlin one should use the [MutableList.removeAt] function instead.\n */\n@Deprecated(\"Use removeAt(index) instead.\", ReplaceWith(\"removeAt(index)\"), level = DeprecationLevel.ERROR)\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList<T>.remove(index: Int): T = removeAt(index)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirst(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(0)\n\n/**\n * Removes the first element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeFirstOrNull(): T? = if (isEmpty()) null else removeAt(0)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or throws [NoSuchElementException] if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLast(): T = if (isEmpty()) throw NoSuchElementException(\"List is empty.\") else removeAt(lastIndex)\n\n/**\n * Removes the last element from this mutable list and returns that removed element, or returns `null` if this list is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> MutableList<T>.removeLastOrNull(): T? = if (isEmpty()) null else removeAt(lastIndex)\n\n/**\n * Removes all elements from this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when no elements were removed and collection was not modified.\n */\npublic fun <T> MutableList<T>.removeAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, true)\n\n/**\n * Retains only elements of this [MutableList] that match the given [predicate].\n *\n * @return `true` if any element was removed from this collection, or `false` when all elements were retained and collection was not modified.\n */\npublic fun <T> MutableList<T>.retainAll(predicate: (T) -> Boolean): Boolean = filterInPlace(predicate, false)\n\nprivate fun <T> MutableList<T>.filterInPlace(predicate: (T) -> Boolean, predicateResultToRemove: Boolean): Boolean {\n    if (this !is RandomAccess)\n        return (this as MutableIterable<T>).filterInPlace(predicate, predicateResultToRemove)\n\n    var writeIndex: Int = 0\n    for (readIndex in 0..lastIndex) {\n        val element = this[readIndex]\n        if (predicate(element) == predicateResultToRemove)\n            continue\n\n        if (writeIndex != readIndex)\n            this[writeIndex] = element\n\n        writeIndex++\n    }\n    if (writeIndex < size) {\n        for (removeIndex in lastIndex downTo writeIndex)\n            removeAt(removeIndex)\n\n        return true\n    } else {\n        return false\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\n\nobject FeatureSwitch {\n    const val PLOT_DEBUG_DRAWING = false\n    const val LEGEND_DEBUG_DRAWING = false\n    private const val PRINT_DEBUG_LOGS = false\n\n    private const val PRINT_ENCODED_DATA_SUMMARY = false\n\n    const val USE_DATA_FRAME_ENCODING = true\n\n    fun printEncodedDataSummary(header: String, dataSpec: Map<String, Any>) {\n        @Suppress(\"ConstantConditionIf\")\n        if (PRINT_ENCODED_DATA_SUMMARY) {\n            printEncodedDataSummary(\n                header,\n                DataFrameUtil.fromMap(dataSpec)\n            )\n        }\n    }\n\n    fun isDebugLogEnabled(): Boolean {\n        return PRINT_DEBUG_LOGS\n    }\n\n    private fun printEncodedDataSummary(header: String, df: DataFrame) {\n        @Suppress(\"ConstantConditionIf\")\n        if (PRINT_ENCODED_DATA_SUMMARY) {\n            //ToDo:\n            //Preconditions.checkState(!GWT.isClient(), \"Not expected on client\")\n            val summary = DataFrameUtil.getSummaryText(df)\n            println(header)\n            println(summary)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.builder.guide.AxisComponent\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nobject AxisUtil {\n    fun applyLayoutInfo(axis: AxisComponent, info: AxisLayoutInfo) {\n        axis.tickLabelOffsets.set(info.tickLabelAdditionalOffsets)\n        axis.tickLabelRotationDegree.set(info.tickLabelRotationAngle)\n        if (info.tickLabelHorizontalAnchor != null) {\n            axis.tickLabelHorizontalAnchor.set(info.tickLabelHorizontalAnchor)\n        }\n        if (info.tickLabelVerticalAnchor != null) {\n            axis.tickLabelVerticalAnchor.set(info.tickLabelVerticalAnchor)\n        }\n        axis.tickLabelSmallFont.set(info.tickLabelSmallFont)\n    }\n\n    fun applyTheme(axis: AxisComponent, theme: AxisTheme) {\n        axis.tickLabelsEnabled().set(theme.showTickLabels())\n        axis.tickMarksEnabled().set(theme.showTickMarks())\n        axis.axisLineEnabled().set(theme.showLine())\n\n        axis.lineWidth.set(theme.lineWidth())\n        axis.tickMarkLength.set(theme.tickMarkLength())\n        axis.tickMarkPadding.set(theme.tickMarkPadding())\n        axis.tickMarkWidth.set(theme.tickMarkWidth())\n    }\n\n    fun setBreaks(axis: AxisComponent, scale: Scale<Double>, coord: CoordinateSystem, horizontal: Boolean) {\n        val scaleBreaks = scale.getScaleBreaks()\n        val mappedBreaks = toAxisCoord(scaleBreaks, scale, coord, horizontal)\n\n        axis.breaks.set(mappedBreaks)\n        axis.labels.set(scaleBreaks.labels)\n    }\n\n    private fun toAxisCoord(\n        scaleBreaks: ScaleBreaks,\n        scale: Scale<Double>,\n        coord: CoordinateSystem,\n        horizontal: Boolean\n    ): List<Double> {\n        val breaksMapped = ScaleUtil.map(scaleBreaks.transformedValues, scale).map {\n            // Don't expect NULLs.\n            it as Double\n        }\n        val axisBreaks = ArrayList<Double>()\n        for (br in breaksMapped) {\n            val mappedBrPoint = when (horizontal) {\n                true -> DoubleVector(br, 0.0)\n                false -> DoubleVector(0.0, br)\n            }\n\n            val axisBrPoint = coord.toClient(mappedBrPoint)\n            val axisBr = if (horizontal)\n                axisBrPoint.x\n            else\n                axisBrPoint.y\n\n            axisBreaks.add(axisBr)\n            if (!axisBr.isFinite()) {\n                throw IllegalStateException(\n                    \"Illegal axis '\" + scale.name + \"' break position \" + axisBr +\n                            \" at index \" + (axisBreaks.size - 1) +\n                            \"\\nsource breaks    : \" + scaleBreaks.domainValues +\n                            \"\\ntranslated breaks: \" + breaksMapped +\n                            \"\\naxis breaks      : \" + axisBreaks\n                )\n            }\n        }\n        return axisBreaks\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\n\ninternal class BogusCoordinateSystem : CoordinateSystem {\n    override fun toClient(p: DoubleVector): DoubleVector {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun fromClient(p: DoubleVector): DoubleVector {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPointInLimits(p: DoubleVector, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isRectInLimits(rect: DoubleRectangle, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPathInLimits(path: List<DoubleVector>, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override fun isPolygonInLimits(polygon: List<DoubleVector>, isClient: Boolean): Boolean {\n        throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n    }\n\n    override val xClientLimit: ClosedRange<Double>\n        get() = throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n\n    override val yClientLimit: ClosedRange<Double>\n        get() = throw IllegalStateException(\"Bogus coordinate system is not supposed to be used.\")\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.Transform\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\ninternal class BogusScale : Scale<Double> {\n    override val name: String\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val labelFormatter: ((Any) -> String)\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val isContinuous: Boolean\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val isContinuousDomain: Boolean\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val multiplicativeExpand: Double\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val additiveExpand: Double\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val transform: Transform\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override val mapper: (Double?) -> Double?\n        get() = throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n\n    override fun hasBreaks(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun hasDomainLimits(): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun isInDomainLimits(v: Any): Boolean {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun getScaleBreaks(): ScaleBreaks {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun applyTransform(source: List<*>, checkLimits: Boolean): List<Double?> {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun getBreaksGenerator(): BreaksGenerator {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n\n    override fun with(): Scale.Builder<Double> {\n        throw IllegalStateException(\"Bogus scale is not supposed to be used.\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nobject GeomLayerListUtil {\n\n//    fun anyBoundXScale(\n//        scaleMap: TypedScaleMap,\n//        layersByTile: List<List<GeomLayer>>\n//    ): Scale<Double>? {\n//        for (layer in layersByTile[0]) {\n//            if (layer.hasBinding(Aes.X)) {\n//                return scaleMap[Aes.X]\n//            }\n//        }\n//        return null\n//    }\n\n//    fun anyBoundYScale(\n//        scaleByAes: TypedScaleMap,\n//        layersByTile: List<List<GeomLayer>>\n//    ): Scale<Double>? {\n//        for (layer in layersByTile[0]) {\n//            if (layer.hasBinding(Aes.Y)) {\n//                return scaleByAes[Aes.Y]\n//            }\n//        }\n//        return null\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\n\nobject LayerRendererUtil {\n\n    fun createLayerRendererData(layer: GeomLayer,\n                                sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>,\n                                overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>\n    ): LayerRendererData {\n\n        val aestheticMappers =\n            PlotUtil.prepareLayerAestheticMappers(layer, sharedNumericMappers)\n        val aesthetics = PlotUtil.createLayerAesthetics(\n            layer,\n            aestheticMappers,\n            overallNumericDomains\n        )\n        val pos = PlotUtil.createLayerPos(layer, aesthetics)\n        return LayerRendererData(\n            layer,\n            aesthetics,\n            aestheticMappers,\n            pos\n        )\n    }\n\n    class LayerRendererData(\n        layer: GeomLayer,\n        val aesthetics: Aesthetics,\n        val aestheticMappers: Map<Aes<*>, (Double?) -> Any?>,\n        val pos: PositionAdjustment\n    ) {\n        val geom: Geom = layer.geom\n        val geomKind: GeomKind = layer.geomKind\n        val dataAccess: MappedDataAccess = layer.dataAccess\n        val contextualMapping: ContextualMapping = layer.contextualMapping\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.event.Event\nimport jetbrains.datalore.base.gcommon.base.Throwables\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ReadableProperty\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.observable.property.WritableProperty\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.FeatureSwitch.PLOT_DEBUG_DRAWING\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.event.MouseEventPeer\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.interact.TooltipSpec\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.layout.PlotLayoutUtil.liveMapBounds\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.vis.svg.SvgElement\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.event.SvgEventHandler\nimport jetbrains.datalore.vis.svg.event.SvgEventSpec\n\nabstract class Plot(private val theme: Theme) : SvgComponent() {\n\n    private val myPreferredSize = ValueProperty(DEF_PLOT_SIZE)\n    private val myLaidOutSize = ValueProperty(DoubleVector.ZERO)\n    private val myTooltipHelper = PlotTooltipHelper()\n    private val myLiveMapFigures = ArrayList<SomeFig>()\n\n    val mouseEventPeer = MouseEventPeer()\n\n    protected abstract val scaleXProto: Scale<Double>\n\n    protected abstract val scaleYProto: Scale<Double>\n\n    protected abstract val title: String\n\n    protected abstract val axisTitleLeft: String\n\n    protected abstract val axisTitleBottom: String\n\n    protected abstract val coordProvider: CoordProvider\n\n    protected abstract val legendBoxInfos: List<LegendBoxInfo>\n\n    protected abstract val isAxisEnabled: Boolean\n\n    abstract val isInteractionsEnabled: Boolean\n\n    internal val liveMapFigures: List<SomeFig>\n        get() = myLiveMapFigures\n\n    internal fun preferredSize(): WritableProperty<DoubleVector> {\n        return myPreferredSize\n    }\n\n    fun laidOutSize(): ReadableProperty<DoubleVector> {\n        return myLaidOutSize\n    }\n\n    protected abstract fun hasTitle(): Boolean\n\n    protected abstract fun hasAxisTitleLeft(): Boolean\n\n    protected abstract fun hasAxisTitleBottom(): Boolean\n\n    protected abstract fun hasLiveMap(): Boolean\n\n    protected abstract fun tileLayers(tileIndex: Int): List<GeomLayer>\n\n    protected abstract fun plotLayout(): PlotLayout\n\n    override fun buildComponent() {\n        try {\n            buildPlot()\n        } catch (e: RuntimeException) {\n            LOG.error(e) { \"buildPlot\" }\n\n            val rootCause = Throwables.getRootCause(e)\n            val messages = arrayOf(\n                \"Error building plot: \" + rootCause::class.simpleName, if (rootCause.message != null)\n                    \"'\" + rootCause.message + \"'\"\n                else\n                    \"<no message>\"\n            )\n            var y = myPreferredSize.get().y / 2 - 8\n            for (s in messages) {\n                val errorLabel = TextLabel(s)\n                errorLabel.setHorizontalAnchor(HorizontalAnchor.MIDDLE)\n                errorLabel.setVerticalAnchor(VerticalAnchor.CENTER)\n                errorLabel.moveTo(myPreferredSize.get().x / 2, y)\n                rootGroup.children().add(errorLabel.rootGroup)\n                y += 16.0\n            }\n        }\n    }\n\n    private fun buildPlot() {\n        rootGroup.addClass(Style.PLOT)\n        buildPlotComponents()\n        reg(myPreferredSize.addHandler(object : EventHandler<PropertyChangeEvent<out DoubleVector>> {\n            override fun onEvent(event: PropertyChangeEvent<out DoubleVector>) {\n                val newValue = event.newValue\n                if (newValue!!.x > 0 && newValue.y > 0) {\n                    rebuildPlot()\n                }\n            }\n        }))\n\n        reg(object : Registration() {\n            override fun doRemove() {\n                myTooltipHelper.removeAllTileInfos()\n                myLiveMapFigures.clear()\n            }\n        })\n    }\n\n    private fun rebuildPlot() {\n        clear()\n        buildPlot()\n    }\n\n\n    private fun createTile(\n        tilesOrigin: DoubleVector,\n        tileInfo: TileLayoutInfo,\n        tileLayers: List<GeomLayer>,\n        theme: Theme\n    ): PlotTile {\n\n        val xScale: Scale<Double>\n        val yScale: Scale<Double>\n        val coord: CoordinateSystem\n        if (tileInfo.xAxisInfo != null && tileInfo.yAxisInfo != null) {\n            val xDomain = tileInfo.xAxisInfo.axisDomain!!\n            val xAxisLength = tileInfo.xAxisInfo.axisLength\n\n            val yDomain = tileInfo.yAxisInfo.axisDomain!!\n            val yAxisLength = tileInfo.yAxisInfo.axisLength\n\n            // set-up scales and coordinate system\n            xScale = coordProvider.buildAxisScaleX(scaleXProto, xDomain, xAxisLength, tileInfo.xAxisInfo.axisBreaks!!)\n            yScale = coordProvider.buildAxisScaleY(scaleYProto, yDomain, yAxisLength, tileInfo.yAxisInfo.axisBreaks!!)\n            coord = coordProvider.createCoordinateSystem(xDomain, xAxisLength, yDomain, yAxisLength)\n        } else {\n            // bogus scales and coordinate system (live map doesn't need them)\n            xScale = BogusScale()\n            yScale = BogusScale()\n            coord = BogusCoordinateSystem()\n        }\n\n        val tile = PlotTile(tileLayers, xScale, yScale, tilesOrigin, tileInfo, coord, theme)\n        tile.setShowAxis(isAxisEnabled)\n        tile.debugDrawing().set(DEBUG_DRAWING)\n\n        return tile\n    }\n\n    private fun createAxisTitle(\n        text: String,\n        orientation: Orientation,\n        plotBounds: DoubleRectangle,\n        geomBounds: DoubleRectangle\n    ) {\n        val horizontalAnchor = HorizontalAnchor.MIDDLE\n        val verticalAnchor: VerticalAnchor = when (orientation) {\n            Orientation.LEFT, Orientation.RIGHT, Orientation.TOP -> VerticalAnchor.TOP\n            Orientation.BOTTOM -> VerticalAnchor.BOTTOM\n        }\n\n        val titleLocation: DoubleVector\n        var rotation = 0.0\n        when (orientation) {\n            Orientation.LEFT -> {\n                titleLocation =\n                    DoubleVector(plotBounds.left + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y)\n                rotation = -90.0\n            }\n            Orientation.RIGHT -> {\n                titleLocation =\n                    DoubleVector(plotBounds.right - PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN, geomBounds.center.y)\n                rotation = 90.0\n            }\n            Orientation.TOP -> titleLocation =\n                DoubleVector(geomBounds.center.x, plotBounds.top + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN)\n            Orientation.BOTTOM -> titleLocation =\n                DoubleVector(geomBounds.center.x, plotBounds.bottom - PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN)\n        }\n\n        val titleLabel = TextLabel(text)\n        titleLabel.setHorizontalAnchor(horizontalAnchor)\n        titleLabel.setVerticalAnchor(verticalAnchor)\n        titleLabel.moveTo(titleLocation)\n        titleLabel.rotate(rotation)\n\n        val titleElement = titleLabel.rootGroup\n        titleElement.addClass(Style.AXIS_TITLE)\n\n        // hack: we have style: \".axis .title text\" and we don't want to break backward-compatibility with 'census' charts\n        val parent = SvgGElement()\n        parent.addClass(Style.AXIS)\n\n        parent.children().add(titleElement)\n\n        add(parent)\n    }\n\n    private fun onMouseMove(e: SvgElement, message: String) {\n        e.addEventHandler(SvgEventSpec.MOUSE_MOVE, object :\n            SvgEventHandler<Event> {\n            override fun handle(node: SvgNode, e: Event) {\n                println(message)\n            }\n        })\n    }\n\n    private fun buildPlotComponents() {\n        val preferredSize = myPreferredSize.get()\n        val overallRect = DoubleRectangle(DoubleVector.ZERO, preferredSize)\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(overallRect)\n            rect.strokeColor().set(Color.MAGENTA)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            onMouseMove(rect, \"MAGENTA: preferred size: $overallRect\")\n            add(rect)\n        }\n\n        // compute geom bounds\n        val entirePlot = if (hasLiveMap()) {\n            liveMapBounds(overallRect)\n        } else {\n            overallRect\n        }\n\n        // subtract title size\n        val withoutTitle = if (hasTitle()) {\n            val titleSize = PlotLayoutUtil.titleDimensions(title)\n            DoubleRectangle(\n                entirePlot.origin.add(DoubleVector(0.0, titleSize.y)),\n                entirePlot.dimension.subtract(DoubleVector(0.0, titleSize.y))\n            )\n        } else {\n            entirePlot\n        }\n\n        // adjust for legend boxes\n        var boxesLayoutResult: LegendBoxesLayout.Result? = null\n        val legendTheme = theme.legend()\n        val withoutTitleAndLegends = if (legendTheme.position().isFixed) {\n            val legendBoxesLayout =\n                LegendBoxesLayout(withoutTitle, legendTheme)\n            boxesLayoutResult = legendBoxesLayout.doLayout(legendBoxInfos)\n            boxesLayoutResult.plotInnerBoundsWithoutLegendBoxes\n        } else {\n            withoutTitle\n        }\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(withoutTitleAndLegends)\n            rect.strokeColor().set(Color.BLUE)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            onMouseMove(rect, \"BLUE: plot without title and legends: $withoutTitleAndLegends\")\n            add(rect)\n        }\n\n        // subtract left axis title width\n        var geomAndAxis = withoutTitleAndLegends\n        if (isAxisEnabled) {\n            if (hasAxisTitleLeft()) {\n                val titleSize = PlotLayoutUtil.axisTitleDimensions(axisTitleLeft)\n                val thickness =\n                    titleSize.y + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil.AXIS_TITLE_INNER_MARGIN\n                geomAndAxis = DoubleRectangle(\n                    geomAndAxis.left + thickness, geomAndAxis.top,\n                    geomAndAxis.width - thickness, geomAndAxis.height\n                )\n            }\n\n            // subtract bottom axis title height\n            if (hasAxisTitleBottom()) {\n                val titleSize = PlotLayoutUtil.axisTitleDimensions(axisTitleBottom)\n                val thickness =\n                    titleSize.y + PlotLayoutUtil.AXIS_TITLE_OUTER_MARGIN + PlotLayoutUtil.AXIS_TITLE_INNER_MARGIN\n                geomAndAxis = DoubleRectangle(\n                    geomAndAxis.left, geomAndAxis.top,\n                    geomAndAxis.width, geomAndAxis.height - thickness\n                )\n            }\n        }\n\n        // Layout plot inners\n        val plotLayout = plotLayout()\n        val plotInfo = plotLayout.doLayout(geomAndAxis.dimension)\n        this.myLaidOutSize.set(preferredSize)\n\n        if (plotInfo.tiles.isEmpty()) {\n            return\n        }\n\n        val geomAreaBounds = PlotLayoutUtil.absoluteGeomBounds(geomAndAxis.origin, plotInfo)\n        if (legendTheme.position().isOverlay) {\n            // put 'overlay' in 'geom' bounds\n            val legendBoxesLayout = LegendBoxesLayout(geomAreaBounds, legendTheme)\n            boxesLayoutResult = legendBoxesLayout.doLayout(legendBoxInfos)\n        }\n\n        // build tiles\n        val tileTheme = if(plotInfo.tiles.size > 1) {\n            theme.multiTile()\n        } else {\n            theme\n        }\n\n        val tilesOrigin = geomAndAxis.origin\n        for (tileLayoutInfo in plotInfo.tiles) {\n//        for (i in plotInfo.tiles.indices) {\n//            val tileLayoutInfo = plotInfo.tiles[i]\n            val tileLayersIndex = tileLayoutInfo.trueIndex\n\n//            println(\"plot offset: \" + tileInfo.plotOffset)\n//            println(\"     bounds: \" + tileInfo.bounds)\n//            println(\"geom bounds: \" + tileInfo.geomBounds)\n//            println(\"clip bounds: \" + tileInfo.clipBounds)\n            val tile = createTile(tilesOrigin, tileLayoutInfo, tileLayers(tileLayersIndex), tileTheme)\n\n            val plotOriginAbsolute = tilesOrigin.add(tileLayoutInfo.plotOrigin)\n            tile.moveTo(plotOriginAbsolute)\n\n            add(tile)\n\n            tile.liveMapFigure?.let(myLiveMapFigures::add)\n\n            val geomBoundsAbsolute = tileLayoutInfo.geomBounds.add(plotOriginAbsolute)\n            myTooltipHelper.addTileInfo(geomBoundsAbsolute, tile.targetLocators)\n        }\n\n        @Suppress(\"ConstantConditionIf\")\n        if (DEBUG_DRAWING) {\n            val rect = SvgRectElement(geomAreaBounds)\n            rect.strokeColor().set(Color.RED)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.0)\n            add(rect)\n        }\n\n        // add plot title\n        if (hasTitle()) {\n            val titleLabel = TextLabel(title)\n            titleLabel.addClassName(Style.PLOT_TITLE)\n            titleLabel.setHorizontalAnchor(HorizontalAnchor.LEFT)\n            titleLabel.setVerticalAnchor(VerticalAnchor.CENTER)\n\n            val titleSize = PlotLayoutUtil.titleDimensions(title)\n            val titleBounds = DoubleRectangle(geomAreaBounds.origin.x, 0.0, titleSize.x, titleSize.y)\n            titleLabel.moveTo(DoubleVector(titleBounds.left, titleBounds.center.y))\n            add(titleLabel)\n\n            @Suppress(\"ConstantConditionIf\")\n            if (DEBUG_DRAWING) {\n                val rect = SvgRectElement(titleBounds)\n                rect.strokeColor().set(Color.BLUE)\n                rect.strokeWidth().set(1.0)\n                rect.fillOpacity().set(0.0)\n                add(rect)\n            }\n        }\n\n        // add axis titles\n        if (isAxisEnabled) {\n            if (hasAxisTitleLeft()) {\n                createAxisTitle(\n                    axisTitleLeft,\n                    Orientation.LEFT,\n                    withoutTitleAndLegends,\n                    geomAreaBounds\n                )\n            }\n            if (hasAxisTitleBottom()) {\n                createAxisTitle(\n                    axisTitleBottom,\n                    Orientation.BOTTOM,\n                    withoutTitleAndLegends,\n                    geomAreaBounds\n                )\n            }\n        }\n\n        // add legends\n        if (boxesLayoutResult != null) {\n            for (boxWithLocation in boxesLayoutResult.boxWithLocationList) {\n                val legendBox = boxWithLocation.legendBox.createLegendBox()\n                legendBox.moveTo(boxWithLocation.location)\n                add(legendBox)\n            }\n        }\n    }\n\n    fun createTooltipSpecs(plotCoord: DoubleVector): List<TooltipSpec> {\n        return myTooltipHelper.createTooltipSpecs(plotCoord)\n    }\n\n    fun getGeomBounds(plotCoord: DoubleVector): DoubleRectangle? {\n        return myTooltipHelper.getGeomBounds(plotCoord)\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(Plot::class)\n\n        private val DEF_PLOT_SIZE = DoubleVector(600.0, 400.0)\n        private const val DEBUG_DRAWING = PLOT_DEBUG_DRAWING\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.base.Strings\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.layout.PlotLayout\nimport jetbrains.datalore.plot.builder.theme.Theme\n\nclass PlotBuilder(private val myTheme: Theme) {\n    private val myLayersByTile = ArrayList<List<GeomLayer>>()\n    private var myTitle: String? = null\n    private lateinit var myCoordProvider: CoordProvider\n    private var myLayout: PlotLayout? = null\n    private var myAxisTitleLeft: String? = null\n    private var myAxisTitleBottom: String? = null\n    private val myLegendBoxInfos = ArrayList<LegendBoxInfo>()\n    private lateinit var myScaleXProto: Scale<Double>\n    private lateinit var myScaleYProto: Scale<Double>\n    private var myAxisEnabled = true\n    private var myInteractionsEnabled = true\n    private var hasLiveMap = false\n\n    fun setTitle(title: String?) {\n        myTitle = title\n    }\n\n    fun setAxisTitleLeft(v: String) {\n        myAxisTitleLeft = v\n    }\n\n    fun setAxisTitleBottom(v: String) {\n        myAxisTitleBottom = v\n    }\n\n    fun setCoordProvider(coordProvider: CoordProvider): PlotBuilder {\n        myCoordProvider = coordProvider\n        return this\n    }\n\n    fun addTileLayers(tileLayers: List<GeomLayer>): PlotBuilder {\n        myLayersByTile.add(ArrayList(tileLayers))\n        return this\n    }\n\n    fun setPlotLayout(layout: PlotLayout): PlotBuilder {\n        myLayout = layout\n        return this\n    }\n\n    fun addLegendBoxInfo(v: LegendBoxInfo): PlotBuilder {\n        myLegendBoxInfos.add(v)\n        return this\n    }\n\n    fun scaleXProto(scaleXProto: Scale<Double>): PlotBuilder {\n        myScaleXProto = scaleXProto\n        return this\n    }\n\n    fun scaleYProto(scaleYProto: Scale<Double>): PlotBuilder {\n        myScaleYProto = scaleYProto\n        return this\n    }\n\n    fun axisEnabled(b: Boolean): PlotBuilder {\n        myAxisEnabled = b\n        return this\n    }\n\n    fun interactionsEnabled(b: Boolean): PlotBuilder {\n        myInteractionsEnabled = b\n        return this\n    }\n\n    fun setLiveMap(b: Boolean): PlotBuilder {\n        hasLiveMap = b\n        return this\n    }\n\n    fun build(): Plot {\n        return MyPlot(this)\n    }\n\n    private class MyPlot(b: PlotBuilder) : Plot(b.myTheme) {\n        override val scaleXProto: Scale<Double> = b.myScaleXProto\n        override val scaleYProto: Scale<Double> = b.myScaleYProto\n\n        private val myTitle: String? = b.myTitle\n        private val myAxisTitleLeft: String? = b.myAxisTitleLeft\n        private val myAxisTitleBottom: String? = b.myAxisTitleBottom\n        private val myAxisXTitleEnabled: Boolean = b.myTheme.axisX().showTitle()\n        private val myAxisYTitleEnabled: Boolean = b.myTheme.axisY().showTitle()\n\n        override val coordProvider: CoordProvider = b.myCoordProvider\n\n        private val myLayersByTile: List<List<GeomLayer>>\n        private val myLayout: PlotLayout?\n        private val myLegendBoxInfos: List<LegendBoxInfo>\n        private val hasLiveMap: Boolean\n\n        override val isAxisEnabled: Boolean\n        override val isInteractionsEnabled: Boolean\n\n        override val title: String\n            get() {\n                require(hasTitle()) { \"No title\" }\n                return myTitle!!\n            }\n\n        override val axisTitleLeft: String\n            get() {\n                require(hasAxisTitleLeft()) { \"No left axis title\" }\n                return myAxisTitleLeft!!\n            }\n\n        override val axisTitleBottom: String\n            get() {\n                require(hasAxisTitleBottom()) { \"No bottom axis title\" }\n                return myAxisTitleBottom!!\n            }\n\n        override val legendBoxInfos: List<LegendBoxInfo>\n            get() = myLegendBoxInfos\n\n        init {\n            myLayersByTile = ArrayList(b.myLayersByTile)\n            myLayout = b.myLayout\n            myLegendBoxInfos = ArrayList(b.myLegendBoxInfos)\n\n            hasLiveMap = b.hasLiveMap\n\n            isAxisEnabled = b.myAxisEnabled\n            isInteractionsEnabled = b.myInteractionsEnabled\n        }\n\n        override fun hasTitle(): Boolean {\n            return !Strings.isNullOrEmpty(myTitle)\n        }\n\n        override fun hasAxisTitleLeft(): Boolean {\n            return myAxisYTitleEnabled && !Strings.isNullOrEmpty(myAxisTitleLeft)\n        }\n\n        override fun hasAxisTitleBottom(): Boolean {\n            return myAxisXTitleEnabled && !Strings.isNullOrEmpty(myAxisTitleBottom)\n        }\n\n        override fun hasLiveMap(): Boolean {\n            return hasLiveMap\n        }\n\n        override fun tileLayers(tileIndex: Int): List<GeomLayer> {\n            return myLayersByTile[tileIndex]\n        }\n\n        override fun plotLayout(): PlotLayout {\n            return myLayout!!\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ReadableProperty\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.plot.builder.presentation.Style.PLOT_BACKDROP\nimport jetbrains.datalore.vis.svg.SvgCssResource\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport jetbrains.datalore.vis.svg.SvgSvgElement\nimport kotlin.math.max\n\n/**\n *  This class only handles static SVG. (no interactions)\n */\nopen class PlotContainerPortable(\n    protected val plot: Plot,\n    private val preferredSize: ReadableProperty<DoubleVector>\n) {\n\n    val svg: SvgSvgElement = SvgSvgElement()\n\n    val liveMapFigures: List<SomeFig>\n        get() = plot.liveMapFigures\n\n    val isLiveMap: Boolean\n        get() = plot.liveMapFigures.isNotEmpty()\n\n    private var myContentBuilt: Boolean = false\n    private var myRegistrations = CompositeRegistration()\n\n    init {\n        svg.addClass(Style.PLOT_CONTAINER)\n        setSvgSize(preferredSize.get())\n\n        plot.laidOutSize().addHandler(sizePropHandler { laidOutSize ->\n            val newSvgSize = DoubleVector(\n                max(preferredSize.get().x, laidOutSize.x),\n                max(preferredSize.get().y, laidOutSize.y)\n            )\n            setSvgSize(newSvgSize)\n        })\n\n        preferredSize.addHandler(sizePropHandler { newPreferredSize ->\n            if (newPreferredSize.x > 0 && newPreferredSize.y > 0) {\n                revalidateContent()\n            }\n        })\n    }\n\n    fun ensureContentBuilt() {\n        if (!myContentBuilt) {\n            buildContent()\n        }\n    }\n\n    private fun revalidateContent() {\n        if (myContentBuilt) {\n            clearContent()\n            buildContent()\n        }\n    }\n\n    protected open fun buildContent() {\n        check(!myContentBuilt)\n        myContentBuilt = true\n\n        svg.setStyle(object : SvgCssResource {\n            override fun css(): String {\n                return Style.css\n            }\n        })\n\n        // Add Plot background.\n\n        // Batik doesn't seem to support any styling (via 'style' element or 'style' attribute)\n        // of root <svg>-element.\n        // Therefore the 'backdrop' rectungle is necessary.\n        val backdrop = SvgRectElement()\n        backdrop.addClass(PLOT_BACKDROP)\n\n        // Jfx Scene ignores these values (percentage is not supported).\n        // In the case of Jfx Scene the 'backdrop' rectungle has visibility=hidden\n        // and styling of the root <svg>-element is used.\n        // (see: 'resources/svgMapper/jfx/plot.css' in plot-builder)\n        backdrop.setAttribute(\"width\", \"100%\")\n        backdrop.setAttribute(\"height\", \"100%\")\n\n        // This works for DOM / Batik but ignored by JFX Scene\n        // Also, 'width'/'height' attributes are required by Batik.\n        // (or it fails with org.apache.batik.bridge.BridgeException)\n//        backdrop.setAttribute(SVG_STYLE_ATTRIBUTE, \"width: 100%; height: 100%\")\n\n        svg.children().add(backdrop)\n\n        plot.preferredSize().set(preferredSize.get())\n        svg.children().add(plot.rootGroup)\n    }\n\n    open fun clearContent() {\n        if (myContentBuilt) {\n            myContentBuilt = false\n\n            svg.children().clear()\n            plot.clear()\n            myRegistrations.remove()\n            myRegistrations = CompositeRegistration()\n        }\n    }\n\n    protected fun reg(registration: Registration) {\n        myRegistrations.add(registration)\n    }\n\n    private fun setSvgSize(size: DoubleVector) {\n        svg.width().set(size.x)\n        svg.height().set(size.y)\n    }\n\n    companion object {\n        private fun sizePropHandler(block: (newValue: DoubleVector) -> Unit): EventHandler<PropertyChangeEvent<out DoubleVector>> {\n            return object : EventHandler<PropertyChangeEvent<out DoubleVector>> {\n                override fun onEvent(event: PropertyChangeEvent<out DoubleVector>) {\n                    val newValue = event.newValue\n                    if (newValue != null) {\n                        block.invoke(newValue)\n                    }\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.SomeFig\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.geom.LiveMapGeom\nimport jetbrains.datalore.plot.base.geom.LiveMapProvider\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.assemble.GeomContextBuilder\nimport jetbrains.datalore.plot.builder.guide.AxisComponent\nimport jetbrains.datalore.plot.builder.interact.loc.LayerTargetCollectorWithLocator\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_H_PADDING\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_TAB_HEIGHT\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.FACET_V_PADDING\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.facetColHeadHeight\nimport jetbrains.datalore.plot.builder.layout.FacetGridPlotLayout.Companion.facetColLabelSize\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.layout.TileLayoutInfo\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport jetbrains.datalore.plot.builder.theme.FacetsTheme\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\ninternal class PlotTile(\n    layers: List<GeomLayer>,\n    private val myScaleX: Scale<Double>,\n    private val myScaleY: Scale<Double>,\n    private val myTilesOrigin: DoubleVector,\n    private val myLayoutInfo: TileLayoutInfo,\n    private val myCoord: CoordinateSystem,\n    private val myTheme: Theme\n) : SvgComponent() {\n\n    private val myDebugDrawing = ValueProperty(false)\n    private val myLayers: List<GeomLayer>\n    private val myTargetLocators = ArrayList<GeomTargetLocator>()\n    private var myShowAxis: Boolean = false\n\n    var liveMapFigure: SomeFig? = null\n        private set\n\n    val targetLocators: List<GeomTargetLocator>\n        get() = myTargetLocators\n\n    private val isDebugDrawing: Boolean\n        get() = myDebugDrawing.get()\n\n    init {\n        myLayers = ArrayList(layers)\n\n        moveTo(myLayoutInfo.getAbsoluteBounds(myTilesOrigin).origin)\n    }\n\n    override fun buildComponent() {\n        /*\n    // Don't set this flag: it was harmless when we were using SvgNodeSubtreeGeneratingSynchronizer but with new\n    // SvgNodeSubtreeBufferGeneratingSynchronizer this leads to having all svg event handlers ignored\n    // because the entire plot panel will be generated to a string buffer.\n    // We want event handlers to be called on SvgElement-s\n    getRootGroup().setPrebuiltSubtree(true);\n    */\n\n        val geomBounds = myLayoutInfo.geomBounds\n\n        if (myTheme.plot().showInnerFrame()) {\n            val rect = SvgRectElement(geomBounds).apply {\n                strokeColor().set(myTheme.plot().innerFrameColor())\n                strokeWidth().set(1.0)\n                fillOpacity().set(0.0)\n            }\n            add(rect)\n        }\n\n        addFacetLabels(geomBounds, myTheme.facets())\n\n        val liveMapGeomLayer = myLayers.firstOrNull { it.isLiveMap }\n        if (liveMapGeomLayer == null && myShowAxis) {\n            addAxis(geomBounds)\n        }\n\n        if (isDebugDrawing) {\n            val tileBounds = myLayoutInfo.bounds\n            val rect = SvgRectElement(tileBounds)\n            rect.fillColor().set(Color.BLACK)\n            rect.strokeWidth().set(0.0)\n            rect.fillOpacity().set(0.1)\n            add(rect)\n        }\n\n        if (isDebugDrawing) {\n            val clipBounds = myLayoutInfo.clipBounds\n            val rect = SvgRectElement(clipBounds)\n            rect.fillColor().set(Color.DARK_GREEN)\n            rect.strokeWidth().set(0.0)\n            rect.fillOpacity().set(0.3)\n            add(rect)\n        }\n\n        if (isDebugDrawing) {\n            val rect = SvgRectElement(geomBounds)\n            rect.fillColor().set(Color.PINK)\n            rect.strokeWidth().set(1.0)\n            rect.fillOpacity().set(0.5)\n            add(rect)\n        }\n\n        // render geoms\n\n        if (liveMapGeomLayer != null) {\n            val realBounds = myLayoutInfo.getAbsoluteGeomBounds(myTilesOrigin)\n\n            val liveMapData = liveMapGeomLayer.createCanvasFigure(realBounds)\n\n            liveMapFigure = liveMapData.canvasFigure\n            myTargetLocators.add(liveMapData.targetLocator)\n        } else {\n            // normal plot tile\n            val sharedNumericMappers = HashMap<Aes<Double>, (Double?) -> Double?>()\n            val overallNumericDomains = HashMap<Aes<Double>, ClosedRange<Double>>()\n\n            val xAxisInfo = myLayoutInfo.xAxisInfo\n            val yAxisInfo = myLayoutInfo.yAxisInfo\n            val mapperX = myScaleX.mapper\n            val mapperY = myScaleY.mapper\n\n            sharedNumericMappers[Aes.X] = mapperX\n            sharedNumericMappers[Aes.Y] = mapperY\n            sharedNumericMappers[Aes.SLOPE] = Mappers.mul(mapperY(1.0)!! / mapperX(1.0)!!)\n\n            overallNumericDomains[Aes.X] = xAxisInfo!!.axisDomain!!\n            overallNumericDomains[Aes.Y] = yAxisInfo!!.axisDomain!!\n\n            val geomLayerComponents = buildGeoms(sharedNumericMappers, overallNumericDomains, myCoord)\n            for (layerComponent in geomLayerComponents) {\n                layerComponent.moveTo(geomBounds.origin)\n\n                val xRange = myCoord.xClientLimit ?: ClosedRange(0.0, geomBounds.width)\n                val yRange = myCoord.yClientLimit ?: ClosedRange(0.0, geomBounds.height)\n                val clipRect = GeometryUtil.doubleRange(xRange, yRange)\n\n                layerComponent.clipBounds(clipRect)\n                add(layerComponent)\n            }\n        }\n    }\n\n    private fun addFacetLabels(geomBounds: DoubleRectangle, theme: FacetsTheme) {\n        // facet X label (on top of geom area)\n        val xLabels = myLayoutInfo.facetXLabels\n        if (xLabels.isNotEmpty()) {\n            val labelSize = facetColLabelSize(geomBounds.width)\n            val labelOrig = DoubleVector(\n                geomBounds.left + FACET_H_PADDING,\n                geomBounds.top - facetColHeadHeight(xLabels.size) + FACET_V_PADDING\n            )\n            var labelBounds = DoubleRectangle(\n                labelOrig, labelSize\n            )\n            for (xLabel in xLabels) {\n                val rect = SvgRectElement(labelBounds).apply {\n                    strokeWidth().set(0.0)\n                    fillColor().set(theme.labelBackground())\n\n//                    strokeWidth().set(1.0)\n//                    strokeColor().set(Color.BLACK)\n//                    fillOpacity().set(0.0)\n                }\n                add(rect)\n\n                val x = labelBounds.center.x\n                val y = labelBounds.center.y\n                val lab = TextLabel(xLabel)\n                lab.moveTo(x, y)\n                lab.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                lab.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n                add(lab)\n\n                labelBounds = labelBounds.add(DoubleVector(0.0, labelSize.y))\n            }\n        }\n\n        // facet Y label (to the right from geom area)\n        if (myLayoutInfo.facetYLabel != null) {\n\n            val hPad = FACET_V_PADDING\n            val vPad = FACET_H_PADDING\n\n            val labelBounds = DoubleRectangle(\n                geomBounds.right + hPad, geomBounds.top - vPad,\n                FACET_TAB_HEIGHT - hPad * 2, geomBounds.height - vPad * 2\n            )\n            val rect = SvgRectElement(labelBounds)\n            rect.strokeWidth().set(0.0)\n            rect.fillColor().set(theme.labelBackground())\n            add(rect)\n\n            val x = labelBounds.center.x\n            val y = labelBounds.center.y\n\n            val lab = TextLabel(myLayoutInfo.facetYLabel)\n            lab.moveTo(x, y)\n            lab.setHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n            lab.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n            lab.rotate(90.0)\n            add(lab)\n        }\n    }\n\n    private fun addAxis(geomBounds: DoubleRectangle) {\n        // X axis (below geom area)\n        if (myLayoutInfo.xAxisShown) {\n            val axis = buildAxis(myScaleX, myLayoutInfo.xAxisInfo!!, myCoord, myTheme.axisX())\n            axis.moveTo(DoubleVector(geomBounds.left, geomBounds.bottom))\n            add(axis)\n        }\n        // Y axis (to the left from geom area, axis elements have negative x-positions)\n        if (myLayoutInfo.yAxisShown) {\n            val axis = buildAxis(myScaleY, myLayoutInfo.yAxisInfo!!, myCoord, myTheme.axisY())\n            axis.moveTo(geomBounds.origin)\n            add(axis)\n        }\n    }\n\n    private fun buildAxis(\n        scale: Scale<Double>,\n        info: AxisLayoutInfo,\n        coord: CoordinateSystem,\n        theme: AxisTheme\n    ): AxisComponent {\n        val axis = AxisComponent(info.axisLength, info.orientation!!)\n        AxisUtil.setBreaks(axis, scale, coord, info.orientation.isHorizontal)\n        AxisUtil.applyLayoutInfo(axis, info)\n        AxisUtil.applyTheme(axis, theme)\n        if (isDebugDrawing) {\n            if (info.tickLabelsBounds != null) {\n                val rect = SvgRectElement(info.tickLabelsBounds)\n                rect.strokeColor().set(Color.GREEN)\n                rect.strokeWidth().set(1.0)\n                rect.fillOpacity().set(0.0)\n                axis.add(rect)\n            }\n        }\n        return axis\n    }\n\n    private fun buildGeoms(\n        sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>,\n        overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>,\n        coord: CoordinateSystem\n    ): List<SvgComponent> {\n\n        val layerRenderers = ArrayList<SvgComponent>()\n        for (layer in myLayers) {\n            val rendererData = LayerRendererUtil.createLayerRendererData(\n                layer,\n                sharedNumericMappers,\n                overallNumericDomains\n            )\n\n            val aestheticMappers = rendererData.aestheticMappers\n            val aesthetics = rendererData.aesthetics\n\n            val targetCollector = LayerTargetCollectorWithLocator(\n                layer.geomKind,\n                layer.locatorLookupSpec,\n                layer.contextualMapping,\n                coord\n            )\n            myTargetLocators.add(targetCollector)\n\n            val ctx = GeomContextBuilder()\n                .aesthetics(aesthetics)\n                .aestheticMappers(aestheticMappers)\n                .geomTargetCollector(targetCollector)\n                .build()\n\n            val pos = rendererData.pos\n            val geom = layer.geom\n\n            layerRenderers.add(SvgLayerRenderer(aesthetics, geom, pos, coord, ctx))\n        }\n        return layerRenderers\n    }\n\n    fun setShowAxis(showAxis: Boolean) {\n        myShowAxis = showAxis\n    }\n\n    fun debugDrawing(): Property<Boolean> {\n        return myDebugDrawing\n    }\n}\n\nprivate fun GeomLayer.createCanvasFigure(bounds: DoubleRectangle): LiveMapProvider.LiveMapData {\n    return (geom as LiveMapGeom).createCanvasFigure(bounds)\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult\nimport jetbrains.datalore.plot.builder.interact.TooltipSpec\nimport jetbrains.datalore.plot.builder.interact.TooltipSpecFactory\nimport jetbrains.datalore.plot.builder.interact.loc.LocatedTargetsPicker\nimport jetbrains.datalore.plot.builder.interact.loc.TransformedTargetLocator\n\ninternal class PlotTooltipHelper {\n    private val myTileInfos = ArrayList<TileInfo>()\n\n    fun removeAllTileInfos() {\n        myTileInfos.clear()\n    }\n\n    fun addTileInfo(geomBounds: DoubleRectangle, targetLocators: List<GeomTargetLocator>) {\n        val tileInfo = TileInfo(\n            geomBounds,\n            targetLocators\n        )\n        myTileInfos.add(tileInfo)\n    }\n\n    fun createTooltipSpecs(plotCoord: DoubleVector): List<TooltipSpec> {\n        val tileInfo = findTileInfo(plotCoord) ?: return emptyList()\n\n        val lookupResults = tileInfo.findTargets(plotCoord)\n        return createTooltipSpecs(lookupResults, tileInfo.axisOrigin)\n    }\n\n    fun getGeomBounds(plotCoord: DoubleVector): DoubleRectangle? {\n        val tileInfo = findTileInfo(plotCoord) ?: return null\n        return tileInfo.geomBounds\n    }\n\n    private fun findTileInfo(plotCoord: DoubleVector): TileInfo? {\n        for (tileInfo in myTileInfos) {\n            if (tileInfo.contains(plotCoord)) {\n                return tileInfo\n            }\n        }\n\n        return null\n    }\n\n    private fun createTooltipSpecs(lookupResults: List<LookupResult>, axisOrigin: DoubleVector): List<TooltipSpec> {\n        val tooltipSpecs = ArrayList<TooltipSpec>()\n\n        lookupResults.forEach { result ->\n            val factory = TooltipSpecFactory(result.contextualMapping, axisOrigin)\n            result.targets.forEach { geomTarget -> tooltipSpecs.addAll(factory.create(geomTarget)) }\n        }\n\n        return tooltipSpecs\n    }\n\n\n    private class TileInfo(\n        internal val geomBounds: DoubleRectangle,\n        targetLocators: List<GeomTargetLocator>\n    ) {\n\n        private val myTargetLocators = targetLocators.map { TileTargetLocator(it) }\n\n        internal val axisOrigin: DoubleVector\n            get() = DoubleVector(geomBounds.left, geomBounds.bottom)\n\n        internal fun findTargets(plotCoord: DoubleVector): List<LookupResult> {\n            val targetsPicker = LocatedTargetsPicker().apply {\n                for (locator in myTargetLocators) {\n                    val result = locator.search(plotCoord)\n                    if (result != null) {\n                        addLookupResult(result, plotCoord)\n                    }\n                }\n            }\n            return targetsPicker.picked\n        }\n\n        internal operator fun contains(plotCoord: DoubleVector): Boolean {\n            return geomBounds.contains(plotCoord)\n        }\n\n        private inner class TileTargetLocator(locator: GeomTargetLocator) : TransformedTargetLocator(locator) {\n\n            override fun convertToTargetCoord(coord: DoubleVector): DoubleVector {\n                return coord.subtract(geomBounds.origin)\n            }\n\n            override fun convertToPlotCoord(coord: DoubleVector): DoubleVector {\n                return coord.add(geomBounds.origin)\n            }\n\n            override fun convertToPlotDistance(distance: Double): Double {\n                return distance\n            }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Sets\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder.Companion.listMapper\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.assemble.GeomContextBuilder\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isFinite\nimport kotlin.math.max\nimport kotlin.math.min\nimport kotlin.math.sign\n\nobject PlotUtil {\n    internal fun createLayerPos(layer: GeomLayer, aes: Aesthetics): PositionAdjustment {\n        return layer.createPos(object : PosProviderContext {\n            override val aesthetics: Aesthetics\n                get() = aes\n\n            override val groupCount: Int\n                    by lazy {\n                        val set = Sets.newHashSet(aes.groups())\n                        set.size\n                    }\n        })\n    }\n\n    fun computeLayerDryRunXYRanges(\n        layer: GeomLayer, aes: Aesthetics\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val geomCtx = GeomContextBuilder().aesthetics(aes).build()\n\n        val rangesAfterPosAdjustment =\n            computeLayerDryRunXYRangesAfterPosAdjustment(layer, aes, geomCtx)\n        val (xRangeAfterSizeExpand, yRangeAfterSizeExpand) =\n            computeLayerDryRunXYRangesAfterSizeExpand(layer, aes, geomCtx)\n\n        var rangeX = rangesAfterPosAdjustment.first\n        if (rangeX == null) {\n            rangeX = xRangeAfterSizeExpand\n        } else if (xRangeAfterSizeExpand != null) {\n            rangeX = rangeX.span(xRangeAfterSizeExpand)\n        }\n\n        var rangeY = rangesAfterPosAdjustment.second\n        if (rangeY == null) {\n            rangeY = yRangeAfterSizeExpand\n        } else if (yRangeAfterSizeExpand != null) {\n            rangeY = rangeY.span(yRangeAfterSizeExpand)\n        }\n\n        return Pair(rangeX, rangeY)\n    }\n\n    private fun combineRanges(aesList: List<Aes<Double>>, aesthetics: Aesthetics): ClosedRange<Double>? {\n        var result: ClosedRange<Double>? = null\n        for (aes in aesList) {\n            val range = aesthetics.range(aes)\n            if (range != null) {\n                result = result?.span(range) ?: range\n            }\n        }\n        return result\n    }\n\n    private fun computeLayerDryRunXYRangesAfterPosAdjustment(\n        layer: GeomLayer, aes: Aesthetics, geomCtx: GeomContext\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val posAesX = Iterables.toList(Aes.affectingScaleX(layer.renderedAes()))\n        val posAesY = Iterables.toList(Aes.affectingScaleY(layer.renderedAes()))\n\n        val pos = createLayerPos(layer, aes)\n        if (pos.isIdentity) {\n            // simplified ranges\n            val rangeX = combineRanges(posAesX, aes)\n            val rangeY = combineRanges(posAesY, aes)\n            return Pair(rangeX, rangeY)\n        }\n\n        var adjustedMinX = 0.0\n        var adjustedMaxX = 0.0\n        var adjustedMinY = 0.0\n        var adjustedMaxY = 0.0\n        var rangesInited = false\n\n        val cardinality = posAesX.size * posAesY.size\n        val px = arrayOfNulls<Double>(cardinality)\n        val py = arrayOfNulls<Double>(cardinality)\n        for (p in aes.dataPoints()) {\n            var i = -1\n            for (aesX in posAesX) {\n                val valX = p.numeric(aesX)\n                for (aesY in posAesY) {\n                    val valY = p.numeric(aesY)\n                    i++\n                    px[i] = valX\n                    py[i] = valY\n                }\n            }\n\n            while (i >= 0) {\n                if (px[i] != null && py[i] != null) {\n                    val x = px[i]\n                    val y = py[i]\n                    if (isFinite(x) && isFinite(y)) {\n                        val newLoc = pos.translate(DoubleVector(x!!, y!!), p, geomCtx)\n                        val adjustedX = newLoc.x\n                        val adjustedY = newLoc.y\n                        if (rangesInited) {\n                            adjustedMinX = min(adjustedX, adjustedMinX)\n                            adjustedMaxX = max(adjustedX, adjustedMaxX)\n                            adjustedMinY = min(adjustedY, adjustedMinY)\n                            adjustedMaxY = max(adjustedY, adjustedMaxY)\n                        } else {\n                            adjustedMaxX = adjustedX\n                            adjustedMinX = adjustedMaxX\n                            adjustedMaxY = adjustedY\n                            adjustedMinY = adjustedMaxY\n                            rangesInited = true\n                        }\n                    }\n                }\n                i--\n            }\n        }\n\n        // X range\n        val xRange = if (rangesInited)\n            ClosedRange(adjustedMinX, adjustedMaxX)\n        else\n            null\n\n        val yRange = if (rangesInited)\n            ClosedRange(adjustedMinY, adjustedMaxY)\n        else\n            null\n        return Pair(xRange, yRange)\n    }\n\n    private fun computeLayerDryRunXYRangesAfterSizeExpand(\n        layer: GeomLayer,\n        aesthetics: Aesthetics,\n        geomCtx: GeomContext\n    ): Pair<ClosedRange<Double>?, ClosedRange<Double>?> {\n        val renderedAes = layer.renderedAes()\n        val computeExpandX = renderedAes.contains(Aes.WIDTH)\n        val computeExpandY = renderedAes.contains(Aes.HEIGHT)\n        val rangeX = if (computeExpandX)\n            computeLayerDryRunRangeAfterSizeExpand(\n                Aes.X,\n                Aes.WIDTH,\n                aesthetics,\n                geomCtx\n            )\n        else\n            null\n        val rangeY = if (computeExpandY)\n            computeLayerDryRunRangeAfterSizeExpand(\n                Aes.Y,\n                Aes.HEIGHT,\n                aesthetics,\n                geomCtx\n            )\n        else\n            null\n\n        return Pair(rangeX, rangeY)\n    }\n\n    private fun computeLayerDryRunRangeAfterSizeExpand(\n        locationAes: Aes<Double>, sizeAes: Aes<Double>, aesthetics: Aesthetics, geomCtx: GeomContext\n    ): ClosedRange<Double>? {\n        val locations = aesthetics.numericValues(locationAes).iterator()\n        val sizes = aesthetics.numericValues(sizeAes).iterator()\n\n        val resolution = geomCtx.getResolution(locationAes)\n        val minMax = doubleArrayOf(Double.POSITIVE_INFINITY, Double.NEGATIVE_INFINITY)\n\n        for (i in 0 until aesthetics.dataPointCount()) {\n            if (!locations.hasNext()) {\n                throw IllegalStateException(\"Index is out of bounds: $i for $locationAes\")\n            }\n            if (!sizes.hasNext()) {\n                throw IllegalStateException(\"Index is out of bounds: $i for $sizeAes\")\n            }\n            val loc = locations.next()\n            val size = sizes.next()\n            if (isFinite(loc) && isFinite(size)) {\n                val expand = resolution * (size!! / 2)\n                updateExpandedMinMax(loc!!, expand, minMax)\n            }\n        }\n\n        return if (minMax[0] <= minMax[1])\n            ClosedRange(minMax[0], minMax[1])\n        else\n            null\n    }\n\n    private fun updateExpandedMinMax(value: Double, expand: Double, expandedMinMax: DoubleArray) {\n        expandedMinMax[0] = min(value - expand, expandedMinMax[0])\n        expandedMinMax[1] = max(value + expand, expandedMinMax[1])\n    }\n\n    fun createLayerDryRunAesthetics(layer: GeomLayer): Aesthetics {\n        val dryRunMapperByAes = HashMap<Aes<Double>, (Double?) -> Double?>()\n        for (aes in layer.renderedAes()) {\n            if (aes.isNumeric) {\n                // safe cast: 'numeric' aes is always <Double>\n                @Suppress(\"UNCHECKED_CAST\")\n                dryRunMapperByAes[aes as Aes<Double>] = Mappers.IDENTITY\n            }\n        }\n\n        val mappers = prepareLayerAestheticMappers(layer, dryRunMapperByAes)\n        return createLayerAesthetics(layer, mappers, emptyMap())\n    }\n\n    internal fun prepareLayerAestheticMappers(\n        layer: GeomLayer,\n        sharedNumericMappers: Map<Aes<Double>, (Double?) -> Double?>\n    ): Map<Aes<*>, (Double?) -> Any?> {\n\n        val mappers = HashMap<Aes<*>, (Double?) -> Any?>(sharedNumericMappers)\n        for (aes in layer.renderedAes()) {\n            var mapper: ((Double?) -> Any?)? = sharedNumericMappers[aes]\n            if (mapper == null) {\n                // positional aes share their mappers\n                if (Aes.isPositionalX(aes)) {\n                    mapper = sharedNumericMappers[Aes.X]\n                } else if (Aes.isPositionalY(aes)) {\n                    mapper = sharedNumericMappers[Aes.Y]\n                }\n            }\n            if (mapper == null && layer.hasBinding(aes)) {\n                mapper = layer.scaleMap[aes].mapper\n            }\n\n            if (mapper != null) {\n                mappers[aes] = mapper\n            }\n        }\n        return mappers\n    }\n\n    internal fun createLayerAesthetics(\n        layer: GeomLayer,\n        sharedMappers: Map<Aes<*>, (Double?) -> Any?>,\n        overallNumericDomains: Map<Aes<Double>, ClosedRange<Double>>\n    ): Aesthetics {\n\n        val aesBuilder = AestheticsBuilder()\n        aesBuilder.group(layer.group)\n        for ((aes, domain) in overallNumericDomains) {\n            sharedMappers[aes]?.let { mapper ->\n                val range = ClosedRange(\n                    mapper(domain.lowerEnd) as Double,\n                    mapper(domain.upperEnd) as Double\n                )\n                aesBuilder.overallRange(aes, range)\n            }\n        }\n\n        var hasPositionalConstants = false\n        for (aes in layer.renderedAes()) {\n            if (Aes.isPositional(aes) && layer.hasConstant(aes)) {\n                hasPositionalConstants = true\n                break\n            }\n        }\n\n        val data = layer.dataFrame\n        var dataPointCount: Int? = null\n        for (aes in layer.renderedAes()) {\n            @Suppress(\"UNCHECKED_CAST\", \"NAME_SHADOWING\")\n            val aes = aes as Aes<Any>\n\n            val mapperOption = sharedMappers[aes]\n            if (layer.hasConstant(aes)) {\n                // Constant overrides binding\n                val v = layer.getConstant(aes)\n                aesBuilder.constantAes(aes, asAesValue(aes, v, mapperOption))\n            } else {\n                // No constant - look-up aes mapping\n                if (layer.hasBinding(aes)) {\n                    check(mapperOption != null) { \"No scale mapper defined for aesthetic $aes\" }\n\n                    // variable at this point must be either STAT or TRANSFORM (but not ORIGIN)\n                    val transformVar = DataFrameUtil.transformVarFor(aes)\n                    check(data.has(transformVar)) { \"Undefined var $transformVar for aesthetic $aes\" }\n                    val numericValues = data.getNumeric(transformVar)\n\n                    if (dataPointCount == null) {\n                        dataPointCount = numericValues.size\n                    } else {\n                        check(dataPointCount == numericValues.size)\n                        { \"\" + aes + \" expected data size=\" + dataPointCount + \" was size=\" + numericValues.size }\n                    }\n\n                    if (dataPointCount == 0 && hasPositionalConstants) {\n                        // put constant instead of empty list\n                        aesBuilder.constantAes(aes, layer.aestheticsDefaults.defaultValue(aes))\n                    } else {\n                        val integerFunction = listMapper(numericValues, mapperOption)\n                        aesBuilder.aes(aes, integerFunction)\n                    }\n                } else {\n                    // apply default\n                    val v = layer.getDefault(aes)\n                    aesBuilder.constantAes(\n                        aes,\n                        asAesValue(aes, v, mapperOption)\n                    )\n                }\n            }\n        }\n\n        if (dataPointCount != null && dataPointCount > 0) {\n            aesBuilder.dataPointCount(dataPointCount)\n        } else if (hasPositionalConstants) {\n            // some geoms (point, abline etc.) can be plotted with only constants\n            aesBuilder.dataPointCount(1)\n        }\n\n        return aesBuilder.build()\n    }\n\n    private fun <T> asAesValue(aes: Aes<*>, dataValue: T, mapperOption: ((Double?) -> T?)?): T {\n        return if (aes.isNumeric && mapperOption != null) {\n            mapperOption(dataValue as? Double)\n                ?: throw IllegalArgumentException(\"Can't map $dataValue to aesthetic $aes\")\n        } else dataValue\n    }\n\n    /**\n     * Expand X/Y-range to ensure that the data is placed some distance away from the axes.\n     */\n    internal fun rangeWithExpand(\n        range: ClosedRange<Double>?,\n        scale: Scale<*>,\n        includeZero: Boolean\n    ): ClosedRange<Double>? {\n        if (range == null) return null\n\n        val mulExp = scale.multiplicativeExpand\n        val addExp = scale.additiveExpand\n\n        // Compute expands in terms of the original data.\n        // Otherwise, can easily run into Infinities then using 'log10' transform\n        val continuousTransform: ContinuousTransform? = if (scale.isContinuousDomain) {\n            scale.transform as ContinuousTransform\n        } else {\n            null\n        }\n\n        val lowerEndpoint = continuousTransform?.applyInverse(range.lowerEnd) ?: range.lowerEnd\n        val upperEndpoint = continuousTransform?.applyInverse(range.upperEnd) ?: range.upperEnd\n\n        val length = upperEndpoint - lowerEndpoint\n        var lowerExpand = addExp + length * mulExp\n        var upperExpand = lowerExpand\n        if (includeZero) {\n            // zero-based plots (like bar) - do not 'expand' on the zero-end\n            if (lowerEndpoint == 0.0 ||\n                upperEndpoint == 0.0 ||\n                sign(lowerEndpoint) == sign(upperEndpoint)\n            ) {\n                if (lowerEndpoint >= 0) {\n                    lowerExpand = 0.0\n                } else {\n                    upperExpand = 0.0\n                }\n            }\n        }\n\n        val lowerEndWithExpand = (lowerEndpoint - lowerExpand).let {\n            val transformed = continuousTransform?.apply(it) ?: it\n            if (transformed.isNaN()) {\n                range.lowerEnd\n            } else {\n                transformed\n            }\n        }\n        val upperEndWithExpand = (upperEndpoint + upperExpand).let {\n            val transformed = continuousTransform?.apply(it) ?: it\n            if (transformed.isNaN()) {\n                range.upperEnd\n            } else {\n                transformed\n            }\n        }\n        return ClosedRange(lowerEndWithExpand, upperEndWithExpand)\n    }\n}\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmName(\"LazyKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin\n\nimport kotlin.reflect.KProperty\n\n/**\n * Represents a value with lazy initialization.\n *\n * To create an instance of [Lazy] use the [lazy] function.\n */\npublic interface Lazy<out T> {\n    /**\n     * Gets the lazily initialized value of the current Lazy instance.\n     * Once the value was initialized it must not change during the rest of lifetime of this Lazy instance.\n     */\n    public val value: T\n\n    /**\n     * Returns `true` if a value for this Lazy instance has been already initialized, and `false` otherwise.\n     * Once this function has returned `true` it stays `true` for the rest of lifetime of this Lazy instance.\n     */\n    public fun isInitialized(): Boolean\n}\n\n/**\n * Creates a new instance of the [Lazy] that is already initialized with the specified [value].\n */\npublic fun <T> lazyOf(value: T): Lazy<T> = InitializedLazyImpl(value)\n\n/**\n * An extension to delegate a read-only property of type [T] to an instance of [Lazy].\n *\n * This extension allows to use instances of Lazy for property delegation:\n * `val property: String by lazy { initializer }`\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Lazy<T>.getValue(thisRef: Any?, property: KProperty<*>): T = value\n\n/**\n * Specifies how a [Lazy] instance synchronizes initialization among multiple threads.\n */\npublic enum class LazyThreadSafetyMode {\n\n    /**\n     * Locks are used to ensure that only a single thread can initialize the [Lazy] instance.\n     */\n    SYNCHRONIZED,\n\n    /**\n     * Initializer function can be called several times on concurrent access to uninitialized [Lazy] instance value,\n     * but only the first returned value will be used as the value of [Lazy] instance.\n     */\n    PUBLICATION,\n\n    /**\n     * No locks are used to synchronize an access to the [Lazy] instance value; if the instance is accessed from multiple threads, its behavior is undefined.\n     *\n     * This mode should not be used unless the [Lazy] instance is guaranteed never to be initialized from more than one thread.\n     */\n    NONE,\n}\n\n\ninternal object UNINITIALIZED_VALUE\n\n// internal to be called from lazy in JS\ninternal class UnsafeLazyImpl<out T>(initializer: () -> T) : Lazy<T>, Serializable {\n    private var initializer: (() -> T)? = initializer\n    private var _value: Any? = UNINITIALIZED_VALUE\n\n    override val value: T\n        get() {\n            if (_value === UNINITIALIZED_VALUE) {\n                _value = initializer!!()\n                initializer = null\n            }\n            @Suppress(\"UNCHECKED_CAST\")\n            return _value as T\n        }\n\n    override fun isInitialized(): Boolean = _value !== UNINITIALIZED_VALUE\n\n    override fun toString(): String = if (isInitialized()) value.toString() else \"Lazy value not initialized yet.\"\n\n    private fun writeReplace(): Any = InitializedLazyImpl(value)\n}\n\ninternal class InitializedLazyImpl<out T>(override val value: T) : Lazy<T>, Serializable {\n\n    override fun isInitialized(): Boolean = true\n\n    override fun toString(): String = value.toString()\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.render.SvgRoot\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\n\nclass SvgLayerRenderer(\n    private val myAesthetics: Aesthetics,\n    private val myGeom: Geom,\n    private val myPos: PositionAdjustment,\n    private val myCoord: CoordinateSystem,\n    private val myGeomContext: GeomContext\n) : SvgComponent(), SvgRoot {\n\n    override fun buildComponent() {\n        buildLayer()\n    }\n\n    private fun buildLayer() {\n        myGeom.build(this, myAesthetics, myPos, myCoord, myGeomContext)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\n\nclass VarBinding(\n    val variable: DataFrame.Variable,\n    val aes: Aes<*>\n) {\n    override fun toString() = \"VarBinding{variable=${variable}, aes=${aes}\"\n\n    override fun equals(other: Any?): Boolean {\n        if (this === other) return true\n        if (other == null || this::class != other::class) return false\n\n        other as VarBinding\n\n        if (variable != other.variable) return false\n        if (aes != other.aes) return false\n\n        return true\n    }\n\n    override fun hashCode(): Int {\n        var result = variable.hashCode()\n        result = 31 * result + aes.hashCode()\n        return result\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.base.scale.breaks.ScaleBreaksUtil\nimport jetbrains.datalore.plot.builder.guide.*\nimport jetbrains.datalore.plot.builder.guide.ColorBarComponentSpec.Companion.DEF_NUM_BIN\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass ColorBarAssembler(\n    private val legendTitle: String,\n    private val transformedDomain: ClosedRange<Double>,\n    private val scale: Scale<Color>,\n    private val theme: LegendTheme\n) {\n\n    private var colorBarOptions: ColorBarOptions? = null\n\n    fun createColorBar(): LegendBoxInfo {\n        var scale = scale\n        if (!scale.hasBreaks()) {\n            scale = ScaleBreaksUtil.withBreaks(scale, transformedDomain, 5)\n        }\n\n        val scaleBreaks = scale.getScaleBreaks()\n        if (scaleBreaks.isEmpty) {\n            return LegendBoxInfo.EMPTY\n        }\n\n        val spec = createColorBarSpec(\n            legendTitle,\n            transformedDomain,\n            scaleBreaks,\n            scale,\n            theme,\n            colorBarOptions\n        )\n\n        return object : LegendBoxInfo(spec.size) {\n            override fun createLegendBox(): LegendBox {\n                val c = ColorBarComponent(spec)\n                c.debug = DEBUG_DRAWING\n                return c\n            }\n        }\n    }\n\n    internal fun setOptions(options: ColorBarOptions?) {\n        colorBarOptions = options\n    }\n\n    companion object {\n        private const val DEBUG_DRAWING = jetbrains.datalore.plot.FeatureSwitch.LEGEND_DEBUG_DRAWING\n\n        fun createColorBarSpec(\n            title: String,\n            transformedDomain: ClosedRange<Double>,\n            breaks: ScaleBreaks,\n            scale: Scale<Color>,\n            theme: LegendTheme,\n            options: ColorBarOptions? = null\n        ): ColorBarComponentSpec {\n\n            val legendDirection = LegendAssemblerUtil.legendDirection(theme)\n            val horizontal: Boolean = legendDirection == LegendDirection.HORIZONTAL\n\n            val width = options?.width\n            val height = options?.height\n            var barSize = ColorBarComponentSpec.barAbsoluteSize(horizontal, theme)\n            if (width != null) {\n                barSize = DoubleVector(width, barSize.y)\n            }\n            if (height != null) {\n                barSize = DoubleVector(barSize.x, height)\n            }\n\n            val reverse = !horizontal\n\n            val layout = when {\n                horizontal -> ColorBarComponentLayout.horizontal(title, transformedDomain, breaks, barSize, reverse)\n                else -> ColorBarComponentLayout.vertical(title, transformedDomain, breaks, barSize, reverse)\n            }\n\n            return ColorBarComponentSpec(\n                title,\n                transformedDomain,\n                breaks,\n                scale,\n                binCount = options?.binCount ?: DEF_NUM_BIN,\n                theme,\n                layout,\n                reverse\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nclass ColorBarOptions : GuideOptions() {\n    var width: Double? = null\n    var height: Double? = null\n    var binCount: Int? = null\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.GeomContext\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector\nimport jetbrains.datalore.plot.base.interact.NullGeomTargetCollector\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass GeomContextBuilder : ImmutableGeomContext.Builder {\n    private var myAesthetics: Aesthetics? = null\n    private var myAestheticMappers: Map<Aes<*>, (Double?) -> Any?>? = null\n    private var myGeomTargetCollector: GeomTargetCollector =\n        NullGeomTargetCollector()\n\n    constructor()\n\n    private constructor(ctx: MyGeomContext) {\n        myAesthetics = ctx.myAesthetics\n        myAestheticMappers = ctx.myAestheticMappers\n    }\n\n    override fun aesthetics(aesthetics: Aesthetics?): ImmutableGeomContext.Builder {\n        myAesthetics = aesthetics\n        return this\n    }\n\n    override fun aestheticMappers(aestheticMappers: Map<Aes<*>, (Double?) -> Any?>?): ImmutableGeomContext.Builder {\n        myAestheticMappers = aestheticMappers\n        return this\n    }\n\n    override fun geomTargetCollector(geomTargetCollector: GeomTargetCollector): ImmutableGeomContext.Builder {\n        myGeomTargetCollector = geomTargetCollector\n        return this\n    }\n\n    override fun build(): ImmutableGeomContext {\n        return MyGeomContext(this)\n    }\n\n\n    private class MyGeomContext(b: GeomContextBuilder) :\n        ImmutableGeomContext {\n        val myAesthetics = b.myAesthetics\n        val myAestheticMappers = b.myAestheticMappers\n        override val targetCollector = b.myGeomTargetCollector\n\n        override fun getResolution(aes: Aes<Double>): Double {\n            var resolution = 0.0\n            if (myAesthetics != null) {\n                resolution = myAesthetics.resolution(aes, 0.0)\n            }\n            if (resolution <= SeriesUtil.TINY) {\n                resolution = getUnitResolution(aes)\n            }\n\n            return resolution\n        }\n\n        override fun getUnitResolution(aes: Aes<Double>): Double {\n            val mapper = myAestheticMappers?.get(aes) ?: Mappers.IDENTITY\n            return mapper(1.0) as Double\n        }\n\n        override fun withTargetCollector(targetCollector: GeomTargetCollector): GeomContext {\n            return GeomContextBuilder()\n                .aesthetics(myAesthetics)\n                .aestheticMappers(myAestheticMappers)\n                .geomTargetCollector(targetCollector)\n                .build()\n        }\n\n        override fun with(): ImmutableGeomContext.Builder {\n            return GeomContextBuilder(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.geom.LiveMapGeom\nimport jetbrains.datalore.plot.base.geom.LiveMapProvider\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpec\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.stat.SimpleStatContext\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.PosProviderContext\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.geom.GeomProvider\nimport jetbrains.datalore.plot.builder.assemble.geom.PointDataAccess\nimport jetbrains.datalore.plot.builder.data.DataProcessing\nimport jetbrains.datalore.plot.builder.data.GroupingContext\nimport jetbrains.datalore.plot.builder.interact.ContextualMappingProvider\nimport jetbrains.datalore.plot.builder.scale.ScaleProvider\n\nclass GeomLayerBuilder {\n    private val myBindings = ArrayList<VarBinding>()\n    private val myConstantByAes = TypedKeyHashMap()\n    private lateinit var myStat: Stat\n    private lateinit var myPosProvider: PosProvider\n    private lateinit var myGeomProvider: GeomProvider\n    private var myGroupingVarName: String? = null\n    private var myPathIdVarName: String? = null\n    private val myScaleProviderByAes = HashMap<Aes<*>, ScaleProvider<*>>()\n\n    private var myDataPreprocessor: ((DataFrame, TypedScaleMap) -> DataFrame)? = null\n    private var myLocatorLookupSpec: LookupSpec = LookupSpec.NONE\n    private var myContextualMappingProvider: ContextualMappingProvider = ContextualMappingProvider.NONE\n\n    private var myIsLegendDisabled: Boolean = false\n\n    fun stat(v: Stat): GeomLayerBuilder {\n        myStat = v\n        return this\n    }\n\n    fun pos(v: PosProvider): GeomLayerBuilder {\n        myPosProvider = v\n        return this\n    }\n\n    fun geom(v: GeomProvider): GeomLayerBuilder {\n        myGeomProvider = v\n        return this\n    }\n\n    fun addBinding(v: VarBinding): GeomLayerBuilder {\n        myBindings.add(v)\n        return this\n    }\n\n    fun groupingVar(v: DataFrame.Variable): GeomLayerBuilder {\n        myGroupingVarName = v.name\n        return this\n    }\n\n    fun groupingVarName(v: String): GeomLayerBuilder {\n        myGroupingVarName = v\n        return this\n    }\n\n    fun pathIdVarName(v: String): GeomLayerBuilder {\n        myPathIdVarName = v\n        return this\n    }\n\n    fun <T> addConstantAes(aes: Aes<T>, v: T): GeomLayerBuilder {\n        myConstantByAes.put(aes, v)\n        return this\n    }\n\n    fun <T> addScaleProvider(aes: Aes<T>, scaleProvider: ScaleProvider<T>): GeomLayerBuilder {\n        myScaleProviderByAes[aes] = scaleProvider\n        return this\n    }\n\n    fun locatorLookupSpec(v: LookupSpec): GeomLayerBuilder {\n        myLocatorLookupSpec = v\n        return this\n    }\n\n    fun contextualMappingProvider(v: ContextualMappingProvider): GeomLayerBuilder {\n        myContextualMappingProvider = v\n        return this\n    }\n\n    fun disableLegend(v: Boolean): GeomLayerBuilder {\n        myIsLegendDisabled = v\n        return this\n    }\n\n    fun build(data: DataFrame, scaleMap: TypedScaleMap): GeomLayer {\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n        if (myDataPreprocessor != null) {\n            data = myDataPreprocessor!!(data, scaleMap)\n        }\n\n        // make sure 'original' series are transformed\n        data = DataProcessing.transformOriginals(data, myBindings, scaleMap)\n\n        val replacementBindings = HashMap(\n            // No 'origin' variables beyond this point.\n            // Replace all 'origin' variables in bindings with 'transform' variables\n            myBindings.map {\n                it.aes to if (it.variable.isOrigin) {\n                    val transformVar = DataFrameUtil.transformVarFor(it.aes)\n                    VarBinding(transformVar, it.aes)\n                } else {\n                    it\n                }\n            }.toMap()\n        )\n\n        // add 'transform' variable for each 'stat' variable\n        val bindingsToPut = ArrayList<VarBinding>()\n        for (binding in replacementBindings.values) {\n            val variable = binding.variable\n            if (variable.isStat) {\n                val aes = binding.aes\n                val scale = scaleMap[aes]\n                data = DataFrameUtil.applyTransform(data, variable, aes, scale)\n                bindingsToPut.add(VarBinding(TransformVar.forAes(aes), aes))\n            }\n        }\n\n        // replace 'stat' vars with 'transform' vars in bindings\n        for (binding in bindingsToPut) {\n            replacementBindings[binding.aes] = binding\n        }\n\n        // (!) Positional aes scales have undefined `mapper` at this time because\n        // dimensions of plot are not yet known.\n        // Data Access shouldn't use aes mapper (!)\n        val dataAccess = PointDataAccess(data, replacementBindings, scaleMap)\n\n        return MyGeomLayer(\n            data,\n            myGeomProvider,\n            myPosProvider,\n            myGeomProvider.renders(),\n            GroupingContext(data, myBindings, myGroupingVarName, myPathIdVarName, handlesGroups()).groupMapper,\n            replacementBindings.values,\n            myConstantByAes,\n            scaleMap,\n            dataAccess,\n            myLocatorLookupSpec,\n            myContextualMappingProvider.createContextualMapping(dataAccess, data),\n            myIsLegendDisabled\n        )\n    }\n\n    private fun handlesGroups(): Boolean {\n        return myGeomProvider.handlesGroups() || myPosProvider.handlesGroups()\n    }\n\n\n    private class MyGeomLayer(\n        override val dataFrame: DataFrame,\n        geomProvider: GeomProvider,\n        private val myPosProvider: PosProvider,\n        renderedAes: List<Aes<*>>,\n        override val group: (Int) -> Int,\n        varBindings: Collection<VarBinding>,\n        constantByAes: TypedKeyHashMap,\n        override val scaleMap: TypedScaleMap,\n        override val dataAccess: MappedDataAccess,\n        override val locatorLookupSpec: LookupSpec,\n        override val contextualMapping: ContextualMapping,\n        override val isLegendDisabled: Boolean\n    ) : GeomLayer {\n\n        override val geom: Geom = geomProvider.createGeom()\n        override val geomKind: GeomKind = geomProvider.geomKind\n        override val aestheticsDefaults: AestheticsDefaults\n\n        private val myRenderedAes: List<Aes<*>>\n        private val myConstantByAes: TypedKeyHashMap\n        private val myVarBindingsByAes = HashMap<Aes<*>, VarBinding>()\n\n        override val legendKeyElementFactory: LegendKeyElementFactory\n            get() = geom.legendKeyElementFactory\n\n        override val isLiveMap: Boolean\n            get() = geom is LiveMapGeom\n\n        init {\n            myRenderedAes = ArrayList(renderedAes)\n\n            // constant value by aes (default + specified)\n            aestheticsDefaults = geomProvider.aestheticsDefaults()\n            myConstantByAes = TypedKeyHashMap()\n\n            for (key in constantByAes.keys<Any>()) {\n                myConstantByAes.put(key, constantByAes[key])\n            }\n\n            for (varBinding in varBindings) {\n                myVarBindingsByAes[varBinding.aes] = varBinding\n            }\n        }\n\n        override fun renderedAes(): List<Aes<*>> {\n            return myRenderedAes\n        }\n\n        override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n            return myPosProvider.createPos(ctx)\n        }\n\n        override fun hasBinding(aes: Aes<*>): Boolean {\n            return myVarBindingsByAes.containsKey(aes)\n        }\n\n        override fun <T> getBinding(aes: Aes<T>): VarBinding {\n            return myVarBindingsByAes[aes]!!\n        }\n\n        override fun hasConstant(aes: Aes<*>): Boolean {\n            return myConstantByAes.containsKey(aes)\n        }\n\n        override fun <T> getConstant(aes: Aes<T>): T {\n            require(hasConstant(aes)) { \"Constant value is not defined for aes $aes\" }\n            return myConstantByAes[aes]\n        }\n\n        override fun <T> getDefault(aes: Aes<T>): T {\n            return aestheticsDefaults.defaultValue(aes)\n        }\n\n        override fun rangeIncludesZero(aes: Aes<*>): Boolean {\n            return aestheticsDefaults.rangeIncludesZero(aes)\n        }\n\n        override fun setLiveMapProvider(liveMapProvider: LiveMapProvider) {\n            if (geom is LiveMapGeom) {\n                geom.setLiveMapProvider(liveMapProvider)\n            } else {\n                throw IllegalStateException(\"Not Livemap: \" + geom::class.simpleName)\n            }\n        }\n    }\n\n    companion object {\n\n        fun demoAndTest(): GeomLayerBuilder {\n            val builder = GeomLayerBuilder()\n            builder.myDataPreprocessor = { data, scaleMap ->\n                val transformedData = DataProcessing.transformOriginals(data, builder.myBindings, scaleMap)\n                when (val stat = builder.myStat) {\n                    Stats.IDENTITY -> transformedData\n                    else -> {\n                        val statCtx = SimpleStatContext(transformedData)\n                        val groupingContext =\n                            GroupingContext(\n                                transformedData,\n                                builder.myBindings,\n                                builder.myGroupingVarName,\n                                builder.myPathIdVarName,\n                                true\n                            )\n                        val dataAndGroupingContext = DataProcessing.buildStatData(\n                            transformedData,\n                            stat,\n                            builder.myBindings,\n                            scaleMap,\n                            groupingContext,\n                            PlotFacets.undefined(),\n                            statCtx,\n                            varsWithoutBinding = emptyList(),\n                            orderOptions = emptyList(),\n                            aggregateOperation = null,\n                            ::println\n                        )\n\n                        dataAndGroupingContext.data\n                    }\n                }\n            }\n\n            return builder\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport kotlin.native.concurrent.ThreadLocal\n\nabstract class GuideOptions {\n\n    var isReverse: Boolean = false\n\n    // In Kotlin Native objects a frozen by default. Annotate with `ThreadLocal` to unfreeze.\n    // @link https://github.com/JetBrains/kotlin-native/blob/master/IMMUTABILITY.md\n    // Required mutations:\n    //      -   `isReverse` in the 'outer' class\n    @ThreadLocal\n    companion object {\n        val NONE: GuideOptions = object : GuideOptions() {}\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.scale.breaks.ScaleBreaksUtil\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.LegendAssemblerUtil.mapToAesthetics\nimport jetbrains.datalore.plot.builder.guide.*\nimport jetbrains.datalore.plot.builder.layout.LegendBoxInfo\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.min\n\nclass LegendAssembler(\n    private val legendTitle: String,\n    private val guideOptionsMap: Map<Aes<*>, GuideOptions>,\n    private val theme: LegendTheme\n) {\n\n    private val legendLayers = ArrayList<LegendLayer>()\n\n    fun addLayer(\n        keyFactory: LegendKeyElementFactory,\n        varBindings: List<VarBinding>,\n        constantByAes: Map<Aes<*>, Any>,\n        aestheticsDefaults: AestheticsDefaults,\n        scaleByAes: TypedScaleMap,\n        transformedDomainByAes: Map<Aes<*>, ClosedRange<Double>>\n    ) {\n\n        legendLayers.add(\n            LegendLayer(\n                keyFactory,\n                varBindings,\n                constantByAes,\n                aestheticsDefaults,\n                scaleByAes,\n                transformedDomainByAes\n            )\n        )\n    }\n\n    fun createLegend(): LegendBoxInfo {\n        val legendBreaksByLabel = LinkedHashMap<String, LegendBreak>()\n        for (legendLayer in legendLayers) {\n            val keyElementFactory = legendLayer.keyElementFactory\n            val dataPoints = legendLayer.keyAesthetics.dataPoints().iterator()\n            for (label in legendLayer.keyLabels) {\n                legendBreaksByLabel.getOrPut(label) { LegendBreak(label) }\n                    .addLayer(dataPoints.next(), keyElementFactory)\n            }\n        }\n\n        val legendBreaks = ArrayList<LegendBreak>()\n        for (legendBreak in legendBreaksByLabel.values) {\n            if (legendBreak.isEmpty) {\n                continue\n            }\n            legendBreaks.add(legendBreak)\n        }\n\n\n        if (legendBreaks.isEmpty()) {\n            return LegendBoxInfo.EMPTY\n        }\n\n        // legend options\n        val legendOptionsList = ArrayList<LegendOptions>()\n        for (legendLayer in legendLayers) {\n            val aesList = legendLayer.aesList\n            for (aes in aesList) {\n                if (guideOptionsMap[aes] is LegendOptions) {\n                    legendOptionsList.add(guideOptionsMap[aes] as LegendOptions)\n                }\n            }\n        }\n\n        val spec =\n            createLegendSpec(\n                legendTitle, legendBreaks, theme,\n                LegendOptions.combine(\n                    legendOptionsList\n                )\n            )\n\n        return object : LegendBoxInfo(spec.size) {\n            override fun createLegendBox(): LegendBox {\n                val c = LegendComponent(spec)\n                c.debug = DEBUG_DRAWING\n                return c\n            }\n        }\n    }\n\n\n    private class LegendLayer(\n        internal val keyElementFactory: LegendKeyElementFactory,\n        private val varBindings: List<VarBinding>,\n        private val constantByAes: Map<Aes<*>, Any>,\n        private val aestheticsDefaults: AestheticsDefaults,\n        private val scaleMap: TypedScaleMap,\n        transformedDomainByAes: Map<Aes<*>, ClosedRange<Double>>\n    ) {\n\n        internal val keyAesthetics: Aesthetics\n        internal val keyLabels: List<String>\n\n        internal val aesList: List<Aes<*>>\n            get() = varBindings.map { it.aes }\n\n        init {\n            val aesValuesByLabel = LinkedHashMap<String, MutableMap<Aes<*>, Any>>()\n            for (varBinding in varBindings) {\n                val aes = varBinding.aes\n                var scale = scaleMap[aes]\n                if (!scale.hasBreaks()) {\n                    scale = ScaleBreaksUtil.withBreaks(scale, transformedDomainByAes.getValue(aes), 5)\n                }\n                check(scale.hasBreaks()) { \"No breaks were defined for scale $aes\" }\n\n//                val aesValues = ScaleUtil.transformAndMap(scale.breaks, scale)\n//                val labels = ScaleUtil.labels(scale)\n                val scaleBreaks = scale.getScaleBreaks()\n                val aesValues = ScaleUtil.map(scaleBreaks.transformedValues, scale)\n                val labels = scaleBreaks.labels\n                for ((label, aesValue) in labels.zip(aesValues)) {\n                    aesValuesByLabel.getOrPut(label) { HashMap() }[aes] = aesValue!!\n                }\n            }\n\n            // build 'key' aesthetics\n            keyAesthetics = mapToAesthetics(aesValuesByLabel.values, constantByAes, aestheticsDefaults)\n            keyLabels = ArrayList(aesValuesByLabel.keys)\n        }\n    }\n\n    companion object {\n        private const val DEBUG_DRAWING = jetbrains.datalore.plot.FeatureSwitch.LEGEND_DEBUG_DRAWING\n\n        fun createLegendSpec(\n            title: String,\n            breaks: List<LegendBreak>,\n            theme: LegendTheme,\n            options: LegendOptions = LegendOptions()\n        ): LegendComponentSpec {\n\n            val legendDirection = LegendAssemblerUtil.legendDirection(theme)\n\n            // key size\n            fun pretty(v: DoubleVector): DoubleVector {\n                val margin = 1.0\n                return DoubleVector(\n                    floor(v.x / 2) * 2 + 1.0 + margin,\n                    floor(v.y / 2) * 2 + 1.0 + margin\n                )\n            }\n\n            var keySize = DoubleVector(theme.keySize(), theme.keySize())\n            for (br in breaks) {\n                val minimumKeySize = br.minimumKeySize\n                keySize = keySize.max(pretty(minimumKeySize))\n            }\n\n            // row, col count\n            val breakCount = breaks.size\n            val colCount: Int\n            val rowCount: Int\n            if (options.isByRow) {\n                colCount = when {\n                    options.hasColCount() -> min(options.colCount, breakCount)\n                    options.hasRowCount() -> ceil(breakCount / options.rowCount.toDouble()).toInt()\n                    legendDirection === LegendDirection.HORIZONTAL -> breakCount\n                    else -> 1\n                }\n                rowCount = ceil(breakCount / colCount.toDouble()).toInt()\n            } else {\n                // by column\n                rowCount = when {\n                    options.hasRowCount() -> min(options.rowCount, breakCount)\n                    options.hasColCount() -> ceil(breakCount / options.colCount.toDouble()).toInt()\n                    legendDirection !== LegendDirection.HORIZONTAL -> breakCount\n                    else -> 1\n                }\n                colCount = ceil(breakCount / rowCount.toDouble()).toInt()\n            }\n\n            val layout: LegendComponentLayout\n            @Suppress(\"LiftReturnOrAssignment\")\n            if (legendDirection === LegendDirection.HORIZONTAL) {\n                if (options.hasRowCount() || options.hasColCount() && options.colCount < breakCount) {\n                    layout = LegendComponentLayout.horizontalMultiRow(\n                        title,\n                        breaks,\n                        keySize\n                    )\n                } else {\n                    layout = LegendComponentLayout.horizontal(title, breaks, keySize)\n                }\n            } else {\n                layout = LegendComponentLayout.vertical(title, breaks, keySize)\n            }\n\n            layout.colCount = colCount\n            layout.rowCount = rowCount\n            layout.isFillByRow = options.isByRow\n\n            return LegendComponentSpec(\n                title,\n                breaks,\n                theme,\n                layout,\n                reverse = false\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.aes.AestheticsBuilder\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.builder.guide.LegendDirection\nimport jetbrains.datalore.plot.builder.guide.LegendPosition\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\ninternal object LegendAssemblerUtil {\n    fun <T> mapToAesthetics(\n        valuesByAes: Map<Aes<T>, List<T>>, constantByAes: Map<Aes<T>, T>, aestheticsDefaults: AestheticsDefaults\n    ): Aesthetics {\n        val builder = AestheticsBuilder(0)\n        for (aes in Aes.values()) {\n            @Suppress(\"UNCHECKED_CAST\")\n            builder.constantAes(aes as Aes<Any>, aestheticsDefaults.defaultValue(aes))\n        }\n        for (aes in valuesByAes.keys) {\n            val values = valuesByAes[aes]!!\n            builder.aes(aes, AestheticsBuilder.collection(values))\n            builder.dataPointCount(values.size)\n        }\n        for (aes in constantByAes.keys) {\n            builder.constantAes<T>(aes, constantByAes[aes]!!)\n        }\n        return builder.build()\n    }\n\n\n    fun mapToAesthetics(\n        valueByAesIterable: Collection<Map<Aes<*>, Any>>,\n        constantByAes: Map<Aes<*>, Any>,\n        aestheticsDefaults: AestheticsDefaults\n    ): Aesthetics {\n        val dataPoints = ArrayList<Map<Aes<*>, Any>>()\n        for (valueByAes in valueByAesIterable) {\n            val dataPoint = HashMap<Aes<*>, Any>()\n            for (aes in Aes.values()) {\n                dataPoint[aes] = aestheticsDefaults.defaultValueInLegend(aes)!!\n            }\n\n            // Derive some aesthetics from constants\n            for (constantAes in constantByAes.keys) {\n                when (constantAes) {\n                    Aes.SHAPE,\n                    Aes.COLOR,\n                    Aes.FILL -> dataPoint[constantAes] = constantByAes[constantAes]!!\n                }\n            }\n\n            for (aes in valueByAes.keys) {\n                dataPoint[aes] = valueByAes[aes]!!\n            }\n\n            dataPoints.add(dataPoint)\n        }\n\n        val builder = AestheticsBuilder(dataPoints.size)\n        for (aes in Aes.values()) {\n            @Suppress(\"UNCHECKED_CAST\")\n            builder.aes(aes as Aes<Any>) { index -> dataPoints[index][aes]!! }\n        }\n        return builder.build()\n    }\n\n    fun legendDirection(theme: LegendTheme): LegendDirection {\n        var legendDirection = theme.direction()\n        if (legendDirection === LegendDirection.AUTO) {\n            val legendPosition = theme.position()\n            legendDirection =\n                if (legendPosition === LegendPosition.TOP || legendPosition === LegendPosition.BOTTOM)\n                    LegendDirection.HORIZONTAL\n                else\n                    LegendDirection.VERTICAL\n        }\n        return legendDirection\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport kotlin.math.max\n\nclass LegendOptions : GuideOptions() {\n\n    private var myColCount: Int? = null\n    private var myRowCount: Int? = null\n    var isByRow: Boolean = false\n\n    var colCount: Int\n        get() = myColCount!!\n        set(colCount) {\n            myColCount = max(1, colCount)\n        }\n\n    var rowCount: Int\n        get() = myRowCount!!\n        set(rowCount) {\n            myRowCount = max(1, rowCount)\n        }\n\n    fun hasColCount(): Boolean {\n        return myColCount != null\n    }\n\n    fun hasRowCount(): Boolean {\n        return myRowCount != null\n    }\n\n    companion object {\n        fun combine(optionsList: List<LegendOptions>): LegendOptions {\n            val result = LegendOptions()\n            for (options in optionsList) {\n                if (options.isByRow) {\n                    result.isByRow = true\n                }\n                if (options.hasColCount()) {\n                    result.colCount = options.colCount\n                }\n                if (options.hasRowCount()) {\n                    result.rowCount = options.rowCount\n                }\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkState\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.Plot\nimport jetbrains.datalore.plot.builder.PlotBuilder\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.theme.Theme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nclass PlotAssembler private constructor(\n    private val scaleByAes: TypedScaleMap,\n    val layersByTile: List<List<GeomLayer>>,\n    private val myCoordProvider: CoordProvider,\n    private val myTheme: Theme\n) {\n\n    val containsLiveMap: Boolean\n\n    var facets: PlotFacets = PlotFacets.undefined()\n    private var myTitle: String? = null\n    private var myGuideOptionsMap: Map<Aes<*>, GuideOptions> = HashMap()\n    private var myAxisEnabled: Boolean\n    private var myLegendsEnabled = true\n    private var myInteractionsEnabled = true\n\n    init {\n        containsLiveMap = layersByTile.flatten().any(GeomLayer::isLiveMap)\n        myAxisEnabled = !containsLiveMap  // no axis on livemap\n    }\n\n    fun setTitle(title: String?) {\n        myTitle = title\n    }\n\n    private fun hasLayers(): Boolean {\n        for (tileLayers in layersByTile) {\n            if (tileLayers.isNotEmpty()) {\n                return true\n            }\n        }\n        return false\n    }\n\n    fun createPlot(): Plot {\n        require(hasLayers()) { \"No layers in plot\" }\n\n        val legendsBoxInfos = if (myLegendsEnabled)\n            PlotAssemblerUtil.createLegends(\n                layersByTile,\n                myGuideOptionsMap,\n                myTheme.legend()\n            )\n        else\n            emptyList()\n\n        // share first X/Y scale among all layers\n        var xScaleProto = scaleByAes[Aes.X]\n        var yScaleProto = scaleByAes[Aes.Y]\n\n        if (containsLiveMap) {\n            // build 'live map' plot:\n            //  - skip X/Y scale training\n            //  - ignore coord provider\n            //  - plot layout without axes\n            val plotLayout = PlotAssemblerUtil.createPlotLayout(\n                LiveMapTileLayout(),\n                facets\n            )\n            return createXYPlot(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos, hasLiveMap = true)\n        }\n\n        // train X/Y scales\n        val (xDomain, yDomain) = PlotAssemblerUtil.computePlotDryRunXYRanges(layersByTile)\n\n        val xAxisLayout: AxisLayout\n        val yAxisLayout: AxisLayout\n        if (myAxisEnabled) {\n            xAxisLayout = PlotAxisLayout.bottom(xScaleProto, xDomain, yDomain, myCoordProvider, myTheme.axisX())\n            yAxisLayout = PlotAxisLayout.left(yScaleProto, xDomain, yDomain, myCoordProvider, myTheme.axisY())\n        } else {\n            xAxisLayout = EmptyAxisLayout.bottom(xDomain, yDomain)\n            yAxisLayout = EmptyAxisLayout.left(xDomain, yDomain)\n        }\n\n        val plotLayout = PlotAssemblerUtil.createPlotLayout(\n            XYPlotTileLayout(xAxisLayout, yAxisLayout),\n            facets\n        )\n        if (!myAxisEnabled) {\n            plotLayout.setPadding(0.0, 0.0, 0.0, 0.0)\n        }\n\n        return createXYPlot(xScaleProto, yScaleProto, plotLayout, legendsBoxInfos)\n    }\n\n\n    private fun createXYPlot(\n        xScaleProto: Scale<Double>,\n        yScaleProto: Scale<Double>,\n        plotLayout: PlotLayout,\n        legendBoxInfos: List<LegendBoxInfo>,\n        hasLiveMap: Boolean = false\n    ): Plot {\n\n        val plotBuilder = PlotBuilder(myTheme)\n        plotBuilder.setTitle(myTitle)\n        plotBuilder.scaleXProto(xScaleProto)\n        plotBuilder.scaleYProto(yScaleProto)\n        plotBuilder.setAxisTitleBottom(xScaleProto.name)\n        plotBuilder.setAxisTitleLeft(yScaleProto.name)\n        plotBuilder.setCoordProvider(myCoordProvider)\n        for (legendBoxInfo in legendBoxInfos) {\n            plotBuilder.addLegendBoxInfo(legendBoxInfo)\n        }\n        for (panelLayers in layersByTile) {\n            plotBuilder.addTileLayers(panelLayers)\n        }\n\n        plotBuilder.setPlotLayout(plotLayout)\n        plotBuilder.axisEnabled(myAxisEnabled)\n        plotBuilder.interactionsEnabled(myInteractionsEnabled)\n        plotBuilder.setLiveMap(hasLiveMap)\n        return plotBuilder.build()\n    }\n\n    fun setGuideOptionsMap(guideOptionsMap: Map<Aes<*>, GuideOptions>) {\n        myGuideOptionsMap = guideOptionsMap\n    }\n\n    fun disableAxis() {\n        myAxisEnabled = false\n    }\n\n    fun disableLegends() {\n        myLegendsEnabled = false\n    }\n\n    fun disableInteractions() {\n        myInteractionsEnabled = false\n    }\n\n    companion object {\n        fun singleTile(\n            scaleByAes: TypedScaleMap,\n            plotLayers: List<GeomLayer>,\n            coordProvider: CoordProvider,\n            theme: Theme\n        ): PlotAssembler {\n            val layersByTile = ArrayList<List<GeomLayer>>()\n            layersByTile.add(plotLayers)\n            return multiTile(\n                scaleByAes,\n                layersByTile,\n                coordProvider,\n                theme\n            )\n        }\n\n        fun multiTile(\n            scaleByAes: TypedScaleMap,\n            layersByTile: List<List<GeomLayer>>,\n            coordProvider: CoordProvider,\n            theme: Theme\n        ): PlotAssembler {\n            return PlotAssembler(scaleByAes, layersByTile, coordProvider, theme)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aesthetics\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.builder.GeomLayer\nimport jetbrains.datalore.plot.builder.PlotUtil\nimport jetbrains.datalore.plot.builder.PlotUtil.computeLayerDryRunXYRanges\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.checkFitsColorBar\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.createColorBarAssembler\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.fitsColorBar\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.guideTransformedDomainByAes\nimport jetbrains.datalore.plot.builder.assemble.PlotGuidesAssemblerUtil.mappedRenderedAesToCreateGuides\nimport jetbrains.datalore.plot.builder.layout.*\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal object PlotAssemblerUtil {\n\n    private fun updateAesRangeMap(\n        aes: Aes<*>,\n        range: ClosedRange<Double>?,\n        rangeByAes: MutableMap<Aes<*>, ClosedRange<Double>>\n    ) {\n        @Suppress(\"NAME_SHADOWING\")\n        var range = range\n        if (range != null) {\n            val wasRange = rangeByAes[aes]\n            if (wasRange != null) {\n                range = wasRange.span(range)\n            }\n            rangeByAes[aes] = range\n        }\n    }\n\n    private fun updateRange(range: ClosedRange<Double>?, wasRange: ClosedRange<Double>?): ClosedRange<Double>? {\n        @Suppress(\"NAME_SHADOWING\")\n        var range = range\n        if (range != null) {\n            if (wasRange != null) {\n                range = wasRange.span(range)\n            }\n            return range\n        }\n        return wasRange\n    }\n\n    private fun updateRange(values: Iterable<Double>, wasRange: ClosedRange<Double>?): ClosedRange<Double>? {\n        if (!Iterables.isEmpty(values)) {\n            var newRange = ClosedRange.encloseAll(values)\n            if (wasRange != null) {\n                newRange = wasRange.span(newRange)\n            }\n            return newRange\n        }\n        return wasRange\n    }\n\n    fun createLegends(\n        layersByPanel: List<List<GeomLayer>>,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>,\n        theme: LegendTheme\n    ): List<LegendBoxInfo> {\n\n        // stitch together layers from all panels\n        var planeCount = 0\n        if (layersByPanel.isNotEmpty()) {\n            planeCount = layersByPanel[0].size\n        }\n\n        val stitchedLayersList = ArrayList<StitchedPlotLayers>()\n        for (i in 0 until planeCount) {\n            val layersOnPlane = ArrayList<GeomLayer>()\n\n            // collect layer[i] chunks from all panels\n            for (panelLayers in layersByPanel) {\n                layersOnPlane.add(panelLayers[i])\n            }\n\n            stitchedLayersList.add(\n                StitchedPlotLayers(\n                    layersOnPlane\n                )\n            )\n        }\n\n        val transformedDomainByAes = HashMap<Aes<*>, ClosedRange<Double>>()\n        for (stitchedPlotLayers in stitchedLayersList) {\n            val layerTransformedDomainByAes = guideTransformedDomainByAes(stitchedPlotLayers, guideOptionsMap)\n            for ((aes, transformedDomain) in layerTransformedDomainByAes) {\n                updateAesRangeMap(\n                    aes,\n                    transformedDomain,\n                    transformedDomainByAes\n                )\n            }\n        }\n\n        return createLegends(\n            stitchedLayersList,\n            transformedDomainByAes,\n            guideOptionsMap,\n            theme\n        )\n    }\n\n    private fun createLegends(\n        stitchedLayersList: List<StitchedPlotLayers>,\n        transformedDomainByAes: Map<Aes<*>, ClosedRange<Double>>,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>,\n        theme: LegendTheme\n    ): List<LegendBoxInfo> {\n\n        val legendAssemblerByTitle = LinkedHashMap<String, LegendAssembler>()\n        val colorBarAssemblerByTitle = LinkedHashMap<String, ColorBarAssembler>()\n\n        for (stitchedLayers in stitchedLayersList) {\n            val layerConstantByAes = HashMap<Aes<*>, Any>()\n            for (aes in stitchedLayers.renderedAes()) {\n                if (stitchedLayers.hasConstant(aes)) {\n                    layerConstantByAes[aes] = stitchedLayers.getConstant(aes)!!\n                }\n            }\n\n            val layerBindingsByScaleName = LinkedHashMap<String, MutableList<VarBinding>>()\n            val aesList = mappedRenderedAesToCreateGuides(stitchedLayers, guideOptionsMap)\n            for (aes in aesList) {\n                var colorBar = false\n                val binding = stitchedLayers.getBinding(aes)\n                val scale = stitchedLayers.getScale(aes)\n                val scaleName = scale.name\n                if (guideOptionsMap.containsKey(aes)) {\n                    val guideOptions = guideOptionsMap[aes]\n                    if (guideOptions is ColorBarOptions) {\n                        checkFitsColorBar(binding.aes, scale)\n                        colorBar = true\n                        @Suppress(\"UNCHECKED_CAST\")\n                        val colorScale = scale as Scale<Color>\n                        colorBarAssemblerByTitle[scaleName] = createColorBarAssembler(\n                            scaleName, binding.aes,\n                            transformedDomainByAes, colorScale, guideOptions, theme\n                        )\n                    }\n                } else if (fitsColorBar(binding.aes, scale)) {\n                    colorBar = true\n                    @Suppress(\"UNCHECKED_CAST\")\n                    val colorScale = scale as Scale<Color>\n                    colorBarAssemblerByTitle[scaleName] = createColorBarAssembler(\n                        scaleName, binding.aes,\n                        transformedDomainByAes, colorScale, null, theme\n                    )\n                }\n\n                if (!colorBar) {\n                    layerBindingsByScaleName.getOrPut(scaleName) { ArrayList() }.add(binding)\n                }\n            }\n\n            for (scaleName in layerBindingsByScaleName.keys) {\n                val legendAssembler = legendAssemblerByTitle.getOrPut(scaleName) {\n                    LegendAssembler(\n                        scaleName,\n                        guideOptionsMap,\n                        theme\n                    )\n                }\n\n                val varBindings = layerBindingsByScaleName[scaleName]!!\n                val legendKeyFactory = stitchedLayers.legendKeyElementFactory\n                val aestheticsDefaults = stitchedLayers.aestheticsDefaults\n                legendAssembler.addLayer(\n                    legendKeyFactory,\n                    varBindings,\n                    layerConstantByAes,\n                    aestheticsDefaults,\n                    stitchedLayers.getScaleMap(),\n                    transformedDomainByAes\n                )\n            }\n        }\n\n        val legendBoxInfos = ArrayList<LegendBoxInfo>()\n        for (legendTitle in colorBarAssemblerByTitle.keys) {\n            val boxInfo = colorBarAssemblerByTitle[legendTitle]!!.createColorBar()\n            if (!boxInfo.isEmpty) {\n                legendBoxInfos.add(boxInfo)\n            }\n        }\n\n        for (legendTitle in legendAssemblerByTitle.keys) {\n            val boxInfo = legendAssemblerByTitle[legendTitle]!!.createLegend()\n            if (!boxInfo.isEmpty) {\n                legendBoxInfos.add(boxInfo)\n            }\n        }\n        return legendBoxInfos\n    }\n\n    fun createPlotLayout(tileLayout: TileLayout, facets: PlotFacets): PlotLayout {\n        if (!facets.isDefined) {\n            return SingleTilePlotLayout(tileLayout)\n        }\n\n        return FacetGridPlotLayout(\n            facets,\n            tileLayout\n        )\n    }\n\n\n    fun computePlotDryRunXYRanges(layersByTile: List<List<GeomLayer>>): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n        // 'dry run' aesthetics use 'identity' mappers for positional aes (because the plot size is not yet determined)\n        val dryRunAestheticsByTileLayer = HashMap<GeomLayer, Aesthetics>()\n        for (tileLayers in layersByTile) {\n            for (layer in tileLayers) {\n                val aesthetics = PlotUtil.createLayerDryRunAesthetics(layer)\n                dryRunAestheticsByTileLayer[layer] = aesthetics\n            }\n        }\n\n        // the \"scale map\" is shared by all layers.\n        val layers0 = layersByTile[0]\n        val scaleMap = layers0[0].scaleMap\n        val xScale = scaleMap[Aes.X]\n        val yScale = scaleMap[Aes.Y]\n        var xInitialRange: ClosedRange<Double>? = RangeUtil.initialRange(xScale)\n        var yInitialRange: ClosedRange<Double>? = RangeUtil.initialRange(yScale)\n\n        var xRangeOverall: ClosedRange<Double>? = null\n        var yRangeOverall: ClosedRange<Double>? = null\n        for (tileLayers in layersByTile) {\n            for (layer in tileLayers) {\n                // use dry-run aesthetics to estimate ranges\n                val aesthetics = dryRunAestheticsByTileLayer.getValue(layer)\n                // adjust X/Y range with 'pos adjustment' and 'expands'\n                val xyRanges = computeLayerDryRunXYRanges(layer, aesthetics)\n\n                val xRangeLayer = updateRange(xInitialRange, xyRanges.first)\n                val yRangeLayer = updateRange(yInitialRange, xyRanges.second)\n\n                xRangeOverall = updateRange(xRangeLayer, xRangeOverall)\n                yRangeOverall = updateRange(yRangeLayer, yRangeOverall)\n            }\n        }\n\n        // 'expand' ranges and include '0' if necessary\n        xRangeOverall = RangeUtil.expandRange(xRangeOverall, Aes.X, xScale, layers0)\n        yRangeOverall = RangeUtil.expandRange(yRangeOverall, Aes.Y, yScale, layers0)\n\n        // validate XY ranges\n        xRangeOverall = SeriesUtil.ensureApplicableRange(xRangeOverall)\n        yRangeOverall = SeriesUtil.ensureApplicableRange(yRangeOverall)\n        return Pair(\n            xRangeOverall,\n            yRangeOverall\n        )\n    }\n\n    private object RangeUtil {\n        fun initialRange(scale: Scale<Double>): ClosedRange<Double>? {\n            var initialRange: ClosedRange<Double>? = null\n\n            // Take in account:\n            // - scales domain if defined\n            // - scales breaks if defined\n            if (scale.isContinuousDomain) {\n                initialRange = updateRange(\n                    ScaleUtil.transformedDefinedLimits(scale).toList().filter { it.isFinite() },\n                    initialRange\n                )\n            }\n\n            if (scale.hasBreaks()) {\n                val scaleBreaks = scale.getScaleBreaks()\n                initialRange = updateRange(\n//                    ScaleUtil.breaksTransformed(scale),\n                    scaleBreaks.transformedValues,\n                    initialRange\n                )\n            }\n            return initialRange\n        }\n\n        fun expandRange(\n            range: ClosedRange<Double>?,\n            aes: Aes<Double>,\n            scale: Scale<*>,\n            layers: List<GeomLayer>\n        ): ClosedRange<Double>? {\n            val includeZero = layers.any { it.rangeIncludesZero(aes) }\n\n            @Suppress(\"NAME_SHADOWING\")\n            val range = when (includeZero) {\n                true -> updateRange(ClosedRange.singleton(0.0), range)\n                false -> range\n            }\n\n            return PlotUtil.rangeWithExpand(range, scale, includeZero)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.builder.assemble.facet.FacetGrid\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\nabstract class PlotFacets {\n\n    abstract val isDefined: Boolean\n    abstract val colCount: Int\n    abstract val rowCount: Int\n    abstract val numTiles: Int\n    abstract val variables: List<String>\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    abstract fun dataByTile(data: DataFrame): List<DataFrame>\n\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    abstract fun tileInfos(): List<FacetTileInfo>\n\n\n    companion object {\n        const val DEF_ORDER_DIR = 1\n        val DEF_FORMATTER: (Any) -> String = { it.toString() }\n\n        fun undefined(): PlotFacets {\n            return FacetGrid(null, null, emptyList<Any>(), emptyList<Any>(), 1, 1)\n        }\n\n        fun dataByLevelTuple(\n            data: DataFrame,\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<Pair<List<Any>, DataFrame>> {\n            // This also checks invariants.\n            val nameLevelTuples = createNameLevelTuples(varNames, varLevels)\n\n            val indicesByVarByLevel = dataIndicesByVarByLevel(data, varNames, varLevels)\n\n            val dataByLevelKey = ArrayList<Pair<List<Any>, DataFrame>>()\n            for (nameLevelTuple in nameLevelTuples) {\n                val topName = nameLevelTuple.first().first\n                val topLevel = nameLevelTuple.first().second\n                val indices = ArrayList(indicesByVarByLevel.getValue(topName).getValue(topLevel))\n                for (i in 1 until nameLevelTuple.size) {\n                    val name = nameLevelTuple[i].first\n                    val level = nameLevelTuple[i].second\n                    val levelIndices = indicesByVarByLevel.getValue(name).getValue(level)\n                    indices.retainAll(HashSet(levelIndices))\n                }\n\n                val levelKey = nameLevelTuple.map { it.second }\n\n                // build the data subset\n                val b = DataFrame.Builder()\n                val variables = data.variables()\n                for (variable in variables) {\n                    val source = data[variable]\n                    val target = SeriesUtil.pickAtIndices(source, indices)\n                    b.put(variable, target)\n                }\n\n                val levelData = b.build()\n                dataByLevelKey.add(levelKey to levelData)\n            }\n\n            return dataByLevelKey\n        }\n\n        private fun dataIndicesByVarByLevel(\n            data: DataFrame,\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): Map<String, Map<Any, List<Int>>> {\n\n            val indicesByVarByLevel = HashMap<String, Map<Any, List<Int>>>()\n            for ((i, varName) in varNames.withIndex()) {\n                val levels = varLevels[i]\n\n                val indicesByLevel = HashMap<Any, List<Int>>()\n                for (level in levels) {\n                    val indices = when {\n                        // 'empty' data in layers with no aes mapping (only constants)\n                        data.isEmpty -> emptyList()\n                        else -> {\n                            val variable = DataFrameUtil.findVariableOrFail(data, varName)\n                            SeriesUtil.matchingIndices(data[variable], level)\n                        }\n                    }\n                    indicesByLevel[level] = indices\n                }\n\n                indicesByVarByLevel[varName] = indicesByLevel\n            }\n\n            return indicesByVarByLevel\n        }\n\n        fun createNameLevelTuples(\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<List<Pair<String, Any>>> {\n            require(varNames.isNotEmpty()) { \"Empty list of facet variables.\" }\n            require(varNames.size == varNames.distinct().size) { \"Facet variables must be distinct, were: $varNames.\" }\n            check(varNames.size == varLevels.size)\n            return createNameLevelTuplesIntern(varNames, varLevels)\n        }\n\n        private fun createNameLevelTuplesIntern(\n            varNames: List<String>,\n            varLevels: List<List<Any>>\n        ): List<List<Pair<String, Any>>> {\n            val name = varNames.first()\n            val levels = varLevels.first()\n\n            val levelKeys = ArrayList<List<Pair<String, Any>>>()\n            for (level in levels) {\n                if (varNames.size > 1) {\n                    val subKeys = createNameLevelTuples(\n                        varNames.subList(1, varNames.size),\n                        varLevels.subList(1, varLevels.size)\n                    )\n                    for (subKey in subKeys) {\n                        levelKeys.add(listOf(name to level) + subKey)\n                    }\n                } else {\n                    // exit\n                    levelKeys.add(listOf(name to level))\n                }\n            }\n\n            return levelKeys\n        }\n\n        fun reorderLevels(\n            varNames: List<String>,\n            varLevels: List<List<Any>>,\n            ordering: List<Int>\n        ): List<List<Any>> {\n            val orderingByFacet = varNames.zip(ordering).toMap()\n\n            val result = ArrayList<List<Any>>()\n            for ((i, name) in varNames.withIndex()) {\n                if (i >= varLevels.size) break\n                result.add(reorderVarLevels(name, varLevels[i], orderingByFacet.getValue(name)))\n            }\n\n            return result\n        }\n\n        fun reorderVarLevels(\n            name: String?,\n            levels: List<Any>,\n            order: Int\n        ): List<Any> {\n            if (name == null) return levels\n\n            // We expect either a list of Doubles or a list of Strings.\n            @Suppress(\"UNCHECKED_CAST\", \"NAME_SHADOWING\")\n            levels as List<Comparable<Any>>\n\n            return when {\n                order < 0 -> levels.sortedDescending()\n                else -> levels.sorted()\n            }\n        }\n    }\n\n    class FacetTileInfo(\n        val col: Int,\n        val row: Int,\n        val colLabs: List<String>,\n        val rowLab: String?,\n        val xAxis: Boolean,\n        val yAxis: Boolean,\n        val trueIndex: Int     // tile index before re-ordering (in facet wrap)\n    ) {\n        override fun toString(): String {\n            return \"FacetTileInfo(col=$col, row=$row, colLabs=$colLabs, rowLab=$rowLab)\"\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.scale.transform.Transforms.ensureApplicableDomain\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\ninternal object PlotGuidesAssemblerUtil {\n    fun mappedRenderedAesToCreateGuides(\n        layerTiles: StitchedPlotLayers,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>\n    ): List<Aes<*>> {\n        if (layerTiles.isLegendDisabled) {\n            // ToDo: add support for\n            // show_legend = True     : show all aesthetics in legend\n            // show_legend = [.. list of aesthetics to show ..]     : show selected aesthetics in legend\n            // see: https://ggplot2.tidyverse.org/reference/geom_point.html\n            return emptyList()\n        }\n\n        val result = ArrayList<Aes<*>>()\n        for (aes in layerTiles.renderedAes()) {\n            if (Aes.noGuideNeeded(aes)) {\n                continue\n            }\n            if (layerTiles.hasConstant(aes)) {\n                // constants mask aes mappings\n                continue\n            }\n            if (!layerTiles.hasBinding(aes)) {\n                continue\n            }\n            if (guideOptionsMap.containsKey(aes)) {\n                if (guideOptionsMap[aes] === GuideOptions.NONE) {\n                    continue\n                }\n            }\n\n            result.add(aes)\n        }\n\n        return result\n    }\n\n    fun guideTransformedDomainByAes(\n        stitchedLayers: StitchedPlotLayers,\n        guideOptionsMap: Map<Aes<*>, GuideOptions>\n    ): Map<Aes<*>, ClosedRange<Double>> {\n        val transformedDomainByAes = HashMap<Aes<*>, ClosedRange<Double>>()\n        val aesSet = mappedRenderedAesToCreateGuides(\n            stitchedLayers,\n            guideOptionsMap\n        )\n\n        for (aes in aesSet) {\n            // Should be only 'tarnsform' variables in bindings at this point.\n            val transformVariable = stitchedLayers.getBinding(aes).variable\n            check(transformVariable.isTransform)\n\n            val transformedDataRange = stitchedLayers.getDataRange(transformVariable)\n            val scale = stitchedLayers.getScale(aes)\n            if (scale.isContinuousDomain) {\n                transformedDomainByAes[aes] = refineTransformedDataRangeForContinuousDomain(transformedDataRange, scale)\n            } else if (transformedDataRange != null) {\n                transformedDomainByAes[aes] = transformedDataRange\n            }\n\n\n//            if (transformedDataRange != null) {\n//\n//                val transformedDomain =\n//                    if (scale.isContinuousDomain && scale.hasDomainLimits()) {\n//                        val (scaleLower, scaleUpper) = ScaleUtil.transformedDefinedLimits(scale)\n//                        val lowerEnd = if (scaleLower.isFinite()) scaleLower else transformedDataRange.lowerEnd\n//                        val upperEnd = if (scaleUpper.isFinite()) scaleUpper else transformedDataRange.upperEnd\n//                        ClosedRange<Double>(lowerEnd, upperEnd)\n//                    } else {\n//                        transformedDataRange\n//                    }\n//\n//\n//                transformedDomainByAes[aes] = transformedDomain\n//            }\n        }\n\n        return transformedDomainByAes\n    }\n\n    private fun refineTransformedDataRangeForContinuousDomain(\n        transformedDataRange: ClosedRange<Double>?,\n        scale: Scale<*>\n    ): ClosedRange<Double> {\n        val (dataLower, dataUpper) = when (transformedDataRange) {\n            null -> Pair(Double.NaN, Double.NaN)\n            else -> Pair(transformedDataRange.lowerEnd, transformedDataRange.upperEnd)\n        }\n        val (scaleLower, scaleUpper) = when (scale.hasDomainLimits()) {\n            true -> ScaleUtil.transformedDefinedLimits(scale)\n            else -> Pair(Double.NaN, Double.NaN)\n        }\n\n        val lowerEnd = if (scaleLower.isFinite()) scaleLower else dataLower\n        val upperEnd = if (scaleUpper.isFinite()) scaleUpper else dataUpper\n\n        val newRange = when {\n            lowerEnd.isFinite() && upperEnd.isFinite() -> ClosedRange(lowerEnd, upperEnd)\n            lowerEnd.isFinite() -> ClosedRange(lowerEnd, lowerEnd)\n            upperEnd.isFinite() -> ClosedRange(upperEnd, upperEnd)\n            else -> null\n        }\n\n        return ensureApplicableDomain(newRange, scale.transform as ContinuousTransform)\n    }\n\n    fun createColorBarAssembler(\n        scaleName: String,\n        aes: Aes<*>,\n        transformedDomainByAes: Map<Aes<*>, ClosedRange<Double>>,\n        scale: Scale<Color>,\n        options: ColorBarOptions?,\n        theme: LegendTheme\n    ): ColorBarAssembler {\n\n        val transformedDomain = transformedDomainByAes[aes]\n        checkNotNull(transformedDomain) { \"Domain for continuous data must not be null\" }\n\n//        // ToDo: this duplicates implementation code in MapperProvider.createContinuousMapper()\n//        val trans = scale.transform as ContinuousTransform\n//        val domainWithLims = MapperUtil.rangeWithLimitsAfterTransform(\n//            ensureApplicableDomain(transformedDomain, trans),\n//            scale.domainLimits.first,\n//            scale.domainLimits.second,\n//            trans\n//        )\n\n        val result = ColorBarAssembler(\n            scaleName,\n//            ensureApplicableRange(domainWithLims),\n            transformedDomain,\n            scale,\n            theme\n        )\n        result.setOptions(options)\n        return result\n    }\n\n    fun fitsColorBar(aes: Aes<*>, scale: Scale<*>): Boolean {\n        return aes.isColor && scale.isContinuous\n    }\n\n    fun checkFitsColorBar(aes: Aes<*>, scale: Scale<*>) {\n        check(aes.isColor) { \"Color-bar is not applicable to $aes aesthetic\" }\n        check(scale.isContinuous) { \"Color-bar is only applicable when both domain and color palette are continuous\" }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.PositionAdjustment\nimport jetbrains.datalore.plot.base.pos.PositionAdjustments\nimport jetbrains.datalore.plot.builder.PosProviderContext\nimport kotlin.jvm.JvmOverloads\n\nabstract class PosProvider {\n\n    abstract fun createPos(ctx: PosProviderContext): PositionAdjustment\n\n    abstract fun handlesGroups(): Boolean\n\n    companion object {\n\n        fun wrap(pos: PositionAdjustment): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return pos\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return pos.handlesGroups()\n                }\n            }\n        }\n\n        fun barStack(): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.stack(ctx.aesthetics, PositionAdjustments.StackingStrategy.SPLIT_POSITIVE_NEGATIVE)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.STACK.handlesGroups()\n                }\n            }\n        }\n\n        @JvmOverloads\n        fun dodge(width: Double? = null): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    val aesthetics = ctx.aesthetics\n                    val groupCount = ctx.groupCount\n                    return PositionAdjustments.dodge(aesthetics, groupCount, width)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.DODGE.handlesGroups()\n                }\n            }\n        }\n\n        fun fill(): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.fill(ctx.aesthetics)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.FILL.handlesGroups()\n                }\n            }\n        }\n\n        fun jitter(width: Double?, height: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.jitter(width, height)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.JITTER.handlesGroups()\n                }\n            }\n        }\n\n        fun nudge(width: Double?, height: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    return PositionAdjustments.nudge(width, height)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.NUDGE.handlesGroups()\n                }\n            }\n        }\n\n        /*\n  public static PosProvider jitterDodge(Double jitterWidth, Double jitterHeight) {\n    return jitterDodge(null, jitterWidth, jitterHeight);\n  }\n  */\n\n        fun jitterDodge(width: Double?, jitterWidth: Double?, jitterHeight: Double?): PosProvider {\n            return object : PosProvider() {\n                override fun createPos(ctx: PosProviderContext): PositionAdjustment {\n                    val aesthetics = ctx.aesthetics\n                    val groupCount = ctx.groupCount\n                    return PositionAdjustments.jitterDodge(aesthetics, groupCount, width, jitterWidth, jitterHeight)\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return PositionAdjustments.Meta.JITTER_DODGE.handlesGroups()\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class StitchedPlotLayers(layers: List<jetbrains.datalore.plot.builder.GeomLayer>) {\n    private val myLayers: List<jetbrains.datalore.plot.builder.GeomLayer>\n\n    val legendKeyElementFactory: LegendKeyElementFactory\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].legendKeyElementFactory\n        }\n\n    val aestheticsDefaults: AestheticsDefaults\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].aestheticsDefaults\n        }\n\n    val isLegendDisabled: Boolean\n        get() {\n            check(myLayers.isNotEmpty())\n            return myLayers[0].isLegendDisabled\n        }\n\n    init {\n        myLayers = ArrayList(layers)\n    }\n\n    fun renderedAes(): List<Aes<*>> {\n        return if (myLayers.isEmpty()) {\n            emptyList()\n        } else myLayers[0].renderedAes()\n    }\n\n    fun hasBinding(aes: Aes<*>): Boolean {\n        return myLayers.isNotEmpty() && myLayers[0].hasBinding(aes)\n    }\n\n    fun hasConstant(aes: Aes<*>): Boolean {\n        return myLayers.isNotEmpty() && myLayers[0].hasConstant(aes)\n    }\n\n    fun <T> getConstant(aes: Aes<T>): T {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].getConstant(aes)\n    }\n\n    fun getBinding(aes: Aes<*>): VarBinding {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].getBinding(aes)\n    }\n\n    fun getScale(aes: Aes<*>): Scale<*> {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].scaleMap[aes]\n    }\n\n    fun getScaleMap(): TypedScaleMap {\n        check(myLayers.isNotEmpty())\n        return myLayers[0].scaleMap\n    }\n\n    fun getDataRange(variable: DataFrame.Variable): ClosedRange<Double>? {\n        check(isNumericData(variable)) { \"Not numeric data [$variable]\" }\n        var result: ClosedRange<Double>? = null\n        for (layer in myLayers) {\n            val range = layer.dataFrame.range(variable)\n            result = SeriesUtil.span(result, range)\n        }\n        return result\n    }\n\n    private fun isNumericData(variable: DataFrame.Variable): Boolean {\n        check(myLayers.isNotEmpty())\n        for (layer in myLayers) {\n            if (!layer.dataFrame.isNumeric(variable)) {\n                return false\n            }\n        }\n        return true\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.base.logging.PortableLogging\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Scale\n\nclass TypedScaleMap constructor(map: Map<Aes<*>, Scale<*>>) {\n    private var myMap: Map<Aes<*>, Scale<*>> = map.toMap()\n\n    operator fun <T> get(aes: Aes<T>): Scale<T> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return (myMap[aes] as? Scale<T>) ?: run {\n            val message = \"No scale found for aes: $aes\"\n            LOG.error(IllegalStateException(message)) { message }\n            error(message)\n        }\n    }\n\n    fun containsKey(aes: Aes<*>): Boolean {\n        return myMap.containsKey(aes)\n    }\n\n    fun keySet(): Set<Aes<*>> {\n        return myMap.keys\n    }\n\n    companion object {\n        private val LOG = PortableLogging.logger(TypedScaleMap::class)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.builder.scale.ScaleProvider\n\nclass TypedScaleProviderMap constructor(map: Map<Aes<*>, ScaleProvider<*>>) {\n    private var myMap: Map<Aes<*>, ScaleProvider<*>> = map.toMap()\n\n    operator fun <T> get(aes: Aes<T>): ScaleProvider<T> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return myMap[aes] as ScaleProvider<T>\n    }\n\n    fun containsKey(aes: Aes<*>): Boolean {\n        return myMap.containsKey(aes)\n    }\n\n    fun keySet(): Set<Aes<*>> {\n        return myMap.keys\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.facet\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.max\n\nclass FacetGrid(\n    private val xVar: String?,\n    private val yVar: String?,\n    xLevels: List<Any>,\n    yLevels: List<Any>,\n    xOrder: Int,\n    yOrder: Int,\n    private val xFormatter: (Any) -> String = DEF_FORMATTER,\n    private val yFormatter: (Any) -> String = DEF_FORMATTER,\n) : PlotFacets() {\n\n    override val isDefined: Boolean = xVar != null || yVar != null\n    private val xLevels: List<Any> = reorderVarLevels(xVar, xLevels, xOrder)\n    private val yLevels: List<Any> = reorderVarLevels(yVar, yLevels, yOrder)\n    override val colCount: Int = max(1, xLevels.size)\n    override val rowCount: Int = max(1, yLevels.size)\n    override val numTiles = colCount * rowCount\n    override val variables: List<String>\n        get() = listOfNotNull(xVar, yVar)\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun dataByTile(data: DataFrame): List<DataFrame> {\n        require(isDefined) { \"dataByTile() called on Undefined plot facets.\" }\n\n        val dataByLevelTupleList = dataByLevelTuple(\n            data,\n            listOfNotNull(\n                xVar,\n                yVar,\n            ),\n            listOfNotNull(\n                xVar?.let { xLevels },\n                yVar?.let { yLevels },\n            )\n        )\n        val dataByLevelTuple = dataByLevelTupleList.toMap()\n\n        val colLevels = xLevels.ifEmpty { listOf(null) }\n        val rowLevels = yLevels.ifEmpty { listOf(null) }\n\n        val dataByTile: MutableList<DataFrame> = ArrayList()\n        // Enumerate tiles by-row.\n        for (rowLevel in rowLevels) {\n            for (colLevel in colLevels) {\n                val levelTuple = listOfNotNull(colLevel, rowLevel)\n                val tileData = dataByLevelTuple.getValue(levelTuple)\n                dataByTile.add(tileData)\n            }\n        }\n\n        return dataByTile\n    }\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun tileInfos(): List<FacetTileInfo> {\n        val colLabels = (xLevels.ifEmpty { listOf(null) }).map {\n            it?.let { xFormatter(it) }\n        }\n        val rowLabels = (yLevels.ifEmpty { listOf(null) }).map {\n            it?.let { yFormatter(it) }\n        }\n\n        val infos = ArrayList<FacetTileInfo>()\n        for (row in 0 until rowCount) {\n            val addColLab = row == 0\n            val hasXAxis = row == rowCount - 1\n            for (col in 0 until colCount) {\n                val addRowLab = col == colCount - 1\n                val hasYAxis = col == 0\n\n                val colLabs = if (addColLab) {\n                    colLabels[col]?.let { listOf(it) } ?: emptyList()\n                } else {\n                    emptyList<String>()\n                }\n\n                infos.add(\n                    FacetTileInfo(\n                        col, row,\n                        colLabs,\n                        if (addRowLab) rowLabels[row] else null,\n                        hasXAxis, hasYAxis,\n                        trueIndex = infos.size\n                    )\n                )\n            }\n        }\n\n        return infos\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.facet\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.ceil\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass FacetWrap(\n    private val facets: List<String>,\n    levels: List<List<Any>>,\n    private val nrow: Int?,\n    private val ncol: Int?,\n    private val direction: Direction,\n    facetOrdering: List<Int>,\n    private val facetFormatters: List<(Any) -> String>,\n) : PlotFacets() {\n\n    override val isDefined: Boolean = true\n    private val levels: List<List<Any>> = reorderLevels(facets, levels, facetOrdering)\n    override val numTiles = numTiles(facets, levels)\n    private val shape = shape(numTiles, ncol, nrow, direction)\n    override val colCount: Int = shape.first\n    override val rowCount: Int = shape.second\n    override val variables: List<String> = facets\n\n    /**\n     * @return List of Dataframes, one Dataframe per tile.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun dataByTile(data: DataFrame): List<DataFrame> {\n        val dataByLevelTuple = dataByLevelTuple(\n            data,\n            variables,\n            levels\n        )\n\n        val dataByTile: MutableList<DataFrame> = ArrayList()\n        for ((_, tileData) in dataByLevelTuple) {\n            dataByTile.add(tileData)\n        }\n        return dataByTile\n    }\n\n    /**\n     * @return List of FacetTileInfo.\n     *          Tiles are enumerated by rows, i.e.:\n     *          the index is computed like: row * nCols + col\n     */\n    override fun tileInfos(): List<FacetTileInfo> {\n\n        val levelTuples = createNameLevelTuples(facets, levels)\n        val tileLabels = levelTuples\n            .map { it.map { pair -> pair.second } }                    // get rid of 'pair'\n            .map { it.mapIndexed { i, level -> facetFormatters[i](level) } }                // to string tuples\n\n        fun toCol(index: Int): Int {\n            return when (direction) {\n                Direction.H -> index % colCount\n                Direction.V -> index / rowCount\n            }\n        }\n\n        fun toRow(index: Int): Int {\n            return when (direction) {\n                Direction.H -> index / colCount\n                Direction.V -> index % rowCount\n            }\n        }\n\n        fun toIndex(col: Int, row: Int): Int {\n            return when (direction) {\n                Direction.H -> row * colCount + col\n                Direction.V -> col * rowCount + row\n            }\n        }\n\n        fun isBottom(col: Int, row: Int): Boolean {\n            val nextRowIndex = toIndex(col, row + 1)\n            return (row + 1) % rowCount == 0 || nextRowIndex >= numTiles\n        }\n\n        val infos = ArrayList<FacetTileInfo>()\n        for ((i, tileLabelTuple) in tileLabels.withIndex()) {\n            val col = toCol(i)\n            val row = toRow(i)\n//            val nextRowIndex = toIndex(col, row + 1)\n//            val hasXAxis = nextRowIndex >= numTiles\n            val hasXAxis = isBottom(col, row)\n            val hasYAxis = col == 0\n\n            infos.add(\n                FacetTileInfo(\n                    col, row,\n                    colLabs = tileLabelTuple,\n                    null,\n                    hasXAxis, hasYAxis,\n                    trueIndex = i\n                )\n            )\n        }\n\n        // Enumeration is always 'by row'.\n        return infos.sortedWith(compareBy<FacetTileInfo> { it.row }.thenBy { it.col })\n    }\n\n    enum class Direction {\n        H, V\n    }\n\n    companion object {\n        private fun numTiles(\n            facets: List<String>,\n            levels: List<List<Any>>,\n        ): Int {\n            require(facets.isNotEmpty()) { \"List of facets is empty.\" }\n            require(facets.distinct().size == facets.size) { \"Duplicated values in the facets list: $facets\" }\n            check(facets.size == levels.size)\n            return createNameLevelTuples(facets, levels).size\n        }\n\n        private fun shape(tilesCount: Int, ncol: Int?, nrow: Int?, dir: Direction): Pair<Int, Int> {\n            require(ncol?.let { ncol > 0 } ?: true) { \"'ncol' must be positive, was $ncol\" }\n            require(nrow?.let { nrow > 0 } ?: true) { \"'nrow' must be positive, was $nrow\" }\n            val shape = when {\n                ncol != null -> {\n                    val ncolActual = min(ncol, tilesCount)\n                    val nrowActual = ceil(tilesCount.toDouble() / ncolActual).toInt()\n                    ncolActual to max(1, nrowActual)\n                }\n                nrow != null -> {\n                    val nrowActual = min(nrow, tilesCount)\n                    val ncolActual = ceil(tilesCount.toDouble() / nrowActual).toInt()\n                    ncolActual to max(1, nrowActual)\n                }\n                else -> {\n                    val w = min(4, max(1, tilesCount / 2))\n                    val h = max(1, ceil(tilesCount.toDouble() / w).toInt())\n                    w to h\n                }\n            }\n\n            val (w, h) = shape\n            return when (dir) {\n                Direction.H -> {\n                    // filling by rows\n                    Pair(\n                        w,\n                        ceil(tilesCount.toDouble() / w).toInt()\n                    )\n                }\n                Direction.V -> {\n                    // filling by cols\n                    Pair(\n                        ceil(tilesCount.toDouble() / h).toInt(),\n                        h\n                    )\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Geom\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.GeomMeta\nimport jetbrains.datalore.plot.base.aes.AestheticsDefaults\nimport jetbrains.datalore.plot.base.geom.*\nimport jetbrains.datalore.plot.base.livemap.LiveMapOptions\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\n\nabstract class GeomProvider private constructor(val geomKind: GeomKind) {\n\n    open val preferredCoordinateSystem: CoordProvider\n        get() = throw IllegalStateException(\"No preferred coordinate system\")\n\n    fun renders(): List<Aes<*>> {\n        return GeomMeta.renders(geomKind)\n    }\n\n    abstract fun createGeom(): Geom\n\n    abstract fun aestheticsDefaults(): AestheticsDefaults\n\n    abstract fun handlesGroups(): Boolean\n\n    private class GeomProviderBuilder internal constructor(\n        private val myKind: GeomKind,\n        private val myAestheticsDefaults: AestheticsDefaults,\n        private val myHandlesGroups: Boolean,\n        private val myGeomSupplier: () -> Geom\n    ) {\n        internal fun build(): GeomProvider {\n            return object : GeomProvider(myKind) {\n\n                override fun createGeom(): Geom {\n                    return myGeomSupplier()\n                }\n\n                override fun aestheticsDefaults(): AestheticsDefaults {\n                    return myAestheticsDefaults\n                }\n\n                override fun handlesGroups(): Boolean {\n                    return myHandlesGroups\n                }\n            }\n        }\n    }\n\n    companion object {\n\n        fun point(): GeomProvider {\n            return point { PointGeom() }\n        }\n\n        fun point(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POINT,\n                AestheticsDefaults.point(),\n                PointGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun path(): GeomProvider {\n            return path { PathGeom() }\n        }\n\n        fun path(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.PATH,\n                AestheticsDefaults.path(),\n                PathGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun line(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LINE,\n                AestheticsDefaults.line(),\n                LineGeom.HANDLES_GROUPS\n            ) { LineGeom() }.build()\n        }\n\n        fun smooth(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.SMOOTH,\n                AestheticsDefaults.smooth(),\n                SmoothGeom.HANDLES_GROUPS\n            ) { SmoothGeom() }.build()\n        }\n\n        fun bar(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BAR,\n                AestheticsDefaults.bar(),\n                BarGeom.HANDLES_GROUPS\n            ) { BarGeom() }.build()\n        }\n\n        fun histogram(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.HISTOGRAM,\n                AestheticsDefaults.histogram(),\n                HistogramGeom.HANDLES_GROUPS\n            ) { HistogramGeom() }.build()\n        }\n\n        fun tile(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.TILE,\n                AestheticsDefaults.tile(),\n                TileGeom.HANDLES_GROUPS\n            ) { TileGeom() }.build()\n        }\n\n        fun bin2d(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BIN_2D,\n                AestheticsDefaults.bin2d(),\n                Bin2dGeom.HANDLES_GROUPS\n            ) { Bin2dGeom() }.build()\n        }\n\n        fun errorBar(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.ERROR_BAR,\n                AestheticsDefaults.errorBar(),\n                ErrorBarGeom.HANDLES_GROUPS\n            ) { ErrorBarGeom() }.build()\n        }\n\n        fun crossBar(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CROSS_BAR,\n                AestheticsDefaults.crossBar(),\n                CrossBarGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun lineRange(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LINE_RANGE,\n                AestheticsDefaults.lineRange(),\n                LineRangeGeom.HANDLES_GROUPS\n            ) { LineRangeGeom() }.build()\n        }\n\n        fun pointRange(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POINT_RANGE,\n                AestheticsDefaults.pointRange(),\n                PointRangeGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun contour(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CONTOUR,\n                AestheticsDefaults.contour(),\n                ContourGeom.HANDLES_GROUPS\n            ) { ContourGeom() }.build()\n        }\n\n        fun contourf(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.CONTOURF,\n                AestheticsDefaults.contourf(),\n                ContourfGeom.HANDLES_GROUPS\n            ) { ContourfGeom() }.build()\n        }\n\n        fun polygon(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.POLYGON,\n                AestheticsDefaults.polygon(),\n                PolygonGeom.HANDLES_GROUPS\n            ) { PolygonGeom() }.build()\n        }\n\n        fun map(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.MAP,\n                AestheticsDefaults.map(),\n                MapGeom.HANDLES_GROUPS\n            ) { MapGeom() }.build()\n        }\n\n        fun abline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.AB_LINE,\n                AestheticsDefaults.abline(),\n                ABLineGeom.HANDLES_GROUPS\n            ) { ABLineGeom() }.build()\n        }\n\n        fun hline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.H_LINE,\n                AestheticsDefaults.hline(),\n                HLineGeom.HANDLES_GROUPS\n            ) { HLineGeom() }.build()\n        }\n\n        fun vline(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.V_LINE,\n                AestheticsDefaults.vline(),\n                VLineGeom.HANDLES_GROUPS\n            ) { VLineGeom() }.build()\n        }\n\n        fun boxplot(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.BOX_PLOT,\n                AestheticsDefaults.boxplot(),\n                BoxplotGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun livemap(\n            options: LiveMapOptions\n        ): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.LIVE_MAP,\n                AestheticsDefaults.livemap(options.displayMode),\n                LiveMapGeom.HANDLES_GROUPS,\n                myGeomSupplier = { LiveMapGeom(options.displayMode) }\n            ).build()\n        }\n\n        fun ribbon(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RIBBON,\n                AestheticsDefaults.ribbon(),\n                RibbonGeom.HANDLES_GROUPS\n            ) { RibbonGeom() }.build()\n        }\n\n        fun area(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.AREA,\n                AestheticsDefaults.area(),\n                AreaGeom.HANDLES_GROUPS\n            ) { AreaGeom() }.build()\n        }\n\n        fun density(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY,\n                AestheticsDefaults.density(),\n                DensityGeom.HANDLES_GROUPS\n            ) { DensityGeom() }.build()\n        }\n\n        fun density2d(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY2D,\n                AestheticsDefaults.density2d(),\n                Density2dGeom.HANDLES_GROUPS\n            ) { Density2dGeom() }.build()\n        }\n\n        fun density2df(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.DENSITY2DF,\n                AestheticsDefaults.density2df(),\n                Density2dfGeom.HANDLES_GROUPS\n            ) { Density2dfGeom() }.build()\n        }\n\n        fun jitter(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.JITTER,\n                AestheticsDefaults.jitter(),\n                JitterGeom.HANDLES_GROUPS\n            ) { JitterGeom() }.build()\n        }\n\n        fun freqpoly(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.FREQPOLY,\n                AestheticsDefaults.freqpoly(),\n                FreqpolyGeom.HANDLES_GROUPS\n            ) { FreqpolyGeom() }.build()\n        }\n\n        fun step(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.STEP,\n                AestheticsDefaults.step(),\n                StepGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun rect(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RECT,\n                AestheticsDefaults.rect(),\n                RectGeom.HANDLES_GROUPS\n            ) { RectGeom() }.build()\n        }\n\n        fun segment(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.SEGMENT,\n                AestheticsDefaults.segment(),\n                SegmentGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun text(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.TEXT,\n                AestheticsDefaults.text(),\n                TextGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n\n        fun raster(): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.RASTER,\n                AestheticsDefaults.raster(),\n                RasterGeom.HANDLES_GROUPS\n            ) { RasterGeom() }.build()\n        }\n\n        fun image(supplier: () -> Geom): GeomProvider {\n            return GeomProviderBuilder(\n                GeomKind.IMAGE,\n                AestheticsDefaults.image(),\n                ImageGeom.HANDLES_GROUPS,\n                supplier\n            ).build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.assemble.geom\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.scale.ScaleUtil.labelByBreak\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.TypedScaleMap\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\n\ninternal class PointDataAccess(\n    private val data: DataFrame,\n    bindings: Map<Aes<*>, VarBinding>,\n    scaleMap: TypedScaleMap\n) : MappedDataAccess {\n\n    override val mappedAes: Set<Aes<*>> = HashSet(bindings.keys)\n    override val scaleByAes: (Aes<*>) -> Scale<*> = { scaleMap[it] }\n    private val myBindings: Map<Aes<*>, VarBinding> = bindings.toMap()\n    private val myFormatters = HashMap<Aes<*>, (Any?) -> String>()\n\n    override fun isMapped(aes: Aes<*>) = myBindings.containsKey(aes)\n\n    override fun <T> getMappedData(aes: Aes<T>, index: Int): MappedDataAccess.MappedData<T> {\n        val originalValue = getOriginalValue(aes, index)\n        val scale = getScale(aes)\n        val value = formatter(aes).invoke(originalValue)\n        return MappedDataAccess.MappedData(\n            label = scale.name,\n            value = value,\n            isContinuous = scale.isContinuous\n        )\n    }\n\n    override fun <T> getOriginalValue(aes: Aes<T>, index: Int): Any? {\n        require(isMapped(aes)) { \"Not mapped: $aes\" }\n\n        val binding = myBindings.getValue(aes)\n        val scale = getScale(aes)\n\n        return binding.variable\n            .let { variable -> data.getNumeric(variable)[index] }\n            .let { value -> scale.transform.applyInverse(value) }\n    }\n\n    override fun getMappedDataLabel(aes: Aes<*>): String = getScale(aes).name\n\n    override fun isMappedDataContinuous(aes: Aes<*>): Boolean = getScale(aes).isContinuous\n\n    private fun getScale(aes: Aes<*>): Scale<*> {\n        return scaleByAes(aes)\n    }\n\n    private fun <T> formatter(aes: Aes<T>): (Any?) -> String {\n        val scale = getScale(aes)\n        return myFormatters.getOrPut(aes, defaultValue = { createFormatter(aes, scale) })\n    }\n\n    private fun createFormatter(aes: Aes<*>, scale: Scale<*>): (Any?) -> String {\n        if (scale.isContinuousDomain) {\n            // only 'stat' or 'transform' vars here\n            val domain = myBindings\n                .getValue(aes)\n                .variable\n                .run(data::range)\n                .run(::ensureApplicableRange)\n\n            val formatter = scale.getBreaksGenerator().labelFormatter(domain, 100)\n            return { value -> value?.let { formatter.invoke(it) } ?: \"n/a\" }\n        } else {\n            val labelsMap = labelByBreak(scale)\n            return { value -> value?.let { labelsMap.getValue(it) } ?: \"n/a\" }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\n\ninternal class CartesianCoordProvider(\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim)","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\ninternal abstract class CoordProviderBase(\n    private val xLim: ClosedRange<Double>?,\n    private val yLim: ClosedRange<Double>?\n) : CoordProvider {\n\n    override fun buildAxisScaleX(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: ScaleBreaks\n    ): Scale<Double> {\n        return buildAxisScaleDefault(\n            scaleProto,\n            domain,\n            axisLength,\n            breaks\n        )\n    }\n\n    override fun buildAxisScaleY(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: ScaleBreaks\n    ): Scale<Double> {\n        return buildAxisScaleDefault(\n            scaleProto,\n            domain,\n            axisLength,\n            breaks\n        )\n    }\n\n    override fun createCoordinateSystem(\n        xDomain: ClosedRange<Double>,\n        xAxisLength: Double,\n        yDomain: ClosedRange<Double>,\n        yAxisLength: Double\n    ): CoordinateSystem {\n        val mapperX = linearMapper(xDomain, xAxisLength)\n        val mapperY = linearMapper(yDomain, yAxisLength)\n        return Coords.create(\n            MapperUtil.map(\n                xDomain,\n                mapperX\n            ),\n            MapperUtil.map(\n                yDomain,\n                mapperY\n            ),\n            xLim?.let { MapperUtil.map(it, mapperX) },\n            yLim?.let { MapperUtil.map(it, mapperY) }\n        )\n    }\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n        return Pair(xLim ?: xDomain, yLim ?: yDomain)\n    }\n\n    companion object {\n        fun linearMapper(domain: ClosedRange<Double>, axisLength: Double): (Double?) -> Double? {\n            return Mappers.mul(domain, axisLength)\n        }\n\n        private fun buildAxisScaleDefault(\n            scaleProto: Scale<Double>,\n            domain: ClosedRange<Double>,\n            axisLength: Double,\n            breaks: ScaleBreaks\n        ): Scale<Double> {\n            return buildAxisScaleDefault(\n                scaleProto,\n                linearMapper(domain, axisLength),\n                breaks\n            )\n        }\n\n        fun buildAxisScaleDefault(\n            scaleProto: Scale<Double>,\n            axisMapper: (Double?) -> Double?,\n            breaks: ScaleBreaks\n        ): Scale<Double> {\n            return scaleProto.with()\n                .breaks(breaks.domainValues)\n                .labels(breaks.labels)\n                .mapper(axisMapper)\n                .build()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.builder.coord.map.MercatorProjectionX\nimport jetbrains.datalore.plot.builder.coord.map.MercatorProjectionY\n\nobject CoordProviders {\n    fun cartesian(xLim: ClosedRange<Double>? = null, yLim: ClosedRange<Double>? = null): CoordProvider {\n        return CartesianCoordProvider(xLim, yLim)\n    }\n\n    fun fixed(\n        ratio: Double,\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordProvider {\n        return FixedRatioCoordProvider(ratio, xLim, yLim)\n    }\n\n    fun map(\n        xLim: ClosedRange<Double>? = null,\n        yLim: ClosedRange<Double>? = null\n    ): CoordProvider {\n        // Only Mercator so far.\n        return ProjectionCoordProvider(\n            MercatorProjectionX(),\n            MercatorProjectionY(),\n            xLim,\n            yLim\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n/**\n * A fixed scale coordinate system forces a specified ratio between the physical representation of data units on the axes.\n * The ratio represents the number of units on the y-axis equivalent to one unit on the x-axis.\n * ratio = 1, ensures that one unit on the x-axis is the same length as one unit on the y-axis.\n * Ratios higher than one make units on the y axis longer than units on the x-axis, and vice versa.\n */\ninternal open class FixedRatioCoordProvider(\n    private val ratio: Double,\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim) {\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n\n        // account for limits\n        val adjusted = super.adjustDomains(xDomain, yDomain, displaySize)\n\n        @Suppress(\"NAME_SHADOWING\")\n        var xDomain = adjusted.first\n\n        @Suppress(\"NAME_SHADOWING\")\n        var yDomain = adjusted.second\n\n        val spanX = SeriesUtil.span(xDomain)\n        val spanY = SeriesUtil.span(yDomain)\n        if (spanX < SeriesUtil.TINY || spanY < SeriesUtil.TINY) {\n            return Pair(xDomain, yDomain) // don't touch\n        }\n\n        // fit the data into the display\n        var displayW = displaySize.x\n        var displayH = displaySize.y\n\n        // Distort display size to account for 'ratio'\n        // ratio == 1 -> X-units equal Y-units\n        // ratio > 1 -> Y-units are longer\n        // ratio < 1 -> X-units are longer\n        if (ratio > 1) {\n            displayW *= ratio\n        } else {\n            displayH *= 1 / ratio\n        }\n\n        val ratioX = spanX / displayW\n        val ratioY = spanY / displayH\n\n        // Take bigger ratio and apply to ortogonal domain (axis) so that\n        // ratio: (data range) / (axis length) is the same for both X and Y.\n        if (ratioX > ratioY) {\n            val spanAdjusted = displayH * ratioX\n            yDomain = SeriesUtil.expand(yDomain, spanAdjusted)\n        } else {\n            val spanAdjusted = displayW * ratioY\n            xDomain = SeriesUtil.expand(xDomain, spanAdjusted)\n        }\n\n        return Pair(xDomain, yDomain)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.coord.Projection\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\ninternal class ProjectionCoordProvider(\n    private val projectionX: Projection,\n    private val projectionY: Projection,\n    xLim: ClosedRange<Double>?,\n    yLim: ClosedRange<Double>?\n) : CoordProviderBase(xLim, yLim) {\n\n    override fun adjustDomains(\n        xDomain: ClosedRange<Double>,\n        yDomain: ClosedRange<Double>,\n        displaySize: DoubleVector\n    ): Pair<ClosedRange<Double>, ClosedRange<Double>> {\n\n        // account for limits\n        val adjusted = super.adjustDomains(xDomain, yDomain, displaySize)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val xDomain = projectionX.toValidDomain(adjusted.first)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val yDomain = projectionY.toValidDomain(adjusted.second)\n\n        // compute projected ratio\n        val spanX = SeriesUtil.span(xDomain)\n        val spanY = SeriesUtil.span(yDomain)\n        val domainSquare: Pair<ClosedRange<Double>, ClosedRange<Double>> =\n            if (spanX > spanY) {\n                val center = xDomain.lowerEnd + spanX / 2\n                val halfSpan = spanY / 2\n                Pair(\n                    ClosedRange(center - halfSpan, center + halfSpan),\n                    yDomain\n                )\n            } else {\n                val center = yDomain.lowerEnd + spanY / 2\n                val halfSpan = spanX / 2\n                Pair(\n                    xDomain,\n                    ClosedRange(center - halfSpan, center + halfSpan)\n                )\n            }\n\n        val projectedXMin = projectionX.apply(domainSquare.first.lowerEnd)\n        val projectedXMax = projectionX.apply(domainSquare.first.upperEnd)\n        val projectedYMin = projectionY.apply(domainSquare.second.lowerEnd)\n        val projectedYMax = projectionY.apply(domainSquare.second.upperEnd)\n\n        val ratio = (projectedYMax - projectedYMin) / (projectedXMax - projectedXMin)\n        val fixedCoord = FixedRatioCoordProvider(ratio, null, null)\n        return fixedCoord.adjustDomains(xDomain, yDomain, displaySize)\n    }\n\n    override fun buildAxisScaleX(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: ScaleBreaks\n    ): Scale<Double> {\n        return if (projectionX.nonlinear) {\n            buildAxisScaleWithProjection(\n                projectionX,\n                scaleProto,\n                domain,\n                axisLength,\n                breaks\n            )\n        } else {\n            super.buildAxisScaleX(scaleProto, domain, axisLength, breaks)\n        }\n    }\n\n    override fun buildAxisScaleY(\n        scaleProto: Scale<Double>,\n        domain: ClosedRange<Double>,\n        axisLength: Double,\n        breaks: ScaleBreaks\n    ): Scale<Double> {\n        return if (projectionY.nonlinear) {\n            buildAxisScaleWithProjection(\n                projectionY,\n                scaleProto,\n                domain,\n                axisLength,\n                breaks\n            )\n        } else {\n            super.buildAxisScaleY(scaleProto, domain, axisLength, breaks)\n        }\n    }\n\n    companion object {\n        private fun buildAxisScaleWithProjection(\n            projection: Projection, scaleProto: Scale<Double>,\n            domain: ClosedRange<Double>,\n            axisLength: Double,\n            breaks: ScaleBreaks\n        ): Scale<Double> {\n\n            val validDomain = projection.toValidDomain(domain)\n            val validDomainProjected = ClosedRange(\n                projection.apply(validDomain.lowerEnd),\n                projection.apply(validDomain.upperEnd)\n            )\n\n            val projectionInverse = Mappers.linear(validDomainProjected, validDomain)\n\n            val linearMapper = linearMapper(\n                domain,\n                axisLength\n            )\n            val scaleMapper = twistScaleMapper(\n                projection,\n                projectionInverse,\n                linearMapper\n            )\n            val validBreaks = validateBreaks(validDomain, breaks)\n            return buildAxisScaleDefault(\n                scaleProto,\n                scaleMapper,\n                validBreaks\n            )\n        }\n\n        private fun validateBreaks(validDomain: ClosedRange<Double>, breaks: ScaleBreaks): ScaleBreaks {\n            val validIndices = ArrayList<Int>()\n            var i = 0\n            for (v in breaks.domainValues) {\n                if (v is Double && validDomain.contains(v)) {\n                    validIndices.add(i)\n                }\n                i++\n            }\n\n            if (validIndices.size == breaks.domainValues.size) {\n                return breaks\n            }\n\n            val validDomainValues = SeriesUtil.pickAtIndices(breaks.domainValues, validIndices)\n            val validLabels = SeriesUtil.pickAtIndices(breaks.labels, validIndices)\n            val validTransformedValues = SeriesUtil.pickAtIndices(breaks.transformedValues, validIndices)\n            return ScaleBreaks(\n                validDomainValues,\n                validTransformedValues,\n                validLabels\n            )\n        }\n\n        private fun twistScaleMapper(\n            projection: Projection, projectionInverse: (Double) -> Double,\n            scaleMapper: (Double?) -> Double?\n        ): (Double?) -> Double? {\n            return { v ->\n                v?.run {\n                    val projected = projection.apply(v)\n                    val unProjected = projectionInverse(projected)\n                    scaleMapper(unProjected)\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord.map\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.MercatorUtils.getMercatorX\nimport jetbrains.datalore.plot.base.coord.Projection\n\n// ToDo: duplicates jetbrains.livemap.core.projections.MercatorProjection\nclass MercatorProjectionX : Projection {\n    override val nonlinear = false\n\n    override fun apply(v: Double): Double {\n        return getMercatorX(v)\n    }\n\n    override fun toValidDomain(domain: ClosedRange<Double>): ClosedRange<Double> {\n        return domain\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.coord.map\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.spatial.MercatorUtils.VALID_LATITUDE_RANGE\nimport jetbrains.datalore.base.spatial.MercatorUtils.getMercatorY\nimport jetbrains.datalore.plot.base.coord.Projection\n\nclass MercatorProjectionY : Projection {\n    override val nonlinear = true\n\n    override fun apply(v: Double): Double {\n        return getMercatorY(v)\n    }\n\n    override fun toValidDomain(domain: ClosedRange<Double>): ClosedRange<Double> {\n        if (VALID_LATITUDE_RANGE.isConnected(domain)) {\n            return VALID_LATITUDE_RANGE.intersection(domain)\n        }\n        throw IllegalArgumentException(\"Illegal latitude range for mercator projection: $domain\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.base.function.Consumer\nimport jetbrains.datalore.base.gcommon.base.Strings.isNullOrEmpty\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport jetbrains.datalore.plot.base.*\nimport jetbrains.datalore.plot.base.DataFrame.Builder\nimport jetbrains.datalore.plot.base.DataFrame.Builder.Companion.emptyFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport jetbrains.datalore.plot.builder.assemble.TypedScaleMap\nimport jetbrains.datalore.plot.builder.data.GroupUtil.indicesByGroup\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.pickAtIndices\n\nobject DataProcessing {\n\n    fun transformOriginals(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap\n    ): DataFrame {\n        @Suppress(\"NAME_SHADOWING\")\n        var data = data\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (variable.isOrigin) {\n                check(data.has(variable)) { \"Undefined variable $variable\" }\n                data = DataFrameUtil.applyTransform(\n                    data,\n                    variable,\n                    binding.aes,\n                    scaleMap[binding.aes]\n                )\n            }\n        }\n\n        return data\n    }\n\n    fun buildStatData(\n        data: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap,\n        groupingContext: GroupingContext,\n        facets: PlotFacets,\n        statCtx: StatContext,\n        varsWithoutBinding: List<String>,\n        orderOptions: List<OrderOptionUtil.OrderOption>,\n        aggregateOperation: ((List<Double?>) -> Double?)?,\n        messageConsumer: Consumer<String>\n    ): DataAndGroupingContext {\n        if (stat === Stats.IDENTITY) {\n            return DataAndGroupingContext(emptyFrame(), groupingContext)\n        }\n\n        val groups = groupingContext.groupMapper\n\n        val resultSeries: Map<Variable, List<Any?>>\n        val groupSizeListAfterStat: List<Int>\n\n        // if only one group no need to modify\n        if (groups === GroupUtil.SINGLE_GROUP) {\n            val sd = applyStat(data, stat, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer)\n            groupSizeListAfterStat = listOf(sd.rowCount())\n            resultSeries = sd.variables().associateWith { variable -> sd[variable] }\n        } else { // add offset to each group\n            val groupMerger = GroupMerger()\n            var lastStatGroupEnd = -1\n            for (d in splitByGroup(data, groups)) {\n                var sd = applyStat(d, stat, bindings, scaleMap, facets, statCtx, varsWithoutBinding, messageConsumer)\n                if (sd.isEmpty) {\n                    continue\n                }\n                groupMerger.initOrderSpecs(orderOptions, sd.variables(), bindings, aggregateOperation)\n\n                val curGroupSizeAfterStat = sd.rowCount()\n\n                // update 'stat group' to avoid collisions as stat is applied independently to each original data group\n                if (sd.has(Stats.GROUP)) {\n                    val range = sd.range(Stats.GROUP)\n                    if (range != null) {\n                        val start = lastStatGroupEnd + 1\n                        val offset = start - range.lowerEnd.toInt()\n                        lastStatGroupEnd = range.upperEnd.toInt() + offset\n                        if (offset != 0) {\n                            val newG = ArrayList<Double>()\n                            for (g in sd.getNumeric(Stats.GROUP)) {\n                                newG.add(g!! + offset)\n                            }\n                            sd = sd.builder().putNumeric(Stats.GROUP, newG).build()\n                        }\n                    }\n                } else { // if stat has ..group.. then groupingVar won't be checked, so no need to update\n                    val groupingVar = groupingContext.optionalGroupingVar\n                    if (groupingVar != null) {\n                        val size = sd[sd.variables().first()].size\n                        val v = d[groupingVar][0]\n                        sd = sd.builder().put(groupingVar, List(size) { v }).build()\n                    }\n                }\n\n                // Add group's data\n                groupMerger.addGroup(sd, curGroupSizeAfterStat)\n            }\n            // Get merged series\n            resultSeries = groupMerger.getResultSeries()\n            groupSizeListAfterStat = groupMerger.getGroupSizes()\n        }\n\n        val dataAfterStat = Builder().run {\n            // put results\n            for (variable in resultSeries.keys) {\n                put(variable, resultSeries[variable]!!)\n            }\n\n            // set ordering specifications\n            val orderSpecs = orderOptions.map { orderOption ->\n                OrderOptionUtil.createOrderSpec(resultSeries.keys, bindings, orderOption, aggregateOperation)\n            }\n            addOrderSpecs(orderSpecs)\n\n            // build DataFrame\n            build()\n        }\n\n        val groupingContextAfterStat = GroupingContext.withOrderedGroups(\n            dataAfterStat,\n            groupSizeListAfterStat\n        )\n\n        return DataAndGroupingContext(\n            dataAfterStat,\n            groupingContextAfterStat\n        )\n    }\n\n    internal fun findOptionalVariable(data: DataFrame, name: String?): Variable? {\n        return if (isNullOrEmpty(name))\n            null\n        else\n            DataFrameUtil.findVariableOrFail(data, name!!)\n    }\n\n    private fun splitByGroup(data: DataFrame, groups: (Int) -> Int): List<DataFrame> {\n        return indicesByGroup(data.rowCount(), groups).values.map { indices ->\n            data.variables().fold(Builder()) { b, variable ->\n                when (data.isNumeric(variable)) {\n                    true -> b.putNumeric(variable, pickAtIndices(data.getNumeric(variable), indices))\n                    false -> b.putDiscrete(variable, pickAtIndices(data[variable], indices))\n                }\n            }\n        }.map(Builder::build)\n    }\n\n    /**\n     * Server-side only\n     */\n    private fun applyStat(\n        data: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap,\n        facets: PlotFacets,\n        statCtx: StatContext,\n        varsWithoutBinding: List<String>,\n        compMessageConsumer: Consumer<String>\n    ): DataFrame {\n\n        var statData = stat.apply(data, statCtx, compMessageConsumer)\n\n        val statVariables = statData.variables()\n        if (statVariables.isEmpty()) {\n            return statData\n        }\n\n        // generate new 'input' series to match stat series\n\n        val inverseTransformedStatSeries =\n            inverseTransformContinuousStatData(\n                statData,\n                stat,\n                bindings,\n                scaleMap\n            )\n\n        // generate new series for facet variables\n\n        val statDataSize = statData[statVariables.iterator().next()].size\n        val facetVars = HashSet<Variable>()\n        for (facetVarName in facets.variables) {\n            val facetVar = DataFrameUtil.findVariableOrFail(data, facetVarName)\n            facetVars.add(facetVar)\n            if (data[facetVar].isNotEmpty()) {\n                val facetLevel = data[facetVar][0]\n                // generate series for 'facet' variable\n                statData = statData\n                    .builder()\n                    .put(facetVar, List(statDataSize) { facetLevel })\n                    .build()\n            }\n        }\n\n        // generate new series for input variables\n\n        if (bindings.isEmpty()) {\n            return statData\n        }\n\n        val newInputSeries = HashMap<Variable, List<*>>()\n\n        fun addSeriesForVariable(variable: Variable) {\n            val value = when (data.isNumeric(variable)) {\n                true -> SeriesUtil.mean(data.getNumeric(variable), defaultValue = null)\n                false -> SeriesUtil.firstNotNull(data[variable], defaultValue = null)\n            }\n            val newInputSerie = List(statDataSize) { value }\n            newInputSeries[variable] = newInputSerie\n        }\n\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (variable.isStat || facetVars.contains(variable)) {\n                continue\n            }\n\n            val aes = binding.aes\n            if (stat.hasDefaultMapping(aes)) {\n                val defaultStatVar = stat.getDefaultMapping(aes)\n                val newInputSerie: List<*> =\n                    if (inverseTransformedStatSeries.containsKey(defaultStatVar)) {\n                        inverseTransformedStatSeries.getValue(defaultStatVar)\n                    } else {\n                        val statSerie = statData.getNumeric(defaultStatVar)\n                        ScaleUtil.inverseTransform(statSerie, scaleMap[aes])\n                    }\n                newInputSeries[variable] = newInputSerie\n            } else {\n                // Do not override series obtained via 'default stat var'\n                if (!newInputSeries.containsKey(variable)) {\n                    addSeriesForVariable(variable)\n                }\n            }\n        }\n        // series for variables without bindings\n        for (varName in varsWithoutBinding.filterNot(Stats::isStatVar)) {\n            val variable = DataFrameUtil.findVariableOrFail(data, varName)\n            if (!newInputSeries.containsKey(variable)) {\n                addSeriesForVariable(variable)\n            }\n        }\n\n        val b = statData.builder()\n        for (variable in newInputSeries.keys) {\n            b.put(variable, newInputSeries.getValue(variable))\n        }\n        // also update stat series\n        for (variable in inverseTransformedStatSeries.keys) {\n            b.putNumeric(variable, inverseTransformedStatSeries.getValue(variable))\n        }\n\n        return b.build()\n    }\n\n    private fun inverseTransformContinuousStatData(\n        statData: DataFrame,\n        stat: Stat,\n        bindings: List<VarBinding>,\n        scaleMap: TypedScaleMap\n    ): Map<Variable, List<Double?>> {\n        // inverse transform stat data with continuous domain.\n        val continuousScaleByAes = HashMap<Aes<*>, Scale<*>>()\n        val aesByMappedStatVar = HashMap<Variable, Aes<*>>()\n        for (aes in Aes.values()) {\n            if (stat.hasDefaultMapping(aes)) {\n                val defaultStatVar = stat.getDefaultMapping(aes)\n                aesByMappedStatVar[defaultStatVar] = aes\n            }\n        }\n\n        for (binding in bindings) {\n            val aes = binding.aes\n            val variable = binding.variable\n            if (variable.isStat) {\n                aesByMappedStatVar[variable] = aes\n                // ignore 'stat' var becaue ..?\n                continue\n            }\n\n            val scale = scaleMap[aes]\n            if (scale.isContinuousDomain) {\n                continuousScaleByAes[aes] = scale\n                if (Aes.isPositionalX(aes) && !continuousScaleByAes.containsKey(Aes.X)) {\n                    continuousScaleByAes[Aes.X] = scale\n                } else if (Aes.isPositionalY(aes) && !continuousScaleByAes.containsKey(Aes.Y)) {\n                    continuousScaleByAes[Aes.Y] = scale\n                }\n            }\n        }\n\n        val inverseTransformedStatSeries = HashMap<Variable, List<Double?>>()\n        for (statVar in statData.variables()) {\n            if (aesByMappedStatVar.containsKey(statVar)) {\n                val aes = aesByMappedStatVar.getValue(statVar)\n                var scale: Scale<*>? = continuousScaleByAes[aes]\n                if (scale == null) {\n                    if (Aes.isPositionalX(aes)) {\n                        scale = continuousScaleByAes[Aes.X]\n                    } else if (Aes.isPositionalY(aes)) {\n                        scale = continuousScaleByAes[Aes.Y]\n                    }\n                }\n\n                if (scale != null) {\n                    val statSerie = statData.getNumeric(statVar)\n                    val inverseTransformedStatSerie = ScaleUtil.inverseTransformToContinuousDomain(statSerie, scale)\n                    inverseTransformedStatSeries[statVar] = inverseTransformedStatSerie\n                }\n            }\n        }\n        return inverseTransformedStatSeries\n    }\n\n    internal fun computeGroups(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        groupingVar: Variable?,\n        pathIdVar: Variable?\n    ): (Int) -> Int {\n        val groupingVariables = getGroupingVariables(data, bindings, groupingVar) + listOfNotNull(pathIdVar)\n\n        var currentGroups: List<Int>? = null\n        if (groupingVar != null) {\n            currentGroups = computeGroups(data[groupingVar])\n        }\n\n        for (groupingVariable in groupingVariables) {\n            val values = data[groupingVariable]\n            val groups = computeGroups(values)\n            if (currentGroups == null) {\n                currentGroups = groups\n                continue\n            }\n\n            check(currentGroups.size == groups.size) {\n                \"Data series used to compute groups must be equal in size (encountered sizes: \" +\n                        \"${currentGroups?.size}, ${groups.size} )\"\n            }\n            val dummies = computeDummyValues(currentGroups, groups)\n            currentGroups = computeGroups(dummies)\n        }\n\n        return if (currentGroups != null) {\n            GroupUtil.wrap(currentGroups)\n        } else {\n            GroupUtil.SINGLE_GROUP\n        }\n    }\n\n    private fun computeGroups(values: List<*>): List<Int> {\n        val groups = ArrayList<Int>()\n        val groupByVal = HashMap<Any?, Int>()\n        var count = 0\n        for (v in values) {\n            if (!groupByVal.containsKey(v)) {\n                groupByVal[v] = count++\n            }\n            groups.add(groupByVal.get(v)!!)\n        }\n        return groups\n    }\n\n    private fun computeDummyValues(list1: List<Int>, list2: List<Int>): List<Int> {\n        if (list1.isEmpty()) return emptyList()\n\n        val limit = 1000\n\n        val max = natural<Int>().max(Iterables.concat(list1, list2))\n        check(max < limit) { \"Too many groups: $max\" }\n        val dummies = ArrayList<Int>()\n        val it1 = list1.iterator()\n        val it2 = list2.iterator()\n        while (it1.hasNext()) {\n            val v1 = it1.next()\n            val v2 = it2.next()\n            val dummy = v1 * limit + v2\n            dummies.add(dummy)\n        }\n        return dummies\n    }\n\n    private fun getGroupingVariables(\n        data: DataFrame,\n        bindings: List<VarBinding>,\n        explicitGroupingVar: Variable?\n    ): Iterable<Variable> {\n\n        // all 'origin' discrete vars (but not positional) + explicitGroupingVar\n        val result = LinkedHashSet<Variable>()\n        for (binding in bindings) {\n            val variable = binding.variable\n            if (!result.contains(variable)) {\n                if (variable.isOrigin) {\n                    if (variable == explicitGroupingVar || isDefaultGroupingVariable(data, binding.aes, variable)) {\n                        result.add(variable)\n                    }\n                }\n            }\n        }\n        return result\n    }\n\n    private fun isDefaultGroupingVariable(\n        data: DataFrame,\n        aes: Aes<*>,\n        variable: Variable\n    ) = !(Aes.isPositional(aes) || data.isNumeric(variable))\n\n    class DataAndGroupingContext internal constructor(val data: DataFrame, val groupingContext: GroupingContext)\n\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.VarBinding\n\ninternal class GroupMerger {\n    private var myOrderSpecs: List<DataFrame.OrderSpec>? = null\n    private val myOrderedGroups = ArrayList<Group>()\n\n    fun initOrderSpecs(\n        orderOptions: List<OrderOptionUtil.OrderOption>,\n        variables: Set<DataFrame.Variable>,\n        bindings: List<VarBinding>,\n        aggregateOperation: ((List<Double?>) -> Double?)?\n    ) {\n        if (myOrderSpecs != null) return\n        myOrderSpecs = orderOptions\n            .filter { orderOption ->\n                // no need to reorder groups by X\n                bindings.find { it.variable.name == orderOption.variableName && it.aes == Aes.X } == null\n            }\n            .map { OrderOptionUtil.createOrderSpec(variables, bindings, it, aggregateOperation) }\n    }\n\n    fun getResultSeries(): HashMap<DataFrame.Variable, MutableList<Any?>> {\n        val resultSeries = HashMap<DataFrame.Variable, MutableList<Any?>>()\n        myOrderedGroups.forEach { group ->\n            group.df.variables().forEach { variable ->\n                resultSeries.getOrPut(variable, ::ArrayList).addAll(group.df[variable])\n            }\n        }\n        return resultSeries\n    }\n\n    fun getGroupSizes(): List<Int> {\n        return myOrderedGroups.map(Group::groupSize)\n    }\n\n    inner class Group(\n        val df: DataFrame,\n        val groupSize: Int\n    ) : Comparable<Group> {\n        override fun compareTo(other: Group): Int {\n            fun compareGroupValue(v1: Any?, v2: Any?, dir: Int): Int {\n                // null value is always greater - will be at the end of the result\n                if (v1 == null && v2 == null ) return 0\n                if (v1 == null) return 1\n                if (v2 == null) return -1\n                return compareValues(v1 as Comparable<*>, v2 as Comparable<*>) * dir\n            }\n            fun getValue(\n                df: DataFrame,\n                variable: DataFrame.Variable,\n                aggregateOperation: ((List<Double?>) -> Double?)? = null\n            ): Any? {\n                return if (aggregateOperation != null) {\n                    require(df.isNumeric(variable)) { \"Can't apply aggregate operation to non-numeric values\" }\n                    aggregateOperation.invoke(df.getNumeric(variable).requireNoNulls())\n                } else {\n                    // group has no more than one unique element\n                    df[variable].firstOrNull()\n                }\n            }\n\n            myOrderSpecs?.forEach { spec ->\n                var cmp = compareGroupValue(\n                    getValue(df, spec.orderBy, spec.aggregateOperation),\n                    getValue(other.df, spec.orderBy, spec.aggregateOperation),\n                    spec.direction\n                )\n                if (cmp == 0) {\n                    // ensure the order as in the legend\n                    cmp = compareGroupValue(\n                        getValue(df, spec.variable),\n                        getValue(other.df, spec.variable),\n                        spec.direction\n                    )\n                }\n                if (cmp != 0) {\n                    return cmp\n                }\n            }\n            return 0\n        }\n    }\n\n    fun addGroup(d: DataFrame, groupSize: Int) {\n        val group = Group(d, groupSize)\n        val indexToInsert = findIndexToInsert(group)\n        myOrderedGroups.add(indexToInsert, group)\n    }\n\n    private fun findIndexToInsert(group: Group): Int {\n        if (myOrderSpecs.isNullOrEmpty()) {\n            return myOrderedGroups.size\n        }\n        var index = myOrderedGroups.binarySearch(group)\n        if (index < 0) index = index.inv()\n        return index\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nobject GroupUtil {\n    internal val SINGLE_GROUP = { _: Int -> 0 }\n\n    fun wrap(l: List<Number?>): (Int) -> Int {\n        return { index ->\n            if (index > 0 && index < l.size)\n                l[index]!!.toInt()\n            else\n                0\n        }\n    }\n\n    fun wrap(groupByPointIndex: Map<Int, Int>): (Int) -> Int {\n        return { groupByPointIndex[it]!! }\n    }\n\n    fun indicesByGroup(dataLength: Int, groups: (Int) -> Int): Map<Int, List<Int>> {\n        val indicesByGroup = LinkedHashMap<Int, MutableList<Int>>()\n        for (i in 0 until dataLength) {\n            val group = groups(i)\n            if (!indicesByGroup.containsKey(group)) {\n                indicesByGroup[group] = ArrayList()\n            }\n            indicesByGroup[group]!!.add(i)\n        }\n\n        return indicesByGroup\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.data.DataProcessing.findOptionalVariable\n\nclass GroupingContext(\n    private val myData: DataFrame,\n    bindings: List<VarBinding>,\n    groupingVarName: String?,\n    pathIdVarName: String?,\n    private val myExpectMultiple: Boolean\n) {\n\n    private val myBindings: List<VarBinding> = ArrayList(bindings)\n    internal val optionalGroupingVar: Variable? = findOptionalVariable(myData, groupingVarName)\n    private val pathIdVar: Variable? = findOptionalVariable(myData, pathIdVarName)\n\n    private var myGroupSizeList: List<Int>? = null\n    private var myGroupMapper: ((Int) -> Int)? = null\n\n    //myGroupMapper = DataProcessing.computeGroups(myData, myBindings, myOptionalGroupingVar, myExpectMultiple);\n    val groupMapper: (Int) -> Int\n        get() = { index ->\n            if (myGroupMapper == null) {\n                myGroupMapper = computeGroups()\n            }\n            myGroupMapper!!(index)\n        }\n\n    private fun computeGroups(): (Int) -> Int {\n        if (myData.has(Stats.GROUP)) {\n            val list = myData.getNumeric(Stats.GROUP)\n            return GroupUtil.wrap(list)\n        } else if (myGroupSizeList != null) {\n            if (myGroupSizeList!!.size == myData.rowCount()) {\n                return GroupUtil.SINGLE_GROUP\n            } else {\n                val groupByPointIndex =\n                    toIndexMap(myGroupSizeList!!)\n                return GroupUtil.wrap(groupByPointIndex)\n            }\n        } else if (myExpectMultiple) {\n            return DataProcessing.computeGroups(\n                myData,\n                myBindings,\n                optionalGroupingVar,\n                pathIdVar\n            )\n        }\n        return GroupUtil.SINGLE_GROUP\n    }\n\n    companion object {\n        internal fun withOrderedGroups(data: DataFrame, groupSizeList: List<Int>): GroupingContext {\n            val groupingContext = GroupingContext(data, emptyList(), null, null, false)\n            groupingContext.myGroupSizeList = ArrayList(groupSizeList)\n            return groupingContext\n        }\n\n        private fun toIndexMap(groupSizeList: List<Int>): Map<Int, Int> {\n            val result = HashMap<Int, Int>()\n            var currentGroup = 0\n            var currentGroupIndexOffset = 0\n            for (groupSize in groupSizeList) {\n                for (i in 0 until groupSize) {\n                    result[currentGroupIndexOffset + i] = currentGroup\n                }\n                currentGroup++\n                currentGroupIndexOffset += groupSize\n            }\n            return result\n        }\n    }\n}\n","/*\n * Copyright (c) 2021. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.data\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.VarBinding\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil\n\nobject OrderOptionUtil {\n    class OrderOption internal constructor(\n        val variableName: String,\n        val byVariable: String?,\n        private val orderDir: Int?\n    ) {\n        fun getOrderDir(): Int = orderDir ?: -1 // descending by default\n\n        companion object {\n            fun create(\n                variableName: String,\n                orderBy: String?,\n                order: Any?\n            ): OrderOption? {\n                if (orderBy == null && order == null) {\n                    return null\n                }\n                require(order == null || (order is Number && order.toInt() in listOf(-1, 1))) {\n                    \"Unsupported `order` value: $order. Use 1 (ascending) or -1 (descending).\"\n                }\n\n                return OrderOption(variableName, orderBy, (order as? Number)?.toInt())\n            }\n\n            fun OrderOption.mergeWith(other: OrderOption): OrderOption {\n                require(variableName == other.variableName) {\n                    \"Can't merge order options for different variables: '$variableName' and '${other.variableName}'\"\n                }\n                require(byVariable == null || other.byVariable == null || other.byVariable == byVariable) {\n                    \"Multiple ordering options for the variable '$variableName' with different non-empty 'order_by' fields: '$byVariable' and '${other.byVariable}'\"\n                }\n                require(orderDir == null || other.orderDir == null || other.orderDir == orderDir) {\n                    \"Multiple ordering options for the variable '$variableName' with different order direction: '$orderDir' and '${other.orderDir}'\"\n                }\n                return OrderOption(\n                    variableName,\n                    byVariable ?: other.byVariable,\n                    orderDir ?: other.orderDir\n                )\n            }\n        }\n    }\n\n    fun createOrderSpec(\n        variables: Set<DataFrame.Variable>,\n        varBindings: List<VarBinding>,\n        orderOption: OrderOption,\n        aggregateOperation: ((List<Double?>) -> Double?)?\n    ): DataFrame.OrderSpec {\n        fun getVariableByName(varName: String): DataFrame.Variable {\n            return variables.find { it.name == varName }\n                ?: error(\"Undefined variable '$varName' in order options. Full variable list: ${variables.map { \"'${it.name}'\" }}\")\n        }\n\n        val variable =\n            if (varBindings.find { it.variable.name == orderOption.variableName && it.aes == Aes.X } != null &&\n                SamplingUtil.xVar(variables) != null\n            ) {\n                // Apply ordering to the X variable which is used for sampling\n                SamplingUtil.xVar(variables)!!\n            } else {\n                getVariableByName(orderOption.variableName)\n            }\n\n        return DataFrame.OrderSpec(\n            variable,\n            orderOption.byVariable?.let(::getVariableByName) ?: getVariableByName(orderOption.variableName),\n            orderOption.getOrderDir(),\n            aggregateOperation.takeIf {\n                // Use the aggregation for ordering by the specified 'order_by' variable\n                orderOption.byVariable != null && orderOption.byVariable != orderOption.variableName\n            }\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.event\n\nimport jetbrains.datalore.base.event.MouseEvent\nimport jetbrains.datalore.base.event.MouseEventSource\nimport jetbrains.datalore.base.event.MouseEventSpec\nimport jetbrains.datalore.base.observable.event.EventHandler\nimport jetbrains.datalore.base.observable.event.ListenerCaller\nimport jetbrains.datalore.base.observable.event.Listeners\nimport jetbrains.datalore.base.registration.CompositeRegistration\nimport jetbrains.datalore.base.registration.Registration\n\nclass MouseEventPeer : MouseEventSource {\n    private val myEventHandlers = HashMap<MouseEventSpec, Listeners<EventHandler<MouseEvent>>>()\n    private val myEventSources = ArrayList<MouseEventSource>()\n    private val mySourceRegistrations = HashMap<MouseEventSpec, CompositeRegistration>()\n\n    override fun addEventHandler(eventSpec: MouseEventSpec, eventHandler: EventHandler<MouseEvent>): Registration {\n        if (!myEventHandlers.containsKey(eventSpec)) {\n            myEventHandlers[eventSpec] = Listeners()\n            onAddSpec(eventSpec)\n        }\n\n        val addReg = myEventHandlers[eventSpec]?.add(eventHandler)\n        return object : Registration() {\n            override fun doRemove() {\n                addReg?.remove()\n                if (myEventHandlers[eventSpec]!!.isEmpty) {\n                    myEventHandlers.remove(eventSpec)\n                    onRemoveSpec(eventSpec)\n                }\n            }\n        }\n    }\n\n    fun dispatch(eventSpec: MouseEventSpec, mouseEvent: MouseEvent) {\n        if (myEventHandlers.containsKey(eventSpec)) {\n            myEventHandlers[eventSpec]?.fire(object : ListenerCaller<EventHandler<MouseEvent>> {\n                override fun call(l: EventHandler<MouseEvent>) {\n                    l.onEvent(mouseEvent)\n                }\n            })\n        }\n    }\n\n    fun addEventSource(eventSource: MouseEventSource) {\n        myEventHandlers.keys.forEach { eventSpec -> startHandleSpecInSource(eventSource, eventSpec) }\n        myEventSources.add(eventSource)\n    }\n\n    private fun onAddSpec(eventSpec: MouseEventSpec) {\n        myEventSources.forEach { eventSource -> startHandleSpecInSource(eventSource, eventSpec) }\n    }\n\n    private fun startHandleSpecInSource(eventSource: MouseEventSource, eventSpec: MouseEventSpec) {\n        val registration = eventSource.addEventHandler(eventSpec, object : EventHandler<MouseEvent> {\n            override fun onEvent(event: MouseEvent) {\n                dispatch(eventSpec, event)\n            }\n        })\n\n        if (!mySourceRegistrations.containsKey(eventSpec)) {\n            mySourceRegistrations[eventSpec] = CompositeRegistration()\n        }\n        mySourceRegistrations[eventSpec]?.add(registration)\n    }\n\n    private fun onRemoveSpec(eventSpec: MouseEventSpec) {\n        if (mySourceRegistrations.containsKey(eventSpec)) {\n            mySourceRegistrations.remove(eventSpec)?.dispose()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.observable.event.EventSource\nimport jetbrains.datalore.base.observable.event.EventSources\nimport jetbrains.datalore.base.observable.property.Property\nimport jetbrains.datalore.base.observable.property.PropertyBinding.bindOneWay\nimport jetbrains.datalore.base.observable.property.PropertyChangeEvent\nimport jetbrains.datalore.base.observable.property.ValueProperty\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor.*\nimport jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor.*\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgUtils.transformTranslate\n\nclass AxisComponent(length: Double, orientation: Orientation) : SvgComponent() {\n\n    val breaks: Property<List<Double>?> = ValueProperty(null)\n    val labels: Property<List<String>?> = ValueProperty(null)\n    // layout\n    val tickLabelRotationDegree: Property<Double> = ValueProperty(0.0)\n    val tickLabelHorizontalAnchor: Property<TextLabel.HorizontalAnchor>\n    // todo: minorBreaks\n    val tickLabelVerticalAnchor: Property<TextLabel.VerticalAnchor>\n    val tickLabelSmallFont: Property<Boolean> = ValueProperty(false)\n    val tickLabelOffsets: Property<List<DoubleVector>?> = ValueProperty(null)  // optional\n    val gridLineColor: Property<Color> = ValueProperty(Color.LIGHT_GRAY)\n    val lineWidth: Property<Double> = ValueProperty(1.0)\n    val gridLineWidth: Property<Double> = ValueProperty(1.0)\n    val gridLineLength: Property<Double> = ValueProperty(0.0)\n    val tickMarkWidth: Property<Double> = ValueProperty(1.0)\n    val tickMarkLength: Property<Double> = ValueProperty(6.0)\n    val tickMarkPadding: Property<Double> = ValueProperty(3.0)\n    private val length = ValueProperty<Double?>(null)\n    private val orientation = ValueProperty<Orientation?>(null)\n    // theme\n    private val myTickMarksEnabled = ValueProperty(true)\n    private val myTickLabelsEnabled = ValueProperty(true)\n    private val myAxisLineEnabled = ValueProperty(true)\n    private val lineColor = ValueProperty(Color.BLACK)\n    private val tickColor = ValueProperty(Color.BLACK)\n\n    private fun defTickLabelHorizontalAnchor(orientation: Orientation): TextLabel.HorizontalAnchor {\n        return when (orientation) {\n            Orientation.LEFT -> RIGHT\n            Orientation.RIGHT -> LEFT\n            Orientation.TOP, Orientation.BOTTOM -> MIDDLE\n        }\n    }\n\n    private fun defTickLabelVerticalAnchor(orientation: Orientation): TextLabel.VerticalAnchor {\n        when (orientation) {\n            Orientation.LEFT, Orientation.RIGHT -> return CENTER\n            Orientation.TOP -> return BOTTOM\n            Orientation.BOTTOM -> return TOP\n            else -> throw RuntimeException(\"Unexpected orientation:$orientation\")\n        }\n    }\n\n    init {\n        this.length.set(length)\n        this.orientation.set(orientation)\n\n        tickLabelHorizontalAnchor = ValueProperty(defTickLabelHorizontalAnchor(orientation))\n        tickLabelVerticalAnchor = ValueProperty(defTickLabelVerticalAnchor(orientation))\n\n        @Suppress(\"UNCHECKED_CAST\")\n        fun <T> EventSource<in PropertyChangeEvent<T>>.asPropertyChangedEventSource() = this as EventSource<PropertyChangeEvent<*>>\n\n        EventSources.composite(\n            this.length.asPropertyChangedEventSource(),\n            this.orientation.asPropertyChangedEventSource(),\n            breaks.asPropertyChangedEventSource(),\n            labels.asPropertyChangedEventSource(),\n            gridLineLength.asPropertyChangedEventSource(),\n            tickLabelOffsets.asPropertyChangedEventSource(),\n            tickLabelHorizontalAnchor.asPropertyChangedEventSource(),\n            tickLabelVerticalAnchor.asPropertyChangedEventSource(),\n            tickLabelRotationDegree.asPropertyChangedEventSource(),\n            tickLabelSmallFont.asPropertyChangedEventSource()\n        ).addHandler(rebuildHandler())\n    }\n\n    override fun buildComponent() {\n        buildAxis()\n    }\n\n    private fun buildAxis() {\n        val rootElement = rootGroup\n        rootElement.addClass(Style.AXIS)\n        if (tickLabelSmallFont.get()) {\n            rootElement.addClass(Style.SMALL_TICK_FONT)\n        }\n\n        val l = length.get()!!\n        val x1: Double\n        val y1: Double\n        val x2: Double\n        val y2: Double\n        val start: Double\n        val end: Double\n        when (orientation.get()) {\n            Orientation.LEFT, Orientation.RIGHT -> {\n                x2 = 0.0\n                x1 = x2\n                start = 0.0\n                y1 = start\n                end = l\n                y2 = end\n            }\n            Orientation.TOP, Orientation.BOTTOM -> {\n                start = 0.0\n                x1 = start\n                end = l\n                x2 = end\n                y2 = 0.0\n                y1 = y2\n            }\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n\n        var axisLine: SvgLineElement? = null\n        if (axisLineEnabled().get()) {\n            axisLine = SvgLineElement(x1, y1, x2, y2)\n            reg(bindOneWay(lineWidth, axisLine.strokeWidth()))\n            reg(bindOneWay(lineColor, axisLine.strokeColor()))\n        }\n\n        // do not draw grid lines then it's too close to axis ends.\n        val gridLineMinPos = start + 3\n        val gridLineMaxPos = end - 3\n\n        if (breaksEnabled()) {\n            // add ticks before axis line\n            val breaks = this.breaks.get()\n            if (!(breaks == null || breaks.isEmpty())) {\n\n                var labels: List<String>? = this.labels.get()\n                if (labels == null || labels.isEmpty()) {\n                    labels = ArrayList()\n                    for (i in breaks.indices) {\n                        labels.add(\"\")\n                    }\n                }\n\n                var i = 0\n                for (br in breaks) {\n                    val addGridLine = br >= gridLineMinPos && br <= gridLineMaxPos\n                    val label = labels[i % labels.size]\n                    val labelOffset = tickLabelOffset(i)\n                    i++\n                    val group = buildTick(\n                            label,\n                            labelOffset,\n                            if (addGridLine) gridLineLength.get() else 0.0)\n\n                    when (orientation.get()) {\n                        Orientation.LEFT, Orientation.RIGHT -> transformTranslate(group, 0.0, br)\n                        Orientation.TOP, Orientation.BOTTOM -> transformTranslate(group, br, 0.0)\n                        else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n                    }\n\n                    rootElement.children().add(group)\n                }\n            }\n        }\n\n        // axis line\n        if (axisLine != null) {\n            rootElement.children().add(axisLine)\n        }\n    }\n\n    private fun buildTick(label: String, labelOffset: DoubleVector, gridLineLength: Double): SvgGElement {\n\n        var tickMark: SvgLineElement? = null\n        if (tickMarksEnabled().get()) {\n            tickMark = SvgLineElement()\n            reg(bindOneWay(tickMarkWidth, tickMark.strokeWidth()))\n            reg(bindOneWay(tickColor, tickMark.strokeColor()))\n        }\n\n        var tickLabel: TextLabel? = null\n        if (tickLabelsEnabled().get()) {\n            tickLabel = TextLabel(label)\n            reg(bindOneWay(tickColor, tickLabel.textColor()))\n        }\n\n        var gridLine: SvgLineElement? = null // optional;\n        if (gridLineLength > 0) {\n            gridLine = SvgLineElement()\n            reg(bindOneWay(gridLineColor, gridLine.strokeColor()))\n            reg(bindOneWay(gridLineWidth, gridLine.strokeWidth()))\n        }\n\n        val markLength = tickMarkLength.get()\n        when (orientation.get()) {\n            Orientation.LEFT -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(-markLength)\n                    tickMark.y2().set(0.0)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(gridLineLength)\n                    gridLine.y2().set(0.0)\n                }\n            }\n            Orientation.RIGHT -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(markLength)\n                    tickMark.y2().set(0.0)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(-gridLineLength)\n                    gridLine.y2().set(0.0)\n                }\n            }\n            Orientation.TOP -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(0.0)\n                    tickMark.y2().set(-markLength)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(0.0)\n                    gridLine.y2().set(gridLineLength)\n                }\n            }\n            Orientation.BOTTOM -> {\n                if (tickMark != null) {\n                    tickMark.x2().set(0.0)\n                    tickMark.y2().set(markLength)\n                }\n                if (gridLine != null) {\n                    gridLine.x2().set(0.0)\n                    gridLine.y2().set(-gridLineLength)\n                }\n            }\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n\n        val g = SvgGElement()\n        if (gridLine != null) {\n            g.children().add(gridLine)\n        }\n\n        if (tickMark != null) {\n            g.children().add(tickMark)\n        }\n\n        if (tickLabel != null) {\n            tickLabel.moveTo(labelOffset.x, labelOffset.y)\n            tickLabel.setHorizontalAnchor(tickLabelHorizontalAnchor.get())\n            tickLabel.setVerticalAnchor(tickLabelVerticalAnchor.get())\n            tickLabel.rotate(tickLabelRotationDegree.get())\n            g.children().add(tickLabel.rootGroup)\n        }\n\n        g.addClass(Style.TICK)\n        return g\n    }\n\n    private fun tickMarkLength(): Double {\n        return if (myTickMarksEnabled.get()) {\n            tickMarkLength.get()\n        } else {\n            0.0\n        }\n    }\n\n    private fun tickLabelDistance(): Double {\n        return tickMarkLength() + tickMarkPadding.get()\n    }\n\n    private fun tickLabelBaseOffset(): DoubleVector {\n        val distance = tickLabelDistance()\n        return when (orientation.get()) {\n            Orientation.LEFT -> DoubleVector(-distance, 0.0)\n            Orientation.RIGHT -> DoubleVector(distance, 0.0)\n            Orientation.TOP -> DoubleVector(0.0, -distance)\n            Orientation.BOTTOM -> DoubleVector(0.0, distance)\n            else -> throw RuntimeException(\"Unexpected orientation:\" + orientation.get())\n        }\n    }\n\n    private fun tickLabelOffset(tickIndex: Int): DoubleVector {\n        val additionalOffsets = tickLabelOffsets.get()\n        val additionalOffset = if (additionalOffsets != null) additionalOffsets[tickIndex] else DoubleVector.ZERO\n        return tickLabelBaseOffset().add(additionalOffset)\n    }\n\n    private fun breaksEnabled(): Boolean {\n        return myTickMarksEnabled.get() || myTickLabelsEnabled.get()\n    }\n\n    fun tickMarksEnabled(): Property<Boolean> {\n        return myTickMarksEnabled\n    }\n\n    fun tickLabelsEnabled(): Property<Boolean> {\n        return myTickLabelsEnabled\n    }\n\n    fun axisLineEnabled(): Property<Boolean> {\n        return myAxisLineEnabled\n    }\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgLineElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\nimport kotlin.math.max\n\nclass ColorBarComponent(\n    override val spec: ColorBarComponentSpec\n) : LegendBox() {\n\n    override fun appendGuideContent(contentRoot: SvgNode): DoubleVector {\n        val layout = spec.layout\n\n        val guideBarGroup = SvgGElement()\n\n        // bar\n        val barBounds = layout.barBounds\n        val horizontal = layout.isHorizontal\n        addColorBar(\n            guideBarGroup,\n            spec.domain, spec.scale, spec.binCount, barBounds,\n            layout.barLengthExpand,\n            horizontal, spec.reverse\n        )\n\n        // Ticks and labels\n        val barThickness = when {\n            horizontal -> barBounds.height\n            else -> barBounds.width\n        }\n        val tickLength = barThickness / 5\n\n        val breakInfos = layout.breakInfos.iterator()\n        for (brLabel in spec.breaks.labels) {\n            val brInfo = breakInfos.next()\n\n            val tickLocation = brInfo.tickLocation\n            val tickMarkPoints = ArrayList<DoubleVector>()\n            if (horizontal) {\n                val tickX = barBounds.left + tickLocation\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.top))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.top + tickLength))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.bottom - tickLength))\n                tickMarkPoints.add(DoubleVector(tickX, barBounds.bottom))\n            } else {\n                val tickY = barBounds.top + tickLocation\n                tickMarkPoints.add(DoubleVector(barBounds.left, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.left + tickLength, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.right - tickLength, tickY))\n                tickMarkPoints.add(DoubleVector(barBounds.right, tickY))\n            }\n\n            addTickMark(guideBarGroup, tickMarkPoints[0], tickMarkPoints[1])\n            addTickMark(guideBarGroup, tickMarkPoints[2], tickMarkPoints[3])\n\n            val label = TextLabel(brLabel)\n            label.setHorizontalAnchor(brInfo.labelHorizontalAnchor)\n            label.setVerticalAnchor(brInfo.labelVerticalAnchor)\n            label.moveTo(brInfo.labelLocation.x, brInfo.labelLocation.y + barBounds.top)\n            guideBarGroup.children().add(label.rootGroup)\n        }\n\n        // add white frame\n        guideBarGroup.children().add(\n            createBorder(\n                barBounds,\n                spec.theme.backgroundFill(),\n                1.0\n            )\n        )\n\n        if (debug) {\n            // frame bar and labels\n            val graphBounds = DoubleRectangle(DoubleVector.ZERO, layout.graphSize)\n            guideBarGroup.children().add(\n                createBorder(\n                    graphBounds,\n                    Color.DARK_BLUE,\n                    1.0\n                )\n            )\n        }\n\n        contentRoot.children().add(guideBarGroup)\n        return layout.size\n    }\n\n    private fun addColorBar(\n        g: SvgGElement,\n        domain: ClosedRange<Double>,\n        scale: Scale<Color>,\n        numBins: Int,\n        barBounds: DoubleRectangle,\n        barLengthExpand: Double,\n        horizontal: Boolean,\n        reverse: Boolean\n    ) {\n\n        val domainSpan = SeriesUtil.span(domain)\n        val stepCount = max(2, numBins)\n        val step = domainSpan / stepCount\n        val v = domain.lowerEnd + step / 2\n        val domainValues = ArrayList<Double>()\n        for (i in 0 until stepCount) {\n            domainValues.add(v + step * i)\n        }\n        if (reverse) {\n            domainValues.reverse()\n        }\n\n        val colors = ScaleUtil.map(domainValues, scale)\n        val barLength = when {\n            horizontal -> barBounds.width\n            else -> barBounds.height\n        }\n        val effectiveBarLength = barLength - barLengthExpand * 2\n        val segmentStep = effectiveBarLength / stepCount\n\n        var segmentLeft = barBounds.left\n        val segmentRight = barBounds.right\n        val segmentBottom = barBounds.bottom\n        var segmentTop = barBounds.top\n\n        for ((i, color) in colors.withIndex()) {\n            val r = SvgRectElement(\n                segmentLeft,\n                segmentTop,\n                segmentRight - segmentLeft,\n                segmentBottom - segmentTop\n            )\n            r.strokeWidth().set(0.0)\n            r.fillColor().set(color)\n            g.children().add(r)\n\n            if (horizontal) {\n                segmentLeft += segmentStep\n            } else {\n                segmentTop += segmentStep\n            }\n            if (i == 0) {\n                // first segment is a bit longer.\n                if (horizontal) {\n                    segmentLeft += barLengthExpand\n                } else {\n                    segmentTop += barLengthExpand\n                }\n            }\n        }\n    }\n\n    private fun addTickMark(g: SvgGElement, p0: DoubleVector, p1: DoubleVector) {\n        val line = SvgLineElement(p0.x, p0.y, p1.x, p1.y)\n        line.strokeWidth().set(1.0)\n        line.strokeColor().set(spec.theme.backgroundFill());\n        g.children().add(line)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\nabstract class ColorBarComponentLayout(\n    title: String,\n    domain: ClosedRange<Double>,\n    breaks: ScaleBreaks,\n    protected val guideBarSize: DoubleVector,\n    legendDirection: LegendDirection,\n    reverse: Boolean\n) : LegendBoxLayout(\n    title,\n    legendDirection\n) {\n\n    var barBounds: DoubleRectangle private set\n\n    // num of pix added on each end of the bar (to avoid terminal ticks to lay on the border)\n    val barLengthExpand: Double = 2.0\n\n    protected abstract val guideBarLength: Double\n    internal val breakInfos: List<BreakInfo>\n\n    init {\n        val guideBarLength = guideBarLength\n        val targetRange = ClosedRange(0.0 + barLengthExpand, guideBarLength - barLengthExpand)\n        val mapper = Mappers.linear(domain, targetRange, reverse)\n        breakInfos = breaks.transformedValues.map {\n            val tickLocation = mapper(it)\n            createBreakInfo(tickLocation)\n        }\n        barBounds = DoubleRectangle(DoubleVector.ZERO, guideBarSize)\n    }\n\n    internal abstract fun createBreakInfo(tickLocation: Double): BreakInfo\n\n    internal class BreakInfo(\n        val tickLocation: Double, val labelLocation: DoubleVector,\n        val labelHorizontalAnchor: TextLabel.HorizontalAnchor, val labelVerticalAnchor: TextLabel.VerticalAnchor\n    )\n\n    private class HorizontalLayout(\n        title: String,\n        domain: ClosedRange<Double>,\n        breaks: ScaleBreaks,\n        barSize: DoubleVector,\n        reverse: Boolean\n    ) : ColorBarComponentLayout(\n        title, domain, breaks, barSize,\n        LegendDirection.HORIZONTAL,\n        reverse\n    ) {\n\n        override val graphSize: DoubleVector\n        private val labelDistance: Double get() = LABEL_SPEC.height() / 3\n        override val guideBarLength: Double get() = guideBarSize.x\n\n        init {\n            // Bar + labels bounds\n            graphSize = DoubleVector(guideBarSize.x, guideBarSize.y + labelDistance + LABEL_SPEC.height())\n        }\n\n        override fun createBreakInfo(tickLocation: Double): BreakInfo {\n            val labelLocation = DoubleVector(tickLocation, guideBarSize.y + labelDistance)\n            return BreakInfo(\n                tickLocation,\n                labelLocation,\n                TextLabel.HorizontalAnchor.MIDDLE,\n                TextLabel.VerticalAnchor.TOP\n            )\n        }\n    }\n\n    private class VerticalLayout(\n        title: String,\n        domain: ClosedRange<Double>,\n        breaks: ScaleBreaks,\n        barSize: DoubleVector,\n        reverse: Boolean\n    ) : ColorBarComponentLayout(\n        title, domain, breaks, barSize,\n        LegendDirection.VERTICAL,\n        reverse\n    ) {\n\n        override val graphSize: DoubleVector\n        private val labelDistance: Double get() = LABEL_SPEC.width(1) / 2\n        override val guideBarLength: Double get() = guideBarSize.y\n\n        init {\n            check(!breaks.isEmpty) { \"Colorbar VerticalLayout received empty breaks list.\" }\n            val maxLabelWidth: Double = breaks.labels.map { it.length }\n                .maxOf { LABEL_SPEC.width(it) }\n\n            // Bar + labels bounds\n            graphSize = DoubleVector(guideBarSize.x + labelDistance + maxLabelWidth, guideBarSize.y)\n        }\n\n        override fun createBreakInfo(tickLocation: Double): BreakInfo {\n            val labelLocation = DoubleVector(guideBarSize.x + labelDistance, tickLocation)\n            return BreakInfo(\n                tickLocation,\n                labelLocation,\n                TextLabel.HorizontalAnchor.LEFT,\n                TextLabel.VerticalAnchor.CENTER\n            )\n        }\n    }\n\n    companion object {\n        fun horizontal(\n            title: String,\n            domain: ClosedRange<Double>,\n            breaks: ScaleBreaks,\n            barSize: DoubleVector,\n            reverse: Boolean\n        ): ColorBarComponentLayout {\n            return HorizontalLayout(\n                title,\n                domain,\n                breaks,\n                barSize,\n                reverse\n            )\n        }\n\n        fun vertical(\n            title: String,\n            domain: ClosedRange<Double>,\n            breaks: ScaleBreaks,\n            barSize: DoubleVector,\n            reverse: Boolean\n        ): ColorBarComponentLayout {\n            return VerticalLayout(\n                title,\n                domain,\n                breaks,\n                barSize,\n                reverse\n            )\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.comparisons\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.js.*\n\n/**\n * Returns the greater of two values.\n * \n * If values are equal, returns the first one.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, b: T): T {\n    return if (a >= b) a else b\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Byte, b: Byte): Byte {\n    return maxOf(a.toInt(), b.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Short, b: Short): Short {\n    return maxOf(a.toInt(), b.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Int, b: Int): Int {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.1\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun maxOf(a: Long, b: Long): Long {\n    return if (a >= b) a else b\n}\n\n/**\n * Returns the greater of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Float, b: Float): Float {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Double, b: Double): Double {\n    return JsMath.max(a, b)\n}\n\n/**\n * Returns the greater of three values.\n * \n * If there are multiple equal maximal values, returns the first of them.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, b: T, c: T): T {\n    return maxOf(a, maxOf(b, c))\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Byte, b: Byte, c: Byte): Byte {\n    return JsMath.max(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Short, b: Short, c: Short): Short {\n    return JsMath.max(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Int, b: Int, c: Int): Int {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Long, b: Long, c: Long): Long {\n    return maxOf(a, maxOf(b, c))\n}\n\n/**\n * Returns the greater of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Float, b: Float, c: Float): Float {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun maxOf(a: Double, b: Double, c: Double): Double {\n    return JsMath.max(a, b, c)\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If there are multiple equal maximal values, returns the first of them.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun <T : Comparable<T>> maxOf(a: T, vararg other: T): T {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Byte, vararg other: Byte): Byte {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Short, vararg other: Short): Short {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Int, vararg other: Int): Int {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Long, vararg other: Long): Long {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Float, vararg other: Float): Float {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the greater of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun maxOf(a: Double, vararg other: Double): Double {\n    var max = a\n    for (e in other) max = maxOf(max, e)\n    return max\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If values are equal, returns the first one.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> minOf(a: T, b: T): T {\n    return if (a <= b) a else b\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Byte, b: Byte): Byte {\n    return minOf(a.toInt(), b.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Short, b: Short): Short {\n    return minOf(a.toInt(), b.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Int, b: Int): Int {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.1\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun minOf(a: Long, b: Long): Long {\n    return if (a <= b) a else b\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Float, b: Float): Float {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of two values.\n * \n * If either value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Double, b: Double): Double {\n    return JsMath.min(a, b)\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If there are multiple equal minimal values, returns the first of them.\n */\n@SinceKotlin(\"1.1\")\npublic actual fun <T : Comparable<T>> minOf(a: T, b: T, c: T): T {\n    return minOf(a, minOf(b, c))\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Byte, b: Byte, c: Byte): Byte {\n    return JsMath.min(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Byte>()\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Short, b: Short, c: Short): Short {\n    return JsMath.min(a.toInt(), b.toInt(), c.toInt()).unsafeCast<Short>()\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Int, b: Int, c: Int): Int {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of three values.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Long, b: Long, c: Long): Long {\n    return minOf(a, minOf(b, c))\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Float, b: Float, c: Float): Float {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of three values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic actual inline fun minOf(a: Double, b: Double, c: Double): Double {\n    return JsMath.min(a, b, c)\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If there are multiple equal minimal values, returns the first of them.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun <T : Comparable<T>> minOf(a: T, vararg other: T): T {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Byte, vararg other: Byte): Byte {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Short, vararg other: Short): Short {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Int, vararg other: Int): Int {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Long, vararg other: Long): Long {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Float, vararg other: Float): Float {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n/**\n * Returns the smaller of the given values.\n * \n * If any value is `NaN`, returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic actual fun minOf(a: Double, vararg other: Double): Double {\n    var min = a\n    for (e in other) min = minOf(min, e)\n    return min\n}\n\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass ColorBarComponentSpec(\n    title: String,\n    val domain: ClosedRange<Double>,\n    val breaks: ScaleBreaks,\n    val scale: Scale<Color>,\n    val binCount: Int,\n    theme: LegendTheme,\n    override val layout: ColorBarComponentLayout,\n    reverse: Boolean\n) : LegendBoxSpec(title, theme, reverse) {\n\n    companion object {\n        const val DEF_NUM_BIN = 20\n\n        private const val DEF_BAR_THICKNESS = 1.0  // in 'key-size' multiples\n        private const val DEF_BAR_LENGTH = 5.0   // in 'key-size' multiples\n\n        internal fun barAbsoluteSize(horizontal: Boolean, theme: LegendTheme): DoubleVector {\n            return when {\n                horizontal -> DoubleVector(\n                    DEF_BAR_LENGTH * theme.keySize(),\n                    DEF_BAR_THICKNESS * theme.keySize()\n                )\n                else -> DoubleVector(\n                    DEF_BAR_THICKNESS * theme.keySize(),\n                    DEF_BAR_LENGTH * theme.keySize()\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * theme legend.box\n * arrangement of multiple legends (\"horizontal\" or \"vertical\")\n */\nenum class LegendArrangement {\n    HORIZONTAL,\n    VERTICAL\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.render.svg.SvgComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.presentation.Style\nimport jetbrains.datalore.vis.svg.SvgGElement\nimport jetbrains.datalore.vis.svg.SvgNode\nimport jetbrains.datalore.vis.svg.SvgRectElement\n\nabstract class LegendBox : SvgComponent() {\n\n    var debug: Boolean = false\n    abstract val spec: LegendBoxSpec\n\n    private val title: String\n        get() = spec.title\n\n    val size: DoubleVector\n        get() = spec.size\n\n    private fun hasTitle(): Boolean {\n        return spec.hasTitle()\n    }\n\n    override fun buildComponent() {\n        addClassName(Style.LEGEND)\n\n        val outerBounds = DoubleRectangle(DoubleVector.ZERO, spec.size)\n        addRectangle(spec.innerBounds, spec.theme.backgroundFill())\n//        addBorder(spec.innerBounds, OUTLINE_COLOR, 1.0)\n\n        val innerGroup = SvgGElement()\n        innerGroup.transform().set(buildTransform(spec.contentOrigin, 0.0))\n\n        val l = spec.layout\n        if (hasTitle()) {\n            val label = createTitleLabel(\n                l.titleLocation,\n                l.titleHorizontalAnchor,\n                l.titleVerticalAnchor\n            )\n            innerGroup.children().add(label.rootGroup)\n        }\n\n        val graphGroup = SvgGElement()\n        graphGroup.transform().set(buildTransform(l.graphOrigin, 0.0))\n        appendGuideContent(graphGroup)\n        innerGroup.children().add(graphGroup)\n\n        if (debug) {\n            run {\n                // outer bounds\n                addBorder(outerBounds, Color.CYAN, 1.0)\n            }\n            run {\n                // inner bounds\n                val rect = SvgRectElement(spec.innerBounds)\n                rect.fillColor().set(Color.BLACK)\n                rect.strokeWidth().set(0.0)\n                rect.fillOpacity().set(0.1)\n                add(rect)\n            }\n            run {\n                // content bounds\n                addBorder(spec.contentBounds, Color.DARK_MAGENTA, 1.0)\n            }\n            run {\n                // title bounds\n                addBorder(l.titleBounds.add(spec.contentOrigin), Color.MAGENTA, 1.0)\n            }\n        }\n\n        add(innerGroup)\n    }\n\n    protected fun addBorder(bounds: DoubleRectangle, strokeColor: Color, strokeWidth: Double) {\n        add(\n            createBorder(\n                bounds,\n                strokeColor,\n                strokeWidth\n            )\n        )\n    }\n\n    protected fun addRectangle(bounds: DoubleRectangle, fillColor: Color) {\n        add(\n            createRectangle(\n                bounds,\n                fillColor\n            )\n        )\n    }\n\n    protected abstract fun appendGuideContent(contentRoot: SvgNode): DoubleVector\n\n    private fun createTitleLabel(\n        origin: DoubleVector,\n        horizontalAnchor: TextLabel.HorizontalAnchor,\n        verticalAnchor: TextLabel.VerticalAnchor\n    ): TextLabel {\n        val label = TextLabel(title)\n        label.addClassName(Style.LEGEND_TITLE)\n        label.setHorizontalAnchor(horizontalAnchor)\n        label.setVerticalAnchor(verticalAnchor)\n        label.moveTo(origin)\n        return label\n    }\n\n    companion object {\n        fun createBorder(bounds: DoubleRectangle, strokeColor: Color, strokeWidth: Double): SvgRectElement {\n            // ToDo: to util\n            val rect = SvgRectElement(bounds)\n            rect.strokeColor().set(strokeColor)\n            rect.strokeWidth().set(strokeWidth)\n            rect.fillOpacity().set(0.0)\n            return rect\n        }\n\n        protected fun createRectangle(bounds: DoubleRectangle, fillColor: Color): SvgRectElement {\n            // ToDo: to util\n            val rect = SvgRectElement(bounds)\n            rect.fillColor().set(fillColor)\n            return rect\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\n\nabstract class LegendBoxLayout(\n    private val title: String,\n    legendDirection: LegendDirection\n) {\n\n    abstract val graphSize: DoubleVector\n    val isHorizontal = legendDirection === LegendDirection.HORIZONTAL\n    val titleHorizontalAnchor = TextLabel.HorizontalAnchor.LEFT\n    val titleVerticalAnchor = if (isHorizontal) {\n        TextLabel.VerticalAnchor.CENTER\n    } else {\n        TextLabel.VerticalAnchor.TOP\n    }\n\n    val titleBounds: DoubleRectangle\n        get() {\n            var origin = titleLocation\n            val size = titleSize(title)\n            if (isHorizontal) {\n                origin = DoubleVector(origin.x, origin.y - size.y / 2)\n            }\n            return DoubleRectangle(origin, size)\n        }\n\n    val graphOrigin: DoubleVector\n        get() = when {\n            isHorizontal ->\n                DoubleVector(titleSize(title).x, 0.0)\n            else ->\n                DoubleVector(0.0, titleSize(title).y)\n        }\n\n    val size: DoubleVector\n        get() {\n            val graphBounds = DoubleRectangle(graphOrigin, graphSize)\n            val titleAndContent = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n                .union(titleBounds)\n                .union(graphBounds)\n            return titleAndContent.dimension\n        }\n\n    val titleLocation: DoubleVector\n        get() = if (isHorizontal) {\n            val graphSize = graphSize\n            DoubleVector(0.0, graphSize.y / 2)\n        } else {\n            // make some distance from the contents\n            val y = -TITLE_SPEC.height() / 3\n            DoubleVector(0.0, y)\n        }\n\n    companion object {\n        private val TITLE_SPEC = PlotLabelSpec.LEGEND_TITLE\n        internal val LABEL_SPEC = PlotLabelSpec.LEGEND_ITEM\n\n        private fun titleSize(s: String): DoubleVector {\n            return when {\n                s.isBlank() -> DoubleVector.ZERO\n                else -> TITLE_SPEC.dimensions(s.length)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nabstract class LegendBoxSpec(\n    val title: String,\n    val theme: LegendTheme,\n    val reverse: Boolean\n) {\n\n    abstract val layout: LegendBoxLayout\n    val contentOrigin: DoubleVector\n\n    private val fullContentExtend: DoubleVector\n    private val innerOrigin: DoubleVector\n    private val innerContentExtend: DoubleVector\n\n    private val contentSize: DoubleVector\n        get() = layout.size\n\n    val size: DoubleVector\n        get() = contentSize.add(fullContentExtend)\n\n    val innerBounds: DoubleRectangle\n        get() = DoubleRectangle(innerOrigin, contentSize.add(innerContentExtend))\n\n    val contentBounds: DoubleRectangle\n        get() = DoubleRectangle(contentOrigin, contentSize)\n\n    init {\n        val contentExpand = theme.margin() + theme.padding()\n        contentOrigin = DoubleVector(contentExpand, contentExpand)\n        fullContentExtend = DoubleVector(contentExpand * 2, contentExpand * 2)\n\n        innerOrigin = DoubleVector(theme.margin(), theme.margin())\n        innerContentExtend = DoubleVector(theme.padding() * 2, theme.padding() * 2)\n    }\n\n    fun hasTitle(): Boolean {\n        return title.isNotBlank()\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StringsKt\")\n\npackage kotlin.text\n\nimport kotlin.contracts.contract\nimport kotlin.jvm.JvmName\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toUpperCase(): String\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.uppercase(): String\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.toLowerCase(): String\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic expect fun String.lowercase(): String\n\n/**\n * Returns a copy of this string having its first letter titlecased using the rules of the default locale,\n * or the original string if it's empty or already starts with a title case letter.\n *\n * The title case of a character is usually the same as its upper case with several exceptions.\n * The particular list of characters with the special title case form depends on the underlying platform.\n *\n * @sample samples.text.Strings.capitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { if (it.isLowerCase()) it.titlecase() else it.toString() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.capitalize(): String\n\n/**\n * Returns a copy of this string having its first letter lowercased using the rules of the default locale,\n * or the original string if it's empty or already starts with a lower case letter.\n *\n * @sample samples.text.Strings.decapitalize\n */\n@Deprecated(\"Use replaceFirstChar instead.\", ReplaceWith(\"replaceFirstChar { it.lowercase() }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic expect fun String.decapitalize(): String\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trim(predicate: (Char) -> Boolean): CharSequence {\n    var startIndex = 0\n    var endIndex = length - 1\n    var startFound = false\n\n    while (startIndex <= endIndex) {\n        val index = if (!startFound) startIndex else endIndex\n        val match = predicate(this[index])\n\n        if (!startFound) {\n            if (!match)\n                startFound = true\n            else\n                startIndex += 1\n        } else {\n            if (!match)\n                break\n            else\n                endIndex -= 1\n        }\n    }\n\n    return subSequence(startIndex, endIndex + 1)\n}\n\n/**\n * Returns a string having leading and trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trim(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trim(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimStart(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices)\n        if (!predicate(this[index]))\n            return subSequence(index, length)\n\n    return \"\"\n}\n\n/**\n * Returns a string having leading characters matching the [predicate] removed.\n */\npublic inline fun String.trimStart(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimStart(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters matching the [predicate] removed.\n */\npublic inline fun CharSequence.trimEnd(predicate: (Char) -> Boolean): CharSequence {\n    for (index in this.indices.reversed())\n        if (!predicate(this[index]))\n            return subSequence(0, index + 1)\n\n    return \"\"\n}\n\n/**\n * Returns a string having trailing characters matching the [predicate] removed.\n */\npublic inline fun String.trimEnd(predicate: (Char) -> Boolean): String =\n    (this as CharSequence).trimEnd(predicate).toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trim(vararg chars: Char): CharSequence = trim { it in chars }\n\n/**\n * Returns a string having leading and trailing characters from the [chars] array removed.\n */\npublic fun String.trim(vararg chars: Char): String = trim { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading characters from the [chars] array removed.\n */\npublic fun CharSequence.trimStart(vararg chars: Char): CharSequence = trimStart { it in chars }\n\n/**\n * Returns a string having leading characters from the [chars] array removed.\n */\npublic fun String.trimStart(vararg chars: Char): String = trimStart { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having trailing characters from the [chars] array removed.\n */\npublic fun CharSequence.trimEnd(vararg chars: Char): CharSequence = trimEnd { it in chars }\n\n/**\n * Returns a string having trailing characters from the [chars] array removed.\n */\npublic fun String.trimEnd(vararg chars: Char): String = trimEnd { it in chars }\n\n/**\n * Returns a sub sequence of this char sequence having leading and trailing whitespace removed.\n */\npublic fun CharSequence.trim(): CharSequence = trim(Char::isWhitespace)\n\n/**\n * Returns a string having leading and trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trim(): String = (this as CharSequence).trim().toString()\n\n/**\n * Returns a sub sequence of this char sequence having leading whitespace removed.\n */\npublic fun CharSequence.trimStart(): CharSequence = trimStart(Char::isWhitespace)\n\n/**\n * Returns a string having leading whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimStart(): String = (this as CharSequence).trimStart().toString()\n\n/**\n * Returns a sub sequence of this char sequence having trailing whitespace removed.\n */\npublic fun CharSequence.trimEnd(): CharSequence = trimEnd(Char::isWhitespace)\n\n/**\n * Returns a string having trailing whitespace removed.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.trimEnd(): String = (this as CharSequence).trimEnd().toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the beginning\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun CharSequence.padStart(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    sb.append(this)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the beginning with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string prepended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padStart\n */\npublic fun String.padStart(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padStart(length, padChar).toString()\n\n/**\n * Returns a char sequence with content of this char sequence padded at the end\n * to the specified [length] with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a char sequence of length at least [length] consisting of `this` char sequence appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun CharSequence.padEnd(length: Int, padChar: Char = ' '): CharSequence {\n    if (length < 0)\n        throw IllegalArgumentException(\"Desired length $length is less than zero.\")\n    if (length <= this.length)\n        return this.subSequence(0, this.length)\n\n    val sb = StringBuilder(length)\n    sb.append(this)\n    for (i in 1..(length - this.length))\n        sb.append(padChar)\n    return sb\n}\n\n/**\n * Pads the string to the specified [length] at the end with the specified character or space.\n *\n * @param length the desired string length.\n * @param padChar the character to pad string with, if it has length less than the [length] specified. Space is used by default.\n * @return Returns a string of length at least [length] consisting of `this` string appended with [padChar] as many times\n * as are necessary to reach that length.\n * @sample samples.text.Strings.padEnd\n */\npublic fun String.padEnd(length: Int, padChar: Char = ' '): String =\n    (this as CharSequence).padEnd(length, padChar).toString()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty.\n *\n * @sample samples.text.Strings.stringIsNullOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.length == 0\n}\n\n/**\n * Returns `true` if this char sequence is empty (contains no characters).\n *\n * @sample samples.text.Strings.stringIsEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isEmpty(): Boolean = length == 0\n\n/**\n * Returns `true` if this char sequence is not empty.\n *\n * @sample samples.text.Strings.stringIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotEmpty(): Boolean = length > 0\n\n// implemented differently in JVM and JS\n//public fun String.isBlank(): Boolean = length() == 0 || all { it.isWhitespace() }\n\n\n/**\n * Returns `true` if this char sequence is not empty and contains some characters except of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNotBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.isNotBlank(): Boolean = !isBlank()\n\n/**\n * Returns `true` if this nullable char sequence is either `null` or empty or consists solely of whitespace characters.\n *\n * @sample samples.text.Strings.stringIsNullOrBlank\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence?.isNullOrBlank(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrBlank != null)\n    }\n\n    return this == null || this.isBlank()\n}\n\n/**\n * Iterator for characters of the given char sequence.\n */\npublic operator fun CharSequence.iterator(): CharIterator = object : CharIterator() {\n    private var index = 0\n\n    public override fun nextChar(): Char = get(index++)\n\n    public override fun hasNext(): Boolean = index < length\n}\n\n/** Returns the string if it is not `null`, or the empty string otherwise. */\n@kotlin.internal.InlineOnly\npublic inline fun String?.orEmpty(): String = this ?: \"\"\n\n/**\n * Returns this char sequence if it's not empty\n * or the result of calling [defaultValue] function if the char sequence is empty.\n *\n * @sample samples.text.Strings.stringIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Returns this char sequence if it is not empty and doesn't consist solely of whitespace characters,\n * or the result of calling [defaultValue] function otherwise.\n *\n * @sample samples.text.Strings.stringIfBlank\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifBlank(defaultValue: () -> R): R where C : CharSequence, C : R =\n    if (isBlank()) defaultValue() else this\n\n/**\n * Returns the range of valid character indices for this char sequence.\n */\npublic val CharSequence.indices: IntRange\n    get() = 0..length - 1\n\n/**\n * Returns the index of the last character in the char sequence or -1 if it is empty.\n */\npublic val CharSequence.lastIndex: Int\n    get() = this.length - 1\n\n/**\n * Returns `true` if this CharSequence has Unicode surrogate pair at the specified [index].\n */\npublic fun CharSequence.hasSurrogatePairAt(index: Int): Boolean {\n    return index in 0..length - 2\n            && this[index].isHighSurrogate()\n            && this[index + 1].isLowSurrogate()\n}\n\n/**\n * Returns a substring specified by the given [range] of indices.\n */\npublic fun String.substring(range: IntRange): String = substring(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence specified by the given [range] of indices.\n */\npublic fun CharSequence.subSequence(range: IntRange): CharSequence = subSequence(range.start, range.endInclusive + 1)\n\n/**\n * Returns a subsequence of this char sequence.\n *\n * This extension is chosen only for invocation with old-named parameters.\n * Replace parameter names with the same as those of [CharSequence.subSequence].\n */\n@kotlin.internal.InlineOnly\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning\n@Deprecated(\"Use parameters named startIndex and endIndex.\", ReplaceWith(\"subSequence(startIndex = start, endIndex = end)\"))\npublic inline fun String.subSequence(start: Int, end: Int): CharSequence = subSequence(start, end)\n\n/**\n * Returns a substring of chars from a range of this char sequence starting at the [startIndex] and ending right before the [endIndex].\n *\n * @param startIndex the start index (inclusive).\n * @param endIndex the end index (exclusive). If not specified, the length of the char sequence is used.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()\n\n/**\n * Returns a substring of chars at indices from the specified [range] of this char sequence.\n */\npublic fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBefore(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the first occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfter(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring before the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringBeforeLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(0, index)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: Char, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + 1, length)\n}\n\n/**\n * Returns a substring after the last occurrence of [delimiter].\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.substringAfterLast(delimiter: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else substring(index + delimiter.length, length)\n}\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range\n * is replaced with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\npublic fun CharSequence.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n    val sb = StringBuilder()\n    sb.appendRange(this, 0, startIndex)\n    sb.append(replacement)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Replaces the part of the string at the given range with the [replacement] char sequence.\n * @param startIndex the index of the first character to be replaced.\n * @param endIndex the index of the first character after the replacement to keep in the string.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(startIndex: Int, endIndex: Int, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(startIndex, endIndex, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range]\n * is replaced with the [replacement] char sequence.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\npublic fun CharSequence.replaceRange(range: IntRange, replacement: CharSequence): CharSequence =\n    replaceRange(range.start, range.endInclusive + 1, replacement)\n\n/**\n * Replace the part of string at the given [range] with the [replacement] string.\n *\n * The end index of the [range] is included in the part to be replaced.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceRange(range: IntRange, replacement: CharSequence): String =\n    (this as CharSequence).replaceRange(range, replacement).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given range is removed.\n *\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n * [endIndex] is not included in the removed part.\n */\npublic fun CharSequence.removeRange(startIndex: Int, endIndex: Int): CharSequence {\n    if (endIndex < startIndex)\n        throw IndexOutOfBoundsException(\"End index ($endIndex) is less than start index ($startIndex).\")\n\n    if (endIndex == startIndex)\n        return this.subSequence(0, length)\n\n    val sb = StringBuilder(length - (endIndex - startIndex))\n    sb.appendRange(this, 0, startIndex)\n    sb.appendRange(this, endIndex, length)\n    return sb\n}\n\n/**\n * Removes the part of a string at a given range.\n * @param startIndex the index of the first character to be removed.\n * @param endIndex the index of the first character after the removed part to keep in the string.\n *\n *  [endIndex] is not included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(startIndex: Int, endIndex: Int): String =\n    (this as CharSequence).removeRange(startIndex, endIndex).toString()\n\n/**\n * Returns a char sequence with content of this char sequence where its part at the given [range] is removed.\n *\n * The end index of the [range] is included in the removed part.\n */\npublic fun CharSequence.removeRange(range: IntRange): CharSequence = removeRange(range.start, range.endInclusive + 1)\n\n/**\n * Removes the part of a string at the given [range].\n *\n * The end index of the [range] is included in the removed part.\n */\n@kotlin.internal.InlineOnly\npublic inline fun String.removeRange(range: IntRange): String =\n    (this as CharSequence).removeRange(range).toString()\n\n/**\n * If this char sequence starts with the given [prefix], returns a new char sequence\n * with the prefix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removePrefix(prefix: CharSequence): CharSequence {\n    if (startsWith(prefix)) {\n        return subSequence(prefix.length, length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string starts with the given [prefix], returns a copy of this string\n * with the prefix removed. Otherwise, returns this string.\n */\npublic fun String.removePrefix(prefix: CharSequence): String {\n    if (startsWith(prefix)) {\n        return substring(prefix.length)\n    }\n    return this\n}\n\n/**\n * If this char sequence ends with the given [suffix], returns a new char sequence\n * with the suffix removed. Otherwise, returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSuffix(suffix: CharSequence): CharSequence {\n    if (endsWith(suffix)) {\n        return subSequence(0, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * If this string ends with the given [suffix], returns a copy of this string\n * with the suffix removed. Otherwise, returns this string.\n */\npublic fun String.removeSuffix(suffix: CharSequence): String {\n    if (endsWith(suffix)) {\n        return substring(0, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with the given [prefix] and ends with the given [suffix],\n * returns a new char sequence having both the given [prefix] and [suffix] removed.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(prefix: CharSequence, suffix: CharSequence): CharSequence {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return subSequence(prefix.length, length - suffix.length)\n    }\n    return subSequence(0, length)\n}\n\n/**\n * Removes from a string both the given [prefix] and [suffix] if and only if\n * it starts with the [prefix] and ends with the [suffix].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {\n    if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {\n        return substring(prefix.length, length - suffix.length)\n    }\n    return this\n}\n\n/**\n * When this char sequence starts with and ends with the given [delimiter],\n * returns a new char sequence having this [delimiter] removed both from the start and end.\n * Otherwise returns a new char sequence with the same characters.\n */\npublic fun CharSequence.removeSurrounding(delimiter: CharSequence): CharSequence = removeSurrounding(delimiter, delimiter)\n\n/**\n * Removes the given [delimiter] string from both the start and the end of this string\n * if and only if it starts with and ends with the [delimiter].\n * Otherwise returns this string unchanged.\n */\npublic fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBefore(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string after the first occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfter(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = indexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + delimiter.length, length, replacement)\n}\n\n/**\n * Replace part of string after the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceAfterLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(index + 1, length, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: Char, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n/**\n * Replace part of string before the last occurrence of given delimiter with the [replacement] string.\n * If the string does not contain the delimiter, returns [missingDelimiterValue] which defaults to the original string.\n */\npublic fun String.replaceBeforeLast(delimiter: String, replacement: String, missingDelimiterValue: String = this): String {\n    val index = lastIndexOf(delimiter)\n    return if (index == -1) missingDelimiterValue else replaceRange(0, index, replacement)\n}\n\n\n// public fun String.replace(oldChar: Char, newChar: Char, ignoreCase: Boolean): String // JVM- and JS-specific\n// public fun String.replace(oldValue: String, newValue: String, ignoreCase: Boolean): String // JVM- and JS-specific\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the given [replacement].\n *\n * The [replacement] can consist of any combination of literal text and $-substitutions. To treat the replacement string\n * literally escape it with the [kotlin.text.Regex.Companion.escapeReplacement] method.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, replacement: String): String = regex.replace(this, replacement)\n\n/**\n * Returns a new string obtained by replacing each substring of this char sequence that matches the given regular expression\n * with the result of the given function [transform] that takes [MatchResult] and returns a string to be used as a\n * replacement for that match.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence): String =\n    regex.replace(this, transform)\n\n/**\n * Replaces the first occurrence of the given regular expression [regex] in this char sequence with specified [replacement] expression.\n *\n * @param replacement A replacement expression that can include substitutions. See [Regex.replaceFirst] for details.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.replaceFirst(regex: Regex, replacement: String): String = regex.replaceFirst(this, replacement)\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithChar\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> Char): String {\n    return if (isNotEmpty()) transform(this[0]) + substring(1) else this\n}\n\n/**\n * Returns a copy of this string having its first character replaced with the result of the specified [transform],\n * or the original string if it's empty.\n *\n * @param transform function that takes the first character and returns the result of the transform applied to the character.\n *\n * @sample samples.text.Strings.replaceFirstChar\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@JvmName(\"replaceFirstCharWithCharSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun String.replaceFirstChar(transform: (Char) -> CharSequence): String {\n    return if (isNotEmpty()) transform(this[0]).toString() + substring(1) else this\n}\n\n\n/**\n * Returns `true` if this char sequence matches the given regular expression.\n */\n@kotlin.internal.InlineOnly\npublic inline infix fun CharSequence.matches(regex: Regex): Boolean = regex.matches(this)\n\n/**\n * Implementation of [regionMatches] for CharSequences.\n * Invoked when it's already known that arguments are not Strings, so that no additional type checks are performed.\n */\ninternal fun CharSequence.regionMatchesImpl(thisOffset: Int, other: CharSequence, otherOffset: Int, length: Int, ignoreCase: Boolean): Boolean {\n    if ((otherOffset < 0) || (thisOffset < 0) || (thisOffset > this.length - length) || (otherOffset > other.length - length)) {\n        return false\n    }\n\n    for (index in 0 until length) {\n        if (!this[thisOffset + index].equals(other[otherOffset + index], ignoreCase))\n            return false\n    }\n    return true\n}\n\n/**\n * Returns `true` if this char sequence starts with the specified character.\n */\npublic fun CharSequence.startsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[0].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence ends with the specified character.\n */\npublic fun CharSequence.endsWith(char: Char, ignoreCase: Boolean = false): Boolean =\n    this.length > 0 && this[lastIndex].equals(char, ignoreCase)\n\n/**\n * Returns `true` if this char sequence starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix)\n    else\n        return regionMatchesImpl(0, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if a substring of this char sequence starting at the specified offset [startIndex] starts with the specified prefix.\n */\npublic fun CharSequence.startsWith(prefix: CharSequence, startIndex: Int, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && prefix is String)\n        return this.startsWith(prefix, startIndex)\n    else\n        return regionMatchesImpl(startIndex, prefix, 0, prefix.length, ignoreCase)\n}\n\n/**\n * Returns `true` if this char sequence ends with the specified suffix.\n */\npublic fun CharSequence.endsWith(suffix: CharSequence, ignoreCase: Boolean = false): Boolean {\n    if (!ignoreCase && this is String && suffix is String)\n        return this.endsWith(suffix)\n    else\n        return regionMatchesImpl(length - suffix.length, suffix, 0, suffix.length, ignoreCase)\n}\n\n\n// common prefix and suffix\n\n/**\n * Returns the longest string `prefix` such that this char sequence and [other] char sequence both start with this prefix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common prefix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonPrefixWith\n */\npublic fun CharSequence.commonPrefixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val shortestLength = minOf(this.length, other.length)\n\n    var i = 0\n    while (i < shortestLength && this[i].equals(other[i], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(i - 1) || other.hasSurrogatePairAt(i - 1)) {\n        i--\n    }\n    return subSequence(0, i).toString()\n}\n\n/**\n * Returns the longest string `suffix` such that this char sequence and [other] char sequence both end with this suffix,\n * taking care not to split surrogate pairs.\n * If this and [other] have no common suffix, returns the empty string.\n\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @sample samples.text.Strings.commonSuffixWith\n */\npublic fun CharSequence.commonSuffixWith(other: CharSequence, ignoreCase: Boolean = false): String {\n    val thisLength = this.length\n    val otherLength = other.length\n    val shortestLength = minOf(thisLength, otherLength)\n\n    var i = 0\n    while (i < shortestLength && this[thisLength - i - 1].equals(other[otherLength - i - 1], ignoreCase = ignoreCase)) {\n        i++\n    }\n    if (this.hasSurrogatePairAt(thisLength - i - 1) || other.hasSurrogatePairAt(otherLength - i - 1)) {\n        i--\n    }\n    return subSequence(thisLength - i, thisLength).toString()\n}\n\n\n// indexOfAny()\n\n/**\n * Finds the index of the first occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.indexOfAny(chars: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeIndexOf(char, startIndex)\n    }\n\n    for (index in startIndex.coerceAtLeast(0)..lastIndex) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n    return -1\n}\n\n/**\n * Finds the index of the last occurrence of any of the specified [chars] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of matched character from [chars] or -1 if none of [chars] are found.\n *\n */\npublic fun CharSequence.lastIndexOfAny(chars: CharArray, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    if (!ignoreCase && chars.size == 1 && this is String) {\n        val char = chars.single()\n        return nativeLastIndexOf(char, startIndex)\n    }\n\n\n    for (index in startIndex.coerceAtMost(lastIndex) downTo 0) {\n        val charAtIndex = get(index)\n        if (chars.any { it.equals(charAtIndex, ignoreCase) })\n            return index\n    }\n\n    return -1\n}\n\n\nprivate fun CharSequence.indexOf(other: CharSequence, startIndex: Int, endIndex: Int, ignoreCase: Boolean, last: Boolean = false): Int {\n    val indices = if (!last)\n        startIndex.coerceAtLeast(0)..endIndex.coerceAtMost(length)\n    else\n        startIndex.coerceAtMost(lastIndex) downTo endIndex.coerceAtLeast(0)\n\n    if (this is String && other is String) { // smart cast\n        for (index in indices) {\n            if (other.regionMatches(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    } else {\n        for (index in indices) {\n            if (other.regionMatchesImpl(0, this, index, other.length, ignoreCase))\n                return index\n        }\n    }\n    return -1\n}\n\nprivate fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int, ignoreCase: Boolean, last: Boolean): Pair<Int, String>? {\n    if (!ignoreCase && strings.size == 1) {\n        val string = strings.single()\n        val index = if (!last) indexOf(string, startIndex) else lastIndexOf(string, startIndex)\n        return if (index < 0) null else index to string\n    }\n\n    val indices = if (!last) startIndex.coerceAtLeast(0)..length else startIndex.coerceAtMost(lastIndex) downTo 0\n\n    if (this is String) {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatches(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    } else {\n        for (index in indices) {\n            val matchingString = strings.firstOrNull { it.regionMatchesImpl(0, this, index, it.length, ignoreCase) }\n            if (matchingString != null)\n                return index to matchingString\n        }\n    }\n\n    return null\n}\n\n/**\n * Finds the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the first occurrence of matched string from [strings] and the string matched\n * or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findAnyOf(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)\n\n/**\n * Finds the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return A pair of an index of the last occurrence of matched string from [strings] and the string matched or `null` if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.findLastAnyOf(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Pair<Int, String>? =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)\n\n/**\n * Finds the index of the first occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.indexOfAny(strings: Collection<String>, startIndex: Int = 0, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = false)?.first ?: -1\n\n/**\n * Finds the index of the last occurrence of any of the specified [strings] in this char sequence,\n * starting from the specified [startIndex] and optionally ignoring the case.\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of matched string from [strings] or -1 if none of [strings] are found.\n *\n * To avoid ambiguous results when strings in [strings] have characters in common, this method proceeds from\n * the end toward the beginning of this string, and finds at each position the first element in [strings]\n * that matches this string at that position.\n */\npublic fun CharSequence.lastIndexOfAny(strings: Collection<String>, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int =\n    findAnyOf(strings, startIndex, ignoreCase, last = true)?.first ?: -1\n\n\n// indexOf\n\n/**\n * Returns the index within this string of the first occurrence of the specified character, starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the first occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.indexOf(char: Char, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the first occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the first occurrence of [string] or `-1` if none is found.\n * @sample samples.text.Strings.indexOf\n */\npublic fun CharSequence.indexOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, length, ignoreCase)\n    else\n        nativeIndexOf(string, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified character,\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a character. By default `false`.\n * @return An index of the last occurrence of [char] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(char: Char, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        lastIndexOfAny(charArrayOf(char), startIndex, ignoreCase)\n    else\n        nativeLastIndexOf(char, startIndex)\n}\n\n/**\n * Returns the index within this char sequence of the last occurrence of the specified [string],\n * starting from the specified [startIndex].\n *\n * @param startIndex The index of character to start searching at. The search proceeds backward toward the beginning of the string.\n * @param ignoreCase `true` to ignore character case when matching a string. By default `false`.\n * @return An index of the last occurrence of [string] or -1 if none is found.\n */\npublic fun CharSequence.lastIndexOf(string: String, startIndex: Int = lastIndex, ignoreCase: Boolean = false): Int {\n    return if (ignoreCase || this !is String)\n        indexOf(string, startIndex, 0, ignoreCase, last = true)\n    else\n        nativeLastIndexOf(string, startIndex)\n}\n\n/**\n * Returns `true` if this char sequence contains the specified [other] sequence of characters as a substring.\n *\n * @param ignoreCase `true` to ignore character case when comparing strings. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(other: CharSequence, ignoreCase: Boolean = false): Boolean =\n    if (other is String)\n        indexOf(other, ignoreCase = ignoreCase) >= 0\n    else\n        indexOf(other, 0, length, ignoreCase) >= 0\n\n\n\n/**\n * Returns `true` if this char sequence contains the specified character [char].\n *\n * @param ignoreCase `true` to ignore character case when comparing characters. By default `false`.\n */\n@Suppress(\"INAPPLICABLE_OPERATOR_MODIFIER\")\npublic operator fun CharSequence.contains(char: Char, ignoreCase: Boolean = false): Boolean =\n    indexOf(char, ignoreCase = ignoreCase) >= 0\n\n/**\n * Returns `true` if this char sequence contains at least one match of the specified regular expression [regex].\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharSequence.contains(regex: Regex): Boolean = regex.containsMatchIn(this)\n\n\n// rangesDelimitedBy\n\n\nprivate class DelimitedRangesSequence(\n    private val input: CharSequence,\n    private val startIndex: Int,\n    private val limit: Int,\n    private val getNextMatch: CharSequence.(currentIndex: Int) -> Pair<Int, Int>?\n) : Sequence<IntRange> {\n\n    override fun iterator(): Iterator<IntRange> = object : Iterator<IntRange> {\n        var nextState: Int = -1 // -1 for unknown, 0 for done, 1 for continue\n        var currentStartIndex: Int = startIndex.coerceIn(0, input.length)\n        var nextSearchIndex: Int = currentStartIndex\n        var nextItem: IntRange? = null\n        var counter: Int = 0\n\n        private fun calcNext() {\n            if (nextSearchIndex < 0) {\n                nextState = 0\n                nextItem = null\n            } else {\n                if (limit > 0 && ++counter >= limit || nextSearchIndex > input.length) {\n                    nextItem = currentStartIndex..input.lastIndex\n                    nextSearchIndex = -1\n                } else {\n                    val match = input.getNextMatch(nextSearchIndex)\n                    if (match == null) {\n                        nextItem = currentStartIndex..input.lastIndex\n                        nextSearchIndex = -1\n                    } else {\n                        val (index, length) = match\n                        nextItem = currentStartIndex until index\n                        currentStartIndex = index + length\n                        nextSearchIndex = currentStartIndex + if (length == 0) 1 else 0\n                    }\n                }\n                nextState = 1\n            }\n        }\n\n        override fun next(): IntRange {\n            if (nextState == -1)\n                calcNext()\n            if (nextState == 0)\n                throw NoSuchElementException()\n            val result = nextItem as IntRange\n            // Clean next to avoid keeping reference on yielded instance\n            nextItem = null\n            nextState = -1\n            return result\n        }\n\n        override fun hasNext(): Boolean {\n            if (nextState == -1)\n                calcNext()\n            return nextState == 1\n        }\n    }\n}\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: CharArray, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex ->\n        indexOfAny(delimiters, currentIndex, ignoreCase = ignoreCase).let { if (it < 0) null else it to 1 }\n    })\n}\n\n\n/**\n * Returns a sequence of index ranges of substrings in this char sequence around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param startIndex The index to start searching delimiters from.\n *  No range having its start value less than [startIndex] is returned.\n *  [startIndex] is coerced to be non-negative and not greater than length of this string.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\nprivate fun CharSequence.rangesDelimitedBy(delimiters: Array<out String>, startIndex: Int = 0, ignoreCase: Boolean = false, limit: Int = 0): Sequence<IntRange> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" } )\n    val delimitersList = delimiters.asList()\n\n    return DelimitedRangesSequence(this, startIndex, limit, { currentIndex -> findAnyOf(delimitersList, currentIndex, ignoreCase = ignoreCase, last = false)?.let { it.first to it.second.length } })\n\n}\n\n\n// split\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and finds at each position the first element in [delimiters]\n * that matches this string at that position.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more strings to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return. Zero by default means no limit is set.\n *\n * To avoid ambiguous results when strings in [delimiters] have characters in common, this method proceeds from\n * the beginning to the end of this string, and matches at each position the first element in [delimiters]\n * that is equal to a delimiter in this instance at that position.\n */\npublic fun CharSequence.split(vararg delimiters: String, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        val delimiter = delimiters[0]\n        if (!delimiter.isEmpty()) {\n            return split(delimiter, ignoreCase, limit)\n        }\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a sequence of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.splitToSequence(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): Sequence<String> =\n    rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).map { substring(it) }\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiters].\n *\n * @param delimiters One or more characters to be used as delimiters.\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\npublic fun CharSequence.split(vararg delimiters: Char, ignoreCase: Boolean = false, limit: Int = 0): List<String> {\n    if (delimiters.size == 1) {\n        return split(delimiters[0].toString(), ignoreCase, limit)\n    }\n\n    return rangesDelimitedBy(delimiters, ignoreCase = ignoreCase, limit = limit).asIterable().map { substring(it) }\n}\n\n/**\n * Splits this char sequence to a list of strings around occurrences of the specified [delimiter].\n * This is specialized version of split which receives single non-empty delimiter and offers better performance\n *\n * @param delimiter String used as delimiter\n * @param ignoreCase `true` to ignore character case when matching a delimiter. By default `false`.\n * @param limit The maximum number of substrings to return.\n */\nprivate fun CharSequence.split(delimiter: String, ignoreCase: Boolean, limit: Int): List<String> {\n    require(limit >= 0, { \"Limit must be non-negative, but was $limit.\" })\n\n    var currentOffset = 0\n    var nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    if (nextIndex == -1 || limit == 1) {\n        return listOf(this.toString())\n    }\n\n    val isLimited = limit > 0\n    val result = ArrayList<String>(if (isLimited) limit.coerceAtMost(10) else 10)\n    do {\n        result.add(substring(currentOffset, nextIndex))\n        currentOffset = nextIndex + delimiter.length\n        // Do not search for next occurrence if we're reaching limit\n        if (isLimited && result.size == limit - 1) break\n        nextIndex = indexOf(delimiter, currentOffset, ignoreCase)\n    } while (nextIndex != -1)\n\n    result.add(substring(currentOffset, length))\n    return result\n}\n\n/**\n * Splits this char sequence around matches of the given regular expression.\n *\n * @param limit Non-negative value specifying the maximum number of substrings to return.\n * Zero by default means no limit is set.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharSequence.split(regex: Regex, limit: Int = 0): List<String> = regex.split(this, limit)\n\n/**\n * Splits this char sequence to a sequence of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lineSequence(): Sequence<String> = splitToSequence(\"\\r\\n\", \"\\n\", \"\\r\")\n\n/**\n * Splits this char sequence to a list of lines delimited by any of the following character sequences: CRLF, LF or CR.\n *\n * The lines returned do not include terminating line separators.\n */\npublic fun CharSequence.lines(): List<String> = lineSequence().toList()\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic expect fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean\n\ninternal fun CharSequence?.contentEqualsIgnoreCaseImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this.equals(other, ignoreCase = true)\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (!this[i].equals(other[i], ignoreCase = true)) {\n            return false\n        }\n    }\n\n    return true\n}\n\ninternal fun CharSequence?.contentEqualsImpl(other: CharSequence?): Boolean {\n    if (this is String && other is String) {\n        return this == other\n    }\n\n    if (this === other) return true\n    if (this == null || other == null || this.length != other.length) return false\n\n    for (i in 0 until length) {\n        if (this[i] != other[i]) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and throws an exception otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrict\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrict(): Boolean = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> throw IllegalArgumentException(\"The string doesn't represent a boolean value: $this\")\n}\n\n/**\n * Returns `true` if the content of this string is equal to the word \"true\", `false` if it is equal to \"false\",\n * and `null` otherwise.\n *\n * There is also a lenient version of the function available on nullable String, [String?.toBoolean].\n * Note that this function is case-sensitive.\n *\n * @sample samples.text.Strings.toBooleanStrictOrNull\n */\n@SinceKotlin(\"1.5\")\npublic fun String.toBooleanStrictOrNull(): Boolean? = when (this) {\n    \"true\" -> true\n    \"false\" -> false\n    else -> null\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.DataPointAesthetics\nimport jetbrains.datalore.plot.base.render.LegendKeyElementFactory\nimport jetbrains.datalore.vis.svg.SvgGElement\n\nclass LegendBreak(val label: String) {\n    private val myLayers = ArrayList<LegendBreakLayer>()\n\n    val minimumKeySize: DoubleVector\n        get() {\n            var minSize = DoubleVector.ZERO\n            for (layer in myLayers) {\n                val layerMinKeySize = layer.keyElementFactory.minimumKeySize(layer.dataPoint)\n                minSize = minSize.max(layerMinKeySize)\n            }\n            return minSize\n        }\n\n    val isEmpty: Boolean\n        get() = myLayers.isEmpty()\n\n    fun addLayer(dataPoint: DataPointAesthetics, keyElementFactory: LegendKeyElementFactory) {\n        myLayers.add(\n            LegendBreakLayer(\n                dataPoint,\n                keyElementFactory\n            )\n        )\n    }\n\n    fun createKeyElement(size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n\n        for (layer in myLayers) {\n            val keyElement = layer.keyElementFactory.createKeyElement(layer.dataPoint, size)\n            g.children().add(keyElement)\n        }\n\n        return g\n    }\n\n    private class LegendBreakLayer(\n        val dataPoint: DataPointAesthetics,\n        val keyElementFactory: LegendKeyElementFactory\n    )\n\n    companion object {\n        fun simple(\n            label: String,\n            dataPoint: DataPointAesthetics,\n            keyElementFactory: LegendKeyElementFactory\n        ): LegendBreak {\n            val br = LegendBreak(label)\n            br.addLayer(dataPoint, keyElementFactory)\n            return br\n        }\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.GroupComponent\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.vis.svg.*\n\nclass LegendComponent(\n    override val spec: LegendComponentSpec\n) : LegendBox() {\n\n    override fun appendGuideContent(contentRoot: SvgNode): DoubleVector {\n        val layout = spec.layout\n\n        val keyLabelBoxes = layout.keyLabelBoxes.iterator()\n        val labelBoxes = layout.labelBoxes.iterator()\n        for (br in spec.breaks) {\n            val keyLabelBox = keyLabelBoxes.next()\n            val labelBox = labelBoxes.next()\n            val breakElement = createBreakElement(br, layout.keySize, keyLabelBox, labelBox)\n            contentRoot.children().add(breakElement)\n        }\n        return layout.size\n    }\n\n    private fun createBreakElement(\n        br: LegendBreak,\n        keySize: DoubleVector,\n        keyLabelBox: DoubleRectangle,\n        labelBox: DoubleRectangle\n    ): SvgElement {\n        val breakComponent = GroupComponent()\n\n        // key element\n        breakComponent.add(createKeyElement(br, keySize))\n\n        // add label at position as was layout\n        val label = TextLabel(br.label)\n        label.setHorizontalAnchor(TextLabel.HorizontalAnchor.LEFT)\n        label.setVerticalAnchor(TextLabel.VerticalAnchor.CENTER)\n        label.moveTo(labelBox.origin.add(DoubleVector(0.0, labelBox.height / 2)))\n        breakComponent.add(label)\n\n        breakComponent.moveTo(keyLabelBox.origin)\n        return breakComponent.rootGroup\n    }\n\n    private fun createKeyElement(legendBreak: LegendBreak, size: DoubleVector): SvgGElement {\n        val g = SvgGElement()\n\n        val innerSize = DoubleVector(size.x - 2, size.y - 2)\n\n        val backgroundFill = spec.theme.backgroundFill()\n\n        // common background\n        val backgroundRect = SvgRectElement(1.0, 1.0, innerSize.x, innerSize.y)\n        backgroundRect.strokeWidth().set(1.0)\n        backgroundRect.strokeColor().set(backgroundFill)\n        backgroundRect.fillColor().set(backgroundFill)\n\n        g.children().add(backgroundRect)\n\n        // key\n        val keyElement = legendBreak.createKeyElement(innerSize)\n        val keyElementTransform = buildTransform(DoubleVector(1.0, 1.0), 0.0)\n        keyElement.transform().set(keyElementTransform)\n\n        g.children().add(keyElement)\n\n        // white frame\n        val frame = SvgRectElement(0.0, 0.0, size.x, size.y)\n        frame.strokeWidth().set(1.0)\n        frame.strokeColor().set(backgroundFill)\n        frame.fill().set(SvgColors.NONE)\n\n        g.children().add(frame)\n        return g\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport kotlin.math.max\n\nabstract class LegendComponentLayout(\n    title: String,\n    protected val breaks: List<LegendBreak>,\n    val keySize: DoubleVector,\n    legendDirection: LegendDirection\n) : LegendBoxLayout(title, legendDirection) {\n\n    private var myContentSize: DoubleVector? = null\n    private val myKeyLabelBoxes = ArrayList<DoubleRectangle>()\n    private val myLabelBoxes = ArrayList<DoubleRectangle>()\n\n    var isFillByRow = false\n    var rowCount = 0\n        set(rowCount) {\n            check(rowCount > 0) { \"Row count must be greater than 0, was $rowCount\" }\n            field = rowCount\n        }\n    var colCount = 0\n        set(colCount) {\n            check(colCount > 0) { \"Col count must be greater than 0, was $colCount\" }\n            field = colCount\n        }\n\n    override val graphSize: DoubleVector\n        get() {\n            ensureInited()\n            return myContentSize!!\n        }\n\n    val keyLabelBoxes: List<DoubleRectangle>\n        get() {\n            ensureInited()\n            return myKeyLabelBoxes\n        }\n\n    val labelBoxes: List<DoubleRectangle>\n        get() {\n            ensureInited()\n            return myLabelBoxes\n        }\n\n    private fun ensureInited() {\n        if (myContentSize == null) {\n            doLayout()\n        }\n    }\n\n    private fun doLayout() {\n        val labelHeight = LABEL_SPEC.height()\n        val labelLeftMargin = LABEL_SPEC.width(1) / 2\n        val labelHOffset = keySize.x + labelLeftMargin\n        val labelVOffset = (keySize.y - labelHeight) / 2\n\n        val contentOrigin = DoubleVector.ZERO\n        var breakBoxBounds: DoubleRectangle? = null\n        for (i in breaks.indices) {\n            val labelSize = labelSize(i)\n            val breakBoxSize = DoubleVector(labelHOffset + labelSize.x, keySize.y)\n            breakBoxBounds = DoubleRectangle(\n                breakBoxBounds?.let { breakBoxOrigin(i, it) } ?: contentOrigin,\n                breakBoxSize\n            )\n\n            myKeyLabelBoxes.add(breakBoxBounds)\n            myLabelBoxes.add(\n                DoubleRectangle(\n                    labelHOffset, labelVOffset,\n                    labelSize.x, labelSize.y\n                )\n            )\n        }\n\n        myContentSize = GeometryUtil.union(DoubleRectangle(contentOrigin, DoubleVector.ZERO), myKeyLabelBoxes).dimension\n    }\n\n    protected abstract fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector\n\n    protected abstract fun labelSize(index: Int): DoubleVector\n\n    private class MyHorizontal internal constructor(title: String, breaks: List<LegendBreak>, keySize: DoubleVector) :\n        LegendComponentLayout(\n            title, breaks, keySize,\n            LegendDirection.HORIZONTAL\n        ) {\n        init {\n            colCount = breaks.size\n            rowCount = 1\n        }\n\n        override fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector {\n            return DoubleVector(prevBreakBoxBounds.right, 0.0)\n        }\n\n        override fun labelSize(index: Int): DoubleVector {\n            val label = breaks[index].label\n            return DoubleVector(LABEL_SPEC.width(label.length), LABEL_SPEC.height())\n        }\n    }\n\n    private class MyHorizontalMultiRow internal constructor(\n        title: String,\n        breaks: List<LegendBreak>,\n        keySize: DoubleVector\n    ) : MyMultiRow(\n        title, breaks, keySize,\n        LegendDirection.HORIZONTAL\n    ) {\n        init {\n            colCount = breaks.size\n            rowCount = 1\n        }\n    }\n\n    private class MyVertical internal constructor(title: String, breaks: List<LegendBreak>, keySize: DoubleVector) :\n        MyMultiRow(\n            title, breaks, keySize,\n            LegendDirection.VERTICAL\n        ) {\n        init {\n            colCount = 1\n            rowCount = breaks.size\n        }\n    }\n\n    private abstract class MyMultiRow internal constructor(\n        title: String,\n        breaks: List<LegendBreak>,\n        keySize: DoubleVector,\n        legendDirection: LegendDirection\n    ) : LegendComponentLayout(title, breaks, keySize, legendDirection) {\n        private var myMaxLabelWidth = 0.0\n\n        init {\n            for (br in breaks) {\n                myMaxLabelWidth = max(myMaxLabelWidth, LABEL_SPEC.width(br.label.length))\n            }\n        }\n\n        override fun breakBoxOrigin(index: Int, prevBreakBoxBounds: DoubleRectangle): DoubleVector {\n            if (isFillByRow) {\n                return if (index % colCount == 0) {\n                    DoubleVector(0.0, prevBreakBoxBounds.bottom)\n                } else DoubleVector(prevBreakBoxBounds.right, prevBreakBoxBounds.top)\n            }\n\n            // fill by column\n            return if (index % rowCount == 0) {\n                DoubleVector(prevBreakBoxBounds.right, 0.0)\n            } else DoubleVector(prevBreakBoxBounds.left, prevBreakBoxBounds.bottom)\n\n        }\n\n        override fun labelSize(index: Int): DoubleVector {\n            return DoubleVector(myMaxLabelWidth, LABEL_SPEC.height())\n        }\n    }\n\n    companion object {\n        fun horizontal(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyHorizontal(\n                title,\n                breaks,\n                keySize\n            )\n        }\n\n        fun horizontalMultiRow(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyHorizontalMultiRow(\n                title,\n                breaks,\n                keySize\n            )\n        }\n\n        fun vertical(title: String, breaks: List<LegendBreak>, keySize: DoubleVector): LegendComponentLayout {\n            return MyVertical(\n                title,\n                breaks,\n                keySize\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\n\nclass LegendComponentSpec(\n    title: String,\n    internal val breaks: List<LegendBreak>,\n    theme: LegendTheme,\n    override val layout: LegendComponentLayout,\n    reverse: Boolean\n) : LegendBoxSpec(title, theme, reverse)\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * theme legend.direction\n * layout of items in legends (\"horizontal\" or \"vertical\")\n */\nenum class LegendDirection {\n    HORIZONTAL,\n    VERTICAL,\n    AUTO\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * anchor point for positioning legend inside plot (\"center\" or two-element numeric vector)\n */\nclass LegendJustification(val x: Double, val y: Double) {\n    companion object {\n        val CENTER = LegendJustification(0.5, 0.5)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\n/**\n * the position of legends (\"none\", \"left\", \"right\", \"bottom\", \"top\", or two-element numeric vector)\n */\nclass LegendPosition(val x: Double, val y: Double) {\n\n    val isFixed: Boolean\n        get() = this === LEFT || this === RIGHT ||\n                this === TOP || this === BOTTOM\n\n    val isHidden: Boolean\n        get() = this === NONE\n\n    val isOverlay: Boolean\n        get() = !(isFixed || isHidden)\n\n    companion object {\n        val RIGHT = LegendPosition(1.0, 0.5)\n        val LEFT = LegendPosition(0.0, 0.5)\n        val TOP = LegendPosition(0.5, 1.0)\n        val BOTTOM = LegendPosition(0.5, 1.0)\n        val NONE = LegendPosition(Double.NaN, Double.NaN)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.guide\n\nenum class Orientation(private val myValue: String) {\n    LEFT(\"LEFT\"),\n    RIGHT(\"RIGHT\"),\n    TOP(\"TOP\"),\n    BOTTOM(\"BOTTOM\");\n\n    val isHorizontal: Boolean\n        get() = this == TOP || this == BOTTOM\n\n    override fun toString(): String {\n        return \"Orientation{\" +\n                \"myValue='\" + myValue + '\\''.toString() +\n                '}'.toString()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\n\ninterface ContextualMappingProvider {\n    fun createContextualMapping(dataAccess: MappedDataAccess, dataFrame: DataFrame): ContextualMapping\n\n    companion object {\n        val NONE = object : ContextualMappingProvider {\n            override fun createContextualMapping(dataAccess: MappedDataAccess, dataFrame: DataFrame): ContextualMapping {\n                return ContextualMapping(\n                    tooltipLines = emptyList(),\n                    tooltipAnchor = null,\n                    tooltipMinWidth = null,\n                    tooltipColor = null,\n                    ignoreInvisibleTargets = false,\n                    hasGeneralTooltip = false,\n                    hasAxisTooltip = false,\n                    isCrosshairEnabled = false\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.*\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.builder.tooltip.MappingValue\nimport jetbrains.datalore.plot.builder.tooltip.TooltipLine\nimport jetbrains.datalore.plot.builder.tooltip.TooltipSpecification.TooltipProperties\nimport jetbrains.datalore.plot.builder.tooltip.ValueSource\n\nclass GeomInteraction(builder: GeomInteractionBuilder) :\n    ContextualMappingProvider {\n\n    private val myLocatorLookupSpace: LookupSpace = builder.locatorLookupSpace\n    private val myLocatorLookupStrategy: LookupStrategy = builder.locatorLookupStrategy\n    private val myTooltipLines: List<TooltipLine> = builder.tooltipLines\n    private val myTooltipProperties: TooltipProperties = builder.tooltipProperties\n    private val myIgnoreInvisibleTargets = builder.isIgnoringInvisibleTargets()\n    private val myIsCrosshairEnabled: Boolean = builder.isCrosshairEnabled\n\n    fun createLookupSpec(): LookupSpec {\n        return LookupSpec(myLocatorLookupSpace, myLocatorLookupStrategy)\n    }\n\n    override fun createContextualMapping(\n        dataAccess: MappedDataAccess,\n        dataFrame: DataFrame\n    ): ContextualMapping {\n        return createContextualMapping(\n            myTooltipLines.map(::TooltipLine),  // clone tooltip lines to not share DataContext between plots when facet is used\n                                                // (issue #247 - With facet_grid tooltip shows data from last plot on all plots)\n            dataAccess,\n            dataFrame,\n            myTooltipProperties,\n            myIgnoreInvisibleTargets,\n            myIsCrosshairEnabled\n        )\n    }\n\n    companion object {\n        // For tests\n        fun createTestContextualMapping(\n            aesListForTooltip: List<Aes<*>>,\n            axisAes: List<Aes<*>>,\n            outliers: List<Aes<*>>,\n            dataAccess: MappedDataAccess,\n            dataFrame: DataFrame,\n            userDefinedValueSources: List<ValueSource>? = null\n        ): ContextualMapping {\n            val defaultTooltipLines = GeomInteractionBuilder.defaultValueSourceTooltipLines(\n                aesListForTooltip,\n                axisAes,\n                outliers,\n                userDefinedValueSources\n            )\n            return createContextualMapping(\n                defaultTooltipLines,\n                dataAccess,\n                dataFrame,\n                TooltipProperties.NONE,\n                ignoreInvisibleTargets = false,\n                isCrosshairEnabled = false\n            )\n        }\n\n        private fun createContextualMapping(\n            tooltipLines: List<TooltipLine>,\n            dataAccess: MappedDataAccess,\n            dataFrame: DataFrame,\n            tooltipProperties: TooltipProperties,\n            ignoreInvisibleTargets: Boolean,\n            isCrosshairEnabled: Boolean\n        ): ContextualMapping {\n            val dataContext = DataContext(dataFrame = dataFrame, mappedDataAccess = dataAccess)\n\n            val mappedTooltipLines = tooltipLines.filter { line ->\n                val dataAesList = line.fields.filterIsInstance<MappingValue>()\n                dataAesList.all { mappedAes -> dataAccess.isMapped(mappedAes.aes) }\n            }\n            mappedTooltipLines.forEach { it.initDataContext(dataContext) }\n\n            val hasGeneralTooltip = mappedTooltipLines.any { line ->\n                line.fields.none(ValueSource::isOutlier)\n            }\n            val hasAxisTooltip = mappedTooltipLines.any { line ->\n                line.fields.any(ValueSource::isAxis)\n            }\n\n            return ContextualMapping(\n                mappedTooltipLines,\n                tooltipProperties.anchor,\n                tooltipProperties.minWidth,\n                tooltipProperties.color,\n                ignoreInvisibleTargets,\n                hasGeneralTooltip,\n                hasAxisTooltip,\n                isCrosshairEnabled\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy\nimport jetbrains.datalore.plot.builder.tooltip.TooltipSpecification\nimport jetbrains.datalore.plot.builder.tooltip.TooltipLine\nimport jetbrains.datalore.plot.builder.tooltip.ValueSource\nimport jetbrains.datalore.plot.builder.tooltip.MappingValue\nimport jetbrains.datalore.plot.builder.tooltip.ConstantValue\n\nclass GeomInteractionBuilder(private val mySupportedAesList: List<Aes<*>>) {\n    private var myIgnoreInvisibleTargets: Boolean = false\n    lateinit var locatorLookupSpace: LookupSpace\n        private set\n    lateinit var locatorLookupStrategy: LookupStrategy\n        private set\n    private var myAxisTooltipVisibilityFromFunctionKind: Boolean = false\n    private var myAxisTooltipVisibilityFromConfig: Boolean? = null\n    private var myAxisAesFromFunctionKind: List<Aes<*>>? = null\n    private lateinit var myTooltipAxisAes: List<Aes<*>>\n    private lateinit var myTooltipAes: List<Aes<*>>\n    private lateinit var myTooltipOutlierAesList: List<Aes<*>>\n    private var myTooltipConstantsAesList: Map<Aes<*>, Any>? = null\n    private var myUserTooltipSpec: TooltipSpecification? = null\n    private var myIsCrosshairEnabled: Boolean = false\n\n    val getAxisFromFunctionKind: List<Aes<*>>\n        get() = myAxisAesFromFunctionKind ?: emptyList()\n\n    val isAxisTooltipEnabled: Boolean\n        get() = if (myAxisTooltipVisibilityFromConfig == null)\n            myAxisTooltipVisibilityFromFunctionKind\n        else\n            myAxisTooltipVisibilityFromConfig!!\n\n    val tooltipLines: List<TooltipLine>\n        get() = prepareTooltipValueSources()\n\n    val tooltipProperties: TooltipSpecification.TooltipProperties\n        get() = myUserTooltipSpec?.tooltipProperties ?: TooltipSpecification.TooltipProperties.NONE\n\n    val isCrosshairEnabled: Boolean\n        get() = myIsCrosshairEnabled\n\n    fun showAxisTooltip(isTrue: Boolean): GeomInteractionBuilder {\n        myAxisTooltipVisibilityFromConfig = isTrue\n        return this\n    }\n\n    fun tooltipAes(aes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipAes = aes\n        return this\n    }\n\n    fun axisAes(axisAes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipAxisAes = axisAes\n        return this\n    }\n\n    fun tooltipOutliers(aes: List<Aes<*>>): GeomInteractionBuilder {\n        myTooltipOutlierAesList = aes\n        return this\n    }\n\n    fun tooltipConstants(constantsMap:  Map<Aes<*>, Any>): GeomInteractionBuilder {\n        myTooltipConstantsAesList = constantsMap\n        return this\n    }\n\n    fun tooltipLinesSpec(tooltipSpec: TooltipSpecification): GeomInteractionBuilder {\n        myUserTooltipSpec = tooltipSpec\n        return this\n    }\n\n    fun setIsCrosshairEnabled(isTrue: Boolean): GeomInteractionBuilder {\n        myIsCrosshairEnabled = isTrue\n        return this\n    }\n\n    fun multilayerLookupStrategy(): GeomInteractionBuilder {\n        locatorLookupStrategy = LookupStrategy.NEAREST\n        locatorLookupSpace = LookupSpace.XY\n        return this\n    }\n\n    fun univariateFunction(lookupStrategy: LookupStrategy): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = AES_X\n        locatorLookupStrategy = lookupStrategy\n        myAxisTooltipVisibilityFromFunctionKind = true\n        locatorLookupSpace = LookupSpace.X\n        initDefaultTooltips()\n        return this\n    }\n\n    fun bivariateFunction(area: Boolean): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = AES_XY\n\n        if (area) {\n            locatorLookupStrategy = LookupStrategy.HOVER\n            myAxisTooltipVisibilityFromFunctionKind = false\n        } else {\n            locatorLookupStrategy = LookupStrategy.NEAREST\n            myAxisTooltipVisibilityFromFunctionKind = true\n        }\n        locatorLookupSpace = LookupSpace.XY\n        initDefaultTooltips()\n        return this\n    }\n\n    fun none(): GeomInteractionBuilder {\n        myAxisAesFromFunctionKind = ArrayList(mySupportedAesList)\n        locatorLookupStrategy = LookupStrategy.NONE\n        myAxisTooltipVisibilityFromFunctionKind = true\n        locatorLookupSpace = LookupSpace.NONE\n        initDefaultTooltips()\n        return this\n    }\n\n    private fun initDefaultTooltips() {\n        myTooltipAxisAes = if (!isAxisTooltipEnabled) emptyList() else getAxisFromFunctionKind\n        myTooltipAes = mySupportedAesList - getAxisFromFunctionKind\n        myTooltipOutlierAesList = emptyList()\n    }\n\n    private fun prepareTooltipValueSources(): List<TooltipLine> {\n\n        return when {\n            myUserTooltipSpec == null -> {\n                // No user tooltip specification => use default tooltips\n                defaultValueSourceTooltipLines(\n                    myTooltipAes,\n                    myTooltipAxisAes,\n                    myTooltipOutlierAesList,\n                    userDefinedValueSources = null,\n                    constantsMap = myTooltipConstantsAesList\n                )\n            }\n            myUserTooltipSpec!!.tooltipLinePatterns == null -> {\n                // No user line patterns => use default tooltips with the given formatted valueSources\n                defaultValueSourceTooltipLines(\n                    myTooltipAes,\n                    myTooltipAxisAes,\n                    myTooltipOutlierAesList,\n                    myUserTooltipSpec!!.valueSources,\n                    myTooltipConstantsAesList\n                )\n            }\n            myUserTooltipSpec!!.tooltipLinePatterns!!.isEmpty() -> {\n                // User list is empty => not show tooltips\n                emptyList()\n            }\n            else -> {\n                // Form value sources: user list + axis + outliers\n                val geomOutliers = myTooltipOutlierAesList.toMutableList()\n\n                // Remove outlier tooltip if the mappedAes is used in the general tooltip\n                myUserTooltipSpec!!.tooltipLinePatterns!!.forEach { line ->\n                    val userDataAesList = line.fields.filterIsInstance<MappingValue>().map { it.aes }\n                    geomOutliers.removeAll(userDataAesList)\n                }\n                val axisValueSources = myTooltipAxisAes.map { aes -> MappingValue(aes, isOutlier = true, isAxis = true) }\n                val geomOutlierValueSources = geomOutliers.map { aes ->\n                    val formatted = myUserTooltipSpec!!.valueSources.filterIsInstance<MappingValue>().find { it.aes == aes }\n                    formatted?.toOutlier() ?: MappingValue(aes, isOutlier = true)\n                }\n\n                myUserTooltipSpec!!.tooltipLinePatterns!! + (axisValueSources + geomOutlierValueSources).map(TooltipLine.Companion::defaultLineForValueSource)\n            }\n        }\n    }\n\n    fun build(): GeomInteraction {\n        return GeomInteraction(this)\n    }\n\n    fun ignoreInvisibleTargets(isTrue: Boolean): GeomInteractionBuilder {\n        myIgnoreInvisibleTargets = isTrue\n        return this\n    }\n\n    fun isIgnoringInvisibleTargets(): Boolean {\n        return myIgnoreInvisibleTargets\n    }\n\n\n    companion object {\n        const val AREA_GEOM = true\n        const val NON_AREA_GEOM = false\n\n        private val AES_X = listOf(Aes.X)\n        private val AES_XY = listOf(Aes.X, Aes.Y)\n\n        fun defaultValueSourceTooltipLines(\n            aesListForTooltip: List<Aes<*>>,\n            axisAes: List<Aes<*>>,\n            outliers: List<Aes<*>>,\n            userDefinedValueSources: List<ValueSource>? = null,\n            constantsMap: Map<Aes<*>, Any>? = null\n        ): List<TooltipLine> {\n            val axisValueSources = axisAes.map { aes -> MappingValue(aes, isOutlier = true, isAxis = true) }\n            val outlierValueSources = outliers.map { aes ->\n                val userDefined = userDefinedValueSources?.filterIsInstance<MappingValue>()?.find { it.aes == aes }\n                userDefined?.toOutlier() ?: MappingValue(aes, isOutlier = true)\n            }\n            val aesValueSources = aesListForTooltip.map { aes ->\n                val userDefined = userDefinedValueSources?.filterIsInstance<MappingValue>()?.find { it.aes == aes }\n                userDefined ?: MappingValue(aes)\n            }\n            val constantValues = constantsMap?.map { (_, value) -> ConstantValue(value, format = null) } ?: emptyList()\n            return (aesValueSources + axisValueSources + outlierValueSources + constantValues).map(TooltipLine.Companion::defaultLineForValueSource)\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to entries of this map in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Any> Map<out K, V>.firstNotNullOf(transform: (Map.Entry<K, V>) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the map was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to entries of this map in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Any> Map<out K, V>.firstNotNullOfOrNull(transform: (Map.Entry<K, V>) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns a [List] containing all key-value pairs.\n */\npublic fun <K, V> Map<out K, V>.toList(): List<Pair<K, V>> {\n    if (size == 0)\n        return emptyList()\n    val iterator = entries.iterator()\n    if (!iterator.hasNext())\n        return emptyList()\n    val first = iterator.next()\n    if (!iterator.hasNext())\n        return listOf(first.toPair())\n    val result = ArrayList<Pair<K, V>>(size)\n    result.add(first.toPair())\n    do {\n        result.add(iterator.next().toPair())\n    } while (iterator.hasNext())\n    return result\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each entry of original map.\n * \n * @sample samples.collections.Maps.Transformations.flatMap\n */\npublic inline fun <K, V, R> Map<out K, V>.flatMap(transform: (Map.Entry<K, V>) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each entry of original map.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <K, V, R> Map<out K, V>.flatMap(transform: (Map.Entry<K, V>) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each entry of original map, to the given [destination].\n */\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.flatMapTo(destination: C, transform: (Map.Entry<K, V>) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each entry of original map, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.flatMapTo(destination: C, transform: (Map.Entry<K, V>) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each entry in the original map.\n * \n * @sample samples.collections.Maps.Transformations.mapToList\n */\npublic inline fun <K, V, R> Map<out K, V>.map(transform: (Map.Entry<K, V>) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each entry in the original map.\n * \n * @sample samples.collections.Maps.Transformations.mapNotNull\n */\npublic inline fun <K, V, R : Any> Map<out K, V>.mapNotNull(transform: (Map.Entry<K, V>) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each entry in the original map\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <K, V, R : Any, C : MutableCollection<in R>> Map<out K, V>.mapNotNullTo(destination: C, transform: (Map.Entry<K, V>) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each entry of the original map\n * and appends the results to the given [destination].\n */\npublic inline fun <K, V, R, C : MutableCollection<in R>> Map<out K, V>.mapTo(destination: C, transform: (Map.Entry<K, V>) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns `true` if all entries match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <K, V> Map<out K, V>.all(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if map has at least one entry.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <K, V> Map<out K, V>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one entry matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <K, V> Map<out K, V>.any(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of entries in this map.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of entries matching the given [predicate].\n */\npublic inline fun <K, V> Map<out K, V>.count(predicate: (Map.Entry<K, V>) -> Boolean): Int {\n    if (isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Performs the given [action] on each entry.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <K, V> Map<out K, V>.forEach(action: (Map.Entry<K, V>) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxBy(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first entry yielding the largest value of the given function or `null` if there are no entries.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxByOrNull(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return entries.maxByOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> Double): Double {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> Float): Float {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxOf(selector: (Map.Entry<K, V>) -> R): R {\n    return entries.maxOf(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> Double): Double? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> Float): Float? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.maxOfOrNull(selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.maxOfOrNull(selector)\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.maxOfWith(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R {\n    return entries.maxOfWith(comparator, selector)\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.maxOfWithOrNull(comparator, selector)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxWith(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first entry having the largest value according to the provided [comparator] or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.maxWithOrNull(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return entries.maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minBy(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first entry yielding the smallest value of the given function or `null` if there are no entries.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minByOrNull(selector: (Map.Entry<K, V>) -> R): Map.Entry<K, V>? {\n    return entries.minByOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> Double): Double {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> Float): Float {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minOf(selector: (Map.Entry<K, V>) -> R): R {\n    return entries.minOf(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> Double): Double? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> Float): Float? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R : Comparable<R>> Map<out K, V>.minOfOrNull(selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.minOfOrNull(selector)\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map.\n * \n * @throws NoSuchElementException if the map is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.minOfWith(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R {\n    return entries.minOfWith(comparator, selector)\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each entry in the map or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <K, V, R> Map<out K, V>.minOfWithOrNull(comparator: Comparator<in R>, selector: (Map.Entry<K, V>) -> R): R? {\n    return entries.minOfWithOrNull(comparator, selector)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <K, V> Map<out K, V>.minWith(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first entry having the smallest value according to the provided [comparator] or `null` if there are no entries.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.minWithOrNull(comparator: Comparator<in Map.Entry<K, V>>): Map.Entry<K, V>? {\n    return entries.minWithOrNull(comparator)\n}\n\n/**\n * Returns `true` if the map has no entries.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <K, V> Map<out K, V>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no entries match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <K, V> Map<out K, V>.none(predicate: (Map.Entry<K, V>) -> Boolean): Boolean {\n    if (isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each entry and returns the map itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <K, V, M : Map<out K, V>> M.onEach(action: (Map.Entry<K, V>) -> Unit): M {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each entry, providing sequential index with the entry,\n * and returns the map itself afterwards.\n * @param [action] function that takes the index of an entry and the entry itself\n * and performs the action on the entry.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : Map<out K, V>> M.onEachIndexed(action: (index: Int, Map.Entry<K, V>) -> Unit): M {\n    return apply { entries.forEachIndexed(action) }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original map returning its entries when being iterated.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.asIterable(): Iterable<Map.Entry<K, V>> {\n    return entries\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original map returning its entries when being iterated.\n */\npublic fun <K, V> Map<out K, V>.asSequence(): Sequence<Map.Entry<K, V>> {\n    return entries.asSequence()\n}\n\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.math.abs\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject MathUtil {\n\n    internal fun polygonContainsCoordinate(points: List<DoubleVector>, coord: DoubleVector): Boolean {\n        var intersectionCount = 0\n\n        for (i in 1 until points.size) {\n            val start = points[i - 1]\n            val end = points[i]\n\n            if (start.y >= coord.y && end.y >= coord.y || start.y < coord.y && end.y < coord.y) {\n                continue\n            }\n\n            val x = start.x + (coord.y - start.y) * (end.x - start.x) / (end.y - start.y)\n\n            if (x <= coord.x) {\n                intersectionCount++\n            }\n        }\n\n        return intersectionCount % 2 != 0\n    }\n\n    fun liesOnSegment(p1: DoubleVector, p2: DoubleVector, c: DoubleVector, epsilon: Double): Boolean {\n        return DoubleSegment(p1, p2).distance(c) < epsilon\n    }\n\n    internal fun areEqual(p1: DoubleVector, p2: DoubleVector, epsilon: Double): Boolean {\n        return p1.subtract(p2).length() < epsilon\n    }\n\n    internal fun areEqual(a: Double, b: Double, epsilon: Double): Boolean {\n        return abs(a - b) < epsilon\n    }\n\n    internal fun distance(p1: DoubleVector, p2: DoubleVector): Double {\n        return DoubleSegment(p1, p2).length()\n    }\n\n    internal fun subtractX(v: DoubleVector, x: Double): DoubleVector {\n        return DoubleVector(v.x - x, v.y)\n    }\n\n    internal fun addX(v: DoubleVector, x: Double): DoubleVector {\n        return DoubleVector(v.x + x, v.y)\n    }\n\n    fun leftEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.top),\n                DoubleVector(rect.left, rect.bottom)\n        )\n    }\n\n    fun topEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.top),\n                DoubleVector(rect.right, rect.top)\n        )\n    }\n\n    fun rightEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.right, rect.top),\n                DoubleVector(rect.right, rect.bottom)\n        )\n    }\n\n    fun bottomEdgeOf(rect: DoubleRectangle): DoubleSegment {\n        return DoubleSegment(\n                DoubleVector(rect.left, rect.bottom),\n                DoubleVector(rect.right, rect.bottom)\n        )\n    }\n\n\n    class ClosestPointChecker internal constructor(val target: DoubleVector) {\n        var distance = -1.0\n            private set\n        var coord: DoubleVector? = null\n            private set\n\n        constructor(x: Double, y: Double) : this(DoubleVector(x, y))\n\n        fun check(coord: DoubleVector): Boolean {\n            val cmpResult = compare(coord)\n            return cmpResult == COMPARISON_RESULT.NEW_CLOSER || cmpResult == COMPARISON_RESULT.EQUAL\n        }\n\n        fun compare(coord: DoubleVector): COMPARISON_RESULT {\n            val newDistance = distance(target, coord)\n            if (distance < 0) {\n                setNewClosestCoord(coord, newDistance)\n                return COMPARISON_RESULT.NEW_CLOSER\n            }\n\n            if (distance < newDistance) {\n                return COMPARISON_RESULT.NEW_FARTHER\n            }\n\n            if (distance == newDistance) {\n                return COMPARISON_RESULT.EQUAL\n            }\n\n            setNewClosestCoord(coord, newDistance)\n            return COMPARISON_RESULT.NEW_CLOSER\n        }\n\n        private fun setNewClosestCoord(coord: DoubleVector, distance: Double) {\n            this.distance = distance\n            this.coord = coord\n        }\n\n        enum class COMPARISON_RESULT {\n            NEW_CLOSER,\n            NEW_FARTHER,\n            EQUAL\n        }\n    }\n\n    class DoubleRange private constructor(private val myStart: Double, private val myLength: Double) {\n\n        init {\n            if (myLength < 0) {\n                throw IllegalStateException(\"Length should be positive\")\n            }\n        }\n\n        fun length(): Double {\n            return myLength\n        }\n\n        fun overlaps(v: DoubleRange): Boolean {\n            return start() <= v.end() && v.start() <= end()\n        }\n\n        fun inside(v: DoubleRange): Boolean {\n            return start() >= v.start() && end() <= v.end()\n        }\n\n        operator fun contains(value: Double): Boolean {\n            return value >= start() && value <= end()\n        }\n\n        fun start(): Double {\n            return myStart\n        }\n\n        fun end(): Double {\n            return myStart + length()\n        }\n\n        fun move(delta: Double): DoubleRange {\n            return withStartAndLength(\n                start() + delta,\n                length()\n            )\n        }\n\n        fun moveLeft(delta: Double): DoubleRange {\n            if (delta < 0) {\n                throw IllegalStateException(\"Value should be positive\")\n            }\n\n            return withStartAndLength(\n                start() - delta,\n                length()\n            )\n        }\n\n        fun moveRight(delta: Double): DoubleRange {\n            if (delta < 0) {\n                throw IllegalStateException(\"Value should be positive\")\n            }\n\n            return withStartAndLength(\n                start() + delta,\n                length()\n            )\n        }\n\n        companion object {\n            fun withStartAndEnd(start: Double, end: Double): DoubleRange {\n                val rangeStart = min(start, end)\n                val rangeLength = max(start, end) - rangeStart\n                return DoubleRange(rangeStart, rangeLength)\n            }\n\n            fun withStartAndLength(start: Double, length: Double): DoubleRange {\n                return DoubleRange(start, length)\n            }\n        }\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TooltipAnchor\n\nclass TooltipSpec(\n    val layoutHint: TipLayoutHint,\n    lines: List<Line>,\n    val fill: Color,\n    val isOutlier: Boolean,\n    val anchor: TooltipAnchor? = null,\n    val minWidth: Double? = null,\n    val isCrosshairEnabled: Boolean = false\n) {\n    val lines: List<Line> = ArrayList(lines)\n\n    override fun toString(): String {\n        return \"TooltipSpec($layoutHint, lines=${lines.map(Line::toString)})\"\n    }\n\n    class Line(val label: String?, val value: String) {\n        override fun toString(): String {\n            return if (label.isNullOrEmpty()) value else \"${label}: $value\"\n        }\n\n        companion object {\n            fun withValue(value: String) = Line(label = null, value = value)\n            fun withLabelAndValue(label: String?, value: String) = Line(label, value)\n        }\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_RADIUS\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_TOOLTIP_COLOR\n\nclass TooltipSpecFactory(\n    private val contextualMapping: ContextualMapping,\n    private val axisOrigin: DoubleVector\n) {\n    fun create(geomTarget: GeomTarget): List<TooltipSpec> {\n        return ArrayList(Helper(geomTarget).createTooltipSpecs())\n    }\n\n    private inner class Helper(private val myGeomTarget: GeomTarget) {\n        private val myDataPoints = contextualMapping.getDataPoints(hitIndex())\n        private val myTooltipAnchor = contextualMapping.tooltipAnchor\n        private val myTooltipMinWidth = contextualMapping.tooltipMinWidth\n        private val myTooltipColor = contextualMapping.tooltipColor\n        private val myIsCrosshairEnabled = contextualMapping.isCrosshairEnabled\n\n        internal fun createTooltipSpecs(): List<TooltipSpec> {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            tooltipSpecs += outlierTooltipSpec()\n            tooltipSpecs += generalTooltipSpec()\n            tooltipSpecs += axisTooltipSpec()\n            return tooltipSpecs\n        }\n\n        private fun hitIndex(): Int {\n            return myGeomTarget.hitIndex\n        }\n\n        private fun tipLayoutHint(): TipLayoutHint {\n            return myGeomTarget.tipLayoutHint\n        }\n\n        private fun outlierHints(): Map<Aes<*>, TipLayoutHint> {\n            return myGeomTarget.aesTipLayoutHints\n        }\n\n        private fun hintColors(): Map<Aes<*>, Color?> {\n            return myGeomTarget.aesTipLayoutHints.map { it.key to it.value.color }.toMap()\n        }\n\n        private fun outlierTooltipSpec(): List<TooltipSpec> {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            val outlierDataPoints = outlierDataPoints()\n            outlierHints().forEach { (aes, hint) ->\n                val linesForAes = outlierDataPoints\n                    .filter { aes == it.aes }\n                    .map(DataPoint::value)\n                    .map(TooltipSpec.Line.Companion::withValue)\n                if (linesForAes.isNotEmpty()) {\n                    tooltipSpecs.add(\n                        TooltipSpec(\n                            layoutHint = hint,\n                            lines = linesForAes,\n                            fill = hint.color ?: tipLayoutHint().color!!,\n                            isOutlier = true\n                        )\n                    )\n                }\n            }\n            return tooltipSpecs\n        }\n\n\n        private fun axisTooltipSpec(): List<TooltipSpec>  {\n            val tooltipSpecs = ArrayList<TooltipSpec>()\n            val axis = mapOf(\n                Aes.X to axisDataPoints().filter { Aes.X == it.aes }.map(DataPoint::value).map(TooltipSpec.Line.Companion::withValue),\n                Aes.Y to axisDataPoints().filter { Aes.Y == it.aes }.map(DataPoint::value).map(TooltipSpec.Line.Companion::withValue)\n            )\n            axis.forEach { (aes, lines) ->\n                if (lines.isNotEmpty()) {\n                    val layoutHint = createHintForAxis(aes)\n                    tooltipSpecs.add(\n                        TooltipSpec(\n                            layoutHint = layoutHint,\n                            lines = lines,\n                            fill = layoutHint.color!!,\n                            isOutlier = true\n                        )\n                    )\n                }\n            }\n            return tooltipSpecs\n        }\n\n        private fun generalTooltipSpec(): List<TooltipSpec> {\n            val generalDataPoints = generalDataPoints()\n            val generalLines = generalDataPoints.map { TooltipSpec.Line.withLabelAndValue(it.label, it.value) }\n            val aesHintColors = hintColors()\n                .filterKeys { aes -> aes in generalDataPoints.map { it.aes } }\n            val colorFromHints = aesHintColors[Aes.Y] ?: aesHintColors.mapNotNull { it.value }.lastOrNull()\n            val tooltipColor = when {\n                myTooltipColor != null -> myTooltipColor\n                colorFromHints != null -> colorFromHints\n                else -> tipLayoutHint().color!!\n            }\n            return if (generalLines.isNotEmpty()) {\n                listOf(\n                    TooltipSpec(\n                        tipLayoutHint(),\n                        lines = generalLines,\n                        fill = tooltipColor,\n                        isOutlier = false,\n                        anchor = myTooltipAnchor,\n                        minWidth = myTooltipMinWidth,\n                        isCrosshairEnabled = myIsCrosshairEnabled\n                    )\n                )\n            } else {\n                emptyList()\n            }\n        }\n\n        private fun outlierDataPoints(): List<DataPoint> {\n            return myDataPoints.filter { it.isOutlier && !it.isAxis }\n        }\n\n        private fun axisDataPoints(): List<DataPoint> {\n            return myDataPoints.filter(DataPoint::isAxis)\n        }\n\n        private fun generalDataPoints(): List<DataPoint> {\n            val nonOutlierDataPoints = myDataPoints.filterNot(DataPoint::isOutlier)\n            val outliers = outlierDataPoints().mapNotNull(DataPoint::aes)\n            val generalAesList = nonOutlierDataPoints.mapNotNull(DataPoint::aes) - outliers\n            return nonOutlierDataPoints.filter { dataPoint ->\n                when (dataPoint.aes){\n                    null -> true                // get all not aes (variables, text)\n                    in generalAesList -> true   // get all existed in prepared aes list (mapped aes)\n                    else -> false               // skip others (axis)\n                }\n            }\n        }\n\n        private fun createHintForAxis(aes: Aes<*>): TipLayoutHint {\n            return when(aes) {\n                 Aes.X -> TipLayoutHint.xAxisTooltip(\n                     coord = DoubleVector(tipLayoutHint().coord!!.x, axisOrigin.y),\n                     color = AXIS_TOOLTIP_COLOR,\n                     axisRadius = AXIS_RADIUS\n                 )\n                Aes.Y -> TipLayoutHint.yAxisTooltip(\n                    coord = DoubleVector(axisOrigin.x, tipLayoutHint().coord!!.y),\n                    color = AXIS_TOOLTIP_COLOR,\n                    axisRadius = AXIS_RADIUS\n                )\n                else -> error(\"Not an axis aes: $aes\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.CoordinateSystem\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.*\n\nclass LayerTargetCollectorWithLocator(\n    private val geomKind: GeomKind,\n    private val lookupSpec: GeomTargetLocator.LookupSpec,\n    private val contextualMapping: ContextualMapping,\n    private val coordinateSystem: CoordinateSystem\n) : GeomTargetCollector, GeomTargetLocator {\n\n    private val myTargets = ArrayList<TargetPrototype>()\n    private var myLocator: GeomTargetLocator? = null\n\n    override fun addPoint(\n        index: Int,\n        point: DoubleVector,\n        radius: Double,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (contextualMapping.ignoreInvisibleTargets) {\n            if (radius == 0.0 || tooltipParams.getColor().alpha == 0) {\n                return;\n            }\n        }\n        if (!coordinateSystem.isPointInLimits(point)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.point(point, radius),\n                { index },\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addRectangle(\n        index: Int,\n        rectangle: DoubleRectangle,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (contextualMapping.ignoreInvisibleTargets) {\n            if (rectangle.width == 0.0 || rectangle.height == 0.0 || tooltipParams.getColor().alpha == 0) {\n                return\n            }\n        }\n        if (!coordinateSystem.isRectInLimits(rectangle)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.rect(rectangle),\n                { index },\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addPath(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (!coordinateSystem.isPathInLimits(points)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.path(points),\n                localToGlobalIndex,\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    override fun addPolygon(\n        points: List<DoubleVector>,\n        localToGlobalIndex: (Int) -> Int,\n        tooltipParams: GeomTargetCollector.TooltipParams,\n        tooltipKind: TipLayoutHint.Kind\n    ) {\n        if (!coordinateSystem.isPolygonInLimits(points)) {\n            return\n        }\n        addTarget(\n            TargetPrototype(\n                HitShape.polygon(points),\n                localToGlobalIndex,\n                tooltipParams,\n                tooltipKind\n            )\n        )\n    }\n\n    private fun addTarget(targetPrototype: TargetPrototype) {\n        myTargets.add(targetPrototype)\n        myLocator = null\n    }\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        if (myLocator == null) {\n            myLocator = LayerTargetLocator(\n                geomKind,\n                lookupSpec,\n                contextualMapping,\n                myTargets\n            )\n        }\n        return myLocator!!.search(coord)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkArgument\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.ContextualMapping\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.HitShape.Kind.*\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.CURSOR_TOOLTIP\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker\nimport kotlin.math.max\n\ninternal class LayerTargetLocator(\n    private val geomKind: GeomKind,\n    private val lookupSpec: GeomTargetLocator.LookupSpec,\n    private val contextualMapping: ContextualMapping,\n    targetPrototypes: List<TargetPrototype>\n) :\n    GeomTargetLocator {\n\n    private val myTargets = ArrayList<Target>()\n    private val myTargetDetector: TargetDetector =\n        TargetDetector(lookupSpec.lookupSpace, lookupSpec.lookupStrategy)\n\n    private val mySimpleGeometry = setOf(GeomKind.RECT, GeomKind.POLYGON)\n\n    private val myCollectingStrategy: Collector.CollectingStrategy =\n        when {\n            geomKind in mySimpleGeometry -> {\n                // fix overlapping tooltips under cursor\n                Collector.CollectingStrategy.REPLACE\n            }\n            lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.X && lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.NEAREST -> {\n                // collect all with a minimum distance from cursor\n                Collector.CollectingStrategy.APPEND_IF_EQUAL\n            }\n            lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.X -> {\n                Collector.CollectingStrategy.APPEND\n            }\n            lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.HOVER -> {\n                Collector.CollectingStrategy.APPEND\n            }\n            lookupSpec.lookupStrategy === GeomTargetLocator.LookupStrategy.NONE || lookupSpec.lookupSpace === GeomTargetLocator.LookupSpace.NONE -> {\n                Collector.CollectingStrategy.IGNORE\n            }\n            else -> {\n                Collector.CollectingStrategy.REPLACE\n            }\n        }\n\n    init {\n        fun toProjection(prototype: TargetPrototype): TargetProjection {\n            return when (prototype.hitShape.kind) {\n                POINT -> PointTargetProjection.create(\n                    prototype.hitShape.point.center,\n                    lookupSpec.lookupSpace\n                )\n\n                RECT -> RectTargetProjection.create(\n                    prototype.hitShape.rect,\n                    lookupSpec.lookupSpace\n                )\n\n                POLYGON -> PolygonTargetProjection.create(\n                    prototype.hitShape.points,\n                    lookupSpec.lookupSpace\n                )\n\n                PATH -> PathTargetProjection.create(\n                    prototype.hitShape.points,\n                    prototype.indexMapper,\n                    lookupSpec.lookupSpace\n                )\n            }\n        }\n\n        for (prototype in targetPrototypes) {\n            myTargets.add(\n                Target(\n                    toProjection(prototype),\n                    prototype\n                )\n            )\n        }\n    }\n\n    private fun addLookupResults(\n        collector: Collector<GeomTarget>,\n        targets: MutableList<GeomTargetLocator.LookupResult>\n    ) {\n        if (collector.size() == 0) {\n            return\n        }\n\n        targets.add(\n            GeomTargetLocator.LookupResult(\n                collector.collection(),\n                // Distance can be negative when lookup space is X\n                // In this case use 0.0 as a distance - we have a direct hit.\n                max(0.0, collector.closestPointChecker.distance),\n                geomKind,\n                contextualMapping,\n                contextualMapping.isCrosshairEnabled\n            )\n        )\n    }\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        if (myTargets.isEmpty()) {\n            return null\n        }\n\n        val rectCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n        val pointCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n        val pathCollector = Collector<GeomTarget>(\n            coord,\n            myCollectingStrategy,\n            lookupSpec.lookupSpace\n        )\n\n        // Should always replace because of polygon with holes - only top should have tooltip.\n        val polygonCollector = Collector<GeomTarget>(\n            coord,\n            Collector.CollectingStrategy.REPLACE,\n            lookupSpec.lookupSpace\n        )\n\n        for (target in myTargets) {\n            when (target.prototype.hitShape.kind) {\n                RECT -> processRect(coord, target, rectCollector)\n\n                POINT -> processPoint(coord, target, pointCollector)\n\n                PATH -> processPath(coord, target, pathCollector)\n\n                POLYGON -> processPolygon(coord, target, polygonCollector)\n            }\n        }\n\n        val lookupResults = ArrayList<GeomTargetLocator.LookupResult>()\n\n        addLookupResults(pathCollector, lookupResults)\n        addLookupResults(rectCollector, lookupResults)\n        addLookupResults(pointCollector, lookupResults)\n        addLookupResults(polygonCollector, lookupResults)\n\n        return getClosestTarget(lookupResults)\n    }\n\n    private fun getClosestTarget(lookupResults: List<GeomTargetLocator.LookupResult>): GeomTargetLocator.LookupResult? {\n        if (lookupResults.isEmpty()) {\n            return null\n        }\n\n        var closestTargets: GeomTargetLocator.LookupResult = lookupResults[0]\n        require(closestTargets.distance >= 0)\n\n        for (lookupResult in lookupResults) {\n            if (lookupResult.distance < closestTargets.distance) {\n                closestTargets = lookupResult\n            }\n        }\n        return closestTargets\n    }\n\n    private fun processRect(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkRect(coord, target.rectProjection, resultCollector.closestPointChecker)) {\n\n            val rect = target.prototype.hitShape.rect\n            val yOffset = when (target.prototype.tooltipKind) {\n                CURSOR_TOOLTIP -> rect.height / 2.0\n                else -> 0.0\n            }\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    rect.origin.add(DoubleVector(rect.width / 2, yOffset)),\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPolygon(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkPolygon(coord, target.polygonProjection, resultCollector.closestPointChecker)) {\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    coord,\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPoint(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        if (myTargetDetector.checkPoint(coord, target.pointProjection, resultCollector.closestPointChecker)) {\n\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    target.prototype.hitShape.point.center,\n                    getKeyForSingleObjectGeometry(target.prototype)\n                )\n            )\n        }\n    }\n\n    private fun processPath(coord: DoubleVector, target: Target, resultCollector: Collector<GeomTarget>) {\n        // When searching single point from all targets (REPLACE) - should search nearest projection between every path target.\n        // When searching points for every target (APPEND) - should reset nearest point between every path target.\n        val pointChecker = if (myCollectingStrategy == Collector.CollectingStrategy.APPEND)\n            ClosestPointChecker(coord)\n        else\n            resultCollector.closestPointChecker\n\n        val hitPoint = myTargetDetector.checkPath(coord, target.pathProjection, pointChecker)\n        if (hitPoint != null) {\n            resultCollector.collect(\n                target.prototype.createGeomTarget(\n                    hitPoint.originalCoord,\n                    hitPoint.index\n                )\n            )\n        }\n    }\n\n    private fun getKeyForSingleObjectGeometry(prototype: TargetPrototype): Int {\n        return prototype.indexMapper(0)\n    }\n\n    internal class Target(private val targetProjection: TargetProjection, val prototype: TargetPrototype) {\n\n        val pointProjection: PointTargetProjection\n            get() = targetProjection as PointTargetProjection\n\n        val rectProjection: RectTargetProjection\n            get() = targetProjection as RectTargetProjection\n\n        val polygonProjection: PolygonTargetProjection\n            get() = targetProjection as PolygonTargetProjection\n\n        val pathProjection: PathTargetProjection\n            get() = targetProjection as PathTargetProjection\n    }\n\n    internal class Collector<T>(\n        cursor: DoubleVector,\n        private val myStrategy: CollectingStrategy,\n        lookupSpace: GeomTargetLocator.LookupSpace\n    ) {\n        private val result = ArrayList<T>()\n        val closestPointChecker: ClosestPointChecker = if (lookupSpace == GeomTargetLocator.LookupSpace.X) {\n            ClosestPointChecker(DoubleVector(cursor.x, 0.0))\n        } else {\n            ClosestPointChecker(cursor)\n        }\n        private var myLastAddedDistance: Double = -1.0\n\n        fun collect(data: T) {\n            when (myStrategy) {\n                CollectingStrategy.APPEND -> add(data)\n                CollectingStrategy.REPLACE -> replace(data)\n                CollectingStrategy.APPEND_IF_EQUAL -> {\n                    if (myLastAddedDistance == closestPointChecker.distance) {\n                        add(data)\n                    } else {\n                        replace(data)\n                    }\n                }\n                CollectingStrategy.IGNORE -> return\n            }\n        }\n\n        fun collection(): List<T> {\n            return result\n        }\n\n        fun size(): Int {\n            return result.size\n        }\n\n        private fun add(data: T) {\n            result.add(data)\n            myLastAddedDistance = closestPointChecker.distance\n        }\n\n        private fun replace(locationData: T) {\n            result.clear()\n            result.add(locationData)\n            myLastAddedDistance = closestPointChecker.distance\n        }\n\n        internal enum class CollectingStrategy {\n            APPEND,\n            REPLACE,\n            APPEND_IF_EQUAL,\n            IGNORE\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.GeomKind\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult\nimport jetbrains.datalore.plot.builder.interact.MathUtil\nimport kotlin.math.abs\n\ninternal class LocatedTargetsPicker {\n    private val myPicked = ArrayList<LookupResult>()\n    private var myMinDistance = 0.0\n    private val myAllLookupResults = ArrayList<LookupResult>()\n\n    val picked: List<LookupResult>\n        get() = chooseBestResult()\n\n    fun addLookupResult(result: LookupResult, coord: DoubleVector? = null) {\n        val lookupResult = filterResults(result, coord)\n\n        val distance = distance(lookupResult, coord)\n        if (!lookupResult.isCrosshairEnabled && distance > CUTOFF_DISTANCE) {\n            return\n        }\n\n        when {\n            myPicked.isEmpty() || myMinDistance > distance -> {\n                myPicked.clear()\n                myPicked.add(lookupResult)\n                myMinDistance = distance\n            }\n            myMinDistance == distance && isSameUnivariateGeom(myPicked[0], lookupResult) -> {\n                myPicked.add(lookupResult)\n            }\n            myMinDistance == distance -> {\n                myPicked.clear()\n                myPicked.add(lookupResult)\n            }\n        }\n        myAllLookupResults.add(lookupResult)\n    }\n\n    private fun chooseBestResult(): List<LookupResult> {\n        fun hasGeneralTooltip(lookupResult: LookupResult) = lookupResult.contextualMapping.hasGeneralTooltip\n        fun hasAxisTooltip(lookupResult: LookupResult): Boolean {\n            return lookupResult.contextualMapping.hasAxisTooltip ||\n                    // actually hline/vline have axis info in the general tooltip\n                    lookupResult.geomKind in listOf(GeomKind.V_LINE, GeomKind.H_LINE)\n        }\n\n        return when {\n            myPicked.any { hasGeneralTooltip(it) && hasAxisTooltip(it) } -> myPicked\n            myAllLookupResults.none { hasGeneralTooltip(it) } -> myPicked\n            myAllLookupResults.any { hasGeneralTooltip(it) && hasAxisTooltip(it) } -> {\n                listOf(myAllLookupResults.last { hasGeneralTooltip(it) && hasAxisTooltip(it) })\n            }\n            else -> {\n                val withGeneralTooltip = myAllLookupResults.lastOrNull { hasGeneralTooltip(it) }\n                val withAxisTooltip = myAllLookupResults.lastOrNull { hasAxisTooltip(it) }\n                listOfNotNull(withGeneralTooltip, withAxisTooltip)\n            }\n        }\n    }\n\n    companion object {\n        internal const val CUTOFF_DISTANCE = 30.0\n        internal const val FAKE_DISTANCE = 15.0\n        private val UNIVARIATE_GEOMS = listOf(\n            GeomKind.DENSITY,\n            GeomKind.FREQPOLY,\n            GeomKind.BOX_PLOT,\n            GeomKind.HISTOGRAM,\n            GeomKind.LINE,\n            GeomKind.AREA,\n            GeomKind.BAR,\n            GeomKind.ERROR_BAR,\n            GeomKind.CROSS_BAR,\n            GeomKind.LINE_RANGE,\n            GeomKind.POINT_RANGE\n        )\n\n        private val UNIVARIATE_LINES = listOf(\n            GeomKind.DENSITY,\n            GeomKind.FREQPOLY,\n            GeomKind.LINE,\n            GeomKind.AREA,\n            GeomKind.SEGMENT\n        )\n\n        private fun distance(locatedTargetList: LookupResult, coord: DoubleVector?): Double {\n            val distance = locatedTargetList.distance\n            // Special case for geoms like histogram, when mouse inside a rect or only X projection is used (so a distance\n            // between cursor is zero). Fake the distance to give a chance for tooltips from other layers.\n            return if (distance == 0.0) {\n                if (!locatedTargetList.isCrosshairEnabled || coord == null) {\n                    FAKE_DISTANCE\n                } else {\n                    // use XY distance for tooltips with crosshair to avoid giving them priority\n                    locatedTargetList.targets\n                        .filter { it.tipLayoutHint.coord != null }\n                        .map { target -> MathUtil.distance(coord, target.tipLayoutHint.coord!!) }\n                        .minOrNull()\n                        ?: FAKE_DISTANCE\n                }\n            } else {\n                distance\n            }\n        }\n\n        private fun isSameUnivariateGeom(lft: LookupResult, rgt: LookupResult): Boolean {\n            return lft.geomKind === rgt.geomKind && UNIVARIATE_GEOMS.contains(rgt.geomKind)\n        }\n\n        private fun filterResults(lookupResult: LookupResult, coord: DoubleVector?): LookupResult {\n            if (coord == null || lookupResult.geomKind !in UNIVARIATE_LINES) {\n                return lookupResult\n            }\n\n            // Get closest targets and remove duplicates\n            val geomTargets = lookupResult.targets.filter { it.tipLayoutHint.coord != null }\n\n            val minXToTarget = geomTargets\n                .map { target -> target.tipLayoutHint.coord!!.subtract(coord).x }\n                .minByOrNull { abs(it) }\n\n            val newTargets = geomTargets\n                .filter { target ->\n                    target.tipLayoutHint.coord!!.subtract(coord).x == minXToTarget\n                }\n                .distinctBy { it.hitIndex }\n\n            return LookupResult(\n                targets = newTargets,\n                distance = lookupResult.distance,\n                geomKind = lookupResult.geomKind,\n                contextualMapping = lookupResult.contextualMapping,\n                isCrosshairEnabled = lookupResult.isCrosshairEnabled\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy\nimport jetbrains.datalore.plot.builder.interact.MathUtil\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker\nimport jetbrains.datalore.plot.builder.interact.MathUtil.ClosestPointChecker.COMPARISON_RESULT\nimport jetbrains.datalore.plot.builder.interact.MathUtil.DoubleRange\nimport jetbrains.datalore.plot.builder.interact.loc.PathTargetProjection.PathPoint\n\ninternal class TargetDetector(\n        private val locatorLookupSpace: LookupSpace,\n        private val locatorLookupStrategy: LookupStrategy\n) {\n    fun checkPath(cursorCoord: DoubleVector, pathProjection: PathTargetProjection, closestPointChecker: ClosestPointChecker): PathPoint? {\n\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                if (locatorLookupStrategy === LookupStrategy.NONE) {\n                    return null\n                }\n\n                val pathPoints = pathProjection.points\n                if (pathPoints.isEmpty()) {\n                    return null\n                }\n\n                val resultIndex = binarySearch(\n                    cursorCoord.x,\n                    pathPoints.size\n                ) { index ->\n                    pathPoints[index].projection().x()\n                }\n                val bestPoint = pathPoints[resultIndex]\n\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> {\n                        if (cursorCoord.x < pathPoints[0].projection().x() || cursorCoord.x > pathPoints[pathPoints.size - 1].projection().x()) {\n                            null\n                        } else bestPoint\n                    }\n\n                    LookupStrategy.NEAREST -> bestPoint\n\n                    else -> throw IllegalStateException(\"Unknown lookup strategy: $locatorLookupStrategy\")\n                }\n            }\n\n            LookupSpace.XY -> {\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER -> {\n                        for (pathPoint in pathProjection.points) {\n                            val targetPointCoord = pathPoint.projection().xy()\n                            if (MathUtil.areEqual(targetPointCoord, cursorCoord,\n                                    POINT_AREA_EPSILON\n                                )) {\n                                return pathPoint\n                            }\n                        }\n                        return null\n                    }\n\n                    LookupStrategy.NEAREST -> {\n                        var nearestPoint: PathPoint? = null\n                        for (pathPoint in pathProjection.points) {\n                            val targetPointCoord = pathPoint.projection().xy()\n                            if (closestPointChecker.check(targetPointCoord)) {\n                                nearestPoint = pathPoint\n                            }\n                        }\n                        return nearestPoint\n                    }\n\n                    LookupStrategy.NONE -> return null\n                }\n            }\n\n            LookupSpace.NONE -> return null\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkPoint(cursorCoord: DoubleVector, pointProjection: PointTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val x = pointProjection.x()\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> MathUtil.areEqual(x, cursorCoord.x,\n                        POINT_AREA_EPSILON\n                    )\n                    LookupStrategy.NEAREST -> {\n                        closestPointChecker.check(DoubleVector(x, 0.0))\n                    }\n                    LookupStrategy.NONE -> false\n                }\n            }\n\n            LookupSpace.XY -> {\n                val targetPointCoord = pointProjection.xy()\n                return when (locatorLookupStrategy) {\n                    LookupStrategy.HOVER -> MathUtil.areEqual(targetPointCoord, cursorCoord, POINT_AREA_EPSILON)\n                    LookupStrategy.NEAREST -> closestPointChecker.check(targetPointCoord)\n                    LookupStrategy.NONE -> false\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkRect(cursorCoord: DoubleVector, rectProjection: RectTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val range = rectProjection.x()\n                return rangeBasedLookup(cursorCoord, closestPointChecker, range)\n            }\n\n            LookupSpace.XY -> {\n                val rect = rectProjection.xy()\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER -> return rect.contains(cursorCoord)\n\n                    LookupStrategy.NEAREST -> {\n                        if (rect.contains(cursorCoord)) {\n                            return closestPointChecker.check(cursorCoord)\n                        }\n\n                        var x = if (cursorCoord.x < rect.left) rect.left else rect.right\n                        var y = if (cursorCoord.y < rect.top) rect.top else rect.bottom\n\n                        x = if (rect.xRange().contains(cursorCoord.x)) cursorCoord.x else x\n                        y = if (rect.yRange().contains(cursorCoord.y)) cursorCoord.y else y\n\n                        return closestPointChecker.check(DoubleVector(x, y))\n                    }\n\n                    LookupStrategy.NONE -> return false\n\n                    else -> throw IllegalStateException()\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    fun checkPolygon(cursorCoord: DoubleVector, polygonProjection: PolygonTargetProjection, closestPointChecker: ClosestPointChecker): Boolean {\n        when (locatorLookupSpace) {\n\n            LookupSpace.X -> {\n                val range = polygonProjection.x()\n                return rangeBasedLookup(cursorCoord, closestPointChecker, range)\n            }\n\n            LookupSpace.XY -> {\n                val polygon = polygonProjection.xy()\n                when (locatorLookupStrategy) {\n\n                    LookupStrategy.HOVER, LookupStrategy.NEAREST -> {\n                        // Doesn't support nearest strategy. Target can be found only by hovering a cursor above the polygon.\n                        var counter = 0\n                        for (ring in polygon) {\n                            if (ring.bbox.contains(cursorCoord) && MathUtil.polygonContainsCoordinate(ring.edges, cursorCoord)) {\n                                counter++\n                            }\n                        }\n                        return counter % 2 != 0\n                    }\n\n                    LookupStrategy.NONE -> return false\n\n                    else -> throw IllegalStateException()\n                }\n            }\n\n            LookupSpace.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    private fun rangeBasedLookup(cursorCoord: DoubleVector, closestPointChecker: ClosestPointChecker, range: DoubleRange): Boolean {\n        when (locatorLookupStrategy) {\n\n            LookupStrategy.HOVER -> return range.contains(cursorCoord.x)\n\n            LookupStrategy.NEAREST -> {\n                //Too far\n                return if (!range.contains(cursorCoord.x - RECT_X_NEAREST_EPSILON) && !range.contains(cursorCoord.x + RECT_X_NEAREST_EPSILON)) {\n                    false\n                } else closestPointChecker.compare(DoubleVector(range.start() + range.length() / 2, cursorCoord.y)) !== COMPARISON_RESULT.NEW_FARTHER\n\n            }\n\n            LookupStrategy.NONE -> return false\n\n            else -> throw IllegalStateException()\n        }\n    }\n\n    companion object {\n        private const val POINT_AREA_EPSILON = 0.1\n        private const val POINT_X_NEAREST_EPSILON = 2.0\n        private const val RECT_X_NEAREST_EPSILON = 2.0\n\n        private fun binarySearch(value: Double, length: Int, indexer: (Int) -> Double): Int {\n\n            if (value < indexer(0)) {\n                return 0\n            }\n            if (value > indexer(length - 1)) {\n                return length - 1\n            }\n\n            var lo = 0\n            var hi = length - 1\n\n            while (lo <= hi) {\n                val mid = (hi + lo) / 2\n                val midValue = indexer(mid)\n\n                when {\n                    value < midValue -> hi = mid - 1\n                    value > midValue -> lo = mid + 1\n                    else -> return mid\n                }\n            }\n\n            return if (indexer(lo) - value < value - indexer(hi)) {\n                lo\n            } else {\n                hi\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.algorithms.calculateArea\nimport jetbrains.datalore.base.algorithms.splitRings\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleRectangles.boundingBox\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupSpace.*\nimport jetbrains.datalore.plot.builder.interact.MathUtil.DoubleRange\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier\nimport kotlin.math.max\nimport kotlin.math.min\n\n\ninternal open class TargetProjection\n\ninternal class PointTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): Double {\n        return data as Double\n    }\n\n    fun xy(): DoubleVector {\n        return data as DoubleVector\n    }\n\n    companion object {\n        fun create(p: DoubleVector, lookupSpace: LookupSpace): PointTargetProjection {\n            return when (lookupSpace) {\n                X -> PointTargetProjection(p.x)\n                XY -> PointTargetProjection(p)\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n    }\n}\n\ninternal class RectTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): DoubleRange {\n        return data as DoubleRange\n    }\n\n    fun xy(): DoubleRectangle {\n        return data as DoubleRectangle\n    }\n\n    companion object {\n        fun create(rect: DoubleRectangle, lookupSpace: LookupSpace): RectTargetProjection {\n            return when (lookupSpace) {\n                X -> RectTargetProjection(DoubleRange.withStartAndEnd(rect.left, rect.right))\n                XY -> RectTargetProjection(rect)\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n    }\n}\n\ninternal class PolygonTargetProjection private constructor(val data: Any) : TargetProjection() {\n\n    fun x(): DoubleRange {\n        return data as DoubleRange\n    }\n\n    fun xy(): List<RingXY> {\n        @Suppress(\"UNCHECKED_CAST\")\n        return data as List<RingXY>\n    }\n\n    companion object {\n        private const val AREA_LIMIT_TO_REMOVE_POLYGON = 25.0\n        private const val POINTS_COUNT_TO_SKIP_SIMPLIFICATION = 20.0\n        private const val AREA_TOLERANCE_RATIO = 0.1\n        private const val MAX_TOLERANCE = 40.0\n\n        fun create(points: List<DoubleVector>, lookupSpace: LookupSpace): PolygonTargetProjection {\n            val rings = splitRings(points)\n\n            return when (lookupSpace) {\n                X -> PolygonTargetProjection(mapToX(rings))\n                XY -> PolygonTargetProjection(mapToXY(rings))\n                NONE -> undefinedLookupSpaceError()\n            }\n        }\n\n        private fun mapToX(rings: List<List<DoubleVector>>): DoubleRange {\n            var min = rings[0][0].x\n            var max = min\n            for (ring in rings) {\n                for (point in ring) {\n                    min = min(min, point.x)\n                    max = max(max, point.x)\n                }\n            }\n            return DoubleRange.withStartAndEnd(min, max)\n        }\n\n        private fun mapToXY(rings: List<List<DoubleVector>>): List<RingXY> {\n            val polygon = ArrayList<RingXY>()\n\n            for (ring in rings) {\n                if (ring.size < 4) {\n                    continue\n                }\n\n\n                val bbox = boundingBox(ring)\n                val area = calculateArea(ring)\n\n                val simplifiedRing: List<DoubleVector>\n\n                if (ring.size > POINTS_COUNT_TO_SKIP_SIMPLIFICATION) {\n                    val tolerance = min(area * AREA_TOLERANCE_RATIO, MAX_TOLERANCE)\n                    simplifiedRing = PolylineSimplifier.visvalingamWhyatt(ring).setWeightLimit(tolerance).points\n\n                    @Suppress(\"ConstantConditionIf\")\n                    if (isLogEnabled) {\n                        log(\"Simp: \" + ring.size + \" -> \" + simplifiedRing.size +\n                                \", tolerance=\" + tolerance +\n                                \", bbox=\" + bbox +\n                                \", area=\" + area\n                        )\n                    }\n                } else {\n                    @Suppress(\"ConstantConditionIf\")\n                    if (isLogEnabled) {\n                        log(\"Keep: size: \" + ring.size +\n                                \", bbox=\" + bbox +\n                                \", area=\" + area\n                        )\n                    }\n                    simplifiedRing = ring\n                }\n\n                if (simplifiedRing.size < 4) {\n                    continue\n                }\n\n                polygon.add(RingXY(simplifiedRing, bbox))\n            }\n\n            return polygon\n        }\n\n        private fun log(str: String) {\n            println(str)\n        }\n\n        private const val isLogEnabled = false\n    }\n\n    internal class RingXY(val edges: List<DoubleVector>, val bbox: DoubleRectangle)\n}\n\ninternal class PathTargetProjection(val data: List<PathPoint>) : TargetProjection() {\n\n    val points: List<PathPoint> = data\n\n    internal class PathPoint private constructor(\n            private val myPointTargetProjection: PointTargetProjection,\n            val originalCoord: DoubleVector,\n            val index: Int) {\n\n        fun projection(): PointTargetProjection {\n            return myPointTargetProjection\n        }\n\n        companion object {\n            fun create(p: DoubleVector, index: Int, lookupSpace: LookupSpace): PathPoint {\n                return when (lookupSpace) {\n                    X -> PathPoint(PointTargetProjection.create(p, lookupSpace), p, index)\n                    XY -> PathPoint(PointTargetProjection.create(p, lookupSpace), p, index)\n                    NONE -> undefinedLookupSpaceError()\n                }\n            }\n        }\n    }\n\n    companion object {\n        fun create(points: List<DoubleVector>, indexMapper: (Int) -> Int, lookupSpace: LookupSpace): PathTargetProjection {\n            val pointsLocation = ArrayList<PathPoint>()\n            for ((i, point) in points.withIndex()) {\n                pointsLocation.add(PathPoint.create(point, indexMapper(i), lookupSpace))\n            }\n\n            return PathTargetProjection(pointsLocation)\n        }\n    }\n}\n\nprivate fun undefinedLookupSpaceError(): Nothing {\n    throw IllegalStateException(\"Undefined geom lookup space\")\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetCollector.TooltipParams\nimport jetbrains.datalore.plot.base.interact.HitShape\nimport jetbrains.datalore.plot.base.interact.HitShape.Kind.*\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint.Kind.*\n\nclass TargetPrototype(\n    internal val hitShape: HitShape,\n    internal val indexMapper: (Int) -> Int,\n    private val tooltipParams: TooltipParams,\n    internal val tooltipKind: TipLayoutHint.Kind\n) {\n\n    internal fun createGeomTarget(hitCoord: DoubleVector, hitIndex: Int): GeomTarget {\n        return GeomTarget(\n            hitIndex,\n            createTipLayoutHint(hitCoord, hitShape, tooltipParams.getColor(), tooltipKind, tooltipParams.getStemLength()),\n            tooltipParams.getTipLayoutHints()\n        )\n    }\n\n    companion object {\n        fun createTipLayoutHint(\n            hitCoord: DoubleVector,\n            hitShape: HitShape,\n            fill: Color,\n            tooltipKind: TipLayoutHint.Kind,\n            stemLength: TipLayoutHint.StemLength\n        ): TipLayoutHint {\n\n            return when (hitShape.kind) {\n                POINT -> when (tooltipKind) {\n                    VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(hitCoord, hitShape.point.radius, fill, stemLength)\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for POINT\")\n                }\n\n                RECT -> when (tooltipKind) {\n                    VERTICAL_TOOLTIP -> TipLayoutHint.verticalTooltip(hitCoord, 0.0, fill, stemLength)\n                    HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(hitCoord, hitShape.rect.width / 2, fill, stemLength)\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for RECT\")\n                }\n\n                PATH -> when (tooltipKind) {\n                    HORIZONTAL_TOOLTIP -> TipLayoutHint.horizontalTooltip(hitCoord, 0.0, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for PATH\")\n                }\n\n                POLYGON -> when (tooltipKind) {\n                    CURSOR_TOOLTIP -> TipLayoutHint.cursorTooltip(hitCoord, fill, stemLength)\n                    else -> error(\"Wrong TipLayoutHint.kind = $tooltipKind for POLYGON\")\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.interact.loc\n\nimport jetbrains.datalore.base.gcommon.collect.Lists\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.GeomTarget\nimport jetbrains.datalore.plot.base.interact.GeomTargetLocator\nimport jetbrains.datalore.plot.base.interact.TipLayoutHint\n\nabstract class TransformedTargetLocator(private val targetLocator: GeomTargetLocator) :\n    GeomTargetLocator {\n\n    override fun search(coord: DoubleVector): GeomTargetLocator.LookupResult? {\n        val targetCoord = convertToTargetCoord(coord)\n        val result = targetLocator.search(targetCoord) ?: return null\n        return convertLookupResult(result)\n    }\n\n    private fun convertLookupResult(lookupResult: GeomTargetLocator.LookupResult): GeomTargetLocator.LookupResult {\n        return GeomTargetLocator.LookupResult(\n                convertGeomTargets(lookupResult.targets),\n                convertToPlotDistance(lookupResult.distance),\n                lookupResult.geomKind,\n                lookupResult.contextualMapping,\n                lookupResult.contextualMapping.isCrosshairEnabled\n        )\n    }\n\n    private fun convertGeomTargets(geomTargets: List<GeomTarget>): List<GeomTarget> {\n        return ArrayList(Lists.transform(geomTargets) { geomTarget ->\n            GeomTarget(\n                geomTarget.hitIndex,\n                convertTipLayoutHint(geomTarget.tipLayoutHint),\n                convertTipLayoutHints(geomTarget.aesTipLayoutHints)\n            )\n        })\n    }\n\n    private fun convertTipLayoutHint(hint: TipLayoutHint): TipLayoutHint {\n        return TipLayoutHint(\n            hint.kind,\n            safeConvertToPlotCoord(hint.coord)!!,\n            convertToPlotDistance(hint.objectRadius),\n            hint.color,\n            hint.stemLength\n        )\n    }\n\n    private fun convertTipLayoutHints(tipLayoutHints: Map<Aes<*>, TipLayoutHint>): Map<Aes<*>, TipLayoutHint> {\n        val result = HashMap<Aes<*>, TipLayoutHint>()\n        tipLayoutHints.forEach { (aes, hint) -> result[aes] = convertTipLayoutHint(hint) }\n        return result\n    }\n\n    private fun safeConvertToPlotCoord(coord: DoubleVector?): DoubleVector? {\n        return if (coord == null) null else convertToPlotCoord(coord)\n    }\n\n    protected abstract fun convertToTargetCoord(coord: DoubleVector): DoubleVector\n\n    protected abstract fun convertToPlotCoord(coord: DoubleVector): DoubleVector\n\n    protected abstract fun convertToPlotDistance(distance: Double): Double\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\nclass AxisLayoutInfo private constructor(b: Builder) {\n    val axisBreaks: ScaleBreaks?\n    val axisLength: Double\n    val orientation: jetbrains.datalore.plot.builder.guide.Orientation?\n    val axisDomain: ClosedRange<Double>?\n\n    val tickLabelsBounds: DoubleRectangle?\n    val tickLabelRotationAngle: Double\n    val tickLabelHorizontalAnchor: TextLabel.HorizontalAnchor?    // optional\n    val tickLabelVerticalAnchor: TextLabel.VerticalAnchor?        // optional\n    val tickLabelAdditionalOffsets: List<DoubleVector>?           // optional\n    val tickLabelSmallFont: Boolean\n    private val tickLabelsBoundsMax: DoubleRectangle?                     // debug\n\n    init {\n        require(b.myAxisBreaks != null)\n        require(b.myOrientation != null)\n        require(b.myTickLabelsBounds != null)\n        require(b.myAxisDomain != null)\n\n        this.axisBreaks = b.myAxisBreaks\n        this.axisLength = b.myAxisLength\n        this.orientation = b.myOrientation\n        this.axisDomain = b.myAxisDomain\n\n        this.tickLabelsBounds = b.myTickLabelsBounds\n        this.tickLabelRotationAngle = b.myTickLabelRotationAngle\n        this.tickLabelHorizontalAnchor = b.myLabelHorizontalAnchor\n        this.tickLabelVerticalAnchor = b.myLabelVerticalAnchor\n        this.tickLabelAdditionalOffsets = b.myLabelAdditionalOffsets\n        this.tickLabelSmallFont = b.myTickLabelSmallFont\n        this.tickLabelsBoundsMax = b.myMaxTickLabelsBounds\n    }\n\n    fun withAxisLength(axisLength: Double): Builder {\n        //checkState(axisDomain != null);\n\n        val b = Builder()\n        b.myAxisBreaks = axisBreaks\n        b.myAxisLength = axisLength\n\n        b.myOrientation = this.orientation\n        b.myAxisDomain = this.axisDomain\n\n        b.myTickLabelsBounds = this.tickLabelsBounds\n        b.myTickLabelRotationAngle = this.tickLabelRotationAngle\n        b.myLabelHorizontalAnchor = this.tickLabelHorizontalAnchor\n        b.myLabelVerticalAnchor = this.tickLabelVerticalAnchor\n        b.myLabelAdditionalOffsets = this.tickLabelAdditionalOffsets\n        b.myTickLabelSmallFont = this.tickLabelSmallFont\n        b.myMaxTickLabelsBounds = this.tickLabelsBoundsMax\n        return b\n    }\n\n    fun axisBounds(): DoubleRectangle {\n        return tickLabelsBounds!!.union(DoubleRectangle(0.0, 0.0, 0.0, 0.0))\n    }\n\n    class Builder {\n        var myAxisLength: Double = 0.toDouble()\n        var myOrientation: jetbrains.datalore.plot.builder.guide.Orientation? = null\n        var myAxisDomain: ClosedRange<Double>? = null\n        var myMaxTickLabelsBounds: DoubleRectangle? = null\n        var myTickLabelSmallFont = false\n        var myLabelAdditionalOffsets: List<DoubleVector>? = null\n        var myLabelHorizontalAnchor: TextLabel.HorizontalAnchor? = null\n        var myLabelVerticalAnchor: TextLabel.VerticalAnchor? = null\n        var myTickLabelRotationAngle = 0.0\n        var myTickLabelsBounds: DoubleRectangle? = null\n        var myAxisBreaks: ScaleBreaks? = null\n\n        fun build(): AxisLayoutInfo {\n            return AxisLayoutInfo(this)\n        }\n\n        fun axisLength(d: Double): Builder {\n            myAxisLength = d\n            return this\n        }\n\n        fun orientation(o: jetbrains.datalore.plot.builder.guide.Orientation): Builder {\n            myOrientation = o\n            return this\n        }\n\n        fun axisDomain(r: ClosedRange<Double>): Builder {\n            myAxisDomain = r\n            return this\n        }\n\n        fun tickLabelsBoundsMax(r: DoubleRectangle?): Builder {\n            myMaxTickLabelsBounds = r\n            return this\n        }\n\n        fun tickLabelSmallFont(b: Boolean): Builder {\n            myTickLabelSmallFont = b\n            return this\n        }\n\n        fun tickLabelAdditionalOffsets(labelAdditionalOffsets: List<DoubleVector>?): Builder {\n            myLabelAdditionalOffsets = labelAdditionalOffsets\n            return this\n        }\n\n        fun tickLabelHorizontalAnchor(labelHorizontalAnchor: TextLabel.HorizontalAnchor?): Builder {\n            myLabelHorizontalAnchor = labelHorizontalAnchor\n            return this\n        }\n\n        fun tickLabelVerticalAnchor(labelVerticalAnchor: TextLabel.VerticalAnchor?): Builder {\n            myLabelVerticalAnchor = labelVerticalAnchor\n            return this\n        }\n\n        fun tickLabelRotationAngle(rotationAngle: Double): Builder {\n            myTickLabelRotationAngle = rotationAngle\n            return this\n        }\n\n        fun tickLabelsBounds(rectangle: DoubleRectangle?): Builder {\n            myTickLabelsBounds = rectangle\n            return this\n        }\n\n        fun axisBreaks(breaks: ScaleBreaks?): Builder {\n            myAxisBreaks = breaks\n            return this\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\nclass EmptyAxisLayout private constructor(\n    xDomain: ClosedRange<Double>,\n    yDomain: ClosedRange<Double>,\n    private val myOrientation: jetbrains.datalore.plot.builder.guide.Orientation\n) :\n    AxisLayout {\n\n    private val myAxisDomain: ClosedRange<Double>\n\n    init {\n        myAxisDomain = if (myOrientation.isHorizontal) xDomain else yDomain\n    }\n\n    override fun initialThickness(): Double {\n        return 0.0\n    }\n\n    override fun doLayout(displaySize: DoubleVector, maxTickLabelsBoundsStretched: DoubleRectangle?): AxisLayoutInfo {\n        val axisLength = if (myOrientation.isHorizontal) displaySize.x else displaySize.y\n        // relative to axis component\n        val tickLabelsBounds = if (myOrientation.isHorizontal) {\n            DoubleRectangle(0.0, 0.0, axisLength, 0.0)\n        } else {\n            DoubleRectangle(0.0, 0.0, 0.0, axisLength)\n        }\n\n        val builder = AxisLayoutInfo.Builder()\n            .axisBreaks(ScaleBreaks.EMPTY)\n            .axisLength(axisLength)\n            .orientation(myOrientation)\n            .axisDomain(myAxisDomain)\n            .tickLabelsBounds(tickLabelsBounds)\n\n        return builder.build()\n    }\n\n    companion object {\n        fun bottom(xDomain: ClosedRange<Double>, yDomain: ClosedRange<Double>): AxisLayout {\n            return EmptyAxisLayout(\n                xDomain,\n                yDomain,\n                jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\n            )\n        }\n\n        fun left(xDomain: ClosedRange<Double>, yDomain: ClosedRange<Double>): AxisLayout {\n            return EmptyAxisLayout(\n                xDomain,\n                yDomain,\n                jetbrains.datalore.plot.builder.guide.Orientation.LEFT\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.assemble.PlotFacets\nimport kotlin.math.abs\n\ninternal class FacetGridPlotLayout(\n    private val facets: PlotFacets,\n    private val tileLayout: TileLayout\n) : PlotLayoutBase() {\n    private val totalPanelHorizontalPadding: Double = PANEL_PADDING * (facets.colCount - 1)\n    private val totalPanelVerticalPadding: Double = PANEL_PADDING * (facets.rowCount - 1)\n\n    init {\n        setPadding(10.0, 10.0, 0.0, 0.0)\n\n        require(facets.isDefined) { \"Undefined facets.\" }\n    }\n\n    override fun doLayout(preferredSize: DoubleVector): PlotLayoutInfo {\n        var tilesAreaSize = DoubleVector(\n            preferredSize.x - (paddingLeft + paddingRight),\n            preferredSize.y - (paddingTop + paddingBottom)\n        )\n\n        val facetTiles = facets.tileInfos()\n        val tileColLabCounts = facetTiles.firstOrNull { it.colLabs.isNotEmpty() }?.colLabs?.size ?: 0\n        val tileWithColLabInRowCount = facetTiles\n            .filter { it.colLabs.isNotEmpty() }\n            .distinctBy { it.row }.count()\n\n        val totalAddedHeight = facetColHeadHeight(tileColLabCounts) * tileWithColLabInRowCount\n\n        val labsInRow = if (facetTiles.any { it.rowLab != null }) 1 else 0\n        val labsTotalDim = DoubleVector(labsInRow * FACET_TAB_HEIGHT, totalAddedHeight)\n        tilesAreaSize = tilesAreaSize.subtract(labsTotalDim)\n\n        // rough estimate (without axis. The final size will be smaller)\n        val tileWidth = (tilesAreaSize.x - totalPanelHorizontalPadding) / facets.colCount\n        val tileHeight = (tilesAreaSize.y - totalPanelVerticalPadding) / facets.rowCount\n\n        // initial layout\n        var tileInfo = layoutTile(tileWidth, tileHeight)\n\n        // do 1 or 2 times\n        for (i in 0..1) {\n            // adjust geom size\n            val tilesAreaSizeNew = tilesAreaSize(tileInfo)\n            val widthDiff = tilesAreaSize.x - tilesAreaSizeNew.x\n            val heightDiff = tilesAreaSize.y - tilesAreaSizeNew.y\n\n            // error 1 px per tile is ok\n            if (abs(widthDiff) <= facets.colCount && abs(heightDiff) <= facets.rowCount) {\n                break\n            }\n\n            val geomWidth = tileInfo.geomWidth() + widthDiff / facets.colCount\n            val newPanelWidth = geomWidth + tileInfo.axisThicknessY()\n            val geomHeight = tileInfo.geomHeight() + heightDiff / facets.rowCount\n            val newPanelHeight = geomHeight + tileInfo.axisThicknessX()\n\n            // re-layout\n            tileInfo = layoutTile(newPanelWidth, newPanelHeight)\n        }\n\n        // create final plot tiles layout infos\n\n        val axisThicknessX = tileInfo.axisThicknessX()\n        val axisThicknessY = tileInfo.axisThicknessY()\n        val geomWidth = tileInfo.geomWidth()\n        val geomHeight = tileInfo.geomHeight()\n\n        var tilesAreaBounds = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        val tilesAreaOffset = DoubleVector(paddingLeft, paddingTop)\n        val tileInfos = ArrayList<TileLayoutInfo>()\n\n        var offsetX = 0.0\n        var offsetY = 0.0\n        var currRow = 0\n        var prevHeight = 0.0\n\n        for (facetTile in facetTiles) {\n            var width = geomWidth\n            var geomX = 0.0\n            if (facetTile.yAxis) {\n                width += axisThicknessY\n                geomX = axisThicknessY\n            }\n            if (facetTile.rowLab != null) {\n                width += FACET_TAB_HEIGHT\n            }\n\n            var height = geomHeight\n            var geomY: Double\n            if (facetTile.xAxis && facetTile.row == facets.rowCount - 1) {   // bottom row only\n                height += axisThicknessX\n            }\n            val addedHeight = facetColHeadHeight(facetTile.colLabs.size)\n            height += addedHeight\n            geomY = addedHeight\n\n            val bounds = DoubleRectangle(0.0, 0.0, width, height)\n            val geomBounds = DoubleRectangle(geomX, geomY, geomWidth, geomHeight)\n\n            val row = facetTile.row\n            if (row > currRow) {\n                currRow = row\n                offsetY += prevHeight + PANEL_PADDING\n            }\n            prevHeight = height\n\n            val col = facetTile.col\n            if (col == 0) {\n                offsetX = 0.0\n            }\n\n            val offset = DoubleVector(offsetX, offsetY)\n            offsetX += width + PANEL_PADDING\n\n            val info = TileLayoutInfo(\n                bounds,\n                geomBounds,\n                XYPlotLayoutUtil.clipBounds(geomBounds),\n                tileInfo.layoutInfo.xAxisInfo,\n                tileInfo.layoutInfo.yAxisInfo,\n                xAxisShown = facetTile.xAxis,\n                yAxisShown = facetTile.yAxis,\n                trueIndex = facetTile.trueIndex\n            )\n                .withOffset(tilesAreaOffset.add(offset))\n                .withFacetLabels(facetTile.colLabs, facetTile.rowLab)\n\n            tileInfos.add(info)\n\n            tilesAreaBounds = tilesAreaBounds.union(info.getAbsoluteBounds(tilesAreaOffset))\n        }\n\n        val plotSize = DoubleVector(\n            tilesAreaBounds.right + paddingRight,\n            tilesAreaBounds.height + paddingBottom\n        )\n\n        return PlotLayoutInfo(tileInfos, plotSize)\n    }\n\n    private fun layoutTile(tileWidth: Double, tileHeight: Double): MyTileInfo {\n        val layoutInfo = tileLayout.doLayout(DoubleVector(tileWidth, tileHeight))\n        return MyTileInfo(layoutInfo)\n    }\n\n    private fun tilesAreaSize(tileInfo: MyTileInfo): DoubleVector {\n        val w = tileInfo.geomWidth() * facets.colCount + totalPanelHorizontalPadding + tileInfo.axisThicknessY()\n        val h = tileInfo.geomHeight() * facets.rowCount + totalPanelVerticalPadding + tileInfo.axisThicknessX()\n        return DoubleVector(w, h)\n    }\n\n    private class MyTileInfo internal constructor(internal val layoutInfo: TileLayoutInfo) {\n\n        internal fun axisThicknessX(): Double {\n            return layoutInfo.bounds.bottom - layoutInfo.geomBounds.bottom\n        }\n\n        internal fun axisThicknessY(): Double {\n            return layoutInfo.geomBounds.left - layoutInfo.bounds.left\n        }\n\n        internal fun geomWidth(): Double {\n            return layoutInfo.geomBounds.width\n        }\n\n        internal fun geomHeight(): Double {\n            return layoutInfo.geomBounds.height\n        }\n    }\n\n    companion object {\n        const val FACET_TAB_HEIGHT = 30.0\n        const val FACET_H_PADDING = 0\n        const val FACET_V_PADDING = 6 //5\n\n        private const val PANEL_PADDING = 10.0\n\n        fun facetColLabelSize(colWidth: Double): DoubleVector {\n            return DoubleVector(colWidth - FACET_H_PADDING * 2, FACET_TAB_HEIGHT - FACET_V_PADDING * 2.0)\n        }\n\n        fun facetColHeadHeight(labCount: Int): Double {\n            return if (labCount > 0) {\n                facetColLabelSize(0.0).y * labCount + FACET_V_PADDING * 2\n            } else {\n                0.0\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\n\nobject GeometryUtil {\n    fun union(first: DoubleRectangle, optionalSecond: DoubleRectangle?): DoubleRectangle {\n        return if (optionalSecond == null) {\n            first\n        } else first.union(optionalSecond)\n    }\n\n    fun union(head: DoubleRectangle, c: Collection<DoubleRectangle>): DoubleRectangle {\n        var result = head\n        for (r in c) {\n            result = result.union(r)\n        }\n        return result\n    }\n\n    fun doubleRange(xRange: ClosedRange<Double>, yRange: ClosedRange<Double>): DoubleRectangle {\n        val xOrigin = xRange.lowerEnd\n        val yOrigin = yRange.lowerEnd\n        val xSpan = xRange.upperEnd - xRange.lowerEnd\n        val ySpan = yRange.upperEnd - yRange.lowerEnd\n        return DoubleRectangle(xOrigin, yOrigin, xSpan, ySpan)\n    }\n\n    fun changeWidth(r: DoubleRectangle, width: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.origin.y,\n                width,\n                r.dimension.y\n        )\n    }\n\n    fun changeWidthKeepRight(r: DoubleRectangle, width: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.right - width,\n                r.origin.y,\n                width,\n                r.dimension.y\n        )\n    }\n\n    fun changeHeight(r: DoubleRectangle, height: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.origin.y,\n                r.dimension.x,\n                height\n        )\n    }\n\n    fun changeHeightKeepBottom(r: DoubleRectangle, height: Double): DoubleRectangle {\n        return DoubleRectangle(\n                r.origin.x,\n                r.bottom - height,\n                r.dimension.x,\n                height\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nabstract class LegendBoxInfo protected constructor(internal val size: DoubleVector) {\n\n    open val isEmpty: Boolean\n        get() = false\n\n    abstract fun createLegendBox(): jetbrains.datalore.plot.builder.guide.LegendBox\n\n    companion object {\n        val EMPTY: LegendBoxInfo = object : LegendBoxInfo(DoubleVector.ZERO) {\n            override val isEmpty: Boolean\n                get() = true\n\n            override fun createLegendBox(): jetbrains.datalore.plot.builder.guide.LegendBox {\n                throw IllegalStateException(\"Empty legend box info\")\n            }\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.theme.LegendTheme\nimport kotlin.math.max\n\nclass LegendBoxesLayout(private val myPlotBounds: DoubleRectangle, private val myTheme: LegendTheme) {\n\n    fun doLayout(infos: List<LegendBoxInfo>): Result {\n        val legendPosition = myTheme.position()\n        val legendJustification = myTheme.justification()\n\n        // ToDo: theme legend.box option\n        val legendArrangement = jetbrains.datalore.plot.builder.guide.LegendArrangement.VERTICAL\n\n        val plotCenter = myPlotBounds.center\n        var plotInnerBoundsWithoutLegendBoxes = myPlotBounds\n\n        val boxWithLocationList = if (legendArrangement === jetbrains.datalore.plot.builder.guide.LegendArrangement.VERTICAL)\n            LegendBoxesLayoutUtil.verticalStack(infos)\n        else\n            LegendBoxesLayoutUtil.horizontalStack(infos)\n\n        val boxesSize =\n            LegendBoxesLayoutUtil.size(boxWithLocationList)\n\n        // adjust plot bounds\n        if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT || legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.RIGHT) {\n            val plotWidth = max(0.0, plotInnerBoundsWithoutLegendBoxes.width - boxesSize.x)\n            if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT) {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeWidthKeepRight(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotWidth\n                    )\n            } else {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeWidth(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotWidth\n                    )\n            }\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP || legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.BOTTOM) {\n            val plotHeight = max(0.0, plotInnerBoundsWithoutLegendBoxes.height - boxesSize.y)\n            if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP) {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeHeightKeepBottom(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotHeight\n                    )\n            } else {\n                plotInnerBoundsWithoutLegendBoxes =\n                    GeometryUtil.changeHeight(\n                        plotInnerBoundsWithoutLegendBoxes,\n                        plotHeight\n                    )\n            }\n        }\n\n        val legendOrigin: DoubleVector\n        if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.LEFT) {\n            legendOrigin = DoubleVector(\n                    plotInnerBoundsWithoutLegendBoxes.left - boxesSize.x,\n                    plotCenter.y - boxesSize.y / 2)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.RIGHT) {\n            legendOrigin = DoubleVector(\n                    plotInnerBoundsWithoutLegendBoxes.right,\n                    plotCenter.y - boxesSize.y / 2)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.TOP) {\n            legendOrigin = DoubleVector(\n                    plotCenter.x - boxesSize.x / 2,\n                    plotInnerBoundsWithoutLegendBoxes.top - boxesSize.y)\n        } else if (legendPosition == jetbrains.datalore.plot.builder.guide.LegendPosition.BOTTOM) {\n            legendOrigin = DoubleVector(\n                    plotCenter.x - boxesSize.x / 2,\n                    plotInnerBoundsWithoutLegendBoxes.bottom)\n        } else {\n            legendOrigin =\n                LegendBoxesLayoutUtil.overlayLegendOrigin(\n                    plotInnerBoundsWithoutLegendBoxes,\n                    boxesSize,\n                    legendPosition,\n                    legendJustification\n                )\n        }\n\n        val resultBoxWithLocationList =\n            LegendBoxesLayoutUtil.moveAll(\n                legendOrigin,\n                boxWithLocationList\n            )\n        return Result(\n            plotInnerBoundsWithoutLegendBoxes,\n            resultBoxWithLocationList\n        )\n    }\n\n    class Result(val plotInnerBoundsWithoutLegendBoxes: DoubleRectangle, locations: List<BoxWithLocation>) {\n        val boxWithLocationList: List<BoxWithLocation> = ArrayList(locations)\n    }\n\n    class BoxWithLocation internal constructor(val legendBox: LegendBoxInfo, val location: DoubleVector) {\n\n        internal fun size(): DoubleVector {\n            return legendBox.size\n        }\n\n        internal fun bounds(): DoubleRectangle {\n            return DoubleRectangle(location, legendBox.size)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninternal object LegendBoxesLayoutUtil {\n    fun verticalStack(boxInfos: List<LegendBoxInfo>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        var y = 0.0\n        for (info in boxInfos) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    info,\n                    DoubleVector(0.0, y)\n                )\n            )\n            y += info.size.y\n        }\n        return result\n    }\n\n    fun horizontalStack(boxInfos: List<LegendBoxInfo>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        var x = 0.0\n        for (info in boxInfos) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    info,\n                    DoubleVector(x, 0.0)\n                )\n            )\n            x += info.size.x\n        }\n        return result\n    }\n\n    fun moveAll(delta: DoubleVector, boxWithLocationList: List<LegendBoxesLayout.BoxWithLocation>): List<LegendBoxesLayout.BoxWithLocation> {\n        val result = ArrayList<LegendBoxesLayout.BoxWithLocation>()\n        for (boxWithLocation in boxWithLocationList) {\n            result.add(\n                LegendBoxesLayout.BoxWithLocation(\n                    boxWithLocation.legendBox,\n                    boxWithLocation.location.add(delta)\n                )\n            )\n        }\n        return result\n    }\n\n    fun size(boxWithLocationList: List<LegendBoxesLayout.BoxWithLocation>): DoubleVector {\n        var bounds: DoubleRectangle? = null\n        for (boxWithLocation in boxWithLocationList) {\n            bounds = bounds?.union(boxWithLocation.bounds()) ?: boxWithLocation.bounds()\n        }\n\n        return bounds?.dimension ?: DoubleVector.ZERO\n    }\n\n    fun overlayLegendOrigin(\n        plotBounds: DoubleRectangle, legendSize: DoubleVector, legendPosition: jetbrains.datalore.plot.builder.guide.LegendPosition, legendJustification: jetbrains.datalore.plot.builder.guide.LegendJustification\n    ): DoubleVector {\n        val plotSize = plotBounds.dimension\n\n        // [0,0] -> bottom-left, [1,1] -> top, right\n        val absolutePosition = DoubleVector(\n                plotBounds.left + plotSize.x * legendPosition.x,\n                plotBounds.bottom - plotSize.y * legendPosition.y\n        )\n\n        // legendJustification: [0,0] -> bottom-left, [1,1] -> top, right\n        val originOffset = DoubleVector(\n                -legendSize.x * legendJustification.x,\n                legendSize.y * legendJustification.y - legendSize.y\n        )\n\n        return absolutePosition.add(originOffset)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MIN_SIZE\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.clipBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.geomBounds\n\ninternal class LiveMapTileLayout : TileLayout {\n\n    override fun doLayout(preferredSize: DoubleVector): TileLayoutInfo {\n        var geomBounds = geomBounds(\n            0.0,\n            0.0,\n            preferredSize\n        )\n        geomBounds = geomBounds.union(\n            DoubleRectangle(\n                geomBounds.origin,\n                GEOM_MIN_SIZE\n            )\n        )\n        val geomWithAxisBounds = geomBounds\n        return TileLayoutInfo(\n            geomWithAxisBounds,\n            geomBounds,\n            clipBounds(geomBounds),\n            null, null,\n            trueIndex = 0\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.builder.coord.CoordProvider\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksUtil\nimport jetbrains.datalore.plot.builder.layout.axis.AxisLayouter\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nclass PlotAxisLayout private constructor(\n    private val scale: Scale<Double>,\n    private val domainX: ClosedRange<Double>,\n    private val domainY: ClosedRange<Double>,\n    private val coordProvider: CoordProvider,\n    private val theme: AxisTheme,\n    private val orientation: Orientation\n) : AxisLayout {\n\n    override fun initialThickness(): Double {\n        if (theme.showTickMarks() || theme.showTickLabels()) {\n            val v = theme.tickLabelDistance()\n            return if (theme.showTickLabels()) {\n                v + initialTickLabelSize(orientation)\n            } else {\n                v\n            }\n        }\n        return 0.0\n    }\n\n    override fun doLayout(displaySize: DoubleVector, maxTickLabelsBoundsStretched: DoubleRectangle?): AxisLayoutInfo {\n        val layouter = createLayouter(displaySize)\n        return layouter.doLayout(\n            axisLength(displaySize, orientation),\n            maxTickLabelsBoundsStretched\n        )\n    }\n\n    private fun createLayouter(displaySize: DoubleVector): AxisLayouter {\n        val domains = coordProvider.adjustDomains(domainX, domainY, displaySize)\n        val axisDomain = axisDomain(\n            domains,\n            orientation\n        )\n\n        val breaksProvider = AxisBreaksUtil.createAxisBreaksProvider(scale, axisDomain)\n        return AxisLayouter.create(orientation, axisDomain, breaksProvider, theme)\n    }\n\n    companion object {\n        private val TICK_LABEL_SPEC = PlotLabelSpec.AXIS_TICK\n\n        fun bottom(\n            scale: Scale<Double>,\n            xDomain: ClosedRange<Double>,\n            yDomain: ClosedRange<Double>,\n            coordProvider: CoordProvider,\n            theme: AxisTheme\n        ): AxisLayout {\n            return PlotAxisLayout(\n                scale, xDomain, yDomain, coordProvider,\n                theme,\n                Orientation.BOTTOM\n            )\n        }\n\n        fun left(\n            scale: Scale<Double>,\n            xDomain: ClosedRange<Double>,\n            yDomain: ClosedRange<Double>,\n            coordProvider: CoordProvider,\n            theme: AxisTheme\n        ): AxisLayout {\n            return PlotAxisLayout(\n                scale, xDomain, yDomain, coordProvider,\n                theme,\n                Orientation.LEFT\n            )\n        }\n\n        private fun initialTickLabelSize(orientation: Orientation): Double {\n            return if (orientation.isHorizontal)\n                TICK_LABEL_SPEC.height()\n            else\n                TICK_LABEL_SPEC.width(1)\n        }\n\n        private fun axisLength(displaySize: DoubleVector, orientation: Orientation): Double {\n            return if (orientation.isHorizontal)\n                displaySize.x\n            else\n                displaySize.y\n        }\n\n        private fun axisDomain(\n            xyDomains: Pair<ClosedRange<Double>, ClosedRange<Double>>,\n            orientation: Orientation\n        ): ClosedRange<Double> {\n            return if (orientation.isHorizontal)\n                xyDomains.first\n            else\n                xyDomains.second\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\ninternal abstract class PlotLayoutBase : PlotLayout {\n    protected var paddingTop: Double = 0.0\n        private set\n    protected var paddingRight: Double = 0.0\n        private set\n    protected var paddingBottom: Double = 0.0\n        private set\n    protected var paddingLeft: Double = 0.0\n        private set\n\n    override fun setPadding(top: Double, right: Double, bottom: Double, left: Double) {\n        paddingTop = top\n        paddingRight = right\n        paddingBottom = bottom\n        paddingLeft = left\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nclass PlotLayoutInfo(tiles: List<TileLayoutInfo>, val size: DoubleVector) {\n    val tiles: List<TileLayoutInfo> = ArrayList(tiles)\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.gcommon.base.Strings.isNullOrEmpty\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\n\nobject PlotLayoutUtil {\n    const val AXIS_TITLE_OUTER_MARGIN = 4.0\n    const val AXIS_TITLE_INNER_MARGIN = 4.0\n    private const val TITLE_V_MARGIN = 4.0\n    private val LIVE_MAP_PLOT_PADDING = DoubleVector(10.0, 0.0)\n    private val LIVE_MAP_PLOT_MARGIN = DoubleVector(10.0, 10.0)\n\n    fun titleDimensions(text: String): DoubleVector {\n        if (isNullOrEmpty(text)) {\n            return DoubleVector.ZERO\n        }\n\n        val labelSpec = PlotLabelSpec.PLOT_TITLE\n        return DoubleVector(\n            labelSpec.width(text.length),\n            labelSpec.height() + 2 * TITLE_V_MARGIN\n        )\n    }\n\n    fun axisTitleDimensions(text: String): DoubleVector {\n        if (isNullOrEmpty(text)) {\n            return DoubleVector.ZERO\n        }\n\n        val labelSpec = PlotLabelSpec.AXIS_TITLE\n        return DoubleVector(\n            labelSpec.width(text.length),\n            labelSpec.height()\n        )\n    }\n\n    fun absoluteGeomBounds(origin: DoubleVector, plotLayoutInfo: PlotLayoutInfo): DoubleRectangle {\n        require(plotLayoutInfo.tiles.isNotEmpty()) { \"Plot is empty\" }\n\n        var result: DoubleRectangle? = null\n        for (tile in plotLayoutInfo.tiles) {\n            val geomBounds = tile.getAbsoluteGeomBounds(origin)\n            result = result?.union(geomBounds) ?: geomBounds\n        }\n        return result!!\n    }\n\n    fun liveMapBounds(container: DoubleRectangle): DoubleRectangle {\n        return DoubleRectangle(\n            container.origin.add(LIVE_MAP_PLOT_PADDING),\n            container.dimension.subtract(LIVE_MAP_PLOT_MARGIN)\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleVector\n\ninternal class SingleTilePlotLayout(private val myTileLayout: TileLayout) : PlotLayoutBase() {\n\n    init {\n        setPadding(10.0, 10.0, 0.0, 0.0)\n    }\n\n    override fun doLayout(preferredSize: DoubleVector): PlotLayoutInfo {\n        val tilePreferredSize = DoubleVector(\n                preferredSize.x - (paddingLeft + paddingRight),\n                preferredSize.y - (paddingTop + paddingBottom))\n\n        var tileInfo = myTileLayout.doLayout(tilePreferredSize)\n        tileInfo = tileInfo.withOffset(DoubleVector(paddingLeft, paddingTop))\n\n        var plotSize = tileInfo.bounds.dimension\n        plotSize = plotSize.add(DoubleVector(paddingRight, paddingBottom))\n\n        return PlotLayoutInfo(listOf(tileInfo), plotSize)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\n\nclass TileLayoutInfo private constructor(\n    // 'plot' means : geom area + axis (but not titles, facet labels or legends)\n    val plotOrigin: DoubleVector,     // tile 'plot' origin relative to overall 'plot' origin\n\n    // relative to plot tile\n    val bounds: DoubleRectangle,      // plotting area + optional elements (axis, axis tick labels)\n    val geomBounds: DoubleRectangle,  // actual plotting area\n    val clipBounds: DoubleRectangle,  // geom shapes outside this bounds will be cut-off\n\n    // Params xAxisInfo/yAxisInfo can be NULL.\n    // In this case any mapping of positional Aes should be dropped (live map plot).\n    val xAxisInfo: AxisLayoutInfo?,\n    val yAxisInfo: AxisLayoutInfo?,\n\n    xAxisShown: Boolean,\n    yAxisShown: Boolean,\n\n    val facetXLabels: List<String>,\n    val facetYLabel: String?,\n\n    val trueIndex: Int     // tile index before re-ordering (in facet wrap)\n) {\n    val xAxisShown: Boolean = xAxisInfo != null && xAxisShown\n    val yAxisShown: Boolean = yAxisInfo != null && yAxisShown\n\n    constructor(\n        bounds: DoubleRectangle,\n        geomBounds: DoubleRectangle,\n        clipBounds: DoubleRectangle,\n        xAxisInfo: AxisLayoutInfo?,\n        yAxisInfo: AxisLayoutInfo?,\n        xAxisShown: Boolean = true,\n        yAxisShown: Boolean = true,\n        trueIndex: Int\n    ) : this(\n        DoubleVector.ZERO,\n        bounds,\n        geomBounds,\n        clipBounds,\n        xAxisInfo,\n        yAxisInfo,\n        xAxisShown = xAxisShown,\n        yAxisShown = yAxisShown,\n        facetXLabels = emptyList(),\n        facetYLabel = null,\n        trueIndex\n    )\n\n    fun withOffset(offset: DoubleVector): TileLayoutInfo {\n        return TileLayoutInfo(\n            offset,\n            bounds,\n            geomBounds,\n            clipBounds,\n            xAxisInfo, yAxisInfo,\n            xAxisShown, yAxisShown,\n            facetXLabels, facetYLabel,\n            trueIndex\n        )\n    }\n\n    fun getAbsoluteBounds(tilesOrigin: DoubleVector): DoubleRectangle {\n        val offset = tilesOrigin.add(plotOrigin)\n        return bounds.add(offset)\n    }\n\n    fun getAbsoluteGeomBounds(tilesOrigin: DoubleVector): DoubleRectangle {\n        val offset = tilesOrigin.add(plotOrigin)\n        return geomBounds.add(offset)\n    }\n\n    fun withFacetLabels(xLabels: List<String>, yLabel: String?): TileLayoutInfo {\n        return TileLayoutInfo(\n            this.plotOrigin,\n            this.bounds,\n            this.geomBounds,\n            this.clipBounds,\n            this.xAxisInfo, this.yAxisInfo,\n            this.xAxisShown, this.yAxisShown,\n            xLabels, yLabel,\n            trueIndex\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation\n\ninternal object XYPlotLayoutUtil {\n    const val GEOM_MARGIN = 0.0          // min space around geom area\n    private const val CLIP_EXTEND = 5.0\n    val GEOM_MIN_SIZE = DoubleVector(50.0, 50.0)\n\n    fun geomBounds(xAxisThickness: Double, yAxisThickness: Double, plotSize: DoubleVector): DoubleRectangle {\n        val marginLeftTop = DoubleVector(yAxisThickness, GEOM_MARGIN)\n        val marginRightBottom = DoubleVector(GEOM_MARGIN, xAxisThickness)\n        var geomSize = plotSize\n            .subtract(marginLeftTop)\n            .subtract(marginRightBottom)\n\n        if (geomSize.x < GEOM_MIN_SIZE.x) {\n            geomSize = DoubleVector(GEOM_MIN_SIZE.x, geomSize.y)\n        }\n        if (geomSize.y < GEOM_MIN_SIZE.y) {\n            geomSize = DoubleVector(geomSize.x, GEOM_MIN_SIZE.y)\n        }\n        return DoubleRectangle(marginLeftTop, geomSize)\n    }\n\n    fun clipBounds(geomBounds: DoubleRectangle): DoubleRectangle {\n        return DoubleRectangle(\n            geomBounds.origin.subtract(\n                DoubleVector(\n                    CLIP_EXTEND,\n                    CLIP_EXTEND\n                )\n            ),\n            DoubleVector(\n                geomBounds.dimension.x + 2 * CLIP_EXTEND,\n                geomBounds.dimension.y + 2 * CLIP_EXTEND\n            )\n        )\n    }\n\n    fun maxTickLabelsBounds(\n        axisOrientation: Orientation,\n        stretch: Double,\n        geomBounds: DoubleRectangle,\n        plotSize: DoubleVector\n    ): DoubleRectangle {\n        val geomPaddung = 10.0          // min space around geom area (labels should not touch geom area).\n\n        val maxGeomBounds = DoubleRectangle(\n            geomPaddung, geomPaddung,\n            plotSize.x - 2 * geomPaddung,\n            plotSize.y - 2 * geomPaddung\n        )\n        when (axisOrientation) {\n            Orientation.TOP,\n            Orientation.BOTTOM -> {\n                val leftSpace = geomBounds.left - maxGeomBounds.left + stretch\n                val rightSpace = maxGeomBounds.right - geomBounds.right + stretch\n\n                val height = 1E42   // just very large number\n                val top = when (axisOrientation) {\n                    Orientation.TOP -> -height\n                    else -> 0.0\n                }\n\n                val left = -leftSpace\n                val width = leftSpace + rightSpace + geomBounds.width\n                return DoubleRectangle(left, top, width, height)\n            }\n\n            else -> throw IllegalArgumentException(\"Orientation not supported: $axisOrientation\")\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MARGIN\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.GEOM_MIN_SIZE\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.clipBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.geomBounds\nimport jetbrains.datalore.plot.builder.layout.XYPlotLayoutUtil.maxTickLabelsBounds\n\ninternal class XYPlotTileLayout(\n    private val xAxisLayout: AxisLayout,\n    private val yAxisLayout: AxisLayout\n) : TileLayout {\n\n    override fun doLayout(preferredSize: DoubleVector): TileLayoutInfo {\n\n        var (xAxisInfo, yAxisInfo) = computeAxisInfos(\n            xAxisLayout,\n            yAxisLayout,\n            preferredSize\n        )\n\n        var geomBounds = geomBounds(\n            xAxisThickness = xAxisInfo.axisBounds().dimension.y,\n            yAxisThickness = yAxisInfo.axisBounds().dimension.x,\n            preferredSize\n        )\n\n        // X-axis labels bounds may exceed axis length - adjust\n        run {\n            val maxTickLabelsBounds = maxTickLabelsBounds(\n                Orientation.BOTTOM,\n                0.0,\n                geomBounds,\n                preferredSize\n            )\n            val tickLabelsBounds = xAxisInfo.tickLabelsBounds\n            val leftOverflow = maxTickLabelsBounds.left - tickLabelsBounds!!.origin.x\n            val rightOverflow = tickLabelsBounds.origin.x + tickLabelsBounds.dimension.x - maxTickLabelsBounds.right\n            if (leftOverflow > 0) {\n                geomBounds = DoubleRectangle(\n                    geomBounds.origin.x + leftOverflow,\n                    geomBounds.origin.y,\n                    geomBounds.dimension.x - leftOverflow,\n                    geomBounds.dimension.y\n                )\n            }\n            if (rightOverflow > 0) {\n                geomBounds = DoubleRectangle(\n                    geomBounds.origin.x,\n                    geomBounds.origin.y,\n                    geomBounds.dimension.x - rightOverflow,\n                    geomBounds.dimension.y\n                )\n            }\n        }\n\n        geomBounds = geomBounds.union(\n            DoubleRectangle(geomBounds.origin, GEOM_MIN_SIZE)\n        )\n\n        // Combine geom area and x/y axis\n        val geomWithAxisBounds =\n            tileBounds(\n                xAxisInfo.axisBounds(),\n                yAxisInfo.axisBounds(),\n                geomBounds\n            )\n\n        // sync axis info with new (may be) geom area size\n        xAxisInfo = xAxisInfo.withAxisLength(geomBounds.width).build()\n        yAxisInfo = yAxisInfo.withAxisLength(geomBounds.height).build()\n\n        return TileLayoutInfo(\n            geomWithAxisBounds,\n            geomBounds,\n            clipBounds(geomBounds),\n            xAxisInfo,\n            yAxisInfo,\n            trueIndex = 0\n        )\n    }\n\n    companion object {\n        private const val AXIS_STRETCH_RATIO = 0.1  // allow 10% axis flexibility (on each end)\n\n        private fun tileBounds(\n            xAxisBounds: DoubleRectangle,\n            yAxisBounds: DoubleRectangle,\n            geomBounds: DoubleRectangle\n        ): DoubleRectangle {\n            // Can't just union bounds because\n            // x-axis has zero origin\n            // y-axis has negative origin\n            val leftTop = DoubleVector(\n                geomBounds.left - yAxisBounds.width,\n                geomBounds.top - GEOM_MARGIN\n            )\n            val rightBottom = DoubleVector(\n                geomBounds.right + GEOM_MARGIN,\n                geomBounds.bottom + xAxisBounds.height\n            )\n            return DoubleRectangle(leftTop, rightBottom.subtract(leftTop))\n        }\n\n        private fun computeAxisInfos(\n            xAxisLayout: AxisLayout,\n            yAxisLayout: AxisLayout,\n            plotSize: DoubleVector\n        ): Pair<AxisLayoutInfo, AxisLayoutInfo> {\n            val xAxisThickness = xAxisLayout.initialThickness()\n            var yAxisInfo = computeYAxisInfo(\n                yAxisLayout,\n                geomBounds(\n                    xAxisThickness,\n                    yAxisLayout.initialThickness(),\n                    plotSize\n                )\n            )\n\n            val yAxisThickness = yAxisInfo.axisBounds().dimension.x\n            var xAxisInfo = computeXAxisInfo(\n                xAxisLayout,\n                plotSize, geomBounds(\n                    xAxisThickness,\n                    yAxisThickness,\n                    plotSize\n                )\n            )\n\n            if (xAxisInfo.axisBounds().dimension.y > xAxisThickness) {\n                // Re-layout y-axis if x-axis became thicker than its 'original thickness'.\n                yAxisInfo = computeYAxisInfo(\n                    yAxisLayout,\n                    geomBounds(\n                        xAxisInfo.axisBounds().dimension.y,\n                        yAxisThickness,\n                        plotSize\n                    )\n                )\n            }\n\n            return Pair(xAxisInfo, yAxisInfo)\n        }\n\n        private fun computeXAxisInfo(\n            axisLayout: AxisLayout,\n            plotSize: DoubleVector,\n            geomBounds: DoubleRectangle\n        ): AxisLayoutInfo {\n            val axisLength = geomBounds.dimension.x\n            val stretch = axisLength * AXIS_STRETCH_RATIO\n            val maxTickLabelsBounds = maxTickLabelsBounds(\n                Orientation.BOTTOM,\n                stretch,\n                geomBounds,\n                plotSize\n            )\n            return axisLayout.doLayout(geomBounds.dimension, maxTickLabelsBounds)\n        }\n\n        private fun computeYAxisInfo(\n            axisLayout: AxisLayout,\n            geomBounds: DoubleRectangle\n        ): AxisLayoutInfo {\n            return axisLayout.doLayout(geomBounds.dimension, null)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\ninternal class AdaptableAxisBreaksProvider(\n    private val domainAfterTransform: ClosedRange<Double>,\n    private val breaksGenerator: BreaksGenerator\n) : AxisBreaksProvider {\n\n    override val isFixedBreaks: Boolean\n        get() = false\n\n    override val fixedBreaks: ScaleBreaks\n        get() = throw IllegalStateException(\"Not a fixed breaks provider\")\n\n    override fun getBreaks(targetCount: Int, axisLength: Double): ScaleBreaks {\n        @Suppress(\"UnnecessaryVariable\")\n        val scaleBreaks = breaksGenerator.generateBreaks(domainAfterTransform, targetCount)\n        return scaleBreaks\n//        return ScaleBreaks(\n//            scaleBreaks.domainValues,\n//            scaleBreaks.transformedValues,\n//            scaleBreaks.labels\n//        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Scale\n\nobject AxisBreaksUtil {\n    fun createAxisBreaksProvider(scale: Scale<Double>, axisDomain: ClosedRange<Double>): AxisBreaksProvider = when {\n        scale.hasBreaks() -> {\n            FixedAxisBreaksProvider(scale.getScaleBreaks())\n        }\n        else -> {\n            AdaptableAxisBreaksProvider(\n                axisDomain,\n                scale.getBreaksGenerator()\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.layout.AxisLayoutInfo\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nabstract class AxisLayouter(\n    val orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    private val domainRange: ClosedRange<Double>,\n    private val labelsLayout: AxisLabelsLayout\n) {\n\n    fun doLayout(axisLength: Double, maxTickLabelsBounds: DoubleRectangle?): AxisLayoutInfo {\n        val labelsInfo = labelsLayout.doLayout(axisLength, toAxisMapper(axisLength), maxTickLabelsBounds)\n        val labelsBounds = labelsInfo.bounds\n\n        val builder = AxisLayoutInfo.Builder()\n            .axisBreaks(labelsInfo.breaks)\n            .axisLength(axisLength)\n            .orientation(orientation)\n            .axisDomain(domainRange)\n            .tickLabelsBoundsMax(maxTickLabelsBounds)\n            // todo: add 1 labels info object\n            .tickLabelSmallFont(labelsInfo.smallFont)\n            .tickLabelAdditionalOffsets(labelsInfo.labelAdditionalOffsets)\n            .tickLabelHorizontalAnchor(labelsInfo.labelHorizontalAnchor)\n            .tickLabelVerticalAnchor(labelsInfo.labelVerticalAnchor)\n            .tickLabelRotationAngle(labelsInfo.labelRotationAngle)\n            .tickLabelsBounds(labelsBounds)\n\n        return builder.build()\n    }\n\n    protected abstract fun toAxisMapper(axisLength: Double): (Double?) -> Double?\n\n    protected fun toScaleMapper(axisLength: Double): (Double?) -> Double? {\n        return Mappers.mul(domainRange, axisLength)\n    }\n\n    companion object {\n        fun create(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme\n        ): AxisLayouter {\n\n            if (orientation.isHorizontal) {\n                val labelsLayout: AxisLabelsLayout = if (breaksProvider.isFixedBreaks) {\n                    AxisLabelsLayout.horizontalFixedBreaks(\n                        orientation,\n                        axisDomain,\n                        breaksProvider.fixedBreaks,\n                        theme\n                    )\n                } else {\n                    AxisLabelsLayout.horizontalFlexBreaks(orientation, axisDomain, breaksProvider, theme)\n                }\n                return HorizontalAxisLayouter(\n                    orientation,\n                    axisDomain,\n                    labelsLayout\n                )\n            }\n\n            // vertical\n            val labelsLayout: AxisLabelsLayout = if (breaksProvider.isFixedBreaks) {\n                AxisLabelsLayout.verticalFixedBreaks(orientation, axisDomain, breaksProvider.fixedBreaks, theme)\n            } else {\n                AxisLabelsLayout.verticalFlexBreaks(orientation, axisDomain, breaksProvider, theme)\n            }\n            return VerticalAxisLayouter(\n                orientation,\n                axisDomain,\n                labelsLayout\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\n//class FixedAxisBreaksProvider(\n//    domainBreaks: List<Any>,\n//    transformedBreaks: List<Double>,\n//    labels: List<String>\n//) : AxisBreaksProvider {\nclass FixedAxisBreaksProvider(\n    override val fixedBreaks: ScaleBreaks\n) : AxisBreaksProvider {\n\n//    override val fixedBreaks: ScaleBreaks = ScaleBreaks(\n//        domainBreaks,\n//        transformedBreaks,\n//        labels\n//    )\n\n    override val isFixedBreaks: Boolean\n        get() = true\n\n    override fun getBreaks(targetCount: Int, axisLength: Double): ScaleBreaks {\n        return fixedBreaks\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\n\nclass HorizontalAxisLayouter(\n    orientation: Orientation,\n    domainRange: ClosedRange<Double>,\n    labelsLayout: AxisLabelsLayout\n) : AxisLayouter(orientation, domainRange, labelsLayout) {\n\n    override fun toAxisMapper(axisLength: Double): (Double?) -> Double? {\n        val scaleMapper = toScaleMapper(axisLength)\n        val cartesianX = Coords.toClientOffsetX(ClosedRange(0.0, axisLength))\n        return { v ->\n            val mapped = scaleMapper(v)\n            if (mapped != null) cartesianX(mapped) else null\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.coord.Coords\nimport jetbrains.datalore.plot.builder.layout.axis.label.AxisLabelsLayout\n\nclass VerticalAxisLayouter(orientation: jetbrains.datalore.plot.builder.guide.Orientation, domainRange: ClosedRange<Double>, labelsLayout: AxisLabelsLayout) : AxisLayouter(orientation, domainRange, labelsLayout) {\n\n    override fun toAxisMapper(axisLength: Double): (Double?) -> Double? {\n        val scaleMapper = toScaleMapper(axisLength)\n        val cartesianY = Coords.toClientOffsetY(ClosedRange(0.0, axisLength))\n        return { v ->\n            val mapped = scaleMapper(v)\n            if (mapped != null) cartesianY(mapped) else null\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal abstract class AbstractFixedBreaksLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    protected val breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    private fun labelBounds(labelLocation: DoubleVector, labelLength: Int): DoubleRectangle {\n        val dim = labelSpec.dimensions(labelLength)\n        val labelBounds = labelBounds(dim)\n        return labelBounds.add(labelLocation)\n    }\n\n    protected abstract fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle\n\n    fun labelsBounds(\n        tickPositions: List<Double>,\n        @Suppress(\"UNUSED_PARAMETER\") tickLabels: List<String>,\n        toTickLocation: (Double) -> DoubleVector\n    ): DoubleRectangle? {\n        val boundsList = labelBoundsList(tickPositions, breaks.labels, toTickLocation)\n        var bounds: DoubleRectangle? = null\n        for (labelBounds in boundsList) {\n            bounds = GeometryUtil.union(labelBounds, bounds)\n        }\n        return bounds\n    }\n\n    fun labelBoundsList(\n        tickPositions: List<Double>,\n        tickLabels: List<String>,\n        toTickLocation: (Double) -> DoubleVector\n    ): List<DoubleRectangle> {\n        val result = ArrayList<DoubleRectangle>()\n        val labels = tickLabels.iterator()\n        for (pos in tickPositions) {\n            val label = labels.next()\n            val bounds = labelBounds(toTickLocation(pos), label.length)\n            result.add(bounds)\n        }\n        return result\n    }\n\n\n    fun createAxisLabelsLayoutInfoBuilder(bounds: DoubleRectangle, overlap: Boolean): AxisLabelsLayoutInfo.Builder {\n        return AxisLabelsLayoutInfo.Builder()\n            .breaks(breaks)\n            .bounds(applyLabelsOffset(bounds))\n            .smallFont(false)\n            .overlap(overlap)\n    }\n\n    fun noLabelsLayoutInfo(\n        axisLength: Double,\n        orientation: jetbrains.datalore.plot.builder.guide.Orientation\n    ): AxisLabelsLayoutInfo {\n        if (orientation.isHorizontal) {\n            var bounds = DoubleRectangle(axisLength / 2, 0.0, 0.0, 0.0) // empty bounds in the middle of the axis;\n            bounds = applyLabelsOffset(bounds)\n            return AxisLabelsLayoutInfo.Builder()\n                .breaks(breaks)\n                .bounds(bounds)\n                .smallFont(false)\n                .overlap(false)\n                .labelAdditionalOffsets(null)\n                .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n                .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n                .build()\n        }\n\n        throw IllegalStateException(\"Not implemented for $orientation\")\n    }\n\n    companion object {\n        val HORIZONTAL_TICK_LOCATION = { x: Double -> DoubleVector(x, 0.0) }\n    }\n\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\nabstract class AxisLabelsLayout protected constructor(\n    val orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    val axisDomain: ClosedRange<Double>,\n    val labelSpec: PlotLabelSpec,\n    val theme: AxisTheme\n) {\n\n    protected val isHorizontal: Boolean\n        get() = orientation.isHorizontal\n\n    abstract fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo\n\n    internal fun mapToAxis(\n        breaks: List<Double>,\n        axisMapper: (Double?) -> Double?\n    ): List<Double> {\n\n        return BreakLabelsLayoutUtil.mapToAxis(\n            breaks,\n            axisDomain,\n            axisMapper\n        )\n    }\n\n    internal fun applyLabelsOffset(labelsBounds: DoubleRectangle): DoubleRectangle {\n        return BreakLabelsLayoutUtil.applyLabelsOffset(\n            labelsBounds,\n            theme.tickLabelDistance(),\n            orientation\n        )\n    }\n\n    companion object {\n        val TICK_LABEL_SPEC = PlotLabelSpec.AXIS_TICK\n        const val INITIAL_TICK_LABEL_LENGTH = 4 // symbols\n        const val MIN_TICK_LABEL_DISTANCE = 20.0  // px\n        val TICK_LABEL_SPEC_SMALL = PlotLabelSpec.AXIS_TICK_SMALL\n\n        fun horizontalFlexBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(orientation.isHorizontal) { orientation.toString() }\n            require(!breaksProvider.isFixedBreaks) { \"fixed breaks\" }\n            return HorizontalFlexBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaksProvider,\n                theme\n            )\n        }\n\n        fun horizontalFixedBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaks: ScaleBreaks, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(orientation.isHorizontal) { orientation.toString() }\n            return HorizontalFixedBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaks,\n                theme\n            )\n        }\n\n        fun verticalFlexBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>, breaksProvider: AxisBreaksProvider, theme: AxisTheme\n        ): AxisLabelsLayout {\n\n            require(!orientation.isHorizontal) { orientation.toString() }\n            require(!breaksProvider.isFixedBreaks) { \"fixed breaks\" }\n            return VerticalFlexBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaksProvider,\n                theme\n            )\n        }\n\n        fun verticalFixedBreaks(\n            orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n            axisDomain: ClosedRange<Double>,\n            breaks: ScaleBreaks,\n            theme: AxisTheme\n        ): AxisLabelsLayout {\n            require(!orientation.isHorizontal) { orientation.toString() }\n            return VerticalFixedBreaksLabelsLayout(\n                orientation,\n                axisDomain,\n                TICK_LABEL_SPEC,\n                breaks,\n                theme\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\n\nclass AxisLabelsLayoutInfo private constructor(b: Builder) {\n    val breaks: ScaleBreaks?\n    val bounds: DoubleRectangle?\n    val smallFont: Boolean\n    val labelAdditionalOffsets: List<DoubleVector>?\n    val labelHorizontalAnchor: TextLabel.HorizontalAnchor?\n    val labelVerticalAnchor: TextLabel.VerticalAnchor?\n    val labelRotationAngle: Double\n    internal val isOverlap: Boolean\n\n\n    init {\n        this.breaks = b.myBreaks\n        this.smallFont = b.mySmallFont\n        this.bounds = b.myBounds\n        this.isOverlap = b.myOverlap\n        this.labelAdditionalOffsets = if (b.myLabelAdditionalOffsets == null)\n            null\n        else\n            ArrayList(b.myLabelAdditionalOffsets!!)\n        this.labelHorizontalAnchor = b.myLabelHorizontalAnchor\n        this.labelVerticalAnchor = b.myLabelVerticalAnchor\n        this.labelRotationAngle = b.myLabelRotationAngle\n    }\n\n    class Builder {\n        internal var myBreaks: ScaleBreaks? = null\n        internal var myBounds: DoubleRectangle? = null\n        internal var mySmallFont: Boolean = false\n        internal var myOverlap: Boolean = false\n        internal var myLabelAdditionalOffsets: List<DoubleVector>? = null\n        internal var myLabelHorizontalAnchor: TextLabel.HorizontalAnchor? = null\n        internal var myLabelVerticalAnchor: TextLabel.VerticalAnchor? = null\n        internal var myLabelRotationAngle = 0.0\n\n        fun breaks(breaks: ScaleBreaks): Builder {\n            myBreaks = breaks\n            return this\n        }\n\n        fun bounds(bounds: DoubleRectangle): Builder {\n            myBounds = bounds\n            return this\n        }\n\n        fun smallFont(b: Boolean): Builder {\n            mySmallFont = b\n            return this\n        }\n\n        fun overlap(b: Boolean): Builder {\n            myOverlap = b\n            return this\n        }\n\n        fun labelAdditionalOffsets(l: List<DoubleVector>?): Builder {\n            myLabelAdditionalOffsets = l\n            return this\n        }\n\n        fun labelHorizontalAnchor(anchor: TextLabel.HorizontalAnchor): Builder {\n            myLabelHorizontalAnchor = anchor\n            return this\n        }\n\n        fun labelVerticalAnchor(anchor: TextLabel.VerticalAnchor): Builder {\n            myLabelVerticalAnchor = anchor\n            return this\n        }\n\n        fun labelRotationAngle(angle: Double): Builder {\n            myLabelRotationAngle = angle\n            return this\n        }\n\n        fun build(): AxisLabelsLayoutInfo {\n            return AxisLabelsLayoutInfo(this)\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation.*\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.max\nimport kotlin.math.min\n\ninternal object BreakLabelsLayoutUtil {\n\n    fun getFlexBreaks(breaksProvider: AxisBreaksProvider, maxCount: Int, axisLength: Double): ScaleBreaks {\n        require(!breaksProvider.isFixedBreaks) { \"fixed breaks not expected\" }\n        require(maxCount > 0) { \"maxCount=$maxCount\" }\n        var breaks = breaksProvider.getBreaks(maxCount, axisLength)\n\n        if (maxCount == 1 && !breaks.isEmpty) {\n            return ScaleBreaks(\n                breaks.domainValues.subList(0, 1),\n                breaks.transformedValues.subList(0, 1),\n                breaks.labels.subList(0, 1)\n            )\n        }\n        var count = maxCount\n        while (breaks.size > maxCount) {\n            val delta = max(1, (breaks.size - maxCount) / 2)\n            count -= delta\n            breaks = breaksProvider.getBreaks(count, axisLength)\n        }\n        return breaks\n    }\n\n    fun maxLength(labels: List<String>): Int {\n        var max = 0\n        for (label in labels) {\n            max = max(max, label.length)\n        }\n        return max\n    }\n\n    fun horizontalCenteredLabelBounds(labelSize: DoubleVector): DoubleRectangle {\n        return DoubleRectangle(-labelSize.x / 2.0, 0.0, labelSize.x, labelSize.y)\n    }\n\n    fun doLayoutVerticalAxisLabels(\n        orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n        breaks: ScaleBreaks,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?,\n        theme: AxisTheme\n    ): AxisLabelsLayoutInfo {\n\n        val axisBounds = when {\n            theme.showTickLabels() -> {\n                val labelsBounds =\n                    verticalAxisLabelsBounds(\n                        breaks,\n                        axisDomain,\n                        axisMapper\n                    )\n                applyLabelsOffset(\n                    labelsBounds,\n                    theme.tickLabelDistance(),\n                    orientation\n                )\n            }\n            theme.showTickMarks() -> {\n                val labelsBounds = DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n                applyLabelsOffset(\n                    labelsBounds,\n                    theme.tickLabelDistance(),\n                    orientation\n                )\n            }\n            else -> DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        }\n\n        return AxisLabelsLayoutInfo.Builder()\n            .breaks(breaks)\n            .bounds(axisBounds)     // label bounds actually\n            .build()\n    }\n\n    fun mapToAxis(\n        breaks: List<Double>,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?\n    ): List<Double> {\n        val axisMin = axisDomain.lowerEnd\n        val axisBreaks = ArrayList<Double>()\n        for (v in breaks) {\n            val mapped = axisMapper(v - axisMin)\n            axisBreaks.add(mapped!!)\n        }\n        return axisBreaks\n    }\n\n    fun applyLabelsOffset(\n        labelsBounds: DoubleRectangle,\n        offset: Double,\n        orientation: jetbrains.datalore.plot.builder.guide.Orientation\n    ): DoubleRectangle {\n        @Suppress(\"NAME_SHADOWING\")\n        var labelsBounds = labelsBounds\n        val offsetVector = when (orientation) {\n            LEFT -> DoubleVector(-offset, 0.0)\n            RIGHT -> DoubleVector(offset, 0.0)\n            TOP -> DoubleVector(0.0, -offset)\n            BOTTOM -> DoubleVector(0.0, offset)\n        }\n\n        if (orientation === RIGHT || orientation === BOTTOM) {\n            labelsBounds = labelsBounds.add(offsetVector)\n        } else if (orientation === LEFT || orientation === TOP) {\n            labelsBounds = labelsBounds.add(offsetVector).subtract(DoubleVector(labelsBounds.width, 0.0))\n        }\n\n        return labelsBounds\n    }\n\n\n    private fun verticalAxisLabelsBounds(\n        breaks: ScaleBreaks,\n        axisDomain: ClosedRange<Double>,\n        axisMapper: (Double?) -> Double?\n    ): DoubleRectangle {\n        val maxLength =\n            maxLength(breaks.labels)\n        val maxLabelWidth = AxisLabelsLayout.TICK_LABEL_SPEC.width(maxLength)\n        var y1 = 0.0\n        var y2 = 0.0\n        if (!breaks.isEmpty) {\n            val axisBreaks =\n                mapToAxis(\n                    breaks.transformedValues,\n                    axisDomain,\n                    axisMapper\n                )\n\n            y1 = min(axisBreaks[0], Iterables.getLast(axisBreaks))\n            y2 = max(axisBreaks[0], Iterables.getLast(axisBreaks))\n            y1 -= AxisLabelsLayout.TICK_LABEL_SPEC.height() / 2\n            y2 += AxisLabelsLayout.TICK_LABEL_SPEC.height() / 2\n        }\n\n        val origin = DoubleVector(0.0, y1)\n        val dimensions = DoubleVector(maxLabelWidth, y2 - y1)\n        return DoubleRectangle(origin, dimensions)\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalFixedBreaksLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(\n    orientation,\n    axisDomain,\n    labelSpec,\n    breaks,\n    theme\n) {\n    init {\n        require(orientation.isHorizontal) { orientation.toString() }\n    }\n\n    private fun overlap(labelsInfo: AxisLabelsLayoutInfo, maxTickLabelsBounds: DoubleRectangle?): Boolean {\n        return labelsInfo.isOverlap || maxTickLabelsBounds != null && !(maxTickLabelsBounds.xRange()\n            .encloses(labelsInfo.bounds!!.xRange()) && maxTickLabelsBounds.yRange()\n            .encloses(labelsInfo.bounds.yRange()))\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n        if (!theme.showTickLabels()) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        var labelsInfo = simpleLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n        if (overlap(labelsInfo, maxLabelsBounds)) {\n            labelsInfo = multilineLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n            if (overlap(labelsInfo, maxLabelsBounds)) {\n                labelsInfo = tiltedLayout().doLayout(axisLength, axisMapper, maxLabelsBounds)\n                if (overlap(labelsInfo, maxLabelsBounds)) {\n                    labelsInfo = verticalLayout(labelSpec).doLayout(axisLength, axisMapper, maxLabelsBounds)\n                    if (overlap(labelsInfo, maxLabelsBounds)) {\n                        labelsInfo =\n                            verticalLayout(TICK_LABEL_SPEC_SMALL).doLayout(axisLength, axisMapper, maxLabelsBounds)\n                    }\n                }\n            }\n        }\n        return labelsInfo\n    }\n\n    private fun simpleLayout(): AxisLabelsLayout {\n        return HorizontalSimpleLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    private fun multilineLayout(): AxisLabelsLayout {\n        return HorizontalMultilineLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme,\n            2\n        )\n    }\n\n    private fun tiltedLayout(): AxisLabelsLayout {\n        return HorizontalTiltedLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    private fun verticalLayout(labelSpec: PlotLabelSpec): AxisLabelsLayout {\n        return HorizontalVerticalLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        throw IllegalStateException(\"Not implemented here\")\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalFlexBreaksLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    private val myBreaksProvider: AxisBreaksProvider,\n    theme: AxisTheme\n) :\n    AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    init {\n        require(orientation.isHorizontal) { orientation.toString() }\n        require(!myBreaksProvider.isFixedBreaks) { \"fixed breaks\" }\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        var targetBreakCount =\n            HorizontalSimpleLabelsLayout.estimateBreakCountInitial(\n                axisLength\n            )\n        var breaks = getBreaks(targetBreakCount, axisLength)\n        var labelsInfo = doLayoutLabels(breaks, axisLength, axisMapper, maxLabelsBounds)\n\n        while (labelsInfo.isOverlap) {\n            // reduce tick count\n            val newTargetBreakCount =\n                HorizontalSimpleLabelsLayout.estimateBreakCount(\n                    breaks.labels,\n                    axisLength\n                )\n            if (newTargetBreakCount >= targetBreakCount) {\n                // paranoid - highly impossible.\n                break\n            }\n            targetBreakCount = newTargetBreakCount\n            breaks = getBreaks(targetBreakCount, axisLength)\n            labelsInfo = doLayoutLabels(breaks, axisLength, axisMapper, maxLabelsBounds)\n        }\n\n        return labelsInfo\n    }\n\n    private fun doLayoutLabels(\n        breaks: ScaleBreaks,\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        val layout = HorizontalSimpleLabelsLayout(\n            orientation,\n            axisDomain,\n            labelSpec,\n            breaks,\n            theme\n        )\n        return layout.doLayout(axisLength, axisMapper, maxLabelsBounds)\n    }\n\n    private fun getBreaks(maxCount: Int, axisLength: Double): ScaleBreaks {\n        return BreakLabelsLayoutUtil.getFlexBreaks(\n            myBreaksProvider,\n            maxCount,\n            axisLength\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class HorizontalMultilineLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme,\n    private val myMaxLines: Int\n) : AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    private val myShelfIndexForTickIndex = ArrayList<Int>()\n\n    private val labelAdditionalOffsets: List<DoubleVector>\n        get() {\n            val h = labelSpec.height() * LINE_HEIGHT\n            val result = ArrayList<DoubleVector>()\n            for (i in 0 until breaks.size) {\n                result.add(DoubleVector(0.0, myShelfIndexForTickIndex[i] * h))\n            }\n            return result\n        }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        val boundsByShelfIndex = HashMap<Int, DoubleRectangle>()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        val boundsList = labelBoundsList(\n            ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n\n        for (labelBounds in boundsList) {\n            // find shelf with no overlap\n            var shelfIndex = 0\n            while (true) {\n                if (!boundsByShelfIndex.containsKey(shelfIndex)) {\n                    boundsByShelfIndex[shelfIndex] = labelBounds\n                    myShelfIndexForTickIndex.add(shelfIndex)\n                    break\n                }\n\n                var shelfBounds = boundsByShelfIndex[shelfIndex]!!\n                // not overlapped?\n                if (!shelfBounds.xRange()\n                        .isConnected(ClosedRange(labelBounds.left - MIN_DISTANCE, labelBounds.right + MIN_DISTANCE))\n                ) {\n                    myShelfIndexForTickIndex.add(shelfIndex)\n                    shelfBounds = shelfBounds.union(labelBounds)\n                    boundsByShelfIndex[shelfIndex] = shelfBounds\n                    break\n                }\n\n                shelfIndex++\n            }\n        }\n\n        var bounds = if (boundsByShelfIndex.isEmpty())\n            DoubleRectangle(DoubleVector.ZERO, DoubleVector.ZERO)\n        else\n            boundsByShelfIndex[0]!!\n        val h = labelSpec.height() * LINE_HEIGHT\n        for (i in 0 until boundsByShelfIndex.size) {\n            val shelfBounds = boundsByShelfIndex[i]!!\n            bounds = bounds.union(shelfBounds.add(DoubleVector(0.0, i * h)))\n        }\n\n        val linesCount = boundsByShelfIndex.size\n        return AxisLabelsLayoutInfo.Builder()\n            .breaks(breaks)\n            .bounds(applyLabelsOffset(bounds))\n            .smallFont(false)\n            .overlap(linesCount > myMaxLines)\n            .labelAdditionalOffsets(labelAdditionalOffsets)\n            .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n            .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n            .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        return BreakLabelsLayoutUtil.horizontalCenteredLabelBounds(\n            labelNormalSize\n        )\n    }\n\n    companion object {\n        private const val LINE_HEIGHT = 1.2\n        private const val MIN_DISTANCE = 60\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.layout.GeometryUtil\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\n\ninternal class HorizontalSimpleLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        if (breaks.isEmpty) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        if (!theme.showTickLabels()) {\n            return noLabelsLayoutInfo(axisLength, orientation)\n        }\n\n        var bounds: DoubleRectangle? = null\n        var overlap = false\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n\n        val boundsList = labelBoundsList(\n            ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        for (labelBounds in boundsList) {\n            overlap = overlap || bounds != null && bounds.xRange().isConnected(\n                SeriesUtil.expand(labelBounds.xRange(), MIN_TICK_LABEL_DISTANCE / 2, MIN_TICK_LABEL_DISTANCE / 2.0)\n            )\n            bounds = GeometryUtil.union(labelBounds, bounds)\n        }\n\n        return AxisLabelsLayoutInfo.Builder()\n            .breaks(breaks)\n            .bounds(applyLabelsOffset(bounds!!))\n            .smallFont(false)\n            .overlap(overlap)\n            .labelAdditionalOffsets(null)\n            .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n            .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n            .build()\n    }\n\n    /*\n  private AxisLabelsLayoutInfo noLabelsLayoutInfo(double axisLength) {\n    DoubleRectangle bounds = new DoubleRectangle(axisLength / 2, 0, 0, 0); // empty bounds in the middle of the axis;\n    bounds = BreakLabelsLayoutUtil.applyLabelsOffset(bounds, myTheme.tickLabelDistance(), getOrientation());\n    return new AxisLabelsLayoutInfo.Builder()\n        .breaks(getBreaks())\n        //.bounds(applyLabelsOffset(bounds))\n        .bounds(bounds)\n        .smallFont(false)\n        .overlap(false)\n        .labelAdditionalOffsets(null)\n        .labelHorizontalAnchor(TextLabel.HorizontalAnchor.MIDDLE)\n        .labelVerticalAnchor(TextLabel.VerticalAnchor.TOP)\n        .build();\n  }\n  */\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        return BreakLabelsLayoutUtil.horizontalCenteredLabelBounds(\n            labelNormalSize\n        )\n    }\n\n    companion object {\n        fun estimateBreakCountInitial(axisLength: Double): Int {\n            return estimateBreakCount(\n                INITIAL_TICK_LABEL_LENGTH,\n                axisLength\n            )\n        }\n\n        fun estimateBreakCount(labels: List<String>, axisLength: Double): Int {\n            val maxLength =\n                BreakLabelsLayoutUtil.maxLength(\n                    labels\n                )\n            return estimateBreakCount(\n                maxLength,\n                axisLength\n            )\n        }\n\n        private fun estimateBreakCount(labelLength: Int, axisLength: Double): Int {\n            val tickDistance = TICK_LABEL_SPEC.width(labelLength) + MIN_TICK_LABEL_DISTANCE\n            return max(1.0, axisLength / tickDistance).toInt()\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.math.toRadians\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.abs\nimport kotlin.math.cos\nimport kotlin.math.sin\n\ninternal class HorizontalTiltedLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    private val labelHorizontalAnchor: TextLabel.HorizontalAnchor\n        get() {\n            if (orientation === BOTTOM) {\n                return TextLabel.HorizontalAnchor.RIGHT\n            }\n            throw RuntimeException(\"Not implemented\")\n        }\n\n    private val labelVerticalAnchor: TextLabel.VerticalAnchor\n        get() = TextLabel.VerticalAnchor.TOP\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        val height = labelSpec.height()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        var overlap = false\n        if (breaks.size >= 2) {\n            val minTickDistance = abs((height + MIN_DISTANCE) / SIN)\n            val tickDistance = abs(ticks[0] - ticks[1])\n            overlap = tickDistance < minTickDistance\n        }\n\n        val bounds = labelsBounds(\n            ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        return createAxisLabelsLayoutInfoBuilder(bounds!!, overlap)\n            .labelHorizontalAnchor(labelHorizontalAnchor)\n            .labelVerticalAnchor(labelVerticalAnchor)\n            .labelRotationAngle(ROTATION_DEGREE)\n            .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        // only works for RIGHT-TOP anchor ang angle 0...-90\n        if (!(ROTATION_DEGREE >= -90 && ROTATION_DEGREE <= 0\n                    && labelHorizontalAnchor === TextLabel.HorizontalAnchor.RIGHT\n                    && labelVerticalAnchor === TextLabel.VerticalAnchor.TOP)\n        ) {\n            throw RuntimeException(\"Not implemented\")\n        }\n\n\n        val w = abs(labelNormalSize.x * COS) + 2 * abs(labelNormalSize.y * SIN)\n        val h = abs(labelNormalSize.x * SIN) + abs(labelNormalSize.y * COS)\n        val x = -(abs(labelNormalSize.x * COS) + abs(labelNormalSize.y * SIN))\n        val y = 0.0\n\n        return DoubleRectangle(x, y, w, h)\n    }\n\n    companion object {\n        private const val MIN_DISTANCE = 5.0\n        private const val ROTATION_DEGREE = -30.0\n\n        private val SIN = sin(toRadians(ROTATION_DEGREE))\n        private val COS = cos(toRadians(ROTATION_DEGREE))\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.render.svg.TextLabel\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.guide.Orientation.BOTTOM\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.abs\n\ninternal class HorizontalVerticalLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(orientation, axisDomain, labelSpec, breaks, theme) {\n\n    val labelHorizontalAnchor: TextLabel.HorizontalAnchor\n        get() {\n            if (orientation === BOTTOM) {\n                return TextLabel.HorizontalAnchor.LEFT\n            }\n            throw RuntimeException(\"Not implemented\")\n        }\n\n    val labelVerticalAnchor: TextLabel.VerticalAnchor\n        get() = TextLabel.VerticalAnchor.CENTER\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        val height = labelSpec.height()\n        val ticks = mapToAxis(breaks.transformedValues, axisMapper)\n        var overlap = false\n        if (breaks.size >= 2) {\n            val minTickDistance = height + MIN_DISTANCE\n            val tickDistance = abs(ticks[0] - ticks[1])\n            overlap = tickDistance < minTickDistance\n        }\n\n        val bounds = labelsBounds(\n            ticks, breaks.labels,\n            HORIZONTAL_TICK_LOCATION\n        )\n        return createAxisLabelsLayoutInfoBuilder(bounds!!, overlap)\n            .labelHorizontalAnchor(labelHorizontalAnchor)\n            .labelVerticalAnchor(labelVerticalAnchor)\n            .labelRotationAngle(ROTATION_DEGREE)\n            .build()\n    }\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        if (!(ROTATION_DEGREE == 90.0\n                    && labelHorizontalAnchor === TextLabel.HorizontalAnchor.LEFT\n                    && labelVerticalAnchor === TextLabel.VerticalAnchor.CENTER)\n        ) {\n            throw RuntimeException(\"Not implemented\")\n        }\n        val w = labelNormalSize.y\n        val h = labelNormalSize.x\n        val x = -w / 2\n        val y = 0.0\n        return DoubleRectangle(x, y, w, h)\n    }\n\n    companion object {\n        private const val MIN_DISTANCE = 5.0\n        private const val ROTATION_DEGREE = 90.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.guide.Orientation\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\n\ninternal class VerticalFixedBreaksLabelsLayout(\n    orientation: Orientation,\n    axisDomain: ClosedRange<Double>,\n    tickLabelSpec: PlotLabelSpec,\n    breaks: ScaleBreaks,\n    theme: AxisTheme\n) : AbstractFixedBreaksLabelsLayout(orientation, axisDomain, tickLabelSpec, breaks, theme) {\n\n    override fun labelBounds(labelNormalSize: DoubleVector): DoubleRectangle {\n        throw IllegalStateException(\"Not implemented here\")\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        return BreakLabelsLayoutUtil.doLayoutVerticalAxisLabels(\n            orientation, breaks,\n            axisDomain,\n            axisMapper,\n            theme\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.layout.axis.label\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.geometry.DoubleRectangle\nimport jetbrains.datalore.plot.base.scale.ScaleBreaks\nimport jetbrains.datalore.plot.builder.layout.axis.AxisBreaksProvider\nimport jetbrains.datalore.plot.builder.presentation.PlotLabelSpec\nimport jetbrains.datalore.plot.builder.theme.AxisTheme\nimport kotlin.math.ceil\n\ninternal class VerticalFlexBreaksLabelsLayout(\n    orientation: jetbrains.datalore.plot.builder.guide.Orientation,\n    axisDomain: ClosedRange<Double>,\n    labelSpec: PlotLabelSpec,\n    private val myBreaksProvider: AxisBreaksProvider,\n    theme: AxisTheme\n) :\n    AxisLabelsLayout(orientation, axisDomain, labelSpec, theme) {\n\n    private fun maxTickCount(axisLength: Double): Int {\n        return ceil(axisLength / (TICK_LABEL_SPEC.height() + MIN_TICK_LABEL_DISTANCE)).toInt()\n    }\n\n    init {\n        require(!orientation.isHorizontal) { orientation.toString() }\n        require(!myBreaksProvider.isFixedBreaks) { \"fixed breaks\" }\n    }\n\n    override fun doLayout(\n        axisLength: Double,\n        axisMapper: (Double?) -> Double?,\n        maxLabelsBounds: DoubleRectangle?\n    ): AxisLabelsLayoutInfo {\n\n        require(axisLength > 0) { \"axis length: $axisLength\" }\n        val maxTickCount = maxTickCount(axisLength)\n        val breaks = getBreaks(maxTickCount, axisLength)\n\n        return BreakLabelsLayoutUtil.doLayoutVerticalAxisLabels(\n            orientation, breaks,\n            axisDomain,\n            axisMapper,\n            theme\n        )\n    }\n\n    protected fun getBreaks(maxCount: Int, axisLength: Double): ScaleBreaks {\n        return BreakLabelsLayoutUtil.getFlexBreaks(\n            myBreaksProvider,\n            maxCount,\n            axisLength\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot.Axis\n\nobject Defaults {\n    // HEX colors only (because of using of parseHex())\n    const val DARK_GRAY = \"#3d3d3d\"\n    val GRAY = Color.GRAY.toHexColor()\n    val LIGHT_GRAY = Color.LIGHT_GRAY.toHexColor()\n    val X_LIGHT_GRAY = Color.VERY_LIGHT_GRAY.toHexColor()\n    const val XX_LIGHT_GRAY = \"#e0e0e0\"\n\n    const val BACKDROP_COLOR = \"white\"\n\n    const val TEXT_COLOR = DARK_GRAY\n\n    const val FONT_LARGE = 16\n    const val FONT_MEDIUM = 12\n    const val FONT_SMALL = 10\n    const val FONT_X_SMALL = 8\n\n    const val FONT_FAMILY_NORMAL = \"\\\"Lucida Grande\\\", sans-serif\"\n    const val FONT_FAMILY_MONOSPACED = \"\\\"Courier New\\\", Courier, monospace\"\n\n    class Common {\n        object Title {\n            const val FONT_SIZE = FONT_LARGE\n            val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n\n        object Legend {\n            const val TITLE_FONT_SIZE =\n                FONT_MEDIUM\n            const val ITEM_FONT_SIZE =\n                FONT_SMALL\n            val OUTLINE_COLOR = Color.parseHex(XX_LIGHT_GRAY)\n        }\n\n        object Tooltip {\n            const val MAX_POINTER_FOOTING_LENGTH = 12.0\n            const val POINTER_FOOTING_TO_SIDE_LENGTH_RATIO = 0.4\n\n            const val MARGIN_BETWEEN_TOOLTIPS = 5.0\n            const val DATA_TOOLTIP_FONT_SIZE = FONT_MEDIUM\n            const val LINE_INTERVAL = 3.0\n            const val H_CONTENT_PADDING = 4.0\n            const val V_CONTENT_PADDING = 4.0\n            const val LABEL_VALUE_INTERVAL = 8.0\n\n            const val BORDER_WIDTH = 4.0\n\n            val DARK_TEXT_COLOR = Color.BLACK\n            val LIGHT_TEXT_COLOR = Color.WHITE\n\n            const val AXIS_TOOLTIP_FONT_SIZE = DATA_TOOLTIP_FONT_SIZE\n            val AXIS_TOOLTIP_COLOR = Axis.LINE_COLOR\n            const val AXIS_RADIUS = 1.5 // fix a tooltip border overlapping an axis\n        }\n    }\n\n    class Table {\n        object Head {\n            const val FONT_SIZE = FONT_MEDIUM\n            const val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n\n        object Data {\n            const val FONT_SIZE = FONT_MEDIUM\n            const val FONT_SIZE_CSS = \"\" + FONT_SIZE + \"px\"\n        }\n    }\n\n    class Plot {\n        object Axis {\n            const val TITLE_FONT_SIZE =\n                FONT_MEDIUM\n            const val TICK_FONT_SIZE =\n                FONT_SMALL\n            const val TICK_FONT_SIZE_SMALL =\n                FONT_X_SMALL\n\n            val LINE_COLOR = Color.parseHex(DARK_GRAY)\n            val TICK_COLOR = Color.parseHex(DARK_GRAY)\n            val GRID_LINE_COLOR = Color.parseHex(X_LIGHT_GRAY)\n\n            // Bug in WebKit (?) : combination of style\n            //    shape-rendering: crispedges;\n            // and stroke-width less than 1\n            // makes horizontal line disappear\n            /*\n      public static final double LINE_WIDTH = 0.8;\n      public static final double TICK_LINE_WIDTH = 0.8;\n      public static final double GRID_LINE_WIDTH = 0.8;\n*/\n            const val LINE_WIDTH = 1.0\n            const val TICK_LINE_WIDTH = 1.0\n            const val GRID_LINE_WIDTH = 1.0\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nobject LabelCss {\n    operator fun get(labelSpec: LabelSpec, selector: String): String {\n        val css = StringBuilder()\n        css\n                .append(selector).append(\" {\")\n                .append(if (labelSpec.isMonospaced)\n                    \"\\n  font-family: \" + Defaults.FONT_FAMILY_MONOSPACED + \";\"\n                else\n                    \"\\n\")\n                .append(\"\\n  font-size: \").append(labelSpec.fontSize).append(\"px;\")\n                .append(if (labelSpec.isBold) \"\\n  font-weight: bold;\" else \"\")\n                //      .append(\"\\n  fill: red;\")\n                .append(\"\\n}\\n\")\n        return css.toString()\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport kotlin.jvm.JvmOverloads\n\n//ToDo:\ninterface Serializable\n\nclass LabelMetrics : LabelSpec,\n    Serializable {\n\n    override val fontSize: Double\n    override val isBold: Boolean\n    override val isMonospaced: Boolean\n\n    /**\n     * for Serializable\n     */\n    constructor() {\n        this.fontSize = 0.0\n        isBold = false\n        isMonospaced = false\n    }\n\n    /**\n     * @param fontSize in 'px' (same meaning as in CSS)\n     */\n    @JvmOverloads\n    constructor(fontSize: Double, bold: Boolean = false, monospaced: Boolean = false) {\n        this.fontSize = fontSize\n        isBold = bold\n        isMonospaced = monospaced\n    }\n\n    override fun dimensions(labelLength: Int): DoubleVector {\n        return DoubleVector(width(labelLength), height())\n    }\n\n    override fun width(labelLength: Int): Double {\n        var ratio =\n            FONT_SIZE_TO_GLYPH_WIDTH_RATIO\n        if (isMonospaced) {\n            ratio =\n                FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED\n        }\n\n        val width = labelLength.toDouble() * fontSize * ratio + 2 * LABEL_PADDING\n        return if (isBold) {\n            width * FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO\n        } else width\n    }\n\n    override fun height(): Double {\n        return fontSize + 2 * LABEL_PADDING\n    }\n\n    companion object {\n        private const val FONT_SIZE_TO_GLYPH_WIDTH_RATIO = 0.67 //0.48; // 0.42;\n        private const val FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED = 0.6\n        private const val FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO = 1.075\n        private const val LABEL_PADDING = 0.0 //2;\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot\n\nenum class PlotLabelSpec(fontSize: Double, bold: Boolean = false, monospaced: Boolean = false) :\n    LabelSpec {\n    PLOT_TITLE(Defaults.Common.Title.FONT_SIZE.toDouble(), true),\n\n    AXIS_TICK(Plot.Axis.TICK_FONT_SIZE.toDouble()),\n    AXIS_TICK_SMALL(Plot.Axis.TICK_FONT_SIZE_SMALL.toDouble()),\n    AXIS_TITLE(Plot.Axis.TITLE_FONT_SIZE.toDouble()),\n\n    LEGEND_TITLE(Defaults.Common.Legend.TITLE_FONT_SIZE.toDouble(), true),\n    LEGEND_ITEM(Defaults.Common.Legend.ITEM_FONT_SIZE.toDouble());\n\n    private val myLabelMetrics: LabelMetrics\n\n    override val isBold: Boolean\n        get() = myLabelMetrics.isBold\n\n    override val isMonospaced: Boolean\n        get() = myLabelMetrics.isMonospaced\n\n    override val fontSize: Double\n        get() = myLabelMetrics.fontSize\n\n    init {\n        myLabelMetrics =\n            LabelMetrics(fontSize, bold, monospaced)\n    }\n\n    override fun dimensions(labelLength: Int): DoubleVector {\n        return myLabelMetrics.dimensions(labelLength)\n    }\n\n    override fun width(labelLength: Int): Double {\n        return myLabelMetrics.width(labelLength)\n    }\n\n    override fun height(): Double {\n        return myLabelMetrics.height()\n    }\n}\n/**\n * @param fontSize in 'px' (same meaning as in CSS)\n */\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.presentation\n\nimport jetbrains.datalore.plot.builder.presentation.Defaults.BACKDROP_COLOR\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.AXIS_TOOLTIP_FONT_SIZE\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Common.Tooltip.DATA_TOOLTIP_FONT_SIZE\nimport jetbrains.datalore.plot.builder.presentation.Defaults.FONT_FAMILY_NORMAL\nimport jetbrains.datalore.plot.builder.presentation.Defaults.FONT_MEDIUM\nimport jetbrains.datalore.plot.builder.presentation.Defaults.TEXT_COLOR\n\n/**\n * Duplicating stylesheet for JavaFX platform is defined in\n * plot-builder/src/jvmMain/resources/svgMapper/jfx/plot.css\n */\nobject Style {\n    const val JFX_PLOT_STYLESHEET = \"/svgMapper/jfx/plot.css\"\n\n    // classes\n    const val PLOT_CONTAINER = \"plt-container\"\n    const val PLOT = \"plt-plot\"\n    const val PLOT_TITLE = \"plt-plot-title\"\n\n    const val PLOT_TRANSPARENT = \"plt-transparent\"\n    const val PLOT_BACKDROP = \"plt-backdrop\"\n\n    const val AXIS = \"plt-axis\"\n\n    const val AXIS_TITLE = \"plt-axis-title\"\n    const val TICK = \"tick\"\n    const val SMALL_TICK_FONT = \"small-tick-font\"\n\n    const val BACK = \"back\"\n\n    const val LEGEND = \"plt_legend\"\n    const val LEGEND_TITLE = \"legend-title\"\n\n    const val PLOT_DATA_TOOLTIP = \"plt-data-tooltip\"\n    const val PLOT_AXIS_TOOLTIP = \"plt-axis-tooltip\"\n\n    private val CSS = \"\"\"\n        |.$PLOT_CONTAINER {\n        |\tfont-family: $FONT_FAMILY_NORMAL;\n        |\tcursor: crosshair;\n        |\tuser-select: none;\n        |\t-webkit-user-select: none;\n        |\t-moz-user-select: none;\n        |\t-ms-user-select: none;\n        |}\n        |.$PLOT_BACKDROP {\n        |   fill: $BACKDROP_COLOR;\n        |}\n        |.$PLOT_TRANSPARENT .$PLOT_BACKDROP {\n        |   visibility: hidden;\n        |}\n        |text {\n        |\tfont-size: ${FONT_MEDIUM}px;\n        |\tfill: $TEXT_COLOR;\n        |\t\n        |\ttext-rendering: optimizeLegibility;\n        |}\n        |.$PLOT_DATA_TOOLTIP text {\n        |\tfont-size: ${DATA_TOOLTIP_FONT_SIZE}px;\n        |}\n        |.$PLOT_AXIS_TOOLTIP text {\n        |\tfont-size: ${AXIS_TOOLTIP_FONT_SIZE}px;\n        |}\n        |.$AXIS line {\n        |\tshape-rendering: crispedges;\n        |}\n    \"\"\".trimMargin()\n\n    val css: String\n        get() {\n            val css = StringBuilder(CSS.toString())\n            css.append('\\n')\n            for (labelSpec in PlotLabelSpec.values()) {\n                val selector = selector(labelSpec)\n                css.append(LabelCss[labelSpec, selector])\n            }\n            return css.toString()\n        }\n\n    private fun selector(labelSpec: PlotLabelSpec): String {\n        return when (labelSpec) {\n            PlotLabelSpec.PLOT_TITLE -> \".$PLOT_TITLE\"\n            PlotLabelSpec.AXIS_TICK -> \".$AXIS .$TICK text\"\n            PlotLabelSpec.AXIS_TICK_SMALL -> \".$AXIS.$SMALL_TICK_FONT .$TICK text\"\n            PlotLabelSpec.AXIS_TITLE -> \".$AXIS_TITLE text\"\n            PlotLabelSpec.LEGEND_TITLE -> \".$LEGEND .$LEGEND_TITLE text\"\n            PlotLabelSpec.LEGEND_ITEM -> \".$LEGEND text\"\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.method.*\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.VertexDpSampling\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.VertexVwSampling\n\nobject Samplings {\n    const val RANDOM = RandomSampling.ALIAS\n    const val PICK = PickSampling.ALIAS\n    const val SYSTEMATIC = SystematicSampling.ALIAS\n    const val RANDOM_GROUP = GroupRandomSampling.ALIAS\n    const val SYSTEMATIC_GROUP = GroupSystematicSampling.ALIAS\n    const val RANDOM_STRATIFIED = RandomStratifiedSampling.ALIAS\n    const val VERTEX_VW = VertexVwSampling.ALIAS\n    const val VERTEX_DP = VertexDpSampling.ALIAS\n\n    val NONE: PointSampling =\n        NoneSampling()\n\n    fun random(sampleSize: Int, seed: Long?): PointSampling {\n        return RandomSampling(sampleSize, seed)\n    }\n\n    fun pick(sampleSize: Int): PointSampling {\n        return PickSampling(sampleSize)\n    }\n\n    fun vertexDp(sampleSize: Int): Sampling {\n        return VertexDpSampling(sampleSize)\n    }\n\n    fun vertexVw(sampleSize: Int): Sampling {\n        return VertexVwSampling(sampleSize)\n    }\n\n    fun systematic(sampleSize: Int): Sampling {\n        return SystematicSampling(sampleSize)\n    }\n\n    fun randomGroup(sampleSize: Int, seed: Long?): Sampling {\n        return GroupRandomSampling(sampleSize, seed)\n    }\n\n    fun systematicGroup(sampleSize: Int): Sampling {\n        return GroupSystematicSampling(sampleSize)\n    }\n\n    fun randomStratified(sampleSize: Int, seed: Long?, minSubSample: Int?): Sampling {\n        return RandomStratifiedSampling(sampleSize, seed, minSubSample)\n    }\n\n    private class NoneSampling : PointSampling {\n\n        override val expressionText: String\n            get() = \"none\"\n\n        override fun isApplicable(population: DataFrame): Boolean {\n            return false\n        }\n\n        override fun apply(population: DataFrame): DataFrame {\n            return population\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport kotlin.random.Random\n\ninternal class GroupRandomSampling(sampleSize: Int, private val mySeed: Long?) : GroupSamplingBase(sampleSize) {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                \")\"\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val distinctGroups = SamplingUtil.distinctGroups(\n            groupMapper,\n            population.rowCount()\n        )\n\n        distinctGroups.shuffle(createRandom())\n        val pickedGroups = distinctGroups.take(sampleSize).toSet()\n        return doSelect(population, pickedGroups, groupMapper)\n    }\n\n    private fun createRandom(): Random {\n        return mySeed?.let { Random(it) } ?: Random.Default\n    }\n\n    companion object {\n        const val ALIAS = \"group_random\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.data.GroupUtil\nimport jetbrains.datalore.plot.builder.sampling.GroupAwareSampling\n\ninternal abstract class GroupSamplingBase(sampleSize: Int) : SamplingBase(sampleSize),\n    GroupAwareSampling {\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int): Boolean {\n        return isApplicable(population, groupMapper,\n            SamplingUtil.groupCount(groupMapper, population.rowCount())\n        )\n    }\n\n    open fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int, groupCount: Int): Boolean {\n        return groupCount > sampleSize\n    }\n\n    fun doSelect(population: DataFrame, pickedGroups: Set<Int>, groupMapper: (Int) -> Int): DataFrame {\n        val indicesByGroup = GroupUtil.indicesByGroup(population.rowCount(), groupMapper)\n\n        val pickedIndices = ArrayList<Int>()\n        for (group in pickedGroups) {\n            pickedIndices.addAll(indicesByGroup.get(group)!!)\n        }\n        return population.selectIndices(pickedIndices)\n\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.method.SystematicSampling.Companion.computeStep\n\ninternal class GroupSystematicSampling(sampleSize: Int) : GroupSamplingBase(sampleSize) {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                \")\"\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int, groupCount: Int): Boolean {\n        return super.isApplicable(population, groupMapper, groupCount) && computeStep(groupCount, sampleSize) >= 2\n    }\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val distinctGroups = SamplingUtil.distinctGroups(\n            groupMapper,\n            population.rowCount()\n        )\n        val step = computeStep(distinctGroups.size, sampleSize)\n\n        val pickedGroups = HashSet<Int>()\n        var i = 0\n        while (i < distinctGroups.size) {\n            pickedGroups.add(distinctGroups[i])\n            i += step\n        }\n\n        return doSelect(population, pickedGroups, groupMapper)\n    }\n\n    companion object {\n        const val ALIAS = \"group_systematic\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.gcommon.base.Preconditions.checkArgument\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.xVar\n\n/**\n * Picks first N data points with unique X-values. In addition scoops all data-points with X-values\n * which are already being accepted to the sample (to account for grouping)\n */\ninternal class PickSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize + \")\"\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n\n        val xVar = xVar(population)\n        val xFactors = population.distinctValues(xVar)\n        if (xFactors.size <= sampleSize) {\n            return population\n        }\n\n        val pickX = xFactors.take(sampleSize).toSet()\n\n        val xValues = population[xVar]\n        val pickedIndices = ArrayList<Int>()\n        for ((index, v) in xValues.withIndex()) {\n            if (v in pickX) {\n                pickedIndices.add(index)\n            }\n        }\n\n        return population.selectIndices(pickedIndices)\n    }\n\n    companion object {\n        const val ALIAS = \"pick\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport kotlin.random.Random\n\n/**\n * Take any point with equal probability without replacement\n */\ninternal class RandomSampling(sampleSize: Int, private val mySeed: Long?) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                \")\"\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n        val rand = mySeed?.let { Random(it) } ?: Random.Default\n\n        return SamplingUtil.sampleWithoutReplacement(sampleSize, rand, population)\n    }\n\n    companion object {\n        const val ALIAS = \"random\"\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.data.GroupUtil\nimport jetbrains.datalore.plot.base.util.SamplingUtil\nimport jetbrains.datalore.plot.builder.sampling.GroupAwareSampling\nimport kotlin.math.max\nimport kotlin.math.round\nimport kotlin.random.Random\n\ninternal class RandomStratifiedSampling(\n        sampleSize: Int,\n        private val mySeed: Long?,\n        private val myMinSubsampleSize: Int?) : SamplingBase(sampleSize),\n    GroupAwareSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                (if (mySeed != null) \", seed=$mySeed\" else \"\") +\n                (if (myMinSubsampleSize != null) \", min_subsample=$myMinSubsampleSize\" else \"\") +\n                \")\"\n\n    override fun isApplicable(population: DataFrame, groupMapper: (Int) -> Int): Boolean {\n        return population.rowCount() > sampleSize\n    }\n\n    override fun apply(population: DataFrame, groupMapper: (Int) -> Int): DataFrame {\n        require(isApplicable(population, groupMapper))\n        val indicesByGroup = GroupUtil.indicesByGroup(population.rowCount(), groupMapper)\n\n        var minSubSampleSize = myMinSubsampleSize ?: DEF_MIN_SUBSAMPLE_SIZE\n        minSubSampleSize = max(0, minSubSampleSize)\n        val popSize = population.rowCount()\n\n        val pickIndices = ArrayList<Int>()\n        val rand = mySeed?.let { Random(it) } ?: Random.Default\n        for (group in indicesByGroup.keys) {\n            val groupIndices = indicesByGroup[group]!!\n            val stratumSize = groupIndices.size\n            // proportionate allocation\n            val ratio = stratumSize.toDouble() / popSize\n\n            var stratumSampleSize = round(sampleSize * ratio).toInt()\n            stratumSampleSize = max(stratumSampleSize, minSubSampleSize)\n\n            if (stratumSampleSize >= stratumSize) {\n                pickIndices.addAll(groupIndices)\n            } else {\n\n                val sampleGroupIndices =\n                    SamplingUtil.sampleWithoutReplacement(stratumSize,\n                        stratumSampleSize,\n                        rand,\n                        { indexSet ->\n                            (0 until groupIndices.size)\n                                .filter { indexSet.contains(it) }\n                        },\n                        { indexSet ->\n                            (0 until groupIndices.size)\n                                .filter { i -> !indexSet.contains(i) }\n                        })\n\n                for (i in sampleGroupIndices) {\n                    pickIndices.add(groupIndices[i])\n                }\n            }\n        }\n\n        return population.selectIndices(pickIndices)\n    }\n\n    companion object {\n        internal const val ALIAS = \"random_stratified\"\n        private const val DEF_MIN_SUBSAMPLE_SIZE = 2 // min needed to draw a line\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.Sampling\n\ninternal abstract class SamplingBase(val sampleSize: Int) : Sampling {\n\n    init {\n        check(this.sampleSize > 0) { \"Sample size must be greater than zero, but was: \" + this.sampleSize }\n    }\n\n    open fun isApplicable(population: DataFrame): Boolean {\n        return population.rowCount() > sampleSize\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.algorithms.calculateArea\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.DataFrame.Variable\nimport jetbrains.datalore.plot.base.data.TransformVar\nimport jetbrains.datalore.plot.base.stat.Stats\nimport jetbrains.datalore.plot.base.util.MutableDouble\nimport jetbrains.datalore.plot.base.util.MutableInteger\nimport jetbrains.datalore.plot.builder.sampling.method.VertexSampling.DoubleVectorComponentsList\nimport kotlin.math.min\nimport kotlin.math.roundToInt\n\ninternal object SamplingUtil {\n\n    fun groupCount(groupMapper: (Int) -> Int, size: Int): Int {\n        return (0 until size).map { groupMapper(it) }.distinct().count()\n    }\n\n    fun distinctGroups(groupMapper: (Int) -> Int, size: Int): MutableList<Int> {\n        return (0 until size).map { groupMapper(it) }.distinct().toMutableList()\n    }\n\n    fun xVar(variables: Set<Variable>): Variable? {\n        return when {\n            Stats.X in variables -> Stats.X\n            TransformVar.X in variables -> TransformVar.X\n            else -> null\n        }\n    }\n    fun xVar(data: DataFrame): Variable {\n        return xVar(data.variables())\n            ?: throw IllegalStateException(\"Can't apply sampling: couldn't deduce the (X) variable.\")\n    }\n\n    fun yVar(data: DataFrame): Variable {\n        if (data.has(Stats.Y)) {\n            return Stats.Y\n        } else if (data.has(TransformVar.Y)) {\n            return TransformVar.Y\n        }\n        throw IllegalStateException(\"Can't apply sampling: couldn't deduce the (Y) variable.\")\n    }\n\n    fun splitRings(population: DataFrame): List<List<DoubleVector>> {\n        val rings = ArrayList<List<DoubleVector>>()\n        var lastPoint: DoubleVector? = null\n        var start = -1\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val xValues = population[xVar(population)] as List<Any>\n\n        @Suppress(\"UNCHECKED_CAST\")\n        val yValues = population[yVar(population)] as List<Any>\n        val points = DoubleVectorComponentsList(xValues, yValues)\n        for (i in points.indices) {\n            val point = points[i]\n            if (start < 0) {\n                start = i\n                lastPoint = point\n            } else if (lastPoint == point) {\n                rings.add(points.subList(start, i + 1))\n                start = -1\n                lastPoint = null\n            }\n        }\n        if (start >= 0) {\n            // not closed\n            rings.add(points.subList(start, points.size))\n        }\n        return rings\n    }\n\n    fun calculateRingLimits(rings: List<List<DoubleVector>>, totalPointsLimit: Int): List<Int> {\n        val totalArea = rings.map { calculateArea(it) }.sum()\n\n        val areaProceed = MutableDouble(0.0)\n        val pointsProceed = MutableInteger(0)\n\n        return rings.indices\n            .asSequence()\n            .map { Pair(it, calculateArea(rings[it])) }\n            .sortedWith(compareBy<Pair<*, Double>> {\n                getRingArea(\n                    it\n                )\n            }.reversed())\n            .map { p ->\n                var limit = min(\n                    (p.second / (totalArea - areaProceed.get()) * (totalPointsLimit - pointsProceed.get())).roundToInt(),\n                    rings[getRingIndex(p)].size\n                )\n\n                if (limit >= 4) {\n                    areaProceed.getAndAdd(getRingArea(p))\n                    pointsProceed.getAndAdd(limit)\n                } else {\n                    limit = 0\n                }\n\n                Pair(getRingIndex(p), limit)\n            }\n            .sortedWith(compareBy { getRingIndex(it) })\n            .map { getRingLimit(it) }\n            .toList()\n    }\n\n    fun getRingIndex(pair: Pair<Int, *>): Int {\n        return pair.first\n    }\n\n    private fun getRingArea(pair: Pair<*, Double>): Double {\n        return pair.second\n    }\n\n    fun getRingLimit(pair: Pair<*, Int>): Int {\n        return pair.second\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport kotlin.math.round\n\n/**\n * Take points at indices selected at regular intervals starting from index 0\n */\ninternal class SystematicSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    override val expressionText: String\n        get() = \"sampling_\" + ALIAS + \"(\" +\n                \"n=\" + sampleSize +\n                \")\"\n\n    override fun isApplicable(population: DataFrame): Boolean {\n        return super.isApplicable(population) && computeStep(population.rowCount()) >= 2\n    }\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n        val popSize = population.rowCount()\n\n        val step = computeStep(popSize)\n        val pickedIndices = ArrayList<Int>()\n        var i = 0\n        while (i < popSize) {\n            pickedIndices.add(i)\n            i += step\n        }\n\n        return population.selectIndices(pickedIndices)\n    }\n\n    private fun computeStep(popSize: Int): Int {\n        return round(popSize.toDouble() / (sampleSize - 1)).toInt()\n    }\n\n    companion object {\n        const val ALIAS = \"systematic\"\n\n        fun computeStep(popSize: Int, sampleSize: Int): Int {\n            return round((popSize - 1).toDouble() / (sampleSize - 1)).toInt()\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.sampling.method\n\nimport jetbrains.datalore.base.algorithms.isClosed\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.util.MutableInteger\nimport jetbrains.datalore.plot.builder.sampling.PointSampling\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.calculateRingLimits\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.getRingIndex\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.getRingLimit\nimport jetbrains.datalore.plot.builder.sampling.method.SamplingUtil.splitRings\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier\n\ninternal abstract class VertexSampling(sampleSize: Int) : SamplingBase(sampleSize),\n    PointSampling {\n\n    private fun simplify(points: List<DoubleVector>, limit: Int): List<Int> {\n        return if (limit == 0) {\n            emptyList()\n        } else {\n            simplifyInternal(points, limit)\n        }\n    }\n\n    internal abstract fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int>\n\n    override fun apply(population: DataFrame): DataFrame {\n        require(isApplicable(population))\n\n        val rings = splitRings(population)\n        val limits = if (rings.size == 1 && !rings[0].isClosed())\n            listOf(sampleSize)\n        else\n            calculateRingLimits(rings, sampleSize)\n\n        val indices = ArrayList<Int>()\n        val ringBase = MutableInteger(0)\n\n        (0 until limits.size)\n                .map { Pair(it, limits[it]) }\n                .forEach { p ->\n                    simplify(rings[getRingIndex(p)], getRingLimit(p))\n                            .forEach { index -> indices.add(ringBase.get() + index) }\n                    ringBase.getAndAdd(rings[getRingIndex(p)].size)\n                }\n\n        return population.selectIndices(indices)\n    }\n\n    internal class VertexVwSampling(sampleSize: Int) : VertexSampling(sampleSize) {\n\n        override val expressionText: String\n            get() = \"sampling_\" + ALIAS + \"(\" +\n                    \"n=\" + sampleSize + \")\"\n\n        override fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int> {\n            return PolylineSimplifier.visvalingamWhyatt(points).setCountLimit(limit).indices\n        }\n\n        companion object {\n            const val ALIAS = \"vertex_vw\"\n        }\n    }\n\n    internal class VertexDpSampling(sampleSize: Int) : VertexSampling(sampleSize) {\n\n        override val expressionText: String\n            get() = \"sampling_\" + ALIAS + \"(\" +\n                    \"n=\" + sampleSize + \")\"\n\n        override fun simplifyInternal(points: List<DoubleVector>, limit: Int): List<Int> {\n            return PolylineSimplifier.douglasPeucker(points).setCountLimit(limit).indices\n        }\n\n        companion object {\n            const val ALIAS = \"vertex_dp\"\n        }\n    }\n\n    internal class DoubleVectorComponentsList(private val myXValues: List<Any>, private val myYValues: List<Any>) : AbstractList<DoubleVector>() {\n        override val size: Int\n            get() = myXValues.size\n\n        override fun get(index: Int): DoubleVector {\n            return createPoint(\n                myXValues[index],\n                myYValues[index]\n            )\n        }\n    }\n\n    companion object {\n        private fun createPoint(x: Any, y: Any): DoubleVector {\n            require(!(x is String || y is String)) { \"String coords are not supported yet\" }\n            require(SeriesUtil.allFinite(x as Double, y as Double)) { \"Invalid coord\" }\n            return DoubleVector(x, y)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.plot.builder.scale.provider.MapperProviderBase\n\nabstract class ContinuousOnlyMapperProvider<T>(naValue: T) : MapperProviderBase<T>(naValue) {\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        val domainRepr = domainValues.joinToString(limit = 3) { \"'$it'\" }\n        throw IllegalStateException(\"[${this::class.simpleName}] Can't create mapper for discrete domain: $domainRepr\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createColorMapperProvider\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createObjectIdentity\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createObjectIdentityDiscrete\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createStringIdentity\nimport jetbrains.datalore.plot.builder.scale.DefaultMapperProviderUtil.createWithDiscreteOutput\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.builder.scale.mapper.LineTypeMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ShapeMapper\nimport jetbrains.datalore.plot.builder.scale.provider.AlphaMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.SizeMapperProvider\n\n\nobject DefaultMapperProvider {\n\n    private val PROVIDER_MAP = TypedMapperProviderMap()\n\n    operator fun <T> get(aes: Aes<T>): MapperProvider<T> {\n        return PROVIDER_MAP[aes]\n    }\n\n    /**\n     * For tests\n     */\n    internal fun hasDefault(aes: Aes<*>): Boolean {\n        return PROVIDER_MAP.containsKey(aes)\n    }\n\n    private class TypedMapperProviderMap internal constructor() {\n\n        private var myMap: MutableMap<Aes<*>, MapperProvider<*>> = HashMap()\n\n        init {\n            for (aes in Aes.allPositional()) {\n                put(aes, NUMERIC_UNDEFINED)\n            }\n\n            this.put(X, NUMERIC_IDENTITY)\n            this.put(Y, NUMERIC_IDENTITY)\n\n            this.put(Z, NUMERIC_IDENTITY)\n            this.put(YMIN, NUMERIC_IDENTITY)\n            this.put(YMAX, NUMERIC_IDENTITY)\n            this.put(COLOR, createColorMapperProvider())\n            this.put(FILL, createColorMapperProvider())\n            this.put(ALPHA, AlphaMapperProvider.DEFAULT)\n            this.put(SHAPE, createWithDiscreteOutput(ShapeMapper.allShapes(), ShapeMapper.NA_VALUE))\n            this.put(LINETYPE, createWithDiscreteOutput(LineTypeMapper.allLineTypes(), LineTypeMapper.NA_VALUE))\n\n            this.put(SIZE, SizeMapperProvider.DEFAULT)\n            this.put(WIDTH, NUMERIC_IDENTITY)\n            this.put(HEIGHT, NUMERIC_IDENTITY)\n            this.put(WEIGHT, NUMERIC_IDENTITY)\n            this.put(INTERCEPT, NUMERIC_IDENTITY)\n            this.put(SLOPE, NUMERIC_IDENTITY)\n            this.put(XINTERCEPT, NUMERIC_IDENTITY)\n            this.put(YINTERCEPT, NUMERIC_IDENTITY)\n            this.put(LOWER, NUMERIC_IDENTITY)\n            this.put(MIDDLE, NUMERIC_IDENTITY)\n            this.put(UPPER, NUMERIC_IDENTITY)\n\n            this.put(FRAME, createStringIdentity(FRAME))\n\n            this.put(SPEED, NUMERIC_IDENTITY)\n            this.put(FLOW, NUMERIC_IDENTITY)\n\n            this.put(XMIN, NUMERIC_IDENTITY)\n            this.put(XMAX, NUMERIC_IDENTITY)\n            this.put(XEND, NUMERIC_IDENTITY)\n            this.put(YEND, NUMERIC_IDENTITY)\n\n            this.put(LABEL, createObjectIdentity(LABEL))\n            this.put(FAMILY, createStringIdentity(FAMILY))\n            this.put(FONTFACE, createStringIdentity(FONTFACE))\n\n            // text horizontal justification (numbers [0..1] or predefined strings, DOUBLE_CVT; not positional)\n            this.put(HJUST, createObjectIdentityDiscrete(HJUST))\n\n            // text vertical justification (numbers [0..1] or predefined strings, not positional)\n            this.put(VJUST, createObjectIdentityDiscrete(VJUST))\n            this.put(ANGLE, NUMERIC_IDENTITY)\n\n            this.put(SYM_X, NUMERIC_IDENTITY)\n            this.put(SYM_Y, NUMERIC_IDENTITY)\n        }\n\n        internal operator fun <T> get(aes: Aes<T>): MapperProvider<T> {\n            @Suppress(\"UNCHECKED_CAST\")\n            return myMap[aes] as MapperProvider<T>\n        }\n\n        private fun <T> put(aes: Aes<T>, value: MapperProvider<T>) {\n            myMap[aes] = value\n        }\n\n        internal fun containsKey(aes: Aes<*>): Boolean {\n            return myMap.containsKey(aes)\n        }\n\n        companion object {\n            // For most of numeric (positional) aesthetics the initial mapper is UNDEFINED mapper as we don't yet know the range of positional aesthetics.\n            private val NUMERIC_UNDEFINED: MapperProvider<Double> = object : MapperProvider<Double> {\n                override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n                    return GuideMappers.UNDEFINED\n                }\n\n                override fun createContinuousMapper(\n                    domain: ClosedRange<Double>,\n                    lowerLimit: Double?,\n                    upperLimit: Double?,\n                    trans: ContinuousTransform\n                ): GuideMapper<Double> {\n                    return GuideMappers.UNDEFINED\n                }\n            }\n\n            private val NUMERIC_IDENTITY: MapperProvider<Double> = object : MapperProvider<Double> {\n                override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n                    return GuideMappers.IDENTITY\n                }\n\n                override fun createContinuousMapper(\n                    domain: ClosedRange<Double>,\n                    lowerLimit: Double?,\n                    upperLimit: Double?,\n                    trans: ContinuousTransform\n                ): GuideMapper<Double> {\n                    return GuideMappers.IDENTITY\n                }\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.builder.scale.provider.ColorBrewerMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.ColorGradientMapperProvider\nimport jetbrains.datalore.plot.builder.scale.provider.IdentityDiscreteMapperProvider\n\nobject DefaultMapperProviderUtil {\n\n    internal fun createColorMapperProvider(): MapperProvider<Color> {\n        val discrete = ColorBrewerMapperProvider(null, null, null, Color.GRAY)\n        val continuous = ColorGradientMapperProvider.DEFAULT\n        return object : MapperProvider<Color> {\n            override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n                return discrete.createDiscreteMapper(domainValues)\n            }\n\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<Color> {\n                return continuous.createContinuousMapper(domain, lowerLimit, upperLimit, trans)\n            }\n        }\n    }\n\n    fun <T> createWithDiscreteOutput(outputValues: List<T>, naValue: T): MapperProvider<T> {\n        return object : MapperProvider<T> {\n            override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n                return GuideMappers.discreteToDiscrete(domainValues, outputValues, naValue)\n            }\n\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<T> {\n                return GuideMappers.continuousToDiscrete(\n                    MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans),\n                    outputValues, naValue\n                )\n            }\n        }\n    }\n\n    @Suppress(\"UNUSED_PARAMETER\")\n    internal fun createObjectIdentity(aes: Aes<Any?>): MapperProvider<Any?> {\n        return object : IdentityDiscreteMapperProvider<Any?>({ it }, null) {\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<Any?> {\n                return GuideMappers.asContinuous { it }\n            }\n        }\n    }\n\n    internal fun createObjectIdentityDiscrete(aes: Aes<Any>): MapperProvider<Any> {\n        val converter: (Any?) -> Any? = { it }\n        return createIdentityMapperProvider(aes, converter, null)\n    }\n\n    internal fun createStringIdentity(aes: Aes<String>): MapperProvider<String> {\n        val converter = { it: Any? -> it?.toString() }\n        val continuousMapper = { it: Double? -> it?.toString() }\n        return createIdentityMapperProvider(\n            aes,\n            converter,\n            continuousMapper\n        )\n    }\n\n    private fun <T> createIdentityMapperProvider(\n        aes: Aes<T>,\n        converter: (Any?) -> T?,\n        continuousMapper: ((Double?) -> T?)?\n    ): MapperProvider<T> {\n        return object : IdentityDiscreteMapperProvider<T>(converter, DefaultNaValue[aes]) {\n            override fun createContinuousMapper(\n                domain: ClosedRange<Double>,\n                lowerLimit: Double?,\n                upperLimit: Double?,\n                trans: ContinuousTransform\n            ): GuideMapper<T> {\n                if (continuousMapper != null) {\n                    return GuideMappers.asContinuous(continuousMapper)\n                }\n                throw IllegalStateException(\"Can't create $aes mapper for continuous domain $domain\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.typedKey.TypedKey\nimport jetbrains.datalore.base.typedKey.TypedKeyHashMap\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.base.Aes.Companion.ANGLE\nimport jetbrains.datalore.plot.base.Aes.Companion.COLOR\nimport jetbrains.datalore.plot.base.Aes.Companion.FAMILY\nimport jetbrains.datalore.plot.base.Aes.Companion.FILL\nimport jetbrains.datalore.plot.base.Aes.Companion.FLOW\nimport jetbrains.datalore.plot.base.Aes.Companion.FONTFACE\nimport jetbrains.datalore.plot.base.Aes.Companion.FRAME\nimport jetbrains.datalore.plot.base.Aes.Companion.HEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.HJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.INTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.LABEL\nimport jetbrains.datalore.plot.base.Aes.Companion.LINETYPE\nimport jetbrains.datalore.plot.base.Aes.Companion.LOWER\nimport jetbrains.datalore.plot.base.Aes.Companion.MIDDLE\nimport jetbrains.datalore.plot.base.Aes.Companion.SHAPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.Aes.Companion.SLOPE\nimport jetbrains.datalore.plot.base.Aes.Companion.SPEED\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_X\nimport jetbrains.datalore.plot.base.Aes.Companion.SYM_Y\nimport jetbrains.datalore.plot.base.Aes.Companion.UPPER\nimport jetbrains.datalore.plot.base.Aes.Companion.VJUST\nimport jetbrains.datalore.plot.base.Aes.Companion.WEIGHT\nimport jetbrains.datalore.plot.base.Aes.Companion.WIDTH\nimport jetbrains.datalore.plot.base.Aes.Companion.X\nimport jetbrains.datalore.plot.base.Aes.Companion.XEND\nimport jetbrains.datalore.plot.base.Aes.Companion.XINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.XMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.XMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Y\nimport jetbrains.datalore.plot.base.Aes.Companion.YEND\nimport jetbrains.datalore.plot.base.Aes.Companion.YINTERCEPT\nimport jetbrains.datalore.plot.base.Aes.Companion.YMAX\nimport jetbrains.datalore.plot.base.Aes.Companion.YMIN\nimport jetbrains.datalore.plot.base.Aes.Companion.Z\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\n\nobject DefaultNaValue {\n    private val VALUE_MAP = TypedKeyHashMap()\n\n    init {\n        VALUE_MAP.put(X, 0.0)\n        VALUE_MAP.put(Y, 0.0)\n        VALUE_MAP.put(Z, 0.0)\n        VALUE_MAP.put(YMIN, 0.0)\n        VALUE_MAP.put(YMAX, 0.0)\n        VALUE_MAP.put(COLOR, Color.GRAY)\n        VALUE_MAP.put(FILL, Color.GRAY)\n        VALUE_MAP.put(ALPHA, 0.0)\n        VALUE_MAP.put(SHAPE, TinyPointShape)\n        VALUE_MAP.put(LINETYPE, NamedLineType.SOLID)\n        VALUE_MAP.put(SIZE, AesScaling.sizeFromCircleDiameter(1.0))\n        VALUE_MAP.put(WIDTH, 1.0)\n        VALUE_MAP.put(HEIGHT, 1.0)\n        VALUE_MAP.put(WEIGHT, 1.0)\n        VALUE_MAP.put(INTERCEPT, 0.0)\n        VALUE_MAP.put(SLOPE, 1.0)\n        VALUE_MAP.put(XINTERCEPT, 0.0)\n        VALUE_MAP.put(YINTERCEPT, 0.0)\n        VALUE_MAP.put(LOWER, 0.0)\n        VALUE_MAP.put(MIDDLE, 0.0)\n        VALUE_MAP.put(UPPER, 0.0)\n        VALUE_MAP.put(FRAME, \"empty frame\")\n        VALUE_MAP.put(SPEED, 10.0)\n        VALUE_MAP.put(FLOW, 0.1)\n        VALUE_MAP.put(XMIN, 0.0)\n        VALUE_MAP.put(XMAX, 0.0)\n        VALUE_MAP.put(XEND, 0.0)\n        VALUE_MAP.put(YEND, 0.0)\n        VALUE_MAP.put(LABEL, \"-\")\n        VALUE_MAP.put(FAMILY, \"sans-serif\")\n        VALUE_MAP.put(FONTFACE, \"plain\")\n        VALUE_MAP.put(HJUST, 0.5)  // 'middle'\n        VALUE_MAP.put(VJUST, 0.5)  // 'middle'\n        VALUE_MAP.put(ANGLE, 0.0)\n        VALUE_MAP.put(SYM_X, 0.0)\n        VALUE_MAP.put(SYM_Y, 0.0)\n    }\n\n    /**\n     * For test only (must br TRUE for any Aes)\n     */\n    fun has(aes: Aes<*>): Boolean {\n        return VALUE_MAP.containsKey(aes)\n    }\n\n    operator fun <T> get(aes: Aes<T>): T {\n        return VALUE_MAP[aes]\n    }\n\n    operator fun <T> get(aes: TypedKey<T>): T {\n        return VALUE_MAP[aes]\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.provider.MapperProviderBase\n\nabstract class DiscreteOnlyMapperProvider<T>(naValue: T) : MapperProviderBase<T>(naValue) {\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<T> {\n        throw IllegalStateException(\"[${this::class.simpleName}] Can't create mapper for continuous domain $domain\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.Scale\nimport jetbrains.datalore.plot.base.scale.BreaksGenerator\nimport jetbrains.datalore.plot.base.scale.Scales\nimport jetbrains.datalore.plot.base.scale.transform.Transforms\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\n\nclass ScaleProviderBuilder<T>(private val aes: Aes<T>) {\n\n    private var _mapperProvider: MapperProvider<T>? = null\n    private var myName: String? = null\n    private var myBreaks: List<Any>? = null\n    private var myLabels: List<String>? = null\n    private var myLabelFormat: String? = null\n    private var myMultiplicativeExpand: Double? = null\n    private var myAdditiveExpand: Double? = null\n    private var myLimits: List<Any?>? = null\n    private var myContinuousTransform: ContinuousTransform = Transforms.IDENTITY\n    private var myBreaksGenerator: BreaksGenerator? = null\n\n    private var myDiscreteDomain = false\n    private var myDiscreteDomainReverse = false\n\n    var mapperProvider: MapperProvider<T>\n        get() {\n            if (_mapperProvider == null) {\n                _mapperProvider = DefaultMapperProvider[aes]\n            }\n            return _mapperProvider ?: throw AssertionError(\"Set to null by another thread\")\n        }\n        set(p: MapperProvider<T>) {\n            _mapperProvider = p\n        }\n\n    fun mapperProvider(mapperProvider: MapperProvider<T>): ScaleProviderBuilder<T> {\n        this.mapperProvider = mapperProvider\n        return this\n    }\n\n    fun name(name: String): ScaleProviderBuilder<T> {\n        myName = name\n        return this\n    }\n\n    fun breaks(breaks: List<Any>): ScaleProviderBuilder<T> {\n        myBreaks = breaks\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun minorBreaks_NI(\n        @Suppress(\"UNUSED_PARAMETER\") minorBreaks: List<Double>\n    ): ScaleProviderBuilder<T> {\n        // continuous scale\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun labels(labels: List<String>): ScaleProviderBuilder<T> {\n        myLabels = ArrayList(labels)\n        return this\n    }\n\n    fun labelFormat(format: String?): ScaleProviderBuilder<T> {\n        myLabelFormat = format\n        return this\n    }\n\n    fun multiplicativeExpand(v: Double): ScaleProviderBuilder<T> {\n        myMultiplicativeExpand = v\n        return this\n    }\n\n    fun additiveExpand(v: Double): ScaleProviderBuilder<T> {\n        myAdditiveExpand = v\n        return this\n    }\n\n    fun limits(v: List<*>): ScaleProviderBuilder<T> {\n        // Limits for continuous scale : list(min, max)\n        // Limits for discrete scale : list (\"a\", \"b\", \"c\")\n        myLimits = v\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun rescaler_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    @Suppress(\"FunctionName\")\n    fun oob_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun continuousTransform(v: ContinuousTransform): ScaleProviderBuilder<T> {\n        myContinuousTransform = v\n        return this\n    }\n\n    fun breaksGenerator(v: BreaksGenerator): ScaleProviderBuilder<T> {\n        myBreaksGenerator = v\n        return this\n    }\n\n    @Suppress(\"FunctionName\")\n    fun guide_NI(\n        @Suppress(\"UNUSED_PARAMETER\") v: Any\n    ): ScaleProviderBuilder<T> {\n        // Name of guide object, or object itself.\n        throw IllegalStateException(\"Not implemented\")\n    }\n\n    fun discreteDomain(b: Boolean): ScaleProviderBuilder<T> {\n        myDiscreteDomain = b\n        return this\n    }\n\n    fun discreteDomainReverse(b: Boolean): ScaleProviderBuilder<T> {\n        myDiscreteDomainReverse = b\n        return this\n    }\n\n    fun build(): ScaleProvider<T> {\n        return MyScaleProvider(this)\n    }\n\n    private class MyScaleProvider<T>(b: ScaleProviderBuilder<T>) : ScaleProvider<T> {\n\n        private val myName: String? = b.myName\n\n        private val myLabels: List<String>? = b.myLabels?.let { ArrayList(it) }\n        private val myLabelFormat: String? = b.myLabelFormat\n        private val myMultiplicativeExpand: Double? = b.myMultiplicativeExpand\n        private val myAdditiveExpand: Double? = b.myAdditiveExpand\n        private val discreteDomainReverse: Boolean = b.myDiscreteDomainReverse\n        private val myBreaksGenerator: BreaksGenerator? = b.myBreaksGenerator\n        private val myAes: Aes<T> = b.aes\n\n        override val discreteDomain: Boolean = b.myDiscreteDomain\n        override val mapperProvider: MapperProvider<T> = b.mapperProvider\n        override val breaks: List<Any>? = b.myBreaks?.let { ArrayList(it) }\n        override val limits: List<Any?>? = b.myLimits?.let { ArrayList(it) }\n\n        override val continuousTransform: ContinuousTransform = b.myContinuousTransform\n\n        private fun scaleName(variable: DataFrame.Variable): String {\n            return myName ?: variable.label\n        }\n\n        override fun createScale(defaultName: String, discreteDomain: Collection<*>): Scale<T> {\n            val name = myName ?: defaultName\n            var scale: Scale<T>\n\n            // discrete domain\n            var domainValues = discreteDomain.filterNotNull()\n\n            val mapper = if (discreteDomain.isEmpty()) {\n                absentMapper(defaultName)\n            } else {\n                mapperProvider.createDiscreteMapper(domainValues)::apply\n            }\n\n            if (discreteDomainReverse) {\n                domainValues = domainValues.reversed()\n            }\n\n            scale = Scales.discreteDomain(\n                name,\n                domainValues,\n                mapper\n            )\n\n            val discreteLimits = limits?.filterNotNull()?.let {\n                if (discreteDomainReverse) {\n                    it.reversed()\n                } else {\n                    it\n                }\n            }\n            if (discreteLimits != null) {\n                scale = scale.with()\n                    .limits(discreteLimits)\n                    .build()\n            }\n\n            return completeScale(scale)\n        }\n\n        override fun createScale(defaultName: String, continuousDomain: ClosedRange<Double>): Scale<T> {\n            val name = myName ?: defaultName\n            var scale: Scale<T>\n\n            // continuous (numeric) domain\n            val dataRange = ensureApplicableRange(continuousDomain)\n\n            var lowerLimit: Double? = null\n            var upperLimit: Double? = null\n            if (limits != null) {\n                var lower = true\n                for (limit in limits) {\n                    if (limit is Number) {\n                        val v = limit.toDouble()\n                        if (v.isFinite()) {\n                            if (lower) {\n                                lowerLimit = v\n                            } else {\n                                upperLimit = v\n                            }\n                        }\n                    }\n                    lower = false\n                }\n            }\n\n            val mapper = mapperProvider.createContinuousMapper(\n                dataRange,\n                lowerLimit,\n                upperLimit,\n                continuousTransform\n            )\n            val continuousRange = mapper.isContinuous || myAes.isNumeric\n\n            scale = Scales.continuousDomain(name, { v -> mapper.apply(v) }, continuousRange)\n\n            // ToDo: need to 'inverse transform' breaks.\n            if (mapper is WithGuideBreaks<*>) {\n                @Suppress(\"UNCHECKED_CAST\")\n                mapper as WithGuideBreaks<Any>\n                scale = scale.with()\n                    .breaks(mapper.breaks)\n                    .labelFormatter(mapper.formatter)\n                    .build()\n            }\n\n            scale = scale.with()\n                .continuousTransform(continuousTransform)\n                .build()\n\n            if (myBreaksGenerator != null) {\n                scale = scale.with()\n                    .breaksGenerator(myBreaksGenerator)\n                    .build()\n            }\n\n            if (limits != null) {\n                val with = scale.with()\n                if (lowerLimit != null) {\n                    with.lowerLimit(lowerLimit)\n                }\n                if (upperLimit != null) {\n                    with.upperLimit(upperLimit)\n                }\n                scale = with.build()\n            }\n\n            return completeScale(scale)\n        }\n\n\n        private fun completeScale(scale: Scale<T>): Scale<T> {\n            val with = scale.with()\n            if (breaks != null) {\n                with.breaks(breaks)\n            }\n            if (myLabels != null) {\n                with.labels(myLabels)\n            }\n            if (myLabelFormat != null) {\n                with.labelFormatter(StringFormat.create(myLabelFormat)::format)\n            }\n            if (myMultiplicativeExpand != null) {\n                with.multiplicativeExpand(myMultiplicativeExpand)\n            }\n            if (myAdditiveExpand != null) {\n                with.additiveExpand(myAdditiveExpand)\n            }\n            return with.build()\n        }\n\n        private fun absentMapper(`var`: DataFrame.Variable): (Double?) -> T {\n            // mapper for empty data is a special case - should never be used\n            return { v -> throw IllegalStateException(\"Mapper for empty data series '\" + `var`.name + \"' was invoked with arg \" + v) }\n        }\n\n        private fun absentMapper(label: String): (Double?) -> T {\n            // mapper for empty data is a special case - should never be used\n            return { v -> throw IllegalStateException(\"Mapper for empty data series '$label' was invoked with arg \" + v) }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale\n\nimport jetbrains.datalore.plot.base.Aes\n\nobject ScaleProviderHelper {\n    fun getOrCreateDefault(aes: Aes<*>, providers: Map<Aes<*>, ScaleProvider<*>>): ScaleProvider<*> {\n        val realAes = when {\n            Aes.isPositionalX(aes) -> Aes.X\n            Aes.isPositionalY(aes) -> Aes.Y\n            else -> aes\n        }\n\n        return providers[realAes] ?: createDefault(realAes)\n    }\n\n    fun <T> createDefault(aes: Aes<T>): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes).build()\n    }\n\n    fun <T> createDefault(aes: Aes<T>, name: String): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes)\n            .name(name)\n            .build()\n    }\n\n    fun <T> create(name: String, aes: Aes<T>, mapperProvider: MapperProvider<T>): ScaleProvider<T> {\n        return ScaleProviderBuilder(aes)\n            .mapperProvider(mapperProvider)\n            .name(name)\n            .build()\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport kotlin.math.abs\n\nobject ColorMapper {\n    val NA_VALUE = Color.GRAY\n\n    // https://ggplot2.tidyverse.org/current/scale_gradient.html\n    val DEF_GRADIENT_LOW = Color.parseHex(\"#132B43\")\n    val DEF_GRADIENT_HIGH = Color.parseHex(\"#56B1F7\")\n\n    fun gradientDefault(domain: ClosedRange<Double>): (Double?) -> Color {\n        return gradient(\n            domain,\n            DEF_GRADIENT_LOW,\n            DEF_GRADIENT_HIGH,\n            NA_VALUE\n        )\n    }\n\n    fun gradient(domain: ClosedRange<Double>, low: Color, high: Color, naColor: Color): (Double?) -> Color {\n        return gradientHSV(\n            domain,\n            Colors.hsvFromRgb(low),\n            Colors.hsvFromRgb(high),\n            true,\n            naColor\n        )\n    }\n\n    /**\n     * @deprecated\n     */\n    fun gradientHSV(\n        domain: ClosedRange<Double>,\n        lowHSV: DoubleArray,\n        highHSV: DoubleArray,\n        autoHueDirection: Boolean,\n        naColor: Color\n    ): (Double?) -> Color {\n        return gradientHSV(\n            domain,\n            HSV(lowHSV[0], lowHSV[1], lowHSV[2]),\n            HSV(highHSV[0], highHSV[1], highHSV[2]),\n            autoHueDirection,\n            naColor\n        )\n    }\n\n    fun gradientHSV(\n        domain: ClosedRange<Double>,\n        lowHSV: HSV,\n        highHSV: HSV,\n        autoHueDirection: Boolean,\n        naColor: Color\n    ): (Double?) -> Color {\n\n        var lowHue = lowHSV.h\n        var highHue = highHSV.h\n\n        val lowS = lowHSV.s\n        val highS = highHSV.s\n\n        // No hue if saturation is near zero\n        if (lowS < 0.0001) {\n            lowHue = highHue\n        }\n        if (highS < 0.0001) {\n            highHue = lowHue\n        }\n\n        if (autoHueDirection) {\n            val dH = abs(highHue - lowHue)\n            if (dH > 180) {\n                if (highHue >= lowHue) {\n                    lowHue += 360.0\n                } else {\n                    highHue += 360.0\n                }\n            }\n        }\n\n        val mapperH = Mappers.linear(domain, lowHue, highHue, Double.NaN)\n        val mapperS = Mappers.linear(domain, lowS, highS, Double.NaN)\n        val mapperV = Mappers.linear(domain, lowHSV.v, highHSV.v, Double.NaN)\n\n        return { input ->\n            if (input == null || !domain.contains(input)) {\n                naColor\n            } else {\n                val hue = mapperH(input) % 360\n                val H = if (hue >= 0) hue else 360 + hue\n                val S = mapperS(input)\n                val V = mapperV(input)\n                Colors.rgbFromHsv(H, S, V)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\ninternal class GuideMapperAdapter<T> constructor(\n    private val mapper: (Double?) -> T?,\n    override val isContinuous: Boolean\n) : GuideMapper<T> {\n\n    override fun apply(value: Double?): T? {\n        return mapper(value)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.WithGuideBreaks\n\ninternal class GuideMapperWithGuideBreaks<DomainT, TargetT>(\n    private val mapper: (Double?) -> TargetT?,\n    override val breaks: List<DomainT>,\n    override val formatter: (DomainT) -> String\n) : GuideMapper<TargetT>,\n    WithGuideBreaks<DomainT> {\n\n    override val isContinuous = false\n\n    override fun apply(value: Double?): TargetT? {\n        return mapper(value)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.scale.Mappers\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\nobject GuideMappers {\n    val IDENTITY: GuideMapper<Double> =\n        GuideMapperAdapter(Mappers.IDENTITY, isContinuous = false) // ToDo: why isContinuous = false?\n    val UNDEFINED: GuideMapper<Double> =\n        GuideMapperAdapter(Mappers.undefined(), false)\n\n    fun <TargetT> discreteToDiscrete(\n        data: DataFrame,\n        variable: DataFrame.Variable,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n\n        val domainValues = data.distinctValues(variable)\n        return discreteToDiscrete(\n            domainValues,\n            outputValues,\n            naValue\n        )\n    }\n\n    fun <TargetT> discreteToDiscrete(\n        domainValues: Collection<*>,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n\n        val mapper = Mappers.discrete(outputValues, naValue)\n        return GuideMapperWithGuideBreaks(\n            mapper,\n            domainValues.mapNotNull { it }\n        ) { v: Any -> v.toString() }\n    }\n\n    fun <TargetT> continuousToDiscrete(\n        domain: ClosedRange<Double>?,\n        outputValues: List<TargetT>,\n        naValue: TargetT\n    ): GuideMapper<TargetT> {\n        // quantized\n        val mapper = Mappers.quantized(domain, outputValues, naValue)\n        return asNotContinuous(mapper)\n    }\n\n    fun discreteToContinuous(\n        domainValues: Collection<*>,\n        outputRange: ClosedRange<Double>,\n        naValue: Double\n    ): GuideMapper<Double> {\n\n        val mapper = Mappers.discreteToContinuous(domainValues, outputRange, naValue)\n        return GuideMapperWithGuideBreaks(\n            mapper,\n            domainValues.mapNotNull { it }\n        ) { v: Any -> v.toString() }\n    }\n\n    fun continuousToContinuous(\n        domain: ClosedRange<Double>,\n        range: ClosedRange<Double>,\n        naValue: Double\n    ): GuideMapper<Double> {\n        return asContinuous(\n            Mappers.linear(\n                domain,\n                range,\n                naValue\n            )\n        )\n    }\n\n    fun <T> asNotContinuous(mapper: (Double?) -> T): GuideMapper<T> {\n        return GuideMapperAdapter(mapper, false)\n    }\n\n    fun <T> asContinuous(mapper: (Double?) -> T?): GuideMapper<T> {\n        return GuideMapperAdapter(mapper, true)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.base.render.linetype.LineType\nimport jetbrains.datalore.plot.base.render.linetype.NamedLineType\n\nobject LineTypeMapper {\n    val NA_VALUE: LineType = NamedLineType.SOLID\n\n    fun allLineTypes(): List<LineType> {\n        return listOf(\n                NamedLineType.SOLID,\n                NamedLineType.DASHED,\n                NamedLineType.DOTTED,\n                NamedLineType.DOTDASH,\n                NamedLineType.LONGDASH,\n                NamedLineType.TWODASH\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.mapper\n\nimport jetbrains.datalore.plot.base.render.point.NamedShape\nimport jetbrains.datalore.plot.base.render.point.PointShape\nimport jetbrains.datalore.plot.base.render.point.TinyPointShape\n\nobject ShapeMapper {\n    val NA_VALUE = TinyPointShape\n\n    fun allShapes(): List<PointShape> {\n        val bestSix: List<PointShape> = listOf(\n                NamedShape.SOLID_CIRCLE,\n                NamedShape.SOLID_TRIANGLE_UP,\n                NamedShape.SOLID_SQUARE,\n                NamedShape.STICK_PLUS,\n                NamedShape.STICK_SQUARE_CROSS,\n                NamedShape.STICK_STAR\n        )\n\n        val theRest = LinkedHashSet<PointShape>(listOf(*NamedShape.values()))\n        theRest.removeAll(bestSix)\n\n        val shapes = ArrayList(bestSix)\n        shapes.addAll(theRest)\n        return shapes\n    }\n\n    /**\n     * see: scale_shape(..., solid = FALSE)\n     */\n    fun hollowShapes(): List<PointShape> {\n        val bestThreeHollow = listOf(\n                NamedShape.STICK_CIRCLE,\n                NamedShape.STICK_TRIANGLE_UP,\n                NamedShape.STICK_SQUARE\n        )\n\n        val theRest = LinkedHashSet(listOf(*NamedShape.values()))\n        theRest.removeAll(bestThreeHollow)\n\n        val shapes = ArrayList(bestThreeHollow)\n        for (shape in theRest) {\n            if (shape.isHollow) {\n                shapes.add(shape)\n            }\n        }\n        return shapes\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes.Companion.ALPHA\nimport jetbrains.datalore.plot.builder.scale.DefaultNaValue\n\nclass AlphaMapperProvider(\n    range: ClosedRange<Double>,\n    naValue: Double\n) : LinearNormalizingMapperProvider(range, naValue) {\n\n    companion object {\n        private val DEF_RANGE = ClosedRange(0.1, 1.0)\n\n        val DEFAULT = AlphaMapperProvider(\n            DEF_RANGE,\n            DefaultNaValue[ALPHA]\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Lists\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.color.ColorPalette\nimport jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.Set2\nimport jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.Set3\nimport jetbrains.datalore.plot.common.color.ColorPalette.Type.*\nimport jetbrains.datalore.plot.common.color.ColorScheme\nimport jetbrains.datalore.plot.common.color.PaletteUtil\nimport jetbrains.datalore.plot.common.color.PaletteUtil.colorSchemeByIndex\n\n\n/**\n * @param paletteTypeName - One of seq (sequential), div (diverging) or qual (qualitative)\n * @param paletteNameOrIndex - If a string, will use that named palette.\n * If a number, will index into the list of palettes of appropriate type\n * @param direction - Sets the order of colors in the scale. If 1, the default, colors are as output by brewer.pal.\n * If -1, the order of colors is reversed\n * @param naValue\n */\nclass ColorBrewerMapperProvider(\n    private val paletteTypeName: String?,\n    private val paletteNameOrIndex: Any?,\n    private val direction: Double?,\n    naValue: Color\n) : MapperProviderBase<Color>(naValue) {\n\n    init {\n        require(paletteNameOrIndex?.let {\n            paletteNameOrIndex is String || paletteNameOrIndex is Number\n        } ?: true) {\n            \"palette: expected a name or index but was: ${paletteNameOrIndex!!::class.simpleName}\"\n        }\n\n        if (paletteNameOrIndex is Number) {\n            require(paletteTypeName != null) { \"brewer palette type required: 'seq', 'div' or 'qual'.\" }\n        }\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        val colorScheme = colorScheme(true, domainValues.size)\n        val colors = colors(colorScheme, domainValues.size)\n        return GuideMappers.discreteToDiscrete(domainValues, colors, naValue)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        val colorScheme = colorScheme(false)\n        val colors = colors(colorScheme, colorScheme.maxColors)\n\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return GuideMappers.continuousToDiscrete(domain, colors, naValue)\n    }\n\n    private fun colors(colorScheme: ColorScheme, count: Int): List<Color> {\n        val colors: List<Color> = PaletteUtil.schemeColors(colorScheme, count)\n        return when (direction?.let { direction < 0 } ?: false) {\n            true -> Lists.reverse(colors)\n            false -> colors\n        }\n    }\n\n    private fun colorScheme(discrete: Boolean, colorCount: Int? = null): ColorScheme {\n        val paletteType = when {\n            paletteNameOrIndex is String -> {\n                val palType = PaletteUtil.paletteTypeByPaletteName(paletteNameOrIndex)\n                require(palType != null) { cantFindPaletteError(paletteNameOrIndex) }\n                palType\n            }\n            paletteTypeName != null -> paletteType(paletteTypeName)\n            discrete -> QUALITATIVE\n            else -> SEQUENTIAL\n        }\n\n        return when {\n            paletteNameOrIndex is Number -> colorSchemeByIndex(paletteType, paletteNameOrIndex.toInt())\n            paletteNameOrIndex is String -> colorSchemeByName(paletteType, paletteNameOrIndex)\n            paletteType == QUALITATIVE -> {\n                if (colorCount != null && colorCount <= Set2.maxColors) Set2\n                else Set3\n            }\n            else -> colorSchemeByIndex(paletteType, 0)\n        }\n    }\n\n\n    companion object {\n        private fun paletteType(name: String?): ColorPalette.Type {\n            if (name == null) {\n                return SEQUENTIAL\n            }\n            return when (name) {\n                \"seq\" -> SEQUENTIAL\n                \"div\" -> DIVERGING\n                \"qual\" -> QUALITATIVE\n                else -> throw IllegalArgumentException(\n                    \"Palette type expected one of 'seq' (sequential), 'div' (diverging) or 'qual' (qualitative) but was: '$name'\"\n                )\n            }\n        }\n\n        private fun colorSchemeByName(paletteType: ColorPalette.Type, paletteName: String): ColorScheme {\n            try {\n                return when (paletteType) {\n                    SEQUENTIAL -> ColorPalette.Sequential.valueOf(paletteName)\n                    DIVERGING -> ColorPalette.Diverging.valueOf(paletteName)\n                    QUALITATIVE -> ColorPalette.Qualitative.valueOf(paletteName)\n                }\n            } catch (ignore: IllegalArgumentException) {\n                // Enum type has no constant with the specified name error.\n                // Replace generic error massage with specific one\n                throw IllegalArgumentException(cantFindPaletteError(paletteName))\n            }\n        }\n\n        private fun cantFindPaletteError(paletteName: String): String {\n            return \"\"\"\n                |Brewer palette '$paletteName' was not found. \n                |Valid palette names are: \n                |   Type 'seq' (sequential): \n                |       ${names(ColorPalette.Sequential.values())}       \n                |   Type 'div' (diverging): \n                |       ${names(ColorPalette.Diverging.values())}       \n                |   Type 'qual' (qualitative): \n                |       ${names(ColorPalette.Qualitative.values())}       \n            \"\"\".trimMargin()\n        }\n\n        private fun <T : Enum<T>> names(enums: Array<T>): String {\n            return enums.joinToString(\", \") { \"'${it.name}'\" }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.ContinuousOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass ColorGradient2MapperProvider(\n    low: Color?, mid: Color?, high: Color?, midpoint: Double?, naValue: Color\n) : ContinuousOnlyMapperProvider<Color>(naValue) {\n\n    private val myLow: Color\n    private val myMid: Color\n    private val myHigh: Color\n    private val myMidpoint: Double?\n\n    init {\n        myLow = low ?: DEF_GRADIENT_LOW\n        myMid = mid ?: DEF_GRADIENT_MID\n        myHigh = high ?: DEF_GRADIENT_HIGH\n        myMidpoint = midpoint ?: 0.0\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n\n        val lowDomain = ClosedRange(domain.lowerEnd, max(myMidpoint!!, domain.lowerEnd))\n        val highDomain = ClosedRange(min(myMidpoint, domain.upperEnd), domain.upperEnd)\n\n        val lowMapper = ColorMapper.gradient(lowDomain, myLow, myMid, naValue)\n        val highMapper = ColorMapper.gradient(highDomain, myMid, myHigh, naValue)\n\n        val rangeMap = mapOf(\n            lowDomain to lowMapper,\n            highDomain to highMapper\n        )\n\n        fun getMapper(v: Double?): ((Double?) -> Color)? {\n            var f_: ((Double?) -> Color)? = null\n            if (SeriesUtil.isFinite(v)) {\n                var f_span = Double.NaN\n                for (range in rangeMap.keys) {\n                    if (range.contains(v!!)) {\n                        val span = range.upperEnd - range.lowerEnd\n                        // try to avoid 0-length ranges\n                        // but prefer shorter ranges\n                        if (f_ == null || f_span == 0.0) {\n                            f_ = rangeMap.get(range)\n                            f_span = span\n                        } else if (span < f_span && span > 0) {\n                            f_ = rangeMap.get(range)\n                            f_span = span\n                        }\n                    }\n                }\n            }\n            return f_\n        }\n\n        val mapperFun: (Double?) -> Color = { input: Double? ->\n            val mapper = getMapper(input)\n            mapper?.invoke(input) ?: naValue\n        }\n\n        return GuideMappers.asContinuous(mapperFun)\n    }\n\n    companion object {\n        // https://ggplot2.tidyverse.org/current/scale_gradient.html\n        private val DEF_GRADIENT_LOW = Color.parseHex(\"#964540\") // muted(\"red\")\n        private val DEF_GRADIENT_MID = Color.WHITE\n        private val DEF_GRADIENT_HIGH = Color.parseHex(\"#3B3D96\") // muted(\"blue\")\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\n\n\nclass ColorGradientMapperProvider(low: Color?, high: Color?, naValue: Color) : MapperProviderBase<Color>(naValue) {\n\n    private val low: Color = low ?: ColorMapper.DEF_GRADIENT_LOW\n    private val high: Color = high ?: ColorMapper.DEF_GRADIENT_HIGH\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        val domainValuesAsNumbers = MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val mapperDomain = SeriesUtil.range(domainValuesAsNumbers.values)!!\n        val gradient = ColorMapper.gradient(mapperDomain, low, high, naValue)\n        return GuideMappers.asNotContinuous(gradient)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        val gradient = ColorMapper.gradient(domain, low, high, naValue)\n        return GuideMappers.asContinuous(gradient)\n    }\n\n    companion object {\n        val DEFAULT = ColorGradientMapperProvider(\n            null,\n            null,\n            ColorMapper.NA_VALUE\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass ColorHueMapperProvider(\n    hueRange: List<Double>?,\n    chroma: Double?,\n    luminance: Double?,\n    startHue: Double?,\n    direction: Double?,\n    naValue: Color\n) : HSVColorMapperProvider(naValue) {\n\n    private val myFromHSV: HSV\n    private val myToHSV: HSV\n    private val myHSVIntervals: List<Pair<HSV, HSV>>\n\n    init {\n        @Suppress(\"NAME_SHADOWING\")\n        val hueRange = normalizeHueRange(hueRange)\n        val clockwise = direction == null || direction != -1.0\n\n        val fromHue = if (clockwise) hueRange.lowerEnd else hueRange.upperEnd\n        val toHue = if (clockwise) hueRange.upperEnd else hueRange.lowerEnd\n\n        @Suppress(\"NAME_SHADOWING\")\n        val startHue = startHue ?: DEF_START_HUE\n\n        val hueIntervals = if (hueRange.contains(startHue) &&\n            startHue - hueRange.lowerEnd > 1 && hueRange.upperEnd - startHue > 1\n        ) {\n            listOf(\n                startHue to toHue,\n                fromHue to startHue\n            )\n        } else {\n            listOf(\n                fromHue to toHue\n            )\n        }\n\n        val saturation = (if (chroma != null) chroma % 100 else DEF_SATURATION) / 100\n        val value = (if (luminance != null) luminance % 100 else DEF_VALUE) / 100\n\n        // for continuous data\n        myHSVIntervals = hueIntervals.map { HSV(it.first, saturation, value) to HSV(it.second, saturation, value) }\n\n        // for discrete data: 'startHue' is ignored (intervals not used)\n        myFromHSV = HSV(fromHue, saturation, value)\n        myToHSV = HSV(toHue, saturation, value)\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        return createDiscreteMapper(domainValues, myFromHSV, myToHSV)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return createContinuousMapper(domain, myHSVIntervals)\n    }\n\n    companion object {\n        private const val DEF_SATURATION = 50.0\n        private const val DEF_VALUE = 90.0\n        private const val DEF_START_HUE = 0.0\n        private val DEF_HUE_RANGE = ClosedRange<Double>(15.0, 375.0) // ggplot2 (R): c(0, 360) + 15\n\n        val DEFAULT = ColorHueMapperProvider(\n            null,\n            null,\n            null,\n            null,\n            null,\n            Color.GRAY\n        )\n\n        private fun normalizeHueRange(hueRange: List<Double>?): ClosedRange<Double> {\n            return if (hueRange == null || hueRange.size != 2) {\n                DEF_HUE_RANGE\n            } else {\n                ClosedRange<Double>(\n                    min(hueRange[0], hueRange[1]),\n                    max(hueRange[0], hueRange[1])\n                )\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.ContinuousOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\n/**\n * @param naValue value used when size is not defined\n */\nopen class DirectlyProportionalMapperProvider(\n    private val max: Double,\n    naValue: Double\n) : ContinuousOnlyMapperProvider<Double>(naValue) {\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Double> {\n        val dataMax = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans).upperEnd\n        return GuideMappers.continuousToContinuous(ClosedRange(0.0, dataMax), ClosedRange(0.0, max), naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\n\nclass GreyscaleLightnessMapperProvider(\n    start: Double?,\n    end: Double?,\n    naValue: Color\n) : HSVColorMapperProvider(naValue) {\n\n    private val myFromHSV: HSV\n    private val myToHSV: HSV\n\n    init {\n        val value0 = start ?: DEF_START\n        val value1 = end ?: DEF_END\n\n        require(value0 in (0.0..1.0)) { \"Value of 'start' must be in range: [0,1]: $start\" }\n        require(value1 in (0.0..1.0)) { \"Value of 'end' must be in range: [0,1]: $end\" }\n\n        myFromHSV = HSV(0.0, 0.0, value0)\n        myToHSV = HSV(0.0, 0.0, value1)\n    }\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Color> {\n        return createDiscreteMapper(domainValues, myFromHSV, myToHSV)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Color> {\n\n        @Suppress(\"NAME_SHADOWING\")\n        val domain = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return createContinuousMapper(\n            domain,\n            listOf(myFromHSV to myToHSV)\n        )\n    }\n\n    companion object {\n        private const val DEF_START = 0.2\n        private const val DEF_END = 0.8\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.HSV\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.ColorMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\nimport jetbrains.datalore.plot.common.data.SeriesUtil\nimport jetbrains.datalore.plot.common.data.SeriesUtil.ensureApplicableRange\nimport kotlin.math.abs\n\nabstract class HSVColorMapperProvider(naValue: Color) : MapperProviderBase<Color>(naValue) {\n\n    protected fun createDiscreteMapper(\n        domainValues: Collection<*>,\n        fromHSV: HSV,\n        toHSV: HSV\n    ): GuideMapper<Color> {\n        val domainValuesAsNumbers = MapperUtil.mapDiscreteDomainValuesToNumbers(domainValues)\n        val mapperDomain = ensureApplicableRange(SeriesUtil.range(domainValuesAsNumbers.values))\n\n        var newFromHue = fromHSV.h\n        var newToHue = toHSV.h\n        if (domainValues.size > 1) {\n            // if 'from' and 'to' hue are too close - ajust the 'toHue'\n            val hueDiff = abs(toHSV.h % 360 - fromHSV.h % 360)\n            val step = (toHSV.h - fromHSV.h) / domainValues.size\n            if (hueDiff < abs(step) / 2) {\n                newFromHue = fromHSV.h + step / 2\n                newToHue = toHSV.h - step / 2\n            }\n        }\n\n        val gradient = ColorMapper.gradientHSV(\n            mapperDomain,\n            HSV(newFromHue, fromHSV.s, fromHSV.v),\n            HSV(newToHue, toHSV.s, toHSV.v),\n            false, naValue\n        )\n        return GuideMappers.asNotContinuous(gradient)\n    }\n\n    protected fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        hsvIntervals: List<Pair<HSV, HSV>>\n    ): GuideMapper<Color> {\n        val gradientMapper = when (hsvIntervals.size) {\n            0 -> throw IllegalArgumentException(\"Empty HSV intervals.\")\n            1 -> ColorMapper.gradientHSV(domain, hsvIntervals[0].first, hsvIntervals[0].second, false, naValue)\n            else -> createCompositeColorMapper(domain, hsvIntervals, false, naValue)\n        }\n\n        return GuideMappers.asContinuous(gradientMapper)\n    }\n\n\n    companion object {\n        private fun createCompositeColorMapper(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>,\n            autoHueDirection: Boolean,\n            naColor: Color\n        ): (Double?) -> Color {\n            val colorMappersPerSubDomain =\n                createColorMappersPerSubDomain(domain, hsvIntervals, autoHueDirection, naColor)\n\n            return { v: Double? ->\n                if (v == null) {\n                    naColor\n                } else {\n                    val mapper = colorMappersPerSubDomain.find { it.first.contains(v) }?.second\n                    mapper?.invoke(v) ?: naColor\n                }\n            }\n        }\n\n        private fun createColorMappersPerSubDomain(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>,\n            autoHueDirection: Boolean,\n            naColor: Color\n        ): List<Pair<ClosedRange<Double>, (Double?) -> Color>> {\n            val subDomains = splitContinuousDomain(domain, hsvIntervals)\n\n            return subDomains.zip(hsvIntervals).map {\n                @Suppress(\"NAME_SHADOWING\")\n                val domain = it.first\n                val hsvInterval = it.second\n                Pair(\n                    domain,\n                    ColorMapper.gradientHSV(domain, hsvInterval.first, hsvInterval.second, autoHueDirection, naColor)\n                )\n            }\n        }\n\n        private fun splitContinuousDomain(\n            domain: ClosedRange<Double>,\n            hsvIntervals: List<Pair<HSV, HSV>>\n        ): List<ClosedRange<Double>> {\n            val domainSize = domain.upperEnd - domain.lowerEnd\n            val hueIntervalSizeList = hsvIntervals.map {\n                abs(it.first.h - it.second.h)\n            }\n            val hueIntervalsTotalSize = hueIntervalSizeList.sum()\n\n            val domainToHueIntevalRatio = domainSize / hueIntervalsTotalSize\n\n            val subDomains = ArrayList<ClosedRange<Double>>()\n            var lowerEnd = domain.lowerEnd\n            for (hueIntervalSize in hueIntervalSizeList) {\n                val upperEnd = lowerEnd + hueIntervalSize * domainToHueIntevalRatio\n                subDomains.add(ClosedRange(lowerEnd, upperEnd))\n                lowerEnd = upperEnd\n            }\n            return subDomains\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.builder.scale.DiscreteOnlyMapperProvider\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nopen class IdentityDiscreteMapperProvider<T>(\n    private val inputConverter: (Any?) -> T?,\n    naValue: T\n) : DiscreteOnlyMapperProvider<T>(naValue) {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        val outputValues = ArrayList<T>()\n        for (inputValue in domainValues) {\n            if (inputValue == null) {\n                outputValues.add(naValue)\n            } else {\n                val outputValue = inputConverter(inputValue)\n                    ?: throw IllegalStateException(\"Can't map input value $inputValue to output type\")\n                outputValues.add(outputValue)\n            }\n        }\n        return GuideMappers.discreteToDiscrete(domainValues, outputValues, naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.MapperProvider\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nclass IdentityMapperProvider<T>(\n    private val discreteMapperProvider: IdentityDiscreteMapperProvider<T>,\n    private val continuousMapper: (Double?) -> T?\n) : MapperProvider<T> {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<T> {\n        return discreteMapperProvider.createDiscreteMapper(domainValues)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<T> {\n        return GuideMappers.asContinuous(continuousMapper)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.ContinuousTransform\nimport jetbrains.datalore.plot.base.scale.MapperUtil\nimport jetbrains.datalore.plot.builder.scale.GuideMapper\nimport jetbrains.datalore.plot.builder.scale.mapper.GuideMappers\n\nopen class LinearNormalizingMapperProvider(\n    private val outputRange: ClosedRange<Double>,\n    naValue: Double\n) : MapperProviderBase<Double>(naValue) {\n\n    override fun createDiscreteMapper(domainValues: Collection<*>): GuideMapper<Double> {\n        return GuideMappers.discreteToContinuous(domainValues, outputRange, naValue)\n    }\n\n    override fun createContinuousMapper(\n        domain: ClosedRange<Double>,\n        lowerLimit: Double?,\n        upperLimit: Double?,\n        trans: ContinuousTransform\n    ): GuideMapper<Double> {\n        val dataRange = MapperUtil.rangeWithLimitsAfterTransform(domain, lowerLimit, upperLimit, trans)\n        return GuideMappers.continuousToContinuous(dataRange, outputRange, naValue)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.builder.scale.MapperProvider\n\nabstract class MapperProviderBase<T>(protected val naValue: T) : MapperProvider<T>\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.plot.base.aes.AesScaling\n\nclass SizeAreaMapperProvider(\n    max: Double?,\n    naValue: Double\n) : DirectlyProportionalMapperProvider(max ?: DEF_MAX, naValue) {\n\n    companion object {\n        val DEF_MAX = AesScaling.sizeFromCircleDiameter(21.0)\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.scale.provider\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.plot.base.Aes.Companion.SIZE\nimport jetbrains.datalore.plot.base.aes.AesScaling\nimport jetbrains.datalore.plot.builder.scale.DefaultNaValue\n\nclass SizeMapperProvider(\n    range: ClosedRange<Double>,\n    naValue: Double\n) : LinearNormalizingMapperProvider(range, naValue) {\n\n    companion object {\n        private val DEF_RANGE = ClosedRange(\n            AesScaling.sizeFromCircleDiameter(3.0),\n            AesScaling.sizeFromCircleDiameter(21.0)\n        )\n\n        val DEFAULT = SizeMapperProvider(\n            DEF_RANGE,\n            DefaultNaValue[SIZE]\n        )\n    }\n}","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\ninterface AxisTheme {\n    fun showLine(): Boolean\n\n    fun showTickMarks(): Boolean\n\n    fun showTickLabels(): Boolean\n\n    fun showTitle(): Boolean\n\n    fun showTooltip(): Boolean\n\n    fun lineWidth(): Double\n\n    fun tickMarkWidth(): Double\n\n    fun tickMarkLength(): Double\n\n    fun tickMarkPadding(): Double\n\n    fun tickLabelDistance(): Double {\n        var result = tickMarkPadding()  // little space always\n        if (showTickMarks()) {\n            result += tickMarkLength()\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\nimport jetbrains.datalore.plot.builder.presentation.Defaults.Plot\n\nopen class DefaultAxisTheme : AxisTheme {\n    override fun showLine(): Boolean {\n        return true\n    }\n\n    override fun showTickMarks(): Boolean {\n        return true\n    }\n\n    override fun showTickLabels(): Boolean {\n        return true\n    }\n\n    override fun showTitle(): Boolean {\n        return true\n    }\n\n    override fun showTooltip(): Boolean {\n        return true\n    }\n\n    override fun lineWidth(): Double {\n        return Plot.Axis.LINE_WIDTH\n    }\n\n    override fun tickMarkWidth(): Double {\n        return Plot.Axis.TICK_LINE_WIDTH\n    }\n\n    override fun tickMarkLength(): Double {\n        return 6.0\n    }\n\n    override fun tickMarkPadding(): Double {\n        return 3.0\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.theme\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.base.values.Colors\nimport jetbrains.datalore.plot.builder.guide.LegendDirection\nimport jetbrains.datalore.plot.builder.guide.LegendJustification\nimport jetbrains.datalore.plot.builder.guide.LegendPosition\n\n\nopen class DefaultTheme : Theme {\n\n    override fun axisX(): AxisTheme {\n        return AXIS_THEME\n    }\n\n    override fun axisY(): AxisTheme {\n        return AXIS_THEME\n    }\n\n    override fun legend(): LegendTheme {\n        return LEGEND_THEME\n    }\n\n    override fun facets(): FacetsTheme {\n        return FACETS_THEME\n    }\n\n    override fun plot(): PlotTheme {\n        return PLOT_THEME\n    }\n\n    override fun multiTile(): Theme {\n        return object : DefaultTheme() {\n            override fun axisX(): AxisTheme {\n                return AXIS_THEME_MULTI_TILE\n            }\n\n            override fun axisY(): AxisTheme {\n                return AXIS_THEME_MULTI_TILE\n            }\n\n            override fun plot(): PlotTheme {\n                return PLOT_THEME_MULTI_TILE\n            }\n        }\n    }\n\n    companion object {\n        private val AXIS_THEME = DefaultAxisTheme()\n\n        private val AXIS_THEME_MULTI_TILE: AxisTheme = object : DefaultAxisTheme() {\n            override fun showLine(): Boolean {\n                return false  // replaced by inner frame\n            }\n        }\n\n        private val LEGEND_THEME: LegendTheme = object : LegendTheme {\n            override fun keySize(): Double {\n                return 23.0\n            }\n\n            override fun margin(): Double {\n                return 5.0\n            }\n\n            override fun padding(): Double {\n                return 5.0\n            }\n\n            override fun position(): LegendPosition {\n                return LegendPosition.RIGHT\n            }\n\n            override fun justification(): LegendJustification {\n                return LegendJustification.CENTER\n            }\n\n            override fun direction(): LegendDirection {\n                return LegendDirection.AUTO\n            }\n\n            override fun backgroundFill(): Color {\n                return Color.WHITE\n            }\n        }\n\n        private val FACETS_THEME: FacetsTheme = object : FacetsTheme {\n            override fun labelBackground(): Color {\n                return Colors.lighter(Color.VERY_LIGHT_GRAY, 0.9)\n            }\n        }\n\n        private val PLOT_THEME: PlotTheme = object : PlotTheme {\n            override fun showInnerFrame(): Boolean {\n                return false\n            }\n\n            override fun innerFrameColor(): Color {\n                throw IllegalStateException(\"The `innerFrameColor()` method shouldn't be used.\")\n            }\n        }\n\n        private val PLOT_THEME_MULTI_TILE: PlotTheme = object : PlotTheme {\n            override fun showInnerFrame(): Boolean {\n                return true\n            }\n\n            override fun innerFrameColor(): Color {\n                return Colors.lighter(Color.VERY_LIGHT_GRAY, 0.9)\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass ConstantValue(\n    private val value: Any,\n    private val format: String? = null\n) : ValueSource {\n\n    private val myDataValue = if (format != null) {\n        StringFormat.create(format).format(value)\n    } else {\n        value.toString()\n    }\n\n    override val isOutlier: Boolean = false\n    override val isAxis: Boolean = false\n\n    override fun initDataContext(dataContext: DataContext) {\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        return DataPoint(\n            label = \"\",\n            value = myDataValue,\n            aes = null,\n            isAxis = false,\n            isOutlier = false\n        )\n    }\n\n    override fun copy(): ConstantValue {\n        return ConstantValue(\n            value,\n            format\n        )\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.DataFrame\nimport jetbrains.datalore.plot.base.data.DataFrameUtil\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass DataFrameValue(\n    private val name: String,\n    private val format: String? = null\n) : ValueSource {\n\n    private lateinit var myDataFrame: DataFrame\n    private lateinit var myVariable: DataFrame.Variable\n    private val myFormatter = format?.let {\n//        StringFormat(format).also {\n//            require(it.argsNumber == 1) { \"Wrong number of arguments in pattern \\'$format\\' to format \\'$name\\'. Expected 1 argument instead of ${it.argsNumber}\" }\n//        }\n        StringFormat.forOneArg(format, formatFor = name)\n    }\n\n    override val isOutlier: Boolean = false\n    override val isAxis: Boolean = false\n\n    override fun initDataContext(dataContext: DataContext) {\n        require(!::myDataFrame.isInitialized) { \"Data context can be initialized only once\" }\n        myDataFrame = dataContext.dataFrame\n\n        myVariable = DataFrameUtil.findVariableOrFail(myDataFrame, name)\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val originalValue = myDataFrame[myVariable][index] ?: return null\n        return DataPoint(\n            label = name,\n            value = myFormatter?.format(originalValue) ?: originalValue.toString(),\n            aes = null,\n            isAxis = false,\n            isOutlier = false\n        )\n    }\n\n    override fun copy(): DataFrameValue {\n        return DataFrameValue(name, format)\n    }\n\n    fun getVariableName(): String {\n        return name\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.plot.base.Aes\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.MappedDataAccess\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass MappingValue(\n    val aes: Aes<*>,\n    override val isOutlier: Boolean = false,\n    override val isAxis: Boolean = false,\n    private val format: String? = null\n) : ValueSource {\n\n    private lateinit var myDataAccess: MappedDataAccess\n    private var myDataLabel: String? = null\n    private val myFormatter = format?.let {\n//        StringFormat(format).also {\n//            require(it.argsNumber == 1) { \"Wrong number of arguments in pattern \\'$format\\' to format \\'${aes.name}\\'. Expected 1 argument instead of ${it.argsNumber}\" }\n//        }\n        StringFormat.forOneArg(format, formatFor = aes.name)\n    }\n\n    override fun initDataContext(dataContext: DataContext) {\n        require(!::myDataAccess.isInitialized) { \"Data context can be initialized only once\" }\n        myDataAccess = dataContext.mappedDataAccess\n\n        require(myDataAccess.isMapped(aes)) { \"$aes have to be mapped\" }\n\n        val axisLabels = listOf(Aes.X, Aes.Y)\n            .filter(myDataAccess::isMapped)\n            .map(myDataAccess::getMappedDataLabel)\n        val dataLabel = myDataAccess.getMappedDataLabel(aes)\n        myDataLabel = when {\n            isAxis -> null\n            dataLabel.isEmpty() -> \"\"\n            dataLabel in axisLabels -> \"\"\n            else -> dataLabel\n        }\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val originalValue = myDataAccess.getOriginalValue(aes, index)\n        val formattedValue =\n            originalValue?.let { myFormatter?.format(it) } ?: myDataAccess.getMappedData(aes, index).value\n\n        // for outliers: myDataLabel is a part of the value, but pattern format removes this part\n        val value = if (isOutlier && !myDataLabel.isNullOrEmpty() &&\n            myFormatter?.formatType != StringFormat.FormatType.STRING_FORMAT\n        ) {\n            \"$myDataLabel: $formattedValue\"\n        } else {\n            formattedValue\n        }\n\n        return DataPoint(\n            label = if (isOutlier) null else myDataLabel,\n            value = value,\n            aes = aes,\n            isAxis = isAxis,\n            isOutlier = isOutlier\n        )\n    }\n\n    override fun copy(): MappingValue {\n        return MappingValue(\n            aes = aes,\n            isOutlier = isOutlier,\n            isAxis = isAxis,\n            format = format\n        )\n    }\n\n    fun toOutlier(): MappingValue {\n        return MappingValue(\n            aes = aes,\n            isOutlier = true,\n            isAxis = isAxis,\n            format = format\n        )\n    }\n}\n","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.stringFormat.StringFormat\nimport jetbrains.datalore.base.stringFormat.StringFormat.FormatType.STRING_FORMAT\nimport jetbrains.datalore.plot.base.interact.DataContext\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec\nimport jetbrains.datalore.plot.base.interact.TooltipLineSpec.DataPoint\n\nclass TooltipLine(\n    private val label: String?,\n    private val pattern: String,\n    val fields: List<ValueSource>\n) : TooltipLineSpec {\n    constructor(other: TooltipLine) : this(other.label, other.pattern, other.fields.map(ValueSource::copy))\n\n    //    private val myLineFormatter = StringFormat(pattern, STRING_FORMAT).also {\n//        require(it.argsNumber == fields.size) { \"Wrong number of arguments in pattern \\'$pattern\\' to format fields. Expected ${fields.size} arguments instead of ${it.argsNumber}\" }\n//    }\n    private val myLineFormatter = StringFormat.forNArgs(pattern, STRING_FORMAT, fields.size, \"fields\")\n\n    fun initDataContext(dataContext: DataContext) {\n        fields.forEach { it.initDataContext(dataContext) }\n    }\n\n    override fun getDataPoint(index: Int): DataPoint? {\n        val dataValues = fields.map { dataValue ->\n            dataValue.getDataPoint(index) ?: return null\n        }\n        return if (dataValues.size == 1) {\n            val dataValue = dataValues.single()\n            DataPoint(\n                label = chooseLabel(dataValue.label),\n                value = myLineFormatter.format(dataValue.value),\n                aes = dataValue.aes,\n                isAxis = dataValue.isAxis,\n                isOutlier = dataValue.isOutlier\n            )\n        } else {\n            DataPoint(\n                label = chooseLabel(dataValues.joinToString(\", \") { it.label ?: \"\" }),\n                value = myLineFormatter.format(dataValues.map { it.value }),\n                aes = null,\n                isAxis = false,\n                isOutlier = false\n            )\n        }\n    }\n\n    private fun chooseLabel(dataLabel: String?): String? {\n        return when (label) {\n            DEFAULT_LABEL_SPECIFIER -> dataLabel    // use default label (from data)\n            else -> label                     // use the given label (can be null)\n        }\n    }\n\n    companion object {\n        fun defaultLineForValueSource(valueSource: ValueSource): TooltipLine = TooltipLine(\n            label = DEFAULT_LABEL_SPECIFIER,\n            pattern = StringFormat.valueInLinePattern(),\n            fields = listOf(valueSource)\n        )\n\n        private const val DEFAULT_LABEL_SPECIFIER = \"@\"\n    }\n}","/*\n * Copyright (c) 2020. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.builder.tooltip\n\nimport jetbrains.datalore.base.values.Color\nimport jetbrains.datalore.plot.base.interact.TooltipAnchor\n\nclass TooltipSpecification(\n    val valueSources: List<ValueSource>,\n    val tooltipLinePatterns: List<TooltipLine>?,\n    val tooltipProperties: TooltipProperties\n) {\n    class TooltipProperties(\n        val anchor: TooltipAnchor?,\n        val minWidth: Double?,\n        val color: Color?\n    ) {\n        companion object {\n            val NONE = TooltipProperties(\n                anchor = null,\n                minWidth = null,\n                color = null\n            )\n        }\n    }\n\n    companion object {\n        fun withoutTooltip() = TooltipSpecification(\n            valueSources = emptyList(),\n            tooltipLinePatterns = emptyList(),\n            tooltipProperties = TooltipProperties.NONE\n        )\n\n        fun defaultTooltip() = TooltipSpecification(\n            valueSources = emptyList(),\n            tooltipLinePatterns = null,\n            tooltipProperties = TooltipProperties.NONE\n        )\n    }\n}"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-builder-portable.js\n"); /***/ }), @@ -185,7 +185,7 @@ eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPAC \**********************************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_base_portable) {\n 'use strict';\n var Enum = Kotlin.kotlin.Enum;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var throwISE = Kotlin.throwISE;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var JsMath = Math;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var Exception = Kotlin.kotlin.Exception;\n var throwCCE = Kotlin.throwCCE;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var numberToInt = Kotlin.numberToInt;\n var ensureNotNull = Kotlin.ensureNotNull;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var toList = Kotlin.kotlin.collections.toList_7wnvza$;\n var List = Kotlin.kotlin.collections.List;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var Iterable = Kotlin.kotlin.collections.Iterable;\n var isInfinite = Kotlin.kotlin.isInfinite_yrwdxr$;\n var equals = Kotlin.equals;\n var contains = Kotlin.kotlin.collections.contains_2ws7j4$;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var Stack = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Stack;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var wrapFunction = Kotlin.wrapFunction;\n var Comparator = Kotlin.kotlin.Comparator;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_vikexg$;\n var Format_init = $module$lets_plot_base_portable.jetbrains.datalore.base.dateFormat.Format_init_61zpoe$;\n var numberToLong = Kotlin.numberToLong;\n var Instant = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Instant;\n var getCallableRef = Kotlin.getCallableRef;\n var TimeZone = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.tz.TimeZone;\n var NumberFormat_init = $module$lets_plot_base_portable.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$;\n var roundToLong = Kotlin.kotlin.math.roundToLong_yrwdxr$;\n var RuntimeException = Kotlin.kotlin.RuntimeException;\n var Date_0 = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Date;\n var DateTime = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.DateTime;\n var Duration = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Duration;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var Month = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Month;\n var UnsupportedOperationException_init = Kotlin.kotlin.UnsupportedOperationException_init;\n var startsWith = Kotlin.kotlin.text.startsWith_7epoxm$;\n var toInt = Kotlin.kotlin.text.toInt_pdl1vz$;\n var NumberFormatException = Kotlin.kotlin.NumberFormatException;\n ColorPalette$Type.prototype = Object.create(Enum.prototype);\n ColorPalette$Type.prototype.constructor = ColorPalette$Type;\n ColorPalette$Sequential.prototype = Object.create(Enum.prototype);\n ColorPalette$Sequential.prototype.constructor = ColorPalette$Sequential;\n ColorPalette$Diverging.prototype = Object.create(Enum.prototype);\n ColorPalette$Diverging.prototype.constructor = ColorPalette$Diverging;\n ColorPalette$Qualitative.prototype = Object.create(Enum.prototype);\n ColorPalette$Qualitative.prototype.constructor = ColorPalette$Qualitative;\n DataType.prototype = Object.create(Enum.prototype);\n DataType.prototype.constructor = DataType;\n RegularMeshDetector$MyRowDetector.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$MyRowDetector.prototype.constructor = RegularMeshDetector$MyRowDetector;\n RegularMeshDetector$MyColumnDetector.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$MyColumnDetector.prototype.constructor = RegularMeshDetector$MyColumnDetector;\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype.constructor = RegularMeshDetector$Companion$NO_MESH$ObjectLiteral;\n SeriesUtil$CheckedDoubleList.prototype = Object.create(SeriesUtil$CheckedDoubleIterable.prototype);\n SeriesUtil$CheckedDoubleList.prototype.constructor = SeriesUtil$CheckedDoubleList;\n DurationInterval.prototype = Object.create(TimeInterval.prototype);\n DurationInterval.prototype.constructor = DurationInterval;\n MeasuredInDays.prototype = Object.create(TimeInterval.prototype);\n MeasuredInDays.prototype.constructor = MeasuredInDays;\n MonthInterval.prototype = Object.create(MeasuredInDays.prototype);\n MonthInterval.prototype.constructor = MonthInterval;\n QuarterInterval.prototype = Object.create(TimeInterval.prototype);\n QuarterInterval.prototype.constructor = QuarterInterval;\n SemesterInterval.prototype = Object.create(TimeInterval.prototype);\n SemesterInterval.prototype.constructor = SemesterInterval;\n YearInterval.prototype = Object.create(MeasuredInDays.prototype);\n YearInterval.prototype.constructor = YearInterval;\n function ColorPalette() {\n ColorPalette_instance = this;\n this.MIN_COLOR_SET_SIZE_0 = 3;\n }\n ColorPalette.prototype.colors_0 = function (scheme, count) {\n var count_0 = count;\n var b = count_0;\n count_0 = JsMath.max(3, b);\n var a = scheme.maxColors;\n var b_0 = count_0;\n count_0 = JsMath.min(a, b_0);\n return scheme.colorSet[count_0 - 3 | 0];\n };\n ColorPalette.prototype.maxColorSetSize_0 = function (scheme) {\n var colorSet = scheme.colorSet;\n return colorSet[colorSet.length - 1 | 0].length;\n };\n function ColorPalette$Type(name, ordinal, myPresentation) {\n Enum.call(this);\n this.myPresentation_6glhnl$_0 = myPresentation;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Type_initFields() {\n ColorPalette$Type_initFields = function () {\n };\n ColorPalette$Type$SEQUENTIAL_instance = new ColorPalette$Type('SEQUENTIAL', 0, 'sequential');\n ColorPalette$Type$DIVERGING_instance = new ColorPalette$Type('DIVERGING', 1, 'diverging');\n ColorPalette$Type$QUALITATIVE_instance = new ColorPalette$Type('QUALITATIVE', 2, 'qualitative');\n }\n var ColorPalette$Type$SEQUENTIAL_instance;\n function ColorPalette$Type$SEQUENTIAL_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$SEQUENTIAL_instance;\n }\n var ColorPalette$Type$DIVERGING_instance;\n function ColorPalette$Type$DIVERGING_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$DIVERGING_instance;\n }\n var ColorPalette$Type$QUALITATIVE_instance;\n function ColorPalette$Type$QUALITATIVE_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$QUALITATIVE_instance;\n }\n ColorPalette$Type.prototype.toString = function () {\n return this.myPresentation_6glhnl$_0;\n };\n ColorPalette$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function ColorPalette$Type$values() {\n return [ColorPalette$Type$SEQUENTIAL_getInstance(), ColorPalette$Type$DIVERGING_getInstance(), ColorPalette$Type$QUALITATIVE_getInstance()];\n }\n ColorPalette$Type.values = ColorPalette$Type$values;\n function ColorPalette$Type$valueOf(name) {\n switch (name) {\n case 'SEQUENTIAL':\n return ColorPalette$Type$SEQUENTIAL_getInstance();\n case 'DIVERGING':\n return ColorPalette$Type$DIVERGING_getInstance();\n case 'QUALITATIVE':\n return ColorPalette$Type$QUALITATIVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Type.' + name);\n }\n }\n ColorPalette$Type.valueOf_61zpoe$ = ColorPalette$Type$valueOf;\n function ColorPalette$Sequential(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_w2uxp8$_0 = myPresentation;\n this.colorSet_b1v09h$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Sequential_initFields() {\n ColorPalette$Sequential_initFields = function () {\n };\n ColorPalette$Sequential$Blues_instance = new ColorPalette$Sequential('Blues', 0, 'blues', ColorSets_getInstance().BLUES);\n ColorPalette$Sequential$BuGn_instance = new ColorPalette$Sequential('BuGn', 1, 'blue-green', ColorSets_getInstance().BU_GN);\n ColorPalette$Sequential$BuPu_instance = new ColorPalette$Sequential('BuPu', 2, 'blue-purple', ColorSets_getInstance().BU_PU);\n ColorPalette$Sequential$GnBu_instance = new ColorPalette$Sequential('GnBu', 3, 'green-blue', ColorSets_getInstance().GN_BU);\n ColorPalette$Sequential$Greens_instance = new ColorPalette$Sequential('Greens', 4, 'greens', ColorSets_getInstance().GREENS);\n ColorPalette$Sequential$Greys_instance = new ColorPalette$Sequential('Greys', 5, 'greys', ColorSets_getInstance().GREYS);\n ColorPalette$Sequential$Oranges_instance = new ColorPalette$Sequential('Oranges', 6, 'oranges', ColorSets_getInstance().ORANGES);\n ColorPalette$Sequential$OrRd_instance = new ColorPalette$Sequential('OrRd', 7, 'orange-red', ColorSets_getInstance().OR_RD);\n ColorPalette$Sequential$PuBu_instance = new ColorPalette$Sequential('PuBu', 8, 'purple-blue', ColorSets_getInstance().PU_BU);\n ColorPalette$Sequential$PuBuGn_instance = new ColorPalette$Sequential('PuBuGn', 9, 'purple-blue-green', ColorSets_getInstance().PU_BU_GN);\n ColorPalette$Sequential$PuRd_instance = new ColorPalette$Sequential('PuRd', 10, 'purple-red', ColorSets_getInstance().PU_RD);\n ColorPalette$Sequential$Purples_instance = new ColorPalette$Sequential('Purples', 11, 'purples', ColorSets_getInstance().PURPLES);\n ColorPalette$Sequential$RdPu_instance = new ColorPalette$Sequential('RdPu', 12, 'red-purple', ColorSets_getInstance().RD_PU);\n ColorPalette$Sequential$Reds_instance = new ColorPalette$Sequential('Reds', 13, 'reds', ColorSets_getInstance().REDS);\n ColorPalette$Sequential$YlGn_instance = new ColorPalette$Sequential('YlGn', 14, 'yellow-green', ColorSets_getInstance().YL_GN);\n ColorPalette$Sequential$YlGnBu_instance = new ColorPalette$Sequential('YlGnBu', 15, 'yellow-green-blue', ColorSets_getInstance().YL_GN_BU);\n ColorPalette$Sequential$YlOrBr_instance = new ColorPalette$Sequential('YlOrBr', 16, 'yellow-orange-brown', ColorSets_getInstance().YL_OR_BR);\n ColorPalette$Sequential$YlOrRd_instance = new ColorPalette$Sequential('YlOrRd', 17, 'yellow-orange-red', ColorSets_getInstance().YL_OR_RD);\n }\n Object.defineProperty(ColorPalette$Sequential.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_b1v09h$_0;\n }\n });\n var ColorPalette$Sequential$Blues_instance;\n function ColorPalette$Sequential$Blues_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Blues_instance;\n }\n var ColorPalette$Sequential$BuGn_instance;\n function ColorPalette$Sequential$BuGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$BuGn_instance;\n }\n var ColorPalette$Sequential$BuPu_instance;\n function ColorPalette$Sequential$BuPu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$BuPu_instance;\n }\n var ColorPalette$Sequential$GnBu_instance;\n function ColorPalette$Sequential$GnBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$GnBu_instance;\n }\n var ColorPalette$Sequential$Greens_instance;\n function ColorPalette$Sequential$Greens_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Greens_instance;\n }\n var ColorPalette$Sequential$Greys_instance;\n function ColorPalette$Sequential$Greys_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Greys_instance;\n }\n var ColorPalette$Sequential$Oranges_instance;\n function ColorPalette$Sequential$Oranges_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Oranges_instance;\n }\n var ColorPalette$Sequential$OrRd_instance;\n function ColorPalette$Sequential$OrRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$OrRd_instance;\n }\n var ColorPalette$Sequential$PuBu_instance;\n function ColorPalette$Sequential$PuBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuBu_instance;\n }\n var ColorPalette$Sequential$PuBuGn_instance;\n function ColorPalette$Sequential$PuBuGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuBuGn_instance;\n }\n var ColorPalette$Sequential$PuRd_instance;\n function ColorPalette$Sequential$PuRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuRd_instance;\n }\n var ColorPalette$Sequential$Purples_instance;\n function ColorPalette$Sequential$Purples_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Purples_instance;\n }\n var ColorPalette$Sequential$RdPu_instance;\n function ColorPalette$Sequential$RdPu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$RdPu_instance;\n }\n var ColorPalette$Sequential$Reds_instance;\n function ColorPalette$Sequential$Reds_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Reds_instance;\n }\n var ColorPalette$Sequential$YlGn_instance;\n function ColorPalette$Sequential$YlGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlGn_instance;\n }\n var ColorPalette$Sequential$YlGnBu_instance;\n function ColorPalette$Sequential$YlGnBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlGnBu_instance;\n }\n var ColorPalette$Sequential$YlOrBr_instance;\n function ColorPalette$Sequential$YlOrBr_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlOrBr_instance;\n }\n var ColorPalette$Sequential$YlOrRd_instance;\n function ColorPalette$Sequential$YlOrRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlOrRd_instance;\n }\n Object.defineProperty(ColorPalette$Sequential.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$SEQUENTIAL_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Sequential.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Sequential.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Sequential.prototype.toString = function () {\n return this.myPresentation_w2uxp8$_0;\n };\n ColorPalette$Sequential.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Sequential',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Sequential$values() {\n return [ColorPalette$Sequential$Blues_getInstance(), ColorPalette$Sequential$BuGn_getInstance(), ColorPalette$Sequential$BuPu_getInstance(), ColorPalette$Sequential$GnBu_getInstance(), ColorPalette$Sequential$Greens_getInstance(), ColorPalette$Sequential$Greys_getInstance(), ColorPalette$Sequential$Oranges_getInstance(), ColorPalette$Sequential$OrRd_getInstance(), ColorPalette$Sequential$PuBu_getInstance(), ColorPalette$Sequential$PuBuGn_getInstance(), ColorPalette$Sequential$PuRd_getInstance(), ColorPalette$Sequential$Purples_getInstance(), ColorPalette$Sequential$RdPu_getInstance(), ColorPalette$Sequential$Reds_getInstance(), ColorPalette$Sequential$YlGn_getInstance(), ColorPalette$Sequential$YlGnBu_getInstance(), ColorPalette$Sequential$YlOrBr_getInstance(), ColorPalette$Sequential$YlOrRd_getInstance()];\n }\n ColorPalette$Sequential.values = ColorPalette$Sequential$values;\n function ColorPalette$Sequential$valueOf(name) {\n switch (name) {\n case 'Blues':\n return ColorPalette$Sequential$Blues_getInstance();\n case 'BuGn':\n return ColorPalette$Sequential$BuGn_getInstance();\n case 'BuPu':\n return ColorPalette$Sequential$BuPu_getInstance();\n case 'GnBu':\n return ColorPalette$Sequential$GnBu_getInstance();\n case 'Greens':\n return ColorPalette$Sequential$Greens_getInstance();\n case 'Greys':\n return ColorPalette$Sequential$Greys_getInstance();\n case 'Oranges':\n return ColorPalette$Sequential$Oranges_getInstance();\n case 'OrRd':\n return ColorPalette$Sequential$OrRd_getInstance();\n case 'PuBu':\n return ColorPalette$Sequential$PuBu_getInstance();\n case 'PuBuGn':\n return ColorPalette$Sequential$PuBuGn_getInstance();\n case 'PuRd':\n return ColorPalette$Sequential$PuRd_getInstance();\n case 'Purples':\n return ColorPalette$Sequential$Purples_getInstance();\n case 'RdPu':\n return ColorPalette$Sequential$RdPu_getInstance();\n case 'Reds':\n return ColorPalette$Sequential$Reds_getInstance();\n case 'YlGn':\n return ColorPalette$Sequential$YlGn_getInstance();\n case 'YlGnBu':\n return ColorPalette$Sequential$YlGnBu_getInstance();\n case 'YlOrBr':\n return ColorPalette$Sequential$YlOrBr_getInstance();\n case 'YlOrRd':\n return ColorPalette$Sequential$YlOrRd_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Sequential.' + name);\n }\n }\n ColorPalette$Sequential.valueOf_61zpoe$ = ColorPalette$Sequential$valueOf;\n function ColorPalette$Diverging(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_im16qo$_0 = myPresentation;\n this.colorSet_las6nb$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Diverging_initFields() {\n ColorPalette$Diverging_initFields = function () {\n };\n ColorPalette$Diverging$BrBG_instance = new ColorPalette$Diverging('BrBG', 0, 'brown-blue/green', ColorSets_getInstance().BR_BG);\n ColorPalette$Diverging$PiYG_instance = new ColorPalette$Diverging('PiYG', 1, 'pink-yellow/green', ColorSets_getInstance().PI_YG);\n ColorPalette$Diverging$PRGn_instance = new ColorPalette$Diverging('PRGn', 2, 'purple/red-green', ColorSets_getInstance().PR_GN);\n ColorPalette$Diverging$PuOr_instance = new ColorPalette$Diverging('PuOr', 3, 'purple-orange', ColorSets_getInstance().PU_OR);\n ColorPalette$Diverging$RdBu_instance = new ColorPalette$Diverging('RdBu', 4, 'red-blue', ColorSets_getInstance().RD_BU);\n ColorPalette$Diverging$RdGy_instance = new ColorPalette$Diverging('RdGy', 5, 'red-grey', ColorSets_getInstance().RD_GY);\n ColorPalette$Diverging$RdYlBu_instance = new ColorPalette$Diverging('RdYlBu', 6, 'red-yellow-blue', ColorSets_getInstance().RD_YL_BU);\n ColorPalette$Diverging$RdYlGn_instance = new ColorPalette$Diverging('RdYlGn', 7, 'red-yellow-green', ColorSets_getInstance().RD_YL_GN);\n ColorPalette$Diverging$Spectral_instance = new ColorPalette$Diverging('Spectral', 8, 'spectral', ColorSets_getInstance().SPECTRAL);\n }\n Object.defineProperty(ColorPalette$Diverging.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_las6nb$_0;\n }\n });\n var ColorPalette$Diverging$BrBG_instance;\n function ColorPalette$Diverging$BrBG_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$BrBG_instance;\n }\n var ColorPalette$Diverging$PiYG_instance;\n function ColorPalette$Diverging$PiYG_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PiYG_instance;\n }\n var ColorPalette$Diverging$PRGn_instance;\n function ColorPalette$Diverging$PRGn_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PRGn_instance;\n }\n var ColorPalette$Diverging$PuOr_instance;\n function ColorPalette$Diverging$PuOr_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PuOr_instance;\n }\n var ColorPalette$Diverging$RdBu_instance;\n function ColorPalette$Diverging$RdBu_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdBu_instance;\n }\n var ColorPalette$Diverging$RdGy_instance;\n function ColorPalette$Diverging$RdGy_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdGy_instance;\n }\n var ColorPalette$Diverging$RdYlBu_instance;\n function ColorPalette$Diverging$RdYlBu_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdYlBu_instance;\n }\n var ColorPalette$Diverging$RdYlGn_instance;\n function ColorPalette$Diverging$RdYlGn_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdYlGn_instance;\n }\n var ColorPalette$Diverging$Spectral_instance;\n function ColorPalette$Diverging$Spectral_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$Spectral_instance;\n }\n Object.defineProperty(ColorPalette$Diverging.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$DIVERGING_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Diverging.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Diverging.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Diverging.prototype.toString = function () {\n return this.myPresentation_im16qo$_0;\n };\n ColorPalette$Diverging.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Diverging',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Diverging$values() {\n return [ColorPalette$Diverging$BrBG_getInstance(), ColorPalette$Diverging$PiYG_getInstance(), ColorPalette$Diverging$PRGn_getInstance(), ColorPalette$Diverging$PuOr_getInstance(), ColorPalette$Diverging$RdBu_getInstance(), ColorPalette$Diverging$RdGy_getInstance(), ColorPalette$Diverging$RdYlBu_getInstance(), ColorPalette$Diverging$RdYlGn_getInstance(), ColorPalette$Diverging$Spectral_getInstance()];\n }\n ColorPalette$Diverging.values = ColorPalette$Diverging$values;\n function ColorPalette$Diverging$valueOf(name) {\n switch (name) {\n case 'BrBG':\n return ColorPalette$Diverging$BrBG_getInstance();\n case 'PiYG':\n return ColorPalette$Diverging$PiYG_getInstance();\n case 'PRGn':\n return ColorPalette$Diverging$PRGn_getInstance();\n case 'PuOr':\n return ColorPalette$Diverging$PuOr_getInstance();\n case 'RdBu':\n return ColorPalette$Diverging$RdBu_getInstance();\n case 'RdGy':\n return ColorPalette$Diverging$RdGy_getInstance();\n case 'RdYlBu':\n return ColorPalette$Diverging$RdYlBu_getInstance();\n case 'RdYlGn':\n return ColorPalette$Diverging$RdYlGn_getInstance();\n case 'Spectral':\n return ColorPalette$Diverging$Spectral_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Diverging.' + name);\n }\n }\n ColorPalette$Diverging.valueOf_61zpoe$ = ColorPalette$Diverging$valueOf;\n function ColorPalette$Qualitative(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_av4sq6$_0 = myPresentation;\n this.colorSet_cgz7kp$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Qualitative_initFields() {\n ColorPalette$Qualitative_initFields = function () {\n };\n ColorPalette$Qualitative$Accent_instance = new ColorPalette$Qualitative('Accent', 0, 'accent', ColorSets_getInstance().ACCENT);\n ColorPalette$Qualitative$Dark2_instance = new ColorPalette$Qualitative('Dark2', 1, 'dark 2', ColorSets_getInstance().DARK_2);\n ColorPalette$Qualitative$Paired_instance = new ColorPalette$Qualitative('Paired', 2, 'paired', ColorSets_getInstance().PAIRED);\n ColorPalette$Qualitative$Pastel1_instance = new ColorPalette$Qualitative('Pastel1', 3, 'pastel 1', ColorSets_getInstance().PASTEL_1);\n ColorPalette$Qualitative$Pastel2_instance = new ColorPalette$Qualitative('Pastel2', 4, 'pastel 2', ColorSets_getInstance().PASTEL_2);\n ColorPalette$Qualitative$Set1_instance = new ColorPalette$Qualitative('Set1', 5, 'set 1', ColorSets_getInstance().SET_1);\n ColorPalette$Qualitative$Set2_instance = new ColorPalette$Qualitative('Set2', 6, 'set 2', ColorSets_getInstance().SET_2);\n ColorPalette$Qualitative$Set3_instance = new ColorPalette$Qualitative('Set3', 7, 'set 3', ColorSets_getInstance().SET_3);\n }\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_cgz7kp$_0;\n }\n });\n var ColorPalette$Qualitative$Accent_instance;\n function ColorPalette$Qualitative$Accent_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Accent_instance;\n }\n var ColorPalette$Qualitative$Dark2_instance;\n function ColorPalette$Qualitative$Dark2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Dark2_instance;\n }\n var ColorPalette$Qualitative$Paired_instance;\n function ColorPalette$Qualitative$Paired_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Paired_instance;\n }\n var ColorPalette$Qualitative$Pastel1_instance;\n function ColorPalette$Qualitative$Pastel1_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Pastel1_instance;\n }\n var ColorPalette$Qualitative$Pastel2_instance;\n function ColorPalette$Qualitative$Pastel2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Pastel2_instance;\n }\n var ColorPalette$Qualitative$Set1_instance;\n function ColorPalette$Qualitative$Set1_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set1_instance;\n }\n var ColorPalette$Qualitative$Set2_instance;\n function ColorPalette$Qualitative$Set2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set2_instance;\n }\n var ColorPalette$Qualitative$Set3_instance;\n function ColorPalette$Qualitative$Set3_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set3_instance;\n }\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$QUALITATIVE_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Qualitative.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Qualitative.prototype.toString = function () {\n return this.myPresentation_av4sq6$_0;\n };\n ColorPalette$Qualitative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Qualitative',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Qualitative$values() {\n return [ColorPalette$Qualitative$Accent_getInstance(), ColorPalette$Qualitative$Dark2_getInstance(), ColorPalette$Qualitative$Paired_getInstance(), ColorPalette$Qualitative$Pastel1_getInstance(), ColorPalette$Qualitative$Pastel2_getInstance(), ColorPalette$Qualitative$Set1_getInstance(), ColorPalette$Qualitative$Set2_getInstance(), ColorPalette$Qualitative$Set3_getInstance()];\n }\n ColorPalette$Qualitative.values = ColorPalette$Qualitative$values;\n function ColorPalette$Qualitative$valueOf(name) {\n switch (name) {\n case 'Accent':\n return ColorPalette$Qualitative$Accent_getInstance();\n case 'Dark2':\n return ColorPalette$Qualitative$Dark2_getInstance();\n case 'Paired':\n return ColorPalette$Qualitative$Paired_getInstance();\n case 'Pastel1':\n return ColorPalette$Qualitative$Pastel1_getInstance();\n case 'Pastel2':\n return ColorPalette$Qualitative$Pastel2_getInstance();\n case 'Set1':\n return ColorPalette$Qualitative$Set1_getInstance();\n case 'Set2':\n return ColorPalette$Qualitative$Set2_getInstance();\n case 'Set3':\n return ColorPalette$Qualitative$Set3_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.' + name);\n }\n }\n ColorPalette$Qualitative.valueOf_61zpoe$ = ColorPalette$Qualitative$valueOf;\n ColorPalette.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorPalette',\n interfaces: []\n };\n var ColorPalette_instance = null;\n function ColorPalette_getInstance() {\n if (ColorPalette_instance === null) {\n new ColorPalette();\n }return ColorPalette_instance;\n }\n function ColorScheme() {\n }\n ColorScheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ColorScheme',\n interfaces: []\n };\n function ColorSets() {\n ColorSets_instance = this;\n this.BU_GN_3 = ['#e5f5f9', '#99d8c9', '#2ca25f'];\n this.BU_GN_4 = ['#edf8fb', '#b2e2e2', '#66c2a4', '#238b45'];\n this.BU_GN_5 = ['#edf8fb', '#b2e2e2', '#66c2a4', '#2ca25f', '#006d2c'];\n this.BU_GN_6 = ['#edf8fb', '#ccece6', '#99d8c9', '#66c2a4', '#2ca25f', '#006d2c'];\n this.BU_GN_7 = ['#edf8fb', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#005824'];\n this.BU_GN_8 = ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#005824'];\n this.BU_GN_9 = ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'];\n this.BU_PU_3 = ['#e0ecf4', '#9ebcda', '#8856a7'];\n this.BU_PU_4 = ['#edf8fb', '#b3cde3', '#8c96c6', '#88419d'];\n this.BU_PU_5 = ['#edf8fb', '#b3cde3', '#8c96c6', '#8856a7', '#810f7c'];\n this.BU_PU_6 = ['#edf8fb', '#bfd3e6', '#9ebcda', '#8c96c6', '#8856a7', '#810f7c'];\n this.BU_PU_7 = ['#edf8fb', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#6e016b'];\n this.BU_PU_8 = ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#6e016b'];\n this.BU_PU_9 = ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'];\n this.GN_BU_3 = ['#e0f3db', '#a8ddb5', '#43a2ca'];\n this.GN_BU_4 = ['#f0f9e8', '#bae4bc', '#7bccc4', '#2b8cbe'];\n this.GN_BU_5 = ['#f0f9e8', '#bae4bc', '#7bccc4', '#43a2ca', '#0868ac'];\n this.GN_BU_6 = ['#f0f9e8', '#ccebc5', '#a8ddb5', '#7bccc4', '#43a2ca', '#0868ac'];\n this.GN_BU_7 = ['#f0f9e8', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#08589e'];\n this.GN_BU_8 = ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#08589e'];\n this.GN_BU_9 = ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'];\n this.OR_RD_3 = ['#fee8c8', '#fdbb84', '#e34a33'];\n this.OR_RD_4 = ['#fef0d9', '#fdcc8a', '#fc8d59', '#d7301f'];\n this.OR_RD_5 = ['#fef0d9', '#fdcc8a', '#fc8d59', '#e34a33', '#b30000'];\n this.OR_RD_6 = ['#fef0d9', '#fdd49e', '#fdbb84', '#fc8d59', '#e34a33', '#b30000'];\n this.OR_RD_7 = ['#fef0d9', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#990000'];\n this.OR_RD_8 = ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#990000'];\n this.OR_RD_9 = ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'];\n this.PU_BU_3 = ['#ece7f2', '#a6bddb', '#2b8cbe'];\n this.PU_BU_4 = ['#f1eef6', '#bdc9e1', '#74a9cf', '#0570b0'];\n this.PU_BU_5 = ['#f1eef6', '#bdc9e1', '#74a9cf', '#2b8cbe', '#045a8d'];\n this.PU_BU_6 = ['#f1eef6', '#d0d1e6', '#a6bddb', '#74a9cf', '#2b8cbe', '#045a8d'];\n this.PU_BU_7 = ['#f1eef6', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#034e7b'];\n this.PU_BU_8 = ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#034e7b'];\n this.PU_BU_9 = ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'];\n this.PU_BU_GN_3 = ['#ece2f0', '#a6bddb', '#1c9099'];\n this.PU_BU_GN_4 = ['#f6eff7', '#bdc9e1', '#67a9cf', '#02818a'];\n this.PU_BU_GN_5 = ['#f6eff7', '#bdc9e1', '#67a9cf', '#1c9099', '#016c59'];\n this.PU_BU_GN_6 = ['#f6eff7', '#d0d1e6', '#a6bddb', '#67a9cf', '#1c9099', '#016c59'];\n this.PU_BU_GN_7 = ['#f6eff7', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016450'];\n this.PU_BU_GN_8 = ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016450'];\n this.PU_BU_GN_9 = ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'];\n this.PU_RD_3 = ['#e7e1ef', '#c994c7', '#dd1c77'];\n this.PU_RD_4 = ['#f1eef6', '#d7b5d8', '#df65b0', '#ce1256'];\n this.PU_RD_5 = ['#f1eef6', '#d7b5d8', '#df65b0', '#dd1c77', '#980043'];\n this.PU_RD_6 = ['#f1eef6', '#d4b9da', '#c994c7', '#df65b0', '#dd1c77', '#980043'];\n this.PU_RD_7 = ['#f1eef6', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#91003f'];\n this.PU_RD_8 = ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#91003f'];\n this.PU_RD_9 = ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'];\n this.RD_PU_3 = ['#fde0dd', '#fa9fb5', '#c51b8a'];\n this.RD_PU_4 = ['#feebe2', '#fbb4b9', '#f768a1', '#ae017e'];\n this.RD_PU_5 = ['#feebe2', '#fbb4b9', '#f768a1', '#c51b8a', '#7a0177'];\n this.RD_PU_6 = ['#feebe2', '#fcc5c0', '#fa9fb5', '#f768a1', '#c51b8a', '#7a0177'];\n this.RD_PU_7 = ['#feebe2', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177'];\n this.RD_PU_8 = ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177'];\n this.RD_PU_9 = ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'];\n this.YL_GN_3 = ['#f7fcb9', '#addd8e', '#31a354'];\n this.YL_GN_4 = ['#ffffcc', '#c2e699', '#78c679', '#238443'];\n this.YL_GN_5 = ['#ffffcc', '#c2e699', '#78c679', '#31a354', '#006837'];\n this.YL_GN_6 = ['#ffffcc', '#d9f0a3', '#addd8e', '#78c679', '#31a354', '#006837'];\n this.YL_GN_7 = ['#ffffcc', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#005a32'];\n this.YL_GN_8 = ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#005a32'];\n this.YL_GN_9 = ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'];\n this.YL_GN_BU_3 = ['#edf8b1', '#7fcdbb', '#2c7fb8'];\n this.YL_GN_BU_4 = ['#ffffcc', '#a1dab4', '#41b6c4', '#225ea8'];\n this.YL_GN_BU_5 = ['#ffffcc', '#a1dab4', '#41b6c4', '#2c7fb8', '#253494'];\n this.YL_GN_BU_6 = ['#ffffcc', '#c7e9b4', '#7fcdbb', '#41b6c4', '#2c7fb8', '#253494'];\n this.YL_GN_BU_7 = ['#ffffcc', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#0c2c84'];\n this.YL_GN_BU_8 = ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#0c2c84'];\n this.YL_GN_BU_9 = ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'];\n this.YL_OR_BR_3 = ['#fff7bc', '#fec44f', '#d95f0e'];\n this.YL_OR_BR_4 = ['#ffffd4', '#fed98e', '#fe9929', '#cc4c02'];\n this.YL_OR_BR_5 = ['#ffffd4', '#fed98e', '#fe9929', '#d95f0e', '#993404'];\n this.YL_OR_BR_6 = ['#ffffd4', '#fee391', '#fec44f', '#fe9929', '#d95f0e', '#993404'];\n this.YL_OR_BR_7 = ['#ffffd4', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#8c2d04'];\n this.YL_OR_BR_8 = ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#8c2d04'];\n this.YL_OR_BR_9 = ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'];\n this.YL_OR_RD_3 = ['#ffeda0', '#feb24c', '#f03b20'];\n this.YL_OR_RD_4 = ['#ffffb2', '#fecc5c', '#fd8d3c', '#e31a1c'];\n this.YL_OR_RD_5 = ['#ffffb2', '#fecc5c', '#fd8d3c', '#f03b20', '#bd0026'];\n this.YL_OR_RD_6 = ['#ffffb2', '#fed976', '#feb24c', '#fd8d3c', '#f03b20', '#bd0026'];\n this.YL_OR_RD_7 = ['#ffffb2', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#b10026'];\n this.YL_OR_RD_8 = ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#b10026'];\n this.YL_OR_RD_9 = ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'];\n this.BU_GN = [this.BU_GN_3, this.BU_GN_4, this.BU_GN_5, this.BU_GN_6, this.BU_GN_7, this.BU_GN_8, this.BU_GN_9];\n this.BU_PU = [this.BU_PU_3, this.BU_PU_4, this.BU_PU_5, this.BU_PU_6, this.BU_PU_7, this.BU_PU_8, this.BU_PU_9];\n this.GN_BU = [this.GN_BU_3, this.GN_BU_4, this.GN_BU_5, this.GN_BU_6, this.GN_BU_7, this.GN_BU_8, this.GN_BU_9];\n this.OR_RD = [this.OR_RD_3, this.OR_RD_4, this.OR_RD_5, this.OR_RD_6, this.OR_RD_7, this.OR_RD_8, this.OR_RD_9];\n this.PU_BU = [this.PU_BU_3, this.PU_BU_4, this.PU_BU_5, this.PU_BU_6, this.PU_BU_7, this.PU_BU_8, this.PU_BU_9];\n this.PU_BU_GN = [this.PU_BU_GN_3, this.PU_BU_GN_4, this.PU_BU_GN_5, this.PU_BU_GN_6, this.PU_BU_GN_7, this.PU_BU_GN_8, this.PU_BU_GN_9];\n this.PU_RD = [this.PU_RD_3, this.PU_RD_4, this.PU_RD_5, this.PU_RD_6, this.PU_RD_7, this.PU_RD_8, this.PU_RD_9];\n this.RD_PU = [this.RD_PU_3, this.RD_PU_4, this.RD_PU_5, this.RD_PU_6, this.RD_PU_7, this.RD_PU_8, this.RD_PU_9];\n this.YL_GN = [this.YL_GN_3, this.YL_GN_4, this.YL_GN_5, this.YL_GN_6, this.YL_GN_7, this.YL_GN_8, this.YL_GN_9];\n this.YL_GN_BU = [this.YL_GN_BU_3, this.YL_GN_BU_4, this.YL_GN_BU_5, this.YL_GN_BU_6, this.YL_GN_BU_7, this.YL_GN_BU_8, this.YL_GN_BU_9];\n this.YL_OR_BR = [this.YL_OR_BR_3, this.YL_OR_BR_4, this.YL_OR_BR_5, this.YL_OR_BR_6, this.YL_OR_BR_7, this.YL_OR_BR_8, this.YL_OR_BR_9];\n this.YL_OR_RD = [this.YL_OR_RD_3, this.YL_OR_RD_4, this.YL_OR_RD_5, this.YL_OR_RD_6, this.YL_OR_RD_7, this.YL_OR_RD_8, this.YL_OR_RD_9];\n this.BLUES_3 = ['#deebf7', '#9ecae1', '#3182bd'];\n this.BLUES_4 = ['#eff3ff', '#bdd7e7', '#6baed6', '#2171b5'];\n this.BLUES_5 = ['#eff3ff', '#bdd7e7', '#6baed6', '#3182bd', '#08519c'];\n this.BLUES_6 = ['#eff3ff', '#c6dbef', '#9ecae1', '#6baed6', '#3182bd', '#08519c'];\n this.BLUES_7 = ['#eff3ff', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#084594'];\n this.BLUES_8 = ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#084594'];\n this.BLUES_9 = ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'];\n this.GREENS_3 = ['#e5f5e0', '#a1d99b', '#31a354'];\n this.GREENS_4 = ['#edf8e9', '#bae4b3', '#74c476', '#238b45'];\n this.GREENS_5 = ['#edf8e9', '#bae4b3', '#74c476', '#31a354', '#006d2c'];\n this.GREENS_6 = ['#edf8e9', '#c7e9c0', '#a1d99b', '#74c476', '#31a354', '#006d2c'];\n this.GREENS_7 = ['#edf8e9', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#005a32'];\n this.GREENS_8 = ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#005a32'];\n this.GREENS_9 = ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'];\n this.GREYS_3 = ['#f0f0f0', '#bdbdbd', '#636363'];\n this.GREYS_4 = ['#f7f7f7', '#cccccc', '#969696', '#525252'];\n this.GREYS_5 = ['#f7f7f7', '#cccccc', '#969696', '#636363', '#252525'];\n this.GREYS_6 = ['#f7f7f7', '#d9d9d9', '#bdbdbd', '#969696', '#636363', '#252525'];\n this.GREYS_7 = ['#f7f7f7', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525'];\n this.GREYS_8 = ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525'];\n this.GREYS_9 = ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'];\n this.ORANGES_3 = ['#fee6ce', '#fdae6b', '#e6550d'];\n this.ORANGES_4 = ['#feedde', '#fdbe85', '#fd8d3c', '#d94701'];\n this.ORANGES_5 = ['#feedde', '#fdbe85', '#fd8d3c', '#e6550d', '#a63603'];\n this.ORANGES_6 = ['#feedde', '#fdd0a2', '#fdae6b', '#fd8d3c', '#e6550d', '#a63603'];\n this.ORANGES_7 = ['#feedde', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#8c2d04'];\n this.ORANGES_8 = ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#8c2d04'];\n this.ORANGES_9 = ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'];\n this.PURPLES_3 = ['#efedf5', '#bcbddc', '#756bb1'];\n this.PURPLES_4 = ['#f2f0f7', '#cbc9e2', '#9e9ac8', '#6a51a3'];\n this.PURPLES_5 = ['#f2f0f7', '#cbc9e2', '#9e9ac8', '#756bb1', '#54278f'];\n this.PURPLES_6 = ['#f2f0f7', '#dadaeb', '#bcbddc', '#9e9ac8', '#756bb1', '#54278f'];\n this.PURPLES_7 = ['#f2f0f7', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#4a1486'];\n this.PURPLES_8 = ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#4a1486'];\n this.PURPLES_9 = ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'];\n this.REDS_3 = ['#fee0d2', '#fc9272', '#de2d26'];\n this.REDS_4 = ['#fee5d9', '#fcae91', '#fb6a4a', '#cb181d'];\n this.REDS_5 = ['#fee5d9', '#fcae91', '#fb6a4a', '#de2d26', '#a50f15'];\n this.REDS_6 = ['#fee5d9', '#fcbba1', '#fc9272', '#fb6a4a', '#de2d26', '#a50f15'];\n this.REDS_7 = ['#fee5d9', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#99000d'];\n this.REDS_8 = ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#99000d'];\n this.REDS_9 = ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'];\n this.BLUES = [this.BLUES_3, this.BLUES_4, this.BLUES_5, this.BLUES_6, this.BLUES_7, this.BLUES_8, this.BLUES_9];\n this.GREENS = [this.GREENS_3, this.GREENS_4, this.GREENS_5, this.GREENS_6, this.GREENS_7, this.GREENS_8, this.GREENS_9];\n this.GREYS = [this.GREYS_3, this.GREYS_4, this.GREYS_5, this.GREYS_6, this.GREYS_7, this.GREYS_8, this.GREYS_9];\n this.ORANGES = [this.ORANGES_3, this.ORANGES_4, this.ORANGES_5, this.ORANGES_6, this.ORANGES_7, this.ORANGES_8, this.ORANGES_9];\n this.PURPLES = [this.PURPLES_3, this.PURPLES_4, this.PURPLES_5, this.PURPLES_6, this.PURPLES_7, this.PURPLES_8, this.PURPLES_9];\n this.REDS = [this.REDS_3, this.REDS_4, this.REDS_5, this.REDS_6, this.REDS_7, this.REDS_8, this.REDS_9];\n this.BR_BG_3 = ['#d8b365', '#f5f5f5', '#5ab4ac'];\n this.BR_BG_4 = ['#a6611a', '#dfc27d', '#80cdc1', '#018571'];\n this.BR_BG_5 = ['#a6611a', '#dfc27d', '#f5f5f5', '#80cdc1', '#018571'];\n this.BR_BG_6 = ['#8c510a', '#d8b365', '#f6e8c3', '#c7eae5', '#5ab4ac', '#01665e'];\n this.BR_BG_7 = ['#8c510a', '#d8b365', '#f6e8c3', '#f5f5f5', '#c7eae5', '#5ab4ac', '#01665e'];\n this.BR_BG_8 = ['#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#c7eae5', '#80cdc1', '#35978f', '#01665e'];\n this.BR_BG_9 = ['#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e'];\n this.BR_BG_10 = ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'];\n this.BR_BG_11 = ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'];\n this.PI_YG_3 = ['#e9a3c9', '#f7f7f7', '#a1d76a'];\n this.PI_YG_4 = ['#d01c8b', '#f1b6da', '#b8e186', '#4dac26'];\n this.PI_YG_5 = ['#d01c8b', '#f1b6da', '#f7f7f7', '#b8e186', '#4dac26'];\n this.PI_YG_6 = ['#c51b7d', '#e9a3c9', '#fde0ef', '#e6f5d0', '#a1d76a', '#4d9221'];\n this.PI_YG_7 = ['#c51b7d', '#e9a3c9', '#fde0ef', '#f7f7f7', '#e6f5d0', '#a1d76a', '#4d9221'];\n this.PI_YG_8 = ['#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221'];\n this.PI_YG_9 = ['#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221'];\n this.PI_YG_10 = ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'];\n this.PI_YG_11 = ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'];\n this.PR_GN_3 = ['#af8dc3', '#f7f7f7', '#7fbf7b'];\n this.PR_GN_4 = ['#7b3294', '#c2a5cf', '#a6dba0', '#008837'];\n this.PR_GN_5 = ['#7b3294', '#c2a5cf', '#f7f7f7', '#a6dba0', '#008837'];\n this.PR_GN_6 = ['#762a83', '#af8dc3', '#e7d4e8', '#d9f0d3', '#7fbf7b', '#1b7837'];\n this.PR_GN_7 = ['#762a83', '#af8dc3', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#7fbf7b', '#1b7837'];\n this.PR_GN_8 = ['#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837'];\n this.PR_GN_9 = ['#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837'];\n this.PR_GN_10 = ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'];\n this.PR_GN_11 = ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'];\n this.PU_OR_3 = ['#f1a340', '#f7f7f7', '#998ec3'];\n this.PU_OR_4 = ['#e66101', '#fdb863', '#b2abd2', '#5e3c99'];\n this.PU_OR_5 = ['#e66101', '#fdb863', '#f7f7f7', '#b2abd2', '#5e3c99'];\n this.PU_OR_6 = ['#b35806', '#f1a340', '#fee0b6', '#d8daeb', '#998ec3', '#542788'];\n this.PU_OR_7 = ['#b35806', '#f1a340', '#fee0b6', '#f7f7f7', '#d8daeb', '#998ec3', '#542788'];\n this.PU_OR_8 = ['#b35806', '#e08214', '#fdb863', '#fee0b6', '#d8daeb', '#b2abd2', '#8073ac', '#542788'];\n this.PU_OR_9 = ['#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788'];\n this.PU_OR_10 = ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'];\n this.PU_OR_11 = ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'];\n this.RD_BU_3 = ['#ef8a62', '#f7f7f7', '#67a9cf'];\n this.RD_BU_4 = ['#ca0020', '#f4a582', '#92c5de', '#0571b0'];\n this.RD_BU_5 = ['#ca0020', '#f4a582', '#f7f7f7', '#92c5de', '#0571b0'];\n this.RD_BU_6 = ['#b2182b', '#ef8a62', '#fddbc7', '#d1e5f0', '#67a9cf', '#2166ac'];\n this.RD_BU_7 = ['#b2182b', '#ef8a62', '#fddbc7', '#f7f7f7', '#d1e5f0', '#67a9cf', '#2166ac'];\n this.RD_BU_8 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac'];\n this.RD_BU_9 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac'];\n this.RD_BU_10 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'];\n this.RD_BU_11 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'];\n this.RD_GY_3 = ['#ef8a62', '#ffffff', '#999999'];\n this.RD_GY_4 = ['#ca0020', '#f4a582', '#bababa', '#404040'];\n this.RD_GY_5 = ['#ca0020', '#f4a582', '#ffffff', '#bababa', '#404040'];\n this.RD_GY_6 = ['#b2182b', '#ef8a62', '#fddbc7', '#e0e0e0', '#999999', '#4d4d4d'];\n this.RD_GY_7 = ['#b2182b', '#ef8a62', '#fddbc7', '#ffffff', '#e0e0e0', '#999999', '#4d4d4d'];\n this.RD_GY_8 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#e0e0e0', '#bababa', '#878787', '#4d4d4d'];\n this.RD_GY_9 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d'];\n this.RD_GY_10 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'];\n this.RD_GY_11 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'];\n this.RD_YL_BU_3 = ['#fc8d59', '#ffffbf', '#91bfdb'];\n this.RD_YL_BU_4 = ['#d7191c', '#fdae61', '#abd9e9', '#2c7bb6'];\n this.RD_YL_BU_5 = ['#d7191c', '#fdae61', '#ffffbf', '#abd9e9', '#2c7bb6'];\n this.RD_YL_BU_6 = ['#d73027', '#fc8d59', '#fee090', '#e0f3f8', '#91bfdb', '#4575b4'];\n this.RD_YL_BU_7 = ['#d73027', '#fc8d59', '#fee090', '#ffffbf', '#e0f3f8', '#91bfdb', '#4575b4'];\n this.RD_YL_BU_8 = ['#d73027', '#f46d43', '#fdae61', '#fee090', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4'];\n this.RD_YL_BU_9 = ['#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4'];\n this.RD_YL_BU_10 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'];\n this.RD_YL_BU_11 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'];\n this.RD_YL_GN_3 = ['#fc8d59', '#ffffbf', '#91cf60'];\n this.RD_YL_GN_4 = ['#d7191c', '#fdae61', '#a6d96a', '#1a9641'];\n this.RD_YL_GN_5 = ['#d7191c', '#fdae61', '#ffffbf', '#a6d96a', '#1a9641'];\n this.RD_YL_GN_6 = ['#d73027', '#fc8d59', '#fee08b', '#d9ef8b', '#91cf60', '#1a9850'];\n this.RD_YL_GN_7 = ['#d73027', '#fc8d59', '#fee08b', '#ffffbf', '#d9ef8b', '#91cf60', '#1a9850'];\n this.RD_YL_GN_8 = ['#d73027', '#f46d43', '#fdae61', '#fee08b', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850'];\n this.RD_YL_GN_9 = ['#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850'];\n this.RD_YL_GN_10 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'];\n this.RD_YL_GN_11 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'];\n this.SPECTRAL_3 = ['#fc8d59', '#ffffbf', '#99d594'];\n this.SPECTRAL_4 = ['#d7191c', '#fdae61', '#abdda4', '#2b83ba'];\n this.SPECTRAL_5 = ['#d7191c', '#fdae61', '#ffffbf', '#abdda4', '#2b83ba'];\n this.SPECTRAL_6 = ['#d53e4f', '#fc8d59', '#fee08b', '#e6f598', '#99d594', '#3288bd'];\n this.SPECTRAL_7 = ['#d53e4f', '#fc8d59', '#fee08b', '#ffffbf', '#e6f598', '#99d594', '#3288bd'];\n this.SPECTRAL_8 = ['#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#e6f598', '#abdda4', '#66c2a5', '#3288bd'];\n this.SPECTRAL_9 = ['#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd'];\n this.SPECTRAL_10 = ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'];\n this.SPECTRAL_11 = ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'];\n this.BR_BG = [this.BR_BG_3, this.BR_BG_4, this.BR_BG_5, this.BR_BG_6, this.BR_BG_7, this.BR_BG_8, this.BR_BG_9, this.BR_BG_10, this.BR_BG_11];\n this.PI_YG = [this.PI_YG_3, this.PI_YG_4, this.PI_YG_5, this.PI_YG_6, this.PI_YG_7, this.PI_YG_8, this.PI_YG_9, this.PI_YG_10, this.PI_YG_11];\n this.PR_GN = [this.PR_GN_3, this.PR_GN_4, this.PR_GN_5, this.PR_GN_6, this.PR_GN_7, this.PR_GN_8, this.PR_GN_9, this.PR_GN_10, this.PR_GN_11];\n this.PU_OR = [this.PU_OR_3, this.PU_OR_4, this.PU_OR_5, this.PU_OR_6, this.PU_OR_7, this.PU_OR_8, this.PU_OR_9, this.PU_OR_10, this.PU_OR_11];\n this.RD_BU = [this.RD_BU_3, this.RD_BU_4, this.RD_BU_5, this.RD_BU_6, this.RD_BU_7, this.RD_BU_8, this.RD_BU_9, this.RD_BU_10, this.RD_BU_11];\n this.RD_GY = [this.RD_GY_3, this.RD_GY_4, this.RD_GY_5, this.RD_GY_6, this.RD_GY_7, this.RD_GY_8, this.RD_GY_9, this.RD_GY_10, this.RD_GY_11];\n this.RD_YL_BU = [this.RD_YL_BU_3, this.RD_YL_BU_4, this.RD_YL_BU_5, this.RD_YL_BU_6, this.RD_YL_BU_7, this.RD_YL_BU_8, this.RD_YL_BU_9, this.RD_YL_BU_10, this.RD_YL_BU_11];\n this.RD_YL_GN = [this.RD_YL_GN_3, this.RD_YL_GN_4, this.RD_YL_GN_5, this.RD_YL_GN_6, this.RD_YL_GN_7, this.RD_YL_GN_8, this.RD_YL_GN_9, this.RD_YL_GN_10, this.RD_YL_GN_11];\n this.SPECTRAL = [this.SPECTRAL_3, this.SPECTRAL_4, this.SPECTRAL_5, this.SPECTRAL_6, this.SPECTRAL_7, this.SPECTRAL_8, this.SPECTRAL_9, this.SPECTRAL_10, this.SPECTRAL_11];\n this.ACCENT_3 = ['#7fc97f', '#beaed4', '#fdc086'];\n this.ACCENT_4 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99'];\n this.ACCENT_5 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0'];\n this.ACCENT_6 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f'];\n this.ACCENT_7 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17'];\n this.ACCENT_8 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'];\n this.DARK_2_3 = ['#1b9e77', '#d95f02', '#7570b3'];\n this.DARK_2_4 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a'];\n this.DARK_2_5 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e'];\n this.DARK_2_6 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02'];\n this.DARK_2_7 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d'];\n this.DARK_2_8 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'];\n this.PAIRED_3 = ['#a6cee3', '#1f78b4', '#b2df8a'];\n this.PAIRED_4 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c'];\n this.PAIRED_5 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99'];\n this.PAIRED_6 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c'];\n this.PAIRED_7 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f'];\n this.PAIRED_8 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00'];\n this.PAIRED_9 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6'];\n this.PAIRED_10 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a'];\n this.PAIRED_11 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99'];\n this.PAIRED_12 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'];\n this.PASTEL_1_3 = ['#fbb4ae', '#b3cde3', '#ccebc5'];\n this.PASTEL_1_4 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4'];\n this.PASTEL_1_5 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6'];\n this.PASTEL_1_6 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc'];\n this.PASTEL_1_7 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd'];\n this.PASTEL_1_8 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec'];\n this.PASTEL_1_9 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'];\n this.PASTEL_2_3 = ['#b3e2cd', '#fdcdac', '#cbd5e8'];\n this.PASTEL_2_4 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4'];\n this.PASTEL_2_5 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9'];\n this.PASTEL_2_6 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae'];\n this.PASTEL_2_7 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc'];\n this.PASTEL_2_8 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'];\n this.SET_1_3 = ['#e41a1c', '#377eb8', '#4daf4a'];\n this.SET_1_4 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3'];\n this.SET_1_5 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00'];\n this.SET_1_6 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33'];\n this.SET_1_7 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628'];\n this.SET_1_8 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf'];\n this.SET_1_9 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'];\n this.SET_2_3 = ['#66c2a5', '#fc8d62', '#8da0cb'];\n this.SET_2_4 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3'];\n this.SET_2_5 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854'];\n this.SET_2_6 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f'];\n this.SET_2_7 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494'];\n this.SET_2_8 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'];\n this.SET_3_3 = ['#8dd3c7', '#ffffb3', '#bebada'];\n this.SET_3_4 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072'];\n this.SET_3_5 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3'];\n this.SET_3_6 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462'];\n this.SET_3_7 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69'];\n this.SET_3_8 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5'];\n this.SET_3_9 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9'];\n this.SET_3_10 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd'];\n this.SET_3_11 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5'];\n this.SET_3_12 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'];\n this.ACCENT = [this.ACCENT_3, this.ACCENT_4, this.ACCENT_5, this.ACCENT_6, this.ACCENT_7, this.ACCENT_8];\n this.DARK_2 = [this.DARK_2_3, this.DARK_2_4, this.DARK_2_5, this.DARK_2_6, this.DARK_2_7, this.DARK_2_8];\n this.PAIRED = [this.PAIRED_3, this.PAIRED_4, this.PAIRED_5, this.PAIRED_6, this.PAIRED_7, this.PAIRED_8, this.PAIRED_9, this.PAIRED_10, this.PAIRED_11, this.PAIRED_12];\n this.PASTEL_1 = [this.PASTEL_1_3, this.PASTEL_1_4, this.PASTEL_1_5, this.PASTEL_1_6, this.PASTEL_1_7, this.PASTEL_1_8, this.PASTEL_1_9];\n this.PASTEL_2 = [this.PASTEL_2_3, this.PASTEL_2_4, this.PASTEL_2_5, this.PASTEL_2_6, this.PASTEL_2_7, this.PASTEL_2_8];\n this.SET_1 = [this.SET_1_3, this.SET_1_4, this.SET_1_5, this.SET_1_6, this.SET_1_7, this.SET_1_8, this.SET_1_9];\n this.SET_2 = [this.SET_2_3, this.SET_2_4, this.SET_2_5, this.SET_2_6, this.SET_2_7, this.SET_2_8];\n this.SET_3 = [this.SET_3_3, this.SET_3_4, this.SET_3_5, this.SET_3_6, this.SET_3_7, this.SET_3_8, this.SET_3_9, this.SET_3_10, this.SET_3_11, this.SET_3_12];\n }\n ColorSets.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorSets',\n interfaces: []\n };\n var ColorSets_instance = null;\n function ColorSets_getInstance() {\n if (ColorSets_instance === null) {\n new ColorSets();\n }return ColorSets_instance;\n }\n function ColorUtil() {\n ColorUtil_instance = this;\n }\n ColorUtil.prototype.genColors_2c6x13$ = function (count, baseColors) {\n var tmp$;\n var rValues = ArrayList_init();\n var gValues = ArrayList_init();\n var bValues = ArrayList_init();\n tmp$ = baseColors.iterator();\n while (tmp$.hasNext()) {\n var baseColor = tmp$.next();\n rValues.add_11rb$(baseColor.red);\n gValues.add_11rb$(baseColor.green);\n bValues.add_11rb$(baseColor.blue);\n }\n var rChannelGen = new RGBChannelGen(rValues);\n var gChannelGen = new RGBChannelGen(gValues);\n var bChannelGen = new RGBChannelGen(bValues);\n var rValuesGen = rChannelGen.generate_za3lpa$(count).iterator();\n var gValuesGen = gChannelGen.generate_za3lpa$(count).iterator();\n var bValuesGen = bChannelGen.generate_za3lpa$(count).iterator();\n var colorsGen = ArrayList_init_0(count);\n while (rValuesGen.hasNext() && gValuesGen.hasNext() && bValuesGen.hasNext()) {\n var colorGen = new Color(rValuesGen.next(), gValuesGen.next(), bValuesGen.next());\n colorsGen.add_11rb$(colorGen);\n }\n return colorsGen;\n };\n ColorUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorUtil',\n interfaces: []\n };\n var ColorUtil_instance = null;\n function ColorUtil_getInstance() {\n if (ColorUtil_instance === null) {\n new ColorUtil();\n }return ColorUtil_instance;\n }\n function PaletteUtil() {\n PaletteUtil_instance = this;\n this.NULL_COLOR = Color.Companion.LIGHT_GRAY;\n this.EXTENSIBLE_COLOR_SCHEMES_0 = setOf([ColorPalette$Qualitative$Accent_getInstance(), ColorPalette$Qualitative$Dark2_getInstance(), ColorPalette$Qualitative$Pastel1_getInstance(), ColorPalette$Qualitative$Pastel2_getInstance(), ColorPalette$Qualitative$Set1_getInstance(), ColorPalette$Qualitative$Set2_getInstance(), ColorPalette$Qualitative$Set3_getInstance()]);\n this.PAL_TYPE_BY_PAL_NAME_0 = null;\n var map = HashMap_init();\n var $receiver = ColorPalette$Sequential$values();\n var destination = ArrayList_init_0($receiver.length);\n var tmp$;\n for (tmp$ = 0; tmp$ !== $receiver.length; ++tmp$) {\n var item = $receiver[tmp$];\n destination.add_11rb$(item.name);\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var value = ColorPalette$Type$SEQUENTIAL_getInstance();\n map.put_xwzc9p$(element, value);\n }\n var $receiver_0 = ColorPalette$Diverging$values();\n var destination_0 = ArrayList_init_0($receiver_0.length);\n var tmp$_1;\n for (tmp$_1 = 0; tmp$_1 !== $receiver_0.length; ++tmp$_1) {\n var item_0 = $receiver_0[tmp$_1];\n destination_0.add_11rb$(item_0.name);\n }\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var element_0 = tmp$_2.next();\n var value_0 = ColorPalette$Type$DIVERGING_getInstance();\n map.put_xwzc9p$(element_0, value_0);\n }\n var $receiver_1 = ColorPalette$Qualitative$values();\n var destination_1 = ArrayList_init_0($receiver_1.length);\n var tmp$_3;\n for (tmp$_3 = 0; tmp$_3 !== $receiver_1.length; ++tmp$_3) {\n var item_1 = $receiver_1[tmp$_3];\n destination_1.add_11rb$(item_1.name);\n }\n var tmp$_4;\n tmp$_4 = destination_1.iterator();\n while (tmp$_4.hasNext()) {\n var element_1 = tmp$_4.next();\n var value_1 = ColorPalette$Type$QUALITATIVE_getInstance();\n map.put_xwzc9p$(element_1, value_1);\n }\n this.PAL_TYPE_BY_PAL_NAME_0 = map;\n }\n PaletteUtil.prototype.isExtensibleScheme_0 = function (colorScheme) {\n return this.EXTENSIBLE_COLOR_SCHEMES_0.contains_11rb$(colorScheme);\n };\n PaletteUtil.prototype.schemeColors_7q5c77$ = function (colorScheme, colorCount) {\n var colorsHex = colorScheme.getColors_za3lpa$(colorCount);\n var colors = this.fromColorsHex_0(colorsHex);\n if (colorsHex.length < colorCount && this.isExtensibleScheme_0(colorScheme)) {\n var addColors = ColorUtil_getInstance().genColors_2c6x13$(colorCount - colorsHex.length | 0, colors);\n return collect.Iterables.toList_yl67zr$(collect.Iterables.concat_yxozss$(colors, addColors));\n }return colors;\n };\n PaletteUtil.prototype.fromColorsHex_0 = function (hexColors) {\n var tmp$;\n var colors = ArrayList_init();\n for (tmp$ = 0; tmp$ !== hexColors.length; ++tmp$) {\n var hexColor = hexColors[tmp$];\n try {\n colors.add_11rb$(Color.Companion.parseHex_61zpoe$(hexColor));\n } catch (e) {\n if (!Kotlin.isType(e, Exception))\n throw e;\n }\n }\n return colors;\n };\n PaletteUtil.prototype.paletteTypeByPaletteName_61zpoe$ = function (paletteName) {\n return this.PAL_TYPE_BY_PAL_NAME_0.get_11rb$(paletteName);\n };\n PaletteUtil.prototype.colorSchemeByIndex_vfydh1$ = function (paletteType, index) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n switch (paletteType.name) {\n case 'SEQUENTIAL':\n tmp$_2 = Kotlin.isArray(tmp$ = ColorPalette$Sequential$values()) ? tmp$ : throwCCE();\n break;\n case 'DIVERGING':\n tmp$_2 = Kotlin.isArray(tmp$_0 = ColorPalette$Diverging$values()) ? tmp$_0 : throwCCE();\n break;\n case 'QUALITATIVE':\n tmp$_2 = Kotlin.isArray(tmp$_1 = ColorPalette$Qualitative$values()) ? tmp$_1 : throwCCE();\n break;\n default:tmp$_2 = Kotlin.noWhenBranchMatched();\n break;\n }\n var values = tmp$_2;\n return values[index % values.length];\n };\n PaletteUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PaletteUtil',\n interfaces: []\n };\n var PaletteUtil_instance = null;\n function PaletteUtil_getInstance() {\n if (PaletteUtil_instance === null) {\n new PaletteUtil();\n }return PaletteUtil_instance;\n }\n function RGBChannelGen(myBaseValues) {\n RGBChannelGen$Companion_getInstance();\n this.myBaseValues_0 = myBaseValues;\n this.myRange_0 = null;\n var tmp$, tmp$_0;\n var min = Ordering.Companion.natural_dahdeg$().min_m5x2f4$(this.myBaseValues_0);\n var max = Ordering.Companion.natural_dahdeg$().max_m5x2f4$(this.myBaseValues_0);\n tmp$ = RGBChannelGen$Companion_getInstance().RANGES_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var r = tmp$[tmp$_0];\n if (r.contains_mef7kx$(min) || r.contains_mef7kx$(max)) {\n if (this.myRange_0 == null) {\n this.myRange_0 = r;\n } else {\n this.myRange_0 = ensureNotNull(this.myRange_0).span_d226ot$(r);\n }\n }}\n }\n RGBChannelGen.prototype.generate_za3lpa$ = function (maxCount) {\n var tmp$;\n var x = maxCount / this.myBaseValues_0.size;\n var genPerBaseValue = numberToInt(JsMath.ceil(x));\n var a = this.maxValueCount_0() - 1 | 0;\n var b = genPerBaseValue;\n genPerBaseValue = JsMath.min(a, b);\n var x_0 = this.maxValueCount_0() / (genPerBaseValue + 1 | 0);\n var inc = numberToInt(JsMath.floor(x_0));\n var b_0 = numberToInt(inc * 1.33);\n inc = JsMath.max(1, b_0);\n var values = ArrayList_init_0(maxCount);\n var baseValues = this.myBaseValues_0;\n while (values.size < maxCount) {\n var nextBaseValues = ArrayList_init();\n tmp$ = baseValues.iterator();\n while (tmp$.hasNext()) {\n var baseValue = tmp$.next();\n var genValue = baseValue + inc | 0;\n if (!ensureNotNull(this.myRange_0).contains_mef7kx$(genValue)) {\n genValue = ensureNotNull(this.myRange_0).lowerEnd + (genValue - ensureNotNull(this.myRange_0).upperEnd) | 0;\n }values.add_11rb$(genValue);\n nextBaseValues.add_11rb$(genValue);\n if (values.size === maxCount) {\n break;\n }}\n baseValues = nextBaseValues;\n }\n return values;\n };\n RGBChannelGen.prototype.maxValueCount_0 = function () {\n return ensureNotNull(this.myRange_0).upperEnd - ensureNotNull(this.myRange_0).lowerEnd + 1 | 0;\n };\n function RGBChannelGen$Companion() {\n RGBChannelGen$Companion_instance = this;\n this.RANGES_0 = [new ClosedRange(0, 37), new ClosedRange(38, 97), new ClosedRange(98, 157), new ClosedRange(158, 217), new ClosedRange(218, 255)];\n }\n RGBChannelGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RGBChannelGen$Companion_instance = null;\n function RGBChannelGen$Companion_getInstance() {\n if (RGBChannelGen$Companion_instance === null) {\n new RGBChannelGen$Companion();\n }return RGBChannelGen$Companion_instance;\n }\n RGBChannelGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RGBChannelGen',\n interfaces: []\n };\n function DataType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DataType_initFields() {\n DataType_initFields = function () {\n };\n DataType$NUMBER_instance = new DataType('NUMBER', 0);\n DataType$STRING_instance = new DataType('STRING', 1);\n DataType$INSTANT_instance = new DataType('INSTANT', 2);\n DataType$INSTANT_OF_DAY_instance = new DataType('INSTANT_OF_DAY', 3);\n DataType$INSTANT_OF_MONTH_instance = new DataType('INSTANT_OF_MONTH', 4);\n DataType$INSTANT_OF_QUARTER_instance = new DataType('INSTANT_OF_QUARTER', 5);\n DataType$INSTANT_OF_HALF_YEAR_instance = new DataType('INSTANT_OF_HALF_YEAR', 6);\n DataType$INSTANT_OF_YEAR_instance = new DataType('INSTANT_OF_YEAR', 7);\n }\n var DataType$NUMBER_instance;\n function DataType$NUMBER_getInstance() {\n DataType_initFields();\n return DataType$NUMBER_instance;\n }\n var DataType$STRING_instance;\n function DataType$STRING_getInstance() {\n DataType_initFields();\n return DataType$STRING_instance;\n }\n var DataType$INSTANT_instance;\n function DataType$INSTANT_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_instance;\n }\n var DataType$INSTANT_OF_DAY_instance;\n function DataType$INSTANT_OF_DAY_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_DAY_instance;\n }\n var DataType$INSTANT_OF_MONTH_instance;\n function DataType$INSTANT_OF_MONTH_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_MONTH_instance;\n }\n var DataType$INSTANT_OF_QUARTER_instance;\n function DataType$INSTANT_OF_QUARTER_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_QUARTER_instance;\n }\n var DataType$INSTANT_OF_HALF_YEAR_instance;\n function DataType$INSTANT_OF_HALF_YEAR_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_HALF_YEAR_instance;\n }\n var DataType$INSTANT_OF_YEAR_instance;\n function DataType$INSTANT_OF_YEAR_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_YEAR_instance;\n }\n Object.defineProperty(DataType.prototype, 'isTime', {\n configurable: true,\n get: function () {\n return this === DataType$INSTANT_getInstance() || this.isTimeInterval;\n }\n });\n Object.defineProperty(DataType.prototype, 'isTimeInterval', {\n configurable: true,\n get: function () {\n return this === DataType$INSTANT_OF_DAY_getInstance() || this === DataType$INSTANT_OF_MONTH_getInstance() || this === DataType$INSTANT_OF_QUARTER_getInstance() || this === DataType$INSTANT_OF_HALF_YEAR_getInstance() || this === DataType$INSTANT_OF_YEAR_getInstance();\n }\n });\n Object.defineProperty(DataType.prototype, 'isString', {\n configurable: true,\n get: function () {\n return this === DataType$STRING_getInstance();\n }\n });\n Object.defineProperty(DataType.prototype, 'isNumber', {\n configurable: true,\n get: function () {\n return this === DataType$NUMBER_getInstance();\n }\n });\n DataType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataType',\n interfaces: [Enum]\n };\n function DataType$values() {\n return [DataType$NUMBER_getInstance(), DataType$STRING_getInstance(), DataType$INSTANT_getInstance(), DataType$INSTANT_OF_DAY_getInstance(), DataType$INSTANT_OF_MONTH_getInstance(), DataType$INSTANT_OF_QUARTER_getInstance(), DataType$INSTANT_OF_HALF_YEAR_getInstance(), DataType$INSTANT_OF_YEAR_getInstance()];\n }\n DataType.values = DataType$values;\n function DataType$valueOf(name) {\n switch (name) {\n case 'NUMBER':\n return DataType$NUMBER_getInstance();\n case 'STRING':\n return DataType$STRING_getInstance();\n case 'INSTANT':\n return DataType$INSTANT_getInstance();\n case 'INSTANT_OF_DAY':\n return DataType$INSTANT_OF_DAY_getInstance();\n case 'INSTANT_OF_MONTH':\n return DataType$INSTANT_OF_MONTH_getInstance();\n case 'INSTANT_OF_QUARTER':\n return DataType$INSTANT_OF_QUARTER_getInstance();\n case 'INSTANT_OF_HALF_YEAR':\n return DataType$INSTANT_OF_HALF_YEAR_getInstance();\n case 'INSTANT_OF_YEAR':\n return DataType$INSTANT_OF_YEAR_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.data.DataType.' + name);\n }\n }\n DataType.valueOf_61zpoe$ = DataType$valueOf;\n function RegularMeshDetector(myError) {\n RegularMeshDetector$Companion_getInstance();\n this.myError_xmg86j$_0 = myError;\n this.isMesh_gozhck$_0 = false;\n this.resolution_byvhl$_0 = 0;\n }\n Object.defineProperty(RegularMeshDetector.prototype, 'isMesh', {\n configurable: true,\n get: function () {\n return this.isMesh_gozhck$_0;\n },\n set: function (isMesh) {\n this.isMesh_gozhck$_0 = isMesh;\n }\n });\n Object.defineProperty(RegularMeshDetector.prototype, 'resolution', {\n configurable: true,\n get: function () {\n if (!this.isMesh) {\n var message = 'Not a mesh';\n throw IllegalStateException_init(message.toString());\n }return this.resolution_byvhl$_0;\n },\n set: function (resolution) {\n this.resolution_byvhl$_0 = resolution;\n }\n });\n RegularMeshDetector.prototype.equalsEnough_lu1900$ = function (d1, d2) {\n var tmp$ = d1 === d2;\n if (!tmp$) {\n var x = d1 - d2;\n tmp$ = JsMath.abs(x) <= this.myError_xmg86j$_0;\n }return tmp$;\n };\n RegularMeshDetector.prototype.nearZero_14dthe$ = function (d) {\n return JsMath.abs(d) <= this.myError_xmg86j$_0;\n };\n function RegularMeshDetector$MyRowDetector(myMinRowSize, error, values) {\n RegularMeshDetector.call(this, error);\n this.myMinRowSize_0 = myMinRowSize;\n this.init_0(values);\n }\n RegularMeshDetector$MyRowDetector.prototype.init_0 = function (values) {\n var tmp$;\n this.isMesh = false;\n var distance = 0.0;\n var distanceInitialized = false;\n var prevValue = null;\n var count = this.myMinRowSize_0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (!SeriesUtil_getInstance().isFinite_yrwdxb$(value)) {\n return;\n }if (prevValue != null) {\n var dist = ensureNotNull(value) - prevValue;\n if (this.nearZero_14dthe$(dist)) {\n return;\n }if (distanceInitialized) {\n if (!this.equalsEnough_lu1900$(dist, distance)) {\n return;\n }} else {\n distance = dist;\n distanceInitialized = true;\n }\n }prevValue = value;\n if ((count = count - 1 | 0, count) === 0) {\n break;\n }}\n if (distanceInitialized && count === 0) {\n var x = distance;\n this.resolution = JsMath.abs(x);\n this.isMesh = true;\n }};\n RegularMeshDetector$MyRowDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyRowDetector',\n interfaces: [RegularMeshDetector]\n };\n function RegularMeshDetector$MyColumnDetector(myMinRowSize, error, values) {\n RegularMeshDetector.call(this, error);\n this.myMinRowSize_0 = myMinRowSize;\n this.init_0(values);\n }\n RegularMeshDetector$MyColumnDetector.prototype.init_0 = function (values) {\n var tmp$;\n this.isMesh = false;\n var rowSize = new Int32Array([0, 0]);\n var rowValue = [null, null];\n var rowIndex = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (!SeriesUtil_getInstance().isFinite_yrwdxb$(value)) {\n break;\n }if (rowValue[rowIndex] == null) {\n rowValue[rowIndex] = value;\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else if (this.equalsEnough_lu1900$(ensureNotNull(rowValue[rowIndex]), ensureNotNull(value))) {\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else {\n if (rowIndex === 0) {\n rowIndex = rowIndex + 1 | 0;\n rowValue[rowIndex] = value;\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else {\n break;\n }\n }\n }\n if (rowSize[0] === rowSize[1] && rowSize[0] >= this.myMinRowSize_0) {\n this.isMesh = true;\n var x = ensureNotNull(rowValue[1]) - ensureNotNull(rowValue[0]);\n this.resolution = JsMath.abs(x);\n }};\n RegularMeshDetector$MyColumnDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyColumnDetector',\n interfaces: [RegularMeshDetector]\n };\n function RegularMeshDetector$Companion() {\n RegularMeshDetector$Companion_instance = this;\n this.NO_MESH_0 = new RegularMeshDetector$Companion$NO_MESH$ObjectLiteral(0.0);\n }\n RegularMeshDetector$Companion.prototype.tryRow_l63ks6$ = function (values) {\n var v0 = collect.Iterables.get_dhabsj$(values, 0, null);\n var v1 = collect.Iterables.get_dhabsj$(values, 1, null);\n if (v0 == null || v1 == null) {\n return this.NO_MESH_0;\n }var x = v1 - v0;\n var delta = JsMath.abs(x);\n if (!isFinite(delta)) {\n return this.NO_MESH_0;\n }var error = delta / 10000.0;\n return this.tryRow_4sxsdq$(50, error, values);\n };\n RegularMeshDetector$Companion.prototype.tryRow_4sxsdq$ = function (minRowSize, error, values) {\n return new RegularMeshDetector$MyRowDetector(minRowSize, error, values);\n };\n RegularMeshDetector$Companion.prototype.tryColumn_l63ks6$ = function (values) {\n return this.tryColumn_4sxsdq$(50, SeriesUtil_getInstance().TINY, values);\n };\n RegularMeshDetector$Companion.prototype.tryColumn_4sxsdq$ = function (minRowSize, error, values) {\n return new RegularMeshDetector$MyColumnDetector(minRowSize, error, values);\n };\n function RegularMeshDetector$Companion$NO_MESH$ObjectLiteral(myError) {\n RegularMeshDetector.call(this, myError);\n }\n Object.defineProperty(RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype, 'isMesh', {\n configurable: true,\n get: function () {\n return false;\n },\n set: function (value) {\n Kotlin.callSetter(this, RegularMeshDetector.prototype, 'isMesh', value);\n }\n });\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [RegularMeshDetector]\n };\n RegularMeshDetector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RegularMeshDetector$Companion_instance = null;\n function RegularMeshDetector$Companion_getInstance() {\n if (RegularMeshDetector$Companion_instance === null) {\n new RegularMeshDetector$Companion();\n }return RegularMeshDetector$Companion_instance;\n }\n RegularMeshDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RegularMeshDetector',\n interfaces: []\n };\n function SeriesUtil() {\n SeriesUtil_instance = this;\n this.TINY = 1.0E-50;\n this.REAL_NUMBER_0 = SeriesUtil$REAL_NUMBER$lambda(this);\n this.NEGATIVE_NUMBER = SeriesUtil$NEGATIVE_NUMBER$lambda;\n }\n SeriesUtil.prototype.isSubTiny_14dthe$ = function (value) {\n return value < this.TINY;\n };\n SeriesUtil.prototype.isSubTiny_4fzjta$ = function (range) {\n return this.isFinite_4fzjta$(range) && this.span_4fzjta$(range) < this.TINY;\n };\n SeriesUtil.prototype.checkedDoubles_fakr2g$ = function (values) {\n return new SeriesUtil$CheckedDoubleIterable(values);\n };\n SeriesUtil.prototype.checkedDoubles_9ma18$ = function (values) {\n return new SeriesUtil$CheckedDoubleList(values);\n };\n SeriesUtil.prototype.isFinite_yrwdxb$ = function (v) {\n return v != null && isFinite(v);\n };\n SeriesUtil.prototype.asFinite_z03gcz$ = function (v, defaultValue) {\n return v != null && isFinite(v) ? v : defaultValue;\n };\n SeriesUtil.prototype.isFinite_14dthe$ = function (v) {\n return isFinite(v);\n };\n SeriesUtil.prototype.allFinite_jma9l8$ = function (v0, v1) {\n return this.isFinite_yrwdxb$(v0) && this.isFinite_yrwdxb$(v1);\n };\n SeriesUtil.prototype.allFinite_xjrefz$ = function (v0, v1, v2) {\n return this.allFinite_jma9l8$(v0, v1) && this.isFinite_yrwdxb$(v2);\n };\n SeriesUtil.prototype.allFinite_rd1tgs$ = function (v0, v1, v2, v3) {\n return this.allFinite_xjrefz$(v0, v1, v2) && this.isFinite_yrwdxb$(v3);\n };\n SeriesUtil.prototype.filterFinite_10sy24$ = function (l0, l1) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!(l0.size === l1.size)) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }var l0Copy = ArrayList_init();\n var l1Copy = ArrayList_init();\n var copy = false;\n var i = 0;\n for (var tmp$_3 = l0.iterator(); tmp$_3.hasNext(); ++i) {\n var v0 = tmp$_3.next();\n var tmp$_4, tmp$_5, tmp$_6, tmp$_7;\n var v1 = l1.get_za3lpa$(i);\n if (!this.allFinite_jma9l8$(v0, v1)) {\n if (!copy) {\n l0Copy.addAll_brywnq$(Kotlin.isType(tmp$_4 = toList(take(l0, i)), List) ? tmp$_4 : throwCCE());\n l1Copy.addAll_brywnq$(Kotlin.isType(tmp$_5 = toList(take(l1, i)), List) ? tmp$_5 : throwCCE());\n copy = true;\n }continue;\n }if (copy) {\n l0Copy.add_11rb$(typeof (tmp$_6 = v0) === 'number' ? tmp$_6 : throwCCE());\n l1Copy.add_11rb$(typeof (tmp$_7 = v1) === 'number' ? tmp$_7 : throwCCE());\n }}\n tmp$ = copy;\n if (tmp$ === true)\n tmp$_2 = listOf([l0Copy, l1Copy]);\n else if (tmp$ === false) {\n tmp$_2 = listOf([Kotlin.isType(tmp$_0 = l0, List) ? tmp$_0 : throwCCE(), Kotlin.isType(tmp$_1 = l1, List) ? tmp$_1 : throwCCE()]);\n } else\n tmp$_2 = Kotlin.noWhenBranchMatched();\n return tmp$_2;\n };\n SeriesUtil.prototype.range_l63ks6$ = function (values) {\n var tmp$;\n var min = 0.0;\n var max = 0.0;\n var inited = false;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (this.isFinite_yrwdxb$(v)) {\n if (inited) {\n var a = min;\n var b = ensureNotNull(v);\n min = JsMath.min(a, b);\n var a_0 = max;\n max = JsMath.max(a_0, v);\n } else {\n max = ensureNotNull(v);\n min = max;\n inited = true;\n }\n }}\n return inited ? new ClosedRange(min, max) : null;\n };\n SeriesUtil.prototype.resolution_u62iiw$ = function (values, naValue) {\n var tmp$;\n var rowDetector = RegularMeshDetector$Companion_getInstance().tryRow_l63ks6$(values);\n if (rowDetector.isMesh) {\n return rowDetector.resolution;\n }var columnDetector = RegularMeshDetector$Companion_getInstance().tryColumn_l63ks6$(values);\n if (columnDetector.isMesh) {\n tmp$ = columnDetector.resolution;\n } else {\n tmp$ = this.resolutionFullScan_0(values, naValue);\n }\n return tmp$;\n };\n SeriesUtil.prototype.resolutionFullScan_0 = function (values, naValue) {\n var tmp$;\n var goodDataVector = Kotlin.isType(tmp$ = collect.Iterables.filter_fpit1u$(values, this.REAL_NUMBER_0), Iterable) ? tmp$ : throwCCE();\n if (collect.Iterables.isEmpty_fakr2g$(goodDataVector)) {\n return naValue;\n }var copy = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(goodDataVector);\n if (copy.size < 2) {\n return naValue;\n }var it = copy.iterator();\n var resolution = naValue;\n var allZero = true;\n var prev = it.next();\n while (it.hasNext()) {\n var curr = it.next();\n var dist = curr - prev;\n if (dist > 0 && (dist < resolution || allZero)) {\n allZero = false;\n resolution = dist;\n }prev = curr;\n }\n return resolution;\n };\n SeriesUtil.prototype.ensureApplicableRange_4am1sd$ = function (range) {\n if (range == null) {\n return new ClosedRange(-0.5, 0.5);\n }if (this.isSubTiny_4fzjta$(range)) {\n var median = range.lowerEnd;\n return new ClosedRange(median - 0.5, median + 0.5);\n }return range;\n };\n SeriesUtil.prototype.span_4fzjta$ = function (range) {\n if (!this.isFinite_4fzjta$(range)) {\n var message = 'range must be finite: ' + range;\n throw IllegalArgumentException_init(message.toString());\n }return range.upperEnd - range.lowerEnd;\n };\n SeriesUtil.prototype.span_t7esj2$ = function (range0, range1) {\n if (range0 == null)\n return range1;\n return range1 == null ? range0 : range0.span_d226ot$(range1);\n };\n SeriesUtil.prototype.expand_mdyssk$ = function (range, newSpan) {\n var expand = (newSpan - this.span_4fzjta$(range)) / 2;\n return this.expand_wws5xy$(range, expand, expand);\n };\n SeriesUtil.prototype.expand_wws5xy$ = function (range, lowerExpand, upperExpand) {\n return new ClosedRange(range.lowerEnd - lowerExpand, range.upperEnd + upperExpand);\n };\n SeriesUtil.prototype.isFinite_4fzjta$ = function (range) {\n return !(isInfinite(range.lowerEnd) || isInfinite(range.upperEnd));\n };\n SeriesUtil.prototype.matchingIndices_3vukww$ = function (list, matchedValue) {\n var result = ArrayList_init();\n for (var i = 0; i !== list.size; ++i) {\n if (equals(matchedValue, list.get_za3lpa$(i))) {\n result.add_11rb$(i);\n }}\n return result;\n };\n SeriesUtil.prototype.matchingIndices_ut89is$ = function (list, matchedValues) {\n var result = ArrayList_init();\n for (var i = 0; i !== list.size; ++i) {\n if (contains(matchedValues, list.get_za3lpa$(i))) {\n result.add_11rb$(i);\n }}\n return result;\n };\n SeriesUtil.prototype.pickAtIndices_ge51dg$ = function (list, indices) {\n var tmp$;\n var initialCapacity = indices.size > 10 ? indices.size : 10;\n var result = ArrayList_init_0(initialCapacity);\n tmp$ = indices.iterator();\n while (tmp$.hasNext()) {\n var index = tmp$.next();\n if (index < list.size) {\n result.add_11rb$(list.get_za3lpa$(index));\n }}\n return result;\n };\n SeriesUtil.prototype.pickAtIndices_jlfzfq$ = function (list, indices) {\n var result = ArrayList_init_0(list.size);\n for (var i = 0; i !== list.size; ++i) {\n if (indices.contains_11rb$(i)) {\n result.add_11rb$(list.get_za3lpa$(i));\n }}\n return result;\n };\n SeriesUtil.prototype.skipAtIndices_jlfzfq$ = function (list, indices) {\n var result = ArrayList_init_0(list.size);\n for (var i = 0; i !== list.size; ++i) {\n if (!indices.contains_11rb$(i)) {\n result.add_11rb$(list.get_za3lpa$(i));\n }}\n return result;\n };\n SeriesUtil.prototype.firstNotNull_rath1t$ = function (list, defaultValue) {\n var tmp$;\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (v != null) {\n return v;\n }}\n return defaultValue;\n };\n SeriesUtil.prototype.mean_l4tjj7$ = function (values, defaultValue) {\n var tmp$;\n var result = 0.0;\n var i = -1.0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (value != null && isFinite(value)) {\n i = i + 1;\n result = value / (i + 1) + result * (i / (i + 1));\n }}\n return i >= 0 ? result : defaultValue;\n };\n SeriesUtil.prototype.sum_k9kaly$ = function (values) {\n var tmp$;\n var result = 0.0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (value != null && isFinite(value)) {\n result += value;\n }}\n return result;\n };\n SeriesUtil.prototype.toDoubleList_8a6n3n$ = function (l) {\n return l == null ? null : (new SeriesUtil$CheckedDoubleList(l)).cast();\n };\n function SeriesUtil$CheckedDoubleList(list) {\n SeriesUtil$CheckedDoubleIterable.call(this, list);\n }\n SeriesUtil$CheckedDoubleList.prototype.cast = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = SeriesUtil$CheckedDoubleIterable.prototype.cast.call(this), List) ? tmp$ : throwCCE();\n };\n SeriesUtil$CheckedDoubleList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CheckedDoubleList',\n interfaces: [SeriesUtil$CheckedDoubleIterable]\n };\n function SeriesUtil$CheckedDoubleIterable(myIterable) {\n this.myIterable_n2c9gl$_0 = myIterable;\n this.myEmpty_3k4vh6$_0 = collect.Iterables.isEmpty_fakr2g$(this.myIterable_n2c9gl$_0);\n this.myCanBeCast_310oqz$_0 = false;\n var tmp$;\n if (this.myEmpty_3k4vh6$_0) {\n tmp$ = true;\n } else {\n tmp$ = collect.Iterables.all_fpit1u$(collect.Iterables.filter_fpit1u$(this.myIterable_n2c9gl$_0, SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda), SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda_0);\n }\n this.myCanBeCast_310oqz$_0 = tmp$;\n }\n SeriesUtil$CheckedDoubleIterable.prototype.notEmptyAndCanBeCast = function () {\n return !this.myEmpty_3k4vh6$_0 && this.myCanBeCast_310oqz$_0;\n };\n SeriesUtil$CheckedDoubleIterable.prototype.canBeCast = function () {\n return this.myCanBeCast_310oqz$_0;\n };\n SeriesUtil$CheckedDoubleIterable.prototype.cast = function () {\n var tmp$;\n if (!this.myCanBeCast_310oqz$_0) {\n var message = \"Can't cast to a collection of Double(s)\";\n throw IllegalStateException_init(message.toString());\n }return Kotlin.isType(tmp$ = this.myIterable_n2c9gl$_0, Iterable) ? tmp$ : throwCCE();\n };\n function SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda(it) {\n return it != null;\n }\n function SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda_0(input) {\n return typeof input === 'number';\n }\n SeriesUtil$CheckedDoubleIterable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CheckedDoubleIterable',\n interfaces: []\n };\n function SeriesUtil$REAL_NUMBER$lambda(this$SeriesUtil) {\n return function (it) {\n return this$SeriesUtil.isFinite_yrwdxb$(it);\n };\n }\n function SeriesUtil$NEGATIVE_NUMBER$lambda(input) {\n return input < 0;\n }\n SeriesUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SeriesUtil',\n interfaces: []\n };\n var SeriesUtil_instance = null;\n function SeriesUtil_getInstance() {\n if (SeriesUtil_instance === null) {\n new SeriesUtil();\n }return SeriesUtil_instance;\n }\n function DouglasPeuckerSimplification() {\n this.myEpsilon_0 = kotlin_js_internal_DoubleCompanionObject.MIN_VALUE;\n }\n function DouglasPeuckerSimplification$calculateWeights$lambda(closure$points, closure$startIndex) {\n return function (p) {\n return (new DoubleSegment(closure$points.get_za3lpa$(closure$startIndex), p)).length();\n };\n }\n function DouglasPeuckerSimplification$calculateWeights$lambda_0(closure$doubleSegment) {\n return function (it) {\n return closure$doubleSegment.distance_gpjtzr$(it);\n };\n }\n DouglasPeuckerSimplification.prototype.calculateWeights_0 = function (points) {\n var stack = new Stack();\n var size = points.size;\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n }\n var weights = list;\n weights.set_wxm5ur$(0, kotlin_js_internal_DoubleCompanionObject.MAX_VALUE);\n weights.set_wxm5ur$(points.size - 1 | 0, kotlin_js_internal_DoubleCompanionObject.MAX_VALUE);\n stack.push_11rb$(new Pair(0, points.size - 1 | 0));\n while (!stack.empty()) {\n var startIndex = ensureNotNull(stack.peek()).first;\n var endIndex = ensureNotNull(stack.peek()).second;\n stack.pop();\n var dMax = 0.0;\n var index_0 = startIndex;\n var doubleSegment = new DoubleSegment(points.get_za3lpa$(startIndex), points.get_za3lpa$(endIndex));\n var distance;\n if (doubleSegment.length() === 0.0) {\n distance = DouglasPeuckerSimplification$calculateWeights$lambda(points, startIndex);\n } else {\n distance = DouglasPeuckerSimplification$calculateWeights$lambda_0(doubleSegment);\n }\n var i = startIndex + 1 | 0;\n while (i < endIndex) {\n var d = distance(points.get_za3lpa$(i));\n if (d > dMax) {\n index_0 = i;\n dMax = d;\n }i = i + 1 | 0;\n }\n if (dMax >= this.myEpsilon_0) {\n stack.push_11rb$(new Pair(startIndex, index_0));\n stack.push_11rb$(new Pair(index_0, endIndex));\n weights.set_wxm5ur$(index_0, dMax);\n }}\n return weights;\n };\n DouglasPeuckerSimplification.prototype.getWeights_ytws2g$ = function (points) {\n return this.calculateWeights_0(points);\n };\n DouglasPeuckerSimplification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DouglasPeuckerSimplification',\n interfaces: [PolylineSimplifier$RankingStrategy]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function PolylineSimplifier(myPoints, strategy) {\n PolylineSimplifier$Companion_getInstance();\n this.myPoints_0 = myPoints;\n this.myWeights_0 = null;\n this.myWeightLimit_0 = kotlin_js_internal_DoubleCompanionObject.NaN;\n this.myCountLimit_0 = -1;\n this.myWeights_0 = strategy.getWeights_ytws2g$(this.myPoints_0);\n }\n Object.defineProperty(PolylineSimplifier.prototype, 'points', {\n configurable: true,\n get: function () {\n var $receiver = this.indices;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.myPoints_0.get_za3lpa$(item));\n }\n return destination;\n }\n });\n function PolylineSimplifier$get_PolylineSimplifier$indices$lambda(this$PolylineSimplifier) {\n return function (it) {\n return this$PolylineSimplifier.getWeight_0(it);\n };\n }\n Object.defineProperty(PolylineSimplifier.prototype, 'indices', {\n configurable: true,\n get: function () {\n var $receiver = until(0, this.myPoints_0.size);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new Pair(item, this.myWeights_0.get_za3lpa$(item)));\n }\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (!isNaN_0(this.getWeight_0(element)))\n destination_0.add_11rb$(element);\n }\n var sorted_0 = sortedWith(destination_0, reversed(new Comparator(compareBy$lambda(PolylineSimplifier$get_PolylineSimplifier$indices$lambda(this)))));\n var filtered;\n if (this.isWeightLimitSet_0) {\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = sorted_0.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (this.getWeight_0(element_0) > this.myWeightLimit_0)\n destination_1.add_11rb$(element_0);\n }\n filtered = destination_1;\n } else {\n filtered = take(sorted_0, this.myCountLimit_0);\n }\n var $receiver_0 = filtered;\n var destination_2 = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_2;\n tmp$_2 = $receiver_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_2.add_11rb$(this.getIndex_0(item_0));\n }\n return sorted(destination_2);\n }\n });\n Object.defineProperty(PolylineSimplifier.prototype, 'isWeightLimitSet_0', {\n configurable: true,\n get: function () {\n return !isNaN_0(this.myWeightLimit_0);\n }\n });\n PolylineSimplifier.prototype.setWeightLimit_14dthe$ = function (weightLimit) {\n this.myWeightLimit_0 = weightLimit;\n this.myCountLimit_0 = -1;\n return this;\n };\n PolylineSimplifier.prototype.setCountLimit_za3lpa$ = function (countLimit) {\n this.myWeightLimit_0 = kotlin_js_internal_DoubleCompanionObject.NaN;\n this.myCountLimit_0 = countLimit;\n return this;\n };\n PolylineSimplifier.prototype.getWeight_0 = function (p) {\n return p.second;\n };\n PolylineSimplifier.prototype.getIndex_0 = function (p) {\n return p.first;\n };\n function PolylineSimplifier$RankingStrategy() {\n }\n PolylineSimplifier$RankingStrategy.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'RankingStrategy',\n interfaces: []\n };\n function PolylineSimplifier$Companion() {\n PolylineSimplifier$Companion_instance = this;\n }\n PolylineSimplifier$Companion.prototype.visvalingamWhyatt_ytws2g$ = function (points) {\n return new PolylineSimplifier(points, new VisvalingamWhyattSimplification());\n };\n PolylineSimplifier$Companion.prototype.douglasPeucker_ytws2g$ = function (points) {\n return new PolylineSimplifier(points, new DouglasPeuckerSimplification());\n };\n PolylineSimplifier$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolylineSimplifier$Companion_instance = null;\n function PolylineSimplifier$Companion_getInstance() {\n if (PolylineSimplifier$Companion_instance === null) {\n new PolylineSimplifier$Companion();\n }return PolylineSimplifier$Companion_instance;\n }\n PolylineSimplifier.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolylineSimplifier',\n interfaces: []\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function VisvalingamWhyattSimplification() {\n VisvalingamWhyattSimplification$Companion_getInstance();\n this.myVerticesToRemove_0 = ArrayList_init();\n this.myTriangles_0 = null;\n }\n Object.defineProperty(VisvalingamWhyattSimplification.prototype, 'isSimplificationDone_0', {\n configurable: true,\n get: function () {\n return this.isEmpty_0;\n }\n });\n Object.defineProperty(VisvalingamWhyattSimplification.prototype, 'isEmpty_0', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myTriangles_0).isEmpty();\n }\n });\n VisvalingamWhyattSimplification.prototype.getWeights_ytws2g$ = function (points) {\n this.myTriangles_0 = ArrayList_init_0(points.size - 2 | 0);\n this.initTriangles_0(points);\n var size = points.size;\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(VisvalingamWhyattSimplification$Companion_getInstance().INITIAL_AREA_0);\n }\n var weights = list;\n var lastRemovedVertexArea = 0.0;\n while (!this.isSimplificationDone_0) {\n var triangle = this.takeTriangle_0();\n lastRemovedVertexArea = triangle.area > lastRemovedVertexArea ? triangle.area : lastRemovedVertexArea;\n weights.set_wxm5ur$(triangle.currentVertex, lastRemovedVertexArea);\n var next = triangle.next;\n if (next != null) {\n next.takePrevFrom_em8fn6$(triangle);\n this.update_0(next);\n }var prev = triangle.prev;\n if (prev != null) {\n prev.takeNextFrom_em8fn6$(triangle);\n this.update_0(prev);\n }this.myVerticesToRemove_0.add_11rb$(triangle.currentVertex);\n }\n return weights;\n };\n VisvalingamWhyattSimplification.prototype.initTriangles_0 = function (points) {\n var triangles = ArrayList_init_0(points.size - 2 | 0);\n var i = 1;\n var n = points.size - 1 | 0;\n while (i < n) {\n triangles.add_11rb$(new VisvalingamWhyattSimplification$Triangle(i, points));\n i = i + 1 | 0;\n }\n var i_0 = 1;\n var n_0 = triangles.size - 1 | 0;\n while (i_0 < n_0) {\n triangles.get_za3lpa$(i_0).next = triangles.get_za3lpa$(i_0 + 1 | 0);\n triangles.get_za3lpa$(i_0).prev = triangles.get_za3lpa$(i_0 - 1 | 0);\n i_0 = i_0 + 1 | 0;\n }\n var tmp$;\n tmp$ = triangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.add_0(element);\n }\n };\n VisvalingamWhyattSimplification.prototype.takeTriangle_0 = function () {\n var minimalTriangle = this.poll_0();\n this.myVerticesToRemove_0.add_11rb$(minimalTriangle.currentVertex);\n return minimalTriangle;\n };\n VisvalingamWhyattSimplification.prototype.add_0 = function (triangle) {\n var index = this.getIndex_0(triangle);\n ensureNotNull(this.myTriangles_0).add_wxm5ur$(index, triangle);\n };\n function VisvalingamWhyattSimplification$getIndex$lambda(it) {\n return it.area;\n }\n VisvalingamWhyattSimplification.prototype.getIndex_0 = function (triangle) {\n var index = binarySearch(ensureNotNull(this.myTriangles_0), triangle, new Comparator(compareBy$lambda_0(VisvalingamWhyattSimplification$getIndex$lambda)));\n if (index < 0) {\n index = ~index;\n }return index;\n };\n VisvalingamWhyattSimplification.prototype.peek_0 = function () {\n return ensureNotNull(this.myTriangles_0).get_za3lpa$(0);\n };\n VisvalingamWhyattSimplification.prototype.poll_0 = function () {\n var triangle = this.peek_0();\n ensureNotNull(this.myTriangles_0).remove_11rb$(triangle);\n return triangle;\n };\n VisvalingamWhyattSimplification.prototype.update_0 = function (triangle) {\n ensureNotNull(this.myTriangles_0).remove_11rb$(triangle);\n ensureNotNull(this.myTriangles_0).add_11rb$(triangle);\n };\n function VisvalingamWhyattSimplification$Triangle(currentVertex, myPoints) {\n this.currentVertex = currentVertex;\n this.myPoints_0 = myPoints;\n this.area_nqp3v0$_0 = 0;\n this.prevVertex_0 = 0;\n this.nextVertex_0 = 0;\n this.prev = null;\n this.next = null;\n this.prevVertex_0 = this.currentVertex - 1 | 0;\n this.nextVertex_0 = this.currentVertex + 1 | 0;\n this.area = this.calculateArea_0();\n }\n Object.defineProperty(VisvalingamWhyattSimplification$Triangle.prototype, 'area', {\n configurable: true,\n get: function () {\n return this.area_nqp3v0$_0;\n },\n set: function (area) {\n this.area_nqp3v0$_0 = area;\n }\n });\n VisvalingamWhyattSimplification$Triangle.prototype.takeNextFrom_em8fn6$ = function (triangle) {\n this.next = triangle.next;\n this.nextVertex_0 = triangle.nextVertex_0;\n this.area = this.calculateArea_0();\n };\n VisvalingamWhyattSimplification$Triangle.prototype.takePrevFrom_em8fn6$ = function (triangle) {\n this.prev = triangle.prev;\n this.prevVertex_0 = triangle.prevVertex_0;\n this.area = this.calculateArea_0();\n };\n VisvalingamWhyattSimplification$Triangle.prototype.calculateArea_0 = function () {\n var a = this.myPoints_0.get_za3lpa$(this.prevVertex_0);\n var b = this.myPoints_0.get_za3lpa$(this.currentVertex);\n var c = this.myPoints_0.get_za3lpa$(this.nextVertex_0);\n var x = ((b.x - a.x) * (c.y - a.y) - (c.x - a.x) * (b.y - a.y)) / 2.0;\n return JsMath.abs(x);\n };\n VisvalingamWhyattSimplification$Triangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Triangle',\n interfaces: []\n };\n function VisvalingamWhyattSimplification$Companion() {\n VisvalingamWhyattSimplification$Companion_instance = this;\n this.INITIAL_AREA_0 = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n }\n VisvalingamWhyattSimplification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VisvalingamWhyattSimplification$Companion_instance = null;\n function VisvalingamWhyattSimplification$Companion_getInstance() {\n if (VisvalingamWhyattSimplification$Companion_instance === null) {\n new VisvalingamWhyattSimplification$Companion();\n }return VisvalingamWhyattSimplification$Companion_instance;\n }\n VisvalingamWhyattSimplification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VisvalingamWhyattSimplification',\n interfaces: [PolylineSimplifier$RankingStrategy]\n };\n function DateTimeFormatUtil() {\n DateTimeFormatUtil_instance = this;\n }\n DateTimeFormatUtil.prototype.formatDateUTC_xfy9o8$ = function (instant, pattern) {\n var format = Format_init(pattern);\n var $receiver = new Instant(numberToLong(instant));\n var $receiver_0 = getCallableRef('toDateTime', function ($receiver, p1) {\n return $receiver.toDateTime_x2y23v$(p1);\n }.bind(null, TimeZone.Companion.UTC))($receiver);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_amwj4p$(p1);\n }.bind(null, format))($receiver_0);\n };\n DateTimeFormatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateTimeFormatUtil',\n interfaces: []\n };\n var DateTimeFormatUtil_instance = null;\n function DateTimeFormatUtil_getInstance() {\n if (DateTimeFormatUtil_instance === null) {\n new DateTimeFormatUtil();\n }return DateTimeFormatUtil_instance;\n }\n function Formatter() {\n Formatter_instance = this;\n this.YEAR_0 = '%b %Y';\n this.YEAR_QUARTER_0 = 'Q %y';\n this.YEAR_MONTH_0 = '%B %Y';\n this.DATE_MEDIUM_0 = '%a, %b %e, %Y';\n this.DATE_MEDIUM_TIME_SHORT_0 = '%a, %b %e, %Y %l:%M %p';\n this.DEF_NUMBER_FORMAT_0 = NumberFormat_init(',g');\n this.DEF_NUMBER_FORMATTER_0 = Formatter$DEF_NUMBER_FORMATTER$lambda(this);\n }\n function Formatter$time$lambda(closure$pattern) {\n return function (input) {\n var tmp$;\n return DateTimeFormatUtil_getInstance().formatDateUTC_xfy9o8$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE(), closure$pattern);\n };\n }\n Formatter.prototype.time_61zpoe$ = function (pattern) {\n return Formatter$time$lambda(pattern);\n };\n Formatter.prototype.tooltip_w817vg$ = function (dataType) {\n return this.nullable_0(this.tooltipImpl_0(dataType), 'null');\n };\n function Formatter$tooltipImpl$lambda(it) {\n return it.toString();\n }\n Formatter.prototype.tooltipImpl_0 = function (dataType) {\n var tmp$;\n switch (dataType.name) {\n case 'NUMBER':\n tmp$ = this.DEF_NUMBER_FORMATTER_0;\n break;\n case 'STRING':\n tmp$ = Formatter$tooltipImpl$lambda;\n break;\n case 'INSTANT':\n tmp$ = this.time_61zpoe$(this.DATE_MEDIUM_TIME_SHORT_0);\n break;\n case 'INSTANT_OF_DAY':\n tmp$ = this.time_61zpoe$(this.DATE_MEDIUM_0);\n break;\n case 'INSTANT_OF_MONTH':\n tmp$ = this.time_61zpoe$(this.YEAR_MONTH_0);\n break;\n case 'INSTANT_OF_QUARTER':\n case 'INSTANT_OF_HALF_YEAR':\n tmp$ = this.time_61zpoe$(this.YEAR_QUARTER_0);\n break;\n case 'INSTANT_OF_YEAR':\n tmp$ = this.time_61zpoe$(this.YEAR_0);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n Formatter.prototype.tableCell_w817vg$ = function (dataType) {\n return this.tableCell_0(dataType, 'null');\n };\n Formatter.prototype.tableCell_0 = function (dataType, nullString) {\n return this.nullable_0(this.tableCellImpl_0(dataType), nullString);\n };\n function Formatter$tableCellImpl$lambda(it) {\n return it.toString();\n }\n Formatter.prototype.tableCellImpl_0 = function (dataType) {\n switch (dataType.name) {\n case 'NUMBER':\n return this.DEF_NUMBER_FORMATTER_0;\n case 'STRING':\n return Formatter$tableCellImpl$lambda;\n case 'INSTANT':\n return this.time_61zpoe$(\"%a, %b %e, '%y\");\n default:if (dataType.isTimeInterval) {\n var timeInterval = TimeInterval$Companion_getInstance().fromIntervalDataType_w817vg$(dataType);\n return timeInterval.tickFormatter;\n }\n break;\n }\n throw IllegalArgumentException_init(\"Can't create formatter for data type \" + dataType);\n };\n function Formatter$nullable$lambda(closure$nullString, closure$f) {\n return function (input) {\n return input == null ? closure$nullString : closure$f(input);\n };\n }\n Formatter.prototype.nullable_0 = function (f, nullString) {\n return Formatter$nullable$lambda(nullString, f);\n };\n function Formatter$DEF_NUMBER_FORMATTER$lambda(this$Formatter) {\n return function (input) {\n var tmp$;\n return this$Formatter.DEF_NUMBER_FORMAT_0.apply_3p81yu$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE());\n };\n }\n Formatter.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Formatter',\n interfaces: []\n };\n var Formatter_instance = null;\n function Formatter_getInstance() {\n if (Formatter_instance === null) {\n new Formatter();\n }return Formatter_instance;\n }\n function TimeUtil() {\n TimeUtil_instance = this;\n }\n TimeUtil.prototype.asDateTimeUTC_14dthe$ = function (instant) {\n try {\n return TimeZone.Companion.UTC.toDateTime_x2y23v$(new Instant(roundToLong(instant)));\n } catch (ignored) {\n if (Kotlin.isType(ignored, RuntimeException)) {\n throw IllegalArgumentException_init(\"Can't create DateTime from instant \" + instant);\n } else\n throw ignored;\n }\n };\n TimeUtil.prototype.asInstantUTC_amwj4p$ = function (dateTime) {\n return TimeZone.Companion.UTC.toInstant_amwj4p$(dateTime).timeSinceEpoch;\n };\n TimeUtil.prototype.yearStart_za3lpa$ = function (year) {\n return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year));\n };\n TimeUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TimeUtil',\n interfaces: []\n };\n var TimeUtil_instance = null;\n function TimeUtil_getInstance() {\n if (TimeUtil_instance === null) {\n new TimeUtil();\n }return TimeUtil_instance;\n }\n function DurationInterval(myDuration, count) {\n TimeInterval.call(this, count);\n this.myDuration_0 = myDuration;\n if (!this.myDuration_0.isPositive) {\n throw RuntimeException_init('Duration must be positive');\n }}\n Object.defineProperty(DurationInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n var duration = this.myDuration_0.duration;\n if (duration.compareTo_11rb$(Duration.Companion.SECOND.duration) < 0) {\n return '%S';\n } else if (duration.compareTo_11rb$(Duration.Companion.MINUTE.duration) < 0) {\n return '%S';\n } else if (duration.compareTo_11rb$(Duration.Companion.HOUR.duration) < 0) {\n return '%M';\n } else if (duration.compareTo_11rb$(Duration.Companion.DAY.duration) < 0) {\n return '%H:%M';\n } else if (duration.compareTo_11rb$(Duration.Companion.WEEK.duration) < 0) {\n return '%b %e';\n }return '%b %e';\n }\n });\n DurationInterval.prototype.range_lu1900$ = function (start, end) {\n var step = this.myDuration_0.duration.multiply(Kotlin.Long.fromInt(this.count)).toNumber();\n var x = start / step;\n var tick = JsMath.ceil(x) * step;\n var result = ArrayList_init();\n while (tick <= end) {\n result.add_11rb$(tick);\n tick += step;\n }\n return result;\n };\n DurationInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DurationInterval',\n interfaces: [TimeInterval]\n };\n function MeasuredInDays(count) {\n TimeInterval.call(this, count);\n }\n MeasuredInDays.prototype.range_lu1900$ = function (start, end) {\n if (start > end) {\n throw RuntimeException_init('Duration must be positive');\n }var dateTimeStart = TimeUtil_getInstance().asDateTimeUTC_14dthe$(start);\n var dateStart = this.getFirstDayContaining_amwj4p$(dateTimeStart);\n var dateTimeTick = new DateTime(dateStart);\n if (dateTimeTick.compareTo_11rb$(dateTimeStart) < 0) {\n dateTimeTick = this.addInterval_amwj4p$(dateTimeTick);\n }var result = ArrayList_init();\n var tick = TimeUtil_getInstance().asInstantUTC_amwj4p$(dateTimeTick).toNumber();\n while (tick <= end) {\n result.add_11rb$(tick);\n dateTimeTick = this.addInterval_amwj4p$(dateTimeTick);\n tick = TimeUtil_getInstance().asInstantUTC_amwj4p$(dateTimeTick).toNumber();\n }\n return result;\n };\n MeasuredInDays.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MeasuredInDays',\n interfaces: [TimeInterval]\n };\n function MonthInterval(count) {\n MeasuredInDays.call(this, count);\n }\n Object.defineProperty(MonthInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return '%b';\n }\n });\n MonthInterval.prototype.getFirstDayContaining_amwj4p$ = function (instant) {\n var firstDay = instant.date;\n firstDay = Date_0.Companion.firstDayOf_8fsw02$(firstDay.year, firstDay.month);\n return firstDay;\n };\n MonthInterval.prototype.addInterval_amwj4p$ = function (toInstant) {\n var tmp$;\n var result = toInstant;\n tmp$ = this.count;\n for (var i = 0; i < tmp$; i++) {\n result = this.addMonth_0(result);\n }\n return result;\n };\n MonthInterval.prototype.addMonth_0 = function (toInstant) {\n var year = toInstant.year;\n var month = toInstant.month;\n var next = ensureNotNull(month).next();\n if (next == null) {\n next = Month.Companion.JANUARY;\n year = year + 1 | 0;\n }return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year, next));\n };\n MonthInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MonthInterval',\n interfaces: [MeasuredInDays]\n };\n function NiceTimeInterval() {\n NiceTimeInterval_instance = this;\n this.AUTO_STEPS_MS_0 = new Float64Array([1000.0, 5000.0, 15000.0, 30000.0, 60000.0, 5 * 60000.0, 15 * 60000.0, 30 * 60000.0, 3600000.0, 3 * 3600000.0, 6 * 3600000.0, 12 * 3600000.0, 8.64E7, 2 * 8.64E7, 6.048E8, 2.592E9, 3 * 2.592E9, YearInterval$Companion_getInstance().MS]);\n this.AUTO_INTERVALS_0 = [TimeInterval$Companion_getInstance().seconds_za3lpa$(1), TimeInterval$Companion_getInstance().seconds_za3lpa$(5), TimeInterval$Companion_getInstance().seconds_za3lpa$(15), TimeInterval$Companion_getInstance().seconds_za3lpa$(30), TimeInterval$Companion_getInstance().minutes_za3lpa$(1), TimeInterval$Companion_getInstance().minutes_za3lpa$(5), TimeInterval$Companion_getInstance().minutes_za3lpa$(15), TimeInterval$Companion_getInstance().minutes_za3lpa$(30), TimeInterval$Companion_getInstance().hours_za3lpa$(1), TimeInterval$Companion_getInstance().hours_za3lpa$(3), TimeInterval$Companion_getInstance().hours_za3lpa$(6), TimeInterval$Companion_getInstance().hours_za3lpa$(12), TimeInterval$Companion_getInstance().days_za3lpa$(1), TimeInterval$Companion_getInstance().days_za3lpa$(2), TimeInterval$Companion_getInstance().weeks_za3lpa$(1), TimeInterval$Companion_getInstance().months_za3lpa$(1), TimeInterval$Companion_getInstance().months_za3lpa$(3), TimeInterval$Companion_getInstance().years_za3lpa$(1)];\n }\n NiceTimeInterval.prototype.forMillis_14dthe$ = function (interval) {\n var tmp$;\n if (interval <= this.AUTO_STEPS_MS_0[0]) {\n return this.AUTO_INTERVALS_0[0];\n }var result = this.AUTO_INTERVALS_0[this.AUTO_STEPS_MS_0.length - 1 | 0];\n tmp$ = this.AUTO_STEPS_MS_0.length;\n for (var i = 1; i < tmp$; i++) {\n if (this.AUTO_STEPS_MS_0[i] >= interval) {\n var deltaDown = interval - this.AUTO_STEPS_MS_0[i - 1 | 0];\n var deltaUp = this.AUTO_STEPS_MS_0[i] - interval;\n if (deltaDown < deltaUp) {\n result = this.AUTO_INTERVALS_0[i - 1 | 0];\n } else {\n result = this.AUTO_INTERVALS_0[i];\n }\n break;\n }}\n return result;\n };\n NiceTimeInterval.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'NiceTimeInterval',\n interfaces: []\n };\n var NiceTimeInterval_instance = null;\n function NiceTimeInterval_getInstance() {\n if (NiceTimeInterval_instance === null) {\n new NiceTimeInterval();\n }return NiceTimeInterval_instance;\n }\n function QuarterInterval(count) {\n TimeInterval.call(this, count);\n }\n Object.defineProperty(QuarterInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return 'Q';\n }\n });\n QuarterInterval.prototype.range_lu1900$ = function (start, end) {\n throw UnsupportedOperationException_init();\n };\n QuarterInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuarterInterval',\n interfaces: [TimeInterval]\n };\n function SemesterInterval(count) {\n SemesterInterval$Companion_getInstance();\n TimeInterval.call(this, count);\n }\n Object.defineProperty(SemesterInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n throw UnsupportedOperationException_init();\n }\n });\n Object.defineProperty(SemesterInterval.prototype, 'tickFormatter', {\n configurable: true,\n get: function () {\n return SemesterInterval$Companion_getInstance().TIME_FORMAT_FUNCTION_0;\n }\n });\n SemesterInterval.prototype.range_lu1900$ = function (start, end) {\n throw UnsupportedOperationException_init();\n };\n function SemesterInterval$Companion() {\n SemesterInterval$Companion_instance = this;\n this.TIME_FORMAT_FUNCTION_0 = SemesterInterval$Companion$TIME_FORMAT_FUNCTION$lambda;\n }\n function SemesterInterval$Companion$TIME_FORMAT_FUNCTION$lambda(input) {\n var tmp$;\n var result = DateTimeFormatUtil_getInstance().formatDateUTC_xfy9o8$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE(), 'Q');\n if (result.length === 2 && startsWith(result, 'Q')) {\n try {\n var quarterNum = toInt(result.substring(1));\n var semesterNumber = (quarterNum + 1 | 0) / 2 | 0;\n if (semesterNumber === 1 || semesterNumber === 2) {\n result = 'Semester ' + semesterNumber;\n }} catch (ignored) {\n if (!Kotlin.isType(ignored, NumberFormatException))\n throw ignored;\n }\n }return result;\n }\n SemesterInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SemesterInterval$Companion_instance = null;\n function SemesterInterval$Companion_getInstance() {\n if (SemesterInterval$Companion_instance === null) {\n new SemesterInterval$Companion();\n }return SemesterInterval$Companion_instance;\n }\n SemesterInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SemesterInterval',\n interfaces: [TimeInterval]\n };\n function TimeInterval(count) {\n TimeInterval$Companion_getInstance();\n this.count = count;\n }\n Object.defineProperty(TimeInterval.prototype, 'tickFormatter', {\n configurable: true,\n get: function () {\n return Formatter_getInstance().time_61zpoe$(this.tickFormatPattern);\n }\n });\n function TimeInterval$Companion() {\n TimeInterval$Companion_instance = this;\n }\n TimeInterval$Companion.prototype.milliseconds_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.MS, count);\n };\n TimeInterval$Companion.prototype.seconds_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.SECOND, count);\n };\n TimeInterval$Companion.prototype.minutes_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.MINUTE, count);\n };\n TimeInterval$Companion.prototype.hours_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.HOUR, count);\n };\n TimeInterval$Companion.prototype.days_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.DAY, count);\n };\n TimeInterval$Companion.prototype.weeks_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.WEEK, count);\n };\n TimeInterval$Companion.prototype.months_za3lpa$ = function (count) {\n return new MonthInterval(count);\n };\n TimeInterval$Companion.prototype.quarter_0 = function (count) {\n return new QuarterInterval(count);\n };\n TimeInterval$Companion.prototype.semester_0 = function (count) {\n return new SemesterInterval(count);\n };\n TimeInterval$Companion.prototype.years_za3lpa$ = function (count) {\n return new YearInterval(count);\n };\n TimeInterval$Companion.prototype.fromIntervalDataType_w817vg$ = function (dataType) {\n var tmp$;\n switch (dataType.name) {\n case 'INSTANT_OF_DAY':\n tmp$ = this.days_za3lpa$(1);\n break;\n case 'INSTANT_OF_MONTH':\n tmp$ = this.months_za3lpa$(1);\n break;\n case 'INSTANT_OF_QUARTER':\n tmp$ = this.quarter_0(1);\n break;\n case 'INSTANT_OF_HALF_YEAR':\n tmp$ = this.semester_0(1);\n break;\n case 'INSTANT_OF_YEAR':\n tmp$ = this.years_za3lpa$(1);\n break;\n default:throw IllegalArgumentException_init(\"Can't create interval from data type: \" + dataType);\n }\n return tmp$;\n };\n TimeInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeInterval$Companion_instance = null;\n function TimeInterval$Companion_getInstance() {\n if (TimeInterval$Companion_instance === null) {\n new TimeInterval$Companion();\n }return TimeInterval$Companion_instance;\n }\n TimeInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeInterval',\n interfaces: []\n };\n function YearInterval(count) {\n YearInterval$Companion_getInstance();\n MeasuredInDays.call(this, count);\n this.tickFormatPattern_1ltjii$_0 = YearInterval$Companion_getInstance().TICK_FORMAT;\n }\n Object.defineProperty(YearInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return this.tickFormatPattern_1ltjii$_0;\n }\n });\n YearInterval.prototype.getFirstDayContaining_amwj4p$ = function (instant) {\n return Date_0.Companion.firstDayOf_8fsw02$(instant.year);\n };\n YearInterval.prototype.addInterval_amwj4p$ = function (toInstant) {\n var tmp$;\n var result = toInstant;\n tmp$ = this.count;\n for (var i = 0; i < tmp$; i++) {\n result = this.addYear_0(result);\n }\n return result;\n };\n YearInterval.prototype.addYear_0 = function (toInstant) {\n var year = toInstant.year;\n return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year + 1 | 0));\n };\n function YearInterval$Companion() {\n YearInterval$Companion_instance = this;\n this.TICK_FORMAT = '%Y';\n this.MS = 3.1536E10;\n this.TICK_FORMATTER = Formatter_getInstance().time_61zpoe$(this.TICK_FORMAT);\n }\n YearInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var YearInterval$Companion_instance = null;\n function YearInterval$Companion_getInstance() {\n if (YearInterval$Companion_instance === null) {\n new YearInterval$Companion();\n }return YearInterval$Companion_instance;\n }\n YearInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'YearInterval',\n interfaces: [MeasuredInDays]\n };\n Object.defineProperty(ColorPalette$Type, 'SEQUENTIAL', {\n get: ColorPalette$Type$SEQUENTIAL_getInstance\n });\n Object.defineProperty(ColorPalette$Type, 'DIVERGING', {\n get: ColorPalette$Type$DIVERGING_getInstance\n });\n Object.defineProperty(ColorPalette$Type, 'QUALITATIVE', {\n get: ColorPalette$Type$QUALITATIVE_getInstance\n });\n ColorPalette.prototype.Type = ColorPalette$Type;\n Object.defineProperty(ColorPalette$Sequential, 'Blues', {\n get: ColorPalette$Sequential$Blues_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'BuGn', {\n get: ColorPalette$Sequential$BuGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'BuPu', {\n get: ColorPalette$Sequential$BuPu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'GnBu', {\n get: ColorPalette$Sequential$GnBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Greens', {\n get: ColorPalette$Sequential$Greens_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Greys', {\n get: ColorPalette$Sequential$Greys_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Oranges', {\n get: ColorPalette$Sequential$Oranges_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'OrRd', {\n get: ColorPalette$Sequential$OrRd_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuBu', {\n get: ColorPalette$Sequential$PuBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuBuGn', {\n get: ColorPalette$Sequential$PuBuGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuRd', {\n get: ColorPalette$Sequential$PuRd_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Purples', {\n get: ColorPalette$Sequential$Purples_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'RdPu', {\n get: ColorPalette$Sequential$RdPu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Reds', {\n get: ColorPalette$Sequential$Reds_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlGn', {\n get: ColorPalette$Sequential$YlGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlGnBu', {\n get: ColorPalette$Sequential$YlGnBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlOrBr', {\n get: ColorPalette$Sequential$YlOrBr_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlOrRd', {\n get: ColorPalette$Sequential$YlOrRd_getInstance\n });\n ColorPalette.prototype.Sequential = ColorPalette$Sequential;\n Object.defineProperty(ColorPalette$Diverging, 'BrBG', {\n get: ColorPalette$Diverging$BrBG_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PiYG', {\n get: ColorPalette$Diverging$PiYG_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PRGn', {\n get: ColorPalette$Diverging$PRGn_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PuOr', {\n get: ColorPalette$Diverging$PuOr_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdBu', {\n get: ColorPalette$Diverging$RdBu_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdGy', {\n get: ColorPalette$Diverging$RdGy_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdYlBu', {\n get: ColorPalette$Diverging$RdYlBu_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdYlGn', {\n get: ColorPalette$Diverging$RdYlGn_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'Spectral', {\n get: ColorPalette$Diverging$Spectral_getInstance\n });\n ColorPalette.prototype.Diverging = ColorPalette$Diverging;\n Object.defineProperty(ColorPalette$Qualitative, 'Accent', {\n get: ColorPalette$Qualitative$Accent_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Dark2', {\n get: ColorPalette$Qualitative$Dark2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Paired', {\n get: ColorPalette$Qualitative$Paired_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Pastel1', {\n get: ColorPalette$Qualitative$Pastel1_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Pastel2', {\n get: ColorPalette$Qualitative$Pastel2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set1', {\n get: ColorPalette$Qualitative$Set1_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set2', {\n get: ColorPalette$Qualitative$Set2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set3', {\n get: ColorPalette$Qualitative$Set3_getInstance\n });\n ColorPalette.prototype.Qualitative = ColorPalette$Qualitative;\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n var package$common = package$plot.common || (package$plot.common = {});\n var package$color = package$common.color || (package$common.color = {});\n Object.defineProperty(package$color, 'ColorPalette', {\n get: ColorPalette_getInstance\n });\n package$color.ColorScheme = ColorScheme;\n Object.defineProperty(package$color, 'ColorSets', {\n get: ColorSets_getInstance\n });\n Object.defineProperty(package$color, 'ColorUtil', {\n get: ColorUtil_getInstance\n });\n Object.defineProperty(package$color, 'PaletteUtil', {\n get: PaletteUtil_getInstance\n });\n Object.defineProperty(RGBChannelGen, 'Companion', {\n get: RGBChannelGen$Companion_getInstance\n });\n package$color.RGBChannelGen = RGBChannelGen;\n Object.defineProperty(DataType, 'NUMBER', {\n get: DataType$NUMBER_getInstance\n });\n Object.defineProperty(DataType, 'STRING', {\n get: DataType$STRING_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT', {\n get: DataType$INSTANT_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_DAY', {\n get: DataType$INSTANT_OF_DAY_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_MONTH', {\n get: DataType$INSTANT_OF_MONTH_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_QUARTER', {\n get: DataType$INSTANT_OF_QUARTER_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_HALF_YEAR', {\n get: DataType$INSTANT_OF_HALF_YEAR_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_YEAR', {\n get: DataType$INSTANT_OF_YEAR_getInstance\n });\n var package$data = package$common.data || (package$common.data = {});\n package$data.DataType = DataType;\n Object.defineProperty(RegularMeshDetector, 'Companion', {\n get: RegularMeshDetector$Companion_getInstance\n });\n package$data.RegularMeshDetector = RegularMeshDetector;\n SeriesUtil.prototype.CheckedDoubleList = SeriesUtil$CheckedDoubleList;\n SeriesUtil.prototype.CheckedDoubleIterable = SeriesUtil$CheckedDoubleIterable;\n Object.defineProperty(package$data, 'SeriesUtil', {\n get: SeriesUtil_getInstance\n });\n var package$geometry = package$common.geometry || (package$common.geometry = {});\n package$geometry.DouglasPeuckerSimplification = DouglasPeuckerSimplification;\n PolylineSimplifier.RankingStrategy = PolylineSimplifier$RankingStrategy;\n Object.defineProperty(PolylineSimplifier, 'Companion', {\n get: PolylineSimplifier$Companion_getInstance\n });\n package$geometry.PolylineSimplifier = PolylineSimplifier;\n Object.defineProperty(VisvalingamWhyattSimplification, 'Companion', {\n get: VisvalingamWhyattSimplification$Companion_getInstance\n });\n package$geometry.VisvalingamWhyattSimplification = VisvalingamWhyattSimplification;\n var package$text = package$common.text || (package$common.text = {});\n Object.defineProperty(package$text, 'DateTimeFormatUtil', {\n get: DateTimeFormatUtil_getInstance\n });\n Object.defineProperty(package$text, 'Formatter', {\n get: Formatter_getInstance\n });\n var package$time = package$common.time || (package$common.time = {});\n Object.defineProperty(package$time, 'TimeUtil', {\n get: TimeUtil_getInstance\n });\n var package$interval = package$time.interval || (package$time.interval = {});\n package$interval.DurationInterval = DurationInterval;\n package$interval.MeasuredInDays = MeasuredInDays;\n package$interval.MonthInterval = MonthInterval;\n Object.defineProperty(package$interval, 'NiceTimeInterval', {\n get: NiceTimeInterval_getInstance\n });\n package$interval.QuarterInterval = QuarterInterval;\n Object.defineProperty(SemesterInterval, 'Companion', {\n get: SemesterInterval$Companion_getInstance\n });\n package$interval.SemesterInterval = SemesterInterval;\n Object.defineProperty(TimeInterval, 'Companion', {\n get: TimeInterval$Companion_getInstance\n });\n package$interval.TimeInterval = TimeInterval;\n Object.defineProperty(YearInterval, 'Companion', {\n get: YearInterval$Companion_getInstance\n });\n package$interval.YearInterval = YearInterval;\n Kotlin.defineModule('lets-plot-plot-common-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorPalette.kt?6e59","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorSets.kt?f7ca","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorUtil.kt?a3a8","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/PaletteUtil.kt?a121","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/RGBChannelGen.kt?7fe0","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/DataType.kt?8899","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/RegularMeshDetector.kt?0541","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/SeriesUtil.kt?e534","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/DouglasPeuckerSimplification.kt?3688","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/PolylineSimplifier.kt?7da6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/VisvalingamWhyattSimplification.kt?0cd2","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/text/DateTimeFormatUtil.kt?2a3e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/text/Formatter.kt?7c5e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/TimeUtil.kt?fd60","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/DurationInterval.kt?8e93","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/MeasuredInDays.kt?727b","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/MonthInterval.kt?8fe6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/NiceTimeInterval.kt?1a02","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/QuarterInterval.kt?c184","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/SemesterInterval.kt?244f","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/TimeInterval.kt?19e6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/YearInterval.kt?d517"],"names":[],"mappings":"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","file":"./kotlin-dce-dev/lets-plot-plot-common-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ColorPalette {\n    private const val MIN_COLOR_SET_SIZE = 3\n\n    private fun colors(scheme: ColorScheme, count: Int): Array<String> {\n        @Suppress(\"NAME_SHADOWING\") var count = count\n        count = max(MIN_COLOR_SET_SIZE, count)\n        count = min(scheme.maxColors, count)\n        return scheme.colorSet[count - MIN_COLOR_SET_SIZE]\n    }\n\n    private fun maxColorSetSize(scheme: ColorScheme): Int {\n        val colorSet = scheme.colorSet\n        return colorSet[colorSet.size - 1].size\n    }\n\n    enum class Type(private val myPresentation: String) {\n        SEQUENTIAL(\"sequential\"),\n        DIVERGING(\"diverging\"),\n        QUALITATIVE(\"qualitative\");\n\n        override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Sequential(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        Blues(\"blues\", ColorSets.BLUES),\n        BuGn(\"blue-green\", ColorSets.BU_GN),\n        BuPu(\"blue-purple\", ColorSets.BU_PU),\n        GnBu(\"green-blue\", ColorSets.GN_BU),\n        Greens(\"greens\", ColorSets.GREENS),\n        Greys(\"greys\", ColorSets.GREYS),\n        Oranges(\"oranges\", ColorSets.ORANGES),\n        OrRd(\"orange-red\", ColorSets.OR_RD),\n        PuBu(\"purple-blue\", ColorSets.PU_BU),\n        PuBuGn(\"purple-blue-green\", ColorSets.PU_BU_GN),\n        PuRd(\"purple-red\", ColorSets.PU_RD),\n        Purples(\"purples\", ColorSets.PURPLES),\n        RdPu(\"red-purple\", ColorSets.RD_PU),\n        Reds(\"reds\", ColorSets.REDS),\n        YlGn(\"yellow-green\", ColorSets.YL_GN),\n        YlGnBu(\"yellow-green-blue\", ColorSets.YL_GN_BU),\n        YlOrBr(\"yellow-orange-brown\", ColorSets.YL_OR_BR),\n        YlOrRd(\"yellow-orange-red\", ColorSets.YL_OR_RD);\n\n        final override val type: Type\n            get() = ColorPalette.Type.SEQUENTIAL\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Diverging(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        BrBG(\"brown-blue/green\", ColorSets.BR_BG),\n        PiYG(\"pink-yellow/green\", ColorSets.PI_YG),\n        PRGn(\"purple/red-green\", ColorSets.PR_GN),\n        PuOr(\"purple-orange\", ColorSets.PU_OR),\n        RdBu(\"red-blue\", ColorSets.RD_BU),\n        RdGy(\"red-grey\", ColorSets.RD_GY),\n        RdYlBu(\"red-yellow-blue\", ColorSets.RD_YL_BU),\n        RdYlGn(\"red-yellow-green\", ColorSets.RD_YL_GN),\n        Spectral(\"spectral\", ColorSets.SPECTRAL);\n\n        final override val type: Type\n            get() = ColorPalette.Type.DIVERGING\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Qualitative(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        Accent(\"accent\", ColorSets.ACCENT),\n        Dark2(\"dark 2\", ColorSets.DARK_2),\n        Paired(\"paired\", ColorSets.PAIRED),\n        Pastel1(\"pastel 1\", ColorSets.PASTEL_1),\n        Pastel2(\"pastel 2\", ColorSets.PASTEL_2),\n        Set1(\"set 1\", ColorSets.SET_1),\n        Set2(\"set 2\", ColorSets.SET_2),\n        Set3(\"set 3\", ColorSets.SET_3);\n\n        final override val type: Type\n            get() = Type.QUALITATIVE\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\n/**\n * source: colorbrewer2.org/\n */\ninternal object ColorSets {\n    // --------------------\n    // sequential multi-hue\n    // --------------------\n    // blue - green\n    val BU_GN_3 = arrayOf(\"#e5f5f9\", \"#99d8c9\", \"#2ca25f\")\n    val BU_GN_4 = arrayOf(\"#edf8fb\", \"#b2e2e2\", \"#66c2a4\", \"#238b45\")\n    val BU_GN_5 = arrayOf(\"#edf8fb\", \"#b2e2e2\", \"#66c2a4\", \"#2ca25f\", \"#006d2c\")\n    val BU_GN_6 = arrayOf(\"#edf8fb\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#2ca25f\", \"#006d2c\")\n    val BU_GN_7 = arrayOf(\"#edf8fb\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#005824\")\n    val BU_GN_8 = arrayOf(\"#f7fcfd\", \"#e5f5f9\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#005824\")\n    val BU_GN_9 = arrayOf(\"#f7fcfd\", \"#e5f5f9\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#006d2c\", \"#00441b\")\n    // blue - purple\n    val BU_PU_3 = arrayOf(\"#e0ecf4\", \"#9ebcda\", \"#8856a7\")\n    val BU_PU_4 = arrayOf(\"#edf8fb\", \"#b3cde3\", \"#8c96c6\", \"#88419d\")\n    val BU_PU_5 = arrayOf(\"#edf8fb\", \"#b3cde3\", \"#8c96c6\", \"#8856a7\", \"#810f7c\")\n    val BU_PU_6 = arrayOf(\"#edf8fb\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8856a7\", \"#810f7c\")\n    val BU_PU_7 = arrayOf(\"#edf8fb\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#6e016b\")\n    val BU_PU_8 = arrayOf(\"#f7fcfd\", \"#e0ecf4\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#6e016b\")\n    val BU_PU_9 = arrayOf(\"#f7fcfd\", \"#e0ecf4\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#810f7c\", \"#4d004b\")\n    // green - blue\n    val GN_BU_3 = arrayOf(\"#e0f3db\", \"#a8ddb5\", \"#43a2ca\")\n    val GN_BU_4 = arrayOf(\"#f0f9e8\", \"#bae4bc\", \"#7bccc4\", \"#2b8cbe\")\n    val GN_BU_5 = arrayOf(\"#f0f9e8\", \"#bae4bc\", \"#7bccc4\", \"#43a2ca\", \"#0868ac\")\n    val GN_BU_6 = arrayOf(\"#f0f9e8\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#43a2ca\", \"#0868ac\")\n    val GN_BU_7 = arrayOf(\"#f0f9e8\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#08589e\")\n    val GN_BU_8 = arrayOf(\"#f7fcf0\", \"#e0f3db\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#08589e\")\n    val GN_BU_9 = arrayOf(\"#f7fcf0\", \"#e0f3db\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#0868ac\", \"#084081\")\n    // orange - red\n    val OR_RD_3 = arrayOf(\"#fee8c8\", \"#fdbb84\", \"#e34a33\")\n    val OR_RD_4 = arrayOf(\"#fef0d9\", \"#fdcc8a\", \"#fc8d59\", \"#d7301f\")\n    val OR_RD_5 = arrayOf(\"#fef0d9\", \"#fdcc8a\", \"#fc8d59\", \"#e34a33\", \"#b30000\")\n    val OR_RD_6 = arrayOf(\"#fef0d9\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#e34a33\", \"#b30000\")\n    val OR_RD_7 = arrayOf(\"#fef0d9\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#990000\")\n    val OR_RD_8 = arrayOf(\"#fff7ec\", \"#fee8c8\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#990000\")\n    val OR_RD_9 = arrayOf(\"#fff7ec\", \"#fee8c8\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#b30000\", \"#7f0000\")\n    // purple - blue\n    val PU_BU_3 = arrayOf(\"#ece7f2\", \"#a6bddb\", \"#2b8cbe\")\n    val PU_BU_4 = arrayOf(\"#f1eef6\", \"#bdc9e1\", \"#74a9cf\", \"#0570b0\")\n    val PU_BU_5 = arrayOf(\"#f1eef6\", \"#bdc9e1\", \"#74a9cf\", \"#2b8cbe\", \"#045a8d\")\n    val PU_BU_6 = arrayOf(\"#f1eef6\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#2b8cbe\", \"#045a8d\")\n    val PU_BU_7 = arrayOf(\"#f1eef6\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#034e7b\")\n    val PU_BU_8 = arrayOf(\"#fff7fb\", \"#ece7f2\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#034e7b\")\n    val PU_BU_9 = arrayOf(\"#fff7fb\", \"#ece7f2\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#045a8d\", \"#023858\")\n    // purple - blue - green\n    val PU_BU_GN_3 = arrayOf(\"#ece2f0\", \"#a6bddb\", \"#1c9099\")\n    val PU_BU_GN_4 = arrayOf(\"#f6eff7\", \"#bdc9e1\", \"#67a9cf\", \"#02818a\")\n    val PU_BU_GN_5 = arrayOf(\"#f6eff7\", \"#bdc9e1\", \"#67a9cf\", \"#1c9099\", \"#016c59\")\n    val PU_BU_GN_6 = arrayOf(\"#f6eff7\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#1c9099\", \"#016c59\")\n    val PU_BU_GN_7 = arrayOf(\"#f6eff7\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016450\")\n    val PU_BU_GN_8 = arrayOf(\"#fff7fb\", \"#ece2f0\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016450\")\n    val PU_BU_GN_9 = arrayOf(\"#fff7fb\", \"#ece2f0\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016c59\", \"#014636\")\n    // purple - red\n    val PU_RD_3 = arrayOf(\"#e7e1ef\", \"#c994c7\", \"#dd1c77\")\n    val PU_RD_4 = arrayOf(\"#f1eef6\", \"#d7b5d8\", \"#df65b0\", \"#ce1256\")\n    val PU_RD_5 = arrayOf(\"#f1eef6\", \"#d7b5d8\", \"#df65b0\", \"#dd1c77\", \"#980043\")\n    val PU_RD_6 = arrayOf(\"#f1eef6\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#dd1c77\", \"#980043\")\n    val PU_RD_7 = arrayOf(\"#f1eef6\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#91003f\")\n    val PU_RD_8 = arrayOf(\"#f7f4f9\", \"#e7e1ef\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#91003f\")\n    val PU_RD_9 = arrayOf(\"#f7f4f9\", \"#e7e1ef\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#980043\", \"#67001f\")\n    // red - purple\n    val RD_PU_3 = arrayOf(\"#fde0dd\", \"#fa9fb5\", \"#c51b8a\")\n    val RD_PU_4 = arrayOf(\"#feebe2\", \"#fbb4b9\", \"#f768a1\", \"#ae017e\")\n    val RD_PU_5 = arrayOf(\"#feebe2\", \"#fbb4b9\", \"#f768a1\", \"#c51b8a\", \"#7a0177\")\n    val RD_PU_6 = arrayOf(\"#feebe2\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#c51b8a\", \"#7a0177\")\n    val RD_PU_7 = arrayOf(\"#feebe2\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\")\n    val RD_PU_8 = arrayOf(\"#fff7f3\", \"#fde0dd\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\")\n    val RD_PU_9 = arrayOf(\"#fff7f3\", \"#fde0dd\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\", \"#49006a\")\n    // yellow - green\n    val YL_GN_3 = arrayOf(\"#f7fcb9\", \"#addd8e\", \"#31a354\")\n    val YL_GN_4 = arrayOf(\"#ffffcc\", \"#c2e699\", \"#78c679\", \"#238443\")\n    val YL_GN_5 = arrayOf(\"#ffffcc\", \"#c2e699\", \"#78c679\", \"#31a354\", \"#006837\")\n    val YL_GN_6 = arrayOf(\"#ffffcc\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#31a354\", \"#006837\")\n    val YL_GN_7 = arrayOf(\"#ffffcc\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#005a32\")\n    val YL_GN_8 = arrayOf(\"#ffffe5\", \"#f7fcb9\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#005a32\")\n    val YL_GN_9 = arrayOf(\"#ffffe5\", \"#f7fcb9\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#006837\", \"#004529\")\n    // yellow - green - blue\n    val YL_GN_BU_3 = arrayOf(\"#edf8b1\", \"#7fcdbb\", \"#2c7fb8\")\n    val YL_GN_BU_4 = arrayOf(\"#ffffcc\", \"#a1dab4\", \"#41b6c4\", \"#225ea8\")\n    val YL_GN_BU_5 = arrayOf(\"#ffffcc\", \"#a1dab4\", \"#41b6c4\", \"#2c7fb8\", \"#253494\")\n    val YL_GN_BU_6 = arrayOf(\"#ffffcc\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#2c7fb8\", \"#253494\")\n    val YL_GN_BU_7 = arrayOf(\"#ffffcc\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#0c2c84\")\n    val YL_GN_BU_8 = arrayOf(\"#ffffd9\", \"#edf8b1\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#0c2c84\")\n    val YL_GN_BU_9 = arrayOf(\"#ffffd9\", \"#edf8b1\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#253494\", \"#081d58\")\n    // yellow - orange - brown\n    val YL_OR_BR_3 = arrayOf(\"#fff7bc\", \"#fec44f\", \"#d95f0e\")\n    val YL_OR_BR_4 = arrayOf(\"#ffffd4\", \"#fed98e\", \"#fe9929\", \"#cc4c02\")\n    val YL_OR_BR_5 = arrayOf(\"#ffffd4\", \"#fed98e\", \"#fe9929\", \"#d95f0e\", \"#993404\")\n    val YL_OR_BR_6 = arrayOf(\"#ffffd4\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#d95f0e\", \"#993404\")\n    val YL_OR_BR_7 = arrayOf(\"#ffffd4\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#8c2d04\")\n    val YL_OR_BR_8 = arrayOf(\"#ffffe5\", \"#fff7bc\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#8c2d04\")\n    val YL_OR_BR_9 = arrayOf(\"#ffffe5\", \"#fff7bc\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#993404\", \"#662506\")\n    // yellow - orange - red\n    val YL_OR_RD_3 = arrayOf(\"#ffeda0\", \"#feb24c\", \"#f03b20\")\n    val YL_OR_RD_4 = arrayOf(\"#ffffb2\", \"#fecc5c\", \"#fd8d3c\", \"#e31a1c\")\n    val YL_OR_RD_5 = arrayOf(\"#ffffb2\", \"#fecc5c\", \"#fd8d3c\", \"#f03b20\", \"#bd0026\")\n    val YL_OR_RD_6 = arrayOf(\"#ffffb2\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#f03b20\", \"#bd0026\")\n    val YL_OR_RD_7 = arrayOf(\"#ffffb2\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#b10026\")\n    val YL_OR_RD_8 = arrayOf(\"#ffffcc\", \"#ffeda0\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#b10026\")\n    val YL_OR_RD_9 = arrayOf(\"#ffffcc\", \"#ffeda0\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#bd0026\", \"#800026\")\n\n\n    val BU_GN = arrayOf(\n        BU_GN_3,\n        BU_GN_4,\n        BU_GN_5,\n        BU_GN_6,\n        BU_GN_7,\n        BU_GN_8,\n        BU_GN_9\n    )\n    val BU_PU = arrayOf(\n        BU_PU_3,\n        BU_PU_4,\n        BU_PU_5,\n        BU_PU_6,\n        BU_PU_7,\n        BU_PU_8,\n        BU_PU_9\n    )\n    val GN_BU = arrayOf(\n        GN_BU_3,\n        GN_BU_4,\n        GN_BU_5,\n        GN_BU_6,\n        GN_BU_7,\n        GN_BU_8,\n        GN_BU_9\n    )\n    val OR_RD = arrayOf(\n        OR_RD_3,\n        OR_RD_4,\n        OR_RD_5,\n        OR_RD_6,\n        OR_RD_7,\n        OR_RD_8,\n        OR_RD_9\n    )\n    val PU_BU = arrayOf(\n        PU_BU_3,\n        PU_BU_4,\n        PU_BU_5,\n        PU_BU_6,\n        PU_BU_7,\n        PU_BU_8,\n        PU_BU_9\n    )\n    val PU_BU_GN = arrayOf(\n        PU_BU_GN_3,\n        PU_BU_GN_4,\n        PU_BU_GN_5,\n        PU_BU_GN_6,\n        PU_BU_GN_7,\n        PU_BU_GN_8,\n        PU_BU_GN_9\n    )\n    val PU_RD = arrayOf(\n        PU_RD_3,\n        PU_RD_4,\n        PU_RD_5,\n        PU_RD_6,\n        PU_RD_7,\n        PU_RD_8,\n        PU_RD_9\n    )\n    val RD_PU = arrayOf(\n        RD_PU_3,\n        RD_PU_4,\n        RD_PU_5,\n        RD_PU_6,\n        RD_PU_7,\n        RD_PU_8,\n        RD_PU_9\n    )\n    val YL_GN = arrayOf(\n        YL_GN_3,\n        YL_GN_4,\n        YL_GN_5,\n        YL_GN_6,\n        YL_GN_7,\n        YL_GN_8,\n        YL_GN_9\n    )\n    val YL_GN_BU = arrayOf(\n        YL_GN_BU_3,\n        YL_GN_BU_4,\n        YL_GN_BU_5,\n        YL_GN_BU_6,\n        YL_GN_BU_7,\n        YL_GN_BU_8,\n        YL_GN_BU_9\n    )\n    val YL_OR_BR = arrayOf(\n        YL_OR_BR_3,\n        YL_OR_BR_4,\n        YL_OR_BR_5,\n        YL_OR_BR_6,\n        YL_OR_BR_7,\n        YL_OR_BR_8,\n        YL_OR_BR_9\n    )\n    val YL_OR_RD = arrayOf(\n        YL_OR_RD_3,\n        YL_OR_RD_4,\n        YL_OR_RD_5,\n        YL_OR_RD_6,\n        YL_OR_RD_7,\n        YL_OR_RD_8,\n        YL_OR_RD_9\n    )\n\n    // --------------------\n    // sequential single-hue\n    // --------------------\n    // Blues\n    val BLUES_3 = arrayOf(\"#deebf7\", \"#9ecae1\", \"#3182bd\")\n    val BLUES_4 = arrayOf(\"#eff3ff\", \"#bdd7e7\", \"#6baed6\", \"#2171b5\")\n    val BLUES_5 = arrayOf(\"#eff3ff\", \"#bdd7e7\", \"#6baed6\", \"#3182bd\", \"#08519c\")\n    val BLUES_6 = arrayOf(\"#eff3ff\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#3182bd\", \"#08519c\")\n    val BLUES_7 = arrayOf(\"#eff3ff\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#084594\")\n    val BLUES_8 = arrayOf(\"#f7fbff\", \"#deebf7\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#084594\")\n    val BLUES_9 = arrayOf(\"#f7fbff\", \"#deebf7\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#08519c\", \"#08306b\")\n    // Greens\n    val GREENS_3 = arrayOf(\"#e5f5e0\", \"#a1d99b\", \"#31a354\")\n    val GREENS_4 = arrayOf(\"#edf8e9\", \"#bae4b3\", \"#74c476\", \"#238b45\")\n    val GREENS_5 = arrayOf(\"#edf8e9\", \"#bae4b3\", \"#74c476\", \"#31a354\", \"#006d2c\")\n    val GREENS_6 = arrayOf(\"#edf8e9\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#31a354\", \"#006d2c\")\n    val GREENS_7 = arrayOf(\"#edf8e9\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#005a32\")\n    val GREENS_8 = arrayOf(\"#f7fcf5\", \"#e5f5e0\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#005a32\")\n    val GREENS_9 = arrayOf(\"#f7fcf5\", \"#e5f5e0\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#006d2c\", \"#00441b\")\n    // Greys\n    val GREYS_3 = arrayOf(\"#f0f0f0\", \"#bdbdbd\", \"#636363\")\n    val GREYS_4 = arrayOf(\"#f7f7f7\", \"#cccccc\", \"#969696\", \"#525252\")\n    val GREYS_5 = arrayOf(\"#f7f7f7\", \"#cccccc\", \"#969696\", \"#636363\", \"#252525\")\n    val GREYS_6 = arrayOf(\"#f7f7f7\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#636363\", \"#252525\")\n    val GREYS_7 = arrayOf(\"#f7f7f7\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\")\n    val GREYS_8 = arrayOf(\"#ffffff\", \"#f0f0f0\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\")\n    val GREYS_9 = arrayOf(\"#ffffff\", \"#f0f0f0\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\", \"#000000\")\n    // Oranges\n    val ORANGES_3 = arrayOf(\"#fee6ce\", \"#fdae6b\", \"#e6550d\")\n    val ORANGES_4 = arrayOf(\"#feedde\", \"#fdbe85\", \"#fd8d3c\", \"#d94701\")\n    val ORANGES_5 = arrayOf(\"#feedde\", \"#fdbe85\", \"#fd8d3c\", \"#e6550d\", \"#a63603\")\n    val ORANGES_6 = arrayOf(\"#feedde\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#e6550d\", \"#a63603\")\n    val ORANGES_7 = arrayOf(\"#feedde\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#8c2d04\")\n    val ORANGES_8 = arrayOf(\"#fff5eb\", \"#fee6ce\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#8c2d04\")\n    val ORANGES_9 = arrayOf(\"#fff5eb\", \"#fee6ce\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#a63603\", \"#7f2704\")\n    // Purples\n    val PURPLES_3 = arrayOf(\"#efedf5\", \"#bcbddc\", \"#756bb1\")\n    val PURPLES_4 = arrayOf(\"#f2f0f7\", \"#cbc9e2\", \"#9e9ac8\", \"#6a51a3\")\n    val PURPLES_5 = arrayOf(\"#f2f0f7\", \"#cbc9e2\", \"#9e9ac8\", \"#756bb1\", \"#54278f\")\n    val PURPLES_6 = arrayOf(\"#f2f0f7\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#756bb1\", \"#54278f\")\n    val PURPLES_7 = arrayOf(\"#f2f0f7\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#4a1486\")\n    val PURPLES_8 = arrayOf(\"#fcfbfd\", \"#efedf5\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#4a1486\")\n    val PURPLES_9 = arrayOf(\"#fcfbfd\", \"#efedf5\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#54278f\", \"#3f007d\")\n    // Reds\n    val REDS_3 = arrayOf(\"#fee0d2\", \"#fc9272\", \"#de2d26\")\n    val REDS_4 = arrayOf(\"#fee5d9\", \"#fcae91\", \"#fb6a4a\", \"#cb181d\")\n    val REDS_5 = arrayOf(\"#fee5d9\", \"#fcae91\", \"#fb6a4a\", \"#de2d26\", \"#a50f15\")\n    val REDS_6 = arrayOf(\"#fee5d9\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#de2d26\", \"#a50f15\")\n    val REDS_7 = arrayOf(\"#fee5d9\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#99000d\")\n    val REDS_8 = arrayOf(\"#fff5f0\", \"#fee0d2\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#99000d\")\n    val REDS_9 = arrayOf(\"#fff5f0\", \"#fee0d2\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#a50f15\", \"#67000d\")\n\n    // single-hue\n    val BLUES = arrayOf(\n        BLUES_3,\n        BLUES_4,\n        BLUES_5,\n        BLUES_6,\n        BLUES_7,\n        BLUES_8,\n        BLUES_9\n    )\n    val GREENS = arrayOf(\n        GREENS_3,\n        GREENS_4,\n        GREENS_5,\n        GREENS_6,\n        GREENS_7,\n        GREENS_8,\n        GREENS_9\n    )\n    val GREYS = arrayOf(\n        GREYS_3,\n        GREYS_4,\n        GREYS_5,\n        GREYS_6,\n        GREYS_7,\n        GREYS_8,\n        GREYS_9\n    )\n    val ORANGES = arrayOf(\n        ORANGES_3,\n        ORANGES_4,\n        ORANGES_5,\n        ORANGES_6,\n        ORANGES_7,\n        ORANGES_8,\n        ORANGES_9\n    )\n    val PURPLES = arrayOf(\n        PURPLES_3,\n        PURPLES_4,\n        PURPLES_5,\n        PURPLES_6,\n        PURPLES_7,\n        PURPLES_8,\n        PURPLES_9\n    )\n    val REDS = arrayOf(\n        REDS_3,\n        REDS_4,\n        REDS_5,\n        REDS_6,\n        REDS_7,\n        REDS_8,\n        REDS_9\n    )\n\n\n    // --------------------\n    // diverging\n    // --------------------\n    // brown - blueGreen\n    val BR_BG_3 = arrayOf(\"#d8b365\", \"#f5f5f5\", \"#5ab4ac\")\n    val BR_BG_4 = arrayOf(\"#a6611a\", \"#dfc27d\", \"#80cdc1\", \"#018571\")\n    val BR_BG_5 = arrayOf(\"#a6611a\", \"#dfc27d\", \"#f5f5f5\", \"#80cdc1\", \"#018571\")\n    val BR_BG_6 = arrayOf(\"#8c510a\", \"#d8b365\", \"#f6e8c3\", \"#c7eae5\", \"#5ab4ac\", \"#01665e\")\n    val BR_BG_7 = arrayOf(\"#8c510a\", \"#d8b365\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#5ab4ac\", \"#01665e\")\n    val BR_BG_8 = arrayOf(\"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\")\n    val BR_BG_9 = arrayOf(\"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\")\n    val BR_BG_10 = arrayOf(\"#543005\", \"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\", \"#003c30\")\n    val BR_BG_11 = arrayOf(\"#543005\", \"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\", \"#003c30\")\n    // pink - yellowGreen\n    val PI_YG_3 = arrayOf(\"#e9a3c9\", \"#f7f7f7\", \"#a1d76a\")\n    val PI_YG_4 = arrayOf(\"#d01c8b\", \"#f1b6da\", \"#b8e186\", \"#4dac26\")\n    val PI_YG_5 = arrayOf(\"#d01c8b\", \"#f1b6da\", \"#f7f7f7\", \"#b8e186\", \"#4dac26\")\n    val PI_YG_6 = arrayOf(\"#c51b7d\", \"#e9a3c9\", \"#fde0ef\", \"#e6f5d0\", \"#a1d76a\", \"#4d9221\")\n    val PI_YG_7 = arrayOf(\"#c51b7d\", \"#e9a3c9\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#a1d76a\", \"#4d9221\")\n    val PI_YG_8 = arrayOf(\"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\")\n    val PI_YG_9 = arrayOf(\"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\")\n    val PI_YG_10 = arrayOf(\"#8e0152\", \"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\", \"#276419\")\n    val PI_YG_11 = arrayOf(\"#8e0152\", \"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\", \"#276419\")\n    // purpleRed - green\n    val PR_GN_3 = arrayOf(\"#af8dc3\", \"#f7f7f7\", \"#7fbf7b\")\n    val PR_GN_4 = arrayOf(\"#7b3294\", \"#c2a5cf\", \"#a6dba0\", \"#008837\")\n    val PR_GN_5 = arrayOf(\"#7b3294\", \"#c2a5cf\", \"#f7f7f7\", \"#a6dba0\", \"#008837\")\n    val PR_GN_6 = arrayOf(\"#762a83\", \"#af8dc3\", \"#e7d4e8\", \"#d9f0d3\", \"#7fbf7b\", \"#1b7837\")\n    val PR_GN_7 = arrayOf(\"#762a83\", \"#af8dc3\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#7fbf7b\", \"#1b7837\")\n    val PR_GN_8 = arrayOf(\"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\")\n    val PR_GN_9 = arrayOf(\"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\")\n    val PR_GN_10 = arrayOf(\"#40004b\", \"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\", \"#00441b\")\n    val PR_GN_11 = arrayOf(\"#40004b\", \"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\", \"#00441b\")\n    // purple - orange\n    val PU_OR_3 = arrayOf(\"#f1a340\", \"#f7f7f7\", \"#998ec3\")\n    val PU_OR_4 = arrayOf(\"#e66101\", \"#fdb863\", \"#b2abd2\", \"#5e3c99\")\n    val PU_OR_5 = arrayOf(\"#e66101\", \"#fdb863\", \"#f7f7f7\", \"#b2abd2\", \"#5e3c99\")\n    val PU_OR_6 = arrayOf(\"#b35806\", \"#f1a340\", \"#fee0b6\", \"#d8daeb\", \"#998ec3\", \"#542788\")\n    val PU_OR_7 = arrayOf(\"#b35806\", \"#f1a340\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#998ec3\", \"#542788\")\n    val PU_OR_8 = arrayOf(\"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\")\n    val PU_OR_9 = arrayOf(\"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\")\n    val PU_OR_10 = arrayOf(\"#7f3b08\", \"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\", \"#2d004b\")\n    val PU_OR_11 = arrayOf(\"#7f3b08\", \"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\", \"#2d004b\")\n    // red - blue\n    val RD_BU_3 = arrayOf(\"#ef8a62\", \"#f7f7f7\", \"#67a9cf\")\n    val RD_BU_4 = arrayOf(\"#ca0020\", \"#f4a582\", \"#92c5de\", \"#0571b0\")\n    val RD_BU_5 = arrayOf(\"#ca0020\", \"#f4a582\", \"#f7f7f7\", \"#92c5de\", \"#0571b0\")\n    val RD_BU_6 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#d1e5f0\", \"#67a9cf\", \"#2166ac\")\n    val RD_BU_7 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#67a9cf\", \"#2166ac\")\n    val RD_BU_8 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\")\n    val RD_BU_9 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\")\n    val RD_BU_10 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\", \"#053061\")\n    val RD_BU_11 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\", \"#053061\")\n    // red - grey\n    val RD_GY_3 = arrayOf(\"#ef8a62\", \"#ffffff\", \"#999999\")\n    val RD_GY_4 = arrayOf(\"#ca0020\", \"#f4a582\", \"#bababa\", \"#404040\")\n    val RD_GY_5 = arrayOf(\"#ca0020\", \"#f4a582\", \"#ffffff\", \"#bababa\", \"#404040\")\n    val RD_GY_6 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#e0e0e0\", \"#999999\", \"#4d4d4d\")\n    val RD_GY_7 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#999999\", \"#4d4d4d\")\n    val RD_GY_8 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\")\n    val RD_GY_9 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\")\n    val RD_GY_10 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\", \"#1a1a1a\")\n    val RD_GY_11 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\", \"#1a1a1a\")\n    // red - yellow - blue\n    val RD_YL_BU_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#91bfdb\")\n    val RD_YL_BU_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#abd9e9\", \"#2c7bb6\")\n    val RD_YL_BU_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#abd9e9\", \"#2c7bb6\")\n    val RD_YL_BU_6 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee090\", \"#e0f3f8\", \"#91bfdb\", \"#4575b4\")\n    val RD_YL_BU_7 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#91bfdb\", \"#4575b4\")\n    val RD_YL_BU_8 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\")\n    val RD_YL_BU_9 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\")\n    val RD_YL_BU_10 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\", \"#313695\")\n    val RD_YL_BU_11 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\", \"#313695\")\n    // red - yellow - green\n    val RD_YL_GN_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#91cf60\")\n    val RD_YL_GN_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#a6d96a\", \"#1a9641\")\n    val RD_YL_GN_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#a6d96a\", \"#1a9641\")\n    val RD_YL_GN_6 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee08b\", \"#d9ef8b\", \"#91cf60\", \"#1a9850\")\n    val RD_YL_GN_7 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#91cf60\", \"#1a9850\")\n    val RD_YL_GN_8 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\")\n    val RD_YL_GN_9 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\")\n    val RD_YL_GN_10 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\", \"#006837\")\n    val RD_YL_GN_11 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\", \"#006837\")\n    // Spectral\n    val SPECTRAL_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#99d594\")\n    val SPECTRAL_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#abdda4\", \"#2b83ba\")\n    val SPECTRAL_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#abdda4\", \"#2b83ba\")\n    val SPECTRAL_6 = arrayOf(\"#d53e4f\", \"#fc8d59\", \"#fee08b\", \"#e6f598\", \"#99d594\", \"#3288bd\")\n    val SPECTRAL_7 = arrayOf(\"#d53e4f\", \"#fc8d59\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#99d594\", \"#3288bd\")\n    val SPECTRAL_8 = arrayOf(\"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\")\n    val SPECTRAL_9 = arrayOf(\"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\")\n    val SPECTRAL_10 = arrayOf(\"#9e0142\", \"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\", \"#5e4fa2\")\n    val SPECTRAL_11 = arrayOf(\"#9e0142\", \"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\", \"#5e4fa2\")\n\n    val BR_BG = arrayOf(\n        BR_BG_3,\n        BR_BG_4,\n        BR_BG_5,\n        BR_BG_6,\n        BR_BG_7,\n        BR_BG_8,\n        BR_BG_9,\n        BR_BG_10,\n        BR_BG_11\n    )\n    val PI_YG = arrayOf(\n        PI_YG_3,\n        PI_YG_4,\n        PI_YG_5,\n        PI_YG_6,\n        PI_YG_7,\n        PI_YG_8,\n        PI_YG_9,\n        PI_YG_10,\n        PI_YG_11\n    )\n    val PR_GN = arrayOf(\n        PR_GN_3,\n        PR_GN_4,\n        PR_GN_5,\n        PR_GN_6,\n        PR_GN_7,\n        PR_GN_8,\n        PR_GN_9,\n        PR_GN_10,\n        PR_GN_11\n    )\n    val PU_OR = arrayOf(\n        PU_OR_3,\n        PU_OR_4,\n        PU_OR_5,\n        PU_OR_6,\n        PU_OR_7,\n        PU_OR_8,\n        PU_OR_9,\n        PU_OR_10,\n        PU_OR_11\n    )\n    val RD_BU = arrayOf(\n        RD_BU_3,\n        RD_BU_4,\n        RD_BU_5,\n        RD_BU_6,\n        RD_BU_7,\n        RD_BU_8,\n        RD_BU_9,\n        RD_BU_10,\n        RD_BU_11\n    )\n    val RD_GY = arrayOf(\n        RD_GY_3,\n        RD_GY_4,\n        RD_GY_5,\n        RD_GY_6,\n        RD_GY_7,\n        RD_GY_8,\n        RD_GY_9,\n        RD_GY_10,\n        RD_GY_11\n    )\n    val RD_YL_BU = arrayOf(\n        RD_YL_BU_3,\n        RD_YL_BU_4,\n        RD_YL_BU_5,\n        RD_YL_BU_6,\n        RD_YL_BU_7,\n        RD_YL_BU_8,\n        RD_YL_BU_9,\n        RD_YL_BU_10,\n        RD_YL_BU_11\n    )\n    val RD_YL_GN = arrayOf(\n        RD_YL_GN_3,\n        RD_YL_GN_4,\n        RD_YL_GN_5,\n        RD_YL_GN_6,\n        RD_YL_GN_7,\n        RD_YL_GN_8,\n        RD_YL_GN_9,\n        RD_YL_GN_10,\n        RD_YL_GN_11\n    )\n    val SPECTRAL = arrayOf(\n        SPECTRAL_3,\n        SPECTRAL_4,\n        SPECTRAL_5,\n        SPECTRAL_6,\n        SPECTRAL_7,\n        SPECTRAL_8,\n        SPECTRAL_9,\n        SPECTRAL_10,\n        SPECTRAL_11\n    )\n\n\n    // ------------------------------\n    // qualitative\n    // ------------------------------\n    // Accent\n    val ACCENT_3 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\")\n    val ACCENT_4 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\")\n    val ACCENT_5 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\")\n    val ACCENT_6 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\")\n    val ACCENT_7 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\", \"#bf5b17\")\n    val ACCENT_8 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\", \"#bf5b17\", \"#666666\")\n    // Dark2\n    val DARK_2_3 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\")\n    val DARK_2_4 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\")\n    val DARK_2_5 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\")\n    val DARK_2_6 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\")\n    val DARK_2_7 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\", \"#a6761d\")\n    val DARK_2_8 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\", \"#a6761d\", \"#666666\")\n    // Paired\n    val PAIRED_3 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\")\n    val PAIRED_4 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\")\n    val PAIRED_5 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\")\n    val PAIRED_6 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\")\n    val PAIRED_7 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\")\n    val PAIRED_8 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\")\n    val PAIRED_9 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\")\n    val PAIRED_10 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\")\n    val PAIRED_11 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\", \"#ffff99\")\n    val PAIRED_12 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\", \"#ffff99\", \"#b15928\")\n    // Pastel1\n    val PASTEL_1_3 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\")\n    val PASTEL_1_4 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\")\n    val PASTEL_1_5 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\")\n    val PASTEL_1_6 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\")\n    val PASTEL_1_7 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\")\n    val PASTEL_1_8 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\", \"#fddaec\")\n    val PASTEL_1_9 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\", \"#fddaec\", \"#f2f2f2\")\n    // Pastel2\n    val PASTEL_2_3 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\")\n    val PASTEL_2_4 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\")\n    val PASTEL_2_5 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\")\n    val PASTEL_2_6 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\")\n    val PASTEL_2_7 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\", \"#f1e2cc\")\n    val PASTEL_2_8 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\", \"#f1e2cc\", \"#cccccc\")\n    // Set1\n    val SET_1_3 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\")\n    val SET_1_4 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\")\n    val SET_1_5 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\")\n    val SET_1_6 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\")\n    val SET_1_7 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\")\n    val SET_1_8 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\", \"#f781bf\")\n    val SET_1_9 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\", \"#f781bf\", \"#999999\")\n    // Set2\n    val SET_2_3 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\")\n    val SET_2_4 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\")\n    val SET_2_5 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\")\n    val SET_2_6 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\")\n    val SET_2_7 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\", \"#e5c494\")\n    val SET_2_8 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\", \"#e5c494\", \"#b3b3b3\")\n    // Set3\n    val SET_3_3 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\")\n    val SET_3_4 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\")\n    val SET_3_5 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\")\n    val SET_3_6 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\")\n    val SET_3_7 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\")\n    val SET_3_8 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\")\n    val SET_3_9 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\")\n    val SET_3_10 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\")\n    val SET_3_11 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\", \"#ccebc5\")\n    val SET_3_12 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\", \"#ccebc5\", \"#ffed6f\")\n\n    val ACCENT = arrayOf(\n        ACCENT_3,\n        ACCENT_4,\n        ACCENT_5,\n        ACCENT_6,\n        ACCENT_7,\n        ACCENT_8\n    )\n    val DARK_2 = arrayOf(\n        DARK_2_3,\n        DARK_2_4,\n        DARK_2_5,\n        DARK_2_6,\n        DARK_2_7,\n        DARK_2_8\n    )\n    val PAIRED = arrayOf(\n        PAIRED_3,\n        PAIRED_4,\n        PAIRED_5,\n        PAIRED_6,\n        PAIRED_7,\n        PAIRED_8,\n        PAIRED_9,\n        PAIRED_10,\n        PAIRED_11,\n        PAIRED_12\n    )\n    val PASTEL_1 = arrayOf(\n        PASTEL_1_3,\n        PASTEL_1_4,\n        PASTEL_1_5,\n        PASTEL_1_6,\n        PASTEL_1_7,\n        PASTEL_1_8,\n        PASTEL_1_9\n    )\n    val PASTEL_2 = arrayOf(\n        PASTEL_2_3,\n        PASTEL_2_4,\n        PASTEL_2_5,\n        PASTEL_2_6,\n        PASTEL_2_7,\n        PASTEL_2_8\n    )\n    val SET_1 = arrayOf(\n        SET_1_3,\n        SET_1_4,\n        SET_1_5,\n        SET_1_6,\n        SET_1_7,\n        SET_1_8,\n        SET_1_9\n    )\n    val SET_2 = arrayOf(\n        SET_2_3,\n        SET_2_4,\n        SET_2_5,\n        SET_2_6,\n        SET_2_7,\n        SET_2_8\n    )\n    val SET_3 = arrayOf(\n        SET_3_3,\n        SET_3_4,\n        SET_3_5,\n        SET_3_6,\n        SET_3_7,\n        SET_3_8,\n        SET_3_9,\n        SET_3_10,\n        SET_3_11,\n        SET_3_12\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.values.Color\n\nobject ColorUtil {\n    fun genColors(count: Int, baseColors: List<Color>): List<Color> {\n        val rValues = ArrayList<Int>()\n        val gValues = ArrayList<Int>()\n        val bValues = ArrayList<Int>()\n        for (baseColor in baseColors) {\n            rValues.add(baseColor.red)\n            gValues.add(baseColor.green)\n            bValues.add(baseColor.blue)\n        }\n        val rChannelGen = RGBChannelGen(rValues)\n        val gChannelGen = RGBChannelGen(gValues)\n        val bChannelGen = RGBChannelGen(bValues)\n\n        val rValuesGen = rChannelGen.generate(count).iterator()\n        val gValuesGen = gChannelGen.generate(count).iterator()\n        val bValuesGen = bChannelGen.generate(count).iterator()\n\n        val colorsGen = ArrayList<Color>(count)\n        while (rValuesGen.hasNext() && gValuesGen.hasNext() && bValuesGen.hasNext()) {\n            val colorGen = Color(rValuesGen.next(), gValuesGen.next(), bValuesGen.next())\n            colorsGen.add(colorGen)\n        }\n\n        return colorsGen\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.concat\nimport jetbrains.datalore.base.values.Color\n\nobject PaletteUtil {\n    val NULL_COLOR = Color.LIGHT_GRAY\n\n    private val EXTENSIBLE_COLOR_SCHEMES: Set<ColorScheme> = setOf(\n        ColorPalette.Qualitative.Accent,\n        ColorPalette.Qualitative.Dark2,\n        ColorPalette.Qualitative.Pastel1,\n        ColorPalette.Qualitative.Pastel2,\n        ColorPalette.Qualitative.Set1,\n        ColorPalette.Qualitative.Set2,\n        ColorPalette.Qualitative.Set3\n    )\n\n    private val PAL_TYPE_BY_PAL_NAME: Map<String, ColorPalette.Type>\n\n    init {\n        val map = HashMap<String, ColorPalette.Type>()\n        ColorPalette.Sequential.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.SEQUENTIAL\n        }\n        ColorPalette.Diverging.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.DIVERGING\n        }\n        ColorPalette.Qualitative.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.QUALITATIVE\n        }\n\n        PAL_TYPE_BY_PAL_NAME = map\n    }\n\n    private fun isExtensibleScheme(colorScheme: ColorScheme): Boolean {\n        return EXTENSIBLE_COLOR_SCHEMES.contains(colorScheme)\n    }\n\n    fun schemeColors(colorScheme: ColorScheme, colorCount: Int): List<Color> {\n        val colorsHex = colorScheme.getColors(colorCount)\n        val colors = fromColorsHex(colorsHex)\n        if (colorsHex.size < colorCount && isExtensibleScheme(\n                colorScheme\n            )\n        ) {\n            val addColors =\n                ColorUtil.genColors(colorCount - colorsHex.size, colors)\n            return Iterables.toList(concat(colors, addColors))\n        }\n        return colors\n    }\n\n    private fun fromColorsHex(hexColors: Array<String>): List<Color> {\n        val colors = ArrayList<Color>()\n        for (hexColor in hexColors) {\n            try {\n                colors.add(Color.parseHex(hexColor))\n            } catch (e: Exception) {\n                // ignore this value\n            }\n\n        }\n        return colors\n    }\n\n    fun paletteTypeByPaletteName(paletteName: String): ColorPalette.Type? =\n        PAL_TYPE_BY_PAL_NAME[paletteName]\n\n    fun colorSchemeByIndex(paletteType: ColorPalette.Type, index: Int): ColorScheme {\n        @Suppress(\"UNCHECKED_CAST\")\n        val values: Array<ColorScheme> = when (paletteType) {\n            ColorPalette.Type.SEQUENTIAL -> ColorPalette.Sequential.values() as Array<ColorScheme>\n            ColorPalette.Type.DIVERGING -> ColorPalette.Diverging.values() as Array<ColorScheme>\n            ColorPalette.Type.QUALITATIVE -> ColorPalette.Qualitative.values() as Array<ColorScheme>\n        }\n\n        return values[index % values.size]\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass RGBChannelGen(private val myBaseValues: List<Int>) {\n    private var myRange: ClosedRange<Int>? = null\n\n    init {\n        val min = natural<Int>().min(myBaseValues)\n        val max = natural<Int>().max(myBaseValues)\n        for (r in RANGES) {\n            if (r.contains(min) || r.contains(max)) {\n                if (myRange == null) {\n                    myRange = r\n                } else {\n                    myRange = myRange!!.span(r)\n                }\n            }\n        }\n    }\n\n    /**\n     * @param maxCount - count of new values required\n     * @return List of generated value, size may be different than maxCount\n     */\n    fun generate(maxCount: Int): List<Int> {\n        var genPerBaseValue = ceil(maxCount.toDouble() / myBaseValues.size).toInt()\n        genPerBaseValue = min(maxValueCount() - 1, genPerBaseValue)\n\n        var inc = floor(maxValueCount().toDouble() / (genPerBaseValue + 1)).toInt()\n        // make increment a bit less regular\n        inc = max(1, (inc * 1.33).toInt())\n\n        val values = ArrayList<Int>(maxCount)\n        var baseValues = myBaseValues\n        while (values.size < maxCount) {\n            val nextBaseValues = ArrayList<Int>()\n            for (baseValue in baseValues) {\n                var genValue = baseValue + inc\n                if (!myRange!!.contains(genValue)) {\n                    genValue = myRange!!.lowerEnd + (genValue - myRange!!.upperEnd)\n                }\n                values.add(genValue)\n                nextBaseValues.add(genValue)\n                if (values.size == maxCount) {\n                    break\n                }\n            }\n\n            baseValues = nextBaseValues\n        }\n\n        return values\n    }\n\n    private fun maxValueCount(): Int {\n        return myRange!!.upperEnd - myRange!!.lowerEnd + 1\n    }\n\n    companion object {\n        private val RANGES = arrayOf(\n                ClosedRange(0, 37),\n                ClosedRange(38, 97),\n                ClosedRange(98, 157),\n                ClosedRange(158, 217),\n                ClosedRange(218, 255)\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nenum class DataType {\n    NUMBER,\n    STRING,\n    INSTANT,\n\n    /**\n     * INSTANT_OF_DAY and INSTANT_OF_MONTH are INSTANTS formatted as year-month-day or year-month\n     */\n    INSTANT_OF_DAY,\n    INSTANT_OF_MONTH,\n    INSTANT_OF_QUARTER,\n    INSTANT_OF_HALF_YEAR,\n    INSTANT_OF_YEAR;\n\n\n    val isTime: Boolean\n        get() = this == INSTANT || isTimeInterval\n\n    val isTimeInterval: Boolean\n        get() = (this == INSTANT_OF_DAY\n                || this == INSTANT_OF_MONTH\n                || this == INSTANT_OF_QUARTER\n                || this == INSTANT_OF_HALF_YEAR\n                || this == INSTANT_OF_YEAR)\n\n    val isString: Boolean\n        get() = this == STRING\n\n    val isNumber: Boolean\n        get() = this == NUMBER\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isFinite\nimport kotlin.math.abs\n\nabstract class RegularMeshDetector protected constructor(private val myError: Double) {\n    open var isMesh: Boolean = false\n        protected set\n    var resolution: Double = 0.toDouble()\n        get() {\n            check(isMesh) { \"Not a mesh\" }\n            return field\n        }\n        protected set\n\n    protected fun equalsEnough(d1: Double, d2: Double): Boolean {\n        return d1 == d2 || abs(d1 - d2) <= myError\n    }\n\n    protected fun nearZero(d: Double): Boolean {\n        return abs(d) <= myError\n    }\n\n\n    private class MyRowDetector internal constructor(\n        private val myMinRowSize: Int,\n        error: Double,\n        values: Iterable<Double?>\n    ) : RegularMeshDetector(error) {\n\n        init {\n            init(values)\n        }\n\n        private fun init(values: Iterable<Double?>) {\n            // check if first N elements are equally spaced\n            isMesh = false\n            var distance = 0.0\n            var distanceInitialized = false\n            var prevValue: Double? = null\n            var count = myMinRowSize\n            for (value in values) {\n                if (!isFinite(value)) {\n                    return\n                }\n                if (prevValue != null) {\n                    val dist = value!! - prevValue\n                    if (nearZero(dist)) {\n                        return\n                    }\n                    if (distanceInitialized) {\n                        if (!equalsEnough(dist, distance)) {\n                            return\n                        }\n                    } else {\n                        distance = dist\n                        distanceInitialized = true\n                    }\n                }\n\n                prevValue = value\n                if (--count == 0) {\n                    break\n                }\n            }\n\n            if (distanceInitialized && count == 0) {\n                resolution = abs(distance)\n                isMesh = true\n            }\n        }\n    }\n\n    private class MyColumnDetector internal constructor(\n        private val myMinRowSize: Int,\n        error: Double,\n        values: Iterable<Double?>\n    ) : RegularMeshDetector(error) {\n\n        init {\n            init(values)\n        }\n\n        private fun init(values: Iterable<Double?>) {\n            // check if there are at least 2 sets of elements where:\n            // 1. sets are equal in size;\n            // 2. all elements in each set are equal\n            isMesh = false\n            val rowSize = intArrayOf(0, 0)\n            val rowValue = arrayOf<Double?>(null, null)\n            var rowIndex = 0\n            for (value in values) {\n                if (!isFinite(value)) {\n                    break\n                }\n                if (rowValue[rowIndex] == null) {\n                    rowValue[rowIndex] = value\n                    rowSize[rowIndex]++\n                } else if (equalsEnough(rowValue[rowIndex]!!, value!!)) {\n                    rowSize[rowIndex]++\n                } else {\n                    if (rowIndex == 0) {\n                        rowIndex++ // next row\n                        rowValue[rowIndex] = value\n                        rowSize[rowIndex]++\n                    } else {\n                        break\n                    }\n                }\n            }\n\n            // check results\n            if (rowSize[0] == rowSize[1] && rowSize[0] >= myMinRowSize) {\n                isMesh = true\n                resolution = abs(rowValue[1]!! - rowValue[0]!!)\n            }\n        }\n    }\n\n    companion object {\n        private val NO_MESH: RegularMeshDetector = object : RegularMeshDetector(0.0) {\n            override var isMesh: Boolean\n                get() = false\n                set(value: Boolean) {\n                    super.isMesh = value\n                }\n        }\n\n        fun tryRow(values: Iterable<Double?>): RegularMeshDetector {\n            // choose 'error' value\n            val v0 = Iterables[values, 0, null]\n            val v1 = Iterables[values, 1, null]\n            if (v0 == null || v1 == null) {\n                return NO_MESH\n            }\n            val delta = abs(v1 - v0)\n            if (!delta.isFinite()) {\n                return NO_MESH\n            }\n            val error = delta / 10000.0\n            return tryRow(50, error, values)\n        }\n\n        fun tryRow(minRowSize: Int, error: Double, values: Iterable<Double?>): RegularMeshDetector {\n            return MyRowDetector(minRowSize, error, values)\n        }\n\n        fun tryColumn(values: Iterable<Double?>): RegularMeshDetector {\n            return tryColumn(\n                50,\n                SeriesUtil.TINY,\n                values\n            )\n        }\n\n        fun tryColumn(minRowSize: Int, error: Double, values: Iterable<Double?>): RegularMeshDetector {\n            return MyColumnDetector(minRowSize, error, values)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.all\nimport jetbrains.datalore.base.gcommon.collect.Iterables.filter\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport kotlin.math.max\nimport kotlin.math.min\n\n\nobject SeriesUtil {\n    const val TINY = 1e-50\n\n    private val REAL_NUMBER = { it: Double? -> isFinite(it) }\n\n    val NEGATIVE_NUMBER = { input: Double -> input < 0 }\n\n    fun isSubTiny(value: Double): Boolean {\n        return value < TINY\n    }\n\n    fun isSubTiny(range: ClosedRange<Double>): Boolean {\n        return isFinite(range) && span(range) < TINY\n    }\n\n    fun checkedDoubles(values: Iterable<*>): CheckedDoubleIterable {\n        return CheckedDoubleIterable(values)\n    }\n\n    fun checkedDoubles(values: List<*>): CheckedDoubleList {\n        return CheckedDoubleList(values)\n    }\n\n    fun isFinite(v: Double?): Boolean {\n        return v != null && v.isFinite()\n    }\n\n    fun asFinite(v: Double?, defaultValue: Double): Double {\n        return if (v != null && v.isFinite())\n            v\n        else\n            defaultValue\n    }\n\n    fun isFinite(v: Double): Boolean {\n        return v.isFinite()\n    }\n\n    fun allFinite(v0: Double?, v1: Double?): Boolean {\n        return isFinite(v0) && isFinite(v1)\n    }\n\n    fun allFinite(v0: Double?, v1: Double?, v2: Double?): Boolean {\n        return allFinite(\n            v0,\n            v1\n        ) && isFinite(v2)\n    }\n\n    fun allFinite(v0: Double?, v1: Double?, v2: Double?, v3: Double?): Boolean {\n        return allFinite(\n            v0,\n            v1,\n            v2\n        ) && isFinite(v3)\n    }\n\n    fun filterFinite(l0: List<Double?>, l1: List<Double?>): List<List<Double>> {\n        check(l0.size == l1.size)\n\n        val l0Copy = ArrayList<Double>()\n        val l1Copy = ArrayList<Double>()\n        var copy = false\n        for ((i, v0) in l0.withIndex()) {\n            val v1 = l1[i]\n            if (!allFinite(v0, v1)) {\n                if (!copy) {\n                    // copy already checked elements\n                    @Suppress(\"UNCHECKED_CAST\")\n                    l0Copy.addAll(l0.take(i).toList() as List<Double>)\n                    @Suppress(\"UNCHECKED_CAST\")\n                    l1Copy.addAll(l1.take(i).toList() as List<Double>)\n                    copy = true\n                }\n                continue\n            }\n\n            if (copy) {\n                l0Copy.add(v0 as Double)\n                l1Copy.add(v1 as Double)\n            }\n        }\n\n        @Suppress(\"UNCHECKED_CAST\")\n        return when (copy) {\n            true -> listOf(l0Copy, l1Copy)\n            false -> listOf(l0 as List<Double>, l1 as List<Double>)\n        }\n    }\n\n    fun range(values: Iterable<Double?>): ClosedRange<Double>? {\n        var min = 0.0\n        var max = 0.0\n        var inited = false\n        for (v in values) {\n            if (isFinite(v)) {\n                if (inited) {\n                    min = min(min, v!!)\n                    max = max(max, v)\n                } else {\n                    max = v!!\n                    min = max\n                    inited = true\n                }\n            }\n        }\n        return if (inited)\n            ClosedRange(min, max)\n        else\n            null\n    }\n\n    fun resolution(values: Iterable<Double?>, naValue: Double): Double {\n\n        // check if this is a row of a regular grid\n        val rowDetector = RegularMeshDetector.tryRow(values)\n        if (rowDetector.isMesh) {\n            return rowDetector.resolution\n        }\n\n        // check if this is a column of a regular grid\n        val columnDetector = RegularMeshDetector.tryColumn(values)\n        return if (columnDetector.isMesh) {\n            columnDetector.resolution\n        } else {\n            // use brut force method to find data resolution\n            resolutionFullScan(values, naValue)\n        }\n    }\n\n    private fun resolutionFullScan(values: Iterable<Double?>, naValue: Double): Double {\n        @Suppress(\"UNCHECKED_CAST\")\n        val goodDataVector = filter(values, REAL_NUMBER) as Iterable<Double>\n        if (Iterables.isEmpty(goodDataVector)) {\n            return naValue\n        }\n\n        val copy = Ordering.natural<Double>().sortedCopy(goodDataVector)\n        if (copy.size < 2) {\n            return naValue\n        }\n\n        val it = copy.iterator()\n        var resolution = naValue\n        var allZero = true\n        var prev = it.next()\n        while (it.hasNext()) {\n            val curr = it.next()\n            val dist = curr - prev\n            if (dist > 0 && (dist < resolution || allZero)) {\n                allZero = false\n                resolution = dist\n            }\n\n            prev = curr\n        }\n\n        return resolution\n    }\n\n    /**\n     * ToDo: Use with caution.\n     * ToDo: The correct method of domain validation is temporarily in 'PlotConfigUtil.ensureApplicableDomain'.\n     */\n    fun ensureApplicableRange(range: ClosedRange<Double>?): ClosedRange<Double> {\n        if (range == null) {\n            return ClosedRange(-0.5, 0.5)\n        }\n        if (isSubTiny(range)) {\n            val median = range.lowerEnd\n            return ClosedRange(median - 0.5, median + 0.5)\n        }\n        return range\n    }\n\n    fun span(range: ClosedRange<Double>): Double {\n        require(isFinite(range)) { \"range must be finite: $range\" }\n        return range.upperEnd - range.lowerEnd\n    }\n\n    fun span(range0: ClosedRange<Double>?, range1: ClosedRange<Double>?): ClosedRange<Double>? {\n        if (range0 == null) return range1\n        return if (range1 == null) range0 else range0.span(range1)\n    }\n\n    fun expand(range: ClosedRange<Double>, newSpan: Double): ClosedRange<Double> {\n        val expand = (newSpan - span(range)) / 2\n        return expand(range, expand, expand)\n    }\n\n    fun expand(range: ClosedRange<Double>, lowerExpand: Double, upperExpand: Double): ClosedRange<Double> {\n        return ClosedRange(range.lowerEnd - lowerExpand, range.upperEnd + upperExpand)\n    }\n\n    fun isFinite(range: ClosedRange<Double>): Boolean {\n        return !(range.lowerEnd.isInfinite() || range.upperEnd.isInfinite())\n    }\n\n    fun matchingIndices(list: List<*>, matchedValue: Any?): MutableList<Int> {\n        val result = ArrayList<Int>()\n        for (i in list.indices) {\n            if (matchedValue == list[i]) {\n                result.add(i)\n            }\n        }\n        return result\n    }\n\n    fun matchingIndices(list: List<*>, matchedValues: Set<*>): List<Int> {\n        val result = ArrayList<Int>()\n        for (i in list.indices) {\n            if (matchedValues.contains(list[i])) {\n                result.add(i)\n            }\n        }\n        return result\n    }\n\n    fun <T> pickAtIndices(list: List<T>, indices: List<Int>): List<T> {\n        val initialCapacity = if (indices.size > 10) indices.size else 10\n        val result = ArrayList<T>(initialCapacity)\n        for (index in indices) {\n            if (index < list.size) {\n                result.add(list[index])\n            }\n        }\n        return result\n    }\n\n    fun <T> pickAtIndices(list: List<T>, indices: Set<Int>): List<T> {\n        val result = ArrayList<T>(list.size)\n        for (i in list.indices) {\n            if (indices.contains(i)) {\n                result.add(list[i])\n            }\n        }\n        return result\n    }\n\n    fun <T> skipAtIndices(list: List<T>, indices: Set<Int>): List<T> {\n        val result = ArrayList<T>(list.size)\n        for (i in list.indices) {\n            if (!indices.contains(i)) {\n                result.add(list[i])\n            }\n        }\n        return result\n    }\n\n    fun <T> firstNotNull(list: List<T>, defaultValue: T): T {\n        for (v in list) {\n            if (v != null) {\n                return v\n            }\n        }\n        return defaultValue\n    }\n\n    fun mean(values: List<Double?>, defaultValue: Double?): Double? {\n        var result = 0.0\n        var i = -1.0\n        for (value in values) {\n            if (value != null && value.isFinite()) {\n                i++\n                result = value / (i + 1) + result * (i / (i + 1))\n            }\n        }\n        return if (i >= 0) result else defaultValue\n    }\n\n    fun sum(values: List<Double?>): Double {\n        var result = 0.0\n        for (value in values) {\n            if (value != null && value.isFinite()) {\n                result += value\n            }\n        }\n        return result\n    }\n\n    fun toDoubleList(l: List<*>?): List<Double?>? {\n        return if (l == null)\n            null\n        else\n            CheckedDoubleList(l).cast()\n    }\n\n    class CheckedDoubleList(list: List<*>) : CheckedDoubleIterable(list) {\n\n        override fun cast(): List<Double?> {\n            return super.cast() as List<Double?>\n        }\n    }\n\n    open class CheckedDoubleIterable(private val myIterable: Iterable<*>) {\n        private val myEmpty: Boolean = Iterables.isEmpty(myIterable)\n        private val myCanBeCast: Boolean\n\n        init {\n            myCanBeCast = if (myEmpty) {\n                true\n            } else {\n                all(filter(myIterable) { it != null }) { input -> input is Double }\n            }\n        }\n\n        fun notEmptyAndCanBeCast(): Boolean {\n            return !myEmpty && myCanBeCast\n        }\n\n        fun canBeCast(): Boolean {\n            return myCanBeCast\n        }\n\n        open fun cast(): Iterable<Double?> {\n            check(myCanBeCast) { \"Can't cast to a collection of Double(s)\" }\n            // Safe cast: all values were checked\n            @Suppress(\"UNCHECKED_CAST\")\n            return myIterable as Iterable<Double?>\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.Stack\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier.RankingStrategy\n\ninternal class DouglasPeuckerSimplification : RankingStrategy {\n    private val myEpsilon = Double.MIN_VALUE\n\n    private fun calculateWeights(points: List<DoubleVector>): List<Double> {\n        val stack = Stack<Pair<Int, Int>>()\n\n        val weights = MutableList(points.size) { Double.NaN }\n        weights[0] = Double.MAX_VALUE\n        weights[points.size - 1] = Double.MAX_VALUE\n        stack.push(Pair(0, points.size - 1))\n\n        while (!stack.empty()) {\n            val startIndex = stack.peek()!!.first\n            val endIndex = stack.peek()!!.second\n            stack.pop()\n\n            var dMax = 0.0\n            var index = startIndex\n            val doubleSegment = DoubleSegment(points[startIndex], points[endIndex])\n            val distance: (DoubleVector) -> Double\n\n            if (doubleSegment.length() == 0.0) {\n                distance = { p -> DoubleSegment(points[startIndex], p).length() }\n            } else {\n                distance = { doubleSegment.distance(it) }\n            }\n\n            var i = startIndex + 1\n            while (i < endIndex) {\n                val d = distance(points[i])\n                if (d > dMax) {\n                    index = i\n                    dMax = d\n                }\n                ++i\n            }\n\n            if (dMax >= myEpsilon) {\n                stack.push(Pair(startIndex, index))\n                stack.push(Pair(index, endIndex))\n                weights[index] = dMax\n            }\n        }\n\n        return weights\n    }\n\n    override fun getWeights(points: List<DoubleVector>): List<Double> {\n        return calculateWeights(points)\n    }\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\n\nclass PolylineSimplifier private constructor(private val myPoints: List<DoubleVector>, strategy: RankingStrategy) {\n    private val myWeights: List<Double>\n    private var myWeightLimit = Double.NaN\n    private var myCountLimit = -1\n\n    val points: List<DoubleVector>\n        get() =\n            indices.map { myPoints[it] }\n\n    val indices: List<Int>\n        get() {\n            val sorted = (0 until myPoints.size)\n                    .map { i -> Pair(i, myWeights[i]) }\n                    .filter { p -> !getWeight(p).isNaN() }\n                    .sortedWith(compareBy<Pair<Int, Double>> { this.getWeight(it) }.reversed())\n\n            val filtered: Collection<Pair<Int, Double>>\n            if (isWeightLimitSet) {\n                filtered = sorted.filter { p -> getWeight(p) > myWeightLimit }\n            } else {\n                filtered = sorted.take(myCountLimit)\n            }\n\n            return filtered\n                    .map { this.getIndex(it) }\n                    .sorted()\n        }\n\n    private val isWeightLimitSet: Boolean\n        get() = !myWeightLimit.isNaN()\n\n    init {\n        myWeights = strategy.getWeights(myPoints)\n    }\n\n    fun setWeightLimit(weightLimit: Double): PolylineSimplifier {\n        myWeightLimit = weightLimit\n        myCountLimit = -1\n        return this\n    }\n\n    fun setCountLimit(countLimit: Int): PolylineSimplifier {\n        myWeightLimit = Double.NaN\n        myCountLimit = countLimit\n        return this\n    }\n\n    private fun getWeight(p: Pair<Int, Double>): Double {\n        return p.second\n    }\n\n    private fun getIndex(p: Pair<Int, Double>): Int {\n        return p.first\n    }\n\n    interface RankingStrategy {\n        fun getWeights(points: List<DoubleVector>): List<Double>\n    }\n\n    companion object {\n\n        fun visvalingamWhyatt(points: List<DoubleVector>): PolylineSimplifier {\n            return PolylineSimplifier(\n                points,\n                VisvalingamWhyattSimplification()\n            )\n        }\n\n        fun douglasPeucker(points: List<DoubleVector>): PolylineSimplifier {\n            return PolylineSimplifier(\n                points,\n                DouglasPeuckerSimplification()\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier.RankingStrategy\nimport kotlin.math.abs\n\n\n// Reference: https://bost.ocks.org/mike/simplify/\ninternal class VisvalingamWhyattSimplification : RankingStrategy {\n    private val myVerticesToRemove = ArrayList<Int>()\n    private var myTriangles: MutableList<Triangle>? = null\n\n    private val isSimplificationDone: Boolean\n        get() = isEmpty\n\n    private val isEmpty: Boolean\n        get() = myTriangles!!.isEmpty()\n\n    override fun getWeights(points: List<DoubleVector>): List<Double> {\n        myTriangles = ArrayList(points.size - 2)\n        initTriangles(points)\n        val weights = MutableList(points.size) { INITIAL_AREA }\n        var lastRemovedVertexArea = 0.0\n        while (!isSimplificationDone) {\n            val triangle = takeTriangle()\n\n            lastRemovedVertexArea = if (triangle.area > lastRemovedVertexArea)\n                triangle.area\n            else\n                lastRemovedVertexArea\n\n            weights[triangle.currentVertex] = lastRemovedVertexArea\n\n            val next = triangle.next\n            if (next != null) {\n                next.takePrevFrom(triangle)\n                update(next)\n            }\n\n            val prev = triangle.prev\n            if (prev != null) {\n                prev.takeNextFrom(triangle)\n                update(prev)\n            }\n\n            myVerticesToRemove.add(triangle.currentVertex)\n        }\n\n        return weights\n    }\n\n    private fun initTriangles(points: List<DoubleVector>) {\n        val triangles = ArrayList<Triangle>(points.size - 2)\n\n        run {\n            var i = 1\n            val n = points.size - 1\n            while (i < n) {\n                triangles.add(\n                    Triangle(\n                        i,\n                        points\n                    )\n                )\n                ++i\n            }\n        }\n\n        var i = 1\n        val n = triangles.size - 1\n        while (i < n) {\n            triangles[i].next = triangles[i + 1]\n            triangles[i].prev = triangles[i - 1]\n            i++\n        }\n\n        triangles.forEach { this.add(it) }\n    }\n\n    private fun takeTriangle(): Triangle {\n        val minimalTriangle = poll()\n        myVerticesToRemove.add(minimalTriangle.currentVertex)\n        return minimalTriangle\n    }\n\n    private fun add(triangle: Triangle) {\n        val index = getIndex(triangle)\n        myTriangles!!.add(index, triangle)\n    }\n\n    private fun getIndex(triangle: Triangle): Int {\n        var index = myTriangles!!.binarySearch(triangle, compareBy { it.area })\n        if (index < 0) {\n            index = index.inv()\n        }\n        return index\n    }\n\n    private fun peek(): Triangle {\n        return myTriangles!![0]\n    }\n\n    private fun poll(): Triangle {\n        val triangle = peek()\n        myTriangles!!.remove(triangle)\n        return triangle\n    }\n\n    private fun update(triangle: Triangle) {\n        myTriangles!!.remove(triangle)\n        myTriangles!!.add(triangle)\n    }\n\n    private class Triangle internal constructor(val currentVertex: Int, private val myPoints: List<DoubleVector>) {\n        var area: Double = 0.toDouble()\n            private set\n        private var prevVertex: Int = 0\n        private var nextVertex: Int = 0\n        var prev: Triangle? = null\n        var next: Triangle? = null\n\n        init {\n            prevVertex = currentVertex - 1\n            nextVertex = currentVertex + 1\n            area = calculateArea()\n        }\n\n        internal fun takeNextFrom(triangle: Triangle) {\n            next = triangle.next\n            nextVertex = triangle.nextVertex\n            area = calculateArea()\n        }\n\n        internal fun takePrevFrom(triangle: Triangle) {\n            prev = triangle.prev\n            prevVertex = triangle.prevVertex\n            area = calculateArea()\n        }\n\n        private fun calculateArea(): Double {\n            val a = myPoints[prevVertex]\n            val b = myPoints[currentVertex]\n            val c = myPoints[nextVertex]\n\n            return abs(((b.x - a.x) * (c.y - a.y) - (c.x - a.x) * (b.y - a.y)) / 2.0)\n        }\n    }\n\n    companion object {\n\n        private val INITIAL_AREA = Double.MAX_VALUE\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.text\n\nimport jetbrains.datalore.base.dateFormat.Format\nimport jetbrains.datalore.base.datetime.Instant\nimport jetbrains.datalore.base.datetime.tz.TimeZone\n\nobject DateTimeFormatUtil {\n    fun formatDateUTC(instant: Number, pattern: String): String {\n        val format = Format(pattern)\n        return instant.toLong()\n            .let(::Instant)\n            .let(TimeZone.UTC::toDateTime)\n            .let(format::apply)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.text\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\nimport jetbrains.datalore.plot.common.data.DataType\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\n\nobject Formatter {\n    private const val YEAR = \"%b %Y\"\n    private const val YEAR_QUARTER = \"Q %y\"\n    private const val YEAR_MONTH = \"%B %Y\"\n    private const val DATE_MEDIUM = \"%a, %b %e, %Y\"\n    private const val DATE_MEDIUM_TIME_SHORT = \"%a, %b %e, %Y %l:%M %p\"\n\n    private val DEF_NUMBER_FORMAT = NumberFormat(\",g\")\n\n    private val DEF_NUMBER_FORMATTER: (Any) -> String = { input ->\n        DEF_NUMBER_FORMAT.apply(input as Number)\n    }\n\n    fun time(pattern: String): (Any) -> String = { input ->\n        DateTimeFormatUtil.formatDateUTC(\n            input as Number,\n            pattern\n        )\n    }\n\n//    @JvmOverloads\n//    fun number(pattern: String): (Any) -> String = { input ->\n//        var result = \"NaN\"\n//        if (input is Number) {\n//            result = NumberFormatUtil.formatNumber(input, pattern)\n//        }\n//        result\n//    }\n\n//    fun legend(dataType: DataType): (Any?) -> String {\n//        return tooltip(dataType)\n//    }\n\n    // ToDo: remove - only used in tests (?)\n    fun tooltip(dataType: DataType): (Any?) -> String {\n        return nullable(\n            tooltipImpl(\n                dataType\n            ), \"null\"\n        )\n    }\n\n    private fun tooltipImpl(dataType: DataType): (Any) -> String {\n        return when (dataType) {\n            DataType.NUMBER -> DEF_NUMBER_FORMATTER\n            DataType.STRING -> { it -> it.toString() } // no formatting really (toSting)\n            DataType.INSTANT -> time(\n                DATE_MEDIUM_TIME_SHORT\n            )\n            DataType.INSTANT_OF_DAY -> time(\n                DATE_MEDIUM\n            )\n            DataType.INSTANT_OF_MONTH -> time(\n                YEAR_MONTH\n            )\n            DataType.INSTANT_OF_QUARTER, DataType.INSTANT_OF_HALF_YEAR -> time(\n                YEAR_QUARTER\n            )\n            DataType.INSTANT_OF_YEAR -> time(\n                YEAR\n            )\n        }\n    }\n\n    // ToDo: remove - only used in tests (?)\n    fun tableCell(dataType: DataType): (Any?) -> String {\n        return tableCell(dataType, \"null\")\n    }\n\n    private fun tableCell(dataType: DataType, nullString: String): (Any?) -> String {\n        return nullable(\n            tableCellImpl(\n                dataType\n            ), nullString\n        )\n    }\n\n    private fun tableCellImpl(dataType: DataType): (Any) -> String {\n        when (dataType) {\n            DataType.NUMBER -> return DEF_NUMBER_FORMATTER\n            DataType.STRING -> return { it.toString() } // no formatting really (toSting)\n            DataType.INSTANT -> return time(\"%a, %b %e, '%y\")\n            else -> if (dataType.isTimeInterval) {\n                val timeInterval = TimeInterval.fromIntervalDataType(dataType)\n                return timeInterval.tickFormatter\n            }\n        }\n\n        throw IllegalArgumentException(\"Can't create formatter for data type $dataType\")\n    }\n\n    private fun nullable(f: (Any) -> String, nullString: String): (Any?) -> String = { input ->\n        if (input == null) nullString else f(input)\n    }\n\n//    fun ordinalSeries(dataType: DataType): (Any?) -> String {\n//        return tableCell(dataType)\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Instant\nimport jetbrains.datalore.base.datetime.tz.TimeZone\nimport kotlin.math.roundToLong\n\nobject TimeUtil {\n    fun asDateTimeUTC(instant: Double): DateTime {\n        try {\n            return TimeZone.UTC.toDateTime(Instant(instant.roundToLong()))\n        } catch (ignored: RuntimeException) {\n            throw IllegalArgumentException(\"Can't create DateTime from instant $instant\")\n        }\n\n    }\n\n    fun asInstantUTC(dateTime: DateTime): Long {\n        return TimeZone.UTC.toInstant(dateTime).timeSinceEpoch\n    }\n\n    fun yearStart(year: Int): DateTime {\n        return DateTime(Date.firstDayOf(year))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Duration\nimport kotlin.math.ceil\n\ninternal class DurationInterval(private val myDuration: Duration, count: Int) : TimeInterval(count) {\n\n    override// milliseconds\n    // fractional seconds\n    // seconds\n    // minutes\n    // hours\n    // days\n    // weeks\n    val tickFormatPattern: String\n        get() {\n            val duration = myDuration.duration\n            if (duration < Duration.SECOND.duration) {\n                return \"%S\"\n            } else if (duration < Duration.MINUTE.duration) {\n                return \"%S\"\n            } else if (duration < Duration.HOUR.duration) {\n                return \"%M\"\n            } else if (duration < Duration.DAY.duration) {\n                return \"%H:%M\"\n            } else if (duration < Duration.WEEK.duration) {\n                return \"%b %e\"\n            }\n            return \"%b %e\"\n        }\n\n    init {\n        if (!myDuration.isPositive) {\n            throw RuntimeException(\"Duration must be positive\")\n        }\n    }\n\n    override fun range(start: Double, end: Double): List<Double> {\n        val step = (myDuration.duration * count).toDouble()\n        var tick = ceil(start / step) * step\n        val result = ArrayList<Double>()\n        while (tick <= end) {\n            result.add(tick)\n            tick += step\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.plot.common.time.TimeUtil\n\nabstract class MeasuredInDays protected constructor(count: Int) : TimeInterval(count) {\n\n    protected abstract fun getFirstDayContaining(instant: DateTime): Date\n\n    override fun range(start: Double, end: Double): List<Double> {\n        if (start > end) {\n            throw RuntimeException(\"Duration must be positive\")\n        }\n\n        val dateTimeStart = TimeUtil.asDateTimeUTC(start)\n\n        val dateStart = getFirstDayContaining(dateTimeStart)\n        var dateTimeTick = DateTime(dateStart)\n        if (dateTimeTick.compareTo(dateTimeStart) < 0) {\n            dateTimeTick = addInterval(dateTimeTick)\n        }\n\n        val result = ArrayList<Double>()\n        var tick = TimeUtil.asInstantUTC(dateTimeTick).toDouble()\n        while (tick <= end) {\n            result.add(tick)\n            dateTimeTick = addInterval(dateTimeTick)\n            tick = TimeUtil.asInstantUTC(dateTimeTick).toDouble()\n        }\n\n        return result\n    }\n\n    protected abstract fun addInterval(toInstant: DateTime): DateTime\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Month\n\ninternal class MonthInterval(count: Int) : MeasuredInDays(count) {\n\n    override val tickFormatPattern: String\n        get() = \"%b\"\n\n    override fun getFirstDayContaining(instant: DateTime): Date {\n        var firstDay = instant.date\n        firstDay = Date.firstDayOf(firstDay.year, firstDay.month)\n        return firstDay\n    }\n\n    override fun addInterval(toInstant: DateTime): DateTime {\n        var result = toInstant\n        for (i in 0 until count) {\n            result = addMonth(result)\n        }\n        return result\n    }\n\n    private fun addMonth(toInstant: DateTime): DateTime {\n        var year = toInstant.year\n        val month = toInstant.month\n        var next = month!!.next()\n        if (next == null) {\n            next = Month.JANUARY\n            year++\n        }\n        return DateTime(Date.firstDayOf(year, next))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nobject NiceTimeInterval {\n    private val AUTO_STEPS_MS = doubleArrayOf(1000.0, 5000.0, 15000.0, 30000.0, // 1-, 5-, 15- and 30-second.\n            6e4, 5 * 6e4, 15 * 6e4, 30 * 6e4, // 1-, 5-, 15- and 30-minute.\n            36e5, 3 * 36e5, 6 * 36e5, 12 * 36e5, // 1-, 3-, 6- and 12-hour.\n            864e5, 2 * 864e5, // 1- and 2-day.\n            6048e5, // 1-week.\n            2592e6, 3 * 2592e6, // 1- and 3-month.\n        YearInterval.MS                                  // 1-year.\n    )\n\n    private val AUTO_INTERVALS = arrayOf(\n        TimeInterval.seconds(1),\n        TimeInterval.seconds(5),\n        TimeInterval.seconds(15),\n        TimeInterval.seconds(30),\n\n        TimeInterval.minutes(1),\n        TimeInterval.minutes(5),\n        TimeInterval.minutes(15),\n        TimeInterval.minutes(30),\n\n        TimeInterval.hours(1),\n        TimeInterval.hours(3),\n        TimeInterval.hours(6),\n        TimeInterval.hours(12),\n\n        TimeInterval.days(1),\n        TimeInterval.days(2),\n\n        TimeInterval.weeks(1),\n\n        TimeInterval.months(1),\n        TimeInterval.months(3),\n\n        TimeInterval.years(1)\n    )\n\n    fun forMillis(interval: Double): TimeInterval {\n        if (interval <= AUTO_STEPS_MS[0]) {\n            return AUTO_INTERVALS[0]\n        }\n\n        var result = AUTO_INTERVALS[AUTO_STEPS_MS.size - 1]\n        for (i in 1 until AUTO_STEPS_MS.size) {\n            if (AUTO_STEPS_MS[i] >= interval) {\n                val deltaDown = interval - AUTO_STEPS_MS[i - 1]\n                val deltaUp = AUTO_STEPS_MS[i] - interval\n                if (deltaDown < deltaUp) {\n                    result = AUTO_INTERVALS[i - 1]\n                } else {\n                    result = AUTO_INTERVALS[i]\n                }\n                break\n            }\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\ninternal class QuarterInterval(count: Int) : TimeInterval(count) {\n\n    override val tickFormatPattern: String\n        get() = \"Q\"\n\n    override fun range(start: Double, end: Double): List<Double> {\n        throw UnsupportedOperationException()\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.plot.common.text.DateTimeFormatUtil\n\ninternal class SemesterInterval(count: Int) : TimeInterval(count) {\n\n    override val tickFormatPattern: String\n        get() = throw UnsupportedOperationException()\n\n    override val tickFormatter: (Any) -> String\n        get() = TIME_FORMAT_FUNCTION\n\n    override fun range(start: Double, end: Double): List<Double> {\n        throw UnsupportedOperationException()\n    }\n\n    companion object {\n\n        private val TIME_FORMAT_FUNCTION: (Any) -> String = { input ->\n            var result = DateTimeFormatUtil.formatDateUTC(input as Number, \"Q\")\n            if (result.length == 2 && result.startsWith(\"Q\")) {\n                try {\n                    val quarterNum = result.substring(1).toInt()\n                    val semesterNumber = (quarterNum + 1) / 2\n                    if (semesterNumber == 1 || semesterNumber == 2) {\n                        result = \"Semester $semesterNumber\"\n                    }\n                } catch (ignored: NumberFormatException) {\n                    // ignore\n                }\n\n            }\n            result\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Duration\nimport jetbrains.datalore.plot.common.data.DataType\nimport jetbrains.datalore.plot.common.text.Formatter\n\nabstract class TimeInterval protected constructor(val count: Int) {\n\n    abstract val tickFormatPattern: String\n\n    open val tickFormatter: (Any) -> String\n        get() = Formatter.time(tickFormatPattern)\n\n    /**\n     * @param start instant\n     * @param end   instant\n     * @return Returns every time interval after or equal to start and before end.\n     */\n    abstract fun range(start: Double, end: Double): List<Double>\n\n    companion object {\n        fun milliseconds(count: Int): TimeInterval {\n            return DurationInterval(Duration.MS, count)\n        }\n\n        fun seconds(count: Int): TimeInterval {\n            return DurationInterval(Duration.SECOND, count)\n        }\n\n        fun minutes(count: Int): TimeInterval {\n            return DurationInterval(Duration.MINUTE, count)\n        }\n\n        fun hours(count: Int): TimeInterval {\n            return DurationInterval(Duration.HOUR, count)\n        }\n\n        fun days(count: Int): TimeInterval {\n            return DurationInterval(Duration.DAY, count)\n        }\n\n        fun weeks(count: Int): TimeInterval {\n            return DurationInterval(Duration.WEEK, count)\n        }\n\n        fun months(count: Int): TimeInterval {\n            return MonthInterval(count)\n        }\n\n        private fun quarter(count: Int): TimeInterval {\n            return QuarterInterval(count)\n        }\n\n        private fun semester(count: Int): TimeInterval {\n            return SemesterInterval(count)\n        }\n\n        fun years(count: Int): TimeInterval {\n            return YearInterval(count)\n        }\n\n        fun fromIntervalDataType(dataType: DataType): TimeInterval {\n            return when (dataType) {\n                DataType.INSTANT_OF_DAY -> days(\n                    1\n                )\n                DataType.INSTANT_OF_MONTH -> months(\n                    1\n                )\n                DataType.INSTANT_OF_QUARTER -> quarter(\n                    1\n                )\n                DataType.INSTANT_OF_HALF_YEAR -> semester(\n                    1\n                )\n                DataType.INSTANT_OF_YEAR -> years(\n                    1\n                )\n                else -> throw IllegalArgumentException(\"Can't create interval from data type: $dataType\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.plot.common.text.Formatter\n\nclass YearInterval internal constructor(count: Int) : MeasuredInDays(count) {\n\n    override val tickFormatPattern = TICK_FORMAT\n\n    override fun getFirstDayContaining(instant: DateTime): Date {\n        return Date.firstDayOf(instant.year)\n    }\n\n    override fun addInterval(toInstant: DateTime): DateTime {\n        var result = toInstant\n        for (i in 0 until count) {\n            result = addYear(result)\n        }\n        return result\n    }\n\n    private fun addYear(toInstant: DateTime): DateTime {\n        val year = toInstant.year\n        return DateTime(Date.firstDayOf(year + 1))\n    }\n\n    companion object {\n        const val TICK_FORMAT = \"%Y\"\n        const val MS = 31536e6\n        val TICK_FORMATTER = Formatter.time(TICK_FORMAT)\n    }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-common-portable.js\n"); +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_base_portable) {\n 'use strict';\n var Enum = Kotlin.kotlin.Enum;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var throwISE = Kotlin.throwISE;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var JsMath = Math;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var Exception = Kotlin.kotlin.Exception;\n var throwCCE = Kotlin.throwCCE;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var numberToInt = Kotlin.numberToInt;\n var ensureNotNull = Kotlin.ensureNotNull;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var Ordering = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Ordering;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var toList = Kotlin.kotlin.collections.toList_7wnvza$;\n var List = Kotlin.kotlin.collections.List;\n var listOf = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var Iterable = Kotlin.kotlin.collections.Iterable;\n var isInfinite = Kotlin.kotlin.isInfinite_yrwdxr$;\n var equals = Kotlin.equals;\n var contains = Kotlin.kotlin.collections.contains_2ws7j4$;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var Stack = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.Stack;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var Pair = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var DoubleSegment = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleSegment;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var isNaN_0 = Kotlin.kotlin.isNaN_yrwdxr$;\n var reversed = Kotlin.kotlin.comparisons.reversed_2avth4$;\n var sortedWith = Kotlin.kotlin.collections.sortedWith_eknfly$;\n var sorted = Kotlin.kotlin.collections.sorted_exjks8$;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var wrapFunction = Kotlin.wrapFunction;\n var Comparator = Kotlin.kotlin.Comparator;\n var binarySearch = Kotlin.kotlin.collections.binarySearch_vikexg$;\n var Format_init = $module$lets_plot_base_portable.jetbrains.datalore.base.dateFormat.Format_init_61zpoe$;\n var numberToLong = Kotlin.numberToLong;\n var Instant = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Instant;\n var getCallableRef = Kotlin.getCallableRef;\n var TimeZone = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.tz.TimeZone;\n var NumberFormat_init = $module$lets_plot_base_portable.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$;\n var roundToLong = Kotlin.kotlin.math.roundToLong_yrwdxr$;\n var RuntimeException = Kotlin.kotlin.RuntimeException;\n var Date_0 = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Date;\n var DateTime = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.DateTime;\n var Duration = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Duration;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var Month = $module$lets_plot_base_portable.jetbrains.datalore.base.datetime.Month;\n var UnsupportedOperationException_init = Kotlin.kotlin.UnsupportedOperationException_init;\n var startsWith = Kotlin.kotlin.text.startsWith_7epoxm$;\n var toInt = Kotlin.kotlin.text.toInt_pdl1vz$;\n var NumberFormatException = Kotlin.kotlin.NumberFormatException;\n ColorPalette$Type.prototype = Object.create(Enum.prototype);\n ColorPalette$Type.prototype.constructor = ColorPalette$Type;\n ColorPalette$Sequential.prototype = Object.create(Enum.prototype);\n ColorPalette$Sequential.prototype.constructor = ColorPalette$Sequential;\n ColorPalette$Diverging.prototype = Object.create(Enum.prototype);\n ColorPalette$Diverging.prototype.constructor = ColorPalette$Diverging;\n ColorPalette$Qualitative.prototype = Object.create(Enum.prototype);\n ColorPalette$Qualitative.prototype.constructor = ColorPalette$Qualitative;\n DataType.prototype = Object.create(Enum.prototype);\n DataType.prototype.constructor = DataType;\n RegularMeshDetector$MyRowDetector.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$MyRowDetector.prototype.constructor = RegularMeshDetector$MyRowDetector;\n RegularMeshDetector$MyColumnDetector.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$MyColumnDetector.prototype.constructor = RegularMeshDetector$MyColumnDetector;\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype = Object.create(RegularMeshDetector.prototype);\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype.constructor = RegularMeshDetector$Companion$NO_MESH$ObjectLiteral;\n SeriesUtil$CheckedDoubleList.prototype = Object.create(SeriesUtil$CheckedDoubleIterable.prototype);\n SeriesUtil$CheckedDoubleList.prototype.constructor = SeriesUtil$CheckedDoubleList;\n DurationInterval.prototype = Object.create(TimeInterval.prototype);\n DurationInterval.prototype.constructor = DurationInterval;\n MeasuredInDays.prototype = Object.create(TimeInterval.prototype);\n MeasuredInDays.prototype.constructor = MeasuredInDays;\n MonthInterval.prototype = Object.create(MeasuredInDays.prototype);\n MonthInterval.prototype.constructor = MonthInterval;\n QuarterInterval.prototype = Object.create(TimeInterval.prototype);\n QuarterInterval.prototype.constructor = QuarterInterval;\n SemesterInterval.prototype = Object.create(TimeInterval.prototype);\n SemesterInterval.prototype.constructor = SemesterInterval;\n YearInterval.prototype = Object.create(MeasuredInDays.prototype);\n YearInterval.prototype.constructor = YearInterval;\n function ColorPalette() {\n ColorPalette_instance = this;\n this.MIN_COLOR_SET_SIZE_0 = 3;\n }\n ColorPalette.prototype.colors_0 = function (scheme, count) {\n var count_0 = count;\n var b = count_0;\n count_0 = JsMath.max(3, b);\n var a = scheme.maxColors;\n var b_0 = count_0;\n count_0 = JsMath.min(a, b_0);\n return scheme.colorSet[count_0 - 3 | 0];\n };\n ColorPalette.prototype.maxColorSetSize_0 = function (scheme) {\n var colorSet = scheme.colorSet;\n return colorSet[colorSet.length - 1 | 0].length;\n };\n function ColorPalette$Type(name, ordinal, myPresentation) {\n Enum.call(this);\n this.myPresentation_6glhnl$_0 = myPresentation;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Type_initFields() {\n ColorPalette$Type_initFields = function () {\n };\n ColorPalette$Type$SEQUENTIAL_instance = new ColorPalette$Type('SEQUENTIAL', 0, 'sequential');\n ColorPalette$Type$DIVERGING_instance = new ColorPalette$Type('DIVERGING', 1, 'diverging');\n ColorPalette$Type$QUALITATIVE_instance = new ColorPalette$Type('QUALITATIVE', 2, 'qualitative');\n }\n var ColorPalette$Type$SEQUENTIAL_instance;\n function ColorPalette$Type$SEQUENTIAL_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$SEQUENTIAL_instance;\n }\n var ColorPalette$Type$DIVERGING_instance;\n function ColorPalette$Type$DIVERGING_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$DIVERGING_instance;\n }\n var ColorPalette$Type$QUALITATIVE_instance;\n function ColorPalette$Type$QUALITATIVE_getInstance() {\n ColorPalette$Type_initFields();\n return ColorPalette$Type$QUALITATIVE_instance;\n }\n ColorPalette$Type.prototype.toString = function () {\n return this.myPresentation_6glhnl$_0;\n };\n ColorPalette$Type.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Type',\n interfaces: [Enum]\n };\n function ColorPalette$Type$values() {\n return [ColorPalette$Type$SEQUENTIAL_getInstance(), ColorPalette$Type$DIVERGING_getInstance(), ColorPalette$Type$QUALITATIVE_getInstance()];\n }\n ColorPalette$Type.values = ColorPalette$Type$values;\n function ColorPalette$Type$valueOf(name) {\n switch (name) {\n case 'SEQUENTIAL':\n return ColorPalette$Type$SEQUENTIAL_getInstance();\n case 'DIVERGING':\n return ColorPalette$Type$DIVERGING_getInstance();\n case 'QUALITATIVE':\n return ColorPalette$Type$QUALITATIVE_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Type.' + name);\n }\n }\n ColorPalette$Type.valueOf_61zpoe$ = ColorPalette$Type$valueOf;\n function ColorPalette$Sequential(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_w2uxp8$_0 = myPresentation;\n this.colorSet_b1v09h$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Sequential_initFields() {\n ColorPalette$Sequential_initFields = function () {\n };\n ColorPalette$Sequential$Blues_instance = new ColorPalette$Sequential('Blues', 0, 'blues', ColorSets_getInstance().BLUES);\n ColorPalette$Sequential$BuGn_instance = new ColorPalette$Sequential('BuGn', 1, 'blue-green', ColorSets_getInstance().BU_GN);\n ColorPalette$Sequential$BuPu_instance = new ColorPalette$Sequential('BuPu', 2, 'blue-purple', ColorSets_getInstance().BU_PU);\n ColorPalette$Sequential$GnBu_instance = new ColorPalette$Sequential('GnBu', 3, 'green-blue', ColorSets_getInstance().GN_BU);\n ColorPalette$Sequential$Greens_instance = new ColorPalette$Sequential('Greens', 4, 'greens', ColorSets_getInstance().GREENS);\n ColorPalette$Sequential$Greys_instance = new ColorPalette$Sequential('Greys', 5, 'greys', ColorSets_getInstance().GREYS);\n ColorPalette$Sequential$Oranges_instance = new ColorPalette$Sequential('Oranges', 6, 'oranges', ColorSets_getInstance().ORANGES);\n ColorPalette$Sequential$OrRd_instance = new ColorPalette$Sequential('OrRd', 7, 'orange-red', ColorSets_getInstance().OR_RD);\n ColorPalette$Sequential$PuBu_instance = new ColorPalette$Sequential('PuBu', 8, 'purple-blue', ColorSets_getInstance().PU_BU);\n ColorPalette$Sequential$PuBuGn_instance = new ColorPalette$Sequential('PuBuGn', 9, 'purple-blue-green', ColorSets_getInstance().PU_BU_GN);\n ColorPalette$Sequential$PuRd_instance = new ColorPalette$Sequential('PuRd', 10, 'purple-red', ColorSets_getInstance().PU_RD);\n ColorPalette$Sequential$Purples_instance = new ColorPalette$Sequential('Purples', 11, 'purples', ColorSets_getInstance().PURPLES);\n ColorPalette$Sequential$RdPu_instance = new ColorPalette$Sequential('RdPu', 12, 'red-purple', ColorSets_getInstance().RD_PU);\n ColorPalette$Sequential$Reds_instance = new ColorPalette$Sequential('Reds', 13, 'reds', ColorSets_getInstance().REDS);\n ColorPalette$Sequential$YlGn_instance = new ColorPalette$Sequential('YlGn', 14, 'yellow-green', ColorSets_getInstance().YL_GN);\n ColorPalette$Sequential$YlGnBu_instance = new ColorPalette$Sequential('YlGnBu', 15, 'yellow-green-blue', ColorSets_getInstance().YL_GN_BU);\n ColorPalette$Sequential$YlOrBr_instance = new ColorPalette$Sequential('YlOrBr', 16, 'yellow-orange-brown', ColorSets_getInstance().YL_OR_BR);\n ColorPalette$Sequential$YlOrRd_instance = new ColorPalette$Sequential('YlOrRd', 17, 'yellow-orange-red', ColorSets_getInstance().YL_OR_RD);\n }\n Object.defineProperty(ColorPalette$Sequential.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_b1v09h$_0;\n }\n });\n var ColorPalette$Sequential$Blues_instance;\n function ColorPalette$Sequential$Blues_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Blues_instance;\n }\n var ColorPalette$Sequential$BuGn_instance;\n function ColorPalette$Sequential$BuGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$BuGn_instance;\n }\n var ColorPalette$Sequential$BuPu_instance;\n function ColorPalette$Sequential$BuPu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$BuPu_instance;\n }\n var ColorPalette$Sequential$GnBu_instance;\n function ColorPalette$Sequential$GnBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$GnBu_instance;\n }\n var ColorPalette$Sequential$Greens_instance;\n function ColorPalette$Sequential$Greens_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Greens_instance;\n }\n var ColorPalette$Sequential$Greys_instance;\n function ColorPalette$Sequential$Greys_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Greys_instance;\n }\n var ColorPalette$Sequential$Oranges_instance;\n function ColorPalette$Sequential$Oranges_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Oranges_instance;\n }\n var ColorPalette$Sequential$OrRd_instance;\n function ColorPalette$Sequential$OrRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$OrRd_instance;\n }\n var ColorPalette$Sequential$PuBu_instance;\n function ColorPalette$Sequential$PuBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuBu_instance;\n }\n var ColorPalette$Sequential$PuBuGn_instance;\n function ColorPalette$Sequential$PuBuGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuBuGn_instance;\n }\n var ColorPalette$Sequential$PuRd_instance;\n function ColorPalette$Sequential$PuRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$PuRd_instance;\n }\n var ColorPalette$Sequential$Purples_instance;\n function ColorPalette$Sequential$Purples_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Purples_instance;\n }\n var ColorPalette$Sequential$RdPu_instance;\n function ColorPalette$Sequential$RdPu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$RdPu_instance;\n }\n var ColorPalette$Sequential$Reds_instance;\n function ColorPalette$Sequential$Reds_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$Reds_instance;\n }\n var ColorPalette$Sequential$YlGn_instance;\n function ColorPalette$Sequential$YlGn_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlGn_instance;\n }\n var ColorPalette$Sequential$YlGnBu_instance;\n function ColorPalette$Sequential$YlGnBu_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlGnBu_instance;\n }\n var ColorPalette$Sequential$YlOrBr_instance;\n function ColorPalette$Sequential$YlOrBr_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlOrBr_instance;\n }\n var ColorPalette$Sequential$YlOrRd_instance;\n function ColorPalette$Sequential$YlOrRd_getInstance() {\n ColorPalette$Sequential_initFields();\n return ColorPalette$Sequential$YlOrRd_instance;\n }\n Object.defineProperty(ColorPalette$Sequential.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$SEQUENTIAL_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Sequential.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Sequential.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Sequential.prototype.toString = function () {\n return this.myPresentation_w2uxp8$_0;\n };\n ColorPalette$Sequential.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Sequential',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Sequential$values() {\n return [ColorPalette$Sequential$Blues_getInstance(), ColorPalette$Sequential$BuGn_getInstance(), ColorPalette$Sequential$BuPu_getInstance(), ColorPalette$Sequential$GnBu_getInstance(), ColorPalette$Sequential$Greens_getInstance(), ColorPalette$Sequential$Greys_getInstance(), ColorPalette$Sequential$Oranges_getInstance(), ColorPalette$Sequential$OrRd_getInstance(), ColorPalette$Sequential$PuBu_getInstance(), ColorPalette$Sequential$PuBuGn_getInstance(), ColorPalette$Sequential$PuRd_getInstance(), ColorPalette$Sequential$Purples_getInstance(), ColorPalette$Sequential$RdPu_getInstance(), ColorPalette$Sequential$Reds_getInstance(), ColorPalette$Sequential$YlGn_getInstance(), ColorPalette$Sequential$YlGnBu_getInstance(), ColorPalette$Sequential$YlOrBr_getInstance(), ColorPalette$Sequential$YlOrRd_getInstance()];\n }\n ColorPalette$Sequential.values = ColorPalette$Sequential$values;\n function ColorPalette$Sequential$valueOf(name) {\n switch (name) {\n case 'Blues':\n return ColorPalette$Sequential$Blues_getInstance();\n case 'BuGn':\n return ColorPalette$Sequential$BuGn_getInstance();\n case 'BuPu':\n return ColorPalette$Sequential$BuPu_getInstance();\n case 'GnBu':\n return ColorPalette$Sequential$GnBu_getInstance();\n case 'Greens':\n return ColorPalette$Sequential$Greens_getInstance();\n case 'Greys':\n return ColorPalette$Sequential$Greys_getInstance();\n case 'Oranges':\n return ColorPalette$Sequential$Oranges_getInstance();\n case 'OrRd':\n return ColorPalette$Sequential$OrRd_getInstance();\n case 'PuBu':\n return ColorPalette$Sequential$PuBu_getInstance();\n case 'PuBuGn':\n return ColorPalette$Sequential$PuBuGn_getInstance();\n case 'PuRd':\n return ColorPalette$Sequential$PuRd_getInstance();\n case 'Purples':\n return ColorPalette$Sequential$Purples_getInstance();\n case 'RdPu':\n return ColorPalette$Sequential$RdPu_getInstance();\n case 'Reds':\n return ColorPalette$Sequential$Reds_getInstance();\n case 'YlGn':\n return ColorPalette$Sequential$YlGn_getInstance();\n case 'YlGnBu':\n return ColorPalette$Sequential$YlGnBu_getInstance();\n case 'YlOrBr':\n return ColorPalette$Sequential$YlOrBr_getInstance();\n case 'YlOrRd':\n return ColorPalette$Sequential$YlOrRd_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Sequential.' + name);\n }\n }\n ColorPalette$Sequential.valueOf_61zpoe$ = ColorPalette$Sequential$valueOf;\n function ColorPalette$Diverging(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_im16qo$_0 = myPresentation;\n this.colorSet_las6nb$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Diverging_initFields() {\n ColorPalette$Diverging_initFields = function () {\n };\n ColorPalette$Diverging$BrBG_instance = new ColorPalette$Diverging('BrBG', 0, 'brown-blue/green', ColorSets_getInstance().BR_BG);\n ColorPalette$Diverging$PiYG_instance = new ColorPalette$Diverging('PiYG', 1, 'pink-yellow/green', ColorSets_getInstance().PI_YG);\n ColorPalette$Diverging$PRGn_instance = new ColorPalette$Diverging('PRGn', 2, 'purple/red-green', ColorSets_getInstance().PR_GN);\n ColorPalette$Diverging$PuOr_instance = new ColorPalette$Diverging('PuOr', 3, 'purple-orange', ColorSets_getInstance().PU_OR);\n ColorPalette$Diverging$RdBu_instance = new ColorPalette$Diverging('RdBu', 4, 'red-blue', ColorSets_getInstance().RD_BU);\n ColorPalette$Diverging$RdGy_instance = new ColorPalette$Diverging('RdGy', 5, 'red-grey', ColorSets_getInstance().RD_GY);\n ColorPalette$Diverging$RdYlBu_instance = new ColorPalette$Diverging('RdYlBu', 6, 'red-yellow-blue', ColorSets_getInstance().RD_YL_BU);\n ColorPalette$Diverging$RdYlGn_instance = new ColorPalette$Diverging('RdYlGn', 7, 'red-yellow-green', ColorSets_getInstance().RD_YL_GN);\n ColorPalette$Diverging$Spectral_instance = new ColorPalette$Diverging('Spectral', 8, 'spectral', ColorSets_getInstance().SPECTRAL);\n }\n Object.defineProperty(ColorPalette$Diverging.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_las6nb$_0;\n }\n });\n var ColorPalette$Diverging$BrBG_instance;\n function ColorPalette$Diverging$BrBG_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$BrBG_instance;\n }\n var ColorPalette$Diverging$PiYG_instance;\n function ColorPalette$Diverging$PiYG_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PiYG_instance;\n }\n var ColorPalette$Diverging$PRGn_instance;\n function ColorPalette$Diverging$PRGn_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PRGn_instance;\n }\n var ColorPalette$Diverging$PuOr_instance;\n function ColorPalette$Diverging$PuOr_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$PuOr_instance;\n }\n var ColorPalette$Diverging$RdBu_instance;\n function ColorPalette$Diverging$RdBu_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdBu_instance;\n }\n var ColorPalette$Diverging$RdGy_instance;\n function ColorPalette$Diverging$RdGy_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdGy_instance;\n }\n var ColorPalette$Diverging$RdYlBu_instance;\n function ColorPalette$Diverging$RdYlBu_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdYlBu_instance;\n }\n var ColorPalette$Diverging$RdYlGn_instance;\n function ColorPalette$Diverging$RdYlGn_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$RdYlGn_instance;\n }\n var ColorPalette$Diverging$Spectral_instance;\n function ColorPalette$Diverging$Spectral_getInstance() {\n ColorPalette$Diverging_initFields();\n return ColorPalette$Diverging$Spectral_instance;\n }\n Object.defineProperty(ColorPalette$Diverging.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$DIVERGING_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Diverging.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Diverging.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Diverging.prototype.toString = function () {\n return this.myPresentation_im16qo$_0;\n };\n ColorPalette$Diverging.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Diverging',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Diverging$values() {\n return [ColorPalette$Diverging$BrBG_getInstance(), ColorPalette$Diverging$PiYG_getInstance(), ColorPalette$Diverging$PRGn_getInstance(), ColorPalette$Diverging$PuOr_getInstance(), ColorPalette$Diverging$RdBu_getInstance(), ColorPalette$Diverging$RdGy_getInstance(), ColorPalette$Diverging$RdYlBu_getInstance(), ColorPalette$Diverging$RdYlGn_getInstance(), ColorPalette$Diverging$Spectral_getInstance()];\n }\n ColorPalette$Diverging.values = ColorPalette$Diverging$values;\n function ColorPalette$Diverging$valueOf(name) {\n switch (name) {\n case 'BrBG':\n return ColorPalette$Diverging$BrBG_getInstance();\n case 'PiYG':\n return ColorPalette$Diverging$PiYG_getInstance();\n case 'PRGn':\n return ColorPalette$Diverging$PRGn_getInstance();\n case 'PuOr':\n return ColorPalette$Diverging$PuOr_getInstance();\n case 'RdBu':\n return ColorPalette$Diverging$RdBu_getInstance();\n case 'RdGy':\n return ColorPalette$Diverging$RdGy_getInstance();\n case 'RdYlBu':\n return ColorPalette$Diverging$RdYlBu_getInstance();\n case 'RdYlGn':\n return ColorPalette$Diverging$RdYlGn_getInstance();\n case 'Spectral':\n return ColorPalette$Diverging$Spectral_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Diverging.' + name);\n }\n }\n ColorPalette$Diverging.valueOf_61zpoe$ = ColorPalette$Diverging$valueOf;\n function ColorPalette$Qualitative(name, ordinal, myPresentation, colorSet) {\n Enum.call(this);\n this.myPresentation_av4sq6$_0 = myPresentation;\n this.colorSet_cgz7kp$_0 = colorSet;\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function ColorPalette$Qualitative_initFields() {\n ColorPalette$Qualitative_initFields = function () {\n };\n ColorPalette$Qualitative$Accent_instance = new ColorPalette$Qualitative('Accent', 0, 'accent', ColorSets_getInstance().ACCENT);\n ColorPalette$Qualitative$Dark2_instance = new ColorPalette$Qualitative('Dark2', 1, 'dark 2', ColorSets_getInstance().DARK_2);\n ColorPalette$Qualitative$Paired_instance = new ColorPalette$Qualitative('Paired', 2, 'paired', ColorSets_getInstance().PAIRED);\n ColorPalette$Qualitative$Pastel1_instance = new ColorPalette$Qualitative('Pastel1', 3, 'pastel 1', ColorSets_getInstance().PASTEL_1);\n ColorPalette$Qualitative$Pastel2_instance = new ColorPalette$Qualitative('Pastel2', 4, 'pastel 2', ColorSets_getInstance().PASTEL_2);\n ColorPalette$Qualitative$Set1_instance = new ColorPalette$Qualitative('Set1', 5, 'set 1', ColorSets_getInstance().SET_1);\n ColorPalette$Qualitative$Set2_instance = new ColorPalette$Qualitative('Set2', 6, 'set 2', ColorSets_getInstance().SET_2);\n ColorPalette$Qualitative$Set3_instance = new ColorPalette$Qualitative('Set3', 7, 'set 3', ColorSets_getInstance().SET_3);\n }\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'colorSet', {\n get: function () {\n return this.colorSet_cgz7kp$_0;\n }\n });\n var ColorPalette$Qualitative$Accent_instance;\n function ColorPalette$Qualitative$Accent_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Accent_instance;\n }\n var ColorPalette$Qualitative$Dark2_instance;\n function ColorPalette$Qualitative$Dark2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Dark2_instance;\n }\n var ColorPalette$Qualitative$Paired_instance;\n function ColorPalette$Qualitative$Paired_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Paired_instance;\n }\n var ColorPalette$Qualitative$Pastel1_instance;\n function ColorPalette$Qualitative$Pastel1_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Pastel1_instance;\n }\n var ColorPalette$Qualitative$Pastel2_instance;\n function ColorPalette$Qualitative$Pastel2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Pastel2_instance;\n }\n var ColorPalette$Qualitative$Set1_instance;\n function ColorPalette$Qualitative$Set1_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set1_instance;\n }\n var ColorPalette$Qualitative$Set2_instance;\n function ColorPalette$Qualitative$Set2_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set2_instance;\n }\n var ColorPalette$Qualitative$Set3_instance;\n function ColorPalette$Qualitative$Set3_getInstance() {\n ColorPalette$Qualitative_initFields();\n return ColorPalette$Qualitative$Set3_instance;\n }\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'type', {\n configurable: true,\n get: function () {\n return ColorPalette$Type$QUALITATIVE_getInstance();\n }\n });\n Object.defineProperty(ColorPalette$Qualitative.prototype, 'maxColors', {\n configurable: true,\n get: function () {\n return ColorPalette_getInstance().maxColorSetSize_0(this);\n }\n });\n ColorPalette$Qualitative.prototype.getColors_za3lpa$ = function (count) {\n return ColorPalette_getInstance().colors_0(this, count);\n };\n ColorPalette$Qualitative.prototype.toString = function () {\n return this.myPresentation_av4sq6$_0;\n };\n ColorPalette$Qualitative.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Qualitative',\n interfaces: [ColorScheme, Enum]\n };\n function ColorPalette$Qualitative$values() {\n return [ColorPalette$Qualitative$Accent_getInstance(), ColorPalette$Qualitative$Dark2_getInstance(), ColorPalette$Qualitative$Paired_getInstance(), ColorPalette$Qualitative$Pastel1_getInstance(), ColorPalette$Qualitative$Pastel2_getInstance(), ColorPalette$Qualitative$Set1_getInstance(), ColorPalette$Qualitative$Set2_getInstance(), ColorPalette$Qualitative$Set3_getInstance()];\n }\n ColorPalette$Qualitative.values = ColorPalette$Qualitative$values;\n function ColorPalette$Qualitative$valueOf(name) {\n switch (name) {\n case 'Accent':\n return ColorPalette$Qualitative$Accent_getInstance();\n case 'Dark2':\n return ColorPalette$Qualitative$Dark2_getInstance();\n case 'Paired':\n return ColorPalette$Qualitative$Paired_getInstance();\n case 'Pastel1':\n return ColorPalette$Qualitative$Pastel1_getInstance();\n case 'Pastel2':\n return ColorPalette$Qualitative$Pastel2_getInstance();\n case 'Set1':\n return ColorPalette$Qualitative$Set1_getInstance();\n case 'Set2':\n return ColorPalette$Qualitative$Set2_getInstance();\n case 'Set3':\n return ColorPalette$Qualitative$Set3_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Qualitative.' + name);\n }\n }\n ColorPalette$Qualitative.valueOf_61zpoe$ = ColorPalette$Qualitative$valueOf;\n ColorPalette.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorPalette',\n interfaces: []\n };\n var ColorPalette_instance = null;\n function ColorPalette_getInstance() {\n if (ColorPalette_instance === null) {\n new ColorPalette();\n }return ColorPalette_instance;\n }\n function ColorScheme() {\n }\n ColorScheme.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'ColorScheme',\n interfaces: []\n };\n function ColorSets() {\n ColorSets_instance = this;\n this.BU_GN_3 = ['#e5f5f9', '#99d8c9', '#2ca25f'];\n this.BU_GN_4 = ['#edf8fb', '#b2e2e2', '#66c2a4', '#238b45'];\n this.BU_GN_5 = ['#edf8fb', '#b2e2e2', '#66c2a4', '#2ca25f', '#006d2c'];\n this.BU_GN_6 = ['#edf8fb', '#ccece6', '#99d8c9', '#66c2a4', '#2ca25f', '#006d2c'];\n this.BU_GN_7 = ['#edf8fb', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#005824'];\n this.BU_GN_8 = ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#005824'];\n this.BU_GN_9 = ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'];\n this.BU_PU_3 = ['#e0ecf4', '#9ebcda', '#8856a7'];\n this.BU_PU_4 = ['#edf8fb', '#b3cde3', '#8c96c6', '#88419d'];\n this.BU_PU_5 = ['#edf8fb', '#b3cde3', '#8c96c6', '#8856a7', '#810f7c'];\n this.BU_PU_6 = ['#edf8fb', '#bfd3e6', '#9ebcda', '#8c96c6', '#8856a7', '#810f7c'];\n this.BU_PU_7 = ['#edf8fb', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#6e016b'];\n this.BU_PU_8 = ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#6e016b'];\n this.BU_PU_9 = ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'];\n this.GN_BU_3 = ['#e0f3db', '#a8ddb5', '#43a2ca'];\n this.GN_BU_4 = ['#f0f9e8', '#bae4bc', '#7bccc4', '#2b8cbe'];\n this.GN_BU_5 = ['#f0f9e8', '#bae4bc', '#7bccc4', '#43a2ca', '#0868ac'];\n this.GN_BU_6 = ['#f0f9e8', '#ccebc5', '#a8ddb5', '#7bccc4', '#43a2ca', '#0868ac'];\n this.GN_BU_7 = ['#f0f9e8', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#08589e'];\n this.GN_BU_8 = ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#08589e'];\n this.GN_BU_9 = ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'];\n this.OR_RD_3 = ['#fee8c8', '#fdbb84', '#e34a33'];\n this.OR_RD_4 = ['#fef0d9', '#fdcc8a', '#fc8d59', '#d7301f'];\n this.OR_RD_5 = ['#fef0d9', '#fdcc8a', '#fc8d59', '#e34a33', '#b30000'];\n this.OR_RD_6 = ['#fef0d9', '#fdd49e', '#fdbb84', '#fc8d59', '#e34a33', '#b30000'];\n this.OR_RD_7 = ['#fef0d9', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#990000'];\n this.OR_RD_8 = ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#990000'];\n this.OR_RD_9 = ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'];\n this.PU_BU_3 = ['#ece7f2', '#a6bddb', '#2b8cbe'];\n this.PU_BU_4 = ['#f1eef6', '#bdc9e1', '#74a9cf', '#0570b0'];\n this.PU_BU_5 = ['#f1eef6', '#bdc9e1', '#74a9cf', '#2b8cbe', '#045a8d'];\n this.PU_BU_6 = ['#f1eef6', '#d0d1e6', '#a6bddb', '#74a9cf', '#2b8cbe', '#045a8d'];\n this.PU_BU_7 = ['#f1eef6', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#034e7b'];\n this.PU_BU_8 = ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#034e7b'];\n this.PU_BU_9 = ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'];\n this.PU_BU_GN_3 = ['#ece2f0', '#a6bddb', '#1c9099'];\n this.PU_BU_GN_4 = ['#f6eff7', '#bdc9e1', '#67a9cf', '#02818a'];\n this.PU_BU_GN_5 = ['#f6eff7', '#bdc9e1', '#67a9cf', '#1c9099', '#016c59'];\n this.PU_BU_GN_6 = ['#f6eff7', '#d0d1e6', '#a6bddb', '#67a9cf', '#1c9099', '#016c59'];\n this.PU_BU_GN_7 = ['#f6eff7', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016450'];\n this.PU_BU_GN_8 = ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016450'];\n this.PU_BU_GN_9 = ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'];\n this.PU_RD_3 = ['#e7e1ef', '#c994c7', '#dd1c77'];\n this.PU_RD_4 = ['#f1eef6', '#d7b5d8', '#df65b0', '#ce1256'];\n this.PU_RD_5 = ['#f1eef6', '#d7b5d8', '#df65b0', '#dd1c77', '#980043'];\n this.PU_RD_6 = ['#f1eef6', '#d4b9da', '#c994c7', '#df65b0', '#dd1c77', '#980043'];\n this.PU_RD_7 = ['#f1eef6', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#91003f'];\n this.PU_RD_8 = ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#91003f'];\n this.PU_RD_9 = ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'];\n this.RD_PU_3 = ['#fde0dd', '#fa9fb5', '#c51b8a'];\n this.RD_PU_4 = ['#feebe2', '#fbb4b9', '#f768a1', '#ae017e'];\n this.RD_PU_5 = ['#feebe2', '#fbb4b9', '#f768a1', '#c51b8a', '#7a0177'];\n this.RD_PU_6 = ['#feebe2', '#fcc5c0', '#fa9fb5', '#f768a1', '#c51b8a', '#7a0177'];\n this.RD_PU_7 = ['#feebe2', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177'];\n this.RD_PU_8 = ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177'];\n this.RD_PU_9 = ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'];\n this.YL_GN_3 = ['#f7fcb9', '#addd8e', '#31a354'];\n this.YL_GN_4 = ['#ffffcc', '#c2e699', '#78c679', '#238443'];\n this.YL_GN_5 = ['#ffffcc', '#c2e699', '#78c679', '#31a354', '#006837'];\n this.YL_GN_6 = ['#ffffcc', '#d9f0a3', '#addd8e', '#78c679', '#31a354', '#006837'];\n this.YL_GN_7 = ['#ffffcc', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#005a32'];\n this.YL_GN_8 = ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#005a32'];\n this.YL_GN_9 = ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'];\n this.YL_GN_BU_3 = ['#edf8b1', '#7fcdbb', '#2c7fb8'];\n this.YL_GN_BU_4 = ['#ffffcc', '#a1dab4', '#41b6c4', '#225ea8'];\n this.YL_GN_BU_5 = ['#ffffcc', '#a1dab4', '#41b6c4', '#2c7fb8', '#253494'];\n this.YL_GN_BU_6 = ['#ffffcc', '#c7e9b4', '#7fcdbb', '#41b6c4', '#2c7fb8', '#253494'];\n this.YL_GN_BU_7 = ['#ffffcc', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#0c2c84'];\n this.YL_GN_BU_8 = ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#0c2c84'];\n this.YL_GN_BU_9 = ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'];\n this.YL_OR_BR_3 = ['#fff7bc', '#fec44f', '#d95f0e'];\n this.YL_OR_BR_4 = ['#ffffd4', '#fed98e', '#fe9929', '#cc4c02'];\n this.YL_OR_BR_5 = ['#ffffd4', '#fed98e', '#fe9929', '#d95f0e', '#993404'];\n this.YL_OR_BR_6 = ['#ffffd4', '#fee391', '#fec44f', '#fe9929', '#d95f0e', '#993404'];\n this.YL_OR_BR_7 = ['#ffffd4', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#8c2d04'];\n this.YL_OR_BR_8 = ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#8c2d04'];\n this.YL_OR_BR_9 = ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'];\n this.YL_OR_RD_3 = ['#ffeda0', '#feb24c', '#f03b20'];\n this.YL_OR_RD_4 = ['#ffffb2', '#fecc5c', '#fd8d3c', '#e31a1c'];\n this.YL_OR_RD_5 = ['#ffffb2', '#fecc5c', '#fd8d3c', '#f03b20', '#bd0026'];\n this.YL_OR_RD_6 = ['#ffffb2', '#fed976', '#feb24c', '#fd8d3c', '#f03b20', '#bd0026'];\n this.YL_OR_RD_7 = ['#ffffb2', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#b10026'];\n this.YL_OR_RD_8 = ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#b10026'];\n this.YL_OR_RD_9 = ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'];\n this.BU_GN = [this.BU_GN_3, this.BU_GN_4, this.BU_GN_5, this.BU_GN_6, this.BU_GN_7, this.BU_GN_8, this.BU_GN_9];\n this.BU_PU = [this.BU_PU_3, this.BU_PU_4, this.BU_PU_5, this.BU_PU_6, this.BU_PU_7, this.BU_PU_8, this.BU_PU_9];\n this.GN_BU = [this.GN_BU_3, this.GN_BU_4, this.GN_BU_5, this.GN_BU_6, this.GN_BU_7, this.GN_BU_8, this.GN_BU_9];\n this.OR_RD = [this.OR_RD_3, this.OR_RD_4, this.OR_RD_5, this.OR_RD_6, this.OR_RD_7, this.OR_RD_8, this.OR_RD_9];\n this.PU_BU = [this.PU_BU_3, this.PU_BU_4, this.PU_BU_5, this.PU_BU_6, this.PU_BU_7, this.PU_BU_8, this.PU_BU_9];\n this.PU_BU_GN = [this.PU_BU_GN_3, this.PU_BU_GN_4, this.PU_BU_GN_5, this.PU_BU_GN_6, this.PU_BU_GN_7, this.PU_BU_GN_8, this.PU_BU_GN_9];\n this.PU_RD = [this.PU_RD_3, this.PU_RD_4, this.PU_RD_5, this.PU_RD_6, this.PU_RD_7, this.PU_RD_8, this.PU_RD_9];\n this.RD_PU = [this.RD_PU_3, this.RD_PU_4, this.RD_PU_5, this.RD_PU_6, this.RD_PU_7, this.RD_PU_8, this.RD_PU_9];\n this.YL_GN = [this.YL_GN_3, this.YL_GN_4, this.YL_GN_5, this.YL_GN_6, this.YL_GN_7, this.YL_GN_8, this.YL_GN_9];\n this.YL_GN_BU = [this.YL_GN_BU_3, this.YL_GN_BU_4, this.YL_GN_BU_5, this.YL_GN_BU_6, this.YL_GN_BU_7, this.YL_GN_BU_8, this.YL_GN_BU_9];\n this.YL_OR_BR = [this.YL_OR_BR_3, this.YL_OR_BR_4, this.YL_OR_BR_5, this.YL_OR_BR_6, this.YL_OR_BR_7, this.YL_OR_BR_8, this.YL_OR_BR_9];\n this.YL_OR_RD = [this.YL_OR_RD_3, this.YL_OR_RD_4, this.YL_OR_RD_5, this.YL_OR_RD_6, this.YL_OR_RD_7, this.YL_OR_RD_8, this.YL_OR_RD_9];\n this.BLUES_3 = ['#deebf7', '#9ecae1', '#3182bd'];\n this.BLUES_4 = ['#eff3ff', '#bdd7e7', '#6baed6', '#2171b5'];\n this.BLUES_5 = ['#eff3ff', '#bdd7e7', '#6baed6', '#3182bd', '#08519c'];\n this.BLUES_6 = ['#eff3ff', '#c6dbef', '#9ecae1', '#6baed6', '#3182bd', '#08519c'];\n this.BLUES_7 = ['#eff3ff', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#084594'];\n this.BLUES_8 = ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#084594'];\n this.BLUES_9 = ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'];\n this.GREENS_3 = ['#e5f5e0', '#a1d99b', '#31a354'];\n this.GREENS_4 = ['#edf8e9', '#bae4b3', '#74c476', '#238b45'];\n this.GREENS_5 = ['#edf8e9', '#bae4b3', '#74c476', '#31a354', '#006d2c'];\n this.GREENS_6 = ['#edf8e9', '#c7e9c0', '#a1d99b', '#74c476', '#31a354', '#006d2c'];\n this.GREENS_7 = ['#edf8e9', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#005a32'];\n this.GREENS_8 = ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#005a32'];\n this.GREENS_9 = ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'];\n this.GREYS_3 = ['#f0f0f0', '#bdbdbd', '#636363'];\n this.GREYS_4 = ['#f7f7f7', '#cccccc', '#969696', '#525252'];\n this.GREYS_5 = ['#f7f7f7', '#cccccc', '#969696', '#636363', '#252525'];\n this.GREYS_6 = ['#f7f7f7', '#d9d9d9', '#bdbdbd', '#969696', '#636363', '#252525'];\n this.GREYS_7 = ['#f7f7f7', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525'];\n this.GREYS_8 = ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525'];\n this.GREYS_9 = ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'];\n this.ORANGES_3 = ['#fee6ce', '#fdae6b', '#e6550d'];\n this.ORANGES_4 = ['#feedde', '#fdbe85', '#fd8d3c', '#d94701'];\n this.ORANGES_5 = ['#feedde', '#fdbe85', '#fd8d3c', '#e6550d', '#a63603'];\n this.ORANGES_6 = ['#feedde', '#fdd0a2', '#fdae6b', '#fd8d3c', '#e6550d', '#a63603'];\n this.ORANGES_7 = ['#feedde', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#8c2d04'];\n this.ORANGES_8 = ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#8c2d04'];\n this.ORANGES_9 = ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'];\n this.PURPLES_3 = ['#efedf5', '#bcbddc', '#756bb1'];\n this.PURPLES_4 = ['#f2f0f7', '#cbc9e2', '#9e9ac8', '#6a51a3'];\n this.PURPLES_5 = ['#f2f0f7', '#cbc9e2', '#9e9ac8', '#756bb1', '#54278f'];\n this.PURPLES_6 = ['#f2f0f7', '#dadaeb', '#bcbddc', '#9e9ac8', '#756bb1', '#54278f'];\n this.PURPLES_7 = ['#f2f0f7', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#4a1486'];\n this.PURPLES_8 = ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#4a1486'];\n this.PURPLES_9 = ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'];\n this.REDS_3 = ['#fee0d2', '#fc9272', '#de2d26'];\n this.REDS_4 = ['#fee5d9', '#fcae91', '#fb6a4a', '#cb181d'];\n this.REDS_5 = ['#fee5d9', '#fcae91', '#fb6a4a', '#de2d26', '#a50f15'];\n this.REDS_6 = ['#fee5d9', '#fcbba1', '#fc9272', '#fb6a4a', '#de2d26', '#a50f15'];\n this.REDS_7 = ['#fee5d9', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#99000d'];\n this.REDS_8 = ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#99000d'];\n this.REDS_9 = ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'];\n this.BLUES = [this.BLUES_3, this.BLUES_4, this.BLUES_5, this.BLUES_6, this.BLUES_7, this.BLUES_8, this.BLUES_9];\n this.GREENS = [this.GREENS_3, this.GREENS_4, this.GREENS_5, this.GREENS_6, this.GREENS_7, this.GREENS_8, this.GREENS_9];\n this.GREYS = [this.GREYS_3, this.GREYS_4, this.GREYS_5, this.GREYS_6, this.GREYS_7, this.GREYS_8, this.GREYS_9];\n this.ORANGES = [this.ORANGES_3, this.ORANGES_4, this.ORANGES_5, this.ORANGES_6, this.ORANGES_7, this.ORANGES_8, this.ORANGES_9];\n this.PURPLES = [this.PURPLES_3, this.PURPLES_4, this.PURPLES_5, this.PURPLES_6, this.PURPLES_7, this.PURPLES_8, this.PURPLES_9];\n this.REDS = [this.REDS_3, this.REDS_4, this.REDS_5, this.REDS_6, this.REDS_7, this.REDS_8, this.REDS_9];\n this.BR_BG_3 = ['#d8b365', '#f5f5f5', '#5ab4ac'];\n this.BR_BG_4 = ['#a6611a', '#dfc27d', '#80cdc1', '#018571'];\n this.BR_BG_5 = ['#a6611a', '#dfc27d', '#f5f5f5', '#80cdc1', '#018571'];\n this.BR_BG_6 = ['#8c510a', '#d8b365', '#f6e8c3', '#c7eae5', '#5ab4ac', '#01665e'];\n this.BR_BG_7 = ['#8c510a', '#d8b365', '#f6e8c3', '#f5f5f5', '#c7eae5', '#5ab4ac', '#01665e'];\n this.BR_BG_8 = ['#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#c7eae5', '#80cdc1', '#35978f', '#01665e'];\n this.BR_BG_9 = ['#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e'];\n this.BR_BG_10 = ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'];\n this.BR_BG_11 = ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'];\n this.PI_YG_3 = ['#e9a3c9', '#f7f7f7', '#a1d76a'];\n this.PI_YG_4 = ['#d01c8b', '#f1b6da', '#b8e186', '#4dac26'];\n this.PI_YG_5 = ['#d01c8b', '#f1b6da', '#f7f7f7', '#b8e186', '#4dac26'];\n this.PI_YG_6 = ['#c51b7d', '#e9a3c9', '#fde0ef', '#e6f5d0', '#a1d76a', '#4d9221'];\n this.PI_YG_7 = ['#c51b7d', '#e9a3c9', '#fde0ef', '#f7f7f7', '#e6f5d0', '#a1d76a', '#4d9221'];\n this.PI_YG_8 = ['#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221'];\n this.PI_YG_9 = ['#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221'];\n this.PI_YG_10 = ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'];\n this.PI_YG_11 = ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'];\n this.PR_GN_3 = ['#af8dc3', '#f7f7f7', '#7fbf7b'];\n this.PR_GN_4 = ['#7b3294', '#c2a5cf', '#a6dba0', '#008837'];\n this.PR_GN_5 = ['#7b3294', '#c2a5cf', '#f7f7f7', '#a6dba0', '#008837'];\n this.PR_GN_6 = ['#762a83', '#af8dc3', '#e7d4e8', '#d9f0d3', '#7fbf7b', '#1b7837'];\n this.PR_GN_7 = ['#762a83', '#af8dc3', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#7fbf7b', '#1b7837'];\n this.PR_GN_8 = ['#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837'];\n this.PR_GN_9 = ['#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837'];\n this.PR_GN_10 = ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'];\n this.PR_GN_11 = ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'];\n this.PU_OR_3 = ['#f1a340', '#f7f7f7', '#998ec3'];\n this.PU_OR_4 = ['#e66101', '#fdb863', '#b2abd2', '#5e3c99'];\n this.PU_OR_5 = ['#e66101', '#fdb863', '#f7f7f7', '#b2abd2', '#5e3c99'];\n this.PU_OR_6 = ['#b35806', '#f1a340', '#fee0b6', '#d8daeb', '#998ec3', '#542788'];\n this.PU_OR_7 = ['#b35806', '#f1a340', '#fee0b6', '#f7f7f7', '#d8daeb', '#998ec3', '#542788'];\n this.PU_OR_8 = ['#b35806', '#e08214', '#fdb863', '#fee0b6', '#d8daeb', '#b2abd2', '#8073ac', '#542788'];\n this.PU_OR_9 = ['#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788'];\n this.PU_OR_10 = ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'];\n this.PU_OR_11 = ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'];\n this.RD_BU_3 = ['#ef8a62', '#f7f7f7', '#67a9cf'];\n this.RD_BU_4 = ['#ca0020', '#f4a582', '#92c5de', '#0571b0'];\n this.RD_BU_5 = ['#ca0020', '#f4a582', '#f7f7f7', '#92c5de', '#0571b0'];\n this.RD_BU_6 = ['#b2182b', '#ef8a62', '#fddbc7', '#d1e5f0', '#67a9cf', '#2166ac'];\n this.RD_BU_7 = ['#b2182b', '#ef8a62', '#fddbc7', '#f7f7f7', '#d1e5f0', '#67a9cf', '#2166ac'];\n this.RD_BU_8 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac'];\n this.RD_BU_9 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac'];\n this.RD_BU_10 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'];\n this.RD_BU_11 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'];\n this.RD_GY_3 = ['#ef8a62', '#ffffff', '#999999'];\n this.RD_GY_4 = ['#ca0020', '#f4a582', '#bababa', '#404040'];\n this.RD_GY_5 = ['#ca0020', '#f4a582', '#ffffff', '#bababa', '#404040'];\n this.RD_GY_6 = ['#b2182b', '#ef8a62', '#fddbc7', '#e0e0e0', '#999999', '#4d4d4d'];\n this.RD_GY_7 = ['#b2182b', '#ef8a62', '#fddbc7', '#ffffff', '#e0e0e0', '#999999', '#4d4d4d'];\n this.RD_GY_8 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#e0e0e0', '#bababa', '#878787', '#4d4d4d'];\n this.RD_GY_9 = ['#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d'];\n this.RD_GY_10 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'];\n this.RD_GY_11 = ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'];\n this.RD_YL_BU_3 = ['#fc8d59', '#ffffbf', '#91bfdb'];\n this.RD_YL_BU_4 = ['#d7191c', '#fdae61', '#abd9e9', '#2c7bb6'];\n this.RD_YL_BU_5 = ['#d7191c', '#fdae61', '#ffffbf', '#abd9e9', '#2c7bb6'];\n this.RD_YL_BU_6 = ['#d73027', '#fc8d59', '#fee090', '#e0f3f8', '#91bfdb', '#4575b4'];\n this.RD_YL_BU_7 = ['#d73027', '#fc8d59', '#fee090', '#ffffbf', '#e0f3f8', '#91bfdb', '#4575b4'];\n this.RD_YL_BU_8 = ['#d73027', '#f46d43', '#fdae61', '#fee090', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4'];\n this.RD_YL_BU_9 = ['#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4'];\n this.RD_YL_BU_10 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'];\n this.RD_YL_BU_11 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'];\n this.RD_YL_GN_3 = ['#fc8d59', '#ffffbf', '#91cf60'];\n this.RD_YL_GN_4 = ['#d7191c', '#fdae61', '#a6d96a', '#1a9641'];\n this.RD_YL_GN_5 = ['#d7191c', '#fdae61', '#ffffbf', '#a6d96a', '#1a9641'];\n this.RD_YL_GN_6 = ['#d73027', '#fc8d59', '#fee08b', '#d9ef8b', '#91cf60', '#1a9850'];\n this.RD_YL_GN_7 = ['#d73027', '#fc8d59', '#fee08b', '#ffffbf', '#d9ef8b', '#91cf60', '#1a9850'];\n this.RD_YL_GN_8 = ['#d73027', '#f46d43', '#fdae61', '#fee08b', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850'];\n this.RD_YL_GN_9 = ['#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850'];\n this.RD_YL_GN_10 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'];\n this.RD_YL_GN_11 = ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'];\n this.SPECTRAL_3 = ['#fc8d59', '#ffffbf', '#99d594'];\n this.SPECTRAL_4 = ['#d7191c', '#fdae61', '#abdda4', '#2b83ba'];\n this.SPECTRAL_5 = ['#d7191c', '#fdae61', '#ffffbf', '#abdda4', '#2b83ba'];\n this.SPECTRAL_6 = ['#d53e4f', '#fc8d59', '#fee08b', '#e6f598', '#99d594', '#3288bd'];\n this.SPECTRAL_7 = ['#d53e4f', '#fc8d59', '#fee08b', '#ffffbf', '#e6f598', '#99d594', '#3288bd'];\n this.SPECTRAL_8 = ['#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#e6f598', '#abdda4', '#66c2a5', '#3288bd'];\n this.SPECTRAL_9 = ['#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd'];\n this.SPECTRAL_10 = ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'];\n this.SPECTRAL_11 = ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'];\n this.BR_BG = [this.BR_BG_3, this.BR_BG_4, this.BR_BG_5, this.BR_BG_6, this.BR_BG_7, this.BR_BG_8, this.BR_BG_9, this.BR_BG_10, this.BR_BG_11];\n this.PI_YG = [this.PI_YG_3, this.PI_YG_4, this.PI_YG_5, this.PI_YG_6, this.PI_YG_7, this.PI_YG_8, this.PI_YG_9, this.PI_YG_10, this.PI_YG_11];\n this.PR_GN = [this.PR_GN_3, this.PR_GN_4, this.PR_GN_5, this.PR_GN_6, this.PR_GN_7, this.PR_GN_8, this.PR_GN_9, this.PR_GN_10, this.PR_GN_11];\n this.PU_OR = [this.PU_OR_3, this.PU_OR_4, this.PU_OR_5, this.PU_OR_6, this.PU_OR_7, this.PU_OR_8, this.PU_OR_9, this.PU_OR_10, this.PU_OR_11];\n this.RD_BU = [this.RD_BU_3, this.RD_BU_4, this.RD_BU_5, this.RD_BU_6, this.RD_BU_7, this.RD_BU_8, this.RD_BU_9, this.RD_BU_10, this.RD_BU_11];\n this.RD_GY = [this.RD_GY_3, this.RD_GY_4, this.RD_GY_5, this.RD_GY_6, this.RD_GY_7, this.RD_GY_8, this.RD_GY_9, this.RD_GY_10, this.RD_GY_11];\n this.RD_YL_BU = [this.RD_YL_BU_3, this.RD_YL_BU_4, this.RD_YL_BU_5, this.RD_YL_BU_6, this.RD_YL_BU_7, this.RD_YL_BU_8, this.RD_YL_BU_9, this.RD_YL_BU_10, this.RD_YL_BU_11];\n this.RD_YL_GN = [this.RD_YL_GN_3, this.RD_YL_GN_4, this.RD_YL_GN_5, this.RD_YL_GN_6, this.RD_YL_GN_7, this.RD_YL_GN_8, this.RD_YL_GN_9, this.RD_YL_GN_10, this.RD_YL_GN_11];\n this.SPECTRAL = [this.SPECTRAL_3, this.SPECTRAL_4, this.SPECTRAL_5, this.SPECTRAL_6, this.SPECTRAL_7, this.SPECTRAL_8, this.SPECTRAL_9, this.SPECTRAL_10, this.SPECTRAL_11];\n this.ACCENT_3 = ['#7fc97f', '#beaed4', '#fdc086'];\n this.ACCENT_4 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99'];\n this.ACCENT_5 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0'];\n this.ACCENT_6 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f'];\n this.ACCENT_7 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17'];\n this.ACCENT_8 = ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'];\n this.DARK_2_3 = ['#1b9e77', '#d95f02', '#7570b3'];\n this.DARK_2_4 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a'];\n this.DARK_2_5 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e'];\n this.DARK_2_6 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02'];\n this.DARK_2_7 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d'];\n this.DARK_2_8 = ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'];\n this.PAIRED_3 = ['#a6cee3', '#1f78b4', '#b2df8a'];\n this.PAIRED_4 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c'];\n this.PAIRED_5 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99'];\n this.PAIRED_6 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c'];\n this.PAIRED_7 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f'];\n this.PAIRED_8 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00'];\n this.PAIRED_9 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6'];\n this.PAIRED_10 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a'];\n this.PAIRED_11 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99'];\n this.PAIRED_12 = ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'];\n this.PASTEL_1_3 = ['#fbb4ae', '#b3cde3', '#ccebc5'];\n this.PASTEL_1_4 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4'];\n this.PASTEL_1_5 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6'];\n this.PASTEL_1_6 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc'];\n this.PASTEL_1_7 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd'];\n this.PASTEL_1_8 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec'];\n this.PASTEL_1_9 = ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'];\n this.PASTEL_2_3 = ['#b3e2cd', '#fdcdac', '#cbd5e8'];\n this.PASTEL_2_4 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4'];\n this.PASTEL_2_5 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9'];\n this.PASTEL_2_6 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae'];\n this.PASTEL_2_7 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc'];\n this.PASTEL_2_8 = ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'];\n this.SET_1_3 = ['#e41a1c', '#377eb8', '#4daf4a'];\n this.SET_1_4 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3'];\n this.SET_1_5 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00'];\n this.SET_1_6 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33'];\n this.SET_1_7 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628'];\n this.SET_1_8 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf'];\n this.SET_1_9 = ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'];\n this.SET_2_3 = ['#66c2a5', '#fc8d62', '#8da0cb'];\n this.SET_2_4 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3'];\n this.SET_2_5 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854'];\n this.SET_2_6 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f'];\n this.SET_2_7 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494'];\n this.SET_2_8 = ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'];\n this.SET_3_3 = ['#8dd3c7', '#ffffb3', '#bebada'];\n this.SET_3_4 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072'];\n this.SET_3_5 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3'];\n this.SET_3_6 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462'];\n this.SET_3_7 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69'];\n this.SET_3_8 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5'];\n this.SET_3_9 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9'];\n this.SET_3_10 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd'];\n this.SET_3_11 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5'];\n this.SET_3_12 = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'];\n this.ACCENT = [this.ACCENT_3, this.ACCENT_4, this.ACCENT_5, this.ACCENT_6, this.ACCENT_7, this.ACCENT_8];\n this.DARK_2 = [this.DARK_2_3, this.DARK_2_4, this.DARK_2_5, this.DARK_2_6, this.DARK_2_7, this.DARK_2_8];\n this.PAIRED = [this.PAIRED_3, this.PAIRED_4, this.PAIRED_5, this.PAIRED_6, this.PAIRED_7, this.PAIRED_8, this.PAIRED_9, this.PAIRED_10, this.PAIRED_11, this.PAIRED_12];\n this.PASTEL_1 = [this.PASTEL_1_3, this.PASTEL_1_4, this.PASTEL_1_5, this.PASTEL_1_6, this.PASTEL_1_7, this.PASTEL_1_8, this.PASTEL_1_9];\n this.PASTEL_2 = [this.PASTEL_2_3, this.PASTEL_2_4, this.PASTEL_2_5, this.PASTEL_2_6, this.PASTEL_2_7, this.PASTEL_2_8];\n this.SET_1 = [this.SET_1_3, this.SET_1_4, this.SET_1_5, this.SET_1_6, this.SET_1_7, this.SET_1_8, this.SET_1_9];\n this.SET_2 = [this.SET_2_3, this.SET_2_4, this.SET_2_5, this.SET_2_6, this.SET_2_7, this.SET_2_8];\n this.SET_3 = [this.SET_3_3, this.SET_3_4, this.SET_3_5, this.SET_3_6, this.SET_3_7, this.SET_3_8, this.SET_3_9, this.SET_3_10, this.SET_3_11, this.SET_3_12];\n }\n ColorSets.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorSets',\n interfaces: []\n };\n var ColorSets_instance = null;\n function ColorSets_getInstance() {\n if (ColorSets_instance === null) {\n new ColorSets();\n }return ColorSets_instance;\n }\n function ColorUtil() {\n ColorUtil_instance = this;\n }\n ColorUtil.prototype.genColors_2c6x13$ = function (count, baseColors) {\n var tmp$;\n var rValues = ArrayList_init();\n var gValues = ArrayList_init();\n var bValues = ArrayList_init();\n tmp$ = baseColors.iterator();\n while (tmp$.hasNext()) {\n var baseColor = tmp$.next();\n rValues.add_11rb$(baseColor.red);\n gValues.add_11rb$(baseColor.green);\n bValues.add_11rb$(baseColor.blue);\n }\n var rChannelGen = new RGBChannelGen(rValues);\n var gChannelGen = new RGBChannelGen(gValues);\n var bChannelGen = new RGBChannelGen(bValues);\n var rValuesGen = rChannelGen.generate_za3lpa$(count).iterator();\n var gValuesGen = gChannelGen.generate_za3lpa$(count).iterator();\n var bValuesGen = bChannelGen.generate_za3lpa$(count).iterator();\n var colorsGen = ArrayList_init_0(count);\n while (rValuesGen.hasNext() && gValuesGen.hasNext() && bValuesGen.hasNext()) {\n var colorGen = new Color(rValuesGen.next(), gValuesGen.next(), bValuesGen.next());\n colorsGen.add_11rb$(colorGen);\n }\n return colorsGen;\n };\n ColorUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'ColorUtil',\n interfaces: []\n };\n var ColorUtil_instance = null;\n function ColorUtil_getInstance() {\n if (ColorUtil_instance === null) {\n new ColorUtil();\n }return ColorUtil_instance;\n }\n function PaletteUtil() {\n PaletteUtil_instance = this;\n this.NULL_COLOR = Color.Companion.LIGHT_GRAY;\n this.EXTENSIBLE_COLOR_SCHEMES_0 = setOf([ColorPalette$Qualitative$Accent_getInstance(), ColorPalette$Qualitative$Dark2_getInstance(), ColorPalette$Qualitative$Pastel1_getInstance(), ColorPalette$Qualitative$Pastel2_getInstance(), ColorPalette$Qualitative$Set1_getInstance(), ColorPalette$Qualitative$Set2_getInstance(), ColorPalette$Qualitative$Set3_getInstance()]);\n this.PAL_TYPE_BY_PAL_NAME_0 = null;\n var map = HashMap_init();\n var $receiver = ColorPalette$Sequential$values();\n var destination = ArrayList_init_0($receiver.length);\n var tmp$;\n for (tmp$ = 0; tmp$ !== $receiver.length; ++tmp$) {\n var item = $receiver[tmp$];\n destination.add_11rb$(item.name);\n }\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n var value = ColorPalette$Type$SEQUENTIAL_getInstance();\n map.put_xwzc9p$(element, value);\n }\n var $receiver_0 = ColorPalette$Diverging$values();\n var destination_0 = ArrayList_init_0($receiver_0.length);\n var tmp$_1;\n for (tmp$_1 = 0; tmp$_1 !== $receiver_0.length; ++tmp$_1) {\n var item_0 = $receiver_0[tmp$_1];\n destination_0.add_11rb$(item_0.name);\n }\n var tmp$_2;\n tmp$_2 = destination_0.iterator();\n while (tmp$_2.hasNext()) {\n var element_0 = tmp$_2.next();\n var value_0 = ColorPalette$Type$DIVERGING_getInstance();\n map.put_xwzc9p$(element_0, value_0);\n }\n var $receiver_1 = ColorPalette$Qualitative$values();\n var destination_1 = ArrayList_init_0($receiver_1.length);\n var tmp$_3;\n for (tmp$_3 = 0; tmp$_3 !== $receiver_1.length; ++tmp$_3) {\n var item_1 = $receiver_1[tmp$_3];\n destination_1.add_11rb$(item_1.name);\n }\n var tmp$_4;\n tmp$_4 = destination_1.iterator();\n while (tmp$_4.hasNext()) {\n var element_1 = tmp$_4.next();\n var value_1 = ColorPalette$Type$QUALITATIVE_getInstance();\n map.put_xwzc9p$(element_1, value_1);\n }\n this.PAL_TYPE_BY_PAL_NAME_0 = map;\n }\n PaletteUtil.prototype.isExtensibleScheme_0 = function (colorScheme) {\n return this.EXTENSIBLE_COLOR_SCHEMES_0.contains_11rb$(colorScheme);\n };\n PaletteUtil.prototype.schemeColors_7q5c77$ = function (colorScheme, colorCount) {\n var colorsHex = colorScheme.getColors_za3lpa$(colorCount);\n var colors = this.fromColorsHex_0(colorsHex);\n if (colorsHex.length < colorCount && this.isExtensibleScheme_0(colorScheme)) {\n var addColors = ColorUtil_getInstance().genColors_2c6x13$(colorCount - colorsHex.length | 0, colors);\n return collect.Iterables.toList_yl67zr$(collect.Iterables.concat_yxozss$(colors, addColors));\n }return colors;\n };\n PaletteUtil.prototype.fromColorsHex_0 = function (hexColors) {\n var tmp$;\n var colors = ArrayList_init();\n for (tmp$ = 0; tmp$ !== hexColors.length; ++tmp$) {\n var hexColor = hexColors[tmp$];\n try {\n colors.add_11rb$(Color.Companion.parseHex_61zpoe$(hexColor));\n } catch (e) {\n if (!Kotlin.isType(e, Exception))\n throw e;\n }\n }\n return colors;\n };\n PaletteUtil.prototype.paletteTypeByPaletteName_61zpoe$ = function (paletteName) {\n return this.PAL_TYPE_BY_PAL_NAME_0.get_11rb$(paletteName);\n };\n PaletteUtil.prototype.colorSchemeByIndex_vfydh1$ = function (paletteType, index) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n switch (paletteType.name) {\n case 'SEQUENTIAL':\n tmp$_2 = Kotlin.isArray(tmp$ = ColorPalette$Sequential$values()) ? tmp$ : throwCCE();\n break;\n case 'DIVERGING':\n tmp$_2 = Kotlin.isArray(tmp$_0 = ColorPalette$Diverging$values()) ? tmp$_0 : throwCCE();\n break;\n case 'QUALITATIVE':\n tmp$_2 = Kotlin.isArray(tmp$_1 = ColorPalette$Qualitative$values()) ? tmp$_1 : throwCCE();\n break;\n default:tmp$_2 = Kotlin.noWhenBranchMatched();\n break;\n }\n var values = tmp$_2;\n return values[index % values.length];\n };\n PaletteUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'PaletteUtil',\n interfaces: []\n };\n var PaletteUtil_instance = null;\n function PaletteUtil_getInstance() {\n if (PaletteUtil_instance === null) {\n new PaletteUtil();\n }return PaletteUtil_instance;\n }\n function RGBChannelGen(myBaseValues) {\n RGBChannelGen$Companion_getInstance();\n this.myBaseValues_0 = myBaseValues;\n this.myRange_0 = null;\n var tmp$, tmp$_0;\n var min = Ordering.Companion.natural_dahdeg$().min_m5x2f4$(this.myBaseValues_0);\n var max = Ordering.Companion.natural_dahdeg$().max_m5x2f4$(this.myBaseValues_0);\n tmp$ = RGBChannelGen$Companion_getInstance().RANGES_0;\n for (tmp$_0 = 0; tmp$_0 !== tmp$.length; ++tmp$_0) {\n var r = tmp$[tmp$_0];\n if (r.contains_mef7kx$(min) || r.contains_mef7kx$(max)) {\n if (this.myRange_0 == null) {\n this.myRange_0 = r;\n } else {\n this.myRange_0 = ensureNotNull(this.myRange_0).span_d226ot$(r);\n }\n }}\n }\n RGBChannelGen.prototype.generate_za3lpa$ = function (maxCount) {\n var tmp$;\n var x = maxCount / this.myBaseValues_0.size;\n var genPerBaseValue = numberToInt(JsMath.ceil(x));\n var a = this.maxValueCount_0() - 1 | 0;\n var b = genPerBaseValue;\n genPerBaseValue = JsMath.min(a, b);\n var x_0 = this.maxValueCount_0() / (genPerBaseValue + 1 | 0);\n var inc = numberToInt(JsMath.floor(x_0));\n var b_0 = numberToInt(inc * 1.33);\n inc = JsMath.max(1, b_0);\n var values = ArrayList_init_0(maxCount);\n var baseValues = this.myBaseValues_0;\n while (values.size < maxCount) {\n var nextBaseValues = ArrayList_init();\n tmp$ = baseValues.iterator();\n while (tmp$.hasNext()) {\n var baseValue = tmp$.next();\n var genValue = baseValue + inc | 0;\n if (!ensureNotNull(this.myRange_0).contains_mef7kx$(genValue)) {\n genValue = ensureNotNull(this.myRange_0).lowerEnd + (genValue - ensureNotNull(this.myRange_0).upperEnd) | 0;\n }values.add_11rb$(genValue);\n nextBaseValues.add_11rb$(genValue);\n if (values.size === maxCount) {\n break;\n }}\n baseValues = nextBaseValues;\n }\n return values;\n };\n RGBChannelGen.prototype.maxValueCount_0 = function () {\n return ensureNotNull(this.myRange_0).upperEnd - ensureNotNull(this.myRange_0).lowerEnd + 1 | 0;\n };\n function RGBChannelGen$Companion() {\n RGBChannelGen$Companion_instance = this;\n this.RANGES_0 = [new ClosedRange(0, 37), new ClosedRange(38, 97), new ClosedRange(98, 157), new ClosedRange(158, 217), new ClosedRange(218, 255)];\n }\n RGBChannelGen$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RGBChannelGen$Companion_instance = null;\n function RGBChannelGen$Companion_getInstance() {\n if (RGBChannelGen$Companion_instance === null) {\n new RGBChannelGen$Companion();\n }return RGBChannelGen$Companion_instance;\n }\n RGBChannelGen.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RGBChannelGen',\n interfaces: []\n };\n function DataType(name, ordinal) {\n Enum.call(this);\n this.name$ = name;\n this.ordinal$ = ordinal;\n }\n function DataType_initFields() {\n DataType_initFields = function () {\n };\n DataType$NUMBER_instance = new DataType('NUMBER', 0);\n DataType$STRING_instance = new DataType('STRING', 1);\n DataType$INSTANT_instance = new DataType('INSTANT', 2);\n DataType$INSTANT_OF_DAY_instance = new DataType('INSTANT_OF_DAY', 3);\n DataType$INSTANT_OF_MONTH_instance = new DataType('INSTANT_OF_MONTH', 4);\n DataType$INSTANT_OF_QUARTER_instance = new DataType('INSTANT_OF_QUARTER', 5);\n DataType$INSTANT_OF_HALF_YEAR_instance = new DataType('INSTANT_OF_HALF_YEAR', 6);\n DataType$INSTANT_OF_YEAR_instance = new DataType('INSTANT_OF_YEAR', 7);\n }\n var DataType$NUMBER_instance;\n function DataType$NUMBER_getInstance() {\n DataType_initFields();\n return DataType$NUMBER_instance;\n }\n var DataType$STRING_instance;\n function DataType$STRING_getInstance() {\n DataType_initFields();\n return DataType$STRING_instance;\n }\n var DataType$INSTANT_instance;\n function DataType$INSTANT_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_instance;\n }\n var DataType$INSTANT_OF_DAY_instance;\n function DataType$INSTANT_OF_DAY_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_DAY_instance;\n }\n var DataType$INSTANT_OF_MONTH_instance;\n function DataType$INSTANT_OF_MONTH_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_MONTH_instance;\n }\n var DataType$INSTANT_OF_QUARTER_instance;\n function DataType$INSTANT_OF_QUARTER_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_QUARTER_instance;\n }\n var DataType$INSTANT_OF_HALF_YEAR_instance;\n function DataType$INSTANT_OF_HALF_YEAR_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_HALF_YEAR_instance;\n }\n var DataType$INSTANT_OF_YEAR_instance;\n function DataType$INSTANT_OF_YEAR_getInstance() {\n DataType_initFields();\n return DataType$INSTANT_OF_YEAR_instance;\n }\n Object.defineProperty(DataType.prototype, 'isTime', {\n configurable: true,\n get: function () {\n return this === DataType$INSTANT_getInstance() || this.isTimeInterval;\n }\n });\n Object.defineProperty(DataType.prototype, 'isTimeInterval', {\n configurable: true,\n get: function () {\n return this === DataType$INSTANT_OF_DAY_getInstance() || this === DataType$INSTANT_OF_MONTH_getInstance() || this === DataType$INSTANT_OF_QUARTER_getInstance() || this === DataType$INSTANT_OF_HALF_YEAR_getInstance() || this === DataType$INSTANT_OF_YEAR_getInstance();\n }\n });\n Object.defineProperty(DataType.prototype, 'isString', {\n configurable: true,\n get: function () {\n return this === DataType$STRING_getInstance();\n }\n });\n Object.defineProperty(DataType.prototype, 'isNumber', {\n configurable: true,\n get: function () {\n return this === DataType$NUMBER_getInstance();\n }\n });\n DataType.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DataType',\n interfaces: [Enum]\n };\n function DataType$values() {\n return [DataType$NUMBER_getInstance(), DataType$STRING_getInstance(), DataType$INSTANT_getInstance(), DataType$INSTANT_OF_DAY_getInstance(), DataType$INSTANT_OF_MONTH_getInstance(), DataType$INSTANT_OF_QUARTER_getInstance(), DataType$INSTANT_OF_HALF_YEAR_getInstance(), DataType$INSTANT_OF_YEAR_getInstance()];\n }\n DataType.values = DataType$values;\n function DataType$valueOf(name) {\n switch (name) {\n case 'NUMBER':\n return DataType$NUMBER_getInstance();\n case 'STRING':\n return DataType$STRING_getInstance();\n case 'INSTANT':\n return DataType$INSTANT_getInstance();\n case 'INSTANT_OF_DAY':\n return DataType$INSTANT_OF_DAY_getInstance();\n case 'INSTANT_OF_MONTH':\n return DataType$INSTANT_OF_MONTH_getInstance();\n case 'INSTANT_OF_QUARTER':\n return DataType$INSTANT_OF_QUARTER_getInstance();\n case 'INSTANT_OF_HALF_YEAR':\n return DataType$INSTANT_OF_HALF_YEAR_getInstance();\n case 'INSTANT_OF_YEAR':\n return DataType$INSTANT_OF_YEAR_getInstance();\n default:throwISE('No enum constant jetbrains.datalore.plot.common.data.DataType.' + name);\n }\n }\n DataType.valueOf_61zpoe$ = DataType$valueOf;\n function RegularMeshDetector(myError) {\n RegularMeshDetector$Companion_getInstance();\n this.myError_xmg86j$_0 = myError;\n this.isMesh_gozhck$_0 = false;\n this.resolution_byvhl$_0 = 0;\n }\n Object.defineProperty(RegularMeshDetector.prototype, 'isMesh', {\n configurable: true,\n get: function () {\n return this.isMesh_gozhck$_0;\n },\n set: function (isMesh) {\n this.isMesh_gozhck$_0 = isMesh;\n }\n });\n Object.defineProperty(RegularMeshDetector.prototype, 'resolution', {\n configurable: true,\n get: function () {\n if (!this.isMesh) {\n var message = 'Not a mesh';\n throw IllegalStateException_init(message.toString());\n }return this.resolution_byvhl$_0;\n },\n set: function (resolution) {\n this.resolution_byvhl$_0 = resolution;\n }\n });\n RegularMeshDetector.prototype.equalsEnough_lu1900$ = function (d1, d2) {\n var tmp$ = d1 === d2;\n if (!tmp$) {\n var x = d1 - d2;\n tmp$ = JsMath.abs(x) <= this.myError_xmg86j$_0;\n }return tmp$;\n };\n RegularMeshDetector.prototype.nearZero_14dthe$ = function (d) {\n return JsMath.abs(d) <= this.myError_xmg86j$_0;\n };\n function RegularMeshDetector$MyRowDetector(myMinRowSize, error, values) {\n RegularMeshDetector.call(this, error);\n this.myMinRowSize_0 = myMinRowSize;\n this.init_0(values);\n }\n RegularMeshDetector$MyRowDetector.prototype.init_0 = function (values) {\n var tmp$;\n this.isMesh = false;\n var distance = 0.0;\n var distanceInitialized = false;\n var prevValue = null;\n var count = this.myMinRowSize_0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (!SeriesUtil_getInstance().isFinite_yrwdxb$(value)) {\n return;\n }if (prevValue != null) {\n var dist = ensureNotNull(value) - prevValue;\n if (this.nearZero_14dthe$(dist)) {\n return;\n }if (distanceInitialized) {\n if (!this.equalsEnough_lu1900$(dist, distance)) {\n return;\n }} else {\n distance = dist;\n distanceInitialized = true;\n }\n }prevValue = value;\n if ((count = count - 1 | 0, count) === 0) {\n break;\n }}\n if (distanceInitialized && count === 0) {\n var x = distance;\n this.resolution = JsMath.abs(x);\n this.isMesh = true;\n }};\n RegularMeshDetector$MyRowDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyRowDetector',\n interfaces: [RegularMeshDetector]\n };\n function RegularMeshDetector$MyColumnDetector(myMinRowSize, error, values) {\n RegularMeshDetector.call(this, error);\n this.myMinRowSize_0 = myMinRowSize;\n this.init_0(values);\n }\n RegularMeshDetector$MyColumnDetector.prototype.init_0 = function (values) {\n var tmp$;\n this.isMesh = false;\n var rowSize = new Int32Array([0, 0]);\n var rowValue = [null, null];\n var rowIndex = 0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (!SeriesUtil_getInstance().isFinite_yrwdxb$(value)) {\n break;\n }if (rowValue[rowIndex] == null) {\n rowValue[rowIndex] = value;\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else if (this.equalsEnough_lu1900$(ensureNotNull(rowValue[rowIndex]), ensureNotNull(value))) {\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else {\n if (rowIndex === 0) {\n rowIndex = rowIndex + 1 | 0;\n rowValue[rowIndex] = value;\n rowSize[rowIndex] = rowSize[rowIndex] + 1 | 0;\n } else {\n break;\n }\n }\n }\n if (rowSize[0] === rowSize[1] && rowSize[0] >= this.myMinRowSize_0) {\n this.isMesh = true;\n var x = ensureNotNull(rowValue[1]) - ensureNotNull(rowValue[0]);\n this.resolution = JsMath.abs(x);\n }};\n RegularMeshDetector$MyColumnDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MyColumnDetector',\n interfaces: [RegularMeshDetector]\n };\n function RegularMeshDetector$Companion() {\n RegularMeshDetector$Companion_instance = this;\n this.NO_MESH_0 = new RegularMeshDetector$Companion$NO_MESH$ObjectLiteral(0.0);\n }\n RegularMeshDetector$Companion.prototype.tryRow_l63ks6$ = function (values) {\n var v0 = collect.Iterables.get_dhabsj$(values, 0, null);\n var v1 = collect.Iterables.get_dhabsj$(values, 1, null);\n if (v0 == null || v1 == null) {\n return this.NO_MESH_0;\n }var x = v1 - v0;\n var delta = JsMath.abs(x);\n if (!isFinite(delta)) {\n return this.NO_MESH_0;\n }var error = delta / 10000.0;\n return this.tryRow_4sxsdq$(50, error, values);\n };\n RegularMeshDetector$Companion.prototype.tryRow_4sxsdq$ = function (minRowSize, error, values) {\n return new RegularMeshDetector$MyRowDetector(minRowSize, error, values);\n };\n RegularMeshDetector$Companion.prototype.tryColumn_l63ks6$ = function (values) {\n return this.tryColumn_4sxsdq$(50, SeriesUtil_getInstance().TINY, values);\n };\n RegularMeshDetector$Companion.prototype.tryColumn_4sxsdq$ = function (minRowSize, error, values) {\n return new RegularMeshDetector$MyColumnDetector(minRowSize, error, values);\n };\n function RegularMeshDetector$Companion$NO_MESH$ObjectLiteral(myError) {\n RegularMeshDetector.call(this, myError);\n }\n Object.defineProperty(RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.prototype, 'isMesh', {\n configurable: true,\n get: function () {\n return false;\n },\n set: function (value) {\n Kotlin.callSetter(this, RegularMeshDetector.prototype, 'isMesh', value);\n }\n });\n RegularMeshDetector$Companion$NO_MESH$ObjectLiteral.$metadata$ = {\n kind: Kind_CLASS,\n interfaces: [RegularMeshDetector]\n };\n RegularMeshDetector$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var RegularMeshDetector$Companion_instance = null;\n function RegularMeshDetector$Companion_getInstance() {\n if (RegularMeshDetector$Companion_instance === null) {\n new RegularMeshDetector$Companion();\n }return RegularMeshDetector$Companion_instance;\n }\n RegularMeshDetector.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'RegularMeshDetector',\n interfaces: []\n };\n function SeriesUtil() {\n SeriesUtil_instance = this;\n this.TINY = 1.0E-50;\n this.REAL_NUMBER_0 = SeriesUtil$REAL_NUMBER$lambda(this);\n this.NEGATIVE_NUMBER = SeriesUtil$NEGATIVE_NUMBER$lambda;\n }\n SeriesUtil.prototype.isSubTiny_14dthe$ = function (value) {\n return value < this.TINY;\n };\n SeriesUtil.prototype.isSubTiny_4fzjta$ = function (range) {\n return this.isFinite_4fzjta$(range) && this.span_4fzjta$(range) < this.TINY;\n };\n SeriesUtil.prototype.checkedDoubles_fakr2g$ = function (values) {\n return new SeriesUtil$CheckedDoubleIterable(values);\n };\n SeriesUtil.prototype.checkedDoubles_9ma18$ = function (values) {\n return new SeriesUtil$CheckedDoubleList(values);\n };\n SeriesUtil.prototype.isFinite_yrwdxb$ = function (v) {\n return v != null && isFinite(v);\n };\n SeriesUtil.prototype.asFinite_z03gcz$ = function (v, defaultValue) {\n return v != null && isFinite(v) ? v : defaultValue;\n };\n SeriesUtil.prototype.isFinite_14dthe$ = function (v) {\n return isFinite(v);\n };\n SeriesUtil.prototype.allFinite_jma9l8$ = function (v0, v1) {\n return this.isFinite_yrwdxb$(v0) && this.isFinite_yrwdxb$(v1);\n };\n SeriesUtil.prototype.allFinite_xjrefz$ = function (v0, v1, v2) {\n return this.allFinite_jma9l8$(v0, v1) && this.isFinite_yrwdxb$(v2);\n };\n SeriesUtil.prototype.allFinite_rd1tgs$ = function (v0, v1, v2, v3) {\n return this.allFinite_xjrefz$(v0, v1, v2) && this.isFinite_yrwdxb$(v3);\n };\n SeriesUtil.prototype.filterFinite_10sy24$ = function (l0, l1) {\n var tmp$, tmp$_0, tmp$_1, tmp$_2;\n if (!(l0.size === l1.size)) {\n var message = 'Check failed.';\n throw IllegalStateException_init(message.toString());\n }var l0Copy = ArrayList_init();\n var l1Copy = ArrayList_init();\n var copy = false;\n var i = 0;\n for (var tmp$_3 = l0.iterator(); tmp$_3.hasNext(); ++i) {\n var v0 = tmp$_3.next();\n var tmp$_4, tmp$_5, tmp$_6, tmp$_7;\n var v1 = l1.get_za3lpa$(i);\n if (!this.allFinite_jma9l8$(v0, v1)) {\n if (!copy) {\n l0Copy.addAll_brywnq$(Kotlin.isType(tmp$_4 = toList(take(l0, i)), List) ? tmp$_4 : throwCCE());\n l1Copy.addAll_brywnq$(Kotlin.isType(tmp$_5 = toList(take(l1, i)), List) ? tmp$_5 : throwCCE());\n copy = true;\n }continue;\n }if (copy) {\n l0Copy.add_11rb$(typeof (tmp$_6 = v0) === 'number' ? tmp$_6 : throwCCE());\n l1Copy.add_11rb$(typeof (tmp$_7 = v1) === 'number' ? tmp$_7 : throwCCE());\n }}\n tmp$ = copy;\n if (tmp$ === true)\n tmp$_2 = listOf([l0Copy, l1Copy]);\n else if (tmp$ === false) {\n tmp$_2 = listOf([Kotlin.isType(tmp$_0 = l0, List) ? tmp$_0 : throwCCE(), Kotlin.isType(tmp$_1 = l1, List) ? tmp$_1 : throwCCE()]);\n } else\n tmp$_2 = Kotlin.noWhenBranchMatched();\n return tmp$_2;\n };\n SeriesUtil.prototype.range_l63ks6$ = function (values) {\n var tmp$;\n var min = 0.0;\n var max = 0.0;\n var inited = false;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (this.isFinite_yrwdxb$(v)) {\n if (inited) {\n var a = min;\n var b = ensureNotNull(v);\n min = JsMath.min(a, b);\n var a_0 = max;\n max = JsMath.max(a_0, v);\n } else {\n max = ensureNotNull(v);\n min = max;\n inited = true;\n }\n }}\n return inited ? new ClosedRange(min, max) : null;\n };\n SeriesUtil.prototype.resolution_u62iiw$ = function (values, naValue) {\n var tmp$;\n var rowDetector = RegularMeshDetector$Companion_getInstance().tryRow_l63ks6$(values);\n if (rowDetector.isMesh) {\n return rowDetector.resolution;\n }var columnDetector = RegularMeshDetector$Companion_getInstance().tryColumn_l63ks6$(values);\n if (columnDetector.isMesh) {\n tmp$ = columnDetector.resolution;\n } else {\n tmp$ = this.resolutionFullScan_0(values, naValue);\n }\n return tmp$;\n };\n SeriesUtil.prototype.resolutionFullScan_0 = function (values, naValue) {\n var tmp$;\n var goodDataVector = Kotlin.isType(tmp$ = collect.Iterables.filter_fpit1u$(values, this.REAL_NUMBER_0), Iterable) ? tmp$ : throwCCE();\n if (collect.Iterables.isEmpty_fakr2g$(goodDataVector)) {\n return naValue;\n }var copy = Ordering.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(goodDataVector);\n if (copy.size < 2) {\n return naValue;\n }var it = copy.iterator();\n var resolution = naValue;\n var allZero = true;\n var prev = it.next();\n while (it.hasNext()) {\n var curr = it.next();\n var dist = curr - prev;\n if (dist > 0 && (dist < resolution || allZero)) {\n allZero = false;\n resolution = dist;\n }prev = curr;\n }\n return resolution;\n };\n SeriesUtil.prototype.ensureApplicableRange_4am1sd$ = function (range) {\n if (range == null) {\n return new ClosedRange(-0.5, 0.5);\n }if (this.isSubTiny_4fzjta$(range)) {\n var median = range.lowerEnd;\n return new ClosedRange(median - 0.5, median + 0.5);\n }return range;\n };\n SeriesUtil.prototype.span_4fzjta$ = function (range) {\n if (!this.isFinite_4fzjta$(range)) {\n var message = 'range must be finite: ' + range;\n throw IllegalArgumentException_init(message.toString());\n }return range.upperEnd - range.lowerEnd;\n };\n SeriesUtil.prototype.span_t7esj2$ = function (range0, range1) {\n if (range0 == null)\n return range1;\n return range1 == null ? range0 : range0.span_d226ot$(range1);\n };\n SeriesUtil.prototype.expand_mdyssk$ = function (range, newSpan) {\n var expand = (newSpan - this.span_4fzjta$(range)) / 2;\n return this.expand_wws5xy$(range, expand, expand);\n };\n SeriesUtil.prototype.expand_wws5xy$ = function (range, lowerExpand, upperExpand) {\n return new ClosedRange(range.lowerEnd - lowerExpand, range.upperEnd + upperExpand);\n };\n SeriesUtil.prototype.isFinite_4fzjta$ = function (range) {\n return !(isInfinite(range.lowerEnd) || isInfinite(range.upperEnd));\n };\n SeriesUtil.prototype.matchingIndices_3vukww$ = function (list, matchedValue) {\n var result = ArrayList_init();\n for (var i = 0; i !== list.size; ++i) {\n if (equals(matchedValue, list.get_za3lpa$(i))) {\n result.add_11rb$(i);\n }}\n return result;\n };\n SeriesUtil.prototype.matchingIndices_ut89is$ = function (list, matchedValues) {\n var result = ArrayList_init();\n for (var i = 0; i !== list.size; ++i) {\n if (contains(matchedValues, list.get_za3lpa$(i))) {\n result.add_11rb$(i);\n }}\n return result;\n };\n SeriesUtil.prototype.pickAtIndices_ge51dg$ = function (list, indices) {\n var tmp$;\n var initialCapacity = indices.size > 10 ? indices.size : 10;\n var result = ArrayList_init_0(initialCapacity);\n tmp$ = indices.iterator();\n while (tmp$.hasNext()) {\n var index = tmp$.next();\n if (index < list.size) {\n result.add_11rb$(list.get_za3lpa$(index));\n }}\n return result;\n };\n SeriesUtil.prototype.pickAtIndices_jlfzfq$ = function (list, indices) {\n var result = ArrayList_init_0(list.size);\n for (var i = 0; i !== list.size; ++i) {\n if (indices.contains_11rb$(i)) {\n result.add_11rb$(list.get_za3lpa$(i));\n }}\n return result;\n };\n SeriesUtil.prototype.skipAtIndices_jlfzfq$ = function (list, indices) {\n var result = ArrayList_init_0(list.size);\n for (var i = 0; i !== list.size; ++i) {\n if (!indices.contains_11rb$(i)) {\n result.add_11rb$(list.get_za3lpa$(i));\n }}\n return result;\n };\n SeriesUtil.prototype.firstNotNull_rath1t$ = function (list, defaultValue) {\n var tmp$;\n tmp$ = list.iterator();\n while (tmp$.hasNext()) {\n var v = tmp$.next();\n if (v != null) {\n return v;\n }}\n return defaultValue;\n };\n SeriesUtil.prototype.mean_l4tjj7$ = function (values, defaultValue) {\n var tmp$;\n var result = 0.0;\n var i = -1.0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (value != null && isFinite(value)) {\n i = i + 1;\n result = value / (i + 1) + result * (i / (i + 1));\n }}\n return i >= 0 ? result : defaultValue;\n };\n SeriesUtil.prototype.sum_k9kaly$ = function (values) {\n var tmp$;\n var result = 0.0;\n tmp$ = values.iterator();\n while (tmp$.hasNext()) {\n var value = tmp$.next();\n if (value != null && isFinite(value)) {\n result += value;\n }}\n return result;\n };\n SeriesUtil.prototype.toDoubleList_8a6n3n$ = function (l) {\n return l == null ? null : (new SeriesUtil$CheckedDoubleList(l)).cast();\n };\n function SeriesUtil$CheckedDoubleList(list) {\n SeriesUtil$CheckedDoubleIterable.call(this, list);\n }\n SeriesUtil$CheckedDoubleList.prototype.cast = function () {\n var tmp$;\n return Kotlin.isType(tmp$ = SeriesUtil$CheckedDoubleIterable.prototype.cast.call(this), List) ? tmp$ : throwCCE();\n };\n SeriesUtil$CheckedDoubleList.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CheckedDoubleList',\n interfaces: [SeriesUtil$CheckedDoubleIterable]\n };\n function SeriesUtil$CheckedDoubleIterable(myIterable) {\n this.myIterable_n2c9gl$_0 = myIterable;\n this.myEmpty_3k4vh6$_0 = collect.Iterables.isEmpty_fakr2g$(this.myIterable_n2c9gl$_0);\n this.myCanBeCast_310oqz$_0 = false;\n var tmp$;\n if (this.myEmpty_3k4vh6$_0) {\n tmp$ = true;\n } else {\n tmp$ = collect.Iterables.all_fpit1u$(collect.Iterables.filter_fpit1u$(this.myIterable_n2c9gl$_0, SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda), SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda_0);\n }\n this.myCanBeCast_310oqz$_0 = tmp$;\n }\n SeriesUtil$CheckedDoubleIterable.prototype.notEmptyAndCanBeCast = function () {\n return !this.myEmpty_3k4vh6$_0 && this.myCanBeCast_310oqz$_0;\n };\n SeriesUtil$CheckedDoubleIterable.prototype.canBeCast = function () {\n return this.myCanBeCast_310oqz$_0;\n };\n SeriesUtil$CheckedDoubleIterable.prototype.cast = function () {\n var tmp$;\n if (!this.myCanBeCast_310oqz$_0) {\n var message = \"Can't cast to a collection of Double(s)\";\n throw IllegalStateException_init(message.toString());\n }return Kotlin.isType(tmp$ = this.myIterable_n2c9gl$_0, Iterable) ? tmp$ : throwCCE();\n };\n function SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda(it) {\n return it != null;\n }\n function SeriesUtil$SeriesUtil$CheckedDoubleIterable_init$lambda_0(input) {\n return typeof input === 'number';\n }\n SeriesUtil$CheckedDoubleIterable.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'CheckedDoubleIterable',\n interfaces: []\n };\n function SeriesUtil$REAL_NUMBER$lambda(this$SeriesUtil) {\n return function (it) {\n return this$SeriesUtil.isFinite_yrwdxb$(it);\n };\n }\n function SeriesUtil$NEGATIVE_NUMBER$lambda(input) {\n return input < 0;\n }\n SeriesUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'SeriesUtil',\n interfaces: []\n };\n var SeriesUtil_instance = null;\n function SeriesUtil_getInstance() {\n if (SeriesUtil_instance === null) {\n new SeriesUtil();\n }return SeriesUtil_instance;\n }\n function DouglasPeuckerSimplification() {\n this.myEpsilon_0 = kotlin_js_internal_DoubleCompanionObject.MIN_VALUE;\n }\n function DouglasPeuckerSimplification$calculateWeights$lambda(closure$points, closure$startIndex) {\n return function (p) {\n return (new DoubleSegment(closure$points.get_za3lpa$(closure$startIndex), p)).length();\n };\n }\n function DouglasPeuckerSimplification$calculateWeights$lambda_0(closure$doubleSegment) {\n return function (it) {\n return closure$doubleSegment.distance_gpjtzr$(it);\n };\n }\n DouglasPeuckerSimplification.prototype.calculateWeights_0 = function (points) {\n var stack = new Stack();\n var size = points.size;\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(kotlin_js_internal_DoubleCompanionObject.NaN);\n }\n var weights = list;\n weights.set_wxm5ur$(0, kotlin_js_internal_DoubleCompanionObject.MAX_VALUE);\n weights.set_wxm5ur$(points.size - 1 | 0, kotlin_js_internal_DoubleCompanionObject.MAX_VALUE);\n stack.push_11rb$(new Pair(0, points.size - 1 | 0));\n while (!stack.empty()) {\n var startIndex = ensureNotNull(stack.peek()).first;\n var endIndex = ensureNotNull(stack.peek()).second;\n stack.pop();\n var dMax = 0.0;\n var index_0 = startIndex;\n var doubleSegment = new DoubleSegment(points.get_za3lpa$(startIndex), points.get_za3lpa$(endIndex));\n var distance;\n if (doubleSegment.length() === 0.0) {\n distance = DouglasPeuckerSimplification$calculateWeights$lambda(points, startIndex);\n } else {\n distance = DouglasPeuckerSimplification$calculateWeights$lambda_0(doubleSegment);\n }\n var i = startIndex + 1 | 0;\n while (i < endIndex) {\n var d = distance(points.get_za3lpa$(i));\n if (d > dMax) {\n index_0 = i;\n dMax = d;\n }i = i + 1 | 0;\n }\n if (dMax >= this.myEpsilon_0) {\n stack.push_11rb$(new Pair(startIndex, index_0));\n stack.push_11rb$(new Pair(index_0, endIndex));\n weights.set_wxm5ur$(index_0, dMax);\n }}\n return weights;\n };\n DouglasPeuckerSimplification.prototype.getWeights_ytws2g$ = function (points) {\n return this.calculateWeights_0(points);\n };\n DouglasPeuckerSimplification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DouglasPeuckerSimplification',\n interfaces: [PolylineSimplifier$RankingStrategy]\n };\n var compareBy$lambda = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function PolylineSimplifier(myPoints, strategy) {\n PolylineSimplifier$Companion_getInstance();\n this.myPoints_0 = myPoints;\n this.myWeights_0 = null;\n this.myWeightLimit_0 = kotlin_js_internal_DoubleCompanionObject.NaN;\n this.myCountLimit_0 = -1;\n this.myWeights_0 = strategy.getWeights_ytws2g$(this.myPoints_0);\n }\n Object.defineProperty(PolylineSimplifier.prototype, 'points', {\n configurable: true,\n get: function () {\n var $receiver = this.indices;\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(this.myPoints_0.get_za3lpa$(item));\n }\n return destination;\n }\n });\n function PolylineSimplifier$get_PolylineSimplifier$indices$lambda(this$PolylineSimplifier) {\n return function (it) {\n return this$PolylineSimplifier.getWeight_0(it);\n };\n }\n Object.defineProperty(PolylineSimplifier.prototype, 'indices', {\n configurable: true,\n get: function () {\n var $receiver = until(0, this.myPoints_0.size);\n var destination = ArrayList_init_0(collectionSizeOrDefault($receiver, 10));\n var tmp$;\n tmp$ = $receiver.iterator();\n while (tmp$.hasNext()) {\n var item = tmp$.next();\n destination.add_11rb$(new Pair(item, this.myWeights_0.get_za3lpa$(item)));\n }\n var destination_0 = ArrayList_init();\n var tmp$_0;\n tmp$_0 = destination.iterator();\n while (tmp$_0.hasNext()) {\n var element = tmp$_0.next();\n if (!isNaN_0(this.getWeight_0(element)))\n destination_0.add_11rb$(element);\n }\n var sorted_0 = sortedWith(destination_0, reversed(new Comparator(compareBy$lambda(PolylineSimplifier$get_PolylineSimplifier$indices$lambda(this)))));\n var filtered;\n if (this.isWeightLimitSet_0) {\n var destination_1 = ArrayList_init();\n var tmp$_1;\n tmp$_1 = sorted_0.iterator();\n while (tmp$_1.hasNext()) {\n var element_0 = tmp$_1.next();\n if (this.getWeight_0(element_0) > this.myWeightLimit_0)\n destination_1.add_11rb$(element_0);\n }\n filtered = destination_1;\n } else {\n filtered = take(sorted_0, this.myCountLimit_0);\n }\n var $receiver_0 = filtered;\n var destination_2 = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_2;\n tmp$_2 = $receiver_0.iterator();\n while (tmp$_2.hasNext()) {\n var item_0 = tmp$_2.next();\n destination_2.add_11rb$(this.getIndex_0(item_0));\n }\n return sorted(destination_2);\n }\n });\n Object.defineProperty(PolylineSimplifier.prototype, 'isWeightLimitSet_0', {\n configurable: true,\n get: function () {\n return !isNaN_0(this.myWeightLimit_0);\n }\n });\n PolylineSimplifier.prototype.setWeightLimit_14dthe$ = function (weightLimit) {\n this.myWeightLimit_0 = weightLimit;\n this.myCountLimit_0 = -1;\n return this;\n };\n PolylineSimplifier.prototype.setCountLimit_za3lpa$ = function (countLimit) {\n this.myWeightLimit_0 = kotlin_js_internal_DoubleCompanionObject.NaN;\n this.myCountLimit_0 = countLimit;\n return this;\n };\n PolylineSimplifier.prototype.getWeight_0 = function (p) {\n return p.second;\n };\n PolylineSimplifier.prototype.getIndex_0 = function (p) {\n return p.first;\n };\n function PolylineSimplifier$RankingStrategy() {\n }\n PolylineSimplifier$RankingStrategy.$metadata$ = {\n kind: Kind_INTERFACE,\n simpleName: 'RankingStrategy',\n interfaces: []\n };\n function PolylineSimplifier$Companion() {\n PolylineSimplifier$Companion_instance = this;\n }\n PolylineSimplifier$Companion.prototype.visvalingamWhyatt_ytws2g$ = function (points) {\n return new PolylineSimplifier(points, new VisvalingamWhyattSimplification());\n };\n PolylineSimplifier$Companion.prototype.douglasPeucker_ytws2g$ = function (points) {\n return new PolylineSimplifier(points, new DouglasPeuckerSimplification());\n };\n PolylineSimplifier$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var PolylineSimplifier$Companion_instance = null;\n function PolylineSimplifier$Companion_getInstance() {\n if (PolylineSimplifier$Companion_instance === null) {\n new PolylineSimplifier$Companion();\n }return PolylineSimplifier$Companion_instance;\n }\n PolylineSimplifier.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PolylineSimplifier',\n interfaces: []\n };\n var compareBy$lambda_0 = wrapFunction(function () {\n var compareValues = Kotlin.kotlin.comparisons.compareValues_s00gnj$;\n return function (closure$selector) {\n return function (a, b) {\n var selector = closure$selector;\n return compareValues(selector(a), selector(b));\n };\n };\n });\n function VisvalingamWhyattSimplification() {\n VisvalingamWhyattSimplification$Companion_getInstance();\n this.myVerticesToRemove_0 = ArrayList_init();\n this.myTriangles_0 = null;\n }\n Object.defineProperty(VisvalingamWhyattSimplification.prototype, 'isSimplificationDone_0', {\n configurable: true,\n get: function () {\n return this.isEmpty_0;\n }\n });\n Object.defineProperty(VisvalingamWhyattSimplification.prototype, 'isEmpty_0', {\n configurable: true,\n get: function () {\n return ensureNotNull(this.myTriangles_0).isEmpty();\n }\n });\n VisvalingamWhyattSimplification.prototype.getWeights_ytws2g$ = function (points) {\n this.myTriangles_0 = ArrayList_init_0(points.size - 2 | 0);\n this.initTriangles_0(points);\n var size = points.size;\n var list = ArrayList_init_0(size);\n for (var index = 0; index < size; index++) {\n list.add_11rb$(VisvalingamWhyattSimplification$Companion_getInstance().INITIAL_AREA_0);\n }\n var weights = list;\n var lastRemovedVertexArea = 0.0;\n while (!this.isSimplificationDone_0) {\n var triangle = this.takeTriangle_0();\n lastRemovedVertexArea = triangle.area > lastRemovedVertexArea ? triangle.area : lastRemovedVertexArea;\n weights.set_wxm5ur$(triangle.currentVertex, lastRemovedVertexArea);\n var next = triangle.next;\n if (next != null) {\n next.takePrevFrom_em8fn6$(triangle);\n this.update_0(next);\n }var prev = triangle.prev;\n if (prev != null) {\n prev.takeNextFrom_em8fn6$(triangle);\n this.update_0(prev);\n }this.myVerticesToRemove_0.add_11rb$(triangle.currentVertex);\n }\n return weights;\n };\n VisvalingamWhyattSimplification.prototype.initTriangles_0 = function (points) {\n var triangles = ArrayList_init_0(points.size - 2 | 0);\n var i = 1;\n var n = points.size - 1 | 0;\n while (i < n) {\n triangles.add_11rb$(new VisvalingamWhyattSimplification$Triangle(i, points));\n i = i + 1 | 0;\n }\n var i_0 = 1;\n var n_0 = triangles.size - 1 | 0;\n while (i_0 < n_0) {\n triangles.get_za3lpa$(i_0).next = triangles.get_za3lpa$(i_0 + 1 | 0);\n triangles.get_za3lpa$(i_0).prev = triangles.get_za3lpa$(i_0 - 1 | 0);\n i_0 = i_0 + 1 | 0;\n }\n var tmp$;\n tmp$ = triangles.iterator();\n while (tmp$.hasNext()) {\n var element = tmp$.next();\n this.add_0(element);\n }\n };\n VisvalingamWhyattSimplification.prototype.takeTriangle_0 = function () {\n var minimalTriangle = this.poll_0();\n this.myVerticesToRemove_0.add_11rb$(minimalTriangle.currentVertex);\n return minimalTriangle;\n };\n VisvalingamWhyattSimplification.prototype.add_0 = function (triangle) {\n var index = this.getIndex_0(triangle);\n ensureNotNull(this.myTriangles_0).add_wxm5ur$(index, triangle);\n };\n function VisvalingamWhyattSimplification$getIndex$lambda(it) {\n return it.area;\n }\n VisvalingamWhyattSimplification.prototype.getIndex_0 = function (triangle) {\n var index = binarySearch(ensureNotNull(this.myTriangles_0), triangle, new Comparator(compareBy$lambda_0(VisvalingamWhyattSimplification$getIndex$lambda)));\n if (index < 0) {\n index = ~index;\n }return index;\n };\n VisvalingamWhyattSimplification.prototype.peek_0 = function () {\n return ensureNotNull(this.myTriangles_0).get_za3lpa$(0);\n };\n VisvalingamWhyattSimplification.prototype.poll_0 = function () {\n var triangle = this.peek_0();\n ensureNotNull(this.myTriangles_0).remove_11rb$(triangle);\n return triangle;\n };\n VisvalingamWhyattSimplification.prototype.update_0 = function (triangle) {\n ensureNotNull(this.myTriangles_0).remove_11rb$(triangle);\n ensureNotNull(this.myTriangles_0).add_11rb$(triangle);\n };\n function VisvalingamWhyattSimplification$Triangle(currentVertex, myPoints) {\n this.currentVertex = currentVertex;\n this.myPoints_0 = myPoints;\n this.area_nqp3v0$_0 = 0;\n this.prevVertex_0 = 0;\n this.nextVertex_0 = 0;\n this.prev = null;\n this.next = null;\n this.prevVertex_0 = this.currentVertex - 1 | 0;\n this.nextVertex_0 = this.currentVertex + 1 | 0;\n this.area = this.calculateArea_0();\n }\n Object.defineProperty(VisvalingamWhyattSimplification$Triangle.prototype, 'area', {\n configurable: true,\n get: function () {\n return this.area_nqp3v0$_0;\n },\n set: function (area) {\n this.area_nqp3v0$_0 = area;\n }\n });\n VisvalingamWhyattSimplification$Triangle.prototype.takeNextFrom_em8fn6$ = function (triangle) {\n this.next = triangle.next;\n this.nextVertex_0 = triangle.nextVertex_0;\n this.area = this.calculateArea_0();\n };\n VisvalingamWhyattSimplification$Triangle.prototype.takePrevFrom_em8fn6$ = function (triangle) {\n this.prev = triangle.prev;\n this.prevVertex_0 = triangle.prevVertex_0;\n this.area = this.calculateArea_0();\n };\n VisvalingamWhyattSimplification$Triangle.prototype.calculateArea_0 = function () {\n var a = this.myPoints_0.get_za3lpa$(this.prevVertex_0);\n var b = this.myPoints_0.get_za3lpa$(this.currentVertex);\n var c = this.myPoints_0.get_za3lpa$(this.nextVertex_0);\n var x = ((b.x - a.x) * (c.y - a.y) - (c.x - a.x) * (b.y - a.y)) / 2.0;\n return JsMath.abs(x);\n };\n VisvalingamWhyattSimplification$Triangle.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Triangle',\n interfaces: []\n };\n function VisvalingamWhyattSimplification$Companion() {\n VisvalingamWhyattSimplification$Companion_instance = this;\n this.INITIAL_AREA_0 = kotlin_js_internal_DoubleCompanionObject.MAX_VALUE;\n }\n VisvalingamWhyattSimplification$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var VisvalingamWhyattSimplification$Companion_instance = null;\n function VisvalingamWhyattSimplification$Companion_getInstance() {\n if (VisvalingamWhyattSimplification$Companion_instance === null) {\n new VisvalingamWhyattSimplification$Companion();\n }return VisvalingamWhyattSimplification$Companion_instance;\n }\n VisvalingamWhyattSimplification.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'VisvalingamWhyattSimplification',\n interfaces: [PolylineSimplifier$RankingStrategy]\n };\n function DateTimeFormatUtil() {\n DateTimeFormatUtil_instance = this;\n }\n DateTimeFormatUtil.prototype.formatDateUTC_xfy9o8$ = function (instant, pattern) {\n var format = Format_init(pattern);\n var $receiver = new Instant(numberToLong(instant));\n var $receiver_0 = getCallableRef('toDateTime', function ($receiver, p1) {\n return $receiver.toDateTime_x2y23v$(p1);\n }.bind(null, TimeZone.Companion.UTC))($receiver);\n return getCallableRef('apply', function ($receiver, p1) {\n return $receiver.apply_amwj4p$(p1);\n }.bind(null, format))($receiver_0);\n };\n DateTimeFormatUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'DateTimeFormatUtil',\n interfaces: []\n };\n var DateTimeFormatUtil_instance = null;\n function DateTimeFormatUtil_getInstance() {\n if (DateTimeFormatUtil_instance === null) {\n new DateTimeFormatUtil();\n }return DateTimeFormatUtil_instance;\n }\n function Formatter() {\n Formatter_instance = this;\n this.YEAR_0 = '%b %Y';\n this.YEAR_QUARTER_0 = 'Q %y';\n this.YEAR_MONTH_0 = '%B %Y';\n this.DATE_MEDIUM_0 = '%a, %b %e, %Y';\n this.DATE_MEDIUM_TIME_SHORT_0 = '%a, %b %e, %Y %l:%M %p';\n this.DEF_NUMBER_FORMAT_0 = NumberFormat_init(',g');\n this.DEF_NUMBER_FORMATTER_0 = Formatter$DEF_NUMBER_FORMATTER$lambda(this);\n }\n function Formatter$time$lambda(closure$pattern) {\n return function (input) {\n var tmp$;\n return DateTimeFormatUtil_getInstance().formatDateUTC_xfy9o8$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE(), closure$pattern);\n };\n }\n Formatter.prototype.time_61zpoe$ = function (pattern) {\n return Formatter$time$lambda(pattern);\n };\n Formatter.prototype.tooltip_w817vg$ = function (dataType) {\n return this.nullable_0(this.tooltipImpl_0(dataType), 'null');\n };\n function Formatter$tooltipImpl$lambda(it) {\n return it.toString();\n }\n Formatter.prototype.tooltipImpl_0 = function (dataType) {\n var tmp$;\n switch (dataType.name) {\n case 'NUMBER':\n tmp$ = this.DEF_NUMBER_FORMATTER_0;\n break;\n case 'STRING':\n tmp$ = Formatter$tooltipImpl$lambda;\n break;\n case 'INSTANT':\n tmp$ = this.time_61zpoe$(this.DATE_MEDIUM_TIME_SHORT_0);\n break;\n case 'INSTANT_OF_DAY':\n tmp$ = this.time_61zpoe$(this.DATE_MEDIUM_0);\n break;\n case 'INSTANT_OF_MONTH':\n tmp$ = this.time_61zpoe$(this.YEAR_MONTH_0);\n break;\n case 'INSTANT_OF_QUARTER':\n case 'INSTANT_OF_HALF_YEAR':\n tmp$ = this.time_61zpoe$(this.YEAR_QUARTER_0);\n break;\n case 'INSTANT_OF_YEAR':\n tmp$ = this.time_61zpoe$(this.YEAR_0);\n break;\n default:tmp$ = Kotlin.noWhenBranchMatched();\n break;\n }\n return tmp$;\n };\n Formatter.prototype.tableCell_w817vg$ = function (dataType) {\n return this.tableCell_0(dataType, 'null');\n };\n Formatter.prototype.tableCell_0 = function (dataType, nullString) {\n return this.nullable_0(this.tableCellImpl_0(dataType), nullString);\n };\n function Formatter$tableCellImpl$lambda(it) {\n return it.toString();\n }\n Formatter.prototype.tableCellImpl_0 = function (dataType) {\n switch (dataType.name) {\n case 'NUMBER':\n return this.DEF_NUMBER_FORMATTER_0;\n case 'STRING':\n return Formatter$tableCellImpl$lambda;\n case 'INSTANT':\n return this.time_61zpoe$(\"%a, %b %e, '%y\");\n default:if (dataType.isTimeInterval) {\n var timeInterval = TimeInterval$Companion_getInstance().fromIntervalDataType_w817vg$(dataType);\n return timeInterval.tickFormatter;\n }\n break;\n }\n throw IllegalArgumentException_init(\"Can't create formatter for data type \" + dataType);\n };\n function Formatter$nullable$lambda(closure$nullString, closure$f) {\n return function (input) {\n return input == null ? closure$nullString : closure$f(input);\n };\n }\n Formatter.prototype.nullable_0 = function (f, nullString) {\n return Formatter$nullable$lambda(nullString, f);\n };\n function Formatter$DEF_NUMBER_FORMATTER$lambda(this$Formatter) {\n return function (input) {\n var tmp$;\n return this$Formatter.DEF_NUMBER_FORMAT_0.apply_3p81yu$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE());\n };\n }\n Formatter.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Formatter',\n interfaces: []\n };\n var Formatter_instance = null;\n function Formatter_getInstance() {\n if (Formatter_instance === null) {\n new Formatter();\n }return Formatter_instance;\n }\n function TimeUtil() {\n TimeUtil_instance = this;\n }\n TimeUtil.prototype.asDateTimeUTC_14dthe$ = function (instant) {\n try {\n return TimeZone.Companion.UTC.toDateTime_x2y23v$(new Instant(roundToLong(instant)));\n } catch (ignored) {\n if (Kotlin.isType(ignored, RuntimeException)) {\n throw IllegalArgumentException_init(\"Can't create DateTime from instant \" + instant);\n } else\n throw ignored;\n }\n };\n TimeUtil.prototype.asInstantUTC_amwj4p$ = function (dateTime) {\n return TimeZone.Companion.UTC.toInstant_amwj4p$(dateTime).timeSinceEpoch;\n };\n TimeUtil.prototype.yearStart_za3lpa$ = function (year) {\n return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year));\n };\n TimeUtil.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'TimeUtil',\n interfaces: []\n };\n var TimeUtil_instance = null;\n function TimeUtil_getInstance() {\n if (TimeUtil_instance === null) {\n new TimeUtil();\n }return TimeUtil_instance;\n }\n function DurationInterval(myDuration, count) {\n TimeInterval.call(this, count);\n this.myDuration_0 = myDuration;\n if (!this.myDuration_0.isPositive) {\n throw RuntimeException_init('Duration must be positive');\n }}\n Object.defineProperty(DurationInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n var duration = this.myDuration_0.duration;\n if (duration.compareTo_11rb$(Duration.Companion.SECOND.duration) < 0) {\n return '%S';\n } else if (duration.compareTo_11rb$(Duration.Companion.MINUTE.duration) < 0) {\n return '%S';\n } else if (duration.compareTo_11rb$(Duration.Companion.HOUR.duration) < 0) {\n return '%M';\n } else if (duration.compareTo_11rb$(Duration.Companion.DAY.duration) < 0) {\n return '%H:%M';\n } else if (duration.compareTo_11rb$(Duration.Companion.WEEK.duration) < 0) {\n return '%b %e';\n }return '%b %e';\n }\n });\n DurationInterval.prototype.range_lu1900$ = function (start, end) {\n var step = this.myDuration_0.duration.multiply(Kotlin.Long.fromInt(this.count)).toNumber();\n var x = start / step;\n var tick = JsMath.ceil(x) * step;\n var result = ArrayList_init();\n while (tick <= end) {\n result.add_11rb$(tick);\n tick += step;\n }\n return result;\n };\n DurationInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'DurationInterval',\n interfaces: [TimeInterval]\n };\n function MeasuredInDays(count) {\n TimeInterval.call(this, count);\n }\n MeasuredInDays.prototype.range_lu1900$ = function (start, end) {\n if (start > end) {\n throw RuntimeException_init('Duration must be positive');\n }var dateTimeStart = TimeUtil_getInstance().asDateTimeUTC_14dthe$(start);\n var dateStart = this.getFirstDayContaining_amwj4p$(dateTimeStart);\n var dateTimeTick = new DateTime(dateStart);\n if (dateTimeTick.compareTo_11rb$(dateTimeStart) < 0) {\n dateTimeTick = this.addInterval_amwj4p$(dateTimeTick);\n }var result = ArrayList_init();\n var tick = TimeUtil_getInstance().asInstantUTC_amwj4p$(dateTimeTick).toNumber();\n while (tick <= end) {\n result.add_11rb$(tick);\n dateTimeTick = this.addInterval_amwj4p$(dateTimeTick);\n tick = TimeUtil_getInstance().asInstantUTC_amwj4p$(dateTimeTick).toNumber();\n }\n return result;\n };\n MeasuredInDays.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MeasuredInDays',\n interfaces: [TimeInterval]\n };\n function MonthInterval(count) {\n MeasuredInDays.call(this, count);\n }\n Object.defineProperty(MonthInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return '%b';\n }\n });\n MonthInterval.prototype.getFirstDayContaining_amwj4p$ = function (instant) {\n var firstDay = instant.date;\n firstDay = Date_0.Companion.firstDayOf_8fsw02$(firstDay.year, firstDay.month);\n return firstDay;\n };\n MonthInterval.prototype.addInterval_amwj4p$ = function (toInstant) {\n var tmp$;\n var result = toInstant;\n tmp$ = this.count;\n for (var i = 0; i < tmp$; i++) {\n result = this.addMonth_0(result);\n }\n return result;\n };\n MonthInterval.prototype.addMonth_0 = function (toInstant) {\n var year = toInstant.year;\n var month = toInstant.month;\n var next = ensureNotNull(month).next();\n if (next == null) {\n next = Month.Companion.JANUARY;\n year = year + 1 | 0;\n }return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year, next));\n };\n MonthInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'MonthInterval',\n interfaces: [MeasuredInDays]\n };\n function NiceTimeInterval() {\n NiceTimeInterval_instance = this;\n this.AUTO_STEPS_MS_0 = new Float64Array([1000.0, 5000.0, 15000.0, 30000.0, 60000.0, 5 * 60000.0, 15 * 60000.0, 30 * 60000.0, 3600000.0, 3 * 3600000.0, 6 * 3600000.0, 12 * 3600000.0, 8.64E7, 2 * 8.64E7, 6.048E8, 2.592E9, 3 * 2.592E9, YearInterval$Companion_getInstance().MS]);\n this.AUTO_INTERVALS_0 = [TimeInterval$Companion_getInstance().seconds_za3lpa$(1), TimeInterval$Companion_getInstance().seconds_za3lpa$(5), TimeInterval$Companion_getInstance().seconds_za3lpa$(15), TimeInterval$Companion_getInstance().seconds_za3lpa$(30), TimeInterval$Companion_getInstance().minutes_za3lpa$(1), TimeInterval$Companion_getInstance().minutes_za3lpa$(5), TimeInterval$Companion_getInstance().minutes_za3lpa$(15), TimeInterval$Companion_getInstance().minutes_za3lpa$(30), TimeInterval$Companion_getInstance().hours_za3lpa$(1), TimeInterval$Companion_getInstance().hours_za3lpa$(3), TimeInterval$Companion_getInstance().hours_za3lpa$(6), TimeInterval$Companion_getInstance().hours_za3lpa$(12), TimeInterval$Companion_getInstance().days_za3lpa$(1), TimeInterval$Companion_getInstance().days_za3lpa$(2), TimeInterval$Companion_getInstance().weeks_za3lpa$(1), TimeInterval$Companion_getInstance().months_za3lpa$(1), TimeInterval$Companion_getInstance().months_za3lpa$(3), TimeInterval$Companion_getInstance().years_za3lpa$(1)];\n }\n NiceTimeInterval.prototype.forMillis_14dthe$ = function (interval) {\n var tmp$;\n if (interval <= this.AUTO_STEPS_MS_0[0]) {\n return this.AUTO_INTERVALS_0[0];\n }var result = this.AUTO_INTERVALS_0[this.AUTO_STEPS_MS_0.length - 1 | 0];\n tmp$ = this.AUTO_STEPS_MS_0.length;\n for (var i = 1; i < tmp$; i++) {\n if (this.AUTO_STEPS_MS_0[i] >= interval) {\n var deltaDown = interval - this.AUTO_STEPS_MS_0[i - 1 | 0];\n var deltaUp = this.AUTO_STEPS_MS_0[i] - interval;\n if (deltaDown < deltaUp) {\n result = this.AUTO_INTERVALS_0[i - 1 | 0];\n } else {\n result = this.AUTO_INTERVALS_0[i];\n }\n break;\n }}\n return result;\n };\n NiceTimeInterval.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'NiceTimeInterval',\n interfaces: []\n };\n var NiceTimeInterval_instance = null;\n function NiceTimeInterval_getInstance() {\n if (NiceTimeInterval_instance === null) {\n new NiceTimeInterval();\n }return NiceTimeInterval_instance;\n }\n function QuarterInterval(count) {\n TimeInterval.call(this, count);\n }\n Object.defineProperty(QuarterInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return 'Q';\n }\n });\n QuarterInterval.prototype.range_lu1900$ = function (start, end) {\n throw UnsupportedOperationException_init();\n };\n QuarterInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'QuarterInterval',\n interfaces: [TimeInterval]\n };\n function SemesterInterval(count) {\n SemesterInterval$Companion_getInstance();\n TimeInterval.call(this, count);\n }\n Object.defineProperty(SemesterInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n throw UnsupportedOperationException_init();\n }\n });\n Object.defineProperty(SemesterInterval.prototype, 'tickFormatter', {\n configurable: true,\n get: function () {\n return SemesterInterval$Companion_getInstance().TIME_FORMAT_FUNCTION_0;\n }\n });\n SemesterInterval.prototype.range_lu1900$ = function (start, end) {\n throw UnsupportedOperationException_init();\n };\n function SemesterInterval$Companion() {\n SemesterInterval$Companion_instance = this;\n this.TIME_FORMAT_FUNCTION_0 = SemesterInterval$Companion$TIME_FORMAT_FUNCTION$lambda;\n }\n function SemesterInterval$Companion$TIME_FORMAT_FUNCTION$lambda(input) {\n var tmp$;\n var result = DateTimeFormatUtil_getInstance().formatDateUTC_xfy9o8$(Kotlin.isNumber(tmp$ = input) ? tmp$ : throwCCE(), 'Q');\n if (result.length === 2 && startsWith(result, 'Q')) {\n try {\n var quarterNum = toInt(result.substring(1));\n var semesterNumber = (quarterNum + 1 | 0) / 2 | 0;\n if (semesterNumber === 1 || semesterNumber === 2) {\n result = 'Semester ' + semesterNumber;\n }} catch (ignored) {\n if (!Kotlin.isType(ignored, NumberFormatException))\n throw ignored;\n }\n }return result;\n }\n SemesterInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var SemesterInterval$Companion_instance = null;\n function SemesterInterval$Companion_getInstance() {\n if (SemesterInterval$Companion_instance === null) {\n new SemesterInterval$Companion();\n }return SemesterInterval$Companion_instance;\n }\n SemesterInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'SemesterInterval',\n interfaces: [TimeInterval]\n };\n function TimeInterval(count) {\n TimeInterval$Companion_getInstance();\n this.count = count;\n }\n Object.defineProperty(TimeInterval.prototype, 'tickFormatter', {\n configurable: true,\n get: function () {\n return Formatter_getInstance().time_61zpoe$(this.tickFormatPattern);\n }\n });\n function TimeInterval$Companion() {\n TimeInterval$Companion_instance = this;\n }\n TimeInterval$Companion.prototype.milliseconds_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.MS, count);\n };\n TimeInterval$Companion.prototype.seconds_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.SECOND, count);\n };\n TimeInterval$Companion.prototype.minutes_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.MINUTE, count);\n };\n TimeInterval$Companion.prototype.hours_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.HOUR, count);\n };\n TimeInterval$Companion.prototype.days_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.DAY, count);\n };\n TimeInterval$Companion.prototype.weeks_za3lpa$ = function (count) {\n return new DurationInterval(Duration.Companion.WEEK, count);\n };\n TimeInterval$Companion.prototype.months_za3lpa$ = function (count) {\n return new MonthInterval(count);\n };\n TimeInterval$Companion.prototype.quarter_0 = function (count) {\n return new QuarterInterval(count);\n };\n TimeInterval$Companion.prototype.semester_0 = function (count) {\n return new SemesterInterval(count);\n };\n TimeInterval$Companion.prototype.years_za3lpa$ = function (count) {\n return new YearInterval(count);\n };\n TimeInterval$Companion.prototype.fromIntervalDataType_w817vg$ = function (dataType) {\n var tmp$;\n switch (dataType.name) {\n case 'INSTANT_OF_DAY':\n tmp$ = this.days_za3lpa$(1);\n break;\n case 'INSTANT_OF_MONTH':\n tmp$ = this.months_za3lpa$(1);\n break;\n case 'INSTANT_OF_QUARTER':\n tmp$ = this.quarter_0(1);\n break;\n case 'INSTANT_OF_HALF_YEAR':\n tmp$ = this.semester_0(1);\n break;\n case 'INSTANT_OF_YEAR':\n tmp$ = this.years_za3lpa$(1);\n break;\n default:throw IllegalArgumentException_init(\"Can't create interval from data type: \" + dataType);\n }\n return tmp$;\n };\n TimeInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var TimeInterval$Companion_instance = null;\n function TimeInterval$Companion_getInstance() {\n if (TimeInterval$Companion_instance === null) {\n new TimeInterval$Companion();\n }return TimeInterval$Companion_instance;\n }\n TimeInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'TimeInterval',\n interfaces: []\n };\n function YearInterval(count) {\n YearInterval$Companion_getInstance();\n MeasuredInDays.call(this, count);\n this.tickFormatPattern_1ltjii$_0 = YearInterval$Companion_getInstance().TICK_FORMAT;\n }\n Object.defineProperty(YearInterval.prototype, 'tickFormatPattern', {\n configurable: true,\n get: function () {\n return this.tickFormatPattern_1ltjii$_0;\n }\n });\n YearInterval.prototype.getFirstDayContaining_amwj4p$ = function (instant) {\n return Date_0.Companion.firstDayOf_8fsw02$(instant.year);\n };\n YearInterval.prototype.addInterval_amwj4p$ = function (toInstant) {\n var tmp$;\n var result = toInstant;\n tmp$ = this.count;\n for (var i = 0; i < tmp$; i++) {\n result = this.addYear_0(result);\n }\n return result;\n };\n YearInterval.prototype.addYear_0 = function (toInstant) {\n var year = toInstant.year;\n return new DateTime(Date_0.Companion.firstDayOf_8fsw02$(year + 1 | 0));\n };\n function YearInterval$Companion() {\n YearInterval$Companion_instance = this;\n this.TICK_FORMAT = '%Y';\n this.MS = 3.1536E10;\n this.TICK_FORMATTER = Formatter_getInstance().time_61zpoe$(this.TICK_FORMAT);\n }\n YearInterval$Companion.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'Companion',\n interfaces: []\n };\n var YearInterval$Companion_instance = null;\n function YearInterval$Companion_getInstance() {\n if (YearInterval$Companion_instance === null) {\n new YearInterval$Companion();\n }return YearInterval$Companion_instance;\n }\n YearInterval.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'YearInterval',\n interfaces: [MeasuredInDays]\n };\n Object.defineProperty(ColorPalette$Type, 'SEQUENTIAL', {\n get: ColorPalette$Type$SEQUENTIAL_getInstance\n });\n Object.defineProperty(ColorPalette$Type, 'DIVERGING', {\n get: ColorPalette$Type$DIVERGING_getInstance\n });\n Object.defineProperty(ColorPalette$Type, 'QUALITATIVE', {\n get: ColorPalette$Type$QUALITATIVE_getInstance\n });\n ColorPalette.prototype.Type = ColorPalette$Type;\n Object.defineProperty(ColorPalette$Sequential, 'Blues', {\n get: ColorPalette$Sequential$Blues_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'BuGn', {\n get: ColorPalette$Sequential$BuGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'BuPu', {\n get: ColorPalette$Sequential$BuPu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'GnBu', {\n get: ColorPalette$Sequential$GnBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Greens', {\n get: ColorPalette$Sequential$Greens_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Greys', {\n get: ColorPalette$Sequential$Greys_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Oranges', {\n get: ColorPalette$Sequential$Oranges_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'OrRd', {\n get: ColorPalette$Sequential$OrRd_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuBu', {\n get: ColorPalette$Sequential$PuBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuBuGn', {\n get: ColorPalette$Sequential$PuBuGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'PuRd', {\n get: ColorPalette$Sequential$PuRd_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Purples', {\n get: ColorPalette$Sequential$Purples_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'RdPu', {\n get: ColorPalette$Sequential$RdPu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'Reds', {\n get: ColorPalette$Sequential$Reds_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlGn', {\n get: ColorPalette$Sequential$YlGn_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlGnBu', {\n get: ColorPalette$Sequential$YlGnBu_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlOrBr', {\n get: ColorPalette$Sequential$YlOrBr_getInstance\n });\n Object.defineProperty(ColorPalette$Sequential, 'YlOrRd', {\n get: ColorPalette$Sequential$YlOrRd_getInstance\n });\n ColorPalette.prototype.Sequential = ColorPalette$Sequential;\n Object.defineProperty(ColorPalette$Diverging, 'BrBG', {\n get: ColorPalette$Diverging$BrBG_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PiYG', {\n get: ColorPalette$Diverging$PiYG_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PRGn', {\n get: ColorPalette$Diverging$PRGn_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'PuOr', {\n get: ColorPalette$Diverging$PuOr_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdBu', {\n get: ColorPalette$Diverging$RdBu_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdGy', {\n get: ColorPalette$Diverging$RdGy_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdYlBu', {\n get: ColorPalette$Diverging$RdYlBu_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'RdYlGn', {\n get: ColorPalette$Diverging$RdYlGn_getInstance\n });\n Object.defineProperty(ColorPalette$Diverging, 'Spectral', {\n get: ColorPalette$Diverging$Spectral_getInstance\n });\n ColorPalette.prototype.Diverging = ColorPalette$Diverging;\n Object.defineProperty(ColorPalette$Qualitative, 'Accent', {\n get: ColorPalette$Qualitative$Accent_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Dark2', {\n get: ColorPalette$Qualitative$Dark2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Paired', {\n get: ColorPalette$Qualitative$Paired_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Pastel1', {\n get: ColorPalette$Qualitative$Pastel1_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Pastel2', {\n get: ColorPalette$Qualitative$Pastel2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set1', {\n get: ColorPalette$Qualitative$Set1_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set2', {\n get: ColorPalette$Qualitative$Set2_getInstance\n });\n Object.defineProperty(ColorPalette$Qualitative, 'Set3', {\n get: ColorPalette$Qualitative$Set3_getInstance\n });\n ColorPalette.prototype.Qualitative = ColorPalette$Qualitative;\n var package$jetbrains = _.jetbrains || (_.jetbrains = {});\n var package$datalore = package$jetbrains.datalore || (package$jetbrains.datalore = {});\n var package$plot = package$datalore.plot || (package$datalore.plot = {});\n var package$common = package$plot.common || (package$plot.common = {});\n var package$color = package$common.color || (package$common.color = {});\n Object.defineProperty(package$color, 'ColorPalette', {\n get: ColorPalette_getInstance\n });\n package$color.ColorScheme = ColorScheme;\n Object.defineProperty(package$color, 'ColorSets', {\n get: ColorSets_getInstance\n });\n Object.defineProperty(package$color, 'ColorUtil', {\n get: ColorUtil_getInstance\n });\n Object.defineProperty(package$color, 'PaletteUtil', {\n get: PaletteUtil_getInstance\n });\n Object.defineProperty(RGBChannelGen, 'Companion', {\n get: RGBChannelGen$Companion_getInstance\n });\n package$color.RGBChannelGen = RGBChannelGen;\n Object.defineProperty(DataType, 'NUMBER', {\n get: DataType$NUMBER_getInstance\n });\n Object.defineProperty(DataType, 'STRING', {\n get: DataType$STRING_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT', {\n get: DataType$INSTANT_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_DAY', {\n get: DataType$INSTANT_OF_DAY_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_MONTH', {\n get: DataType$INSTANT_OF_MONTH_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_QUARTER', {\n get: DataType$INSTANT_OF_QUARTER_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_HALF_YEAR', {\n get: DataType$INSTANT_OF_HALF_YEAR_getInstance\n });\n Object.defineProperty(DataType, 'INSTANT_OF_YEAR', {\n get: DataType$INSTANT_OF_YEAR_getInstance\n });\n var package$data = package$common.data || (package$common.data = {});\n package$data.DataType = DataType;\n Object.defineProperty(RegularMeshDetector, 'Companion', {\n get: RegularMeshDetector$Companion_getInstance\n });\n package$data.RegularMeshDetector = RegularMeshDetector;\n SeriesUtil.prototype.CheckedDoubleList = SeriesUtil$CheckedDoubleList;\n SeriesUtil.prototype.CheckedDoubleIterable = SeriesUtil$CheckedDoubleIterable;\n Object.defineProperty(package$data, 'SeriesUtil', {\n get: SeriesUtil_getInstance\n });\n var package$geometry = package$common.geometry || (package$common.geometry = {});\n package$geometry.DouglasPeuckerSimplification = DouglasPeuckerSimplification;\n PolylineSimplifier.RankingStrategy = PolylineSimplifier$RankingStrategy;\n Object.defineProperty(PolylineSimplifier, 'Companion', {\n get: PolylineSimplifier$Companion_getInstance\n });\n package$geometry.PolylineSimplifier = PolylineSimplifier;\n Object.defineProperty(VisvalingamWhyattSimplification, 'Companion', {\n get: VisvalingamWhyattSimplification$Companion_getInstance\n });\n package$geometry.VisvalingamWhyattSimplification = VisvalingamWhyattSimplification;\n var package$text = package$common.text || (package$common.text = {});\n Object.defineProperty(package$text, 'DateTimeFormatUtil', {\n get: DateTimeFormatUtil_getInstance\n });\n Object.defineProperty(package$text, 'Formatter', {\n get: Formatter_getInstance\n });\n var package$time = package$common.time || (package$common.time = {});\n Object.defineProperty(package$time, 'TimeUtil', {\n get: TimeUtil_getInstance\n });\n var package$interval = package$time.interval || (package$time.interval = {});\n package$interval.DurationInterval = DurationInterval;\n package$interval.MeasuredInDays = MeasuredInDays;\n package$interval.MonthInterval = MonthInterval;\n Object.defineProperty(package$interval, 'NiceTimeInterval', {\n get: NiceTimeInterval_getInstance\n });\n package$interval.QuarterInterval = QuarterInterval;\n Object.defineProperty(SemesterInterval, 'Companion', {\n get: SemesterInterval$Companion_getInstance\n });\n package$interval.SemesterInterval = SemesterInterval;\n Object.defineProperty(TimeInterval, 'Companion', {\n get: TimeInterval$Companion_getInstance\n });\n package$interval.TimeInterval = TimeInterval;\n Object.defineProperty(YearInterval, 'Companion', {\n get: YearInterval$Companion_getInstance\n });\n package$interval.YearInterval = YearInterval;\n Kotlin.defineModule('lets-plot-plot-common-portable', _);\n return _;\n}));\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/math.kt?73ab","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Preconditions.kt?9a95","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Collections.kt?f027","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/comparisons/Comparisons.kt?afee","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorPalette.kt?6e59","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorSets.kt?f7ca","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/ColorUtil.kt?a3a8","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/PaletteUtil.kt?a121","webpack://LetsPlot/./kotlin-dce-dev/common/src/generated/_Arrays.kt?0bbf","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Maps.kt?c73e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/color/RGBChannelGen.kt?7fe0","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/DataType.kt?8899","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/RegularMeshDetector.kt?0541","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/data/SeriesUtil.kt?e534","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/DouglasPeuckerSimplification.kt?3688","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/collections/Collections.kt?4d98","webpack://LetsPlot/./kotlin-dce-dev/src/kotlin/util/Standard.kt?edbd","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/PolylineSimplifier.kt?7da6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/geometry/VisvalingamWhyattSimplification.kt?0cd2","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/text/DateTimeFormatUtil.kt?2a3e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/text/Formatter.kt?7c5e","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/TimeUtil.kt?fd60","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/DurationInterval.kt?8e93","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/MeasuredInDays.kt?727b","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/MonthInterval.kt?8fe6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/NiceTimeInterval.kt?1a02","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/QuarterInterval.kt?c184","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/SemesterInterval.kt?244f","webpack://LetsPlot/./kotlin-dce-dev/js/src/kotlin/text/string.kt?8c1f","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/TimeInterval.kt?19e6","webpack://LetsPlot/../plot-common-portable/src/commonMain/kotlin/jetbrains/datalore/plot/common/time/interval/YearInterval.kt?d517"],"names":[],"mappings":"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","file":"./kotlin-dce-dev/lets-plot-plot-common-portable.js.js","sourcesContent":["/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\npackage kotlin.math\n\n\nimport kotlin.internal.InlineOnly\nimport kotlin.js.JsMath as nativeMath\n\n\n// region ================ Double Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Double): Double = nativeMath.sin(x)\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Double): Double = nativeMath.cos(x)\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Double): Double = nativeMath.tan(x)\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Double): Double = nativeMath.asin(x)\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Double): Double = nativeMath.acos(x)\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Double): Double = nativeMath.atan(x)\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Double, x: Double): Double = nativeMath.atan2(y, x)\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Double): Double = nativeMath.sinh(x)\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Double): Double = nativeMath.cosh(x)\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Double): Double = nativeMath.tanh(x)\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Double): Double = nativeMath.asinh(x)\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Double): Double = nativeMath.acosh(x)\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Double): Double = nativeMath.atanh(x)\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Double, y: Double): Double = nativeMath.hypot(x, y)\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Double): Double = nativeMath.sqrt(x)\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Double): Double = nativeMath.exp(x)\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Double): Double = nativeMath.expm1(x)\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\npublic actual fun log(x: Double, base: Double): Double {\n    if (base <= 0.0 || base == 1.0) return Double.NaN\n    return nativeMath.log(x) / nativeMath.log(base)\n}\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Double): Double = nativeMath.log(x)\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Double): Double = nativeMath.log10(x)\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Double): Double = nativeMath.log2(x)\n\n/**\n * Computes `ln(x + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Double): Double = nativeMath.log1p(x)\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest double value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Double): Double = nativeMath.ceil(x)\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest double value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Double): Double = nativeMath.floor(x)\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Double): Double = nativeMath.trunc(x)\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun round(x: Double): Double {\n    if (x % 0.5 != 0.0) {\n        return nativeMath.round(x)\n    }\n    val floor = floor(x)\n    return if (floor % 2 == 0.0) floor else ceil(x)\n}\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Double]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Double): Double = nativeMath.abs(x)\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Double): Double = nativeMath.sign(x)\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Double, b: Double): Double = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Double, b: Double): Double = nativeMath.max(a, b)\n\n// extensions\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(x: Double): Double = nativeMath.pow(this, x)\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.pow(n: Int): Double = nativeMath.pow(this, n.toDouble())\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.absoluteValue: Double get() = nativeMath.abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Double.sign: Double get() = nativeMath.sign(this)\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Double.withSign(sign: Int): Double = this.withSign(sign.toDouble())\n\n/**\n * Returns the ulp (unit in the last place) of this value.\n *\n * An ulp is a positive distance between this value and the next nearest [Double] value larger in magnitude.\n *\n * Special Cases:\n *   - `NaN.ulp` is `NaN`\n *   - `x.ulp` is `+Inf` when `x` is `+Inf` or `-Inf`\n *   - `0.0.ulp` is `Double.MIN_VALUE`\n */\n@SinceKotlin(\"1.2\")\npublic actual val Double.ulp: Double get() = when {\n    this < 0 -> (-this).ulp\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == Double.MAX_VALUE -> this - this.nextDown()\n    else -> this.nextUp() - this\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of positive infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextUp(): Double = when {\n    this.isNaN() || this == Double.POSITIVE_INFINITY -> this\n    this == 0.0 -> Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) 1 else -1)\n}\n\n/**\n * Returns the [Double] value nearest to this value in direction of negative infinity.\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextDown(): Double = when {\n    this.isNaN() || this == Double.NEGATIVE_INFINITY -> this\n    this == 0.0 -> -Double.MIN_VALUE\n    else -> Double.fromBits(this.toRawBits() + if (this > 0) -1 else 1)\n}\n\n\n/**\n * Returns the [Double] value nearest to this value in direction from this value towards the value [to].\n *\n * Special cases:\n *   - `x.nextTowards(y)` is `NaN` if either `x` or `y` are `NaN`\n *   - `x.nextTowards(x) == x`\n *\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.nextTowards(to: Double): Double = when {\n    this.isNaN() || to.isNaN() -> Double.NaN\n    to == this -> to\n    to > this -> this.nextUp()\n    else /* to < this */ -> this.nextDown()\n}\n\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToInt(): Int = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Int.MAX_VALUE -> Int.MAX_VALUE\n    this < Int.MIN_VALUE -> Int.MIN_VALUE\n    else -> nativeMath.round(this).toInt()\n}\n\n/**\n * Rounds this [Double] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\npublic actual fun Double.roundToLong(): Long = when {\n    isNaN() -> throw IllegalArgumentException(\"Cannot round NaN value.\")\n    this > Long.MAX_VALUE -> Long.MAX_VALUE\n    this < Long.MIN_VALUE -> Long.MIN_VALUE\n    else -> nativeMath.round(this).toLong()\n}\n\n// endregion\n\n\n\n// region ================ Float Math ========================================\n\n/** Computes the sine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `sin(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sin(x: Float): Float = nativeMath.sin(x.toDouble()).toFloat()\n\n/** Computes the cosine of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `cos(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cos(x: Float): Float = nativeMath.cos(x.toDouble()).toFloat()\n\n/** Computes the tangent of the angle [x] given in radians.\n *\n *  Special cases:\n *   - `tan(NaN|+Inf|-Inf)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tan(x: Float): Float = nativeMath.tan(x.toDouble()).toFloat()\n\n/**\n * Computes the arc sine of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *    - `asin(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asin(x: Float): Float = nativeMath.asin(x.toDouble()).toFloat()\n\n/**\n * Computes the arc cosine of the value [x];\n * the returned value is an angle in the range from `0.0` to `PI` radians.\n *\n * Special cases:\n *    - `acos(x)` is `NaN`, when `abs(x) > 1` or x is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acos(x: Float): Float = nativeMath.acos(x.toDouble()).toFloat()\n\n/**\n * Computes the arc tangent of the value [x];\n * the returned value is an angle in the range from `-PI/2` to `PI/2` radians.\n *\n * Special cases:\n *   - `atan(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan(x: Float): Float = nativeMath.atan(x.toDouble()).toFloat()\n\n/**\n * Returns the angle `theta` of the polar coordinates `(r, theta)` that correspond\n * to the rectangular coordinates `(x, y)` by computing the arc tangent of the value [y] / [x];\n * the returned value is an angle in the range from `-PI` to `PI` radians.\n *\n * Special cases:\n *   - `atan2(0.0, 0.0)` is `0.0`\n *   - `atan2(0.0, x)` is  `0.0` for `x > 0` and `PI` for `x < 0`\n *   - `atan2(-0.0, x)` is `-0.0` for 'x > 0` and `-PI` for `x < 0`\n *   - `atan2(y, +Inf)` is `0.0` for `0 < y < +Inf` and `-0.0` for '-Inf < y < 0`\n *   - `atan2(y, -Inf)` is `PI` for `0 < y < +Inf` and `-PI` for `-Inf < y < 0`\n *   - `atan2(y, 0.0)` is `PI/2` for `y > 0` and `-PI/2` for `y < 0`\n *   - `atan2(+Inf, x)` is `PI/2` for finite `x`y\n *   - `atan2(-Inf, x)` is `-PI/2` for finite `x`\n *   - `atan2(NaN, x)` and `atan2(y, NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atan2(y: Float, x: Float): Float = nativeMath.atan2(y.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic sine of the value [x].\n *\n * Special cases:\n *   - `sinh(NaN)` is `NaN`\n *   - `sinh(+Inf)` is `+Inf`\n *   - `sinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sinh(x: Float): Float = nativeMath.sinh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic cosine of the value [x].\n *\n * Special cases:\n *   - `cosh(NaN)` is `NaN`\n *   - `cosh(+Inf|-Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun cosh(x: Float): Float = nativeMath.cosh(x.toDouble()).toFloat()\n\n/**\n * Computes the hyperbolic tangent of the value [x].\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(+Inf)` is `1.0`\n *   - `tanh(-Inf)` is `-1.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun tanh(x: Float): Float = nativeMath.tanh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic sine of the value [x].\n *\n * The returned value is `y` such that `sinh(y) == x`.\n *\n * Special cases:\n *   - `asinh(NaN)` is `NaN`\n *   - `asinh(+Inf)` is `+Inf`\n *   - `asinh(-Inf)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun asinh(x: Float): Float = nativeMath.asinh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic cosine of the value [x].\n *\n * The returned value is positive `y` such that `cosh(y) == x`.\n *\n * Special cases:\n *   - `acosh(NaN)` is `NaN`\n *   - `acosh(x)` is `NaN` when `x < 1`\n *   - `acosh(+Inf)` is `+Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun acosh(x: Float): Float = nativeMath.acosh(x.toDouble()).toFloat()\n\n/**\n * Computes the inverse hyperbolic tangent of the value [x].\n *\n * The returned value is `y` such that `tanh(y) == x`.\n *\n * Special cases:\n *   - `tanh(NaN)` is `NaN`\n *   - `tanh(x)` is `NaN` when `x > 1` or `x < -1`\n *   - `tanh(1.0)` is `+Inf`\n *   - `tanh(-1.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun atanh(x: Float): Float = nativeMath.atanh(x.toDouble()).toFloat()\n\n/**\n * Computes `sqrt(x^2 + y^2)` without intermediate overflow or underflow.\n *\n * Special cases:\n *   - returns `+Inf` if any of arguments is infinite\n *   - returns `NaN` if any of arguments is `NaN` and the other is not infinite\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun hypot(x: Float, y: Float): Float = nativeMath.hypot(x.toDouble(), y.toDouble()).toFloat()\n\n/**\n * Computes the positive square root of the value [x].\n *\n * Special cases:\n *   - `sqrt(x)` is `NaN` when `x < 0` or `x` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sqrt(x: Float): Float = nativeMath.sqrt(x.toDouble()).toFloat()\n\n/**\n * Computes Euler's number `e` raised to the power of the value [x].\n *\n * Special cases:\n *   - `exp(NaN)` is `NaN`\n *   - `exp(+Inf)` is `+Inf`\n *   - `exp(-Inf)` is `0.0`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun exp(x: Float): Float = nativeMath.exp(x.toDouble()).toFloat()\n\n/**\n * Computes `exp(x) - 1`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `expm1(NaN)` is `NaN`\n *   - `expm1(+Inf)` is `+Inf`\n *   - `expm1(-Inf)` is `-1.0`\n *\n * @see [exp] function.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun expm1(x: Float): Float = nativeMath.expm1(x.toDouble()).toFloat()\n\n/**\n * Computes the logarithm of the value [x] to the given [base].\n *\n * Special cases:\n *   - `log(x, b)` is `NaN` if either `x` or `b` are `NaN`\n *   - `log(x, b)` is `NaN` when `x < 0` or `b <= 0` or `b == 1.0`\n *   - `log(+Inf, +Inf)` is `NaN`\n *   - `log(+Inf, b)` is `+Inf` for `b > 1` and `-Inf` for `b < 1`\n *   - `log(0.0, b)` is `-Inf` for `b > 1` and `+Inf` for `b > 1`\n *\n * See also logarithm functions for common fixed bases: [ln], [log10] and [log2].\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log(x: Float, base: Float): Float = log(x.toDouble(), base.toDouble()).toFloat()\n\n/**\n * Computes the natural logarithm (base `E`) of the value [x].\n *\n * Special cases:\n *   - `ln(NaN)` is `NaN`\n *   - `ln(x)` is `NaN` when `x < 0.0`\n *   - `ln(+Inf)` is `+Inf`\n *   - `ln(0.0)` is `-Inf`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln(x: Float): Float = nativeMath.log(x.toDouble()).toFloat()\n\n/**\n * Computes the common logarithm (base 10) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log10(x: Float): Float = nativeMath.log10(x.toDouble()).toFloat()\n\n/**\n * Computes the binary logarithm (base 2) of the value [x].\n *\n * @see [ln] function for special cases.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun log2(x: Float): Float = nativeMath.log2(x.toDouble()).toFloat()\n\n/**\n * Computes `ln(a + 1)`.\n *\n * This function can be implemented to produce more precise result for [x] near zero.\n *\n * Special cases:\n *   - `ln1p(NaN)` is `NaN`\n *   - `ln1p(x)` is `NaN` where `x < -1.0`\n *   - `ln1p(-1.0)` is `-Inf`\n *   - `ln1p(+Inf)` is `+Inf`\n *\n * @see [ln] function\n * @see [expm1] function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ln1p(x: Float): Float = nativeMath.log1p(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards positive infinity.\n\n * @return the smallest Float value that is greater than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `ceil(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun ceil(x: Float): Float = nativeMath.ceil(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards negative infinity.\n\n * @return the largest Float value that is smaller than or equal to the given value [x] and is a mathematical integer.\n *\n * Special cases:\n *   - `floor(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun floor(x: Float): Float = nativeMath.floor(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] to an integer towards zero.\n *\n * @return the value [x] having its fractional part truncated.\n *\n * Special cases:\n *   - `truncate(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun truncate(x: Float): Float = truncate(x.toDouble()).toFloat()\n\n/**\n * Rounds the given value [x] towards the closest integer with ties rounded towards even integer.\n *\n * Special cases:\n *   - `round(x)` is `x` where `x` is `NaN` or `+Inf` or `-Inf` or already a mathematical integer.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun round(x: Float): Float = round(x.toDouble()).toFloat()\n\n\n/**\n * Returns the absolute value of the given value [x].\n *\n * Special cases:\n *   - `abs(NaN)` is `NaN`\n *\n * @see absoluteValue extension property for [Float]\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun abs(x: Float): Float = nativeMath.abs(x.toDouble()).toFloat()\n\n/**\n * Returns the sign of the given value [x]:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `sign(NaN)` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun sign(x: Float): Float = nativeMath.sign(x.toDouble()).toFloat()\n\n\n\n/**\n * Returns the smaller of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Float, b: Float): Float = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n *\n * If either value is `NaN`, then the result is `NaN`.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Float, b: Float): Float = nativeMath.max(a, b)\n\n// extensions\n\n\n/**\n * Raises this value to the power [x].\n *\n * Special cases:\n *   - `b.pow(0.0)` is `1.0`\n *   - `b.pow(1.0) == b`\n *   - `b.pow(NaN)` is `NaN`\n *   - `NaN.pow(x)` is `NaN` for `x != 0.0`\n *   - `b.pow(Inf)` is `NaN` for `abs(b) == 1.0`\n *   - `b.pow(x)` is `NaN` for `b < 0` and `x` is finite and not an integer\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(x: Float): Float = nativeMath.pow(this.toDouble(), x.toDouble()).toFloat()\n\n/**\n * Raises this value to the integer power [n].\n *\n * See the other overload of [pow] for details.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.pow(n: Int): Float = nativeMath.pow(this.toDouble(), n.toDouble()).toFloat()\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `NaN.absoluteValue` is `NaN`\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.absoluteValue: Float get() = nativeMath.abs(this.toDouble()).toFloat()\n\n/**\n * Returns the sign of this value:\n *   - `-1.0` if the value is negative,\n *   - zero if the value is zero,\n *   - `1.0` if the value is positive\n *\n * Special case:\n *   - `NaN.sign` is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Float.sign: Float get() = nativeMath.sign(this.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n *\n * If [sign] is `NaN` the sign of the result is undefined.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Float): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n/**\n * Returns this value with the sign bit same as of the [sign] value.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.withSign(sign: Int): Float = this.toDouble().withSign(sign.toDouble()).toFloat()\n\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Int].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToInt() == Int.MAX_VALUE` when `x > Int.MAX_VALUE`\n *   - `x.roundToInt() == Int.MIN_VALUE` when `x < Int.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToInt(): Int = toDouble().roundToInt()\n\n/**\n * Rounds this [Float] value to the nearest integer and converts the result to [Long].\n * Ties are rounded towards positive infinity.\n *\n * Special cases:\n *   - `x.roundToLong() == Long.MAX_VALUE` when `x > Long.MAX_VALUE`\n *   - `x.roundToLong() == Long.MIN_VALUE` when `x < Long.MIN_VALUE`\n *\n * @throws IllegalArgumentException when this value is `NaN`\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun Float.roundToLong(): Long = toDouble().roundToLong()\n\n\n// endregion\n\n// region ================ Integer Math ========================================\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Int.MIN_VALUE)` is `Int.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Int]\n */\n// TODO: remove manual 'or' when KT-19290 is fixed\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Int): Int = if (n < 0) (-n or 0) else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun min(a: Int, b: Int): Int = nativeMath.min(a, b)\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline fun max(a: Int, b: Int): Int = nativeMath.max(a, b)\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Int.MIN_VALUE.absoluteValue` is `Int.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Int.absoluteValue: Int get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Int.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n\n/**\n * Returns the absolute value of the given value [n].\n *\n * Special cases:\n *   - `abs(Long.MIN_VALUE)` is `Long.MIN_VALUE` due to an overflow\n *\n * @see absoluteValue extension property for [Long]\n */\n@SinceKotlin(\"1.2\")\npublic actual fun abs(n: Long): Long = if (n < 0) -n else n\n\n/**\n * Returns the smaller of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun min(a: Long, b: Long): Long = if (a <= b) a else b\n\n/**\n * Returns the greater of two values.\n */\n@SinceKotlin(\"1.2\")\n@Suppress(\"NOTHING_TO_INLINE\")\npublic actual inline fun max(a: Long, b: Long): Long = if (a >= b) a else b\n\n/**\n * Returns the absolute value of this value.\n *\n * Special cases:\n *   - `Long.MIN_VALUE.absoluteValue` is `Long.MIN_VALUE` due to an overflow\n *\n * @see abs function\n */\n@SinceKotlin(\"1.2\")\n@InlineOnly\npublic actual inline val Long.absoluteValue: Long get() = abs(this)\n\n/**\n * Returns the sign of this value:\n *   - `-1` if the value is negative,\n *   - `0` if the value is zero,\n *   - `1` if the value is positive\n */\n@SinceKotlin(\"1.2\")\npublic actual val Long.sign: Int get() = when {\n    this < 0 -> -1\n    this > 0 -> 1\n    else -> 0\n}\n\n\n// endregion\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"PreconditionsKt\")\n\npackage kotlin\n\nimport kotlin.contracts.contract\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    require(value) { \"Failed requirement.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failRequireWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun require(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalArgumentException] if the [value] is null. Otherwise returns the not null value.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return requireNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalArgumentException] with the result of calling [lazyMessage] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failRequireNotNullWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> requireNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalArgumentException(message.toString())\n    } else {\n        return value\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean): Unit {\n    contract {\n        returns() implies value\n    }\n    check(value) { \"Check failed.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage] if the [value] is false.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun check(value: Boolean, lazyMessage: () -> Any): Unit {\n    contract {\n        returns() implies value\n    }\n    if (!value) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    }\n}\n\n/**\n * Throws an [IllegalStateException] if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?): T {\n    contract {\n        returns() implies (value != null)\n    }\n    return checkNotNull(value) { \"Required value was null.\" }\n}\n\n/**\n * Throws an [IllegalStateException] with the result of calling [lazyMessage]  if the [value] is null. Otherwise\n * returns the not null value.\n *\n * @sample samples.misc.Preconditions.failCheckWithLazyMessage\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Any> checkNotNull(value: T?, lazyMessage: () -> Any): T {\n    contract {\n        returns() implies (value != null)\n    }\n\n    if (value == null) {\n        val message = lazyMessage()\n        throw IllegalStateException(message.toString())\n    } else {\n        return value\n    }\n}\n\n\n/**\n * Throws an [IllegalStateException] with the given [message].\n *\n * @sample samples.misc.Preconditions.failWithError\n */\n@kotlin.internal.InlineOnly\npublic inline fun error(message: Any): Nothing = throw IllegalStateException(message.toString())\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 1.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 2.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 3.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 4.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the list.\n * \n * Throws an [IndexOutOfBoundsException] if the size of this list is less than 5.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> List<T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the collection.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.contains(element: T): Boolean {\n    if (this is Collection)\n        return contains(element)\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic fun <T> Iterable<T>.elementAt(index: Int): T {\n    if (this is List)\n        return get(index)\n    return elementAtOrElse(index) { throw IndexOutOfBoundsException(\"Collection doesn't contain element at index $index.\") }\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAt(index: Int): T {\n    return get(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\npublic fun <T> Iterable<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    if (this is List)\n        return this.getOrElse(index, defaultValue)\n    if (index < 0)\n        return defaultValue(index)\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this collection.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\npublic fun <T> Iterable<T>.elementAtOrNull(index: Int): T? {\n    if (this is List)\n        return this.getOrNull(index)\n    if (index < 0)\n        return null\n    val iterator = iterator()\n    var count = 0\n    while (iterator.hasNext()) {\n        val element = iterator.next()\n        if (index == count++)\n            return element\n    }\n    return null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the collection is empty.\n */\npublic fun <T> Iterable<T>.first(): T {\n    when (this) {\n        is List -> return this.first()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the list is empty.\n */\npublic fun <T> List<T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Iterable<T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the collection was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this collection in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Iterable<T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the collection is empty.\n */\npublic fun <T> Iterable<T>.firstOrNull(): T? {\n    when (this) {\n        is List -> {\n            if (isEmpty())\n                return null\n            else\n                return this[0]\n        }\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            return iterator.next()\n        }\n    }\n}\n\n/**\n * Returns the first element, or `null` if the list is empty.\n */\npublic fun <T> List<T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Iterable<T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this list.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this list.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> List<T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.indexOf(element: T): Int {\n    if (this is List) return this.indexOf(element)\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.indexOf(element: T): Int {\n    return indexOf(element)\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    var index = 0\n    for (item in this) {\n        if (predicate(item))\n            return index\n        index++\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the collection does not contain such element.\n */\npublic inline fun <T> Iterable<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (predicate(item))\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the list does not contain such element.\n */\npublic inline fun <T> List<T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (predicate(iterator.previous())) {\n            return iterator.nextIndex()\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.last(): T {\n    when (this) {\n        is List -> return this.last()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"List is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.last(predicate: (T) -> Boolean): T {\n    var last: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return last as T\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.last(predicate: (T) -> Boolean): T {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"List contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the collection does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Iterable<T>.lastIndexOf(element: T): Int {\n    if (this is List) return this.lastIndexOf(element)\n    var lastIndex = -1\n    var index = 0\n    for (item in this) {\n        checkIndexOverflow(index)\n        if (element == item)\n            lastIndex = index\n        index++\n    }\n    return lastIndex\n}\n\n/**\n * Returns last index of [element], or -1 if the list does not contain element.\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\npublic fun <@kotlin.internal.OnlyInputTypes T> List<T>.lastIndexOf(element: T): Int {\n    return lastIndexOf(element)\n}\n\n/**\n * Returns the last element, or `null` if the collection is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Iterable<T>.lastOrNull(): T? {\n    when (this) {\n        is List -> return if (isEmpty()) null else this[size - 1]\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            var last = iterator.next()\n            while (iterator.hasNext())\n                last = iterator.next()\n            return last\n        }\n    }\n}\n\n/**\n * Returns the last element, or `null` if the list is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> List<T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Iterable<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    var last: T? = null\n    for (element in this) {\n        if (predicate(element)) {\n            last = element\n        }\n    }\n    return last\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> List<T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    val iterator = this.listIterator(size)\n    while (iterator.hasPrevious()) {\n        val element = iterator.previous()\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this collection.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness.\n * \n * @throws NoSuchElementException if this collection is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Collection<T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Collection is empty.\")\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this collection, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this collection using the specified source of randomness, or `null` if this collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Collection<T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return elementAt(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.single(): T {\n    when (this) {\n        is List -> return this.single()\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                throw NoSuchElementException(\"Collection is empty.\")\n            val single = iterator.next()\n            if (iterator.hasNext())\n                throw IllegalArgumentException(\"Collection has more than one element.\")\n            return single\n        }\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"List is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"List has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Iterable<T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Collection contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Collection contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns single element, or `null` if the collection is empty or has more than one element.\n */\npublic fun <T> Iterable<T>.singleOrNull(): T? {\n    when (this) {\n        is List -> return if (size == 1) this[0] else null\n        else -> {\n            val iterator = iterator()\n            if (!iterator.hasNext())\n                return null\n            val single = iterator.next()\n            if (iterator.hasNext())\n                return null\n            return single\n        }\n    }\n}\n\n/**\n * Returns single element, or `null` if the list is empty or has more than one element.\n */\npublic fun <T> List<T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Iterable<T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Iterable<T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return toList()\n    val list: ArrayList<T>\n    if (this is Collection<*>) {\n        val resultSize = size - n\n        if (resultSize <= 0)\n            return emptyList()\n        if (resultSize == 1)\n            return listOf(last())\n        list = ArrayList<T>(resultSize)\n        if (this is List<T>) {\n            if (this is RandomAccess) {\n                for (index in n until size)\n                    list.add(this[index])\n            } else {\n                for (item in listIterator(n))\n                    list.add(item)\n            }\n            return list\n        }\n    }\n    else {\n        list = ArrayList<T>()\n    }\n    var count = 0\n    for (item in this) {\n        if (count >= n) list.add(item) else ++count\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> List<T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> List<T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            if (!predicate(iterator.previous())) {\n                return take(iterator.nextIndex() + 1)\n            }\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Iterable<T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Iterable<T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Iterable<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Iterable<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Iterable<T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Iterable<T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Iterable<T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> List<T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return this.subList(indices.start, indices.endInclusive + 1).toList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> List<T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Iterable<T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (this is Collection<T>) {\n        if (n >= size) return toList()\n        if (n == 1) return listOf(first())\n    }\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list.optimizeReadOnlyList()\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> List<T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(last())\n    val list = ArrayList<T>(n)\n    if (this is RandomAccess) {\n        for (index in size - n until size)\n            list.add(this[index])\n    } else {\n        for (item in listIterator(size - n))\n            list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> List<T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    if (isEmpty())\n        return emptyList()\n    val iterator = listIterator(size)\n    while (iterator.hasPrevious()) {\n        if (!predicate(iterator.previous())) {\n            iterator.next()\n            val expectedSize = size - iterator.nextIndex()\n            if (expectedSize == 0) return emptyList()\n            return ArrayList<T>(expectedSize).apply {\n                while (iterator.hasNext())\n                    add(iterator.next())\n            }\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Iterable<T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the list in-place.\n */\npublic expect fun <T> MutableList<T>.reverse(): Unit\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Iterable<T>.reversed(): List<T> {\n    if (this is Collection && size <= 1) return toList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Randomly shuffles elements in this list in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> MutableList<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        this[j] = this.set(i, this[j])\n    }\n}\n\n/**\n * Sorts elements in the list in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> MutableList<T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the list in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> MutableList<T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sorted(): List<T> {\n    if (this is Collection) {\n        if (size <= 1) return this.toList()\n        @Suppress(\"UNCHECKED_CAST\")\n        return (toTypedArray<Comparable<T>>() as Array<T>).apply { sort() }.asList()\n    }\n    return toMutableList().apply { sort() }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Iterable<T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Iterable<T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Iterable<T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    if (this is Collection) {\n       if (size <= 1) return this.toList()\n       @Suppress(\"UNCHECKED_CAST\")\n       return (toTypedArray<Any?>() as Array<T>).apply { sortWith(comparator) }.asList()\n    }\n    return toMutableList().apply { sortWith(comparator) }\n}\n\n/**\n * Returns an array of Boolean containing all of the elements of this collection.\n */\npublic fun Collection<Boolean>.toBooleanArray(): BooleanArray {\n    val result = BooleanArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this collection.\n */\npublic fun Collection<Byte>.toByteArray(): ByteArray {\n    val result = ByteArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Char containing all of the elements of this collection.\n */\npublic fun Collection<Char>.toCharArray(): CharArray {\n    val result = CharArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Double containing all of the elements of this collection.\n */\npublic fun Collection<Double>.toDoubleArray(): DoubleArray {\n    val result = DoubleArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Float containing all of the elements of this collection.\n */\npublic fun Collection<Float>.toFloatArray(): FloatArray {\n    val result = FloatArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Int containing all of the elements of this collection.\n */\npublic fun Collection<Int>.toIntArray(): IntArray {\n    val result = IntArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Long containing all of the elements of this collection.\n */\npublic fun Collection<Long>.toLongArray(): LongArray {\n    val result = LongArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns an array of Short containing all of the elements of this collection.\n */\npublic fun Collection<Short>.toShortArray(): ShortArray {\n    val result = ShortArray(size)\n    var index = 0\n    for (element in this)\n        result[index++] = element\n    return result\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associate\n */\npublic inline fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given collection indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateBy\n */\npublic inline fun <T, K> Iterable<T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateByWithValueTransform\n */\npublic inline fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given collection\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given collection.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given collection.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Collections.Transformations.associateTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Iterable<T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given collection and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original collection.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V> Iterable<K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(collectionSizeOrDefault(10)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given collection,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.3\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Iterable<K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Iterable<T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Iterable<T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(collectionSizeOrDefault(12))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Iterable<T>.toList(): List<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyList()\n            1 -> listOf(if (this is List) get(0) else iterator().next())\n            else -> this.toMutableList()\n        }\n    }\n    return this.toMutableList().optimizeReadOnlyList()\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Iterable<T>.toMutableList(): MutableList<T> {\n    if (this is Collection<T>)\n        return this.toMutableList()\n    return toCollection(ArrayList<T>())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this collection.\n */\npublic fun <T> Collection<T>.toMutableList(): MutableList<T> {\n    return ArrayList(this)\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toSet(): Set<T> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptySet()\n            1 -> setOf(if (this is List) this[0] else iterator().next())\n            else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n        }\n    }\n    return toCollection(LinkedHashSet<T>()).optimizeReadOnlySet()\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Iterable<T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(checkIndexOverflow(index++), element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original collection, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Iterable<T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original collection.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Iterable<T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original collection by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original collection\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Iterable<T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from a collection to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Iterable<T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Iterable<T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original collection.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Iterable<T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original collection\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(checkIndexOverflow(index++), item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original collection.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Iterable<T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original collection\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Iterable<T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original collection\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original collection\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Iterable<T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given collection.\n * \n * Among equal elements of the given collection, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Iterable<T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given collection\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given collection with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source collection.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Iterable<T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this collection and the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Iterable<T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this collection and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic infix fun <T> Iterable<T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given collection.\n * \n * The returned set preserves the element iteration order of the original collection.\n */\npublic fun <T> Iterable<T>.toMutableSet(): MutableSet<T> {\n    return when (this) {\n        is Collection<T> -> LinkedHashSet(this)\n        else -> toCollection(LinkedHashSet<T>())\n    }\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original collection.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Iterable<T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Iterable<T>.all(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if collection has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Iterable<T>.any(): Boolean {\n    if (this is Collection) return !isEmpty()\n    return iterator().hasNext()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Iterable<T>.any(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return false\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this collection.\n */\npublic fun <T> Iterable<T>.count(): Int {\n    if (this is Collection) return size\n    var count = 0\n    for (element in this) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Returns the number of elements in this collection.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Iterable<T>.count(predicate: (T) -> Boolean): Int {\n    if (this is Collection && isEmpty()) return 0\n    var count = 0\n    for (element in this) if (predicate(element)) checkCountOverflow(++count)\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns the specified [initial] value if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Iterable<T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(checkIndexOverflow(index++), accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            accumulator = operation(iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns the specified [initial] value if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> List<T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var accumulator = initial\n    if (!isEmpty()) {\n        val iterator = listIterator(size)\n        while (iterator.hasPrevious()) {\n            val index = iterator.previousIndex()\n            accumulator = operation(index, iterator.previous(), accumulator)\n        }\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\n@kotlin.internal.HidesMembers\npublic inline fun <T> Iterable<T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Iterable<T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(checkIndexOverflow(index++), item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxElem = iterator.next()\n    if (!iterator.hasNext()) return maxElem\n    var maxValue = selector(maxElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    } while (iterator.hasNext())\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.maxOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var maxValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.maxOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.maxOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.maxOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var max = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Iterable<Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Iterable<T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minByOrNull(selector: (T) -> R): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minElem = iterator.next()\n    if (!iterator.hasNext()) return minElem\n    var minValue = selector(minElem)\n    do {\n        val e = iterator.next()\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    } while (iterator.hasNext())\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Double): Double {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOf(selector: (T) -> Float): Float {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOf(selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Double): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minOfOrNull(selector: (T) -> Float): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Iterable<T>.minOfOrNull(selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection.\n * \n * @throws NoSuchElementException if the collection is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    val iterator = iterator()\n    if (!iterator.hasNext()) throw NoSuchElementException()\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the collection or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Iterable<T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var minValue = selector(iterator.next())\n    while (iterator.hasNext()) {\n        val v = selector(iterator.next())\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Double>.minOrNull(): Double? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Iterable<Float>.minOrNull(): Float? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Iterable<T>.minOrNull(): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Iterable<T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Iterable<T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return null\n    var min = iterator.next()\n    while (iterator.hasNext()) {\n        val e = iterator.next()\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the collection has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Iterable<T>.none(): Boolean {\n    if (this is Collection) return isEmpty()\n    return !iterator().hasNext()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Iterable<T>.none(predicate: (T) -> Boolean): Boolean {\n    if (this is Collection && isEmpty()) return true\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the collection itself afterwards.\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, C : Iterable<T>> C.onEach(action: (T) -> Unit): C {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the collection itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, C : Iterable<T>> C.onEachIndexed(action: (index: Int, T) -> Unit): C {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Throws an exception if this collection is empty. If the collection can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Iterable<T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) throw UnsupportedOperationException(\"Empty collection can't be reduced.\")\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original collection.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var index = 1\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(checkIndexOverflow(index++), accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the collection is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return null\n    var accumulator: S = iterator.next()\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRight(operation: (T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Throws an exception if this list is empty. If the list can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> List<T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        throw UnsupportedOperationException(\"Empty list can't be reduced.\")\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original list and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> List<T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        val index = iterator.previousIndex()\n        accumulator = operation(index, iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the list is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> List<T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    val iterator = listIterator(size)\n    if (!iterator.hasPrevious())\n        return null\n    var accumulator: S = iterator.previous()\n    while (iterator.hasPrevious()) {\n        accumulator = operation(iterator.previous(), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Iterable<T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    val estimatedSize = collectionSizeOrDefault(9)\n    if (estimatedSize == 0) return listOf(initial)\n    val result = ArrayList<R>(estimatedSize + 1).apply { add(initial) }\n    var index = 0\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(index++, accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Iterable<T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    while (iterator.hasNext()) {\n        accumulator = operation(accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with the first element of this collection.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Iterable<T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    val iterator = this.iterator()\n    if (!iterator.hasNext()) return emptyList()\n    var accumulator: S = iterator.next()\n    val result = ArrayList<S>(collectionSizeOrDefault(10)).apply { add(accumulator) }\n    var index = 1\n    while (iterator.hasNext()) {\n        accumulator = operation(index++, accumulator, iterator.next())\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original collection and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Iterable<T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Iterable<T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the collection.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Iterable<T?>.requireNoNulls(): Iterable<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Iterable<T>\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> List<T?>.requireNoNulls(): List<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as List<T>\n}\n\n/**\n * Splits this collection into a list of lists each not exceeding the given [size].\n * \n * The last list in the resulting list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.collections.Collections.Transformations.chunked\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.chunked(size: Int): List<List<T>> {\n    return windowed(size, size, partialWindows = true)\n}\n\n/**\n * Splits this collection into several lists each not exceeding the given [size]\n * and applies the given [transform] function to an each.\n * \n * @return list of results of the [transform] applied to an each list.\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * The last list may have fewer elements than the given [size].\n * \n * @param size the number of elements to take in each list, must be positive and can be greater than the number of elements in this collection.\n * \n * @sample samples.text.Strings.chunkedTransform\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.chunked(size: Int, transform: (List<T>) -> R): List<R> {\n    return windowed(size, size, partialWindows = true, transform = transform)\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\npublic operator fun <T> Iterable<T>.minus(element: T): List<T> {\n    val result = ArrayList<T>(collectionSizeOrDefault(10))\n    var removed = false\n    return this.filterTo(result) { if (!removed && it == element) { removed = true; false } else true }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] array.\n * \n * The [elements] array may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Array<out T>): List<T> {\n    if (elements.isEmpty()) return this.toList()\n    val other = elements.toHashSet()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] collection.\n * \n * The [elements] collection may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Iterable<T>): List<T> {\n    val other = elements.convertToSetForSetOperationWith(this)\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection except the elements contained in the given [elements] sequence.\n * \n * The [elements] sequence may be converted to a [HashSet] to speed up the operation, thus the elements are required to have\n * a correct and stable implementation of `hashCode()` that doesn't change between successive invocations.\n */\npublic operator fun <T> Iterable<T>.minus(elements: Sequence<T>): List<T> {\n    val other = elements.toHashSet()\n    if (other.isEmpty())\n        return this.toList()\n    return this.filterNot { it in other }\n}\n\n/**\n * Returns a list containing all elements of the original collection without the first occurrence of the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.minusElement(element: T): List<T> {\n    return minus(element)\n}\n\n/**\n * Splits the original collection into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Iterables.Operations.partition\n */\npublic inline fun <T> Iterable<T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Iterable<T>.plus(element: T): List<T> {\n    if (this is Collection) return this.plus(element)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\npublic operator fun <T> Collection<T>.plus(element: T): List<T> {\n    val result = ArrayList<T>(size + 1)\n    result.addAll(this)\n    result.add(element)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Array<out T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] array.\n */\npublic operator fun <T> Collection<T>.plus(elements: Array<out T>): List<T> {\n    val result = ArrayList<T>(this.size + elements.size)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Iterable<T>): List<T> {\n    if (this is Collection) return this.plus(elements)\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] collection.\n */\npublic operator fun <T> Collection<T>.plus(elements: Iterable<T>): List<T> {\n    if (elements is Collection) {\n        val result = ArrayList<T>(this.size + elements.size)\n        result.addAll(this)\n        result.addAll(elements)\n        return result\n    } else {\n        val result = ArrayList<T>(this)\n        result.addAll(elements)\n        return result\n    }\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Iterable<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>()\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then all elements of the given [elements] sequence.\n */\npublic operator fun <T> Collection<T>.plus(elements: Sequence<T>): List<T> {\n    val result = ArrayList<T>(this.size + 10)\n    result.addAll(this)\n    result.addAll(elements)\n    return result\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list containing all elements of the original collection and then the given [element].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.plusElement(element: T): List<T> {\n    return plus(element)\n}\n\n/**\n * Returns a list of snapshots of the window of the given [size]\n * sliding along this collection with the given [step], where each\n * snapshot is a list.\n * \n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.takeWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false): List<List<T>> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<List<T>>(resultCapacity)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (windowSize < size && !partialWindows) break\n            result.add(List(windowSize) { this[it + index] })\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<List<T>>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = false).forEach {\n        result.add(it)\n    }\n    return result\n}\n\n/**\n * Returns a list of results of applying the given [transform] function to\n * an each list representing a view over the window of the given [size]\n * sliding along this collection with the given [step].\n * \n * Note that the list passed to the [transform] function is ephemeral and is valid only inside that function.\n * You should not store it or allow it to escape in some way, unless you made a snapshot of it.\n * Several last lists may have fewer elements than the given [size].\n * \n * Both [size] and [step] must be positive and can be greater than the number of elements in this collection.\n * @param size the number of elements to take in each window\n * @param step the number of elements to move the window forward by on an each step, by default 1\n * @param partialWindows controls whether or not to keep partial windows in the end if any,\n * by default `false` which means partial windows won't be preserved\n * \n * @sample samples.collections.Sequences.Transformations.averageWindows\n */\n@SinceKotlin(\"1.2\")\npublic fun <T, R> Iterable<T>.windowed(size: Int, step: Int = 1, partialWindows: Boolean = false, transform: (List<T>) -> R): List<R> {\n    checkWindowSizeStep(size, step)\n    if (this is RandomAccess && this is List) {\n        val thisSize = this.size\n        val resultCapacity = thisSize / step + if (thisSize % step == 0) 0 else 1\n        val result = ArrayList<R>(resultCapacity)\n        val window = MovingSubList(this)\n        var index = 0\n        while (index in 0 until thisSize) {\n            val windowSize = size.coerceAtMost(thisSize - index)\n            if (!partialWindows && windowSize < size) break\n            window.move(index, index + windowSize)\n            result.add(transform(window))\n            index += step\n        }\n        return result\n    }\n    val result = ArrayList<R>()\n    windowedIterator(iterator(), size, step, partialWindows, reuseBuffer = true).forEach {\n        result.add(transform(it))\n    }\n    return result\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = other.size\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in this) {\n        if (i >= arraySize) break\n        list.add(transform(element, other[i++]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] collection with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Iterable<T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` collection and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Iterable<T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val first = iterator()\n    val second = other.iterator()\n    val list = ArrayList<V>(minOf(collectionSizeOrDefault(10), other.collectionSizeOrDefault(10)))\n    while (first.hasNext() && second.hasNext()) {\n        list.add(transform(first.next(), second.next()))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs of each two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNext\n */\n@SinceKotlin(\"1.2\")\npublic fun <T> Iterable<T>.zipWithNext(): List<Pair<T, T>> {\n    return zipWithNext { a, b -> a to b }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to an each pair of two adjacent elements in this collection.\n * \n * The returned list is empty if this collection contains less than two elements.\n * \n * @sample samples.collections.Collections.Transformations.zipWithNextToFindDeltas\n */\n@SinceKotlin(\"1.2\")\npublic inline fun <T, R> Iterable<T>.zipWithNext(transform: (a: T, b: T) -> R): List<R> {\n    val iterator = iterator()\n    if (!iterator.hasNext()) return emptyList()\n    val result = mutableListOf<R>()\n    var current = iterator.next()\n    while (iterator.hasNext()) {\n        val next = iterator.next()\n        result.add(transform(current, next))\n        current = next\n    }\n    return result\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Iterable<T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Iterable<T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Returns this collection as an [Iterable].\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Iterable<T>.asIterable(): Iterable<T> {\n    return this\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original collection returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromCollection\n */\npublic fun <T> Iterable<T>.asSequence(): Sequence<T> {\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Iterable<Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Iterable<Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Iterable<Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Iterable<Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Iterable<Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the collection.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Iterable<Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        checkCountOverflow(++count)\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Iterable<Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Iterable<Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Iterable<Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Iterable<Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Iterable<Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the collection.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Iterable<Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n@file:kotlin.jvm.JvmName(\"ComparisonsKt\")\n@file:kotlin.jvm.JvmMultifileClass\n\npackage kotlin.comparisons\n\n/**\n * Compares two values using the specified functions [selectors] to calculate the result of the comparison.\n * The functions are called sequentially, receive the given values [a] and [b] and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for [a] and [b] values do not\n * compare as equal, the result of that comparison is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSelectors\n */\npublic fun <T> compareValuesBy(a: T, b: T, vararg selectors: (T) -> Comparable<*>?): Int {\n    require(selectors.size > 0)\n    return compareValuesByImpl(a, b, selectors)\n}\n\nprivate fun <T> compareValuesByImpl(a: T, b: T, selectors: Array<out (T) -> Comparable<*>?>): Int {\n    for (fn in selectors) {\n        val v1 = fn(a)\n        val v2 = fn(b)\n        val diff = compareValues(v1, v2)\n        if (diff != 0) return diff\n    }\n    return 0\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return [Comparable] objects.\n * The result of comparison of these [Comparable] instances is returned.\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareValuesBy(a: T, b: T, selector: (T) -> Comparable<*>?): Int {\n    return compareValues(selector(a), selector(b))\n}\n\n/**\n * Compares two values using the specified [selector] function to calculate the result of the comparison.\n * The function is applied to the given values [a] and [b] and return objects of type K which are then being\n * compared with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.compareValuesByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareValuesBy(a: T, b: T, comparator: Comparator<in K>, selector: (T) -> K): Int {\n    return comparator.compare(selector(a), selector(b))\n}\n\n//// Not so useful without type inference for receiver of expression\n//// compareValuesWith(v1, v2, compareBy { it.prop1 } thenByDescending { it.prop2 })\n///**\n// * Compares two values using the specified [comparator].\n// */\n//@Suppress(\"NOTHING_TO_INLINE\")\n//public inline fun <T> compareValuesWith(a: T, b: T, comparator: Comparator<T>): Int = comparator.compare(a, b)\n//\n\n\n/**\n * Compares two nullable [Comparable] values. Null is considered less than any value.\n *\n * @sample samples.comparisons.Comparisons.compareValues\n */\npublic fun <T : Comparable<*>> compareValues(a: T?, b: T?): Int {\n    if (a === b) return 0\n    if (a == null) return -1\n    if (b == null) return 1\n\n    @Suppress(\"UNCHECKED_CAST\")\n    return (a as Comparable<Any>).compareTo(b)\n}\n\n/**\n * Creates a comparator using the sequence of functions to calculate a result of comparison.\n * The functions are called sequentially, receive the given values `a` and `b` and return [Comparable]\n * objects. As soon as the [Comparable] instances returned by a function for `a` and `b` values do not\n * compare as equal, the result of that comparison is returned from the [Comparator].\n *\n * @sample samples.comparisons.Comparisons.compareByWithSelectors\n */\npublic fun <T> compareBy(vararg selectors: (T) -> Comparable<*>?): Comparator<T> {\n    require(selectors.size > 0)\n    return Comparator { a, b -> compareValuesByImpl(a, b, selectors) }\n}\n\n\n/**\n * Creates a comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, selector) }\n\n/**\n * Creates a comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * @sample samples.comparisons.Comparisons.compareByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(a, b, comparator, selector) }\n\n/**\n * Creates a descending comparator using the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithSingleSelector\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> compareByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, selector) }\n\n/**\n * Creates a descending comparator using the [selector] function to transform values being compared and then applying\n * the specified [comparator] to compare transformed values.\n *\n * Note that an order of [comparator] is reversed by this wrapper.\n *\n * @sample samples.comparisons.Comparisons.compareByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> compareByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b -> compareValuesBy(b, a, comparator, selector) }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenBy\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenBy(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, selector)\n    }\n\n/**\n * Creates a comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenBy(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenBy.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(a, b, comparator, selector)\n    }\n\n/**\n * Creates a descending comparator using the primary comparator and\n * the function to transform value to a [Comparable] instance for comparison.\n *\n * @sample samples.comparisons.Comparisons.thenByDescending\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenByDescending(crossinline selector: (T) -> Comparable<*>?): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, selector)\n    }\n\n/**\n * Creates a descending comparator comparing values after the primary comparator defined them equal. It uses\n * the [selector] function to transform values and then compares them with the given [comparator].\n *\n * @sample samples.comparisons.Comparisons.thenByDescendingWithComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, K> Comparator<T>.thenByDescending(comparator: Comparator<in K>, crossinline selector: (T) -> K): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenByDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else compareValuesBy(b, a, comparator, selector)\n    }\n\n\n/**\n * Creates a comparator using the primary comparator and function to calculate a result of comparison.\n *\n * @sample samples.comparisons.Comparisons.thenComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Comparator<T>.thenComparator(crossinline comparison: (a: T, b: T) -> Int): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@thenComparator.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparison(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.then\n */\npublic infix fun <T> Comparator<T>.then(comparator: Comparator<in T>): Comparator<T> =\n    Comparator { a, b ->\n        val previousCompare = this@then.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(a, b)\n    }\n\n/**\n * Combines this comparator and the given [comparator] such that the latter is applied only\n * when the former considered values equal.\n *\n * @sample samples.comparisons.Comparisons.thenDescending\n */\npublic infix fun <T> Comparator<T>.thenDescending(comparator: Comparator<in T>): Comparator<T> =\n    Comparator<T> { a, b ->\n        val previousCompare = this@thenDescending.compare(a, b)\n        if (previousCompare != 0) previousCompare else comparator.compare(b, a)\n    }\n\n// Not so useful without type inference for receiver of expression\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsFirst(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> -1\n            b == null -> 1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value less than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsFirst(): Comparator<T?> = nullsFirst(naturalOrder())\n\n/**\n * Extends the given [comparator] of non-nullable values to a comparator of nullable values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Any> nullsLast(comparator: Comparator<in T>): Comparator<T?> =\n    Comparator { a, b ->\n        when {\n            a === b -> 0\n            a == null -> 1\n            b == null -> -1\n            else -> comparator.compare(a, b)\n        }\n    }\n\n/**\n * Provides a comparator of nullable [Comparable] values\n * considering `null` value greater than any other value.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastComparator\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T : Comparable<T>> nullsLast(): Comparator<T?> = nullsLast(naturalOrder())\n\n/**\n * Returns a comparator that compares [Comparable] objects in natural order.\n *\n * @sample samples.comparisons.Comparisons.naturalOrderComparator\n */\npublic fun <T : Comparable<T>> naturalOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n\n/**\n * Returns a comparator that compares [Comparable] objects in reversed natural order.\n *\n * @sample samples.comparisons.Comparisons.nullsFirstLastWithComparator\n */\npublic fun <T : Comparable<T>> reverseOrder(): Comparator<T> = @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n\n/**\n *  Returns a comparator that imposes the reverse ordering of this comparator.\n *\n *  @sample samples.comparisons.Comparisons.reversed\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\")\npublic fun <T> Comparator<T>.reversed(): Comparator<T> = when (this) {\n    is ReversedComparator -> this.comparator\n    NaturalOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (ReverseOrderComparator as Comparator<T>)\n    ReverseOrderComparator -> @Suppress(\"UNCHECKED_CAST\") (NaturalOrderComparator as Comparator<T>)\n    else -> ReversedComparator(this)\n}\n\n\nprivate class ReversedComparator<T>(public val comparator: Comparator<T>) : Comparator<T> {\n    override fun compare(a: T, b: T): Int = comparator.compare(b, a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<T> = comparator\n}\n\nprivate object NaturalOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = a.compareTo(b)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = ReverseOrderComparator\n}\n\nprivate object ReverseOrderComparator : Comparator<Comparable<Any>> {\n    override fun compare(a: Comparable<Any>, b: Comparable<Any>): Int = b.compareTo(a)\n    @Suppress(\"VIRTUAL_MEMBER_HIDDEN\")\n    fun reversed(): Comparator<Comparable<Any>> = NaturalOrderComparator\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport kotlin.math.max\nimport kotlin.math.min\n\nobject ColorPalette {\n    private const val MIN_COLOR_SET_SIZE = 3\n\n    private fun colors(scheme: ColorScheme, count: Int): Array<String> {\n        @Suppress(\"NAME_SHADOWING\") var count = count\n        count = max(MIN_COLOR_SET_SIZE, count)\n        count = min(scheme.maxColors, count)\n        return scheme.colorSet[count - MIN_COLOR_SET_SIZE]\n    }\n\n    private fun maxColorSetSize(scheme: ColorScheme): Int {\n        val colorSet = scheme.colorSet\n        return colorSet[colorSet.size - 1].size\n    }\n\n    enum class Type(private val myPresentation: String) {\n        SEQUENTIAL(\"sequential\"),\n        DIVERGING(\"diverging\"),\n        QUALITATIVE(\"qualitative\");\n\n        override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Sequential(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        Blues(\"blues\", ColorSets.BLUES),\n        BuGn(\"blue-green\", ColorSets.BU_GN),\n        BuPu(\"blue-purple\", ColorSets.BU_PU),\n        GnBu(\"green-blue\", ColorSets.GN_BU),\n        Greens(\"greens\", ColorSets.GREENS),\n        Greys(\"greys\", ColorSets.GREYS),\n        Oranges(\"oranges\", ColorSets.ORANGES),\n        OrRd(\"orange-red\", ColorSets.OR_RD),\n        PuBu(\"purple-blue\", ColorSets.PU_BU),\n        PuBuGn(\"purple-blue-green\", ColorSets.PU_BU_GN),\n        PuRd(\"purple-red\", ColorSets.PU_RD),\n        Purples(\"purples\", ColorSets.PURPLES),\n        RdPu(\"red-purple\", ColorSets.RD_PU),\n        Reds(\"reds\", ColorSets.REDS),\n        YlGn(\"yellow-green\", ColorSets.YL_GN),\n        YlGnBu(\"yellow-green-blue\", ColorSets.YL_GN_BU),\n        YlOrBr(\"yellow-orange-brown\", ColorSets.YL_OR_BR),\n        YlOrRd(\"yellow-orange-red\", ColorSets.YL_OR_RD);\n\n        final override val type: Type\n            get() = ColorPalette.Type.SEQUENTIAL\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Diverging(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        BrBG(\"brown-blue/green\", ColorSets.BR_BG),\n        PiYG(\"pink-yellow/green\", ColorSets.PI_YG),\n        PRGn(\"purple/red-green\", ColorSets.PR_GN),\n        PuOr(\"purple-orange\", ColorSets.PU_OR),\n        RdBu(\"red-blue\", ColorSets.RD_BU),\n        RdGy(\"red-grey\", ColorSets.RD_GY),\n        RdYlBu(\"red-yellow-blue\", ColorSets.RD_YL_BU),\n        RdYlGn(\"red-yellow-green\", ColorSets.RD_YL_GN),\n        Spectral(\"spectral\", ColorSets.SPECTRAL);\n\n        final override val type: Type\n            get() = ColorPalette.Type.DIVERGING\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n    // redundant `final` in overridden members are necessary due to kotlin-native issue:\n    // `Not in vtable error` #2865\n    // https://github.com/JetBrains/kotlin-native/issues/2865\n    @Suppress(\"RedundantModalityModifier\")\n    enum class Qualitative(private val myPresentation: String, final override val colorSet: Array<Array<String>>) :\n        ColorScheme {\n        Accent(\"accent\", ColorSets.ACCENT),\n        Dark2(\"dark 2\", ColorSets.DARK_2),\n        Paired(\"paired\", ColorSets.PAIRED),\n        Pastel1(\"pastel 1\", ColorSets.PASTEL_1),\n        Pastel2(\"pastel 2\", ColorSets.PASTEL_2),\n        Set1(\"set 1\", ColorSets.SET_1),\n        Set2(\"set 2\", ColorSets.SET_2),\n        Set3(\"set 3\", ColorSets.SET_3);\n\n        final override val type: Type\n            get() = Type.QUALITATIVE\n\n        final override val maxColors: Int\n            get() = maxColorSetSize(this)\n\n        final override fun getColors(count: Int): Array<String> {\n            return colors(this, count)\n        }\n\n        final override fun toString(): String {\n            return myPresentation\n        }\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\n/**\n * source: colorbrewer2.org/\n */\ninternal object ColorSets {\n    // --------------------\n    // sequential multi-hue\n    // --------------------\n    // blue - green\n    val BU_GN_3 = arrayOf(\"#e5f5f9\", \"#99d8c9\", \"#2ca25f\")\n    val BU_GN_4 = arrayOf(\"#edf8fb\", \"#b2e2e2\", \"#66c2a4\", \"#238b45\")\n    val BU_GN_5 = arrayOf(\"#edf8fb\", \"#b2e2e2\", \"#66c2a4\", \"#2ca25f\", \"#006d2c\")\n    val BU_GN_6 = arrayOf(\"#edf8fb\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#2ca25f\", \"#006d2c\")\n    val BU_GN_7 = arrayOf(\"#edf8fb\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#005824\")\n    val BU_GN_8 = arrayOf(\"#f7fcfd\", \"#e5f5f9\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#005824\")\n    val BU_GN_9 = arrayOf(\"#f7fcfd\", \"#e5f5f9\", \"#ccece6\", \"#99d8c9\", \"#66c2a4\", \"#41ae76\", \"#238b45\", \"#006d2c\", \"#00441b\")\n    // blue - purple\n    val BU_PU_3 = arrayOf(\"#e0ecf4\", \"#9ebcda\", \"#8856a7\")\n    val BU_PU_4 = arrayOf(\"#edf8fb\", \"#b3cde3\", \"#8c96c6\", \"#88419d\")\n    val BU_PU_5 = arrayOf(\"#edf8fb\", \"#b3cde3\", \"#8c96c6\", \"#8856a7\", \"#810f7c\")\n    val BU_PU_6 = arrayOf(\"#edf8fb\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8856a7\", \"#810f7c\")\n    val BU_PU_7 = arrayOf(\"#edf8fb\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#6e016b\")\n    val BU_PU_8 = arrayOf(\"#f7fcfd\", \"#e0ecf4\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#6e016b\")\n    val BU_PU_9 = arrayOf(\"#f7fcfd\", \"#e0ecf4\", \"#bfd3e6\", \"#9ebcda\", \"#8c96c6\", \"#8c6bb1\", \"#88419d\", \"#810f7c\", \"#4d004b\")\n    // green - blue\n    val GN_BU_3 = arrayOf(\"#e0f3db\", \"#a8ddb5\", \"#43a2ca\")\n    val GN_BU_4 = arrayOf(\"#f0f9e8\", \"#bae4bc\", \"#7bccc4\", \"#2b8cbe\")\n    val GN_BU_5 = arrayOf(\"#f0f9e8\", \"#bae4bc\", \"#7bccc4\", \"#43a2ca\", \"#0868ac\")\n    val GN_BU_6 = arrayOf(\"#f0f9e8\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#43a2ca\", \"#0868ac\")\n    val GN_BU_7 = arrayOf(\"#f0f9e8\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#08589e\")\n    val GN_BU_8 = arrayOf(\"#f7fcf0\", \"#e0f3db\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#08589e\")\n    val GN_BU_9 = arrayOf(\"#f7fcf0\", \"#e0f3db\", \"#ccebc5\", \"#a8ddb5\", \"#7bccc4\", \"#4eb3d3\", \"#2b8cbe\", \"#0868ac\", \"#084081\")\n    // orange - red\n    val OR_RD_3 = arrayOf(\"#fee8c8\", \"#fdbb84\", \"#e34a33\")\n    val OR_RD_4 = arrayOf(\"#fef0d9\", \"#fdcc8a\", \"#fc8d59\", \"#d7301f\")\n    val OR_RD_5 = arrayOf(\"#fef0d9\", \"#fdcc8a\", \"#fc8d59\", \"#e34a33\", \"#b30000\")\n    val OR_RD_6 = arrayOf(\"#fef0d9\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#e34a33\", \"#b30000\")\n    val OR_RD_7 = arrayOf(\"#fef0d9\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#990000\")\n    val OR_RD_8 = arrayOf(\"#fff7ec\", \"#fee8c8\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#990000\")\n    val OR_RD_9 = arrayOf(\"#fff7ec\", \"#fee8c8\", \"#fdd49e\", \"#fdbb84\", \"#fc8d59\", \"#ef6548\", \"#d7301f\", \"#b30000\", \"#7f0000\")\n    // purple - blue\n    val PU_BU_3 = arrayOf(\"#ece7f2\", \"#a6bddb\", \"#2b8cbe\")\n    val PU_BU_4 = arrayOf(\"#f1eef6\", \"#bdc9e1\", \"#74a9cf\", \"#0570b0\")\n    val PU_BU_5 = arrayOf(\"#f1eef6\", \"#bdc9e1\", \"#74a9cf\", \"#2b8cbe\", \"#045a8d\")\n    val PU_BU_6 = arrayOf(\"#f1eef6\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#2b8cbe\", \"#045a8d\")\n    val PU_BU_7 = arrayOf(\"#f1eef6\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#034e7b\")\n    val PU_BU_8 = arrayOf(\"#fff7fb\", \"#ece7f2\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#034e7b\")\n    val PU_BU_9 = arrayOf(\"#fff7fb\", \"#ece7f2\", \"#d0d1e6\", \"#a6bddb\", \"#74a9cf\", \"#3690c0\", \"#0570b0\", \"#045a8d\", \"#023858\")\n    // purple - blue - green\n    val PU_BU_GN_3 = arrayOf(\"#ece2f0\", \"#a6bddb\", \"#1c9099\")\n    val PU_BU_GN_4 = arrayOf(\"#f6eff7\", \"#bdc9e1\", \"#67a9cf\", \"#02818a\")\n    val PU_BU_GN_5 = arrayOf(\"#f6eff7\", \"#bdc9e1\", \"#67a9cf\", \"#1c9099\", \"#016c59\")\n    val PU_BU_GN_6 = arrayOf(\"#f6eff7\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#1c9099\", \"#016c59\")\n    val PU_BU_GN_7 = arrayOf(\"#f6eff7\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016450\")\n    val PU_BU_GN_8 = arrayOf(\"#fff7fb\", \"#ece2f0\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016450\")\n    val PU_BU_GN_9 = arrayOf(\"#fff7fb\", \"#ece2f0\", \"#d0d1e6\", \"#a6bddb\", \"#67a9cf\", \"#3690c0\", \"#02818a\", \"#016c59\", \"#014636\")\n    // purple - red\n    val PU_RD_3 = arrayOf(\"#e7e1ef\", \"#c994c7\", \"#dd1c77\")\n    val PU_RD_4 = arrayOf(\"#f1eef6\", \"#d7b5d8\", \"#df65b0\", \"#ce1256\")\n    val PU_RD_5 = arrayOf(\"#f1eef6\", \"#d7b5d8\", \"#df65b0\", \"#dd1c77\", \"#980043\")\n    val PU_RD_6 = arrayOf(\"#f1eef6\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#dd1c77\", \"#980043\")\n    val PU_RD_7 = arrayOf(\"#f1eef6\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#91003f\")\n    val PU_RD_8 = arrayOf(\"#f7f4f9\", \"#e7e1ef\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#91003f\")\n    val PU_RD_9 = arrayOf(\"#f7f4f9\", \"#e7e1ef\", \"#d4b9da\", \"#c994c7\", \"#df65b0\", \"#e7298a\", \"#ce1256\", \"#980043\", \"#67001f\")\n    // red - purple\n    val RD_PU_3 = arrayOf(\"#fde0dd\", \"#fa9fb5\", \"#c51b8a\")\n    val RD_PU_4 = arrayOf(\"#feebe2\", \"#fbb4b9\", \"#f768a1\", \"#ae017e\")\n    val RD_PU_5 = arrayOf(\"#feebe2\", \"#fbb4b9\", \"#f768a1\", \"#c51b8a\", \"#7a0177\")\n    val RD_PU_6 = arrayOf(\"#feebe2\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#c51b8a\", \"#7a0177\")\n    val RD_PU_7 = arrayOf(\"#feebe2\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\")\n    val RD_PU_8 = arrayOf(\"#fff7f3\", \"#fde0dd\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\")\n    val RD_PU_9 = arrayOf(\"#fff7f3\", \"#fde0dd\", \"#fcc5c0\", \"#fa9fb5\", \"#f768a1\", \"#dd3497\", \"#ae017e\", \"#7a0177\", \"#49006a\")\n    // yellow - green\n    val YL_GN_3 = arrayOf(\"#f7fcb9\", \"#addd8e\", \"#31a354\")\n    val YL_GN_4 = arrayOf(\"#ffffcc\", \"#c2e699\", \"#78c679\", \"#238443\")\n    val YL_GN_5 = arrayOf(\"#ffffcc\", \"#c2e699\", \"#78c679\", \"#31a354\", \"#006837\")\n    val YL_GN_6 = arrayOf(\"#ffffcc\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#31a354\", \"#006837\")\n    val YL_GN_7 = arrayOf(\"#ffffcc\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#005a32\")\n    val YL_GN_8 = arrayOf(\"#ffffe5\", \"#f7fcb9\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#005a32\")\n    val YL_GN_9 = arrayOf(\"#ffffe5\", \"#f7fcb9\", \"#d9f0a3\", \"#addd8e\", \"#78c679\", \"#41ab5d\", \"#238443\", \"#006837\", \"#004529\")\n    // yellow - green - blue\n    val YL_GN_BU_3 = arrayOf(\"#edf8b1\", \"#7fcdbb\", \"#2c7fb8\")\n    val YL_GN_BU_4 = arrayOf(\"#ffffcc\", \"#a1dab4\", \"#41b6c4\", \"#225ea8\")\n    val YL_GN_BU_5 = arrayOf(\"#ffffcc\", \"#a1dab4\", \"#41b6c4\", \"#2c7fb8\", \"#253494\")\n    val YL_GN_BU_6 = arrayOf(\"#ffffcc\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#2c7fb8\", \"#253494\")\n    val YL_GN_BU_7 = arrayOf(\"#ffffcc\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#0c2c84\")\n    val YL_GN_BU_8 = arrayOf(\"#ffffd9\", \"#edf8b1\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#0c2c84\")\n    val YL_GN_BU_9 = arrayOf(\"#ffffd9\", \"#edf8b1\", \"#c7e9b4\", \"#7fcdbb\", \"#41b6c4\", \"#1d91c0\", \"#225ea8\", \"#253494\", \"#081d58\")\n    // yellow - orange - brown\n    val YL_OR_BR_3 = arrayOf(\"#fff7bc\", \"#fec44f\", \"#d95f0e\")\n    val YL_OR_BR_4 = arrayOf(\"#ffffd4\", \"#fed98e\", \"#fe9929\", \"#cc4c02\")\n    val YL_OR_BR_5 = arrayOf(\"#ffffd4\", \"#fed98e\", \"#fe9929\", \"#d95f0e\", \"#993404\")\n    val YL_OR_BR_6 = arrayOf(\"#ffffd4\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#d95f0e\", \"#993404\")\n    val YL_OR_BR_7 = arrayOf(\"#ffffd4\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#8c2d04\")\n    val YL_OR_BR_8 = arrayOf(\"#ffffe5\", \"#fff7bc\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#8c2d04\")\n    val YL_OR_BR_9 = arrayOf(\"#ffffe5\", \"#fff7bc\", \"#fee391\", \"#fec44f\", \"#fe9929\", \"#ec7014\", \"#cc4c02\", \"#993404\", \"#662506\")\n    // yellow - orange - red\n    val YL_OR_RD_3 = arrayOf(\"#ffeda0\", \"#feb24c\", \"#f03b20\")\n    val YL_OR_RD_4 = arrayOf(\"#ffffb2\", \"#fecc5c\", \"#fd8d3c\", \"#e31a1c\")\n    val YL_OR_RD_5 = arrayOf(\"#ffffb2\", \"#fecc5c\", \"#fd8d3c\", \"#f03b20\", \"#bd0026\")\n    val YL_OR_RD_6 = arrayOf(\"#ffffb2\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#f03b20\", \"#bd0026\")\n    val YL_OR_RD_7 = arrayOf(\"#ffffb2\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#b10026\")\n    val YL_OR_RD_8 = arrayOf(\"#ffffcc\", \"#ffeda0\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#b10026\")\n    val YL_OR_RD_9 = arrayOf(\"#ffffcc\", \"#ffeda0\", \"#fed976\", \"#feb24c\", \"#fd8d3c\", \"#fc4e2a\", \"#e31a1c\", \"#bd0026\", \"#800026\")\n\n\n    val BU_GN = arrayOf(\n        BU_GN_3,\n        BU_GN_4,\n        BU_GN_5,\n        BU_GN_6,\n        BU_GN_7,\n        BU_GN_8,\n        BU_GN_9\n    )\n    val BU_PU = arrayOf(\n        BU_PU_3,\n        BU_PU_4,\n        BU_PU_5,\n        BU_PU_6,\n        BU_PU_7,\n        BU_PU_8,\n        BU_PU_9\n    )\n    val GN_BU = arrayOf(\n        GN_BU_3,\n        GN_BU_4,\n        GN_BU_5,\n        GN_BU_6,\n        GN_BU_7,\n        GN_BU_8,\n        GN_BU_9\n    )\n    val OR_RD = arrayOf(\n        OR_RD_3,\n        OR_RD_4,\n        OR_RD_5,\n        OR_RD_6,\n        OR_RD_7,\n        OR_RD_8,\n        OR_RD_9\n    )\n    val PU_BU = arrayOf(\n        PU_BU_3,\n        PU_BU_4,\n        PU_BU_5,\n        PU_BU_6,\n        PU_BU_7,\n        PU_BU_8,\n        PU_BU_9\n    )\n    val PU_BU_GN = arrayOf(\n        PU_BU_GN_3,\n        PU_BU_GN_4,\n        PU_BU_GN_5,\n        PU_BU_GN_6,\n        PU_BU_GN_7,\n        PU_BU_GN_8,\n        PU_BU_GN_9\n    )\n    val PU_RD = arrayOf(\n        PU_RD_3,\n        PU_RD_4,\n        PU_RD_5,\n        PU_RD_6,\n        PU_RD_7,\n        PU_RD_8,\n        PU_RD_9\n    )\n    val RD_PU = arrayOf(\n        RD_PU_3,\n        RD_PU_4,\n        RD_PU_5,\n        RD_PU_6,\n        RD_PU_7,\n        RD_PU_8,\n        RD_PU_9\n    )\n    val YL_GN = arrayOf(\n        YL_GN_3,\n        YL_GN_4,\n        YL_GN_5,\n        YL_GN_6,\n        YL_GN_7,\n        YL_GN_8,\n        YL_GN_9\n    )\n    val YL_GN_BU = arrayOf(\n        YL_GN_BU_3,\n        YL_GN_BU_4,\n        YL_GN_BU_5,\n        YL_GN_BU_6,\n        YL_GN_BU_7,\n        YL_GN_BU_8,\n        YL_GN_BU_9\n    )\n    val YL_OR_BR = arrayOf(\n        YL_OR_BR_3,\n        YL_OR_BR_4,\n        YL_OR_BR_5,\n        YL_OR_BR_6,\n        YL_OR_BR_7,\n        YL_OR_BR_8,\n        YL_OR_BR_9\n    )\n    val YL_OR_RD = arrayOf(\n        YL_OR_RD_3,\n        YL_OR_RD_4,\n        YL_OR_RD_5,\n        YL_OR_RD_6,\n        YL_OR_RD_7,\n        YL_OR_RD_8,\n        YL_OR_RD_9\n    )\n\n    // --------------------\n    // sequential single-hue\n    // --------------------\n    // Blues\n    val BLUES_3 = arrayOf(\"#deebf7\", \"#9ecae1\", \"#3182bd\")\n    val BLUES_4 = arrayOf(\"#eff3ff\", \"#bdd7e7\", \"#6baed6\", \"#2171b5\")\n    val BLUES_5 = arrayOf(\"#eff3ff\", \"#bdd7e7\", \"#6baed6\", \"#3182bd\", \"#08519c\")\n    val BLUES_6 = arrayOf(\"#eff3ff\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#3182bd\", \"#08519c\")\n    val BLUES_7 = arrayOf(\"#eff3ff\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#084594\")\n    val BLUES_8 = arrayOf(\"#f7fbff\", \"#deebf7\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#084594\")\n    val BLUES_9 = arrayOf(\"#f7fbff\", \"#deebf7\", \"#c6dbef\", \"#9ecae1\", \"#6baed6\", \"#4292c6\", \"#2171b5\", \"#08519c\", \"#08306b\")\n    // Greens\n    val GREENS_3 = arrayOf(\"#e5f5e0\", \"#a1d99b\", \"#31a354\")\n    val GREENS_4 = arrayOf(\"#edf8e9\", \"#bae4b3\", \"#74c476\", \"#238b45\")\n    val GREENS_5 = arrayOf(\"#edf8e9\", \"#bae4b3\", \"#74c476\", \"#31a354\", \"#006d2c\")\n    val GREENS_6 = arrayOf(\"#edf8e9\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#31a354\", \"#006d2c\")\n    val GREENS_7 = arrayOf(\"#edf8e9\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#005a32\")\n    val GREENS_8 = arrayOf(\"#f7fcf5\", \"#e5f5e0\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#005a32\")\n    val GREENS_9 = arrayOf(\"#f7fcf5\", \"#e5f5e0\", \"#c7e9c0\", \"#a1d99b\", \"#74c476\", \"#41ab5d\", \"#238b45\", \"#006d2c\", \"#00441b\")\n    // Greys\n    val GREYS_3 = arrayOf(\"#f0f0f0\", \"#bdbdbd\", \"#636363\")\n    val GREYS_4 = arrayOf(\"#f7f7f7\", \"#cccccc\", \"#969696\", \"#525252\")\n    val GREYS_5 = arrayOf(\"#f7f7f7\", \"#cccccc\", \"#969696\", \"#636363\", \"#252525\")\n    val GREYS_6 = arrayOf(\"#f7f7f7\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#636363\", \"#252525\")\n    val GREYS_7 = arrayOf(\"#f7f7f7\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\")\n    val GREYS_8 = arrayOf(\"#ffffff\", \"#f0f0f0\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\")\n    val GREYS_9 = arrayOf(\"#ffffff\", \"#f0f0f0\", \"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\", \"#252525\", \"#000000\")\n    // Oranges\n    val ORANGES_3 = arrayOf(\"#fee6ce\", \"#fdae6b\", \"#e6550d\")\n    val ORANGES_4 = arrayOf(\"#feedde\", \"#fdbe85\", \"#fd8d3c\", \"#d94701\")\n    val ORANGES_5 = arrayOf(\"#feedde\", \"#fdbe85\", \"#fd8d3c\", \"#e6550d\", \"#a63603\")\n    val ORANGES_6 = arrayOf(\"#feedde\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#e6550d\", \"#a63603\")\n    val ORANGES_7 = arrayOf(\"#feedde\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#8c2d04\")\n    val ORANGES_8 = arrayOf(\"#fff5eb\", \"#fee6ce\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#8c2d04\")\n    val ORANGES_9 = arrayOf(\"#fff5eb\", \"#fee6ce\", \"#fdd0a2\", \"#fdae6b\", \"#fd8d3c\", \"#f16913\", \"#d94801\", \"#a63603\", \"#7f2704\")\n    // Purples\n    val PURPLES_3 = arrayOf(\"#efedf5\", \"#bcbddc\", \"#756bb1\")\n    val PURPLES_4 = arrayOf(\"#f2f0f7\", \"#cbc9e2\", \"#9e9ac8\", \"#6a51a3\")\n    val PURPLES_5 = arrayOf(\"#f2f0f7\", \"#cbc9e2\", \"#9e9ac8\", \"#756bb1\", \"#54278f\")\n    val PURPLES_6 = arrayOf(\"#f2f0f7\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#756bb1\", \"#54278f\")\n    val PURPLES_7 = arrayOf(\"#f2f0f7\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#4a1486\")\n    val PURPLES_8 = arrayOf(\"#fcfbfd\", \"#efedf5\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#4a1486\")\n    val PURPLES_9 = arrayOf(\"#fcfbfd\", \"#efedf5\", \"#dadaeb\", \"#bcbddc\", \"#9e9ac8\", \"#807dba\", \"#6a51a3\", \"#54278f\", \"#3f007d\")\n    // Reds\n    val REDS_3 = arrayOf(\"#fee0d2\", \"#fc9272\", \"#de2d26\")\n    val REDS_4 = arrayOf(\"#fee5d9\", \"#fcae91\", \"#fb6a4a\", \"#cb181d\")\n    val REDS_5 = arrayOf(\"#fee5d9\", \"#fcae91\", \"#fb6a4a\", \"#de2d26\", \"#a50f15\")\n    val REDS_6 = arrayOf(\"#fee5d9\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#de2d26\", \"#a50f15\")\n    val REDS_7 = arrayOf(\"#fee5d9\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#99000d\")\n    val REDS_8 = arrayOf(\"#fff5f0\", \"#fee0d2\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#99000d\")\n    val REDS_9 = arrayOf(\"#fff5f0\", \"#fee0d2\", \"#fcbba1\", \"#fc9272\", \"#fb6a4a\", \"#ef3b2c\", \"#cb181d\", \"#a50f15\", \"#67000d\")\n\n    // single-hue\n    val BLUES = arrayOf(\n        BLUES_3,\n        BLUES_4,\n        BLUES_5,\n        BLUES_6,\n        BLUES_7,\n        BLUES_8,\n        BLUES_9\n    )\n    val GREENS = arrayOf(\n        GREENS_3,\n        GREENS_4,\n        GREENS_5,\n        GREENS_6,\n        GREENS_7,\n        GREENS_8,\n        GREENS_9\n    )\n    val GREYS = arrayOf(\n        GREYS_3,\n        GREYS_4,\n        GREYS_5,\n        GREYS_6,\n        GREYS_7,\n        GREYS_8,\n        GREYS_9\n    )\n    val ORANGES = arrayOf(\n        ORANGES_3,\n        ORANGES_4,\n        ORANGES_5,\n        ORANGES_6,\n        ORANGES_7,\n        ORANGES_8,\n        ORANGES_9\n    )\n    val PURPLES = arrayOf(\n        PURPLES_3,\n        PURPLES_4,\n        PURPLES_5,\n        PURPLES_6,\n        PURPLES_7,\n        PURPLES_8,\n        PURPLES_9\n    )\n    val REDS = arrayOf(\n        REDS_3,\n        REDS_4,\n        REDS_5,\n        REDS_6,\n        REDS_7,\n        REDS_8,\n        REDS_9\n    )\n\n\n    // --------------------\n    // diverging\n    // --------------------\n    // brown - blueGreen\n    val BR_BG_3 = arrayOf(\"#d8b365\", \"#f5f5f5\", \"#5ab4ac\")\n    val BR_BG_4 = arrayOf(\"#a6611a\", \"#dfc27d\", \"#80cdc1\", \"#018571\")\n    val BR_BG_5 = arrayOf(\"#a6611a\", \"#dfc27d\", \"#f5f5f5\", \"#80cdc1\", \"#018571\")\n    val BR_BG_6 = arrayOf(\"#8c510a\", \"#d8b365\", \"#f6e8c3\", \"#c7eae5\", \"#5ab4ac\", \"#01665e\")\n    val BR_BG_7 = arrayOf(\"#8c510a\", \"#d8b365\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#5ab4ac\", \"#01665e\")\n    val BR_BG_8 = arrayOf(\"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\")\n    val BR_BG_9 = arrayOf(\"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\")\n    val BR_BG_10 = arrayOf(\"#543005\", \"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\", \"#003c30\")\n    val BR_BG_11 = arrayOf(\"#543005\", \"#8c510a\", \"#bf812d\", \"#dfc27d\", \"#f6e8c3\", \"#f5f5f5\", \"#c7eae5\", \"#80cdc1\", \"#35978f\", \"#01665e\", \"#003c30\")\n    // pink - yellowGreen\n    val PI_YG_3 = arrayOf(\"#e9a3c9\", \"#f7f7f7\", \"#a1d76a\")\n    val PI_YG_4 = arrayOf(\"#d01c8b\", \"#f1b6da\", \"#b8e186\", \"#4dac26\")\n    val PI_YG_5 = arrayOf(\"#d01c8b\", \"#f1b6da\", \"#f7f7f7\", \"#b8e186\", \"#4dac26\")\n    val PI_YG_6 = arrayOf(\"#c51b7d\", \"#e9a3c9\", \"#fde0ef\", \"#e6f5d0\", \"#a1d76a\", \"#4d9221\")\n    val PI_YG_7 = arrayOf(\"#c51b7d\", \"#e9a3c9\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#a1d76a\", \"#4d9221\")\n    val PI_YG_8 = arrayOf(\"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\")\n    val PI_YG_9 = arrayOf(\"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\")\n    val PI_YG_10 = arrayOf(\"#8e0152\", \"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\", \"#276419\")\n    val PI_YG_11 = arrayOf(\"#8e0152\", \"#c51b7d\", \"#de77ae\", \"#f1b6da\", \"#fde0ef\", \"#f7f7f7\", \"#e6f5d0\", \"#b8e186\", \"#7fbc41\", \"#4d9221\", \"#276419\")\n    // purpleRed - green\n    val PR_GN_3 = arrayOf(\"#af8dc3\", \"#f7f7f7\", \"#7fbf7b\")\n    val PR_GN_4 = arrayOf(\"#7b3294\", \"#c2a5cf\", \"#a6dba0\", \"#008837\")\n    val PR_GN_5 = arrayOf(\"#7b3294\", \"#c2a5cf\", \"#f7f7f7\", \"#a6dba0\", \"#008837\")\n    val PR_GN_6 = arrayOf(\"#762a83\", \"#af8dc3\", \"#e7d4e8\", \"#d9f0d3\", \"#7fbf7b\", \"#1b7837\")\n    val PR_GN_7 = arrayOf(\"#762a83\", \"#af8dc3\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#7fbf7b\", \"#1b7837\")\n    val PR_GN_8 = arrayOf(\"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\")\n    val PR_GN_9 = arrayOf(\"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\")\n    val PR_GN_10 = arrayOf(\"#40004b\", \"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\", \"#00441b\")\n    val PR_GN_11 = arrayOf(\"#40004b\", \"#762a83\", \"#9970ab\", \"#c2a5cf\", \"#e7d4e8\", \"#f7f7f7\", \"#d9f0d3\", \"#a6dba0\", \"#5aae61\", \"#1b7837\", \"#00441b\")\n    // purple - orange\n    val PU_OR_3 = arrayOf(\"#f1a340\", \"#f7f7f7\", \"#998ec3\")\n    val PU_OR_4 = arrayOf(\"#e66101\", \"#fdb863\", \"#b2abd2\", \"#5e3c99\")\n    val PU_OR_5 = arrayOf(\"#e66101\", \"#fdb863\", \"#f7f7f7\", \"#b2abd2\", \"#5e3c99\")\n    val PU_OR_6 = arrayOf(\"#b35806\", \"#f1a340\", \"#fee0b6\", \"#d8daeb\", \"#998ec3\", \"#542788\")\n    val PU_OR_7 = arrayOf(\"#b35806\", \"#f1a340\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#998ec3\", \"#542788\")\n    val PU_OR_8 = arrayOf(\"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\")\n    val PU_OR_9 = arrayOf(\"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\")\n    val PU_OR_10 = arrayOf(\"#7f3b08\", \"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\", \"#2d004b\")\n    val PU_OR_11 = arrayOf(\"#7f3b08\", \"#b35806\", \"#e08214\", \"#fdb863\", \"#fee0b6\", \"#f7f7f7\", \"#d8daeb\", \"#b2abd2\", \"#8073ac\", \"#542788\", \"#2d004b\")\n    // red - blue\n    val RD_BU_3 = arrayOf(\"#ef8a62\", \"#f7f7f7\", \"#67a9cf\")\n    val RD_BU_4 = arrayOf(\"#ca0020\", \"#f4a582\", \"#92c5de\", \"#0571b0\")\n    val RD_BU_5 = arrayOf(\"#ca0020\", \"#f4a582\", \"#f7f7f7\", \"#92c5de\", \"#0571b0\")\n    val RD_BU_6 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#d1e5f0\", \"#67a9cf\", \"#2166ac\")\n    val RD_BU_7 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#67a9cf\", \"#2166ac\")\n    val RD_BU_8 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\")\n    val RD_BU_9 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\")\n    val RD_BU_10 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\", \"#053061\")\n    val RD_BU_11 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#f7f7f7\", \"#d1e5f0\", \"#92c5de\", \"#4393c3\", \"#2166ac\", \"#053061\")\n    // red - grey\n    val RD_GY_3 = arrayOf(\"#ef8a62\", \"#ffffff\", \"#999999\")\n    val RD_GY_4 = arrayOf(\"#ca0020\", \"#f4a582\", \"#bababa\", \"#404040\")\n    val RD_GY_5 = arrayOf(\"#ca0020\", \"#f4a582\", \"#ffffff\", \"#bababa\", \"#404040\")\n    val RD_GY_6 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#e0e0e0\", \"#999999\", \"#4d4d4d\")\n    val RD_GY_7 = arrayOf(\"#b2182b\", \"#ef8a62\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#999999\", \"#4d4d4d\")\n    val RD_GY_8 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\")\n    val RD_GY_9 = arrayOf(\"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\")\n    val RD_GY_10 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\", \"#1a1a1a\")\n    val RD_GY_11 = arrayOf(\"#67001f\", \"#b2182b\", \"#d6604d\", \"#f4a582\", \"#fddbc7\", \"#ffffff\", \"#e0e0e0\", \"#bababa\", \"#878787\", \"#4d4d4d\", \"#1a1a1a\")\n    // red - yellow - blue\n    val RD_YL_BU_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#91bfdb\")\n    val RD_YL_BU_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#abd9e9\", \"#2c7bb6\")\n    val RD_YL_BU_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#abd9e9\", \"#2c7bb6\")\n    val RD_YL_BU_6 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee090\", \"#e0f3f8\", \"#91bfdb\", \"#4575b4\")\n    val RD_YL_BU_7 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#91bfdb\", \"#4575b4\")\n    val RD_YL_BU_8 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\")\n    val RD_YL_BU_9 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\")\n    val RD_YL_BU_10 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\", \"#313695\")\n    val RD_YL_BU_11 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee090\", \"#ffffbf\", \"#e0f3f8\", \"#abd9e9\", \"#74add1\", \"#4575b4\", \"#313695\")\n    // red - yellow - green\n    val RD_YL_GN_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#91cf60\")\n    val RD_YL_GN_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#a6d96a\", \"#1a9641\")\n    val RD_YL_GN_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#a6d96a\", \"#1a9641\")\n    val RD_YL_GN_6 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee08b\", \"#d9ef8b\", \"#91cf60\", \"#1a9850\")\n    val RD_YL_GN_7 = arrayOf(\"#d73027\", \"#fc8d59\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#91cf60\", \"#1a9850\")\n    val RD_YL_GN_8 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\")\n    val RD_YL_GN_9 = arrayOf(\"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\")\n    val RD_YL_GN_10 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\", \"#006837\")\n    val RD_YL_GN_11 = arrayOf(\"#a50026\", \"#d73027\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#d9ef8b\", \"#a6d96a\", \"#66bd63\", \"#1a9850\", \"#006837\")\n    // Spectral\n    val SPECTRAL_3 = arrayOf(\"#fc8d59\", \"#ffffbf\", \"#99d594\")\n    val SPECTRAL_4 = arrayOf(\"#d7191c\", \"#fdae61\", \"#abdda4\", \"#2b83ba\")\n    val SPECTRAL_5 = arrayOf(\"#d7191c\", \"#fdae61\", \"#ffffbf\", \"#abdda4\", \"#2b83ba\")\n    val SPECTRAL_6 = arrayOf(\"#d53e4f\", \"#fc8d59\", \"#fee08b\", \"#e6f598\", \"#99d594\", \"#3288bd\")\n    val SPECTRAL_7 = arrayOf(\"#d53e4f\", \"#fc8d59\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#99d594\", \"#3288bd\")\n    val SPECTRAL_8 = arrayOf(\"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\")\n    val SPECTRAL_9 = arrayOf(\"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\")\n    val SPECTRAL_10 = arrayOf(\"#9e0142\", \"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\", \"#5e4fa2\")\n    val SPECTRAL_11 = arrayOf(\"#9e0142\", \"#d53e4f\", \"#f46d43\", \"#fdae61\", \"#fee08b\", \"#ffffbf\", \"#e6f598\", \"#abdda4\", \"#66c2a5\", \"#3288bd\", \"#5e4fa2\")\n\n    val BR_BG = arrayOf(\n        BR_BG_3,\n        BR_BG_4,\n        BR_BG_5,\n        BR_BG_6,\n        BR_BG_7,\n        BR_BG_8,\n        BR_BG_9,\n        BR_BG_10,\n        BR_BG_11\n    )\n    val PI_YG = arrayOf(\n        PI_YG_3,\n        PI_YG_4,\n        PI_YG_5,\n        PI_YG_6,\n        PI_YG_7,\n        PI_YG_8,\n        PI_YG_9,\n        PI_YG_10,\n        PI_YG_11\n    )\n    val PR_GN = arrayOf(\n        PR_GN_3,\n        PR_GN_4,\n        PR_GN_5,\n        PR_GN_6,\n        PR_GN_7,\n        PR_GN_8,\n        PR_GN_9,\n        PR_GN_10,\n        PR_GN_11\n    )\n    val PU_OR = arrayOf(\n        PU_OR_3,\n        PU_OR_4,\n        PU_OR_5,\n        PU_OR_6,\n        PU_OR_7,\n        PU_OR_8,\n        PU_OR_9,\n        PU_OR_10,\n        PU_OR_11\n    )\n    val RD_BU = arrayOf(\n        RD_BU_3,\n        RD_BU_4,\n        RD_BU_5,\n        RD_BU_6,\n        RD_BU_7,\n        RD_BU_8,\n        RD_BU_9,\n        RD_BU_10,\n        RD_BU_11\n    )\n    val RD_GY = arrayOf(\n        RD_GY_3,\n        RD_GY_4,\n        RD_GY_5,\n        RD_GY_6,\n        RD_GY_7,\n        RD_GY_8,\n        RD_GY_9,\n        RD_GY_10,\n        RD_GY_11\n    )\n    val RD_YL_BU = arrayOf(\n        RD_YL_BU_3,\n        RD_YL_BU_4,\n        RD_YL_BU_5,\n        RD_YL_BU_6,\n        RD_YL_BU_7,\n        RD_YL_BU_8,\n        RD_YL_BU_9,\n        RD_YL_BU_10,\n        RD_YL_BU_11\n    )\n    val RD_YL_GN = arrayOf(\n        RD_YL_GN_3,\n        RD_YL_GN_4,\n        RD_YL_GN_5,\n        RD_YL_GN_6,\n        RD_YL_GN_7,\n        RD_YL_GN_8,\n        RD_YL_GN_9,\n        RD_YL_GN_10,\n        RD_YL_GN_11\n    )\n    val SPECTRAL = arrayOf(\n        SPECTRAL_3,\n        SPECTRAL_4,\n        SPECTRAL_5,\n        SPECTRAL_6,\n        SPECTRAL_7,\n        SPECTRAL_8,\n        SPECTRAL_9,\n        SPECTRAL_10,\n        SPECTRAL_11\n    )\n\n\n    // ------------------------------\n    // qualitative\n    // ------------------------------\n    // Accent\n    val ACCENT_3 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\")\n    val ACCENT_4 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\")\n    val ACCENT_5 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\")\n    val ACCENT_6 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\")\n    val ACCENT_7 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\", \"#bf5b17\")\n    val ACCENT_8 = arrayOf(\"#7fc97f\", \"#beaed4\", \"#fdc086\", \"#ffff99\", \"#386cb0\", \"#f0027f\", \"#bf5b17\", \"#666666\")\n    // Dark2\n    val DARK_2_3 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\")\n    val DARK_2_4 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\")\n    val DARK_2_5 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\")\n    val DARK_2_6 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\")\n    val DARK_2_7 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\", \"#a6761d\")\n    val DARK_2_8 = arrayOf(\"#1b9e77\", \"#d95f02\", \"#7570b3\", \"#e7298a\", \"#66a61e\", \"#e6ab02\", \"#a6761d\", \"#666666\")\n    // Paired\n    val PAIRED_3 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\")\n    val PAIRED_4 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\")\n    val PAIRED_5 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\")\n    val PAIRED_6 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\")\n    val PAIRED_7 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\")\n    val PAIRED_8 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\")\n    val PAIRED_9 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\")\n    val PAIRED_10 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\")\n    val PAIRED_11 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\", \"#ffff99\")\n    val PAIRED_12 = arrayOf(\"#a6cee3\", \"#1f78b4\", \"#b2df8a\", \"#33a02c\", \"#fb9a99\", \"#e31a1c\", \"#fdbf6f\", \"#ff7f00\", \"#cab2d6\", \"#6a3d9a\", \"#ffff99\", \"#b15928\")\n    // Pastel1\n    val PASTEL_1_3 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\")\n    val PASTEL_1_4 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\")\n    val PASTEL_1_5 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\")\n    val PASTEL_1_6 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\")\n    val PASTEL_1_7 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\")\n    val PASTEL_1_8 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\", \"#fddaec\")\n    val PASTEL_1_9 = arrayOf(\"#fbb4ae\", \"#b3cde3\", \"#ccebc5\", \"#decbe4\", \"#fed9a6\", \"#ffffcc\", \"#e5d8bd\", \"#fddaec\", \"#f2f2f2\")\n    // Pastel2\n    val PASTEL_2_3 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\")\n    val PASTEL_2_4 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\")\n    val PASTEL_2_5 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\")\n    val PASTEL_2_6 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\")\n    val PASTEL_2_7 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\", \"#f1e2cc\")\n    val PASTEL_2_8 = arrayOf(\"#b3e2cd\", \"#fdcdac\", \"#cbd5e8\", \"#f4cae4\", \"#e6f5c9\", \"#fff2ae\", \"#f1e2cc\", \"#cccccc\")\n    // Set1\n    val SET_1_3 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\")\n    val SET_1_4 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\")\n    val SET_1_5 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\")\n    val SET_1_6 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\")\n    val SET_1_7 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\")\n    val SET_1_8 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\", \"#f781bf\")\n    val SET_1_9 = arrayOf(\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#984ea3\", \"#ff7f00\", \"#ffff33\", \"#a65628\", \"#f781bf\", \"#999999\")\n    // Set2\n    val SET_2_3 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\")\n    val SET_2_4 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\")\n    val SET_2_5 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\")\n    val SET_2_6 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\")\n    val SET_2_7 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\", \"#e5c494\")\n    val SET_2_8 = arrayOf(\"#66c2a5\", \"#fc8d62\", \"#8da0cb\", \"#e78ac3\", \"#a6d854\", \"#ffd92f\", \"#e5c494\", \"#b3b3b3\")\n    // Set3\n    val SET_3_3 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\")\n    val SET_3_4 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\")\n    val SET_3_5 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\")\n    val SET_3_6 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\")\n    val SET_3_7 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\")\n    val SET_3_8 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\")\n    val SET_3_9 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\")\n    val SET_3_10 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\")\n    val SET_3_11 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\", \"#ccebc5\")\n    val SET_3_12 = arrayOf(\"#8dd3c7\", \"#ffffb3\", \"#bebada\", \"#fb8072\", \"#80b1d3\", \"#fdb462\", \"#b3de69\", \"#fccde5\", \"#d9d9d9\", \"#bc80bd\", \"#ccebc5\", \"#ffed6f\")\n\n    val ACCENT = arrayOf(\n        ACCENT_3,\n        ACCENT_4,\n        ACCENT_5,\n        ACCENT_6,\n        ACCENT_7,\n        ACCENT_8\n    )\n    val DARK_2 = arrayOf(\n        DARK_2_3,\n        DARK_2_4,\n        DARK_2_5,\n        DARK_2_6,\n        DARK_2_7,\n        DARK_2_8\n    )\n    val PAIRED = arrayOf(\n        PAIRED_3,\n        PAIRED_4,\n        PAIRED_5,\n        PAIRED_6,\n        PAIRED_7,\n        PAIRED_8,\n        PAIRED_9,\n        PAIRED_10,\n        PAIRED_11,\n        PAIRED_12\n    )\n    val PASTEL_1 = arrayOf(\n        PASTEL_1_3,\n        PASTEL_1_4,\n        PASTEL_1_5,\n        PASTEL_1_6,\n        PASTEL_1_7,\n        PASTEL_1_8,\n        PASTEL_1_9\n    )\n    val PASTEL_2 = arrayOf(\n        PASTEL_2_3,\n        PASTEL_2_4,\n        PASTEL_2_5,\n        PASTEL_2_6,\n        PASTEL_2_7,\n        PASTEL_2_8\n    )\n    val SET_1 = arrayOf(\n        SET_1_3,\n        SET_1_4,\n        SET_1_5,\n        SET_1_6,\n        SET_1_7,\n        SET_1_8,\n        SET_1_9\n    )\n    val SET_2 = arrayOf(\n        SET_2_3,\n        SET_2_4,\n        SET_2_5,\n        SET_2_6,\n        SET_2_7,\n        SET_2_8\n    )\n    val SET_3 = arrayOf(\n        SET_3_3,\n        SET_3_4,\n        SET_3_5,\n        SET_3_6,\n        SET_3_7,\n        SET_3_8,\n        SET_3_9,\n        SET_3_10,\n        SET_3_11,\n        SET_3_12\n    )\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.values.Color\n\nobject ColorUtil {\n    fun genColors(count: Int, baseColors: List<Color>): List<Color> {\n        val rValues = ArrayList<Int>()\n        val gValues = ArrayList<Int>()\n        val bValues = ArrayList<Int>()\n        for (baseColor in baseColors) {\n            rValues.add(baseColor.red)\n            gValues.add(baseColor.green)\n            bValues.add(baseColor.blue)\n        }\n        val rChannelGen = RGBChannelGen(rValues)\n        val gChannelGen = RGBChannelGen(gValues)\n        val bChannelGen = RGBChannelGen(bValues)\n\n        val rValuesGen = rChannelGen.generate(count).iterator()\n        val gValuesGen = gChannelGen.generate(count).iterator()\n        val bValuesGen = bChannelGen.generate(count).iterator()\n\n        val colorsGen = ArrayList<Color>(count)\n        while (rValuesGen.hasNext() && gValuesGen.hasNext() && bValuesGen.hasNext()) {\n            val colorGen = Color(rValuesGen.next(), gValuesGen.next(), bValuesGen.next())\n            colorsGen.add(colorGen)\n        }\n\n        return colorsGen\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.concat\nimport jetbrains.datalore.base.values.Color\n\nobject PaletteUtil {\n    val NULL_COLOR = Color.LIGHT_GRAY\n\n    private val EXTENSIBLE_COLOR_SCHEMES: Set<ColorScheme> = setOf(\n        ColorPalette.Qualitative.Accent,\n        ColorPalette.Qualitative.Dark2,\n        ColorPalette.Qualitative.Pastel1,\n        ColorPalette.Qualitative.Pastel2,\n        ColorPalette.Qualitative.Set1,\n        ColorPalette.Qualitative.Set2,\n        ColorPalette.Qualitative.Set3\n    )\n\n    private val PAL_TYPE_BY_PAL_NAME: Map<String, ColorPalette.Type>\n\n    init {\n        val map = HashMap<String, ColorPalette.Type>()\n        ColorPalette.Sequential.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.SEQUENTIAL\n        }\n        ColorPalette.Diverging.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.DIVERGING\n        }\n        ColorPalette.Qualitative.values().map { it.name }.forEach {\n            map[it] = ColorPalette.Type.QUALITATIVE\n        }\n\n        PAL_TYPE_BY_PAL_NAME = map\n    }\n\n    private fun isExtensibleScheme(colorScheme: ColorScheme): Boolean {\n        return EXTENSIBLE_COLOR_SCHEMES.contains(colorScheme)\n    }\n\n    fun schemeColors(colorScheme: ColorScheme, colorCount: Int): List<Color> {\n        val colorsHex = colorScheme.getColors(colorCount)\n        val colors = fromColorsHex(colorsHex)\n        if (colorsHex.size < colorCount && isExtensibleScheme(\n                colorScheme\n            )\n        ) {\n            val addColors =\n                ColorUtil.genColors(colorCount - colorsHex.size, colors)\n            return Iterables.toList(concat(colors, addColors))\n        }\n        return colors\n    }\n\n    private fun fromColorsHex(hexColors: Array<String>): List<Color> {\n        val colors = ArrayList<Color>()\n        for (hexColor in hexColors) {\n            try {\n                colors.add(Color.parseHex(hexColor))\n            } catch (e: Exception) {\n                // ignore this value\n            }\n\n        }\n        return colors\n    }\n\n    fun paletteTypeByPaletteName(paletteName: String): ColorPalette.Type? =\n        PAL_TYPE_BY_PAL_NAME[paletteName]\n\n    fun colorSchemeByIndex(paletteType: ColorPalette.Type, index: Int): ColorScheme {\n        @Suppress(\"UNCHECKED_CAST\")\n        val values: Array<ColorScheme> = when (paletteType) {\n            ColorPalette.Type.SEQUENTIAL -> ColorPalette.Sequential.values() as Array<ColorScheme>\n            ColorPalette.Type.DIVERGING -> ColorPalette.Diverging.values() as Array<ColorScheme>\n            ColorPalette.Type.QUALITATIVE -> ColorPalette.Qualitative.values() as Array<ColorScheme>\n        }\n\n        return values[index % values.size]\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"ArraysKt\")\n\npackage kotlin.collections\n\n//\n// NOTE: THIS FILE IS AUTO-GENERATED by the GenerateStandardLib.kt\n// See: https://github.com/JetBrains/kotlin/tree/master/libraries/stdlib\n//\n\nimport kotlin.random.*\nimport kotlin.ranges.contains\nimport kotlin.ranges.reversed\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component1(): T {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component1(): Byte {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component1(): Short {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component1(): Int {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component1(): Long {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component1(): Float {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component1(): Double {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component1(): Boolean {\n    return get(0)\n}\n\n/**\n * Returns 1st *element* from the array.\n * \n * If the size of this array is less than 1, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component1(): Char {\n    return get(0)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component2(): T {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component2(): Byte {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component2(): Short {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component2(): Int {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component2(): Long {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component2(): Float {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component2(): Double {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component2(): Boolean {\n    return get(1)\n}\n\n/**\n * Returns 2nd *element* from the array.\n * \n * If the size of this array is less than 2, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component2(): Char {\n    return get(1)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component3(): T {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component3(): Byte {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component3(): Short {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component3(): Int {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component3(): Long {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component3(): Float {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component3(): Double {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component3(): Boolean {\n    return get(2)\n}\n\n/**\n * Returns 3rd *element* from the array.\n * \n * If the size of this array is less than 3, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component3(): Char {\n    return get(2)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component4(): T {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component4(): Byte {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component4(): Short {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component4(): Int {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component4(): Long {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component4(): Float {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component4(): Double {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component4(): Boolean {\n    return get(3)\n}\n\n/**\n * Returns 4th *element* from the array.\n * \n * If the size of this array is less than 4, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component4(): Char {\n    return get(3)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <T> Array<out T>.component5(): T {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ByteArray.component5(): Byte {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun ShortArray.component5(): Short {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun IntArray.component5(): Int {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun LongArray.component5(): Long {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun FloatArray.component5(): Float {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun DoubleArray.component5(): Double {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun BooleanArray.component5(): Boolean {\n    return get(4)\n}\n\n/**\n * Returns 5th *element* from the array.\n * \n * If the size of this array is less than 5, throws an [IndexOutOfBoundsException] except in Kotlin/JS\n * where the behavior is unspecified.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun CharArray.component5(): Char {\n    return get(4)\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.contains(element: T): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ByteArray.contains(element: Byte): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun ShortArray.contains(element: Short): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun IntArray.contains(element: Int): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun LongArray.contains(element: Long): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun FloatArray.contains(element: Float): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'any { it == element }' instead to continue using this behavior, or '.asList().contains(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"any { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\n@Suppress(\"DEPRECATION\")\npublic operator fun DoubleArray.contains(element: Double): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun BooleanArray.contains(element: Boolean): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns `true` if [element] is found in the array.\n */\npublic operator fun CharArray.contains(element: Char): Boolean {\n    return indexOf(element) >= 0\n}\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun <T> Array<out T>.elementAt(index: Int): T\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ByteArray.elementAt(index: Int): Byte\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun ShortArray.elementAt(index: Int): Short\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun IntArray.elementAt(index: Int): Int\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun LongArray.elementAt(index: Int): Long\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun FloatArray.elementAt(index: Int): Float\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun DoubleArray.elementAt(index: Int): Double\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun BooleanArray.elementAt(index: Int): Boolean\n\n/**\n * Returns an element at the given [index] or throws an [IndexOutOfBoundsException] if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAt\n */\npublic expect fun CharArray.elementAt(index: Int): Char\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.elementAtOrNull(index: Int): T? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.elementAtOrNull(index: Int): Byte? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.elementAtOrNull(index: Int): Short? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.elementAtOrNull(index: Int): Int? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.elementAtOrNull(index: Int): Long? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.elementAtOrNull(index: Int): Float? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.elementAtOrNull(index: Int): Double? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.elementAtOrNull(index: Int): Boolean? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.elementAtOrNull\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.elementAtOrNull(index: Int): Char? {\n    return this.getOrNull(index)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.find(predicate: (T) -> Boolean): T? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.find(predicate: (Byte) -> Boolean): Byte? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.find(predicate: (Short) -> Boolean): Short? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.find(predicate: (Int) -> Boolean): Int? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.find(predicate: (Long) -> Boolean): Long? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.find(predicate: (Float) -> Boolean): Float? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.find(predicate: (Double) -> Boolean): Double? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.find(predicate: (Boolean) -> Boolean): Boolean? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.find(predicate: (Char) -> Boolean): Char? {\n    return firstOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.findLast(predicate: (T) -> Boolean): T? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.findLast(predicate: (Byte) -> Boolean): Byte? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.findLast(predicate: (Short) -> Boolean): Short? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.findLast(predicate: (Int) -> Boolean): Int? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.findLast(predicate: (Long) -> Boolean): Long? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.findLast(predicate: (Float) -> Boolean): Float? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.findLast(predicate: (Double) -> Boolean): Double? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.findLast(predicate: (Boolean) -> Boolean): Boolean? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.find\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.findLast(predicate: (Char) -> Boolean): Char? {\n    return lastOrNull(predicate)\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun <T> Array<out T>.first(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ByteArray.first(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun ShortArray.first(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun IntArray.first(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun LongArray.first(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun FloatArray.first(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun DoubleArray.first(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun BooleanArray.first(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns first element.\n * @throws [NoSuchElementException] if the array is empty.\n */\npublic fun CharArray.first(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun <T> Array<out T>.first(predicate: (T) -> Boolean): T {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ByteArray.first(predicate: (Byte) -> Boolean): Byte {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun ShortArray.first(predicate: (Short) -> Boolean): Short {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun IntArray.first(predicate: (Int) -> Boolean): Int {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun LongArray.first(predicate: (Long) -> Boolean): Long {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun FloatArray.first(predicate: (Float) -> Boolean): Float {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun DoubleArray.first(predicate: (Double) -> Boolean): Double {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun BooleanArray.first(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first element matching the given [predicate].\n * @throws [NoSuchElementException] if no such element is found.\n */\npublic inline fun CharArray.first(predicate: (Char) -> Boolean): Char {\n    for (element in this) if (predicate(element)) return element\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or throws [NoSuchElementException] if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOf(transform: (T) -> R?): R {\n    return firstNotNullOfOrNull(transform) ?: throw NoSuchElementException(\"No element of the array was transformed to a non-null value.\")\n}\n\n/**\n * Returns the first non-null value produced by [transform] function being applied to elements of this array in iteration order,\n * or `null` if no non-null value was produced.\n * \n * @sample samples.collections.Collections.Transformations.firstNotNullOf\n */\n@SinceKotlin(\"1.5\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Any> Array<out T>.firstNotNullOfOrNull(transform: (T) -> R?): R? {\n    for (element in this) {\n        val result = transform(element)\n        if (result != null) {\n            return result\n        }\n    }\n    return null\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun <T> Array<out T>.firstOrNull(): T? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ByteArray.firstOrNull(): Byte? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun ShortArray.firstOrNull(): Short? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun IntArray.firstOrNull(): Int? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun LongArray.firstOrNull(): Long? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun FloatArray.firstOrNull(): Float? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun DoubleArray.firstOrNull(): Double? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun BooleanArray.firstOrNull(): Boolean? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element, or `null` if the array is empty.\n */\npublic fun CharArray.firstOrNull(): Char? {\n    return if (isEmpty()) null else this[0]\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun <T> Array<out T>.firstOrNull(predicate: (T) -> Boolean): T? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ByteArray.firstOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun ShortArray.firstOrNull(predicate: (Short) -> Boolean): Short? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun IntArray.firstOrNull(predicate: (Int) -> Boolean): Int? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun LongArray.firstOrNull(predicate: (Long) -> Boolean): Long? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun FloatArray.firstOrNull(predicate: (Float) -> Boolean): Float? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun DoubleArray.firstOrNull(predicate: (Double) -> Boolean): Double? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun BooleanArray.firstOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns the first element matching the given [predicate], or `null` if element was not found.\n */\npublic inline fun CharArray.firstOrNull(predicate: (Char) -> Boolean): Char? {\n    for (element in this) if (predicate(element)) return element\n    return null\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.getOrElse(index: Int, defaultValue: (Int) -> T): T {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.getOrElse(index: Int, defaultValue: (Int) -> Byte): Byte {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.getOrElse(index: Int, defaultValue: (Int) -> Short): Short {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.getOrElse(index: Int, defaultValue: (Int) -> Int): Int {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.getOrElse(index: Int, defaultValue: (Int) -> Long): Long {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.getOrElse(index: Int, defaultValue: (Int) -> Float): Float {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.getOrElse(index: Int, defaultValue: (Int) -> Double): Double {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.getOrElse(index: Int, defaultValue: (Int) -> Boolean): Boolean {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or the result of calling the [defaultValue] function if the [index] is out of bounds of this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.getOrElse(index: Int, defaultValue: (Int) -> Char): Char {\n    return if (index >= 0 && index <= lastIndex) get(index) else defaultValue(index)\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun <T> Array<out T>.getOrNull(index: Int): T? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ByteArray.getOrNull(index: Int): Byte? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun ShortArray.getOrNull(index: Int): Short? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun IntArray.getOrNull(index: Int): Int? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun LongArray.getOrNull(index: Int): Long? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun FloatArray.getOrNull(index: Int): Float? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun DoubleArray.getOrNull(index: Int): Double? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun BooleanArray.getOrNull(index: Int): Boolean? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns an element at the given [index] or `null` if the [index] is out of bounds of this array.\n * \n * @sample samples.collections.Collections.Elements.getOrNull\n */\npublic fun CharArray.getOrNull(index: Int): Char? {\n    return if (index >= 0 && index <= lastIndex) get(index) else null\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.indexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.indexOf(element: Byte): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.indexOf(element: Short): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.indexOf(element: Int): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.indexOf(element: Long): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.indexOf(element: Float): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfFirst { it == element }' instead to continue using this behavior, or '.asList().indexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfFirst { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.indexOf(element: Double): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.indexOf(element: Boolean): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns first index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.indexOf(element: Char): Int {\n    for (index in indices) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfFirst(predicate: (T) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfFirst(predicate: (Byte) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfFirst(predicate: (Short) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfFirst(predicate: (Int) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfFirst(predicate: (Long) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfFirst(predicate: (Float) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfFirst(predicate: (Double) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfFirst(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the first element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfFirst(predicate: (Char) -> Boolean): Int {\n    for (index in indices) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun <T> Array<out T>.indexOfLast(predicate: (T) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ByteArray.indexOfLast(predicate: (Byte) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun ShortArray.indexOfLast(predicate: (Short) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun IntArray.indexOfLast(predicate: (Int) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun LongArray.indexOfLast(predicate: (Long) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun FloatArray.indexOfLast(predicate: (Float) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun DoubleArray.indexOfLast(predicate: (Double) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun BooleanArray.indexOfLast(predicate: (Boolean) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns index of the last element matching the given [predicate], or -1 if the array does not contain such element.\n */\npublic inline fun CharArray.indexOfLast(predicate: (Char) -> Boolean): Int {\n    for (index in indices.reversed()) {\n        if (predicate(this[index])) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.last(): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.last(): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.last(): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.last(): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.last(): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.last(): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.last(): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.last(): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element.\n * \n * @throws NoSuchElementException if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.last(): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return this[lastIndex]\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.last(predicate: (T) -> Boolean): T {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.last(predicate: (Byte) -> Boolean): Byte {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.last(predicate: (Short) -> Boolean): Short {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.last(predicate: (Int) -> Boolean): Int {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.last(predicate: (Long) -> Boolean): Long {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.last(predicate: (Float) -> Boolean): Float {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.last(predicate: (Double) -> Boolean): Double {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.last(predicate: (Boolean) -> Boolean): Boolean {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns the last element matching the given [predicate].\n * \n * @throws NoSuchElementException if no such element is found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.last(predicate: (Char) -> Boolean): Char {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun <@kotlin.internal.OnlyInputTypes T> Array<out T>.lastIndexOf(element: T): Int {\n    if (element == null) {\n        for (index in indices.reversed()) {\n            if (this[index] == null) {\n                return index\n            }\n        }\n    } else {\n        for (index in indices.reversed()) {\n            if (element == this[index]) {\n                return index\n            }\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ByteArray.lastIndexOf(element: Byte): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun ShortArray.lastIndexOf(element: Short): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun IntArray.lastIndexOf(element: Int): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun LongArray.lastIndexOf(element: Long): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun FloatArray.lastIndexOf(element: Float): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\n@Deprecated(\"The function has unclear behavior when searching for NaN or zero values and will be removed soon. Use 'indexOfLast { it == element }' instead to continue using this behavior, or '.asList().lastIndexOf(element: T)' to get the same search behavior as in a list.\", ReplaceWith(\"indexOfLast { it == element }\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\")\npublic fun DoubleArray.lastIndexOf(element: Double): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun BooleanArray.lastIndexOf(element: Boolean): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns last index of [element], or -1 if the array does not contain element.\n */\npublic fun CharArray.lastIndexOf(element: Char): Int {\n    for (index in indices.reversed()) {\n        if (element == this[index]) {\n            return index\n        }\n    }\n    return -1\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun <T> Array<out T>.lastOrNull(): T? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ByteArray.lastOrNull(): Byte? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun ShortArray.lastOrNull(): Short? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun IntArray.lastOrNull(): Int? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun LongArray.lastOrNull(): Long? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun FloatArray.lastOrNull(): Float? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun DoubleArray.lastOrNull(): Double? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun BooleanArray.lastOrNull(): Boolean? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element, or `null` if the array is empty.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic fun CharArray.lastOrNull(): Char? {\n    return if (isEmpty()) null else this[size - 1]\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun <T> Array<out T>.lastOrNull(predicate: (T) -> Boolean): T? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ByteArray.lastOrNull(predicate: (Byte) -> Boolean): Byte? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun ShortArray.lastOrNull(predicate: (Short) -> Boolean): Short? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun IntArray.lastOrNull(predicate: (Int) -> Boolean): Int? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun LongArray.lastOrNull(predicate: (Long) -> Boolean): Long? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun FloatArray.lastOrNull(predicate: (Float) -> Boolean): Float? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun DoubleArray.lastOrNull(predicate: (Double) -> Boolean): Double? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun BooleanArray.lastOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns the last element matching the given [predicate], or `null` if no such element was found.\n * \n * @sample samples.collections.Collections.Elements.last\n */\npublic inline fun CharArray.lastOrNull(predicate: (Char) -> Boolean): Char? {\n    for (index in this.indices.reversed()) {\n        val element = this[index]\n        if (predicate(element)) return element\n    }\n    return null\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.random(): T {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.random(): Byte {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.random(): Short {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.random(): Int {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.random(): Long {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.random(): Float {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.random(): Double {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.random(): Boolean {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.random(): Char {\n    return random(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Array<out T>.random(random: Random): T {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ByteArray.random(random: Random): Byte {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun ShortArray.random(random: Random): Short {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun IntArray.random(random: Random): Int {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun LongArray.random(random: Random): Long {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun FloatArray.random(random: Random): Float {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun DoubleArray.random(random: Random): Double {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun BooleanArray.random(random: Random): Boolean {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness.\n * \n * @throws NoSuchElementException if this array is empty.\n */\n@SinceKotlin(\"1.3\")\npublic fun CharArray.random(random: Random): Char {\n    if (isEmpty())\n        throw NoSuchElementException(\"Array is empty.\")\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.randomOrNull(): T? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.randomOrNull(): Byte? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.randomOrNull(): Short? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.randomOrNull(): Int? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.randomOrNull(): Long? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.randomOrNull(): Float? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.randomOrNull(): Double? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.randomOrNull(): Boolean? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.randomOrNull(): Char? {\n    return randomOrNull(Random)\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun <T> Array<out T>.randomOrNull(random: Random): T? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ByteArray.randomOrNull(random: Random): Byte? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun ShortArray.randomOrNull(random: Random): Short? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun IntArray.randomOrNull(random: Random): Int? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun LongArray.randomOrNull(random: Random): Long? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun FloatArray.randomOrNull(random: Random): Float? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun DoubleArray.randomOrNull(random: Random): Double? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun BooleanArray.randomOrNull(random: Random): Boolean? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns a random element from this array using the specified source of randomness, or `null` if this array is empty.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic fun CharArray.randomOrNull(random: Random): Char? {\n    if (isEmpty())\n        return null\n    return get(random.nextInt(size))\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.single(): T {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ByteArray.single(): Byte {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun ShortArray.single(): Short {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun IntArray.single(): Int {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun LongArray.single(): Long {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun FloatArray.single(): Float {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun DoubleArray.single(): Double {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun BooleanArray.single(): Boolean {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element, or throws an exception if the array is empty or has more than one element.\n */\npublic fun CharArray.single(): Char {\n    return when (size) {\n        0 -> throw NoSuchElementException(\"Array is empty.\")\n        1 -> this[0]\n        else -> throw IllegalArgumentException(\"Array has more than one element.\")\n    }\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun <T> Array<out T>.single(predicate: (T) -> Boolean): T {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as T\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ByteArray.single(predicate: (Byte) -> Boolean): Byte {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Byte\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun ShortArray.single(predicate: (Short) -> Boolean): Short {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Short\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun IntArray.single(predicate: (Int) -> Boolean): Int {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Int\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun LongArray.single(predicate: (Long) -> Boolean): Long {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Long\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun FloatArray.single(predicate: (Float) -> Boolean): Float {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Float\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun DoubleArray.single(predicate: (Double) -> Boolean): Double {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Double\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun BooleanArray.single(predicate: (Boolean) -> Boolean): Boolean {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Boolean\n}\n\n/**\n * Returns the single element matching the given [predicate], or throws exception if there is no or more than one matching element.\n */\npublic inline fun CharArray.single(predicate: (Char) -> Boolean): Char {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) throw IllegalArgumentException(\"Array contains more than one matching element.\")\n            single = element\n            found = true\n        }\n    }\n    if (!found) throw NoSuchElementException(\"Array contains no element matching the predicate.\")\n    @Suppress(\"UNCHECKED_CAST\")\n    return single as Char\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun <T> Array<out T>.singleOrNull(): T? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ByteArray.singleOrNull(): Byte? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun ShortArray.singleOrNull(): Short? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun IntArray.singleOrNull(): Int? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun LongArray.singleOrNull(): Long? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun FloatArray.singleOrNull(): Float? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun DoubleArray.singleOrNull(): Double? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun BooleanArray.singleOrNull(): Boolean? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns single element, or `null` if the array is empty or has more than one element.\n */\npublic fun CharArray.singleOrNull(): Char? {\n    return if (size == 1) this[0] else null\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun <T> Array<out T>.singleOrNull(predicate: (T) -> Boolean): T? {\n    var single: T? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ByteArray.singleOrNull(predicate: (Byte) -> Boolean): Byte? {\n    var single: Byte? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun ShortArray.singleOrNull(predicate: (Short) -> Boolean): Short? {\n    var single: Short? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun IntArray.singleOrNull(predicate: (Int) -> Boolean): Int? {\n    var single: Int? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun LongArray.singleOrNull(predicate: (Long) -> Boolean): Long? {\n    var single: Long? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun FloatArray.singleOrNull(predicate: (Float) -> Boolean): Float? {\n    var single: Float? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun DoubleArray.singleOrNull(predicate: (Double) -> Boolean): Double? {\n    var single: Double? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun BooleanArray.singleOrNull(predicate: (Boolean) -> Boolean): Boolean? {\n    var single: Boolean? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns the single element matching the given [predicate], or `null` if element was not found or more than one element was found.\n */\npublic inline fun CharArray.singleOrNull(predicate: (Char) -> Boolean): Char? {\n    var single: Char? = null\n    var found = false\n    for (element in this) {\n        if (predicate(element)) {\n            if (found) return null\n            single = element\n            found = true\n        }\n    }\n    if (!found) return null\n    return single\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.drop(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.drop(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.drop(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.drop(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.drop(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.drop(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.drop(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.drop(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.drop(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return takeLast((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun <T> Array<out T>.dropLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ByteArray.dropLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun ShortArray.dropLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun IntArray.dropLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun LongArray.dropLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun FloatArray.dropLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun DoubleArray.dropLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun BooleanArray.dropLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic fun CharArray.dropLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    return take((size - n).coerceAtLeast(0))\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except last elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return take(index + 1)\n        }\n    }\n    return emptyList()\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun <T> Array<out T>.dropWhile(predicate: (T) -> Boolean): List<T> {\n    var yielding = false\n    val list = ArrayList<T>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ByteArray.dropWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    var yielding = false\n    val list = ArrayList<Byte>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun ShortArray.dropWhile(predicate: (Short) -> Boolean): List<Short> {\n    var yielding = false\n    val list = ArrayList<Short>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun IntArray.dropWhile(predicate: (Int) -> Boolean): List<Int> {\n    var yielding = false\n    val list = ArrayList<Int>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun LongArray.dropWhile(predicate: (Long) -> Boolean): List<Long> {\n    var yielding = false\n    val list = ArrayList<Long>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun FloatArray.dropWhile(predicate: (Float) -> Boolean): List<Float> {\n    var yielding = false\n    val list = ArrayList<Float>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun DoubleArray.dropWhile(predicate: (Double) -> Boolean): List<Double> {\n    var yielding = false\n    val list = ArrayList<Double>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun BooleanArray.dropWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    var yielding = false\n    val list = ArrayList<Boolean>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing all elements except first elements that satisfy the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.drop\n */\npublic inline fun CharArray.dropWhile(predicate: (Char) -> Boolean): List<Char> {\n    var yielding = false\n    val list = ArrayList<Char>()\n    for (item in this)\n        if (yielding)\n            list.add(item)\n        else if (!predicate(item)) {\n            list.add(item)\n            yielding = true\n        }\n    return list\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filter(predicate: (T) -> Boolean): List<T> {\n    return filterTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filter(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filter(predicate: (Short) -> Boolean): List<Short> {\n    return filterTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filter(predicate: (Int) -> Boolean): List<Int> {\n    return filterTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filter(predicate: (Long) -> Boolean): List<Long> {\n    return filterTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filter(predicate: (Float) -> Boolean): List<Float> {\n    return filterTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filter(predicate: (Double) -> Boolean): List<Double> {\n    return filterTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filter(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filter(predicate: (Char) -> Boolean): List<Char> {\n    return filterTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun <T> Array<out T>.filterIndexed(predicate: (index: Int, T) -> Boolean): List<T> {\n    return filterIndexedTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ByteArray.filterIndexed(predicate: (index: Int, Byte) -> Boolean): List<Byte> {\n    return filterIndexedTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun ShortArray.filterIndexed(predicate: (index: Int, Short) -> Boolean): List<Short> {\n    return filterIndexedTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun IntArray.filterIndexed(predicate: (index: Int, Int) -> Boolean): List<Int> {\n    return filterIndexedTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun LongArray.filterIndexed(predicate: (index: Int, Long) -> Boolean): List<Long> {\n    return filterIndexedTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun FloatArray.filterIndexed(predicate: (index: Int, Float) -> Boolean): List<Float> {\n    return filterIndexedTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun DoubleArray.filterIndexed(predicate: (index: Int, Double) -> Boolean): List<Double> {\n    return filterIndexedTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun BooleanArray.filterIndexed(predicate: (index: Int, Boolean) -> Boolean): List<Boolean> {\n    return filterIndexedTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing only elements matching the given [predicate].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexed\n */\npublic inline fun CharArray.filterIndexed(predicate: (index: Int, Char) -> Boolean): List<Char> {\n    return filterIndexedTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterIndexedTo(destination: C, predicate: (index: Int, T) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterIndexedTo(destination: C, predicate: (index: Int, Byte) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterIndexedTo(destination: C, predicate: (index: Int, Short) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterIndexedTo(destination: C, predicate: (index: Int, Int) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterIndexedTo(destination: C, predicate: (index: Int, Long) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterIndexedTo(destination: C, predicate: (index: Int, Float) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterIndexedTo(destination: C, predicate: (index: Int, Double) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterIndexedTo(destination: C, predicate: (index: Int, Boolean) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * @param [predicate] function that takes the index of an element and the element itself\n * and returns the result of predicate evaluation on the element.\n * \n * @sample samples.collections.Collections.Filtering.filterIndexedTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterIndexedTo(destination: C, predicate: (index: Int, Char) -> Boolean): C {\n    forEachIndexed { index, element ->\n        if (predicate(index, element)) destination.add(element)\n    }\n    return destination\n}\n\n/**\n * Returns a list containing all elements that are instances of specified type parameter R.\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstance\n */\npublic inline fun <reified R> Array<*>.filterIsInstance(): List<@kotlin.internal.NoInfer R> {\n    return filterIsInstanceTo(ArrayList<R>())\n}\n\n/**\n * Appends all elements that are instances of specified type parameter R to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterIsInstanceTo\n */\npublic inline fun <reified R, C : MutableCollection<in R>> Array<*>.filterIsInstanceTo(destination: C): C {\n    for (element in this) if (element is R) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun <T> Array<out T>.filterNot(predicate: (T) -> Boolean): List<T> {\n    return filterNotTo(ArrayList<T>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ByteArray.filterNot(predicate: (Byte) -> Boolean): List<Byte> {\n    return filterNotTo(ArrayList<Byte>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun ShortArray.filterNot(predicate: (Short) -> Boolean): List<Short> {\n    return filterNotTo(ArrayList<Short>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun IntArray.filterNot(predicate: (Int) -> Boolean): List<Int> {\n    return filterNotTo(ArrayList<Int>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun LongArray.filterNot(predicate: (Long) -> Boolean): List<Long> {\n    return filterNotTo(ArrayList<Long>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun FloatArray.filterNot(predicate: (Float) -> Boolean): List<Float> {\n    return filterNotTo(ArrayList<Float>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun DoubleArray.filterNot(predicate: (Double) -> Boolean): List<Double> {\n    return filterNotTo(ArrayList<Double>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun BooleanArray.filterNot(predicate: (Boolean) -> Boolean): List<Boolean> {\n    return filterNotTo(ArrayList<Boolean>(), predicate)\n}\n\n/**\n * Returns a list containing all elements not matching the given [predicate].\n * \n * @sample samples.collections.Collections.Filtering.filter\n */\npublic inline fun CharArray.filterNot(predicate: (Char) -> Boolean): List<Char> {\n    return filterNotTo(ArrayList<Char>(), predicate)\n}\n\n/**\n * Returns a list containing all elements that are not `null`.\n * \n * @sample samples.collections.Collections.Filtering.filterNotNull\n */\npublic fun <T : Any> Array<out T?>.filterNotNull(): List<T> {\n    return filterNotNullTo(ArrayList<T>())\n}\n\n/**\n * Appends all elements that are not `null` to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterNotNullTo\n */\npublic fun <C : MutableCollection<in T>, T : Any> Array<out T?>.filterNotNullTo(destination: C): C {\n    for (element in this) if (element != null) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterNotTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterNotTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterNotTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterNotTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterNotTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterNotTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterNotTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterNotTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements not matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterNotTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (!predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <T, C : MutableCollection<in T>> Array<out T>.filterTo(destination: C, predicate: (T) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Byte>> ByteArray.filterTo(destination: C, predicate: (Byte) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Short>> ShortArray.filterTo(destination: C, predicate: (Short) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Int>> IntArray.filterTo(destination: C, predicate: (Int) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Long>> LongArray.filterTo(destination: C, predicate: (Long) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Float>> FloatArray.filterTo(destination: C, predicate: (Float) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Double>> DoubleArray.filterTo(destination: C, predicate: (Double) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Boolean>> BooleanArray.filterTo(destination: C, predicate: (Boolean) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Appends all elements matching the given [predicate] to the given [destination].\n * \n * @sample samples.collections.Collections.Filtering.filterTo\n */\npublic inline fun <C : MutableCollection<in Char>> CharArray.filterTo(destination: C, predicate: (Char) -> Boolean): C {\n    for (element in this) if (predicate(element)) destination.add(element)\n    return destination\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<out T>.slice(indices: IntRange): List<T> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.slice(indices: IntRange): List<Byte> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.slice(indices: IntRange): List<Short> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.slice(indices: IntRange): List<Int> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.slice(indices: IntRange): List<Long> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.slice(indices: IntRange): List<Float> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.slice(indices: IntRange): List<Double> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.slice(indices: IntRange): List<Boolean> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.slice(indices: IntRange): List<Char> {\n    if (indices.isEmpty()) return listOf()\n    return copyOfRange(indices.start, indices.endInclusive + 1).asList()\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun <T> Array<out T>.slice(indices: Iterable<Int>): List<T> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<T>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ByteArray.slice(indices: Iterable<Int>): List<Byte> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Byte>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun ShortArray.slice(indices: Iterable<Int>): List<Short> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Short>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun IntArray.slice(indices: Iterable<Int>): List<Int> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Int>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun LongArray.slice(indices: Iterable<Int>): List<Long> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Long>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun FloatArray.slice(indices: Iterable<Int>): List<Float> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Float>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun DoubleArray.slice(indices: Iterable<Int>): List<Double> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Double>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun BooleanArray.slice(indices: Iterable<Int>): List<Boolean> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Boolean>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns a list containing elements at specified [indices].\n */\npublic fun CharArray.slice(indices: Iterable<Int>): List<Char> {\n    val size = indices.collectionSizeOrDefault(10)\n    if (size == 0) return emptyList()\n    val list = ArrayList<Char>(size)\n    for (index in indices) {\n        list.add(get(index))\n    }\n    return list\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun <T> Array<T>.sliceArray(indices: Collection<Int>): Array<T> {\n    val result = arrayOfNulls(this, indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ByteArray.sliceArray(indices: Collection<Int>): ByteArray {\n    val result = ByteArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun ShortArray.sliceArray(indices: Collection<Int>): ShortArray {\n    val result = ShortArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun IntArray.sliceArray(indices: Collection<Int>): IntArray {\n    val result = IntArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun LongArray.sliceArray(indices: Collection<Int>): LongArray {\n    val result = LongArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun FloatArray.sliceArray(indices: Collection<Int>): FloatArray {\n    val result = FloatArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun DoubleArray.sliceArray(indices: Collection<Int>): DoubleArray {\n    val result = DoubleArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun BooleanArray.sliceArray(indices: Collection<Int>): BooleanArray {\n    val result = BooleanArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements of this array at specified [indices].\n */\npublic fun CharArray.sliceArray(indices: Collection<Int>): CharArray {\n    val result = CharArray(indices.size)\n    var targetIndex = 0\n    for (sourceIndex in indices) {\n        result[targetIndex++] = this[sourceIndex]\n    }\n    return result\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun <T> Array<T>.sliceArray(indices: IntRange): Array<T> {\n    if (indices.isEmpty()) return copyOfRange(0, 0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ByteArray.sliceArray(indices: IntRange): ByteArray {\n    if (indices.isEmpty()) return ByteArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun ShortArray.sliceArray(indices: IntRange): ShortArray {\n    if (indices.isEmpty()) return ShortArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun IntArray.sliceArray(indices: IntRange): IntArray {\n    if (indices.isEmpty()) return IntArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun LongArray.sliceArray(indices: IntRange): LongArray {\n    if (indices.isEmpty()) return LongArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun FloatArray.sliceArray(indices: IntRange): FloatArray {\n    if (indices.isEmpty()) return FloatArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun DoubleArray.sliceArray(indices: IntRange): DoubleArray {\n    if (indices.isEmpty()) return DoubleArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun BooleanArray.sliceArray(indices: IntRange): BooleanArray {\n    if (indices.isEmpty()) return BooleanArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns an array containing elements at indices in the specified [indices] range.\n */\npublic fun CharArray.sliceArray(indices: IntRange): CharArray {\n    if (indices.isEmpty()) return CharArray(0)\n    return copyOfRange(indices.start, indices.endInclusive + 1)\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.take(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<T>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.take(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Byte>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.take(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Short>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.take(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Int>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.take(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Long>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.take(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Float>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.take(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Double>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.take(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Boolean>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing first [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.take(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[0])\n    var count = 0\n    val list = ArrayList<Char>(n)\n    for (item in this) {\n        list.add(item)\n        if (++count == n)\n            break\n    }\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun <T> Array<out T>.takeLast(n: Int): List<T> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<T>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ByteArray.takeLast(n: Int): List<Byte> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Byte>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun ShortArray.takeLast(n: Int): List<Short> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Short>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun IntArray.takeLast(n: Int): List<Int> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Int>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun LongArray.takeLast(n: Int): List<Long> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Long>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun FloatArray.takeLast(n: Int): List<Float> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Float>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun DoubleArray.takeLast(n: Int): List<Double> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Double>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun BooleanArray.takeLast(n: Int): List<Boolean> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Boolean>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last [n] elements.\n * \n * @throws IllegalArgumentException if [n] is negative.\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic fun CharArray.takeLast(n: Int): List<Char> {\n    require(n >= 0) { \"Requested element count $n is less than zero.\" }\n    if (n == 0) return emptyList()\n    val size = size\n    if (n >= size) return toList()\n    if (n == 1) return listOf(this[size - 1])\n    val list = ArrayList<Char>(n)\n    for (index in size - n until size)\n        list.add(this[index])\n    return list\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeLastWhile(predicate: (T) -> Boolean): List<T> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeLastWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeLastWhile(predicate: (Short) -> Boolean): List<Short> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeLastWhile(predicate: (Int) -> Boolean): List<Int> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeLastWhile(predicate: (Long) -> Boolean): List<Long> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeLastWhile(predicate: (Float) -> Boolean): List<Float> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeLastWhile(predicate: (Double) -> Boolean): List<Double> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeLastWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing last elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeLastWhile(predicate: (Char) -> Boolean): List<Char> {\n    for (index in lastIndex downTo 0) {\n        if (!predicate(this[index])) {\n            return drop(index + 1)\n        }\n    }\n    return toList()\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun <T> Array<out T>.takeWhile(predicate: (T) -> Boolean): List<T> {\n    val list = ArrayList<T>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ByteArray.takeWhile(predicate: (Byte) -> Boolean): List<Byte> {\n    val list = ArrayList<Byte>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun ShortArray.takeWhile(predicate: (Short) -> Boolean): List<Short> {\n    val list = ArrayList<Short>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun IntArray.takeWhile(predicate: (Int) -> Boolean): List<Int> {\n    val list = ArrayList<Int>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun LongArray.takeWhile(predicate: (Long) -> Boolean): List<Long> {\n    val list = ArrayList<Long>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun FloatArray.takeWhile(predicate: (Float) -> Boolean): List<Float> {\n    val list = ArrayList<Float>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun DoubleArray.takeWhile(predicate: (Double) -> Boolean): List<Double> {\n    val list = ArrayList<Double>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun BooleanArray.takeWhile(predicate: (Boolean) -> Boolean): List<Boolean> {\n    val list = ArrayList<Boolean>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Returns a list containing first elements satisfying the given [predicate].\n * \n * @sample samples.collections.Collections.Transformations.take\n */\npublic inline fun CharArray.takeWhile(predicate: (Char) -> Boolean): List<Char> {\n    val list = ArrayList<Char>()\n    for (item in this) {\n        if (!predicate(item))\n            break\n        list.add(item)\n    }\n    return list\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun <T> Array<T>.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ByteArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun ShortArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun IntArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun LongArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun FloatArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun DoubleArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun BooleanArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements in the array in-place.\n */\npublic fun CharArray.reverse(): Unit {\n    val midPoint = (size / 2) - 1\n    if (midPoint < 0) return\n    var reverseIndex = lastIndex\n    for (index in 0..midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Reverses elements of the array in the specified range in-place.\n * \n * @param fromIndex the start of the range (inclusive) to reverse.\n * @param toIndex the end of the range (exclusive) to reverse.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.reverse(fromIndex: Int, toIndex: Int): Unit {\n    AbstractList.checkRangeIndexes(fromIndex, toIndex, size)\n    val midPoint = (fromIndex + toIndex) / 2\n    if (fromIndex == midPoint) return\n    var reverseIndex = toIndex - 1\n    for (index in fromIndex until midPoint) {\n        val tmp = this[index]\n        this[index] = this[reverseIndex]\n        this[reverseIndex] = tmp\n        reverseIndex--\n    }\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun <T> Array<out T>.reversed(): List<T> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ByteArray.reversed(): List<Byte> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun ShortArray.reversed(): List<Short> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun IntArray.reversed(): List<Int> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun LongArray.reversed(): List<Long> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun FloatArray.reversed(): List<Float> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun DoubleArray.reversed(): List<Double> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun BooleanArray.reversed(): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns a list with elements in reversed order.\n */\npublic fun CharArray.reversed(): List<Char> {\n    if (isEmpty()) return emptyList()\n    val list = toMutableList()\n    list.reverse()\n    return list\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun <T> Array<T>.reversedArray(): Array<T> {\n    if (isEmpty()) return this\n    val result = arrayOfNulls(this, size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ByteArray.reversedArray(): ByteArray {\n    if (isEmpty()) return this\n    val result = ByteArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun ShortArray.reversedArray(): ShortArray {\n    if (isEmpty()) return this\n    val result = ShortArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun IntArray.reversedArray(): IntArray {\n    if (isEmpty()) return this\n    val result = IntArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun LongArray.reversedArray(): LongArray {\n    if (isEmpty()) return this\n    val result = LongArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun FloatArray.reversedArray(): FloatArray {\n    if (isEmpty()) return this\n    val result = FloatArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun DoubleArray.reversedArray(): DoubleArray {\n    if (isEmpty()) return this\n    val result = DoubleArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun BooleanArray.reversedArray(): BooleanArray {\n    if (isEmpty()) return this\n    val result = BooleanArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Returns an array with elements of this array in reversed order.\n */\npublic fun CharArray.reversedArray(): CharArray {\n    if (isEmpty()) return this\n    val result = CharArray(size)\n    val lastIndex = lastIndex\n    for (i in 0..lastIndex)\n        result[lastIndex - i] = this[i]\n    return result\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(): Unit {\n    shuffle(Random)\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<T>.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Randomly shuffles elements in this array in-place using the specified [random] instance as the source of randomness.\n * \n * See: https://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle#The_modern_algorithm\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.shuffle(random: Random): Unit {\n    for (i in lastIndex downTo 1) {\n        val j = random.nextInt(i + 1)\n        val copy = this[i]\n        this[i] = this[j]\n        this[j] = copy\n    }\n}\n\n/**\n * Sorts elements in the array in-place according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortBy(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareBy(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortByDescending(crossinline selector: (T) -> R?): Unit {\n    if (size > 1) sortWith(compareByDescending(selector))\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(): Unit {\n    sortWith(reverseOrder())\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ByteArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun ShortArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun IntArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun LongArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun FloatArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun DoubleArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Sorts elements in the array in-place descending according to their natural sort order.\n */\npublic fun CharArray.sortDescending(): Unit {\n    if (size > 1) {\n        sort()\n        reverse()\n    }\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sorted(): List<T> {\n    return sortedArray().asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ByteArray.sorted(): List<Byte> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun ShortArray.sorted(): List<Short> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun IntArray.sorted(): List<Int> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun LongArray.sorted(): List<Long> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun FloatArray.sorted(): List<Float> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun DoubleArray.sorted(): List<Double> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to their natural sort order.\n */\npublic fun CharArray.sorted(): List<Char> {\n    return toTypedArray().apply { sort() }.asList()\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArray(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ByteArray.sortedArray(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun ShortArray.sortedArray(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun IntArray.sortedArray(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun LongArray.sortedArray(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun FloatArray.sortedArray(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun DoubleArray.sortedArray(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according to their natural sort order.\n */\npublic fun CharArray.sortedArray(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sort() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<T>.sortedArrayDescending(): Array<T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(reverseOrder()) }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedArrayDescending(): ByteArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedArrayDescending(): ShortArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedArrayDescending(): IntArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedArrayDescending(): LongArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedArrayDescending(): FloatArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedArrayDescending(): DoubleArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedArrayDescending(): CharArray {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortDescending() }\n}\n\n/**\n * Returns an array with all elements of this array sorted according the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedArrayWith(comparator: Comparator<in T>): Array<out T> {\n    if (isEmpty()) return this\n    return this.copyOf().apply { sortWith(comparator) }\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedBy(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedBy(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedBy(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedBy(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedBy(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedBy(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedBy(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedBy(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted according to natural sort order of the value returned by specified [selector] function.\n * \n * @sample samples.collections.Collections.Sorting.sortedBy\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedBy(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareBy(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic inline fun <T, R : Comparable<R>> Array<out T>.sortedByDescending(crossinline selector: (T) -> R?): List<T> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ByteArray.sortedByDescending(crossinline selector: (Byte) -> R?): List<Byte> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> ShortArray.sortedByDescending(crossinline selector: (Short) -> R?): List<Short> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> IntArray.sortedByDescending(crossinline selector: (Int) -> R?): List<Int> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> LongArray.sortedByDescending(crossinline selector: (Long) -> R?): List<Long> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> FloatArray.sortedByDescending(crossinline selector: (Float) -> R?): List<Float> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> DoubleArray.sortedByDescending(crossinline selector: (Double) -> R?): List<Double> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> BooleanArray.sortedByDescending(crossinline selector: (Boolean) -> R?): List<Boolean> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to natural sort order of the value returned by specified [selector] function.\n */\npublic inline fun <R : Comparable<R>> CharArray.sortedByDescending(crossinline selector: (Char) -> R?): List<Char> {\n    return sortedWith(compareByDescending(selector))\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T : Comparable<T>> Array<out T>.sortedDescending(): List<T> {\n    return sortedWith(reverseOrder())\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ByteArray.sortedDescending(): List<Byte> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun ShortArray.sortedDescending(): List<Short> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun IntArray.sortedDescending(): List<Int> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun LongArray.sortedDescending(): List<Long> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun FloatArray.sortedDescending(): List<Float> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun DoubleArray.sortedDescending(): List<Double> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted descending according to their natural sort order.\n */\npublic fun CharArray.sortedDescending(): List<Char> {\n    return copyOf().apply { sort() }.reversed()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic fun <T> Array<out T>.sortedWith(comparator: Comparator<in T>): List<T> {\n    return sortedArrayWith(comparator).asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ByteArray.sortedWith(comparator: Comparator<in Byte>): List<Byte> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun ShortArray.sortedWith(comparator: Comparator<in Short>): List<Short> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun IntArray.sortedWith(comparator: Comparator<in Int>): List<Int> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun LongArray.sortedWith(comparator: Comparator<in Long>): List<Long> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun FloatArray.sortedWith(comparator: Comparator<in Float>): List<Float> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun DoubleArray.sortedWith(comparator: Comparator<in Double>): List<Double> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun BooleanArray.sortedWith(comparator: Comparator<in Boolean>): List<Boolean> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a list of all elements sorted according to the specified [comparator].\n */\npublic fun CharArray.sortedWith(comparator: Comparator<in Char>): List<Char> {\n    return toTypedArray().apply { sortWith(comparator) }.asList()\n}\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun <T> Array<out T>.asList(): List<T>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ByteArray.asList(): List<Byte>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun ShortArray.asList(): List<Short>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun IntArray.asList(): List<Int>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun LongArray.asList(): List<Long>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun FloatArray.asList(): List<Float>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun DoubleArray.asList(): List<Double>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun BooleanArray.asList(): List<Boolean>\n\n/**\n * Returns a [List] that wraps the original array.\n */\npublic expect fun CharArray.asList(): List<Char>\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect infix fun <T> Array<out T>.contentDeepEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *deeply* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The specified arrays are also considered deeply equal if both are `null`.\n * \n * If two corresponding elements are nested arrays, they are also compared deeply.\n * If any of arrays contains itself on any nesting level the behavior is undefined.\n * \n * The elements of other types are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentDeepEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level the behavior is undefined.\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepHashCode(): Int\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.LowPriorityInOverloadResolution\npublic expect fun <T> Array<out T>.contentDeepToString(): String\n\n/**\n * Returns a string representation of the contents of this array as if it is a [List].\n * Nested arrays are treated as lists too.\n * \n * If any of arrays contains itself on any nesting level that reference\n * is rendered as `\"[...]\"` to prevent recursion.\n * \n * @sample samples.collections.Arrays.ContentOperations.contentDeepToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentDeepToString(): String\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun <T> Array<out T>.contentEquals(other: Array<out T>): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ByteArray.contentEquals(other: ByteArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun ShortArray.contentEquals(other: ShortArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun IntArray.contentEquals(other: IntArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun LongArray.contentEquals(other: LongArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun FloatArray.contentEquals(other: FloatArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun DoubleArray.contentEquals(other: DoubleArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun BooleanArray.contentEquals(other: BooleanArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect infix fun CharArray.contentEquals(other: CharArray): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun <T> Array<out T>?.contentEquals(other: Array<out T>?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ByteArray?.contentEquals(other: ByteArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun ShortArray?.contentEquals(other: ShortArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun IntArray?.contentEquals(other: IntArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun LongArray?.contentEquals(other: LongArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun FloatArray?.contentEquals(other: FloatArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun DoubleArray?.contentEquals(other: DoubleArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun BooleanArray?.contentEquals(other: BooleanArray?): Boolean\n\n/**\n * Returns `true` if the two specified arrays are *structurally* equal to one another,\n * i.e. contain the same number of the same elements in the same order.\n * \n * The elements are compared for equality with the [equals][Any.equals] function.\n * For floating point numbers it means that `NaN` is equal to itself and `-0.0` is not equal to `0.0`.\n */\n@SinceKotlin(\"1.4\")\npublic expect infix fun CharArray?.contentEquals(other: CharArray?): Boolean\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentHashCode(): Int\n\n/**\n * Returns a hash code based on the contents of this array as if it is [List].\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentHashCode(): Int\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun <T> Array<out T>.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ByteArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun ShortArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun IntArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun LongArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun FloatArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun DoubleArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun BooleanArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@Deprecated(\"Use Kotlin compiler 1.4 to avoid deprecation warning.\")\n@SinceKotlin(\"1.1\")\n@DeprecatedSinceKotlin(hiddenSince = \"1.4\")\npublic expect fun CharArray.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T> Array<out T>?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun BooleanArray?.contentToString(): String\n\n/**\n * Returns a string representation of the contents of the specified array as if it is [List].\n * \n * @sample samples.collections.Arrays.ContentOperations.contentToString\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray?.contentToString(): String\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<out T>.copyInto(destination: Array<T>, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): Array<T>\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.copyInto(destination: ByteArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ByteArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.copyInto(destination: ShortArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): ShortArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.copyInto(destination: IntArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): IntArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.copyInto(destination: LongArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): LongArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.copyInto(destination: FloatArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): FloatArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.copyInto(destination: DoubleArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): DoubleArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.copyInto(destination: BooleanArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): BooleanArray\n\n/**\n * Copies this array or its subrange into the [destination] array and returns that array.\n * \n * It's allowed to pass the same array in the [destination] and even specify the subrange so that it overlaps with the destination range.\n * \n * @param destination the array to copy to.\n * @param destinationOffset the position in the [destination] array to copy to, 0 by default.\n * @param startIndex the beginning (inclusive) of the subrange to copy, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to copy, size of this array by default.\n * \n * @throws IndexOutOfBoundsException or [IllegalArgumentException] when [startIndex] or [endIndex] is out of range of this array indices or when `startIndex > endIndex`.\n * @throws IndexOutOfBoundsException when the subrange doesn't fit into the [destination] array starting at the specified [destinationOffset],\n * or when that index is out of the [destination] array indices range.\n * \n * @return the [destination] array.\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.copyInto(destination: CharArray, destinationOffset: Int = 0, startIndex: Int = 0, endIndex: Int = size): CharArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(): Array<T>\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ByteArray.copyOf(): ByteArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun ShortArray.copyOf(): ShortArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun IntArray.copyOf(): IntArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun LongArray.copyOf(): LongArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun FloatArray.copyOf(): FloatArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun DoubleArray.copyOf(): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun BooleanArray.copyOf(): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.copyOf\n */\npublic expect fun CharArray.copyOf(): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ByteArray.copyOf(newSize: Int): ByteArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun ShortArray.copyOf(newSize: Int): ShortArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun IntArray.copyOf(newSize: Int): IntArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun LongArray.copyOf(newSize: Int): LongArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun FloatArray.copyOf(newSize: Int): FloatArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with zero values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with zero values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun DoubleArray.copyOf(newSize: Int): DoubleArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `false` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `false` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun BooleanArray.copyOf(newSize: Int): BooleanArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with null char (`\\u0000`) values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with null char (`\\u0000`) values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizedPrimitiveCopyOf\n */\npublic expect fun CharArray.copyOf(newSize: Int): CharArray\n\n/**\n * Returns new array which is a copy of the original array, resized to the given [newSize].\n * The copy is either truncated or padded at the end with `null` values if necessary.\n * \n * - If [newSize] is less than the size of the original array, the copy array is truncated to the [newSize].\n * - If [newSize] is greater than the size of the original array, the extra elements in the copy array are filled with `null` values.\n * \n * @sample samples.collections.Arrays.CopyOfOperations.resizingCopyOf\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOf(newSize: Int): Array<T?>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.copyOfRange(fromIndex: Int, toIndex: Int): Array<T>\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ByteArray.copyOfRange(fromIndex: Int, toIndex: Int): ByteArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun ShortArray.copyOfRange(fromIndex: Int, toIndex: Int): ShortArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun IntArray.copyOfRange(fromIndex: Int, toIndex: Int): IntArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun LongArray.copyOfRange(fromIndex: Int, toIndex: Int): LongArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun FloatArray.copyOfRange(fromIndex: Int, toIndex: Int): FloatArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun DoubleArray.copyOfRange(fromIndex: Int, toIndex: Int): DoubleArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun BooleanArray.copyOfRange(fromIndex: Int, toIndex: Int): BooleanArray\n\n/**\n * Returns a new array which is a copy of the specified range of the original array.\n * \n * @param fromIndex the start of the range (inclusive) to copy.\n * @param toIndex the end of the range (exclusive) to copy.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun CharArray.copyOfRange(fromIndex: Int, toIndex: Int): CharArray\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun <T> Array<T>.fill(element: T, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ByteArray.fill(element: Byte, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun ShortArray.fill(element: Short, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun IntArray.fill(element: Int, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun LongArray.fill(element: Long, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun FloatArray.fill(element: Float, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun DoubleArray.fill(element: Double, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun BooleanArray.fill(element: Boolean, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Fills this array or its subrange with the specified [element] value.\n * \n * @param fromIndex the start of the range (inclusive) to fill, 0 by default.\n * @param toIndex the end of the range (exclusive) to fill, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.3\")\npublic expect fun CharArray.fill(element: Char, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val <T> Array<out T>.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ByteArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val ShortArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val IntArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val LongArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val FloatArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val DoubleArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val BooleanArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns the range of valid indices for the array.\n */\npublic val CharArray.indices: IntRange\n    get() = IntRange(0, lastIndex)\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isEmpty(): Boolean {\n    return size == 0\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if the array is not empty.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.isNotEmpty(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns the last valid index for the array.\n */\npublic val <T> Array<out T>.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ByteArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val ShortArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val IntArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val LongArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val FloatArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val DoubleArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val BooleanArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns the last valid index for the array.\n */\npublic val CharArray.lastIndex: Int\n    get() = size - 1\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(element: T): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ByteArray.plus(element: Byte): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun ShortArray.plus(element: Short): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun IntArray.plus(element: Int): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun LongArray.plus(element: Long): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun FloatArray.plus(element: Float): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun DoubleArray.plus(element: Double): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun BooleanArray.plus(element: Boolean): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\npublic expect operator fun CharArray.plus(element: Char): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Collection<T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ByteArray.plus(elements: Collection<Byte>): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun ShortArray.plus(elements: Collection<Short>): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun IntArray.plus(elements: Collection<Int>): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun LongArray.plus(elements: Collection<Long>): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun FloatArray.plus(elements: Collection<Float>): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun DoubleArray.plus(elements: Collection<Double>): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun BooleanArray.plus(elements: Collection<Boolean>): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] collection.\n */\npublic expect operator fun CharArray.plus(elements: Collection<Char>): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect operator fun <T> Array<T>.plus(elements: Array<out T>): Array<T>\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ByteArray.plus(elements: ByteArray): ByteArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun ShortArray.plus(elements: ShortArray): ShortArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun IntArray.plus(elements: IntArray): IntArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun LongArray.plus(elements: LongArray): LongArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun FloatArray.plus(elements: FloatArray): FloatArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun DoubleArray.plus(elements: DoubleArray): DoubleArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun BooleanArray.plus(elements: BooleanArray): BooleanArray\n\n/**\n * Returns an array containing all elements of the original array and then all elements of the given [elements] array.\n */\npublic expect operator fun CharArray.plus(elements: CharArray): CharArray\n\n/**\n * Returns an array containing all elements of the original array and then the given [element].\n */\n@Suppress(\"NO_ACTUAL_FOR_EXPECT\")\npublic expect fun <T> Array<T>.plusElement(element: T): Array<T>\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun IntArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun LongArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ByteArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun ShortArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun DoubleArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun FloatArray.sort(): Unit\n\n/**\n * Sorts the array in-place.\n * \n * @sample samples.collections.Arrays.Sorting.sortArray\n */\npublic expect fun CharArray.sort(): Unit\n\n/**\n * Sorts the array in-place according to the natural order of its elements.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @sample samples.collections.Arrays.Sorting.sortArrayOfComparable\n */\npublic expect fun <T : Comparable<T>> Array<out T>.sort(): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArrayOfComparable\n */\n@SinceKotlin(\"1.4\")\npublic expect fun <T : Comparable<T>> Array<out T>.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts a range in the array in-place.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n * \n * @sample samples.collections.Arrays.Sorting.sortRangeOfArray\n */\n@SinceKotlin(\"1.4\")\npublic expect fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sortWith(reverseOrder(), fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts elements of the array in the specified range in-place.\n * The elements are sorted descending according to their natural sort order.\n * \n * @param fromIndex the start of the range (inclusive) to sort.\n * @param toIndex the end of the range (exclusive) to sort.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.sortDescending(fromIndex: Int, toIndex: Int): Unit {\n    sort(fromIndex, toIndex)\n    reverse(fromIndex, toIndex)\n}\n\n/**\n * Sorts the array in-place according to the order specified by the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>): Unit\n\n/**\n * Sorts a range in the array in-place with the given [comparator].\n * \n * The sort is _stable_. It means that equal elements preserve their order relative to each other after sorting.\n * \n * @param fromIndex the start of the range (inclusive) to sort, 0 by default.\n * @param toIndex the end of the range (exclusive) to sort, size of this array by default.\n * \n * @throws IndexOutOfBoundsException if [fromIndex] is less than zero or [toIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [fromIndex] is greater than [toIndex].\n */\npublic expect fun <T> Array<out T>.sortWith(comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Unit\n\n/**\n * Returns an array of Boolean containing all of the elements of this generic array.\n */\npublic fun Array<out Boolean>.toBooleanArray(): BooleanArray {\n    return BooleanArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Byte containing all of the elements of this generic array.\n */\npublic fun Array<out Byte>.toByteArray(): ByteArray {\n    return ByteArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Char containing all of the elements of this generic array.\n */\npublic fun Array<out Char>.toCharArray(): CharArray {\n    return CharArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Double containing all of the elements of this generic array.\n */\npublic fun Array<out Double>.toDoubleArray(): DoubleArray {\n    return DoubleArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Float containing all of the elements of this generic array.\n */\npublic fun Array<out Float>.toFloatArray(): FloatArray {\n    return FloatArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Int containing all of the elements of this generic array.\n */\npublic fun Array<out Int>.toIntArray(): IntArray {\n    return IntArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Long containing all of the elements of this generic array.\n */\npublic fun Array<out Long>.toLongArray(): LongArray {\n    return LongArray(size) { index -> this[index] }\n}\n\n/**\n * Returns an array of Short containing all of the elements of this generic array.\n */\npublic fun Array<out Short>.toShortArray(): ShortArray {\n    return ShortArray(size) { index -> this[index] }\n}\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ByteArray.toTypedArray(): Array<Byte>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun ShortArray.toTypedArray(): Array<Short>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun IntArray.toTypedArray(): Array<Int>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun LongArray.toTypedArray(): Array<Long>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun FloatArray.toTypedArray(): Array<Float>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun DoubleArray.toTypedArray(): Array<Double>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun BooleanArray.toTypedArray(): Array<Boolean>\n\n/**\n * Returns a *typed* object array containing all of the elements of this primitive array.\n */\npublic expect fun CharArray.toTypedArray(): Array<Char>\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <T, K, V> Array<out T>.associate(transform: (T) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ByteArray.associate(transform: (Byte) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> ShortArray.associate(transform: (Short) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> IntArray.associate(transform: (Int) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> LongArray.associate(transform: (Long) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> FloatArray.associate(transform: (Float) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> DoubleArray.associate(transform: (Double) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> BooleanArray.associate(transform: (Boolean) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing key-value pairs provided by [transform] function\n * applied to elements of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitives\n */\npublic inline fun <K, V> CharArray.associate(transform: (Char) -> Pair<K, V>): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateTo(LinkedHashMap<K, V>(capacity), transform)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <T, K> Array<out T>.associateBy(keySelector: (T) -> K): Map<K, T> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, T>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ByteArray.associateBy(keySelector: (Byte) -> K): Map<K, Byte> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Byte>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> ShortArray.associateBy(keySelector: (Short) -> K): Map<K, Short> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Short>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> IntArray.associateBy(keySelector: (Int) -> K): Map<K, Int> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Int>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> LongArray.associateBy(keySelector: (Long) -> K): Map<K, Long> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Long>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> FloatArray.associateBy(keySelector: (Float) -> K): Map<K, Float> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Float>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> DoubleArray.associateBy(keySelector: (Double) -> K): Map<K, Double> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Double>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> BooleanArray.associateBy(keySelector: (Boolean) -> K): Map<K, Boolean> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Boolean>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the elements from the given array indexed by the key\n * returned from [keySelector] function applied to each element.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesBy\n */\npublic inline fun <K> CharArray.associateBy(keySelector: (Char) -> K): Map<K, Char> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, Char>(capacity), keySelector)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <T, K, V> Array<out T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ByteArray.associateBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> ShortArray.associateBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> IntArray.associateBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> LongArray.associateBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> FloatArray.associateBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> DoubleArray.associateBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> BooleanArray.associateBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Returns a [Map] containing the values provided by [valueTransform] and indexed by [keySelector] functions applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByWithValueTransform\n */\npublic inline fun <K, V> CharArray.associateBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, V> {\n    val capacity = mapCapacity(size).coerceAtLeast(16)\n    return associateByTo(LinkedHashMap<K, V>(capacity), keySelector, valueTransform)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <T, K, M : MutableMap<in K, in T>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Byte>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Short>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Int>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Long>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Float>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Double>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Boolean>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function applied to each element of the given array\n * and value is the element itself.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByTo\n */\npublic inline fun <K, M : MutableMap<in K, in Char>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        destination.put(keySelector(element), element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs,\n * where key is provided by the [keySelector] function and\n * and value is provided by the [valueTransform] function applied to elements of the given array.\n * \n * If any two elements would have the same key returned by [keySelector] the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesByToWithValueTransform\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        destination.put(keySelector(element), valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <T, K, V, M : MutableMap<in K, in V>> Array<out T>.associateTo(destination: M, transform: (T) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ByteArray.associateTo(destination: M, transform: (Byte) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> ShortArray.associateTo(destination: M, transform: (Short) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> IntArray.associateTo(destination: M, transform: (Int) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> LongArray.associateTo(destination: M, transform: (Long) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> FloatArray.associateTo(destination: M, transform: (Float) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> DoubleArray.associateTo(destination: M, transform: (Double) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> BooleanArray.associateTo(destination: M, transform: (Boolean) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs\n * provided by [transform] function applied to each element of the given array.\n * \n * If any of two pairs would have the same key the last one gets added to the map.\n * \n * @sample samples.collections.Arrays.Transformations.associateArrayOfPrimitivesTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> CharArray.associateTo(destination: M, transform: (Char) -> Pair<K, V>): M {\n    for (element in this) {\n        destination += transform(element)\n    }\n    return destination\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V> Array<out K>.associateWith(valueSelector: (K) -> V): Map<K, V> {\n    val result = LinkedHashMap<K, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ByteArray.associateWith(valueSelector: (Byte) -> V): Map<Byte, V> {\n    val result = LinkedHashMap<Byte, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> ShortArray.associateWith(valueSelector: (Short) -> V): Map<Short, V> {\n    val result = LinkedHashMap<Short, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> IntArray.associateWith(valueSelector: (Int) -> V): Map<Int, V> {\n    val result = LinkedHashMap<Int, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> LongArray.associateWith(valueSelector: (Long) -> V): Map<Long, V> {\n    val result = LinkedHashMap<Long, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> FloatArray.associateWith(valueSelector: (Float) -> V): Map<Float, V> {\n    val result = LinkedHashMap<Float, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> DoubleArray.associateWith(valueSelector: (Double) -> V): Map<Double, V> {\n    val result = LinkedHashMap<Double, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> BooleanArray.associateWith(valueSelector: (Boolean) -> V): Map<Boolean, V> {\n    val result = LinkedHashMap<Boolean, V>(mapCapacity(size).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Returns a [Map] where keys are elements from the given array and values are\n * produced by the [valueSelector] function applied to each element.\n * \n * If any two elements are equal, the last one gets added to the map.\n * \n * The returned map preserves the entry iteration order of the original array.\n * \n * @sample samples.collections.Collections.Transformations.associateWith\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V> CharArray.associateWith(valueSelector: (Char) -> V): Map<Char, V> {\n    val result = LinkedHashMap<Char, V>(mapCapacity(size.coerceAtMost(128)).coerceAtLeast(16))\n    return associateWithTo(result, valueSelector)\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <K, V, M : MutableMap<in K, in V>> Array<out K>.associateWithTo(destination: M, valueSelector: (K) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Byte, in V>> ByteArray.associateWithTo(destination: M, valueSelector: (Byte) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Short, in V>> ShortArray.associateWithTo(destination: M, valueSelector: (Short) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Int, in V>> IntArray.associateWithTo(destination: M, valueSelector: (Int) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Long, in V>> LongArray.associateWithTo(destination: M, valueSelector: (Long) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Float, in V>> FloatArray.associateWithTo(destination: M, valueSelector: (Float) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Double, in V>> DoubleArray.associateWithTo(destination: M, valueSelector: (Double) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Boolean, in V>> BooleanArray.associateWithTo(destination: M, valueSelector: (Boolean) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs for each element of the given array,\n * where key is the element itself and value is provided by the [valueSelector] function applied to that key.\n * \n * If any two elements are equal, the last one overwrites the former value in the map.\n * \n * @sample samples.collections.Collections.Transformations.associateWithTo\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <V, M : MutableMap<in Char, in V>> CharArray.associateWithTo(destination: M, valueSelector: (Char) -> V): M {\n    for (element in this) {\n        destination.put(element, valueSelector(element))\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <T, C : MutableCollection<in T>> Array<out T>.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Byte>> ByteArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Short>> ShortArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Int>> IntArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Long>> LongArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Float>> FloatArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Double>> DoubleArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Boolean>> BooleanArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Appends all elements to the given [destination] collection.\n */\npublic fun <C : MutableCollection<in Char>> CharArray.toCollection(destination: C): C {\n    for (item in this) {\n        destination.add(item)\n    }\n    return destination\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun <T> Array<out T>.toHashSet(): HashSet<T> {\n    return toCollection(HashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ByteArray.toHashSet(): HashSet<Byte> {\n    return toCollection(HashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun ShortArray.toHashSet(): HashSet<Short> {\n    return toCollection(HashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun IntArray.toHashSet(): HashSet<Int> {\n    return toCollection(HashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun LongArray.toHashSet(): HashSet<Long> {\n    return toCollection(HashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun FloatArray.toHashSet(): HashSet<Float> {\n    return toCollection(HashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun DoubleArray.toHashSet(): HashSet<Double> {\n    return toCollection(HashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun BooleanArray.toHashSet(): HashSet<Boolean> {\n    return toCollection(HashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [HashSet] of all elements.\n */\npublic fun CharArray.toHashSet(): HashSet<Char> {\n    return toCollection(HashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun <T> Array<out T>.toList(): List<T> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ByteArray.toList(): List<Byte> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun ShortArray.toList(): List<Short> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun IntArray.toList(): List<Int> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun LongArray.toList(): List<Long> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun FloatArray.toList(): List<Float> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun DoubleArray.toList(): List<Double> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun BooleanArray.toList(): List<Boolean> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a [List] containing all elements.\n */\npublic fun CharArray.toList(): List<Char> {\n    return when (size) {\n        0 -> emptyList()\n        1 -> listOf(this[0])\n        else -> this.toMutableList()\n    }\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun <T> Array<out T>.toMutableList(): MutableList<T> {\n    return ArrayList(this.asCollection())\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ByteArray.toMutableList(): MutableList<Byte> {\n    val list = ArrayList<Byte>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun ShortArray.toMutableList(): MutableList<Short> {\n    val list = ArrayList<Short>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun IntArray.toMutableList(): MutableList<Int> {\n    val list = ArrayList<Int>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun LongArray.toMutableList(): MutableList<Long> {\n    val list = ArrayList<Long>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun FloatArray.toMutableList(): MutableList<Float> {\n    val list = ArrayList<Float>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun DoubleArray.toMutableList(): MutableList<Double> {\n    val list = ArrayList<Double>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun BooleanArray.toMutableList(): MutableList<Boolean> {\n    val list = ArrayList<Boolean>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a new [MutableList] filled with all elements of this array.\n */\npublic fun CharArray.toMutableList(): MutableList<Char> {\n    val list = ArrayList<Char>(size)\n    for (item in this) list.add(item)\n    return list\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toSet(): Set<T> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<T>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toSet(): Set<Byte> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toSet(): Set<Short> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toSet(): Set<Int> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toSet(): Set<Long> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toSet(): Set<Float> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toSet(): Set<Double> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toSet(): Set<Boolean> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n    }\n}\n\n/**\n * Returns a [Set] of all elements.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toSet(): Set<Char> {\n    return when (size) {\n        0 -> emptySet()\n        1 -> setOf(this[0])\n        else -> toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n    }\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ByteArray.flatMap(transform: (Byte) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> ShortArray.flatMap(transform: (Short) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> IntArray.flatMap(transform: (Int) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> LongArray.flatMap(transform: (Long) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> FloatArray.flatMap(transform: (Float) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> DoubleArray.flatMap(transform: (Double) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> BooleanArray.flatMap(transform: (Boolean) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\npublic inline fun <R> CharArray.flatMap(transform: (Char) -> Iterable<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element of original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMap\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequence\")\npublic inline fun <T, R> Array<out T>.flatMap(transform: (T) -> Sequence<R>): List<R> {\n    return flatMapTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.flatMapIndexed(transform: (index: Int, Byte) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.flatMapIndexed(transform: (index: Int, Short) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.flatMapIndexed(transform: (index: Int, Int) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.flatMapIndexed(transform: (index: Int, Long) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.flatMapIndexed(transform: (index: Int, Float) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.flatMapIndexed(transform: (index: Int, Double) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.flatMapIndexed(transform: (index: Int, Boolean) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterable\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.flatMapIndexed(transform: (index: Int, Char) -> Iterable<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Returns a single list of all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array.\n * \n * @sample samples.collections.Collections.Transformations.flatMapIndexed\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequence\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.flatMapIndexed(transform: (index: Int, T) -> Sequence<R>): List<R> {\n    return flatMapIndexedTo(ArrayList<R>(), transform)\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapIndexedTo(destination: C, transform: (index: Int, Byte) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapIndexedTo(destination: C, transform: (index: Int, Short) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapIndexedTo(destination: C, transform: (index: Int, Int) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapIndexedTo(destination: C, transform: (index: Int, Long) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapIndexedTo(destination: C, transform: (index: Int, Float) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapIndexedTo(destination: C, transform: (index: Int, Double) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapIndexedTo(destination: C, transform: (index: Int, Boolean) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedIterableTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapIndexedTo(destination: C, transform: (index: Int, Char) -> Iterable<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element\n * and its index in the original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapIndexedSequenceTo\")\n@kotlin.internal.InlineOnly\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapIndexedTo(destination: C, transform: (index: Int, T) -> Sequence<R>): C {\n    var index = 0\n    for (element in this) {\n        val list = transform(index++, element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.flatMapTo(destination: C, transform: (Byte) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.flatMapTo(destination: C, transform: (Short) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.flatMapTo(destination: C, transform: (Int) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.flatMapTo(destination: C, transform: (Long) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.flatMapTo(destination: C, transform: (Float) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.flatMapTo(destination: C, transform: (Double) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.flatMapTo(destination: C, transform: (Boolean) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.flatMapTo(destination: C, transform: (Char) -> Iterable<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Appends all elements yielded from results of [transform] function being invoked on each element of original array, to the given [destination].\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"flatMapSequenceTo\")\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.flatMapTo(destination: C, transform: (T) -> Sequence<R>): C {\n    for (element in this) {\n        val list = transform(element)\n        destination.addAll(list)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K> Array<out T>.groupBy(keySelector: (T) -> K): Map<K, List<T>> {\n    return groupByTo(LinkedHashMap<K, MutableList<T>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ByteArray.groupBy(keySelector: (Byte) -> K): Map<K, List<Byte>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Byte>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> ShortArray.groupBy(keySelector: (Short) -> K): Map<K, List<Short>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Short>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> IntArray.groupBy(keySelector: (Int) -> K): Map<K, List<Int>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Int>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> LongArray.groupBy(keySelector: (Long) -> K): Map<K, List<Long>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Long>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> FloatArray.groupBy(keySelector: (Float) -> K): Map<K, List<Float>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Float>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> DoubleArray.groupBy(keySelector: (Double) -> K): Map<K, List<Double>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Double>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> BooleanArray.groupBy(keySelector: (Boolean) -> K): Map<K, List<Boolean>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Boolean>>(), keySelector)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and returns a map where each group key is associated with a list of corresponding elements.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K> CharArray.groupBy(keySelector: (Char) -> K): Map<K, List<Char>> {\n    return groupByTo(LinkedHashMap<K, MutableList<Char>>(), keySelector)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V> Array<out T>.groupBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ByteArray.groupBy(keySelector: (Byte) -> K, valueTransform: (Byte) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> ShortArray.groupBy(keySelector: (Short) -> K, valueTransform: (Short) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> IntArray.groupBy(keySelector: (Int) -> K, valueTransform: (Int) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> LongArray.groupBy(keySelector: (Long) -> K, valueTransform: (Long) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> FloatArray.groupBy(keySelector: (Float) -> K, valueTransform: (Float) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> DoubleArray.groupBy(keySelector: (Double) -> K, valueTransform: (Double) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> BooleanArray.groupBy(keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and returns a map where each group key is associated with a list of corresponding values.\n * \n * The returned map preserves the entry iteration order of the keys produced from the original array.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V> CharArray.groupBy(keySelector: (Char) -> K, valueTransform: (Char) -> V): Map<K, List<V>> {\n    return groupByTo(LinkedHashMap<K, MutableList<V>>(), keySelector, valueTransform)\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<T>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Byte>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Short>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Int>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Long>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Float>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Double>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Boolean>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups elements of the original array by the key returned by the given [keySelector] function\n * applied to each element and puts to the [destination] map each group key associated with a list of corresponding elements.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupBy\n */\npublic inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<Char>() }\n        list.add(element)\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(destination: M, keySelector: (T) -> K, valueTransform: (T) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(destination: M, keySelector: (Byte) -> K, valueTransform: (Byte) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(destination: M, keySelector: (Short) -> K, valueTransform: (Short) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(destination: M, keySelector: (Int) -> K, valueTransform: (Int) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(destination: M, keySelector: (Long) -> K, valueTransform: (Long) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(destination: M, keySelector: (Float) -> K, valueTransform: (Float) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(destination: M, keySelector: (Double) -> K, valueTransform: (Double) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(destination: M, keySelector: (Boolean) -> K, valueTransform: (Boolean) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Groups values returned by the [valueTransform] function applied to each element of the original array\n * by the key returned by the given [keySelector] function applied to the element\n * and puts to the [destination] map each group key associated with a list of corresponding values.\n * \n * @return The [destination] map.\n * \n * @sample samples.collections.Collections.Transformations.groupByKeysAndValues\n */\npublic inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(destination: M, keySelector: (Char) -> K, valueTransform: (Char) -> V): M {\n    for (element in this) {\n        val key = keySelector(element)\n        val list = destination.getOrPut(key) { ArrayList<V>() }\n        list.add(valueTransform(element))\n    }\n    return destination\n}\n\n/**\n * Creates a [Grouping] source from an array to be used later with one of group-and-fold operations\n * using the specified [keySelector] function to extract a key from each element.\n * \n * @sample samples.collections.Grouping.groupingByEachCount\n */\n@SinceKotlin(\"1.1\")\npublic inline fun <T, K> Array<out T>.groupingBy(crossinline keySelector: (T) -> K): Grouping<T, K> {\n    return object : Grouping<T, K> {\n        override fun sourceIterator(): Iterator<T> = this@groupingBy.iterator()\n        override fun keyOf(element: T): K = keySelector(element)\n    }\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <T, R> Array<out T>.map(transform: (T) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ByteArray.map(transform: (Byte) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> ShortArray.map(transform: (Short) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> IntArray.map(transform: (Int) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> LongArray.map(transform: (Long) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> FloatArray.map(transform: (Float) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> DoubleArray.map(transform: (Double) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> BooleanArray.map(transform: (Boolean) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.map\n */\npublic inline fun <R> CharArray.map(transform: (Char) -> R): List<R> {\n    return mapTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R> Array<out T>.mapIndexed(transform: (index: Int, T) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ByteArray.mapIndexed(transform: (index: Int, Byte) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> ShortArray.mapIndexed(transform: (index: Int, Short) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> IntArray.mapIndexed(transform: (index: Int, Int) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> LongArray.mapIndexed(transform: (index: Int, Long) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> FloatArray.mapIndexed(transform: (index: Int, Float) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> DoubleArray.mapIndexed(transform: (index: Int, Double) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> BooleanArray.mapIndexed(transform: (index: Int, Boolean) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing the results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R> CharArray.mapIndexed(transform: (index: Int, Char) -> R): List<R> {\n    return mapIndexedTo(ArrayList<R>(size), transform)\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element and its index in the original array.\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any> Array<out T>.mapIndexedNotNull(transform: (index: Int, T) -> R?): List<R> {\n    return mapIndexedNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends only the non-null results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapIndexedNotNullTo(destination: C, transform: (index: Int, T) -> R?): C {\n    forEachIndexed { index, element -> transform(index, element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapIndexedTo(destination: C, transform: (index: Int, T) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapIndexedTo(destination: C, transform: (index: Int, Byte) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapIndexedTo(destination: C, transform: (index: Int, Short) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapIndexedTo(destination: C, transform: (index: Int, Int) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapIndexedTo(destination: C, transform: (index: Int, Long) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapIndexedTo(destination: C, transform: (index: Int, Float) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapIndexedTo(destination: C, transform: (index: Int, Double) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapIndexedTo(destination: C, transform: (index: Int, Boolean) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element and its index in the original array\n * and appends the results to the given [destination].\n * @param [transform] function that takes the index of an element and the element itself\n * and returns the result of the transform applied to the element.\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapIndexedTo(destination: C, transform: (index: Int, Char) -> R): C {\n    var index = 0\n    for (item in this)\n        destination.add(transform(index++, item))\n    return destination\n}\n\n/**\n * Returns a list containing only the non-null results of applying the given [transform] function\n * to each element in the original array.\n * \n * @sample samples.collections.Collections.Transformations.mapNotNull\n */\npublic inline fun <T, R : Any> Array<out T>.mapNotNull(transform: (T) -> R?): List<R> {\n    return mapNotNullTo(ArrayList<R>(), transform)\n}\n\n/**\n * Applies the given [transform] function to each element in the original array\n * and appends only the non-null results to the given [destination].\n */\npublic inline fun <T, R : Any, C : MutableCollection<in R>> Array<out T>.mapNotNullTo(destination: C, transform: (T) -> R?): C {\n    forEach { element -> transform(element)?.let { destination.add(it) } }\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <T, R, C : MutableCollection<in R>> Array<out T>.mapTo(destination: C, transform: (T) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ByteArray.mapTo(destination: C, transform: (Byte) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> ShortArray.mapTo(destination: C, transform: (Short) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> IntArray.mapTo(destination: C, transform: (Int) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> LongArray.mapTo(destination: C, transform: (Long) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> FloatArray.mapTo(destination: C, transform: (Float) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> DoubleArray.mapTo(destination: C, transform: (Double) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> BooleanArray.mapTo(destination: C, transform: (Boolean) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Applies the given [transform] function to each element of the original array\n * and appends the results to the given [destination].\n */\npublic inline fun <R, C : MutableCollection<in R>> CharArray.mapTo(destination: C, transform: (Char) -> R): C {\n    for (item in this)\n        destination.add(transform(item))\n    return destination\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun <T> Array<out T>.withIndex(): Iterable<IndexedValue<T>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ByteArray.withIndex(): Iterable<IndexedValue<Byte>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun ShortArray.withIndex(): Iterable<IndexedValue<Short>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun IntArray.withIndex(): Iterable<IndexedValue<Int>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun LongArray.withIndex(): Iterable<IndexedValue<Long>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun FloatArray.withIndex(): Iterable<IndexedValue<Float>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun DoubleArray.withIndex(): Iterable<IndexedValue<Double>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun BooleanArray.withIndex(): Iterable<IndexedValue<Boolean>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a lazy [Iterable] that wraps each element of the original array\n * into an [IndexedValue] containing the index of that element and the element itself.\n */\npublic fun CharArray.withIndex(): Iterable<IndexedValue<Char>> {\n    return IndexingIterable { iterator() }\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * Among equal elements of the given array, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun <T> Array<out T>.distinct(): List<T> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ByteArray.distinct(): List<Byte> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun ShortArray.distinct(): List<Short> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun IntArray.distinct(): List<Int> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun LongArray.distinct(): List<Long> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun FloatArray.distinct(): List<Float> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun DoubleArray.distinct(): List<Double> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun BooleanArray.distinct(): List<Boolean> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only distinct elements from the given array.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic fun CharArray.distinct(): List<Char> {\n    return this.toMutableSet().toList()\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * Among elements of the given array with equal keys, only the first one will be present in the resulting list.\n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <T, K> Array<out T>.distinctBy(selector: (T) -> K): List<T> {\n    val set = HashSet<K>()\n    val list = ArrayList<T>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ByteArray.distinctBy(selector: (Byte) -> K): List<Byte> {\n    val set = HashSet<K>()\n    val list = ArrayList<Byte>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> ShortArray.distinctBy(selector: (Short) -> K): List<Short> {\n    val set = HashSet<K>()\n    val list = ArrayList<Short>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> IntArray.distinctBy(selector: (Int) -> K): List<Int> {\n    val set = HashSet<K>()\n    val list = ArrayList<Int>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> LongArray.distinctBy(selector: (Long) -> K): List<Long> {\n    val set = HashSet<K>()\n    val list = ArrayList<Long>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> FloatArray.distinctBy(selector: (Float) -> K): List<Float> {\n    val set = HashSet<K>()\n    val list = ArrayList<Float>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> DoubleArray.distinctBy(selector: (Double) -> K): List<Double> {\n    val set = HashSet<K>()\n    val list = ArrayList<Double>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> BooleanArray.distinctBy(selector: (Boolean) -> K): List<Boolean> {\n    val set = HashSet<K>()\n    val list = ArrayList<Boolean>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a list containing only elements from the given array\n * having distinct keys returned by the given [selector] function.\n * \n * The elements in the resulting list are in the same order as they were in the source array.\n * \n * @sample samples.collections.Collections.Transformations.distinctAndDistinctBy\n */\npublic inline fun <K> CharArray.distinctBy(selector: (Char) -> K): List<Char> {\n    val set = HashSet<K>()\n    val list = ArrayList<Char>()\n    for (e in this) {\n        val key = selector(e)\n        if (set.add(key))\n            list.add(e)\n    }\n    return list\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun <T> Array<out T>.intersect(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ByteArray.intersect(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun ShortArray.intersect(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun IntArray.intersect(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun LongArray.intersect(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun FloatArray.intersect(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun DoubleArray.intersect(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun BooleanArray.intersect(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by both this array and the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n * \n * To get a set containing all elements that are contained at least in one of these collections use [union].\n */\npublic infix fun CharArray.intersect(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.retainAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun <T> Array<out T>.subtract(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ByteArray.subtract(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun ShortArray.subtract(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun IntArray.subtract(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun LongArray.subtract(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun FloatArray.subtract(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun DoubleArray.subtract(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun BooleanArray.subtract(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all elements that are contained by this array and not contained by the specified collection.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic infix fun CharArray.subtract(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.removeAll(other)\n    return set\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun <T> Array<out T>.toMutableSet(): MutableSet<T> {\n    return toCollection(LinkedHashSet<T>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ByteArray.toMutableSet(): MutableSet<Byte> {\n    return toCollection(LinkedHashSet<Byte>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun ShortArray.toMutableSet(): MutableSet<Short> {\n    return toCollection(LinkedHashSet<Short>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun IntArray.toMutableSet(): MutableSet<Int> {\n    return toCollection(LinkedHashSet<Int>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun LongArray.toMutableSet(): MutableSet<Long> {\n    return toCollection(LinkedHashSet<Long>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun FloatArray.toMutableSet(): MutableSet<Float> {\n    return toCollection(LinkedHashSet<Float>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun DoubleArray.toMutableSet(): MutableSet<Double> {\n    return toCollection(LinkedHashSet<Double>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun BooleanArray.toMutableSet(): MutableSet<Boolean> {\n    return toCollection(LinkedHashSet<Boolean>(mapCapacity(size)))\n}\n\n/**\n * Returns a new [MutableSet] containing all distinct elements from the given array.\n * \n * The returned set preserves the element iteration order of the original array.\n */\npublic fun CharArray.toMutableSet(): MutableSet<Char> {\n    return toCollection(LinkedHashSet<Char>(mapCapacity(size.coerceAtMost(128))))\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun <T> Array<out T>.union(other: Iterable<T>): Set<T> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ByteArray.union(other: Iterable<Byte>): Set<Byte> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun ShortArray.union(other: Iterable<Short>): Set<Short> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun IntArray.union(other: Iterable<Int>): Set<Int> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun LongArray.union(other: Iterable<Long>): Set<Long> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun FloatArray.union(other: Iterable<Float>): Set<Float> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun DoubleArray.union(other: Iterable<Double>): Set<Double> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun BooleanArray.union(other: Iterable<Boolean>): Set<Boolean> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns a set containing all distinct elements from both collections.\n * \n * The returned set preserves the element iteration order of the original array.\n * Those elements of the [other] collection that are unique are iterated in the end\n * in the order of the [other] collection.\n * \n * To get a set containing all elements that are contained in both collections use [intersect].\n */\npublic infix fun CharArray.union(other: Iterable<Char>): Set<Char> {\n    val set = this.toMutableSet()\n    set.addAll(other)\n    return set\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun <T> Array<out T>.all(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ByteArray.all(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun ShortArray.all(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun IntArray.all(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun LongArray.all(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun FloatArray.all(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun DoubleArray.all(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun BooleanArray.all(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if all elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.all\n */\npublic inline fun CharArray.all(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (!predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun <T> Array<out T>.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ByteArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun ShortArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun IntArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun LongArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun FloatArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun DoubleArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun BooleanArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if array has at least one element.\n * \n * @sample samples.collections.Collections.Aggregates.any\n */\npublic fun CharArray.any(): Boolean {\n    return !isEmpty()\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun <T> Array<out T>.any(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ByteArray.any(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun ShortArray.any(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun IntArray.any(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun LongArray.any(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun FloatArray.any(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun DoubleArray.any(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun BooleanArray.any(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns `true` if at least one element matches the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.anyWithPredicate\n */\npublic inline fun CharArray.any(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return true\n    return false\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements in this array.\n */\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.count(): Int {\n    return size\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun <T> Array<out T>.count(predicate: (T) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ByteArray.count(predicate: (Byte) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun ShortArray.count(predicate: (Short) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun IntArray.count(predicate: (Int) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun LongArray.count(predicate: (Long) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun FloatArray.count(predicate: (Float) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun DoubleArray.count(predicate: (Double) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun BooleanArray.count(predicate: (Boolean) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Returns the number of elements matching the given [predicate].\n */\npublic inline fun CharArray.count(predicate: (Char) -> Boolean): Int {\n    var count = 0\n    for (element in this) if (predicate(element)) ++count\n    return count\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.fold(initial: R, operation: (acc: R, T) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.fold(initial: R, operation: (acc: R, Byte) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.fold(initial: R, operation: (acc: R, Short) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.fold(initial: R, operation: (acc: R, Int) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.fold(initial: R, operation: (acc: R, Long) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.fold(initial: R, operation: (acc: R, Float) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.fold(initial: R, operation: (acc: R, Double) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.fold(initial: R, operation: (acc: R, Boolean) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.fold(initial: R, operation: (acc: R, Char) -> R): R {\n    var accumulator = initial\n    for (element in this) accumulator = operation(accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): R {\n    var index = 0\n    var accumulator = initial\n    for (element in this) accumulator = operation(index++, accumulator, element)\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRight(initial: R, operation: (T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRight(initial: R, operation: (Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRight(initial: R, operation: (Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRight(initial: R, operation: (Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRight(initial: R, operation: (Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRight(initial: R, operation: (Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRight(initial: R, operation: (Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRight(initial: R, operation: (Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRight(initial: R, operation: (Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <T, R> Array<out T>.foldRightIndexed(initial: R, operation: (index: Int, T, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ByteArray.foldRightIndexed(initial: R, operation: (index: Int, Byte, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> ShortArray.foldRightIndexed(initial: R, operation: (index: Int, Short, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> IntArray.foldRightIndexed(initial: R, operation: (index: Int, Int, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> LongArray.foldRightIndexed(initial: R, operation: (index: Int, Long, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> FloatArray.foldRightIndexed(initial: R, operation: (index: Int, Float, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> DoubleArray.foldRightIndexed(initial: R, operation: (index: Int, Double, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> BooleanArray.foldRightIndexed(initial: R, operation: (index: Int, Boolean, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with [initial] value and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns the specified [initial] value if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself\n * and current accumulator value, and calculates the next accumulator value.\n */\npublic inline fun <R> CharArray.foldRightIndexed(initial: R, operation: (index: Int, Char, acc: R) -> R): R {\n    var index = lastIndex\n    var accumulator = initial\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun <T> Array<out T>.forEach(action: (T) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ByteArray.forEach(action: (Byte) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun ShortArray.forEach(action: (Short) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun IntArray.forEach(action: (Int) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun LongArray.forEach(action: (Long) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun FloatArray.forEach(action: (Float) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun DoubleArray.forEach(action: (Double) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun BooleanArray.forEach(action: (Boolean) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element.\n */\npublic inline fun CharArray.forEach(action: (Char) -> Unit): Unit {\n    for (element in this) action(element)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun <T> Array<out T>.forEachIndexed(action: (index: Int, T) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ByteArray.forEachIndexed(action: (index: Int, Byte) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun ShortArray.forEachIndexed(action: (index: Int, Short) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun IntArray.forEachIndexed(action: (index: Int, Int) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun LongArray.forEachIndexed(action: (index: Int, Long) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun FloatArray.forEachIndexed(action: (index: Int, Float) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun DoubleArray.forEachIndexed(action: (index: Int, Double) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun BooleanArray.forEachIndexed(action: (index: Int, Boolean) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\npublic inline fun CharArray.forEachIndexed(action: (index: Int, Char) -> Unit): Unit {\n    var index = 0\n    for (item in this) action(index++, item)\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.max(): T? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.max(): Byte? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.max(): Short? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.max(): Int? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.max(): Long? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.max(): Float? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.max(): Double? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxOrNull instead.\", ReplaceWith(\"this.maxOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.max(): Char? {\n    return maxOrNull()\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxBy(selector: (T) -> R): T? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.maxBy(selector: (Byte) -> R): Byte? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.maxBy(selector: (Short) -> R): Short? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.maxBy(selector: (Int) -> R): Int? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.maxBy(selector: (Long) -> R): Long? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.maxBy(selector: (Float) -> R): Float? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxBy(selector: (Double) -> R): Double? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxBy(selector: (Boolean) -> R): Boolean? {\n    return maxByOrNull(selector)\n}\n\n@Deprecated(\"Use maxByOrNull instead.\", ReplaceWith(\"this.maxByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.maxBy(selector: (Char) -> R): Char? {\n    return maxByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.maxByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.maxByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.maxByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.maxByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.maxByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.maxByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.maxByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the first element yielding the largest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.maxByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.maxByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var maxElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return maxElem\n    var maxValue = selector(maxElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (maxValue < v) {\n            maxElem = e\n            maxValue = v\n        }\n    }\n    return maxElem\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.maxOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.maxOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.maxOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.maxOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.maxOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.maxOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.maxOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.maxOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.maxOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        maxValue = maxOf(maxValue, v)\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.maxOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.maxOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.maxOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.maxOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.maxOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.maxOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.maxOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.maxOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.maxOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (maxValue < v) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.maxOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.maxOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var maxValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(maxValue, v) < 0) {\n            maxValue = v\n        }\n    }\n    return maxValue\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.maxOrNull(): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxOrNull(): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxOrNull(): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxOrNull(): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxOrNull(): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxOrNull(): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxOrNull(): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        max = maxOf(max, e)\n    }\n    return max\n}\n\n/**\n * Returns the largest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxOrNull(): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (max < e) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.maxWith(comparator: Comparator<in T>): T? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.maxWith(comparator: Comparator<in Byte>): Byte? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.maxWith(comparator: Comparator<in Short>): Short? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.maxWith(comparator: Comparator<in Int>): Int? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.maxWith(comparator: Comparator<in Long>): Long? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.maxWith(comparator: Comparator<in Float>): Float? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.maxWith(comparator: Comparator<in Double>): Double? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.maxWith(comparator: Comparator<in Boolean>): Boolean? {\n    return maxWithOrNull(comparator)\n}\n\n@Deprecated(\"Use maxWithOrNull instead.\", ReplaceWith(\"this.maxWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.maxWith(comparator: Comparator<in Char>): Char? {\n    return maxWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.maxWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.maxWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.maxWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.maxWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.maxWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.maxWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.maxWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.maxWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n/**\n * Returns the first element having the largest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.maxWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var max = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(max, e) < 0) max = e\n    }\n    return max\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Double>.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\n@SinceKotlin(\"1.1\")\npublic fun Array<out Float>.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T : Comparable<T>> Array<out T>.min(): T? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.min(): Byte? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.min(): Short? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.min(): Int? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.min(): Long? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.min(): Float? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.min(): Double? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minOrNull instead.\", ReplaceWith(\"this.minOrNull()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.min(): Char? {\n    return minOrNull()\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minBy(selector: (T) -> R): T? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ByteArray.minBy(selector: (Byte) -> R): Byte? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> ShortArray.minBy(selector: (Short) -> R): Short? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> IntArray.minBy(selector: (Int) -> R): Int? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> LongArray.minBy(selector: (Long) -> R): Long? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> FloatArray.minBy(selector: (Float) -> R): Float? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> DoubleArray.minBy(selector: (Double) -> R): Double? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> BooleanArray.minBy(selector: (Boolean) -> R): Boolean? {\n    return minByOrNull(selector)\n}\n\n@Deprecated(\"Use minByOrNull instead.\", ReplaceWith(\"this.minByOrNull(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic inline fun <R : Comparable<R>> CharArray.minBy(selector: (Char) -> R): Char? {\n    return minByOrNull(selector)\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R : Comparable<R>> Array<out T>.minByOrNull(selector: (T) -> R): T? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ByteArray.minByOrNull(selector: (Byte) -> R): Byte? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> ShortArray.minByOrNull(selector: (Short) -> R): Short? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> IntArray.minByOrNull(selector: (Int) -> R): Int? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> LongArray.minByOrNull(selector: (Long) -> R): Long? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> FloatArray.minByOrNull(selector: (Float) -> R): Float? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> DoubleArray.minByOrNull(selector: (Double) -> R): Double? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> BooleanArray.minByOrNull(selector: (Boolean) -> R): Boolean? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the first element yielding the smallest value of the given function or `null` if there are no elements.\n * \n * @sample samples.collections.Collections.Aggregates.minByOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <R : Comparable<R>> CharArray.minByOrNull(selector: (Char) -> R): Char? {\n    if (isEmpty()) return null\n    var minElem = this[0]\n    val lastIndex = this.lastIndex\n    if (lastIndex == 0) return minElem\n    var minValue = selector(minElem)\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        val v = selector(e)\n        if (minValue > v) {\n            minElem = e\n            minValue = v\n        }\n    }\n    return minElem\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Double): Double {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOf(selector: (T) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOf(selector: (Byte) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOf(selector: (Short) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOf(selector: (Int) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOf(selector: (Long) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOf(selector: (Float) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOf(selector: (Double) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOf(selector: (Boolean) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOf(selector: (Char) -> Float): Float {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOf(selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOf(selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOf(selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOf(selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOf(selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOf(selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOf(selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOf(selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOf(selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Double): Double? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.minOfOrNull(selector: (T) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.minOfOrNull(selector: (Byte) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.minOfOrNull(selector: (Short) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.minOfOrNull(selector: (Int) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.minOfOrNull(selector: (Long) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.minOfOrNull(selector: (Float) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.minOfOrNull(selector: (Double) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.minOfOrNull(selector: (Boolean) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n * \n * If any of values produced by [selector] function is `NaN`, the returned result is `NaN`.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.minOfOrNull(selector: (Char) -> Float): Float? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        minValue = minOf(minValue, v)\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R : Comparable<R>> Array<out T>.minOfOrNull(selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ByteArray.minOfOrNull(selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> ShortArray.minOfOrNull(selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> IntArray.minOfOrNull(selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> LongArray.minOfOrNull(selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> FloatArray.minOfOrNull(selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> DoubleArray.minOfOrNull(selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> BooleanArray.minOfOrNull(selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value among all values produced by [selector] function\n * applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R : Comparable<R>> CharArray.minOfOrNull(selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (minValue > v) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWith(comparator: Comparator<in R>, selector: (T) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWith(comparator: Comparator<in R>, selector: (Byte) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWith(comparator: Comparator<in R>, selector: (Short) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWith(comparator: Comparator<in R>, selector: (Int) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWith(comparator: Comparator<in R>, selector: (Long) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWith(comparator: Comparator<in R>, selector: (Float) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWith(comparator: Comparator<in R>, selector: (Double) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWith(comparator: Comparator<in R>, selector: (Boolean) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array.\n * \n * @throws NoSuchElementException if the array is empty.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWith(comparator: Comparator<in R>, selector: (Char) -> R): R {\n    if (isEmpty()) throw NoSuchElementException()\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> Array<out T>.minOfWithOrNull(comparator: Comparator<in R>, selector: (T) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Byte) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Short) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Int) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Long) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Float) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Double) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Boolean) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest value according to the provided [comparator]\n * among all values produced by [selector] function applied to each element in the array or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.minOfWithOrNull(comparator: Comparator<in R>, selector: (Char) -> R): R? {\n    if (isEmpty()) return null\n    var minValue = selector(this[0])\n    for (i in 1..lastIndex) {\n        val v = selector(this[i])\n        if (comparator.compare(minValue, v) > 0) {\n            minValue = v\n        }\n    }\n    return minValue\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Double>.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun Array<out Float>.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T : Comparable<T>> Array<out T>.minOrNull(): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minOrNull(): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minOrNull(): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minOrNull(): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minOrNull(): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minOrNull(): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n * \n * If any of elements is `NaN` returns `NaN`.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minOrNull(): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        min = minOf(min, e)\n    }\n    return min\n}\n\n/**\n * Returns the smallest element or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minOrNull(): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (min > e) min = e\n    }\n    return min\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun <T> Array<out T>.minWith(comparator: Comparator<in T>): T? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ByteArray.minWith(comparator: Comparator<in Byte>): Byte? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun ShortArray.minWith(comparator: Comparator<in Short>): Short? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun IntArray.minWith(comparator: Comparator<in Int>): Int? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun LongArray.minWith(comparator: Comparator<in Long>): Long? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun FloatArray.minWith(comparator: Comparator<in Float>): Float? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun DoubleArray.minWith(comparator: Comparator<in Double>): Double? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun BooleanArray.minWith(comparator: Comparator<in Boolean>): Boolean? {\n    return minWithOrNull(comparator)\n}\n\n@Deprecated(\"Use minWithOrNull instead.\", ReplaceWith(\"this.minWithOrNull(comparator)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic fun CharArray.minWith(comparator: Comparator<in Char>): Char? {\n    return minWithOrNull(comparator)\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun <T> Array<out T>.minWithOrNull(comparator: Comparator<in T>): T? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ByteArray.minWithOrNull(comparator: Comparator<in Byte>): Byte? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun ShortArray.minWithOrNull(comparator: Comparator<in Short>): Short? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun IntArray.minWithOrNull(comparator: Comparator<in Int>): Int? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun LongArray.minWithOrNull(comparator: Comparator<in Long>): Long? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun FloatArray.minWithOrNull(comparator: Comparator<in Float>): Float? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun DoubleArray.minWithOrNull(comparator: Comparator<in Double>): Double? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun BooleanArray.minWithOrNull(comparator: Comparator<in Boolean>): Boolean? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns the first element having the smallest value according to the provided [comparator] or `null` if there are no elements.\n */\n@SinceKotlin(\"1.4\")\npublic fun CharArray.minWithOrNull(comparator: Comparator<in Char>): Char? {\n    if (isEmpty()) return null\n    var min = this[0]\n    for (i in 1..lastIndex) {\n        val e = this[i]\n        if (comparator.compare(min, e) > 0) min = e\n    }\n    return min\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun <T> Array<out T>.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ByteArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun ShortArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun IntArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun LongArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun FloatArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun DoubleArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun BooleanArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if the array has no elements.\n * \n * @sample samples.collections.Collections.Aggregates.none\n */\npublic fun CharArray.none(): Boolean {\n    return isEmpty()\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun <T> Array<out T>.none(predicate: (T) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ByteArray.none(predicate: (Byte) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun ShortArray.none(predicate: (Short) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun LongArray.none(predicate: (Long) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun FloatArray.none(predicate: (Float) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun DoubleArray.none(predicate: (Double) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun BooleanArray.none(predicate: (Boolean) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Returns `true` if no elements match the given [predicate].\n * \n * @sample samples.collections.Collections.Aggregates.noneWithPredicate\n */\npublic inline fun CharArray.none(predicate: (Char) -> Boolean): Boolean {\n    for (element in this) if (predicate(element)) return false\n    return true\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEach(action: (T) -> Unit): Array<out T> {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEach(action: (Byte) -> Unit): ByteArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEach(action: (Short) -> Unit): ShortArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEach(action: (Int) -> Unit): IntArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEach(action: (Long) -> Unit): LongArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEach(action: (Float) -> Unit): FloatArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEach(action: (Double) -> Unit): DoubleArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEach(action: (Boolean) -> Unit): BooleanArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element and returns the array itself afterwards.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEach(action: (Char) -> Unit): CharArray {\n    return apply { for (element in this) action(element) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.onEachIndexed(action: (index: Int, T) -> Unit): Array<out T> {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.onEachIndexed(action: (index: Int, Byte) -> Unit): ByteArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.onEachIndexed(action: (index: Int, Short) -> Unit): ShortArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.onEachIndexed(action: (index: Int, Int) -> Unit): IntArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.onEachIndexed(action: (index: Int, Long) -> Unit): LongArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.onEachIndexed(action: (index: Int, Float) -> Unit): FloatArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.onEachIndexed(action: (index: Int, Double) -> Unit): DoubleArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.onEachIndexed(action: (index: Int, Boolean) -> Unit): BooleanArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Performs the given [action] on each element, providing sequential index with the element,\n * and returns the array itself afterwards.\n * @param [action] function that takes the index of an element and the element itself\n * and performs the action on the element.\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.onEachIndexed(action: (index: Int, Char) -> Unit): CharArray {\n    return apply { forEachIndexed(action) }\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduce(operation: (acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduce(operation: (acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduce(operation: (acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduce(operation: (acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduce(operation: (acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduce(operation: (acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduce(operation: (acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduce(operation: (acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduce(operation: (acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun <S, T : S> Array<out T>.reduceIndexed(operation: (index: Int, acc: S, T) -> S): S {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ByteArray.reduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun ShortArray.reduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): Short {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun IntArray.reduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): Int {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun LongArray.reduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): Long {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun FloatArray.reduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): Float {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun DoubleArray.reduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): Double {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun BooleanArray.reduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduce\n */\npublic inline fun CharArray.reduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): Char {\n    if (isEmpty())\n        throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceIndexedOrNull(operation: (index: Int, acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceIndexedOrNull(operation: (index: Int, acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceIndexedOrNull(operation: (index: Int, acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceIndexedOrNull(operation: (index: Int, acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceIndexedOrNull(operation: (index: Int, acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceIndexedOrNull(operation: (index: Int, acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceIndexedOrNull(operation: (index: Int, acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceIndexedOrNull(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element with its index in the original array.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, current accumulator value and the element itself,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceIndexedOrNull(operation: (index: Int, acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(index, accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceOrNull(operation: (acc: S, T) -> S): S? {\n    if (isEmpty())\n        return null\n    var accumulator: S = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceOrNull(operation: (acc: Byte, Byte) -> Byte): Byte? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceOrNull(operation: (acc: Short, Short) -> Short): Short? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceOrNull(operation: (acc: Int, Int) -> Int): Int? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceOrNull(operation: (acc: Long, Long) -> Long): Long? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceOrNull(operation: (acc: Float, Float) -> Float): Float? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceOrNull(operation: (acc: Double, Double) -> Double): Double? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceOrNull(operation: (acc: Boolean, Boolean) -> Boolean): Boolean? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the first element and applying [operation] from left to right\n * to current accumulator value and each element.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes current accumulator value and an element,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceOrNull(operation: (acc: Char, Char) -> Char): Char? {\n    if (isEmpty())\n        return null\n    var accumulator = this[0]\n    for (index in 1..lastIndex) {\n        accumulator = operation(accumulator, this[index])\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRight(operation: (T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRight(operation: (Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRight(operation: (Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRight(operation: (Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRight(operation: (Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRight(operation: (Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRight(operation: (Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRight(operation: (Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRight(operation: (Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexed(operation: (index: Int, T, acc: S) -> S): S {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ByteArray.reduceRightIndexed(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun ShortArray.reduceRightIndexed(operation: (index: Int, Short, acc: Short) -> Short): Short {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun IntArray.reduceRightIndexed(operation: (index: Int, Int, acc: Int) -> Int): Int {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun LongArray.reduceRightIndexed(operation: (index: Int, Long, acc: Long) -> Long): Long {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun FloatArray.reduceRightIndexed(operation: (index: Int, Float, acc: Float) -> Float): Float {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun DoubleArray.reduceRightIndexed(operation: (index: Int, Double, acc: Double) -> Double): Double {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun BooleanArray.reduceRightIndexed(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Throws an exception if this array is empty. If the array can be empty in an expected way,\n * please use [reduceRightIndexedOrNull] instead. It returns `null` when its receiver is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRight\n */\npublic inline fun CharArray.reduceRightIndexed(operation: (index: Int, Char, acc: Char) -> Char): Char {\n    var index = lastIndex\n    if (index < 0) throw UnsupportedOperationException(\"Empty array can't be reduced.\")\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.reduceRightIndexedOrNull(operation: (index: Int, T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ByteArray.reduceRightIndexedOrNull(operation: (index: Int, Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun ShortArray.reduceRightIndexedOrNull(operation: (index: Int, Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun IntArray.reduceRightIndexedOrNull(operation: (index: Int, Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun LongArray.reduceRightIndexedOrNull(operation: (index: Int, Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun FloatArray.reduceRightIndexedOrNull(operation: (index: Int, Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun DoubleArray.reduceRightIndexedOrNull(operation: (index: Int, Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun BooleanArray.reduceRightIndexedOrNull(operation: (index: Int, Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element with its index in the original array and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes the index of an element, the element itself and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\npublic inline fun CharArray.reduceRightIndexedOrNull(operation: (index: Int, Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(index, get(index), accumulator)\n        --index\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.reduceRightOrNull(operation: (T, acc: S) -> S): S? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator: S = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ByteArray.reduceRightOrNull(operation: (Byte, acc: Byte) -> Byte): Byte? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun ShortArray.reduceRightOrNull(operation: (Short, acc: Short) -> Short): Short? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun IntArray.reduceRightOrNull(operation: (Int, acc: Int) -> Int): Int? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun LongArray.reduceRightOrNull(operation: (Long, acc: Long) -> Long): Long? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun FloatArray.reduceRightOrNull(operation: (Float, acc: Float) -> Float): Float? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun DoubleArray.reduceRightOrNull(operation: (Double, acc: Double) -> Double): Double? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun BooleanArray.reduceRightOrNull(operation: (Boolean, acc: Boolean) -> Boolean): Boolean? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Accumulates value starting with the last element and applying [operation] from right to left\n * to each element and current accumulator value.\n * \n * Returns `null` if the array is empty.\n * \n * @param [operation] function that takes an element and current accumulator value,\n * and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.reduceRightOrNull\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun CharArray.reduceRightOrNull(operation: (Char, acc: Char) -> Char): Char? {\n    var index = lastIndex\n    if (index < 0) return null\n    var accumulator = get(index--)\n    while (index >= 0) {\n        accumulator = operation(get(index--), accumulator)\n    }\n    return accumulator\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFold(initial: R, operation: (acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFold(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFold(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFold(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFold(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFold(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFold(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFold(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFold(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (element in this) {\n        accumulator = operation(accumulator, element)\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <T, R> Array<out T>.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningFold\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.runningFoldIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    if (isEmpty()) return listOf(initial)\n    val result = ArrayList<R>(size + 1).apply { add(initial) }\n    var accumulator = initial\n    for (index in indices) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and the element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <S, T : S> Array<out T>.runningReduce(operation: (acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduce(operation: (acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduce(operation: (acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduce(operation: (acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduce(operation: (acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduce(operation: (acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduce(operation: (acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduce(operation: (acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduce(operation: (acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\npublic inline fun <S, T : S> Array<out T>.runningReduceIndexed(operation: (index: Int, acc: S, T) -> S): List<S> {\n    if (isEmpty()) return emptyList()\n    var accumulator: S = this[0]\n    val result = ArrayList<S>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.runningReduceIndexed(operation: (index: Int, acc: Byte, Byte) -> Byte): List<Byte> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Byte>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.runningReduceIndexed(operation: (index: Int, acc: Short, Short) -> Short): List<Short> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Short>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.runningReduceIndexed(operation: (index: Int, acc: Int, Int) -> Int): List<Int> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Int>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.runningReduceIndexed(operation: (index: Int, acc: Long, Long) -> Long): List<Long> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Long>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.runningReduceIndexed(operation: (index: Int, acc: Float, Float) -> Float): List<Float> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Float>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.runningReduceIndexed(operation: (index: Int, acc: Double, Double) -> Double): List<Double> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Double>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.runningReduceIndexed(operation: (index: Int, acc: Boolean, Boolean) -> Boolean): List<Boolean> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Boolean>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with the first element of this array.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.runningReduce\n */\n@SinceKotlin(\"1.4\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.runningReduceIndexed(operation: (index: Int, acc: Char, Char) -> Char): List<Char> {\n    if (isEmpty()) return emptyList()\n    var accumulator = this[0]\n    val result = ArrayList<Char>(size).apply { add(accumulator) }\n    for (index in 1 until size) {\n        accumulator = operation(index, accumulator, this[index])\n        result.add(accumulator)\n    }\n    return result\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scan(initial: R, operation: (acc: R, T) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scan(initial: R, operation: (acc: R, Byte) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scan(initial: R, operation: (acc: R, Short) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scan(initial: R, operation: (acc: R, Int) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scan(initial: R, operation: (acc: R, Long) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scan(initial: R, operation: (acc: R, Float) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scan(initial: R, operation: (acc: R, Double) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scan(initial: R, operation: (acc: R, Boolean) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes current accumulator value and an element, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scan(initial: R, operation: (acc: R, Char) -> R): List<R> {\n    return runningFold(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic inline fun <T, R> Array<out T>.scanIndexed(initial: R, operation: (index: Int, acc: R, T) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ByteArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Byte) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> ShortArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Short) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> IntArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Int) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> LongArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Long) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> FloatArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Float) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> DoubleArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Double) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> BooleanArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Boolean) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns a list containing successive accumulation values generated by applying [operation] from left to right\n * to each element, its index in the original array and current accumulator value that starts with [initial] value.\n * \n * Note that `acc` value passed to [operation] function should not be mutated;\n * otherwise it would affect the previous value in resulting list.\n * \n * @param [operation] function that takes the index of an element, current accumulator value\n * and the element itself, and calculates the next accumulator value.\n * \n * @sample samples.collections.Collections.Aggregates.scan\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic inline fun <R> CharArray.scanIndexed(initial: R, operation: (index: Int, acc: R, Char) -> R): List<R> {\n    return runningFoldIndexed(initial, operation)\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumBy(selector: (T) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumBy(selector: (Byte) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumBy(selector: (Short) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumBy(selector: (Int) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumBy(selector: (Long) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumBy(selector: (Float) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumBy(selector: (Double) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumBy(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumBy(selector: (Char) -> Int): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun <T> Array<out T>.sumByDouble(selector: (T) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ByteArray.sumByDouble(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun ShortArray.sumByDouble(selector: (Short) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun IntArray.sumByDouble(selector: (Int) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun LongArray.sumByDouble(selector: (Long) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun FloatArray.sumByDouble(selector: (Float) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun DoubleArray.sumByDouble(selector: (Double) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun BooleanArray.sumByDouble(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@Deprecated(\"Use sumOf instead.\", ReplaceWith(\"this.sumOf(selector)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\npublic inline fun CharArray.sumByDouble(selector: (Char) -> Double): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfDouble\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Double): Double {\n    var sum: Double = 0.toDouble()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfInt\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Int): Int {\n    var sum: Int = 0.toInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.4\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfLong\")\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> Long): Long {\n    var sum: Long = 0.toLong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfUInt\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> UInt): UInt {\n    var sum: UInt = 0.toUInt()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun <T> Array<out T>.sumOf(selector: (T) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ByteArray.sumOf(selector: (Byte) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun ShortArray.sumOf(selector: (Short) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun IntArray.sumOf(selector: (Int) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun LongArray.sumOf(selector: (Long) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun FloatArray.sumOf(selector: (Float) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun DoubleArray.sumOf(selector: (Double) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun BooleanArray.sumOf(selector: (Boolean) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all values produced by [selector] function applied to each element in the array.\n */\n@SinceKotlin(\"1.5\")\n@OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n@OverloadResolutionByLambdaReturnType\n@kotlin.jvm.JvmName(\"sumOfULong\")\n@WasExperimental(ExperimentalUnsignedTypes::class)\n@kotlin.internal.InlineOnly\npublic inline fun CharArray.sumOf(selector: (Char) -> ULong): ULong {\n    var sum: ULong = 0.toULong()\n    for (element in this) {\n        sum += selector(element)\n    }\n    return sum\n}\n\n/**\n * Returns an original collection containing all the non-`null` elements, throwing an [IllegalArgumentException] if there are any `null` elements.\n */\npublic fun <T : Any> Array<T?>.requireNoNulls(): Array<T> {\n    for (element in this) {\n        if (element == null) {\n            throw IllegalArgumentException(\"null element found in $this.\")\n        }\n    }\n    @Suppress(\"UNCHECKED_CAST\")\n    return this as Array<T>\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun <T> Array<out T>.partition(predicate: (T) -> Boolean): Pair<List<T>, List<T>> {\n    val first = ArrayList<T>()\n    val second = ArrayList<T>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ByteArray.partition(predicate: (Byte) -> Boolean): Pair<List<Byte>, List<Byte>> {\n    val first = ArrayList<Byte>()\n    val second = ArrayList<Byte>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun ShortArray.partition(predicate: (Short) -> Boolean): Pair<List<Short>, List<Short>> {\n    val first = ArrayList<Short>()\n    val second = ArrayList<Short>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun IntArray.partition(predicate: (Int) -> Boolean): Pair<List<Int>, List<Int>> {\n    val first = ArrayList<Int>()\n    val second = ArrayList<Int>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun LongArray.partition(predicate: (Long) -> Boolean): Pair<List<Long>, List<Long>> {\n    val first = ArrayList<Long>()\n    val second = ArrayList<Long>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun FloatArray.partition(predicate: (Float) -> Boolean): Pair<List<Float>, List<Float>> {\n    val first = ArrayList<Float>()\n    val second = ArrayList<Float>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun DoubleArray.partition(predicate: (Double) -> Boolean): Pair<List<Double>, List<Double>> {\n    val first = ArrayList<Double>()\n    val second = ArrayList<Double>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun BooleanArray.partition(predicate: (Boolean) -> Boolean): Pair<List<Boolean>, List<Boolean>> {\n    val first = ArrayList<Boolean>()\n    val second = ArrayList<Boolean>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Splits the original array into pair of lists,\n * where *first* list contains elements for which [predicate] yielded `true`,\n * while *second* list contains elements for which [predicate] yielded `false`.\n * \n * @sample samples.collections.Arrays.Transformations.partitionArrayOfPrimitives\n */\npublic inline fun CharArray.partition(predicate: (Char) -> Boolean): Pair<List<Char>, List<Char>> {\n    val first = ArrayList<Char>()\n    val second = ArrayList<Char>()\n    for (element in this) {\n        if (predicate(element)) {\n            first.add(element)\n        } else {\n            second.add(element)\n        }\n    }\n    return Pair(first, second)\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Array<out R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Array<out R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Array<out R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Array<out R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Array<out R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Array<out R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Array<out R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Array<out R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Array<out R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Array<out R>, transform: (a: T, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Array<out R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Array<out R>, transform: (a: Short, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Array<out R>, transform: (a: Int, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Array<out R>, transform: (a: Long, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Array<out R>, transform: (a: Float, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Array<out R>, transform: (a: Double, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Array<out R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Array<out R>, transform: (a: Char, b: R) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <T, R> Array<out T>.zip(other: Iterable<R>): List<Pair<T, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ByteArray.zip(other: Iterable<R>): List<Pair<Byte, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> ShortArray.zip(other: Iterable<R>): List<Pair<Short, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> IntArray.zip(other: Iterable<R>): List<Pair<Int, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> LongArray.zip(other: Iterable<R>): List<Pair<Long, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> FloatArray.zip(other: Iterable<R>): List<Pair<Float, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> DoubleArray.zip(other: Iterable<R>): List<Pair<Double, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> BooleanArray.zip(other: Iterable<R>): List<Pair<Boolean, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` collection and [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun <R> CharArray.zip(other: Iterable<R>): List<Pair<Char, R>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <T, R, V> Array<out T>.zip(other: Iterable<R>, transform: (a: T, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ByteArray.zip(other: Iterable<R>, transform: (a: Byte, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> ShortArray.zip(other: Iterable<R>, transform: (a: Short, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> IntArray.zip(other: Iterable<R>, transform: (a: Int, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> LongArray.zip(other: Iterable<R>, transform: (a: Long, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> FloatArray.zip(other: Iterable<R>, transform: (a: Float, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> DoubleArray.zip(other: Iterable<R>, transform: (a: Double, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> BooleanArray.zip(other: Iterable<R>, transform: (a: Boolean, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] collection with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <R, V> CharArray.zip(other: Iterable<R>, transform: (a: Char, b: R) -> V): List<V> {\n    val arraySize = size\n    val list = ArrayList<V>(minOf(other.collectionSizeOrDefault(10), arraySize))\n    var i = 0\n    for (element in other) {\n        if (i >= arraySize) break\n        list.add(transform(this[i++], element))\n    }\n    return list\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ByteArray.zip(other: ByteArray): List<Pair<Byte, Byte>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun ShortArray.zip(other: ShortArray): List<Pair<Short, Short>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun IntArray.zip(other: IntArray): List<Pair<Int, Int>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun LongArray.zip(other: LongArray): List<Pair<Long, Long>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun FloatArray.zip(other: FloatArray): List<Pair<Float, Float>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun DoubleArray.zip(other: DoubleArray): List<Pair<Double, Double>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun BooleanArray.zip(other: BooleanArray): List<Pair<Boolean, Boolean>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of pairs built from the elements of `this` array and the [other] array with the same index.\n * The returned list has length of the shortest collection.\n * \n * @sample samples.collections.Iterables.Operations.zipIterable\n */\npublic infix fun CharArray.zip(other: CharArray): List<Pair<Char, Char>> {\n    return zip(other) { t1, t2 -> t1 to t2 }\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ByteArray.zip(other: ByteArray, transform: (a: Byte, b: Byte) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> ShortArray.zip(other: ShortArray, transform: (a: Short, b: Short) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> IntArray.zip(other: IntArray, transform: (a: Int, b: Int) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> LongArray.zip(other: LongArray, transform: (a: Long, b: Long) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> FloatArray.zip(other: FloatArray, transform: (a: Float, b: Float) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> DoubleArray.zip(other: DoubleArray, transform: (a: Double, b: Double) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> BooleanArray.zip(other: BooleanArray, transform: (a: Boolean, b: Boolean) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Returns a list of values built from the elements of `this` array and the [other] array with the same index\n * using the provided [transform] function applied to each pair of elements.\n * The returned list has length of the shortest array.\n * \n * @sample samples.collections.Iterables.Operations.zipIterableWithTransform\n */\npublic inline fun <V> CharArray.zip(other: CharArray, transform: (a: Char, b: Char) -> V): List<V> {\n    val size = minOf(size, other.size)\n    val list = ArrayList<V>(size)\n    for (i in 0 until size) {\n        list.add(transform(this[i], other[i]))\n    }\n    return list\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <T, A : Appendable> Array<out T>.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            buffer.appendElement(element, transform)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ByteArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> ShortArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> IntArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> LongArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> FloatArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> DoubleArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> BooleanArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element.toString())\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Appends the string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinTo\n */\npublic fun <A : Appendable> CharArray.joinTo(buffer: A, separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): A {\n    buffer.append(prefix)\n    var count = 0\n    for (element in this) {\n        if (++count > 1) buffer.append(separator)\n        if (limit < 0 || count <= limit) {\n            if (transform != null)\n                buffer.append(transform(element))\n            else\n                buffer.append(element)\n        } else break\n    }\n    if (limit >= 0 && count > limit) buffer.append(truncated)\n    buffer.append(postfix)\n    return buffer\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun <T> Array<out T>.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((T) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ByteArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Byte) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun ShortArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Short) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun IntArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Int) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun LongArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Long) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun FloatArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Float) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun DoubleArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Double) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun BooleanArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Boolean) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates a string from all the elements separated using [separator] and using the given [prefix] and [postfix] if supplied.\n * \n * If the collection could be huge, you can specify a non-negative value of [limit], in which case only the first [limit]\n * elements will be appended, followed by the [truncated] string (which defaults to \"...\").\n * \n * @sample samples.collections.Collections.Transformations.joinToString\n */\npublic fun CharArray.joinToString(separator: CharSequence = \", \", prefix: CharSequence = \"\", postfix: CharSequence = \"\", limit: Int = -1, truncated: CharSequence = \"...\", transform: ((Char) -> CharSequence)? = null): String {\n    return joinTo(StringBuilder(), separator, prefix, postfix, limit, truncated, transform).toString()\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun <T> Array<out T>.asIterable(): Iterable<T> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ByteArray.asIterable(): Iterable<Byte> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun ShortArray.asIterable(): Iterable<Short> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun IntArray.asIterable(): Iterable<Int> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun LongArray.asIterable(): Iterable<Long> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun FloatArray.asIterable(): Iterable<Float> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun DoubleArray.asIterable(): Iterable<Double> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun BooleanArray.asIterable(): Iterable<Boolean> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates an [Iterable] instance that wraps the original array returning its elements when being iterated.\n */\npublic fun CharArray.asIterable(): Iterable<Char> {\n    if (isEmpty()) return emptyList()\n    return Iterable { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun <T> Array<out T>.asSequence(): Sequence<T> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ByteArray.asSequence(): Sequence<Byte> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun ShortArray.asSequence(): Sequence<Short> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun IntArray.asSequence(): Sequence<Int> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun LongArray.asSequence(): Sequence<Long> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun FloatArray.asSequence(): Sequence<Float> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun DoubleArray.asSequence(): Sequence<Double> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun BooleanArray.asSequence(): Sequence<Boolean> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Creates a [Sequence] instance that wraps the original array returning its elements when being iterated.\n * \n * @sample samples.collections.Sequences.Building.sequenceFromArray\n */\npublic fun CharArray.asSequence(): Sequence<Char> {\n    if (isEmpty()) return emptySequence()\n    return Sequence { this.iterator() }\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfByte\")\npublic fun Array<out Byte>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfShort\")\npublic fun Array<out Short>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfInt\")\npublic fun Array<out Int>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfLong\")\npublic fun Array<out Long>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfFloat\")\npublic fun Array<out Float>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\n@kotlin.jvm.JvmName(\"averageOfDouble\")\npublic fun Array<out Double>.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ByteArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun ShortArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun IntArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun LongArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun FloatArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns an average value of elements in the array.\n */\npublic fun DoubleArray.average(): Double {\n    var sum: Double = 0.0\n    var count: Int = 0\n    for (element in this) {\n        sum += element\n        ++count\n    }\n    return if (count == 0) Double.NaN else sum / count\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfByte\")\npublic fun Array<out Byte>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfShort\")\npublic fun Array<out Short>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfInt\")\npublic fun Array<out Int>.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfLong\")\npublic fun Array<out Long>.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfFloat\")\npublic fun Array<out Float>.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\n@kotlin.jvm.JvmName(\"sumOfDouble\")\npublic fun Array<out Double>.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ByteArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun ShortArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun IntArray.sum(): Int {\n    var sum: Int = 0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun LongArray.sum(): Long {\n    var sum: Long = 0L\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun FloatArray.sum(): Float {\n    var sum: Float = 0.0f\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n/**\n * Returns the sum of all elements in the array.\n */\npublic fun DoubleArray.sum(): Double {\n    var sum: Double = 0.0\n    for (element in this) {\n        sum += element\n    }\n    return sum\n}\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"MapsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\n\nprivate object EmptyMap : Map<Any?, Nothing>, Serializable {\n    private const val serialVersionUID: Long = 8246714829545688274\n\n    override fun equals(other: Any?): Boolean = other is Map<*, *> && other.isEmpty()\n    override fun hashCode(): Int = 0\n    override fun toString(): String = \"{}\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n\n    override fun containsKey(key: Any?): Boolean = false\n    override fun containsValue(value: Nothing): Boolean = false\n    override fun get(key: Any?): Nothing? = null\n    override val entries: Set<Map.Entry<Any?, Nothing>> get() = EmptySet\n    override val keys: Set<Any?> get() = EmptySet\n    override val values: Collection<Nothing> get() = EmptyList\n\n    private fun readResolve(): Any = EmptyMap\n}\n\n/**\n * Returns an empty read-only map of specified type.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\npublic fun <K, V> emptyMap(): Map<K, V> = @Suppress(\"UNCHECKED_CAST\") (EmptyMap as Map<K, V>)\n\n/**\n * Returns a new read-only map with the specified contents, given as a list of pairs\n * where the first value is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * The returned map is serializable (JVM).\n *\n * @sample samples.collections.Maps.Instantiation.mapFromPairs\n */\npublic fun <K, V> mapOf(vararg pairs: Pair<K, V>): Map<K, V> =\n    if (pairs.size > 0) pairs.toMap(LinkedHashMap(mapCapacity(pairs.size))) else emptyMap()\n\n/**\n * Returns an empty read-only map.\n *\n * The returned map is serializable (JVM).\n * @sample samples.collections.Maps.Instantiation.emptyReadOnlyMap\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mapOf(): Map<K, V> = emptyMap()\n\n/**\n * Returns an empty new [MutableMap].\n *\n * The returned map preserves the entry iteration order.\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> mutableMapOf(): MutableMap<K, V> = LinkedHashMap()\n\n/**\n * Returns a new [MutableMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.mutableMapFromPairs\n * @sample samples.collections.Maps.Instantiation.emptyMutableMap\n */\npublic fun <K, V> mutableMapOf(vararg pairs: Pair<K, V>): MutableMap<K, V> =\n    LinkedHashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [HashMap].\n *\n * @sample samples.collections.Maps.Instantiation.emptyHashMap\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> hashMapOf(): HashMap<K, V> = HashMap<K, V>()\n\n/**\n * Returns a new [HashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * @sample samples.collections.Maps.Instantiation.hashMapFromPairs\n */\npublic fun <K, V> hashMapOf(vararg pairs: Pair<K, V>): HashMap<K, V> = HashMap<K, V>(mapCapacity(pairs.size)).apply { putAll(pairs) }\n\n/**\n * Returns an empty new [LinkedHashMap].\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> linkedMapOf(): LinkedHashMap<K, V> = LinkedHashMap<K, V>()\n\n/**\n * Returns a new [LinkedHashMap] with the specified contents, given as a list of pairs\n * where the first component is the key and the second is the value.\n *\n * If multiple pairs have the same key, the resulting map will contain the value from the last of those pairs.\n *\n * Entries of the map are iterated in the order they were specified.\n *\n * @sample samples.collections.Maps.Instantiation.linkedMapFromPairs\n */\npublic fun <K, V> linkedMapOf(vararg pairs: Pair<K, V>): LinkedHashMap<K, V> = pairs.toMap(LinkedHashMap(mapCapacity(pairs.size)))\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(@BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Builds a new read-only [Map] by populating a [MutableMap] using the given [builderAction]\n * and returning a read-only map with the same key-value pairs.\n *\n * The map passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of pairs added in the [builderAction].\n *\n * Entries of the map are iterated in the order they were added by the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Maps.buildMapSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> buildMap(capacity: Int, @BuilderInference builderAction: MutableMap<K, V>.() -> Unit): Map<K, V> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildMapInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <K, V> buildMapInternal(capacity: Int, builderAction: MutableMap<K, V>.() -> Unit): Map<K, V>\n\n/**\n * Calculate the initial capacity of a map.\n */\n@PublishedApi\ninternal expect fun mapCapacity(expectedSize: Int): Int\n\n/**\n * Returns `true` if this map is not empty.\n * @sample samples.collections.Maps.Usage.mapIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable map is either null or empty.\n * @sample samples.collections.Maps.Usage.mapIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<out K, V>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || isEmpty()\n}\n\n/**\n * Returns the [Map] if its not `null`, or the empty [Map] otherwise.\n *\n * @sample samples.collections.Maps.Usage.mapOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>?.orEmpty(): Map<K, V> = this ?: emptyMap()\n\n/**\n * Returns this map if it's not empty\n * or the result of calling [defaultValue] function if the map is empty.\n *\n * @sample samples.collections.Maps.Usage.mapIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <M, R> M.ifEmpty(defaultValue: () -> R): R where M : Map<*, *>, M : R =\n    if (isEmpty()) defaultValue() else this\n\n/**\n * Checks if the map contains the given key.\n *\n * This method allows to use the `x in map` syntax for checking whether an object is contained in the map.\n *\n * @sample samples.collections.Maps.Usage.containsKey\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.contains(key: K): Boolean = containsKey(key)\n\n/**\n * Returns the value corresponding to the given [key], or `null` if such a key is not present in the map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <@kotlin.internal.OnlyInputTypes K, V> Map<out K, V>.get(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, V>).get(key)\n\n/**\n * Allows to use the index operator for storing values in a mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.set(key: K, value: V): Unit {\n    put(key, value)\n}\n\n/**\n * Returns `true` if the map contains the specified [key].\n *\n * Allows to overcome type-safety restriction of `containsKey` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K> Map<out K, *>.containsKey(key: K): Boolean =\n    @Suppress(\"UNCHECKED_CAST\") (this as Map<K, *>).containsKey(key)\n\n/**\n * Returns `true` if the map maps one or more keys to the specified [value].\n *\n * Allows to overcome type-safety restriction of `containsValue` that requires to pass a value of type `V`.\n *\n * @sample samples.collections.Maps.Usage.containsValue\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <K, @kotlin.internal.OnlyInputTypes V> Map<K, V>.containsValue(value: V): Boolean = this.containsValue(value)\n\n\n/**\n * Removes the specified key and its corresponding value from this map.\n *\n * @return the previous value associated with the key, or `null` if the key was not present in the map.\n\n * Allows to overcome type-safety restriction of `remove` that requires to pass a key of type `K`.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes K, V> MutableMap<out K, V>.remove(key: K): V? =\n    @Suppress(\"UNCHECKED_CAST\") (this as MutableMap<K, V>).remove(key)\n\n/**\n * Returns the key component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component1(): K = key\n\n/**\n * Returns the value component of the map entry.\n *\n * This method allows to use destructuring declarations when working with maps, for example:\n * ```\n * for ((key, value) in map) {\n *     // do something with the key and the value\n * }\n * ```\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map.Entry<K, V>.component2(): V = value\n\n/**\n * Converts entry to [Pair] with key being first component and value being second.\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map.Entry<K, V>.toPair(): Pair<K, V> = Pair(key, value)\n\n/**\n * Returns the value for the given key, or the result of the [defaultValue] function if there was no entry for the given key.\n *\n * @sample samples.collections.Maps.Usage.getOrElse\n */\n@kotlin.internal.InlineOnly\npublic inline fun <K, V> Map<K, V>.getOrElse(key: K, defaultValue: () -> V): V = get(key) ?: defaultValue()\n\n\ninternal inline fun <K, V> Map<K, V>.getOrElseNullable(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    if (value == null && !containsKey(key)) {\n        return defaultValue()\n    } else {\n        @Suppress(\"UNCHECKED_CAST\")\n        return value as V\n    }\n}\n\n/**\n * Returns the value for the given [key] or throws an exception if there is no such key in the map.\n *\n * If the map was created by [withDefault], resorts to its `defaultValue` provider function\n * instead of throwing an exception.\n *\n * @throws NoSuchElementException when the map doesn't contain a value for the specified key and\n * no implicit default value was provided for that map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<K, V>.getValue(key: K): V = getOrImplicitDefault(key)\n\n/**\n * Returns the value for the given key. If the key is not found in the map, calls the [defaultValue] function,\n * puts its result into the map under the given key and returns it.\n *\n * Note that the operation is not guaranteed to be atomic if the map is being modified concurrently.\n *\n * @sample samples.collections.Maps.Usage.getOrPut\n */\npublic inline fun <K, V> MutableMap<K, V>.getOrPut(key: K, defaultValue: () -> V): V {\n    val value = get(key)\n    return if (value == null) {\n        val answer = defaultValue()\n        put(key, answer)\n        answer\n    } else {\n        value\n    }\n}\n\n/**\n * Returns an [Iterator] over the entries in the [Map].\n *\n * @sample samples.collections.Maps.Usage.forOverEntries\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> Map<out K, V>.iterator(): Iterator<Map.Entry<K, V>> = entries.iterator()\n\n/**\n * Returns a [MutableIterator] over the mutable entries in the [MutableMap].\n *\n */\n@kotlin.jvm.JvmName(\"mutableIterator\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.iterator(): MutableIterator<MutableMap.MutableEntry<K, V>> = entries.iterator()\n\n/**\n * Populates the given [destination] map with entries having the keys of this map and the values obtained\n * by applying the [transform] function to each entry in this [Map].\n */\npublic inline fun <K, V, R, M : MutableMap<in K, in R>> Map<out K, V>.mapValuesTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, { it.key }, transform)\n}\n\n/**\n * Populates the given [destination] map with entries having the keys obtained\n * by applying the [transform] function to each entry in this [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n */\npublic inline fun <K, V, R, M : MutableMap<in R, in V>> Map<out K, V>.mapKeysTo(destination: M, transform: (Map.Entry<K, V>) -> R): M {\n    return entries.associateByTo(destination, transform, { it.value })\n}\n\n/**\n * Puts all the given [pairs] into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Array<out Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given collection into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Iterable<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Puts all the elements of the given sequence into this [MutableMap] with the first component in the pair being the key and the second the value.\n */\npublic fun <K, V> MutableMap<in K, in V>.putAll(pairs: Sequence<Pair<K, V>>): Unit {\n    for ((key, value) in pairs) {\n        put(key, value)\n    }\n}\n\n/**\n * Returns a new map with entries having the keys of this map and the values obtained by applying the [transform]\n * function to each entry in this [Map].\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapValues\n */\npublic inline fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R> {\n    return mapValuesTo(LinkedHashMap<K, R>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a new Map with entries having the keys obtained by applying the [transform] function to each entry in this\n * [Map] and the values of this map.\n *\n * In case if any two entries are mapped to the equal keys, the value of the latter one will overwrite\n * the value associated with the former one.\n *\n * The returned map preserves the entry iteration order of the original map.\n *\n * @sample samples.collections.Maps.Transformations.mapKeys\n */\npublic inline fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V> {\n    return mapKeysTo(LinkedHashMap<R, V>(mapCapacity(size)), transform) // .optimizeReadOnlyMap()\n}\n\n/**\n * Returns a map containing all key-value pairs with keys matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterKeys\n */\npublic inline fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.key)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n/**\n * Returns a map containing all key-value pairs with values matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n *  @sample samples.collections.Maps.Filtering.filterValues\n */\npublic inline fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V> {\n    val result = LinkedHashMap<K, V>()\n    for (entry in this) {\n        if (predicate(entry.value)) {\n            result.put(entry.key, entry.value)\n        }\n    }\n    return result\n}\n\n\n/**\n * Appends all entries matching the given [predicate] into the mutable map given as [destination] parameter.\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filter\n */\npublic inline fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Appends all entries not matching the given [predicate] into the given [destination].\n *\n * @return the destination map.\n * @sample samples.collections.Maps.Filtering.filterNotTo\n */\npublic inline fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.filterNotTo(destination: M, predicate: (Map.Entry<K, V>) -> Boolean): M {\n    for (element in this) {\n        if (!predicate(element)) {\n            destination.put(element.key, element.value)\n        }\n    }\n    return destination\n}\n\n/**\n * Returns a new map containing all key-value pairs not matching the given [predicate].\n *\n * The returned map preserves the entry iteration order of the original map.\n * @sample samples.collections.Maps.Filtering.filterNot\n */\npublic inline fun <K, V> Map<out K, V>.filterNot(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V> {\n    return filterNotTo(LinkedHashMap<K, V>(), predicate)\n}\n\n/**\n * Returns a new map containing all key-value pairs from the given collection of pairs.\n *\n * The returned map preserves the entry iteration order of the original collection.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Iterable<Pair<K, V>>.toMap(): Map<K, V> {\n    if (this is Collection) {\n        return when (size) {\n            0 -> emptyMap()\n            1 -> mapOf(if (this is List) this[0] else iterator().next())\n            else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n        }\n    }\n    return toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n}\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given collection of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Iterable<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given array of pairs.\n *\n * The returned map preserves the entry iteration order of the original array.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Array<out Pair<K, V>>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> mapOf(this[0])\n    else -> toMap(LinkedHashMap<K, V>(mapCapacity(size)))\n}\n\n/**\n *  Populates and returns the [destination] mutable map with key-value pairs from the given array of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Array<out Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new map containing all key-value pairs from the given sequence of pairs.\n *\n * The returned map preserves the entry iteration order of the original sequence.\n * If any of two pairs would have the same key the last one gets added to the map.\n */\npublic fun <K, V> Sequence<Pair<K, V>>.toMap(): Map<K, V> = toMap(LinkedHashMap<K, V>()).optimizeReadOnlyMap()\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given sequence of pairs.\n */\npublic fun <K, V, M : MutableMap<in K, in V>> Sequence<Pair<K, V>>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Returns a new read-only map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMap(): Map<K, V> = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMap()\n    else -> toMutableMap()\n}\n\n/**\n * Returns a new mutable map containing all key-value pairs from the original map.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V> Map<out K, V>.toMutableMap(): MutableMap<K, V> = LinkedHashMap(this)\n\n/**\n * Populates and returns the [destination] mutable map with key-value pairs from the given map.\n */\n@SinceKotlin(\"1.1\")\npublic fun <K, V, M : MutableMap<in K, in V>> Map<out K, V>.toMap(destination: M): M =\n    destination.apply { putAll(this@toMap) }\n\n/**\n * Creates a new read-only map by replacing or adding an entry to this map from a given key-value [pair].\n *\n * The returned map preserves the entry iteration order of the original map.\n * The [pair] is iterated in the end if it has a unique key.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V> =\n    if (this.isEmpty()) mapOf(pair) else LinkedHashMap(this).apply { put(pair.first, pair.second) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given collection of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] collection.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Iterable<Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given array of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] array.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Array<out Pair<K, V>>): Map<K, V> =\n    if (this.isEmpty()) pairs.toMap() else LinkedHashMap(this).apply { putAll(pairs) }\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from a given sequence of key-value [pairs].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those [pairs] with unique keys are iterated in the end in the order of [pairs] sequence.\n */\npublic operator fun <K, V> Map<out K, V>.plus(pairs: Sequence<Pair<K, V>>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(pairs) }.optimizeReadOnlyMap()\n\n/**\n * Creates a new read-only map by replacing or adding entries to this map from another [map].\n *\n * The returned map preserves the entry iteration order of the original map.\n * Those entries of another [map] that are missing in this map are iterated in the end in the order of that [map].\n */\npublic operator fun <K, V> Map<out K, V>.plus(map: Map<out K, V>): Map<K, V> =\n    LinkedHashMap(this).apply { putAll(map) }\n\n\n/**\n * Appends or replaces the given [pair] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pair: Pair<K, V>) {\n    put(pair.first, pair.second)\n}\n\n/**\n * Appends or replaces all pairs from the given collection of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Iterable<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given array of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Array<out Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all pairs from the given sequence of [pairs] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(pairs: Sequence<Pair<K, V>>) {\n    putAll(pairs)\n}\n\n/**\n * Appends or replaces all entries from the given [map] in this mutable map.\n */\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<in K, in V>.plusAssign(map: Map<K, V>) {\n    putAll(map)\n}\n\n/**\n * Returns a map containing all entries of the original map except the entry with the given [key].\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(key) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] collection.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Iterable<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] array.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Array<out K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Returns a map containing all entries of the original map except those entries\n * the keys of which are contained in the given [keys] sequence.\n *\n * The returned map preserves the entry iteration order of the original map.\n */\n@SinceKotlin(\"1.1\")\npublic operator fun <K, V> Map<out K, V>.minus(keys: Sequence<K>): Map<K, V> =\n    this.toMutableMap().apply { minusAssign(keys) }.optimizeReadOnlyMap()\n\n/**\n * Removes the entry with the given [key] from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(key: K) {\n    remove(key)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] collection from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Iterable<K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries the keys of which are contained in the given [keys] array from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Array<out K>) {\n    this.keys.removeAll(keys)\n}\n\n/**\n * Removes all entries from the keys of which are contained in the given [keys] sequence from this mutable map.\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline operator fun <K, V> MutableMap<K, V>.minusAssign(keys: Sequence<K>) {\n    this.keys.removeAll(keys)\n}\n\n\n// do not expose for now @PublishedApi\ninternal fun <K, V> Map<K, V>.optimizeReadOnlyMap() = when (size) {\n    0 -> emptyMap()\n    1 -> toSingletonMapOrSelf()\n    else -> this\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.color\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Ordering.Companion.natural\nimport kotlin.math.ceil\nimport kotlin.math.floor\nimport kotlin.math.max\nimport kotlin.math.min\n\nclass RGBChannelGen(private val myBaseValues: List<Int>) {\n    private var myRange: ClosedRange<Int>? = null\n\n    init {\n        val min = natural<Int>().min(myBaseValues)\n        val max = natural<Int>().max(myBaseValues)\n        for (r in RANGES) {\n            if (r.contains(min) || r.contains(max)) {\n                if (myRange == null) {\n                    myRange = r\n                } else {\n                    myRange = myRange!!.span(r)\n                }\n            }\n        }\n    }\n\n    /**\n     * @param maxCount - count of new values required\n     * @return List of generated value, size may be different than maxCount\n     */\n    fun generate(maxCount: Int): List<Int> {\n        var genPerBaseValue = ceil(maxCount.toDouble() / myBaseValues.size).toInt()\n        genPerBaseValue = min(maxValueCount() - 1, genPerBaseValue)\n\n        var inc = floor(maxValueCount().toDouble() / (genPerBaseValue + 1)).toInt()\n        // make increment a bit less regular\n        inc = max(1, (inc * 1.33).toInt())\n\n        val values = ArrayList<Int>(maxCount)\n        var baseValues = myBaseValues\n        while (values.size < maxCount) {\n            val nextBaseValues = ArrayList<Int>()\n            for (baseValue in baseValues) {\n                var genValue = baseValue + inc\n                if (!myRange!!.contains(genValue)) {\n                    genValue = myRange!!.lowerEnd + (genValue - myRange!!.upperEnd)\n                }\n                values.add(genValue)\n                nextBaseValues.add(genValue)\n                if (values.size == maxCount) {\n                    break\n                }\n            }\n\n            baseValues = nextBaseValues\n        }\n\n        return values\n    }\n\n    private fun maxValueCount(): Int {\n        return myRange!!.upperEnd - myRange!!.lowerEnd + 1\n    }\n\n    companion object {\n        private val RANGES = arrayOf(\n                ClosedRange(0, 37),\n                ClosedRange(38, 97),\n                ClosedRange(98, 157),\n                ClosedRange(158, 217),\n                ClosedRange(218, 255)\n        )\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nenum class DataType {\n    NUMBER,\n    STRING,\n    INSTANT,\n\n    /**\n     * INSTANT_OF_DAY and INSTANT_OF_MONTH are INSTANTS formatted as year-month-day or year-month\n     */\n    INSTANT_OF_DAY,\n    INSTANT_OF_MONTH,\n    INSTANT_OF_QUARTER,\n    INSTANT_OF_HALF_YEAR,\n    INSTANT_OF_YEAR;\n\n\n    val isTime: Boolean\n        get() = this == INSTANT || isTimeInterval\n\n    val isTimeInterval: Boolean\n        get() = (this == INSTANT_OF_DAY\n                || this == INSTANT_OF_MONTH\n                || this == INSTANT_OF_QUARTER\n                || this == INSTANT_OF_HALF_YEAR\n                || this == INSTANT_OF_YEAR)\n\n    val isString: Boolean\n        get() = this == STRING\n\n    val isNumber: Boolean\n        get() = this == NUMBER\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.plot.common.data.SeriesUtil.isFinite\nimport kotlin.math.abs\n\nabstract class RegularMeshDetector protected constructor(private val myError: Double) {\n    open var isMesh: Boolean = false\n        protected set\n    var resolution: Double = 0.toDouble()\n        get() {\n            check(isMesh) { \"Not a mesh\" }\n            return field\n        }\n        protected set\n\n    protected fun equalsEnough(d1: Double, d2: Double): Boolean {\n        return d1 == d2 || abs(d1 - d2) <= myError\n    }\n\n    protected fun nearZero(d: Double): Boolean {\n        return abs(d) <= myError\n    }\n\n\n    private class MyRowDetector internal constructor(\n        private val myMinRowSize: Int,\n        error: Double,\n        values: Iterable<Double?>\n    ) : RegularMeshDetector(error) {\n\n        init {\n            init(values)\n        }\n\n        private fun init(values: Iterable<Double?>) {\n            // check if first N elements are equally spaced\n            isMesh = false\n            var distance = 0.0\n            var distanceInitialized = false\n            var prevValue: Double? = null\n            var count = myMinRowSize\n            for (value in values) {\n                if (!isFinite(value)) {\n                    return\n                }\n                if (prevValue != null) {\n                    val dist = value!! - prevValue\n                    if (nearZero(dist)) {\n                        return\n                    }\n                    if (distanceInitialized) {\n                        if (!equalsEnough(dist, distance)) {\n                            return\n                        }\n                    } else {\n                        distance = dist\n                        distanceInitialized = true\n                    }\n                }\n\n                prevValue = value\n                if (--count == 0) {\n                    break\n                }\n            }\n\n            if (distanceInitialized && count == 0) {\n                resolution = abs(distance)\n                isMesh = true\n            }\n        }\n    }\n\n    private class MyColumnDetector internal constructor(\n        private val myMinRowSize: Int,\n        error: Double,\n        values: Iterable<Double?>\n    ) : RegularMeshDetector(error) {\n\n        init {\n            init(values)\n        }\n\n        private fun init(values: Iterable<Double?>) {\n            // check if there are at least 2 sets of elements where:\n            // 1. sets are equal in size;\n            // 2. all elements in each set are equal\n            isMesh = false\n            val rowSize = intArrayOf(0, 0)\n            val rowValue = arrayOf<Double?>(null, null)\n            var rowIndex = 0\n            for (value in values) {\n                if (!isFinite(value)) {\n                    break\n                }\n                if (rowValue[rowIndex] == null) {\n                    rowValue[rowIndex] = value\n                    rowSize[rowIndex]++\n                } else if (equalsEnough(rowValue[rowIndex]!!, value!!)) {\n                    rowSize[rowIndex]++\n                } else {\n                    if (rowIndex == 0) {\n                        rowIndex++ // next row\n                        rowValue[rowIndex] = value\n                        rowSize[rowIndex]++\n                    } else {\n                        break\n                    }\n                }\n            }\n\n            // check results\n            if (rowSize[0] == rowSize[1] && rowSize[0] >= myMinRowSize) {\n                isMesh = true\n                resolution = abs(rowValue[1]!! - rowValue[0]!!)\n            }\n        }\n    }\n\n    companion object {\n        private val NO_MESH: RegularMeshDetector = object : RegularMeshDetector(0.0) {\n            override var isMesh: Boolean\n                get() = false\n                set(value: Boolean) {\n                    super.isMesh = value\n                }\n        }\n\n        fun tryRow(values: Iterable<Double?>): RegularMeshDetector {\n            // choose 'error' value\n            val v0 = Iterables[values, 0, null]\n            val v1 = Iterables[values, 1, null]\n            if (v0 == null || v1 == null) {\n                return NO_MESH\n            }\n            val delta = abs(v1 - v0)\n            if (!delta.isFinite()) {\n                return NO_MESH\n            }\n            val error = delta / 10000.0\n            return tryRow(50, error, values)\n        }\n\n        fun tryRow(minRowSize: Int, error: Double, values: Iterable<Double?>): RegularMeshDetector {\n            return MyRowDetector(minRowSize, error, values)\n        }\n\n        fun tryColumn(values: Iterable<Double?>): RegularMeshDetector {\n            return tryColumn(\n                50,\n                SeriesUtil.TINY,\n                values\n            )\n        }\n\n        fun tryColumn(minRowSize: Int, error: Double, values: Iterable<Double?>): RegularMeshDetector {\n            return MyColumnDetector(minRowSize, error, values)\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.data\n\nimport jetbrains.datalore.base.gcommon.collect.ClosedRange\nimport jetbrains.datalore.base.gcommon.collect.Iterables\nimport jetbrains.datalore.base.gcommon.collect.Iterables.all\nimport jetbrains.datalore.base.gcommon.collect.Iterables.filter\nimport jetbrains.datalore.base.gcommon.collect.Ordering\nimport kotlin.math.max\nimport kotlin.math.min\n\n\nobject SeriesUtil {\n    const val TINY = 1e-50\n\n    private val REAL_NUMBER = { it: Double? -> isFinite(it) }\n\n    val NEGATIVE_NUMBER = { input: Double -> input < 0 }\n\n    fun isSubTiny(value: Double): Boolean {\n        return value < TINY\n    }\n\n    fun isSubTiny(range: ClosedRange<Double>): Boolean {\n        return isFinite(range) && span(range) < TINY\n    }\n\n    fun checkedDoubles(values: Iterable<*>): CheckedDoubleIterable {\n        return CheckedDoubleIterable(values)\n    }\n\n    fun checkedDoubles(values: List<*>): CheckedDoubleList {\n        return CheckedDoubleList(values)\n    }\n\n    fun isFinite(v: Double?): Boolean {\n        return v != null && v.isFinite()\n    }\n\n    fun asFinite(v: Double?, defaultValue: Double): Double {\n        return if (v != null && v.isFinite())\n            v\n        else\n            defaultValue\n    }\n\n    fun isFinite(v: Double): Boolean {\n        return v.isFinite()\n    }\n\n    fun allFinite(v0: Double?, v1: Double?): Boolean {\n        return isFinite(v0) && isFinite(v1)\n    }\n\n    fun allFinite(v0: Double?, v1: Double?, v2: Double?): Boolean {\n        return allFinite(\n            v0,\n            v1\n        ) && isFinite(v2)\n    }\n\n    fun allFinite(v0: Double?, v1: Double?, v2: Double?, v3: Double?): Boolean {\n        return allFinite(\n            v0,\n            v1,\n            v2\n        ) && isFinite(v3)\n    }\n\n    fun filterFinite(l0: List<Double?>, l1: List<Double?>): List<List<Double>> {\n        check(l0.size == l1.size)\n\n        val l0Copy = ArrayList<Double>()\n        val l1Copy = ArrayList<Double>()\n        var copy = false\n        for ((i, v0) in l0.withIndex()) {\n            val v1 = l1[i]\n            if (!allFinite(v0, v1)) {\n                if (!copy) {\n                    // copy already checked elements\n                    @Suppress(\"UNCHECKED_CAST\")\n                    l0Copy.addAll(l0.take(i).toList() as List<Double>)\n                    @Suppress(\"UNCHECKED_CAST\")\n                    l1Copy.addAll(l1.take(i).toList() as List<Double>)\n                    copy = true\n                }\n                continue\n            }\n\n            if (copy) {\n                l0Copy.add(v0 as Double)\n                l1Copy.add(v1 as Double)\n            }\n        }\n\n        @Suppress(\"UNCHECKED_CAST\")\n        return when (copy) {\n            true -> listOf(l0Copy, l1Copy)\n            false -> listOf(l0 as List<Double>, l1 as List<Double>)\n        }\n    }\n\n    fun range(values: Iterable<Double?>): ClosedRange<Double>? {\n        var min = 0.0\n        var max = 0.0\n        var inited = false\n        for (v in values) {\n            if (isFinite(v)) {\n                if (inited) {\n                    min = min(min, v!!)\n                    max = max(max, v)\n                } else {\n                    max = v!!\n                    min = max\n                    inited = true\n                }\n            }\n        }\n        return if (inited)\n            ClosedRange(min, max)\n        else\n            null\n    }\n\n    fun resolution(values: Iterable<Double?>, naValue: Double): Double {\n\n        // check if this is a row of a regular grid\n        val rowDetector = RegularMeshDetector.tryRow(values)\n        if (rowDetector.isMesh) {\n            return rowDetector.resolution\n        }\n\n        // check if this is a column of a regular grid\n        val columnDetector = RegularMeshDetector.tryColumn(values)\n        return if (columnDetector.isMesh) {\n            columnDetector.resolution\n        } else {\n            // use brut force method to find data resolution\n            resolutionFullScan(values, naValue)\n        }\n    }\n\n    private fun resolutionFullScan(values: Iterable<Double?>, naValue: Double): Double {\n        @Suppress(\"UNCHECKED_CAST\")\n        val goodDataVector = filter(values, REAL_NUMBER) as Iterable<Double>\n        if (Iterables.isEmpty(goodDataVector)) {\n            return naValue\n        }\n\n        val copy = Ordering.natural<Double>().sortedCopy(goodDataVector)\n        if (copy.size < 2) {\n            return naValue\n        }\n\n        val it = copy.iterator()\n        var resolution = naValue\n        var allZero = true\n        var prev = it.next()\n        while (it.hasNext()) {\n            val curr = it.next()\n            val dist = curr - prev\n            if (dist > 0 && (dist < resolution || allZero)) {\n                allZero = false\n                resolution = dist\n            }\n\n            prev = curr\n        }\n\n        return resolution\n    }\n\n    /**\n     * ToDo: Use with caution.\n     * ToDo: The correct method of domain validation is temporarily in 'Transforms.ensureApplicableDomain'.\n     */\n    fun ensureApplicableRange(range: ClosedRange<Double>?): ClosedRange<Double> {\n        if (range == null) {\n            return ClosedRange(-0.5, 0.5)\n        }\n        if (isSubTiny(range)) {\n            val median = range.lowerEnd\n            return ClosedRange(median - 0.5, median + 0.5)\n        }\n        return range\n    }\n\n    fun span(range: ClosedRange<Double>): Double {\n        require(isFinite(range)) { \"range must be finite: $range\" }\n        return range.upperEnd - range.lowerEnd\n    }\n\n    fun span(range0: ClosedRange<Double>?, range1: ClosedRange<Double>?): ClosedRange<Double>? {\n        if (range0 == null) return range1\n        return if (range1 == null) range0 else range0.span(range1)\n    }\n\n    fun expand(range: ClosedRange<Double>, newSpan: Double): ClosedRange<Double> {\n        val expand = (newSpan - span(range)) / 2\n        return expand(range, expand, expand)\n    }\n\n    fun expand(range: ClosedRange<Double>, lowerExpand: Double, upperExpand: Double): ClosedRange<Double> {\n        return ClosedRange(range.lowerEnd - lowerExpand, range.upperEnd + upperExpand)\n    }\n\n    fun isFinite(range: ClosedRange<Double>): Boolean {\n        return !(range.lowerEnd.isInfinite() || range.upperEnd.isInfinite())\n    }\n\n    fun matchingIndices(list: List<*>, matchedValue: Any?): MutableList<Int> {\n        val result = ArrayList<Int>()\n        for (i in list.indices) {\n            if (matchedValue == list[i]) {\n                result.add(i)\n            }\n        }\n        return result\n    }\n\n    fun matchingIndices(list: List<*>, matchedValues: Set<*>): List<Int> {\n        val result = ArrayList<Int>()\n        for (i in list.indices) {\n            if (matchedValues.contains(list[i])) {\n                result.add(i)\n            }\n        }\n        return result\n    }\n\n    fun <T> pickAtIndices(list: List<T>, indices: List<Int>): List<T> {\n        val initialCapacity = if (indices.size > 10) indices.size else 10\n        val result = ArrayList<T>(initialCapacity)\n        for (index in indices) {\n            if (index < list.size) {\n                result.add(list[index])\n            }\n        }\n        return result\n    }\n\n    fun <T> pickAtIndices(list: List<T>, indices: Set<Int>): List<T> {\n        val result = ArrayList<T>(list.size)\n        for (i in list.indices) {\n            if (indices.contains(i)) {\n                result.add(list[i])\n            }\n        }\n        return result\n    }\n\n    fun <T> skipAtIndices(list: List<T>, indices: Set<Int>): List<T> {\n        val result = ArrayList<T>(list.size)\n        for (i in list.indices) {\n            if (!indices.contains(i)) {\n                result.add(list[i])\n            }\n        }\n        return result\n    }\n\n    fun <T> firstNotNull(list: List<T>, defaultValue: T): T {\n        for (v in list) {\n            if (v != null) {\n                return v\n            }\n        }\n        return defaultValue\n    }\n\n    fun mean(values: List<Double?>, defaultValue: Double?): Double? {\n        var result = 0.0\n        var i = -1.0\n        for (value in values) {\n            if (value != null && value.isFinite()) {\n                i++\n                result = value / (i + 1) + result * (i / (i + 1))\n            }\n        }\n        return if (i >= 0) result else defaultValue\n    }\n\n    fun sum(values: List<Double?>): Double {\n        var result = 0.0\n        for (value in values) {\n            if (value != null && value.isFinite()) {\n                result += value\n            }\n        }\n        return result\n    }\n\n    fun toDoubleList(l: List<*>?): List<Double?>? {\n        return if (l == null)\n            null\n        else\n            CheckedDoubleList(l).cast()\n    }\n\n    class CheckedDoubleList(list: List<*>) : CheckedDoubleIterable(list) {\n\n        override fun cast(): List<Double?> {\n            return super.cast() as List<Double?>\n        }\n    }\n\n    open class CheckedDoubleIterable(private val myIterable: Iterable<*>) {\n        private val myEmpty: Boolean = Iterables.isEmpty(myIterable)\n        private val myCanBeCast: Boolean\n\n        init {\n            myCanBeCast = if (myEmpty) {\n                true\n            } else {\n                all(filter(myIterable) { it != null }) { input -> input is Double }\n            }\n        }\n\n        fun notEmptyAndCanBeCast(): Boolean {\n            return !myEmpty && myCanBeCast\n        }\n\n        fun canBeCast(): Boolean {\n            return myCanBeCast\n        }\n\n        open fun cast(): Iterable<Double?> {\n            check(myCanBeCast) { \"Can't cast to a collection of Double(s)\" }\n            // Safe cast: all values were checked\n            @Suppress(\"UNCHECKED_CAST\")\n            return myIterable as Iterable<Double?>\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.gcommon.collect.Stack\nimport jetbrains.datalore.base.geometry.DoubleSegment\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier.RankingStrategy\n\ninternal class DouglasPeuckerSimplification : RankingStrategy {\n    private val myEpsilon = Double.MIN_VALUE\n\n    private fun calculateWeights(points: List<DoubleVector>): List<Double> {\n        val stack = Stack<Pair<Int, Int>>()\n\n        val weights = MutableList(points.size) { Double.NaN }\n        weights[0] = Double.MAX_VALUE\n        weights[points.size - 1] = Double.MAX_VALUE\n        stack.push(Pair(0, points.size - 1))\n\n        while (!stack.empty()) {\n            val startIndex = stack.peek()!!.first\n            val endIndex = stack.peek()!!.second\n            stack.pop()\n\n            var dMax = 0.0\n            var index = startIndex\n            val doubleSegment = DoubleSegment(points[startIndex], points[endIndex])\n            val distance: (DoubleVector) -> Double\n\n            if (doubleSegment.length() == 0.0) {\n                distance = { p -> DoubleSegment(points[startIndex], p).length() }\n            } else {\n                distance = { doubleSegment.distance(it) }\n            }\n\n            var i = startIndex + 1\n            while (i < endIndex) {\n                val d = distance(points[i])\n                if (d > dMax) {\n                    index = i\n                    dMax = d\n                }\n                ++i\n            }\n\n            if (dMax >= myEpsilon) {\n                stack.push(Pair(startIndex, index))\n                stack.push(Pair(index, endIndex))\n                weights[index] = dMax\n            }\n        }\n\n        return weights\n    }\n\n    override fun getWeights(points: List<DoubleVector>): List<Double> {\n        return calculateWeights(points)\n    }\n}\n","/*\n * Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"CollectionsKt\")\n@file:OptIn(kotlin.experimental.ExperimentalTypeInference::class)\n\npackage kotlin.collections\n\nimport kotlin.contracts.*\nimport kotlin.random.Random\n\ninternal object EmptyIterator : ListIterator<Nothing> {\n    override fun hasNext(): Boolean = false\n    override fun hasPrevious(): Boolean = false\n    override fun nextIndex(): Int = 0\n    override fun previousIndex(): Int = -1\n    override fun next(): Nothing = throw NoSuchElementException()\n    override fun previous(): Nothing = throw NoSuchElementException()\n}\n\ninternal object EmptyList : List<Nothing>, Serializable, RandomAccess {\n    private const val serialVersionUID: Long = -7390468764508069838L\n\n    override fun equals(other: Any?): Boolean = other is List<*> && other.isEmpty()\n    override fun hashCode(): Int = 1\n    override fun toString(): String = \"[]\"\n\n    override val size: Int get() = 0\n    override fun isEmpty(): Boolean = true\n    override fun contains(element: Nothing): Boolean = false\n    override fun containsAll(elements: Collection<Nothing>): Boolean = elements.isEmpty()\n\n    override fun get(index: Int): Nothing = throw IndexOutOfBoundsException(\"Empty list doesn't contain element at index $index.\")\n    override fun indexOf(element: Nothing): Int = -1\n    override fun lastIndexOf(element: Nothing): Int = -1\n\n    override fun iterator(): Iterator<Nothing> = EmptyIterator\n    override fun listIterator(): ListIterator<Nothing> = EmptyIterator\n    override fun listIterator(index: Int): ListIterator<Nothing> {\n        if (index != 0) throw IndexOutOfBoundsException(\"Index: $index\")\n        return EmptyIterator\n    }\n\n    override fun subList(fromIndex: Int, toIndex: Int): List<Nothing> {\n        if (fromIndex == 0 && toIndex == 0) return this\n        throw IndexOutOfBoundsException(\"fromIndex: $fromIndex, toIndex: $toIndex\")\n    }\n\n    private fun readResolve(): Any = EmptyList\n}\n\ninternal fun <T> Array<out T>.asCollection(): Collection<T> = ArrayAsCollection(this, isVarargs = false)\n\nprivate class ArrayAsCollection<T>(val values: Array<out T>, val isVarargs: Boolean) : Collection<T> {\n    override val size: Int get() = values.size\n    override fun isEmpty(): Boolean = values.isEmpty()\n    override fun contains(element: T): Boolean = values.contains(element)\n    override fun containsAll(elements: Collection<T>): Boolean = elements.all { contains(it) }\n    override fun iterator(): Iterator<T> = values.iterator()\n    // override hidden toArray implementation to prevent copying of values array\n    public fun toArray(): Array<out Any?> = values.copyToArrayOfAny(isVarargs)\n}\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\npublic fun <T> emptyList(): List<T> = EmptyList\n\n/**\n * Returns a new read-only list of given elements.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.readOnlyList\n */\npublic fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()\n\n/**\n * Returns an empty read-only list.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.emptyReadOnlyList\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> listOf(): List<T> = emptyList()\n\n/**\n * Returns an empty new [MutableList].\n * @sample samples.collections.Collections.Lists.emptyMutableList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> mutableListOf(): MutableList<T> = ArrayList()\n\n/**\n * Returns an empty new [ArrayList].\n * @sample samples.collections.Collections.Lists.emptyArrayList\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()\n\n/**\n * Returns a new [MutableList] with the given elements.\n * @sample samples.collections.Collections.Lists.mutableList\n */\npublic fun <T> mutableListOf(vararg elements: T): MutableList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new [ArrayList] with the given elements.\n * @sample samples.collections.Collections.Lists.arrayList\n */\npublic fun <T> arrayListOf(vararg elements: T): ArrayList<T> =\n    if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))\n\n/**\n * Returns a new read-only list either of single given element, if it is not null, or empty list if the element is null. The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(element: T?): List<T> = if (element != null) listOf(element) else emptyList()\n\n/**\n * Returns a new read-only list only of those given elements, that are not null.  The returned list is serializable (JVM).\n * @sample samples.collections.Collections.Lists.listOfNotNull\n */\npublic fun <T : Any> listOfNotNull(vararg elements: T?): List<T> = elements.filterNotNull()\n\n/**\n * Creates a new read-only list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.readOnlyListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> List(size: Int, init: (index: Int) -> T): List<T> = MutableList(size, init)\n\n/**\n * Creates a new mutable list with the specified [size], where each element is calculated by calling the specified\n * [init] function.\n *\n * The function [init] is called for each list element sequentially starting from the first one.\n * It should return the value for a list element given its index.\n *\n * @sample samples.collections.Collections.Lists.mutableListFromInitializer\n */\n@SinceKotlin(\"1.1\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> MutableList(size: Int, init: (index: Int) -> T): MutableList<T> {\n    val list = ArrayList<T>(size)\n    repeat(size) { index -> list.add(init(index)) }\n    return list\n}\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * @sample samples.collections.Builders.Lists.buildListSample\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(@BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Builds a new read-only [List] by populating a [MutableList] using the given [builderAction]\n * and returning a read-only list with the same elements.\n *\n * The list passed as a receiver to the [builderAction] is valid only inside that function.\n * Using it outside of the function produces an unspecified behavior.\n *\n * [capacity] is used to hint the expected number of elements added in the [builderAction].\n *\n * @throws IllegalArgumentException if the given [capacity] is negative.\n *\n * @sample samples.collections.Builders.Lists.buildListSampleWithCapacity\n */\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\npublic inline fun <E> buildList(capacity: Int, @BuilderInference builderAction: MutableList<E>.() -> Unit): List<E> {\n    contract { callsInPlace(builderAction, InvocationKind.EXACTLY_ONCE) }\n    return buildListInternal(capacity, builderAction)\n}\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\n@ExperimentalStdlibApi\n@kotlin.internal.InlineOnly\ninternal expect inline fun <E> buildListInternal(capacity: Int, builderAction: MutableList<E>.() -> Unit): List<E>\n\n/**\n * Returns an [IntRange] of the valid indices for this collection.\n * @sample samples.collections.Collections.Collections.indicesOfCollection\n */\npublic val Collection<*>.indices: IntRange\n    get() = 0..size - 1\n\n/**\n * Returns the index of the last item in the list or -1 if the list is empty.\n *\n * @sample samples.collections.Collections.Lists.lastIndexOfList\n */\npublic val <T> List<T>.lastIndex: Int\n    get() = this.size - 1\n\n/**\n * Returns `true` if the collection is not empty.\n * @sample samples.collections.Collections.Collections.collectionIsNotEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>.isNotEmpty(): Boolean = !isEmpty()\n\n/**\n * Returns `true` if this nullable collection is either null or empty.\n * @sample samples.collections.Collections.Collections.collectionIsNullOrEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.isNullOrEmpty(): Boolean {\n    contract {\n        returns(false) implies (this@isNullOrEmpty != null)\n    }\n\n    return this == null || this.isEmpty()\n}\n\n/**\n * Returns this Collection if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Collections.collectionOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> Collection<T>?.orEmpty(): Collection<T> = this ?: emptyList()\n\n/**\n * Returns this List if it's not `null` and the empty list otherwise.\n * @sample samples.collections.Collections.Lists.listOrEmpty\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> List<T>?.orEmpty(): List<T> = this ?: emptyList()\n\n/**\n * Returns this collection if it's not empty\n * or the result of calling [defaultValue] function if the collection is empty.\n *\n * @sample samples.collections.Collections.Collections.collectionIfEmpty\n */\n@SinceKotlin(\"1.3\")\n@kotlin.internal.InlineOnly\npublic inline fun <C, R> C.ifEmpty(defaultValue: () -> R): R where C : Collection<*>, C : R =\n    if (isEmpty()) defaultValue() else this\n\n\n/**\n * Checks if all elements in the specified collection are contained in this collection.\n *\n * Allows to overcome type-safety restriction of `containsAll` that requires to pass a collection of type `Collection<E>`.\n * @sample samples.collections.Collections.Collections.collectionContainsAll\n */\n@Suppress(\"EXTENSION_SHADOWED_BY_MEMBER\") // false warning, extension takes precedence in some cases\n@kotlin.internal.InlineOnly\npublic inline fun <@kotlin.internal.OnlyInputTypes T> Collection<T>.containsAll(elements: Collection<T>): Boolean = this.containsAll(elements)\n\n\n/**\n * Returns a new list with the elements of this list randomly shuffled\n * using the specified [random] instance as the source of randomness.\n */\n@SinceKotlin(\"1.3\")\npublic fun <T> Iterable<T>.shuffled(random: Random): List<T> = toMutableList().apply { shuffle(random) }\n\n\ninternal fun <T> List<T>.optimizeReadOnlyList() = when (size) {\n    0 -> emptyList()\n    1 -> listOf(this[0])\n    else -> this\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of its elements,\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchOnComparable\n * @sample samples.collections.Collections.Lists.binarySearchWithBoundaries\n */\npublic fun <T : Comparable<T>> List<T?>.binarySearch(element: T?, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = compareValues(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for the provided [element] using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the specified [comparator],\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements equal to the specified [element], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted according to the specified [comparator].\n * @sample samples.collections.Collections.Lists.binarySearchWithComparator\n */\npublic fun <T> List<T>.binarySearch(element: T, comparator: Comparator<in T>, fromIndex: Int = 0, toIndex: Int = size): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparator.compare(midVal, element)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Searches this list or its range for an element having the key returned by the specified [selector] function\n * equal to the provided [key] value using the binary search algorithm.\n * The list is expected to be sorted into ascending order according to the Comparable natural ordering of keys of its elements.\n * otherwise the result is undefined.\n *\n * If the list contains multiple elements with the specified [key], there is no guarantee which one will be found.\n *\n * `null` value is considered to be less than any non-null value.\n *\n * @return the index of the element with the specified [key], if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchByKey\n */\npublic inline fun <T, K : Comparable<K>> List<T>.binarySearchBy(\n    key: K?,\n    fromIndex: Int = 0,\n    toIndex: Int = size,\n    crossinline selector: (T) -> K?\n): Int =\n    binarySearch(fromIndex, toIndex) { compareValues(selector(it), key) }\n\n// do not introduce this overload --- too rare\n//public fun <T, K> List<T>.binarySearchBy(key: K, comparator: Comparator<K>, fromIndex: Int = 0, toIndex: Int = size(), selector: (T) -> K): Int =\n//        binarySearch(fromIndex, toIndex) { comparator.compare(selector(it), key) }\n\n\n/**\n * Searches this list or its range for an element for which the given [comparison] function returns zero using the binary search algorithm.\n *\n * The list is expected to be sorted so that the signs of the [comparison] function's return values ascend on the list elements,\n * i.e. negative values come before zero and zeroes come before positive values.\n * Otherwise, the result is undefined.\n *\n * If the list contains multiple elements for which [comparison] returns zero, there is no guarantee which one will be found.\n *\n * @param comparison function that returns zero when called on the list element being searched.\n * On the elements coming before the target element, the function must return negative values;\n * on the elements coming after the target element, the function must return positive values.\n *\n * @return the index of the found element, if it is contained in the list within the specified range;\n * otherwise, the inverted insertion point `(-insertion point - 1)`.\n * The insertion point is defined as the index at which the element should be inserted,\n * so that the list (or the specified subrange of list) still remains sorted.\n * @sample samples.collections.Collections.Lists.binarySearchWithComparisonFunction\n */\npublic fun <T> List<T>.binarySearch(fromIndex: Int = 0, toIndex: Int = size, comparison: (T) -> Int): Int {\n    rangeCheck(size, fromIndex, toIndex)\n\n    var low = fromIndex\n    var high = toIndex - 1\n\n    while (low <= high) {\n        val mid = (low + high).ushr(1) // safe from overflows\n        val midVal = get(mid)\n        val cmp = comparison(midVal)\n\n        if (cmp < 0)\n            low = mid + 1\n        else if (cmp > 0)\n            high = mid - 1\n        else\n            return mid // key found\n    }\n    return -(low + 1)  // key not found\n}\n\n/**\n * Checks that `from` and `to` are in\n * the range of [0..size] and throws an appropriate exception, if they aren't.\n */\nprivate fun rangeCheck(size: Int, fromIndex: Int, toIndex: Int) {\n    when {\n        fromIndex > toIndex -> throw IllegalArgumentException(\"fromIndex ($fromIndex) is greater than toIndex ($toIndex).\")\n        fromIndex < 0 -> throw IndexOutOfBoundsException(\"fromIndex ($fromIndex) is less than zero.\")\n        toIndex > size -> throw IndexOutOfBoundsException(\"toIndex ($toIndex) is greater than size ($size).\")\n    }\n}\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkIndexOverflow(index: Int): Int\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal expect fun checkCountOverflow(count: Int): Int\n\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwIndexOverflow() { throw ArithmeticException(\"Index overflow has happened.\") }\n\n@PublishedApi\n@SinceKotlin(\"1.3\")\ninternal fun throwCountOverflow() { throw ArithmeticException(\"Count overflow has happened.\") }\n\n","/*\n * Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\n@file:kotlin.jvm.JvmMultifileClass\n@file:kotlin.jvm.JvmName(\"StandardKt\")\npackage kotlin\n\nimport kotlin.contracts.*\n\n/**\n * An exception is thrown to indicate that a method body remains to be implemented.\n */\npublic class NotImplementedError(message: String = \"An operation is not implemented.\") : Error(message)\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n */\n\n@kotlin.internal.InlineOnly\npublic inline fun TODO(): Nothing = throw NotImplementedError()\n\n/**\n * Always throws [NotImplementedError] stating that operation is not implemented.\n *\n * @param reason a string explaining why the implementation is missing.\n */\n@kotlin.internal.InlineOnly\npublic inline fun TODO(reason: String): Nothing = throw NotImplementedError(\"An operation is not implemented: $reason\")\n\n\n\n/**\n * Calls the specified function [block] and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <R> run(block: () -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#run).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.run(block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block()\n}\n\n/**\n * Calls the specified function [block] with the given [receiver] as its receiver and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#with).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> with(receiver: T, block: T.() -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return receiver.block()\n}\n\n/**\n * Calls the specified function [block] with `this` value as its receiver and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#apply).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T> T.apply(block: T.() -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block()\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns `this` value.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#also).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.also(block: (T) -> Unit): T {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    block(this)\n    return this\n}\n\n/**\n * Calls the specified function [block] with `this` value as its argument and returns its result.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#let).\n */\n@kotlin.internal.InlineOnly\npublic inline fun <T, R> T.let(block: (T) -> R): R {\n    contract {\n        callsInPlace(block, InvocationKind.EXACTLY_ONCE)\n    }\n    return block(this)\n}\n\n/**\n * Returns `this` value if it satisfies the given [predicate] or `null`, if it doesn't.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (predicate(this)) this else null\n}\n\n/**\n * Returns `this` value if it _does not_ satisfy the given [predicate] or `null`, if it does.\n *\n * For detailed usage information see the documentation for [scope functions](https://kotlinlang.org/docs/reference/scope-functions.html#takeif-and-takeunless).\n */\n@kotlin.internal.InlineOnly\n@SinceKotlin(\"1.1\")\npublic inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {\n    contract {\n        callsInPlace(predicate, InvocationKind.EXACTLY_ONCE)\n    }\n    return if (!predicate(this)) this else null\n}\n\n/**\n * Executes the given function [action] specified number of [times].\n *\n * A zero-based index of current iteration is passed as a parameter to [action].\n *\n * @sample samples.misc.ControlFlow.repeat\n */\n@kotlin.internal.InlineOnly\npublic inline fun repeat(times: Int, action: (Int) -> Unit) {\n    contract { callsInPlace(action) }\n\n    for (index in 0 until times) {\n        action(index)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.base.values.Pair\n\nclass PolylineSimplifier private constructor(private val myPoints: List<DoubleVector>, strategy: RankingStrategy) {\n    private val myWeights: List<Double>\n    private var myWeightLimit = Double.NaN\n    private var myCountLimit = -1\n\n    val points: List<DoubleVector>\n        get() =\n            indices.map { myPoints[it] }\n\n    val indices: List<Int>\n        get() {\n            val sorted = (0 until myPoints.size)\n                    .map { i -> Pair(i, myWeights[i]) }\n                    .filter { p -> !getWeight(p).isNaN() }\n                    .sortedWith(compareBy<Pair<Int, Double>> { this.getWeight(it) }.reversed())\n\n            val filtered: Collection<Pair<Int, Double>>\n            if (isWeightLimitSet) {\n                filtered = sorted.filter { p -> getWeight(p) > myWeightLimit }\n            } else {\n                filtered = sorted.take(myCountLimit)\n            }\n\n            return filtered\n                    .map { this.getIndex(it) }\n                    .sorted()\n        }\n\n    private val isWeightLimitSet: Boolean\n        get() = !myWeightLimit.isNaN()\n\n    init {\n        myWeights = strategy.getWeights(myPoints)\n    }\n\n    fun setWeightLimit(weightLimit: Double): PolylineSimplifier {\n        myWeightLimit = weightLimit\n        myCountLimit = -1\n        return this\n    }\n\n    fun setCountLimit(countLimit: Int): PolylineSimplifier {\n        myWeightLimit = Double.NaN\n        myCountLimit = countLimit\n        return this\n    }\n\n    private fun getWeight(p: Pair<Int, Double>): Double {\n        return p.second\n    }\n\n    private fun getIndex(p: Pair<Int, Double>): Int {\n        return p.first\n    }\n\n    interface RankingStrategy {\n        fun getWeights(points: List<DoubleVector>): List<Double>\n    }\n\n    companion object {\n\n        fun visvalingamWhyatt(points: List<DoubleVector>): PolylineSimplifier {\n            return PolylineSimplifier(\n                points,\n                VisvalingamWhyattSimplification()\n            )\n        }\n\n        fun douglasPeucker(points: List<DoubleVector>): PolylineSimplifier {\n            return PolylineSimplifier(\n                points,\n                DouglasPeuckerSimplification()\n            )\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.geometry\n\nimport jetbrains.datalore.base.geometry.DoubleVector\nimport jetbrains.datalore.plot.common.geometry.PolylineSimplifier.RankingStrategy\nimport kotlin.math.abs\n\n\n// Reference: https://bost.ocks.org/mike/simplify/\ninternal class VisvalingamWhyattSimplification : RankingStrategy {\n    private val myVerticesToRemove = ArrayList<Int>()\n    private var myTriangles: MutableList<Triangle>? = null\n\n    private val isSimplificationDone: Boolean\n        get() = isEmpty\n\n    private val isEmpty: Boolean\n        get() = myTriangles!!.isEmpty()\n\n    override fun getWeights(points: List<DoubleVector>): List<Double> {\n        myTriangles = ArrayList(points.size - 2)\n        initTriangles(points)\n        val weights = MutableList(points.size) { INITIAL_AREA }\n        var lastRemovedVertexArea = 0.0\n        while (!isSimplificationDone) {\n            val triangle = takeTriangle()\n\n            lastRemovedVertexArea = if (triangle.area > lastRemovedVertexArea)\n                triangle.area\n            else\n                lastRemovedVertexArea\n\n            weights[triangle.currentVertex] = lastRemovedVertexArea\n\n            val next = triangle.next\n            if (next != null) {\n                next.takePrevFrom(triangle)\n                update(next)\n            }\n\n            val prev = triangle.prev\n            if (prev != null) {\n                prev.takeNextFrom(triangle)\n                update(prev)\n            }\n\n            myVerticesToRemove.add(triangle.currentVertex)\n        }\n\n        return weights\n    }\n\n    private fun initTriangles(points: List<DoubleVector>) {\n        val triangles = ArrayList<Triangle>(points.size - 2)\n\n        run {\n            var i = 1\n            val n = points.size - 1\n            while (i < n) {\n                triangles.add(\n                    Triangle(\n                        i,\n                        points\n                    )\n                )\n                ++i\n            }\n        }\n\n        var i = 1\n        val n = triangles.size - 1\n        while (i < n) {\n            triangles[i].next = triangles[i + 1]\n            triangles[i].prev = triangles[i - 1]\n            i++\n        }\n\n        triangles.forEach { this.add(it) }\n    }\n\n    private fun takeTriangle(): Triangle {\n        val minimalTriangle = poll()\n        myVerticesToRemove.add(minimalTriangle.currentVertex)\n        return minimalTriangle\n    }\n\n    private fun add(triangle: Triangle) {\n        val index = getIndex(triangle)\n        myTriangles!!.add(index, triangle)\n    }\n\n    private fun getIndex(triangle: Triangle): Int {\n        var index = myTriangles!!.binarySearch(triangle, compareBy { it.area })\n        if (index < 0) {\n            index = index.inv()\n        }\n        return index\n    }\n\n    private fun peek(): Triangle {\n        return myTriangles!![0]\n    }\n\n    private fun poll(): Triangle {\n        val triangle = peek()\n        myTriangles!!.remove(triangle)\n        return triangle\n    }\n\n    private fun update(triangle: Triangle) {\n        myTriangles!!.remove(triangle)\n        myTriangles!!.add(triangle)\n    }\n\n    private class Triangle internal constructor(val currentVertex: Int, private val myPoints: List<DoubleVector>) {\n        var area: Double = 0.toDouble()\n            private set\n        private var prevVertex: Int = 0\n        private var nextVertex: Int = 0\n        var prev: Triangle? = null\n        var next: Triangle? = null\n\n        init {\n            prevVertex = currentVertex - 1\n            nextVertex = currentVertex + 1\n            area = calculateArea()\n        }\n\n        internal fun takeNextFrom(triangle: Triangle) {\n            next = triangle.next\n            nextVertex = triangle.nextVertex\n            area = calculateArea()\n        }\n\n        internal fun takePrevFrom(triangle: Triangle) {\n            prev = triangle.prev\n            prevVertex = triangle.prevVertex\n            area = calculateArea()\n        }\n\n        private fun calculateArea(): Double {\n            val a = myPoints[prevVertex]\n            val b = myPoints[currentVertex]\n            val c = myPoints[nextVertex]\n\n            return abs(((b.x - a.x) * (c.y - a.y) - (c.x - a.x) * (b.y - a.y)) / 2.0)\n        }\n    }\n\n    companion object {\n\n        private val INITIAL_AREA = Double.MAX_VALUE\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.text\n\nimport jetbrains.datalore.base.dateFormat.Format\nimport jetbrains.datalore.base.datetime.Instant\nimport jetbrains.datalore.base.datetime.tz.TimeZone\n\nobject DateTimeFormatUtil {\n    fun formatDateUTC(instant: Number, pattern: String): String {\n        val format = Format(pattern)\n        return instant.toLong()\n            .let(::Instant)\n            .let(TimeZone.UTC::toDateTime)\n            .let(format::apply)\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.text\n\nimport jetbrains.datalore.base.numberFormat.NumberFormat\nimport jetbrains.datalore.plot.common.data.DataType\nimport jetbrains.datalore.plot.common.time.interval.TimeInterval\n\nobject Formatter {\n    private const val YEAR = \"%b %Y\"\n    private const val YEAR_QUARTER = \"Q %y\"\n    private const val YEAR_MONTH = \"%B %Y\"\n    private const val DATE_MEDIUM = \"%a, %b %e, %Y\"\n    private const val DATE_MEDIUM_TIME_SHORT = \"%a, %b %e, %Y %l:%M %p\"\n\n    private val DEF_NUMBER_FORMAT = NumberFormat(\",g\")\n\n    private val DEF_NUMBER_FORMATTER: (Any) -> String = { input ->\n        DEF_NUMBER_FORMAT.apply(input as Number)\n    }\n\n    fun time(pattern: String): (Any) -> String = { input ->\n        DateTimeFormatUtil.formatDateUTC(\n            input as Number,\n            pattern\n        )\n    }\n\n//    @JvmOverloads\n//    fun number(pattern: String): (Any) -> String = { input ->\n//        var result = \"NaN\"\n//        if (input is Number) {\n//            result = NumberFormatUtil.formatNumber(input, pattern)\n//        }\n//        result\n//    }\n\n//    fun legend(dataType: DataType): (Any?) -> String {\n//        return tooltip(dataType)\n//    }\n\n    // ToDo: remove - only used in tests (?)\n    fun tooltip(dataType: DataType): (Any?) -> String {\n        return nullable(\n            tooltipImpl(\n                dataType\n            ), \"null\"\n        )\n    }\n\n    private fun tooltipImpl(dataType: DataType): (Any) -> String {\n        return when (dataType) {\n            DataType.NUMBER -> DEF_NUMBER_FORMATTER\n            DataType.STRING -> { it -> it.toString() } // no formatting really (toSting)\n            DataType.INSTANT -> time(\n                DATE_MEDIUM_TIME_SHORT\n            )\n            DataType.INSTANT_OF_DAY -> time(\n                DATE_MEDIUM\n            )\n            DataType.INSTANT_OF_MONTH -> time(\n                YEAR_MONTH\n            )\n            DataType.INSTANT_OF_QUARTER, DataType.INSTANT_OF_HALF_YEAR -> time(\n                YEAR_QUARTER\n            )\n            DataType.INSTANT_OF_YEAR -> time(\n                YEAR\n            )\n        }\n    }\n\n    // ToDo: remove - only used in tests (?)\n    fun tableCell(dataType: DataType): (Any?) -> String {\n        return tableCell(dataType, \"null\")\n    }\n\n    private fun tableCell(dataType: DataType, nullString: String): (Any?) -> String {\n        return nullable(\n            tableCellImpl(\n                dataType\n            ), nullString\n        )\n    }\n\n    private fun tableCellImpl(dataType: DataType): (Any) -> String {\n        when (dataType) {\n            DataType.NUMBER -> return DEF_NUMBER_FORMATTER\n            DataType.STRING -> return { it.toString() } // no formatting really (toSting)\n            DataType.INSTANT -> return time(\"%a, %b %e, '%y\")\n            else -> if (dataType.isTimeInterval) {\n                val timeInterval = TimeInterval.fromIntervalDataType(dataType)\n                return timeInterval.tickFormatter\n            }\n        }\n\n        throw IllegalArgumentException(\"Can't create formatter for data type $dataType\")\n    }\n\n    private fun nullable(f: (Any) -> String, nullString: String): (Any?) -> String = { input ->\n        if (input == null) nullString else f(input)\n    }\n\n//    fun ordinalSeries(dataType: DataType): (Any?) -> String {\n//        return tableCell(dataType)\n//    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Instant\nimport jetbrains.datalore.base.datetime.tz.TimeZone\nimport kotlin.math.roundToLong\n\nobject TimeUtil {\n    fun asDateTimeUTC(instant: Double): DateTime {\n        try {\n            return TimeZone.UTC.toDateTime(Instant(instant.roundToLong()))\n        } catch (ignored: RuntimeException) {\n            throw IllegalArgumentException(\"Can't create DateTime from instant $instant\")\n        }\n\n    }\n\n    fun asInstantUTC(dateTime: DateTime): Long {\n        return TimeZone.UTC.toInstant(dateTime).timeSinceEpoch\n    }\n\n    fun yearStart(year: Int): DateTime {\n        return DateTime(Date.firstDayOf(year))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Duration\nimport kotlin.math.ceil\n\ninternal class DurationInterval(private val myDuration: Duration, count: Int) : TimeInterval(count) {\n\n    override// milliseconds\n    // fractional seconds\n    // seconds\n    // minutes\n    // hours\n    // days\n    // weeks\n    val tickFormatPattern: String\n        get() {\n            val duration = myDuration.duration\n            if (duration < Duration.SECOND.duration) {\n                return \"%S\"\n            } else if (duration < Duration.MINUTE.duration) {\n                return \"%S\"\n            } else if (duration < Duration.HOUR.duration) {\n                return \"%M\"\n            } else if (duration < Duration.DAY.duration) {\n                return \"%H:%M\"\n            } else if (duration < Duration.WEEK.duration) {\n                return \"%b %e\"\n            }\n            return \"%b %e\"\n        }\n\n    init {\n        if (!myDuration.isPositive) {\n            throw RuntimeException(\"Duration must be positive\")\n        }\n    }\n\n    override fun range(start: Double, end: Double): List<Double> {\n        val step = (myDuration.duration * count).toDouble()\n        var tick = ceil(start / step) * step\n        val result = ArrayList<Double>()\n        while (tick <= end) {\n            result.add(tick)\n            tick += step\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.plot.common.time.TimeUtil\n\nabstract class MeasuredInDays protected constructor(count: Int) : TimeInterval(count) {\n\n    protected abstract fun getFirstDayContaining(instant: DateTime): Date\n\n    override fun range(start: Double, end: Double): List<Double> {\n        if (start > end) {\n            throw RuntimeException(\"Duration must be positive\")\n        }\n\n        val dateTimeStart = TimeUtil.asDateTimeUTC(start)\n\n        val dateStart = getFirstDayContaining(dateTimeStart)\n        var dateTimeTick = DateTime(dateStart)\n        if (dateTimeTick.compareTo(dateTimeStart) < 0) {\n            dateTimeTick = addInterval(dateTimeTick)\n        }\n\n        val result = ArrayList<Double>()\n        var tick = TimeUtil.asInstantUTC(dateTimeTick).toDouble()\n        while (tick <= end) {\n            result.add(tick)\n            dateTimeTick = addInterval(dateTimeTick)\n            tick = TimeUtil.asInstantUTC(dateTimeTick).toDouble()\n        }\n\n        return result\n    }\n\n    protected abstract fun addInterval(toInstant: DateTime): DateTime\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.base.datetime.Month\n\ninternal class MonthInterval(count: Int) : MeasuredInDays(count) {\n\n    override val tickFormatPattern: String\n        get() = \"%b\"\n\n    override fun getFirstDayContaining(instant: DateTime): Date {\n        var firstDay = instant.date\n        firstDay = Date.firstDayOf(firstDay.year, firstDay.month)\n        return firstDay\n    }\n\n    override fun addInterval(toInstant: DateTime): DateTime {\n        var result = toInstant\n        for (i in 0 until count) {\n            result = addMonth(result)\n        }\n        return result\n    }\n\n    private fun addMonth(toInstant: DateTime): DateTime {\n        var year = toInstant.year\n        val month = toInstant.month\n        var next = month!!.next()\n        if (next == null) {\n            next = Month.JANUARY\n            year++\n        }\n        return DateTime(Date.firstDayOf(year, next))\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nobject NiceTimeInterval {\n    private val AUTO_STEPS_MS = doubleArrayOf(1000.0, 5000.0, 15000.0, 30000.0, // 1-, 5-, 15- and 30-second.\n            6e4, 5 * 6e4, 15 * 6e4, 30 * 6e4, // 1-, 5-, 15- and 30-minute.\n            36e5, 3 * 36e5, 6 * 36e5, 12 * 36e5, // 1-, 3-, 6- and 12-hour.\n            864e5, 2 * 864e5, // 1- and 2-day.\n            6048e5, // 1-week.\n            2592e6, 3 * 2592e6, // 1- and 3-month.\n        YearInterval.MS                                  // 1-year.\n    )\n\n    private val AUTO_INTERVALS = arrayOf(\n        TimeInterval.seconds(1),\n        TimeInterval.seconds(5),\n        TimeInterval.seconds(15),\n        TimeInterval.seconds(30),\n\n        TimeInterval.minutes(1),\n        TimeInterval.minutes(5),\n        TimeInterval.minutes(15),\n        TimeInterval.minutes(30),\n\n        TimeInterval.hours(1),\n        TimeInterval.hours(3),\n        TimeInterval.hours(6),\n        TimeInterval.hours(12),\n\n        TimeInterval.days(1),\n        TimeInterval.days(2),\n\n        TimeInterval.weeks(1),\n\n        TimeInterval.months(1),\n        TimeInterval.months(3),\n\n        TimeInterval.years(1)\n    )\n\n    fun forMillis(interval: Double): TimeInterval {\n        if (interval <= AUTO_STEPS_MS[0]) {\n            return AUTO_INTERVALS[0]\n        }\n\n        var result = AUTO_INTERVALS[AUTO_STEPS_MS.size - 1]\n        for (i in 1 until AUTO_STEPS_MS.size) {\n            if (AUTO_STEPS_MS[i] >= interval) {\n                val deltaDown = interval - AUTO_STEPS_MS[i - 1]\n                val deltaUp = AUTO_STEPS_MS[i] - interval\n                if (deltaDown < deltaUp) {\n                    result = AUTO_INTERVALS[i - 1]\n                } else {\n                    result = AUTO_INTERVALS[i]\n                }\n                break\n            }\n        }\n        return result\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\ninternal class QuarterInterval(count: Int) : TimeInterval(count) {\n\n    override val tickFormatPattern: String\n        get() = \"Q\"\n\n    override fun range(start: Double, end: Double): List<Double> {\n        throw UnsupportedOperationException()\n    }\n\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.plot.common.text.DateTimeFormatUtil\n\ninternal class SemesterInterval(count: Int) : TimeInterval(count) {\n\n    override val tickFormatPattern: String\n        get() = throw UnsupportedOperationException()\n\n    override val tickFormatter: (Any) -> String\n        get() = TIME_FORMAT_FUNCTION\n\n    override fun range(start: Double, end: Double): List<Double> {\n        throw UnsupportedOperationException()\n    }\n\n    companion object {\n\n        private val TIME_FORMAT_FUNCTION: (Any) -> String = { input ->\n            var result = DateTimeFormatUtil.formatDateUTC(input as Number, \"Q\")\n            if (result.length == 2 && result.startsWith(\"Q\")) {\n                try {\n                    val quarterNum = result.substring(1).toInt()\n                    val semesterNumber = (quarterNum + 1) / 2\n                    if (semesterNumber == 1 || semesterNumber == 2) {\n                        result = \"Semester $semesterNumber\"\n                    }\n                } catch (ignored: NumberFormatException) {\n                    // ignore\n                }\n\n            }\n            result\n        }\n    }\n}\n","/*\n * Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.\n * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.\n */\n\npackage kotlin.text\n\nimport kotlin.js.RegExp\n\n/**\n * Converts the characters in the specified array to a string.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString() instead\", ReplaceWith(\"chars.concatToString()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray): String {\n    var result = \"\"\n    for (char in chars) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Converts the characters from a portion of the specified array to a string.\n *\n * @throws IndexOutOfBoundsException if either [offset] or [length] are less than zero\n * or `offset + length` is out of [chars] array bounds.\n */\n@SinceKotlin(\"1.2\")\n@Deprecated(\"Use CharArray.concatToString(startIndex, endIndex) instead\", ReplaceWith(\"chars.concatToString(offset, offset + length)\"))\n@DeprecatedSinceKotlin(warningSince = \"1.4\", errorSince = \"1.5\")\npublic actual fun String(chars: CharArray, offset: Int, length: Int): String {\n    if (offset < 0 || length < 0 || chars.size - offset < length)\n        throw IndexOutOfBoundsException(\"size: ${chars.size}; offset: $offset; length: $length\")\n    var result = \"\"\n    for (index in offset until offset + length) {\n        result += chars[index]\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] into a String.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun CharArray.concatToString(): String {\n    var result = \"\"\n    for (char in this) {\n        result += char\n    }\n    return result\n}\n\n/**\n * Concatenates characters in this [CharArray] or its subrange into a String.\n *\n * @param startIndex the beginning (inclusive) of the subrange of characters, 0 by default.\n * @param endIndex the end (exclusive) of the subrange of characters, size of this array by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun CharArray.concatToString(startIndex: Int = 0, endIndex: Int = this.size): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    var result = \"\"\n    for (index in startIndex until endIndex) {\n        result += this[index]\n    }\n    return result\n}\n\n/**\n * Returns a [CharArray] containing characters of this string.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.toCharArray(): CharArray {\n    return CharArray(length) { get(it) }\n}\n\n/**\n * Returns a [CharArray] containing characters of this string or its substring.\n *\n * @param startIndex the beginning (inclusive) of the substring, 0 by default.\n * @param endIndex the end (exclusive) of the substring, length of this string by default.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.toCharArray(startIndex: Int = 0, endIndex: Int = this.length): CharArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return CharArray(endIndex - startIndex) { get(startIndex + it) }\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array.\n *\n * Malformed byte sequences are replaced by the replacement char `\\uFFFD`.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun ByteArray.decodeToString(): String {\n    return decodeUtf8(this, 0, size, false)\n}\n\n/**\n * Decodes a string from the bytes in UTF-8 encoding in this array or its subrange.\n *\n * @param startIndex the beginning (inclusive) of the subrange to decode, 0 by default.\n * @param endIndex the end (exclusive) of the subrange to decode, size of this array by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed byte sequence or replace it by the replacement char `\\uFFFD`.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the size of this array.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if the byte array contains malformed UTF-8 byte sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun ByteArray.decodeToString(\n    startIndex: Int = 0,\n    endIndex: Int = this.size,\n    throwOnInvalidSequence: Boolean = false\n): String {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, this.size)\n    return decodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Encodes this string to an array of bytes in UTF-8 encoding.\n *\n * Any malformed char sequence is replaced by the replacement byte sequence.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\npublic actual fun String.encodeToByteArray(): ByteArray {\n    return encodeUtf8(this, 0, length, false)\n}\n\n/**\n * Encodes this string or its substring to an array of bytes in UTF-8 encoding.\n *\n * @param startIndex the beginning (inclusive) of the substring to encode, 0 by default.\n * @param endIndex the end (exclusive) of the substring to encode, length of this string by default.\n * @param throwOnInvalidSequence specifies whether to throw an exception on malformed char sequence or replace.\n *\n * @throws IndexOutOfBoundsException if [startIndex] is less than zero or [endIndex] is greater than the length of this string.\n * @throws IllegalArgumentException if [startIndex] is greater than [endIndex].\n * @throws CharacterCodingException if this string contains malformed char sequence and [throwOnInvalidSequence] is true.\n */\n@SinceKotlin(\"1.4\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.encodeToByteArray(\n    startIndex: Int = 0,\n    endIndex: Int = this.length,\n    throwOnInvalidSequence: Boolean = false\n): ByteArray {\n    AbstractList.checkBoundsIndexes(startIndex, endIndex, length)\n    return encodeUtf8(this, startIndex, endIndex, throwOnInvalidSequence)\n}\n\n/**\n * Returns a copy of this string converted to upper case using the rules of the default locale.\n */\n@Deprecated(\"Use uppercase() instead.\", ReplaceWith(\"uppercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toUpperCase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to upper case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.uppercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.uppercase(): String = asDynamic().toUpperCase()\n\n/**\n * Returns a copy of this string converted to lower case using the rules of the default locale.\n */\n@Deprecated(\"Use lowercase() instead.\", ReplaceWith(\"lowercase()\"))\n@DeprecatedSinceKotlin(warningSince = \"1.5\")\n@kotlin.internal.InlineOnly\npublic actual inline fun String.toLowerCase(): String = asDynamic().toLowerCase()\n\n/**\n * Returns a copy of this string converted to lower case using Unicode mapping rules of the invariant locale.\n *\n * This function supports one-to-many and many-to-one character mapping,\n * thus the length of the returned string can be different from the length of the original string.\n *\n * @sample samples.text.Strings.lowercase\n */\n@SinceKotlin(\"1.5\")\n@WasExperimental(ExperimentalStdlibApi::class)\n@kotlin.internal.InlineOnly\npublic actual inline fun String.lowercase(): String = asDynamic().toLowerCase()\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeIndexOf(str: String, fromIndex: Int): Int = asDynamic().indexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal actual inline fun String.nativeLastIndexOf(str: String, fromIndex: Int): Int = asDynamic().lastIndexOf(str, fromIndex)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeStartsWith(s: String, position: Int): Boolean = asDynamic().startsWith(s, position)\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeEndsWith(s: String): Boolean = asDynamic().endsWith(s)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int): String = asDynamic().substring(startIndex)\n\n@kotlin.internal.InlineOnly\npublic actual inline fun String.substring(startIndex: Int, endIndex: Int): String = asDynamic().substring(startIndex, endIndex)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.concat(str: String): String = asDynamic().concat(str)\n\n@kotlin.internal.InlineOnly\npublic inline fun String.match(regex: String): Array<String>? = asDynamic().match(regex)\n\n//native public fun String.trim(): String\n//TODO: String.replace to implement effective trimLeading and trimTrailing\n\n@kotlin.internal.InlineOnly\ninternal inline fun String.nativeReplace(pattern: RegExp, replacement: String): String = asDynamic().replace(pattern, replacement)\n\n@SinceKotlin(\"1.2\")\n@Suppress(\"ACTUAL_FUNCTION_WITH_DEFAULT_ARGUMENTS\")\npublic actual fun String.compareTo(other: String, ignoreCase: Boolean = false): Int {\n    if (ignoreCase) {\n        val n1 = this.length\n        val n2 = other.length\n        val min = minOf(n1, n2)\n        if (min == 0) return n1 - n2\n        var start = 0\n        while (true) {\n            val end = minOf(start + 16, min)\n            var s1 = this.substring(start, end)\n            var s2 = other.substring(start, end)\n            if (s1 != s2) {\n                s1 = s1.uppercase()\n                s2 = s2.uppercase()\n                if (s1 != s2) {\n                    s1 = s1.lowercase()\n                    s2 = s2.lowercase()\n                    if (s1 != s2) {\n                        return s1.compareTo(s2)\n                    }\n                }\n            }\n            if (end == min) break\n            start = end\n        }\n        return n1 - n2\n    } else {\n        return compareTo(other)\n    }\n}\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other],\n * i.e. both char sequences contain the same number of the same characters in the same order.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual infix fun CharSequence?.contentEquals(other: CharSequence?): Boolean = contentEqualsImpl(other)\n\n/**\n * Returns `true` if the contents of this char sequence are equal to the contents of the specified [other], optionally ignoring case difference.\n *\n * @param ignoreCase `true` to ignore character case when comparing contents.\n *\n * @sample samples.text.Strings.contentEquals\n */\n@SinceKotlin(\"1.5\")\npublic actual fun CharSequence?.contentEquals(other: CharSequence?, ignoreCase: Boolean): Boolean {\n    return if (ignoreCase)\n        this.contentEqualsIgnoreCaseImpl(other)\n    else\n        this.contentEqualsImpl(other)\n}\n\n\nprivate val STRING_CASE_INSENSITIVE_ORDER = Comparator<String> { a, b -> a.compareTo(b, ignoreCase = true) }\n\n@SinceKotlin(\"1.2\")\npublic actual val String.Companion.CASE_INSENSITIVE_ORDER: Comparator<String>\n    get() = STRING_CASE_INSENSITIVE_ORDER\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Duration\nimport jetbrains.datalore.plot.common.data.DataType\nimport jetbrains.datalore.plot.common.text.Formatter\n\nabstract class TimeInterval protected constructor(val count: Int) {\n\n    abstract val tickFormatPattern: String\n\n    open val tickFormatter: (Any) -> String\n        get() = Formatter.time(tickFormatPattern)\n\n    /**\n     * @param start instant\n     * @param end   instant\n     * @return Returns every time interval after or equal to start and before end.\n     */\n    abstract fun range(start: Double, end: Double): List<Double>\n\n    companion object {\n        fun milliseconds(count: Int): TimeInterval {\n            return DurationInterval(Duration.MS, count)\n        }\n\n        fun seconds(count: Int): TimeInterval {\n            return DurationInterval(Duration.SECOND, count)\n        }\n\n        fun minutes(count: Int): TimeInterval {\n            return DurationInterval(Duration.MINUTE, count)\n        }\n\n        fun hours(count: Int): TimeInterval {\n            return DurationInterval(Duration.HOUR, count)\n        }\n\n        fun days(count: Int): TimeInterval {\n            return DurationInterval(Duration.DAY, count)\n        }\n\n        fun weeks(count: Int): TimeInterval {\n            return DurationInterval(Duration.WEEK, count)\n        }\n\n        fun months(count: Int): TimeInterval {\n            return MonthInterval(count)\n        }\n\n        private fun quarter(count: Int): TimeInterval {\n            return QuarterInterval(count)\n        }\n\n        private fun semester(count: Int): TimeInterval {\n            return SemesterInterval(count)\n        }\n\n        fun years(count: Int): TimeInterval {\n            return YearInterval(count)\n        }\n\n        fun fromIntervalDataType(dataType: DataType): TimeInterval {\n            return when (dataType) {\n                DataType.INSTANT_OF_DAY -> days(\n                    1\n                )\n                DataType.INSTANT_OF_MONTH -> months(\n                    1\n                )\n                DataType.INSTANT_OF_QUARTER -> quarter(\n                    1\n                )\n                DataType.INSTANT_OF_HALF_YEAR -> semester(\n                    1\n                )\n                DataType.INSTANT_OF_YEAR -> years(\n                    1\n                )\n                else -> throw IllegalArgumentException(\"Can't create interval from data type: $dataType\")\n            }\n        }\n    }\n}\n","/*\n * Copyright (c) 2019. JetBrains s.r.o.\n * Use of this source code is governed by the MIT license that can be found in the LICENSE file.\n */\n\npackage jetbrains.datalore.plot.common.time.interval\n\nimport jetbrains.datalore.base.datetime.Date\nimport jetbrains.datalore.base.datetime.DateTime\nimport jetbrains.datalore.plot.common.text.Formatter\n\nclass YearInterval internal constructor(count: Int) : MeasuredInDays(count) {\n\n    override val tickFormatPattern = TICK_FORMAT\n\n    override fun getFirstDayContaining(instant: DateTime): Date {\n        return Date.firstDayOf(instant.year)\n    }\n\n    override fun addInterval(toInstant: DateTime): DateTime {\n        var result = toInstant\n        for (i in 0 until count) {\n            result = addYear(result)\n        }\n        return result\n    }\n\n    private fun addYear(toInstant: DateTime): DateTime {\n        val year = toInstant.year\n        return DateTime(Date.firstDayOf(year + 1))\n    }\n\n    companion object {\n        const val TICK_FORMAT = \"%Y\"\n        const val MS = 31536e6\n        val TICK_FORMATTER = Formatter.time(TICK_FORMAT)\n    }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./kotlin-dce-dev/lets-plot-plot-common-portable.js\n"); /***/ }), @@ -205,7 +205,7 @@ eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPAC \**********************************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (root, factory) {\n if (true)\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports, __webpack_require__(/*! kotlin */ \"./kotlin-dce-dev/kotlin.js\"), __webpack_require__(/*! lets-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-plot-builder-portable */ \"./kotlin-dce-dev/lets-plot-plot-builder-portable.js\"), __webpack_require__(/*! lets-plot-vis-svg-portable */ \"./kotlin-dce-dev/lets-plot-vis-svg-portable.js\"), __webpack_require__(/*! lets-plot-plot-base-portable */ \"./kotlin-dce-dev/lets-plot-plot-base-portable.js\"), __webpack_require__(/*! lets-plot-plot-common-portable */ \"./kotlin-dce-dev/lets-plot-plot-common-portable.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n}(this, function (_, Kotlin, $module$lets_plot_base_portable, $module$lets_plot_plot_builder_portable, $module$lets_plot_vis_svg_portable, $module$lets_plot_plot_base_portable, $module$lets_plot_plot_common_portable) {\n 'use strict';\n var $$importsForInline$$ = _.$$importsForInline$$ || (_.$$importsForInline$$ = {});\n var replace = Kotlin.kotlin.text.replace_680rmw$;\n var json = $module$lets_plot_base_portable.jetbrains.datalore.base.json;\n var MutableMap = Kotlin.kotlin.collections.MutableMap;\n var throwCCE = Kotlin.throwCCE;\n var RuntimeException_init = Kotlin.kotlin.RuntimeException_init_pdl1vj$;\n var PlotContainerPortable = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.PlotContainerPortable;\n var listOf = Kotlin.kotlin.collections.listOf_mh5how$;\n var toString = Kotlin.toString;\n var ArrayList_init = Kotlin.kotlin.collections.ArrayList_init_287e2$;\n var DoubleVector = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleVector;\n var Unit = Kotlin.kotlin.Unit;\n var ValueProperty = $module$lets_plot_base_portable.jetbrains.datalore.base.observable.property.ValueProperty;\n var Kind_CLASS = Kotlin.Kind.CLASS;\n var DoubleRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle;\n var Kind_OBJECT = Kotlin.Kind.OBJECT;\n var addAll = Kotlin.kotlin.collections.addAll_ipc267$;\n var collectionSizeOrDefault = Kotlin.kotlin.collections.collectionSizeOrDefault_ba2ldo$;\n var ArrayList_init_0 = Kotlin.kotlin.collections.ArrayList_init_ww73n8$;\n var trimMargin = Kotlin.kotlin.text.trimMargin_rjktp$;\n var round = Kotlin.kotlin.math.round_14dthe$;\n var numberToInt = Kotlin.numberToInt;\n var joinToString = Kotlin.kotlin.collections.joinToString_fmv235$;\n var trimIndent = Kotlin.kotlin.text.trimIndent_pdl1vz$;\n var RuntimeException = Kotlin.kotlin.RuntimeException;\n var contains = Kotlin.kotlin.text.contains_li3zpu$;\n var random = $module$lets_plot_base_portable.jetbrains.datalore.base.random;\n var jsObject = $module$lets_plot_base_portable.jetbrains.datalore.base.jsObject;\n var IllegalArgumentException_init = Kotlin.kotlin.IllegalArgumentException_init_pdl1vj$;\n var PlotFacets = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.PlotFacets;\n var Map = Kotlin.kotlin.collections.Map;\n var Regex_init = Kotlin.kotlin.text.Regex_init_61zpoe$;\n var ensureNotNull = Kotlin.ensureNotNull;\n var toDouble = Kotlin.kotlin.text.toDouble_pdl1vz$;\n var JsMath = Math;\n var IllegalStateException_init = Kotlin.kotlin.IllegalStateException_init_pdl1vj$;\n var zip = Kotlin.kotlin.collections.zip_45mdf7$;\n var DoubleRectangle_init = $module$lets_plot_base_portable.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$;\n var split = Kotlin.kotlin.text.split_ip8yn$;\n var indexOf = Kotlin.kotlin.text.indexOf_l5u8uk$;\n var Pair = Kotlin.kotlin.Pair;\n var logging = $module$lets_plot_base_portable.jetbrains.datalore.base.logging;\n var getKClass = Kotlin.getKClass;\n var SvgToString = $module$lets_plot_vis_svg_portable.jetbrains.datalore.vis.svgToString.SvgToString;\n var ArrowSpec$End = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.util.ArrowSpec.End;\n var ArrowSpec$Type = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.util.ArrowSpec.Type;\n var toRadians = $module$lets_plot_base_portable.jetbrains.datalore.base.math.toRadians_14dthe$;\n var ArrowSpec = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.util.ArrowSpec;\n var equals = Kotlin.equals;\n var DataFrame$Builder = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder;\n var data = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.data;\n var until = Kotlin.kotlin.ranges.until_dqglrj$;\n var toSet = Kotlin.kotlin.collections.toSet_7wnvza$;\n var HashMap_init = Kotlin.kotlin.collections.HashMap_init_q3lmfv$;\n var filterNotNull = Kotlin.kotlin.collections.filterNotNull_m3lr2h$;\n var toMutableSet = Kotlin.kotlin.collections.toMutableSet_7wnvza$;\n var DataFrame$DataFrame$Builder_init = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder_init;\n var emptyMap = Kotlin.kotlin.collections.emptyMap_q3lmfv$;\n var List = Kotlin.kotlin.collections.List;\n var numberToDouble = Kotlin.numberToDouble;\n var Iterable = Kotlin.kotlin.collections.Iterable;\n var NumberFormatException = Kotlin.kotlin.NumberFormatException;\n var checkIndexOverflow = Kotlin.kotlin.collections.checkIndexOverflow_za3lpa$;\n var coord = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.coord;\n var startsWith = Kotlin.kotlin.text.startsWith_7epoxm$;\n var removePrefix = Kotlin.kotlin.text.removePrefix_gsj5wt$;\n var emptyList = Kotlin.kotlin.collections.emptyList_287e2$;\n var to = Kotlin.kotlin.to_ujzrz7$;\n var getCallableRef = Kotlin.getCallableRef;\n var emptySet = Kotlin.kotlin.collections.emptySet_287e2$;\n var flatten = Kotlin.kotlin.collections.flatten_u0ad8z$;\n var plus = Kotlin.kotlin.collections.plus_mydzjv$;\n var mutableMapOf = Kotlin.kotlin.collections.mutableMapOf_qfcya0$;\n var DataFrame$DataFrame$Builder_init_0 = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Builder_init_dhhkv7$;\n var contains_0 = Kotlin.kotlin.collections.contains_2ws7j4$;\n var minus = Kotlin.kotlin.collections.minus_khz7k3$;\n var plus_0 = Kotlin.kotlin.collections.plus_khz7k3$;\n var plus_1 = Kotlin.kotlin.collections.plus_iwxh38$;\n var OrderOptionUtil$OrderOption = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.data.OrderOptionUtil.OrderOption;\n var mapCapacity = Kotlin.kotlin.collections.mapCapacity_za3lpa$;\n var coerceAtLeast = Kotlin.kotlin.ranges.coerceAtLeast_dqglrj$;\n var LinkedHashMap_init = Kotlin.kotlin.collections.LinkedHashMap_init_bwtc7$;\n var LinkedHashMap_init_0 = Kotlin.kotlin.collections.LinkedHashMap_init_q3lmfv$;\n var LinkedHashSet_init = Kotlin.kotlin.collections.LinkedHashSet_init_287e2$;\n var ArrayList_init_1 = Kotlin.kotlin.collections.ArrayList_init_mqih57$;\n var FacetGrid = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.facet.FacetGrid;\n var HashSet_init = Kotlin.kotlin.collections.HashSet_init_287e2$;\n var toList = Kotlin.kotlin.collections.toList_7wnvza$;\n var take = Kotlin.kotlin.collections.take_ba2ldo$;\n var FacetWrap = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.facet.FacetWrap;\n var FacetWrap$Direction = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.facet.FacetWrap.Direction;\n var StringFormat = $module$lets_plot_base_portable.jetbrains.datalore.base.stringFormat.StringFormat;\n var base = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.base;\n var IllegalStateException = Kotlin.kotlin.IllegalStateException;\n var IllegalArgumentException = Kotlin.kotlin.IllegalArgumentException;\n var isBlank = Kotlin.kotlin.text.isBlank_gw00vp$;\n var Aes = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.Aes;\n var spatial = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial;\n var DataFrame$Variable = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DataFrame.Variable;\n var SimpleFeature$Consumer = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial.SimpleFeature.Consumer;\n var firstOrNull = Kotlin.kotlin.collections.firstOrNull_7wnvza$;\n var asSequence = Kotlin.kotlin.collections.asSequence_7wnvza$;\n var flatten_0 = Kotlin.kotlin.sequences.flatten_d9bjs1$;\n var union = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial.union_86o20w$;\n var convertToGeoRectangle = $module$lets_plot_base_portable.jetbrains.datalore.base.spatial.convertToGeoRectangle_i3vl8m$;\n var boundingBox = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.boundingBox_gyuce3$;\n var limit = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.limit_106pae$;\n var limit_0 = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.limit_lddjmn$;\n var get_left = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.get_left_h9e6jg$;\n var get_right = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.get_right_h9e6jg$;\n var get_top = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.get_top_h9e6jg$;\n var get_bottom = $module$lets_plot_base_portable.jetbrains.datalore.base.typedGeometry.get_bottom_h9e6jg$;\n var mapOf = Kotlin.kotlin.collections.mapOf_qfcya0$;\n var Result = Kotlin.kotlin.Result;\n var Throwable = Error;\n var createFailure = Kotlin.kotlin.createFailure_tcv7n7$;\n var Any = Object;\n var Collection = Kotlin.kotlin.collections.Collection;\n var minus_0 = Kotlin.kotlin.collections.minus_q4559j$;\n var GeomKind = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomKind;\n var listOf_0 = Kotlin.kotlin.collections.listOf_i5x0yv$;\n var base_0 = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base;\n var removeAll = Kotlin.kotlin.collections.removeAll_qafx1e$;\n var GeomInteractionBuilder = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.interact.GeomInteractionBuilder;\n var GeomTargetLocator$LookupStrategy = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupStrategy;\n var geom = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.geom;\n var sampling = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.sampling;\n var PosProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.PosProvider;\n var pos = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.pos;\n var mapOf_0 = Kotlin.kotlin.collections.mapOf_x2b85n$;\n var GeomKind$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.GeomKind.values;\n var GeomProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.geom.GeomProvider;\n var CrossBarGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.CrossBarGeom;\n var PointRangeGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointRangeGeom;\n var BoxplotGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.BoxplotGeom;\n var StepGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.StepGeom;\n var SegmentGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.SegmentGeom;\n var PathGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PathGeom;\n var PointGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.PointGeom;\n var TextGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.TextGeom;\n var ImageGeom = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.geom.ImageGeom;\n var GuideOptions = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.GuideOptions;\n var LegendOptions = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.LegendOptions;\n var Runnable = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Runnable;\n var ColorBarOptions = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.ColorBarOptions;\n var data_0 = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.data;\n var HashSet_init_0 = Kotlin.kotlin.collections.HashSet_init_mqih57$;\n var stat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat;\n var minus_1 = Kotlin.kotlin.collections.minus_uk696c$;\n var TooltipSpecification = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.TooltipSpecification;\n var getPropertyCallableRef = Kotlin.getPropertyCallableRef;\n var data_1 = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.data;\n var Grouping = Kotlin.kotlin.collections.Grouping;\n var VarBinding = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.VarBinding;\n var first = Kotlin.kotlin.collections.first_2p1efm$;\n var LivemapConstants$DisplayMode = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode;\n var LivemapConstants$Projection = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection;\n var LiveMapOptions = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LiveMapOptions;\n var joinToString_0 = Kotlin.kotlin.collections.joinToString_cgipc5$;\n var LivemapConstants$DisplayMode$valueOf = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode.valueOf_61zpoe$;\n var LivemapConstants$DisplayMode$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.DisplayMode.values;\n var Exception = Kotlin.kotlin.Exception;\n var LivemapConstants$Projection$valueOf = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection.valueOf_61zpoe$;\n var LivemapConstants$Projection$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.livemap.LivemapConstants.Projection.values;\n var checkCountOverflow = Kotlin.kotlin.collections.checkCountOverflow_za3lpa$;\n var last = Kotlin.kotlin.collections.last_2p1efm$;\n var ClosedRange = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect.ClosedRange;\n var numberToLong = Kotlin.numberToLong;\n var firstOrNull_0 = Kotlin.kotlin.collections.firstOrNull_2p1efm$;\n var dropLast = Kotlin.kotlin.collections.dropLast_8ujjk8$;\n var last_0 = Kotlin.kotlin.collections.last_us0mfu$;\n var toList_0 = Kotlin.kotlin.collections.toList_us0mfu$;\n var MutableList = Kotlin.kotlin.collections.MutableList;\n var PlotAssembler = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.PlotAssembler;\n var GeomLayerBuilder = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.GeomLayerBuilder;\n var distinct = Kotlin.kotlin.collections.distinct_7wnvza$;\n var collect = $module$lets_plot_base_portable.jetbrains.datalore.base.gcommon.collect;\n var setOf = Kotlin.kotlin.collections.setOf_i5x0yv$;\n var scale = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale;\n var toMap = Kotlin.kotlin.collections.toMap_6hr0sd$;\n var getValue = Kotlin.kotlin.collections.getValue_t9ocha$;\n var DiscreteTransform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.DiscreteTransform;\n var transform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.transform;\n var ContinuousTransform = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.ContinuousTransform;\n var TypedScaleMap = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.assemble.TypedScaleMap;\n var DiscreteOnlyMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.DiscreteOnlyMapperProvider;\n var ContinuousOnlyMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.ContinuousOnlyMapperProvider;\n var HashMap_init_0 = Kotlin.kotlin.collections.HashMap_init_73mtqc$;\n var mapper = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.mapper;\n var AlphaMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.AlphaMapperProvider;\n var SizeMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.SizeMapperProvider;\n var Color = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Color;\n var ColorGradientMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.ColorGradientMapperProvider;\n var ColorGradient2MapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.ColorGradient2MapperProvider;\n var ColorHueMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.ColorHueMapperProvider;\n var GreyscaleLightnessMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.GreyscaleLightnessMapperProvider;\n var ColorBrewerMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.ColorBrewerMapperProvider;\n var SizeAreaMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.SizeAreaMapperProvider;\n var ScaleProviderBuilder = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.ScaleProviderBuilder;\n var MapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.MapperProvider;\n var text = $module$lets_plot_plot_common_portable.jetbrains.datalore.plot.common.text;\n var DateTimeBreaksGen = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale.transform.DateTimeBreaksGen;\n var IdentityDiscreteMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.IdentityDiscreteMapperProvider;\n var scale_0 = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.scale;\n var IdentityMapperProvider = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.scale.provider.IdentityMapperProvider;\n var Enum = Kotlin.kotlin.Enum;\n var throwISE = Kotlin.throwISE;\n var EnumInfoImpl_init = $module$lets_plot_base_portable.jetbrains.datalore.base.enums.EnumInfoImpl;\n var Bin2dStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.Bin2dStat;\n var ContourStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.ContourStat;\n var ContourfStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.ContourfStat;\n var BoxplotStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.BoxplotStat;\n var SmoothStat$Method = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.SmoothStat.Method;\n var SmoothStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.SmoothStat;\n var SmoothStat$Companion$DEF_SAMPLING_SEED = Kotlin.Long.fromInt(37);\n var CorrelationStat$Method = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.CorrelationStat.Method;\n var CorrelationStat$Type = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.CorrelationStat.Type;\n var CorrelationStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.CorrelationStat;\n var DensityStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.DensityStat;\n var AbstractDensity2dStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.AbstractDensity2dStat;\n var Density2dfStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.Density2dfStat;\n var Density2dStat = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.stat.Density2dStat;\n var TooltipSpecification$TooltipProperties = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.TooltipSpecification.TooltipProperties;\n var substringAfter = Kotlin.kotlin.text.substringAfter_j4ogox$;\n var TooltipLine = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.TooltipLine;\n var DataFrameValue = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.DataFrameValue;\n var MappingValue = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.MappingValue;\n var ConstantValue = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.tooltip.ConstantValue;\n var toList_1 = Kotlin.kotlin.collections.toList_abgq59$;\n var removeSurrounding = Kotlin.kotlin.text.removeSurrounding_90ijwr$;\n var substringBefore = Kotlin.kotlin.text.substringBefore_j4ogox$;\n var TooltipAnchor$VerticalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipAnchor.VerticalAnchor;\n var TooltipAnchor$HorizontalAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipAnchor.HorizontalAnchor;\n var TooltipAnchor = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.interact.TooltipAnchor;\n var values = $module$lets_plot_base_portable.jetbrains.datalore.base.values;\n var toMutableMap = Kotlin.kotlin.collections.toMutableMap_abgq59$;\n var StringBuilder_init = Kotlin.kotlin.text.StringBuilder_init_za3lpa$;\n var trim = Kotlin.kotlin.text.trim_gw00vp$;\n var Function = $module$lets_plot_base_portable.jetbrains.datalore.base.function.Function;\n var NamedLineType = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.linetype.NamedLineType;\n var LineType = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.linetype.LineType;\n var NamedLineType$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.linetype.NamedLineType.values;\n var PointShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.PointShape;\n var point = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point;\n var NamedShape = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape;\n var NamedShape$values = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.render.point.NamedShape.values;\n var roundToInt = Kotlin.kotlin.math.roundToInt_yrwdxr$;\n var abs = Kotlin.kotlin.math.abs_za3lpa$;\n var AxisTheme = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.theme.AxisTheme;\n var LegendPosition = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.guide.LegendPosition;\n var LegendJustification = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.guide.LegendJustification;\n var LegendDirection = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.guide.LegendDirection;\n var LegendTheme = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.theme.LegendTheme;\n var Theme = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.theme.Theme;\n var DefaultTheme = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.theme.DefaultTheme;\n var Kind_INTERFACE = Kotlin.Kind.INTERFACE;\n var hashCode = Kotlin.hashCode;\n var copyToArray = Kotlin.kotlin.collections.copyToArray;\n var kotlin_js_internal_DoubleCompanionObject = Kotlin.kotlin.js.internal.DoubleCompanionObject;\n var isFinite = Kotlin.kotlin.isFinite_yrwdxr$;\n var StatContext = $module$lets_plot_plot_base_portable.jetbrains.datalore.plot.base.StatContext;\n var Pair_0 = $module$lets_plot_base_portable.jetbrains.datalore.base.values.Pair;\n var GroupingContext = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.data.GroupingContext;\n var plus_2 = Kotlin.kotlin.collections.plus_xfiyik$;\n var listOfNotNull = Kotlin.kotlin.collections.listOfNotNull_issdgt$;\n var PointSampling = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.sampling.PointSampling;\n var GroupAwareSampling = $module$lets_plot_plot_builder_portable.jetbrains.datalore.plot.builder.sampling.GroupAwareSampling;\n var Set = Kotlin.kotlin.collections.Set;\n MonolithicCommon$PlotsBuildResult$Error.prototype = Object.create(MonolithicCommon$PlotsBuildResult.prototype);\n MonolithicCommon$PlotsBuildResult$Error.prototype.constructor = MonolithicCommon$PlotsBuildResult$Error;\n MonolithicCommon$PlotsBuildResult$Success.prototype = Object.create(MonolithicCommon$PlotsBuildResult.prototype);\n MonolithicCommon$PlotsBuildResult$Success.prototype.constructor = MonolithicCommon$PlotsBuildResult$Success;\n ArrowSpecConfig.prototype = Object.create(OptionsAccessor.prototype);\n ArrowSpecConfig.prototype.constructor = ArrowSpecConfig;\n BunchConfig.prototype = Object.create(OptionsAccessor.prototype);\n BunchConfig.prototype.constructor = BunchConfig;\n CoordConfig.prototype = Object.create(OptionsAccessor.prototype);\n CoordConfig.prototype.constructor = CoordConfig;\n FacetConfig.prototype = Object.create(OptionsAccessor.prototype);\n FacetConfig.prototype.constructor = FacetConfig;\n CoordinatesCollector$PointCoordinatesCollector.prototype = Object.create(CoordinatesCollector.prototype);\n CoordinatesCollector$PointCoordinatesCollector.prototype.constructor = CoordinatesCollector$PointCoordinatesCollector;\n CoordinatesCollector$PathCoordinatesCollector.prototype = Object.create(CoordinatesCollector.prototype);\n CoordinatesCollector$PathCoordinatesCollector.prototype.constructor = CoordinatesCollector$PathCoordinatesCollector;\n CoordinatesCollector$BoundaryCoordinatesCollector.prototype = Object.create(CoordinatesCollector.prototype);\n CoordinatesCollector$BoundaryCoordinatesCollector.prototype.constructor = CoordinatesCollector$BoundaryCoordinatesCollector;\n CoordinatesCollector$BboxCoordinatesCollector.prototype = Object.create(CoordinatesCollector.prototype);\n CoordinatesCollector$BboxCoordinatesCollector.prototype.constructor = CoordinatesCollector$BboxCoordinatesCollector;\n GeomProtoClientSide.prototype = Object.create(GeomProto.prototype);\n GeomProtoClientSide.prototype.constructor = GeomProtoClientSide;\n GuideConfig.prototype = Object.create(OptionsAccessor.prototype);\n GuideConfig.prototype.constructor = GuideConfig;\n GuideConfig$GuideNoneConfig.prototype = Object.create(GuideConfig.prototype);\n GuideConfig$GuideNoneConfig.prototype.constructor = GuideConfig$GuideNoneConfig;\n GuideConfig$LegendConfig.prototype = Object.create(GuideConfig.prototype);\n GuideConfig$LegendConfig.prototype.constructor = GuideConfig$LegendConfig;\n GuideConfig$ColorBarConfig.prototype = Object.create(GuideConfig.prototype);\n GuideConfig$ColorBarConfig.prototype.constructor = GuideConfig$ColorBarConfig;\n LayerConfig.prototype = Object.create(OptionsAccessor.prototype);\n LayerConfig.prototype.constructor = LayerConfig;\n PlotConfig.prototype = Object.create(OptionsAccessor.prototype);\n PlotConfig.prototype.constructor = PlotConfig;\n PlotConfigClientSide.prototype = Object.create(PlotConfig.prototype);\n PlotConfigClientSide.prototype.constructor = PlotConfigClientSide;\n PosConfig.prototype = Object.create(OptionsAccessor.prototype);\n PosConfig.prototype.constructor = PosConfig;\n ScaleConfig.prototype = Object.create(OptionsAccessor.prototype);\n ScaleConfig.prototype.constructor = ScaleConfig;\n StatKind.prototype = Object.create(Enum.prototype);\n StatKind.prototype.constructor = StatKind;\n TooltipConfig.prototype = Object.create(OptionsAccessor.prototype);\n TooltipConfig.prototype.constructor = TooltipConfig;\n AxisThemeConfig.prototype = Object.create(OptionsAccessor.prototype);\n AxisThemeConfig.prototype.constructor = AxisThemeConfig;\n LegendThemeConfig.prototype = Object.create(OptionsAccessor.prototype);\n LegendThemeConfig.prototype.constructor = LegendThemeConfig;\n ThemeConfig$OneTileTheme.prototype = Object.create(ThemeConfig$ConfiguredTheme.prototype);\n ThemeConfig$OneTileTheme.prototype.constructor = ThemeConfig$OneTileTheme;\n ThemeConfig$MultiTileTheme.prototype = Object.create(ThemeConfig$ConfiguredTheme.prototype);\n ThemeConfig$MultiTileTheme.prototype.constructor = ThemeConfig$MultiTileTheme;\n ViewElementConfig.prototype = Object.create(OptionsAccessor.prototype);\n ViewElementConfig.prototype.constructor = ViewElementConfig;\n PlotSpecTransformUtil$TargetSpec.prototype = Object.create(Enum.prototype);\n PlotSpecTransformUtil$TargetSpec.prototype.constructor = PlotSpecTransformUtil$TargetSpec;\n PlotConfigServerSide.prototype = Object.create(PlotConfig.prototype);\n PlotConfigServerSide.prototype.constructor = PlotConfigServerSide;\n function parsePlotSpec(spec) {\n var it = replace(spec, \"'\", '\"');\n var tmp$;\n return Kotlin.isType(tmp$ = json.JsonSupport.parseJson_61zpoe$(it), MutableMap) ? tmp$ : throwCCE();\n }\n function MonolithicCommon() {\n MonolithicCommon_instance = this;\n }\n MonolithicCommon.prototype.buildSvgImagesFromRawSpecs_k2v8cf$ = function (plotSpec, plotSize, svgToString, computationMessagesHandler) {\n var tmp$, tmp$_0;\n var plotSpec_0 = this.processRawSpecs_lqxyja$(plotSpec, false);\n var buildResult = this.buildPlotsFromProcessedSpecs_rim63o$(plotSpec_0, plotSize, null);\n if (buildResult.isError) {\n var errorMessage = (Kotlin.isType(tmp$ = buildResult, MonolithicCommon$PlotsBuildResult$Error) ? tmp$ : throwCCE()).error;\n throw RuntimeException_init(errorMessage);\n }var success = Kotlin.isType(tmp$_0 = buildResult, MonolithicCommon$PlotsBuildResult$Success) ? tmp$_0 : throwCCE();\n var $receiver = success.buildInfos;\n var destination = ArrayList_init();\n var tmp$_1;\n tmp$_1 = $receiver.iterator();\n while (tmp$_1.hasNext()) {\n var element = tmp$_1.next();\n var list = element.computationMessages;\n addAll(destination, list);\n }\n var computationMessages = destination;\n if (!computationMessages.isEmpty()) {\n computationMessagesHandler(computationMessages);\n }var $receiver_0 = success.buildInfos;\n var destination_0 = ArrayList_init_0(collectionSizeOrDefault($receiver_0, 10));\n var tmp$_2;\n tmp$_2 = $receiver_0.iterator();\n while (tmp$_2.hasNext()) {\n var item = tmp$_2.next();\n var tmp$_3 = destination_0.add_11rb$;\n var assembler = item.plotAssembler;\n var plot = assembler.createPlot();\n var plotContainer = new PlotContainerPortable(plot, item.size);\n plotContainer.ensureContentBuilt();\n tmp$_3.call(destination_0, plotContainer.svg);\n }\n var destination_1 = ArrayList_init_0(collectionSizeOrDefault(destination_0, 10));\n var tmp$_4;\n tmp$_4 = destination_0.iterator();\n while (tmp$_4.hasNext()) {\n var item_0 = tmp$_4.next();\n destination_1.add_11rb$(svgToString.render_5lup6a$(item_0));\n }\n return destination_1;\n };\n MonolithicCommon.prototype.buildPlotsFromProcessedSpecs_rim63o$ = function (plotSpec, plotSize, plotMaxWidth) {\n var tmp$;\n this.throwTestingErrors_0();\n PlotConfig$Companion_getInstance().assertPlotSpecOrErrorMessage_x7u0o8$(plotSpec);\n if (PlotConfig$Companion_getInstance().isFailure_x7u0o8$(plotSpec)) {\n var errorMessage = PlotConfig$Companion_getInstance().getErrorMessage_x7u0o8$(plotSpec);\n return new MonolithicCommon$PlotsBuildResult$Error(errorMessage);\n }if (PlotConfig$Companion_getInstance().isPlotSpec_bkhwtg$(plotSpec))\n tmp$ = new MonolithicCommon$PlotsBuildResult$Success(listOf(this.buildSinglePlotFromProcessedSpecs_0(plotSpec, plotSize, plotMaxWidth)));\n else if (PlotConfig$Companion_getInstance().isGGBunchSpec_bkhwtg$(plotSpec))\n tmp$ = this.buildGGBunchFromProcessedSpecs_0(plotSpec);\n else\n throw RuntimeException_init('Unexpected plot spec kind: ' + toString(PlotConfig$Companion_getInstance().specKind_bkhwtg$(plotSpec)));\n return tmp$;\n };\n MonolithicCommon.prototype.buildGGBunchFromProcessedSpecs_0 = function (bunchSpec) {\n var tmp$, tmp$_0;\n var bunchConfig = new BunchConfig(bunchSpec);\n if (bunchConfig.bunchItems.isEmpty())\n return new MonolithicCommon$PlotsBuildResult$Error('No plots in the bunch');\n var buildInfos = ArrayList_init();\n tmp$ = bunchConfig.bunchItems.iterator();\n while (tmp$.hasNext()) {\n var bunchItem = tmp$.next();\n var plotSpec = Kotlin.isType(tmp$_0 = bunchItem.featureSpec, MutableMap) ? tmp$_0 : throwCCE();\n var buildInfo = this.buildSinglePlotFromProcessedSpecs_0(plotSpec, PlotSizeHelper_getInstance().bunchItemSize_6ixfn5$(bunchItem), null);\n buildInfo = new MonolithicCommon$PlotBuildInfo(buildInfo.plotAssembler, buildInfo.processedPlotSpec, new DoubleVector(bunchItem.x, bunchItem.y), buildInfo.size, buildInfo.computationMessages);\n buildInfos.add_11rb$(buildInfo);\n }\n return new MonolithicCommon$PlotsBuildResult$Success(buildInfos);\n };\n function MonolithicCommon$buildSinglePlotFromProcessedSpecs$lambda(closure$computationMessages) {\n return function (it) {\n closure$computationMessages.addAll_brywnq$(it);\n return Unit;\n };\n }\n MonolithicCommon.prototype.buildSinglePlotFromProcessedSpecs_0 = function (plotSpec, plotSize, plotMaxWidth) {\n var computationMessages = ArrayList_init();\n var config = PlotConfigClientSide$Companion_getInstance().create_vb0rb2$(plotSpec, MonolithicCommon$buildSinglePlotFromProcessedSpecs$lambda(computationMessages));\n var preferredSize = new ValueProperty(PlotSizeHelper_getInstance().singlePlotSize_k8r1k3$(plotSpec, plotSize, plotMaxWidth, config.facets, config.containsLiveMap));\n var assembler = this.createPlotAssembler_rwfsgt$(config);\n return new MonolithicCommon$PlotBuildInfo(assembler, plotSpec, DoubleVector.Companion.ZERO, preferredSize, computationMessages);\n };\n MonolithicCommon.prototype.createPlotAssembler_rwfsgt$ = function (config) {\n return PlotConfigClientSideUtil_getInstance().createPlotAssembler_6u1zvq$(config);\n };\n MonolithicCommon.prototype.throwTestingErrors_0 = function () {\n };\n MonolithicCommon.prototype.processRawSpecs_lqxyja$ = function (plotSpec, frontendOnly) {\n var tmp$;\n PlotConfig$Companion_getInstance().assertPlotSpecOrErrorMessage_x7u0o8$(plotSpec);\n if (PlotConfig$Companion_getInstance().isFailure_x7u0o8$(plotSpec)) {\n return plotSpec;\n }if (frontendOnly) {\n tmp$ = plotSpec;\n } else {\n tmp$ = PlotConfigServerSide$Companion_getInstance().processTransform_2wxo1b$(plotSpec);\n }\n var plotSpec_0 = tmp$;\n if (PlotConfig$Companion_getInstance().isFailure_x7u0o8$(plotSpec_0)) {\n return plotSpec_0;\n }return PlotConfigClientSide$Companion_getInstance().processTransform_2wxo1b$(plotSpec_0);\n };\n function MonolithicCommon$PlotsBuildResult() {\n this.isError = Kotlin.isType(this, MonolithicCommon$PlotsBuildResult$Error);\n }\n function MonolithicCommon$PlotsBuildResult$Error(error) {\n MonolithicCommon$PlotsBuildResult.call(this);\n this.error = error;\n }\n MonolithicCommon$PlotsBuildResult$Error.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Error',\n interfaces: [MonolithicCommon$PlotsBuildResult]\n };\n function MonolithicCommon$PlotsBuildResult$Success(buildInfos) {\n MonolithicCommon$PlotsBuildResult.call(this);\n this.buildInfos = buildInfos;\n }\n MonolithicCommon$PlotsBuildResult$Success.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'Success',\n interfaces: [MonolithicCommon$PlotsBuildResult]\n };\n MonolithicCommon$PlotsBuildResult.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotsBuildResult',\n interfaces: []\n };\n function MonolithicCommon$PlotBuildInfo(plotAssembler, processedPlotSpec, origin, size, computationMessages) {\n this.plotAssembler = plotAssembler;\n this.processedPlotSpec = processedPlotSpec;\n this.origin = origin;\n this.size = size;\n this.computationMessages = computationMessages;\n }\n MonolithicCommon$PlotBuildInfo.prototype.bounds = function () {\n return new DoubleRectangle(this.origin, this.size.get());\n };\n MonolithicCommon$PlotBuildInfo.$metadata$ = {\n kind: Kind_CLASS,\n simpleName: 'PlotBuildInfo',\n interfaces: []\n };\n MonolithicCommon.$metadata$ = {\n kind: Kind_OBJECT,\n simpleName: 'MonolithicCommon',\n interfaces: []\n };\n var MonolithicCommon_instance = null;\n function MonolithicCommon_getInstance() {\n if (MonolithicCommon_instance === null) {\n new MonolithicCommon();\n }return MonolithicCommon_instance;\n }\n function PlotHtmlExport() {\n PlotHtmlExport_instance = this;\n }\n PlotHtmlExport.prototype.buildHtmlFromRawSpecs_dmb0ma$ = function (plotSpec, scriptUrl, iFrame, plotSize) {\n if (iFrame === void 0)\n iFrame = false;\n if (plotSize === void 0)\n plotSize = null;\n var tmp$, tmp$_0;\n var configureHtml = PlotHtmlHelper_getInstance().getStaticConfigureHtml_61zpoe$(scriptUrl);\n var displayHtml = PlotHtmlHelper_getInstance().getStaticDisplayHtmlForRawSpec_xfa7ld$(plotSpec, plotSize);\n if (iFrame) {\n tmp$ = '\\n \n '),E('\n |\n |'+Wp+'\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | Lunch\n | \n | \n | \n | \n | \n | \n | \n | \n | Dinner\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 0.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 1.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 2.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 2.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 3.0\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | count\n | \n | \n | \n | \n | \n | \n | time\n | \n | \n | \n | \n |\n '),E('\n |\n |\n |\n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | 3\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | b\n | \n | \n | \n | \n | \n | \n | a\n | \n | \n | \n | \n |\n |\n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | 3\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | b\n | \n | \n | \n | \n | \n | \n | a\n | \n | \n | \n | \n |\n |\n '),t})?i.apply(e,r):i)||(t.exports=o)},698:function(t,e,n){var i,r,o;r=[e,n(421),n(770),n(767),n(836),n(52),n(958),n(623)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o,a,s){"use strict";e.kotlin.io.println_s8jyv4$,e.kotlin.Unit;var l=n.jetbrains.datalore.plot.config.PlotConfig,u=e.kotlin.IllegalArgumentException_init_pdl1vj$,c=n.jetbrains.datalore.plot.config.PlotConfigClientSide,p=(n.jetbrains.datalore.plot.config,n.jetbrains.datalore.plot.server.config.PlotConfigServerSide,i.jetbrains.datalore.base.geometry.DoubleVector,e.kotlin.collections.ArrayList_init_287e2$),h=e.kotlin.collections.HashMap_init_q3lmfv$,_=e.kotlin.collections.Map,f=(e.kotlin.collections.emptyMap_q3lmfv$,e.Kind.OBJECT),d=e.Kind.CLASS,m=n.jetbrains.datalore.plot.config.transform.SpecChange,y=r.jetbrains.datalore.plot.base.data,$=e.kotlin.collections.List,v=e.throwCCE,g=r.jetbrains.datalore.plot.base.DataFrame.Builder_init,b=o.jetbrains.datalore.plot.common.base64,w=e.kotlin.collections.ArrayList_init_mqih57$,x=e.kotlin.Comparator,k=e.kotlin.collections.sortWith_nqfjgj$,E=e.kotlin.collections.sort_4wi501$,C=a.jetbrains.datalore.plot.common.data,S=n.jetbrains.datalore.plot.config.transform,T=n.jetbrains.datalore.plot.config.Option,O=n.jetbrains.datalore.plot.config.transform.PlotSpecTransform,N=s.jetbrains.datalore.plot;function P(){}function A(){}function j(){R=this,this.DATA_FRAME_KEY_0="__data_frame_encoded",this.DATA_SPEC_KEY_0="__data_spec_encoded"}function L(t,n){return e.compareTo(t.name,n.name)}P.prototype.isApplicable_x7u0o8$=function(t){return I().isEncodedDataSpec_za3rmp$(t)},P.prototype.apply_il3x6g$=function(t,e){var n;n=I().decode1_6uu7i0$(t),t.clear(),t.putAll_a2k3zr$(n)},P.$metadata$={kind:d,simpleName:"ClientSideDecodeChange",interfaces:[m]},A.prototype.isApplicable_x7u0o8$=function(t){return I().isEncodedDataFrame_bkhwtg$(t)},A.prototype.apply_il3x6g$=function(t,e){var n=I().decode_bkhwtg$(t);t.clear(),t.putAll_a2k3zr$(y.DataFrameUtil.toMap_dhhkv7$(n))},A.$metadata$={kind:d,simpleName:"ClientSideDecodeOldStyleChange",interfaces:[m]},j.prototype.isEncodedDataFrame_bkhwtg$=function(t){var n=1===t.size;if(n){var i,r=this.DATA_FRAME_KEY_0;n=(e.isType(i=t,_)?i:v()).containsKey_11rb$(r)}return n},j.prototype.isEncodedDataSpec_za3rmp$=function(t){var n;if(e.isType(t,_)){var i=1===t.size;if(i){var r,o=this.DATA_SPEC_KEY_0;i=(e.isType(r=t,_)?r:v()).containsKey_11rb$(o)}n=i}else n=!1;return n},j.prototype.decode_bkhwtg$=function(t){var n,i,r,o;if(!this.isEncodedDataFrame_bkhwtg$(t))throw u("Not a data frame".toString());for(var a,s=this.DATA_FRAME_KEY_0,l=e.isType(n=(e.isType(a=t,_)?a:v()).get_11rb$(s),$)?n:v(),c=e.isType(i=l.get_za3lpa$(0),$)?i:v(),p=e.isType(r=l.get_za3lpa$(1),$)?r:v(),h=e.isType(o=l.get_za3lpa$(2),$)?o:v(),f=g(),d=0;d!==c.size;++d){var m,w,x,k,E,C="string"==typeof(m=c.get_za3lpa$(d))?m:v(),S="string"==typeof(w=p.get_za3lpa$(d))?w:v(),T="boolean"==typeof(x=h.get_za3lpa$(d))?x:v(),O=y.DataFrameUtil.createVariable_puj7f4$(C,S),N=l.get_za3lpa$(3+d|0);if(T){var P=b.BinaryUtil.decodeList_61zpoe$("string"==typeof(k=N)?k:v());f.putNumeric_s1rqo9$(O,P)}else f.put_2l962d$(O,e.isType(E=N,$)?E:v())}return f.build()},j.prototype.decode1_6uu7i0$=function(t){var n,i,r;if(!this.isEncodedDataSpec_za3rmp$(t))throw u("Not an encoded data spec".toString());for(var o=e.isType(n=t.get_11rb$(this.DATA_SPEC_KEY_0),$)?n:v(),a=e.isType(i=o.get_za3lpa$(0),$)?i:v(),s=e.isType(r=o.get_za3lpa$(1),$)?r:v(),l=h(),c=0;c!==a.size;++c){var p,_,f,d,m="string"==typeof(p=a.get_za3lpa$(c))?p:v(),y="boolean"==typeof(_=s.get_za3lpa$(c))?_:v(),g=o.get_za3lpa$(2+c|0),w=y?b.BinaryUtil.decodeList_61zpoe$("string"==typeof(f=g)?f:v()):e.isType(d=g,$)?d:v();l.put_xwzc9p$(m,w)}return l},j.prototype.encode_dhhkv7$=function(t){var n,i,r=h(),o=p(),a=this.DATA_FRAME_KEY_0;r.put_xwzc9p$(a,o);var s=p(),l=p(),u=p();o.add_11rb$(s),o.add_11rb$(l),o.add_11rb$(u);var c=w(t.variables());for(k(c,new x(L)),n=c.iterator();n.hasNext();){var _=n.next();s.add_11rb$(_.name),l.add_11rb$(_.label);var f=t.isNumeric_8xm3sj$(_);u.add_11rb$(f);var d=t.get_8xm3sj$(_);if(f){var m=b.BinaryUtil.encodeList_k9kaly$(e.isType(i=d,$)?i:v());o.add_11rb$(m)}else o.add_11rb$(d)}return r},j.prototype.encode1_x7u0o8$=function(t){var n,i=h(),r=p(),o=this.DATA_SPEC_KEY_0;i.put_xwzc9p$(o,r);var a=p(),s=p();r.add_11rb$(a),r.add_11rb$(s);var l=w(t.keys);for(E(l),n=l.iterator();n.hasNext();){var u=n.next(),c=t.get_11rb$(u);if(e.isType(c,$)){var _=C.SeriesUtil.checkedDoubles_9ma18$(c),f=_.notEmptyAndCanBeCast();if(a.add_11rb$(u),s.add_11rb$(f),f){var d=b.BinaryUtil.encodeList_k9kaly$(_.cast());r.add_11rb$(d)}else r.add_11rb$(c)}}return i},j.$metadata$={kind:f,simpleName:"DataFrameEncoding",interfaces:[]};var R=null;function I(){return null===R&&new j,R}function z(){D=this}z.prototype.addDataChanges_0=function(t,e,n){var i;for(i=S.PlotSpecTransformUtil.getPlotAndLayersSpecSelectors_esgbho$(n,[T.PlotBase.DATA]).iterator();i.hasNext();){var r=i.next();t.change_t6n62v$(r,e)}return t},z.prototype.clientSideDecode_6taknv$=function(t){var e=O.Companion.builderForRawSpec();return this.addDataChanges_0(e,new P,t),this.addDataChanges_0(e,new A,t),e.build()},z.prototype.serverSideEncode_6taknv$=function(t){var e;return e=t?O.Companion.builderForRawSpec():O.Companion.builderForCleanSpec(),this.addDataChanges_0(e,new B,!1).build()},z.$metadata$={kind:f,simpleName:"DataSpecEncodeTransforms",interfaces:[]};var D=null;function M(){return null===D&&new z,D}function B(){}function U(){F=this}B.prototype.apply_il3x6g$=function(t,e){if(N.FeatureSwitch.printEncodedDataSummary_d0u64m$("DataFrameOptionHelper.encodeUpdateOption",t),N.FeatureSwitch.USE_DATA_FRAME_ENCODING){var n=I().encode1_x7u0o8$(t);t.clear(),t.putAll_a2k3zr$(n)}},B.$metadata$={kind:d,simpleName:"ServerSideEncodeChange",interfaces:[m]},U.prototype.processTransform_2wxo1b$=function(t){var e=l.Companion.isGGBunchSpec_bkhwtg$(t),n=M().clientSideDecode_6taknv$(e).apply_i49brq$(t);return c.Companion.processTransform_2wxo1b$(n)},U.$metadata$={kind:f,simpleName:"PlotConfigClientSideJvmJs",interfaces:[]};var F=null;var q=t.jetbrains||(t.jetbrains={}),G=q.datalore||(q.datalore={}),H=G.plot||(G.plot={}),Y=H.config||(H.config={}),V=Y.transform||(Y.transform={}),K=V.encode||(V.encode={});K.ClientSideDecodeChange=P,K.ClientSideDecodeOldStyleChange=A,Object.defineProperty(K,"DataFrameEncoding",{get:I}),Object.defineProperty(K,"DataSpecEncodeTransforms",{get:M}),K.ServerSideEncodeChange=B;var W=H.server||(H.server={}),X=W.config||(W.config={});return Object.defineProperty(X,"PlotConfigClientSideJvmJs",{get:function(){return null===F&&new U,F}}),B.prototype.isApplicable_x7u0o8$=m.prototype.isApplicable_x7u0o8$,t})?i.apply(e,r):i)||(t.exports=o)},362:function(t,e,n){var i,r,o;r=[e,n(421),n(521),n(836),n(958),n(767),n(770),n(564),n(623)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o,a,s,l){"use strict";var u=n.jetbrains.livemap.ui.CursorService,c=e.Kind.CLASS,p=e.kotlin.IllegalArgumentException_init_pdl1vj$,h=e.numberToInt,_=e.toString,f=i.jetbrains.datalore.plot.base.geom.PathGeom,d=i.jetbrains.datalore.plot.base.geom.util,m=e.kotlin.collections.ArrayList_init_287e2$,y=e.getCallableRef,$=i.jetbrains.datalore.plot.base.geom.SegmentGeom,v=e.kotlin.collections.ArrayList_init_ww73n8$,g=r.jetbrains.datalore.plot.common.data,b=e.ensureNotNull,w=e.kotlin.collections.emptyList_287e2$,x=o.jetbrains.datalore.base.geometry.DoubleVector,k=e.kotlin.collections.listOf_i5x0yv$,E=e.kotlin.collections.toList_7wnvza$,C=e.equals,S=i.jetbrains.datalore.plot.base.geom.PointGeom,T=o.jetbrains.datalore.base.typedGeometry.explicitVec_y7b45i$,O=Math,N=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,P=i.jetbrains.datalore.plot.base.aes,A=i.jetbrains.datalore.plot.base.Aes,j=e.kotlin.IllegalStateException_init_pdl1vj$,L=e.throwUPAE,R=a.jetbrains.datalore.plot.config.Option.Geom.LiveMap,I=e.throwCCE,z=e.kotlin.Unit,D=n.jetbrains.livemap.config.DevParams,M=n.jetbrains.livemap.config.LiveMapSpec,B=e.kotlin.ranges.IntRange,U=e.Kind.OBJECT,F=e.kotlin.collections.List,q=s.jetbrains.gis.geoprotocol.MapRegion,G=o.jetbrains.datalore.base.spatial.convertToGeoRectangle_i3vl8m$,H=n.jetbrains.livemap.core.projections.ProjectionType,Y=e.kotlin.collections.HashMap_init_q3lmfv$,V=e.kotlin.collections.Map,K=n.jetbrains.livemap.MapLocation,W=n.jetbrains.livemap.tiles,X=o.jetbrains.datalore.base.values.Color,Z=a.jetbrains.datalore.plot.config.getString_wpa7aq$,J=s.jetbrains.gis.tileprotocol.TileService.Theme.valueOf_61zpoe$,Q=n.jetbrains.livemap.api.liveMapVectorTiles_jo61jr$,tt=e.unboxChar,et=e.kotlin.collections.listOf_mh5how$,nt=e.kotlin.ranges.CharRange,it=n.jetbrains.livemap.api.liveMapGeocoding_leryx0$,rt=n.jetbrains.livemap.api,ot=e.kotlin.collections.setOf_i5x0yv$,at=o.jetbrains.datalore.base.spatial,st=o.jetbrains.datalore.base.spatial.pointsBBox_2r9fhj$,lt=o.jetbrains.datalore.base.spatial.makeSegments_8o5yvy$,ut=e.kotlin.collections.checkIndexOverflow_za3lpa$,ct=e.kotlin.collections.Collection,pt=e.kotlin.text.get_indices_gw00vp$,ht=e.toBoxedChar,_t=e.kotlin.ranges.reversed_zf1xzc$,ft=e.kotlin.text.iterator_gw00vp$,dt=i.jetbrains.datalore.plot.base.interact.GeomTargetLocator,mt=i.jetbrains.datalore.plot.base.interact.TipLayoutHint,yt=e.kotlin.collections.emptyMap_q3lmfv$,$t=i.jetbrains.datalore.plot.base.interact.GeomTarget,vt=i.jetbrains.datalore.plot.base.GeomKind,gt=e.kotlin.to_ujzrz7$,bt=i.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult,wt=e.getPropertyCallableRef,xt=e.kotlin.collections.first_2p1efm$,kt=n.jetbrains.livemap.api.point_4sq48w$,Et=n.jetbrains.livemap.api.points_5t73na$,Ct=n.jetbrains.livemap.api.polygon_z7sk6d$,St=n.jetbrains.livemap.api.polygons_6q4rqs$,Tt=n.jetbrains.livemap.api.path_noshw0$,Ot=n.jetbrains.livemap.api.paths_dvul77$,Nt=n.jetbrains.livemap.api.line_us2cr2$,Pt=n.jetbrains.livemap.api.vLines_t2cee4$,At=n.jetbrains.livemap.api.hLines_t2cee4$,jt=n.jetbrains.livemap.api.text_od6cu8$,Lt=n.jetbrains.livemap.api.texts_mbu85n$,Rt=n.jetbrains.livemap.api.pie_m5p8e8$,It=n.jetbrains.livemap.api.pies_vquu0q$,zt=n.jetbrains.livemap.api.bar_1evwdj$,Dt=n.jetbrains.livemap.api.bars_q7kt7x$,Mt=n.jetbrains.livemap.config.LiveMapFactory,Bt=n.jetbrains.livemap.config.LiveMapCanvasFigure,Ut=o.jetbrains.datalore.base.geometry.Rectangle_init_tjonv8$,Ft=i.jetbrains.datalore.plot.base.geom.LiveMapProvider.LiveMapData,qt=l.jetbrains.datalore.plot.builder,Gt=e.kotlin.collections.drop_ba2ldo$,Ht=n.jetbrains.livemap.ui,Yt=n.jetbrains.livemap.LiveMapLocation,Vt=i.jetbrains.datalore.plot.base.geom.LiveMapProvider,Kt=e.kotlin.collections.checkCountOverflow_za3lpa$,Wt=o.jetbrains.datalore.base.gcommon.collect,Xt=e.kotlin.collections.ArrayList_init_mqih57$,Zt=l.jetbrains.datalore.plot.builder.scale,Jt=i.jetbrains.datalore.plot.base.geom.util.GeomHelper,Qt=i.jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor,te=i.jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor,ee=n.jetbrains.livemap.api.limitCoord_now9aw$,ne=n.jetbrains.livemap.api.geometry_5qim13$,ie=e.kotlin.Enum,re=e.throwISE,oe=e.kotlin.collections.get_lastIndex_55thoc$,ae=e.kotlin.collections.sortedWith_eknfly$,se=e.wrapFunction,le=e.kotlin.Comparator;function ue(){this.cursorService=new u}function ce(t){this.myGeodesic_0=t}function pe(t,e){this.myPointFeatureConverter_0=new de(this,t),this.mySinglePathFeatureConverter_0=new fe(this,t,e),this.myMultiPathFeatureConverter_0=new _e(this,t,e)}function he(t,e,n){this.$outer=t,this.aesthetics_8be2vx$=e,this.myGeodesic_0=n,this.myArrowSpec_0=null,this.myAnimation_0=null}function _e(t,e,n){this.$outer=t,he.call(this,this.$outer,e,n)}function fe(t,e,n){this.$outer=t,he.call(this,this.$outer,e,n)}function de(t,e){this.$outer=t,this.myAesthetics_0=e,this.myAnimation_0=null}function me(t,e){this.myAesthetics_0=t,this.myLayerKind_0=this.getLayerKind_0(e.displayMode),this.myGeodesic_0=e.geodesic,this.myFrameSpecified_0=this.allAesMatch_0(this.myAesthetics_0,y("isFrameSet",function(t,e){return t.isFrameSet_0(e)}.bind(null,this)))}function ye(t,e,n){this.geom=t,this.geomKind=e,this.aesthetics=n}function $e(){Ce(),this.myAesthetics_rxz54u$_0=this.myAesthetics_rxz54u$_0,this.myLayers_u9pl8d$_0=this.myLayers_u9pl8d$_0,this.myLiveMapOptions_92ydlj$_0=this.myLiveMapOptions_92ydlj$_0,this.myDataAccess_85d5nb$_0=this.myDataAccess_85d5nb$_0,this.mySize_1s22w4$_0=this.mySize_1s22w4$_0,this.myDevParams_rps7kc$_0=this.myDevParams_rps7kc$_0,this.myMapLocationConsumer_hhmy08$_0=this.myMapLocationConsumer_hhmy08$_0,this.myCursorService_1uez3k$_0=this.myCursorService_1uez3k$_0,this.minZoom_0=1,this.maxZoom_0=15}function ve(){Ee=this,this.REGION_TYPE_0="type",this.REGION_DATA_0="data",this.REGION_TYPE_NAME_0="region_name",this.REGION_TYPE_IDS_0="region_ids",this.REGION_TYPE_COORDINATES_0="coordinates",this.REGION_TYPE_DATAFRAME_0="data_frame",this.POINT_X_0="lon",this.POINT_Y_0="lat",this.RECT_XMIN_0="lonmin",this.RECT_XMAX_0="lonmax",this.RECT_YMIN_0="latmin",this.RECT_YMAX_0="latmax",this.DEFAULT_SHOW_TILES_0=!0,this.DEFAULT_LOOP_Y_0=!1,this.CYLINDRICAL_PROJECTIONS_0=ot([H.GEOGRAPHIC,H.MERCATOR])}function ge(){be=this,this.URL="url"}_e.prototype=Object.create(he.prototype),_e.prototype.constructor=_e,fe.prototype=Object.create(he.prototype),fe.prototype.constructor=fe,Xe.prototype=Object.create(ie.prototype),Xe.prototype.constructor=Xe,dn.prototype=Object.create(ie.prototype),dn.prototype.constructor=dn,ue.prototype.defaultSetter_o14v8n$=function(t){this.cursorService.default=t},ue.prototype.pointerSetter_o14v8n$=function(t){this.cursorService.pointer=t},ue.$metadata$={kind:c,simpleName:"CursorServiceConfig",interfaces:[]},ce.prototype.createConfigurator_blfxhp$=function(t,e){var n,i,r,o=e.geomKind,a=new pe(e.aesthetics,this.myGeodesic_0);switch(o.name){case"POINT":n=a.toPoint_qbow5e$(e.geom),i=Je();break;case"H_LINE":n=a.toHorizontalLine(),i=en();break;case"V_LINE":n=a.toVerticalLine(),i=nn();break;case"SEGMENT":n=a.toSegment_qbow5e$(e.geom),i=tn();break;case"RECT":n=a.toRect(),i=Qe();break;case"TILE":case"BIN_2D":n=a.toTile(),i=Qe();break;case"DENSITY2D":case"CONTOUR":case"PATH":n=a.toPath_qbow5e$(e.geom),i=tn();break;case"TEXT":n=a.toText(),i=rn();break;case"DENSITY2DF":case"CONTOURF":case"POLYGON":case"MAP":n=a.toPolygon(),i=Qe();break;default:throw p("Layer '"+o.name+"' is not supported on Live Map.")}for(r=n.iterator();r.hasNext();)r.next().layerIndex=t+1|0;return Ye().createLayersConfigurator_7kwpjf$(i,n)},pe.prototype.toPoint_qbow5e$=function(t){return this.myPointFeatureConverter_0.point_n4jwzf$(t)},pe.prototype.toHorizontalLine=function(){return this.myPointFeatureConverter_0.hLine_8be2vx$()},pe.prototype.toVerticalLine=function(){return this.myPointFeatureConverter_0.vLine_8be2vx$()},pe.prototype.toSegment_qbow5e$=function(t){return this.mySinglePathFeatureConverter_0.segment_n4jwzf$(t)},pe.prototype.toRect=function(){return this.myMultiPathFeatureConverter_0.rect_8be2vx$()},pe.prototype.toTile=function(){return this.mySinglePathFeatureConverter_0.tile_8be2vx$()},pe.prototype.toPath_qbow5e$=function(t){return this.myMultiPathFeatureConverter_0.path_n4jwzf$(t)},pe.prototype.toPolygon=function(){return this.myMultiPathFeatureConverter_0.polygon_8be2vx$()},pe.prototype.toText=function(){return this.myPointFeatureConverter_0.text_8be2vx$()},he.prototype.parsePathAnimation_0=function(t){if(null==t)return null;if(e.isNumber(t))return h(t);if("string"==typeof t)switch(t){case"dash":return 1;case"plane":return 2;case"circle":return 3}throw p("Unknown path animation: '"+_(t)+"'")},he.prototype.pathToBuilder_zbovrq$=function(t,e,n){return Ke(t,this.getRender_0(n)).setGeometryData_5qim13$(e,n,this.myGeodesic_0).setArrowSpec_la4xi3$(this.myArrowSpec_0).setAnimation_s8ev37$(this.myAnimation_0)},he.prototype.getRender_0=function(t){return t?Qe():tn()},he.prototype.setArrowSpec_28xgda$=function(t){this.myArrowSpec_0=t},he.prototype.setAnimation_8ea4ql$=function(t){this.myAnimation_0=this.parsePathAnimation_0(t)},he.$metadata$={kind:c,simpleName:"PathFeatureConverterBase",interfaces:[]},_e.prototype.path_n4jwzf$=function(t){return this.setAnimation_8ea4ql$(e.isType(t,f)?t.animation:null),this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.singlePointAppender_v9bvvf$(d.GeomUtil.TO_LOCATION_X_Y)),!1)},_e.prototype.polygon_8be2vx$=function(){return this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.singlePointAppender_v9bvvf$(d.GeomUtil.TO_LOCATION_X_Y)),!0)},_e.prototype.rect_8be2vx$=function(){return this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.multiPointAppender_t2aup3$(d.GeomUtil.TO_RECTANGLE)),!0)},_e.prototype.multiPointDataByGroup_0=function(t){return d.MultiPointDataConstructor.createMultiPointDataByGroup_ugj9hh$(this.aesthetics_8be2vx$.dataPoints(),t,d.MultiPointDataConstructor.collector())},_e.prototype.process_0=function(t,e){var n,i=m();for(n=t.iterator();n.hasNext();){var r=n.next(),o=this.pathToBuilder_zbovrq$(r.aes,this.$outer.toVecs_0(r.points),e);y("add",function(t,e){return t.add_11rb$(e)}.bind(null,i))(o)}return i},_e.$metadata$={kind:c,simpleName:"MultiPathFeatureConverter",interfaces:[he]},fe.prototype.tile_8be2vx$=function(){return this.process_0(!0,this.tileGeometryGenerator_0())},fe.prototype.segment_n4jwzf$=function(t){return this.setArrowSpec_28xgda$(e.isType(t,$)?t.arrowSpec:null),this.setAnimation_8ea4ql$(e.isType(t,$)?t.animation:null),this.process_0(!1,y("pointToSegmentGeometry",function(t,e){return t.pointToSegmentGeometry_0(e)}.bind(null,this)))},fe.prototype.process_0=function(t,e){var n,i=v(this.aesthetics_8be2vx$.dataPointCount());for(n=this.aesthetics_8be2vx$.dataPoints().iterator();n.hasNext();){var r=n.next(),o=e(r);if(!o.isEmpty()){var a=this.pathToBuilder_zbovrq$(r,this.$outer.toVecs_0(o),t);y("add",function(t,e){return t.add_11rb$(e)}.bind(null,i))(a)}}return i.trimToSize(),i},fe.prototype.tileGeometryGenerator_0=function(){return t=this.getMinXYNonZeroDistance_0(this.aesthetics_8be2vx$),e=this,function(n){if(g.SeriesUtil.allFinite_rd1tgs$(n.x(),n.y(),n.width(),n.height())){var i=e.nonZero_0(b(n.width())*t.x,1),r=e.nonZero_0(b(n.height())*t.y,1);return d.GeomUtil.rectToGeometry_6y0v78$(b(n.x())-i/2,b(n.y())-r/2,b(n.x())+i/2,b(n.y())+r/2)}return w()};var t,e},fe.prototype.pointToSegmentGeometry_0=function(t){return g.SeriesUtil.allFinite_rd1tgs$(t.x(),t.y(),t.xend(),t.yend())?k([new x(b(t.x()),b(t.y())),new x(b(t.xend()),b(t.yend()))]):w()},fe.prototype.nonZero_0=function(t,e){return 0===t?e:t},fe.prototype.getMinXYNonZeroDistance_0=function(t){var e=E(t.dataPoints());if(e.size<2)return x.Companion.ZERO;for(var n=0,i=0,r=0,o=e.size-1|0;rh)throw p("Error parsing subdomains: wrong brackets order");var _,f=l+1|0,d=t.substring(f,h);if(0===d.length)throw p("Empty subdomains list");t:do{var m;for(m=ft(d);m.hasNext();){var y=tt(m.next()),$=ht(y),g=new nt(97,122),b=tt($);if(!g.contains_mef7kx$(String.fromCharCode(b).toLowerCase().charCodeAt(0))){_=!0;break t}}_=!1}while(0);if(_)throw p("subdomain list contains non-letter symbols");var w,x=t.substring(0,l),k=h+1|0,E=t.length,C=t.substring(k,E),S=v(d.length);for(w=ft(d);w.hasNext();){var T=tt(w.next()),O=S.add_11rb$,N=ht(T);O.call(S,x+String.fromCharCode(N)+C)}return S},ve.prototype.createGeocodingService_0=function(t){var n,i,r,o,a=we().URL;return null!=(i=null!=(n=(e.isType(r=t,V)?r:I()).get_11rb$(a))?it((o=n,function(t){var e;return t.url="string"==typeof(e=o)?e:I(),z})):null)?i:rt.Services.bogusGeocodingService()},ve.$metadata$={kind:U,simpleName:"Companion",interfaces:[]};var Ee=null;function Ce(){return null===Ee&&new ve,Ee}function Se(){Te=this}Se.prototype.calculateBoundingBox_d3e2cz$=function(t){return st(at.BBOX_CALCULATOR,t)},Se.prototype.calculateBoundingBox_2a5262$=function(t,e){if(t.size!==e.size)throw p("Longitude list count is not equal Latitude list count.".toString());return at.BBOX_CALCULATOR.calculateBoundingBox_qpfwx8$(lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),t.size),lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),t.size))},Se.prototype.calculateBoundingBox_55b83s$=function(t,e,n,i){var r=t.size;if(e.size!==r||n.size!==r||i.size!==r)throw p("Counts of 'minLongitudes', 'minLatitudes', 'maxLongitudes', 'maxLatitudes' lists are not equal.".toString());return at.BBOX_CALCULATOR.calculateBoundingBox_qpfwx8$(lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,n)),r),lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,i)),r))},Se.$metadata$={kind:U,simpleName:"BboxUtil",interfaces:[]};var Te=null;function Oe(){return null===Te&&new Se,Te}function Ne(t,e){var n;this.myTargetSource_0=e,this.myLiveMap_0=null,t.map_2o04qz$((n=this,function(t){return n.myLiveMap_0=t,z}))}function Pe(){He=this}function Ae(t,e){return function(n){switch(t.name){case"POINT":Et(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toPointBuilder())&&y("point",function(t,e){return kt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"POLYGON":St(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();Ct(e,i.createPolygonConfigurator())}return z}}(e));break;case"PATH":Ot(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toPathBuilder())&&y("path",function(t,e){return Tt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"V_LINE":Pt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toLineBuilder())&&y("line",function(t,e){return Nt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"H_LINE":At(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toLineBuilder())&&y("line",function(t,e){return Nt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"TEXT":Lt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toTextBuilder())&&y("text",function(t,e){return jt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"PIE":It(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toChartBuilder())&&y("pie",function(t,e){return Rt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"BAR":Dt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toChartBuilder())&&y("bar",function(t,e){return zt(t,e),z}.bind(null,e))(i)}return z}}(e));break;default:throw j(("Unsupported layer kind: "+t).toString())}return z}}function je(t,e,n){if(this.myLiveMapOptions_0=e,this.liveMapSpecBuilder_0=null,this.myTargetSource_0=Y(),t.isEmpty())throw p("Failed requirement.".toString());if(!xt(t).isLiveMap)throw p("geom_livemap have to be the very first geom after ggplot()".toString());var i,r,o,a=Le,s=v(N(t,10));for(i=t.iterator();i.hasNext();){var l=i.next();s.add_11rb$(a(l))}var u=0;for(r=s.iterator();r.hasNext();){var c,h=r.next(),_=ut((u=(o=u)+1|0,o));for(c=h.aesthetics.dataPoints().iterator();c.hasNext();){var f=c.next(),d=this.myTargetSource_0,m=gt(_,f.index()),y=h.contextualMapping;d.put_xwzc9p$(m,y)}}var $,g=Gt(t,1),b=v(N(g,10));for($=g.iterator();$.hasNext();){var w=$.next();b.add_11rb$(a(w))}var x,k=v(N(b,10));for(x=b.iterator();x.hasNext();){var E=x.next();k.add_11rb$(new ye(E.geom,E.geomKind,E.aesthetics))}var C=k,S=a(xt(t));this.liveMapSpecBuilder_0=(new $e).liveMapOptions_d2y5pu$(this.myLiveMapOptions_0).aesthetics_m7huy5$(S.aesthetics).dataAccess_c3j6od$(S.dataAccess).layers_ipzze3$(C).devParams_5pp8sb$(new D(this.myLiveMapOptions_0.devParams)).mapLocationConsumer_te0ohe$(Re).cursorService_kmk1wb$(n)}function Le(t){return qt.LayerRendererUtil.createLayerRendererData_knseyn$(t,yt(),yt())}function Re(t){return Ht.Clipboard.copy_61zpoe$(Yt.Companion.getLocationString_wthzt5$(t)),z}$e.$metadata$={kind:c,simpleName:"LiveMapSpecBuilder",interfaces:[]},Ne.prototype.search_gpjtzr$=function(t){var e,n,i;if(null!=(n=null!=(e=this.myLiveMap_0)?e.searchResult():null)){var r,o,a;if(r=et(new $t(n.index,mt.Companion.cursorTooltip_itpcqk$(t,n.color),yt())),o=vt.LIVE_MAP,null==(a=this.myTargetSource_0.get_11rb$(gt(n.layerIndex,n.index))))throw j("Can't find target.".toString());i=new bt(r,0,o,a,!1)}else i=null;return i},Ne.$metadata$={kind:c,simpleName:"LiveMapTargetLocator",interfaces:[dt]},Pe.prototype.injectLiveMapProvider_q1corz$=function(t,n,i){var r;for(r=t.iterator();r.hasNext();){var o,a=r.next(),s=wt("isLiveMap",1,(function(t){return t.isLiveMap}));t:do{var l;if(e.isType(a,ct)&&a.isEmpty()){o=!1;break t}for(l=a.iterator();l.hasNext();)if(s(l.next())){o=!0;break t}o=!1}while(0);if(o){var u,c=wt("isLiveMap",1,(function(t){return t.isLiveMap}));t:do{var h;if(e.isType(a,ct)&&a.isEmpty()){u=0;break t}var _=0;for(h=a.iterator();h.hasNext();)c(h.next())&&Kt(_=_+1|0);u=_}while(0);if(1!==u)throw p("Failed requirement.".toString());if(!xt(a).isLiveMap)throw p("Failed requirement.".toString());xt(a).setLiveMapProvider_kld0fp$(new je(a,n,i.cursorService))}}},Pe.prototype.createLayersConfigurator_7kwpjf$=function(t,e){return Ae(t,e)},je.prototype.createLiveMap_wthzt5$=function(t){var e=new Mt(this.liveMapSpecBuilder_0.size_gpjtzr$(t.dimension).build()).createLiveMap(),n=new Bt(e);return n.setBounds_vfns7u$(Ut(h(t.origin.x),h(t.origin.y),h(t.dimension.x),h(t.dimension.y))),new Ft(n,new Ne(e,this.myTargetSource_0))},je.$metadata$={kind:c,simpleName:"MyLiveMapProvider",interfaces:[Vt]},Pe.$metadata$={kind:U,simpleName:"LiveMapUtil",interfaces:[]};var Ie,ze,De,Me,Be,Ue,Fe,qe,Ge,He=null;function Ye(){return null===He&&new Pe,He}function Ve(){this.myP_0=null,this.indices_0=w(),this.myArrowSpec_0=null,this.myValueArray_0=w(),this.myColorArray_0=w(),this.myLayerKind=null,this.geometry=null,this.point=null,this.animation=0,this.geodesic=!1,this.layerIndex=null}function Ke(t,e,n){return n=n||Object.create(Ve.prototype),Ve.call(n),n.myLayerKind=e,n.myP_0=t,n}function We(t,e,n){return n=n||Object.create(Ve.prototype),Ve.call(n),n.myLayerKind=e,n.myP_0=t.aes,n.indices_0=t.indices,n.myValueArray_0=t.values,n.myColorArray_0=t.colors,n}function Xe(t,e){ie.call(this),this.name$=t,this.ordinal$=e}function Ze(){Ze=function(){},Ie=new Xe("POINT",0),ze=new Xe("POLYGON",1),De=new Xe("PATH",2),Me=new Xe("H_LINE",3),Be=new Xe("V_LINE",4),Ue=new Xe("TEXT",5),Fe=new Xe("PIE",6),qe=new Xe("BAR",7),Ge=new Xe("HEATMAP",8)}function Je(){return Ze(),Ie}function Qe(){return Ze(),ze}function tn(){return Ze(),De}function en(){return Ze(),Me}function nn(){return Ze(),Be}function rn(){return Ze(),Ue}function on(){return Ze(),Fe}function an(){return Ze(),qe}function sn(){return Ze(),Ge}Object.defineProperty(Ve.prototype,"index",{configurable:!0,get:function(){return this.myP_0.index()}}),Object.defineProperty(Ve.prototype,"shape",{configurable:!0,get:function(){return b(this.myP_0.shape()).code}}),Object.defineProperty(Ve.prototype,"size",{configurable:!0,get:function(){return P.AestheticsUtil.textSize_l6g9mh$(this.myP_0)}}),Object.defineProperty(Ve.prototype,"speed",{configurable:!0,get:function(){return b(this.myP_0.speed())}}),Object.defineProperty(Ve.prototype,"flow",{configurable:!0,get:function(){return b(this.myP_0.flow())}}),Object.defineProperty(Ve.prototype,"fillColor",{configurable:!0,get:function(){return this.colorWithAlpha_0(b(this.myP_0.fill()))}}),Object.defineProperty(Ve.prototype,"strokeColor",{configurable:!0,get:function(){return C(this.myLayerKind,Qe())?b(this.myP_0.color()):this.colorWithAlpha_0(b(this.myP_0.color()))}}),Object.defineProperty(Ve.prototype,"label",{configurable:!0,get:function(){var t,e;return null!=(e=null!=(t=this.myP_0.label())?t.toString():null)?e:"n/a"}}),Object.defineProperty(Ve.prototype,"family",{configurable:!0,get:function(){return this.myP_0.family()}}),Object.defineProperty(Ve.prototype,"hjust",{configurable:!0,get:function(){return this.hjust_0(this.myP_0.hjust())}}),Object.defineProperty(Ve.prototype,"vjust",{configurable:!0,get:function(){return this.vjust_0(this.myP_0.vjust())}}),Object.defineProperty(Ve.prototype,"angle",{configurable:!0,get:function(){return b(this.myP_0.angle())}}),Object.defineProperty(Ve.prototype,"fontface",{configurable:!0,get:function(){var t=this.myP_0.fontface();return C(t,P.AesInitValue.get_31786j$(A.Companion.FONTFACE))?"":t}}),Object.defineProperty(Ve.prototype,"radius",{configurable:!0,get:function(){switch(this.myLayerKind.name){case"POLYGON":case"PATH":case"H_LINE":case"V_LINE":case"POINT":case"PIE":case"BAR":var t=b(this.myP_0.shape()).size_l6g9mh$(this.myP_0)/2;return O.ceil(t);case"HEATMAP":return b(this.myP_0.size());case"TEXT":return 0;default:return e.noWhenBranchMatched()}}}),Object.defineProperty(Ve.prototype,"strokeWidth",{configurable:!0,get:function(){switch(this.myLayerKind.name){case"POLYGON":case"PATH":case"H_LINE":case"V_LINE":return P.AestheticsUtil.strokeWidth_l6g9mh$(this.myP_0);case"POINT":case"PIE":case"BAR":return 1;case"TEXT":case"HEATMAP":return 0;default:return e.noWhenBranchMatched()}}}),Object.defineProperty(Ve.prototype,"lineDash",{configurable:!0,get:function(){var t=this.myP_0.lineType();if(t.isSolid||t.isBlank)return w();var e,n=P.AestheticsUtil.strokeWidth_l6g9mh$(this.myP_0);return Xt(Wt.Lists.transform_l7riir$(t.dashArray,(e=n,function(t){return t*e})))}}),Object.defineProperty(Ve.prototype,"colorArray_0",{configurable:!0,get:function(){return this.myLayerKind===on()&&this.allZeroes_0(this.myValueArray_0)?this.createNaColorList_0(this.myValueArray_0.size):this.myColorArray_0}}),Ve.prototype.allZeroes_0=function(t){var n,i=y("equals",function(t,e){return C(t,e)}.bind(null,0));t:do{var r;if(e.isType(t,ct)&&t.isEmpty()){n=!0;break t}for(r=t.iterator();r.hasNext();)if(!i(r.next())){n=!1;break t}n=!0}while(0);return n},Ve.prototype.createNaColorList_0=function(t){for(var e=v(t),n=0;n0&&(a=a+"/"+l);var u=a;return d(o).replaceFirst_x2uqeu$(t,u)},le.prototype.scaleFontValue_0=function(t,e){return null==t?"":(t*e).toString()+"px"},le.$metadata$={kind:s,simpleName:"CssStyleUtil",interfaces:[]};var ue=null;function ce(){this.myLastTick_0=g,this.myDt_0=g}function pe(){}function he(t,e){return function(n){return e.schedule_klfg04$(function(t,e){return function(){return t.success_11rb$(e),w}}(t,n)),w}}function _e(t,e){return function(n){return e.schedule_klfg04$(function(t,e){return function(){return t.failure_tcv7n7$(e),w}}(t,n)),w}}function fe(t){this.myEventHandlers_51nth5$_0=E()}function de(t,e,n){this.closure$addReg=t,this.this$EventPeer=e,this.closure$eventSpec=n}function me(t){this.closure$event=t}function ye(t,e,n){this.size_mf5u5r$_0=e,this.context2d_imt5ib$_0=1===n?t:new $e(t,n)}function $e(t,e){this.myContext2d_0=t,this.myScale_0=e}function ve(t){this.myCanvasControl_0=t,this.canvas=null,this.canvas=this.myCanvasControl_0.createCanvas_119tl4$(this.myCanvasControl_0.size),this.myCanvasControl_0.addChild_eqkm0m$(this.canvas)}function ge(){}function be(){this.myHandle_0=null,this.myIsStarted_0=!1,this.myIsStarted_0=!1}function we(t,n,i){var r;Ce(),ye.call(this,new Pe(e.isType(r=t.getContext("2d"),CanvasRenderingContext2D)?r:$()),n,i),this.canvasElement=t,N(this.canvasElement.style,n.x),P(this.canvasElement.style,n.y);var o=this.canvasElement,a=n.x*i;o.width=A(j.ceil(a));var s=this.canvasElement,l=n.y*i;s.height=A(j.ceil(l))}function xe(t){this.$outer=t}function ke(){Ee=this,this.DEVICE_PIXEL_RATIO=window.devicePixelRatio}ce.prototype.tick_s8cxhz$=function(t){return this.myLastTick_0.toNumber()>0&&(this.myDt_0=t.subtract(this.myLastTick_0)),this.myLastTick_0=t,this.myDt_0},ce.prototype.dt=function(){return this.myDt_0},ce.$metadata$={kind:a,simpleName:"DeltaTime",interfaces:[]},pe.$metadata$={kind:o,simpleName:"Dispatcher",interfaces:[]},de.prototype.dispose=function(){this.closure$addReg.remove(),u(this.this$EventPeer.myEventHandlers_51nth5$_0.get_11rb$(this.closure$eventSpec)).isEmpty&&(this.this$EventPeer.myEventHandlers_51nth5$_0.remove_11rb$(this.closure$eventSpec),this.this$EventPeer.onSpecRemoved_1gkqfp$(this.closure$eventSpec))},de.$metadata$={kind:a,interfaces:[p]},fe.prototype.addEventHandler_b14a3c$=function(t,e){if(!this.myEventHandlers_51nth5$_0.containsKey_11rb$(t)){var n=this.myEventHandlers_51nth5$_0,i=new x;n.put_xwzc9p$(t,i),this.onSpecAdded_1gkqfp$(t)}var r=u(this.myEventHandlers_51nth5$_0.get_11rb$(t)).add_11rb$(e);return c.Companion.from_gg3y3y$(new de(r,this,t))},me.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},me.$metadata$={kind:a,interfaces:[k]},fe.prototype.dispatch_b6y3vz$=function(t,e){var n;null!=(n=this.myEventHandlers_51nth5$_0.get_11rb$(t))&&n.fire_kucmxw$(new me(e))},fe.$metadata$={kind:a,simpleName:"EventPeer",interfaces:[]},Object.defineProperty(ye.prototype,"size",{get:function(){return this.size_mf5u5r$_0}}),Object.defineProperty(ye.prototype,"context2d",{configurable:!0,get:function(){return this.context2d_imt5ib$_0}}),ye.$metadata$={kind:a,simpleName:"ScaledCanvas",interfaces:[Q]},$e.prototype.scaled_0=function(t){return this.myScale_0*t},$e.prototype.descaled_0=function(t){return t/this.myScale_0},$e.prototype.scaled_1=function(t){if(1===this.myScale_0)return t;for(var e=new Float64Array(t.length),n=0;n!==t.length;++n)e[n]=this.scaled_0(t[n]);return e},$e.prototype.scaled_2=function(t){return t.copy_edneyn$(void 0,void 0,t.fontSize*this.myScale_0)},$e.prototype.drawImage_xo47pw$=function(t,e,n){this.myContext2d_0.drawImage_xo47pw$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.drawImage_nks7bk$=function(t,e,n,i,r){this.myContext2d_0.drawImage_nks7bk$(t,this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r))},$e.prototype.drawImage_urnjjc$=function(t,e,n,i,r,o,a,s,l){this.myContext2d_0.drawImage_urnjjc$(t,this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r),this.scaled_0(o),this.scaled_0(a),this.scaled_0(s),this.scaled_0(l))},$e.prototype.beginPath=function(){this.myContext2d_0.beginPath()},$e.prototype.closePath=function(){this.myContext2d_0.closePath()},$e.prototype.stroke=function(){this.myContext2d_0.stroke()},$e.prototype.fill=function(){this.myContext2d_0.fill()},$e.prototype.fillRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.fillRect_6y0v78$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i))},$e.prototype.moveTo_lu1900$=function(t,e){this.myContext2d_0.moveTo_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.lineTo_lu1900$=function(t,e){this.myContext2d_0.lineTo_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.arc_6p3vsx$$default=function(t,e,n,i,r,o){this.myContext2d_0.arc_6p3vsx$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),i,r,o)},$e.prototype.save=function(){this.myContext2d_0.save()},$e.prototype.restore=function(){this.myContext2d_0.restore()},$e.prototype.setFillStyle_2160e9$=function(t){this.myContext2d_0.setFillStyle_2160e9$(t)},$e.prototype.setStrokeStyle_2160e9$=function(t){this.myContext2d_0.setStrokeStyle_2160e9$(t)},$e.prototype.setGlobalAlpha_14dthe$=function(t){this.myContext2d_0.setGlobalAlpha_14dthe$(t)},$e.prototype.setFont_ov8mpe$=function(t){this.myContext2d_0.setFont_ov8mpe$(this.scaled_2(t))},$e.prototype.setLineWidth_14dthe$=function(t){this.myContext2d_0.setLineWidth_14dthe$(this.scaled_0(t))},$e.prototype.strokeRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.strokeRect_6y0v78$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i))},$e.prototype.strokeText_ai6r6m$=function(t,e,n){this.myContext2d_0.strokeText_ai6r6m$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.fillText_ai6r6m$=function(t,e,n){this.myContext2d_0.fillText_ai6r6m$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.scale_lu1900$=function(t,e){this.myContext2d_0.scale_lu1900$(t,e)},$e.prototype.rotate_14dthe$=function(t){this.myContext2d_0.rotate_14dthe$(t)},$e.prototype.translate_lu1900$=function(t,e){this.myContext2d_0.translate_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.transform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.transform_15yvbs$(t,e,n,i,this.scaled_0(r),this.scaled_0(o))},$e.prototype.bezierCurveTo_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.bezierCurveTo_15yvbs$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r),this.scaled_0(o))},$e.prototype.setLineJoin_v2gigt$=function(t){this.myContext2d_0.setLineJoin_v2gigt$(t)},$e.prototype.setLineCap_useuqn$=function(t){this.myContext2d_0.setLineCap_useuqn$(t)},$e.prototype.setTextBaseline_5cz80h$=function(t){this.myContext2d_0.setTextBaseline_5cz80h$(t)},$e.prototype.setTextAlign_iwro1z$=function(t){this.myContext2d_0.setTextAlign_iwro1z$(t)},$e.prototype.setTransform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.setTransform_15yvbs$(t,e,n,i,this.scaled_0(r),this.scaled_0(o))},$e.prototype.fillEvenOdd=function(){this.myContext2d_0.fillEvenOdd()},$e.prototype.setLineDash_gf7tl1$=function(t){this.myContext2d_0.setLineDash_gf7tl1$(this.scaled_1(t))},$e.prototype.measureText_61zpoe$=function(t){return this.descaled_0(this.myContext2d_0.measureText_61zpoe$(t))},$e.prototype.clearRect_wthzt5$=function(t){this.myContext2d_0.clearRect_wthzt5$(new C(t.origin.mul_14dthe$(2),t.dimension.mul_14dthe$(2)))},$e.$metadata$={kind:a,simpleName:"ScaledContext2d",interfaces:[kt]},Object.defineProperty(ve.prototype,"context",{configurable:!0,get:function(){return this.canvas.context2d}}),Object.defineProperty(ve.prototype,"size",{configurable:!0,get:function(){return this.myCanvasControl_0.size}}),ve.prototype.createCanvas=function(){return this.myCanvasControl_0.createCanvas_119tl4$(this.myCanvasControl_0.size)},ve.prototype.dispose=function(){this.myCanvasControl_0.removeChild_eqkm0m$(this.canvas)},ve.$metadata$={kind:a,simpleName:"SingleCanvasControl",interfaces:[]},ge.$metadata$={kind:o,simpleName:"CanvasFigure",interfaces:[S]},be.prototype.start=function(){this.myIsStarted_0||(this.myIsStarted_0=!0,this.requestNextFrame_0())},be.prototype.stop=function(){this.myIsStarted_0&&(this.myIsStarted_0=!1,window.cancelAnimationFrame(u(this.myHandle_0)))},be.prototype.execute_0=function(t){this.myIsStarted_0&&(this.handle_s8cxhz$(e.Long.fromNumber(t)),this.requestNextFrame_0())},be.prototype.requestNextFrame_0=function(){var t;this.myHandle_0=window.requestAnimationFrame((t=this,function(e){return t.execute_0(e),w}))},be.$metadata$={kind:a,simpleName:"DomAnimationTimer",interfaces:[V]},we.prototype.takeSnapshot=function(){return O.Asyncs.constant_mh5how$(new xe(this))},Object.defineProperty(xe.prototype,"canvasElement",{configurable:!0,get:function(){return this.$outer.canvasElement}}),xe.$metadata$={kind:a,simpleName:"DomSnapshot",interfaces:[tt]},ke.prototype.create_duqvgq$=function(t,n){var i;return new we(e.isType(i=document.createElement("canvas"),HTMLCanvasElement)?i:$(),t,n)},ke.$metadata$={kind:s,simpleName:"Companion",interfaces:[]};var Ee=null;function Ce(){return null===Ee&&new ke,Ee}function Se(t,e,n){this.myRootElement_0=t,this.size_malc5o$_0=e,this.myEventPeer_0=n}function Te(t){this.closure$eventHandler=t,be.call(this)}function Oe(t,n,i,r){return function(o){var a,s,l;if(null!=t){var u,c=t;l=e.isType(u=n.createCanvas_119tl4$(c),we)?u:$()}else l=null;var p=null!=(a=l)?a:Ce().create_duqvgq$(new M(i.width,i.height),1);return(e.isType(s=p.canvasElement.getContext("2d"),CanvasRenderingContext2D)?s:$()).drawImage(i,0,0,p.canvasElement.width,p.canvasElement.height),p.takeSnapshot().onSuccess_qlkmfe$(function(t){return function(e){return t(e),w}}(r))}}function Ne(t,e){var n;fe.call(this,q(G)),this.myEventTarget_0=t,this.myTargetBounds_0=e,this.myButtonPressed_0=!1,this.myWasDragged_0=!1,this.myButtonPressCoord_0=null,this.myDragToleranceDistance_0=3,this.handle_0(U.Companion.MOUSE_ENTER,(n=this,function(t){if(n.isHitOnTarget_0(t))return n.dispatch_b6y3vz$(G.MOUSE_ENTERED,n.translate_0(t)),w})),this.handle_0(U.Companion.MOUSE_LEAVE,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.dispatch_b6y3vz$(G.MOUSE_LEFT,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.CLICK,function(t){return function(e){if(!t.myWasDragged_0){if(!t.isHitOnTarget_0(e))return;t.dispatch_b6y3vz$(G.MOUSE_CLICKED,t.translate_0(e))}return t.myWasDragged_0=!1,w}}(this)),this.handle_0(U.Companion.DOUBLE_CLICK,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.dispatch_b6y3vz$(G.MOUSE_DOUBLE_CLICKED,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_DOWN,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.myButtonPressed_0=!0,t.myButtonPressCoord_0=new M(A(e.x),A(e.y)),t.dispatch_b6y3vz$(G.MOUSE_PRESSED,F.DomEventUtil.translateInPageCoord_tfvzir$(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_UP,function(t){return function(e){return t.myButtonPressed_0=!1,t.myButtonPressCoord_0=null,t.dispatch_b6y3vz$(G.MOUSE_RELEASED,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_MOVE,function(t){return function(e){var n,i,r;if(t.myWasDragged_0)t.dispatch_b6y3vz$(G.MOUSE_DRAGGED,F.DomEventUtil.translateInPageCoord_tfvzir$(e));else if(t.myButtonPressed_0&&!t.myWasDragged_0)(null!=(r=null!=(i=null!=(n=t.myButtonPressCoord_0)?n.sub_119tl4$(new M(A(e.x),A(e.y))):null)?i.length():null)?r:0)>t.myDragToleranceDistance_0&&(t.myWasDragged_0=!0,t.dispatch_b6y3vz$(G.MOUSE_DRAGGED,F.DomEventUtil.translateInPageCoord_tfvzir$(e)));else if(!t.myButtonPressed_0&&!t.myWasDragged_0){if(!t.isHitOnTarget_0(e))return;t.dispatch_b6y3vz$(G.MOUSE_MOVED,t.translate_0(e))}return w}}(this))}function Pe(t){this.myContext2d_0=t}we.$metadata$={kind:a,simpleName:"DomCanvas",interfaces:[ye]},Object.defineProperty(Se.prototype,"size",{get:function(){return this.size_malc5o$_0}}),Te.prototype.handle_s8cxhz$=function(t){this.closure$eventHandler.onEvent_s8cxhz$(t)},Te.$metadata$={kind:a,interfaces:[be]},Se.prototype.createAnimationTimer_ckdfex$=function(t){return new Te(t)},Se.prototype.addEventHandler_mfdhbe$=function(t,e){return this.myEventPeer_0.addEventHandler_b14a3c$(t,L((n=e,function(t){return n.onEvent_11rb$(t),w})));var n},Se.prototype.createCanvas_119tl4$=function(t){var e=Ce().create_duqvgq$(t,Ce().DEVICE_PIXEL_RATIO);return I(e.canvasElement.style,R.ABSOLUTE),e},Se.prototype.createSnapshot_61zpoe$=function(t){return this.createSnapshotAsync_0(t,null)},Se.prototype.createSnapshot_50eegg$=function(t,e){var n={type:"image/png"};return this.createSnapshotAsync_0(URL.createObjectURL(new Blob([t],n)),e)},Se.prototype.createSnapshotAsync_0=function(t,e){void 0===e&&(e=null);var n=new z,i=new Image;return i.onload=this.onLoad_0(i,e,D("success",function(t,e){return t.success_11rb$(e),w}.bind(null,n))),i.src=t,n},Se.prototype.onLoad_0=function(t,e,n){return Oe(e,this,t,n)},Se.prototype.addChild_eqkm0m$=function(t){var n;this.myRootElement_0.appendChild((e.isType(n=t,we)?n:$()).canvasElement)},Se.prototype.addChild_fwfip8$=function(t,n){var i;this.myRootElement_0.insertBefore((e.isType(i=n,we)?i:$()).canvasElement,this.myRootElement_0.childNodes[t])},Se.prototype.removeChild_eqkm0m$=function(t){var n;this.myRootElement_0.removeChild((e.isType(n=t,we)?n:$()).canvasElement)},Se.prototype.schedule_klfg04$=function(t){t()},Ne.prototype.handle_0=function(t,e){var n;this.targetNode_0(t).addEventListener(t.name,new B((n=e,function(t){return n(t),!1})))},Ne.prototype.targetNode_0=function(t){return T(t,U.Companion.MOUSE_MOVE)||T(t,U.Companion.MOUSE_UP)?document:this.myEventTarget_0},Ne.prototype.onSpecAdded_1gkqfp$=function(t){},Ne.prototype.onSpecRemoved_1gkqfp$=function(t){},Ne.prototype.isHitOnTarget_0=function(t){return this.myTargetBounds_0.contains_119tl4$(new M(A(t.offsetX),A(t.offsetY)))},Ne.prototype.translate_0=function(t){return F.DomEventUtil.translateInTargetCoordWithOffset_6zzdys$(t,this.myEventTarget_0,this.myTargetBounds_0.origin)},Ne.$metadata$={kind:a,simpleName:"DomEventPeer",interfaces:[fe]},Se.$metadata$={kind:a,simpleName:"DomCanvasControl",interfaces:[et]},Pe.prototype.convertLineJoin_0=function(t){var n;switch(t.name){case"BEVEL":n="bevel";break;case"MITER":n="miter";break;case"ROUND":n="round";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertLineCap_0=function(t){var n;switch(t.name){case"BUTT":n="butt";break;case"ROUND":n="round";break;case"SQUARE":n="square";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertTextBaseline_0=function(t){var n;switch(t.name){case"ALPHABETIC":n="alphabetic";break;case"BOTTOM":n="bottom";break;case"MIDDLE":n="middle";break;case"TOP":n="top";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertTextAlign_0=function(t){var n;switch(t.name){case"CENTER":n="center";break;case"END":n="end";break;case"START":n="start";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.drawImage_xo47pw$=function(t,n,i){var r,o=e.isType(r=t,xe)?r:$();this.myContext2d_0.drawImage(o.canvasElement,n,i)},Pe.prototype.drawImage_nks7bk$=function(t,n,i,r,o){var a,s=e.isType(a=t,xe)?a:$();this.myContext2d_0.drawImage(s.canvasElement,n,i,r,o)},Pe.prototype.drawImage_urnjjc$=function(t,n,i,r,o,a,s,l,u){var c,p=e.isType(c=t,xe)?c:$();this.myContext2d_0.drawImage(p.canvasElement,n,i,r,o,a,s,l,u)},Pe.prototype.beginPath=function(){this.myContext2d_0.beginPath()},Pe.prototype.closePath=function(){this.myContext2d_0.closePath()},Pe.prototype.stroke=function(){this.myContext2d_0.stroke()},Pe.prototype.fill=function(){this.myContext2d_0.fill("nonzero")},Pe.prototype.fillEvenOdd=function(){this.myContext2d_0.fill("evenodd")},Pe.prototype.fillRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.fillRect(t,e,n,i)},Pe.prototype.moveTo_lu1900$=function(t,e){this.myContext2d_0.moveTo(t,e)},Pe.prototype.lineTo_lu1900$=function(t,e){this.myContext2d_0.lineTo(t,e)},Pe.prototype.arc_6p3vsx$$default=function(t,e,n,i,r,o){this.myContext2d_0.arc(t,e,n,i,r,o)},Pe.prototype.save=function(){this.myContext2d_0.save()},Pe.prototype.restore=function(){this.myContext2d_0.restore()},Pe.prototype.setFillStyle_2160e9$=function(t){this.myContext2d_0.fillStyle=null!=t?t.toCssColor():null},Pe.prototype.setStrokeStyle_2160e9$=function(t){this.myContext2d_0.strokeStyle=null!=t?t.toCssColor():null},Pe.prototype.setGlobalAlpha_14dthe$=function(t){this.myContext2d_0.globalAlpha=t},Pe.prototype.toCssString_0=function(t){var n,i;switch(t.fontWeight.name){case"NORMAL":n="normal";break;case"BOLD":n="bold";break;default:n=e.noWhenBranchMatched()}var r=n;switch(t.fontStyle.name){case"NORMAL":i="normal";break;case"ITALIC":i="italic";break;default:i=e.noWhenBranchMatched()}return i+" "+r+" "+t.fontSize+"px "+t.fontFamily},Pe.prototype.setFont_ov8mpe$=function(t){this.myContext2d_0.font=this.toCssString_0(t)},Pe.prototype.setLineWidth_14dthe$=function(t){this.myContext2d_0.lineWidth=t},Pe.prototype.strokeRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.strokeRect(t,e,n,i)},Pe.prototype.strokeText_ai6r6m$=function(t,e,n){this.myContext2d_0.strokeText(t,e,n)},Pe.prototype.fillText_ai6r6m$=function(t,e,n){this.myContext2d_0.fillText(t,e,n)},Pe.prototype.scale_lu1900$=function(t,e){this.myContext2d_0.scale(t,e)},Pe.prototype.rotate_14dthe$=function(t){this.myContext2d_0.rotate(t)},Pe.prototype.translate_lu1900$=function(t,e){this.myContext2d_0.translate(t,e)},Pe.prototype.transform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.transform(t,e,n,i,r,o)},Pe.prototype.bezierCurveTo_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.bezierCurveTo(t,e,n,i,r,o)},Pe.prototype.setLineJoin_v2gigt$=function(t){this.myContext2d_0.lineJoin=this.convertLineJoin_0(t)},Pe.prototype.setLineCap_useuqn$=function(t){this.myContext2d_0.lineCap=this.convertLineCap_0(t)},Pe.prototype.setTextBaseline_5cz80h$=function(t){this.myContext2d_0.textBaseline=this.convertTextBaseline_0(t)},Pe.prototype.setTextAlign_iwro1z$=function(t){this.myContext2d_0.textAlign=this.convertTextAlign_0(t)},Pe.prototype.setTransform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.setTransform(t,e,n,i,r,o)},Pe.prototype.setLineDash_gf7tl1$=function(t){this.myContext2d_0.setLineDash(H(t))},Pe.prototype.measureText_61zpoe$=function(t){return this.myContext2d_0.measureText(t).width},Pe.prototype.clearRect_wthzt5$=function(t){this.myContext2d_0.clearRect(t.left,t.top,t.width,t.height)},Pe.$metadata$={kind:a,simpleName:"DomContext2d",interfaces:[kt]},Y.AnimationTimer=V,Object.defineProperty(K,"Companion",{get:J}),Y.AnimationEventHandler=K;var Ae=t.jetbrains||(t.jetbrains={}),je=Ae.datalore||(Ae.datalore={}),Le=je.vis||(je.vis={}),Re=Le.canvas||(Le.canvas={});Re.AnimationProvider=Y,Q.Snapshot=tt,Re.Canvas=Q,Re.CanvasControl=et,Object.defineProperty(Re,"CanvasControlUtil",{get:function(){return null===wt&&new nt,wt}}),Re.CanvasProvider=xt,Object.defineProperty(Et,"BEVEL",{get:St}),Object.defineProperty(Et,"MITER",{get:Tt}),Object.defineProperty(Et,"ROUND",{get:Ot}),kt.LineJoin=Et,Object.defineProperty(Nt,"BUTT",{get:At}),Object.defineProperty(Nt,"ROUND",{get:jt}),Object.defineProperty(Nt,"SQUARE",{get:Lt}),kt.LineCap=Nt,Object.defineProperty(Rt,"ALPHABETIC",{get:zt}),Object.defineProperty(Rt,"BOTTOM",{get:Dt}),Object.defineProperty(Rt,"MIDDLE",{get:Mt}),Object.defineProperty(Rt,"TOP",{get:Bt}),kt.TextBaseline=Rt,Object.defineProperty(Ut,"CENTER",{get:qt}),Object.defineProperty(Ut,"END",{get:Gt}),Object.defineProperty(Ut,"START",{get:Ht}),kt.TextAlign=Ut,Object.defineProperty(Vt,"NORMAL",{get:Wt}),Object.defineProperty(Vt,"ITALIC",{get:Xt}),Yt.FontStyle=Vt,Object.defineProperty(Zt,"NORMAL",{get:Qt}),Object.defineProperty(Zt,"BOLD",{get:te}),Yt.FontWeight=Zt,Object.defineProperty(Yt,"Companion",{get:ie}),kt.Font_init_1nsek9$=function(t,e,n,i,r){return r=r||Object.create(Yt.prototype),Yt.call(r,null!=t?t:Wt(),null!=e?e:Qt(),null!=n?n:ie().DEFAULT_SIZE,null!=i?i:ie().DEFAULT_FAMILY),r},kt.Font=Yt,Re.Context2d=kt,Object.defineProperty(re,"Companion",{get:se}),Re.CssFontParser=re,Object.defineProperty(Re,"CssStyleUtil",{get:function(){return null===ue&&new le,ue}}),Re.DeltaTime=ce,Re.Dispatcher=pe,Re.scheduleAsync_ebnxch$=function(t,e){var n=new b;return e.onResult_m8e4a6$(he(n,t),_e(n,t)),n},Re.EventPeer=fe,Re.ScaledCanvas=ye,Re.ScaledContext2d=$e,Re.SingleCanvasControl=ve,(Le.canvasFigure||(Le.canvasFigure={})).CanvasFigure=ge;var Ie=Re.dom||(Re.dom={});return Ie.DomAnimationTimer=be,we.DomSnapshot=xe,Object.defineProperty(we,"Companion",{get:Ce}),Ie.DomCanvas=we,Se.DomEventPeer=Ne,Ie.DomCanvasControl=Se,Ie.DomContext2d=Pe,$e.prototype.arc_6p3vsx$=kt.prototype.arc_6p3vsx$,Pe.prototype.arc_6p3vsx$=kt.prototype.arc_6p3vsx$,t})?i.apply(e,r):i)||(t.exports=o)},179:function(t,e,n){var i,r,o;r=[e,n(421),n(331),n(799),n(767),n(602)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o){"use strict";var a=e.kotlin.collections.ArrayList_init_287e2$,s=n.jetbrains.datalore.vis.svg.slim.SvgSlimNode,l=e.toString,u=e.ensureNotNull,c=n.jetbrains.datalore.vis.svg.SvgElement,p=n.jetbrains.datalore.vis.svg.SvgTextNode,h=e.kotlin.IllegalStateException_init_pdl1vj$,_=n.jetbrains.datalore.vis.svg.slim,f=e.equals,d=e.Kind.CLASS,m=i.jetbrains.datalore.mapper.core.Synchronizer,y=e.kotlin.IllegalArgumentException_init_pdl1vj$,$=e.Kind.INTERFACE,v=(n.jetbrains.datalore.vis.svg.SvgNodeContainer,e.Kind.OBJECT),g=e.throwCCE,b=r.jetbrains.datalore.base.registration.CompositeRegistration,w=o.jetbrains.datalore.base.js.dom.DomEventType,x=o.jetbrains.datalore.base.event.dom,k=r.jetbrains.datalore.base.event.MouseEvent,E=r.jetbrains.datalore.base.registration.Registration,C=n.jetbrains.datalore.vis.svg.SvgImageElementEx.RGBEncoder,S=n.jetbrains.datalore.vis.svg.SvgNode,T=r.jetbrains.datalore.base.geometry.DoubleVector,O=r.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$,N=e.kotlin.collections.HashMap_init_q3lmfv$,P=n.jetbrains.datalore.vis.svg.SvgPlatformPeer,A=n.jetbrains.datalore.vis.svg.SvgElementListener,j=i.jetbrains.datalore.mapper.core,L=n.jetbrains.datalore.vis.svg.event.SvgEventSpec.values,R=e.kotlin.IllegalStateException_init,I=r.jetbrains.datalore.base.function.Function,z=r.jetbrains.datalore.base.observable.property.WritableProperty,D=e.numberToInt,M=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,B=i.jetbrains.datalore.mapper.core.Mapper,U=n.jetbrains.datalore.vis.svg.SvgImageElementEx,F=n.jetbrains.datalore.vis.svg.SvgImageElement,q=i.jetbrains.datalore.mapper.core.MapperFactory,G=n.jetbrains.datalore.vis.svg,H=(e.defineInlineFunction,e.kotlin.Unit),Y=e.kotlin.collections.AbstractMutableList,V=r.jetbrains.datalore.base.function.Value,K=r.jetbrains.datalore.base.observable.property.PropertyChangeEvent,W=r.jetbrains.datalore.base.observable.event.ListenerCaller,X=r.jetbrains.datalore.base.observable.event.Listeners,Z=r.jetbrains.datalore.base.observable.property.Property,J=e.kotlinx.dom.addClass_hhb33f$,Q=e.kotlinx.dom.removeClass_hhb33f$,tt=r.jetbrains.datalore.base.geometry.Vector,et=r.jetbrains.datalore.base.function.Supplier,nt=o.jetbrains.datalore.base.observable.property.UpdatableProperty,it=n.jetbrains.datalore.vis.svg.SvgEllipseElement,rt=n.jetbrains.datalore.vis.svg.SvgCircleElement,ot=n.jetbrains.datalore.vis.svg.SvgRectElement,at=n.jetbrains.datalore.vis.svg.SvgTextElement,st=n.jetbrains.datalore.vis.svg.SvgPathElement,lt=n.jetbrains.datalore.vis.svg.SvgLineElement,ut=n.jetbrains.datalore.vis.svg.SvgSvgElement,ct=n.jetbrains.datalore.vis.svg.SvgGElement,pt=n.jetbrains.datalore.vis.svg.SvgStyleElement,ht=n.jetbrains.datalore.vis.svg.SvgTSpanElement,_t=n.jetbrains.datalore.vis.svg.SvgDefsElement,ft=n.jetbrains.datalore.vis.svg.SvgClipPathElement;function dt(t,e,n){this.source_0=t,this.target_0=e,this.targetPeer_0=n,this.myHandlersRegs_0=null}function mt(){}function yt(){}function $t(t,e){this.closure$source=t,this.closure$spec=e}function vt(t,e,n){this.closure$target=t,this.closure$eventType=e,this.closure$listener=n,E.call(this)}function gt(){}function bt(){this.myMappingMap_0=N()}function wt(t,e,n){St.call(this,t,e,n),this.myPeer_0=n,this.myHandlersRegs_0=null}function xt(t){this.this$SvgElementMapper=t,this.myReg_0=null}function kt(t){this.this$SvgElementMapper=t}function Et(t){this.this$SvgElementMapper=t}function Ct(t,e){this.this$SvgElementMapper=t,this.closure$spec=e}function St(t,e,n){B.call(this,t,e),this.peer_cyou3s$_0=n}function Tt(t){this.myPeer_0=t}function Ot(t){At(),B.call(this,t,At().createDocument_0()),this.myRootMapper_0=null}function Nt(){Pt=this}vt.prototype=Object.create(E.prototype),vt.prototype.constructor=vt,St.prototype=Object.create(B.prototype),St.prototype.constructor=St,wt.prototype=Object.create(St.prototype),wt.prototype.constructor=wt,Ot.prototype=Object.create(B.prototype),Ot.prototype.constructor=Ot,jt.prototype=Object.create(St.prototype),jt.prototype.constructor=jt,Ft.prototype=Object.create(E.prototype),Ft.prototype.constructor=Ft,Qt.prototype=Object.create(Y.prototype),Qt.prototype.constructor=Qt,te.prototype=Object.create(Y.prototype),te.prototype.constructor=te,re.prototype=Object.create(E.prototype),re.prototype.constructor=re,oe.prototype=Object.create(E.prototype),oe.prototype.constructor=oe,pe.prototype=Object.create(nt.prototype),pe.prototype.constructor=pe,dt.prototype.attach_1rog5x$=function(t){if(this.myHandlersRegs_0=a(),e.isType(this.source_0,s)){var n="Slim SVG node is not expected: "+l(e.getKClassFromExpression(this.source_0).simpleName);throw y(n.toString())}this.targetPeer_0.appendChild_xwzc9q$(this.target_0,this.generateNode_0(this.source_0))},dt.prototype.detach=function(){var t;for(t=u(this.myHandlersRegs_0).iterator();t.hasNext();)t.next().remove();this.myHandlersRegs_0=null,this.targetPeer_0.removeAllChildren_11rb$(this.target_0)},dt.prototype.generateNode_0=function(t){if(e.isType(t,s))return this.generateSlimNode_0(t);if(e.isType(t,c))return this.generateElement_0(t);if(e.isType(t,p))return this.generateTextNode_0(t);throw h("Can't generate dom for svg node "+e.getKClassFromExpression(t).simpleName)},dt.prototype.generateElement_0=function(t){var e,n,i=this.targetPeer_0.newSvgElement_b1cgbq$(t);for(e=t.attributeKeys.iterator();e.hasNext();){var r=e.next();this.targetPeer_0.setAttribute_ohl585$(i,r.name,l(t.getAttribute_61zpoe$(r.name).get()))}var o=t.handlersSet().get();for(o.isEmpty()||this.targetPeer_0.hookEventHandlers_ewuthb$(t,i,o),n=t.children().iterator();n.hasNext();){var a=n.next();this.targetPeer_0.appendChild_xwzc9q$(i,this.generateNode_0(a))}return i},dt.prototype.generateTextNode_0=function(t){return this.targetPeer_0.newSvgTextNode_tginx7$(t)},dt.prototype.generateSlimNode_0=function(t){var e,n,i=this.targetPeer_0.newSvgSlimNode_qwqme8$(t);if(f(t.elementName,_.SvgSlimElements.GROUP))for(e=t.slimChildren.iterator();e.hasNext();){var r=e.next();this.targetPeer_0.appendChild_xwzc9q$(i,this.generateSlimNode_0(r))}for(n=t.attributes.iterator();n.hasNext();){var o=n.next();this.targetPeer_0.setAttribute_ohl585$(i,o.key,o.value)}return i},dt.$metadata$={kind:d,simpleName:"SvgNodeSubtreeGeneratingSynchronizer",interfaces:[m]},mt.$metadata$={kind:$,simpleName:"TargetPeer",interfaces:[]},yt.prototype.appendChild_xwzc9q$=function(t,e){t.appendChild(e)},yt.prototype.removeAllChildren_11rb$=function(t){if(t.hasChildNodes())for(var e=t.firstChild;null!=e;){var n=e.nextSibling;t.removeChild(e),e=n}},yt.prototype.newSvgElement_b1cgbq$=function(t){return _e().generateElement_b1cgbq$(t)},yt.prototype.newSvgTextNode_tginx7$=function(t){var e=document.createTextNode("");return e.nodeValue=t.textContent().get(),e},yt.prototype.newSvgSlimNode_qwqme8$=function(t){return _e().generateSlimNode_qwqme8$(t)},yt.prototype.setAttribute_ohl585$=function(t,n,i){var r;(e.isType(r=t,Element)?r:g()).setAttribute(n,i)},yt.prototype.hookEventHandlers_ewuthb$=function(t,n,i){var r,o,a,s=new b([]);for(r=i.iterator();r.hasNext();){var l=r.next();switch(l.name){case"MOUSE_CLICKED":o=w.Companion.CLICK;break;case"MOUSE_PRESSED":o=w.Companion.MOUSE_DOWN;break;case"MOUSE_RELEASED":o=w.Companion.MOUSE_UP;break;case"MOUSE_OVER":o=w.Companion.MOUSE_OVER;break;case"MOUSE_MOVE":o=w.Companion.MOUSE_MOVE;break;case"MOUSE_OUT":o=w.Companion.MOUSE_OUT;break;default:throw y("unexpected event spec "+l)}var u=o;s.add_3xv6fb$(this.addMouseHandler_0(t,e.isType(a=n,EventTarget)?a:g(),l,u.name))}return s},$t.prototype.handleEvent=function(t){var n;t.stopPropagation();var i=e.isType(n=t,MouseEvent)?n:g(),r=new k(i.clientX,i.clientY,x.DomEventUtil.getButton_tfvzir$(i),x.DomEventUtil.getModifiers_tfvzir$(i));this.closure$source.dispatch_lgzia2$(this.closure$spec,r)},$t.$metadata$={kind:d,interfaces:[]},vt.prototype.doRemove=function(){this.closure$target.removeEventListener(this.closure$eventType,this.closure$listener,!1)},vt.$metadata$={kind:d,interfaces:[E]},yt.prototype.addMouseHandler_0=function(t,e,n,i){var r=new $t(t,n);return e.addEventListener(i,r,!1),new vt(e,i,r)},yt.$metadata$={kind:d,simpleName:"DomTargetPeer",interfaces:[mt]},gt.prototype.toDataUrl_nps3vt$=function(t,n,i){var r,o,a=null==(r=document.createElement("canvas"))||e.isType(r,HTMLCanvasElement)?r:g();if(null==a)throw h("Canvas is not supported.");a.width=t,a.height=n;for(var s=e.isType(o=a.getContext("2d"),CanvasRenderingContext2D)?o:g(),l=s.createImageData(t,n),u=l.data,c=0;c>24&255,t,e),Vt(i,r,n>>16&255,t,e),Yt(i,r,n>>8&255,t,e),Ht(i,r,255&n,t,e)},gt.$metadata$={kind:d,simpleName:"RGBEncoderDom",interfaces:[C]},bt.prototype.ensureSourceRegistered_0=function(t){if(!this.myMappingMap_0.containsKey_11rb$(t))throw h("Trying to call platform peer method of unmapped node")},bt.prototype.registerMapper_dxg7rd$=function(t,e){this.myMappingMap_0.put_xwzc9p$(t,e)},bt.prototype.unregisterMapper_26jijc$=function(t){this.myMappingMap_0.remove_11rb$(t)},bt.prototype.getComputedTextLength_u60gfq$=function(t){var n,i;this.ensureSourceRegistered_0(e.isType(n=t,S)?n:g());var r=u(this.myMappingMap_0.get_11rb$(t)).target;return(e.isType(i=r,SVGTextContentElement)?i:g()).getComputedTextLength()},bt.prototype.transformCoordinates_1=function(t,n,i){var r,o;this.ensureSourceRegistered_0(e.isType(r=t,S)?r:g());var a=u(this.myMappingMap_0.get_11rb$(t)).target;return this.transformCoordinates_0(e.isType(o=a,SVGElement)?o:g(),n.x,n.y,i)},bt.prototype.transformCoordinates_0=function(t,n,i,r){var o,a=(e.isType(o=t,SVGGraphicsElement)?o:g()).getCTM();r&&(a=u(a).inverse());var s=u(t.ownerSVGElement).createSVGPoint();s.x=n,s.y=i;var l=s.matrixTransform(u(a));return new T(l.x,l.y)},bt.prototype.inverseScreenTransform_ljxa03$=function(t,n){var i,r=t.ownerSvgElement;this.ensureSourceRegistered_0(u(r));var o=u(this.myMappingMap_0.get_11rb$(r)).target;return this.inverseScreenTransform_0(e.isType(i=o,SVGSVGElement)?i:g(),n.x,n.y)},bt.prototype.inverseScreenTransform_0=function(t,e,n){var i=u(t.getScreenCTM()).inverse(),r=t.createSVGPoint();return r.x=e,r.y=n,r=r.matrixTransform(i),new T(r.x,r.y)},bt.prototype.invertTransform_12yub8$=function(t,e){return this.transformCoordinates_1(t,e,!0)},bt.prototype.applyTransform_12yub8$=function(t,e){return this.transformCoordinates_1(t,e,!1)},bt.prototype.getBBox_7snaev$=function(t){var n;this.ensureSourceRegistered_0(e.isType(n=t,S)?n:g());var i=u(this.myMappingMap_0.get_11rb$(t)).target;return this.getBoundingBox_0(i)},bt.prototype.getBoundingBox_0=function(t){var n,i=(e.isType(n=t,SVGGraphicsElement)?n:g()).getBBox();return O(i.x,i.y,i.width,i.height)},bt.$metadata$={kind:d,simpleName:"SvgDomPeer",interfaces:[P]},kt.prototype.onAttrSet_ud3ldc$=function(t){null==t.newValue&&this.this$SvgElementMapper.target.removeAttribute(t.attrSpec.name),this.this$SvgElementMapper.target.setAttribute(t.attrSpec.name,l(t.newValue))},kt.$metadata$={kind:d,interfaces:[A]},xt.prototype.attach_1rog5x$=function(t){var e;for(this.myReg_0=this.this$SvgElementMapper.source.addListener_e4m8w6$(new kt(this.this$SvgElementMapper)),e=this.this$SvgElementMapper.source.attributeKeys.iterator();e.hasNext();){var n=e.next(),i=n.name,r=l(this.this$SvgElementMapper.source.getAttribute_61zpoe$(i).get());n.hasNamespace()?this.this$SvgElementMapper.target.setAttributeNS(n.namespaceUri,i,r):this.this$SvgElementMapper.target.setAttribute(i,r)}},xt.prototype.detach=function(){u(this.myReg_0).remove()},xt.$metadata$={kind:d,interfaces:[m]},Ct.prototype.apply_11rb$=function(t){if(e.isType(t,MouseEvent)){var n=this.this$SvgElementMapper.createMouseEvent_0(t);return this.this$SvgElementMapper.source.dispatch_lgzia2$(this.closure$spec,n),!0}return!1},Ct.$metadata$={kind:d,interfaces:[I]},Et.prototype.set_11rb$=function(t){var e,n,i;for(null==this.this$SvgElementMapper.myHandlersRegs_0&&(this.this$SvgElementMapper.myHandlersRegs_0=M()),e=L(),n=0;n!==e.length;++n){var r=e[n];if(!u(t).contains_11rb$(r)&&u(this.this$SvgElementMapper.myHandlersRegs_0).containsKey_11rb$(r)&&u(u(this.this$SvgElementMapper.myHandlersRegs_0).remove_11rb$(r)).dispose(),t.contains_11rb$(r)&&!u(this.this$SvgElementMapper.myHandlersRegs_0).containsKey_11rb$(r)){switch(r.name){case"MOUSE_CLICKED":i=w.Companion.CLICK;break;case"MOUSE_PRESSED":i=w.Companion.MOUSE_DOWN;break;case"MOUSE_RELEASED":i=w.Companion.MOUSE_UP;break;case"MOUSE_OVER":i=w.Companion.MOUSE_OVER;break;case"MOUSE_MOVE":i=w.Companion.MOUSE_MOVE;break;case"MOUSE_OUT":i=w.Companion.MOUSE_OUT;break;default:throw R()}var o=i,a=u(this.this$SvgElementMapper.myHandlersRegs_0),s=Ut(this.this$SvgElementMapper.target,o,new Ct(this.this$SvgElementMapper,r));a.put_xwzc9p$(r,s)}}},Et.$metadata$={kind:d,interfaces:[z]},wt.prototype.registerSynchronizers_jp3a7u$=function(t){St.prototype.registerSynchronizers_jp3a7u$.call(this,t),t.add_te27wm$(new xt(this)),t.add_te27wm$(j.Synchronizers.forPropsOneWay_2ov6i0$(this.source.handlersSet(),new Et(this)))},wt.prototype.onDetach=function(){var t;if(St.prototype.onDetach.call(this),null!=this.myHandlersRegs_0){for(t=u(this.myHandlersRegs_0).values.iterator();t.hasNext();)t.next().dispose();u(this.myHandlersRegs_0).clear()}},wt.prototype.createMouseEvent_0=function(t){t.stopPropagation();var e=this.myPeer_0.inverseScreenTransform_ljxa03$(this.source,new T(t.clientX,t.clientY));return new k(D(e.x),D(e.y),x.DomEventUtil.getButton_tfvzir$(t),x.DomEventUtil.getModifiers_tfvzir$(t))},wt.$metadata$={kind:d,simpleName:"SvgElementMapper",interfaces:[St]},St.prototype.registerSynchronizers_jp3a7u$=function(t){B.prototype.registerSynchronizers_jp3a7u$.call(this,t),this.source.isPrebuiltSubtree?t.add_te27wm$(new dt(this.source,this.target,new yt)):t.add_te27wm$(j.Synchronizers.forObservableRole_umd8ru$(this,this.source.children(),_e().nodeChildren_b3w3xb$(this.target),new Tt(this.peer_cyou3s$_0)))},St.prototype.onAttach_8uof53$=function(t){B.prototype.onAttach_8uof53$.call(this,t),this.peer_cyou3s$_0.registerMapper_dxg7rd$(this.source,this)},St.prototype.onDetach=function(){B.prototype.onDetach.call(this),this.peer_cyou3s$_0.unregisterMapper_26jijc$(this.source)},St.$metadata$={kind:d,simpleName:"SvgNodeMapper",interfaces:[B]},Tt.prototype.createMapper_11rb$=function(t){if(e.isType(t,F)){var n=t;return e.isType(n,U)&&(n=n.asImageElement_xhdger$(new gt)),new wt(n,_e().generateElement_b1cgbq$(t),this.myPeer_0)}if(e.isType(t,c))return new wt(t,_e().generateElement_b1cgbq$(t),this.myPeer_0);if(e.isType(t,p))return new jt(t,_e().generateTextElement_tginx7$(t),this.myPeer_0);if(e.isType(t,s))return new St(t,_e().generateSlimNode_qwqme8$(t),this.myPeer_0);throw h("Unsupported SvgNode "+e.getKClassFromExpression(t))},Tt.$metadata$={kind:d,simpleName:"SvgNodeMapperFactory",interfaces:[q]},Nt.prototype.createDocument_0=function(){var t;return e.isType(t=document.createElementNS(G.XmlNamespace.SVG_NAMESPACE_URI,"svg"),SVGSVGElement)?t:g()},Nt.$metadata$={kind:v,simpleName:"Companion",interfaces:[]};var Pt=null;function At(){return null===Pt&&new Nt,Pt}function jt(t,e,n){St.call(this,t,e,n)}function Lt(t){this.this$SvgTextNodeMapper=t}function Rt(){It=this,this.DEFAULT="default",this.NONE="none",this.BLOCK="block",this.FLEX="flex",this.GRID="grid",this.INLINE_BLOCK="inline-block"}Ot.prototype.onAttach_8uof53$=function(t){if(B.prototype.onAttach_8uof53$.call(this,t),!this.source.isAttached())throw h("Element must be attached");var e=new bt;this.source.container().setPeer_kqs5uc$(e),this.myRootMapper_0=new wt(this.source,this.target,e),this.target.setAttribute("shape-rendering","geometricPrecision"),u(this.myRootMapper_0).attachRoot_8uof53$()},Ot.prototype.onDetach=function(){u(this.myRootMapper_0).detachRoot(),this.myRootMapper_0=null,this.source.isAttached()&&this.source.container().setPeer_kqs5uc$(null),B.prototype.onDetach.call(this)},Ot.$metadata$={kind:d,simpleName:"SvgRootDocumentMapper",interfaces:[B]},Lt.prototype.set_11rb$=function(t){this.this$SvgTextNodeMapper.target.nodeValue=t},Lt.$metadata$={kind:d,interfaces:[z]},jt.prototype.registerSynchronizers_jp3a7u$=function(t){St.prototype.registerSynchronizers_jp3a7u$.call(this,t),t.add_te27wm$(j.Synchronizers.forPropsOneWay_2ov6i0$(this.source.textContent(),new Lt(this)))},jt.$metadata$={kind:d,simpleName:"SvgTextNodeMapper",interfaces:[St]},Rt.$metadata$={kind:v,simpleName:"CssDisplay",interfaces:[]};var It=null;function zt(){return null===It&&new Rt,It}function Dt(t,e){return t.removeProperty(e),t}function Mt(t){return Dt(t,"display")}function Bt(t){this.closure$handler=t}function Ut(t,e,n){return qt(t,e,new Bt(n),!1)}function Ft(t,e,n){this.closure$type=t,this.closure$listener=e,this.this$onEvent=n,E.call(this)}function qt(t,e,n,i){return t.addEventListener(e.name,n,i),new Ft(e,n,t)}function Gt(t,e,n,i,r){Kt(t,e,n,i,r,3)}function Ht(t,e,n,i,r){Kt(t,e,n,i,r,2)}function Yt(t,e,n,i,r){Kt(t,e,n,i,r,1)}function Vt(t,e,n,i,r){Kt(t,e,n,i,r,0)}function Kt(t,n,i,r,o,a){n[(4*(r+e.imul(o,t.width)|0)|0)+a|0]=i}function Wt(t){return t.childNodes.length}function Xt(t,e){return t.insertBefore(e,t.firstChild)}function Zt(t,e,n){var i=null!=n?n.nextSibling:null;null==i?t.appendChild(e):t.insertBefore(e,i)}function Jt(){he=this}function Qt(t){this.closure$n=t,Y.call(this)}function te(t,e){this.closure$items=t,this.closure$base=e,Y.call(this)}function ee(t){this.closure$e=t}function ne(t){this.closure$element=t,this.myTimerRegistration_0=null,this.myListeners_0=new X}function ie(t,e){this.closure$value=t,this.closure$currentValue=e}function re(t){this.closure$timer=t,E.call(this)}function oe(t,e){this.closure$reg=t,this.this$=e,E.call(this)}function ae(t,e){this.closure$el=t,this.closure$cls=e,this.myValue_0=null}function se(t,e){this.closure$el=t,this.closure$attr=e}function le(t,e,n){this.closure$el=t,this.closure$attr=e,this.closure$attrValue=n}function ue(t){this.closure$el=t}function ce(t){this.closure$el=t}function pe(t,e){this.closure$period=t,this.closure$supplier=e,nt.call(this),this.myTimer_0=-1}Bt.prototype.handleEvent=function(t){this.closure$handler.apply_11rb$(t)||(t.preventDefault(),t.stopPropagation())},Bt.$metadata$={kind:d,interfaces:[]},Ft.prototype.doRemove=function(){this.this$onEvent.removeEventListener(this.closure$type.name,this.closure$listener)},Ft.$metadata$={kind:d,interfaces:[E]},Jt.prototype.elementChildren_2rdptt$=function(t){return this.nodeChildren_b3w3xb$(t)},Object.defineProperty(Qt.prototype,"size",{configurable:!0,get:function(){return Wt(this.closure$n)}}),Qt.prototype.get_za3lpa$=function(t){return this.closure$n.childNodes[t]},Qt.prototype.set_wxm5ur$=function(t,e){if(null!=u(e).parentNode)throw R();var n=u(this.get_za3lpa$(t));return this.closure$n.replaceChild(n,e),n},Qt.prototype.add_wxm5ur$=function(t,e){if(null!=u(e).parentNode)throw R();if(0===t)Xt(this.closure$n,e);else{var n=t-1|0,i=this.closure$n.childNodes[n];Zt(this.closure$n,e,i)}},Qt.prototype.removeAt_za3lpa$=function(t){var e=u(this.closure$n.childNodes[t]);return this.closure$n.removeChild(e),e},Qt.$metadata$={kind:d,interfaces:[Y]},Jt.prototype.nodeChildren_b3w3xb$=function(t){return new Qt(t)},Object.defineProperty(te.prototype,"size",{configurable:!0,get:function(){return this.closure$items.size}}),te.prototype.get_za3lpa$=function(t){return this.closure$items.get_za3lpa$(t)},te.prototype.set_wxm5ur$=function(t,e){var n=this.closure$items.set_wxm5ur$(t,e);return this.closure$base.set_wxm5ur$(t,u(n).getElement()),n},te.prototype.add_wxm5ur$=function(t,e){this.closure$items.add_wxm5ur$(t,e),this.closure$base.add_wxm5ur$(t,u(e).getElement())},te.prototype.removeAt_za3lpa$=function(t){var e=this.closure$items.removeAt_za3lpa$(t);return this.closure$base.removeAt_za3lpa$(t),e},te.$metadata$={kind:d,interfaces:[Y]},Jt.prototype.withElementChildren_9w66cp$=function(t){return new te(a(),t)},ee.prototype.set_11rb$=function(t){this.closure$e.innerHTML=t},ee.$metadata$={kind:d,interfaces:[z]},Jt.prototype.innerTextOf_2rdptt$=function(t){return new ee(t)},Object.defineProperty(ne.prototype,"propExpr",{configurable:!0,get:function(){return"checkbox("+this.closure$element+")"}}),ne.prototype.get=function(){return this.closure$element.checked},ne.prototype.set_11rb$=function(t){this.closure$element.checked=t},ie.prototype.call_11rb$=function(t){t.onEvent_11rb$(new K(this.closure$value.get(),this.closure$currentValue))},ie.$metadata$={kind:d,interfaces:[W]},re.prototype.doRemove=function(){window.clearInterval(this.closure$timer)},re.$metadata$={kind:d,interfaces:[E]},oe.prototype.doRemove=function(){this.closure$reg.remove(),this.this$.myListeners_0.isEmpty&&(u(this.this$.myTimerRegistration_0).remove(),this.this$.myTimerRegistration_0=null)},oe.$metadata$={kind:d,interfaces:[E]},ne.prototype.addHandler_gxwwpc$=function(t){if(this.myListeners_0.isEmpty){var e=new V(this.closure$element.checked),n=window.setInterval((i=this.closure$element,r=e,o=this,function(){var t=i.checked;return t!==r.get()&&(o.myListeners_0.fire_kucmxw$(new ie(r,t)),r.set_11rb$(t)),H}));this.myTimerRegistration_0=new re(n)}var i,r,o;return new oe(this.myListeners_0.add_11rb$(t),this)},ne.$metadata$={kind:d,interfaces:[Z]},Jt.prototype.checkbox_36rv4q$=function(t){return new ne(t)},ae.prototype.set_11rb$=function(t){this.myValue_0!==t&&(t?J(this.closure$el,[this.closure$cls]):Q(this.closure$el,[this.closure$cls]),this.myValue_0=t)},ae.$metadata$={kind:d,interfaces:[z]},Jt.prototype.hasClass_t9mn69$=function(t,e){return new ae(t,e)},se.prototype.set_11rb$=function(t){this.closure$el.setAttribute(this.closure$attr,t)},se.$metadata$={kind:d,interfaces:[z]},Jt.prototype.attribute_t9mn69$=function(t,e){return new se(t,e)},le.prototype.set_11rb$=function(t){t?this.closure$el.setAttribute(this.closure$attr,this.closure$attrValue):this.closure$el.removeAttribute(this.closure$attr)},le.$metadata$={kind:d,interfaces:[z]},Jt.prototype.hasAttribute_1x5wil$=function(t,e,n){return new le(t,e,n)},ue.prototype.set_11rb$=function(t){t?Mt(this.closure$el.style):this.closure$el.style.display=zt().NONE},ue.$metadata$={kind:d,interfaces:[z]},Jt.prototype.visibilityOf_lt8gi4$=function(t){return new ue(t)},ce.prototype.get=function(){return new tt(this.closure$el.clientWidth,this.closure$el.clientHeight)},ce.$metadata$={kind:d,interfaces:[et]},Jt.prototype.dimension_2rdptt$=function(t){return this.timerBasedProperty_ndenup$(new ce(t),200)},pe.prototype.doAddListeners=function(){var t;this.myTimer_0=window.setInterval((t=this,function(){return t.update(),H}),this.closure$period)},pe.prototype.doRemoveListeners=function(){window.clearInterval(this.myTimer_0)},pe.prototype.doGet=function(){return this.closure$supplier.get()},pe.$metadata$={kind:d,interfaces:[nt]},Jt.prototype.timerBasedProperty_ndenup$=function(t,e){return new pe(e,t)},Jt.prototype.generateElement_b1cgbq$=function(t){if(e.isType(t,it))return this.createSVGElement_0("ellipse");if(e.isType(t,rt))return this.createSVGElement_0("circle");if(e.isType(t,ot))return this.createSVGElement_0("rect");if(e.isType(t,at))return this.createSVGElement_0("text");if(e.isType(t,st))return this.createSVGElement_0("path");if(e.isType(t,lt))return this.createSVGElement_0("line");if(e.isType(t,ut))return this.createSVGElement_0("svg");if(e.isType(t,ct))return this.createSVGElement_0("g");if(e.isType(t,pt))return this.createSVGElement_0("style");if(e.isType(t,ht))return this.createSVGElement_0("tspan");if(e.isType(t,_t))return this.createSVGElement_0("defs");if(e.isType(t,ft))return this.createSVGElement_0("clipPath");if(e.isType(t,F))return this.createSVGElement_0("image");throw h("Unsupported svg element "+l(e.getKClassFromExpression(t).simpleName))},Jt.prototype.generateSlimNode_qwqme8$=function(t){switch(t.elementName){case"g":return this.createSVGElement_0("g");case"line":return this.createSVGElement_0("line");case"circle":return this.createSVGElement_0("circle");case"rect":return this.createSVGElement_0("rect");case"path":return this.createSVGElement_0("path");default:throw h("Unsupported SvgSlimNode "+e.getKClassFromExpression(t))}},Jt.prototype.generateTextElement_tginx7$=function(t){return document.createTextNode("")},Jt.prototype.createSVGElement_0=function(t){var n;return e.isType(n=document.createElementNS(G.XmlNamespace.SVG_NAMESPACE_URI,t),SVGElement)?n:g()},Jt.$metadata$={kind:v,simpleName:"DomUtil",interfaces:[]};var he=null;function _e(){return null===he&&new Jt,he}var fe=t.jetbrains||(t.jetbrains={}),de=fe.datalore||(fe.datalore={}),me=de.vis||(de.vis={}),ye=me.svgMapper||(me.svgMapper={});ye.SvgNodeSubtreeGeneratingSynchronizer=dt,ye.TargetPeer=mt;var $e=ye.dom||(ye.dom={});$e.DomTargetPeer=yt,$e.RGBEncoderDom=gt,$e.SvgDomPeer=bt,$e.SvgElementMapper=wt,$e.SvgNodeMapper=St,$e.SvgNodeMapperFactory=Tt,Object.defineProperty(Ot,"Companion",{get:At}),$e.SvgRootDocumentMapper=Ot,$e.SvgTextNodeMapper=jt;var ve=$e.css||($e.css={});Object.defineProperty(ve,"CssDisplay",{get:zt});var ge=$e.domExtensions||($e.domExtensions={});ge.clearProperty_77nir7$=Dt,ge.clearDisplay_b8w5wr$=Mt,ge.on_wkfwsw$=Ut,ge.onEvent_jxnl6r$=qt,ge.setAlphaAt_h5k0c3$=Gt,ge.setBlueAt_h5k0c3$=Ht,ge.setGreenAt_h5k0c3$=Yt,ge.setRedAt_h5k0c3$=Vt,ge.setColorAt_z0tnfj$=Kt,ge.get_childCount_asww5s$=Wt,ge.insertFirst_fga9sf$=Xt,ge.insertAfter_5a54o3$=Zt;var be=$e.domUtil||($e.domUtil={});return Object.defineProperty(be,"DomUtil",{get:_e}),t})?i.apply(e,r):i)||(t.exports=o)},331:function(t,e,n){var i,r,o;r=[e,n(421),n(767)],void 0===(o="function"==typeof(i=function(t,e,n){"use strict";var i=e.Kind.OBJECT,r=e.hashCode,o=e.throwCCE,a=e.equals,s=e.Kind.CLASS,l=e.ensureNotNull,u=e.kotlin.Enum,c=e.throwISE,p=e.Kind.INTERFACE,h=e.kotlin.collections.HashMap_init_q3lmfv$,_=e.kotlin.IllegalArgumentException_init,f=Object,d=n.jetbrains.datalore.base.observable.property.PropertyChangeEvent,m=n.jetbrains.datalore.base.observable.property.Property,y=n.jetbrains.datalore.base.observable.event.ListenerCaller,$=n.jetbrains.datalore.base.observable.event.Listeners,v=n.jetbrains.datalore.base.registration.Registration,g=n.jetbrains.datalore.base.listMap.ListMap,b=e.kotlin.collections.emptySet_287e2$,w=e.kotlin.text.StringBuilder_init,x=n.jetbrains.datalore.base.observable.property.ReadableProperty,k=(e.kotlin.Unit,e.kotlin.IllegalStateException_init_pdl1vj$),E=n.jetbrains.datalore.base.observable.collections.list.ObservableList,C=n.jetbrains.datalore.base.observable.children.ChildList,S=n.jetbrains.datalore.base.observable.children.SimpleComposite,T=e.kotlin.text.StringBuilder,O=n.jetbrains.datalore.base.observable.property.ValueProperty,N=e.toBoxedChar,P=e.kotlin.text.uppercaseChar_myv2d0$,A=e.getKClass,j=e.toString,L=e.kotlin.IllegalArgumentException_init_pdl1vj$,R=e.unboxChar,I=e.kotlin.collections.ArrayList_init_ww73n8$,z=e.kotlin.collections.ArrayList_init_287e2$,D=n.jetbrains.datalore.base.geometry.DoubleVector,M=e.kotlin.collections.ArrayList_init_mqih57$,B=Math,U=e.kotlin.text.split_ip8yn$,F=e.kotlin.text.contains_li3zpu$,q=n.jetbrains.datalore.base.observable.property.WritableProperty,G=e.kotlin.UnsupportedOperationException_init_pdl1vj$,H=n.jetbrains.datalore.base.observable.collections.list.ObservableArrayList,Y=e.numberToInt,V=n.jetbrains.datalore.base.event.Event,K=(e.numberToDouble,e.kotlin.text.toDouble_pdl1vz$,e.kotlin.collections.filterNotNull_m3lr2h$),W=e.kotlin.collections.emptyList_287e2$,X=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$;function Z(t,e){tt(),this.name=t,this.namespaceUri=e}function J(){Q=this}Is.prototype=Object.create(S.prototype),Is.prototype.constructor=Is,la.prototype=Object.create(Is.prototype),la.prototype.constructor=la,Al.prototype=Object.create(la.prototype),Al.prototype.constructor=Al,Oa.prototype=Object.create(Al.prototype),Oa.prototype.constructor=Oa,et.prototype=Object.create(Oa.prototype),et.prototype.constructor=et,Qn.prototype=Object.create(u.prototype),Qn.prototype.constructor=Qn,ot.prototype=Object.create(Oa.prototype),ot.prototype.constructor=ot,ri.prototype=Object.create(u.prototype),ri.prototype.constructor=ri,sa.prototype=Object.create(Oa.prototype),sa.prototype.constructor=sa,da.prototype=Object.create(v.prototype),da.prototype.constructor=da,$a.prototype=Object.create(Oa.prototype),$a.prototype.constructor=$a,ka.prototype=Object.create(v.prototype),ka.prototype.constructor=ka,Ea.prototype=Object.create(v.prototype),Ea.prototype.constructor=Ea,Ta.prototype=Object.create(Oa.prototype),Ta.prototype.constructor=Ta,Va.prototype=Object.create(u.prototype),Va.prototype.constructor=Va,os.prototype=Object.create(u.prototype),os.prototype.constructor=os,hs.prototype=Object.create(Oa.prototype),hs.prototype.constructor=hs,ys.prototype=Object.create(hs.prototype),ys.prototype.constructor=ys,bs.prototype=Object.create(Oa.prototype),bs.prototype.constructor=bs,zs.prototype=Object.create(C.prototype),zs.prototype.constructor=zs,Fs.prototype=Object.create(O.prototype),Fs.prototype.constructor=Fs,Gs.prototype=Object.create(u.prototype),Gs.prototype.constructor=Gs,_l.prototype=Object.create(u.prototype),_l.prototype.constructor=_l,$l.prototype=Object.create(Oa.prototype),$l.prototype.constructor=$l,xl.prototype=Object.create(Oa.prototype),xl.prototype.constructor=xl,Il.prototype=Object.create(la.prototype),Il.prototype.constructor=Il,zl.prototype=Object.create(Al.prototype),zl.prototype.constructor=zl,Gl.prototype=Object.create(la.prototype),Gl.prototype.constructor=Gl,Ql.prototype=Object.create(Oa.prototype),Ql.prototype.constructor=Ql,ou.prototype=Object.create(H.prototype),ou.prototype.constructor=ou,iu.prototype=Object.create(Is.prototype),iu.prototype.constructor=iu,Nu.prototype=Object.create(V.prototype),Nu.prototype.constructor=Nu,Au.prototype=Object.create(u.prototype),Au.prototype.constructor=Au,Bu.prototype=Object.create(Is.prototype),Bu.prototype.constructor=Bu,Uu.prototype=Object.create(Yu.prototype),Uu.prototype.constructor=Uu,Gu.prototype=Object.create(Bu.prototype),Gu.prototype.constructor=Gu,qu.prototype=Object.create(Uu.prototype),qu.prototype.constructor=qu,J.prototype.createSpec_ytbaoo$=function(t){return new Z(t,null)},J.prototype.createSpecNS_wswq18$=function(t,e,n){return new Z(e+":"+t,n)},J.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Q=null;function tt(){return null===Q&&new J,Q}function et(){rt(),Oa.call(this),this.elementName_4ww0r9$_0="circle"}function nt(){it=this,this.CX=tt().createSpec_ytbaoo$("cx"),this.CY=tt().createSpec_ytbaoo$("cy"),this.R=tt().createSpec_ytbaoo$("r")}Z.prototype.hasNamespace=function(){return null!=this.namespaceUri},Z.prototype.toString=function(){return this.name},Z.prototype.hashCode=function(){return r(this.name)},Z.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Z)||o(),!!a(this.name,t.name))},Z.$metadata$={kind:s,simpleName:"SvgAttributeSpec",interfaces:[]},nt.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var it=null;function rt(){return null===it&&new nt,it}function ot(){Jn(),Oa.call(this)}function at(){Zn=this,this.CLIP_PATH_UNITS_0=tt().createSpec_ytbaoo$("clipPathUnits")}Object.defineProperty(et.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_4ww0r9$_0}}),Object.defineProperty(et.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),et.prototype.cx=function(){return this.getAttribute_mumjwj$(rt().CX)},et.prototype.cy=function(){return this.getAttribute_mumjwj$(rt().CY)},et.prototype.r=function(){return this.getAttribute_mumjwj$(rt().R)},et.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},et.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},et.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},et.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},et.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},et.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},et.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},et.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},et.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},et.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},et.$metadata$={kind:s,simpleName:"SvgCircleElement",interfaces:[Tl,_u,Oa]},at.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var st,lt,ut,ct,pt,ht,_t,ft,dt,mt,yt,$t,vt,gt,bt,wt,xt,kt,Et,Ct,St,Tt,Ot,Nt,Pt,At,jt,Lt,Rt,It,zt,Dt,Mt,Bt,Ut,Ft,qt,Gt,Ht,Yt,Vt,Kt,Wt,Xt,Zt,Jt,Qt,te,ee,ne,ie,re,oe,ae,se,le,ue,ce,pe,he,_e,fe,de,me,ye,$e,ve,ge,be,we,xe,ke,Ee,Ce,Se,Te,Oe,Ne,Pe,Ae,je,Le,Re,Ie,ze,De,Me,Be,Ue,Fe,qe,Ge,He,Ye,Ve,Ke,We,Xe,Ze,Je,Qe,tn,en,nn,rn,on,an,sn,ln,un,cn,pn,hn,_n,fn,dn,mn,yn,$n,vn,gn,bn,wn,xn,kn,En,Cn,Sn,Tn,On,Nn,Pn,An,jn,Ln,Rn,In,zn,Dn,Mn,Bn,Un,Fn,qn,Gn,Hn,Yn,Vn,Kn,Wn,Xn,Zn=null;function Jn(){return null===Zn&&new at,Zn}function Qn(t,e,n){u.call(this),this.myAttributeString_ss0dpy$_0=n,this.name$=t,this.ordinal$=e}function ti(){ti=function(){},st=new Qn("USER_SPACE_ON_USE",0,"userSpaceOnUse"),lt=new Qn("OBJECT_BOUNDING_BOX",1,"objectBoundingBox")}function ei(){return ti(),st}function ni(){return ti(),lt}function ii(){}function ri(t,e,n){u.call(this),this.literal_7kwssz$_0=n,this.name$=t,this.ordinal$=e}function oi(){oi=function(){},ut=new ri("ALICE_BLUE",0,"aliceblue"),ct=new ri("ANTIQUE_WHITE",1,"antiquewhite"),pt=new ri("AQUA",2,"aqua"),ht=new ri("AQUAMARINE",3,"aquamarine"),_t=new ri("AZURE",4,"azure"),ft=new ri("BEIGE",5,"beige"),dt=new ri("BISQUE",6,"bisque"),mt=new ri("BLACK",7,"black"),yt=new ri("BLANCHED_ALMOND",8,"blanchedalmond"),$t=new ri("BLUE",9,"blue"),vt=new ri("BLUE_VIOLET",10,"blueviolet"),gt=new ri("BROWN",11,"brown"),bt=new ri("BURLY_WOOD",12,"burlywood"),wt=new ri("CADET_BLUE",13,"cadetblue"),xt=new ri("CHARTREUSE",14,"chartreuse"),kt=new ri("CHOCOLATE",15,"chocolate"),Et=new ri("CORAL",16,"coral"),Ct=new ri("CORNFLOWER_BLUE",17,"cornflowerblue"),St=new ri("CORNSILK",18,"cornsilk"),Tt=new ri("CRIMSON",19,"crimson"),Ot=new ri("CYAN",20,"cyan"),Nt=new ri("DARK_BLUE",21,"darkblue"),Pt=new ri("DARK_CYAN",22,"darkcyan"),At=new ri("DARK_GOLDEN_ROD",23,"darkgoldenrod"),jt=new ri("DARK_GRAY",24,"darkgray"),Lt=new ri("DARK_GREEN",25,"darkgreen"),Rt=new ri("DARK_GREY",26,"darkgrey"),It=new ri("DARK_KHAKI",27,"darkkhaki"),zt=new ri("DARK_MAGENTA",28,"darkmagenta"),Dt=new ri("DARK_OLIVE_GREEN",29,"darkolivegreen"),Mt=new ri("DARK_ORANGE",30,"darkorange"),Bt=new ri("DARK_ORCHID",31,"darkorchid"),Ut=new ri("DARK_RED",32,"darkred"),Ft=new ri("DARK_SALMON",33,"darksalmon"),qt=new ri("DARK_SEA_GREEN",34,"darkseagreen"),Gt=new ri("DARK_SLATE_BLUE",35,"darkslateblue"),Ht=new ri("DARK_SLATE_GRAY",36,"darkslategray"),Yt=new ri("DARK_SLATE_GREY",37,"darkslategrey"),Vt=new ri("DARK_TURQUOISE",38,"darkturquoise"),Kt=new ri("DARK_VIOLET",39,"darkviolet"),Wt=new ri("DEEP_PINK",40,"deeppink"),Xt=new ri("DEEP_SKY_BLUE",41,"deepskyblue"),Zt=new ri("DIM_GRAY",42,"dimgray"),Jt=new ri("DIM_GREY",43,"dimgrey"),Qt=new ri("DODGER_BLUE",44,"dodgerblue"),te=new ri("FIRE_BRICK",45,"firebrick"),ee=new ri("FLORAL_WHITE",46,"floralwhite"),ne=new ri("FOREST_GREEN",47,"forestgreen"),ie=new ri("FUCHSIA",48,"fuchsia"),re=new ri("GAINSBORO",49,"gainsboro"),oe=new ri("GHOST_WHITE",50,"ghostwhite"),ae=new ri("GOLD",51,"gold"),se=new ri("GOLDEN_ROD",52,"goldenrod"),le=new ri("GRAY",53,"gray"),ue=new ri("GREY",54,"grey"),ce=new ri("GREEN",55,"green"),pe=new ri("GREEN_YELLOW",56,"greenyellow"),he=new ri("HONEY_DEW",57,"honeydew"),_e=new ri("HOT_PINK",58,"hotpink"),fe=new ri("INDIAN_RED",59,"indianred"),de=new ri("INDIGO",60,"indigo"),me=new ri("IVORY",61,"ivory"),ye=new ri("KHAKI",62,"khaki"),$e=new ri("LAVENDER",63,"lavender"),ve=new ri("LAVENDER_BLUSH",64,"lavenderblush"),ge=new ri("LAWN_GREEN",65,"lawngreen"),be=new ri("LEMON_CHIFFON",66,"lemonchiffon"),we=new ri("LIGHT_BLUE",67,"lightblue"),xe=new ri("LIGHT_CORAL",68,"lightcoral"),ke=new ri("LIGHT_CYAN",69,"lightcyan"),Ee=new ri("LIGHT_GOLDEN_ROD_YELLOW",70,"lightgoldenrodyellow"),Ce=new ri("LIGHT_GRAY",71,"lightgray"),Se=new ri("LIGHT_GREEN",72,"lightgreen"),Te=new ri("LIGHT_GREY",73,"lightgrey"),Oe=new ri("LIGHT_PINK",74,"lightpink"),Ne=new ri("LIGHT_SALMON",75,"lightsalmon"),Pe=new ri("LIGHT_SEA_GREEN",76,"lightseagreen"),Ae=new ri("LIGHT_SKY_BLUE",77,"lightskyblue"),je=new ri("LIGHT_SLATE_GRAY",78,"lightslategray"),Le=new ri("LIGHT_SLATE_GREY",79,"lightslategrey"),Re=new ri("LIGHT_STEEL_BLUE",80,"lightsteelblue"),Ie=new ri("LIGHT_YELLOW",81,"lightyellow"),ze=new ri("LIME",82,"lime"),De=new ri("LIME_GREEN",83,"limegreen"),Me=new ri("LINEN",84,"linen"),Be=new ri("MAGENTA",85,"magenta"),Ue=new ri("MAROON",86,"maroon"),Fe=new ri("MEDIUM_AQUA_MARINE",87,"mediumaquamarine"),qe=new ri("MEDIUM_BLUE",88,"mediumblue"),Ge=new ri("MEDIUM_ORCHID",89,"mediumorchid"),He=new ri("MEDIUM_PURPLE",90,"mediumpurple"),Ye=new ri("MEDIUM_SEAGREEN",91,"mediumseagreen"),Ve=new ri("MEDIUM_SLATE_BLUE",92,"mediumslateblue"),Ke=new ri("MEDIUM_SPRING_GREEN",93,"mediumspringgreen"),We=new ri("MEDIUM_TURQUOISE",94,"mediumturquoise"),Xe=new ri("MEDIUM_VIOLET_RED",95,"mediumvioletred"),Ze=new ri("MIDNIGHT_BLUE",96,"midnightblue"),Je=new ri("MINT_CREAM",97,"mintcream"),Qe=new ri("MISTY_ROSE",98,"mistyrose"),tn=new ri("MOCCASIN",99,"moccasin"),en=new ri("NAVAJO_WHITE",100,"navajowhite"),nn=new ri("NAVY",101,"navy"),rn=new ri("OLD_LACE",102,"oldlace"),on=new ri("OLIVE",103,"olive"),an=new ri("OLIVE_DRAB",104,"olivedrab"),sn=new ri("ORANGE",105,"orange"),ln=new ri("ORANGE_RED",106,"orangered"),un=new ri("ORCHID",107,"orchid"),cn=new ri("PALE_GOLDEN_ROD",108,"palegoldenrod"),pn=new ri("PALE_GREEN",109,"palegreen"),hn=new ri("PALE_TURQUOISE",110,"paleturquoise"),_n=new ri("PALE_VIOLET_RED",111,"palevioletred"),fn=new ri("PAPAYA_WHIP",112,"papayawhip"),dn=new ri("PEACH_PUFF",113,"peachpuff"),mn=new ri("PERU",114,"peru"),yn=new ri("PINK",115,"pink"),$n=new ri("PLUM",116,"plum"),vn=new ri("POWDER_BLUE",117,"powderblue"),gn=new ri("PURPLE",118,"purple"),bn=new ri("RED",119,"red"),wn=new ri("ROSY_BROWN",120,"rosybrown"),xn=new ri("ROYAL_BLUE",121,"royalblue"),kn=new ri("SADDLE_BROWN",122,"saddlebrown"),En=new ri("SALMON",123,"salmon"),Cn=new ri("SANDY_BROWN",124,"sandybrown"),Sn=new ri("SEA_GREEN",125,"seagreen"),Tn=new ri("SEASHELL",126,"seashell"),On=new ri("SIENNA",127,"sienna"),Nn=new ri("SILVER",128,"silver"),Pn=new ri("SKY_BLUE",129,"skyblue"),An=new ri("SLATE_BLUE",130,"slateblue"),jn=new ri("SLATE_GRAY",131,"slategray"),Ln=new ri("SLATE_GREY",132,"slategrey"),Rn=new ri("SNOW",133,"snow"),In=new ri("SPRING_GREEN",134,"springgreen"),zn=new ri("STEEL_BLUE",135,"steelblue"),Dn=new ri("TAN",136,"tan"),Mn=new ri("TEAL",137,"teal"),Bn=new ri("THISTLE",138,"thistle"),Un=new ri("TOMATO",139,"tomato"),Fn=new ri("TURQUOISE",140,"turquoise"),qn=new ri("VIOLET",141,"violet"),Gn=new ri("WHEAT",142,"wheat"),Hn=new ri("WHITE",143,"white"),Yn=new ri("WHITE_SMOKE",144,"whitesmoke"),Vn=new ri("YELLOW",145,"yellow"),Kn=new ri("YELLOW_GREEN",146,"yellowgreen"),Wn=new ri("NONE",147,"none"),Xn=new ri("CURRENT_COLOR",148,"currentColor"),Zo()}function ai(){return oi(),ut}function si(){return oi(),ct}function li(){return oi(),pt}function ui(){return oi(),ht}function ci(){return oi(),_t}function pi(){return oi(),ft}function hi(){return oi(),dt}function _i(){return oi(),mt}function fi(){return oi(),yt}function di(){return oi(),$t}function mi(){return oi(),vt}function yi(){return oi(),gt}function $i(){return oi(),bt}function vi(){return oi(),wt}function gi(){return oi(),xt}function bi(){return oi(),kt}function wi(){return oi(),Et}function xi(){return oi(),Ct}function ki(){return oi(),St}function Ei(){return oi(),Tt}function Ci(){return oi(),Ot}function Si(){return oi(),Nt}function Ti(){return oi(),Pt}function Oi(){return oi(),At}function Ni(){return oi(),jt}function Pi(){return oi(),Lt}function Ai(){return oi(),Rt}function ji(){return oi(),It}function Li(){return oi(),zt}function Ri(){return oi(),Dt}function Ii(){return oi(),Mt}function zi(){return oi(),Bt}function Di(){return oi(),Ut}function Mi(){return oi(),Ft}function Bi(){return oi(),qt}function Ui(){return oi(),Gt}function Fi(){return oi(),Ht}function qi(){return oi(),Yt}function Gi(){return oi(),Vt}function Hi(){return oi(),Kt}function Yi(){return oi(),Wt}function Vi(){return oi(),Xt}function Ki(){return oi(),Zt}function Wi(){return oi(),Jt}function Xi(){return oi(),Qt}function Zi(){return oi(),te}function Ji(){return oi(),ee}function Qi(){return oi(),ne}function tr(){return oi(),ie}function er(){return oi(),re}function nr(){return oi(),oe}function ir(){return oi(),ae}function rr(){return oi(),se}function or(){return oi(),le}function ar(){return oi(),ue}function sr(){return oi(),ce}function lr(){return oi(),pe}function ur(){return oi(),he}function cr(){return oi(),_e}function pr(){return oi(),fe}function hr(){return oi(),de}function _r(){return oi(),me}function fr(){return oi(),ye}function dr(){return oi(),$e}function mr(){return oi(),ve}function yr(){return oi(),ge}function $r(){return oi(),be}function vr(){return oi(),we}function gr(){return oi(),xe}function br(){return oi(),ke}function wr(){return oi(),Ee}function xr(){return oi(),Ce}function kr(){return oi(),Se}function Er(){return oi(),Te}function Cr(){return oi(),Oe}function Sr(){return oi(),Ne}function Tr(){return oi(),Pe}function Or(){return oi(),Ae}function Nr(){return oi(),je}function Pr(){return oi(),Le}function Ar(){return oi(),Re}function jr(){return oi(),Ie}function Lr(){return oi(),ze}function Rr(){return oi(),De}function Ir(){return oi(),Me}function zr(){return oi(),Be}function Dr(){return oi(),Ue}function Mr(){return oi(),Fe}function Br(){return oi(),qe}function Ur(){return oi(),Ge}function Fr(){return oi(),He}function qr(){return oi(),Ye}function Gr(){return oi(),Ve}function Hr(){return oi(),Ke}function Yr(){return oi(),We}function Vr(){return oi(),Xe}function Kr(){return oi(),Ze}function Wr(){return oi(),Je}function Xr(){return oi(),Qe}function Zr(){return oi(),tn}function Jr(){return oi(),en}function Qr(){return oi(),nn}function to(){return oi(),rn}function eo(){return oi(),on}function no(){return oi(),an}function io(){return oi(),sn}function ro(){return oi(),ln}function oo(){return oi(),un}function ao(){return oi(),cn}function so(){return oi(),pn}function lo(){return oi(),hn}function uo(){return oi(),_n}function co(){return oi(),fn}function po(){return oi(),dn}function ho(){return oi(),mn}function _o(){return oi(),yn}function fo(){return oi(),$n}function mo(){return oi(),vn}function yo(){return oi(),gn}function $o(){return oi(),bn}function vo(){return oi(),wn}function go(){return oi(),xn}function bo(){return oi(),kn}function wo(){return oi(),En}function xo(){return oi(),Cn}function ko(){return oi(),Sn}function Eo(){return oi(),Tn}function Co(){return oi(),On}function So(){return oi(),Nn}function To(){return oi(),Pn}function Oo(){return oi(),An}function No(){return oi(),jn}function Po(){return oi(),Ln}function Ao(){return oi(),Rn}function jo(){return oi(),In}function Lo(){return oi(),zn}function Ro(){return oi(),Dn}function Io(){return oi(),Mn}function zo(){return oi(),Bn}function Do(){return oi(),Un}function Mo(){return oi(),Fn}function Bo(){return oi(),qn}function Uo(){return oi(),Gn}function Fo(){return oi(),Hn}function qo(){return oi(),Yn}function Go(){return oi(),Vn}function Ho(){return oi(),Kn}function Yo(){return oi(),Wn}function Vo(){return oi(),Xn}function Ko(){Xo=this,this.svgColorList_0=this.createSvgColorList_0()}function Wo(t,e,n){this.myR_0=t,this.myG_0=e,this.myB_0=n}Object.defineProperty(ot.prototype,"elementName",{configurable:!0,get:function(){return"clipPath"}}),Object.defineProperty(ot.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),ot.prototype.clipPathUnits=function(){return this.getAttribute_mumjwj$(Jn().CLIP_PATH_UNITS_0)},ot.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},ot.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},ot.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Qn.prototype.toString=function(){return this.myAttributeString_ss0dpy$_0},Qn.$metadata$={kind:s,simpleName:"ClipPathUnits",interfaces:[u]},Qn.values=function(){return[ei(),ni()]},Qn.valueOf_61zpoe$=function(t){switch(t){case"USER_SPACE_ON_USE":return ei();case"OBJECT_BOUNDING_BOX":return ni();default:c("No enum constant jetbrains.datalore.vis.svg.SvgClipPathElement.ClipPathUnits."+t)}},ot.$metadata$={kind:s,simpleName:"SvgClipPathElement",interfaces:[_u,Oa]},ii.$metadata$={kind:p,simpleName:"SvgColor",interfaces:[]},ri.prototype.toString=function(){return this.literal_7kwssz$_0},Ko.prototype.createSvgColorList_0=function(){var t,e=h(),n=Jo();for(t=0;t!==n.length;++t){var i=n[t],r=i.toString().toLowerCase();e.put_xwzc9p$(r,i)}return e},Ko.prototype.isColorName_61zpoe$=function(t){return this.svgColorList_0.containsKey_11rb$(t.toLowerCase())},Ko.prototype.forName_61zpoe$=function(t){var e;if(null==(e=this.svgColorList_0.get_11rb$(t.toLowerCase())))throw _();return e},Ko.prototype.create_qt1dr2$=function(t,e,n){return new Wo(t,e,n)},Ko.prototype.create_2160e9$=function(t){return null==t?Yo():new Wo(t.red,t.green,t.blue)},Wo.prototype.toString=function(){return"rgb("+this.myR_0+","+this.myG_0+","+this.myB_0+")"},Wo.$metadata$={kind:s,simpleName:"SvgColorRgb",interfaces:[ii]},Wo.prototype.component1_0=function(){return this.myR_0},Wo.prototype.component2_0=function(){return this.myG_0},Wo.prototype.component3_0=function(){return this.myB_0},Wo.prototype.copy_qt1dr2$=function(t,e,n){return new Wo(void 0===t?this.myR_0:t,void 0===e?this.myG_0:e,void 0===n?this.myB_0:n)},Wo.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.myR_0)|0)+e.hashCode(this.myG_0)|0)+e.hashCode(this.myB_0)|0},Wo.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.myR_0,t.myR_0)&&e.equals(this.myG_0,t.myG_0)&&e.equals(this.myB_0,t.myB_0)},Ko.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Xo=null;function Zo(){return oi(),null===Xo&&new Ko,Xo}function Jo(){return[ai(),si(),li(),ui(),ci(),pi(),hi(),_i(),fi(),di(),mi(),yi(),$i(),vi(),gi(),bi(),wi(),xi(),ki(),Ei(),Ci(),Si(),Ti(),Oi(),Ni(),Pi(),Ai(),ji(),Li(),Ri(),Ii(),zi(),Di(),Mi(),Bi(),Ui(),Fi(),qi(),Gi(),Hi(),Yi(),Vi(),Ki(),Wi(),Xi(),Zi(),Ji(),Qi(),tr(),er(),nr(),ir(),rr(),or(),ar(),sr(),lr(),ur(),cr(),pr(),hr(),_r(),fr(),dr(),mr(),yr(),$r(),vr(),gr(),br(),wr(),xr(),kr(),Er(),Cr(),Sr(),Tr(),Or(),Nr(),Pr(),Ar(),jr(),Lr(),Rr(),Ir(),zr(),Dr(),Mr(),Br(),Ur(),Fr(),qr(),Gr(),Hr(),Yr(),Vr(),Kr(),Wr(),Xr(),Zr(),Jr(),Qr(),to(),eo(),no(),io(),ro(),oo(),ao(),so(),lo(),uo(),co(),po(),ho(),_o(),fo(),mo(),yo(),$o(),vo(),go(),bo(),wo(),xo(),ko(),Eo(),Co(),So(),To(),Oo(),No(),Po(),Ao(),jo(),Lo(),Ro(),Io(),zo(),Do(),Mo(),Bo(),Uo(),Fo(),qo(),Go(),Ho(),Yo(),Vo()]}function Qo(){ta=this,this.WIDTH="width",this.HEIGHT="height",this.SVG_TEXT_ANCHOR_ATTRIBUTE="text-anchor",this.SVG_STROKE_DASHARRAY_ATTRIBUTE="stroke-dasharray",this.SVG_STYLE_ATTRIBUTE="style",this.SVG_TEXT_DY_ATTRIBUTE="dy",this.SVG_TEXT_ANCHOR_START="start",this.SVG_TEXT_ANCHOR_MIDDLE="middle",this.SVG_TEXT_ANCHOR_END="end",this.SVG_TEXT_DY_TOP="0.7em",this.SVG_TEXT_DY_CENTER="0.35em"}ri.$metadata$={kind:s,simpleName:"SvgColors",interfaces:[ii,u]},ri.values=Jo,ri.valueOf_61zpoe$=function(t){switch(t){case"ALICE_BLUE":return ai();case"ANTIQUE_WHITE":return si();case"AQUA":return li();case"AQUAMARINE":return ui();case"AZURE":return ci();case"BEIGE":return pi();case"BISQUE":return hi();case"BLACK":return _i();case"BLANCHED_ALMOND":return fi();case"BLUE":return di();case"BLUE_VIOLET":return mi();case"BROWN":return yi();case"BURLY_WOOD":return $i();case"CADET_BLUE":return vi();case"CHARTREUSE":return gi();case"CHOCOLATE":return bi();case"CORAL":return wi();case"CORNFLOWER_BLUE":return xi();case"CORNSILK":return ki();case"CRIMSON":return Ei();case"CYAN":return Ci();case"DARK_BLUE":return Si();case"DARK_CYAN":return Ti();case"DARK_GOLDEN_ROD":return Oi();case"DARK_GRAY":return Ni();case"DARK_GREEN":return Pi();case"DARK_GREY":return Ai();case"DARK_KHAKI":return ji();case"DARK_MAGENTA":return Li();case"DARK_OLIVE_GREEN":return Ri();case"DARK_ORANGE":return Ii();case"DARK_ORCHID":return zi();case"DARK_RED":return Di();case"DARK_SALMON":return Mi();case"DARK_SEA_GREEN":return Bi();case"DARK_SLATE_BLUE":return Ui();case"DARK_SLATE_GRAY":return Fi();case"DARK_SLATE_GREY":return qi();case"DARK_TURQUOISE":return Gi();case"DARK_VIOLET":return Hi();case"DEEP_PINK":return Yi();case"DEEP_SKY_BLUE":return Vi();case"DIM_GRAY":return Ki();case"DIM_GREY":return Wi();case"DODGER_BLUE":return Xi();case"FIRE_BRICK":return Zi();case"FLORAL_WHITE":return Ji();case"FOREST_GREEN":return Qi();case"FUCHSIA":return tr();case"GAINSBORO":return er();case"GHOST_WHITE":return nr();case"GOLD":return ir();case"GOLDEN_ROD":return rr();case"GRAY":return or();case"GREY":return ar();case"GREEN":return sr();case"GREEN_YELLOW":return lr();case"HONEY_DEW":return ur();case"HOT_PINK":return cr();case"INDIAN_RED":return pr();case"INDIGO":return hr();case"IVORY":return _r();case"KHAKI":return fr();case"LAVENDER":return dr();case"LAVENDER_BLUSH":return mr();case"LAWN_GREEN":return yr();case"LEMON_CHIFFON":return $r();case"LIGHT_BLUE":return vr();case"LIGHT_CORAL":return gr();case"LIGHT_CYAN":return br();case"LIGHT_GOLDEN_ROD_YELLOW":return wr();case"LIGHT_GRAY":return xr();case"LIGHT_GREEN":return kr();case"LIGHT_GREY":return Er();case"LIGHT_PINK":return Cr();case"LIGHT_SALMON":return Sr();case"LIGHT_SEA_GREEN":return Tr();case"LIGHT_SKY_BLUE":return Or();case"LIGHT_SLATE_GRAY":return Nr();case"LIGHT_SLATE_GREY":return Pr();case"LIGHT_STEEL_BLUE":return Ar();case"LIGHT_YELLOW":return jr();case"LIME":return Lr();case"LIME_GREEN":return Rr();case"LINEN":return Ir();case"MAGENTA":return zr();case"MAROON":return Dr();case"MEDIUM_AQUA_MARINE":return Mr();case"MEDIUM_BLUE":return Br();case"MEDIUM_ORCHID":return Ur();case"MEDIUM_PURPLE":return Fr();case"MEDIUM_SEAGREEN":return qr();case"MEDIUM_SLATE_BLUE":return Gr();case"MEDIUM_SPRING_GREEN":return Hr();case"MEDIUM_TURQUOISE":return Yr();case"MEDIUM_VIOLET_RED":return Vr();case"MIDNIGHT_BLUE":return Kr();case"MINT_CREAM":return Wr();case"MISTY_ROSE":return Xr();case"MOCCASIN":return Zr();case"NAVAJO_WHITE":return Jr();case"NAVY":return Qr();case"OLD_LACE":return to();case"OLIVE":return eo();case"OLIVE_DRAB":return no();case"ORANGE":return io();case"ORANGE_RED":return ro();case"ORCHID":return oo();case"PALE_GOLDEN_ROD":return ao();case"PALE_GREEN":return so();case"PALE_TURQUOISE":return lo();case"PALE_VIOLET_RED":return uo();case"PAPAYA_WHIP":return co();case"PEACH_PUFF":return po();case"PERU":return ho();case"PINK":return _o();case"PLUM":return fo();case"POWDER_BLUE":return mo();case"PURPLE":return yo();case"RED":return $o();case"ROSY_BROWN":return vo();case"ROYAL_BLUE":return go();case"SADDLE_BROWN":return bo();case"SALMON":return wo();case"SANDY_BROWN":return xo();case"SEA_GREEN":return ko();case"SEASHELL":return Eo();case"SIENNA":return Co();case"SILVER":return So();case"SKY_BLUE":return To();case"SLATE_BLUE":return Oo();case"SLATE_GRAY":return No();case"SLATE_GREY":return Po();case"SNOW":return Ao();case"SPRING_GREEN":return jo();case"STEEL_BLUE":return Lo();case"TAN":return Ro();case"TEAL":return Io();case"THISTLE":return zo();case"TOMATO":return Do();case"TURQUOISE":return Mo();case"VIOLET":return Bo();case"WHEAT":return Uo();case"WHITE":return Fo();case"WHITE_SMOKE":return qo();case"YELLOW":return Go();case"YELLOW_GREEN":return Ho();case"NONE":return Yo();case"CURRENT_COLOR":return Vo();default:c("No enum constant jetbrains.datalore.vis.svg.SvgColors."+t)}},Qo.$metadata$={kind:i,simpleName:"SvgConstants",interfaces:[]};var ta=null;function ea(){return null===ta&&new Qo,ta}function na(){oa()}function ia(){ra=this,this.OPACITY=tt().createSpec_ytbaoo$("opacity"),this.CLIP_PATH=tt().createSpec_ytbaoo$("clip-path")}ia.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ra=null;function oa(){return null===ra&&new ia,ra}function aa(){}function sa(){Oa.call(this),this.elementName_ohv755$_0="defs"}function la(){pa(),Is.call(this),this.myAttributes_9lwppr$_0=new ma(this),this.myListeners_acqj1r$_0=null,this.myEventPeer_bxokaa$_0=new wa}function ua(){ca=this,this.ID_0=tt().createSpec_ytbaoo$("id")}na.$metadata$={kind:p,simpleName:"SvgContainer",interfaces:[]},aa.$metadata$={kind:p,simpleName:"SvgCssResource",interfaces:[]},Object.defineProperty(sa.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_ohv755$_0}}),Object.defineProperty(sa.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),sa.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},sa.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},sa.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},sa.$metadata$={kind:s,simpleName:"SvgDefsElement",interfaces:[_u,na,Oa]},ua.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ca=null;function pa(){return null===ca&&new ua,ca}function ha(t,e){this.closure$spec=t,this.this$SvgElement=e}function _a(t,e){this.closure$spec=t,this.closure$handler=e}function fa(t){this.closure$event=t}function da(t,e){this.closure$reg=t,this.this$SvgElement=e,v.call(this)}function ma(t){this.$outer=t,this.myAttrs_0=null}function ya(){}function $a(){ba(),Oa.call(this),this.elementName_psynub$_0="ellipse"}function va(){ga=this,this.CX=tt().createSpec_ytbaoo$("cx"),this.CY=tt().createSpec_ytbaoo$("cy"),this.RX=tt().createSpec_ytbaoo$("rx"),this.RY=tt().createSpec_ytbaoo$("ry")}Object.defineProperty(la.prototype,"ownerSvgElement",{configurable:!0,get:function(){for(var t,n=this;null!=n&&!e.isType(n,zl);)n=n.parentProperty().get();return null!=n?null==(t=n)||e.isType(t,zl)?t:o():null}}),Object.defineProperty(la.prototype,"attributeKeys",{configurable:!0,get:function(){return this.myAttributes_9lwppr$_0.keySet()}}),la.prototype.id=function(){return this.getAttribute_mumjwj$(pa().ID_0)},la.prototype.handlersSet=function(){return this.myEventPeer_bxokaa$_0.handlersSet()},la.prototype.addEventHandler_mm8kk2$=function(t,e){return this.myEventPeer_bxokaa$_0.addEventHandler_mm8kk2$(t,e)},la.prototype.dispatch_lgzia2$=function(t,n){var i;this.myEventPeer_bxokaa$_0.dispatch_2raoxs$(t,n,this),null!=this.parentProperty().get()&&!n.isConsumed&&e.isType(this.parentProperty().get(),la)&&(e.isType(i=this.parentProperty().get(),la)?i:o()).dispatch_lgzia2$(t,n)},la.prototype.getSpecByName_o4z2a7$_0=function(t){return tt().createSpec_ytbaoo$(t)},Object.defineProperty(ha.prototype,"propExpr",{configurable:!0,get:function(){return this.toString()+"."+this.closure$spec}}),ha.prototype.get=function(){return this.this$SvgElement.myAttributes_9lwppr$_0.get_mumjwj$(this.closure$spec)},ha.prototype.set_11rb$=function(t){this.this$SvgElement.myAttributes_9lwppr$_0.set_qdh7ux$(this.closure$spec,t)},_a.prototype.onAttrSet_ud3ldc$=function(t){var n,i;if(this.closure$spec===t.attrSpec){var r=null==(n=t.oldValue)||e.isType(n,f)?n:o(),a=null==(i=t.newValue)||e.isType(i,f)?i:o();this.closure$handler.onEvent_11rb$(new d(r,a))}},_a.$metadata$={kind:s,interfaces:[ya]},ha.prototype.addHandler_gxwwpc$=function(t){return this.this$SvgElement.addListener_e4m8w6$(new _a(this.closure$spec,t))},ha.$metadata$={kind:s,interfaces:[m]},la.prototype.getAttribute_mumjwj$=function(t){return new ha(t,this)},la.prototype.getAttribute_61zpoe$=function(t){var e=this.getSpecByName_o4z2a7$_0(t);return this.getAttribute_mumjwj$(e)},la.prototype.setAttribute_qdh7ux$=function(t,e){this.getAttribute_mumjwj$(t).set_11rb$(e)},la.prototype.setAttribute_jyasbz$=function(t,e){this.getAttribute_61zpoe$(t).set_11rb$(e)},fa.prototype.call_11rb$=function(t){t.onAttrSet_ud3ldc$(this.closure$event)},fa.$metadata$={kind:s,interfaces:[y]},la.prototype.onAttributeChanged_2oaikr$_0=function(t){null!=this.myListeners_acqj1r$_0&&l(this.myListeners_acqj1r$_0).fire_kucmxw$(new fa(t)),this.isAttached()&&this.container().attributeChanged_1u4bot$(this,t)},da.prototype.doRemove=function(){this.closure$reg.remove(),l(this.this$SvgElement.myListeners_acqj1r$_0).isEmpty&&(this.this$SvgElement.myListeners_acqj1r$_0=null)},da.$metadata$={kind:s,interfaces:[v]},la.prototype.addListener_e4m8w6$=function(t){return null==this.myListeners_acqj1r$_0&&(this.myListeners_acqj1r$_0=new $),new da(l(this.myListeners_acqj1r$_0).add_11rb$(t),this)},la.prototype.toString=function(){return"<"+this.elementName+" "+this.myAttributes_9lwppr$_0.toSvgString_8be2vx$()+">"},Object.defineProperty(ma.prototype,"isEmpty",{configurable:!0,get:function(){return null==this.myAttrs_0||l(this.myAttrs_0).isEmpty}}),ma.prototype.size=function(){return null==this.myAttrs_0?0:l(this.myAttrs_0).size()},ma.prototype.containsKey_p8ci7$=function(t){return null!=this.myAttrs_0&&l(this.myAttrs_0).containsKey_11rb$(t)},ma.prototype.get_mumjwj$=function(t){var n;return null!=this.myAttrs_0&&l(this.myAttrs_0).containsKey_11rb$(t)?null==(n=l(this.myAttrs_0).get_11rb$(t))||e.isType(n,f)?n:o():null},ma.prototype.set_qdh7ux$=function(t,n){var i,r;null==this.myAttrs_0&&(this.myAttrs_0=new g);var s=null==n?null==(i=l(this.myAttrs_0).remove_11rb$(t))||e.isType(i,f)?i:o():null==(r=l(this.myAttrs_0).put_xwzc9p$(t,n))||e.isType(r,f)?r:o();if(!a(n,s)){var u=new Nu(t,s,n);this.$outer.onAttributeChanged_2oaikr$_0(u)}return s},ma.prototype.remove_mumjwj$=function(t){return this.set_qdh7ux$(t,null)},ma.prototype.keySet=function(){return null==this.myAttrs_0?b():l(this.myAttrs_0).keySet()},ma.prototype.toSvgString_8be2vx$=function(){var t,e=w();for(t=this.keySet().iterator();t.hasNext();){var n=t.next();e.append_pdl1vj$(n.name).append_pdl1vj$('="').append_s8jyv4$(this.get_mumjwj$(n)).append_pdl1vj$('" ')}return e.toString()},ma.prototype.toString=function(){return this.toSvgString_8be2vx$()},ma.$metadata$={kind:s,simpleName:"AttributeMap",interfaces:[]},la.$metadata$={kind:s,simpleName:"SvgElement",interfaces:[Is]},ya.$metadata$={kind:p,simpleName:"SvgElementListener",interfaces:[]},va.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ga=null;function ba(){return null===ga&&new va,ga}function wa(){this.myEventHandlers_0=null,this.myListeners_0=null}function xa(t){this.this$SvgEventPeer=t}function ka(t,e){this.closure$addReg=t,this.this$SvgEventPeer=e,v.call(this)}function Ea(t,e,n,i){this.closure$addReg=t,this.closure$specListeners=e,this.closure$eventHandlers=n,this.closure$spec=i,v.call(this)}function Ca(t,e){this.closure$oldHandlersSet=t,this.this$SvgEventPeer=e}function Sa(t,e){this.closure$event=t,this.closure$target=e}function Ta(){Oa.call(this),this.elementName_84zyy2$_0="g"}function Oa(){Ya(),Al.call(this)}function Na(){Ha=this,this.POINTER_EVENTS_0=tt().createSpec_ytbaoo$("pointer-events"),this.OPACITY=tt().createSpec_ytbaoo$("opacity"),this.VISIBILITY=tt().createSpec_ytbaoo$("visibility"),this.CLIP_PATH=tt().createSpec_ytbaoo$("clip-path"),this.CLIP_BOUNDS_JFX=tt().createSpec_ytbaoo$("clip-bounds-jfx")}Object.defineProperty($a.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_psynub$_0}}),Object.defineProperty($a.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),$a.prototype.cx=function(){return this.getAttribute_mumjwj$(ba().CX)},$a.prototype.cy=function(){return this.getAttribute_mumjwj$(ba().CY)},$a.prototype.rx=function(){return this.getAttribute_mumjwj$(ba().RX)},$a.prototype.ry=function(){return this.getAttribute_mumjwj$(ba().RY)},$a.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},$a.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},$a.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},$a.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},$a.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},$a.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},$a.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},$a.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},$a.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},$a.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},$a.$metadata$={kind:s,simpleName:"SvgEllipseElement",interfaces:[Tl,_u,Oa]},Object.defineProperty(xa.prototype,"propExpr",{configurable:!0,get:function(){return this.toString()+".handlersProp"}}),xa.prototype.get=function(){return this.this$SvgEventPeer.handlersKeySet_0()},ka.prototype.doRemove=function(){this.closure$addReg.remove(),l(this.this$SvgEventPeer.myListeners_0).isEmpty&&(this.this$SvgEventPeer.myListeners_0=null)},ka.$metadata$={kind:s,interfaces:[v]},xa.prototype.addHandler_gxwwpc$=function(t){return null==this.this$SvgEventPeer.myListeners_0&&(this.this$SvgEventPeer.myListeners_0=new $),new ka(l(this.this$SvgEventPeer.myListeners_0).add_11rb$(t),this.this$SvgEventPeer)},xa.$metadata$={kind:s,interfaces:[x]},wa.prototype.handlersSet=function(){return new xa(this)},wa.prototype.handlersKeySet_0=function(){return null==this.myEventHandlers_0?b():l(this.myEventHandlers_0).keys},Ea.prototype.doRemove=function(){this.closure$addReg.remove(),this.closure$specListeners.isEmpty&&this.closure$eventHandlers.remove_11rb$(this.closure$spec)},Ea.$metadata$={kind:s,interfaces:[v]},Ca.prototype.call_11rb$=function(t){t.onEvent_11rb$(new d(this.closure$oldHandlersSet,this.this$SvgEventPeer.handlersKeySet_0()))},Ca.$metadata$={kind:s,interfaces:[y]},wa.prototype.addEventHandler_mm8kk2$=function(t,e){var n;null==this.myEventHandlers_0&&(this.myEventHandlers_0=h());var i=l(this.myEventHandlers_0);if(!i.containsKey_11rb$(t)){var r=new $;i.put_xwzc9p$(t,r)}var o=i.keys,a=l(i.get_11rb$(t)),s=new Ea(a.add_11rb$(e),a,i,t);return null!=(n=this.myListeners_0)&&n.fire_kucmxw$(new Ca(o,this)),s},Sa.prototype.call_11rb$=function(t){var n;this.closure$event.isConsumed||(e.isType(n=t,Pu)?n:o()).handle_42da0z$(this.closure$target,this.closure$event)},Sa.$metadata$={kind:s,interfaces:[y]},wa.prototype.dispatch_2raoxs$=function(t,e,n){null!=this.myEventHandlers_0&&l(this.myEventHandlers_0).containsKey_11rb$(t)&&l(l(this.myEventHandlers_0).get_11rb$(t)).fire_kucmxw$(new Sa(e,n))},wa.$metadata$={kind:s,simpleName:"SvgEventPeer",interfaces:[]},Object.defineProperty(Ta.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_84zyy2$_0}}),Object.defineProperty(Ta.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),Ta.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},Ta.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},Ta.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Ta.$metadata$={kind:s,simpleName:"SvgGElement",interfaces:[na,_u,Oa]},Na.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Pa,Aa,ja,La,Ra,Ia,za,Da,Ma,Ba,Ua,Fa,qa,Ga,Ha=null;function Ya(){return null===Ha&&new Na,Ha}function Va(t,e,n){u.call(this),this.myAttributeString_wpy0pw$_0=n,this.name$=t,this.ordinal$=e}function Ka(){Ka=function(){},Pa=new Va("VISIBLE_PAINTED",0,"visiblePainted"),Aa=new Va("VISIBLE_FILL",1,"visibleFill"),ja=new Va("VISIBLE_STROKE",2,"visibleStroke"),La=new Va("VISIBLE",3,"visible"),Ra=new Va("PAINTED",4,"painted"),Ia=new Va("FILL",5,"fill"),za=new Va("STROKE",6,"stroke"),Da=new Va("ALL",7,"all"),Ma=new Va("NONE",8,"none"),Ba=new Va("INHERIT",9,"inherit")}function Wa(){return Ka(),Pa}function Xa(){return Ka(),Aa}function Za(){return Ka(),ja}function Ja(){return Ka(),La}function Qa(){return Ka(),Ra}function ts(){return Ka(),Ia}function es(){return Ka(),za}function ns(){return Ka(),Da}function is(){return Ka(),Ma}function rs(){return Ka(),Ba}function os(t,e,n){u.call(this),this.myAttrString_w3r471$_0=n,this.name$=t,this.ordinal$=e}function as(){as=function(){},Ua=new os("VISIBLE",0,"visible"),Fa=new os("HIDDEN",1,"hidden"),qa=new os("COLLAPSE",2,"collapse"),Ga=new os("INHERIT",3,"inherit")}function ss(){return as(),Ua}function ls(){return as(),Fa}function us(){return as(),qa}function cs(){return as(),Ga}function ps(t){this.myElementId_0=t}function hs(){ds(),Oa.call(this),this.elementName_r17hoq$_0="image",this.setAttribute_qdh7ux$(ds().PRESERVE_ASPECT_RATIO,"none"),this.setAttribute_jyasbz$(ea().SVG_STYLE_ATTRIBUTE,"image-rendering: pixelated;image-rendering: crisp-edges;")}function _s(){fs=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT),this.HREF=tt().createSpecNS_wswq18$("href",Ou().XLINK_PREFIX,Ou().XLINK_NAMESPACE_URI),this.PRESERVE_ASPECT_RATIO=tt().createSpec_ytbaoo$("preserveAspectRatio")}Oa.prototype.pointerEvents=function(){return this.getAttribute_mumjwj$(Ya().POINTER_EVENTS_0)},Oa.prototype.opacity=function(){return this.getAttribute_mumjwj$(Ya().OPACITY)},Oa.prototype.visibility=function(){return this.getAttribute_mumjwj$(Ya().VISIBILITY)},Oa.prototype.clipPath=function(){return this.getAttribute_mumjwj$(Ya().CLIP_PATH)},Va.prototype.toString=function(){return this.myAttributeString_wpy0pw$_0},Va.$metadata$={kind:s,simpleName:"PointerEvents",interfaces:[u]},Va.values=function(){return[Wa(),Xa(),Za(),Ja(),Qa(),ts(),es(),ns(),is(),rs()]},Va.valueOf_61zpoe$=function(t){switch(t){case"VISIBLE_PAINTED":return Wa();case"VISIBLE_FILL":return Xa();case"VISIBLE_STROKE":return Za();case"VISIBLE":return Ja();case"PAINTED":return Qa();case"FILL":return ts();case"STROKE":return es();case"ALL":return ns();case"NONE":return is();case"INHERIT":return rs();default:c("No enum constant jetbrains.datalore.vis.svg.SvgGraphicsElement.PointerEvents."+t)}},os.prototype.toString=function(){return this.myAttrString_w3r471$_0},os.$metadata$={kind:s,simpleName:"Visibility",interfaces:[u]},os.values=function(){return[ss(),ls(),us(),cs()]},os.valueOf_61zpoe$=function(t){switch(t){case"VISIBLE":return ss();case"HIDDEN":return ls();case"COLLAPSE":return us();case"INHERIT":return cs();default:c("No enum constant jetbrains.datalore.vis.svg.SvgGraphicsElement.Visibility."+t)}},Oa.$metadata$={kind:s,simpleName:"SvgGraphicsElement",interfaces:[Al]},ps.prototype.toString=function(){return"url(#"+this.myElementId_0+")"},ps.$metadata$={kind:s,simpleName:"SvgIRI",interfaces:[]},_s.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var fs=null;function ds(){return null===fs&&new _s,fs}function ms(t,e,n,i,r){return r=r||Object.create(hs.prototype),hs.call(r),r.setAttribute_qdh7ux$(ds().X,t),r.setAttribute_qdh7ux$(ds().Y,e),r.setAttribute_qdh7ux$(ds().WIDTH,n),r.setAttribute_qdh7ux$(ds().HEIGHT,i),r}function ys(t,e,n,i,r){ms(t,e,n,i,this),this.myBitmap_0=r}function $s(t,e){this.closure$hrefProp=t,this.this$SvgImageElementEx=e}function vs(){}function gs(t,e,n){this.width=t,this.height=e,this.argbValues=n.slice()}function bs(){Ls(),Oa.call(this),this.elementName_7igd9t$_0="line"}function ws(){js=this,this.X1=tt().createSpec_ytbaoo$("x1"),this.Y1=tt().createSpec_ytbaoo$("y1"),this.X2=tt().createSpec_ytbaoo$("x2"),this.Y2=tt().createSpec_ytbaoo$("y2")}Object.defineProperty(hs.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_r17hoq$_0}}),Object.defineProperty(hs.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),hs.prototype.x=function(){return this.getAttribute_mumjwj$(ds().X)},hs.prototype.y=function(){return this.getAttribute_mumjwj$(ds().Y)},hs.prototype.width=function(){return this.getAttribute_mumjwj$(ds().WIDTH)},hs.prototype.height=function(){return this.getAttribute_mumjwj$(ds().HEIGHT)},hs.prototype.href=function(){return this.getAttribute_mumjwj$(ds().HREF)},hs.prototype.preserveAspectRatio=function(){return this.getAttribute_mumjwj$(ds().PRESERVE_ASPECT_RATIO)},hs.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},hs.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},hs.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},hs.$metadata$={kind:s,simpleName:"SvgImageElement",interfaces:[_u,Oa]},Object.defineProperty($s.prototype,"propExpr",{configurable:!0,get:function(){return this.closure$hrefProp.propExpr}}),$s.prototype.get=function(){return this.closure$hrefProp.get()},$s.prototype.addHandler_gxwwpc$=function(t){return this.closure$hrefProp.addHandler_gxwwpc$(t)},$s.prototype.set_11rb$=function(t){throw k("href property is read-only in "+e.getKClassFromExpression(this.this$SvgImageElementEx).simpleName)},$s.$metadata$={kind:s,interfaces:[m]},ys.prototype.href=function(){return new $s(hs.prototype.href.call(this),this)},ys.prototype.asImageElement_xhdger$=function(t){var e=new hs;gu().copyAttributes_azdp7k$(this,e);var n=t.toDataUrl_nps3vt$(this.myBitmap_0.width,this.myBitmap_0.height,this.myBitmap_0.argbValues);return e.href().set_11rb$(n),e},vs.$metadata$={kind:p,simpleName:"RGBEncoder",interfaces:[]},gs.$metadata$={kind:s,simpleName:"Bitmap",interfaces:[]},ys.$metadata$={kind:s,simpleName:"SvgImageElementEx",interfaces:[hs]},ws.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var xs,ks,Es,Cs,Ss,Ts,Os,Ns,Ps,As,js=null;function Ls(){return null===js&&new ws,js}function Rs(){}function Is(){S.call(this),this.myContainer_rnn3uj$_0=null,this.myChildren_jvkzg9$_0=null,this.isPrebuiltSubtree=!1}function zs(t,e){this.$outer=t,C.call(this,e)}function Ds(t){this.mySvgRoot_0=new Fs(this,t),this.myListeners_0=new $,this.myPeer_0=null,this.mySvgRoot_0.get().attach_1gwaml$(this)}function Ms(t,e){this.closure$element=t,this.closure$event=e}function Bs(t){this.closure$node=t}function Us(t){this.closure$node=t}function Fs(t,e){this.this$SvgNodeContainer=t,O.call(this,e)}function qs(t){pl(),this.myPathData_0=t}function Gs(t,e,n){u.call(this),this.myChar_90i289$_0=n,this.name$=t,this.ordinal$=e}function Hs(){Hs=function(){},xs=new Gs("MOVE_TO",0,109),ks=new Gs("LINE_TO",1,108),Es=new Gs("HORIZONTAL_LINE_TO",2,104),Cs=new Gs("VERTICAL_LINE_TO",3,118),Ss=new Gs("CURVE_TO",4,99),Ts=new Gs("SMOOTH_CURVE_TO",5,115),Os=new Gs("QUADRATIC_BEZIER_CURVE_TO",6,113),Ns=new Gs("SMOOTH_QUADRATIC_BEZIER_CURVE_TO",7,116),Ps=new Gs("ELLIPTICAL_ARC",8,97),As=new Gs("CLOSE_PATH",9,122),rl()}function Ys(){return Hs(),xs}function Vs(){return Hs(),ks}function Ks(){return Hs(),Es}function Ws(){return Hs(),Cs}function Xs(){return Hs(),Ss}function Zs(){return Hs(),Ts}function Js(){return Hs(),Os}function Qs(){return Hs(),Ns}function tl(){return Hs(),Ps}function el(){return Hs(),As}function nl(){var t,e;for(il=this,this.MAP_0=h(),t=ol(),e=0;e!==t.length;++e){var n=t[e],i=this.MAP_0,r=n.absoluteCmd();i.put_xwzc9p$(r,n);var o=this.MAP_0,a=n.relativeCmd();o.put_xwzc9p$(a,n)}}Object.defineProperty(bs.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_7igd9t$_0}}),Object.defineProperty(bs.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),bs.prototype.x1=function(){return this.getAttribute_mumjwj$(Ls().X1)},bs.prototype.y1=function(){return this.getAttribute_mumjwj$(Ls().Y1)},bs.prototype.x2=function(){return this.getAttribute_mumjwj$(Ls().X2)},bs.prototype.y2=function(){return this.getAttribute_mumjwj$(Ls().Y2)},bs.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},bs.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},bs.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},bs.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},bs.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},bs.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},bs.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},bs.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},bs.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},bs.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},bs.$metadata$={kind:s,simpleName:"SvgLineElement",interfaces:[Tl,_u,Oa]},Rs.$metadata$={kind:p,simpleName:"SvgLocatable",interfaces:[]},Is.prototype.isAttached=function(){return null!=this.myContainer_rnn3uj$_0},Is.prototype.container=function(){return l(this.myContainer_rnn3uj$_0)},Is.prototype.children=function(){var t;return null==this.myChildren_jvkzg9$_0&&(this.myChildren_jvkzg9$_0=new zs(this,this)),e.isType(t=this.myChildren_jvkzg9$_0,E)?t:o()},Is.prototype.attach_1gwaml$=function(t){var e;if(this.isAttached())throw k("Svg element is already attached");for(e=this.children().iterator();e.hasNext();)e.next().attach_1gwaml$(t);this.myContainer_rnn3uj$_0=t,l(this.myContainer_rnn3uj$_0).svgNodeAttached_vvfmut$(this)},Is.prototype.detach_8be2vx$=function(){var t;if(!this.isAttached())throw k("Svg element is not attached");for(t=this.children().iterator();t.hasNext();)t.next().detach_8be2vx$();l(this.myContainer_rnn3uj$_0).svgNodeDetached_vvfmut$(this),this.myContainer_rnn3uj$_0=null},zs.prototype.beforeItemAdded_wxm5ur$=function(t,e){this.$outer.isAttached()&&e.attach_1gwaml$(this.$outer.container()),C.prototype.beforeItemAdded_wxm5ur$.call(this,t,e)},zs.prototype.beforeItemSet_hu11d4$=function(t,e,n){this.$outer.isAttached()&&(e.detach_8be2vx$(),n.attach_1gwaml$(this.$outer.container())),C.prototype.beforeItemSet_hu11d4$.call(this,t,e,n)},zs.prototype.beforeItemRemoved_wxm5ur$=function(t,e){this.$outer.isAttached()&&e.detach_8be2vx$(),C.prototype.beforeItemRemoved_wxm5ur$.call(this,t,e)},zs.$metadata$={kind:s,simpleName:"SvgChildList",interfaces:[C]},Is.$metadata$={kind:s,simpleName:"SvgNode",interfaces:[S]},Ds.prototype.setPeer_kqs5uc$=function(t){this.myPeer_0=t},Ds.prototype.getPeer=function(){return this.myPeer_0},Ds.prototype.root=function(){return this.mySvgRoot_0},Ds.prototype.addListener_6zkzfn$=function(t){return this.myListeners_0.add_11rb$(t)},Ms.prototype.call_11rb$=function(t){t.onAttributeSet_os9wmi$(this.closure$element,this.closure$event)},Ms.$metadata$={kind:s,interfaces:[y]},Ds.prototype.attributeChanged_1u4bot$=function(t,e){this.myListeners_0.fire_kucmxw$(new Ms(t,e))},Bs.prototype.call_11rb$=function(t){t.onNodeAttached_26jijc$(this.closure$node)},Bs.$metadata$={kind:s,interfaces:[y]},Ds.prototype.svgNodeAttached_vvfmut$=function(t){this.myListeners_0.fire_kucmxw$(new Bs(t))},Us.prototype.call_11rb$=function(t){t.onNodeDetached_26jijc$(this.closure$node)},Us.$metadata$={kind:s,interfaces:[y]},Ds.prototype.svgNodeDetached_vvfmut$=function(t){this.myListeners_0.fire_kucmxw$(new Us(t))},Fs.prototype.set_11rb$=function(t){this.get().detach_8be2vx$(),O.prototype.set_11rb$.call(this,t),t.attach_1gwaml$(this.this$SvgNodeContainer)},Fs.$metadata$={kind:s,interfaces:[O]},Ds.$metadata$={kind:s,simpleName:"SvgNodeContainer",interfaces:[]},Gs.prototype.relativeCmd=function(){return N(this.myChar_90i289$_0)},Gs.prototype.absoluteCmd=function(){return N(P(this.myChar_90i289$_0))},nl.prototype.get_s8itvh$=function(t){if(this.MAP_0.containsKey_11rb$(N(t)))return l(this.MAP_0.get_11rb$(N(t)));throw L("No enum constant "+j(A(Gs))+"@myChar."+String.fromCharCode(N(t)))},nl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var il=null;function rl(){return Hs(),null===il&&new nl,il}function ol(){return[Ys(),Vs(),Ks(),Ws(),Xs(),Zs(),Js(),Qs(),tl(),el()]}function al(){cl=this,this.EMPTY=new qs("")}Gs.$metadata$={kind:s,simpleName:"Action",interfaces:[u]},Gs.values=ol,Gs.valueOf_61zpoe$=function(t){switch(t){case"MOVE_TO":return Ys();case"LINE_TO":return Vs();case"HORIZONTAL_LINE_TO":return Ks();case"VERTICAL_LINE_TO":return Ws();case"CURVE_TO":return Xs();case"SMOOTH_CURVE_TO":return Zs();case"QUADRATIC_BEZIER_CURVE_TO":return Js();case"SMOOTH_QUADRATIC_BEZIER_CURVE_TO":return Qs();case"ELLIPTICAL_ARC":return tl();case"CLOSE_PATH":return el();default:c("No enum constant jetbrains.datalore.vis.svg.SvgPathData.Action."+t)}},qs.prototype.toString=function(){return this.myPathData_0},al.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var sl,ll,ul,cl=null;function pl(){return null===cl&&new al,cl}function hl(t){void 0===t&&(t=!0),this.myDefaultAbsolute_0=t,this.myStringBuilder_0=null,this.myTension_0=.7,this.myStringBuilder_0=w()}function _l(t,e){u.call(this),this.name$=t,this.ordinal$=e}function fl(){fl=function(){},sl=new _l("LINEAR",0),ll=new _l("CARDINAL",1),ul=new _l("MONOTONE",2)}function dl(){return fl(),sl}function ml(){return fl(),ll}function yl(){return fl(),ul}function $l(){bl(),Oa.call(this),this.elementName_d87la8$_0="path"}function vl(){gl=this,this.D=tt().createSpec_ytbaoo$("d")}qs.$metadata$={kind:s,simpleName:"SvgPathData",interfaces:[]},_l.$metadata$={kind:s,simpleName:"Interpolation",interfaces:[u]},_l.values=function(){return[dl(),ml(),yl()]},_l.valueOf_61zpoe$=function(t){switch(t){case"LINEAR":return dl();case"CARDINAL":return ml();case"MONOTONE":return yl();default:c("No enum constant jetbrains.datalore.vis.svg.SvgPathDataBuilder.Interpolation."+t)}},hl.prototype.build=function(){return new qs(this.myStringBuilder_0.toString())},hl.prototype.addAction_0=function(t,e,n){var i;for(e?this.myStringBuilder_0.append_s8itvh$(R(t.absoluteCmd())):this.myStringBuilder_0.append_s8itvh$(R(t.relativeCmd())),i=0;i!==n.length;++i){var r=n[i];this.myStringBuilder_0.append_s8jyv4$(r).append_s8itvh$(32)}},hl.prototype.addActionWithStringTokens_0=function(t,e,n){var i;for(e?this.myStringBuilder_0.append_s8itvh$(R(t.absoluteCmd())):this.myStringBuilder_0.append_s8itvh$(R(t.relativeCmd())),i=0;i!==n.length;++i){var r=n[i];this.myStringBuilder_0.append_pdl1vj$(r).append_s8itvh$(32)}},hl.prototype.moveTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Ys(),n,new Float64Array([t,e])),this},hl.prototype.moveTo_k2qmv6$=function(t,e){return this.moveTo_przk3b$(t.x,t.y,e)},hl.prototype.moveTo_gpjtzr$=function(t){return this.moveTo_przk3b$(t.x,t.y)},hl.prototype.lineTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Vs(),n,new Float64Array([t,e])),this},hl.prototype.lineTo_k2qmv6$=function(t,e){return this.lineTo_przk3b$(t.x,t.y,e)},hl.prototype.lineTo_gpjtzr$=function(t){return this.lineTo_przk3b$(t.x,t.y)},hl.prototype.horizontalLineTo_8555vt$=function(t,e){return void 0===e&&(e=this.myDefaultAbsolute_0),this.addAction_0(Ks(),e,new Float64Array([t])),this},hl.prototype.verticalLineTo_8555vt$=function(t,e){return void 0===e&&(e=this.myDefaultAbsolute_0),this.addAction_0(Ws(),e,new Float64Array([t])),this},hl.prototype.curveTo_igz2nj$=function(t,e,n,i,r,o,a){return void 0===a&&(a=this.myDefaultAbsolute_0),this.addAction_0(Xs(),a,new Float64Array([t,e,n,i,r,o])),this},hl.prototype.curveTo_d4nu7w$=function(t,e,n,i){return this.curveTo_igz2nj$(t.x,t.y,e.x,e.y,n.x,n.y,i)},hl.prototype.curveTo_fkixjx$=function(t,e,n){return this.curveTo_igz2nj$(t.x,t.y,e.x,e.y,n.x,n.y)},hl.prototype.smoothCurveTo_84c9il$=function(t,e,n,i,r){return void 0===r&&(r=this.myDefaultAbsolute_0),this.addAction_0(Zs(),r,new Float64Array([t,e,n,i])),this},hl.prototype.smoothCurveTo_sosulb$=function(t,e,n){return this.smoothCurveTo_84c9il$(t.x,t.y,e.x,e.y,n)},hl.prototype.smoothCurveTo_qt8ska$=function(t,e){return this.smoothCurveTo_84c9il$(t.x,t.y,e.x,e.y)},hl.prototype.quadraticBezierCurveTo_84c9il$=function(t,e,n,i,r){return void 0===r&&(r=this.myDefaultAbsolute_0),this.addAction_0(Js(),r,new Float64Array([t,e,n,i])),this},hl.prototype.quadraticBezierCurveTo_sosulb$=function(t,e,n){return this.quadraticBezierCurveTo_84c9il$(t.x,t.y,e.x,e.y,n)},hl.prototype.quadraticBezierCurveTo_qt8ska$=function(t,e){return this.quadraticBezierCurveTo_84c9il$(t.x,t.y,e.x,e.y)},hl.prototype.smoothQuadraticBezierCurveTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Qs(),n,new Float64Array([t,e])),this},hl.prototype.smoothQuadraticBezierCurveTo_k2qmv6$=function(t,e){return this.smoothQuadraticBezierCurveTo_przk3b$(t.x,t.y,e)},hl.prototype.smoothQuadraticBezierCurveTo_gpjtzr$=function(t){return this.smoothQuadraticBezierCurveTo_przk3b$(t.x,t.y)},hl.prototype.ellipticalArc_d37okh$=function(t,e,n,i,r,o,a,s){return void 0===s&&(s=this.myDefaultAbsolute_0),this.addActionWithStringTokens_0(tl(),s,[t.toString(),e.toString(),n.toString(),i?"1":"0",r?"1":"0",o.toString(),a.toString()]),this},hl.prototype.ellipticalArc_dcaprc$=function(t,e,n,i,r,o,a){return this.ellipticalArc_d37okh$(t,e,n,i,r,o.x,o.y,a)},hl.prototype.ellipticalArc_gc0whr$=function(t,e,n,i,r,o){return this.ellipticalArc_d37okh$(t,e,n,i,r,o.x,o.y)},hl.prototype.closePath=function(){return this.addAction_0(el(),this.myDefaultAbsolute_0,new Float64Array([])),this},hl.prototype.setTension_14dthe$=function(t){if(0>t||t>1)throw L("Tension should be within [0, 1] interval");this.myTension_0=t},hl.prototype.lineSlope_0=function(t,e){return(e.y-t.y)/(e.x-t.x)},hl.prototype.finiteDifferences_0=function(t){var e,n=I(t.size),i=this.lineSlope_0(t.get_za3lpa$(0),t.get_za3lpa$(1));n.add_11rb$(i),e=t.size-1|0;for(var r=1;r1){a=e.get_za3lpa$(1),r=t.get_za3lpa$(s),s=s+1|0,this.curveTo_igz2nj$(i.x+o.x,i.y+o.y,r.x-a.x,r.y-a.y,r.x,r.y,!0);for(var l=2;l9){var l=s;s=3*r/B.sqrt(l),n.set_wxm5ur$(i,s*o),n.set_wxm5ur$(i+1|0,s*a)}}}for(var u=z(),c=0;c!==t.size;++c){var p=c+1|0,h=t.size-1|0,_=c-1|0,f=(t.get_za3lpa$(B.min(p,h)).x-t.get_za3lpa$(B.max(_,0)).x)/(6*(1+n.get_za3lpa$(c)*n.get_za3lpa$(c)));u.add_11rb$(new D(f,n.get_za3lpa$(c)*f))}return u},hl.prototype.interpolatePoints_3g1a62$=function(t,e,n){if(t.size!==e.size)throw L("Sizes of xs and ys must be equal");for(var i=I(t.size),r=M(t),o=M(e),a=0;a!==t.size;++a)i.add_11rb$(new D(r.get_za3lpa$(a),o.get_za3lpa$(a)));switch(n.name){case"LINEAR":this.doLinearInterpolation_0(i);break;case"CARDINAL":i.size<3?this.doLinearInterpolation_0(i):this.doCardinalInterpolation_0(i);break;case"MONOTONE":i.size<3?this.doLinearInterpolation_0(i):this.doHermiteInterpolation_0(i,this.monotoneTangents_0(i))}return this},hl.prototype.interpolatePoints_1ravjc$=function(t,e){var n,i=I(t.size),r=I(t.size);for(n=t.iterator();n.hasNext();){var o=n.next();i.add_11rb$(o.x),r.add_11rb$(o.y)}return this.interpolatePoints_3g1a62$(i,r,e)},hl.$metadata$={kind:s,simpleName:"SvgPathDataBuilder",interfaces:[]},vl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var gl=null;function bl(){return null===gl&&new vl,gl}function wl(){}function xl(){Cl(),Oa.call(this),this.elementName_sgtow1$_0="rect"}function kl(){El=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT)}Object.defineProperty($l.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_d87la8$_0}}),Object.defineProperty($l.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),$l.prototype.d=function(){return this.getAttribute_mumjwj$(bl().D)},$l.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},$l.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},$l.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},$l.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},$l.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},$l.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},$l.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},$l.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},$l.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},$l.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},$l.$metadata$={kind:s,simpleName:"SvgPathElement",interfaces:[Tl,_u,Oa]},wl.$metadata$={kind:p,simpleName:"SvgPlatformPeer",interfaces:[]},kl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var El=null;function Cl(){return null===El&&new kl,El}function Sl(t,e,n,i,r){return r=r||Object.create(xl.prototype),xl.call(r),r.setAttribute_qdh7ux$(Cl().X,t),r.setAttribute_qdh7ux$(Cl().Y,e),r.setAttribute_qdh7ux$(Cl().HEIGHT,i),r.setAttribute_qdh7ux$(Cl().WIDTH,n),r}function Tl(){Pl()}function Ol(){Nl=this,this.FILL=tt().createSpec_ytbaoo$("fill"),this.FILL_OPACITY=tt().createSpec_ytbaoo$("fill-opacity"),this.STROKE=tt().createSpec_ytbaoo$("stroke"),this.STROKE_OPACITY=tt().createSpec_ytbaoo$("stroke-opacity"),this.STROKE_WIDTH=tt().createSpec_ytbaoo$("stroke-width")}Object.defineProperty(xl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_sgtow1$_0}}),Object.defineProperty(xl.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),xl.prototype.x=function(){return this.getAttribute_mumjwj$(Cl().X)},xl.prototype.y=function(){return this.getAttribute_mumjwj$(Cl().Y)},xl.prototype.height=function(){return this.getAttribute_mumjwj$(Cl().HEIGHT)},xl.prototype.width=function(){return this.getAttribute_mumjwj$(Cl().WIDTH)},xl.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},xl.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},xl.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},xl.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},xl.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},xl.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},xl.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},xl.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},xl.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},xl.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},xl.$metadata$={kind:s,simpleName:"SvgRectElement",interfaces:[Tl,_u,Oa]},Ol.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Nl=null;function Pl(){return null===Nl&&new Ol,Nl}function Al(){Rl(),la.call(this)}function jl(){Ll=this,this.CLASS=tt().createSpec_ytbaoo$("class")}Tl.$metadata$={kind:p,simpleName:"SvgShape",interfaces:[]},jl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ll=null;function Rl(){return null===Ll&&new jl,Ll}function Il(t){la.call(this),this.resource=t,this.elementName_1a5z8g$_0="style",this.setContent_61zpoe$(this.resource.css())}function zl(){Bl(),Al.call(this),this.elementName_9c3al$_0="svg"}function Dl(){Ml=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT),this.VIEW_BOX=tt().createSpec_ytbaoo$("viewBox")}Al.prototype.classAttribute=function(){return this.getAttribute_mumjwj$(Rl().CLASS)},Al.prototype.addClass_61zpoe$=function(t){this.validateClassName_rb6n0l$_0(t);var e=this.classAttribute();return null==e.get()?(e.set_11rb$(t),!0):!U(l(e.get()),[" "]).contains_11rb$(t)&&(e.set_11rb$(e.get()+" "+t),!0)},Al.prototype.removeClass_61zpoe$=function(t){this.validateClassName_rb6n0l$_0(t);var e=this.classAttribute();if(null==e.get())return!1;var n=M(U(l(e.get()),[" "])),i=n.remove_11rb$(t);return i&&e.set_11rb$(this.buildClassString_fbk06u$_0(n)),i},Al.prototype.replaceClass_puj7f4$=function(t,e){this.validateClassName_rb6n0l$_0(t),this.validateClassName_rb6n0l$_0(e);var n=this.classAttribute();if(null==n.get())throw k("Trying to replace class when class is empty");var i=U(l(n.get()),[" "]);if(!i.contains_11rb$(t))throw k("Class attribute does not contain specified oldClass");for(var r=i.size,o=I(r),a=0;a0&&n.append_s8itvh$(32),n.append_pdl1vj$(i)}return n.toString()},Al.prototype.validateClassName_rb6n0l$_0=function(t){if(F(t," "))throw L("Class name cannot contain spaces")},Al.$metadata$={kind:s,simpleName:"SvgStylableElement",interfaces:[la]},Object.defineProperty(Il.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_1a5z8g$_0}}),Il.prototype.setContent_61zpoe$=function(t){for(var e=this.children();!e.isEmpty();)e.removeAt_za3lpa$(0);var n=new iu(t);e.add_11rb$(n),this.setAttribute_jyasbz$("type","text/css")},Il.$metadata$={kind:s,simpleName:"SvgStyleElement",interfaces:[la]},Dl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ml=null;function Bl(){return null===Ml&&new Dl,Ml}function Ul(t){this.this$SvgSvgElement=t}function Fl(){this.myX_0=0,this.myY_0=0,this.myWidth_0=0,this.myHeight_0=0}function ql(t,e){return e=e||Object.create(Fl.prototype),Fl.call(e),e.myX_0=t.origin.x,e.myY_0=t.origin.y,e.myWidth_0=t.dimension.x,e.myHeight_0=t.dimension.y,e}function Gl(){Vl(),la.call(this),this.elementName_7co8y5$_0="tspan"}function Hl(){Yl=this,this.X_0=tt().createSpec_ytbaoo$("x"),this.Y_0=tt().createSpec_ytbaoo$("y")}Object.defineProperty(zl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_9c3al$_0}}),Object.defineProperty(zl.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),zl.prototype.setStyle_i8z0m3$=function(t){this.children().add_11rb$(new Il(t))},zl.prototype.x=function(){return this.getAttribute_mumjwj$(Bl().X)},zl.prototype.y=function(){return this.getAttribute_mumjwj$(Bl().Y)},zl.prototype.width=function(){return this.getAttribute_mumjwj$(Bl().WIDTH)},zl.prototype.height=function(){return this.getAttribute_mumjwj$(Bl().HEIGHT)},zl.prototype.viewBox=function(){return this.getAttribute_mumjwj$(Bl().VIEW_BOX)},Ul.prototype.set_11rb$=function(t){this.this$SvgSvgElement.viewBox().set_11rb$(ql(t))},Ul.$metadata$={kind:s,interfaces:[q]},zl.prototype.viewBoxRect=function(){return new Ul(this)},zl.prototype.opacity=function(){return this.getAttribute_mumjwj$(oa().OPACITY)},zl.prototype.clipPath=function(){return this.getAttribute_mumjwj$(oa().CLIP_PATH)},zl.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},zl.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Fl.prototype.toString=function(){return this.myX_0.toString()+" "+this.myY_0+" "+this.myWidth_0+" "+this.myHeight_0},Fl.$metadata$={kind:s,simpleName:"ViewBoxRectangle",interfaces:[]},zl.$metadata$={kind:s,simpleName:"SvgSvgElement",interfaces:[Rs,na,Al]},Hl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Yl=null;function Vl(){return null===Yl&&new Hl,Yl}function Kl(t,e){return e=e||Object.create(Gl.prototype),Gl.call(e),e.setText_61zpoe$(t),e}function Wl(){Jl()}function Xl(){Zl=this,this.FILL=tt().createSpec_ytbaoo$("fill"),this.FILL_OPACITY=tt().createSpec_ytbaoo$("fill-opacity"),this.STROKE=tt().createSpec_ytbaoo$("stroke"),this.STROKE_OPACITY=tt().createSpec_ytbaoo$("stroke-opacity"),this.STROKE_WIDTH=tt().createSpec_ytbaoo$("stroke-width"),this.TEXT_ANCHOR=tt().createSpec_ytbaoo$(ea().SVG_TEXT_ANCHOR_ATTRIBUTE),this.TEXT_DY=tt().createSpec_ytbaoo$(ea().SVG_TEXT_DY_ATTRIBUTE)}Object.defineProperty(Gl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_7co8y5$_0}}),Object.defineProperty(Gl.prototype,"computedTextLength",{configurable:!0,get:function(){return l(this.container().getPeer()).getComputedTextLength_u60gfq$(this)}}),Gl.prototype.x=function(){return this.getAttribute_mumjwj$(Vl().X_0)},Gl.prototype.y=function(){return this.getAttribute_mumjwj$(Vl().Y_0)},Gl.prototype.setText_61zpoe$=function(t){this.children().clear(),this.addText_61zpoe$(t)},Gl.prototype.addText_61zpoe$=function(t){var e=new iu(t);this.children().add_11rb$(e)},Gl.prototype.fill=function(){return this.getAttribute_mumjwj$(Jl().FILL)},Gl.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},Gl.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Jl().FILL_OPACITY)},Gl.prototype.stroke=function(){return this.getAttribute_mumjwj$(Jl().STROKE)},Gl.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},Gl.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Jl().STROKE_OPACITY)},Gl.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Jl().STROKE_WIDTH)},Gl.prototype.textAnchor=function(){return this.getAttribute_mumjwj$(Jl().TEXT_ANCHOR)},Gl.prototype.textDy=function(){return this.getAttribute_mumjwj$(Jl().TEXT_DY)},Gl.$metadata$={kind:s,simpleName:"SvgTSpanElement",interfaces:[Wl,la]},Xl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Zl=null;function Jl(){return null===Zl&&new Xl,Zl}function Ql(){nu(),Oa.call(this),this.elementName_s70iuw$_0="text"}function tu(){eu=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y")}Wl.$metadata$={kind:p,simpleName:"SvgTextContent",interfaces:[]},tu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var eu=null;function nu(){return null===eu&&new tu,eu}function iu(t){su(),Is.call(this),this.myContent_0=null,this.myContent_0=new O(t)}function ru(){au=this,this.NO_CHILDREN_LIST_0=new ou}function ou(){H.call(this)}Object.defineProperty(Ql.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_s70iuw$_0}}),Object.defineProperty(Ql.prototype,"computedTextLength",{configurable:!0,get:function(){return l(this.container().getPeer()).getComputedTextLength_u60gfq$(this)}}),Object.defineProperty(Ql.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),Ql.prototype.x=function(){return this.getAttribute_mumjwj$(nu().X)},Ql.prototype.y=function(){return this.getAttribute_mumjwj$(nu().Y)},Ql.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},Ql.prototype.setTextNode_61zpoe$=function(t){this.children().clear(),this.addTextNode_61zpoe$(t)},Ql.prototype.addTextNode_61zpoe$=function(t){var e=new iu(t);this.children().add_11rb$(e)},Ql.prototype.setTSpan_ddcap8$=function(t){this.children().clear(),this.addTSpan_ddcap8$(t)},Ql.prototype.setTSpan_61zpoe$=function(t){this.children().clear(),this.addTSpan_61zpoe$(t)},Ql.prototype.addTSpan_ddcap8$=function(t){this.children().add_11rb$(t)},Ql.prototype.addTSpan_61zpoe$=function(t){this.children().add_11rb$(Kl(t))},Ql.prototype.fill=function(){return this.getAttribute_mumjwj$(Jl().FILL)},Ql.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},Ql.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Jl().FILL_OPACITY)},Ql.prototype.stroke=function(){return this.getAttribute_mumjwj$(Jl().STROKE)},Ql.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},Ql.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Jl().STROKE_OPACITY)},Ql.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Jl().STROKE_WIDTH)},Ql.prototype.textAnchor=function(){return this.getAttribute_mumjwj$(Jl().TEXT_ANCHOR)},Ql.prototype.textDy=function(){return this.getAttribute_mumjwj$(Jl().TEXT_DY)},Ql.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},Ql.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Ql.$metadata$={kind:s,simpleName:"SvgTextElement",interfaces:[Wl,_u,Oa]},iu.prototype.textContent=function(){return this.myContent_0},iu.prototype.children=function(){return su().NO_CHILDREN_LIST_0},iu.prototype.toString=function(){return this.textContent().get()},ou.prototype.checkAdd_wxm5ur$=function(t,e){throw G("Cannot add children to SvgTextNode")},ou.prototype.checkRemove_wxm5ur$=function(t,e){throw G("Cannot remove children from SvgTextNode")},ou.$metadata$={kind:s,interfaces:[H]},ru.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var au=null;function su(){return null===au&&new ru,au}function lu(t){pu(),this.myTransform_0=t}function uu(){cu=this,this.EMPTY=new lu(""),this.MATRIX="matrix",this.ROTATE="rotate",this.SCALE="scale",this.SKEW_X="skewX",this.SKEW_Y="skewY",this.TRANSLATE="translate"}iu.$metadata$={kind:s,simpleName:"SvgTextNode",interfaces:[Is]},lu.prototype.toString=function(){return this.myTransform_0},uu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var cu=null;function pu(){return null===cu&&new uu,cu}function hu(){this.myStringBuilder_0=w()}function _u(){mu()}function fu(){du=this,this.TRANSFORM=tt().createSpec_ytbaoo$("transform")}lu.$metadata$={kind:s,simpleName:"SvgTransform",interfaces:[]},hu.prototype.build=function(){return new lu(this.myStringBuilder_0.toString())},hu.prototype.addTransformation_0=function(t,e){var n;for(this.myStringBuilder_0.append_pdl1vj$(t).append_s8itvh$(40),n=0;n!==e.length;++n){var i=e[n];this.myStringBuilder_0.append_s8jyv4$(i).append_s8itvh$(32)}return this.myStringBuilder_0.append_pdl1vj$(") "),this},hu.prototype.matrix_15yvbs$=function(t,e,n,i,r,o){return this.addTransformation_0(pu().MATRIX,new Float64Array([t,e,n,i,r,o]))},hu.prototype.translate_lu1900$=function(t,e){return this.addTransformation_0(pu().TRANSLATE,new Float64Array([t,e]))},hu.prototype.translate_gpjtzr$=function(t){return this.translate_lu1900$(t.x,t.y)},hu.prototype.translate_14dthe$=function(t){return this.addTransformation_0(pu().TRANSLATE,new Float64Array([t]))},hu.prototype.scale_lu1900$=function(t,e){return this.addTransformation_0(pu().SCALE,new Float64Array([t,e]))},hu.prototype.scale_14dthe$=function(t){return this.addTransformation_0(pu().SCALE,new Float64Array([t]))},hu.prototype.rotate_yvo9jy$=function(t,e,n){return this.addTransformation_0(pu().ROTATE,new Float64Array([t,e,n]))},hu.prototype.rotate_jx7lbv$=function(t,e){return this.rotate_yvo9jy$(t,e.x,e.y)},hu.prototype.rotate_14dthe$=function(t){return this.addTransformation_0(pu().ROTATE,new Float64Array([t]))},hu.prototype.skewX_14dthe$=function(t){return this.addTransformation_0(pu().SKEW_X,new Float64Array([t]))},hu.prototype.skewY_14dthe$=function(t){return this.addTransformation_0(pu().SKEW_Y,new Float64Array([t]))},hu.$metadata$={kind:s,simpleName:"SvgTransformBuilder",interfaces:[]},fu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var du=null;function mu(){return null===du&&new fu,du}function yu(){vu=this,this.OPACITY_TABLE_0=new Float64Array(256);for(var t=0;t<=255;t++)this.OPACITY_TABLE_0[t]=t/255}function $u(t,e){this.closure$color=t,this.closure$opacity=e}_u.$metadata$={kind:p,simpleName:"SvgTransformable",interfaces:[Rs]},yu.prototype.opacity_98b62m$=function(t){return this.OPACITY_TABLE_0[t.alpha]},yu.prototype.alpha2opacity_za3lpa$=function(t){return this.OPACITY_TABLE_0[t]},yu.prototype.toARGB_98b62m$=function(t){return this.toARGB_tjonv8$(t.red,t.green,t.blue,t.alpha)},yu.prototype.toARGB_o14uds$=function(t,e){var n=t.red,i=t.green,r=t.blue,o=255*e,a=B.min(255,o);return this.toARGB_tjonv8$(n,i,r,Y(B.max(0,a)))},yu.prototype.toARGB_tjonv8$=function(t,e,n,i){return(i<<24)+((t<<16)+(e<<8)+n|0)|0},$u.prototype.set_11rb$=function(t){this.closure$color.set_11rb$(Zo().create_2160e9$(t)),null!=t?this.closure$opacity.set_11rb$(gu().opacity_98b62m$(t)):this.closure$opacity.set_11rb$(1)},$u.$metadata$={kind:s,interfaces:[q]},yu.prototype.colorAttributeTransform_dc5zq8$=function(t,e){return new $u(t,e)},yu.prototype.transformMatrix_98ex5o$=function(t,e,n,i,r,o,a){t.transform().set_11rb$((new hu).matrix_15yvbs$(e,n,i,r,o,a).build())},yu.prototype.transformTranslate_pw34rw$=function(t,e,n){t.transform().set_11rb$((new hu).translate_lu1900$(e,n).build())},yu.prototype.transformTranslate_cbcjvx$=function(t,e){this.transformTranslate_pw34rw$(t,e.x,e.y)},yu.prototype.transformTranslate_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).translate_14dthe$(e).build())},yu.prototype.transformScale_pw34rw$=function(t,e,n){t.transform().set_11rb$((new hu).scale_lu1900$(e,n).build())},yu.prototype.transformScale_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).scale_14dthe$(e).build())},yu.prototype.transformRotate_tk1esa$=function(t,e,n,i){t.transform().set_11rb$((new hu).rotate_yvo9jy$(e,n,i).build())},yu.prototype.transformRotate_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).rotate_14dthe$(e).build())},yu.prototype.transformSkewX_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).skewX_14dthe$(e).build())},yu.prototype.transformSkewY_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).skewY_14dthe$(e).build())},yu.prototype.copyAttributes_azdp7k$=function(t,n){var i,r;for(i=t.attributeKeys.iterator();i.hasNext();){var a=i.next(),s=e.isType(r=a,Z)?r:o();n.setAttribute_qdh7ux$(s,t.getAttribute_mumjwj$(a).get())}},yu.prototype.pngDataURI_61zpoe$=function(t){return new T("data:image/png;base64,").append_pdl1vj$(t).toString()},yu.$metadata$={kind:i,simpleName:"SvgUtils",interfaces:[]};var vu=null;function gu(){return null===vu&&new yu,vu}function bu(){Tu=this,this.SVG_NAMESPACE_URI="http://www.w3.org/2000/svg",this.XLINK_NAMESPACE_URI="http://www.w3.org/1999/xlink",this.XLINK_PREFIX="xlink"}bu.$metadata$={kind:i,simpleName:"XmlNamespace",interfaces:[]};var wu,xu,ku,Eu,Cu,Su,Tu=null;function Ou(){return null===Tu&&new bu,Tu}function Nu(t,e,n){V.call(this),this.attrSpec=t,this.oldValue=e,this.newValue=n}function Pu(){}function Au(t,e){u.call(this),this.name$=t,this.ordinal$=e}function ju(){ju=function(){},wu=new Au("MOUSE_CLICKED",0),xu=new Au("MOUSE_PRESSED",1),ku=new Au("MOUSE_RELEASED",2),Eu=new Au("MOUSE_OVER",3),Cu=new Au("MOUSE_MOVE",4),Su=new Au("MOUSE_OUT",5)}function Lu(){return ju(),wu}function Ru(){return ju(),xu}function Iu(){return ju(),ku}function zu(){return ju(),Eu}function Du(){return ju(),Cu}function Mu(){return ju(),Su}function Bu(){Is.call(this),this.isPrebuiltSubtree=!0}function Uu(t){Yu.call(this,t),this.myAttributes_0=e.newArray(Wu().ATTR_COUNT_8be2vx$,null)}function Fu(t,e){this.closure$key=t,this.closure$value=e}function qu(t){Uu.call(this,Ju().GROUP),this.myChildren_0=I(t)}function Gu(t){Bu.call(this),this.myGroup_0=t}function Hu(t,e,n){return n=n||Object.create(qu.prototype),qu.call(n,t),n.setAttribute_vux3hl$(19,e),n}function Yu(t){Wu(),this.elementName=t}function Vu(){Ku=this,this.fill_8be2vx$=0,this.fillOpacity_8be2vx$=1,this.stroke_8be2vx$=2,this.strokeOpacity_8be2vx$=3,this.strokeWidth_8be2vx$=4,this.strokeTransform_8be2vx$=5,this.classes_8be2vx$=6,this.x1_8be2vx$=7,this.y1_8be2vx$=8,this.x2_8be2vx$=9,this.y2_8be2vx$=10,this.cx_8be2vx$=11,this.cy_8be2vx$=12,this.r_8be2vx$=13,this.x_8be2vx$=14,this.y_8be2vx$=15,this.height_8be2vx$=16,this.width_8be2vx$=17,this.pathData_8be2vx$=18,this.transform_8be2vx$=19,this.ATTR_KEYS_8be2vx$=["fill","fill-opacity","stroke","stroke-opacity","stroke-width","transform","classes","x1","y1","x2","y2","cx","cy","r","x","y","height","width","d","transform"],this.ATTR_COUNT_8be2vx$=this.ATTR_KEYS_8be2vx$.length}Nu.$metadata$={kind:s,simpleName:"SvgAttributeEvent",interfaces:[V]},Pu.$metadata$={kind:p,simpleName:"SvgEventHandler",interfaces:[]},Au.$metadata$={kind:s,simpleName:"SvgEventSpec",interfaces:[u]},Au.values=function(){return[Lu(),Ru(),Iu(),zu(),Du(),Mu()]},Au.valueOf_61zpoe$=function(t){switch(t){case"MOUSE_CLICKED":return Lu();case"MOUSE_PRESSED":return Ru();case"MOUSE_RELEASED":return Iu();case"MOUSE_OVER":return zu();case"MOUSE_MOVE":return Du();case"MOUSE_OUT":return Mu();default:c("No enum constant jetbrains.datalore.vis.svg.event.SvgEventSpec."+t)}},Bu.prototype.children=function(){var t=Is.prototype.children.call(this);if(!t.isEmpty())throw k("Can't have children");return t},Bu.$metadata$={kind:s,simpleName:"DummySvgNode",interfaces:[Is]},Object.defineProperty(Fu.prototype,"key",{configurable:!0,get:function(){return this.closure$key}}),Object.defineProperty(Fu.prototype,"value",{configurable:!0,get:function(){return this.closure$value.toString()}}),Fu.$metadata$={kind:s,interfaces:[ec]},Object.defineProperty(Uu.prototype,"attributes",{configurable:!0,get:function(){var t,e,n=this.myAttributes_0,i=I(n.length),r=0;for(t=0;t!==n.length;++t){var o,a=n[t],s=i.add_11rb$,l=(r=(e=r)+1|0,e),u=Wu().ATTR_KEYS_8be2vx$[l];o=null==a?null:new Fu(u,a),s.call(i,o)}return K(i)}}),Object.defineProperty(Uu.prototype,"slimChildren",{configurable:!0,get:function(){return W()}}),Uu.prototype.setAttribute_vux3hl$=function(t,e){this.myAttributes_0[t]=e},Uu.prototype.hasAttribute_za3lpa$=function(t){return null!=this.myAttributes_0[t]},Uu.prototype.getAttribute_za3lpa$=function(t){return this.myAttributes_0[t]},Uu.prototype.appendTo_i2myw1$=function(t){var n;(e.isType(n=t,qu)?n:o()).addChild_3o5936$(this)},Uu.$metadata$={kind:s,simpleName:"ElementJava",interfaces:[tc,Yu]},Object.defineProperty(qu.prototype,"slimChildren",{configurable:!0,get:function(){var t,e=this.myChildren_0,n=I(X(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(i)}return n}}),qu.prototype.addChild_3o5936$=function(t){this.myChildren_0.add_11rb$(t)},qu.prototype.asDummySvgNode=function(){return new Gu(this)},Object.defineProperty(Gu.prototype,"elementName",{configurable:!0,get:function(){return this.myGroup_0.elementName}}),Object.defineProperty(Gu.prototype,"attributes",{configurable:!0,get:function(){return this.myGroup_0.attributes}}),Object.defineProperty(Gu.prototype,"slimChildren",{configurable:!0,get:function(){return this.myGroup_0.slimChildren}}),Gu.$metadata$={kind:s,simpleName:"MyDummySvgNode",interfaces:[tc,Bu]},qu.$metadata$={kind:s,simpleName:"GroupJava",interfaces:[Qu,Uu]},Vu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ku=null;function Wu(){return null===Ku&&new Vu,Ku}function Xu(){Zu=this,this.GROUP="g",this.LINE="line",this.CIRCLE="circle",this.RECT="rect",this.PATH="path"}Yu.prototype.setFill_o14uds$=function(t,e){this.setAttribute_vux3hl$(0,t.toHexColor()),e<1&&this.setAttribute_vux3hl$(1,e.toString())},Yu.prototype.setStroke_o14uds$=function(t,e){this.setAttribute_vux3hl$(2,t.toHexColor()),e<1&&this.setAttribute_vux3hl$(3,e.toString())},Yu.prototype.setStrokeWidth_14dthe$=function(t){this.setAttribute_vux3hl$(4,t.toString())},Yu.prototype.setAttribute_7u9h3l$=function(t,e){this.setAttribute_vux3hl$(t,e.toString())},Yu.$metadata$={kind:s,simpleName:"SlimBase",interfaces:[ic]},Xu.prototype.createElement_0=function(t){return new Uu(t)},Xu.prototype.g_za3lpa$=function(t){return new qu(t)},Xu.prototype.g_vux3hl$=function(t,e){return Hu(t,e)},Xu.prototype.line_6y0v78$=function(t,e,n,i){var r=this.createElement_0(this.LINE);return r.setAttribute_7u9h3l$(7,t),r.setAttribute_7u9h3l$(8,e),r.setAttribute_7u9h3l$(9,n),r.setAttribute_7u9h3l$(10,i),r},Xu.prototype.circle_yvo9jy$=function(t,e,n){var i=this.createElement_0(this.CIRCLE);return i.setAttribute_7u9h3l$(11,t),i.setAttribute_7u9h3l$(12,e),i.setAttribute_7u9h3l$(13,n),i},Xu.prototype.rect_6y0v78$=function(t,e,n,i){var r=this.createElement_0(this.RECT);return r.setAttribute_7u9h3l$(14,t),r.setAttribute_7u9h3l$(15,e),r.setAttribute_7u9h3l$(17,n),r.setAttribute_7u9h3l$(16,i),r},Xu.prototype.path_za3rmp$=function(t){var e=this.createElement_0(this.PATH);return e.setAttribute_vux3hl$(18,t.toString()),e},Xu.$metadata$={kind:i,simpleName:"SvgSlimElements",interfaces:[]};var Zu=null;function Ju(){return null===Zu&&new Xu,Zu}function Qu(){}function tc(){}function ec(){}function nc(){}function ic(){}Qu.$metadata$={kind:p,simpleName:"SvgSlimGroup",interfaces:[nc]},ec.$metadata$={kind:p,simpleName:"Attr",interfaces:[]},tc.$metadata$={kind:p,simpleName:"SvgSlimNode",interfaces:[]},nc.$metadata$={kind:p,simpleName:"SvgSlimObject",interfaces:[]},ic.$metadata$={kind:p,simpleName:"SvgSlimShape",interfaces:[nc]},Object.defineProperty(Z,"Companion",{get:tt});var rc=t.jetbrains||(t.jetbrains={}),oc=rc.datalore||(rc.datalore={}),ac=oc.vis||(oc.vis={}),sc=ac.svg||(ac.svg={});sc.SvgAttributeSpec=Z,Object.defineProperty(et,"Companion",{get:rt}),sc.SvgCircleElement=et,Object.defineProperty(ot,"Companion",{get:Jn}),Object.defineProperty(Qn,"USER_SPACE_ON_USE",{get:ei}),Object.defineProperty(Qn,"OBJECT_BOUNDING_BOX",{get:ni}),ot.ClipPathUnits=Qn,sc.SvgClipPathElement=ot,sc.SvgColor=ii,Object.defineProperty(ri,"ALICE_BLUE",{get:ai}),Object.defineProperty(ri,"ANTIQUE_WHITE",{get:si}),Object.defineProperty(ri,"AQUA",{get:li}),Object.defineProperty(ri,"AQUAMARINE",{get:ui}),Object.defineProperty(ri,"AZURE",{get:ci}),Object.defineProperty(ri,"BEIGE",{get:pi}),Object.defineProperty(ri,"BISQUE",{get:hi}),Object.defineProperty(ri,"BLACK",{get:_i}),Object.defineProperty(ri,"BLANCHED_ALMOND",{get:fi}),Object.defineProperty(ri,"BLUE",{get:di}),Object.defineProperty(ri,"BLUE_VIOLET",{get:mi}),Object.defineProperty(ri,"BROWN",{get:yi}),Object.defineProperty(ri,"BURLY_WOOD",{get:$i}),Object.defineProperty(ri,"CADET_BLUE",{get:vi}),Object.defineProperty(ri,"CHARTREUSE",{get:gi}),Object.defineProperty(ri,"CHOCOLATE",{get:bi}),Object.defineProperty(ri,"CORAL",{get:wi}),Object.defineProperty(ri,"CORNFLOWER_BLUE",{get:xi}),Object.defineProperty(ri,"CORNSILK",{get:ki}),Object.defineProperty(ri,"CRIMSON",{get:Ei}),Object.defineProperty(ri,"CYAN",{get:Ci}),Object.defineProperty(ri,"DARK_BLUE",{get:Si}),Object.defineProperty(ri,"DARK_CYAN",{get:Ti}),Object.defineProperty(ri,"DARK_GOLDEN_ROD",{get:Oi}),Object.defineProperty(ri,"DARK_GRAY",{get:Ni}),Object.defineProperty(ri,"DARK_GREEN",{get:Pi}),Object.defineProperty(ri,"DARK_GREY",{get:Ai}),Object.defineProperty(ri,"DARK_KHAKI",{get:ji}),Object.defineProperty(ri,"DARK_MAGENTA",{get:Li}),Object.defineProperty(ri,"DARK_OLIVE_GREEN",{get:Ri}),Object.defineProperty(ri,"DARK_ORANGE",{get:Ii}),Object.defineProperty(ri,"DARK_ORCHID",{get:zi}),Object.defineProperty(ri,"DARK_RED",{get:Di}),Object.defineProperty(ri,"DARK_SALMON",{get:Mi}),Object.defineProperty(ri,"DARK_SEA_GREEN",{get:Bi}),Object.defineProperty(ri,"DARK_SLATE_BLUE",{get:Ui}),Object.defineProperty(ri,"DARK_SLATE_GRAY",{get:Fi}),Object.defineProperty(ri,"DARK_SLATE_GREY",{get:qi}),Object.defineProperty(ri,"DARK_TURQUOISE",{get:Gi}),Object.defineProperty(ri,"DARK_VIOLET",{get:Hi}),Object.defineProperty(ri,"DEEP_PINK",{get:Yi}),Object.defineProperty(ri,"DEEP_SKY_BLUE",{get:Vi}),Object.defineProperty(ri,"DIM_GRAY",{get:Ki}),Object.defineProperty(ri,"DIM_GREY",{get:Wi}),Object.defineProperty(ri,"DODGER_BLUE",{get:Xi}),Object.defineProperty(ri,"FIRE_BRICK",{get:Zi}),Object.defineProperty(ri,"FLORAL_WHITE",{get:Ji}),Object.defineProperty(ri,"FOREST_GREEN",{get:Qi}),Object.defineProperty(ri,"FUCHSIA",{get:tr}),Object.defineProperty(ri,"GAINSBORO",{get:er}),Object.defineProperty(ri,"GHOST_WHITE",{get:nr}),Object.defineProperty(ri,"GOLD",{get:ir}),Object.defineProperty(ri,"GOLDEN_ROD",{get:rr}),Object.defineProperty(ri,"GRAY",{get:or}),Object.defineProperty(ri,"GREY",{get:ar}),Object.defineProperty(ri,"GREEN",{get:sr}),Object.defineProperty(ri,"GREEN_YELLOW",{get:lr}),Object.defineProperty(ri,"HONEY_DEW",{get:ur}),Object.defineProperty(ri,"HOT_PINK",{get:cr}),Object.defineProperty(ri,"INDIAN_RED",{get:pr}),Object.defineProperty(ri,"INDIGO",{get:hr}),Object.defineProperty(ri,"IVORY",{get:_r}),Object.defineProperty(ri,"KHAKI",{get:fr}),Object.defineProperty(ri,"LAVENDER",{get:dr}),Object.defineProperty(ri,"LAVENDER_BLUSH",{get:mr}),Object.defineProperty(ri,"LAWN_GREEN",{get:yr}),Object.defineProperty(ri,"LEMON_CHIFFON",{get:$r}),Object.defineProperty(ri,"LIGHT_BLUE",{get:vr}),Object.defineProperty(ri,"LIGHT_CORAL",{get:gr}),Object.defineProperty(ri,"LIGHT_CYAN",{get:br}),Object.defineProperty(ri,"LIGHT_GOLDEN_ROD_YELLOW",{get:wr}),Object.defineProperty(ri,"LIGHT_GRAY",{get:xr}),Object.defineProperty(ri,"LIGHT_GREEN",{get:kr}),Object.defineProperty(ri,"LIGHT_GREY",{get:Er}),Object.defineProperty(ri,"LIGHT_PINK",{get:Cr}),Object.defineProperty(ri,"LIGHT_SALMON",{get:Sr}),Object.defineProperty(ri,"LIGHT_SEA_GREEN",{get:Tr}),Object.defineProperty(ri,"LIGHT_SKY_BLUE",{get:Or}),Object.defineProperty(ri,"LIGHT_SLATE_GRAY",{get:Nr}),Object.defineProperty(ri,"LIGHT_SLATE_GREY",{get:Pr}),Object.defineProperty(ri,"LIGHT_STEEL_BLUE",{get:Ar}),Object.defineProperty(ri,"LIGHT_YELLOW",{get:jr}),Object.defineProperty(ri,"LIME",{get:Lr}),Object.defineProperty(ri,"LIME_GREEN",{get:Rr}),Object.defineProperty(ri,"LINEN",{get:Ir}),Object.defineProperty(ri,"MAGENTA",{get:zr}),Object.defineProperty(ri,"MAROON",{get:Dr}),Object.defineProperty(ri,"MEDIUM_AQUA_MARINE",{get:Mr}),Object.defineProperty(ri,"MEDIUM_BLUE",{get:Br}),Object.defineProperty(ri,"MEDIUM_ORCHID",{get:Ur}),Object.defineProperty(ri,"MEDIUM_PURPLE",{get:Fr}),Object.defineProperty(ri,"MEDIUM_SEAGREEN",{get:qr}),Object.defineProperty(ri,"MEDIUM_SLATE_BLUE",{get:Gr}),Object.defineProperty(ri,"MEDIUM_SPRING_GREEN",{get:Hr}),Object.defineProperty(ri,"MEDIUM_TURQUOISE",{get:Yr}),Object.defineProperty(ri,"MEDIUM_VIOLET_RED",{get:Vr}),Object.defineProperty(ri,"MIDNIGHT_BLUE",{get:Kr}),Object.defineProperty(ri,"MINT_CREAM",{get:Wr}),Object.defineProperty(ri,"MISTY_ROSE",{get:Xr}),Object.defineProperty(ri,"MOCCASIN",{get:Zr}),Object.defineProperty(ri,"NAVAJO_WHITE",{get:Jr}),Object.defineProperty(ri,"NAVY",{get:Qr}),Object.defineProperty(ri,"OLD_LACE",{get:to}),Object.defineProperty(ri,"OLIVE",{get:eo}),Object.defineProperty(ri,"OLIVE_DRAB",{get:no}),Object.defineProperty(ri,"ORANGE",{get:io}),Object.defineProperty(ri,"ORANGE_RED",{get:ro}),Object.defineProperty(ri,"ORCHID",{get:oo}),Object.defineProperty(ri,"PALE_GOLDEN_ROD",{get:ao}),Object.defineProperty(ri,"PALE_GREEN",{get:so}),Object.defineProperty(ri,"PALE_TURQUOISE",{get:lo}),Object.defineProperty(ri,"PALE_VIOLET_RED",{get:uo}),Object.defineProperty(ri,"PAPAYA_WHIP",{get:co}),Object.defineProperty(ri,"PEACH_PUFF",{get:po}),Object.defineProperty(ri,"PERU",{get:ho}),Object.defineProperty(ri,"PINK",{get:_o}),Object.defineProperty(ri,"PLUM",{get:fo}),Object.defineProperty(ri,"POWDER_BLUE",{get:mo}),Object.defineProperty(ri,"PURPLE",{get:yo}),Object.defineProperty(ri,"RED",{get:$o}),Object.defineProperty(ri,"ROSY_BROWN",{get:vo}),Object.defineProperty(ri,"ROYAL_BLUE",{get:go}),Object.defineProperty(ri,"SADDLE_BROWN",{get:bo}),Object.defineProperty(ri,"SALMON",{get:wo}),Object.defineProperty(ri,"SANDY_BROWN",{get:xo}),Object.defineProperty(ri,"SEA_GREEN",{get:ko}),Object.defineProperty(ri,"SEASHELL",{get:Eo}),Object.defineProperty(ri,"SIENNA",{get:Co}),Object.defineProperty(ri,"SILVER",{get:So}),Object.defineProperty(ri,"SKY_BLUE",{get:To}),Object.defineProperty(ri,"SLATE_BLUE",{get:Oo}),Object.defineProperty(ri,"SLATE_GRAY",{get:No}),Object.defineProperty(ri,"SLATE_GREY",{get:Po}),Object.defineProperty(ri,"SNOW",{get:Ao}),Object.defineProperty(ri,"SPRING_GREEN",{get:jo}),Object.defineProperty(ri,"STEEL_BLUE",{get:Lo}),Object.defineProperty(ri,"TAN",{get:Ro}),Object.defineProperty(ri,"TEAL",{get:Io}),Object.defineProperty(ri,"THISTLE",{get:zo}),Object.defineProperty(ri,"TOMATO",{get:Do}),Object.defineProperty(ri,"TURQUOISE",{get:Mo}),Object.defineProperty(ri,"VIOLET",{get:Bo}),Object.defineProperty(ri,"WHEAT",{get:Uo}),Object.defineProperty(ri,"WHITE",{get:Fo}),Object.defineProperty(ri,"WHITE_SMOKE",{get:qo}),Object.defineProperty(ri,"YELLOW",{get:Go}),Object.defineProperty(ri,"YELLOW_GREEN",{get:Ho}),Object.defineProperty(ri,"NONE",{get:Yo}),Object.defineProperty(ri,"CURRENT_COLOR",{get:Vo}),Object.defineProperty(ri,"Companion",{get:Zo}),sc.SvgColors=ri,Object.defineProperty(sc,"SvgConstants",{get:ea}),Object.defineProperty(na,"Companion",{get:oa}),sc.SvgContainer=na,sc.SvgCssResource=aa,sc.SvgDefsElement=sa,Object.defineProperty(la,"Companion",{get:pa}),sc.SvgElement=la,sc.SvgElementListener=ya,Object.defineProperty($a,"Companion",{get:ba}),sc.SvgEllipseElement=$a,sc.SvgEventPeer=wa,sc.SvgGElement=Ta,Object.defineProperty(Oa,"Companion",{get:Ya}),Object.defineProperty(Va,"VISIBLE_PAINTED",{get:Wa}),Object.defineProperty(Va,"VISIBLE_FILL",{get:Xa}),Object.defineProperty(Va,"VISIBLE_STROKE",{get:Za}),Object.defineProperty(Va,"VISIBLE",{get:Ja}),Object.defineProperty(Va,"PAINTED",{get:Qa}),Object.defineProperty(Va,"FILL",{get:ts}),Object.defineProperty(Va,"STROKE",{get:es}),Object.defineProperty(Va,"ALL",{get:ns}),Object.defineProperty(Va,"NONE",{get:is}),Object.defineProperty(Va,"INHERIT",{get:rs}),Oa.PointerEvents=Va,Object.defineProperty(os,"VISIBLE",{get:ss}),Object.defineProperty(os,"HIDDEN",{get:ls}),Object.defineProperty(os,"COLLAPSE",{get:us}),Object.defineProperty(os,"INHERIT",{get:cs}),Oa.Visibility=os,sc.SvgGraphicsElement=Oa,sc.SvgIRI=ps,Object.defineProperty(hs,"Companion",{get:ds}),sc.SvgImageElement_init_6y0v78$=ms,sc.SvgImageElement=hs,ys.RGBEncoder=vs,ys.Bitmap=gs,sc.SvgImageElementEx=ys,Object.defineProperty(bs,"Companion",{get:Ls}),sc.SvgLineElement_init_6y0v78$=function(t,e,n,i,r){return r=r||Object.create(bs.prototype),bs.call(r),r.setAttribute_qdh7ux$(Ls().X1,t),r.setAttribute_qdh7ux$(Ls().Y1,e),r.setAttribute_qdh7ux$(Ls().X2,n),r.setAttribute_qdh7ux$(Ls().Y2,i),r},sc.SvgLineElement=bs,sc.SvgLocatable=Rs,sc.SvgNode=Is,sc.SvgNodeContainer=Ds,Object.defineProperty(Gs,"MOVE_TO",{get:Ys}),Object.defineProperty(Gs,"LINE_TO",{get:Vs}),Object.defineProperty(Gs,"HORIZONTAL_LINE_TO",{get:Ks}),Object.defineProperty(Gs,"VERTICAL_LINE_TO",{get:Ws}),Object.defineProperty(Gs,"CURVE_TO",{get:Xs}),Object.defineProperty(Gs,"SMOOTH_CURVE_TO",{get:Zs}),Object.defineProperty(Gs,"QUADRATIC_BEZIER_CURVE_TO",{get:Js}),Object.defineProperty(Gs,"SMOOTH_QUADRATIC_BEZIER_CURVE_TO",{get:Qs}),Object.defineProperty(Gs,"ELLIPTICAL_ARC",{get:tl}),Object.defineProperty(Gs,"CLOSE_PATH",{get:el}),Object.defineProperty(Gs,"Companion",{get:rl}),qs.Action=Gs,Object.defineProperty(qs,"Companion",{get:pl}),sc.SvgPathData=qs,Object.defineProperty(_l,"LINEAR",{get:dl}),Object.defineProperty(_l,"CARDINAL",{get:ml}),Object.defineProperty(_l,"MONOTONE",{get:yl}),hl.Interpolation=_l,sc.SvgPathDataBuilder=hl,Object.defineProperty($l,"Companion",{get:bl}),sc.SvgPathElement_init_7jrsat$=function(t,e){return e=e||Object.create($l.prototype),$l.call(e),e.setAttribute_qdh7ux$(bl().D,t),e},sc.SvgPathElement=$l,sc.SvgPlatformPeer=wl,Object.defineProperty(xl,"Companion",{get:Cl}),sc.SvgRectElement_init_6y0v78$=Sl,sc.SvgRectElement_init_wthzt5$=function(t,e){return e=e||Object.create(xl.prototype),Sl(t.origin.x,t.origin.y,t.dimension.x,t.dimension.y,e),e},sc.SvgRectElement=xl,Object.defineProperty(Tl,"Companion",{get:Pl}),sc.SvgShape=Tl,Object.defineProperty(Al,"Companion",{get:Rl}),sc.SvgStylableElement=Al,sc.SvgStyleElement=Il,Object.defineProperty(zl,"Companion",{get:Bl}),zl.ViewBoxRectangle_init_6y0v78$=function(t,e,n,i,r){return r=r||Object.create(Fl.prototype),Fl.call(r),r.myX_0=t,r.myY_0=e,r.myWidth_0=n,r.myHeight_0=i,r},zl.ViewBoxRectangle_init_wthzt5$=ql,zl.ViewBoxRectangle=Fl,sc.SvgSvgElement=zl,Object.defineProperty(Gl,"Companion",{get:Vl}),sc.SvgTSpanElement_init_61zpoe$=Kl,sc.SvgTSpanElement=Gl,Object.defineProperty(Wl,"Companion",{get:Jl}),sc.SvgTextContent=Wl,Object.defineProperty(Ql,"Companion",{get:nu}),sc.SvgTextElement_init_61zpoe$=function(t,e){return e=e||Object.create(Ql.prototype),Ql.call(e),e.setTextNode_61zpoe$(t),e},sc.SvgTextElement=Ql,Object.defineProperty(iu,"Companion",{get:su}),sc.SvgTextNode=iu,Object.defineProperty(lu,"Companion",{get:pu}),sc.SvgTransform=lu,sc.SvgTransformBuilder=hu,Object.defineProperty(_u,"Companion",{get:mu}),sc.SvgTransformable=_u,Object.defineProperty(sc,"SvgUtils",{get:gu}),Object.defineProperty(sc,"XmlNamespace",{get:Ou});var lc=sc.event||(sc.event={});lc.SvgAttributeEvent=Nu,lc.SvgEventHandler=Pu,Object.defineProperty(Au,"MOUSE_CLICKED",{get:Lu}),Object.defineProperty(Au,"MOUSE_PRESSED",{get:Ru}),Object.defineProperty(Au,"MOUSE_RELEASED",{get:Iu}),Object.defineProperty(Au,"MOUSE_OVER",{get:zu}),Object.defineProperty(Au,"MOUSE_MOVE",{get:Du}),Object.defineProperty(Au,"MOUSE_OUT",{get:Mu}),lc.SvgEventSpec=Au;var uc=sc.slim||(sc.slim={});return uc.DummySvgNode=Bu,uc.ElementJava=Uu,uc.GroupJava_init_vux3hl$=Hu,uc.GroupJava=qu,Object.defineProperty(Yu,"Companion",{get:Wu}),uc.SlimBase=Yu,Object.defineProperty(uc,"SvgSlimElements",{get:Ju}),uc.SvgSlimGroup=Qu,tc.Attr=ec,uc.SvgSlimNode=tc,uc.SvgSlimObject=nc,uc.SvgSlimShape=ic,t})?i.apply(e,r):i)||(t.exports=o)},975:t=>{function e(t){var e=new Error("Cannot find module '"+t+"'");throw e.code="MODULE_NOT_FOUND",e}e.keys=()=>[],e.resolve=e,e.id=975,t.exports=e}},e={};function n(i){var r=e[i];if(void 0!==r)return r.exports;var o=e[i]={exports:{}};return t[i].call(o.exports,o,o.exports,n),o.exports}n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var i=n(837);window.LetsPlot=i})(); +(()=>{var t={73:function(t,e,n){var i,r,o;r=[e,n(421)],void 0===(o="function"==typeof(i=function(t,e){"use strict";e.defineInlineFunction,e.wrapFunction;var n=e.Kind.INTERFACE,i=e.Kind.OBJECT,r=e.toString,o=e.equals,a=e.kotlin.Exception,s=e.kotlin.js.get_js_1yb8b7$,l=e.kotlin.Enum,u=e.Kind.CLASS,c=e.throwISE,p=e.kotlin.Unit,h=e.getCallableRef;function _(){}function f(){d=this}A.prototype=Object.create(l.prototype),A.prototype.constructor=A,_.$metadata$={kind:n,simpleName:"Appender",interfaces:[]},f.prototype.trace_s8jyv4$=function(t){console.log(t)},f.prototype.debug_s8jyv4$=function(t){console.log(t)},f.prototype.info_s8jyv4$=function(t){console.info(t)},f.prototype.warn_s8jyv4$=function(t){console.warn(t)},f.prototype.error_s8jyv4$=function(t){console.error(t)},f.$metadata$={kind:i,simpleName:"ConsoleOutputAppender",interfaces:[_]};var d=null;function m(){return null===d&&new f,d}function y(){$=this}y.prototype.formatMessage_pijeg6$=function(t,n,i){var o,s=t.name+": ["+n+"] ";try{o=r(i())}catch(t){if(!e.isType(t,a))throw t;o=H.ErrorMessageProducer.getErrorLog_3lhtaa$(t)}return s+o},y.prototype.formatMessage_hqgb2y$=function(t,n,i,o){var s,l=t.name+": ["+n+"] ";try{s=r(o())}catch(t){if(!e.isType(t,a))throw t;s=H.ErrorMessageProducer.getErrorLog_3lhtaa$(t)}return l+s+this.throwableToString_0(i)},y.prototype.formatMessage_i9qi47$=function(t,n,i,o){var s,l=t.name+": ["+n+"] "+r(null!=i?i.getName():null)+" ";try{s=r(o())}catch(t){if(!e.isType(t,a))throw t;s=H.ErrorMessageProducer.getErrorLog_3lhtaa$(t)}return l+s},y.prototype.formatMessage_fud0c7$=function(t,n,i,o,s){var l,u=t.name+": ["+n+"] "+r(null!=i?i.getName():null)+" ";try{l=r(s())}catch(t){if(!e.isType(t,a))throw t;l=H.ErrorMessageProducer.getErrorLog_3lhtaa$(t)}return u+l+this.throwableToString_0(o)},y.prototype.throwableToString_0=function(t){if(null==t)return"";for(var e="",n=t;null!=n&&!o(n.cause,n);)e+=", Caused by: '"+r(n.message)+"'",n=n.cause;return e},y.$metadata$={kind:i,simpleName:"DefaultMessageFormatter",interfaces:[g]};var $=null;function v(){return null===$&&new y,$}function g(){}function b(){}function w(){x=this}g.$metadata$={kind:n,simpleName:"Formatter",interfaces:[]},b.$metadata$={kind:n,simpleName:"KLogger",interfaces:[]},w.prototype.logger_o14v8n$=function(t){return new F(s(e.getKClassFromExpression(t)).name)},w.prototype.logger_61zpoe$=function(t){return new F(t)},w.$metadata$={kind:i,simpleName:"KotlinLogging",interfaces:[]};var x=null;function k(){N=this,this.LOG_LEVEL=I(),this.APPENDER=m(),this.FORMATTER=v()}k.$metadata$={kind:i,simpleName:"KotlinLoggingConfiguration",interfaces:[]};var E,C,S,T,O,N=null;function P(){return null===N&&new k,N}function A(t,e){l.call(this),this.name$=t,this.ordinal$=e}function j(){j=function(){},E=new A("TRACE",0),C=new A("DEBUG",1),S=new A("INFO",2),T=new A("WARN",3),O=new A("ERROR",4)}function L(){return j(),E}function R(){return j(),C}function I(){return j(),S}function z(){return j(),T}function D(){return j(),O}function M(t){return t.ordinal>=P().LOG_LEVEL.ordinal}function B(){U=this}A.$metadata$={kind:u,simpleName:"KotlinLoggingLevel",interfaces:[l]},A.values=function(){return[L(),R(),I(),z(),D()]},A.valueOf_61zpoe$=function(t){switch(t){case"TRACE":return L();case"DEBUG":return R();case"INFO":return I();case"WARN":return z();case"ERROR":return D();default:c("No enum constant mu.KotlinLoggingLevel."+t)}},B.prototype.getErrorLog_3lhtaa$=function(t){return"Log message invocation failed: "+t},B.$metadata$={kind:i,simpleName:"ErrorMessageProducer",interfaces:[]};var U=null;function F(t){this.loggerName_0=t}function q(){return"exit()"}F.prototype.trace_nq59yw$=function(t){this.logIfEnabled_0(L(),t,h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.debug_nq59yw$=function(t){this.logIfEnabled_0(R(),t,h("debug",function(t,e){return t.debug_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.info_nq59yw$=function(t){this.logIfEnabled_0(I(),t,h("info",function(t,e){return t.info_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.warn_nq59yw$=function(t){this.logIfEnabled_0(z(),t,h("warn",function(t,e){return t.warn_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.error_nq59yw$=function(t){this.logIfEnabled_0(D(),t,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.trace_ca4k3s$=function(t,e){this.logIfEnabled_1(L(),e,t,h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.debug_ca4k3s$=function(t,e){this.logIfEnabled_1(R(),e,t,h("debug",function(t,e){return t.debug_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.info_ca4k3s$=function(t,e){this.logIfEnabled_1(I(),e,t,h("info",function(t,e){return t.info_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.warn_ca4k3s$=function(t,e){this.logIfEnabled_1(z(),e,t,h("warn",function(t,e){return t.warn_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.error_ca4k3s$=function(t,e){this.logIfEnabled_1(D(),e,t,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.trace_8jakm3$=function(t,e){this.logIfEnabled_2(L(),t,e,h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.debug_8jakm3$=function(t,e){this.logIfEnabled_2(R(),t,e,h("debug",function(t,e){return t.debug_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.info_8jakm3$=function(t,e){this.logIfEnabled_2(I(),t,e,h("info",function(t,e){return t.info_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.warn_8jakm3$=function(t,e){this.logIfEnabled_2(z(),t,e,h("warn",function(t,e){return t.warn_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.error_8jakm3$=function(t,e){this.logIfEnabled_2(D(),t,e,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.trace_o4svvp$=function(t,e,n){this.logIfEnabled_3(L(),t,n,e,h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.debug_o4svvp$=function(t,e,n){this.logIfEnabled_3(R(),t,n,e,h("debug",function(t,e){return t.debug_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.info_o4svvp$=function(t,e,n){this.logIfEnabled_3(I(),t,n,e,h("info",function(t,e){return t.info_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.warn_o4svvp$=function(t,e,n){this.logIfEnabled_3(z(),t,n,e,h("warn",function(t,e){return t.warn_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.error_o4svvp$=function(t,e,n){this.logIfEnabled_3(D(),t,n,e,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.logIfEnabled_0=function(t,e,n){M(t)&&n(P().FORMATTER.formatMessage_pijeg6$(t,this.loggerName_0,e))},F.prototype.logIfEnabled_1=function(t,e,n,i){M(t)&&i(P().FORMATTER.formatMessage_hqgb2y$(t,this.loggerName_0,n,e))},F.prototype.logIfEnabled_2=function(t,e,n,i){M(t)&&i(P().FORMATTER.formatMessage_i9qi47$(t,this.loggerName_0,e,n))},F.prototype.logIfEnabled_3=function(t,e,n,i,r){M(t)&&r(P().FORMATTER.formatMessage_fud0c7$(t,this.loggerName_0,e,i,n))},F.prototype.entry_yhszz7$=function(t){var e;this.logIfEnabled_0(L(),(e=t,function(){return"entry("+e+")"}),h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.exit=function(){this.logIfEnabled_0(L(),q,h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.prototype.exit_mh5how$=function(t){return this.logIfEnabled_0(L(),(e=t,function(){return"exit("+e+")"}),h("trace",function(t,e){return t.trace_s8jyv4$(e),p}.bind(null,P().APPENDER))),t;var e},F.prototype.throwing_849n7l$=function(t){return this.logIfEnabled_1(D(),(e=t,function(){return"throwing("+e}),t,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER))),t;var e},F.prototype.catching_849n7l$=function(t){var e;this.logIfEnabled_1(D(),(e=t,function(){return"catching("+e}),t,h("error",function(t,e){return t.error_s8jyv4$(e),p}.bind(null,P().APPENDER)))},F.$metadata$={kind:u,simpleName:"KLoggerJS",interfaces:[b]};var G=t.mu||(t.mu={}),H=G.internal||(G.internal={});return G.Appender=_,Object.defineProperty(G,"ConsoleOutputAppender",{get:m}),Object.defineProperty(G,"DefaultMessageFormatter",{get:v}),G.Formatter=g,G.KLogger=b,Object.defineProperty(G,"KotlinLogging",{get:function(){return null===x&&new w,x}}),Object.defineProperty(G,"KotlinLoggingConfiguration",{get:P}),Object.defineProperty(A,"TRACE",{get:L}),Object.defineProperty(A,"DEBUG",{get:R}),Object.defineProperty(A,"INFO",{get:I}),Object.defineProperty(A,"WARN",{get:z}),Object.defineProperty(A,"ERROR",{get:D}),G.KotlinLoggingLevel=A,G.isLoggingEnabled_pm19j7$=M,Object.defineProperty(H,"ErrorMessageProducer",{get:function(){return null===U&&new B,U}}),H.KLoggerJS=F,t})?i.apply(e,r):i)||(t.exports=o)},421:function(t,e){var n,i;void 0===(i="function"==typeof(n=function(t){var e=t;t.isBooleanArray=function(t){return(Array.isArray(t)||t instanceof Int8Array)&&"BooleanArray"===t.$type$},t.isByteArray=function(t){return t instanceof Int8Array&&"BooleanArray"!==t.$type$},t.isShortArray=function(t){return t instanceof Int16Array},t.isCharArray=function(t){return t instanceof Uint16Array&&"CharArray"===t.$type$},t.isIntArray=function(t){return t instanceof Int32Array},t.isFloatArray=function(t){return t instanceof Float32Array},t.isDoubleArray=function(t){return t instanceof Float64Array},t.isLongArray=function(t){return Array.isArray(t)&&"LongArray"===t.$type$},t.isArray=function(t){return Array.isArray(t)&&!t.$type$},t.isArrayish=function(t){return Array.isArray(t)||ArrayBuffer.isView(t)},t.arrayToString=function(e){if(null===e)return"null";var n=t.isCharArray(e)?String.fromCharCode:t.toString;return"["+Array.prototype.map.call(e,(function(t){return n(t)})).join(", ")+"]"},t.arrayEquals=function(e,n){if(e===n)return!0;if(null===e||null===n||!t.isArrayish(n)||e.length!==n.length)return!1;for(var i=0,r=e.length;i>16},t.toByte=function(t){return(255&t)<<24>>24},t.toChar=function(t){return 65535&t},t.numberToLong=function(e){return e instanceof t.Long?e:t.Long.fromNumber(e)},t.numberToInt=function(e){return e instanceof t.Long?e.toInt():t.doubleToInt(e)},t.numberToDouble=function(t){return+t},t.doubleToInt=function(t){return t>2147483647?2147483647:t<-2147483648?-2147483648:0|t},t.toBoxedChar=function(e){return null==e||e instanceof t.BoxedChar?e:new t.BoxedChar(e)},t.unboxChar=function(e){return null==e?e:t.toChar(e)},t.equals=function(t,e){return null==t?null==e:null!=e&&(t!=t?e!=e:"object"==typeof t&&"function"==typeof t.equals?t.equals(e):"number"==typeof t&&"number"==typeof e?t===e&&(0!==t||1/t==1/e):t===e)},t.hashCode=function(e){if(null==e)return 0;var n=typeof e;return"object"===n?"function"==typeof e.hashCode?e.hashCode():h(e):"function"===n?h(e):"number"===n?t.numberHashCode(e):"boolean"===n?Number(e):function(t){for(var e=0,n=0;n=t.Long.TWO_PWR_63_DBL_?t.Long.MAX_VALUE:e<0?t.Long.fromNumber(-e).negate():new t.Long(e%t.Long.TWO_PWR_32_DBL_|0,e/t.Long.TWO_PWR_32_DBL_|0)},t.Long.fromBits=function(e,n){return new t.Long(e,n)},t.Long.fromString=function(e,n){if(0==e.length)throw Error("number format error: empty string");var i=n||10;if(i<2||36=0)throw Error('number format error: interior "-" character: '+e);for(var r=t.Long.fromNumber(Math.pow(i,8)),o=t.Long.ZERO,a=0;a=0?this.low_:t.Long.TWO_PWR_32_DBL_+this.low_},t.Long.prototype.getNumBitsAbs=function(){if(this.isNegative())return this.equalsLong(t.Long.MIN_VALUE)?64:this.negate().getNumBitsAbs();for(var e=0!=this.high_?this.high_:this.low_,n=31;n>0&&0==(e&1<0},t.Long.prototype.greaterThanOrEqual=function(t){return this.compare(t)>=0},t.Long.prototype.compare=function(t){if(this.equalsLong(t))return 0;var e=this.isNegative(),n=t.isNegative();return e&&!n?-1:!e&&n?1:this.subtract(t).isNegative()?-1:1},t.Long.prototype.negate=function(){return this.equalsLong(t.Long.MIN_VALUE)?t.Long.MIN_VALUE:this.not().add(t.Long.ONE)},t.Long.prototype.add=function(e){var n=this.high_>>>16,i=65535&this.high_,r=this.low_>>>16,o=65535&this.low_,a=e.high_>>>16,s=65535&e.high_,l=e.low_>>>16,u=0,c=0,p=0,h=0;return p+=(h+=o+(65535&e.low_))>>>16,h&=65535,c+=(p+=r+l)>>>16,p&=65535,u+=(c+=i+s)>>>16,c&=65535,u+=n+a,u&=65535,t.Long.fromBits(p<<16|h,u<<16|c)},t.Long.prototype.subtract=function(t){return this.add(t.negate())},t.Long.prototype.multiply=function(e){if(this.isZero())return t.Long.ZERO;if(e.isZero())return t.Long.ZERO;if(this.equalsLong(t.Long.MIN_VALUE))return e.isOdd()?t.Long.MIN_VALUE:t.Long.ZERO;if(e.equalsLong(t.Long.MIN_VALUE))return this.isOdd()?t.Long.MIN_VALUE:t.Long.ZERO;if(this.isNegative())return e.isNegative()?this.negate().multiply(e.negate()):this.negate().multiply(e).negate();if(e.isNegative())return this.multiply(e.negate()).negate();if(this.lessThan(t.Long.TWO_PWR_24_)&&e.lessThan(t.Long.TWO_PWR_24_))return t.Long.fromNumber(this.toNumber()*e.toNumber());var n=this.high_>>>16,i=65535&this.high_,r=this.low_>>>16,o=65535&this.low_,a=e.high_>>>16,s=65535&e.high_,l=e.low_>>>16,u=65535&e.low_,c=0,p=0,h=0,_=0;return h+=(_+=o*u)>>>16,_&=65535,p+=(h+=r*u)>>>16,h&=65535,p+=(h+=o*l)>>>16,h&=65535,c+=(p+=i*u)>>>16,p&=65535,c+=(p+=r*l)>>>16,p&=65535,c+=(p+=o*s)>>>16,p&=65535,c+=n*u+i*l+r*s+o*a,c&=65535,t.Long.fromBits(h<<16|_,c<<16|p)},t.Long.prototype.div=function(e){if(e.isZero())throw Error("division by zero");if(this.isZero())return t.Long.ZERO;if(this.equalsLong(t.Long.MIN_VALUE)){if(e.equalsLong(t.Long.ONE)||e.equalsLong(t.Long.NEG_ONE))return t.Long.MIN_VALUE;if(e.equalsLong(t.Long.MIN_VALUE))return t.Long.ONE;if((r=this.shiftRight(1).div(e).shiftLeft(1)).equalsLong(t.Long.ZERO))return e.isNegative()?t.Long.ONE:t.Long.NEG_ONE;var n=this.subtract(e.multiply(r));return r.add(n.div(e))}if(e.equalsLong(t.Long.MIN_VALUE))return t.Long.ZERO;if(this.isNegative())return e.isNegative()?this.negate().div(e.negate()):this.negate().div(e).negate();if(e.isNegative())return this.div(e.negate()).negate();var i=t.Long.ZERO;for(n=this;n.greaterThanOrEqual(e);){for(var r=Math.max(1,Math.floor(n.toNumber()/e.toNumber())),o=Math.ceil(Math.log(r)/Math.LN2),a=o<=48?1:Math.pow(2,o-48),s=t.Long.fromNumber(r),l=s.multiply(e);l.isNegative()||l.greaterThan(n);)r-=a,l=(s=t.Long.fromNumber(r)).multiply(e);s.isZero()&&(s=t.Long.ONE),i=i.add(s),n=n.subtract(l)}return i},t.Long.prototype.modulo=function(t){return this.subtract(this.div(t).multiply(t))},t.Long.prototype.not=function(){return t.Long.fromBits(~this.low_,~this.high_)},t.Long.prototype.and=function(e){return t.Long.fromBits(this.low_&e.low_,this.high_&e.high_)},t.Long.prototype.or=function(e){return t.Long.fromBits(this.low_|e.low_,this.high_|e.high_)},t.Long.prototype.xor=function(e){return t.Long.fromBits(this.low_^e.low_,this.high_^e.high_)},t.Long.prototype.shiftLeft=function(e){if(0==(e&=63))return this;var n=this.low_;if(e<32){var i=this.high_;return t.Long.fromBits(n<>>32-e)}return t.Long.fromBits(0,n<>>e|n<<32-e,n>>e)}return t.Long.fromBits(n>>e-32,n>=0?0:-1)},t.Long.prototype.shiftRightUnsigned=function(e){if(0==(e&=63))return this;var n=this.high_;if(e<32){var i=this.low_;return t.Long.fromBits(i>>>e|n<<32-e,n>>>e)}return 32==e?t.Long.fromBits(n,0):t.Long.fromBits(n>>>e-32,0)},t.Long.prototype.equals=function(e){return e instanceof t.Long&&this.equalsLong(e)},t.Long.prototype.compareTo_11rb$=t.Long.prototype.compare,t.Long.prototype.inc=function(){return this.add(t.Long.ONE)},t.Long.prototype.dec=function(){return this.add(t.Long.NEG_ONE)},t.Long.prototype.valueOf=function(){return this.toNumber()},t.Long.prototype.unaryPlus=function(){return this},t.Long.prototype.unaryMinus=t.Long.prototype.negate,t.Long.prototype.inv=t.Long.prototype.not,t.Long.prototype.rangeTo=function(e){return new t.kotlin.ranges.LongRange(this,e)},t.defineInlineFunction=function(t,e){return e},t.wrapFunction=function(t){var e=function(){return(e=t()).apply(this,arguments)};return function(){return e.apply(this,arguments)}},t.suspendCall=function(t){return t},t.coroutineResult=function(t){_()},t.coroutineReceiver=function(t){_()},t.setCoroutineResult=function(t,e){_()},t.getReifiedTypeParameterKType=function(t){_()},t.compareTo=function(e,n){var i=typeof e;return"number"===i?"number"==typeof n?t.doubleCompareTo(e,n):t.primitiveCompareTo(e,n):"string"===i||"boolean"===i?t.primitiveCompareTo(e,n):e.compareTo_11rb$(n)},t.primitiveCompareTo=function(t,e){return te?1:0},t.doubleCompareTo=function(t,e){if(te)return 1;if(t===e){if(0!==t)return 0;var n=1/t;return n===1/e?0:n<0?-1:1}return t!=t?e!=e?0:1:-1},t.charInc=function(e){return t.toChar(e+1)},t.imul=Math.imul||f,t.imulEmulated=f,i=new ArrayBuffer(8),r=new Float64Array(i),o=new Float32Array(i),a=new Int32Array(i),s=0,l=1,r[0]=-1,0!==a[s]&&(s=1,l=0),t.doubleToBits=function(e){return t.doubleToRawBits(isNaN(e)?NaN:e)},t.doubleToRawBits=function(e){return r[0]=e,t.Long.fromBits(a[s],a[l])},t.doubleFromBits=function(t){return a[s]=t.low_,a[l]=t.high_,r[0]},t.floatToBits=function(e){return t.floatToRawBits(isNaN(e)?NaN:e)},t.floatToRawBits=function(t){return o[0]=t,a[0]},t.floatFromBits=function(t){return a[0]=t,o[0]},t.numberHashCode=function(t){return(0|t)===t?0|t:(r[0]=t,(31*a[l]|0)+a[s]|0)},t.ensureNotNull=function(e){return null!=e?e:t.throwNPE()},void 0===String.prototype.startsWith&&Object.defineProperty(String.prototype,"startsWith",{value:function(t,e){return e=e||0,this.lastIndexOf(t,e)===e}}),void 0===String.prototype.endsWith&&Object.defineProperty(String.prototype,"endsWith",{value:function(t,e){var n=this.toString();(void 0===e||e>n.length)&&(e=n.length),e-=t.length;var i=n.indexOf(t,e);return-1!==i&&i===e}}),void 0===Math.sign&&(Math.sign=function(t){return 0==(t=+t)||isNaN(t)?Number(t):t>0?1:-1}),void 0===Math.trunc&&(Math.trunc=function(t){return isNaN(t)?NaN:t>0?Math.floor(t):Math.ceil(t)}),function(){var t=Math.sqrt(2220446049250313e-31),e=Math.sqrt(t),n=1/t,i=1/e;if(void 0===Math.sinh&&(Math.sinh=function(n){if(Math.abs(n)t&&(i+=n*n*n/6),i}var r=Math.exp(n),o=1/r;return isFinite(r)?isFinite(o)?(r-o)/2:-Math.exp(-n-Math.LN2):Math.exp(n-Math.LN2)}),void 0===Math.cosh&&(Math.cosh=function(t){var e=Math.exp(t),n=1/e;return isFinite(e)&&isFinite(n)?(e+n)/2:Math.exp(Math.abs(t)-Math.LN2)}),void 0===Math.tanh&&(Math.tanh=function(n){if(Math.abs(n)t&&(i-=n*n*n/3),i}var r=Math.exp(+n),o=Math.exp(-n);return r===1/0?1:o===1/0?-1:(r-o)/(r+o)}),void 0===Math.asinh){var r=function(o){if(o>=+e)return o>i?o>n?Math.log(o)+Math.LN2:Math.log(2*o+1/(2*o)):Math.log(o+Math.sqrt(o*o+1));if(o<=-e)return-r(-o);var a=o;return Math.abs(o)>=t&&(a-=o*o*o/6),a};Math.asinh=r}void 0===Math.acosh&&(Math.acosh=function(i){if(i<1)return NaN;if(i-1>=e)return i>n?Math.log(i)+Math.LN2:Math.log(i+Math.sqrt(i*i-1));var r=Math.sqrt(i-1),o=r;return r>=t&&(o-=r*r*r/12),Math.sqrt(2)*o}),void 0===Math.atanh&&(Math.atanh=function(n){if(Math.abs(n)t&&(i+=n*n*n/3),i}return Math.log((1+n)/(1-n))/2}),void 0===Math.log1p&&(Math.log1p=function(t){if(Math.abs(t)>>0;return 0===e?32:31-(u(e)/c|0)|0})),void 0===ArrayBuffer.isView&&(ArrayBuffer.isView=function(t){return null!=t&&null!=t.__proto__&&t.__proto__.__proto__===Int8Array.prototype.__proto__}),void 0===Array.prototype.fill&&Object.defineProperty(Array.prototype,"fill",{value:function(t){if(null==this)throw new TypeError("this is null or not defined");for(var e=Object(this),n=e.length>>>0,i=arguments[1]>>0,r=i<0?Math.max(n+i,0):Math.min(i,n),o=arguments[2],a=void 0===o?n:o>>0,s=a<0?Math.max(n+a,0):Math.min(a,n);re)return 1;if(t===e){if(0!==t)return 0;var n=1/t;return n===1/e?0:n<0?-1:1}return t!=t?e!=e?0:1:-1};for(i=0;i=0}function U(t,e){return q(t,e)>=0}function F(t,e){if(null==e){for(var n=0;n!==t.length;++n)if(null==t[n])return n}else for(var i=0;i!==t.length;++i)if(o(e,t[i]))return i;return-1}function q(t,e){for(var n=0;n!==t.length;++n)if(e===t[n])return n;return-1}function G(t,e){var n,i;if(null==e)for(n=Nt(W(t)).iterator();n.hasNext();){var r=n.next();if(null==t[r])return r}else for(i=Nt(W(t)).iterator();i.hasNext();){var a=i.next();if(o(e,t[a]))return a}return-1}function H(t){var e;switch(t.length){case 0:throw new Xn("Array is empty.");case 1:e=t[0];break;default:throw Mn("Array has more than one element.")}return e}function Y(t){return V(t,Ki())}function V(t,e){var n;for(n=0;n!==t.length;++n){var i=t[n];null!=i&&e.add_11rb$(i)}return e}function K(t,e){var n;if(!(e>=0))throw Mn(("Requested element count "+e+" is less than zero.").toString());if(0===e)return $s();if(e>=t.length)return Q(t);if(1===e)return ki(t[0]);var i=0,r=Wi(e);for(n=0;n!==t.length;++n){var o=t[n];if(r.add_11rb$(o),(i=i+1|0)===e)break}return r}function W(t){return new qe(0,X(t))}function X(t){return t.length-1|0}function Z(t){return t.length-1|0}function J(t,e){var n;for(n=0;n!==t.length;++n){var i=t[n];e.add_11rb$(i)}return e}function Q(t){var e;switch(t.length){case 0:e=$s();break;case 1:e=ki(t[0]);break;default:e=tt(t)}return e}function tt(t){return Xi(ms(t))}function et(t){var e;switch(t.length){case 0:e=Dl();break;case 1:e=Ei(t[0]);break;default:e=J(t,Dr(t.length))}return e}function nt(t,e,n,i,r,o,a,s){var l;void 0===n&&(n=", "),void 0===i&&(i=""),void 0===r&&(r=""),void 0===o&&(o=-1),void 0===a&&(a="..."),void 0===s&&(s=null),e.append_gw00v9$(i);var u=0;for(l=0;l!==t.length;++l){var c=t[l];if((u=u+1|0)>1&&e.append_gw00v9$(n),!(o<0||u<=o))break;ic(e,c,s)}return o>=0&&u>o&&e.append_gw00v9$(a),e.append_gw00v9$(r),e}function it(e){return 0===e.length?ll():new M((n=e,function(){return t.arrayIterator(n)}));var n}function rt(t){this.closure$iterator=t}function ot(e,n){return t.isType(e,ee)?e.contains_11rb$(n):ct(e,n)>=0}function at(e,n){return t.isType(e,ie)?e.get_za3lpa$(n):st(e,n,(i=n,function(t){throw new Fn("Collection doesn't contain element at index "+i+".")}));var i}function st(e,n,i){var r;if(t.isType(e,ie))return n>=0&&n<=ws(e)?e.get_za3lpa$(n):i(n);if(n<0)return i(n);for(var o=e.iterator(),a=0;o.hasNext();){var s=o.next();if(n===(a=(r=a)+1|0,r))return s}return i(n)}function lt(e){if(t.isType(e,ie))return ut(e);var n=e.iterator();if(!n.hasNext())throw new Xn("Collection is empty.");return n.next()}function ut(t){if(t.isEmpty())throw new Xn("List is empty.");return t.get_za3lpa$(0)}function ct(e,n){var i;if(t.isType(e,ie))return e.indexOf_11rb$(n);var r=0;for(i=e.iterator();i.hasNext();){var a=i.next();if(Pi(r),o(n,a))return r;r=r+1|0}return-1}function pt(e){if(t.isType(e,ie))return ht(e);var n=e.iterator();if(!n.hasNext())throw new Xn("Collection is empty.");for(var i=n.next();n.hasNext();)i=n.next();return i}function ht(t){if(t.isEmpty())throw new Xn("List is empty.");return t.get_za3lpa$(ws(t))}function _t(e){if(t.isType(e,ie))return ft(e);var n=e.iterator();if(!n.hasNext())throw new Xn("Collection is empty.");var i=n.next();if(n.hasNext())throw Mn("Collection has more than one element.");return i}function ft(t){var e;switch(t.size){case 0:throw new Xn("List is empty.");case 1:e=t.get_za3lpa$(0);break;default:throw Mn("List has more than one element.")}return e}function dt(t,e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();null!=i&&e.add_11rb$(i)}return e}function mt(t,e){for(var n=ws(t);n>=1;n--){var i=e.nextInt_za3lpa$(n+1|0);t.set_wxm5ur$(i,t.set_wxm5ur$(n,t.get_za3lpa$(i)))}}function yt(e,n){var i;if(t.isType(e,ee)){if(e.size<=1)return gt(e);var r=t.isArray(i=bi(e))?i:Yr();return pi(r,n),ai(r)}var o=bt(e);return Ti(o,n),o}function $t(t,e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();e.add_11rb$(i)}return e}function vt(t){return $t(t,gr(Ps(t,12)))}function gt(e){var n;if(t.isType(e,ee)){switch(e.size){case 0:n=$s();break;case 1:n=ki(t.isType(e,ie)?e.get_za3lpa$(0):e.iterator().next());break;default:n=wt(e)}return n}return xs(bt(e))}function bt(e){return t.isType(e,ee)?wt(e):$t(e,Ki())}function wt(t){return Xi(t)}function xt(e){var n;if(t.isType(e,ee)){switch(e.size){case 0:n=Dl();break;case 1:n=Ei(t.isType(e,ie)?e.get_za3lpa$(0):e.iterator().next());break;default:n=$t(e,Dr(e.size))}return n}return Bl($t(e,Rr()))}function kt(e){return t.isType(e,ee)?Ir(e):$t(e,Rr())}function Et(e,n){if(t.isType(n,ee)){var i=Wi(e.size+n.size|0);return i.addAll_brywnq$(e),i.addAll_brywnq$(n),i}var r=Xi(e);return Ws(r,n),r}function Ct(t,e,n,i,r,o,a,s){var l;void 0===n&&(n=", "),void 0===i&&(i=""),void 0===r&&(r=""),void 0===o&&(o=-1),void 0===a&&(a="..."),void 0===s&&(s=null),e.append_gw00v9$(i);var u=0;for(l=t.iterator();l.hasNext();){var c=l.next();if((u=u+1|0)>1&&e.append_gw00v9$(n),!(o<0||u<=o))break;ic(e,c,s)}return o>=0&&u>o&&e.append_gw00v9$(a),e.append_gw00v9$(r),e}function St(t,e,n,i,r,o,a){return void 0===e&&(e=", "),void 0===n&&(n=""),void 0===i&&(i=""),void 0===r&&(r=-1),void 0===o&&(o="..."),void 0===a&&(a=null),Ct(t,Qo(),e,n,i,r,o,a).toString()}function Tt(t){return new rt((e=t,function(){return e.iterator()}));var e}function Ot(t,e){return je().fromClosedRange_qt1dr2$(t,e,-1)}function Nt(t){return je().fromClosedRange_qt1dr2$(t.last,t.first,0|-t.step)}function Pt(t,e){return e<=-2147483648?Ye().EMPTY:new qe(t,e-1|0)}function At(t,e){return te?e:t}function Lt(t,e,n){if(e>n)throw Mn("Cannot coerce value to an empty range: maximum "+n+" is less than minimum "+e+".");return tn?n:t}function Rt(t){this.closure$iterator=t}function It(t,e){return new yl(t,!1,e)}function zt(t){return null==t}function Dt(e){var n;return t.isType(n=It(e,zt),nl)?n:Yr()}function Mt(e,n){if(!(n>=0))throw Mn(("Requested element count "+n+" is less than zero.").toString());return 0===n?ll():t.isType(e,El)?e.take_za3lpa$(n):new Tl(e,n)}function Bt(t,e){this.this$sortedWith=t,this.closure$comparator=e}function Ut(t,e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();e.add_11rb$(i)}return e}function Ft(t){return xs(qt(t))}function qt(t){return Ut(t,Ki())}function Gt(t,e){return new vl(t,e)}function Ht(t,e,n,i){return void 0===n&&(n=1),void 0===i&&(i=!1),ql(t,e,n,i,!1)}function Yt(t,e){return cp(t,e)}function Vt(t,e,n,i,r,o,a,s){var l;void 0===n&&(n=", "),void 0===i&&(i=""),void 0===r&&(r=""),void 0===o&&(o=-1),void 0===a&&(a="..."),void 0===s&&(s=null),e.append_gw00v9$(i);var u=0;for(l=t.iterator();l.hasNext();){var c=l.next();if((u=u+1|0)>1&&e.append_gw00v9$(n),!(o<0||u<=o))break;ic(e,c,s)}return o>=0&&u>o&&e.append_gw00v9$(a),e.append_gw00v9$(r),e}function Kt(t){return new Rt((e=t,function(){return e.iterator()}));var e}function Wt(t){this.closure$iterator=t}function Xt(t,e){if(!(e>=0))throw Mn(("Requested character count "+e+" is less than zero.").toString());return t.substring(0,jt(e,t.length))}function Zt(){}function Jt(){}function Qt(){}function te(){}function ee(){}function ne(){}function ie(){}function re(){}function oe(){}function ae(){}function se(){}function le(){}function ue(){}function ce(){}function pe(){}function he(){}function _e(){}function fe(){}function de(){}function me(){}function ye(){}function $e(){}function ve(){}function ge(){}function be(){}function we(){}function xe(t,e,n){me.call(this),this.step=n,this.finalElement_0=0|e,this.hasNext_0=this.step>0?t<=e:t>=e,this.next_0=this.hasNext_0?0|t:this.finalElement_0}function ke(t,e,n){$e.call(this),this.step=n,this.finalElement_0=e,this.hasNext_0=this.step>0?t<=e:t>=e,this.next_0=this.hasNext_0?t:this.finalElement_0}function Ee(t,e,n){ve.call(this),this.step=n,this.finalElement_0=e,this.hasNext_0=this.step.toNumber()>0?t.compareTo_11rb$(e)<=0:t.compareTo_11rb$(e)>=0,this.next_0=this.hasNext_0?t:this.finalElement_0}function Ce(t,e,n){if(Oe(),0===n)throw Mn("Step must be non-zero.");if(-2147483648===n)throw Mn("Step must be greater than Int.MIN_VALUE to avoid overflow on negation.");this.first=t,this.last=h(on(0|t,0|e,n)),this.step=n}function Se(){Te=this}Rn.prototype=Object.create(T.prototype),Rn.prototype.constructor=Rn,In.prototype=Object.create(Rn.prototype),In.prototype.constructor=In,xe.prototype=Object.create(me.prototype),xe.prototype.constructor=xe,ke.prototype=Object.create($e.prototype),ke.prototype.constructor=ke,Ee.prototype=Object.create(ve.prototype),Ee.prototype.constructor=Ee,Me.prototype=Object.create(Ce.prototype),Me.prototype.constructor=Me,qe.prototype=Object.create(Ne.prototype),qe.prototype.constructor=qe,Ve.prototype=Object.create(Le.prototype),Ve.prototype.constructor=Ve,ln.prototype=Object.create(we.prototype),ln.prototype.constructor=ln,cn.prototype=Object.create(de.prototype),cn.prototype.constructor=cn,hn.prototype=Object.create(ye.prototype),hn.prototype.constructor=hn,fn.prototype=Object.create(me.prototype),fn.prototype.constructor=fn,mn.prototype=Object.create($e.prototype),mn.prototype.constructor=mn,$n.prototype=Object.create(ge.prototype),$n.prototype.constructor=$n,gn.prototype=Object.create(be.prototype),gn.prototype.constructor=gn,wn.prototype=Object.create(ve.prototype),wn.prototype.constructor=wn,jn.prototype=Object.create(T.prototype),jn.prototype.constructor=jn,Dn.prototype=Object.create(In.prototype),Dn.prototype.constructor=Dn,Bn.prototype=Object.create(In.prototype),Bn.prototype.constructor=Bn,Fn.prototype=Object.create(In.prototype),Fn.prototype.constructor=Fn,qn.prototype=Object.create(In.prototype),qn.prototype.constructor=qn,Yn.prototype=Object.create(Dn.prototype),Yn.prototype.constructor=Yn,Vn.prototype=Object.create(In.prototype),Vn.prototype.constructor=Vn,Kn.prototype=Object.create(In.prototype),Kn.prototype.constructor=Kn,Wn.prototype=Object.create(jn.prototype),Wn.prototype.constructor=Wn,Xn.prototype=Object.create(In.prototype),Xn.prototype.constructor=Xn,Jn.prototype=Object.create(In.prototype),Jn.prototype.constructor=Jn,Qn.prototype=Object.create(In.prototype),Qn.prototype.constructor=Qn,ei.prototype=Object.create(In.prototype),ei.prototype.constructor=ei,Ha.prototype=Object.create(za.prototype),Ha.prototype.constructor=Ha,Li.prototype=Object.create(za.prototype),Li.prototype.constructor=Li,zi.prototype=Object.create(Ii.prototype),zi.prototype.constructor=zi,Ri.prototype=Object.create(Li.prototype),Ri.prototype.constructor=Ri,Di.prototype=Object.create(Ri.prototype),Di.prototype.constructor=Di,Yi.prototype=Object.create(Li.prototype),Yi.prototype.constructor=Yi,Ui.prototype=Object.create(Yi.prototype),Ui.prototype.constructor=Ui,Fi.prototype=Object.create(Yi.prototype),Fi.prototype.constructor=Fi,Gi.prototype=Object.create(Li.prototype),Gi.prototype.constructor=Gi,Mi.prototype=Object.create(Ja.prototype),Mi.prototype.constructor=Mi,Vi.prototype=Object.create(Ri.prototype),Vi.prototype.constructor=Vi,hr.prototype=Object.create(Ui.prototype),hr.prototype.constructor=hr,pr.prototype=Object.create(Mi.prototype),pr.prototype.constructor=pr,yr.prototype=Object.create(Yi.prototype),yr.prototype.constructor=yr,Sr.prototype=Object.create(Bi.prototype),Sr.prototype.constructor=Sr,Tr.prototype=Object.create(Ui.prototype),Tr.prototype.constructor=Tr,Cr.prototype=Object.create(pr.prototype),Cr.prototype.constructor=Cr,Lr.prototype=Object.create(yr.prototype),Lr.prototype.constructor=Lr,Ur.prototype=Object.create(Br.prototype),Ur.prototype.constructor=Ur,Fr.prototype=Object.create(Br.prototype),Fr.prototype.constructor=Fr,qr.prototype=Object.create(Fr.prototype),qr.prototype.constructor=qr,ro.prototype=Object.create(io.prototype),ro.prototype.constructor=ro,oo.prototype=Object.create(io.prototype),oo.prototype.constructor=oo,ao.prototype=Object.create(io.prototype),ao.prototype.constructor=ao,sa.prototype=Object.create(x.prototype),sa.prototype.constructor=sa,ka.prototype=Object.create(Ha.prototype),ka.prototype.constructor=ka,Ea.prototype=Object.create(za.prototype),Ea.prototype.constructor=Ea,Da.prototype=Object.create(x.prototype),Da.prototype.constructor=Da,Ya.prototype=Object.create(Ha.prototype),Ya.prototype.constructor=Ya,Ka.prototype=Object.create(Va.prototype),Ka.prototype.constructor=Ka,as.prototype=Object.create(za.prototype),as.prototype.constructor=as,Qa.prototype=Object.create(as.prototype),Qa.prototype.constructor=Qa,es.prototype=Object.create(za.prototype),es.prototype.constructor=es,el.prototype=Object.create(Ha.prototype),el.prototype.constructor=el,al.prototype=Object.create(ol.prototype),al.prototype.constructor=al,Vl.prototype=Object.create(Ga.prototype),Vl.prototype.constructor=Vl,Yl.prototype=Object.create(Ha.prototype),Yl.prototype.constructor=Yl,Tu.prototype=Object.create(x.prototype),Tu.prototype.constructor=Tu,Lu.prototype=Object.create(ju.prototype),Lu.prototype.constructor=Lu,Yu.prototype=Object.create(ju.prototype),Yu.prototype.constructor=Yu,yc.prototype=Object.create(me.prototype),yc.prototype.constructor=yc,Hc.prototype=Object.create(x.prototype),Hc.prototype.constructor=Hc,lp.prototype=Object.create(jn.prototype),lp.prototype.constructor=lp,gp.prototype=Object.create(kp.prototype),gp.prototype.constructor=gp,Tp.prototype=Object.create(Op.prototype),Tp.prototype.constructor=Tp,Rp.prototype=Object.create(Mp.prototype),Rp.prototype.constructor=Rp,qp.prototype=Object.create(Np.prototype),qp.prototype.constructor=qp,M.prototype.iterator=function(){return this.closure$iterator()},M.$metadata$={kind:p,interfaces:[nl]},rt.prototype.iterator=function(){return this.closure$iterator()},rt.$metadata$={kind:p,interfaces:[nl]},Rt.prototype.iterator=function(){return this.closure$iterator()},Rt.$metadata$={kind:p,interfaces:[Qt]},Bt.prototype.iterator=function(){var t=qt(this.this$sortedWith);return Ti(t,this.closure$comparator),t.iterator()},Bt.$metadata$={kind:p,interfaces:[nl]},Wt.prototype.iterator=function(){return this.closure$iterator()},Wt.$metadata$={kind:p,interfaces:[nl]},Zt.$metadata$={kind:g,simpleName:"Annotation",interfaces:[]},Jt.$metadata$={kind:g,simpleName:"CharSequence",interfaces:[]},Qt.$metadata$={kind:g,simpleName:"Iterable",interfaces:[]},te.$metadata$={kind:g,simpleName:"MutableIterable",interfaces:[Qt]},ee.$metadata$={kind:g,simpleName:"Collection",interfaces:[Qt]},ne.$metadata$={kind:g,simpleName:"MutableCollection",interfaces:[te,ee]},ie.$metadata$={kind:g,simpleName:"List",interfaces:[ee]},re.$metadata$={kind:g,simpleName:"MutableList",interfaces:[ne,ie]},oe.$metadata$={kind:g,simpleName:"Set",interfaces:[ee]},ae.$metadata$={kind:g,simpleName:"MutableSet",interfaces:[ne,oe]},se.prototype.getOrDefault_xwzc9p$=function(t,e){throw new lp},le.$metadata$={kind:g,simpleName:"Entry",interfaces:[]},se.$metadata$={kind:g,simpleName:"Map",interfaces:[]},ue.prototype.remove_xwzc9p$=function(t,e){return!0},ce.$metadata$={kind:g,simpleName:"MutableEntry",interfaces:[le]},ue.$metadata$={kind:g,simpleName:"MutableMap",interfaces:[se]},pe.$metadata$={kind:g,simpleName:"Iterator",interfaces:[]},he.$metadata$={kind:g,simpleName:"MutableIterator",interfaces:[pe]},_e.$metadata$={kind:g,simpleName:"ListIterator",interfaces:[pe]},fe.$metadata$={kind:g,simpleName:"MutableListIterator",interfaces:[he,_e]},de.prototype.next=function(){return this.nextByte()},de.$metadata$={kind:p,simpleName:"ByteIterator",interfaces:[pe]},me.prototype.next=function(){return a(this.nextChar())},me.$metadata$={kind:p,simpleName:"CharIterator",interfaces:[pe]},ye.prototype.next=function(){return this.nextShort()},ye.$metadata$={kind:p,simpleName:"ShortIterator",interfaces:[pe]},$e.prototype.next=function(){return this.nextInt()},$e.$metadata$={kind:p,simpleName:"IntIterator",interfaces:[pe]},ve.prototype.next=function(){return this.nextLong()},ve.$metadata$={kind:p,simpleName:"LongIterator",interfaces:[pe]},ge.prototype.next=function(){return this.nextFloat()},ge.$metadata$={kind:p,simpleName:"FloatIterator",interfaces:[pe]},be.prototype.next=function(){return this.nextDouble()},be.$metadata$={kind:p,simpleName:"DoubleIterator",interfaces:[pe]},we.prototype.next=function(){return this.nextBoolean()},we.$metadata$={kind:p,simpleName:"BooleanIterator",interfaces:[pe]},xe.prototype.hasNext=function(){return this.hasNext_0},xe.prototype.nextChar=function(){var t=this.next_0;if(t===this.finalElement_0){if(!this.hasNext_0)throw Zn();this.hasNext_0=!1}else this.next_0=this.next_0+this.step|0;return h(t)},xe.$metadata$={kind:p,simpleName:"CharProgressionIterator",interfaces:[me]},ke.prototype.hasNext=function(){return this.hasNext_0},ke.prototype.nextInt=function(){var t=this.next_0;if(t===this.finalElement_0){if(!this.hasNext_0)throw Zn();this.hasNext_0=!1}else this.next_0=this.next_0+this.step|0;return t},ke.$metadata$={kind:p,simpleName:"IntProgressionIterator",interfaces:[$e]},Ee.prototype.hasNext=function(){return this.hasNext_0},Ee.prototype.nextLong=function(){var t=this.next_0;if(o(t,this.finalElement_0)){if(!this.hasNext_0)throw Zn();this.hasNext_0=!1}else this.next_0=this.next_0.add(this.step);return t},Ee.$metadata$={kind:p,simpleName:"LongProgressionIterator",interfaces:[ve]},Ce.prototype.iterator=function(){return new xe(this.first,this.last,this.step)},Ce.prototype.isEmpty=function(){return this.step>0?this.first>this.last:this.first0?String.fromCharCode(this.first)+".."+String.fromCharCode(this.last)+" step "+this.step:String.fromCharCode(this.first)+" downTo "+String.fromCharCode(this.last)+" step "+(0|-this.step)},Se.prototype.fromClosedRange_ayra44$=function(t,e,n){return new Ce(t,e,n)},Se.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Te=null;function Oe(){return null===Te&&new Se,Te}function Ne(t,e,n){if(je(),0===n)throw Mn("Step must be non-zero.");if(-2147483648===n)throw Mn("Step must be greater than Int.MIN_VALUE to avoid overflow on negation.");this.first=t,this.last=on(t,e,n),this.step=n}function Pe(){Ae=this}Ce.$metadata$={kind:p,simpleName:"CharProgression",interfaces:[Qt]},Ne.prototype.iterator=function(){return new ke(this.first,this.last,this.step)},Ne.prototype.isEmpty=function(){return this.step>0?this.first>this.last:this.first0?this.first.toString()+".."+this.last+" step "+this.step:this.first.toString()+" downTo "+this.last+" step "+(0|-this.step)},Pe.prototype.fromClosedRange_qt1dr2$=function(t,e,n){return new Ne(t,e,n)},Pe.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ae=null;function je(){return null===Ae&&new Pe,Ae}function Le(t,e,n){if(ze(),o(n,u))throw Mn("Step must be non-zero.");if(o(n,m))throw Mn("Step must be greater than Long.MIN_VALUE to avoid overflow on negation.");this.first=t,this.last=an(t,e,n),this.step=n}function Re(){Ie=this}Ne.$metadata$={kind:p,simpleName:"IntProgression",interfaces:[Qt]},Le.prototype.iterator=function(){return new Ee(this.first,this.last,this.step)},Le.prototype.isEmpty=function(){return this.step.toNumber()>0?this.first.compareTo_11rb$(this.last)>0:this.first.compareTo_11rb$(this.last)<0},Le.prototype.equals=function(e){return t.isType(e,Le)&&(this.isEmpty()&&e.isEmpty()||o(this.first,e.first)&&o(this.last,e.last)&&o(this.step,e.step))},Le.prototype.hashCode=function(){return this.isEmpty()?-1:t.Long.fromInt(31).multiply(t.Long.fromInt(31).multiply(this.first.xor(this.first.shiftRightUnsigned(32))).add(this.last.xor(this.last.shiftRightUnsigned(32)))).add(this.step.xor(this.step.shiftRightUnsigned(32))).toInt()},Le.prototype.toString=function(){return this.step.toNumber()>0?this.first.toString()+".."+this.last.toString()+" step "+this.step.toString():this.first.toString()+" downTo "+this.last.toString()+" step "+this.step.unaryMinus().toString()},Re.prototype.fromClosedRange_b9bd0d$=function(t,e,n){return new Le(t,e,n)},Re.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ie=null;function ze(){return null===Ie&&new Re,Ie}function De(){}function Me(t,e){Fe(),Ce.call(this,t,e,1)}function Be(){Ue=this,this.EMPTY=new Me(h(1),h(0))}Le.$metadata$={kind:p,simpleName:"LongProgression",interfaces:[Qt]},De.prototype.contains_mef7kx$=function(e){return t.compareTo(e,this.start)>=0&&t.compareTo(e,this.endInclusive)<=0},De.prototype.isEmpty=function(){return t.compareTo(this.start,this.endInclusive)>0},De.$metadata$={kind:g,simpleName:"ClosedRange",interfaces:[]},Object.defineProperty(Me.prototype,"start",{configurable:!0,get:function(){return a(this.first)}}),Object.defineProperty(Me.prototype,"endInclusive",{configurable:!0,get:function(){return a(this.last)}}),Me.prototype.contains_mef7kx$=function(t){return this.first<=t&&t<=this.last},Me.prototype.isEmpty=function(){return this.first>this.last},Me.prototype.equals=function(e){return t.isType(e,Me)&&(this.isEmpty()&&e.isEmpty()||this.first===e.first&&this.last===e.last)},Me.prototype.hashCode=function(){return this.isEmpty()?-1:(31*(0|this.first)|0)+(0|this.last)|0},Me.prototype.toString=function(){return String.fromCharCode(this.first)+".."+String.fromCharCode(this.last)},Be.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ue=null;function Fe(){return null===Ue&&new Be,Ue}function qe(t,e){Ye(),Ne.call(this,t,e,1)}function Ge(){He=this,this.EMPTY=new qe(1,0)}Me.$metadata$={kind:p,simpleName:"CharRange",interfaces:[De,Ce]},Object.defineProperty(qe.prototype,"start",{configurable:!0,get:function(){return this.first}}),Object.defineProperty(qe.prototype,"endInclusive",{configurable:!0,get:function(){return this.last}}),qe.prototype.contains_mef7kx$=function(t){return this.first<=t&&t<=this.last},qe.prototype.isEmpty=function(){return this.first>this.last},qe.prototype.equals=function(e){return t.isType(e,qe)&&(this.isEmpty()&&e.isEmpty()||this.first===e.first&&this.last===e.last)},qe.prototype.hashCode=function(){return this.isEmpty()?-1:(31*this.first|0)+this.last|0},qe.prototype.toString=function(){return this.first.toString()+".."+this.last},Ge.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var He=null;function Ye(){return null===He&&new Ge,He}function Ve(t,e){Xe(),Le.call(this,t,e,w)}function Ke(){We=this,this.EMPTY=new Ve(w,u)}qe.$metadata$={kind:p,simpleName:"IntRange",interfaces:[De,Ne]},Object.defineProperty(Ve.prototype,"start",{configurable:!0,get:function(){return this.first}}),Object.defineProperty(Ve.prototype,"endInclusive",{configurable:!0,get:function(){return this.last}}),Ve.prototype.contains_mef7kx$=function(t){return this.first.compareTo_11rb$(t)<=0&&t.compareTo_11rb$(this.last)<=0},Ve.prototype.isEmpty=function(){return this.first.compareTo_11rb$(this.last)>0},Ve.prototype.equals=function(e){return t.isType(e,Ve)&&(this.isEmpty()&&e.isEmpty()||o(this.first,e.first)&&o(this.last,e.last))},Ve.prototype.hashCode=function(){return this.isEmpty()?-1:t.Long.fromInt(31).multiply(this.first.xor(this.first.shiftRightUnsigned(32))).add(this.last.xor(this.last.shiftRightUnsigned(32))).toInt()},Ve.prototype.toString=function(){return this.first.toString()+".."+this.last.toString()},Ke.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var We=null;function Xe(){return null===We&&new Ke,We}function Ze(){Je=this}Ve.$metadata$={kind:p,simpleName:"LongRange",interfaces:[De,Le]},Ze.prototype.toString=function(){return"kotlin.Unit"},Ze.$metadata$={kind:b,simpleName:"Unit",interfaces:[]};var Je=null;function Qe(){return null===Je&&new Ze,Je}function tn(t,e){var n=t%e;return n>=0?n:n+e|0}function en(t,e){var n=t.modulo(e);return n.toNumber()>=0?n:n.add(e)}function nn(t,e,n){return tn(tn(t,n)-tn(e,n)|0,n)}function rn(t,e,n){return en(en(t,n).subtract(en(e,n)),n)}function on(t,e,n){if(n>0)return t>=e?e:e-nn(e,t,n)|0;if(n<0)return t<=e?e:e+nn(t,e,0|-n)|0;throw Mn("Step is zero.")}function an(t,e,n){if(n.toNumber()>0)return t.compareTo_11rb$(e)>=0?e:e.subtract(rn(e,t,n));if(n.toNumber()<0)return t.compareTo_11rb$(e)<=0?e:e.add(rn(t,e,n.unaryMinus()));throw Mn("Step is zero.")}function sn(t){this.closure$arr=t,this.index=0}function ln(t){this.closure$array=t,we.call(this),this.index=0}function un(t){return new ln(t)}function cn(t){this.closure$array=t,de.call(this),this.index=0}function pn(t){return new cn(t)}function hn(t){this.closure$array=t,ye.call(this),this.index=0}function _n(t){return new hn(t)}function fn(t){this.closure$array=t,me.call(this),this.index=0}function dn(t){return new fn(t)}function mn(t){this.closure$array=t,$e.call(this),this.index=0}function yn(t){return new mn(t)}function $n(t){this.closure$array=t,ge.call(this),this.index=0}function vn(t){return new $n(t)}function gn(t){this.closure$array=t,be.call(this),this.index=0}function bn(t){return new gn(t)}function wn(t){this.closure$array=t,ve.call(this),this.index=0}function xn(t){return new wn(t)}function kn(t){this.c=t}function En(t){this.resultContinuation_0=t,this.state_0=0,this.exceptionState_0=0,this.result_0=null,this.exception_0=null,this.finallyPath_0=null,this.context_hxcuhl$_0=this.resultContinuation_0.context,this.intercepted__0=null}function Cn(){Sn=this}sn.prototype.hasNext=function(){return this.indexo)for(r.length=e;o=0))throw Mn(("Invalid new array size: "+e+".").toString());return ri(t,e,null)}function li(t,e,n){return Za().checkRangeIndexes_cub51b$(e,n,t.length),t.slice(e,n)}function ui(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=t.length),Za().checkRangeIndexes_cub51b$(n,i,t.length),t.fill(e,n,i)}function ci(t){t.length>1&&Qi(t)}function pi(t,e){t.length>1&&Zi(t,e)}function hi(t){var e=(t.size/2|0)-1|0;if(!(e<0))for(var n=ws(t),i=0;i<=e;i++){var r=t.get_za3lpa$(i);t.set_wxm5ur$(i,t.get_za3lpa$(n)),t.set_wxm5ur$(n,r),n=n-1|0}}function _i(){di=this,this.rangeStart_8be2vx$=new Int32Array([48,1632,1776,1984,2406,2534,2662,2790,2918,3046,3174,3302,3430,3558,3664,3792,3872,4160,4240,6112,6160,6470,6608,6784,6800,6992,7088,7232,7248,42528,43216,43264,43472,43504,43600,44016,65296])}On.prototype=Object.create(En.prototype),On.prototype.constructor=On,On.prototype.doResume=function(){var t;if(null!=(t=this.exception_0))throw t;return this.closure$block()},On.$metadata$={kind:p,interfaces:[En]},Object.defineProperty(jn.prototype,"message",{get:function(){return this.message_q7r8iu$_0}}),Object.defineProperty(jn.prototype,"cause",{get:function(){return this.cause_us9j0c$_0}}),jn.$metadata$={kind:p,simpleName:"Error",interfaces:[T]},Object.defineProperty(Rn.prototype,"message",{get:function(){return this.message_8yp7un$_0}}),Object.defineProperty(Rn.prototype,"cause",{get:function(){return this.cause_th0jdv$_0}}),Rn.$metadata$={kind:p,simpleName:"Exception",interfaces:[T]},In.$metadata$={kind:p,simpleName:"RuntimeException",interfaces:[Rn]},Dn.$metadata$={kind:p,simpleName:"IllegalArgumentException",interfaces:[In]},Bn.$metadata$={kind:p,simpleName:"IllegalStateException",interfaces:[In]},Fn.$metadata$={kind:p,simpleName:"IndexOutOfBoundsException",interfaces:[In]},qn.$metadata$={kind:p,simpleName:"UnsupportedOperationException",interfaces:[In]},Yn.$metadata$={kind:p,simpleName:"NumberFormatException",interfaces:[Dn]},Vn.$metadata$={kind:p,simpleName:"NullPointerException",interfaces:[In]},Kn.$metadata$={kind:p,simpleName:"ClassCastException",interfaces:[In]},Wn.$metadata$={kind:p,simpleName:"AssertionError",interfaces:[jn]},Xn.$metadata$={kind:p,simpleName:"NoSuchElementException",interfaces:[In]},Jn.$metadata$={kind:p,simpleName:"ArithmeticException",interfaces:[In]},Qn.$metadata$={kind:p,simpleName:"NoWhenBranchMatchedException",interfaces:[In]},ei.$metadata$={kind:p,simpleName:"UninitializedPropertyAccessException",interfaces:[In]},_i.$metadata$={kind:b,simpleName:"Digit",interfaces:[]};var fi,di=null;function mi(){return null===di&&new _i,di}function yi(t,e){for(var n=0,i=t.length-1|0,r=-1,o=0;n<=i;)if(e>(o=t[r=(n+i|0)/2|0]))n=r+1|0;else{if(e===o)return r;i=r-1|0}return r-(e4096&&(5760===e||8192<=e&&e<=8202||8232===e||8233===e||8239===e||8287===e||12288===e)}function gi(t){this.function$=t}function bi(t){return void 0!==t.toArray?t.toArray():wi(t)}function wi(t){for(var e=[],n=t.iterator();n.hasNext();)e.push(n.next());return e}function xi(t,e){var n;if(e.length=0;l--)e[n+l|0]=t[i+l|0]}function Pi(t){return t<0&&Es(),t}function Ai(t){return t<0&&Cs(),t}function ji(t){return t}function Li(){za.call(this)}function Ri(){Li.call(this),this.modCount=0}function Ii(t){this.$outer=t,this.index_0=0,this.last_0=-1}function zi(t,e){this.$outer=t,Ii.call(this,this.$outer),Za().checkPositionIndex_6xvm5r$(e,this.$outer.size),this.index_0=e}function Di(t,e,n){Ri.call(this),this.list_0=t,this.fromIndex_0=e,this._size_0=0,Za().checkRangeIndexes_cub51b$(this.fromIndex_0,n,this.list_0.size),this._size_0=n-this.fromIndex_0|0}function Mi(){Ja.call(this),this._keys_qe2m0n$_0=null,this._values_kxdlqh$_0=null}function Bi(t,e){this.key_5xhq3d$_0=t,this._value_0=e}function Ui(){Yi.call(this)}function Fi(t){this.this$AbstractMutableMap=t,Yi.call(this)}function qi(t){this.closure$entryIterator=t}function Gi(t){this.this$AbstractMutableMap=t,Li.call(this)}function Hi(t){this.closure$entryIterator=t}function Yi(){Li.call(this)}function Vi(t){Ri.call(this),this.array_hd7ov6$_0=t,this.isReadOnly_dbt2oh$_0=!1}function Ki(t){return t=t||Object.create(Vi.prototype),Vi.call(t,[]),t}function Wi(t,e){return void 0===t&&(t=0),e=e||Object.create(Vi.prototype),Vi.call(e,[]),e}function Xi(t,e){return e=e||Object.create(Vi.prototype),Vi.call(e,bi(t)),e}function Zi(t,e){if(er()){var n=(i=e,function(t,e){return i.compare(t,e)});t.sort(n)}else nr(t,0,X(t),e);var i}function Ji(e,n){return t.compareTo(e,n)}function Qi(t){if(er()){var e=Ji;t.sort(e)}else nr(t,0,X(t),Xl())}function tr(t,e){return(3&t)-(3&e)|0}function er(){if(null!=fi)return fi;fi=!1;for(var t=[],e=0;e<600;e++)t.push(e);var n=tr;t.sort(n);for(var i=1;i=o)return!1}return fi=!0,!0}function nr(e,n,i,r){var o=ir(e,t.newArray(e.length,null),n,i,r);if(o!==e)for(var a=n;a<=i;a++)e[a]=o[a]}function ir(t,e,n,i,r){if(n===i)return t;for(var o=(n+i|0)/2|0,a=ir(t,e,n,o,r),s=ir(t,e,o+1|0,i,r),l=a===e?t:e,u=n,c=o+1|0,p=n;p<=i;p++)if(u<=o&&c<=i){var h=a[u],_=s[c];r.compare(h,_)<=0?(l[p]=h,u=u+1|0):(l[p]=_,c=c+1|0)}else u<=o?(l[p]=a[u],u=u+1|0):(l[p]=s[c],c=c+1|0);return l}function rr(){}function or(){ur=this}gi.prototype.compare=function(t,e){return this.function$(t,e)},gi.$metadata$={kind:g,simpleName:"Comparator",interfaces:[]},Li.prototype.remove_11rb$=function(t){this.checkIsMutable();for(var e=this.iterator();e.hasNext();)if(o(e.next(),t))return e.remove(),!0;return!1},Li.prototype.addAll_brywnq$=function(t){var e;this.checkIsMutable();var n=!1;for(e=t.iterator();e.hasNext();){var i=e.next();this.add_11rb$(i)&&(n=!0)}return n},Li.prototype.removeAll_brywnq$=function(e){var n;return this.checkIsMutable(),Js(t.isType(this,te)?this:Yr(),(n=e,function(t){return n.contains_11rb$(t)}))},Li.prototype.retainAll_brywnq$=function(e){var n;return this.checkIsMutable(),Js(t.isType(this,te)?this:Yr(),(n=e,function(t){return!n.contains_11rb$(t)}))},Li.prototype.clear=function(){this.checkIsMutable();for(var t=this.iterator();t.hasNext();)t.next(),t.remove()},Li.prototype.toJSON=function(){return this.toArray()},Li.prototype.checkIsMutable=function(){},Li.$metadata$={kind:p,simpleName:"AbstractMutableCollection",interfaces:[ne,za]},Ri.prototype.add_11rb$=function(t){return this.checkIsMutable(),this.add_wxm5ur$(this.size,t),!0},Ri.prototype.addAll_u57x28$=function(t,e){var n,i;this.checkIsMutable();var r=t,o=!1;for(n=e.iterator();n.hasNext();){var a=n.next();this.add_wxm5ur$((r=(i=r)+1|0,i),a),o=!0}return o},Ri.prototype.clear=function(){this.checkIsMutable(),this.removeRange_vux9f0$(0,this.size)},Ri.prototype.removeAll_brywnq$=function(t){return this.checkIsMutable(),tl(this,(e=t,function(t){return e.contains_11rb$(t)}));var e},Ri.prototype.retainAll_brywnq$=function(t){return this.checkIsMutable(),tl(this,(e=t,function(t){return!e.contains_11rb$(t)}));var e},Ri.prototype.iterator=function(){return new Ii(this)},Ri.prototype.contains_11rb$=function(t){return this.indexOf_11rb$(t)>=0},Ri.prototype.indexOf_11rb$=function(t){var e;e=ws(this);for(var n=0;n<=e;n++)if(o(this.get_za3lpa$(n),t))return n;return-1},Ri.prototype.lastIndexOf_11rb$=function(t){for(var e=ws(this);e>=0;e--)if(o(this.get_za3lpa$(e),t))return e;return-1},Ri.prototype.listIterator=function(){return this.listIterator_za3lpa$(0)},Ri.prototype.listIterator_za3lpa$=function(t){return new zi(this,t)},Ri.prototype.subList_vux9f0$=function(t,e){return new Di(this,t,e)},Ri.prototype.removeRange_vux9f0$=function(t,e){for(var n=this.listIterator_za3lpa$(t),i=e-t|0,r=0;r0},zi.prototype.nextIndex=function(){return this.index_0},zi.prototype.previous=function(){if(!this.hasPrevious())throw Zn();return this.last_0=(this.index_0=this.index_0-1|0,this.index_0),this.$outer.get_za3lpa$(this.last_0)},zi.prototype.previousIndex=function(){return this.index_0-1|0},zi.prototype.add_11rb$=function(t){this.$outer.add_wxm5ur$(this.index_0,t),this.index_0=this.index_0+1|0,this.last_0=-1},zi.prototype.set_11rb$=function(t){if(-1===this.last_0)throw Un("Call next() or previous() before updating element value with the iterator.".toString());this.$outer.set_wxm5ur$(this.last_0,t)},zi.$metadata$={kind:p,simpleName:"ListIteratorImpl",interfaces:[fe,Ii]},Di.prototype.add_wxm5ur$=function(t,e){Za().checkPositionIndex_6xvm5r$(t,this._size_0),this.list_0.add_wxm5ur$(this.fromIndex_0+t|0,e),this._size_0=this._size_0+1|0},Di.prototype.get_za3lpa$=function(t){return Za().checkElementIndex_6xvm5r$(t,this._size_0),this.list_0.get_za3lpa$(this.fromIndex_0+t|0)},Di.prototype.removeAt_za3lpa$=function(t){Za().checkElementIndex_6xvm5r$(t,this._size_0);var e=this.list_0.removeAt_za3lpa$(this.fromIndex_0+t|0);return this._size_0=this._size_0-1|0,e},Di.prototype.set_wxm5ur$=function(t,e){return Za().checkElementIndex_6xvm5r$(t,this._size_0),this.list_0.set_wxm5ur$(this.fromIndex_0+t|0,e)},Object.defineProperty(Di.prototype,"size",{configurable:!0,get:function(){return this._size_0}}),Di.prototype.checkIsMutable=function(){this.list_0.checkIsMutable()},Di.$metadata$={kind:p,simpleName:"SubList",interfaces:[Mr,Ri]},Ri.$metadata$={kind:p,simpleName:"AbstractMutableList",interfaces:[re,Li]},Object.defineProperty(Bi.prototype,"key",{get:function(){return this.key_5xhq3d$_0}}),Object.defineProperty(Bi.prototype,"value",{configurable:!0,get:function(){return this._value_0}}),Bi.prototype.setValue_11rc$=function(t){var e=this._value_0;return this._value_0=t,e},Bi.prototype.hashCode=function(){return os().entryHashCode_9fthdn$(this)},Bi.prototype.toString=function(){return os().entryToString_9fthdn$(this)},Bi.prototype.equals=function(t){return os().entryEquals_js7fox$(this,t)},Bi.$metadata$={kind:p,simpleName:"SimpleEntry",interfaces:[ce]},Ui.prototype.contains_11rb$=function(t){return this.containsEntry_kw6fkd$(t)},Ui.prototype.remove_11rb$=function(t){return this.removeEntry_kw6fkd$(t)},Ui.$metadata$={kind:p,simpleName:"AbstractEntrySet",interfaces:[Yi]},Mi.prototype.clear=function(){this.entries.clear()},Fi.prototype.add_11rb$=function(t){throw Hn("Add is not supported on keys")},Fi.prototype.clear=function(){this.this$AbstractMutableMap.clear()},Fi.prototype.contains_11rb$=function(t){return this.this$AbstractMutableMap.containsKey_11rb$(t)},qi.prototype.hasNext=function(){return this.closure$entryIterator.hasNext()},qi.prototype.next=function(){return this.closure$entryIterator.next().key},qi.prototype.remove=function(){this.closure$entryIterator.remove()},qi.$metadata$={kind:p,interfaces:[he]},Fi.prototype.iterator=function(){return new qi(this.this$AbstractMutableMap.entries.iterator())},Fi.prototype.remove_11rb$=function(t){return this.checkIsMutable(),!!this.this$AbstractMutableMap.containsKey_11rb$(t)&&(this.this$AbstractMutableMap.remove_11rb$(t),!0)},Object.defineProperty(Fi.prototype,"size",{configurable:!0,get:function(){return this.this$AbstractMutableMap.size}}),Fi.prototype.checkIsMutable=function(){this.this$AbstractMutableMap.checkIsMutable()},Fi.$metadata$={kind:p,interfaces:[Yi]},Object.defineProperty(Mi.prototype,"keys",{configurable:!0,get:function(){return null==this._keys_qe2m0n$_0&&(this._keys_qe2m0n$_0=new Fi(this)),E(this._keys_qe2m0n$_0)}}),Mi.prototype.putAll_a2k3zr$=function(t){var e;for(this.checkIsMutable(),e=t.entries.iterator();e.hasNext();){var n=e.next(),i=n.key,r=n.value;this.put_xwzc9p$(i,r)}},Gi.prototype.add_11rb$=function(t){throw Hn("Add is not supported on values")},Gi.prototype.clear=function(){this.this$AbstractMutableMap.clear()},Gi.prototype.contains_11rb$=function(t){return this.this$AbstractMutableMap.containsValue_11rc$(t)},Hi.prototype.hasNext=function(){return this.closure$entryIterator.hasNext()},Hi.prototype.next=function(){return this.closure$entryIterator.next().value},Hi.prototype.remove=function(){this.closure$entryIterator.remove()},Hi.$metadata$={kind:p,interfaces:[he]},Gi.prototype.iterator=function(){return new Hi(this.this$AbstractMutableMap.entries.iterator())},Object.defineProperty(Gi.prototype,"size",{configurable:!0,get:function(){return this.this$AbstractMutableMap.size}}),Gi.prototype.equals=function(e){return this===e||!!t.isType(e,ee)&&Za().orderedEquals_e92ka7$(this,e)},Gi.prototype.hashCode=function(){return Za().orderedHashCode_nykoif$(this)},Gi.prototype.checkIsMutable=function(){this.this$AbstractMutableMap.checkIsMutable()},Gi.$metadata$={kind:p,interfaces:[Li]},Object.defineProperty(Mi.prototype,"values",{configurable:!0,get:function(){return null==this._values_kxdlqh$_0&&(this._values_kxdlqh$_0=new Gi(this)),E(this._values_kxdlqh$_0)}}),Mi.prototype.remove_11rb$=function(t){this.checkIsMutable();for(var e=this.entries.iterator();e.hasNext();){var n=e.next(),i=n.key;if(o(t,i)){var r=n.value;return e.remove(),r}}return null},Mi.prototype.checkIsMutable=function(){},Mi.$metadata$={kind:p,simpleName:"AbstractMutableMap",interfaces:[ue,Ja]},Yi.prototype.equals=function(e){return e===this||!!t.isType(e,oe)&&us().setEquals_y8f7en$(this,e)},Yi.prototype.hashCode=function(){return us().unorderedHashCode_nykoif$(this)},Yi.$metadata$={kind:p,simpleName:"AbstractMutableSet",interfaces:[ae,Li]},Vi.prototype.build=function(){return this.checkIsMutable(),this.isReadOnly_dbt2oh$_0=!0,this},Vi.prototype.trimToSize=function(){},Vi.prototype.ensureCapacity_za3lpa$=function(t){},Object.defineProperty(Vi.prototype,"size",{configurable:!0,get:function(){return this.array_hd7ov6$_0.length}}),Vi.prototype.get_za3lpa$=function(e){var n;return null==(n=this.array_hd7ov6$_0[this.rangeCheck_xcmk5o$_0(e)])||t.isType(n,C)?n:Yr()},Vi.prototype.set_wxm5ur$=function(e,n){var i;this.checkIsMutable(),this.rangeCheck_xcmk5o$_0(e);var r=this.array_hd7ov6$_0[e];return this.array_hd7ov6$_0[e]=n,null==(i=r)||t.isType(i,C)?i:Yr()},Vi.prototype.add_11rb$=function(t){return this.checkIsMutable(),this.array_hd7ov6$_0.push(t),this.modCount=this.modCount+1|0,!0},Vi.prototype.add_wxm5ur$=function(t,e){this.checkIsMutable(),this.array_hd7ov6$_0.splice(this.insertionRangeCheck_xwivfl$_0(t),0,e),this.modCount=this.modCount+1|0},Vi.prototype.addAll_brywnq$=function(t){return this.checkIsMutable(),!t.isEmpty()&&(this.array_hd7ov6$_0=this.array_hd7ov6$_0.concat(bi(t)),this.modCount=this.modCount+1|0,!0)},Vi.prototype.addAll_u57x28$=function(t,e){return this.checkIsMutable(),this.insertionRangeCheck_xwivfl$_0(t),t===this.size?this.addAll_brywnq$(e):!e.isEmpty()&&(t===this.size?this.addAll_brywnq$(e):(this.array_hd7ov6$_0=0===t?bi(e).concat(this.array_hd7ov6$_0):li(this.array_hd7ov6$_0,0,t).concat(bi(e),li(this.array_hd7ov6$_0,t,this.size)),this.modCount=this.modCount+1|0,!0))},Vi.prototype.removeAt_za3lpa$=function(t){return this.checkIsMutable(),this.rangeCheck_xcmk5o$_0(t),this.modCount=this.modCount+1|0,t===ws(this)?this.array_hd7ov6$_0.pop():this.array_hd7ov6$_0.splice(t,1)[0]},Vi.prototype.remove_11rb$=function(t){var e;this.checkIsMutable(),e=this.array_hd7ov6$_0;for(var n=0;n!==e.length;++n)if(o(this.array_hd7ov6$_0[n],t))return this.array_hd7ov6$_0.splice(n,1),this.modCount=this.modCount+1|0,!0;return!1},Vi.prototype.removeRange_vux9f0$=function(t,e){this.checkIsMutable(),this.modCount=this.modCount+1|0,this.array_hd7ov6$_0.splice(t,e-t|0)},Vi.prototype.clear=function(){this.checkIsMutable(),this.array_hd7ov6$_0=[],this.modCount=this.modCount+1|0},Vi.prototype.indexOf_11rb$=function(t){return F(this.array_hd7ov6$_0,t)},Vi.prototype.lastIndexOf_11rb$=function(t){return G(this.array_hd7ov6$_0,t)},Vi.prototype.toString=function(){return O(this.array_hd7ov6$_0)},Vi.prototype.toArray_ro6dgy$=function(e){var n,i;if(e.lengththis.size&&(e[this.size]=null==null||t.isType(null,C)?null:Yr()),e},Vi.prototype.toArray=function(){return[].slice.call(this.array_hd7ov6$_0)},Vi.prototype.checkIsMutable=function(){if(this.isReadOnly_dbt2oh$_0)throw Gn()},Vi.prototype.rangeCheck_xcmk5o$_0=function(t){return Za().checkElementIndex_6xvm5r$(t,this.size),t},Vi.prototype.insertionRangeCheck_xwivfl$_0=function(t){return Za().checkPositionIndex_6xvm5r$(t,this.size),t},Vi.$metadata$={kind:p,simpleName:"ArrayList",interfaces:[Mr,Ri,re]},or.prototype.equals_oaftn8$=function(t,e){return o(t,e)},or.prototype.getHashCode_s8jyv4$=function(t){var e;return null!=(e=null!=t?N(t):null)?e:0},or.$metadata$={kind:b,simpleName:"HashCode",interfaces:[rr]};var ar,sr,lr,ur=null;function cr(){return null===ur&&new or,ur}function pr(){this.internalMap_uxhen5$_0=null,this.equality_vgh6cm$_0=null,this._entries_7ih87x$_0=null}function hr(t){this.$outer=t,Ui.call(this)}function _r(t,e){return e=e||Object.create(pr.prototype),Mi.call(e),pr.call(e),e.internalMap_uxhen5$_0=t,e.equality_vgh6cm$_0=t.equality,e}function fr(t){return t=t||Object.create(pr.prototype),_r(new wr(cr()),t),t}function dr(t,e,n){if(void 0===e&&(e=0),fr(n=n||Object.create(pr.prototype)),!(t>=0))throw Mn(("Negative initial capacity: "+t).toString());if(!(e>=0))throw Mn(("Non-positive load factor: "+e).toString());return n}function mr(t,e){return dr(t,0,e=e||Object.create(pr.prototype)),e}function yr(){this.map_8be2vx$=null}function $r(t){return t=t||Object.create(yr.prototype),Yi.call(t),yr.call(t),t.map_8be2vx$=fr(),t}function vr(t,e,n){return void 0===e&&(e=0),n=n||Object.create(yr.prototype),Yi.call(n),yr.call(n),n.map_8be2vx$=dr(t,e),n}function gr(t,e){return vr(t,0,e=e||Object.create(yr.prototype)),e}function br(t,e){return e=e||Object.create(yr.prototype),Yi.call(e),yr.call(e),e.map_8be2vx$=t,e}function wr(t){this.equality_mamlu8$_0=t,this.backingMap_0=this.createJsMap(),this.size_x3bm7r$_0=0}function xr(t){this.this$InternalHashCodeMap=t,this.state=-1,this.keys=Object.keys(t.backingMap_0),this.keyIndex=-1,this.chainOrEntry=null,this.isChain=!1,this.itemIndex=-1,this.lastEntry=null}function kr(){}function Er(t){this.equality_qma612$_0=t,this.backingMap_0=this.createJsMap(),this.size_6u3ykz$_0=0}function Cr(){this.head_1lr44l$_0=null,this.map_97q5dv$_0=null,this.isReadOnly_uhyvn5$_0=!1}function Sr(t,e,n){this.$outer=t,Bi.call(this,e,n),this.next_8be2vx$=null,this.prev_8be2vx$=null}function Tr(t){this.$outer=t,Ui.call(this)}function Or(t){this.$outer=t,this.last_0=null,this.next_0=null,this.next_0=this.$outer.$outer.head_1lr44l$_0}function Nr(t){return fr(t=t||Object.create(Cr.prototype)),Cr.call(t),t.map_97q5dv$_0=fr(),t}function Pr(t,e,n){return void 0===e&&(e=0),dr(t,e,n=n||Object.create(Cr.prototype)),Cr.call(n),n.map_97q5dv$_0=fr(),n}function Ar(t,e){return Pr(t,0,e=e||Object.create(Cr.prototype)),e}function jr(t,e){return fr(e=e||Object.create(Cr.prototype)),Cr.call(e),e.map_97q5dv$_0=fr(),e.putAll_a2k3zr$(t),e}function Lr(){}function Rr(t){return t=t||Object.create(Lr.prototype),br(Nr(),t),Lr.call(t),t}function Ir(t,e){return e=e||Object.create(Lr.prototype),br(Nr(),e),Lr.call(e),e.addAll_brywnq$(t),e}function zr(t,e,n){return void 0===e&&(e=0),n=n||Object.create(Lr.prototype),br(Pr(t,e),n),Lr.call(n),n}function Dr(t,e){return zr(t,0,e=e||Object.create(Lr.prototype)),e}function Mr(){}function Br(){}function Ur(t){Br.call(this),this.outputStream=t}function Fr(){Br.call(this),this.buffer=""}function qr(){Fr.call(this)}function Gr(t,e){this.delegate_0=t,this.result_0=e}function Hr(t,e){this.closure$context=t,this.closure$resumeWith=e}function Yr(){throw new Kn("Illegal cast")}function Vr(t){throw Un(t)}function Kr(){}function Wr(e){if(Xr(e)||e===l.NEGATIVE_INFINITY)return e;if(0===e)return-l.MIN_VALUE;var n=P(e).add(t.Long.fromInt(e>0?-1:1));return t.doubleFromBits(n)}function Xr(t){return t!=t}function Zr(t){return t===l.POSITIVE_INFINITY||t===l.NEGATIVE_INFINITY}function Jr(t){return!Zr(t)&&!Xr(t)}function Qr(){return Mu(Math.random()*Math.pow(2,32)|0)}function to(t,e){return t*sr+e*lr}function eo(){}function no(){}function io(t){this.jClass_1ppatx$_0=t}function ro(t){var e;io.call(this,t),this.simpleName_m7mxi0$_0=null!=(e=t.$metadata$)?e.simpleName:null}function oo(t,e,n){io.call(this,t),this.givenSimpleName_0=e,this.isInstanceFunction_0=n}function ao(){so=this,io.call(this,Object),this.simpleName_lnzy73$_0="Nothing"}rr.$metadata$={kind:g,simpleName:"EqualityComparator",interfaces:[]},hr.prototype.add_11rb$=function(t){throw Hn("Add is not supported on entries")},hr.prototype.clear=function(){this.$outer.clear()},hr.prototype.containsEntry_kw6fkd$=function(t){return this.$outer.containsEntry_8hxqw4$(t)},hr.prototype.iterator=function(){return this.$outer.internalMap_uxhen5$_0.iterator()},hr.prototype.removeEntry_kw6fkd$=function(t){return!!ot(this,t)&&(this.$outer.remove_11rb$(t.key),!0)},Object.defineProperty(hr.prototype,"size",{configurable:!0,get:function(){return this.$outer.size}}),hr.$metadata$={kind:p,simpleName:"EntrySet",interfaces:[Ui]},pr.prototype.clear=function(){this.internalMap_uxhen5$_0.clear()},pr.prototype.containsKey_11rb$=function(t){return this.internalMap_uxhen5$_0.contains_11rb$(t)},pr.prototype.containsValue_11rc$=function(e){var n,i=this.internalMap_uxhen5$_0;t:do{var r;if(t.isType(i,ee)&&i.isEmpty()){n=!1;break t}for(r=i.iterator();r.hasNext();){var o=r.next();if(this.equality_vgh6cm$_0.equals_oaftn8$(o.value,e)){n=!0;break t}}n=!1}while(0);return n},Object.defineProperty(pr.prototype,"entries",{configurable:!0,get:function(){return null==this._entries_7ih87x$_0&&(this._entries_7ih87x$_0=this.createEntrySet()),E(this._entries_7ih87x$_0)}}),pr.prototype.createEntrySet=function(){return new hr(this)},pr.prototype.get_11rb$=function(t){return this.internalMap_uxhen5$_0.get_11rb$(t)},pr.prototype.put_xwzc9p$=function(t,e){return this.internalMap_uxhen5$_0.put_xwzc9p$(t,e)},pr.prototype.remove_11rb$=function(t){return this.internalMap_uxhen5$_0.remove_11rb$(t)},Object.defineProperty(pr.prototype,"size",{configurable:!0,get:function(){return this.internalMap_uxhen5$_0.size}}),pr.$metadata$={kind:p,simpleName:"HashMap",interfaces:[Mi,ue]},yr.prototype.add_11rb$=function(t){return null==this.map_8be2vx$.put_xwzc9p$(t,this)},yr.prototype.clear=function(){this.map_8be2vx$.clear()},yr.prototype.contains_11rb$=function(t){return this.map_8be2vx$.containsKey_11rb$(t)},yr.prototype.isEmpty=function(){return this.map_8be2vx$.isEmpty()},yr.prototype.iterator=function(){return this.map_8be2vx$.keys.iterator()},yr.prototype.remove_11rb$=function(t){return null!=this.map_8be2vx$.remove_11rb$(t)},Object.defineProperty(yr.prototype,"size",{configurable:!0,get:function(){return this.map_8be2vx$.size}}),yr.$metadata$={kind:p,simpleName:"HashSet",interfaces:[Yi,ae]},Object.defineProperty(wr.prototype,"equality",{get:function(){return this.equality_mamlu8$_0}}),Object.defineProperty(wr.prototype,"size",{configurable:!0,get:function(){return this.size_x3bm7r$_0},set:function(t){this.size_x3bm7r$_0=t}}),wr.prototype.put_xwzc9p$=function(e,n){var i=this.equality.getHashCode_s8jyv4$(e),r=this.getChainOrEntryOrNull_0(i);if(null==r)this.backingMap_0[i]=new Bi(e,n);else{if(!t.isArray(r)){var o=r;return this.equality.equals_oaftn8$(o.key,e)?o.setValue_11rc$(n):(this.backingMap_0[i]=[o,new Bi(e,n)],this.size=this.size+1|0,null)}var a=r,s=this.findEntryInChain_0(a,e);if(null!=s)return s.setValue_11rc$(n);a.push(new Bi(e,n))}return this.size=this.size+1|0,null},wr.prototype.remove_11rb$=function(e){var n,i=this.equality.getHashCode_s8jyv4$(e);if(null==(n=this.getChainOrEntryOrNull_0(i)))return null;var r=n;if(!t.isArray(r)){var o=r;return this.equality.equals_oaftn8$(o.key,e)?(delete this.backingMap_0[i],this.size=this.size-1|0,o.value):null}for(var a=r,s=0;s!==a.length;++s){var l=a[s];if(this.equality.equals_oaftn8$(e,l.key))return 1===a.length?(a.length=0,delete this.backingMap_0[i]):a.splice(s,1),this.size=this.size-1|0,l.value}return null},wr.prototype.clear=function(){this.backingMap_0=this.createJsMap(),this.size=0},wr.prototype.contains_11rb$=function(t){return null!=this.getEntry_0(t)},wr.prototype.get_11rb$=function(t){var e;return null!=(e=this.getEntry_0(t))?e.value:null},wr.prototype.getEntry_0=function(e){var n;if(null==(n=this.getChainOrEntryOrNull_0(this.equality.getHashCode_s8jyv4$(e))))return null;var i=n;if(t.isArray(i)){var r=i;return this.findEntryInChain_0(r,e)}var o=i;return this.equality.equals_oaftn8$(o.key,e)?o:null},wr.prototype.findEntryInChain_0=function(t,e){var n;t:do{var i;for(i=0;i!==t.length;++i){var r=t[i];if(this.equality.equals_oaftn8$(r.key,e)){n=r;break t}}n=null}while(0);return n},xr.prototype.computeNext_0=function(){if(null!=this.chainOrEntry&&this.isChain){var e=this.chainOrEntry.length;if(this.itemIndex=this.itemIndex+1|0,this.itemIndex=0&&(this.buffer=this.buffer+e.substring(0,n),this.flush(),e=e.substring(n+1|0)),this.buffer=this.buffer+e},qr.prototype.flush=function(){console.log(this.buffer),this.buffer=""},qr.$metadata$={kind:p,simpleName:"BufferedOutputToConsoleLog",interfaces:[Fr]},Object.defineProperty(Gr.prototype,"context",{configurable:!0,get:function(){return this.delegate_0.context}}),Gr.prototype.resumeWith_tl1gpc$=function(t){var e=this.result_0;if(e===Pu())this.result_0=t.value;else{if(e!==Su())throw Un("Already resumed");this.result_0=Au(),this.delegate_0.resumeWith_tl1gpc$(t)}},Gr.prototype.getOrThrow=function(){var e;if(this.result_0===Pu())return this.result_0=Su(),Su();var n=this.result_0;if(n===Au())e=Su();else{if(t.isType(n,op))throw n.exception;e=n}return e},Gr.$metadata$={kind:p,simpleName:"SafeContinuation",interfaces:[ou]},Object.defineProperty(Hr.prototype,"context",{configurable:!0,get:function(){return this.closure$context}}),Hr.prototype.resumeWith_tl1gpc$=function(t){this.closure$resumeWith(t)},Hr.$metadata$={kind:p,interfaces:[ou]},Kr.$metadata$={kind:g,simpleName:"Serializable",interfaces:[]},eo.$metadata$={kind:g,simpleName:"KCallable",interfaces:[]},no.$metadata$={kind:g,simpleName:"KClass",interfaces:[nc]},Object.defineProperty(io.prototype,"jClass",{get:function(){return this.jClass_1ppatx$_0}}),Object.defineProperty(io.prototype,"qualifiedName",{configurable:!0,get:function(){throw new lp}}),io.prototype.equals=function(e){return t.isType(e,io)&&o(this.jClass,e.jClass)},io.prototype.hashCode=function(){var t,e;return null!=(e=null!=(t=this.simpleName)?N(t):null)?e:0},io.prototype.toString=function(){return"class "+$(this.simpleName)},io.$metadata$={kind:p,simpleName:"KClassImpl",interfaces:[no]},Object.defineProperty(ro.prototype,"simpleName",{configurable:!0,get:function(){return this.simpleName_m7mxi0$_0}}),ro.prototype.isInstance_s8jyv4$=function(e){var n=this.jClass;return t.isType(e,n)},ro.$metadata$={kind:p,simpleName:"SimpleKClassImpl",interfaces:[io]},oo.prototype.equals=function(e){return!!t.isType(e,oo)&&io.prototype.equals.call(this,e)&&o(this.givenSimpleName_0,e.givenSimpleName_0)},Object.defineProperty(oo.prototype,"simpleName",{configurable:!0,get:function(){return this.givenSimpleName_0}}),oo.prototype.isInstance_s8jyv4$=function(t){return this.isInstanceFunction_0(t)},oo.$metadata$={kind:p,simpleName:"PrimitiveKClassImpl",interfaces:[io]},Object.defineProperty(ao.prototype,"simpleName",{configurable:!0,get:function(){return this.simpleName_lnzy73$_0}}),ao.prototype.isInstance_s8jyv4$=function(t){return!1},Object.defineProperty(ao.prototype,"jClass",{configurable:!0,get:function(){throw Hn("There's no native JS class for Nothing type")}}),ao.prototype.equals=function(t){return t===this},ao.prototype.hashCode=function(){return 0},ao.$metadata$={kind:b,simpleName:"NothingKClassImpl",interfaces:[io]};var so=null;function lo(){return null===so&&new ao,so}function uo(){}function co(){}function po(){}function ho(){}function _o(){}function fo(){}function mo(){}function yo(){}function $o(t,e,n){this.classifier_50lv52$_0=t,this.arguments_lev63t$_0=e,this.isMarkedNullable_748rxs$_0=n}function vo(e){switch(e.name){case"INVARIANT":return"";case"IN":return"in ";case"OUT":return"out ";default:return t.noWhenBranchMatched()}}function go(){qo=this,this.anyClass=new oo(Object,"Any",bo),this.numberClass=new oo(Number,"Number",wo),this.nothingClass=lo(),this.booleanClass=new oo(Boolean,"Boolean",xo),this.byteClass=new oo(Number,"Byte",ko),this.shortClass=new oo(Number,"Short",Eo),this.intClass=new oo(Number,"Int",Co),this.floatClass=new oo(Number,"Float",So),this.doubleClass=new oo(Number,"Double",To),this.arrayClass=new oo(Array,"Array",Oo),this.stringClass=new oo(String,"String",No),this.throwableClass=new oo(Error,"Throwable",Po),this.booleanArrayClass=new oo(Array,"BooleanArray",Ao),this.charArrayClass=new oo(Uint16Array,"CharArray",jo),this.byteArrayClass=new oo(Int8Array,"ByteArray",Lo),this.shortArrayClass=new oo(Int16Array,"ShortArray",Ro),this.intArrayClass=new oo(Int32Array,"IntArray",Io),this.longArrayClass=new oo(Array,"LongArray",zo),this.floatArrayClass=new oo(Float32Array,"FloatArray",Do),this.doubleArrayClass=new oo(Float64Array,"DoubleArray",Mo)}function bo(e){return t.isType(e,C)}function wo(e){return t.isNumber(e)}function xo(t){return"boolean"==typeof t}function ko(t){return"number"==typeof t}function Eo(t){return"number"==typeof t}function Co(t){return"number"==typeof t}function So(t){return"number"==typeof t}function To(t){return"number"==typeof t}function Oo(e){return t.isArray(e)}function No(t){return"string"==typeof t}function Po(e){return t.isType(e,T)}function Ao(e){return t.isBooleanArray(e)}function jo(e){return t.isCharArray(e)}function Lo(e){return t.isByteArray(e)}function Ro(e){return t.isShortArray(e)}function Io(e){return t.isIntArray(e)}function zo(e){return t.isLongArray(e)}function Do(e){return t.isFloatArray(e)}function Mo(e){return t.isDoubleArray(e)}Object.defineProperty(uo.prototype,"simpleName",{configurable:!0,get:function(){throw Un("Unknown simpleName for ErrorKClass".toString())}}),Object.defineProperty(uo.prototype,"qualifiedName",{configurable:!0,get:function(){throw Un("Unknown qualifiedName for ErrorKClass".toString())}}),uo.prototype.isInstance_s8jyv4$=function(t){throw Un("Can's check isInstance on ErrorKClass".toString())},uo.prototype.equals=function(t){return t===this},uo.prototype.hashCode=function(){return 0},uo.$metadata$={kind:p,simpleName:"ErrorKClass",interfaces:[no]},co.$metadata$={kind:g,simpleName:"KProperty",interfaces:[eo]},po.$metadata$={kind:g,simpleName:"KMutableProperty",interfaces:[co]},ho.$metadata$={kind:g,simpleName:"KProperty0",interfaces:[co]},_o.$metadata$={kind:g,simpleName:"KMutableProperty0",interfaces:[po,ho]},fo.$metadata$={kind:g,simpleName:"KProperty1",interfaces:[co]},mo.$metadata$={kind:g,simpleName:"KMutableProperty1",interfaces:[po,fo]},yo.$metadata$={kind:g,simpleName:"KType",interfaces:[]},Object.defineProperty($o.prototype,"classifier",{get:function(){return this.classifier_50lv52$_0}}),Object.defineProperty($o.prototype,"arguments",{get:function(){return this.arguments_lev63t$_0}}),Object.defineProperty($o.prototype,"isMarkedNullable",{get:function(){return this.isMarkedNullable_748rxs$_0}}),$o.prototype.equals=function(e){return t.isType(e,$o)&&o(this.classifier,e.classifier)&&o(this.arguments,e.arguments)&&this.isMarkedNullable===e.isMarkedNullable},$o.prototype.hashCode=function(){return(31*((31*N(this.classifier)|0)+N(this.arguments)|0)|0)+N(this.isMarkedNullable)|0},$o.prototype.toString=function(){var e,n,i=t.isType(e=this.classifier,no)?e:null;return(null==i?this.classifier.toString():null!=i.simpleName?i.simpleName:"(non-denotable type)")+(this.arguments.isEmpty()?"":St(this.arguments,", ","<",">",void 0,void 0,(n=this,function(t){return n.asString_0(t)})))+(this.isMarkedNullable?"?":"")},$o.prototype.asString_0=function(t){return null==t.variance?"*":vo(t.variance)+$(t.type)},$o.$metadata$={kind:p,simpleName:"KTypeImpl",interfaces:[yo]},go.prototype.functionClass=function(t){var e,n,i;if(null!=(e=Bo[t]))n=e;else{var r=new oo(Function,"Function"+t,(i=t,function(t){return"function"==typeof t&&t.length===i}));Bo[t]=r,n=r}return n},go.$metadata$={kind:b,simpleName:"PrimitiveClasses",interfaces:[]};var Bo,Uo,Fo,qo=null;function Go(){return null===qo&&new go,qo}function Ho(t){return Array.isArray(t)?Yo(t):Vo(t)}function Yo(t){switch(t.length){case 1:return Vo(t[0]);case 0:return lo();default:return new uo}}function Vo(t){var e;if(t===String)return Go().stringClass;var n=t.$metadata$;if(null!=n)if(null==n.$kClass$){var i=new ro(t);n.$kClass$=i,e=i}else e=n.$kClass$;else e=new ro(t);return e}function Ko(t){t.lastIndex=0}function Wo(){}function Xo(t){this.string_0=void 0!==t?t:""}function Zo(t,e){return Qo(e=e||Object.create(Xo.prototype)),e}function Jo(t,e){return e=e||Object.create(Xo.prototype),Xo.call(e,t.toString()),e}function Qo(t){return t=t||Object.create(Xo.prototype),Xo.call(t,""),t}function ta(t){var e=String.fromCharCode(t).toUpperCase();return e.length>1?t:e.charCodeAt(0)}function ea(t){return new Me(A.MIN_HIGH_SURROGATE,A.MAX_HIGH_SURROGATE).contains_mef7kx$(t)}function na(t){return new Me(A.MIN_LOW_SURROGATE,A.MAX_LOW_SURROGATE).contains_mef7kx$(t)}function ia(t){return vi(t)}function ra(t){switch(t.toLowerCase()){case"nan":case"+nan":case"-nan":return!0;default:return!1}}function oa(t){if(!(2<=t&&t<=36))throw Mn("radix "+t+" was not in valid range 2..36");return t}function aa(t,e){var n;return(n=t>=48&&t<=57?t-48:t>=65&&t<=90?t-65+10|0:t>=97&&t<=122?t-97+10|0:t<128?-1:t>=65313&&t<=65338?t-65313+10|0:t>=65345&&t<=65370?t-65345+10|0:$i(t))>=e?-1:n}function sa(t,e,n){x.call(this),this.value=n,this.name$=t,this.ordinal$=e}function la(){la=function(){},Uo=new sa("IGNORE_CASE",0,"i"),Fo=new sa("MULTILINE",1,"m")}function ua(){return la(),Uo}function ca(){return la(),Fo}function pa(t){this.value=t}function ha(t,e){ga(),this.pattern=t,this.options=xt(e),this.nativePattern_0=new RegExp(t,St(e,"","gu",void 0,void 0,void 0,ba))}function _a(t){return t.next()}function fa(){va=this,this.patternEscape_0=new RegExp("[\\\\^$*+?.()|[\\]{}]","g"),this.replacementEscape_0=new RegExp("\\$","g")}Wo.$metadata$={kind:g,simpleName:"Appendable",interfaces:[]},Object.defineProperty(Xo.prototype,"length",{configurable:!0,get:function(){return this.string_0.length}}),Xo.prototype.charCodeAt=function(t){var e=this.string_0;if(!(t>=0&&t<=gc(e)))throw new Fn("index: "+t+", length: "+this.length+"}");return e.charCodeAt(t)},Xo.prototype.subSequence_vux9f0$=function(t,e){return this.string_0.substring(t,e)},Xo.prototype.append_s8itvh$=function(t){return this.string_0+=String.fromCharCode(t),this},Xo.prototype.append_gw00v9$=function(t){return this.string_0+=$(t),this},Xo.prototype.append_ezbsdh$=function(t,e,n){return this.appendRange_3peag4$(null!=t?t:"null",e,n)},Xo.prototype.reverse=function(){for(var t,e,n="",i=this.string_0.length-1|0;i>=0;){var r=this.string_0.charCodeAt((i=(t=i)-1|0,t));if(na(r)&&i>=0){var o=this.string_0.charCodeAt((i=(e=i)-1|0,e));n=ea(o)?n+String.fromCharCode(a(o))+String.fromCharCode(a(r)):n+String.fromCharCode(a(r))+String.fromCharCode(a(o))}else n+=String.fromCharCode(r)}return this.string_0=n,this},Xo.prototype.append_s8jyv4$=function(t){return this.string_0+=$(t),this},Xo.prototype.append_6taknv$=function(t){return this.string_0+=t,this},Xo.prototype.append_4hbowm$=function(t){return this.string_0+=Sa(t),this},Xo.prototype.append_61zpoe$=function(t){return this.append_pdl1vj$(t)},Xo.prototype.append_pdl1vj$=function(t){return this.string_0=this.string_0+(null!=t?t:"null"),this},Xo.prototype.capacity=function(){return this.length},Xo.prototype.ensureCapacity_za3lpa$=function(t){},Xo.prototype.indexOf_61zpoe$=function(t){return this.string_0.indexOf(t)},Xo.prototype.indexOf_bm4lxs$=function(t,e){return this.string_0.indexOf(t,e)},Xo.prototype.lastIndexOf_61zpoe$=function(t){return this.string_0.lastIndexOf(t)},Xo.prototype.lastIndexOf_bm4lxs$=function(t,e){return 0===t.length&&e<0?-1:this.string_0.lastIndexOf(t,e)},Xo.prototype.insert_fzusl$=function(t,e){return Za().checkPositionIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+$(e)+this.string_0.substring(t),this},Xo.prototype.insert_6t1mh3$=function(t,e){return Za().checkPositionIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+String.fromCharCode(a(e))+this.string_0.substring(t),this},Xo.prototype.insert_7u455s$=function(t,e){return Za().checkPositionIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+Sa(e)+this.string_0.substring(t),this},Xo.prototype.insert_1u9bqd$=function(t,e){return Za().checkPositionIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+$(e)+this.string_0.substring(t),this},Xo.prototype.insert_6t2rgq$=function(t,e){return Za().checkPositionIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+$(e)+this.string_0.substring(t),this},Xo.prototype.insert_19mbxw$=function(t,e){return this.insert_vqvrqt$(t,e)},Xo.prototype.insert_vqvrqt$=function(t,e){Za().checkPositionIndex_6xvm5r$(t,this.length);var n=null!=e?e:"null";return this.string_0=this.string_0.substring(0,t)+n+this.string_0.substring(t),this},Xo.prototype.setLength_za3lpa$=function(t){if(t<0)throw Mn("Negative new length: "+t+".");if(t<=this.length)this.string_0=this.string_0.substring(0,t);else for(var e=this.length;en)throw new Fn("startIndex: "+t+", length: "+n);if(t>e)throw Mn("startIndex("+t+") > endIndex("+e+")")},Xo.prototype.deleteAt_za3lpa$=function(t){return Za().checkElementIndex_6xvm5r$(t,this.length),this.string_0=this.string_0.substring(0,t)+this.string_0.substring(t+1|0),this},Xo.prototype.deleteRange_vux9f0$=function(t,e){return this.checkReplaceRange_0(t,e,this.length),this.string_0=this.string_0.substring(0,t)+this.string_0.substring(e),this},Xo.prototype.toCharArray_pqkatk$=function(t,e,n,i){var r;void 0===e&&(e=0),void 0===n&&(n=0),void 0===i&&(i=this.length),Za().checkBoundsIndexes_cub51b$(n,i,this.length),Za().checkBoundsIndexes_cub51b$(e,e+i-n|0,t.length);for(var o=e,a=n;at.length)throw new Fn("Start index out of bounds: "+e+", input length: "+t.length);return Ca(this.nativePattern_0,t.toString(),e)},ha.prototype.findAll_905azu$=function(t,e){if(void 0===e&&(e=0),e<0||e>t.length)throw new Fn("Start index out of bounds: "+e+", input length: "+t.length);return Ll((n=t,i=e,r=this,function(){return r.find_905azu$(n,i)}),_a);var n,i,r},ha.prototype.matchEntire_6bul2c$=function(e){return kc(this.pattern,94)&&Ec(this.pattern,36)?this.find_905azu$(e):new ha("^"+_c(hc(this.pattern,t.charArrayOf(94)),t.charArrayOf(36))+"$",this.options).find_905azu$(e)},ha.prototype.replace_x2uqeu$=function(t,e){return t.toString().replace(this.nativePattern_0,e)},ha.prototype.replace_20wsma$=i("kotlin.kotlin.text.Regex.replace_20wsma$",r((function(){var n=e.kotlin.text.StringBuilder_init_za3lpa$,i=t.ensureNotNull;return function(t,e){var r=this.find_905azu$(t);if(null==r)return t.toString();var o=0,a=t.length,s=n(a);do{var l=i(r);s.append_ezbsdh$(t,o,l.range.start),s.append_gw00v9$(e(l)),o=l.range.endInclusive+1|0,r=l.next()}while(o=0))throw Mn(("Limit must be non-negative, but was "+n).toString());var r=this.findAll_905azu$(e),o=0===n?r:Mt(r,n-1|0),a=Ki(),s=0;for(i=o.iterator();i.hasNext();){var l=i.next();a.add_11rb$(t.subSequence(e,s,l.range.start).toString()),s=l.range.endInclusive+1|0}return a.add_11rb$(t.subSequence(e,s,e.length).toString()),a},ha.prototype.toString=function(){return this.nativePattern_0.toString()},fa.prototype.fromLiteral_61zpoe$=function(t){return wa(this.escape_61zpoe$(t))},fa.prototype.escape_61zpoe$=function(t){return t.replace(this.patternEscape_0,"\\$&")},fa.prototype.escapeReplacement_61zpoe$=function(t){return t.replace(this.replacementEscape_0,"$$$$")},fa.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var da,ma,ya,$a,va=null;function ga(){return null===va&&new fa,va}function ba(t){return t.value}function wa(t,e){return e=e||Object.create(ha.prototype),ha.call(e,t,Dl()),e}function xa(t,e,n,i){this.closure$match=t,this.this$findNext=e,this.closure$input=n,this.closure$range=i,this.range_co6b9w$_0=i,this.groups_qcaztb$_0=new Ea(t),this.groupValues__0=null}function ka(t){this.closure$match=t,Ha.call(this)}function Ea(t){this.closure$match=t,za.call(this)}function Ca(t,e,n){t.lastIndex=n;var i=t.exec(e);return null==i?null:new xa(i,t,e,new qe(i.index,t.lastIndex-1|0))}function Sa(t){var e,n="";for(e=0;e!==t.length;++e){var i=s(t[e]);n+=String.fromCharCode(i)}return n}function Ta(t,e,n){void 0===e&&(e=0),void 0===n&&(n=t.length),Za().checkBoundsIndexes_cub51b$(e,n,t.length);for(var i="",r=e;r0},Ka.prototype.nextIndex=function(){return this.index_0},Ka.prototype.previous=function(){if(!this.hasPrevious())throw Zn();return this.$outer.get_za3lpa$((this.index_0=this.index_0-1|0,this.index_0))},Ka.prototype.previousIndex=function(){return this.index_0-1|0},Ka.$metadata$={kind:p,simpleName:"ListIteratorImpl",interfaces:[_e,Va]},Wa.prototype.checkElementIndex_6xvm5r$=function(t,e){if(t<0||t>=e)throw new Fn("index: "+t+", size: "+e)},Wa.prototype.checkPositionIndex_6xvm5r$=function(t,e){if(t<0||t>e)throw new Fn("index: "+t+", size: "+e)},Wa.prototype.checkRangeIndexes_cub51b$=function(t,e,n){if(t<0||e>n)throw new Fn("fromIndex: "+t+", toIndex: "+e+", size: "+n);if(t>e)throw Mn("fromIndex: "+t+" > toIndex: "+e)},Wa.prototype.checkBoundsIndexes_cub51b$=function(t,e,n){if(t<0||e>n)throw new Fn("startIndex: "+t+", endIndex: "+e+", size: "+n);if(t>e)throw Mn("startIndex: "+t+" > endIndex: "+e)},Wa.prototype.orderedHashCode_nykoif$=function(t){var e,n,i=1;for(e=t.iterator();e.hasNext();){var r=e.next();i=(31*i|0)+(null!=(n=null!=r?N(r):null)?n:0)|0}return i},Wa.prototype.orderedEquals_e92ka7$=function(t,e){var n;if(t.size!==e.size)return!1;var i=e.iterator();for(n=t.iterator();n.hasNext();){var r=n.next(),a=i.next();if(!o(r,a))return!1}return!0},Wa.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Xa=null;function Za(){return null===Xa&&new Wa,Xa}function Ja(){os(),this._keys_up5z3z$_0=null,this._values_6nw1f1$_0=null}function Qa(t){this.this$AbstractMap=t,as.call(this)}function ts(t){this.closure$entryIterator=t}function es(t){this.this$AbstractMap=t,za.call(this)}function ns(t){this.closure$entryIterator=t}function is(){rs=this}Ha.$metadata$={kind:p,simpleName:"AbstractList",interfaces:[ie,za]},Ja.prototype.containsKey_11rb$=function(t){return null!=this.implFindEntry_8k1i24$_0(t)},Ja.prototype.containsValue_11rc$=function(e){var n,i=this.entries;t:do{var r;if(t.isType(i,ee)&&i.isEmpty()){n=!1;break t}for(r=i.iterator();r.hasNext();){var a=r.next();if(o(a.value,e)){n=!0;break t}}n=!1}while(0);return n},Ja.prototype.containsEntry_8hxqw4$=function(e){if(!t.isType(e,le))return!1;var n=e.key,i=e.value,r=(t.isType(this,se)?this:S()).get_11rb$(n);if(!o(i,r))return!1;var a=null==r;return a&&(a=!(t.isType(this,se)?this:S()).containsKey_11rb$(n)),!a},Ja.prototype.equals=function(e){if(e===this)return!0;if(!t.isType(e,se))return!1;if(this.size!==e.size)return!1;var n,i=e.entries;t:do{var r;if(t.isType(i,ee)&&i.isEmpty()){n=!0;break t}for(r=i.iterator();r.hasNext();){var o=r.next();if(!this.containsEntry_8hxqw4$(o)){n=!1;break t}}n=!0}while(0);return n},Ja.prototype.get_11rb$=function(t){var e;return null!=(e=this.implFindEntry_8k1i24$_0(t))?e.value:null},Ja.prototype.hashCode=function(){return N(this.entries)},Ja.prototype.isEmpty=function(){return 0===this.size},Object.defineProperty(Ja.prototype,"size",{configurable:!0,get:function(){return this.entries.size}}),Qa.prototype.contains_11rb$=function(t){return this.this$AbstractMap.containsKey_11rb$(t)},ts.prototype.hasNext=function(){return this.closure$entryIterator.hasNext()},ts.prototype.next=function(){return this.closure$entryIterator.next().key},ts.$metadata$={kind:p,interfaces:[pe]},Qa.prototype.iterator=function(){return new ts(this.this$AbstractMap.entries.iterator())},Object.defineProperty(Qa.prototype,"size",{configurable:!0,get:function(){return this.this$AbstractMap.size}}),Qa.$metadata$={kind:p,interfaces:[as]},Object.defineProperty(Ja.prototype,"keys",{configurable:!0,get:function(){return null==this._keys_up5z3z$_0&&(this._keys_up5z3z$_0=new Qa(this)),E(this._keys_up5z3z$_0)}}),Ja.prototype.toString=function(){return St(this.entries,", ","{","}",void 0,void 0,(t=this,function(e){return t.toString_55he67$_0(e)}));var t},Ja.prototype.toString_55he67$_0=function(t){return this.toString_kthv8s$_0(t.key)+"="+this.toString_kthv8s$_0(t.value)},Ja.prototype.toString_kthv8s$_0=function(t){return t===this?"(this Map)":$(t)},es.prototype.contains_11rb$=function(t){return this.this$AbstractMap.containsValue_11rc$(t)},ns.prototype.hasNext=function(){return this.closure$entryIterator.hasNext()},ns.prototype.next=function(){return this.closure$entryIterator.next().value},ns.$metadata$={kind:p,interfaces:[pe]},es.prototype.iterator=function(){return new ns(this.this$AbstractMap.entries.iterator())},Object.defineProperty(es.prototype,"size",{configurable:!0,get:function(){return this.this$AbstractMap.size}}),es.$metadata$={kind:p,interfaces:[za]},Object.defineProperty(Ja.prototype,"values",{configurable:!0,get:function(){return null==this._values_6nw1f1$_0&&(this._values_6nw1f1$_0=new es(this)),E(this._values_6nw1f1$_0)}}),Ja.prototype.implFindEntry_8k1i24$_0=function(t){var e,n=this.entries;t:do{var i;for(i=n.iterator();i.hasNext();){var r=i.next();if(o(r.key,t)){e=r;break t}}e=null}while(0);return e},is.prototype.entryHashCode_9fthdn$=function(t){var e,n,i,r;return(null!=(n=null!=(e=t.key)?N(e):null)?n:0)^(null!=(r=null!=(i=t.value)?N(i):null)?r:0)},is.prototype.entryToString_9fthdn$=function(t){return $(t.key)+"="+$(t.value)},is.prototype.entryEquals_js7fox$=function(e,n){return!!t.isType(n,le)&&o(e.key,n.key)&&o(e.value,n.value)},is.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var rs=null;function os(){return null===rs&&new is,rs}function as(){us(),za.call(this)}function ss(){ls=this}Ja.$metadata$={kind:p,simpleName:"AbstractMap",interfaces:[se]},as.prototype.equals=function(e){return e===this||!!t.isType(e,oe)&&us().setEquals_y8f7en$(this,e)},as.prototype.hashCode=function(){return us().unorderedHashCode_nykoif$(this)},ss.prototype.unorderedHashCode_nykoif$=function(t){var e,n=0;for(e=t.iterator();e.hasNext();){var i,r=e.next();n=n+(null!=(i=null!=r?N(r):null)?i:0)|0}return n},ss.prototype.setEquals_y8f7en$=function(t,e){return t.size===e.size&&t.containsAll_brywnq$(e)},ss.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var ls=null;function us(){return null===ls&&new ss,ls}function cs(){ps=this}as.$metadata$={kind:p,simpleName:"AbstractSet",interfaces:[oe,za]},cs.prototype.hasNext=function(){return!1},cs.prototype.hasPrevious=function(){return!1},cs.prototype.nextIndex=function(){return 0},cs.prototype.previousIndex=function(){return-1},cs.prototype.next=function(){throw Zn()},cs.prototype.previous=function(){throw Zn()},cs.$metadata$={kind:b,simpleName:"EmptyIterator",interfaces:[_e]};var ps=null;function hs(){return null===ps&&new cs,ps}function _s(){fs=this,this.serialVersionUID_0=j}_s.prototype.equals=function(e){return t.isType(e,ie)&&e.isEmpty()},_s.prototype.hashCode=function(){return 1},_s.prototype.toString=function(){return"[]"},Object.defineProperty(_s.prototype,"size",{configurable:!0,get:function(){return 0}}),_s.prototype.isEmpty=function(){return!0},_s.prototype.contains_11rb$=function(t){return!1},_s.prototype.containsAll_brywnq$=function(t){return t.isEmpty()},_s.prototype.get_za3lpa$=function(t){throw new Fn("Empty list doesn't contain element at index "+t+".")},_s.prototype.indexOf_11rb$=function(t){return-1},_s.prototype.lastIndexOf_11rb$=function(t){return-1},_s.prototype.iterator=function(){return hs()},_s.prototype.listIterator=function(){return hs()},_s.prototype.listIterator_za3lpa$=function(t){if(0!==t)throw new Fn("Index: "+t);return hs()},_s.prototype.subList_vux9f0$=function(t,e){if(0===t&&0===e)return this;throw new Fn("fromIndex: "+t+", toIndex: "+e)},_s.prototype.readResolve_0=function(){return ds()},_s.$metadata$={kind:b,simpleName:"EmptyList",interfaces:[Mr,Kr,ie]};var fs=null;function ds(){return null===fs&&new _s,fs}function ms(t){return new ys(t,!1)}function ys(t,e){this.values=t,this.isVarargs=e}function $s(){return ds()}function vs(t){return t.length>0?ai(t):$s()}function gs(t){return 0===t.length?Ki():Xi(new ys(t,!0))}function bs(t){return new qe(0,t.size-1|0)}function ws(t){return t.size-1|0}function xs(t){switch(t.size){case 0:return $s();case 1:return ki(t.get_za3lpa$(0));default:return t}}function ks(t,e,n){if(e>n)throw Mn("fromIndex ("+e+") is greater than toIndex ("+n+").");if(e<0)throw new Fn("fromIndex ("+e+") is less than zero.");if(n>t)throw new Fn("toIndex ("+n+") is greater than size ("+t+").")}function Es(){throw new Jn("Index overflow has happened.")}function Cs(){throw new Jn("Count overflow has happened.")}function Ss(){}function Ts(t,e){this.index=t,this.value=e}function Os(t){this.iteratorFactory_0=t}function Ns(e){return t.isType(e,ee)?e.size:null}function Ps(e,n){return t.isType(e,ee)?e.size:n}function As(e,n){return t.isType(e,oe)?e:t.isType(e,ee)?t.isType(n,ee)&&n.size<2?e:function(e){return e.size>2&&t.isType(e,Vi)}(e)?vt(e):e:vt(e)}function js(t){this.iterator_0=t,this.index_0=0}function Ls(e,n){if(t.isType(e,Rs))return e.getOrImplicitDefault_11rb$(n);var i,r=e.get_11rb$(n);if(null==r&&!e.containsKey_11rb$(n))throw new Xn("Key "+n+" is missing in the map.");return null==(i=r)||t.isType(i,C)?i:S()}function Rs(){}function Is(){}function zs(t,e){this.map_a09uzx$_0=t,this.default_0=e}function Ds(){Ms=this,this.serialVersionUID_0=L}Object.defineProperty(ys.prototype,"size",{configurable:!0,get:function(){return this.values.length}}),ys.prototype.isEmpty=function(){return 0===this.values.length},ys.prototype.contains_11rb$=function(t){return B(this.values,t)},ys.prototype.containsAll_brywnq$=function(e){var n;t:do{var i;if(t.isType(e,ee)&&e.isEmpty()){n=!0;break t}for(i=e.iterator();i.hasNext();){var r=i.next();if(!this.contains_11rb$(r)){n=!1;break t}}n=!0}while(0);return n},ys.prototype.iterator=function(){return t.arrayIterator(this.values)},ys.prototype.toArray=function(){var t=this.values;return this.isVarargs?t:t.slice()},ys.$metadata$={kind:p,simpleName:"ArrayAsCollection",interfaces:[ee]},Ss.$metadata$={kind:g,simpleName:"Grouping",interfaces:[]},Ts.$metadata$={kind:p,simpleName:"IndexedValue",interfaces:[]},Ts.prototype.component1=function(){return this.index},Ts.prototype.component2=function(){return this.value},Ts.prototype.copy_wxm5ur$=function(t,e){return new Ts(void 0===t?this.index:t,void 0===e?this.value:e)},Ts.prototype.toString=function(){return"IndexedValue(index="+t.toString(this.index)+", value="+t.toString(this.value)+")"},Ts.prototype.hashCode=function(){var e=0;return 31*(e=31*e+t.hashCode(this.index)|0)+t.hashCode(this.value)|0},Ts.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.index,e.index)&&t.equals(this.value,e.value)},Os.prototype.iterator=function(){return new js(this.iteratorFactory_0())},Os.$metadata$={kind:p,simpleName:"IndexingIterable",interfaces:[Qt]},js.prototype.hasNext=function(){return this.iterator_0.hasNext()},js.prototype.next=function(){var t;return new Ts(Pi((t=this.index_0,this.index_0=t+1|0,t)),this.iterator_0.next())},js.$metadata$={kind:p,simpleName:"IndexingIterator",interfaces:[pe]},Rs.$metadata$={kind:g,simpleName:"MapWithDefault",interfaces:[se]},Ds.prototype.equals=function(e){return t.isType(e,se)&&e.isEmpty()},Ds.prototype.hashCode=function(){return 0},Ds.prototype.toString=function(){return"{}"},Object.defineProperty(Ds.prototype,"size",{configurable:!0,get:function(){return 0}}),Ds.prototype.isEmpty=function(){return!0},Ds.prototype.containsKey_11rb$=function(t){return!1},Ds.prototype.containsValue_11rc$=function(t){return!1},Ds.prototype.get_11rb$=function(t){return null},Object.defineProperty(Ds.prototype,"entries",{configurable:!0,get:function(){return zl()}}),Object.defineProperty(Ds.prototype,"keys",{configurable:!0,get:function(){return zl()}}),Object.defineProperty(Ds.prototype,"values",{configurable:!0,get:function(){return ds()}}),Ds.prototype.readResolve_0=function(){return Bs()},Ds.$metadata$={kind:b,simpleName:"EmptyMap",interfaces:[Kr,se]};var Ms=null;function Bs(){return null===Ms&&new Ds,Ms}function Us(){var e;return t.isType(e=Bs(),se)?e:Yr()}function Fs(t){var e=mr(t.length);return qs(e,t),e}function qs(t,e){var n;for(n=0;n!==e.length;++n){var i=e[n],r=i.component1(),o=i.component2();t.put_xwzc9p$(r,o)}}function Gs(t,e){var n;for(n=e.iterator();n.hasNext();){var i=n.next(),r=i.component1(),o=i.component2();t.put_xwzc9p$(r,o)}}function Hs(t,e){return Gs(e,t),e}function Ys(t,e){return qs(e,t),e}function Vs(t){return jr(t)}function Ks(t){switch(t.size){case 0:return Us();case 1:default:return t}}function Ws(e,n){var i;if(t.isType(n,ee))return e.addAll_brywnq$(n);var r=!1;for(i=n.iterator();i.hasNext();){var o=i.next();e.add_11rb$(o)&&(r=!0)}return r}function Xs(e,n){var i,r=As(n,e);return(t.isType(i=e,ne)?i:S()).removeAll_brywnq$(r)}function Zs(e,n){var i,r=As(n,e);return(t.isType(i=e,ne)?i:S()).retainAll_brywnq$(r)}function Js(t,e){return Qs(t,e,!0)}function Qs(t,e,n){for(var i={v:!1},r=t.iterator();r.hasNext();)e(r.next())===n&&(r.remove(),i.v=!0);return i.v}function tl(e,n){return function(e,n,i){var r,o,a;if(!t.isType(e,Mr))return Qs(t.isType(r=e,te)?r:Yr(),n,i);var s=0;o=ws(e);for(var l=0;l<=o;l++){var u=e.get_za3lpa$(l);n(u)!==i&&(s!==l&&e.set_wxm5ur$(s,u),s=s+1|0)}if(s=a;c--)e.removeAt_za3lpa$(c);return!0}return!1}(e,n,!0)}function el(t){Ha.call(this),this.delegate_0=t}function nl(){}function il(t){this.closure$iterator=t}function rl(t){var e=new al;return e.nextStep=Pn(t,e,e),e}function ol(){}function al(){ol.call(this),this.state_0=0,this.nextValue_0=null,this.nextIterator_0=null,this.nextStep=null}function sl(t){return 0===t.length?ll():it(t)}function ll(){return pl()}function ul(){cl=this}Object.defineProperty(el.prototype,"size",{configurable:!0,get:function(){return this.delegate_0.size}}),el.prototype.get_za3lpa$=function(t){return this.delegate_0.get_za3lpa$(function(t,e){var n;if(n=ws(t),0<=e&&e<=n)return ws(t)-e|0;throw new Fn("Element index "+e+" must be in range ["+new qe(0,ws(t))+"].")}(this,t))},el.$metadata$={kind:p,simpleName:"ReversedListReadOnly",interfaces:[Ha]},nl.$metadata$={kind:g,simpleName:"Sequence",interfaces:[]},il.prototype.iterator=function(){return this.closure$iterator()},il.$metadata$={kind:p,interfaces:[nl]},ol.prototype.yieldAll_p1ys8y$=function(e,n){if(!t.isType(e,ee)||!e.isEmpty())return this.yieldAll_1phuh2$(e.iterator(),n)},ol.prototype.yieldAll_swo9gw$=function(t,e){return this.yieldAll_1phuh2$(t.iterator(),e)},ol.$metadata$={kind:p,simpleName:"SequenceScope",interfaces:[]},al.prototype.hasNext=function(){for(;;){switch(this.state_0){case 0:break;case 1:if(E(this.nextIterator_0).hasNext())return this.state_0=2,!0;this.nextIterator_0=null;break;case 4:return!1;case 3:case 2:return!0;default:throw this.exceptionalState_0()}this.state_0=5;var t=E(this.nextStep);this.nextStep=null,t.resumeWith_tl1gpc$(new ep(Qe()))}},al.prototype.next=function(){var e;switch(this.state_0){case 0:case 1:return this.nextNotReady_0();case 2:return this.state_0=1,E(this.nextIterator_0).next();case 3:this.state_0=0;var n=null==(e=this.nextValue_0)||t.isType(e,C)?e:Yr();return this.nextValue_0=null,n;default:throw this.exceptionalState_0()}},al.prototype.nextNotReady_0=function(){if(this.hasNext())return this.next();throw Zn()},al.prototype.exceptionalState_0=function(){switch(this.state_0){case 4:return Zn();case 5:return Un("Iterator has failed.");default:return Un("Unexpected state of the iterator: "+this.state_0)}},al.prototype.yield_11rb$=function(t,e){return this.nextValue_0=t,this.state_0=3,(n=this,function(t){return n.nextStep=t,Su()})(e);var n},al.prototype.yieldAll_1phuh2$=function(t,e){if(t.hasNext())return this.nextIterator_0=t,this.state_0=2,(n=this,function(t){return n.nextStep=t,Su()})(e);var n},al.prototype.resumeWith_tl1gpc$=function(e){var n;sp(e),null==(n=e.value)||t.isType(n,C)||S(),this.state_0=4},Object.defineProperty(al.prototype,"context",{configurable:!0,get:function(){return $u()}}),al.$metadata$={kind:p,simpleName:"SequenceBuilderIterator",interfaces:[ou,pe,ol]},ul.prototype.iterator=function(){return hs()},ul.prototype.drop_za3lpa$=function(t){return pl()},ul.prototype.take_za3lpa$=function(t){return pl()},ul.$metadata$={kind:b,simpleName:"EmptySequence",interfaces:[El,nl]};var cl=null;function pl(){return null===cl&&new ul,cl}function hl(t){return t.iterator()}function _l(t){return ml(t,hl)}function fl(t){return t.iterator()}function dl(t){return t}function ml(e,n){var i;return t.isType(e,vl)?(t.isType(i=e,vl)?i:Yr()).flatten_1tglza$(n):new xl(e,dl,n)}function yl(t,e,n){void 0===e&&(e=!0),this.sequence_0=t,this.sendWhen_0=e,this.predicate_0=n}function $l(t){this.this$FilteringSequence=t,this.iterator=t.sequence_0.iterator(),this.nextState=-1,this.nextItem=null}function vl(t,e){this.sequence_0=t,this.transformer_0=e}function gl(t){this.this$TransformingSequence=t,this.iterator=t.sequence_0.iterator()}function bl(t,e,n){this.sequence1_0=t,this.sequence2_0=e,this.transform_0=n}function wl(t){this.this$MergingSequence=t,this.iterator1=t.sequence1_0.iterator(),this.iterator2=t.sequence2_0.iterator()}function xl(t,e,n){this.sequence_0=t,this.transformer_0=e,this.iterator_0=n}function kl(t){this.this$FlatteningSequence=t,this.iterator=t.sequence_0.iterator(),this.itemIterator=null}function El(){}function Cl(t,e,n){if(this.sequence_0=t,this.startIndex_0=e,this.endIndex_0=n,!(this.startIndex_0>=0))throw Mn(("startIndex should be non-negative, but is "+this.startIndex_0).toString());if(!(this.endIndex_0>=0))throw Mn(("endIndex should be non-negative, but is "+this.endIndex_0).toString());if(!(this.endIndex_0>=this.startIndex_0))throw Mn(("endIndex should be not less than startIndex, but was "+this.endIndex_0+" < "+this.startIndex_0).toString())}function Sl(t){this.this$SubSequence=t,this.iterator=t.sequence_0.iterator(),this.position=0}function Tl(t,e){if(this.sequence_0=t,this.count_0=e,!(this.count_0>=0))throw Mn(("count must be non-negative, but was "+this.count_0+".").toString())}function Ol(t){this.left=t.count_0,this.iterator=t.sequence_0.iterator()}function Nl(t,e){if(this.sequence_0=t,this.count_0=e,!(this.count_0>=0))throw Mn(("count must be non-negative, but was "+this.count_0+".").toString())}function Pl(t){this.iterator=t.sequence_0.iterator(),this.left=t.count_0}function Al(t,e){this.getInitialValue_0=t,this.getNextValue_0=e}function jl(t){this.this$GeneratorSequence=t,this.nextItem=null,this.nextState=-2}function Ll(t,e){return new Al(t,e)}function Rl(){Il=this,this.serialVersionUID_0=R}$l.prototype.calcNext_0=function(){for(;this.iterator.hasNext();){var t=this.iterator.next();if(this.this$FilteringSequence.predicate_0(t)===this.this$FilteringSequence.sendWhen_0)return this.nextItem=t,void(this.nextState=1)}this.nextState=0},$l.prototype.next=function(){var e;if(-1===this.nextState&&this.calcNext_0(),0===this.nextState)throw Zn();var n=this.nextItem;return this.nextItem=null,this.nextState=-1,null==(e=n)||t.isType(e,C)?e:Yr()},$l.prototype.hasNext=function(){return-1===this.nextState&&this.calcNext_0(),1===this.nextState},$l.$metadata$={kind:p,interfaces:[pe]},yl.prototype.iterator=function(){return new $l(this)},yl.$metadata$={kind:p,simpleName:"FilteringSequence",interfaces:[nl]},gl.prototype.next=function(){return this.this$TransformingSequence.transformer_0(this.iterator.next())},gl.prototype.hasNext=function(){return this.iterator.hasNext()},gl.$metadata$={kind:p,interfaces:[pe]},vl.prototype.iterator=function(){return new gl(this)},vl.prototype.flatten_1tglza$=function(t){return new xl(this.sequence_0,this.transformer_0,t)},vl.$metadata$={kind:p,simpleName:"TransformingSequence",interfaces:[nl]},wl.prototype.next=function(){return this.this$MergingSequence.transform_0(this.iterator1.next(),this.iterator2.next())},wl.prototype.hasNext=function(){return this.iterator1.hasNext()&&this.iterator2.hasNext()},wl.$metadata$={kind:p,interfaces:[pe]},bl.prototype.iterator=function(){return new wl(this)},bl.$metadata$={kind:p,simpleName:"MergingSequence",interfaces:[nl]},kl.prototype.next=function(){if(!this.ensureItemIterator_0())throw Zn();return E(this.itemIterator).next()},kl.prototype.hasNext=function(){return this.ensureItemIterator_0()},kl.prototype.ensureItemIterator_0=function(){var t;for(!1===(null!=(t=this.itemIterator)?t.hasNext():null)&&(this.itemIterator=null);null==this.itemIterator;){if(!this.iterator.hasNext())return!1;var e=this.iterator.next(),n=this.this$FlatteningSequence.iterator_0(this.this$FlatteningSequence.transformer_0(e));if(n.hasNext())return this.itemIterator=n,!0}return!0},kl.$metadata$={kind:p,interfaces:[pe]},xl.prototype.iterator=function(){return new kl(this)},xl.$metadata$={kind:p,simpleName:"FlatteningSequence",interfaces:[nl]},El.$metadata$={kind:g,simpleName:"DropTakeSequence",interfaces:[nl]},Object.defineProperty(Cl.prototype,"count_0",{configurable:!0,get:function(){return this.endIndex_0-this.startIndex_0|0}}),Cl.prototype.drop_za3lpa$=function(t){return t>=this.count_0?ll():new Cl(this.sequence_0,this.startIndex_0+t|0,this.endIndex_0)},Cl.prototype.take_za3lpa$=function(t){return t>=this.count_0?this:new Cl(this.sequence_0,this.startIndex_0,this.startIndex_0+t|0)},Sl.prototype.drop_0=function(){for(;this.position=this.this$SubSequence.endIndex_0)throw Zn();return this.position=this.position+1|0,this.iterator.next()},Sl.$metadata$={kind:p,interfaces:[pe]},Cl.prototype.iterator=function(){return new Sl(this)},Cl.$metadata$={kind:p,simpleName:"SubSequence",interfaces:[El,nl]},Tl.prototype.drop_za3lpa$=function(t){return t>=this.count_0?ll():new Cl(this.sequence_0,t,this.count_0)},Tl.prototype.take_za3lpa$=function(t){return t>=this.count_0?this:new Tl(this.sequence_0,t)},Ol.prototype.next=function(){if(0===this.left)throw Zn();return this.left=this.left-1|0,this.iterator.next()},Ol.prototype.hasNext=function(){return this.left>0&&this.iterator.hasNext()},Ol.$metadata$={kind:p,interfaces:[pe]},Tl.prototype.iterator=function(){return new Ol(this)},Tl.$metadata$={kind:p,simpleName:"TakeSequence",interfaces:[El,nl]},Nl.prototype.drop_za3lpa$=function(t){var e=this.count_0+t|0;return e<0?new Nl(this,t):new Nl(this.sequence_0,e)},Nl.prototype.take_za3lpa$=function(t){var e=this.count_0+t|0;return e<0?new Tl(this,t):new Cl(this.sequence_0,this.count_0,e)},Pl.prototype.drop_0=function(){for(;this.left>0&&this.iterator.hasNext();)this.iterator.next(),this.left=this.left-1|0},Pl.prototype.next=function(){return this.drop_0(),this.iterator.next()},Pl.prototype.hasNext=function(){return this.drop_0(),this.iterator.hasNext()},Pl.$metadata$={kind:p,interfaces:[pe]},Nl.prototype.iterator=function(){return new Pl(this)},Nl.$metadata$={kind:p,simpleName:"DropSequence",interfaces:[El,nl]},jl.prototype.calcNext_0=function(){this.nextItem=-2===this.nextState?this.this$GeneratorSequence.getInitialValue_0():this.this$GeneratorSequence.getNextValue_0(E(this.nextItem)),this.nextState=null==this.nextItem?0:1},jl.prototype.next=function(){var e;if(this.nextState<0&&this.calcNext_0(),0===this.nextState)throw Zn();var n=t.isType(e=this.nextItem,C)?e:Yr();return this.nextState=-1,n},jl.prototype.hasNext=function(){return this.nextState<0&&this.calcNext_0(),1===this.nextState},jl.$metadata$={kind:p,interfaces:[pe]},Al.prototype.iterator=function(){return new jl(this)},Al.$metadata$={kind:p,simpleName:"GeneratorSequence",interfaces:[nl]},Rl.prototype.equals=function(e){return t.isType(e,oe)&&e.isEmpty()},Rl.prototype.hashCode=function(){return 0},Rl.prototype.toString=function(){return"[]"},Object.defineProperty(Rl.prototype,"size",{configurable:!0,get:function(){return 0}}),Rl.prototype.isEmpty=function(){return!0},Rl.prototype.contains_11rb$=function(t){return!1},Rl.prototype.containsAll_brywnq$=function(t){return t.isEmpty()},Rl.prototype.iterator=function(){return hs()},Rl.prototype.readResolve_0=function(){return zl()},Rl.$metadata$={kind:b,simpleName:"EmptySet",interfaces:[Kr,oe]};var Il=null;function zl(){return null===Il&&new Rl,Il}function Dl(){return zl()}function Ml(t){return J(t,gr(t.length))}function Bl(t){switch(t.size){case 0:return Dl();case 1:return Ei(t.iterator().next());default:return t}}function Ul(t){this.closure$iterator=t}function Fl(t,e){if(!(t>0&&e>0))throw Mn((t!==e?"Both size "+t+" and step "+e+" must be greater than zero.":"size "+t+" must be greater than zero.").toString())}function ql(t,e,n,i,r){return Fl(e,n),new Ul((o=t,a=e,s=n,l=i,u=r,function(){return Hl(o.iterator(),a,s,l,u)}));var o,a,s,l,u}function Gl(t,e,n,i,r,o,a,s){En.call(this,s),this.$controller=a,this.exceptionState_0=1,this.local$closure$size=t,this.local$closure$step=e,this.local$closure$iterator=n,this.local$closure$reuseBuffer=i,this.local$closure$partialWindows=r,this.local$tmp$=void 0,this.local$tmp$_0=void 0,this.local$gap=void 0,this.local$buffer=void 0,this.local$skip=void 0,this.local$e=void 0,this.local$buffer_0=void 0,this.local$$receiver=o}function Hl(t,e,n,i,r){return t.hasNext()?rl((o=e,a=n,s=t,l=r,u=i,function(t,e,n){var i=new Gl(o,a,s,l,u,t,this,e);return n?i:i.doResume(null)})):hs();var o,a,s,l,u}function Yl(t,e){if(Ha.call(this),this.buffer_0=t,!(e>=0))throw Mn(("ring buffer filled size should not be negative but it is "+e).toString());if(!(e<=this.buffer_0.length))throw Mn(("ring buffer filled size: "+e+" cannot be larger than the buffer size: "+this.buffer_0.length).toString());this.capacity_0=this.buffer_0.length,this.startIndex_0=0,this.size_4goa01$_0=e}function Vl(t){this.this$RingBuffer=t,Ga.call(this),this.count_0=t.size,this.index_0=t.startIndex_0}function Kl(e,n){var i;return e===n?0:null==e?-1:null==n?1:t.compareTo(t.isComparable(i=e)?i:Yr(),n)}function Wl(t){return function(e,n){return function(t,e,n){var i;for(i=0;i!==n.length;++i){var r=n[i],o=Kl(r(t),r(e));if(0!==o)return o}return 0}(e,n,t)}}function Xl(){var e;return t.isType(e=eu(),gi)?e:Yr()}function Zl(){var e;return t.isType(e=ru(),gi)?e:Yr()}function Jl(t){this.comparator=t}function Ql(){tu=this}Ul.prototype.iterator=function(){return this.closure$iterator()},Ul.$metadata$={kind:p,interfaces:[nl]},Gl.$metadata$={kind:t.Kind.CLASS,simpleName:null,interfaces:[En]},Gl.prototype=Object.create(En.prototype),Gl.prototype.constructor=Gl,Gl.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var e=jt(this.local$closure$size,1024);if(this.local$gap=this.local$closure$step-this.local$closure$size|0,this.local$gap>=0){this.local$buffer=Wi(e),this.local$skip=0,this.local$tmp$=this.local$closure$iterator,this.state_0=13;continue}this.local$buffer_0=(i=e,r=(r=void 0)||Object.create(Yl.prototype),Yl.call(r,t.newArray(i,null),0),r),this.local$tmp$_0=this.local$closure$iterator,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(!this.local$tmp$_0.hasNext()){this.state_0=6;continue}var n=this.local$tmp$_0.next();if(this.local$buffer_0.add_11rb$(n),this.local$buffer_0.isFull()){if(this.local$buffer_0.size0){this.local$skip=this.local$skip-1|0,this.state_0=13;continue}this.state_0=14;continue;case 14:if(this.local$buffer.add_11rb$(this.local$e),this.local$buffer.size===this.local$closure$size){if(this.state_0=15,this.result_0=this.local$$receiver.yield_11rb$(this.local$buffer,this),this.result_0===Su())return Su();continue}this.state_0=16;continue;case 15:this.local$closure$reuseBuffer?this.local$buffer.clear():this.local$buffer=Wi(this.local$closure$size),this.local$skip=this.local$gap,this.state_0=16;continue;case 16:this.state_0=13;continue;case 17:if(this.local$buffer.isEmpty()){this.state_0=20;continue}if(this.local$closure$partialWindows||this.local$buffer.size===this.local$closure$size){if(this.state_0=18,this.result_0=this.local$$receiver.yield_11rb$(this.local$buffer,this),this.result_0===Su())return Su();continue}this.state_0=19;continue;case 18:return Ze;case 19:this.state_0=20;continue;case 20:this.state_0=21;continue;case 21:return Ze;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}var i,r},Object.defineProperty(Yl.prototype,"size",{configurable:!0,get:function(){return this.size_4goa01$_0},set:function(t){this.size_4goa01$_0=t}}),Yl.prototype.get_za3lpa$=function(e){var n;return Za().checkElementIndex_6xvm5r$(e,this.size),null==(n=this.buffer_0[(this.startIndex_0+e|0)%this.capacity_0])||t.isType(n,C)?n:Yr()},Yl.prototype.isFull=function(){return this.size===this.capacity_0},Vl.prototype.computeNext=function(){var e;0===this.count_0?this.done():(this.setNext_11rb$(null==(e=this.this$RingBuffer.buffer_0[this.index_0])||t.isType(e,C)?e:Yr()),this.index_0=(this.index_0+1|0)%this.this$RingBuffer.capacity_0,this.count_0=this.count_0-1|0)},Vl.$metadata$={kind:p,interfaces:[Ga]},Yl.prototype.iterator=function(){return new Vl(this)},Yl.prototype.toArray_ro6dgy$=function(e){for(var n,i,r,o,a=e.lengththis.size&&(a[this.size]=null),t.isArray(o=a)?o:Yr()},Yl.prototype.toArray=function(){return this.toArray_ro6dgy$(t.newArray(this.size,null))},Yl.prototype.expanded_za3lpa$=function(e){var n=jt(this.capacity_0+(this.capacity_0>>1)+1|0,e);return new Yl(0===this.startIndex_0?si(this.buffer_0,n):this.toArray_ro6dgy$(t.newArray(n,null)),this.size)},Yl.prototype.add_11rb$=function(t){if(this.isFull())throw Un("ring buffer is full");this.buffer_0[(this.startIndex_0+this.size|0)%this.capacity_0]=t,this.size=this.size+1|0},Yl.prototype.removeFirst_za3lpa$=function(t){if(!(t>=0))throw Mn(("n shouldn't be negative but it is "+t).toString());if(!(t<=this.size))throw Mn(("n shouldn't be greater than the buffer size: n = "+t+", size = "+this.size).toString());if(t>0){var e=this.startIndex_0,n=(e+t|0)%this.capacity_0;e>n?(ui(this.buffer_0,null,e,this.capacity_0),ui(this.buffer_0,null,0,n)):ui(this.buffer_0,null,e,n),this.startIndex_0=n,this.size=this.size-t|0}},Yl.prototype.forward_0=function(t,e){return(t+e|0)%this.capacity_0},Yl.$metadata$={kind:p,simpleName:"RingBuffer",interfaces:[Mr,Ha]},Jl.prototype.compare=function(t,e){return this.comparator.compare(e,t)},Jl.prototype.reversed=function(){return this.comparator},Jl.$metadata$={kind:p,simpleName:"ReversedComparator",interfaces:[gi]},Ql.prototype.compare=function(e,n){return t.compareTo(e,n)},Ql.prototype.reversed=function(){return ru()},Ql.$metadata$={kind:b,simpleName:"NaturalOrderComparator",interfaces:[gi]};var tu=null;function eu(){return null===tu&&new Ql,tu}function nu(){iu=this}nu.prototype.compare=function(e,n){return t.compareTo(n,e)},nu.prototype.reversed=function(){return eu()},nu.$metadata$={kind:b,simpleName:"ReverseOrderComparator",interfaces:[gi]};var iu=null;function ru(){return null===iu&&new nu,iu}function ou(){}function au(){uu()}function su(){lu=this}ou.$metadata$={kind:g,simpleName:"Continuation",interfaces:[]},i("kotlin.kotlin.coroutines.suspendCoroutine_922awp$",r((function(){var n=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,i=e.kotlin.coroutines.SafeContinuation_init_wj8d80$;return function(e,r){return t.suspendCall((o=e,function(t){var e=i(n(t));return o(e),e.getOrThrow()})(t.coroutineReceiver())),t.coroutineResult(t.coroutineReceiver());var o}}))),su.$metadata$={kind:b,simpleName:"Key",interfaces:[hu]};var lu=null;function uu(){return null===lu&&new su,lu}function cu(){}function pu(t,e){var n=t.minusKey_yeqjby$(e.key);if(n===$u())return e;var i=n.get_j3r2sn$(uu());if(null==i)return new vu(n,e);var r=n.minusKey_yeqjby$(uu());return r===$u()?new vu(e,i):new vu(new vu(r,e),i)}function hu(){}function _u(){}function fu(t){this.key_no4tas$_0=t}function du(e,n){this.safeCast_9rw4bk$_0=n,this.topmostKey_3x72pn$_0=t.isType(e,du)?e.topmostKey_3x72pn$_0:e}function mu(){yu=this,this.serialVersionUID_0=u}au.prototype.releaseInterceptedContinuation_k98bjh$=function(t){},au.prototype.get_j3r2sn$=function(e){var n;return t.isType(e,du)?e.isSubKey_i2ksv9$(this.key)&&t.isType(n=e.tryCast_m1180o$(this),_u)?n:null:uu()===e?t.isType(this,_u)?this:Yr():null},au.prototype.minusKey_yeqjby$=function(e){return t.isType(e,du)?e.isSubKey_i2ksv9$(this.key)&&null!=e.tryCast_m1180o$(this)?$u():this:uu()===e?$u():this},au.$metadata$={kind:g,simpleName:"ContinuationInterceptor",interfaces:[_u]},cu.prototype.plus_1fupul$=function(t){return t===$u()?this:t.fold_3cc69b$(this,pu)},hu.$metadata$={kind:g,simpleName:"Key",interfaces:[]},_u.prototype.get_j3r2sn$=function(e){return o(this.key,e)?t.isType(this,_u)?this:Yr():null},_u.prototype.fold_3cc69b$=function(t,e){return e(t,this)},_u.prototype.minusKey_yeqjby$=function(t){return o(this.key,t)?$u():this},_u.$metadata$={kind:g,simpleName:"Element",interfaces:[cu]},cu.$metadata$={kind:g,simpleName:"CoroutineContext",interfaces:[]},Object.defineProperty(fu.prototype,"key",{get:function(){return this.key_no4tas$_0}}),fu.$metadata$={kind:p,simpleName:"AbstractCoroutineContextElement",interfaces:[_u]},du.prototype.tryCast_m1180o$=function(t){return this.safeCast_9rw4bk$_0(t)},du.prototype.isSubKey_i2ksv9$=function(t){return t===this||this.topmostKey_3x72pn$_0===t},du.$metadata$={kind:p,simpleName:"AbstractCoroutineContextKey",interfaces:[hu]},mu.prototype.readResolve_0=function(){return $u()},mu.prototype.get_j3r2sn$=function(t){return null},mu.prototype.fold_3cc69b$=function(t,e){return t},mu.prototype.plus_1fupul$=function(t){return t},mu.prototype.minusKey_yeqjby$=function(t){return this},mu.prototype.hashCode=function(){return 0},mu.prototype.toString=function(){return"EmptyCoroutineContext"},mu.$metadata$={kind:b,simpleName:"EmptyCoroutineContext",interfaces:[Kr,cu]};var yu=null;function $u(){return null===yu&&new mu,yu}function vu(t,e){this.left_0=t,this.element_0=e}function gu(t,e){return 0===t.length?e.toString():t+", "+e}function bu(t){null===Cu&&new wu,this.elements=t}function wu(){Cu=this,this.serialVersionUID_0=u}vu.prototype.get_j3r2sn$=function(e){for(var n,i=this;;){if(null!=(n=i.element_0.get_j3r2sn$(e)))return n;var r=i.left_0;if(!t.isType(r,vu))return r.get_j3r2sn$(e);i=r}},vu.prototype.fold_3cc69b$=function(t,e){return e(this.left_0.fold_3cc69b$(t,e),this.element_0)},vu.prototype.minusKey_yeqjby$=function(t){if(null!=this.element_0.get_j3r2sn$(t))return this.left_0;var e=this.left_0.minusKey_yeqjby$(t);return e===this.left_0?this:e===$u()?this.element_0:new vu(e,this.element_0)},vu.prototype.size_0=function(){for(var e,n,i=this,r=2;;){if(null==(n=t.isType(e=i.left_0,vu)?e:null))return r;i=n,r=r+1|0}},vu.prototype.contains_0=function(t){return o(this.get_j3r2sn$(t.key),t)},vu.prototype.containsAll_0=function(e){for(var n,i=e;;){if(!this.contains_0(i.element_0))return!1;var r=i.left_0;if(!t.isType(r,vu))return this.contains_0(t.isType(n=r,_u)?n:Yr());i=r}},vu.prototype.equals=function(e){return this===e||t.isType(e,vu)&&e.size_0()===this.size_0()&&e.containsAll_0(this)},vu.prototype.hashCode=function(){return N(this.left_0)+N(this.element_0)|0},vu.prototype.toString=function(){return"["+this.fold_3cc69b$("",gu)+"]"},vu.prototype.writeReplace_0=function(){var e,n,i,r=this.size_0(),o=t.newArray(r,null),a={v:0};if(this.fold_3cc69b$(Qe(),(n=o,i=a,function(t,e){var r;return n[(r=i.v,i.v=r+1|0,r)]=e,Ze})),a.v!==r)throw Un("Check failed.".toString());return new bu(t.isArray(e=o)?e:Yr())},wu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var xu,ku,Eu,Cu=null;function Su(){return Nu()}function Tu(t,e){x.call(this),this.name$=t,this.ordinal$=e}function Ou(){Ou=function(){},xu=new Tu("COROUTINE_SUSPENDED",0),ku=new Tu("UNDECIDED",1),Eu=new Tu("RESUMED",2)}function Nu(){return Ou(),xu}function Pu(){return Ou(),ku}function Au(){return Ou(),Eu}function ju(){Du()}function Lu(){zu=this,ju.call(this),this.defaultRandom_0=Qr()}function Ru(){Iu=this,this.serialVersionUID_0=u}bu.prototype.readResolve_0=function(){var t,e=this.elements,n=$u();for(t=0;t!==e.length;++t){var i=e[t];n=n.plus_1fupul$(i)}return n},bu.$metadata$={kind:p,simpleName:"Serialized",interfaces:[Kr]},vu.$metadata$={kind:p,simpleName:"CombinedContext",interfaces:[Kr,cu]},i("kotlin.kotlin.coroutines.intrinsics.suspendCoroutineUninterceptedOrReturn_zb0pmy$",r((function(){var t=e.kotlin.NotImplementedError;return function(e,n){throw new t("Implementation of suspendCoroutineUninterceptedOrReturn is intrinsic")}}))),Tu.$metadata$={kind:p,simpleName:"CoroutineSingletons",interfaces:[x]},Tu.values=function(){return[Nu(),Pu(),Au()]},Tu.valueOf_61zpoe$=function(t){switch(t){case"COROUTINE_SUSPENDED":return Nu();case"UNDECIDED":return Pu();case"RESUMED":return Au();default:Vr("No enum constant kotlin.coroutines.intrinsics.CoroutineSingletons."+t)}},ju.prototype.nextInt=function(){return this.nextBits_za3lpa$(32)},ju.prototype.nextInt_za3lpa$=function(t){return this.nextInt_vux9f0$(0,t)},ju.prototype.nextInt_vux9f0$=function(t,e){var n;Fu(t,e);var i=e-t|0;if(i>0||-2147483648===i){if((i&(0|-i))===i){var r=Bu(i);n=this.nextBits_za3lpa$(r)}else{var o;do{var a=this.nextInt()>>>1;o=a%i}while((a-o+(i-1)|0)<0);n=o}return t+n|0}for(;;){var s=this.nextInt();if(t<=s&&s0){var a;if(o(r.and(r.unaryMinus()),r)){var s=r.toInt(),l=r.shiftRightUnsigned(32).toInt();if(0!==s){var u=Bu(s);i=t.Long.fromInt(this.nextBits_za3lpa$(u)).and(v)}else if(1===l)i=t.Long.fromInt(this.nextInt()).and(v);else{var c=Bu(l);i=t.Long.fromInt(this.nextBits_za3lpa$(c)).shiftLeft(32).add(t.Long.fromInt(this.nextInt()))}a=i}else{var p;do{var h=this.nextLong().shiftRightUnsigned(1);p=h.modulo(r)}while(h.subtract(p).add(r.subtract(t.Long.fromInt(1))).toNumber()<0);a=p}return e.add(a)}for(;;){var _=this.nextLong();if(e.lessThanOrEqual(_)&&_.lessThan(n))return _}},ju.prototype.nextBoolean=function(){return 0!==this.nextBits_za3lpa$(1)},ju.prototype.nextDouble=function(){return to(this.nextBits_za3lpa$(26),this.nextBits_za3lpa$(27))},ju.prototype.nextDouble_14dthe$=function(t){return this.nextDouble_lu1900$(0,t)},ju.prototype.nextDouble_lu1900$=function(t,e){var n;Gu(t,e);var i=e-t;if(Zr(i)&&Jr(t)&&Jr(e)){var r=this.nextDouble()*(e/2-t/2);n=t+r+r}else n=t+this.nextDouble()*i;var o=n;return o>=e?Wr(e):o},ju.prototype.nextFloat=function(){return this.nextBits_za3lpa$(24)/16777216},ju.prototype.nextBytes_mj6st8$$default=function(t,e,n){if(!(0<=e&&e<=t.length&&0<=n&&n<=t.length))throw Mn((i=e,r=n,o=t,function(){return"fromIndex ("+i+") or toIndex ("+r+") are out of range: 0.."+o.length+"."})().toString());var i,r,o;if(!(e<=n))throw Mn(("fromIndex ("+e+") must be not greater than toIndex ("+n+").").toString());for(var a=(n-e|0)/4|0,s={v:e},l=0;l>>8),t[s.v+2|0]=f(u>>>16),t[s.v+3|0]=f(u>>>24),s.v=s.v+4|0}for(var c=n-s.v|0,p=this.nextBits_za3lpa$(8*c|0),h=0;h>>(8*h|0));return t},ju.prototype.nextBytes_mj6st8$=function(t,e,n,i){return void 0===e&&(e=0),void 0===n&&(n=t.length),i?i(t,e,n):this.nextBytes_mj6st8$$default(t,e,n)},ju.prototype.nextBytes_fqrh44$=function(t){return this.nextBytes_mj6st8$(t,0,t.length)},ju.prototype.nextBytes_za3lpa$=function(t){return this.nextBytes_fqrh44$(new Int8Array(t))},Ru.prototype.readResolve_0=function(){return Du()},Ru.$metadata$={kind:b,simpleName:"Serialized",interfaces:[Kr]};var Iu=null;Lu.prototype.writeReplace_0=function(){return null===Iu&&new Ru,Iu},Lu.prototype.nextBits_za3lpa$=function(t){return this.defaultRandom_0.nextBits_za3lpa$(t)},Lu.prototype.nextInt=function(){return this.defaultRandom_0.nextInt()},Lu.prototype.nextInt_za3lpa$=function(t){return this.defaultRandom_0.nextInt_za3lpa$(t)},Lu.prototype.nextInt_vux9f0$=function(t,e){return this.defaultRandom_0.nextInt_vux9f0$(t,e)},Lu.prototype.nextLong=function(){return this.defaultRandom_0.nextLong()},Lu.prototype.nextLong_s8cxhz$=function(t){return this.defaultRandom_0.nextLong_s8cxhz$(t)},Lu.prototype.nextLong_3pjtqy$=function(t,e){return this.defaultRandom_0.nextLong_3pjtqy$(t,e)},Lu.prototype.nextBoolean=function(){return this.defaultRandom_0.nextBoolean()},Lu.prototype.nextDouble=function(){return this.defaultRandom_0.nextDouble()},Lu.prototype.nextDouble_14dthe$=function(t){return this.defaultRandom_0.nextDouble_14dthe$(t)},Lu.prototype.nextDouble_lu1900$=function(t,e){return this.defaultRandom_0.nextDouble_lu1900$(t,e)},Lu.prototype.nextFloat=function(){return this.defaultRandom_0.nextFloat()},Lu.prototype.nextBytes_fqrh44$=function(t){return this.defaultRandom_0.nextBytes_fqrh44$(t)},Lu.prototype.nextBytes_za3lpa$=function(t){return this.defaultRandom_0.nextBytes_za3lpa$(t)},Lu.prototype.nextBytes_mj6st8$$default=function(t,e,n){return this.defaultRandom_0.nextBytes_mj6st8$(t,e,n)},Lu.$metadata$={kind:b,simpleName:"Default",interfaces:[Kr,ju]};var zu=null;function Du(){return null===zu&&new Lu,zu}function Mu(t){return Ju(t,t>>31)}function Bu(t){return 31-c.clz32(t)|0}function Uu(t,e){return t>>>32-e&(0|-e)>>31}function Fu(t,e){if(!(e>t))throw Mn(Hu(t,e).toString())}function qu(t,e){if(!(e.compareTo_11rb$(t)>0))throw Mn(Hu(t,e).toString())}function Gu(t,e){if(!(e>t))throw Mn(Hu(t,e).toString())}function Hu(t,e){return"Random range is empty: ["+t.toString()+", "+e.toString()+")."}function Yu(t,e,n,i,r,o){if(null===Zu&&new Vu,ju.call(this),this.x_0=t,this.y_0=e,this.z_0=n,this.w_0=i,this.v_0=r,this.addend_0=o,0==(this.x_0|this.y_0|this.z_0|this.w_0|this.v_0))throw Mn("Initial state must have at least one non-zero element.".toString());for(var a=0;a<64;a++)this.nextInt()}function Vu(){Zu=this,this.serialVersionUID_0=u}ju.$metadata$={kind:p,simpleName:"Random",interfaces:[]},Yu.prototype.nextInt=function(){var t=this.x_0;t^=t>>>2,this.x_0=this.y_0,this.y_0=this.z_0,this.z_0=this.w_0;var e=this.v_0;return this.w_0=e,t=t^t<<1^e^e<<4,this.v_0=t,this.addend_0=this.addend_0+362437|0,t+this.addend_0|0},Yu.prototype.nextBits_za3lpa$=function(t){return Uu(this.nextInt(),t)},Vu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ku,Wu,Xu,Zu=null;function Ju(t,e,n){return n=n||Object.create(Yu.prototype),Yu.call(n,t,e,0,0,~t,t<<10^e>>>4),n}function Qu(t,e){this.start_p1gsmm$_0=t,this.endInclusive_jj4lf7$_0=e}function tc(){}function ec(t,e){this._start_0=t,this._endInclusive_0=e}function nc(){}function ic(e,n,i){null!=i?e.append_gw00v9$(i(n)):null==n||t.isCharSequence(n)?e.append_gw00v9$(n):t.isChar(n)?e.append_s8itvh$(s(n)):e.append_gw00v9$($(n))}function rc(t,e,n){if(void 0===n&&(n=!1),t===e)return!0;if(!n)return!1;var i=ta(t),r=ta(e),o=i===r;return o||(o=String.fromCharCode(i).toLowerCase().charCodeAt(0)===String.fromCharCode(r).toLowerCase().charCodeAt(0)),o}function oc(e,n,i){if(void 0===n&&(n=""),void 0===i&&(i="|"),La(i))throw Mn("marginPrefix must be non-blank string.".toString());var r,o,l,u,c=Bc(e),p=(e.length,t.imul(n.length,c.size),0===(l=n).length?ac:(u=l,function(t){return u+t})),h=ws(c),_=Ki(),f=0;for(r=c.iterator();r.hasNext();){var d,m,y,$,v=r.next(),g=Pi((f=(o=f)+1|0,o));if(0!==g&&g!==h||!La(v)){var b;t:do{var w,x,k,E;x=(w=vc(v)).first,k=w.last,E=w.step;for(var C=x;C<=k;C+=E)if(!ia(s(a(v.charCodeAt(C))))){b=C;break t}b=-1}while(0);var S=b;$=null!=(y=null!=(m=-1===S?null:Pa(v,i,S)?v.substring(S+i.length|0):null)?p(m):null)?y:v}else $=null;null!=(d=$)&&_.add_11rb$(d)}return Ct(_,Zo(),"\n").toString()}function ac(t){return t}function sc(t){return lc(t,10)}function lc(e,n){oa(n);var i,r,o,a=e.length;if(0===a)return null;var s=e.charCodeAt(0);if(s<48){if(1===a)return null;if(i=1,45===s)r=!0,o=-2147483648;else{if(43!==s)return null;r=!1,o=-2147483647}}else i=0,r=!1,o=-2147483647;for(var l=-59652323,u=l,c=0,p=i;p(t.length-r|0)||i>(n.length-r|0))return!1;for(var a=0;a0&&rc(t.charCodeAt(0),e,n)}function Ec(t,e,n){return void 0===n&&(n=!1),t.length>0&&rc(t.charCodeAt(gc(t)),e,n)}function Cc(t,e,n){return void 0===n&&(n=!1),n||"string"!=typeof t||"string"!=typeof e?xc(t,0,e,0,e.length,n):Na(t,e)}function Sc(t,e,n){return void 0===n&&(n=!1),n||"string"!=typeof t||"string"!=typeof e?xc(t,t.length-e.length|0,e,0,e.length,n):Aa(t,e)}function Tc(t,e,n,i){var r,o;if(void 0===n&&(n=0),void 0===i&&(i=!1),!i&&1===e.length&&"string"==typeof t){var l=H(e);return t.indexOf(String.fromCharCode(l),n)}r=At(n,0),o=gc(t);for(var u=r;u<=o;u++){var c,p=t.charCodeAt(u);t:do{var h;for(h=0;h!==e.length;++h){var _=s(e[h]);if(rc(s(a(_)),p,i)){c=!0;break t}}c=!1}while(0);if(c)return u}return-1}function Oc(t,e,n,i){if(void 0===n&&(n=gc(t)),void 0===i&&(i=!1),!i&&1===e.length&&"string"==typeof t){var r=H(e);return t.lastIndexOf(String.fromCharCode(r),n)}for(var o=jt(n,gc(t));o>=0;o--){var l,u=t.charCodeAt(o);t:do{var c;for(c=0;c!==e.length;++c){var p=s(e[c]);if(rc(s(a(p)),u,i)){l=!0;break t}}l=!1}while(0);if(l)return o}return-1}function Nc(t,e,n,i,r,o){var a,s;void 0===o&&(o=!1);var l=o?Ot(jt(n,gc(t)),At(i,0)):new qe(At(n,0),jt(i,t.length));if("string"==typeof t&&"string"==typeof e)for(a=l.iterator();a.hasNext();){var u=a.next();if(Ra(e,0,t,u,e.length,r))return u}else for(s=l.iterator();s.hasNext();){var c=s.next();if(xc(e,0,t,c,e.length,r))return c}return-1}function Pc(e,n,i,r){return void 0===i&&(i=0),void 0===r&&(r=!1),r||"string"!=typeof e?Tc(e,t.charArrayOf(n),i,r):e.indexOf(String.fromCharCode(n),i)}function Ac(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=!1),i||"string"!=typeof t?Nc(t,e,n,t.length,i):t.indexOf(e,n)}function jc(t,e,n,i){return void 0===n&&(n=gc(t)),void 0===i&&(i=!1),i||"string"!=typeof t?Nc(t,e,n,0,i,!0):t.lastIndexOf(e,n)}function Lc(t,e,n,i){this.input_0=t,this.startIndex_0=e,this.limit_0=n,this.getNextMatch_0=i}function Rc(t){this.this$DelimitedRangesSequence=t,this.nextState=-1,this.currentStartIndex=Lt(t.startIndex_0,0,t.input_0.length),this.nextSearchIndex=this.currentStartIndex,this.nextItem=null,this.counter=0}function Ic(t,e){return function(n,i){var r;return null!=(r=function(t,e,n,i,r){var o,a;if(!i&&1===e.size){var s=_t(e),l=r?jc(t,s,n):Ac(t,s,n);return l<0?null:cp(l,s)}var u=r?Ot(jt(n,gc(t)),0):new qe(At(n,0),t.length);if("string"==typeof t)for(o=u.iterator();o.hasNext();){var c,p=o.next();t:do{var h;for(h=e.iterator();h.hasNext();){var _=h.next();if(Ra(_,0,t,p,_.length,i)){c=_;break t}}c=null}while(0);if(null!=c)return cp(p,c)}else for(a=u.iterator();a.hasNext();){var f,d=a.next();t:do{var m;for(m=e.iterator();m.hasNext();){var y=m.next();if(xc(y,0,t,d,y.length,i)){f=y;break t}}f=null}while(0);if(null!=f)return cp(d,f)}return null}(n,t,i,e,!1))?cp(r.first,r.second.length):null}}function zc(t,e,n,i,r){if(void 0===n&&(n=0),void 0===i&&(i=!1),void 0===r&&(r=0),!(r>=0))throw Mn(("Limit must be non-negative, but was "+r+".").toString());return new Lc(t,n,r,Ic(ai(e),i))}function Dc(t,e,n,i){return void 0===n&&(n=!1),void 0===i&&(i=0),Gt(zc(t,e,void 0,n,i),(r=t,function(t){return wc(r,t)}));var r}function Mc(t){return Dc(t,["\r\n","\n","\r"])}function Bc(t){return Ft(Mc(t))}function Uc(){}function Fc(){}function qc(t){this.match=t}function Gc(){}function Hc(t,e){x.call(this),this.name$=t,this.ordinal$=e}function Yc(){Yc=function(){},Ku=new Hc("SYNCHRONIZED",0),Wu=new Hc("PUBLICATION",1),Xu=new Hc("NONE",2)}function Vc(){return Yc(),Ku}function Kc(){return Yc(),Wu}function Wc(){return Yc(),Xu}function Xc(){Zc=this}Yu.$metadata$={kind:p,simpleName:"XorWowRandom",interfaces:[Kr,ju]},tc.prototype.contains_mef7kx$=function(t){return this.lessThanOrEquals_n65qkk$(this.start,t)&&this.lessThanOrEquals_n65qkk$(t,this.endInclusive)},tc.prototype.isEmpty=function(){return!this.lessThanOrEquals_n65qkk$(this.start,this.endInclusive)},tc.$metadata$={kind:g,simpleName:"ClosedFloatingPointRange",interfaces:[De]},Object.defineProperty(ec.prototype,"start",{configurable:!0,get:function(){return this._start_0}}),Object.defineProperty(ec.prototype,"endInclusive",{configurable:!0,get:function(){return this._endInclusive_0}}),ec.prototype.lessThanOrEquals_n65qkk$=function(t,e){return t<=e},ec.prototype.contains_mef7kx$=function(t){return t>=this._start_0&&t<=this._endInclusive_0},ec.prototype.isEmpty=function(){return!(this._start_0<=this._endInclusive_0)},ec.prototype.equals=function(e){return t.isType(e,ec)&&(this.isEmpty()&&e.isEmpty()||this._start_0===e._start_0&&this._endInclusive_0===e._endInclusive_0)},ec.prototype.hashCode=function(){return this.isEmpty()?-1:(31*N(this._start_0)|0)+N(this._endInclusive_0)|0},ec.prototype.toString=function(){return this._start_0.toString()+".."+this._endInclusive_0},ec.$metadata$={kind:p,simpleName:"ClosedDoubleRange",interfaces:[tc]},nc.$metadata$={kind:g,simpleName:"KClassifier",interfaces:[]},yc.prototype.nextChar=function(){var t,e;return t=this.index_0,this.index_0=t+1|0,e=t,this.this$iterator.charCodeAt(e)},yc.prototype.hasNext=function(){return this.index_00&&(this.counter=this.counter+1|0,this.counter>=this.this$DelimitedRangesSequence.limit_0)||this.nextSearchIndex>this.this$DelimitedRangesSequence.input_0.length)this.nextItem=new qe(this.currentStartIndex,gc(this.this$DelimitedRangesSequence.input_0)),this.nextSearchIndex=-1;else{var t=this.this$DelimitedRangesSequence.getNextMatch_0(this.this$DelimitedRangesSequence.input_0,this.nextSearchIndex);if(null==t)this.nextItem=new qe(this.currentStartIndex,gc(this.this$DelimitedRangesSequence.input_0)),this.nextSearchIndex=-1;else{var e=t.component1(),n=t.component2();this.nextItem=Pt(this.currentStartIndex,e),this.currentStartIndex=e+n|0,this.nextSearchIndex=this.currentStartIndex+(0===n?1:0)|0}}this.nextState=1}},Rc.prototype.next=function(){var e;if(-1===this.nextState&&this.calcNext_0(),0===this.nextState)throw Zn();var n=t.isType(e=this.nextItem,qe)?e:Yr();return this.nextItem=null,this.nextState=-1,n},Rc.prototype.hasNext=function(){return-1===this.nextState&&this.calcNext_0(),1===this.nextState},Rc.$metadata$={kind:p,interfaces:[pe]},Lc.prototype.iterator=function(){return new Rc(this)},Lc.$metadata$={kind:p,simpleName:"DelimitedRangesSequence",interfaces:[nl]},Uc.$metadata$={kind:g,simpleName:"MatchGroupCollection",interfaces:[ee]},Object.defineProperty(Fc.prototype,"destructured",{configurable:!0,get:function(){return new qc(this)}}),qc.prototype.component1=i("kotlin.kotlin.text.MatchResult.Destructured.component1",(function(){return this.match.groupValues.get_za3lpa$(1)})),qc.prototype.component2=i("kotlin.kotlin.text.MatchResult.Destructured.component2",(function(){return this.match.groupValues.get_za3lpa$(2)})),qc.prototype.component3=i("kotlin.kotlin.text.MatchResult.Destructured.component3",(function(){return this.match.groupValues.get_za3lpa$(3)})),qc.prototype.component4=i("kotlin.kotlin.text.MatchResult.Destructured.component4",(function(){return this.match.groupValues.get_za3lpa$(4)})),qc.prototype.component5=i("kotlin.kotlin.text.MatchResult.Destructured.component5",(function(){return this.match.groupValues.get_za3lpa$(5)})),qc.prototype.component6=i("kotlin.kotlin.text.MatchResult.Destructured.component6",(function(){return this.match.groupValues.get_za3lpa$(6)})),qc.prototype.component7=i("kotlin.kotlin.text.MatchResult.Destructured.component7",(function(){return this.match.groupValues.get_za3lpa$(7)})),qc.prototype.component8=i("kotlin.kotlin.text.MatchResult.Destructured.component8",(function(){return this.match.groupValues.get_za3lpa$(8)})),qc.prototype.component9=i("kotlin.kotlin.text.MatchResult.Destructured.component9",(function(){return this.match.groupValues.get_za3lpa$(9)})),qc.prototype.component10=i("kotlin.kotlin.text.MatchResult.Destructured.component10",(function(){return this.match.groupValues.get_za3lpa$(10)})),qc.prototype.toList=function(){return this.match.groupValues.subList_vux9f0$(1,this.match.groupValues.size)},qc.$metadata$={kind:p,simpleName:"Destructured",interfaces:[]},Fc.$metadata$={kind:g,simpleName:"MatchResult",interfaces:[]},Gc.$metadata$={kind:g,simpleName:"Lazy",interfaces:[]},Hc.$metadata$={kind:p,simpleName:"LazyThreadSafetyMode",interfaces:[x]},Hc.values=function(){return[Vc(),Kc(),Wc()]},Hc.valueOf_61zpoe$=function(t){switch(t){case"SYNCHRONIZED":return Vc();case"PUBLICATION":return Kc();case"NONE":return Wc();default:Vr("No enum constant kotlin.LazyThreadSafetyMode."+t)}},Xc.$metadata$={kind:b,simpleName:"UNINITIALIZED_VALUE",interfaces:[]};var Zc=null;function Jc(){return null===Zc&&new Xc,Zc}function Qc(t){this.initializer_0=t,this._value_0=Jc()}function tp(t){this.value_7taq70$_0=t}function ep(t){rp(),this.value=t}function np(){ip=this}Object.defineProperty(Qc.prototype,"value",{configurable:!0,get:function(){var e;return this._value_0===Jc()&&(this._value_0=E(this.initializer_0)(),this.initializer_0=null),null==(e=this._value_0)||t.isType(e,C)?e:Yr()}}),Qc.prototype.isInitialized=function(){return this._value_0!==Jc()},Qc.prototype.toString=function(){return this.isInitialized()?$(this.value):"Lazy value not initialized yet."},Qc.prototype.writeReplace_0=function(){return new tp(this.value)},Qc.$metadata$={kind:p,simpleName:"UnsafeLazyImpl",interfaces:[Kr,Gc]},Object.defineProperty(tp.prototype,"value",{get:function(){return this.value_7taq70$_0}}),tp.prototype.isInitialized=function(){return!0},tp.prototype.toString=function(){return $(this.value)},tp.$metadata$={kind:p,simpleName:"InitializedLazyImpl",interfaces:[Kr,Gc]},Object.defineProperty(ep.prototype,"isSuccess",{configurable:!0,get:function(){return!t.isType(this.value,op)}}),Object.defineProperty(ep.prototype,"isFailure",{configurable:!0,get:function(){return t.isType(this.value,op)}}),ep.prototype.getOrNull=i("kotlin.kotlin.Result.getOrNull",r((function(){var e=Object,n=t.throwCCE;return function(){var i;return this.isFailure?null:null==(i=this.value)||t.isType(i,e)?i:n()}}))),ep.prototype.exceptionOrNull=function(){return t.isType(this.value,op)?this.value.exception:null},ep.prototype.toString=function(){return t.isType(this.value,op)?this.value.toString():"Success("+$(this.value)+")"},np.prototype.success_mh5how$=i("kotlin.kotlin.Result.Companion.success_mh5how$",r((function(){var t=e.kotlin.Result;return function(e){return new t(e)}}))),np.prototype.failure_lsqlk3$=i("kotlin.kotlin.Result.Companion.failure_lsqlk3$",r((function(){var t=e.kotlin.createFailure_tcv7n7$,n=e.kotlin.Result;return function(e){return new n(t(e))}}))),np.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var ip=null;function rp(){return null===ip&&new np,ip}function op(t){this.exception=t}function ap(t){return new op(t)}function sp(e){if(t.isType(e.value,op))throw e.value.exception}function lp(t){void 0===t&&(t="An operation is not implemented."),Ln(t,this),this.name="NotImplementedError"}function up(t,e){this.first=t,this.second=e}function cp(t,e){return new up(t,e)}function pp(t,e,n){this.first=t,this.second=e,this.third=n}function hp(t){dp(),this.data=t}function _p(){fp=this,this.MIN_VALUE=new hp(0),this.MAX_VALUE=new hp(-1),this.SIZE_BYTES=1,this.SIZE_BITS=8}op.prototype.equals=function(e){return t.isType(e,op)&&o(this.exception,e.exception)},op.prototype.hashCode=function(){return N(this.exception)},op.prototype.toString=function(){return"Failure("+this.exception+")"},op.$metadata$={kind:p,simpleName:"Failure",interfaces:[Kr]},ep.$metadata$={kind:p,simpleName:"Result",interfaces:[Kr]},ep.prototype.unbox=function(){return this.value},ep.prototype.hashCode=function(){var e=0;return 31*e+t.hashCode(this.value)|0},ep.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.value,e.value)},lp.$metadata$={kind:p,simpleName:"NotImplementedError",interfaces:[jn]},up.prototype.toString=function(){return"("+this.first+", "+this.second+")"},up.$metadata$={kind:p,simpleName:"Pair",interfaces:[Kr]},up.prototype.component1=function(){return this.first},up.prototype.component2=function(){return this.second},up.prototype.copy_xwzc9p$=function(t,e){return new up(void 0===t?this.first:t,void 0===e?this.second:e)},up.prototype.hashCode=function(){var e=0;return 31*(e=31*e+t.hashCode(this.first)|0)+t.hashCode(this.second)|0},up.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.first,e.first)&&t.equals(this.second,e.second)},pp.prototype.toString=function(){return"("+this.first+", "+this.second+", "+this.third+")"},pp.$metadata$={kind:p,simpleName:"Triple",interfaces:[Kr]},pp.prototype.component1=function(){return this.first},pp.prototype.component2=function(){return this.second},pp.prototype.component3=function(){return this.third},pp.prototype.copy_1llc0w$=function(t,e,n){return new pp(void 0===t?this.first:t,void 0===e?this.second:e,void 0===n?this.third:n)},pp.prototype.hashCode=function(){var e=0;return 31*(e=31*(e=31*e+t.hashCode(this.first)|0)+t.hashCode(this.second)|0)+t.hashCode(this.third)|0},pp.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.first,e.first)&&t.equals(this.second,e.second)&&t.equals(this.third,e.third)},_p.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var fp=null;function dp(){return null===fp&&new _p,fp}function mp(t){vp(),this.data=t}function yp(){$p=this,this.MIN_VALUE=new mp(0),this.MAX_VALUE=new mp(-1),this.SIZE_BYTES=4,this.SIZE_BITS=32}hp.prototype.compareTo_11rb$=i("kotlin.kotlin.UByte.compareTo_11rb$",(function(e){return t.primitiveCompareTo(255&this.data,255&e.data)})),hp.prototype.compareTo_6hrhkk$=i("kotlin.kotlin.UByte.compareTo_6hrhkk$",(function(e){return t.primitiveCompareTo(255&this.data,65535&e.data)})),hp.prototype.compareTo_s87ys9$=i("kotlin.kotlin.UByte.compareTo_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintCompare_vux9f0$;return function(e){return n(new t(255&this.data).data,e.data)}}))),hp.prototype.compareTo_mpgczg$=i("kotlin.kotlin.UByte.compareTo_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)).data,e.data)}}))),hp.prototype.plus_mpmjao$=i("kotlin.kotlin.UByte.plus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data+new t(255&e.data).data|0)}}))),hp.prototype.plus_6hrhkk$=i("kotlin.kotlin.UByte.plus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data+new t(65535&e.data).data|0)}}))),hp.prototype.plus_s87ys9$=i("kotlin.kotlin.UByte.plus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data+e.data|0)}}))),hp.prototype.plus_mpgczg$=i("kotlin.kotlin.UByte.plus_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.add(e.data))}}))),hp.prototype.minus_mpmjao$=i("kotlin.kotlin.UByte.minus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data-new t(255&e.data).data|0)}}))),hp.prototype.minus_6hrhkk$=i("kotlin.kotlin.UByte.minus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data-new t(65535&e.data).data|0)}}))),hp.prototype.minus_s87ys9$=i("kotlin.kotlin.UByte.minus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(255&this.data).data-e.data|0)}}))),hp.prototype.minus_mpgczg$=i("kotlin.kotlin.UByte.minus_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.subtract(e.data))}}))),hp.prototype.times_mpmjao$=i("kotlin.kotlin.UByte.times_mpmjao$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(255&this.data).data,new n(255&e.data).data))}}))),hp.prototype.times_6hrhkk$=i("kotlin.kotlin.UByte.times_6hrhkk$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(255&this.data).data,new n(65535&e.data).data))}}))),hp.prototype.times_s87ys9$=i("kotlin.kotlin.UByte.times_s87ys9$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(255&this.data).data,e.data))}}))),hp.prototype.times_mpgczg$=i("kotlin.kotlin.UByte.times_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.multiply(e.data))}}))),hp.prototype.div_mpmjao$=i("kotlin.kotlin.UByte.div_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),new t(255&e.data))}}))),hp.prototype.div_6hrhkk$=i("kotlin.kotlin.UByte.div_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),new t(65535&e.data))}}))),hp.prototype.div_s87ys9$=i("kotlin.kotlin.UByte.div_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),e)}}))),hp.prototype.div_mpgczg$=i("kotlin.kotlin.UByte.div_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),hp.prototype.rem_mpmjao$=i("kotlin.kotlin.UByte.rem_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(255&this.data),new t(255&e.data))}}))),hp.prototype.rem_6hrhkk$=i("kotlin.kotlin.UByte.rem_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(255&this.data),new t(65535&e.data))}}))),hp.prototype.rem_s87ys9$=i("kotlin.kotlin.UByte.rem_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(255&this.data),e)}}))),hp.prototype.rem_mpgczg$=i("kotlin.kotlin.UByte.rem_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),hp.prototype.floorDiv_mpmjao$=i("kotlin.kotlin.UByte.floorDiv_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),new t(255&e.data))}}))),hp.prototype.floorDiv_6hrhkk$=i("kotlin.kotlin.UByte.floorDiv_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),new t(65535&e.data))}}))),hp.prototype.floorDiv_s87ys9$=i("kotlin.kotlin.UByte.floorDiv_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(255&this.data),e)}}))),hp.prototype.floorDiv_mpgczg$=i("kotlin.kotlin.UByte.floorDiv_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),hp.prototype.mod_mpmjao$=i("kotlin.kotlin.UByte.mod_mpmjao$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toByte,o=e.kotlin.UByte;return function(t){return new o(r(i(new n(255&this.data),new n(255&t.data)).data))}}))),hp.prototype.mod_6hrhkk$=i("kotlin.kotlin.UByte.mod_6hrhkk$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toShort,o=e.kotlin.UShort;return function(t){return new o(r(i(new n(255&this.data),new n(65535&t.data)).data))}}))),hp.prototype.mod_s87ys9$=i("kotlin.kotlin.UByte.mod_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(255&this.data),e)}}))),hp.prototype.mod_mpgczg$=i("kotlin.kotlin.UByte.mod_mpgczg$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),hp.prototype.inc=i("kotlin.kotlin.UByte.inc",r((function(){var n=t.toByte,i=e.kotlin.UByte;return function(){return new i(n(this.data+1))}}))),hp.prototype.dec=i("kotlin.kotlin.UByte.dec",r((function(){var n=t.toByte,i=e.kotlin.UByte;return function(){return new i(n(this.data-1))}}))),hp.prototype.rangeTo_mpmjao$=i("kotlin.kotlin.UByte.rangeTo_mpmjao$",r((function(){var t=e.kotlin.ranges.UIntRange,n=e.kotlin.UInt;return function(e){return new t(new n(255&this.data),new n(255&e.data))}}))),hp.prototype.and_mpmjao$=i("kotlin.kotlin.UByte.and_mpmjao$",r((function(){var n=e.kotlin.UByte,i=t.toByte;return function(t){return new n(i(this.data&t.data))}}))),hp.prototype.or_mpmjao$=i("kotlin.kotlin.UByte.or_mpmjao$",r((function(){var n=e.kotlin.UByte,i=t.toByte;return function(t){return new n(i(this.data|t.data))}}))),hp.prototype.xor_mpmjao$=i("kotlin.kotlin.UByte.xor_mpmjao$",r((function(){var n=e.kotlin.UByte,i=t.toByte;return function(t){return new n(i(this.data^t.data))}}))),hp.prototype.inv=i("kotlin.kotlin.UByte.inv",r((function(){var n=e.kotlin.UByte,i=t.toByte;return function(){return new n(i(~this.data))}}))),hp.prototype.toByte=i("kotlin.kotlin.UByte.toByte",(function(){return this.data})),hp.prototype.toShort=i("kotlin.kotlin.UByte.toShort",r((function(){var e=t.toShort;return function(){return e(255&this.data)}}))),hp.prototype.toInt=i("kotlin.kotlin.UByte.toInt",(function(){return 255&this.data})),hp.prototype.toLong=i("kotlin.kotlin.UByte.toLong",r((function(){var e=t.Long.fromInt(255);return function(){return t.Long.fromInt(this.data).and(e)}}))),hp.prototype.toUByte=i("kotlin.kotlin.UByte.toUByte",(function(){return this})),hp.prototype.toUShort=i("kotlin.kotlin.UByte.toUShort",r((function(){var n=e.kotlin.UShort,i=t.toShort;return function(){return new n(i(255&this.data))}}))),hp.prototype.toUInt=i("kotlin.kotlin.UByte.toUInt",r((function(){var t=e.kotlin.UInt;return function(){return new t(255&this.data)}}))),hp.prototype.toULong=i("kotlin.kotlin.UByte.toULong",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(){return new i(t.Long.fromInt(this.data).and(n))}}))),hp.prototype.toFloat=i("kotlin.kotlin.UByte.toFloat",(function(){return 255&this.data})),hp.prototype.toDouble=i("kotlin.kotlin.UByte.toDouble",(function(){return 255&this.data})),hp.prototype.toString=function(){return(255&this.data).toString()},hp.$metadata$={kind:p,simpleName:"UByte",interfaces:[k]},hp.prototype.unbox=function(){return this.data},hp.prototype.hashCode=function(){var e=0;return 31*e+t.hashCode(this.data)|0},hp.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.data,e.data)},yp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var $p=null;function vp(){return null===$p&&new yp,$p}function gp(t,e){xp(),kp.call(this,t,e,1)}function bp(){wp=this,this.EMPTY=new gp(vp().MAX_VALUE,vp().MIN_VALUE)}mp.prototype.compareTo_mpmjao$=i("kotlin.kotlin.UInt.compareTo_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintCompare_vux9f0$;return function(e){return n(this.data,new t(255&e.data).data)}}))),mp.prototype.compareTo_6hrhkk$=i("kotlin.kotlin.UInt.compareTo_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintCompare_vux9f0$;return function(e){return n(this.data,new t(65535&e.data).data)}}))),mp.prototype.compareTo_11rb$=i("kotlin.kotlin.UInt.compareTo_11rb$",r((function(){var t=e.kotlin.uintCompare_vux9f0$;return function(e){return t(this.data,e.data)}}))),mp.prototype.compareTo_mpgczg$=i("kotlin.kotlin.UInt.compareTo_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)).data,e.data)}}))),mp.prototype.plus_mpmjao$=i("kotlin.kotlin.UInt.plus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data+new t(255&e.data).data|0)}}))),mp.prototype.plus_6hrhkk$=i("kotlin.kotlin.UInt.plus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data+new t(65535&e.data).data|0)}}))),mp.prototype.plus_s87ys9$=i("kotlin.kotlin.UInt.plus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data+e.data|0)}}))),mp.prototype.plus_mpgczg$=i("kotlin.kotlin.UInt.plus_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.add(e.data))}}))),mp.prototype.minus_mpmjao$=i("kotlin.kotlin.UInt.minus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data-new t(255&e.data).data|0)}}))),mp.prototype.minus_6hrhkk$=i("kotlin.kotlin.UInt.minus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data-new t(65535&e.data).data|0)}}))),mp.prototype.minus_s87ys9$=i("kotlin.kotlin.UInt.minus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data-e.data|0)}}))),mp.prototype.minus_mpgczg$=i("kotlin.kotlin.UInt.minus_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.subtract(e.data))}}))),mp.prototype.times_mpmjao$=i("kotlin.kotlin.UInt.times_mpmjao$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(this.data,new n(255&e.data).data))}}))),mp.prototype.times_6hrhkk$=i("kotlin.kotlin.UInt.times_6hrhkk$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(this.data,new n(65535&e.data).data))}}))),mp.prototype.times_s87ys9$=i("kotlin.kotlin.UInt.times_s87ys9$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(this.data,e.data))}}))),mp.prototype.times_mpgczg$=i("kotlin.kotlin.UInt.times_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.multiply(e.data))}}))),mp.prototype.div_mpmjao$=i("kotlin.kotlin.UInt.div_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(this,new t(255&e.data))}}))),mp.prototype.div_6hrhkk$=i("kotlin.kotlin.UInt.div_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(this,new t(65535&e.data))}}))),mp.prototype.div_s87ys9$=i("kotlin.kotlin.UInt.div_s87ys9$",r((function(){var t=e.kotlin.uintDivide_oqfnby$;return function(e){return t(this,e)}}))),mp.prototype.div_mpgczg$=i("kotlin.kotlin.UInt.div_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),mp.prototype.rem_mpmjao$=i("kotlin.kotlin.UInt.rem_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(this,new t(255&e.data))}}))),mp.prototype.rem_6hrhkk$=i("kotlin.kotlin.UInt.rem_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(this,new t(65535&e.data))}}))),mp.prototype.rem_s87ys9$=i("kotlin.kotlin.UInt.rem_s87ys9$",r((function(){var t=e.kotlin.uintRemainder_oqfnby$;return function(e){return t(this,e)}}))),mp.prototype.rem_mpgczg$=i("kotlin.kotlin.UInt.rem_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),mp.prototype.floorDiv_mpmjao$=i("kotlin.kotlin.UInt.floorDiv_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(this,new t(255&e.data))}}))),mp.prototype.floorDiv_6hrhkk$=i("kotlin.kotlin.UInt.floorDiv_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(this,new t(65535&e.data))}}))),mp.prototype.floorDiv_s87ys9$=i("kotlin.kotlin.UInt.floorDiv_s87ys9$",r((function(){var t=e.kotlin.uintDivide_oqfnby$;return function(e){return t(this,e)}}))),mp.prototype.floorDiv_mpgczg$=i("kotlin.kotlin.UInt.floorDiv_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),mp.prototype.mod_mpmjao$=i("kotlin.kotlin.UInt.mod_mpmjao$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toByte,o=e.kotlin.UByte;return function(t){return new o(r(i(this,new n(255&t.data)).data))}}))),mp.prototype.mod_6hrhkk$=i("kotlin.kotlin.UInt.mod_6hrhkk$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toShort,o=e.kotlin.UShort;return function(t){return new o(r(i(this,new n(65535&t.data)).data))}}))),mp.prototype.mod_s87ys9$=i("kotlin.kotlin.UInt.mod_s87ys9$",r((function(){var t=e.kotlin.uintRemainder_oqfnby$;return function(e){return t(this,e)}}))),mp.prototype.mod_mpgczg$=i("kotlin.kotlin.UInt.mod_mpgczg$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),mp.prototype.inc=i("kotlin.kotlin.UInt.inc",r((function(){var t=e.kotlin.UInt;return function(){return new t(this.data+1|0)}}))),mp.prototype.dec=i("kotlin.kotlin.UInt.dec",r((function(){var t=e.kotlin.UInt;return function(){return new t(this.data-1|0)}}))),mp.prototype.rangeTo_s87ys9$=i("kotlin.kotlin.UInt.rangeTo_s87ys9$",r((function(){var t=e.kotlin.ranges.UIntRange;return function(e){return new t(this,e)}}))),mp.prototype.shl_za3lpa$=i("kotlin.kotlin.UInt.shl_za3lpa$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data<>>e)}}))),mp.prototype.and_s87ys9$=i("kotlin.kotlin.UInt.and_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data&e.data)}}))),mp.prototype.or_s87ys9$=i("kotlin.kotlin.UInt.or_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data|e.data)}}))),mp.prototype.xor_s87ys9$=i("kotlin.kotlin.UInt.xor_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(this.data^e.data)}}))),mp.prototype.inv=i("kotlin.kotlin.UInt.inv",r((function(){var t=e.kotlin.UInt;return function(){return new t(~this.data)}}))),mp.prototype.toByte=i("kotlin.kotlin.UInt.toByte",r((function(){var e=t.toByte;return function(){return e(this.data)}}))),mp.prototype.toShort=i("kotlin.kotlin.UInt.toShort",r((function(){var e=t.toShort;return function(){return e(this.data)}}))),mp.prototype.toInt=i("kotlin.kotlin.UInt.toInt",(function(){return this.data})),mp.prototype.toLong=i("kotlin.kotlin.UInt.toLong",r((function(){var e=new t.Long(-1,0);return function(){return t.Long.fromInt(this.data).and(e)}}))),mp.prototype.toUByte=i("kotlin.kotlin.UInt.toUByte",r((function(){var n=t.toByte,i=e.kotlin.UByte;return function(){return new i(n(this.data))}}))),mp.prototype.toUShort=i("kotlin.kotlin.UInt.toUShort",r((function(){var n=t.toShort,i=e.kotlin.UShort;return function(){return new i(n(this.data))}}))),mp.prototype.toUInt=i("kotlin.kotlin.UInt.toUInt",(function(){return this})),mp.prototype.toULong=i("kotlin.kotlin.UInt.toULong",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(){return new i(t.Long.fromInt(this.data).and(n))}}))),mp.prototype.toFloat=i("kotlin.kotlin.UInt.toFloat",r((function(){var t=e.kotlin.uintToDouble_za3lpa$;return function(){return t(this.data)}}))),mp.prototype.toDouble=i("kotlin.kotlin.UInt.toDouble",r((function(){var t=e.kotlin.uintToDouble_za3lpa$;return function(){return t(this.data)}}))),mp.prototype.toString=function(){return t.Long.fromInt(this.data).and(v).toString()},mp.$metadata$={kind:p,simpleName:"UInt",interfaces:[k]},mp.prototype.unbox=function(){return this.data},mp.prototype.hashCode=function(){var e=0;return 31*e+t.hashCode(this.data)|0},mp.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.data,e.data)},Object.defineProperty(gp.prototype,"start",{configurable:!0,get:function(){return this.first}}),Object.defineProperty(gp.prototype,"endInclusive",{configurable:!0,get:function(){return this.last}}),gp.prototype.contains_mef7kx$=function(t){var e=Jp(this.first.data,t.data)<=0;return e&&(e=Jp(t.data,this.last.data)<=0),e},gp.prototype.isEmpty=function(){return Jp(this.first.data,this.last.data)>0},gp.prototype.equals=function(e){var n,i;return t.isType(e,gp)&&(this.isEmpty()&&e.isEmpty()||(null!=(n=this.first)?n.equals(e.first):null)&&(null!=(i=this.last)?i.equals(e.last):null))},gp.prototype.hashCode=function(){return this.isEmpty()?-1:(31*this.first.data|0)+this.last.data|0},gp.prototype.toString=function(){return this.first.toString()+".."+this.last},bp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var wp=null;function xp(){return null===wp&&new bp,wp}function kp(t,e,n){if(Sp(),0===n)throw Mn("Step must be non-zero.");if(-2147483648===n)throw Mn("Step must be greater than Int.MIN_VALUE to avoid overflow on negation.");this.first=t,this.last=Yp(t,e,n),this.step=n}function Ep(){Cp=this}gp.$metadata$={kind:p,simpleName:"UIntRange",interfaces:[De,kp]},kp.prototype.iterator=function(){return new Tp(this.first,this.last,this.step)},kp.prototype.isEmpty=function(){return this.step>0?Jp(this.first.data,this.last.data)>0:Jp(this.first.data,this.last.data)<0},kp.prototype.equals=function(e){var n,i;return t.isType(e,kp)&&(this.isEmpty()&&e.isEmpty()||(null!=(n=this.first)?n.equals(e.first):null)&&(null!=(i=this.last)?i.equals(e.last):null)&&this.step===e.step)},kp.prototype.hashCode=function(){return this.isEmpty()?-1:(31*((31*this.first.data|0)+this.last.data|0)|0)+this.step|0},kp.prototype.toString=function(){return this.step>0?this.first.toString()+".."+this.last+" step "+this.step:this.first.toString()+" downTo "+this.last+" step "+(0|-this.step)},Ep.prototype.fromClosedRange_fjk8us$=function(t,e,n){return new kp(t,e,n)},Ep.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Cp=null;function Sp(){return null===Cp&&new Ep,Cp}function Tp(t,e,n){Op.call(this),this.finalElement_0=e,this.hasNext_0=n>0?Jp(t.data,e.data)<=0:Jp(t.data,e.data)>=0,this.step_0=new mp(n),this.next_0=this.hasNext_0?t:this.finalElement_0}function Op(){}function Np(){}function Pp(t){Lp(),this.data=t}function Ap(){jp=this,this.MIN_VALUE=new Pp(u),this.MAX_VALUE=new Pp(_),this.SIZE_BYTES=8,this.SIZE_BITS=64}kp.$metadata$={kind:p,simpleName:"UIntProgression",interfaces:[Qt]},Tp.prototype.hasNext=function(){return this.hasNext_0},Tp.prototype.nextUInt=function(){var t=this.next_0;if(null!=t&&t.equals(this.finalElement_0)){if(!this.hasNext_0)throw Zn();this.hasNext_0=!1}else this.next_0=new mp(this.next_0.data+this.step_0.data|0);return t},Tp.$metadata$={kind:p,simpleName:"UIntProgressionIterator",interfaces:[Op]},Op.prototype.next=function(){return this.nextUInt()},Op.$metadata$={kind:p,simpleName:"UIntIterator",interfaces:[pe]},Np.prototype.next=function(){return this.nextULong()},Np.$metadata$={kind:p,simpleName:"ULongIterator",interfaces:[pe]},Ap.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var jp=null;function Lp(){return null===jp&&new Ap,jp}function Rp(t,e){Dp(),Mp.call(this,t,e,w)}function Ip(){zp=this,this.EMPTY=new Rp(Lp().MAX_VALUE,Lp().MIN_VALUE)}Pp.prototype.compareTo_mpmjao$=i("kotlin.kotlin.ULong.compareTo_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(this.data,new i(t.Long.fromInt(e.data).and(n)).data)}}))),Pp.prototype.compareTo_6hrhkk$=i("kotlin.kotlin.ULong.compareTo_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(this.data,new i(t.Long.fromInt(e.data).and(n)).data)}}))),Pp.prototype.compareTo_s87ys9$=i("kotlin.kotlin.ULong.compareTo_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(this.data,new i(t.Long.fromInt(e.data).and(n)).data)}}))),Pp.prototype.compareTo_11rb$=i("kotlin.kotlin.ULong.compareTo_11rb$",r((function(){var t=e.kotlin.ulongCompare_3pjtqy$;return function(e){return t(this.data,e.data)}}))),Pp.prototype.plus_mpmjao$=i("kotlin.kotlin.ULong.plus_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(this.data.add(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.plus_6hrhkk$=i("kotlin.kotlin.ULong.plus_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(this.data.add(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.plus_s87ys9$=i("kotlin.kotlin.ULong.plus_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(this.data.add(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.plus_mpgczg$=i("kotlin.kotlin.ULong.plus_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.add(e.data))}}))),Pp.prototype.minus_mpmjao$=i("kotlin.kotlin.ULong.minus_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(this.data.subtract(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.minus_6hrhkk$=i("kotlin.kotlin.ULong.minus_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(this.data.subtract(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.minus_s87ys9$=i("kotlin.kotlin.ULong.minus_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(this.data.subtract(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.minus_mpgczg$=i("kotlin.kotlin.ULong.minus_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.subtract(e.data))}}))),Pp.prototype.times_mpmjao$=i("kotlin.kotlin.ULong.times_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong;return function(e){return new i(this.data.multiply(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.times_6hrhkk$=i("kotlin.kotlin.ULong.times_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(this.data.multiply(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.times_s87ys9$=i("kotlin.kotlin.ULong.times_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong;return function(e){return new i(this.data.multiply(new i(t.Long.fromInt(e.data).and(n)).data))}}))),Pp.prototype.times_mpgczg$=i("kotlin.kotlin.ULong.times_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.multiply(e.data))}}))),Pp.prototype.div_mpmjao$=i("kotlin.kotlin.ULong.div_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.div_6hrhkk$=i("kotlin.kotlin.ULong.div_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.div_s87ys9$=i("kotlin.kotlin.ULong.div_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.div_mpgczg$=i("kotlin.kotlin.ULong.div_mpgczg$",r((function(){var t=e.kotlin.ulongDivide_jpm79w$;return function(e){return t(this,e)}}))),Pp.prototype.rem_mpmjao$=i("kotlin.kotlin.ULong.rem_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.rem_6hrhkk$=i("kotlin.kotlin.ULong.rem_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.rem_s87ys9$=i("kotlin.kotlin.ULong.rem_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.rem_mpgczg$=i("kotlin.kotlin.ULong.rem_mpgczg$",r((function(){var t=e.kotlin.ulongRemainder_jpm79w$;return function(e){return t(this,e)}}))),Pp.prototype.floorDiv_mpmjao$=i("kotlin.kotlin.ULong.floorDiv_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.floorDiv_6hrhkk$=i("kotlin.kotlin.ULong.floorDiv_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.floorDiv_s87ys9$=i("kotlin.kotlin.ULong.floorDiv_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(this,new i(t.Long.fromInt(e.data).and(n)))}}))),Pp.prototype.floorDiv_mpgczg$=i("kotlin.kotlin.ULong.floorDiv_mpgczg$",r((function(){var t=e.kotlin.ulongDivide_jpm79w$;return function(e){return t(this,e)}}))),Pp.prototype.mod_mpmjao$=i("kotlin.kotlin.ULong.mod_mpmjao$",r((function(){var n=t.Long.fromInt(255),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$,o=t.toByte,a=e.kotlin.UByte;return function(e){return new a(o(r(this,new i(t.Long.fromInt(e.data).and(n))).data.toInt()))}}))),Pp.prototype.mod_6hrhkk$=i("kotlin.kotlin.ULong.mod_6hrhkk$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$,o=t.toShort,a=e.kotlin.UShort;return function(e){return new a(o(r(this,new i(t.Long.fromInt(e.data).and(n))).data.toInt()))}}))),Pp.prototype.mod_s87ys9$=i("kotlin.kotlin.ULong.mod_s87ys9$",r((function(){var n=new t.Long(-1,0),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$,o=e.kotlin.UInt;return function(e){return new o(r(this,new i(t.Long.fromInt(e.data).and(n))).data.toInt())}}))),Pp.prototype.mod_mpgczg$=i("kotlin.kotlin.ULong.mod_mpgczg$",r((function(){var t=e.kotlin.ulongRemainder_jpm79w$;return function(e){return t(this,e)}}))),Pp.prototype.inc=i("kotlin.kotlin.ULong.inc",r((function(){var t=e.kotlin.ULong;return function(){return new t(this.data.inc())}}))),Pp.prototype.dec=i("kotlin.kotlin.ULong.dec",r((function(){var t=e.kotlin.ULong;return function(){return new t(this.data.dec())}}))),Pp.prototype.rangeTo_mpgczg$=i("kotlin.kotlin.ULong.rangeTo_mpgczg$",r((function(){var t=e.kotlin.ranges.ULongRange;return function(e){return new t(this,e)}}))),Pp.prototype.shl_za3lpa$=i("kotlin.kotlin.ULong.shl_za3lpa$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.shiftLeft(e))}}))),Pp.prototype.shr_za3lpa$=i("kotlin.kotlin.ULong.shr_za3lpa$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.shiftRightUnsigned(e))}}))),Pp.prototype.and_mpgczg$=i("kotlin.kotlin.ULong.and_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.and(e.data))}}))),Pp.prototype.or_mpgczg$=i("kotlin.kotlin.ULong.or_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.or(e.data))}}))),Pp.prototype.xor_mpgczg$=i("kotlin.kotlin.ULong.xor_mpgczg$",r((function(){var t=e.kotlin.ULong;return function(e){return new t(this.data.xor(e.data))}}))),Pp.prototype.inv=i("kotlin.kotlin.ULong.inv",r((function(){var t=e.kotlin.ULong;return function(){return new t(this.data.inv())}}))),Pp.prototype.toByte=i("kotlin.kotlin.ULong.toByte",r((function(){var e=t.toByte;return function(){return e(this.data.toInt())}}))),Pp.prototype.toShort=i("kotlin.kotlin.ULong.toShort",r((function(){var e=t.toShort;return function(){return e(this.data.toInt())}}))),Pp.prototype.toInt=i("kotlin.kotlin.ULong.toInt",(function(){return this.data.toInt()})),Pp.prototype.toLong=i("kotlin.kotlin.ULong.toLong",(function(){return this.data})),Pp.prototype.toUByte=i("kotlin.kotlin.ULong.toUByte",r((function(){var n=t.toByte,i=e.kotlin.UByte;return function(){return new i(n(this.data.toInt()))}}))),Pp.prototype.toUShort=i("kotlin.kotlin.ULong.toUShort",r((function(){var n=t.toShort,i=e.kotlin.UShort;return function(){return new i(n(this.data.toInt()))}}))),Pp.prototype.toUInt=i("kotlin.kotlin.ULong.toUInt",r((function(){var t=e.kotlin.UInt;return function(){return new t(this.data.toInt())}}))),Pp.prototype.toULong=i("kotlin.kotlin.ULong.toULong",(function(){return this})),Pp.prototype.toFloat=i("kotlin.kotlin.ULong.toFloat",r((function(){var t=e.kotlin.ulongToDouble_s8cxhz$;return function(){return t(this.data)}}))),Pp.prototype.toDouble=i("kotlin.kotlin.ULong.toDouble",r((function(){var t=e.kotlin.ulongToDouble_s8cxhz$;return function(){return t(this.data)}}))),Pp.prototype.toString=function(){return nh(this.data)},Pp.$metadata$={kind:p,simpleName:"ULong",interfaces:[k]},Pp.prototype.unbox=function(){return this.data},Pp.prototype.hashCode=function(){var e=0;return 31*e+t.hashCode(this.data)|0},Pp.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.data,e.data)},Object.defineProperty(Rp.prototype,"start",{configurable:!0,get:function(){return this.first}}),Object.defineProperty(Rp.prototype,"endInclusive",{configurable:!0,get:function(){return this.last}}),Rp.prototype.contains_mef7kx$=function(t){var e=Qp(this.first.data,t.data)<=0;return e&&(e=Qp(t.data,this.last.data)<=0),e},Rp.prototype.isEmpty=function(){return Qp(this.first.data,this.last.data)>0},Rp.prototype.equals=function(e){var n,i;return t.isType(e,Rp)&&(this.isEmpty()&&e.isEmpty()||(null!=(n=this.first)?n.equals(e.first):null)&&(null!=(i=this.last)?i.equals(e.last):null))},Rp.prototype.hashCode=function(){return this.isEmpty()?-1:(31*new Pp(this.first.data.xor(new Pp(this.first.data.shiftRightUnsigned(32)).data)).data.toInt()|0)+new Pp(this.last.data.xor(new Pp(this.last.data.shiftRightUnsigned(32)).data)).data.toInt()|0},Rp.prototype.toString=function(){return this.first.toString()+".."+this.last},Ip.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var zp=null;function Dp(){return null===zp&&new Ip,zp}function Mp(t,e,n){if(Fp(),o(n,u))throw Mn("Step must be non-zero.");if(o(n,m))throw Mn("Step must be greater than Long.MIN_VALUE to avoid overflow on negation.");this.first=t,this.last=Vp(t,e,n),this.step=n}function Bp(){Up=this}Rp.$metadata$={kind:p,simpleName:"ULongRange",interfaces:[De,Mp]},Mp.prototype.iterator=function(){return new qp(this.first,this.last,this.step)},Mp.prototype.isEmpty=function(){return this.step.toNumber()>0?Qp(this.first.data,this.last.data)>0:Qp(this.first.data,this.last.data)<0},Mp.prototype.equals=function(e){var n,i;return t.isType(e,Mp)&&(this.isEmpty()&&e.isEmpty()||(null!=(n=this.first)?n.equals(e.first):null)&&(null!=(i=this.last)?i.equals(e.last):null)&&o(this.step,e.step))},Mp.prototype.hashCode=function(){return this.isEmpty()?-1:(31*((31*new Pp(this.first.data.xor(new Pp(this.first.data.shiftRightUnsigned(32)).data)).data.toInt()|0)+new Pp(this.last.data.xor(new Pp(this.last.data.shiftRightUnsigned(32)).data)).data.toInt()|0)|0)+this.step.xor(this.step.shiftRightUnsigned(32)).toInt()|0},Mp.prototype.toString=function(){return this.step.toNumber()>0?this.first.toString()+".."+this.last+" step "+this.step.toString():this.first.toString()+" downTo "+this.last+" step "+this.step.unaryMinus().toString()},Bp.prototype.fromClosedRange_15zasp$=function(t,e,n){return new Mp(t,e,n)},Bp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Up=null;function Fp(){return null===Up&&new Bp,Up}function qp(t,e,n){Np.call(this),this.finalElement_0=e,this.hasNext_0=n.toNumber()>0?Qp(t.data,e.data)<=0:Qp(t.data,e.data)>=0,this.step_0=new Pp(n),this.next_0=this.hasNext_0?t:this.finalElement_0}function Gp(t,e,n){var i=th(t,n),r=th(e,n);return Jp(i.data,r.data)>=0?new mp(i.data-r.data|0):new mp(new mp(i.data-r.data|0).data+n.data|0)}function Hp(t,e,n){var i=eh(t,n),r=eh(e,n);return Qp(i.data,r.data)>=0?new Pp(i.data.subtract(r.data)):new Pp(new Pp(i.data.subtract(r.data)).data.add(n.data))}function Yp(t,e,n){if(n>0)return Jp(t.data,e.data)>=0?e:new mp(e.data-Gp(e,t,new mp(n)).data|0);if(n<0)return Jp(t.data,e.data)<=0?e:new mp(e.data+Gp(t,e,new mp(0|-n)).data|0);throw Mn("Step is zero.")}function Vp(t,e,n){if(n.toNumber()>0)return Qp(t.data,e.data)>=0?e:new Pp(e.data.subtract(Hp(e,t,new Pp(n)).data));if(n.toNumber()<0)return Qp(t.data,e.data)<=0?e:new Pp(e.data.add(Hp(t,e,new Pp(n.unaryMinus())).data));throw Mn("Step is zero.")}function Kp(t){Zp(),this.data=t}function Wp(){Xp=this,this.MIN_VALUE=new Kp(0),this.MAX_VALUE=new Kp(-1),this.SIZE_BYTES=2,this.SIZE_BITS=16}Mp.$metadata$={kind:p,simpleName:"ULongProgression",interfaces:[Qt]},qp.prototype.hasNext=function(){return this.hasNext_0},qp.prototype.nextULong=function(){var t=this.next_0;if(null!=t&&t.equals(this.finalElement_0)){if(!this.hasNext_0)throw Zn();this.hasNext_0=!1}else this.next_0=new Pp(this.next_0.data.add(this.step_0.data));return t},qp.$metadata$={kind:p,simpleName:"ULongProgressionIterator",interfaces:[Np]},Wp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Xp=null;function Zp(){return null===Xp&&new Wp,Xp}function Jp(e,n){return t.primitiveCompareTo(-2147483648^e,-2147483648^n)}function Qp(t,e){return t.xor(m).compareTo_11rb$(e.xor(m))}function th(e,n){return new mp(t.Long.fromInt(e.data).and(v).modulo(t.Long.fromInt(n.data).and(v)).toInt())}function eh(t,e){var n=t.data,i=e.data;if(i.toNumber()<0)return Qp(t.data,e.data)<0?t:new Pp(t.data.subtract(e.data));if(n.toNumber()>=0)return new Pp(n.modulo(i));var r=n.shiftRightUnsigned(1).div(i).shiftLeft(1),o=n.subtract(r.multiply(i));return new Pp(o.subtract(Qp(new Pp(o).data,new Pp(i).data)>=0?i:u))}function nh(t){return ih(t,10)}function ih(e,n){if(e.toNumber()>=0)return oi(e,n);var i=e.shiftRightUnsigned(1).div(t.Long.fromInt(n)).shiftLeft(1),r=e.subtract(i.multiply(t.Long.fromInt(n)));return r.toNumber()>=n&&(r=r.subtract(t.Long.fromInt(n)),i=i.add(t.Long.fromInt(1))),oi(i,n)+oi(r,n)}Kp.prototype.compareTo_mpmjao$=i("kotlin.kotlin.UShort.compareTo_mpmjao$",(function(e){return t.primitiveCompareTo(65535&this.data,255&e.data)})),Kp.prototype.compareTo_11rb$=i("kotlin.kotlin.UShort.compareTo_11rb$",(function(e){return t.primitiveCompareTo(65535&this.data,65535&e.data)})),Kp.prototype.compareTo_s87ys9$=i("kotlin.kotlin.UShort.compareTo_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintCompare_vux9f0$;return function(e){return n(new t(65535&this.data).data,e.data)}}))),Kp.prototype.compareTo_mpgczg$=i("kotlin.kotlin.UShort.compareTo_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongCompare_3pjtqy$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)).data,e.data)}}))),Kp.prototype.plus_mpmjao$=i("kotlin.kotlin.UShort.plus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data+new t(255&e.data).data|0)}}))),Kp.prototype.plus_6hrhkk$=i("kotlin.kotlin.UShort.plus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data+new t(65535&e.data).data|0)}}))),Kp.prototype.plus_s87ys9$=i("kotlin.kotlin.UShort.plus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data+e.data|0)}}))),Kp.prototype.plus_mpgczg$=i("kotlin.kotlin.UShort.plus_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.add(e.data))}}))),Kp.prototype.minus_mpmjao$=i("kotlin.kotlin.UShort.minus_mpmjao$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data-new t(255&e.data).data|0)}}))),Kp.prototype.minus_6hrhkk$=i("kotlin.kotlin.UShort.minus_6hrhkk$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data-new t(65535&e.data).data|0)}}))),Kp.prototype.minus_s87ys9$=i("kotlin.kotlin.UShort.minus_s87ys9$",r((function(){var t=e.kotlin.UInt;return function(e){return new t(new t(65535&this.data).data-e.data|0)}}))),Kp.prototype.minus_mpgczg$=i("kotlin.kotlin.UShort.minus_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.subtract(e.data))}}))),Kp.prototype.times_mpmjao$=i("kotlin.kotlin.UShort.times_mpmjao$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(65535&this.data).data,new n(255&e.data).data))}}))),Kp.prototype.times_6hrhkk$=i("kotlin.kotlin.UShort.times_6hrhkk$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(65535&this.data).data,new n(65535&e.data).data))}}))),Kp.prototype.times_s87ys9$=i("kotlin.kotlin.UShort.times_s87ys9$",r((function(){var n=e.kotlin.UInt;return function(e){return new n(t.imul(new n(65535&this.data).data,e.data))}}))),Kp.prototype.times_mpgczg$=i("kotlin.kotlin.UShort.times_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(e){return new i(new i(t.Long.fromInt(this.data).and(n)).data.multiply(e.data))}}))),Kp.prototype.div_mpmjao$=i("kotlin.kotlin.UShort.div_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),new t(255&e.data))}}))),Kp.prototype.div_6hrhkk$=i("kotlin.kotlin.UShort.div_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),new t(65535&e.data))}}))),Kp.prototype.div_s87ys9$=i("kotlin.kotlin.UShort.div_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),e)}}))),Kp.prototype.div_mpgczg$=i("kotlin.kotlin.UShort.div_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),Kp.prototype.rem_mpmjao$=i("kotlin.kotlin.UShort.rem_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(65535&this.data),new t(255&e.data))}}))),Kp.prototype.rem_6hrhkk$=i("kotlin.kotlin.UShort.rem_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(65535&this.data),new t(65535&e.data))}}))),Kp.prototype.rem_s87ys9$=i("kotlin.kotlin.UShort.rem_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(65535&this.data),e)}}))),Kp.prototype.rem_mpgczg$=i("kotlin.kotlin.UShort.rem_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),Kp.prototype.floorDiv_mpmjao$=i("kotlin.kotlin.UShort.floorDiv_mpmjao$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),new t(255&e.data))}}))),Kp.prototype.floorDiv_6hrhkk$=i("kotlin.kotlin.UShort.floorDiv_6hrhkk$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),new t(65535&e.data))}}))),Kp.prototype.floorDiv_s87ys9$=i("kotlin.kotlin.UShort.floorDiv_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintDivide_oqfnby$;return function(e){return n(new t(65535&this.data),e)}}))),Kp.prototype.floorDiv_mpgczg$=i("kotlin.kotlin.UShort.floorDiv_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongDivide_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),Kp.prototype.mod_mpmjao$=i("kotlin.kotlin.UShort.mod_mpmjao$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toByte,o=e.kotlin.UByte;return function(t){return new o(r(i(new n(65535&this.data),new n(255&t.data)).data))}}))),Kp.prototype.mod_6hrhkk$=i("kotlin.kotlin.UShort.mod_6hrhkk$",r((function(){var n=e.kotlin.UInt,i=e.kotlin.uintRemainder_oqfnby$,r=t.toShort,o=e.kotlin.UShort;return function(t){return new o(r(i(new n(65535&this.data),new n(65535&t.data)).data))}}))),Kp.prototype.mod_s87ys9$=i("kotlin.kotlin.UShort.mod_s87ys9$",r((function(){var t=e.kotlin.UInt,n=e.kotlin.uintRemainder_oqfnby$;return function(e){return n(new t(65535&this.data),e)}}))),Kp.prototype.mod_mpgczg$=i("kotlin.kotlin.UShort.mod_mpgczg$",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong,r=e.kotlin.ulongRemainder_jpm79w$;return function(e){return r(new i(t.Long.fromInt(this.data).and(n)),e)}}))),Kp.prototype.inc=i("kotlin.kotlin.UShort.inc",r((function(){var n=t.toShort,i=e.kotlin.UShort;return function(){return new i(n(this.data+1))}}))),Kp.prototype.dec=i("kotlin.kotlin.UShort.dec",r((function(){var n=t.toShort,i=e.kotlin.UShort;return function(){return new i(n(this.data-1))}}))),Kp.prototype.rangeTo_6hrhkk$=i("kotlin.kotlin.UShort.rangeTo_6hrhkk$",r((function(){var t=e.kotlin.ranges.UIntRange,n=e.kotlin.UInt;return function(e){return new t(new n(65535&this.data),new n(65535&e.data))}}))),Kp.prototype.and_6hrhkk$=i("kotlin.kotlin.UShort.and_6hrhkk$",r((function(){var n=e.kotlin.UShort,i=t.toShort;return function(t){return new n(i(this.data&t.data))}}))),Kp.prototype.or_6hrhkk$=i("kotlin.kotlin.UShort.or_6hrhkk$",r((function(){var n=e.kotlin.UShort,i=t.toShort;return function(t){return new n(i(this.data|t.data))}}))),Kp.prototype.xor_6hrhkk$=i("kotlin.kotlin.UShort.xor_6hrhkk$",r((function(){var n=e.kotlin.UShort,i=t.toShort;return function(t){return new n(i(this.data^t.data))}}))),Kp.prototype.inv=i("kotlin.kotlin.UShort.inv",r((function(){var n=e.kotlin.UShort,i=t.toShort;return function(){return new n(i(~this.data))}}))),Kp.prototype.toByte=i("kotlin.kotlin.UShort.toByte",r((function(){var e=t.toByte;return function(){return e(this.data)}}))),Kp.prototype.toShort=i("kotlin.kotlin.UShort.toShort",(function(){return this.data})),Kp.prototype.toInt=i("kotlin.kotlin.UShort.toInt",(function(){return 65535&this.data})),Kp.prototype.toLong=i("kotlin.kotlin.UShort.toLong",r((function(){var e=t.Long.fromInt(65535);return function(){return t.Long.fromInt(this.data).and(e)}}))),Kp.prototype.toUByte=i("kotlin.kotlin.UShort.toUByte",r((function(){var n=t.toByte,i=e.kotlin.UByte;return function(){return new i(n(this.data))}}))),Kp.prototype.toUShort=i("kotlin.kotlin.UShort.toUShort",(function(){return this})),Kp.prototype.toUInt=i("kotlin.kotlin.UShort.toUInt",r((function(){var t=e.kotlin.UInt;return function(){return new t(65535&this.data)}}))),Kp.prototype.toULong=i("kotlin.kotlin.UShort.toULong",r((function(){var n=t.Long.fromInt(65535),i=e.kotlin.ULong;return function(){return new i(t.Long.fromInt(this.data).and(n))}}))),Kp.prototype.toFloat=i("kotlin.kotlin.UShort.toFloat",(function(){return 65535&this.data})),Kp.prototype.toDouble=i("kotlin.kotlin.UShort.toDouble",(function(){return 65535&this.data})),Kp.prototype.toString=function(){return(65535&this.data).toString()},Kp.$metadata$={kind:p,simpleName:"UShort",interfaces:[k]},Kp.prototype.unbox=function(){return this.data},Kp.prototype.hashCode=function(){var e=0;return 31*e+t.hashCode(this.data)|0},Kp.prototype.equals=function(e){return this===e||null!==e&&"object"==typeof e&&Object.getPrototypeOf(this)===Object.getPrototypeOf(e)&&t.equals(this.data,e.data)};var rh=e.kotlin||(e.kotlin={}),oh=rh.collections||(rh.collections={});oh.contains_mjy6jw$=B,oh.contains_o2f9me$=U,oh.get_lastIndex_m7z4lg$=X,oh.get_lastIndex_bvy38s$=Z,oh.indexOf_mjy6jw$=F,oh.indexOf_o2f9me$=q,oh.get_indices_m7z4lg$=W;var ah=rh.ranges||(rh.ranges={});ah.reversed_zf1xzc$=Nt,oh.get_indices_bvy38s$=function(t){return new qe(0,Z(t))},oh.last_us0mfu$=function(t){if(0===t.length)throw new Xn("Array is empty.");return t[X(t)]},oh.lastIndexOf_mjy6jw$=G;var sh=rh.random||(rh.random={});sh.Random=ju,oh.single_355ntz$=H,rh.IllegalArgumentException_init_pdl1vj$=Mn,oh.dropLast_8ujjk8$=function(t,e){if(!(e>=0))throw Mn(("Requested element count "+e+" is less than zero.").toString());return K(t,At(t.length-e|0,0))},oh.take_8ujjk8$=K,oh.emptyList_287e2$=$s,oh.ArrayList_init_287e2$=Ki,oh.filterNotNull_emfgvx$=Y,oh.filterNotNullTo_hhiqfl$=V,oh.toList_us0mfu$=Q,oh.sortWith_iwcb0m$=pi,oh.mapCapacity_za3lpa$=ji,ah.coerceAtLeast_dqglrj$=At,oh.LinkedHashMap_init_bwtc7$=Ar,ah.coerceAtMost_dqglrj$=jt,oh.toCollection_5n4o2z$=J,oh.toMutableList_us0mfu$=tt,oh.toMutableList_bvy38s$=function(t){var e,n=Wi(t.length);for(e=0;e!==t.length;++e){var i=t[e];n.add_11rb$(i)}return n},oh.toSet_us0mfu$=et,oh.addAll_ipc267$=Ws,oh.LinkedHashMap_init_q3lmfv$=Nr,oh.Grouping=Ss,oh.ArrayList_init_ww73n8$=Wi,oh.HashSet_init_287e2$=$r,rh.NoSuchElementException_init=Zn,rh.UnsupportedOperationException_init_pdl1vj$=Hn,oh.listOf_mh5how$=ki,oh.collectionSizeOrDefault_ba2ldo$=Ps,oh.zip_pmvpm9$=function(t,e){for(var n=c.min(t.length,e.length),i=Wi(n),r=0;r=0&&e<=ws(t)?t.get_za3lpa$(e):null},oh.first_7wnvza$=lt,oh.first_2p1efm$=ut,oh.firstOrNull_7wnvza$=function(e){if(t.isType(e,ie))return e.isEmpty()?null:e.get_za3lpa$(0);var n=e.iterator();return n.hasNext()?n.next():null},oh.firstOrNull_2p1efm$=function(t){return t.isEmpty()?null:t.get_za3lpa$(0)},oh.indexOf_2ws7j4$=ct,oh.checkIndexOverflow_za3lpa$=Pi,oh.last_7wnvza$=pt,oh.last_2p1efm$=ht,oh.lastOrNull_2p1efm$=function(t){return t.isEmpty()?null:t.get_za3lpa$(t.size-1|0)},oh.random_iscd7z$=function(t,e){if(t.isEmpty())throw new Xn("Collection is empty.");return at(t,e.nextInt_za3lpa$(t.size))},oh.single_7wnvza$=_t,oh.single_2p1efm$=ft,oh.drop_ba2ldo$=function(e,n){var i,r,o,a;if(!(n>=0))throw Mn(("Requested element count "+n+" is less than zero.").toString());if(0===n)return gt(e);if(t.isType(e,ee)){var s=e.size-n|0;if(s<=0)return $s();if(1===s)return ki(pt(e));if(a=Wi(s),t.isType(e,ie)){if(t.isType(e,Mr)){i=e.size;for(var l=n;l=n?a.add_11rb$(p):c=c+1|0}return xs(a)},oh.take_ba2ldo$=function(e,n){var i;if(!(n>=0))throw Mn(("Requested element count "+n+" is less than zero.").toString());if(0===n)return $s();if(t.isType(e,ee)){if(n>=e.size)return gt(e);if(1===n)return ki(lt(e))}var r=0,o=Wi(n);for(i=e.iterator();i.hasNext();){var a=i.next();if(o.add_11rb$(a),(r=r+1|0)===n)break}return xs(o)},oh.filterNotNull_m3lr2h$=function(t){return dt(t,Ki())},oh.filterNotNullTo_u9kwcl$=dt,oh.toList_7wnvza$=gt,oh.reversed_7wnvza$=function(e){if(t.isType(e,ee)&&e.size<=1)return gt(e);var n=bt(e);return hi(n),n},oh.shuffle_9jeydg$=mt,oh.sortWith_nqfjgj$=Ti,oh.sorted_exjks8$=function(e){var n;if(t.isType(e,ee)){if(e.size<=1)return gt(e);var i=t.isArray(n=bi(e))?n:Yr();return ci(i),ai(i)}var r=bt(e);return Si(r),r},oh.sortedWith_eknfly$=yt,oh.sortedDescending_exjks8$=function(t){return yt(t,Zl())},oh.toByteArray_kdx1v$=function(t){var e,n,i=new Int8Array(t.size),r=0;for(e=t.iterator();e.hasNext();){var o=e.next();i[(n=r,r=n+1|0,n)]=o}return i},oh.toDoubleArray_tcduak$=function(t){var e,n,i=new Float64Array(t.size),r=0;for(e=t.iterator();e.hasNext();){var o=e.next();i[(n=r,r=n+1|0,n)]=o}return i},oh.toLongArray_558emf$=function(e){var n,i,r=t.longArray(e.size),o=0;for(n=e.iterator();n.hasNext();){var a=n.next();r[(i=o,o=i+1|0,i)]=a}return r},oh.toCollection_5cfyqp$=$t,oh.toHashSet_7wnvza$=vt,oh.toMutableList_7wnvza$=bt,oh.toMutableList_4c7yge$=wt,oh.toSet_7wnvza$=xt,oh.withIndex_7wnvza$=function(t){return new Os((e=t,function(){return e.iterator()}));var e},oh.distinct_7wnvza$=function(t){return gt(kt(t))},oh.intersect_q4559j$=function(t,e){var n=kt(t);return Zs(n,e),n},oh.subtract_q4559j$=function(t,e){var n=kt(t);return Xs(n,e),n},oh.toMutableSet_7wnvza$=kt,oh.Collection=ee,oh.count_7wnvza$=function(e){var n;if(t.isType(e,ee))return e.size;var i=0;for(n=e.iterator();n.hasNext();)n.next(),Ai(i=i+1|0);return i},oh.checkCountOverflow_za3lpa$=Ai,oh.maxOrNull_l63kqw$=function(t){var e=t.iterator();if(!e.hasNext())return null;for(var n=e.next();e.hasNext();){var i=e.next();n=c.max(n,i)}return n},oh.minOrNull_l63kqw$=function(t){var e=t.iterator();if(!e.hasNext())return null;for(var n=e.next();e.hasNext();){var i=e.next();n=c.min(n,i)}return n},oh.requireNoNulls_whsx6z$=function(e){var n,i;for(n=e.iterator();n.hasNext();)if(null==n.next())throw Mn("null element found in "+e+".");return t.isType(i=e,ie)?i:Yr()},oh.minus_q4559j$=function(t,e){var n=As(e,t);if(n.isEmpty())return gt(t);var i,r=Ki();for(i=t.iterator();i.hasNext();){var o=i.next();n.contains_11rb$(o)||r.add_11rb$(o)}return r},oh.plus_qloxvw$=function(t,e){var n=Wi(t.size+1|0);return n.addAll_brywnq$(t),n.add_11rb$(e),n},oh.plus_q4559j$=function(e,n){if(t.isType(e,ee))return Et(e,n);var i=Ki();return Ws(i,e),Ws(i,n),i},oh.plus_mydzjv$=Et,oh.windowed_vo9c23$=function(e,n,i,r){var o;if(void 0===i&&(i=1),void 0===r&&(r=!1),Fl(n,i),t.isType(e,Mr)&&t.isType(e,ie)){for(var a=e.size,s=Wi((a/i|0)+(a%i==0?0:1)|0),l={v:0};0<=(o=l.v)&&o0?e:t},ah.coerceAtMost_38ydlf$=function(t,e){return t>e?e:t},ah.coerceIn_e4yvb3$=Lt,ah.coerceIn_ekzx8g$=function(t,e,n){if(e.compareTo_11rb$(n)>0)throw Mn("Cannot coerce value to an empty range: maximum "+n.toString()+" is less than minimum "+e.toString()+".");return t.compareTo_11rb$(e)<0?e:t.compareTo_11rb$(n)>0?n:t},ah.coerceIn_nig4hr$=function(t,e,n){if(e>n)throw Mn("Cannot coerce value to an empty range: maximum "+n+" is less than minimum "+e+".");return tn?n:t};var ch=rh.sequences||(rh.sequences={});ch.first_veqyi0$=function(t){var e=t.iterator();if(!e.hasNext())throw new Xn("Sequence is empty.");return e.next()},ch.firstOrNull_veqyi0$=function(t){var e=t.iterator();return e.hasNext()?e.next():null},ch.drop_wuwhe2$=function(e,n){if(!(n>=0))throw Mn(("Requested element count "+n+" is less than zero.").toString());return 0===n?e:t.isType(e,El)?e.drop_za3lpa$(n):new Nl(e,n)},ch.filter_euau3h$=function(t,e){return new yl(t,!0,e)},ch.Sequence=nl,ch.filterNot_euau3h$=It,ch.filterNotNull_q2m9h7$=Dt,ch.take_wuwhe2$=Mt,ch.sortedWith_vjgqpk$=function(t,e){return new Bt(t,e)},ch.toCollection_gtszxp$=Ut,ch.toHashSet_veqyi0$=function(t){return Ut(t,$r())},ch.toList_veqyi0$=Ft,ch.toMutableList_veqyi0$=qt,ch.toSet_veqyi0$=function(t){return Bl(Ut(t,Rr()))},ch.map_z5avom$=Gt,ch.mapNotNull_qpz9h9$=function(t,e){return Dt(new vl(t,e))},ch.count_veqyi0$=function(t){var e,n=0;for(e=t.iterator();e.hasNext();)e.next(),Ai(n=n+1|0);return n},ch.maxOrNull_1bslqu$=function(t){var e=t.iterator();if(!e.hasNext())return null;for(var n=e.next();e.hasNext();){var i=e.next();n=c.max(n,i)}return n},ch.minOrNull_1bslqu$=function(t){var e=t.iterator();if(!e.hasNext())return null;for(var n=e.next();e.hasNext();){var i=e.next();n=c.min(n,i)}return n},ch.chunked_wuwhe2$=function(t,e){return Ht(t,e,e,!0)},ch.plus_v0iwhp$=function(t,e){return _l(sl([t,e]))},ch.windowed_1ll6yl$=Ht,ch.zip_r7q3s9$=function(t,e){return new bl(t,e,Yt)},ch.joinTo_q99qgx$=Vt,ch.joinToString_853xkz$=function(t,e,n,i,r,o,a){return void 0===e&&(e=", "),void 0===n&&(n=""),void 0===i&&(i=""),void 0===r&&(r=-1),void 0===o&&(o="..."),void 0===a&&(a=null),Vt(t,Qo(),e,n,i,r,o,a).toString()},ch.asIterable_veqyi0$=Kt,oh.minus_khz7k3$=function(e,n){var i=As(n,e);if(i.isEmpty())return xt(e);if(t.isType(i,oe)){var r,o=Rr();for(r=e.iterator();r.hasNext();){var a=r.next();i.contains_11rb$(a)||o.add_11rb$(a)}return o}var s=Ir(e);return s.removeAll_brywnq$(i),s},oh.plus_xfiyik$=function(t,e){var n=Dr(t.size+1|0);return n.addAll_brywnq$(t),n.add_11rb$(e),n},oh.plus_khz7k3$=function(t,e){var n,i,r=Dr(null!=(i=null!=(n=Ns(e))?t.size+n|0:null)?i:2*t.size|0);return r.addAll_brywnq$(t),Ws(r,e),r},uh.get_lastIndex_gw00vp$=gc,uh.iterator_gw00vp$=$c,uh.get_indices_gw00vp$=vc,uh.dropLast_6ic1pp$=function(t,e){if(!(e>=0))throw Mn(("Requested character count "+e+" is less than zero.").toString());return Xt(t,At(t.length-e|0,0))},uh.StringBuilder_init=Qo,uh.slice_fc3b62$=function(t,e){return e.isEmpty()?"":bc(t,e)},uh.take_6ic1pp$=Xt,uh.reversed_gw00vp$=function(t){return Jo(t).reverse()},uh.asSequence_gw00vp$=function(t){var e,n="string"==typeof t;return n&&(n=0===t.length),n?ll():new Wt((e=t,function(){return $c(e)}))},rh.UInt=mp,rh.ULong=Pp,rh.UByte=hp,rh.UShort=Kp,oh.copyOf_mrm5p$=function(t,e){if(!(e>=0))throw Mn(("Invalid new array size: "+e+".").toString());return ii(t,new Int8Array(e))},oh.copyOfRange_ietg8x$=function(t,e,n){return Za().checkRangeIndexes_cub51b$(e,n,t.length),t.slice(e,n)};var ph=rh.js||(rh.js={}),hh=rh.math||(rh.math={});Object.defineProperty(hh,"PI",{get:function(){return n}}),rh.Annotation=Zt,rh.CharSequence=Jt,oh.Iterable=Qt,oh.MutableIterable=te,oh.MutableCollection=ne,oh.List=ie,oh.MutableList=re,oh.Set=oe,oh.MutableSet=ae,se.Entry=le,oh.Map=se,ue.MutableEntry=ce,oh.MutableMap=ue,oh.Iterator=pe,oh.MutableIterator=he,oh.ListIterator=_e,oh.MutableListIterator=fe,oh.ByteIterator=de,oh.CharIterator=me,oh.ShortIterator=ye,oh.IntIterator=$e,oh.LongIterator=ve,oh.FloatIterator=ge,oh.DoubleIterator=be,oh.BooleanIterator=we,ah.CharProgressionIterator=xe,ah.IntProgressionIterator=ke,ah.LongProgressionIterator=Ee,Object.defineProperty(Ce,"Companion",{get:Oe}),ah.CharProgression=Ce,Object.defineProperty(Ne,"Companion",{get:je}),ah.IntProgression=Ne,Object.defineProperty(Le,"Companion",{get:ze}),ah.LongProgression=Le,ah.ClosedRange=De,Object.defineProperty(Me,"Companion",{get:Fe}),ah.CharRange=Me,Object.defineProperty(qe,"Companion",{get:Ye}),ah.IntRange=qe,Object.defineProperty(Ve,"Companion",{get:Xe}),ah.LongRange=Ve,Object.defineProperty(rh,"Unit",{get:Qe});var _h=rh.internal||(rh.internal={});_h.getProgressionLastElement_qt1dr2$=on,_h.getProgressionLastElement_b9bd0d$=an,e.arrayIterator=function(t,e){if(null==e)return new sn(t);switch(e){case"BooleanArray":return un(t);case"ByteArray":return pn(t);case"ShortArray":return _n(t);case"CharArray":return dn(t);case"IntArray":return yn(t);case"LongArray":return xn(t);case"FloatArray":return vn(t);case"DoubleArray":return bn(t);default:throw Un("Unsupported type argument for arrayIterator: "+$(e))}},e.booleanArrayIterator=un,e.byteArrayIterator=pn,e.shortArrayIterator=_n,e.charArrayIterator=dn,e.intArrayIterator=yn,e.floatArrayIterator=vn,e.doubleArrayIterator=bn,e.longArrayIterator=xn,e.noWhenBranchMatched=function(){throw ti()},e.subSequence=function(t,e,n){return"string"==typeof t?t.substring(e,n):t.subSequence_vux9f0$(e,n)},e.captureStack=function(t,e){Error.captureStackTrace?Error.captureStackTrace(e):e.stack=(new Error).stack},e.newThrowable=function(t,e){var n,i=new Error;return n=o(typeof t,"undefined")?null!=e?e.toString():null:t,i.message=n,i.cause=e,i.name="Throwable",i},e.BoxedChar=kn,e.charArrayOf=function(){var t="CharArray",e=new Uint16Array([].slice.call(arguments));return e.$type$=t,e};var fh=rh.coroutines||(rh.coroutines={});fh.CoroutineImpl=En,Object.defineProperty(fh,"CompletedContinuation",{get:Tn});var dh=fh.intrinsics||(fh.intrinsics={});dh.createCoroutineUnintercepted_x18nsh$=Nn,dh.createCoroutineUnintercepted_3a617i$=Pn,dh.intercepted_f9mg25$=An,rh.Error_init_pdl1vj$=Ln,rh.Error=jn,rh.Exception_init_pdl1vj$=function(t,e){return e=e||Object.create(Rn.prototype),Rn.call(e,t,null),e},rh.Exception=Rn,rh.RuntimeException_init=function(t){return t=t||Object.create(In.prototype),In.call(t,null,null),t},rh.RuntimeException_init_pdl1vj$=zn,rh.RuntimeException=In,rh.IllegalArgumentException_init=function(t){return t=t||Object.create(Dn.prototype),Dn.call(t,null,null),t},rh.IllegalArgumentException=Dn,rh.IllegalStateException_init=function(t){return t=t||Object.create(Bn.prototype),Bn.call(t,null,null),t},rh.IllegalStateException_init_pdl1vj$=Un,rh.IllegalStateException=Bn,rh.IndexOutOfBoundsException_init=function(t){return t=t||Object.create(Fn.prototype),Fn.call(t,null),t},rh.IndexOutOfBoundsException=Fn,rh.UnsupportedOperationException_init=Gn,rh.UnsupportedOperationException=qn,rh.NumberFormatException=Yn,rh.NullPointerException=Vn,rh.ClassCastException=Kn,rh.AssertionError_init_pdl1vj$=function(t,e){return e=e||Object.create(Wn.prototype),Wn.call(e,t,null),e},rh.AssertionError=Wn,rh.NoSuchElementException=Xn,rh.ArithmeticException=Jn,rh.NoWhenBranchMatchedException_init=ti,rh.NoWhenBranchMatchedException=Qn,rh.UninitializedPropertyAccessException_init_pdl1vj$=ni,rh.UninitializedPropertyAccessException=ei,rh.lazy_klfg04$=function(t){return new Qc(t)},rh.lazy_kls4a0$=function(t,e){return new Qc(e)},rh.fillFrom_dgzutr$=ii,rh.arrayCopyResize_xao4iu$=ri,uh.toString_if0zpk$=oi,oh.asList_us0mfu$=ai,oh.arrayCopy=Ni,oh.copyOf_8ujjk8$=si,oh.copyOfRange_5f8l3u$=li,oh.fill_jfbbbd$=ui,oh.fill_x4f2cq$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=t.length),Za().checkRangeIndexes_cub51b$(n,i,t.length),t.fill(e,n,i)},oh.sort_pbinho$=ci,oh.toTypedArray_964n91$=function(t){return[].slice.call(t)},oh.toTypedArray_bvy38s$=function(t){return[].slice.call(t)},oh.reverse_vvxzk3$=hi,uh.binarySearchRange_wmnbas$=yi,uh.digitToIntImpl_nupfqh$=$i,uh.isWhitespaceImpl_nupfqh$=vi,rh.Comparator=gi,oh.copyToArray=bi,oh.copyToArrayImpl=wi,oh.copyToExistingArrayImpl=xi,oh.setOf_mh5how$=Ei,oh.LinkedHashSet_init_287e2$=Rr,oh.LinkedHashSet_init_ww73n8$=Dr,oh.mapOf_x2b85n$=Ci,oh.shuffle_vvxzk3$=function(t){mt(t,Du())},oh.sort_4wi501$=Si,oh.toMutableMap_abgq59$=Vs,oh.AbstractMutableCollection=Li,oh.AbstractMutableList=Ri,Mi.SimpleEntry_init_trwmqg$=function(t,e){return e=e||Object.create(Bi.prototype),Bi.call(e,t.key,t.value),e},Mi.SimpleEntry=Bi,Mi.AbstractEntrySet=Ui,oh.AbstractMutableMap=Mi,oh.AbstractMutableSet=Yi,oh.ArrayList_init_mqih57$=Xi,oh.ArrayList=Vi,oh.sortArrayWith_6xblhi$=Zi,oh.sortArray_5zbtrs$=Qi,Object.defineProperty(rr,"HashCode",{get:cr}),oh.EqualityComparator=rr,oh.HashMap_init_va96d4$=_r,oh.HashMap_init_q3lmfv$=fr,oh.HashMap_init_xf5xz2$=dr,oh.HashMap_init_bwtc7$=mr,oh.HashMap_init_73mtqc$=function(t,e){return fr(e=e||Object.create(pr.prototype)),e.putAll_a2k3zr$(t),e},oh.HashMap=pr,oh.HashSet_init_mqih57$=function(t,e){return e=e||Object.create(yr.prototype),Yi.call(e),yr.call(e),e.map_8be2vx$=mr(t.size),e.addAll_brywnq$(t),e},oh.HashSet_init_2wofer$=vr,oh.HashSet_init_ww73n8$=gr,oh.HashSet_init_nn01ho$=br,oh.HashSet=yr,oh.InternalHashCodeMap=wr,oh.InternalMap=kr,oh.InternalStringMap=Er,oh.LinkedHashMap_init_xf5xz2$=Pr,oh.LinkedHashMap_init_73mtqc$=jr,oh.LinkedHashMap=Cr,oh.LinkedHashSet_init_mqih57$=Ir,oh.LinkedHashSet_init_2wofer$=zr,oh.LinkedHashSet=Lr,oh.RandomAccess=Mr;var mh=rh.io||(rh.io={});mh.BaseOutput=Br,mh.NodeJsOutput=Ur,mh.BufferedOutput=Fr,mh.BufferedOutputToConsoleLog=qr,mh.println_s8jyv4$=function(t){ar.println_s8jyv4$(t)},fh.SafeContinuation_init_wj8d80$=function(t,e){return e=e||Object.create(Gr.prototype),Gr.call(e,t,Pu()),e},fh.SafeContinuation=Gr;var yh=e.kotlinx||(e.kotlinx={}),$h=yh.dom||(yh.dom={});$h.createElement_7cgwi1$=function(t,e,n){var i=t.createElement(e);return n(i),i},$h.hasClass_46n0ku$=Ia,$h.addClass_hhb33f$=function(e,n){var i,r=Ki();for(i=0;i!==n.length;++i){var o=n[i];Ia(e,o)||r.add_11rb$(o)}var a=r;if(!a.isEmpty()){var s,l=fc(t.isCharSequence(s=e.className)?s:S()).toString(),u=Qo();return u.append_pdl1vj$(l),0!==l.length&&u.append_pdl1vj$(" "),Ct(a,u," "),e.className=u.toString(),!0}return!1},$h.removeClass_hhb33f$=function(e,n){var i;t:do{var r;for(r=0;r!==n.length;++r)if(Ia(e,n[r])){i=!0;break t}i=!1}while(0);if(i){var o,a,s=et(n),l=fc(t.isCharSequence(o=e.className)?o:S()).toString(),u=wa("\\s+").split_905azu$(l,0),c=Ki();for(a=u.iterator();a.hasNext();){var p=a.next();s.contains_11rb$(p)||c.add_11rb$(p)}return e.className=St(c," "),!0}return!1},ph.iterator_s8jyvk$=function(e){var n,i=e;return null!=e.iterator?e.iterator():t.isArrayish(i)?t.arrayIterator(i):(t.isType(n=i,Qt)?n:Yr()).iterator()},e.throwNPE=function(t){throw new Vn(t)},e.throwCCE=Yr,e.throwISE=Vr,e.throwUPAE=function(t){throw ni("lateinit property "+t+" has not been initialized")},mh.Serializable=Kr,hh.round_14dthe$=function(t){if(t%.5!=0)return Math.round(t);var e=c.floor(t);return e%2==0?e:c.ceil(t)},hh.nextDown_yrwdxr$=Wr,hh.roundToInt_yrwdxr$=function(t){if(Xr(t))throw Mn("Cannot round NaN value.");return t>2147483647?2147483647:t<-2147483648?-2147483648:d(Math.round(t))},hh.roundToLong_yrwdxr$=function(e){if(Xr(e))throw Mn("Cannot round NaN value.");return e>y.toNumber()?y:e0?1:0},hh.abs_s8cxhz$=function(t){return t.toNumber()<0?t.unaryMinus():t},rh.isNaN_yrwdxr$=Xr,rh.isNaN_81szk$=function(t){return t!=t},rh.isInfinite_yrwdxr$=Zr,rh.isFinite_yrwdxr$=Jr,sh.defaultPlatformRandom_8be2vx$=Qr,sh.doubleFromParts_6xvm5r$=to;var vh=rh.reflect||(rh.reflect={});ph.get_js_1yb8b7$=function(e){var n;return(t.isType(n=e,io)?n:Yr()).jClass},vh.KCallable=eo,vh.KClass=no;var gh=vh.js||(vh.js={}),bh=gh.internal||(gh.internal={});bh.KClassImpl=io,bh.SimpleKClassImpl=ro,bh.PrimitiveKClassImpl=oo,Object.defineProperty(bh,"NothingKClassImpl",{get:lo}),bh.ErrorKClass=uo,vh.KProperty=co,vh.KMutableProperty=po,vh.KProperty0=ho,vh.KMutableProperty0=_o,vh.KProperty1=fo,vh.KMutableProperty1=mo,vh.KType=yo,e.createKType=function(t,e,n){return new $o(t,ai(e),n)},bh.KTypeImpl=$o,bh.prefixString_knho38$=vo,Object.defineProperty(bh,"PrimitiveClasses",{get:Go}),e.getKClass=Ho,e.getKClassM=Yo,e.getKClassFromExpression=function(e){var n;switch(typeof e){case"string":n=Go().stringClass;break;case"number":n=(0|e)===e?Go().intClass:Go().doubleClass;break;case"boolean":n=Go().booleanClass;break;case"function":n=Go().functionClass(e.length);break;default:if(t.isBooleanArray(e))n=Go().booleanArrayClass;else if(t.isCharArray(e))n=Go().charArrayClass;else if(t.isByteArray(e))n=Go().byteArrayClass;else if(t.isShortArray(e))n=Go().shortArrayClass;else if(t.isIntArray(e))n=Go().intArrayClass;else if(t.isLongArray(e))n=Go().longArrayClass;else if(t.isFloatArray(e))n=Go().floatArrayClass;else if(t.isDoubleArray(e))n=Go().doubleArrayClass;else if(t.isType(e,no))n=Ho(no);else if(t.isArray(e))n=Go().arrayClass;else{var i=Object.getPrototypeOf(e).constructor;n=i===Object?Go().anyClass:i===Error?Go().throwableClass:Vo(i)}}return n},e.getKClass1=Vo,ph.reset_xjqeni$=Ko,uh.Appendable=Wo,uh.StringBuilder_init_za3lpa$=Zo,uh.StringBuilder_init_6bul2c$=Jo,uh.StringBuilder=Xo,uh.uppercaseChar_myv2d0$=ta,uh.isHighSurrogate_myv2d0$=ea,uh.isLowSurrogate_myv2d0$=na,uh.isWhitespace_myv2d0$=ia,uh.toBoolean_5cw0du$=function(t){var e=null!=t;return e&&(e=o(t.toLowerCase(),"true")),e},uh.toInt_pdl1vz$=function(t){var e;return null!=(e=sc(t))?e:pc(t)},uh.toInt_6ic1pp$=function(t,e){var n;return null!=(n=lc(t,e))?n:pc(t)},uh.toLong_pdl1vz$=function(t){var e;return null!=(e=uc(t))?e:pc(t)},uh.toDouble_pdl1vz$=function(t){var e=+t;return(Xr(e)&&!ra(t)||0===e&&La(t))&&pc(t),e},uh.toDoubleOrNull_pdl1vz$=function(t){var e=+t;return Xr(e)&&!ra(t)||0===e&&La(t)?null:e},uh.toString_dqglrj$=function(t,e){return t.toString(oa(e))},uh.checkRadix_za3lpa$=oa,uh.digitOf_xvg9q0$=aa,Object.defineProperty(sa,"IGNORE_CASE",{get:ua}),Object.defineProperty(sa,"MULTILINE",{get:ca}),uh.RegexOption=sa,uh.MatchGroup=pa,Object.defineProperty(ha,"Companion",{get:ga}),uh.Regex_init_sb3q2$=function(t,e,n){return n=n||Object.create(ha.prototype),ha.call(n,t,Ei(e)),n},uh.Regex_init_61zpoe$=wa,uh.Regex=ha,uh.String_4hbowm$=function(t){var e,n="";for(e=0;e!==t.length;++e){var i=s(t[e]);n+=String.fromCharCode(i)}return n},uh.concatToString_355ntz$=Sa,uh.concatToString_wlitf7$=Ta,uh.compareTo_7epoxm$=Oa,uh.startsWith_7epoxm$=Na,uh.startsWith_3azpy2$=Pa,uh.endsWith_7epoxm$=Aa,uh.matches_rjktp$=ja,uh.isBlank_gw00vp$=La,uh.equals_igcy3c$=function(t,e,n){if(void 0===n&&(n=!1),null==t)return null==e;if(n){if(null==e)return!1;var i=t.toLowerCase(),r=e.toLowerCase(),a=o(i,r);return a||(a=o(i.toUpperCase(),r.toUpperCase())),a}return o(t,e)},uh.regionMatches_h3ii2q$=Ra,uh.repeat_94bcnn$=function(t,e){var n;if(!(e>=0))throw Mn(("Count 'n' must be non-negative, but was "+e+".").toString());switch(e){case 0:n="";break;case 1:n=t.toString();break;default:var i="";if(0!==t.length)for(var r=t.toString(),o=e;1==(1&o)&&(i+=r),0!=(o>>>=1);)r+=r;return i}return n},uh.replace_680rmw$=function(t,e,n,i){return void 0===i&&(i=!1),t.replace(new RegExp(ga().escape_61zpoe$(e),i?"gui":"gu"),ga().escapeReplacement_61zpoe$(n))},uh.replace_r2fvfm$=function(t,e,n,i){return void 0===i&&(i=!1),t.replace(new RegExp(ga().escape_61zpoe$(String.fromCharCode(e)),i?"gui":"gu"),String.fromCharCode(n))},oh.AbstractCollection=za,oh.AbstractIterator=Ga,Object.defineProperty(Ha,"Companion",{get:Za}),oh.AbstractList=Ha,Object.defineProperty(Ja,"Companion",{get:os}),oh.AbstractMap=Ja,Object.defineProperty(as,"Companion",{get:us}),oh.AbstractSet=as,Object.defineProperty(oh,"EmptyIterator",{get:hs}),Object.defineProperty(oh,"EmptyList",{get:ds}),oh.asCollection_vj43ah$=ms,oh.listOf_i5x0yv$=vs,oh.arrayListOf_i5x0yv$=gs,oh.listOfNotNull_issdgt$=function(t){return null!=t?ki(t):$s()},oh.listOfNotNull_jurz7g$=function(t){return Y(t)},oh.get_indices_gzk92b$=bs,oh.optimizeReadOnlyList_qzupvv$=xs,oh.binarySearch_jhx6be$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=t.size),ks(t.size,n,i);for(var r=n,o=i-1|0;r<=o;){var a=r+o>>>1,s=Kl(t.get_za3lpa$(a),e);if(s<0)r=a+1|0;else{if(!(s>0))return a;o=a-1|0}}return 0|-(r+1|0)},oh.binarySearch_vikexg$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=t.size),ks(t.size,i,r);for(var o=i,a=r-1|0;o<=a;){var s=o+a>>>1,l=t.get_za3lpa$(s),u=n.compare(l,e);if(u<0)o=s+1|0;else{if(!(u>0))return s;a=s-1|0}}return 0|-(o+1|0)},lh.compareValues_s00gnj$=Kl,oh.throwIndexOverflow=Es,oh.throwCountOverflow=Cs,oh.IndexedValue=Ts,oh.IndexingIterable=Os,oh.collectionSizeOrNull_7wnvza$=Ns,oh.convertToSetForSetOperationWith_wo44v8$=As,oh.flatten_u0ad8z$=function(t){var e,n=Ki();for(e=t.iterator();e.hasNext();)Ws(n,e.next());return n},oh.unzip_6hr0sd$=function(t){var e,n=Ps(t,10),i=Wi(n),r=Wi(n);for(e=t.iterator();e.hasNext();){var o=e.next();i.add_11rb$(o.first),r.add_11rb$(o.second)}return cp(i,r)},oh.IndexingIterator=js,oh.getOrImplicitDefault_t9ocha$=Ls,oh.emptyMap_q3lmfv$=Us,oh.mapOf_qfcya0$=function(t){return t.length>0?Ys(t,Ar(t.length)):Us()},oh.mutableMapOf_qfcya0$=function(t){var e=Ar(t.length);return qs(e,t),e},oh.hashMapOf_qfcya0$=Fs,oh.getValue_t9ocha$=function(t,e){return Ls(t,e)},oh.putAll_5gv49o$=qs,oh.putAll_cweazw$=Gs,oh.toMap_6hr0sd$=function(e){var n;if(t.isType(e,ee)){switch(e.size){case 0:n=Us();break;case 1:n=Ci(t.isType(e,ie)?e.get_za3lpa$(0):e.iterator().next());break;default:n=Hs(e,Ar(e.size))}return n}return Ks(Hs(e,Nr()))},oh.toMap_jbpz7q$=Hs,oh.toMap_ujwnei$=Ys,oh.toMap_abgq59$=function(t){switch(t.size){case 0:return Us();case 1:default:return Vs(t)}},oh.plus_iwxh38$=function(t,e){var n=jr(t);return n.putAll_a2k3zr$(e),n},oh.minus_uk696c$=function(t,e){var n=Vs(t);return Xs(n.keys,e),Ks(n)},oh.removeAll_ipc267$=Xs,oh.optimizeReadOnlyMap_1vp4qn$=Ks,oh.retainAll_ipc267$=Zs,oh.removeAll_uhyeqt$=Js,oh.removeAll_qafx1e$=tl,oh.asReversed_2p1efm$=function(t){return new el(t)},ch.sequence_o0x0bg$=function(t){return new il((e=t,function(){return rl(e)}));var e},ch.iterator_o0x0bg$=rl,ch.SequenceScope=ol,ch.sequenceOf_i5x0yv$=sl,ch.emptySequence_287e2$=ll,ch.flatten_41nmvn$=_l,ch.flatten_d9bjs1$=function(t){return ml(t,fl)},ch.FilteringSequence=yl,ch.TransformingSequence=vl,ch.MergingSequence=bl,ch.FlatteningSequence=xl,ch.DropTakeSequence=El,ch.SubSequence=Cl,ch.TakeSequence=Tl,ch.DropSequence=Nl,ch.generateSequence_c6s9hp$=Ll,Object.defineProperty(oh,"EmptySet",{get:zl}),oh.emptySet_287e2$=Dl,oh.setOf_i5x0yv$=function(t){return t.length>0?et(t):Dl()},oh.mutableSetOf_i5x0yv$=function(t){return J(t,Dr(t.length))},oh.hashSetOf_i5x0yv$=Ml,oh.optimizeReadOnlySet_94kdbt$=Bl,oh.checkWindowSizeStep_6xvm5r$=Fl,oh.windowedSequence_38k18b$=ql,oh.windowedIterator_4ozct4$=Hl,lh.compareBy_bvgy4j$=function(t){if(!(t.length>0))throw Mn("Failed requirement.".toString());return new gi(Wl(t))},lh.naturalOrder_dahdeg$=Xl,lh.reverseOrder_dahdeg$=Zl,lh.reversed_2avth4$=function(e){var n,i;return t.isType(e,Jl)?e.comparator:o(e,eu())?t.isType(n=ru(),gi)?n:Yr():o(e,ru())?t.isType(i=eu(),gi)?i:Yr():new Jl(e)},fh.Continuation=ou,rh.Result=ep,fh.startCoroutine_x18nsh$=function(t,e){An(Nn(t,e)).resumeWith_tl1gpc$(new ep(Qe()))},fh.startCoroutine_3a617i$=function(t,e,n){An(Pn(t,e,n)).resumeWith_tl1gpc$(new ep(Qe()))},dh.get_COROUTINE_SUSPENDED=Su,Object.defineProperty(au,"Key",{get:uu}),fh.ContinuationInterceptor=au,cu.Key=hu,cu.Element=_u,fh.CoroutineContext=cu,fh.AbstractCoroutineContextElement=fu,fh.AbstractCoroutineContextKey=du,Object.defineProperty(fh,"EmptyCoroutineContext",{get:$u}),fh.CombinedContext=vu,Object.defineProperty(dh,"COROUTINE_SUSPENDED",{get:Su}),Object.defineProperty(Tu,"COROUTINE_SUSPENDED",{get:Nu}),Object.defineProperty(Tu,"UNDECIDED",{get:Pu}),Object.defineProperty(Tu,"RESUMED",{get:Au}),dh.CoroutineSingletons=Tu,Object.defineProperty(ju,"Default",{get:Du}),sh.Random_za3lpa$=Mu,sh.Random_s8cxhz$=function(t){return Ju(t.toInt(),t.shiftRight(32).toInt())},sh.fastLog2_kcn2v3$=Bu,sh.takeUpperBits_b6l1hq$=Uu,sh.checkRangeBounds_6xvm5r$=Fu,sh.checkRangeBounds_cfj5zr$=qu,sh.checkRangeBounds_sdh6z7$=Gu,sh.boundsErrorMessage_dgzutr$=Hu,sh.XorWowRandom_init_6xvm5r$=Ju,sh.XorWowRandom=Yu,ah.ClosedFloatingPointRange=tc,ah.rangeTo_38ydlf$=function(t,e){return new ec(t,e)},vh.KClassifier=nc,uh.appendElement_k2zgzt$=ic,uh.equals_4lte5s$=rc,uh.trimMargin_rjktp$=function(t,e){return void 0===e&&(e="|"),oc(t,"",e)},uh.replaceIndentByMargin_j4ogox$=oc,uh.toIntOrNull_pdl1vz$=sc,uh.toIntOrNull_6ic1pp$=lc,uh.toLongOrNull_pdl1vz$=uc,uh.toLongOrNull_6ic1pp$=cc,uh.numberFormatError_y4putb$=pc,uh.trimStart_wqw3xr$=hc,uh.trimEnd_wqw3xr$=_c,uh.trim_gw00vp$=fc,uh.padStart_yk9sg4$=dc,uh.padStart_vrc1nu$=function(e,n,i){var r;return void 0===i&&(i=32),dc(t.isCharSequence(r=e)?r:Yr(),n,i).toString()},uh.padEnd_yk9sg4$=mc,uh.padEnd_vrc1nu$=function(e,n,i){var r;return void 0===i&&(i=32),mc(t.isCharSequence(r=e)?r:Yr(),n,i).toString()},uh.substring_fc3b62$=bc,uh.substring_i511yc$=wc,uh.substringBefore_j4ogox$=function(t,e,n){void 0===n&&(n=t);var i=Ac(t,e);return-1===i?n:t.substring(0,i)},uh.substringAfter_j4ogox$=function(t,e,n){void 0===n&&(n=t);var i=Ac(t,e);return-1===i?n:t.substring(i+e.length|0,t.length)},uh.removePrefix_gsj5wt$=function(t,e){return Cc(t,e)?t.substring(e.length):t},uh.removeSurrounding_90ijwr$=function(t,e,n){return t.length>=(e.length+n.length|0)&&Cc(t,e)&&Sc(t,n)?t.substring(e.length,t.length-n.length|0):t},uh.regionMatchesImpl_4c7s8r$=xc,uh.startsWith_sgbm27$=kc,uh.endsWith_sgbm27$=Ec,uh.startsWith_li3zpu$=Cc,uh.endsWith_li3zpu$=Sc,uh.indexOfAny_junqau$=Tc,uh.lastIndexOfAny_junqau$=Oc,uh.indexOf_8eortd$=Pc,uh.indexOf_l5u8uk$=Ac,uh.lastIndexOf_8eortd$=function(e,n,i,r){return void 0===i&&(i=gc(e)),void 0===r&&(r=!1),r||"string"!=typeof e?Oc(e,t.charArrayOf(n),i,r):e.lastIndexOf(String.fromCharCode(n),i)},uh.lastIndexOf_l5u8uk$=jc,uh.contains_li3zpu$=function(t,e,n){return void 0===n&&(n=!1),"string"==typeof e?Ac(t,e,void 0,n)>=0:Nc(t,e,0,t.length,n)>=0},uh.contains_sgbm27$=function(t,e,n){return void 0===n&&(n=!1),Pc(t,e,void 0,n)>=0},uh.splitToSequence_ip8yn$=Dc,uh.split_ip8yn$=function(e,n,i,r){if(void 0===i&&(i=!1),void 0===r&&(r=0),1===n.length){var o=n[0];if(0!==o.length)return function(e,n,i,r){if(!(r>=0))throw Mn(("Limit must be non-negative, but was "+r+".").toString());var o=0,a=Ac(e,n,o,i);if(-1===a||1===r)return ki(e.toString());var s=r>0,l=Wi(s?jt(r,10):10);do{if(l.add_11rb$(t.subSequence(e,o,a).toString()),o=a+n.length|0,s&&l.size===(r-1|0))break;a=Ac(e,n,o,i)}while(-1!==a);return l.add_11rb$(t.subSequence(e,o,e.length).toString()),l}(e,o,i,r)}var a,s=Kt(zc(e,n,void 0,i,r)),l=Wi(Ps(s,10));for(a=s.iterator();a.hasNext();){var u=a.next();l.add_11rb$(wc(e,u))}return l},uh.lineSequence_gw00vp$=Mc,uh.lines_gw00vp$=Bc,uh.MatchGroupCollection=Uc,Fc.Destructured=qc,uh.MatchResult=Fc,rh.Lazy=Gc,Object.defineProperty(Hc,"SYNCHRONIZED",{get:Vc}),Object.defineProperty(Hc,"PUBLICATION",{get:Kc}),Object.defineProperty(Hc,"NONE",{get:Wc}),rh.LazyThreadSafetyMode=Hc,Object.defineProperty(rh,"UNINITIALIZED_VALUE",{get:Jc}),rh.UnsafeLazyImpl=Qc,rh.InitializedLazyImpl=tp,rh.createFailure_tcv7n7$=ap,Object.defineProperty(ep,"Companion",{get:rp}),ep.Failure=op,rh.throwOnFailure_iacion$=sp,rh.NotImplementedError=lp,rh.Pair=up,rh.to_ujzrz7$=cp,rh.toList_tt9upe$=function(t){return vs([t.first,t.second])},rh.Triple=pp,Object.defineProperty(hp,"Companion",{get:dp}),Object.defineProperty(mp,"Companion",{get:vp}),rh.uintCompare_vux9f0$=Jp,rh.uintDivide_oqfnby$=function(e,n){return new mp(t.Long.fromInt(e.data).and(v).div(t.Long.fromInt(n.data).and(v)).toInt())},rh.uintRemainder_oqfnby$=th,rh.uintToDouble_za3lpa$=function(t){return(2147483647&t)+2*(t>>>31<<30)},Object.defineProperty(gp,"Companion",{get:xp}),ah.UIntRange=gp,Object.defineProperty(kp,"Companion",{get:Sp}),ah.UIntProgression=kp,oh.UIntIterator=Op,oh.ULongIterator=Np,Object.defineProperty(Pp,"Companion",{get:Lp}),rh.ulongCompare_3pjtqy$=Qp,rh.ulongDivide_jpm79w$=function(e,n){var i=e.data,r=n.data;if(r.toNumber()<0)return Qp(e.data,n.data)<0?new Pp(u):new Pp(w);if(i.toNumber()>=0)return new Pp(i.div(r));var o=i.shiftRightUnsigned(1).div(r).shiftLeft(1),a=i.subtract(o.multiply(r));return new Pp(o.add(t.Long.fromInt(Qp(new Pp(a).data,new Pp(r).data)>=0?1:0)))},rh.ulongRemainder_jpm79w$=eh,rh.ulongToDouble_s8cxhz$=function(t){return 2048*t.shiftRightUnsigned(11).toNumber()+t.and(D).toNumber()},Object.defineProperty(Rp,"Companion",{get:Dp}),ah.ULongRange=Rp,Object.defineProperty(Mp,"Companion",{get:Fp}),ah.ULongProgression=Mp,_h.getProgressionLastElement_fjk8us$=Yp,_h.getProgressionLastElement_15zasp$=Vp,Object.defineProperty(Kp,"Companion",{get:Zp}),rh.ulongToString_8e33dg$=nh,rh.ulongToString_plstum$=ih,ue.prototype.getOrDefault_xwzc9p$=se.prototype.getOrDefault_xwzc9p$,Ja.prototype.getOrDefault_xwzc9p$=se.prototype.getOrDefault_xwzc9p$,Mi.prototype.remove_xwzc9p$=ue.prototype.remove_xwzc9p$,wr.prototype.createJsMap=kr.prototype.createJsMap,Er.prototype.createJsMap=kr.prototype.createJsMap,Object.defineProperty(xa.prototype,"destructured",Object.getOwnPropertyDescriptor(Fc.prototype,"destructured")),Rs.prototype.getOrDefault_xwzc9p$=se.prototype.getOrDefault_xwzc9p$,Is.prototype.remove_xwzc9p$=ue.prototype.remove_xwzc9p$,Is.prototype.getOrDefault_xwzc9p$=ue.prototype.getOrDefault_xwzc9p$,Rs.prototype.getOrDefault_xwzc9p$,zs.prototype.remove_xwzc9p$=Is.prototype.remove_xwzc9p$,zs.prototype.getOrDefault_xwzc9p$=Is.prototype.getOrDefault_xwzc9p$,Ds.prototype.getOrDefault_xwzc9p$=se.prototype.getOrDefault_xwzc9p$,_u.prototype.plus_1fupul$=cu.prototype.plus_1fupul$,au.prototype.fold_3cc69b$=_u.prototype.fold_3cc69b$,au.prototype.plus_1fupul$=_u.prototype.plus_1fupul$,fu.prototype.get_j3r2sn$=_u.prototype.get_j3r2sn$,fu.prototype.fold_3cc69b$=_u.prototype.fold_3cc69b$,fu.prototype.minusKey_yeqjby$=_u.prototype.minusKey_yeqjby$,fu.prototype.plus_1fupul$=_u.prototype.plus_1fupul$,vu.prototype.plus_1fupul$=cu.prototype.plus_1fupul$,Qu.prototype.contains_mef7kx$=De.prototype.contains_mef7kx$,Qu.prototype.isEmpty=De.prototype.isEmpty,n=3.141592653589793,fi=null;var wh="undefined"!=typeof process&&process.versions&&!!process.versions.node;ar=wh?new Ur(process.stdout):new qr,new Hr($u(),(function(e){var n;return sp(e),null==(n=e.value)||t.isType(n,C)||S(),Ze})),sr=c.pow(2,-26),lr=c.pow(2,-53),Bo=t.newArray(0,null),new gi((function(t,e){return Oa(t,e,!0)})),new Int8Array([f(239),f(191),f(189)]),new ep(Su())}()})?n.apply(e,[e]):n)||(t.exports=i)},197:function(t,e,n){var i,r,o;r=[e,n(421)],void 0===(o="function"==typeof(i=function(t,e){"use strict";var n,i=Object,r=e.throwCCE,o=e.Kind.CLASS,a=e.kotlin.coroutines.Continuation,s=(e.kotlin.Annotation,e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED),l=e.kotlin.coroutines.CoroutineImpl,u=(e.kotlin.collections.emptyList_287e2$,e.kotlin.Unit),c=e.throwUPAE,p=(e.kotlin.collections.copyToArray,e.kotlin.coroutines.intrinsics.intercepted_f9mg25$),h=e.kotlin.collections.ArrayList_init_ww73n8$,_=e.kotlin.Result,f=e.kotlin.coroutines,d=e.kotlin.coroutines.intrinsics.createCoroutineUnintercepted_3a617i$,m=e.kotlin.coroutines.ContinuationInterceptor,y=e.equals,$=e.defineInlineFunction,v=e.wrapFunction,g=e.kotlin.IllegalStateException_init_pdl1vj$,b=e.Kind.INTERFACE,w=Error,x=e.toString,k=e.Kind.OBJECT,E=e.kotlin.createFailure_tcv7n7$,C=e.kotlin.coroutines.AbstractCoroutineContextElement,S=e.kotlin.RuntimeException,T=e.kotlin.coroutines.CoroutineContext.Key,O=e.kotlin.coroutines.CoroutineContext.Element,N=e.kotlin.coroutines.startCoroutine_x18nsh$,P=e.kotlin.coroutines.startCoroutine_3a617i$,A=e.kotlin.Enum,j=e.throwISE,L=e.Long.MAX_VALUE,R=e.Long.ZERO,I=new e.Long(0,1),z=e.Long.ONE,D=(e.Long.fromInt(1e6),new e.Long(2077252342,2147),new e.Long(-1,1073741823),e.kotlin.ranges.coerceAtLeast_2p08ub$,e.ensureNotNull),M=(e.kotlin.Comparable,e.kotlin.IllegalArgumentException_init_pdl1vj$),B=e.kotlin.Error,U=e.kotlin.IllegalStateException,F=e.kotlin.sequences.sequence_o0x0bg$,q=e.kotlin.collections.ArrayList,G=e.kotlin.text.StringBuilder_init,H=e.kotlin.UnsupportedOperationException_init_pdl1vj$,Y=(e.kotlin.sequences.emptySequence_287e2$,Function),V=(e.kotlin.ranges.coerceAtMost_2p08ub$,Math),K=e.kotlin.NoSuchElementException,W=e.hashCode,X=(e.kotlin.collections.IndexedValue,e.kotlin.IndexOutOfBoundsException,e.kotlin.collections.LinkedHashMap_init_q3lmfv$,e.kotlin.collections.ArrayList_init_287e2$),Z=(e.kotlin.collections.HashSet_init_287e2$,e.kotlin.collections.LinkedHashSet_init_287e2$,e.kotlin.Pair,e.kotlin.to_ujzrz7$,e.kotlin.collections.indexOf_mjy6jw$,e.kotlin.collections.arrayCopy),J=(e.kotlin.ArithmeticException,new e.Long(0,805306368),e.Long.fromInt(1073741823),new e.Long(-1073741824,268435455),new e.Long(0,268435456),new e.Long(0,536870912),e.kotlin.text.toLongOrNull_pdl1vz$),Q=(e.kotlin.collections.fill_jfbbbd$,e.kotlin.collections.copyOf_8ujjk8$,e.kotlin.coroutines.intrinsics.createCoroutineUnintercepted_x18nsh$),tt=e.kotlin.collections.shuffle_vvxzk3$,et=e.Long.fromInt(2147483647),nt=e.kotlin.ranges.coerceIn_ekzx8g$,it=e.kotlin.collections.HashSet_init_ww73n8$,rt=(e.kotlin.collections.get_lastIndex_55thoc$,e.kotlin.NoSuchElementException_init,e.kotlin.collections.MutableIterator,e.kotlin.collections.AbstractMutableList,e.kotlin.UnsupportedOperationException_init);function ot(t,e){void 0===e&&(e=!0),Me.call(this,e),this.parentContext=t,this.context_p8rm81$_0=this.parentContext.plus_1fupul$(this)}function at(t,e){ot.call(this,t,e)}function st(t,e){l.call(this,e),this.exceptionState_0=1,this.$this=t}function lt(t,e){at.call(this,t,!1),this.continuation_0=d(e,this,this)}function ut(t,e){ot.call(this,t,e)}function ct(t,e){ut.call(this,t,!1),this.continuation_0=d(e,this,this)}function pt(t,e){Qi.call(this,t,e)}function ht(t,e){Qi.call(this,t,e),this._decision_0=0}function _t(){}function ft(t){var n,i;return e.isType(t,Gi)?null==(i=null!=(n=t.claimReusableCancellableContinuation())&&n.resetState_8be2vx$()?n:null)?new vt(t,0):i:new vt(t,0)}function dt(t,e){t.invokeOnCancellation_f05bi3$(new yt(e))}function mt(t,e){t.invokeOnCancellation_f05bi3$(new $t(e))}function yt(t){kt.call(this),this.node_0=t}function $t(t){kt.call(this),this.handle_0=t}function vt(t,e){Wi.call(this,e),this.delegate_dhbmku$_0=t,this.context_xycjfy$_0=this.delegate.context,this._decision_0=0,this._state_0=xt(),this._parentHandle_0=null}function gt(){}function bt(){wt=this}ot.prototype=Object.create(Me.prototype),ot.prototype.constructor=ot,kt.prototype=Object.create(Sr.prototype),kt.prototype.constructor=kt,Cr.prototype=Object.create(mo.prototype),Cr.prototype.constructor=Cr,Ze.prototype=Object.create(Cr.prototype),Ze.prototype.constructor=Ze,at.prototype=Object.create(ot.prototype),at.prototype.constructor=at,lt.prototype=Object.create(at.prototype),lt.prototype.constructor=lt,ut.prototype=Object.create(ot.prototype),ut.prototype.constructor=ut,ct.prototype=Object.create(ut.prototype),ct.prototype.constructor=ct,Qi.prototype=Object.create(ot.prototype),Qi.prototype.constructor=Qi,pt.prototype=Object.create(Qi.prototype),pt.prototype.constructor=pt,ht.prototype=Object.create(Qi.prototype),ht.prototype.constructor=ht,yt.prototype=Object.create(kt.prototype),yt.prototype.constructor=yt,$t.prototype=Object.create(kt.prototype),$t.prototype.constructor=$t,Wi.prototype=Object.create(co.prototype),Wi.prototype.constructor=Wi,vt.prototype=Object.create(Wi.prototype),vt.prototype.constructor=vt,Et.prototype=Object.create(kt.prototype),Et.prototype.constructor=Et,Ot.prototype=Object.create(Me.prototype),Ot.prototype.constructor=Ot,It.prototype=Object.create(Rt.prototype),It.prototype.constructor=It,zt.prototype=Object.create(C.prototype),zt.prototype.constructor=zt,Gt.prototype=Object.create(C.prototype),Gt.prototype.constructor=Gt,ne.prototype=Object.create(A.prototype),ne.prototype.constructor=ne,_e.prototype=Object.create(zt.prototype),_e.prototype.constructor=_e,Gr.prototype=Object.create(_e.prototype),Gr.prototype.constructor=Gr,ye.prototype=Object.create(Gr.prototype),$e.prototype=Object.create(S.prototype),$e.prototype.constructor=$e,ve.prototype=Object.create(B.prototype),ve.prototype.constructor=ve,qe.prototype=Object.create(Ze.prototype),qe.prototype.constructor=qe,Ge.prototype=Object.create(vt.prototype),Ge.prototype.constructor=Ge,We.prototype=Object.create(Me.prototype),We.prototype.constructor=We,bo.prototype=Object.create(mo.prototype),bo.prototype.constructor=bo,Je.prototype=Object.create(bo.prototype),Je.prototype.constructor=Je,tn.prototype=Object.create(Ze.prototype),tn.prototype.constructor=tn,en.prototype=Object.create(Ze.prototype),en.prototype.constructor=en,nn.prototype=Object.create(Ze.prototype),nn.prototype.constructor=nn,rn.prototype=Object.create(Ze.prototype),rn.prototype.constructor=rn,on.prototype=Object.create(Ze.prototype),on.prototype.constructor=on,an.prototype=Object.create(Ze.prototype),an.prototype.constructor=an,sn.prototype=Object.create(an.prototype),sn.prototype.constructor=sn,ln.prototype=Object.create(an.prototype),ln.prototype.constructor=ln,un.prototype=Object.create(an.prototype),un.prototype.constructor=un,cn.prototype=Object.create(zt.prototype),cn.prototype.constructor=cn,pn.prototype=Object.create(C.prototype),hn.prototype=Object.create(We.prototype),hn.prototype.constructor=hn,Yr.prototype=Object.create(U.prototype),Yr.prototype.constructor=Yr,_n.prototype=Object.create(Yr.prototype),_n.prototype.constructor=_n,fn.prototype=Object.create(zt.prototype),fn.prototype.constructor=fn,yn.prototype=Object.create(C.prototype),yn.prototype.constructor=yn,vo.prototype=Object.create(qi.prototype),vo.prototype.constructor=vo,yo.prototype=Object.create(vo.prototype),yo.prototype.constructor=yo,Nn.prototype=Object.create(yo.prototype),Nn.prototype.constructor=Nn,Pn.prototype=Object.create(Nn.prototype),Pn.prototype.constructor=Pn,$o.prototype=Object.create(vo.prototype),$o.prototype.constructor=$o,Ln.prototype=Object.create($o.prototype),Ln.prototype.constructor=Ln,Wn.prototype=Object.create(mo.prototype),Wn.prototype.constructor=Wn,In.prototype=Object.create(Wn.prototype),In.prototype.constructor=In,zn.prototype=Object.create(Wn.prototype),zn.prototype.constructor=zn,Bn.prototype=Object.create($o.prototype),Bn.prototype.constructor=Bn,Gn.prototype=Object.create(kt.prototype),Gn.prototype.constructor=Gn,Qn.prototype=Object.create(mo.prototype),Qn.prototype.constructor=Qn,Yn.prototype=Object.create(Qn.prototype),Yn.prototype.constructor=Yn,Vn.prototype=Object.create(Qn.prototype),Vn.prototype.constructor=Vn,Kn.prototype=Object.create(Qn.prototype),Kn.prototype.constructor=Kn,Dn.prototype=Object.create(On.prototype),Dn.prototype.constructor=Dn,Zn.prototype=Object.create(Wn.prototype),Zn.prototype.constructor=Zn,Jn.prototype=Object.create(Wn.prototype),Jn.prototype.constructor=Jn,ti.prototype=Object.create(Dn.prototype),ti.prototype.constructor=ti,ei.prototype=Object.create(ot.prototype),Pi.prototype=Object.create(U.prototype),Pi.prototype.constructor=Pi,Ai.prototype=Object.create(K.prototype),Ai.prototype.constructor=Ai,ji.prototype=Object.create(ot.prototype),Ri.prototype=Object.create(Dn.prototype),Ri.prototype.constructor=Ri,Ii.prototype=Object.create(Dn.prototype),Ii.prototype.constructor=Ii,Di.prototype=Object.create(Dn.prototype),Di.prototype.constructor=Di,Fi.prototype=Object.create(Ui.prototype),Fi.prototype.constructor=Fi,Gi.prototype=Object.create(Wi.prototype),Gi.prototype.constructor=Gi,gr.prototype=Object.create(an.prototype),gr.prototype.constructor=gr,br.prototype=Object.create(Ui.prototype),br.prototype.constructor=br,wr.prototype=Object.create(Fi.prototype),wr.prototype.constructor=wr,xr.prototype=Object.create(mo.prototype),xr.prototype.constructor=xr,vr.prototype=Object.create(bo.prototype),vr.prototype.constructor=vr,Ur.prototype=Object.create(cn.prototype),Ur.prototype.constructor=Ur,qr.prototype=Object.create(_e.prototype),qr.prototype.constructor=qr,Kr.prototype=Object.create(Yr.prototype),Kr.prototype.constructor=Kr,lo.prototype=Object.create(Bi.prototype),lo.prototype.constructor=lo,Zr.prototype=Object.create(lo.prototype),Zr.prototype.constructor=Zr,Xr.prototype=Object.create(zt.prototype),Xr.prototype.constructor=Xr,Jr.prototype=Object.create(Xr.prototype),Jr.prototype.constructor=Jr,eo.prototype=Object.create(Xr.prototype),eo.prototype.constructor=eo,ro.prototype=Object.create(kt.prototype),ro.prototype.constructor=ro,oo.prototype=Object.create(zt.prototype),oo.prototype.constructor=oo,so.prototype=Object.create(lo.prototype),so.prototype.constructor=so,go.prototype=Object.create(Ui.prototype),go.prototype.constructor=go,Object.defineProperty(ot.prototype,"context",{get:function(){return this.context_p8rm81$_0}}),Object.defineProperty(ot.prototype,"coroutineContext",{get:function(){return this.context}}),Object.defineProperty(ot.prototype,"isActive",{get:function(){return e.callGetter(this,Me.prototype,"isActive")}}),ot.prototype.initParentJob_8be2vx$=function(){this.initParentJobInternal_8vd9i7$(this.parentContext.get_j3r2sn$(xe()))},ot.prototype.onStart=function(){},ot.prototype.onStartInternal=function(){this.onStart()},ot.prototype.onCompleted_11rb$=function(t){},ot.prototype.onCancelled_z1nxw$=function(t,e){},ot.prototype.cancellationExceptionMessage=function(){return Ir(this)+" was cancelled"},ot.prototype.onCompletionInternal_s8jyv4$=function(t){var n;e.isType(t,Rt)?this.onCancelled_z1nxw$(t.cause,t.handled):this.onCompleted_11rb$(null==(n=t)||e.isType(n,i)?n:r())},ot.prototype.resumeWith_tl1gpc$=function(t){var e=this.makeCompletingOnce_8ea4ql$(At(t));e!==Pe&&this.afterResume_s8jyv4$(e)},ot.prototype.afterResume_s8jyv4$=function(t){this.afterCompletion_s8jyv4$(t)},ot.prototype.handleOnCompletionException_tcv7n7$=function(t){Dt(this.context,t)},ot.prototype.nameString=function(){var t;return null==(this.context,t=null)?Me.prototype.nameString.call(this):'"'+t+'":'+Me.prototype.nameString.call(this)},ot.prototype.start_cfq2d3$=function(t,e){this.initParentJob_8be2vx$(),t.invoke_810yno$(e,this)},ot.prototype.start_b5ul0p$=function(t,e,n){this.initParentJob_8be2vx$(),t.invoke_3o0yor$(n,e,this)},ot.$metadata$={kind:o,simpleName:"AbstractCoroutine",interfaces:[Kt,a,Me,ge]},at.prototype.getCompleted=function(){var t;return null==(t=this.getCompletedInternal_8be2vx$())||e.isType(t,i)?t:r()},st.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[l]},st.prototype=Object.create(l.prototype),st.prototype.constructor=st,st.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.state_0=2,this.result_0=this.$this.awaitInternal_8be2vx$(this),this.result_0===s)return s;continue;case 1:throw this.exception_0;case 2:return null==(t=this.result_0)||e.isType(t,i)?t:r();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},at.prototype.await=function(t,e){var n=new st(this,t);return e?n:n.doResume(null)},Object.defineProperty(at.prototype,"onAwait",{get:function(){return this}}),at.prototype.registerSelectClause1_o3xas4$=function(t,e){this.registerSelectClause1Internal_u6kgbh$(t,e)},at.$metadata$={kind:o,simpleName:"DeferredCoroutine",interfaces:[dr,ue,ot]},lt.prototype.onStart=function(){ar(this.continuation_0,this)},lt.$metadata$={kind:o,simpleName:"LazyDeferredCoroutine",interfaces:[at]},$("kotlinx-coroutines-core.kotlinx.coroutines.invoke_5xrhu2$",v((function(){var n=t.kotlinx.coroutines.withContext_i5cbzn$;return function(t,i,r){return e.suspendCall(n(t,i,e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())}}))),ut.prototype.handleJobException_tcv7n7$=function(t){return Dt(this.context,t),!0},ut.$metadata$={kind:o,simpleName:"StandaloneCoroutine",interfaces:[ot]},ct.prototype.onStart=function(){ar(this.continuation_0,this)},ct.$metadata$={kind:o,simpleName:"LazyStandaloneCoroutine",interfaces:[ut]},pt.prototype.afterResume_s8jyv4$=function(t){var e=Lt(t,this.uCont);this.uCont.context,this.uCont.resumeWith_tl1gpc$(e)},pt.$metadata$={kind:o,simpleName:"UndispatchedCoroutine",interfaces:[Qi]},ht.prototype.trySuspend_0=function(){for(this._decision_0;;)switch(this._decision_0){case 0:if(0===this._decision_0&&(this._decision_0=1,1))return!0;break;case 2:return!1;default:throw g("Already suspended".toString())}},ht.prototype.tryResume_0=function(){for(this._decision_0;;)switch(this._decision_0){case 0:if(0===this._decision_0&&(this._decision_0=2,1))return!0;break;case 1:return!1;default:throw g("Already resumed".toString())}},ht.prototype.afterCompletion_s8jyv4$=function(t){this.afterResume_s8jyv4$(t)},ht.prototype.afterResume_s8jyv4$=function(t){this.tryResume_0()||Hi(p(this.uCont),Lt(t,this.uCont))},ht.prototype.getResult=function(){var t;if(this.trySuspend_0())return s;var n=Ve(this.state_8be2vx$);if(e.isType(n,Rt))throw n.cause;return null==(t=n)||e.isType(t,i)?t:r()},ht.$metadata$={kind:o,simpleName:"DispatchedCoroutine",interfaces:[Qi]},_t.prototype.tryResume_19pj23$=function(t,e,n){return void 0===e&&(e=null),n?n(t,e):this.tryResume_19pj23$$default(t,e)},_t.prototype.cancel_dbl4no$=function(t,e){return void 0===t&&(t=null),e?e(t):this.cancel_dbl4no$$default(t)},_t.$metadata$={kind:b,simpleName:"CancellableContinuation",interfaces:[a]},$("kotlinx-coroutines-core.kotlinx.coroutines.suspendCancellableCoroutine_o6sdx9$",v((function(){var n=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,i=t.kotlinx.coroutines.CancellableContinuationImpl;return function(t,r){return e.suspendCall((o=t,function(t){var e=new i(n(t),1);return o(e),e.getResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var o}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.suspendAtomicCancellableCoroutine_o6sdx9$",v((function(){var n=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,i=t.kotlinx.coroutines.CancellableContinuationImpl;return function(t,r){return e.suspendCall((o=t,function(t){var e=new i(n(t),0);return o(e),e.getResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var o}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.suspendAtomicCancellableCoroutineReusable_mkkzkw$",v((function(){var n=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,i=t.kotlinx.coroutines.getOrCreateCancellableContinuation_3j0xf1$;return function(t,r){return e.suspendCall((o=t,function(t){var e=i(n(t));return o(e),e.getResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var o}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.suspendAtomicCancellableCoroutine_i8nyj0$",v((function(){var n=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,i=t.kotlinx.coroutines.CancellableContinuationImpl;return function(t,r,o){return void 0===t&&(t=!1),e.suspendCall((a=r,function(t){var e=new i(n(t),0);return a(e),e.getResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var a}}))),yt.prototype.invoke=function(t){this.node_0.remove()},yt.prototype.toString=function(){return"RemoveOnCancel["+this.node_0+"]"},yt.$metadata$={kind:o,simpleName:"RemoveOnCancel",interfaces:[kt]},$t.prototype.invoke=function(t){this.handle_0.dispose()},$t.prototype.toString=function(){return"DisposeOnCancel["+this.handle_0+"]"},$t.$metadata$={kind:o,simpleName:"DisposeOnCancel",interfaces:[kt]},Object.defineProperty(vt.prototype,"delegate",{get:function(){return this.delegate_dhbmku$_0}}),Object.defineProperty(vt.prototype,"context",{get:function(){return this.context_xycjfy$_0}}),Object.defineProperty(vt.prototype,"parentHandle_0",{get:function(){return this._parentHandle_0},set:function(t){this._parentHandle_0=t}}),Object.defineProperty(vt.prototype,"state_8be2vx$",{get:function(){return this._state_0}}),Object.defineProperty(vt.prototype,"isActive",{get:function(){return e.isType(this.state_8be2vx$,gt)}}),Object.defineProperty(vt.prototype,"isCompleted",{get:function(){return!e.isType(this.state_8be2vx$,gt)}}),Object.defineProperty(vt.prototype,"isCancelled",{get:function(){return e.isType(this.state_8be2vx$,It)}}),vt.prototype.initCancellability=function(){},vt.prototype.isReusable_0=function(){return e.isType(this.delegate,Gi)&&this.delegate.isReusable},vt.prototype.resetState_8be2vx$=function(){var t=this._state_0;return e.isType(t,Ct)?(this.detachChild_8be2vx$(),!1):(this._decision_0=0,this._state_0=xt(),!0)},vt.prototype.setupCancellation_0=function(){var t;if(!this.checkCompleted_0()&&null===this.parentHandle_0&&null!=(t=this.delegate.context.get_j3r2sn$(xe()))){var e=t;e.start();var n=e.invokeOnCompletion_ct2b2z$(!0,void 0,new un(e,this));this.parentHandle_0=n,this.isCompleted&&!this.isReusable_0()&&(n.dispose(),this.parentHandle_0=De())}},vt.prototype.checkCompleted_0=function(){var t,n,i,r=this.isCompleted;if(0!==this.resumeMode)return r;if(null==(n=e.isType(t=this.delegate,Gi)?t:null))return r;if(null==(i=n.checkPostponedCancellation_jp3215$(this)))return r;var o=i;return r||this.cancel_dbl4no$(o),!0},Object.defineProperty(vt.prototype,"callerFrame",{get:function(){var t;return e.isType(t=this.delegate,Eo)?t:null}}),vt.prototype.getStackTraceElement=function(){return null},vt.prototype.takeState=function(){return this.state_8be2vx$},vt.prototype.cancelResult_83a7kv$=function(t,n){if(e.isType(t,St))try{t.onCancellation(n)}catch(t){if(!e.isType(t,w))throw t;Dt(this.context,new $e("Exception in cancellation handler for "+this,t))}},vt.prototype.cancelLater_0=function(t){var n,i;return 0===this.resumeMode&&null!=(i=e.isType(n=this.delegate,Gi)?n:null)&&i.postponeCancellation_tcv7n7$(t)},vt.prototype.cancel_dbl4no$$default=function(t){for(this._state_0;;){var n=this._state_0;t:do{if(!e.isType(n,gt))return!1;var i=new It(this,t,e.isType(n,kt));if(this._state_0!==n||(this._state_0=i,0))break t;if(e.isType(n,kt))try{n.invoke(t)}catch(t){if(!e.isType(t,w))throw t;Dt(this.context,new $e("Exception in cancellation handler for "+this,t))}return this.detachChildIfNonResuable_0(),this.dispatchResume_0(0),!0}while(0)}},vt.prototype.parentCancelled_8o0b5c$=function(t){this.cancelLater_0(t)||(this.cancel_dbl4no$(t),this.detachChildIfNonResuable_0())},vt.prototype.invokeHandlerSafely_0=function(t){try{t()}catch(t){if(!e.isType(t,w))throw t;Dt(this.context,new $e("Exception in cancellation handler for "+this,t))}},vt.prototype.getContinuationCancellationCause_dqr1mp$=function(t){return t.getCancellationException()},vt.prototype.trySuspend_0=function(){for(this._decision_0;;)switch(this._decision_0){case 0:if(0===this._decision_0&&(this._decision_0=1,1))return!0;break;case 2:return!1;default:throw g("Already suspended".toString())}},vt.prototype.tryResume_0=function(){for(this._decision_0;;)switch(this._decision_0){case 0:if(0===this._decision_0&&(this._decision_0=2,1))return!0;break;case 1:return!1;default:throw g("Already resumed".toString())}},vt.prototype.getResult=function(){if(this.setupCancellation_0(),this.trySuspend_0())return s;var t=this.state_8be2vx$;if(e.isType(t,Rt))throw wo(t.cause);if(1===this.resumeMode){var n=this.context.get_j3r2sn$(xe());if(null!=n&&!n.isActive){var i=n.getCancellationException();throw this.cancelResult_83a7kv$(t,i),wo(i)}}return this.getSuccessfulResult_tpy1pm$(t)},vt.prototype.resumeWith_tl1gpc$=function(t){this.resumeImpl_0(jt(t,this),this.resumeMode)},vt.prototype.resume_qnlsu9$=function(t,n){var i=this.resumeImpl_0(new St(t,n),this.resumeMode);if(null!=i)try{n(i.cause)}catch(t){if(!e.isType(t,w))throw t;Dt(this.context,new $e("Exception in cancellation handler for "+this,t))}},vt.prototype.invokeOnCancellation_f05bi3$=function(t){var n={v:null};for(this._state_0;;){var i,r=this._state_0;if(e.isType(r,bt)){var o;if(null!=(i=n.v))o=i;else{var a=this.makeHandler_0(t);n.v=a,o=a}var s=o;if(this._state_0===r&&(this._state_0=s,1))return}else{if(!e.isType(r,kt)){if(e.isType(r,It)){r.makeHandled()||this.multipleHandlersError_0(t,r);try{var l,u;Tr(t,null!=(u=e.isType(l=r,Rt)?l:null)?u.cause:null)}catch(t){if(!e.isType(t,w))throw t;Dt(this.context,new $e("Exception in cancellation handler for "+this,t))}return}return}this.multipleHandlersError_0(t,r)}}},vt.prototype.multipleHandlersError_0=function(t,e){throw g(("It's prohibited to register multiple handlers, tried to register "+t+", already has "+x(e)).toString())},vt.prototype.makeHandler_0=function(t){return e.isType(t,kt)?t:new Et(t)},vt.prototype.dispatchResume_0=function(t){this.tryResume_0()||Xi(this,t)},vt.prototype.resumeImpl_0=function(t,n){for(this._state_0;;){var i=this._state_0;t:do{if(e.isType(i,gt)){if(this._state_0!==i||(this._state_0=t,0))break t;return this.detachChildIfNonResuable_0(),this.dispatchResume_0(n),null}if(e.isType(i,It)&&i.makeResumed())return i;this.alreadyResumedError_0(t)}while(0)}},vt.prototype.alreadyResumedError_0=function(t){throw g(("Already resumed, but proposed with update "+x(t)).toString())},vt.prototype.detachChildIfNonResuable_0=function(){this.isReusable_0()||this.detachChild_8be2vx$()},vt.prototype.detachChild_8be2vx$=function(){var t=this.parentHandle_0;null!=t&&t.dispose(),this.parentHandle_0=De()},vt.prototype.tryResume_19pj23$$default=function(t,i){for(this._state_0;;){var r=this._state_0;t:do{if(e.isType(r,gt)){var o=null==i?t:new Ct(i,t);if(this._state_0!==r||(this._state_0=o,0))break t;return this.detachChildIfNonResuable_0(),n}return e.isType(r,Ct)&&r.idempotentResume===i?n:null}while(0)}},vt.prototype.tryResumeWithException_tcv7n7$=function(t){for(this._state_0;;){var i=this._state_0;t:do{if(e.isType(i,gt)){var r=new Rt(t);if(this._state_0!==i||(this._state_0=r,0))break t;return this.detachChildIfNonResuable_0(),n}return null}while(0)}},vt.prototype.completeResume_za3rmp$=function(t){this.dispatchResume_0(this.resumeMode)},vt.prototype.resumeUndispatched_hyuxa3$=function(t,n){var i,r=e.isType(i=this.delegate,Gi)?i:null;this.resumeImpl_0(n,(null!=r?r.dispatcher:null)===t?2:this.resumeMode)},vt.prototype.resumeUndispatchedWithException_gd0rtt$=function(t,n){var i,r=e.isType(i=this.delegate,Gi)?i:null;this.resumeImpl_0(new Rt(n),(null!=r?r.dispatcher:null)===t?2:this.resumeMode)},vt.prototype.getSuccessfulResult_tpy1pm$=function(t){var n,o,a;return e.isType(t,Ct)?null==(n=t.result)||e.isType(n,i)?n:r():e.isType(t,St)?null==(o=t.result)||e.isType(o,i)?o:r():null==(a=t)||e.isType(a,i)?a:r()},vt.prototype.toString=function(){return this.nameString()+"("+Ar(this.delegate)+"){"+x(this.state_8be2vx$)+"}@"+Rr(this)},vt.prototype.nameString=function(){return"CancellableContinuation"},vt.$metadata$={kind:o,simpleName:"CancellableContinuationImpl",interfaces:[Eo,_t,Wi]},gt.$metadata$={kind:b,simpleName:"NotCompleted",interfaces:[]},bt.prototype.toString=function(){return"Active"},bt.$metadata$={kind:k,simpleName:"Active",interfaces:[gt]};var wt=null;function xt(){return null===wt&&new bt,wt}function kt(){Sr.call(this)}function Et(t){kt.call(this),this.handler_0=t}function Ct(t,e){this.idempotentResume=t,this.result=e}function St(t,e){this.result=t,this.onCancellation=e}function Tt(){}function Ot(t){Me.call(this,!0),this.initParentJobInternal_8vd9i7$(t)}function Nt(t,e){l.call(this,e),this.exceptionState_0=1,this.$this=t}function Pt(){}function At(t){var n,o=t.exceptionOrNull();return null==o?null==(n=t.value)||e.isType(n,i)?n:r():new Rt(o)}function jt(t,n){var o,a=t.exceptionOrNull();return null==a?null==(o=t.value)||e.isType(o,i)?o:r():new Rt(wo(a))}function Lt(t,n){var o;return e.isType(t,Rt)?new _(E(wo(t.cause))):(_.Companion,new _(null==(o=t)||e.isType(o,i)?o:r()))}function Rt(t,e){void 0===e&&(e=!1),this.cause=t,this._handled_0=e}function It(t,e,n){Rt.call(this,null!=e?e:Vr("Continuation "+t+" was cancelled normally"),n),this._resumed_0=!1}function zt(){C.call(this,m.Key)}function Dt(t,n){var i;try{if(null!=(i=t.get_j3r2sn$(qt())))return void i.handleException_1ur55u$(t,n)}catch(t){if(e.isType(t,w))return void Lr(0,Mt(n,t));throw t}Lr(0,n)}function Mt(t,e){return t===e?t:new S("Exception while trying to handle coroutine exception",e)}function Bt(){qt()}function Ut(){Ft=this}kt.$metadata$={kind:o,simpleName:"CancelHandler",interfaces:[gt,Sr]},Et.prototype.invoke=function(t){this.handler_0(t)},Et.prototype.toString=function(){return"InvokeOnCancel["+Ir(this.handler_0)+"@"+Rr(this)+"]"},Et.$metadata$={kind:o,simpleName:"InvokeOnCancel",interfaces:[kt]},Ct.prototype.toString=function(){return"CompletedIdempotentResult["+x(this.result)+"]"},Ct.$metadata$={kind:o,simpleName:"CompletedIdempotentResult",interfaces:[]},St.prototype.toString=function(){return"CompletedWithCancellation["+x(this.result)+"]"},St.$metadata$={kind:o,simpleName:"CompletedWithCancellation",interfaces:[]},Tt.$metadata$={kind:b,simpleName:"CompletableDeferred",interfaces:[ue]},Object.defineProperty(Ot.prototype,"onCancelComplete",{get:function(){return!0}}),Ot.prototype.getCompleted=function(){var t;return null==(t=this.getCompletedInternal_8be2vx$())||e.isType(t,i)?t:r()},Nt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[l]},Nt.prototype=Object.create(l.prototype),Nt.prototype.constructor=Nt,Nt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.state_0=2,this.result_0=this.$this.awaitInternal_8be2vx$(this),this.result_0===s)return s;continue;case 1:throw this.exception_0;case 2:return null==(t=this.result_0)||e.isType(t,i)?t:r();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.await=function(t,e){var n=new Nt(this,t);return e?n:n.doResume(null)},Object.defineProperty(Ot.prototype,"onAwait",{get:function(){return this}}),Ot.prototype.registerSelectClause1_o3xas4$=function(t,e){this.registerSelectClause1Internal_u6kgbh$(t,e)},Ot.prototype.complete_11rb$=function(t){return this.makeCompleting_8ea4ql$(t)},Ot.prototype.completeExceptionally_tcv7n7$=function(t){return this.makeCompleting_8ea4ql$(new Rt(t))},Ot.$metadata$={kind:o,simpleName:"CompletableDeferredImpl",interfaces:[dr,Tt,Me]},Pt.$metadata$={kind:b,simpleName:"CompletableJob",interfaces:[ge]},Object.defineProperty(Rt.prototype,"handled",{get:function(){return this._handled_0}}),Rt.prototype.makeHandled=function(){return!1===this._handled_0&&(this._handled_0=!0,!0)},Rt.prototype.toString=function(){return Ir(this)+"["+this.cause+"]"},Rt.$metadata$={kind:o,simpleName:"CompletedExceptionally",interfaces:[]},It.prototype.makeResumed=function(){return!1===this._resumed_0&&(this._resumed_0=!0,!0)},It.$metadata$={kind:o,simpleName:"CancelledContinuation",interfaces:[Rt]},zt.prototype.isDispatchNeeded_1fupul$=function(t){return!0},zt.prototype.dispatchYield_5bn72i$=function(t,e){this.dispatch_5bn72i$(t,e)},zt.prototype.interceptContinuation_wj8d80$=function(t){return new Gi(this,t)},zt.prototype.releaseInterceptedContinuation_k98bjh$=function(t){var n,i;null!=(i=(e.isType(n=t,Gi)?n:r()).reusableCancellableContinuation)&&i.detachChild_8be2vx$()},zt.prototype.plus_9wrrq5$=function(t){return t},zt.prototype.toString=function(){return Ir(this)+"@"+Rr(this)},zt.$metadata$={kind:o,simpleName:"CoroutineDispatcher",interfaces:[m,C]},Ut.$metadata$={kind:k,simpleName:"Key",interfaces:[T]};var Ft=null;function qt(){return null===Ft&&new Ut,Ft}function Gt(t){Vt(),C.call(this,Vt()),this.name=t}function Ht(){Yt=this}Bt.$metadata$={kind:b,simpleName:"CoroutineExceptionHandler",interfaces:[O]},Ht.$metadata$={kind:k,simpleName:"Key",interfaces:[T]};var Yt=null;function Vt(){return null===Yt&&new Ht,Yt}function Kt(){}function Wt(){te=this}Gt.prototype.toString=function(){return"CoroutineName("+this.name+")"},Gt.$metadata$={kind:o,simpleName:"CoroutineName",interfaces:[C]},Gt.prototype.component1=function(){return this.name},Gt.prototype.copy_61zpoe$=function(t){return new Gt(void 0===t?this.name:t)},Gt.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.name)|0},Gt.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)},Kt.$metadata$={kind:b,simpleName:"CoroutineScope",interfaces:[]},Object.defineProperty(Wt.prototype,"coroutineContext",{get:function(){return f.EmptyCoroutineContext}}),Wt.$metadata$={kind:k,simpleName:"GlobalScope",interfaces:[Kt]};var Xt,Zt,Jt,Qt,te=null;function ee(t,e){var n;if(void 0===e&&(e=null),null==(n=t.coroutineContext.get_j3r2sn$(xe())))throw g(("Scope cannot be cancelled because it does not have a job: "+t).toString());n.cancel_m4sck1$(e)}function ne(t,e){A.call(this),this.name$=t,this.ordinal$=e}function ie(){ie=function(){},Xt=new ne("DEFAULT",0),Zt=new ne("LAZY",1),Jt=new ne("ATOMIC",2),Qt=new ne("UNDISPATCHED",3)}function re(){return ie(),Xt}function oe(){return ie(),Zt}function ae(){return ie(),Jt}function se(){return ie(),Qt}function le(){}function ue(){}function ce(t){return function(e){var n=new vt(p(e),1);return t(n),n.getResult()}}function pe(){}function he(t){var n,i;return null!=(i=e.isType(n=t.get_j3r2sn$(m.Key),pe)?n:null)?i:Nr()}function _e(){zt.call(this),this.useCount_0=R,this.shared_0=!1,this.unconfinedQueue_0=null}function fe(){de=this,this.ref_0=new Oo}ne.prototype.invoke_810yno$=function(t,n){switch(this.name){case"DEFAULT":rr(t,n);break;case"ATOMIC":N(t,n);break;case"UNDISPATCHED":ur(t,n);break;case"LAZY":break;default:e.noWhenBranchMatched()}},ne.prototype.invoke_3o0yor$=function(t,n,i){switch(this.name){case"DEFAULT":or(t,n,i);break;case"ATOMIC":P(t,n,i);break;case"UNDISPATCHED":cr(t,n,i);break;case"LAZY":break;default:e.noWhenBranchMatched()}},Object.defineProperty(ne.prototype,"isLazy",{get:function(){return this===oe()}}),ne.$metadata$={kind:o,simpleName:"CoroutineStart",interfaces:[A]},ne.values=function(){return[re(),oe(),ae(),se()]},ne.valueOf_61zpoe$=function(t){switch(t){case"DEFAULT":return re();case"LAZY":return oe();case"ATOMIC":return ae();case"UNDISPATCHED":return se();default:j("No enum constant kotlinx.coroutines.CoroutineStart."+t)}},le.$metadata$={kind:b,simpleName:"CopyableThrowable",interfaces:[]},ue.$metadata$={kind:b,simpleName:"Deferred",interfaces:[ge]},pe.prototype.delay_s8cxhz$=function(t,e){if(!(t.toNumber()<=0))return ce((n=t,i=this,function(t){return i.scheduleResumeAfterDelay_egqmvs$(n,t),u}))(e);var n,i},pe.prototype.invokeOnTimeout_8irseu$=function(t,e){return Nr().invokeOnTimeout_8irseu$(t,e)},pe.$metadata$={kind:b,simpleName:"Delay",interfaces:[]},_e.prototype.processNextEvent=function(){return this.processUnconfinedEvent()?this.nextTime:L},Object.defineProperty(_e.prototype,"isEmpty",{get:function(){return this.isUnconfinedQueueEmpty}}),Object.defineProperty(_e.prototype,"nextTime",{get:function(){var t;return null==(t=this.unconfinedQueue_0)||t.isEmpty?L:R}}),_e.prototype.processUnconfinedEvent=function(){var t,e;return null!=(t=this.unconfinedQueue_0)&&null!=(e=t.removeFirstOrNull())&&(e.run(),!0)},_e.prototype.shouldBeProcessedFromContext=function(){return!1},_e.prototype.dispatchUnconfined_4avnfa$=function(t){var e,n;if(null!=(e=this.unconfinedQueue_0))n=e;else{var i=new Bi;this.unconfinedQueue_0=i,n=i}n.addLast_trkh7z$(t)},Object.defineProperty(_e.prototype,"isActive",{get:function(){return this.useCount_0.toNumber()>0}}),Object.defineProperty(_e.prototype,"isUnconfinedLoopActive",{get:function(){return this.useCount_0.compareTo_11rb$(this.delta_0(!0))>=0}}),Object.defineProperty(_e.prototype,"isUnconfinedQueueEmpty",{get:function(){var t,e;return null==(e=null!=(t=this.unconfinedQueue_0)?t.isEmpty:null)||e}}),_e.prototype.delta_0=function(t){return t?I:z},_e.prototype.incrementUseCount_6taknv$=function(t){void 0===t&&(t=!1),this.useCount_0=this.useCount_0.add(this.delta_0(t)),t||(this.shared_0=!0)},_e.prototype.decrementUseCount_6taknv$=function(t){void 0===t&&(t=!1),this.useCount_0=this.useCount_0.subtract(this.delta_0(t)),this.useCount_0.toNumber()>0||this.shared_0&&this.shutdown()},_e.prototype.shutdown=function(){},_e.$metadata$={kind:o,simpleName:"EventLoop",interfaces:[zt]},Object.defineProperty(fe.prototype,"eventLoop_8be2vx$",{get:function(){var t,e;if(null!=(t=this.ref_0.get()))e=t;else{var n=Fr();this.ref_0.set_11rb$(n),e=n}return e}}),fe.prototype.currentOrNull_8be2vx$=function(){return this.ref_0.get()},fe.prototype.resetEventLoop_8be2vx$=function(){this.ref_0.set_11rb$(null)},fe.prototype.setEventLoop_13etkv$=function(t){this.ref_0.set_11rb$(t)},fe.$metadata$={kind:k,simpleName:"ThreadLocalEventLoop",interfaces:[]};var de=null;function me(){return null===de&&new fe,de}function ye(){Gr.call(this),this._queue_0=null,this._delayed_0=null,this._isCompleted_0=!1}function $e(t,e){S.call(this,t,e),this.name="CompletionHandlerException"}function ve(t,e){B.call(this,t,e),this.name="CoroutinesInternalError"}function ge(){xe()}function be(){we=this,qt()}$e.$metadata$={kind:o,simpleName:"CompletionHandlerException",interfaces:[S]},ve.$metadata$={kind:o,simpleName:"CoroutinesInternalError",interfaces:[B]},be.$metadata$={kind:k,simpleName:"Key",interfaces:[T]};var we=null;function xe(){return null===we&&new be,we}function ke(t){return void 0===t&&(t=null),new We(t)}function Ee(){}function Ce(){}function Se(){}function Te(){}function Oe(){ze=this}ge.prototype.cancel_m4sck1$=function(t,e){void 0===t&&(t=null),e?e(t):this.cancel_m4sck1$$default(t)},ge.prototype.cancel=function(){this.cancel_m4sck1$(null)},ge.prototype.cancel_dbl4no$=function(t,e){return void 0===t&&(t=null),e?e(t):this.cancel_dbl4no$$default(t)},ge.prototype.invokeOnCompletion_ct2b2z$=function(t,e,n,i){return void 0===t&&(t=!1),void 0===e&&(e=!0),i?i(t,e,n):this.invokeOnCompletion_ct2b2z$$default(t,e,n)},ge.prototype.plus_dqr1mp$=function(t){return t},ge.$metadata$={kind:b,simpleName:"Job",interfaces:[O]},Ee.$metadata$={kind:b,simpleName:"DisposableHandle",interfaces:[]},Ce.$metadata$={kind:b,simpleName:"ChildJob",interfaces:[ge]},Se.$metadata$={kind:b,simpleName:"ParentJob",interfaces:[ge]},Te.$metadata$={kind:b,simpleName:"ChildHandle",interfaces:[Ee]},Oe.prototype.dispose=function(){},Oe.prototype.childCancelled_tcv7n7$=function(t){return!1},Oe.prototype.toString=function(){return"NonDisposableHandle"},Oe.$metadata$={kind:k,simpleName:"NonDisposableHandle",interfaces:[Te,Ee]};var Ne,Pe,Ae,je,Le,Re,Ie,ze=null;function De(){return null===ze&&new Oe,ze}function Me(t){this._state_v70vig$_0=t?Ie:Re,this._parentHandle_acgcx5$_0=null}function Be(t,e){return function(){return t.state_8be2vx$===e}}function Ue(t,e,n,i){l.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$this$JobSupport=t,this.local$tmp$=void 0,this.local$tmp$_0=void 0,this.local$cur=void 0,this.local$$receiver=e}function Fe(t,e,n){this.list_m9wkmb$_0=t,this._isCompleting_0=e,this._rootCause_0=n,this._exceptionsHolder_0=null}function qe(t,e,n,i){Ze.call(this,n.childJob),this.parent_0=t,this.state_0=e,this.child_0=n,this.proposedUpdate_0=i}function Ge(t,e){vt.call(this,t,1),this.job_0=e}function He(t){this.state=t}function Ye(t){return e.isType(t,Xe)?new He(t):t}function Ve(t){var n,i,r;return null!=(r=null!=(i=e.isType(n=t,He)?n:null)?i.state:null)?r:t}function Ke(t){this.isActive_hyoax9$_0=t}function We(t){Me.call(this,!0),this.initParentJobInternal_8vd9i7$(t),this.handlesException_fejgjb$_0=this.handlesExceptionF()}function Xe(){}function Ze(t){Cr.call(this),this.job=t}function Je(){bo.call(this)}function Qe(t){this.list_afai45$_0=t}function tn(t,e){Ze.call(this,t),this.handler_0=e}function en(t,e){Ze.call(this,t),this.continuation_0=e}function nn(t,e){Ze.call(this,t),this.continuation_0=e}function rn(t,e,n){Ze.call(this,t),this.select_0=e,this.block_0=n}function on(t,e,n){Ze.call(this,t),this.select_0=e,this.block_0=n}function an(t){Ze.call(this,t)}function sn(t,e){an.call(this,t),this.handler_0=e,this._invoked_0=0}function ln(t,e){an.call(this,t),this.childJob=e}function un(t,e){an.call(this,t),this.child=e}function cn(){zt.call(this)}function pn(){C.call(this,xe())}function hn(t){We.call(this,t)}function _n(t,e){Vr(t,this),this.coroutine_8be2vx$=e,this.name="TimeoutCancellationException"}function fn(){dn=this,zt.call(this)}Object.defineProperty(Me.prototype,"key",{get:function(){return xe()}}),Object.defineProperty(Me.prototype,"parentHandle_8be2vx$",{get:function(){return this._parentHandle_acgcx5$_0},set:function(t){this._parentHandle_acgcx5$_0=t}}),Me.prototype.initParentJobInternal_8vd9i7$=function(t){if(null!=t){t.start();var e=t.attachChild_kx8v25$(this);this.parentHandle_8be2vx$=e,this.isCompleted&&(e.dispose(),this.parentHandle_8be2vx$=De())}else this.parentHandle_8be2vx$=De()},Object.defineProperty(Me.prototype,"state_8be2vx$",{get:function(){for(this._state_v70vig$_0;;){var t=this._state_v70vig$_0;if(!e.isType(t,Ui))return t;t.perform_s8jyv4$(this)}}}),Me.prototype.loopOnState_46ivxf$_0=function(t){for(;;)t(this.state_8be2vx$)},Object.defineProperty(Me.prototype,"isActive",{get:function(){var t=this.state_8be2vx$;return e.isType(t,Xe)&&t.isActive}}),Object.defineProperty(Me.prototype,"isCompleted",{get:function(){return!e.isType(this.state_8be2vx$,Xe)}}),Object.defineProperty(Me.prototype,"isCancelled",{get:function(){var t=this.state_8be2vx$;return e.isType(t,Rt)||e.isType(t,Fe)&&t.isCancelling}}),Me.prototype.finalizeFinishingState_10mr1z$_0=function(t,n){var i,o,a,s=null!=(o=e.isType(i=n,Rt)?i:null)?o.cause:null,l={v:!1};l.v=t.isCancelling;var u=t.sealLocked_dbl4no$(s),c=this.getFinalRootCause_3zkch4$_0(t,u);null!=c&&this.addSuppressedExceptions_85dgeo$_0(c,u);var p=c,h=null==p||p===s?n:new Rt(p);return null!=p&&(this.cancelParent_7dutpz$_0(p)||this.handleJobException_tcv7n7$(p))&&(e.isType(a=h,Rt)?a:r()).makeHandled(),l.v||this.onCancelling_dbl4no$(p),this.onCompletionInternal_s8jyv4$(h),this._state_v70vig$_0===t&&(this._state_v70vig$_0=Ye(h)),this.completeStateFinalization_a4ilmi$_0(t,h),h},Me.prototype.getFinalRootCause_3zkch4$_0=function(t,n){if(n.isEmpty())return t.isCancelling?new Kr(this.cancellationExceptionMessage(),null,this):null;var i;t:do{var r;for(r=n.iterator();r.hasNext();){var o=r.next();if(!e.isType(o,Yr)){i=o;break t}}i=null}while(0);if(null!=i)return i;var a=n.get_za3lpa$(0);if(e.isType(a,_n)){var s;t:do{var l;for(l=n.iterator();l.hasNext();){var u=l.next();if(u!==a&&e.isType(u,_n)){s=u;break t}}s=null}while(0);if(null!=s)return s}return a},Me.prototype.addSuppressedExceptions_85dgeo$_0=function(t,n){var i;if(!(n.size<=1)){var r=fo(n.size),o=t;for(i=n.iterator();i.hasNext();){var a=i.next();a!==t&&a!==o&&!e.isType(a,Yr)&&r.add_11rb$(a)}}},Me.prototype.tryFinalizeSimpleState_5emg4m$_0=function(t,e){return this._state_v70vig$_0===t&&(this._state_v70vig$_0=Ye(e),!0)&&(this.onCancelling_dbl4no$(null),this.onCompletionInternal_s8jyv4$(e),this.completeStateFinalization_a4ilmi$_0(t,e),!0)},Me.prototype.completeStateFinalization_a4ilmi$_0=function(t,n){var i,r,o,a;null!=(i=this.parentHandle_8be2vx$)&&(i.dispose(),this.parentHandle_8be2vx$=De());var s=null!=(o=e.isType(r=n,Rt)?r:null)?o.cause:null;if(e.isType(t,Ze))try{t.invoke(s)}catch(n){if(!e.isType(n,w))throw n;this.handleOnCompletionException_tcv7n7$(new $e("Exception in completion handler "+t+" for "+this,n))}else null!=(a=t.list)&&this.notifyCompletion_mgxta4$_0(a,s)},Me.prototype.notifyCancelling_xkpzb8$_0=function(t,n){var i;this.onCancelling_dbl4no$(n);for(var r={v:null},o=t._next;!y(o,t);){if(e.isType(o,an)){var a,s=o;try{s.invoke(n)}catch(t){if(!e.isType(t,w))throw t;null==(null!=(a=r.v)?a:null)&&(r.v=new $e("Exception in completion handler "+s+" for "+this,t))}}o=o._next}null!=(i=r.v)&&this.handleOnCompletionException_tcv7n7$(i),this.cancelParent_7dutpz$_0(n)},Me.prototype.cancelParent_7dutpz$_0=function(t){if(this.isScopedCoroutine)return!0;var n=e.isType(t,Yr),i=this.parentHandle_8be2vx$;return null===i||i===De()?n:i.childCancelled_tcv7n7$(t)||n},Me.prototype.notifyCompletion_mgxta4$_0=function(t,n){for(var i,r={v:null},o=t._next;!y(o,t);){if(e.isType(o,Ze)){var a,s=o;try{s.invoke(n)}catch(t){if(!e.isType(t,w))throw t;null==(null!=(a=r.v)?a:null)&&(r.v=new $e("Exception in completion handler "+s+" for "+this,t))}}o=o._next}null!=(i=r.v)&&this.handleOnCompletionException_tcv7n7$(i)},Me.prototype.notifyHandlers_alhslr$_0=v((function(){var t=e.equals;return function(n,i,r,o){for(var a,s={v:null},l=r._next;!t(l,r);){if(i(l)){var u,c=l;try{c.invoke(o)}catch(t){if(!e.isType(t,w))throw t;null==(null!=(u=s.v)?u:null)&&(s.v=new $e("Exception in completion handler "+c+" for "+this,t))}}l=l._next}null!=(a=s.v)&&this.handleOnCompletionException_tcv7n7$(a)}})),Me.prototype.start=function(){for(;;)switch(this.startInternal_tp1bqd$_0(this.state_8be2vx$)){case 0:return!1;case 1:return!0}},Me.prototype.startInternal_tp1bqd$_0=function(t){return e.isType(t,Ke)?t.isActive?0:this._state_v70vig$_0!==t||(this._state_v70vig$_0=Ie,0)?-1:(this.onStartInternal(),1):e.isType(t,Qe)?function(e){return e._state_v70vig$_0===t&&(e._state_v70vig$_0=t.list,!0)}(this)?(this.onStartInternal(),1):-1:0},Me.prototype.onStartInternal=function(){},Me.prototype.getCancellationException=function(){var t,n,i=this.state_8be2vx$;if(e.isType(i,Fe)){if(null==(n=null!=(t=i.rootCause)?this.toCancellationException_rg9tb7$(t,Ir(this)+" is cancelling"):null))throw g(("Job is still new or active: "+this).toString());return n}if(e.isType(i,Xe))throw g(("Job is still new or active: "+this).toString());return e.isType(i,Rt)?this.toCancellationException_rg9tb7$(i.cause):new Kr(Ir(this)+" has completed normally",null,this)},Me.prototype.toCancellationException_rg9tb7$=function(t,n){var i,r;return void 0===n&&(n=null),null!=(r=e.isType(i=t,Yr)?i:null)?r:new Kr(null!=n?n:this.cancellationExceptionMessage(),t,this)},Object.defineProperty(Me.prototype,"completionCause",{get:function(){var t,n=this.state_8be2vx$;if(e.isType(n,Fe)){if(null==(t=n.rootCause))throw g(("Job is still new or active: "+this).toString());return t}if(e.isType(n,Xe))throw g(("Job is still new or active: "+this).toString());return e.isType(n,Rt)?n.cause:null}}),Object.defineProperty(Me.prototype,"completionCauseHandled",{get:function(){var t=this.state_8be2vx$;return e.isType(t,Rt)&&t.handled}}),Me.prototype.invokeOnCompletion_f05bi3$=function(t){return this.invokeOnCompletion_ct2b2z$(!1,!0,t)},Me.prototype.invokeOnCompletion_ct2b2z$$default=function(t,n,i){for(var o={v:null};;){var a=this.state_8be2vx$;t:do{var s,l,u,c,p;if(e.isType(a,Ke))if(a.isActive){var h;if(null!=(s=o.v))h=s;else{var _=this.makeNode_9qhc1i$_0(i,t);o.v=_,h=_}var f=h;if(this._state_v70vig$_0===a&&(this._state_v70vig$_0=f,1))return f}else this.promoteEmptyToNodeList_lchanx$_0(a);else{if(!e.isType(a,Xe))return n&&Tr(i,null!=(p=e.isType(c=a,Rt)?c:null)?p.cause:null),De();var d=a.list;if(null==d)this.promoteSingleToNodeList_ft43ca$_0(e.isType(l=a,Ze)?l:r());else{var m,y={v:null},$={v:De()};if(t&&e.isType(a,Fe)){var v;y.v=a.rootCause;var g=null==y.v;if(g||(g=e.isType(i,ln)&&!a.isCompleting),g){var b;if(null!=(v=o.v))b=v;else{var w=this.makeNode_9qhc1i$_0(i,t);o.v=w,b=w}var x=b;if(!this.addLastAtomic_qayz7c$_0(a,d,x))break t;if(null==y.v)return x;$.v=x}}if(null!=y.v)return n&&Tr(i,y.v),$.v;if(null!=(u=o.v))m=u;else{var k=this.makeNode_9qhc1i$_0(i,t);o.v=k,m=k}var E=m;if(this.addLastAtomic_qayz7c$_0(a,d,E))return E}}}while(0)}},Me.prototype.makeNode_9qhc1i$_0=function(t,n){var i,r,o,a,s,l;return n?null!=(o=null!=(r=e.isType(i=t,an)?i:null)?r:null)?o:new sn(this,t):null!=(l=null!=(s=e.isType(a=t,Ze)?a:null)?s:null)?l:new tn(this,t)},Me.prototype.addLastAtomic_qayz7c$_0=function(t,e,n){var i;t:do{if(!Be(this,t)()){i=!1;break t}e.addLast_l2j9rm$(n),i=!0}while(0);return i},Me.prototype.promoteEmptyToNodeList_lchanx$_0=function(t){var e=new Je,n=t.isActive?e:new Qe(e);this._state_v70vig$_0===t&&(this._state_v70vig$_0=n)},Me.prototype.promoteSingleToNodeList_ft43ca$_0=function(t){t.addOneIfEmpty_l2j9rm$(new Je);var e=t._next;this._state_v70vig$_0===t&&(this._state_v70vig$_0=e)},Me.prototype.join=function(t){if(this.joinInternal_ta6o25$_0())return this.joinSuspend_kfh5g8$_0(t);Sn(t.context)},Me.prototype.joinInternal_ta6o25$_0=function(){for(;;){var t=this.state_8be2vx$;if(!e.isType(t,Xe))return!1;if(this.startInternal_tp1bqd$_0(t)>=0)return!0}},Me.prototype.joinSuspend_kfh5g8$_0=function(t){return(n=this,e=function(t){return mt(t,n.invokeOnCompletion_f05bi3$(new en(n,t))),u},function(t){var n=new vt(p(t),1);return e(n),n.getResult()})(t);var e,n},Object.defineProperty(Me.prototype,"onJoin",{get:function(){return this}}),Me.prototype.registerSelectClause0_s9h9qd$=function(t,n){for(;;){var i=this.state_8be2vx$;if(t.isSelected)return;if(!e.isType(i,Xe))return void(t.trySelect()&&sr(n,t.completion));if(0===this.startInternal_tp1bqd$_0(i))return void t.disposeOnSelect_rvfg84$(this.invokeOnCompletion_f05bi3$(new rn(this,t,n)))}},Me.prototype.removeNode_nxb11s$=function(t){for(;;){var n=this.state_8be2vx$;if(!e.isType(n,Ze))return e.isType(n,Xe)?void(null!=n.list&&t.remove()):void 0;if(n!==t)return;if(this._state_v70vig$_0===n&&(this._state_v70vig$_0=Ie,1))return}},Object.defineProperty(Me.prototype,"onCancelComplete",{get:function(){return!1}}),Me.prototype.cancel_m4sck1$$default=function(t){this.cancelInternal_tcv7n7$(null!=t?t:new Kr(this.cancellationExceptionMessage(),null,this))},Me.prototype.cancellationExceptionMessage=function(){return"Job was cancelled"},Me.prototype.cancel_dbl4no$$default=function(t){var e;return this.cancelInternal_tcv7n7$(null!=(e=null!=t?this.toCancellationException_rg9tb7$(t):null)?e:new Kr(this.cancellationExceptionMessage(),null,this)),!0},Me.prototype.cancelInternal_tcv7n7$=function(t){this.cancelImpl_8ea4ql$(t)},Me.prototype.parentCancelled_pv1t6x$=function(t){this.cancelImpl_8ea4ql$(t)},Me.prototype.childCancelled_tcv7n7$=function(t){return!!e.isType(t,Yr)||this.cancelImpl_8ea4ql$(t)&&this.handlesException},Me.prototype.cancelCoroutine_dbl4no$=function(t){return this.cancelImpl_8ea4ql$(t)},Me.prototype.cancelImpl_8ea4ql$=function(t){var e,n=Ne;return!(!this.onCancelComplete||(n=this.cancelMakeCompleting_z3ww04$_0(t))!==Pe)||(n===Ne&&(n=this.makeCancelling_xjon1g$_0(t)),n===Ne||n===Pe?e=!0:n===je?e=!1:(this.afterCompletion_s8jyv4$(n),e=!0),e)},Me.prototype.cancelMakeCompleting_z3ww04$_0=function(t){for(;;){var n=this.state_8be2vx$;if(!e.isType(n,Xe)||e.isType(n,Fe)&&n.isCompleting)return Ne;var i=new Rt(this.createCauseException_kfrsk8$_0(t)),r=this.tryMakeCompleting_w5s53t$_0(n,i);if(r!==Ae)return r}},Me.prototype.defaultCancellationException_6umzry$=$("kotlinx-coroutines-core.kotlinx.coroutines.JobSupport.defaultCancellationException_6umzry$",v((function(){var e=t.kotlinx.coroutines.JobCancellationException;return function(t,n){return void 0===t&&(t=null),void 0===n&&(n=null),new e(null!=t?t:this.cancellationExceptionMessage(),n,this)}}))),Me.prototype.getChildJobCancellationCause=function(){var t,n,i,r=this.state_8be2vx$;if(e.isType(r,Fe))t=r.rootCause;else if(e.isType(r,Rt))t=r.cause;else{if(e.isType(r,Xe))throw g(("Cannot be cancelling child in this state: "+x(r)).toString());t=null}var o=t;return null!=(i=e.isType(n=o,Yr)?n:null)?i:new Kr("Parent job is "+this.stateString_u2sjqg$_0(r),o,this)},Me.prototype.createCauseException_kfrsk8$_0=function(t){var n;return null==t||e.isType(t,w)?null!=t?t:new Kr(this.cancellationExceptionMessage(),null,this):(e.isType(n=t,Se)?n:r()).getChildJobCancellationCause()},Me.prototype.makeCancelling_xjon1g$_0=function(t){for(var n={v:null};;){var i,r,o=this.state_8be2vx$;if(e.isType(o,Fe)){var a;if(o.isSealed)return je;var s=o.isCancelling;if(null!=t||!s){var l;if(null!=(a=n.v))l=a;else{var u=this.createCauseException_kfrsk8$_0(t);n.v=u,l=u}var c=l;o.addExceptionLocked_tcv7n7$(c)}var p=o.rootCause,h=s?null:p;return null!=h&&this.notifyCancelling_xkpzb8$_0(o.list,h),Ne}if(!e.isType(o,Xe))return je;if(null!=(i=n.v))r=i;else{var _=this.createCauseException_kfrsk8$_0(t);n.v=_,r=_}var f=r;if(o.isActive){if(this.tryMakeCancelling_v0qvyy$_0(o,f))return Ne}else{var d=this.tryMakeCompleting_w5s53t$_0(o,new Rt(f));if(d===Ne)throw g(("Cannot happen in "+x(o)).toString());if(d!==Ae)return d}}},Me.prototype.getOrPromoteCancellingList_dmij2j$_0=function(t){var n,i;if(null==(i=t.list)){if(e.isType(t,Ke))n=new Je;else{if(!e.isType(t,Ze))throw g(("State should have list: "+t).toString());this.promoteSingleToNodeList_ft43ca$_0(t),n=null}i=n}return i},Me.prototype.tryMakeCancelling_v0qvyy$_0=function(t,e){var n;if(null==(n=this.getOrPromoteCancellingList_dmij2j$_0(t)))return!1;var i=n,r=new Fe(i,!1,e);return this._state_v70vig$_0===t&&(this._state_v70vig$_0=r,!0)&&(this.notifyCancelling_xkpzb8$_0(i,e),!0)},Me.prototype.makeCompleting_8ea4ql$=function(t){for(;;){var e=this.tryMakeCompleting_w5s53t$_0(this.state_8be2vx$,t);if(e===Ne)return!1;if(e===Pe)return!0;if(e!==Ae)return this.afterCompletion_s8jyv4$(e),!0}},Me.prototype.makeCompletingOnce_8ea4ql$=function(t){for(;;){var e=this.tryMakeCompleting_w5s53t$_0(this.state_8be2vx$,t);if(e===Ne)throw new U("Job "+this+" is already complete or completing, but is being completed with "+x(t),this.get_exceptionOrNull_ejijbb$_0(t));if(e!==Ae)return e}},Me.prototype.tryMakeCompleting_w5s53t$_0=function(t,n){return e.isType(t,Xe)?!e.isType(t,Ke)&&!e.isType(t,Ze)||e.isType(t,ln)||e.isType(n,Rt)?this.tryMakeCompletingSlowPath_uh1ctj$_0(t,n):this.tryFinalizeSimpleState_5emg4m$_0(t,n)?n:Ae:Ne},Me.prototype.tryMakeCompletingSlowPath_uh1ctj$_0=function(t,n){var i,r,o,a;if(null==(i=this.getOrPromoteCancellingList_dmij2j$_0(t)))return Ae;var s,l,u=i,c=null!=(o=e.isType(r=t,Fe)?r:null)?o:new Fe(u,!1,null),p={v:null};if(c.isCompleting)return Ne;if(c.isCompleting=!0,c!==t&&(this._state_v70vig$_0!==t||(this._state_v70vig$_0=c,0)))return Ae;var h=c.isCancelling;null!=(l=e.isType(s=n,Rt)?s:null)&&c.addExceptionLocked_tcv7n7$(l.cause);var _=c.rootCause;p.v=h?null:_,null!=(a=p.v)&&this.notifyCancelling_xkpzb8$_0(u,a);var f=this.firstChild_15hr5g$_0(t);return null!=f&&this.tryWaitForChild_dzo3im$_0(c,f,n)?Pe:this.finalizeFinishingState_10mr1z$_0(c,n)},Me.prototype.get_exceptionOrNull_ejijbb$_0=function(t){var n,i;return null!=(i=e.isType(n=t,Rt)?n:null)?i.cause:null},Me.prototype.firstChild_15hr5g$_0=function(t){var n,i,r;return null!=(r=e.isType(n=t,ln)?n:null)?r:null!=(i=t.list)?this.nextChild_n2no7k$_0(i):null},Me.prototype.tryWaitForChild_dzo3im$_0=function(t,e,n){var i;if(e.childJob.invokeOnCompletion_ct2b2z$(void 0,!1,new qe(this,t,e,n))!==De())return!0;if(null==(i=this.nextChild_n2no7k$_0(e)))return!1;var r=i;return this.tryWaitForChild_dzo3im$_0(t,r,n)},Me.prototype.continueCompleting_vth2d4$_0=function(t,e,n){var i=this.nextChild_n2no7k$_0(e);if(null==i||!this.tryWaitForChild_dzo3im$_0(t,i,n)){var r=this.finalizeFinishingState_10mr1z$_0(t,n);this.afterCompletion_s8jyv4$(r)}},Me.prototype.nextChild_n2no7k$_0=function(t){for(var n=t;n._removed;)n=n._prev;for(;;)if(!(n=n._next)._removed){if(e.isType(n,ln))return n;if(e.isType(n,Je))return null}},Ue.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[l]},Ue.prototype=Object.create(l.prototype),Ue.prototype.constructor=Ue,Ue.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=this.local$this$JobSupport.state_8be2vx$;if(e.isType(t,ln)){if(this.state_0=8,this.result_0=this.local$$receiver.yield_11rb$(t.childJob,this),this.result_0===s)return s;continue}if(e.isType(t,Xe)){if(null!=(this.local$tmp$=t.list)){this.local$cur=this.local$tmp$._next,this.state_0=2;continue}this.local$tmp$_0=null,this.state_0=6;continue}this.state_0=7;continue;case 1:throw this.exception_0;case 2:if(y(this.local$cur,this.local$tmp$)){this.state_0=5;continue}if(e.isType(this.local$cur,ln)){if(this.state_0=3,this.result_0=this.local$$receiver.yield_11rb$(this.local$cur.childJob,this),this.result_0===s)return s;continue}this.state_0=4;continue;case 3:this.state_0=4;continue;case 4:this.local$cur=this.local$cur._next,this.state_0=2;continue;case 5:this.local$tmp$_0=u,this.state_0=6;continue;case 6:return this.local$tmp$_0;case 7:this.state_0=9;continue;case 8:return this.result_0;case 9:return u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(Me.prototype,"children",{get:function(){return F((t=this,function(e,n,i){var r=new Ue(t,e,this,n);return i?r:r.doResume(null)}));var t}}),Me.prototype.attachChild_kx8v25$=function(t){var n;return e.isType(n=this.invokeOnCompletion_ct2b2z$(!0,void 0,new ln(this,t)),Te)?n:r()},Me.prototype.handleOnCompletionException_tcv7n7$=function(t){throw t},Me.prototype.onCancelling_dbl4no$=function(t){},Object.defineProperty(Me.prototype,"isScopedCoroutine",{get:function(){return!1}}),Object.defineProperty(Me.prototype,"handlesException",{get:function(){return!0}}),Me.prototype.handleJobException_tcv7n7$=function(t){return!1},Me.prototype.onCompletionInternal_s8jyv4$=function(t){},Me.prototype.afterCompletion_s8jyv4$=function(t){},Me.prototype.toString=function(){return this.toDebugString()+"@"+Rr(this)},Me.prototype.toDebugString=function(){return this.nameString()+"{"+this.stateString_u2sjqg$_0(this.state_8be2vx$)+"}"},Me.prototype.nameString=function(){return Ir(this)},Me.prototype.stateString_u2sjqg$_0=function(t){return e.isType(t,Fe)?t.isCancelling?"Cancelling":t.isCompleting?"Completing":"Active":e.isType(t,Xe)?t.isActive?"Active":"New":e.isType(t,Rt)?"Cancelled":"Completed"},Object.defineProperty(Fe.prototype,"list",{get:function(){return this.list_m9wkmb$_0}}),Object.defineProperty(Fe.prototype,"isCompleting",{get:function(){return this._isCompleting_0},set:function(t){this._isCompleting_0=t}}),Object.defineProperty(Fe.prototype,"rootCause",{get:function(){return this._rootCause_0},set:function(t){this._rootCause_0=t}}),Object.defineProperty(Fe.prototype,"exceptionsHolder_0",{get:function(){return this._exceptionsHolder_0},set:function(t){this._exceptionsHolder_0=t}}),Object.defineProperty(Fe.prototype,"isSealed",{get:function(){return this.exceptionsHolder_0===Le}}),Object.defineProperty(Fe.prototype,"isCancelling",{get:function(){return null!=this.rootCause}}),Object.defineProperty(Fe.prototype,"isActive",{get:function(){return null==this.rootCause}}),Fe.prototype.sealLocked_dbl4no$=function(t){var n,i,o=this.exceptionsHolder_0;if(null==o)i=this.allocateList_0();else if(e.isType(o,w)){var a=this.allocateList_0();a.add_11rb$(o),i=a}else{if(!e.isType(o,q))throw g(("State is "+x(o)).toString());i=e.isType(n=o,q)?n:r()}var s=i,l=this.rootCause;return null!=l&&s.add_wxm5ur$(0,l),null==t||y(t,l)||s.add_11rb$(t),this.exceptionsHolder_0=Le,s},Fe.prototype.addExceptionLocked_tcv7n7$=function(t){var n,i=this.rootCause;if(null!=i){if(t!==i){var o=this.exceptionsHolder_0;if(null==o)this.exceptionsHolder_0=t;else if(e.isType(o,w)){if(t===o)return;var a=this.allocateList_0();a.add_11rb$(o),a.add_11rb$(t),this.exceptionsHolder_0=a}else{if(!e.isType(o,q))throw g(("State is "+x(o)).toString());(e.isType(n=o,q)?n:r()).add_11rb$(t)}}}else this.rootCause=t},Fe.prototype.allocateList_0=function(){return h(4)},Fe.prototype.toString=function(){return"Finishing[cancelling="+this.isCancelling+", completing="+this.isCompleting+", rootCause="+x(this.rootCause)+", exceptions="+x(this.exceptionsHolder_0)+", list="+this.list+"]"},Fe.$metadata$={kind:o,simpleName:"Finishing",interfaces:[Xe]},Me.prototype.get_isCancelling_dpdoz8$_0=function(t){return e.isType(t,Fe)&&t.isCancelling},qe.prototype.invoke=function(t){this.parent_0.continueCompleting_vth2d4$_0(this.state_0,this.child_0,this.proposedUpdate_0)},qe.prototype.toString=function(){return"ChildCompletion["+this.child_0+", "+x(this.proposedUpdate_0)+"]"},qe.$metadata$={kind:o,simpleName:"ChildCompletion",interfaces:[Ze]},Ge.prototype.getContinuationCancellationCause_dqr1mp$=function(t){var n,i=this.job_0.state_8be2vx$;return e.isType(i,Fe)&&null!=(n=i.rootCause)?n:e.isType(i,Rt)?i.cause:t.getCancellationException()},Ge.prototype.nameString=function(){return"AwaitContinuation"},Ge.$metadata$={kind:o,simpleName:"AwaitContinuation",interfaces:[vt]},Object.defineProperty(Me.prototype,"isCompletedExceptionally",{get:function(){return e.isType(this.state_8be2vx$,Rt)}}),Me.prototype.getCompletionExceptionOrNull=function(){var t=this.state_8be2vx$;if(e.isType(t,Xe))throw g("This job has not completed yet".toString());return this.get_exceptionOrNull_ejijbb$_0(t)},Me.prototype.getCompletedInternal_8be2vx$=function(){var t=this.state_8be2vx$;if(e.isType(t,Xe))throw g("This job has not completed yet".toString());if(e.isType(t,Rt))throw t.cause;return Ve(t)},Me.prototype.awaitInternal_8be2vx$=function(t){for(;;){var n=this.state_8be2vx$;if(!e.isType(n,Xe)){if(e.isType(n,Rt))throw n.cause;return Ve(n)}if(this.startInternal_tp1bqd$_0(n)>=0)break}return this.awaitSuspend_ixl9xw$_0(t)},Me.prototype.awaitSuspend_ixl9xw$_0=function(t){return(e=this,function(t){var n=new Ge(p(t),e);return mt(n,e.invokeOnCompletion_f05bi3$(new nn(e,n))),n.getResult()})(t);var e},Me.prototype.registerSelectClause1Internal_u6kgbh$=function(t,n){for(;;){var o,a=this.state_8be2vx$;if(t.isSelected)return;if(!e.isType(a,Xe))return void(t.trySelect()&&(e.isType(a,Rt)?t.resumeSelectWithException_tcv7n7$(a.cause):lr(n,null==(o=Ve(a))||e.isType(o,i)?o:r(),t.completion)));if(0===this.startInternal_tp1bqd$_0(a))return void t.disposeOnSelect_rvfg84$(this.invokeOnCompletion_f05bi3$(new on(this,t,n)))}},Me.prototype.selectAwaitCompletion_u6kgbh$=function(t,n){var o,a=this.state_8be2vx$;e.isType(a,Rt)?t.resumeSelectWithException_tcv7n7$(a.cause):or(n,null==(o=Ve(a))||e.isType(o,i)?o:r(),t.completion)},Me.$metadata$={kind:o,simpleName:"JobSupport",interfaces:[fr,Se,Ce,ge]},He.$metadata$={kind:o,simpleName:"IncompleteStateBox",interfaces:[]},Object.defineProperty(Ke.prototype,"isActive",{get:function(){return this.isActive_hyoax9$_0}}),Object.defineProperty(Ke.prototype,"list",{get:function(){return null}}),Ke.prototype.toString=function(){return"Empty{"+(this.isActive?"Active":"New")+"}"},Ke.$metadata$={kind:o,simpleName:"Empty",interfaces:[Xe]},Object.defineProperty(We.prototype,"onCancelComplete",{get:function(){return!0}}),Object.defineProperty(We.prototype,"handlesException",{get:function(){return this.handlesException_fejgjb$_0}}),We.prototype.complete=function(){return this.makeCompleting_8ea4ql$(u)},We.prototype.completeExceptionally_tcv7n7$=function(t){return this.makeCompleting_8ea4ql$(new Rt(t))},We.prototype.handlesExceptionF=function(){var t,n,i,r,o,a;if(null==(i=null!=(n=e.isType(t=this.parentHandle_8be2vx$,ln)?t:null)?n.job:null))return!1;for(var s=i;;){if(s.handlesException)return!0;if(null==(a=null!=(o=e.isType(r=s.parentHandle_8be2vx$,ln)?r:null)?o.job:null))return!1;s=a}},We.$metadata$={kind:o,simpleName:"JobImpl",interfaces:[Pt,Me]},Xe.$metadata$={kind:b,simpleName:"Incomplete",interfaces:[]},Object.defineProperty(Ze.prototype,"isActive",{get:function(){return!0}}),Object.defineProperty(Ze.prototype,"list",{get:function(){return null}}),Ze.prototype.dispose=function(){var t;(e.isType(t=this.job,Me)?t:r()).removeNode_nxb11s$(this)},Ze.$metadata$={kind:o,simpleName:"JobNode",interfaces:[Xe,Ee,Cr]},Object.defineProperty(Je.prototype,"isActive",{get:function(){return!0}}),Object.defineProperty(Je.prototype,"list",{get:function(){return this}}),Je.prototype.getString_61zpoe$=function(t){var n=G();n.append_gw00v9$("List{"),n.append_gw00v9$(t),n.append_gw00v9$("}[");for(var i={v:!0},r=this._next;!y(r,this);){if(e.isType(r,Ze)){var o=r;i.v?i.v=!1:n.append_gw00v9$(", "),n.append_s8jyv4$(o)}r=r._next}return n.append_gw00v9$("]"),n.toString()},Je.prototype.toString=function(){return Ti?this.getString_61zpoe$("Active"):bo.prototype.toString.call(this)},Je.$metadata$={kind:o,simpleName:"NodeList",interfaces:[Xe,bo]},Object.defineProperty(Qe.prototype,"list",{get:function(){return this.list_afai45$_0}}),Object.defineProperty(Qe.prototype,"isActive",{get:function(){return!1}}),Qe.prototype.toString=function(){return Ti?this.list.getString_61zpoe$("New"):i.prototype.toString.call(this)},Qe.$metadata$={kind:o,simpleName:"InactiveNodeList",interfaces:[Xe]},tn.prototype.invoke=function(t){this.handler_0(t)},tn.prototype.toString=function(){return"InvokeOnCompletion["+Ir(this)+"@"+Rr(this)+"]"},tn.$metadata$={kind:o,simpleName:"InvokeOnCompletion",interfaces:[Ze]},en.prototype.invoke=function(t){this.continuation_0.resumeWith_tl1gpc$(new _(u))},en.prototype.toString=function(){return"ResumeOnCompletion["+this.continuation_0+"]"},en.$metadata$={kind:o,simpleName:"ResumeOnCompletion",interfaces:[Ze]},nn.prototype.invoke=function(t){var n,o,a=this.job.state_8be2vx$;if(e.isType(a,Rt)){var s=this.continuation_0,l=a.cause;s.resumeWith_tl1gpc$(new _(E(l)))}else{o=this.continuation_0;var u=null==(n=Ve(a))||e.isType(n,i)?n:r();o.resumeWith_tl1gpc$(new _(u))}},nn.prototype.toString=function(){return"ResumeAwaitOnCompletion["+this.continuation_0+"]"},nn.$metadata$={kind:o,simpleName:"ResumeAwaitOnCompletion",interfaces:[Ze]},rn.prototype.invoke=function(t){this.select_0.trySelect()&&rr(this.block_0,this.select_0.completion)},rn.prototype.toString=function(){return"SelectJoinOnCompletion["+this.select_0+"]"},rn.$metadata$={kind:o,simpleName:"SelectJoinOnCompletion",interfaces:[Ze]},on.prototype.invoke=function(t){this.select_0.trySelect()&&this.job.selectAwaitCompletion_u6kgbh$(this.select_0,this.block_0)},on.prototype.toString=function(){return"SelectAwaitOnCompletion["+this.select_0+"]"},on.$metadata$={kind:o,simpleName:"SelectAwaitOnCompletion",interfaces:[Ze]},an.$metadata$={kind:o,simpleName:"JobCancellingNode",interfaces:[Ze]},sn.prototype.invoke=function(t){0===this._invoked_0&&(this._invoked_0=1,1)&&this.handler_0(t)},sn.prototype.toString=function(){return"InvokeOnCancelling["+Ir(this)+"@"+Rr(this)+"]"},sn.$metadata$={kind:o,simpleName:"InvokeOnCancelling",interfaces:[an]},ln.prototype.invoke=function(t){this.childJob.parentCancelled_pv1t6x$(this.job)},ln.prototype.childCancelled_tcv7n7$=function(t){return this.job.childCancelled_tcv7n7$(t)},ln.prototype.toString=function(){return"ChildHandle["+this.childJob+"]"},ln.$metadata$={kind:o,simpleName:"ChildHandleNode",interfaces:[Te,an]},un.prototype.invoke=function(t){this.child.parentCancelled_8o0b5c$(this.child.getContinuationCancellationCause_dqr1mp$(this.job))},un.prototype.toString=function(){return"ChildContinuation["+this.child+"]"},un.$metadata$={kind:o,simpleName:"ChildContinuation",interfaces:[an]},cn.$metadata$={kind:o,simpleName:"MainCoroutineDispatcher",interfaces:[zt]},hn.prototype.childCancelled_tcv7n7$=function(t){return!1},hn.$metadata$={kind:o,simpleName:"SupervisorJobImpl",interfaces:[We]},_n.prototype.createCopy=function(){var t,e=new _n(null!=(t=this.message)?t:"",this.coroutine_8be2vx$);return e},_n.$metadata$={kind:o,simpleName:"TimeoutCancellationException",interfaces:[le,Yr]},fn.prototype.isDispatchNeeded_1fupul$=function(t){return!1},fn.prototype.dispatch_5bn72i$=function(t,e){var n=t.get_j3r2sn$(En());if(null==n)throw H("Dispatchers.Unconfined.dispatch function can only be used by the yield function. If you wrap Unconfined dispatcher in your code, make sure you properly delegate isDispatchNeeded and dispatch calls.");n.dispatcherWasUnconfined=!0},fn.prototype.toString=function(){return"Unconfined"},fn.$metadata$={kind:k,simpleName:"Unconfined",interfaces:[zt]};var dn=null;function mn(){return null===dn&&new fn,dn}function yn(){En(),C.call(this,En()),this.dispatcherWasUnconfined=!1}function $n(){kn=this}$n.$metadata$={kind:k,simpleName:"Key",interfaces:[T]};var vn,gn,bn,wn,xn,kn=null;function En(){return null===kn&&new $n,kn}function Cn(t){return function(t){var n,i,r=t.context;if(Sn(r),null==(i=e.isType(n=p(t),Gi)?n:null))return u;var o=i;if(o.dispatcher.isDispatchNeeded_1fupul$(r))o.dispatchYield_6v298r$(r,u);else{var a=new yn;if(o.dispatchYield_6v298r$(r.plus_1fupul$(a),u),a.dispatcherWasUnconfined)return Yi(o)?s:u}return s}(t)}function Sn(t){var e=t.get_j3r2sn$(xe());if(null!=e&&!e.isActive)throw e.getCancellationException()}function Tn(t){return function(e){var n=ft(p(e));return t(n),n.getResult()}}function On(){this.queue_0=new bo,this.onCloseHandler_0=null}function Nn(t,e){yo.call(this,t,new zn(e))}function Pn(t,e){Nn.call(this,t,e)}function An(t,e,n){l.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$element=e}function jn(t){return function(){return t.isBufferFull}}function Ln(t,e){$o.call(this,e),this.element=t}function Rn(t){this.this$AbstractSendChannel=t}function In(t,e,n,i){Wn.call(this),this.pollResult_m5nr4l$_0=t,this.channel=e,this.select=n,this.block=i}function zn(t){Wn.call(this),this.element=t}function Dn(){On.call(this)}function Mn(t){return function(){return t.isBufferEmpty}}function Bn(t){$o.call(this,t)}function Un(t){this.this$AbstractChannel=t}function Fn(t){this.this$AbstractChannel=t}function qn(t){this.this$AbstractChannel=t}function Gn(t,e){this.$outer=t,kt.call(this),this.receive_0=e}function Hn(t){this.channel=t,this.result=bn}function Yn(t,e){Qn.call(this),this.cont=t,this.receiveMode=e}function Vn(t,e){Qn.call(this),this.iterator=t,this.cont=e}function Kn(t,e,n,i){Qn.call(this),this.channel=t,this.select=e,this.block=n,this.receiveMode=i}function Wn(){mo.call(this)}function Xn(){}function Zn(t,e){Wn.call(this),this.pollResult_vo6xxe$_0=t,this.cont=e}function Jn(t){Wn.call(this),this.closeCause=t}function Qn(){mo.call(this)}function ti(t){if(Dn.call(this),this.capacity=t,!(this.capacity>=1)){var n="ArrayChannel capacity must be at least 1, but "+this.capacity+" was specified";throw M(n.toString())}this.lock_0=new _o;var i=this.capacity;this.buffer_0=e.newArray(V.min(i,8),null),this.head_0=0,this.size_0=0}function ei(t,e,n){ot.call(this,t,n),this._channel_0=e}function ni(){}function ii(){}function ri(){}function oi(t){ui(),this.holder_0=t}function ai(t){this.cause=t}function si(){li=this}yn.$metadata$={kind:o,simpleName:"YieldContext",interfaces:[C]},On.prototype.offerInternal_11rb$=function(t){for(var e;;){if(null==(e=this.takeFirstReceiveOrPeekClosed()))return gn;var n=e;if(null!=n.tryResumeReceive_j43gjz$(t,null))return n.completeResumeReceive_11rb$(t),n.offerResult}},On.prototype.offerSelectInternal_ys5ufj$=function(t,e){var n=this.describeTryOffer_0(t),i=e.performAtomicTrySelect_6q0pxr$(n);if(null!=i)return i;var r=n.result;return r.completeResumeReceive_11rb$(t),r.offerResult},Object.defineProperty(On.prototype,"closedForSend_0",{get:function(){var t,n,i;return null!=(n=e.isType(t=this.queue_0._prev,Jn)?t:null)?(this.helpClose_0(n),i=n):i=null,i}}),Object.defineProperty(On.prototype,"closedForReceive_0",{get:function(){var t,n,i;return null!=(n=e.isType(t=this.queue_0._next,Jn)?t:null)?(this.helpClose_0(n),i=n):i=null,i}}),On.prototype.takeFirstSendOrPeekClosed_0=function(){var t,n=this.queue_0;t:do{var i=n._next;if(i===n){t=null;break t}if(!e.isType(i,Wn)){t=null;break t}if(e.isType(i,Jn)){t=i;break t}if(!i.remove())throw g("Should remove".toString());t=i}while(0);return t},On.prototype.sendBuffered_0=function(t){var n=this.queue_0,i=new zn(t),r=n._prev;return e.isType(r,Xn)?r:(n.addLast_l2j9rm$(i),null)},On.prototype.describeSendBuffered_0=function(t){return new Nn(this.queue_0,t)},Nn.prototype.failure_l2j9rm$=function(t){return e.isType(t,Jn)?t:e.isType(t,Xn)?gn:null},Nn.$metadata$={kind:o,simpleName:"SendBufferedDesc",interfaces:[yo]},On.prototype.describeSendConflated_0=function(t){return new Pn(this.queue_0,t)},Pn.prototype.finishOnSuccess_bpl3tg$=function(t,n){var i,r;Nn.prototype.finishOnSuccess_bpl3tg$.call(this,t,n),null!=(r=e.isType(i=t,zn)?i:null)&&r.remove()},Pn.$metadata$={kind:o,simpleName:"SendConflatedDesc",interfaces:[Nn]},Object.defineProperty(On.prototype,"isClosedForSend",{get:function(){return null!=this.closedForSend_0}}),Object.defineProperty(On.prototype,"isFull",{get:function(){return this.full_0}}),Object.defineProperty(On.prototype,"full_0",{get:function(){return!e.isType(this.queue_0._next,Xn)&&this.isBufferFull}}),On.prototype.send_11rb$=function(t,e){if(this.offerInternal_11rb$(t)!==vn)return this.sendSuspend_0(t,e)},An.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[l]},An.prototype=Object.create(l.prototype),An.prototype.constructor=An,An.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.offerInternal_11rb$(this.local$element)===vn){if(this.state_0=2,this.result_0=Cn(this),this.result_0===s)return s;continue}this.state_0=3;continue;case 1:throw this.exception_0;case 2:return;case 3:if(this.state_0=4,this.result_0=this.$this.sendSuspend_0(this.local$element,this),this.result_0===s)return s;continue;case 4:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},On.prototype.sendFair_1c3m6u$=function(t,e,n){var i=new An(this,t,e);return n?i:i.doResume(null)},On.prototype.offer_11rb$=function(t){var n,i=this.offerInternal_11rb$(t);if(i!==vn){if(i===gn){if(null==(n=this.closedForSend_0))return!1;throw this.helpCloseAndGetSendException_0(n)}throw e.isType(i,Jn)?this.helpCloseAndGetSendException_0(i):g(("offerInternal returned "+i.toString()).toString())}return!0},On.prototype.helpCloseAndGetSendException_0=function(t){return this.helpClose_0(t),t.sendException},On.prototype.sendSuspend_0=function(t,n){return Tn((i=this,r=t,function(t){for(;;){if(i.full_0){var n=new Zn(r,t),o=i.enqueueSend_0(n);if(null==o)return void dt(t,n);if(e.isType(o,Jn))return void i.helpCloseAndResumeWithSendException_0(t,o);if(o!==wn&&!e.isType(o,Qn))throw g(("enqueueSend returned "+x(o)).toString())}var a=i.offerInternal_11rb$(r);if(a===vn)return void t.resumeWith_tl1gpc$(new _(u));if(a!==gn){if(e.isType(a,Jn))return void i.helpCloseAndResumeWithSendException_0(t,a);throw g(("offerInternal returned "+a.toString()).toString())}}}))(n);var i,r},On.prototype.helpCloseAndResumeWithSendException_0=function(t,e){this.helpClose_0(e);var n=e.sendException;t.resumeWith_tl1gpc$(new _(E(n)))},On.prototype.enqueueSend_0=function(t){if(this.isBufferAlwaysFull){var n=this.queue_0,i=n._prev;if(e.isType(i,Xn))return i;n.addLast_l2j9rm$(t)}else{var r,o=this.queue_0;t:do{var a=o._prev;if(e.isType(a,Xn))return a;if(!jn(this)()){r=!1;break t}o.addLast_l2j9rm$(t),r=!0}while(0);if(!r)return wn}return null},On.prototype.close_dbl4no$$default=function(t){var n,i,o=new Jn(t),a=this.queue_0;t:do{if(e.isType(a._prev,Jn)){i=!1;break t}a.addLast_l2j9rm$(o),i=!0}while(0);var s=i,l=s?o:e.isType(n=this.queue_0._prev,Jn)?n:r();return this.helpClose_0(l),s&&this.invokeOnCloseHandler_0(t),s},On.prototype.invokeOnCloseHandler_0=function(t){var e,n,i=this.onCloseHandler_0;null!==i&&i!==xn&&(n=this).onCloseHandler_0===i&&(n.onCloseHandler_0=xn,1)&&("function"==typeof(e=i)?e:r())(t)},On.prototype.invokeOnClose_f05bi3$=function(t){if(null!=this.onCloseHandler_0||(this.onCloseHandler_0=t,0)){var e=this.onCloseHandler_0;if(e===xn)throw g("Another handler was already registered and successfully invoked");throw g("Another handler was already registered: "+x(e))}var n=this.closedForSend_0;null!=n&&function(e){return e.onCloseHandler_0===t&&(e.onCloseHandler_0=xn,!0)}(this)&&t(n.closeCause)},On.prototype.helpClose_0=function(t){for(var n,o,a=new Ji;null!=(o=e.isType(n=t._prev,Qn)?n:null);){var s=o;s.remove()?a=a.plus_11rb$(s):s.helpRemove()}var l,u,c,p=a;if(null!=(l=p.holder_0))if(e.isType(l,q))for(var h=e.isType(c=p.holder_0,q)?c:r(),_=h.size-1|0;_>=0;_--)h.get_za3lpa$(_).resumeReceiveClosed_1zqbm$(t);else(null==(u=p.holder_0)||e.isType(u,i)?u:r()).resumeReceiveClosed_1zqbm$(t);this.onClosedIdempotent_l2j9rm$(t)},On.prototype.onClosedIdempotent_l2j9rm$=function(t){},On.prototype.takeFirstReceiveOrPeekClosed=function(){var t,n=this.queue_0;t:do{var i=n._next;if(i===n){t=null;break t}if(!e.isType(i,Xn)){t=null;break t}if(e.isType(i,Jn)){t=i;break t}if(!i.remove())throw g("Should remove".toString());t=i}while(0);return t},On.prototype.describeTryOffer_0=function(t){return new Ln(t,this.queue_0)},Ln.prototype.failure_l2j9rm$=function(t){return e.isType(t,Jn)?t:e.isType(t,Xn)?null:gn},Ln.prototype.onPrepare_xe32vn$=function(t){var n,i;return null==(i=(e.isType(n=t.affected,Xn)?n:r()).tryResumeReceive_j43gjz$(this.element,t))?vi:i===mi?mi:null},Ln.$metadata$={kind:o,simpleName:"TryOfferDesc",interfaces:[$o]},Rn.prototype.registerSelectClause2_rol3se$=function(t,e,n){this.this$AbstractSendChannel.registerSelectSend_0(t,e,n)},Rn.$metadata$={kind:o,interfaces:[mr]},Object.defineProperty(On.prototype,"onSend",{get:function(){return new Rn(this)}}),On.prototype.registerSelectSend_0=function(t,n,i){for(;;){if(t.isSelected)return;if(this.full_0){var r=new In(n,this,t,i),o=this.enqueueSend_0(r);if(null==o)return void t.disposeOnSelect_rvfg84$(r);if(e.isType(o,Jn))throw this.helpCloseAndGetSendException_0(o);if(o!==wn&&!e.isType(o,Qn))throw g(("enqueueSend returned "+x(o)+" ").toString())}var a=this.offerSelectInternal_ys5ufj$(n,t);if(a===gi)return;if(a!==gn&&a!==mi){if(a===vn)return void lr(i,this,t.completion);throw e.isType(a,Jn)?this.helpCloseAndGetSendException_0(a):g(("offerSelectInternal returned "+a.toString()).toString())}}},On.prototype.toString=function(){return Ir(this)+"@"+Rr(this)+"{"+this.queueDebugStateString_0+"}"+this.bufferDebugString},Object.defineProperty(On.prototype,"queueDebugStateString_0",{get:function(){var t=this.queue_0._next;if(t===this.queue_0)return"EmptyQueue";var n=e.isType(t,Jn)?t.toString():e.isType(t,Qn)?"ReceiveQueued":e.isType(t,Wn)?"SendQueued":"UNEXPECTED:"+t,i=this.queue_0._prev;return i!==t&&(n+=",queueSize="+this.countQueueSize_0(),e.isType(i,Jn)&&(n+=",closedForSend="+i)),n}}),On.prototype.countQueueSize_0=function(){for(var t={v:0},n=this.queue_0,i=n._next;!y(i,n);)e.isType(i,mo)&&(t.v=t.v+1|0),i=i._next;return t.v},Object.defineProperty(On.prototype,"bufferDebugString",{get:function(){return""}}),Object.defineProperty(In.prototype,"pollResult",{get:function(){return this.pollResult_m5nr4l$_0}}),In.prototype.tryResumeSend_uc1cc4$=function(t){var n;return null==(n=this.select.trySelectOther_uc1cc4$(t))||e.isType(n,er)?n:r()},In.prototype.completeResumeSend=function(){P(this.block,this.channel,this.select.completion)},In.prototype.dispose=function(){this.remove()},In.prototype.resumeSendClosed_1zqbm$=function(t){this.select.trySelect()&&this.select.resumeSelectWithException_tcv7n7$(t.sendException)},In.prototype.toString=function(){return"SendSelect@"+Rr(this)+"("+x(this.pollResult)+")["+this.channel+", "+this.select+"]"},In.$metadata$={kind:o,simpleName:"SendSelect",interfaces:[Ee,Wn]},Object.defineProperty(zn.prototype,"pollResult",{get:function(){return this.element}}),zn.prototype.tryResumeSend_uc1cc4$=function(t){return null!=t&&t.finishPrepare(),n},zn.prototype.completeResumeSend=function(){},zn.prototype.resumeSendClosed_1zqbm$=function(t){},zn.prototype.toString=function(){return"SendBuffered@"+Rr(this)+"("+this.element+")"},zn.$metadata$={kind:o,simpleName:"SendBuffered",interfaces:[Wn]},On.$metadata$={kind:o,simpleName:"AbstractSendChannel",interfaces:[ii]},Dn.prototype.pollInternal=function(){for(var t;;){if(null==(t=this.takeFirstSendOrPeekClosed_0()))return bn;var e=t;if(null!=e.tryResumeSend_uc1cc4$(null))return e.completeResumeSend(),e.pollResult}},Dn.prototype.pollSelectInternal_y5yyj0$=function(t){var e=this.describeTryPoll_0(),n=t.performAtomicTrySelect_6q0pxr$(e);return null!=n?n:(e.result.completeResumeSend(),e.result.pollResult)},Object.defineProperty(Dn.prototype,"hasReceiveOrClosed_0",{get:function(){return e.isType(this.queue_0._next,Xn)}}),Object.defineProperty(Dn.prototype,"isClosedForReceive",{get:function(){return null!=this.closedForReceive_0&&this.isBufferEmpty}}),Object.defineProperty(Dn.prototype,"isEmpty",{get:function(){return!e.isType(this.queue_0._next,Wn)&&this.isBufferEmpty}}),Dn.prototype.receive=function(t){var n,o=this.pollInternal();return o===bn||e.isType(o,Jn)?this.receiveSuspend_0(0,t):null==(n=o)||e.isType(n,i)?n:r()},Dn.prototype.receiveSuspend_0=function(t,n){return Tn((o=t,a=this,function(t){for(var n,s,l=new Yn(e.isType(n=t,_t)?n:r(),o);;){if(a.enqueueReceive_0(l))return void a.removeReceiveOnCancel_0(t,l);var c=a.pollInternal();if(e.isType(c,Jn))return void l.resumeReceiveClosed_1zqbm$(c);if(c!==bn){var p=l.resumeValue_11rb$(null==(s=c)||e.isType(s,i)?s:r());return void t.resumeWith_tl1gpc$(new _(p))}}return u}))(n);var o,a},Dn.prototype.enqueueReceive_0=function(t){var n;if(this.isBufferAlwaysEmpty){var i,r=this.queue_0;t:do{if(e.isType(r._prev,Wn)){i=!1;break t}r.addLast_l2j9rm$(t),i=!0}while(0);n=i}else{var o,a=this.queue_0;t:do{if(e.isType(a._prev,Wn)){o=!1;break t}if(!Mn(this)()){o=!1;break t}a.addLast_l2j9rm$(t),o=!0}while(0);n=o}var s=n;return s&&this.onReceiveEnqueued(),s},Dn.prototype.receiveOrNull=function(t){var n,o=this.pollInternal();return o===bn||e.isType(o,Jn)?this.receiveSuspend_0(1,t):null==(n=o)||e.isType(n,i)?n:r()},Dn.prototype.receiveOrNullResult_0=function(t){var n;if(e.isType(t,Jn)){if(null!=t.closeCause)throw t.closeCause;return null}return null==(n=t)||e.isType(n,i)?n:r()},Dn.prototype.receiveOrClosed=function(t){var n,o,a=this.pollInternal();return a!==bn?(e.isType(a,Jn)?n=new oi(new ai(a.closeCause)):(ui(),n=new oi(null==(o=a)||e.isType(o,i)?o:r())),n):this.receiveSuspend_0(2,t)},Dn.prototype.poll=function(){var t=this.pollInternal();return t===bn?null:this.receiveOrNullResult_0(t)},Dn.prototype.cancel_dbl4no$$default=function(t){return this.cancelInternal_fg6mcv$(t)},Dn.prototype.cancel_m4sck1$$default=function(t){this.cancelInternal_fg6mcv$(null!=t?t:Vr(Ir(this)+" was cancelled"))},Dn.prototype.cancelInternal_fg6mcv$=function(t){var e=this.close_dbl4no$(t);return this.onCancelIdempotent_6taknv$(e),e},Dn.prototype.onCancelIdempotent_6taknv$=function(t){var n;if(null==(n=this.closedForSend_0))throw g("Cannot happen".toString());for(var o=n,a=new Ji;;){var s,l=o._prev;if(e.isType(l,bo))break;l.remove()?a=a.plus_11rb$(e.isType(s=l,Wn)?s:r()):l.helpRemove()}var u,c,p,h=a;if(null!=(u=h.holder_0))if(e.isType(u,q))for(var _=e.isType(p=h.holder_0,q)?p:r(),f=_.size-1|0;f>=0;f--)_.get_za3lpa$(f).resumeSendClosed_1zqbm$(o);else(null==(c=h.holder_0)||e.isType(c,i)?c:r()).resumeSendClosed_1zqbm$(o)},Dn.prototype.iterator=function(){return new Hn(this)},Dn.prototype.describeTryPoll_0=function(){return new Bn(this.queue_0)},Bn.prototype.failure_l2j9rm$=function(t){return e.isType(t,Jn)?t:e.isType(t,Wn)?null:bn},Bn.prototype.onPrepare_xe32vn$=function(t){var n,i;return null==(i=(e.isType(n=t.affected,Wn)?n:r()).tryResumeSend_uc1cc4$(t))?vi:i===mi?mi:null},Bn.$metadata$={kind:o,simpleName:"TryPollDesc",interfaces:[$o]},Un.prototype.registerSelectClause1_o3xas4$=function(t,n){var i,o;o=e.isType(i=n,Y)?i:r(),this.this$AbstractChannel.registerSelectReceiveMode_0(t,0,o)},Un.$metadata$={kind:o,interfaces:[dr]},Object.defineProperty(Dn.prototype,"onReceive",{get:function(){return new Un(this)}}),Fn.prototype.registerSelectClause1_o3xas4$=function(t,n){var i,o;o=e.isType(i=n,Y)?i:r(),this.this$AbstractChannel.registerSelectReceiveMode_0(t,1,o)},Fn.$metadata$={kind:o,interfaces:[dr]},Object.defineProperty(Dn.prototype,"onReceiveOrNull",{get:function(){return new Fn(this)}}),qn.prototype.registerSelectClause1_o3xas4$=function(t,n){var i,o;o=e.isType(i=n,Y)?i:r(),this.this$AbstractChannel.registerSelectReceiveMode_0(t,2,o)},qn.$metadata$={kind:o,interfaces:[dr]},Object.defineProperty(Dn.prototype,"onReceiveOrClosed",{get:function(){return new qn(this)}}),Dn.prototype.registerSelectReceiveMode_0=function(t,e,n){for(;;){if(t.isSelected)return;if(this.isEmpty){if(this.enqueueReceiveSelect_0(t,n,e))return}else{var i=this.pollSelectInternal_y5yyj0$(t);if(i===gi)return;i!==bn&&i!==mi&&this.tryStartBlockUnintercepted_0(n,t,e,i)}}},Dn.prototype.tryStartBlockUnintercepted_0=function(t,n,o,a){var s,l;if(e.isType(a,Jn))switch(o){case 0:throw a.receiveException;case 2:if(!n.trySelect())return;lr(t,new oi(new ai(a.closeCause)),n.completion);break;case 1:if(null!=a.closeCause)throw a.receiveException;if(!n.trySelect())return;lr(t,null,n.completion)}else 2===o?(e.isType(a,Jn)?s=new oi(new ai(a.closeCause)):(ui(),s=new oi(null==(l=a)||e.isType(l,i)?l:r())),lr(t,s,n.completion)):lr(t,a,n.completion)},Dn.prototype.enqueueReceiveSelect_0=function(t,e,n){var i=new Kn(this,t,e,n),r=this.enqueueReceive_0(i);return r&&t.disposeOnSelect_rvfg84$(i),r},Dn.prototype.takeFirstReceiveOrPeekClosed=function(){var t=On.prototype.takeFirstReceiveOrPeekClosed.call(this);return null==t||e.isType(t,Jn)||this.onReceiveDequeued(),t},Dn.prototype.onReceiveEnqueued=function(){},Dn.prototype.onReceiveDequeued=function(){},Dn.prototype.removeReceiveOnCancel_0=function(t,e){t.invokeOnCancellation_f05bi3$(new Gn(this,e))},Gn.prototype.invoke=function(t){this.receive_0.remove()&&this.$outer.onReceiveDequeued()},Gn.prototype.toString=function(){return"RemoveReceiveOnCancel["+this.receive_0+"]"},Gn.$metadata$={kind:o,simpleName:"RemoveReceiveOnCancel",interfaces:[kt]},Hn.prototype.hasNext=function(t){return this.result!==bn?this.hasNextResult_0(this.result):(this.result=this.channel.pollInternal(),this.result!==bn?this.hasNextResult_0(this.result):this.hasNextSuspend_0(t))},Hn.prototype.hasNextResult_0=function(t){if(e.isType(t,Jn)){if(null!=t.closeCause)throw t.receiveException;return!1}return!0},Hn.prototype.hasNextSuspend_0=function(t){return Tn((n=this,function(t){for(var i=new Vn(n,t);;){if(n.channel.enqueueReceive_0(i))return void n.channel.removeReceiveOnCancel_0(t,i);var r=n.channel.pollInternal();if(n.result=r,e.isType(r,Jn)){if(null==r.closeCause)t.resumeWith_tl1gpc$(new _(!1));else{var o=r.receiveException;t.resumeWith_tl1gpc$(new _(E(o)))}return}if(r!==bn)return void t.resumeWith_tl1gpc$(new _(!0))}return u}))(t);var n},Hn.prototype.next=function(){var t,n=this.result;if(e.isType(n,Jn))throw n.receiveException;if(n!==bn)return this.result=bn,null==(t=n)||e.isType(t,i)?t:r();throw g("'hasNext' should be called prior to 'next' invocation")},Hn.$metadata$={kind:o,simpleName:"Itr",interfaces:[ci]},Yn.prototype.resumeValue_11rb$=function(t){return 2===this.receiveMode?new oi(t):t},Yn.prototype.tryResumeReceive_j43gjz$=function(t,e){return null==this.cont.tryResume_19pj23$(this.resumeValue_11rb$(t),null!=e?e.desc:null)?null:(null!=e&&e.finishPrepare(),n)},Yn.prototype.completeResumeReceive_11rb$=function(t){this.cont.completeResume_za3rmp$(n)},Yn.prototype.resumeReceiveClosed_1zqbm$=function(t){if(1===this.receiveMode&&null==t.closeCause)this.cont.resumeWith_tl1gpc$(new _(null));else if(2===this.receiveMode){var e=this.cont,n=new oi(new ai(t.closeCause));e.resumeWith_tl1gpc$(new _(n))}else{var i=this.cont,r=t.receiveException;i.resumeWith_tl1gpc$(new _(E(r)))}},Yn.prototype.toString=function(){return"ReceiveElement@"+Rr(this)+"[receiveMode="+this.receiveMode+"]"},Yn.$metadata$={kind:o,simpleName:"ReceiveElement",interfaces:[Qn]},Vn.prototype.tryResumeReceive_j43gjz$=function(t,e){return null==this.cont.tryResume_19pj23$(!0,null!=e?e.desc:null)?null:(null!=e&&e.finishPrepare(),n)},Vn.prototype.completeResumeReceive_11rb$=function(t){this.iterator.result=t,this.cont.completeResume_za3rmp$(n)},Vn.prototype.resumeReceiveClosed_1zqbm$=function(t){var e=null==t.closeCause?this.cont.tryResume_19pj23$(!1):this.cont.tryResumeWithException_tcv7n7$(wo(t.receiveException,this.cont));null!=e&&(this.iterator.result=t,this.cont.completeResume_za3rmp$(e))},Vn.prototype.toString=function(){return"ReceiveHasNext@"+Rr(this)},Vn.$metadata$={kind:o,simpleName:"ReceiveHasNext",interfaces:[Qn]},Kn.prototype.tryResumeReceive_j43gjz$=function(t,n){var i;return null==(i=this.select.trySelectOther_uc1cc4$(n))||e.isType(i,er)?i:r()},Kn.prototype.completeResumeReceive_11rb$=function(t){P(this.block,2===this.receiveMode?new oi(t):t,this.select.completion)},Kn.prototype.resumeReceiveClosed_1zqbm$=function(t){if(this.select.trySelect())switch(this.receiveMode){case 0:this.select.resumeSelectWithException_tcv7n7$(t.receiveException);break;case 2:P(this.block,new oi(new ai(t.closeCause)),this.select.completion);break;case 1:null==t.closeCause?P(this.block,null,this.select.completion):this.select.resumeSelectWithException_tcv7n7$(t.receiveException)}},Kn.prototype.dispose=function(){this.remove()&&this.channel.onReceiveDequeued()},Kn.prototype.toString=function(){return"ReceiveSelect@"+Rr(this)+"["+this.select+",receiveMode="+this.receiveMode+"]"},Kn.$metadata$={kind:o,simpleName:"ReceiveSelect",interfaces:[Ee,Qn]},Dn.$metadata$={kind:o,simpleName:"AbstractChannel",interfaces:[hi,On]},Wn.$metadata$={kind:o,simpleName:"Send",interfaces:[mo]},Xn.$metadata$={kind:b,simpleName:"ReceiveOrClosed",interfaces:[]},Object.defineProperty(Zn.prototype,"pollResult",{get:function(){return this.pollResult_vo6xxe$_0}}),Zn.prototype.tryResumeSend_uc1cc4$=function(t){return null==this.cont.tryResume_19pj23$(u,null!=t?t.desc:null)?null:(null!=t&&t.finishPrepare(),n)},Zn.prototype.completeResumeSend=function(){this.cont.completeResume_za3rmp$(n)},Zn.prototype.resumeSendClosed_1zqbm$=function(t){var e=this.cont,n=t.sendException;e.resumeWith_tl1gpc$(new _(E(n)))},Zn.prototype.toString=function(){return"SendElement@"+Rr(this)+"("+x(this.pollResult)+")"},Zn.$metadata$={kind:o,simpleName:"SendElement",interfaces:[Wn]},Object.defineProperty(Jn.prototype,"sendException",{get:function(){var t;return null!=(t=this.closeCause)?t:new Pi(fi)}}),Object.defineProperty(Jn.prototype,"receiveException",{get:function(){var t;return null!=(t=this.closeCause)?t:new Ai(fi)}}),Object.defineProperty(Jn.prototype,"offerResult",{get:function(){return this}}),Object.defineProperty(Jn.prototype,"pollResult",{get:function(){return this}}),Jn.prototype.tryResumeSend_uc1cc4$=function(t){return null!=t&&t.finishPrepare(),n},Jn.prototype.completeResumeSend=function(){},Jn.prototype.tryResumeReceive_j43gjz$=function(t,e){return null!=e&&e.finishPrepare(),n},Jn.prototype.completeResumeReceive_11rb$=function(t){},Jn.prototype.resumeSendClosed_1zqbm$=function(t){},Jn.prototype.toString=function(){return"Closed@"+Rr(this)+"["+x(this.closeCause)+"]"},Jn.$metadata$={kind:o,simpleName:"Closed",interfaces:[Xn,Wn]},Object.defineProperty(Qn.prototype,"offerResult",{get:function(){return vn}}),Qn.$metadata$={kind:o,simpleName:"Receive",interfaces:[Xn,mo]},Object.defineProperty(ti.prototype,"isBufferAlwaysEmpty",{get:function(){return!1}}),Object.defineProperty(ti.prototype,"isBufferEmpty",{get:function(){return 0===this.size_0}}),Object.defineProperty(ti.prototype,"isBufferAlwaysFull",{get:function(){return!1}}),Object.defineProperty(ti.prototype,"isBufferFull",{get:function(){return this.size_0===this.capacity}}),ti.prototype.offerInternal_11rb$=function(t){var n={v:null};t:do{var i,r,o=this.size_0;if(null!=(i=this.closedForSend_0))return i;if(o=this.buffer_0.length){for(var n=2*this.buffer_0.length|0,i=this.capacity,r=V.min(n,i),o=e.newArray(r,null),a=0;a0&&(l=c,u=p)}return l}catch(t){throw e.isType(t,n)?(a=t,t):t}finally{i(t,a)}}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.none_4c38lx$",v((function(){var n=e.kotlin.Unit,i=Error,r=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,o,a){var s=null;try{var l;for(l=t.iterator();e.suspendCall(l.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());)if(o(l.next()))return!1}catch(t){throw e.isType(t,i)?(s=t,t):t}finally{r(t,s)}return e.setCoroutineResult(n,e.coroutineReceiver()),!0}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.reduce_vk3vfd$",v((function(){var n=e.kotlin.UnsupportedOperationException_init_pdl1vj$,i=Error,r=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,o,a){var s=null;try{var l=t.iterator();if(e.suspendCall(l.hasNext(e.coroutineReceiver())),!e.coroutineResult(e.coroutineReceiver()))throw n("Empty channel can't be reduced.");for(var u=l.next();e.suspendCall(l.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());)u=o(u,l.next());return u}catch(t){throw e.isType(t,i)?(s=t,t):t}finally{r(t,s)}}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.reduceIndexed_a6mkxp$",v((function(){var n=e.kotlin.UnsupportedOperationException_init_pdl1vj$,i=Error,r=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,o,a){var s=null;try{var l,u=t.iterator();if(e.suspendCall(u.hasNext(e.coroutineReceiver())),!e.coroutineResult(e.coroutineReceiver()))throw n("Empty channel can't be reduced.");for(var c=1,p=u.next();e.suspendCall(u.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());)p=o((c=(l=c)+1|0,l),p,u.next());return p}catch(t){throw e.isType(t,i)?(s=t,t):t}finally{r(t,s)}}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.sumBy_fl2dz0$",v((function(){var n=e.kotlin.Unit,i=Error,r=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,o,a){var s={v:0},l=null;try{var u;for(u=t.iterator();e.suspendCall(u.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());){var c=u.next();s.v=s.v+o(c)|0}}catch(t){throw e.isType(t,i)?(l=t,t):t}finally{r(t,l)}return e.setCoroutineResult(n,e.coroutineReceiver()),s.v}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.sumByDouble_jy8qhg$",v((function(){var n=e.kotlin.Unit,i=Error,r=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,o,a){var s={v:0},l=null;try{var u;for(u=t.iterator();e.suspendCall(u.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());){var c=u.next();s.v+=o(c)}}catch(t){throw e.isType(t,i)?(l=t,t):t}finally{r(t,l)}return e.setCoroutineResult(n,e.coroutineReceiver()),s.v}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.channels.partition_4c38lx$",v((function(){var n=e.kotlin.collections.ArrayList_init_287e2$,i=e.kotlin.Unit,r=e.kotlin.Pair,o=Error,a=t.kotlinx.coroutines.channels.cancelConsumed_v57n85$;return function(t,s,l){var u=n(),c=n(),p=null;try{var h;for(h=t.iterator();e.suspendCall(h.hasNext(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());){var _=h.next();s(_)?u.add_11rb$(_):c.add_11rb$(_)}}catch(t){throw e.isType(t,o)?(p=t,t):t}finally{a(t,p)}return e.setCoroutineResult(i,e.coroutineReceiver()),new r(u,c)}}))),Object.defineProperty(Ri.prototype,"isBufferAlwaysEmpty",{get:function(){return!0}}),Object.defineProperty(Ri.prototype,"isBufferEmpty",{get:function(){return!0}}),Object.defineProperty(Ri.prototype,"isBufferAlwaysFull",{get:function(){return!1}}),Object.defineProperty(Ri.prototype,"isBufferFull",{get:function(){return!1}}),Ri.prototype.onClosedIdempotent_l2j9rm$=function(t){var n,i;null!=(i=e.isType(n=t._prev,zn)?n:null)&&this.conflatePreviousSendBuffered_0(i)},Ri.prototype.sendConflated_0=function(t){var n=new zn(t),i=this.queue_0,r=i._prev;return e.isType(r,Xn)?r:(i.addLast_l2j9rm$(n),this.conflatePreviousSendBuffered_0(n),null)},Ri.prototype.conflatePreviousSendBuffered_0=function(t){for(var n=t._prev;e.isType(n,zn);)n.remove()||n.helpRemove(),n=n._prev},Ri.prototype.offerInternal_11rb$=function(t){for(;;){var n=Dn.prototype.offerInternal_11rb$.call(this,t);if(n===vn)return vn;if(n!==gn){if(e.isType(n,Jn))return n;throw g(("Invalid offerInternal result "+n.toString()).toString())}var i=this.sendConflated_0(t);if(null==i)return vn;if(e.isType(i,Jn))return i}},Ri.prototype.offerSelectInternal_ys5ufj$=function(t,n){for(var i;;){var r=this.hasReceiveOrClosed_0?Dn.prototype.offerSelectInternal_ys5ufj$.call(this,t,n):null!=(i=n.performAtomicTrySelect_6q0pxr$(this.describeSendConflated_0(t)))?i:vn;if(r===gi)return gi;if(r===vn)return vn;if(r!==gn&&r!==mi){if(e.isType(r,Jn))return r;throw g(("Invalid result "+r.toString()).toString())}}},Ri.$metadata$={kind:o,simpleName:"ConflatedChannel",interfaces:[Dn]},Object.defineProperty(Ii.prototype,"isBufferAlwaysEmpty",{get:function(){return!0}}),Object.defineProperty(Ii.prototype,"isBufferEmpty",{get:function(){return!0}}),Object.defineProperty(Ii.prototype,"isBufferAlwaysFull",{get:function(){return!1}}),Object.defineProperty(Ii.prototype,"isBufferFull",{get:function(){return!1}}),Ii.prototype.offerInternal_11rb$=function(t){for(;;){var n=Dn.prototype.offerInternal_11rb$.call(this,t);if(n===vn)return vn;if(n!==gn){if(e.isType(n,Jn))return n;throw g(("Invalid offerInternal result "+n.toString()).toString())}var i=this.sendBuffered_0(t);if(null==i)return vn;if(e.isType(i,Jn))return i}},Ii.prototype.offerSelectInternal_ys5ufj$=function(t,n){for(var i;;){var r=this.hasReceiveOrClosed_0?Dn.prototype.offerSelectInternal_ys5ufj$.call(this,t,n):null!=(i=n.performAtomicTrySelect_6q0pxr$(this.describeSendBuffered_0(t)))?i:vn;if(r===gi)return gi;if(r===vn)return vn;if(r!==gn&&r!==mi){if(e.isType(r,Jn))return r;throw g(("Invalid result "+r.toString()).toString())}}},Ii.$metadata$={kind:o,simpleName:"LinkedListChannel",interfaces:[Dn]},Object.defineProperty(Di.prototype,"isBufferAlwaysEmpty",{get:function(){return!0}}),Object.defineProperty(Di.prototype,"isBufferEmpty",{get:function(){return!0}}),Object.defineProperty(Di.prototype,"isBufferAlwaysFull",{get:function(){return!0}}),Object.defineProperty(Di.prototype,"isBufferFull",{get:function(){return!0}}),Di.$metadata$={kind:o,simpleName:"RendezvousChannel",interfaces:[Dn]},Mi.$metadata$={kind:b,simpleName:"FlowCollector",interfaces:[]},$("kotlinx-coroutines-core.kotlinx.coroutines.flow.collect_706ovd$",v((function(){var n=e.Kind.CLASS,i=t.kotlinx.coroutines.flow.FlowCollector;function r(t){this.closure$action=t}return r.prototype.emit_11rb$=function(t,e){return this.closure$action(t,e)},r.$metadata$={kind:n,interfaces:[i]},function(t,n,i){return e.suspendCall(t.collect_42ocv1$(new r(n),e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.flow.collectIndexed_57beod$",v((function(){var n=e.Kind.CLASS,i=t.kotlinx.coroutines.flow.FlowCollector,r=e.kotlin.ArithmeticException;function o(t){this.closure$action=t,this.index_0=0}return o.prototype.emit_11rb$=function(t,e){var n,i;i=this.closure$action;var o=(n=this.index_0,this.index_0=n+1|0,n);if(o<0)throw new r("Index overflow has happened");return i(o,t,e)},o.$metadata$={kind:n,interfaces:[i]},function(t,n,i){return e.suspendCall(t.collect_42ocv1$(new o(n),e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.flow.emitAll_c14n1u$",(function(t,n,i){return e.suspendCall(n.collect_42ocv1$(t,e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())})),$("kotlinx-coroutines-core.kotlinx.coroutines.flow.fold_usjyvu$",v((function(){var n=e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED,i=e.kotlin.coroutines.CoroutineImpl,r=e.kotlin.Unit,o=e.Kind.CLASS,a=t.kotlinx.coroutines.flow.FlowCollector;function s(t){this.closure$action=t}function l(t,e,n,r){i.call(this,r),this.exceptionState_0=1,this.local$closure$operation=t,this.local$closure$accumulator=e,this.local$value=n}return s.prototype.emit_11rb$=function(t,e){return this.closure$action(t,e)},s.$metadata$={kind:o,interfaces:[a]},l.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[i]},l.prototype=Object.create(i.prototype),l.prototype.constructor=l,l.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$closure$operation(this.local$closure$accumulator.v,this.local$value,this),this.result_0===n)return n;continue;case 1:throw this.exception_0;case 2:return this.local$closure$accumulator.v=this.result_0,r;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},function(t,n,i,r){var o,a,u={v:n};return e.suspendCall(t.collect_42ocv1$(new s((o=i,a=u,function(t,e,n){var i=new l(o,a,t,e);return n?i:i.doResume(null)})),e.coroutineReceiver())),u.v}}))),Object.defineProperty(Bi.prototype,"isEmpty",{get:function(){return this.head_0===this.tail_0}}),Bi.prototype.addLast_trkh7z$=function(t){this.elements_0[this.tail_0]=t,this.tail_0=this.tail_0+1&this.elements_0.length-1,this.tail_0===this.head_0&&this.ensureCapacity_0()},Bi.prototype.removeFirstOrNull=function(){var t;if(this.head_0===this.tail_0)return null;var n=this.elements_0[this.head_0];return this.elements_0[this.head_0]=null,this.head_0=this.head_0+1&this.elements_0.length-1,e.isType(t=n,i)?t:r()},Bi.prototype.clear=function(){this.head_0=0,this.tail_0=0,this.elements_0=e.newArray(this.elements_0.length,null)},Bi.prototype.ensureCapacity_0=function(){var t=this.elements_0.length,n=t<<1,i=e.newArray(n,null),r=this.elements_0;Z(r,i,0,this.head_0,r.length),Z(this.elements_0,i,this.elements_0.length-this.head_0|0,0,this.head_0),this.elements_0=i,this.head_0=0,this.tail_0=t},Bi.$metadata$={kind:o,simpleName:"ArrayQueue",interfaces:[]},Ui.prototype.toString=function(){return Ir(this)+"@"+Rr(this)},Ui.prototype.isEarlierThan_bfmzsr$=function(t){var e,n;if(null==(e=this.atomicOp))return!1;var i=e;if(null==(n=t.atomicOp))return!1;var r=n;return i.opSequence.compareTo_11rb$(r.opSequence)<0},Ui.$metadata$={kind:o,simpleName:"OpDescriptor",interfaces:[]},Object.defineProperty(Fi.prototype,"isDecided",{get:function(){return this._consensus_c6dvpx$_0!==di}}),Object.defineProperty(Fi.prototype,"opSequence",{get:function(){return R}}),Object.defineProperty(Fi.prototype,"atomicOp",{get:function(){return this}}),Fi.prototype.decide_s8jyv4$=function(t){var e=this._consensus_c6dvpx$_0;return e!==di?e:this._consensus_c6dvpx$_0===di&&(this._consensus_c6dvpx$_0=t,1)?t:this._consensus_c6dvpx$_0},Fi.prototype.perform_s8jyv4$=function(t){var n,o,a=this._consensus_c6dvpx$_0;return a===di&&(a=this.decide_s8jyv4$(this.prepare_11rb$(null==(n=t)||e.isType(n,i)?n:r()))),this.complete_19pj23$(null==(o=t)||e.isType(o,i)?o:r(),a),a},Fi.$metadata$={kind:o,simpleName:"AtomicOp",interfaces:[Ui]},Object.defineProperty(qi.prototype,"atomicOp",{get:function(){return null==this.atomicOp_ss7ttb$_0?c("atomicOp"):this.atomicOp_ss7ttb$_0},set:function(t){this.atomicOp_ss7ttb$_0=t}}),qi.$metadata$={kind:o,simpleName:"AtomicDesc",interfaces:[]},Object.defineProperty(Gi.prototype,"callerFrame",{get:function(){return this.callerFrame_w1cgfa$_0}}),Gi.prototype.getStackTraceElement=function(){return null},Object.defineProperty(Gi.prototype,"reusableCancellableContinuation",{get:function(){var t;return e.isType(t=this._reusableCancellableContinuation_0,vt)?t:null}}),Object.defineProperty(Gi.prototype,"isReusable",{get:function(){return null!=this._reusableCancellableContinuation_0}}),Gi.prototype.claimReusableCancellableContinuation=function(){for(this._reusableCancellableContinuation_0;;){var t,n=this._reusableCancellableContinuation_0;if(null===n)return this._reusableCancellableContinuation_0=$i,null;if(!e.isType(n,vt))throw g(("Inconsistent state "+x(n)).toString());if(this._reusableCancellableContinuation_0===n&&(this._reusableCancellableContinuation_0=$i,1))return e.isType(t=n,vt)?t:r()}},Gi.prototype.checkPostponedCancellation_jp3215$=function(t){for(this._reusableCancellableContinuation_0;;){var n=this._reusableCancellableContinuation_0;if(n!==$i){if(null===n)return null;if(e.isType(n,w)){if(!function(t){return t._reusableCancellableContinuation_0===n&&(t._reusableCancellableContinuation_0=null,!0)}(this))throw M("Failed requirement.".toString());return n}throw g(("Inconsistent state "+x(n)).toString())}if(this._reusableCancellableContinuation_0===$i&&(this._reusableCancellableContinuation_0=t,1))return null}},Gi.prototype.postponeCancellation_tcv7n7$=function(t){for(this._reusableCancellableContinuation_0;;){var n=this._reusableCancellableContinuation_0;if(y(n,$i)){if(this._reusableCancellableContinuation_0===$i&&(this._reusableCancellableContinuation_0=t,1))return!0}else{if(e.isType(n,w))return!0;if(function(t){return t._reusableCancellableContinuation_0===n&&(t._reusableCancellableContinuation_0=null,!0)}(this))return!1}}},Gi.prototype.takeState=function(){var t=this._state_8be2vx$;return this._state_8be2vx$=yi,t},Object.defineProperty(Gi.prototype,"delegate",{get:function(){return this}}),Gi.prototype.resumeWith_tl1gpc$=function(t){var n=this.continuation.context,i=At(t);if(this.dispatcher.isDispatchNeeded_1fupul$(n))this._state_8be2vx$=i,this.resumeMode=0,this.dispatcher.dispatch_5bn72i$(n,this);else{var r=me().eventLoop_8be2vx$;if(r.isUnconfinedLoopActive)this._state_8be2vx$=i,this.resumeMode=0,r.dispatchUnconfined_4avnfa$(this);else{r.incrementUseCount_6taknv$(!0);try{for(this.context,this.continuation.resumeWith_tl1gpc$(t);r.processUnconfinedEvent(););}catch(t){if(!e.isType(t,w))throw t;this.handleFatalException_mseuzz$(t,null)}finally{r.decrementUseCount_6taknv$(!0)}}}},Gi.prototype.resumeCancellableWith_tl1gpc$=$("kotlinx-coroutines-core.kotlinx.coroutines.DispatchedContinuation.resumeCancellableWith_tl1gpc$",v((function(){var n=t.kotlinx.coroutines.toState_dwruuz$,i=e.kotlin.Unit,r=e.wrapFunction,o=Error,a=t.kotlinx.coroutines.Job,s=e.kotlin.Result,l=e.kotlin.createFailure_tcv7n7$;return r((function(){var n=t.kotlinx.coroutines.Job,r=e.kotlin.Result,o=e.kotlin.createFailure_tcv7n7$;return function(t,e){return function(){var a,s=t;t:do{var l=s.context.get_j3r2sn$(n.Key);if(null!=l&&!l.isActive){var u=l.getCancellationException();s.resumeWith_tl1gpc$(new r(o(u))),a=!0;break t}a=!1}while(0);if(!a){var c=t,p=e;c.context,c.continuation.resumeWith_tl1gpc$(p)}return i}}})),function(t){var i=n(t);if(this.dispatcher.isDispatchNeeded_1fupul$(this.context))this._state_8be2vx$=i,this.resumeMode=1,this.dispatcher.dispatch_5bn72i$(this.context,this);else{var r=me().eventLoop_8be2vx$;if(r.isUnconfinedLoopActive)this._state_8be2vx$=i,this.resumeMode=1,r.dispatchUnconfined_4avnfa$(this);else{r.incrementUseCount_6taknv$(!0);try{var u;t:do{var c=this.context.get_j3r2sn$(a.Key);if(null!=c&&!c.isActive){var p=c.getCancellationException();this.resumeWith_tl1gpc$(new s(l(p))),u=!0;break t}u=!1}while(0);for(u||(this.context,this.continuation.resumeWith_tl1gpc$(t));r.processUnconfinedEvent(););}catch(t){if(!e.isType(t,o))throw t;this.handleFatalException_mseuzz$(t,null)}finally{r.decrementUseCount_6taknv$(!0)}}}}}))),Gi.prototype.resumeCancelled=$("kotlinx-coroutines-core.kotlinx.coroutines.DispatchedContinuation.resumeCancelled",v((function(){var n=t.kotlinx.coroutines.Job,i=e.kotlin.Result,r=e.kotlin.createFailure_tcv7n7$;return function(){var t=this.context.get_j3r2sn$(n.Key);if(null!=t&&!t.isActive){var e=t.getCancellationException();return this.resumeWith_tl1gpc$(new i(r(e))),!0}return!1}}))),Gi.prototype.resumeUndispatchedWith_tl1gpc$=$("kotlinx-coroutines-core.kotlinx.coroutines.DispatchedContinuation.resumeUndispatchedWith_tl1gpc$",(function(t){this.context,this.continuation.resumeWith_tl1gpc$(t)})),Gi.prototype.dispatchYield_6v298r$=function(t,e){this._state_8be2vx$=e,this.resumeMode=1,this.dispatcher.dispatchYield_5bn72i$(t,this)},Gi.prototype.toString=function(){return"DispatchedContinuation["+this.dispatcher+", "+Ar(this.continuation)+"]"},Object.defineProperty(Gi.prototype,"context",{get:function(){return this.continuation.context}}),Gi.$metadata$={kind:o,simpleName:"DispatchedContinuation",interfaces:[a,Eo,Wi]},Wi.prototype.cancelResult_83a7kv$=function(t,e){},Wi.prototype.getSuccessfulResult_tpy1pm$=function(t){var n;return null==(n=t)||e.isType(n,i)?n:r()},Wi.prototype.getExceptionalResult_8ea4ql$=function(t){var n,i;return null!=(i=e.isType(n=t,Rt)?n:null)?i.cause:null},Wi.prototype.run=function(){var t,n=null;try{var i=(e.isType(t=this.delegate,Gi)?t:r()).continuation,o=i.context,a=this.takeState(),s=this.getExceptionalResult_8ea4ql$(a),l=Vi(this.resumeMode)?o.get_j3r2sn$(xe()):null;if(null!=s||null==l||l.isActive)if(null!=s)i.resumeWith_tl1gpc$(new _(E(s)));else{var c=this.getSuccessfulResult_tpy1pm$(a);i.resumeWith_tl1gpc$(new _(c))}else{var p=l.getCancellationException();this.cancelResult_83a7kv$(a,p),i.resumeWith_tl1gpc$(new _(E(wo(p))))}}catch(t){if(!e.isType(t,w))throw t;n=t}finally{var h;try{h=new _(u)}catch(t){if(!e.isType(t,w))throw t;h=new _(E(t))}var f=h;this.handleFatalException_mseuzz$(n,f.exceptionOrNull())}},Wi.prototype.handleFatalException_mseuzz$=function(t,e){if(null!==t||null!==e){var n=new ve("Fatal exception in coroutines machinery for "+this+". Please read KDoc to 'handleFatalException' method and report this incident to maintainers",D(null!=t?t:e));Dt(this.delegate.context,n)}},Wi.$metadata$={kind:o,simpleName:"DispatchedTask",interfaces:[co]},Ji.prototype.plus_11rb$=function(t){var n,o,a,s;if(null==(n=this.holder_0))s=new Ji(t);else if(e.isType(n,q))(e.isType(o=this.holder_0,q)?o:r()).add_11rb$(t),s=new Ji(this.holder_0);else{var l=h(4);l.add_11rb$(null==(a=this.holder_0)||e.isType(a,i)?a:r()),l.add_11rb$(t),s=new Ji(l)}return s},Ji.prototype.forEachReversed_qlkmfe$=$("kotlinx-coroutines-core.kotlinx.coroutines.internal.InlineList.forEachReversed_qlkmfe$",v((function(){var t=Object,n=e.throwCCE,i=e.kotlin.collections.ArrayList;return function(r){var o,a,s;if(null!=(o=this.holder_0))if(e.isType(o,i))for(var l=e.isType(s=this.holder_0,i)?s:n(),u=l.size-1|0;u>=0;u--)r(l.get_za3lpa$(u));else r(null==(a=this.holder_0)||e.isType(a,t)?a:n())}}))),Ji.$metadata$={kind:o,simpleName:"InlineList",interfaces:[]},Ji.prototype.unbox=function(){return this.holder_0},Ji.prototype.toString=function(){return"InlineList(holder="+e.toString(this.holder_0)+")"},Ji.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.holder_0)|0},Ji.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.holder_0,t.holder_0)},Object.defineProperty(Qi.prototype,"callerFrame",{get:function(){var t;return null==(t=this.uCont)||e.isType(t,Eo)?t:r()}}),Qi.prototype.getStackTraceElement=function(){return null},Object.defineProperty(Qi.prototype,"isScopedCoroutine",{get:function(){return!0}}),Object.defineProperty(Qi.prototype,"parent_8be2vx$",{get:function(){return this.parentContext.get_j3r2sn$(xe())}}),Qi.prototype.afterCompletion_s8jyv4$=function(t){Hi(p(this.uCont),Lt(t,this.uCont))},Qi.prototype.afterResume_s8jyv4$=function(t){this.uCont.resumeWith_tl1gpc$(Lt(t,this.uCont))},Qi.$metadata$={kind:o,simpleName:"ScopeCoroutine",interfaces:[Eo,ot]},Object.defineProperty(tr.prototype,"coroutineContext",{get:function(){return this.coroutineContext_glfhxt$_0}}),tr.prototype.toString=function(){return"CoroutineScope(coroutineContext="+this.coroutineContext+")"},tr.$metadata$={kind:o,simpleName:"ContextScope",interfaces:[Kt]},er.prototype.toString=function(){return this.symbol},er.prototype.unbox_tpy1pm$=$("kotlinx-coroutines-core.kotlinx.coroutines.internal.Symbol.unbox_tpy1pm$",v((function(){var t=Object,n=e.throwCCE;return function(i){var r;return i===this?null==null||e.isType(null,t)?null:n():null==(r=i)||e.isType(r,t)?r:n()}}))),er.$metadata$={kind:o,simpleName:"Symbol",interfaces:[]},hr.prototype.run=function(){this.closure$block()},hr.$metadata$={kind:o,interfaces:[uo]},_r.prototype.invoke_en0wgx$=function(t,e){this.invoke_ha2bmj$(t,null,e)},_r.$metadata$={kind:b,simpleName:"SelectBuilder",interfaces:[]},fr.$metadata$={kind:b,simpleName:"SelectClause0",interfaces:[]},dr.$metadata$={kind:b,simpleName:"SelectClause1",interfaces:[]},mr.$metadata$={kind:b,simpleName:"SelectClause2",interfaces:[]},yr.$metadata$={kind:b,simpleName:"SelectInstance",interfaces:[]},$("kotlinx-coroutines-core.kotlinx.coroutines.selects.select_wd2ujs$",v((function(){var n=t.kotlinx.coroutines.selects.SelectBuilderImpl,i=Error;return function(t,r){return e.suspendCall((o=t,function(t){var r=new n(t);try{o(r)}catch(t){if(!e.isType(t,i))throw t;r.handleBuilderException_tcv7n7$(t)}return r.getResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var o}}))),$r.prototype.next=function(){return(t=this).number_0=t.number_0.inc();var t},$r.$metadata$={kind:o,simpleName:"SeqNumber",interfaces:[]},Object.defineProperty(vr.prototype,"callerFrame",{get:function(){var t;return e.isType(t=this.uCont_0,Eo)?t:null}}),vr.prototype.getStackTraceElement=function(){return null},Object.defineProperty(vr.prototype,"parentHandle_0",{get:function(){return this._parentHandle_0},set:function(t){this._parentHandle_0=t}}),Object.defineProperty(vr.prototype,"context",{get:function(){return this.uCont_0.context}}),Object.defineProperty(vr.prototype,"completion",{get:function(){return this}}),vr.prototype.doResume_0=function(t,e){for(this._result_0;;){var n=this._result_0;if(n===bi){if(this._result_0===bi&&(this._result_0=t(),1))return}else{if(n!==s)throw g("Already resumed");if(function(t){return t._result_0===s&&(t._result_0=wi,!0)}(this))return void e()}}},vr.prototype.resumeWith_tl1gpc$=function(t){t:do{for(this._result_0;;){var e=this._result_0;if(e===bi){if(this._result_0===bi&&(this._result_0=At(t),1))break t}else{if(e!==s)throw g("Already resumed");if(function(t){return t._result_0===s&&(t._result_0=wi,!0)}(this)){if(t.isFailure){var n=this.uCont_0;n.resumeWith_tl1gpc$(new _(E(wo(D(t.exceptionOrNull())))))}else this.uCont_0.resumeWith_tl1gpc$(t);break t}}}}while(0)},vr.prototype.resumeSelectWithException_tcv7n7$=function(t){t:do{for(this._result_0;;){var e=this._result_0;if(e===bi){if((n=this)._result_0===bi&&function(){return n._result_0=new Rt(wo(t,this.uCont_0)),!0}())break t}else{if(e!==s)throw g("Already resumed");if(function(t){return t._result_0===s&&(t._result_0=wi,!0)}(this)){p(this.uCont_0).resumeWith_tl1gpc$(new _(E(t)));break t}}}}while(0);var n},vr.prototype.getResult=function(){this.isSelected||this.initCancellability_0();var t=this._result_0;if(t===bi){if(this._result_0===bi&&(this._result_0=s,1))return s;t=this._result_0}if(t===wi)throw g("Already resumed");if(e.isType(t,Rt))throw t.cause;return t},vr.prototype.initCancellability_0=function(){var t;if(null!=(t=this.context.get_j3r2sn$(xe()))){var e=t,n=e.invokeOnCompletion_ct2b2z$(!0,void 0,new gr(this,e));this.parentHandle_0=n,this.isSelected&&n.dispose()}},gr.prototype.invoke=function(t){this.$outer.trySelect()&&this.$outer.resumeSelectWithException_tcv7n7$(this.job.getCancellationException())},gr.prototype.toString=function(){return"SelectOnCancelling["+this.$outer+"]"},gr.$metadata$={kind:o,simpleName:"SelectOnCancelling",interfaces:[an]},vr.prototype.handleBuilderException_tcv7n7$=function(t){if(this.trySelect())this.resumeWith_tl1gpc$(new _(E(t)));else if(!e.isType(t,Yr)){var n=this.getResult();e.isType(n,Rt)&&n.cause===t||Dt(this.context,t)}},Object.defineProperty(vr.prototype,"isSelected",{get:function(){for(this._state_0;;){var t=this._state_0;if(t===this)return!1;if(!e.isType(t,Ui))return!0;t.perform_s8jyv4$(this)}}}),vr.prototype.disposeOnSelect_rvfg84$=function(t){var e=new xr(t);(this.isSelected||(this.addLast_l2j9rm$(e),this.isSelected))&&t.dispose()},vr.prototype.doAfterSelect_0=function(){var t;null!=(t=this.parentHandle_0)&&t.dispose();for(var n=this._next;!y(n,this);)e.isType(n,xr)&&n.handle.dispose(),n=n._next},vr.prototype.trySelect=function(){var t,e=this.trySelectOther_uc1cc4$(null);if(e===n)t=!0;else{if(null!=e)throw g(("Unexpected trySelectIdempotent result "+x(e)).toString());t=!1}return t},vr.prototype.trySelectOther_uc1cc4$=function(t){for(this._state_0;;){var i=this._state_0;t:do{if(i===this){if(null==t){if(this._state_0!==this||(this._state_0=null,0))break t}else{var r=new br(t);if(!function(t){return t._state_0===t&&(t._state_0=r,!0)}(this))break t;var o=r.perform_s8jyv4$(this);if(null!==o)return o}return this.doAfterSelect_0(),n}if(!e.isType(i,Ui))return null==t?null:i===t.desc?n:null;if(null!=t){var a=t.atomicOp;if(e.isType(a,wr)&&a.impl===this)throw g("Cannot use matching select clauses on the same object".toString());if(a.isEarlierThan_bfmzsr$(i))return mi}i.perform_s8jyv4$(this)}while(0)}},br.prototype.perform_s8jyv4$=function(t){var n,i=e.isType(n=t,vr)?n:r();this.otherOp.finishPrepare();var o=this.otherOp.atomicOp.decide_s8jyv4$(null),a=null==o?this.otherOp.desc:i;return this,i._state_0===this&&(i._state_0=a),o},Object.defineProperty(br.prototype,"atomicOp",{get:function(){return this.otherOp.atomicOp}}),br.$metadata$={kind:o,simpleName:"PairSelectOp",interfaces:[Ui]},vr.prototype.performAtomicTrySelect_6q0pxr$=function(t){return new wr(this,t).perform_s8jyv4$(null)},vr.prototype.toString=function(){var t=this._state_0;return"SelectInstance(state="+(t===this?"this":x(t))+", result="+x(this._result_0)+")"},Object.defineProperty(wr.prototype,"opSequence",{get:function(){return this.opSequence_oe6pw4$_0}}),wr.prototype.prepare_11rb$=function(t){var n;if(null==t&&null!=(n=this.prepareSelectOp_0()))return n;try{return this.desc.prepare_4uxf5b$(this)}catch(n){throw e.isType(n,w)?(null==t&&this.undoPrepare_0(),n):n}},wr.prototype.complete_19pj23$=function(t,e){this.completeSelect_0(e),this.desc.complete_ayrq83$(this,e)},wr.prototype.prepareSelectOp_0=function(){var t;for(this.impl._state_0;;){var n=this.impl._state_0;if(n===this)return null;if(e.isType(n,Ui))n.perform_s8jyv4$(this.impl);else{if(n!==this.impl)return gi;if((t=this).impl._state_0===t.impl&&(t.impl._state_0=t,1))return null}}},wr.prototype.undoPrepare_0=function(){var t;(t=this).impl._state_0===t&&(t.impl._state_0=t.impl)},wr.prototype.completeSelect_0=function(t){var e=null==t,n=e?null:this.impl;this.impl._state_0===this&&(this.impl._state_0=n,1)&&e&&this.impl.doAfterSelect_0()},wr.prototype.toString=function(){return"AtomicSelectOp(sequence="+this.opSequence.toString()+")"},wr.$metadata$={kind:o,simpleName:"AtomicSelectOp",interfaces:[Fi]},vr.prototype.invoke_nd4vgy$=function(t,e){t.registerSelectClause0_s9h9qd$(this,e)},vr.prototype.invoke_veq140$=function(t,e){t.registerSelectClause1_o3xas4$(this,e)},vr.prototype.invoke_ha2bmj$=function(t,e,n){t.registerSelectClause2_rol3se$(this,e,n)},vr.prototype.onTimeout_7xvrws$=function(t,e){if(t.compareTo_11rb$(R)<=0)this.trySelect()&&sr(e,this.completion);else{var n=new hr((i=this,r=e,function(){return i.trySelect()&&rr(r,i.completion),u}));this.disposeOnSelect_rvfg84$(he(this.context).invokeOnTimeout_8irseu$(t,n))}var i,r},xr.$metadata$={kind:o,simpleName:"DisposeNode",interfaces:[mo]},vr.$metadata$={kind:o,simpleName:"SelectBuilderImpl",interfaces:[Eo,a,yr,_r,bo]},$("kotlinx-coroutines-core.kotlinx.coroutines.selects.selectUnbiased_wd2ujs$",v((function(){var n=t.kotlinx.coroutines.selects.UnbiasedSelectBuilderImpl,i=Error;return function(t,r){return e.suspendCall((o=t,function(t){var r=new n(t);try{o(r)}catch(t){if(!e.isType(t,i))throw t;r.handleBuilderException_tcv7n7$(t)}return r.initSelectResult()})(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver());var o}}))),kr.prototype.handleBuilderException_tcv7n7$=function(t){this.instance.handleBuilderException_tcv7n7$(t)},kr.prototype.initSelectResult=function(){if(!this.instance.isSelected)try{var t;for(tt(this.clauses),t=this.clauses.iterator();t.hasNext();)t.next()()}catch(t){if(!e.isType(t,w))throw t;this.instance.handleBuilderException_tcv7n7$(t)}return this.instance.getResult()},kr.prototype.invoke_nd4vgy$=function(t,e){var n,i,r;this.clauses.add_11rb$((n=this,i=e,r=t,function(){return r.registerSelectClause0_s9h9qd$(n.instance,i),u}))},kr.prototype.invoke_veq140$=function(t,e){var n,i,r;this.clauses.add_11rb$((n=this,i=e,r=t,function(){return r.registerSelectClause1_o3xas4$(n.instance,i),u}))},kr.prototype.invoke_ha2bmj$=function(t,e,n){var i,r,o,a;this.clauses.add_11rb$((i=this,r=e,o=n,a=t,function(){return a.registerSelectClause2_rol3se$(i.instance,r,o),u}))},kr.prototype.onTimeout_7xvrws$=function(t,e){var n,i,r;this.clauses.add_11rb$((n=this,i=t,r=e,function(){return n.instance.onTimeout_7xvrws$(i,r),u}))},kr.$metadata$={kind:o,simpleName:"UnbiasedSelectBuilderImpl",interfaces:[_r]},$("kotlinx-coroutines-core.kotlinx.coroutines.selects.whileSelect_vmyjlh$",v((function(){var n=t.kotlinx.coroutines.selects.SelectBuilderImpl,i=Error;function r(t){return function(r){var o=new n(r);try{t(o)}catch(t){if(!e.isType(t,i))throw t;o.handleBuilderException_tcv7n7$(t)}return o.getResult()}}return function(t,n){for(;e.suspendCall(r(t)(e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver()););}}))),$("kotlinx-coroutines-core.kotlinx.coroutines.sync.withLock_8701tb$",(function(t,n,i,r){void 0===n&&(n=null),e.suspendCall(t.lock_s8jyv4$(n,e.coroutineReceiver()));try{return i()}finally{t.unlock_s8jyv4$(n)}})),Er.prototype.toString=function(){return"Empty["+this.locked.toString()+"]"},Er.$metadata$={kind:o,simpleName:"Empty",interfaces:[]},$("kotlinx-coroutines-core.kotlinx.coroutines.sync.withPermit_103m5a$",(function(t,n,i){e.suspendCall(t.acquire(e.coroutineReceiver()));try{return n()}finally{t.release()}})),Cr.$metadata$={kind:o,simpleName:"CompletionHandlerBase",interfaces:[mo]},Sr.$metadata$={kind:o,simpleName:"CancelHandlerBase",interfaces:[]},zr.$metadata$={kind:k,simpleName:"Dispatchers",interfaces:[]};var Dr,Mr=null;function Br(){return null===Mr&&new zr,Mr}function Ur(t){cn.call(this),this.delegate=t}function Fr(){return new qr}function qr(){_e.call(this)}function Gr(){_e.call(this)}function Hr(){throw H("runBlocking event loop is not supported")}function Yr(t,e){U.call(this,t,e),this.name="CancellationException"}function Vr(t,e){return e=e||Object.create(Yr.prototype),Yr.call(e,t,null),e}function Kr(t,e,n){Yr.call(this,t,e),this.job_8be2vx$=n,this.name="JobCancellationException"}function Wr(t){return nt(t,R,Dr).toInt()}function Xr(){zt.call(this),this.messageQueue_8be2vx$=new Zr(this)}function Zr(t){var e;this.$outer=t,lo.call(this),this.processQueue_8be2vx$=(e=this,function(){return e.process(),u})}function Jr(){Qr=this,Xr.call(this)}Object.defineProperty(Ur.prototype,"immediate",{get:function(){throw H("Immediate dispatching is not supported on JS")}}),Ur.prototype.dispatch_5bn72i$=function(t,e){this.delegate.dispatch_5bn72i$(t,e)},Ur.prototype.isDispatchNeeded_1fupul$=function(t){return this.delegate.isDispatchNeeded_1fupul$(t)},Ur.prototype.dispatchYield_5bn72i$=function(t,e){this.delegate.dispatchYield_5bn72i$(t,e)},Ur.prototype.toString=function(){return this.delegate.toString()},Ur.$metadata$={kind:o,simpleName:"JsMainDispatcher",interfaces:[cn]},qr.prototype.dispatch_5bn72i$=function(t,e){Hr()},qr.$metadata$={kind:o,simpleName:"UnconfinedEventLoop",interfaces:[_e]},Gr.prototype.unpark_0=function(){Hr()},Gr.prototype.reschedule_0=function(t,e){Hr()},Gr.$metadata$={kind:o,simpleName:"EventLoopImplPlatform",interfaces:[_e]},Yr.$metadata$={kind:o,simpleName:"CancellationException",interfaces:[U]},Kr.prototype.toString=function(){return Yr.prototype.toString.call(this)+"; job="+this.job_8be2vx$},Kr.prototype.equals=function(t){return t===this||e.isType(t,Kr)&&y(t.message,this.message)&&y(t.job_8be2vx$,this.job_8be2vx$)&&y(t.cause,this.cause)},Kr.prototype.hashCode=function(){var t,e;return(31*((31*W(D(this.message))|0)+W(this.job_8be2vx$)|0)|0)+(null!=(e=null!=(t=this.cause)?W(t):null)?e:0)|0},Kr.$metadata$={kind:o,simpleName:"JobCancellationException",interfaces:[Yr]},Zr.prototype.schedule=function(){this.$outer.scheduleQueueProcessing()},Zr.prototype.reschedule=function(){setTimeout(this.processQueue_8be2vx$,0)},Zr.$metadata$={kind:o,simpleName:"ScheduledMessageQueue",interfaces:[lo]},Xr.prototype.dispatch_5bn72i$=function(t,e){this.messageQueue_8be2vx$.enqueue_771g0p$(e)},Xr.prototype.invokeOnTimeout_8irseu$=function(t,e){return new ro(setTimeout((n=e,function(){return n.run(),u}),Wr(t)));var n},Xr.prototype.scheduleResumeAfterDelay_egqmvs$=function(t,e){var n,i,r=setTimeout((n=e,i=this,function(){return n.resumeUndispatched_hyuxa3$(i,u),u}),Wr(t));e.invokeOnCancellation_f05bi3$(new ro(r))},Xr.$metadata$={kind:o,simpleName:"SetTimeoutBasedDispatcher",interfaces:[pe,zt]},Jr.prototype.scheduleQueueProcessing=function(){process.nextTick(this.messageQueue_8be2vx$.processQueue_8be2vx$)},Jr.$metadata$={kind:k,simpleName:"NodeDispatcher",interfaces:[Xr]};var Qr=null;function to(){return null===Qr&&new Jr,Qr}function eo(){no=this,Xr.call(this)}eo.prototype.scheduleQueueProcessing=function(){setTimeout(this.messageQueue_8be2vx$.processQueue_8be2vx$,0)},eo.$metadata$={kind:k,simpleName:"SetTimeoutDispatcher",interfaces:[Xr]};var no=null;function io(){return null===no&&new eo,no}function ro(t){kt.call(this),this.handle_0=t}function oo(t){zt.call(this),this.window_0=t,this.queue_0=new so(this.window_0)}function ao(t,e){this.this$WindowDispatcher=t,this.closure$handle=e}function so(t){var e;lo.call(this),this.window_0=t,this.messageName_0="dispatchCoroutine",this.window_0.addEventListener("message",(e=this,function(t){return t.source==e.window_0&&t.data==e.messageName_0&&(t.stopPropagation(),e.process()),u}),!0)}function lo(){Bi.call(this),this.yieldEvery=16,this.scheduled_0=!1}function uo(){}function co(){}function po(t){}function ho(t){var e,n;if(null!=(e=t.coroutineDispatcher))n=e;else{var i=new oo(t);t.coroutineDispatcher=i,n=i}return n}function _o(){}function fo(t){return it(t)}function mo(){this._next=this,this._prev=this,this._removed=!1}function yo(t,e){vo.call(this),this.queue=t,this.node=e}function $o(t){vo.call(this),this.queue=t,this.affectedNode_rjf1fm$_0=this.queue._next}function vo(){qi.call(this)}function go(t,e,n){Ui.call(this),this.affected=t,this.desc=e,this.atomicOp_khy6pf$_0=n}function bo(){mo.call(this)}function wo(t,e){return t}function xo(t){return t}function ko(t){return t}function Eo(){}function Co(t,e){}function So(t){return null}function To(t){return 0}function Oo(){this.value_0=null}ro.prototype.dispose=function(){clearTimeout(this.handle_0)},ro.prototype.invoke=function(t){this.dispose()},ro.prototype.toString=function(){return"ClearTimeout["+this.handle_0+"]"},ro.$metadata$={kind:o,simpleName:"ClearTimeout",interfaces:[Ee,kt]},oo.prototype.dispatch_5bn72i$=function(t,e){this.queue_0.enqueue_771g0p$(e)},oo.prototype.scheduleResumeAfterDelay_egqmvs$=function(t,e){var n,i;this.window_0.setTimeout((n=e,i=this,function(){return n.resumeUndispatched_hyuxa3$(i,u),u}),Wr(t))},ao.prototype.dispose=function(){this.this$WindowDispatcher.window_0.clearTimeout(this.closure$handle)},ao.$metadata$={kind:o,interfaces:[Ee]},oo.prototype.invokeOnTimeout_8irseu$=function(t,e){return new ao(this,this.window_0.setTimeout((n=e,function(){return n.run(),u}),Wr(t)));var n},oo.$metadata$={kind:o,simpleName:"WindowDispatcher",interfaces:[pe,zt]},so.prototype.schedule=function(){var t;Promise.resolve(u).then((t=this,function(e){return t.process(),u}))},so.prototype.reschedule=function(){this.window_0.postMessage(this.messageName_0,"*")},so.$metadata$={kind:o,simpleName:"WindowMessageQueue",interfaces:[lo]},lo.prototype.enqueue_771g0p$=function(t){this.addLast_trkh7z$(t),this.scheduled_0||(this.scheduled_0=!0,this.schedule())},lo.prototype.process=function(){try{for(var t=this.yieldEvery,e=0;e "+n+"\n |with response from "+na(t).url+":\n |status: "+t.status+"\n |response headers: \n |"+I(R(t.headers),void 0,void 0,void 0,void 0,void 0,Bn)+"\n ")}function Bn(t){return t.component1()+": "+t.component2()+"\n"}function Un(t){Cn.call(this,t)}function Fn(t,e){this.call_k7cxor$_0=t,this.$delegate_k8mkjd$_0=e}function qn(t,e,n){ea.call(this),this.call_tbj7t5$_0=t,this.status_i2dvkt$_0=n.status,this.version_ol3l9j$_0=n.version,this.requestTime_3msfjx$_0=n.requestTime,this.responseTime_xhbsdj$_0=n.responseTime,this.headers_w25qx3$_0=n.headers,this.coroutineContext_pwmz9e$_0=n.coroutineContext,this.content_mzxkbe$_0=U(e)}function Gn(t,e){_.call(this,e),this.exceptionState_0=1,this.local$$receiver_0=void 0,this.local$$receiver=t}function Hn(t,e,n){var i=new Gn(t,e);return n?i:i.doResume(null)}function Yn(t,e,n){void 0===n&&(n=null),this.type=t,this.reifiedType=e,this.kotlinType=n}function Vn(t){w("Failed to write body: "+e.getKClassFromExpression(t),this),this.name="UnsupportedContentTypeException"}function Kn(t){G("Unsupported upgrade protocol exception: "+t,this),this.name="UnsupportedUpgradeProtocolException"}function Wn(t,e,n){_.call(this,n),this.$controller=e,this.exceptionState_0=1}function Xn(t,e,n){var i=new Wn(t,this,e);return n?i:i.doResume(null)}function Zn(t,e,n){_.call(this,n),this.$controller=e,this.exceptionState_0=1}function Jn(t,e,n){var i=new Zn(t,this,e);return n?i:i.doResume(null)}function Qn(t){return function(e){if(null!=e)return t.cancel_m4sck1$(J(e.message)),u}}function ti(t){return function(e){return t.dispose(),u}}function ei(){}function ni(t,e,n,i,r,o){_.call(this,o),this.$controller=r,this.exceptionState_0=1,this.local$this$HttpClientEngine=t,this.local$closure$client=e,this.local$requestData=void 0,this.local$$receiver=n,this.local$content=i}function ii(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$this$HttpClientEngine=t,this.local$closure$requestData=e}function ri(t,e){return function(n,i,r){var o=new ii(t,e,n,this,i);return r?o:o.doResume(null)}}function oi(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$requestData=e}function ai(){}function si(t){return u}function li(t){var e,n=t.headers;for(e=X.HttpHeaders.UnsafeHeadersList.iterator();e.hasNext();){var i=e.next();if(n.contains_61zpoe$(i))throw new Z(i)}}function ui(t){var e;this.engineName_n0bloo$_0=t,this.coroutineContext_huxu0y$_0=tt((e=this,function(){return Q().plus_1fupul$(e.dispatcher).plus_1fupul$(new Y(e.engineName_n0bloo$_0+"-context"))}))}function ci(t){return function(n){return function(t){var n,i;try{null!=(i=e.isType(n=t,m)?n:null)&&i.close()}catch(t){if(e.isType(t,T))return u;throw t}}(t.dispatcher),u}}function pi(t){void 0===t&&(t=null),w("Client already closed",this),this.cause_om4vf0$_0=t,this.name="ClientEngineClosedException"}function hi(){}function _i(){this.threadsCount=4,this.pipelining=!1,this.proxy=null}function fi(t,e,n){var i,r,o,a,s,l,c;La((l=t,c=e,function(t){return t.appendAll_hb0ubp$(l),t.appendAll_hb0ubp$(c.headers),u})).forEach_ubvtmq$((s=n,function(t,e){if(!nt(X.HttpHeaders.ContentLength,t)&&!nt(X.HttpHeaders.ContentType,t))return s(t,I(e,";")),u})),null==t.get_61zpoe$(X.HttpHeaders.UserAgent)&&null==e.headers.get_61zpoe$(X.HttpHeaders.UserAgent)&&!ot.PlatformUtils.IS_BROWSER&&n(X.HttpHeaders.UserAgent,Pn);var p=null!=(r=null!=(i=e.contentType)?i.toString():null)?r:e.headers.get_61zpoe$(X.HttpHeaders.ContentType),h=null!=(a=null!=(o=e.contentLength)?o.toString():null)?a:e.headers.get_61zpoe$(X.HttpHeaders.ContentLength);null!=p&&n(X.HttpHeaders.ContentType,p),null!=h&&n(X.HttpHeaders.ContentLength,h)}function di(t){return p(t.context.get_j3r2sn$(gi())).callContext}function mi(t){gi(),this.callContext=t}function yi(){vi=this}Cn.$metadata$={kind:g,simpleName:"HttpClientCall",interfaces:[b]},Ln.$metadata$={kind:g,simpleName:"HttpEngineCall",interfaces:[]},Ln.prototype.component1=function(){return this.request},Ln.prototype.component2=function(){return this.response},Ln.prototype.copy_ukxvzw$=function(t,e){return new Ln(void 0===t?this.request:t,void 0===e?this.response:e)},Ln.prototype.toString=function(){return"HttpEngineCall(request="+e.toString(this.request)+", response="+e.toString(this.response)+")"},Ln.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.request)|0)+e.hashCode(this.response)|0},Ln.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.request,t.request)&&e.equals(this.response,t.response)},Rn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Rn.prototype=Object.create(_.prototype),Rn.prototype.constructor=Rn,Rn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:return u;case 1:throw this.exception_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},N("ktor-ktor-client-core.io.ktor.client.call.receive_8ov3cv$",P((function(){var n=e.getReifiedTypeParameterKType,i=e.throwCCE,r=e.getKClass,o=t.io.ktor.client.call,a=t.io.ktor.client.call.TypeInfo;return function(t,s,l,u){var c,p;t:do{try{p=new a(r(t),o.JsType,n(t))}catch(e){p=new a(r(t),o.JsType);break t}}while(0);return e.suspendCall(l.receive_jo9acv$(p,e.coroutineReceiver())),s(c=e.coroutineResult(e.coroutineReceiver()))?c:i()}}))),N("ktor-ktor-client-core.io.ktor.client.call.receive_5sqbag$",P((function(){var n=e.getReifiedTypeParameterKType,i=e.throwCCE,r=e.getKClass,o=t.io.ktor.client.call,a=t.io.ktor.client.call.TypeInfo;return function(t,s,l,u){var c,p,h=l.call;t:do{try{p=new a(r(t),o.JsType,n(t))}catch(e){p=new a(r(t),o.JsType);break t}}while(0);return e.suspendCall(h.receive_jo9acv$(p,e.coroutineReceiver())),s(c=e.coroutineResult(e.coroutineReceiver()))?c:i()}}))),Object.defineProperty(zn.prototype,"message",{get:function(){return this.message_eo7lbx$_0}}),zn.$metadata$={kind:g,simpleName:"DoubleReceiveException",interfaces:[j]},Object.defineProperty(Dn.prototype,"cause",{get:function(){return this.cause_xlcv2q$_0}}),Dn.$metadata$={kind:g,simpleName:"ReceivePipelineException",interfaces:[j]},Object.defineProperty(Mn.prototype,"message",{get:function(){return this.message_gd84kd$_0}}),Mn.$metadata$={kind:g,simpleName:"NoTransformationFoundException",interfaces:[D]},Un.$metadata$={kind:g,simpleName:"SavedHttpCall",interfaces:[Cn]},Object.defineProperty(Fn.prototype,"call",{get:function(){return this.call_k7cxor$_0}}),Object.defineProperty(Fn.prototype,"attributes",{get:function(){return this.$delegate_k8mkjd$_0.attributes}}),Object.defineProperty(Fn.prototype,"content",{get:function(){return this.$delegate_k8mkjd$_0.content}}),Object.defineProperty(Fn.prototype,"coroutineContext",{get:function(){return this.$delegate_k8mkjd$_0.coroutineContext}}),Object.defineProperty(Fn.prototype,"executionContext",{get:function(){return this.$delegate_k8mkjd$_0.executionContext}}),Object.defineProperty(Fn.prototype,"headers",{get:function(){return this.$delegate_k8mkjd$_0.headers}}),Object.defineProperty(Fn.prototype,"method",{get:function(){return this.$delegate_k8mkjd$_0.method}}),Object.defineProperty(Fn.prototype,"url",{get:function(){return this.$delegate_k8mkjd$_0.url}}),Fn.$metadata$={kind:g,simpleName:"SavedHttpRequest",interfaces:[Eo]},Object.defineProperty(qn.prototype,"call",{get:function(){return this.call_tbj7t5$_0}}),Object.defineProperty(qn.prototype,"status",{get:function(){return this.status_i2dvkt$_0}}),Object.defineProperty(qn.prototype,"version",{get:function(){return this.version_ol3l9j$_0}}),Object.defineProperty(qn.prototype,"requestTime",{get:function(){return this.requestTime_3msfjx$_0}}),Object.defineProperty(qn.prototype,"responseTime",{get:function(){return this.responseTime_xhbsdj$_0}}),Object.defineProperty(qn.prototype,"headers",{get:function(){return this.headers_w25qx3$_0}}),Object.defineProperty(qn.prototype,"coroutineContext",{get:function(){return this.coroutineContext_pwmz9e$_0}}),Object.defineProperty(qn.prototype,"content",{get:function(){return this.content_mzxkbe$_0}}),qn.$metadata$={kind:g,simpleName:"SavedHttpResponse",interfaces:[ea]},Gn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Gn.prototype=Object.create(_.prototype),Gn.prototype.constructor=Gn,Gn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$$receiver_0=new Un(this.local$$receiver.client),this.state_0=2,this.result_0=F(this.local$$receiver.response.content,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return this.local$$receiver_0.request=new Fn(this.local$$receiver_0,this.local$$receiver.request),this.local$$receiver_0.response=new qn(this.local$$receiver_0,q(t),this.local$$receiver.response),this.local$$receiver_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Yn.$metadata$={kind:g,simpleName:"TypeInfo",interfaces:[]},Yn.prototype.component1=function(){return this.type},Yn.prototype.component2=function(){return this.reifiedType},Yn.prototype.component3=function(){return this.kotlinType},Yn.prototype.copy_zg9ia4$=function(t,e,n){return new Yn(void 0===t?this.type:t,void 0===e?this.reifiedType:e,void 0===n?this.kotlinType:n)},Yn.prototype.toString=function(){return"TypeInfo(type="+e.toString(this.type)+", reifiedType="+e.toString(this.reifiedType)+", kotlinType="+e.toString(this.kotlinType)+")"},Yn.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.type)|0)+e.hashCode(this.reifiedType)|0)+e.hashCode(this.kotlinType)|0},Yn.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.type,t.type)&&e.equals(this.reifiedType,t.reifiedType)&&e.equals(this.kotlinType,t.kotlinType)},Vn.$metadata$={kind:g,simpleName:"UnsupportedContentTypeException",interfaces:[j]},Kn.$metadata$={kind:g,simpleName:"UnsupportedUpgradeProtocolException",interfaces:[H]},Wn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Wn.prototype=Object.create(_.prototype),Wn.prototype.constructor=Wn,Wn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:return u;case 1:throw this.exception_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Zn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Zn.prototype=Object.create(_.prototype),Zn.prototype.constructor=Zn,Zn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:return u;case 1:throw this.exception_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(ei.prototype,"supportedCapabilities",{get:function(){return V()}}),Object.defineProperty(ei.prototype,"closed_yj5g8o$_0",{get:function(){var t,e;return!(null!=(e=null!=(t=this.coroutineContext.get_j3r2sn$(c.Key))?t.isActive:null)&&e)}}),ni.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ni.prototype=Object.create(_.prototype),ni.prototype.constructor=ni,ni.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=new Co;if(t.takeFrom_s9rlw$(this.local$$receiver.context),t.body=this.local$content,this.local$requestData=t.build(),li(this.local$requestData),this.local$this$HttpClientEngine.checkExtensions_1320zn$_0(this.local$requestData),this.state_0=2,this.result_0=this.local$this$HttpClientEngine.executeWithinCallContext_2kaaho$_0(this.local$requestData,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:var e=this.result_0,n=En(this.local$closure$client,this.local$requestData,e);if(this.state_0=3,this.result_0=this.local$$receiver.proceedWith_trkh7z$(n,this),this.result_0===h)return h;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ei.prototype.install_k5i6f8$=function(t){var e,n;t.sendPipeline.intercept_h71y74$(Go().Engine,(e=this,n=t,function(t,i,r,o){var a=new ni(e,n,t,i,this,r);return o?a:a.doResume(null)}))},ii.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ii.prototype=Object.create(_.prototype),ii.prototype.constructor=ii,ii.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$this$HttpClientEngine.closed_yj5g8o$_0)throw new pi;if(this.state_0=2,this.result_0=this.local$this$HttpClientEngine.execute_dkgphz$(this.local$closure$requestData,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},oi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},oi.prototype=Object.create(_.prototype),oi.prototype.constructor=oi,oi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.createCallContext_bk2bfg$_0(this.local$requestData.executionContext,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;if(this.state_0=3,this.result_0=K(this.$this,t.plus_1fupul$(new mi(t)),void 0,ri(this.$this,this.local$requestData)).await(this),this.result_0===h)return h;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ei.prototype.executeWithinCallContext_2kaaho$_0=function(t,e,n){var i=new oi(this,t,e);return n?i:i.doResume(null)},ei.prototype.checkExtensions_1320zn$_0=function(t){var e;for(e=t.requiredCapabilities_8be2vx$.iterator();e.hasNext();){var n=e.next();if(!this.supportedCapabilities.contains_11rb$(n))throw G(("Engine doesn't support "+n).toString())}},ei.prototype.createCallContext_bk2bfg$_0=function(t,e){var n=$(t),i=this.coroutineContext.plus_1fupul$(n).plus_1fupul$(On);t:do{var r;if(null==(r=e.context.get_j3r2sn$(c.Key)))break t;var o=r.invokeOnCompletion_ct2b2z$(!0,void 0,Qn(n));n.invokeOnCompletion_f05bi3$(ti(o))}while(0);return i},ei.$metadata$={kind:W,simpleName:"HttpClientEngine",interfaces:[m,b]},ai.prototype.create_dxyxif$=function(t,e){return void 0===t&&(t=si),e?e(t):this.create_dxyxif$$default(t)},ai.$metadata$={kind:W,simpleName:"HttpClientEngineFactory",interfaces:[]},Object.defineProperty(ui.prototype,"coroutineContext",{get:function(){return this.coroutineContext_huxu0y$_0.value}}),ui.prototype.close=function(){var t,n=e.isType(t=this.coroutineContext.get_j3r2sn$(c.Key),y)?t:f();n.complete(),n.invokeOnCompletion_f05bi3$(ci(this))},ui.$metadata$={kind:g,simpleName:"HttpClientEngineBase",interfaces:[ei]},Object.defineProperty(pi.prototype,"cause",{get:function(){return this.cause_om4vf0$_0}}),pi.$metadata$={kind:g,simpleName:"ClientEngineClosedException",interfaces:[j]},hi.$metadata$={kind:W,simpleName:"HttpClientEngineCapability",interfaces:[]},Object.defineProperty(_i.prototype,"response",{get:function(){throw w("Unbound [HttpClientCall] is deprecated. Consider using [request(block)] in instead.".toString())}}),_i.$metadata$={kind:g,simpleName:"HttpClientEngineConfig",interfaces:[]},Object.defineProperty(mi.prototype,"key",{get:function(){return gi()}}),yi.$metadata$={kind:O,simpleName:"Companion",interfaces:[it]};var $i,vi=null;function gi(){return null===vi&&new yi,vi}function bi(t,e){_.call(this,e),this.exceptionState_0=1,this.local$statusCode=void 0,this.local$originCall=void 0,this.local$response=t}function wi(t,e,n){var i=new bi(t,e);return n?i:i.doResume(null)}function xi(t){return t.validateResponse_d4bkoy$(wi),u}function ki(t){Ki(t,xi)}function Ei(t){w("Bad response: "+t,this),this.response=t,this.name="ResponseException"}function Ci(t){Ei.call(this,t),this.name="RedirectResponseException",this.message_rcd2w9$_0="Unhandled redirect: "+t.call.request.url+". Status: "+t.status}function Si(t){Ei.call(this,t),this.name="ServerResponseException",this.message_3dyog2$_0="Server error("+t.call.request.url+": "+t.status+"."}function Ti(t){Ei.call(this,t),this.name="ClientRequestException",this.message_mrabda$_0="Client request("+t.call.request.url+") invalid: "+t.status}function Oi(t){this.closure$body=t,lt.call(this),this.contentLength_ca0n1g$_0=e.Long.fromInt(t.length)}function Ni(t){this.closure$body=t,ut.call(this)}function Pi(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$$receiver=t,this.local$body=e}function Ai(t,e,n,i){var r=new Pi(t,e,this,n);return i?r:r.doResume(null)}function ji(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=10,this.local$closure$body=t,this.local$closure$response=e,this.local$$receiver=n}function Li(t,e){return function(n,i,r){var o=new ji(t,e,n,this,i);return r?o:o.doResume(null)}}function Ri(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$info=void 0,this.local$body=void 0,this.local$$receiver=t,this.local$f=e}function Ii(t,e,n,i){var r=new Ri(t,e,this,n);return i?r:r.doResume(null)}function zi(t){t.requestPipeline.intercept_h71y74$(Mo().Render,Ai),t.responsePipeline.intercept_h71y74$(sa().Parse,Ii)}function Di(t,e){Vi(),this.responseValidators_0=t,this.callExceptionHandlers_0=e}function Mi(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$response=e}function Bi(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$cause=e}function Ui(){this.responseValidators_8be2vx$=St(),this.responseExceptionHandlers_8be2vx$=St()}function Fi(){Yi=this,this.key_uukd7r$_0=new d("HttpResponseValidator")}function qi(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=6,this.local$closure$feature=t,this.local$cause=void 0,this.local$$receiver=e,this.local$it=n}function Gi(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=7,this.local$closure$feature=t,this.local$cause=void 0,this.local$$receiver=e,this.local$container=n}mi.$metadata$={kind:g,simpleName:"KtorCallContextElement",interfaces:[rt]},N("ktor-ktor-client-core.io.ktor.client.engine.attachToUserJob_mmkme6$",P((function(){var n=t.$$importsForInline$$["kotlinx-coroutines-core"].kotlinx.coroutines.Job,i=t.$$importsForInline$$["kotlinx-coroutines-core"].kotlinx.coroutines.CancellationException_init_pdl1vj$,r=e.kotlin.Unit;return function(t,o){var a,s,l;if(null!=(a=e.coroutineReceiver().context.get_j3r2sn$(n.Key))){var u=a.invokeOnCompletion_ct2b2z$(!0,void 0,(l=t,function(t){if(null!=t)return l.cancel_m4sck1$(i(t.message)),r}));t.invokeOnCompletion_f05bi3$((s=u,function(t){return s.dispose(),r}))}}}))),bi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},bi.prototype=Object.create(_.prototype),bi.prototype.constructor=bi,bi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$statusCode=this.local$response.status.value,this.local$originCall=this.local$response.call,this.local$statusCode<300||this.local$originCall.attributes.contains_w48dwb$($i))return;this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=Hn(this.local$originCall,this),this.result_0===h)return h;continue;case 3:var t=this.result_0;t.attributes.put_uuntuo$($i,u);var e=t.response;throw this.local$statusCode>=300&&this.local$statusCode<=399?new Ci(e):this.local$statusCode>=400&&this.local$statusCode<=499?new Ti(e):this.local$statusCode>=500&&this.local$statusCode<=599?new Si(e):new Ei(e);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ei.$metadata$={kind:g,simpleName:"ResponseException",interfaces:[j]},Object.defineProperty(Ci.prototype,"message",{get:function(){return this.message_rcd2w9$_0}}),Ci.$metadata$={kind:g,simpleName:"RedirectResponseException",interfaces:[Ei]},Object.defineProperty(Si.prototype,"message",{get:function(){return this.message_3dyog2$_0}}),Si.$metadata$={kind:g,simpleName:"ServerResponseException",interfaces:[Ei]},Object.defineProperty(Ti.prototype,"message",{get:function(){return this.message_mrabda$_0}}),Ti.$metadata$={kind:g,simpleName:"ClientRequestException",interfaces:[Ei]},Object.defineProperty(Oi.prototype,"contentLength",{get:function(){return this.contentLength_ca0n1g$_0}}),Oi.prototype.bytes=function(){return this.closure$body},Oi.$metadata$={kind:g,interfaces:[lt]},Ni.prototype.readFrom=function(){return this.closure$body},Ni.$metadata$={kind:g,interfaces:[ut]},Pi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Pi.prototype=Object.create(_.prototype),Pi.prototype.constructor=Pi,Pi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n;if(null==this.local$$receiver.context.headers.get_61zpoe$(X.HttpHeaders.Accept)&&this.local$$receiver.context.headers.append_puj7f4$(X.HttpHeaders.Accept,"*/*"),"string"==typeof this.local$body){var i;null!=(t=this.local$$receiver.context.headers.get_61zpoe$(X.HttpHeaders.ContentType))?(this.local$$receiver.context.headers.remove_61zpoe$(X.HttpHeaders.ContentType),i=at.Companion.parse_61zpoe$(t)):i=null;var r=null!=(n=i)?n:at.Text.Plain;if(this.state_0=6,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new st(this.local$body,r),this),this.result_0===h)return h;continue}if(e.isByteArray(this.local$body)){if(this.state_0=4,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new Oi(this.local$body),this),this.result_0===h)return h;continue}if(e.isType(this.local$body,E)){if(this.state_0=2,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new Ni(this.local$body),this),this.result_0===h)return h;continue}this.state_0=3;continue;case 1:throw this.exception_0;case 2:return this.result_0;case 3:this.state_0=5;continue;case 4:return this.result_0;case 5:this.state_0=7;continue;case 6:return this.result_0;case 7:return u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ji.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ji.prototype=Object.create(_.prototype),ji.prototype.constructor=ji,ji.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=3,this.state_0=1,this.result_0=gt(this.local$closure$body,this.local$$receiver.channel,pt,this),this.result_0===h)return h;continue;case 1:this.exceptionState_0=10,this.finallyPath_0=[2],this.state_0=8,this.$returnValue=this.result_0;continue;case 2:return this.$returnValue;case 3:this.finallyPath_0=[10],this.exceptionState_0=8;var t=this.exception_0;if(e.isType(t,wt)){this.exceptionState_0=10,this.finallyPath_0=[6],this.state_0=8,this.$returnValue=(bt(this.local$closure$response,t),u);continue}if(e.isType(t,T)){this.exceptionState_0=10,this.finallyPath_0=[4],this.state_0=8,this.$returnValue=(S(this.local$closure$response,"Receive failed",t),u);continue}throw t;case 4:return this.$returnValue;case 5:this.state_0=7;continue;case 6:return this.$returnValue;case 7:this.finallyPath_0=[9],this.state_0=8;continue;case 8:this.exceptionState_0=10,ia(this.local$closure$response),this.state_0=this.finallyPath_0.shift();continue;case 9:return;case 10:throw this.exception_0;default:throw this.state_0=10,new Error("State Machine Unreachable execution")}}catch(t){if(10===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ri.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Ri.prototype=Object.create(_.prototype),Ri.prototype.constructor=Ri,Ri.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n,i;if(this.local$info=this.local$f.component1(),this.local$body=this.local$f.component2(),e.isType(this.local$body,E)){this.state_0=2;continue}return;case 1:throw this.exception_0;case 2:var r=this.local$$receiver.context.response,o=null!=(n=null!=(t=r.headers.get_61zpoe$(X.HttpHeaders.ContentLength))?ct(t):null)?n:pt;if(i=this.local$info.type,nt(i,B(Object.getPrototypeOf(_t.Unit).constructor))){if(ht(this.local$body),this.state_0=16,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,u),this),this.result_0===h)return h;continue}if(nt(i,dt)){if(this.state_0=13,this.result_0=F(this.local$body,this),this.result_0===h)return h;continue}if(nt(i,B(mt))||nt(i,B(yt))){if(this.state_0=10,this.result_0=F(this.local$body,this),this.result_0===h)return h;continue}if(nt(i,vt)){if(this.state_0=7,this.result_0=$t(this.local$body,o,this),this.result_0===h)return h;continue}if(nt(i,B(E))){var a=xt(this.local$$receiver,void 0,void 0,Li(this.local$body,r)).channel;if(this.state_0=5,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,a),this),this.result_0===h)return h;continue}if(nt(i,B(kt))){if(ht(this.local$body),this.state_0=3,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,r.status),this),this.result_0===h)return h;continue}this.state_0=4;continue;case 3:return this.result_0;case 4:this.state_0=6;continue;case 5:return this.result_0;case 6:this.state_0=9;continue;case 7:var s=this.result_0;if(this.state_0=8,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,q(s)),this),this.result_0===h)return h;continue;case 8:return this.result_0;case 9:this.state_0=12;continue;case 10:if(this.state_0=11,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,this.result_0),this),this.result_0===h)return h;continue;case 11:return this.result_0;case 12:this.state_0=15;continue;case 13:if(this.state_0=14,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,ft(this.result_0.readText_vux9f0$())),this),this.result_0===h)return h;continue;case 14:return this.result_0;case 15:this.state_0=17;continue;case 16:return this.result_0;case 17:return u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Mi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Mi.prototype=Object.create(_.prototype),Mi.prototype.constructor=Mi,Mi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$tmp$=this.$this.responseValidators_0.iterator(),this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(!this.local$tmp$.hasNext()){this.state_0=4;continue}var t=this.local$tmp$.next();if(this.state_0=3,this.result_0=t(this.local$response,this),this.result_0===h)return h;continue;case 3:this.state_0=2;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Di.prototype.validateResponse_0=function(t,e,n){var i=new Mi(this,t,e);return n?i:i.doResume(null)},Bi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Bi.prototype=Object.create(_.prototype),Bi.prototype.constructor=Bi,Bi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$tmp$=this.$this.callExceptionHandlers_0.iterator(),this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(!this.local$tmp$.hasNext()){this.state_0=4;continue}var t=this.local$tmp$.next();if(this.state_0=3,this.result_0=t(this.local$cause,this),this.result_0===h)return h;continue;case 3:this.state_0=2;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Di.prototype.processException_0=function(t,e,n){var i=new Bi(this,t,e);return n?i:i.doResume(null)},Ui.prototype.handleResponseException_9rdja$=function(t){this.responseExceptionHandlers_8be2vx$.add_11rb$(t)},Ui.prototype.validateResponse_d4bkoy$=function(t){this.responseValidators_8be2vx$.add_11rb$(t)},Ui.$metadata$={kind:g,simpleName:"Config",interfaces:[]},Object.defineProperty(Fi.prototype,"key",{get:function(){return this.key_uukd7r$_0}}),Fi.prototype.prepare_oh3mgy$$default=function(t){var e=new Ui;t(e);var n=e;return Et(n.responseValidators_8be2vx$),Et(n.responseExceptionHandlers_8be2vx$),new Di(n.responseValidators_8be2vx$,n.responseExceptionHandlers_8be2vx$)},qi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},qi.prototype=Object.create(_.prototype),qi.prototype.constructor=qi,qi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=2,this.state_0=1,this.result_0=this.local$$receiver.proceedWith_trkh7z$(this.local$it,this),this.result_0===h)return h;continue;case 1:return this.result_0;case 2:if(this.exceptionState_0=6,this.local$cause=this.exception_0,e.isType(this.local$cause,T)){if(this.state_0=3,this.result_0=this.local$closure$feature.processException_0(this.local$cause,this),this.result_0===h)return h;continue}throw this.local$cause;case 3:throw this.local$cause;case 4:this.state_0=5;continue;case 5:return;case 6:throw this.exception_0;default:throw this.state_0=6,new Error("State Machine Unreachable execution")}}catch(t){if(6===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Gi.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Gi.prototype=Object.create(_.prototype),Gi.prototype.constructor=Gi,Gi.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=3,this.state_0=1,this.result_0=this.local$closure$feature.validateResponse_0(this.local$$receiver.context.response,this),this.result_0===h)return h;continue;case 1:if(this.state_0=2,this.result_0=this.local$$receiver.proceedWith_trkh7z$(this.local$container,this),this.result_0===h)return h;continue;case 2:return this.result_0;case 3:if(this.exceptionState_0=7,this.local$cause=this.exception_0,e.isType(this.local$cause,T)){if(this.state_0=4,this.result_0=this.local$closure$feature.processException_0(this.local$cause,this),this.result_0===h)return h;continue}throw this.local$cause;case 4:throw this.local$cause;case 5:this.state_0=6;continue;case 6:return;case 7:throw this.exception_0;default:throw this.state_0=7,new Error("State Machine Unreachable execution")}}catch(t){if(7===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Fi.prototype.install_wojrb5$=function(t,e){var n,i=new Ct("BeforeReceive");e.responsePipeline.insertPhaseBefore_b9zzbm$(sa().Receive,i),e.requestPipeline.intercept_h71y74$(Mo().Before,(n=t,function(t,e,i,r){var o=new qi(n,t,e,this,i);return r?o:o.doResume(null)})),e.responsePipeline.intercept_h71y74$(i,function(t){return function(e,n,i,r){var o=new Gi(t,e,n,this,i);return r?o:o.doResume(null)}}(t))},Fi.$metadata$={kind:O,simpleName:"Companion",interfaces:[Wi]};var Hi,Yi=null;function Vi(){return null===Yi&&new Fi,Yi}function Ki(t,e){t.install_xlxg29$(Vi(),e)}function Wi(){}function Xi(t){return u}function Zi(t,e){var n;return null!=(n=t.attributes.getOrNull_yzaw86$(Hi))?n.getOrNull_yzaw86$(e.key):null}function Ji(t){this.closure$comparison=t}Di.$metadata$={kind:g,simpleName:"HttpCallValidator",interfaces:[]},Wi.prototype.prepare_oh3mgy$=function(t,e){return void 0===t&&(t=Xi),e?e(t):this.prepare_oh3mgy$$default(t)},Wi.$metadata$={kind:W,simpleName:"HttpClientFeature",interfaces:[]},Ji.prototype.compare=function(t,e){return this.closure$comparison(t,e)},Ji.$metadata$={kind:g,interfaces:[Ut]};var Qi=P((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(i),r(n))}}}));function tr(t){this.closure$comparison=t}tr.prototype.compare=function(t,e){return this.closure$comparison(t,e)},tr.$metadata$={kind:g,interfaces:[Ut]};var er=P((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function nr(t,e,n,i){var r,o,a;ur(),this.responseCharsetFallback_0=i,this.requestCharset_0=null,this.acceptCharsetHeader_0=null;var s,l=Bt(zt(e),new Ji(Qi(cr))),u=St();for(s=t.iterator();s.hasNext();){var c=s.next();e.containsKey_11rb$(c)||u.add_11rb$(c)}var p,h,_=Bt(u,new tr(er(pr))),f=Ft();for(p=_.iterator();p.hasNext();){var d=p.next();f.length>0&&f.append_gw00v9$(","),f.append_gw00v9$(Dt(d))}for(h=l.iterator();h.hasNext();){var m=h.next(),y=m.component1(),$=m.component2();if(f.length>0&&f.append_gw00v9$(","),!Ot(Tt(0,1),$))throw w("Check failed.".toString());var v=qt(100*$)/100;f.append_gw00v9$(Dt(y)+";q="+v)}0===f.length&&f.append_gw00v9$(Dt(this.responseCharsetFallback_0)),this.acceptCharsetHeader_0=f.toString(),this.requestCharset_0=null!=(a=null!=(o=null!=n?n:Mt(_))?o:null!=(r=Mt(l))?r.first:null)?a:Nt.Charsets.UTF_8}function ir(){this.charsets_8be2vx$=Gt(),this.charsetQuality_8be2vx$=k(),this.sendCharset=null,this.responseCharsetFallback=Nt.Charsets.UTF_8,this.defaultCharset=Nt.Charsets.UTF_8}function rr(){lr=this,this.key_wkh146$_0=new d("HttpPlainText")}function or(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$closure$feature=t,this.local$contentType=void 0,this.local$$receiver=e,this.local$content=n}function ar(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$closure$feature=t,this.local$info=void 0,this.local$body=void 0,this.local$tmp$_0=void 0,this.local$$receiver=e,this.local$f=n}ir.prototype.register_qv516$=function(t,e){if(void 0===e&&(e=null),null!=e&&!Ot(Tt(0,1),e))throw w("Check failed.".toString());this.charsets_8be2vx$.add_11rb$(t),null==e?this.charsetQuality_8be2vx$.remove_11rb$(t):this.charsetQuality_8be2vx$.put_xwzc9p$(t,e)},ir.$metadata$={kind:g,simpleName:"Config",interfaces:[]},Object.defineProperty(rr.prototype,"key",{get:function(){return this.key_wkh146$_0}}),rr.prototype.prepare_oh3mgy$$default=function(t){var e=new ir;t(e);var n=e;return new nr(n.charsets_8be2vx$,n.charsetQuality_8be2vx$,n.sendCharset,n.responseCharsetFallback)},or.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},or.prototype=Object.create(_.prototype),or.prototype.constructor=or,or.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$closure$feature.addCharsetHeaders_jc2hdt$(this.local$$receiver.context),"string"!=typeof this.local$content)return;this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$contentType=Pt(this.local$$receiver.context),null==this.local$contentType||nt(this.local$contentType.contentType,at.Text.Plain.contentType)){this.state_0=3;continue}return;case 3:var t=null!=this.local$contentType?At(this.local$contentType):null;if(this.state_0=4,this.result_0=this.local$$receiver.proceedWith_trkh7z$(this.local$closure$feature.wrapContent_0(this.local$content,t),this),this.result_0===h)return h;continue;case 4:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ar.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ar.prototype=Object.create(_.prototype),ar.prototype.constructor=ar,ar.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n;if(this.local$info=this.local$f.component1(),this.local$body=this.local$f.component2(),null!=(t=this.local$info.type)&&t.equals(jt)&&e.isType(this.local$body,E)){this.state_0=2;continue}return;case 1:throw this.exception_0;case 2:if(this.local$tmp$_0=this.local$$receiver.context,this.state_0=3,this.result_0=F(this.local$body,this),this.result_0===h)return h;continue;case 3:n=this.result_0;var i=this.local$closure$feature.read_r18uy3$(this.local$tmp$_0,n);if(this.state_0=4,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,i),this),this.result_0===h)return h;continue;case 4:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},rr.prototype.install_wojrb5$=function(t,e){var n;e.requestPipeline.intercept_h71y74$(Mo().Render,(n=t,function(t,e,i,r){var o=new or(n,t,e,this,i);return r?o:o.doResume(null)})),e.responsePipeline.intercept_h71y74$(sa().Parse,function(t){return function(e,n,i,r){var o=new ar(t,e,n,this,i);return r?o:o.doResume(null)}}(t))},rr.$metadata$={kind:O,simpleName:"Feature",interfaces:[Wi]};var sr,lr=null;function ur(){return null===lr&&new rr,lr}function cr(t){return t.second}function pr(t){return Dt(t)}function hr(){yr(),this.checkHttpMethod=!0,this.allowHttpsDowngrade=!1}function _r(){mr=this,this.key_oxn36d$_0=new d("HttpRedirect")}function fr(t,e,n,i,r,o,a){_.call(this,a),this.$controller=o,this.exceptionState_0=1,this.local$closure$feature=t,this.local$this$HttpRedirect$=e,this.local$$receiver=n,this.local$origin=i,this.local$context=r}function dr(t,e,n,i,r,o){_.call(this,o),this.exceptionState_0=1,this.$this=t,this.local$call=void 0,this.local$originProtocol=void 0,this.local$originAuthority=void 0,this.local$$receiver=void 0,this.local$$receiver_0=e,this.local$context=n,this.local$origin=i,this.local$allowHttpsDowngrade=r}nr.prototype.wrapContent_0=function(t,e){var n=null!=e?e:this.requestCharset_0;return new st(t,Lt(at.Text.Plain,n))},nr.prototype.read_r18uy3$=function(t,e){var n,i=null!=(n=Rt(t.response))?n:this.responseCharsetFallback_0;return It(e,i)},nr.prototype.addCharsetHeaders_jc2hdt$=function(t){null==t.headers.get_61zpoe$(X.HttpHeaders.AcceptCharset)&&t.headers.set_puj7f4$(X.HttpHeaders.AcceptCharset,this.acceptCharsetHeader_0)},Object.defineProperty(nr.prototype,"defaultCharset",{get:function(){throw w("defaultCharset is deprecated".toString())},set:function(t){throw w("defaultCharset is deprecated".toString())}}),nr.$metadata$={kind:g,simpleName:"HttpPlainText",interfaces:[]},Object.defineProperty(_r.prototype,"key",{get:function(){return this.key_oxn36d$_0}}),_r.prototype.prepare_oh3mgy$$default=function(t){var e=new hr;return t(e),e},fr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},fr.prototype=Object.create(_.prototype),fr.prototype.constructor=fr,fr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$closure$feature.checkHttpMethod&&!sr.contains_11rb$(this.local$origin.request.method))return this.local$origin;this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.local$this$HttpRedirect$.handleCall_0(this.local$$receiver,this.local$context,this.local$origin,this.local$closure$feature.allowHttpsDowngrade,this),this.result_0===h)return h;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},_r.prototype.install_wojrb5$=function(t,e){var n,i;p(Zi(e,Pr())).intercept_vsqnz3$((n=t,i=this,function(t,e,r,o,a){var s=new fr(n,i,t,e,r,this,o);return a?s:s.doResume(null)}))},dr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},dr.prototype=Object.create(_.prototype),dr.prototype.constructor=dr,dr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if($r(this.local$origin.response.status)){this.state_0=2;continue}return this.local$origin;case 1:throw this.exception_0;case 2:this.local$call={v:this.local$origin},this.local$originProtocol=this.local$origin.request.url.protocol,this.local$originAuthority=Vt(this.local$origin.request.url),this.state_0=3;continue;case 3:var t=this.local$call.v.response.headers.get_61zpoe$(X.HttpHeaders.Location);if(this.local$$receiver=new Co,this.local$$receiver.takeFrom_s9rlw$(this.local$context),this.local$$receiver.url.parameters.clear(),null!=t&&Kt(this.local$$receiver.url,t),this.local$allowHttpsDowngrade||!Wt(this.local$originProtocol)||Wt(this.local$$receiver.url.protocol)){this.state_0=4;continue}return this.local$call.v;case 4:nt(this.local$originAuthority,Xt(this.local$$receiver.url))||this.local$$receiver.headers.remove_61zpoe$(X.HttpHeaders.Authorization);var e=this.local$$receiver;if(this.state_0=5,this.result_0=this.local$$receiver_0.execute_s9rlw$(e,this),this.result_0===h)return h;continue;case 5:if(this.local$call.v=this.result_0,$r(this.local$call.v.response.status)){this.state_0=6;continue}return this.local$call.v;case 6:this.state_0=3;continue;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},_r.prototype.handleCall_0=function(t,e,n,i,r,o){var a=new dr(this,t,e,n,i,r);return o?a:a.doResume(null)},_r.$metadata$={kind:O,simpleName:"Feature",interfaces:[Wi]};var mr=null;function yr(){return null===mr&&new _r,mr}function $r(t){var e;return(e=t.value)===kt.Companion.MovedPermanently.value||e===kt.Companion.Found.value||e===kt.Companion.TemporaryRedirect.value||e===kt.Companion.PermanentRedirect.value}function vr(){kr()}function gr(){xr=this,this.key_livr7a$_0=new d("RequestLifecycle")}function br(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=6,this.local$executionContext=void 0,this.local$$receiver=t}function wr(t,e,n,i){var r=new br(t,e,this,n);return i?r:r.doResume(null)}hr.$metadata$={kind:g,simpleName:"HttpRedirect",interfaces:[]},Object.defineProperty(gr.prototype,"key",{get:function(){return this.key_livr7a$_0}}),gr.prototype.prepare_oh3mgy$$default=function(t){return new vr},br.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},br.prototype=Object.create(_.prototype),br.prototype.constructor=br,br.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$executionContext=$(this.local$$receiver.context.executionContext),n=this.local$$receiver,i=this.local$executionContext,r=void 0,r=i.invokeOnCompletion_f05bi3$(function(t){return function(n){var i;return null!=n?Zt(t.context.executionContext,"Engine failed",n):(e.isType(i=t.context.executionContext.get_j3r2sn$(c.Key),y)?i:f()).complete(),u}}(n)),p(n.context.executionContext.get_j3r2sn$(c.Key)).invokeOnCompletion_f05bi3$(function(t){return function(e){return t.dispose(),u}}(r)),this.exceptionState_0=3,this.local$$receiver.context.executionContext=this.local$executionContext,this.state_0=1,this.result_0=this.local$$receiver.proceed(this),this.result_0===h)return h;continue;case 1:this.exceptionState_0=6,this.finallyPath_0=[2],this.state_0=4,this.$returnValue=this.result_0;continue;case 2:return this.$returnValue;case 3:this.finallyPath_0=[6],this.exceptionState_0=4;var t=this.exception_0;throw e.isType(t,T)?(this.local$executionContext.completeExceptionally_tcv7n7$(t),t):t;case 4:this.exceptionState_0=6,this.local$executionContext.complete(),this.state_0=this.finallyPath_0.shift();continue;case 5:return;case 6:throw this.exception_0;default:throw this.state_0=6,new Error("State Machine Unreachable execution")}}catch(t){if(6===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}var n,i,r},gr.prototype.install_wojrb5$=function(t,e){e.requestPipeline.intercept_h71y74$(Mo().Before,wr)},gr.$metadata$={kind:O,simpleName:"Feature",interfaces:[Wi]};var xr=null;function kr(){return null===xr&&new gr,xr}function Er(){}function Cr(t){Pr(),void 0===t&&(t=20),this.maxSendCount=t,this.interceptors_0=St()}function Sr(t,e,n,i,r,o){_.call(this,o),this.$controller=r,this.exceptionState_0=1,this.local$closure$block=t,this.local$$receiver=e,this.local$call=n}function Tr(){Nr=this,this.key_x494tl$_0=new d("HttpSend")}function Or(t,e,n,i,r,o){_.call(this,o),this.$controller=r,this.exceptionState_0=1,this.local$closure$feature=t,this.local$closure$scope=e,this.local$tmp$=void 0,this.local$sender=void 0,this.local$currentCall=void 0,this.local$callChanged=void 0,this.local$transformed=void 0,this.local$$receiver=n,this.local$content=i}vr.$metadata$={kind:g,simpleName:"HttpRequestLifecycle",interfaces:[]},Er.$metadata$={kind:W,simpleName:"Sender",interfaces:[]},Cr.prototype.intercept_vsqnz3$=function(t){this.interceptors_0.add_11rb$(t)},Sr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Sr.prototype=Object.create(_.prototype),Sr.prototype.constructor=Sr,Sr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$closure$block(this.local$$receiver,this.local$call,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Cr.prototype.intercept_efqc3v$=function(t){var e;this.interceptors_0.add_11rb$((e=t,function(t,n,i,r,o){var a=new Sr(e,t,n,i,this,r);return o?a:a.doResume(null)}))},Object.defineProperty(Tr.prototype,"key",{get:function(){return this.key_x494tl$_0}}),Tr.prototype.prepare_oh3mgy$$default=function(t){var e=new Cr;return t(e),e},Or.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Or.prototype=Object.create(_.prototype),Or.prototype.constructor=Or,Or.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(!e.isType(this.local$content,Jt)){var t="Fail to send body. Content has type: "+e.getKClassFromExpression(this.local$content)+", but OutgoingContent expected.";throw w(t.toString())}if(this.local$$receiver.context.body=this.local$content,this.local$sender=new Ar(this.local$closure$feature.maxSendCount,this.local$closure$scope),this.state_0=2,this.result_0=this.local$sender.execute_s9rlw$(this.local$$receiver.context,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:this.local$currentCall=this.result_0,this.state_0=3;continue;case 3:this.local$callChanged=!1,this.local$tmp$=this.local$closure$feature.interceptors_0.iterator(),this.state_0=4;continue;case 4:if(!this.local$tmp$.hasNext()){this.state_0=7;continue}var n=this.local$tmp$.next();if(this.state_0=5,this.result_0=n(this.local$sender,this.local$currentCall,this.local$$receiver.context,this),this.result_0===h)return h;continue;case 5:if(this.local$transformed=this.result_0,this.local$transformed===this.local$currentCall){this.state_0=4;continue}this.state_0=6;continue;case 6:this.local$currentCall=this.local$transformed,this.local$callChanged=!0,this.state_0=7;continue;case 7:if(!this.local$callChanged){this.state_0=8;continue}this.state_0=3;continue;case 8:if(this.state_0=9,this.result_0=this.local$$receiver.proceedWith_trkh7z$(this.local$currentCall,this),this.result_0===h)return h;continue;case 9:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Tr.prototype.install_wojrb5$=function(t,e){var n,i;e.requestPipeline.intercept_h71y74$(Mo().Send,(n=t,i=e,function(t,e,r,o){var a=new Or(n,i,t,e,this,r);return o?a:a.doResume(null)}))},Tr.$metadata$={kind:O,simpleName:"Feature",interfaces:[Wi]};var Nr=null;function Pr(){return null===Nr&&new Tr,Nr}function Ar(t,e){this.maxSendCount_0=t,this.client_0=e,this.sentCount_0=0,this.currentCall_0=null}function jr(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$requestBuilder=e}function Lr(t){w(t,this),this.name="SendCountExceedException"}function Rr(t,e,n){Kr(),this.requestTimeoutMillis_0=t,this.connectTimeoutMillis_0=e,this.socketTimeoutMillis_0=n}function Ir(){Mr(),this.requestTimeoutMillis_9n7r3q$_0=null,this.connectTimeoutMillis_v2k54f$_0=null,this.socketTimeoutMillis_tzgsjy$_0=null}function zr(){Dr=this,this.key=new d("TimeoutConfiguration")}jr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},jr.prototype=Object.create(_.prototype),jr.prototype.constructor=jr,jr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n,i;if(null!=(t=this.$this.currentCall_0)&&bt(t),this.$this.sentCount_0>=this.$this.maxSendCount_0)throw new Lr("Max send count "+this.$this.maxSendCount_0+" exceeded");if(this.$this.sentCount_0=this.$this.sentCount_0+1|0,this.state_0=2,this.result_0=this.$this.client_0.sendPipeline.execute_8pmvt0$(this.local$requestBuilder,this.local$requestBuilder.body,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:var r=this.result_0;if(null==(i=e.isType(n=r,Cn)?n:null))throw w(("Failed to execute send pipeline. Expected to got [HttpClientCall], but received "+r.toString()).toString());var o=i;return this.$this.currentCall_0=o,o;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ar.prototype.execute_s9rlw$=function(t,e,n){var i=new jr(this,t,e);return n?i:i.doResume(null)},Ar.$metadata$={kind:g,simpleName:"DefaultSender",interfaces:[Er]},Cr.$metadata$={kind:g,simpleName:"HttpSend",interfaces:[]},Lr.$metadata$={kind:g,simpleName:"SendCountExceedException",interfaces:[j]},Object.defineProperty(Ir.prototype,"requestTimeoutMillis",{get:function(){return this.requestTimeoutMillis_9n7r3q$_0},set:function(t){this.requestTimeoutMillis_9n7r3q$_0=this.checkTimeoutValue_0(t)}}),Object.defineProperty(Ir.prototype,"connectTimeoutMillis",{get:function(){return this.connectTimeoutMillis_v2k54f$_0},set:function(t){this.connectTimeoutMillis_v2k54f$_0=this.checkTimeoutValue_0(t)}}),Object.defineProperty(Ir.prototype,"socketTimeoutMillis",{get:function(){return this.socketTimeoutMillis_tzgsjy$_0},set:function(t){this.socketTimeoutMillis_tzgsjy$_0=this.checkTimeoutValue_0(t)}}),Ir.prototype.build_8be2vx$=function(){return new Rr(this.requestTimeoutMillis,this.connectTimeoutMillis,this.socketTimeoutMillis)},Ir.prototype.checkTimeoutValue_0=function(t){if(!(null==t||t.toNumber()>0))throw G("Only positive timeout values are allowed, for infinite timeout use HttpTimeout.INFINITE_TIMEOUT_MS".toString());return t},zr.$metadata$={kind:O,simpleName:"Companion",interfaces:[]};var Dr=null;function Mr(){return null===Dr&&new zr,Dr}function Br(t,e,n,i){return void 0===t&&(t=null),void 0===e&&(e=null),void 0===n&&(n=null),i=i||Object.create(Ir.prototype),Ir.call(i),i.requestTimeoutMillis=t,i.connectTimeoutMillis=e,i.socketTimeoutMillis=n,i}function Ur(){Vr=this,this.key_g1vqj4$_0=new d("TimeoutFeature"),this.INFINITE_TIMEOUT_MS=pt}function Fr(t,e,n,i,r,o){_.call(this,o),this.$controller=r,this.exceptionState_0=1,this.local$closure$requestTimeout=t,this.local$closure$executionContext=e,this.local$this$=n}function qr(t,e,n){return function(i,r,o){var a=new Fr(t,e,n,i,this,r);return o?a:a.doResume(null)}}function Gr(t){return function(e){return t.cancel_m4sck1$(),u}}function Hr(t,e,n,i,r,o,a){_.call(this,a),this.$controller=o,this.exceptionState_0=1,this.local$closure$feature=t,this.local$this$HttpTimeout$=e,this.local$closure$scope=n,this.local$$receiver=i}Ir.$metadata$={kind:g,simpleName:"HttpTimeoutCapabilityConfiguration",interfaces:[]},Rr.prototype.hasNotNullTimeouts_0=function(){return null!=this.requestTimeoutMillis_0||null!=this.connectTimeoutMillis_0||null!=this.socketTimeoutMillis_0},Object.defineProperty(Ur.prototype,"key",{get:function(){return this.key_g1vqj4$_0}}),Ur.prototype.prepare_oh3mgy$$default=function(t){var e=Br();return t(e),e.build_8be2vx$()},Fr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Fr.prototype=Object.create(_.prototype),Fr.prototype.constructor=Fr,Fr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=Qt(this.local$closure$requestTimeout,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.local$closure$executionContext.cancel_m4sck1$(new Wr(this.local$this$.context)),u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Hr.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Hr.prototype=Object.create(_.prototype),Hr.prototype.constructor=Hr,Hr.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,e=this.local$$receiver.context.getCapabilityOrNull_i25mbv$(Kr());if(null==e&&this.local$closure$feature.hasNotNullTimeouts_0()&&(e=Br(),this.local$$receiver.context.setCapability_wfl2px$(Kr(),e)),null!=e){var n=e,i=this.local$closure$feature,r=this.local$this$HttpTimeout$,o=this.local$closure$scope;t:do{var a,s,l,u;n.connectTimeoutMillis=null!=(a=n.connectTimeoutMillis)?a:i.connectTimeoutMillis_0,n.socketTimeoutMillis=null!=(s=n.socketTimeoutMillis)?s:i.socketTimeoutMillis_0,n.requestTimeoutMillis=null!=(l=n.requestTimeoutMillis)?l:i.requestTimeoutMillis_0;var c=null!=(u=n.requestTimeoutMillis)?u:i.requestTimeoutMillis_0;if(null==c||nt(c,r.INFINITE_TIMEOUT_MS))break t;var p=this.local$$receiver.context.executionContext,h=te(o,void 0,void 0,qr(c,p,this.local$$receiver));this.local$$receiver.context.executionContext.invokeOnCompletion_f05bi3$(Gr(h))}while(0);t=n}else t=null;return t;case 1:throw this.exception_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ur.prototype.install_wojrb5$=function(t,e){var n,i,r;e.requestPipeline.intercept_h71y74$(Mo().Before,(n=t,i=this,r=e,function(t,e,o,a){var s=new Hr(n,i,r,t,e,this,o);return a?s:s.doResume(null)}))},Ur.$metadata$={kind:O,simpleName:"Feature",interfaces:[hi,Wi]};var Yr,Vr=null;function Kr(){return null===Vr&&new Ur,Vr}function Wr(t){var e,n;J("Request timeout has been expired [url="+t.url.buildString()+", request_timeout="+(null!=(n=null!=(e=t.getCapabilityOrNull_i25mbv$(Kr()))?e.requestTimeoutMillis:null)?n:"unknown").toString()+" ms]",this),this.name="HttpRequestTimeoutException"}function Xr(){}function Zr(t,e){this.call_e1jkgq$_0=t,this.$delegate_wwo9g4$_0=e}function Jr(t,e){this.call_8myheh$_0=t,this.$delegate_46xi97$_0=e}function Qr(){bo.call(this);var t=Ft(),e=pe(16);t.append_gw00v9$(he(e)),this.nonce_0=t.toString();var n=new re;n.append_puj7f4$(X.HttpHeaders.Upgrade,"websocket"),n.append_puj7f4$(X.HttpHeaders.Connection,"upgrade"),n.append_puj7f4$(X.HttpHeaders.SecWebSocketKey,this.nonce_0),n.append_puj7f4$(X.HttpHeaders.SecWebSocketVersion,Yr),this.headers_mq8s01$_0=n.build()}function to(t,e){ao(),void 0===t&&(t=de),void 0===e&&(e=me),this.pingInterval=t,this.maxFrameSize=e}function eo(){oo=this,this.key_9eo0u2$_0=new d("Websocket")}function no(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$$receiver=t}function io(t,e,n,i){var r=new no(t,e,this,n);return i?r:r.doResume(null)}function ro(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$closure$feature=t,this.local$info=void 0,this.local$session=void 0,this.local$$receiver=e,this.local$f=n}Rr.$metadata$={kind:g,simpleName:"HttpTimeout",interfaces:[]},Wr.$metadata$={kind:g,simpleName:"HttpRequestTimeoutException",interfaces:[wt]},Xr.$metadata$={kind:W,simpleName:"ClientWebSocketSession",interfaces:[le]},Object.defineProperty(Zr.prototype,"call",{get:function(){return this.call_e1jkgq$_0}}),Object.defineProperty(Zr.prototype,"closeReason",{get:function(){return this.$delegate_wwo9g4$_0.closeReason}}),Object.defineProperty(Zr.prototype,"coroutineContext",{get:function(){return this.$delegate_wwo9g4$_0.coroutineContext}}),Object.defineProperty(Zr.prototype,"incoming",{get:function(){return this.$delegate_wwo9g4$_0.incoming}}),Object.defineProperty(Zr.prototype,"outgoing",{get:function(){return this.$delegate_wwo9g4$_0.outgoing}}),Zr.prototype.flush=function(t){return this.$delegate_wwo9g4$_0.flush(t)},Zr.prototype.send_x9o3m3$=function(t,e){return this.$delegate_wwo9g4$_0.send_x9o3m3$(t,e)},Zr.prototype.terminate=function(){return this.$delegate_wwo9g4$_0.terminate()},Zr.$metadata$={kind:g,simpleName:"DefaultClientWebSocketSession",interfaces:[ue,Xr]},Object.defineProperty(Jr.prototype,"call",{get:function(){return this.call_8myheh$_0}}),Object.defineProperty(Jr.prototype,"coroutineContext",{get:function(){return this.$delegate_46xi97$_0.coroutineContext}}),Object.defineProperty(Jr.prototype,"incoming",{get:function(){return this.$delegate_46xi97$_0.incoming}}),Object.defineProperty(Jr.prototype,"outgoing",{get:function(){return this.$delegate_46xi97$_0.outgoing}}),Jr.prototype.flush=function(t){return this.$delegate_46xi97$_0.flush(t)},Jr.prototype.send_x9o3m3$=function(t,e){return this.$delegate_46xi97$_0.send_x9o3m3$(t,e)},Jr.prototype.terminate=function(){return this.$delegate_46xi97$_0.terminate()},Jr.$metadata$={kind:g,simpleName:"DelegatingClientWebSocketSession",interfaces:[Xr,le]},Object.defineProperty(Qr.prototype,"headers",{get:function(){return this.headers_mq8s01$_0}}),Qr.prototype.verify_fkh4uy$=function(t){var e;if(null==(e=t.get_61zpoe$(X.HttpHeaders.SecWebSocketAccept)))throw w("Server should specify header Sec-WebSocket-Accept".toString());var n=e,i=ce(this.nonce_0);if(!nt(i,n))throw w(("Failed to verify server accept header. Expected: "+i+", received: "+n).toString())},Qr.prototype.toString=function(){return"WebSocketContent"},Qr.$metadata$={kind:g,simpleName:"WebSocketContent",interfaces:[bo]},Object.defineProperty(eo.prototype,"key",{get:function(){return this.key_9eo0u2$_0}}),eo.prototype.prepare_oh3mgy$$default=function(t){return new to},no.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},no.prototype=Object.create(_.prototype),no.prototype.constructor=no,no.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(_e(this.local$$receiver.context.url.protocol)){this.state_0=2;continue}return;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new Qr,this),this.result_0===h)return h;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ro.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ro.prototype=Object.create(_.prototype),ro.prototype.constructor=ro,ro.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.local$info=this.local$f.component1(),this.local$session=this.local$f.component2(),e.isType(this.local$session,le)){this.state_0=2;continue}return;case 1:throw this.exception_0;case 2:if(null!=(t=this.local$info.type)&&t.equals(B(Zr))){var n=this.local$closure$feature,i=new Zr(this.local$$receiver.context,n.asDefault_0(this.local$session));if(this.state_0=3,this.result_0=this.local$$receiver.proceedWith_trkh7z$(new fa(this.local$info,i),this),this.result_0===h)return h;continue}this.state_0=4;continue;case 3:return;case 4:var r=new fa(this.local$info,new Jr(this.local$$receiver.context,this.local$session));if(this.state_0=5,this.result_0=this.local$$receiver.proceedWith_trkh7z$(r,this),this.result_0===h)return h;continue;case 5:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},eo.prototype.install_wojrb5$=function(t,e){var n;e.requestPipeline.intercept_h71y74$(Mo().Render,io),e.responsePipeline.intercept_h71y74$(sa().Transform,(n=t,function(t,e,i,r){var o=new ro(n,t,e,this,i);return r?o:o.doResume(null)}))},eo.$metadata$={kind:O,simpleName:"Feature",interfaces:[Wi]};var oo=null;function ao(){return null===oo&&new eo,oo}function so(t){w(t,this),this.name="WebSocketException"}function lo(t,e){return t.protocol=ye.Companion.WS,t.port=t.protocol.defaultPort,u}function uo(t,e,n){_.call(this,n),this.exceptionState_0=7,this.local$closure$block=t,this.local$it=e}function co(t){return function(e,n,i){var r=new uo(t,e,n);return i?r:r.doResume(null)}}function po(t,e,n,i){_.call(this,i),this.exceptionState_0=16,this.local$response=void 0,this.local$session=void 0,this.local$response_0=void 0,this.local$$receiver=t,this.local$request=e,this.local$block=n}function ho(t,e,n,i,r){var o=new po(t,e,n,i);return r?o:o.doResume(null)}function _o(t){return u}function fo(t,e,n,i,r){return function(o){return o.method=t,Lo(o,"ws",e,n,i),r(o),u}}function mo(t,e,n,i,r,o,a,s){_.call(this,s),this.exceptionState_0=1,this.local$$receiver=t,this.local$method=e,this.local$host=n,this.local$port=i,this.local$path=r,this.local$request=o,this.local$block=a}function yo(t,e,n,i,r,o,a,s,l){var u=new mo(t,e,n,i,r,o,a,s);return l?u:u.doResume(null)}function $o(t){return u}function vo(t,e){return function(n){return n.url.protocol=ye.Companion.WS,n.url.port=Qo(n),Kt(n.url,t),e(n),u}}function go(t,e,n,i,r){_.call(this,r),this.exceptionState_0=1,this.local$$receiver=t,this.local$urlString=e,this.local$request=n,this.local$block=i}function bo(){ne.call(this),this.content_1mwwgv$_xt2h6t$_0=tt(xo)}function wo(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$output=e}function xo(){return be()}function ko(t,e){this.call_bo7spw$_0=t,this.method_c5x7eh$_0=e.method,this.url_9j6cnp$_0=e.url,this.content_jw4yw1$_0=e.body,this.headers_atwsac$_0=e.headers,this.attributes_el41s3$_0=e.attributes}function Eo(){}function Co(){No(),this.url=new ae,this.method=Ht.Companion.Get,this.headers_nor9ye$_0=new re,this.body=Ea(),this.executionContext_h6ms6p$_0=$(),this.attributes=v(!0)}function So(){return k()}function To(){Oo=this}to.prototype.asDefault_0=function(t){return e.isType(t,ue)?t:fe(t,this.pingInterval,this.maxFrameSize)},to.$metadata$={kind:g,simpleName:"WebSockets",interfaces:[]},so.$metadata$={kind:g,simpleName:"WebSocketException",interfaces:[j]},uo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},uo.prototype=Object.create(_.prototype),uo.prototype.constructor=uo,uo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=4,this.state_0=1,this.result_0=this.local$closure$block(this.local$it,this),this.result_0===h)return h;continue;case 1:this.exceptionState_0=7,this.finallyPath_0=[2],this.state_0=5,this.$returnValue=this.result_0;continue;case 2:return this.$returnValue;case 3:return;case 4:this.finallyPath_0=[7],this.state_0=5;continue;case 5:if(this.exceptionState_0=7,this.state_0=6,this.result_0=ve(this.local$it,void 0,this),this.result_0===h)return h;continue;case 6:this.state_0=this.finallyPath_0.shift();continue;case 7:throw this.exception_0;default:throw this.state_0=7,new Error("State Machine Unreachable execution")}}catch(t){if(7===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},po.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},po.prototype=Object.create(_.prototype),po.prototype.constructor=po,po.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=new Co;t.url_6yzzjr$(lo),this.local$request(t);var n,i,r,o=new da(t,this.local$$receiver);if(n=B(da),nt(n,B(da))){this.result_0=e.isType(i=o,da)?i:f(),this.state_0=8;continue}if(nt(n,B(ea))){if(this.state_0=6,this.result_0=o.execute(this),this.result_0===h)return h;continue}if(this.state_0=1,this.result_0=o.executeUnsafe(this),this.result_0===h)return h;continue;case 1:var a;this.local$response=this.result_0,this.exceptionState_0=4;var s,l=this.local$response.call;t:do{try{s=new Yn(B(da),js.JsType,$e(B(da),[],!1))}catch(t){s=new Yn(B(da),js.JsType);break t}}while(0);if(this.state_0=2,this.result_0=l.receive_jo9acv$(s,this),this.result_0===h)return h;continue;case 2:this.result_0=e.isType(a=this.result_0,da)?a:f(),this.exceptionState_0=16,this.finallyPath_0=[3],this.state_0=5;continue;case 3:this.state_0=7;continue;case 4:this.finallyPath_0=[16],this.state_0=5;continue;case 5:this.exceptionState_0=16,ia(this.local$response),this.state_0=this.finallyPath_0.shift();continue;case 6:this.result_0=e.isType(r=this.result_0,da)?r:f(),this.state_0=7;continue;case 7:this.state_0=8;continue;case 8:if(this.local$session=this.result_0,this.state_0=9,this.result_0=this.local$session.executeUnsafe(this),this.result_0===h)return h;continue;case 9:var u;this.local$response_0=this.result_0,this.exceptionState_0=13;var c,p=this.local$response_0.call;t:do{try{c=new Yn(B(Zr),js.JsType,$e(B(Zr),[],!1))}catch(t){c=new Yn(B(Zr),js.JsType);break t}}while(0);if(this.state_0=10,this.result_0=p.receive_jo9acv$(c,this),this.result_0===h)return h;continue;case 10:this.result_0=e.isType(u=this.result_0,Zr)?u:f();var _=this.result_0;if(this.state_0=11,this.result_0=co(this.local$block)(_,this),this.result_0===h)return h;continue;case 11:this.exceptionState_0=16,this.finallyPath_0=[12],this.state_0=14;continue;case 12:return;case 13:this.finallyPath_0=[16],this.state_0=14;continue;case 14:if(this.exceptionState_0=16,this.state_0=15,this.result_0=this.local$session.cleanup_abn2de$(this.local$response_0,this),this.result_0===h)return h;continue;case 15:this.state_0=this.finallyPath_0.shift();continue;case 16:throw this.exception_0;default:throw this.state_0=16,new Error("State Machine Unreachable execution")}}catch(t){if(16===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},mo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},mo.prototype=Object.create(_.prototype),mo.prototype.constructor=mo,mo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(void 0===this.local$method&&(this.local$method=Ht.Companion.Get),void 0===this.local$host&&(this.local$host="localhost"),void 0===this.local$port&&(this.local$port=0),void 0===this.local$path&&(this.local$path="/"),void 0===this.local$request&&(this.local$request=_o),this.state_0=2,this.result_0=ho(this.local$$receiver,fo(this.local$method,this.local$host,this.local$port,this.local$path,this.local$request),this.local$block,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},go.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},go.prototype=Object.create(_.prototype),go.prototype.constructor=go,go.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(void 0===this.local$request&&(this.local$request=$o),this.state_0=2,this.result_0=yo(this.local$$receiver,Ht.Companion.Get,"localhost",0,"/",vo(this.local$urlString,this.local$request),this.local$block,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(bo.prototype,"content_1mwwgv$_0",{get:function(){return this.content_1mwwgv$_xt2h6t$_0.value}}),Object.defineProperty(bo.prototype,"output",{get:function(){return this.content_1mwwgv$_0}}),wo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},wo.prototype=Object.create(_.prototype),wo.prototype.constructor=wo,wo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=ge(this.$this.content_1mwwgv$_0,this.local$output,void 0,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},bo.prototype.pipeTo_h3x4ir$=function(t,e,n){var i=new wo(this,t,e);return n?i:i.doResume(null)},bo.$metadata$={kind:g,simpleName:"ClientUpgradeContent",interfaces:[ne]},Object.defineProperty(ko.prototype,"call",{get:function(){return this.call_bo7spw$_0}}),Object.defineProperty(ko.prototype,"coroutineContext",{get:function(){return this.call.coroutineContext}}),Object.defineProperty(ko.prototype,"method",{get:function(){return this.method_c5x7eh$_0}}),Object.defineProperty(ko.prototype,"url",{get:function(){return this.url_9j6cnp$_0}}),Object.defineProperty(ko.prototype,"content",{get:function(){return this.content_jw4yw1$_0}}),Object.defineProperty(ko.prototype,"headers",{get:function(){return this.headers_atwsac$_0}}),Object.defineProperty(ko.prototype,"attributes",{get:function(){return this.attributes_el41s3$_0}}),ko.$metadata$={kind:g,simpleName:"DefaultHttpRequest",interfaces:[Eo]},Object.defineProperty(Eo.prototype,"coroutineContext",{get:function(){return this.call.coroutineContext}}),Object.defineProperty(Eo.prototype,"executionContext",{get:function(){return p(this.coroutineContext.get_j3r2sn$(c.Key))}}),Eo.$metadata$={kind:W,simpleName:"HttpRequest",interfaces:[b,we]},Object.defineProperty(Co.prototype,"headers",{get:function(){return this.headers_nor9ye$_0}}),Object.defineProperty(Co.prototype,"executionContext",{get:function(){return this.executionContext_h6ms6p$_0},set:function(t){this.executionContext_h6ms6p$_0=t}}),Co.prototype.url_6yzzjr$=function(t){t(this.url,this.url)},Co.prototype.build=function(){var t,n,i,r,o;if(t=this.url.build(),n=this.method,i=this.headers.build(),null==(o=e.isType(r=this.body,Jt)?r:null))throw w(("No request transformation found: "+this.body.toString()).toString());return new Po(t,n,i,o,this.executionContext,this.attributes)},Co.prototype.setAttributes_yhh5ns$=function(t){t(this.attributes)},Co.prototype.takeFrom_s9rlw$=function(t){var n;for(this.executionContext=t.executionContext,this.method=t.method,this.body=t.body,xe(this.url,t.url),this.url.encodedPath=oe(this.url.encodedPath)?"/":this.url.encodedPath,ke(this.headers,t.headers),n=t.attributes.allKeys.iterator();n.hasNext();){var i,r=n.next();this.attributes.put_uuntuo$(e.isType(i=r,d)?i:f(),t.attributes.get_yzaw86$(r))}return this},Co.prototype.setCapability_wfl2px$=function(t,e){this.attributes.computeIfAbsent_u4q9l2$(Nn,So).put_xwzc9p$(t,e)},Co.prototype.getCapabilityOrNull_i25mbv$=function(t){var n,i;return null==(i=null!=(n=this.attributes.getOrNull_yzaw86$(Nn))?n.get_11rb$(t):null)||e.isType(i,x)?i:f()},To.$metadata$={kind:O,simpleName:"Companion",interfaces:[]};var Oo=null;function No(){return null===Oo&&new To,Oo}function Po(t,e,n,i,r,o){var a,s;this.url=t,this.method=e,this.headers=n,this.body=i,this.executionContext=r,this.attributes=o,this.requiredCapabilities_8be2vx$=null!=(s=null!=(a=this.attributes.getOrNull_yzaw86$(Nn))?a.keys:null)?s:V()}function Ao(t,e,n,i,r,o){this.statusCode=t,this.requestTime=e,this.headers=n,this.version=i,this.body=r,this.callContext=o,this.responseTime=ie()}function jo(t){return u}function Lo(t,e,n,i,r,o){void 0===e&&(e="http"),void 0===n&&(n="localhost"),void 0===i&&(i=0),void 0===r&&(r="/"),void 0===o&&(o=jo);var a=t.url;a.protocol=ye.Companion.createOrDefault_61zpoe$(e),a.host=n,a.port=i,a.encodedPath=r,o(t.url)}function Ro(t){return e.isType(t.body,bo)}function Io(){Mo(),Se.call(this,[Mo().Before,Mo().State,Mo().Transform,Mo().Render,Mo().Send])}function zo(){Do=this,this.Before=new Ct("Before"),this.State=new Ct("State"),this.Transform=new Ct("Transform"),this.Render=new Ct("Render"),this.Send=new Ct("Send")}Co.$metadata$={kind:g,simpleName:"HttpRequestBuilder",interfaces:[Ee]},Po.prototype.getCapabilityOrNull_1sr7de$=function(t){var n,i;return null==(i=null!=(n=this.attributes.getOrNull_yzaw86$(Nn))?n.get_11rb$(t):null)||e.isType(i,x)?i:f()},Po.prototype.toString=function(){return"HttpRequestData(url="+this.url+", method="+this.method+")"},Po.$metadata$={kind:g,simpleName:"HttpRequestData",interfaces:[]},Ao.prototype.toString=function(){return"HttpResponseData=(statusCode="+this.statusCode+")"},Ao.$metadata$={kind:g,simpleName:"HttpResponseData",interfaces:[]},zo.$metadata$={kind:O,simpleName:"Phases",interfaces:[]};var Do=null;function Mo(){return null===Do&&new zo,Do}function Bo(){Go(),Se.call(this,[Go().Before,Go().State,Go().Monitoring,Go().Engine,Go().Receive])}function Uo(){qo=this,this.Before=new Ct("Before"),this.State=new Ct("State"),this.Monitoring=new Ct("Monitoring"),this.Engine=new Ct("Engine"),this.Receive=new Ct("Receive")}Io.$metadata$={kind:g,simpleName:"HttpRequestPipeline",interfaces:[Se]},Uo.$metadata$={kind:O,simpleName:"Phases",interfaces:[]};var Fo,qo=null;function Go(){return null===qo&&new Uo,qo}function Ho(t){lt.call(this),this.formData=t;var n=Te(this.formData);this.content_0=Fe(Nt.Charsets.UTF_8.newEncoder(),n,0,n.length),this.contentLength_f2tvnf$_0=e.Long.fromInt(this.content_0.length),this.contentType_gyve29$_0=Lt(at.Application.FormUrlEncoded,Nt.Charsets.UTF_8)}function Yo(t){Pe.call(this),this.boundary_0=function(){for(var t=Ft(),e=0;e<32;e++)t.append_gw00v9$(Me(De.Default.nextInt(),16));return Be(t.toString(),70)}();var n="--"+this.boundary_0+"\r\n";this.BOUNDARY_BYTES_0=Fe(Nt.Charsets.UTF_8.newEncoder(),n,0,n.length);var i="--"+this.boundary_0+"--\r\n\r\n";this.LAST_BOUNDARY_BYTES_0=Fe(Nt.Charsets.UTF_8.newEncoder(),i,0,i.length),this.BODY_OVERHEAD_SIZE_0=(2*Fo.length|0)+this.LAST_BOUNDARY_BYTES_0.length|0,this.PART_OVERHEAD_SIZE_0=(2*Fo.length|0)+this.BOUNDARY_BYTES_0.length|0;var r,o=se(qe(t,10));for(r=t.iterator();r.hasNext();){var a,s,l,u,c,p=r.next(),h=o.add_11rb$,_=Ae();for(s=p.headers.entries().iterator();s.hasNext();){var f=s.next(),d=f.key,m=f.value;je(_,d+": "+I(m,"; ")),Le(_,Fo)}var y=null!=(l=p.headers.get_61zpoe$(X.HttpHeaders.ContentLength))?ct(l):null;if(e.isType(p,Re)){var $=q(_.build()),v=null!=(u=null!=y?y.add(e.Long.fromInt(this.PART_OVERHEAD_SIZE_0)):null)?u.add(e.Long.fromInt($.length)):null;a=new Wo($,p.provider,v)}else if(e.isType(p,Ie)){var g=q(_.build()),b=null!=(c=null!=y?y.add(e.Long.fromInt(this.PART_OVERHEAD_SIZE_0)):null)?c.add(e.Long.fromInt(g.length)):null;a=new Wo(g,p.provider,b)}else if(e.isType(p,ze)){var w,x=Ae(0);try{je(x,p.value),w=x.build()}catch(t){throw e.isType(t,T)?(x.release(),t):t}var k=q(w),E=Ko(k);null==y&&(je(_,X.HttpHeaders.ContentLength+": "+k.length),Le(_,Fo));var C=q(_.build()),S=k.length+this.PART_OVERHEAD_SIZE_0+C.length|0;a=new Wo(C,E,e.Long.fromInt(S))}else a=e.noWhenBranchMatched();h.call(o,a)}this.rawParts_0=o,this.contentLength_egukxp$_0=null,this.contentType_azd2en$_0=at.MultiPart.FormData.withParameter_puj7f4$("boundary",this.boundary_0);var O,N=this.rawParts_0,P=ee;for(O=N.iterator();O.hasNext();){var A=P,j=O.next().size;P=null!=A&&null!=j?A.add(j):null}var L=P;null==L||nt(L,ee)||(L=L.add(e.Long.fromInt(this.BODY_OVERHEAD_SIZE_0))),this.contentLength_egukxp$_0=L}function Vo(t,e,n){_.call(this,n),this.exceptionState_0=18,this.$this=t,this.local$tmp$=void 0,this.local$part=void 0,this.local$$receiver=void 0,this.local$channel=e}function Ko(t){return function(){var n,i=Ae(0);try{Le(i,t),n=i.build()}catch(t){throw e.isType(t,T)?(i.release(),t):t}return n}}function Wo(t,e,n){this.headers=t,this.provider=e,this.size=n}function Xo(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$this$copyTo=t,this.local$size=void 0,this.local$$receiver=e}function Zo(t){return function(e,n,i){var r=new Xo(t,e,this,n);return i?r:r.doResume(null)}}function Jo(t,e,n){_.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$channel=e}function Qo(t){return t.url.port}function ta(t,n){var i,r;ea.call(this),this.call_9p3cfk$_0=t,this.coroutineContext_5l7f2v$_0=n.callContext,this.status_gsg6kc$_0=n.statusCode,this.version_vctfwy$_0=n.version,this.requestTime_34y64q$_0=n.requestTime,this.responseTime_u9wao0$_0=n.responseTime,this.content_7wqjir$_0=null!=(r=e.isType(i=n.body,E)?i:null)?r:E.Companion.Empty,this.headers_gyyq4g$_0=n.headers}function ea(){}function na(t){return t.call.request}function ia(t){var n;(e.isType(n=p(t.coroutineContext.get_j3r2sn$(c.Key)),y)?n:f()).complete()}function ra(){sa(),Se.call(this,[sa().Receive,sa().Parse,sa().Transform,sa().State,sa().After])}function oa(){aa=this,this.Receive=new Ct("Receive"),this.Parse=new Ct("Parse"),this.Transform=new Ct("Transform"),this.State=new Ct("State"),this.After=new Ct("After")}Bo.$metadata$={kind:g,simpleName:"HttpSendPipeline",interfaces:[Se]},N("ktor-ktor-client-core.io.ktor.client.request.request_ixrg4t$",P((function(){var n=t.io.ktor.client.request.HttpRequestBuilder,i=t.io.ktor.client.statement.HttpStatement,r=e.getReifiedTypeParameterKType,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){void 0===f&&(f=new n);var m,y,$,v=new i(f,_);if(m=o(t),s(m,o(i)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,r(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.request_g0tv8i$",P((function(){var n=t.io.ktor.client.request.HttpRequestBuilder,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){var m=new n;f(m);var y,$,v,g=new r(m,_);if(y=o(t),s(y,o(r)))e.setCoroutineResult(h($=g)?$:a(),e.coroutineReceiver());else if(s(y,o(l)))e.suspendCall(g.execute(e.coroutineReceiver())),e.setCoroutineResult(h(v=e.coroutineResult(e.coroutineReceiver()))?v:a(),e.coroutineReceiver());else{e.suspendCall(g.executeUnsafe(e.coroutineReceiver()));var b=e.coroutineResult(e.coroutineReceiver());try{var w,x,k=b.call;t:do{try{x=new p(o(t),c.JsType,i(t))}catch(e){x=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(k.receive_jo9acv$(x,e.coroutineReceiver())),e.setCoroutineResult(h(w=e.coroutineResult(e.coroutineReceiver()))?w:a(),e.coroutineReceiver())}finally{u(b)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.request_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.io.ktor.client.request.HttpRequestBuilder,r=t.io.ktor.client.request.url_g8iu3v$,o=e.getReifiedTypeParameterKType,a=t.io.ktor.client.statement.HttpStatement,s=e.getKClass,l=e.throwCCE,u=e.equals,c=t.io.ktor.client.statement.HttpResponse,p=t.io.ktor.client.statement.complete_abn2de$,h=t.io.ktor.client.call,_=t.io.ktor.client.call.TypeInfo;function f(t){return n}return function(t,n,d,m,y,$){void 0===y&&(y=f);var v=new i;r(v,m),y(v);var g,b,w,x=new a(v,d);if(g=s(t),u(g,s(a)))e.setCoroutineResult(n(b=x)?b:l(),e.coroutineReceiver());else if(u(g,s(c)))e.suspendCall(x.execute(e.coroutineReceiver())),e.setCoroutineResult(n(w=e.coroutineResult(e.coroutineReceiver()))?w:l(),e.coroutineReceiver());else{e.suspendCall(x.executeUnsafe(e.coroutineReceiver()));var k=e.coroutineResult(e.coroutineReceiver());try{var E,C,S=k.call;t:do{try{C=new _(s(t),h.JsType,o(t))}catch(e){C=new _(s(t),h.JsType);break t}}while(0);e.suspendCall(S.receive_jo9acv$(C,e.coroutineReceiver())),e.setCoroutineResult(n(E=e.coroutineResult(e.coroutineReceiver()))?E:l(),e.coroutineReceiver())}finally{p(k)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.request_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.io.ktor.client.request.HttpRequestBuilder,r=t.io.ktor.client.request.url_qpqkqe$,o=e.getReifiedTypeParameterKType,a=t.io.ktor.client.statement.HttpStatement,s=e.getKClass,l=e.throwCCE,u=e.equals,c=t.io.ktor.client.statement.HttpResponse,p=t.io.ktor.client.statement.complete_abn2de$,h=t.io.ktor.client.call,_=t.io.ktor.client.call.TypeInfo;function f(t){return n}return function(t,n,d,m,y,$){void 0===y&&(y=f);var v=new i;r(v,m),y(v);var g,b,w,x=new a(v,d);if(g=s(t),u(g,s(a)))e.setCoroutineResult(n(b=x)?b:l(),e.coroutineReceiver());else if(u(g,s(c)))e.suspendCall(x.execute(e.coroutineReceiver())),e.setCoroutineResult(n(w=e.coroutineResult(e.coroutineReceiver()))?w:l(),e.coroutineReceiver());else{e.suspendCall(x.executeUnsafe(e.coroutineReceiver()));var k=e.coroutineResult(e.coroutineReceiver());try{var E,C,S=k.call;t:do{try{C=new _(s(t),h.JsType,o(t))}catch(e){C=new _(s(t),h.JsType);break t}}while(0);e.suspendCall(S.receive_jo9acv$(C,e.coroutineReceiver())),e.setCoroutineResult(n(E=e.coroutineResult(e.coroutineReceiver()))?E:l(),e.coroutineReceiver())}finally{p(k)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.get_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Get;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.post_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Post;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.put_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Put;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.delete_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Delete;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.options_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Options;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.patch_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Patch;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.head_ixrg4t$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,i=e.getReifiedTypeParameterKType,r=t.io.ktor.client.statement.HttpStatement,o=e.getKClass,a=e.throwCCE,s=e.equals,l=t.io.ktor.client.statement.HttpResponse,u=t.io.ktor.client.statement.complete_abn2de$,c=t.io.ktor.client.call,p=t.io.ktor.client.call.TypeInfo;return function(t,h,_,f,d){f.method=n.Companion.Head;var m,y,$,v=new r(f,_);if(m=o(t),s(m,o(r)))e.setCoroutineResult(h(y=v)?y:a(),e.coroutineReceiver());else if(s(m,o(l)))e.suspendCall(v.execute(e.coroutineReceiver())),e.setCoroutineResult(h($=e.coroutineResult(e.coroutineReceiver()))?$:a(),e.coroutineReceiver());else{e.suspendCall(v.executeUnsafe(e.coroutineReceiver()));var g=e.coroutineResult(e.coroutineReceiver());try{var b,w,x=g.call;t:do{try{w=new p(o(t),c.JsType,i(t))}catch(e){w=new p(o(t),c.JsType);break t}}while(0);e.suspendCall(x.receive_jo9acv$(w,e.coroutineReceiver())),e.setCoroutineResult(h(b=e.coroutineResult(e.coroutineReceiver()))?b:a(),e.coroutineReceiver())}finally{u(g)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.get_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Get,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.post_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Post,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.put_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Put,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.delete_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Delete,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.patch_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Patch,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.head_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Head,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.options_xwttm9$",P((function(){var n=t.io.ktor.client.utils,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b,w,x,k){void 0===$&&($="http"),void 0===v&&(v="localhost"),void 0===g&&(g=0),void 0===b&&(b="/"),void 0===w&&(w=n.EmptyContent),void 0===x&&(x=m);var E=new s;r(E,$,v,g,b),E.method=o.Companion.Options,E.body=w,x(E);var C,S,T,O=new l(E,y);if(C=u(t),p(C,u(l)))e.setCoroutineResult(i(S=O)?S:c(),e.coroutineReceiver());else if(p(C,u(h)))e.suspendCall(O.execute(e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver());else{e.suspendCall(O.executeUnsafe(e.coroutineReceiver()));var N=e.coroutineResult(e.coroutineReceiver());try{var P,A,j=N.call;t:do{try{A=new d(u(t),f.JsType,a(t))}catch(e){A=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(j.receive_jo9acv$(A,e.coroutineReceiver())),e.setCoroutineResult(i(P=e.coroutineResult(e.coroutineReceiver()))?P:c(),e.coroutineReceiver())}finally{_(N)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.get_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Get,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.post_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Post,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.put_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Put,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.delete_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Delete,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.options_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Options,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.patch_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Patch,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.head_hf8dw$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_jl1sg7$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Head,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.get_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Get,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.post_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Post,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.put_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Put,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.patch_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Patch,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.options_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Options,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.head_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Head,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.delete_2swosf$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.takeFrom_wol2ee$,r=e.getReifiedTypeParameterKType,o=t.io.ktor.client.utils,a=t.io.ktor.client.request.url_3rzbk2$,s=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return n}return function(t,n,$,v,g,b){var w;void 0===g&&(g=y),w=o.EmptyContent;var x=new l;a(x,"http","localhost",0,"/"),x.method=s.Companion.Delete,x.body=w,i(x.url,v),g(x);var k,E,C,S=new u(x,$);if(k=c(t),h(k,c(u)))e.setCoroutineResult(n(E=S)?E:p(),e.coroutineReceiver());else if(h(k,c(_)))e.suspendCall(S.execute(e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:p(),e.coroutineReceiver());else{e.suspendCall(S.executeUnsafe(e.coroutineReceiver()));var T=e.coroutineResult(e.coroutineReceiver());try{var O,N,P=T.call;t:do{try{N=new m(c(t),d.JsType,r(t))}catch(e){N=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(P.receive_jo9acv$(N,e.coroutineReceiver())),e.setCoroutineResult(n(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver())}finally{f(T)}}return e.coroutineResult(e.coroutineReceiver())}}))),Object.defineProperty(Ho.prototype,"contentLength",{get:function(){return this.contentLength_f2tvnf$_0}}),Object.defineProperty(Ho.prototype,"contentType",{get:function(){return this.contentType_gyve29$_0}}),Ho.prototype.bytes=function(){return this.content_0},Ho.$metadata$={kind:g,simpleName:"FormDataContent",interfaces:[lt]},Object.defineProperty(Yo.prototype,"contentLength",{get:function(){return this.contentLength_egukxp$_0}}),Object.defineProperty(Yo.prototype,"contentType",{get:function(){return this.contentType_azd2en$_0}}),Vo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Vo.prototype=Object.create(_.prototype),Vo.prototype.constructor=Vo,Vo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=14,this.$this.rawParts_0.isEmpty()){this.exceptionState_0=18,this.finallyPath_0=[1],this.state_0=17;continue}this.state_0=2;continue;case 1:return;case 2:if(this.state_0=3,this.result_0=Oe(this.local$channel,Fo,this),this.result_0===h)return h;continue;case 3:if(this.state_0=4,this.result_0=Oe(this.local$channel,Fo,this),this.result_0===h)return h;continue;case 4:this.local$tmp$=this.$this.rawParts_0.iterator(),this.state_0=5;continue;case 5:if(!this.local$tmp$.hasNext()){this.state_0=15;continue}if(this.local$part=this.local$tmp$.next(),this.state_0=6,this.result_0=Oe(this.local$channel,this.$this.BOUNDARY_BYTES_0,this),this.result_0===h)return h;continue;case 6:if(this.state_0=7,this.result_0=Oe(this.local$channel,this.local$part.headers,this),this.result_0===h)return h;continue;case 7:if(this.state_0=8,this.result_0=Oe(this.local$channel,Fo,this),this.result_0===h)return h;continue;case 8:if(this.local$$receiver=this.local$part.provider(),this.exceptionState_0=12,this.state_0=9,this.result_0=(n=this.local$$receiver,i=this.local$channel,r=void 0,o=void 0,o=new Jo(n,i,this),r?o:o.doResume(null)),this.result_0===h)return h;continue;case 9:this.exceptionState_0=14,this.finallyPath_0=[10],this.state_0=13;continue;case 10:if(this.state_0=11,this.result_0=Oe(this.local$channel,Fo,this),this.result_0===h)return h;continue;case 11:this.state_0=5;continue;case 12:this.finallyPath_0=[14],this.state_0=13;continue;case 13:this.exceptionState_0=14,this.local$$receiver.close(),this.state_0=this.finallyPath_0.shift();continue;case 14:this.finallyPath_0=[18],this.exceptionState_0=17;var t=this.exception_0;if(!e.isType(t,T))throw t;this.local$channel.close_dbl4no$(t),this.finallyPath_0=[19],this.state_0=17;continue;case 15:if(this.state_0=16,this.result_0=Oe(this.local$channel,this.$this.LAST_BOUNDARY_BYTES_0,this),this.result_0===h)return h;continue;case 16:this.exceptionState_0=18,this.finallyPath_0=[19],this.state_0=17;continue;case 17:this.exceptionState_0=18,Ne(this.local$channel),this.state_0=this.finallyPath_0.shift();continue;case 18:throw this.exception_0;case 19:return;default:throw this.state_0=18,new Error("State Machine Unreachable execution")}}catch(t){if(18===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}var n,i,r,o},Yo.prototype.writeTo_h3x4ir$=function(t,e,n){var i=new Vo(this,t,e);return n?i:i.doResume(null)},Yo.$metadata$={kind:g,simpleName:"MultiPartFormDataContent",interfaces:[Pe]},Wo.$metadata$={kind:g,simpleName:"PreparedPart",interfaces:[]},Xo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Xo.prototype=Object.create(_.prototype),Xo.prototype.constructor=Xo,Xo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$this$copyTo.endOfInput){this.state_0=5;continue}if(this.state_0=3,this.result_0=this.local$$receiver.tryAwait_za3lpa$(1,this),this.result_0===h)return h;continue;case 3:var t=p(this.local$$receiver.request_za3lpa$(1));if(this.local$size=Ue(this.local$this$copyTo,t),this.local$size<0){this.state_0=2;continue}this.state_0=4;continue;case 4:this.local$$receiver.written_za3lpa$(this.local$size),this.state_0=2;continue;case 5:return u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Jo.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Jo.prototype=Object.create(_.prototype),Jo.prototype.constructor=Jo,Jo.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(e.isType(this.local$$receiver,mt)){if(this.state_0=2,this.result_0=this.local$channel.writePacket_3uq2w4$(this.local$$receiver,this),this.result_0===h)return h;continue}this.state_0=3;continue;case 1:throw this.exception_0;case 2:return;case 3:if(this.state_0=4,this.result_0=this.local$channel.writeSuspendSession_8dv01$(Zo(this.local$$receiver),this),this.result_0===h)return h;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},N("ktor-ktor-client-core.io.ktor.client.request.forms.submitForm_k24olv$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.Parameters,i=e.kotlin.Unit,r=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,o=t.io.ktor.client.request.forms.FormDataContent,a=e.getReifiedTypeParameterKType,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return i}return function(t,i,y,$,v,g,b){void 0===$&&($=n.Companion.Empty),void 0===v&&(v=!1),void 0===g&&(g=m);var w=new s;v?(w.method=r.Companion.Get,w.url.parameters.appendAll_hb0ubp$($)):(w.method=r.Companion.Post,w.body=new o($)),g(w);var x,k,E,C=new l(w,y);if(x=u(t),p(x,u(l)))e.setCoroutineResult(i(k=C)?k:c(),e.coroutineReceiver());else if(p(x,u(h)))e.suspendCall(C.execute(e.coroutineReceiver())),e.setCoroutineResult(i(E=e.coroutineResult(e.coroutineReceiver()))?E:c(),e.coroutineReceiver());else{e.suspendCall(C.executeUnsafe(e.coroutineReceiver()));var S=e.coroutineResult(e.coroutineReceiver());try{var T,O,N=S.call;t:do{try{O=new d(u(t),f.JsType,a(t))}catch(e){O=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(N.receive_jo9acv$(O,e.coroutineReceiver())),e.setCoroutineResult(i(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver())}finally{_(S)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.forms.submitForm_32veqj$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.Parameters,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_g8iu3v$,o=e.getReifiedTypeParameterKType,a=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,s=t.io.ktor.client.request.forms.FormDataContent,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return i}return function(t,i,$,v,g,b,w,x){void 0===g&&(g=n.Companion.Empty),void 0===b&&(b=!1),void 0===w&&(w=y);var k=new l;b?(k.method=a.Companion.Get,k.url.parameters.appendAll_hb0ubp$(g)):(k.method=a.Companion.Post,k.body=new s(g)),r(k,v),w(k);var E,C,S,T=new u(k,$);if(E=c(t),h(E,c(u)))e.setCoroutineResult(i(C=T)?C:p(),e.coroutineReceiver());else if(h(E,c(_)))e.suspendCall(T.execute(e.coroutineReceiver())),e.setCoroutineResult(i(S=e.coroutineResult(e.coroutineReceiver()))?S:p(),e.coroutineReceiver());else{e.suspendCall(T.executeUnsafe(e.coroutineReceiver()));var O=e.coroutineResult(e.coroutineReceiver());try{var N,P,A=O.call;t:do{try{P=new m(c(t),d.JsType,o(t))}catch(e){P=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(A.receive_jo9acv$(P,e.coroutineReceiver())),e.setCoroutineResult(i(N=e.coroutineResult(e.coroutineReceiver()))?N:p(),e.coroutineReceiver())}finally{f(O)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.forms.submitFormWithBinaryData_k1tmp5$",P((function(){var n=e.kotlin.Unit,i=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,r=t.io.ktor.client.request.forms.MultiPartFormDataContent,o=e.getReifiedTypeParameterKType,a=t.io.ktor.client.request.HttpRequestBuilder,s=t.io.ktor.client.statement.HttpStatement,l=e.getKClass,u=e.throwCCE,c=e.equals,p=t.io.ktor.client.statement.HttpResponse,h=t.io.ktor.client.statement.complete_abn2de$,_=t.io.ktor.client.call,f=t.io.ktor.client.call.TypeInfo;function d(t){return n}return function(t,n,m,y,$,v){void 0===$&&($=d);var g=new a;g.method=i.Companion.Post,g.body=new r(y),$(g);var b,w,x,k=new s(g,m);if(b=l(t),c(b,l(s)))e.setCoroutineResult(n(w=k)?w:u(),e.coroutineReceiver());else if(c(b,l(p)))e.suspendCall(k.execute(e.coroutineReceiver())),e.setCoroutineResult(n(x=e.coroutineResult(e.coroutineReceiver()))?x:u(),e.coroutineReceiver());else{e.suspendCall(k.executeUnsafe(e.coroutineReceiver()));var E=e.coroutineResult(e.coroutineReceiver());try{var C,S,T=E.call;t:do{try{S=new f(l(t),_.JsType,o(t))}catch(e){S=new f(l(t),_.JsType);break t}}while(0);e.suspendCall(T.receive_jo9acv$(S,e.coroutineReceiver())),e.setCoroutineResult(n(C=e.coroutineResult(e.coroutineReceiver()))?C:u(),e.coroutineReceiver())}finally{h(E)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.forms.submitFormWithBinaryData_i2k1l1$",P((function(){var n=e.kotlin.Unit,i=t.io.ktor.client.request.url_g8iu3v$,r=e.getReifiedTypeParameterKType,o=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,a=t.io.ktor.client.request.forms.MultiPartFormDataContent,s=t.io.ktor.client.request.HttpRequestBuilder,l=t.io.ktor.client.statement.HttpStatement,u=e.getKClass,c=e.throwCCE,p=e.equals,h=t.io.ktor.client.statement.HttpResponse,_=t.io.ktor.client.statement.complete_abn2de$,f=t.io.ktor.client.call,d=t.io.ktor.client.call.TypeInfo;function m(t){return n}return function(t,n,y,$,v,g,b){void 0===g&&(g=m);var w=new s;w.method=o.Companion.Post,w.body=new a(v),i(w,$),g(w);var x,k,E,C=new l(w,y);if(x=u(t),p(x,u(l)))e.setCoroutineResult(n(k=C)?k:c(),e.coroutineReceiver());else if(p(x,u(h)))e.suspendCall(C.execute(e.coroutineReceiver())),e.setCoroutineResult(n(E=e.coroutineResult(e.coroutineReceiver()))?E:c(),e.coroutineReceiver());else{e.suspendCall(C.executeUnsafe(e.coroutineReceiver()));var S=e.coroutineResult(e.coroutineReceiver());try{var T,O,N=S.call;t:do{try{O=new d(u(t),f.JsType,r(t))}catch(e){O=new d(u(t),f.JsType);break t}}while(0);e.suspendCall(N.receive_jo9acv$(O,e.coroutineReceiver())),e.setCoroutineResult(n(T=e.coroutineResult(e.coroutineReceiver()))?T:c(),e.coroutineReceiver())}finally{_(S)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.forms.submitForm_ejo4ot$",P((function(){var n=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.Parameters,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=e.getReifiedTypeParameterKType,a=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,s=t.io.ktor.client.request.forms.FormDataContent,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return i}return function(t,i,$,v,g,b,w,x,k,E,C){void 0===v&&(v="http"),void 0===g&&(g="localhost"),void 0===b&&(b=80),void 0===w&&(w="/"),void 0===x&&(x=n.Companion.Empty),void 0===k&&(k=!1),void 0===E&&(E=y);var S=new l;k?(S.method=a.Companion.Get,S.url.parameters.appendAll_hb0ubp$(x)):(S.method=a.Companion.Post,S.body=new s(x)),r(S,v,g,b,w),E(S);var T,O,N,P=new u(S,$);if(T=c(t),h(T,c(u)))e.setCoroutineResult(i(O=P)?O:p(),e.coroutineReceiver());else if(h(T,c(_)))e.suspendCall(P.execute(e.coroutineReceiver())),e.setCoroutineResult(i(N=e.coroutineResult(e.coroutineReceiver()))?N:p(),e.coroutineReceiver());else{e.suspendCall(P.executeUnsafe(e.coroutineReceiver()));var A=e.coroutineResult(e.coroutineReceiver());try{var j,L,R=A.call;t:do{try{L=new m(c(t),d.JsType,o(t))}catch(e){L=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(R.receive_jo9acv$(L,e.coroutineReceiver())),e.setCoroutineResult(i(j=e.coroutineResult(e.coroutineReceiver()))?j:p(),e.coroutineReceiver())}finally{f(A)}}return e.coroutineResult(e.coroutineReceiver())}}))),N("ktor-ktor-client-core.io.ktor.client.request.forms.submitFormWithBinaryData_vcnbbn$",P((function(){var n=e.kotlin.collections.emptyList_287e2$,i=e.kotlin.Unit,r=t.io.ktor.client.request.url_3rzbk2$,o=e.getReifiedTypeParameterKType,a=t.$$importsForInline$$["ktor-ktor-http"].io.ktor.http.HttpMethod,s=t.io.ktor.client.request.forms.MultiPartFormDataContent,l=t.io.ktor.client.request.HttpRequestBuilder,u=t.io.ktor.client.statement.HttpStatement,c=e.getKClass,p=e.throwCCE,h=e.equals,_=t.io.ktor.client.statement.HttpResponse,f=t.io.ktor.client.statement.complete_abn2de$,d=t.io.ktor.client.call,m=t.io.ktor.client.call.TypeInfo;function y(t){return i}return function(t,i,$,v,g,b,w,x,k,E){void 0===v&&(v="http"),void 0===g&&(g="localhost"),void 0===b&&(b=80),void 0===w&&(w="/"),void 0===x&&(x=n()),void 0===k&&(k=y);var C=new l;C.method=a.Companion.Post,C.body=new s(x),r(C,v,g,b,w),k(C);var S,T,O,N=new u(C,$);if(S=c(t),h(S,c(u)))e.setCoroutineResult(i(T=N)?T:p(),e.coroutineReceiver());else if(h(S,c(_)))e.suspendCall(N.execute(e.coroutineReceiver())),e.setCoroutineResult(i(O=e.coroutineResult(e.coroutineReceiver()))?O:p(),e.coroutineReceiver());else{e.suspendCall(N.executeUnsafe(e.coroutineReceiver()));var P=e.coroutineResult(e.coroutineReceiver());try{var A,j,L=P.call;t:do{try{j=new m(c(t),d.JsType,o(t))}catch(e){j=new m(c(t),d.JsType);break t}}while(0);e.suspendCall(L.receive_jo9acv$(j,e.coroutineReceiver())),e.setCoroutineResult(i(A=e.coroutineResult(e.coroutineReceiver()))?A:p(),e.coroutineReceiver())}finally{f(P)}}return e.coroutineResult(e.coroutineReceiver())}}))),Object.defineProperty(ta.prototype,"call",{get:function(){return this.call_9p3cfk$_0}}),Object.defineProperty(ta.prototype,"coroutineContext",{get:function(){return this.coroutineContext_5l7f2v$_0}}),Object.defineProperty(ta.prototype,"status",{get:function(){return this.status_gsg6kc$_0}}),Object.defineProperty(ta.prototype,"version",{get:function(){return this.version_vctfwy$_0}}),Object.defineProperty(ta.prototype,"requestTime",{get:function(){return this.requestTime_34y64q$_0}}),Object.defineProperty(ta.prototype,"responseTime",{get:function(){return this.responseTime_u9wao0$_0}}),Object.defineProperty(ta.prototype,"content",{get:function(){return this.content_7wqjir$_0}}),Object.defineProperty(ta.prototype,"headers",{get:function(){return this.headers_gyyq4g$_0}}),ta.$metadata$={kind:g,simpleName:"DefaultHttpResponse",interfaces:[ea]},ea.prototype.toString=function(){return"HttpResponse["+na(this).url+", "+this.status+"]"},ea.$metadata$={kind:g,simpleName:"HttpResponse",interfaces:[b,we]},oa.$metadata$={kind:O,simpleName:"Phases",interfaces:[]};var aa=null;function sa(){return null===aa&&new oa,aa}function la(){_a(),Se.call(this,[_a().Before,_a().State,_a().After])}function ua(){ha=this,this.Before=new Ct("Before"),this.State=new Ct("State"),this.After=new Ct("After")}ra.$metadata$={kind:g,simpleName:"HttpResponsePipeline",interfaces:[Se]},ua.$metadata$={kind:O,simpleName:"Phases",interfaces:[]};var ca,pa,ha=null;function _a(){return null===ha&&new ua,ha}function fa(t,e){this.expectedType=t,this.response=e}function da(t,e){this.builder_0=t,this.client_0=e,this.checkCapabilities_0()}function ma(t,e,n){_.call(this,n),this.exceptionState_0=8,this.$this=t,this.local$response=void 0,this.local$block=e}function ya(t,e){_.call(this,e),this.exceptionState_0=1,this.local$it=t}function $a(t,e,n){var i=new ya(t,e);return n?i:i.doResume(null)}function va(t,e,n,i){_.call(this,i),this.exceptionState_0=7,this.$this=t,this.local$response=void 0,this.local$T_0=e,this.local$isT=n}function ga(t,e,n,i,r){_.call(this,r),this.exceptionState_0=9,this.$this=t,this.local$response=void 0,this.local$T_0=e,this.local$isT=n,this.local$block=i}function ba(t,e){_.call(this,e),this.exceptionState_0=1,this.$this=t}function wa(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$$receiver=e}function xa(){ka=this,ne.call(this),this.contentLength_89rfwp$_0=ee}la.$metadata$={kind:g,simpleName:"HttpReceivePipeline",interfaces:[Se]},fa.$metadata$={kind:g,simpleName:"HttpResponseContainer",interfaces:[]},fa.prototype.component1=function(){return this.expectedType},fa.prototype.component2=function(){return this.response},fa.prototype.copy_ju9ok$=function(t,e){return new fa(void 0===t?this.expectedType:t,void 0===e?this.response:e)},fa.prototype.toString=function(){return"HttpResponseContainer(expectedType="+e.toString(this.expectedType)+", response="+e.toString(this.response)+")"},fa.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.expectedType)|0)+e.hashCode(this.response)|0},fa.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.expectedType,t.expectedType)&&e.equals(this.response,t.response)},ma.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ma.prototype=Object.create(_.prototype),ma.prototype.constructor=ma,ma.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=1,this.result_0=this.$this.executeUnsafe(this),this.result_0===h)return h;continue;case 1:if(this.local$response=this.result_0,this.exceptionState_0=5,this.state_0=2,this.result_0=this.local$block(this.local$response,this),this.result_0===h)return h;continue;case 2:this.exceptionState_0=8,this.finallyPath_0=[3],this.state_0=6,this.$returnValue=this.result_0;continue;case 3:return this.$returnValue;case 4:return;case 5:this.finallyPath_0=[8],this.state_0=6;continue;case 6:if(this.exceptionState_0=8,this.state_0=7,this.result_0=this.$this.cleanup_abn2de$(this.local$response,this),this.result_0===h)return h;continue;case 7:this.state_0=this.finallyPath_0.shift();continue;case 8:throw this.exception_0;default:throw this.state_0=8,new Error("State Machine Unreachable execution")}}catch(t){if(8===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.execute_2rh6on$=function(t,e,n){var i=new ma(this,t,e);return n?i:i.doResume(null)},ya.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ya.prototype=Object.create(_.prototype),ya.prototype.constructor=ya,ya.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=Hn(this.local$it.call,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0.response;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.execute=function(t){return this.execute_2rh6on$($a,t)},va.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},va.prototype=Object.create(_.prototype),va.prototype.constructor=va,va.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,e,n;if(t=B(this.local$T_0),nt(t,B(da)))return this.local$isT(e=this.$this)?e:f();if(nt(t,B(ea))){if(this.state_0=8,this.result_0=this.$this.execute(this),this.result_0===h)return h;continue}if(this.state_0=1,this.result_0=this.$this.executeUnsafe(this),this.result_0===h)return h;continue;case 1:var i;this.local$response=this.result_0,this.exceptionState_0=5;var r,o=this.local$response.call;t:do{try{r=new Yn(B(this.local$T_0),js.JsType,M(this.local$T_0))}catch(t){r=new Yn(B(this.local$T_0),js.JsType);break t}}while(0);if(this.state_0=2,this.result_0=o.receive_jo9acv$(r,this),this.result_0===h)return h;continue;case 2:this.result_0=this.local$isT(i=this.result_0)?i:f(),this.exceptionState_0=7,this.finallyPath_0=[3],this.state_0=6,this.$returnValue=this.result_0;continue;case 3:return this.$returnValue;case 4:this.state_0=9;continue;case 5:this.finallyPath_0=[7],this.state_0=6;continue;case 6:this.exceptionState_0=7,ia(this.local$response),this.state_0=this.finallyPath_0.shift();continue;case 7:throw this.exception_0;case 8:return this.local$isT(n=this.result_0)?n:f();case 9:this.state_0=10;continue;case 10:return;default:throw this.state_0=7,new Error("State Machine Unreachable execution")}}catch(t){if(7===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.receive_287e2$=function(t,e,n,i){var r=new va(this,t,e,n);return i?r:r.doResume(null)},N("ktor-ktor-client-core.io.ktor.client.statement.HttpStatement.receive_287e2$",P((function(){var n=e.getKClass,i=e.throwCCE,r=t.io.ktor.client.statement.HttpStatement,o=e.equals,a=t.io.ktor.client.statement.HttpResponse,s=e.getReifiedTypeParameterKType,l=t.io.ktor.client.statement.complete_abn2de$,u=t.io.ktor.client.call,c=t.io.ktor.client.call.TypeInfo;return function(t,p,h){var _,f;if(_=n(t),o(_,n(r)))return p(this)?this:i();if(o(_,n(a)))return e.suspendCall(this.execute(e.coroutineReceiver())),p(f=e.coroutineResult(e.coroutineReceiver()))?f:i();e.suspendCall(this.executeUnsafe(e.coroutineReceiver()));var d=e.coroutineResult(e.coroutineReceiver());try{var m,y,$=d.call;t:do{try{y=new c(n(t),u.JsType,s(t))}catch(e){y=new c(n(t),u.JsType);break t}}while(0);return e.suspendCall($.receive_jo9acv$(y,e.coroutineReceiver())),e.setCoroutineResult(p(m=e.coroutineResult(e.coroutineReceiver()))?m:i(),e.coroutineReceiver()),e.coroutineResult(e.coroutineReceiver())}finally{l(d)}}}))),ga.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ga.prototype=Object.create(_.prototype),ga.prototype.constructor=ga,ga.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=1,this.result_0=this.$this.executeUnsafe(this),this.result_0===h)return h;continue;case 1:var t;this.local$response=this.result_0,this.exceptionState_0=6;var e,n=this.local$response.call;t:do{try{e=new Yn(B(this.local$T_0),js.JsType,M(this.local$T_0))}catch(t){e=new Yn(B(this.local$T_0),js.JsType);break t}}while(0);if(this.state_0=2,this.result_0=n.receive_jo9acv$(e,this),this.result_0===h)return h;continue;case 2:this.result_0=this.local$isT(t=this.result_0)?t:f();var i=this.result_0;if(this.state_0=3,this.result_0=this.local$block(i,this),this.result_0===h)return h;continue;case 3:this.exceptionState_0=9,this.finallyPath_0=[4],this.state_0=7,this.$returnValue=this.result_0;continue;case 4:return this.$returnValue;case 5:return;case 6:this.finallyPath_0=[9],this.state_0=7;continue;case 7:if(this.exceptionState_0=9,this.state_0=8,this.result_0=this.$this.cleanup_abn2de$(this.local$response,this),this.result_0===h)return h;continue;case 8:this.state_0=this.finallyPath_0.shift();continue;case 9:throw this.exception_0;default:throw this.state_0=9,new Error("State Machine Unreachable execution")}}catch(t){if(9===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.receive_yswr0a$=function(t,e,n,i,r){var o=new ga(this,t,e,n,i);return r?o:o.doResume(null)},N("ktor-ktor-client-core.io.ktor.client.statement.HttpStatement.receive_yswr0a$",P((function(){var n=e.getReifiedTypeParameterKType,i=e.throwCCE,r=e.getKClass,o=t.io.ktor.client.call,a=t.io.ktor.client.call.TypeInfo;return function(t,s,l,u){e.suspendCall(this.executeUnsafe(e.coroutineReceiver()));var c=e.coroutineResult(e.coroutineReceiver());try{var p,h,_=c.call;t:do{try{h=new a(r(t),o.JsType,n(t))}catch(e){h=new a(r(t),o.JsType);break t}}while(0);e.suspendCall(_.receive_jo9acv$(h,e.coroutineReceiver())),e.setCoroutineResult(s(p=e.coroutineResult(e.coroutineReceiver()))?p:i(),e.coroutineReceiver());var f=e.coroutineResult(e.coroutineReceiver());return e.suspendCall(l(f,e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())}finally{e.suspendCall(this.cleanup_abn2de$(c,e.coroutineReceiver()))}}}))),ba.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ba.prototype=Object.create(_.prototype),ba.prototype.constructor=ba,ba.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=(new Co).takeFrom_s9rlw$(this.$this.builder_0);if(this.state_0=2,this.result_0=this.$this.client_0.execute_s9rlw$(t,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0.response;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.executeUnsafe=function(t,e){var n=new ba(this,t);return e?n:n.doResume(null)},wa.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},wa.prototype=Object.create(_.prototype),wa.prototype.constructor=wa,wa.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n=e.isType(t=p(this.local$$receiver.coroutineContext.get_j3r2sn$(c.Key)),y)?t:f();n.complete();try{ht(this.local$$receiver.content)}catch(t){if(!e.isType(t,T))throw t}if(this.state_0=2,this.result_0=n.join(this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},da.prototype.cleanup_abn2de$=function(t,e,n){var i=new wa(this,t,e);return n?i:i.doResume(null)},da.prototype.checkCapabilities_0=function(){var t,n,i,r,o;if(null!=(n=null!=(t=this.builder_0.attributes.getOrNull_yzaw86$(Nn))?t.keys:null)){var a,s=St();for(a=n.iterator();a.hasNext();){var l=a.next();e.isType(l,Wi)&&s.add_11rb$(l)}r=s}else r=null;if(null!=(i=r))for(o=i.iterator();o.hasNext();){var u,c=o.next();if(null==Zi(this.client_0,e.isType(u=c,Wi)?u:f()))throw G(("Consider installing "+c+" feature because the request requires it to be installed").toString())}},da.prototype.toString=function(){return"HttpStatement["+this.builder_0.url.buildString()+"]"},da.$metadata$={kind:g,simpleName:"HttpStatement",interfaces:[]},Object.defineProperty(xa.prototype,"contentLength",{get:function(){return this.contentLength_89rfwp$_0}}),xa.prototype.toString=function(){return"EmptyContent"},xa.$metadata$={kind:O,simpleName:"EmptyContent",interfaces:[ne]};var ka=null;function Ea(){return null===ka&&new xa,ka}function Ca(t,e){this.this$wrapHeaders=t,ne.call(this),this.headers_byaa2p$_0=e(t.headers)}function Sa(t,e){this.this$wrapHeaders=t,ut.call(this),this.headers_byaa2p$_0=e(t.headers)}function Ta(t,e){this.this$wrapHeaders=t,Pe.call(this),this.headers_byaa2p$_0=e(t.headers)}function Oa(t,e){this.this$wrapHeaders=t,lt.call(this),this.headers_byaa2p$_0=e(t.headers)}function Na(t,e){this.this$wrapHeaders=t,He.call(this),this.headers_byaa2p$_0=e(t.headers)}function Pa(){Aa=this,this.MAX_AGE="max-age",this.MIN_FRESH="min-fresh",this.ONLY_IF_CACHED="only-if-cached",this.MAX_STALE="max-stale",this.NO_CACHE="no-cache",this.NO_STORE="no-store",this.NO_TRANSFORM="no-transform",this.MUST_REVALIDATE="must-revalidate",this.PUBLIC="public",this.PRIVATE="private",this.PROXY_REVALIDATE="proxy-revalidate",this.S_MAX_AGE="s-maxage"}Object.defineProperty(Ca.prototype,"contentLength",{get:function(){return this.this$wrapHeaders.contentLength}}),Object.defineProperty(Ca.prototype,"contentType",{get:function(){return this.this$wrapHeaders.contentType}}),Object.defineProperty(Ca.prototype,"status",{get:function(){return this.this$wrapHeaders.status}}),Object.defineProperty(Ca.prototype,"headers",{get:function(){return this.headers_byaa2p$_0}}),Ca.$metadata$={kind:g,interfaces:[ne]},Object.defineProperty(Sa.prototype,"contentLength",{get:function(){return this.this$wrapHeaders.contentLength}}),Object.defineProperty(Sa.prototype,"contentType",{get:function(){return this.this$wrapHeaders.contentType}}),Object.defineProperty(Sa.prototype,"status",{get:function(){return this.this$wrapHeaders.status}}),Object.defineProperty(Sa.prototype,"headers",{get:function(){return this.headers_byaa2p$_0}}),Sa.prototype.readFrom=function(){return this.this$wrapHeaders.readFrom()},Sa.prototype.readFrom_6z6t3e$=function(t){return this.this$wrapHeaders.readFrom_6z6t3e$(t)},Sa.$metadata$={kind:g,interfaces:[ut]},Object.defineProperty(Ta.prototype,"contentLength",{get:function(){return this.this$wrapHeaders.contentLength}}),Object.defineProperty(Ta.prototype,"contentType",{get:function(){return this.this$wrapHeaders.contentType}}),Object.defineProperty(Ta.prototype,"status",{get:function(){return this.this$wrapHeaders.status}}),Object.defineProperty(Ta.prototype,"headers",{get:function(){return this.headers_byaa2p$_0}}),Ta.prototype.writeTo_h3x4ir$=function(t,e){return this.this$wrapHeaders.writeTo_h3x4ir$(t,e)},Ta.$metadata$={kind:g,interfaces:[Pe]},Object.defineProperty(Oa.prototype,"contentLength",{get:function(){return this.this$wrapHeaders.contentLength}}),Object.defineProperty(Oa.prototype,"contentType",{get:function(){return this.this$wrapHeaders.contentType}}),Object.defineProperty(Oa.prototype,"status",{get:function(){return this.this$wrapHeaders.status}}),Object.defineProperty(Oa.prototype,"headers",{get:function(){return this.headers_byaa2p$_0}}),Oa.prototype.bytes=function(){return this.this$wrapHeaders.bytes()},Oa.$metadata$={kind:g,interfaces:[lt]},Object.defineProperty(Na.prototype,"contentLength",{get:function(){return this.this$wrapHeaders.contentLength}}),Object.defineProperty(Na.prototype,"contentType",{get:function(){return this.this$wrapHeaders.contentType}}),Object.defineProperty(Na.prototype,"headers",{get:function(){return this.headers_byaa2p$_0}}),Na.prototype.upgrade_h1mv0l$=function(t,e,n,i,r){return this.this$wrapHeaders.upgrade_h1mv0l$(t,e,n,i,r)},Na.$metadata$={kind:g,interfaces:[He]},Pa.prototype.getMAX_AGE=function(){return this.MAX_AGE},Pa.prototype.getMIN_FRESH=function(){return this.MIN_FRESH},Pa.prototype.getONLY_IF_CACHED=function(){return this.ONLY_IF_CACHED},Pa.prototype.getMAX_STALE=function(){return this.MAX_STALE},Pa.prototype.getNO_CACHE=function(){return this.NO_CACHE},Pa.prototype.getNO_STORE=function(){return this.NO_STORE},Pa.prototype.getNO_TRANSFORM=function(){return this.NO_TRANSFORM},Pa.prototype.getMUST_REVALIDATE=function(){return this.MUST_REVALIDATE},Pa.prototype.getPUBLIC=function(){return this.PUBLIC},Pa.prototype.getPRIVATE=function(){return this.PRIVATE},Pa.prototype.getPROXY_REVALIDATE=function(){return this.PROXY_REVALIDATE},Pa.prototype.getS_MAX_AGE=function(){return this.S_MAX_AGE},Pa.$metadata$={kind:O,simpleName:"CacheControl",interfaces:[]};var Aa=null;function ja(t){return u}function La(t){void 0===t&&(t=ja);var e=new re;return t(e),e.build()}function Ra(t){return u}function Ia(){}function za(){Da=this}Ia.$metadata$={kind:W,simpleName:"Type",interfaces:[]},za.$metadata$={kind:O,simpleName:"JsType",interfaces:[Ia]};var Da=null;function Ma(t,e){return e.isInstance_s8jyv4$(t)}function Ba(){Ua=this}Ba.prototype.create_dxyxif$$default=function(t){var e=new _i;return t(e),new Ha(e)},Ba.$metadata$={kind:O,simpleName:"Js",interfaces:[ai]};var Ua=null;function Fa(){return null===Ua&&new Ba,Ua}function qa(){return Fa()}function Ga(t){return function(e){var n=new tn(Qe(e),1);return t(n),n.getResult()}}function Ha(t){if(ui.call(this,"ktor-js"),this.config_2md4la$_0=t,this.dispatcher_j9yf5v$_0=Xe.Dispatchers.Default,this.supportedCapabilities_380cpg$_0=et(Kr()),null!=this.config.proxy)throw w("Proxy unsupported in Js engine.".toString())}function Ya(t,e,n){_.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$callContext=void 0,this.local$requestTime=void 0,this.local$data=e}function Va(t,e,n,i){_.call(this,i),this.exceptionState_0=4,this.$this=t,this.local$requestTime=void 0,this.local$urlString=void 0,this.local$socket=void 0,this.local$request=e,this.local$callContext=n}function Ka(t){return function(e){if(!e.isCancelled){var n=function(t,e){return function(n){switch(n.type){case"open":var i=e;t.resumeWith_tl1gpc$(new Ze(i));break;case"error":var r=t,o=new so(JSON.stringify(n));r.resumeWith_tl1gpc$(new Ze(Je(o)))}return u}}(e,t);return t.addEventListener("open",n),t.addEventListener("error",n),e.invokeOnCancellation_f05bi3$(function(t,e){return function(n){return e.removeEventListener("open",t),e.removeEventListener("error",t),null!=n&&e.close(),u}}(n,t)),u}}}function Wa(t,e){_.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function Xa(t){return function(e){return t.forEach((n=e,function(t,e){return n.append_puj7f4$(e,t),u})),u;var n}}function Za(t){T.call(this),this.message_9vnttw$_0="Error from javascript["+t.toString()+"].",this.cause_kdow7y$_0=null,this.origin=t,e.captureStack(T,this),this.name="JsError"}function Ja(t){return function(e,n){return t[e]=n,u}}function Qa(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=1,this.local$closure$content=t,this.local$$receiver=e}function ts(t){return function(e,n,i){var r=new Qa(t,e,this,n);return i?r:r.doResume(null)}}function es(t,e,n){return function(i){return i.method=t.method.value,i.headers=e,i.redirect="follow",null!=n&&(i.body=new Uint8Array(en(n))),u}}function ns(t,e,n){_.call(this,n),this.exceptionState_0=1,this.local$tmp$=void 0,this.local$jsHeaders=void 0,this.local$$receiver=t,this.local$callContext=e}function is(t,e,n,i){var r=new ns(t,e,n);return i?r:r.doResume(null)}function rs(t){var n,i=null==(n={})||e.isType(n,x)?n:f();return t(i),i}function os(t){return function(e){var n=new tn(Qe(e),1);return t(n),n.getResult()}}function as(t){return function(e){return t.read().then((n=e,function(t){var e=t.value,i=t.done||null==e?null:e;return n.resumeWith_tl1gpc$(new Ze(i)),u})).catch(function(t){return function(e){return t.resumeWith_tl1gpc$(new Ze(Je(e))),u}}(e)),u;var n}}function ss(t,e){_.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function ls(t,e,n){var i=new ss(t,e);return n?i:i.doResume(null)}function us(t){return new Int8Array(t.buffer,t.byteOffset,t.length)}function cs(t,n){var i,r;if(null==(r=e.isType(i=n.body,Object)?i:null))throw w(("Fail to obtain native stream: "+n.toString()).toString());return hs(t,r)}function ps(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=8,this.local$closure$stream=t,this.local$tmp$=void 0,this.local$reader=void 0,this.local$$receiver=e}function hs(t,e){return xt(t,void 0,void 0,(n=e,function(t,e,i){var r=new ps(n,t,this,e);return i?r:r.doResume(null)})).channel;var n}function _s(t){return function(e){var n=new tn(Qe(e),1);return t(n),n.getResult()}}function fs(t,e){return function(i){var r,o,a=ys();return t.signal=a.signal,i.invokeOnCancellation_f05bi3$((o=a,function(t){return o.abort(),u})),(ot.PlatformUtils.IS_NODE?function(t){try{return n(975)(t)}catch(e){throw rn("Error loading module '"+t+"': "+e.toString())}}("node-fetch")(e,t):fetch(e,t)).then((r=i,function(t){return r.resumeWith_tl1gpc$(new Ze(t)),u}),function(t){return function(e){return t.resumeWith_tl1gpc$(new Ze(Je(new nn("Fail to fetch",e)))),u}}(i)),u}}function ds(t,e,n){_.call(this,n),this.exceptionState_0=1,this.local$input=t,this.local$init=e}function ms(t,e,n,i){var r=new ds(t,e,n);return i?r:r.doResume(null)}function ys(){return ot.PlatformUtils.IS_NODE?new(n(Object(function(){var t=new Error("Cannot find module 'abort-controller'");throw t.code="MODULE_NOT_FOUND",t}()))):new AbortController}function $s(t,e){return ot.PlatformUtils.IS_NODE?xs(t,e):cs(t,e)}function vs(t,e){return function(n){return t.offer_11rb$(us(new Uint8Array(n))),e.pause()}}function gs(t,e){return function(n){var i=new Za(n);return t.close_dbl4no$(i),e.channel.close_dbl4no$(i)}}function bs(t){return function(){return t.close_dbl4no$()}}function ws(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=8,this.local$closure$response=t,this.local$tmp$_0=void 0,this.local$body=void 0,this.local$$receiver=e}function xs(t,e){return xt(t,void 0,void 0,(n=e,function(t,e,i){var r=new ws(n,t,this,e);return i?r:r.doResume(null)})).channel;var n}function ks(t){}function Es(t,e){var n,i,r;this.coroutineContext_x6mio4$_0=t,this.websocket_0=e,this._closeReason_0=an(),this._incoming_0=on(2147483647),this._outgoing_0=on(2147483647),this.incoming_115vn1$_0=this._incoming_0,this.outgoing_ex3pqx$_0=this._outgoing_0,this.closeReason_n5pjc5$_0=this._closeReason_0,this.websocket_0.binaryType="arraybuffer",this.websocket_0.addEventListener("message",(r=this,function(t){return te(r,void 0,void 0,(e=t,n=r,function(t,i,r){var o=new Cs(e,n,t,this,i);return r?o:o.doResume(null)})),u;var e,n})),this.websocket_0.addEventListener("error",function(t){return function(e){var n=new so(e.toString());return t._closeReason_0.completeExceptionally_tcv7n7$(n),t._incoming_0.close_dbl4no$(n),t._outgoing_0.cancel_m4sck1$(),u}}(this)),this.websocket_0.addEventListener("close",function(t){return function(e){return te(t,void 0,void 0,(n=e,i=t,function(t,e,r){var o=new Ss(n,i,t,this,e);return r?o:o.doResume(null)})),u;var n,i}}(this)),te(this,void 0,void 0,(i=this,function(t,e,n){var r=new Ts(i,t,this,e);return n?r:r.doResume(null)})),null!=(n=this.coroutineContext.get_j3r2sn$(c.Key))&&n.invokeOnCompletion_f05bi3$(function(t){return function(e){return null==e?t.websocket_0.close():t.websocket_0.close(_n.INTERNAL_ERROR.code,"Client failed"),u}}(this))}function Cs(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$closure$event=t,this.local$this$JsWebSocketSession=e}function Ss(t,e,n,i,r){_.call(this,r),this.$controller=i,this.exceptionState_0=1,this.local$closure$event=t,this.local$this$JsWebSocketSession=e}function Ts(t,e,n,i){_.call(this,i),this.$controller=n,this.exceptionState_0=8,this.local$this$JsWebSocketSession=t,this.local$$receiver=void 0,this.local$cause=void 0,this.local$tmp$=void 0}function Os(t){this._value_0=t}Object.defineProperty(Ha.prototype,"config",{get:function(){return this.config_2md4la$_0}}),Object.defineProperty(Ha.prototype,"dispatcher",{get:function(){return this.dispatcher_j9yf5v$_0}}),Object.defineProperty(Ha.prototype,"supportedCapabilities",{get:function(){return this.supportedCapabilities_380cpg$_0}}),Ya.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Ya.prototype=Object.create(_.prototype),Ya.prototype.constructor=Ya,Ya.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=di(this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:if(this.local$callContext=this.result_0,Ro(this.local$data)){if(this.state_0=3,this.result_0=this.$this.executeWebSocketRequest_0(this.local$data,this.local$callContext,this),this.result_0===h)return h;continue}this.state_0=4;continue;case 3:return this.result_0;case 4:if(this.local$requestTime=ie(),this.state_0=5,this.result_0=is(this.local$data,this.local$callContext,this),this.result_0===h)return h;continue;case 5:var t=this.result_0;if(this.state_0=6,this.result_0=ms(this.local$data.url.toString(),t,this),this.result_0===h)return h;continue;case 6:var e=this.result_0,n=new kt(Ye(e.status),e.statusText),i=La(Xa(e.headers)),r=Ve.Companion.HTTP_1_1,o=$s(Ke(this.local$callContext),e);return new Ao(n,this.local$requestTime,i,r,o,this.local$callContext);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ha.prototype.execute_dkgphz$=function(t,e,n){var i=new Ya(this,t,e);return n?i:i.doResume(null)},Va.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Va.prototype=Object.create(_.prototype),Va.prototype.constructor=Va,Va.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.local$requestTime=ie(),this.local$urlString=this.local$request.url.toString(),t=ot.PlatformUtils.IS_NODE?new(n(Object(function(){var t=new Error("Cannot find module 'ws'");throw t.code="MODULE_NOT_FOUND",t}())))(this.local$urlString):new WebSocket(this.local$urlString),this.local$socket=t,this.exceptionState_0=2,this.state_0=1,this.result_0=(o=this.local$socket,a=void 0,s=void 0,s=new Wa(o,this),a?s:s.doResume(null)),this.result_0===h)return h;continue;case 1:this.exceptionState_0=4,this.state_0=3;continue;case 2:this.exceptionState_0=4;var i=this.exception_0;throw e.isType(i,T)?(We(this.local$callContext,new wt("Failed to connect to "+this.local$urlString,i)),i):i;case 3:var r=new Es(this.local$callContext,this.local$socket);return new Ao(kt.Companion.OK,this.local$requestTime,Ge.Companion.Empty,Ve.Companion.HTTP_1_1,r,this.local$callContext);case 4:throw this.exception_0;default:throw this.state_0=4,new Error("State Machine Unreachable execution")}}catch(t){if(4===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}var o,a,s},Ha.prototype.executeWebSocketRequest_0=function(t,e,n,i){var r=new Va(this,t,e,n);return i?r:r.doResume(null)},Ha.$metadata$={kind:g,simpleName:"JsClientEngine",interfaces:[ui]},Wa.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Wa.prototype=Object.create(_.prototype),Wa.prototype.constructor=Wa,Wa.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=Ga(Ka(this.local$$receiver))(this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0,this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(Za.prototype,"message",{get:function(){return this.message_9vnttw$_0}}),Object.defineProperty(Za.prototype,"cause",{get:function(){return this.cause_kdow7y$_0}}),Za.$metadata$={kind:g,simpleName:"JsError",interfaces:[T]},Qa.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Qa.prototype=Object.create(_.prototype),Qa.prototype.constructor=Qa,Qa.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$closure$content.writeTo_h3x4ir$(this.local$$receiver.channel,this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ns.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ns.prototype=Object.create(_.prototype),ns.prototype.constructor=ns,ns.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$jsHeaders={},fi(this.local$$receiver.headers,this.local$$receiver.body,Ja(this.local$jsHeaders));var t=this.local$$receiver.body;if(e.isType(t,lt)){this.local$tmp$=t.bytes(),this.state_0=6;continue}if(e.isType(t,ut)){if(this.state_0=4,this.result_0=F(t.readFrom(),this),this.result_0===h)return h;continue}if(e.isType(t,Pe)){if(this.state_0=2,this.result_0=F(xt(Xe.GlobalScope,this.local$callContext,void 0,ts(t)).channel,this),this.result_0===h)return h;continue}this.local$tmp$=null,this.state_0=3;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=q(this.result_0),this.state_0=3;continue;case 3:this.state_0=5;continue;case 4:this.local$tmp$=q(this.result_0),this.state_0=5;continue;case 5:this.state_0=6;continue;case 6:var n=this.local$tmp$;return rs(es(this.local$$receiver,this.local$jsHeaders,n));default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ss.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ss.prototype=Object.create(_.prototype),ss.prototype.constructor=ss,ss.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=os(as(this.local$$receiver))(this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0,this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ps.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ps.prototype=Object.create(_.prototype),ps.prototype.constructor=ps,ps.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$reader=this.local$closure$stream.getReader(),this.state_0=1;continue;case 1:if(this.exceptionState_0=6,this.state_0=2,this.result_0=ls(this.local$reader,this),this.result_0===h)return h;continue;case 2:if(this.local$tmp$=this.result_0,null==this.local$tmp$){this.exceptionState_0=6,this.state_0=5;continue}this.state_0=3;continue;case 3:var t=this.local$tmp$;if(this.state_0=4,this.result_0=Oe(this.local$$receiver.channel,us(t),this),this.result_0===h)return h;continue;case 4:this.exceptionState_0=8,this.state_0=7;continue;case 5:return u;case 6:this.exceptionState_0=8;var n=this.exception_0;throw e.isType(n,T)?(this.local$reader.cancel(n),n):n;case 7:this.state_0=1;continue;case 8:throw this.exception_0;default:throw this.state_0=8,new Error("State Machine Unreachable execution")}}catch(t){if(8===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ds.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ds.prototype=Object.create(_.prototype),ds.prototype.constructor=ds,ds.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=_s(fs(this.local$init,this.local$input))(this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.result_0,this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ws.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},ws.prototype=Object.create(_.prototype),ws.prototype.constructor=ws,ws.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n;if(null==(t=this.local$closure$response.body))throw w("Fail to get body".toString());n=t,this.local$body=n;var i=on(1);this.local$body.on("data",vs(i,this.local$body)),this.local$body.on("error",gs(i,this.local$$receiver)),this.local$body.on("end",bs(i)),this.exceptionState_0=6,this.local$tmp$_0=i.iterator(),this.state_0=1;continue;case 1:if(this.state_0=2,this.result_0=this.local$tmp$_0.hasNext(this),this.result_0===h)return h;continue;case 2:if(this.result_0){this.state_0=3;continue}this.state_0=5;continue;case 3:var r=this.local$tmp$_0.next();if(this.state_0=4,this.result_0=Oe(this.local$$receiver.channel,r,this),this.result_0===h)return h;continue;case 4:this.local$body.resume(),this.state_0=1;continue;case 5:this.exceptionState_0=8,this.state_0=7;continue;case 6:this.exceptionState_0=8;var o=this.exception_0;throw e.isType(o,T)?(this.local$body.destroy(o),o):o;case 7:return u;case 8:throw this.exception_0;default:throw this.state_0=8,new Error("State Machine Unreachable execution")}}catch(t){if(8===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(Es.prototype,"coroutineContext",{get:function(){return this.coroutineContext_x6mio4$_0}}),Object.defineProperty(Es.prototype,"incoming",{get:function(){return this.incoming_115vn1$_0}}),Object.defineProperty(Es.prototype,"outgoing",{get:function(){return this.outgoing_ex3pqx$_0}}),Object.defineProperty(Es.prototype,"closeReason",{get:function(){return this.closeReason_n5pjc5$_0}}),Es.prototype.flush=function(t){},Es.prototype.terminate=function(){this._incoming_0.cancel_m4sck1$(),this._outgoing_0.cancel_m4sck1$(),Zt(this._closeReason_0,"WebSocket terminated"),this.websocket_0.close()},Cs.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Cs.prototype=Object.create(_.prototype),Cs.prototype.constructor=Cs,Cs.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n=this.local$closure$event.data;if(e.isType(n,ArrayBuffer))t=new sn(!1,new Int8Array(n));else{if("string"!=typeof n){var i=w("Unknown frame type: "+this.local$closure$event.type);throw this.local$this$JsWebSocketSession._closeReason_0.completeExceptionally_tcv7n7$(i),i}t=ln(n)}var r=t;return this.local$this$JsWebSocketSession._incoming_0.offer_11rb$(r);case 1:throw this.exception_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ss.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Ss.prototype=Object.create(_.prototype),Ss.prototype.constructor=Ss,Ss.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,e,n=new un("number"==typeof(t=this.local$closure$event.code)?t:f(),"string"==typeof(e=this.local$closure$event.reason)?e:f());if(this.local$this$JsWebSocketSession._closeReason_0.complete_11rb$(n),this.state_0=2,this.result_0=this.local$this$JsWebSocketSession._incoming_0.send_11rb$(cn(n),this),this.result_0===h)return h;continue;case 1:throw this.exception_0;case 2:return this.local$this$JsWebSocketSession._incoming_0.close_dbl4no$(),this.local$this$JsWebSocketSession._outgoing_0.cancel_m4sck1$(),u;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ts.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[_]},Ts.prototype=Object.create(_.prototype),Ts.prototype.constructor=Ts,Ts.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$$receiver=this.local$this$JsWebSocketSession._outgoing_0,this.local$cause=null,this.exceptionState_0=5,this.local$tmp$=this.local$$receiver.iterator(),this.state_0=1;continue;case 1:if(this.state_0=2,this.result_0=this.local$tmp$.hasNext(this),this.result_0===h)return h;continue;case 2:if(this.result_0){this.state_0=3;continue}this.state_0=4;continue;case 3:var t,n=this.local$tmp$.next(),i=this.local$this$JsWebSocketSession;switch(n.frameType.name){case"TEXT":var r=n.data;i.websocket_0.send(pn(r));break;case"BINARY":var o=e.isType(t=n.data,Int8Array)?t:f(),a=o.buffer.slice(o.byteOffset,o.byteOffset+o.byteLength|0);i.websocket_0.send(a);break;case"CLOSE":var s,l=Ae(0);try{Le(l,n.data),s=l.build()}catch(t){throw e.isType(t,T)?(l.release(),t):t}var c=s,p=hn(c),_=c.readText_vux9f0$();i._closeReason_0.complete_11rb$(new un(p,_)),i.websocket_0.close(p,_)}this.state_0=1;continue;case 4:this.exceptionState_0=8,this.finallyPath_0=[7],this.state_0=6;continue;case 5:this.finallyPath_0=[8],this.exceptionState_0=6;var d=this.exception_0;throw e.isType(d,T)?(this.local$cause=d,d):d;case 6:this.exceptionState_0=8,fn(this.local$$receiver,this.local$cause),this.state_0=this.finallyPath_0.shift();continue;case 7:return this.result_0=u,this.result_0;case 8:throw this.exception_0;default:throw this.state_0=8,new Error("State Machine Unreachable execution")}}catch(t){if(8===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Es.$metadata$={kind:g,simpleName:"JsWebSocketSession",interfaces:[ue]},Object.defineProperty(Os.prototype,"value",{get:function(){return this._value_0}}),Os.prototype.compareAndSet_dqye30$=function(t,e){return this._value_0===t&&(this._value_0=e,!0)},Os.$metadata$={kind:g,simpleName:"AtomicBoolean",interfaces:[]};var Ns=t.io||(t.io={}),Ps=Ns.ktor||(Ns.ktor={}),As=Ps.client||(Ps.client={});As.HttpClient_744i18$=mn,As.HttpClient=yn,As.HttpClientConfig=bn;var js=As.call||(As.call={});js.HttpClientCall_iofdyz$=En,Object.defineProperty(Cn,"Companion",{get:jn}),js.HttpClientCall=Cn,js.HttpEngineCall=Ln,js.call_htnejk$=function(t,e,n){throw void 0===e&&(e=In),w("Unbound [HttpClientCall] is deprecated. Consider using [request(block)] in instead.".toString())},js.DoubleReceiveException=zn,js.ReceivePipelineException=Dn,js.NoTransformationFoundException=Mn,js.SavedHttpCall=Un,js.SavedHttpRequest=Fn,js.SavedHttpResponse=qn,js.save_iicrl5$=Hn,js.TypeInfo=Yn,js.UnsupportedContentTypeException=Vn,js.UnsupportedUpgradeProtocolException=Kn,js.call_30bfl5$=function(t,e,n){throw w("Unbound [HttpClientCall] is deprecated. Consider using [request(builder)] instead.".toString())},js.call_1t1q32$=function(t,e,n,i){throw void 0===n&&(n=Xn),w("Unbound [HttpClientCall] is deprecated. Consider using [request(urlString, block)] instead.".toString())},js.call_p7i9r1$=function(t,e,n,i){throw void 0===n&&(n=Jn),w("Unbound [HttpClientCall] is deprecated. Consider using [request(url, block)] instead.".toString())};var Ls=As.engine||(As.engine={});Ls.HttpClientEngine=ei,Ls.HttpClientEngineFactory=ai,Ls.HttpClientEngineBase=ui,Ls.ClientEngineClosedException=pi,Ls.HttpClientEngineCapability=hi,Ls.HttpClientEngineConfig=_i,Ls.mergeHeaders_kqv6tz$=fi,Ls.callContext=di,Object.defineProperty(mi,"Companion",{get:gi}),Ls.KtorCallContextElement=mi,l["kotlinx-coroutines-core"]=i;var Rs=As.features||(As.features={});Rs.addDefaultResponseValidation_bbdm9p$=ki,Rs.ResponseException=Ei,Rs.RedirectResponseException=Ci,Rs.ServerResponseException=Si,Rs.ClientRequestException=Ti,Rs.defaultTransformers_ejcypf$=zi,Di.Config=Ui,Object.defineProperty(Di,"Companion",{get:Vi}),Rs.HttpCallValidator=Di,Rs.HttpResponseValidator_jqt3w2$=Ki,Rs.HttpClientFeature=Wi,Rs.feature_ccg70z$=Zi,nr.Config=ir,Object.defineProperty(nr,"Feature",{get:ur}),Rs.HttpPlainText=nr,Object.defineProperty(hr,"Feature",{get:yr}),Rs.HttpRedirect=hr,Object.defineProperty(vr,"Feature",{get:kr}),Rs.HttpRequestLifecycle=vr,Rs.Sender=Er,Object.defineProperty(Cr,"Feature",{get:Pr}),Rs.HttpSend=Cr,Rs.SendCountExceedException=Lr,Object.defineProperty(Ir,"Companion",{get:Mr}),Rr.HttpTimeoutCapabilityConfiguration_init_oq4a4q$=Br,Rr.HttpTimeoutCapabilityConfiguration=Ir,Object.defineProperty(Rr,"Feature",{get:Kr}),Rs.HttpTimeout=Rr,Rs.HttpRequestTimeoutException=Wr,l["ktor-ktor-http"]=a,l["ktor-ktor-utils"]=r;var Is=Rs.websocket||(Rs.websocket={});Is.ClientWebSocketSession=Xr,Is.DefaultClientWebSocketSession=Zr,Is.DelegatingClientWebSocketSession=Jr,Is.WebSocketContent=Qr,Object.defineProperty(to,"Feature",{get:ao}),Is.WebSockets=to,Is.WebSocketException=so,Is.webSocket_5f0jov$=ho,Is.webSocket_c3wice$=yo,Is.webSocket_xhesox$=function(t,e,n,i,r,o){var a=new go(t,e,n,i,r);return o?a:a.doResume(null)};var zs=As.request||(As.request={});zs.ClientUpgradeContent=bo,zs.DefaultHttpRequest=ko,zs.HttpRequest=Eo,Object.defineProperty(Co,"Companion",{get:No}),zs.HttpRequestBuilder=Co,zs.HttpRequestData=Po,zs.HttpResponseData=Ao,zs.url_3rzbk2$=Lo,zs.url_g8iu3v$=function(t,e){Kt(t.url,e)},zs.isUpgradeRequest_5kadeu$=Ro,Object.defineProperty(Io,"Phases",{get:Mo}),zs.HttpRequestPipeline=Io,Object.defineProperty(Bo,"Phases",{get:Go}),zs.HttpSendPipeline=Bo,zs.url_qpqkqe$=function(t,e){Ce(t.url,e)};var Ds=As.utils||(As.utils={});l["ktor-ktor-io"]=o;var Ms=zs.forms||(zs.forms={});Ms.FormDataContent=Ho,Ms.MultiPartFormDataContent=Yo,zs.get_port_ocert9$=Qo;var Bs=As.statement||(As.statement={});Bs.DefaultHttpResponse=ta,Bs.HttpResponse=ea,Bs.get_request_abn2de$=na,Bs.complete_abn2de$=ia,Object.defineProperty(ra,"Phases",{get:sa}),Bs.HttpResponsePipeline=ra,Object.defineProperty(la,"Phases",{get:_a}),Bs.HttpReceivePipeline=la,Bs.HttpResponseContainer=fa,Bs.HttpStatement=da,Object.defineProperty(Ds,"DEFAULT_HTTP_POOL_SIZE",{get:function(){return ca}}),Object.defineProperty(Ds,"DEFAULT_HTTP_BUFFER_SIZE",{get:function(){return pa}}),Object.defineProperty(Ds,"EmptyContent",{get:Ea}),Ds.wrapHeaders_j1n6iz$=function(t,n){return e.isType(t,ne)?new Ca(t,n):e.isType(t,ut)?new Sa(t,n):e.isType(t,Pe)?new Ta(t,n):e.isType(t,lt)?new Oa(t,n):e.isType(t,He)?new Na(t,n):e.noWhenBranchMatched()},Object.defineProperty(Ds,"CacheControl",{get:function(){return null===Aa&&new Pa,Aa}}),Ds.buildHeaders_g6xk4w$=La,As.HttpClient_f0veat$=function(t){return void 0===t&&(t=Ra),mn(qa(),t)},js.Type=Ia,Object.defineProperty(js,"JsType",{get:function(){return null===Da&&new za,Da}}),js.instanceOf_ofcvxk$=Ma;var Us=Ls.js||(Ls.js={});Object.defineProperty(Us,"Js",{get:Fa}),Us.JsClient=qa,Us.JsClientEngine=Ha,Us.JsError=Za,Us.toRaw_lu1yd6$=is,Us.buildObject_ymnom6$=rs,Us.readChunk_pggmy1$=ls,Us.asByteArray_es0py6$=us;var Fs=Us.browser||(Us.browser={});Fs.readBodyBrowser_katr0q$=cs,Fs.channelFromStream_xaoqny$=hs;var qs=Us.compatibility||(Us.compatibility={});return qs.commonFetch_gzh8gj$=ms,qs.AbortController_8be2vx$=ys,qs.readBody_katr0q$=$s,(Us.node||(Us.node={})).readBodyNode_katr0q$=xs,Rs.platformDefaultTransformers_h1fxjk$=ks,Is.JsWebSocketSession=Es,Ds.AtomicBoolean=Os,ai.prototype.create_dxyxif$,Object.defineProperty(ui.prototype,"supportedCapabilities",Object.getOwnPropertyDescriptor(ei.prototype,"supportedCapabilities")),Object.defineProperty(ui.prototype,"closed_yj5g8o$_0",Object.getOwnPropertyDescriptor(ei.prototype,"closed_yj5g8o$_0")),ui.prototype.install_k5i6f8$=ei.prototype.install_k5i6f8$,ui.prototype.executeWithinCallContext_2kaaho$_0=ei.prototype.executeWithinCallContext_2kaaho$_0,ui.prototype.checkExtensions_1320zn$_0=ei.prototype.checkExtensions_1320zn$_0,ui.prototype.createCallContext_bk2bfg$_0=ei.prototype.createCallContext_bk2bfg$_0,mi.prototype.fold_3cc69b$=rt.prototype.fold_3cc69b$,mi.prototype.get_j3r2sn$=rt.prototype.get_j3r2sn$,mi.prototype.minusKey_yeqjby$=rt.prototype.minusKey_yeqjby$,mi.prototype.plus_1fupul$=rt.prototype.plus_1fupul$,Wi.prototype.prepare_oh3mgy$,Wi.prototype.prepare_oh3mgy$,Fi.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,rr.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,_r.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,gr.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,Tr.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,Ur.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,Wi.prototype.prepare_oh3mgy$,Wi.prototype.prepare_oh3mgy$,Wi.prototype.prepare_oh3mgy$,Wi.prototype.prepare_oh3mgy$,Xr.prototype.send_x9o3m3$=le.prototype.send_x9o3m3$,eo.prototype.prepare_oh3mgy$=Wi.prototype.prepare_oh3mgy$,Object.defineProperty(ko.prototype,"executionContext",Object.getOwnPropertyDescriptor(Eo.prototype,"executionContext")),Ba.prototype.create_dxyxif$=ai.prototype.create_dxyxif$,Object.defineProperty(Ha.prototype,"closed_yj5g8o$_0",Object.getOwnPropertyDescriptor(ei.prototype,"closed_yj5g8o$_0")),Ha.prototype.executeWithinCallContext_2kaaho$_0=ei.prototype.executeWithinCallContext_2kaaho$_0,Ha.prototype.checkExtensions_1320zn$_0=ei.prototype.checkExtensions_1320zn$_0,Ha.prototype.createCallContext_bk2bfg$_0=ei.prototype.createCallContext_bk2bfg$_0,Es.prototype.send_x9o3m3$=ue.prototype.send_x9o3m3$,On=new Y("call-context"),Nn=new d("EngineCapabilities"),et(Kr()),Pn="Ktor client",$i=new d("ValidateMark"),Hi=new d("ApplicationFeatureRegistry"),sr=Yt([Ht.Companion.Get,Ht.Companion.Head]),Yr="13",Fo=Fe(Nt.Charsets.UTF_8.newEncoder(),"\r\n",0,"\r\n".length),ca=1e3,pa=4096,t})?i.apply(e,r):i)||(t.exports=o)},804:function(t,e,n){var i,r,o;r=[e,n(421),n(267),n(276),n(197)],void 0===(o="function"==typeof(i=function(t,e,n,i,r){"use strict";var o=t.$$importsForInline$$||(t.$$importsForInline$$={}),a=(e.kotlin.sequences.map_z5avom$,e.kotlin.sequences.toList_veqyi0$,e.kotlin.ranges.until_dqglrj$,e.kotlin.collections.toSet_7wnvza$,e.kotlin.collections.listOf_mh5how$,e.Kind.CLASS),s=(e.kotlin.collections.Map.Entry,e.kotlin.LazyThreadSafetyMode),l=(e.kotlin.collections.LinkedHashSet_init_ww73n8$,e.kotlin.lazy_kls4a0$),u=n.io.ktor.http.Headers,c=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,p=e.kotlin.collections.ArrayList_init_ww73n8$,h=e.kotlin.text.StringBuilder_init_za3lpa$,_=(e.kotlin.Unit,i.io.ktor.utils.io.pool.DefaultPool),f=e.Long.NEG_ONE,d=e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED,m=e.kotlin.coroutines.CoroutineImpl,y=(i.io.ktor.utils.io.writer_x9a1ni$,e.Long.ZERO,i.io.ktor.utils.io.errors.EOFException,e.equals,i.io.ktor.utils.io.cancel_3dmw3p$,i.io.ktor.utils.io.copyTo_47ygvz$,Error),$=(i.io.ktor.utils.io.close_x5qia6$,r.kotlinx.coroutines,i.io.ktor.utils.io.reader_ps9zta$,i.io.ktor.utils.io.core.IoBuffer,i.io.ktor.utils.io.writeFully_4scpqu$,i.io.ktor.utils.io.core.Buffer,e.throwCCE,i.io.ktor.utils.io.core.writeShort_cx5lgg$,i.io.ktor.utils.io.charsets),v=i.io.ktor.utils.io.charsets.encodeToByteArray_fj4osb$,g=e.kotlin.collections.ArrayList_init_287e2$,b=e.kotlin.collections.emptyList_287e2$,w=(e.kotlin.to_ujzrz7$,e.kotlin.collections.listOf_i5x0yv$),x=e.toBoxedChar,k=e.Kind.OBJECT,E=(e.kotlin.collections.joinTo_gcc71v$,e.hashCode,e.kotlin.text.StringBuilder_init,n.io.ktor.http.HttpMethod),C=(e.toString,e.kotlin.IllegalStateException_init_pdl1vj$),S=(e.Long.MAX_VALUE,e.kotlin.sequences.filter_euau3h$,e.kotlin.NotImplementedError,e.kotlin.IllegalArgumentException_init_pdl1vj$),T=(e.kotlin.Exception_init_pdl1vj$,e.kotlin.Exception,e.unboxChar),O=(e.kotlin.ranges.CharRange,e.kotlin.NumberFormatException,e.kotlin.text.contains_sgbm27$,i.io.ktor.utils.io.core.Closeable,e.kotlin.NoSuchElementException),N=Array,P=e.toChar,A=e.kotlin.collections.Collection,j=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,L=e.ensureNotNull,R=(e.kotlin.CharSequence,e.kotlin.IndexOutOfBoundsException,e.kotlin.text.Appendable,Math,e.kotlin.ranges.IntRange),I=e.Long.fromInt(48),z=e.Long.fromInt(97),D=e.Long.fromInt(102),M=e.Long.fromInt(65),B=e.Long.fromInt(70),U=e.kotlin.collections.toLongArray_558emf$,F=e.toByte,q=e.kotlin.collections.toByteArray_kdx1v$,G=e.kotlin.Enum,H=e.throwISE,Y=e.kotlin.collections.mapCapacity_za3lpa$,V=e.kotlin.ranges.coerceAtLeast_dqglrj$,K=e.kotlin.collections.LinkedHashMap_init_bwtc7$,W=i.io.ktor.utils.io.core.writeFully_i6snlg$,X=i.io.ktor.utils.io.charsets.decode_lb8wo3$,Z=(i.io.ktor.utils.io.core.readShort_7wsnj1$,r.kotlinx.coroutines.DisposableHandle),J=i.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,Q=e.kotlin.collections.get_lastIndex_m7z4lg$,tt=(e.defineInlineFunction,e.wrapFunction,e.kotlin.Annotation,r.kotlinx.coroutines.CancellationException,e.Kind.INTERFACE),et=i.io.ktor.utils.io.core.readBytes_xc9h3n$,nt=i.io.ktor.utils.io.core.writeShort_9kfkzl$,it=r.kotlinx.coroutines.CoroutineScope;function rt(t){this.headers_0=t,this.names_pj02dq$_0=l(s.NONE,CIOHeaders$names$lambda(this))}function ot(t){_.call(this,t)}function at(t){_.call(this,t)}function st(t){kt(),this.root=t}function lt(t,e,n){this.ch=x(t),this.exact=e,this.children=n;var i,r=N(256);i=r.length-1|0;for(var o=0;o<=i;o++){var a,s=this.children;t:do{var l,u=null,c=!1;for(l=s.iterator();l.hasNext();){var p=l.next();if((0|T(p.ch))===o){if(c){a=null;break t}u=p,c=!0}}if(!c){a=null;break t}a=u}while(0);r[o]=a}this.array=r}function ut(){xt=this}function ct(t){return t.length}function pt(t,e){return x(t.charCodeAt(e))}ot.prototype=Object.create(_.prototype),ot.prototype.constructor=ot,at.prototype=Object.create(_.prototype),at.prototype.constructor=at,Et.prototype=Object.create(_.prototype),Et.prototype.constructor=Et,St.prototype=Object.create(G.prototype),St.prototype.constructor=St,Qt.prototype=Object.create(G.prototype),Qt.prototype.constructor=Qt,_e.prototype=Object.create(he.prototype),_e.prototype.constructor=_e,fe.prototype=Object.create(he.prototype),fe.prototype.constructor=fe,de.prototype=Object.create(he.prototype),de.prototype.constructor=de,$e.prototype=Object.create(he.prototype),$e.prototype.constructor=$e,ve.prototype=Object.create(he.prototype),ve.prototype.constructor=ve,ot.prototype.produceInstance=function(){return h(128)},ot.prototype.clearInstance_trkh7z$=function(t){return t.clear(),t},ot.$metadata$={kind:a,interfaces:[_]},at.prototype.produceInstance=function(){return new Int32Array(512)},at.$metadata$={kind:a,interfaces:[_]},lt.$metadata$={kind:a,simpleName:"Node",interfaces:[]},st.prototype.search_5wmzmj$=function(t,e,n,i,r){var o,a;if(void 0===e&&(e=0),void 0===n&&(n=t.length),void 0===i&&(i=!1),0===t.length)throw S("Couldn't search in char tree for empty string");for(var s=this.root,l=e;l$&&b.add_11rb$(w)}this.build_0(v,b,n,$,r,o),v.trimToSize();var x,k=g();for(x=y.iterator();x.hasNext();){var E=x.next();r(E)===$&&k.add_11rb$(E)}t.add_11rb$(new lt(m,k,v))}},ut.$metadata$={kind:k,simpleName:"Companion",interfaces:[]};var ht,_t,ft,dt,mt,yt,$t,vt,gt,bt,wt,xt=null;function kt(){return null===xt&&new ut,xt}function Et(t){_.call(this,t)}function Ct(t,e){this.code=t,this.message=e}function St(t,e,n){G.call(this),this.code=n,this.name$=t,this.ordinal$=e}function Tt(){Tt=function(){},ht=new St("NORMAL",0,1e3),_t=new St("GOING_AWAY",1,1001),ft=new St("PROTOCOL_ERROR",2,1002),dt=new St("CANNOT_ACCEPT",3,1003),mt=new St("NOT_CONSISTENT",4,1007),yt=new St("VIOLATED_POLICY",5,1008),$t=new St("TOO_BIG",6,1009),vt=new St("NO_EXTENSION",7,1010),gt=new St("INTERNAL_ERROR",8,1011),bt=new St("SERVICE_RESTART",9,1012),wt=new St("TRY_AGAIN_LATER",10,1013),Ft()}function Ot(){return Tt(),ht}function Nt(){return Tt(),_t}function Pt(){return Tt(),ft}function At(){return Tt(),dt}function jt(){return Tt(),mt}function Lt(){return Tt(),yt}function Rt(){return Tt(),$t}function It(){return Tt(),vt}function zt(){return Tt(),gt}function Dt(){return Tt(),bt}function Mt(){return Tt(),wt}function Bt(){Ut=this;var t,e=qt(),n=V(Y(e.length),16),i=K(n);for(t=0;t!==e.length;++t){var r=e[t];i.put_xwzc9p$(r.code,r)}this.byCodeMap_0=i,this.UNEXPECTED_CONDITION=zt()}st.$metadata$={kind:a,simpleName:"AsciiCharTree",interfaces:[]},Et.prototype.produceInstance=function(){return e.charArray(2048)},Et.$metadata$={kind:a,interfaces:[_]},Object.defineProperty(Ct.prototype,"knownReason",{get:function(){return Ft().byCode_mq22fl$(this.code)}}),Ct.prototype.toString=function(){var t;return"CloseReason(reason="+(null!=(t=this.knownReason)?t:this.code).toString()+", message="+this.message+")"},Bt.prototype.byCode_mq22fl$=function(t){return this.byCodeMap_0.get_11rb$(t)},Bt.$metadata$={kind:k,simpleName:"Companion",interfaces:[]};var Ut=null;function Ft(){return Tt(),null===Ut&&new Bt,Ut}function qt(){return[Ot(),Nt(),Pt(),At(),jt(),Lt(),Rt(),It(),zt(),Dt(),Mt()]}function Gt(t,e,n){return n=n||Object.create(Ct.prototype),Ct.call(n,t.code,e),n}function Ht(){Zt=this}St.$metadata$={kind:a,simpleName:"Codes",interfaces:[G]},St.values=qt,St.valueOf_61zpoe$=function(t){switch(t){case"NORMAL":return Ot();case"GOING_AWAY":return Nt();case"PROTOCOL_ERROR":return Pt();case"CANNOT_ACCEPT":return At();case"NOT_CONSISTENT":return jt();case"VIOLATED_POLICY":return Lt();case"TOO_BIG":return Rt();case"NO_EXTENSION":return It();case"INTERNAL_ERROR":return zt();case"SERVICE_RESTART":return Dt();case"TRY_AGAIN_LATER":return Mt();default:H("No enum constant io.ktor.http.cio.websocket.CloseReason.Codes."+t)}},Ct.$metadata$={kind:a,simpleName:"CloseReason",interfaces:[]},Ct.prototype.component1=function(){return this.code},Ct.prototype.component2=function(){return this.message},Ct.prototype.copy_qid81t$=function(t,e){return new Ct(void 0===t?this.code:t,void 0===e?this.message:e)},Ct.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.code)|0)+e.hashCode(this.message)|0},Ct.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.code,t.code)&&e.equals(this.message,t.message)},Ht.prototype.dispose=function(){},Ht.prototype.toString=function(){return"NonDisposableHandle"},Ht.$metadata$={kind:k,simpleName:"NonDisposableHandle",interfaces:[Z]};var Yt,Vt,Kt,Wt,Xt,Zt=null;function Jt(){return null===Zt&&new Ht,Zt}function Qt(t,e,n,i){G.call(this),this.controlFrame=n,this.opcode=i,this.name$=t,this.ordinal$=e}function te(){te=function(){},Yt=new Qt("TEXT",0,!1,1),Vt=new Qt("BINARY",1,!1,2),Kt=new Qt("CLOSE",2,!0,8),Wt=new Qt("PING",3,!0,9),Xt=new Qt("PONG",4,!0,10),le()}function ee(){return te(),Yt}function ne(){return te(),Vt}function ie(){return te(),Kt}function re(){return te(),Wt}function oe(){return te(),Xt}function ae(){se=this;var t,n=ue();t:do{if(0===n.length){t=null;break t}var i=n[0],r=Q(n);if(0===r){t=i;break t}for(var o=i.opcode,a=1;a<=r;a++){var s=n[a],l=s.opcode;e.compareTo(o,l)<0&&(i=s,o=l)}t=i}while(0);this.maxOpcode_0=L(t).opcode;var u,c=N(this.maxOpcode_0+1|0);u=c.length-1|0;for(var p=0;p<=u;p++){var h,_=ue();t:do{var f,d=null,m=!1;for(f=0;f!==_.length;++f){var y=_[f];if(y.opcode===p){if(m){h=null;break t}d=y,m=!0}}if(!m){h=null;break t}h=d}while(0);c[p]=h}this.byOpcodeArray_0=c}ae.prototype.get_za3lpa$=function(t){var e;return e=this.maxOpcode_0,0<=t&&t<=e?this.byOpcodeArray_0[t]:null},ae.$metadata$={kind:k,simpleName:"Companion",interfaces:[]};var se=null;function le(){return te(),null===se&&new ae,se}function ue(){return[ee(),ne(),ie(),re(),oe()]}function ce(t,e,n){m.call(this,n),this.exceptionState_0=5,this.local$$receiver=t,this.local$reason=e}function pe(){}function he(t,e,n,i){we(),void 0===i&&(i=Jt()),this.fin=t,this.frameType=e,this.data=n,this.disposableHandle=i}function _e(t,e){he.call(this,t,ne(),e)}function fe(t,e){he.call(this,t,ee(),e)}function de(t){he.call(this,!0,ie(),t)}function me(t,n){var i;n=n||Object.create(de.prototype);var r=J(0);try{nt(r,t.code),r.writeStringUtf8_61zpoe$(t.message),i=r.build()}catch(t){throw e.isType(t,y)?(r.release(),t):t}return ye(i,n),n}function ye(t,e){return e=e||Object.create(de.prototype),de.call(e,et(t)),e}function $e(t){he.call(this,!0,re(),t)}function ve(t,e){void 0===e&&(e=Jt()),he.call(this,!0,oe(),t,e)}function ge(){be=this,this.Empty_0=new Int8Array(0)}Qt.$metadata$={kind:a,simpleName:"FrameType",interfaces:[G]},Qt.values=ue,Qt.valueOf_61zpoe$=function(t){switch(t){case"TEXT":return ee();case"BINARY":return ne();case"CLOSE":return ie();case"PING":return re();case"PONG":return oe();default:H("No enum constant io.ktor.http.cio.websocket.FrameType."+t)}},ce.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[m]},ce.prototype=Object.create(m.prototype),ce.prototype.constructor=ce,ce.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(void 0===this.local$reason&&(this.local$reason=Gt(Ot(),"")),this.exceptionState_0=3,this.state_0=1,this.result_0=this.local$$receiver.send_x9o3m3$(me(this.local$reason),this),this.result_0===d)return d;continue;case 1:if(this.state_0=2,this.result_0=this.local$$receiver.flush(this),this.result_0===d)return d;continue;case 2:this.exceptionState_0=5,this.state_0=4;continue;case 3:this.exceptionState_0=5;var t=this.exception_0;if(!e.isType(t,y))throw t;this.state_0=4;continue;case 4:return;case 5:throw this.exception_0;default:throw this.state_0=5,new Error("State Machine Unreachable execution")}}catch(t){if(5===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},pe.$metadata$={kind:tt,simpleName:"DefaultWebSocketSession",interfaces:[xe]},_e.$metadata$={kind:a,simpleName:"Binary",interfaces:[he]},fe.$metadata$={kind:a,simpleName:"Text",interfaces:[he]},de.$metadata$={kind:a,simpleName:"Close",interfaces:[he]},$e.$metadata$={kind:a,simpleName:"Ping",interfaces:[he]},ve.$metadata$={kind:a,simpleName:"Pong",interfaces:[he]},he.prototype.toString=function(){return"Frame "+this.frameType+" (fin="+this.fin+", buffer len = "+this.data.length+")"},he.prototype.copy=function(){return we().byType_8ejoj4$(this.fin,this.frameType,this.data.slice())},ge.prototype.byType_8ejoj4$=function(t,n,i){switch(n.name){case"BINARY":return new _e(t,i);case"TEXT":return new fe(t,i);case"CLOSE":return new de(i);case"PING":return new $e(i);case"PONG":return new ve(i);default:return e.noWhenBranchMatched()}},ge.$metadata$={kind:k,simpleName:"Companion",interfaces:[]};var be=null;function we(){return null===be&&new ge,be}function xe(){}function ke(t,e,n){m.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$frame=e}he.$metadata$={kind:a,simpleName:"Frame",interfaces:[]},ke.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[m]},ke.prototype=Object.create(m.prototype),ke.prototype.constructor=ke,ke.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.outgoing.send_11rb$(this.local$frame,this),this.result_0===d)return d;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},xe.prototype.send_x9o3m3$=function(t,e,n){var i=new ke(this,t,e);return n?i:i.doResume(null)},xe.$metadata$={kind:tt,simpleName:"WebSocketSession",interfaces:[it]};var Ee=t.io||(t.io={}),Ce=Ee.ktor||(Ee.ktor={}),Se=Ce.http||(Ce.http={}),Te=Se.cio||(Se.cio={});Te.CIOHeaders=rt,o["ktor-ktor-io"]=i,st.Node=lt,Object.defineProperty(st,"Companion",{get:kt}),(Te.internals||(Te.internals={})).AsciiCharTree=st,Object.defineProperty(St,"NORMAL",{get:Ot}),Object.defineProperty(St,"GOING_AWAY",{get:Nt}),Object.defineProperty(St,"PROTOCOL_ERROR",{get:Pt}),Object.defineProperty(St,"CANNOT_ACCEPT",{get:At}),Object.defineProperty(St,"NOT_CONSISTENT",{get:jt}),Object.defineProperty(St,"VIOLATED_POLICY",{get:Lt}),Object.defineProperty(St,"TOO_BIG",{get:Rt}),Object.defineProperty(St,"NO_EXTENSION",{get:It}),Object.defineProperty(St,"INTERNAL_ERROR",{get:zt}),Object.defineProperty(St,"SERVICE_RESTART",{get:Dt}),Object.defineProperty(St,"TRY_AGAIN_LATER",{get:Mt}),Object.defineProperty(St,"Companion",{get:Ft}),Ct.Codes=St;var Oe=Te.websocket||(Te.websocket={});Oe.CloseReason_init_ia8ci6$=Gt,Oe.CloseReason=Ct,Oe.readText_2pdr7t$=function(t){if(!t.fin)throw S("Text could be only extracted from non-fragmented frame".toString());var n,i=$.Charsets.UTF_8.newDecoder(),r=J(0);try{W(r,t.data),n=r.build()}catch(t){throw e.isType(t,y)?(r.release(),t):t}return X(i,n)},Oe.readBytes_y4xpne$=function(t){return t.data.slice()},Object.defineProperty(Oe,"NonDisposableHandle",{get:Jt}),Object.defineProperty(Qt,"TEXT",{get:ee}),Object.defineProperty(Qt,"BINARY",{get:ne}),Object.defineProperty(Qt,"CLOSE",{get:ie}),Object.defineProperty(Qt,"PING",{get:re}),Object.defineProperty(Qt,"PONG",{get:oe}),Object.defineProperty(Qt,"Companion",{get:le}),Oe.FrameType=Qt,Oe.close_icv0wc$=function(t,e,n,i){var r=new ce(t,e,n);return i?r:r.doResume(null)},Oe.DefaultWebSocketSession=pe,Oe.DefaultWebSocketSession_23cfxb$=function(t,e,n){throw C("There is no CIO js websocket implementation. Consider using platform default.".toString())},he.Binary_init_cqnnqj$=function(t,e,n){return n=n||Object.create(_e.prototype),_e.call(n,t,et(e)),n},he.Binary=_e,he.Text_init_61zpoe$=function(t,e){return e=e||Object.create(fe.prototype),fe.call(e,!0,v($.Charsets.UTF_8.newEncoder(),t,0,t.length)),e},he.Text_init_cqnnqj$=function(t,e,n){return n=n||Object.create(fe.prototype),fe.call(n,t,et(e)),n},he.Text=fe,he.Close_init_p695es$=me,he.Close_init_3uq2w4$=ye,he.Close_init=function(t){return t=t||Object.create(de.prototype),de.call(t,we().Empty_0),t},he.Close=de,he.Ping_init_3uq2w4$=function(t,e){return e=e||Object.create($e.prototype),$e.call(e,et(t)),e},he.Ping=$e,he.Pong_init_3uq2w4$=function(t,e){return e=e||Object.create(ve.prototype),ve.call(e,et(t)),e},he.Pong=ve,Object.defineProperty(he,"Companion",{get:we}),Oe.Frame=he,Oe.WebSocketSession=xe,rt.prototype.contains_61zpoe$=u.prototype.contains_61zpoe$,rt.prototype.contains_puj7f4$=u.prototype.contains_puj7f4$,rt.prototype.forEach_ubvtmq$=u.prototype.forEach_ubvtmq$,pe.prototype.send_x9o3m3$=xe.prototype.send_x9o3m3$,new ot(2048),v($.Charsets.UTF_8.newEncoder(),"\r\n",0,"\r\n".length);var Ne="0\r\n\r\n";v($.Charsets.UTF_8.newEncoder(),Ne,0,Ne.length),new Int32Array(0),new at(1e3),kt().build_mowv1r$(w(["HTTP/1.0","HTTP/1.1"])),new Et(4096),kt().build_za6fmz$(E.Companion.DefaultMethods,(function(t){return t.value.length}),(function(t,e){return x(t.value.charCodeAt(e))}));var Pe,Ae=new R(0,255),je=p(c(Ae,10));for(Pe=Ae.iterator();Pe.hasNext();){var Le,Re=Pe.next(),Ie=je.add_11rb$;Le=48<=Re&&Re<=57?e.Long.fromInt(Re).subtract(I):Re>=z.toNumber()&&Re<=D.toNumber()?e.Long.fromInt(Re).subtract(z).add(e.Long.fromInt(10)):Re>=M.toNumber()&&Re<=B.toNumber()?e.Long.fromInt(Re).subtract(M).add(e.Long.fromInt(10)):f,Ie.call(je,Le)}U(je);var ze,De=new R(0,15),Me=p(c(De,10));for(ze=De.iterator();ze.hasNext();){var Be=ze.next();Me.add_11rb$(F(Be<10?48+Be|0:0|P(P(97+Be)-10)))}return q(Me),t})?i.apply(e,r):i)||(t.exports=o)},267:function(t,e,n){var i,r,o;r=[e,n(421),n(276),n(94),n(197)],void 0===(o="function"==typeof(i=function(t,e,n,i,r){"use strict";var o,a,s,l,u,c,p=t.$$importsForInline$$||(t.$$importsForInline$$={}),h=(e.kotlin.Enum,e.Kind.CLASS),_=(e.throwISE,e.kotlin.collections.ArrayList_init_ww73n8$),f=e.toString,d=e.kotlin.collections.joinToString_fmv235$,m=e.kotlin.ranges.CharRange,y=e.kotlin.collections.plus_q4559j$,$=e.kotlin.collections.plus_mydzjv$,v=e.unboxChar,g=e.toByte,b=e.toBoxedChar,w=e.kotlin.collections.listOf_i5x0yv$,x=n.io.ktor.utils.io.charsets,k=n.io.ktor.utils.io.charsets.encode_fj4osb$,E=e.toChar,C=e.kotlin.Unit,S=e.kotlin.text.StringBuilder_init_za3lpa$,T=n.io.ktor.utils.io.core.String_xge8xe$,O=e.kotlin.Exception_init_pdl1vj$,N=e.kotlin.Exception,P=e.kotlin.text.StringBuilder_init,A=n.io.ktor.utils.io.core.internal.prepareReadFirstHead_j319xh$,j=n.io.ktor.utils.io.core.internal.prepareReadNextHead_x2nit9$,L=n.io.ktor.utils.io.core.internal.completeReadHead_x2nit9$,R=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,I=e.kotlin.collections.plus_qloxvw$,z=e.equals,D=e.hashCode,M=e.Kind.OBJECT,B=e.kotlin.collections.emptyList_287e2$,U=e.kotlin.collections.single_2p1efm$,F=e.kotlin.text.equals_igcy3c$,q=e.kotlin.text.indexOf_8eortd$,G=e.kotlin.text.contains_sgbm27$,H=n.io.ktor.utils.io.charsets.get_name_2sg7fd$,Y=n.io.ktor.utils.io.charsets.Charset,V=e.kotlin.collections.Collection,K=e.throwCCE,W=e.kotlin.text.trim_gw00vp$,X=e.kotlin.collections.emptyMap_q3lmfv$,Z=e.kotlin.collections.setOf_i5x0yv$,J=e.kotlin.text.startsWith_7epoxm$,Q=i.io.ktor.util.toLowerCasePreservingASCIIRules_pdl1vz$,tt=e.kotlin.text.toInt_pdl1vz$,et=e.kotlin.to_ujzrz7$,nt=e.kotlin.sequences.map_z5avom$,it=(e.kotlin.sequences.filter_euau3h$,e.kotlin.text.endsWith_7epoxm$,e.kotlin.IllegalArgumentException_init_pdl1vj$),rt=e.kotlin.text.isWhitespace_myv2d0$,ot=(e.kotlin.NoSuchElementException,e.kotlin.collections.mapCapacity_za3lpa$),at=e.kotlin.collections.LinkedHashMap_init_bwtc7$,st=e.kotlin.collections.Map,lt=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,ut=e.kotlin.collections.ArrayList_init_287e2$,ct=e.kotlin.text.iterator_gw00vp$,pt=e.kotlin.text.Regex_init_61zpoe$,ht=e.defineInlineFunction,_t=e.wrapFunction,ft=(i.io.ktor.util.date.Month.values,e.ensureNotNull),dt=(e.kotlin.ranges.IntRange,e.kotlin.IllegalStateException_init_pdl1vj$),mt=e.kotlin.IllegalStateException,yt=(e.kotlin.text.padStart_vrc1nu$,i.io.ktor.util.toCharArray_pdl1vz$),$t=(e.kotlin.text.lastIndexOfAny_junqau$,e.kotlin.text.removePrefix_gsj5wt$),vt=(e.kotlin.text.substringAfter_j4ogox$,i.io.ktor.util.caseInsensitiveMap_287e2$),gt=e.kotlin.collections.asSequence_7wnvza$,bt=e.kotlin.lazy_klfg04$,wt=e.kotlin.collections.firstOrNull_2p1efm$,xt=e.kotlin.IllegalArgumentException,kt=Error,Et=e.Kind.INTERFACE,Ct=i.io.ktor.util.StringValues,St=i.io.ktor.util.StringValuesBuilder,Tt=e.kotlin.collections.emptySet_287e2$,Ot=e.kotlin.collections.listOf_mh5how$,Nt=e.kotlin.collections.asList_us0mfu$,Pt=(e.kotlin.collections.toMap_6hr0sd$,i.io.ktor.util.StringValuesImpl),At=e.kotlin.text.toDoubleOrNull_pdl1vz$,jt=e.kotlin.ranges.rangeTo_38ydlf$,Lt=(e.kotlin.collections.sortedWith_eknfly$,e.kotlin.LazyThreadSafetyMode),Rt=e.kotlin.lazy_kls4a0$,It=e.kotlin.text.get_lastIndex_gw00vp$,zt=(e.kotlin.Comparator,e.kotlin.text.split_ip8yn$),Dt=(e.kotlin.text.toLong_pdl1vz$,Array),Mt=(e.kotlin.text.substringBefore_j4ogox$,e.kotlin.collections.joinTo_gcc71v$),Bt=e.kotlin.collections.addAll_ipc267$,Ut=(e.kotlin.collections.joinToString_cgipc5$,e.kotlin.text.lineSequence_gw00vp$),Ft=e.kotlin.sequences.mapNotNull_qpz9h9$,qt=e.kotlin.sequences.toList_veqyi0$,Gt=(e.kotlin.ranges.coerceAtMost_2p08ub$,e.Long.ZERO,e.kotlin.ranges.coerceAtLeast_2p08ub$,e.kotlin.collections.last_2p1efm$,e.kotlin.collections.get_lastIndex_55thoc$,e.kotlin.collections.filterNotNull_emfgvx$,e.kotlin.text.indexOf_l5u8uk$,e.kotlin.text.indexOfAny_junqau$),Ht=e.kotlin.text.lastIndexOf_8eortd$,Yt=e.kotlin.text.get_indices_gw00vp$,Vt=e.kotlin.ranges.reversed_zf1xzc$,Kt=i.io.ktor.util.isLowerCase_myv2d0$,Wt=e.kotlin.ranges.coerceAtLeast_dqglrj$,Xt=i.io.ktor.util.appendAll_k10e8h$,Zt=e.kotlin.text.isBlank_gw00vp$,Jt=(i.io.ktor.util,i.io.ktor.util.generateNonce,e.kotlin.text.startsWith_sgbm27$,e.kotlin.text.endsWith_sgbm27$,i.io.ktor.util.AttributeKey),Qt=e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED,te=e.kotlin.coroutines.CoroutineImpl,ee=i.io.ktor.util.AttributesJsFn,ne=n.io.ktor.utils.io.ByteReadChannel,ie=r.kotlinx.coroutines,re=n.io.ktor.utils.io.copyTo_47ygvz$,oe=n.io.ktor.utils.io.writer_x9a1ni$,ae=e.kotlin.text.take_6ic1pp$,se=n.io.ktor.utils.io.charsets.encodeToByteArray_fj4osb$,le=e.kotlin.text.Regex,ue=(e.kotlin.text.repeat_94bcnn$,e.kotlin.io.println_s8jyv4$,e.kotlin.collections.first_2p1efm$,e.kotlin.collections.checkIndexOverflow_za3lpa$),ce=i.io.ktor.util.sha1_fqrh44$,pe=i.io.ktor.util.encodeBase64_964n91$;function he(t,e,n,i){void 0===e&&(e=!1),void 0===n&&(n=!1),void 0===i&&(i=x.Charsets.UTF_8);var r,a,s,u=P();return we(k(i.newEncoder(),t),(r=n,a=u,s=e,function(t){return t===g(32)?r?a.append_s8itvh$(43):a.append_gw00v9$("%20"):o.contains_11rb$(t)||!s&&l.contains_11rb$(t)?a.append_s8itvh$(E(t)):a.append_gw00v9$(ve(t)),C})),u.toString()}function _e(t){return function(e){return t.append_gw00v9$(ve(e)),C}}function fe(t){for(var e=P(),n=x.Charsets.UTF_8,i=0;i255?l/3|0:l);r>n&&u.append_ezbsdh$(t,n,r);for(var c=r,p=null;c=i){var f,d=c;throw f=t.length,new $e("Incomplete trailing HEX escape: "+e.subSequence(t,d,f).toString()+", in "+t+" at "+c)}var m=ge(t.charCodeAt(c+1|0)),y=ge(t.charCodeAt(c+2|0));if(-1===m||-1===y)throw new $e("Wrong HEX escape: %"+String.fromCharCode(t.charCodeAt(c+1|0))+String.fromCharCode(t.charCodeAt(c+2|0))+", in "+t+", at "+c);p[(s=_,_=s+1|0,s)]=g((16*m|0)+y|0),c=c+3|0}u.append_gw00v9$(T(p,0,_,a))}else u.append_s8itvh$(h),c=c+1|0}return u.toString()}function $e(t){O(t,this),this.name="URLDecodeException"}function ve(t){var e=S(3),n=255&t;return e.append_s8itvh$(37),e.append_s8itvh$(be(n>>4)),e.append_s8itvh$(be(15&n)),e.toString()}function ge(t){return new m(48,57).contains_mef7kx$(t)?t-48:new m(65,70).contains_mef7kx$(t)?t-65+10|0:new m(97,102).contains_mef7kx$(t)?t-97+10|0:-1}function be(t){return E(t>=0&&t<=9?48+t:E(65+t)-10)}function we(t,e){t:do{var n,i,r=!0;if(null==(n=A(t,1)))break t;var o=n;try{for(;;){for(var a=o;a.writePosition>a.readPosition;)e(a.readByte());if(r=!1,null==(i=j(t,o)))break;o=i,r=!0}}finally{r&&L(t,o)}}while(0)}function xe(t,e){Ce(),void 0===e&&(e=B()),tn.call(this,t,e)}function ke(){Ee=this,this.File=new xe("file"),this.Mixed=new xe("mixed"),this.Attachment=new xe("attachment"),this.Inline=new xe("inline")}$e.prototype=Object.create(N.prototype),$e.prototype.constructor=$e,xe.prototype=Object.create(tn.prototype),xe.prototype.constructor=xe,Ne.prototype=Object.create(tn.prototype),Ne.prototype.constructor=Ne,We.prototype=Object.create(N.prototype),We.prototype.constructor=We,pn.prototype=Object.create(St.prototype),pn.prototype.constructor=pn,dn.prototype=Object.create(Pt.prototype),dn.prototype.constructor=dn,Pn.prototype=Object.create(xt.prototype),Pn.prototype.constructor=Pn,An.prototype=Object.create(xt.prototype),An.prototype.constructor=An,jn.prototype=Object.create(xt.prototype),jn.prototype.constructor=jn,ui.prototype=Object.create(St.prototype),ui.prototype.constructor=ui,_i.prototype=Object.create(Pt.prototype),_i.prototype.constructor=_i,Oi.prototype=Object.create(mt.prototype),Oi.prototype.constructor=Oi,Ji.prototype=Object.create(Vi.prototype),Ji.prototype.constructor=Ji,Gi.prototype=Object.create(qi.prototype),Gi.prototype.constructor=Gi,Hi.prototype=Object.create(qi.prototype),Hi.prototype.constructor=Hi,Yi.prototype=Object.create(qi.prototype),Yi.prototype.constructor=Yi,Ki.prototype=Object.create(Vi.prototype),Ki.prototype.constructor=Ki,Wi.prototype=Object.create(Vi.prototype),Wi.prototype.constructor=Wi,Zi.prototype=Object.create(Vi.prototype),Zi.prototype.constructor=Zi,Qi.prototype=Object.create(Vi.prototype),Qi.prototype.constructor=Qi,tr.prototype=Object.create(Ji.prototype),tr.prototype.constructor=tr,ar.prototype=Object.create(ir.prototype),ar.prototype.constructor=ar,sr.prototype=Object.create(ir.prototype),sr.prototype.constructor=sr,lr.prototype=Object.create(ir.prototype),lr.prototype.constructor=lr,ur.prototype=Object.create(ir.prototype),ur.prototype.constructor=ur,cr.prototype=Object.create(ir.prototype),cr.prototype.constructor=cr,pr.prototype=Object.create(ir.prototype),pr.prototype.constructor=pr,hr.prototype=Object.create(ir.prototype),hr.prototype.constructor=hr,_r.prototype=Object.create(ir.prototype),_r.prototype.constructor=_r,fr.prototype=Object.create(ir.prototype),fr.prototype.constructor=fr,dr.prototype=Object.create(ir.prototype),dr.prototype.constructor=dr,$e.$metadata$={kind:h,simpleName:"URLDecodeException",interfaces:[N]},Object.defineProperty(xe.prototype,"disposition",{get:function(){return this.content}}),Object.defineProperty(xe.prototype,"name",{get:function(){return this.parameter_61zpoe$(Oe().Name)}}),xe.prototype.withParameter_puj7f4$=function(t,e){return new xe(this.disposition,I(this.parameters,new mn(t,e)))},xe.prototype.withParameters_1wyvw$=function(t){return new xe(this.disposition,$(this.parameters,t))},xe.prototype.equals=function(t){return e.isType(t,xe)&&z(this.disposition,t.disposition)&&z(this.parameters,t.parameters)},xe.prototype.hashCode=function(){return(31*D(this.disposition)|0)+D(this.parameters)|0},ke.prototype.parse_61zpoe$=function(t){var e=U($n(t));return new xe(e.value,e.params)},ke.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Ee=null;function Ce(){return null===Ee&&new ke,Ee}function Se(){Te=this,this.FileName="filename",this.FileNameAsterisk="filename*",this.Name="name",this.CreationDate="creation-date",this.ModificationDate="modification-date",this.ReadDate="read-date",this.Size="size",this.Handling="handling"}Se.$metadata$={kind:M,simpleName:"Parameters",interfaces:[]};var Te=null;function Oe(){return null===Te&&new Se,Te}function Ne(t,e,n,i){je(),void 0===i&&(i=B()),tn.call(this,n,i),this.contentType=t,this.contentSubtype=e}function Pe(){Ae=this,this.Any=Ke("*","*")}xe.$metadata$={kind:h,simpleName:"ContentDisposition",interfaces:[tn]},Ne.prototype.withParameter_puj7f4$=function(t,e){return this.hasParameter_0(t,e)?this:new Ne(this.contentType,this.contentSubtype,this.content,I(this.parameters,new mn(t,e)))},Ne.prototype.hasParameter_0=function(t,n){switch(this.parameters.size){case 0:return!1;case 1:var i=this.parameters.get_za3lpa$(0);return F(i.name,t,!0)&&F(i.value,n,!0);default:var r,o=this.parameters;t:do{var a;if(e.isType(o,V)&&o.isEmpty()){r=!1;break t}for(a=o.iterator();a.hasNext();){var s=a.next();if(F(s.name,t,!0)&&F(s.value,n,!0)){r=!0;break t}}r=!1}while(0);return r}},Ne.prototype.withoutParameters=function(){return Ke(this.contentType,this.contentSubtype)},Ne.prototype.match_9v5yzd$=function(t){var n,i;if(!z(t.contentType,"*")&&!F(t.contentType,this.contentType,!0))return!1;if(!z(t.contentSubtype,"*")&&!F(t.contentSubtype,this.contentSubtype,!0))return!1;for(n=t.parameters.iterator();n.hasNext();){var r=n.next(),o=r.component1(),a=r.component2();if(z(o,"*"))if(z(a,"*"))i=!0;else{var s,l=this.parameters;t:do{var u;if(e.isType(l,V)&&l.isEmpty()){s=!1;break t}for(u=l.iterator();u.hasNext();){var c=u.next();if(F(c.value,a,!0)){s=!0;break t}}s=!1}while(0);i=s}else{var p=this.parameter_61zpoe$(o);i=z(a,"*")?null!=p:F(p,a,!0)}if(!i)return!1}return!0},Ne.prototype.match_61zpoe$=function(t){return this.match_9v5yzd$(je().parse_61zpoe$(t))},Ne.prototype.equals=function(t){return e.isType(t,Ne)&&F(this.contentType,t.contentType,!0)&&F(this.contentSubtype,t.contentSubtype,!0)&&z(this.parameters,t.parameters)},Ne.prototype.hashCode=function(){var t=D(this.contentType.toLowerCase());return(t=t+((31*t|0)+D(this.contentSubtype.toLowerCase()))|0)+(31*D(this.parameters)|0)|0},Pe.prototype.parse_61zpoe$=function(t){var n=U($n(t)),i=n.value,r=n.params,o=q(i,47);if(-1===o){var a;if(z(W(e.isCharSequence(a=i)?a:K()).toString(),"*"))return this.Any;throw new We(t)}var s,l=i.substring(0,o),u=W(e.isCharSequence(s=l)?s:K()).toString();if(0===u.length)throw new We(t);var c,p=o+1|0,h=i.substring(p),_=W(e.isCharSequence(c=h)?c:K()).toString();if(0===_.length||G(_,47))throw new We(t);return Ke(u,_,r)},Pe.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Ae=null;function je(){return null===Ae&&new Pe,Ae}function Le(){Re=this,this.Any=Ke("application","*"),this.Atom=Ke("application","atom+xml"),this.Json=Ke("application","json"),this.JavaScript=Ke("application","javascript"),this.OctetStream=Ke("application","octet-stream"),this.FontWoff=Ke("application","font-woff"),this.Rss=Ke("application","rss+xml"),this.Xml=Ke("application","xml"),this.Xml_Dtd=Ke("application","xml-dtd"),this.Zip=Ke("application","zip"),this.GZip=Ke("application","gzip"),this.FormUrlEncoded=Ke("application","x-www-form-urlencoded"),this.Pdf=Ke("application","pdf"),this.Wasm=Ke("application","wasm"),this.ProblemJson=Ke("application","problem+json"),this.ProblemXml=Ke("application","problem+xml")}Le.$metadata$={kind:M,simpleName:"Application",interfaces:[]};var Re=null;function Ie(){ze=this,this.Any=Ke("audio","*"),this.MP4=Ke("audio","mp4"),this.MPEG=Ke("audio","mpeg"),this.OGG=Ke("audio","ogg")}Ie.$metadata$={kind:M,simpleName:"Audio",interfaces:[]};var ze=null;function De(){Me=this,this.Any=Ke("image","*"),this.GIF=Ke("image","gif"),this.JPEG=Ke("image","jpeg"),this.PNG=Ke("image","png"),this.SVG=Ke("image","svg+xml"),this.XIcon=Ke("image","x-icon")}De.$metadata$={kind:M,simpleName:"Image",interfaces:[]};var Me=null;function Be(){Ue=this,this.Any=Ke("message","*"),this.Http=Ke("message","http")}Be.$metadata$={kind:M,simpleName:"Message",interfaces:[]};var Ue=null;function Fe(){qe=this,this.Any=Ke("multipart","*"),this.Mixed=Ke("multipart","mixed"),this.Alternative=Ke("multipart","alternative"),this.Related=Ke("multipart","related"),this.FormData=Ke("multipart","form-data"),this.Signed=Ke("multipart","signed"),this.Encrypted=Ke("multipart","encrypted"),this.ByteRanges=Ke("multipart","byteranges")}Fe.$metadata$={kind:M,simpleName:"MultiPart",interfaces:[]};var qe=null;function Ge(){He=this,this.Any=Ke("text","*"),this.Plain=Ke("text","plain"),this.CSS=Ke("text","css"),this.CSV=Ke("text","csv"),this.Html=Ke("text","html"),this.JavaScript=Ke("text","javascript"),this.VCard=Ke("text","vcard"),this.Xml=Ke("text","xml"),this.EventStream=Ke("text","event-stream")}Ge.$metadata$={kind:M,simpleName:"Text",interfaces:[]};var He=null;function Ye(){Ve=this,this.Any=Ke("video","*"),this.MPEG=Ke("video","mpeg"),this.MP4=Ke("video","mp4"),this.OGG=Ke("video","ogg"),this.QuickTime=Ke("video","quicktime")}Ye.$metadata$={kind:M,simpleName:"Video",interfaces:[]};var Ve=null;function Ke(t,e,n,i){return void 0===n&&(n=B()),i=i||Object.create(Ne.prototype),Ne.call(i,t,e,t+"/"+e,n),i}function We(t){O("Bad Content-Type format: "+t,this),this.name="BadContentTypeFormatException"}function Xe(t){var e;return null!=(e=t.parameter_61zpoe$("charset"))?Y.Companion.forName_61zpoe$(e):null}function Ze(t){var e=t.component1(),n=t.component2();return et(n,e)}function Je(t){var e,n=lt();for(e=t.iterator();e.hasNext();){var i,r=e.next(),o=r.first,a=n.get_11rb$(o);if(null==a){var s=ut();n.put_xwzc9p$(o,s),i=s}else i=a;i.add_11rb$(r)}var l,u=at(ot(n.size));for(l=n.entries.iterator();l.hasNext();){var c,p=l.next(),h=u.put_xwzc9p$,f=p.key,d=p.value,m=_(R(d,10));for(c=d.iterator();c.hasNext();){var y=c.next();m.add_11rb$(y.second)}h.call(u,f,m)}return u}function Qe(t){try{return je().parse_61zpoe$(t)}catch(n){throw e.isType(n,kt)?new xt("Failed to parse "+t,n):n}}function tn(t,e){rn(),void 0===e&&(e=B()),this.content=t,this.parameters=e}function en(){nn=this}Ne.$metadata$={kind:h,simpleName:"ContentType",interfaces:[tn]},We.$metadata$={kind:h,simpleName:"BadContentTypeFormatException",interfaces:[N]},tn.prototype.parameter_61zpoe$=function(t){var e,n,i=this.parameters;t:do{var r;for(r=i.iterator();r.hasNext();){var o=r.next();if(F(o.name,t,!0)){n=o;break t}}n=null}while(0);return null!=(e=n)?e.value:null},tn.prototype.toString=function(){if(this.parameters.isEmpty())return this.content;var t,e=this.content.length,n=0;for(t=this.parameters.iterator();t.hasNext();){var i=t.next();n=n+(i.name.length+i.value.length+3|0)|0}var r,o=S(e+n|0);o.append_gw00v9$(this.content),r=this.parameters.size;for(var a=0;a?@[\\]{}',t)}function Rn(){}function In(){}function zn(t){var e;return null!=(e=t.headers.get_61zpoe$(Nn().ContentType))?je().parse_61zpoe$(e):null}function Dn(t){Un(),this.value=t}function Mn(){Bn=this,this.Get=new Dn("GET"),this.Post=new Dn("POST"),this.Put=new Dn("PUT"),this.Patch=new Dn("PATCH"),this.Delete=new Dn("DELETE"),this.Head=new Dn("HEAD"),this.Options=new Dn("OPTIONS"),this.DefaultMethods=w([this.Get,this.Post,this.Put,this.Patch,this.Delete,this.Head,this.Options])}Pn.$metadata$={kind:h,simpleName:"UnsafeHeaderException",interfaces:[xt]},An.$metadata$={kind:h,simpleName:"IllegalHeaderNameException",interfaces:[xt]},jn.$metadata$={kind:h,simpleName:"IllegalHeaderValueException",interfaces:[xt]},Rn.$metadata$={kind:Et,simpleName:"HttpMessage",interfaces:[]},In.$metadata$={kind:Et,simpleName:"HttpMessageBuilder",interfaces:[]},Mn.prototype.parse_61zpoe$=function(t){return z(t,this.Get.value)?this.Get:z(t,this.Post.value)?this.Post:z(t,this.Put.value)?this.Put:z(t,this.Patch.value)?this.Patch:z(t,this.Delete.value)?this.Delete:z(t,this.Head.value)?this.Head:z(t,this.Options.value)?this.Options:new Dn(t)},Mn.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Bn=null;function Un(){return null===Bn&&new Mn,Bn}function Fn(t,e,n){Hn(),this.name=t,this.major=e,this.minor=n}function qn(){Gn=this,this.HTTP_2_0=new Fn("HTTP",2,0),this.HTTP_1_1=new Fn("HTTP",1,1),this.HTTP_1_0=new Fn("HTTP",1,0),this.SPDY_3=new Fn("SPDY",3,0),this.QUIC=new Fn("QUIC",1,0)}Dn.$metadata$={kind:h,simpleName:"HttpMethod",interfaces:[]},Dn.prototype.component1=function(){return this.value},Dn.prototype.copy_61zpoe$=function(t){return new Dn(void 0===t?this.value:t)},Dn.prototype.toString=function(){return"HttpMethod(value="+e.toString(this.value)+")"},Dn.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.value)|0},Dn.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.value,t.value)},qn.prototype.fromValue_3m52m6$=function(t,e,n){return z(t,"HTTP")&&1===e&&1===n?this.HTTP_1_1:z(t,"HTTP")&&2===e&&0===n?this.HTTP_2_0:new Fn(t,e,n)},qn.prototype.parse_6bul2c$=function(t){var e=zt(t,["/","."]);if(3!==e.size)throw dt(("Failed to parse HttpProtocolVersion. Expected format: protocol/major.minor, but actual: "+t).toString());var n=e.get_za3lpa$(0),i=e.get_za3lpa$(1),r=e.get_za3lpa$(2);return this.fromValue_3m52m6$(n,tt(i),tt(r))},qn.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Gn=null;function Hn(){return null===Gn&&new qn,Gn}function Yn(t,e){Xn(),this.value=t,this.description=e}function Vn(){Wn=this,this.Continue=new Yn(100,"Continue"),this.SwitchingProtocols=new Yn(101,"Switching Protocols"),this.Processing=new Yn(102,"Processing"),this.OK=new Yn(200,"OK"),this.Created=new Yn(201,"Created"),this.Accepted=new Yn(202,"Accepted"),this.NonAuthoritativeInformation=new Yn(203,"Non-Authoritative Information"),this.NoContent=new Yn(204,"No Content"),this.ResetContent=new Yn(205,"Reset Content"),this.PartialContent=new Yn(206,"Partial Content"),this.MultiStatus=new Yn(207,"Multi-Status"),this.MultipleChoices=new Yn(300,"Multiple Choices"),this.MovedPermanently=new Yn(301,"Moved Permanently"),this.Found=new Yn(302,"Found"),this.SeeOther=new Yn(303,"See Other"),this.NotModified=new Yn(304,"Not Modified"),this.UseProxy=new Yn(305,"Use Proxy"),this.SwitchProxy=new Yn(306,"Switch Proxy"),this.TemporaryRedirect=new Yn(307,"Temporary Redirect"),this.PermanentRedirect=new Yn(308,"Permanent Redirect"),this.BadRequest=new Yn(400,"Bad Request"),this.Unauthorized=new Yn(401,"Unauthorized"),this.PaymentRequired=new Yn(402,"Payment Required"),this.Forbidden=new Yn(403,"Forbidden"),this.NotFound=new Yn(404,"Not Found"),this.MethodNotAllowed=new Yn(405,"Method Not Allowed"),this.NotAcceptable=new Yn(406,"Not Acceptable"),this.ProxyAuthenticationRequired=new Yn(407,"Proxy Authentication Required"),this.RequestTimeout=new Yn(408,"Request Timeout"),this.Conflict=new Yn(409,"Conflict"),this.Gone=new Yn(410,"Gone"),this.LengthRequired=new Yn(411,"Length Required"),this.PreconditionFailed=new Yn(412,"Precondition Failed"),this.PayloadTooLarge=new Yn(413,"Payload Too Large"),this.RequestURITooLong=new Yn(414,"Request-URI Too Long"),this.UnsupportedMediaType=new Yn(415,"Unsupported Media Type"),this.RequestedRangeNotSatisfiable=new Yn(416,"Requested Range Not Satisfiable"),this.ExpectationFailed=new Yn(417,"Expectation Failed"),this.UnprocessableEntity=new Yn(422,"Unprocessable Entity"),this.Locked=new Yn(423,"Locked"),this.FailedDependency=new Yn(424,"Failed Dependency"),this.UpgradeRequired=new Yn(426,"Upgrade Required"),this.TooManyRequests=new Yn(429,"Too Many Requests"),this.RequestHeaderFieldTooLarge=new Yn(431,"Request Header Fields Too Large"),this.InternalServerError=new Yn(500,"Internal Server Error"),this.NotImplemented=new Yn(501,"Not Implemented"),this.BadGateway=new Yn(502,"Bad Gateway"),this.ServiceUnavailable=new Yn(503,"Service Unavailable"),this.GatewayTimeout=new Yn(504,"Gateway Timeout"),this.VersionNotSupported=new Yn(505,"HTTP Version Not Supported"),this.VariantAlsoNegotiates=new Yn(506,"Variant Also Negotiates"),this.InsufficientStorage=new Yn(507,"Insufficient Storage"),this.allStatusCodes=Zn();var t,e=Dt(1e3);t=e.length-1|0;for(var n=0;n<=t;n++){var i,r=this.allStatusCodes;t:do{var o;for(o=r.iterator();o.hasNext();){var a=o.next();if(a.value===n){i=a;break t}}i=null}while(0);e[n]=i}this.byValue_0=e}Fn.prototype.toString=function(){return this.name+"/"+this.major+"."+this.minor},Fn.$metadata$={kind:h,simpleName:"HttpProtocolVersion",interfaces:[]},Fn.prototype.component1=function(){return this.name},Fn.prototype.component2=function(){return this.major},Fn.prototype.component3=function(){return this.minor},Fn.prototype.copy_3m52m6$=function(t,e,n){return new Fn(void 0===t?this.name:t,void 0===e?this.major:e,void 0===n?this.minor:n)},Fn.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.name)|0)+e.hashCode(this.major)|0)+e.hashCode(this.minor)|0},Fn.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)&&e.equals(this.major,t.major)&&e.equals(this.minor,t.minor)},Yn.prototype.toString=function(){return this.value.toString()+" "+this.description},Yn.prototype.equals=function(t){return e.isType(t,Yn)&&t.value===this.value},Yn.prototype.hashCode=function(){return D(this.value)},Yn.prototype.description_61zpoe$=function(t){return this.copy_19mbxw$(void 0,t)},Vn.prototype.fromValue_za3lpa$=function(t){var e=1<=t&&t<1e3?this.byValue_0[t]:null;return null!=e?e:new Yn(t,"Unknown Status Code")},Vn.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Kn,Wn=null;function Xn(){return null===Wn&&new Vn,Wn}function Zn(){return w([Xn().Continue,Xn().SwitchingProtocols,Xn().Processing,Xn().OK,Xn().Created,Xn().Accepted,Xn().NonAuthoritativeInformation,Xn().NoContent,Xn().ResetContent,Xn().PartialContent,Xn().MultiStatus,Xn().MultipleChoices,Xn().MovedPermanently,Xn().Found,Xn().SeeOther,Xn().NotModified,Xn().UseProxy,Xn().SwitchProxy,Xn().TemporaryRedirect,Xn().PermanentRedirect,Xn().BadRequest,Xn().Unauthorized,Xn().PaymentRequired,Xn().Forbidden,Xn().NotFound,Xn().MethodNotAllowed,Xn().NotAcceptable,Xn().ProxyAuthenticationRequired,Xn().RequestTimeout,Xn().Conflict,Xn().Gone,Xn().LengthRequired,Xn().PreconditionFailed,Xn().PayloadTooLarge,Xn().RequestURITooLong,Xn().UnsupportedMediaType,Xn().RequestedRangeNotSatisfiable,Xn().ExpectationFailed,Xn().UnprocessableEntity,Xn().Locked,Xn().FailedDependency,Xn().UpgradeRequired,Xn().TooManyRequests,Xn().RequestHeaderFieldTooLarge,Xn().InternalServerError,Xn().NotImplemented,Xn().BadGateway,Xn().ServiceUnavailable,Xn().GatewayTimeout,Xn().VersionNotSupported,Xn().VariantAlsoNegotiates,Xn().InsufficientStorage])}function Jn(t){var e=P();return ti(t,e),e.toString()}function Qn(t){var e=de(t.first,!0);return null==t.second?e:e+"="+de(f(t.second),!0)}function ti(t,e){Mt(t,e,"&",void 0,void 0,void 0,void 0,Qn)}function ei(t,e){var n,i=t.entries(),r=ut();for(n=i.iterator();n.hasNext();){var o,a=n.next();if(a.value.isEmpty())o=Ot(et(a.key,null));else{var s,l=a.value,u=_(R(l,10));for(s=l.iterator();s.hasNext();){var c=s.next();u.add_11rb$(et(a.key,c))}o=u}Bt(r,o)}ti(r,e)}function ni(t){var n,i=W(e.isCharSequence(n=t)?n:K()).toString();if(0===i.length)return null;var r=q(i,44),o=i.substring(0,r),a=r+1|0,s=i.substring(a);return et(Q($t(o,".")),Qe(s))}function ii(){return qt(Ft(Ut("\n.123,application/vnd.lotus-1-2-3\n.3dmf,x-world/x-3dmf\n.3dml,text/vnd.in3d.3dml\n.3dm,x-world/x-3dmf\n.3g2,video/3gpp2\n.3gp,video/3gpp\n.7z,application/x-7z-compressed\n.aab,application/x-authorware-bin\n.aac,audio/aac\n.aam,application/x-authorware-map\n.a,application/octet-stream\n.aas,application/x-authorware-seg\n.abc,text/vnd.abc\n.abw,application/x-abiword\n.ac,application/pkix-attr-cert\n.acc,application/vnd.americandynamics.acc\n.ace,application/x-ace-compressed\n.acgi,text/html\n.acu,application/vnd.acucobol\n.adp,audio/adpcm\n.aep,application/vnd.audiograph\n.afl,video/animaflex\n.afp,application/vnd.ibm.modcap\n.ahead,application/vnd.ahead.space\n.ai,application/postscript\n.aif,audio/aiff\n.aifc,audio/aiff\n.aiff,audio/aiff\n.aim,application/x-aim\n.aip,text/x-audiosoft-intra\n.air,application/vnd.adobe.air-application-installer-package+zip\n.ait,application/vnd.dvb.ait\n.ami,application/vnd.amiga.ami\n.ani,application/x-navi-animation\n.aos,application/x-nokia-9000-communicator-add-on-software\n.apk,application/vnd.android.package-archive\n.application,application/x-ms-application\n,application/pgp-encrypted\n.apr,application/vnd.lotus-approach\n.aps,application/mime\n.arc,application/octet-stream\n.arj,application/arj\n.arj,application/octet-stream\n.art,image/x-jg\n.asf,video/x-ms-asf\n.asm,text/x-asm\n.aso,application/vnd.accpac.simply.aso\n.asp,text/asp\n.asx,application/x-mplayer2\n.asx,video/x-ms-asf\n.asx,video/x-ms-asf-plugin\n.atc,application/vnd.acucorp\n.atomcat,application/atomcat+xml\n.atomsvc,application/atomsvc+xml\n.atom,application/atom+xml\n.atx,application/vnd.antix.game-component\n.au,audio/basic\n.au,audio/x-au\n.avi,video/avi\n.avi,video/msvideo\n.avi,video/x-msvideo\n.avs,video/avs-video\n.aw,application/applixware\n.azf,application/vnd.airzip.filesecure.azf\n.azs,application/vnd.airzip.filesecure.azs\n.azw,application/vnd.amazon.ebook\n.bcpio,application/x-bcpio\n.bdf,application/x-font-bdf\n.bdm,application/vnd.syncml.dm+wbxml\n.bed,application/vnd.realvnc.bed\n.bh2,application/vnd.fujitsu.oasysprs\n.bin,application/macbinary\n.bin,application/mac-binary\n.bin,application/octet-stream\n.bin,application/x-binary\n.bin,application/x-macbinary\n.bmi,application/vnd.bmi\n.bm,image/bmp\n.bmp,image/bmp\n.bmp,image/x-windows-bmp\n.boo,application/book\n.book,application/book\n.box,application/vnd.previewsystems.box\n.boz,application/x-bzip2\n.bsh,application/x-bsh\n.btif,image/prs.btif\n.bz2,application/x-bzip2\n.bz,application/x-bzip\n.c11amc,application/vnd.cluetrust.cartomobile-config\n.c11amz,application/vnd.cluetrust.cartomobile-config-pkg\n.c4g,application/vnd.clonk.c4group\n.cab,application/vnd.ms-cab-compressed\n.car,application/vnd.curl.car\n.cat,application/vnd.ms-pki.seccat\n.ccad,application/clariscad\n.cco,application/x-cocoa\n.cc,text/plain\n.cc,text/x-c\n.ccxml,application/ccxml+xml,\n.cdbcmsg,application/vnd.contact.cmsg\n.cdf,application/cdf\n.cdf,application/x-cdf\n.cdf,application/x-netcdf\n.cdkey,application/vnd.mediastation.cdkey\n.cdmia,application/cdmi-capability\n.cdmic,application/cdmi-container\n.cdmid,application/cdmi-domain\n.cdmio,application/cdmi-object\n.cdmiq,application/cdmi-queue\n.cdx,chemical/x-cdx\n.cdxml,application/vnd.chemdraw+xml\n.cdy,application/vnd.cinderella\n.cer,application/pkix-cert\n.cgm,image/cgm\n.cha,application/x-chat\n.chat,application/x-chat\n.chm,application/vnd.ms-htmlhelp\n.chrt,application/vnd.kde.kchart\n.cif,chemical/x-cif\n.cii,application/vnd.anser-web-certificate-issue-initiation\n.cil,application/vnd.ms-artgalry\n.cla,application/vnd.claymore\n.class,application/java\n.class,application/java-byte-code\n.class,application/java-vm\n.class,application/x-java-class\n.clkk,application/vnd.crick.clicker.keyboard\n.clkp,application/vnd.crick.clicker.palette\n.clkt,application/vnd.crick.clicker.template\n.clkw,application/vnd.crick.clicker.wordbank\n.clkx,application/vnd.crick.clicker\n.clp,application/x-msclip\n.cmc,application/vnd.cosmocaller\n.cmdf,chemical/x-cmdf\n.cml,chemical/x-cml\n.cmp,application/vnd.yellowriver-custom-menu\n.cmx,image/x-cmx\n.cod,application/vnd.rim.cod\n.com,application/octet-stream\n.com,text/plain\n.conf,text/plain\n.cpio,application/x-cpio\n.cpp,text/x-c\n.cpt,application/mac-compactpro\n.cpt,application/x-compactpro\n.cpt,application/x-cpt\n.crd,application/x-mscardfile\n.crl,application/pkcs-crl\n.crl,application/pkix-crl\n.crt,application/pkix-cert\n.crt,application/x-x509-ca-cert\n.crt,application/x-x509-user-cert\n.cryptonote,application/vnd.rig.cryptonote\n.csh,application/x-csh\n.csh,text/x-script.csh\n.csml,chemical/x-csml\n.csp,application/vnd.commonspace\n.css,text/css\n.csv,text/csv\n.c,text/plain\n.c++,text/plain\n.c,text/x-c\n.cu,application/cu-seeme\n.curl,text/vnd.curl\n.cww,application/prs.cww\n.cxx,text/plain\n.dat,binary/octet-stream\n.dae,model/vnd.collada+xml\n.daf,application/vnd.mobius.daf\n.davmount,application/davmount+xml\n.dcr,application/x-director\n.dcurl,text/vnd.curl.dcurl\n.dd2,application/vnd.oma.dd2+xml\n.ddd,application/vnd.fujixerox.ddd\n.deb,application/x-debian-package\n.deepv,application/x-deepv\n.def,text/plain\n.der,application/x-x509-ca-cert\n.dfac,application/vnd.dreamfactory\n.dif,video/x-dv\n.dir,application/x-director\n.dis,application/vnd.mobius.dis\n.djvu,image/vnd.djvu\n.dl,video/dl\n.dl,video/x-dl\n.dna,application/vnd.dna\n.doc,application/msword\n.docm,application/vnd.ms-word.document.macroenabled.12\n.docx,application/vnd.openxmlformats-officedocument.wordprocessingml.document\n.dot,application/msword\n.dotm,application/vnd.ms-word.template.macroenabled.12\n.dotx,application/vnd.openxmlformats-officedocument.wordprocessingml.template\n.dp,application/commonground\n.dp,application/vnd.osgi.dp\n.dpg,application/vnd.dpgraph\n.dra,audio/vnd.dra\n.drw,application/drafting\n.dsc,text/prs.lines.tag\n.dssc,application/dssc+der\n.dtb,application/x-dtbook+xml\n.dtd,application/xml-dtd\n.dts,audio/vnd.dts\n.dtshd,audio/vnd.dts.hd\n.dump,application/octet-stream\n.dvi,application/x-dvi\n.dv,video/x-dv\n.dwf,drawing/x-dwf (old)\n.dwf,model/vnd.dwf\n.dwg,application/acad\n.dwg,image/vnd.dwg\n.dwg,image/x-dwg\n.dxf,application/dxf\n.dxf,image/vnd.dwg\n.dxf,image/vnd.dxf\n.dxf,image/x-dwg\n.dxp,application/vnd.spotfire.dxp\n.dxr,application/x-director\n.ecelp4800,audio/vnd.nuera.ecelp4800\n.ecelp7470,audio/vnd.nuera.ecelp7470\n.ecelp9600,audio/vnd.nuera.ecelp9600\n.edm,application/vnd.novadigm.edm\n.edx,application/vnd.novadigm.edx\n.efif,application/vnd.picsel\n.ei6,application/vnd.pg.osasli\n.elc,application/x-bytecode.elisp (compiled elisp)\n.elc,application/x-elc\n.el,text/x-script.elisp\n.eml,message/rfc822\n.emma,application/emma+xml\n.env,application/x-envoy\n.eol,audio/vnd.digital-winds\n.eot,application/vnd.ms-fontobject\n.eps,application/postscript\n.epub,application/epub+zip\n.es3,application/vnd.eszigno3+xml\n.es,application/ecmascript\n.es,application/x-esrehber\n.esf,application/vnd.epson.esf\n.etx,text/x-setext\n.evy,application/envoy\n.evy,application/x-envoy\n.exe,application/octet-stream\n.exe,application/x-msdownload\n.exi,application/exi\n.ext,application/vnd.novadigm.ext\n.ez2,application/vnd.ezpix-album\n.ez3,application/vnd.ezpix-package\n.f4v,video/x-f4v\n.f77,text/x-fortran\n.f90,text/plain\n.f90,text/x-fortran\n.fbs,image/vnd.fastbidsheet\n.fcs,application/vnd.isac.fcs\n.fdf,application/vnd.fdf\n.fe_launch,application/vnd.denovo.fcselayout-link\n.fg5,application/vnd.fujitsu.oasysgp\n.fh,image/x-freehand\n.fif,application/fractals\n.fif,image/fif\n.fig,application/x-xfig\n.fli,video/fli\n.fli,video/x-fli\n.flo,application/vnd.micrografx.flo\n.flo,image/florian\n.flv,video/x-flv\n.flw,application/vnd.kde.kivio\n.flx,text/vnd.fmi.flexstor\n.fly,text/vnd.fly\n.fm,application/vnd.framemaker\n.fmf,video/x-atomic3d-feature\n.fnc,application/vnd.frogans.fnc\n.for,text/plain\n.for,text/x-fortran\n.fpx,image/vnd.fpx\n.fpx,image/vnd.net-fpx\n.frl,application/freeloader\n.fsc,application/vnd.fsc.weblaunch\n.fst,image/vnd.fst\n.ftc,application/vnd.fluxtime.clip\n.f,text/plain\n.f,text/x-fortran\n.fti,application/vnd.anser-web-funds-transfer-initiation\n.funk,audio/make\n.fvt,video/vnd.fvt\n.fxp,application/vnd.adobe.fxp\n.fzs,application/vnd.fuzzysheet\n.g2w,application/vnd.geoplan\n.g3,image/g3fax\n.g3w,application/vnd.geospace\n.gac,application/vnd.groove-account\n.gdl,model/vnd.gdl\n.geo,application/vnd.dynageo\n.gex,application/vnd.geometry-explorer\n.ggb,application/vnd.geogebra.file\n.ggt,application/vnd.geogebra.tool\n.ghf,application/vnd.groove-help\n.gif,image/gif\n.gim,application/vnd.groove-identity-message\n.gl,video/gl\n.gl,video/x-gl\n.gmx,application/vnd.gmx\n.gnumeric,application/x-gnumeric\n.gph,application/vnd.flographit\n.gqf,application/vnd.grafeq\n.gram,application/srgs\n.grv,application/vnd.groove-injector\n.grxml,application/srgs+xml\n.gsd,audio/x-gsm\n.gsf,application/x-font-ghostscript\n.gsm,audio/x-gsm\n.gsp,application/x-gsp\n.gss,application/x-gss\n.gtar,application/x-gtar\n.g,text/plain\n.gtm,application/vnd.groove-tool-message\n.gtw,model/vnd.gtw\n.gv,text/vnd.graphviz\n.gxt,application/vnd.geonext\n.gz,application/x-compressed\n.gz,application/x-gzip\n.gzip,application/x-gzip\n.gzip,multipart/x-gzip\n.h261,video/h261\n.h263,video/h263\n.h264,video/h264\n.hal,application/vnd.hal+xml\n.hbci,application/vnd.hbci\n.hdf,application/x-hdf\n.help,application/x-helpfile\n.hgl,application/vnd.hp-hpgl\n.hh,text/plain\n.hh,text/x-h\n.hlb,text/x-script\n.hlp,application/hlp\n.hlp,application/winhlp\n.hlp,application/x-helpfile\n.hlp,application/x-winhelp\n.hpg,application/vnd.hp-hpgl\n.hpgl,application/vnd.hp-hpgl\n.hpid,application/vnd.hp-hpid\n.hps,application/vnd.hp-hps\n.hqx,application/binhex\n.hqx,application/binhex4\n.hqx,application/mac-binhex\n.hqx,application/mac-binhex40\n.hqx,application/x-binhex40\n.hqx,application/x-mac-binhex40\n.hta,application/hta\n.htc,text/x-component\n.h,text/plain\n.h,text/x-h\n.htke,application/vnd.kenameaapp\n.htmls,text/html\n.html,text/html\n.htm,text/html\n.htt,text/webviewhtml\n.htx,text/html\n.hvd,application/vnd.yamaha.hv-dic\n.hvp,application/vnd.yamaha.hv-voice\n.hvs,application/vnd.yamaha.hv-script\n.i2g,application/vnd.intergeo\n.icc,application/vnd.iccprofile\n.ice,x-conference/x-cooltalk\n.ico,image/x-icon\n.ics,text/calendar\n.idc,text/plain\n.ief,image/ief\n.iefs,image/ief\n.iff,application/iff\n.ifm,application/vnd.shana.informed.formdata\n.iges,application/iges\n.iges,model/iges\n.igl,application/vnd.igloader\n.igm,application/vnd.insors.igm\n.igs,application/iges\n.igs,model/iges\n.igx,application/vnd.micrografx.igx\n.iif,application/vnd.shana.informed.interchange\n.ima,application/x-ima\n.imap,application/x-httpd-imap\n.imp,application/vnd.accpac.simply.imp\n.ims,application/vnd.ms-ims\n.inf,application/inf\n.ins,application/x-internett-signup\n.ip,application/x-ip2\n.ipfix,application/ipfix\n.ipk,application/vnd.shana.informed.package\n.irm,application/vnd.ibm.rights-management\n.irp,application/vnd.irepository.package+xml\n.isu,video/x-isvideo\n.it,audio/it\n.itp,application/vnd.shana.informed.formtemplate\n.iv,application/x-inventor\n.ivp,application/vnd.immervision-ivp\n.ivr,i-world/i-vrml\n.ivu,application/vnd.immervision-ivu\n.ivy,application/x-livescreen\n.jad,text/vnd.sun.j2me.app-descriptor\n.jam,application/vnd.jam\n.jam,audio/x-jam\n.jar,application/java-archive\n.java,text/plain\n.java,text/x-java-source\n.jav,text/plain\n.jav,text/x-java-source\n.jcm,application/x-java-commerce\n.jfif,image/jpeg\n.jfif,image/pjpeg\n.jfif-tbnl,image/jpeg\n.jisp,application/vnd.jisp\n.jlt,application/vnd.hp-jlyt\n.jnlp,application/x-java-jnlp-file\n.joda,application/vnd.joost.joda-archive\n.jpeg,image/jpeg\n.jpe,image/jpeg\n.jpg,image/jpeg\n.jpgv,video/jpeg\n.jpm,video/jpm\n.jps,image/x-jps\n.js,application/javascript\n.json,application/json\n.jut,image/jutvision\n.kar,audio/midi\n.karbon,application/vnd.kde.karbon\n.kar,music/x-karaoke\n.key,application/pgp-keys\n.keychain,application/octet-stream\n.kfo,application/vnd.kde.kformula\n.kia,application/vnd.kidspiration\n.kml,application/vnd.google-earth.kml+xml\n.kmz,application/vnd.google-earth.kmz\n.kne,application/vnd.kinar\n.kon,application/vnd.kde.kontour\n.kpr,application/vnd.kde.kpresenter\n.ksh,application/x-ksh\n.ksh,text/x-script.ksh\n.ksp,application/vnd.kde.kspread\n.ktx,image/ktx\n.ktz,application/vnd.kahootz\n.kwd,application/vnd.kde.kword\n.la,audio/nspaudio\n.la,audio/x-nspaudio\n.lam,audio/x-liveaudio\n.lasxml,application/vnd.las.las+xml\n.latex,application/x-latex\n.lbd,application/vnd.llamagraphics.life-balance.desktop\n.lbe,application/vnd.llamagraphics.life-balance.exchange+xml\n.les,application/vnd.hhe.lesson-player\n.lha,application/lha\n.lha,application/x-lha\n.link66,application/vnd.route66.link66+xml\n.list,text/plain\n.lma,audio/nspaudio\n.lma,audio/x-nspaudio\n.log,text/plain\n.lrm,application/vnd.ms-lrm\n.lsp,application/x-lisp\n.lsp,text/x-script.lisp\n.lst,text/plain\n.lsx,text/x-la-asf\n.ltf,application/vnd.frogans.ltf\n.ltx,application/x-latex\n.lvp,audio/vnd.lucent.voice\n.lwp,application/vnd.lotus-wordpro\n.lzh,application/octet-stream\n.lzh,application/x-lzh\n.lzx,application/lzx\n.lzx,application/octet-stream\n.lzx,application/x-lzx\n.m1v,video/mpeg\n.m21,application/mp21\n.m2a,audio/mpeg\n.m2v,video/mpeg\n.m3u8,application/vnd.apple.mpegurl\n.m3u,audio/x-mpegurl\n.m4a,audio/mp4\n.m4v,video/mp4\n.ma,application/mathematica\n.mads,application/mads+xml\n.mag,application/vnd.ecowin.chart\n.man,application/x-troff-man\n.map,application/x-navimap\n.mar,text/plain\n.mathml,application/mathml+xml\n.mbd,application/mbedlet\n.mbk,application/vnd.mobius.mbk\n.mbox,application/mbox\n.mc1,application/vnd.medcalcdata\n.mc$,application/x-magic-cap-package-1.0\n.mcd,application/mcad\n.mcd,application/vnd.mcd\n.mcd,application/x-mathcad\n.mcf,image/vasa\n.mcf,text/mcf\n.mcp,application/netmc\n.mcurl,text/vnd.curl.mcurl\n.mdb,application/x-msaccess\n.mdi,image/vnd.ms-modi\n.me,application/x-troff-me\n.meta4,application/metalink4+xml\n.mets,application/mets+xml\n.mfm,application/vnd.mfmp\n.mgp,application/vnd.osgeo.mapguide.package\n.mgz,application/vnd.proteus.magazine\n.mht,message/rfc822\n.mhtml,message/rfc822\n.mid,application/x-midi\n.mid,audio/midi\n.mid,audio/x-mid\n.midi,application/x-midi\n.midi,audio/midi\n.midi,audio/x-mid\n.midi,audio/x-midi\n.midi,music/crescendo\n.midi,x-music/x-midi\n.mid,music/crescendo\n.mid,x-music/x-midi\n.mif,application/vnd.mif\n.mif,application/x-frame\n.mif,application/x-mif\n.mime,message/rfc822\n.mime,www/mime\n.mj2,video/mj2\n.mjf,audio/x-vnd.audioexplosion.mjuicemediafile\n.mjpg,video/x-motion-jpeg\n.mkv,video/x-matroska\n.mkv,audio/x-matroska\n.mlp,application/vnd.dolby.mlp\n.mm,application/base64\n.mm,application/x-meme\n.mmd,application/vnd.chipnuts.karaoke-mmd\n.mme,application/base64\n.mmf,application/vnd.smaf\n.mmr,image/vnd.fujixerox.edmics-mmr\n.mny,application/x-msmoney\n.mod,audio/mod\n.mod,audio/x-mod\n.mods,application/mods+xml\n.moov,video/quicktime\n.movie,video/x-sgi-movie\n.mov,video/quicktime\n.mp2,audio/mpeg\n.mp2,audio/x-mpeg\n.mp2,video/mpeg\n.mp2,video/x-mpeg\n.mp2,video/x-mpeq2a\n.mp3,audio/mpeg\n.mp3,audio/mpeg3\n.mp4a,audio/mp4\n.mp4,application/mp4\n.mp4,video/mp4\n.mpa,audio/mpeg\n.mpc,application/vnd.mophun.certificate\n.mpc,application/x-project\n.mpeg,video/mpeg\n.mpe,video/mpeg\n.mpga,audio/mpeg\n.mpg,video/mpeg\n.mpg,audio/mpeg\n.mpkg,application/vnd.apple.installer+xml\n.mpm,application/vnd.blueice.multipass\n.mpn,application/vnd.mophun.application\n.mpp,application/vnd.ms-project\n.mpt,application/x-project\n.mpv,application/x-project\n.mpx,application/x-project\n.mpy,application/vnd.ibm.minipay\n.mqy,application/vnd.mobius.mqy\n.mrc,application/marc\n.mrcx,application/marcxml+xml\n.ms,application/x-troff-ms\n.mscml,application/mediaservercontrol+xml\n.mseq,application/vnd.mseq\n.msf,application/vnd.epson.msf\n.msg,application/vnd.ms-outlook\n.msh,model/mesh\n.msl,application/vnd.mobius.msl\n.msty,application/vnd.muvee.style\n.m,text/plain\n.m,text/x-m\n.mts,model/vnd.mts\n.mus,application/vnd.musician\n.musicxml,application/vnd.recordare.musicxml+xml\n.mvb,application/x-msmediaview\n.mv,video/x-sgi-movie\n.mwf,application/vnd.mfer\n.mxf,application/mxf\n.mxl,application/vnd.recordare.musicxml\n.mxml,application/xv+xml\n.mxs,application/vnd.triscape.mxs\n.mxu,video/vnd.mpegurl\n.my,audio/make\n.mzz,application/x-vnd.audioexplosion.mzz\n.n3,text/n3\nN/A,application/andrew-inset\n.nap,image/naplps\n.naplps,image/naplps\n.nbp,application/vnd.wolfram.player\n.nc,application/x-netcdf\n.ncm,application/vnd.nokia.configuration-message\n.ncx,application/x-dtbncx+xml\n.n-gage,application/vnd.nokia.n-gage.symbian.install\n.ngdat,application/vnd.nokia.n-gage.data\n.niff,image/x-niff\n.nif,image/x-niff\n.nix,application/x-mix-transfer\n.nlu,application/vnd.neurolanguage.nlu\n.nml,application/vnd.enliven\n.nnd,application/vnd.noblenet-directory\n.nns,application/vnd.noblenet-sealer\n.nnw,application/vnd.noblenet-web\n.npx,image/vnd.net-fpx\n.nsc,application/x-conference\n.nsf,application/vnd.lotus-notes\n.nvd,application/x-navidoc\n.oa2,application/vnd.fujitsu.oasys2\n.oa3,application/vnd.fujitsu.oasys3\n.o,application/octet-stream\n.oas,application/vnd.fujitsu.oasys\n.obd,application/x-msbinder\n.oda,application/oda\n.odb,application/vnd.oasis.opendocument.database\n.odc,application/vnd.oasis.opendocument.chart\n.odf,application/vnd.oasis.opendocument.formula\n.odft,application/vnd.oasis.opendocument.formula-template\n.odg,application/vnd.oasis.opendocument.graphics\n.odi,application/vnd.oasis.opendocument.image\n.odm,application/vnd.oasis.opendocument.text-master\n.odp,application/vnd.oasis.opendocument.presentation\n.ods,application/vnd.oasis.opendocument.spreadsheet\n.odt,application/vnd.oasis.opendocument.text\n.oga,audio/ogg\n.ogg,audio/ogg\n.ogv,video/ogg\n.ogx,application/ogg\n.omc,application/x-omc\n.omcd,application/x-omcdatamaker\n.omcr,application/x-omcregerator\n.onetoc,application/onenote\n.opf,application/oebps-package+xml\n.org,application/vnd.lotus-organizer\n.osf,application/vnd.yamaha.openscoreformat\n.osfpvg,application/vnd.yamaha.openscoreformat.osfpvg+xml\n.otc,application/vnd.oasis.opendocument.chart-template\n.otf,application/x-font-otf\n.otg,application/vnd.oasis.opendocument.graphics-template\n.oth,application/vnd.oasis.opendocument.text-web\n.oti,application/vnd.oasis.opendocument.image-template\n.otp,application/vnd.oasis.opendocument.presentation-template\n.ots,application/vnd.oasis.opendocument.spreadsheet-template\n.ott,application/vnd.oasis.opendocument.text-template\n.oxt,application/vnd.openofficeorg.extension\n.p10,application/pkcs10\n.p12,application/pkcs-12\n.p7a,application/x-pkcs7-signature\n.p7b,application/x-pkcs7-certificates\n.p7c,application/pkcs7-mime\n.p7m,application/pkcs7-mime\n.p7r,application/x-pkcs7-certreqresp\n.p7s,application/pkcs7-signature\n.p8,application/pkcs8\n.pages,application/vnd.apple.pages\n.part,application/pro_eng\n.par,text/plain-bas\n.pas,text/pascal\n.paw,application/vnd.pawaafile\n.pbd,application/vnd.powerbuilder6\n.pbm,image/x-portable-bitmap\n.pcf,application/x-font-pcf\n.pcl,application/vnd.hp-pcl\n.pcl,application/x-pcl\n.pclxl,application/vnd.hp-pclxl\n.pct,image/x-pict\n.pcurl,application/vnd.curl.pcurl\n.pcx,image/x-pcx\n.pdb,application/vnd.palm\n.pdb,chemical/x-pdb\n.pdf,application/pdf\n.pem,application/x-pem-file\n.pfa,application/x-font-type1\n.pfr,application/font-tdpfr\n.pfunk,audio/make\n.pfunk,audio/make.my.funk\n.pfx,application/x-pkcs12\n.pgm,image/x-portable-graymap\n.pgn,application/x-chess-pgn\n.pgp,application/pgp-signature\n.pic,image/pict\n.pict,image/pict\n.pkg,application/x-newton-compatible-pkg\n.pki,application/pkixcmp\n.pkipath,application/pkix-pkipath\n.pko,application/vnd.ms-pki.pko\n.plb,application/vnd.3gpp.pic-bw-large\n.plc,application/vnd.mobius.plc\n.plf,application/vnd.pocketlearn\n.pls,application/pls+xml\n.pl,text/plain\n.pl,text/x-script.perl\n.plx,application/x-pixclscript\n.pm4,application/x-pagemaker\n.pm5,application/x-pagemaker\n.pm,image/x-xpixmap\n.pml,application/vnd.ctc-posml\n.pm,text/x-script.perl-module\n.png,image/png\n.pnm,application/x-portable-anymap\n.pnm,image/x-portable-anymap\n.portpkg,application/vnd.macports.portpkg\n.pot,application/mspowerpoint\n.pot,application/vnd.ms-powerpoint\n.potm,application/vnd.ms-powerpoint.template.macroenabled.12\n.potx,application/vnd.openxmlformats-officedocument.presentationml.template\n.pov,model/x-pov\n.ppa,application/vnd.ms-powerpoint\n.ppam,application/vnd.ms-powerpoint.addin.macroenabled.12\n.ppd,application/vnd.cups-ppd\n.ppm,image/x-portable-pixmap\n.pps,application/mspowerpoint\n.pps,application/vnd.ms-powerpoint\n.ppsm,application/vnd.ms-powerpoint.slideshow.macroenabled.12\n.ppsx,application/vnd.openxmlformats-officedocument.presentationml.slideshow\n.ppt,application/mspowerpoint\n.ppt,application/powerpoint\n.ppt,application/vnd.ms-powerpoint\n.ppt,application/x-mspowerpoint\n.pptm,application/vnd.ms-powerpoint.presentation.macroenabled.12\n.pptx,application/vnd.openxmlformats-officedocument.presentationml.presentation\n.ppz,application/mspowerpoint\n.prc,application/x-mobipocket-ebook\n.pre,application/vnd.lotus-freelance\n.pre,application/x-freelance\n.prf,application/pics-rules\n.prt,application/pro_eng\n.ps,application/postscript\n.psb,application/vnd.3gpp.pic-bw-small\n.psd,application/octet-stream\n.psd,image/vnd.adobe.photoshop\n.psf,application/x-font-linux-psf\n.pskcxml,application/pskc+xml\n.p,text/x-pascal\n.ptid,application/vnd.pvi.ptid1\n.pub,application/x-mspublisher\n.pvb,application/vnd.3gpp.pic-bw-var\n.pvu,paleovu/x-pv\n.pwn,application/vnd.3m.post-it-notes\n.pwz,application/vnd.ms-powerpoint\n.pya,audio/vnd.ms-playready.media.pya\n.pyc,applicaiton/x-bytecode.python\n.py,text/x-script.phyton\n.pyv,video/vnd.ms-playready.media.pyv\n.qam,application/vnd.epson.quickanime\n.qbo,application/vnd.intu.qbo\n.qcp,audio/vnd.qcelp\n.qd3d,x-world/x-3dmf\n.qd3,x-world/x-3dmf\n.qfx,application/vnd.intu.qfx\n.qif,image/x-quicktime\n.qps,application/vnd.publishare-delta-tree\n.qtc,video/x-qtc\n.qtif,image/x-quicktime\n.qti,image/x-quicktime\n.qt,video/quicktime\n.qxd,application/vnd.quark.quarkxpress\n.ra,audio/x-pn-realaudio\n.ra,audio/x-pn-realaudio-plugin\n.ra,audio/x-realaudio\n.ram,audio/x-pn-realaudio\n.rar,application/x-rar-compressed\n.ras,application/x-cmu-raster\n.ras,image/cmu-raster\n.ras,image/x-cmu-raster\n.rast,image/cmu-raster\n.rcprofile,application/vnd.ipunplugged.rcprofile\n.rdf,application/rdf+xml\n.rdz,application/vnd.data-vision.rdz\n.rep,application/vnd.businessobjects\n.res,application/x-dtbresource+xml\n.rexx,text/x-script.rexx\n.rf,image/vnd.rn-realflash\n.rgb,image/x-rgb\n.rif,application/reginfo+xml\n.rip,audio/vnd.rip\n.rl,application/resource-lists+xml\n.rlc,image/vnd.fujixerox.edmics-rlc\n.rld,application/resource-lists-diff+xml\n.rm,application/vnd.rn-realmedia\n.rm,audio/x-pn-realaudio\n.rmi,audio/mid\n.rmm,audio/x-pn-realaudio\n.rmp,audio/x-pn-realaudio\n.rmp,audio/x-pn-realaudio-plugin\n.rms,application/vnd.jcp.javame.midlet-rms\n.rnc,application/relax-ng-compact-syntax\n.rng,application/ringing-tones\n.rng,application/vnd.nokia.ringing-tone\n.rnx,application/vnd.rn-realplayer\n.roff,application/x-troff\n.rp9,application/vnd.cloanto.rp9\n.rp,image/vnd.rn-realpix\n.rpm,audio/x-pn-realaudio-plugin\n.rpm,application/x-rpm\n.rpss,application/vnd.nokia.radio-presets\n.rpst,application/vnd.nokia.radio-preset\n.rq,application/sparql-query\n.rs,application/rls-services+xml\n.rsd,application/rsd+xml\n.rss,application/rss+xml\n.rtf,application/rtf\n.rtf,text/rtf\n.rt,text/richtext\n.rt,text/vnd.rn-realtext\n.rtx,application/rtf\n.rtx,text/richtext\n.rv,video/vnd.rn-realvideo\n.s3m,audio/s3m\n.saf,application/vnd.yamaha.smaf-audio\n.saveme,application/octet-stream\n.sbk,application/x-tbook\n.sbml,application/sbml+xml\n.sc,application/vnd.ibm.secure-container\n.scd,application/x-msschedule\n.scm,application/vnd.lotus-screencam\n.scm,application/x-lotusscreencam\n.scm,text/x-script.guile\n.scm,text/x-script.scheme\n.scm,video/x-scm\n.scq,application/scvp-cv-request\n.scs,application/scvp-cv-response\n.scurl,text/vnd.curl.scurl\n.sda,application/vnd.stardivision.draw\n.sdc,application/vnd.stardivision.calc\n.sdd,application/vnd.stardivision.impress\n.sdf,application/octet-stream\n.sdkm,application/vnd.solent.sdkm+xml\n.sdml,text/plain\n.sdp,application/sdp\n.sdp,application/x-sdp\n.sdr,application/sounder\n.sdw,application/vnd.stardivision.writer\n.sea,application/sea\n.sea,application/x-sea\n.see,application/vnd.seemail\n.seed,application/vnd.fdsn.seed\n.sema,application/vnd.sema\n.semd,application/vnd.semd\n.semf,application/vnd.semf\n.ser,application/java-serialized-object\n.set,application/set\n.setpay,application/set-payment-initiation\n.setreg,application/set-registration-initiation\n.sfd-hdstx,application/vnd.hydrostatix.sof-data\n.sfs,application/vnd.spotfire.sfs\n.sgl,application/vnd.stardivision.writer-global\n.sgml,text/sgml\n.sgml,text/x-sgml\n.sgm,text/sgml\n.sgm,text/x-sgml\n.sh,application/x-bsh\n.sh,application/x-sh\n.sh,application/x-shar\n.shar,application/x-bsh\n.shar,application/x-shar\n.shf,application/shf+xml\n.sh,text/x-script.sh\n.shtml,text/html\n.shtml,text/x-server-parsed-html\n.sid,audio/x-psid\n.sis,application/vnd.symbian.install\n.sit,application/x-sit\n.sit,application/x-stuffit\n.sitx,application/x-stuffitx\n.skd,application/x-koan\n.skm,application/x-koan\n.skp,application/vnd.koan\n.skp,application/x-koan\n.skt,application/x-koan\n.sl,application/x-seelogo\n.sldm,application/vnd.ms-powerpoint.slide.macroenabled.12\n.sldx,application/vnd.openxmlformats-officedocument.presentationml.slide\n.slt,application/vnd.epson.salt\n.sm,application/vnd.stepmania.stepchart\n.smf,application/vnd.stardivision.math\n.smi,application/smil\n.smi,application/smil+xml\n.smil,application/smil\n.snd,audio/basic\n.snd,audio/x-adpcm\n.snf,application/x-font-snf\n.sol,application/solids\n.spc,application/x-pkcs7-certificates\n.spc,text/x-speech\n.spf,application/vnd.yamaha.smaf-phrase\n.spl,application/futuresplash\n.spl,application/x-futuresplash\n.spot,text/vnd.in3d.spot\n.spp,application/scvp-vp-response\n.spq,application/scvp-vp-request\n.spr,application/x-sprite\n.sprite,application/x-sprite\n.src,application/x-wais-source\n.srt,text/srt\n.sru,application/sru+xml\n.srx,application/sparql-results+xml\n.sse,application/vnd.kodak-descriptor\n.ssf,application/vnd.epson.ssf\n.ssi,text/x-server-parsed-html\n.ssm,application/streamingmedia\n.ssml,application/ssml+xml\n.sst,application/vnd.ms-pki.certstore\n.st,application/vnd.sailingtracker.track\n.stc,application/vnd.sun.xml.calc.template\n.std,application/vnd.sun.xml.draw.template\n.step,application/step\n.s,text/x-asm\n.stf,application/vnd.wt.stf\n.sti,application/vnd.sun.xml.impress.template\n.stk,application/hyperstudio\n.stl,application/sla\n.stl,application/vnd.ms-pki.stl\n.stl,application/x-navistyle\n.stp,application/step\n.str,application/vnd.pg.format\n.stw,application/vnd.sun.xml.writer.template\n.sub,image/vnd.dvb.subtitle\n.sus,application/vnd.sus-calendar\n.sv4cpio,application/x-sv4cpio\n.sv4crc,application/x-sv4crc\n.svc,application/vnd.dvb.service\n.svd,application/vnd.svd\n.svf,image/vnd.dwg\n.svf,image/x-dwg\n.svg,image/svg+xml\n.svr,application/x-world\n.svr,x-world/x-svr\n.swf,application/x-shockwave-flash\n.swi,application/vnd.aristanetworks.swi\n.sxc,application/vnd.sun.xml.calc\n.sxd,application/vnd.sun.xml.draw\n.sxg,application/vnd.sun.xml.writer.global\n.sxi,application/vnd.sun.xml.impress\n.sxm,application/vnd.sun.xml.math\n.sxw,application/vnd.sun.xml.writer\n.talk,text/x-speech\n.tao,application/vnd.tao.intent-module-archive\n.t,application/x-troff\n.tar,application/x-tar\n.tbk,application/toolbook\n.tbk,application/x-tbook\n.tcap,application/vnd.3gpp2.tcap\n.tcl,application/x-tcl\n.tcl,text/x-script.tcl\n.tcsh,text/x-script.tcsh\n.teacher,application/vnd.smart.teacher\n.tei,application/tei+xml\n.tex,application/x-tex\n.texi,application/x-texinfo\n.texinfo,application/x-texinfo\n.text,text/plain\n.tfi,application/thraud+xml\n.tfm,application/x-tex-tfm\n.tgz,application/gnutar\n.tgz,application/x-compressed\n.thmx,application/vnd.ms-officetheme\n.tiff,image/tiff\n.tif,image/tiff\n.tmo,application/vnd.tmobile-livetv\n.torrent,application/x-bittorrent\n.tpl,application/vnd.groove-tool-template\n.tpt,application/vnd.trid.tpt\n.tra,application/vnd.trueapp\n.tr,application/x-troff\n.trm,application/x-msterminal\n.tsd,application/timestamped-data\n.tsi,audio/tsp-audio\n.tsp,application/dsptype\n.tsp,audio/tsplayer\n.tsv,text/tab-separated-values\n.t,text/troff\n.ttf,application/x-font-ttf\n.ttl,text/turtle\n.turbot,image/florian\n.twd,application/vnd.simtech-mindmapper\n.txd,application/vnd.genomatix.tuxedo\n.txf,application/vnd.mobius.txf\n.txt,text/plain\n.ufd,application/vnd.ufdl\n.uil,text/x-uil\n.umj,application/vnd.umajin\n.unis,text/uri-list\n.uni,text/uri-list\n.unityweb,application/vnd.unity\n.unv,application/i-deas\n.uoml,application/vnd.uoml+xml\n.uris,text/uri-list\n.uri,text/uri-list\n.ustar,application/x-ustar\n.ustar,multipart/x-ustar\n.utz,application/vnd.uiq.theme\n.uu,application/octet-stream\n.uue,text/x-uuencode\n.uu,text/x-uuencode\n.uva,audio/vnd.dece.audio\n.uvh,video/vnd.dece.hd\n.uvi,image/vnd.dece.graphic\n.uvm,video/vnd.dece.mobile\n.uvp,video/vnd.dece.pd\n.uvs,video/vnd.dece.sd\n.uvu,video/vnd.uvvu.mp4\n.uvv,video/vnd.dece.video\n.vcd,application/x-cdlink\n.vcf,text/x-vcard\n.vcg,application/vnd.groove-vcard\n.vcs,text/x-vcalendar\n.vcx,application/vnd.vcx\n.vda,application/vda\n.vdo,video/vdo\n.vew,application/groupwise\n.vis,application/vnd.visionary\n.vivo,video/vivo\n.vivo,video/vnd.vivo\n.viv,video/vivo\n.viv,video/vnd.vivo\n.vmd,application/vocaltec-media-desc\n.vmf,application/vocaltec-media-file\n.vob,video/dvd\n.voc,audio/voc\n.voc,audio/x-voc\n.vos,video/vosaic\n.vox,audio/voxware\n.vqe,audio/x-twinvq-plugin\n.vqf,audio/x-twinvq\n.vql,audio/x-twinvq-plugin\n.vrml,application/x-vrml\n.vrml,model/vrml\n.vrml,x-world/x-vrml\n.vrt,x-world/x-vrt\n.vsd,application/vnd.visio\n.vsd,application/x-visio\n.vsf,application/vnd.vsf\n.vst,application/x-visio\n.vsw,application/x-visio\n.vtt,text/vtt\n.vtu,model/vnd.vtu\n.vxml,application/voicexml+xml\n.w60,application/wordperfect6.0\n.w61,application/wordperfect6.1\n.w6w,application/msword\n.wad,application/x-doom\n.war,application/zip\n.wasm,application/wasm\n.wav,audio/wav\n.wax,audio/x-ms-wax\n.wb1,application/x-qpro\n.wbmp,image/vnd.wap.wbmp\n.wbs,application/vnd.criticaltools.wbs+xml\n.wbxml,application/vnd.wap.wbxml\n.weba,audio/webm\n.web,application/vnd.xara\n.webm,video/webm\n.webp,image/webp\n.wg,application/vnd.pmi.widget\n.wgt,application/widget\n.wiz,application/msword\n.wk1,application/x-123\n.wma,audio/x-ms-wma\n.wmd,application/x-ms-wmd\n.wmf,application/x-msmetafile\n.wmf,windows/metafile\n.wmlc,application/vnd.wap.wmlc\n.wmlsc,application/vnd.wap.wmlscriptc\n.wmls,text/vnd.wap.wmlscript\n.wml,text/vnd.wap.wml\n.wm,video/x-ms-wm\n.wmv,video/x-ms-wmv\n.wmx,video/x-ms-wmx\n.wmz,application/x-ms-wmz\n.woff,application/x-font-woff\n.word,application/msword\n.wp5,application/wordperfect\n.wp5,application/wordperfect6.0\n.wp6,application/wordperfect\n.wp,application/wordperfect\n.wpd,application/vnd.wordperfect\n.wpd,application/wordperfect\n.wpd,application/x-wpwin\n.wpl,application/vnd.ms-wpl\n.wps,application/vnd.ms-works\n.wq1,application/x-lotus\n.wqd,application/vnd.wqd\n.wri,application/mswrite\n.wri,application/x-mswrite\n.wri,application/x-wri\n.wrl,application/x-world\n.wrl,model/vrml\n.wrl,x-world/x-vrml\n.wrz,model/vrml\n.wrz,x-world/x-vrml\n.wsc,text/scriplet\n.wsdl,application/wsdl+xml\n.wspolicy,application/wspolicy+xml\n.wsrc,application/x-wais-source\n.wtb,application/vnd.webturbo\n.wtk,application/x-wintalk\n.wvx,video/x-ms-wvx\n.x3d,application/vnd.hzn-3d-crossword\n.xap,application/x-silverlight-app\n.xar,application/vnd.xara\n.xbap,application/x-ms-xbap\n.xbd,application/vnd.fujixerox.docuworks.binder\n.xbm,image/xbm\n.xbm,image/x-xbitmap\n.xbm,image/x-xbm\n.xdf,application/xcap-diff+xml\n.xdm,application/vnd.syncml.dm+xml\n.xdp,application/vnd.adobe.xdp+xml\n.xdr,video/x-amt-demorun\n.xdssc,application/dssc+xml\n.xdw,application/vnd.fujixerox.docuworks\n.xenc,application/xenc+xml\n.xer,application/patch-ops-error+xml\n.xfdf,application/vnd.adobe.xfdf\n.xfdl,application/vnd.xfdl\n.xgz,xgl/drawing\n.xhtml,application/xhtml+xml\n.xif,image/vnd.xiff\n.xla,application/excel\n.xla,application/x-excel\n.xla,application/x-msexcel\n.xlam,application/vnd.ms-excel.addin.macroenabled.12\n.xl,application/excel\n.xlb,application/excel\n.xlb,application/vnd.ms-excel\n.xlb,application/x-excel\n.xlc,application/excel\n.xlc,application/vnd.ms-excel\n.xlc,application/x-excel\n.xld,application/excel\n.xld,application/x-excel\n.xlk,application/excel\n.xlk,application/x-excel\n.xll,application/excel\n.xll,application/vnd.ms-excel\n.xll,application/x-excel\n.xlm,application/excel\n.xlm,application/vnd.ms-excel\n.xlm,application/x-excel\n.xls,application/excel\n.xls,application/vnd.ms-excel\n.xls,application/x-excel\n.xls,application/x-msexcel\n.xlsb,application/vnd.ms-excel.sheet.binary.macroenabled.12\n.xlsm,application/vnd.ms-excel.sheet.macroenabled.12\n.xlsx,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\n.xlt,application/excel\n.xlt,application/x-excel\n.xltm,application/vnd.ms-excel.template.macroenabled.12\n.xltx,application/vnd.openxmlformats-officedocument.spreadsheetml.template\n.xlv,application/excel\n.xlv,application/x-excel\n.xlw,application/excel\n.xlw,application/vnd.ms-excel\n.xlw,application/x-excel\n.xlw,application/x-msexcel\n.xm,audio/xm\n.xml,application/xml\n.xml,text/xml\n.xmz,xgl/movie\n.xo,application/vnd.olpc-sugar\n.xop,application/xop+xml\n.xpi,application/x-xpinstall\n.xpix,application/x-vnd.ls-xpix\n.xpm,image/xpm\n.xpm,image/x-xpixmap\n.x-png,image/png\n.xpr,application/vnd.is-xpr\n.xps,application/vnd.ms-xpsdocument\n.xpw,application/vnd.intercon.formnet\n.xslt,application/xslt+xml\n.xsm,application/vnd.syncml+xml\n.xspf,application/xspf+xml\n.xsr,video/x-amt-showrun\n.xul,application/vnd.mozilla.xul+xml\n.xwd,image/x-xwd\n.xwd,image/x-xwindowdump\n.xyz,chemical/x-pdb\n.xyz,chemical/x-xyz\n.xz,application/x-xz\n.yaml,text/yaml\n.yang,application/yang\n.yin,application/yin+xml\n.z,application/x-compress\n.z,application/x-compressed\n.zaz,application/vnd.zzazz.deck+xml\n.zip,application/zip\n.zip,application/x-compressed\n.zip,application/x-zip-compressed\n.zip,multipart/x-zip\n.zir,application/vnd.zul\n.zmm,application/vnd.handheld-entertainment+xml\n.zoo,application/octet-stream\n.zsh,text/x-script.zsh\n"),ni))}function ri(){return Kn.value}function oi(){li()}function ai(){si=this,this.Empty=hi()}Yn.$metadata$={kind:h,simpleName:"HttpStatusCode",interfaces:[]},Yn.prototype.component1=function(){return this.value},Yn.prototype.component2=function(){return this.description},Yn.prototype.copy_19mbxw$=function(t,e){return new Yn(void 0===t?this.value:t,void 0===e?this.description:e)},ai.prototype.build_itqcaa$=ht("ktor-ktor-http.io.ktor.http.Parameters.Companion.build_itqcaa$",_t((function(){var e=t.io.ktor.http.ParametersBuilder;return function(t){var n=new e;return t(n),n.build()}}))),ai.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var si=null;function li(){return null===si&&new ai,si}function ui(t){void 0===t&&(t=8),St.call(this,!0,t)}function ci(){pi=this}oi.$metadata$={kind:Et,simpleName:"Parameters",interfaces:[Ct]},ui.prototype.build=function(){if(this.built)throw it("ParametersBuilder can only build a single Parameters instance".toString());return this.built=!0,new _i(this.values)},ui.$metadata$={kind:h,simpleName:"ParametersBuilder",interfaces:[St]},Object.defineProperty(ci.prototype,"caseInsensitiveName",{get:function(){return!0}}),ci.prototype.getAll_61zpoe$=function(t){return null},ci.prototype.names=function(){return Tt()},ci.prototype.entries=function(){return Tt()},ci.prototype.isEmpty=function(){return!0},ci.prototype.toString=function(){return"Parameters "+this.entries()},ci.prototype.equals=function(t){return e.isType(t,oi)&&t.isEmpty()},ci.$metadata$={kind:M,simpleName:"EmptyParameters",interfaces:[oi]};var pi=null;function hi(){return null===pi&&new ci,pi}function _i(t){void 0===t&&(t=X()),Pt.call(this,!0,t)}function fi(t,e,n){var i;if(void 0===e&&(e=0),void 0===n&&(n=1e3),e>It(t))i=li().Empty;else{var r=new ui;(function(t,e,n,i){var r,o=0,a=n,s=-1;r=It(e);for(var l=n;l<=r;l++){if(o===i)return;switch(e.charCodeAt(l)){case 38:di(t,e,a,s,l),a=l+1|0,s=-1,o=o+1|0;break;case 61:-1===s&&(s=l)}}o!==i&&di(t,e,a,s,e.length)})(r,t,e,n),i=r.build()}return i}function di(t,e,n,i,r){if(-1===i){var o=yi(n,r,e),a=mi(o,r,e);if(a>o){var s=me(e,o,a);t.appendAll_poujtz$(s,B())}}else{var l=yi(n,i,e),u=mi(l,i,e);if(u>l){var c=me(e,l,u),p=yi(i+1|0,r,e),h=me(e,p,mi(p,r,e),!0);t.append_puj7f4$(c,h)}}}function mi(t,e,n){for(var i=e;i>t&&rt(n.charCodeAt(i-1|0));)i=i-1|0;return i}function yi(t,e,n){for(var i=t;i0&&(t.append_s8itvh$(35),t.append_gw00v9$(he(this.fragment))),t},$i.prototype.buildString=function(){return this.appendTo_0(S(256)).toString()},$i.prototype.build=function(){return new xi(this.protocol,this.host,this.port,this.encodedPath,this.parameters.build(),this.fragment,this.user,this.password,this.trailingQuery)},gi.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var bi=null;function wi(){return null===bi&&new gi,bi}function xi(t,e,n,i,r,o,a,s,l){var u;if(Ci(),this.protocol=t,this.host=e,this.specifiedPort=n,this.encodedPath=i,this.parameters=r,this.fragment=o,this.user=a,this.password=s,this.trailingQuery=l,!(1<=(u=this.specifiedPort)&&u<=65536||0===this.specifiedPort))throw it("port must be between 1 and 65536, or 0 if not set".toString())}function ki(){Ei=this}$i.$metadata$={kind:h,simpleName:"URLBuilder",interfaces:[]},Object.defineProperty(xi.prototype,"port",{get:function(){var t,e=this.specifiedPort;return null!=(t=0!==e?e:null)?t:this.protocol.defaultPort}}),xi.prototype.toString=function(){var t=P();return t.append_gw00v9$(this.protocol.name),t.append_gw00v9$("://"),t.append_gw00v9$(Si(this)),t.append_gw00v9$(Bi(this)),this.fragment.length>0&&(t.append_s8itvh$(35),t.append_gw00v9$(this.fragment)),t.toString()},ki.$metadata$={kind:M,simpleName:"Companion",interfaces:[]};var Ei=null;function Ci(){return null===Ei&&new ki,Ei}function Si(t){var e=P();return null!=t.user&&(e.append_gw00v9$(de(t.user)),null!=t.password&&(e.append_s8itvh$(58),e.append_gw00v9$(de(t.password))),e.append_s8itvh$(64)),0===t.specifiedPort?e.append_gw00v9$(t.host):e.append_gw00v9$(Ui(t)),e.toString()}function Ti(t){var e,n,i=P();return null!=(e=t.user)&&(i.append_gw00v9$(de(e)),null!=(n=t.password)&&(i.append_gw00v9$(":"),i.append_gw00v9$(de(n))),i.append_gw00v9$("@")),i.append_gw00v9$(t.host),0!==t.port&&t.port!==t.protocol.defaultPort&&(i.append_gw00v9$(":"),i.append_gw00v9$(t.port.toString())),i.toString()}function Oi(t,e){mt.call(this,"Fail to parse url: "+t,e),this.name="URLParserException"}function Ni(t,e){var n,i,r,o,a;t:do{var s,l,u,c;l=(s=Yt(e)).first,u=s.last,c=s.step;for(var p=l;p<=u;p+=c)if(!rt(v(b(e.charCodeAt(p))))){a=p;break t}a=-1}while(0);var h,_=a;t:do{var f;for(f=Vt(Yt(e)).iterator();f.hasNext();){var d=f.next();if(!rt(v(b(e.charCodeAt(d))))){h=d;break t}}h=-1}while(0);var m=h+1|0,y=function(t,e,n){for(var i=e;i0){var $=_,g=_+y|0,w=e.substring($,g);t.protocol=Mi().createOrDefault_61zpoe$(w),_=_+(y+1)|0}var x=function(t,e,n,i){for(var r=0;(e+r|0)=2)t:for(;;){var k=Gt(e,yt("@/\\?#"),_),E=null!=(n=k>0?k:null)?n:m;if(!(E=m)return t.encodedPath=47===e.charCodeAt(m-1|0)?"/":"",t;if(0===x){var P=Ht(t.encodedPath,47);if(P!==(t.encodedPath.length-1|0))if(-1!==P){var A=P+1|0;i=t.encodedPath.substring(0,A)}else i="/";else i=t.encodedPath}else i="";t.encodedPath=i;var j,L=Gt(e,yt("?#"),_),R=null!=(r=L>0?L:null)?r:m,I=_,z=e.substring(I,R);if(t.encodedPath+=fe(z),(_=R)0?D:null)?o:m,B=_+1|0;fi(e.substring(B,M)).forEach_ubvtmq$((j=t,function(t,e){return j.parameters.appendAll_poujtz$(t,e),C})),_=M}if(_0?o:null)?r:i;if(t.host=e.substring(n,a),(a+1|0)@;:/\\\\"\\[\\]\\?=\\{\\}\\s]+)\\s*(=\\s*("[^"]*"|[^;]*))?'),Z([b(59),b(44),b(34)]),w(["***, dd MMM YYYY hh:mm:ss zzz","****, dd-MMM-YYYY hh:mm:ss zzz","*** MMM d hh:mm:ss YYYY","***, dd-MMM-YYYY hh:mm:ss zzz","***, dd-MMM-YYYY hh-mm-ss zzz","***, dd MMM YYYY hh:mm:ss zzz","*** dd-MMM-YYYY hh:mm:ss zzz","*** dd MMM YYYY hh:mm:ss zzz","*** dd-MMM-YYYY hh-mm-ss zzz","***,dd-MMM-YYYY hh:mm:ss zzz","*** MMM d YYYY hh:mm:ss zzz"]),bt((function(){var t=vt();return t.putAll_a2k3zr$(Je(gt(ri()))),t})),bt((function(){return Je(nt(gt(ri()),Ze))})),Sr(vr(yr($r(yr($r(yr($r(Er(),"."),Er()),"."),Er()),"."),Er()),$r(mr("[",br(gr(kr(),":"))),"]"))),Kn=bt((function(){return ii()})),'("((\\\\.)|[^\\\\"])*")|[^\\s,]*',Ii=pt("[a-zA-Z0-9\\-._~+/]+=*"),pt("\\S+"),pt("\\s*,?\\s*("+Ii+')\\s*=\\s*(("((\\\\.)|[^\\\\"])*")|[^\\s,]*)\\s*,?\\s*'),pt("\\\\."),new Jt("Caching"),zi="258EAFA5-E914-47DA-95CA-C5AB0DC85B11",t})?i.apply(e,r):i)||(t.exports=o)},276:function(t,e,n){var i,r,o;r=[e,n(421),n(197)],void 0===(o="function"==typeof(i=function(t,e,i){"use strict";var r=t.$$importsForInline$$||(t.$$importsForInline$$={}),o=e.Kind.INTERFACE,a=e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED,s=e.kotlin.coroutines.CoroutineImpl,l=e.Long.MAX_VALUE,u=e.Long.ZERO,c=e.throwCCE,p=e.Kind.CLASS,h=e.kotlin.Unit,_=e.equals,f=e.ensureNotNull,d=e.toByte,m=e.kotlin.text.StringBuilder_init,y=i.kotlinx.coroutines.CancellationException_init_pdl1vj$,$=e.Long.fromInt(4088),v=e.kotlin.ranges.coerceAtMost_2p08ub$,g=Math,b=e.kotlin.IllegalArgumentException_init_pdl1vj$,w=e.defineInlineFunction,x=e.wrapFunction,k=e.toShort,E=i.kotlinx.coroutines.CancellationException,C=Error,S=i.kotlinx.coroutines.Job,T=i.kotlinx.coroutines.CoroutineScope,O=e.kotlin.coroutines,N=i.kotlinx.coroutines,P=i.kotlinx.coroutines.newCoroutineContext_7n4184$,A=i.kotlinx.coroutines.CoroutineScope_1fupul$,j=i.kotlinx.coroutines.launch_s496o7$,L=e.kotlin.ranges.coerceAtMost_dqglrj$,R=e.kotlin.UnsupportedOperationException_init_pdl1vj$,I=e.kotlin.UShort,z=e.kotlin.UInt,D=e.kotlin.ULong,M=e.Long.fromInt(16),B=e.kotlin.IllegalStateException_init_pdl1vj$,U=e.kotlin.text.StringBuilder_init_za3lpa$,F=e.kotlin.UnsupportedOperationException_init,q=e.kotlin.text.Appendable,G=e.kotlin.ranges.coerceAtLeast_dqglrj$,H=e.unboxChar,Y=e.Kind.OBJECT,V=e.toChar,K=e.toBoxedChar,W=e.kotlin.Exception_init_pdl1vj$,X=e.kotlin.Exception,Z=e.kotlin.UByte,J=new e.Long(-1,0),Q=e.kotlin.Annotation,tt=e.Long.NEG_ONE,et=e.kotlin.ranges.until_ebnic$,nt=e.floatToRawBits,it=e.doubleToRawBits,rt=e.kotlin.text.contains_sgbm27$,ot=e.kotlin.ranges.coerceAtLeast_2p08ub$,at=e.kotlin.collections.copyOf_mrm5p$,st=e.Long.fromInt(2147483647),lt=e.kotlin.IndexOutOfBoundsException,ut=e.kotlin.CharSequence,ct=e.kotlin.text.isLowSurrogate_myv2d0$,pt=e.kotlin.text.isHighSurrogate_myv2d0$,ht=e.kotlin.Error_init_pdl1vj$,_t=e.kotlin.NotImplementedError,ft=e.toString,dt=e.hashCode,mt=e.Long.ONE,yt=e.kotlin.lazy_klfg04$,$t=e.kotlin.Result,vt=e.kotlin.coroutines.intrinsics.intercepted_f9mg25$,gt=e.kotlin.coroutines.SafeContinuation_init_wj8d80$,bt=e.kotlin.text.replace_r2fvfm$,wt=Int8Array,xt=e.kotlin.Enum,kt=e.throwISE,Et=e.kotlin.IndexOutOfBoundsException_init,Ct=Object;function St(){}function Tt(t){this.closure$message=t,Il.call(this)}function Ot(t,e,n){var i;void 0===n&&(n=Nl().Pool),this.autoFlush_tqevpj$_0=e,this.closed=!1,this.writable=new Jo(0,n),this.readable=ia(t,n),this.notFull_8be2vx$=new Bu((i=this,function(){var t=i;return(t.readable.remaining.toInt()+t.writable.size|0)<=$.toNumber()})),this.waitingForSize_acioxj$_0=1,this.atLeastNBytesAvailableForWrite_dspbt2$_0=new Bu(function(t){return function(){return t.availableForWrite>=t.waitingForSize_acioxj$_0||t.closed}}(this)),this.waitingForRead_ad5k18$_0=1,this.atLeastNBytesAvailableForRead_mdv8hx$_0=new Bu(function(t){return function(){return t.availableForRead>=t.waitingForRead_ad5k18$_0||t.closed}}(this)),this.readByteOrder_mxhhha$_0=xp(),this.writeByteOrder_nzwt0f$_0=xp(),this.closedCause_mi5adr$_0=null,this.lastReadAvailable_1j890x$_0=0,this.lastReadView_92ta1h$_0=Nl().Empty}function Nt(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$src=e,this.local$offset=n,this.local$length=i}function Pt(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$srcRemaining=void 0,this.local$size=void 0,this.local$src=e}function At(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$size=void 0,this.local$src=e,this.local$offset=n,this.local$length=i}function jt(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$visitor=e}function Lt(t){this.this$ByteChannelSequentialBase=t}function Rt(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$n=e}function It(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function zt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Dt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function Mt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Bt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function Ut(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Ft(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function qt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Gt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function Ht(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Yt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function Vt(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Kt(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$limit=e,this.local$headerSizeHint=n}function Wt(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$builder=e,this.local$limit=n}function Xt(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$size=e,this.local$headerSizeHint=n}function Zt(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$remaining=void 0,this.local$builder=e,this.local$size=n}function Jt(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$dst=e}function Qt(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$dst=e}function te(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$dst=e,this.local$n=n}function ee(t){return function(){return"Not enough space in the destination buffer to write "+t+" bytes"}}function ne(){return"n shouldn't be negative"}function ie(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$dst=e,this.local$n=n}function re(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$dst=e,this.local$n=n}function oe(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$dst=e,this.local$offset=n,this.local$length=i}function ae(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$dst=e,this.local$offset=n,this.local$length=i}function se(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$rc=void 0,this.local$dst=e,this.local$offset=n,this.local$length=i}function le(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$written=void 0,this.local$dst=e,this.local$offset=n,this.local$length=i}function ue(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0}function ce(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function pe(t){return function(){return t.afterRead(),h}}function he(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$atLeast=e}function _e(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$tmp$=void 0,this.local$max=e}function fe(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$discarded=void 0,this.local$max=e,this.local$discarded0=n}function de(t,e,n){s.call(this,n),this.exceptionState_0=5,this.$this=t,this.local$consumer=e}function me(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$this$ByteChannelSequentialBase=t,this.local$size=e}function ye(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$sb=void 0,this.local$limit=e}function $e(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.$this=t,this.local$n=e,this.local$block=n}function ve(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$src=e}function ge(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$src=e,this.local$offset=n,this.local$length=i}function be(t){return function(){return t.flush(),h}}function we(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function xe(t,e,n,i,r,o,a,l,u){s.call(this,u),this.$controller=l,this.exceptionState_0=1,this.local$closure$min=t,this.local$closure$offset=e,this.local$closure$max=n,this.local$closure$bytesCopied=i,this.local$closure$destination=r,this.local$closure$destinationOffset=o,this.local$$receiver=a}function ke(t,e,n,i,r,o){return function(a,s,l){var u=new xe(t,e,n,i,r,o,a,this,s);return l?u:u.doResume(null)}}function Ee(t,e,n,i,r,o,a){s.call(this,a),this.exceptionState_0=1,this.$this=t,this.local$bytesCopied=void 0,this.local$destination=e,this.local$destinationOffset=n,this.local$offset=i,this.local$min=r,this.local$max=o}function Ce(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$n=e}function Se(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$dst=e,this.local$limit=n}function Te(t,e,n){return t.writeShort_mq22fl$(k(65535&e),n)}function Oe(t,e,n){return t.writeByte_s8j3t7$(d(255&e),n)}function Ne(t){return t.close_dbl4no$(null)}function Pe(t,e,n){s.call(this,n),this.exceptionState_0=5,this.local$buildPacket$result=void 0,this.local$builder=void 0,this.local$$receiver=t,this.local$builder_0=e}function Ae(t){y(t,this),this.name="ClosedWriteChannelException"}function je(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$byteOrder=e}function Le(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$byteOrder=e}function Re(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$byteOrder=e}function Ie(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$byteOrder=e}function ze(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$byteOrder=e}function De(t,e){s.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function Me(t,e){s.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function Be(t,e){s.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function Ue(t,e){s.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function Fe(t,e){s.call(this,e),this.exceptionState_0=1,this.local$$receiver=t}function qe(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e,this.local$byteOrder=n}function Ge(t,e,n,i,r){var o=new qe(t,e,n,i);return r?o:o.doResume(null)}function He(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e,this.local$byteOrder=n}function Ye(t,e,n,i,r){var o=new He(t,e,n,i);return r?o:o.doResume(null)}function Ve(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e,this.local$byteOrder=n}function Ke(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e,this.local$byteOrder=n}function We(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e,this.local$byteOrder=n}function Xe(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e}function Ze(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e}function Je(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e}function Qe(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e}function tn(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$value=e}Ae.prototype=Object.create(E.prototype),Ae.prototype.constructor=Ae,pr.prototype=Object.create(X.prototype),pr.prototype.constructor=pr,Sr.prototype=Object.create(Mh.prototype),Sr.prototype.constructor=Sr,Lo.prototype=Object.create(bu.prototype),Lo.prototype.constructor=Lo,Vo.prototype=Object.create(X.prototype),Vo.prototype.constructor=Vo,Xo.prototype=Object.create(Hi.prototype),Xo.prototype.constructor=Xo,Wo.prototype=Object.create(Xo.prototype),Wo.prototype.constructor=Wo,Jo.prototype=Object.create(Wo.prototype),Jo.prototype.constructor=Jo,ks.prototype=Object.create(Mi.prototype),ks.prototype.constructor=ks,ra.prototype=Object.create(ks.prototype),ra.prototype.constructor=ra,Qo.prototype=Object.create(ra.prototype),Qo.prototype.constructor=Qo,Sl.prototype=Object.create(bu.prototype),Sl.prototype.constructor=Sl,Tl.prototype=Object.create(bu.prototype),Tl.prototype.constructor=Tl,bl.prototype=Object.create(Vi.prototype),bl.prototype.constructor=bl,ru.prototype=Object.create(X.prototype),ru.prototype.constructor=ru,Ou.prototype=Object.create(Ot.prototype),Ou.prototype.constructor=Ou,Zc.prototype=Object.create(Xc.prototype),Zc.prototype.constructor=Zc,rp.prototype=Object.create(ip.prototype),rp.prototype.constructor=rp,dp.prototype=Object.create(Hc.prototype),dp.prototype.constructor=dp,mp.prototype=Object.create(C.prototype),mp.prototype.constructor=mp,bp.prototype=Object.create(xt.prototype),bp.prototype.constructor=bp,Tp.prototype=Object.create(wu.prototype),Tp.prototype.constructor=Tp,Wp.prototype=Object.create(Mh.prototype),Wp.prototype.constructor=Wp,Zp.prototype=Object.create(bu.prototype),Zp.prototype.constructor=Zp,Hp.prototype=Object.create(bl.prototype),Hp.prototype.constructor=Hp,Ch.prototype=Object.create(X.prototype),Ch.prototype.constructor=Ch,Th.prototype=Object.create(Ch.prototype),Th.prototype.constructor=Th,St.$metadata$={kind:o,simpleName:"ByteChannel",interfaces:[Du,ju]},Tt.prototype=Object.create(Il.prototype),Tt.prototype.constructor=Tt,Tt.prototype.doFail=function(){throw b(this.closure$message())},Tt.$metadata$={kind:p,interfaces:[Il]},Object.defineProperty(Ot.prototype,"autoFlush",{get:function(){return this.autoFlush_tqevpj$_0}}),Ot.prototype.totalPending_82umvh$_0=function(){return this.readable.remaining.toInt()+this.writable.size|0},Object.defineProperty(Ot.prototype,"availableForRead",{get:function(){return this.readable.remaining.toInt()}}),Object.defineProperty(Ot.prototype,"availableForWrite",{get:function(){var t=4088-(this.readable.remaining.toInt()+this.writable.size|0)|0;return g.max(0,t)}}),Object.defineProperty(Ot.prototype,"readByteOrder",{get:function(){return this.readByteOrder_mxhhha$_0},set:function(t){this.readByteOrder_mxhhha$_0=t}}),Object.defineProperty(Ot.prototype,"writeByteOrder",{get:function(){return this.writeByteOrder_nzwt0f$_0},set:function(t){this.writeByteOrder_nzwt0f$_0=t}}),Object.defineProperty(Ot.prototype,"isClosedForRead",{get:function(){var t=this.closed;return t&&(t=this.readable.endOfInput),t}}),Object.defineProperty(Ot.prototype,"isClosedForWrite",{get:function(){return this.closed}}),Object.defineProperty(Ot.prototype,"totalBytesRead",{get:function(){return u}}),Object.defineProperty(Ot.prototype,"totalBytesWritten",{get:function(){return u}}),Object.defineProperty(Ot.prototype,"closedCause",{get:function(){return this.closedCause_mi5adr$_0},set:function(t){this.closedCause_mi5adr$_0=t}}),Ot.prototype.flush=function(){this.writable.isNotEmpty&&(au(this.readable,this.writable),this.atLeastNBytesAvailableForRead_mdv8hx$_0.signal())},Ot.prototype.ensureNotClosed_ozgwi5$_0=function(){var t;if(this.closed)throw null!=(t=this.closedCause)?t:new Ae("Channel is already closed")},Ot.prototype.ensureNotFailed_7bddlw$_0=function(){var t;if(null!=(t=this.closedCause))throw t},Ot.prototype.ensureNotFailed_2bmfsh$_0=function(t){var e;if(null!=(e=this.closedCause))throw t.release(),e},Ot.prototype.writeByte_s8j3t7$=function(t,e){return this.writable.writeByte_s8j3t7$(t),this.awaitFreeSpace(e)},Ot.prototype.reverseWrite_hkpayy$_0=function(t,e){return this.writeByteOrder===xp()?t():e()},Ot.prototype.writeShort_mq22fl$=function(t,e){return ms(this.writable,this.writeByteOrder===xp()?t:Hu(t)),this.awaitFreeSpace(e)},Ot.prototype.writeInt_za3lpa$=function(t,e){return ys(this.writable,this.writeByteOrder===xp()?t:Yu(t)),this.awaitFreeSpace(e)},Ot.prototype.writeLong_s8cxhz$=function(t,e){return gs(this.writable,this.writeByteOrder===xp()?t:Vu(t)),this.awaitFreeSpace(e)},Ot.prototype.writeFloat_mx4ult$=function(t,e){return ws(this.writable,this.writeByteOrder===xp()?t:Ku(t)),this.awaitFreeSpace(e)},Ot.prototype.writeDouble_14dthe$=function(t,e){return xs(this.writable,this.writeByteOrder===xp()?t:Wu(t)),this.awaitFreeSpace(e)},Ot.prototype.writePacket_3uq2w4$=function(t,e){return this.writable.writePacket_3uq2w4$(t),this.awaitFreeSpace(e)},Ot.prototype.writeFully_99qa0s$=function(t,n){var i;return this.writeFully_lh221x$(e.isType(i=t,Vi)?i:c(),n)},Ot.prototype.writeFully_lh221x$=function(t,e){return rs(this.writable,t),this.awaitFreeSpace(e)},Nt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Nt.prototype=Object.create(s.prototype),Nt.prototype.constructor=Nt,Nt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(Ja(this.$this.writable,this.local$src,this.local$offset,this.local$length),this.state_0=2,this.result_0=this.$this.awaitFreeSpace(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeFully_mj6st8$=function(t,e,n,i,r){var o=new Nt(this,t,e,n,i);return r?o:o.doResume(null)},Pt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Pt.prototype=Object.create(s.prototype),Pt.prototype.constructor=Pt,Pt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$srcRemaining=this.local$src.writePosition-this.local$src.readPosition|0,0===this.local$srcRemaining)return 0;this.state_0=2;continue;case 1:throw this.exception_0;case 2:var t=this.$this.availableForWrite;if(this.local$size=g.min(this.local$srcRemaining,t),0===this.local$size){if(this.state_0=4,this.result_0=this.$this.writeAvailableSuspend_5fukw0$_0(this.local$src,this),this.result_0===a)return a;continue}if(rs(this.$this.writable,this.local$src,this.local$size),this.state_0=3,this.result_0=this.$this.awaitFreeSpace(this),this.result_0===a)return a;continue;case 3:this.local$tmp$=this.local$size,this.state_0=5;continue;case 4:this.local$tmp$=this.result_0,this.state_0=5;continue;case 5:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeAvailable_99qa0s$=function(t,e,n){var i=new Pt(this,t,e);return n?i:i.doResume(null)},At.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},At.prototype=Object.create(s.prototype),At.prototype.constructor=At,At.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(0===this.local$length)return 0;this.state_0=2;continue;case 1:throw this.exception_0;case 2:var t=this.$this.availableForWrite;if(this.local$size=g.min(this.local$length,t),0===this.local$size){if(this.state_0=4,this.result_0=this.$this.writeAvailableSuspend_1zn44g$_0(this.local$src,this.local$offset,this.local$length,this),this.result_0===a)return a;continue}if(Ja(this.$this.writable,this.local$src,this.local$offset,this.local$size),this.state_0=3,this.result_0=this.$this.awaitFreeSpace(this),this.result_0===a)return a;continue;case 3:this.local$tmp$=this.local$size,this.state_0=5;continue;case 4:this.local$tmp$=this.result_0,this.state_0=5;continue;case 5:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeAvailable_mj6st8$=function(t,e,n,i,r){var o=new At(this,t,e,n,i);return r?o:o.doResume(null)},jt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},jt.prototype=Object.create(s.prototype),jt.prototype.constructor=jt,jt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=this.$this.beginWriteSession();if(this.state_0=2,this.result_0=this.local$visitor(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeSuspendSession_8dv01$=function(t,e,n){var i=new jt(this,t,e);return n?i:i.doResume(null)},Lt.prototype.request_za3lpa$=function(t){var n;return 0===this.this$ByteChannelSequentialBase.availableForWrite?null:e.isType(n=this.this$ByteChannelSequentialBase.writable.prepareWriteHead_za3lpa$(t),Hp)?n:c()},Lt.prototype.written_za3lpa$=function(t){this.this$ByteChannelSequentialBase.writable.afterHeadWrite(),this.this$ByteChannelSequentialBase.afterWrite()},Lt.prototype.flush=function(){this.this$ByteChannelSequentialBase.flush()},Rt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Rt.prototype=Object.create(s.prototype),Rt.prototype.constructor=Rt,Rt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.this$ByteChannelSequentialBase.availableForWrite=this.local$limit.toNumber()){this.state_0=5;continue}var t=this.local$limit.subtract(e.Long.fromInt(this.local$builder.size)),n=this.$this.readable.remaining,i=t.compareTo_11rb$(n)<=0?t:n;if(this.local$builder.writePacket_pi0yjl$(this.$this.readable,i),this.$this.afterRead(),this.$this.ensureNotFailed_2bmfsh$_0(this.local$builder),_(this.$this.readable.remaining,u)&&0===this.$this.writable.size&&this.$this.closed){this.state_0=5;continue}this.state_0=3;continue;case 3:if(this.state_0=4,this.result_0=this.$this.awaitSuspend_za3lpa$(1,this),this.result_0===a)return a;continue;case 4:this.state_0=2;continue;case 5:return this.$this.ensureNotFailed_2bmfsh$_0(this.local$builder),this.local$builder.build();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readRemainingSuspend_gfhva8$_0=function(t,e,n,i){var r=new Wt(this,t,e,n);return i?r:r.doResume(null)},Xt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Xt.prototype=Object.create(s.prototype),Xt.prototype.constructor=Xt,Xt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=mh(this.local$headerSizeHint),n=this.local$size,i=e.Long.fromInt(n),r=this.$this.readable.remaining,o=(i.compareTo_11rb$(r)<=0?i:r).toInt();if(n=n-o|0,t.writePacket_f7stg6$(this.$this.readable,o),this.$this.afterRead(),n>0){if(this.state_0=2,this.result_0=this.$this.readPacketSuspend_2ns5o1$_0(t,n,this),this.result_0===a)return a;continue}this.local$tmp$=t.build(),this.state_0=3;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readPacket_vux9f0$=function(t,e,n,i){var r=new Xt(this,t,e,n);return i?r:r.doResume(null)},Zt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Zt.prototype=Object.create(s.prototype),Zt.prototype.constructor=Zt,Zt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$remaining=this.local$size,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$remaining<=0){this.state_0=5;continue}var t=e.Long.fromInt(this.local$remaining),n=this.$this.readable.remaining,i=(t.compareTo_11rb$(n)<=0?t:n).toInt();if(this.local$remaining=this.local$remaining-i|0,this.local$builder.writePacket_f7stg6$(this.$this.readable,i),this.$this.afterRead(),this.local$remaining>0){if(this.state_0=3,this.result_0=this.$this.awaitSuspend_za3lpa$(1,this),this.result_0===a)return a;continue}this.state_0=4;continue;case 3:this.state_0=4;continue;case 4:this.state_0=2;continue;case 5:return this.local$builder.build();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readPacketSuspend_2ns5o1$_0=function(t,e,n,i){var r=new Zt(this,t,e,n);return i?r:r.doResume(null)},Ot.prototype.readAvailableClosed=function(){var t;if(null!=(t=this.closedCause))throw t;return-1},Ot.prototype.readAvailable_99qa0s$=function(t,n){var i;return this.readAvailable_lh221x$(e.isType(i=t,Vi)?i:c(),n)},Jt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Jt.prototype=Object.create(s.prototype),Jt.prototype.constructor=Jt,Jt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(null!=this.$this.closedCause)throw f(this.$this.closedCause);if(this.$this.readable.canRead()){var t=e.Long.fromInt(this.local$dst.limit-this.local$dst.writePosition|0),n=this.$this.readable.remaining,i=(t.compareTo_11rb$(n)<=0?t:n).toInt();va(this.$this.readable,this.local$dst,i),this.$this.afterRead(),this.local$tmp$=i,this.state_0=5;continue}if(this.$this.closed){this.local$tmp$=this.$this.readAvailableClosed(),this.state_0=4;continue}if(this.local$dst.limit>this.local$dst.writePosition){if(this.state_0=2,this.result_0=this.$this.readAvailableSuspend_b4eait$_0(this.local$dst,this),this.result_0===a)return a;continue}this.local$tmp$=0,this.state_0=3;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:this.state_0=4;continue;case 4:this.state_0=5;continue;case 5:this.state_0=6;continue;case 6:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readAvailable_lh221x$=function(t,e,n){var i=new Jt(this,t,e);return n?i:i.doResume(null)},Qt.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Qt.prototype=Object.create(s.prototype),Qt.prototype.constructor=Qt,Qt.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitSuspend_za3lpa$(1,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.readAvailable_lh221x$(this.local$dst,this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readAvailableSuspend_b4eait$_0=function(t,e,n){var i=new Qt(this,t,e);return n?i:i.doResume(null)},te.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},te.prototype=Object.create(s.prototype),te.prototype.constructor=te,te.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.state_0=2,this.result_0=this.$this.readFully_bkznnu$_0(e.isType(t=this.local$dst,Vi)?t:c(),this.local$n,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readFully_qr0era$=function(t,e,n,i){var r=new te(this,t,e,n);return i?r:r.doResume(null)},ie.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ie.prototype=Object.create(s.prototype),ie.prototype.constructor=ie,ie.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$n<=(this.local$dst.limit-this.local$dst.writePosition|0)||new Tt(ee(this.local$n)).doFail(),this.local$n>=0||new Tt(ne).doFail(),null!=this.$this.closedCause)throw f(this.$this.closedCause);if(this.$this.readable.remaining.toNumber()>=this.local$n){var t=(va(this.$this.readable,this.local$dst,this.local$n),h);this.$this.afterRead(),this.local$tmp$=t,this.state_0=4;continue}if(this.$this.closed)throw new Th("Channel is closed and not enough bytes available: required "+this.local$n+" but "+this.$this.availableForRead+" available");if(this.state_0=2,this.result_0=this.$this.readFullySuspend_8xotw2$_0(this.local$dst,this.local$n,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:this.state_0=4;continue;case 4:this.state_0=5;continue;case 5:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readFully_bkznnu$_0=function(t,e,n,i){var r=new ie(this,t,e,n);return i?r:r.doResume(null)},re.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},re.prototype=Object.create(s.prototype),re.prototype.constructor=re,re.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitSuspend_za3lpa$(this.local$n,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.readFully_bkznnu$_0(this.local$dst,this.local$n,this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readFullySuspend_8xotw2$_0=function(t,e,n,i){var r=new re(this,t,e,n);return i?r:r.doResume(null)},oe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},oe.prototype=Object.create(s.prototype),oe.prototype.constructor=oe,oe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.readable.canRead()){var t=e.Long.fromInt(this.local$length),n=this.$this.readable.remaining,i=(t.compareTo_11rb$(n)<=0?t:n).toInt();_a(this.$this.readable,this.local$dst,this.local$offset,i),this.$this.afterRead(),this.local$tmp$=i,this.state_0=4;continue}if(this.$this.closed){this.local$tmp$=this.$this.readAvailableClosed(),this.state_0=3;continue}if(this.state_0=2,this.result_0=this.$this.readAvailableSuspend_v6ah9b$_0(this.local$dst,this.local$offset,this.local$length,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:this.state_0=4;continue;case 4:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readAvailable_mj6st8$=function(t,e,n,i,r){var o=new oe(this,t,e,n,i);return r?o:o.doResume(null)},ae.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ae.prototype=Object.create(s.prototype),ae.prototype.constructor=ae,ae.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitSuspend_za3lpa$(1,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.readAvailable_mj6st8$(this.local$dst,this.local$offset,this.local$length,this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readAvailableSuspend_v6ah9b$_0=function(t,e,n,i,r){var o=new ae(this,t,e,n,i);return r?o:o.doResume(null)},se.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},se.prototype=Object.create(s.prototype),se.prototype.constructor=se,se.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.readAvailable_mj6st8$(this.local$dst,this.local$offset,this.local$length,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.local$rc=this.result_0,this.local$rc===this.local$length)return;this.state_0=3;continue;case 3:if(-1===this.local$rc)throw new Th("Unexpected end of stream");if(this.state_0=4,this.result_0=this.$this.readFullySuspend_ayq7by$_0(this.local$dst,this.local$offset+this.local$rc|0,this.local$length-this.local$rc|0,this),this.result_0===a)return a;continue;case 4:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readFully_mj6st8$=function(t,e,n,i,r){var o=new se(this,t,e,n,i);return r?o:o.doResume(null)},le.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},le.prototype=Object.create(s.prototype),le.prototype.constructor=le,le.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$written=0,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$written>=this.local$length){this.state_0=4;continue}if(this.state_0=3,this.result_0=this.$this.readAvailable_mj6st8$(this.local$dst,this.local$offset+this.local$written|0,this.local$length-this.local$written|0,this),this.result_0===a)return a;continue;case 3:var t=this.result_0;if(-1===t)throw new Th("Unexpected end of stream");this.local$written=this.local$written+t|0,this.state_0=2;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readFullySuspend_ayq7by$_0=function(t,e,n,i,r){var o=new le(this,t,e,n,i);return r?o:o.doResume(null)},ue.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ue.prototype=Object.create(s.prototype),ue.prototype.constructor=ue,ue.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.readable.canRead()){var t=this.$this.readable.readByte()===d(1);this.$this.afterRead(),this.local$tmp$=t,this.state_0=3;continue}if(this.state_0=2,this.result_0=this.$this.readBooleanSlow_cbbszf$_0(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readBoolean=function(t,e){var n=new ue(this,t);return e?n:n.doResume(null)},ce.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ce.prototype=Object.create(s.prototype),ce.prototype.constructor=ce,ce.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitSuspend_za3lpa$(1,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.$this.checkClosed_ldvyyk$_0(1),this.state_0=3,this.result_0=this.$this.readBoolean(this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readBooleanSlow_cbbszf$_0=function(t,e){var n=new ce(this,t);return e?n:n.doResume(null)},Ot.prototype.completeReading_um9rnf$_0=function(){var t=this.lastReadView_92ta1h$_0,e=t.writePosition-t.readPosition|0,n=this.lastReadAvailable_1j890x$_0-e|0;this.lastReadView_92ta1h$_0!==Xi().Empty&&lu(this.readable,this.lastReadView_92ta1h$_0),n>0&&this.afterRead(),this.lastReadAvailable_1j890x$_0=0,this.lastReadView_92ta1h$_0=Nl().Empty},Ot.prototype.await_za3lpa$$default=function(t,e){return t>=0||new Tt((n=t,function(){return"atLeast parameter shouldn't be negative: "+n})).doFail(),t<=4088||new Tt(function(t){return function(){return"atLeast parameter shouldn't be larger than max buffer size of 4088: "+t}}(t)).doFail(),this.completeReading_um9rnf$_0(),0===t?!this.isClosedForRead:this.availableForRead>=t||this.awaitSuspend_za3lpa$(t,e);var n},Ot.prototype.awaitInternalAtLeast1_8be2vx$=function(t){return!this.readable.endOfInput||this.awaitSuspend_za3lpa$(1,t)},he.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},he.prototype=Object.create(s.prototype),he.prototype.constructor=he,he.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(!(this.local$atLeast>=0))throw b("Failed requirement.".toString());if(this.$this.waitingForRead_ad5k18$_0=this.local$atLeast,this.state_0=2,this.result_0=this.$this.atLeastNBytesAvailableForRead_mdv8hx$_0.await_o14v8n$(pe(this.$this),this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(null!=(t=this.$this.closedCause))throw t;return!this.$this.isClosedForRead&&this.$this.availableForRead>=this.local$atLeast;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.awaitSuspend_za3lpa$=function(t,e,n){var i=new he(this,t,e);return n?i:i.doResume(null)},Ot.prototype.discard_za3lpa$=function(t){var e;if(null!=(e=this.closedCause))throw e;var n=this.readable.discard_za3lpa$(t);return this.afterRead(),n},Ot.prototype.request_za3lpa$$default=function(t){var n,i;if(null!=(n=this.closedCause))throw n;this.completeReading_um9rnf$_0();var r=null==(i=this.readable.prepareReadHead_za3lpa$(t))||e.isType(i,Hp)?i:c();return null==r?(this.lastReadView_92ta1h$_0=Nl().Empty,this.lastReadAvailable_1j890x$_0=0):(this.lastReadView_92ta1h$_0=r,this.lastReadAvailable_1j890x$_0=r.writePosition-r.readPosition|0),r},_e.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},_e.prototype=Object.create(s.prototype),_e.prototype.constructor=_e,_e.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t=this.$this.readable.discard_s8cxhz$(this.local$max);if(_(t,this.local$max)||this.$this.isClosedForRead)return t;if(this.state_0=2,this.result_0=this.$this.discardSuspend_7c0j1e$_0(this.local$max,t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:this.local$tmp$=this.result_0,this.state_0=3;continue;case 3:return this.local$tmp$;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.discard_s8cxhz$=function(t,e,n){var i=new _e(this,t,e);return n?i:i.doResume(null)},fe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},fe.prototype=Object.create(s.prototype),fe.prototype.constructor=fe,fe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$discarded=this.local$discarded0,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.await_za3lpa$(1,this),this.result_0===a)return a;continue;case 3:if(this.result_0){this.state_0=4;continue}this.state_0=5;continue;case 4:if(this.local$discarded=this.local$discarded.add(this.$this.readable.discard_s8cxhz$(this.local$max.subtract(this.local$discarded))),this.local$discarded.compareTo_11rb$(this.local$max)>=0||this.$this.isClosedForRead){this.state_0=5;continue}this.state_0=2;continue;case 5:return this.local$discarded;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.discardSuspend_7c0j1e$_0=function(t,e,n,i){var r=new fe(this,t,e,n);return i?r:r.doResume(null)},Ot.prototype.readSession_m70re0$=function(t){try{t(this)}finally{this.completeReading_um9rnf$_0()}},Ot.prototype.startReadSession=function(){return this},Ot.prototype.endReadSession=function(){this.completeReading_um9rnf$_0()},de.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},de.prototype=Object.create(s.prototype),de.prototype.constructor=de,de.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.exceptionState_0=3,this.state_0=1,this.result_0=this.local$consumer(this.$this,this),this.result_0===a)return a;continue;case 1:this.exceptionState_0=5,this.finallyPath_0=[2],this.state_0=4;continue;case 2:return;case 3:this.finallyPath_0=[5],this.state_0=4;continue;case 4:this.exceptionState_0=5,this.$this.completeReading_um9rnf$_0(),this.state_0=this.finallyPath_0.shift();continue;case 5:throw this.exception_0;default:throw this.state_0=5,new Error("State Machine Unreachable execution")}}catch(t){if(5===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readSuspendableSession_kiqllg$=function(t,e,n){var i=new de(this,t,e);return n?i:i.doResume(null)},me.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},me.prototype=Object.create(s.prototype),me.prototype.constructor=me,me.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$this$ByteChannelSequentialBase.afterRead(),this.state_0=2,this.result_0=this.local$this$ByteChannelSequentialBase.await_za3lpa$(this.local$size,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return this.result_0?this.local$this$ByteChannelSequentialBase.readable:null;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readUTF8LineTo_yhx0yw$=function(t,e,n){if(this.isClosedForRead){var i=this.closedCause;if(null!=i)throw i;return!1}return Bl(t,e,(r=this,function(t,e,n){var i=new me(r,t,e);return n?i:i.doResume(null)}),n);var r},ye.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ye.prototype=Object.create(s.prototype),ye.prototype.constructor=ye,ye.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$sb=m(),this.state_0=2,this.result_0=this.$this.readUTF8LineTo_yhx0yw$(this.local$sb,this.local$limit,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.result_0){this.state_0=3;continue}return null;case 3:return this.local$sb.toString();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readUTF8Line_za3lpa$=function(t,e,n){var i=new ye(this,t,e);return n?i:i.doResume(null)},Ot.prototype.cancel_dbl4no$=function(t){return null==this.closedCause&&!this.closed&&this.close_dbl4no$(null!=t?t:y("Channel cancelled"))},Ot.prototype.close_dbl4no$=function(t){return!this.closed&&null==this.closedCause&&(this.closedCause=t,this.closed=!0,null!=t?(this.readable.release(),this.writable.release()):this.flush(),this.atLeastNBytesAvailableForRead_mdv8hx$_0.signal(),this.atLeastNBytesAvailableForWrite_dspbt2$_0.signal(),this.notFull_8be2vx$.signal(),!0)},Ot.prototype.transferTo_pxvbjg$=function(t,e){var n,i=this.readable.remaining;return i.compareTo_11rb$(e)<=0?(t.writable.writePacket_3uq2w4$(this.readable),t.afterWrite(),this.afterRead(),n=i):n=u,n},$e.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},$e.prototype=Object.create(s.prototype),$e.prototype.constructor=$e,$e.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.awaitSuspend_za3lpa$(this.local$n,this),this.result_0===a)return a;continue;case 3:this.$this.readable.hasBytes_za3lpa$(this.local$n)&&this.local$block(),this.$this.checkClosed_ldvyyk$_0(this.local$n),this.state_0=2;continue;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.readNSlow_2lkm5r$_0=function(t,e,n,i){var r=new $e(this,t,e,n);return i?r:r.doResume(null)},ve.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ve.prototype=Object.create(s.prototype),ve.prototype.constructor=ve,ve.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitFreeSpace(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.writeAvailable_99qa0s$(this.local$src,this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeAvailableSuspend_5fukw0$_0=function(t,e,n){var i=new ve(this,t,e);return n?i:i.doResume(null)},ge.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ge.prototype=Object.create(s.prototype),ge.prototype.constructor=ge,ge.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.awaitFreeSpace(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.$this.writeAvailable_mj6st8$(this.local$src,this.local$offset,this.local$length,this),this.result_0===a)return a;continue;case 3:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.writeAvailableSuspend_1zn44g$_0=function(t,e,n,i,r){var o=new ge(this,t,e,n,i);return r?o:o.doResume(null)},Ot.prototype.afterWrite=function(){this.closed&&(this.writable.release(),this.ensureNotClosed_ozgwi5$_0()),(this.autoFlush||0===this.availableForWrite)&&this.flush()},we.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},we.prototype=Object.create(s.prototype),we.prototype.constructor=we,we.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.afterWrite(),this.state_0=2,this.result_0=this.$this.notFull_8be2vx$.await_o14v8n$(be(this.$this),this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return void this.$this.ensureNotClosed_ozgwi5$_0();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.awaitFreeSpace=function(t,e){var n=new we(this,t);return e?n:n.doResume(null)},xe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},xe.prototype=Object.create(s.prototype),xe.prototype.constructor=xe,xe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n=v(this.local$closure$min.add(this.local$closure$offset),$).toInt();if(this.state_0=2,this.result_0=this.local$$receiver.await_za3lpa$(n,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var i=null!=(t=this.local$$receiver.request_za3lpa$(1))?t:Qp().Empty;if((i.writePosition-i.readPosition|0)>this.local$closure$offset.toNumber()){la(i,this.local$closure$offset);var r=this.local$closure$bytesCopied,o=e.Long.fromInt(i.writePosition-i.readPosition|0),s=this.local$closure$max;return r.v=o.compareTo_11rb$(s)<=0?o:s,i.memory.copyTo_q2ka7j$(this.local$closure$destination,e.Long.fromInt(i.readPosition),this.local$closure$bytesCopied.v,this.local$closure$destinationOffset),h}this.state_0=3;continue;case 3:return h;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ee.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ee.prototype=Object.create(s.prototype),Ee.prototype.constructor=Ee,Ee.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$bytesCopied={v:u},this.state_0=2,this.result_0=this.$this.readSuspendableSession_kiqllg$(ke(this.local$min,this.local$offset,this.local$max,this.local$bytesCopied,this.local$destination,this.local$destinationOffset),this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return this.local$bytesCopied.v;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ot.prototype.peekTo_afjyek$$default=function(t,e,n,i,r,o,a){var s=new Ee(this,t,e,n,i,r,o);return a?s:s.doResume(null)},Ot.$metadata$={kind:p,simpleName:"ByteChannelSequentialBase",interfaces:[Pn,Sn,$n,St,Du,ju]},Ce.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ce.prototype=Object.create(s.prototype),Ce.prototype.constructor=Ce,Ce.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.discard_s8cxhz$(this.local$n,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(!_(this.result_0,this.local$n))throw new Th("Unable to discard "+this.local$n.toString()+" bytes");return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.discardExact_b56lbm$",x((function(){var n=e.equals,i=t.io.ktor.utils.io.errors.EOFException;return function(t,r,o){if(e.suspendCall(t.discard_s8cxhz$(r,e.coroutineReceiver())),!n(e.coroutineResult(e.coroutineReceiver()),r))throw new i("Unable to discard "+r.toString()+" bytes")}}))),Se.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Se.prototype=Object.create(s.prototype),Se.prototype.constructor=Se,Se.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(void 0===this.local$limit&&(this.local$limit=l),this.state_0=2,this.result_0=Tu(this.local$$receiver,this.local$dst,this.local$limit,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return Ne(this.local$dst),t;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.writePacket_c7ucec$",x((function(){var n=t.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,i=Error;return function(t,r,o,a){var s;void 0===r&&(r=0);var l=n(r);try{o(l),s=l.build()}catch(t){throw e.isType(t,i)?(l.release(),t):t}return e.suspendCall(t.writePacket_3uq2w4$(s,e.coroutineReceiver())),e.coroutineResult(e.coroutineReceiver())}}))),Pe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Pe.prototype=Object.create(s.prototype),Pe.prototype.constructor=Pe,Pe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$builder=mh(0),this.exceptionState_0=2,this.state_0=1,this.result_0=this.local$builder_0(this.local$builder,this),this.result_0===a)return a;continue;case 1:this.local$buildPacket$result=this.local$builder.build(),this.exceptionState_0=5,this.state_0=3;continue;case 2:this.exceptionState_0=5;var t=this.exception_0;throw e.isType(t,C)?(this.local$builder.release(),t):t;case 3:if(this.state_0=4,this.result_0=this.local$$receiver.writePacket_3uq2w4$(this.local$buildPacket$result,this),this.result_0===a)return a;continue;case 4:return this.result_0;case 5:throw this.exception_0;default:throw this.state_0=5,new Error("State Machine Unreachable execution")}}catch(t){if(5===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ae.$metadata$={kind:p,simpleName:"ClosedWriteChannelException",interfaces:[E]},je.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},je.prototype=Object.create(s.prototype),je.prototype.constructor=je,je.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readShort(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$byteOrder,bp.BIG_ENDIAN)?t:Hu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readShort_e2pdtf$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_5vcgdc$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o,a){e.suspendCall(t.readShort(e.coroutineReceiver()));var s=e.coroutineResult(e.coroutineReceiver());return r(o,i.BIG_ENDIAN)?s:n(s)}}))),Le.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Le.prototype=Object.create(s.prototype),Le.prototype.constructor=Le,Le.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readInt(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$byteOrder,bp.BIG_ENDIAN)?t:Yu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readInt_e2pdtf$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_s8ev3n$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o,a){e.suspendCall(t.readInt(e.coroutineReceiver()));var s=e.coroutineResult(e.coroutineReceiver());return r(o,i.BIG_ENDIAN)?s:n(s)}}))),Re.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Re.prototype=Object.create(s.prototype),Re.prototype.constructor=Re,Re.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readLong(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$byteOrder,bp.BIG_ENDIAN)?t:Vu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readLong_e2pdtf$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_mts6qi$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o,a){e.suspendCall(t.readLong(e.coroutineReceiver()));var s=e.coroutineResult(e.coroutineReceiver());return r(o,i.BIG_ENDIAN)?s:n(s)}}))),Ie.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ie.prototype=Object.create(s.prototype),Ie.prototype.constructor=Ie,Ie.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readFloat(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$byteOrder,bp.BIG_ENDIAN)?t:Ku(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readFloat_e2pdtf$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_81szk$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o,a){e.suspendCall(t.readFloat(e.coroutineReceiver()));var s=e.coroutineResult(e.coroutineReceiver());return r(o,i.BIG_ENDIAN)?s:n(s)}}))),ze.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},ze.prototype=Object.create(s.prototype),ze.prototype.constructor=ze,ze.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readDouble(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$byteOrder,bp.BIG_ENDIAN)?t:Wu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readDouble_e2pdtf$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_yrwdxr$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o,a){e.suspendCall(t.readDouble(e.coroutineReceiver()));var s=e.coroutineResult(e.coroutineReceiver());return r(o,i.BIG_ENDIAN)?s:n(s)}}))),De.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},De.prototype=Object.create(s.prototype),De.prototype.constructor=De,De.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readShort(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$$receiver.readByteOrder,bp.LITTLE_ENDIAN)?t:Hu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readShortLittleEndian_3dmw3p$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_5vcgdc$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o){e.suspendCall(t.readShort(e.coroutineReceiver()));var a=e.coroutineResult(e.coroutineReceiver());return r(t.readByteOrder,i.LITTLE_ENDIAN)?a:n(a)}}))),Me.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Me.prototype=Object.create(s.prototype),Me.prototype.constructor=Me,Me.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readInt(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$$receiver.readByteOrder,bp.LITTLE_ENDIAN)?t:Yu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readIntLittleEndian_3dmw3p$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_s8ev3n$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o){e.suspendCall(t.readInt(e.coroutineReceiver()));var a=e.coroutineResult(e.coroutineReceiver());return r(t.readByteOrder,i.LITTLE_ENDIAN)?a:n(a)}}))),Be.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Be.prototype=Object.create(s.prototype),Be.prototype.constructor=Be,Be.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readLong(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$$receiver.readByteOrder,bp.LITTLE_ENDIAN)?t:Vu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readLongLittleEndian_3dmw3p$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_mts6qi$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o){e.suspendCall(t.readLong(e.coroutineReceiver()));var a=e.coroutineResult(e.coroutineReceiver());return r(t.readByteOrder,i.LITTLE_ENDIAN)?a:n(a)}}))),Ue.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ue.prototype=Object.create(s.prototype),Ue.prototype.constructor=Ue,Ue.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readFloat(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$$receiver.readByteOrder,bp.LITTLE_ENDIAN)?t:Ku(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readFloatLittleEndian_3dmw3p$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_81szk$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o){e.suspendCall(t.readFloat(e.coroutineReceiver()));var a=e.coroutineResult(e.coroutineReceiver());return r(t.readByteOrder,i.LITTLE_ENDIAN)?a:n(a)}}))),Fe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Fe.prototype=Object.create(s.prototype),Fe.prototype.constructor=Fe,Fe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.readDouble(this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return _(this.local$$receiver.readByteOrder,bp.LITTLE_ENDIAN)?t:Wu(t);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.readDoubleLittleEndian_3dmw3p$",x((function(){var n=t.io.ktor.utils.io.bits.reverseByteOrder_yrwdxr$,i=t.io.ktor.utils.io.core.ByteOrder,r=e.equals;return function(t,o){e.suspendCall(t.readDouble(e.coroutineReceiver()));var a=e.coroutineResult(e.coroutineReceiver());return r(t.readByteOrder,i.LITTLE_ENDIAN)?a:n(a)}}))),qe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},qe.prototype=Object.create(s.prototype),qe.prototype.constructor=qe,qe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$byteOrder,bp.BIG_ENDIAN)?this.local$value:Hu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeShort_mq22fl$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},He.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},He.prototype=Object.create(s.prototype),He.prototype.constructor=He,He.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$byteOrder,bp.BIG_ENDIAN)?this.local$value:Yu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeInt_za3lpa$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ve.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ve.prototype=Object.create(s.prototype),Ve.prototype.constructor=Ve,Ve.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$byteOrder,bp.BIG_ENDIAN)?this.local$value:Vu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeLong_s8cxhz$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ke.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ke.prototype=Object.create(s.prototype),Ke.prototype.constructor=Ke,Ke.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$byteOrder,bp.BIG_ENDIAN)?this.local$value:Ku(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeFloat_mx4ult$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},We.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},We.prototype=Object.create(s.prototype),We.prototype.constructor=We,We.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$byteOrder,bp.BIG_ENDIAN)?this.local$value:Wu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeDouble_14dthe$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Xe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Xe.prototype=Object.create(s.prototype),Xe.prototype.constructor=Xe,Xe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$$receiver.writeByteOrder,kp())?this.local$value:Hu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeShort_mq22fl$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ze.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ze.prototype=Object.create(s.prototype),Ze.prototype.constructor=Ze,Ze.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$$receiver.writeByteOrder,kp())?this.local$value:Yu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeInt_za3lpa$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Je.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Je.prototype=Object.create(s.prototype),Je.prototype.constructor=Je,Je.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$$receiver.writeByteOrder,kp())?this.local$value:Vu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeLong_s8cxhz$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Qe.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Qe.prototype=Object.create(s.prototype),Qe.prototype.constructor=Qe,Qe.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$$receiver.writeByteOrder,kp())?this.local$value:Ku(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeFloat_mx4ult$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},tn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},tn.prototype=Object.create(s.prototype),tn.prototype.constructor=tn,tn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=_(this.local$$receiver.writeByteOrder,kp())?this.local$value:Wu(this.local$value),this.state_0=2,this.result_0=this.local$$receiver.writeDouble_14dthe$(t,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}};var en=w("ktor-ktor-io.io.ktor.utils.io.toLittleEndian_npz7h3$",x((function(){var n=t.io.ktor.utils.io.core.ByteOrder,i=e.equals;return function(t,e,r){return i(t.readByteOrder,n.LITTLE_ENDIAN)?e:r(e)}}))),nn=w("ktor-ktor-io.io.ktor.utils.io.reverseIfNeeded_xs36oz$",x((function(){var n=t.io.ktor.utils.io.core.ByteOrder,i=e.equals;return function(t,e,r){return i(e,n.BIG_ENDIAN)?t:r(t)}})));function rn(){}function on(){}function an(){}function sn(){}function ln(t,e,n,i){return void 0===e&&(e=O.EmptyCoroutineContext),_n(t,e,n,!1,i)}function un(t,e,n,i){void 0===n&&(n=null);var r=P(N.GlobalScope,null!=n?t.plus_1fupul$(n):t);return ln(A(r),O.EmptyCoroutineContext,e,i)}function cn(t,e,n,i){return void 0===e&&(e=O.EmptyCoroutineContext),_n(t,e,n,!1,i)}function pn(t,e,n,i){void 0===n&&(n=null);var r=P(N.GlobalScope,null!=n?t.plus_1fupul$(n):t);return cn(A(r),O.EmptyCoroutineContext,e,i)}function hn(t,e,n,i,r,o){s.call(this,o),this.$controller=r,this.exceptionState_0=1,this.local$closure$attachJob=t,this.local$closure$channel=e,this.local$closure$block=n,this.local$$receiver=i}function _n(t,e,n,i,r){var o,a,s,l,u=j(t,e,void 0,(o=i,a=n,s=r,function(t,e,n){var i=new hn(o,a,s,t,this,e);return n?i:i.doResume(null)}));return u.invokeOnCompletion_f05bi3$((l=n,function(t){return l.close_dbl4no$(t),h})),new dn(u,n)}function fn(t,e){this.channel_79cwt9$_0=e,this.$delegate_h3p63m$_0=t}function dn(t,e){this.delegate_0=t,this.channel_zg1n2y$_0=e}function mn(t,e,n,i){s.call(this,i),this.exceptionState_0=6,this.local$buffer=void 0,this.local$bytesRead=void 0,this.local$$receiver=t,this.local$desiredSize=e,this.local$block=n}function yn(){}function $n(){}function vn(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$readSession=void 0,this.local$$receiver=t,this.local$desiredSize=e}function gn(t,e,n,i){var r=new vn(t,e,n);return i?r:r.doResume(null)}function bn(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$buffer=e,this.local$bytesRead=n}function wn(t,e,n,i,r){var o=new bn(t,e,n,i);return r?o:o.doResume(null)}function xn(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$desiredSize=e}function kn(t,e,n,i){var r=new xn(t,e,n);return i?r:r.doResume(null)}function En(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$chunk=void 0,this.local$$receiver=t,this.local$desiredSize=e}function Cn(t,e,n,i){var r=new En(t,e,n);return i?r:r.doResume(null)}function Sn(){}function Tn(t,e,n,i){s.call(this,i),this.exceptionState_0=6,this.local$buffer=void 0,this.local$bytesWritten=void 0,this.local$$receiver=t,this.local$desiredSpace=e,this.local$block=n}function On(){}function Nn(){}function Pn(){}function An(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$session=void 0,this.local$$receiver=t,this.local$desiredSpace=e}function jn(t,e,n,i){var r=new An(t,e,n);return i?r:r.doResume(null)}function Ln(t,n,i,r){if(!e.isType(t,Pn))return function(t,e,n,i){var r=new Rn(t,e,n);return i?r:r.doResume(null)}(t,n,r);t.endWriteSession_za3lpa$(i)}function Rn(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$$receiver=t,this.local$buffer=e}function In(t,e,n){s.call(this,n),this.exceptionState_0=1,this.local$session=t,this.local$desiredSpace=e}function zn(){var t=Nl().Pool.borrow();return t.resetForWrite(),t.reserveEndGap_za3lpa$(8),t}rn.$metadata$={kind:o,simpleName:"ReaderJob",interfaces:[S]},on.$metadata$={kind:o,simpleName:"WriterJob",interfaces:[S]},an.$metadata$={kind:o,simpleName:"ReaderScope",interfaces:[T]},sn.$metadata$={kind:o,simpleName:"WriterScope",interfaces:[T]},hn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},hn.prototype=Object.create(s.prototype),hn.prototype.constructor=hn,hn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.local$closure$attachJob&&this.local$closure$channel.attachJob_dqr1mp$(f(this.local$$receiver.coroutineContext.get_j3r2sn$(S.Key))),this.state_0=2,this.result_0=this.local$closure$block(e.isType(t=new fn(this.local$$receiver,this.local$closure$channel),T)?t:c(),this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Object.defineProperty(fn.prototype,"channel",{get:function(){return this.channel_79cwt9$_0}}),Object.defineProperty(fn.prototype,"coroutineContext",{get:function(){return this.$delegate_h3p63m$_0.coroutineContext}}),fn.$metadata$={kind:p,simpleName:"ChannelScope",interfaces:[sn,an,T]},Object.defineProperty(dn.prototype,"channel",{get:function(){return this.channel_zg1n2y$_0}}),dn.prototype.toString=function(){return"ChannelJob["+this.delegate_0+"]"},Object.defineProperty(dn.prototype,"children",{get:function(){return this.delegate_0.children}}),Object.defineProperty(dn.prototype,"isActive",{get:function(){return this.delegate_0.isActive}}),Object.defineProperty(dn.prototype,"isCancelled",{get:function(){return this.delegate_0.isCancelled}}),Object.defineProperty(dn.prototype,"isCompleted",{get:function(){return this.delegate_0.isCompleted}}),Object.defineProperty(dn.prototype,"key",{get:function(){return this.delegate_0.key}}),Object.defineProperty(dn.prototype,"onJoin",{get:function(){return this.delegate_0.onJoin}}),dn.prototype.attachChild_kx8v25$=function(t){return this.delegate_0.attachChild_kx8v25$(t)},dn.prototype.cancel=function(){return this.delegate_0.cancel()},dn.prototype.cancel_dbl4no$$default=function(t){return this.delegate_0.cancel_dbl4no$$default(t)},dn.prototype.cancel_m4sck1$$default=function(t){return this.delegate_0.cancel_m4sck1$$default(t)},dn.prototype.fold_3cc69b$=function(t,e){return this.delegate_0.fold_3cc69b$(t,e)},dn.prototype.get_j3r2sn$=function(t){return this.delegate_0.get_j3r2sn$(t)},dn.prototype.getCancellationException=function(){return this.delegate_0.getCancellationException()},dn.prototype.invokeOnCompletion_ct2b2z$$default=function(t,e,n){return this.delegate_0.invokeOnCompletion_ct2b2z$$default(t,e,n)},dn.prototype.invokeOnCompletion_f05bi3$=function(t){return this.delegate_0.invokeOnCompletion_f05bi3$(t)},dn.prototype.join=function(t){return this.delegate_0.join(t)},dn.prototype.minusKey_yeqjby$=function(t){return this.delegate_0.minusKey_yeqjby$(t)},dn.prototype.plus_1fupul$=function(t){return this.delegate_0.plus_1fupul$(t)},dn.prototype.plus_dqr1mp$=function(t){return this.delegate_0.plus_dqr1mp$(t)},dn.prototype.start=function(){return this.delegate_0.start()},dn.$metadata$={kind:p,simpleName:"ChannelJob",interfaces:[on,rn,S]},mn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},mn.prototype=Object.create(s.prototype),mn.prototype.constructor=mn,mn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(void 0===this.local$desiredSize&&(this.local$desiredSize=1),this.state_0=1,this.result_0=gn(this.local$$receiver,this.local$desiredSize,this),this.result_0===a)return a;continue;case 1:this.local$buffer=null!=(t=this.result_0)?t:Vi.Companion.Empty,this.local$bytesRead=0,this.exceptionState_0=2,this.local$bytesRead=this.local$block(this.local$buffer.memory,e.Long.fromInt(this.local$buffer.readPosition),e.Long.fromInt(this.local$buffer.writePosition-this.local$buffer.readPosition|0)),this.exceptionState_0=6,this.finallyPath_0=[3],this.state_0=4,this.$returnValue=this.local$bytesRead;continue;case 2:this.finallyPath_0=[6],this.state_0=4;continue;case 3:return this.$returnValue;case 4:if(this.exceptionState_0=6,this.state_0=5,this.result_0=wn(this.local$$receiver,this.local$buffer,this.local$bytesRead,this),this.result_0===a)return a;continue;case 5:this.state_0=this.finallyPath_0.shift();continue;case 6:throw this.exception_0;case 7:return;default:throw this.state_0=6,new Error("State Machine Unreachable execution")}}catch(t){if(6===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.read_ons6h$",x((function(){var n=t.io.ktor.utils.io.requestBuffer_78elpf$,i=t.io.ktor.utils.io.core.Buffer,r=t.io.ktor.utils.io.completeReadingFromBuffer_6msh3s$;return function(t,o,a,s){var l;void 0===o&&(o=1),e.suspendCall(n(t,o,e.coroutineReceiver()));var u=null!=(l=e.coroutineResult(e.coroutineReceiver()))?l:i.Companion.Empty,c=0;try{return c=a(u.memory,e.Long.fromInt(u.readPosition),e.Long.fromInt(u.writePosition-u.readPosition|0))}finally{e.suspendCall(r(t,u,c,e.coroutineReceiver()))}}}))),yn.prototype.request_za3lpa$=function(t,e){return void 0===t&&(t=1),e?e(t):this.request_za3lpa$$default(t)},yn.$metadata$={kind:o,simpleName:"ReadSession",interfaces:[]},$n.prototype.await_za3lpa$=function(t,e,n){return void 0===t&&(t=1),n?n(t,e):this.await_za3lpa$$default(t,e)},$n.$metadata$={kind:o,simpleName:"SuspendableReadSession",interfaces:[yn]},vn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},vn.prototype=Object.create(s.prototype),vn.prototype.constructor=vn,vn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=e.isType(this.local$$receiver,$n)?this.local$$receiver:e.isType(this.local$$receiver,Sn)?this.local$$receiver.startReadSession():null,this.local$readSession=t,null!=this.local$readSession){var n=this.local$readSession.request_za3lpa$(L(this.local$desiredSize,8));if(null!=n)return n;this.state_0=2;continue}this.state_0=4;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=kn(this.local$readSession,this.local$desiredSize,this),this.result_0===a)return a;continue;case 3:return this.result_0;case 4:if(this.state_0=5,this.result_0=Cn(this.local$$receiver,this.local$desiredSize,this),this.result_0===a)return a;continue;case 5:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},bn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},bn.prototype=Object.create(s.prototype),bn.prototype.constructor=bn,bn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(null!=(t=e.isType(this.local$$receiver,Sn)?this.local$$receiver.startReadSession():null))return void t.discard_za3lpa$(this.local$bytesRead);this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(e.isType(this.local$buffer,bl)){if(this.local$buffer.release_2bs5fo$(Nl().Pool),this.state_0=3,this.result_0=this.local$$receiver.discard_s8cxhz$(e.Long.fromInt(this.local$bytesRead),this),this.result_0===a)return a;continue}this.state_0=4;continue;case 3:this.state_0=4;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},xn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},xn.prototype=Object.create(s.prototype),xn.prototype.constructor=xn,xn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.local$$receiver.await_za3lpa$(this.local$desiredSize,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return this.local$$receiver.request_za3lpa$(1);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},En.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},En.prototype=Object.create(s.prototype),En.prototype.constructor=En,En.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$chunk=Nl().Pool.borrow(),this.state_0=2,this.result_0=this.local$$receiver.peekTo_afjyek$(this.local$chunk.memory,e.Long.fromInt(this.local$chunk.writePosition),u,e.Long.fromInt(this.local$desiredSize),e.Long.fromInt(this.local$chunk.limit-this.local$chunk.writePosition|0),this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:var t=this.result_0;return this.local$chunk.commitWritten_za3lpa$(t.toInt()),this.local$chunk;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Sn.$metadata$={kind:o,simpleName:"HasReadSession",interfaces:[]},Tn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Tn.prototype=Object.create(s.prototype),Tn.prototype.constructor=Tn,Tn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(void 0===this.local$desiredSpace&&(this.local$desiredSpace=1),this.state_0=1,this.result_0=jn(this.local$$receiver,this.local$desiredSpace,this),this.result_0===a)return a;continue;case 1:this.local$buffer=null!=(t=this.result_0)?t:Vi.Companion.Empty,this.local$bytesWritten=0,this.exceptionState_0=2,this.local$bytesWritten=this.local$block(this.local$buffer.memory,e.Long.fromInt(this.local$buffer.writePosition),e.Long.fromInt(this.local$buffer.limit)),this.local$buffer.commitWritten_za3lpa$(this.local$bytesWritten),this.exceptionState_0=6,this.finallyPath_0=[3],this.state_0=4,this.$returnValue=this.local$bytesWritten;continue;case 2:this.finallyPath_0=[6],this.state_0=4;continue;case 3:return this.$returnValue;case 4:if(this.exceptionState_0=6,this.state_0=5,this.result_0=Ln(this.local$$receiver,this.local$buffer,this.local$bytesWritten,this),this.result_0===a)return a;continue;case 5:this.state_0=this.finallyPath_0.shift();continue;case 6:throw this.exception_0;case 7:return;default:throw this.state_0=6,new Error("State Machine Unreachable execution")}}catch(t){if(6===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},w("ktor-ktor-io.io.ktor.utils.io.write_k0oolq$",x((function(){var n=t.io.ktor.utils.io.requestWriteBuffer_9tm6dw$,i=t.io.ktor.utils.io.core.Buffer,r=t.io.ktor.utils.io.completeWriting_oczduq$;return function(t,o,a,s){var l;void 0===o&&(o=1),e.suspendCall(n(t,o,e.coroutineReceiver()));var u=null!=(l=e.coroutineResult(e.coroutineReceiver()))?l:i.Companion.Empty,c=0;try{return c=a(u.memory,e.Long.fromInt(u.writePosition),e.Long.fromInt(u.limit)),u.commitWritten_za3lpa$(c),c}finally{e.suspendCall(r(t,u,c,e.coroutineReceiver()))}}}))),On.$metadata$={kind:o,simpleName:"WriterSession",interfaces:[]},Nn.$metadata$={kind:o,simpleName:"WriterSuspendSession",interfaces:[On]},Pn.$metadata$={kind:o,simpleName:"HasWriteSession",interfaces:[]},An.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},An.prototype=Object.create(s.prototype),An.prototype.constructor=An,An.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(t=e.isType(this.local$$receiver,Pn)?this.local$$receiver.beginWriteSession():null,this.local$session=t,null!=this.local$session){var n=this.local$session.request_za3lpa$(this.local$desiredSpace);if(null!=n)return n;this.state_0=2;continue}this.state_0=4;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=(i=this.local$session,r=this.local$desiredSpace,o=void 0,s=void 0,s=new In(i,r,this),o?s:s.doResume(null)),this.result_0===a)return a;continue;case 3:return this.result_0;case 4:return zn();default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}var i,r,o,s},Rn.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Rn.prototype=Object.create(s.prototype),Rn.prototype.constructor=Rn,Rn.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(e.isType(this.local$buffer,Hp)){if(this.state_0=2,this.result_0=this.local$$receiver.writeFully_99qa0s$(this.local$buffer,this),this.result_0===a)return a;continue}this.state_0=3;continue;case 1:throw this.exception_0;case 2:return void this.local$buffer.release_duua06$(Qp().Pool);case 3:throw R("Only IoBuffer instance is supported.");default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},In.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},In.prototype=Object.create(s.prototype),In.prototype.constructor=In,In.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.state_0=2,this.result_0=this.local$session.tryAwait_za3lpa$(this.local$desiredSpace,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return null!=(t=this.local$session.request_za3lpa$(this.local$desiredSpace))?t:this.local$session.request_za3lpa$(1);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}};var Dn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_highByte_5vcgdc$",x((function(){var t=e.toByte;return function(e){return t((255&e)>>8)}}))),Mn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_lowByte_5vcgdc$",x((function(){var t=e.toByte;return function(e){return t(255&e)}}))),Bn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_highShort_s8ev3n$",x((function(){var t=e.toShort;return function(e){return t(e>>>16)}}))),Un=w("ktor-ktor-io.io.ktor.utils.io.bits.get_lowShort_s8ev3n$",x((function(){var t=e.toShort;return function(e){return t(65535&e)}}))),Fn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_highInt_mts6qi$",(function(t){return t.shiftRightUnsigned(32).toInt()})),qn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_lowInt_mts6qi$",x((function(){var t=new e.Long(-1,0);return function(e){return e.and(t).toInt()}}))),Gn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_ad7opl$",(function(t,e){return t.view.getInt8(e)})),Hn=w("ktor-ktor-io.io.ktor.utils.io.bits.get_xrw27i$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){var i=t.view;return n.toNumber()>=2147483647&&e(n,"index"),i.getInt8(n.toInt())}}))),Yn=w("ktor-ktor-io.io.ktor.utils.io.bits.set_x25fc5$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=t.view;n.toNumber()>=2147483647&&e(n,"index"),r.setInt8(n.toInt(),i)}}))),Vn=w("ktor-ktor-io.io.ktor.utils.io.bits.set_gx2x5q$",(function(t,e,n){t.view.setInt8(e,n)})),Kn=w("ktor-ktor-io.io.ktor.utils.io.bits.storeAt_u5mcnq$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=i.data,o=t.view;n.toNumber()>=2147483647&&e(n,"index"),o.setInt8(n.toInt(),r)}}))),Wn=w("ktor-ktor-io.io.ktor.utils.io.bits.storeAt_r092yl$",(function(t,e,n){t.view.setInt8(e,n.data)})),Xn=w("ktor-ktor-io.io.ktor.utils.io.bits.withMemory_24cc00$",x((function(){var n=t.io.ktor.utils.io.bits;return function(t,i){var r,o=e.Long.fromInt(t),a=n.DefaultAllocator,s=a.alloc_s8cxhz$(o);try{r=i(s)}finally{a.free_vn6nzs$(s)}return r}}))),Zn=w("ktor-ktor-io.io.ktor.utils.io.bits.withMemory_ksmduh$",x((function(){var e=t.io.ktor.utils.io.bits;return function(t,n){var i,r=e.DefaultAllocator,o=r.alloc_s8cxhz$(t);try{i=n(o)}finally{r.free_vn6nzs$(o)}return i}})));function Jn(){}Jn.$metadata$={kind:o,simpleName:"Allocator",interfaces:[]};var Qn=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUShortAt_ad7opl$",x((function(){var t=e.kotlin.UShort;return function(e,n){return new t(e.view.getInt16(n,!1))}}))),ti=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUShortAt_xrw27i$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$,i=e.kotlin.UShort;return function(t,e){return e.toNumber()>=2147483647&&n(e,"offset"),new i(t.view.getInt16(e.toInt(),!1))}}))),ei=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUShortAt_feknxd$",(function(t,e,n){t.view.setInt16(e,n.data,!1)})),ni=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUShortAt_b6qmqu$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=i.data,o=t.view;n.toNumber()>=2147483647&&e(n,"offset"),o.setInt16(n.toInt(),r,!1)}}))),ii=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUIntAt_ad7opl$",x((function(){var t=e.kotlin.UInt;return function(e,n){return new t(e.view.getInt32(n,!1))}}))),ri=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUIntAt_xrw27i$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$,i=e.kotlin.UInt;return function(t,e){return e.toNumber()>=2147483647&&n(e,"offset"),new i(t.view.getInt32(e.toInt(),!1))}}))),oi=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUIntAt_gwrs4s$",(function(t,e,n){t.view.setInt32(e,n.data,!1)})),ai=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUIntAt_x1uab7$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=i.data,o=t.view;n.toNumber()>=2147483647&&e(n,"offset"),o.setInt32(n.toInt(),r,!1)}}))),si=w("ktor-ktor-io.io.ktor.utils.io.bits.loadULongAt_ad7opl$",x((function(){var t=e.kotlin.ULong;return function(n,i){return new t(e.Long.fromInt(n.view.getUint32(i,!1)).shiftLeft(32).or(e.Long.fromInt(n.view.getUint32(i+4|0,!1))))}}))),li=w("ktor-ktor-io.io.ktor.utils.io.bits.loadULongAt_xrw27i$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$,i=e.kotlin.ULong;return function(t,r){r.toNumber()>=2147483647&&n(r,"offset");var o=r.toInt();return new i(e.Long.fromInt(t.view.getUint32(o,!1)).shiftLeft(32).or(e.Long.fromInt(t.view.getUint32(o+4|0,!1))))}}))),ui=w("ktor-ktor-io.io.ktor.utils.io.bits.storeULongAt_r02wnd$",x((function(){var t=new e.Long(-1,0);return function(e,n,i){var r=i.data;e.view.setInt32(n,r.shiftRight(32).toInt(),!1),e.view.setInt32(n+4|0,r.and(t).toInt(),!1)}}))),ci=w("ktor-ktor-io.io.ktor.utils.io.bits.storeULongAt_u5g6ci$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$,i=new e.Long(-1,0);return function(t,e,r){var o=r.data;e.toNumber()>=2147483647&&n(e,"offset");var a=e.toInt();t.view.setInt32(a,o.shiftRight(32).toInt(),!1),t.view.setInt32(a+4|0,o.and(i).toInt(),!1)}}))),pi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadByteArray_ngtxw7$",x((function(){var e=t.io.ktor.utils.io.bits.copyTo_tiw1kd$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.length-r|0),e(t,i,n,o,r)}}))),hi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadByteArray_dy6oua$",x((function(){var e=t.io.ktor.utils.io.bits.copyTo_yqt5go$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.length-r|0),e(t,i,n,o,r)}}))),_i=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUByteArray_moiot2$",x((function(){var e=t.io.ktor.utils.io.bits.copyTo_tiw1kd$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,i.storage,n,o,r)}}))),fi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUByteArray_r80dt$",x((function(){var e=t.io.ktor.utils.io.bits.copyTo_yqt5go$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,i.storage,n,o,r)}}))),di=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUShortArray_fu1ix4$",x((function(){var e=t.io.ktor.utils.io.bits.loadShortArray_8jnas7$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),mi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUShortArray_w2wo2p$",x((function(){var e=t.io.ktor.utils.io.bits.loadShortArray_ew3eeo$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),yi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUIntArray_795lej$",x((function(){var e=t.io.ktor.utils.io.bits.loadIntArray_kz60l8$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),$i=w("ktor-ktor-io.io.ktor.utils.io.bits.loadUIntArray_qcxtu4$",x((function(){var e=t.io.ktor.utils.io.bits.loadIntArray_qrle83$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),vi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadULongArray_1mgmjm$",x((function(){var e=t.io.ktor.utils.io.bits.loadLongArray_2ervmr$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),gi=w("ktor-ktor-io.io.ktor.utils.io.bits.loadULongArray_lta2n9$",x((function(){var e=t.io.ktor.utils.io.bits.loadLongArray_z08r3q$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),bi=w("ktor-ktor-io.io.ktor.utils.io.bits.storeByteArray_ngtxw7$",x((function(){var e=t.io.ktor.utils.io.bits.Memory,n=t.io.ktor.utils.io.bits.of_2z595v$;return function(t,i,r,o,a){void 0===o&&(o=0),void 0===a&&(a=r.length-o|0),n(e.Companion,r,o,a).copyTo_ubllm2$(t,0,a,i)}}))),wi=w("ktor-ktor-io.io.ktor.utils.io.bits.storeByteArray_dy6oua$",x((function(){var n=e.Long.ZERO,i=t.io.ktor.utils.io.bits.Memory,r=t.io.ktor.utils.io.bits.of_2z595v$;return function(t,o,a,s,l){void 0===s&&(s=0),void 0===l&&(l=a.length-s|0),r(i.Companion,a,s,l).copyTo_q2ka7j$(t,n,e.Long.fromInt(l),o)}}))),xi=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUByteArray_moiot2$",x((function(){var e=t.io.ktor.utils.io.bits.Memory,n=t.io.ktor.utils.io.bits.of_2z595v$;return function(t,i,r,o,a){void 0===o&&(o=0),void 0===a&&(a=r.size-o|0);var s=r.storage;n(e.Companion,s,o,a).copyTo_ubllm2$(t,0,a,i)}}))),ki=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUByteArray_r80dt$",x((function(){var n=e.Long.ZERO,i=t.io.ktor.utils.io.bits.Memory,r=t.io.ktor.utils.io.bits.of_2z595v$;return function(t,o,a,s,l){void 0===s&&(s=0),void 0===l&&(l=a.size-s|0);var u=a.storage;r(i.Companion,u,s,l).copyTo_q2ka7j$(t,n,e.Long.fromInt(l),o)}}))),Ei=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUShortArray_fu1ix4$",x((function(){var e=t.io.ktor.utils.io.bits.storeShortArray_8jnas7$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),Ci=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUShortArray_w2wo2p$",x((function(){var e=t.io.ktor.utils.io.bits.storeShortArray_ew3eeo$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),Si=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUIntArray_795lej$",x((function(){var e=t.io.ktor.utils.io.bits.storeIntArray_kz60l8$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),Ti=w("ktor-ktor-io.io.ktor.utils.io.bits.storeUIntArray_qcxtu4$",x((function(){var e=t.io.ktor.utils.io.bits.storeIntArray_qrle83$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),Oi=w("ktor-ktor-io.io.ktor.utils.io.bits.storeULongArray_1mgmjm$",x((function(){var e=t.io.ktor.utils.io.bits.storeLongArray_2ervmr$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}}))),Ni=w("ktor-ktor-io.io.ktor.utils.io.bits.storeULongArray_lta2n9$",x((function(){var e=t.io.ktor.utils.io.bits.storeLongArray_z08r3q$;return function(t,n,i,r,o){void 0===r&&(r=0),void 0===o&&(o=i.size-r|0),e(t,n,i.storage,r,o)}})));function Pi(t,e,n,i,r){var o={v:n};if(!(o.v>=i)){var a=cu(r,1,null);try{for(var s;;){var l=ji(t,e,o.v,i,a);if(!(l>=0))throw B("Check failed.".toString());if(o.v=o.v+l|0,(s=o.v>=i?0:0===l?8:1)<=0)break;a=cu(r,s,a)}}finally{pu(r,a)}Ii(t,r)}}function Ai(t,n,i){void 0===i&&(i=2147483647);var r=e.Long.fromInt(i),o=Ri(n),a=U((r.compareTo_11rb$(o)<=0?r:o).toInt());return sp(t,n,a,i),a.toString()}function ji(t,e,n,i,r){var o=i-n|0;return tp(t,new Hl(e,n,o),0,o,r)}function Li(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length);var o={v:i};if(o.v>=r)return Wl;var a=Nl().Pool.borrow();try{var s,l=tp(t,n,o.v,r,a);if(o.v=o.v+l|0,o.v===r){var u=new Int8Array(a.writePosition-a.readPosition|0);return ao(a,u),u}var c=mh(0);try{c.appendSingleChunk_pvnryh$(a.duplicate()),zi(t,c,n,o.v,r),s=c.build()}catch(t){throw e.isType(t,C)?(c.release(),t):t}return Gs(s)}finally{a.release_2bs5fo$(Nl().Pool)}}function Ri(t){if(e.isType(t,Qo))return t.remaining;if(e.isType(t,Mi)){var n=t.remaining,i=M;return n.compareTo_11rb$(i)>=0?n:i}return M}function Ii(t,e){var n={v:1},i={v:0},r=cu(e,1,null);try{for(;;){var o=r,a=o.limit-o.writePosition|0;if(n.v=0,i.v=i.v+(a-(o.limit-o.writePosition|0))|0,!(n.v>0))break;r=cu(e,1,r)}}finally{pu(e,r)}return i.v}function zi(t,e,n,i,r){var o={v:i};if(o.v>=r)return 0;var a={v:0},s=cu(e,1,null);try{for(var l;;){var u=s,c=u.limit-u.writePosition|0,p=tp(t,n,o.v,r,u);if(!(p>=0))throw B("Check failed.".toString());if(o.v=o.v+p|0,a.v=a.v+(c-(u.limit-u.writePosition|0))|0,(l=o.v>=r?0:0===p?8:1)<=0)break;s=cu(e,l,s)}}finally{pu(e,s)}return a.v=a.v+Ii(0,e)|0,a.v}function Di(t){this.closure$message=t,Il.call(this)}function Mi(t,n,i){Gi(),void 0===t&&(t=Nl().Empty),void 0===n&&(n=Fo(t)),void 0===i&&(i=Nl().Pool),this.pool=i,this._head_xb1tt$_l4zxc7$_0=t,this.headMemory=t.memory,this.headPosition=t.readPosition,this.headEndExclusive=t.writePosition,this.tailRemaining_l8ht08$_7gwoj7$_0=n.subtract(e.Long.fromInt(this.headEndExclusive-this.headPosition|0)),this.noMoreChunksAvailable_2n0tap$_0=!1}function Bi(t,e){this.closure$destination=t,this.idx_0=e}function Ui(){throw B("It should be no tail remaining bytes if current tail is EmptyBuffer")}function Fi(){qi=this}Di.prototype=Object.create(Il.prototype),Di.prototype.constructor=Di,Di.prototype.doFail=function(){throw b(this.closure$message())},Di.$metadata$={kind:p,interfaces:[Il]},Object.defineProperty(Mi.prototype,"_head_xb1tt$_0",{get:function(){return this._head_xb1tt$_l4zxc7$_0},set:function(t){this._head_xb1tt$_l4zxc7$_0=t,this.headMemory=t.memory,this.headPosition=t.readPosition,this.headEndExclusive=t.writePosition}}),Object.defineProperty(Mi.prototype,"head",{get:function(){var t=this._head_xb1tt$_0;return t.discardUntilIndex_kcn2v3$(this.headPosition),t},set:function(t){this._head_xb1tt$_0=t}}),Object.defineProperty(Mi.prototype,"headRemaining",{get:w("ktor-ktor-io.io.ktor.utils.io.core.AbstractInput.get_headRemaining",(function(){return this.headEndExclusive-this.headPosition|0})),set:function(t){this.updateHeadRemaining_za3lpa$(t)}}),Object.defineProperty(Mi.prototype,"tailRemaining_l8ht08$_0",{get:function(){return this.tailRemaining_l8ht08$_7gwoj7$_0},set:function(t){var e,n,i,r;if(t.toNumber()<0)throw B(("tailRemaining is negative: "+t.toString()).toString());if(_(t,u)){var o=null!=(n=null!=(e=this._head_xb1tt$_0.next)?Fo(e):null)?n:u;if(!_(o,u))throw B(("tailRemaining is set 0 while there is a tail of size "+o.toString()).toString())}var a=null!=(r=null!=(i=this._head_xb1tt$_0.next)?Fo(i):null)?r:u;if(!_(t,a))throw B(("tailRemaining is set to a value that is not consistent with the actual tail: "+t.toString()+" != "+a.toString()).toString());this.tailRemaining_l8ht08$_7gwoj7$_0=t}}),Object.defineProperty(Mi.prototype,"byteOrder",{get:function(){return xp()},set:function(t){if(t!==xp())throw b("Only BIG_ENDIAN is supported.")}}),Mi.prototype.prefetch_8e33dg$=function(t){if(t.toNumber()<=0)return!0;var n=this.headEndExclusive-this.headPosition|0;return n>=t.toNumber()||e.Long.fromInt(n).add(this.tailRemaining_l8ht08$_0).compareTo_11rb$(t)>=0||this.doPrefetch_15sylx$_0(t)},Mi.prototype.peekTo_afjyek$$default=function(t,n,i,r,o){var a;this.prefetch_8e33dg$(r.add(i));for(var s=this.head,l=u,c=i,p=n,h=e.Long.fromInt(t.view.byteLength).subtract(n),_=o.compareTo_11rb$(h)<=0?o:h;l.compareTo_11rb$(r)<0&&l.compareTo_11rb$(_)<0;){var f=s,d=f.writePosition-f.readPosition|0;if(d>c.toNumber()){var m=e.Long.fromInt(d).subtract(c),y=_.subtract(l),$=m.compareTo_11rb$(y)<=0?m:y;s.memory.copyTo_q2ka7j$(t,e.Long.fromInt(s.readPosition).add(c),$,p),c=u,l=l.add($),p=p.add($)}else c=c.subtract(e.Long.fromInt(d));if(null==(a=s.next))break;s=a}return l},Mi.prototype.doPrefetch_15sylx$_0=function(t){var n=Uo(this._head_xb1tt$_0),i=e.Long.fromInt(this.headEndExclusive-this.headPosition|0).add(this.tailRemaining_l8ht08$_0);do{var r=this.fill();if(null==r)return this.noMoreChunksAvailable_2n0tap$_0=!0,!1;var o=r.writePosition-r.readPosition|0;n===Nl().Empty?(this._head_xb1tt$_0=r,n=r):(n.next=r,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.add(e.Long.fromInt(o))),i=i.add(e.Long.fromInt(o))}while(i.compareTo_11rb$(t)<0);return!0},Object.defineProperty(Mi.prototype,"remaining",{get:function(){return e.Long.fromInt(this.headEndExclusive-this.headPosition|0).add(this.tailRemaining_l8ht08$_0)}}),Mi.prototype.canRead=function(){return this.headPosition!==this.headEndExclusive||!_(this.tailRemaining_l8ht08$_0,u)},Mi.prototype.hasBytes_za3lpa$=function(t){return e.Long.fromInt(this.headEndExclusive-this.headPosition|0).add(this.tailRemaining_l8ht08$_0).toNumber()>=t},Object.defineProperty(Mi.prototype,"isEmpty",{get:function(){return this.endOfInput}}),Object.defineProperty(Mi.prototype,"isNotEmpty",{get:function(){return Os(this)}}),Object.defineProperty(Mi.prototype,"endOfInput",{get:function(){return 0==(this.headEndExclusive-this.headPosition|0)&&_(this.tailRemaining_l8ht08$_0,u)&&(this.noMoreChunksAvailable_2n0tap$_0||null==this.doFill_nh863c$_0())}}),Mi.prototype.release=function(){var t=this.head,e=Nl().Empty;t!==e&&(this._head_xb1tt$_0=e,this.tailRemaining_l8ht08$_0=u,zo(t,this.pool))},Mi.prototype.close=function(){this.release(),this.noMoreChunksAvailable_2n0tap$_0||(this.noMoreChunksAvailable_2n0tap$_0=!0),this.closeSource()},Mi.prototype.stealAll_8be2vx$=function(){var t=this.head,e=Nl().Empty;return t===e?null:(this._head_xb1tt$_0=e,this.tailRemaining_l8ht08$_0=u,t)},Mi.prototype.steal_8be2vx$=function(){var t=this.head,n=t.next,i=Nl().Empty;return t===i?null:(null==n?(this._head_xb1tt$_0=i,this.tailRemaining_l8ht08$_0=u):(this._head_xb1tt$_0=n,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.subtract(e.Long.fromInt(n.writePosition-n.readPosition|0))),t.next=null,t)},Mi.prototype.append_pvnryh$=function(t){if(t!==Nl().Empty){var n=Fo(t);this._head_xb1tt$_0===Nl().Empty?(this._head_xb1tt$_0=t,this.tailRemaining_l8ht08$_0=n.subtract(e.Long.fromInt(this.headEndExclusive-this.headPosition|0))):(Uo(this._head_xb1tt$_0).next=t,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.add(n))}},Mi.prototype.tryWriteAppend_pvnryh$=function(t){var n=Uo(this.head),i=t.writePosition-t.readPosition|0,r=0===i;return r||(r=(n.limit-n.writePosition|0)=0||new Di((e=t,function(){return"Negative discard is not allowed: "+e})).doFail(),this.discardAsMuchAsPossible_3xuwvm$_0(t,0);var e},Mi.prototype.discardExact_za3lpa$=function(t){if(this.discard_za3lpa$(t)!==t)throw new Th("Unable to discard "+t+" bytes due to end of packet")},Mi.prototype.read_wbh1sp$=w("ktor-ktor-io.io.ktor.utils.io.core.AbstractInput.read_wbh1sp$",x((function(){var n=t.io.ktor.utils.io.core.prematureEndOfStream_za3lpa$,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(t){var e,r=null!=(e=this.prepareRead_za3lpa$(1))?e:n(1),o=r.readPosition;try{t(r)}finally{var a=r.readPosition;if(a0?n.tryPeekByte():_(this.tailRemaining_l8ht08$_0,u)&&this.noMoreChunksAvailable_2n0tap$_0?-1:null!=(e=null!=(t=this.prepareReadLoop_3ilf5z$_0(1,n))?t.tryPeekByte():null)?e:-1},Mi.prototype.peekTo_99qa0s$=function(t){var n,i;if(null==(n=this.prepareReadHead_za3lpa$(1)))return-1;var r=n,o=t.limit-t.writePosition|0,a=r.writePosition-r.readPosition|0,s=g.min(o,a);return No(e.isType(i=t,Vi)?i:c(),r,s),s},Mi.prototype.discard_s8cxhz$=function(t){return t.toNumber()<=0?u:this.discardAsMuchAsPossible_s35ayg$_0(t,u)},Bi.prototype.append_s8itvh$=function(t){var e;return this.closure$destination[(e=this.idx_0,this.idx_0=e+1|0,e)]=t,this},Bi.prototype.append_gw00v9$=function(t){var e,n;if("string"==typeof t)Eh(t,this.closure$destination,this.idx_0),this.idx_0=this.idx_0+t.length|0;else if(null!=t){e=t.length;for(var i=0;i=0){var r=Ws(this,this.remaining.toInt());return t.append_gw00v9$(r),r.length}return this.readASCII_ka9uwb$_0(t,n,i)},Mi.prototype.readTextExact_a5kscm$=function(t,e){this.readText_5dvtqg$(t,e,e)},Mi.prototype.readText_vux9f0$=function(t,n){if(void 0===t&&(t=0),void 0===n&&(n=2147483647),0===t&&(0===n||this.endOfInput))return"";var i=this.remaining;if(i.toNumber()>0&&e.Long.fromInt(n).compareTo_11rb$(i)>=0)return Ws(this,i.toInt());var r=U(L(G(t,16),n));return this.readASCII_ka9uwb$_0(r,t,n),r.toString()},Mi.prototype.readTextExact_za3lpa$=function(t){return this.readText_vux9f0$(t,t)},Mi.prototype.readASCII_ka9uwb$_0=function(t,e,n){if(0===n&&0===e)return 0;if(this.endOfInput){if(0===e)return 0;this.atLeastMinCharactersRequire_tmg3q9$_0(e)}else n=l)try{var h,_=s;n:do{for(var f={v:0},d={v:0},m={v:0},y=_.memory,$=_.readPosition,v=_.writePosition,g=$;g>=1,f.v=f.v+1|0;if(m.v=f.v,f.v=f.v-1|0,m.v>(v-g|0)){_.discardExact_za3lpa$(g-$|0),h=m.v;break n}}else if(d.v=d.v<<6|127&b,f.v=f.v-1|0,0===f.v){if(Ql(d.v)){var C,S=K(V(d.v));if(i.v===n?C=!1:(t.append_s8itvh$(H(S)),i.v=i.v+1|0,C=!0),!C){_.discardExact_za3lpa$(g-$-m.v+1|0),h=-1;break n}}else if(tu(d.v)){var T,O=K(V(nu(d.v)));i.v===n?T=!1:(t.append_s8itvh$(H(O)),i.v=i.v+1|0,T=!0);var N=!T;if(!N){var P,A=K(V(eu(d.v)));i.v===n?P=!1:(t.append_s8itvh$(H(A)),i.v=i.v+1|0,P=!0),N=!P}if(N){_.discardExact_za3lpa$(g-$-m.v+1|0),h=-1;break n}}else Jl(d.v);d.v=0}}var j=v-$|0;_.discardExact_za3lpa$(j),h=0}while(0);l=0===h?1:h>0?h:0}finally{var L=s;u=L.writePosition-L.readPosition|0}else u=p;if(a=!1,0===u)o=uu(this,s);else{var R=u0)}finally{a&&lu(this,s)}}while(0);return i.va?(t.releaseEndGap_8be2vx$(),this.headEndExclusive=t.writePosition,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.add(e.Long.fromInt(a))):(this._head_xb1tt$_0=i,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.subtract(e.Long.fromInt((i.writePosition-i.readPosition|0)-a|0)),t.cleanNext(),t.release_2bs5fo$(this.pool))},Mi.prototype.fixGapAfterReadFallback_q485vf$_0=function(t){if(this.noMoreChunksAvailable_2n0tap$_0&&null==t.next)return this.headPosition=t.readPosition,this.headEndExclusive=t.writePosition,void(this.tailRemaining_l8ht08$_0=u);var e=t.writePosition-t.readPosition|0,n=8-(t.capacity-t.limit|0)|0,i=g.min(e,n);if(e>i)this.fixGapAfterReadFallbackUnreserved_13fwc$_0(t,e,i);else{var r=this.pool.borrow();r.reserveEndGap_za3lpa$(8),r.next=t.cleanNext(),_r(r,t,e),this._head_xb1tt$_0=r}t.release_2bs5fo$(this.pool)},Mi.prototype.fixGapAfterReadFallbackUnreserved_13fwc$_0=function(t,e,n){var i=this.pool.borrow(),r=this.pool.borrow();i.reserveEndGap_za3lpa$(8),r.reserveEndGap_za3lpa$(8),i.next=r,r.next=t.cleanNext(),_r(i,t,e-n|0),_r(r,t,n),this._head_xb1tt$_0=i,this.tailRemaining_l8ht08$_0=Fo(r)},Mi.prototype.ensureNext_pxb5qx$_0=function(t,n){var i;if(t===n)return this.doFill_nh863c$_0();var r=t.cleanNext();return t.release_2bs5fo$(this.pool),null==r?(this._head_xb1tt$_0=n,this.tailRemaining_l8ht08$_0=u,i=this.ensureNext_pxb5qx$_0(n,n)):r.writePosition>r.readPosition?(this._head_xb1tt$_0=r,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.subtract(e.Long.fromInt(r.writePosition-r.readPosition|0)),i=r):i=this.ensureNext_pxb5qx$_0(r,n),i},Mi.prototype.fill=function(){var t=this.pool.borrow();try{t.reserveEndGap_za3lpa$(8);var n=this.fill_9etqdk$(t.memory,t.writePosition,t.limit-t.writePosition|0);return 0!==n||(this.noMoreChunksAvailable_2n0tap$_0=!0,t.writePosition>t.readPosition)?(t.commitWritten_za3lpa$(n),t):(t.release_2bs5fo$(this.pool),null)}catch(n){throw e.isType(n,C)?(t.release_2bs5fo$(this.pool),n):n}},Mi.prototype.markNoMoreChunksAvailable=function(){this.noMoreChunksAvailable_2n0tap$_0||(this.noMoreChunksAvailable_2n0tap$_0=!0)},Mi.prototype.doFill_nh863c$_0=function(){if(this.noMoreChunksAvailable_2n0tap$_0)return null;var t=this.fill();return null==t?(this.noMoreChunksAvailable_2n0tap$_0=!0,null):(this.appendView_4be14h$_0(t),t)},Mi.prototype.appendView_4be14h$_0=function(t){var e,n,i=Uo(this._head_xb1tt$_0);i===Nl().Empty?(this._head_xb1tt$_0=t,_(this.tailRemaining_l8ht08$_0,u)||new Di(Ui).doFail(),this.tailRemaining_l8ht08$_0=null!=(n=null!=(e=t.next)?Fo(e):null)?n:u):(i.next=t,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.add(Fo(t)))},Mi.prototype.prepareRead_za3lpa$=function(t){var e=this.head;return(this.headEndExclusive-this.headPosition|0)>=t?e:this.prepareReadLoop_3ilf5z$_0(t,e)},Mi.prototype.prepareRead_cvuqs$=function(t,e){return(this.headEndExclusive-this.headPosition|0)>=t?e:this.prepareReadLoop_3ilf5z$_0(t,e)},Mi.prototype.prepareReadLoop_3ilf5z$_0=function(t,n){var i,r,o=this.headEndExclusive-this.headPosition|0;if(o>=t)return n;if(null==(r=null!=(i=n.next)?i:this.doFill_nh863c$_0()))return null;var a=r;if(0===o)return n!==Nl().Empty&&this.releaseHead_pvnryh$(n),this.prepareReadLoop_3ilf5z$_0(t,a);var s=_r(n,a,t-o|0);return this.headEndExclusive=n.writePosition,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.subtract(e.Long.fromInt(s)),a.writePosition>a.readPosition?a.reserveStartGap_za3lpa$(s):(n.next=null,n.next=a.cleanNext(),a.release_2bs5fo$(this.pool)),(n.writePosition-n.readPosition|0)>=t?n:(t>8&&this.minSizeIsTooBig_5ot22f$_0(t),this.prepareReadLoop_3ilf5z$_0(t,n))},Mi.prototype.minSizeIsTooBig_5ot22f$_0=function(t){throw B("minSize of "+t+" is too big (should be less than 8)")},Mi.prototype.afterRead_3wtcpm$_0=function(t){0==(t.writePosition-t.readPosition|0)&&this.releaseHead_pvnryh$(t)},Mi.prototype.releaseHead_pvnryh$=function(t){var n,i=null!=(n=t.cleanNext())?n:Nl().Empty;return this._head_xb1tt$_0=i,this.tailRemaining_l8ht08$_0=this.tailRemaining_l8ht08$_0.subtract(e.Long.fromInt(i.writePosition-i.readPosition|0)),t.release_2bs5fo$(this.pool),i},Fi.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var qi=null;function Gi(){return null===qi&&new Fi,qi}function Hi(t,e){this.headerSizeHint_8gle5k$_0=t,this.pool=e,this._head_hofq54$_0=null,this._tail_hhwkug$_0=null,this.tailMemory_8be2vx$=sc().Empty,this.tailPosition_8be2vx$=0,this.tailEndExclusive_8be2vx$_yr29se$_0=0,this.tailInitialPosition_f6hjsm$_0=0,this.chainedSize_8c83kq$_0=0,this.byteOrder_t3hxpd$_0=xp()}function Yi(t,e){return e=e||Object.create(Hi.prototype),Hi.call(e,0,t),e}function Vi(t){Xi(),this.memory=t,this.readPosition_osecaz$_0=0,this.writePosition_oj9ite$_0=0,this.startGap_cakrhy$_0=0,this.limit_uf38zz$_0=this.memory.view.byteLength,this.capacity=this.memory.view.byteLength,this.attachment=null}function Ki(){Wi=this,this.ReservedSize=8}Mi.$metadata$={kind:p,simpleName:"AbstractInput",interfaces:[Np]},Object.defineProperty(Hi.prototype,"head_8be2vx$",{get:function(){var t;return null!=(t=this._head_hofq54$_0)?t:Nl().Empty}}),Object.defineProperty(Hi.prototype,"tail",{get:function(){return this.prepareWriteHead_za3lpa$(1)}}),Object.defineProperty(Hi.prototype,"currentTail",{get:function(){return this.prepareWriteHead_za3lpa$(1)},set:function(t){this.appendChain_pvnryh$(t)}}),Object.defineProperty(Hi.prototype,"tailEndExclusive_8be2vx$",{get:function(){return this.tailEndExclusive_8be2vx$_yr29se$_0},set:function(t){this.tailEndExclusive_8be2vx$_yr29se$_0=t}}),Object.defineProperty(Hi.prototype,"tailRemaining_8be2vx$",{get:w("ktor-ktor-io.io.ktor.utils.io.core.AbstractOutput.get_tailRemaining_8be2vx$",(function(){return this.tailEndExclusive_8be2vx$-this.tailPosition_8be2vx$|0}))}),Object.defineProperty(Hi.prototype,"_size",{get:function(){return this.chainedSize_8c83kq$_0+(this.tailPosition_8be2vx$-this.tailInitialPosition_f6hjsm$_0)|0},set:function(t){}}),Object.defineProperty(Hi.prototype,"byteOrder",{get:function(){return this.byteOrder_t3hxpd$_0},set:function(t){if(this.byteOrder_t3hxpd$_0=t,t!==xp())throw b("Only BIG_ENDIAN is supported. Use corresponding functions to read/writein the little endian")}}),Hi.prototype.flush=function(){this.flushChain_iwxacw$_0()},Hi.prototype.flushChain_iwxacw$_0=function(){var t;if(null!=(t=this.stealAll_8be2vx$())){var e=t;try{for(var n,i=e;;){var r=i;if(this.flush_9etqdk$(r.memory,r.readPosition,r.writePosition-r.readPosition|0),null==(n=i.next))break;i=n}}finally{zo(e,this.pool)}}},Hi.prototype.stealAll_8be2vx$=function(){var t,e;if(null==(t=this._head_hofq54$_0))return null;var n=t;return null!=(e=this._tail_hhwkug$_0)&&e.commitWrittenUntilIndex_za3lpa$(this.tailPosition_8be2vx$),this._head_hofq54$_0=null,this._tail_hhwkug$_0=null,this.tailPosition_8be2vx$=0,this.tailEndExclusive_8be2vx$=0,this.tailInitialPosition_f6hjsm$_0=0,this.chainedSize_8c83kq$_0=0,this.tailMemory_8be2vx$=sc().Empty,n},Hi.prototype.afterBytesStolen_8be2vx$=function(){var t=this.head_8be2vx$;if(t!==Nl().Empty){if(null!=t.next)throw B("Check failed.".toString());t.resetForWrite(),t.reserveStartGap_za3lpa$(this.headerSizeHint_8gle5k$_0),t.reserveEndGap_za3lpa$(8),this.tailPosition_8be2vx$=t.writePosition,this.tailInitialPosition_f6hjsm$_0=this.tailPosition_8be2vx$,this.tailEndExclusive_8be2vx$=t.limit}},Hi.prototype.appendSingleChunk_pvnryh$=function(t){if(null!=t.next)throw B("It should be a single buffer chunk.".toString());this.appendChainImpl_gq6rjy$_0(t,t,0)},Hi.prototype.appendChain_pvnryh$=function(t){var n=Uo(t),i=Fo(t).subtract(e.Long.fromInt(n.writePosition-n.readPosition|0));i.toNumber()>=2147483647&&Ll(i,"total size increase");var r=i.toInt();this.appendChainImpl_gq6rjy$_0(t,n,r)},Hi.prototype.appendNewChunk_oskcze$_0=function(){var t=this.pool.borrow();return t.reserveEndGap_za3lpa$(8),this.appendSingleChunk_pvnryh$(t),t},Hi.prototype.appendChainImpl_gq6rjy$_0=function(t,e,n){var i=this._tail_hhwkug$_0;if(null==i)this._head_hofq54$_0=t,this.chainedSize_8c83kq$_0=0;else{i.next=t;var r=this.tailPosition_8be2vx$;i.commitWrittenUntilIndex_za3lpa$(r),this.chainedSize_8c83kq$_0=this.chainedSize_8c83kq$_0+(r-this.tailInitialPosition_f6hjsm$_0)|0}this._tail_hhwkug$_0=e,this.chainedSize_8c83kq$_0=this.chainedSize_8c83kq$_0+n|0,this.tailMemory_8be2vx$=e.memory,this.tailPosition_8be2vx$=e.writePosition,this.tailInitialPosition_f6hjsm$_0=e.readPosition,this.tailEndExclusive_8be2vx$=e.limit},Hi.prototype.writeByte_s8j3t7$=function(t){var e=this.tailPosition_8be2vx$;return e=3){var n,i=this.tailMemory_8be2vx$,r=0|t;0<=r&&r<=127?(i.view.setInt8(e,d(r)),n=1):128<=r&&r<=2047?(i.view.setInt8(e,d(192|r>>6&31)),i.view.setInt8(e+1|0,d(128|63&r)),n=2):2048<=r&&r<=65535?(i.view.setInt8(e,d(224|r>>12&15)),i.view.setInt8(e+1|0,d(128|r>>6&63)),i.view.setInt8(e+2|0,d(128|63&r)),n=3):65536<=r&&r<=1114111?(i.view.setInt8(e,d(240|r>>18&7)),i.view.setInt8(e+1|0,d(128|r>>12&63)),i.view.setInt8(e+2|0,d(128|r>>6&63)),i.view.setInt8(e+3|0,d(128|63&r)),n=4):n=Jl(r);var o=n;return this.tailPosition_8be2vx$=e+o|0,this}return this.appendCharFallback_r92zh4$_0(t),this},Hi.prototype.appendCharFallback_r92zh4$_0=function(t){var e=this.prepareWriteHead_za3lpa$(3);try{var n,i=e.memory,r=e.writePosition,o=0|t;0<=o&&o<=127?(i.view.setInt8(r,d(o)),n=1):128<=o&&o<=2047?(i.view.setInt8(r,d(192|o>>6&31)),i.view.setInt8(r+1|0,d(128|63&o)),n=2):2048<=o&&o<=65535?(i.view.setInt8(r,d(224|o>>12&15)),i.view.setInt8(r+1|0,d(128|o>>6&63)),i.view.setInt8(r+2|0,d(128|63&o)),n=3):65536<=o&&o<=1114111?(i.view.setInt8(r,d(240|o>>18&7)),i.view.setInt8(r+1|0,d(128|o>>12&63)),i.view.setInt8(r+2|0,d(128|o>>6&63)),i.view.setInt8(r+3|0,d(128|63&o)),n=4):n=Jl(o);var a=n;if(e.commitWritten_za3lpa$(a),!(a>=0))throw B("The returned value shouldn't be negative".toString())}finally{this.afterHeadWrite()}},Hi.prototype.append_gw00v9$=function(t){return null==t?this.append_ezbsdh$("null",0,4):this.append_ezbsdh$(t,0,t.length),this},Hi.prototype.append_ezbsdh$=function(t,e,n){return null==t?this.append_ezbsdh$("null",e,n):(Xs(this,t,e,n,fp().UTF_8),this)},Hi.prototype.writePacket_3uq2w4$=function(t){var e=t.stealAll_8be2vx$();if(null!=e){var n=this._tail_hhwkug$_0;null!=n?this.writePacketMerging_jurx1f$_0(n,e,t):this.appendChain_pvnryh$(e)}else t.release()},Hi.prototype.writePacketMerging_jurx1f$_0=function(t,e,n){var i;t.commitWrittenUntilIndex_za3lpa$(this.tailPosition_8be2vx$);var r=t.writePosition-t.readPosition|0,o=e.writePosition-e.readPosition|0,a=oh,s=o0;){var r=t.headEndExclusive-t.headPosition|0;if(!(r<=i.v)){var o,a=null!=(o=t.prepareRead_za3lpa$(1))?o:tl(1),s=a.readPosition;try{rs(this,a,i.v)}finally{var l=a.readPosition;if(l0;){var o=e.Long.fromInt(t.headEndExclusive-t.headPosition|0);if(!(o.compareTo_11rb$(r.v)<=0)){var a,s=null!=(a=t.prepareRead_za3lpa$(1))?a:tl(1),l=s.readPosition;try{rs(this,s,r.v.toInt())}finally{var c=s.readPosition;if(c=e)return i;for(i=n(this.prepareWriteHead_za3lpa$(1),i),this.afterHeadWrite();i2047){var i=t.memory,r=t.writePosition,o=t.limit-r|0;if(o<3)throw e("3 bytes character",3,o);var a=i,s=r;a.view.setInt8(s,d(224|n>>12&15)),a.view.setInt8(s+1|0,d(128|n>>6&63)),a.view.setInt8(s+2|0,d(128|63&n));return t.commitWritten_za3lpa$(3),3}var l=t.memory,u=t.writePosition,c=t.limit-u|0;if(c<2)throw e("2 bytes character",2,c);var p=l,h=u;p.view.setInt8(h,d(192|n>>6&31)),p.view.setInt8(h+1|0,d(128|63&n));return t.commitWritten_za3lpa$(2),2}})),Hi.prototype.release=function(){this.close()},Hi.prototype.prepareWriteHead_za3lpa$=function(t){var e;return(this.tailEndExclusive_8be2vx$-this.tailPosition_8be2vx$|0)>=t&&null!=(e=this._tail_hhwkug$_0)?(e.commitWrittenUntilIndex_za3lpa$(this.tailPosition_8be2vx$),e):this.appendNewChunk_oskcze$_0()},Hi.prototype.afterHeadWrite=function(){var t;null!=(t=this._tail_hhwkug$_0)&&(this.tailPosition_8be2vx$=t.writePosition)},Hi.prototype.write_rtdvbs$=w("ktor-ktor-io.io.ktor.utils.io.core.AbstractOutput.write_rtdvbs$",x((function(){var t=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,n){var i=this.prepareWriteHead_za3lpa$(e);try{if(!(n(i)>=0))throw t("The returned value shouldn't be negative".toString())}finally{this.afterHeadWrite()}}}))),Hi.prototype.addSize_za3lpa$=function(t){if(!(t>=0))throw B(("It should be non-negative size increment: "+t).toString());if(!(t<=(this.tailEndExclusive_8be2vx$-this.tailPosition_8be2vx$|0))){var e="Unable to mark more bytes than available: "+t+" > "+(this.tailEndExclusive_8be2vx$-this.tailPosition_8be2vx$|0);throw B(e.toString())}this.tailPosition_8be2vx$=this.tailPosition_8be2vx$+t|0},Hi.prototype.last_99qa0s$=function(t){var n;this.appendSingleChunk_pvnryh$(e.isType(n=t,bl)?n:c())},Hi.prototype.appendNewBuffer=function(){var t;return e.isType(t=this.appendNewChunk_oskcze$_0(),Hp)?t:c()},Hi.prototype.reset=function(){},Hi.$metadata$={kind:p,simpleName:"AbstractOutput",interfaces:[dh,q]},Object.defineProperty(Vi.prototype,"readPosition",{get:function(){return this.readPosition_osecaz$_0},set:function(t){this.readPosition_osecaz$_0=t}}),Object.defineProperty(Vi.prototype,"writePosition",{get:function(){return this.writePosition_oj9ite$_0},set:function(t){this.writePosition_oj9ite$_0=t}}),Object.defineProperty(Vi.prototype,"startGap",{get:function(){return this.startGap_cakrhy$_0},set:function(t){this.startGap_cakrhy$_0=t}}),Object.defineProperty(Vi.prototype,"limit",{get:function(){return this.limit_uf38zz$_0},set:function(t){this.limit_uf38zz$_0=t}}),Object.defineProperty(Vi.prototype,"endGap",{get:w("ktor-ktor-io.io.ktor.utils.io.core.Buffer.get_endGap",(function(){return this.capacity-this.limit|0}))}),Object.defineProperty(Vi.prototype,"readRemaining",{get:w("ktor-ktor-io.io.ktor.utils.io.core.Buffer.get_readRemaining",(function(){return this.writePosition-this.readPosition|0}))}),Object.defineProperty(Vi.prototype,"writeRemaining",{get:w("ktor-ktor-io.io.ktor.utils.io.core.Buffer.get_writeRemaining",(function(){return this.limit-this.writePosition|0}))}),Vi.prototype.discardExact_za3lpa$=function(t){if(void 0===t&&(t=this.writePosition-this.readPosition|0),0!==t){var e=this.readPosition+t|0;(t<0||e>this.writePosition)&&nr(t,this.writePosition-this.readPosition|0),this.readPosition=e}},Vi.prototype.discard_za3lpa$=function(t){var e=this.writePosition-this.readPosition|0,n=g.min(t,e);return this.discardExact_za3lpa$(n),n},Vi.prototype.discard_s8cxhz$=function(t){var n=e.Long.fromInt(this.writePosition-this.readPosition|0),i=(t.compareTo_11rb$(n)<=0?t:n).toInt();return this.discardExact_za3lpa$(i),e.Long.fromInt(i)},Vi.prototype.commitWritten_za3lpa$=function(t){var e=this.writePosition+t|0;(t<0||e>this.limit)&&ir(t,this.limit-this.writePosition|0),this.writePosition=e},Vi.prototype.commitWrittenUntilIndex_za3lpa$=function(t){var e=this.limit;if(t=e){if(t===e)return this.writePosition=t,!1;ir(t-this.writePosition|0,this.limit-this.writePosition|0)}return this.writePosition=t,!0},Vi.prototype.discardUntilIndex_kcn2v3$=function(t){(t<0||t>this.writePosition)&&nr(t-this.readPosition|0,this.writePosition-this.readPosition|0),this.readPosition!==t&&(this.readPosition=t)},Vi.prototype.rewind_za3lpa$=function(t){void 0===t&&(t=this.readPosition-this.startGap|0);var e=this.readPosition-t|0;e=0))throw b(("startGap shouldn't be negative: "+t).toString());if(!(this.readPosition>=t))return this.readPosition===this.writePosition?(t>this.limit&&or(this,t),this.writePosition=t,this.readPosition=t,void(this.startGap=t)):void ar(this,t);this.startGap=t},Vi.prototype.reserveEndGap_za3lpa$=function(t){if(!(t>=0))throw b(("endGap shouldn't be negative: "+t).toString());var e=this.capacity-t|0;if(e>=this.writePosition)this.limit=e;else{if(e<0&&sr(this,t),e=0))throw b(("newReadPosition shouldn't be negative: "+t).toString());if(!(t<=this.readPosition)){var e="newReadPosition shouldn't be ahead of the read position: "+t+" > "+this.readPosition;throw b(e.toString())}this.readPosition=t,this.startGap>t&&(this.startGap=t)},Vi.prototype.duplicateTo_b4g5fm$=function(t){t.limit=this.limit,t.startGap=this.startGap,t.readPosition=this.readPosition,t.writePosition=this.writePosition},Vi.prototype.duplicate=function(){var t=new Vi(this.memory);return t.duplicateTo_b4g5fm$(t),t},Vi.prototype.tryPeekByte=function(){var t=this.readPosition;return t===this.writePosition?-1:255&this.memory.view.getInt8(t)},Vi.prototype.tryReadByte=function(){var t=this.readPosition;return t===this.writePosition?-1:(this.readPosition=t+1|0,255&this.memory.view.getInt8(t))},Vi.prototype.readByte=function(){var t=this.readPosition;if(t===this.writePosition)throw new Th("No readable bytes available.");return this.readPosition=t+1|0,this.memory.view.getInt8(t)},Vi.prototype.writeByte_s8j3t7$=function(t){var e=this.writePosition;if(e===this.limit)throw new pr("No free space in the buffer to write a byte");this.memory.view.setInt8(e,t),this.writePosition=e+1|0},Vi.prototype.reset=function(){this.releaseGaps_8be2vx$(),this.resetForWrite()},Vi.prototype.toString=function(){return"Buffer("+(this.writePosition-this.readPosition|0)+" used, "+(this.limit-this.writePosition|0)+" free, "+(this.startGap+(this.capacity-this.limit|0)|0)+" reserved of "+this.capacity+")"},Object.defineProperty(Ki.prototype,"Empty",{get:function(){return Qp().Empty}}),Ki.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Wi=null;function Xi(){return null===Wi&&new Ki,Wi}Vi.$metadata$={kind:p,simpleName:"Buffer",interfaces:[]};var Zi,Ji=w("ktor-ktor-io.io.ktor.utils.io.core.canRead_abnlgx$",(function(t){return t.writePosition>t.readPosition})),Qi=w("ktor-ktor-io.io.ktor.utils.io.core.canWrite_abnlgx$",(function(t){return t.limit>t.writePosition})),tr=w("ktor-ktor-io.io.ktor.utils.io.core.read_kmyesx$",(function(t,e){var n=e(t.memory,t.readPosition,t.writePosition);return t.discardExact_za3lpa$(n),n})),er=w("ktor-ktor-io.io.ktor.utils.io.core.write_kmyesx$",(function(t,e){var n=e(t.memory,t.writePosition,t.limit);return t.commitWritten_za3lpa$(n),n}));function nr(t,e){throw new Th("Unable to discard "+t+" bytes: only "+e+" available for reading")}function ir(t,e){throw new Th("Unable to discard "+t+" bytes: only "+e+" available for writing")}function rr(t,e){throw b("Unable to rewind "+t+" bytes: only "+e+" could be rewinded")}function or(t,e){if(e>t.capacity)throw b("Start gap "+e+" is bigger than the capacity "+t.capacity);throw B("Unable to reserve "+e+" start gap: there are already "+(t.capacity-t.limit|0)+" bytes reserved in the end")}function ar(t,e){throw B("Unable to reserve "+e+" start gap: there are already "+(t.writePosition-t.readPosition|0)+" content bytes starting at offset "+t.readPosition)}function sr(t,e){throw b("End gap "+e+" is too big: capacity is "+t.capacity)}function lr(t,e){throw b("End gap "+e+" is too big: there are already "+t.startGap+" bytes reserved in the beginning")}function ur(t,e){throw b("Unable to reserve end gap "+e+": there are already "+(t.writePosition-t.readPosition|0)+" content bytes at offset "+t.readPosition)}function cr(t,e){t.releaseStartGap_kcn2v3$(t.readPosition-e|0)}function pr(t){void 0===t&&(t="Not enough free space"),W(t,this),this.name="InsufficientSpaceException"}function hr(t,e,n,i){return i=i||Object.create(pr.prototype),pr.call(i,"Not enough free space to write "+t+" of "+e+" bytes, available "+n+" bytes."),i}function _r(t,e,n){var i=e.writePosition-e.readPosition|0,r=g.min(i,n);(t.limit-t.writePosition|0)<=r&&function(t,e){if(((t.limit-t.writePosition|0)+(t.capacity-t.limit|0)|0)0&&t.releaseEndGap_8be2vx$()}(t,r),e.memory.copyTo_ubllm2$(t.memory,e.readPosition,r,t.writePosition);var o=r;e.discardExact_za3lpa$(o);var a=o;return t.commitWritten_za3lpa$(a),a}function fr(t,e){var n=e.writePosition-e.readPosition|0,i=t.readPosition;if(i=0||new dr((i=e,function(){return"times shouldn't be negative: "+i})).doFail(),e<=(t.limit-t.writePosition|0)||new dr(function(t,e){return function(){var n=e;return"times shouldn't be greater than the write remaining space: "+t+" > "+(n.limit-n.writePosition|0)}}(e,t)).doFail(),uc(t.memory,t.writePosition,e,n),t.commitWritten_za3lpa$(e)}function yr(t,e,n){e.toNumber()>=2147483647&&Ll(e,"n"),mr(t,e.toInt(),n)}function $r(t,e,n,i){return vr(t,new Hl(e,0,e.length),n,i)}function vr(t,e,n,i){var r={v:null},o=Kl(t.memory,e,n,i,t.writePosition,t.limit);r.v=65535&new I(k(o.value>>>16)).data;var a=65535&new I(k(65535&o.value)).data;return t.commitWritten_za3lpa$(a),n+r.v|0}function gr(t,e){var n,i=t.memory,r=t.writePosition,o=t.limit,a=0|e;0<=a&&a<=127?(i.view.setInt8(r,d(a)),n=1):128<=a&&a<=2047?(i.view.setInt8(r,d(192|a>>6&31)),i.view.setInt8(r+1|0,d(128|63&a)),n=2):2048<=a&&a<=65535?(i.view.setInt8(r,d(224|a>>12&15)),i.view.setInt8(r+1|0,d(128|a>>6&63)),i.view.setInt8(r+2|0,d(128|63&a)),n=3):65536<=a&&a<=1114111?(i.view.setInt8(r,d(240|a>>18&7)),i.view.setInt8(r+1|0,d(128|a>>12&63)),i.view.setInt8(r+2|0,d(128|a>>6&63)),i.view.setInt8(r+3|0,d(128|63&a)),n=4):n=Jl(a);var s=n,l=s>(o-r|0)?wr(1):s;return t.commitWritten_za3lpa$(l),t}function br(t,e,n,i){return null==e?br(t,"null",n,i):(vr(t,e,n,i)!==i&&wr(i-n|0),t)}function wr(t){throw new Vo("Not enough free space available to write "+t+" character(s).")}pr.$metadata$={kind:p,simpleName:"InsufficientSpaceException",interfaces:[X]},dr.prototype=Object.create(Il.prototype),dr.prototype.constructor=dr,dr.prototype.doFail=function(){throw b(this.closure$message())},dr.$metadata$={kind:p,interfaces:[Il]};var xr,kr=w("ktor-ktor-io.io.ktor.utils.io.core.withBuffer_3o3i6e$",x((function(){var e=t.io.ktor.utils.io.bits,n=t.io.ktor.utils.io.core.Buffer;return function(t,i){return i(new n(e.DefaultAllocator.alloc_za3lpa$(t)))}}))),Er=w("ktor-ktor-io.io.ktor.utils.io.core.withBuffer_75fp88$",(function(t,e){var n,i=t.borrow();try{n=e(i)}finally{t.recycle_trkh7z$(i)}return n})),Cr=w("ktor-ktor-io.io.ktor.utils.io.core.withChunkBuffer_24tmir$",(function(t,e){var n,i=t.borrow();try{n=e(i)}finally{i.release_2bs5fo$(t)}return n}));function Sr(t,e,n){void 0===t&&(t=4096),void 0===e&&(e=1e3),void 0===n&&(n=ic()),Mh.call(this,e),this.bufferSize_0=t,this.allocator_0=n}function Tr(t){this.closure$message=t,Il.call(this)}function Or(t,e){return function(){throw new Th("Not enough bytes to read a "+t+" of size "+e+".")}}function Nr(t){this.closure$message=t,Il.call(this)}Sr.prototype.produceInstance=function(){return new Hp(this.allocator_0.alloc_za3lpa$(this.bufferSize_0),null)},Sr.prototype.disposeInstance_trkh7z$=function(t){this.allocator_0.free_vn6nzs$(t.memory),Mh.prototype.disposeInstance_trkh7z$.call(this,t),t.unlink_8be2vx$()},Sr.prototype.validateInstance_trkh7z$=function(t){if(Mh.prototype.validateInstance_trkh7z$.call(this,t),t===Qp().Empty)throw B("IoBuffer.Empty couldn't be recycled".toString());if(t===Qp().Empty)throw B("Empty instance couldn't be recycled".toString());if(t===Xi().Empty)throw B("Empty instance couldn't be recycled".toString());if(t===Nl().Empty)throw B("Empty instance couldn't be recycled".toString());if(0!==t.referenceCount)throw B("Unable to clear buffer: it is still in use.".toString());if(null!=t.next)throw B("Recycled instance shouldn't be a part of a chain.".toString());if(null!=t.origin)throw B("Recycled instance shouldn't be a view or another buffer.".toString())},Sr.prototype.clearInstance_trkh7z$=function(t){var e=Mh.prototype.clearInstance_trkh7z$.call(this,t);return e.unpark_8be2vx$(),e.reset(),e},Sr.$metadata$={kind:p,simpleName:"DefaultBufferPool",interfaces:[Mh]},Tr.prototype=Object.create(Il.prototype),Tr.prototype.constructor=Tr,Tr.prototype.doFail=function(){throw b(this.closure$message())},Tr.$metadata$={kind:p,interfaces:[Il]},Nr.prototype=Object.create(Il.prototype),Nr.prototype.constructor=Nr,Nr.prototype.doFail=function(){throw b(this.closure$message())},Nr.$metadata$={kind:p,interfaces:[Il]};var Pr=w("ktor-ktor-io.io.ktor.utils.io.core.forEach_13x7pp$",(function(t,e){for(var n=t.memory,i=t.readPosition,r=t.writePosition,o=i;o=2||new Tr(Or("short integer",2)).doFail(),e.v=n.view.getInt16(i,!1);return t.discardExact_za3lpa$(2),e.v}var Rr=w("ktor-ktor-io.io.ktor.utils.io.core.readShort_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readShort_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));var Ir=w("ktor-ktor-io.io.ktor.utils.io.core.readUShort_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readUShort_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));function zr(t){var e={v:null},n=t.memory,i=t.readPosition;(t.writePosition-i|0)>=4||new Tr(Or("regular integer",4)).doFail(),e.v=n.view.getInt32(i,!1);return t.discardExact_za3lpa$(4),e.v}var Dr=w("ktor-ktor-io.io.ktor.utils.io.core.readInt_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readInt_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));var Mr=w("ktor-ktor-io.io.ktor.utils.io.core.readUInt_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readUInt_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));function Br(t){var n={v:null},i=t.memory,r=t.readPosition;(t.writePosition-r|0)>=8||new Tr(Or("long integer",8)).doFail();var o=i,a=r;n.v=e.Long.fromInt(o.view.getUint32(a,!1)).shiftLeft(32).or(e.Long.fromInt(o.view.getUint32(a+4|0,!1)));return t.discardExact_za3lpa$(8),n.v}var Ur=w("ktor-ktor-io.io.ktor.utils.io.core.readLong_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readLong_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));var Fr=w("ktor-ktor-io.io.ktor.utils.io.core.readULong_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readULong_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));function qr(t){var e={v:null},n=t.memory,i=t.readPosition;(t.writePosition-i|0)>=4||new Tr(Or("floating point number",4)).doFail(),e.v=n.view.getFloat32(i,!1);return t.discardExact_za3lpa$(4),e.v}var Gr=w("ktor-ktor-io.io.ktor.utils.io.core.readFloat_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readFloat_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));function Hr(t){var e={v:null},n=t.memory,i=t.readPosition;(t.writePosition-i|0)>=8||new Tr(Or("long floating point number",8)).doFail(),e.v=n.view.getFloat64(i,!1);return t.discardExact_za3lpa$(8),e.v}var Yr=w("ktor-ktor-io.io.ktor.utils.io.core.readDouble_396eqd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readDouble_abnlgx$;return function(t){var o;return r(e.isType(o=t,n)?o:i())}})));function Vr(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<2)throw hr("short integer",2,r);n.view.setInt16(i,e,!1);t.commitWritten_za3lpa$(2)}var Kr=w("ktor-ktor-io.io.ktor.utils.io.core.writeShort_89txly$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeShort_cx5lgg$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));var Wr=w("ktor-ktor-io.io.ktor.utils.io.core.writeUShort_sa3b8p$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeUShort_q99vxf$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));function Xr(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<4)throw hr("regular integer",4,r);n.view.setInt32(i,e,!1);t.commitWritten_za3lpa$(4)}var Zr=w("ktor-ktor-io.io.ktor.utils.io.core.writeInt_q5mzkd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeInt_cni1rh$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));var Jr=w("ktor-ktor-io.io.ktor.utils.io.core.writeUInt_tiqx5o$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeUInt_xybpjq$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));function Qr(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<8)throw hr("long integer",8,r);var o=n,a=i;o.view.setInt32(a,e.shiftRight(32).toInt(),!1),o.view.setInt32(a+4|0,e.and(J).toInt(),!1);t.commitWritten_za3lpa$(8)}var to=w("ktor-ktor-io.io.ktor.utils.io.core.writeLong_tilyfy$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeLong_xy6qu0$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));var eo=w("ktor-ktor-io.io.ktor.utils.io.core.writeULong_89885t$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeULong_cwjw0b$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));function no(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<4)throw hr("floating point number",4,r);n.view.setFloat32(i,e,!1);t.commitWritten_za3lpa$(4)}var io=w("ktor-ktor-io.io.ktor.utils.io.core.writeFloat_8gwps6$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeFloat_d48dmo$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));function ro(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<8)throw hr("long floating point number",8,r);n.view.setFloat64(i,e,!1);t.commitWritten_za3lpa$(8)}var oo=w("ktor-ktor-io.io.ktor.utils.io.core.writeDouble_kny06r$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.writeDouble_in4kvh$;return function(t,o){var a;r(e.isType(a=t,n)?a:i(),o)}})));function ao(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:null},o=t.memory,a=t.readPosition;(t.writePosition-a|0)>=i||new Tr(Or("byte array",i)).doFail(),lc(o,e,a,i,n),r.v=h;var s=i;t.discardExact_za3lpa$(s),r.v}var so=w("ktor-ktor-io.io.ktor.utils.io.core.readFully_ou1upd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readFully_7ntqvp$;return function(t,o,a,s){var l;void 0===a&&(a=0),void 0===s&&(s=o.length-a|0),r(e.isType(l=t,n)?l:i(),o,a,s)}})));function lo(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=t.writePosition-t.readPosition|0,s=g.min(i,a);return ao(t,e,n,s),s}var uo=w("ktor-ktor-io.io.ktor.utils.io.core.readAvailable_ou1upd$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.readAvailable_7ntqvp$;return function(t,o,a,s){var l;return void 0===a&&(a=0),void 0===s&&(s=o.length-a|0),r(e.isType(l=t,n)?l:i(),o,a,s)}})));function co(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=t.memory,o=t.writePosition,a=t.limit-o|0;if(a=r||new Tr(Or("short integers array",r)).doFail(),Rc(a,s,e,n,i),o.v=h;var l=r;t.discardExact_za3lpa$(l),o.v}function _o(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=i/2|0,s=t.writePosition-t.readPosition|0,l=g.min(a,s);return ho(t,e,n,l),l}function fo(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=2*i|0,o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s=r||new Tr(Or("integers array",r)).doFail(),Ic(a,s,e,n,i),o.v=h;var l=r;t.discardExact_za3lpa$(l),o.v}function yo(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=i/4|0,s=t.writePosition-t.readPosition|0,l=g.min(a,s);return mo(t,e,n,l),l}function $o(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=4*i|0,o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s=r||new Tr(Or("long integers array",r)).doFail(),zc(a,s,e,n,i),o.v=h;var l=r;t.discardExact_za3lpa$(l),o.v}function go(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=i/8|0,s=t.writePosition-t.readPosition|0,l=g.min(a,s);return vo(t,e,n,l),l}function bo(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=8*i|0,o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s=r||new Tr(Or("floating point numbers array",r)).doFail(),Dc(a,s,e,n,i),o.v=h;var l=r;t.discardExact_za3lpa$(l),o.v}function xo(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=i/4|0,s=t.writePosition-t.readPosition|0,l=g.min(a,s);return wo(t,e,n,l),l}function ko(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=4*i|0,o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s=r||new Tr(Or("floating point numbers array",r)).doFail(),Mc(a,s,e,n,i),o.v=h;var l=r;t.discardExact_za3lpa$(l),o.v}function Co(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),n>=0||new Nr((o=n,function(){return"offset shouldn't be negative: "+o})).doFail(),i>=0||new Nr((r=i,function(){return"length shouldn't be negative: "+r})).doFail(),(n+i|0)<=e.length||new Nr(function(t,e,n){return function(){return"offset + length should be less than the destination size: "+t+" + "+e+" > "+n.length}}(n,i,e)).doFail(),!(t.writePosition>t.readPosition))return-1;var r,o,a=i/8|0,s=t.writePosition-t.readPosition|0,l=g.min(a,s);return Eo(t,e,n,l),l}function So(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=8*i|0,o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s=0))throw b("Failed requirement.".toString());if(!(n<=(e.limit-e.writePosition|0)))throw b("Failed requirement.".toString());var i={v:null},r=t.memory,o=t.readPosition;(t.writePosition-o|0)>=n||new Tr(Or("buffer content",n)).doFail(),r.copyTo_ubllm2$(e.memory,o,n,e.writePosition),e.commitWritten_za3lpa$(n),i.v=h;var a=n;return t.discardExact_za3lpa$(a),i.v,n}function Oo(t,e,n){if(void 0===n&&(n=e.limit-e.writePosition|0),!(t.writePosition>t.readPosition))return-1;var i=e.limit-e.writePosition|0,r=t.writePosition-t.readPosition|0,o=g.min(i,r,n),a={v:null},s=t.memory,l=t.readPosition;(t.writePosition-l|0)>=o||new Tr(Or("buffer content",o)).doFail(),s.copyTo_ubllm2$(e.memory,l,o,e.writePosition),e.commitWritten_za3lpa$(o),a.v=h;var u=o;return t.discardExact_za3lpa$(u),a.v,o}function No(t,e,n){var i;n>=0||new Nr((i=n,function(){return"length shouldn't be negative: "+i})).doFail(),n<=(e.writePosition-e.readPosition|0)||new Nr(function(t,e){return function(){var n=e;return"length shouldn't be greater than the source read remaining: "+t+" > "+(n.writePosition-n.readPosition|0)}}(n,e)).doFail(),n<=(t.limit-t.writePosition|0)||new Nr(function(t,e){return function(){var n=e;return"length shouldn't be greater than the destination write remaining space: "+t+" > "+(n.limit-n.writePosition|0)}}(n,t)).doFail();var r=t.memory,o=t.writePosition,a=t.limit-o|0;if(a=t,c=l(e,t);return u||new o(c).doFail(),i.v=n(r,a),t}}})),function(t,e,n,i){var r={v:null},o=t.memory,a=t.readPosition;(t.writePosition-a|0)>=e||new s(l(n,e)).doFail(),r.v=i(o,a);var u=e;return t.discardExact_za3lpa$(u),r.v}}))),Ao=w("ktor-ktor-io.io.ktor.utils.io.core.writeExact_n5pafo$",x((function(){var e=t.io.ktor.utils.io.core.InsufficientSpaceException_init_3m52m6$;return function(t,n,i,r){var o=t.memory,a=t.writePosition,s=t.limit-a|0;if(s0)throw n(i);return e.toInt()}})));function Yo(t,n,i,r,o,a){var s=e.Long.fromInt(n.view.byteLength).subtract(i),l=e.Long.fromInt(t.writePosition-t.readPosition|0),u=a.compareTo_11rb$(l)<=0?a:l,c=s.compareTo_11rb$(u)<=0?s:u;return t.memory.copyTo_q2ka7j$(n,e.Long.fromInt(t.readPosition).add(r),c,i),c}function Vo(t){W(t,this),this.name="BufferLimitExceededException"}Vo.$metadata$={kind:p,simpleName:"BufferLimitExceededException",interfaces:[X]};var Ko=w("ktor-ktor-io.io.ktor.utils.io.core.buildPacket_1pjhv2$",x((function(){var n=t.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,i=Error;return function(t,r){void 0===t&&(t=0);var o=n(t);try{return r(o),o.build()}catch(t){throw e.isType(t,i)?(o.release(),t):t}}})));function Wo(t){Xo.call(this,t)}function Xo(t){Yi(t,this)}function Zo(t){this.closure$message=t,Il.call(this)}function Jo(t,e){var n;void 0===t&&(t=0),Wo.call(this,e),this.headerSizeHint_0=t,this.headerSizeHint_0>=0||new Zo((n=this,function(){return"shouldn't be negative: headerSizeHint = "+n.headerSizeHint_0})).doFail()}function Qo(t,e,n){na(),ra.call(this,t,e,n),this.markNoMoreChunksAvailable()}function ta(){ea=this,this.Empty=new Qo(Nl().Empty,u,Nl().EmptyPool)}Wo.$metadata$={kind:p,simpleName:"BytePacketBuilderPlatformBase",interfaces:[Xo]},Xo.$metadata$={kind:p,simpleName:"BytePacketBuilderBase",interfaces:[Hi]},Zo.prototype=Object.create(Il.prototype),Zo.prototype.constructor=Zo,Zo.prototype.doFail=function(){throw b(this.closure$message())},Zo.$metadata$={kind:p,interfaces:[Il]},Object.defineProperty(Jo.prototype,"size",{get:function(){return this._size}}),Object.defineProperty(Jo.prototype,"isEmpty",{get:function(){return 0===this._size}}),Object.defineProperty(Jo.prototype,"isNotEmpty",{get:function(){return this._size>0}}),Object.defineProperty(Jo.prototype,"_pool",{get:function(){return this.pool}}),Jo.prototype.closeDestination=function(){},Jo.prototype.flush_9etqdk$=function(t,e,n){},Jo.prototype.append_s8itvh$=function(t){var n;return e.isType(n=Wo.prototype.append_s8itvh$.call(this,t),Jo)?n:c()},Jo.prototype.append_gw00v9$=function(t){var n;return e.isType(n=Wo.prototype.append_gw00v9$.call(this,t),Jo)?n:c()},Jo.prototype.append_ezbsdh$=function(t,n,i){var r;return e.isType(r=Wo.prototype.append_ezbsdh$.call(this,t,n,i),Jo)?r:c()},Jo.prototype.appendOld_s8itvh$=function(t){return this.append_s8itvh$(t)},Jo.prototype.appendOld_gw00v9$=function(t){return this.append_gw00v9$(t)},Jo.prototype.appendOld_ezbsdh$=function(t,e,n){return this.append_ezbsdh$(t,e,n)},Jo.prototype.preview_chaoki$=function(t){var e,n=Ls(this);try{e=t(n)}finally{n.release()}return e},Jo.prototype.build=function(){var t=this.size,n=this.stealAll_8be2vx$();return null==n?na().Empty:new Qo(n,e.Long.fromInt(t),this.pool)},Jo.prototype.reset=function(){this.release()},Jo.prototype.preview=function(){return Ls(this)},Jo.prototype.toString=function(){return"BytePacketBuilder("+this.size+" bytes written)"},Jo.$metadata$={kind:p,simpleName:"BytePacketBuilder",interfaces:[Wo]},Qo.prototype.copy=function(){return new Qo(Mo(this.head),this.remaining,this.pool)},Qo.prototype.fill=function(){return null},Qo.prototype.fill_9etqdk$=function(t,e,n){return 0},Qo.prototype.closeSource=function(){},Qo.prototype.toString=function(){return"ByteReadPacket("+this.remaining.toString()+" bytes remaining)"},Object.defineProperty(ta.prototype,"ReservedSize",{get:function(){return 8}}),ta.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var ea=null;function na(){return null===ea&&new ta,ea}function ia(t,e,n){return n=n||Object.create(Qo.prototype),Qo.call(n,t,Fo(t),e),n}function ra(t,e,n){ks.call(this,t,e,n)}Qo.$metadata$={kind:p,simpleName:"ByteReadPacket",interfaces:[ra,Np]},ra.$metadata$={kind:p,simpleName:"ByteReadPacketPlatformBase",interfaces:[ks]};var oa=w("ktor-ktor-io.io.ktor.utils.io.core.ByteReadPacket_mj6st8$",x((function(){var n=e.kotlin.Unit,i=t.io.ktor.utils.io.core.ByteReadPacket_1qge3v$;function r(t){return n}return function(t,e,n){return void 0===e&&(e=0),void 0===n&&(n=t.length),i(t,e,n,r)}}))),aa=w("ktor-ktor-io.io.ktor.utils.io.core.use_jh8f9t$",x((function(){var n=t.io.ktor.utils.io.core.addSuppressedInternal_oh0dqn$,i=Error;return function(t,r){var o,a=!1;try{o=r(t)}catch(r){if(e.isType(r,i)){try{a=!0,t.close()}catch(t){if(!e.isType(t,i))throw t;n(r,t)}throw r}throw r}finally{a||t.close()}return o}})));function sa(){}function la(t,e){var n=t.discard_s8cxhz$(e);if(!_(n,e))throw B("Only "+n.toString()+" bytes were discarded of "+e.toString()+" requested")}function ua(t,n){la(t,e.Long.fromInt(n))}sa.$metadata$={kind:p,simpleName:"ExperimentalIoApi",interfaces:[Q]};var ca=w("ktor-ktor-io.io.ktor.utils.io.core.takeWhile_nkhzd2$",x((function(){var e=t.io.ktor.utils.io.core.internal.prepareReadFirstHead_j319xh$,n=t.io.ktor.utils.io.core.internal.prepareReadNextHead_x2nit9$,i=t.io.ktor.utils.io.core.internal.completeReadHead_x2nit9$;return function(t,r){var o,a,s=!0;if(null!=(o=e(t,1))){var l=o;try{for(;r(l)&&(s=!1,null!=(a=n(t,l)));)l=a,s=!0}finally{s&&i(t,l)}}}}))),pa=w("ktor-ktor-io.io.ktor.utils.io.core.takeWhileSize_y109dn$",x((function(){var e=t.io.ktor.utils.io.core.internal.prepareReadFirstHead_j319xh$,n=t.io.ktor.utils.io.core.internal.prepareReadNextHead_x2nit9$,i=t.io.ktor.utils.io.core.internal.completeReadHead_x2nit9$;return function(t,r,o){var a,s;void 0===r&&(r=1);var l=!0;if(null!=(a=e(t,r))){var u=a,c=r;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{c=o(u)}finally{var f=u;p=f.writePosition-f.readPosition|0}else p=_;if(l=!1,0===p)s=n(t,u);else{var d=p0)}finally{l&&i(t,u)}}}})));var ha=w("ktor-ktor-io.io.ktor.utils.io.core.forEach_xalon3$",x((function(){var e=t.io.ktor.utils.io.core.internal.prepareReadFirstHead_j319xh$,n=t.io.ktor.utils.io.core.internal.prepareReadNextHead_x2nit9$,i=t.io.ktor.utils.io.core.internal.completeReadHead_x2nit9$;return function(t,r){t:do{var o,a,s=!0;if(null==(o=e(t,1)))break t;var l=o;try{for(;;){for(var u=l,c=u.memory,p=u.readPosition,h=u.writePosition,_=p;_0))break;if(l=!1,null==(s=uu(t,u)))break;u=s,l=!0}}finally{l&&lu(t,u)}}while(0);var f=r.v;f>0&&tl(f)}function fa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/2|0,y=g.min(d,m);ho(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?2:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);var x=r.v;x>0&&tl(x)}function da(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/4|0,y=g.min(d,m);mo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?4:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);var x=r.v;x>0&&tl(x)}function ma(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/8|0,y=g.min(d,m);vo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?8:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);var x=r.v;x>0&&tl(x)}function ya(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/4|0,y=g.min(d,m);wo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?4:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);var x=r.v;x>0&&tl(x)}function $a(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/8|0,y=g.min(d,m);Eo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?8:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);var x=r.v;x>0&&tl(x)}function va(t,e,n){void 0===n&&(n=e.limit-e.writePosition|0);var i={v:n},r={v:0};t:do{var o,a,s=!0;if(null==(o=su(t,1)))break t;var l=o;try{for(;;){var u=l,c=i.v,p=u.writePosition-u.readPosition|0,h=g.min(c,p);if(To(u,e,h),i.v=i.v-h|0,r.v=r.v+h|0,!(i.v>0))break;if(s=!1,null==(a=uu(t,l)))break;l=a,s=!0}}finally{s&&lu(t,l)}}while(0);var _=i.v;_>0&&tl(_)}function ga(t,e,n,i){_(Ta(t,e,n,i),i)||el(i)}function ba(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a;try{for(;;){var c=u,p=r.v,h=c.writePosition-c.readPosition|0,_=g.min(p,h);if(ao(c,e,o.v,_),r.v=r.v-_|0,o.v=o.v+_|0,!(r.v>0))break;if(l=!1,null==(s=uu(t,u)))break;u=s,l=!0}}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function wa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/2|0,y=g.min(d,m);ho(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?2:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function xa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/4|0,y=g.min(d,m);mo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?4:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function ka(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/8|0,y=g.min(d,m);vo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?8:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function Ea(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/4|0,y=g.min(d,m);wo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?4:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function Ca(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:i},o={v:n};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a,c=1;try{do{var p,h=u,_=h.writePosition-h.readPosition|0;if(_>=c)try{var f=u,d=r.v,m=(f.writePosition-f.readPosition|0)/8|0,y=g.min(d,m);Eo(f,e,o.v,y),r.v=r.v-y|0,o.v=o.v+y|0,c=r.v>0?8:0}finally{var $=u;p=$.writePosition-$.readPosition|0}else p=_;if(l=!1,0===p)s=uu(t,u);else{var v=p0)}finally{l&&lu(t,u)}}while(0);return i-r.v|0}function Sa(t,e,n){void 0===n&&(n=e.limit-e.writePosition|0);var i={v:n},r={v:0};t:do{var o,a,s=!0;if(null==(o=su(t,1)))break t;var l=o;try{for(;;){var u=l,c=i.v,p=u.writePosition-u.readPosition|0,h=g.min(c,p);if(To(u,e,h),i.v=i.v-h|0,r.v=r.v+h|0,!(i.v>0))break;if(s=!1,null==(a=uu(t,l)))break;l=a,s=!0}}finally{s&&lu(t,l)}}while(0);return n-i.v|0}function Ta(t,n,i,r){var o={v:r},a={v:i};t:do{var s,l,c=!0;if(null==(s=su(t,1)))break t;var p=s;try{for(;;){var h=p,f=o.v,d=e.Long.fromInt(h.writePosition-h.readPosition|0),m=(f.compareTo_11rb$(d)<=0?f:d).toInt(),y=h.memory,$=e.Long.fromInt(h.readPosition),v=a.v;if(y.copyTo_q2ka7j$(n,$,e.Long.fromInt(m),v),h.discardExact_za3lpa$(m),o.v=o.v.subtract(e.Long.fromInt(m)),a.v=a.v.add(e.Long.fromInt(m)),!(o.v.toNumber()>0))break;if(c=!1,null==(l=uu(t,p)))break;p=l,c=!0}}finally{c&&lu(t,p)}}while(0);var g=o.v,b=r.subtract(g);return _(b,u)&&t.endOfInput?tt:b}function Oa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),fa(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Hu(e[o])}function Na(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),da(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Yu(e[o])}function Pa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ma(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Vu(e[o])}function Aa(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=wa(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Hu(e[a]);return r}function ja(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=xa(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Yu(e[a]);return r}function La(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=ka(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Vu(e[a]);return r}function Ra(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ho(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Hu(e[o])}function Ia(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),mo(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Yu(e[o])}function za(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),vo(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Vu(e[o])}function Da(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);for(var r=_o(t,e,n,i),o=n+r-1|0,a=n;a<=o;a++)e[a]=Hu(e[a]);return r}function Ma(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);for(var r=yo(t,e,n,i),o=n+r-1|0,a=n;a<=o;a++)e[a]=Yu(e[a]);return r}function Ba(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=go(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Vu(e[a]);return r}function Ua(t,n,i,r,o){void 0===i&&(i=0),void 0===r&&(r=1),void 0===o&&(o=2147483647),_u(n,i,r,o);var a=t.peekTo_afjyek$(n.memory,e.Long.fromInt(n.writePosition),e.Long.fromInt(i),e.Long.fromInt(r),e.Long.fromInt(L(o,n.limit-n.writePosition|0))).toInt();return n.commitWritten_za3lpa$(a),a}function Fa(t){var n;t:do{var i=e.isType(t,Mi);if(i&&(i=(t.headEndExclusive-t.headPosition|0)>2),i){var r=t.headPosition;t.headPosition=r+2|0,n=t.headMemory.view.getInt16(r,!1);break t}n=qa(t)}while(0);return n}function qa(t){var e,n=null!=(e=su(t,2))?e:tl(2),i=Lr(n);return lu(t,n),i}function Ga(t){var n;t:do{var i=e.isType(t,Mi);if(i&&(i=(t.headEndExclusive-t.headPosition|0)>4),i){var r=t.headPosition;t.headPosition=r+4|0,n=t.headMemory.view.getInt32(r,!1);break t}n=Ha(t)}while(0);return n}function Ha(t){var e,n=null!=(e=su(t,4))?e:tl(4),i=zr(n);return lu(t,n),i}function Ya(t){var n;t:do{var i=e.isType(t,Mi);if(i&&(i=(t.headEndExclusive-t.headPosition|0)>8),i){var r=t.headPosition;t.headPosition=r+8|0;var o=t.headMemory;n=e.Long.fromInt(o.view.getUint32(r,!1)).shiftLeft(32).or(e.Long.fromInt(o.view.getUint32(r+4|0,!1)));break t}n=Va(t)}while(0);return n}function Va(t){var e,n=null!=(e=su(t,8))?e:tl(8),i=Br(n);return lu(t,n),i}function Ka(t){var n;t:do{var i=e.isType(t,Mi);if(i&&(i=(t.headEndExclusive-t.headPosition|0)>4),i){var r=t.headPosition;t.headPosition=r+4|0,n=t.headMemory.view.getFloat32(r,!1);break t}n=Wa(t)}while(0);return n}function Wa(t){var e,n=null!=(e=su(t,4))?e:tl(4),i=qr(n);return lu(t,n),i}function Xa(t){var n;t:do{var i=e.isType(t,Mi);if(i&&(i=(t.headEndExclusive-t.headPosition|0)>8),i){var r=t.headPosition;t.headPosition=r+8|0,n=t.headMemory.view.getFloat64(r,!1);break t}n=Za(t)}while(0);return n}function Za(t){var e,n=null!=(e=su(t,8))?e:tl(8),i=Hr(n);return lu(t,n),i}function Ja(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r={v:n},o={v:i},a=cu(t,1,null);try{for(;;){var s=a,l=o.v,u=s.limit-s.writePosition|0,c=g.min(l,u);if(co(s,e,r.v,c),r.v=r.v+c|0,o.v=o.v-c|0,!(o.v>0))break;a=cu(t,1,a)}}finally{pu(t,a)}}function Qa(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o={v:i},a={v:r},s=cu(t,2,null);try{for(var l;;){var u=s,c=a.v,p=u.limit-u.writePosition|0,h=g.min(c,p);if(fo(u,n,o.v,h),o.v=o.v+h|0,a.v=a.v-h|0,(l=e.imul(a.v,2))<=0)break;s=cu(t,l,s)}}finally{pu(t,s)}}function ts(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o={v:i},a={v:r},s=cu(t,4,null);try{for(var l;;){var u=s,c=a.v,p=u.limit-u.writePosition|0,h=g.min(c,p);if($o(u,n,o.v,h),o.v=o.v+h|0,a.v=a.v-h|0,(l=e.imul(a.v,4))<=0)break;s=cu(t,l,s)}}finally{pu(t,s)}}function es(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o={v:i},a={v:r},s=cu(t,8,null);try{for(var l;;){var u=s,c=a.v,p=u.limit-u.writePosition|0,h=g.min(c,p);if(bo(u,n,o.v,h),o.v=o.v+h|0,a.v=a.v-h|0,(l=e.imul(a.v,8))<=0)break;s=cu(t,l,s)}}finally{pu(t,s)}}function ns(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o={v:i},a={v:r},s=cu(t,4,null);try{for(var l;;){var u=s,c=a.v,p=u.limit-u.writePosition|0,h=g.min(c,p);if(ko(u,n,o.v,h),o.v=o.v+h|0,a.v=a.v-h|0,(l=e.imul(a.v,4))<=0)break;s=cu(t,l,s)}}finally{pu(t,s)}}function is(t,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o={v:i},a={v:r},s=cu(t,8,null);try{for(var l;;){var u=s,c=a.v,p=u.limit-u.writePosition|0,h=g.min(c,p);if(So(u,n,o.v,h),o.v=o.v+h|0,a.v=a.v-h|0,(l=e.imul(a.v,8))<=0)break;s=cu(t,l,s)}}finally{pu(t,s)}}function rs(t,e,n){void 0===n&&(n=e.writePosition-e.readPosition|0);var i={v:0},r={v:n},o=cu(t,1,null);try{for(;;){var a=o,s=r.v,l=a.limit-a.writePosition|0,u=g.min(s,l);if(No(a,e,u),i.v=i.v+u|0,r.v=r.v-u|0,!(r.v>0))break;o=cu(t,1,o)}}finally{pu(t,o)}}function os(t,n,i,r){var o={v:i},a={v:r},s=cu(t,1,null);try{for(;;){var l=s,u=a.v,c=e.Long.fromInt(l.limit-l.writePosition|0),p=u.compareTo_11rb$(c)<=0?u:c;if(n.copyTo_q2ka7j$(l.memory,o.v,p,e.Long.fromInt(l.writePosition)),l.commitWritten_za3lpa$(p.toInt()),o.v=o.v.add(p),a.v=a.v.subtract(p),!(a.v.toNumber()>0))break;s=cu(t,1,s)}}finally{pu(t,s)}}function as(t,n,i){if(void 0===i&&(i=0),e.isType(t,Hi)){var r={v:u},o=cu(t,1,null);try{for(;;){var a=o,s=e.Long.fromInt(a.limit-a.writePosition|0),l=n.subtract(r.v),c=(s.compareTo_11rb$(l)<=0?s:l).toInt();if(mr(a,c,i),r.v=r.v.add(e.Long.fromInt(c)),!(r.v.compareTo_11rb$(n)<0))break;o=cu(t,1,o)}}finally{pu(t,o)}}else!function(t,e,n){var i;for(i=et(0,e).iterator();i.hasNext();)i.next(),t.writeByte_s8j3t7$(n)}(t,n,i)}var ss=w("ktor-ktor-io.io.ktor.utils.io.core.writeWhile_rh5n47$",x((function(){var e=t.io.ktor.utils.io.core.internal.prepareWriteHead_6z8r11$,n=t.io.ktor.utils.io.core.internal.afterHeadWrite_z1cqja$;return function(t,i){var r=e(t,1,null);try{for(;i(r);)r=e(t,1,r)}finally{n(t,r)}}}))),ls=w("ktor-ktor-io.io.ktor.utils.io.core.writeWhileSize_cmxbvc$",x((function(){var e=t.io.ktor.utils.io.core.internal.prepareWriteHead_6z8r11$,n=t.io.ktor.utils.io.core.internal.afterHeadWrite_z1cqja$;return function(t,i,r){void 0===i&&(i=1);var o=e(t,i,null);try{for(var a;!((a=r(o))<=0);)o=e(t,a,o)}finally{n(t,o)}}})));function us(t,n){if(e.isType(t,Xo))t.writePacket_3uq2w4$(n);else t:do{var i,r,o=!0;if(null==(i=su(n,1)))break t;var a=i;try{for(;rs(t,a),o=!1,null!=(r=uu(n,a));)a=r,o=!0}finally{o&&lu(n,a)}}while(0)}function cs(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=n+i|0,o={v:n},a=cu(t,2,null);try{for(var s;;){for(var l=a,u=(l.limit-l.writePosition|0)/2|0,c=r-o.v|0,p=g.min(u,c),h=o.v+p-1|0,_=o.v;_<=h;_++)Vr(l,Hu(e[_]));if(o.v=o.v+p|0,(s=o.v2){t.tailPosition_8be2vx$=r+2|0,t.tailMemory_8be2vx$.view.setInt16(r,n,!1),i=!0;break t}}i=!1}while(0);i||function(t,n){var i;t:do{if(e.isType(t,Hi)){Vr(t.prepareWriteHead_za3lpa$(2),n),t.afterHeadWrite(),i=!0;break t}i=!1}while(0);i||(t.writeByte_s8j3t7$(d((255&n)>>8)),t.writeByte_s8j3t7$(d(255&n)))}(t,n)}function ys(t,n){var i;t:do{if(e.isType(t,Hi)){var r=t.tailPosition_8be2vx$;if((t.tailEndExclusive_8be2vx$-r|0)>4){t.tailPosition_8be2vx$=r+4|0,t.tailMemory_8be2vx$.view.setInt32(r,n,!1),i=!0;break t}}i=!1}while(0);i||$s(t,n)}function $s(t,n){var i;t:do{if(e.isType(t,Hi)){Xr(t.prepareWriteHead_za3lpa$(4),n),t.afterHeadWrite(),i=!0;break t}i=!1}while(0);i||vs(t,n)}function vs(t,e){var n=k(e>>>16);t.writeByte_s8j3t7$(d((255&n)>>8)),t.writeByte_s8j3t7$(d(255&n));var i=k(65535&e);t.writeByte_s8j3t7$(d((255&i)>>8)),t.writeByte_s8j3t7$(d(255&i))}function gs(t,n){var i;t:do{if(e.isType(t,Hi)){var r=t.tailPosition_8be2vx$;if((t.tailEndExclusive_8be2vx$-r|0)>8){t.tailPosition_8be2vx$=r+8|0;var o=t.tailMemory_8be2vx$;o.view.setInt32(r,n.shiftRight(32).toInt(),!1),o.view.setInt32(r+4|0,n.and(J).toInt(),!1),i=!0;break t}}i=!1}while(0);i||bs(t,n)}function bs(t,n){var i;t:do{if(e.isType(t,Hi)){Qr(t.prepareWriteHead_za3lpa$(8),n),t.afterHeadWrite(),i=!0;break t}i=!1}while(0);i||(vs(t,n.shiftRightUnsigned(32).toInt()),vs(t,n.and(J).toInt()))}function ws(t,n){var i;t:do{if(e.isType(t,Hi)){var r=t.tailPosition_8be2vx$;if((t.tailEndExclusive_8be2vx$-r|0)>4){t.tailPosition_8be2vx$=r+4|0,t.tailMemory_8be2vx$.view.setFloat32(r,n,!1),i=!0;break t}}i=!1}while(0);i||$s(t,nt(n))}function xs(t,n){var i;t:do{if(e.isType(t,Hi)){var r=t.tailPosition_8be2vx$;if((t.tailEndExclusive_8be2vx$-r|0)>8){t.tailPosition_8be2vx$=r+8|0,t.tailMemory_8be2vx$.view.setFloat64(r,n,!1),i=!0;break t}}i=!1}while(0);i||bs(t,it(n))}function ks(t,e,n){Ss(),Mi.call(this,t,e,n)}function Es(){Cs=this}Object.defineProperty(Es.prototype,"Empty",{get:function(){return na().Empty}}),Es.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Cs=null;function Ss(){return null===Cs&&new Es,Cs}ks.$metadata$={kind:p,simpleName:"ByteReadPacketBase",interfaces:[Mi]};var Ts=w("ktor-ktor-io.io.ktor.utils.io.core.get_isEmpty_7wsnj1$",(function(t){return t.endOfInput}));function Os(t){var e;return!t.endOfInput&&null!=(e=su(t,1))&&(lu(t,e),!0)}var Ns=w("ktor-ktor-io.io.ktor.utils.io.core.get_isEmpty_mlrm9h$",(function(t){return t.endOfInput})),Ps=w("ktor-ktor-io.io.ktor.utils.io.core.get_isNotEmpty_mlrm9h$",(function(t){return!t.endOfInput})),As=w("ktor-ktor-io.io.ktor.utils.io.core.read_q4ikbw$",x((function(){var n=t.io.ktor.utils.io.core.prematureEndOfStream_za3lpa$,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(t,e,r){var o;void 0===e&&(e=1);var a=null!=(o=t.prepareRead_za3lpa$(e))?o:n(e),s=a.readPosition;try{r(a)}finally{var l=a.readPosition;if(l0;if(_&&(_=!(p.writePosition>p.readPosition)),!_)break;if(u=!1,null==(l=uu(t,c)))break;c=l,u=!0}}finally{u&&lu(t,c)}}while(0);return o.v-i|0}function Is(t,n,i){var r={v:u};t:do{var o,a,s=!0;if(null==(o=su(t,1)))break t;var l=o;try{for(;;){var c=l,p=wh(c,n,i);if(r.v=r.v.add(e.Long.fromInt(p)),c.writePosition>c.readPosition)break;if(s=!1,null==(a=uu(t,l)))break;l=a,s=!0}}finally{s&&lu(t,l)}}while(0);return r.v}function zs(t,n,i,r){var o={v:u};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var c=a;try{for(;;){var p=c,h=xh(p,n,i,r);if(o.v=o.v.add(e.Long.fromInt(h)),p.writePosition>p.readPosition)break;if(l=!1,null==(s=uu(t,c)))break;c=s,l=!0}}finally{l&&lu(t,c)}}while(0);return o.v}var Ds=w("ktor-ktor-io.io.ktor.utils.io.core.copyUntil_31bg9c$",x((function(){var e=Math,n=t.io.ktor.utils.io.bits.copyTo_tiw1kd$;return function(t,i,r,o,a){var s,l=t.readPosition,u=t.writePosition,c=l+a|0,p=e.min(u,c),h=t.memory;s=p;for(var _=l;_=p)try{var d,m=c,y={v:0};n:do{for(var $={v:0},v={v:0},g={v:0},b=m.memory,w=m.readPosition,x=m.writePosition,k=w;k>=1,$.v=$.v+1|0;if(g.v=$.v,$.v=$.v-1|0,g.v>(x-k|0)){m.discardExact_za3lpa$(k-w|0),d=g.v;break n}}else if(v.v=v.v<<6|127&E,$.v=$.v-1|0,0===$.v){if(Ql(v.v)){var N,P=K(V(v.v));i:do{switch(H(P)){case 13:if(o.v){a.v=!0,N=!1;break i}o.v=!0,N=!0;break i;case 10:a.v=!0,y.v=1,N=!1;break i;default:if(o.v){a.v=!0,N=!1;break i}i.v===n&&Qs(n),i.v=i.v+1|0,e.append_s8itvh$(H(P)),N=!0;break i}}while(0);if(!N){m.discardExact_za3lpa$(k-w-g.v+1|0),d=-1;break n}}else if(tu(v.v)){var A,j=K(V(nu(v.v)));i:do{switch(H(j)){case 13:if(o.v){a.v=!0,A=!1;break i}o.v=!0,A=!0;break i;case 10:a.v=!0,y.v=1,A=!1;break i;default:if(o.v){a.v=!0,A=!1;break i}i.v===n&&Qs(n),i.v=i.v+1|0,e.append_s8itvh$(H(j)),A=!0;break i}}while(0);var L=!A;if(!L){var R,I=K(V(eu(v.v)));i:do{switch(H(I)){case 13:if(o.v){a.v=!0,R=!1;break i}o.v=!0,R=!0;break i;case 10:a.v=!0,y.v=1,R=!1;break i;default:if(o.v){a.v=!0,R=!1;break i}i.v===n&&Qs(n),i.v=i.v+1|0,e.append_s8itvh$(H(I)),R=!0;break i}}while(0);L=!R}if(L){m.discardExact_za3lpa$(k-w-g.v+1|0),d=-1;break n}}else Jl(v.v);v.v=0}}var z=x-w|0;m.discardExact_za3lpa$(z),d=0}while(0);r.v=d,y.v>0&&m.discardExact_za3lpa$(y.v),p=a.v?0:G(r.v,1)}finally{var D=c;h=D.writePosition-D.readPosition|0}else h=f;if(u=!1,0===h)l=uu(t,c);else{var M=h0)}finally{u&&lu(t,c)}}while(0);return r.v>1&&tl(r.v),i.v>0||!t.endOfInput}function Fs(t,e,n,i){void 0===i&&(i=2147483647);var r={v:0},o={v:!1};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a;try{e:for(;;){var c,p=u;n:do{for(var h=p.memory,_=p.readPosition,f=p.writePosition,d=_;d=p)try{var d,m=c;n:do{for(var y={v:0},$={v:0},v={v:0},g=m.memory,b=m.readPosition,w=m.writePosition,x=b;x>=1,y.v=y.v+1|0;if(v.v=y.v,y.v=y.v-1|0,v.v>(w-x|0)){m.discardExact_za3lpa$(x-b|0),d=v.v;break n}}else if($.v=$.v<<6|127&k,y.v=y.v-1|0,0===y.v){if(Ql($.v)){var O,N=K(V($.v));if(rt(n,H(N))?O=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,e.append_s8itvh$(H(N)),O=!0),!O){m.discardExact_za3lpa$(x-b-v.v+1|0),d=-1;break n}}else if(tu($.v)){var P,A=K(V(nu($.v)));rt(n,H(A))?P=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,e.append_s8itvh$(H(A)),P=!0);var j=!P;if(!j){var L,R=K(V(eu($.v)));rt(n,H(R))?L=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,e.append_s8itvh$(H(R)),L=!0),j=!L}if(j){m.discardExact_za3lpa$(x-b-v.v+1|0),d=-1;break n}}else Jl($.v);$.v=0}}var I=w-b|0;m.discardExact_za3lpa$(I),d=0}while(0);a.v=d,a.v=-1===a.v?0:G(a.v,1),p=a.v}finally{var z=c;h=z.writePosition-z.readPosition|0}else h=f;if(u=!1,0===h)l=uu(t,c);else{var D=h0)}finally{u&&lu(t,c)}}while(0);return a.v>1&&tl(a.v),o.v}(t,e,n,i,r.v)),r.v}function qs(t,e,n,i){void 0===i&&(i=2147483647);var r=n.length,o=1===r;if(o&&(o=(0|n.charCodeAt(0))<=127),o)return Is(t,d(0|n.charCodeAt(0)),e).toInt();var a=2===r;a&&(a=(0|n.charCodeAt(0))<=127);var s=a;return s&&(s=(0|n.charCodeAt(1))<=127),s?zs(t,d(0|n.charCodeAt(0)),d(0|n.charCodeAt(1)),e).toInt():function(t,e,n,i){var r={v:0},o={v:!1};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a;try{e:for(;;){var c,p=u,h=p.writePosition-p.readPosition|0;n:do{for(var _=p.memory,f=p.readPosition,d=p.writePosition,m=f;m0&&(p.rewind_za3lpa$(w),rs(i,p,w)),!b)break e;if(l=!1,null==(s=uu(t,u)))break e;u=s,l=!0}}finally{l&&lu(t,u)}}while(0);return o.v||t.endOfInput||(r.v=function(t,e,n,i,r){var o={v:r},a={v:1};t:do{var s,l,u=!0;if(null==(s=su(t,1)))break t;var c=s,p=1;try{e:do{var h,_=c,f=_.writePosition-_.readPosition|0;if(f>=p)try{var d,m=c,y=m.writePosition-m.readPosition|0;n:do{for(var $={v:0},v={v:0},g={v:0},b=m.memory,w=m.readPosition,x=m.writePosition,k=w;k>=1,$.v=$.v+1|0;if(g.v=$.v,$.v=$.v-1|0,g.v>(x-k|0)){m.discardExact_za3lpa$(k-w|0),d=g.v;break n}}else if(v.v=v.v<<6|127&C,$.v=$.v-1|0,0===$.v){var O;if(Ql(v.v)){if(rt(n,H(K(V(v.v))))?O=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,O=!0),!O){m.discardExact_za3lpa$(k-w-g.v+1|0),d=-1;break n}}else if(tu(v.v)){var N;rt(n,H(K(V(nu(v.v)))))?N=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,N=!0);var P,A=!N;if(A||(rt(n,H(K(V(eu(v.v)))))?P=!1:(o.v===i&&Qs(i),o.v=o.v+1|0,P=!0),A=!P),A){m.discardExact_za3lpa$(k-w-g.v+1|0),d=-1;break n}}else Jl(v.v);v.v=0}}var j=x-w|0;m.discardExact_za3lpa$(j),d=0}while(0);a.v=d;var L=y-(m.writePosition-m.readPosition|0)|0;L>0&&(m.rewind_za3lpa$(L),rs(e,m,L)),a.v=-1===a.v?0:G(a.v,1),p=a.v}finally{var R=c;h=R.writePosition-R.readPosition|0}else h=f;if(u=!1,0===h)l=uu(t,c);else{var I=h0)}finally{u&&lu(t,c)}}while(0);return a.v>1&&tl(a.v),o.v}(t,i,e,n,r.v)),r.v}(t,n,i,e)}function Gs(t,e){if(void 0===e){var n=t.remaining;if(n.compareTo_11rb$(st)>0)throw b("Unable to convert to a ByteArray: packet is too big");e=n.toInt()}if(0!==e){var i=new Int8Array(e);return _a(t,i,0,e),i}return Wl}function Hs(t,n,i){if(void 0===n&&(n=0),void 0===i&&(i=2147483647),n===i&&0===n)return Wl;if(n===i){var r=new Int8Array(n);return _a(t,r,0,n),r}for(var o=new Int8Array(ot(v(e.Long.fromInt(i),Ri(t)),e.Long.fromInt(n)).toInt()),a=0;a>>16)),_=new I(k(65535&p.value));if(r.v=r.v+(65535&h.data)|0,s.commitWritten_za3lpa$(65535&_.data),(a=0==(65535&h.data)&&r.v0)throw B("This instance is already in use but somehow appeared in the pool.");if(this.refCount_yk3bl6$_0===t&&(this.refCount_yk3bl6$_0=1,1))break t}}while(0)},bl.prototype.release_8be2vx$=function(){var t;this.refCount_yk3bl6$_0;t:do{for(;;){var e=this.refCount_yk3bl6$_0;if(e<=0)throw B("Unable to release: it is already released.");var n=e-1|0;if(this.refCount_yk3bl6$_0===e&&(this.refCount_yk3bl6$_0=n,1)){t=n;break t}}}while(0);return 0===t},bl.prototype.reset=function(){null!=this.origin&&new gl(wl).doFail(),Vi.prototype.reset.call(this),this.attachment=null,this.nextRef_43oo9e$_0=null},Object.defineProperty(xl.prototype,"Empty",{get:function(){return Qp().Empty}}),Object.defineProperty(kl.prototype,"capacity",{get:function(){return xr.capacity}}),kl.prototype.borrow=function(){return xr.borrow()},kl.prototype.recycle_trkh7z$=function(t){if(!e.isType(t,Hp))throw b("Only IoBuffer instances can be recycled.");xr.recycle_trkh7z$(t)},kl.prototype.dispose=function(){xr.dispose()},kl.$metadata$={kind:p,interfaces:[gu]},Object.defineProperty(El.prototype,"capacity",{get:function(){return 1}}),El.prototype.borrow=function(){return Nl().Empty},El.prototype.recycle_trkh7z$=function(t){t!==Nl().Empty&&new gl(Cl).doFail()},El.prototype.dispose=function(){},El.$metadata$={kind:p,interfaces:[gu]},Sl.prototype.borrow=function(){return new Hp(ic().alloc_za3lpa$(4096),null)},Sl.prototype.recycle_trkh7z$=function(t){if(!e.isType(t,Hp))throw b("Only IoBuffer instances can be recycled.");ic().free_vn6nzs$(t.memory)},Sl.$metadata$={kind:p,interfaces:[bu]},Tl.prototype.borrow=function(){throw R("This pool doesn't support borrow")},Tl.prototype.recycle_trkh7z$=function(t){},Tl.$metadata$={kind:p,interfaces:[bu]},xl.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Ol=null;function Nl(){return null===Ol&&new xl,Ol}function Pl(){return"A chunk couldn't be a view of itself."}function Al(t){return 1===t.referenceCount}bl.$metadata$={kind:p,simpleName:"ChunkBuffer",interfaces:[Vi]};var jl=w("ktor-ktor-io.io.ktor.utils.io.core.internal.toIntOrFail_z7h088$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){return t.toNumber()>=2147483647&&e(t,n),t.toInt()}})));function Ll(t,e){throw b("Long value "+t.toString()+" of "+e+" doesn't fit into 32-bit integer")}var Rl=w("ktor-ktor-io.io.ktor.utils.io.core.internal.require_87ejdh$",x((function(){var n=e.kotlin.IllegalArgumentException_init_pdl1vj$,i=t.io.ktor.utils.io.core.internal.RequireFailureCapture,r=e.Kind.CLASS;function o(t){this.closure$message=t,i.call(this)}return o.prototype=Object.create(i.prototype),o.prototype.constructor=o,o.prototype.doFail=function(){throw n(this.closure$message())},o.$metadata$={kind:r,interfaces:[i]},function(t,e){t||new o(e).doFail()}})));function Il(){}function zl(t){this.closure$message=t,Il.call(this)}Il.$metadata$={kind:p,simpleName:"RequireFailureCapture",interfaces:[]},zl.prototype=Object.create(Il.prototype),zl.prototype.constructor=zl,zl.prototype.doFail=function(){throw b(this.closure$message())},zl.$metadata$={kind:p,interfaces:[Il]};var Dl=w("ktor-ktor-io.io.ktor.utils.io.core.internal.decodeASCII_j5qx8u$",x((function(){var t=e.toChar,n=e.toBoxedChar;return function(e,i){for(var r=e.memory,o=e.readPosition,a=e.writePosition,s=o;s>=1,e=e+1|0;return e}Ml.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Ml.prototype=Object.create(s.prototype),Ml.prototype.constructor=Ml,Ml.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$decoded={v:0},this.local$size={v:1},this.local$cr={v:!1},this.local$end={v:!1},this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$end.v||0===this.local$size.v){this.state_0=5;continue}if(this.state_0=3,this.result_0=this.local$nextChunk(this.local$size.v,this),this.result_0===a)return a;continue;case 3:if(this.local$tmp$=this.result_0,null==this.local$tmp$){this.state_0=5;continue}this.state_0=4;continue;case 4:var t=this.local$tmp$;t:do{var e,n,i=!0;if(null==(e=su(t,1)))break t;var r=e,o=1;try{e:do{var s,l=r,u=l.writePosition-l.readPosition|0;if(u>=o)try{var c,p=r,h={v:0};n:do{for(var _={v:0},f={v:0},d={v:0},m=p.memory,y=p.readPosition,$=p.writePosition,v=y;v<$;v++){var g=255&m.view.getInt8(v);if(0==(128&g)){0!==_.v&&Zl(_.v);var b,w=K(V(g));i:do{switch(H(w)){case 13:if(this.local$cr.v){this.local$end.v=!0,b=!1;break i}this.local$cr.v=!0,b=!0;break i;case 10:this.local$end.v=!0,h.v=1,b=!1;break i;default:if(this.local$cr.v){this.local$end.v=!0,b=!1;break i}if(this.local$decoded.v===this.local$limit)throw new Vo("Too many characters in line: limit "+this.local$limit+" exceeded");this.local$decoded.v=this.local$decoded.v+1|0,this.local$out.append_s8itvh$(H(w)),b=!0;break i}}while(0);if(!b){p.discardExact_za3lpa$(v-y|0),c=-1;break n}}else if(0===_.v){var x=128;f.v=g;for(var k=1;k<=6&&0!=(f.v&x);k++)f.v=f.v&~x,x>>=1,_.v=_.v+1|0;if(d.v=_.v,_.v=_.v-1|0,d.v>($-v|0)){p.discardExact_za3lpa$(v-y|0),c=d.v;break n}}else if(f.v=f.v<<6|127&g,_.v=_.v-1|0,0===_.v){if(Ql(f.v)){var E,C=K(V(f.v));i:do{switch(H(C)){case 13:if(this.local$cr.v){this.local$end.v=!0,E=!1;break i}this.local$cr.v=!0,E=!0;break i;case 10:this.local$end.v=!0,h.v=1,E=!1;break i;default:if(this.local$cr.v){this.local$end.v=!0,E=!1;break i}if(this.local$decoded.v===this.local$limit)throw new Vo("Too many characters in line: limit "+this.local$limit+" exceeded");this.local$decoded.v=this.local$decoded.v+1|0,this.local$out.append_s8itvh$(H(C)),E=!0;break i}}while(0);if(!E){p.discardExact_za3lpa$(v-y-d.v+1|0),c=-1;break n}}else if(tu(f.v)){var S,T=K(V(nu(f.v)));i:do{switch(H(T)){case 13:if(this.local$cr.v){this.local$end.v=!0,S=!1;break i}this.local$cr.v=!0,S=!0;break i;case 10:this.local$end.v=!0,h.v=1,S=!1;break i;default:if(this.local$cr.v){this.local$end.v=!0,S=!1;break i}if(this.local$decoded.v===this.local$limit)throw new Vo("Too many characters in line: limit "+this.local$limit+" exceeded");this.local$decoded.v=this.local$decoded.v+1|0,this.local$out.append_s8itvh$(H(T)),S=!0;break i}}while(0);var O=!S;if(!O){var N,P=K(V(eu(f.v)));i:do{switch(H(P)){case 13:if(this.local$cr.v){this.local$end.v=!0,N=!1;break i}this.local$cr.v=!0,N=!0;break i;case 10:this.local$end.v=!0,h.v=1,N=!1;break i;default:if(this.local$cr.v){this.local$end.v=!0,N=!1;break i}if(this.local$decoded.v===this.local$limit)throw new Vo("Too many characters in line: limit "+this.local$limit+" exceeded");this.local$decoded.v=this.local$decoded.v+1|0,this.local$out.append_s8itvh$(H(P)),N=!0;break i}}while(0);O=!N}if(O){p.discardExact_za3lpa$(v-y-d.v+1|0),c=-1;break n}}else Jl(f.v);f.v=0}}var A=$-y|0;p.discardExact_za3lpa$(A),c=0}while(0);this.local$size.v=c,h.v>0&&p.discardExact_za3lpa$(h.v),this.local$size.v=this.local$end.v?0:G(this.local$size.v,1),o=this.local$size.v}finally{var j=r;s=j.writePosition-j.readPosition|0}else s=u;if(i=!1,0===s)n=uu(t,r);else{var L=s0)}finally{i&&lu(t,r)}}while(0);this.state_0=2;continue;case 5:return this.local$size.v>1&&Ul(this.local$size.v),this.local$cr.v&&(this.local$end.v=!0),this.local$decoded.v>0||this.local$end.v;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}};var ql=w("ktor-ktor-io.io.ktor.utils.io.core.internal.decodeUTF8_cise53$",x((function(){var n=t.io.ktor.utils.io.core.Buffer,i=e.throwCCE,r=t.io.ktor.utils.io.core.internal.malformedByteCount_za3lpa$,o=e.toChar,a=e.toBoxedChar,s=t.io.ktor.utils.io.core.internal.isBmpCodePoint_za3lpa$,l=t.io.ktor.utils.io.core.internal.isValidCodePoint_za3lpa$,u=t.io.ktor.utils.io.core.internal.malformedCodePoint_za3lpa$,c=t.io.ktor.utils.io.core.internal.highSurrogate_za3lpa$,p=t.io.ktor.utils.io.core.internal.lowSurrogate_za3lpa$;return function(t,h){var _,f,d=e.isType(_=t,n)?_:i();t:do{for(var m={v:0},y={v:0},$={v:0},v=d.memory,g=d.readPosition,b=d.writePosition,w=g;w>=1,m.v=m.v+1|0;if($.v=m.v,m.v=m.v-1|0,$.v>(b-w|0)){d.discardExact_za3lpa$(w-g|0),f=$.v;break t}}else if(y.v=y.v<<6|127&x,m.v=m.v-1|0,0===m.v){if(s(y.v)){if(!h(a(o(y.v)))){d.discardExact_za3lpa$(w-g-$.v+1|0),f=-1;break t}}else if(l(y.v)){if(!h(a(o(c(y.v))))||!h(a(o(p(y.v))))){d.discardExact_za3lpa$(w-g-$.v+1|0),f=-1;break t}}else u(y.v);y.v=0}}var C=b-g|0;d.discardExact_za3lpa$(C),f=0}while(0);return f}}))),Gl=w("ktor-ktor-io.io.ktor.utils.io.core.internal.decodeUTF8_dce4k1$",x((function(){var n=t.io.ktor.utils.io.core.internal.malformedByteCount_za3lpa$,i=e.toChar,r=e.toBoxedChar,o=t.io.ktor.utils.io.core.internal.isBmpCodePoint_za3lpa$,a=t.io.ktor.utils.io.core.internal.isValidCodePoint_za3lpa$,s=t.io.ktor.utils.io.core.internal.malformedCodePoint_za3lpa$,l=t.io.ktor.utils.io.core.internal.highSurrogate_za3lpa$,u=t.io.ktor.utils.io.core.internal.lowSurrogate_za3lpa$;return function(t,e){for(var c={v:0},p={v:0},h={v:0},_=t.memory,f=t.readPosition,d=t.writePosition,m=f;m>=1,c.v=c.v+1|0;if(h.v=c.v,c.v=c.v-1|0,h.v>(d-m|0))return t.discardExact_za3lpa$(m-f|0),h.v}else if(p.v=p.v<<6|127&y,c.v=c.v-1|0,0===c.v){if(o(p.v)){if(!e(r(i(p.v))))return t.discardExact_za3lpa$(m-f-h.v+1|0),-1}else if(a(p.v)){if(!e(r(i(l(p.v))))||!e(r(i(u(p.v)))))return t.discardExact_za3lpa$(m-f-h.v+1|0),-1}else s(p.v);p.v=0}}var g=d-f|0;return t.discardExact_za3lpa$(g),0}})));function Hl(t,e,n){this.array_0=t,this.offset_0=e,this.length_xy9hzd$_0=n}function Yl(t){this.value=t}function Vl(t,e,n){return n=n||Object.create(Yl.prototype),Yl.call(n,(65535&t.data)<<16|65535&e.data),n}function Kl(t,e,n,i,r,o){for(var a,s,l=n+(65535&I.Companion.MAX_VALUE.data)|0,u=g.min(i,l),c=L(o,65535&I.Companion.MAX_VALUE.data),p=r,h=n;;){if(p>=c||h>=u)return Vl(new I(k(h-n|0)),new I(k(p-r|0)));var _=65535&(0|e.charCodeAt((h=(a=h)+1|0,a)));if(0!=(65408&_))break;t.view.setInt8((p=(s=p)+1|0,s),d(_))}return function(t,e,n,i,r,o,a,s){for(var l,u,c=n,p=o,h=a-3|0;!((h-p|0)<=0||c>=i);){var _,f=e.charCodeAt((c=(l=c)+1|0,l)),m=pt(f)?c!==i&&ct(e.charCodeAt(c))?iu(f,e.charCodeAt((c=(u=c)+1|0,u))):63:0|f,y=p;0<=m&&m<=127?(t.view.setInt8(y,d(m)),_=1):128<=m&&m<=2047?(t.view.setInt8(y,d(192|m>>6&31)),t.view.setInt8(y+1|0,d(128|63&m)),_=2):2048<=m&&m<=65535?(t.view.setInt8(y,d(224|m>>12&15)),t.view.setInt8(y+1|0,d(128|m>>6&63)),t.view.setInt8(y+2|0,d(128|63&m)),_=3):65536<=m&&m<=1114111?(t.view.setInt8(y,d(240|m>>18&7)),t.view.setInt8(y+1|0,d(128|m>>12&63)),t.view.setInt8(y+2|0,d(128|m>>6&63)),t.view.setInt8(y+3|0,d(128|63&m)),_=4):_=Jl(m),p=p+_|0}return p===h?function(t,e,n,i,r,o,a,s){for(var l,u,c=n,p=o;;){var h=a-p|0;if(h<=0||c>=i)break;var _=e.charCodeAt((c=(l=c)+1|0,l)),f=pt(_)?c!==i&&ct(e.charCodeAt(c))?iu(_,e.charCodeAt((c=(u=c)+1|0,u))):63:0|_;if((1<=f&&f<=127?1:128<=f&&f<=2047?2:2048<=f&&f<=65535?3:65536<=f&&f<=1114111?4:Jl(f))>h){c=c-1|0;break}var m,y=p;0<=f&&f<=127?(t.view.setInt8(y,d(f)),m=1):128<=f&&f<=2047?(t.view.setInt8(y,d(192|f>>6&31)),t.view.setInt8(y+1|0,d(128|63&f)),m=2):2048<=f&&f<=65535?(t.view.setInt8(y,d(224|f>>12&15)),t.view.setInt8(y+1|0,d(128|f>>6&63)),t.view.setInt8(y+2|0,d(128|63&f)),m=3):65536<=f&&f<=1114111?(t.view.setInt8(y,d(240|f>>18&7)),t.view.setInt8(y+1|0,d(128|f>>12&63)),t.view.setInt8(y+2|0,d(128|f>>6&63)),t.view.setInt8(y+3|0,d(128|63&f)),m=4):m=Jl(f),p=p+m|0}return Vl(new I(k(c-r|0)),new I(k(p-s|0)))}(t,e,c,i,r,p,a,s):Vl(new I(k(c-r|0)),new I(k(p-s|0)))}(t,e,h=h-1|0,u,n,p,c,r)}Object.defineProperty(Hl.prototype,"length",{get:function(){return this.length_xy9hzd$_0}}),Hl.prototype.charCodeAt=function(t){return t>=this.length&&this.indexOutOfBounds_0(t),this.array_0[t+this.offset_0|0]},Hl.prototype.subSequence_vux9f0$=function(t,e){return t>=0||new zl((r=t,function(){return"startIndex shouldn't be negative: "+r})).doFail(),t<=this.length||new zl(function(t,e){return function(){return"startIndex is too large: "+t+" > "+e.length}}(t,this)).doFail(),(t+e|0)<=this.length||new zl((n=e,i=this,function(){return"endIndex is too large: "+n+" > "+i.length})).doFail(),e>=t||new zl(function(t,e){return function(){return"endIndex should be greater or equal to startIndex: "+t+" > "+e}}(t,e)).doFail(),new Hl(this.array_0,this.offset_0+t|0,e-t|0);var n,i,r},Hl.prototype.indexOutOfBounds_0=function(t){throw new lt("String index out of bounds: "+t+" > "+this.length)},Hl.$metadata$={kind:p,simpleName:"CharArraySequence",interfaces:[ut]},Object.defineProperty(Yl.prototype,"characters",{get:w("ktor-ktor-io.io.ktor.utils.io.core.internal.EncodeResult.get_characters",x((function(){var t=e.toShort,n=e.kotlin.UShort;return function(){return new n(t(this.value>>>16))}})))}),Object.defineProperty(Yl.prototype,"bytes",{get:w("ktor-ktor-io.io.ktor.utils.io.core.internal.EncodeResult.get_bytes",x((function(){var t=e.toShort,n=e.kotlin.UShort;return function(){return new n(t(65535&this.value))}})))}),Yl.prototype.component1=w("ktor-ktor-io.io.ktor.utils.io.core.internal.EncodeResult.component1",x((function(){var t=e.toShort,n=e.kotlin.UShort;return function(){return new n(t(this.value>>>16))}}))),Yl.prototype.component2=w("ktor-ktor-io.io.ktor.utils.io.core.internal.EncodeResult.component2",x((function(){var t=e.toShort,n=e.kotlin.UShort;return function(){return new n(t(65535&this.value))}}))),Yl.$metadata$={kind:p,simpleName:"EncodeResult",interfaces:[]},Yl.prototype.unbox=function(){return this.value},Yl.prototype.toString=function(){return"EncodeResult(value="+e.toString(this.value)+")"},Yl.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.value)|0},Yl.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.value,t.value)};var Wl,Xl=w("ktor-ktor-io.io.ktor.utils.io.core.internal.putUtf8Char_9qn7ci$",x((function(){var n=e.toByte,i=t.io.ktor.utils.io.core.internal.malformedCodePoint_za3lpa$;return function(t,e,r){return 0<=r&&r<=127?(t.view.setInt8(e,n(r)),1):128<=r&&r<=2047?(t.view.setInt8(e,n(192|r>>6&31)),t.view.setInt8(e+1|0,n(128|63&r)),2):2048<=r&&r<=65535?(t.view.setInt8(e,n(224|r>>12&15)),t.view.setInt8(e+1|0,n(128|r>>6&63)),t.view.setInt8(e+2|0,n(128|63&r)),3):65536<=r&&r<=1114111?(t.view.setInt8(e,n(240|r>>18&7)),t.view.setInt8(e+1|0,n(128|r>>12&63)),t.view.setInt8(e+2|0,n(128|r>>6&63)),t.view.setInt8(e+3|0,n(128|63&r)),4):i(r)}})));function Zl(t){throw new ru("Expected "+t+" more character bytes")}function Jl(t){throw b("Malformed code-point "+t+" found")}function Ql(t){return t>>>16==0}function tu(t){return t<=1114111}function eu(t){return 56320+(1023&t)|0}function nu(t){return 55232+(t>>>10)|0}function iu(t,e){return((0|t)-55232|0)<<10|(0|e)-56320|0}function ru(t){W(t,this),this.name="MalformedUTF8InputException"}function ou(){}function au(t,e){var n;if(null!=(n=e.stealAll_8be2vx$())){var i=n;e.size<=oh&&null==i.next&&t.tryWriteAppend_pvnryh$(i)?e.afterBytesStolen_8be2vx$():t.append_pvnryh$(i)}}function su(t,n){return e.isType(t,Mi)?t.prepareReadHead_za3lpa$(n):e.isType(t,bl)?t.writePosition>t.readPosition?t:null:function(t,n){if(t.endOfInput)return null;var i=Nl().Pool.borrow(),r=t.peekTo_afjyek$(i.memory,e.Long.fromInt(i.writePosition),u,e.Long.fromInt(n),e.Long.fromInt(i.limit-i.writePosition|0)).toInt();return i.commitWritten_za3lpa$(r),rn.readPosition?(n.capacity-n.limit|0)<8?t.fixGapAfterRead_j2u0py$(n):t.headPosition=n.readPosition:t.ensureNext_j2u0py$(n):function(t,e){ua(t,e.capacity-(e.limit-e.writePosition|0)-(e.writePosition-e.readPosition|0)|0),e.release_2bs5fo$(Nl().Pool)}(t,n))}function uu(t,n){return n===t?t.writePosition>t.readPosition?t:null:e.isType(t,Mi)?t.ensureNextHead_j2u0py$(n):function(t,e){return ua(t,e.capacity-(e.limit-e.writePosition|0)-(e.writePosition-e.readPosition|0)|0),e.resetForWrite(),t.endOfInput||Ua(t,e)<=0?(e.release_2bs5fo$(Nl().Pool),null):e}(t,n)}function cu(t,n,i){return e.isType(t,Hi)?(null!=i&&t.afterHeadWrite(),t.prepareWriteHead_za3lpa$(n)):function(t,e){return null!=e?(rs(t,e),e.resetForWrite(),e):Nl().Pool.borrow()}(t,i)}function pu(t,n){if(e.isType(t,Hi))return t.afterHeadWrite();!function(t,e){rs(t,e),e.release_2bs5fo$(Nl().Pool)}(t,n)}function hu(t){this.closure$message=t,Il.call(this)}function _u(t,e,n,i){var r,o;e>=0||new hu((o=e,function(){return"offset shouldn't be negative: "+o+"."})).doFail(),n>=0||new hu((r=n,function(){return"min shouldn't be negative: "+r+"."})).doFail(),i>=n||new hu(function(t,e){return function(){return"max should't be less than min: max = "+t+", min = "+e+"."}}(i,n)).doFail(),n<=(t.limit-t.writePosition|0)||new hu(function(t,e){return function(){var n=e;return"Not enough free space in the destination buffer to write the specified minimum number of bytes: min = "+t+", free = "+(n.limit-n.writePosition|0)+"."}}(n,t)).doFail()}function fu(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$dst=e,this.local$closeOnEnd=n}function du(t,e,n,i,r){var o=new fu(t,e,n,i);return r?o:o.doResume(null)}function mu(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$tmp$=void 0,this.local$remainingLimit=void 0,this.local$transferred=void 0,this.local$tail=void 0,this.local$$receiver=t,this.local$dst=e,this.local$limit=n}function yu(t,e,n,i,r){var o=new mu(t,e,n,i);return r?o:o.doResume(null)}function $u(t,e,n,i){s.call(this,i),this.exceptionState_0=9,this.local$lastPiece=void 0,this.local$rc=void 0,this.local$$receiver=t,this.local$dst=e,this.local$limit=n}function vu(t,e,n,i,r){var o=new $u(t,e,n,i);return r?o:o.doResume(null)}function gu(){}function bu(){}function wu(){this.borrowed_m1d2y6$_0=0,this.disposed_rxrbhb$_0=!1,this.instance_vlsx8v$_0=null}ru.$metadata$={kind:p,simpleName:"MalformedUTF8InputException",interfaces:[X]},ou.$metadata$={kind:p,simpleName:"DangerousInternalIoApi",interfaces:[Q]},hu.prototype=Object.create(Il.prototype),hu.prototype.constructor=hu,hu.prototype.doFail=function(){throw b(this.closure$message())},hu.$metadata$={kind:p,interfaces:[Il]},fu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},fu.prototype=Object.create(s.prototype),fu.prototype.constructor=fu,fu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=yu(this.local$$receiver,this.local$dst,l,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return void(this.local$closeOnEnd&&Ne(this.local$dst));default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},mu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},mu.prototype=Object.create(s.prototype),mu.prototype.constructor=mu,mu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$$receiver===this.local$dst)throw b("Failed requirement.".toString());this.local$remainingLimit=this.local$limit,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.local$$receiver.awaitInternalAtLeast1_8be2vx$(this),this.result_0===a)return a;continue;case 3:if(this.result_0){this.state_0=4;continue}this.state_0=10;continue;case 4:if(this.local$transferred=this.local$$receiver.transferTo_pxvbjg$(this.local$dst,this.local$remainingLimit),_(this.local$transferred,u)){if(this.state_0=7,this.result_0=vu(this.local$$receiver,this.local$dst,this.local$remainingLimit,this),this.result_0===a)return a;continue}if(0===this.local$dst.availableForWrite){if(this.state_0=5,this.result_0=this.local$dst.notFull_8be2vx$.await(this),this.result_0===a)return a;continue}this.state_0=6;continue;case 5:this.state_0=6;continue;case 6:this.local$tmp$=this.local$transferred,this.state_0=9;continue;case 7:if(this.local$tail=this.result_0,_(this.local$tail,u)){this.state_0=10;continue}this.state_0=8;continue;case 8:this.local$tmp$=this.local$tail,this.state_0=9;continue;case 9:var t=this.local$tmp$;this.local$remainingLimit=this.local$remainingLimit.subtract(t),this.state_0=2;continue;case 10:return this.local$limit.subtract(this.local$remainingLimit);default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},$u.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},$u.prototype=Object.create(s.prototype),$u.prototype.constructor=$u,$u.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.local$lastPiece=Nl().Pool.borrow(),this.exceptionState_0=7,this.local$lastPiece.resetForWrite_za3lpa$(v(this.local$limit,e.Long.fromInt(this.local$lastPiece.capacity)).toInt()),this.state_0=1,this.result_0=this.local$$receiver.readAvailable_lh221x$(this.local$lastPiece,this),this.result_0===a)return a;continue;case 1:if(this.local$rc=this.result_0,-1===this.local$rc){this.local$lastPiece.release_2bs5fo$(Nl().Pool),this.exceptionState_0=9,this.finallyPath_0=[2],this.state_0=8,this.$returnValue=u;continue}this.state_0=3;continue;case 2:return this.$returnValue;case 3:if(this.state_0=4,this.result_0=this.local$dst.writeFully_lh221x$(this.local$lastPiece,this),this.result_0===a)return a;continue;case 4:this.exceptionState_0=9,this.finallyPath_0=[5],this.state_0=8,this.$returnValue=e.Long.fromInt(this.local$rc);continue;case 5:return this.$returnValue;case 6:return;case 7:this.finallyPath_0=[9],this.state_0=8;continue;case 8:this.exceptionState_0=9,this.local$lastPiece.release_2bs5fo$(Nl().Pool),this.state_0=this.finallyPath_0.shift();continue;case 9:throw this.exception_0;default:throw this.state_0=9,new Error("State Machine Unreachable execution")}}catch(t){if(9===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},gu.prototype.close=function(){this.dispose()},gu.$metadata$={kind:o,simpleName:"ObjectPool",interfaces:[Op]},Object.defineProperty(bu.prototype,"capacity",{get:function(){return 0}}),bu.prototype.recycle_trkh7z$=function(t){},bu.prototype.dispose=function(){},bu.$metadata$={kind:p,simpleName:"NoPoolImpl",interfaces:[gu]},Object.defineProperty(wu.prototype,"capacity",{get:function(){return 1}}),wu.prototype.borrow=function(){this.borrowed_m1d2y6$_0;t:do{for(;;){var t=this.borrowed_m1d2y6$_0;if(0!==t)throw B("Instance is already consumed");if(this.borrowed_m1d2y6$_0===t&&(this.borrowed_m1d2y6$_0=1,1))break t}}while(0);var e=this.produceInstance();return this.instance_vlsx8v$_0=e,e},wu.prototype.recycle_trkh7z$=function(t){if(this.instance_vlsx8v$_0!==t){if(null==this.instance_vlsx8v$_0&&0!==this.borrowed_m1d2y6$_0)throw B("Already recycled or an irrelevant instance tried to be recycled");throw B("Unable to recycle irrelevant instance")}if(this.instance_vlsx8v$_0=null,!1!==this.disposed_rxrbhb$_0||(this.disposed_rxrbhb$_0=!0,0))throw B("An instance is already disposed");this.disposeInstance_trkh7z$(t)},wu.prototype.dispose=function(){var t;if(!1===this.disposed_rxrbhb$_0&&(this.disposed_rxrbhb$_0=!0,1)){if(null==(t=this.instance_vlsx8v$_0))return;var e=t;this.instance_vlsx8v$_0=null,this.disposeInstance_trkh7z$(e)}},wu.$metadata$={kind:p,simpleName:"SingleInstancePool",interfaces:[gu]};var xu=w("ktor-ktor-io.io.ktor.utils.io.pool.useBorrowed_ufoqs6$",(function(t,e){var n,i=t.borrow();try{n=e(i)}finally{t.recycle_trkh7z$(i)}return n})),ku=w("ktor-ktor-io.io.ktor.utils.io.pool.useInstance_ufoqs6$",(function(t,e){var n=t.borrow();try{return e(n)}finally{t.recycle_trkh7z$(n)}}));function Eu(t){return void 0===t&&(t=!1),new Ou(Qp().Empty,t)}function Cu(t,n,i){var r;if(void 0===n&&(n=0),void 0===i&&(i=t.length),0===t.length)return zu().Empty;for(var o=Qp().Pool.borrow(),a=o,s=n,l=s+i|0;;){a.reserveEndGap_za3lpa$(8);var u=l-s|0,p=a,h=p.limit-p.writePosition|0,_=g.min(u,h);if(co(e.isType(r=a,Vi)?r:c(),t,s,_),(s=s+_|0)===l)break;var f=a;a=Qp().Pool.borrow(),f.next=a}var d=new Ou(o,!1);return Ne(d),d}function Su(t,e,n,i){s.call(this,i),this.exceptionState_0=1,this.local$$receiver=t,this.local$dst=e,this.local$closeOnEnd=n}function Tu(t,n,i,r){var o,a;return void 0===i&&(i=l),yu(e.isType(o=t,Ot)?o:c(),e.isType(a=n,Ot)?a:c(),i,r)}function Ou(t,e){Ot.call(this,t,e),this.attachedJob_0=null}function Nu(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$tmp$_0=void 0,this.local$dst=e,this.local$offset=n,this.local$length=i}function Pu(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$dst=e,this.local$offset=n,this.local$length=i}function Au(t,e,n,i,r){s.call(this,r),this.exceptionState_0=1,this.$this=t,this.local$start=void 0,this.local$end=void 0,this.local$remaining=void 0,this.local$dst=e,this.local$offset=n,this.local$length=i}function ju(){zu()}function Lu(){Iu=this,this.Empty_wsx8uv$_0=yt(Ru)}function Ru(){var t=new Ou(Qp().Empty,!1);return t.close_dbl4no$(null),t}Su.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Su.prototype=Object.create(s.prototype),Su.prototype.constructor=Su,Su.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t,n;if(this.state_0=2,this.result_0=du(e.isType(t=this.local$$receiver,Ot)?t:c(),e.isType(n=this.local$dst,Ot)?n:c(),this.local$closeOnEnd,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ou.prototype.attachJob_dqr1mp$=function(t){var e,n;null!=(e=this.attachedJob_0)&&e.cancel_m4sck1$(),this.attachedJob_0=t,t.invokeOnCompletion_ct2b2z$(!0,void 0,(n=this,function(t){return n.attachedJob_0=null,null!=t&&n.cancel_dbl4no$(y("Channel closed due to job failure: "+ft(t))),h}))},Nu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Nu.prototype=Object.create(s.prototype),Nu.prototype.constructor=Nu,Nu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(this.$this.readable.endOfInput){if(this.state_0=2,this.result_0=this.$this.readAvailableSuspend_0(this.local$dst,this.local$offset,this.local$length,this),this.result_0===a)return a;continue}if(null!=(t=this.$this.closedCause))throw t;this.local$tmp$_0=Fp(this.$this.readable,this.local$dst,this.local$offset,this.local$length),this.state_0=3;continue;case 1:throw this.exception_0;case 2:this.local$tmp$_0=this.result_0,this.state_0=3;continue;case 3:return this.local$tmp$_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ou.prototype.readAvailable_qmgm5g$=function(t,e,n,i,r){var o=new Nu(this,t,e,n,i);return r?o:o.doResume(null)},Pu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Pu.prototype=Object.create(s.prototype),Pu.prototype.constructor=Pu,Pu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=this.$this.await_za3lpa$(1,this),this.result_0===a)return a;continue;case 1:throw this.exception_0;case 2:if(this.result_0){this.state_0=3;continue}return-1;case 3:if(this.state_0=4,this.result_0=this.$this.readAvailable_qmgm5g$(this.local$dst,this.local$offset,this.local$length,this),this.result_0===a)return a;continue;case 4:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ou.prototype.readAvailableSuspend_0=function(t,e,n,i,r){var o=new Pu(this,t,e,n,i);return r?o:o.doResume(null)},Ou.prototype.readFully_qmgm5g$=function(t,e,n,i){var r;if(!(this.availableForRead>=n))return this.readFullySuspend_0(t,e,n,i);if(null!=(r=this.closedCause))throw r;Mp(this.readable,t,e,n)},Au.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Au.prototype=Object.create(s.prototype),Au.prototype.constructor=Au,Au.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$start=this.local$offset,this.local$end=this.local$offset+this.local$length|0,this.local$remaining=this.local$length,this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.local$start>=this.local$end){this.state_0=4;continue}if(this.state_0=3,this.result_0=this.$this.readAvailable_qmgm5g$(this.local$dst,this.local$start,this.local$remaining,this),this.result_0===a)return a;continue;case 3:var t=this.result_0;if(-1===t)throw new Th("Premature end of stream: required "+this.local$remaining+" more bytes");this.local$start=this.local$start+t|0,this.local$remaining=this.local$remaining-t|0,this.state_0=2;continue;case 4:return;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ou.prototype.readFullySuspend_0=function(t,e,n,i,r){var o=new Au(this,t,e,n,i);return r?o:o.doResume(null)},Ou.prototype.toString=function(){return"ByteChannel["+ft(this.attachedJob_0)+", "+dt(this)+"]"},Ou.$metadata$={kind:p,simpleName:"ByteChannelJS",interfaces:[Ot]},ju.prototype.peekTo_afjyek$=function(t,e,n,i,r,o,a){return void 0===n&&(n=u),void 0===i&&(i=mt),void 0===r&&(r=l),a?a(t,e,n,i,r,o):this.peekTo_afjyek$$default(t,e,n,i,r,o)},Object.defineProperty(Lu.prototype,"Empty",{get:function(){return this.Empty_wsx8uv$_0.value}}),Lu.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Iu=null;function zu(){return null===Iu&&new Lu,Iu}function Du(){}function Mu(t){return function(e){var n=gt(vt(e));return t(n),n.getOrThrow()}}function Bu(t){this.predicate=t,this.cont_0=null}function Uu(t,e){return function(n){return t.cont_0=n,e(),h}}function Fu(t,e,n){s.call(this,n),this.exceptionState_0=1,this.$this=t,this.local$block=e}function qu(t){return function(e){return t.cont_0=e,h}}function Gu(t,e){s.call(this,e),this.exceptionState_0=1,this.$this=t}function Hu(t){return k((255&t)<<8|(65535&t)>>>8)}function Yu(t){var e=k(65535&t),n=k((255&e)<<8|(65535&e)>>>8)<<16,i=k(t>>>16);return n|65535&k((255&i)<<8|(65535&i)>>>8)}function Vu(t){var n=t.and(J).toInt(),i=k(65535&n),r=k((255&i)<<8|(65535&i)>>>8)<<16,o=k(n>>>16),a=e.Long.fromInt(r|65535&k((255&o)<<8|(65535&o)>>>8)).shiftLeft(32),s=t.shiftRightUnsigned(32).toInt(),l=k(65535&s),u=k((255&l)<<8|(65535&l)>>>8)<<16,c=k(s>>>16);return a.or(e.Long.fromInt(u|65535&k((255&c)<<8|(65535&c)>>>8)).and(J))}function Ku(t){var n=nt(t),i=k(65535&n),r=k((255&i)<<8|(65535&i)>>>8)<<16,o=k(n>>>16),a=r|65535&k((255&o)<<8|(65535&o)>>>8);return e.floatFromBits(a)}function Wu(t){var n=it(t),i=n.and(J).toInt(),r=k(65535&i),o=k((255&r)<<8|(65535&r)>>>8)<<16,a=k(i>>>16),s=e.Long.fromInt(o|65535&k((255&a)<<8|(65535&a)>>>8)).shiftLeft(32),l=n.shiftRightUnsigned(32).toInt(),u=k(65535&l),c=k((255&u)<<8|(65535&u)>>>8)<<16,p=k(l>>>16),h=s.or(e.Long.fromInt(c|65535&k((255&p)<<8|(65535&p)>>>8)).and(J));return e.doubleFromBits(h)}ju.$metadata$={kind:o,simpleName:"ByteReadChannel",interfaces:[]},Du.$metadata$={kind:o,simpleName:"ByteWriteChannel",interfaces:[]},Bu.prototype.check=function(){return this.predicate()},Bu.prototype.signal=function(){var t=this.cont_0;null!=t&&this.predicate()&&(this.cont_0=null,t.resumeWith_tl1gpc$(new $t(h)))},Fu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Fu.prototype=Object.create(s.prototype),Fu.prototype.constructor=Fu,Fu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.predicate())return;this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=Mu(Uu(this.$this,this.local$block))(this),this.result_0===a)return a;continue;case 3:return this.result_0,this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Bu.prototype.await_o14v8n$=function(t,e,n){var i=new Fu(this,t,e);return n?i:i.doResume(null)},Gu.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[s]},Gu.prototype=Object.create(s.prototype),Gu.prototype.constructor=Gu,Gu.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.$this.predicate())return;this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=Mu(qu(this.$this))(this),this.result_0===a)return a;continue;case 3:return this.result_0,this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Bu.prototype.await=function(t,e){var n=new Gu(this,t);return e?n:n.doResume(null)},Bu.$metadata$={kind:p,simpleName:"Condition",interfaces:[]};var Xu=w("ktor-ktor-io.io.ktor.utils.io.bits.useMemory_jjtqwx$",x((function(){var e=t.io.ktor.utils.io.bits.Memory,n=t.io.ktor.utils.io.bits.of_2z595v$;return function(t,i,r,o){return void 0===i&&(i=0),o(n(e.Companion,t,i,r))}})));function Zu(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=e;return tc(sc(),r,n,i)}function Ju(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.byteLength-n|0),new rc(new DataView(e,n,i))}function Qu(t,e){return new rc(e)}function tc(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.byteLength),Ju(sc(),e.buffer,e.byteOffset+n|0,i)}function ec(){nc=this}ec.prototype.alloc_za3lpa$=function(t){return new rc(new DataView(new ArrayBuffer(t)))},ec.prototype.alloc_s8cxhz$=function(t){return t.toNumber()>=2147483647&&Ll(t,"size"),new rc(new DataView(new ArrayBuffer(t.toInt())))},ec.prototype.free_vn6nzs$=function(t){},ec.$metadata$={kind:Y,simpleName:"DefaultAllocator",interfaces:[Jn]};var nc=null;function ic(){return null===nc&&new ec,nc}function rc(t){sc(),this.view=t}function oc(){ac=this,this.Empty=new rc(new DataView(new ArrayBuffer(0)))}Object.defineProperty(rc.prototype,"size",{get:w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.get_size",(function(){return e.Long.fromInt(this.view.byteLength)}))}),Object.defineProperty(rc.prototype,"size32",{get:w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.get_size32",(function(){return this.view.byteLength}))}),rc.prototype.loadAt_za3lpa$=w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.loadAt_za3lpa$",(function(t){return this.view.getInt8(t)})),rc.prototype.loadAt_s8cxhz$=w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.loadAt_s8cxhz$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t){var n=this.view;return t.toNumber()>=2147483647&&e(t,"index"),n.getInt8(t.toInt())}}))),rc.prototype.storeAt_6t1wet$=w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.storeAt_6t1wet$",(function(t,e){this.view.setInt8(t,e)})),rc.prototype.storeAt_3pq026$=w("ktor-ktor-io.io.ktor.utils.io.bits.Memory.storeAt_3pq026$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){var i=this.view;t.toNumber()>=2147483647&&e(t,"index"),i.setInt8(t.toInt(),n)}}))),rc.prototype.slice_vux9f0$=function(t,n){if(!(t>=0))throw b(("offset shouldn't be negative: "+t).toString());if(!(n>=0))throw b(("length shouldn't be negative: "+n).toString());if((t+n|0)>e.Long.fromInt(this.view.byteLength).toNumber())throw new lt("offset + length > size: "+t+" + "+n+" > "+e.Long.fromInt(this.view.byteLength).toString());return new rc(new DataView(this.view.buffer,this.view.byteOffset+t|0,n))},rc.prototype.slice_3pjtqy$=function(t,e){t.toNumber()>=2147483647&&Ll(t,"offset");var n=t.toInt();return e.toNumber()>=2147483647&&Ll(e,"length"),this.slice_vux9f0$(n,e.toInt())},rc.prototype.copyTo_ubllm2$=function(t,e,n,i){var r=new Int8Array(this.view.buffer,this.view.byteOffset+e|0,n);new Int8Array(t.view.buffer,t.view.byteOffset+i|0,n).set(r)},rc.prototype.copyTo_q2ka7j$=function(t,e,n,i){e.toNumber()>=2147483647&&Ll(e,"offset");var r=e.toInt();n.toNumber()>=2147483647&&Ll(n,"length");var o=n.toInt();i.toNumber()>=2147483647&&Ll(i,"destinationOffset"),this.copyTo_ubllm2$(t,r,o,i.toInt())},oc.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var ac=null;function sc(){return null===ac&&new oc,ac}function lc(t,e,n,i,r){void 0===r&&(r=0);var o=e,a=new Int8Array(t.view.buffer,t.view.byteOffset+n|0,i);o.set(a,r)}function uc(t,e,n,i){var r;r=e+n|0;for(var o=e;o=2147483647&&e(n,"offset"),t.view.getInt16(n.toInt(),!1)}}))),yc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadIntAt_ad7opl$",(function(t,e){return t.view.getInt32(e,!1)})),$c=w("ktor-ktor-io.io.ktor.utils.io.bits.loadIntAt_xrw27i$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){return n.toNumber()>=2147483647&&e(n,"offset"),t.view.getInt32(n.toInt(),!1)}}))),vc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadLongAt_ad7opl$",(function(t,n){return e.Long.fromInt(t.view.getUint32(n,!1)).shiftLeft(32).or(e.Long.fromInt(t.view.getUint32(n+4|0,!1)))})),gc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadLongAt_xrw27i$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,i){i.toNumber()>=2147483647&&n(i,"offset");var r=i.toInt();return e.Long.fromInt(t.view.getUint32(r,!1)).shiftLeft(32).or(e.Long.fromInt(t.view.getUint32(r+4|0,!1)))}}))),bc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadFloatAt_ad7opl$",(function(t,e){return t.view.getFloat32(e,!1)})),wc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadFloatAt_xrw27i$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){return n.toNumber()>=2147483647&&e(n,"offset"),t.view.getFloat32(n.toInt(),!1)}}))),xc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadDoubleAt_ad7opl$",(function(t,e){return t.view.getFloat64(e,!1)})),kc=w("ktor-ktor-io.io.ktor.utils.io.bits.loadDoubleAt_xrw27i$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n){return n.toNumber()>=2147483647&&e(n,"offset"),t.view.getFloat64(n.toInt(),!1)}}))),Ec=w("ktor-ktor-io.io.ktor.utils.io.bits.storeIntAt_vj6iol$",(function(t,e,n){t.view.setInt32(e,n,!1)})),Cc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeIntAt_qfgmm4$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=t.view;n.toNumber()>=2147483647&&e(n,"offset"),r.setInt32(n.toInt(),i,!1)}}))),Sc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeShortAt_r0om3i$",(function(t,e,n){t.view.setInt16(e,n,!1)})),Tc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeShortAt_u61vsn$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=t.view;n.toNumber()>=2147483647&&e(n,"offset"),r.setInt16(n.toInt(),i,!1)}}))),Oc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeLongAt_gwwqui$",x((function(){var t=new e.Long(-1,0);return function(e,n,i){e.view.setInt32(n,i.shiftRight(32).toInt(),!1),e.view.setInt32(n+4|0,i.and(t).toInt(),!1)}}))),Nc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeLongAt_x1z90x$",x((function(){var n=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$,i=new e.Long(-1,0);return function(t,e,r){e.toNumber()>=2147483647&&n(e,"offset");var o=e.toInt();t.view.setInt32(o,r.shiftRight(32).toInt(),!1),t.view.setInt32(o+4|0,r.and(i).toInt(),!1)}}))),Pc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeFloatAt_r7re9q$",(function(t,e,n){t.view.setFloat32(e,n,!1)})),Ac=w("ktor-ktor-io.io.ktor.utils.io.bits.storeFloatAt_ud4nyv$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=t.view;n.toNumber()>=2147483647&&e(n,"offset"),r.setFloat32(n.toInt(),i,!1)}}))),jc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeDoubleAt_7sfcvf$",(function(t,e,n){t.view.setFloat64(e,n,!1)})),Lc=w("ktor-ktor-io.io.ktor.utils.io.bits.storeDoubleAt_isvxss$",x((function(){var e=t.io.ktor.utils.io.core.internal.failLongToIntConversion_a4hdmt$;return function(t,n,i){var r=t.view;n.toNumber()>=2147483647&&e(n,"offset"),r.setFloat64(n.toInt(),i,!1)}})));function Rc(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0);var o=new Int16Array(t.view.buffer,t.view.byteOffset+e|0,r);if(fc)for(var a=0;a0;){var u=r-s|0,c=l/6|0,p=G(g.min(u,c),1),h=pt(n.charCodeAt(s+p-1|0)),f=h&&1===p?s+2|0:h?s+p-1|0:s+p|0,d=s,m=a.encode(e.subSequence(n,d,f).toString());if(m.length>l)break;rh(o,m),s=f,l=l-m.length|0}return s-i|0}function ep(t,e,n){if(Jc(t)!==fp().UTF_8)throw b("Failed requirement.".toString());us(n,e)}function np(t,e){return!0}function ip(t){this._charset_8be2vx$=t}function rp(t){ip.call(this,t),this.charset_0=t}function op(t){return t._charset_8be2vx$}function ap(t,e,n,i,r){if(void 0===r&&(r=2147483647),0===r)return 0;var o=Oh(Wc(op(t))),a={v:null},s=e.memory,l=e.readPosition,u=e.writePosition,c=$p(new wt(s.view.buffer,s.view.byteOffset+l|0,u-l|0),o,r);n.append_gw00v9$(c.charactersDecoded),a.v=c.bytesConsumed;var p=c.bytesConsumed;return e.discardExact_za3lpa$(p),a.v}function sp(t,n,i,r){var o=Oh(Wc(op(t)),!0),a={v:0};t:do{var s,l,u=!0;if(null==(s=su(n,1)))break t;var c=s,p=1;try{e:do{var h,_=c,f=_.writePosition-_.readPosition|0;if(f>=p)try{var d,m=c;n:do{var y,$=r-a.v|0,v=m.writePosition-m.readPosition|0;if($0&&m.rewind_za3lpa$(v),d=0}else d=a.v0)}finally{u&&lu(n,c)}}while(0);if(a.v=M)try{var q=D,G=q.memory,H=q.readPosition,Y=q.writePosition,V=$p(new wt(G.view.buffer,G.view.byteOffset+H|0,Y-H|0),o,r-a.v|0);i.append_gw00v9$(V.charactersDecoded),a.v=a.v+V.charactersDecoded.length|0;var K=V.bytesConsumed;q.discardExact_za3lpa$(K),K>0?L.v=1:8===L.v?L.v=0:L.v=L.v+1|0,M=L.v}finally{var W=D;B=W.writePosition-W.readPosition|0}else B=F;if(z=!1,0===B)I=uu(n,D);else{var X=B0)}finally{z&&lu(n,D)}}while(0)}return a.v}function lp(t,n,i){if(0===i)return"";var r=e.isType(n,Mi);if(r&&(r=(n.headEndExclusive-n.headPosition|0)>=i),r){var o,a,s=Oh(op(t)._name_8be2vx$,!0),l=n.head,u=n.headMemory.view;try{var c=0===l.readPosition&&i===u.byteLength?u:new DataView(u.buffer,u.byteOffset+l.readPosition|0,i);o=s.decode(c)}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(a=t.message)?a:"no cause provided")):t}var p=o;return n.discardExact_za3lpa$(i),p}return function(t,n,i){var r,o=Oh(Wc(op(t)),!0),a={v:i},s=U(i);try{t:do{var l,u,c=!0;if(null==(l=su(n,6)))break t;var p=l,h=6;try{do{var _,f=p,d=f.writePosition-f.readPosition|0;if(d>=h)try{var m,y=p,$=y.writePosition-y.readPosition|0,v=a.v,b=g.min($,v);if(0===y.readPosition&&y.memory.view.byteLength===b){var w,x,k=y.memory.view;try{w=o.decode(k,uh)}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(x=t.message)?x:"no cause provided")):t}m=w}else{var E,S,T=new Int8Array(y.memory.view.buffer,y.memory.view.byteOffset+y.readPosition|0,b);try{E=o.decode(T,uh)}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(S=t.message)?S:"no cause provided")):t}m=E}var O=m;s.append_gw00v9$(O),y.discardExact_za3lpa$(b),a.v=a.v-b|0,h=a.v>0?6:0}finally{var N=p;_=N.writePosition-N.readPosition|0}else _=d;if(c=!1,0===_)u=uu(n,p);else{var P=_0)}finally{c&&lu(n,p)}}while(0);if(a.v>0)t:do{var L,R,I=!0;if(null==(L=su(n,1)))break t;var z=L;try{for(;;){var D,M=z,B=M.writePosition-M.readPosition|0,F=a.v,q=g.min(B,F);if(0===M.readPosition&&M.memory.view.byteLength===q)D=o.decode(M.memory.view);else{var G,H,Y=new Int8Array(M.memory.view.buffer,M.memory.view.byteOffset+M.readPosition|0,q);try{G=o.decode(Y,uh)}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(H=t.message)?H:"no cause provided")):t}D=G}var V=D;if(s.append_gw00v9$(V),M.discardExact_za3lpa$(q),a.v=a.v-q|0,I=!1,null==(R=uu(n,z)))break;z=R,I=!0}}finally{I&&lu(n,z)}}while(0);s.append_gw00v9$(o.decode())}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(r=t.message)?r:"no cause provided")):t}return s.toString()}(t,n,i)}function up(){_p=this,this.UTF_8=new dp("UTF-8"),this.ISO_8859_1=new dp("ISO-8859-1")}Hc.$metadata$={kind:p,simpleName:"Charset",interfaces:[]},Xc.$metadata$={kind:p,simpleName:"CharsetEncoder",interfaces:[]},Zc.$metadata$={kind:p,simpleName:"CharsetEncoderImpl",interfaces:[Xc]},Zc.prototype.component1_0=function(){return this.charset_0},Zc.prototype.copy_6ypavq$=function(t){return new Zc(void 0===t?this.charset_0:t)},Zc.prototype.toString=function(){return"CharsetEncoderImpl(charset="+e.toString(this.charset_0)+")"},Zc.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.charset_0)|0},Zc.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.charset_0,t.charset_0)},ip.$metadata$={kind:p,simpleName:"CharsetDecoder",interfaces:[]},rp.$metadata$={kind:p,simpleName:"CharsetDecoderImpl",interfaces:[ip]},rp.prototype.component1_0=function(){return this.charset_0},rp.prototype.copy_6ypavq$=function(t){return new rp(void 0===t?this.charset_0:t)},rp.prototype.toString=function(){return"CharsetDecoderImpl(charset="+e.toString(this.charset_0)+")"},rp.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.charset_0)|0},rp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.charset_0,t.charset_0)},up.$metadata$={kind:Y,simpleName:"Charsets",interfaces:[]};var cp,pp,hp,_p=null;function fp(){return null===_p&&new up,_p}function dp(t){Hc.call(this,t),this.name=t}function mp(t){C.call(this),this.message_dl21pz$_0=t,this.cause_5de4tn$_0=null,e.captureStack(C,this),this.name="MalformedInputException"}function yp(t,e){this.charactersDecoded=t,this.bytesConsumed=e}function $p(t,n,i){if(0===i)return new yp("",0);try{var r=L(i,t.byteLength),o=n.decode(t.subarray(0,r));if(o.length<=i)return new yp(o,r)}catch(t){}return function(t,n,i){for(var r,o=L(i>=268435455?2147483647:8*i|0,t.byteLength);o>8;){try{var a=n.decode(t.subarray(0,o));if(a.length<=i)return new yp(a,o)}catch(t){}o=o/2|0}for(o=8;o>0;){try{var s=n.decode(t.subarray(0,o));if(s.length<=i)return new yp(s,o)}catch(t){}o=o-1|0}try{n.decode(t)}catch(t){throw e.isType(t,C)?new mp("Failed to decode bytes: "+(null!=(r=t.message)?r:"no cause provided")):t}throw new mp("Unable to decode buffer")}(t,n,i)}function vp(t,e,n,i){if(e>=n)return 0;for(var r,o=i.writePosition,a=i.memory.slice_vux9f0$(o,i.limit-o|0).view,s=new Int8Array(a.buffer,a.byteOffset,a.byteLength),l=0,u=e;u255&&gp(c),s[(r=l,l=r+1|0,r)]=d(c)}var p=l;return i.commitWritten_za3lpa$(p),n-e|0}function gp(t){throw new mp("The character with unicode point "+t+" couldn't be mapped to ISO-8859-1 character")}function bp(t,e){xt.call(this),this.name$=t,this.ordinal$=e}function wp(){wp=function(){},pp=new bp("BIG_ENDIAN",0),hp=new bp("LITTLE_ENDIAN",1),Sp()}function xp(){return wp(),pp}function kp(){return wp(),hp}function Ep(){Cp=this,this.native_0=null;var t=new ArrayBuffer(4),e=new Int32Array(t),n=new DataView(t);e[0]=287454020,this.native_0=287454020===n.getInt32(0,!0)?kp():xp()}dp.prototype.newEncoder=function(){return new Zc(this)},dp.prototype.newDecoder=function(){return new rp(this)},dp.$metadata$={kind:p,simpleName:"CharsetImpl",interfaces:[Hc]},dp.prototype.component1=function(){return this.name},dp.prototype.copy_61zpoe$=function(t){return new dp(void 0===t?this.name:t)},dp.prototype.toString=function(){return"CharsetImpl(name="+e.toString(this.name)+")"},dp.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.name)|0},dp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)},Object.defineProperty(mp.prototype,"message",{get:function(){return this.message_dl21pz$_0}}),Object.defineProperty(mp.prototype,"cause",{get:function(){return this.cause_5de4tn$_0}}),mp.$metadata$={kind:p,simpleName:"MalformedInputException",interfaces:[C]},yp.$metadata$={kind:p,simpleName:"DecodeBufferResult",interfaces:[]},yp.prototype.component1=function(){return this.charactersDecoded},yp.prototype.component2=function(){return this.bytesConsumed},yp.prototype.copy_bm4lxs$=function(t,e){return new yp(void 0===t?this.charactersDecoded:t,void 0===e?this.bytesConsumed:e)},yp.prototype.toString=function(){return"DecodeBufferResult(charactersDecoded="+e.toString(this.charactersDecoded)+", bytesConsumed="+e.toString(this.bytesConsumed)+")"},yp.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.charactersDecoded)|0)+e.hashCode(this.bytesConsumed)|0},yp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.charactersDecoded,t.charactersDecoded)&&e.equals(this.bytesConsumed,t.bytesConsumed)},Ep.prototype.nativeOrder=function(){return this.native_0},Ep.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Cp=null;function Sp(){return wp(),null===Cp&&new Ep,Cp}function Tp(t,e,n){this.closure$sub=t,this.closure$block=e,this.closure$array=n,wu.call(this)}function Op(){}function Np(){}function Pp(t){this.closure$message=t,Il.call(this)}function Ap(t,n,i,r){if(void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.isType(t,Mi))return Dp(t,n,i,r);Rp(t,n,i,r)!==r&&tl(r)}function jp(t,n,i,r){if(void 0===i&&(i=0),void 0===r&&(r=n.byteLength-i|0),e.isType(t,Mi))return Mp(t,n,i,r);Ip(t,n,i,r)!==r&&tl(r)}function Lp(t,n,i,r){if(void 0===i&&(i=0),void 0===r&&(r=n.byteLength-i|0),e.isType(t,Mi))return Bp(t,n,i,r);zp(t,n,i,r)!==r&&tl(r)}function Rp(t,n,i,r){var o;return void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.isType(t,Mi)?Up(t,n,i,r):zp(t,e.isType(o=n,Object)?o:c(),i,r)}function Ip(t,n,i,r){if(void 0===i&&(i=0),void 0===r&&(r=n.byteLength-i|0),e.isType(t,Mi))return Fp(t,n,i,r);var o={v:0};t:do{var a,s,l=!0;if(null==(a=su(t,1)))break t;var u=a;try{for(;;){var c=u,p=c.writePosition-c.readPosition|0,h=r-o.v|0,_=g.min(p,h);if(cc(c.memory,n,c.readPosition,_,o.v),o.v=o.v+_|0,!(o.v0&&(r.v=r.v+u|0),!(r.vt.byteLength)throw b("Destination buffer overflow: length = "+i+", buffer capacity "+t.byteLength);n>=0||new Gp(Yp).doFail(),(n+i|0)<=t.byteLength||new Gp(Vp).doFail(),th(e.isType(this,Vi)?this:c(),t.buffer,t.byteOffset+n|0,i)},Hp.prototype.readAvailable_p0d4q1$=function(t,n,i){var r=this.writePosition-this.readPosition|0;if(0===r)return-1;var o=g.min(i,r);return eh(e.isType(this,Vi)?this:c(),t,n,o),o},Hp.prototype.readFully_gsnag5$=function(t,n,i){eh(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_gsnag5$=function(t,n,i){return ih(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_qr0era$=function(t,n){To(e.isType(this,Vi)?this:c(),t,n)},Hp.prototype.append_ezbsdh$=function(t,e,n){if(vr(this,null!=t?t:"null",e,n)!==n)throw B("Not enough free space to append char sequence");return this},Hp.prototype.append_gw00v9$=function(t){return null==t?this.append_gw00v9$("null"):this.append_ezbsdh$(t,0,t.length)},Hp.prototype.append_8chfmy$=function(t,e,n){if($r(this,t,e,n)!==n)throw B("Not enough free space to append char sequence");return this},Hp.prototype.append_s8itvh$=function(t){return gr(e.isType(this,Vi)?this:c(),t),this},Hp.prototype.write_mj6st8$=function(t,n,i){co(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.write_gsnag5$=function(t,n,i){rh(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readShort=function(){return Lr(e.isType(this,Vi)?this:c())},Hp.prototype.readInt=function(){return zr(e.isType(this,Vi)?this:c())},Hp.prototype.readFloat=function(){return qr(e.isType(this,Vi)?this:c())},Hp.prototype.readDouble=function(){return Hr(e.isType(this,Vi)?this:c())},Hp.prototype.readFully_mj6st8$=function(t,n,i){ao(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_359eei$=function(t,n,i){ho(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_nd5v6f$=function(t,n,i){mo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_rfv6wg$=function(t,n,i){vo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_kgymra$=function(t,n,i){wo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readFully_6icyh1$=function(t,n,i){Eo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_mj6st8$=function(t,n,i){return lo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_359eei$=function(t,n,i){return _o(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_nd5v6f$=function(t,n,i){return yo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_rfv6wg$=function(t,n,i){return go(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_kgymra$=function(t,n,i){return xo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.readAvailable_6icyh1$=function(t,n,i){return Co(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.peekTo_99qa0s$=function(t){return Ua(e.isType(this,Np)?this:c(),t)},Hp.prototype.readLong=function(){return Br(e.isType(this,Vi)?this:c())},Hp.prototype.writeShort_mq22fl$=function(t){Vr(e.isType(this,Vi)?this:c(),t)},Hp.prototype.writeInt_za3lpa$=function(t){Xr(e.isType(this,Vi)?this:c(),t)},Hp.prototype.writeFloat_mx4ult$=function(t){no(e.isType(this,Vi)?this:c(),t)},Hp.prototype.writeDouble_14dthe$=function(t){ro(e.isType(this,Vi)?this:c(),t)},Hp.prototype.writeFully_mj6st8$=function(t,n,i){co(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_359eei$=function(t,n,i){fo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_nd5v6f$=function(t,n,i){$o(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_rfv6wg$=function(t,n,i){bo(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_kgymra$=function(t,n,i){ko(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_6icyh1$=function(t,n,i){So(e.isType(this,Vi)?this:c(),t,n,i)},Hp.prototype.writeFully_qr0era$=function(t,n){No(e.isType(this,Vi)?this:c(),t,n)},Hp.prototype.fill_3pq026$=function(t,n){yr(e.isType(this,Vi)?this:c(),t,n)},Hp.prototype.writeLong_s8cxhz$=function(t){Qr(e.isType(this,Vi)?this:c(),t)},Hp.prototype.writeBuffer_qr0era$=function(t,n){return No(e.isType(this,Vi)?this:c(),t,n),n},Hp.prototype.flush=function(){},Hp.prototype.readableView=function(){var t=this.readPosition,e=this.writePosition;return t===e?Qp().EmptyDataView_0:0===t&&e===this.content_0.byteLength?this.memory.view:new DataView(this.content_0,t,e-t|0)},Hp.prototype.writableView=function(){var t=this.writePosition,e=this.limit;return t===e?Qp().EmptyDataView_0:0===t&&e===this.content_0.byteLength?this.memory.view:new DataView(this.content_0,t,e-t|0)},Hp.prototype.readDirect_5b066c$=w("ktor-ktor-io.io.ktor.utils.io.core.IoBuffer.readDirect_5b066c$",x((function(){var t=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e){var n=e(this.readableView());if(!(n>=0))throw t(("The returned value from block function shouldn't be negative: "+n).toString());return this.discard_za3lpa$(n),n}}))),Hp.prototype.writeDirect_5b066c$=w("ktor-ktor-io.io.ktor.utils.io.core.IoBuffer.writeDirect_5b066c$",x((function(){var t=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e){var n=e(this.writableView());if(!(n>=0))throw t(("The returned value from block function shouldn't be negative: "+n).toString());if(!(n<=(this.limit-this.writePosition|0))){var i="The returned value from block function is too big: "+n+" > "+(this.limit-this.writePosition|0);throw t(i.toString())}return this.commitWritten_za3lpa$(n),n}}))),Hp.prototype.release_duua06$=function(t){jo(this,t)},Hp.prototype.close=function(){throw R("close for buffer view is not supported")},Hp.prototype.toString=function(){return"Buffer[readable = "+(this.writePosition-this.readPosition|0)+", writable = "+(this.limit-this.writePosition|0)+", startGap = "+this.startGap+", endGap = "+(this.capacity-this.limit|0)+"]"},Object.defineProperty(Kp.prototype,"ReservedSize",{get:function(){return 8}}),Wp.prototype.produceInstance=function(){return new Hp(ic().alloc_za3lpa$(4096),null)},Wp.prototype.clearInstance_trkh7z$=function(t){var e=Mh.prototype.clearInstance_trkh7z$.call(this,t);return e.unpark_8be2vx$(),e.reset(),e},Wp.prototype.validateInstance_trkh7z$=function(t){var e;Mh.prototype.validateInstance_trkh7z$.call(this,t),0!==t.referenceCount&&new Gp((e=t,function(){return"unable to recycle buffer: buffer view is in use (refCount = "+e.referenceCount+")"})).doFail(),null!=t.origin&&new Gp(Xp).doFail()},Wp.prototype.disposeInstance_trkh7z$=function(t){ic().free_vn6nzs$(t.memory),t.unlink_8be2vx$()},Wp.$metadata$={kind:p,interfaces:[Mh]},Zp.prototype.borrow=function(){return new Hp(ic().alloc_za3lpa$(4096),null)},Zp.prototype.recycle_trkh7z$=function(t){ic().free_vn6nzs$(t.memory)},Zp.$metadata$={kind:p,interfaces:[bu]},Kp.$metadata$={kind:Y,simpleName:"Companion",interfaces:[]};var Jp=null;function Qp(){return null===Jp&&new Kp,Jp}function th(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.byteLength-n|0);var r=t.memory,o=t.readPosition;if((t.writePosition-o|0)t.readPosition))return-1;var r=t.writePosition-t.readPosition|0,o=g.min(i,r);return th(t,e,n,o),o}function ih(t,e,n,i){if(void 0===n&&(n=0),void 0===i&&(i=e.byteLength-n|0),!(t.writePosition>t.readPosition))return-1;var r=t.writePosition-t.readPosition|0,o=g.min(i,r);return eh(t,e,n,o),o}function rh(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.byteLength-n|0);var r=t.memory,o=t.writePosition;if((t.limit-o|0)=0))throw B("Check failed.".toString());if(!(o>=0))throw B("Check failed.".toString());if(!((r+o|0)<=i.length))throw B("Check failed.".toString());for(var s=yh(t.memory),l=t.readPosition,u=l,p=u,h=t.writePosition-t.readPosition|0,_=p+g.min(o,h)|0;;){var f=u<_;if(f&&(f=!(s[u]===n)),!f)break;u=u+1|0}var d=u-l|0;return(e.isType(a=i,Int8Array)?a:c()).set(s.subarray(l,_),r),t.discardUntilIndex_kcn2v3$(u),d}function bh(t,n,i,r,o,a){var s;if(!(o>=0))throw B("Check failed.".toString());if(!(a>=0))throw B("Check failed.".toString());if(!((o+a|0)<=r.length))throw B("Check failed.".toString());if(n===i)throw B("Check failed.".toString());for(var l=yh(t.memory),u=t.readPosition,p=u,h=p,_=t.writePosition-t.readPosition|0,f=h+g.min(a,_)|0;;){var d=p=0))throw new lt("offset ("+t+") shouldn't be negative");if(!(e>=0))throw new lt("length ("+e+") shouldn't be negative");if(!((t+e|0)<=n.length))throw new lt("offset ("+t+") + length ("+e+") > bytes.size ("+n.length+")");throw Et()}function Eh(t,e,n){var i,r=t.length;if(!((n+r|0)<=e.length))throw b("Failed requirement.".toString());for(var o=n,a=0;a0)throw b("Unable to make a new ArrayBuffer: packet is too big");e=n.toInt()}var i=new ArrayBuffer(e);return Mp(t,i,0,e),i}function Rh(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);for(var r={v:0},o={v:i};o.v>0;){var a=t.prepareWriteHead_za3lpa$(1);try{var s=a.limit-a.writePosition|0,l=o.v,u=g.min(s,l);if(rh(a,e,r.v+n|0,u),r.v=r.v+u|0,o.v=o.v-u|0,!(u>=0))throw B("The returned value shouldn't be negative".toString())}finally{t.afterHeadWrite()}}}var Ih=w("ktor-ktor-io.io.ktor.utils.io.js.sendPacket_3qvznb$",x((function(){var n=t.io.ktor.utils.io.js.sendPacket_ac3gnr$,i=t.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,r=Error;return function(t,o){var a,s=i(0);try{o(s),a=s.build()}catch(t){throw e.isType(t,r)?(s.release(),t):t}n(t,a)}}))),zh=w("ktor-ktor-io.io.ktor.utils.io.js.packet_lwnq0v$",x((function(){var n=t.io.ktor.utils.io.bits.Memory,i=DataView,r=e.throwCCE,o=t.io.ktor.utils.io.bits.of_qdokgt$,a=t.io.ktor.utils.io.core.IoBuffer,s=t.io.ktor.utils.io.core.internal.ChunkBuffer,l=t.io.ktor.utils.io.core.ByteReadPacket_init_mfe2hi$;return function(t){var u;return l(new a(o(n.Companion,e.isType(u=t.data,i)?u:r()),null),s.Companion.NoPool_8be2vx$)}}))),Dh=w("ktor-ktor-io.io.ktor.utils.io.js.sendPacket_xzmm9y$",x((function(){var n=t.io.ktor.utils.io.js.sendPacket_f89g06$,i=t.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,r=Error;return function(t,o){var a,s=i(0);try{o(s),a=s.build()}catch(t){throw e.isType(t,r)?(s.release(),t):t}n(t,a)}})));function Mh(t){this.capacity_7nvyry$_0=t,this.instances_j5hzgy$_0=e.newArray(this.capacity,null),this.size_p9jgx3$_0=0}Object.defineProperty(Mh.prototype,"capacity",{get:function(){return this.capacity_7nvyry$_0}}),Mh.prototype.disposeInstance_trkh7z$=function(t){},Mh.prototype.clearInstance_trkh7z$=function(t){return t},Mh.prototype.validateInstance_trkh7z$=function(t){},Mh.prototype.borrow=function(){var t;if(0===this.size_p9jgx3$_0)return this.produceInstance();var n=(this.size_p9jgx3$_0=this.size_p9jgx3$_0-1|0,this.size_p9jgx3$_0),i=e.isType(t=this.instances_j5hzgy$_0[n],Ct)?t:c();return this.instances_j5hzgy$_0[n]=null,this.clearInstance_trkh7z$(i)},Mh.prototype.recycle_trkh7z$=function(t){var e;this.validateInstance_trkh7z$(t),this.size_p9jgx3$_0===this.capacity?this.disposeInstance_trkh7z$(t):this.instances_j5hzgy$_0[(e=this.size_p9jgx3$_0,this.size_p9jgx3$_0=e+1|0,e)]=t},Mh.prototype.dispose=function(){var t,n;t=this.size_p9jgx3$_0;for(var i=0;i=2147483647&&Ll(n,"offset"),lc(t,e,n.toInt(),i,r)},Hh.loadByteArray_dy6oua$=hi,Hh.loadUByteArray_moiot2$=_i,Hh.loadUByteArray_r80dt$=fi,Hh.loadShortArray_8jnas7$=Rc,Hh.loadUShortArray_fu1ix4$=di,Hh.loadShortArray_ew3eeo$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Rc(t,e.toInt(),n,i,r)},Hh.loadUShortArray_w2wo2p$=mi,Hh.loadIntArray_kz60l8$=Ic,Hh.loadUIntArray_795lej$=yi,Hh.loadIntArray_qrle83$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Ic(t,e.toInt(),n,i,r)},Hh.loadUIntArray_qcxtu4$=$i,Hh.loadLongArray_2ervmr$=zc,Hh.loadULongArray_1mgmjm$=vi,Hh.loadLongArray_z08r3q$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),zc(t,e.toInt(),n,i,r)},Hh.loadULongArray_lta2n9$=gi,Hh.useMemory_jjtqwx$=Xu,Hh.storeByteArray_ngtxw7$=bi,Hh.storeByteArray_dy6oua$=wi,Hh.storeUByteArray_moiot2$=xi,Hh.storeUByteArray_r80dt$=ki,Hh.storeShortArray_8jnas7$=Bc,Hh.storeUShortArray_fu1ix4$=Ei,Hh.storeShortArray_ew3eeo$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Bc(t,e.toInt(),n,i,r)},Hh.storeUShortArray_w2wo2p$=Ci,Hh.storeIntArray_kz60l8$=Uc,Hh.storeUIntArray_795lej$=Si,Hh.storeIntArray_qrle83$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Uc(t,e.toInt(),n,i,r)},Hh.storeUIntArray_qcxtu4$=Ti,Hh.storeLongArray_2ervmr$=Fc,Hh.storeULongArray_1mgmjm$=Oi,Hh.storeLongArray_z08r3q$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Fc(t,e.toInt(),n,i,r)},Hh.storeULongArray_lta2n9$=Ni;var Yh=qh.charsets||(qh.charsets={});Yh.encode_6xuvjk$=function(t,e,n,i,r){zi(t,r,e,n,i)},Yh.encodeToByteArrayImpl_fj4osb$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length),Qc(t,e,n,i)},Yh.encode_fj4osb$=function(t,n,i,r){var o;void 0===i&&(i=0),void 0===r&&(r=n.length);var a=mh(0);try{zi(t,a,n,i,r),o=a.build()}catch(t){throw e.isType(t,C)?(a.release(),t):t}return o},Yh.encodeUTF8_45773h$=function(t,n){var i,r=mh(0);try{ep(t,n,r),i=r.build()}catch(t){throw e.isType(t,C)?(r.release(),t):t}return i},Yh.encode_ufq2gc$=Pi,Yh.decode_lb8wo3$=Ai,Yh.encodeArrayImpl_bptnt4$=ji,Yh.encodeToByteArrayImpl1_5lnu54$=Li,Yh.sizeEstimate_i9ek5c$=Ri,Yh.encodeToImpl_nctdml$=zi,Gh.read_q4ikbw$=As,Object.defineProperty(Mi,"Companion",{get:Gi}),Gh.AbstractInput_init_njy0gf$=function(t,n,i,r){var o;return void 0===t&&(t=Qp().Empty),void 0===n&&(n=Fo(t)),void 0===i&&(i=Nl().Pool),r=r||Object.create(Mi.prototype),Mi.call(r,e.isType(o=t,bl)?o:c(),n,i),r},Gh.AbstractInput=Mi,Gh.AbstractOutput_init_2bs5fo$=Yi,Gh.AbstractOutput_init=function(t){return t=t||Object.create(Hi.prototype),Yi(Nl().Pool,t),t},Gh.AbstractOutput=Hi,Object.defineProperty(Vi,"Companion",{get:Xi}),Gh.canRead_abnlgx$=Ji,Gh.canWrite_abnlgx$=Qi,Gh.read_kmyesx$=tr,Gh.write_kmyesx$=er,Gh.discardFailed_6xvm5r$=nr,Gh.commitWrittenFailed_6xvm5r$=ir,Gh.rewindFailed_6xvm5r$=rr,Gh.startGapReservationFailedDueToLimit_g087h2$=or,Gh.startGapReservationFailed_g087h2$=ar,Gh.endGapReservationFailedDueToCapacity_g087h2$=sr,Gh.endGapReservationFailedDueToStartGap_g087h2$=lr,Gh.endGapReservationFailedDueToContent_g087h2$=ur,Gh.restoreStartGap_g087h2$=cr,Gh.InsufficientSpaceException_init_vux9f0$=function(t,e,n){return n=n||Object.create(pr.prototype),pr.call(n,"Not enough free space to write "+t+" bytes, available "+e+" bytes."),n},Gh.InsufficientSpaceException_init_3m52m6$=hr,Gh.InsufficientSpaceException_init_3pjtqy$=function(t,e,n){return n=n||Object.create(pr.prototype),pr.call(n,"Not enough free space to write "+t.toString()+" bytes, available "+e.toString()+" bytes."),n},Gh.InsufficientSpaceException=pr,Gh.writeBufferAppend_eajdjw$=_r,Gh.writeBufferPrepend_tfs7w2$=fr,Gh.fill_ffmap0$=mr,Gh.fill_j129ft$=function(t,e,n){mr(t,e,n.data)},Gh.fill_cz5x29$=yr,Gh.pushBack_cni1rh$=function(t,e){t.rewind_za3lpa$(e)},Gh.makeView_abnlgx$=function(t){return t.duplicate()},Gh.makeView_n6y6i3$=function(t){return t.duplicate()},Gh.flush_abnlgx$=function(t){},Gh.appendChars_uz44xi$=$r,Gh.appendChars_ske834$=vr,Gh.append_xy0ugi$=gr,Gh.append_mhxg24$=function t(e,n){return null==n?t(e,"null"):br(e,n,0,n.length)},Gh.append_j2nfp0$=br,Gh.append_luj41z$=function(t,e,n,i){return br(t,new Hl(e,0,e.length),n,i)},Gh.readText_ky2b9g$=function(t,e,n,i,r){return void 0===r&&(r=2147483647),ap(e,t,n,0,r)},Gh.release_3omthh$=function(t,n){var i,r;(e.isType(i=t,bl)?i:c()).release_2bs5fo$(e.isType(r=n,gu)?r:c())},Gh.tryPeek_abnlgx$=function(t){return t.tryPeekByte()},Gh.readFully_e6hzc$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=t.memory,o=t.readPosition;if((t.writePosition-o|0)=2||new Tr(Or("short unsigned integer",2)).doFail(),e.v=new I(n.view.getInt16(i,!1)),t.discardExact_za3lpa$(2),e.v},Gh.readUShort_396eqd$=Ir,Gh.readInt_abnlgx$=zr,Gh.readInt_396eqd$=Dr,Gh.readUInt_abnlgx$=function(t){var e={v:null},n=t.memory,i=t.readPosition;return(t.writePosition-i|0)>=4||new Tr(Or("regular unsigned integer",4)).doFail(),e.v=new z(n.view.getInt32(i,!1)),t.discardExact_za3lpa$(4),e.v},Gh.readUInt_396eqd$=Mr,Gh.readLong_abnlgx$=Br,Gh.readLong_396eqd$=Ur,Gh.readULong_abnlgx$=function(t){var n={v:null},i=t.memory,r=t.readPosition;(t.writePosition-r|0)>=8||new Tr(Or("long unsigned integer",8)).doFail();var o=i,a=r;return n.v=new D(e.Long.fromInt(o.view.getUint32(a,!1)).shiftLeft(32).or(e.Long.fromInt(o.view.getUint32(a+4|0,!1)))),t.discardExact_za3lpa$(8),n.v},Gh.readULong_396eqd$=Fr,Gh.readFloat_abnlgx$=qr,Gh.readFloat_396eqd$=Gr,Gh.readDouble_abnlgx$=Hr,Gh.readDouble_396eqd$=Yr,Gh.writeShort_cx5lgg$=Vr,Gh.writeShort_89txly$=Kr,Gh.writeUShort_q99vxf$=function(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<2)throw hr("short unsigned integer",2,r);n.view.setInt16(i,e.data,!1),t.commitWritten_za3lpa$(2)},Gh.writeUShort_sa3b8p$=Wr,Gh.writeInt_cni1rh$=Xr,Gh.writeInt_q5mzkd$=Zr,Gh.writeUInt_xybpjq$=function(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<4)throw hr("regular unsigned integer",4,r);n.view.setInt32(i,e.data,!1),t.commitWritten_za3lpa$(4)},Gh.writeUInt_tiqx5o$=Jr,Gh.writeLong_xy6qu0$=Qr,Gh.writeLong_tilyfy$=to,Gh.writeULong_cwjw0b$=function(t,e){var n=t.memory,i=t.writePosition,r=t.limit-i|0;if(r<8)throw hr("long unsigned integer",8,r);var o=n,a=i,s=e.data;o.view.setInt32(a,s.shiftRight(32).toInt(),!1),o.view.setInt32(a+4|0,s.and(J).toInt(),!1),t.commitWritten_za3lpa$(8)},Gh.writeULong_89885t$=eo,Gh.writeFloat_d48dmo$=no,Gh.writeFloat_8gwps6$=io,Gh.writeDouble_in4kvh$=ro,Gh.writeDouble_kny06r$=oo,Gh.readFully_7ntqvp$=ao,Gh.readFully_ou1upd$=so,Gh.readFully_tx517c$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),ao(t,e.storage,n,i)},Gh.readAvailable_7ntqvp$=lo,Gh.readAvailable_ou1upd$=uo,Gh.readAvailable_tx517c$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),lo(t,e.storage,n,i)},Gh.writeFully_7ntqvp$=co,Gh.writeFully_ou1upd$=po,Gh.writeFully_tx517c$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),co(t,e.storage,n,i)},Gh.readFully_fs9n6h$=ho,Gh.readFully_4i50ju$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),ho(t,e.storage,n,i)},Gh.readAvailable_fs9n6h$=_o,Gh.readAvailable_4i50ju$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),_o(t,e.storage,n,i)},Gh.writeFully_fs9n6h$=fo,Gh.writeFully_4i50ju$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),fo(t,e.storage,n,i)},Gh.readFully_lhisoq$=mo,Gh.readFully_n25sf1$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),mo(t,e.storage,n,i)},Gh.readAvailable_lhisoq$=yo,Gh.readAvailable_n25sf1$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),yo(t,e.storage,n,i)},Gh.writeFully_lhisoq$=$o,Gh.writeFully_n25sf1$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),$o(t,e.storage,n,i)},Gh.readFully_de8bdr$=vo,Gh.readFully_8v2yxw$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),vo(t,e.storage,n,i)},Gh.readAvailable_de8bdr$=go,Gh.readAvailable_8v2yxw$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),go(t,e.storage,n,i)},Gh.writeFully_de8bdr$=bo,Gh.writeFully_8v2yxw$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),bo(t,e.storage,n,i)},Gh.readFully_7tydzb$=wo,Gh.readAvailable_7tydzb$=xo,Gh.writeFully_7tydzb$=ko,Gh.readFully_u5abqk$=Eo,Gh.readAvailable_u5abqk$=Co,Gh.writeFully_u5abqk$=So,Gh.readFully_i3yunz$=To,Gh.readAvailable_i3yunz$=Oo,Gh.writeFully_kxmhld$=function(t,e){var n=e.writePosition-e.readPosition|0,i=t.memory,r=t.writePosition,o=t.limit-r|0;if(o0)&&(null==(n=e.next)||t(n))},Gh.coerceAtMostMaxInt_nzsbcz$=Go,Gh.coerceAtMostMaxIntOrFail_z4ke79$=Ho,Gh.peekTo_twshuo$=Yo,Gh.BufferLimitExceededException=Vo,Gh.BytePacketBuilder_za3lpa$=mh,Gh.reset_en5wxq$=function(t){t.release()},Gh.BytePacketBuilderPlatformBase=Wo,Gh.BytePacketBuilderBase=Xo,Gh.BytePacketBuilder=Jo,Object.defineProperty(Qo,"Companion",{get:na}),Gh.ByteReadPacket_init_mfe2hi$=ia,Gh.ByteReadPacket_init_bioeb0$=function(t,e,n){return n=n||Object.create(Qo.prototype),Qo.call(n,t,Fo(t),e),n},Gh.ByteReadPacket=Qo,Gh.ByteReadPacketPlatformBase_init_njy0gf$=function(t,n,i,r){var o;return r=r||Object.create(ra.prototype),ra.call(r,e.isType(o=t,bl)?o:c(),n,i),r},Gh.ByteReadPacketPlatformBase=ra,Gh.ByteReadPacket_1qge3v$=function(t,n,i,r){var o;void 0===n&&(n=0),void 0===i&&(i=t.length);var a=e.isType(o=t,Int8Array)?o:c(),s=new Tp(0===n&&i===t.length?a.buffer:a.buffer.slice(n,n+i|0),r,t),l=s.borrow();return l.resetForRead(),ia(l,s)},Gh.ByteReadPacket_mj6st8$=oa,Gh.addSuppressedInternal_oh0dqn$=function(t,e){},Gh.use_jh8f9t$=aa,Gh.copyTo_tc38ta$=function(t,n){if(!e.isType(t,Mi)||!e.isType(n,Hi))return function(t,n){var i=Nl().Pool.borrow(),r=u;try{for(;;){i.resetForWrite();var o=Sa(t,i);if(-1===o)break;r=r.add(e.Long.fromInt(o)),rs(n,i)}return r}finally{i.release_2bs5fo$(Nl().Pool)}}(t,n);for(var i=u;;){var r=t.stealAll_8be2vx$();if(null!=r)i=i.add(Fo(r)),n.appendChain_pvnryh$(r);else if(null==t.prepareRead_za3lpa$(1))break}return i},Gh.ExperimentalIoApi=sa,Gh.discard_7wsnj1$=function(t){return t.discard_s8cxhz$(l)},Gh.discardExact_nd91nq$=la,Gh.discardExact_j319xh$=ua,Vh.prepareReadFirstHead_j319xh$=su,Vh.prepareReadNextHead_x2nit9$=uu,Vh.completeReadHead_x2nit9$=lu,Gh.takeWhile_nkhzd2$=ca,Gh.takeWhileSize_y109dn$=pa,Gh.peekCharUtf8_7wsnj1$=function(t){var e=t.tryPeek();if(0==(128&e))return V(e);if(-1===e)throw new Th("Failed to peek a char: end of input");return function(t,e){var n={v:63},i={v:!1},r=Fl(e);t:do{var o,a,s=!0;if(null==(o=su(t,r)))break t;var l=o,u=r;try{e:do{var c,p=l,h=p.writePosition-p.readPosition|0;if(h>=u)try{var _,f=l;n:do{for(var d={v:0},m={v:0},y={v:0},$=f.memory,v=f.readPosition,g=f.writePosition,b=v;b>=1,d.v=d.v+1|0;if(y.v=d.v,d.v=d.v-1|0,y.v>(g-b|0)){f.discardExact_za3lpa$(b-v|0),_=y.v;break n}}else if(m.v=m.v<<6|127&w,d.v=d.v-1|0,0===d.v){if(Ql(m.v)){var C=K(V(m.v));i.v=!0,n.v=H(C),f.discardExact_za3lpa$(b-v-y.v+1|0),_=-1;break n}if(tu(m.v)){var S=K(V(nu(m.v)));i.v=!0,n.v=H(S);var T=!0;if(!T){var O=K(V(eu(m.v)));i.v=!0,n.v=H(O),T=!0}if(T){f.discardExact_za3lpa$(b-v-y.v+1|0),_=-1;break n}}else Jl(m.v);m.v=0}}var N=g-v|0;f.discardExact_za3lpa$(N),_=0}while(0);u=_}finally{var P=l;c=P.writePosition-P.readPosition|0}else c=h;if(s=!1,0===c)a=uu(t,l);else{var A=c0)}finally{s&&lu(t,l)}}while(0);if(!i.v)throw new ru("No UTF-8 character found");return n.v}(t,e)},Gh.forEach_xalon3$=ha,Gh.readAvailable_tx93nr$=function(t,e,n){return void 0===n&&(n=e.limit-e.writePosition|0),Sa(t,e,n)},Gh.readAvailableOld_ja303r$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ba(t,e,n,i)},Gh.readAvailableOld_ksob8n$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),wa(t,e,n,i)},Gh.readAvailableOld_8ob2ms$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),xa(t,e,n,i)},Gh.readAvailableOld_1rz25p$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ka(t,e,n,i)},Gh.readAvailableOld_2tjpx5$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),Ea(t,e,n,i)},Gh.readAvailableOld_rlf4bm$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),Ca(t,e,n,i)},Gh.readFully_tx93nr$=function(t,e,n){void 0===n&&(n=e.limit-e.writePosition|0),va(t,e,n)},Gh.readFullyOld_ja303r$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),_a(t,e,n,i)},Gh.readFullyOld_ksob8n$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),fa(t,e,n,i)},Gh.readFullyOld_8ob2ms$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),da(t,e,n,i)},Gh.readFullyOld_1rz25p$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ma(t,e,n,i)},Gh.readFullyOld_2tjpx5$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ya(t,e,n,i)},Gh.readFullyOld_rlf4bm$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),$a(t,e,n,i)},Gh.readFully_ja303r$=_a,Gh.readFully_ksob8n$=fa,Gh.readFully_8ob2ms$=da,Gh.readFully_1rz25p$=ma,Gh.readFully_2tjpx5$=ya,Gh.readFully_rlf4bm$=$a,Gh.readFully_n4diq5$=va,Gh.readFully_em5cpx$=function(t,n,i,r){ga(t,n,e.Long.fromInt(i),e.Long.fromInt(r))},Gh.readFully_czhrh1$=ga,Gh.readAvailable_ja303r$=ba,Gh.readAvailable_ksob8n$=wa,Gh.readAvailable_8ob2ms$=xa,Gh.readAvailable_1rz25p$=ka,Gh.readAvailable_2tjpx5$=Ea,Gh.readAvailable_rlf4bm$=Ca,Gh.readAvailable_n4diq5$=Sa,Gh.readAvailable_em5cpx$=function(t,n,i,r){return Ta(t,n,e.Long.fromInt(i),e.Long.fromInt(r)).toInt()},Gh.readAvailable_czhrh1$=Ta,Gh.readShort_l8hihx$=function(t,e){return _(e,xp())?Fa(t):Hu(Fa(t))},Gh.readInt_l8hihx$=function(t,e){return _(e,xp())?Ga(t):Yu(Ga(t))},Gh.readLong_l8hihx$=function(t,e){return _(e,xp())?Ya(t):Vu(Ya(t))},Gh.readFloat_l8hihx$=function(t,e){return _(e,xp())?Ka(t):Ku(Ka(t))},Gh.readDouble_l8hihx$=function(t,e){return _(e,xp())?Xa(t):Wu(Xa(t))},Gh.readShortLittleEndian_7wsnj1$=function(t){return Hu(Fa(t))},Gh.readIntLittleEndian_7wsnj1$=function(t){return Yu(Ga(t))},Gh.readLongLittleEndian_7wsnj1$=function(t){return Vu(Ya(t))},Gh.readFloatLittleEndian_7wsnj1$=function(t){return Ku(Ka(t))},Gh.readDoubleLittleEndian_7wsnj1$=function(t){return Wu(Xa(t))},Gh.readShortLittleEndian_abnlgx$=function(t){return Hu(Lr(t))},Gh.readIntLittleEndian_abnlgx$=function(t){return Yu(zr(t))},Gh.readLongLittleEndian_abnlgx$=function(t){return Vu(Br(t))},Gh.readFloatLittleEndian_abnlgx$=function(t){return Ku(qr(t))},Gh.readDoubleLittleEndian_abnlgx$=function(t){return Wu(Hr(t))},Gh.readFullyLittleEndian_8s9ld4$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Oa(t,e.storage,n,i)},Gh.readFullyLittleEndian_ksob8n$=Oa,Gh.readFullyLittleEndian_bfwj6z$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Na(t,e.storage,n,i)},Gh.readFullyLittleEndian_8ob2ms$=Na,Gh.readFullyLittleEndian_dvhn02$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Pa(t,e.storage,n,i)},Gh.readFullyLittleEndian_1rz25p$=Pa,Gh.readFullyLittleEndian_2tjpx5$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),ya(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Ku(e[o])},Gh.readFullyLittleEndian_rlf4bm$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),$a(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Wu(e[o])},Gh.readAvailableLittleEndian_8s9ld4$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Aa(t,e.storage,n,i)},Gh.readAvailableLittleEndian_ksob8n$=Aa,Gh.readAvailableLittleEndian_bfwj6z$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),ja(t,e.storage,n,i)},Gh.readAvailableLittleEndian_8ob2ms$=ja,Gh.readAvailableLittleEndian_dvhn02$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),La(t,e.storage,n,i)},Gh.readAvailableLittleEndian_1rz25p$=La,Gh.readAvailableLittleEndian_2tjpx5$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=Ea(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Ku(e[a]);return r},Gh.readAvailableLittleEndian_rlf4bm$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=Ca(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Wu(e[a]);return r},Gh.readFullyLittleEndian_4i50ju$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Ra(t,e.storage,n,i)},Gh.readFullyLittleEndian_fs9n6h$=Ra,Gh.readFullyLittleEndian_n25sf1$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Ia(t,e.storage,n,i)},Gh.readFullyLittleEndian_lhisoq$=Ia,Gh.readFullyLittleEndian_8v2yxw$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),za(t,e.storage,n,i)},Gh.readFullyLittleEndian_de8bdr$=za,Gh.readFullyLittleEndian_7tydzb$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),wo(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Ku(e[o])},Gh.readFullyLittleEndian_u5abqk$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0),Eo(t,e,n,i);for(var r=n+i-1|0,o=n;o<=r;o++)e[o]=Wu(e[o])},Gh.readAvailableLittleEndian_4i50ju$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Da(t,e.storage,n,i)},Gh.readAvailableLittleEndian_fs9n6h$=Da,Gh.readAvailableLittleEndian_n25sf1$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Ma(t,e.storage,n,i)},Gh.readAvailableLittleEndian_lhisoq$=Ma,Gh.readAvailableLittleEndian_8v2yxw$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),Ba(t,e.storage,n,i)},Gh.readAvailableLittleEndian_de8bdr$=Ba,Gh.readAvailableLittleEndian_7tydzb$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=xo(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Ku(e[a]);return r},Gh.readAvailableLittleEndian_u5abqk$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=Co(t,e,n,i);if(r>0)for(var o=n+r-1|0,a=n;a<=o;a++)e[a]=Wu(e[a]);return r},Gh.peekTo_cg8jeh$=function(t,n,i,r,o){var a;return void 0===i&&(i=0),void 0===r&&(r=1),void 0===o&&(o=2147483647),Ua(t,e.isType(a=n,Vi)?a:c(),i,r,o)},Gh.peekTo_6v858t$=Ua,Gh.readShort_7wsnj1$=Fa,Gh.readInt_7wsnj1$=Ga,Gh.readLong_7wsnj1$=Ya,Gh.readFloat_7wsnj1$=Ka,Gh.readFloatFallback_7wsnj1$=Wa,Gh.readDouble_7wsnj1$=Xa,Gh.readDoubleFallback_7wsnj1$=Za,Gh.append_a2br84$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length),t.append_ezbsdh$(e,n,i)},Gh.append_wdi0rq$=function(t,e,n,i){return void 0===n&&(n=0),void 0===i&&(i=e.length),t.append_8chfmy$(e,n,i)},Gh.writeFully_i6snlg$=Ja,Gh.writeFully_d18giu$=Qa,Gh.writeFully_yw8055$=ts,Gh.writeFully_2v9eo0$=es,Gh.writeFully_ydnkai$=ns,Gh.writeFully_avy7cl$=is,Gh.writeFully_ke2xza$=function(t,n,i){var r;void 0===i&&(i=n.writePosition-n.readPosition|0),rs(t,e.isType(r=n,Vi)?r:c(),i)},Gh.writeFully_apj91c$=rs,Gh.writeFully_35rta0$=function(t,n,i,r){os(t,n,e.Long.fromInt(i),e.Long.fromInt(r))},Gh.writeFully_bch96q$=os,Gh.fill_g2e272$=as,Vh.prepareWriteHead_6z8r11$=cu,Vh.afterHeadWrite_z1cqja$=pu,Gh.writeWhile_rh5n47$=ss,Gh.writeWhileSize_cmxbvc$=ls,Gh.writePacket_we8ufg$=us,Gh.writeShort_hklg1n$=function(t,e,n){ms(t,_(n,xp())?e:Hu(e))},Gh.writeInt_uvxpoy$=function(t,e,n){ys(t,_(n,xp())?e:Yu(e))},Gh.writeLong_5y1ywb$=function(t,e,n){gs(t,_(n,xp())?e:Vu(e))},Gh.writeFloat_gulwb$=function(t,e,n){ws(t,_(n,xp())?e:Ku(e))},Gh.writeDouble_1z13h2$=function(t,e,n){xs(t,_(n,xp())?e:Wu(e))},Gh.writeShortLittleEndian_9kfkzl$=function(t,e){ms(t,Hu(e))},Gh.writeIntLittleEndian_qu9kum$=function(t,e){ys(t,Yu(e))},Gh.writeLongLittleEndian_kb5mzd$=function(t,e){gs(t,Vu(e))},Gh.writeFloatLittleEndian_9rid5t$=function(t,e){ws(t,Ku(e))},Gh.writeDoubleLittleEndian_jgp4k2$=function(t,e){xs(t,Wu(e))},Gh.writeFullyLittleEndian_phqic5$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),cs(t,e.storage,n,i)},Gh.writeShortLittleEndian_cx5lgg$=function(t,e){Vr(t,Hu(e))},Gh.writeIntLittleEndian_cni1rh$=function(t,e){Xr(t,Yu(e))},Gh.writeLongLittleEndian_xy6qu0$=function(t,e){Qr(t,Vu(e))},Gh.writeFloatLittleEndian_d48dmo$=function(t,e){no(t,Ku(e))},Gh.writeDoubleLittleEndian_in4kvh$=function(t,e){ro(t,Wu(e))},Gh.writeFullyLittleEndian_4i50ju$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),_s(t,e.storage,n,i)},Gh.writeFullyLittleEndian_d18giu$=cs,Gh.writeFullyLittleEndian_cj6vpa$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),ps(t,e.storage,n,i)},Gh.writeFullyLittleEndian_yw8055$=ps,Gh.writeFullyLittleEndian_jyf4rf$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.size-n|0),hs(t,e.storage,n,i)},Gh.writeFullyLittleEndian_2v9eo0$=hs,Gh.writeFullyLittleEndian_ydnkai$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.length-n|0);var r=n+i|0,o={v:n},a=cu(t,4,null);try{for(var s;;){for(var l=a,u=(l.limit-l.writePosition|0)/4|0,c=r-o.v|0,p=g.min(u,c),h=o.v+p-1|0,_=o.v;_<=h;_++)no(l,Ku(e[_]));if(o.v=o.v+p|0,(s=o.v0;if(p&&(p=!(l.writePosition>l.readPosition)),!p)break;if(a=!1,null==(o=uu(t,s)))break;s=o,a=!0}}finally{a&&lu(t,s)}}while(0);return i.v},Gh.discardUntilDelimiters_16hsaj$=function(t,n,i){var r={v:u};t:do{var o,a,s=!0;if(null==(o=su(t,1)))break t;var l=o;try{for(;;){var c=l,p=vh(c,n,i);r.v=r.v.add(e.Long.fromInt(p));var h=p>0;if(h&&(h=!(c.writePosition>c.readPosition)),!h)break;if(s=!1,null==(a=uu(t,l)))break;l=a,s=!0}}finally{s&&lu(t,l)}}while(0);return r.v},Gh.readUntilDelimiter_47qg82$=Rs,Gh.readUntilDelimiters_3dgv7v$=function(t,e,n,i,r,o){if(void 0===r&&(r=0),void 0===o&&(o=i.length),e===n)return Rs(t,e,i,r,o);var a={v:r},s={v:o};t:do{var l,u,c=!0;if(null==(l=su(t,1)))break t;var p=l;try{for(;;){var h=p,_=bh(h,e,n,i,a.v,s.v);if(a.v=a.v+_|0,s.v=s.v-_|0,h.writePosition>h.readPosition||!(s.v>0))break;if(c=!1,null==(u=uu(t,p)))break;p=u,c=!0}}finally{c&&lu(t,p)}}while(0);return a.v-r|0},Gh.readUntilDelimiter_75zcs9$=Is,Gh.readUntilDelimiters_gcjxsg$=zs,Gh.discardUntilDelimiterImplMemory_7fe9ek$=function(t,e){for(var n=t.readPosition,i=n,r=t.writePosition,o=t.memory;i=2147483647&&Ll(e,"offset");var r=e.toInt();n.toNumber()>=2147483647&&Ll(n,"count"),uc(t,r,n.toInt(),i)},Hh.copyTo_1uvjz5$=cc,Hh.copyTo_duys70$=pc,Hh.copyTo_3wm8wl$=hc,Hh.copyTo_vnj7g0$=_c,Hh.get_Int8ArrayView_ktv2uy$=function(t){return new Int8Array(t.view.buffer,t.view.byteOffset,t.view.byteLength)},Hh.loadFloatAt_ad7opl$=bc,Hh.loadFloatAt_xrw27i$=wc,Hh.loadDoubleAt_ad7opl$=xc,Hh.loadDoubleAt_xrw27i$=kc,Hh.storeFloatAt_r7re9q$=Pc,Hh.storeFloatAt_ud4nyv$=Ac,Hh.storeDoubleAt_7sfcvf$=jc,Hh.storeDoubleAt_isvxss$=Lc,Hh.loadFloatArray_f2kqdl$=Dc,Hh.loadFloatArray_wismeo$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Dc(t,e.toInt(),n,i,r)},Hh.loadDoubleArray_itdtda$=Mc,Hh.loadDoubleArray_2kio7p$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Mc(t,e.toInt(),n,i,r)},Hh.storeFloatArray_f2kqdl$=qc,Hh.storeFloatArray_wismeo$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),qc(t,e.toInt(),n,i,r)},Hh.storeDoubleArray_itdtda$=Gc,Hh.storeDoubleArray_2kio7p$=function(t,e,n,i,r){void 0===i&&(i=0),void 0===r&&(r=n.length-i|0),e.toNumber()>=2147483647&&Ll(e,"offset"),Gc(t,e.toInt(),n,i,r)},Object.defineProperty(Hc,"Companion",{get:Kc}),Yh.Charset=Hc,Yh.get_name_2sg7fd$=Wc,Yh.CharsetEncoder=Xc,Yh.get_charset_x4isqx$=Jc,Yh.encodeImpl_edsj0y$=tp,Yh.encodeUTF8_sbvn4u$=ep,Yh.encodeComplete_5txte2$=np,Yh.CharsetDecoder=ip,Yh.get_charset_e9jvmp$=op,Yh.decodeBuffer_eccjnr$=ap,Yh.decode_eyhcpn$=sp,Yh.decodeExactBytes_lb8wo3$=lp,Object.defineProperty(Yh,"Charsets",{get:fp}),Yh.MalformedInputException=mp,Object.defineProperty(Yh,"MAX_CHARACTERS_SIZE_IN_BYTES_8be2vx$",{get:function(){return cp}}),Yh.DecodeBufferResult=yp,Yh.decodeBufferImpl_do9qbo$=$p,Yh.encodeISO88591_4e1bz1$=vp,Object.defineProperty(bp,"BIG_ENDIAN",{get:xp}),Object.defineProperty(bp,"LITTLE_ENDIAN",{get:kp}),Object.defineProperty(bp,"Companion",{get:Sp}),Gh.Closeable=Op,Gh.Input=Np,Gh.readFully_nu5h60$=Ap,Gh.readFully_7dohgh$=jp,Gh.readFully_hqska$=Lp,Gh.readAvailable_nu5h60$=Rp,Gh.readAvailable_7dohgh$=Ip,Gh.readAvailable_hqska$=zp,Gh.readFully_56hr53$=Dp,Gh.readFully_xvjntq$=Mp,Gh.readFully_28a27b$=Bp,Gh.readAvailable_56hr53$=Up,Gh.readAvailable_xvjntq$=Fp,Gh.readAvailable_28a27b$=qp,Object.defineProperty(Hp,"Companion",{get:Qp}),Gh.IoBuffer=Hp,Gh.readFully_xbe0h9$=th,Gh.readFully_agdgmg$=eh,Gh.readAvailable_xbe0h9$=nh,Gh.readAvailable_agdgmg$=ih,Gh.writeFully_xbe0h9$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.byteLength);var r=t.memory,o=t.writePosition;if((t.limit-o|0)t.length)&&kh(e,n,t);var r=t,o=r.byteOffset+e|0,a=r.buffer.slice(o,o+n|0),s=new Hp(Ju(sc(),a),null);s.resetForRead();var l=ia(s,Nl().NoPoolManuallyManaged_8be2vx$);return Ai(i.newDecoder(),l,2147483647)},Gh.checkIndices_khgzz8$=kh,Gh.getCharsInternal_8t7fl6$=Eh,Kh.IOException_init_61zpoe$=Sh,Kh.IOException=Ch,Kh.EOFException=Th;var Zh,Jh=qh.js||(qh.js={});Jh.readText_fwlggr$=function(t,e,n){return void 0===n&&(n=2147483647),Vs(t,Kc().forName_61zpoe$(e),n)},Jh.readText_4pep7x$=function(t,e,n,i){return void 0===e&&(e="UTF-8"),void 0===i&&(i=2147483647),Ys(t,n,Kc().forName_61zpoe$(e),i)},Jh.TextDecoderFatal_t8jjq2$=Oh,Jh.decodeWrap_i3ch5z$=Ah,Jh.decodeStream_n9pbvr$=Nh,Jh.decodeStream_6h85h0$=Ph,Jh.TextEncoderCtor_8be2vx$=jh,Jh.readArrayBuffer_xc9h3n$=Lh,Jh.writeFully_uphcrm$=function(t,e,n,i){void 0===n&&(n=0),void 0===i&&(i=e.byteLength-n|0),Rh(t,new Int8Array(e),n,i)},Jh.writeFully_xn6cfb$=Rh,Jh.sendPacket_ac3gnr$=function(t,e){t.send(Lh(e))},Jh.sendPacket_3qvznb$=Ih,Jh.packet_lwnq0v$=zh,Jh.sendPacket_f89g06$=function(t,e){t.send(Lh(e))},Jh.sendPacket_xzmm9y$=Dh,Jh.responsePacket_rezk82$=function(t){var n,i;if(n=t.responseType,_(n,"arraybuffer"))return ia(new Hp(Qu(sc(),e.isType(i=t.response,DataView)?i:c()),null),Nl().NoPoolManuallyManaged_8be2vx$);if(_(n,""))return na().Empty;throw B("Incompatible type "+t.responseType+": only ARRAYBUFFER and EMPTY are supported")},Xh.DefaultPool=Mh,St.prototype.peekTo_afjyek$=ju.prototype.peekTo_afjyek$,$n.prototype.request_za3lpa$=yn.prototype.request_za3lpa$,Ot.prototype.await_za3lpa$=$n.prototype.await_za3lpa$,Ot.prototype.request_za3lpa$=$n.prototype.request_za3lpa$,Ot.prototype.peekTo_afjyek$=St.prototype.peekTo_afjyek$,rn.prototype.cancel=S.prototype.cancel,rn.prototype.fold_3cc69b$=S.prototype.fold_3cc69b$,rn.prototype.get_j3r2sn$=S.prototype.get_j3r2sn$,rn.prototype.minusKey_yeqjby$=S.prototype.minusKey_yeqjby$,rn.prototype.plus_dqr1mp$=S.prototype.plus_dqr1mp$,rn.prototype.plus_1fupul$=S.prototype.plus_1fupul$,rn.prototype.cancel_dbl4no$=S.prototype.cancel_dbl4no$,rn.prototype.cancel_m4sck1$=S.prototype.cancel_m4sck1$,rn.prototype.invokeOnCompletion_ct2b2z$=S.prototype.invokeOnCompletion_ct2b2z$,on.prototype.cancel=S.prototype.cancel,on.prototype.fold_3cc69b$=S.prototype.fold_3cc69b$,on.prototype.get_j3r2sn$=S.prototype.get_j3r2sn$,on.prototype.minusKey_yeqjby$=S.prototype.minusKey_yeqjby$,on.prototype.plus_dqr1mp$=S.prototype.plus_dqr1mp$,on.prototype.plus_1fupul$=S.prototype.plus_1fupul$,on.prototype.cancel_dbl4no$=S.prototype.cancel_dbl4no$,on.prototype.cancel_m4sck1$=S.prototype.cancel_m4sck1$,on.prototype.invokeOnCompletion_ct2b2z$=S.prototype.invokeOnCompletion_ct2b2z$,dn.prototype.cancel_dbl4no$=rn.prototype.cancel_dbl4no$,dn.prototype.cancel_m4sck1$=rn.prototype.cancel_m4sck1$,dn.prototype.invokeOnCompletion_ct2b2z$=rn.prototype.invokeOnCompletion_ct2b2z$,Mi.prototype.readFully_359eei$=Np.prototype.readFully_359eei$,Mi.prototype.readFully_nd5v6f$=Np.prototype.readFully_nd5v6f$,Mi.prototype.readFully_rfv6wg$=Np.prototype.readFully_rfv6wg$,Mi.prototype.readFully_kgymra$=Np.prototype.readFully_kgymra$,Mi.prototype.readFully_6icyh1$=Np.prototype.readFully_6icyh1$,Mi.prototype.readFully_qr0era$=Np.prototype.readFully_qr0era$,Mi.prototype.readFully_gsnag5$=Np.prototype.readFully_gsnag5$,Mi.prototype.readFully_qmgm5g$=Np.prototype.readFully_qmgm5g$,Mi.prototype.readFully_p0d4q1$=Np.prototype.readFully_p0d4q1$,Mi.prototype.readAvailable_mj6st8$=Np.prototype.readAvailable_mj6st8$,Mi.prototype.readAvailable_359eei$=Np.prototype.readAvailable_359eei$,Mi.prototype.readAvailable_nd5v6f$=Np.prototype.readAvailable_nd5v6f$,Mi.prototype.readAvailable_rfv6wg$=Np.prototype.readAvailable_rfv6wg$,Mi.prototype.readAvailable_kgymra$=Np.prototype.readAvailable_kgymra$,Mi.prototype.readAvailable_6icyh1$=Np.prototype.readAvailable_6icyh1$,Mi.prototype.readAvailable_qr0era$=Np.prototype.readAvailable_qr0era$,Mi.prototype.readAvailable_gsnag5$=Np.prototype.readAvailable_gsnag5$,Mi.prototype.readAvailable_qmgm5g$=Np.prototype.readAvailable_qmgm5g$,Mi.prototype.readAvailable_p0d4q1$=Np.prototype.readAvailable_p0d4q1$,Mi.prototype.peekTo_afjyek$=Np.prototype.peekTo_afjyek$,Hi.prototype.writeShort_mq22fl$=dh.prototype.writeShort_mq22fl$,Hi.prototype.writeInt_za3lpa$=dh.prototype.writeInt_za3lpa$,Hi.prototype.writeLong_s8cxhz$=dh.prototype.writeLong_s8cxhz$,Hi.prototype.writeFloat_mx4ult$=dh.prototype.writeFloat_mx4ult$,Hi.prototype.writeDouble_14dthe$=dh.prototype.writeDouble_14dthe$,Hi.prototype.writeFully_mj6st8$=dh.prototype.writeFully_mj6st8$,Hi.prototype.writeFully_359eei$=dh.prototype.writeFully_359eei$,Hi.prototype.writeFully_nd5v6f$=dh.prototype.writeFully_nd5v6f$,Hi.prototype.writeFully_rfv6wg$=dh.prototype.writeFully_rfv6wg$,Hi.prototype.writeFully_kgymra$=dh.prototype.writeFully_kgymra$,Hi.prototype.writeFully_6icyh1$=dh.prototype.writeFully_6icyh1$,Hi.prototype.writeFully_qr0era$=dh.prototype.writeFully_qr0era$,Hi.prototype.fill_3pq026$=dh.prototype.fill_3pq026$,Mh.prototype.close=gu.prototype.close,bu.prototype.close=gu.prototype.close,kl.prototype.close=gu.prototype.close,El.prototype.close=gu.prototype.close,wu.prototype.close=gu.prototype.close,Hp.prototype.peekTo_afjyek$=Np.prototype.peekTo_afjyek$,Zi=4096,xr=new Sr,Wl=new Int8Array(0),fc=Sp().nativeOrder()===kp(),cp=8,oh=200,ah=100,sh=4096,lh="boolean"==typeof(Zh="undefined"!=typeof process&&null!=process.versions&&null!=process.versions.node)?Zh:c();var Qh=new Ct;Qh.stream=!0,uh=Qh;var t_=new Ct;return t_.fatal=!0,ch=t_,t})?i.apply(e,r):i)||(t.exports=o)},94:function(t,e,n){var i,r,o;r=[e,n(421),n(276),n(197)],void 0===(o="function"==typeof(i=function(t,e,i,r){"use strict";var o,a,s,l=t.$$importsForInline$$||(t.$$importsForInline$$={}),u=e.Kind.CLASS,c=(e.kotlin.Annotation,Object),p=e.kotlin.IllegalStateException_init_pdl1vj$,h=e.Kind.INTERFACE,_=e.toChar,f=e.kotlin.text.indexOf_8eortd$,d=i.io.ktor.utils.io.core.writeText_t153jy$,m=i.io.ktor.utils.io.core.writeFully_i6snlg$,y=i.io.ktor.utils.io.core.readAvailable_ja303r$,$=(i.io.ktor.utils.io.charsets,i.io.ktor.utils.io.core.String_xge8xe$,e.unboxChar),v=(i.io.ktor.utils.io.core.readBytes_7wsnj1$,e.toByte,i.io.ktor.utils.io.core.readText_1lnizf$,e.kotlin.ranges.until_dqglrj$),g=i.io.ktor.utils.io.core.BytePacketBuilder_za3lpa$,b=Error,w=e.kotlin.text.StringBuilder_init,x=e.kotlin.text.get_lastIndex_gw00vp$,k=e.toBoxedChar,E=(e.Long.fromInt(4096),i.io.ktor.utils.io.ByteChannel_6taknv$,i.io.ktor.utils.io.readRemaining_b56lbm$,e.kotlin.Unit),C=e.kotlin.coroutines.intrinsics.COROUTINE_SUSPENDED,S=e.kotlin.coroutines.CoroutineImpl,T=(r.kotlinx.coroutines.async_pda6u4$,e.kotlin.collections.listOf_i5x0yv$,i.io.ktor.utils.io.close_x5qia6$,r.kotlinx.coroutines.launch_s496o7$,e.kotlin.to_ujzrz7$),O=(r.kotlinx.coroutines,i.io.ktor.utils.io.readRemaining_3dmw3p$,i.io.ktor.utils.io.core.readBytes_xc9h3n$),N=(e.toShort,e.equals),P=e.hashCode,A=e.kotlin.collections.MutableMap,j=e.ensureNotNull,L=e.kotlin.collections.Map.Entry,R=e.kotlin.collections.MutableMap.MutableEntry,I=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,z=e.kotlin.collections.MutableSet,D=e.kotlin.collections.addAll_ipc267$,M=e.kotlin.collections.Map,B=e.throwCCE,U=e.charArray,F=(e.kotlin.text.repeat_94bcnn$,e.toString),q=(e.kotlin.io.println_s8jyv4$,r.kotlinx.coroutines.SupervisorJob_5dx9e$),G=e.kotlin.coroutines.AbstractCoroutineContextElement,H=r.kotlinx.coroutines.CoroutineExceptionHandler,Y=e.kotlin.text.String_4hbowm$,V=(e.kotlin.text.toInt_6ic1pp$,i.io.ktor.utils.io.charsets.encodeToByteArray_fj4osb$,e.kotlin.collections.MutableIterator),K=e.kotlin.collections.Set,W=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,X=e.kotlin.collections.ArrayList_init_ww73n8$,Z=e.Kind.OBJECT,J=(e.kotlin.collections.toList_us0mfu$,e.defineInlineFunction),Q=(e.kotlin.UnsupportedOperationException_init_pdl1vj$,e.Long.ZERO),tt=(e.kotlin.ranges.coerceAtLeast_2p08ub$,e.wrapFunction),et=e.kotlin.collections.firstOrNull_2p1efm$,nt=e.kotlin.text.equals_igcy3c$,it=(e.kotlin.collections.setOf_mh5how$,e.kotlin.collections.emptyMap_q3lmfv$),rt=e.kotlin.collections.toMap_abgq59$,ot=e.kotlin.lazy_klfg04$,at=e.kotlin.collections.Collection,st=e.kotlin.collections.toSet_7wnvza$,lt=e.kotlin.collections.emptySet_287e2$,ut=e.kotlin.collections.LinkedHashMap_init_bwtc7$,ct=(e.kotlin.collections.asList_us0mfu$,e.kotlin.collections.toMap_6hr0sd$,e.kotlin.collections.listOf_mh5how$,e.kotlin.collections.single_7wnvza$,e.kotlin.collections.toList_7wnvza$),pt=e.kotlin.collections.ArrayList_init_287e2$,ht=e.kotlin.IllegalArgumentException_init_pdl1vj$,_t=e.kotlin.ranges.CharRange,ft=e.kotlin.text.StringBuilder_init_za3lpa$,dt=e.kotlin.text.get_indices_gw00vp$,mt=(i.io.ktor.utils.io.errors.IOException,e.kotlin.collections.MutableCollection,e.kotlin.collections.LinkedHashSet_init_287e2$,e.kotlin.Enum),yt=e.throwISE,$t=e.kotlin.Comparable,vt=(e.kotlin.text.toInt_pdl1vz$,e.throwUPAE,e.kotlin.IllegalStateException),gt=(e.kotlin.text.iterator_gw00vp$,e.kotlin.collections.ArrayList_init_mqih57$),bt=e.kotlin.collections.ArrayList,wt=e.kotlin.collections.emptyList_287e2$,xt=e.kotlin.collections.get_lastIndex_55thoc$,kt=e.kotlin.collections.MutableList,Et=e.kotlin.collections.last_2p1efm$,Ct=r.kotlinx.coroutines.CoroutineScope,St=e.kotlin.Result,Tt=e.kotlin.coroutines.Continuation,Ot=e.kotlin.collections.List,Nt=e.kotlin.createFailure_tcv7n7$,Pt=r.kotlinx.coroutines.internal.recoverStackTrace_ak2v6d$,At=e.kotlin.isNaN_yrwdxr$;function jt(t){this.name=t}function Lt(){}function Rt(t){for(var e=w(),n=new Int8Array(3);t.remaining.toNumber()>0;){var i=y(t,n);It(n,i);for(var r=(8*(n.length-i|0)|0)/6|0,o=(255&n[0])<<16|(255&n[1])<<8|255&n[2],s=n.length;s>=r;s--){var l=o>>(6*s|0)&63;e.append_s8itvh$(zt(l))}for(var u=0;u>4],r[(i=o,o=i+1|0,i)]=a[15&u]}return Y(r)}function Wt(t,e,n){this.delegate_0=t,this.convertTo_0=e,this.convert_0=n,this.size_uukmxx$_0=this.delegate_0.size}function Xt(t){this.this$DelegatingMutableSet=t,this.delegateIterator=t.delegate_0.iterator()}function Zt(){se()}function Jt(){ae=this,this.Empty=new le}_e.prototype=Object.create(mt.prototype),_e.prototype.constructor=_e,De.prototype=Object.create(mt.prototype),De.prototype.constructor=De,fn.prototype=Object.create(_n.prototype),fn.prototype.constructor=fn,dn.prototype=Object.create(_n.prototype),dn.prototype.constructor=dn,mn.prototype=Object.create(_n.prototype),mn.prototype.constructor=mn,Tn.prototype=Object.create(b.prototype),Tn.prototype.constructor=Tn,Mn.prototype=Object.create(vt.prototype),Mn.prototype.constructor=Mn,jt.prototype.toString=function(){return 0===this.name.length?c.prototype.toString.call(this):"AttributeKey: "+this.name},jt.$metadata$={kind:u,simpleName:"AttributeKey",interfaces:[]},Lt.prototype.get_yzaw86$=function(t){var e;if(null==(e=this.getOrNull_yzaw86$(t)))throw p("No instance for key "+t);return e},Lt.prototype.take_yzaw86$=function(t){var e=this.get_yzaw86$(t);return this.remove_yzaw86$(t),e},Lt.prototype.takeOrNull_yzaw86$=function(t){var e=this.getOrNull_yzaw86$(t);return this.remove_yzaw86$(t),e},Lt.$metadata$={kind:h,simpleName:"Attributes",interfaces:[]},Object.defineProperty(Dt.prototype,"size",{get:function(){return this.delegate_0.size}}),Dt.prototype.containsKey_11rb$=function(t){return this.delegate_0.containsKey_11rb$(new he(t))},Dt.prototype.containsValue_11rc$=function(t){return this.delegate_0.containsValue_11rc$(t)},Dt.prototype.get_11rb$=function(t){return this.delegate_0.get_11rb$(pe(t))},Dt.prototype.isEmpty=function(){return this.delegate_0.isEmpty()},Dt.prototype.clear=function(){this.delegate_0.clear()},Dt.prototype.put_xwzc9p$=function(t,e){return this.delegate_0.put_xwzc9p$(pe(t),e)},Dt.prototype.putAll_a2k3zr$=function(t){var e;for(e=t.entries.iterator();e.hasNext();){var n=e.next(),i=n.key,r=n.value;this.put_xwzc9p$(i,r)}},Dt.prototype.remove_11rb$=function(t){return this.delegate_0.remove_11rb$(pe(t))},Object.defineProperty(Dt.prototype,"keys",{get:function(){return new Wt(this.delegate_0.keys,Mt,Bt)}}),Object.defineProperty(Dt.prototype,"entries",{get:function(){return new Wt(this.delegate_0.entries,Ut,Ft)}}),Object.defineProperty(Dt.prototype,"values",{get:function(){return this.delegate_0.values}}),Dt.prototype.equals=function(t){return!(null==t||!e.isType(t,Dt))&&N(t.delegate_0,this.delegate_0)},Dt.prototype.hashCode=function(){return P(this.delegate_0)},Dt.$metadata$={kind:u,simpleName:"CaseInsensitiveMap",interfaces:[A]},Object.defineProperty(qt.prototype,"key",{get:function(){return this.key_3iz5qv$_0}}),Object.defineProperty(qt.prototype,"value",{get:function(){return this.value_p1xw47$_0},set:function(t){this.value_p1xw47$_0=t}}),qt.prototype.setValue_11rc$=function(t){return this.value=t,this.value},qt.prototype.hashCode=function(){return 527+P(j(this.key))+P(j(this.value))|0},qt.prototype.equals=function(t){return!(null==t||!e.isType(t,L))&&N(t.key,this.key)&&N(t.value,this.value)},qt.prototype.toString=function(){return this.key.toString()+"="+this.value},qt.$metadata$={kind:u,simpleName:"Entry",interfaces:[R]},Yt.prototype=Object.create(G.prototype),Yt.prototype.constructor=Yt,Yt.prototype.handleException_1ur55u$=function(t,e){this.closure$handler(t,e)},Yt.$metadata$={kind:u,interfaces:[H,G]},Wt.prototype.convert_9xhtru$=function(t){var e,n=X(W(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.convert_0(i))}return n},Wt.prototype.convertTo_9xhuij$=function(t){var e,n=X(W(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.convertTo_0(i))}return n},Object.defineProperty(Wt.prototype,"size",{get:function(){return this.size_uukmxx$_0}}),Wt.prototype.add_11rb$=function(t){return this.delegate_0.add_11rb$(this.convert_0(t))},Wt.prototype.addAll_brywnq$=function(t){return this.delegate_0.addAll_brywnq$(this.convert_9xhtru$(t))},Wt.prototype.clear=function(){this.delegate_0.clear()},Wt.prototype.remove_11rb$=function(t){return this.delegate_0.remove_11rb$(this.convert_0(t))},Wt.prototype.removeAll_brywnq$=function(t){return this.delegate_0.removeAll_brywnq$(this.convert_9xhtru$(t))},Wt.prototype.retainAll_brywnq$=function(t){return this.delegate_0.retainAll_brywnq$(this.convert_9xhtru$(t))},Wt.prototype.contains_11rb$=function(t){return this.delegate_0.contains_11rb$(this.convert_0(t))},Wt.prototype.containsAll_brywnq$=function(t){return this.delegate_0.containsAll_brywnq$(this.convert_9xhtru$(t))},Wt.prototype.isEmpty=function(){return this.delegate_0.isEmpty()},Xt.prototype.hasNext=function(){return this.delegateIterator.hasNext()},Xt.prototype.next=function(){return this.this$DelegatingMutableSet.convertTo_0(this.delegateIterator.next())},Xt.prototype.remove=function(){this.delegateIterator.remove()},Xt.$metadata$={kind:u,interfaces:[V]},Wt.prototype.iterator=function(){return new Xt(this)},Wt.prototype.hashCode=function(){return P(this.delegate_0)},Wt.prototype.equals=function(t){if(null==t||!e.isType(t,K))return!1;var n=this.convertTo_9xhuij$(this.delegate_0),i=t.containsAll_brywnq$(n);return i&&(i=n.containsAll_brywnq$(t)),i},Wt.prototype.toString=function(){return this.convertTo_9xhuij$(this.delegate_0).toString()},Wt.$metadata$={kind:u,simpleName:"DelegatingMutableSet",interfaces:[z]},Jt.prototype.build_o7hlrk$=J("ktor-ktor-utils.io.ktor.util.StringValues.Companion.build_o7hlrk$",tt((function(){var e=t.io.ktor.util.StringValuesBuilder;return function(t,n){void 0===t&&(t=!1);var i=new e(t);return n(i),i.build()}}))),Jt.$metadata$={kind:Z,simpleName:"Companion",interfaces:[]};var Qt,te,ee,ne,ie,re,oe,ae=null;function se(){return null===ae&&new Jt,ae}function le(t,e){var n,i;void 0===t&&(t=!1),void 0===e&&(e=it()),this.caseInsensitiveName_w2tiaf$_0=t,this.values_x1t64x$_0=ot((n=this,i=e,function(){var t;if(n.caseInsensitiveName){var e=Ht();e.putAll_a2k3zr$(i),t=e}else t=rt(i);return t}))}function ue(t,e){void 0===t&&(t=!1),void 0===e&&(e=8),this.caseInsensitiveName=t,this.values=this.caseInsensitiveName?Ht():ut(e),this.built=!1}function ce(t){return new _t(65,90).contains_mef7kx$(t)?_(t+32):new _t(0,127).contains_mef7kx$(t)?t:_(String.fromCharCode(0|t).toLowerCase().charCodeAt(0))}function pe(t){return new he(t)}function he(t){this.content=t,this.hash_0=P(this.content.toLowerCase())}function _e(t,e,n){mt.call(this),this.value=n,this.name$=t,this.ordinal$=e}function fe(){fe=function(){},Qt=new _e("MONDAY",0,"Mon"),te=new _e("TUESDAY",1,"Tue"),ee=new _e("WEDNESDAY",2,"Wed"),ne=new _e("THURSDAY",3,"Thu"),ie=new _e("FRIDAY",4,"Fri"),re=new _e("SATURDAY",5,"Sat"),oe=new _e("SUNDAY",6,"Sun"),Ie()}function de(){return fe(),Qt}function me(){return fe(),te}function ye(){return fe(),ee}function $e(){return fe(),ne}function ve(){return fe(),ie}function ge(){return fe(),re}function be(){return fe(),oe}function we(){Re=this}Zt.prototype.get_61zpoe$=function(t){var e;return null!=(e=this.getAll_61zpoe$(t))?et(e):null},Zt.prototype.contains_61zpoe$=function(t){return null!=this.getAll_61zpoe$(t)},Zt.prototype.contains_puj7f4$=function(t,e){var n,i;return null!=(i=null!=(n=this.getAll_61zpoe$(t))?n.contains_11rb$(e):null)&&i},Zt.prototype.forEach_ubvtmq$=function(t){var e;for(e=this.entries().iterator();e.hasNext();){var n=e.next();t(n.key,n.value)}},Zt.$metadata$={kind:h,simpleName:"StringValues",interfaces:[]},Object.defineProperty(le.prototype,"caseInsensitiveName",{get:function(){return this.caseInsensitiveName_w2tiaf$_0}}),Object.defineProperty(le.prototype,"values",{get:function(){return this.values_x1t64x$_0.value}}),le.prototype.get_61zpoe$=function(t){var e;return null!=(e=this.listForKey_6rkiov$_0(t))?et(e):null},le.prototype.getAll_61zpoe$=function(t){return this.listForKey_6rkiov$_0(t)},le.prototype.contains_61zpoe$=function(t){return null!=this.listForKey_6rkiov$_0(t)},le.prototype.contains_puj7f4$=function(t,e){var n,i;return null!=(i=null!=(n=this.listForKey_6rkiov$_0(t))?n.contains_11rb$(e):null)&&i},le.prototype.names=function(){return this.values.keys},le.prototype.isEmpty=function(){return this.values.isEmpty()},le.prototype.entries=function(){return this.values.entries},le.prototype.forEach_ubvtmq$=function(t){var e;for(e=this.values.entries.iterator();e.hasNext();){var n=e.next();t(n.key,n.value)}},le.prototype.listForKey_6rkiov$_0=function(t){return this.values.get_11rb$(t)},le.prototype.toString=function(){return"StringValues(case="+!this.caseInsensitiveName+") "+this.entries()},le.prototype.equals=function(t){return this===t||!!e.isType(t,Zt)&&this.caseInsensitiveName===t.caseInsensitiveName&&(n=this.entries(),i=t.entries(),N(n,i));var n,i},le.prototype.hashCode=function(){return t=this.entries(),(31*(31*P(this.caseInsensitiveName)|0)|0)+P(t)|0;var t},le.$metadata$={kind:u,simpleName:"StringValuesImpl",interfaces:[Zt]},ue.prototype.getAll_61zpoe$=function(t){return this.values.get_11rb$(t)},ue.prototype.contains_61zpoe$=function(t){var n,i=this.values;return(e.isType(n=i,M)?n:B()).containsKey_11rb$(t)},ue.prototype.contains_puj7f4$=function(t,e){var n,i;return null!=(i=null!=(n=this.values.get_11rb$(t))?n.contains_11rb$(e):null)&&i},ue.prototype.names=function(){return this.values.keys},ue.prototype.isEmpty=function(){return this.values.isEmpty()},ue.prototype.entries=function(){return this.values.entries},ue.prototype.set_puj7f4$=function(t,e){this.validateValue_61zpoe$(e);var n=this.ensureListForKey_fsrbb4$_0(t,1);n.clear(),n.add_11rb$(e)},ue.prototype.get_61zpoe$=function(t){var e;return null!=(e=this.getAll_61zpoe$(t))?et(e):null},ue.prototype.append_puj7f4$=function(t,e){this.validateValue_61zpoe$(e),this.ensureListForKey_fsrbb4$_0(t,1).add_11rb$(e)},ue.prototype.appendAll_hb0ubp$=function(t){var e;t.forEach_ubvtmq$((e=this,function(t,n){return e.appendAll_poujtz$(t,n),E}))},ue.prototype.appendMissing_hb0ubp$=function(t){var e;t.forEach_ubvtmq$((e=this,function(t,n){return e.appendMissing_poujtz$(t,n),E}))},ue.prototype.appendAll_poujtz$=function(t,n){var i,r,o,a,s=this.ensureListForKey_fsrbb4$_0(t,null!=(o=null!=(r=e.isType(i=n,at)?i:null)?r.size:null)?o:2);for(a=n.iterator();a.hasNext();){var l=a.next();this.validateValue_61zpoe$(l),s.add_11rb$(l)}},ue.prototype.appendMissing_poujtz$=function(t,e){var n,i,r,o=null!=(i=null!=(n=this.values.get_11rb$(t))?st(n):null)?i:lt(),a=pt();for(r=e.iterator();r.hasNext();){var s=r.next();o.contains_11rb$(s)||a.add_11rb$(s)}this.appendAll_poujtz$(t,a)},ue.prototype.remove_61zpoe$=function(t){this.values.remove_11rb$(t)},ue.prototype.removeKeysWithNoEntries=function(){var t,e,n=this.values,i=I();for(e=n.entries.iterator();e.hasNext();){var r=e.next();r.value.isEmpty()&&i.put_xwzc9p$(r.key,r.value)}for(t=i.entries.iterator();t.hasNext();){var o=t.next().key;this.remove_61zpoe$(o)}},ue.prototype.remove_puj7f4$=function(t,e){var n,i;return null!=(i=null!=(n=this.values.get_11rb$(t))?n.remove_11rb$(e):null)&&i},ue.prototype.clear=function(){this.values.clear()},ue.prototype.build=function(){if(this.built)throw ht("ValueMapBuilder can only build a single ValueMap".toString());return this.built=!0,new le(this.caseInsensitiveName,this.values)},ue.prototype.validateName_61zpoe$=function(t){},ue.prototype.validateValue_61zpoe$=function(t){},ue.prototype.ensureListForKey_fsrbb4$_0=function(t,e){var n,i;if(this.built)throw p("Cannot modify a builder when final structure has already been built");if(null!=(n=this.values.get_11rb$(t)))i=n;else{var r=X(e);this.validateName_61zpoe$(t),this.values.put_xwzc9p$(t,r),i=r}return i},ue.$metadata$={kind:u,simpleName:"StringValuesBuilder",interfaces:[]},he.prototype.equals=function(t){var n,i,r;return!0===(null!=(r=null!=(i=e.isType(n=t,he)?n:null)?i.content:null)?nt(r,this.content,!0):null)},he.prototype.hashCode=function(){return this.hash_0},he.prototype.toString=function(){return this.content},he.$metadata$={kind:u,simpleName:"CaseInsensitiveString",interfaces:[]},we.prototype.from_za3lpa$=function(t){return ze()[t]},we.prototype.from_61zpoe$=function(t){var e,n,i=ze();t:do{var r;for(r=0;r!==i.length;++r){var o=i[r];if(N(o.value,t)){n=o;break t}}n=null}while(0);if(null==(e=n))throw p(("Invalid day of week: "+t).toString());return e},we.$metadata$={kind:Z,simpleName:"Companion",interfaces:[]};var xe,ke,Ee,Ce,Se,Te,Oe,Ne,Pe,Ae,je,Le,Re=null;function Ie(){return fe(),null===Re&&new we,Re}function ze(){return[de(),me(),ye(),$e(),ve(),ge(),be()]}function De(t,e,n){mt.call(this),this.value=n,this.name$=t,this.ordinal$=e}function Me(){Me=function(){},xe=new De("JANUARY",0,"Jan"),ke=new De("FEBRUARY",1,"Feb"),Ee=new De("MARCH",2,"Mar"),Ce=new De("APRIL",3,"Apr"),Se=new De("MAY",4,"May"),Te=new De("JUNE",5,"Jun"),Oe=new De("JULY",6,"Jul"),Ne=new De("AUGUST",7,"Aug"),Pe=new De("SEPTEMBER",8,"Sep"),Ae=new De("OCTOBER",9,"Oct"),je=new De("NOVEMBER",10,"Nov"),Le=new De("DECEMBER",11,"Dec"),tn()}function Be(){return Me(),xe}function Ue(){return Me(),ke}function Fe(){return Me(),Ee}function qe(){return Me(),Ce}function Ge(){return Me(),Se}function He(){return Me(),Te}function Ye(){return Me(),Oe}function Ve(){return Me(),Ne}function Ke(){return Me(),Pe}function We(){return Me(),Ae}function Xe(){return Me(),je}function Ze(){return Me(),Le}function Je(){Qe=this}_e.$metadata$={kind:u,simpleName:"WeekDay",interfaces:[mt]},_e.values=ze,_e.valueOf_61zpoe$=function(t){switch(t){case"MONDAY":return de();case"TUESDAY":return me();case"WEDNESDAY":return ye();case"THURSDAY":return $e();case"FRIDAY":return ve();case"SATURDAY":return ge();case"SUNDAY":return be();default:yt("No enum constant io.ktor.util.date.WeekDay."+t)}},Je.prototype.from_za3lpa$=function(t){return en()[t]},Je.prototype.from_61zpoe$=function(t){var e,n,i=en();t:do{var r;for(r=0;r!==i.length;++r){var o=i[r];if(N(o.value,t)){n=o;break t}}n=null}while(0);if(null==(e=n))throw p(("Invalid month: "+t).toString());return e},Je.$metadata$={kind:Z,simpleName:"Companion",interfaces:[]};var Qe=null;function tn(){return Me(),null===Qe&&new Je,Qe}function en(){return[Be(),Ue(),Fe(),qe(),Ge(),He(),Ye(),Ve(),Ke(),We(),Xe(),Ze()]}function nn(t,e,n,i,r,o,a,s,l){an(),this.seconds=t,this.minutes=e,this.hours=n,this.dayOfWeek=i,this.dayOfMonth=r,this.dayOfYear=o,this.month=a,this.year=s,this.timestamp=l}function rn(){on=this,this.START=Dn(Q)}De.$metadata$={kind:u,simpleName:"Month",interfaces:[mt]},De.values=en,De.valueOf_61zpoe$=function(t){switch(t){case"JANUARY":return Be();case"FEBRUARY":return Ue();case"MARCH":return Fe();case"APRIL":return qe();case"MAY":return Ge();case"JUNE":return He();case"JULY":return Ye();case"AUGUST":return Ve();case"SEPTEMBER":return Ke();case"OCTOBER":return We();case"NOVEMBER":return Xe();case"DECEMBER":return Ze();default:yt("No enum constant io.ktor.util.date.Month."+t)}},nn.prototype.compareTo_11rb$=function(t){return this.timestamp.compareTo_11rb$(t.timestamp)},rn.$metadata$={kind:Z,simpleName:"Companion",interfaces:[]};var on=null;function an(){return null===on&&new rn,on}function sn(t){this.attributes=Nn();var e,n=X(t.length+1|0);for(e=0;e!==t.length;++e){var i=t[e];n.add_11rb$(i)}this.phasesRaw_hnbfpg$_0=n,this.interceptorsQuantity_zh48jz$_0=0,this.interceptors_dzu4x2$_0=null,this.interceptorsListShared_q9lih5$_0=!1,this.interceptorsListSharedPhase_9t9y1q$_0=null}function ln(t,e,n){pn(),this.phase=t,this.relation=e,this.interceptors_0=n,this.shared=!0}function un(){cn=this,this.SharedArrayList=X(0)}nn.$metadata$={kind:u,simpleName:"GMTDate",interfaces:[$t]},nn.prototype.component1=function(){return this.seconds},nn.prototype.component2=function(){return this.minutes},nn.prototype.component3=function(){return this.hours},nn.prototype.component4=function(){return this.dayOfWeek},nn.prototype.component5=function(){return this.dayOfMonth},nn.prototype.component6=function(){return this.dayOfYear},nn.prototype.component7=function(){return this.month},nn.prototype.component8=function(){return this.year},nn.prototype.component9=function(){return this.timestamp},nn.prototype.copy_j9f46j$=function(t,e,n,i,r,o,a,s,l){return new nn(void 0===t?this.seconds:t,void 0===e?this.minutes:e,void 0===n?this.hours:n,void 0===i?this.dayOfWeek:i,void 0===r?this.dayOfMonth:r,void 0===o?this.dayOfYear:o,void 0===a?this.month:a,void 0===s?this.year:s,void 0===l?this.timestamp:l)},nn.prototype.toString=function(){return"GMTDate(seconds="+e.toString(this.seconds)+", minutes="+e.toString(this.minutes)+", hours="+e.toString(this.hours)+", dayOfWeek="+e.toString(this.dayOfWeek)+", dayOfMonth="+e.toString(this.dayOfMonth)+", dayOfYear="+e.toString(this.dayOfYear)+", month="+e.toString(this.month)+", year="+e.toString(this.year)+", timestamp="+e.toString(this.timestamp)+")"},nn.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*t+e.hashCode(this.seconds)|0)+e.hashCode(this.minutes)|0)+e.hashCode(this.hours)|0)+e.hashCode(this.dayOfWeek)|0)+e.hashCode(this.dayOfMonth)|0)+e.hashCode(this.dayOfYear)|0)+e.hashCode(this.month)|0)+e.hashCode(this.year)|0)+e.hashCode(this.timestamp)|0},nn.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.seconds,t.seconds)&&e.equals(this.minutes,t.minutes)&&e.equals(this.hours,t.hours)&&e.equals(this.dayOfWeek,t.dayOfWeek)&&e.equals(this.dayOfMonth,t.dayOfMonth)&&e.equals(this.dayOfYear,t.dayOfYear)&&e.equals(this.month,t.month)&&e.equals(this.year,t.year)&&e.equals(this.timestamp,t.timestamp)},sn.prototype.execute_8pmvt0$=function(t,e,n){return this.createContext_xnqwxl$(t,e).execute_11rb$(e,n)},sn.prototype.createContext_xnqwxl$=function(t,e){return kn(t,this.sharedInterceptorsList_8aep55$_0(),e)},Object.defineProperty(ln.prototype,"isEmpty",{get:function(){return this.interceptors_0.isEmpty()}}),Object.defineProperty(ln.prototype,"size",{get:function(){return this.interceptors_0.size}}),ln.prototype.addInterceptor_mx8w25$=function(t){this.shared&&this.copyInterceptors_0(),this.interceptors_0.add_11rb$(t)},ln.prototype.addTo_vaasg2$=function(t){var e,n=this.interceptors_0;t.ensureCapacity_za3lpa$(t.size+n.size|0),e=n.size;for(var i=0;i0){var c=new wn(w(t,b(i.v,s)));n.add_11rb$(c)}n.add_11rb$(new xn(o)),i.v=l+1|0}if(i.v=ki().CACHE_DAYS_0&&r===ki().EPOCH.year&&(r=ki().CACHE_STAMP_0.year,i=ki().CACHE_STAMP_0.month,n=ki().CACHE_STAMP_0.day,e=e-ki().CACHE_DAYS_0|0);e>0;){var a=i.getDaysInYear_za3lpa$(r)-n+1|0;if(e=s?(n=1,i=Ui().JANUARY,r=r+1|0,e=e-s|0):(i=N(i.next()),n=1,e=e-a|0,o=!0)}}return new bi(n,i,r)},bi.prototype.nextDate=function(){return this.addDays_za3lpa$(1)},bi.prototype.prevDate=function(){return this.subtractDays_za3lpa$(1)},bi.prototype.subtractDays_za3lpa$=function(t){if(t<0)throw O();if(0===t)return this;if(te?ki().lastDayOf_8fsw02$(this.year-1|0).subtractDays_za3lpa$(t-e-1|0):ki().lastDayOf_8fsw02$(this.year,N(this.month.prev())).subtractDays_za3lpa$(t-this.day|0)},bi.prototype.compareTo_11rb$=function(t){return this.year!==t.year?this.year-t.year|0:this.month.ordinal()!==t.month.ordinal()?this.month.ordinal()-t.month.ordinal()|0:this.day-t.day|0},bi.prototype.equals=function(t){var n;if(!e.isType(t,bi))return!1;var i=null==(n=t)||e.isType(n,bi)?n:E();return N(i).year===this.year&&i.month===this.month&&i.day===this.day},bi.prototype.hashCode=function(){return(239*this.year|0)+(31*P(this.month)|0)+this.day|0},bi.prototype.toString=function(){var t=A();return t.append_s8jyv4$(this.year),this.appendMonth_0(t),this.appendDay_0(t),t.toString()},bi.prototype.appendDay_0=function(t){this.day<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.day)},bi.prototype.appendMonth_0=function(t){var e=this.month.ordinal()+1|0;e<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(e)},bi.prototype.toPrettyString=function(){var t=A();return this.appendDay_0(t),t.append_pdl1vj$("."),this.appendMonth_0(t),t.append_pdl1vj$("."),t.append_s8jyv4$(this.year),t.toString()},wi.prototype.parse_61zpoe$=function(t){if(8!==t.length)throw j();var e=L(t.substring(0,4)),n=L(t.substring(4,6));return new bi(L(t.substring(6,8)),Ui().values()[n-1|0],e)},wi.prototype.firstDayOf_8fsw02$=function(t,e){return void 0===e&&(e=Ui().JANUARY),new bi(1,e,t)},wi.prototype.lastDayOf_8fsw02$=function(t,e){return void 0===e&&(e=Ui().DECEMBER),new bi(e.days,e,t)},wi.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var xi=null;function ki(){return null===xi&&new wi,xi}function Ei(t,e){Ti(),void 0===e&&(e=Ji().DAY_START),this.date=t,this.time=e}function Ci(){Si=this}bi.$metadata$={kind:$,simpleName:"Date",interfaces:[R]},Object.defineProperty(Ei.prototype,"year",{configurable:!0,get:function(){return this.date.year}}),Object.defineProperty(Ei.prototype,"month",{configurable:!0,get:function(){return this.date.month}}),Object.defineProperty(Ei.prototype,"day",{configurable:!0,get:function(){return this.date.day}}),Object.defineProperty(Ei.prototype,"weekDay",{configurable:!0,get:function(){return this.date.weekDay}}),Object.defineProperty(Ei.prototype,"hours",{configurable:!0,get:function(){return this.time.hours}}),Object.defineProperty(Ei.prototype,"minutes",{configurable:!0,get:function(){return this.time.minutes}}),Object.defineProperty(Ei.prototype,"seconds",{configurable:!0,get:function(){return this.time.seconds}}),Object.defineProperty(Ei.prototype,"milliseconds",{configurable:!0,get:function(){return this.time.milliseconds}}),Ei.prototype.changeDate_z9gqti$=function(t){return new Ei(t,this.time)},Ei.prototype.changeTime_z96d9j$=function(t){return new Ei(this.date,t)},Ei.prototype.add_27523k$=function(t){var e=$r().UTC.toInstant_amwj4p$(this);return $r().UTC.toDateTime_x2y23v$(e.add_27523k$(t))},Ei.prototype.to_amwj4p$=function(t){var e=$r().UTC.toInstant_amwj4p$(this),n=$r().UTC.toInstant_amwj4p$(t);return e.to_x2y23v$(n)},Ei.prototype.isBefore_amwj4p$=function(t){return this.compareTo_11rb$(t)<0},Ei.prototype.isAfter_amwj4p$=function(t){return this.compareTo_11rb$(t)>0},Ei.prototype.hashCode=function(){return(31*this.date.hashCode()|0)+this.time.hashCode()|0},Ei.prototype.equals=function(t){var n,i,r;if(!e.isType(t,Ei))return!1;var o=null==(n=t)||e.isType(n,Ei)?n:E();return(null!=(i=this.date)?i.equals(N(o).date):null)&&(null!=(r=this.time)?r.equals(o.time):null)},Ei.prototype.compareTo_11rb$=function(t){var e=this.date.compareTo_11rb$(t.date);return 0!==e?e:this.time.compareTo_11rb$(t.time)},Ei.prototype.toString=function(){return this.date.toString()+"T"+I(this.time)},Ei.prototype.toPrettyString=function(){return this.time.toPrettyHMString()+" "+this.date.toPrettyString()},Ci.prototype.parse_61zpoe$=function(t){if(t.length<15)throw O();return new Ei(ki().parse_61zpoe$(t.substring(0,8)),Ji().parse_61zpoe$(t.substring(9)))},Ci.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Si=null;function Ti(){return null===Si&&new Ci,Si}function Oi(){var t,e;Ni=this,this.BASE_YEAR=1900,this.MAX_SUPPORTED_YEAR=2100,this.MIN_SUPPORTED_YEAR_8be2vx$=1970,this.DAYS_IN_YEAR_8be2vx$=0,this.DAYS_IN_LEAP_YEAR_8be2vx$=0,this.LEAP_YEARS_FROM_1969_8be2vx$=new Int32Array([477,477,477,478,478,478,478,479,479,479,479,480,480,480,480,481,481,481,481,482,482,482,482,483,483,483,483,484,484,484,484,485,485,485,485,486,486,486,486,487,487,487,487,488,488,488,488,489,489,489,489,490,490,490,490,491,491,491,491,492,492,492,492,493,493,493,493,494,494,494,494,495,495,495,495,496,496,496,496,497,497,497,497,498,498,498,498,499,499,499,499,500,500,500,500,501,501,501,501,502,502,502,502,503,503,503,503,504,504,504,504,505,505,505,505,506,506,506,506,507,507,507,507,508,508,508,508,509,509,509,509,509]);var n=0,i=0;for(t=Ui().values(),e=0;e!==t.length;++e){var r=t[e];n=n+r.getDaysInLeapYear()|0,i=i+r.days|0}this.DAYS_IN_YEAR_8be2vx$=i,this.DAYS_IN_LEAP_YEAR_8be2vx$=n}Ei.$metadata$={kind:$,simpleName:"DateTime",interfaces:[R]},Oi.prototype.isLeap_kcn2v3$=function(t){return this.checkYear_0(t),1==(this.LEAP_YEARS_FROM_1969_8be2vx$[t-1970+1|0]-this.LEAP_YEARS_FROM_1969_8be2vx$[t-1970|0]|0)},Oi.prototype.leapYearsBetween_6xvm5r$=function(t,e){if(t>e)throw O();return this.checkYear_0(t),this.checkYear_0(e),this.LEAP_YEARS_FROM_1969_8be2vx$[e-1970|0]-this.LEAP_YEARS_FROM_1969_8be2vx$[t-1970|0]|0},Oi.prototype.leapYearsFromZero_0=function(t){return(t/4|0)-(t/100|0)+(t/400|0)|0},Oi.prototype.checkYear_0=function(t){if(t>2100||t<1970)throw v(t.toString()+"")},Oi.$metadata$={kind:y,simpleName:"DateTimeUtil",interfaces:[]};var Ni=null;function Pi(){return null===Ni&&new Oi,Ni}function Ai(t){Ri(),this.duration=t}function ji(){Li=this,this.MS=new Ai(D),this.SECOND=this.MS.mul_s8cxhz$(M),this.MINUTE=this.SECOND.mul_s8cxhz$(B),this.HOUR=this.MINUTE.mul_s8cxhz$(B),this.DAY=this.HOUR.mul_s8cxhz$(U),this.WEEK=this.DAY.mul_s8cxhz$(F)}Object.defineProperty(Ai.prototype,"isPositive",{configurable:!0,get:function(){return this.duration.toNumber()>0}}),Ai.prototype.mul_s8cxhz$=function(t){return new Ai(this.duration.multiply(t))},Ai.prototype.add_27523k$=function(t){return new Ai(this.duration.add(t.duration))},Ai.prototype.sub_27523k$=function(t){return new Ai(this.duration.subtract(t.duration))},Ai.prototype.div_27523k$=function(t){return this.duration.toNumber()/t.duration.toNumber()},Ai.prototype.compareTo_11rb$=function(t){var e=this.duration.subtract(t.duration);return e.toNumber()>0?1:l(e,z)?0:-1},Ai.prototype.hashCode=function(){return this.duration.toInt()},Ai.prototype.equals=function(t){return!!e.isType(t,Ai)&&l(this.duration,t.duration)},Ai.prototype.toString=function(){return"Duration : "+I(this.duration)+"ms"},ji.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Li=null;function Ri(){return null===Li&&new ji,Li}function Ii(t){this.timeSinceEpoch=t}function zi(t,e,n){Ui(),this.days=t,this.myOrdinal_hzcl1t$_0=e,this.myName_s01cg9$_0=n}function Di(t,e,n,i){zi.call(this,t,n,i),this.myDaysInLeapYear_0=e}function Mi(){Bi=this,this.JANUARY=new zi(31,0,"January"),this.FEBRUARY=new Di(28,29,1,"February"),this.MARCH=new zi(31,2,"March"),this.APRIL=new zi(30,3,"April"),this.MAY=new zi(31,4,"May"),this.JUNE=new zi(30,5,"June"),this.JULY=new zi(31,6,"July"),this.AUGUST=new zi(31,7,"August"),this.SEPTEMBER=new zi(30,8,"September"),this.OCTOBER=new zi(31,9,"October"),this.NOVEMBER=new zi(30,10,"November"),this.DECEMBER=new zi(31,11,"December"),this.VALUES_0=[this.JANUARY,this.FEBRUARY,this.MARCH,this.APRIL,this.MAY,this.JUNE,this.JULY,this.AUGUST,this.SEPTEMBER,this.OCTOBER,this.NOVEMBER,this.DECEMBER]}Ai.$metadata$={kind:$,simpleName:"Duration",interfaces:[R]},Ii.prototype.add_27523k$=function(t){return new Ii(this.timeSinceEpoch.add(t.duration))},Ii.prototype.sub_27523k$=function(t){return new Ii(this.timeSinceEpoch.subtract(t.duration))},Ii.prototype.to_x2y23v$=function(t){return new Ai(t.timeSinceEpoch.subtract(this.timeSinceEpoch))},Ii.prototype.compareTo_11rb$=function(t){var e=this.timeSinceEpoch.subtract(t.timeSinceEpoch);return e.toNumber()>0?1:l(e,z)?0:-1},Ii.prototype.hashCode=function(){return this.timeSinceEpoch.toInt()},Ii.prototype.toString=function(){return""+I(this.timeSinceEpoch)},Ii.prototype.equals=function(t){return!!e.isType(t,Ii)&&l(this.timeSinceEpoch,t.timeSinceEpoch)},Ii.$metadata$={kind:$,simpleName:"Instant",interfaces:[R]},zi.prototype.ordinal=function(){return this.myOrdinal_hzcl1t$_0},zi.prototype.getDaysInYear_za3lpa$=function(t){return this.days},zi.prototype.getDaysInLeapYear=function(){return this.days},zi.prototype.prev=function(){return 0===this.myOrdinal_hzcl1t$_0?null:Ui().values()[this.myOrdinal_hzcl1t$_0-1|0]},zi.prototype.next=function(){var t=Ui().values();return this.myOrdinal_hzcl1t$_0===(t.length-1|0)?null:t[this.myOrdinal_hzcl1t$_0+1|0]},zi.prototype.toString=function(){return this.myName_s01cg9$_0},Di.prototype.getDaysInLeapYear=function(){return this.myDaysInLeapYear_0},Di.prototype.getDaysInYear_za3lpa$=function(t){return Pi().isLeap_kcn2v3$(t)?this.getDaysInLeapYear():this.days},Di.$metadata$={kind:$,simpleName:"VarLengthMonth",interfaces:[zi]},Mi.prototype.values=function(){return this.VALUES_0},Mi.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Bi=null;function Ui(){return null===Bi&&new Mi,Bi}function Fi(t,e,n,i){if(Ji(),void 0===n&&(n=0),void 0===i&&(i=0),this.hours=t,this.minutes=e,this.seconds=n,this.milliseconds=i,this.hours<0||this.hours>24)throw O();if(24===this.hours&&(0!==this.minutes||0!==this.seconds))throw O();if(this.minutes<0||this.minutes>=60)throw O();if(this.seconds<0||this.seconds>=60)throw O()}function qi(){Zi=this,this.DELIMITER_0=58,this.DAY_START=new Fi(0,0),this.DAY_END=new Fi(24,0)}zi.$metadata$={kind:$,simpleName:"Month",interfaces:[]},Fi.prototype.compareTo_11rb$=function(t){var e=this.hours-t.hours|0;return 0!==e||0!=(e=this.minutes-t.minutes|0)||0!=(e=this.seconds-t.seconds|0)?e:this.milliseconds-t.milliseconds|0},Fi.prototype.hashCode=function(){return(239*this.hours|0)+(491*this.minutes|0)+(41*this.seconds|0)+this.milliseconds|0},Fi.prototype.equals=function(t){var n;return!!e.isType(t,Fi)&&0===this.compareTo_11rb$(N(null==(n=t)||e.isType(n,Fi)?n:E()))},Fi.prototype.toString=function(){var t=A();return this.hours<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.hours),this.minutes<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.minutes),this.seconds<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.seconds),t.toString()},Fi.prototype.toPrettyHMString=function(){var t=A();return this.hours<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.hours).append_s8itvh$(Ji().DELIMITER_0),this.minutes<10&&t.append_pdl1vj$("0"),t.append_s8jyv4$(this.minutes),t.toString()},qi.prototype.parse_61zpoe$=function(t){if(t.length<6)throw O();return new Fi(L(t.substring(0,2)),L(t.substring(2,4)),L(t.substring(4,6)))},qi.prototype.fromPrettyHMString_61zpoe$=function(t){var n=this.DELIMITER_0;if(!q(t,String.fromCharCode(n)+""))throw O();var i=t.length;if(5!==i&&4!==i)throw O();var r=4===i?1:2;try{var o=L(t.substring(0,r)),a=r+1|0;return new Fi(o,L(t.substring(a,i)),0)}catch(t){throw e.isType(t,G)?O():t}},qi.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Gi,Hi,Yi,Vi,Ki,Wi,Xi,Zi=null;function Ji(){return null===Zi&&new qi,Zi}function Qi(t,e,n,i){C.call(this),this.abbreviation=n,this.isWeekend=i,this.name$=t,this.ordinal$=e}function tr(){tr=function(){},Gi=new Qi("MONDAY",0,"MO",!1),Hi=new Qi("TUESDAY",1,"TU",!1),Yi=new Qi("WEDNESDAY",2,"WE",!1),Vi=new Qi("THURSDAY",3,"TH",!1),Ki=new Qi("FRIDAY",4,"FR",!1),Wi=new Qi("SATURDAY",5,"SA",!0),Xi=new Qi("SUNDAY",6,"SU",!0)}function er(){return tr(),Gi}function nr(){return tr(),Hi}function ir(){return tr(),Yi}function rr(){return tr(),Vi}function or(){return tr(),Ki}function ar(){return tr(),Wi}function sr(){return tr(),Xi}function lr(){return[er(),nr(),ir(),rr(),or(),ar(),sr()]}function ur(){}function cr(){_r=this}function pr(t,e){this.closure$weekDay=t,this.closure$month=e}function hr(t,e,n){this.closure$number=t,this.closure$weekDay=e,this.closure$month=n}Fi.$metadata$={kind:$,simpleName:"Time",interfaces:[R]},Qi.$metadata$={kind:$,simpleName:"WeekDay",interfaces:[C]},Qi.values=lr,Qi.valueOf_61zpoe$=function(t){switch(t){case"MONDAY":return er();case"TUESDAY":return nr();case"WEDNESDAY":return ir();case"THURSDAY":return rr();case"FRIDAY":return or();case"SATURDAY":return ar();case"SUNDAY":return sr();default:S("No enum constant jetbrains.datalore.base.datetime.WeekDay."+t)}},ur.$metadata$={kind:H,simpleName:"DateSpec",interfaces:[]},Object.defineProperty(pr.prototype,"rRule",{configurable:!0,get:function(){return"RRULE:FREQ=YEARLY;BYDAY=-1"+this.closure$weekDay.abbreviation+";BYMONTH="+I(this.closure$month.ordinal()+1|0)}}),pr.prototype.getDate_za3lpa$=function(t){for(var e=this.closure$month.getDaysInYear_za3lpa$(t);e>=1;e--){var n=new bi(e,this.closure$month,t);if(n.weekDay===this.closure$weekDay)return n}throw j()},pr.$metadata$={kind:$,interfaces:[ur]},cr.prototype.last_kvq57g$=function(t,e){return new pr(t,e)},Object.defineProperty(hr.prototype,"rRule",{configurable:!0,get:function(){return"RRULE:FREQ=YEARLY;BYDAY="+I(this.closure$number)+this.closure$weekDay.abbreviation+";BYMONTH="+I(this.closure$month.ordinal()+1|0)}}),hr.prototype.getDate_za3lpa$=function(t){for(var n=e.imul(this.closure$number-1|0,lr().length)+1|0,i=this.closure$month.getDaysInYear_za3lpa$(t),r=n;r<=i;r++){var o=new bi(r,this.closure$month,t);if(o.weekDay===this.closure$weekDay)return o}throw j()},hr.$metadata$={kind:$,interfaces:[ur]},cr.prototype.first_t96ihi$=function(t,e,n){return void 0===n&&(n=1),new hr(n,t,e)},cr.$metadata$={kind:y,simpleName:"DateSpecs",interfaces:[]};var _r=null;function fr(){return null===_r&&new cr,_r}function dr(t){$r(),this.id=t}function mr(){yr=this,this.UTC=ra().utc(),this.BERLIN=ra().withEuSummerTime_rwkwum$("Europe/Berlin",Ri().HOUR.mul_s8cxhz$(D)),this.MOSCOW=new vr,this.NY=ra().withUsSummerTime_rwkwum$("America/New_York",Ri().HOUR.mul_s8cxhz$(Y))}dr.prototype.convertTo_8hfrhi$=function(t,e){return e===this?t:e.toDateTime_x2y23v$(this.toInstant_amwj4p$(t))},dr.prototype.convertTimeAtDay_aopdye$=function(t,e,n){var i=new Ei(e,t),r=this.convertTo_8hfrhi$(i,n),o=e.compareTo_11rb$(r.date);return 0!==o&&(i=new Ei(o>0?e.nextDate():e.prevDate(),t),r=this.convertTo_8hfrhi$(i,n)),r.time},dr.prototype.getTimeZoneShift_x2y23v$=function(t){var e=this.toDateTime_x2y23v$(t);return t.to_x2y23v$($r().UTC.toInstant_amwj4p$(e))},dr.prototype.toString=function(){return N(this.id)},mr.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var yr=null;function $r(){return null===yr&&new mr,yr}function vr(){wr(),dr.call(this,wr().ID_0),this.myOldOffset_0=Ri().HOUR.mul_s8cxhz$(V),this.myNewOffset_0=Ri().HOUR.mul_s8cxhz$(K),this.myOldTz_0=ra().offset_nf4kng$(null,this.myOldOffset_0,$r().UTC),this.myNewTz_0=ra().offset_nf4kng$(null,this.myNewOffset_0,$r().UTC),this.myOffsetChangeTime_0=new Ei(new bi(26,Ui().OCTOBER,2014),new Fi(2,0)),this.myOffsetChangeInstant_0=this.myOldTz_0.toInstant_amwj4p$(this.myOffsetChangeTime_0)}function gr(){br=this,this.ID_0="Europe/Moscow"}dr.$metadata$={kind:$,simpleName:"TimeZone",interfaces:[]},vr.prototype.toDateTime_x2y23v$=function(t){return t.compareTo_11rb$(this.myOffsetChangeInstant_0)>=0?this.myNewTz_0.toDateTime_x2y23v$(t):this.myOldTz_0.toDateTime_x2y23v$(t)},vr.prototype.toInstant_amwj4p$=function(t){return t.compareTo_11rb$(this.myOffsetChangeTime_0)>=0?this.myNewTz_0.toInstant_amwj4p$(t):this.myOldTz_0.toInstant_amwj4p$(t)},gr.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var br=null;function wr(){return null===br&&new gr,br}function xr(){ia=this,this.MILLIS_IN_SECOND_0=M,this.MILLIS_IN_MINUTE_0=W,this.MILLIS_IN_HOUR_0=X,this.MILLIS_IN_DAY_0=Z}function kr(t){dr.call(this,t)}function Er(t,e,n){this.closure$base=t,this.closure$offset=e,dr.call(this,n)}function Cr(t,e,n,i,r){this.closure$startSpec=t,this.closure$utcChangeTime=e,this.closure$endSpec=n,Tr.call(this,i,r)}function Sr(t,e,n,i,r){this.closure$startSpec=t,this.closure$offset=e,this.closure$endSpec=n,Tr.call(this,i,r)}function Tr(t,e){dr.call(this,t),this.myTz_0=ra().offset_nf4kng$(null,e,$r().UTC),this.mySummerTz_0=ra().offset_nf4kng$(null,e.add_27523k$(Ri().HOUR),$r().UTC)}vr.$metadata$={kind:$,simpleName:"TimeZoneMoscow",interfaces:[dr]},xr.prototype.toDateTime_0=function(t,e){var n=t,i=(n=n.add_27523k$(e)).timeSinceEpoch.div(this.MILLIS_IN_DAY_0).toInt(),r=ki().EPOCH.addDays_za3lpa$(i),o=n.timeSinceEpoch.modulo(this.MILLIS_IN_DAY_0);return new Ei(r,new Fi(o.div(this.MILLIS_IN_HOUR_0).toInt(),(o=o.modulo(this.MILLIS_IN_HOUR_0)).div(this.MILLIS_IN_MINUTE_0).toInt(),(o=o.modulo(this.MILLIS_IN_MINUTE_0)).div(this.MILLIS_IN_SECOND_0).toInt(),(o=o.modulo(this.MILLIS_IN_SECOND_0)).modulo(this.MILLIS_IN_SECOND_0).toInt()))},xr.prototype.toInstant_0=function(t,e){return new Ii(this.toMillis_0(t.date).add(this.toMillis_1(t.time))).sub_27523k$(e)},xr.prototype.toMillis_1=function(t){return e.Long.fromInt(t.hours).multiply(B).add(e.Long.fromInt(t.minutes)).multiply(e.Long.fromInt(60)).add(e.Long.fromInt(t.seconds)).multiply(e.Long.fromInt(1e3)).add(e.Long.fromInt(t.milliseconds))},xr.prototype.toMillis_0=function(t){return e.Long.fromInt(t.daysFrom_z9gqti$(ki().EPOCH)).multiply(this.MILLIS_IN_DAY_0)},kr.prototype.toDateTime_x2y23v$=function(t){return ra().toDateTime_0(t,new Ai(z))},kr.prototype.toInstant_amwj4p$=function(t){return ra().toInstant_0(t,new Ai(z))},kr.$metadata$={kind:$,interfaces:[dr]},xr.prototype.utc=function(){return new kr("UTC")},Er.prototype.toDateTime_x2y23v$=function(t){return this.closure$base.toDateTime_x2y23v$(t.add_27523k$(this.closure$offset))},Er.prototype.toInstant_amwj4p$=function(t){return this.closure$base.toInstant_amwj4p$(t).sub_27523k$(this.closure$offset)},Er.$metadata$={kind:$,interfaces:[dr]},xr.prototype.offset_nf4kng$=function(t,e,n){return new Er(n,e,t)},Cr.prototype.getStartInstant_za3lpa$=function(t){return $r().UTC.toInstant_amwj4p$(new Ei(this.closure$startSpec.getDate_za3lpa$(t),this.closure$utcChangeTime))},Cr.prototype.getEndInstant_za3lpa$=function(t){return $r().UTC.toInstant_amwj4p$(new Ei(this.closure$endSpec.getDate_za3lpa$(t),this.closure$utcChangeTime))},Cr.$metadata$={kind:$,interfaces:[Tr]},xr.prototype.withEuSummerTime_rwkwum$=function(t,e){var n=fr().last_kvq57g$(sr(),Ui().MARCH),i=fr().last_kvq57g$(sr(),Ui().OCTOBER);return new Cr(n,new Fi(1,0),i,t,e)},Sr.prototype.getStartInstant_za3lpa$=function(t){return $r().UTC.toInstant_amwj4p$(new Ei(this.closure$startSpec.getDate_za3lpa$(t),new Fi(2,0))).sub_27523k$(this.closure$offset)},Sr.prototype.getEndInstant_za3lpa$=function(t){return $r().UTC.toInstant_amwj4p$(new Ei(this.closure$endSpec.getDate_za3lpa$(t),new Fi(2,0))).sub_27523k$(this.closure$offset.add_27523k$(Ri().HOUR))},Sr.$metadata$={kind:$,interfaces:[Tr]},xr.prototype.withUsSummerTime_rwkwum$=function(t,e){return new Sr(fr().first_t96ihi$(sr(),Ui().MARCH,2),e,fr().first_t96ihi$(sr(),Ui().NOVEMBER),t,e)},Tr.prototype.toDateTime_x2y23v$=function(t){var e=this.myTz_0.toDateTime_x2y23v$(t),n=this.getStartInstant_za3lpa$(e.year),i=this.getEndInstant_za3lpa$(e.year);return t.compareTo_11rb$(n)>0&&t.compareTo_11rb$(i)<0?this.mySummerTz_0.toDateTime_x2y23v$(t):e},Tr.prototype.toInstant_amwj4p$=function(t){var e=this.toDateTime_x2y23v$(this.getStartInstant_za3lpa$(t.year)),n=this.toDateTime_x2y23v$(this.getEndInstant_za3lpa$(t.year));return t.compareTo_11rb$(e)>0&&t.compareTo_11rb$(n)<0?this.mySummerTz_0.toInstant_amwj4p$(t):this.myTz_0.toInstant_amwj4p$(t)},Tr.$metadata$={kind:$,simpleName:"DSTimeZone",interfaces:[dr]},xr.$metadata$={kind:y,simpleName:"TimeZones",interfaces:[]};var Or,Nr,Pr,Ar,jr,Lr,Rr,Ir,zr,Dr,Mr,Br,Ur,Fr,qr,Gr,Hr,Yr,Vr,Kr,Wr,Xr,Zr,Jr,Qr,to,eo,no,io,ro,oo,ao,so,lo,uo,co,po,ho,_o,fo,mo,yo,$o,vo,go,bo,wo,xo,ko,Eo,Co,So,To,Oo,No,Po,Ao,jo,Lo,Ro,Io,zo,Do,Mo,Bo,Uo,Fo,qo,Go,Ho,Yo,Vo,Ko,Wo,Xo,Zo,Jo,Qo,ta,ea,na,ia=null;function ra(){return null===ia&&new xr,ia}function oa(){}function aa(t){var e;this.myNormalizedValueMap_0=null,this.myOriginalNames_0=null;var n=t.length,i=tt(n),r=h(n);for(e=0;e!==t.length;++e){var o=t[e],a=o.toString();r.add_11rb$(a);var s=this.toNormalizedName_0(a),l=i.put_xwzc9p$(s,o);if(null!=l)throw v("duplicate values: '"+o+"', '"+I(l)+"'")}this.myOriginalNames_0=r,this.myNormalizedValueMap_0=i}function sa(t,e){C.call(this),this.name$=t,this.ordinal$=e}function la(){la=function(){},Or=new sa("NONE",0),Nr=new sa("LEFT",1),Pr=new sa("MIDDLE",2),Ar=new sa("RIGHT",3)}function ua(){return la(),Or}function ca(){return la(),Nr}function pa(){return la(),Pr}function ha(){return la(),Ar}function _a(){this.eventContext_qzl3re$_d6nbbo$_0=null,this.isConsumed_gb68t5$_0=!1}function fa(t,e,n){C.call(this),this.myValue_n4kdnj$_0=n,this.name$=t,this.ordinal$=e}function da(){da=function(){},jr=new fa("A",0,"A"),Lr=new fa("B",1,"B"),Rr=new fa("C",2,"C"),Ir=new fa("D",3,"D"),zr=new fa("E",4,"E"),Dr=new fa("F",5,"F"),Mr=new fa("G",6,"G"),Br=new fa("H",7,"H"),Ur=new fa("I",8,"I"),Fr=new fa("J",9,"J"),qr=new fa("K",10,"K"),Gr=new fa("L",11,"L"),Hr=new fa("M",12,"M"),Yr=new fa("N",13,"N"),Vr=new fa("O",14,"O"),Kr=new fa("P",15,"P"),Wr=new fa("Q",16,"Q"),Xr=new fa("R",17,"R"),Zr=new fa("S",18,"S"),Jr=new fa("T",19,"T"),Qr=new fa("U",20,"U"),to=new fa("V",21,"V"),eo=new fa("W",22,"W"),no=new fa("X",23,"X"),io=new fa("Y",24,"Y"),ro=new fa("Z",25,"Z"),oo=new fa("DIGIT_0",26,"0"),ao=new fa("DIGIT_1",27,"1"),so=new fa("DIGIT_2",28,"2"),lo=new fa("DIGIT_3",29,"3"),uo=new fa("DIGIT_4",30,"4"),co=new fa("DIGIT_5",31,"5"),po=new fa("DIGIT_6",32,"6"),ho=new fa("DIGIT_7",33,"7"),_o=new fa("DIGIT_8",34,"8"),fo=new fa("DIGIT_9",35,"9"),mo=new fa("LEFT_BRACE",36,"["),yo=new fa("RIGHT_BRACE",37,"]"),$o=new fa("UP",38,"Up"),vo=new fa("DOWN",39,"Down"),go=new fa("LEFT",40,"Left"),bo=new fa("RIGHT",41,"Right"),wo=new fa("PAGE_UP",42,"Page Up"),xo=new fa("PAGE_DOWN",43,"Page Down"),ko=new fa("ESCAPE",44,"Escape"),Eo=new fa("ENTER",45,"Enter"),Co=new fa("HOME",46,"Home"),So=new fa("END",47,"End"),To=new fa("TAB",48,"Tab"),Oo=new fa("SPACE",49,"Space"),No=new fa("INSERT",50,"Insert"),Po=new fa("DELETE",51,"Delete"),Ao=new fa("BACKSPACE",52,"Backspace"),jo=new fa("EQUALS",53,"Equals"),Lo=new fa("BACK_QUOTE",54,"`"),Ro=new fa("PLUS",55,"Plus"),Io=new fa("MINUS",56,"Minus"),zo=new fa("SLASH",57,"Slash"),Do=new fa("CONTROL",58,"Ctrl"),Mo=new fa("META",59,"Meta"),Bo=new fa("ALT",60,"Alt"),Uo=new fa("SHIFT",61,"Shift"),Fo=new fa("UNKNOWN",62,"?"),qo=new fa("F1",63,"F1"),Go=new fa("F2",64,"F2"),Ho=new fa("F3",65,"F3"),Yo=new fa("F4",66,"F4"),Vo=new fa("F5",67,"F5"),Ko=new fa("F6",68,"F6"),Wo=new fa("F7",69,"F7"),Xo=new fa("F8",70,"F8"),Zo=new fa("F9",71,"F9"),Jo=new fa("F10",72,"F10"),Qo=new fa("F11",73,"F11"),ta=new fa("F12",74,"F12"),ea=new fa("COMMA",75,","),na=new fa("PERIOD",76,".")}function ma(){return da(),jr}function ya(){return da(),Lr}function $a(){return da(),Rr}function va(){return da(),Ir}function ga(){return da(),zr}function ba(){return da(),Dr}function wa(){return da(),Mr}function xa(){return da(),Br}function ka(){return da(),Ur}function Ea(){return da(),Fr}function Ca(){return da(),qr}function Sa(){return da(),Gr}function Ta(){return da(),Hr}function Oa(){return da(),Yr}function Na(){return da(),Vr}function Pa(){return da(),Kr}function Aa(){return da(),Wr}function ja(){return da(),Xr}function La(){return da(),Zr}function Ra(){return da(),Jr}function Ia(){return da(),Qr}function za(){return da(),to}function Da(){return da(),eo}function Ma(){return da(),no}function Ba(){return da(),io}function Ua(){return da(),ro}function Fa(){return da(),oo}function qa(){return da(),ao}function Ga(){return da(),so}function Ha(){return da(),lo}function Ya(){return da(),uo}function Va(){return da(),co}function Ka(){return da(),po}function Wa(){return da(),ho}function Xa(){return da(),_o}function Za(){return da(),fo}function Ja(){return da(),mo}function Qa(){return da(),yo}function ts(){return da(),$o}function es(){return da(),vo}function ns(){return da(),go}function is(){return da(),bo}function rs(){return da(),wo}function os(){return da(),xo}function as(){return da(),ko}function ss(){return da(),Eo}function ls(){return da(),Co}function us(){return da(),So}function cs(){return da(),To}function ps(){return da(),Oo}function hs(){return da(),No}function _s(){return da(),Po}function fs(){return da(),Ao}function ds(){return da(),jo}function ms(){return da(),Lo}function ys(){return da(),Ro}function $s(){return da(),Io}function vs(){return da(),zo}function gs(){return da(),Do}function bs(){return da(),Mo}function ws(){return da(),Bo}function xs(){return da(),Uo}function ks(){return da(),Fo}function Es(){return da(),qo}function Cs(){return da(),Go}function Ss(){return da(),Ho}function Ts(){return da(),Yo}function Os(){return da(),Vo}function Ns(){return da(),Ko}function Ps(){return da(),Wo}function As(){return da(),Xo}function js(){return da(),Zo}function Ls(){return da(),Jo}function Rs(){return da(),Qo}function Is(){return da(),ta}function zs(){return da(),ea}function Ds(){return da(),na}function Ms(){this.keyStroke=null,this.keyChar=null}function Bs(t,e,n,i){return i=i||Object.create(Ms.prototype),_a.call(i),Ms.call(i),i.keyStroke=Vs(t,n),i.keyChar=e,i}function Us(t,e,n,i){Gs(),this.isCtrl=t,this.isAlt=e,this.isShift=n,this.isMeta=i}function Fs(){var t;qs=this,this.EMPTY_MODIFIERS_0=(t=t||Object.create(Us.prototype),Us.call(t,!1,!1,!1,!1),t)}oa.$metadata$={kind:H,simpleName:"EnumInfo",interfaces:[]},Object.defineProperty(aa.prototype,"originalNames",{configurable:!0,get:function(){return this.myOriginalNames_0}}),aa.prototype.toNormalizedName_0=function(t){return t.toUpperCase()},aa.prototype.safeValueOf_7po0m$=function(t,e){var n=this.safeValueOf_pdl1vj$(t);return null!=n?n:e},aa.prototype.safeValueOf_pdl1vj$=function(t){return this.hasValue_pdl1vj$(t)?this.myNormalizedValueMap_0.get_11rb$(this.toNormalizedName_0(N(t))):null},aa.prototype.hasValue_pdl1vj$=function(t){return null!=t&&this.myNormalizedValueMap_0.containsKey_11rb$(this.toNormalizedName_0(t))},aa.prototype.unsafeValueOf_61zpoe$=function(t){var e;if(null==(e=this.safeValueOf_pdl1vj$(t)))throw v("name not found: '"+t+"'");return e},aa.$metadata$={kind:$,simpleName:"EnumInfoImpl",interfaces:[oa]},sa.$metadata$={kind:$,simpleName:"Button",interfaces:[C]},sa.values=function(){return[ua(),ca(),pa(),ha()]},sa.valueOf_61zpoe$=function(t){switch(t){case"NONE":return ua();case"LEFT":return ca();case"MIDDLE":return pa();case"RIGHT":return ha();default:S("No enum constant jetbrains.datalore.base.event.Button."+t)}},Object.defineProperty(_a.prototype,"eventContext_qzl3re$_0",{configurable:!0,get:function(){return this.eventContext_qzl3re$_d6nbbo$_0},set:function(t){if(null!=this.eventContext_qzl3re$_0)throw _("Already set "+I(N(this.eventContext_qzl3re$_0)));if(this.isConsumed)throw _("Can't set a context to the consumed event");if(null==t)throw v("Can't set null context");this.eventContext_qzl3re$_d6nbbo$_0=t}}),Object.defineProperty(_a.prototype,"isConsumed",{configurable:!0,get:function(){return this.isConsumed_gb68t5$_0},set:function(t){this.isConsumed_gb68t5$_0=t}}),_a.prototype.consume=function(){this.doConsume_smptag$_0()},_a.prototype.doConsume_smptag$_0=function(){if(this.isConsumed)throw et();this.isConsumed=!0},_a.prototype.ensureConsumed=function(){this.isConsumed||this.consume()},_a.$metadata$={kind:$,simpleName:"Event",interfaces:[]},fa.prototype.toString=function(){return this.myValue_n4kdnj$_0},fa.$metadata$={kind:$,simpleName:"Key",interfaces:[C]},fa.values=function(){return[ma(),ya(),$a(),va(),ga(),ba(),wa(),xa(),ka(),Ea(),Ca(),Sa(),Ta(),Oa(),Na(),Pa(),Aa(),ja(),La(),Ra(),Ia(),za(),Da(),Ma(),Ba(),Ua(),Fa(),qa(),Ga(),Ha(),Ya(),Va(),Ka(),Wa(),Xa(),Za(),Ja(),Qa(),ts(),es(),ns(),is(),rs(),os(),as(),ss(),ls(),us(),cs(),ps(),hs(),_s(),fs(),ds(),ms(),ys(),$s(),vs(),gs(),bs(),ws(),xs(),ks(),Es(),Cs(),Ss(),Ts(),Os(),Ns(),Ps(),As(),js(),Ls(),Rs(),Is(),zs(),Ds()]},fa.valueOf_61zpoe$=function(t){switch(t){case"A":return ma();case"B":return ya();case"C":return $a();case"D":return va();case"E":return ga();case"F":return ba();case"G":return wa();case"H":return xa();case"I":return ka();case"J":return Ea();case"K":return Ca();case"L":return Sa();case"M":return Ta();case"N":return Oa();case"O":return Na();case"P":return Pa();case"Q":return Aa();case"R":return ja();case"S":return La();case"T":return Ra();case"U":return Ia();case"V":return za();case"W":return Da();case"X":return Ma();case"Y":return Ba();case"Z":return Ua();case"DIGIT_0":return Fa();case"DIGIT_1":return qa();case"DIGIT_2":return Ga();case"DIGIT_3":return Ha();case"DIGIT_4":return Ya();case"DIGIT_5":return Va();case"DIGIT_6":return Ka();case"DIGIT_7":return Wa();case"DIGIT_8":return Xa();case"DIGIT_9":return Za();case"LEFT_BRACE":return Ja();case"RIGHT_BRACE":return Qa();case"UP":return ts();case"DOWN":return es();case"LEFT":return ns();case"RIGHT":return is();case"PAGE_UP":return rs();case"PAGE_DOWN":return os();case"ESCAPE":return as();case"ENTER":return ss();case"HOME":return ls();case"END":return us();case"TAB":return cs();case"SPACE":return ps();case"INSERT":return hs();case"DELETE":return _s();case"BACKSPACE":return fs();case"EQUALS":return ds();case"BACK_QUOTE":return ms();case"PLUS":return ys();case"MINUS":return $s();case"SLASH":return vs();case"CONTROL":return gs();case"META":return bs();case"ALT":return ws();case"SHIFT":return xs();case"UNKNOWN":return ks();case"F1":return Es();case"F2":return Cs();case"F3":return Ss();case"F4":return Ts();case"F5":return Os();case"F6":return Ns();case"F7":return Ps();case"F8":return As();case"F9":return js();case"F10":return Ls();case"F11":return Rs();case"F12":return Is();case"COMMA":return zs();case"PERIOD":return Ds();default:S("No enum constant jetbrains.datalore.base.event.Key."+t)}},Object.defineProperty(Ms.prototype,"key",{configurable:!0,get:function(){return this.keyStroke.key}}),Object.defineProperty(Ms.prototype,"modifiers",{configurable:!0,get:function(){return this.keyStroke.modifiers}}),Ms.prototype.is_ji7i3y$=function(t,e){return this.keyStroke.is_ji7i3y$(t,e.slice())},Ms.prototype.is_c4rqdo$=function(t){var e;for(e=0;e!==t.length;++e)if(t[e].matches_l9pgtg$(this.keyStroke))return!0;return!1},Ms.prototype.is_4t3vif$=function(t){var e;for(e=0;e!==t.length;++e)if(t[e].matches_l9pgtg$(this.keyStroke))return!0;return!1},Ms.prototype.has_hny0b7$=function(t){return this.keyStroke.has_hny0b7$(t)},Ms.prototype.copy=function(){return Bs(this.key,nt(this.keyChar),this.modifiers)},Ms.prototype.toString=function(){return this.keyStroke.toString()},Ms.$metadata$={kind:$,simpleName:"KeyEvent",interfaces:[_a]},Fs.prototype.emptyModifiers=function(){return this.EMPTY_MODIFIERS_0},Fs.prototype.withShift=function(){return new Us(!1,!1,!0,!1)},Fs.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var qs=null;function Gs(){return null===qs&&new Fs,qs}function Hs(){this.key=null,this.modifiers=null}function Ys(t,e,n){return n=n||Object.create(Hs.prototype),Vs(t,at(e),n),n}function Vs(t,e,n){return n=n||Object.create(Hs.prototype),Hs.call(n),n.key=t,n.modifiers=ot(e),n}function Ks(){this.myKeyStrokes_0=null}function Ws(t,e,n){return n=n||Object.create(Ks.prototype),Ks.call(n),n.myKeyStrokes_0=[Ys(t,e.slice())],n}function Xs(t,e){return e=e||Object.create(Ks.prototype),Ks.call(e),e.myKeyStrokes_0=lt(t),e}function Zs(t,e){return e=e||Object.create(Ks.prototype),Ks.call(e),e.myKeyStrokes_0=t.slice(),e}function Js(){il=this,this.COPY=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$($a(),[]),Ws(hs(),[al()])]),this.CUT=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Ma(),[]),Ws(_s(),[ll()])]),this.PASTE=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(za(),[]),Ws(hs(),[ll()])]),this.UNDO=this.ctrlOrMeta_ji7i3y$(Ua(),[]),this.REDO=this.UNDO.with_hny0b7$(ll()),this.COMPLETE=Ws(ps(),[al()]),this.SHOW_DOC=this.composite_c4rqdo$([Ws(Es(),[]),this.ctrlOrMeta_ji7i3y$(Ea(),[])]),this.HELP=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(ka(),[]),this.ctrlOrMeta_ji7i3y$(Es(),[])]),this.HOME=this.composite_4t3vif$([Ys(ls(),[]),Ys(ns(),[ul()])]),this.END=this.composite_4t3vif$([Ys(us(),[]),Ys(is(),[ul()])]),this.FILE_HOME=this.ctrlOrMeta_ji7i3y$(ls(),[]),this.FILE_END=this.ctrlOrMeta_ji7i3y$(us(),[]),this.PREV_WORD=this.ctrlOrAlt_ji7i3y$(ns(),[]),this.NEXT_WORD=this.ctrlOrAlt_ji7i3y$(is(),[]),this.NEXT_EDITABLE=this.ctrlOrMeta_ji7i3y$(is(),[sl()]),this.PREV_EDITABLE=this.ctrlOrMeta_ji7i3y$(ns(),[sl()]),this.SELECT_ALL=this.ctrlOrMeta_ji7i3y$(ma(),[]),this.SELECT_FILE_HOME=this.FILE_HOME.with_hny0b7$(ll()),this.SELECT_FILE_END=this.FILE_END.with_hny0b7$(ll()),this.SELECT_HOME=this.HOME.with_hny0b7$(ll()),this.SELECT_END=this.END.with_hny0b7$(ll()),this.SELECT_WORD_FORWARD=this.NEXT_WORD.with_hny0b7$(ll()),this.SELECT_WORD_BACKWARD=this.PREV_WORD.with_hny0b7$(ll()),this.SELECT_LEFT=Ws(ns(),[ll()]),this.SELECT_RIGHT=Ws(is(),[ll()]),this.SELECT_UP=Ws(ts(),[ll()]),this.SELECT_DOWN=Ws(es(),[ll()]),this.INCREASE_SELECTION=Ws(ts(),[sl()]),this.DECREASE_SELECTION=Ws(es(),[sl()]),this.INSERT_BEFORE=this.composite_4t3vif$([Vs(ss(),this.add_0(ul(),[])),Ys(hs(),[]),Vs(ss(),this.add_0(al(),[]))]),this.INSERT_AFTER=Ws(ss(),[]),this.INSERT=this.composite_c4rqdo$([this.INSERT_BEFORE,this.INSERT_AFTER]),this.DUPLICATE=this.ctrlOrMeta_ji7i3y$(va(),[]),this.DELETE_CURRENT=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(fs(),[]),this.ctrlOrMeta_ji7i3y$(_s(),[])]),this.DELETE_TO_WORD_START=Ws(fs(),[sl()]),this.MATCHING_CONSTRUCTS=this.composite_c4rqdo$([this.ctrlOrMeta_ji7i3y$(Ja(),[sl()]),this.ctrlOrMeta_ji7i3y$(Qa(),[sl()])]),this.NAVIGATE=this.ctrlOrMeta_ji7i3y$(ya(),[]),this.NAVIGATE_BACK=this.ctrlOrMeta_ji7i3y$(Ja(),[]),this.NAVIGATE_FORWARD=this.ctrlOrMeta_ji7i3y$(Qa(),[])}Us.$metadata$={kind:$,simpleName:"KeyModifiers",interfaces:[]},Hs.prototype.has_hny0b7$=function(t){return this.modifiers.contains_11rb$(t)},Hs.prototype.is_ji7i3y$=function(t,e){return this.matches_l9pgtg$(Ys(t,e.slice()))},Hs.prototype.matches_l9pgtg$=function(t){return this.equals(t)},Hs.prototype.with_hny0b7$=function(t){var e=ot(this.modifiers);return e.add_11rb$(t),Vs(this.key,e)},Hs.prototype.hashCode=function(){return(31*this.key.hashCode()|0)+P(this.modifiers)|0},Hs.prototype.equals=function(t){var n;if(!e.isType(t,Hs))return!1;var i=null==(n=t)||e.isType(n,Hs)?n:E();return this.key===N(i).key&&l(this.modifiers,N(i).modifiers)},Hs.prototype.toString=function(){return this.key.toString()+" "+this.modifiers},Hs.$metadata$={kind:$,simpleName:"KeyStroke",interfaces:[]},Object.defineProperty(Ks.prototype,"keyStrokes",{configurable:!0,get:function(){return st(this.myKeyStrokes_0.slice())}}),Object.defineProperty(Ks.prototype,"isEmpty",{configurable:!0,get:function(){return 0===this.myKeyStrokes_0.length}}),Ks.prototype.matches_l9pgtg$=function(t){var e,n;for(e=this.myKeyStrokes_0,n=0;n!==e.length;++n)if(e[n].matches_l9pgtg$(t))return!0;return!1},Ks.prototype.with_hny0b7$=function(t){var e,n,i=u();for(e=this.myKeyStrokes_0,n=0;n!==e.length;++n){var r=e[n];i.add_11rb$(r.with_hny0b7$(t))}return Xs(i)},Ks.prototype.equals=function(t){var n,i;if(this===t)return!0;if(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))return!1;var r=null==(i=t)||e.isType(i,Ks)?i:E();return l(this.keyStrokes,N(r).keyStrokes)},Ks.prototype.hashCode=function(){return P(this.keyStrokes)},Ks.prototype.toString=function(){return this.keyStrokes.toString()},Ks.$metadata$={kind:$,simpleName:"KeyStrokeSpec",interfaces:[]},Js.prototype.ctrlOrMeta_ji7i3y$=function(t,e){return this.composite_4t3vif$([Vs(t,this.add_0(al(),e.slice())),Vs(t,this.add_0(ul(),e.slice()))])},Js.prototype.ctrlOrAlt_ji7i3y$=function(t,e){return this.composite_4t3vif$([Vs(t,this.add_0(al(),e.slice())),Vs(t,this.add_0(sl(),e.slice()))])},Js.prototype.add_0=function(t,e){var n=ot(at(e));return n.add_11rb$(t),n},Js.prototype.composite_c4rqdo$=function(t){var e,n,i=ut();for(e=0;e!==t.length;++e)for(n=t[e].keyStrokes.iterator();n.hasNext();){var r=n.next();i.add_11rb$(r)}return Xs(i)},Js.prototype.composite_4t3vif$=function(t){return Zs(t.slice())},Js.prototype.withoutShift_b0jlop$=function(t){var e,n=t.keyStrokes.iterator().next(),i=n.modifiers,r=ut();for(e=i.iterator();e.hasNext();){var o=e.next();o!==ll()&&r.add_11rb$(o)}return Bs(n.key,it(0),r)},Js.$metadata$={kind:y,simpleName:"KeyStrokeSpecs",interfaces:[]};var Qs,tl,el,nl,il=null;function rl(t,e){C.call(this),this.name$=t,this.ordinal$=e}function ol(){ol=function(){},Qs=new rl("CONTROL",0),tl=new rl("ALT",1),el=new rl("SHIFT",2),nl=new rl("META",3)}function al(){return ol(),Qs}function sl(){return ol(),tl}function ll(){return ol(),el}function ul(){return ol(),nl}function cl(t,e,n,i){if(bl(),Ll.call(this,t,e),this.button=n,this.modifiers=i,null==this.button)throw v("Null button".toString())}function pl(){gl=this}rl.$metadata$={kind:$,simpleName:"ModifierKey",interfaces:[C]},rl.values=function(){return[al(),sl(),ll(),ul()]},rl.valueOf_61zpoe$=function(t){switch(t){case"CONTROL":return al();case"ALT":return sl();case"SHIFT":return ll();case"META":return ul();default:S("No enum constant jetbrains.datalore.base.event.ModifierKey."+t)}},pl.prototype.noButton_119tl4$=function(t){return wl(t,ua(),Gs().emptyModifiers())},pl.prototype.leftButton_119tl4$=function(t){return wl(t,ca(),Gs().emptyModifiers())},pl.prototype.middleButton_119tl4$=function(t){return wl(t,pa(),Gs().emptyModifiers())},pl.prototype.rightButton_119tl4$=function(t){return wl(t,ha(),Gs().emptyModifiers())},pl.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var hl,_l,fl,dl,ml,yl,$l,vl,gl=null;function bl(){return null===gl&&new pl,gl}function wl(t,e,n,i){return i=i||Object.create(cl.prototype),cl.call(i,t.x,t.y,e,n),i}function xl(){}function kl(t,e){C.call(this),this.name$=t,this.ordinal$=e}function El(){El=function(){},hl=new kl("MOUSE_ENTERED",0),_l=new kl("MOUSE_LEFT",1),fl=new kl("MOUSE_MOVED",2),dl=new kl("MOUSE_DRAGGED",3),ml=new kl("MOUSE_CLICKED",4),yl=new kl("MOUSE_DOUBLE_CLICKED",5),$l=new kl("MOUSE_PRESSED",6),vl=new kl("MOUSE_RELEASED",7)}function Cl(){return El(),hl}function Sl(){return El(),_l}function Tl(){return El(),fl}function Ol(){return El(),dl}function Nl(){return El(),ml}function Pl(){return El(),yl}function Al(){return El(),$l}function jl(){return El(),vl}function Ll(t,e){_a.call(this),this.x=t,this.y=e}function Rl(){}function Il(){Hl=this,this.TRUE_PREDICATE_0=Ul,this.FALSE_PREDICATE_0=Fl,this.NULL_PREDICATE_0=ql,this.NOT_NULL_PREDICATE_0=Gl}function zl(t){this.closure$value=t}function Dl(t){return t}function Ml(t){this.closure$lambda=t}function Bl(t){this.mySupplier_0=t,this.myCachedValue_0=null,this.myCached_0=!1}function Ul(t){return!0}function Fl(t){return!1}function ql(t){return null==t}function Gl(t){return null!=t}cl.$metadata$={kind:$,simpleName:"MouseEvent",interfaces:[Ll]},xl.$metadata$={kind:H,simpleName:"MouseEventSource",interfaces:[]},kl.$metadata$={kind:$,simpleName:"MouseEventSpec",interfaces:[C]},kl.values=function(){return[Cl(),Sl(),Tl(),Ol(),Nl(),Pl(),Al(),jl()]},kl.valueOf_61zpoe$=function(t){switch(t){case"MOUSE_ENTERED":return Cl();case"MOUSE_LEFT":return Sl();case"MOUSE_MOVED":return Tl();case"MOUSE_DRAGGED":return Ol();case"MOUSE_CLICKED":return Nl();case"MOUSE_DOUBLE_CLICKED":return Pl();case"MOUSE_PRESSED":return Al();case"MOUSE_RELEASED":return jl();default:S("No enum constant jetbrains.datalore.base.event.MouseEventSpec."+t)}},Object.defineProperty(Ll.prototype,"location",{configurable:!0,get:function(){return new Iu(this.x,this.y)}}),Ll.prototype.toString=function(){return"{x="+this.x+",y="+this.y+"}"},Ll.$metadata$={kind:$,simpleName:"PointEvent",interfaces:[_a]},Rl.$metadata$={kind:H,simpleName:"Function",interfaces:[]},zl.prototype.get=function(){return this.closure$value},zl.$metadata$={kind:$,interfaces:[Vl]},Il.prototype.constantSupplier_mh5how$=function(t){return new zl(t)},Il.prototype.memorize_kji2v1$=function(t){return new Bl(t)},Il.prototype.alwaysTrue_287e2$=function(){return this.TRUE_PREDICATE_0},Il.prototype.alwaysFalse_287e2$=function(){return this.FALSE_PREDICATE_0},Il.prototype.constant_jkq9vw$=function(t){return e=t,function(t){return e};var e},Il.prototype.isNull_287e2$=function(){return this.NULL_PREDICATE_0},Il.prototype.isNotNull_287e2$=function(){return this.NOT_NULL_PREDICATE_0},Il.prototype.identity_287e2$=function(){return Dl},Il.prototype.same_tpy1pm$=function(t){return e=t,function(t){return t===e};var e},Ml.prototype.apply_11rb$=function(t){return this.closure$lambda(t)},Ml.$metadata$={kind:$,interfaces:[Rl]},Il.prototype.funcOf_7h29gk$=function(t){return new Ml(t)},Bl.prototype.get=function(){return this.myCached_0||(this.myCachedValue_0=this.mySupplier_0.get(),this.myCached_0=!0),N(this.myCachedValue_0)},Bl.$metadata$={kind:$,simpleName:"Memo",interfaces:[Vl]},Il.$metadata$={kind:y,simpleName:"Functions",interfaces:[]};var Hl=null;function Yl(){}function Vl(){}function Kl(t){this.myValue_0=t}function Wl(){Xl=this}Yl.$metadata$={kind:H,simpleName:"Runnable",interfaces:[]},Vl.$metadata$={kind:H,simpleName:"Supplier",interfaces:[]},Kl.prototype.get=function(){return this.myValue_0},Kl.prototype.set_11rb$=function(t){this.myValue_0=t},Kl.prototype.toString=function(){return""+I(this.myValue_0)},Kl.$metadata$={kind:$,simpleName:"Value",interfaces:[Vl]},Wl.prototype.isNullOrEmpty_pdl1vj$=function(t){var e=null==t;return e||(e=0===t.length),e},Wl.prototype.nullToEmpty_pdl1vj$=function(t){return null!=t?t:""},Wl.prototype.repeat_bm4lxs$=function(t,e){for(var n=A(),i=0;i=0?t:n},iu.prototype.lse_sdesaw$=function(t,n){return e.compareTo(t,n)<=0},iu.prototype.gte_sdesaw$=function(t,n){return e.compareTo(t,n)>=0},iu.prototype.ls_sdesaw$=function(t,n){return e.compareTo(t,n)<0},iu.prototype.gt_sdesaw$=function(t,n){return e.compareTo(t,n)>0},iu.$metadata$={kind:y,simpleName:"Comparables",interfaces:[]};var ru=null;function ou(){return null===ru&&new iu,ru}function au(t){hu.call(this),this.myComparator_0=t}function su(){lu=this}au.prototype.compare=function(t,e){return this.myComparator_0.compare(t,e)},au.$metadata$={kind:$,simpleName:"ComparatorOrdering",interfaces:[hu]},su.prototype.checkNonNegative_0=function(t){if(t<0)throw new _t(t.toString())},su.prototype.toList_yl67zr$=function(t){return ft(t)},su.prototype.size_fakr2g$=function(t){return dt(t)},su.prototype.isEmpty_fakr2g$=function(t){var n,i,r;return null!=(r=null!=(i=e.isType(n=t,mt)?n:null)?i.isEmpty():null)?r:!t.iterator().hasNext()},su.prototype.filter_fpit1u$=function(t,e){var n,i=u();for(n=t.iterator();n.hasNext();){var r=n.next();e(r)&&i.add_11rb$(r)}return i},su.prototype.all_fpit1u$=function(t,n){var i;t:do{var r;if(e.isType(t,mt)&&t.isEmpty()){i=!0;break t}for(r=t.iterator();r.hasNext();)if(!n(r.next())){i=!1;break t}i=!0}while(0);return i},su.prototype.concat_yxozss$=function(t,e){return yt(t,e)},su.prototype.get_7iig3d$=function(t,n){var i;if(this.checkNonNegative_0(n),e.isType(t,$t))return(e.isType(i=t,$t)?i:E()).get_za3lpa$(n);for(var r=t.iterator(),o=0;o<=n;o++){if(o===n)return r.next();r.next()}throw new _t(n.toString())},su.prototype.get_dhabsj$=function(t,n,i){var r;if(this.checkNonNegative_0(n),e.isType(t,$t)){var o=e.isType(r=t,$t)?r:E();return n0)return!1;n=i}return!0},_u.prototype.compare=function(t,e){return this.this$Ordering.compare(t,e)},_u.$metadata$={kind:$,interfaces:[wt]},hu.prototype.sortedCopy_m5x2f4$=function(t){var n,i=e.isArray(n=uu().toArray_hjktyj$(t))?n:E();return xt(i,new _u(this)),kt(i)},hu.prototype.reverse=function(){return new au(Et(this))},hu.prototype.min_t5quzl$=function(t,e){return this.compare(t,e)<=0?t:e},hu.prototype.min_m5x2f4$=function(t){return this.min_x5a2gs$(t.iterator())},hu.prototype.min_x5a2gs$=function(t){for(var e=t.next();t.hasNext();)e=this.min_t5quzl$(e,t.next());return e},hu.prototype.max_t5quzl$=function(t,e){return this.compare(t,e)>=0?t:e},hu.prototype.max_m5x2f4$=function(t){return this.max_x5a2gs$(t.iterator())},hu.prototype.max_x5a2gs$=function(t){for(var e=t.next();t.hasNext();)e=this.max_t5quzl$(e,t.next());return e},fu.prototype.from_iajr8b$=function(t){var n;return e.isType(t,hu)?e.isType(n=t,hu)?n:E():new au(t)},fu.prototype.natural_dahdeg$=function(){return new au(Ct())},fu.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var du=null;function mu(){return null===du&&new fu,du}function yu(){$u=this}hu.$metadata$={kind:$,simpleName:"Ordering",interfaces:[wt]},yu.prototype.newHashSet_yl67zr$=function(t){var n;if(e.isType(t,mt)){var i=e.isType(n=t,mt)?n:E();return ot(i)}return this.newHashSet_0(t.iterator())},yu.prototype.newHashSet_0=function(t){for(var e=ut();t.hasNext();)e.add_11rb$(t.next());return e},yu.$metadata$={kind:y,simpleName:"Sets",interfaces:[]};var $u=null;function vu(){this.elements_0=u()}function gu(){this.sortedKeys_0=u(),this.map_0=Ot()}function bu(t,e){ku(),this.origin=t,this.dimension=e}function wu(){xu=this}vu.prototype.empty=function(){return this.elements_0.isEmpty()},vu.prototype.push_11rb$=function(t){return this.elements_0.add_11rb$(t)},vu.prototype.pop=function(){return this.elements_0.isEmpty()?null:this.elements_0.removeAt_za3lpa$(this.elements_0.size-1|0)},vu.prototype.peek=function(){return St(this.elements_0)},vu.$metadata$={kind:$,simpleName:"Stack",interfaces:[]},Object.defineProperty(gu.prototype,"values",{configurable:!0,get:function(){return this.map_0.values}}),gu.prototype.get_mef7kx$=function(t){return this.map_0.get_11rb$(t)},gu.prototype.put_ncwa5f$=function(t,e){var n=Tt(this.sortedKeys_0,t);return n<0?this.sortedKeys_0.add_wxm5ur$(~n,t):this.sortedKeys_0.set_wxm5ur$(n,t),this.map_0.put_xwzc9p$(t,e)},gu.prototype.containsKey_mef7kx$=function(t){return this.map_0.containsKey_11rb$(t)},gu.prototype.floorKey_mef7kx$=function(t){var e=Tt(this.sortedKeys_0,t);return e<0&&(e=~e-1|0)<0?null:this.sortedKeys_0.get_za3lpa$(e)},gu.prototype.ceilingKey_mef7kx$=function(t){var e=Tt(this.sortedKeys_0,t);return e<0&&(e=~e)===this.sortedKeys_0.size?null:this.sortedKeys_0.get_za3lpa$(e)},gu.$metadata$={kind:$,simpleName:"TreeMap",interfaces:[]},Object.defineProperty(bu.prototype,"center",{configurable:!0,get:function(){return this.origin.add_gpjtzr$(this.dimension.mul_14dthe$(.5))}}),Object.defineProperty(bu.prototype,"left",{configurable:!0,get:function(){return this.origin.x}}),Object.defineProperty(bu.prototype,"right",{configurable:!0,get:function(){return this.origin.x+this.dimension.x}}),Object.defineProperty(bu.prototype,"top",{configurable:!0,get:function(){return this.origin.y}}),Object.defineProperty(bu.prototype,"bottom",{configurable:!0,get:function(){return this.origin.y+this.dimension.y}}),Object.defineProperty(bu.prototype,"width",{configurable:!0,get:function(){return this.dimension.x}}),Object.defineProperty(bu.prototype,"height",{configurable:!0,get:function(){return this.dimension.y}}),Object.defineProperty(bu.prototype,"parts",{configurable:!0,get:function(){var t=u();return t.add_11rb$(new Ou(this.origin,this.origin.add_gpjtzr$(new Nu(this.dimension.x,0)))),t.add_11rb$(new Ou(this.origin,this.origin.add_gpjtzr$(new Nu(0,this.dimension.y)))),t.add_11rb$(new Ou(this.origin.add_gpjtzr$(this.dimension),this.origin.add_gpjtzr$(new Nu(this.dimension.x,0)))),t.add_11rb$(new Ou(this.origin.add_gpjtzr$(this.dimension),this.origin.add_gpjtzr$(new Nu(0,this.dimension.y)))),t}}),bu.prototype.xRange=function(){return new Ql(this.origin.x,this.origin.x+this.dimension.x)},bu.prototype.yRange=function(){return new Ql(this.origin.y,this.origin.y+this.dimension.y)},bu.prototype.contains_gpjtzr$=function(t){return this.origin.x<=t.x&&this.origin.x+this.dimension.x>=t.x&&this.origin.y<=t.y&&this.origin.y+this.dimension.y>=t.y},bu.prototype.union_wthzt5$=function(t){var e=this.origin.min_gpjtzr$(t.origin),n=this.origin.add_gpjtzr$(this.dimension),i=t.origin.add_gpjtzr$(t.dimension);return new bu(e,n.max_gpjtzr$(i).subtract_gpjtzr$(e))},bu.prototype.intersects_wthzt5$=function(t){var e=this.origin,n=this.origin.add_gpjtzr$(this.dimension),i=t.origin,r=t.origin.add_gpjtzr$(t.dimension);return r.x>=e.x&&n.x>=i.x&&r.y>=e.y&&n.y>=i.y},bu.prototype.intersect_wthzt5$=function(t){var e=this.origin,n=this.origin.add_gpjtzr$(this.dimension),i=t.origin,r=t.origin.add_gpjtzr$(t.dimension),o=e.max_gpjtzr$(i),a=n.min_gpjtzr$(r).subtract_gpjtzr$(o);return a.x<0||a.y<0?null:new bu(o,a)},bu.prototype.add_gpjtzr$=function(t){return new bu(this.origin.add_gpjtzr$(t),this.dimension)},bu.prototype.subtract_gpjtzr$=function(t){return new bu(this.origin.subtract_gpjtzr$(t),this.dimension)},bu.prototype.distance_gpjtzr$=function(t){var e,n=0,i=!1;for(e=this.parts.iterator();e.hasNext();){var r=e.next();if(i){var o=r.distance_gpjtzr$(t);o=0&&n.dotProduct_gpjtzr$(r)>=0},Ou.prototype.intersection_69p9e5$=function(t){var e=this.start,n=t.start,i=this.end.subtract_gpjtzr$(this.start),r=t.end.subtract_gpjtzr$(t.start),o=i.dotProduct_gpjtzr$(r.orthogonal());if(0===o)return null;var a=n.subtract_gpjtzr$(e).dotProduct_gpjtzr$(r.orthogonal())/o;if(a<0||a>1)return null;var s=r.dotProduct_gpjtzr$(i.orthogonal()),l=e.subtract_gpjtzr$(n).dotProduct_gpjtzr$(i.orthogonal())/s;return l<0||l>1?null:e.add_gpjtzr$(i.mul_14dthe$(a))},Ou.prototype.length=function(){return this.start.subtract_gpjtzr$(this.end).length()},Ou.prototype.equals=function(t){var n;if(!e.isType(t,Ou))return!1;var i=null==(n=t)||e.isType(n,Ou)?n:E();return N(i).start.equals(this.start)&&i.end.equals(this.end)},Ou.prototype.hashCode=function(){return(31*this.start.hashCode()|0)+this.end.hashCode()|0},Ou.prototype.toString=function(){return"["+this.start+" -> "+this.end+"]"},Ou.$metadata$={kind:$,simpleName:"DoubleSegment",interfaces:[]},Nu.prototype.add_gpjtzr$=function(t){return new Nu(this.x+t.x,this.y+t.y)},Nu.prototype.subtract_gpjtzr$=function(t){return new Nu(this.x-t.x,this.y-t.y)},Nu.prototype.max_gpjtzr$=function(t){var e=this.x,n=t.x,i=f.max(e,n),r=this.y,o=t.y;return new Nu(i,f.max(r,o))},Nu.prototype.min_gpjtzr$=function(t){var e=this.x,n=t.x,i=f.min(e,n),r=this.y,o=t.y;return new Nu(i,f.min(r,o))},Nu.prototype.mul_14dthe$=function(t){return new Nu(this.x*t,this.y*t)},Nu.prototype.dotProduct_gpjtzr$=function(t){return this.x*t.x+this.y*t.y},Nu.prototype.negate=function(){return new Nu(-this.x,-this.y)},Nu.prototype.orthogonal=function(){return new Nu(-this.y,this.x)},Nu.prototype.length=function(){var t=this.x*this.x+this.y*this.y;return f.sqrt(t)},Nu.prototype.normalize=function(){return this.mul_14dthe$(1/this.length())},Nu.prototype.rotate_14dthe$=function(t){return new Nu(this.x*f.cos(t)-this.y*f.sin(t),this.x*f.sin(t)+this.y*f.cos(t))},Nu.prototype.equals=function(t){var n;if(!e.isType(t,Nu))return!1;var i=null==(n=t)||e.isType(n,Nu)?n:E();return N(i).x===this.x&&i.y===this.y},Nu.prototype.hashCode=function(){return P(this.x)+(31*P(this.y)|0)|0},Nu.prototype.toString=function(){return"("+this.x+", "+this.y+")"},Pu.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Au=null;function ju(){return null===Au&&new Pu,Au}function Lu(t,e){this.origin=t,this.dimension=e}function Ru(t,e){this.start=t,this.end=e}function Iu(t,e){Mu(),this.x=t,this.y=e}function zu(){Du=this,this.ZERO=new Iu(0,0)}Nu.$metadata$={kind:$,simpleName:"DoubleVector",interfaces:[]},Object.defineProperty(Lu.prototype,"boundSegments",{configurable:!0,get:function(){var t=this.boundPoints_0;return[new Ru(t[0],t[1]),new Ru(t[1],t[2]),new Ru(t[2],t[3]),new Ru(t[3],t[0])]}}),Object.defineProperty(Lu.prototype,"boundPoints_0",{configurable:!0,get:function(){return[this.origin,this.origin.add_119tl4$(new Iu(this.dimension.x,0)),this.origin.add_119tl4$(this.dimension),this.origin.add_119tl4$(new Iu(0,this.dimension.y))]}}),Lu.prototype.add_119tl4$=function(t){return new Lu(this.origin.add_119tl4$(t),this.dimension)},Lu.prototype.sub_119tl4$=function(t){return new Lu(this.origin.sub_119tl4$(t),this.dimension)},Lu.prototype.contains_vfns7u$=function(t){return this.contains_119tl4$(t.origin)&&this.contains_119tl4$(t.origin.add_119tl4$(t.dimension))},Lu.prototype.contains_119tl4$=function(t){return this.origin.x<=t.x&&(this.origin.x+this.dimension.x|0)>=t.x&&this.origin.y<=t.y&&(this.origin.y+this.dimension.y|0)>=t.y},Lu.prototype.union_vfns7u$=function(t){var e=this.origin.min_119tl4$(t.origin),n=this.origin.add_119tl4$(this.dimension),i=t.origin.add_119tl4$(t.dimension);return new Lu(e,n.max_119tl4$(i).sub_119tl4$(e))},Lu.prototype.intersects_vfns7u$=function(t){var e=this.origin,n=this.origin.add_119tl4$(this.dimension),i=t.origin,r=t.origin.add_119tl4$(t.dimension);return r.x>=e.x&&n.x>=i.x&&r.y>=e.y&&n.y>=i.y},Lu.prototype.intersect_vfns7u$=function(t){if(!this.intersects_vfns7u$(t))throw _("rectangle ["+this+"] doesn't intersect ["+t+"]");var e=this.origin.add_119tl4$(this.dimension),n=t.origin.add_119tl4$(t.dimension),i=e.min_119tl4$(n),r=this.origin.max_119tl4$(t.origin);return new Lu(r,i.sub_119tl4$(r))},Lu.prototype.innerIntersects_vfns7u$=function(t){var e=this.origin,n=this.origin.add_119tl4$(this.dimension),i=t.origin,r=t.origin.add_119tl4$(t.dimension);return r.x>e.x&&n.x>i.x&&r.y>e.y&&n.y>i.y},Lu.prototype.changeDimension_119tl4$=function(t){return new Lu(this.origin,t)},Lu.prototype.distance_119tl4$=function(t){return this.toDoubleRectangle_0().distance_gpjtzr$(t.toDoubleVector())},Lu.prototype.xRange=function(){return new Ql(this.origin.x,this.origin.x+this.dimension.x|0)},Lu.prototype.yRange=function(){return new Ql(this.origin.y,this.origin.y+this.dimension.y|0)},Lu.prototype.hashCode=function(){return(31*this.origin.hashCode()|0)+this.dimension.hashCode()|0},Lu.prototype.equals=function(t){var n,i,r;if(!e.isType(t,Lu))return!1;var o=null==(n=t)||e.isType(n,Lu)?n:E();return(null!=(i=this.origin)?i.equals(N(o).origin):null)&&(null!=(r=this.dimension)?r.equals(o.dimension):null)},Lu.prototype.toDoubleRectangle_0=function(){return new bu(this.origin.toDoubleVector(),this.dimension.toDoubleVector())},Lu.prototype.center=function(){return this.origin.add_119tl4$(new Iu(this.dimension.x/2|0,this.dimension.y/2|0))},Lu.prototype.toString=function(){return this.origin.toString()+" - "+this.dimension},Lu.$metadata$={kind:$,simpleName:"Rectangle",interfaces:[]},Ru.prototype.distance_119tl4$=function(t){var n=this.start.sub_119tl4$(t),i=this.end.sub_119tl4$(t);if(this.isDistanceToLineBest_0(t))return Nt(e.imul(n.x,i.y)-e.imul(n.y,i.x)|0)/this.length();var r=n.toDoubleVector().length(),o=i.toDoubleVector().length();return f.min(r,o)},Ru.prototype.isDistanceToLineBest_0=function(t){var e=this.start.sub_119tl4$(this.end),n=e.negate(),i=t.sub_119tl4$(this.end),r=t.sub_119tl4$(this.start);return e.dotProduct_119tl4$(i)>=0&&n.dotProduct_119tl4$(r)>=0},Ru.prototype.toDoubleSegment=function(){return new Ou(this.start.toDoubleVector(),this.end.toDoubleVector())},Ru.prototype.intersection_51grtu$=function(t){return this.toDoubleSegment().intersection_69p9e5$(t.toDoubleSegment())},Ru.prototype.length=function(){return this.start.sub_119tl4$(this.end).length()},Ru.prototype.contains_119tl4$=function(t){var e=t.sub_119tl4$(this.start),n=t.sub_119tl4$(this.end);return!!e.isParallel_119tl4$(n)&&e.dotProduct_119tl4$(n)<=0},Ru.prototype.equals=function(t){var n,i,r;if(!e.isType(t,Ru))return!1;var o=null==(n=t)||e.isType(n,Ru)?n:E();return(null!=(i=N(o).start)?i.equals(this.start):null)&&(null!=(r=o.end)?r.equals(this.end):null)},Ru.prototype.hashCode=function(){return(31*this.start.hashCode()|0)+this.end.hashCode()|0},Ru.prototype.toString=function(){return"["+this.start+" -> "+this.end+"]"},Ru.$metadata$={kind:$,simpleName:"Segment",interfaces:[]},zu.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var Du=null;function Mu(){return null===Du&&new zu,Du}function Bu(){this.myArray_0=null}function Uu(t){return t=t||Object.create(Bu.prototype),Hu.call(t),Bu.call(t),t.myArray_0=u(),t}function Fu(t,e){return e=e||Object.create(Bu.prototype),Hu.call(e),Bu.call(e),e.myArray_0=gt(t),e}function qu(){this.myObj_0=null}function Gu(t,n){var i;return n=n||Object.create(qu.prototype),Hu.call(n),qu.call(n),n.myObj_0=Rt(e.isType(i=t,k)?i:E()),n}function Hu(){}function Yu(){this.buffer_suueb3$_0=this.buffer_suueb3$_0}function Vu(t){ec(),this.input_0=t,this.i_0=0,this.tokenStart_0=0,this.currentToken_dslfm7$_0=null,this.nextToken()}function Ku(t){return Ut(nt(t))}function Wu(t){return ec().isDigit_0(nt(t))}function Xu(t){return ec().isDigit_0(nt(t))}function Zu(t){return ec().isDigit_0(nt(t))}function Ju(){return Pt}function Qu(){tc=this,this.digits_0=new Gt(48,57)}Iu.prototype.add_119tl4$=function(t){return new Iu(this.x+t.x|0,this.y+t.y|0)},Iu.prototype.sub_119tl4$=function(t){return this.add_119tl4$(t.negate())},Iu.prototype.negate=function(){return new Iu(0|-this.x,0|-this.y)},Iu.prototype.max_119tl4$=function(t){var e=this.x,n=t.x,i=f.max(e,n),r=this.y,o=t.y;return new Iu(i,f.max(r,o))},Iu.prototype.min_119tl4$=function(t){var e=this.x,n=t.x,i=f.min(e,n),r=this.y,o=t.y;return new Iu(i,f.min(r,o))},Iu.prototype.mul_za3lpa$=function(t){return new Iu(e.imul(this.x,t),e.imul(this.y,t))},Iu.prototype.div_za3lpa$=function(t){return new Iu(this.x/t|0,this.y/t|0)},Iu.prototype.dotProduct_119tl4$=function(t){return e.imul(this.x,t.x)+e.imul(this.y,t.y)|0},Iu.prototype.length=function(){var t=e.imul(this.x,this.x)+e.imul(this.y,this.y)|0;return f.sqrt(t)},Iu.prototype.toDoubleVector=function(){return new Nu(this.x,this.y)},Iu.prototype.abs=function(){return new Iu(Nt(this.x),Nt(this.y))},Iu.prototype.isParallel_119tl4$=function(t){return 0==(e.imul(this.x,t.y)-e.imul(t.x,this.y)|0)},Iu.prototype.orthogonal=function(){return new Iu(0|-this.y,this.x)},Iu.prototype.equals=function(t){var n;if(!e.isType(t,Iu))return!1;var i=null==(n=t)||e.isType(n,Iu)?n:E();return this.x===N(i).x&&this.y===i.y},Iu.prototype.hashCode=function(){return(31*this.x|0)+this.y|0},Iu.prototype.toString=function(){return"("+this.x+", "+this.y+")"},Iu.$metadata$={kind:$,simpleName:"Vector",interfaces:[]},Bu.prototype.getDouble_za3lpa$=function(t){var e;return"number"==typeof(e=this.myArray_0.get_za3lpa$(t))?e:E()},Bu.prototype.add_pdl1vj$=function(t){return this.myArray_0.add_11rb$(t),this},Bu.prototype.add_yrwdxb$=function(t){return this.myArray_0.add_11rb$(t),this},Bu.prototype.addStrings_d294za$=function(t){return this.myArray_0.addAll_brywnq$(t),this},Bu.prototype.addAll_5ry1at$=function(t){var e;for(e=t.iterator();e.hasNext();){var n=e.next();this.myArray_0.add_11rb$(n.get())}return this},Bu.prototype.addAll_m5dwgt$=function(t){return this.addAll_5ry1at$(st(t.slice())),this},Bu.prototype.stream=function(){return Rc(this.myArray_0)},Bu.prototype.objectStream=function(){return zc(this.myArray_0)},Bu.prototype.fluentObjectStream=function(){return jt(zc(this.myArray_0),At("FluentObject",(function(t){return Gu(t)})))},Bu.prototype.get=function(){return this.myArray_0},Bu.$metadata$={kind:$,simpleName:"FluentArray",interfaces:[Hu]},qu.prototype.getArr_0=function(t){var n;return e.isType(n=this.myObj_0.get_11rb$(t),$t)?n:E()},qu.prototype.getObj_0=function(t){var n;return e.isType(n=this.myObj_0.get_11rb$(t),k)?n:E()},qu.prototype.get=function(){return this.myObj_0},qu.prototype.contains_61zpoe$=function(t){return this.myObj_0.containsKey_11rb$(t)},qu.prototype.containsNotNull_0=function(t){return this.contains_61zpoe$(t)&&null!=this.myObj_0.get_11rb$(t)},qu.prototype.put_wxs67v$=function(t,e){var n=this.myObj_0,i=null!=e?e.get():null;return n.put_xwzc9p$(t,i),this},qu.prototype.put_jyasbz$=function(t,e){return this.myObj_0.put_xwzc9p$(t,e),this},qu.prototype.put_hzlfav$=function(t,e){return this.myObj_0.put_xwzc9p$(t,e),this},qu.prototype.put_h92gdm$=function(t,e){return this.myObj_0.put_xwzc9p$(t,e),this},qu.prototype.put_snuhza$=function(t,e){var n=this.myObj_0,i=null!=e?Bc(e):null;return n.put_xwzc9p$(t,i),this},qu.prototype.getInt_61zpoe$=function(t){return Lt(Uc(this.myObj_0,t))},qu.prototype.getDouble_61zpoe$=function(t){return Fc(this.myObj_0,t)},qu.prototype.getBoolean_61zpoe$=function(t){var e;return"boolean"==typeof(e=this.myObj_0.get_11rb$(t))?e:E()},qu.prototype.getString_61zpoe$=function(t){var e;return"string"==typeof(e=this.myObj_0.get_11rb$(t))?e:E()},qu.prototype.getStrings_61zpoe$=function(t){var e,n=this.getArr_0(t),i=h(p(n,10));for(e=n.iterator();e.hasNext();){var r=e.next();i.add_11rb$(Dc(r))}return i},qu.prototype.getEnum_xwn52g$=function(t,e){var n;return Mc("string"==typeof(n=this.myObj_0.get_11rb$(t))?n:E(),e)},qu.prototype.getEnum_a9gw98$=J("lets-plot-base-portable.jetbrains.datalore.base.json.FluentObject.getEnum_a9gw98$",(function(t,e,n){return this.getEnum_xwn52g$(n,t.values())})),qu.prototype.getArray_61zpoe$=function(t){return Fu(this.getArr_0(t))},qu.prototype.getObject_61zpoe$=function(t){return Gu(this.getObj_0(t))},qu.prototype.getInt_qoz5hj$=function(t,e){return e(this.getInt_61zpoe$(t)),this},qu.prototype.getDouble_l47sdb$=function(t,e){return e(this.getDouble_61zpoe$(t)),this},qu.prototype.getBoolean_48wr2m$=function(t,e){return e(this.getBoolean_61zpoe$(t)),this},qu.prototype.getString_hyc7mn$=function(t,e){return e(this.getString_61zpoe$(t)),this},qu.prototype.getStrings_lpk3a7$=function(t,e){return e(this.getStrings_61zpoe$(t)),this},qu.prototype.getEnum_651ru9$=function(t,e,n){return e(this.getEnum_xwn52g$(t,n)),this},qu.prototype.getArray_nhu1ij$=function(t,e){return e(this.getArray_61zpoe$(t)),this},qu.prototype.getObject_6k19qz$=function(t,e){return e(this.getObject_61zpoe$(t)),this},qu.prototype.putRemovable_wxs67v$=function(t,e){return null!=e&&this.put_wxs67v$(t,e),this},qu.prototype.putRemovable_snuhza$=function(t,e){return null!=e&&this.put_snuhza$(t,e),this},qu.prototype.forEntries_ophlsb$=function(t){var e;for(e=this.myObj_0.keys.iterator();e.hasNext();){var n=e.next();t(n,this.myObj_0.get_11rb$(n))}return this},qu.prototype.forObjEntries_izf7h5$=function(t){var n;for(n=this.myObj_0.keys.iterator();n.hasNext();){var i,r=n.next();t(r,e.isType(i=this.myObj_0.get_11rb$(r),k)?i:E())}return this},qu.prototype.forArrEntries_2wy1dl$=function(t){var n;for(n=this.myObj_0.keys.iterator();n.hasNext();){var i,r=n.next();t(r,e.isType(i=this.myObj_0.get_11rb$(r),$t)?i:E())}return this},qu.prototype.accept_ysf37t$=function(t){return t(this),this},qu.prototype.forStrings_2by8ig$=function(t,e){var n,i,r=qc(this.myObj_0,t),o=h(p(r,10));for(n=r.iterator();n.hasNext();){var a=n.next();o.add_11rb$(Dc(a))}for(i=o.iterator();i.hasNext();)e(i.next());return this},qu.prototype.getExistingDouble_l47sdb$=function(t,e){return this.containsNotNull_0(t)&&this.getDouble_l47sdb$(t,e),this},qu.prototype.getOptionalStrings_jpy86i$=function(t,e){return this.containsNotNull_0(t)?e(this.getStrings_61zpoe$(t)):e(null),this},qu.prototype.getExistingString_hyc7mn$=function(t,e){return this.containsNotNull_0(t)&&this.getString_hyc7mn$(t,e),this},qu.prototype.forExistingStrings_hyc7mn$=function(t,e){return this.containsNotNull_0(t)&&this.forStrings_2by8ig$(t,(n=e,function(t){return n(N(t)),Pt})),this;var n},qu.prototype.getExistingObject_6k19qz$=function(t,e){if(this.containsNotNull_0(t)){var n=this.getObject_61zpoe$(t);n.myObj_0.keys.isEmpty()||e(n)}return this},qu.prototype.getExistingArray_nhu1ij$=function(t,e){return this.containsNotNull_0(t)&&e(this.getArray_61zpoe$(t)),this},qu.prototype.forObjects_6k19qz$=function(t,e){var n;for(n=this.getArray_61zpoe$(t).fluentObjectStream().iterator();n.hasNext();)e(n.next());return this},qu.prototype.getOptionalInt_w5p0jm$=function(t,e){return this.containsNotNull_0(t)?e(this.getInt_61zpoe$(t)):e(null),this},qu.prototype.getIntOrDefault_u1i54l$=function(t,e,n){return this.containsNotNull_0(t)?e(this.getInt_61zpoe$(t)):e(n),this},qu.prototype.forEnums_651ru9$=function(t,e,n){var i;for(i=this.getArr_0(t).iterator();i.hasNext();){var r;e(Mc("string"==typeof(r=i.next())?r:E(),n))}return this},qu.prototype.getOptionalEnum_651ru9$=function(t,e,n){return this.containsNotNull_0(t)?e(this.getEnum_xwn52g$(t,n)):e(null),this},qu.$metadata$={kind:$,simpleName:"FluentObject",interfaces:[Hu]},Hu.$metadata$={kind:$,simpleName:"FluentValue",interfaces:[]},Object.defineProperty(Yu.prototype,"buffer_0",{configurable:!0,get:function(){return null==this.buffer_suueb3$_0?It("buffer"):this.buffer_suueb3$_0},set:function(t){this.buffer_suueb3$_0=t}}),Yu.prototype.formatJson_za3rmp$=function(t){return this.buffer_0=A(),this.handleValue_0(t),this.buffer_0.toString()},Yu.prototype.handleList_0=function(t){var e;this.append_0("["),this.headTail_0(t,At("handleValue",function(t,e){return t.handleValue_0(e),Pt}.bind(null,this)),(e=this,function(t){var n;for(n=t.iterator();n.hasNext();){var i=n.next(),r=e;r.append_0(","),r.handleValue_0(i)}return Pt})),this.append_0("]")},Yu.prototype.handleMap_0=function(t){var e;this.append_0("{"),this.headTail_0(t.entries,At("handlePair",function(t,e){return t.handlePair_0(e),Pt}.bind(null,this)),(e=this,function(t){var n;for(n=t.iterator();n.hasNext();){var i=n.next(),r=e;r.append_0(",\n"),r.handlePair_0(i)}return Pt})),this.append_0("}")},Yu.prototype.handleValue_0=function(t){if(null==t)this.append_0("null");else if("string"==typeof t)this.handleString_0(t);else if(e.isNumber(t)||l(t,zt))this.append_0(t.toString());else if(e.isArray(t))this.handleList_0(at(t));else if(e.isType(t,$t))this.handleList_0(t);else{if(!e.isType(t,k))throw v("Can't serialize object "+I(t));this.handleMap_0(t)}},Yu.prototype.handlePair_0=function(t){this.handleString_0(t.key),this.append_0(":"),this.handleValue_0(t.value)},Yu.prototype.handleString_0=function(t){if(null!=t){if("string"!=typeof t)throw v("Expected a string, but got '"+I(e.getKClassFromExpression(t).simpleName)+"'");this.append_0('"'+jc(t)+'"')}},Yu.prototype.append_0=function(t){return this.buffer_0.append_pdl1vj$(t)},Yu.prototype.headTail_0=function(t,e,n){t.isEmpty()||(e(Dt(t)),n(Bt(Mt(t),1)))},Yu.$metadata$={kind:$,simpleName:"JsonFormatter",interfaces:[]},Object.defineProperty(Vu.prototype,"currentToken",{configurable:!0,get:function(){return this.currentToken_dslfm7$_0},set:function(t){this.currentToken_dslfm7$_0=t}}),Object.defineProperty(Vu.prototype,"currentChar_0",{configurable:!0,get:function(){return this.input_0.charCodeAt(this.i_0)}}),Vu.prototype.nextToken=function(){var t;if(this.advanceWhile_0(Ku),!this.isFinished()){if(123===this.currentChar_0){var e=wc();this.advance_0(),t=e}else if(125===this.currentChar_0){var n=xc();this.advance_0(),t=n}else if(91===this.currentChar_0){var i=kc();this.advance_0(),t=i}else if(93===this.currentChar_0){var r=Ec();this.advance_0(),t=r}else if(44===this.currentChar_0){var o=Cc();this.advance_0(),t=o}else if(58===this.currentChar_0){var a=Sc();this.advance_0(),t=a}else if(116===this.currentChar_0){var s=Nc();this.read_0("true"),t=s}else if(102===this.currentChar_0){var l=Pc();this.read_0("false"),t=l}else if(110===this.currentChar_0){var u=Ac();this.read_0("null"),t=u}else if(34===this.currentChar_0){var c=Tc();this.readString_0(),t=c}else{if(!this.readNumber_0())throw _((this.i_0.toString()+":"+String.fromCharCode(this.currentChar_0)+" - unkown token").toString());t=Oc()}this.currentToken=t}},Vu.prototype.tokenValue=function(){var t=this.input_0,e=this.tokenStart_0,n=this.i_0;return t.substring(e,n)},Vu.prototype.readString_0=function(){for(this.startToken_0(),this.advance_0();34!==this.currentChar_0;)if(92===this.currentChar_0)if(this.advance_0(),117===this.currentChar_0){this.advance_0();for(var t=0;t<4;t++){if(!ec().isHex_0(this.currentChar_0))throw v("Failed requirement.".toString());this.advance_0()}}else{var n,i=mc,r=Ft(this.currentChar_0);if(!(e.isType(n=i,k)?n:E()).containsKey_11rb$(r))throw _("Invalid escape sequence".toString());this.advance_0()}else this.advance_0();this.advance_0()},Vu.prototype.readNumber_0=function(){return!(!ec().isDigit_0(this.currentChar_0)&&45!==this.currentChar_0||(this.startToken_0(),this.advanceIfCurrent_0(e.charArrayOf(45)),this.advanceWhile_0(Wu),this.advanceIfCurrent_0(e.charArrayOf(46),(t=this,function(){if(!ec().isDigit_0(t.currentChar_0))throw v("Number should have decimal part".toString());return t.advanceWhile_0(Xu),Pt})),this.advanceIfCurrent_0(e.charArrayOf(101,69),function(t){return function(){return t.advanceIfCurrent_0(e.charArrayOf(43,45)),t.advanceWhile_0(Zu),Pt}}(this)),0));var t},Vu.prototype.isFinished=function(){return this.i_0===this.input_0.length},Vu.prototype.startToken_0=function(){this.tokenStart_0=this.i_0},Vu.prototype.advance_0=function(){this.i_0=this.i_0+1|0},Vu.prototype.read_0=function(t){var e;for(e=Ht(t);e.hasNext();){var n=nt(e.next()),i=Ft(n);if(this.currentChar_0!==nt(i))throw v(("Wrong data: "+t).toString());if(this.isFinished())throw v("Unexpected end of string".toString());this.advance_0()}},Vu.prototype.advanceWhile_0=function(t){for(;!this.isFinished()&&t(Ft(this.currentChar_0));)this.advance_0()},Vu.prototype.advanceIfCurrent_0=function(t,e){void 0===e&&(e=Ju),!this.isFinished()&&qt(t,this.currentChar_0)&&(this.advance_0(),e())},Qu.prototype.isDigit_0=function(t){var e=this.digits_0;return null!=t&&e.contains_mef7kx$(t)},Qu.prototype.isHex_0=function(t){return this.isDigit_0(t)||new Gt(97,102).contains_mef7kx$(t)||new Gt(65,70).contains_mef7kx$(t)},Qu.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var tc=null;function ec(){return null===tc&&new Qu,tc}function nc(t){this.json_0=t}function ic(t){Vt(t,this),this.name="JsonParser$JsonException"}function rc(){$c=this}Vu.$metadata$={kind:$,simpleName:"JsonLexer",interfaces:[]},nc.prototype.parseJson=function(){var t=new Vu(this.json_0);return this.parseValue_0(t)},nc.prototype.parseValue_0=function(t){var e,n;if(e=t.currentToken,l(e,Tc())){var i=Lc(t.tokenValue());t.nextToken(),n=i}else if(l(e,Oc())){var r=Yt(t.tokenValue());t.nextToken(),n=r}else if(l(e,Pc()))t.nextToken(),n=!1;else if(l(e,Nc()))t.nextToken(),n=!0;else if(l(e,Ac()))t.nextToken(),n=null;else if(l(e,wc()))n=this.parseObject_0(t);else{if(!l(e,kc()))throw _(("Invalid token: "+I(t.currentToken)).toString());n=this.parseArray_0(t)}return n},nc.prototype.parseArray_0=function(t){var e,n,i=(e=t,n=this,function(t){n.require_0(e.currentToken,t,"[Arr] ")}),r=u();for(i(kc()),t.nextToken();!l(t.currentToken,Ec());)r.isEmpty()||(i(Cc()),t.nextToken()),r.add_11rb$(this.parseValue_0(t));return i(Ec()),t.nextToken(),r},nc.prototype.parseObject_0=function(t){var e,n,i=(e=t,n=this,function(t){n.require_0(e.currentToken,t,"[Obj] ")}),r=Wt();for(i(wc()),t.nextToken();!l(t.currentToken,xc());){r.isEmpty()||(i(Cc()),t.nextToken()),i(Tc());var o=Lc(t.tokenValue());t.nextToken(),i(Sc()),t.nextToken();var a=this.parseValue_0(t);r.put_xwzc9p$(o,a)}return i(xc()),t.nextToken(),r},nc.prototype.require_0=function(t,e,n){if(void 0===n&&(n=null),!l(t,e))throw new ic(n+"Expected token: "+I(e)+", actual: "+I(t))},ic.$metadata$={kind:$,simpleName:"JsonException",interfaces:[Kt]},nc.$metadata$={kind:$,simpleName:"JsonParser",interfaces:[]},rc.prototype.parseJson_61zpoe$=function(t){var n;return e.isType(n=new nc(t).parseJson(),Xt)?n:E()},rc.prototype.formatJson_za3rmp$=function(t){return(new Yu).formatJson_za3rmp$(t)},rc.$metadata$={kind:y,simpleName:"JsonSupport",interfaces:[]};var oc,ac,sc,lc,uc,cc,pc,hc,_c,fc,dc,mc,yc,$c=null;function vc(){return null===$c&&new rc,$c}function gc(t,e){C.call(this),this.name$=t,this.ordinal$=e}function bc(){bc=function(){},oc=new gc("LEFT_BRACE",0),ac=new gc("RIGHT_BRACE",1),sc=new gc("LEFT_BRACKET",2),lc=new gc("RIGHT_BRACKET",3),uc=new gc("COMMA",4),cc=new gc("COLON",5),pc=new gc("STRING",6),hc=new gc("NUMBER",7),_c=new gc("TRUE",8),fc=new gc("FALSE",9),dc=new gc("NULL",10)}function wc(){return bc(),oc}function xc(){return bc(),ac}function kc(){return bc(),sc}function Ec(){return bc(),lc}function Cc(){return bc(),uc}function Sc(){return bc(),cc}function Tc(){return bc(),pc}function Oc(){return bc(),hc}function Nc(){return bc(),_c}function Pc(){return bc(),fc}function Ac(){return bc(),dc}function jc(t){for(var e,n,i,r={v:null},o={v:0},a=function(t,e,n){return function(i){var r,o,a=t;if(null!=(r=t.v))o=r;else{var s=n,l=e.v;o=new Jt(s.substring(0,l))}a.v=o.append_pdl1vj$(i)}}(r,o,t);o.v0;)n=n+1|0,i=i.div(e.Long.fromInt(10));return n}function lp(t){kp(),this.spec_0=t}function up(t,e,n,i,r,o,a,s,l,u){void 0===t&&(t=" "),void 0===e&&(e=">"),void 0===n&&(n="-"),void 0===o&&(o=-1),void 0===s&&(s=6),void 0===l&&(l=""),void 0===u&&(u=!1),this.fill=t,this.align=e,this.sign=n,this.symbol=i,this.zero=r,this.width=o,this.comma=a,this.precision=s,this.type=l,this.trim=u}function cp(t,n,i,r,o){fp(),void 0===t&&(t=0),void 0===n&&(n=!1),void 0===i&&(i=z),void 0===r&&(r=z),void 0===o&&(o=null),this.number=t,this.negative=n,this.integerPart=i,this.fractionalPart=r,this.exponent=o,this.fractionLeadingZeros=18-sp(this.fractionalPart)|0,this.integerLength=sp(this.integerPart),this.fractionString=de("0",this.fractionLeadingZeros)+me(this.fractionalPart.toString(),e.charArrayOf(48))}function pp(){_p=this,this.MAX_DECIMALS_0=18,this.MAX_DECIMAL_VALUE_8be2vx$=e.Long.fromNumber(f.pow(10,18))}function hp(t,n){var i=t;n>18&&(i=w(t,b(0,t.length-(n-18)|0)));var r=he(i),o=_e(18-n|0,0);return r.multiply(e.Long.fromNumber(f.pow(10,o)))}Object.defineProperty(Gc.prototype,"isEmpty",{configurable:!0,get:function(){return 0===this.size()}}),Gc.prototype.containsKey_11rb$=function(t){return this.findByKey_0(t)>=0},Gc.prototype.remove_11rb$=function(t){var n,i=this.findByKey_0(t);if(i>=0){var r=this.myData_0[i+1|0];return this.removeAt_0(i),null==(n=r)||e.isType(n,re)?n:E()}return null},Object.defineProperty(Kc.prototype,"size",{configurable:!0,get:function(){return this.this$ListMap.size()}}),Kc.prototype.add_11rb$=function(t){throw _("Not available in keySet")},Wc.prototype.get_za3lpa$=function(t){return this.this$ListMap.myData_0[t]},Wc.$metadata$={kind:$,interfaces:[np]},Kc.prototype.iterator=function(){return this.this$ListMap.mapIterator_0(new Wc(this.this$ListMap))},Kc.$metadata$={kind:$,interfaces:[oe]},Gc.prototype.keySet=function(){return new Kc(this)},Object.defineProperty(Xc.prototype,"size",{configurable:!0,get:function(){return this.this$ListMap.size()}}),Zc.prototype.get_za3lpa$=function(t){return this.this$ListMap.myData_0[t+1|0]},Zc.$metadata$={kind:$,interfaces:[np]},Xc.prototype.iterator=function(){return this.this$ListMap.mapIterator_0(new Zc(this.this$ListMap))},Xc.$metadata$={kind:$,interfaces:[ae]},Gc.prototype.values=function(){return new Xc(this)},Object.defineProperty(Jc.prototype,"size",{configurable:!0,get:function(){return this.this$ListMap.size()}}),Qc.prototype.get_za3lpa$=function(t){return new ep(this.this$ListMap,t)},Qc.$metadata$={kind:$,interfaces:[np]},Jc.prototype.iterator=function(){return this.this$ListMap.mapIterator_0(new Qc(this.this$ListMap))},Jc.$metadata$={kind:$,interfaces:[se]},Gc.prototype.entrySet=function(){return new Jc(this)},Gc.prototype.size=function(){return this.myData_0.length/2|0},Gc.prototype.put_xwzc9p$=function(t,n){var i,r=this.findByKey_0(t);if(r>=0){var o=this.myData_0[r+1|0];return this.myData_0[r+1|0]=n,null==(i=o)||e.isType(i,re)?i:E()}var a,s=ue(this.myData_0.length+2|0);a=s.length-1|0;for(var l=0;l<=a;l++)s[l]=l=18)return dp(t,he(l),z,p);if(!(p<18))throw _("Check failed.".toString());if(p<0)return dp(t,void 0,r(l+u,Nt(p)+u.length|0));if(!(p>=0&&p<=18))throw _("Check failed.".toString());if(p>=u.length)return dp(t,he(l+u+de("0",p-u.length|0)));if(!(p>=0&&p=^]))?([+ -])?([#$])?(0)?(\\d+)?(,)?(?:\\.(\\d+))?([%bcdefgosXx])?$")}function vp(t){return g(t,"")}cp.$metadata$={kind:$,simpleName:"NumberInfo",interfaces:[]},cp.prototype.component1=function(){return this.number},cp.prototype.component2=function(){return this.negative},cp.prototype.component3=function(){return this.integerPart},cp.prototype.component4=function(){return this.fractionalPart},cp.prototype.component5=function(){return this.exponent},cp.prototype.copy_xz9h4k$=function(t,e,n,i,r){return new cp(void 0===t?this.number:t,void 0===e?this.negative:e,void 0===n?this.integerPart:n,void 0===i?this.fractionalPart:i,void 0===r?this.exponent:r)},cp.prototype.toString=function(){return"NumberInfo(number="+e.toString(this.number)+", negative="+e.toString(this.negative)+", integerPart="+e.toString(this.integerPart)+", fractionalPart="+e.toString(this.fractionalPart)+", exponent="+e.toString(this.exponent)+")"},cp.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*(t=31*t+e.hashCode(this.number)|0)+e.hashCode(this.negative)|0)+e.hashCode(this.integerPart)|0)+e.hashCode(this.fractionalPart)|0)+e.hashCode(this.exponent)|0},cp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.number,t.number)&&e.equals(this.negative,t.negative)&&e.equals(this.integerPart,t.integerPart)&&e.equals(this.fractionalPart,t.fractionalPart)&&e.equals(this.exponent,t.exponent)},mp.$metadata$={kind:$,simpleName:"Output",interfaces:[]},mp.prototype.component1=function(){return this.body},mp.prototype.component2=function(){return this.sign},mp.prototype.component3=function(){return this.prefix},mp.prototype.component4=function(){return this.suffix},mp.prototype.component5=function(){return this.padding},mp.prototype.copy_rm1j3u$=function(t,e,n,i,r){return new mp(void 0===t?this.body:t,void 0===e?this.sign:e,void 0===n?this.prefix:n,void 0===i?this.suffix:i,void 0===r?this.padding:r)},mp.prototype.toString=function(){return"Output(body="+e.toString(this.body)+", sign="+e.toString(this.sign)+", prefix="+e.toString(this.prefix)+", suffix="+e.toString(this.suffix)+", padding="+e.toString(this.padding)+")"},mp.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*(t=31*t+e.hashCode(this.body)|0)+e.hashCode(this.sign)|0)+e.hashCode(this.prefix)|0)+e.hashCode(this.suffix)|0)+e.hashCode(this.padding)|0},mp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.body,t.body)&&e.equals(this.sign,t.sign)&&e.equals(this.prefix,t.prefix)&&e.equals(this.suffix,t.suffix)&&e.equals(this.padding,t.padding)},yp.prototype.toString=function(){var t,e=this.integerPart,n=kp().FRACTION_DELIMITER_0;return e+(null!=(t=this.fractionalPart.length>0?n:null)?t:"")+this.fractionalPart+this.exponentialPart},yp.$metadata$={kind:$,simpleName:"FormattedNumber",interfaces:[]},yp.prototype.component1=function(){return this.integerPart},yp.prototype.component2=function(){return this.fractionalPart},yp.prototype.component3=function(){return this.exponentialPart},yp.prototype.copy_6hosri$=function(t,e,n){return new yp(void 0===t?this.integerPart:t,void 0===e?this.fractionalPart:e,void 0===n?this.exponentialPart:n)},yp.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.integerPart)|0)+e.hashCode(this.fractionalPart)|0)+e.hashCode(this.exponentialPart)|0},yp.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.integerPart,t.integerPart)&&e.equals(this.fractionalPart,t.fractionalPart)&&e.equals(this.exponentialPart,t.exponentialPart)},lp.prototype.apply_3p81yu$=function(t){var e=this.handleNonNumbers_0(t);if(null!=e)return e;var n=fp().createNumberInfo_yjmjg9$(t),i=new mp;return i=this.computeBody_0(i,n),i=this.trimFraction_0(i),i=this.computeSign_0(i,n),i=this.computePrefix_0(i),i=this.computeSuffix_0(i),this.spec_0.comma&&!this.spec_0.zero&&(i=this.applyGroup_0(i)),i=this.computePadding_0(i),this.spec_0.comma&&this.spec_0.zero&&(i=this.applyGroup_0(i)),this.getAlignedString_0(i)},lp.prototype.handleNonNumbers_0=function(t){var e=ee(t);return ye(e)?"NaN":e===$e.NEGATIVE_INFINITY?"-Infinity":e===$e.POSITIVE_INFINITY?"+Infinity":null},lp.prototype.getAlignedString_0=function(t){var e;switch(this.spec_0.align){case"<":e=t.sign+t.prefix+t.body+t.suffix+t.padding;break;case"=":e=t.sign+t.prefix+t.padding+t.body+t.suffix;break;case"^":var n=t.padding.length/2|0;e=ve(t.padding,b(0,n))+t.sign+t.prefix+t.body+t.suffix+ve(t.padding,b(n,t.padding.length));break;default:e=t.padding+t.sign+t.prefix+t.body+t.suffix}return e},lp.prototype.applyGroup_0=function(t){var e,n,i=t.padding,r=null!=(e=this.spec_0.zero?i:null)?e:"",o=t.body,a=r+o.integerPart,s=a.length/3,l=Lt(f.ceil(s)-1),u=_e(this.spec_0.width-o.fractionalLength-o.exponentialPart.length|0,o.integerPart.length+l|0);if((a=kp().group_0(a)).length>u){var c=a,p=a.length-u|0;a=c.substring(p),ge(a,44)&&(a="0"+a)}return t.copy_rm1j3u$(o.copy_6hosri$(a),void 0,void 0,void 0,null!=(n=this.spec_0.zero?"":null)?n:t.padding)},lp.prototype.computeBody_0=function(t,e){var n;switch(this.spec_0.type){case"%":n=this.toFixedFormat_0(fp().createNumberInfo_yjmjg9$(100*e.number),this.spec_0.precision);break;case"c":n=new yp(e.number.toString());break;case"d":n=this.toSimpleFormat_0(e,0);break;case"e":n=this.toSimpleFormat_0(this.toExponential_0(e,this.spec_0.precision),this.spec_0.precision);break;case"f":n=this.toFixedFormat_0(e,this.spec_0.precision);break;case"g":n=this.toPrecisionFormat_0(e,this.spec_0.precision);break;case"b":n=new yp(we(be(e.number),2));break;case"o":n=new yp(we(be(e.number),8));break;case"X":n=new yp(we(be(e.number),16).toUpperCase());break;case"x":n=new yp(we(be(e.number),16));break;case"s":n=this.toSiFormat_0(e,this.spec_0.precision);break;default:throw v("Wrong type: "+this.spec_0.type)}var i=n;return t.copy_rm1j3u$(i)},lp.prototype.toExponential_0=function(t,e){var n;void 0===e&&(e=-1);var i=t.number;if(i-1&&(s=this.roundToPrecision_0(s,e)),s.integerLength>1&&(r=r+1|0,s=fp().createNumberInfo_yjmjg9$(a/10)),s.copy_xz9h4k$(void 0,void 0,void 0,void 0,r)},lp.prototype.toPrecisionFormat_0=function(t,e){return void 0===e&&(e=-1),l(t.integerPart,z)?l(t.fractionalPart,z)?this.toFixedFormat_0(t,e-1|0):this.toFixedFormat_0(t,e+t.fractionLeadingZeros|0):t.integerLength>e?this.toSimpleFormat_0(this.toExponential_0(t,e-1|0),e-1|0):this.toFixedFormat_0(t,e-t.integerLength|0)},lp.prototype.toFixedFormat_0=function(t,e){if(void 0===e&&(e=0),e<=0)return new yp(be(t.number).toString());var n=this.roundToPrecision_0(t,e),i=t.integerLength=0?"+":"")+I(t.exponent):"",i=fp().createNumberInfo_yjmjg9$(t.integerPart.toNumber()+t.fractionalPart.toNumber()/fp().MAX_DECIMAL_VALUE_8be2vx$.toNumber());return e>-1?this.toFixedFormat_0(i,e).copy_6hosri$(void 0,void 0,n):new yp(i.integerPart.toString(),l(i.fractionalPart,z)?"":i.fractionString,n)},lp.prototype.toSiFormat_0=function(t,e){var n;void 0===e&&(e=-1);var i=(null!=(n=(null==t.exponent?this.toExponential_0(t,e-1|0):t).exponent)?n:0)/3,r=3*Lt(Ce(Ee(f.floor(i),-8),8))|0,o=fp(),a=t.number,s=0|-r,l=o.createNumberInfo_yjmjg9$(a*f.pow(10,s)),u=8+(r/3|0)|0,c=kp().SI_SUFFIXES_0[u];return this.toFixedFormat_0(l,e-l.integerLength|0).copy_6hosri$(void 0,void 0,c)},lp.prototype.roundToPrecision_0=function(t,n){var i;void 0===n&&(n=0);var r,o,a=n+(null!=(i=t.exponent)?i:0)|0;if(a<0){r=z;var s=Nt(a);o=t.integerLength<=s?z:t.integerPart.div(e.Long.fromNumber(f.pow(10,s))).multiply(e.Long.fromNumber(f.pow(10,s)))}else{var u=fp().MAX_DECIMAL_VALUE_8be2vx$.div(e.Long.fromNumber(f.pow(10,a)));r=l(u,z)?t.fractionalPart:be(t.fractionalPart.toNumber()/u.toNumber()).multiply(u),o=t.integerPart,l(r,fp().MAX_DECIMAL_VALUE_8be2vx$)&&(r=z,o=o.inc())}var c=o.toNumber()+r.toNumber()/fp().MAX_DECIMAL_VALUE_8be2vx$.toNumber();return t.copy_xz9h4k$(c,void 0,o,r)},lp.prototype.trimFraction_0=function(t){var n=!this.spec_0.trim;if(n||(n=0===t.body.fractionalPart.length),n)return t;var i=me(t.body.fractionalPart,e.charArrayOf(48));return t.copy_rm1j3u$(t.body.copy_6hosri$(void 0,i))},lp.prototype.computeSign_0=function(t,e){var n,i=t.body,r=Te(Se(i.integerPart),Se(i.fractionalPart));t:do{var o;for(o=r.iterator();o.hasNext();){var a=o.next();if(48!==nt(a)){n=!1;break t}}n=!0}while(0);var s=n,u=e.negative&&!s?"-":l(this.spec_0.sign,"-")?"":this.spec_0.sign;return t.copy_rm1j3u$(void 0,u)},lp.prototype.computePrefix_0=function(t){var e;switch(this.spec_0.symbol){case"$":e=kp().CURRENCY_0;break;case"#":e=Oe("boxX",this.spec_0.type)>-1?"0"+this.spec_0.type.toLowerCase():"";break;default:e=""}var n=e;return t.copy_rm1j3u$(void 0,void 0,n)},lp.prototype.computeSuffix_0=function(t){var e=kp().PERCENT_0,n=l(this.spec_0.type,"%")?e:null;return t.copy_rm1j3u$(void 0,void 0,void 0,null!=n?n:"")},lp.prototype.computePadding_0=function(t){var e=t.sign.length+t.prefix.length+t.body.fullLength+t.suffix.length|0,n=e",null!=(s=null!=(a=m.groups.get_za3lpa$(3))?a.value:null)?s:"-",null!=(u=null!=(l=m.groups.get_za3lpa$(4))?l.value:null)?u:"",null!=m.groups.get_za3lpa$(5),L(null!=(p=null!=(c=m.groups.get_za3lpa$(6))?c.value:null)?p:"-1"),null!=m.groups.get_za3lpa$(7),L(null!=(_=null!=(h=m.groups.get_za3lpa$(8))?h.value:null)?_:"6"),null!=(d=null!=(f=m.groups.get_za3lpa$(9))?f.value:null)?d:"")},$p.prototype.group_0=function(t){var n,i,r=Pe(jt(Ne(Se(Ae(e.isCharSequence(n=t)?n:E()).toString()),3),vp),this.COMMA_0);return Ae(e.isCharSequence(i=r)?i:E()).toString()},$p.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var gp,bp,wp,xp=null;function kp(){return null===xp&&new $p,xp}function Ep(t,e){return e=e||Object.create(lp.prototype),lp.call(e,kp().create_61zpoe$(t)),e}function Cp(t){Kp.call(this),this.myParent_2riath$_0=t,this.addListener_n5no9j$(new Op)}function Sp(t,e){this.closure$item=t,this.this$ChildList=e}function Tp(t,e){this.this$ChildList=t,this.closure$index=e}function Op(){jp.call(this)}function Np(){}function Pp(){}function Ap(){this.myParent_eaa9sw$_0=new gh,this.myPositionData_2io8uh$_0=null}function jp(){}function Lp(t,e,n,i){if(this.oldItem=t,this.newItem=e,this.index=n,this.type=i,zp()===this.type&&null!=this.oldItem||Mp()===this.type&&null!=this.newItem)throw et()}function Rp(t,e){C.call(this),this.name$=t,this.ordinal$=e}function Ip(){Ip=function(){},gp=new Rp("ADD",0),bp=new Rp("SET",1),wp=new Rp("REMOVE",2)}function zp(){return Ip(),gp}function Dp(){return Ip(),bp}function Mp(){return Ip(),wp}function Bp(){}function Up(){}function Fp(){Le.call(this),this.myListeners_ky8jhb$_0=null}function qp(t){this.closure$event=t}function Gp(t){this.closure$event=t}function Hp(t){this.closure$event=t}function Yp(t){this.this$AbstractObservableList=t,fh.call(this)}function Vp(t){this.closure$handler=t}function Kp(){Fp.call(this),this.myContainer_2lyzpq$_0=null}function Wp(){}function Xp(){this.myHandlers_0=null,this.myEventSources_0=u(),this.myRegistrations_0=u()}function Zp(t){this.this$CompositeEventSource=t,fh.call(this)}function Jp(t){this.this$CompositeEventSource=t}function Qp(t){this.closure$event=t}function th(t,e){var n;for(e=e||Object.create(Xp.prototype),Xp.call(e),n=0;n!==t.length;++n){var i=t[n];e.add_5zt0a2$(i)}return e}function eh(t,e){var n;for(e=e||Object.create(Xp.prototype),Xp.call(e),n=t.iterator();n.hasNext();){var i=n.next();e.add_5zt0a2$(i)}return e}function nh(){}function ih(){}function rh(){ph=this}function oh(t){this.closure$events=t}function ah(t,e){this.closure$source=t,this.closure$pred=e}function sh(t,e){this.closure$pred=t,this.closure$handler=e}function lh(t,e){this.closure$list=t,this.closure$selector=e}function uh(t,e,n){this.closure$itemRegs=t,this.closure$selector=e,this.closure$handler=n,jp.call(this)}function ch(t,e){this.closure$itemRegs=t,this.closure$listReg=e,Dh.call(this)}lp.$metadata$={kind:$,simpleName:"NumberFormat",interfaces:[]},Cp.prototype.checkAdd_wxm5ur$=function(t,e){if(Kp.prototype.checkAdd_wxm5ur$.call(this,t,e),null!=e.parentProperty().get())throw O()},Object.defineProperty(Tp.prototype,"role",{configurable:!0,get:function(){return this.this$ChildList}}),Tp.prototype.get=function(){return this.this$ChildList.size<=this.closure$index?null:this.this$ChildList.get_za3lpa$(this.closure$index)},Tp.$metadata$={kind:$,interfaces:[Np]},Sp.prototype.get=function(){var t=this.this$ChildList.indexOf_11rb$(this.closure$item);return new Tp(this.this$ChildList,t)},Sp.prototype.remove=function(){this.this$ChildList.remove_11rb$(this.closure$item)},Sp.$metadata$={kind:$,interfaces:[Pp]},Cp.prototype.beforeItemAdded_wxm5ur$=function(t,e){e.parentProperty().set_11rb$(this.myParent_2riath$_0),e.setPositionData_uvvaqs$(new Sp(e,this))},Cp.prototype.checkSet_hu11d4$=function(t,e,n){Kp.prototype.checkSet_hu11d4$.call(this,t,e,n),this.checkRemove_wxm5ur$(t,e),this.checkAdd_wxm5ur$(t,n)},Cp.prototype.beforeItemSet_hu11d4$=function(t,e,n){this.beforeItemAdded_wxm5ur$(t,n)},Cp.prototype.checkRemove_wxm5ur$=function(t,e){if(Kp.prototype.checkRemove_wxm5ur$.call(this,t,e),e.parentProperty().get()!==this.myParent_2riath$_0)throw O()},Op.prototype.onItemAdded_u8tacu$=function(t){N(t.newItem).parentProperty().flush()},Op.prototype.onItemRemoved_u8tacu$=function(t){var e=t.oldItem;N(e).parentProperty().set_11rb$(null),e.setPositionData_uvvaqs$(null),e.parentProperty().flush()},Op.$metadata$={kind:$,interfaces:[jp]},Cp.$metadata$={kind:$,simpleName:"ChildList",interfaces:[Kp]},Np.$metadata$={kind:H,simpleName:"Position",interfaces:[]},Pp.$metadata$={kind:H,simpleName:"PositionData",interfaces:[]},Object.defineProperty(Ap.prototype,"position",{configurable:!0,get:function(){if(null==this.myPositionData_2io8uh$_0)throw et();return N(this.myPositionData_2io8uh$_0).get()}}),Ap.prototype.removeFromParent=function(){null!=this.myPositionData_2io8uh$_0&&N(this.myPositionData_2io8uh$_0).remove()},Ap.prototype.parentProperty=function(){return this.myParent_eaa9sw$_0},Ap.prototype.setPositionData_uvvaqs$=function(t){this.myPositionData_2io8uh$_0=t},Ap.$metadata$={kind:$,simpleName:"SimpleComposite",interfaces:[]},jp.prototype.onItemAdded_u8tacu$=function(t){},jp.prototype.onItemSet_u8tacu$=function(t){this.onItemRemoved_u8tacu$(new Lp(t.oldItem,null,t.index,Mp())),this.onItemAdded_u8tacu$(new Lp(null,t.newItem,t.index,zp()))},jp.prototype.onItemRemoved_u8tacu$=function(t){},jp.$metadata$={kind:$,simpleName:"CollectionAdapter",interfaces:[Bp]},Lp.prototype.dispatch_11rb$=function(t){zp()===this.type?t.onItemAdded_u8tacu$(this):Dp()===this.type?t.onItemSet_u8tacu$(this):t.onItemRemoved_u8tacu$(this)},Lp.prototype.toString=function(){return zp()===this.type?I(this.newItem)+" added at "+I(this.index):Dp()===this.type?I(this.oldItem)+" replaced with "+I(this.newItem)+" at "+I(this.index):I(this.oldItem)+" removed at "+I(this.index)},Lp.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Lp)||E(),!!l(this.oldItem,t.oldItem)&&!!l(this.newItem,t.newItem)&&this.index===t.index&&this.type===t.type)},Lp.prototype.hashCode=function(){var t,e,n,i,r=null!=(e=null!=(t=this.oldItem)?P(t):null)?e:0;return(31*(r=(31*(r=(31*r|0)+(null!=(i=null!=(n=this.newItem)?P(n):null)?i:0)|0)|0)+this.index|0)|0)+this.type.hashCode()|0},Rp.$metadata$={kind:$,simpleName:"EventType",interfaces:[C]},Rp.values=function(){return[zp(),Dp(),Mp()]},Rp.valueOf_61zpoe$=function(t){switch(t){case"ADD":return zp();case"SET":return Dp();case"REMOVE":return Mp();default:S("No enum constant jetbrains.datalore.base.observable.collections.CollectionItemEvent.EventType."+t)}},Lp.$metadata$={kind:$,simpleName:"CollectionItemEvent",interfaces:[_h]},Bp.$metadata$={kind:H,simpleName:"CollectionListener",interfaces:[]},Up.$metadata$={kind:H,simpleName:"ObservableCollection",interfaces:[ih,je]},Fp.prototype.checkAdd_wxm5ur$=function(t,e){if(t<0||t>this.size)throw new _t("Add: index="+t+", size="+this.size)},Fp.prototype.checkSet_hu11d4$=function(t,e,n){if(t<0||t>=this.size)throw new _t("Set: index="+t+", size="+this.size)},Fp.prototype.checkRemove_wxm5ur$=function(t,e){if(t<0||t>=this.size)throw new _t("Remove: index="+t+", size="+this.size)},qp.prototype.call_11rb$=function(t){t.onItemAdded_u8tacu$(this.closure$event)},qp.$metadata$={kind:$,interfaces:[hh]},Fp.prototype.add_wxm5ur$=function(t,e){this.checkAdd_wxm5ur$(t,e),this.beforeItemAdded_wxm5ur$(t,e);var n=!1;try{if(this.doAdd_wxm5ur$(t,e),n=!0,this.onItemAdd_wxm5ur$(t,e),null!=this.myListeners_ky8jhb$_0){var i=new Lp(null,e,t,zp());N(this.myListeners_ky8jhb$_0).fire_kucmxw$(new qp(i))}}finally{this.afterItemAdded_5x52oa$(t,e,n)}},Fp.prototype.beforeItemAdded_wxm5ur$=function(t,e){},Fp.prototype.onItemAdd_wxm5ur$=function(t,e){},Fp.prototype.afterItemAdded_5x52oa$=function(t,e,n){},Gp.prototype.call_11rb$=function(t){t.onItemSet_u8tacu$(this.closure$event)},Gp.$metadata$={kind:$,interfaces:[hh]},Fp.prototype.set_wxm5ur$=function(t,e){var n=this.get_za3lpa$(t);this.checkSet_hu11d4$(t,n,e),this.beforeItemSet_hu11d4$(t,n,e);var i=!1;try{if(this.doSet_wxm5ur$(t,e),i=!0,this.onItemSet_hu11d4$(t,n,e),null!=this.myListeners_ky8jhb$_0){var r=new Lp(n,e,t,Dp());N(this.myListeners_ky8jhb$_0).fire_kucmxw$(new Gp(r))}}finally{this.afterItemSet_yk9x8x$(t,n,e,i)}return n},Fp.prototype.doSet_wxm5ur$=function(t,e){this.doRemove_za3lpa$(t),this.doAdd_wxm5ur$(t,e)},Fp.prototype.beforeItemSet_hu11d4$=function(t,e,n){},Fp.prototype.onItemSet_hu11d4$=function(t,e,n){},Fp.prototype.afterItemSet_yk9x8x$=function(t,e,n,i){},Hp.prototype.call_11rb$=function(t){t.onItemRemoved_u8tacu$(this.closure$event)},Hp.$metadata$={kind:$,interfaces:[hh]},Fp.prototype.removeAt_za3lpa$=function(t){var e=this.get_za3lpa$(t);this.checkRemove_wxm5ur$(t,e),this.beforeItemRemoved_wxm5ur$(t,e);var n=!1;try{if(this.doRemove_za3lpa$(t),n=!0,this.onItemRemove_wxm5ur$(t,e),null!=this.myListeners_ky8jhb$_0){var i=new Lp(e,null,t,Mp());N(this.myListeners_ky8jhb$_0).fire_kucmxw$(new Hp(i))}}finally{this.afterItemRemoved_5x52oa$(t,e,n)}return e},Fp.prototype.beforeItemRemoved_wxm5ur$=function(t,e){},Fp.prototype.onItemRemove_wxm5ur$=function(t,e){},Fp.prototype.afterItemRemoved_5x52oa$=function(t,e,n){},Yp.prototype.beforeFirstAdded=function(){this.this$AbstractObservableList.onListenersAdded()},Yp.prototype.afterLastRemoved=function(){this.this$AbstractObservableList.myListeners_ky8jhb$_0=null,this.this$AbstractObservableList.onListenersRemoved()},Yp.$metadata$={kind:$,interfaces:[fh]},Fp.prototype.addListener_n5no9j$=function(t){return null==this.myListeners_ky8jhb$_0&&(this.myListeners_ky8jhb$_0=new Yp(this)),N(this.myListeners_ky8jhb$_0).add_11rb$(t)},Vp.prototype.onItemAdded_u8tacu$=function(t){this.closure$handler.onEvent_11rb$(t)},Vp.prototype.onItemSet_u8tacu$=function(t){this.closure$handler.onEvent_11rb$(t)},Vp.prototype.onItemRemoved_u8tacu$=function(t){this.closure$handler.onEvent_11rb$(t)},Vp.$metadata$={kind:$,interfaces:[Bp]},Fp.prototype.addHandler_gxwwpc$=function(t){var e=new Vp(t);return this.addListener_n5no9j$(e)},Fp.prototype.onListenersAdded=function(){},Fp.prototype.onListenersRemoved=function(){},Fp.$metadata$={kind:$,simpleName:"AbstractObservableList",interfaces:[Wp,Le]},Object.defineProperty(Kp.prototype,"size",{configurable:!0,get:function(){return null==this.myContainer_2lyzpq$_0?0:N(this.myContainer_2lyzpq$_0).size}}),Kp.prototype.get_za3lpa$=function(t){if(null==this.myContainer_2lyzpq$_0)throw new _t(t.toString());return N(this.myContainer_2lyzpq$_0).get_za3lpa$(t)},Kp.prototype.doAdd_wxm5ur$=function(t,e){this.ensureContainerInitialized_mjxwec$_0(),N(this.myContainer_2lyzpq$_0).add_wxm5ur$(t,e)},Kp.prototype.doSet_wxm5ur$=function(t,e){N(this.myContainer_2lyzpq$_0).set_wxm5ur$(t,e)},Kp.prototype.doRemove_za3lpa$=function(t){N(this.myContainer_2lyzpq$_0).removeAt_za3lpa$(t),N(this.myContainer_2lyzpq$_0).isEmpty()&&(this.myContainer_2lyzpq$_0=null)},Kp.prototype.ensureContainerInitialized_mjxwec$_0=function(){null==this.myContainer_2lyzpq$_0&&(this.myContainer_2lyzpq$_0=h(1))},Kp.$metadata$={kind:$,simpleName:"ObservableArrayList",interfaces:[Fp]},Wp.$metadata$={kind:H,simpleName:"ObservableList",interfaces:[Up,Re]},Xp.prototype.add_5zt0a2$=function(t){this.myEventSources_0.add_11rb$(t)},Xp.prototype.remove_r5wlyb$=function(t){var n,i=this.myEventSources_0;(e.isType(n=i,je)?n:E()).remove_11rb$(t)},Zp.prototype.beforeFirstAdded=function(){var t;for(t=this.this$CompositeEventSource.myEventSources_0.iterator();t.hasNext();){var e=t.next();this.this$CompositeEventSource.addHandlerTo_0(e)}},Zp.prototype.afterLastRemoved=function(){var t;for(t=this.this$CompositeEventSource.myRegistrations_0.iterator();t.hasNext();)t.next().remove();this.this$CompositeEventSource.myRegistrations_0.clear(),this.this$CompositeEventSource.myHandlers_0=null},Zp.$metadata$={kind:$,interfaces:[fh]},Xp.prototype.addHandler_gxwwpc$=function(t){return null==this.myHandlers_0&&(this.myHandlers_0=new Zp(this)),N(this.myHandlers_0).add_11rb$(t)},Qp.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},Qp.$metadata$={kind:$,interfaces:[hh]},Jp.prototype.onEvent_11rb$=function(t){N(this.this$CompositeEventSource.myHandlers_0).fire_kucmxw$(new Qp(t))},Jp.$metadata$={kind:$,interfaces:[nh]},Xp.prototype.addHandlerTo_0=function(t){this.myRegistrations_0.add_11rb$(t.addHandler_gxwwpc$(new Jp(this)))},Xp.$metadata$={kind:$,simpleName:"CompositeEventSource",interfaces:[ih]},nh.$metadata$={kind:H,simpleName:"EventHandler",interfaces:[]},ih.$metadata$={kind:H,simpleName:"EventSource",interfaces:[]},oh.prototype.addHandler_gxwwpc$=function(t){var e,n;for(e=this.closure$events,n=0;n!==e.length;++n){var i=e[n];t.onEvent_11rb$(i)}return Gh().EMPTY},oh.$metadata$={kind:$,interfaces:[ih]},rh.prototype.of_i5x0yv$=function(t){return new oh(t)},rh.prototype.empty_287e2$=function(){return this.composite_xw2ruy$([])},rh.prototype.composite_xw2ruy$=function(t){return th(t.slice())},rh.prototype.composite_3qo2qg$=function(t){return eh(t)},sh.prototype.onEvent_11rb$=function(t){this.closure$pred(t)&&this.closure$handler.onEvent_11rb$(t)},sh.$metadata$={kind:$,interfaces:[nh]},ah.prototype.addHandler_gxwwpc$=function(t){return this.closure$source.addHandler_gxwwpc$(new sh(this.closure$pred,t))},ah.$metadata$={kind:$,interfaces:[ih]},rh.prototype.filter_ff3xdm$=function(t,e){return new ah(t,e)},rh.prototype.map_9hq6p$=function(t,e){return new yh(t,e)},uh.prototype.onItemAdded_u8tacu$=function(t){this.closure$itemRegs.add_wxm5ur$(t.index,this.closure$selector(t.newItem).addHandler_gxwwpc$(this.closure$handler))},uh.prototype.onItemRemoved_u8tacu$=function(t){this.closure$itemRegs.removeAt_za3lpa$(t.index).remove()},uh.$metadata$={kind:$,interfaces:[jp]},ch.prototype.doRemove=function(){var t;for(t=this.closure$itemRegs.iterator();t.hasNext();)t.next().remove();this.closure$listReg.remove()},ch.$metadata$={kind:$,interfaces:[Dh]},lh.prototype.addHandler_gxwwpc$=function(t){var e,n=u();for(e=this.closure$list.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.closure$selector(i).addHandler_gxwwpc$(t))}return new ch(n,this.closure$list.addListener_n5no9j$(new uh(n,this.closure$selector,t)))},lh.$metadata$={kind:$,interfaces:[ih]},rh.prototype.selectList_jnjwvc$=function(t,e){return new lh(t,e)},rh.$metadata$={kind:y,simpleName:"EventSources",interfaces:[]};var ph=null;function hh(){}function _h(){}function fh(){this.myListeners_30lqoe$_0=null,this.myFireDepth_t4vnc0$_0=0,this.myListenersCount_umrzvt$_0=0}function dh(t,e){this.this$Listeners=t,this.closure$l=e,Dh.call(this)}function mh(t,e){this.listener=t,this.add=e}function yh(t,e){this.mySourceEventSource_0=t,this.myFunction_0=e}function $h(t,e){this.closure$handler=t,this.this$MappingEventSource=e}function vh(){this.propExpr_4jt19b$_0=e.getKClassFromExpression(this).toString()}function gh(t){void 0===t&&(t=null),vh.call(this),this.myValue_0=t,this.myHandlers_0=null,this.myPendingEvent_0=null}function bh(t){this.this$DelayedValueProperty=t}function wh(t){this.this$DelayedValueProperty=t,fh.call(this)}function xh(){}function kh(){Sh=this}function Eh(t){this.closure$target=t}function Ch(t,e,n,i){this.closure$syncing=t,this.closure$target=e,this.closure$source=n,this.myForward_0=i}hh.$metadata$={kind:H,simpleName:"ListenerCaller",interfaces:[]},_h.$metadata$={kind:H,simpleName:"ListenerEvent",interfaces:[]},Object.defineProperty(fh.prototype,"isEmpty",{configurable:!0,get:function(){return null==this.myListeners_30lqoe$_0||N(this.myListeners_30lqoe$_0).isEmpty()}}),dh.prototype.doRemove=function(){var t,n;this.this$Listeners.myFireDepth_t4vnc0$_0>0?N(this.this$Listeners.myListeners_30lqoe$_0).add_11rb$(new mh(this.closure$l,!1)):(N(this.this$Listeners.myListeners_30lqoe$_0).remove_11rb$(e.isType(t=this.closure$l,re)?t:E()),n=this.this$Listeners.myListenersCount_umrzvt$_0,this.this$Listeners.myListenersCount_umrzvt$_0=n-1|0),this.this$Listeners.isEmpty&&this.this$Listeners.afterLastRemoved()},dh.$metadata$={kind:$,interfaces:[Dh]},fh.prototype.add_11rb$=function(t){var n;return this.isEmpty&&this.beforeFirstAdded(),this.myFireDepth_t4vnc0$_0>0?N(this.myListeners_30lqoe$_0).add_11rb$(new mh(t,!0)):(null==this.myListeners_30lqoe$_0&&(this.myListeners_30lqoe$_0=h(1)),N(this.myListeners_30lqoe$_0).add_11rb$(e.isType(n=t,re)?n:E()),this.myListenersCount_umrzvt$_0=this.myListenersCount_umrzvt$_0+1|0),new dh(this,t)},fh.prototype.fire_kucmxw$=function(t){var n;if(!this.isEmpty){this.beforeFire_ul1jia$_0();try{for(var i=this.myListenersCount_umrzvt$_0,r=0;r "+I(this.newValue)},Th.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Th)||E(),!!l(this.oldValue,t.oldValue)&&!!l(this.newValue,t.newValue))},Th.prototype.hashCode=function(){var t,e,n,i,r=null!=(e=null!=(t=this.oldValue)?P(t):null)?e:0;return(31*r|0)+(null!=(i=null!=(n=this.newValue)?P(n):null)?i:0)|0},Th.$metadata$={kind:$,simpleName:"PropertyChangeEvent",interfaces:[]},Oh.$metadata$={kind:H,simpleName:"ReadableProperty",interfaces:[Vl,ih]},Object.defineProperty(Nh.prototype,"propExpr",{configurable:!0,get:function(){return"valueProperty()"}}),Nh.prototype.get=function(){return this.myValue_x0fqz2$_0},Nh.prototype.set_11rb$=function(t){if(!l(t,this.myValue_x0fqz2$_0)){var e=this.myValue_x0fqz2$_0;this.myValue_x0fqz2$_0=t,this.fireEvents_ym4swk$_0(e,this.myValue_x0fqz2$_0)}},Ph.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},Ph.$metadata$={kind:$,interfaces:[hh]},Nh.prototype.fireEvents_ym4swk$_0=function(t,e){if(null!=this.myHandlers_sdxgfs$_0){var n=new Th(t,e);N(this.myHandlers_sdxgfs$_0).fire_kucmxw$(new Ph(n))}},Ah.prototype.afterLastRemoved=function(){this.this$ValueProperty.myHandlers_sdxgfs$_0=null},Ah.$metadata$={kind:$,interfaces:[fh]},Nh.prototype.addHandler_gxwwpc$=function(t){return null==this.myHandlers_sdxgfs$_0&&(this.myHandlers_sdxgfs$_0=new Ah(this)),N(this.myHandlers_sdxgfs$_0).add_11rb$(t)},Nh.$metadata$={kind:$,simpleName:"ValueProperty",interfaces:[xh,vh]},jh.$metadata$={kind:H,simpleName:"WritableProperty",interfaces:[]},Lh.prototype.randomString_za3lpa$=function(t){for(var e=ze(yt(new Gt(97,122),new Gt(65,90)),new Gt(48,57)),n=h(t),i=0;i=0;t--)this.myRegistrations_0.get_za3lpa$(t).remove();this.myRegistrations_0.clear()},Ih.$metadata$={kind:$,simpleName:"CompositeRegistration",interfaces:[Dh]},zh.$metadata$={kind:H,simpleName:"Disposable",interfaces:[]},Dh.prototype.remove=function(){if(this.myRemoved_guv51v$_0)throw _("Registration already removed");this.myRemoved_guv51v$_0=!0,this.doRemove()},Dh.prototype.dispose=function(){this.remove()},Mh.prototype.doRemove=function(){},Mh.prototype.remove=function(){},Mh.$metadata$={kind:$,simpleName:"EmptyRegistration",interfaces:[Dh]},Uh.prototype.doRemove=function(){this.closure$disposable.dispose()},Uh.$metadata$={kind:$,interfaces:[Dh]},Bh.prototype.from_gg3y3y$=function(t){return new Uh(t)},Fh.prototype.doRemove=function(){var t,e;for(t=this.closure$disposables,e=0;e!==t.length;++e)t[e].dispose()},Fh.$metadata$={kind:$,interfaces:[Dh]},Bh.prototype.from_h9hjd7$=function(t){return new Fh(t)},Bh.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var qh=null;function Gh(){return null===qh&&new Bh,qh}function Hh(){}function Yh(){Qh=this,this.instance=new Hh}Dh.$metadata$={kind:$,simpleName:"Registration",interfaces:[zh]},Hh.prototype.handle_tcv7n7$=function(t){throw t},Hh.$metadata$={kind:$,simpleName:"ThrowableHandler",interfaces:[]},Yh.$metadata$={kind:y,simpleName:"ThrowableHandlers",interfaces:[]};var Vh,Kh,Wh,Xh,Zh,Jh,Qh=null;function t_(){return null===Qh&&new Yh,Qh}var e_=Q((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function n_(t){return t.first}function i_(t){return t.second}function r_(t,e,n){l_(),this.myMapRect_0=t,this.myLoopX_0=e,this.myLoopY_0=n}function o_(){s_=this}function a_(t,e){return new Ql(f.min(t,e),f.max(t,e))}r_.prototype.calculateBoundingBox_qpfwx8$=function(t,e){var n=this.calculateBoundingRange_0(t,Zf(this.myMapRect_0),this.myLoopX_0),i=this.calculateBoundingRange_0(e,Jf(this.myMapRect_0),this.myLoopY_0);return fd(n.lowerEnd,i.lowerEnd,l_().length_0(n),l_().length_0(i))},r_.prototype.calculateBoundingRange_0=function(t,e,n){return n?l_().calculateLoopLimitRange_h7l5yb$(t,e):new Ql(N(Ue(jt(t,c("start",1,(function(t){return n_(t)}))))),N(Fe(jt(t,c("end",1,(function(t){return i_(t)}))))))},o_.prototype.calculateLoopLimitRange_h7l5yb$=function(t,e){return this.normalizeCenter_0(this.invertRange_0(this.findMaxGapBetweenRanges_0(qe(jt(t,(n=e,function(t){return k_().splitSegment_6y0v78$(n_(t),i_(t),n.lowerEnd,n.upperEnd)}))),this.length_0(e)),this.length_0(e)),e);var n},o_.prototype.normalizeCenter_0=function(t,e){return e.contains_mef7kx$((t.upperEnd+t.lowerEnd)/2)?t:new Ql(t.lowerEnd-this.length_0(e),t.upperEnd-this.length_0(e))},o_.prototype.findMaxGapBetweenRanges_0=function(t,n){var i,r=Ye(t,new wt(e_(c("lowerEnd",1,(function(t){return t.lowerEnd}))))),o=c("upperEnd",1,(function(t){return t.upperEnd}));t:do{var a=r.iterator();if(!a.hasNext()){i=null;break t}var s=a.next();if(!a.hasNext()){i=s;break t}var l=o(s);do{var u=a.next(),p=o(u);e.compareTo(l,p)<0&&(s=u,l=p)}while(a.hasNext());i=s}while(0);var h=N(i).upperEnd,_=Ge(r).lowerEnd,d=n+_,m=h,y=new Ql(h,f.max(d,m)),$=r.iterator();for(h=$.next().upperEnd;$.hasNext();){var v=$.next();(_=v.lowerEnd)>h&&_-h>this.length_0(y)&&(y=new Ql(h,_));var g=h,b=v.upperEnd;h=f.max(g,b)}return y},o_.prototype.invertRange_0=function(t,e){var n=a_;return this.length_0(t)>e?new Ql(t.lowerEnd,t.lowerEnd):t.upperEnd>e?n(t.upperEnd-e,t.lowerEnd):n(t.upperEnd,e+t.lowerEnd)},o_.prototype.length_0=function(t){return t.upperEnd-t.lowerEnd},o_.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var s_=null;function l_(){return null===s_&&new o_,s_}function u_(t,e,n){return jt(Mt(b(0,n)),(i=t,r=e,function(t){return new He(i(t),r(t))}));var i,r}function c_(){m_=this,this.LON_INDEX_0=0,this.LAT_INDEX_0=1}function p_(){}function h_(t){return l(t.getString_61zpoe$("type"),"Feature")}function __(t){return t.getObject_61zpoe$("geometry")}r_.$metadata$={kind:$,simpleName:"GeoBoundingBoxCalculator",interfaces:[]},c_.prototype.parse_gdwatq$=function(t,e){var n=Gu(vc().parseJson_61zpoe$(t)),i=new G_;e(i);var r=i;(new p_).parse_m8ausf$(n,r)},c_.prototype.parse_4mzk4t$=function(t,e){var n=Gu(vc().parseJson_61zpoe$(t));(new p_).parse_m8ausf$(n,e)},p_.prototype.parse_m8ausf$=function(t,e){var n=t.getString_61zpoe$("type");switch(n){case"FeatureCollection":var i;if(!t.contains_61zpoe$("features"))throw v("GeoJson: Missing 'features' in 'FeatureCollection'".toString());for(i=jt(Ve(t.getArray_61zpoe$("features").fluentObjectStream(),h_),__).iterator();i.hasNext();){var r=i.next();this.parse_m8ausf$(r,e)}break;case"GeometryCollection":var o;if(!t.contains_61zpoe$("geometries"))throw v("GeoJson: Missing 'geometries' in 'GeometryCollection'".toString());for(o=t.getArray_61zpoe$("geometries").fluentObjectStream().iterator();o.hasNext();){var a=o.next();this.parse_m8ausf$(a,e)}break;default:if(!t.contains_61zpoe$("coordinates"))throw v(("GeoJson: Missing 'coordinates' in "+n).toString());var s=t.getArray_61zpoe$("coordinates");switch(n){case"Point":var l=this.parsePoint_0(s);At("onPoint",function(t,e){return t.onPoint_adb7pk$(e),Pt}.bind(null,e))(l);break;case"LineString":var u=this.parseLineString_0(s);At("onLineString",function(t,e){return t.onLineString_1u6eph$(e),Pt}.bind(null,e))(u);break;case"Polygon":var c=this.parsePolygon_0(s);At("onPolygon",function(t,e){return t.onPolygon_z3kb82$(e),Pt}.bind(null,e))(c);break;case"MultiPoint":var p=this.parseMultiPoint_0(s);At("onMultiPoint",function(t,e){return t.onMultiPoint_oeq1z7$(e),Pt}.bind(null,e))(p);break;case"MultiLineString":var h=this.parseMultiLineString_0(s);At("onMultiLineString",function(t,e){return t.onMultiLineString_6n275e$(e),Pt}.bind(null,e))(h);break;case"MultiPolygon":var f=this.parseMultiPolygon_0(s);At("onMultiPolygon",function(t,e){return t.onMultiPolygon_a0zxnd$(e),Pt}.bind(null,e))(f);break;default:throw _(("Not support GeoJson type: "+n).toString())}}},p_.prototype.parsePoint_0=function(t){return $d(t.getDouble_za3lpa$(0),t.getDouble_za3lpa$(1))},p_.prototype.parseLineString_0=function(t){return new ld(this.mapArray_0(t,At("parsePoint",function(t,e){return t.parsePoint_0(e)}.bind(null,this))))},p_.prototype.parseRing_0=function(t){return new dd(this.mapArray_0(t,At("parsePoint",function(t,e){return t.parsePoint_0(e)}.bind(null,this))))},p_.prototype.parseMultiPoint_0=function(t){return new cd(this.mapArray_0(t,At("parsePoint",function(t,e){return t.parsePoint_0(e)}.bind(null,this))))},p_.prototype.parsePolygon_0=function(t){return new hd(this.mapArray_0(t,At("parseRing",function(t,e){return t.parseRing_0(e)}.bind(null,this))))},p_.prototype.parseMultiLineString_0=function(t){return new ud(this.mapArray_0(t,At("parseLineString",function(t,e){return t.parseLineString_0(e)}.bind(null,this))))},p_.prototype.parseMultiPolygon_0=function(t){return new pd(this.mapArray_0(t,At("parsePolygon",function(t,e){return t.parsePolygon_0(e)}.bind(null,this))))},p_.prototype.mapArray_0=function(t,n){return Ke(jt(t.stream(),(i=n,function(t){var n;return i(Fu(e.isType(n=t,$t)?n:E()))})));var i},p_.$metadata$={kind:$,simpleName:"Parser",interfaces:[]},c_.$metadata$={kind:y,simpleName:"GeoJson",interfaces:[]};var f_,d_,m_=null;function y_(t,e,n,i){if(this.myLongitudeSegment_0=null,this.myLatitudeRange_0=null,!(e<=i))throw v(("Invalid latitude range: ["+e+".."+i+"]").toString());this.myLongitudeSegment_0=new b_(t,n),this.myLatitudeRange_0=new Ql(e,i)}function $_(t){var e=Kh,n=Wh,i=f.min(t,n);return f.max(e,i)}function v_(t){var e=Zh,n=Jh,i=f.min(t,n);return f.max(e,i)}function g_(t){var e=t-Lt(t/Xh)*Xh;return e>Wh&&(e-=Xh),e<-Wh&&(e+=Xh),e}function b_(t,e){k_(),this.myStart_0=$_(t),this.myEnd_0=$_(e)}function w_(){x_=this}Object.defineProperty(y_.prototype,"isEmpty",{configurable:!0,get:function(){return this.myLongitudeSegment_0.isEmpty&&this.latitudeRangeIsEmpty_0(this.myLatitudeRange_0)}}),y_.prototype.latitudeRangeIsEmpty_0=function(t){return t.upperEnd===t.lowerEnd},y_.prototype.startLongitude=function(){return this.myLongitudeSegment_0.start()},y_.prototype.endLongitude=function(){return this.myLongitudeSegment_0.end()},y_.prototype.minLatitude=function(){return this.myLatitudeRange_0.lowerEnd},y_.prototype.maxLatitude=function(){return this.myLatitudeRange_0.upperEnd},y_.prototype.encloses_emtjl$=function(t){return this.myLongitudeSegment_0.encloses_moa7dh$(t.myLongitudeSegment_0)&&this.myLatitudeRange_0.encloses_d226ot$(t.myLatitudeRange_0)},y_.prototype.splitByAntiMeridian=function(){var t,e=u();for(t=this.myLongitudeSegment_0.splitByAntiMeridian().iterator();t.hasNext();){var n=t.next();e.add_11rb$(Wf(new yd(n.lowerEnd,this.myLatitudeRange_0.lowerEnd),new yd(n.upperEnd,this.myLatitudeRange_0.upperEnd)))}return e},y_.prototype.equals=function(t){var n,i,r,o;if(this===t)return!0;if(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))return!1;var a=null==(i=t)||e.isType(i,y_)?i:E();return(null!=(r=this.myLongitudeSegment_0)?r.equals(N(a).myLongitudeSegment_0):null)&&(null!=(o=this.myLatitudeRange_0)?o.equals(a.myLatitudeRange_0):null)},y_.prototype.hashCode=function(){return P(st([this.myLongitudeSegment_0,this.myLatitudeRange_0]))},y_.$metadata$={kind:$,simpleName:"GeoRectangle",interfaces:[]},Object.defineProperty(b_.prototype,"isEmpty",{configurable:!0,get:function(){return this.myEnd_0===this.myStart_0}}),b_.prototype.start=function(){return this.myStart_0},b_.prototype.end=function(){return this.myEnd_0},b_.prototype.length=function(){return this.myEnd_0-this.myStart_0+(this.myEnd_0=1;o--){var a=48,s=1<0?r(t):null})));break;default:i=e.noWhenBranchMatched()}this.myNumberFormatters_0=i,this.argsNumber=this.myNumberFormatters_0.size}function pf(t,e){C.call(this),this.name$=t,this.ordinal$=e}function hf(){hf=function(){},sf=new pf("NUMBER_FORMAT",0),lf=new pf("STRING_FORMAT",1)}function _f(){return hf(),sf}function ff(){return hf(),lf}function df(){vf=this,this.BRACES_REGEX_0=T("(?![^{]|\\{\\{)(\\{([^{}]*)\\})(?=[^}]|\\}\\}|$)"),this.TEXT_IN_BRACES=2}pf.$metadata$={kind:$,simpleName:"FormatType",interfaces:[C]},pf.values=function(){return[_f(),ff()]},pf.valueOf_61zpoe$=function(t){switch(t){case"NUMBER_FORMAT":return _f();case"STRING_FORMAT":return ff();default:S("No enum constant jetbrains.datalore.base.stringFormat.StringFormat.FormatType."+t)}},cf.prototype.format_za3rmp$=function(t){return this.format_pqjuzw$(We(t))},cf.prototype.format_pqjuzw$=function(t){var n;if(this.argsNumber!==t.size)throw _(("Can't format values "+t+' with pattern "'+this.pattern_0+'"). Wrong number of arguments: expected '+this.argsNumber+" instead of "+t.size).toString());t:switch(this.formatType.name){case"NUMBER_FORMAT":if(1!==this.myNumberFormatters_0.size)throw v("Failed requirement.".toString());n=this.formatValue_0(Xe(t),Xe(this.myNumberFormatters_0));break t;case"STRING_FORMAT":var i,r={v:0},o=gf().BRACES_REGEX_0,a=this.pattern_0;e:do{var s=o.find_905azu$(a);if(null==s){i=a.toString();break e}var l=0,u=a.length,c=Je(u);do{var p=N(s);c.append_ezbsdh$(a,l,p.range.start);var h,f=c.append_gw00v9$,d=t.get_za3lpa$(r.v),m=this.myNumberFormatters_0.get_za3lpa$((h=r.v,r.v=h+1|0,h));f.call(c,this.formatValue_0(d,m)),l=p.range.endInclusive+1|0,s=p.next()}while(l0&&r.argsNumber!==i){var o,a="Wrong number of arguments in pattern '"+t+"' "+(null!=(o=null!=n?"to format '"+I(n)+"'":null)?o:"")+". Expected "+i+" "+(i>1?"arguments":"argument")+" instead of "+r.argsNumber;throw v(a.toString())}return r},df.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var mf,yf,$f,vf=null;function gf(){return null===vf&&new df,vf}function bf(t){try{return Ep(t)}catch(n){throw e.isType(n,Kt)?_(("Wrong number pattern: "+t).toString()):n}}function wf(t){return t.groupValues.get_za3lpa$(2)}function xf(t){tn.call(this),this.myGeometry_8dt6c9$_0=t}function kf(t){return mn(t,c("x",1,(function(t){return t.x})),c("y",1,(function(t){return t.y})))}function Ef(t,e,n,i){return Wf(new yd(t,e),new yd(n,i))}function Cf(t){return Tu().calculateBoundingBox_h5l7ap$(t,c("x",1,(function(t){return t.x})),c("y",1,(function(t){return t.y})),Ef)}function Sf(t){return t.origin.y+t.dimension.y}function Tf(t){return t.origin.x+t.dimension.x}function Of(t){return t.dimension.y}function Nf(t){return t.dimension.x}function Pf(t){return t.origin.y}function Af(t){return t.origin.x}function jf(t){return new md(Sf(t))}function Lf(t){return new md(Of(t))}function Rf(t){return new md(Nf(t))}function If(t){return new md(Pf(t))}function zf(t){return new md(Af(t))}function Df(t){return new md(t.x)}function Mf(t){return new md(t.y)}function Bf(t,e){return new yd(t.x+e.x,t.y+e.y)}function Uf(t,e){return new yd(t.x-e.x,t.y-e.y)}function Ff(t,e){return new yd(t.x/e,t.y/e)}function qf(t){return t}function Gf(t){return t}function Hf(t,e,n){return void 0===e&&(e=qf),void 0===n&&(n=Gf),new yd(e(Df(t)).value,n(Mf(t)).value)}function Yf(t,e){return new md(t.value+e.value)}function Vf(t,e){return new md(t.value-e.value)}function Kf(t,e){return new md(t.value/e)}function Wf(t,e){return new _d(t,Uf(e,t))}function Xf(t){return Cf(en(qe(Mt(t))))}function Zf(t){return new Ql(t.origin.x,t.origin.x+t.dimension.x)}function Jf(t){return new Ql(t.origin.y,t.origin.y+t.dimension.y)}function Qf(t,e){C.call(this),this.name$=t,this.ordinal$=e}function td(){td=function(){},mf=new Qf("MULTI_POINT",0),yf=new Qf("MULTI_LINESTRING",1),$f=new Qf("MULTI_POLYGON",2)}function ed(){return td(),mf}function nd(){return td(),yf}function id(){return td(),$f}function rd(t,e,n,i){sd(),this.type=t,this.myMultiPoint_0=e,this.myMultiLineString_0=n,this.myMultiPolygon_0=i}function od(){ad=this}cf.$metadata$={kind:$,simpleName:"StringFormat",interfaces:[]},xf.prototype.get_za3lpa$=function(t){return this.myGeometry_8dt6c9$_0.get_za3lpa$(t)},Object.defineProperty(xf.prototype,"size",{configurable:!0,get:function(){return this.myGeometry_8dt6c9$_0.size}}),xf.$metadata$={kind:$,simpleName:"AbstractGeometryList",interfaces:[tn]},Qf.$metadata$={kind:$,simpleName:"GeometryType",interfaces:[C]},Qf.values=function(){return[ed(),nd(),id()]},Qf.valueOf_61zpoe$=function(t){switch(t){case"MULTI_POINT":return ed();case"MULTI_LINESTRING":return nd();case"MULTI_POLYGON":return id();default:S("No enum constant jetbrains.datalore.base.typedGeometry.GeometryType."+t)}},Object.defineProperty(rd.prototype,"multiPoint",{configurable:!0,get:function(){var t;if(null==(t=this.myMultiPoint_0))throw _((this.type.toString()+" is not a MultiPoint").toString());return t}}),Object.defineProperty(rd.prototype,"multiLineString",{configurable:!0,get:function(){var t;if(null==(t=this.myMultiLineString_0))throw _((this.type.toString()+" is not a MultiLineString").toString());return t}}),Object.defineProperty(rd.prototype,"multiPolygon",{configurable:!0,get:function(){var t;if(null==(t=this.myMultiPolygon_0))throw _((this.type.toString()+" is not a MultiPolygon").toString());return t}}),od.prototype.createMultiPoint_xgn53i$=function(t){return new rd(ed(),t,null,null)},od.prototype.createMultiLineString_bc4hlz$=function(t){return new rd(nd(),null,t,null)},od.prototype.createMultiPolygon_8ft4gs$=function(t){return new rd(id(),null,null,t)},od.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var ad=null;function sd(){return null===ad&&new od,ad}function ld(t){xf.call(this,t)}function ud(t){xf.call(this,t)}function cd(t){xf.call(this,t)}function pd(t){xf.call(this,t)}function hd(t){xf.call(this,t)}function _d(t,e){this.origin=t,this.dimension=e}function fd(t,e,n,i,r){return r=r||Object.create(_d.prototype),_d.call(r,new yd(t,e),new yd(n,i)),r}function dd(t){xf.call(this,t)}function md(t){this.value=t}function yd(t,e){this.x=t,this.y=e}function $d(t,e){return new yd(t,e)}function vd(t,e){return new yd(t.value,e.value)}function gd(){}function bd(){this.map=Ot()}function wd(t,e,n,i){if(Ed(),void 0===i&&(i=255),this.red=t,this.green=e,this.blue=n,this.alpha=i,!(0<=this.red&&this.red<=255&&0<=this.green&&this.green<=255&&0<=this.blue&&this.blue<=255&&0<=this.alpha&&this.alpha<=255))throw v(("Color components out of range: "+this).toString())}function xd(){kd=this,this.TRANSPARENT=new wd(0,0,0,0),this.WHITE=new wd(255,255,255),this.CONSOLE_WHITE=new wd(204,204,204),this.BLACK=new wd(0,0,0),this.LIGHT_GRAY=new wd(192,192,192),this.VERY_LIGHT_GRAY=new wd(210,210,210),this.GRAY=new wd(128,128,128),this.RED=new wd(255,0,0),this.LIGHT_GREEN=new wd(210,255,210),this.GREEN=new wd(0,255,0),this.DARK_GREEN=new wd(0,128,0),this.BLUE=new wd(0,0,255),this.DARK_BLUE=new wd(0,0,128),this.LIGHT_BLUE=new wd(210,210,255),this.YELLOW=new wd(255,255,0),this.CONSOLE_YELLOW=new wd(174,174,36),this.LIGHT_YELLOW=new wd(255,255,128),this.VERY_LIGHT_YELLOW=new wd(255,255,210),this.MAGENTA=new wd(255,0,255),this.LIGHT_MAGENTA=new wd(255,210,255),this.DARK_MAGENTA=new wd(128,0,128),this.CYAN=new wd(0,255,255),this.LIGHT_CYAN=new wd(210,255,255),this.ORANGE=new wd(255,192,0),this.PINK=new wd(255,175,175),this.LIGHT_PINK=new wd(255,210,210),this.PACIFIC_BLUE=this.parseHex_61zpoe$("#118ED8"),this.RGB_0="rgb",this.COLOR_0="color",this.RGBA_0="rgba"}rd.$metadata$={kind:$,simpleName:"Geometry",interfaces:[]},ld.$metadata$={kind:$,simpleName:"LineString",interfaces:[xf]},ud.$metadata$={kind:$,simpleName:"MultiLineString",interfaces:[xf]},cd.$metadata$={kind:$,simpleName:"MultiPoint",interfaces:[xf]},pd.$metadata$={kind:$,simpleName:"MultiPolygon",interfaces:[xf]},hd.$metadata$={kind:$,simpleName:"Polygon",interfaces:[xf]},_d.$metadata$={kind:$,simpleName:"Rect",interfaces:[]},_d.prototype.component1=function(){return this.origin},_d.prototype.component2=function(){return this.dimension},_d.prototype.copy_rbt1hw$=function(t,e){return new _d(void 0===t?this.origin:t,void 0===e?this.dimension:e)},_d.prototype.toString=function(){return"Rect(origin="+e.toString(this.origin)+", dimension="+e.toString(this.dimension)+")"},_d.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.origin)|0)+e.hashCode(this.dimension)|0},_d.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.origin,t.origin)&&e.equals(this.dimension,t.dimension)},dd.$metadata$={kind:$,simpleName:"Ring",interfaces:[xf]},md.$metadata$={kind:$,simpleName:"Scalar",interfaces:[]},md.prototype.component1=function(){return this.value},md.prototype.copy_14dthe$=function(t){return new md(void 0===t?this.value:t)},md.prototype.toString=function(){return"Scalar(value="+e.toString(this.value)+")"},md.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.value)|0},md.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.value,t.value)},yd.$metadata$={kind:$,simpleName:"Vec",interfaces:[]},yd.prototype.component1=function(){return this.x},yd.prototype.component2=function(){return this.y},yd.prototype.copy_lu1900$=function(t,e){return new yd(void 0===t?this.x:t,void 0===e?this.y:e)},yd.prototype.toString=function(){return"Vec(x="+e.toString(this.x)+", y="+e.toString(this.y)+")"},yd.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.x)|0)+e.hashCode(this.y)|0},yd.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.x,t.x)&&e.equals(this.y,t.y)},gd.$metadata$={kind:H,simpleName:"TypedKey",interfaces:[]},bd.prototype.get_ex36zt$=function(t){var n;if(this.map.containsKey_11rb$(t))return null==(n=this.map.get_11rb$(t))||e.isType(n,re)?n:E();throw new ie("Wasn't found key "+t)},bd.prototype.set_ev6mlr$=function(t,e){this.put_ev6mlr$(t,e)},bd.prototype.put_ev6mlr$=function(t,e){null==e?this.map.remove_11rb$(t):this.map.put_xwzc9p$(t,e)},bd.prototype.contains_ku7evr$=function(t){return this.containsKey_ex36zt$(t)},bd.prototype.containsKey_ex36zt$=function(t){return this.map.containsKey_11rb$(t)},bd.prototype.keys_287e2$=function(){var t;return e.isType(t=this.map.keys,nn)?t:E()},bd.$metadata$={kind:$,simpleName:"TypedKeyHashMap",interfaces:[]},wd.prototype.changeAlpha_za3lpa$=function(t){return new wd(this.red,this.green,this.blue,t)},wd.prototype.equals=function(t){return this===t||!!e.isType(t,wd)&&this.red===t.red&&this.green===t.green&&this.blue===t.blue&&this.alpha===t.alpha},wd.prototype.toCssColor=function(){return 255===this.alpha?"rgb("+this.red+","+this.green+","+this.blue+")":"rgba("+I(this.red)+","+I(this.green)+","+I(this.blue)+","+I(this.alpha/255)+")"},wd.prototype.toHexColor=function(){return"#"+Ed().toColorPart_0(this.red)+Ed().toColorPart_0(this.green)+Ed().toColorPart_0(this.blue)},wd.prototype.hashCode=function(){var t=0;return(31*(t=(31*(t=(31*(t=(31*t|0)+this.red|0)|0)+this.green|0)|0)+this.blue|0)|0)+this.alpha|0},wd.prototype.toString=function(){return"color("+this.red+","+this.green+","+this.blue+","+this.alpha+")"},xd.prototype.parseRGB_61zpoe$=function(t){var n=this.findNext_0(t,"(",0),i=t.substring(0,n),r=this.findNext_0(t,",",n+1|0),o=this.findNext_0(t,",",r+1|0),a=-1;if(l(i,this.RGBA_0))a=this.findNext_0(t,",",o+1|0);else if(l(i,this.COLOR_0))a=Oe(t,",",o+1|0);else if(!l(i,this.RGB_0))throw v(t);for(var s,u=this.findNext_0(t,")",a+1|0),c=n+1|0,p=t.substring(c,r),h=e.isCharSequence(s=p)?s:E(),_=0,f=h.length-1|0,d=!1;_<=f;){var m=d?f:_,y=nt(Ft(h.charCodeAt(m)))<=32;if(d){if(!y)break;f=f-1|0}else y?_=_+1|0:d=!0}for(var $,g=L(e.subSequence(h,_,f+1|0).toString()),b=r+1|0,w=t.substring(b,o),x=e.isCharSequence($=w)?$:E(),k=0,C=x.length-1|0,S=!1;k<=C;){var T=S?C:k,O=nt(Ft(x.charCodeAt(T)))<=32;if(S){if(!O)break;C=C-1|0}else O?k=k+1|0:S=!0}var N,P,A=L(e.subSequence(x,k,C+1|0).toString());if(-1===a){for(var j,R=o+1|0,I=t.substring(R,u),z=e.isCharSequence(j=I)?j:E(),D=0,M=z.length-1|0,B=!1;D<=M;){var U=B?M:D,F=nt(Ft(z.charCodeAt(U)))<=32;if(B){if(!F)break;M=M-1|0}else F?D=D+1|0:B=!0}N=L(e.subSequence(z,D,M+1|0).toString()),P=255}else{for(var q,G=o+1|0,H=a,Y=t.substring(G,H),V=e.isCharSequence(q=Y)?q:E(),K=0,W=V.length-1|0,X=!1;K<=W;){var Z=X?W:K,J=nt(Ft(V.charCodeAt(Z)))<=32;if(X){if(!J)break;W=W-1|0}else J?K=K+1|0:X=!0}N=L(e.subSequence(V,K,W+1|0).toString());for(var Q,tt=a+1|0,et=t.substring(tt,u),it=e.isCharSequence(Q=et)?Q:E(),rt=0,ot=it.length-1|0,at=!1;rt<=ot;){var st=at?ot:rt,lt=nt(Ft(it.charCodeAt(st)))<=32;if(at){if(!lt)break;ot=ot-1|0}else lt?rt=rt+1|0:at=!0}P=an(255*Yt(e.subSequence(it,rt,ot+1|0).toString()))}return new wd(g,A,N,P)},xd.prototype.findNext_0=function(t,e,n){var i=Oe(t,e,n);if(-1===i)throw v("text="+t+" what="+e+" from="+n);return i},xd.prototype.parseHex_61zpoe$=function(t){var e=t;if(!on(e,"#"))throw v("Not a HEX value: "+e);if(6!==(e=e.substring(1)).length)throw v("Not a HEX value: "+e);return new wd(te(e.substring(0,2),16),te(e.substring(2,4),16),te(e.substring(4,6),16))},xd.prototype.toColorPart_0=function(t){if(t<0||t>255)throw v("RGB color part must be in range [0..255] but was "+t);var e=Qt(t,16);return 1===e.length?"0"+e:e},xd.$metadata$={kind:y,simpleName:"Companion",interfaces:[]};var kd=null;function Ed(){return null===kd&&new xd,kd}function Cd(){Sd=this,this.DEFAULT_FACTOR_0=.7,this.variantColors_0=m([d("dark_blue",Ed().DARK_BLUE),d("dark_green",Ed().DARK_GREEN),d("dark_magenta",Ed().DARK_MAGENTA),d("light_blue",Ed().LIGHT_BLUE),d("light_gray",Ed().LIGHT_GRAY),d("light_green",Ed().LIGHT_GREEN),d("light_yellow",Ed().LIGHT_YELLOW),d("light_magenta",Ed().LIGHT_MAGENTA),d("light_cyan",Ed().LIGHT_CYAN),d("light_pink",Ed().LIGHT_PINK),d("very_light_gray",Ed().VERY_LIGHT_GRAY),d("very_light_yellow",Ed().VERY_LIGHT_YELLOW)]);var t,e=ln(m([d("white",Ed().WHITE),d("black",Ed().BLACK),d("gray",Ed().GRAY),d("red",Ed().RED),d("green",Ed().GREEN),d("blue",Ed().BLUE),d("yellow",Ed().YELLOW),d("magenta",Ed().MAGENTA),d("cyan",Ed().CYAN),d("orange",Ed().ORANGE),d("pink",Ed().PINK)]),this.variantColors_0),n=this.variantColors_0,i=pn(cn(n.size));for(t=n.entries.iterator();t.hasNext();){var r=t.next();i.put_xwzc9p$(un(r.key,95,45),r.value)}var o,a=ln(e,i),s=this.variantColors_0,l=pn(cn(s.size));for(o=s.entries.iterator();o.hasNext();){var u=o.next();l.put_xwzc9p$(Ze(u.key,"_",""),u.value)}this.namedColors_0=ln(a,l)}wd.$metadata$={kind:$,simpleName:"Color",interfaces:[]},Cd.prototype.parseColor_61zpoe$=function(t){var e;if(sn(t,40)>0)e=Ed().parseRGB_61zpoe$(t);else if(on(t,"#"))e=Ed().parseHex_61zpoe$(t);else{if(!this.isColorName_61zpoe$(t))throw v("Error persing color value: "+t);e=this.forName_61zpoe$(t)}return e},Cd.prototype.isColorName_61zpoe$=function(t){return this.namedColors_0.containsKey_11rb$(t.toLowerCase())},Cd.prototype.forName_61zpoe$=function(t){var e;if(null==(e=this.namedColors_0.get_11rb$(t.toLowerCase())))throw O();return e},Cd.prototype.generateHueColor=function(){return 360*De.Default.nextDouble()},Cd.prototype.generateColor_lu1900$=function(t,e){return this.rgbFromHsv_yvo9jy$(360*De.Default.nextDouble(),t,e)},Cd.prototype.rgbFromHsv_yvo9jy$=function(t,e,n){void 0===n&&(n=1);var i=t/60,r=n*e,o=i%2-1,a=r*(1-f.abs(o)),s=0,l=0,u=0;i<1?(s=r,l=a):i<2?(s=a,l=r):i<3?(l=r,u=a):i<4?(l=a,u=r):i<5?(s=a,u=r):(s=r,u=a);var c=n-r;return new wd(Lt(255*(s+c)),Lt(255*(l+c)),Lt(255*(u+c)))},Cd.prototype.hsvFromRgb_98b62m$=function(t){var e=1/255,n=t.red*e,i=t.green*e,r=t.blue*e,o=f.min(i,r),a=f.min(n,o),s=f.max(i,r),l=f.max(n,s),u=1/(6*(l-a));return new Float64Array([360*(l===a?0:l===n?i>=r?(i-r)*u:1+(i-r)*u:l===i?1/3+(r-n)*u:2/3+(n-i)*u),0===l?0:1-a/l,l])},Cd.prototype.darker_w32t8z$=function(t,e){var n;if(void 0===e&&(e=this.DEFAULT_FACTOR_0),null!=t){var i=Lt(t.red*e),r=f.max(i,0),o=Lt(t.green*e),a=f.max(o,0),s=Lt(t.blue*e);n=new wd(r,a,f.max(s,0),t.alpha)}else n=null;return n},Cd.prototype.lighter_o14uds$=function(t,e){void 0===e&&(e=this.DEFAULT_FACTOR_0);var n=t.red,i=t.green,r=t.blue,o=t.alpha,a=Lt(1/(1-e));if(0===n&&0===i&&0===r)return new wd(a,a,a,o);n>0&&n0&&i0&&r=-.001&&e<=1.001))throw v(("HSV 'saturation' must be in range [0, 1] but was "+e).toString());if(!(n>=-.001&&n<=1.001))throw v(("HSV 'value' must be in range [0, 1] but was "+n).toString());var i=Lt(100*e)/100;this.s=f.abs(i);var r=Lt(100*n)/100;this.v=f.abs(r)}function Od(t,e){this.first=t,this.second=e}function Nd(){}function Pd(){jd=this}function Ad(t){this.closure$kl=t}Td.prototype.toString=function(){return"HSV("+this.h+", "+this.s+", "+this.v+")"},Td.$metadata$={kind:$,simpleName:"HSV",interfaces:[]},Od.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Od)||E(),!!l(this.first,t.first)&&!!l(this.second,t.second))},Od.prototype.hashCode=function(){var t,e,n,i,r=null!=(e=null!=(t=this.first)?P(t):null)?e:0;return(31*r|0)+(null!=(i=null!=(n=this.second)?P(n):null)?i:0)|0},Od.prototype.toString=function(){return"["+this.first+", "+this.second+"]"},Od.prototype.component1=function(){return this.first},Od.prototype.component2=function(){return this.second},Od.$metadata$={kind:$,simpleName:"Pair",interfaces:[]},Nd.$metadata$={kind:H,simpleName:"SomeFig",interfaces:[]},Ad.prototype.error_l35kib$=function(t,e){this.closure$kl.error_ca4k3s$(t,e)},Ad.prototype.info_h4ejuu$=function(t){this.closure$kl.info_nq59yw$(t)},Ad.$metadata$={kind:$,interfaces:[ip]},Pd.prototype.logger_xo1ogr$=function(t){var e;return new Ad(hn.KotlinLogging.logger_61zpoe$(null!=(e=t.simpleName)?e:""))},Pd.$metadata$={kind:y,simpleName:"PortableLogging",interfaces:[]};var jd=null;var Ld=t.jetbrains||(t.jetbrains={}),Rd=Ld.datalore||(Ld.datalore={}),Id=Rd.base||(Rd.base={}),zd=Id.algorithms||(Id.algorithms={});zd.splitRings_bemo1h$=_n,zd.isClosed_2p1efm$=fn,zd.calculateArea_ytws2g$=function(t){return yn(t,c("x",1,(function(t){return t.x})),c("y",1,(function(t){return t.y})))},zd.isClockwise_st9g9f$=mn,zd.calculateArea_st9g9f$=yn;var Dd=Id.dateFormat||(Id.dateFormat={});Object.defineProperty(Dd,"DateLocale",{get:gn}),bn.SpecPart=wn,bn.PatternSpecPart=xn,Object.defineProperty(bn,"Companion",{get:Yn}),Dd.Format_init_61zpoe$=function(t,e){return e=e||Object.create(bn.prototype),bn.call(e,Yn().parse_61zpoe$(t)),e},Dd.Format=bn,Object.defineProperty(Vn,"DAY_OF_WEEK_ABBR",{get:Wn}),Object.defineProperty(Vn,"DAY_OF_WEEK_FULL",{get:Xn}),Object.defineProperty(Vn,"MONTH_ABBR",{get:Zn}),Object.defineProperty(Vn,"MONTH_FULL",{get:Jn}),Object.defineProperty(Vn,"DAY_OF_MONTH_LEADING_ZERO",{get:Qn}),Object.defineProperty(Vn,"DAY_OF_MONTH",{get:ti}),Object.defineProperty(Vn,"DAY_OF_THE_YEAR",{get:ei}),Object.defineProperty(Vn,"MONTH",{get:ni}),Object.defineProperty(Vn,"DAY_OF_WEEK",{get:ii}),Object.defineProperty(Vn,"YEAR_SHORT",{get:ri}),Object.defineProperty(Vn,"YEAR_FULL",{get:oi}),Object.defineProperty(Vn,"HOUR_24",{get:ai}),Object.defineProperty(Vn,"HOUR_12_LEADING_ZERO",{get:si}),Object.defineProperty(Vn,"HOUR_12",{get:li}),Object.defineProperty(Vn,"MINUTE",{get:ui}),Object.defineProperty(Vn,"MERIDIAN_LOWER",{get:ci}),Object.defineProperty(Vn,"MERIDIAN_UPPER",{get:pi}),Object.defineProperty(Vn,"SECOND",{get:hi}),Object.defineProperty(fi,"DATE",{get:mi}),Object.defineProperty(fi,"TIME",{get:yi}),_i.prototype.Kind=fi,Object.defineProperty(Vn,"Companion",{get:vi}),Dd.Pattern=Vn,Object.defineProperty(bi,"Companion",{get:ki});var Md=Id.datetime||(Id.datetime={});Md.Date=bi,Object.defineProperty(Ei,"Companion",{get:Ti}),Md.DateTime=Ei,Object.defineProperty(Md,"DateTimeUtil",{get:Pi}),Object.defineProperty(Ai,"Companion",{get:Ri}),Md.Duration=Ai,Md.Instant=Ii,Object.defineProperty(zi,"Companion",{get:Ui}),Md.Month=zi,Object.defineProperty(Fi,"Companion",{get:Ji}),Md.Time=Fi,Object.defineProperty(Qi,"MONDAY",{get:er}),Object.defineProperty(Qi,"TUESDAY",{get:nr}),Object.defineProperty(Qi,"WEDNESDAY",{get:ir}),Object.defineProperty(Qi,"THURSDAY",{get:rr}),Object.defineProperty(Qi,"FRIDAY",{get:or}),Object.defineProperty(Qi,"SATURDAY",{get:ar}),Object.defineProperty(Qi,"SUNDAY",{get:sr}),Md.WeekDay=Qi;var Bd=Md.tz||(Md.tz={});Bd.DateSpec=ur,Object.defineProperty(Bd,"DateSpecs",{get:fr}),Object.defineProperty(dr,"Companion",{get:$r}),Bd.TimeZone=dr,Object.defineProperty(vr,"Companion",{get:wr}),Bd.TimeZoneMoscow=vr,Object.defineProperty(Bd,"TimeZones",{get:ra});var Ud=Id.enums||(Id.enums={});Ud.EnumInfo=oa,Ud.EnumInfoImpl=aa,Object.defineProperty(sa,"NONE",{get:ua}),Object.defineProperty(sa,"LEFT",{get:ca}),Object.defineProperty(sa,"MIDDLE",{get:pa}),Object.defineProperty(sa,"RIGHT",{get:ha});var Fd=Id.event||(Id.event={});Fd.Button=sa,Fd.Event=_a,Object.defineProperty(fa,"A",{get:ma}),Object.defineProperty(fa,"B",{get:ya}),Object.defineProperty(fa,"C",{get:$a}),Object.defineProperty(fa,"D",{get:va}),Object.defineProperty(fa,"E",{get:ga}),Object.defineProperty(fa,"F",{get:ba}),Object.defineProperty(fa,"G",{get:wa}),Object.defineProperty(fa,"H",{get:xa}),Object.defineProperty(fa,"I",{get:ka}),Object.defineProperty(fa,"J",{get:Ea}),Object.defineProperty(fa,"K",{get:Ca}),Object.defineProperty(fa,"L",{get:Sa}),Object.defineProperty(fa,"M",{get:Ta}),Object.defineProperty(fa,"N",{get:Oa}),Object.defineProperty(fa,"O",{get:Na}),Object.defineProperty(fa,"P",{get:Pa}),Object.defineProperty(fa,"Q",{get:Aa}),Object.defineProperty(fa,"R",{get:ja}),Object.defineProperty(fa,"S",{get:La}),Object.defineProperty(fa,"T",{get:Ra}),Object.defineProperty(fa,"U",{get:Ia}),Object.defineProperty(fa,"V",{get:za}),Object.defineProperty(fa,"W",{get:Da}),Object.defineProperty(fa,"X",{get:Ma}),Object.defineProperty(fa,"Y",{get:Ba}),Object.defineProperty(fa,"Z",{get:Ua}),Object.defineProperty(fa,"DIGIT_0",{get:Fa}),Object.defineProperty(fa,"DIGIT_1",{get:qa}),Object.defineProperty(fa,"DIGIT_2",{get:Ga}),Object.defineProperty(fa,"DIGIT_3",{get:Ha}),Object.defineProperty(fa,"DIGIT_4",{get:Ya}),Object.defineProperty(fa,"DIGIT_5",{get:Va}),Object.defineProperty(fa,"DIGIT_6",{get:Ka}),Object.defineProperty(fa,"DIGIT_7",{get:Wa}),Object.defineProperty(fa,"DIGIT_8",{get:Xa}),Object.defineProperty(fa,"DIGIT_9",{get:Za}),Object.defineProperty(fa,"LEFT_BRACE",{get:Ja}),Object.defineProperty(fa,"RIGHT_BRACE",{get:Qa}),Object.defineProperty(fa,"UP",{get:ts}),Object.defineProperty(fa,"DOWN",{get:es}),Object.defineProperty(fa,"LEFT",{get:ns}),Object.defineProperty(fa,"RIGHT",{get:is}),Object.defineProperty(fa,"PAGE_UP",{get:rs}),Object.defineProperty(fa,"PAGE_DOWN",{get:os}),Object.defineProperty(fa,"ESCAPE",{get:as}),Object.defineProperty(fa,"ENTER",{get:ss}),Object.defineProperty(fa,"HOME",{get:ls}),Object.defineProperty(fa,"END",{get:us}),Object.defineProperty(fa,"TAB",{get:cs}),Object.defineProperty(fa,"SPACE",{get:ps}),Object.defineProperty(fa,"INSERT",{get:hs}),Object.defineProperty(fa,"DELETE",{get:_s}),Object.defineProperty(fa,"BACKSPACE",{get:fs}),Object.defineProperty(fa,"EQUALS",{get:ds}),Object.defineProperty(fa,"BACK_QUOTE",{get:ms}),Object.defineProperty(fa,"PLUS",{get:ys}),Object.defineProperty(fa,"MINUS",{get:$s}),Object.defineProperty(fa,"SLASH",{get:vs}),Object.defineProperty(fa,"CONTROL",{get:gs}),Object.defineProperty(fa,"META",{get:bs}),Object.defineProperty(fa,"ALT",{get:ws}),Object.defineProperty(fa,"SHIFT",{get:xs}),Object.defineProperty(fa,"UNKNOWN",{get:ks}),Object.defineProperty(fa,"F1",{get:Es}),Object.defineProperty(fa,"F2",{get:Cs}),Object.defineProperty(fa,"F3",{get:Ss}),Object.defineProperty(fa,"F4",{get:Ts}),Object.defineProperty(fa,"F5",{get:Os}),Object.defineProperty(fa,"F6",{get:Ns}),Object.defineProperty(fa,"F7",{get:Ps}),Object.defineProperty(fa,"F8",{get:As}),Object.defineProperty(fa,"F9",{get:js}),Object.defineProperty(fa,"F10",{get:Ls}),Object.defineProperty(fa,"F11",{get:Rs}),Object.defineProperty(fa,"F12",{get:Is}),Object.defineProperty(fa,"COMMA",{get:zs}),Object.defineProperty(fa,"PERIOD",{get:Ds}),Fd.Key=fa,Fd.KeyEvent_init_m5etgt$=Bs,Fd.KeyEvent=Ms,Object.defineProperty(Us,"Companion",{get:Gs}),Fd.KeyModifiers=Us,Fd.KeyStroke_init_ji7i3y$=Ys,Fd.KeyStroke_init_812rgc$=Vs,Fd.KeyStroke=Hs,Fd.KeyStrokeSpec_init_ji7i3y$=Ws,Fd.KeyStrokeSpec_init_luoraj$=Xs,Fd.KeyStrokeSpec_init_4t3vif$=Zs,Fd.KeyStrokeSpec=Ks,Object.defineProperty(Fd,"KeyStrokeSpecs",{get:function(){return null===il&&new Js,il}}),Object.defineProperty(rl,"CONTROL",{get:al}),Object.defineProperty(rl,"ALT",{get:sl}),Object.defineProperty(rl,"SHIFT",{get:ll}),Object.defineProperty(rl,"META",{get:ul}),Fd.ModifierKey=rl,Object.defineProperty(cl,"Companion",{get:bl}),Fd.MouseEvent_init_fbovgd$=wl,Fd.MouseEvent=cl,Fd.MouseEventSource=xl,Object.defineProperty(kl,"MOUSE_ENTERED",{get:Cl}),Object.defineProperty(kl,"MOUSE_LEFT",{get:Sl}),Object.defineProperty(kl,"MOUSE_MOVED",{get:Tl}),Object.defineProperty(kl,"MOUSE_DRAGGED",{get:Ol}),Object.defineProperty(kl,"MOUSE_CLICKED",{get:Nl}),Object.defineProperty(kl,"MOUSE_DOUBLE_CLICKED",{get:Pl}),Object.defineProperty(kl,"MOUSE_PRESSED",{get:Al}),Object.defineProperty(kl,"MOUSE_RELEASED",{get:jl}),Fd.MouseEventSpec=kl,Fd.PointEvent=Ll;var qd=Id.function||(Id.function={});qd.Function=Rl,Object.defineProperty(qd,"Functions",{get:function(){return null===Hl&&new Il,Hl}}),qd.Runnable=Yl,qd.Supplier=Vl,qd.Value=Kl;var Gd=Id.gcommon||(Id.gcommon={}),Hd=Gd.base||(Gd.base={});Object.defineProperty(Hd,"Strings",{get:function(){return null===Xl&&new Wl,Xl}}),Object.defineProperty(Hd,"Throwables",{get:function(){return null===Jl&&new Zl,Jl}}),Object.defineProperty(Ql,"Companion",{get:nu});var Yd=Gd.collect||(Gd.collect={});Yd.ClosedRange=Ql,Object.defineProperty(Yd,"Comparables",{get:ou}),Yd.ComparatorOrdering=au,Object.defineProperty(Yd,"Iterables",{get:uu}),Object.defineProperty(Yd,"Lists",{get:function(){return null===pu&&new cu,pu}}),Object.defineProperty(hu,"Companion",{get:mu}),Yd.Ordering=hu,Object.defineProperty(Yd,"Sets",{get:function(){return null===$u&&new yu,$u}}),Yd.Stack=vu,Yd.TreeMap=gu,Object.defineProperty(bu,"Companion",{get:ku});var Vd=Id.geometry||(Id.geometry={});Vd.DoubleRectangle_init_6y0v78$=function(t,e,n,i,r){return r=r||Object.create(bu.prototype),bu.call(r,new Nu(t,e),new Nu(n,i)),r},Vd.DoubleRectangle=bu,Object.defineProperty(Vd,"DoubleRectangles",{get:Tu}),Vd.DoubleSegment=Ou,Object.defineProperty(Nu,"Companion",{get:ju}),Vd.DoubleVector=Nu,Vd.Rectangle_init_tjonv8$=function(t,e,n,i,r){return r=r||Object.create(Lu.prototype),Lu.call(r,new Iu(t,e),new Iu(n,i)),r},Vd.Rectangle=Lu,Vd.Segment=Ru,Object.defineProperty(Iu,"Companion",{get:Mu}),Vd.Vector=Iu;var Kd=Id.json||(Id.json={});Kd.FluentArray_init=Uu,Kd.FluentArray_init_giv38x$=Fu,Kd.FluentArray=Bu,Kd.FluentObject_init_bkhwtg$=Gu,Kd.FluentObject_init=function(t){return t=t||Object.create(qu.prototype),Hu.call(t),qu.call(t),t.myObj_0=Ot(),t},Kd.FluentObject=qu,Kd.FluentValue=Hu,Kd.JsonFormatter=Yu,Object.defineProperty(Vu,"Companion",{get:ec}),Kd.JsonLexer=Vu,nc.JsonException=ic,Kd.JsonParser=nc,Object.defineProperty(Kd,"JsonSupport",{get:vc}),Object.defineProperty(gc,"LEFT_BRACE",{get:wc}),Object.defineProperty(gc,"RIGHT_BRACE",{get:xc}),Object.defineProperty(gc,"LEFT_BRACKET",{get:kc}),Object.defineProperty(gc,"RIGHT_BRACKET",{get:Ec}),Object.defineProperty(gc,"COMMA",{get:Cc}),Object.defineProperty(gc,"COLON",{get:Sc}),Object.defineProperty(gc,"STRING",{get:Tc}),Object.defineProperty(gc,"NUMBER",{get:Oc}),Object.defineProperty(gc,"TRUE",{get:Nc}),Object.defineProperty(gc,"FALSE",{get:Pc}),Object.defineProperty(gc,"NULL",{get:Ac}),Kd.Token=gc,Kd.escape_pdl1vz$=jc,Kd.unescape_pdl1vz$=Lc,Kd.streamOf_9ma18$=Rc,Kd.objectsStreamOf_9ma18$=zc,Kd.getAsInt_s8jyv4$=function(t){var n;return Lt(e.isNumber(n=t)?n:E())},Kd.getAsString_s8jyv4$=Dc,Kd.parseEnum_xwn52g$=Mc,Kd.formatEnum_wbfx10$=Bc,Kd.put_5zytao$=function(t,e,n){var i,r=Uu(),o=h(p(n,10));for(i=n.iterator();i.hasNext();){var a=i.next();o.add_11rb$(a)}return t.put_wxs67v$(e,r.addStrings_d294za$(o))},Kd.getNumber_8dq7w5$=Uc,Kd.getDouble_8dq7w5$=Fc,Kd.getString_8dq7w5$=function(t,n){var i,r;return"string"==typeof(i=(e.isType(r=t,k)?r:E()).get_11rb$(n))?i:E()},Kd.getArr_8dq7w5$=qc,Object.defineProperty(Gc,"Companion",{get:Vc}),Gc.Entry=ep,(Id.listMap||(Id.listMap={})).ListMap=Gc;var Wd=Id.logging||(Id.logging={});Wd.Logger=ip;var Xd=Id.math||(Id.math={});Xd.toRadians_14dthe$=rp,Xd.toDegrees_14dthe$=op,Xd.round_lu1900$=function(t,e){return new Iu(Lt(pe(t)),Lt(pe(e)))},Xd.ipow_dqglrj$=ap;var Zd=Id.numberFormat||(Id.numberFormat={});Zd.length_s8cxhz$=sp,lp.Spec=up,Object.defineProperty(cp,"Companion",{get:fp}),lp.NumberInfo_init_hjbnfl$=dp,lp.NumberInfo=cp,lp.Output=mp,lp.FormattedNumber=yp,Object.defineProperty(lp,"Companion",{get:kp}),Zd.NumberFormat_init_61zpoe$=Ep,Zd.NumberFormat=lp;var Jd=Id.observable||(Id.observable={}),Qd=Jd.children||(Jd.children={});Qd.ChildList=Cp,Qd.Position=Np,Qd.PositionData=Pp,Qd.SimpleComposite=Ap;var tm=Jd.collections||(Jd.collections={});tm.CollectionAdapter=jp,Object.defineProperty(Rp,"ADD",{get:zp}),Object.defineProperty(Rp,"SET",{get:Dp}),Object.defineProperty(Rp,"REMOVE",{get:Mp}),Lp.EventType=Rp,tm.CollectionItemEvent=Lp,tm.CollectionListener=Bp,tm.ObservableCollection=Up;var em=tm.list||(tm.list={});em.AbstractObservableList=Fp,em.ObservableArrayList=Kp,em.ObservableList=Wp;var nm=Jd.event||(Jd.event={});nm.CompositeEventSource_init_xw2ruy$=th,nm.CompositeEventSource_init_3qo2qg$=eh,nm.CompositeEventSource=Xp,nm.EventHandler=nh,nm.EventSource=ih,Object.defineProperty(nm,"EventSources",{get:function(){return null===ph&&new rh,ph}}),nm.ListenerCaller=hh,nm.ListenerEvent=_h,nm.Listeners=fh,nm.MappingEventSource=yh;var im=Jd.property||(Jd.property={});im.BaseReadableProperty=vh,im.DelayedValueProperty=gh,im.Property=xh,Object.defineProperty(im,"PropertyBinding",{get:function(){return null===Sh&&new kh,Sh}}),im.PropertyChangeEvent=Th,im.ReadableProperty=Oh,im.ValueProperty=Nh,im.WritableProperty=jh;var rm=Id.random||(Id.random={});Object.defineProperty(rm,"RandomString",{get:function(){return null===Rh&&new Lh,Rh}});var om=Id.registration||(Id.registration={});om.CompositeRegistration=Ih,om.Disposable=zh,Object.defineProperty(Dh,"Companion",{get:Gh}),om.Registration=Dh;var am=om.throwableHandlers||(om.throwableHandlers={});am.ThrowableHandler=Hh,Object.defineProperty(am,"ThrowableHandlers",{get:t_});var sm=Id.spatial||(Id.spatial={});Object.defineProperty(sm,"FULL_LONGITUDE",{get:function(){return Xh}}),sm.get_start_cawtq0$=n_,sm.get_end_cawtq0$=i_,Object.defineProperty(r_,"Companion",{get:l_}),sm.GeoBoundingBoxCalculator=r_,sm.makeSegments_8o5yvy$=u_,sm.geoRectsBBox_wfabpm$=function(t,e){return t.calculateBoundingBox_qpfwx8$(u_((n=e,function(t){return n.get_za3lpa$(t).startLongitude()}),function(t){return function(e){return t.get_za3lpa$(e).endLongitude()}}(e),e.size),u_(function(t){return function(e){return t.get_za3lpa$(e).minLatitude()}}(e),function(t){return function(e){return t.get_za3lpa$(e).maxLatitude()}}(e),e.size));var n},sm.pointsBBox_2r9fhj$=function(t,e){if(e.size%2!=0)throw v("Longitude-Latitude list is not even-numbered.".toString());var n,i=(n=e,function(t){return n.get_za3lpa$(2*t|0)}),r=function(t){return function(e){return t.get_za3lpa$(1+(2*e|0)|0)}}(e),o=e.size/2|0;return t.calculateBoundingBox_qpfwx8$(u_(i,i,o),u_(r,r,o))},sm.union_86o20w$=function(t,e){return t.calculateBoundingBox_qpfwx8$(u_((n=e,function(t){return Af(n.get_za3lpa$(t))}),function(t){return function(e){return Tf(t.get_za3lpa$(e))}}(e),e.size),u_(function(t){return function(e){return Pf(t.get_za3lpa$(e))}}(e),function(t){return function(e){return Sf(t.get_za3lpa$(e))}}(e),e.size));var n},Object.defineProperty(sm,"GeoJson",{get:function(){return null===m_&&new c_,m_}}),sm.GeoRectangle=y_,sm.limitLon_14dthe$=$_,sm.limitLat_14dthe$=v_,sm.normalizeLon_14dthe$=g_,Object.defineProperty(sm,"BBOX_CALCULATOR",{get:function(){return d_}}),sm.convertToGeoRectangle_i3vl8m$=function(t){var e,n;return Nf(t)=e.x&&t.origin.y<=e.y&&t.origin.y+t.dimension.y>=e.y},lm.intersects_32samh$=function(t,e){var n=t.origin,i=Bf(t.origin,t.dimension),r=e.origin,o=Bf(e.origin,e.dimension);return o.x>=n.x&&i.x>=r.x&&o.y>=n.y&&i.y>=r.y},lm.xRange_h9e6jg$=Zf,lm.yRange_h9e6jg$=Jf,lm.limit_lddjmn$=function(t){var e,n=h(p(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(Xf(i))}return n},Object.defineProperty(Qf,"MULTI_POINT",{get:ed}),Object.defineProperty(Qf,"MULTI_LINESTRING",{get:nd}),Object.defineProperty(Qf,"MULTI_POLYGON",{get:id}),lm.GeometryType=Qf,Object.defineProperty(rd,"Companion",{get:sd}),lm.Geometry=rd,lm.LineString=ld,lm.MultiLineString=ud,lm.MultiPoint=cd,lm.MultiPolygon=pd,lm.Polygon=hd,lm.Rect_init_94ua8u$=fd,lm.Rect=_d,lm.Ring=dd,lm.Scalar=md,lm.Vec_init_vrm8gm$=function(t,e,n){return n=n||Object.create(yd.prototype),yd.call(n,t,e),n},lm.Vec=yd,lm.explicitVec_y7b45i$=$d,lm.explicitVec_vrm8gm$=function(t,e){return new yd(t,e)},lm.newVec_4xl464$=vd;var um=Id.typedKey||(Id.typedKey={});um.TypedKey=gd,um.TypedKeyHashMap=bd,(Id.unsupported||(Id.unsupported={})).UNSUPPORTED_61zpoe$=function(t){throw rn(t)},Object.defineProperty(wd,"Companion",{get:Ed});var cm=Id.values||(Id.values={});cm.Color=wd,Object.defineProperty(cm,"Colors",{get:function(){return null===Sd&&new Cd,Sd}}),cm.HSV=Td,cm.Pair=Od,cm.SomeFig=Nd,Object.defineProperty(Wd,"PortableLogging",{get:function(){return null===jd&&new Pd,jd}}),mc=m([d(Ft(34),Ft(34)),d(Ft(92),Ft(92)),d(Ft(47),Ft(47)),d(Ft(98),Ft(8)),d(Ft(102),Ft(12)),d(Ft(110),Ft(10)),d(Ft(114),Ft(13)),d(Ft(116),Ft(9))]);var pm,hm=b(0,32),_m=h(p(hm,10));for(pm=hm.iterator();pm.hasNext();){var fm=pm.next();_m.add_11rb$(Ft(it(fm)))}return yc=Zt(_m),Vh=6378137,f_=fd(Kh=-180,Zh=-90,Xh=(Wh=180)-Kh,(Jh=90)-Zh),d_=new r_(f_,!0,!1),t})?i.apply(e,r):i)||(t.exports=o)},602:function(t,e,n){var i,r,o;r=[e,n(421),n(767),n(73)],void 0===(o="function"==typeof(i=function(t,e,n,i){"use strict";var r=e.Kind.INTERFACE,o=n.jetbrains.datalore.base.function.Value,a=e.kotlin.Unit,s=n.jetbrains.datalore.base.registration.Registration,l=Error,u=e.throwCCE,c=e.Kind.CLASS,p=e.kotlin.Exception,h=Object,_=e.kotlin.Pair,f=e.ensureNotNull,d=e.Kind.OBJECT,m=e.kotlin.collections.listOf_i5x0yv$,y=e.kotlin.collections.ArrayList_init_mqih57$,$=n.jetbrains.datalore.base.gcommon.collect.TreeMap,v=e.kotlin.collections.ArrayList_init_ww73n8$,g=e.kotlin.IllegalStateException_init_pdl1vj$,b=n.jetbrains.datalore.base.observable.event.ListenerCaller,w=n.jetbrains.datalore.base.observable.event.Listeners,x=e.kotlin.collections.ArrayList_init_287e2$,k=e.kotlin.RuntimeException,E=e.toString,C=e.kotlin.IllegalArgumentException_init_pdl1vj$,S=n.jetbrains.datalore.base.function,T=e.kotlin.collections.get_indices_gzk92b$,O=e.kotlin.ranges.reversed_zf1xzc$,N=e.kotlin.NoSuchElementException_init,P=e.kotlin.collections.Iterator,A=e.kotlin.collections.Iterable,j=Math,L=n.jetbrains.datalore.base.geometry.Vector,R=n.jetbrains.datalore.base.function.Function,I=(e.defineInlineFunction,e.wrapFunction,e.kotlin.collections.Collection,e.kotlin.collections.List,e.kotlin.collections.Set,e.kotlin.collections.Map,e.kotlin.RuntimeException_init_pdl1vj$,n.jetbrains.datalore.base.observable.collections.ObservableCollection),z=(n.jetbrains.datalore.base.observable.collections.list.ObservableArrayList,n.jetbrains.datalore.base.observable.property.WritableProperty),D=n.jetbrains.datalore.base.observable.property.PropertyChangeEvent,M=n.jetbrains.datalore.base.observable.property.Property,B=n.jetbrains.datalore.base.observable.collections.CollectionAdapter,U=(e.kotlin.UnsupportedOperationException_init,n.jetbrains.datalore.base.observable.collections.list.AbstractObservableList,e.kotlin.collections.MutableCollection,e.kotlin.IllegalStateException_init),F=(e.kotlin.math.abs_za3lpa$,e.hashCode,e.equals),q=(e.kotlin.collections.AbstractMutableList,n.jetbrains.datalore.base.observable.collections.list.ObservableList,n.jetbrains.datalore.base.observable.collections.CollectionItemEvent.EventType),G=n.jetbrains.datalore.base.observable.collections.CollectionItemEvent,H=e.kotlin.collections.MutableIterator,Y=e.kotlin.collections.AbstractMutableSet,V=e.kotlin.collections.LinkedHashSet_init_287e2$,K=e.kotlin.collections.HashSet_init_ww73n8$,W=e.kotlin.collections.MutableSet,X=n.jetbrains.datalore.base.function.Runnable,Z=n.jetbrains.datalore.base.observable.event.EventSource,J=n.jetbrains.datalore.base.observable.property.BaseReadableProperty,Q=Array,tt=(n.jetbrains.datalore.base.observable.property.ValueProperty,n.jetbrains.datalore.base.registration.Disposable,e.kotlin.text.startsWith_7epoxm$),et=n.jetbrains.datalore.base.function.Supplier,nt=n.jetbrains.datalore.base.observable.property.ReadableProperty,it=e.kotlin.text.StringBuilder_init,rt=e.kotlin.text.StringBuilder,ot=n.jetbrains.datalore.base.observable.collections.CollectionListener,at=e.kotlin.Enum,st=e.throwISE,lt=(e.kotlin.Comparator,e.kotlin.collections.HashMap_init_q3lmfv$),ut=(e.kotlin.collections.binarySearch_vikexg$,e.kotlin.collections.sortWith_nqfjgj$,e.kotlin.collections.MutableMap,e.toByte),ct=e.toChar,pt=e.kotlin.collections.HashSet_init_287e2$,ht=n.jetbrains.datalore.base.event.ModifierKey,_t=n.jetbrains.datalore.base.event.KeyEvent_init_m5etgt$,ft=n.jetbrains.datalore.base.event.Key,dt=n.jetbrains.datalore.base.event,mt=n.jetbrains.datalore.base.event.Button,yt=n.jetbrains.datalore.base.event.KeyModifiers,$t=e.numberToInt,vt=n.jetbrains.datalore.base.event.MouseEvent,gt=e.kotlin.text.equals_igcy3c$,bt=(e.toShort,e.getCallableRef,e.kotlin.random.Random,i.mu),wt=e.kotlin.js.iterator_s8jyvk$,xt=e.numberToDouble;function kt(){}function Et(){}function Ct(){Pt=this}function St(t){this.closure$value=t}function Tt(t){this.closure$t=t}function Ot(t){return a}function Nt(t){this.myAsync_0=t,this.myItem_8be2vx$=null,this.mySucceeded_8be2vx$=!1,this.myReg_0=null}Ut.prototype=Object.create(s.prototype),Ut.prototype.constructor=Ut,Ht.prototype=Object.create(s.prototype),Ht.prototype.constructor=Ht,Yt.prototype=Object.create(k.prototype),Yt.prototype.constructor=Yt,$e.prototype=Object.create(J.prototype),$e.prototype.constructor=$e,pe.prototype=Object.create(B.prototype),pe.prototype.constructor=pe,se.prototype=Object.create(Y.prototype),se.prototype.constructor=se,he.prototype=Object.create(se.prototype),he.prototype.constructor=he,ge.prototype=Object.create(w.prototype),ge.prototype.constructor=ge,be.prototype=Object.create($e.prototype),be.prototype.constructor=be,Se.prototype=Object.create(be.prototype),Se.prototype.constructor=Se,Te.prototype=Object.create(be.prototype),Te.prototype.constructor=Te,Oe.prototype=Object.create(be.prototype),Oe.prototype.constructor=Oe,Ne.prototype=Object.create(be.prototype),Ne.prototype.constructor=Ne,Pe.prototype=Object.create(be.prototype),Pe.prototype.constructor=Pe,je.prototype=Object.create($e.prototype),je.prototype.constructor=je,ze.prototype=Object.create($e.prototype),ze.prototype.constructor=ze,qe.prototype=Object.create(s.prototype),qe.prototype.constructor=qe,Ge.prototype=Object.create(be.prototype),Ge.prototype.constructor=Ge,He.prototype=Object.create(be.prototype),He.prototype.constructor=He,Ke.prototype=Object.create(J.prototype),Ke.prototype.constructor=Ke,mn.prototype=Object.create($e.prototype),mn.prototype.constructor=mn,We.prototype=Object.create(mn.prototype),We.prototype.constructor=We,Xe.prototype=Object.create(mn.prototype),Xe.prototype.constructor=Xe,Ze.prototype=Object.create($e.prototype),Ze.prototype.constructor=Ze,Qe.prototype=Object.create(B.prototype),Qe.prototype.constructor=Qe,tn.prototype=Object.create(be.prototype),tn.prototype.constructor=tn,nn.prototype=Object.create(be.prototype),nn.prototype.constructor=nn,rn.prototype=Object.create(be.prototype),rn.prototype.constructor=rn,on.prototype=Object.create(be.prototype),on.prototype.constructor=on,an.prototype=Object.create(be.prototype),an.prototype.constructor=an,sn.prototype=Object.create(be.prototype),sn.prototype.constructor=sn,pn.prototype=Object.create(B.prototype),pn.prototype.constructor=pn,hn.prototype=Object.create(be.prototype),hn.prototype.constructor=hn,_n.prototype=Object.create(be.prototype),_n.prototype.constructor=_n,$n.prototype=Object.create($e.prototype),$n.prototype.constructor=$n,Vn.prototype=Object.create(at.prototype),Vn.prototype.constructor=Vn,ui.prototype=Object.create(at.prototype),ui.prototype.constructor=ui,fi.prototype=Object.create(at.prototype),fi.prototype.constructor=fi,kt.$metadata$={kind:r,simpleName:"Async",interfaces:[]},Et.$metadata$={kind:r,simpleName:"AsyncResolver",interfaces:[]},Ct.prototype.isFinished_jdxood$=function(t){var e,n=new o(!1);return t.onResult_m8e4a6$((e=n,function(t){return e.set_11rb$(!0),a}),function(t){return function(e){return t.set_11rb$(!0),a}}(n)).remove(),n.get()},St.prototype.onSuccess_qlkmfe$=function(t){return t(this.closure$value),s.Companion.EMPTY},St.prototype.onResult_m8e4a6$=function(t,e){return this.onSuccess_qlkmfe$(t)},St.prototype.onFailure_4m4org$=function(t){return s.Companion.EMPTY},St.prototype.map_2o04qz$=function(t){var n;try{n=t(this.closure$value)}catch(t){if(e.isType(t,l))return At().failure_lsqlk3$(t);throw t}return At().constant_mh5how$(n)},St.prototype.flatMap_sqztdv$=function(t){var n,i;try{i=t(this.closure$value)}catch(t){if(e.isType(t,l))return At().failure_lsqlk3$(t);throw t}return null==i?At().constant_mh5how$(null):e.isType(n=i,kt)?n:u()},St.$metadata$={kind:c,interfaces:[kt]},Ct.prototype.constant_mh5how$=function(t){return new St(t)},Tt.prototype.onSuccess_qlkmfe$=function(t){return s.Companion.EMPTY},Tt.prototype.onResult_m8e4a6$=function(t,e){return this.onFailure_4m4org$(e)},Tt.prototype.onFailure_4m4org$=function(t){return t(this.closure$t),s.Companion.EMPTY},Tt.prototype.map_2o04qz$=function(t){return At().failure_lsqlk3$(this.closure$t)},Tt.prototype.flatMap_sqztdv$=function(t){return At().failure_lsqlk3$(this.closure$t)},Tt.$metadata$={kind:c,interfaces:[kt]},Ct.prototype.failure_lsqlk3$=function(t){return new Tt(t)},Ct.prototype.voidAsync=function(){return this.constant_mh5how$(a)},Ct.prototype.toUnit_5m6kth$=function(t){return this.map_wnedw7$(t,Ot,new Gt)},Ct.prototype.map_wnedw7$=function(t,n,i){return t.onResult_m8e4a6$((r=n,o=i,function(t){var n;try{n=r(t)}catch(t){if(e.isType(t,p))return void o.failure_tcv7n7$(t);throw t}return o.success_11rb$(n),a}),function(t){return function(e){return t.failure_tcv7n7$(e),a}}(i)),i;var r,o},Ct.prototype.select_vkqda3$=function(t,n,i){return t.onResult_m8e4a6$((r=n,o=i,s=this,function(t){var n;try{n=r(t)}catch(t){if(e.isType(t,p))return void o.failure_tcv7n7$(t);throw t}return null==n?o.success_11rb$(null):s.delegate_6j4q7x$(n,o),a}),function(t){return function(e){return t.failure_tcv7n7$(e),a}}(i)),i;var r,o,s},Ct.prototype.seq_y7kb4$=function(t,e){return this.select_vkqda3$(t,(n=e,function(t){return n}),new Gt);var n},Ct.prototype.onAnyResult_l1da99$=function(t,e){return t.onResult_m8e4a6$((n=e,function(t){return n.run(),a}),function(t){return function(e){return t.run(),a}}(e));var n},Ct.prototype.untilSuccess_qkdzg6$=function(t){var n,i,r,o,s,l=new Bt,u=(i=l,function(t){return i.success_11rb$(t),a});try{n=t.get()}catch(n){if(e.isType(n,p))return this.untilSuccess_qkdzg6$(t).onSuccess_qlkmfe$(u),l;throw n}return n.onResult_m8e4a6$(u,(r=t,o=this,s=u,function(t){return o.untilSuccess_qkdzg6$(r).onSuccess_qlkmfe$(s),a})),l},Ct.prototype.delegate_6j4q7x$=function(t,e){return t.onResult_m8e4a6$((n=e,function(t){return n.success_11rb$(t),a}),function(t){return function(e){return t.failure_tcv7n7$(e),a}}(e));var n},Ct.prototype.pair_y7kb4$=function(t,n){var i,r,o,s=new Bt,l=new Bt,c=new Nt(t),p=new Nt(n);return l.onResult_m8e4a6$((i=c,r=p,o=s,function(t){var n,s;return i.mySucceeded_8be2vx$&&r.mySucceeded_8be2vx$?o.success_11rb$(new _(null==(n=i.myItem_8be2vx$)||e.isType(n,h)?n:u(),null==(s=r.myItem_8be2vx$)||e.isType(s,h)?s:u())):o.failure_tcv7n7$(e.newThrowable("internal error in pair async")),a}),function(t){return function(e){return t.failure_tcv7n7$(e),a}}(s)),c.pair_sr8jes$(p,l),p.pair_sr8jes$(c,l),s},Nt.prototype.pair_sr8jes$=function(t,e){var n,i,r;e.hasSucceeded_8be2vx$()||e.hasFailed_8be2vx$()||(this.myReg_0=this.myAsync_0.onResult_m8e4a6$((n=this,i=t,r=e,function(t){return n.myItem_8be2vx$=t,n.mySucceeded_8be2vx$=!0,i.mySucceeded_8be2vx$&&r.success_11rb$(a),a}),function(t,e){return function(n){return null!=t.myReg_0&&f(t.myReg_0).remove(),e.failure_tcv7n7$(n),a}}(t,e)))},Nt.$metadata$={kind:c,simpleName:"PairedAsync",interfaces:[]},Ct.$metadata$={kind:d,simpleName:"Asyncs",interfaces:[]};var Pt=null;function At(){return null===Pt&&new Ct,Pt}function jt(){Dt=this}function Lt(t,e,n){return function(i){return t.set_5ltja$(e,i),n(),a}}function Rt(t,e){return function(n){return t.add_8o0b5c$(n),e(),a}}function It(){this.myLock_0=new gn,this.myMap_0=new $}function zt(){this.myLock_0=new gn,this.myThrowables_0=v(0)}jt.prototype.parallel_nq6ec4$=function(t){return this.parallel_yy0mju$(m(t.slice()))},jt.prototype.parallelResult_b5my6p$=function(t){return this.runParallel_0(t,!0)},jt.prototype.parallel_yy0mju$=function(t,e){return void 0===e&&(e=!1),At().toUnit_5m6kth$(this.runParallel_0(t,e))},jt.prototype.composite_a4rjr8$=function(t){return this.runParallel_0(t,!1)},jt.prototype.runParallel_0=function(t,e){for(var n=new Gt,i=new vn(t.size),r=new It,o=new zt,s=function(t,e,n,i,r){return function(){return t.decrementAndGet()<=0&&(e.isEmpty_8be2vx$||n?i.success_11rb$(r.get_8be2vx$()):i.failure_tcv7n7$(e.toSingleException_8be2vx$())),a}}(i,o,e,n,r),l=0,u=t.iterator();u.hasNext();++l)u.next().onResult_m8e4a6$(Lt(r,l,s),Rt(o,s));return t.isEmpty()&&s(),n},It.prototype.set_5ltja$=function(t,e){var n=this.myLock_0;try{n.lock(),this.myMap_0.put_ncwa5f$(t,e)}finally{n.unlock()}},It.prototype.get_8be2vx$=function(){var t=this.myLock_0;try{return t.lock(),y(this.myMap_0.values)}finally{t.unlock()}},It.$metadata$={kind:c,simpleName:"OrderedValues",interfaces:[]},Object.defineProperty(zt.prototype,"isEmpty_8be2vx$",{configurable:!0,get:function(){var t=this.myLock_0;try{return t.lock(),this.myThrowables_0.isEmpty()}finally{t.unlock()}}}),zt.prototype.add_8o0b5c$=function(t){var e=this.myLock_0;try{e.lock(),this.myThrowables_0.add_11rb$(t)}finally{e.unlock()}},zt.prototype.toSingleException_8be2vx$=function(){var t=this.myLock_0;try{if(t.lock(),this.myThrowables_0.isEmpty())throw g("Empty collection".toString());return 1===this.myThrowables_0.size?this.myThrowables_0.get_za3lpa$(0):Vt(y(this.myThrowables_0))}finally{t.unlock()}},zt.$metadata$={kind:c,simpleName:"ThreadSafeThrowables",interfaces:[]},jt.$metadata$={kind:d,simpleName:"PlatformAsyncs",interfaces:[]};var Dt=null;function Mt(){}function Bt(){this.mySuccessItem_0=null,this.mySucceeded_0=!1,this.myFailureThrowable_0=null,this.myFailed_0=!1,this.mySuccessHandlers_0=new w,this.myFailureHandlers_0=new w}function Ut(t,e){this.closure$successRegistration=t,this.closure$failureRegistration=e,s.call(this)}function Ft(t){this.this$SimpleAsync=t}function qt(t){this.this$SimpleAsync=t}function Gt(){this.myAsync_0=new Bt,this.lock_0=new gn}function Ht(t,e){this.this$ThreadSafeAsync=t,this.closure$r=e,s.call(this)}function Yt(){this.name="ThrowableCollectionException",this.myThrowables_0=x()}function Vt(t,e){return e=e||Object.create(Yt.prototype),k.call(e,"size="+E(t.size),t.get_za3lpa$(0)),Yt.call(e),e.myThrowables_0.addAll_brywnq$(t),e}function Kt(){ee=this,this.ourWithBounds_0=new ie(0)}function Wt(t){return t.parent}function Xt(t){return t.parent}function Zt(t){return!t.visible().get()}function Jt(t){return t.focusable().get()}function Qt(t,e){this.closure$trans=t,this.closure$initial=e}function te(t,e){this.closure$trans=t,this.myCurrent_0=e}Mt.$metadata$={kind:r,simpleName:"ResolvableAsync",interfaces:[Et,kt]},Bt.prototype.onSuccess_qlkmfe$=function(t){return this.alreadyHandled_0()?(this.mySucceeded_0&&t(f(this.mySuccessItem_0)),s.Companion.EMPTY):f(this.mySuccessHandlers_0).add_11rb$(t)},Ut.prototype.doRemove=function(){this.closure$successRegistration.remove(),this.closure$failureRegistration.remove()},Ut.$metadata$={kind:c,interfaces:[s]},Bt.prototype.onResult_m8e4a6$=function(t,e){return new Ut(this.onSuccess_qlkmfe$(t),this.onFailure_4m4org$(e))},Bt.prototype.onFailure_4m4org$=function(t){return this.alreadyHandled_0()?(this.myFailed_0&&t(f(this.myFailureThrowable_0)),s.Companion.EMPTY):f(this.myFailureHandlers_0).add_11rb$(t)},Bt.prototype.map_2o04qz$=function(t){return At().map_wnedw7$(this,t,new Bt)},Bt.prototype.flatMap_sqztdv$=function(t){return At().select_vkqda3$(this,t,new Bt)},Ft.prototype.call_11rb$=function(t){var n;t(null==(n=this.this$SimpleAsync.mySuccessItem_0)||e.isType(n,h)?n:u())},Ft.$metadata$={kind:c,interfaces:[b]},Bt.prototype.success_11rb$=function(t){if(this.alreadyHandled_0())throw g("Async already completed");this.mySuccessItem_0=t,this.mySucceeded_0=!0,f(this.mySuccessHandlers_0).fire_kucmxw$(new Ft(this)),this.clearHandlers_0()},qt.prototype.call_11rb$=function(t){t(f(this.this$SimpleAsync.myFailureThrowable_0))},qt.$metadata$={kind:c,interfaces:[b]},Bt.prototype.failure_tcv7n7$=function(t){if(this.alreadyHandled_0())throw g("Async already completed");this.myFailureThrowable_0=t,this.myFailed_0=!0,f(this.myFailureHandlers_0).fire_kucmxw$(new qt(this)),this.clearHandlers_0()},Bt.prototype.clearHandlers_0=function(){this.mySuccessHandlers_0=null,this.myFailureHandlers_0=null},Bt.prototype.alreadyHandled_0=function(){return this.mySucceeded_0||this.myFailed_0},Bt.prototype.hasSucceeded_8be2vx$=function(){return this.mySucceeded_0},Bt.prototype.hasFailed_8be2vx$=function(){return this.myFailed_0},Bt.$metadata$={kind:c,simpleName:"SimpleAsync",interfaces:[Mt]},Gt.prototype.onSuccess_qlkmfe$=function(t){var e=this.lock_0;try{return e.lock(),this.safeReg_0(this.myAsync_0.onSuccess_qlkmfe$(t))}finally{e.unlock()}},Gt.prototype.onResult_m8e4a6$=function(t,e){var n=this.lock_0;try{return n.lock(),this.safeReg_0(this.myAsync_0.onResult_m8e4a6$(t,e))}finally{n.unlock()}},Gt.prototype.onFailure_4m4org$=function(t){var e=this.lock_0;try{return e.lock(),this.safeReg_0(this.myAsync_0.onFailure_4m4org$(t))}finally{e.unlock()}},Gt.prototype.map_2o04qz$=function(t){var e=this.lock_0;try{return e.lock(),At().map_wnedw7$(this,t,new Gt)}finally{e.unlock()}},Gt.prototype.flatMap_sqztdv$=function(t){var e=this.lock_0;try{return e.lock(),At().select_vkqda3$(this,t,new Gt)}finally{e.unlock()}},Ht.prototype.doRemove=function(){var t=this.this$ThreadSafeAsync.lock_0;this.closure$r;try{t.lock(),this.closure$r.remove()}finally{t.unlock()}},Ht.$metadata$={kind:c,interfaces:[s]},Gt.prototype.safeReg_0=function(t){return new Ht(this,t)},Gt.prototype.success_11rb$=function(t){var e=this.lock_0;try{e.lock(),this.myAsync_0.success_11rb$(t)}finally{e.unlock()}},Gt.prototype.failure_tcv7n7$=function(t){var e=this.lock_0;try{e.lock(),this.myAsync_0.failure_tcv7n7$(t)}finally{e.unlock()}},Gt.$metadata$={kind:c,simpleName:"ThreadSafeAsync",interfaces:[Mt]},Object.defineProperty(Yt.prototype,"throwables",{configurable:!0,get:function(){return this.myThrowables_0}}),Yt.$metadata$={kind:c,simpleName:"ThrowableCollectionException",interfaces:[k]},Kt.prototype.removeFromParent_j88a3b$=function(t){var e;null!=(e=t.parent)&&e.children().remove_11rb$(t)},Kt.prototype.isNonCompositeChild_gv3x1o$=function(t){if(null==t.parent)return!1;if(null!=t.nextSibling())return!1;if(null!=t.prevSibling())return!1;var e=f(t.parent).children();return 1!==e.size||e.get_za3lpa$(0)!==t},Kt.prototype.nextSibling_j88a3b$=function(t){var e;if(null==(e=t.parent))return null;var n=e,i=n.children().indexOf_11rb$(t);return-1===i?null:(i+1|0)0?n.children().get_za3lpa$(i-1|0):null},Kt.prototype.firstLeaf_gv3x1o$=function(t){var e;if(null==(e=t.firstChild()))return t;var n=e;return this.firstLeaf_gv3x1o$(n)},Kt.prototype.lastLeaf_gv3x1o$=function(t){var e;if(null==(e=t.lastChild()))return t;var n=e;return this.lastLeaf_gv3x1o$(n)},Kt.prototype.nextLeaf_gv3x1o$=function(t){return this.nextLeaf_yd3t6i$(t,null)},Kt.prototype.nextLeaf_yd3t6i$=function(t,e){for(var n=t;;){var i=n.nextSibling();if(null!=i)return this.firstLeaf_gv3x1o$(i);if(this.isNonCompositeChild_gv3x1o$(n))return null;var r=n.parent;if(r===e)return null;n=f(r)}},Kt.prototype.prevLeaf_gv3x1o$=function(t){return this.prevLeaf_yd3t6i$(t,null)},Kt.prototype.prevLeaf_yd3t6i$=function(t,e){for(var n=t;;){var i=n.prevSibling();if(null!=i)return this.lastLeaf_gv3x1o$(i);if(this.isNonCompositeChild_gv3x1o$(n))return null;var r=n.parent;if(r===e)return null;n=f(r)}},Kt.prototype.root_2jhxsk$=function(t){for(var e=t;;){if(null==e.parent)return e;e=f(e.parent)}},Kt.prototype.ancestorsFrom_2jhxsk$=function(t){return this.iterateFrom_0(t,Wt)},Kt.prototype.ancestors_2jhxsk$=function(t){return this.iterate_e5aqdj$(t,Xt)},Kt.prototype.nextLeaves_gv3x1o$=function(t){return this.iterate_e5aqdj$(t,(e=this,function(t){return e.nextLeaf_gv3x1o$(t)}));var e},Kt.prototype.prevLeaves_gv3x1o$=function(t){return this.iterate_e5aqdj$(t,(e=this,function(t){return e.prevLeaf_gv3x1o$(t)}));var e},Kt.prototype.nextNavOrder_gv3x1o$=function(t){return this.iterate_e5aqdj$(t,(e=t,n=this,function(t){return n.nextNavOrder_0(e,t)}));var e,n},Kt.prototype.prevNavOrder_gv3x1o$=function(t){return this.iterate_e5aqdj$(t,(e=t,n=this,function(t){return n.prevNavOrder_0(e,t)}));var e,n},Kt.prototype.nextNavOrder_0=function(t,e){var n=e.nextSibling();if(null!=n)return this.firstLeaf_gv3x1o$(n);if(this.isNonCompositeChild_gv3x1o$(e))return null;var i=e.parent;return this.isDescendant_5jhjy8$(i,t)?this.nextNavOrder_0(t,f(i)):i},Kt.prototype.prevNavOrder_0=function(t,e){var n=e.prevSibling();if(null!=n)return this.lastLeaf_gv3x1o$(n);if(this.isNonCompositeChild_gv3x1o$(e))return null;var i=e.parent;return this.isDescendant_5jhjy8$(i,t)?this.prevNavOrder_0(t,f(i)):i},Kt.prototype.isBefore_yd3t6i$=function(t,e){if(t===e)return!1;var n=this.reverseAncestors_0(t),i=this.reverseAncestors_0(e);if(n.get_za3lpa$(0)!==i.get_za3lpa$(0))throw C("Items are in different trees");for(var r=n.size,o=i.size,a=j.min(r,o),s=1;s0}throw C("One parameter is an ancestor of the other")},Kt.prototype.deltaBetween_b8q44p$=function(t,e){for(var n=t,i=t,r=0;;){if(n===e)return 0|-r;if(i===e)return r;if(r=r+1|0,null==n&&null==i)throw g("Both left and right are null");null!=n&&(n=n.prevSibling()),null!=i&&(i=i.nextSibling())}},Kt.prototype.commonAncestor_pd1sey$=function(t,e){var n,i;if(t===e)return t;if(this.isDescendant_5jhjy8$(t,e))return t;if(this.isDescendant_5jhjy8$(e,t))return e;var r=x(),o=x();for(n=this.ancestorsFrom_2jhxsk$(t).iterator();n.hasNext();){var a=n.next();r.add_11rb$(a)}for(i=this.ancestorsFrom_2jhxsk$(e).iterator();i.hasNext();){var s=i.next();o.add_11rb$(s)}if(r.isEmpty()||o.isEmpty())return null;do{var l=r.removeAt_za3lpa$(r.size-1|0);if(l!==o.removeAt_za3lpa$(o.size-1|0))return l.parent;var u=!r.isEmpty();u&&(u=!o.isEmpty())}while(u);return null},Kt.prototype.getClosestAncestor_hpi6l0$=function(t,e,n){var i;for(i=(e?this.ancestorsFrom_2jhxsk$(t):this.ancestors_2jhxsk$(t)).iterator();i.hasNext();){var r=i.next();if(n(r))return r}return null},Kt.prototype.isDescendant_5jhjy8$=function(t,e){return null!=this.getClosestAncestor_hpi6l0$(e,!0,S.Functions.same_tpy1pm$(t))},Kt.prototype.reverseAncestors_0=function(t){var e=x();return this.collectReverseAncestors_0(t,e),e},Kt.prototype.collectReverseAncestors_0=function(t,e){var n=t.parent;null!=n&&this.collectReverseAncestors_0(n,e),e.add_11rb$(t)},Kt.prototype.toList_qkgd1o$=function(t){var e,n=x();for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(i)}return n},Kt.prototype.isLastChild_ofc81$=function(t){var e,n;if(null==(e=t.parent))return!1;var i=e.children(),r=i.indexOf_11rb$(t);for(n=i.subList_vux9f0$(r+1|0,i.size).iterator();n.hasNext();)if(n.next().visible().get())return!1;return!0},Kt.prototype.isFirstChild_ofc81$=function(t){var e,n;if(null==(e=t.parent))return!1;var i=e.children(),r=i.indexOf_11rb$(t);for(n=i.subList_vux9f0$(0,r).iterator();n.hasNext();)if(n.next().visible().get())return!1;return!0},Kt.prototype.firstFocusable_ghk449$=function(t){return this.firstFocusable_eny5bg$(t,!0)},Kt.prototype.firstFocusable_eny5bg$=function(t,e){var n;for(n=t.children().iterator();n.hasNext();){var i=n.next();if(i.visible().get()){if(!e&&i.focusable().get())return i;var r=this.firstFocusable_ghk449$(i);if(null!=r)return r}}return t.focusable().get()?t:null},Kt.prototype.lastFocusable_ghk449$=function(t){return this.lastFocusable_eny5bg$(t,!0)},Kt.prototype.lastFocusable_eny5bg$=function(t,e){var n,i=t.children();for(n=O(T(i)).iterator();n.hasNext();){var r=n.next(),o=i.get_za3lpa$(r);if(o.visible().get()){if(!e&&o.focusable().get())return o;var a=this.lastFocusable_eny5bg$(o,e);if(null!=a)return a}}return t.focusable().get()?t:null},Kt.prototype.isVisible_vv2w6c$=function(t){return null==this.getClosestAncestor_hpi6l0$(t,!0,Zt)},Kt.prototype.focusableParent_2xdot8$=function(t){return this.focusableParent_ce34rj$(t,!1)},Kt.prototype.focusableParent_ce34rj$=function(t,e){return this.getClosestAncestor_hpi6l0$(t,e,Jt)},Kt.prototype.isFocusable_c3v93w$=function(t){return t.focusable().get()&&this.isVisible_vv2w6c$(t)},Kt.prototype.next_c8h0sn$=function(t,e){var n;for(n=this.nextNavOrder_gv3x1o$(t).iterator();n.hasNext();){var i=n.next();if(e(i))return i}return null},Kt.prototype.prev_c8h0sn$=function(t,e){var n;for(n=this.prevNavOrder_gv3x1o$(t).iterator();n.hasNext();){var i=n.next();if(e(i))return i}return null},Kt.prototype.nextFocusable_l3p44k$=function(t){var e;for(e=this.nextNavOrder_gv3x1o$(t).iterator();e.hasNext();){var n=e.next();if(this.isFocusable_c3v93w$(n))return n}return null},Kt.prototype.prevFocusable_l3p44k$=function(t){var e;for(e=this.prevNavOrder_gv3x1o$(t).iterator();e.hasNext();){var n=e.next();if(this.isFocusable_c3v93w$(n))return n}return null},Kt.prototype.iterate_e5aqdj$=function(t,e){return this.iterateFrom_0(e(t),e)},te.prototype.hasNext=function(){return null!=this.myCurrent_0},te.prototype.next=function(){if(null==this.myCurrent_0)throw N();var t=this.myCurrent_0;return this.myCurrent_0=this.closure$trans(f(t)),t},te.$metadata$={kind:c,interfaces:[P]},Qt.prototype.iterator=function(){return new te(this.closure$trans,this.closure$initial)},Qt.$metadata$={kind:c,interfaces:[A]},Kt.prototype.iterateFrom_0=function(t,e){return new Qt(e,t)},Kt.prototype.allBetween_yd3t6i$=function(t,e){var n=x();return e!==t&&this.includeClosed_0(t,e,n),n},Kt.prototype.includeClosed_0=function(t,e,n){for(var i=t.nextSibling();null!=i;){if(this.includeOpen_0(i,e,n))return;i=i.nextSibling()}if(null==t.parent)throw C("Right bound not found in left's bound hierarchy. to="+e);this.includeClosed_0(f(t.parent),e,n)},Kt.prototype.includeOpen_0=function(t,e,n){var i;if(t===e)return!0;for(i=t.children().iterator();i.hasNext();){var r=i.next();if(this.includeOpen_0(r,e,n))return!0}return n.add_11rb$(t),!1},Kt.prototype.isAbove_k112ux$=function(t,e){return this.ourWithBounds_0.isAbove_k112ux$(t,e)},Kt.prototype.isBelow_k112ux$=function(t,e){return this.ourWithBounds_0.isBelow_k112ux$(t,e)},Kt.prototype.homeElement_mgqo3l$=function(t){return this.ourWithBounds_0.homeElement_mgqo3l$(t)},Kt.prototype.endElement_mgqo3l$=function(t){return this.ourWithBounds_0.endElement_mgqo3l$(t)},Kt.prototype.upperFocusable_8i9rgd$=function(t,e){return this.ourWithBounds_0.upperFocusable_8i9rgd$(t,e)},Kt.prototype.lowerFocusable_8i9rgd$=function(t,e){return this.ourWithBounds_0.lowerFocusable_8i9rgd$(t,e)},Kt.$metadata$={kind:d,simpleName:"Composites",interfaces:[]};var ee=null;function ne(){return null===ee&&new Kt,ee}function ie(t){this.myThreshold_0=t}function re(t,e){this.$outer=t,this.myInitial_0=e,this.myFirstFocusableAbove_0=null,this.myFirstFocusableAbove_0=this.firstFocusableAbove_0(this.myInitial_0)}function oe(t,e){this.$outer=t,this.myInitial_0=e,this.myFirstFocusableBelow_0=null,this.myFirstFocusableBelow_0=this.firstFocusableBelow_0(this.myInitial_0)}function ae(){}function se(){Y.call(this),this.myListeners_xjxep$_0=null}function le(t){this.closure$item=t}function ue(t,e){this.closure$iterator=t,this.this$AbstractObservableSet=e,this.myCanRemove_0=!1,this.myLastReturned_0=null}function ce(t){this.closure$item=t}function pe(t){this.closure$handler=t,B.call(this)}function he(){se.call(this),this.mySet_fvkh6y$_0=null}function _e(){}function fe(){}function de(t){this.closure$onEvent=t}function me(){this.myListeners_0=new w}function ye(t){this.closure$event=t}function $e(t){J.call(this),this.myValue_uehepj$_0=t,this.myHandlers_e7gyn7$_0=null}function ve(t){this.closure$event=t}function ge(t){this.this$BaseDerivedProperty=t,w.call(this)}function be(t,e){$e.call(this,t);var n,i=Q(e.length);n=i.length-1|0;for(var r=0;r<=n;r++)i[r]=e[r];this.myDeps_nbedfd$_0=i,this.myRegistrations_3svoxv$_0=null}function we(t){this.this$DerivedProperty=t}function xe(){fn=this,this.TRUE=this.constant_mh5how$(!0),this.FALSE=this.constant_mh5how$(!1)}function ke(t){return null==t?null:!t}function Ee(t){return null!=t}function Ce(t){return null==t}function Se(t,e,n,i){this.closure$string=t,this.closure$prefix=e,be.call(this,n,i)}function Te(t,e,n){this.closure$prop=t,be.call(this,e,n)}function Oe(t,e,n,i){this.closure$op1=t,this.closure$op2=e,be.call(this,n,i)}function Ne(t,e,n,i){this.closure$op1=t,this.closure$op2=e,be.call(this,n,i)}function Pe(t,e,n,i){this.closure$p1=t,this.closure$p2=e,be.call(this,n,i)}function Ae(t,e,n){this.closure$source=t,this.closure$nullValue=e,this.closure$fun=n}function je(t,e,n,i){this.closure$source=t,this.closure$fun=e,this.closure$calc=n,$e.call(this,i),this.myTargetProperty_0=null,this.mySourceRegistration_0=null,this.myTargetRegistration_0=null}function Le(t){this.this$=t}function Re(t,e,n,i){this.this$=t,this.closure$source=e,this.closure$fun=n,this.closure$targetHandler=i}function Ie(t,e){this.closure$source=t,this.closure$fun=e}function ze(t,e,n){this.closure$source=t,this.closure$fun=e,this.closure$calc=n,$e.call(this,n.get()),this.myTargetProperty_0=null,this.mySourceRegistration_0=null,this.myTargetRegistration_0=null}function De(t){this.this$MyProperty=t}function Me(t,e,n,i){this.this$MyProperty=t,this.closure$source=e,this.closure$fun=n,this.closure$targetHandler=i}function Be(t,e){this.closure$prop=t,this.closure$selector=e}function Ue(t,e,n,i){this.closure$esReg=t,this.closure$prop=e,this.closure$selector=n,this.closure$handler=i}function Fe(t){this.closure$update=t}function qe(t,e){this.closure$propReg=t,this.closure$esReg=e,s.call(this)}function Ge(t,e,n,i){this.closure$p1=t,this.closure$p2=e,be.call(this,n,i)}function He(t,e,n,i){this.closure$prop=t,this.closure$f=e,be.call(this,n,i)}function Ye(t,e,n){this.closure$prop=t,this.closure$sToT=e,this.closure$tToS=n}function Ve(t,e){this.closure$sToT=t,this.closure$handler=e}function Ke(t){this.closure$value=t,J.call(this)}function We(t,e,n){this.closure$collection=t,mn.call(this,e,n)}function Xe(t,e,n){this.closure$collection=t,mn.call(this,e,n)}function Ze(t,e){this.closure$collection=t,$e.call(this,e),this.myCollectionRegistration_0=null}function Je(t){this.this$=t}function Qe(t){this.closure$r=t,B.call(this)}function tn(t,e,n,i,r){this.closure$cond=t,this.closure$ifTrue=e,this.closure$ifFalse=n,be.call(this,i,r)}function en(t,e,n){this.closure$cond=t,this.closure$ifTrue=e,this.closure$ifFalse=n}function nn(t,e,n,i){this.closure$prop=t,this.closure$ifNull=e,be.call(this,n,i)}function rn(t,e,n){this.closure$values=t,be.call(this,e,n)}function on(t,e,n,i){this.closure$source=t,this.closure$validator=e,be.call(this,n,i)}function an(t,e){this.closure$source=t,this.closure$validator=e,be.call(this,null,[t]),this.myLastValid_0=null}function sn(t,e,n,i){this.closure$p=t,this.closure$nullValue=e,be.call(this,n,i)}function ln(t,e){this.closure$read=t,this.closure$write=e}function un(t){this.closure$props=t}function cn(t){this.closure$coll=t}function pn(t,e){this.closure$coll=t,this.closure$handler=e,B.call(this)}function hn(t,e,n){this.closure$props=t,be.call(this,e,n)}function _n(t,e,n){this.closure$props=t,be.call(this,e,n)}ie.prototype.isAbove_k112ux$=function(t,e){var n=f(t).bounds,i=f(e).bounds;return(n.origin.y+n.dimension.y-this.myThreshold_0|0)<=i.origin.y},ie.prototype.isBelow_k112ux$=function(t,e){return this.isAbove_k112ux$(e,t)},ie.prototype.homeElement_mgqo3l$=function(t){for(var e=t;;){var n=ne().prevFocusable_l3p44k$(e);if(null==n||this.isAbove_k112ux$(n,t))return e;e=n}},ie.prototype.endElement_mgqo3l$=function(t){for(var e=t;;){var n=ne().nextFocusable_l3p44k$(e);if(null==n||this.isBelow_k112ux$(n,t))return e;e=n}},ie.prototype.upperFocusables_mgqo3l$=function(t){var e,n=new re(this,t);return ne().iterate_e5aqdj$(t,(e=n,function(t){return e.apply_11rb$(t)}))},ie.prototype.lowerFocusables_mgqo3l$=function(t){var e,n=new oe(this,t);return ne().iterate_e5aqdj$(t,(e=n,function(t){return e.apply_11rb$(t)}))},ie.prototype.upperFocusable_8i9rgd$=function(t,e){for(var n=ne().prevFocusable_l3p44k$(t),i=null;null!=n&&(null==i||!this.isAbove_k112ux$(n,i));)null!=i?this.distanceTo_nr7zox$(i,e)>this.distanceTo_nr7zox$(n,e)&&(i=n):this.isAbove_k112ux$(n,t)&&(i=n),n=ne().prevFocusable_l3p44k$(n);return i},ie.prototype.lowerFocusable_8i9rgd$=function(t,e){for(var n=ne().nextFocusable_l3p44k$(t),i=null;null!=n&&(null==i||!this.isBelow_k112ux$(n,i));)null!=i?this.distanceTo_nr7zox$(i,e)>this.distanceTo_nr7zox$(n,e)&&(i=n):this.isBelow_k112ux$(n,t)&&(i=n),n=ne().nextFocusable_l3p44k$(n);return i},ie.prototype.distanceTo_nr7zox$=function(t,e){var n=t.bounds;return n.distance_119tl4$(new L(e,n.origin.y))},re.prototype.firstFocusableAbove_0=function(t){for(var e=ne().prevFocusable_l3p44k$(t);null!=e&&!this.$outer.isAbove_k112ux$(e,t);)e=ne().prevFocusable_l3p44k$(e);return e},re.prototype.apply_11rb$=function(t){if(t===this.myInitial_0)return this.myFirstFocusableAbove_0;var e=ne().prevFocusable_l3p44k$(t);return null==e||this.$outer.isAbove_k112ux$(e,this.myFirstFocusableAbove_0)?null:e},re.$metadata$={kind:c,simpleName:"NextUpperFocusable",interfaces:[R]},oe.prototype.firstFocusableBelow_0=function(t){for(var e=ne().nextFocusable_l3p44k$(t);null!=e&&!this.$outer.isBelow_k112ux$(e,t);)e=ne().nextFocusable_l3p44k$(e);return e},oe.prototype.apply_11rb$=function(t){if(t===this.myInitial_0)return this.myFirstFocusableBelow_0;var e=ne().nextFocusable_l3p44k$(t);return null==e||this.$outer.isBelow_k112ux$(e,this.myFirstFocusableBelow_0)?null:e},oe.$metadata$={kind:c,simpleName:"NextLowerFocusable",interfaces:[R]},ie.$metadata$={kind:c,simpleName:"CompositesWithBounds",interfaces:[]},ae.$metadata$={kind:r,simpleName:"HasParent",interfaces:[]},se.prototype.addListener_n5no9j$=function(t){return null==this.myListeners_xjxep$_0&&(this.myListeners_xjxep$_0=new w),f(this.myListeners_xjxep$_0).add_11rb$(t)},se.prototype.add_11rb$=function(t){if(this.contains_11rb$(t))return!1;this.doBeforeAdd_zcqj2i$_0(t);var e=!1;try{this.onItemAdd_11rb$(t),e=this.doAdd_11rb$(t)}finally{this.doAfterAdd_yxsu9c$_0(t,e)}return e},se.prototype.doBeforeAdd_zcqj2i$_0=function(t){this.checkAdd_11rb$(t),this.beforeItemAdded_11rb$(t)},le.prototype.call_11rb$=function(t){t.onItemAdded_u8tacu$(new G(null,this.closure$item,-1,q.ADD))},le.$metadata$={kind:c,interfaces:[b]},se.prototype.doAfterAdd_yxsu9c$_0=function(t,e){try{e&&null!=this.myListeners_xjxep$_0&&f(this.myListeners_xjxep$_0).fire_kucmxw$(new le(t))}finally{this.afterItemAdded_iuyhfk$(t,e)}},se.prototype.remove_11rb$=function(t){if(!this.contains_11rb$(t))return!1;this.doBeforeRemove_u15i8b$_0(t);var e=!1;try{this.onItemRemove_11rb$(t),e=this.doRemove_11rb$(t)}finally{this.doAfterRemove_xembz3$_0(t,e)}return e},ue.prototype.hasNext=function(){return this.closure$iterator.hasNext()},ue.prototype.next=function(){return this.myLastReturned_0=this.closure$iterator.next(),this.myCanRemove_0=!0,f(this.myLastReturned_0)},ue.prototype.remove=function(){if(!this.myCanRemove_0)throw U();this.myCanRemove_0=!1,this.this$AbstractObservableSet.doBeforeRemove_u15i8b$_0(f(this.myLastReturned_0));var t=!1;try{this.closure$iterator.remove(),t=!0}finally{this.this$AbstractObservableSet.doAfterRemove_xembz3$_0(f(this.myLastReturned_0),t)}},ue.$metadata$={kind:c,interfaces:[H]},se.prototype.iterator=function(){return 0===this.size?V().iterator():new ue(this.actualIterator,this)},se.prototype.doBeforeRemove_u15i8b$_0=function(t){this.checkRemove_11rb$(t),this.beforeItemRemoved_11rb$(t)},ce.prototype.call_11rb$=function(t){t.onItemRemoved_u8tacu$(new G(this.closure$item,null,-1,q.REMOVE))},ce.$metadata$={kind:c,interfaces:[b]},se.prototype.doAfterRemove_xembz3$_0=function(t,e){try{e&&null!=this.myListeners_xjxep$_0&&f(this.myListeners_xjxep$_0).fire_kucmxw$(new ce(t))}finally{this.afterItemRemoved_iuyhfk$(t,e)}},se.prototype.checkAdd_11rb$=function(t){},se.prototype.checkRemove_11rb$=function(t){},se.prototype.beforeItemAdded_11rb$=function(t){},se.prototype.onItemAdd_11rb$=function(t){},se.prototype.afterItemAdded_iuyhfk$=function(t,e){},se.prototype.beforeItemRemoved_11rb$=function(t){},se.prototype.onItemRemove_11rb$=function(t){},se.prototype.afterItemRemoved_iuyhfk$=function(t,e){},pe.prototype.onItemAdded_u8tacu$=function(t){this.closure$handler.onEvent_11rb$(t)},pe.prototype.onItemRemoved_u8tacu$=function(t){this.closure$handler.onEvent_11rb$(t)},pe.$metadata$={kind:c,interfaces:[B]},se.prototype.addHandler_gxwwpc$=function(t){return this.addListener_n5no9j$(new pe(t))},se.$metadata$={kind:c,simpleName:"AbstractObservableSet",interfaces:[_e,Y]},Object.defineProperty(he.prototype,"size",{configurable:!0,get:function(){var t,e;return null!=(e=null!=(t=this.mySet_fvkh6y$_0)?t.size:null)?e:0}}),Object.defineProperty(he.prototype,"actualIterator",{configurable:!0,get:function(){return f(this.mySet_fvkh6y$_0).iterator()}}),he.prototype.contains_11rb$=function(t){var e,n;return null!=(n=null!=(e=this.mySet_fvkh6y$_0)?e.contains_11rb$(t):null)&&n},he.prototype.doAdd_11rb$=function(t){return this.ensureSetInitialized_8c11ng$_0(),f(this.mySet_fvkh6y$_0).add_11rb$(t)},he.prototype.doRemove_11rb$=function(t){return f(this.mySet_fvkh6y$_0).remove_11rb$(t)},he.prototype.ensureSetInitialized_8c11ng$_0=function(){null==this.mySet_fvkh6y$_0&&(this.mySet_fvkh6y$_0=K(1))},he.$metadata$={kind:c,simpleName:"ObservableHashSet",interfaces:[se]},_e.$metadata$={kind:r,simpleName:"ObservableSet",interfaces:[I,W]},fe.$metadata$={kind:r,simpleName:"EventHandler",interfaces:[]},de.prototype.onEvent_11rb$=function(t){this.closure$onEvent(t)},de.$metadata$={kind:c,interfaces:[fe]},ye.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},ye.$metadata$={kind:c,interfaces:[b]},me.prototype.fire_11rb$=function(t){this.myListeners_0.fire_kucmxw$(new ye(t))},me.prototype.addHandler_gxwwpc$=function(t){return this.myListeners_0.add_11rb$(t)},me.$metadata$={kind:c,simpleName:"SimpleEventSource",interfaces:[Z]},$e.prototype.get=function(){return null!=this.myHandlers_e7gyn7$_0?this.myValue_uehepj$_0:this.doGet()},ve.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},ve.$metadata$={kind:c,interfaces:[b]},$e.prototype.somethingChanged=function(){var t=this.doGet();if(!F(this.myValue_uehepj$_0,t)){var e=new D(this.myValue_uehepj$_0,t);this.myValue_uehepj$_0=t,null!=this.myHandlers_e7gyn7$_0&&f(this.myHandlers_e7gyn7$_0).fire_kucmxw$(new ve(e))}},ge.prototype.beforeFirstAdded=function(){this.this$BaseDerivedProperty.myValue_uehepj$_0=this.this$BaseDerivedProperty.doGet(),this.this$BaseDerivedProperty.doAddListeners()},ge.prototype.afterLastRemoved=function(){this.this$BaseDerivedProperty.doRemoveListeners(),this.this$BaseDerivedProperty.myHandlers_e7gyn7$_0=null},ge.$metadata$={kind:c,interfaces:[w]},$e.prototype.addHandler_gxwwpc$=function(t){return null==this.myHandlers_e7gyn7$_0&&(this.myHandlers_e7gyn7$_0=new ge(this)),f(this.myHandlers_e7gyn7$_0).add_11rb$(t)},$e.$metadata$={kind:c,simpleName:"BaseDerivedProperty",interfaces:[J]},be.prototype.doAddListeners=function(){var t,e=Q(this.myDeps_nbedfd$_0.length);t=e.length-1|0;for(var n=0;n<=t;n++)e[n]=this.register_hhwf17$_0(this.myDeps_nbedfd$_0[n]);this.myRegistrations_3svoxv$_0=e},we.prototype.onEvent_11rb$=function(t){this.this$DerivedProperty.somethingChanged()},we.$metadata$={kind:c,interfaces:[fe]},be.prototype.register_hhwf17$_0=function(t){return t.addHandler_gxwwpc$(new we(this))},be.prototype.doRemoveListeners=function(){var t,e;for(t=f(this.myRegistrations_3svoxv$_0),e=0;e!==t.length;++e)t[e].remove();this.myRegistrations_3svoxv$_0=null},be.$metadata$={kind:c,simpleName:"DerivedProperty",interfaces:[$e]},xe.prototype.not_scsqf1$=function(t){return this.map_ohntev$(t,ke)},xe.prototype.notNull_pnjvn9$=function(t){return this.map_ohntev$(t,Ee)},xe.prototype.isNull_pnjvn9$=function(t){return this.map_ohntev$(t,Ce)},Object.defineProperty(Se.prototype,"propExpr",{configurable:!0,get:function(){return"startsWith("+this.closure$string.propExpr+", "+this.closure$prefix.propExpr+")"}}),Se.prototype.doGet=function(){return null!=this.closure$string.get()&&null!=this.closure$prefix.get()&&tt(f(this.closure$string.get()),f(this.closure$prefix.get()))},Se.$metadata$={kind:c,interfaces:[be]},xe.prototype.startsWith_258nik$=function(t,e){return new Se(t,e,!1,[t,e])},Object.defineProperty(Te.prototype,"propExpr",{configurable:!0,get:function(){return"isEmptyString("+this.closure$prop.propExpr+")"}}),Te.prototype.doGet=function(){var t=this.closure$prop.get(),e=null==t;return e||(e=0===t.length),e},Te.$metadata$={kind:c,interfaces:[be]},xe.prototype.isNullOrEmpty_zi86m3$=function(t){return new Te(t,!1,[t])},Object.defineProperty(Oe.prototype,"propExpr",{configurable:!0,get:function(){return"("+this.closure$op1.propExpr+" && "+this.closure$op2.propExpr+")"}}),Oe.prototype.doGet=function(){return dn().and_0(this.closure$op1.get(),this.closure$op2.get())},Oe.$metadata$={kind:c,interfaces:[be]},xe.prototype.and_us87nw$=function(t,e){return new Oe(t,e,null,[t,e])},xe.prototype.and_0=function(t,e){return null==t?this.andWithNull_0(e):null==e?this.andWithNull_0(t):t&&e},xe.prototype.andWithNull_0=function(t){return!(null!=t&&!t)&&null},Object.defineProperty(Ne.prototype,"propExpr",{configurable:!0,get:function(){return"("+this.closure$op1.propExpr+" || "+this.closure$op2.propExpr+")"}}),Ne.prototype.doGet=function(){return dn().or_0(this.closure$op1.get(),this.closure$op2.get())},Ne.$metadata$={kind:c,interfaces:[be]},xe.prototype.or_us87nw$=function(t,e){return new Ne(t,e,null,[t,e])},xe.prototype.or_0=function(t,e){return null==t?this.orWithNull_0(e):null==e?this.orWithNull_0(t):t||e},xe.prototype.orWithNull_0=function(t){return!(null==t||!t)||null},Object.defineProperty(Pe.prototype,"propExpr",{configurable:!0,get:function(){return"("+this.closure$p1.propExpr+" + "+this.closure$p2.propExpr+")"}}),Pe.prototype.doGet=function(){return null==this.closure$p1.get()||null==this.closure$p2.get()?null:f(this.closure$p1.get())+f(this.closure$p2.get())|0},Pe.$metadata$={kind:c,interfaces:[be]},xe.prototype.add_qmazvq$=function(t,e){return new Pe(t,e,null,[t,e])},xe.prototype.select_uirx34$=function(t,e){return this.select_phvhtn$(t,e,null)},Ae.prototype.get=function(){var t;if(null==(t=this.closure$source.get()))return this.closure$nullValue;var e=t;return this.closure$fun(e).get()},Ae.$metadata$={kind:c,interfaces:[et]},Object.defineProperty(je.prototype,"propExpr",{configurable:!0,get:function(){return"select("+this.closure$source.propExpr+", "+E(this.closure$fun)+")"}}),Le.prototype.onEvent_11rb$=function(t){this.this$.somethingChanged()},Le.$metadata$={kind:c,interfaces:[fe]},Re.prototype.onEvent_11rb$=function(t){null!=this.this$.myTargetProperty_0&&f(this.this$.myTargetRegistration_0).remove();var e=this.closure$source.get();this.this$.myTargetProperty_0=null!=e?this.closure$fun(e):null,null!=this.this$.myTargetProperty_0&&(this.this$.myTargetRegistration_0=f(this.this$.myTargetProperty_0).addHandler_gxwwpc$(this.closure$targetHandler)),this.this$.somethingChanged()},Re.$metadata$={kind:c,interfaces:[fe]},je.prototype.doAddListeners=function(){this.myTargetProperty_0=null==this.closure$source.get()?null:this.closure$fun(this.closure$source.get());var t=new Le(this),e=new Re(this,this.closure$source,this.closure$fun,t);this.mySourceRegistration_0=this.closure$source.addHandler_gxwwpc$(e),null!=this.myTargetProperty_0&&(this.myTargetRegistration_0=f(this.myTargetProperty_0).addHandler_gxwwpc$(t))},je.prototype.doRemoveListeners=function(){null!=this.myTargetProperty_0&&f(this.myTargetRegistration_0).remove(),f(this.mySourceRegistration_0).remove()},je.prototype.doGet=function(){return this.closure$calc.get()},je.$metadata$={kind:c,interfaces:[$e]},xe.prototype.select_phvhtn$=function(t,e,n){return new je(t,e,new Ae(t,n,e),null)},Ie.prototype.get=function(){var t;if(null==(t=this.closure$source.get()))return null;var e=t;return this.closure$fun(e).get()},Ie.$metadata$={kind:c,interfaces:[et]},Object.defineProperty(ze.prototype,"propExpr",{configurable:!0,get:function(){return"select("+this.closure$source.propExpr+", "+E(this.closure$fun)+")"}}),De.prototype.onEvent_11rb$=function(t){this.this$MyProperty.somethingChanged()},De.$metadata$={kind:c,interfaces:[fe]},Me.prototype.onEvent_11rb$=function(t){null!=this.this$MyProperty.myTargetProperty_0&&f(this.this$MyProperty.myTargetRegistration_0).remove();var e=this.closure$source.get();this.this$MyProperty.myTargetProperty_0=null!=e?this.closure$fun(e):null,null!=this.this$MyProperty.myTargetProperty_0&&(this.this$MyProperty.myTargetRegistration_0=f(this.this$MyProperty.myTargetProperty_0).addHandler_gxwwpc$(this.closure$targetHandler)),this.this$MyProperty.somethingChanged()},Me.$metadata$={kind:c,interfaces:[fe]},ze.prototype.doAddListeners=function(){this.myTargetProperty_0=null==this.closure$source.get()?null:this.closure$fun(this.closure$source.get());var t=new De(this),e=new Me(this,this.closure$source,this.closure$fun,t);this.mySourceRegistration_0=this.closure$source.addHandler_gxwwpc$(e),null!=this.myTargetProperty_0&&(this.myTargetRegistration_0=f(this.myTargetProperty_0).addHandler_gxwwpc$(t))},ze.prototype.doRemoveListeners=function(){null!=this.myTargetProperty_0&&f(this.myTargetRegistration_0).remove(),f(this.mySourceRegistration_0).remove()},ze.prototype.doGet=function(){return this.closure$calc.get()},ze.prototype.set_11rb$=function(t){null!=this.myTargetProperty_0&&f(this.myTargetProperty_0).set_11rb$(t)},ze.$metadata$={kind:c,simpleName:"MyProperty",interfaces:[M,$e]},xe.prototype.selectRw_dnjkuo$=function(t,e){return new ze(t,e,new Ie(t,e))},Ue.prototype.run=function(){this.closure$esReg.get().remove(),null!=this.closure$prop.get()?this.closure$esReg.set_11rb$(this.closure$selector(this.closure$prop.get()).addHandler_gxwwpc$(this.closure$handler)):this.closure$esReg.set_11rb$(s.Companion.EMPTY)},Ue.$metadata$={kind:c,interfaces:[X]},Fe.prototype.onEvent_11rb$=function(t){this.closure$update.run()},Fe.$metadata$={kind:c,interfaces:[fe]},qe.prototype.doRemove=function(){this.closure$propReg.remove(),this.closure$esReg.get().remove()},qe.$metadata$={kind:c,interfaces:[s]},Be.prototype.addHandler_gxwwpc$=function(t){var e=new o(s.Companion.EMPTY),n=new Ue(e,this.closure$prop,this.closure$selector,t);return n.run(),new qe(this.closure$prop.addHandler_gxwwpc$(new Fe(n)),e)},Be.$metadata$={kind:c,interfaces:[Z]},xe.prototype.selectEvent_mncfl5$=function(t,e){return new Be(t,e)},xe.prototype.same_xyb9ob$=function(t,e){return this.map_ohntev$(t,(n=e,function(t){return t===n}));var n},xe.prototype.equals_xyb9ob$=function(t,e){return this.map_ohntev$(t,(n=e,function(t){return F(t,n)}));var n},Object.defineProperty(Ge.prototype,"propExpr",{configurable:!0,get:function(){return"equals("+this.closure$p1.propExpr+", "+this.closure$p2.propExpr+")"}}),Ge.prototype.doGet=function(){return F(this.closure$p1.get(),this.closure$p2.get())},Ge.$metadata$={kind:c,interfaces:[be]},xe.prototype.equals_r3q8zu$=function(t,e){return new Ge(t,e,!1,[t,e])},xe.prototype.notEquals_xyb9ob$=function(t,e){return this.not_scsqf1$(this.equals_xyb9ob$(t,e))},xe.prototype.notEquals_r3q8zu$=function(t,e){return this.not_scsqf1$(this.equals_r3q8zu$(t,e))},Object.defineProperty(He.prototype,"propExpr",{configurable:!0,get:function(){return"transform("+this.closure$prop.propExpr+", "+E(this.closure$f)+")"}}),He.prototype.doGet=function(){return this.closure$f(this.closure$prop.get())},He.$metadata$={kind:c,interfaces:[be]},xe.prototype.map_ohntev$=function(t,e){return new He(t,e,e(t.get()),[t])},Object.defineProperty(Ye.prototype,"propExpr",{configurable:!0,get:function(){return"transform("+this.closure$prop.propExpr+", "+E(this.closure$sToT)+", "+E(this.closure$tToS)+")"}}),Ye.prototype.get=function(){return this.closure$sToT(this.closure$prop.get())},Ve.prototype.onEvent_11rb$=function(t){var e=this.closure$sToT(t.oldValue),n=this.closure$sToT(t.newValue);F(e,n)||this.closure$handler.onEvent_11rb$(new D(e,n))},Ve.$metadata$={kind:c,interfaces:[fe]},Ye.prototype.addHandler_gxwwpc$=function(t){return this.closure$prop.addHandler_gxwwpc$(new Ve(this.closure$sToT,t))},Ye.prototype.set_11rb$=function(t){this.closure$prop.set_11rb$(this.closure$tToS(t))},Ye.$metadata$={kind:c,simpleName:"TransformedProperty",interfaces:[M]},xe.prototype.map_6va22f$=function(t,e,n){return new Ye(t,e,n)},Object.defineProperty(Ke.prototype,"propExpr",{configurable:!0,get:function(){return"constant("+this.closure$value+")"}}),Ke.prototype.get=function(){return this.closure$value},Ke.prototype.addHandler_gxwwpc$=function(t){return s.Companion.EMPTY},Ke.$metadata$={kind:c,interfaces:[J]},xe.prototype.constant_mh5how$=function(t){return new Ke(t)},Object.defineProperty(We.prototype,"propExpr",{configurable:!0,get:function(){return"isEmpty("+this.closure$collection+")"}}),We.prototype.doGet=function(){return this.closure$collection.isEmpty()},We.$metadata$={kind:c,interfaces:[mn]},xe.prototype.isEmpty_4gck1s$=function(t){return new We(t,t,t.isEmpty())},Object.defineProperty(Xe.prototype,"propExpr",{configurable:!0,get:function(){return"size("+this.closure$collection+")"}}),Xe.prototype.doGet=function(){return this.closure$collection.size},Xe.$metadata$={kind:c,interfaces:[mn]},xe.prototype.size_4gck1s$=function(t){return new Xe(t,t,t.size)},xe.prototype.notEmpty_4gck1s$=function(t){var n;return this.not_scsqf1$(e.isType(n=this.empty_4gck1s$(t),nt)?n:u())},Object.defineProperty(Ze.prototype,"propExpr",{configurable:!0,get:function(){return"empty("+this.closure$collection+")"}}),Je.prototype.run=function(){this.this$.somethingChanged()},Je.$metadata$={kind:c,interfaces:[X]},Ze.prototype.doAddListeners=function(){this.myCollectionRegistration_0=this.closure$collection.addListener_n5no9j$(dn().simpleAdapter_0(new Je(this)))},Ze.prototype.doRemoveListeners=function(){f(this.myCollectionRegistration_0).remove()},Ze.prototype.doGet=function(){return this.closure$collection.isEmpty()},Ze.$metadata$={kind:c,interfaces:[$e]},xe.prototype.empty_4gck1s$=function(t){return new Ze(t,t.isEmpty())},Qe.prototype.onItemAdded_u8tacu$=function(t){this.closure$r.run()},Qe.prototype.onItemRemoved_u8tacu$=function(t){this.closure$r.run()},Qe.$metadata$={kind:c,interfaces:[B]},xe.prototype.simpleAdapter_0=function(t){return new Qe(t)},Object.defineProperty(tn.prototype,"propExpr",{configurable:!0,get:function(){return"if("+this.closure$cond.propExpr+", "+this.closure$ifTrue.propExpr+", "+this.closure$ifFalse.propExpr+")"}}),tn.prototype.doGet=function(){return this.closure$cond.get()?this.closure$ifTrue.get():this.closure$ifFalse.get()},tn.$metadata$={kind:c,interfaces:[be]},xe.prototype.ifProp_h6sj4s$=function(t,e,n){return new tn(t,e,n,null,[t,e,n])},xe.prototype.ifProp_2ercqg$=function(t,e,n){return this.ifProp_h6sj4s$(t,this.constant_mh5how$(e),this.constant_mh5how$(n))},en.prototype.set_11rb$=function(t){t?this.closure$cond.set_11rb$(this.closure$ifTrue):this.closure$cond.set_11rb$(this.closure$ifFalse)},en.$metadata$={kind:c,interfaces:[z]},xe.prototype.ifProp_g6gwfc$=function(t,e,n){return new en(t,e,n)},nn.prototype.doGet=function(){return null==this.closure$prop.get()?this.closure$ifNull:this.closure$prop.get()},nn.$metadata$={kind:c,interfaces:[be]},xe.prototype.withDefaultValue_xyb9ob$=function(t,e){return new nn(t,e,e,[t])},Object.defineProperty(rn.prototype,"propExpr",{configurable:!0,get:function(){var t,e,n=it();n.append_pdl1vj$("firstNotNull(");var i=!0;for(t=this.closure$values,e=0;e!==t.length;++e){var r=t[e];i?i=!1:n.append_pdl1vj$(", "),n.append_pdl1vj$(r.propExpr)}return n.append_pdl1vj$(")"),n.toString()}}),rn.prototype.doGet=function(){var t,e;for(t=this.closure$values,e=0;e!==t.length;++e){var n=t[e];if(null!=n.get())return n.get()}return null},rn.$metadata$={kind:c,interfaces:[be]},xe.prototype.firstNotNull_qrqmoy$=function(t){return new rn(t,null,t.slice())},Object.defineProperty(on.prototype,"propExpr",{configurable:!0,get:function(){return"isValid("+this.closure$source.propExpr+", "+E(this.closure$validator)+")"}}),on.prototype.doGet=function(){return this.closure$validator(this.closure$source.get())},on.$metadata$={kind:c,interfaces:[be]},xe.prototype.isPropertyValid_ngb39s$=function(t,e){return new on(t,e,!1,[t])},Object.defineProperty(an.prototype,"propExpr",{configurable:!0,get:function(){return"validated("+this.closure$source.propExpr+", "+E(this.closure$validator)+")"}}),an.prototype.doGet=function(){var t=this.closure$source.get();return this.closure$validator(t)&&(this.myLastValid_0=t),this.myLastValid_0},an.prototype.set_11rb$=function(t){this.closure$validator(t)&&this.closure$source.set_11rb$(t)},an.$metadata$={kind:c,simpleName:"ValidatedProperty",interfaces:[M,be]},xe.prototype.validatedProperty_nzo3ll$=function(t,e){return new an(t,e)},sn.prototype.doGet=function(){var t=this.closure$p.get();return null!=t?""+E(t):this.closure$nullValue},sn.$metadata$={kind:c,interfaces:[be]},xe.prototype.toStringOf_ysc3eg$=function(t,e){return void 0===e&&(e="null"),new sn(t,e,e,[t])},Object.defineProperty(ln.prototype,"propExpr",{configurable:!0,get:function(){return this.closure$read.propExpr}}),ln.prototype.get=function(){return this.closure$read.get()},ln.prototype.addHandler_gxwwpc$=function(t){return this.closure$read.addHandler_gxwwpc$(t)},ln.prototype.set_11rb$=function(t){this.closure$write.set_11rb$(t)},ln.$metadata$={kind:c,interfaces:[M]},xe.prototype.property_2ov6i0$=function(t,e){return new ln(t,e)},un.prototype.set_11rb$=function(t){var e,n;for(e=this.closure$props,n=0;n!==e.length;++n)e[n].set_11rb$(t)},un.$metadata$={kind:c,interfaces:[z]},xe.prototype.compose_qzq9dc$=function(t){return new un(t)},Object.defineProperty(cn.prototype,"propExpr",{configurable:!0,get:function(){return"singleItemCollection("+this.closure$coll+")"}}),cn.prototype.get=function(){return this.closure$coll.isEmpty()?null:this.closure$coll.iterator().next()},cn.prototype.set_11rb$=function(t){var e=this.get();F(e,t)||(this.closure$coll.clear(),null!=t&&this.closure$coll.add_11rb$(t))},pn.prototype.onItemAdded_u8tacu$=function(t){if(1!==this.closure$coll.size)throw U();this.closure$handler.onEvent_11rb$(new D(null,t.newItem))},pn.prototype.onItemSet_u8tacu$=function(t){if(0!==t.index)throw U();this.closure$handler.onEvent_11rb$(new D(t.oldItem,t.newItem))},pn.prototype.onItemRemoved_u8tacu$=function(t){if(!this.closure$coll.isEmpty())throw U();this.closure$handler.onEvent_11rb$(new D(t.oldItem,null))},pn.$metadata$={kind:c,interfaces:[B]},cn.prototype.addHandler_gxwwpc$=function(t){return this.closure$coll.addListener_n5no9j$(new pn(this.closure$coll,t))},cn.$metadata$={kind:c,interfaces:[M]},xe.prototype.forSingleItemCollection_4gck1s$=function(t){if(t.size>1)throw g("Collection "+t+" has more than one item");return new cn(t)},Object.defineProperty(hn.prototype,"propExpr",{configurable:!0,get:function(){var t,e=new rt("(");e.append_pdl1vj$(this.closure$props[0].propExpr),t=this.closure$props.length;for(var n=1;n>4)},Ke.prototype.type_kcn2v3$=function(t){return sn().fromCode_kcn2v3$(15&t)},Ke.prototype.assertNoMeta_0=function(t){if(this.isSet_0(t,3))throw P("META_EXTRA_PRECISION_BIT is not supported");if(this.isSet_0(t,1))throw P("META_SIZE_BIT is not supported");if(this.isSet_0(t,0))throw P("META_BBOX_BIT is not supported")},on.prototype.fromCode_kcn2v3$=function(t){switch(t){case 1:return Ze();case 2:return Je();case 3:return Qe();case 4:return tn();case 5:return en();case 6:return nn();case 7:return rn();default:throw j("Unkown geometry type: "+t)}},on.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var an=null;function sn(){return Xe(),null===an&&new on,an}We.$metadata$={kind:$,simpleName:"GeometryType",interfaces:[L]},We.values=function(){return[Ze(),Je(),Qe(),tn(),en(),nn(),rn()]},We.valueOf_61zpoe$=function(t){switch(t){case"POINT":return Ze();case"LINESTRING":return Je();case"POLYGON":return Qe();case"MULTI_POINT":return tn();case"MULTI_LINESTRING":return en();case"MULTI_POLYGON":return nn();case"GEOMETRY_COLLECTION":return rn();default:R("No enum constant jetbrains.gis.common.twkb.Twkb.Parser.GeometryType."+t)}},Ke.$metadata$={kind:$,simpleName:"Parser",interfaces:[]},Ve.$metadata$={kind:m,simpleName:"Twkb",interfaces:[]};var ln=null;function un(){return null===ln&&new Ve,ln}function cn(){pn=this,this.VARINT_EXPECT_NEXT_PART_0=7}cn.prototype.readVarInt_5a21t1$=function(t){var e=this.readVarUInt_t0n4v2$(t);return this.decodeZigZag_kcn2v3$(e)},cn.prototype.readVarUInt_t0n4v2$=function(t){var e,n=0,i=0;do{n|=(127&(e=t()))<>1^(0|-(1&t))},cn.$metadata$={kind:m,simpleName:"VarInt",interfaces:[]};var pn=null;function hn(){return null===pn&&new cn,pn}function _n(){yn()}function fn(){mn=this}function dn(t){this.closure$points=t}dn.prototype.asMultipolygon=function(){return this.closure$points},dn.$metadata$={kind:$,interfaces:[_n]},fn.prototype.create_8ft4gs$=function(t){return new dn(t)},fn.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var mn=null;function yn(){return null===mn&&new fn,mn}function $n(){Bn=this}function vn(t){var e;this.rawData_8be2vx$=t,this.myMultipolygon_svkeey$_0=F((e=this,function(){return e.parse_61zpoe$(e.rawData_8be2vx$)}))}function gn(t){vn.call(this,t)}function bn(t){this.closure$polygons=t}function wn(t){vn.call(this,t)}function xn(t){return function(e){return e.onPolygon=function(t){return function(e){if(null!=t.v)throw j("Failed requirement.".toString());return t.v=new E(Y(e)),g}}(t),e.onMultiPolygon=function(t){return function(e){if(null!=t.v)throw j("Failed requirement.".toString());return t.v=e,g}}(t),g}}_n.$metadata$={kind:D,simpleName:"Boundary",interfaces:[]},$n.prototype.fromTwkb_61zpoe$=function(t){return new gn(t)},$n.prototype.fromGeoJson_61zpoe$=function(t){return new wn(t)},$n.prototype.getRawData_riekmd$=function(t){var n;return(e.isType(n=t,vn)?n:M()).rawData_8be2vx$},Object.defineProperty(vn.prototype,"myMultipolygon_0",{configurable:!0,get:function(){return this.myMultipolygon_svkeey$_0.value}}),vn.prototype.asMultipolygon=function(){return this.myMultipolygon_0},vn.prototype.hashCode=function(){return B(this.rawData_8be2vx$)},vn.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,vn)||M(),!!U(this.rawData_8be2vx$,t.rawData_8be2vx$))},vn.$metadata$={kind:$,simpleName:"StringBoundary",interfaces:[_n]},bn.prototype.onPolygon_z3kb82$=function(t){this.closure$polygons.add_11rb$(t)},bn.prototype.onMultiPolygon_a0zxnd$=function(t){this.closure$polygons.addAll_brywnq$(t)},bn.$metadata$={kind:$,interfaces:[G]},gn.prototype.parse_61zpoe$=function(t){var e=z();return un().parse_gqqjn5$(q.Base64.decode_61zpoe$(t),new bn(e)),new E(e)},gn.$metadata$={kind:$,simpleName:"TinyBoundary",interfaces:[vn]},wn.prototype.parse_61zpoe$=function(t){var e,n={v:null};return H.GeoJson.parse_gdwatq$(t,xn(n)),null!=(e=n.v)?e:new E(V())},wn.$metadata$={kind:$,simpleName:"GeoJsonBoundary",interfaces:[vn]},$n.$metadata$={kind:m,simpleName:"Boundaries",interfaces:[]};var kn,En,Cn,Sn,Tn,On,Nn,Pn,An,jn,Ln,Rn,In,zn,Dn,Mn,Bn=null;function Un(){return null===Bn&&new $n,Bn}function Fn(t,e){L.call(this),this.name$=t,this.ordinal$=e}function qn(){qn=function(){},kn=new Fn("COUNTRY",0),En=new Fn("MACRO_STATE",1),Cn=new Fn("STATE",2),Sn=new Fn("MACRO_COUNTY",3),Tn=new Fn("COUNTY",4),On=new Fn("CITY",5)}function Gn(){return qn(),kn}function Hn(){return qn(),En}function Yn(){return qn(),Cn}function Vn(){return qn(),Sn}function Kn(){return qn(),Tn}function Wn(){return qn(),On}function Xn(){return[Gn(),Hn(),Yn(),Vn(),Kn(),Wn()]}function Zn(t,e){var n,i;this.key=t,this.boundaries=e,this.multiPolygon=null;var r=z();for(n=this.boundaries.iterator();n.hasNext();)for(i=n.next().asMultipolygon().iterator();i.hasNext();){var o=i.next();o.isEmpty()||r.add_11rb$(o)}this.multiPolygon=new E(r)}function Jn(){}function Qn(t,e,n){L.call(this),this.myValue_l7uf9u$_0=n,this.name$=t,this.ordinal$=e}function ti(){ti=function(){},Nn=new Qn("HIGHLIGHTS",0,"highlights"),Pn=new Qn("POSITION",1,"position"),An=new Qn("CENTROID",2,"centroid"),jn=new Qn("LIMIT",3,"limit"),Ln=new Qn("BOUNDARY",4,"boundary"),Rn=new Qn("FRAGMENTS",5,"tiles")}function ei(){return ti(),Nn}function ni(){return ti(),Pn}function ii(){return ti(),An}function ri(){return ti(),jn}function oi(){return ti(),Ln}function ai(){return ti(),Rn}function si(){}function li(){}function ui(t,e,n){$i(),this.ignoringStrategy=t,this.closestCoord=e,this.box=n}function ci(t,e){L.call(this),this.name$=t,this.ordinal$=e}function pi(){pi=function(){},In=new ci("SKIP_ALL",0),zn=new ci("SKIP_MISSING",1),Dn=new ci("SKIP_NAMESAKES",2),Mn=new ci("TAKE_NAMESAKES",3)}function hi(){return pi(),In}function _i(){return pi(),zn}function fi(){return pi(),Dn}function di(){return pi(),Mn}function mi(){yi=this}Fn.$metadata$={kind:$,simpleName:"FeatureLevel",interfaces:[L]},Fn.values=Xn,Fn.valueOf_61zpoe$=function(t){switch(t){case"COUNTRY":return Gn();case"MACRO_STATE":return Hn();case"STATE":return Yn();case"MACRO_COUNTY":return Vn();case"COUNTY":return Kn();case"CITY":return Wn();default:R("No enum constant jetbrains.gis.geoprotocol.FeatureLevel."+t)}},Zn.$metadata$={kind:$,simpleName:"Fragment",interfaces:[]},Qn.prototype.toString=function(){return this.myValue_l7uf9u$_0},Qn.$metadata$={kind:$,simpleName:"FeatureOption",interfaces:[L]},Qn.values=function(){return[ei(),ni(),ii(),ri(),oi(),ai()]},Qn.valueOf_61zpoe$=function(t){switch(t){case"HIGHLIGHTS":return ei();case"POSITION":return ni();case"CENTROID":return ii();case"LIMIT":return ri();case"BOUNDARY":return oi();case"FRAGMENTS":return ai();default:R("No enum constant jetbrains.gis.geoprotocol.GeoRequest.FeatureOption."+t)}},si.$metadata$={kind:D,simpleName:"ExplicitSearchRequest",interfaces:[Jn]},Object.defineProperty(ui.prototype,"isEmpty",{configurable:!0,get:function(){return null==this.closestCoord&&null==this.ignoringStrategy&&null==this.box}}),ci.$metadata$={kind:$,simpleName:"IgnoringStrategy",interfaces:[L]},ci.values=function(){return[hi(),_i(),fi(),di()]},ci.valueOf_61zpoe$=function(t){switch(t){case"SKIP_ALL":return hi();case"SKIP_MISSING":return _i();case"SKIP_NAMESAKES":return fi();case"TAKE_NAMESAKES":return di();default:R("No enum constant jetbrains.gis.geoprotocol.GeoRequest.GeocodingSearchRequest.AmbiguityResolver.IgnoringStrategy."+t)}},mi.prototype.ignoring_6lwvuf$=function(t){return new ui(t,null,null)},mi.prototype.closestTo_gpjtzr$=function(t){return new ui(null,t,null)},mi.prototype.within_wthzt5$=function(t){return new ui(null,null,t)},mi.prototype.empty=function(){return new ui(null,null,null)},mi.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var yi=null;function $i(){return null===yi&&new mi,yi}function vi(t,e,n){this.names=t,this.parent=e,this.ambiguityResolver=n}function gi(){}function bi(){Di=this,this.PARENT_KIND_ID_0=!0}function wi(){this.mySelf_r0smt8$_2fjbkj$_0=this.mySelf_r0smt8$_2fjbkj$_0,this.features=W(),this.fragments_n0offn$_0=null,this.levelOfDetails_31v9rh$_0=null}function xi(){wi.call(this),this.mode_17k92x$_0=lr(),this.coordinates_fjgqzn$_0=this.coordinates_fjgqzn$_0,this.level_y4w9sc$_0=this.level_y4w9sc$_0,this.parent_0=null,wi.prototype.setSelf_8auog8$.call(this,this)}function ki(t,e,n,i,r,o){Ai.call(this,t,e,n),this.coordinates_ulu2p5$_0=i,this.level_m6ep8g$_0=r,this.parent_xyqqdi$_0=o}function Ei(){Oi(),wi.call(this),this.mode_lc8f7p$_0=sr(),this.featureLevel_0=null,this.namesakeExampleLimit_0=10,this.regionQueries_0=z(),wi.prototype.setSelf_8auog8$.call(this,this)}function Ci(t,e,n,i,r,o){Ai.call(this,i,r,o),this.queries_kc4mug$_0=t,this.level_kybz0a$_0=e,this.namesakeExampleLimit_diu8fm$_0=n}function Si(){Ti=this,this.DEFAULT_NAMESAKE_EXAMPLE_LIMIT_0=10}ui.$metadata$={kind:$,simpleName:"AmbiguityResolver",interfaces:[]},ui.prototype.component1=function(){return this.ignoringStrategy},ui.prototype.component2=function(){return this.closestCoord},ui.prototype.component3=function(){return this.box},ui.prototype.copy_ixqc52$=function(t,e,n){return new ui(void 0===t?this.ignoringStrategy:t,void 0===e?this.closestCoord:e,void 0===n?this.box:n)},ui.prototype.toString=function(){return"AmbiguityResolver(ignoringStrategy="+e.toString(this.ignoringStrategy)+", closestCoord="+e.toString(this.closestCoord)+", box="+e.toString(this.box)+")"},ui.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.ignoringStrategy)|0)+e.hashCode(this.closestCoord)|0)+e.hashCode(this.box)|0},ui.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.ignoringStrategy,t.ignoringStrategy)&&e.equals(this.closestCoord,t.closestCoord)&&e.equals(this.box,t.box)},vi.$metadata$={kind:$,simpleName:"RegionQuery",interfaces:[]},vi.prototype.component1=function(){return this.names},vi.prototype.component2=function(){return this.parent},vi.prototype.component3=function(){return this.ambiguityResolver},vi.prototype.copy_mlden1$=function(t,e,n){return new vi(void 0===t?this.names:t,void 0===e?this.parent:e,void 0===n?this.ambiguityResolver:n)},vi.prototype.toString=function(){return"RegionQuery(names="+e.toString(this.names)+", parent="+e.toString(this.parent)+", ambiguityResolver="+e.toString(this.ambiguityResolver)+")"},vi.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.names)|0)+e.hashCode(this.parent)|0)+e.hashCode(this.ambiguityResolver)|0},vi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.names,t.names)&&e.equals(this.parent,t.parent)&&e.equals(this.ambiguityResolver,t.ambiguityResolver)},li.$metadata$={kind:D,simpleName:"GeocodingSearchRequest",interfaces:[Jn]},gi.$metadata$={kind:D,simpleName:"ReverseGeocodingSearchRequest",interfaces:[Jn]},Jn.$metadata$={kind:D,simpleName:"GeoRequest",interfaces:[]},Object.defineProperty(wi.prototype,"mySelf_r0smt8$_0",{configurable:!0,get:function(){return null==this.mySelf_r0smt8$_2fjbkj$_0?C("mySelf"):this.mySelf_r0smt8$_2fjbkj$_0},set:function(t){this.mySelf_r0smt8$_2fjbkj$_0=t}}),Object.defineProperty(wi.prototype,"fragments",{configurable:!0,get:function(){return this.fragments_n0offn$_0},set:function(t){this.fragments_n0offn$_0=t}}),Object.defineProperty(wi.prototype,"levelOfDetails",{configurable:!0,get:function(){return this.levelOfDetails_31v9rh$_0},set:function(t){this.levelOfDetails_31v9rh$_0=t}}),wi.prototype.setSelf_8auog8$=function(t){this.mySelf_r0smt8$_0=t},wi.prototype.setResolution_s8ev37$=function(t){return this.levelOfDetails=null!=t?io().fromResolution_za3lpa$(t):null,this.mySelf_r0smt8$_0},wi.prototype.setFragments_g9b45l$=function(t){return this.fragments=null!=t?K(t):null,this.mySelf_r0smt8$_0},wi.prototype.addFragments_8j3uov$=function(t,e){return null==this.fragments&&(this.fragments=Z()),A(this.fragments).put_xwzc9p$(t,e),this.mySelf_r0smt8$_0},wi.prototype.addFeature_bdjexh$=function(t){return this.features.add_11rb$(t),this.mySelf_r0smt8$_0},wi.prototype.setFeatures_kzd2fe$=function(t){return this.features.clear(),this.features.addAll_brywnq$(t),this.mySelf_r0smt8$_0},wi.$metadata$={kind:$,simpleName:"RequestBuilderBase",interfaces:[]},Object.defineProperty(xi.prototype,"mode",{configurable:!0,get:function(){return this.mode_17k92x$_0}}),Object.defineProperty(xi.prototype,"coordinates_0",{configurable:!0,get:function(){return null==this.coordinates_fjgqzn$_0?C("coordinates"):this.coordinates_fjgqzn$_0},set:function(t){this.coordinates_fjgqzn$_0=t}}),Object.defineProperty(xi.prototype,"level_0",{configurable:!0,get:function(){return null==this.level_y4w9sc$_0?C("level"):this.level_y4w9sc$_0},set:function(t){this.level_y4w9sc$_0=t}}),xi.prototype.setCoordinates_ytws2g$=function(t){return this.coordinates_0=t,this},xi.prototype.setLevel_5pii6g$=function(t){return this.level_0=t,this},xi.prototype.setParent_acwriv$=function(t){return this.parent_0=t,this},xi.prototype.build=function(){return new ki(this.features,this.fragments,this.levelOfDetails,this.coordinates_0,this.level_0,this.parent_0)},Object.defineProperty(ki.prototype,"coordinates",{get:function(){return this.coordinates_ulu2p5$_0}}),Object.defineProperty(ki.prototype,"level",{get:function(){return this.level_m6ep8g$_0}}),Object.defineProperty(ki.prototype,"parent",{get:function(){return this.parent_xyqqdi$_0}}),ki.$metadata$={kind:$,simpleName:"MyReverseGeocodingSearchRequest",interfaces:[gi,Ai]},xi.$metadata$={kind:$,simpleName:"ReverseGeocodingRequestBuilder",interfaces:[wi]},Object.defineProperty(Ei.prototype,"mode",{configurable:!0,get:function(){return this.mode_lc8f7p$_0}}),Ei.prototype.addQuery_71f1k8$=function(t){return this.regionQueries_0.add_11rb$(t),this},Ei.prototype.setLevel_ywpjnb$=function(t){return this.featureLevel_0=t,this},Ei.prototype.setNamesakeExampleLimit_za3lpa$=function(t){return this.namesakeExampleLimit_0=t,this},Ei.prototype.build=function(){return new Ci(this.regionQueries_0,this.featureLevel_0,this.namesakeExampleLimit_0,this.features,this.fragments,this.levelOfDetails)},Object.defineProperty(Ci.prototype,"queries",{get:function(){return this.queries_kc4mug$_0}}),Object.defineProperty(Ci.prototype,"level",{get:function(){return this.level_kybz0a$_0}}),Object.defineProperty(Ci.prototype,"namesakeExampleLimit",{get:function(){return this.namesakeExampleLimit_diu8fm$_0}}),Ci.$metadata$={kind:$,simpleName:"MyGeocodingSearchRequest",interfaces:[li,Ai]},Si.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var Ti=null;function Oi(){return null===Ti&&new Si,Ti}function Ni(){wi.call(this),this.mode_73qlis$_0=ar(),this.ids_kuk605$_0=this.ids_kuk605$_0,wi.prototype.setSelf_8auog8$.call(this,this)}function Pi(t,e,n,i){Ai.call(this,e,n,i),this.ids_uekfos$_0=t}function Ai(t,e,n){this.features_o650gb$_0=t,this.fragments_gwv6hr$_0=e,this.levelOfDetails_6xp3yt$_0=n}function ji(){this.values_dve3y8$_0=this.values_dve3y8$_0,this.kind_0=Mi().PARENT_KIND_ID_0}function Li(){this.parent_0=null,this.names_0=z(),this.ambiguityResolver_0=$i().empty()}Ei.$metadata$={kind:$,simpleName:"GeocodingRequestBuilder",interfaces:[wi]},Object.defineProperty(Ni.prototype,"mode",{configurable:!0,get:function(){return this.mode_73qlis$_0}}),Object.defineProperty(Ni.prototype,"ids_0",{configurable:!0,get:function(){return null==this.ids_kuk605$_0?C("ids"):this.ids_kuk605$_0},set:function(t){this.ids_kuk605$_0=t}}),Ni.prototype.setIds_mhpeer$=function(t){return this.ids_0=t,this},Ni.prototype.build=function(){return new Pi(this.ids_0,this.features,this.fragments,this.levelOfDetails)},Object.defineProperty(Pi.prototype,"ids",{get:function(){return this.ids_uekfos$_0}}),Pi.$metadata$={kind:$,simpleName:"MyExplicitSearchRequest",interfaces:[si,Ai]},Ni.$metadata$={kind:$,simpleName:"ExplicitRequestBuilder",interfaces:[wi]},Object.defineProperty(Ai.prototype,"features",{get:function(){return this.features_o650gb$_0}}),Object.defineProperty(Ai.prototype,"fragments",{get:function(){return this.fragments_gwv6hr$_0}}),Object.defineProperty(Ai.prototype,"levelOfDetails",{get:function(){return this.levelOfDetails_6xp3yt$_0}}),Ai.$metadata$={kind:$,simpleName:"MyGeoRequestBase",interfaces:[Jn]},Object.defineProperty(ji.prototype,"values_0",{configurable:!0,get:function(){return null==this.values_dve3y8$_0?C("values"):this.values_dve3y8$_0},set:function(t){this.values_dve3y8$_0=t}}),ji.prototype.setParentValues_mhpeer$=function(t){return this.values_0=t,this},ji.prototype.setParentKind_6taknv$=function(t){return this.kind_0=t,this},ji.prototype.build=function(){return this.kind_0===Mi().PARENT_KIND_ID_0?ho().withIdList_mhpeer$(this.values_0):ho().withName_61zpoe$(this.values_0.get_za3lpa$(0))},ji.$metadata$={kind:$,simpleName:"MapRegionBuilder",interfaces:[]},Li.prototype.setQueryNames_mhpeer$=function(t){return this.names_0=t,this},Li.prototype.setQueryNames_vqirvp$=function(t){return this.names_0=X(t.slice()),this},Li.prototype.setParent_acwriv$=function(t){return this.parent_0=t,this},Li.prototype.setIgnoringStrategy_880qs6$=function(t){return null!=t&&(this.ambiguityResolver_0=$i().ignoring_6lwvuf$(t)),this},Li.prototype.setClosestObject_ksafwq$=function(t){return null!=t&&(this.ambiguityResolver_0=$i().closestTo_gpjtzr$(t)),this},Li.prototype.setBox_myx2hi$=function(t){return null!=t&&(this.ambiguityResolver_0=$i().within_wthzt5$(t)),this},Li.prototype.setAmbiguityResolver_pqmad5$=function(t){return this.ambiguityResolver_0=t,this},Li.prototype.build=function(){return new vi(this.names_0,this.parent_0,this.ambiguityResolver_0)},Li.$metadata$={kind:$,simpleName:"RegionQueryBuilder",interfaces:[]},bi.$metadata$={kind:m,simpleName:"GeoRequestBuilder",interfaces:[]};var Ri,Ii,zi,Di=null;function Mi(){return null===Di&&new bi,Di}function Bi(){}function Ui(t,e){this.features=t,this.featureLevel=e}function Fi(t,e,n,i,r,o,a,s,l){this.request=t,this.id=e,this.name=n,this.centroid=i,this.position=r,this.limit=o,this.boundary=a,this.highlights=s,this.fragments=l}function qi(t){this.message=t}function Gi(t,e){this.features=t,this.featureLevel=e}function Hi(t,e,n){this.request=t,this.namesakeCount=e,this.namesakes=n}function Yi(t,e){this.name=t,this.parents=e}function Vi(t,e){this.name=t,this.level=e}function Ki(){}function Wi(){this.geocodedFeatures_0=z(),this.featureLevel_0=null}function Xi(){this.ambiguousFeatures_0=z(),this.featureLevel_0=null}function Zi(){this.query_g4upvu$_0=this.query_g4upvu$_0,this.id_jdni55$_0=this.id_jdni55$_0,this.name_da6rd5$_0=this.name_da6rd5$_0,this.centroid_0=null,this.limit_0=null,this.position_0=null,this.boundary_0=null,this.highlights_0=z(),this.fragments_0=z()}function Ji(){this.query_lkdzx6$_0=this.query_lkdzx6$_0,this.totalNamesakeCount_0=0,this.namesakeExamples_0=z()}function Qi(){this.name_xd6cda$_0=this.name_xd6cda$_0,this.parentNames_0=z(),this.parentLevels_0=z()}function tr(){}function er(t){this.myUrl_0=t,this.myClient_0=lt()}function nr(t){return function(e){var n=t,i=y("format",function(t,e){return t.format_2yxzh4$(e)}.bind(null,vo()))(n);return e.body=y("formatJson",function(t,e){return t.formatJson_za3rmp$(e)}.bind(null,et.JsonSupport))(i),g}}function ir(t,e,n,i,r,o){at.call(this,o),this.$controller=r,this.exceptionState_0=12,this.local$this$GeoTransportImpl=t,this.local$closure$request=e,this.local$closure$async=n,this.local$response=void 0}function rr(t,e,n){L.call(this),this.myValue_dowh1b$_0=n,this.name$=t,this.ordinal$=e}function or(){or=function(){},Ri=new rr("BY_ID",0,"by_id"),Ii=new rr("BY_NAME",1,"by_geocoding"),zi=new rr("REVERSE",2,"reverse")}function ar(){return or(),Ri}function sr(){return or(),Ii}function lr(){return or(),zi}function ur(t){dr(),this.myTransport_0=t}function cr(t){return t.features}function pr(t,e){return U(e.request,t)}function hr(){fr=this}function _r(t){return t.name}Fi.$metadata$={kind:$,simpleName:"GeocodedFeature",interfaces:[]},Fi.prototype.component1=function(){return this.request},Fi.prototype.component2=function(){return this.id},Fi.prototype.component3=function(){return this.name},Fi.prototype.component4=function(){return this.centroid},Fi.prototype.component5=function(){return this.position},Fi.prototype.component6=function(){return this.limit},Fi.prototype.component7=function(){return this.boundary},Fi.prototype.component8=function(){return this.highlights},Fi.prototype.component9=function(){return this.fragments},Fi.prototype.copy_4mpox9$=function(t,e,n,i,r,o,a,s,l){return new Fi(void 0===t?this.request:t,void 0===e?this.id:e,void 0===n?this.name:n,void 0===i?this.centroid:i,void 0===r?this.position:r,void 0===o?this.limit:o,void 0===a?this.boundary:a,void 0===s?this.highlights:s,void 0===l?this.fragments:l)},Fi.prototype.toString=function(){return"GeocodedFeature(request="+e.toString(this.request)+", id="+e.toString(this.id)+", name="+e.toString(this.name)+", centroid="+e.toString(this.centroid)+", position="+e.toString(this.position)+", limit="+e.toString(this.limit)+", boundary="+e.toString(this.boundary)+", highlights="+e.toString(this.highlights)+", fragments="+e.toString(this.fragments)+")"},Fi.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*t+e.hashCode(this.request)|0)+e.hashCode(this.id)|0)+e.hashCode(this.name)|0)+e.hashCode(this.centroid)|0)+e.hashCode(this.position)|0)+e.hashCode(this.limit)|0)+e.hashCode(this.boundary)|0)+e.hashCode(this.highlights)|0)+e.hashCode(this.fragments)|0},Fi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.request,t.request)&&e.equals(this.id,t.id)&&e.equals(this.name,t.name)&&e.equals(this.centroid,t.centroid)&&e.equals(this.position,t.position)&&e.equals(this.limit,t.limit)&&e.equals(this.boundary,t.boundary)&&e.equals(this.highlights,t.highlights)&&e.equals(this.fragments,t.fragments)},Ui.$metadata$={kind:$,simpleName:"SuccessGeoResponse",interfaces:[Bi]},Ui.prototype.component1=function(){return this.features},Ui.prototype.component2=function(){return this.featureLevel},Ui.prototype.copy_xn8lgx$=function(t,e){return new Ui(void 0===t?this.features:t,void 0===e?this.featureLevel:e)},Ui.prototype.toString=function(){return"SuccessGeoResponse(features="+e.toString(this.features)+", featureLevel="+e.toString(this.featureLevel)+")"},Ui.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.features)|0)+e.hashCode(this.featureLevel)|0},Ui.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.features,t.features)&&e.equals(this.featureLevel,t.featureLevel)},qi.$metadata$={kind:$,simpleName:"ErrorGeoResponse",interfaces:[Bi]},qi.prototype.component1=function(){return this.message},qi.prototype.copy_61zpoe$=function(t){return new qi(void 0===t?this.message:t)},qi.prototype.toString=function(){return"ErrorGeoResponse(message="+e.toString(this.message)+")"},qi.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.message)|0},qi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.message,t.message)},Hi.$metadata$={kind:$,simpleName:"AmbiguousFeature",interfaces:[]},Hi.prototype.component1=function(){return this.request},Hi.prototype.component2=function(){return this.namesakeCount},Hi.prototype.component3=function(){return this.namesakes},Hi.prototype.copy_ckeskw$=function(t,e,n){return new Hi(void 0===t?this.request:t,void 0===e?this.namesakeCount:e,void 0===n?this.namesakes:n)},Hi.prototype.toString=function(){return"AmbiguousFeature(request="+e.toString(this.request)+", namesakeCount="+e.toString(this.namesakeCount)+", namesakes="+e.toString(this.namesakes)+")"},Hi.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.request)|0)+e.hashCode(this.namesakeCount)|0)+e.hashCode(this.namesakes)|0},Hi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.request,t.request)&&e.equals(this.namesakeCount,t.namesakeCount)&&e.equals(this.namesakes,t.namesakes)},Yi.$metadata$={kind:$,simpleName:"Namesake",interfaces:[]},Yi.prototype.component1=function(){return this.name},Yi.prototype.component2=function(){return this.parents},Yi.prototype.copy_5b6i1g$=function(t,e){return new Yi(void 0===t?this.name:t,void 0===e?this.parents:e)},Yi.prototype.toString=function(){return"Namesake(name="+e.toString(this.name)+", parents="+e.toString(this.parents)+")"},Yi.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.name)|0)+e.hashCode(this.parents)|0},Yi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)&&e.equals(this.parents,t.parents)},Vi.$metadata$={kind:$,simpleName:"NamesakeParent",interfaces:[]},Vi.prototype.component1=function(){return this.name},Vi.prototype.component2=function(){return this.level},Vi.prototype.copy_3i9pe2$=function(t,e){return new Vi(void 0===t?this.name:t,void 0===e?this.level:e)},Vi.prototype.toString=function(){return"NamesakeParent(name="+e.toString(this.name)+", level="+e.toString(this.level)+")"},Vi.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.name)|0)+e.hashCode(this.level)|0},Vi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)&&e.equals(this.level,t.level)},Gi.$metadata$={kind:$,simpleName:"AmbiguousGeoResponse",interfaces:[Bi]},Gi.prototype.component1=function(){return this.features},Gi.prototype.component2=function(){return this.featureLevel},Gi.prototype.copy_i46hsw$=function(t,e){return new Gi(void 0===t?this.features:t,void 0===e?this.featureLevel:e)},Gi.prototype.toString=function(){return"AmbiguousGeoResponse(features="+e.toString(this.features)+", featureLevel="+e.toString(this.featureLevel)+")"},Gi.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.features)|0)+e.hashCode(this.featureLevel)|0},Gi.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.features,t.features)&&e.equals(this.featureLevel,t.featureLevel)},Bi.$metadata$={kind:D,simpleName:"GeoResponse",interfaces:[]},Wi.prototype.addGeocodedFeature_sv8o3d$=function(t){return this.geocodedFeatures_0.add_11rb$(t),this},Wi.prototype.setLevel_ywpjnb$=function(t){return this.featureLevel_0=t,this},Wi.prototype.build=function(){return new Ui(this.geocodedFeatures_0,this.featureLevel_0)},Wi.$metadata$={kind:$,simpleName:"SuccessResponseBuilder",interfaces:[]},Xi.prototype.addAmbiguousFeature_1j15ng$=function(t){return this.ambiguousFeatures_0.add_11rb$(t),this},Xi.prototype.setLevel_ywpjnb$=function(t){return this.featureLevel_0=t,this},Xi.prototype.build=function(){return new Gi(this.ambiguousFeatures_0,this.featureLevel_0)},Xi.$metadata$={kind:$,simpleName:"AmbiguousResponseBuilder",interfaces:[]},Object.defineProperty(Zi.prototype,"query_0",{configurable:!0,get:function(){return null==this.query_g4upvu$_0?C("query"):this.query_g4upvu$_0},set:function(t){this.query_g4upvu$_0=t}}),Object.defineProperty(Zi.prototype,"id_0",{configurable:!0,get:function(){return null==this.id_jdni55$_0?C("id"):this.id_jdni55$_0},set:function(t){this.id_jdni55$_0=t}}),Object.defineProperty(Zi.prototype,"name_0",{configurable:!0,get:function(){return null==this.name_da6rd5$_0?C("name"):this.name_da6rd5$_0},set:function(t){this.name_da6rd5$_0=t}}),Zi.prototype.setQuery_61zpoe$=function(t){return this.query_0=t,this},Zi.prototype.setId_61zpoe$=function(t){return this.id_0=t,this},Zi.prototype.setName_61zpoe$=function(t){return this.name_0=t,this},Zi.prototype.setBoundary_dfy5bc$=function(t){return this.boundary_0=t,this},Zi.prototype.setCentroid_o5m5pd$=function(t){return this.centroid_0=t,this},Zi.prototype.setLimit_emtjl$=function(t){return this.limit_0=t,this},Zi.prototype.setPosition_emtjl$=function(t){return this.position_0=t,this},Zi.prototype.addHighlight_61zpoe$=function(t){return this.highlights_0.add_11rb$(t),this},Zi.prototype.addFragment_1ve0tm$=function(t){return this.fragments_0.add_11rb$(t),this},Zi.prototype.build=function(){var t=this.highlights_0,e=this.fragments_0;return new Fi(this.query_0,this.id_0,this.name_0,this.centroid_0,this.position_0,this.limit_0,this.boundary_0,t.isEmpty()?null:t,e.isEmpty()?null:e)},Zi.$metadata$={kind:$,simpleName:"GeocodedFeatureBuilder",interfaces:[]},Object.defineProperty(Ji.prototype,"query_0",{configurable:!0,get:function(){return null==this.query_lkdzx6$_0?C("query"):this.query_lkdzx6$_0},set:function(t){this.query_lkdzx6$_0=t}}),Ji.prototype.setQuery_61zpoe$=function(t){return this.query_0=t,this},Ji.prototype.addNamesakeExample_ulfa63$=function(t){return this.namesakeExamples_0.add_11rb$(t),this},Ji.prototype.setTotalNamesakeCount_za3lpa$=function(t){return this.totalNamesakeCount_0=t,this},Ji.prototype.build=function(){return new Hi(this.query_0,this.totalNamesakeCount_0,this.namesakeExamples_0)},Ji.$metadata$={kind:$,simpleName:"AmbiguousFeatureBuilder",interfaces:[]},Object.defineProperty(Qi.prototype,"name_0",{configurable:!0,get:function(){return null==this.name_xd6cda$_0?C("name"):this.name_xd6cda$_0},set:function(t){this.name_xd6cda$_0=t}}),Qi.prototype.setName_61zpoe$=function(t){return this.name_0=t,this},Qi.prototype.addParentName_61zpoe$=function(t){return this.parentNames_0.add_11rb$(t),this},Qi.prototype.addParentLevel_5pii6g$=function(t){return this.parentLevels_0.add_11rb$(t),this},Qi.prototype.build=function(){if(this.parentNames_0.size!==this.parentLevels_0.size)throw d();for(var t=this.name_0,e=this.parentNames_0,n=this.parentLevels_0,i=e.iterator(),r=n.iterator(),o=S(I.min(Q(e,10),Q(n,10)));i.hasNext()&&r.hasNext();)o.add_11rb$(new Vi(i.next(),r.next()));return new Yi(t,J(o))},Qi.$metadata$={kind:$,simpleName:"NamesakeBuilder",interfaces:[]},tr.$metadata$={kind:D,simpleName:"GeoTransport",interfaces:[]},ir.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},ir.prototype=Object.create(at.prototype),ir.prototype.constructor=ir,ir.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.exceptionState_0=9;var t,n=this.local$this$GeoTransportImpl.myClient_0,i=this.local$this$GeoTransportImpl.myUrl_0,r=nr(this.local$closure$request);"localhost",t=ct.EmptyContent;var o=new _t;pt(o,"http","localhost",0,"/"),o.method=ht.Companion.Post,o.body=t,ut(o.url,i),r(o);var a,s,l,u=new ft(o,n);if(U(a=nt,dt(ft))){this.result_0="string"==typeof(s=u)?s:M(),this.state_0=8;continue}if(U(a,dt(mt))){if(this.state_0=6,this.result_0=u.execute(this),this.result_0===ot)return ot;continue}if(this.state_0=1,this.result_0=u.executeUnsafe(this),this.result_0===ot)return ot;continue;case 1:var c;this.local$response=this.result_0,this.exceptionState_0=4;var p,h=this.local$response.call;t:do{try{p=new vt(nt,$t.JsType,it(nt,[],!1))}catch(t){p=new vt(nt,$t.JsType);break t}}while(0);if(this.state_0=2,this.result_0=h.receive_jo9acv$(p,this),this.result_0===ot)return ot;continue;case 2:this.result_0="string"==typeof(c=this.result_0)?c:M(),this.exceptionState_0=9,this.finallyPath_0=[3],this.state_0=5;continue;case 3:this.state_0=7;continue;case 4:this.finallyPath_0=[9],this.state_0=5;continue;case 5:this.exceptionState_0=9,yt(this.local$response),this.state_0=this.finallyPath_0.shift();continue;case 6:this.result_0="string"==typeof(l=this.result_0)?l:M(),this.state_0=7;continue;case 7:this.state_0=8;continue;case 8:this.result_0;var _=this.result_0,f=y("parseJson",function(t,e){return t.parseJson_61zpoe$(e)}.bind(null,et.JsonSupport))(_),d=y("parse",function(t,e){return t.parse_bkhwtg$(e)}.bind(null,Ao()))(f);return y("success",function(t,e){return t.success_11rb$(e),g}.bind(null,this.local$closure$async))(d);case 9:this.exceptionState_0=12;var m=this.exception_0;if(e.isType(m,rt))return this.local$closure$async.failure_tcv7n7$(m),g;throw m;case 10:this.state_0=11;continue;case 11:return;case 12:throw this.exception_0;default:throw this.state_0=12,new Error("State Machine Unreachable execution")}}catch(t){if(12===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},er.prototype.send_2yxzh4$=function(t){var e,n,i,r=new tt;return st(this.myClient_0,void 0,void 0,(e=this,n=t,i=r,function(t,r,o){var a=new ir(e,n,i,t,this,r);return o?a:a.doResume(null)})),r},er.$metadata$={kind:$,simpleName:"GeoTransportImpl",interfaces:[tr]},rr.prototype.toString=function(){return this.myValue_dowh1b$_0},rr.$metadata$={kind:$,simpleName:"GeocodingMode",interfaces:[L]},rr.values=function(){return[ar(),sr(),lr()]},rr.valueOf_61zpoe$=function(t){switch(t){case"BY_ID":return ar();case"BY_NAME":return sr();case"REVERSE":return lr();default:R("No enum constant jetbrains.gis.geoprotocol.GeocodingMode."+t)}},ur.prototype.execute_2yxzh4$=function(t){var n;if(e.isType(t,si))n=t.ids;else if(e.isType(t,li)){var i,r=t.queries,o=z();for(i=r.iterator();i.hasNext();){var a=i.next().names;Et(o,a)}n=o}else{if(!e.isType(t,gi))return bt.Asyncs.failure_lsqlk3$(P("Unknown request type: "+t));n=V()}var s,l,u,c=n,p=c.isEmpty()?cr:(s=c,l=this,function(t){return l.leftJoin_0(s,t.features,pr)});return this.myTransport_0.send_2yxzh4$(t).map_2o04qz$((u=p,function(t){if(e.isType(t,Ui))return u(t);throw e.isType(t,Gi)?gt(dr().createAmbiguousMessage_z3t9ig$(t.features)):e.isType(t,qi)?gt("GIS error: "+t.message):P("Unknown response status: "+t)}))},ur.prototype.leftJoin_0=function(t,e,n){var i,r=z();for(i=t.iterator();i.hasNext();){var o,a,s=i.next();t:do{var l;for(l=e.iterator();l.hasNext();){var u=l.next();if(n(s,u)){a=u;break t}}a=null}while(0);null!=(o=a)&&r.add_11rb$(o)}return r},hr.prototype.createAmbiguousMessage_z3t9ig$=function(t){var e,n=wt().append_pdl1vj$("Geocoding errors:\n");for(e=t.iterator();e.hasNext();){var i=e.next();if(1!==i.namesakeCount)if(i.namesakeCount>1){n.append_pdl1vj$("Multiple objects ("+i.namesakeCount).append_pdl1vj$(") were found for '"+i.request+"'").append_pdl1vj$(i.namesakes.isEmpty()?".":":");var r,o,a=i.namesakes,s=S(Q(a,10));for(r=a.iterator();r.hasNext();){var l=r.next(),u=s.add_11rb$,c=l.component1(),p=l.component2();u.call(s,"- "+c+xt(p,void 0,"(",")",void 0,void 0,_r))}for(o=kt(s).iterator();o.hasNext();){var h=o.next();n.append_pdl1vj$("\n"+h)}}else n.append_pdl1vj$("No objects were found for '"+i.request+"'.");n.append_pdl1vj$("\n")}return n.toString()},hr.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var fr=null;function dr(){return null===fr&&new hr,fr}function mr(){Lr=this}function yr(t){return t.origin}function $r(t){return Ot(t.origin,t.dimension)}ur.$metadata$={kind:$,simpleName:"GeocodingService",interfaces:[]},mr.prototype.bbox_8ft4gs$=function(t){var e=Ct(t);return e.isEmpty()?null:jt(At(Pt(Nt([Tt(St(e),yr),Tt(St(e),$r)]))))},mr.prototype.asLineString_8ft4gs$=function(t){return new b(t.get_za3lpa$(0).get_za3lpa$(0))},mr.$metadata$={kind:m,simpleName:"GeometryUtil",interfaces:[]};var vr,gr,br,wr,xr,kr,Er,Cr,Sr,Tr,Or,Nr,Pr,Ar,jr,Lr=null;function Rr(t,e){L.call(this),this.name$=t,this.ordinal$=e}function Ir(){Ir=function(){},vr=new Rr("CITY_HIGH",0),gr=new Rr("CITY_MEDIUM",1),br=new Rr("CITY_LOW",2),wr=new Rr("COUNTY_HIGH",3),xr=new Rr("COUNTY_MEDIUM",4),kr=new Rr("COUNTY_LOW",5),Er=new Rr("STATE_HIGH",6),Cr=new Rr("STATE_MEDIUM",7),Sr=new Rr("STATE_LOW",8),Tr=new Rr("COUNTRY_HIGH",9),Or=new Rr("COUNTRY_MEDIUM",10),Nr=new Rr("COUNTRY_LOW",11),Pr=new Rr("WORLD_HIGH",12),Ar=new Rr("WORLD_MEDIUM",13),jr=new Rr("WORLD_LOW",14),io()}function zr(){return Ir(),vr}function Dr(){return Ir(),gr}function Mr(){return Ir(),br}function Br(){return Ir(),wr}function Ur(){return Ir(),xr}function Fr(){return Ir(),kr}function qr(){return Ir(),Er}function Gr(){return Ir(),Cr}function Hr(){return Ir(),Sr}function Yr(){return Ir(),Tr}function Vr(){return Ir(),Or}function Kr(){return Ir(),Nr}function Wr(){return Ir(),Pr}function Xr(){return Ir(),Ar}function Zr(){return Ir(),jr}function Jr(t,e){this.resolution_8be2vx$=t,this.level_8be2vx$=e}function Qr(){no=this;var t,e=ro(),n=S(e.length);for(t=0;t!==e.length;++t){var i=e[t];n.add_11rb$(new Jr(i.toResolution(),i))}this.LOD_RANGES_0=n}Jr.$metadata$={kind:$,simpleName:"Lod",interfaces:[]},Rr.prototype.toResolution=function(){return 15-this.ordinal|0},Qr.prototype.fromResolution_za3lpa$=function(t){var e;for(e=this.LOD_RANGES_0.iterator();e.hasNext();){var n=e.next();if(t>=n.resolution_8be2vx$)return n.level_8be2vx$}return Zr()},Qr.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var to,eo,no=null;function io(){return Ir(),null===no&&new Qr,no}function ro(){return[zr(),Dr(),Mr(),Br(),Ur(),Fr(),qr(),Gr(),Hr(),Yr(),Vr(),Kr(),Wr(),Xr(),Zr()]}function oo(t,e){ho(),this.myKind_0=t,this.myValueList_0=null,this.myValueList_0=Rt(e)}function ao(t,e){L.call(this),this.name$=t,this.ordinal$=e}function so(){so=function(){},to=new ao("MAP_REGION_KIND_ID",0),eo=new ao("MAP_REGION_KIND_NAME",1)}function lo(){return so(),to}function uo(){return so(),eo}function co(){po=this,this.US_48_NAME_0="us-48",this.US_48_0=new oo(uo(),Y(this.US_48_NAME_0)),this.US_48_PARENT_NAME_0="United States of America",this.US_48_PARENT=new oo(uo(),Y(this.US_48_PARENT_NAME_0))}Rr.$metadata$={kind:$,simpleName:"LevelOfDetails",interfaces:[L]},Rr.values=ro,Rr.valueOf_61zpoe$=function(t){switch(t){case"CITY_HIGH":return zr();case"CITY_MEDIUM":return Dr();case"CITY_LOW":return Mr();case"COUNTY_HIGH":return Br();case"COUNTY_MEDIUM":return Ur();case"COUNTY_LOW":return Fr();case"STATE_HIGH":return qr();case"STATE_MEDIUM":return Gr();case"STATE_LOW":return Hr();case"COUNTRY_HIGH":return Yr();case"COUNTRY_MEDIUM":return Vr();case"COUNTRY_LOW":return Kr();case"WORLD_HIGH":return Wr();case"WORLD_MEDIUM":return Xr();case"WORLD_LOW":return Zr();default:R("No enum constant jetbrains.gis.geoprotocol.LevelOfDetails."+t)}},Object.defineProperty(oo.prototype,"idList",{configurable:!0,get:function(){if(!this.containsId())throw j("Can't get ids from MapRegion with name".toString());return this.myValueList_0}}),Object.defineProperty(oo.prototype,"name",{configurable:!0,get:function(){if(!this.containsName())throw j("Can't get name from MapRegion with ids".toString());if(1!==this.myValueList_0.size)throw j("MapRegion should contain one name".toString());return this.myValueList_0.get_za3lpa$(0)}}),oo.prototype.containsId=function(){return this.myKind_0===lo()},oo.prototype.containsName=function(){return this.myKind_0===uo()},oo.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,oo)||M(),this.myKind_0===t.myKind_0&&!!U(this.myValueList_0,t.myValueList_0))},oo.prototype.hashCode=function(){var t=this.myKind_0.hashCode();return(31*t|0)+B(this.myValueList_0)|0},ao.$metadata$={kind:$,simpleName:"MapRegionKind",interfaces:[L]},ao.values=function(){return[lo(),uo()]},ao.valueOf_61zpoe$=function(t){switch(t){case"MAP_REGION_KIND_ID":return lo();case"MAP_REGION_KIND_NAME":return uo();default:R("No enum constant jetbrains.gis.geoprotocol.MapRegion.MapRegionKind."+t)}},co.prototype.withIdList_mhpeer$=function(t){return new oo(lo(),t)},co.prototype.withId_61zpoe$=function(t){return new oo(lo(),Y(t))},co.prototype.withName_61zpoe$=function(t){return Lt(this.US_48_NAME_0,t,!0)?this.US_48_0:new oo(uo(),Y(t))},co.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var po=null;function ho(){return null===po&&new co,po}function _o(){fo=this,this.MIN_LON_0="min_lon",this.MIN_LAT_0="min_lat",this.MAX_LON_0="max_lon",this.MAX_LAT_0="max_lat"}oo.$metadata$={kind:$,simpleName:"MapRegion",interfaces:[]},_o.prototype.parseGeoRectangle_bkhwtg$=function(t){return new zt(It(t,this.MIN_LON_0),It(t,this.MIN_LAT_0),It(t,this.MAX_LON_0),It(t,this.MAX_LAT_0))},_o.prototype.formatGeoRectangle_emtjl$=function(t){return Dt().put_hzlfav$(this.MIN_LON_0,t.startLongitude()).put_hzlfav$(this.MIN_LAT_0,t.minLatitude()).put_hzlfav$(this.MAX_LAT_0,t.maxLatitude()).put_hzlfav$(this.MAX_LON_0,t.endLongitude())},_o.$metadata$={kind:m,simpleName:"ProtocolJsonHelper",interfaces:[]};var fo=null;function mo(){return null===fo&&new _o,fo}function yo(){$o=this,this.PARENT_KIND_ID_0=!0,this.PARENT_KIND_NAME_0=!1}yo.prototype.format_2yxzh4$=function(t){var n;if(e.isType(t,li))n=this.geocoding_0(t);else if(e.isType(t,si))n=this.explicit_0(t);else{if(!e.isType(t,gi))throw P("Unknown request: "+e.getKClassFromExpression(t).toString());n=this.reverse_0(t)}return n},yo.prototype.geocoding_0=function(t){var e,n=this.common_0(t,sr()).put_snuhza$(wo().LEVEL,t.level).put_hzlfav$(wo().NAMESAKE_EXAMPLE_LIMIT,t.namesakeExampleLimit),i=wo().REGION_QUERIES,r=Mt(),o=t.queries,a=S(Q(o,10));for(e=o.iterator();e.hasNext();){var s,l=e.next();a.add_11rb$(Bt(Dt(),wo().REGION_QUERY_NAMES,l.names).put_wxs67v$(wo().REGION_QUERY_PARENT,this.formatMapRegion_0(l.parent)).put_wxs67v$(wo().AMBIGUITY_RESOLVER,Dt().put_snuhza$(wo().AMBIGUITY_IGNORING_STRATEGY,l.ambiguityResolver.ignoringStrategy).put_wxs67v$(wo().AMBIGUITY_CLOSEST_COORD,this.formatCoord_0(l.ambiguityResolver.closestCoord)).put_wxs67v$(wo().AMBIGUITY_BOX,null!=(s=l.ambiguityResolver.box)?this.formatRect_0(s):null)))}return n.put_wxs67v$(i,r.addAll_5ry1at$(a)).get()},yo.prototype.explicit_0=function(t){return Bt(this.common_0(t,ar()),wo().IDS,t.ids).get()},yo.prototype.reverse_0=function(t){var e,n=this.common_0(t,lr()).put_wxs67v$(wo().REVERSE_PARENT,this.formatMapRegion_0(t.parent)),i=wo().REVERSE_COORDINATES,r=Mt(),o=t.coordinates,a=S(Q(o,10));for(e=o.iterator();e.hasNext();){var s=e.next();a.add_11rb$(Mt().add_yrwdxb$(s.x).add_yrwdxb$(s.y))}return n.put_wxs67v$(i,r.addAll_5ry1at$(a)).put_snuhza$(wo().REVERSE_LEVEL,t.level).get()},yo.prototype.formatRect_0=function(t){var e=Dt().put_hzlfav$(wo().LON_MIN,t.left),n=wo().LAT_MIN,i=t.top,r=t.bottom,o=e.put_hzlfav$(n,I.min(i,r)).put_hzlfav$(wo().LON_MAX,t.right),a=wo().LAT_MAX,s=t.top,l=t.bottom;return o.put_hzlfav$(a,I.max(s,l))},yo.prototype.formatCoord_0=function(t){return null!=t?Mt().add_yrwdxb$(t.x).add_yrwdxb$(t.y):null},yo.prototype.common_0=function(t,e){var n,i,r,o,a,s,l=Dt().put_hzlfav$(wo().VERSION,2).put_snuhza$(wo().MODE,e).put_hzlfav$(wo().RESOLUTION,null!=(n=t.levelOfDetails)?n.toResolution():null),u=wo().FEATURE_OPTIONS,c=t.features,p=S(Q(c,10));for(a=c.iterator();a.hasNext();){var h=a.next();p.add_11rb$(Ut(h))}if(o=Bt(l,u,p),i=wo().FRAGMENTS,null!=(r=t.fragments)){var _,f=Dt(),d=S(r.size);for(_=r.entries.iterator();_.hasNext();){var m,y=_.next(),$=d.add_11rb$,v=y.key,g=y.value,b=Ft("key",1,(function(t){return t.key})),w=S(Q(g,10));for(m=g.iterator();m.hasNext();){var x=m.next();w.add_11rb$(b(x))}$.call(d,Bt(f,v,w))}s=f}else s=null;return o.putRemovable_wxs67v$(i,s)},yo.prototype.formatMapRegion_0=function(t){var e;if(null!=t){var n=t.containsId()?this.PARENT_KIND_ID_0:this.PARENT_KIND_NAME_0,i=t.containsId()?t.idList:Y(t.name);e=Bt(Dt().put_h92gdm$(wo().MAP_REGION_KIND,n),wo().MAP_REGION_VALUES,i)}else e=null;return e},yo.$metadata$={kind:m,simpleName:"RequestJsonFormatter",interfaces:[]};var $o=null;function vo(){return null===$o&&new yo,$o}function go(){bo=this,this.PROTOCOL_VERSION=2,this.VERSION="version",this.MODE="mode",this.RESOLUTION="resolution",this.FEATURE_OPTIONS="feature_options",this.IDS="ids",this.REGION_QUERIES="region_queries",this.REGION_QUERY_NAMES="region_query_names",this.REGION_QUERY_PARENT="region_query_parent",this.LEVEL="level",this.MAP_REGION_KIND="kind",this.MAP_REGION_VALUES="values",this.NAMESAKE_EXAMPLE_LIMIT="namesake_example_limit",this.FRAGMENTS="tiles",this.AMBIGUITY_RESOLVER="ambiguity_resolver",this.AMBIGUITY_IGNORING_STRATEGY="ambiguity_resolver_ignoring_strategy",this.AMBIGUITY_CLOSEST_COORD="ambiguity_resolver_closest_coord",this.AMBIGUITY_BOX="ambiguity_resolver_box",this.REVERSE_LEVEL="level",this.REVERSE_COORDINATES="reverse_coordinates",this.REVERSE_PARENT="reverse_parent",this.COORDINATE_LON=0,this.COORDINATE_LAT=1,this.LON_MIN="min_lon",this.LAT_MIN="min_lat",this.LON_MAX="max_lon",this.LAT_MAX="max_lat"}go.$metadata$={kind:m,simpleName:"RequestKeys",interfaces:[]};var bo=null;function wo(){return null===bo&&new go,bo}function xo(){Po=this}function ko(t,e){return function(n){return n.forArrEntries_2wy1dl$(function(t,e){return function(n,i){var r,o=t,a=new Ht(n),s=S(Q(i,10));for(r=i.iterator();r.hasNext();){var l,u=r.next();s.add_11rb$(e.readBoundary_0("string"==typeof(l=A(u))?l:M()))}return o.addFragment_1ve0tm$(new Zn(a,s)),g}}(t,e)),g}}function Eo(t,e){return function(n){var i,r=new Zi;return n.getString_hyc7mn$(Do().QUERY,(i=r,function(t){return i.setQuery_61zpoe$(t),g})).getString_hyc7mn$(Do().ID,function(t){return function(e){return t.setId_61zpoe$(e),g}}(r)).getString_hyc7mn$(Do().NAME,function(t){return function(e){return t.setName_61zpoe$(e),g}}(r)).forExistingStrings_hyc7mn$(Do().HIGHLIGHTS,function(t){return function(e){return t.addHighlight_61zpoe$(e),g}}(r)).getExistingString_hyc7mn$(Do().BOUNDARY,function(t,e){return function(n){return t.setBoundary_dfy5bc$(e.readGeometry_0(n)),g}}(r,t)).getExistingObject_6k19qz$(Do().CENTROID,function(t,e){return function(n){return t.setCentroid_o5m5pd$(e.parseCentroid_0(n)),g}}(r,t)).getExistingObject_6k19qz$(Do().LIMIT,function(t,e){return function(n){return t.setLimit_emtjl$(e.parseGeoRectangle_0(n)),g}}(r,t)).getExistingObject_6k19qz$(Do().POSITION,function(t,e){return function(n){return t.setPosition_emtjl$(e.parseGeoRectangle_0(n)),g}}(r,t)).getExistingObject_6k19qz$(Do().FRAGMENTS,ko(r,t)),e.addGeocodedFeature_sv8o3d$(r.build()),g}}function Co(t,e){return function(n){return n.getOptionalEnum_651ru9$(Do().LEVEL,function(t){return function(e){return t.setLevel_ywpjnb$(e),g}}(t),Xn()).forObjects_6k19qz$(Do().FEATURES,Eo(e,t)),g}}function So(t){return function(e){return e.getString_hyc7mn$(Do().NAMESAKE_NAME,function(t){return function(e){return t.addParentName_61zpoe$(e),g}}(t)).getEnum_651ru9$(Do().LEVEL,function(t){return function(e){return t.addParentLevel_5pii6g$(e),g}}(t),Xn()),g}}function To(t){return function(e){var n,i=new Qi;return e.getString_hyc7mn$(Do().NAMESAKE_NAME,(n=i,function(t){return n.setName_61zpoe$(t),g})).forObjects_6k19qz$(Do().NAMESAKE_PARENTS,So(i)),t.addNamesakeExample_ulfa63$(i.build()),g}}function Oo(t){return function(e){var n,i=new Ji;return e.getString_hyc7mn$(Do().QUERY,(n=i,function(t){return n.setQuery_61zpoe$(t),g})).getInt_qoz5hj$(Do().NAMESAKE_COUNT,function(t){return function(e){return t.setTotalNamesakeCount_za3lpa$(e),g}}(i)).forObjects_6k19qz$(Do().NAMESAKE_EXAMPLES,To(i)),t.addAmbiguousFeature_1j15ng$(i.build()),g}}function No(t){return function(e){return e.getOptionalEnum_651ru9$(Do().LEVEL,function(t){return function(e){return t.setLevel_ywpjnb$(e),g}}(t),Xn()).forObjects_6k19qz$(Do().FEATURES,Oo(t)),g}}xo.prototype.parse_bkhwtg$=function(t){var e,n=qt(t),i=n.getEnum_xwn52g$(Do().STATUS,Go());switch(i.name){case"SUCCESS":e=this.success_0(n);break;case"AMBIGUOUS":e=this.ambiguous_0(n);break;case"ERROR":e=this.error_0(n);break;default:throw P("Unknown response status: "+i)}return e},xo.prototype.success_0=function(t){var e=new Wi;return t.getObject_6k19qz$(Do().DATA,Co(e,this)),e.build()},xo.prototype.ambiguous_0=function(t){var e=new Xi;return t.getObject_6k19qz$(Do().DATA,No(e)),e.build()},xo.prototype.error_0=function(t){return new qi(t.getString_61zpoe$(Do().MESSAGE))},xo.prototype.parseCentroid_0=function(t){return v(t.getDouble_61zpoe$(Do().LON),t.getDouble_61zpoe$(Do().LAT))},xo.prototype.readGeometry_0=function(t){return Un().fromGeoJson_61zpoe$(t)},xo.prototype.readBoundary_0=function(t){return Un().fromTwkb_61zpoe$(t)},xo.prototype.parseGeoRectangle_0=function(t){return mo().parseGeoRectangle_bkhwtg$(t.get())},xo.$metadata$={kind:m,simpleName:"ResponseJsonParser",interfaces:[]};var Po=null;function Ao(){return null===Po&&new xo,Po}function jo(){zo=this,this.STATUS="status",this.MESSAGE="message",this.DATA="data",this.FEATURES="features",this.LEVEL="level",this.QUERY="query",this.ID="id",this.NAME="name",this.HIGHLIGHTS="highlights",this.BOUNDARY="boundary",this.FRAGMENTS="tiles",this.LIMIT="limit",this.CENTROID="centroid",this.POSITION="position",this.LON="lon",this.LAT="lat",this.NAMESAKE_COUNT="total_namesake_count",this.NAMESAKE_EXAMPLES="namesake_examples",this.NAMESAKE_NAME="name",this.NAMESAKE_PARENTS="parents"}jo.$metadata$={kind:m,simpleName:"ResponseKeys",interfaces:[]};var Lo,Ro,Io,zo=null;function Do(){return null===zo&&new jo,zo}function Mo(t,e){L.call(this),this.name$=t,this.ordinal$=e}function Bo(){Bo=function(){},Lo=new Mo("SUCCESS",0),Ro=new Mo("AMBIGUOUS",1),Io=new Mo("ERROR",2)}function Uo(){return Bo(),Lo}function Fo(){return Bo(),Ro}function qo(){return Bo(),Io}function Go(){return[Uo(),Fo(),qo()]}function Ho(t){ea(),this.myTwkb_mge4rt$_0=t}function Yo(){ta=this}Mo.$metadata$={kind:$,simpleName:"ResponseStatus",interfaces:[L]},Mo.values=Go,Mo.valueOf_61zpoe$=function(t){switch(t){case"SUCCESS":return Uo();case"AMBIGUOUS":return Fo();case"ERROR":return qo();default:R("No enum constant jetbrains.gis.geoprotocol.json.ResponseStatus."+t)}},Yo.prototype.createEmpty=function(){return new Ho(new Int8Array(0))},Yo.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var Vo,Ko,Wo,Xo,Zo,Jo,Qo,ta=null;function ea(){return null===ta&&new Yo,ta}function na(){}function ia(t){na.call(this),this.styleName=t}function ra(t,e,n){na.call(this),this.key=t,this.zoom=e,this.bbox=n}function oa(t){na.call(this),this.coordinates=t}function aa(t,e,n){this.x=t,this.y=e,this.z=n}function sa(t){this.myGeometryConsumer_0=new la,this.myParser_0=un().parser_gqqjn5$(t.asTwkb(),this.myGeometryConsumer_0)}function la(){this.myTileGeometries_0=z()}function ua(t,e,n,i,r,o,a){this.name=t,this.geometryCollection=e,this.kinds=n,this.subs=i,this.labels=r,this.shorts=o,this.size=a}function ca(){this.name="NoName",this.geometryCollection=ea().createEmpty(),this.kinds=V(),this.subs=V(),this.labels=V(),this.shorts=V(),this.layerSize=0}function pa(t,e){this.myTheme_fy5ei1$_0=e,this.mySocket_8l2uvz$_0=t.build_korocx$(new ss(new xa(this),ie.ThrowableHandlers.instance)),this.myMessageQueue_ew5tg6$_0=new Ea,this.pendingRequests_jgnyu1$_0=new ka,this.mapConfig_7r1z1y$_0=null,this.myIncrement_xi5m5t$_0=0,this.myStatus_68s9dq$_0=va()}function ha(t,e){L.call(this),this.name$=t,this.ordinal$=e}function _a(){_a=function(){},Vo=new ha("COLOR",0),Ko=new ha("LIGHT",1),Wo=new ha("DARK",2)}function fa(){return _a(),Vo}function da(){return _a(),Ko}function ma(){return _a(),Wo}function ya(t,e){L.call(this),this.name$=t,this.ordinal$=e}function $a(){$a=function(){},Xo=new ya("NOT_CONNECTED",0),Zo=new ya("CONFIGURED",1),Jo=new ya("CONNECTING",2),Qo=new ya("ERROR",3)}function va(){return $a(),Xo}function ga(){return $a(),Zo}function ba(){return $a(),Jo}function wa(){return $a(),Qo}function xa(t){this.$outer=t}function ka(){this.lock_0=new ne,this.myAsyncMap_0=Z()}function Ea(){this.myList_0=z(),this.myLock_0=new ne}function Ca(t){this.bytes_0=t,this.count_0=this.bytes_0.length,this.position_0=0}function Sa(t){this.byteArrayStream_0=new Ca(t),this.key_0=this.readString_0(),this.tileLayers_0=this.readLayers_0()}function Ta(){this.myClient_0=lt()}function Oa(t,e,n,i,r,o){at.call(this,o),this.$controller=r,this.exceptionState_0=13,this.local$this$HttpTileTransport=t,this.local$closure$url=e,this.local$closure$async=n,this.local$response=void 0}function Na(){Ra=this,this.MIN_ZOOM_FIELD_0="minZoom",this.MAX_ZOOM_FIELD_0="maxZoom",this.ZOOMS_0="zooms",this.LAYERS_0="layers",this.BORDER_0="border",this.TABLE_0="table",this.COLUMNS_0="columns",this.ORDER_0="order",this.COLORS_0="colors",this.STYLES_0="styles",this.TILE_SHEETS_0="tiles",this.BACKGROUND_0="background",this.FILTER_0="filter",this.GT_0="$gt",this.GTE_0="$gte",this.LT_0="$lt",this.LTE_0="$lte",this.SYMBOLIZER_0="symbolizer",this.TYPE_0="type",this.FILL_0="fill",this.STROKE_0="stroke",this.STROKE_WIDTH_0="stroke-width",this.LINE_CAP_0="stroke-linecap",this.LINE_JOIN_0="stroke-linejoin",this.LABEL_FIELD_0="label",this.FONT_STYLE_0="fontStyle",this.FONT_FACE_0="fontface",this.TEXT_TRANSFORM_0="text-transform",this.SIZE_0="size",this.WRAP_WIDTH_0="wrap-width",this.MINIMUM_PADDING_0="minimum-padding",this.REPEAT_DISTANCE_0="repeat-distance",this.SHIELD_CORNER_RADIUS_0="shield-corner-radius",this.SHIELD_FILL_COLOR_0="shield-fill-color",this.SHIELD_STROKE_COLOR_0="shield-stroke-color",this.MIN_ZOOM_0=1,this.MAX_ZOOM_0=15}function Pa(t){var e;return"string"==typeof(e=t)?e:M()}function Aa(t,n){return function(i){return i.forEntries_ophlsb$(function(t,n){return function(i,r){var o,a,s,l,u,c;if(e.isType(r,Gt)){var p,h=S(Q(r,10));for(p=r.iterator();p.hasNext();){var _=p.next();h.add_11rb$(_e(_))}l=h,o=function(t){return l.contains_11rb$(t)}}else if(e.isNumber(r))s=_e(r),o=function(t){return t===s};else{if(!e.isType(r,ce))throw P("Unsupported filter type.");o=t.makeCompareFunctions_0(qt(r))}return a=o,n.addFilterFunction_xmiwn3$((u=a,c=i,function(t){return u(t.getFieldValue_61zpoe$(c))})),g}}(t,n)),g}}function ja(t,e,n){return function(i){var r,o=new as;return i.getExistingString_hyc7mn$(t.TYPE_0,(r=o,function(t){return r.type=t,g})).getExistingString_hyc7mn$(t.FILL_0,function(t,e){return function(n){return e.fill=t.get_11rb$(n),g}}(e,o)).getExistingString_hyc7mn$(t.STROKE_0,function(t,e){return function(n){return e.stroke=t.get_11rb$(n),g}}(e,o)).getExistingDouble_l47sdb$(t.STROKE_WIDTH_0,function(t){return function(e){return t.strokeWidth=e,g}}(o)).getExistingString_hyc7mn$(t.LINE_CAP_0,function(t){return function(e){return t.lineCap=e,g}}(o)).getExistingString_hyc7mn$(t.LINE_JOIN_0,function(t){return function(e){return t.lineJoin=e,g}}(o)).getExistingString_hyc7mn$(t.LABEL_FIELD_0,function(t){return function(e){return t.labelField=e,g}}(o)).getExistingString_hyc7mn$(t.FONT_STYLE_0,function(t){return function(e){return t.fontStyle=e,g}}(o)).getExistingString_hyc7mn$(t.FONT_FACE_0,function(t){return function(e){return t.fontFamily=e,g}}(o)).getExistingString_hyc7mn$(t.TEXT_TRANSFORM_0,function(t){return function(e){return t.textTransform=e,g}}(o)).getExistingDouble_l47sdb$(t.SIZE_0,function(t){return function(e){return t.size=e,g}}(o)).getExistingDouble_l47sdb$(t.WRAP_WIDTH_0,function(t){return function(e){return t.wrapWidth=e,g}}(o)).getExistingDouble_l47sdb$(t.MINIMUM_PADDING_0,function(t){return function(e){return t.minimumPadding=e,g}}(o)).getExistingDouble_l47sdb$(t.REPEAT_DISTANCE_0,function(t){return function(e){return t.repeatDistance=e,g}}(o)).getExistingDouble_l47sdb$(t.SHIELD_CORNER_RADIUS_0,function(t){return function(e){return t.shieldCornerRadius=e,g}}(o)).getExistingString_hyc7mn$(t.SHIELD_FILL_COLOR_0,function(t,e){return function(n){return e.shieldFillColor=t.get_11rb$(n),g}}(e,o)).getExistingString_hyc7mn$(t.SHIELD_STROKE_COLOR_0,function(t,e){return function(n){return e.shieldStrokeColor=t.get_11rb$(n),g}}(e,o)),n.style_wyrdse$(o),g}}function La(t,e){return function(n){var i=Z();return n.forArrEntries_2wy1dl$(function(t,e){return function(n,i){var r,o=e,a=S(Q(i,10));for(r=i.iterator();r.hasNext();){var s,l=r.next();a.add_11rb$(he(t,"string"==typeof(s=l)?s:M()))}return o.put_xwzc9p$(n,a),g}}(t,i)),e.rulesByTileSheet=i,g}}Ho.prototype.asTwkb=function(){return this.myTwkb_mge4rt$_0},Ho.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Ho)||M(),!!Vt(this.myTwkb_mge4rt$_0,t.myTwkb_mge4rt$_0))},Ho.prototype.hashCode=function(){return Kt(this.myTwkb_mge4rt$_0)},Ho.prototype.toString=function(){return"GeometryCollection(myTwkb="+this.myTwkb_mge4rt$_0+")"},Ho.$metadata$={kind:$,simpleName:"GeometryCollection",interfaces:[]},ia.$metadata$={kind:$,simpleName:"ConfigureConnectionRequest",interfaces:[na]},ra.$metadata$={kind:$,simpleName:"GetBinaryGeometryRequest",interfaces:[na]},oa.$metadata$={kind:$,simpleName:"CancelBinaryTileRequest",interfaces:[na]},na.$metadata$={kind:$,simpleName:"Request",interfaces:[]},aa.prototype.toString=function(){return this.z.toString()+"-"+this.x+"-"+this.y},aa.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,aa)||M(),this.x===t.x&&this.y===t.y&&this.z===t.z)},aa.prototype.hashCode=function(){var t=this.x;return(31*(t=(31*t|0)+this.y|0)|0)+this.z|0},aa.$metadata$={kind:$,simpleName:"TileCoordinates",interfaces:[]},Object.defineProperty(sa.prototype,"geometries",{configurable:!0,get:function(){return this.myGeometryConsumer_0.tileGeometries}}),sa.prototype.resume=function(){return this.myParser_0.next()},Object.defineProperty(la.prototype,"tileGeometries",{configurable:!0,get:function(){return this.myTileGeometries_0}}),la.prototype.onPoint_adb7pk$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiPoint_xgn53i$(new x(Y(Xt(t)))))},la.prototype.onLineString_1u6eph$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiLineString_bc4hlz$(new k(Y(Zt(t)))))},la.prototype.onPolygon_z3kb82$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiPolygon_8ft4gs$(new E(Y(Jt(t)))))},la.prototype.onMultiPoint_oeq1z7$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiPoint_xgn53i$(Qt(t)))},la.prototype.onMultiLineString_6n275e$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiLineString_bc4hlz$(te(t)))},la.prototype.onMultiPolygon_a0zxnd$=function(t){this.myTileGeometries_0.add_11rb$(Wt.Companion.createMultiPolygon_8ft4gs$(ee(t)))},la.$metadata$={kind:$,simpleName:"MyGeometryConsumer",interfaces:[G]},sa.$metadata$={kind:$,simpleName:"TileGeometryParser",interfaces:[]},ua.$metadata$={kind:$,simpleName:"TileLayer",interfaces:[]},ua.prototype.component1=function(){return this.name},ua.prototype.component2=function(){return this.geometryCollection},ua.prototype.component3=function(){return this.kinds},ua.prototype.component4=function(){return this.subs},ua.prototype.component5=function(){return this.labels},ua.prototype.component6=function(){return this.shorts},ua.prototype.component7=function(){return this.size},ua.prototype.copy_4csmna$=function(t,e,n,i,r,o,a){return new ua(void 0===t?this.name:t,void 0===e?this.geometryCollection:e,void 0===n?this.kinds:n,void 0===i?this.subs:i,void 0===r?this.labels:r,void 0===o?this.shorts:o,void 0===a?this.size:a)},ua.prototype.toString=function(){return"TileLayer(name="+e.toString(this.name)+", geometryCollection="+e.toString(this.geometryCollection)+", kinds="+e.toString(this.kinds)+", subs="+e.toString(this.subs)+", labels="+e.toString(this.labels)+", shorts="+e.toString(this.shorts)+", size="+e.toString(this.size)+")"},ua.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*(t=31*(t=31*(t=31*t+e.hashCode(this.name)|0)+e.hashCode(this.geometryCollection)|0)+e.hashCode(this.kinds)|0)+e.hashCode(this.subs)|0)+e.hashCode(this.labels)|0)+e.hashCode(this.shorts)|0)+e.hashCode(this.size)|0},ua.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)&&e.equals(this.geometryCollection,t.geometryCollection)&&e.equals(this.kinds,t.kinds)&&e.equals(this.subs,t.subs)&&e.equals(this.labels,t.labels)&&e.equals(this.shorts,t.shorts)&&e.equals(this.size,t.size)},ca.prototype.build=function(){return new ua(this.name,this.geometryCollection,this.kinds,this.subs,this.labels,this.shorts,this.layerSize)},ca.$metadata$={kind:$,simpleName:"TileLayerBuilder",interfaces:[]},ha.$metadata$={kind:$,simpleName:"Theme",interfaces:[L]},ha.values=function(){return[fa(),da(),ma()]},ha.valueOf_61zpoe$=function(t){switch(t){case"COLOR":return fa();case"LIGHT":return da();case"DARK":return ma();default:R("No enum constant jetbrains.gis.tileprotocol.TileService.Theme."+t)}},Object.defineProperty(pa.prototype,"mapConfig",{configurable:!0,get:function(){return this.mapConfig_7r1z1y$_0},set:function(t){this.mapConfig_7r1z1y$_0=t}}),pa.prototype.getTileData_h9hod0$=function(t,n){var i,r=(i=this.myIncrement_xi5m5t$_0,this.myIncrement_xi5m5t$_0=i+1|0,i).toString(),o=new tt;this.pendingRequests_jgnyu1$_0.put_9yqal7$(r,o);try{var a=new ra(r,n,t),s=y("format",function(t,e){return t.format_scn9es$(e)}.bind(null,Ma()))(a),l=y("formatJson",function(t,e){return t.formatJson_za3rmp$(e)}.bind(null,et.JsonSupport))(s);y("sendGeometryRequest",function(t,e){return t.sendGeometryRequest_rzspr3$_0(e),g}.bind(null,this))(l)}catch(t){if(!e.isType(t,rt))throw t;this.pendingRequests_jgnyu1$_0.poll_61zpoe$(r).failure_tcv7n7$(t)}return o},pa.prototype.sendGeometryRequest_rzspr3$_0=function(t){switch(this.myStatus_68s9dq$_0.name){case"NOT_CONNECTED":this.myMessageQueue_ew5tg6$_0.add_11rb$(t),this.myStatus_68s9dq$_0=ba(),this.mySocket_8l2uvz$_0.connect();break;case"CONFIGURED":this.mySocket_8l2uvz$_0.send_61zpoe$(t);break;case"CONNECTING":this.myMessageQueue_ew5tg6$_0.add_11rb$(t);break;case"ERROR":throw P("Socket error")}},pa.prototype.sendInitMessage_n8ehnp$_0=function(){var t=new ia(this.myTheme_fy5ei1$_0.name.toLowerCase()),e=y("format",function(t,e){return t.format_scn9es$(e)}.bind(null,Ma()))(t),n=et.JsonSupport.formatJson_za3rmp$(e);y("send",function(t,e){return t.send_61zpoe$(e),g}.bind(null,this.mySocket_8l2uvz$_0))(n)},ya.$metadata$={kind:$,simpleName:"SocketStatus",interfaces:[L]},ya.values=function(){return[va(),ga(),ba(),wa()]},ya.valueOf_61zpoe$=function(t){switch(t){case"NOT_CONNECTED":return va();case"CONFIGURED":return ga();case"CONNECTING":return ba();case"ERROR":return wa();default:R("No enum constant jetbrains.gis.tileprotocol.TileService.SocketStatus."+t)}},xa.prototype.onOpen=function(){this.$outer.sendInitMessage_n8ehnp$_0()},xa.prototype.onClose_61zpoe$=function(t){this.$outer.myMessageQueue_ew5tg6$_0.add_11rb$(t),this.$outer.myStatus_68s9dq$_0===ga()&&(this.$outer.myStatus_68s9dq$_0=ba(),this.$outer.mySocket_8l2uvz$_0.connect())},xa.prototype.onError_tcv7n7$=function(t){this.$outer.myStatus_68s9dq$_0=wa(),this.failPending_0(t)},xa.prototype.onTextMessage_61zpoe$=function(t){null==this.$outer.mapConfig&&(this.$outer.mapConfig=Ia().parse_jbvn2s$(et.JsonSupport.parseJson_61zpoe$(t))),this.$outer.myStatus_68s9dq$_0=ga();var e=this.$outer.myMessageQueue_ew5tg6$_0;this.$outer;var n=this.$outer;e.forEach_qlkmfe$(y("send",function(t,e){return t.send_61zpoe$(e),g}.bind(null,n.mySocket_8l2uvz$_0))),e.clear()},xa.prototype.onBinaryMessage_fqrh44$=function(t){try{var n=new Sa(t);this.$outer;var i=this.$outer,r=n.component1(),o=n.component2();i.pendingRequests_jgnyu1$_0.poll_61zpoe$(r).success_11rb$(o)}catch(t){if(!e.isType(t,rt))throw t;this.failPending_0(t)}},xa.prototype.failPending_0=function(t){var e;for(e=this.$outer.pendingRequests_jgnyu1$_0.pollAll().values.iterator();e.hasNext();)e.next().failure_tcv7n7$(t)},xa.$metadata$={kind:$,simpleName:"TileSocketHandler",interfaces:[ps]},ka.prototype.put_9yqal7$=function(t,e){var n=this.lock_0;try{n.lock(),this.myAsyncMap_0.put_xwzc9p$(t,e)}finally{n.unlock()}},ka.prototype.pollAll=function(){var t=this.lock_0;try{t.lock();var e=K(this.myAsyncMap_0);return this.myAsyncMap_0.clear(),e}finally{t.unlock()}},ka.prototype.poll_61zpoe$=function(t){var e=this.lock_0;try{return e.lock(),A(this.myAsyncMap_0.remove_11rb$(t))}finally{e.unlock()}},ka.$metadata$={kind:$,simpleName:"RequestMap",interfaces:[]},Ea.prototype.add_11rb$=function(t){var e=this.myLock_0;try{e.lock(),this.myList_0.add_11rb$(t)}finally{e.unlock()}},Ea.prototype.forEach_qlkmfe$=function(t){var e=this.myLock_0;try{var n;for(e.lock(),n=this.myList_0.iterator();n.hasNext();)t(n.next())}finally{e.unlock()}},Ea.prototype.clear=function(){var t=this.myLock_0;try{t.lock(),this.myList_0.clear()}finally{t.unlock()}},Ea.$metadata$={kind:$,simpleName:"ThreadSafeMessageQueue",interfaces:[]},pa.$metadata$={kind:$,simpleName:"TileService",interfaces:[]},Ca.prototype.available=function(){return this.count_0-this.position_0|0},Ca.prototype.read=function(){var t;if(this.position_0=this.count_0)throw P("Array size exceeded.");if(t>this.available())throw P("Expected to read "+t+" bytea, but read "+this.available());if(t<=0)return new Int8Array(0);var e=this.position_0;return this.position_0=this.position_0+t|0,re(this.bytes_0,e,this.position_0)},Ca.$metadata$={kind:$,simpleName:"ByteArrayStream",interfaces:[]},Sa.prototype.readLayers_0=function(){var t=z();do{var e=this.byteArrayStream_0.available(),n=new ca;n.name=this.readString_0();var i=hn().readVarUInt_t0n4v2$(y("readByte",function(t){return t.readByte_0()}.bind(null,this)));n.geometryCollection=new Ho(y("read",function(t,e){return t.read_za3lpa$(e)}.bind(null,this.byteArrayStream_0))(i)),n.kinds=this.readInts_0(),n.subs=this.readInts_0(),n.labels=this.readStrings_0(),n.shorts=this.readStrings_0(),n.layerSize=e-this.byteArrayStream_0.available()|0;var r=n.build();y("add",function(t,e){return t.add_11rb$(e)}.bind(null,t))(r)}while(this.byteArrayStream_0.available()>0);return t},Sa.prototype.readInts_0=function(){var t,e=hn().readVarUInt_t0n4v2$(y("readByte",function(t){return t.readByte_0()}.bind(null,this)));if(e>0){var n,i=oe(0,e),r=S(Q(i,10));for(n=i.iterator();n.hasNext();)n.next(),r.add_11rb$(hn().readVarUInt_t0n4v2$(y("readByte",function(t){return t.readByte_0()}.bind(null,this))));t=r}else{if(0!==e)throw d();t=V()}return t},Sa.prototype.readStrings_0=function(){var t,e=hn().readVarUInt_t0n4v2$(y("readByte",function(t){return t.readByte_0()}.bind(null,this)));if(e>0){var n,i=oe(0,e),r=S(Q(i,10));for(n=i.iterator();n.hasNext();)n.next(),r.add_11rb$(this.readString_0());t=r}else{if(0!==e)throw d();t=V()}return t},Sa.prototype.readString_0=function(){var t,e=hn().readVarUInt_t0n4v2$(y("readByte",function(t){return t.readByte_0()}.bind(null,this)));if(e>0)t=(new ae).decode_fqrh44$(this.byteArrayStream_0.read_za3lpa$(e));else{if(0!==e)throw d();t=""}return t},Sa.prototype.readByte_0=function(){return this.byteArrayStream_0.read()},Sa.prototype.component1=function(){return this.key_0},Sa.prototype.component2=function(){return this.tileLayers_0},Sa.$metadata$={kind:$,simpleName:"ResponseTileDecoder",interfaces:[]},Oa.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},Oa.prototype=Object.create(at.prototype),Oa.prototype.constructor=Oa,Oa.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.exceptionState_0=9;var t,n=this.local$this$HttpTileTransport.myClient_0,i=this.local$closure$url;"localhost",t=ct.EmptyContent;var r=new _t;pt(r,"http","localhost",0,"/"),r.method=ht.Companion.Get,r.body=t,ut(r.url,i);var o,a,s,l=new ft(r,n);if(U(o=se,dt(ft))){this.result_0=e.isByteArray(a=l)?a:M(),this.state_0=8;continue}if(U(o,dt(mt))){if(this.state_0=6,this.result_0=l.execute(this),this.result_0===ot)return ot;continue}if(this.state_0=1,this.result_0=l.executeUnsafe(this),this.result_0===ot)return ot;continue;case 1:var u;this.local$response=this.result_0,this.exceptionState_0=4;var c,p=this.local$response.call;t:do{try{c=new vt(se,$t.JsType,it(se,[],!1))}catch(t){c=new vt(se,$t.JsType);break t}}while(0);if(this.state_0=2,this.result_0=p.receive_jo9acv$(c,this),this.result_0===ot)return ot;continue;case 2:this.result_0=e.isByteArray(u=this.result_0)?u:M(),this.exceptionState_0=9,this.finallyPath_0=[3],this.state_0=5;continue;case 3:this.state_0=7;continue;case 4:this.finallyPath_0=[9],this.state_0=5;continue;case 5:this.exceptionState_0=9,yt(this.local$response),this.state_0=this.finallyPath_0.shift();continue;case 6:this.result_0=e.isByteArray(s=this.result_0)?s:M(),this.state_0=7;continue;case 7:this.state_0=8;continue;case 8:this.result_0;var h=this.result_0;return this.local$closure$async.success_11rb$(h),g;case 9:this.exceptionState_0=13;var _=this.exception_0;if(e.isType(_,ue))return this.local$closure$async.failure_tcv7n7$(le(_.response.status.toString())),g;if(e.isType(_,rt))return this.local$closure$async.failure_tcv7n7$(_),g;throw _;case 10:this.state_0=11;continue;case 11:this.state_0=12;continue;case 12:return;case 13:throw this.exception_0;default:throw this.state_0=13,new Error("State Machine Unreachable execution")}}catch(t){if(13===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},Ta.prototype.get_61zpoe$=function(t){var e,n,i,r=new tt;return st(this.myClient_0,void 0,void 0,(e=this,n=t,i=r,function(t,r,o){var a=new Oa(e,n,i,t,this,r);return o?a:a.doResume(null)})),r},Ta.$metadata$={kind:$,simpleName:"HttpTileTransport",interfaces:[]},Na.prototype.parse_jbvn2s$=function(t){var e=qt(t),n=this.readColors_0(e.getObject_61zpoe$(this.COLORS_0)),i=this.readStyles_0(e.getObject_61zpoe$(this.STYLES_0),n);return(new ns).tileSheetBackgrounds_5rxuhj$(this.readTileSheets_0(e.getObject_61zpoe$(this.TILE_SHEETS_0),n)).colors_5rxuhj$(n).layerNamesByZoom_qqdhea$(this.readZooms_0(e.getObject_61zpoe$(this.ZOOMS_0))).layers_c08aqx$(this.readLayers_0(e.getObject_61zpoe$(this.LAYERS_0),i)).build()},Na.prototype.readStyles_0=function(t,n){var i,r,o,a=Z();return t.forArrEntries_2wy1dl$((i=n,r=this,o=a,function(t,n){var a,s=o,l=S(Q(n,10));for(a=n.iterator();a.hasNext();){var u,c=a.next(),p=l.add_11rb$,h=i;p.call(l,r.readRule_0(qt(e.isType(u=c,ce)?u:M()),h))}return s.put_xwzc9p$(t,l),g})),a},Na.prototype.readZooms_0=function(t){for(var e=Z(),n=1;n<=15;n++){var i=Yt(Tt(t.getArray_61zpoe$(n.toString()).stream(),Pa));e.put_xwzc9p$(n,i)}return e},Na.prototype.readLayers_0=function(t,e){var n,i,r,o=Z();return t.forObjEntries_izf7h5$((n=e,i=this,r=o,function(t,e){var o=r,a=i.parseLayerConfig_0(t,qt(e),n);return o.put_xwzc9p$(t,a),g})),o},Na.prototype.readColors_0=function(t){var e,n,i=Z();return t.forEntries_ophlsb$((e=this,n=i,function(t,i){var r,o;o="string"==typeof(r=i)?r:M();var a=n,s=e.parseHexWithAlpha_0(o);return a.put_xwzc9p$(t,s),g})),i},Na.prototype.readTileSheets_0=function(t,e){var n,i,r,o=Z();return t.forObjEntries_izf7h5$((n=e,i=this,r=o,function(t,e){var o=r,a=he(n,pe(e,i.BACKGROUND_0));return o.put_xwzc9p$(t,a),g})),o},Na.prototype.readRule_0=function(t,e){var n=new os;return t.getIntOrDefault_u1i54l$(this.MIN_ZOOM_FIELD_0,y("minZoom",function(t,e){return t.minZoom_za3lpa$(e),g}.bind(null,n)),1).getIntOrDefault_u1i54l$(this.MAX_ZOOM_FIELD_0,y("maxZoom",function(t,e){return t.maxZoom_za3lpa$(e),g}.bind(null,n)),15).getExistingObject_6k19qz$(this.FILTER_0,Aa(this,n)).getExistingObject_6k19qz$(this.SYMBOLIZER_0,ja(this,e,n)),n.build()},Na.prototype.makeCompareFunctions_0=function(t){if(t.contains_61zpoe$(this.GT_0))return e=t.getInt_61zpoe$(this.GT_0),function(t){return t>e};var e;if(t.contains_61zpoe$(this.GTE_0))return function(t){return function(e){return e>=t}}(t.getInt_61zpoe$(this.GTE_0));if(t.contains_61zpoe$(this.LT_0))return function(t){return function(e){return ee)return!1;for(n=this.filters.iterator();n.hasNext();)if(!n.next()(t))return!1;return!0},Object.defineProperty(os.prototype,"style_0",{configurable:!0,get:function(){return null==this.style_czizc7$_0?C("style"):this.style_czizc7$_0},set:function(t){this.style_czizc7$_0=t}}),os.prototype.minZoom_za3lpa$=function(t){this.minZoom_0=t},os.prototype.maxZoom_za3lpa$=function(t){this.maxZoom_0=t},os.prototype.style_wyrdse$=function(t){this.style_0=t},os.prototype.addFilterFunction_xmiwn3$=function(t){this.filters_0.add_11rb$(t)},os.prototype.build=function(){return new rs(A(this.minZoom_0),A(this.maxZoom_0),this.filters_0,this.style_0)},os.$metadata$={kind:$,simpleName:"RuleBuilder",interfaces:[]},rs.$metadata$={kind:$,simpleName:"Rule",interfaces:[]},as.$metadata$={kind:$,simpleName:"Style",interfaces:[]},ss.prototype.safeRun_0=function(t){try{t()}catch(t){if(!e.isType(t,rt))throw t;this.myThrowableHandler_0.handle_tcv7n7$(t)}},ss.prototype.onClose_61zpoe$=function(t){var e,n;this.safeRun_0((e=this,n=t,function(){return e.myHandler_0.onClose_61zpoe$(n),g}))},ss.prototype.onError_tcv7n7$=function(t){var e,n;this.safeRun_0((e=this,n=t,function(){return e.myHandler_0.onError_tcv7n7$(n),g}))},ss.prototype.onTextMessage_61zpoe$=function(t){var e,n;this.safeRun_0((e=this,n=t,function(){return e.myHandler_0.onTextMessage_61zpoe$(n),g}))},ss.prototype.onBinaryMessage_fqrh44$=function(t){var e,n;this.safeRun_0((e=this,n=t,function(){return e.myHandler_0.onBinaryMessage_fqrh44$(n),g}))},ss.prototype.onOpen=function(){var t;this.safeRun_0((t=this,function(){return t.myHandler_0.onOpen(),g}))},ss.$metadata$={kind:$,simpleName:"SafeSocketHandler",interfaces:[ps]},ls.$metadata$={kind:D,simpleName:"Socket",interfaces:[]},cs.$metadata$={kind:$,simpleName:"BaseSocketBuilder",interfaces:[us]},us.$metadata$={kind:D,simpleName:"SocketBuilder",interfaces:[]},ps.$metadata$={kind:D,simpleName:"SocketHandler",interfaces:[]},_s.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},_s.prototype=Object.create(at.prototype),_s.prototype.constructor=_s,_s.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:this.local$this$TileWebSocket.mySession_0=this.local$$receiver,this.local$this$TileWebSocket.myHandler_0.onOpen(),this.local$tmp$=this.local$$receiver.incoming.iterator(),this.state_0=2;continue;case 1:throw this.exception_0;case 2:if(this.state_0=3,this.result_0=this.local$tmp$.hasNext(this),this.result_0===ot)return ot;continue;case 3:if(this.result_0){this.state_0=4;continue}this.state_0=5;continue;case 4:var t=this.local$tmp$.next();e.isType(t,Ee)?this.local$this$TileWebSocket.myHandler_0.onTextMessage_61zpoe$(ke(t)):e.isType(t,Se)&&this.local$this$TileWebSocket.myHandler_0.onBinaryMessage_fqrh44$(Ce(t)),this.state_0=2;continue;case 5:return g;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},ds.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},ds.prototype=Object.create(at.prototype),ds.prototype.constructor=ds,ds.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:if(this.state_0=2,this.result_0=Te(this.local$this$,this.local$this$TileWebSocket.myUrl_0,void 0,fs(this.local$this$TileWebSocket),this),this.result_0===ot)return ot;continue;case 1:throw this.exception_0;case 2:return this.result_0;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},hs.prototype.connect=function(){var t,e,n=this.myClient_0;st(n,void 0,void 0,(t=this,e=n,function(n,i,r){var o=new ds(t,e,n,this,i);return r?o:o.doResume(null)}))},ms.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},ms.prototype=Object.create(at.prototype),ms.prototype.constructor=ms,ms.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(null!=(t=this.local$this$TileWebSocket.mySession_0)){if(this.state_0=2,this.result_0=Pe(t,Ne(Oe.NORMAL,"Close session"),this),this.result_0===ot)return ot;continue}this.result_0=null,this.state_0=3;continue;case 1:throw this.exception_0;case 2:this.result_0=g,this.state_0=3;continue;case 3:return this.local$this$TileWebSocket.mySession_0=null,g;default:throw this.state_0=1,new Error("State Machine Unreachable execution")}}catch(t){if(1===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},hs.prototype.close=function(){var t;st(this.myClient_0,void 0,void 0,(t=this,function(e,n,i){var r=new ms(t,e,this,n);return i?r:r.doResume(null)}))},ys.$metadata$={kind:e.Kind.CLASS,simpleName:null,interfaces:[at]},ys.prototype=Object.create(at.prototype),ys.prototype.constructor=ys,ys.prototype.doResume=function(){for(;;)try{switch(this.state_0){case 0:var t;if(null!=(t=this.local$this$TileWebSocket.mySession_0)){if(this.local$closure$msg_0=this.local$closure$msg,this.local$this$TileWebSocket_0=this.local$this$TileWebSocket,this.exceptionState_0=2,this.state_0=1,this.result_0=t.outgoing.send_11rb$(Ae(this.local$closure$msg_0),this),this.result_0===ot)return ot;continue}this.local$tmp$=null,this.state_0=4;continue;case 1:this.exceptionState_0=5,this.state_0=3;continue;case 2:this.exceptionState_0=5;var n=this.exception_0;if(!e.isType(n,rt))throw n;this.local$this$TileWebSocket_0.myHandler_0.onClose_61zpoe$(this.local$closure$msg_0),this.state_0=3;continue;case 3:this.local$tmp$=g,this.state_0=4;continue;case 4:return this.local$tmp$;case 5:throw this.exception_0;default:throw this.state_0=5,new Error("State Machine Unreachable execution")}}catch(t){if(5===this.state_0)throw this.exceptionState_0=this.state_0,t;this.state_0=this.exceptionState_0,this.exception_0=t}},hs.prototype.send_61zpoe$=function(t){var e,n;st(this.myClient_0,void 0,void 0,(e=this,n=t,function(t,i,r){var o=new ys(e,n,t,this,i);return r?o:o.doResume(null)}))},hs.$metadata$={kind:$,simpleName:"TileWebSocket",interfaces:[ls]},$s.prototype.build_korocx$=function(t){return new hs(Re(je.Js,vs),t,this.myUrl_0)},$s.$metadata$={kind:$,simpleName:"TileWebSocketBuilder",interfaces:[us]};var gs=t.jetbrains||(t.jetbrains={}),bs=gs.gis||(gs.gis={}),ws=bs.common||(bs.common={}),xs=ws.twkb||(ws.twkb={});xs.InputBuffer=Ie,xs.SimpleFeatureParser=ze,Object.defineProperty(We,"POINT",{get:Ze}),Object.defineProperty(We,"LINESTRING",{get:Je}),Object.defineProperty(We,"POLYGON",{get:Qe}),Object.defineProperty(We,"MULTI_POINT",{get:tn}),Object.defineProperty(We,"MULTI_LINESTRING",{get:en}),Object.defineProperty(We,"MULTI_POLYGON",{get:nn}),Object.defineProperty(We,"GEOMETRY_COLLECTION",{get:rn}),Object.defineProperty(We,"Companion",{get:sn}),Ke.GeometryType=We,Ve.prototype.Parser=Ke,Object.defineProperty(xs,"Twkb",{get:un}),Object.defineProperty(xs,"VarInt",{get:hn}),Object.defineProperty(_n,"Companion",{get:yn});var ks=bs.geoprotocol||(bs.geoprotocol={});ks.Boundary=_n,Object.defineProperty(ks,"Boundaries",{get:Un}),Object.defineProperty(Fn,"COUNTRY",{get:Gn}),Object.defineProperty(Fn,"MACRO_STATE",{get:Hn}),Object.defineProperty(Fn,"STATE",{get:Yn}),Object.defineProperty(Fn,"MACRO_COUNTY",{get:Vn}),Object.defineProperty(Fn,"COUNTY",{get:Kn}),Object.defineProperty(Fn,"CITY",{get:Wn}),ks.FeatureLevel=Fn,ks.Fragment=Zn,Object.defineProperty(Qn,"HIGHLIGHTS",{get:ei}),Object.defineProperty(Qn,"POSITION",{get:ni}),Object.defineProperty(Qn,"CENTROID",{get:ii}),Object.defineProperty(Qn,"LIMIT",{get:ri}),Object.defineProperty(Qn,"BOUNDARY",{get:oi}),Object.defineProperty(Qn,"FRAGMENTS",{get:ai}),Jn.FeatureOption=Qn,Jn.ExplicitSearchRequest=si,Object.defineProperty(ci,"SKIP_ALL",{get:hi}),Object.defineProperty(ci,"SKIP_MISSING",{get:_i}),Object.defineProperty(ci,"SKIP_NAMESAKES",{get:fi}),Object.defineProperty(ci,"TAKE_NAMESAKES",{get:di}),ui.IgnoringStrategy=ci,Object.defineProperty(ui,"Companion",{get:$i}),li.AmbiguityResolver=ui,li.RegionQuery=vi,Jn.GeocodingSearchRequest=li,Jn.ReverseGeocodingSearchRequest=gi,ks.GeoRequest=Jn,bi.prototype.RequestBuilderBase=wi,xi.MyReverseGeocodingSearchRequest=ki,bi.prototype.ReverseGeocodingRequestBuilder=xi,Ei.MyGeocodingSearchRequest=Ci,Object.defineProperty(Ei,"Companion",{get:Oi}),bi.prototype.GeocodingRequestBuilder=Ei,Ni.MyExplicitSearchRequest=Pi,bi.prototype.ExplicitRequestBuilder=Ni,bi.prototype.MyGeoRequestBase=Ai,bi.prototype.MapRegionBuilder=ji,bi.prototype.RegionQueryBuilder=Li,Object.defineProperty(ks,"GeoRequestBuilder",{get:Mi}),Ui.GeocodedFeature=Fi,Bi.SuccessGeoResponse=Ui,Bi.ErrorGeoResponse=qi,Gi.AmbiguousFeature=Hi,Gi.Namesake=Yi,Gi.NamesakeParent=Vi,Bi.AmbiguousGeoResponse=Gi,ks.GeoResponse=Bi,Ki.prototype.SuccessResponseBuilder=Wi,Ki.prototype.AmbiguousResponseBuilder=Xi,Ki.prototype.GeocodedFeatureBuilder=Zi,Ki.prototype.AmbiguousFeatureBuilder=Ji,Ki.prototype.NamesakeBuilder=Qi,ks.GeoTransport=tr,f["ktor-ktor-client-core"]=r,ks.GeoTransportImpl=er,Object.defineProperty(rr,"BY_ID",{get:ar}),Object.defineProperty(rr,"BY_NAME",{get:sr}),Object.defineProperty(rr,"REVERSE",{get:lr}),ks.GeocodingMode=rr,Object.defineProperty(ur,"Companion",{get:dr}),ks.GeocodingService=ur,Object.defineProperty(ks,"GeometryUtil",{get:function(){return null===Lr&&new mr,Lr}}),Object.defineProperty(Rr,"CITY_HIGH",{get:zr}),Object.defineProperty(Rr,"CITY_MEDIUM",{get:Dr}),Object.defineProperty(Rr,"CITY_LOW",{get:Mr}),Object.defineProperty(Rr,"COUNTY_HIGH",{get:Br}),Object.defineProperty(Rr,"COUNTY_MEDIUM",{get:Ur}),Object.defineProperty(Rr,"COUNTY_LOW",{get:Fr}),Object.defineProperty(Rr,"STATE_HIGH",{get:qr}),Object.defineProperty(Rr,"STATE_MEDIUM",{get:Gr}),Object.defineProperty(Rr,"STATE_LOW",{get:Hr}),Object.defineProperty(Rr,"COUNTRY_HIGH",{get:Yr}),Object.defineProperty(Rr,"COUNTRY_MEDIUM",{get:Vr}),Object.defineProperty(Rr,"COUNTRY_LOW",{get:Kr}),Object.defineProperty(Rr,"WORLD_HIGH",{get:Wr}),Object.defineProperty(Rr,"WORLD_MEDIUM",{get:Xr}),Object.defineProperty(Rr,"WORLD_LOW",{get:Zr}),Object.defineProperty(Rr,"Companion",{get:io}),ks.LevelOfDetails=Rr,Object.defineProperty(oo,"Companion",{get:ho}),ks.MapRegion=oo;var Es=ks.json||(ks.json={});Object.defineProperty(Es,"ProtocolJsonHelper",{get:mo}),Object.defineProperty(Es,"RequestJsonFormatter",{get:vo}),Object.defineProperty(Es,"RequestKeys",{get:wo}),Object.defineProperty(Es,"ResponseJsonParser",{get:Ao}),Object.defineProperty(Es,"ResponseKeys",{get:Do}),Object.defineProperty(Mo,"SUCCESS",{get:Uo}),Object.defineProperty(Mo,"AMBIGUOUS",{get:Fo}),Object.defineProperty(Mo,"ERROR",{get:qo}),Es.ResponseStatus=Mo,Object.defineProperty(Ho,"Companion",{get:ea});var Cs=bs.tileprotocol||(bs.tileprotocol={});Cs.GeometryCollection=Ho,na.ConfigureConnectionRequest=ia,na.GetBinaryGeometryRequest=ra,na.CancelBinaryTileRequest=oa,Cs.Request=na,Cs.TileCoordinates=aa,Cs.TileGeometryParser=sa,Cs.TileLayer=ua,Cs.TileLayerBuilder=ca,Object.defineProperty(ha,"COLOR",{get:fa}),Object.defineProperty(ha,"LIGHT",{get:da}),Object.defineProperty(ha,"DARK",{get:ma}),pa.Theme=ha,pa.TileSocketHandler=xa,f["lets-plot-base"]=i,pa.RequestMap=ka,pa.ThreadSafeMessageQueue=Ea,Cs.TileService=pa;var Ss=Cs.binary||(Cs.binary={});Ss.ByteArrayStream=Ca,Ss.ResponseTileDecoder=Sa,(Cs.http||(Cs.http={})).HttpTileTransport=Ta;var Ts=Cs.json||(Cs.json={});Object.defineProperty(Ts,"MapStyleJsonParser",{get:Ia}),Object.defineProperty(Ts,"RequestFormatter",{get:Ma}),f["lets-plot-base-portable"]=n,Object.defineProperty(Ts,"RequestJsonParser",{get:Fa}),Object.defineProperty(Ts,"RequestKeys",{get:Ka}),Object.defineProperty(Wa,"CONFIGURE_CONNECTION",{get:Za}),Object.defineProperty(Wa,"GET_BINARY_TILE",{get:Ja}),Object.defineProperty(Wa,"CANCEL_BINARY_TILE",{get:Qa}),Ts.RequestTypes=Wa;var Os=Cs.mapConfig||(Cs.mapConfig={});Os.LayerConfig=ts,es.MapConfigBuilder=ns,Os.MapConfig=es,Os.TilePredicate=is,rs.RuleBuilder=os,Os.Rule=rs,Os.Style=as;var Ns=Cs.socket||(Cs.socket={});return Ns.SafeSocketHandler=ss,Ns.Socket=ls,us.BaseSocketBuilder=cs,Ns.SocketBuilder=us,Ns.SocketHandler=ps,Ns.TileWebSocket=hs,Ns.TileWebSocketBuilder=$s,bn.prototype.onLineString_1u6eph$=G.prototype.onLineString_1u6eph$,bn.prototype.onMultiLineString_6n275e$=G.prototype.onMultiLineString_6n275e$,bn.prototype.onMultiPoint_oeq1z7$=G.prototype.onMultiPoint_oeq1z7$,bn.prototype.onPoint_adb7pk$=G.prototype.onPoint_adb7pk$,t})?i.apply(e,r):i)||(t.exports=o)},837:function(t,e,n){var i,r,o;r=[e,n(421),n(73),n(602),n(770),n(767),n(623),n(362),n(232),n(179),n(331),n(330),n(698)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o,a,s,l,u,c,p,h){"use strict";var _,f=n.mu,d=e.kotlin.Unit,m=i.jetbrains.datalore.base.jsObject.dynamicObjectToMap_za3rmp$,y=r.jetbrains.datalore.plot.config.PlotConfig,$=e.kotlin.RuntimeException,v=o.jetbrains.datalore.base.geometry.DoubleVector,g=r.jetbrains.datalore.plot,b=r.jetbrains.datalore.plot.MonolithicCommon.PlotsBuildResult.Error,w=e.throwCCE,x=r.jetbrains.datalore.plot.MonolithicCommon.PlotsBuildResult.Success,k=e.ensureNotNull,E=e.kotlinx.dom.createElement_7cgwi1$,C=o.jetbrains.datalore.base.geometry.DoubleRectangle,S=a.jetbrains.datalore.plot.builder.presentation,T=s.jetbrains.datalore.plot.livemap.CursorServiceConfig,O=l.jetbrains.datalore.plot.builder.PlotContainer,N=i.jetbrains.datalore.base.js.css.enumerables.CssCursor,P=i.jetbrains.datalore.base.js.css.setCursor_1m07bc$,A=r.jetbrains.datalore.plot.config.LiveMapOptionsParser,j=s.jetbrains.datalore.plot.livemap,L=u.jetbrains.datalore.vis.svgMapper.dom.SvgRootDocumentMapper,R=c.jetbrains.datalore.vis.svg.SvgNodeContainer,I=i.jetbrains.datalore.base.js.css.enumerables.CssPosition,z=i.jetbrains.datalore.base.js.css.setPosition_h2yxxn$,D=i.jetbrains.datalore.base.js.dom.DomEventType,M=o.jetbrains.datalore.base.event.MouseEventSpec,B=i.jetbrains.datalore.base.event.dom,U=p.jetbrains.datalore.vis.canvasFigure.CanvasFigure,F=i.jetbrains.datalore.base.js.css.setLeft_1gtuon$,q=i.jetbrains.datalore.base.js.css.setTop_1gtuon$,G=i.jetbrains.datalore.base.js.css.setWidth_o105z1$,H=p.jetbrains.datalore.vis.canvas.dom.DomCanvasControl,Y=p.jetbrains.datalore.vis.canvas.dom.DomCanvasControl.DomEventPeer,V=r.jetbrains.datalore.plot.config,K=r.jetbrains.datalore.plot.server.config.PlotConfigServerSide,W=h.jetbrains.datalore.plot.server.config,X=e.kotlin.collections.ArrayList_init_287e2$,Z=e.kotlin.collections.addAll_ipc267$,J=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,Q=e.kotlin.collections.ArrayList_init_ww73n8$,tt=e.kotlin.collections.Collection,et=e.kotlin.text.isBlank_gw00vp$;function nt(t,n,i,r){var o,a,s=n>0&&i>0?new v(n,i):null,l=r.clientWidth,u=g.MonolithicCommon.buildPlotsFromProcessedSpecs_rim63o$(t,s,l);if(u.isError)ut((e.isType(o=u,b)?o:w()).error,r);else{var c,p,h=e.isType(a=u,x)?a:w(),_=h.buildInfos,f=X();for(c=_.iterator();c.hasNext();){var d=c.next().computationMessages;Z(f,d)}for(p=f.iterator();p.hasNext();)ct(p.next(),r);1===h.buildInfos.size?ot(h.buildInfos.get_za3lpa$(0),r):rt(h.buildInfos,r)}}function it(t){return function(e){return e.setAttribute("style","position: absolute; left: "+t.origin.x+"px; top: "+t.origin.y+"px;"),d}}function rt(t,n){var i,r;for(i=t.iterator();i.hasNext();){var o=i.next(),a=e.isType(r=E(k(n.ownerDocument),"div",it(o)),HTMLElement)?r:w();n.appendChild(a),ot(o,a)}var s,l,u=Q(J(t,10));for(s=t.iterator();s.hasNext();){var c=s.next();u.add_11rb$(c.bounds())}var p=new C(v.Companion.ZERO,v.Companion.ZERO);for(l=u.iterator();l.hasNext();){var h=l.next();p=p.union_wthzt5$(h)}var _,f=p,d="position: relative; width: "+f.width+"px; height: "+f.height+"px;";t:do{var m;if(e.isType(t,tt)&&t.isEmpty()){_=!1;break t}for(m=t.iterator();m.hasNext();)if(m.next().plotAssembler.containsLiveMap){_=!0;break t}_=!1}while(0);_||(d=d+" background-color: "+S.Defaults.BACKDROP_COLOR+";"),n.setAttribute("style",d)}function ot(t,n){var i=t.plotAssembler,r=new T;!function(t,e,n){var i;null!=(i=A.Companion.parseFromPlotSpec_x7u0o8$(e))&&j.LiveMapUtil.injectLiveMapProvider_q1corz$(t.layersByTile,i,n)}(i,t.processedPlotSpec,r);var o,a=i.createPlot(),s=function(t,n){t.ensureContentBuilt();var i,r=t.svg,o=new L(r);for(new R(r),o.attachRoot_8uof53$(),t.isLiveMap&&(r.addClass_61zpoe$(S.Style.PLOT_TRANSPARENT),z(o.target.style,I.RELATIVE)),n.addEventListener(D.Companion.MOUSE_DOWN.name,at),n.addEventListener(D.Companion.MOUSE_MOVE.name,function(t,n){return function(i){var r;return t.mouseEventPeer.dispatch_w7zfbj$(M.MOUSE_MOVED,B.DomEventUtil.translateInTargetCoord_iyxqrk$(e.isType(r=i,MouseEvent)?r:w(),n.target)),d}}(t,o)),n.addEventListener(D.Companion.MOUSE_LEAVE.name,function(t,n){return function(i){var r;return t.mouseEventPeer.dispatch_w7zfbj$(M.MOUSE_LEFT,B.DomEventUtil.translateInTargetCoord_iyxqrk$(e.isType(r=i,MouseEvent)?r:w(),n.target)),d}}(t,o)),i=t.liveMapFigures.iterator();i.hasNext();){var a,s,l=i.next(),u=(e.isType(a=l,U)?a:w()).bounds().get(),c=e.isType(s=document.createElement("div"),HTMLElement)?s:w(),p=c.style;F(p,u.origin.x),q(p,u.origin.y),G(p,u.dimension.x),z(p,I.RELATIVE);var h=new H(c,u.dimension,new Y(o.target,u));l.mapToCanvas_49gm0j$(h),n.appendChild(c)}return o.target}(new O(a,t.size),n);r.defaultSetter_o14v8n$((o=s,function(){return P(o.style,N.CROSSHAIR),d})),r.pointerSetter_o14v8n$(function(t){return function(){return P(t.style,N.POINTER),d}}(s)),n.appendChild(s)}function at(t){return t.preventDefault(),d}function st(){return d}function lt(t,e){var n=V.FailureHandler.failureInfo_j5jy6c$(t);ut(n.message,e),n.isInternalError&&_.error_ca4k3s$(t,st)}function ut(t,e){pt(t,"lets-plot-message-error","color:darkred;",e)}function ct(t,e){pt(t,"lets-plot-message-info","color:darkblue;",e)}function pt(t,n,i,r){var o,a=e.isType(o=k(r.ownerDocument).createElement("p"),HTMLParagraphElement)?o:w();et(i)||a.setAttribute("style",i),a.textContent=t,a.className=n,r.appendChild(a)}function ht(t,e){if(y.Companion.assertPlotSpecOrErrorMessage_x7u0o8$(t),y.Companion.isFailure_x7u0o8$(t))return t;var n=e?t:K.Companion.processTransform_2wxo1b$(t);return y.Companion.isFailure_x7u0o8$(n)?n:W.PlotConfigClientSideJvmJs.processTransform_2wxo1b$(n)}return t.buildPlotFromRawSpecs=function(t,n,i,r){try{var o=m(t);y.Companion.assertPlotSpecOrErrorMessage_x7u0o8$(o),nt(ht(o,!1),n,i,r)}catch(t){if(!e.isType(t,$))throw t;lt(t,r)}},t.buildPlotFromProcessedSpecs=function(t,n,i,r){try{nt(ht(m(t),!0),n,i,r)}catch(t){if(!e.isType(t,$))throw t;lt(t,r)}},t.buildGGBunchComponent_w287e$=rt,_=f.KotlinLogging.logger_o14v8n$((function(){return d})),t})?i.apply(e,r):i)||(t.exports=o)},521:function(t,e,n){var i,r,o;r=[e,n(421),n(767),n(330),n(602),n(564)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o){"use strict";var a=t.$$importsForInline$$||(t.$$importsForInline$$={}),s=e.ensureNotNull,l=e.toString,u=e.Long.ZERO,c=e.Kind.CLASS,p=e.getKClass,h=e.kotlin.sequences.map_z5avom$,_=e.kotlin.sequences.toSet_veqyi0$,f=e.kotlin.collections.intersect_q4559j$,d=e.getPropertyCallableRef,m=e.kotlin.collections.joinToString_fmv235$,y=e.kotlin.sequences.filter_euau3h$,$=e.kotlin.sequences.count_veqyi0$,v=e.Kind.INTERFACE,g=e.numberToInt,b=e.Kind.OBJECT,w=e.kotlin.collections.ArrayList_init_287e2$,x=e.kotlin.collections.listOf_i5x0yv$,k=n.jetbrains.datalore.base.values.Color,E=n.jetbrains.datalore.base.geometry.DoubleVector,C=e.throwCCE,S=e.kotlin.IllegalStateException_init_pdl1vj$,T=e.throwUPAE,O=n.jetbrains.datalore.base.observable.event.EventHandler,N=e.kotlin.Unit,P=i.jetbrains.datalore.vis.canvas.AnimationProvider.AnimationEventHandler,A=e.getCallableRef,j=i.jetbrains.datalore.vis.canvas,L=n.jetbrains.datalore.base.typedGeometry.plus_cg1mpz$,R=n.jetbrains.datalore.base.typedGeometry.div_4nb5xq$,I=n.jetbrains.datalore.base.geometry.Vector,z=i.jetbrains.datalore.vis.canvas.DeltaTime,D=n.jetbrains.datalore.base.registration.Registration,M=r.jetbrains.datalore.base.observable.event.SimpleEventSource,B=n.jetbrains.datalore.base.observable.property.ValueProperty,U=n.jetbrains.datalore.base.registration.Disposable,F=n.jetbrains.datalore.base.spatial.GeoRectangle,q=n.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$,G=n.jetbrains.datalore.base.spatial,H=n.jetbrains.datalore.base.typedGeometry.explicitVec_y7b45i$,Y=n.jetbrains.datalore.base.typedGeometry.get_scalarX_xocuba$,V=n.jetbrains.datalore.base.typedGeometry.minus_qnxb21$,K=n.jetbrains.datalore.base.typedGeometry.transform_nj6yk8$,W=n.jetbrains.datalore.base.typedGeometry.plus_qnxb21$,X=e.kotlin.math.round_14dthe$,Z=Math,J=r.jetbrains.datalore.base.async,Q=e.kotlin.collections.asSequence_7wnvza$,tt=e.kotlin.sequences.mapNotNull_qpz9h9$,et=e.kotlin.sequences.flatten_d9bjs1$,nt=e.kotlin.sequences.maxOrNull_1bslqu$,it=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,rt=e.kotlin.collections.ArrayList_init_ww73n8$,ot=e.kotlin.collections.checkIndexOverflow_za3lpa$,at=(e.kotlin.Annotation,e.kotlin.collections.emptyList_287e2$),st=e.kotlin.collections.HashMap_init_q3lmfv$,lt=n.jetbrains.datalore.base.typedGeometry.createMultiPolygon_hv912c$,ut=n.jetbrains.datalore.base.typedGeometry.Ring,ct=e.kotlin.collections.listOf_mh5how$,pt=n.jetbrains.datalore.base.typedGeometry.Polygon,ht=n.jetbrains.datalore.base.typedGeometry.MultiPolygon,_t=n.jetbrains.datalore.base.spatial.limitLon_14dthe$,ft=n.jetbrains.datalore.base.spatial.limitLat_14dthe$,dt=(o.jetbrains.gis.geoprotocol.MapRegion,o.jetbrains.gis.tileprotocol.socket.TileWebSocketBuilder),mt=o.jetbrains.gis.tileprotocol.TileService,yt=o.jetbrains.gis.tileprotocol.TileService.Theme,$t=o.jetbrains.gis.geoprotocol.GeoTransportImpl,vt=o.jetbrains.gis.geoprotocol.GeocodingService,gt=o.jetbrains.gis.geoprotocol,bt=e.kotlin.collections.toDoubleArray_tcduak$,wt=e.kotlin.math,xt=e.kotlin.collections.addAll_ipc267$,kt=e.kotlin.js.internal.DoubleCompanionObject,Et=e.kotlin.RuntimeException_init_pdl1vj$,Ct=o.jetbrains.gis.geoprotocol.GeoTransport,St=n.jetbrains.datalore.base.unsupported.UNSUPPORTED_61zpoe$,Tt=o.jetbrains.gis.tileprotocol.socket.Socket,Ot=o.jetbrains.gis.tileprotocol.socket.SocketBuilder,Nt=e.kotlin.collections.sum_l63kqw$,Pt=n.jetbrains.datalore.base.typedGeometry.get_scalarLeft_xdjzag$,At=n.jetbrains.datalore.base.typedGeometry.get_scalarRight_xdjzag$,jt=n.jetbrains.datalore.base.typedGeometry.get_scalarTop_xdjzag$,Lt=n.jetbrains.datalore.base.typedGeometry.get_scalarBottom_xdjzag$,Rt=n.jetbrains.datalore.base.typedGeometry.get_left_h9e6jg$,It=n.jetbrains.datalore.base.typedGeometry.get_width_h9e6jg$,zt=n.jetbrains.datalore.base.typedGeometry.Rect,Dt=n.jetbrains.datalore.base.typedGeometry.get_top_h9e6jg$,Mt=n.jetbrains.datalore.base.typedGeometry.get_height_h9e6jg$,Bt=e.equals,Ut=n.jetbrains.datalore.base.typedGeometry.minus_cg1mpz$,Ft=e.kotlin.sequences.toList_veqyi0$,qt=n.jetbrains.datalore.base.spatial.GeoBoundingBoxCalculator,Gt=n.jetbrains.datalore.base.spatial.union_86o20w$,Ht=n.jetbrains.datalore.base.typedGeometry.get_right_h9e6jg$,Yt=n.jetbrains.datalore.base.typedGeometry.get_bottom_h9e6jg$,Vt=n.jetbrains.datalore.base.typedGeometry.xRange_h9e6jg$,Kt=n.jetbrains.datalore.base.typedGeometry.yRange_h9e6jg$,Wt=n.jetbrains.datalore.base.spatial.QuadKey,Xt=n.jetbrains.datalore.base.spatial.calculateQuadKeys_a35lcs$,Zt=e.kotlin.collections.flatten_u0ad8z$,Jt=e.kotlin.collections.toSet_7wnvza$,Qt=n.jetbrains.datalore.base.gcommon.collect.ClosedRange,te=n.jetbrains.datalore.base.typedGeometry.Rect_init_94ua8u$,ee=i.jetbrains.datalore.vis.canvas.scheduleAsync_ebnxch$,ne=n.jetbrains.datalore.base.observable.property,ie=r.jetbrains.datalore.base.observable.property,re=i.jetbrains.datalore.vis.canvas.SingleCanvasControl,oe=e.kotlin.text.split_ip8yn$,ae=i.jetbrains.datalore.vis.canvas.Context2d.TextBaseline,se=i.jetbrains.datalore.vis.canvas.Context2d.TextAlign,le=i.jetbrains.datalore.vis.canvas.Context2d.Font,ue=e.kotlin.collections.get_indices_gzk92b$,ce=e.Long.fromInt(1e3),pe=e.kotlin.collections.HashSet_init_287e2$,he=e.kotlin.IllegalStateException_init,_e=n.jetbrains.datalore.base.spatial.computeRect_v4gkf3$,fe=n.jetbrains.datalore.base.spatial.calculateQuadKeys_h9hod0$,de=e.kotlin.collections.minus_khz7k3$,me=e.kotlin.Enum,ye=e.throwISE,$e=e.numberToDouble,ve=e.kotlin.IllegalArgumentException_init,ge=e.kotlin.text.toBoolean_5cw0du$,be=e.kotlin.text.equals_igcy3c$,we=e.kotlin.Pair,xe=e.kotlin.collections.Map,ke=n.jetbrains.datalore.base.geometry.Rectangle_init_tjonv8$,Ee=i.jetbrains.datalore.vis.canvasFigure.CanvasFigure,Ce=n.jetbrains.datalore.base.typedGeometry.get_center_xdjzag$,Se=e.kotlin.IndexOutOfBoundsException_init,Te=e.kotlin.collections.AbstractIterator,Oe=e.kotlin.collections.MutableIterator,Ne=e.kotlin.collections.MutableIterable,Pe=e.kotlin.collections.binarySearch_vikexg$,Ae=e.kotlin.collections.AbstractCollection,je=e.kotlin.comparisons.reversed_2avth4$,Le=e.wrapFunction,Re=e.kotlin.Comparator,Ie=e.kotlin.collections.ArrayList,ze=e.kotlin.collections.ArrayList_init_mqih57$,De=e.defineInlineFunction,Me=e.kotlin.collections.emptySet_287e2$,Be=e.kotlin.collections.emptyMap_q3lmfv$,Ue=e.kotlin.collections.first_7wnvza$,Fe=e.kotlin.sequences.firstOrNull_veqyi0$,qe=e.kotlin.sequences.filterNot_euau3h$,Ge=e.kotlin.IllegalArgumentException_init_pdl1vj$,He=n.jetbrains.datalore.base.geometry.DoubleRectangle,Ye=n.jetbrains.datalore.base.event.MouseEventSpec,Ve=r.jetbrains.datalore.base.observable.event.handler_7qq44f$,Ke=n.jetbrains.datalore.base.event.Button,We=n.jetbrains.datalore.base.registration.CompositeRegistration,Xe=e.kotlin.sequences.toHashSet_veqyi0$,Ze=e.kotlin.collections.get_lastIndex_55thoc$,Je=e.kotlin.collections.last_2p1efm$,Qe=n.jetbrains.datalore.base.math.toRadians_14dthe$,tn=n.jetbrains.datalore.base.math.toDegrees_14dthe$,en=n.jetbrains.datalore.base.typedGeometry.Scalar,nn=n.jetbrains.datalore.base.typedGeometry.unaryMinus_cr59ze$,rn=n.jetbrains.datalore.base.typedGeometry.newVec_4xl464$,on=n.jetbrains.datalore.base.typedGeometry.newSpanRectangle_2d1svq$,an=n.jetbrains.datalore.base.typedGeometry.get_scalarY_xocuba$,sn=n.jetbrains.datalore.base.typedGeometry.compareTo_85q7fw$,ln=n.jetbrains.datalore.base.spatial.normalizeLon_14dthe$,un=n.jetbrains.datalore.base.typedGeometry.get_scalarWidth_xdjzag$,cn=n.jetbrains.datalore.base.typedGeometry.get_scalarHeight_xdjzag$,pn=n.jetbrains.datalore.base.typedGeometry.boundingBox_gyuce3$,hn=e.kotlin.isNaN_yrwdxr$,_n=e.kotlin.to_ujzrz7$,fn=e.kotlin.collections.hashMapOf_qfcya0$,dn=e.kotlin.collections.Collection,mn=e.kotlin.collections.toList_us0mfu$,yn=e.kotlin.collections.binarySearch_jhx6be$,$n=e.kotlin.collections.distinct_7wnvza$,vn=o.jetbrains.gis.geoprotocol.GeoRequestBuilder.ExplicitRequestBuilder,gn=o.jetbrains.gis.geoprotocol.GeoRequest.FeatureOption,bn=e.kotlin.collections.mapCapacity_za3lpa$,wn=e.kotlin.ranges.coerceAtLeast_dqglrj$,xn=e.kotlin.collections.LinkedHashMap_init_bwtc7$,kn=n.jetbrains.datalore.base.typedGeometry.reinterpret_q42o9k$,En=n.jetbrains.datalore.base.typedGeometry.limit_lddjmn$,Cn=n.jetbrains.datalore.base.typedGeometry.Geometry,Sn=n.jetbrains.datalore.base.typedGeometry.LineString,Tn=n.jetbrains.datalore.base.typedGeometry.MultiLineString,On=e.kotlin.io.println_s8jyv4$,Nn=e.kotlin.RuntimeException,Pn=n.jetbrains.datalore.base.typedGeometry.MultiPoint,An=e.kotlin.text.dropLast_6ic1pp$,jn=n.jetbrains.datalore.base.typedGeometry.Vec_init_vrm8gm$,Ln=n.jetbrains.datalore.base.typedGeometry.times_4nb5xq$,Rn=n.jetbrains.datalore.base.typedGeometry.Vec,In=e.kotlin.collections.HashMap_init_73mtqc$,zn=e.kotlin.collections.HashSet_init_ww73n8$,Dn=e.kotlin.collections.subtract_q4559j$,Mn=o.jetbrains.gis.geoprotocol.Fragment,Bn=r.jetbrains.datalore.base.concurrent.Lock,Un=n.jetbrains.datalore.base.typedGeometry.reinterpret_dg847r$,Fn=n.jetbrains.datalore.base.spatial.zoom_c2pv3p$,qn=n.jetbrains.datalore.base.spatial.computeRect_c2pv3p$,Gn=n.jetbrains.datalore.base.typedGeometry.intersects_32samh$,Hn=e.kotlin.collections.HashSet_init_mqih57$,Yn=e.kotlin.collections.removeAll_uhyeqt$,Vn=n.jetbrains.datalore.base.typedGeometry.unaryMinus_e0pgg$,Kn=e.kotlin.collections.drop_ba2ldo$,Wn=i.jetbrains.datalore.vis.canvas.Context2d.LineJoin,Xn=n.jetbrains.datalore.base.typedGeometry.contains_h8bixx$,Zn=n.jetbrains.datalore.base.typedGeometry.explicitVec_vrm8gm$,Jn=e.kotlin.sequences.sortedWith_vjgqpk$,Qn=n.jetbrains.datalore.base.typedGeometry.limit_106pae$,ti=e.kotlin.collections.toList_7wnvza$,ei=e.kotlin.collections.single_2p1efm$,ni=o.jetbrains.gis.geoprotocol.GeoRequestBuilder.GeocodingRequestBuilder,ii=o.jetbrains.gis.geoprotocol.GeoRequestBuilder.RegionQueryBuilder,ri=e.kotlin.ranges.rangeTo_38ydlf$,oi=e.kotlin.text.startsWith_7epoxm$,ai=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,si=e.kotlin.collections.removeAll_qafx1e$,li=n.jetbrains.datalore.base.spatial.projectRect_cub2h3$,ui=n.jetbrains.datalore.base.spatial.projectOrigin_cub2h3$,ci=e.kotlin.text.replace_680rmw$,pi=e.kotlin.math.roundToInt_yrwdxr$,hi=o.jetbrains.gis.tileprotocol.http.HttpTileTransport,_i=(e.kotlin.random.Random,i.jetbrains.datalore.vis.canvas.Context2d.Font_init_1nsek9$),fi=i.jetbrains.datalore.vis.canvas.Context2d.LineCap,di=e.kotlin.text.get_indices_gw00vp$,mi=e.kotlin.text.indexOf_8eortd$,yi=n.jetbrains.datalore.base.spatial.convertToGeoRectangle_i3vl8m$,$i=n.jetbrains.datalore.base.spatial.geoRectsBBox_wfabpm$,vi=o.jetbrains.gis.tileprotocol.TileGeometryParser,gi=e.kotlin.collections.getOrNull_yzln2o$,bi=o.jetbrains.gis.tileprotocol.mapConfig.TilePredicate,wi=n.jetbrains.datalore.base.math.round_lu1900$,xi=e.kotlin.collections.setOf_i5x0yv$,ki=e.kotlin.text.Regex_init_61zpoe$;function Ei(){}function Ci(t,e,n,i,r,o){Fi(),Ei.call(this),this.dirtyLayers_0=e,this.schedulerSystem_0=n,this.debugService_0=i,this.registry_0=o,this.diagnostics_0=w(),this.deltaTime_0=u,this.metrics_0=null,this.diagnostics_0.addAll_brywnq$(x([new Si(this),new Ti(this),new Ni(this),new Pi(this),new Ai(this),new ji(this),new Li(this),new Ri(this),new Di(this,t)])),this.debugService_0.setValuesOrder_mhpeer$(x([Fi().TIMER_TICK_0,Fi().SYSTEMS_UPDATE_TIME_0,Fi().ENTITIES_COUNT_0,Fi().SLOWEST_SYSTEM_0,Fi().FREEZING_SYSTEM_0,Fi().SCHEDULER_SYSTEM_0,Fi().DIRTY_LAYERS_0,Fi().STREAMING_FRAGMENTS_0,Fi().DOWNLOADING_FRAGMENTS_0,Fi().FRAGMENTS_CACHE_0,Fi().DOWNLOADING_TILES_0,Fi().IS_LOADING_0]));var a=new hp;a.color=k.Companion.DARK_GREEN,a.fontFamily="Courier New",a.fontSize=12,this.metrics_0=a;var s=new ap(new E(0,150),this.metrics_0);s.padding=4,s.background=k.Companion.WHITE;var l=s;r.addRenderable_pshs1s$(l)}function Si(t){this.$outer=t,this.timeToShowLeft_0=u,this.freezeTime_0=0,this.message_0="",this.timeToShow_0=7e3}function Ti(t){this.$outer=t}function Oi(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(mc)))||e.isType(n,mc)?n:C()))throw S("Component "+p(mc).simpleName+" is not found");return i.canvasLayer}function Ni(t){this.$outer=t}function Pi(t){this.$outer=t}function Ai(t){this.$outer=t}function ji(t){this.$outer=t}function Li(t){this.$outer=t}function Ri(t){this.$outer=t}function Ii(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hy)))||e.isType(n,hy)?n:C()))throw S("Component "+p(hy).simpleName+" is not found");return null==i.tileData}function zi(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(km)))||e.isType(n,km)?n:C()))throw S("Component "+p(km).simpleName+" is not found");return null==i.imageData}function Di(t,e){this.$outer=t,this.isLoading_0=e}function Mi(){}function Bi(){Ui=this,this.TIMER_TICK_0="timer_tick",this.SYSTEMS_UPDATE_TIME_0="systems_update_time",this.ENTITIES_COUNT_0="entities_count",this.SLOWEST_SYSTEM_0="slow_system",this.FREEZING_SYSTEM_0="freezing_system",this.SCHEDULER_SYSTEM_0="scheduler_load",this.DIRTY_LAYERS_0="dirty_layers",this.STREAMING_FRAGMENTS_0="streaming_fragments",this.DOWNLOADING_FRAGMENTS_0="downloading_fragments",this.DOWNLOADING_TILES_0="downloading_tiles",this.FRAGMENTS_CACHE_0="fragments_cache",this.IS_LOADING_0="is_loading"}Ci.prototype=Object.create(Ei.prototype),Ci.prototype.constructor=Ci,Xi.prototype=Object.create(Ws.prototype),Xi.prototype.constructor=Xi,Hr.prototype=Object.create(mt.prototype),Hr.prototype.constructor=Hr,_o.prototype=Object.create(Bs.prototype),_o.prototype.constructor=_o,mo.prototype=Object.create(Bs.prototype),mo.prototype.constructor=mo,go.prototype=Object.create(Bs.prototype),go.prototype.constructor=go,Po.prototype=Object.create(Bs.prototype),Po.prototype.constructor=Po,Jo.prototype=Object.create(Bs.prototype),Jo.prototype.constructor=Jo,da.prototype=Object.create(me.prototype),da.prototype.constructor=da,xa.prototype=Object.create(me.prototype),xa.prototype.constructor=xa,Ga.prototype=Object.create(Te.prototype),Ga.prototype.constructor=Ga,Za.prototype=Object.create(Te.prototype),Za.prototype.constructor=Za,Xa.prototype=Object.create(Ae.prototype),Xa.prototype.constructor=Xa,es.prototype=Object.create(me.prototype),es.prototype.constructor=es,os.prototype=Object.create(me.prototype),os.prototype.constructor=os,ts.prototype=Object.create(Bs.prototype),ts.prototype.constructor=ts,ys.prototype=Object.create(me.prototype),ys.prototype.constructor=ys,ws.prototype=Object.create(me.prototype),ws.prototype.constructor=ws,qs.prototype=Object.create(Bs.prototype),qs.prototype.constructor=qs,Gs.prototype=Object.create(Bs.prototype),Gs.prototype.constructor=Gs,Zs.prototype=Object.create(tl.prototype),Zs.prototype.constructor=Zs,rl.prototype=Object.create(me.prototype),rl.prototype.constructor=rl,sl.prototype=Object.create(Bs.prototype),sl.prototype.constructor=sl,ml.prototype=Object.create(me.prototype),ml.prototype.constructor=ml,xl.prototype=Object.create(Bs.prototype),xl.prototype.constructor=xl,Tl.prototype=Object.create(Bs.prototype),Tl.prototype.constructor=Tl,Yl.prototype=Object.create(Bs.prototype),Yl.prototype.constructor=Yl,Ql.prototype=Object.create(Wl.prototype),Ql.prototype.constructor=Ql,tu.prototype=Object.create(Wl.prototype),tu.prototype.constructor=tu,ju.prototype=Object.create(me.prototype),ju.prototype.constructor=ju,ec.prototype=Object.create(me.prototype),ec.prototype.constructor=ec,ac.prototype=Object.create(me.prototype),ac.prototype.constructor=ac,Cc.prototype=Object.create(me.prototype),Cc.prototype.constructor=Cc,Yc.prototype=Object.create(Bs.prototype),Yc.prototype.constructor=Yc,Kc.prototype=Object.create(me.prototype),Kc.prototype.constructor=Kc,fp.prototype=Object.create(Bs.prototype),fp.prototype.constructor=fp,wp.prototype=Object.create(Bs.prototype),wp.prototype.constructor=wp,Sp.prototype=Object.create(Bs.prototype),Sp.prototype.constructor=Sp,Ap.prototype=Object.create(Bs.prototype),Ap.prototype.constructor=Ap,ah.prototype=Object.create(Bs.prototype),ah.prototype.constructor=ah,ch.prototype=Object.create(Bs.prototype),ch.prototype.constructor=ch,ph.prototype=Object.create(Bs.prototype),ph.prototype.constructor=ph,yh.prototype=Object.create(Bs.prototype),yh.prototype.constructor=yh,Sh.prototype=Object.create(Bs.prototype),Sh.prototype.constructor=Sh,Lh.prototype=Object.create(Bs.prototype),Lh.prototype.constructor=Lh,Hh.prototype=Object.create(me.prototype),Hh.prototype.constructor=Hh,t_.prototype=Object.create(Bs.prototype),t_.prototype.constructor=t_,r_.prototype=Object.create(Bs.prototype),r_.prototype.constructor=r_,l_.prototype=Object.create(Bs.prototype),l_.prototype.constructor=l_,I_.prototype=Object.create(Bs.prototype),I_.prototype.constructor=I_,D_.prototype=Object.create(Bs.prototype),D_.prototype.constructor=D_,G_.prototype=Object.create(Bs.prototype),G_.prototype.constructor=G_,W_.prototype=Object.create(Bs.prototype),W_.prototype.constructor=W_,X_.prototype=Object.create(Bs.prototype),X_.prototype.constructor=X_,gf.prototype=Object.create(Bs.prototype),gf.prototype.constructor=gf,Gf.prototype=Object.create(Bs.prototype),Gf.prototype.constructor=Gf,td.prototype=Object.create(Bs.prototype),td.prototype.constructor=td,nm.prototype=Object.create(Bs.prototype),nm.prototype.constructor=nm,rm.prototype=Object.create(Bs.prototype),rm.prototype.constructor=rm,dm.prototype=Object.create(Bs.prototype),dm.prototype.constructor=dm,Em.prototype=Object.create(Bs.prototype),Em.prototype.constructor=Em,Jm.prototype=Object.create(me.prototype),Jm.prototype.constructor=Jm,ny.prototype=Object.create(Bs.prototype),ny.prototype.constructor=ny,yy.prototype=Object.create(Bs.prototype),yy.prototype.constructor=yy,Ry.prototype=Object.create(Ly.prototype),Ry.prototype.constructor=Ry,Iy.prototype=Object.create(Ly.prototype),Iy.prototype.constructor=Iy,Ay.prototype=Object.create(Bs.prototype),Ay.prototype.constructor=Ay,qy.prototype=Object.create(Bs.prototype),qy.prototype.constructor=qy,Ei.prototype.update_s8cxhz$=function(t){},Object.defineProperty(Ci.prototype,"slowestSystemType_0",{configurable:!0,get:function(){var t;return e.getKClassFromExpression(s(null!=(t=this.debugService_0.slowestSystem())?t.first:null)).simpleName}}),Object.defineProperty(Ci.prototype,"slowestSystemTime_0",{configurable:!0,get:function(){var t,e;return null!=(e=null!=(t=this.debugService_0.slowestSystem())?t.second:null)?e:0}}),Ci.prototype.update_s8cxhz$=function(t){var e;for(this.deltaTime_0=t,this.debugService_0.setValue_puj7f4$(Fi().TIMER_TICK_0,"Timer tick: "+this.deltaTime_0.toString()),this.debugService_0.setValue_puj7f4$(Fi().SYSTEMS_UPDATE_TIME_0,"Systems update: "+this.formatDouble_0(this.debugService_0.totalUpdateTime,1)),this.debugService_0.setValue_puj7f4$(Fi().ENTITIES_COUNT_0,"Entities count: "+this.registry_0.entitiesCount),e=this.diagnostics_0.iterator();e.hasNext();)e.next().update();this.metrics_0.text=this.debugService_0.values},Si.prototype.update=function(){this.$outer.slowestSystemTime_0>16?this.$outer.slowestSystemTime_0>this.freezeTime_0&&(this.timeToShowLeft_0=e.Long.fromInt(this.timeToShow_0),this.message_0="Freezed by: "+this.$outer.formatDouble_0(this.$outer.slowestSystemTime_0,1)+" "+l(this.$outer.slowestSystemType_0),this.freezeTime_0=this.$outer.slowestSystemTime_0):this.timeToShowLeft_0.toNumber()>0?this.timeToShowLeft_0=this.timeToShowLeft_0.subtract(this.$outer.deltaTime_0):this.timeToShowLeft_0.toNumber()<0&&(this.message_0="",this.timeToShowLeft_0=u,this.freezeTime_0=0),this.$outer.debugService_0.setValue_puj7f4$(Fi().FREEZING_SYSTEM_0,this.message_0)},Si.$metadata$={kind:c,simpleName:"FreezingSystemDiagnostic",interfaces:[Mi]},Ti.prototype.update=function(){var t,n,i=_(h(this.$outer.registry_0.getEntitiesById_wlb8mv$(this.$outer.dirtyLayers_0),Oi)),r=this.$outer.registry_0.getSingletonEntity_9u06oy$(p(dc));if(null==(n=null==(t=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(dc)))||e.isType(t,dc)?t:C()))throw S("Component "+p(dc).simpleName+" is not found");var o=m(f(i,n.canvasLayers),void 0,void 0,void 0,void 0,void 0,d("name",1,(function(t){return t.name})));this.$outer.debugService_0.setValue_puj7f4$(Fi().DIRTY_LAYERS_0,"Dirty layers: "+o)},Ti.$metadata$={kind:c,simpleName:"DirtyLayersDiagnostic",interfaces:[Mi]},Ni.prototype.update=function(){this.$outer.debugService_0.setValue_puj7f4$(Fi().SLOWEST_SYSTEM_0,"Slowest update: "+(this.$outer.slowestSystemTime_0>2?this.$outer.formatDouble_0(this.$outer.slowestSystemTime_0,1)+" "+l(this.$outer.slowestSystemType_0):"-"))},Ni.$metadata$={kind:c,simpleName:"SlowestSystemDiagnostic",interfaces:[Mi]},Pi.prototype.update=function(){var t=this.$outer.registry_0.count_9u06oy$(p(Gl));this.$outer.debugService_0.setValue_puj7f4$(Fi().SCHEDULER_SYSTEM_0,"Micro threads: "+t+", "+this.$outer.schedulerSystem_0.loading.toString())},Pi.$metadata$={kind:c,simpleName:"SchedulerSystemDiagnostic",interfaces:[Mi]},Ai.prototype.update=function(){var t,n,i,r,o=this.$outer.registry_0;t:do{if(o.containsEntity_9u06oy$(p(x_))){var a,s,l=o.getSingletonEntity_9u06oy$(p(x_));if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(x_)))||e.isType(a,x_)?a:C()))throw S("Component "+p(x_).simpleName+" is not found");r=s;break t}r=null}while(0);var u=null!=(i=null!=(n=null!=(t=r)?t.keys():null)?n.size:null)?i:0;this.$outer.debugService_0.setValue_puj7f4$(Fi().FRAGMENTS_CACHE_0,"Fragments cache: "+u)},Ai.$metadata$={kind:c,simpleName:"FragmentsCacheDiagnostic",interfaces:[Mi]},ji.prototype.update=function(){var t,n,i,r,o=this.$outer.registry_0;t:do{if(o.containsEntity_9u06oy$(p(R_))){var a,s,l=o.getSingletonEntity_9u06oy$(p(R_));if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(R_)))||e.isType(a,R_)?a:C()))throw S("Component "+p(R_).simpleName+" is not found");r=s;break t}r=null}while(0);var u=null!=(i=null!=(n=null!=(t=r)?t.keys():null)?n.size:null)?i:0;this.$outer.debugService_0.setValue_puj7f4$(Fi().STREAMING_FRAGMENTS_0,"Streaming fragments: "+u)},ji.$metadata$={kind:c,simpleName:"StreamingFragmentsDiagnostic",interfaces:[Mi]},Li.prototype.update=function(){var t,n,i,r,o=this.$outer.registry_0;t:do{if(o.containsEntity_9u06oy$(p(N_))){var a,s,l=o.getSingletonEntity_9u06oy$(p(N_));if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(N_)))||e.isType(a,N_)?a:C()))throw S("Component "+p(N_).simpleName+" is not found");r=s;break t}r=null}while(0);if(null!=(t=r)){var u,c="D: "+t.downloading.size+" Q: ",h=t.queue.values,_=d("size",1,(function(t){return t.size})),f=0;for(u=h.iterator();u.hasNext();)f=f+_(u.next())|0;i=c+f}else i=null;var m=null!=(n=i)?n:"D: 0 Q: 0";this.$outer.debugService_0.setValue_puj7f4$(Fi().DOWNLOADING_FRAGMENTS_0,"Downloading fragments: "+m)},Li.$metadata$={kind:c,simpleName:"DownloadingFragmentsDiagnostic",interfaces:[Mi]},Ri.prototype.update=function(){var t=$(y(this.$outer.registry_0.getEntities_9u06oy$(p(hy)),Ii)),e=$(y(this.$outer.registry_0.getEntities_9u06oy$(p(km)),zi));this.$outer.debugService_0.setValue_puj7f4$(Fi().DOWNLOADING_TILES_0,"Downloading tiles: V: "+t+", R: "+e)},Ri.$metadata$={kind:c,simpleName:"DownloadingTilesDiagnostic",interfaces:[Mi]},Di.prototype.update=function(){this.$outer.debugService_0.setValue_puj7f4$(Fi().IS_LOADING_0,"Is loading: "+this.isLoading_0.get())},Di.$metadata$={kind:c,simpleName:"IsLoadingDiagnostic",interfaces:[Mi]},Mi.$metadata$={kind:v,simpleName:"Diagnostic",interfaces:[]},Ci.prototype.formatDouble_0=function(t,e){var n=g(t),i=g(10*(t-n)*e);return n.toString()+"."+i},Bi.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ui=null;function Fi(){return null===Ui&&new Bi,Ui}function qi(t,e,n,i,r,o,a,s,l,u,c,p,h){this.myMapRuler_0=t,this.myMapProjection_0=e,this.viewport_0=n,this.layers_0=i,this.myTileSystemProvider_0=r,this.myFragmentProvider_0=o,this.myDevParams_0=a,this.myMapLocationConsumer_0=s,this.myGeocodingService_0=l,this.myMapLocationRect_0=u,this.myZoom_0=c,this.myAttribution_0=p,this.myCursorService_0=h,this.myRenderTarget_0=this.myDevParams_0.read_m9w1rv$(Da().RENDER_TARGET),this.myTimerReg_0=D.Companion.EMPTY,this.myInitialized_0=!1,this.myEcsController_wurexj$_0=this.myEcsController_wurexj$_0,this.myContext_l6buwl$_0=this.myContext_l6buwl$_0,this.myLayerRenderingSystem_rw6iwg$_0=this.myLayerRenderingSystem_rw6iwg$_0,this.myLayerManager_n334qq$_0=this.myLayerManager_n334qq$_0,this.myDiagnostics_hj908e$_0=this.myDiagnostics_hj908e$_0,this.mySchedulerSystem_xjqp68$_0=this.mySchedulerSystem_xjqp68$_0,this.myUiService_gvbha1$_0=this.myUiService_gvbha1$_0,this.errorEvent_0=new M,this.isLoading=new B(!0),this.myComponentManager_0=new Vs}function Gi(t){this.closure$handler=t}function Hi(t,e){return function(n){return t.schedule_klfg04$(function(t,e){return function(){return t.errorEvent_0.fire_11rb$(e),N}}(e,n)),N}}function Yi(t,e,n){this.timePredicate_0=t,this.skipTime_0=e,this.animationMultiplier_0=n,this.deltaTime_0=new z,this.currentTime_0=u}function Vi(){Ki=this,this.MIN_ZOOM=1,this.MAX_ZOOM=15,this.DEFAULT_LOCATION=new F(-124.76,25.52,-66.94,49.39),this.TILE_PIXEL_SIZE=256}Ci.$metadata$={kind:c,simpleName:"LiveMapDiagnostics",interfaces:[Ei]},Ei.$metadata$={kind:c,simpleName:"Diagnostics",interfaces:[]},Object.defineProperty(qi.prototype,"myEcsController_0",{configurable:!0,get:function(){return null==this.myEcsController_wurexj$_0?T("myEcsController"):this.myEcsController_wurexj$_0},set:function(t){this.myEcsController_wurexj$_0=t}}),Object.defineProperty(qi.prototype,"myContext_0",{configurable:!0,get:function(){return null==this.myContext_l6buwl$_0?T("myContext"):this.myContext_l6buwl$_0},set:function(t){this.myContext_l6buwl$_0=t}}),Object.defineProperty(qi.prototype,"myLayerRenderingSystem_0",{configurable:!0,get:function(){return null==this.myLayerRenderingSystem_rw6iwg$_0?T("myLayerRenderingSystem"):this.myLayerRenderingSystem_rw6iwg$_0},set:function(t){this.myLayerRenderingSystem_rw6iwg$_0=t}}),Object.defineProperty(qi.prototype,"myLayerManager_0",{configurable:!0,get:function(){return null==this.myLayerManager_n334qq$_0?T("myLayerManager"):this.myLayerManager_n334qq$_0},set:function(t){this.myLayerManager_n334qq$_0=t}}),Object.defineProperty(qi.prototype,"myDiagnostics_0",{configurable:!0,get:function(){return null==this.myDiagnostics_hj908e$_0?T("myDiagnostics"):this.myDiagnostics_hj908e$_0},set:function(t){this.myDiagnostics_hj908e$_0=t}}),Object.defineProperty(qi.prototype,"mySchedulerSystem_0",{configurable:!0,get:function(){return null==this.mySchedulerSystem_xjqp68$_0?T("mySchedulerSystem"):this.mySchedulerSystem_xjqp68$_0},set:function(t){this.mySchedulerSystem_xjqp68$_0=t}}),Object.defineProperty(qi.prototype,"myUiService_0",{configurable:!0,get:function(){return null==this.myUiService_gvbha1$_0?T("myUiService"):this.myUiService_gvbha1$_0},set:function(t){this.myUiService_gvbha1$_0=t}}),Gi.prototype.onEvent_11rb$=function(t){this.closure$handler(t)},Gi.$metadata$={kind:c,interfaces:[O]},qi.prototype.addErrorHandler_4m4org$=function(t){return this.errorEvent_0.addHandler_gxwwpc$(new Gi(t))},qi.prototype.draw_49gm0j$=function(t){var n=new ho(this.myComponentManager_0);n.requestZoom_14dthe$(this.viewport_0.zoom),n.requestPosition_c01uj8$(this.viewport_0.position);var i=n;this.myContext_0=new Xi(this.myMapProjection_0,t,new cr(this.viewport_0,t),Hi(t,this),i),this.myUiService_0=new Hy(this.myComponentManager_0,new By(this.myContext_0.mapRenderContext.canvasProvider)),this.myLayerManager_0=Hc().createLayerManager_ju5hjs$(this.myComponentManager_0,this.myRenderTarget_0,t);var r,o=new Yi((r=this,function(t){return r.animationHandler_0(r.myComponentManager_0,t)}),e.Long.fromInt(this.myDevParams_0.read_zgynif$(Da().UPDATE_PAUSE_MS)),this.myDevParams_0.read_366xgz$(Da().UPDATE_TIME_MULTIPLIER));this.myTimerReg_0=j.CanvasControlUtil.setAnimationHandler_1ixrg0$(t,P.Companion.toHandler_qm21m0$(A("onTime",function(t,e){return t.onTime_8e33dg$(e)}.bind(null,o))))},qi.prototype.searchResult=function(){if(!this.myInitialized_0)return null;var t,n,i=this.myComponentManager_0.getSingletonEntity_9u06oy$(p(Qf));if(null==(n=null==(t=i.componentManager.getComponents_ahlfl2$(i).get_11rb$(p(Qf)))||e.isType(t,Qf)?t:C()))throw S("Component "+p(Qf).simpleName+" is not found");return n.searchResult},qi.prototype.animationHandler_0=function(t,e){return this.myInitialized_0||(this.init_0(t),this.myInitialized_0=!0),this.myEcsController_0.update_14dthe$(e.toNumber()),this.myDiagnostics_0.update_s8cxhz$(e),!this.myLayerRenderingSystem_0.dirtyLayers.isEmpty()},qi.prototype.init_0=function(t){var e;this.initLayers_0(t),this.initSystems_0(t),this.initCamera_0(t),e=this.myDevParams_0.isSet_1a54na$(Da().PERF_STATS)?new Ci(this.isLoading,this.myLayerRenderingSystem_0.dirtyLayers,this.mySchedulerSystem_0,this.myContext_0.metricsService,this.myUiService_0,t):new Ei,this.myDiagnostics_0=e},qi.prototype.initSystems_0=function(t){var n,i;switch(this.myDevParams_0.read_m9w1rv$(Da().MICRO_TASK_EXECUTOR).name){case"UI_THREAD":n=new Ll(this.myContext_0,e.Long.fromInt(this.myDevParams_0.read_zgynif$(Da().COMPUTATION_FRAME_TIME)));break;case"AUTO":case"BACKGROUND":n=Xy().create();break;default:n=e.noWhenBranchMatched()}var r=null!=n?n:new Ll(this.myContext_0,e.Long.fromInt(this.myDevParams_0.read_zgynif$(Da().COMPUTATION_FRAME_TIME)));this.myLayerRenderingSystem_0=this.myLayerManager_0.createLayerRenderingSystem(),this.mySchedulerSystem_0=new Yl(r,t),this.myEcsController_0=new Xs(t,this.myContext_0,x([new Tl(t),new xl(t),new _o(t),new go(t),new sl(t,this.myCursorService_0),new Lh(t,this.myMapProjection_0,this.viewport_0),new Ap(t,this.myGeocodingService_0),new Sp(t,this.myGeocodingService_0),new ch(t,null==this.myMapLocationRect_0),new ph(t,this.myGeocodingService_0),new ah(this.myMapRuler_0,t),new yh(t,null!=(i=this.myZoom_0)?i:null,this.myMapLocationRect_0),new wp(t),new Gf(t),new qs(t),new Gs(t),new Po(t),new Ay(this.myUiService_0,t,this.myMapLocationConsumer_0,this.myLayerManager_0,this.myAttribution_0),new Jo(t),new rm(t),this.myTileSystemProvider_0.create_v8qzyl$(t),new nm(this.myDevParams_0.read_zgynif$(Da().TILE_CACHE_LIMIT),t),new yy(t),new G_(t),new I_(this.myDevParams_0.read_zgynif$(Da().FRAGMENT_ACTIVE_DOWNLOADS_LIMIT),this.myFragmentProvider_0,t),new D_(this.myDevParams_0.read_zgynif$(Da().COMPUTATION_PROJECTION_QUANT),t),new X_(t),new W_(this.myDevParams_0.read_zgynif$(Da().FRAGMENT_CACHE_LIMIT),t),new r_(t),new l_(t),new Sh(this.myDevParams_0.read_zgynif$(Da().COMPUTATION_PROJECTION_QUANT),t),new t_(t),new td(t),new gf(t),new ts(t,this.myUiService_0),new qy(t),this.myLayerRenderingSystem_0,this.mySchedulerSystem_0,new fp(t),new mo(t)]))},qi.prototype.initCamera_0=function(t){var n,i,r=new fl,o=Qs(t.getSingletonEntity_9u06oy$(p(ko)),(n=this,i=r,function(t){t.unaryPlus_jixjl7$(new wl);var e=new up,r=n;return e.rect=d_(f_().ZERO_CLIENT_POINT,r.viewport_0.size),t.unaryPlus_jixjl7$(new nl(e)),t.unaryPlus_jixjl7$(i),N}));r.addDoubleClickListener_abz6et$(function(t,n){return function(i){var r=t.contains_9u06oy$(p(yo));if(!r){var o,a,s=t;if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(ko)))||e.isType(o,ko)?o:C()))throw S("Component "+p(ko).simpleName+" is not found");r=a.zoom===n.viewport_0.maxZoom}if(!r){var l=m_(i.location),u=n.viewport_0.getMapCoord_5wcbfv$(R(L(l,n.viewport_0.center),2));return vo().setAnimation_egeizv$(t,l,u,1),N}}}(o,this))},qi.prototype.initLayers_0=function(t){var e;Qs(t.createEntity_61zpoe$("layers_order"),(e=this,function(t){return t.unaryPlus_jixjl7$(e.myLayerManager_0.createLayersOrderComponent()),N})),this.myTileSystemProvider_0.isVector?Qs(t.createEntity_61zpoe$("vector_layer_ground"),function(t){return function(e){return e.unaryPlus_jixjl7$(new _a(ya())),e.unaryPlus_jixjl7$(new lf),e.unaryPlus_jixjl7$(t.myLayerManager_0.addLayer_kqh14j$("ground",Tc())),N}}(this)):Qs(t.createEntity_61zpoe$("raster_layer_ground"),function(t){return function(e){return e.unaryPlus_jixjl7$(new _a(ga())),e.unaryPlus_jixjl7$(new fm),e.unaryPlus_jixjl7$(new lf),e.unaryPlus_jixjl7$(t.myLayerManager_0.addLayer_kqh14j$("http_ground",Tc())),N}}(this));var n,i=new dr(t,this.myLayerManager_0,this.myMapProjection_0,this.myMapRuler_0,this.myDevParams_0.isSet_1a54na$(Da().POINT_SCALING),new pc(this.myContext_0.mapRenderContext.canvasProvider.createCanvas_119tl4$(I.Companion.ZERO).context2d));for(n=this.layers_0.iterator();n.hasNext();)n.next()(i);this.myTileSystemProvider_0.isVector&&Qs(t.createEntity_61zpoe$("vector_layer_labels"),function(t){return function(e){return e.unaryPlus_jixjl7$(new _a($a())),e.unaryPlus_jixjl7$(new lf),e.unaryPlus_jixjl7$(t.myLayerManager_0.addLayer_kqh14j$("labels",Nc())),N}}(this)),this.myDevParams_0.isSet_1a54na$(Da().DEBUG_GRID)&&Qs(t.createEntity_61zpoe$("cell_layer_debug"),function(t){return function(e){return e.unaryPlus_jixjl7$(new _a(va())),e.unaryPlus_jixjl7$(new fa),e.unaryPlus_jixjl7$(new lf),e.unaryPlus_jixjl7$(t.myLayerManager_0.addLayer_kqh14j$("debug",Nc())),N}}(this)),Qs(t.createEntity_61zpoe$("layer_ui"),function(t){return function(e){return e.unaryPlus_jixjl7$(new Gy),e.unaryPlus_jixjl7$(t.myLayerManager_0.addLayer_kqh14j$("ui",Pc())),N}}(this))},qi.prototype.dispose=function(){this.myTimerReg_0.dispose(),this.myEcsController_0.dispose()},Yi.prototype.onTime_8e33dg$=function(t){var n=this.deltaTime_0.tick_s8cxhz$(t);return this.currentTime_0=this.currentTime_0.add(n),this.currentTime_0.compareTo_11rb$(this.skipTime_0)>0&&(this.currentTime_0=u,this.timePredicate_0(e.Long.fromNumber(n.toNumber()*this.animationMultiplier_0)))},Yi.$metadata$={kind:c,simpleName:"UpdateController",interfaces:[]},qi.$metadata$={kind:c,simpleName:"LiveMap",interfaces:[U]},Vi.$metadata$={kind:b,simpleName:"LiveMapConstants",interfaces:[]};var Ki=null;function Wi(){return null===Ki&&new Vi,Ki}function Xi(t,e,n,i,r){Ws.call(this,e),this.mapProjection_mgrs6g$_0=t,this.mapRenderContext_uxh8yk$_0=n,this.errorHandler_6fxwnz$_0=i,this.camera_b2oksc$_0=r}function Zi(t,e){tr(),this.myViewport_0=t,this.myMapProjection_0=e}function Ji(){Qi=this}Object.defineProperty(Xi.prototype,"mapProjection",{get:function(){return this.mapProjection_mgrs6g$_0}}),Object.defineProperty(Xi.prototype,"mapRenderContext",{get:function(){return this.mapRenderContext_uxh8yk$_0}}),Object.defineProperty(Xi.prototype,"camera",{get:function(){return this.camera_b2oksc$_0}}),Xi.prototype.raiseError_tcv7n7$=function(t){this.errorHandler_6fxwnz$_0(t)},Xi.$metadata$={kind:c,simpleName:"LiveMapContext",interfaces:[Ws]},Object.defineProperty(Zi.prototype,"viewLonLatRect",{configurable:!0,get:function(){var t=this.myViewport_0.window,e=this.worldToLonLat_0(t.origin),n=this.worldToLonLat_0(L(t.origin,t.dimension));return q(e.x,n.y,n.x-e.x,e.y-n.y)}}),Zi.prototype.worldToLonLat_0=function(t){var e,n,i,r=this.myMapProjection_0.mapRect.dimension;return t.x>r.x?(n=H(G.FULL_LONGITUDE,0),e=K(t,(i=r,function(t){return V(t,Y(i))}))):t.x<0?(n=H(-G.FULL_LONGITUDE,0),e=K(r,function(t){return function(e){return W(e,Y(t))}}(r))):(n=H(0,0),e=t),L(n,this.myMapProjection_0.invert_11rc$(e))},Ji.prototype.getLocationString_wthzt5$=function(t){var e=t.dimension.mul_14dthe$(.05);return"location = ["+l(this.round_0(t.left+e.x,6))+", "+l(this.round_0(t.top+e.y,6))+", "+l(this.round_0(t.right-e.x,6))+", "+l(this.round_0(t.bottom-e.y,6))+"]"},Ji.prototype.round_0=function(t,e){var n=Z.pow(10,e);return X(t*n)/n},Ji.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Qi=null;function tr(){return null===Qi&&new Ji,Qi}function er(){ur()}function nr(){lr=this}function ir(t){this.closure$geoRectangle=t}function rr(t){this.closure$mapRegion=t}Zi.$metadata$={kind:c,simpleName:"LiveMapLocation",interfaces:[]},ir.prototype.getBBox_p5tkbv$=function(t){return J.Asyncs.constant_mh5how$(t.calculateBBoxOfGeoRect_emtjl$(this.closure$geoRectangle))},ir.$metadata$={kind:c,interfaces:[er]},nr.prototype.create_emtjl$=function(t){return new ir(t)},rr.prototype.getBBox_p5tkbv$=function(t){return t.geocodeMapRegion_4x05nu$(this.closure$mapRegion)},rr.$metadata$={kind:c,interfaces:[er]},nr.prototype.create_4x05nu$=function(t){return new rr(t)},nr.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var or,ar,sr,lr=null;function ur(){return null===lr&&new nr,lr}function cr(t,e){this.viewport_j7tkex$_0=t,this.canvasProvider=e}function pr(t){this.barsFactory=new hr(t)}function hr(t){this.myFactory_0=t,this.myItems_0=w()}function _r(t,e,n){return function(i,r,o,a){var l;if(null==n.point)throw S("Can't create bar entity. Coord is null.".toString());return l=so(e.myFactory_0,"map_ent_s_bar",s(n.point)),t.add_11rb$(uo(l,function(t,e,n,i,r){return function(o,a){var s;null!=(s=t.layerIndex)&&o.unaryPlus_jixjl7$(new Xf(s,e)),o.unaryPlus_jixjl7$(new sf(new jf)),o.unaryPlus_jixjl7$(new qh(a)),o.unaryPlus_jixjl7$(new Gh),o.unaryPlus_jixjl7$(new Jh);var l=new Qh;l.offset=n,o.unaryPlus_jixjl7$(l);var u=new Zh;u.dimension=i,o.unaryPlus_jixjl7$(u);var c=new hf,p=t;return ff(c,r),df(c,p.strokeColor),mf(c,p.strokeWidth),o.unaryPlus_jixjl7$(c),o.unaryPlus_jixjl7$(new Zf(new Wf)),N}}(n,i,r,o,a))),N}}function fr(t,e,n){var i,r=t.values,o=rt(it(r,10));for(i=r.iterator();i.hasNext();){var a,s=i.next(),l=o.add_11rb$,u=0===e?0:s/e;a=Z.abs(u)>=or?u:Z.sign(u)*or,l.call(o,a)}var c,p,h=o,_=2*t.radius/t.values.size,f=0;for(c=h.iterator();c.hasNext();){var d=c.next(),m=ot((f=(p=f)+1|0,p)),y=H(_,t.radius*Z.abs(d)),$=H(_*m-t.radius,d>0?-y.y:0);n(t.indices.get_za3lpa$(m),$,y,t.colors.get_za3lpa$(m))}}function dr(t,e,n,i,r,o){this.myComponentManager=t,this.layerManager=e,this.mapProjection=n,this.mapRuler=i,this.pointScaling=r,this.textMeasurer=o}function mr(){this.layerIndex=null,this.point=null,this.radius=0,this.strokeColor=k.Companion.BLACK,this.strokeWidth=0,this.indices=at(),this.values=at(),this.colors=at()}function yr(t,e,n){var i,r,o=rt(it(t,10));for(r=t.iterator();r.hasNext();){var a=r.next();o.add_11rb$($r(a))}var s=o;if(e)i=lt(s);else{var l,u=vr(n?_u(s):s),c=rt(it(u,10));for(l=u.iterator();l.hasNext();){var p=l.next();c.add_11rb$(new pt(ct(new ut(p))))}i=new ht(c)}return i}function $r(t){return H(_t(t.x),ft(t.y))}function vr(t){var e,n=w(),i=w();if(!t.isEmpty()){i.add_11rb$(t.get_za3lpa$(0)),e=t.size;for(var r=1;rar-l){var u=o.x<0?-1:1,c=o.x-u*sr,p=a.x+u*sr,h=(a.y-o.y)*(p===c?.5:c/(c-p))+o.y;i.add_11rb$(H(u*sr,h)),n.add_11rb$(i),(i=w()).add_11rb$(H(-u*sr,h))}i.add_11rb$(a)}}return n.add_11rb$(i),n}function gr(){this.url_6i03cv$_0=this.url_6i03cv$_0,this.theme=yt.COLOR}function br(){this.url_u3glsy$_0=this.url_u3glsy$_0}function wr(t,e,n){return Qs(t.createEntity_61zpoe$(n),(i=e,function(t){return t.unaryPlus_jixjl7$(i),t.unaryPlus_jixjl7$(new xo),t.unaryPlus_jixjl7$(new wo),t.unaryPlus_jixjl7$(new bo),N}));var i}function xr(t){var n,i;if(this.myComponentManager_0=t.componentManager,this.myParentLayerComponent_0=new yc(t.id_8be2vx$),null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(lf)))||e.isType(n,lf)?n:C()))throw S("Component "+p(lf).simpleName+" is not found");this.myLayerEntityComponent_0=i}function kr(t){var e=new gr;return t(e),e.build()}function Er(t){var e=new br;return t(e),e.build()}function Cr(t,e,n){this.factory=t,this.mapProjection=e,this.horizontal=n}function Sr(t,e,n){var i;n(new Cr(new xr(Qs(t.myComponentManager.createEntity_61zpoe$("map_layer_line"),(i=t,function(t){return t.unaryPlus_jixjl7$(i.layerManager.addLayer_kqh14j$("geom_line",Oc())),t.unaryPlus_jixjl7$(new lf),N}))),t.mapProjection,e))}function Tr(t,e){this.myFactory_0=t,this.myMapProjection_0=e,this.point=null,this.lineDash=at(),this.strokeColor=k.Companion.BLACK,this.strokeWidth=1}function Or(t,e){this.factory=t,this.mapProjection=e}function Nr(t,e){this.myFactory_0=t,this.myMapProjection_0=e,this.layerIndex=null,this.index=null,this.regionId="",this.lineDash=at(),this.strokeColor=k.Companion.BLACK,this.strokeWidth=1,this.multiPolygon_cwupzr$_0=this.multiPolygon_cwupzr$_0,this.animation=0,this.speed=0,this.flow=0}function Pr(t){return t.duration=5e3,t.easingFunction=zs().LINEAR,t.direction=vs(),t.loop=Cs(),N}function Ar(t,e,n){t.multiPolygon=yr(e,!1,n)}function jr(t){this.piesFactory=new Lr(t)}function Lr(t){this.myFactory_0=t,this.myItems_0=w()}function Rr(t,e,n,i){return function(r,o){null!=t.layerIndex&&r.unaryPlus_jixjl7$(new Xf(s(t.layerIndex),t.indices.get_za3lpa$(e))),r.unaryPlus_jixjl7$(new sf(new Rf)),r.unaryPlus_jixjl7$(new qh(o));var a=new pf,l=t,u=n,c=i;a.radius=l.radius,a.startAngle=u,a.endAngle=c,r.unaryPlus_jixjl7$(a);var p=new hf,h=t;return ff(p,h.colors.get_za3lpa$(e)),df(p,h.strokeColor),mf(p,h.strokeWidth),r.unaryPlus_jixjl7$(p),r.unaryPlus_jixjl7$(new Zh),r.unaryPlus_jixjl7$(new Gh),r.unaryPlus_jixjl7$(new Jh),r.unaryPlus_jixjl7$(new Zf(new cd)),N}}function Ir(t,e,n,i){this.factory=t,this.mapProjection=e,this.pointScaling=n,this.animationBuilder=i}function zr(t){this.myFactory_0=t,this.layerIndex=null,this.index=null,this.point=null,this.radius=4,this.fillColor=k.Companion.WHITE,this.strokeColor=k.Companion.BLACK,this.strokeWidth=1,this.animation=0,this.label="",this.shape=1}function Dr(t,e,n,i,r,o){return function(a,l){var u;null!=t.layerIndex&&null!=t.index&&a.unaryPlus_jixjl7$(new Xf(s(t.layerIndex),s(t.index)));var c=new uf;if(c.shape=t.shape,a.unaryPlus_jixjl7$(c),a.unaryPlus_jixjl7$(t.createStyle_0()),e)u=new Fh(H(n,n));else{var p=new Zh,h=n;p.dimension=H(h,h),u=p}if(a.unaryPlus_jixjl7$(u),a.unaryPlus_jixjl7$(new qh(l)),a.unaryPlus_jixjl7$(new sf(new Of)),a.unaryPlus_jixjl7$(new Gh),a.unaryPlus_jixjl7$(new Jh),i||a.unaryPlus_jixjl7$(new Zf(new fd)),2===t.animation){var _=new hc,f=new Ts(0,1,function(t,e){return function(n){return t.scale=n,kc().tagDirtyParentLayer_ahlfl2$(e),N}}(_,r));o.addAnimator_i7e8zu$(f),a.unaryPlus_jixjl7$(_)}return N}}function Mr(t,e,n){this.factory=t,this.mapProjection=e,this.mapRuler=n}function Br(t,e,n){this.myFactory_0=t,this.myMapProjection_0=e,this.myMapRuler_0=n,this.layerIndex=null,this.index=null,this.lineDash=at(),this.strokeColor=k.Companion.BLACK,this.strokeWidth=0,this.fillColor=k.Companion.GREEN,this.multiPolygon=null}function Ur(){Zr=this}function Fr(){}function qr(){}function Gr(){}function Hr(t,e){mt.call(this,t,e)}function Yr(t){return t.url="http://10.0.0.127:3020/map_data/geocoding",N}function Vr(t){return t.url="https://geo2.datalore.jetbrains.com",N}function Kr(t){return t.url="ws://10.0.0.127:3933",N}function Wr(t){return t.url="wss://tiles.datalore.jetbrains.com",N}er.$metadata$={kind:v,simpleName:"MapLocation",interfaces:[]},Object.defineProperty(cr.prototype,"viewport",{get:function(){return this.viewport_j7tkex$_0}}),cr.prototype.draw_5xkfq8$=function(t,e,n){this.draw_4xlq28$_0(t,e.x,e.y,n)},cr.prototype.draw_28t4fw$=function(t,e,n){this.draw_4xlq28$_0(t,e.x,e.y,n)},cr.prototype.draw_4xlq28$_0=function(t,e,n,i){t.save(),t.translate_lu1900$(e,n),i.render_pzzegf$(t),t.restore()},cr.$metadata$={kind:c,simpleName:"MapRenderContext",interfaces:[]},pr.$metadata$={kind:c,simpleName:"Bars",interfaces:[]},hr.prototype.add_ltb8x$=function(t){this.myItems_0.add_11rb$(t)},hr.prototype.produce=function(){var t;if(null==(t=nt(h(et(tt(Q(this.myItems_0),d("values",1,(function(t){return t.values}),(function(t,e){t.values=e})))),A("abs",(function(t){return Z.abs(t)}))))))throw S("Failed to calculate maxAbsValue.".toString());var e,n=t,i=w();for(e=this.myItems_0.iterator();e.hasNext();){var r=e.next();fr(r,n,_r(i,this,r))}return i},hr.$metadata$={kind:c,simpleName:"BarsFactory",interfaces:[]},dr.$metadata$={kind:c,simpleName:"LayersBuilder",interfaces:[]},mr.$metadata$={kind:c,simpleName:"ChartSource",interfaces:[]},Object.defineProperty(gr.prototype,"url",{configurable:!0,get:function(){return null==this.url_6i03cv$_0?T("url"):this.url_6i03cv$_0},set:function(t){this.url_6i03cv$_0=t}}),gr.prototype.build=function(){return new mt(new dt(this.url),this.theme)},gr.$metadata$={kind:c,simpleName:"LiveMapTileServiceBuilder",interfaces:[]},Object.defineProperty(br.prototype,"url",{configurable:!0,get:function(){return null==this.url_u3glsy$_0?T("url"):this.url_u3glsy$_0},set:function(t){this.url_u3glsy$_0=t}}),br.prototype.build=function(){return new vt(new $t(this.url))},br.$metadata$={kind:c,simpleName:"LiveMapGeocodingServiceBuilder",interfaces:[]},xr.prototype.createMapEntity_61zpoe$=function(t){var e=wr(this.myComponentManager_0,this.myParentLayerComponent_0,t);return this.myLayerEntityComponent_0.add_za3lpa$(e.id_8be2vx$),e},xr.$metadata$={kind:c,simpleName:"MapEntityFactory",interfaces:[]},Cr.$metadata$={kind:c,simpleName:"Lines",interfaces:[]},Tr.prototype.build_6taknv$=function(t){if(null==this.point)throw S("Can't create line entity. Coord is null.".toString());var e,n,i=uo(lo(this.myFactory_0,"map_ent_s_line",s(this.point)),(e=t,n=this,function(t,i){var r=ro(i,e,n.myMapProjection_0.mapRect),o=oo(i,n.strokeWidth,e,n.myMapProjection_0.mapRect);t.unaryPlus_jixjl7$(new sf(new Pf)),t.unaryPlus_jixjl7$(new qh(o.origin));var a=new Ah;a.geometry=r,t.unaryPlus_jixjl7$(a),t.unaryPlus_jixjl7$(new Fh(o.dimension)),t.unaryPlus_jixjl7$(new Gh),t.unaryPlus_jixjl7$(new Jh);var s=new hf,l=n;return df(s,l.strokeColor),mf(s,l.strokeWidth),_f(s,l.lineDash),t.unaryPlus_jixjl7$(s),N}));return i.removeComponent_9u06oy$(p(Fp)),i.removeComponent_9u06oy$(p(Wp)),i.removeComponent_9u06oy$(p(Hp)),i},Tr.$metadata$={kind:c,simpleName:"LineBuilder",interfaces:[]},Or.$metadata$={kind:c,simpleName:"Paths",interfaces:[]},Object.defineProperty(Nr.prototype,"multiPolygon",{configurable:!0,get:function(){return null==this.multiPolygon_cwupzr$_0?T("multiPolygon"):this.multiPolygon_cwupzr$_0},set:function(t){this.multiPolygon_cwupzr$_0=t}}),Nr.prototype.build_6taknv$=function(t){var e;void 0===t&&(t=!1);var n,i,r,o,a,l=Qu().transformMultiPolygon_c0yqik$(this.multiPolygon,A("project",function(t,e){return t.project_11rb$(e)}.bind(null,this.myMapProjection_0)));if(null!=(e=gt.GeometryUtil.bbox_8ft4gs$(l))){var u=Qs(this.myFactory_0.createMapEntity_61zpoe$("map_ent_path"),(i=this,r=e,o=l,a=t,function(t){null!=i.layerIndex&&null!=i.index&&t.unaryPlus_jixjl7$(new Xf(s(i.layerIndex),s(i.index))),t.unaryPlus_jixjl7$(new sf(new Pf)),t.unaryPlus_jixjl7$(new qh(r.origin));var e=new Ah;e.geometry=o,t.unaryPlus_jixjl7$(e),t.unaryPlus_jixjl7$(new Fh(r.dimension)),t.unaryPlus_jixjl7$(new Gh),t.unaryPlus_jixjl7$(new Jh);var n=new hf,l=i;return df(n,l.strokeColor),n.strokeWidth=l.strokeWidth,n.lineDash=bt(l.lineDash),t.unaryPlus_jixjl7$(n),t.unaryPlus_jixjl7$(Gp()),t.unaryPlus_jixjl7$(Zp()),a||t.unaryPlus_jixjl7$(new Zf(new ad)),N}));if(2===this.animation){var c=this.addAnimationComponent_0(u.componentManager.createEntity_61zpoe$("map_ent_path_animation"),Pr);this.addGrowingPathEffectComponent_0(u.setComponent_qqqpmc$(new sf(new vp)),(n=c,function(t){return t.animationId=n.id_8be2vx$,N}))}return u}return null},Nr.prototype.addAnimationComponent_0=function(t,e){var n=new Us;return e(n),t.add_57nep2$(n)},Nr.prototype.addGrowingPathEffectComponent_0=function(t,e){var n=new $p;return e(n),t.add_57nep2$(n)},Nr.$metadata$={kind:c,simpleName:"PathBuilder",interfaces:[]},jr.$metadata$={kind:c,simpleName:"Pies",interfaces:[]},Lr.prototype.add_ltb8x$=function(t){this.myItems_0.add_11rb$(t)},Lr.prototype.produce=function(){var t,e=this.myItems_0,n=w();for(t=e.iterator();t.hasNext();){var i=t.next(),r=this.splitMapPieChart_0(i);xt(n,r)}return n},Lr.prototype.splitMapPieChart_0=function(t){for(var e=w(),n=to(t.values),i=-wt.PI/2,r=0;r!==n.size;++r){var o,a=i,l=i+n.get_za3lpa$(r);if(null==t.point)throw S("Can't create pieSector entity. Coord is null.".toString());o=so(this.myFactory_0,"map_ent_s_pie_sector",s(t.point)),e.add_11rb$(uo(o,Rr(t,r,a,l))),i=l}return e},Lr.$metadata$={kind:c,simpleName:"PiesFactory",interfaces:[]},Ir.$metadata$={kind:c,simpleName:"Points",interfaces:[]},zr.prototype.build_h0uvfn$=function(t,e,n){var i;void 0===n&&(n=!1);var r=2*this.radius;if(null==this.point)throw S("Can't create point entity. Coord is null.".toString());return uo(i=so(this.myFactory_0,"map_ent_s_point",s(this.point)),Dr(this,t,r,n,i,e))},zr.prototype.createStyle_0=function(){var t,e;if((t=this.shape)>=1&&t<=14){var n=new hf;df(n,this.strokeColor),n.strokeWidth=this.strokeWidth,e=n}else if(t>=15&&t<=18||20===t){var i=new hf;ff(i,this.strokeColor),i.strokeWidth=kt.NaN,e=i}else if(19===t){var r=new hf;ff(r,this.strokeColor),df(r,this.strokeColor),r.strokeWidth=this.strokeWidth,e=r}else{if(!(t>=21&&t<=25))throw S(("Not supported shape: "+this.shape).toString());var o=new hf;ff(o,this.fillColor),df(o,this.strokeColor),o.strokeWidth=this.strokeWidth,e=o}return e},zr.$metadata$={kind:c,simpleName:"PointBuilder",interfaces:[]},Mr.$metadata$={kind:c,simpleName:"Polygons",interfaces:[]},Br.prototype.build=function(){return null!=this.multiPolygon?this.createStaticEntity_0():null},Br.prototype.createStaticEntity_0=function(){var t,e=s(this.multiPolygon),n=Qu().transformMultiPolygon_c0yqik$(e,A("project",function(t,e){return t.project_11rb$(e)}.bind(null,this.myMapProjection_0)));if(null==(t=gt.GeometryUtil.bbox_8ft4gs$(n)))throw S("Polygon bbox can't be null".toString());var i,r,o,a=t;return Qs(this.myFactory_0.createMapEntity_61zpoe$("map_ent_s_polygon"),(i=this,r=a,o=n,function(t){null!=i.layerIndex&&null!=i.index&&t.unaryPlus_jixjl7$(new Xf(s(i.layerIndex),s(i.index))),t.unaryPlus_jixjl7$(new sf(new Nf)),t.unaryPlus_jixjl7$(new qh(r.origin));var e=new Ah;e.geometry=o,t.unaryPlus_jixjl7$(e),t.unaryPlus_jixjl7$(new Fh(r.dimension)),t.unaryPlus_jixjl7$(new Gh),t.unaryPlus_jixjl7$(new Jh),t.unaryPlus_jixjl7$(new qf);var n=new hf,a=i;return ff(n,a.fillColor),df(n,a.strokeColor),mf(n,a.strokeWidth),t.unaryPlus_jixjl7$(n),t.unaryPlus_jixjl7$(Gp()),t.unaryPlus_jixjl7$(Zp()),t.unaryPlus_jixjl7$(new Zf(new $d)),N}))},Br.$metadata$={kind:c,simpleName:"PolygonsBuilder",interfaces:[]},Fr.prototype.send_2yxzh4$=function(t){return J.Asyncs.failure_lsqlk3$(Et("Geocoding is disabled."))},Fr.$metadata$={kind:c,interfaces:[Ct]},Ur.prototype.bogusGeocodingService=function(){return new vt(new Fr)},Gr.prototype.connect=function(){St("DummySocketBuilder.connect")},Gr.prototype.close=function(){St("DummySocketBuilder.close")},Gr.prototype.send_61zpoe$=function(t){St("DummySocketBuilder.send")},Gr.$metadata$={kind:c,interfaces:[Tt]},qr.prototype.build_korocx$=function(t){return new Gr},qr.$metadata$={kind:c,simpleName:"DummySocketBuilder",interfaces:[Ot]},Hr.prototype.getTileData_h9hod0$=function(t,e){return J.Asyncs.constant_mh5how$(at())},Hr.$metadata$={kind:c,interfaces:[mt]},Ur.prototype.bogusTileProvider=function(){return new Hr(new qr,yt.COLOR)},Ur.prototype.devGeocodingService=function(){return Er(Yr)},Ur.prototype.jetbrainsGeocodingService=function(){return Er(Vr)},Ur.prototype.devTileProvider=function(){return kr(Kr)},Ur.prototype.jetbrainsTileProvider=function(){return kr(Wr)},Ur.$metadata$={kind:b,simpleName:"Services",interfaces:[]};var Xr,Zr=null;function Jr(t,e){this.factory=t,this.textMeasurer=e}function Qr(t){this.myFactory_0=t,this.index=0,this.point=null,this.fillColor=k.Companion.BLACK,this.strokeColor=k.Companion.TRANSPARENT,this.strokeWidth=0,this.label="",this.size=10,this.family="Arial",this.fontface="",this.hjust=0,this.vjust=0,this.angle=0}function to(t){var e,n,i=rt(it(t,10));for(n=t.iterator();n.hasNext();){var r=n.next();i.add_11rb$(Z.abs(r))}var o=Nt(i);if(0===o){for(var a=t.size,s=rt(a),l=0;ln&&(a-=o),athis.limit_0&&null!=(i=this.tail_0)&&(this.tail_0=i.myPrev_8be2vx$,s(this.tail_0).myNext_8be2vx$=null,this.map_0.remove_11rb$(i.myKey_8be2vx$))},Ya.prototype.getOrPut_kpg1aj$=function(t,e){var n,i=this.get_11rb$(t);if(null!=i)n=i;else{var r=e();this.put_xwzc9p$(t,r),n=r}return n},Ya.prototype.containsKey_11rb$=function(t){return this.map_0.containsKey_11rb$(t)},Va.$metadata$={kind:c,simpleName:"Node",interfaces:[]},Ya.$metadata$={kind:c,simpleName:"LruCache",interfaces:[]},Ka.prototype.add_11rb$=function(t){var e=Pe(this.queue_0,t,this.comparator_0);e<0&&(e=(0|-e)-1|0),this.queue_0.add_wxm5ur$(e,t)},Ka.prototype.peek=function(){return this.queue_0.isEmpty()?null:this.queue_0.get_za3lpa$(0)},Ka.prototype.clear=function(){this.queue_0.clear()},Ka.prototype.toArray=function(){return this.queue_0},Ka.$metadata$={kind:c,simpleName:"PriorityQueue",interfaces:[]},Object.defineProperty(Xa.prototype,"size",{configurable:!0,get:function(){return 1}}),Xa.prototype.iterator=function(){return new Za(this.item_0)},Za.prototype.computeNext=function(){var t;!1===(t=this.requested_0)?this.setNext_11rb$(this.value_0):!0===t&&this.done(),this.requested_0=!0},Za.$metadata$={kind:c,simpleName:"SingleItemIterator",interfaces:[Te]},Xa.$metadata$={kind:c,simpleName:"SingletonCollection",interfaces:[Ae]},Ja.$metadata$={kind:c,simpleName:"BusyStateComponent",interfaces:[Ys]},Qa.$metadata$={kind:c,simpleName:"BusyMarkerComponent",interfaces:[Ys]},Object.defineProperty(ts.prototype,"spinnerGraphics_0",{configurable:!0,get:function(){return null==this.spinnerGraphics_692qlm$_0?T("spinnerGraphics"):this.spinnerGraphics_692qlm$_0},set:function(t){this.spinnerGraphics_692qlm$_0=t}}),ts.prototype.initImpl_4pvjek$=function(t){var e=new E(14,169),n=new E(26,26),i=new ep;i.origin=E.Companion.ZERO,i.dimension=n,i.fillColor=k.Companion.WHITE,i.strokeColor=k.Companion.LIGHT_GRAY,i.strokeWidth=1;var r=new ep;r.origin=new E(4,4),r.dimension=new E(18,18),r.fillColor=k.Companion.TRANSPARENT,r.strokeColor=k.Companion.LIGHT_GRAY,r.strokeWidth=2;var o=this.mySpinnerArc_0;o.origin=new E(4,4),o.dimension=new E(18,18),o.strokeColor=k.Companion.parseHex_61zpoe$("#70a7e3"),o.strokeWidth=2,o.angle=wt.PI/4,this.spinnerGraphics_0=new np(e,x([i,r,o]))},ts.prototype.updateImpl_og8vrq$=function(t,e){var n,i,r,o=is(),a=null!=(n=this.componentManager.count_9u06oy$(p(Ja))>0?o:null)?n:rs(),l=ss(),u=null!=(i=this.componentManager.count_9u06oy$(p(Qa))>0?l:null)?i:ls();r=new we(a,u),Bt(r,new we(rs(),ls()))||(Bt(r,new we(rs(),ss()))?s(this.spinnerEntity_0).remove():Bt(r,new we(is(),ss()))?(this.myStartAngle_0+=2*wt.PI*e/1e3,this.mySpinnerArc_0.startAngle=this.myStartAngle_0):Bt(r,new we(is(),ls()))&&(this.spinnerEntity_0=this.uiService_0.addRenderable_pshs1s$(this.spinnerGraphics_0,"ui_busy_marker").add_57nep2$(new Qa)),this.uiService_0.repaint())},es.$metadata$={kind:c,simpleName:"EntitiesState",interfaces:[me]},es.values=function(){return[is(),rs()]},es.valueOf_61zpoe$=function(t){switch(t){case"BUSY":return is();case"NOT_BUSY":return rs();default:ye("No enum constant jetbrains.livemap.core.BusyStateSystem.EntitiesState."+t)}},os.$metadata$={kind:c,simpleName:"MarkerState",interfaces:[me]},os.values=function(){return[ss(),ls()]},os.valueOf_61zpoe$=function(t){switch(t){case"SHOWING":return ss();case"NOT_SHOWING":return ls();default:ye("No enum constant jetbrains.livemap.core.BusyStateSystem.MarkerState."+t)}},ts.$metadata$={kind:c,simpleName:"BusyStateSystem",interfaces:[Bs]};var us,cs,ps,hs,_s,fs=Le((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function ds(t){this.mySystemTime_0=t,this.myMeasures_0=new Ka(je(new Re(fs(d("second",1,(function(t){return t.second})))))),this.myBeginTime_0=u,this.totalUpdateTime_581y0z$_0=0,this.myValuesMap_0=st(),this.myValuesOrder_0=w()}function ms(){}function ys(t,e){me.call(this),this.name$=t,this.ordinal$=e}function $s(){$s=function(){},us=new ys("FORWARD",0),cs=new ys("BACK",1)}function vs(){return $s(),us}function gs(){return $s(),cs}function bs(){return[vs(),gs()]}function ws(t,e){me.call(this),this.name$=t,this.ordinal$=e}function xs(){xs=function(){},ps=new ws("DISABLED",0),hs=new ws("SWITCH_DIRECTION",1),_s=new ws("KEEP_DIRECTION",2)}function ks(){return xs(),ps}function Es(){return xs(),hs}function Cs(){return xs(),_s}function Ss(){Is=this,this.LINEAR=As,this.EASE_IN_QUAD=js,this.EASE_OUT_QUAD=Ls}function Ts(t,e,n){this.start_0=t,this.length_0=e,this.consumer_0=n}function Os(t,e,n){this.start_0=t,this.length_0=e,this.consumer_0=n}function Ns(t){this.duration_0=t,this.easingFunction_0=zs().LINEAR,this.loop_0=ks(),this.direction_0=vs(),this.animators_0=w()}function Ps(t,e,n){this.timeState_0=t,this.easingFunction_0=e,this.animators_0=n,this.time_kdbqol$_0=0}function As(t){return t}function js(t){return t*t}function Ls(t){return t*(2-t)}Object.defineProperty(ds.prototype,"totalUpdateTime",{configurable:!0,get:function(){return this.totalUpdateTime_581y0z$_0},set:function(t){this.totalUpdateTime_581y0z$_0=t}}),Object.defineProperty(ds.prototype,"values",{configurable:!0,get:function(){var t,e,n=w();for(t=this.myValuesOrder_0.iterator();t.hasNext();){var i=t.next();null!=(e=this.myValuesMap_0.get_11rb$(i))&&e.length>0&&n.add_11rb$(e)}return n}}),ds.prototype.beginMeasureUpdate=function(){this.myBeginTime_0=this.mySystemTime_0.getTimeMs()},ds.prototype.endMeasureUpdate_ha9gfm$=function(t){var e=this.mySystemTime_0.getTimeMs().subtract(this.myBeginTime_0);this.myMeasures_0.add_11rb$(new we(t,e.toNumber())),this.totalUpdateTime=this.totalUpdateTime+e},ds.prototype.reset=function(){this.myMeasures_0.clear(),this.totalUpdateTime=0},ds.prototype.slowestSystem=function(){return this.myMeasures_0.peek()},ds.prototype.setValue_puj7f4$=function(t,e){this.myValuesMap_0.put_xwzc9p$(t,e)},ds.prototype.setValuesOrder_mhpeer$=function(t){this.myValuesOrder_0=t},ds.$metadata$={kind:c,simpleName:"MetricsService",interfaces:[]},ys.$metadata$={kind:c,simpleName:"Direction",interfaces:[me]},ys.values=bs,ys.valueOf_61zpoe$=function(t){switch(t){case"FORWARD":return vs();case"BACK":return gs();default:ye("No enum constant jetbrains.livemap.core.animation.Animation.Direction."+t)}},ws.$metadata$={kind:c,simpleName:"Loop",interfaces:[me]},ws.values=function(){return[ks(),Es(),Cs()]},ws.valueOf_61zpoe$=function(t){switch(t){case"DISABLED":return ks();case"SWITCH_DIRECTION":return Es();case"KEEP_DIRECTION":return Cs();default:ye("No enum constant jetbrains.livemap.core.animation.Animation.Loop."+t)}},ms.$metadata$={kind:v,simpleName:"Animation",interfaces:[]},Ts.prototype.doAnimation_14dthe$=function(t){this.consumer_0(this.start_0+t*this.length_0)},Ts.$metadata$={kind:c,simpleName:"DoubleAnimator",interfaces:[Ds]},Os.prototype.doAnimation_14dthe$=function(t){this.consumer_0(this.start_0.add_gpjtzr$(this.length_0.mul_14dthe$(t)))},Os.$metadata$={kind:c,simpleName:"DoubleVectorAnimator",interfaces:[Ds]},Ns.prototype.setEasingFunction_7fnk9s$=function(t){return this.easingFunction_0=t,this},Ns.prototype.setLoop_tfw1f3$=function(t){return this.loop_0=t,this},Ns.prototype.setDirection_aylh82$=function(t){return this.direction_0=t,this},Ns.prototype.setAnimator_i7e8zu$=function(t){var n;return this.animators_0=e.isType(n=ct(t),Ie)?n:C(),this},Ns.prototype.setAnimators_1h9huh$=function(t){return this.animators_0=ze(t),this},Ns.prototype.addAnimator_i7e8zu$=function(t){return this.animators_0.add_11rb$(t),this},Ns.prototype.build=function(){return new Ps(new Ms(this.duration_0,this.loop_0,this.direction_0),this.easingFunction_0,this.animators_0)},Ns.$metadata$={kind:c,simpleName:"AnimationBuilder",interfaces:[]},Object.defineProperty(Ps.prototype,"isFinished",{configurable:!0,get:function(){return this.timeState_0.isFinished}}),Object.defineProperty(Ps.prototype,"duration",{configurable:!0,get:function(){return this.timeState_0.duration}}),Object.defineProperty(Ps.prototype,"time",{configurable:!0,get:function(){return this.time_kdbqol$_0},set:function(t){this.time_kdbqol$_0=this.timeState_0.calcTime_tq0o01$(t)}}),Ps.prototype.animate=function(){var t,e=this.progress_0;for(t=this.animators_0.iterator();t.hasNext();)t.next().doAnimation_14dthe$(e)},Object.defineProperty(Ps.prototype,"progress_0",{configurable:!0,get:function(){if(0===this.duration)return 1;var t=this.easingFunction_0(this.time/this.duration);return this.timeState_0.direction===vs()?t:1-t}}),Ps.$metadata$={kind:c,simpleName:"SimpleAnimation",interfaces:[ms]},Ss.$metadata$={kind:b,simpleName:"Animations",interfaces:[]};var Rs,Is=null;function zs(){return null===Is&&new Ss,Is}function Ds(){}function Ms(t,e,n){this.duration=t,this.loop_0=e,this.direction=n,this.isFinished_wap2n$_0=!1}function Bs(t){this.componentManager=t,this.myTasks_osfxy5$_0=w()}function Us(){this.time=0,this.duration=0,this.finished=!1,this.progress=0,this.easingFunction_heah4c$_0=this.easingFunction_heah4c$_0,this.loop_zepar7$_0=this.loop_zepar7$_0,this.direction_vdy4gu$_0=this.direction_vdy4gu$_0}function Fs(t){this.animation=t}function qs(t){Bs.call(this,t)}function Gs(t){Bs.call(this,t)}function Hs(){}function Ys(){}function Vs(){this.myEntityById_0=st(),this.myComponentsByEntity_0=st(),this.myEntitiesByComponent_0=st(),this.myRemovedEntities_0=w(),this.myIdGenerator_0=0,this.entities_8be2vx$=this.myComponentsByEntity_0.keys}function Ks(t){return t.hasRemoveFlag()}function Ws(t){this.eventSource=t,this.systemTime_kac7b8$_0=new Yy,this.frameStartTimeMs_fwcob4$_0=u,this.metricsService=new ds(this.systemTime),this.tick=u}function Xs(t,e,n){var i;for(this.myComponentManager_0=t,this.myContext_0=e,this.mySystems_0=n,this.myDebugService_0=this.myContext_0.metricsService,i=this.mySystems_0.iterator();i.hasNext();)i.next().init_c257f0$(this.myContext_0)}function Zs(t,e,n){tl.call(this),this.id_8be2vx$=t,this.name=e,this.componentManager=n,this.componentsMap_8be2vx$=st()}function Js(){this.components=w()}function Qs(t,e){var n,i=new Js;for(e(i),n=i.components.iterator();n.hasNext();){var r=n.next();t.componentManager.addComponent_pw9baj$(t,r)}return t}function tl(){this.removeFlag_krvsok$_0=!1}function el(){}function nl(t){this.myRenderBox_0=t}function il(t){this.cursorStyle=t}function rl(t,e){me.call(this),this.name$=t,this.ordinal$=e}function ol(){ol=function(){},Rs=new rl("POINTER",0)}function al(){return ol(),Rs}function sl(t,e){_l(),Bs.call(this,t),this.myCursorService_0=e,this.myInput_0=new wl}function ll(){hl=this,this.COMPONENT_TYPES_0=x([p(il),p(nl)])}Ds.$metadata$={kind:v,simpleName:"Animator",interfaces:[]},Object.defineProperty(Ms.prototype,"isFinished",{configurable:!0,get:function(){return this.isFinished_wap2n$_0},set:function(t){this.isFinished_wap2n$_0=t}}),Ms.prototype.calcTime_tq0o01$=function(t){var e;if(t>this.duration){if(this.loop_0===ks())e=this.duration,this.isFinished=!0;else if(e=t%this.duration,this.loop_0===Es()){var n=g(this.direction.ordinal+t/this.duration)%2;this.direction=bs()[n]}}else e=t;return e},Ms.$metadata$={kind:c,simpleName:"TimeState",interfaces:[]},Bs.prototype.init_c257f0$=function(t){var n;this.initImpl_4pvjek$(e.isType(n=t,Ws)?n:C())},Bs.prototype.update_tqyjj6$=function(t,n){var i;this.executeTasks_t289vu$_0(),this.updateImpl_og8vrq$(e.isType(i=t,Ws)?i:C(),n)},Bs.prototype.destroy=function(){},Bs.prototype.initImpl_4pvjek$=function(t){},Bs.prototype.updateImpl_og8vrq$=function(t,e){},Bs.prototype.getEntities_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.AbstractSystem.getEntities_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){return this.componentManager.getEntities_9u06oy$(t(e))}}))),Bs.prototype.getEntities_9u06oy$=function(t){return this.componentManager.getEntities_9u06oy$(t)},Bs.prototype.getEntities_38uplf$=function(t){return this.componentManager.getEntities_tv8pd9$(t)},Bs.prototype.getMutableEntities_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.AbstractSystem.getMutableEntities_s66lbm$",Le((function(){var t=e.getKClass,n=e.kotlin.sequences.toList_veqyi0$;return function(e,i){return n(this.componentManager.getEntities_9u06oy$(t(e)))}}))),Bs.prototype.getMutableEntities_38uplf$=function(t){return Ft(this.componentManager.getEntities_tv8pd9$(t))},Bs.prototype.getEntityById_za3lpa$=function(t){return this.componentManager.getEntityById_za3lpa$(t)},Bs.prototype.getEntitiesById_wlb8mv$=function(t){return this.componentManager.getEntitiesById_wlb8mv$(t)},Bs.prototype.getSingletonEntity_9u06oy$=function(t){return this.componentManager.getSingletonEntity_9u06oy$(t)},Bs.prototype.containsEntity_9u06oy$=function(t){return this.componentManager.containsEntity_9u06oy$(t)},Bs.prototype.getSingleton_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.AbstractSystem.getSingleton_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){var o,a,s=this.componentManager.getSingletonEntity_9u06oy$(t(e));if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}}))),Bs.prototype.getSingletonEntity_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.AbstractSystem.getSingletonEntity_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){return this.componentManager.getSingletonEntity_9u06oy$(t(e))}}))),Bs.prototype.getSingletonEntity_38uplf$=function(t){return this.componentManager.getSingletonEntity_tv8pd9$(t)},Bs.prototype.createEntity_61zpoe$=function(t){return this.componentManager.createEntity_61zpoe$(t)},Bs.prototype.runLaterBySystem_ayosff$=function(t,e){var n,i,r;this.myTasks_osfxy5$_0.add_11rb$((n=this,i=t,r=e,function(){return n.componentManager.containsEntity_ahlfl2$(i)&&r(i),N}))},Bs.prototype.fetchTasks_u1j879$_0=function(){if(this.myTasks_osfxy5$_0.isEmpty())return at();var t=ze(this.myTasks_osfxy5$_0);return this.myTasks_osfxy5$_0.clear(),t},Bs.prototype.executeTasks_t289vu$_0=function(){var t;for(t=this.fetchTasks_u1j879$_0().iterator();t.hasNext();)t.next()()},Bs.$metadata$={kind:c,simpleName:"AbstractSystem",interfaces:[el]},Object.defineProperty(Us.prototype,"easingFunction",{configurable:!0,get:function(){return null==this.easingFunction_heah4c$_0?T("easingFunction"):this.easingFunction_heah4c$_0},set:function(t){this.easingFunction_heah4c$_0=t}}),Object.defineProperty(Us.prototype,"loop",{configurable:!0,get:function(){return null==this.loop_zepar7$_0?T("loop"):this.loop_zepar7$_0},set:function(t){this.loop_zepar7$_0=t}}),Object.defineProperty(Us.prototype,"direction",{configurable:!0,get:function(){return null==this.direction_vdy4gu$_0?T("direction"):this.direction_vdy4gu$_0},set:function(t){this.direction_vdy4gu$_0=t}}),Us.$metadata$={kind:c,simpleName:"AnimationComponent",interfaces:[Ys]},Fs.$metadata$={kind:c,simpleName:"AnimationObjectComponent",interfaces:[Ys]},qs.prototype.init_c257f0$=function(t){},qs.prototype.update_tqyjj6$=function(t,n){var i;for(i=this.getEntities_9u06oy$(p(Fs)).iterator();i.hasNext();){var r,o,a=i.next();if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Fs)))||e.isType(r,Fs)?r:C()))throw S("Component "+p(Fs).simpleName+" is not found");var s=o.animation;s.time=s.time+n,s.animate(),s.isFinished&&a.removeComponent_9u06oy$(p(Fs))}},qs.$metadata$={kind:c,simpleName:"AnimationObjectSystem",interfaces:[Bs]},Gs.prototype.updateProgress_0=function(t){var e;e=t.direction===vs()?this.progress_0(t):1-this.progress_0(t),t.progress=e},Gs.prototype.progress_0=function(t){return t.easingFunction(t.time/t.duration)},Gs.prototype.updateTime_0=function(t,e){var n,i=t.time+e,r=t.duration,o=t.loop;if(i>r){if(o===ks())n=r,t.finished=!0;else if(n=i%r,o===Es()){var a=g(t.direction.ordinal+i/r)%2;t.direction=bs()[a]}}else n=i;t.time=n},Gs.prototype.updateImpl_og8vrq$=function(t,n){var i;for(i=this.getEntities_9u06oy$(p(Us)).iterator();i.hasNext();){var r,o,a=i.next();if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Us)))||e.isType(r,Us)?r:C()))throw S("Component "+p(Us).simpleName+" is not found");var s=o;this.updateTime_0(s,n),this.updateProgress_0(s)}},Gs.$metadata$={kind:c,simpleName:"AnimationSystem",interfaces:[Bs]},Hs.$metadata$={kind:v,simpleName:"EcsClock",interfaces:[]},Ys.$metadata$={kind:v,simpleName:"EcsComponent",interfaces:[]},Object.defineProperty(Vs.prototype,"entitiesCount",{configurable:!0,get:function(){return this.myComponentsByEntity_0.size}}),Vs.prototype.createEntity_61zpoe$=function(t){var e,n=new Zs((e=this.myIdGenerator_0,this.myIdGenerator_0=e+1|0,e),t,this),i=this.myComponentsByEntity_0,r=n.componentsMap_8be2vx$;i.put_xwzc9p$(n,r);var o=this.myEntityById_0,a=n.id_8be2vx$;return o.put_xwzc9p$(a,n),n},Vs.prototype.getEntityById_za3lpa$=function(t){var e;return s(null!=(e=this.myEntityById_0.get_11rb$(t))?e.hasRemoveFlag()?null:e:null)},Vs.prototype.getEntitiesById_wlb8mv$=function(t){return this.notRemoved_0(tt(Q(t),(e=this,function(t){return e.myEntityById_0.get_11rb$(t)})));var e},Vs.prototype.getEntities_9u06oy$=function(t){var e;return this.notRemoved_1(null!=(e=this.myEntitiesByComponent_0.get_11rb$(t))?e:Me())},Vs.prototype.addComponent_pw9baj$=function(t,n){var i=this.myComponentsByEntity_0.get_11rb$(t);if(null==i)throw Ge("addComponent to non existing entity".toString());var r,o=e.getKClassFromExpression(n);if((e.isType(r=i,xe)?r:C()).containsKey_11rb$(o)){var a="Entity already has component with the type "+l(e.getKClassFromExpression(n));throw Ge(a.toString())}var s=e.getKClassFromExpression(n);i.put_xwzc9p$(s,n);var u,c=this.myEntitiesByComponent_0,p=e.getKClassFromExpression(n),h=c.get_11rb$(p);if(null==h){var _=pe();c.put_xwzc9p$(p,_),u=_}else u=h;u.add_11rb$(t)},Vs.prototype.getComponents_ahlfl2$=function(t){var e;return t.hasRemoveFlag()?Be():null!=(e=this.myComponentsByEntity_0.get_11rb$(t))?e:Be()},Vs.prototype.count_9u06oy$=function(t){var e,n,i;return null!=(i=null!=(n=null!=(e=this.myEntitiesByComponent_0.get_11rb$(t))?this.notRemoved_1(e):null)?$(n):null)?i:0},Vs.prototype.containsEntity_9u06oy$=function(t){return this.myEntitiesByComponent_0.containsKey_11rb$(t)},Vs.prototype.containsEntity_ahlfl2$=function(t){return!t.hasRemoveFlag()&&this.myComponentsByEntity_0.containsKey_11rb$(t)},Vs.prototype.getEntities_tv8pd9$=function(t){return y(this.getEntities_9u06oy$(Ue(t)),(e=t,function(t){return t.contains_tv8pd9$(e)}));var e},Vs.prototype.tryGetSingletonEntity_tv8pd9$=function(t){var e=this.getEntities_tv8pd9$(t);if(!($(e)<=1))throw S(("Entity with specified components is not a singleton: "+t).toString());return Fe(e)},Vs.prototype.getSingletonEntity_tv8pd9$=function(t){var e=this.tryGetSingletonEntity_tv8pd9$(t);if(null==e)throw S(("Entity with specified components does not exist: "+t).toString());return e},Vs.prototype.getSingletonEntity_9u06oy$=function(t){return this.getSingletonEntity_tv8pd9$(Wa(t))},Vs.prototype.getEntity_9u06oy$=function(t){var e;if(null==(e=Fe(this.getEntities_9u06oy$(t))))throw S(("Entity with specified component does not exist: "+t).toString());return e},Vs.prototype.getSingleton_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsComponentManager.getSingleton_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){var o,a,s=this.getSingletonEntity_9u06oy$(t(e));if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}}))),Vs.prototype.tryGetSingleton_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsComponentManager.tryGetSingleton_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){if(this.containsEntity_9u06oy$(t(e))){var o,a,s=this.getSingletonEntity_9u06oy$(t(e));if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}return null}}))),Vs.prototype.count_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsComponentManager.count_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){return this.count_9u06oy$(t(e))}}))),Vs.prototype.removeEntity_ag9c8t$=function(t){var e=this.myRemovedEntities_0;t.setRemoveFlag(),e.add_11rb$(t)},Vs.prototype.removeComponent_mfvtx1$=function(t,e){var n;this.removeEntityFromComponents_0(t,e),null!=(n=this.getComponentsWithRemoved_0(t))&&n.remove_11rb$(e)},Vs.prototype.getComponentsWithRemoved_0=function(t){return this.myComponentsByEntity_0.get_11rb$(t)},Vs.prototype.doRemove_8be2vx$=function(){var t;for(t=this.myRemovedEntities_0.iterator();t.hasNext();){var e,n,i=t.next();if(null!=(e=this.getComponentsWithRemoved_0(i)))for(n=e.entries.iterator();n.hasNext();){var r=n.next().key;this.removeEntityFromComponents_0(i,r)}this.myComponentsByEntity_0.remove_11rb$(i),this.myEntityById_0.remove_11rb$(i.id_8be2vx$)}this.myRemovedEntities_0.clear()},Vs.prototype.removeEntityFromComponents_0=function(t,e){var n;null!=(n=this.myEntitiesByComponent_0.get_11rb$(e))&&(n.remove_11rb$(t),n.isEmpty()&&this.myEntitiesByComponent_0.remove_11rb$(e))},Vs.prototype.notRemoved_1=function(t){return qe(Q(t),A("hasRemoveFlag",(function(t){return t.hasRemoveFlag()})))},Vs.prototype.notRemoved_0=function(t){return qe(t,Ks)},Vs.$metadata$={kind:c,simpleName:"EcsComponentManager",interfaces:[]},Object.defineProperty(Ws.prototype,"systemTime",{configurable:!0,get:function(){return this.systemTime_kac7b8$_0}}),Object.defineProperty(Ws.prototype,"frameStartTimeMs",{configurable:!0,get:function(){return this.frameStartTimeMs_fwcob4$_0},set:function(t){this.frameStartTimeMs_fwcob4$_0=t}}),Object.defineProperty(Ws.prototype,"frameDurationMs",{configurable:!0,get:function(){return this.systemTime.getTimeMs().subtract(this.frameStartTimeMs)}}),Ws.prototype.startFrame_8be2vx$=function(){this.tick=this.tick.inc(),this.frameStartTimeMs=this.systemTime.getTimeMs()},Ws.$metadata$={kind:c,simpleName:"EcsContext",interfaces:[Hs]},Xs.prototype.update_14dthe$=function(t){var e;for(this.myContext_0.startFrame_8be2vx$(),this.myDebugService_0.reset(),e=this.mySystems_0.iterator();e.hasNext();){var n=e.next();this.myDebugService_0.beginMeasureUpdate(),n.update_tqyjj6$(this.myContext_0,t),this.myDebugService_0.endMeasureUpdate_ha9gfm$(n)}this.myComponentManager_0.doRemove_8be2vx$()},Xs.prototype.dispose=function(){var t;for(t=this.mySystems_0.iterator();t.hasNext();)t.next().destroy()},Xs.$metadata$={kind:c,simpleName:"EcsController",interfaces:[U]},Object.defineProperty(Zs.prototype,"components_0",{configurable:!0,get:function(){return this.componentsMap_8be2vx$.values}}),Zs.prototype.toString=function(){return this.name},Zs.prototype.add_57nep2$=function(t){return this.componentManager.addComponent_pw9baj$(this,t),this},Zs.prototype.get_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.get_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){var o,a;if(null==(a=null==(o=this.componentManager.getComponents_ahlfl2$(this).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}}))),Zs.prototype.tryGet_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.tryGet_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){if(this.contains_9u06oy$(t(e))){var o,a;if(null==(a=null==(o=this.componentManager.getComponents_ahlfl2$(this).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}return null}}))),Zs.prototype.provide_fpbork$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.provide_fpbork$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r,o){if(this.contains_9u06oy$(t(e))){var a,s;if(null==(s=null==(a=this.componentManager.getComponents_ahlfl2$(this).get_11rb$(t(e)))||r(a)?a:n()))throw i("Component "+t(e).simpleName+" is not found");return s}var l=o();return this.add_57nep2$(l),l}}))),Zs.prototype.addComponent_qqqpmc$=function(t){return this.componentManager.addComponent_pw9baj$(this,t),this},Zs.prototype.setComponent_qqqpmc$=function(t){return this.contains_9u06oy$(e.getKClassFromExpression(t))&&this.componentManager.removeComponent_mfvtx1$(this,e.getKClassFromExpression(t)),this.componentManager.addComponent_pw9baj$(this,t),this},Zs.prototype.removeComponent_9u06oy$=function(t){this.componentManager.removeComponent_mfvtx1$(this,t)},Zs.prototype.remove=function(){this.componentManager.removeEntity_ag9c8t$(this)},Zs.prototype.contains_9u06oy$=function(t){return this.componentManager.getComponents_ahlfl2$(this).containsKey_11rb$(t)},Zs.prototype.contains_tv8pd9$=function(t){return this.componentManager.getComponents_ahlfl2$(this).keys.containsAll_brywnq$(t)},Zs.prototype.getComponent_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.getComponent_s66lbm$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r){var o,a;if(null==(a=null==(o=this.componentManager.getComponents_ahlfl2$(this).get_11rb$(t(e)))||r(o)?o:n()))throw i("Component "+t(e).simpleName+" is not found");return a}}))),Zs.prototype.contains_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.contains_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){return this.contains_9u06oy$(t(e))}}))),Zs.prototype.remove_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.remove_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){return this.removeComponent_9u06oy$(t(e)),this}}))),Zs.prototype.tag_fpbork$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.tag_fpbork$",Le((function(){var t=e.getKClass,n=e.throwCCE,i=e.kotlin.IllegalStateException_init_pdl1vj$;return function(e,r,o){var a;if(this.contains_9u06oy$(t(e))){var s,l;if(null==(l=null==(s=this.componentManager.getComponents_ahlfl2$(this).get_11rb$(t(e)))||r(s)?s:n()))throw i("Component "+t(e).simpleName+" is not found");a=l}else{var u=o();this.add_57nep2$(u),a=u}return a}}))),Zs.prototype.untag_s66lbm$=De("lets-plot-livemap.jetbrains.livemap.core.ecs.EcsEntity.untag_s66lbm$",Le((function(){var t=e.getKClass;return function(e,n){this.removeComponent_9u06oy$(t(e))}}))),Zs.$metadata$={kind:c,simpleName:"EcsEntity",interfaces:[tl]},Js.prototype.unaryPlus_jixjl7$=function(t){this.components.add_11rb$(t)},Js.$metadata$={kind:c,simpleName:"ComponentsList",interfaces:[]},tl.prototype.setRemoveFlag=function(){this.removeFlag_krvsok$_0=!0},tl.prototype.hasRemoveFlag=function(){return this.removeFlag_krvsok$_0},tl.$metadata$={kind:c,simpleName:"EcsRemovable",interfaces:[]},el.$metadata$={kind:v,simpleName:"EcsSystem",interfaces:[]},Object.defineProperty(nl.prototype,"rect",{configurable:!0,get:function(){return new He(this.myRenderBox_0.origin,this.myRenderBox_0.dimension)}}),nl.$metadata$={kind:c,simpleName:"ClickableComponent",interfaces:[Ys]},il.$metadata$={kind:c,simpleName:"CursorStyleComponent",interfaces:[Ys]},rl.$metadata$={kind:c,simpleName:"CursorStyle",interfaces:[me]},rl.values=function(){return[al()]},rl.valueOf_61zpoe$=function(t){switch(t){case"POINTER":return al();default:ye("No enum constant jetbrains.livemap.core.input.CursorStyle."+t)}},sl.prototype.initImpl_4pvjek$=function(t){this.componentManager.createEntity_61zpoe$("CursorInputComponent").add_57nep2$(this.myInput_0)},sl.prototype.updateImpl_og8vrq$=function(t,n){var i;if(null!=(i=this.myInput_0.location)){var r,o,a,s=this.getEntities_38uplf$(_l().COMPONENT_TYPES_0);t:do{var l;for(l=s.iterator();l.hasNext();){var u,c,h=l.next();if(null==(c=null==(u=h.componentManager.getComponents_ahlfl2$(h).get_11rb$(p(nl)))||e.isType(u,nl)?u:C()))throw S("Component "+p(nl).simpleName+" is not found");if(c.rect.contains_gpjtzr$(i.toDoubleVector())){a=h;break t}}a=null}while(0);if(null!=(r=a)){var _,f;if(null==(f=null==(_=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(il)))||e.isType(_,il)?_:C()))throw S("Component "+p(il).simpleName+" is not found");Bt(f.cursorStyle,al())&&this.myCursorService_0.pointer(),o=N}else o=null;null!=o||this.myCursorService_0.default()}},ll.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var ul,cl,pl,hl=null;function _l(){return null===hl&&new ll,hl}function fl(){this.pressListeners_0=w(),this.clickListeners_0=w(),this.doubleClickListeners_0=w()}function dl(t){this.location=t,this.isStopped_wl0zz7$_0=!1}function ml(t,e){me.call(this),this.name$=t,this.ordinal$=e}function yl(){yl=function(){},ul=new ml("PRESS",0),cl=new ml("CLICK",1),pl=new ml("DOUBLE_CLICK",2)}function $l(){return yl(),ul}function vl(){return yl(),cl}function gl(){return yl(),pl}function bl(){return[$l(),vl(),gl()]}function wl(){this.location=null,this.dragDistance=null,this.press=null,this.click=null,this.doubleClick=null}function xl(t){Sl(),Bs.call(this,t),this.myInteractiveEntityView_0=new kl}function kl(){this.myInput_e8l61w$_0=this.myInput_e8l61w$_0,this.myClickable_rbak90$_0=this.myClickable_rbak90$_0,this.myListeners_gfgcs9$_0=this.myListeners_gfgcs9$_0,this.myEntity_2u1elx$_0=this.myEntity_2u1elx$_0}function El(){Cl=this,this.COMPONENTS_0=x([p(wl),p(nl),p(fl)])}sl.$metadata$={kind:c,simpleName:"CursorStyleSystem",interfaces:[Bs]},fl.prototype.getListeners_skrnrl$=function(t){var n;switch(t.name){case"PRESS":n=this.pressListeners_0;break;case"CLICK":n=this.clickListeners_0;break;case"DOUBLE_CLICK":n=this.doubleClickListeners_0;break;default:n=e.noWhenBranchMatched()}return n},fl.prototype.contains_uuhdck$=function(t){return!this.getListeners_skrnrl$(t).isEmpty()},fl.prototype.addPressListener_abz6et$=function(t){this.pressListeners_0.add_11rb$(t)},fl.prototype.removePressListener=function(){this.pressListeners_0.clear()},fl.prototype.removePressListener_abz6et$=function(t){this.pressListeners_0.remove_11rb$(t)},fl.prototype.addClickListener_abz6et$=function(t){this.clickListeners_0.add_11rb$(t)},fl.prototype.removeClickListener=function(){this.clickListeners_0.clear()},fl.prototype.removeClickListener_abz6et$=function(t){this.clickListeners_0.remove_11rb$(t)},fl.prototype.addDoubleClickListener_abz6et$=function(t){this.doubleClickListeners_0.add_11rb$(t)},fl.prototype.removeDoubleClickListener=function(){this.doubleClickListeners_0.clear()},fl.prototype.removeDoubleClickListener_abz6et$=function(t){this.doubleClickListeners_0.remove_11rb$(t)},fl.$metadata$={kind:c,simpleName:"EventListenerComponent",interfaces:[Ys]},Object.defineProperty(dl.prototype,"isStopped",{configurable:!0,get:function(){return this.isStopped_wl0zz7$_0},set:function(t){this.isStopped_wl0zz7$_0=t}}),dl.prototype.stopPropagation=function(){this.isStopped=!0},dl.$metadata$={kind:c,simpleName:"InputMouseEvent",interfaces:[]},ml.$metadata$={kind:c,simpleName:"MouseEventType",interfaces:[me]},ml.values=bl,ml.valueOf_61zpoe$=function(t){switch(t){case"PRESS":return $l();case"CLICK":return vl();case"DOUBLE_CLICK":return gl();default:ye("No enum constant jetbrains.livemap.core.input.MouseEventType."+t)}},wl.prototype.getEvent_uuhdck$=function(t){var n;switch(t.name){case"PRESS":n=this.press;break;case"CLICK":n=this.click;break;case"DOUBLE_CLICK":n=this.doubleClick;break;default:n=e.noWhenBranchMatched()}return n},wl.$metadata$={kind:c,simpleName:"MouseInputComponent",interfaces:[Ys]},xl.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o,a,s,l,u=st(),c=this.componentManager.getSingletonEntity_9u06oy$(p(dc));if(null==(l=null==(s=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(dc)))||e.isType(s,dc)?s:C()))throw S("Component "+p(dc).simpleName+" is not found");var h,_=l.canvasLayers;for(h=this.getEntities_38uplf$(Sl().COMPONENTS_0).iterator();h.hasNext();){var f=h.next();this.myInteractiveEntityView_0.setEntity_ag9c8t$(f);var d,m=bl();for(d=0;d!==m.length;++d){var y=m[d];if(this.myInteractiveEntityView_0.needToAdd_uuhdck$(y)){var $,v=this.myInteractiveEntityView_0,g=u.get_11rb$(y);if(null==g){var b=st();u.put_xwzc9p$(y,b),$=b}else $=g;v.addTo_o8fzf1$($,this.getZIndex_0(f,_))}}}for(i=bl(),r=0;r!==i.length;++r){var w=i[r];if(null!=(o=u.get_11rb$(w)))for(var x=o,k=_.size;k>=0;k--)null!=(a=x.get_11rb$(k))&&this.acceptListeners_0(w,a)}},xl.prototype.acceptListeners_0=function(t,n){var i;for(i=n.iterator();i.hasNext();){var r,o,a,s=i.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(wl)))||e.isType(o,wl)?o:C()))throw S("Component "+p(wl).simpleName+" is not found");var l,u,c=a;if(null==(u=null==(l=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(fl)))||e.isType(l,fl)?l:C()))throw S("Component "+p(fl).simpleName+" is not found");var h,_=u;if(null!=(r=c.getEvent_uuhdck$(t))&&!r.isStopped)for(h=_.getListeners_skrnrl$(t).iterator();h.hasNext();)h.next()(r)}},xl.prototype.getZIndex_0=function(t,n){var i;if(t.contains_9u06oy$(p(ko)))i=0;else{var r,o,a=t.componentManager;if(null==(o=null==(r=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(yc)))||e.isType(r,yc)?r:C()))throw S("Component "+p(yc).simpleName+" is not found");var s,l,u=a.getEntityById_za3lpa$(o.layerId);if(null==(l=null==(s=u.componentManager.getComponents_ahlfl2$(u).get_11rb$(p(mc)))||e.isType(s,mc)?s:C()))throw S("Component "+p(mc).simpleName+" is not found");var c=l.canvasLayer;i=n.indexOf_11rb$(c)+1|0}return i},Object.defineProperty(kl.prototype,"myInput_0",{configurable:!0,get:function(){return null==this.myInput_e8l61w$_0?T("myInput"):this.myInput_e8l61w$_0},set:function(t){this.myInput_e8l61w$_0=t}}),Object.defineProperty(kl.prototype,"myClickable_0",{configurable:!0,get:function(){return null==this.myClickable_rbak90$_0?T("myClickable"):this.myClickable_rbak90$_0},set:function(t){this.myClickable_rbak90$_0=t}}),Object.defineProperty(kl.prototype,"myListeners_0",{configurable:!0,get:function(){return null==this.myListeners_gfgcs9$_0?T("myListeners"):this.myListeners_gfgcs9$_0},set:function(t){this.myListeners_gfgcs9$_0=t}}),Object.defineProperty(kl.prototype,"myEntity_0",{configurable:!0,get:function(){return null==this.myEntity_2u1elx$_0?T("myEntity"):this.myEntity_2u1elx$_0},set:function(t){this.myEntity_2u1elx$_0=t}}),kl.prototype.setEntity_ag9c8t$=function(t){var n,i,r,o,a,s;if(this.myEntity_0=t,null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(wl)))||e.isType(n,wl)?n:C()))throw S("Component "+p(wl).simpleName+" is not found");if(this.myInput_0=i,null==(o=null==(r=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(nl)))||e.isType(r,nl)?r:C()))throw S("Component "+p(nl).simpleName+" is not found");if(this.myClickable_0=o,null==(s=null==(a=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(fl)))||e.isType(a,fl)?a:C()))throw S("Component "+p(fl).simpleName+" is not found");this.myListeners_0=s},kl.prototype.needToAdd_uuhdck$=function(t){var e=this.myInput_0.getEvent_uuhdck$(t);return null!=e&&this.myListeners_0.contains_uuhdck$(t)&&this.myClickable_0.rect.contains_gpjtzr$(e.location.toDoubleVector())},kl.prototype.addTo_o8fzf1$=function(t,e){var n,i=t.get_11rb$(e);if(null==i){var r=w();t.put_xwzc9p$(e,r),n=r}else n=i;n.add_11rb$(this.myEntity_0)},kl.$metadata$={kind:c,simpleName:"InteractiveEntityView",interfaces:[]},El.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Cl=null;function Sl(){return null===Cl&&new El,Cl}function Tl(t){Bs.call(this,t),this.myRegs_0=new We([]),this.myLocation_0=null,this.myDragStartLocation_0=null,this.myDragCurrentLocation_0=null,this.myDragDelta_0=null,this.myPressEvent_0=null,this.myClickEvent_0=null,this.myDoubleClickEvent_0=null}function Ol(t,e){this.mySystemTime_0=t,this.myMicroTask_0=e,this.finishEventSource_0=new M,this.processTime_hf7vj9$_0=u,this.maxResumeTime_v6sfa5$_0=u}function Nl(t){this.closure$handler=t}function Pl(){}function Al(t,e){return ql().map_69kpin$(t,e)}function jl(t,e){return ql().flatMap_fgpnzh$(t,e)}function Ll(t,e){this.myClock_0=t,this.myFrameDurationLimit_0=e}function Rl(){}function Il(){Fl=this,this.EMPTY_MICRO_THREAD_0=new Ul}function zl(t,e){this.closure$microTask=t,this.closure$mapFunction=e,this.result_0=null,this.transformed_0=!1}function Dl(t,e){this.closure$microTask=t,this.closure$mapFunction=e,this.transformed_0=!1,this.result_0=null}function Ml(t){this.myTasks_0=t.iterator()}function Bl(t){this.threads_0=t.iterator(),this.currentMicroThread_0=ql().EMPTY_MICRO_THREAD_0,this.goToNextAliveMicroThread_0()}function Ul(){}xl.$metadata$={kind:c,simpleName:"MouseInputDetectionSystem",interfaces:[Bs]},Tl.prototype.init_c257f0$=function(t){this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_DOUBLE_CLICKED,Ve(A("onMouseDoubleClicked",function(t,e){return t.onMouseDoubleClicked_0(e),N}.bind(null,this))))),this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_PRESSED,Ve(A("onMousePressed",function(t,e){return t.onMousePressed_0(e),N}.bind(null,this))))),this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_RELEASED,Ve(A("onMouseReleased",function(t,e){return t.onMouseReleased_0(e),N}.bind(null,this))))),this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_DRAGGED,Ve(A("onMouseDragged",function(t,e){return t.onMouseDragged_0(e),N}.bind(null,this))))),this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_MOVED,Ve(A("onMouseMoved",function(t,e){return t.onMouseMoved_0(e),N}.bind(null,this))))),this.myRegs_0.add_3xv6fb$(t.eventSource.addEventHandler_mfdhbe$(Ye.MOUSE_CLICKED,Ve(A("onMouseClicked",function(t,e){return t.onMouseClicked_0(e),N}.bind(null,this)))))},Tl.prototype.update_tqyjj6$=function(t,n){var i,r;for(null!=(i=this.myDragCurrentLocation_0)&&(Bt(i,this.myDragStartLocation_0)||(this.myDragDelta_0=i.sub_119tl4$(s(this.myDragStartLocation_0)),this.myDragStartLocation_0=i)),r=this.getEntities_9u06oy$(p(wl)).iterator();r.hasNext();){var o,a,l=r.next();if(null==(a=null==(o=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(wl)))||e.isType(o,wl)?o:C()))throw S("Component "+p(wl).simpleName+" is not found");a.location=this.myLocation_0,a.dragDistance=this.myDragDelta_0,a.press=this.myPressEvent_0,a.click=this.myClickEvent_0,a.doubleClick=this.myDoubleClickEvent_0}this.myLocation_0=null,this.myPressEvent_0=null,this.myClickEvent_0=null,this.myDoubleClickEvent_0=null,this.myDragDelta_0=null},Tl.prototype.destroy=function(){this.myRegs_0.dispose()},Tl.prototype.onMouseClicked_0=function(t){t.button===Ke.LEFT&&(this.myClickEvent_0=new dl(t.location),this.myDragCurrentLocation_0=null,this.myDragStartLocation_0=null)},Tl.prototype.onMousePressed_0=function(t){t.button===Ke.LEFT&&(this.myPressEvent_0=new dl(t.location),this.myDragStartLocation_0=t.location)},Tl.prototype.onMouseReleased_0=function(t){t.button===Ke.LEFT&&(this.myDragCurrentLocation_0=null,this.myDragStartLocation_0=null)},Tl.prototype.onMouseDragged_0=function(t){null!=this.myDragStartLocation_0&&(this.myDragCurrentLocation_0=t.location)},Tl.prototype.onMouseDoubleClicked_0=function(t){t.button===Ke.LEFT&&(this.myDoubleClickEvent_0=new dl(t.location))},Tl.prototype.onMouseMoved_0=function(t){this.myLocation_0=t.location},Tl.$metadata$={kind:c,simpleName:"MouseInputSystem",interfaces:[Bs]},Object.defineProperty(Ol.prototype,"processTime",{configurable:!0,get:function(){return this.processTime_hf7vj9$_0},set:function(t){this.processTime_hf7vj9$_0=t}}),Object.defineProperty(Ol.prototype,"maxResumeTime",{configurable:!0,get:function(){return this.maxResumeTime_v6sfa5$_0},set:function(t){this.maxResumeTime_v6sfa5$_0=t}}),Ol.prototype.resume=function(){var t=this.mySystemTime_0.getTimeMs();this.myMicroTask_0.resume();var e=this.mySystemTime_0.getTimeMs().subtract(t);this.processTime=this.processTime.add(e);var n=this.maxResumeTime;this.maxResumeTime=e.compareTo_11rb$(n)>=0?e:n,this.myMicroTask_0.alive()||this.finishEventSource_0.fire_11rb$(null)},Nl.prototype.onEvent_11rb$=function(t){this.closure$handler()},Nl.$metadata$={kind:c,interfaces:[O]},Ol.prototype.addFinishHandler_o14v8n$=function(t){return this.finishEventSource_0.addHandler_gxwwpc$(new Nl(t))},Ol.prototype.alive=function(){return this.myMicroTask_0.alive()},Ol.prototype.getResult=function(){return this.myMicroTask_0.getResult()},Ol.$metadata$={kind:c,simpleName:"DebugMicroTask",interfaces:[Pl]},Pl.$metadata$={kind:v,simpleName:"MicroTask",interfaces:[]},Ll.prototype.start=function(){},Ll.prototype.stop=function(){},Ll.prototype.updateAndGetFinished_gjcz1g$=function(t){for(var e=pe(),n=!0;;){var i=n;if(i&&(i=!t.isEmpty()),!i)break;for(var r=t.iterator();r.hasNext();){if(this.myClock_0.frameDurationMs.compareTo_11rb$(this.myFrameDurationLimit_0)>0){n=!1;break}for(var o,a=r.next(),s=a.resumesBeforeTimeCheck_8be2vx$;s=(o=s)-1|0,o>0&&a.microTask.alive();)a.microTask.resume();a.microTask.alive()||(e.add_11rb$(a),r.remove())}}return e},Ll.$metadata$={kind:c,simpleName:"MicroTaskCooperativeExecutor",interfaces:[Rl]},Rl.$metadata$={kind:v,simpleName:"MicroTaskExecutor",interfaces:[]},zl.prototype.resume=function(){this.closure$microTask.alive()?this.closure$microTask.resume():this.transformed_0||(this.result_0=this.closure$mapFunction(this.closure$microTask.getResult()),this.transformed_0=!0)},zl.prototype.alive=function(){return this.closure$microTask.alive()||!this.transformed_0},zl.prototype.getResult=function(){var t;if(null==(t=this.result_0))throw S("".toString());return t},zl.$metadata$={kind:c,interfaces:[Pl]},Il.prototype.map_69kpin$=function(t,e){return new zl(t,e)},Dl.prototype.resume=function(){this.closure$microTask.alive()?this.closure$microTask.resume():this.transformed_0?s(this.result_0).alive()&&s(this.result_0).resume():(this.result_0=this.closure$mapFunction(this.closure$microTask.getResult()),this.transformed_0=!0)},Dl.prototype.alive=function(){return this.closure$microTask.alive()||!this.transformed_0||s(this.result_0).alive()},Dl.prototype.getResult=function(){return s(this.result_0).getResult()},Dl.$metadata$={kind:c,interfaces:[Pl]},Il.prototype.flatMap_fgpnzh$=function(t,e){return new Dl(t,e)},Il.prototype.create_o14v8n$=function(t){return new Ml(ct(t))},Il.prototype.create_xduz9s$=function(t){return new Ml(t)},Il.prototype.join_asgahm$=function(t){return new Bl(t)},Ml.prototype.resume=function(){this.myTasks_0.next()()},Ml.prototype.alive=function(){return this.myTasks_0.hasNext()},Ml.prototype.getResult=function(){return N},Ml.$metadata$={kind:c,simpleName:"CompositeMicroThread",interfaces:[Pl]},Bl.prototype.resume=function(){this.currentMicroThread_0.resume(),this.goToNextAliveMicroThread_0()},Bl.prototype.alive=function(){return this.currentMicroThread_0.alive()},Bl.prototype.getResult=function(){return N},Bl.prototype.goToNextAliveMicroThread_0=function(){for(;!this.currentMicroThread_0.alive();){if(!this.threads_0.hasNext())return;this.currentMicroThread_0=this.threads_0.next()}},Bl.$metadata$={kind:c,simpleName:"MultiMicroThread",interfaces:[Pl]},Ul.prototype.getResult=function(){return N},Ul.prototype.resume=function(){},Ul.prototype.alive=function(){return!1},Ul.$metadata$={kind:c,interfaces:[Pl]},Il.$metadata$={kind:b,simpleName:"MicroTaskUtil",interfaces:[]};var Fl=null;function ql(){return null===Fl&&new Il,Fl}function Gl(t,e){this.microTask=t,this.resumesBeforeTimeCheck_8be2vx$=e}function Hl(t,e,n){t.setComponent_qqqpmc$(new Gl(n,e))}function Yl(t,e){Bs.call(this,e),this.microTaskExecutor_0=t,this.loading_dhgexf$_0=u}function Vl(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Gl)))||e.isType(n,Gl)?n:C()))throw S("Component "+p(Gl).simpleName+" is not found");return i}function Kl(t,e){this.transform_0=t,this.epsilonSqr_0=e*e}function Wl(){Jl()}function Xl(){Zl=this,this.LON_LIMIT_0=new en(179.999),this.LAT_LIMIT_0=new en(90),this.VALID_RECTANGLE_0=on(rn(nn(this.LON_LIMIT_0),nn(this.LAT_LIMIT_0)),rn(this.LON_LIMIT_0,this.LAT_LIMIT_0))}Gl.$metadata$={kind:c,simpleName:"MicroThreadComponent",interfaces:[Ys]},Object.defineProperty(Yl.prototype,"loading",{configurable:!0,get:function(){return this.loading_dhgexf$_0},set:function(t){this.loading_dhgexf$_0=t}}),Yl.prototype.initImpl_4pvjek$=function(t){this.microTaskExecutor_0.start()},Yl.prototype.updateImpl_og8vrq$=function(t,n){if(this.componentManager.count_9u06oy$(p(Gl))>0){var i,r=Q(Ft(this.getEntities_9u06oy$(p(Gl)))),o=Xe(h(r,Vl)),a=A("updateAndGetFinished",function(t,e){return t.updateAndGetFinished_gjcz1g$(e)}.bind(null,this.microTaskExecutor_0))(o);for(i=y(r,function(t){return function(n){var i,r,o=t;if(null==(r=null==(i=n.componentManager.getComponents_ahlfl2$(n).get_11rb$(p(Gl)))||e.isType(i,Gl)?i:C()))throw S("Component "+p(Gl).simpleName+" is not found");return o.contains_11rb$(r)}}(a)).iterator();i.hasNext();)i.next().removeComponent_9u06oy$(p(Gl));this.loading=t.frameDurationMs}else this.loading=u},Yl.prototype.destroy=function(){this.microTaskExecutor_0.stop()},Yl.$metadata$={kind:c,simpleName:"SchedulerSystem",interfaces:[Bs]},Kl.prototype.pop_0=function(t){var e=t.get_za3lpa$(Ze(t));return t.removeAt_za3lpa$(Ze(t)),e},Kl.prototype.resample_ohchv7$=function(t){var e,n=rt(t.size);e=t.size;for(var i=1;i0?n<-wt.PI/2+ru().EPSILON_0&&(n=-wt.PI/2+ru().EPSILON_0):n>wt.PI/2-ru().EPSILON_0&&(n=wt.PI/2-ru().EPSILON_0);var i=this.f_0,r=ru().tany_0(n),o=this.n_0,a=i/Z.pow(r,o),s=this.n_0*e,l=a*Z.sin(s),u=this.f_0,c=this.n_0*e,p=u-a*Z.cos(c);return Qu().safePoint_y7b45i$(l,p)},eu.prototype.invert_11rc$=function(t){var e=t.x,n=t.y,i=this.f_0-n,r=this.n_0,o=e*e+i*i,a=Z.sign(r)*Z.sqrt(o),s=Z.abs(i),l=tn(Z.atan2(e,s)/this.n_0*Z.sign(i)),u=this.f_0/a,c=1/this.n_0,p=Z.pow(u,c),h=tn(2*Z.atan(p)-wt.PI/2);return Qu().safePoint_y7b45i$(l,h)},nu.prototype.tany_0=function(t){var e=(wt.PI/2+t)/2;return Z.tan(e)},nu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var iu=null;function ru(){return null===iu&&new nu,iu}function ou(t,e){pu(),this.n_0=0,this.c_0=0,this.r0_0=0;var n=Z.sin(t);this.n_0=(n+Z.sin(e))/2,this.c_0=1+n*(2*this.n_0-n);var i=this.c_0;this.r0_0=Z.sqrt(i)/this.n_0}function au(){cu=this,this.VALID_RECTANGLE_0=on(H(-180,-90),H(180,90))}eu.$metadata$={kind:c,simpleName:"ConicConformalProjection",interfaces:[hu]},ou.prototype.validRect=function(){return pu().VALID_RECTANGLE_0},ou.prototype.project_11rb$=function(t){var e=Qe(t.x),n=Qe(t.y),i=this.c_0-2*this.n_0*Z.sin(n),r=Z.sqrt(i)/this.n_0;e*=this.n_0;var o=r*Z.sin(e),a=this.r0_0-r*Z.cos(e);return Qu().safePoint_y7b45i$(o,a)},ou.prototype.invert_11rc$=function(t){var e=t.x,n=t.y,i=this.r0_0-n,r=Z.abs(i),o=tn(Z.atan2(e,r)/this.n_0*Z.sign(i)),a=(this.c_0-(e*e+i*i)*this.n_0*this.n_0)/(2*this.n_0),s=tn(Z.asin(a));return Qu().safePoint_y7b45i$(o,s)},au.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var su,lu,uu,cu=null;function pu(){return null===cu&&new au,cu}function hu(){}function _u(t){var e,n=w();if(t.isEmpty())return n;n.add_11rb$(t.get_za3lpa$(0)),e=t.size;for(var i=1;i=0?1:-1)*uu/2;return t.add_11rb$(K(e,void 0,(r=l,function(t){return new en(r)}))),void t.add_11rb$(K(n,void 0,function(t){return function(e){return new en(t)}}(l)))}for(var u=du(e.x,n.x)<=du(n.x,e.x)?1:-1,c=mu(e.y),p=Z.tan(c),h=mu(n.y),_=Z.tan(h),f=mu(n.x-e.x),d=Z.sin(f),m=e.x;;){var y=m-n.x;if(!(Z.abs(y)>su))break;var $=mu((m=ln(m+=u*su))-e.x),v=_*Z.sin($),g=mu(n.x-m),b=(v+p*Z.sin(g))/d,w=(i=Z.atan(b),uu*i/wt.PI);t.add_11rb$(H(m,w))}}}function du(t,e){var n=e-t;return n+(n<0?lu:0)}function mu(t){return wt.PI*t/uu}function yu(){gu()}function $u(){vu=this,this.VALID_RECTANGLE_0=on(H(-180,-90),H(180,90))}ou.$metadata$={kind:c,simpleName:"ConicEqualAreaProjection",interfaces:[hu]},hu.$metadata$={kind:v,simpleName:"GeoProjection",interfaces:[Au]},yu.prototype.project_11rb$=function(t){return H(_t(t.x),ft(t.y))},yu.prototype.invert_11rc$=function(t){return H(_t(t.x),ft(t.y))},yu.prototype.validRect=function(){return gu().VALID_RECTANGLE_0},$u.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var vu=null;function gu(){return null===vu&&new $u,vu}function bu(){}function wu(){Pu()}function xu(){Nu=this,this.VALID_RECTANGLE_0=on(H(G.MercatorUtils.VALID_LONGITUDE_RANGE.lowerEnd,G.MercatorUtils.VALID_LATITUDE_RANGE.lowerEnd),H(G.MercatorUtils.VALID_LONGITUDE_RANGE.upperEnd,G.MercatorUtils.VALID_LATITUDE_RANGE.upperEnd))}yu.$metadata$={kind:c,simpleName:"GeographicProjection",interfaces:[hu]},bu.$metadata$={kind:v,simpleName:"MapRuler",interfaces:[]},wu.prototype.project_11rb$=function(t){return H(G.MercatorUtils.getMercatorX_14dthe$(_t(t.x)),G.MercatorUtils.getMercatorY_14dthe$(ft(t.y)))},wu.prototype.invert_11rc$=function(t){return H(_t(G.MercatorUtils.getLongitude_14dthe$(t.x)),ft(G.MercatorUtils.getLatitude_14dthe$(t.y)))},wu.prototype.validRect=function(){return Pu().VALID_RECTANGLE_0},xu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var ku,Eu,Cu,Su,Tu,Ou,Nu=null;function Pu(){return null===Nu&&new xu,Nu}function Au(){}function ju(t,e){me.call(this),this.name$=t,this.ordinal$=e}function Lu(){Lu=function(){},ku=new ju("GEOGRAPHIC",0),Eu=new ju("MERCATOR",1),Cu=new ju("AZIMUTHAL_EQUAL_AREA",2),Su=new ju("AZIMUTHAL_EQUIDISTANT",3),Tu=new ju("CONIC_CONFORMAL",4),Ou=new ju("CONIC_EQUAL_AREA",5)}function Ru(){return Lu(),ku}function Iu(){return Lu(),Eu}function zu(){return Lu(),Cu}function Du(){return Lu(),Su}function Mu(){return Lu(),Tu}function Bu(){return Lu(),Ou}function Uu(){Ju=this,this.SAMPLING_EPSILON_0=.001,this.PROJECTION_MAP_0=fn([_n(Ru(),new yu),_n(Iu(),new wu),_n(zu(),new Ql),_n(Du(),new tu),_n(Mu(),new eu(0,wt.PI/3)),_n(Bu(),new ou(0,wt.PI/3))])}function Fu(t,e){this.closure$xProjection=t,this.closure$yProjection=e}function qu(t,e){this.closure$t1=t,this.closure$t2=e}function Gu(t){this.closure$scale=t}function Hu(t){this.closure$offset=t}wu.$metadata$={kind:c,simpleName:"MercatorProjection",interfaces:[hu]},Au.$metadata$={kind:v,simpleName:"Projection",interfaces:[]},ju.$metadata$={kind:c,simpleName:"ProjectionType",interfaces:[me]},ju.values=function(){return[Ru(),Iu(),zu(),Du(),Mu(),Bu()]},ju.valueOf_61zpoe$=function(t){switch(t){case"GEOGRAPHIC":return Ru();case"MERCATOR":return Iu();case"AZIMUTHAL_EQUAL_AREA":return zu();case"AZIMUTHAL_EQUIDISTANT":return Du();case"CONIC_CONFORMAL":return Mu();case"CONIC_EQUAL_AREA":return Bu();default:ye("No enum constant jetbrains.livemap.core.projections.ProjectionType."+t)}},Uu.prototype.createGeoProjection_7v9tu4$=function(t){var e;if(null==(e=this.PROJECTION_MAP_0.get_11rb$(t)))throw S(("Unknown projection type: "+t).toString());return e},Uu.prototype.calculateAngle_l9poh5$=function(t,e){var n=t.y-e.y,i=e.x-t.x;return Z.atan2(n,i)},Uu.prototype.rectToPolygon_0=function(t){var e,n=w();return n.add_11rb$(t.origin),n.add_11rb$(K(t.origin,(e=t,function(t){return W(t,un(e))}))),n.add_11rb$(L(t.origin,t.dimension)),n.add_11rb$(K(t.origin,void 0,function(t){return function(e){return W(e,cn(t))}}(t))),n.add_11rb$(t.origin),n},Uu.prototype.square_ilk2sd$=function(t){return this.tuple_bkiy7g$(t,t)},Fu.prototype.project_11rb$=function(t){return H(this.closure$xProjection.project_11rb$(t.x),this.closure$yProjection.project_11rb$(t.y))},Fu.prototype.invert_11rc$=function(t){return H(this.closure$xProjection.invert_11rc$(t.x),this.closure$yProjection.invert_11rc$(t.y))},Fu.$metadata$={kind:c,interfaces:[Au]},Uu.prototype.tuple_bkiy7g$=function(t,e){return new Fu(t,e)},qu.prototype.project_11rb$=function(t){var e=A("project",function(t,e){return t.project_11rb$(e)}.bind(null,this.closure$t1))(t);return A("project",function(t,e){return t.project_11rb$(e)}.bind(null,this.closure$t2))(e)},qu.prototype.invert_11rc$=function(t){var e=A("invert",function(t,e){return t.invert_11rc$(e)}.bind(null,this.closure$t2))(t);return A("invert",function(t,e){return t.invert_11rc$(e)}.bind(null,this.closure$t1))(e)},qu.$metadata$={kind:c,interfaces:[Au]},Uu.prototype.composite_ogd8x7$=function(t,e){return new qu(t,e)},Uu.prototype.zoom_t0n4v2$=function(t){return this.scale_d4mmvr$((e=t,function(){var t=e();return Z.pow(2,t)}));var e},Gu.prototype.project_11rb$=function(t){return t*this.closure$scale()},Gu.prototype.invert_11rc$=function(t){return t/this.closure$scale()},Gu.$metadata$={kind:c,interfaces:[Au]},Uu.prototype.scale_d4mmvr$=function(t){return new Gu(t)},Uu.prototype.linear_sdh6z7$=function(t,e){return this.composite_ogd8x7$(this.offset_tq0o01$(t),this.scale_tq0o01$(e))},Hu.prototype.project_11rb$=function(t){return t-this.closure$offset},Hu.prototype.invert_11rc$=function(t){return t+this.closure$offset},Hu.$metadata$={kind:c,interfaces:[Au]},Uu.prototype.offset_tq0o01$=function(t){return new Hu(t)},Uu.prototype.zoom_za3lpa$=function(t){return this.zoom_t0n4v2$((e=t,function(){return e}));var e},Uu.prototype.scale_tq0o01$=function(t){return this.scale_d4mmvr$((e=t,function(){return e}));var e},Uu.prototype.transformBBox_kr9gox$=function(t,e){return pn(this.transformRing_0(A("rectToPolygon",function(t,e){return t.rectToPolygon_0(e)}.bind(null,this))(t),e,this.SAMPLING_EPSILON_0))},Uu.prototype.transformMultiPolygon_c0yqik$=function(t,e){var n,i=rt(t.size);for(n=t.iterator();n.hasNext();){var r=n.next();i.add_11rb$(this.transformPolygon_0(r,e,this.SAMPLING_EPSILON_0))}return new ht(i)},Uu.prototype.transformPolygon_0=function(t,e,n){var i,r=rt(t.size);for(i=t.iterator();i.hasNext();){var o=i.next();r.add_11rb$(new ut(this.transformRing_0(o,e,n)))}return new pt(r)},Uu.prototype.transformRing_0=function(t,e,n){return new Kl(e,n).resample_ohchv7$(t)},Uu.prototype.transform_c0yqik$=function(t,e){var n,i=rt(t.size);for(n=t.iterator();n.hasNext();){var r=n.next();i.add_11rb$(this.transform_0(r,e,this.SAMPLING_EPSILON_0))}return new ht(i)},Uu.prototype.transform_0=function(t,e,n){var i,r=rt(t.size);for(i=t.iterator();i.hasNext();){var o=i.next();r.add_11rb$(new ut(this.transform_1(o,e,n)))}return new pt(r)},Uu.prototype.transform_1=function(t,e,n){var i,r=rt(t.size);for(i=t.iterator();i.hasNext();){var o=i.next();r.add_11rb$(e(o))}return r},Uu.prototype.safePoint_y7b45i$=function(t,e){if(hn(t)||hn(e))throw S(("Value for DoubleVector isNaN x = "+t+" and y = "+e).toString());return H(t,e)},Uu.$metadata$={kind:b,simpleName:"ProjectionUtil",interfaces:[]};var Yu,Vu,Ku,Wu,Xu,Zu,Ju=null;function Qu(){return null===Ju&&new Uu,Ju}function tc(){this.horizontal=ic(),this.vertical=lc()}function ec(t,e){me.call(this),this.name$=t,this.ordinal$=e}function nc(){nc=function(){},Yu=new ec("RIGHT",0),Vu=new ec("CENTER",1),Ku=new ec("LEFT",2)}function ic(){return nc(),Yu}function rc(){return nc(),Vu}function oc(){return nc(),Ku}function ac(t,e){me.call(this),this.name$=t,this.ordinal$=e}function sc(){sc=function(){},Wu=new ac("TOP",0),Xu=new ac("CENTER",1),Zu=new ac("BOTTOM",2)}function lc(){return sc(),Wu}function uc(){return sc(),Xu}function cc(){return sc(),Zu}function pc(t){this.myContext2d_0=t}function hc(){this.scale=0,this.position=E.Companion.ZERO}function _c(t,e){this.myCanvas_0=t,this.name=e,this.myRect_0=q(0,0,this.myCanvas_0.size.x,this.myCanvas_0.size.y),this.myRenderTaskList_0=w()}function fc(){}function dc(t){this.myGroupedLayers_0=t}function mc(t){this.canvasLayer=t}function yc(t){kc(),this.layerId=t}function $c(){xc=this}ec.$metadata$={kind:c,simpleName:"HorizontalAlignment",interfaces:[me]},ec.values=function(){return[ic(),rc(),oc()]},ec.valueOf_61zpoe$=function(t){switch(t){case"RIGHT":return ic();case"CENTER":return rc();case"LEFT":return oc();default:ye("No enum constant jetbrains.livemap.core.rendering.Alignment.HorizontalAlignment."+t)}},ac.$metadata$={kind:c,simpleName:"VerticalAlignment",interfaces:[me]},ac.values=function(){return[lc(),uc(),cc()]},ac.valueOf_61zpoe$=function(t){switch(t){case"TOP":return lc();case"CENTER":return uc();case"BOTTOM":return cc();default:ye("No enum constant jetbrains.livemap.core.rendering.Alignment.VerticalAlignment."+t)}},tc.prototype.calculatePosition_qt8ska$=function(t,n){var i,r;switch(this.horizontal.name){case"LEFT":i=-n.x;break;case"CENTER":i=-n.x/2;break;case"RIGHT":i=0;break;default:i=e.noWhenBranchMatched()}var o=i;switch(this.vertical.name){case"TOP":r=0;break;case"CENTER":r=-n.y/2;break;case"BOTTOM":r=-n.y;break;default:r=e.noWhenBranchMatched()}return sp(t,new E(o,r))},tc.$metadata$={kind:c,simpleName:"Alignment",interfaces:[]},pc.prototype.measure_2qe7uk$=function(t,e){this.myContext2d_0.save(),this.myContext2d_0.setFont_ov8mpe$(e);var n=this.myContext2d_0.measureText_61zpoe$(t);return this.myContext2d_0.restore(),new E(n,e.fontSize)},pc.$metadata$={kind:c,simpleName:"TextMeasurer",interfaces:[]},hc.$metadata$={kind:c,simpleName:"TransformComponent",interfaces:[Ys]},Object.defineProperty(_c.prototype,"size",{configurable:!0,get:function(){return this.myCanvas_0.size}}),_c.prototype.addRenderTask_ddf932$=function(t){this.myRenderTaskList_0.add_11rb$(t)},_c.prototype.render=function(){var t,e=this.myCanvas_0.context2d;for(t=this.myRenderTaskList_0.iterator();t.hasNext();)t.next()(e);this.myRenderTaskList_0.clear()},_c.prototype.takeSnapshot=function(){return this.myCanvas_0.takeSnapshot()},_c.prototype.clear=function(){this.myCanvas_0.context2d.clearRect_wthzt5$(this.myRect_0)},_c.prototype.removeFrom_49gm0j$=function(t){t.removeChild_eqkm0m$(this.myCanvas_0)},_c.$metadata$={kind:c,simpleName:"CanvasLayer",interfaces:[]},fc.$metadata$={kind:c,simpleName:"DirtyCanvasLayerComponent",interfaces:[Ys]},Object.defineProperty(dc.prototype,"canvasLayers",{configurable:!0,get:function(){return this.myGroupedLayers_0.orderedLayers}}),dc.$metadata$={kind:c,simpleName:"LayersOrderComponent",interfaces:[Ys]},mc.$metadata$={kind:c,simpleName:"CanvasLayerComponent",interfaces:[Ys]},$c.prototype.tagDirtyParentLayer_ahlfl2$=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(yc)))||e.isType(n,yc)?n:C()))throw S("Component "+p(yc).simpleName+" is not found");var r,o=i,a=t.componentManager.getEntityById_za3lpa$(o.layerId);if(a.contains_9u06oy$(p(fc))){if(null==(null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(fc)))||e.isType(r,fc)?r:C()))throw S("Component "+p(fc).simpleName+" is not found")}else a.add_57nep2$(new fc)},$c.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var vc,gc,bc,wc,xc=null;function kc(){return null===xc&&new $c,xc}function Ec(){this.myGroupedLayers_0=st(),this.orderedLayers=at()}function Cc(t,e){me.call(this),this.name$=t,this.ordinal$=e}function Sc(){Sc=function(){},vc=new Cc("BACKGROUND",0),gc=new Cc("FEATURES",1),bc=new Cc("FOREGROUND",2),wc=new Cc("UI",3)}function Tc(){return Sc(),vc}function Oc(){return Sc(),gc}function Nc(){return Sc(),bc}function Pc(){return Sc(),wc}function Ac(){return[Tc(),Oc(),Nc(),Pc()]}function jc(){}function Lc(){Gc=this}function Rc(t,e,n){this.closure$componentManager=t,this.closure$singleCanvasControl=e,this.closure$rect=n,this.myGroupedLayers_0=new Ec}function Ic(t,e){this.closure$singleCanvasControl=t,this.closure$rect=e}function zc(t,e,n){this.closure$componentManager=t,this.closure$singleCanvasControl=e,this.closure$rect=n,this.myGroupedLayers_0=new Ec}function Dc(t,e){this.closure$singleCanvasControl=t,this.closure$rect=e}function Mc(t,e){this.closure$componentManager=t,this.closure$canvasControl=e,this.myGroupedLayers_0=new Ec}function Bc(){}yc.$metadata$={kind:c,simpleName:"ParentLayerComponent",interfaces:[Ys]},Ec.prototype.add_vanbej$=function(t,e){var n,i=this.myGroupedLayers_0,r=i.get_11rb$(t);if(null==r){var o=w();i.put_xwzc9p$(t,o),n=o}else n=r;n.add_11rb$(e);var a,s=Ac(),l=w();for(a=0;a!==s.length;++a){var u,c=s[a],p=null!=(u=this.myGroupedLayers_0.get_11rb$(c))?u:at();xt(l,p)}this.orderedLayers=l},Ec.prototype.remove_vanbej$=function(t,e){var n;null!=(n=this.myGroupedLayers_0.get_11rb$(t))&&n.remove_11rb$(e)},Ec.$metadata$={kind:c,simpleName:"GroupedLayers",interfaces:[]},Cc.$metadata$={kind:c,simpleName:"LayerGroup",interfaces:[me]},Cc.values=Ac,Cc.valueOf_61zpoe$=function(t){switch(t){case"BACKGROUND":return Tc();case"FEATURES":return Oc();case"FOREGROUND":return Nc();case"UI":return Pc();default:ye("No enum constant jetbrains.livemap.core.rendering.layers.LayerGroup."+t)}},jc.$metadata$={kind:v,simpleName:"LayerManager",interfaces:[]},Lc.prototype.createLayerManager_ju5hjs$=function(t,n,i){var r;switch(n.name){case"SINGLE_SCREEN_CANVAS":r=this.singleScreenCanvas_0(i,t);break;case"OWN_OFFSCREEN_CANVAS":r=this.offscreenLayers_0(i,t);break;case"OWN_SCREEN_CANVAS":r=this.screenLayers_0(i,t);break;default:r=e.noWhenBranchMatched()}return r},Ic.prototype.render_wuw0ll$=function(t,n,i){var r,o;for(this.closure$singleCanvasControl.context.clearRect_wthzt5$(this.closure$rect),r=t.iterator();r.hasNext();)r.next().render();for(o=n.iterator();o.hasNext();){var a,s=o.next();if(s.contains_9u06oy$(p(fc))){if(null==(null==(a=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(fc)))||e.isType(a,fc)?a:C()))throw S("Component "+p(fc).simpleName+" is not found")}else s.add_57nep2$(new fc)}},Ic.$metadata$={kind:c,interfaces:[Vc]},Rc.prototype.createLayerRenderingSystem=function(){return new Yc(this.closure$componentManager,new Ic(this.closure$singleCanvasControl,this.closure$rect))},Rc.prototype.addLayer_kqh14j$=function(t,e){var n=new _c(this.closure$singleCanvasControl.canvas,t);return this.myGroupedLayers_0.add_vanbej$(e,n),new mc(n)},Rc.prototype.removeLayer_vanbej$=function(t,e){this.myGroupedLayers_0.remove_vanbej$(t,e)},Rc.prototype.createLayersOrderComponent=function(){return new dc(this.myGroupedLayers_0)},Rc.$metadata$={kind:c,interfaces:[jc]},Lc.prototype.singleScreenCanvas_0=function(t,e){return new Rc(e,new re(t),new He(E.Companion.ZERO,t.size.toDoubleVector()))},Dc.prototype.render_wuw0ll$=function(t,n,i){if(!i.isEmpty()){var r;for(r=i.iterator();r.hasNext();){var o,a,s=r.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(mc)))||e.isType(o,mc)?o:C()))throw S("Component "+p(mc).simpleName+" is not found");var l=a.canvasLayer;l.clear(),l.render(),s.removeComponent_9u06oy$(p(fc))}var u,c=J.PlatformAsyncs,h=rt(it(t,10));for(u=t.iterator();u.hasNext();){var _=u.next();h.add_11rb$(_.takeSnapshot())}c.composite_a4rjr8$(h).onSuccess_qlkmfe$((f=this.closure$singleCanvasControl,d=this.closure$rect,function(t){var e;for(f.context.clearRect_wthzt5$(d),e=t.iterator();e.hasNext();){var n=e.next();f.context.drawImage_xo47pw$(n,0,0)}return N}))}var f,d},Dc.$metadata$={kind:c,interfaces:[Vc]},zc.prototype.createLayerRenderingSystem=function(){return new Yc(this.closure$componentManager,new Dc(this.closure$singleCanvasControl,this.closure$rect))},zc.prototype.addLayer_kqh14j$=function(t,e){var n=new _c(this.closure$singleCanvasControl.createCanvas(),t);return this.myGroupedLayers_0.add_vanbej$(e,n),new mc(n)},zc.prototype.removeLayer_vanbej$=function(t,e){this.myGroupedLayers_0.remove_vanbej$(t,e)},zc.prototype.createLayersOrderComponent=function(){return new dc(this.myGroupedLayers_0)},zc.$metadata$={kind:c,interfaces:[jc]},Lc.prototype.offscreenLayers_0=function(t,e){return new zc(e,new re(t),new He(E.Companion.ZERO,t.size.toDoubleVector()))},Bc.prototype.render_wuw0ll$=function(t,n,i){var r;for(r=i.iterator();r.hasNext();){var o,a,s=r.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(mc)))||e.isType(o,mc)?o:C()))throw S("Component "+p(mc).simpleName+" is not found");var l=a.canvasLayer;l.clear(),l.render(),s.removeComponent_9u06oy$(p(fc))}},Bc.$metadata$={kind:c,interfaces:[Vc]},Mc.prototype.createLayerRenderingSystem=function(){return new Yc(this.closure$componentManager,new Bc)},Mc.prototype.addLayer_kqh14j$=function(t,e){var n=this.closure$canvasControl.createCanvas_119tl4$(this.closure$canvasControl.size),i=new _c(n,t);return this.myGroupedLayers_0.add_vanbej$(e,i),this.closure$canvasControl.addChild_fwfip8$(this.myGroupedLayers_0.orderedLayers.indexOf_11rb$(i),n),new mc(i)},Mc.prototype.removeLayer_vanbej$=function(t,e){e.removeFrom_49gm0j$(this.closure$canvasControl),this.myGroupedLayers_0.remove_vanbej$(t,e)},Mc.prototype.createLayersOrderComponent=function(){return new dc(this.myGroupedLayers_0)},Mc.$metadata$={kind:c,interfaces:[jc]},Lc.prototype.screenLayers_0=function(t,e){return new Mc(e,t)},Lc.$metadata$={kind:b,simpleName:"LayerManagers",interfaces:[]};var Uc,Fc,qc,Gc=null;function Hc(){return null===Gc&&new Lc,Gc}function Yc(t,e){Bs.call(this,t),this.myRenderingStrategy_0=e,this.myDirtyLayers_0=w()}function Vc(){}function Kc(t,e){me.call(this),this.name$=t,this.ordinal$=e}function Wc(){Wc=function(){},Uc=new Kc("SINGLE_SCREEN_CANVAS",0),Fc=new Kc("OWN_OFFSCREEN_CANVAS",1),qc=new Kc("OWN_SCREEN_CANVAS",2)}function Xc(){return Wc(),Uc}function Zc(){return Wc(),Fc}function Jc(){return Wc(),qc}function Qc(){this.origin_eatjrl$_0=E.Companion.ZERO,this.dimension_n63b3r$_0=E.Companion.ZERO,this.center_0=E.Companion.ZERO,this.strokeColor=null,this.strokeWidth=null,this.angle=wt.PI/2,this.startAngle=0}function tp(t,e){this.origin_rgqk5e$_0=t,this.texts_0=e,this.dimension_z2jy5m$_0=E.Companion.ZERO,this.rectangle_0=new up,this.alignment_0=new tc,this.padding=0,this.background=k.Companion.TRANSPARENT}function ep(){this.origin_ccvchv$_0=E.Companion.ZERO,this.dimension_mpx8hh$_0=E.Companion.ZERO,this.center_0=E.Companion.ZERO,this.strokeColor=null,this.strokeWidth=null,this.fillColor=null}function np(t,e){op(),this.position_0=t,this.renderBoxes_0=e}function ip(){rp=this}Object.defineProperty(Yc.prototype,"dirtyLayers",{configurable:!0,get:function(){return this.myDirtyLayers_0}}),Yc.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o=this.componentManager.getSingletonEntity_9u06oy$(p(dc));if(null==(r=null==(i=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(dc)))||e.isType(i,dc)?i:C()))throw S("Component "+p(dc).simpleName+" is not found");var a,s=r.canvasLayers,l=Ft(this.getEntities_9u06oy$(p(mc))),u=Ft(this.getEntities_9u06oy$(p(fc)));for(this.myDirtyLayers_0.clear(),a=u.iterator();a.hasNext();){var c=a.next();this.myDirtyLayers_0.add_11rb$(c.id_8be2vx$)}this.myRenderingStrategy_0.render_wuw0ll$(s,l,u)},Vc.$metadata$={kind:v,simpleName:"RenderingStrategy",interfaces:[]},Yc.$metadata$={kind:c,simpleName:"LayersRenderingSystem",interfaces:[Bs]},Kc.$metadata$={kind:c,simpleName:"RenderTarget",interfaces:[me]},Kc.values=function(){return[Xc(),Zc(),Jc()]},Kc.valueOf_61zpoe$=function(t){switch(t){case"SINGLE_SCREEN_CANVAS":return Xc();case"OWN_OFFSCREEN_CANVAS":return Zc();case"OWN_SCREEN_CANVAS":return Jc();default:ye("No enum constant jetbrains.livemap.core.rendering.layers.RenderTarget."+t)}},Object.defineProperty(Qc.prototype,"origin",{configurable:!0,get:function(){return this.origin_eatjrl$_0},set:function(t){this.origin_eatjrl$_0=t,this.update_0()}}),Object.defineProperty(Qc.prototype,"dimension",{configurable:!0,get:function(){return this.dimension_n63b3r$_0},set:function(t){this.dimension_n63b3r$_0=t,this.update_0()}}),Qc.prototype.update_0=function(){this.center_0=this.dimension.mul_14dthe$(.5)},Qc.prototype.render_pzzegf$=function(t){var e,n;t.beginPath(),t.arc_6p3vsx$(this.center_0.x,this.center_0.y,this.dimension.x/2,this.startAngle,this.startAngle+this.angle),null!=(e=this.strokeWidth)&&t.setLineWidth_14dthe$(e),null!=(n=this.strokeColor)&&t.setStrokeStyle_2160e9$(n),t.stroke()},Qc.$metadata$={kind:c,simpleName:"Arc",interfaces:[cp]},Object.defineProperty(tp.prototype,"origin",{get:function(){return this.origin_rgqk5e$_0},set:function(t){this.origin_rgqk5e$_0=t}}),Object.defineProperty(tp.prototype,"dimension",{configurable:!0,get:function(){return this.dimension_z2jy5m$_0},set:function(t){this.dimension_z2jy5m$_0=t}}),Object.defineProperty(tp.prototype,"horizontalAlignment",{configurable:!0,get:function(){return this.alignment_0.horizontal},set:function(t){this.alignment_0.horizontal=t}}),Object.defineProperty(tp.prototype,"verticalAlignment",{configurable:!0,get:function(){return this.alignment_0.vertical},set:function(t){this.alignment_0.vertical=t}}),tp.prototype.render_pzzegf$=function(t){if(this.isDirty_0()){var e;for(e=this.texts_0.iterator();e.hasNext();){var n=e.next(),i=n.isDirty?n.measureText_pzzegf$(t):n.dimension;n.origin=new E(this.dimension.x+this.padding,this.padding);var r=this.dimension.x+i.x,o=this.dimension.y,a=i.y;this.dimension=new E(r,Z.max(o,a))}this.dimension=this.dimension.add_gpjtzr$(new E(2*this.padding,2*this.padding)),this.origin=this.alignment_0.calculatePosition_qt8ska$(this.origin,this.dimension);var s,l=this.rectangle_0;for(l.rect=new He(this.origin,this.dimension),l.color=this.background,s=this.texts_0.iterator();s.hasNext();){var u=s.next();u.origin=sp(u.origin,this.origin)}}var c;for(t.setTransform_15yvbs$(1,0,0,1,0,0),this.rectangle_0.render_pzzegf$(t),c=this.texts_0.iterator();c.hasNext();){var p=c.next();this.renderPrimitive_0(t,p)}},tp.prototype.renderPrimitive_0=function(t,e){t.save();var n=e.origin;t.setTransform_15yvbs$(1,0,0,1,n.x,n.y),e.render_pzzegf$(t),t.restore()},tp.prototype.isDirty_0=function(){var t,n=this.texts_0;t:do{var i;if(e.isType(n,dn)&&n.isEmpty()){t=!1;break t}for(i=n.iterator();i.hasNext();)if(i.next().isDirty){t=!0;break t}t=!1}while(0);return t},tp.$metadata$={kind:c,simpleName:"Attribution",interfaces:[cp]},Object.defineProperty(ep.prototype,"origin",{configurable:!0,get:function(){return this.origin_ccvchv$_0},set:function(t){this.origin_ccvchv$_0=t,this.update_0()}}),Object.defineProperty(ep.prototype,"dimension",{configurable:!0,get:function(){return this.dimension_mpx8hh$_0},set:function(t){this.dimension_mpx8hh$_0=t,this.update_0()}}),ep.prototype.update_0=function(){this.center_0=this.dimension.mul_14dthe$(.5)},ep.prototype.render_pzzegf$=function(t){var e,n,i;t.beginPath(),t.arc_6p3vsx$(this.center_0.x,this.center_0.y,this.dimension.x/2,0,2*wt.PI),null!=(e=this.fillColor)&&t.setFillStyle_2160e9$(e),t.fill(),null!=(n=this.strokeWidth)&&t.setLineWidth_14dthe$(n),null!=(i=this.strokeColor)&&t.setStrokeStyle_2160e9$(i),t.stroke()},ep.$metadata$={kind:c,simpleName:"Circle",interfaces:[cp]},Object.defineProperty(np.prototype,"origin",{configurable:!0,get:function(){return this.position_0}}),Object.defineProperty(np.prototype,"dimension",{configurable:!0,get:function(){return this.calculateDimension_0()}}),np.prototype.render_pzzegf$=function(t){var e;for(e=this.renderBoxes_0.iterator();e.hasNext();){var n=e.next();t.save();var i=n.origin;t.translate_lu1900$(i.x,i.y),n.render_pzzegf$(t),t.restore()}},np.prototype.calculateDimension_0=function(){var t,e=this.getRight_0(this.renderBoxes_0.get_za3lpa$(0)),n=this.getBottom_0(this.renderBoxes_0.get_za3lpa$(0));for(t=this.renderBoxes_0.iterator();t.hasNext();){var i=t.next(),r=e,o=this.getRight_0(i);e=Z.max(r,o);var a=n,s=this.getBottom_0(i);n=Z.max(a,s)}return new E(e,n)},np.prototype.getRight_0=function(t){return t.origin.x+this.renderBoxes_0.get_za3lpa$(0).dimension.x},np.prototype.getBottom_0=function(t){return t.origin.y+this.renderBoxes_0.get_za3lpa$(0).dimension.y},ip.prototype.create_x8r7ta$=function(t,e){return new np(t,mn(e))},ip.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var rp=null;function op(){return null===rp&&new ip,rp}function ap(t,e){this.origin_71rgz7$_0=t,this.text_0=e,this.frame_0=null,this.dimension_4cjgkr$_0=E.Companion.ZERO,this.rectangle_0=new up,this.alignment_0=new tc,this.padding=0,this.background=k.Companion.TRANSPARENT}function sp(t,e){return t.add_gpjtzr$(e)}function lp(t,e){this.origin_lg7k8u$_0=t,this.dimension_6s7c2u$_0=e,this.snapshot=null}function up(){this.rect=q(0,0,0,0),this.color=null}function cp(){}function pp(){}function hp(){this.origin_7b8a1y$_0=E.Companion.ZERO,this.dimension_bbzer6$_0=E.Companion.ZERO,this.text_tsqtfx$_0=at(),this.color=k.Companion.WHITE,this.isDirty_nrslik$_0=!0,this.fontSize=10,this.fontFamily="serif"}function _p(){gp=this}function fp(t){yp(),Bs.call(this,t)}function dp(){mp=this,this.COMPONENT_TYPES_0=x([p($p),p(Ch),p(yc)])}np.$metadata$={kind:c,simpleName:"Frame",interfaces:[cp]},Object.defineProperty(ap.prototype,"origin",{get:function(){return this.origin_71rgz7$_0},set:function(t){this.origin_71rgz7$_0=t}}),Object.defineProperty(ap.prototype,"dimension",{configurable:!0,get:function(){return this.dimension_4cjgkr$_0},set:function(t){this.dimension_4cjgkr$_0=t}}),Object.defineProperty(ap.prototype,"horizontalAlignment",{configurable:!0,get:function(){return this.alignment_0.horizontal},set:function(t){this.alignment_0.horizontal=t}}),Object.defineProperty(ap.prototype,"verticalAlignment",{configurable:!0,get:function(){return this.alignment_0.vertical},set:function(t){this.alignment_0.vertical=t}}),ap.prototype.render_pzzegf$=function(t){var e;if(this.text_0.isDirty){this.dimension=sp(this.text_0.measureText_pzzegf$(t),new E(2*this.padding,2*this.padding));var n=this.rectangle_0;n.rect=new He(E.Companion.ZERO,this.dimension),n.color=this.background,this.origin=this.alignment_0.calculatePosition_qt8ska$(this.origin,this.dimension),this.text_0.origin=new E(this.padding,this.padding),this.frame_0=op().create_x8r7ta$(this.origin,[this.rectangle_0,this.text_0])}null!=(e=this.frame_0)&&e.render_pzzegf$(t)},ap.$metadata$={kind:c,simpleName:"Label",interfaces:[cp]},Object.defineProperty(lp.prototype,"origin",{get:function(){return this.origin_lg7k8u$_0}}),Object.defineProperty(lp.prototype,"dimension",{get:function(){return this.dimension_6s7c2u$_0}}),lp.prototype.render_pzzegf$=function(t){var e;null!=(e=this.snapshot)&&t.drawImage_nks7bk$(e,0,0,this.dimension.x,this.dimension.y)},lp.$metadata$={kind:c,simpleName:"MutableImage",interfaces:[cp]},Object.defineProperty(up.prototype,"origin",{configurable:!0,get:function(){return this.rect.origin}}),Object.defineProperty(up.prototype,"dimension",{configurable:!0,get:function(){return this.rect.dimension}}),up.prototype.render_pzzegf$=function(t){var e;null!=(e=this.color)&&t.setFillStyle_2160e9$(e),t.fillRect_6y0v78$(this.rect.left,this.rect.top,this.rect.width,this.rect.height)},up.$metadata$={kind:c,simpleName:"Rectangle",interfaces:[cp]},cp.$metadata$={kind:v,simpleName:"RenderBox",interfaces:[pp]},pp.$metadata$={kind:v,simpleName:"RenderObject",interfaces:[]},Object.defineProperty(hp.prototype,"origin",{configurable:!0,get:function(){return this.origin_7b8a1y$_0},set:function(t){this.origin_7b8a1y$_0=t}}),Object.defineProperty(hp.prototype,"dimension",{configurable:!0,get:function(){return this.dimension_bbzer6$_0},set:function(t){this.dimension_bbzer6$_0=t}}),Object.defineProperty(hp.prototype,"text",{configurable:!0,get:function(){return this.text_tsqtfx$_0},set:function(t){this.text_tsqtfx$_0=t,this.isDirty=!0}}),Object.defineProperty(hp.prototype,"isDirty",{configurable:!0,get:function(){return this.isDirty_nrslik$_0},set:function(t){this.isDirty_nrslik$_0=t}}),hp.prototype.render_pzzegf$=function(t){var e;t.setFont_ov8mpe$(new le(void 0,void 0,this.fontSize,this.fontFamily)),t.setTextBaseline_5cz80h$(ae.BOTTOM),this.isDirty&&(this.dimension=this.calculateDimension_0(t),this.isDirty=!1),t.setFillStyle_2160e9$(this.color);var n=this.fontSize;for(e=this.text.iterator();e.hasNext();){var i=e.next();t.fillText_ai6r6m$(i,0,n),n+=this.fontSize}},hp.prototype.measureText_pzzegf$=function(t){return this.isDirty&&(t.save(),t.setFont_ov8mpe$(new le(void 0,void 0,this.fontSize,this.fontFamily)),t.setTextBaseline_5cz80h$(ae.BOTTOM),this.dimension=this.calculateDimension_0(t),this.isDirty=!1,t.restore()),this.dimension},hp.prototype.calculateDimension_0=function(t){var e,n=0;for(e=this.text.iterator();e.hasNext();){var i=e.next(),r=n,o=t.measureText_61zpoe$(i);n=Z.max(r,o)}return new E(n,this.text.size*this.fontSize)},hp.$metadata$={kind:c,simpleName:"Text",interfaces:[cp]},_p.prototype.length_0=function(t,e){var n=e.x-t.x,i=e.y-t.y,r=n*n+i*i;return Z.sqrt(r)},fp.prototype.updateImpl_og8vrq$=function(t,n){var i,r;for(i=this.getEntities_38uplf$(yp().COMPONENT_TYPES_0).iterator();i.hasNext();){var o,a,s=i.next(),l=gt.GeometryUtil;if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(Ch)))||e.isType(o,Ch)?o:C()))throw S("Component "+p(Ch).simpleName+" is not found");var u,c,h=l.asLineString_8ft4gs$(a.geometry);if(null==(c=null==(u=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p($p)))||e.isType(u,$p)?u:C()))throw S("Component "+p($p).simpleName+" is not found");var _=c;if(_.lengthIndex.isEmpty()&&this.init_0(_,h),null==(r=this.getEntityById_za3lpa$(_.animationId)))return;var f,d,m=r;if(null==(d=null==(f=m.componentManager.getComponents_ahlfl2$(m).get_11rb$(p(Us)))||e.isType(f,Us)?f:C()))throw S("Component "+p(Us).simpleName+" is not found");this.calculateEffectState_0(_,h,d.progress),kc().tagDirtyParentLayer_ahlfl2$(s)}},fp.prototype.init_0=function(t,e){var n,i={v:0},r=rt(e.size);r.add_11rb$(0),n=e.size;for(var o=1;o=0)return t.endIndex=o,void(t.interpolatedPoint=null);if((o=~o-1|0)==(i.size-1|0))return t.endIndex=o,void(t.interpolatedPoint=null);var a=i.get_za3lpa$(o),s=i.get_za3lpa$(o+1|0)-a;if(s>2){var l=(n-a/r)/(s/r),u=e.get_za3lpa$(o),c=e.get_za3lpa$(o+1|0);t.endIndex=o,t.interpolatedPoint=H(u.x+(c.x-u.x)*l,u.y+(c.y-u.y)*l)}else t.endIndex=o,t.interpolatedPoint=null},dp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var mp=null;function yp(){return null===mp&&new dp,mp}function $p(){this.animationId=0,this.lengthIndex=at(),this.length=0,this.endIndex=0,this.interpolatedPoint=null}function vp(){}fp.$metadata$={kind:c,simpleName:"GrowingPathEffectSystem",interfaces:[Bs]},$p.$metadata$={kind:c,simpleName:"GrowingPathEffectComponent",interfaces:[Ys]},vp.prototype.render_j83es7$=function(t,n){var i,r,o;if(t.contains_9u06oy$(p(Ch))){var a,s;if(null==(s=null==(a=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(a,hf)?a:C()))throw S("Component "+p(hf).simpleName+" is not found");var l,u,c=s;if(null==(u=null==(l=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Ch)))||e.isType(l,Ch)?l:C()))throw S("Component "+p(Ch).simpleName+" is not found");var h,_,f=u.geometry;if(null==(_=null==(h=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p($p)))||e.isType(h,$p)?h:C()))throw S("Component "+p($p).simpleName+" is not found");var d=_;for(n.setStrokeStyle_2160e9$(c.strokeColor),n.setLineWidth_14dthe$(c.strokeWidth),n.beginPath(),i=f.iterator();i.hasNext();){var m=i.next().get_za3lpa$(0),y=m.get_za3lpa$(0);n.moveTo_lu1900$(y.x,y.y),r=d.endIndex;for(var $=1;$<=r;$++)y=m.get_za3lpa$($),n.lineTo_lu1900$(y.x,y.y);null!=(o=d.interpolatedPoint)&&n.lineTo_lu1900$(o.x,o.y)}n.stroke()}},vp.$metadata$={kind:c,simpleName:"GrowingPathRenderer",interfaces:[Sf]},_p.$metadata$={kind:b,simpleName:"GrowingPath",interfaces:[]};var gp=null;function bp(){return null===gp&&new _p,gp}function wp(t){Cp(),Bs.call(this,t),this.myMapProjection_1mw1qp$_0=this.myMapProjection_1mw1qp$_0}function xp(t,e){return function(n){return e.get_worldPointInitializer_0(t)(n,e.myMapProjection_0.project_11rb$(e.get_point_0(t))),N}}function kp(){Ep=this,this.NEED_APPLY=x([p(Qp),p(oh)])}Object.defineProperty(wp.prototype,"myMapProjection_0",{configurable:!0,get:function(){return null==this.myMapProjection_1mw1qp$_0?T("myMapProjection"):this.myMapProjection_1mw1qp$_0},set:function(t){this.myMapProjection_1mw1qp$_0=t}}),wp.prototype.initImpl_4pvjek$=function(t){this.myMapProjection_0=t.mapProjection},wp.prototype.updateImpl_og8vrq$=function(t,e){var n;for(n=this.getMutableEntities_38uplf$(Cp().NEED_APPLY).iterator();n.hasNext();){var i=n.next();Qs(i,xp(i,this)),kc().tagDirtyParentLayer_ahlfl2$(i),i.removeComponent_9u06oy$(p(Qp)),i.removeComponent_9u06oy$(p(oh))}},wp.prototype.get_point_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Qp)))||e.isType(n,Qp)?n:C()))throw S("Component "+p(Qp).simpleName+" is not found");return i.point},wp.prototype.get_worldPointInitializer_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(oh)))||e.isType(n,oh)?n:C()))throw S("Component "+p(oh).simpleName+" is not found");return i.worldPointInitializer},kp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ep=null;function Cp(){return null===Ep&&new kp,Ep}function Sp(t,e){Pp(),Bs.call(this,t),this.myGeocodingService_0=e}function Tp(t){var e,n=d("request",1,(function(t){return t.request})),i=wn(bn(it(t,10)),16),r=xn(i);for(e=t.iterator();e.hasNext();){var o=e.next();r.put_xwzc9p$(n(o),o)}return r}function Op(){Np=this,this.NEED_BBOX=x([p(zp),p(th)]),this.WAIT_BBOX=x([p(zp),p(eh),p(A_)])}wp.$metadata$={kind:c,simpleName:"ApplyPointSystem",interfaces:[Bs]},Sp.prototype.updateImpl_og8vrq$=function(t,n){var i=this.getMutableEntities_38uplf$(Pp().NEED_BBOX);if(!i.isEmpty()){var r,o=rt(it(i,10));for(r=i.iterator();r.hasNext();){var a,s,l=r.next(),u=o.add_11rb$;if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(zp)))||e.isType(a,zp)?a:C()))throw S("Component "+p(zp).simpleName+" is not found");u.call(o,s.regionId)}var c,h=$n(o),_=(new vn).setIds_mhpeer$(h).setFeatures_kzd2fe$(ct(gn.LIMIT)).build();for(A("execute",function(t,e){return t.execute_2yxzh4$(e)}.bind(null,this.myGeocodingService_0))(_).map_2o04qz$(Tp).map_2o04qz$(A("parseBBoxMap",function(t,e){return t.parseBBoxMap_0(e),N}.bind(null,this))),c=i.iterator();c.hasNext();){var f=c.next();f.add_57nep2$(ih()),f.removeComponent_9u06oy$(p(th))}}},Sp.prototype.parseBBoxMap_0=function(t){var n;for(n=this.getMutableEntities_38uplf$(Pp().WAIT_BBOX).iterator();n.hasNext();){var i,r,o,a,s=n.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(zp)))||e.isType(o,zp)?o:C()))throw S("Component "+p(zp).simpleName+" is not found");null!=(r=null!=(i=t.get_11rb$(a.regionId))?i.limit:null)&&(s.add_57nep2$(new rh(r)),s.removeComponent_9u06oy$(p(eh)))}},Op.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Np=null;function Pp(){return null===Np&&new Op,Np}function Ap(t,e){Ip(),Bs.call(this,t),this.myGeocodingService_0=e,this.myProject_4p7cfa$_0=this.myProject_4p7cfa$_0}function jp(t){var e,n=d("request",1,(function(t){return t.request})),i=wn(bn(it(t,10)),16),r=xn(i);for(e=t.iterator();e.hasNext();){var o=e.next();r.put_xwzc9p$(n(o),o)}return r}function Lp(){Rp=this,this.NEED_CENTROID=x([p(Dp),p(zp)]),this.WAIT_CENTROID=x([p(Mp),p(zp)])}Sp.$metadata$={kind:c,simpleName:"BBoxGeocodingSystem",interfaces:[Bs]},Object.defineProperty(Ap.prototype,"myProject_0",{configurable:!0,get:function(){return null==this.myProject_4p7cfa$_0?T("myProject"):this.myProject_4p7cfa$_0},set:function(t){this.myProject_4p7cfa$_0=t}}),Ap.prototype.initImpl_4pvjek$=function(t){this.myProject_0=A("project",function(t,e){return t.project_11rb$(e)}.bind(null,t.mapProjection))},Ap.prototype.updateImpl_og8vrq$=function(t,n){var i=this.getMutableEntities_38uplf$(Ip().NEED_CENTROID);if(!i.isEmpty()){var r,o=rt(it(i,10));for(r=i.iterator();r.hasNext();){var a,s,l=r.next(),u=o.add_11rb$;if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(zp)))||e.isType(a,zp)?a:C()))throw S("Component "+p(zp).simpleName+" is not found");u.call(o,s.regionId)}var c,h=$n(o),_=(new vn).setIds_mhpeer$(h).setFeatures_kzd2fe$(ct(gn.CENTROID)).build();for(A("execute",function(t,e){return t.execute_2yxzh4$(e)}.bind(null,this.myGeocodingService_0))(_).map_2o04qz$(jp).map_2o04qz$(A("parseCentroidMap",function(t,e){return t.parseCentroidMap_0(e),N}.bind(null,this))),c=i.iterator();c.hasNext();){var f=c.next();f.add_57nep2$(Up()),f.removeComponent_9u06oy$(p(Dp))}}},Ap.prototype.parseCentroidMap_0=function(t){var n;for(n=this.getMutableEntities_38uplf$(Ip().WAIT_CENTROID).iterator();n.hasNext();){var i,r,o,a,s=n.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(zp)))||e.isType(o,zp)?o:C()))throw S("Component "+p(zp).simpleName+" is not found");null!=(r=null!=(i=t.get_11rb$(a.regionId))?i.centroid:null)&&(s.add_57nep2$(new Qp(kn(r))),s.removeComponent_9u06oy$(p(Mp)))}},Lp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Rp=null;function Ip(){return null===Rp&&new Lp,Rp}function zp(t){this.regionId=t}function Dp(){}function Mp(){Bp=this}Ap.$metadata$={kind:c,simpleName:"CentroidGeocodingSystem",interfaces:[Bs]},zp.$metadata$={kind:c,simpleName:"RegionIdComponent",interfaces:[Ys]},Dp.$metadata$={kind:b,simpleName:"NeedCentroidComponent",interfaces:[Ys]},Mp.$metadata$={kind:b,simpleName:"WaitCentroidComponent",interfaces:[Ys]};var Bp=null;function Up(){return null===Bp&&new Mp,Bp}function Fp(){qp=this}Fp.$metadata$={kind:b,simpleName:"NeedLocationComponent",interfaces:[Ys]};var qp=null;function Gp(){return null===qp&&new Fp,qp}function Hp(){}function Yp(){Vp=this}Hp.$metadata$={kind:b,simpleName:"NeedGeocodeLocationComponent",interfaces:[Ys]},Yp.$metadata$={kind:b,simpleName:"WaitGeocodeLocationComponent",interfaces:[Ys]};var Vp=null;function Kp(){return null===Vp&&new Yp,Vp}function Wp(){Xp=this}Wp.$metadata$={kind:b,simpleName:"NeedCalculateLocationComponent",interfaces:[Ys]};var Xp=null;function Zp(){return null===Xp&&new Wp,Xp}function Jp(){this.myWaitingCount_0=null,this.locations=w()}function Qp(t){this.point=t}function th(){}function eh(){nh=this}Jp.prototype.add_9badfu$=function(t){this.locations.add_11rb$(t)},Jp.prototype.wait_za3lpa$=function(t){var e,n;this.myWaitingCount_0=null!=(n=null!=(e=this.myWaitingCount_0)?e+t|0:null)?n:t},Jp.prototype.isReady=function(){return null!=this.myWaitingCount_0&&this.myWaitingCount_0===this.locations.size},Jp.$metadata$={kind:c,simpleName:"LocationComponent",interfaces:[Ys]},Qp.$metadata$={kind:c,simpleName:"LonLatComponent",interfaces:[Ys]},th.$metadata$={kind:b,simpleName:"NeedBboxComponent",interfaces:[Ys]},eh.$metadata$={kind:b,simpleName:"WaitBboxComponent",interfaces:[Ys]};var nh=null;function ih(){return null===nh&&new eh,nh}function rh(t){this.bbox=t}function oh(t){this.worldPointInitializer=t}function ah(t,e){uh(),Bs.call(this,e),this.mapRuler_0=t,this.myLocation_f4pf0e$_0=this.myLocation_f4pf0e$_0}function sh(){lh=this,this.READY_CALCULATE=ct(p(Wp))}rh.$metadata$={kind:c,simpleName:"RegionBBoxComponent",interfaces:[Ys]},oh.$metadata$={kind:c,simpleName:"PointInitializerComponent",interfaces:[Ys]},Object.defineProperty(ah.prototype,"myLocation_0",{configurable:!0,get:function(){return null==this.myLocation_f4pf0e$_0?T("myLocation"):this.myLocation_f4pf0e$_0},set:function(t){this.myLocation_f4pf0e$_0=t}}),ah.prototype.initImpl_4pvjek$=function(t){var n,i,r=this.componentManager.getSingletonEntity_9u06oy$(p(Jp));if(null==(i=null==(n=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(Jp)))||e.isType(n,Jp)?n:C()))throw S("Component "+p(Jp).simpleName+" is not found");this.myLocation_0=i},ah.prototype.updateImpl_og8vrq$=function(t,n){var i;for(i=this.getMutableEntities_38uplf$(uh().READY_CALCULATE).iterator();i.hasNext();){var r,o,a,s,l,u,c=i.next();if(c.contains_9u06oy$(p(Ah))){var h,_;if(null==(_=null==(h=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(Ah)))||e.isType(h,Ah)?h:C()))throw S("Component "+p(Ah).simpleName+" is not found");if(null==(o=null!=(r=_.geometry)?this.mapRuler_0.calculateBoundingBox_yqwbdx$(En(r)):null))throw S("Unexpected - no geometry".toString());u=o}else if(c.contains_9u06oy$(p(qh))){var f,d,m;if(null==(d=null==(f=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(qh)))||e.isType(f,qh)?f:C()))throw S("Component "+p(qh).simpleName+" is not found");if(a=d.origin,c.contains_9u06oy$(p(Fh))){var y,$;if(null==($=null==(y=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(Fh)))||e.isType(y,Fh)?y:C()))throw S("Component "+p(Fh).simpleName+" is not found");m=$}else m=null;u=new zt(a,null!=(l=null!=(s=m)?s.dimension:null)?l:f_().ZERO_WORLD_POINT)}else u=null;null!=u&&(this.myLocation_0.add_9badfu$(u),c.removeComponent_9u06oy$(p(Wp)))}},sh.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var lh=null;function uh(){return null===lh&&new sh,lh}function ch(t,e){Bs.call(this,t),this.myNeedLocation_0=e,this.myLocation_0=new Jp}function ph(t,e){mh(),Bs.call(this,t),this.myGeocodingService_0=e,this.myLocation_7uyaqx$_0=this.myLocation_7uyaqx$_0,this.myMapProjection_mkxcyr$_0=this.myMapProjection_mkxcyr$_0}function hh(t){var e,n=d("request",1,(function(t){return t.request})),i=wn(bn(it(t,10)),16),r=xn(i);for(e=t.iterator();e.hasNext();){var o=e.next();r.put_xwzc9p$(n(o),o)}return r}function _h(){dh=this,this.NEED_LOCATION=x([p(zp),p(Hp)]),this.WAIT_LOCATION=x([p(zp),p(Yp)])}ah.$metadata$={kind:c,simpleName:"LocationCalculateSystem",interfaces:[Bs]},ch.prototype.initImpl_4pvjek$=function(t){this.createEntity_61zpoe$("LocationSingleton").add_57nep2$(this.myLocation_0)},ch.prototype.updateImpl_og8vrq$=function(t,e){var n,i,r=Ft(this.componentManager.getEntities_9u06oy$(p(Fp)));if(this.myNeedLocation_0)this.myLocation_0.wait_za3lpa$(r.size);else for(n=r.iterator();n.hasNext();){var o=n.next();o.removeComponent_9u06oy$(p(Wp)),o.removeComponent_9u06oy$(p(Hp))}for(i=r.iterator();i.hasNext();)i.next().removeComponent_9u06oy$(p(Fp))},ch.$metadata$={kind:c,simpleName:"LocationCounterSystem",interfaces:[Bs]},Object.defineProperty(ph.prototype,"myLocation_0",{configurable:!0,get:function(){return null==this.myLocation_7uyaqx$_0?T("myLocation"):this.myLocation_7uyaqx$_0},set:function(t){this.myLocation_7uyaqx$_0=t}}),Object.defineProperty(ph.prototype,"myMapProjection_0",{configurable:!0,get:function(){return null==this.myMapProjection_mkxcyr$_0?T("myMapProjection"):this.myMapProjection_mkxcyr$_0},set:function(t){this.myMapProjection_mkxcyr$_0=t}}),ph.prototype.initImpl_4pvjek$=function(t){var n,i,r=this.componentManager.getSingletonEntity_9u06oy$(p(Jp));if(null==(i=null==(n=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(Jp)))||e.isType(n,Jp)?n:C()))throw S("Component "+p(Jp).simpleName+" is not found");this.myLocation_0=i,this.myMapProjection_0=t.mapProjection},ph.prototype.updateImpl_og8vrq$=function(t,n){var i=this.getMutableEntities_38uplf$(mh().NEED_LOCATION);if(!i.isEmpty()){var r,o=rt(it(i,10));for(r=i.iterator();r.hasNext();){var a,s,l=r.next(),u=o.add_11rb$;if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(zp)))||e.isType(a,zp)?a:C()))throw S("Component "+p(zp).simpleName+" is not found");u.call(o,s.regionId)}var c,h=$n(o),_=(new vn).setIds_mhpeer$(h).setFeatures_kzd2fe$(ct(gn.POSITION)).build();for(A("execute",function(t,e){return t.execute_2yxzh4$(e)}.bind(null,this.myGeocodingService_0))(_).map_2o04qz$(hh).map_2o04qz$(A("parseLocationMap",function(t,e){return t.parseLocationMap_0(e),N}.bind(null,this))),c=i.iterator();c.hasNext();){var f=c.next();f.add_57nep2$(Kp()),f.removeComponent_9u06oy$(p(Hp))}}},ph.prototype.parseLocationMap_0=function(t){var n;for(n=this.getMutableEntities_38uplf$(mh().WAIT_LOCATION).iterator();n.hasNext();){var i,r,o,a,s=n.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(zp)))||e.isType(o,zp)?o:C()))throw S("Component "+p(zp).simpleName+" is not found");if(null!=(r=null!=(i=t.get_11rb$(a.regionId))?i.position:null)){var l,u=jd().convertToWorldRects_oq2oou$(r,this.myMapProjection_0),c=A("add",function(t,e){return t.add_9badfu$(e),N}.bind(null,this.myLocation_0));for(l=u.iterator();l.hasNext();)c(l.next());s.removeComponent_9u06oy$(p(Yp))}}},_h.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var fh,dh=null;function mh(){return null===dh&&new _h,dh}function yh(t,e,n){Bs.call(this,t),this.myZoom_0=e,this.myLocationRect_0=n,this.myLocation_9g9fb6$_0=this.myLocation_9g9fb6$_0,this.myCamera_khy6qa$_0=this.myCamera_khy6qa$_0,this.myViewport_3hrnxt$_0=this.myViewport_3hrnxt$_0,this.myDefaultLocation_fypjfr$_0=this.myDefaultLocation_fypjfr$_0,this.myNeedLocation_0=!0}function $h(t,e){return function(n){t.myNeedLocation_0=!1;var i=t,r=ct(n);return i.calculatePosition_0(A("calculateBoundingBox",function(t,e){return t.calculateBoundingBox_anatxn$(e)}.bind(null,t.myViewport_0))(r),function(t,e){return function(n,i){return e.setCameraPosition_0(t,n,i),N}}(e,t)),N}}function vh(){bh=this}function gh(t){this.myTransform_0=t,this.myAdaptiveResampling_0=new Kl(this.myTransform_0,fh),this.myPrevPoint_0=null,this.myRing_0=null}ph.$metadata$={kind:c,simpleName:"LocationGeocodingSystem",interfaces:[Bs]},Object.defineProperty(yh.prototype,"myLocation_0",{configurable:!0,get:function(){return null==this.myLocation_9g9fb6$_0?T("myLocation"):this.myLocation_9g9fb6$_0},set:function(t){this.myLocation_9g9fb6$_0=t}}),Object.defineProperty(yh.prototype,"myCamera_0",{configurable:!0,get:function(){return null==this.myCamera_khy6qa$_0?T("myCamera"):this.myCamera_khy6qa$_0},set:function(t){this.myCamera_khy6qa$_0=t}}),Object.defineProperty(yh.prototype,"myViewport_0",{configurable:!0,get:function(){return null==this.myViewport_3hrnxt$_0?T("myViewport"):this.myViewport_3hrnxt$_0},set:function(t){this.myViewport_3hrnxt$_0=t}}),Object.defineProperty(yh.prototype,"myDefaultLocation_0",{configurable:!0,get:function(){return null==this.myDefaultLocation_fypjfr$_0?T("myDefaultLocation"):this.myDefaultLocation_fypjfr$_0},set:function(t){this.myDefaultLocation_fypjfr$_0=t}}),yh.prototype.initImpl_4pvjek$=function(t){var n,i,r=this.componentManager.getSingletonEntity_9u06oy$(p(Jp));if(null==(i=null==(n=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(Jp)))||e.isType(n,Jp)?n:C()))throw S("Component "+p(Jp).simpleName+" is not found");this.myLocation_0=i,this.myCamera_0=this.getSingletonEntity_9u06oy$(p(ko)),this.myViewport_0=t.mapRenderContext.viewport,this.myDefaultLocation_0=jd().convertToWorldRects_oq2oou$(Wi().DEFAULT_LOCATION,t.mapProjection)},yh.prototype.updateImpl_og8vrq$=function(t,e){var n,i,r;if(this.myNeedLocation_0)if(null!=this.myLocationRect_0)this.myLocationRect_0.map_2o04qz$($h(this,t));else if(this.myLocation_0.isReady()){this.myNeedLocation_0=!1;var o=this.myLocation_0.locations,a=null!=(n=o.isEmpty()?null:o)?n:this.myDefaultLocation_0;this.calculatePosition_0(A("calculateBoundingBox",function(t,e){return t.calculateBoundingBox_anatxn$(e)}.bind(null,this.myViewport_0))(a),(i=t,r=this,function(t,e){return r.setCameraPosition_0(i,t,e),N}))}},yh.prototype.calculatePosition_0=function(t,e){var n;null==(n=this.myZoom_0)&&(n=0!==t.dimension.x&&0!==t.dimension.y?this.calculateMaxZoom_0(t.dimension,this.myViewport_0.size):this.calculateMaxZoom_0(this.myViewport_0.calculateBoundingBox_anatxn$(this.myDefaultLocation_0).dimension,this.myViewport_0.size)),e(n,Ce(t))},yh.prototype.setCameraPosition_0=function(t,e,n){t.camera.requestZoom_14dthe$(Z.floor(e)),t.camera.requestPosition_c01uj8$(n)},yh.prototype.calculateMaxZoom_0=function(t,e){var n=this.calculateMaxZoom_1(t.x,e.x),i=this.calculateMaxZoom_1(t.y,e.y),r=Z.min(n,i),o=this.myViewport_0.minZoom,a=this.myViewport_0.maxZoom,s=Z.min(r,a);return Z.max(o,s)},yh.prototype.calculateMaxZoom_1=function(t,e){var n;if(0===t)return this.myViewport_0.maxZoom;if(0===e)n=this.myViewport_0.minZoom;else{var i=e/t;n=Z.log(i)/Z.log(2)}return n},yh.$metadata$={kind:c,simpleName:"MapLocationInitializationSystem",interfaces:[Bs]},vh.prototype.resampling_2z2okz$=function(t,e){return this.createTransformer_0(t,this.resampling_0(e))},vh.prototype.simple_c0yqik$=function(t,e){return new Eh(t,this.simple_0(e))},vh.prototype.resampling_c0yqik$=function(t,e){return new Eh(t,this.resampling_0(e))},vh.prototype.simple_0=function(t){return e=t,function(t,n){return n.add_11rb$(e(t)),N};var e},vh.prototype.resampling_0=function(t){return A("next",function(t,e,n){return t.next_2w6fi5$(e,n),N}.bind(null,new gh(t)))},vh.prototype.createTransformer_0=function(t,n){var i;switch(t.type.name){case"MULTI_POLYGON":i=Al(new Eh(t.multiPolygon,n),A("createMultiPolygon",(function(t){return Cn.Companion.createMultiPolygon_8ft4gs$(t)})));break;case"MULTI_LINESTRING":i=Al(new xh(t.multiLineString,n),A("createMultiLineString",(function(t){return Cn.Companion.createMultiLineString_bc4hlz$(t)})));break;case"MULTI_POINT":i=Al(new kh(t.multiPoint,n),A("createMultiPoint",(function(t){return Cn.Companion.createMultiPoint_xgn53i$(t)})));break;default:i=e.noWhenBranchMatched()}return i},gh.prototype.next_2w6fi5$=function(t,e){var n;for(null!=this.myRing_0&&e===this.myRing_0||(this.myRing_0=e,this.myPrevPoint_0=null),n=this.resample_0(t).iterator();n.hasNext();){var i=n.next();s(this.myRing_0).add_11rb$(this.myTransform_0(i))}},gh.prototype.resample_0=function(t){var e,n=this.myPrevPoint_0;if(this.myPrevPoint_0=t,null!=n){var i=this.myAdaptiveResampling_0.resample_rbt1hw$(n,t);e=i.subList_vux9f0$(1,i.size)}else e=ct(t);return e},gh.$metadata$={kind:c,simpleName:"IterativeResampler",interfaces:[]},vh.$metadata$={kind:b,simpleName:"GeometryTransform",interfaces:[]};var bh=null;function wh(){return null===bh&&new vh,bh}function xh(t,n){this.myTransform_0=n,this.myLineStringIterator_go6o1r$_0=this.myLineStringIterator_go6o1r$_0,this.myPointIterator_8dl2ke$_0=this.myPointIterator_8dl2ke$_0,this.myNewLineString_0=w(),this.myNewMultiLineString_0=w(),this.myHasNext_0=!0,this.myResult_pphhuf$_0=this.myResult_pphhuf$_0;try{this.myLineStringIterator_0=t.iterator(),this.myPointIterator_0=this.myLineStringIterator_0.next().iterator()}catch(t){if(!e.isType(t,Nn))throw t;On(t)}}function kh(t,n){this.myTransform_0=n,this.myPointIterator_dr5tzt$_0=this.myPointIterator_dr5tzt$_0,this.myNewMultiPoint_0=w(),this.myHasNext_0=!0,this.myResult_kbfpjm$_0=this.myResult_kbfpjm$_0;try{this.myPointIterator_0=t.iterator()}catch(t){if(!e.isType(t,Nn))throw t;On(t)}}function Eh(t,n){this.myTransform_0=n,this.myPolygonsIterator_luodmq$_0=this.myPolygonsIterator_luodmq$_0,this.myRingIterator_1fq3dz$_0=this.myRingIterator_1fq3dz$_0,this.myPointIterator_tmjm9$_0=this.myPointIterator_tmjm9$_0,this.myNewRing_0=w(),this.myNewPolygon_0=w(),this.myNewMultiPolygon_0=w(),this.myHasNext_0=!0,this.myResult_7m5cwo$_0=this.myResult_7m5cwo$_0;try{this.myPolygonsIterator_0=t.iterator(),this.myRingIterator_0=this.myPolygonsIterator_0.next().iterator(),this.myPointIterator_0=this.myRingIterator_0.next().iterator()}catch(t){if(!e.isType(t,Nn))throw t;On(t)}}function Ch(){this.geometry_ycd7cj$_0=this.geometry_ycd7cj$_0,this.zoom=0}function Sh(t,e){Ph(),Bs.call(this,e),this.myQuantIterations_0=t}function Th(t,n,i){return function(r){return i.runLaterBySystem_ayosff$(t,function(t,n){return function(i){var r,o;if(kc().tagDirtyParentLayer_ahlfl2$(i),i.contains_9u06oy$(p(Ch))){var a,s;if(null==(s=null==(a=i.componentManager.getComponents_ahlfl2$(i).get_11rb$(p(Ch)))||e.isType(a,Ch)?a:C()))throw S("Component "+p(Ch).simpleName+" is not found");o=s}else{var l=new Ch;i.add_57nep2$(l),o=l}var u,c=o,h=t,_=n;if(c.geometry=h,c.zoom=_,i.contains_9u06oy$(p(qf))){var f,d;if(null==(d=null==(f=i.componentManager.getComponents_ahlfl2$(i).get_11rb$(p(qf)))||e.isType(f,qf)?f:C()))throw S("Component "+p(qf).simpleName+" is not found");u=d}else u=null;return null!=(r=u)&&(r.zoom=n,r.scale=1),N}}(r,n)),N}}function Oh(){Nh=this,this.COMPONENT_TYPES_0=x([p(bo),p(qh),p(Ah),p(Jh),p(yc)])}Object.defineProperty(xh.prototype,"myLineStringIterator_0",{configurable:!0,get:function(){return null==this.myLineStringIterator_go6o1r$_0?T("myLineStringIterator"):this.myLineStringIterator_go6o1r$_0},set:function(t){this.myLineStringIterator_go6o1r$_0=t}}),Object.defineProperty(xh.prototype,"myPointIterator_0",{configurable:!0,get:function(){return null==this.myPointIterator_8dl2ke$_0?T("myPointIterator"):this.myPointIterator_8dl2ke$_0},set:function(t){this.myPointIterator_8dl2ke$_0=t}}),Object.defineProperty(xh.prototype,"myResult_0",{configurable:!0,get:function(){return null==this.myResult_pphhuf$_0?T("myResult"):this.myResult_pphhuf$_0},set:function(t){this.myResult_pphhuf$_0=t}}),xh.prototype.getResult=function(){return this.myResult_0},xh.prototype.resume=function(){if(!this.myPointIterator_0.hasNext()){if(this.myNewMultiLineString_0.add_11rb$(new Sn(this.myNewLineString_0)),!this.myLineStringIterator_0.hasNext())return this.myHasNext_0=!1,void(this.myResult_0=new Tn(this.myNewMultiLineString_0));this.myPointIterator_0=this.myLineStringIterator_0.next().iterator(),this.myNewLineString_0=w()}this.myTransform_0(this.myPointIterator_0.next(),this.myNewLineString_0)},xh.prototype.alive=function(){return this.myHasNext_0},xh.$metadata$={kind:c,simpleName:"MultiLineStringTransform",interfaces:[Pl]},Object.defineProperty(kh.prototype,"myPointIterator_0",{configurable:!0,get:function(){return null==this.myPointIterator_dr5tzt$_0?T("myPointIterator"):this.myPointIterator_dr5tzt$_0},set:function(t){this.myPointIterator_dr5tzt$_0=t}}),Object.defineProperty(kh.prototype,"myResult_0",{configurable:!0,get:function(){return null==this.myResult_kbfpjm$_0?T("myResult"):this.myResult_kbfpjm$_0},set:function(t){this.myResult_kbfpjm$_0=t}}),kh.prototype.getResult=function(){return this.myResult_0},kh.prototype.resume=function(){if(!this.myPointIterator_0.hasNext())return this.myHasNext_0=!1,void(this.myResult_0=new Pn(this.myNewMultiPoint_0));this.myTransform_0(this.myPointIterator_0.next(),this.myNewMultiPoint_0)},kh.prototype.alive=function(){return this.myHasNext_0},kh.$metadata$={kind:c,simpleName:"MultiPointTransform",interfaces:[Pl]},Object.defineProperty(Eh.prototype,"myPolygonsIterator_0",{configurable:!0,get:function(){return null==this.myPolygonsIterator_luodmq$_0?T("myPolygonsIterator"):this.myPolygonsIterator_luodmq$_0},set:function(t){this.myPolygonsIterator_luodmq$_0=t}}),Object.defineProperty(Eh.prototype,"myRingIterator_0",{configurable:!0,get:function(){return null==this.myRingIterator_1fq3dz$_0?T("myRingIterator"):this.myRingIterator_1fq3dz$_0},set:function(t){this.myRingIterator_1fq3dz$_0=t}}),Object.defineProperty(Eh.prototype,"myPointIterator_0",{configurable:!0,get:function(){return null==this.myPointIterator_tmjm9$_0?T("myPointIterator"):this.myPointIterator_tmjm9$_0},set:function(t){this.myPointIterator_tmjm9$_0=t}}),Object.defineProperty(Eh.prototype,"myResult_0",{configurable:!0,get:function(){return null==this.myResult_7m5cwo$_0?T("myResult"):this.myResult_7m5cwo$_0},set:function(t){this.myResult_7m5cwo$_0=t}}),Eh.prototype.getResult=function(){return this.myResult_0},Eh.prototype.resume=function(){if(!this.myPointIterator_0.hasNext())if(this.myNewPolygon_0.add_11rb$(new ut(this.myNewRing_0)),this.myRingIterator_0.hasNext())this.myPointIterator_0=this.myRingIterator_0.next().iterator(),this.myNewRing_0=w();else{if(this.myNewMultiPolygon_0.add_11rb$(new pt(this.myNewPolygon_0)),!this.myPolygonsIterator_0.hasNext())return this.myHasNext_0=!1,void(this.myResult_0=new ht(this.myNewMultiPolygon_0));this.myRingIterator_0=this.myPolygonsIterator_0.next().iterator(),this.myPointIterator_0=this.myRingIterator_0.next().iterator(),this.myNewRing_0=w(),this.myNewPolygon_0=w()}this.myTransform_0(this.myPointIterator_0.next(),this.myNewRing_0)},Eh.prototype.alive=function(){return this.myHasNext_0},Eh.$metadata$={kind:c,simpleName:"MultiPolygonTransform",interfaces:[Pl]},Object.defineProperty(Ch.prototype,"geometry",{configurable:!0,get:function(){return null==this.geometry_ycd7cj$_0?T("geometry"):this.geometry_ycd7cj$_0},set:function(t){this.geometry_ycd7cj$_0=t}}),Ch.$metadata$={kind:c,simpleName:"ScreenGeometryComponent",interfaces:[Ys]},Sh.prototype.createScalingTask_0=function(t,n){var i,r;if(t.contains_9u06oy$(p(qf))||t.removeComponent_9u06oy$(p(Ch)),null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(qh)))||e.isType(i,qh)?i:C()))throw S("Component "+p(qh).simpleName+" is not found");var o,a,l,u,c=r.origin,h=new w_(n),_=wh();if(null==(a=null==(o=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Ah)))||e.isType(o,Ah)?o:C()))throw S("Component "+p(Ah).simpleName+" is not found");return Al(_.simple_c0yqik$(s(a.geometry),(l=h,u=c,function(t){return l.project_11rb$(Ut(t,u))})),Th(t,n,this))},Sh.prototype.updateImpl_og8vrq$=function(t,e){var n,i=t.mapRenderContext.viewport;if(po(t.camera))for(n=this.getEntities_38uplf$(Ph().COMPONENT_TYPES_0).iterator();n.hasNext();){var r=n.next();r.setComponent_qqqpmc$(new Gl(this.createScalingTask_0(r,i.zoom),this.myQuantIterations_0))}},Oh.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Nh=null;function Ph(){return null===Nh&&new Oh,Nh}function Ah(){this.geometry=null}function jh(){this.points=w()}function Lh(t,e,n){Mh(),Bs.call(this,t),this.myComponentManager_0=t,this.myMapProjection_0=e,this.myViewport_0=n}function Rh(){Dh=this,this.WIDGET_COMPONENTS=x([p(lf),p(wl),p(jh)]),this.DARK_ORANGE=k.Companion.parseHex_61zpoe$("#cc7a00")}Sh.$metadata$={kind:c,simpleName:"WorldGeometry2ScreenUpdateSystem",interfaces:[Bs]},Ah.$metadata$={kind:c,simpleName:"WorldGeometryComponent",interfaces:[Ys]},jh.$metadata$={kind:c,simpleName:"MakeGeometryWidgetComponent",interfaces:[Ys]},Lh.prototype.updateImpl_og8vrq$=function(t,e){var n,i;if(null!=(n=this.getWidgetLayer_0())&&null!=(i=this.click_0(n))&&!i.isStopped){var r=m_(i.location),o=A("getMapCoord",function(t,e){return t.getMapCoord_5wcbfv$(e)}.bind(null,this.myViewport_0))(r),a=A("invert",function(t,e){return t.invert_11rc$(e)}.bind(null,this.myMapProjection_0))(o);this.createVisualEntities_0(a,n),this.add_0(n,a)}},Lh.prototype.createVisualEntities_0=function(t,e){var n=new xr(e),i=new zr(n);if(i.point=t,i.strokeColor=Mh().DARK_ORANGE,i.shape=20,i.build_h0uvfn$(!1,new Ns(500),!0),this.count_0(e)>0){var r=new Nr(n,this.myMapProjection_0);Ar(r,x([this.last_0(e),t]),!1),r.strokeColor=Mh().DARK_ORANGE,r.strokeWidth=1.5,r.build_6taknv$(!0)}},Lh.prototype.getWidgetLayer_0=function(){return this.myComponentManager_0.tryGetSingletonEntity_tv8pd9$(Mh().WIDGET_COMPONENTS)},Lh.prototype.click_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(wl)))||e.isType(n,wl)?n:C()))throw S("Component "+p(wl).simpleName+" is not found");return i.click},Lh.prototype.count_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(jh)))||e.isType(n,jh)?n:C()))throw S("Component "+p(jh).simpleName+" is not found");return i.points.size},Lh.prototype.last_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(jh)))||e.isType(n,jh)?n:C()))throw S("Component "+p(jh).simpleName+" is not found");return Je(i.points)},Lh.prototype.add_0=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(jh)))||e.isType(i,jh)?i:C()))throw S("Component "+p(jh).simpleName+" is not found");return r.points.add_11rb$(n)},Rh.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ih,zh,Dh=null;function Mh(){return null===Dh&&new Rh,Dh}function Bh(t){var e,n={v:0},i={v:""},r={v:""};for(e=t.iterator();e.hasNext();){var o=e.next();5===n.v&&(n.v=0,i.v+="\n ",r.v+="\n "),n.v=n.v+1|0,i.v+=Uh(o.x)+", ",r.v+=Uh(o.y)+", "}return"geometry = {\n 'lon': ["+An(i.v,2)+"], \n 'lat': ["+An(r.v,2)+"]\n}"}function Uh(t){var e=oe(t.toString(),["."]);return e.get_za3lpa$(0)+"."+(e.get_za3lpa$(1).length>6?e.get_za3lpa$(1).substring(0,6):e.get_za3lpa$(1))}function Fh(t){this.dimension=t}function qh(t){this.origin=t}function Gh(){this.origins=w(),this.rounding=Kh()}function Hh(t,e,n){me.call(this),this.f_wsutam$_0=n,this.name$=t,this.ordinal$=e}function Yh(){Yh=function(){},Ih=new Hh("NONE",0,Vh),zh=new Hh("FLOOR",1,Wh)}function Vh(t){return t}function Kh(){return Yh(),Ih}function Wh(t){var e=t.x,n=Z.floor(e),i=t.y;return H(n,Z.floor(i))}function Xh(){return Yh(),zh}function Zh(){this.dimension=f_().ZERO_CLIENT_POINT}function Jh(){this.origin=f_().ZERO_CLIENT_POINT}function Qh(){this.offset=f_().ZERO_CLIENT_POINT}function t_(t){i_(),Bs.call(this,t)}function e_(){n_=this,this.COMPONENT_TYPES_0=x([p(wo),p(Jh),p(Zh),p(Gh)])}Lh.$metadata$={kind:c,simpleName:"MakeGeometryWidgetSystem",interfaces:[Bs]},Fh.$metadata$={kind:c,simpleName:"WorldDimensionComponent",interfaces:[Ys]},qh.$metadata$={kind:c,simpleName:"WorldOriginComponent",interfaces:[Ys]},Hh.prototype.apply_5wcbfv$=function(t){return this.f_wsutam$_0(t)},Hh.$metadata$={kind:c,simpleName:"Rounding",interfaces:[me]},Hh.values=function(){return[Kh(),Xh()]},Hh.valueOf_61zpoe$=function(t){switch(t){case"NONE":return Kh();case"FLOOR":return Xh();default:ye("No enum constant jetbrains.livemap.placement.ScreenLoopComponent.Rounding."+t)}},Gh.$metadata$={kind:c,simpleName:"ScreenLoopComponent",interfaces:[Ys]},Zh.$metadata$={kind:c,simpleName:"ScreenDimensionComponent",interfaces:[Ys]},Jh.$metadata$={kind:c,simpleName:"ScreenOriginComponent",interfaces:[Ys]},Qh.$metadata$={kind:c,simpleName:"ScreenOffsetComponent",interfaces:[Ys]},t_.prototype.updateImpl_og8vrq$=function(t,n){var i,r=t.mapRenderContext.viewport;for(i=this.getEntities_38uplf$(i_().COMPONENT_TYPES_0).iterator();i.hasNext();){var o,a,s,l=i.next();if(l.contains_9u06oy$(p(Qh))){var u,c;if(null==(c=null==(u=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(Qh)))||e.isType(u,Qh)?u:C()))throw S("Component "+p(Qh).simpleName+" is not found");s=c}else s=null;var h,_,f=null!=(a=null!=(o=s)?o.offset:null)?a:f_().ZERO_CLIENT_POINT;if(null==(_=null==(h=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(Jh)))||e.isType(h,Jh)?h:C()))throw S("Component "+p(Jh).simpleName+" is not found");var d,m,y=L(_.origin,f);if(null==(m=null==(d=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(Zh)))||e.isType(d,Zh)?d:C()))throw S("Component "+p(Zh).simpleName+" is not found");var $,v,g=m.dimension;if(null==(v=null==($=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(Gh)))||e.isType($,Gh)?$:C()))throw S("Component "+p(Gh).simpleName+" is not found");var b,w=r.getOrigins_uqcerw$(y,g),x=rt(it(w,10));for(b=w.iterator();b.hasNext();){var k=b.next();x.add_11rb$(v.rounding.apply_5wcbfv$(k))}v.origins=x}},e_.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var n_=null;function i_(){return null===n_&&new e_,n_}function r_(t){s_(),Bs.call(this,t)}function o_(){a_=this,this.COMPONENT_TYPES_0=x([p(bo),p(Fh),p(yc)])}t_.$metadata$={kind:c,simpleName:"ScreenLoopsUpdateSystem",interfaces:[Bs]},r_.prototype.updateImpl_og8vrq$=function(t,n){var i;if(po(t.camera))for(i=this.getEntities_38uplf$(s_().COMPONENT_TYPES_0).iterator();i.hasNext();){var r,o,a=i.next();if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Fh)))||e.isType(r,Fh)?r:C()))throw S("Component "+p(Fh).simpleName+" is not found");var s,l=o.dimension,u=s_().world2Screen_t8ozei$(l,g(t.camera.zoom));if(a.contains_9u06oy$(p(Zh))){var c,h;if(null==(h=null==(c=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Zh)))||e.isType(c,Zh)?c:C()))throw S("Component "+p(Zh).simpleName+" is not found");s=h}else{var _=new Zh;a.add_57nep2$(_),s=_}s.dimension=u,kc().tagDirtyParentLayer_ahlfl2$(a)}},o_.prototype.world2Screen_t8ozei$=function(t,e){return new w_(e).project_11rb$(t)},o_.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var a_=null;function s_(){return null===a_&&new o_,a_}function l_(t){p_(),Bs.call(this,t)}function u_(){c_=this,this.COMPONENT_TYPES_0=x([p(wo),p(qh),p(yc)])}r_.$metadata$={kind:c,simpleName:"WorldDimension2ScreenUpdateSystem",interfaces:[Bs]},l_.prototype.updateImpl_og8vrq$=function(t,n){var i,r=t.mapRenderContext.viewport;for(i=this.getEntities_38uplf$(p_().COMPONENT_TYPES_0).iterator();i.hasNext();){var o,a,s=i.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(qh)))||e.isType(o,qh)?o:C()))throw S("Component "+p(qh).simpleName+" is not found");var l,u=a.origin,c=A("getViewCoord",function(t,e){return t.getViewCoord_c01uj8$(e)}.bind(null,r))(u);if(s.contains_9u06oy$(p(Jh))){var h,_;if(null==(_=null==(h=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(Jh)))||e.isType(h,Jh)?h:C()))throw S("Component "+p(Jh).simpleName+" is not found");l=_}else{var f=new Jh;s.add_57nep2$(f),l=f}l.origin=c,kc().tagDirtyParentLayer_ahlfl2$(s)}},u_.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var c_=null;function p_(){return null===c_&&new u_,c_}function h_(){__=this,this.ZERO_LONLAT_POINT=H(0,0),this.ZERO_WORLD_POINT=H(0,0),this.ZERO_CLIENT_POINT=H(0,0)}l_.$metadata$={kind:c,simpleName:"WorldOrigin2ScreenUpdateSystem",interfaces:[Bs]},h_.$metadata$={kind:b,simpleName:"Coordinates",interfaces:[]};var __=null;function f_(){return null===__&&new h_,__}function d_(t,e){return q(t.x,t.y,e.x,e.y)}function m_(t){return jn(t.x,t.y)}function y_(t){return H(t.x,t.y)}function $_(){}function v_(t,e){this.geoProjection_0=t,this.mapRect_0=e,this.reverseX_0=!1,this.reverseY_0=!1}function g_(t,e){this.this$MapProjectionBuilder=t,this.closure$proj=e}function b_(t,e){return new v_(Qu().createGeoProjection_7v9tu4$(t),e).reverseY().create()}function w_(t){this.projector_0=Qu().square_ilk2sd$(Qu().zoom_za3lpa$(t))}function x_(){this.myCache_0=st()}function k_(){S_(),this.myCache_0=new Ya(5e3)}function E_(){C_=this,this.EMPTY_FRAGMENTS_CACHE_LIMIT_0=5e4,this.REGIONS_CACHE_LIMIT_0=5e3}$_.$metadata$={kind:v,simpleName:"MapProjection",interfaces:[Au]},v_.prototype.reverseX=function(){return this.reverseX_0=!0,this},v_.prototype.reverseY=function(){return this.reverseY_0=!0,this},Object.defineProperty(g_.prototype,"mapRect",{configurable:!0,get:function(){return this.this$MapProjectionBuilder.mapRect_0}}),g_.prototype.project_11rb$=function(t){return this.closure$proj.project_11rb$(t)},g_.prototype.invert_11rc$=function(t){return this.closure$proj.invert_11rc$(t)},g_.$metadata$={kind:c,interfaces:[$_]},v_.prototype.create=function(){var t,n=Qu().transformBBox_kr9gox$(this.geoProjection_0.validRect(),A("project",function(t,e){return t.project_11rb$(e)}.bind(null,this.geoProjection_0))),i=It(this.mapRect_0)/It(n),r=Mt(this.mapRect_0)/Mt(n),o=Z.min(i,r),a=e.isType(t=Ln(this.mapRect_0.dimension,1/o),Rn)?t:C(),s=new zt(Ut(Ce(n),Ln(a,.5)),a),l=this.reverseX_0?Ht(s):Rt(s),u=this.reverseX_0?-o:o,c=this.reverseY_0?Yt(s):Dt(s),p=this.reverseY_0?-o:o,h=Qu().tuple_bkiy7g$(Qu().linear_sdh6z7$(l,u),Qu().linear_sdh6z7$(c,p));return new g_(this,Qu().composite_ogd8x7$(this.geoProjection_0,h))},v_.$metadata$={kind:c,simpleName:"MapProjectionBuilder",interfaces:[]},w_.prototype.project_11rb$=function(t){return this.projector_0.project_11rb$(t)},w_.prototype.invert_11rc$=function(t){return this.projector_0.invert_11rc$(t)},w_.$metadata$={kind:c,simpleName:"WorldProjection",interfaces:[Au]},x_.prototype.contains_x1fgxf$=function(t){return this.myCache_0.containsKey_11rb$(t)},x_.prototype.keys=function(){return this.myCache_0.keys},x_.prototype.store_9ormk8$=function(t,e){if(this.myCache_0.containsKey_11rb$(t))throw S(("Already existing fragment: "+e.name).toString());this.myCache_0.put_xwzc9p$(t,e)},x_.prototype.get_n5xzzq$=function(t){return this.myCache_0.get_11rb$(t)},x_.prototype.dispose_n5xzzq$=function(t){var e;null!=(e=this.get_n5xzzq$(t))&&e.remove(),this.myCache_0.remove_11rb$(t)},x_.$metadata$={kind:c,simpleName:"CachedFragmentsComponent",interfaces:[Ys]},k_.prototype.createCache=function(){return new Ya(5e4)},k_.prototype.add_x1fgxf$=function(t){this.myCache_0.getOrPut_kpg1aj$(t.regionId,A("createCache",function(t){return t.createCache()}.bind(null,this))).put_xwzc9p$(t.quadKey,!0)},k_.prototype.contains_ny6xdl$=function(t,e){var n=this.myCache_0.get_11rb$(t);return null!=n&&n.containsKey_11rb$(e)},k_.prototype.addAll_j9syn5$=function(t){var e;for(e=t.iterator();e.hasNext();){var n=e.next();this.add_x1fgxf$(n)}},E_.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var C_=null;function S_(){return null===C_&&new E_,C_}function T_(){this.existingRegions=pe()}function O_(){this.myNewFragments_0=pe(),this.myObsoleteFragments_0=pe()}function N_(){this.queue=st(),this.downloading=pe(),this.downloaded_hhbogc$_0=st()}function P_(t){this.fragmentKey=t}function A_(){this.myFragmentEntities_0=pe()}function j_(){this.myEmitted_0=pe()}function L_(){this.myEmitted_0=pe()}function R_(){this.fetching_0=st()}function I_(t,e,n){Bs.call(this,n),this.myMaxActiveDownloads_0=t,this.myFragmentGeometryProvider_0=e,this.myRegionFragments_0=st(),this.myLock_0=new Bn}function z_(t,e){return function(n){var i;for(i=n.entries.iterator();i.hasNext();){var r,o=i.next(),a=t,s=e,l=o.key,u=o.value,c=ze(u),p=d("key",1,(function(t){return t.key})),h=rt(it(u,10));for(r=u.iterator();r.hasNext();){var _=r.next();h.add_11rb$(p(_))}var f,m=Jt(h);for(f=Dn(a,m).iterator();f.hasNext();){var y=f.next();c.add_11rb$(new Mn(y,at()))}var $=s.myLock_0;try{$.lock();var v,g=s.myRegionFragments_0,b=g.get_11rb$(l);if(null==b){var x=w();g.put_xwzc9p$(l,x),v=x}else v=b;v.addAll_brywnq$(c)}finally{$.unlock()}}return N}}function D_(t,e){Bs.call(this,e),this.myProjectionQuant_0=t,this.myRegionIndex_0=new Q_(e),this.myWaitingForScreenGeometry_0=st()}function M_(t){return t.unaryPlus_jixjl7$(new R_),t.unaryPlus_jixjl7$(new j_),t.unaryPlus_jixjl7$(new x_),N}function B_(t){return function(e){return Qs(e,function(t){return function(e){return e.unaryPlus_jixjl7$(new Fh(t.dimension)),e.unaryPlus_jixjl7$(new qh(t.origin)),N}}(t)),N}}function U_(t,e,n){return function(i){var r;if(null==(r=gt.GeometryUtil.bbox_8ft4gs$(i)))throw S("Fragment bbox can't be null".toString());var o=r;return e.runLaterBySystem_ayosff$(t,B_(o)),wh().simple_c0yqik$(i,function(t,e){return function(n){return t.project_11rb$(Ut(n,e.origin))}}(n,o))}}function F_(t,n,i){return function(r){return Qs(r,function(t,n,i){return function(r){r.unaryPlus_jixjl7$(new xo),r.unaryPlus_jixjl7$(new wo),r.unaryPlus_jixjl7$(new bo);var o=new qf,a=t;o.zoom=af().zoom_x1fgxf$(a),r.unaryPlus_jixjl7$(o),r.unaryPlus_jixjl7$(new P_(t)),r.unaryPlus_jixjl7$(new Gh);var s=new Ch;s.geometry=n,r.unaryPlus_jixjl7$(s);var l,u,c=i.myRegionIndex_0.find_61zpoe$(t.regionId);if(null==(u=null==(l=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(yc)))||e.isType(l,yc)?l:C()))throw S("Component "+p(yc).simpleName+" is not found");return r.unaryPlus_jixjl7$(u),N}}(t,n,i)),N}}function q_(t,e){this.regionId=t,this.quadKey=e}function G_(t){K_(),Bs.call(this,t)}function H_(t){return t.unaryPlus_jixjl7$(new O_),t.unaryPlus_jixjl7$(new k_),t.unaryPlus_jixjl7$(new T_),N}function Y_(){V_=this,this.REGION_ENTITY_COMPONENTS=x([p(zp),p(rh),p(A_)])}k_.$metadata$={kind:c,simpleName:"EmptyFragmentsComponent",interfaces:[Ys]},T_.$metadata$={kind:c,simpleName:"ExistingRegionsComponent",interfaces:[Ys]},Object.defineProperty(O_.prototype,"requested",{configurable:!0,get:function(){return this.myNewFragments_0}}),Object.defineProperty(O_.prototype,"obsolete",{configurable:!0,get:function(){return this.myObsoleteFragments_0}}),O_.prototype.setToAdd_c2k76v$=function(t){this.myNewFragments_0.clear(),this.myNewFragments_0.addAll_brywnq$(t)},O_.prototype.setToRemove_c2k76v$=function(t){this.myObsoleteFragments_0.clear(),this.myObsoleteFragments_0.addAll_brywnq$(t)},O_.prototype.anyChanges=function(){return!this.myNewFragments_0.isEmpty()&&this.myObsoleteFragments_0.isEmpty()},O_.$metadata$={kind:c,simpleName:"ChangedFragmentsComponent",interfaces:[Ys]},Object.defineProperty(N_.prototype,"downloaded",{configurable:!0,get:function(){return this.downloaded_hhbogc$_0},set:function(t){this.downloaded.clear(),this.downloaded.putAll_a2k3zr$(t)}}),N_.prototype.getZoomQueue_za3lpa$=function(t){var e;return null!=(e=this.queue.get_11rb$(t))?e:pe()},N_.prototype.extendQueue_j9syn5$=function(t){var e;for(e=t.iterator();e.hasNext();){var n,i=e.next(),r=this.queue,o=i.zoom(),a=r.get_11rb$(o);if(null==a){var s=pe();r.put_xwzc9p$(o,s),n=s}else n=a;n.add_11rb$(i)}},N_.prototype.reduceQueue_j9syn5$=function(t){var e,n;for(e=t.iterator();e.hasNext();){var i=e.next();null!=(n=this.queue.get_11rb$(i.zoom()))&&n.remove_11rb$(i)}},N_.prototype.extendDownloading_alj0n8$=function(t){this.downloading.addAll_brywnq$(t)},N_.prototype.reduceDownloading_alj0n8$=function(t){this.downloading.removeAll_brywnq$(t)},N_.$metadata$={kind:c,simpleName:"DownloadingFragmentsComponent",interfaces:[Ys]},P_.$metadata$={kind:c,simpleName:"FragmentComponent",interfaces:[Ys]},Object.defineProperty(A_.prototype,"fragments",{configurable:!0,get:function(){return this.myFragmentEntities_0},set:function(t){this.myFragmentEntities_0.clear(),this.myFragmentEntities_0.addAll_brywnq$(t)}}),A_.$metadata$={kind:c,simpleName:"RegionFragmentsComponent",interfaces:[Ys]},j_.prototype.setEmitted_j9syn5$=function(t){return this.myEmitted_0.clear(),this.myEmitted_0.addAll_brywnq$(t),this},j_.prototype.keys_8be2vx$=function(){return this.myEmitted_0},j_.$metadata$={kind:c,simpleName:"EmittedFragmentsComponent",interfaces:[Ys]},L_.prototype.keys=function(){return this.myEmitted_0},L_.$metadata$={kind:c,simpleName:"EmittedRegionsComponent",interfaces:[Ys]},R_.prototype.keys=function(){return this.fetching_0.keys},R_.prototype.add_x1fgxf$=function(t){this.fetching_0.put_xwzc9p$(t,null)},R_.prototype.addAll_alj0n8$=function(t){var e;for(e=t.iterator();e.hasNext();){var n=e.next();this.fetching_0.put_xwzc9p$(n,null)}},R_.prototype.set_j1gy6z$=function(t,e){this.fetching_0.put_xwzc9p$(t,e)},R_.prototype.getEntity_x1fgxf$=function(t){return this.fetching_0.get_11rb$(t)},R_.prototype.remove_x1fgxf$=function(t){this.fetching_0.remove_11rb$(t)},R_.$metadata$={kind:c,simpleName:"StreamingFragmentsComponent",interfaces:[Ys]},I_.prototype.initImpl_4pvjek$=function(t){this.createEntity_61zpoe$("DownloadingFragments").add_57nep2$(new N_)},I_.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o=this.componentManager.getSingletonEntity_9u06oy$(p(N_));if(null==(r=null==(i=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(N_)))||e.isType(i,N_)?i:C()))throw S("Component "+p(N_).simpleName+" is not found");var a,s,l=r,u=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(s=null==(a=u.componentManager.getComponents_ahlfl2$(u).get_11rb$(p(O_)))||e.isType(a,O_)?a:C()))throw S("Component "+p(O_).simpleName+" is not found");var c,h,_=s,f=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(h=null==(c=f.componentManager.getComponents_ahlfl2$(f).get_11rb$(p(R_)))||e.isType(c,R_)?c:C()))throw S("Component "+p(R_).simpleName+" is not found");var d,m,y=h,$=this.componentManager.getSingletonEntity_9u06oy$(p(x_));if(null==(m=null==(d=$.componentManager.getComponents_ahlfl2$($).get_11rb$(p(x_)))||e.isType(d,x_)?d:C()))throw S("Component "+p(x_).simpleName+" is not found");var v=m;if(l.reduceQueue_j9syn5$(_.obsolete),l.extendQueue_j9syn5$(rf().ofCopy_j9syn5$(_.requested).exclude_8tsrz2$(y.keys()).exclude_8tsrz2$(v.keys()).exclude_8tsrz2$(l.downloading).get()),l.downloading.size=0;)i.add_11rb$(r.next()),r.remove(),n=n-1|0;return i},I_.prototype.downloadGeometries_0=function(t){var n,i,r,o=st(),a=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(r=null==(i=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(R_)))||e.isType(i,R_)?i:C()))throw S("Component "+p(R_).simpleName+" is not found");var s,l=r;for(n=t.iterator();n.hasNext();){var u,c=n.next(),h=c.regionId,_=o.get_11rb$(h);if(null==_){var f=pe();o.put_xwzc9p$(h,f),u=f}else u=_;u.add_11rb$(c.quadKey),l.add_x1fgxf$(c)}for(s=o.entries.iterator();s.hasNext();){var d=s.next(),m=d.key,y=d.value;this.myFragmentGeometryProvider_0.getFragments_u051w$(ct(m),y).onSuccess_qlkmfe$(z_(y,this))}},I_.$metadata$={kind:c,simpleName:"FragmentDownloadingSystem",interfaces:[Bs]},D_.prototype.initImpl_4pvjek$=function(t){Qs(this.createEntity_61zpoe$("FragmentsFetch"),M_)},D_.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o=this.componentManager.getSingletonEntity_9u06oy$(p(N_));if(null==(r=null==(i=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(N_)))||e.isType(i,N_)?i:C()))throw S("Component "+p(N_).simpleName+" is not found");var a=r.downloaded,s=pe();if(!a.isEmpty()){var l,u,c=this.componentManager.getSingletonEntity_9u06oy$(p(pa));if(null==(u=null==(l=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(pa)))||e.isType(l,pa)?l:C()))throw S("Component "+p(pa).simpleName+" is not found");var h,_=u.visibleQuads,d=pe(),m=pe();for(h=a.entries.iterator();h.hasNext();){var y=h.next(),$=y.key,v=y.value;if(_.contains_11rb$($.quadKey))if(v.isEmpty()){s.add_11rb$($);var g,b,w=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(b=null==(g=w.componentManager.getComponents_ahlfl2$(w).get_11rb$(p(R_)))||e.isType(g,R_)?g:C()))throw S("Component "+p(R_).simpleName+" is not found");b.remove_x1fgxf$($)}else{d.add_11rb$($.quadKey);var x=this.myWaitingForScreenGeometry_0,k=this.createFragmentEntity_0($,Un(v),t.mapProjection);x.put_xwzc9p$($,k)}else{var E,T,O=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(T=null==(E=O.componentManager.getComponents_ahlfl2$(O).get_11rb$(p(R_)))||e.isType(E,R_)?E:C()))throw S("Component "+p(R_).simpleName+" is not found");T.remove_x1fgxf$($),m.add_11rb$($.quadKey)}}}var N,P=this.findTransformedFragments_0();for(N=P.entries.iterator();N.hasNext();){var A,j,L=N.next(),R=L.key,I=L.value,z=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(j=null==(A=z.componentManager.getComponents_ahlfl2$(z).get_11rb$(p(R_)))||e.isType(A,R_)?A:C()))throw S("Component "+p(R_).simpleName+" is not found");j.remove_x1fgxf$(R);var D,M,B=this.componentManager.getSingletonEntity_9u06oy$(p(x_));if(null==(M=null==(D=B.componentManager.getComponents_ahlfl2$(B).get_11rb$(p(x_)))||e.isType(D,x_)?D:C()))throw S("Component "+p(x_).simpleName+" is not found");M.store_9ormk8$(R,I)}var U=pe();U.addAll_brywnq$(s),U.addAll_brywnq$(P.keys);var F,q,G=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(q=null==(F=G.componentManager.getComponents_ahlfl2$(G).get_11rb$(p(O_)))||e.isType(F,O_)?F:C()))throw S("Component "+p(O_).simpleName+" is not found");var H,Y,V=q.requested,K=this.componentManager.getSingletonEntity_9u06oy$(p(x_));if(null==(Y=null==(H=K.componentManager.getComponents_ahlfl2$(K).get_11rb$(p(x_)))||e.isType(H,x_)?H:C()))throw S("Component "+p(x_).simpleName+" is not found");U.addAll_brywnq$(f(V,Y.keys()));var W,X,Z=this.componentManager.getSingletonEntity_9u06oy$(p(k_));if(null==(X=null==(W=Z.componentManager.getComponents_ahlfl2$(Z).get_11rb$(p(k_)))||e.isType(W,k_)?W:C()))throw S("Component "+p(k_).simpleName+" is not found");X.addAll_j9syn5$(s);var J,Q,tt=this.componentManager.getSingletonEntity_9u06oy$(p(j_));if(null==(Q=null==(J=tt.componentManager.getComponents_ahlfl2$(tt).get_11rb$(p(j_)))||e.isType(J,j_)?J:C()))throw S("Component "+p(j_).simpleName+" is not found");Q.setEmitted_j9syn5$(U)},D_.prototype.findTransformedFragments_0=function(){for(var t=st(),n=this.myWaitingForScreenGeometry_0.values.iterator();n.hasNext();){var i=n.next();if(i.contains_9u06oy$(p(Ch))){var r,o;if(null==(o=null==(r=i.componentManager.getComponents_ahlfl2$(i).get_11rb$(p(P_)))||e.isType(r,P_)?r:C()))throw S("Component "+p(P_).simpleName+" is not found");var a=o.fragmentKey;t.put_xwzc9p$(a,i),n.remove()}}return t},D_.prototype.createFragmentEntity_0=function(t,n,i){if(n.isEmpty())throw Ge("Failed requirement.".toString());var r,o,a,s=this.createEntity_61zpoe$(af().entityName_n5xzzq$(t)),l=Qu().square_ilk2sd$(Qu().zoom_za3lpa$(af().zoom_x1fgxf$(t))),u=Al(jl(wh().resampling_c0yqik$(n,A("project",function(t,e){return t.project_11rb$(e)}.bind(null,i))),U_(s,this,l)),(r=s,o=t,a=this,function(t){a.runLaterBySystem_ayosff$(r,F_(o,t,a))}));s.add_57nep2$(new Gl(u,this.myProjectionQuant_0));var c,h,_=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(h=null==(c=_.componentManager.getComponents_ahlfl2$(_).get_11rb$(p(R_)))||e.isType(c,R_)?c:C()))throw S("Component "+p(R_).simpleName+" is not found");return h.set_j1gy6z$(t,s),s},D_.$metadata$={kind:c,simpleName:"FragmentEmitSystem",interfaces:[Bs]},q_.prototype.zoom=function(){return Fn(this.quadKey)},q_.$metadata$={kind:c,simpleName:"FragmentKey",interfaces:[]},q_.prototype.component1=function(){return this.regionId},q_.prototype.component2=function(){return this.quadKey},q_.prototype.copy_cwu9hm$=function(t,e){return new q_(void 0===t?this.regionId:t,void 0===e?this.quadKey:e)},q_.prototype.toString=function(){return"FragmentKey(regionId="+e.toString(this.regionId)+", quadKey="+e.toString(this.quadKey)+")"},q_.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.regionId)|0)+e.hashCode(this.quadKey)|0},q_.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.regionId,t.regionId)&&e.equals(this.quadKey,t.quadKey)},G_.prototype.initImpl_4pvjek$=function(t){Qs(this.createEntity_61zpoe$("FragmentsChange"),H_)},G_.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o,a,s,l=this.componentManager.getSingletonEntity_9u06oy$(p(pa));if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(pa)))||e.isType(a,pa)?a:C()))throw S("Component "+p(pa).simpleName+" is not found");var u,c,h=s,_=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(c=null==(u=_.componentManager.getComponents_ahlfl2$(_).get_11rb$(p(O_)))||e.isType(u,O_)?u:C()))throw S("Component "+p(O_).simpleName+" is not found");var f,d,m=c,y=this.componentManager.getSingletonEntity_9u06oy$(p(k_));if(null==(d=null==(f=y.componentManager.getComponents_ahlfl2$(y).get_11rb$(p(k_)))||e.isType(f,k_)?f:C()))throw S("Component "+p(k_).simpleName+" is not found");var $,v,g=d,b=this.componentManager.getSingletonEntity_9u06oy$(p(T_));if(null==(v=null==($=b.componentManager.getComponents_ahlfl2$(b).get_11rb$(p(T_)))||e.isType($,T_)?$:C()))throw S("Component "+p(T_).simpleName+" is not found");var x=v.existingRegions,k=h.quadsToRemove,E=w(),T=w();for(i=this.getEntities_38uplf$(K_().REGION_ENTITY_COMPONENTS).iterator();i.hasNext();){var O,N,P=i.next();if(null==(N=null==(O=P.componentManager.getComponents_ahlfl2$(P).get_11rb$(p(rh)))||e.isType(O,rh)?O:C()))throw S("Component "+p(rh).simpleName+" is not found");var A,j,L=N.bbox;if(null==(j=null==(A=P.componentManager.getComponents_ahlfl2$(P).get_11rb$(p(zp)))||e.isType(A,zp)?A:C()))throw S("Component "+p(zp).simpleName+" is not found");var R=j.regionId,I=h.quadsToAdd;for(x.contains_11rb$(R)||(I=h.visibleQuads,x.add_11rb$(R)),r=I.iterator();r.hasNext();){var z=r.next();!g.contains_ny6xdl$(R,z)&&this.intersect_0(L,z)&&E.add_11rb$(new q_(R,z))}for(o=k.iterator();o.hasNext();){var D=o.next();g.contains_ny6xdl$(R,D)||T.add_11rb$(new q_(R,D))}}m.setToAdd_c2k76v$(E),m.setToRemove_c2k76v$(T)},G_.prototype.intersect_0=function(t,e){var n,i=qn(e);for(n=t.splitByAntiMeridian().iterator();n.hasNext();){var r=n.next();if(Gn(r,i))return!0}return!1},Y_.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var V_=null;function K_(){return null===V_&&new Y_,V_}function W_(t,e){Bs.call(this,e),this.myCacheSize_0=t}function X_(t){Bs.call(this,t),this.myRegionIndex_0=new Q_(t),this.myPendingFragments_0=st(),this.myPendingZoom_0=-1}function Z_(){this.myWaitingFragments_0=pe(),this.myReadyFragments_0=pe(),this.myIsDone_0=!1}function J_(){of=this}function Q_(t){this.myComponentManager_0=t,this.myRegionIndex_0=new Ya(1e4)}function tf(t){rf(),this.myValues_0=t}function ef(){nf=this}G_.$metadata$={kind:c,simpleName:"FragmentUpdateSystem",interfaces:[Bs]},W_.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o,a,s,l=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(a=null==(o=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(O_)))||e.isType(o,O_)?o:C()))throw S("Component "+p(O_).simpleName+" is not found");if(a.anyChanges()){var u,c,h=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(c=null==(u=h.componentManager.getComponents_ahlfl2$(h).get_11rb$(p(O_)))||e.isType(u,O_)?u:C()))throw S("Component "+p(O_).simpleName+" is not found");var _,f,d,m=c.requested,y=pe(),$=this.componentManager.getSingletonEntity_9u06oy$(p(R_));if(null==(d=null==(f=$.componentManager.getComponents_ahlfl2$($).get_11rb$(p(R_)))||e.isType(f,R_)?f:C()))throw S("Component "+p(R_).simpleName+" is not found");var v,g=d,b=pe();if(!m.isEmpty()){var w=af().zoom_x1fgxf$(Ue(m));for(_=g.keys().iterator();_.hasNext();){var x=_.next();af().zoom_x1fgxf$(x)===w?y.add_11rb$(x):b.add_11rb$(x)}}for(v=b.iterator();v.hasNext();){var k,E=v.next();null!=(k=g.getEntity_x1fgxf$(E))&&k.remove(),g.remove_x1fgxf$(E)}var T=pe();for(i=this.getEntities_9u06oy$(p(A_)).iterator();i.hasNext();){var O,N,P=i.next();if(null==(N=null==(O=P.componentManager.getComponents_ahlfl2$(P).get_11rb$(p(A_)))||e.isType(O,A_)?O:C()))throw S("Component "+p(A_).simpleName+" is not found");var A,j=N.fragments,L=rt(it(j,10));for(A=j.iterator();A.hasNext();){var R,I,z=A.next(),D=L.add_11rb$;if(null==(I=null==(R=z.componentManager.getComponents_ahlfl2$(z).get_11rb$(p(P_)))||e.isType(R,P_)?R:C()))throw S("Component "+p(P_).simpleName+" is not found");D.call(L,I.fragmentKey)}T.addAll_brywnq$(L)}var M,B,U=this.componentManager.getSingletonEntity_9u06oy$(p(x_));if(null==(B=null==(M=U.componentManager.getComponents_ahlfl2$(U).get_11rb$(p(x_)))||e.isType(M,x_)?M:C()))throw S("Component "+p(x_).simpleName+" is not found");var F,q,G=B,H=this.componentManager.getSingletonEntity_9u06oy$(p(pa));if(null==(q=null==(F=H.componentManager.getComponents_ahlfl2$(H).get_11rb$(p(pa)))||e.isType(F,pa)?F:C()))throw S("Component "+p(pa).simpleName+" is not found");var Y,V,K=q.visibleQuads,W=Hn(G.keys()),X=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(V=null==(Y=X.componentManager.getComponents_ahlfl2$(X).get_11rb$(p(O_)))||e.isType(Y,O_)?Y:C()))throw S("Component "+p(O_).simpleName+" is not found");W.addAll_brywnq$(V.obsolete),W.removeAll_brywnq$(m),W.removeAll_brywnq$(T),W.removeAll_brywnq$(y),Yn(W,(s=K,function(t){return s.contains_11rb$(t.quadKey)}));for(var Z=W.size-this.myCacheSize_0|0,J=W.iterator();J.hasNext()&&(Z=(r=Z)-1|0,r>0);){var Q=J.next();G.contains_x1fgxf$(Q)&&G.dispose_n5xzzq$(Q)}}},W_.$metadata$={kind:c,simpleName:"FragmentsRemovingSystem",interfaces:[Bs]},X_.prototype.initImpl_4pvjek$=function(t){this.createEntity_61zpoe$("emitted_regions").add_57nep2$(new L_)},X_.prototype.updateImpl_og8vrq$=function(t,n){var i;t.camera.isZoomChanged&&po(t.camera)&&(this.myPendingZoom_0=g(t.camera.zoom),this.myPendingFragments_0.clear());var r,o,a=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(O_)))||e.isType(r,O_)?r:C()))throw S("Component "+p(O_).simpleName+" is not found");var s,l=o.requested,u=A("wait",function(t,e){return t.wait_0(e),N}.bind(null,this));for(s=l.iterator();s.hasNext();)u(s.next());var c,h,_=this.componentManager.getSingletonEntity_9u06oy$(p(O_));if(null==(h=null==(c=_.componentManager.getComponents_ahlfl2$(_).get_11rb$(p(O_)))||e.isType(c,O_)?c:C()))throw S("Component "+p(O_).simpleName+" is not found");var f,d=h.obsolete,m=A("remove",function(t,e){return t.remove_0(e),N}.bind(null,this));for(f=d.iterator();f.hasNext();)m(f.next());var y,$,v=this.componentManager.getSingletonEntity_9u06oy$(p(j_));if(null==($=null==(y=v.componentManager.getComponents_ahlfl2$(v).get_11rb$(p(j_)))||e.isType(y,j_)?y:C()))throw S("Component "+p(j_).simpleName+" is not found");var b,w=$.keys_8be2vx$(),x=A("accept",function(t,e){return t.accept_0(e),N}.bind(null,this));for(b=w.iterator();b.hasNext();)x(b.next());var k,E,T=this.componentManager.getSingletonEntity_9u06oy$(p(L_));if(null==(E=null==(k=T.componentManager.getComponents_ahlfl2$(T).get_11rb$(p(L_)))||e.isType(k,L_)?k:C()))throw S("Component "+p(L_).simpleName+" is not found");var O=E;for(O.keys().clear(),i=this.checkReadyRegions_0().iterator();i.hasNext();){var P=i.next();O.keys().add_11rb$(P),this.renderRegion_0(P)}},X_.prototype.renderRegion_0=function(t){var n,i,r=this.myRegionIndex_0.find_61zpoe$(t),o=this.componentManager.getSingletonEntity_9u06oy$(p(x_));if(null==(i=null==(n=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(x_)))||e.isType(n,x_)?n:C()))throw S("Component "+p(x_).simpleName+" is not found");var a,l,u=i;if(null==(l=null==(a=r.componentManager.getComponents_ahlfl2$(r).get_11rb$(p(A_)))||e.isType(a,A_)?a:C()))throw S("Component "+p(A_).simpleName+" is not found");var c,h=s(this.myPendingFragments_0.get_11rb$(t)).readyFragments(),_=A("get",function(t,e){return t.get_n5xzzq$(e)}.bind(null,u)),f=w();for(c=h.iterator();c.hasNext();){var d;null!=(d=_(c.next()))&&f.add_11rb$(d)}l.fragments=f,kc().tagDirtyParentLayer_ahlfl2$(r)},X_.prototype.wait_0=function(t){if(this.myPendingZoom_0===af().zoom_x1fgxf$(t)){var e,n=this.myPendingFragments_0,i=t.regionId,r=n.get_11rb$(i);if(null==r){var o=new Z_;n.put_xwzc9p$(i,o),e=o}else e=r;e.waitFragment_n5xzzq$(t)}},X_.prototype.accept_0=function(t){var e;this.myPendingZoom_0===af().zoom_x1fgxf$(t)&&null!=(e=this.myPendingFragments_0.get_11rb$(t.regionId))&&e.accept_n5xzzq$(t)},X_.prototype.remove_0=function(t){var e;this.myPendingZoom_0===af().zoom_x1fgxf$(t)&&null!=(e=this.myPendingFragments_0.get_11rb$(t.regionId))&&e.remove_n5xzzq$(t)},X_.prototype.checkReadyRegions_0=function(){var t,e=w();for(t=this.myPendingFragments_0.entries.iterator();t.hasNext();){var n=t.next(),i=n.key;n.value.checkDone()&&e.add_11rb$(i)}return e},Z_.prototype.waitFragment_n5xzzq$=function(t){this.myWaitingFragments_0.add_11rb$(t),this.myIsDone_0=!1},Z_.prototype.accept_n5xzzq$=function(t){this.myReadyFragments_0.add_11rb$(t),this.remove_n5xzzq$(t)},Z_.prototype.remove_n5xzzq$=function(t){this.myWaitingFragments_0.remove_11rb$(t),this.myWaitingFragments_0.isEmpty()&&(this.myIsDone_0=!0)},Z_.prototype.checkDone=function(){return!!this.myIsDone_0&&(this.myIsDone_0=!1,!0)},Z_.prototype.readyFragments=function(){return this.myReadyFragments_0},Z_.$metadata$={kind:c,simpleName:"PendingFragments",interfaces:[]},X_.$metadata$={kind:c,simpleName:"RegionEmitSystem",interfaces:[Bs]},J_.prototype.entityName_n5xzzq$=function(t){return this.entityName_cwu9hm$(t.regionId,t.quadKey)},J_.prototype.entityName_cwu9hm$=function(t,e){return"fragment_"+t+"_"+e.key},J_.prototype.zoom_x1fgxf$=function(t){return Fn(t.quadKey)},Q_.prototype.find_61zpoe$=function(t){var n,i,r;if(this.myRegionIndex_0.containsKey_11rb$(t)){var o;if(i=this.myComponentManager_0,null==(n=this.myRegionIndex_0.get_11rb$(t)))throw S("".toString());return o=n,i.getEntityById_za3lpa$(o)}for(r=this.myComponentManager_0.getEntities_9u06oy$(p(zp)).iterator();r.hasNext();){var a,s,l=r.next();if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(zp)))||e.isType(a,zp)?a:C()))throw S("Component "+p(zp).simpleName+" is not found");if(Bt(s.regionId,t))return this.myRegionIndex_0.put_xwzc9p$(t,l.id_8be2vx$),l}throw S("".toString())},Q_.$metadata$={kind:c,simpleName:"RegionsIndex",interfaces:[]},tf.prototype.exclude_8tsrz2$=function(t){return this.myValues_0.removeAll_brywnq$(t),this},tf.prototype.get=function(){return this.myValues_0},ef.prototype.ofCopy_j9syn5$=function(t){return new tf(Hn(t))},ef.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var nf=null;function rf(){return null===nf&&new ef,nf}tf.$metadata$={kind:c,simpleName:"SetBuilder",interfaces:[]},J_.$metadata$={kind:b,simpleName:"Utils",interfaces:[]};var of=null;function af(){return null===of&&new J_,of}function sf(t){this.renderer=t}function lf(){this.myEntities_0=pe()}function uf(){this.shape=0}function cf(){this.textSpec_43kqrj$_0=this.textSpec_43kqrj$_0}function pf(){this.radius=0,this.startAngle=0,this.endAngle=0}function hf(){this.fillColor=null,this.strokeColor=null,this.strokeWidth=0,this.lineDash=null}function _f(t,e){t.lineDash=bt(e)}function ff(t,e){t.fillColor=e}function df(t,e){t.strokeColor=e}function mf(t,e){t.strokeWidth=e}function yf(t,e){t.moveTo_lu1900$(e.x,e.y)}function $f(t,e){t.lineTo_lu1900$(e.x,e.y)}function vf(t,e){t.translate_lu1900$(e.x,e.y)}function gf(t){Cf(),Bs.call(this,t)}function bf(t){var n;if(t.contains_9u06oy$(p(Gh))){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Gh)))||e.isType(i,Gh)?i:C()))throw S("Component "+p(Gh).simpleName+" is not found");n=r}else n=null;return null!=n}function wf(t,e){this.closure$renderer=t,this.closure$layerEntity=e}function xf(t,n,i,r){return function(o){var a,s;if(o.save(),null!=t){var l=t;vf(o,l.scaleOrigin),o.scale_lu1900$(l.currentScale,l.currentScale),vf(o,Vn(l.scaleOrigin)),s=l}else s=null;for(null!=s||o.scale_lu1900$(1,1),a=y(i.getLayerEntities_0(n),bf).iterator();a.hasNext();){var u,c,h=a.next();if(null==(c=null==(u=h.componentManager.getComponents_ahlfl2$(h).get_11rb$(p(sf)))||e.isType(u,sf)?u:C()))throw S("Component "+p(sf).simpleName+" is not found");var _,f,d,m=c.renderer;if(null==(f=null==(_=h.componentManager.getComponents_ahlfl2$(h).get_11rb$(p(Gh)))||e.isType(_,Gh)?_:C()))throw S("Component "+p(Gh).simpleName+" is not found");for(d=f.origins.iterator();d.hasNext();){var $=d.next();r.mapRenderContext.draw_5xkfq8$(o,$,new wf(m,h))}}return o.restore(),N}}function kf(){Ef=this,this.DIRTY_LAYERS_0=x([p(fc),p(lf),p(mc)])}sf.$metadata$={kind:c,simpleName:"RendererComponent",interfaces:[Ys]},Object.defineProperty(lf.prototype,"entities",{configurable:!0,get:function(){return this.myEntities_0}}),lf.prototype.add_za3lpa$=function(t){this.myEntities_0.add_11rb$(t)},lf.prototype.remove_za3lpa$=function(t){this.myEntities_0.remove_11rb$(t)},lf.$metadata$={kind:c,simpleName:"LayerEntitiesComponent",interfaces:[Ys]},uf.$metadata$={kind:c,simpleName:"ShapeComponent",interfaces:[Ys]},Object.defineProperty(cf.prototype,"textSpec",{configurable:!0,get:function(){return null==this.textSpec_43kqrj$_0?T("textSpec"):this.textSpec_43kqrj$_0},set:function(t){this.textSpec_43kqrj$_0=t}}),cf.$metadata$={kind:c,simpleName:"TextSpecComponent",interfaces:[Ys]},pf.$metadata$={kind:c,simpleName:"PieSectorComponent",interfaces:[Ys]},hf.$metadata$={kind:c,simpleName:"StyleComponent",interfaces:[Ys]},wf.prototype.render_pzzegf$=function(t){this.closure$renderer.render_j83es7$(this.closure$layerEntity,t)},wf.$metadata$={kind:c,interfaces:[pp]},gf.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o=this.componentManager.getSingletonEntity_9u06oy$(p(ko));if(o.contains_9u06oy$(p(yo))){var a,s;if(null==(s=null==(a=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(yo)))||e.isType(a,yo)?a:C()))throw S("Component "+p(yo).simpleName+" is not found");r=s}else r=null;var l=r;for(i=this.getEntities_38uplf$(Cf().DIRTY_LAYERS_0).iterator();i.hasNext();){var u,c,h=i.next();if(null==(c=null==(u=h.componentManager.getComponents_ahlfl2$(h).get_11rb$(p(mc)))||e.isType(u,mc)?u:C()))throw S("Component "+p(mc).simpleName+" is not found");c.canvasLayer.addRenderTask_ddf932$(xf(l,h,this,t))}},gf.prototype.getLayerEntities_0=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(lf)))||e.isType(n,lf)?n:C()))throw S("Component "+p(lf).simpleName+" is not found");return this.getEntitiesById_wlb8mv$(i.entities)},kf.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ef=null;function Cf(){return null===Ef&&new kf,Ef}function Sf(){}function Tf(){zf=this}function Of(){}function Nf(){}function Pf(){}function Af(t){return t.stroke(),N}function jf(){}function Lf(){}function Rf(){}function If(){}gf.$metadata$={kind:c,simpleName:"EntitiesRenderingTaskSystem",interfaces:[Bs]},Sf.$metadata$={kind:v,simpleName:"Renderer",interfaces:[]},Tf.prototype.drawLines_8zv1en$=function(t,e,n){var i,r;for(i=t.iterator();i.hasNext();)for(r=i.next().iterator();r.hasNext();){var o,a=r.next();for(yf(e,a.get_za3lpa$(0)),o=Kn(a,1).iterator();o.hasNext();)$f(e,o.next())}n(e)},Of.prototype.renderFeature_0=function(t,e,n,i){e.translate_lu1900$(n,n),e.beginPath(),Ff().drawPath_iz58c6$(e,n,i),null!=t.fillColor&&(e.setFillStyle_2160e9$(t.fillColor),e.fill()),null==t.strokeColor||hn(t.strokeWidth)||(e.setStrokeStyle_2160e9$(t.strokeColor),e.setLineWidth_14dthe$(t.strokeWidth),e.stroke())},Of.prototype.render_j83es7$=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Zh)))||e.isType(i,Zh)?i:C()))throw S("Component "+p(Zh).simpleName+" is not found");var o,a,s,l=r.dimension.x/2;if(t.contains_9u06oy$(p(hc))){var u,c;if(null==(c=null==(u=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hc)))||e.isType(u,hc)?u:C()))throw S("Component "+p(hc).simpleName+" is not found");s=c}else s=null;var h,_,f,d,m=l*(null!=(a=null!=(o=s)?o.scale:null)?a:1);if(n.translate_lu1900$(-m,-m),null==(_=null==(h=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(h,hf)?h:C()))throw S("Component "+p(hf).simpleName+" is not found");if(null==(d=null==(f=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(uf)))||e.isType(f,uf)?f:C()))throw S("Component "+p(uf).simpleName+" is not found");this.renderFeature_0(_,n,m,d.shape)},Of.$metadata$={kind:c,simpleName:"PointRenderer",interfaces:[Sf]},Nf.prototype.render_j83es7$=function(t,n){if(t.contains_9u06oy$(p(Ch))){if(n.save(),t.contains_9u06oy$(p(qf))){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(qf)))||e.isType(i,qf)?i:C()))throw S("Component "+p(qf).simpleName+" is not found");var o=r.scale;1!==o&&n.scale_lu1900$(o,o)}var a,s;if(null==(s=null==(a=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(a,hf)?a:C()))throw S("Component "+p(hf).simpleName+" is not found");var l=s;n.setLineJoin_v2gigt$(Wn.ROUND),n.beginPath();var u,c,h=Df();if(null==(c=null==(u=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Ch)))||e.isType(u,Ch)?u:C()))throw S("Component "+p(Ch).simpleName+" is not found");h.drawLines_8zv1en$(c.geometry,n,(_=l,function(t){return t.closePath(),null!=_.fillColor&&(t.setFillStyle_2160e9$(_.fillColor),t.fill()),null!=_.strokeColor&&0!==_.strokeWidth&&(t.setStrokeStyle_2160e9$(_.strokeColor),t.setLineWidth_14dthe$(_.strokeWidth),t.stroke()),N})),n.restore()}var _},Nf.$metadata$={kind:c,simpleName:"PolygonRenderer",interfaces:[Sf]},Pf.prototype.render_j83es7$=function(t,n){if(t.contains_9u06oy$(p(Ch))){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(i,hf)?i:C()))throw S("Component "+p(hf).simpleName+" is not found");var o=r;n.setLineDash_gf7tl1$(s(o.lineDash)),n.setStrokeStyle_2160e9$(o.strokeColor),n.setLineWidth_14dthe$(o.strokeWidth),n.beginPath();var a,l,u=Df();if(null==(l=null==(a=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Ch)))||e.isType(a,Ch)?a:C()))throw S("Component "+p(Ch).simpleName+" is not found");u.drawLines_8zv1en$(l.geometry,n,Af)}},Pf.$metadata$={kind:c,simpleName:"PathRenderer",interfaces:[Sf]},jf.prototype.render_j83es7$=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(i,hf)?i:C()))throw S("Component "+p(hf).simpleName+" is not found");var o,a,s=r;if(null==(a=null==(o=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Zh)))||e.isType(o,Zh)?o:C()))throw S("Component "+p(Zh).simpleName+" is not found");var l=a.dimension;null!=s.fillColor&&(n.setFillStyle_2160e9$(s.fillColor),n.fillRect_6y0v78$(0,0,l.x,l.y)),null!=s.strokeColor&&0!==s.strokeWidth&&(n.setStrokeStyle_2160e9$(s.strokeColor),n.setLineWidth_14dthe$(s.strokeWidth),n.strokeRect_6y0v78$(0,0,l.x,l.y))},jf.$metadata$={kind:c,simpleName:"BarRenderer",interfaces:[Sf]},Lf.prototype.render_j83es7$=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(i,hf)?i:C()))throw S("Component "+p(hf).simpleName+" is not found");var o,a,s=r;if(null==(a=null==(o=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(pf)))||e.isType(o,pf)?o:C()))throw S("Component "+p(pf).simpleName+" is not found");var l=a;null!=s.strokeColor&&s.strokeWidth>0&&(n.setStrokeStyle_2160e9$(s.strokeColor),n.setLineWidth_14dthe$(s.strokeWidth),n.beginPath(),n.arc_6p3vsx$(0,0,l.radius+s.strokeWidth/2,l.startAngle,l.endAngle),n.stroke()),null!=s.fillColor&&(n.setFillStyle_2160e9$(s.fillColor),n.beginPath(),n.moveTo_lu1900$(0,0),n.arc_6p3vsx$(0,0,l.radius,l.startAngle,l.endAngle),n.fill())},Lf.$metadata$={kind:c,simpleName:"PieSectorRenderer",interfaces:[Sf]},Rf.prototype.render_j83es7$=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(i,hf)?i:C()))throw S("Component "+p(hf).simpleName+" is not found");var o,a,s=r;if(null==(a=null==(o=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(pf)))||e.isType(o,pf)?o:C()))throw S("Component "+p(pf).simpleName+" is not found");var l=a,u=.55*l.radius,c=Z.floor(u);if(null!=s.strokeColor&&s.strokeWidth>0){n.setStrokeStyle_2160e9$(s.strokeColor),n.setLineWidth_14dthe$(s.strokeWidth),n.beginPath();var h=c-s.strokeWidth/2;n.arc_6p3vsx$(0,0,Z.max(0,h),l.startAngle,l.endAngle),n.stroke(),n.beginPath(),n.arc_6p3vsx$(0,0,l.radius+s.strokeWidth/2,l.startAngle,l.endAngle),n.stroke()}null!=s.fillColor&&(n.setFillStyle_2160e9$(s.fillColor),n.beginPath(),n.arc_6p3vsx$(0,0,c,l.startAngle,l.endAngle),n.arc_6p3vsx$(0,0,l.radius,l.endAngle,l.startAngle,!0),n.fill())},Rf.$metadata$={kind:c,simpleName:"DonutSectorRenderer",interfaces:[Sf]},If.prototype.render_j83es7$=function(t,n){var i,r;if(null==(r=null==(i=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(i,hf)?i:C()))throw S("Component "+p(hf).simpleName+" is not found");var o,a,s=r;if(null==(a=null==(o=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(cf)))||e.isType(o,cf)?o:C()))throw S("Component "+p(cf).simpleName+" is not found");var l=a.textSpec;n.save(),n.rotate_14dthe$(l.angle),n.setFont_ov8mpe$(l.font),n.setFillStyle_2160e9$(s.fillColor),n.fillText_ai6r6m$(l.label,l.alignment.x,l.alignment.y),n.restore()},If.$metadata$={kind:c,simpleName:"TextRenderer",interfaces:[Sf]},Tf.$metadata$={kind:b,simpleName:"Renderers",interfaces:[]};var zf=null;function Df(){return null===zf&&new Tf,zf}function Mf(t,e,n,i,r,o,a,s){this.label=t,this.font=new le(j.CssStyleUtil.extractFontStyle_pdl1vz$(e),j.CssStyleUtil.extractFontWeight_pdl1vz$(e),n,i),this.dimension=null,this.alignment=null,this.angle=Qe(-r);var l=s.measure_2qe7uk$(this.label,this.font);this.alignment=H(-l.x*o,l.y*a),this.dimension=this.rotateTextSize_0(l.mul_14dthe$(2),this.angle)}function Bf(){Uf=this}Mf.prototype.rotateTextSize_0=function(t,e){var n=new E(t.x/2,+t.y/2).rotate_14dthe$(e),i=new E(t.x/2,-t.y/2).rotate_14dthe$(e),r=n.x,o=Z.abs(r),a=i.x,s=Z.abs(a),l=Z.max(o,s),u=n.y,c=Z.abs(u),p=i.y,h=Z.abs(p),_=Z.max(c,h);return H(2*l,2*_)},Mf.$metadata$={kind:c,simpleName:"TextSpec",interfaces:[]},Bf.prototype.apply_rxdkm1$=function(t,e){e.setFillStyle_2160e9$(t.fillColor),e.setStrokeStyle_2160e9$(t.strokeColor),e.setLineWidth_14dthe$(t.strokeWidth)},Bf.prototype.drawPath_iz58c6$=function(t,e,n){switch(n){case 0:this.square_mics58$(t,e);break;case 1:this.circle_mics58$(t,e);break;case 2:this.triangleUp_mics58$(t,e);break;case 3:this.plus_mics58$(t,e);break;case 4:this.cross_mics58$(t,e);break;case 5:this.diamond_mics58$(t,e);break;case 6:this.triangleDown_mics58$(t,e);break;case 7:this.square_mics58$(t,e),this.cross_mics58$(t,e);break;case 8:this.plus_mics58$(t,e),this.cross_mics58$(t,e);break;case 9:this.diamond_mics58$(t,e),this.plus_mics58$(t,e);break;case 10:this.circle_mics58$(t,e),this.plus_mics58$(t,e);break;case 11:this.triangleUp_mics58$(t,e),this.triangleDown_mics58$(t,e);break;case 12:this.square_mics58$(t,e),this.plus_mics58$(t,e);break;case 13:this.circle_mics58$(t,e),this.cross_mics58$(t,e);break;case 14:this.squareTriangle_mics58$(t,e);break;case 15:this.square_mics58$(t,e);break;case 16:this.circle_mics58$(t,e);break;case 17:this.triangleUp_mics58$(t,e);break;case 18:this.diamond_mics58$(t,e);break;case 19:case 20:case 21:this.circle_mics58$(t,e);break;case 22:this.square_mics58$(t,e);break;case 23:this.diamond_mics58$(t,e);break;case 24:this.triangleUp_mics58$(t,e);break;case 25:this.triangleDown_mics58$(t,e);break;default:throw S("Unknown point shape")}},Bf.prototype.circle_mics58$=function(t,e){t.arc_6p3vsx$(0,0,e,0,2*wt.PI)},Bf.prototype.square_mics58$=function(t,e){t.moveTo_lu1900$(-e,-e),t.lineTo_lu1900$(e,-e),t.lineTo_lu1900$(e,e),t.lineTo_lu1900$(-e,e),t.lineTo_lu1900$(-e,-e)},Bf.prototype.squareTriangle_mics58$=function(t,e){t.moveTo_lu1900$(-e,e),t.lineTo_lu1900$(0,-e),t.lineTo_lu1900$(e,e),t.lineTo_lu1900$(-e,e),t.lineTo_lu1900$(-e,-e),t.lineTo_lu1900$(e,-e),t.lineTo_lu1900$(e,e)},Bf.prototype.triangleUp_mics58$=function(t,e){var n=3*e/Z.sqrt(3);t.moveTo_lu1900$(0,-e),t.lineTo_lu1900$(n/2,e/2),t.lineTo_lu1900$(-n/2,e/2),t.lineTo_lu1900$(0,-e)},Bf.prototype.triangleDown_mics58$=function(t,e){var n=3*e/Z.sqrt(3);t.moveTo_lu1900$(0,e),t.lineTo_lu1900$(-n/2,-e/2),t.lineTo_lu1900$(n/2,-e/2),t.lineTo_lu1900$(0,e)},Bf.prototype.plus_mics58$=function(t,e){t.moveTo_lu1900$(0,-e),t.lineTo_lu1900$(0,e),t.moveTo_lu1900$(-e,0),t.lineTo_lu1900$(e,0)},Bf.prototype.cross_mics58$=function(t,e){t.moveTo_lu1900$(-e,-e),t.lineTo_lu1900$(e,e),t.moveTo_lu1900$(-e,e),t.lineTo_lu1900$(e,-e)},Bf.prototype.diamond_mics58$=function(t,e){t.moveTo_lu1900$(0,-e),t.lineTo_lu1900$(e,0),t.lineTo_lu1900$(0,e),t.lineTo_lu1900$(-e,0),t.lineTo_lu1900$(0,-e)},Bf.$metadata$={kind:b,simpleName:"Utils",interfaces:[]};var Uf=null;function Ff(){return null===Uf&&new Bf,Uf}function qf(){this.scale=1,this.zoom=0}function Gf(t){Kf(),Bs.call(this,t)}function Hf(){Vf=this,this.COMPONENT_TYPES_0=x([p(bo),p(qf)])}qf.$metadata$={kind:c,simpleName:"ScaleComponent",interfaces:[Ys]},Gf.prototype.updateImpl_og8vrq$=function(t,n){var i;if(po(t.camera))for(i=this.getEntities_38uplf$(Kf().COMPONENT_TYPES_0).iterator();i.hasNext();){var r,o,a=i.next();if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(qf)))||e.isType(r,qf)?r:C()))throw S("Component "+p(qf).simpleName+" is not found");var s=o,l=t.camera.zoom-s.zoom,u=Z.pow(2,l);s.scale=u}},Hf.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Yf,Vf=null;function Kf(){return null===Vf&&new Hf,Vf}function Wf(){}function Xf(t,e){this.layerIndex=t,this.index=e}function Zf(t){this.locatorHelper=t}Gf.$metadata$={kind:c,simpleName:"ScaleUpdateSystem",interfaces:[Bs]},Wf.prototype.getColor_ahlfl2$=function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(hf)))||e.isType(n,hf)?n:C()))throw S("Component "+p(hf).simpleName+" is not found");return i.fillColor},Wf.prototype.isCoordinateInTarget_29hhdz$=function(t,n){var i,r;if(null==(r=null==(i=n.componentManager.getComponents_ahlfl2$(n).get_11rb$(p(Zh)))||e.isType(i,Zh)?i:C()))throw S("Component "+p(Zh).simpleName+" is not found");var o,a,s,l=r.dimension;if(null==(a=null==(o=n.componentManager.getComponents_ahlfl2$(n).get_11rb$(p(Gh)))||e.isType(o,Gh)?o:C()))throw S("Component "+p(Gh).simpleName+" is not found");for(s=a.origins.iterator();s.hasNext();){var u=s.next();if(Xn(new zt(u,l),t))return!0}return!1},Wf.$metadata$={kind:c,simpleName:"BarLocatorHelper",interfaces:[nd]},Xf.$metadata$={kind:c,simpleName:"IndexComponent",interfaces:[Ys]},Zf.$metadata$={kind:c,simpleName:"LocatorComponent",interfaces:[Ys]};var Jf=Le((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(i),r(n))}}}));function Qf(){this.searchResult=null,this.zoom=null,this.cursotPosition=null}function td(t){Bs.call(this,t)}function ed(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Xf)))||e.isType(n,Xf)?n:C()))throw S("Component "+p(Xf).simpleName+" is not found");return i.layerIndex}function nd(){}function id(){rd=this}Qf.$metadata$={kind:c,simpleName:"HoverObjectComponent",interfaces:[Ys]},td.prototype.initImpl_4pvjek$=function(t){Bs.prototype.initImpl_4pvjek$.call(this,t),this.createEntity_61zpoe$("hover_object").add_57nep2$(new Qf).add_57nep2$(new wl)},td.prototype.updateImpl_og8vrq$=function(t,n){var i,r,o,a,s,l,u=this.componentManager.getSingletonEntity_9u06oy$(p(Qf));if(null==(l=null==(s=u.componentManager.getComponents_ahlfl2$(u).get_11rb$(p(wl)))||e.isType(s,wl)?s:C()))throw S("Component "+p(wl).simpleName+" is not found");var c,h=l;if(null!=(r=null!=(i=h.location)?Zn(i.x,i.y):null)){var _,f,d=r;if(null==(f=null==(_=u.componentManager.getComponents_ahlfl2$(u).get_11rb$(p(Qf)))||e.isType(_,Qf)?_:C()))throw S("Component "+p(Qf).simpleName+" is not found");var m=f;if(t.camera.isZoomChanged&&!po(t.camera))return m.cursotPosition=null,m.zoom=null,void(m.searchResult=null);if(!Bt(m.cursotPosition,d)||t.camera.zoom!==(null!=(a=null!=(o=m.zoom)?o:null)?a:kt.NaN))if(null==h.dragDistance){var $,v;if(m.cursotPosition=d,m.zoom=g(t.camera.zoom),null!=($=Fe(Jn(y(this.getEntities_38uplf$(Yf),(c=d,function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Zf)))||e.isType(n,Zf)?n:C()))throw S("Component "+p(Zf).simpleName+" is not found");return i.locatorHelper.isCoordinateInTarget_29hhdz$(c,t)})),new Re(Jf(ed)))))){var b,w;if(null==(w=null==(b=$.componentManager.getComponents_ahlfl2$($).get_11rb$(p(Xf)))||e.isType(b,Xf)?b:C()))throw S("Component "+p(Xf).simpleName+" is not found");var x,k,E=w.layerIndex;if(null==(k=null==(x=$.componentManager.getComponents_ahlfl2$($).get_11rb$(p(Xf)))||e.isType(x,Xf)?x:C()))throw S("Component "+p(Xf).simpleName+" is not found");var T,O,N=k.index;if(null==(O=null==(T=$.componentManager.getComponents_ahlfl2$($).get_11rb$(p(Zf)))||e.isType(T,Zf)?T:C()))throw S("Component "+p(Zf).simpleName+" is not found");v=new wd(E,N,O.locatorHelper.getColor_ahlfl2$($))}else v=null;m.searchResult=v}else m.cursotPosition=d}},td.$metadata$={kind:c,simpleName:"HoverObjectDetectionSystem",interfaces:[Bs]},nd.$metadata$={kind:v,simpleName:"LocatorHelper",interfaces:[]},id.prototype.calculateAngle_2d1svq$=function(t,e){var n=e.x-t.x,i=e.y-t.y;return Z.atan2(i,n)},id.prototype.distance_2d1svq$=function(t,e){var n=t.x-e.x,i=Z.pow(n,2),r=t.y-e.y,o=i+Z.pow(r,2);return Z.sqrt(o)},id.prototype.coordInExtendedRect_3tn9i8$=function(t,e,n){var i=Xn(e,t);if(!i){var r=t.x-Rt(e);i=Z.abs(r)<=n}var o=i;if(!o){var a=t.x-Ht(e);o=Z.abs(a)<=n}var s=o;if(!s){var l=t.y-Yt(e);s=Z.abs(l)<=n}var u=s;if(!u){var c=t.y-Dt(e);u=Z.abs(c)<=n}return u},id.prototype.pathContainsCoordinate_ya4zfl$=function(t,e,n){var i;i=e.size-1|0;for(var r=0;r=s?this.calculateSquareDistanceToPathPoint_0(t,e,i):this.calculateSquareDistanceToPathPoint_0(t,e,n)-l},id.prototype.calculateSquareDistanceToPathPoint_0=function(t,e,n){var i=t.x-e.get_za3lpa$(n).x,r=t.y-e.get_za3lpa$(n).y;return i*i+r*r},id.prototype.ringContainsCoordinate_bsqkoz$=function(t,e){var n,i=0;n=t.size;for(var r=1;r=e.y&&t.get_za3lpa$(r).y>=e.y||t.get_za3lpa$(o).yn.radius)return!1;var i=od().calculateAngle_2d1svq$(e,t);return i<-wt.PI/2&&(i+=2*wt.PI),n.startAngle<=i&&ithis.myTileCacheLimit_0;)g.add_11rb$(this.myCache_0.removeAt_za3lpa$(0));this.removeCells_0(g)},nm.prototype.removeCells_0=function(t){var n,i=Ft(this.getEntities_9u06oy$(p(lf)));for(n=y(this.getEntities_9u06oy$(p(ha)),function(t){return function(n){var i,r,o=t;if(null==(r=null==(i=n.componentManager.getComponents_ahlfl2$(n).get_11rb$(p(ha)))||e.isType(i,ha)?i:C()))throw S("Component "+p(ha).simpleName+" is not found");return o.contains_11rb$(r.cellKey)}}(t)).iterator();n.hasNext();){var r,o=n.next();for(r=i.iterator();r.hasNext();){var a,s,l=r.next();if(null==(s=null==(a=l.componentManager.getComponents_ahlfl2$(l).get_11rb$(p(lf)))||e.isType(a,lf)?a:C()))throw S("Component "+p(lf).simpleName+" is not found");s.remove_za3lpa$(o.id_8be2vx$)}o.remove()}},nm.$metadata$={kind:c,simpleName:"TileRemovingSystem",interfaces:[Bs]},Object.defineProperty(im.prototype,"myCellRect_0",{configurable:!0,get:function(){return null==this.myCellRect_cbttp2$_0?T("myCellRect"):this.myCellRect_cbttp2$_0},set:function(t){this.myCellRect_cbttp2$_0=t}}),Object.defineProperty(im.prototype,"myCtx_0",{configurable:!0,get:function(){return null==this.myCtx_uwiahv$_0?T("myCtx"):this.myCtx_uwiahv$_0},set:function(t){this.myCtx_uwiahv$_0=t}}),im.prototype.render_j83es7$=function(t,n){var i,r,o;if(null==(o=null==(r=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Gd)))||e.isType(r,Gd)?r:C()))throw S("Component "+p(Gd).simpleName+" is not found");if(null!=(i=o.tile)){var a,s,l=i;if(null==(s=null==(a=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Zh)))||e.isType(a,Zh)?a:C()))throw S("Component "+p(Zh).simpleName+" is not found");var u=s.dimension;this.render_k86o6i$(l,new zt(f_().ZERO_CLIENT_POINT,u),n)}},im.prototype.render_k86o6i$=function(t,e,n){this.myCellRect_0=e,this.myCtx_0=n,this.renderTile_0(t,new Wt(""),new Wt(""))},im.prototype.renderTile_0=function(t,n,i){if(e.isType(t,Wd))this.renderSnapshotTile_0(t,n,i);else if(e.isType(t,Xd))this.renderSubTile_0(t,n,i);else if(e.isType(t,Zd))this.renderCompositeTile_0(t,n,i);else if(!e.isType(t,Jd))throw S(("Unsupported Tile class: "+p(Kd)).toString())},im.prototype.renderSubTile_0=function(t,e,n){this.renderTile_0(t.tile,t.subKey.plus_vnxxg4$(e),n)},im.prototype.renderCompositeTile_0=function(t,e,n){var i;for(i=t.tiles.iterator();i.hasNext();){var r=i.next(),o=r.component1(),a=r.component2();this.renderTile_0(o,e,n.plus_vnxxg4$(a))}},im.prototype.renderSnapshotTile_0=function(t,e,n){var i=li(e,this.myCellRect_0),r=li(n,this.myCellRect_0);this.myCtx_0.drawImage_urnjjc$(t.snapshot,Rt(i),Dt(i),It(i),Mt(i),Rt(r),Dt(r),It(r),Mt(r))},im.$metadata$={kind:c,simpleName:"TileRenderer",interfaces:[Sf]},Object.defineProperty(rm.prototype,"myMapRect_0",{configurable:!0,get:function(){return null==this.myMapRect_7veail$_0?T("myMapRect"):this.myMapRect_7veail$_0},set:function(t){this.myMapRect_7veail$_0=t}}),Object.defineProperty(rm.prototype,"myDonorTileCalculators_0",{configurable:!0,get:function(){return null==this.myDonorTileCalculators_o8thho$_0?T("myDonorTileCalculators"):this.myDonorTileCalculators_o8thho$_0},set:function(t){this.myDonorTileCalculators_o8thho$_0=t}}),rm.prototype.initImpl_4pvjek$=function(t){this.myMapRect_0=t.mapProjection.mapRect,Qs(this.createEntity_61zpoe$("tile_for_request"),om)},rm.prototype.updateImpl_og8vrq$=function(t,n){this.myDonorTileCalculators_0=this.createDonorTileCalculators_0();var i,r,o=this.componentManager.getSingletonEntity_9u06oy$(p(pa));if(null==(r=null==(i=o.componentManager.getComponents_ahlfl2$(o).get_11rb$(p(pa)))||e.isType(i,pa)?i:C()))throw S("Component "+p(pa).simpleName+" is not found");var a,s=Hn(r.requestCells);for(a=this.getEntities_9u06oy$(p(ha)).iterator();a.hasNext();){var l,u,c=a.next();if(null==(u=null==(l=c.componentManager.getComponents_ahlfl2$(c).get_11rb$(p(ha)))||e.isType(l,ha)?l:C()))throw S("Component "+p(ha).simpleName+" is not found");s.remove_11rb$(u.cellKey)}var h,_=A("createTileLayerEntities",function(t,e){return t.createTileLayerEntities_0(e),N}.bind(null,this));for(h=s.iterator();h.hasNext();)_(h.next());var f,d,m=this.componentManager.getSingletonEntity_9u06oy$(p(Hd));if(null==(d=null==(f=m.componentManager.getComponents_ahlfl2$(m).get_11rb$(p(Hd)))||e.isType(f,Hd)?f:C()))throw S("Component "+p(Hd).simpleName+" is not found");d.requestTiles=s},rm.prototype.createDonorTileCalculators_0=function(){var t,n,i=st();for(t=this.getEntities_38uplf$(py().TILE_COMPONENT_LIST).iterator();t.hasNext();){var r,o,a=t.next();if(null==(o=null==(r=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Gd)))||e.isType(r,Gd)?r:C()))throw S("Component "+p(Gd).simpleName+" is not found");if(!o.nonCacheable){var s,l;if(null==(l=null==(s=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(Gd)))||e.isType(s,Gd)?s:C()))throw S("Component "+p(Gd).simpleName+" is not found");if(null!=(n=l.tile)){var u,c,h=n;if(null==(c=null==(u=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(ba)))||e.isType(u,ba)?u:C()))throw S("Component "+p(ba).simpleName+" is not found");var _,f=c.layerKind,d=i.get_11rb$(f);if(null==d){var m=st();i.put_xwzc9p$(f,m),_=m}else _=d;var y,$,v=_;if(null==($=null==(y=a.componentManager.getComponents_ahlfl2$(a).get_11rb$(p(ha)))||e.isType(y,ha)?y:C()))throw S("Component "+p(ha).simpleName+" is not found");var g=$.cellKey;v.put_xwzc9p$(g,h)}}}var b,w=xn(bn(i.size));for(b=i.entries.iterator();b.hasNext();){var x=b.next(),k=w.put_xwzc9p$,E=x.key,T=x.value;k.call(w,E,new Yd(T))}return w},rm.prototype.createTileLayerEntities_0=function(t){var n,i=t.length,r=_e(t,this.myMapRect_0);for(n=this.getEntities_9u06oy$(p(_a)).iterator();n.hasNext();){var o,a,s=n.next();if(null==(a=null==(o=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(_a)))||e.isType(o,_a)?o:C()))throw S("Component "+p(_a).simpleName+" is not found");var l,u,c=a.layerKind,h=Qs(wr(this.componentManager,new yc(s.id_8be2vx$),"tile_"+c+"_"+t),am(r,i,this,t,c,s));if(null==(u=null==(l=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(lf)))||e.isType(l,lf)?l:C()))throw S("Component "+p(lf).simpleName+" is not found");u.add_za3lpa$(h.id_8be2vx$)}},rm.prototype.getRenderer_0=function(t){return t.contains_9u06oy$(p(fa))?new _y:new im},rm.prototype.calculateDonorTile_0=function(t,e){var n;return null!=(n=this.myDonorTileCalculators_0.get_11rb$(t))?n.createDonorTile_92p1wg$(e):null},rm.prototype.screenDimension_0=function(t){var e=new Zh;return t(e),e},rm.prototype.renderCache_0=function(t){var e=new Md;return t(e),e},rm.$metadata$={kind:c,simpleName:"TileRequestSystem",interfaces:[Bs]},sm.$metadata$={kind:v,simpleName:"TileSystemProvider",interfaces:[]},um.prototype.create_v8qzyl$=function(t){return new Em(Om(this.closure$black,this.closure$white),t)},Object.defineProperty(um.prototype,"isVector",{configurable:!0,get:function(){return this.isVector_6ju0ww$_0}}),um.$metadata$={kind:c,interfaces:[sm]},lm.prototype.chessboard_a87jzg$=function(t,e){return void 0===t&&(t=k.Companion.GRAY),void 0===e&&(e=k.Companion.LIGHT_GRAY),new um(t,e)},cm.prototype.create_v8qzyl$=function(t){return new Em(Tm(this.closure$color),t)},Object.defineProperty(cm.prototype,"isVector",{configurable:!0,get:function(){return this.isVector_vug5zv$_0}}),cm.$metadata$={kind:c,interfaces:[sm]},lm.prototype.solid_98b62m$=function(t){return new cm(t)},pm.prototype.create_v8qzyl$=function(t){return new dm(this.closure$domains,t)},Object.defineProperty(pm.prototype,"isVector",{configurable:!0,get:function(){return this.isVector_e34bo7$_0}}),pm.$metadata$={kind:c,interfaces:[sm]},lm.prototype.raster_mhpeer$=function(t){return new pm(t)},hm.prototype.create_v8qzyl$=function(t){return new ny(this.closure$quantumIterations,this.closure$tileService,t)},Object.defineProperty(hm.prototype,"isVector",{configurable:!0,get:function(){return this.isVector_5jtyhf$_0}}),hm.$metadata$={kind:c,interfaces:[sm]},lm.prototype.letsPlot_e94j16$=function(t,e){return void 0===e&&(e=1e3),new hm(e,t)},lm.$metadata$={kind:b,simpleName:"Tilesets",interfaces:[]};var _m=null;function fm(){}function dm(t,e){xm(),Bs.call(this,e),this.myDomains_0=t,this.myIndex_0=0,this.myTileTransport_0=new hi}function mm(t,e){return function(n){return n.unaryPlus_jixjl7$(new ha(t)),n.unaryPlus_jixjl7$(e),N}}function ym(t){return function(e){return t.imageData=e,N}}function $m(t){return function(e){return t.imageData=new Int8Array(0),t.errorCode=e,N}}function vm(t,n,i){return function(r){return i.runLaterBySystem_ayosff$(t,function(t,n){return function(i){var r,o;if(null==(o=null==(r=i.componentManager.getComponents_ahlfl2$(i).get_11rb$(p(Gd)))||e.isType(r,Gd)?r:C()))throw S("Component "+p(Gd).simpleName+" is not found");var a=t,s=n;return o.nonCacheable=null!=a.errorCode,o.tile=new Wd(s),kc().tagDirtyParentLayer_ahlfl2$(i),N}}(n,r)),N}}function gm(t,e,n,i,r){return function(){var o,a;if(null!=t.errorCode){var l=null!=(o=s(t.errorCode).message)?o:"Unknown error",u=e.mapRenderContext.canvasProvider.createCanvas_119tl4$(xm().TILE_PIXEL_DIMESION),c=u.context2d,p=c.measureText_61zpoe$(l),h=p0&&ta.v&&1!==s.size;)l.add_wxm5ur$(0,s.removeAt_za3lpa$(s.size-1|0));1===s.size&&t.measureText_61zpoe$(s.get_za3lpa$(0))>a.v?(u.add_11rb$(s.get_za3lpa$(0)),a.v=t.measureText_61zpoe$(s.get_za3lpa$(0))):u.add_11rb$(m(s," ")),s=l,l=w()}for(o=e.iterator();o.hasNext();){var p=o.next(),h=this.bboxFromPoint_0(p,a.v,c);if(!this.labelInBounds_0(h)){var _,f,d=0;for(_=u.iterator();_.hasNext();){var y=_.next(),$=h.origin.y+c/2+c*ot((d=(f=d)+1|0,f));t.strokeText_ai6r6m$(y,p.x,$),t.fillText_ai6r6m$(y,p.x,$)}this.myLabelBounds_0.add_11rb$(h)}}},jm.prototype.labelInBounds_0=function(t){var e,n=this.myLabelBounds_0;t:do{var i;for(i=n.iterator();i.hasNext();){var r=i.next();if(t.intersects_wthzt5$(r)){e=r;break t}}e=null}while(0);return null!=e},jm.prototype.getLabel_0=function(t){var e,n=null!=(e=this.myStyle_0.labelField)?e:Bm().LABEL_0;switch(n){case"short":return t.short;case"label":return t.label;default:throw S("Unknown label field: "+n)}},jm.prototype.applyTo_pzzegf$=function(t){var e,n;t.setFont_ov8mpe$(_i(null!=(e=this.myStyle_0.fontStyle)?j.CssStyleUtil.extractFontStyle_pdl1vz$(e):null,null!=(n=this.myStyle_0.fontStyle)?j.CssStyleUtil.extractFontWeight_pdl1vz$(n):null,this.myStyle_0.size,this.myStyle_0.fontFamily)),t.setTextAlign_iwro1z$(se.CENTER),t.setTextBaseline_5cz80h$(ae.MIDDLE),Bm().setBaseStyle_ocy23$(t,this.myStyle_0)},jm.$metadata$={kind:c,simpleName:"PointTextSymbolizer",interfaces:[Nm]},Lm.prototype.createDrawTasks_ldp3af$=function(t,e){return at()},Lm.prototype.applyTo_pzzegf$=function(t){},Lm.$metadata$={kind:c,simpleName:"ShieldTextSymbolizer",interfaces:[Nm]},Rm.prototype.createDrawTasks_ldp3af$=function(t,e){return at()},Rm.prototype.applyTo_pzzegf$=function(t){},Rm.$metadata$={kind:c,simpleName:"LineTextSymbolizer",interfaces:[Nm]},Im.prototype.create_h15n9n$=function(t,e){var n,i;switch(n=t.type){case"line":i=new Am(t);break;case"polygon":i=new Pm(t);break;case"point-text":i=new jm(t,e);break;case"shield-text":i=new Lm(t,e);break;case"line-text":i=new Rm(t,e);break;default:throw S(null==n?"Empty symbolizer type.".toString():"Unknown symbolizer type.".toString())}return i},Im.prototype.stringToLineCap_61zpoe$=function(t){var e;switch(t){case"butt":e=fi.BUTT;break;case"round":e=fi.ROUND;break;case"square":e=fi.SQUARE;break;default:throw S(("Unknown lineCap type: "+t).toString())}return e},Im.prototype.stringToLineJoin_61zpoe$=function(t){var e;switch(t){case"bevel":e=Wn.BEVEL;break;case"round":e=Wn.ROUND;break;case"miter":e=Wn.MITER;break;default:throw S(("Unknown lineJoin type: "+t).toString())}return e},Im.prototype.splitLabel_61zpoe$=function(t){var e,n,i,r,o=w(),a=0;n=(e=di(t)).first,i=e.last,r=e.step;for(var s=n;s<=i;s+=r)if(32===t.charCodeAt(s)){if(a!==s){var l=a;o.add_11rb$(t.substring(l,s))}a=s+1|0}else if(-1!==mi("-',.)!?",t.charCodeAt(s))){var u=a,c=s+1|0;o.add_11rb$(t.substring(u,c)),a=s+1|0}if(a!==t.length){var p=a;o.add_11rb$(t.substring(p))}return o},Im.prototype.setBaseStyle_ocy23$=function(t,e){var n,i,r;null!=(n=e.strokeWidth)&&A("setLineWidth",function(t,e){return t.setLineWidth_14dthe$(e),N}.bind(null,t))(n),null!=(i=e.fill)&&t.setFillStyle_2160e9$(i),null!=(r=e.stroke)&&t.setStrokeStyle_2160e9$(r)},Im.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var zm,Dm,Mm=null;function Bm(){return null===Mm&&new Im,Mm}function Um(){}function Fm(t,e){this.myMapProjection_0=t,this.myTileService_0=e}function qm(){}function Gm(t){this.myMapProjection_0=t}function Hm(t,e){return function(n){var i=t,r=e.name;return i.put_xwzc9p$(r,n),N}}function Ym(t,e,n){return function(i){t.add_11rb$(new Zm(i,gi(e.kinds,n),gi(e.subs,n),gi(e.labels,n),gi(e.shorts,n)))}}function Vm(t){this.closure$tileGeometryParser=t,this.myDone_0=!1}function Km(){}function Wm(t){this.myMapConfigSupplier_0=t}function Xm(t,e){return function(){return t.applyTo_pzzegf$(e),N}}function Zm(t,e,n,i,r){this.tileGeometry=t,this.myKind_0=e,this.mySub_0=n,this.label=i,this.short=r}function Jm(t,e,n){me.call(this),this.field=n,this.name$=t,this.ordinal$=e}function Qm(){Qm=function(){},zm=new Jm("CLASS",0,"class"),Dm=new Jm("SUB",1,"sub")}function ty(){return Qm(),zm}function ey(){return Qm(),Dm}function ny(t,e,n){py(),Bs.call(this,n),this.myQuantumIterations_0=t,this.myTileService_0=e,this.myMapRect_x008rn$_0=this.myMapRect_x008rn$_0,this.myCanvasSupplier_rjbwhf$_0=this.myCanvasSupplier_rjbwhf$_0,this.myTileDataFetcher_x9uzis$_0=this.myTileDataFetcher_x9uzis$_0,this.myTileDataParser_z2wh1i$_0=this.myTileDataParser_z2wh1i$_0,this.myTileDataRenderer_gwohqu$_0=this.myTileDataRenderer_gwohqu$_0}function iy(t,e){return function(n){return n.unaryPlus_jixjl7$(new ha(t)),n.unaryPlus_jixjl7$(e),n.unaryPlus_jixjl7$(new Ja),N}}function ry(t){return function(e){return t.tileData=e,N}}function oy(t){return function(e){return t.tileData=at(),N}}function ay(t,n){return function(i){return n.runLaterBySystem_ayosff$(t,(r=i,function(t){var n,i;if(null==(i=null==(n=t.componentManager.getComponents_ahlfl2$(t).get_11rb$(p(Gd)))||e.isType(n,Gd)?n:C()))throw S("Component "+p(Gd).simpleName+" is not found");return i.tile=new Wd(r),t.removeComponent_9u06oy$(p(Ja)),kc().tagDirtyParentLayer_ahlfl2$(t),N})),N;var r}}function sy(t,e){return function(n){n.onSuccess_qlkmfe$(ay(t,e))}}function ly(t,n,i){return function(r){var o,a=w();for(o=t.iterator();o.hasNext();){var s=o.next(),l=n,u=i;s.add_57nep2$(new Ja);var c,h,_=l.myTileDataRenderer_0,f=l.myCanvasSupplier_0();if(null==(h=null==(c=s.componentManager.getComponents_ahlfl2$(s).get_11rb$(p(ba)))||e.isType(c,ba)?c:C()))throw S("Component "+p(ba).simpleName+" is not found");a.add_11rb$(Al(_.render_qge02a$(f,r,u,h.layerKind),sy(s,l)))}return ql().join_asgahm$(a)}}function uy(){cy=this,this.CELL_COMPONENT_LIST=x([p(ha),p(ba)]),this.TILE_COMPONENT_LIST=x([p(ha),p(ba),p(Gd)])}Nm.$metadata$={kind:v,simpleName:"Symbolizer",interfaces:[]},Um.$metadata$={kind:v,simpleName:"TileDataFetcher",interfaces:[]},Fm.prototype.fetch_92p1wg$=function(t){var e=ca(this.myMapProjection_0,t),n=this.calculateBBox_0(e),i=t.length;return this.myTileService_0.getTileData_h9hod0$(n,i)},Fm.prototype.calculateBBox_0=function(t){var e,n=G.BBOX_CALCULATOR,i=rt(it(t,10));for(e=t.iterator();e.hasNext();){var r=e.next();i.add_11rb$(yi(qn(r)))}return $i(n,i)},Fm.$metadata$={kind:c,simpleName:"TileDataFetcherImpl",interfaces:[Um]},qm.$metadata$={kind:v,simpleName:"TileDataParser",interfaces:[]},Gm.prototype.parse_yeqvx5$=function(t,e){var n,i=this.calculateTransform_0(t),r=st(),o=rt(it(e,10));for(n=e.iterator();n.hasNext();){var a=n.next();o.add_11rb$(Al(this.parseTileLayer_0(a,i),Hm(r,a)))}var s,l=o;return Al(ql().join_asgahm$(l),(s=r,function(t){return s}))},Gm.prototype.calculateTransform_0=function(t){var e,n,i,r=new w_(t.length),o=_e(t,this.myMapProjection_0.mapRect),a=r.project_11rb$(o.origin);return e=r,n=this,i=a,function(t){return Ut(e.project_11rb$(n.myMapProjection_0.project_11rb$(t)),i)}},Gm.prototype.parseTileLayer_0=function(t,e){return jl(this.createMicroThread_0(new vi(t.geometryCollection)),(n=e,i=t,function(t){for(var e=w(),r=w(),o=t.size,a=0;a]*>[^<]*<\\/a>|[^<]*)"),this.linkRegex_0=ki('href="([^"]*)"[^>]*>([^<]*)<\\/a>')}function Oy(){this.default=Ny,this.pointer=Py}function Ny(){return N}function Py(){return N}function Ay(t,e,n,i,r){My(),Bs.call(this,e),this.myUiService_0=t,this.myMapLocationConsumer_0=n,this.myLayerManager_0=i,this.myAttribution_0=r,this.myLiveMapLocation_d7ahsw$_0=this.myLiveMapLocation_d7ahsw$_0,this.myZoomPlus_swwfsu$_0=this.myZoomPlus_swwfsu$_0,this.myZoomMinus_plmgvc$_0=this.myZoomMinus_plmgvc$_0,this.myGetCenter_3ls1ty$_0=this.myGetCenter_3ls1ty$_0,this.myMakeGeometry_kkepht$_0=this.myMakeGeometry_kkepht$_0,this.myViewport_aqqdmf$_0=this.myViewport_aqqdmf$_0,this.myButtonPlus_jafosd$_0=this.myButtonPlus_jafosd$_0,this.myButtonMinus_v7ijll$_0=this.myButtonMinus_v7ijll$_0,this.myDrawingGeometry_0=!1,this.myUiState_0=new Ry(this)}function jy(t){return function(){return Zy(t.href),N}}function Ly(){}function Ry(t){this.$outer=t,Ly.call(this)}function Iy(t){this.$outer=t,Ly.call(this)}function zy(){Dy=this,this.KEY_PLUS_0="img_plus",this.KEY_PLUS_DISABLED_0="img_plus_disable",this.KEY_MINUS_0="img_minus",this.KEY_MINUS_DISABLED_0="img_minus_disable",this.KEY_GET_CENTER_0="img_get_center",this.KEY_MAKE_GEOMETRY_0="img_create_geometry",this.KEY_MAKE_GEOMETRY_ACTIVE_0="img_create_geometry_active",this.BUTTON_PLUS_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAMAAADypuvZAAAAUVBMVEUAAADf39/f39/n5+fk5OTk5OTl5eXl5eXk5OTm5ubl5eXl5eXm5uYAAAAQEBAgICCfn5+goKDl5eXo6Oj29vb39/f4+Pj5+fn9/f3+/v7///8nQ8gkAAAADXRSTlMAECAgX2B/gL+/z9/fDLiFVAAAAKJJREFUeNrt1tEOwiAMheGi2xQ2KBzc3Hj/BxXv5K41MTHKf/+lCSRNichcLMS5gZ6dF6iaTxUtyPejSFszZkMjciXy9oyJHNaiaoMloOjaAT0qHXX0WRQDJzVi74Ma+drvoBj8S5xEiH1TEKHQIhahyM2g9I//1L4hq1HkkPqO6OgL0aFHFpvO3OBo0h9UA5kFeZWTLWN+80isjU5OrpMhegCRuP2dffXKGwAAAABJRU5ErkJggg==",this.BUTTON_MINUS_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAMAAADypuvZAAAAUVBMVEUAAADf39/f39/n5+fk5OTk5OTl5eXl5eXk5OTm5ubl5eXl5eXm5uYAAAAQEBAgICCfn5+goKDl5eXo6Oj29vb39/f4+Pj5+fn9/f3+/v7///8nQ8gkAAAADXRSTlMAECAgX2B/gL+/z9/fDLiFVAAAAI1JREFUeNrt1rEOwjAMRdEXaAtJ2qZ9JqHJ/38oYqObzYRQ7n5kS14MwN081YUB764zTcULgJnyrE1bFkaHkVKboUM4ITA3U4UeZLN1kHbUOuqoo19E27p8lHYVSsupVYXWM0q69dJp0N6P21FHf4OqHXkWm3kwYLI/VAPcTMl6UoTx2ycRGIOe3CcHvAAlagACEKjXQgAAAABJRU5ErkJggg==",this.BUTTON_MINUS_DISABLED_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAYAAADFeBvrAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAABYlAAAWJQFJUiTwAAAAB3RJTUUH4wYTDA80Pt7fQwAAAaRJREFUaN7t2jFqAkEUBuB/xt1XiKwGwWqLbBBSWecEtltEG61yg+QCabyBrZU2Wm2jp0gn2McUCxJBcEUXdpQxRbIJadJo4WzeX07x4OPNNMMv8JX5fF4ioqcgCO4dx6nBgMRx/Or7fsd13UF6JgBgsVhcTyaTFyKqwMAopZb1ev3O87w3AQC9Xu+diCpSShQKBViWBSGECRDsdjtorVPUrQzD8CHFlEol2LZtBAYAiAjFYhFSShBRhYgec9VqNbBt+yrdjGkRQsCyLCRJgul0Wpb5fP4m1ZqaXC4HAHAcpyaRgUj5w8gE6BeOQQxiEIMYxCAGMYhBDGIQg/4p6CyfCMPhEKPR6KQZrVYL7Xb7MjZ0KuZcM/gN/XVdLmEGAIh+v38EgHK5bPRmVqsVXzkGMYhBDGIQgxjEIAYxiEEMyiToeDxmA7TZbGYAcDgcjEUkSQLgs24mG41GAADb7dbILWmtEccxAMD3/Y5USnWVUkutNdbrNZRSxkD2+z2iKPqul7muO8hmATBNGIYP4/H4OW1oXXqiKJo1m81AKdX1PG8NAB90n6KaLrmkCQAAAABJRU5ErkJggg==",this.BUTTON_PLUS_DISABLED_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAYAAADFeBvrAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAABYlAAAWJQFJUiTwAAAAB3RJTUUH4wYTDBAFolrR5wAAAdlJREFUaN7t2j9v2kAYBvDnDvsdEDJUSEwe6gipU+Z+AkZ7KCww5Rs0XyBLvkFWJrIckxf8KbohZS8dLKFGQsIILPlAR4fE/adEaiWScOh9JsuDrZ/v7hmsV+Axs9msQUSXcRx/8jzvHBYkz/OvURRd+75/W94TADCfz98nSfKFiFqwMFrr+06n8zEIgm8CAIbD4XciakkpUavV4DgOhBA2QLDZbGCMKVEfZJqmFyWm0WjAdV0rMABARKjX65BSgohaRPS50m63Y9d135UrY1uEEHAcB0VRYDqdNmW1Wj0rtbamUqkAADzPO5c4gUj5i3ESoD9wDGIQgxjEIAYxyCKQUgphGCIMQyil7AeNx+Mnr3nLMYhBDHqVHOQnglLqnxssDMMn7/f7fQwGg+NYoUPU8aEqnc/Qc9vlGJ4BAGI0Gu0BoNlsvsgX+/vMJEnyIu9ZLBa85RjEIAa9Aej3Oj5UNb9pbb9WuLYZxCAGMYhBDGLQf4D2+/1pgFar1R0A7HY7axFFUQB4GDeT3W43BoD1em3lKhljkOc5ACCKomuptb7RWt8bY7BcLqG1tgay3W6RZdnP8TLf929PcwCwTJqmF5PJ5Kqc0Dr2ZFl21+v1Yq31TRAESwD4AcX3uBFfeFCxAAAAAElFTkSuQmCC",this.BUTTON_GET_CENTER_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAYAAADFeBvrAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAABYlAAAWJQFJUiTwAAAAB3RJTUUH4wYcCCsV3DWWMQAAAc9JREFUaN7tmkGu2jAQhv+xE0BsEjYsgAW5Ae8Ej96EG7x3BHIDeoSepNyg3CAsQtgGNkFGeLp4hNcu2kIaXnE6vxQpika2P2Xs8YyGcFaSJGGr1XolomdmnsINrZh5MRqNvpQfCAC22+2Ymb8y8xhuam2M+RRF0ZoAIMuyhJnHWmv0ej34vg8ieniKw+GA3W6H0+lUQj3pNE1nAGZaa/T7fXie5wQMAHieh263i6IowMyh1vqgiOgFAIIgcAbkRymlEIbh2/4hmioAEwDodDpwVb7vAwCYearQACn1jtEIoJ/gBKgpQHEcg4iueuI4/vDxLjeFzWbDADAYDH5veOORzswfOl6WZbKHrtZ8Pq/Fpooqu9yfXOCvF3bjfOJyAiRAAiRAv4wb94ohdcx3dRx6dEkcEiABEiAB+n9qCrfk+FVVdb5KCR4RwVrbnATv3tmq7CEBEiAB+vdA965tV16X1LabWFOow7bu8aSmIMe2ANUM9Mg36JuAiGgJAMYYZyGKoihfV4qZlwCQ57mTf8lai/1+X3rZgpIkCdvt9reyvSwIAif6fqy1OB6PyPP80l42HA6jZjYAlkrTdHZuN5u4QMHMSyJaGmM+R1GUA8B3Hdvtjp1TGh0AAAAASUVORK5CYII=",this.CONTRIBUTORS_FONT_FAMILY_0='-apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"',this.BUTTON_MAKE_GEOMETRY_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAMAAADypuvZAAAAQlBMVEUAAADf39/n5+fm5ubm5ubm5ubm5uYAAABvb29wcHB/f3+AgICPj4+/v7/f39/m5ubv7+/w8PD8/Pz9/f3+/v7////uOQjKAAAAB3RSTlMAICCvw/H3O5ZWYwAAAKZJREFUeAHt1sEOgyAQhGEURMWFsdR9/1ctddPepwlJD/z3LyRzIOvcHCKY/NTMArJlch6PS4nqieCAqlRPxIaUDOiPBhooixQWpbWVOFTWu0whMST90WaoMCiZOZRAb7OLZCVQ+jxCIDMcMsMhMwTKItttCPQdmkDFzK4MEkPSH2VDhUJ62Awc0iKS//Q3GmigiIsztaGAszLmOuF/OxLd7CkSw+RetQbMcCdSSXgAAAAASUVORK5CYII=",this.BUTTON_MAKE_GEOMETRY_ACTIVE_0="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAMAAADypuvZAAAAflBMVEUAAACfv9+fv+eiv+aiwOajwOajv+ajwOaiv+ajv+akwOakweaiv+aoxu+ox++ox/Cx0fyy0vyz0/2z0/601P+92f++2v/G3v/H3v/H3//U5v/V5//Z6f/Z6v/a6f/a6v/d7P/f7f/n8f/o8f/o8v/s9P/6/P/7/P/7/f////8N3bWvAAAADHRSTlMAICCvr6/Dw/Hx9/cE8gnKAAABCUlEQVR42tXW2U7DMBAFUIcC6TJ0i20oDnRNyvz/DzJtJCJxkUdTqUK5T7Gs82JfTezcQzkjS54KMRMyZly4R1pU3pDVnEpHtPKmrGkqyBtDNBgUmy9mrrtFLZ+/VoeIKArJIm4joBNriBtArKP2T+QzYck/olqSMf2+frmblKK1EVuWfNpQ5GveTCh16P3+aN+hAChz5Nu+S/0+XC6aXUqvSiPA1JYaodERGh2h0ZH0bQ9GaXl/0ErLsW87w9yD6twRbbBvOvIfeAw68uGnb5BbBsvQhuVZ/wEganR0ABTOGmoDIB+OWdQ2YUhPAjuaUWUzS0ElzZcWU73Q6IZH4uTytByZyPS5cN9XNuQXxwNiAAAAAABJRU5ErkJggg=="}yy.$metadata$={kind:c,simpleName:"DebugDataSystem",interfaces:[Bs]},by.prototype.fetch_92p1wg$=function(t){var n,i,r,o=this.myTileDataFetcher_0.fetch_92p1wg$(t),a=this.mySystemTime_0.getTimeMs();return o.onSuccess_qlkmfe$((n=this,i=t,r=a,function(t){var o,a,s,u,c,p=n.myStats_0,h=i,_=Dd().CELL_DATA_SIZE,f=0;for(c=t.iterator();c.hasNext();)f=f+c.next().size|0;p.add_xamlz8$(h,_,(f/1024|0).toString()+"Kb"),n.myStats_0.add_xamlz8$(i,Dd().LOADING_TIME,n.mySystemTime_0.getTimeMs().subtract(r).toString()+"ms");var m,y=d("size",1,(function(t){return t.size}));t:do{var $=t.iterator();if(!$.hasNext()){m=null;break t}var v=$.next();if(!$.hasNext()){m=v;break t}var g=y(v);do{var b=$.next(),w=y(b);e.compareTo(g,w)<0&&(v=b,g=w)}while($.hasNext());m=v}while(0);var x=m;return u=n.myStats_0,o=Dd().BIGGEST_LAYER,s=l(null!=x?x.name:null)+" "+((null!=(a=null!=x?x.size:null)?a:0)/1024|0)+"Kb",u.add_xamlz8$(i,o,s),N})),o},by.$metadata$={kind:c,simpleName:"DebugTileDataFetcher",interfaces:[Um]},wy.prototype.parse_yeqvx5$=function(t,e){var n,i,r,o=new Ol(this.mySystemTime_0,this.myTileDataParser_0.parse_yeqvx5$(t,e));return o.addFinishHandler_o14v8n$((n=this,i=t,r=o,function(){return n.myStats_0.add_xamlz8$(i,Dd().PARSING_TIME,r.processTime.toString()+"ms ("+r.maxResumeTime.toString()+"ms)"),N})),o},wy.$metadata$={kind:c,simpleName:"DebugTileDataParser",interfaces:[qm]},xy.prototype.render_qge02a$=function(t,e,n,i){var r=this.myTileDataRenderer_0.render_qge02a$(t,e,n,i);if(i===va())return r;var o=Dd().renderTimeKey_23sqz4$(i),a=Dd().snapshotTimeKey_23sqz4$(i),s=new Ol(this.mySystemTime_0,r);return s.addFinishHandler_o14v8n$(ky(this,s,n,a,o)),s},xy.$metadata$={kind:c,simpleName:"DebugTileDataRenderer",interfaces:[Km]},Object.defineProperty(Cy.prototype,"text",{get:function(){return this.text_h19r89$_0}}),Cy.$metadata$={kind:c,simpleName:"SimpleText",interfaces:[Ey]},Cy.prototype.component1=function(){return this.text},Cy.prototype.copy_61zpoe$=function(t){return new Cy(void 0===t?this.text:t)},Cy.prototype.toString=function(){return"SimpleText(text="+e.toString(this.text)+")"},Cy.prototype.hashCode=function(){var t=0;return 31*t+e.hashCode(this.text)|0},Cy.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.text,t.text)},Object.defineProperty(Sy.prototype,"text",{get:function(){return this.text_xpr0uk$_0}}),Sy.$metadata$={kind:c,simpleName:"SimpleLink",interfaces:[Ey]},Sy.prototype.component1=function(){return this.href},Sy.prototype.component2=function(){return this.text},Sy.prototype.copy_puj7f4$=function(t,e){return new Sy(void 0===t?this.href:t,void 0===e?this.text:e)},Sy.prototype.toString=function(){return"SimpleLink(href="+e.toString(this.href)+", text="+e.toString(this.text)+")"},Sy.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.href)|0)+e.hashCode(this.text)|0},Sy.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.href,t.href)&&e.equals(this.text,t.text)},Ey.$metadata$={kind:v,simpleName:"AttributionParts",interfaces:[]},Ty.prototype.parse=function(){for(var t=w(),e=this.regex_0.find_905azu$(this.rawAttribution_0);null!=e;){if(e.value.length>0){var n=oi(e.value,"1)throw f("There are more than one mapper for "+e);return n.iterator().next()},zt.prototype.getMappers_abn725$=function(t,e){var n,i=this.getMappers_0(e),r=null;for(n=i.iterator();n.hasNext();){var o=n.next();if(It().isDescendant_1xbo8k$(t,o)){if(null==r){if(1===i.size)return Y(o);r=Z()}r.add_11rb$(o)}}return null==r?J():r},zt.prototype.put_teo19m$=function(t,e){if(this.myProperties_0.containsKey_11rb$(t))throw f("Property "+t+" is already defined");if(null==e)throw V("Trying to set null as a value of "+t);this.myProperties_0.put_xwzc9p$(t,e)},zt.prototype.get_kpbivk$=function(t){var n,i;if(null==(n=this.myProperties_0.get_11rb$(t)))throw f("Property "+t+" wasn't found");return null==(i=n)||e.isType(i,K)?i:k()},zt.prototype.contains_iegf2p$=function(t){return this.myProperties_0.containsKey_11rb$(t)},zt.prototype.remove_9l51dn$=function(t){var n;if(!this.myProperties_0.containsKey_11rb$(t))throw f("Property "+t+" wasn't found");return null==(n=this.myProperties_0.remove_11rb$(t))||e.isType(n,K)?n:k()},zt.prototype.getMappers=function(){var t,e=Z();for(t=this.myMappers_0.keys.iterator();t.hasNext();){var n=t.next();e.addAll_brywnq$(this.getMappers_0(n))}return e},zt.prototype.getMappers_0=function(t){var n,i,r;if(!this.myMappers_0.containsKey_11rb$(t))return J();var o=this.myMappers_0.get_11rb$(t);if(e.isType(o,st)){var a=e.isType(n=o,st)?n:k();return Y(a)}var s=Z();for(r=(e.isType(i=o,U)?i:k()).iterator();r.hasNext();){var l=r.next();s.add_11rb$(l)}return s},zt.$metadata$={kind:p,simpleName:"MappingContext",interfaces:[]},Ut.prototype.onItemAdded_u8tacu$=function(t){var e=this.this$ObservableCollectionRoleSynchronizer.createMapper_11rb$(_(t.newItem));this.closure$modifiableMappers.add_wxm5ur$(t.index,e),this.this$ObservableCollectionRoleSynchronizer.myTarget_0.add_wxm5ur$(t.index,e.target),this.this$ObservableCollectionRoleSynchronizer.processMapper_obu244$(e)},Ut.prototype.onItemRemoved_u8tacu$=function(t){this.closure$modifiableMappers.removeAt_za3lpa$(t.index),this.this$ObservableCollectionRoleSynchronizer.myTarget_0.removeAt_za3lpa$(t.index)},Ut.$metadata$={kind:p,interfaces:[Q]},Bt.prototype.onAttach=function(){var t;if(nt.prototype.onAttach.call(this),!this.myTarget_0.isEmpty())throw V("Target Collection Should Be Empty");this.myCollectionRegistration_0=B.Companion.EMPTY,new it(this).update_4f0l55$(this.mySource_0);var e=this.modifiableMappers;for(t=e.iterator();t.hasNext();){var n=t.next();this.myTarget_0.add_11rb$(n.target)}this.myCollectionRegistration_0=this.mySource_0.addListener_n5no9j$(new Ut(this,e))},Bt.prototype.onDetach=function(){nt.prototype.onDetach.call(this),_(this.myCollectionRegistration_0).remove(),this.myTarget_0.clear()},Bt.$metadata$={kind:p,simpleName:"ObservableCollectionRoleSynchronizer",interfaces:[nt]},Ft.$metadata$={kind:A,simpleName:"RefreshableSynchronizer",interfaces:[Wt]},qt.prototype.attach_1rog5x$=function(t){this.myReg_cuddgt$_0=this.doAttach_1rog5x$(t)},qt.prototype.detach=function(){_(this.myReg_cuddgt$_0).remove()},qt.$metadata$={kind:p,simpleName:"RegistrationSynchronizer",interfaces:[Wt]},Gt.$metadata$={kind:A,simpleName:"RoleSynchronizer",interfaces:[Wt]},Yt.prototype.mapperAdded_r9e1k2$=function(t,e){this.this$SimpleRoleSynchronizer.myTarget_0.add_wxm5ur$(t,e.target)},Yt.prototype.mapperRemoved_r9e1k2$=function(t,e){this.this$SimpleRoleSynchronizer.myTarget_0.removeAt_za3lpa$(t)},Yt.$metadata$={kind:p,interfaces:[it]},Ht.prototype.refresh=function(){new Yt(this).update_4f0l55$(this.mySource_0)},Ht.prototype.onAttach=function(){nt.prototype.onAttach.call(this),this.refresh()},Ht.prototype.onDetach=function(){nt.prototype.onDetach.call(this),this.myTarget_0.clear()},Ht.$metadata$={kind:p,simpleName:"SimpleRoleSynchronizer",interfaces:[Ft,nt]},Object.defineProperty(Vt.prototype,"mappers",{configurable:!0,get:function(){return null==this.myTargetMapper_0.get()?T():O(_(this.myTargetMapper_0.get()))}}),Kt.prototype.onEvent_11rb$=function(t){this.this$SingleChildRoleSynchronizer.sync_0()},Kt.$metadata$={kind:p,interfaces:[tt]},Vt.prototype.attach_1rog5x$=function(t){this.sync_0(),this.myChildRegistration_0=this.myChildProperty_0.addHandler_gxwwpc$(new Kt(this))},Vt.prototype.detach=function(){this.myChildRegistration_0.remove(),this.myTargetProperty_0.set_11rb$(null),this.myTargetMapper_0.set_11rb$(null)},Vt.prototype.sync_0=function(){var t,e=this.myChildProperty_0.get();if(e!==(null!=(t=this.myTargetMapper_0.get())?t.source:null))if(null!=e){var n=this.createMapper_11rb$(e);this.myTargetMapper_0.set_11rb$(n),this.myTargetProperty_0.set_11rb$(n.target),this.processMapper_obu244$(n)}else this.myTargetMapper_0.set_11rb$(null),this.myTargetProperty_0.set_11rb$(null)},Vt.$metadata$={kind:p,simpleName:"SingleChildRoleSynchronizer",interfaces:[rt]},Xt.$metadata$={kind:m,simpleName:"Companion",interfaces:[]};var Zt=null;function Jt(){return null===Zt&&new Xt,Zt}function Qt(){}function te(){he=this,this.EMPTY_0=new pe}function ee(t,e){this.closure$target=t,this.closure$source=e,qt.call(this)}function ne(t){this.closure$target=t}function ie(t,e){this.closure$source=t,this.closure$target=e,this.myOldValue_0=null,this.myRegistration_0=null}function re(t){this.closure$r=t}function oe(t){this.closure$disposable=t}function ae(t){this.closure$disposables=t}function se(t,e){this.closure$r=t,this.closure$src=e,qt.call(this)}function le(t){this.closure$r=t}function ue(t,e){this.closure$src=t,this.closure$h=e,qt.call(this)}function ce(t){this.closure$h=t}function pe(){}Wt.$metadata$={kind:A,simpleName:"Synchronizer",interfaces:[]},Qt.$metadata$={kind:A,simpleName:"SynchronizerContext",interfaces:[]},te.prototype.forSimpleRole_z48wgy$=function(t,e,n,i){return new Ht(t,e,n,i)},te.prototype.forObservableRole_abqnzq$=function(t,e,n,i,r){return new _e(t,e,n,i,r)},te.prototype.forObservableRole_umd8ru$=function(t,e,n,i){return this.forObservableRole_ndqwza$(t,e,n,i,null)},te.prototype.forObservableRole_ndqwza$=function(t,e,n,i,r){return new Bt(t,e,n,i,r)},te.prototype.forSingleRole_pri2ej$=function(t,e,n,i){return new Vt(t,e,n,i)},ne.prototype.onEvent_11rb$=function(t){this.closure$target.set_11rb$(t.newValue)},ne.$metadata$={kind:p,interfaces:[tt]},ee.prototype.doAttach_1rog5x$=function(t){return this.closure$target.set_11rb$(this.closure$source.get()),this.closure$source.addHandler_gxwwpc$(new ne(this.closure$target))},ee.$metadata$={kind:p,interfaces:[qt]},te.prototype.forPropsOneWay_2ov6i0$=function(t,e){return new ee(e,t)},ie.prototype.attach_1rog5x$=function(t){this.myOldValue_0=this.closure$source.get(),this.myRegistration_0=et.PropertyBinding.bindTwoWay_ejkotq$(this.closure$source,this.closure$target)},ie.prototype.detach=function(){var t;_(this.myRegistration_0).remove(),this.closure$target.set_11rb$(null==(t=this.myOldValue_0)||e.isType(t,K)?t:k())},ie.$metadata$={kind:p,interfaces:[Wt]},te.prototype.forPropsTwoWay_ejkotq$=function(t,e){return new ie(t,e)},re.prototype.attach_1rog5x$=function(t){},re.prototype.detach=function(){this.closure$r.remove()},re.$metadata$={kind:p,interfaces:[Wt]},te.prototype.forRegistration_3xv6fb$=function(t){return new re(t)},oe.prototype.attach_1rog5x$=function(t){},oe.prototype.detach=function(){this.closure$disposable.dispose()},oe.$metadata$={kind:p,interfaces:[Wt]},te.prototype.forDisposable_gg3y3y$=function(t){return new oe(t)},ae.prototype.attach_1rog5x$=function(t){},ae.prototype.detach=function(){var t,e;for(t=this.closure$disposables,e=0;e!==t.length;++e)t[e].dispose()},ae.$metadata$={kind:p,interfaces:[Wt]},te.prototype.forDisposables_h9hjd7$=function(t){return new ae(t)},le.prototype.onEvent_11rb$=function(t){this.closure$r.run()},le.$metadata$={kind:p,interfaces:[tt]},se.prototype.doAttach_1rog5x$=function(t){return this.closure$r.run(),this.closure$src.addHandler_gxwwpc$(new le(this.closure$r))},se.$metadata$={kind:p,interfaces:[qt]},te.prototype.forEventSource_giy12r$=function(t,e){return new se(e,t)},ce.prototype.onEvent_11rb$=function(t){this.closure$h(t)},ce.$metadata$={kind:p,interfaces:[tt]},ue.prototype.doAttach_1rog5x$=function(t){return this.closure$src.addHandler_gxwwpc$(new ce(this.closure$h))},ue.$metadata$={kind:p,interfaces:[qt]},te.prototype.forEventSource_k8sbiu$=function(t,e){return new ue(t,e)},te.prototype.empty=function(){return this.EMPTY_0},pe.prototype.attach_1rog5x$=function(t){},pe.prototype.detach=function(){},pe.$metadata$={kind:p,interfaces:[Wt]},te.$metadata$={kind:m,simpleName:"Synchronizers",interfaces:[]};var he=null;function _e(t,e,n,i,r){nt.call(this,t),this.mySource_0=e,this.mySourceTransformer_0=n,this.myTarget_0=i,this.myCollectionRegistration_0=null,this.mySourceTransformation_0=null,this.addMapperFactory_7h0hpi$(r)}function fe(t){this.this$TransformingObservableCollectionRoleSynchronizer=t,Q.call(this)}fe.prototype.onItemAdded_u8tacu$=function(t){var e=this.this$TransformingObservableCollectionRoleSynchronizer.createMapper_11rb$(_(t.newItem));this.this$TransformingObservableCollectionRoleSynchronizer.modifiableMappers.add_wxm5ur$(t.index,e),this.this$TransformingObservableCollectionRoleSynchronizer.myTarget_0.add_wxm5ur$(t.index,e.target),this.this$TransformingObservableCollectionRoleSynchronizer.processMapper_obu244$(e)},fe.prototype.onItemRemoved_u8tacu$=function(t){this.this$TransformingObservableCollectionRoleSynchronizer.modifiableMappers.removeAt_za3lpa$(t.index),this.this$TransformingObservableCollectionRoleSynchronizer.myTarget_0.removeAt_za3lpa$(t.index)},fe.$metadata$={kind:p,interfaces:[Q]},_e.prototype.onAttach=function(){var t;nt.prototype.onAttach.call(this);var e=new N;for(this.mySourceTransformation_0=this.mySourceTransformer_0.transform_xwzc9p$(this.mySource_0,e),new it(this).update_4f0l55$(e),t=this.modifiableMappers.iterator();t.hasNext();){var n=t.next();this.myTarget_0.add_11rb$(n.target)}this.myCollectionRegistration_0=e.addListener_n5no9j$(new fe(this))},_e.prototype.onDetach=function(){nt.prototype.onDetach.call(this),_(this.myCollectionRegistration_0).remove(),_(this.mySourceTransformation_0).dispose(),this.myTarget_0.clear()},_e.$metadata$={kind:p,simpleName:"TransformingObservableCollectionRoleSynchronizer",interfaces:[nt]},nt.MapperUpdater=it;var de=t.jetbrains||(t.jetbrains={}),me=de.datalore||(de.datalore={}),ye=me.mapper||(me.mapper={}),$e=ye.core||(ye.core={});return $e.BaseCollectionRoleSynchronizer=nt,$e.BaseRoleSynchronizer=rt,ot.DifferenceItem=at,$e.DifferenceBuilder=ot,st.SynchronizersConfiguration=$t,Object.defineProperty(st,"Companion",{get:Ot}),$e.Mapper=st,$e.MapperFactory=Nt,Object.defineProperty($e,"Mappers",{get:It}),$e.MappingContext=zt,$e.ObservableCollectionRoleSynchronizer=Bt,$e.RefreshableSynchronizer=Ft,$e.RegistrationSynchronizer=qt,$e.RoleSynchronizer=Gt,$e.SimpleRoleSynchronizer=Ht,$e.SingleChildRoleSynchronizer=Vt,Object.defineProperty(Wt,"Companion",{get:Jt}),$e.Synchronizer=Wt,$e.SynchronizerContext=Qt,Object.defineProperty($e,"Synchronizers",{get:function(){return null===he&&new te,he}}),$e.TransformingObservableCollectionRoleSynchronizer=_e,t})?i.apply(e,r):i)||(t.exports=o)},836:function(t,e,n){var i,r,o;r=[e,n(421),n(767),n(958),n(331)],void 0===(o="function"==typeof(i=function(t,e,n,i,r){"use strict";var o=n.jetbrains.datalore.base.gcommon.collect,a=e.kotlin.collections.Iterable,s=e.throwCCE,l=e.equals,u=e.kotlin.collections.List,c=e.kotlin.collections.ArrayList_init_287e2$,p=e.Kind.OBJECT,h=e.Kind.CLASS,_=n.jetbrains.datalore.base.typedKey.TypedKey,f=e.Kind.INTERFACE,d=e.kotlin.IllegalArgumentException_init_pdl1vj$,m=e.kotlin.text.StringBuilder_init,y=e.ensureNotNull,$=e.kotlin.collections.emptyList_287e2$,v=e.kotlin.collections.LinkedHashSet_init_mqih57$,g=e.kotlin.collections.Collection,b=i.jetbrains.datalore.plot.common.data,w=e.kotlin.Enum,x=e.throwISE,k=e.kotlin.isFinite_yrwdxr$,E=e.kotlin.collections.zip_45mdf7$,C=e.getCallableRef,S=e.kotlin.collections.toList_abgq59$,T=e.kotlin.comparisons.compareBy_bvgy4j$,O=e.kotlin.collections.sortedWith_eknfly$,N=e.kotlin.collections.reversed_7wnvza$,P=e.kotlin.collections.plus_mydzjv$,A=e.kotlin.collections.toSet_7wnvza$,j=n.jetbrains.datalore.base.logging,L=e.getKClass,R=e.kotlin.collections.ArrayList_init_mqih57$,I=e.kotlin.collections.HashMap_init_q3lmfv$,z=e.kotlin.collections.HashMap_init_73mtqc$,D=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,M=e.kotlin.collections.mapCapacity_za3lpa$,B=e.kotlin.collections.LinkedHashMap_init_bwtc7$,U=e.kotlin.collections.MutableCollection,F=e.toString,q=e.kotlin.IllegalStateException_init_pdl1vj$,G=n.jetbrains.datalore.base.gcommon.collect.TreeMap,H=e.kotlin.collections.intersect_q4559j$,Y=e.kotlin.collections.Map,V=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,K=e.kotlin.collections.ArrayList_init_ww73n8$,W=Math,X=e.kotlin.collections.listOf_i5x0yv$,Z=e.kotlin.Unit,J=n.jetbrains.datalore.base.typedKey.TypedKeyHashMap,Q=e.kotlin.js.internal.DoubleCompanionObject,tt=n.jetbrains.datalore.base.values.Color,et=n.jetbrains.datalore.base.gcommon.collect.ClosedRange,nt=e.kotlin.collections.HashSet_init_mqih57$,it=e.kotlin.NoSuchElementException,rt=e.kotlin.collections.Iterator,ot=n.jetbrains.datalore.base.function.Function,at=n.jetbrains.datalore.base.values,st=r.jetbrains.datalore.vis.svg,lt=n.jetbrains.datalore.base.geometry.DoubleVector,ut=n.jetbrains.datalore.base.geometry,ct=n.jetbrains.datalore.base.gcommon.collect.Ordering,pt=e.kotlin.Comparator,ht=e.getPropertyCallableRef,_t=e.kotlin.ranges.coerceAtLeast_dqglrj$,ft=n.jetbrains.datalore.base.gcommon.base,dt=e.kotlin.text.startsWith_7epoxm$,mt=e.kotlin.text.Regex_init_61zpoe$,yt=n.jetbrains.datalore.base.geometry.DoubleSegment,$t=e.kotlin.collections.HashSet_init_ww73n8$,vt=e.kotlin.collections.reverse_vvxzk3$,gt=Object,bt=n.jetbrains.datalore.base.geometry.DoubleRectangle,wt=n.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$,xt=r.jetbrains.datalore.vis.svg.SvgLineElement_init_6y0v78$,kt=r.jetbrains.datalore.vis.svg.SvgGElement,Et=r.jetbrains.datalore.vis.svg.slim,Ct=r.jetbrains.datalore.vis.svg.SvgRectElement_init_6y0v78$,St=r.jetbrains.datalore.vis.svg.SvgImageElement_init_6y0v78$,Tt=e.throwUPAE,Ot=e.kotlin.isNaN_yrwdxr$,Nt=r.jetbrains.datalore.vis.svg.SvgPathDataBuilder,Pt=e.kotlin.math,At=e.kotlin.math.round_14dthe$,jt=e.numberToInt,Lt=r.jetbrains.datalore.vis.svg.SvgImageElementEx.Bitmap,Rt=r.jetbrains.datalore.vis.svg.SvgImageElementEx,It=r.jetbrains.datalore.vis.svg.SvgPathElement_init_7jrsat$,zt=r.jetbrains.datalore.vis.svg.SvgShape,Dt=r.jetbrains.datalore.vis.svg.SvgElement,Mt=e.kotlin.to_ujzrz7$,Bt=e.kotlin.collections.mapOf_qfcya0$,Ut=e.kotlin.collections.setOf_i5x0yv$,Ft=e.kotlin.collections.take_ba2ldo$,qt=e.kotlin.collections.copyToArray,Gt=n.jetbrains.datalore.base.algorithms.splitRings_bemo1h$,Ht=n.jetbrains.datalore.base.values.Pair,Yt=r.jetbrains.datalore.vis.svg.SvgRectElement_init_wthzt5$,Vt=e.kotlin.collections.emptyMap_q3lmfv$,Kt=e.kotlin.random.Random,Wt=e.kotlin.collections.asList_us0mfu$,Xt=r.jetbrains.datalore.vis.svg.slim.SvgSlimObject,Zt=r.jetbrains.datalore.vis.svg.SvgPathData,Jt=r.jetbrains.datalore.vis.svg.SvgPathDataBuilder.Interpolation,Qt=n.jetbrains.datalore.base.observable.property.WritableProperty,te=r.jetbrains.datalore.vis.svg.SvgColors,ee=n.jetbrains.datalore.base.observable.event.EventHandler,ne=n.jetbrains.datalore.base.registration.CompositeRegistration,ie=r.jetbrains.datalore.vis.svg.SvgClipPathElement,re=r.jetbrains.datalore.vis.svg.SvgRectElement,oe=r.jetbrains.datalore.vis.svg.SvgDefsElement,ae=r.jetbrains.datalore.vis.svg.SvgIRI,se=r.jetbrains.datalore.vis.svg.SvgGraphicsElement,le=r.jetbrains.datalore.vis.svg.SvgTransformBuilder,ue=n.jetbrains.datalore.base.random,ce=r.jetbrains.datalore.vis.svg.SvgTextElement_init_61zpoe$,pe=e.kotlin.text.isBlank_gw00vp$,he=e.kotlin.collections.filterNotNull_m3lr2h$,_e=e.kotlin.collections.checkIndexOverflow_za3lpa$,fe=e.numberToDouble,de=e.kotlin.Pair,me=e.kotlin.collections.toMap_6hr0sd$,ye=e.kotlin.collections.getValue_t9ocha$,$e=e.kotlin.collections.toList_7wnvza$,ve=e.kotlin.isInfinite_yrwdxr$,ge=e.kotlin.collections.toMutableList_4c7yge$,be=i.jetbrains.datalore.plot.common.time.interval.YearInterval,we=i.jetbrains.datalore.plot.common.time,xe=i.jetbrains.datalore.plot.common.time.interval,ke=e.kotlin.ranges.until_dqglrj$,Ee=e.kotlin.collections.listOf_mh5how$,Ce=e.kotlin.collections.asReversed_2p1efm$,Se=n.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$,Te=i.jetbrains.datalore.plot.common.text,Oe=i.jetbrains.datalore.plot.common.time.interval.TimeInterval,Ne=e.kotlin.collections.first_2p1efm$,Pe=e.kotlin.collections.last_2p1efm$,Ae=e.kotlin.collections.binarySearch_jhx6be$,je=e.kotlin.math.abs_za3lpa$,Le=e.kotlin.collections.maxOrNull_l63kqw$,Re=e.kotlin.collections.mutableMapOf_qfcya0$,Ie=e.kotlin.collections.HashSet_init_287e2$,ze=e.kotlin.collections.sortWith_nqfjgj$,De=e.hashCode,Me=e.kotlin.ranges.rangeTo_38ydlf$,Be=e.kotlin.collections.withIndex_7wnvza$,Ue=e.kotlin.collections.LinkedHashSet_init_287e2$,Fe=e.kotlin.RuntimeException_init_pdl1vj$,qe=e.kotlin.collections.unzip_6hr0sd$,Ge=e.kotlin.collections.sorted_exjks8$,He=e.kotlin.collections.sum_l63kqw$,Ye=e.wrapFunction,Ve=Array,Ke=e.Long.fromInt(37),We=e.kotlin.random.Random_s8cxhz$,Xe=e.kotlin.ranges.coerceIn_nig4hr$,Ze=new e.Long(456400702,-8856424),Je=e.kotlin.collections.arrayCopy,Qe=e.kotlin.collections.average_bvy38s$,tn=e.kotlin.collections.arrayListOf_i5x0yv$,en=e.kotlin.collections.fill_x4f2cq$,nn=e.primitiveArraySort,rn=e.kotlin.collections.get_lastIndex_bvy38s$,on=e.kotlin.collections.get_indices_bvy38s$,an=e.kotlin.ranges.reversed_zf1xzc$,sn=e.kotlin.collections.toMutableList_bvy38s$,ln=e.kotlin.isNaN_81szk$,un=e.floatToBits,cn=e.doubleToBits,pn=e.kotlin.math.abs_s8cxhz$,hn=e.Long.fromInt(-2147483648),_n=new e.Long(1994767346,-1362668208),fn=e.kotlin.collections.zip_pmvpm9$,dn=e.kotlin.collections.toDoubleArray_tcduak$,mn=e.kotlin.collections.asSequence_7wnvza$,yn=e.kotlin.sequences.zip_r7q3s9$,$n=e.kotlin.sequences.drop_wuwhe2$;function vn(t,e){Cn(),void 0===e&&(e=!0),this.name=t,this.isNumeric=e,Cn().values_0.add_11rb$(this)}function gn(){En=this,this.values_0=c(),this.X=new vn("x"),this.Y=new vn("y"),this.Z=new vn("z"),this.COLOR=new vn("color",!1),this.FILL=new vn("fill",!1),this.ALPHA=new vn("alpha"),this.SHAPE=new vn("shape",!1),this.LINETYPE=new vn("linetype",!1),this.SIZE=new vn("size"),this.WIDTH=new vn("width"),this.HEIGHT=new vn("height"),this.WEIGHT=new vn("weight"),this.INTERCEPT=new vn("intercept"),this.SLOPE=new vn("slope"),this.XINTERCEPT=new vn("xintercept"),this.YINTERCEPT=new vn("yintercept"),this.LOWER=new vn("lower"),this.MIDDLE=new vn("middle"),this.UPPER=new vn("upper"),this.XMIN=new vn("xmin"),this.XMAX=new vn("xmax"),this.YMIN=new vn("ymin"),this.YMAX=new vn("ymax"),this.XEND=new vn("xend"),this.YEND=new vn("yend"),this.FRAME=new vn("frame",!1),this.SPEED=new vn("speed"),this.FLOW=new vn("flow"),this.LABEL=new vn("label",!1),this.FAMILY=new vn("family",!1),this.FONTFACE=new vn("fontface",!1),this.HJUST=new vn("hjust",!1),this.VJUST=new vn("vjust",!1),this.ANGLE=new vn("angle"),this.SYM_X=new vn("sym_x"),this.SYM_Y=new vn("sym_y")}function bn(t){return t.isNumeric}jn.prototype=Object.create(w.prototype),jn.prototype.constructor=jn,zi.prototype=Object.create(w.prototype),zi.prototype.constructor=zi,Kr.prototype=Object.create(Yr.prototype),Kr.prototype.constructor=Kr,Wr.prototype=Object.create(Yr.prototype),Wr.prototype.constructor=Wr,Xr.prototype=Object.create(Yr.prototype),Xr.prototype.constructor=Xr,mo.prototype=Object.create(Lr.prototype),mo.prototype.constructor=mo,vo.prototype=Object.create(Sa.prototype),vo.prototype.constructor=vo,xo.prototype=Object.create(Sa.prototype),xo.prototype.constructor=xo,So.prototype=Object.create(Sa.prototype),So.prototype.constructor=So,$l.prototype=Object.create(Sa.prototype),$l.prototype.constructor=$l,Ao.prototype=Object.create($l.prototype),Ao.prototype.constructor=Ao,Do.prototype=Object.create(tu.prototype),Do.prototype.constructor=Do,Io.prototype=Object.create(Sa.prototype),Io.prototype.constructor=Io,_s.prototype=Object.create(Sa.prototype),_s.prototype.constructor=_s,Fo.prototype=Object.create(_s.prototype),Fo.prototype.constructor=Fo,Ss.prototype=Object.create(Sa.prototype),Ss.prototype.constructor=Ss,Yo.prototype=Object.create(Ss.prototype),Yo.prototype.constructor=Yo,Xo.prototype=Object.create(Sa.prototype),Xo.prototype.constructor=Xo,ea.prototype=Object.create(Fo.prototype),ea.prototype.constructor=ea,oa.prototype=Object.create(Yo.prototype),oa.prototype.constructor=oa,ua.prototype=Object.create(xo.prototype),ua.prototype.constructor=ua,_a.prototype=Object.create(Sa.prototype),_a.prototype.constructor=_a,Va.prototype=Object.create(_s.prototype),Va.prototype.constructor=Va,xa.prototype=Object.create(Va.prototype),xa.prototype.constructor=xa,Pa.prototype=Object.create(Sa.prototype),Pa.prototype.constructor=Pa,Ra.prototype=Object.create(So.prototype),Ra.prototype.constructor=Ra,Ma.prototype=Object.create(Sa.prototype),Ma.prototype.constructor=Ma,ys.prototype=Object.create(Sa.prototype),ys.prototype.constructor=ys,qa.prototype=Object.create(ys.prototype),qa.prototype.constructor=qa,Za.prototype=Object.create(Sa.prototype),Za.prototype.constructor=Za,us.prototype=Object.create(Ss.prototype),us.prototype.constructor=us,Eu.prototype=Object.create(nu.prototype),Eu.prototype.constructor=Eu,ws.prototype=Object.create(Sa.prototype),ws.prototype.constructor=ws,Ps.prototype=Object.create(Sa.prototype),Ps.prototype.constructor=Ps,Rs.prototype=Object.create(Sa.prototype),Rs.prototype.constructor=Rs,Ms.prototype=Object.create(Sa.prototype),Ms.prototype.constructor=Ms,qs.prototype=Object.create(Sa.prototype),qs.prototype.constructor=qs,Ks.prototype=Object.create(Sa.prototype),Ks.prototype.constructor=Ks,il.prototype=Object.create(w.prototype),il.prototype.constructor=il,nl.prototype=Object.create(Va.prototype),nl.prototype.constructor=nl,_l.prototype=Object.create(Sa.prototype),_l.prototype.constructor=_l,xl.prototype=Object.create(Sa.prototype),xl.prototype.constructor=xl,zl.prototype=Object.create(tu.prototype),zl.prototype.constructor=zl,Dl.prototype=Object.create(w.prototype),Dl.prototype.constructor=Dl,ql.prototype=Object.create(w.prototype),ql.prototype.constructor=ql,Fu.prototype=Object.create(nu.prototype),Fu.prototype.constructor=Fu,rc.prototype=Object.create(w.prototype),rc.prototype.constructor=rc,uc.prototype=Object.create(w.prototype),uc.prototype.constructor=uc,kc.prototype=Object.create(w.prototype),kc.prototype.constructor=kc,Ac.prototype=Object.create(xc.prototype),Ac.prototype.constructor=Ac,Vc.prototype=Object.create(w.prototype),Vc.prototype.constructor=Vc,Jc.prototype=Object.create(w.prototype),Jc.prototype.constructor=Jc,wp.prototype=Object.create(w.prototype),wp.prototype.constructor=wp,Sp.prototype=Object.create(w.prototype),Sp.prototype.constructor=Sp,Rp.prototype=Object.create(w.prototype),Rp.prototype.constructor=Rp,Bp.prototype=Object.create(w.prototype),Bp.prototype.constructor=Bp,dh.prototype=Object.create(w.prototype),dh.prototype.constructor=dh,kh.prototype=Object.create(w.prototype),kh.prototype.constructor=kh,Nh.prototype=Object.create(Oh.prototype),Nh.prototype.constructor=Nh,Ph.prototype=Object.create(Oh.prototype),Ph.prototype.constructor=Ph,Dh.prototype=Object.create(w.prototype),Dh.prototype.constructor=Dh,Bh.prototype=Object.create(Dh.prototype),Bh.prototype.constructor=Bh,qh.prototype=Object.create(Dh.prototype),qh.prototype.constructor=qh,T_.prototype=Object.create(w.prototype),T_.prototype.constructor=T_,pf.prototype=Object.create(Sf.prototype),pf.prototype.constructor=pf,Rf.prototype=Object.create(Ef.prototype),Rf.prototype.constructor=Rf,hf.prototype=Object.create(Rf.prototype),hf.prototype.constructor=hf,mf.prototype=Object.create(Sf.prototype),mf.prototype.constructor=mf,Cf.prototype=Object.create(Rf.prototype),Cf.prototype.constructor=Cf,Nf.prototype=Object.create(Sf.prototype),Nf.prototype.constructor=Nf,Pf.prototype=Object.create(Sf.prototype),Pf.prototype.constructor=Pf,If.prototype=Object.create(Yf.prototype),If.prototype.constructor=If,zf.prototype=Object.create(Yf.prototype),zf.prototype.constructor=zf,cd.prototype=Object.create(w.prototype),cd.prototype.constructor=cd,dd.prototype=Object.create(w.prototype),dd.prototype.constructor=dd,ld.prototype=Object.create(Yf.prototype),ld.prototype.constructor=ld,Sd.prototype=Object.create(wd.prototype),Sd.prototype.constructor=Sd,Cd.prototype=Object.create(gd.prototype),Cd.prototype.constructor=Cd,Nd.prototype=Object.create(wd.prototype),Nd.prototype.constructor=Nd,Od.prototype=Object.create(gd.prototype),Od.prototype.constructor=Od,Zd.prototype=Object.create(Xd.prototype),Zd.prototype.constructor=Zd,Jd.prototype=Object.create(Xd.prototype),Jd.prototype.constructor=Jd,cm.prototype=Object.create(um.prototype),cm.prototype.constructor=cm,ym.prototype=Object.create(um.prototype),ym.prototype.constructor=ym,Tm.prototype=Object.create(um.prototype),Tm.prototype.constructor=Tm,Pm.prototype=Object.create(um.prototype),Pm.prototype.constructor=Pm,Dm.prototype=Object.create(Fm.prototype),Dm.prototype.constructor=Dm,qm.prototype=Object.create(Fm.prototype),qm.prototype.constructor=qm,Qm.prototype=Object.create(w.prototype),Qm.prototype.constructor=Qm,Jm.prototype=Object.create(Fm.prototype),Jm.prototype.constructor=Jm,dy.prototype=Object.create(Fm.prototype),dy.prototype.constructor=dy,Ay.prototype=Object.create(w.prototype),Ay.prototype.constructor=Ay,Uy.prototype=Object.create(Fm.prototype),Uy.prototype.constructor=Uy,Xy.prototype=Object.create(Fm.prototype),Xy.prototype.constructor=Xy,s$.prototype=Object.create(w.prototype),s$.prototype.constructor=s$,h$.prototype=Object.create(w.prototype),h$.prototype.constructor=h$,a$.prototype=Object.create(Fm.prototype),a$.prototype.constructor=a$,x$.prototype=Object.create(Fm.prototype),x$.prototype.constructor=x$,S$.prototype=Object.create(Dm.prototype),S$.prototype.constructor=S$,T$.prototype=Object.create(Dm.prototype),T$.prototype.constructor=T$,U$.prototype=Object.create(w.prototype),U$.prototype.constructor=U$,X$.prototype=Object.create(w.prototype),X$.prototype.constructor=X$,M$.prototype=Object.create(Fm.prototype),M$.prototype.constructor=M$,wv.prototype=Object.create(w.prototype),wv.prototype.constructor=wv,bv.prototype=Object.create(Fm.prototype),bv.prototype.constructor=bv,jv.prototype=Object.create(Fm.prototype),jv.prototype.constructor=jv,Yv.prototype=Object.create(eg.prototype),Yv.prototype.constructor=Yv,Kv.prototype=Object.create(w.prototype),Kv.prototype.constructor=Kv,lg.prototype=Object.create(vg.prototype),lg.prototype.constructor=lg,fg.prototype=Object.create(Yv.prototype),fg.prototype.constructor=fg,Ng.prototype=Object.create(vg.prototype),Ng.prototype.constructor=Ng,qg.prototype=Object.create(w.prototype),qg.prototype.constructor=qg,ob.prototype=Object.create(Iv.prototype),ob.prototype.constructor=ob,db.prototype=Object.create(bb.prototype),db.prototype.constructor=db,mb.prototype=Object.create(bb.prototype),mb.prototype.constructor=mb,yb.prototype=Object.create(bb.prototype),yb.prototype.constructor=yb,Object.defineProperty(vn.prototype,"isColor",{configurable:!0,get:function(){return Cn().isColor_896ixz$(this)}}),vn.prototype.toString=function(){return"aes '"+this.name+"'"},gn.prototype.numeric_shhb9a$=function(t){var n;return e.isType(n=o.Iterables.filter_fpit1u$(t,bn),a)?n:s()},gn.prototype.isPositional_896ixz$=function(t){return this.isPositionalXY_896ixz$(t)||l(t,this.SLOPE)},gn.prototype.isPositionalXY_896ixz$=function(t){return this.isPositionalX_896ixz$(t)||this.isPositionalY_896ixz$(t)},gn.prototype.isPositionalX_896ixz$=function(t){return l(t,this.X)||l(t,this.XINTERCEPT)||l(t,this.XMIN)||l(t,this.XMAX)||l(t,this.XEND)},gn.prototype.isPositionalY_896ixz$=function(t){return l(t,this.Y)||l(t,this.YMIN)||l(t,this.YMAX)||l(t,this.INTERCEPT)||l(t,this.YINTERCEPT)||l(t,this.LOWER)||l(t,this.MIDDLE)||l(t,this.UPPER)||l(t,this.YEND)},gn.prototype.isColor_896ixz$=function(t){return l(t,this.COLOR)||l(t,this.FILL)},gn.prototype.isAffectingScaleX_896ixz$=function(t){return this.isPositionalX_896ixz$(t)},gn.prototype.isAffectingScaleY_896ixz$=function(t){return this.isPositionalY_896ixz$(t)&&!l(t,this.INTERCEPT)},gn.prototype.affectingScaleX_shhb9a$=function(t){var e,n=this.numeric_shhb9a$(t);return o.Iterables.filter_fpit1u$(n,(e=this,function(t){return e.isAffectingScaleX_896ixz$(t)}))},gn.prototype.affectingScaleY_shhb9a$=function(t){var e,n=this.numeric_shhb9a$(t);return o.Iterables.filter_fpit1u$(n,(e=this,function(t){return e.isAffectingScaleY_896ixz$(t)}))},gn.prototype.noGuideNeeded_896ixz$=function(t){return l(t,this.FRAME)||l(t,this.SPEED)||l(t,this.FLOW)||l(t,this.LABEL)||l(t,this.SLOPE)||l(t,this.WIDTH)||l(t,this.HEIGHT)||l(t,this.HJUST)||l(t,this.VJUST)||l(t,this.ANGLE)||l(t,this.FAMILY)||l(t,this.FONTFACE)||l(t,this.SYM_X)||l(t,this.SYM_Y)||this.isPositional_896ixz$(t)},gn.prototype.values=function(){return this.values_0},gn.prototype.allPositional=function(){var t,n,i=this.values_0,r=c();for(n=i.iterator();n.hasNext();){var o=n.next();this.isPositional_896ixz$(o)&&r.add_11rb$(o)}return e.isType(t=r,u)?t:s()},gn.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var wn,xn,kn,En=null;function Cn(){return null===En&&new gn,En}function Sn(){}function Tn(){}function On(){}function Nn(t){var e;for(Yn(),this.myVectorByVar_0=null,this.myIsNumeric_0=null,this.myRanges_0=I(),this.myDistinctValues_0=I(),this.myOrderSpecs_0=null,this.assertAllSeriesAreSameSize_0(t.myVectorByVar_8be2vx$),this.myVectorByVar_0=z(t.myVectorByVar_8be2vx$),this.myIsNumeric_0=z(t.myIsNumeric_8be2vx$),this.myOrderSpecs_0=t.myOrderSpecs_8be2vx$,e=this.myOrderSpecs_0.iterator();e.hasNext();){var n=e.next(),i=this.myDistinctValues_0,r=n.variable,o=this.getOrderedDistinctValues_0(n);i.put_xwzc9p$(r,o)}}function Pn(t,e,n,i){void 0===i&&(i=null),this.variable=t,this.orderBy=e,this.direction=n,this.aggregateOperation=i}function An(t,e,n){Bn(),void 0===e&&(e=Rn()),void 0===n&&(n=t),this.name=t,this.source=e,this.label=n}function jn(t,e){w.call(this),this.name$=t,this.ordinal$=e}function Ln(){Ln=function(){},wn=new jn("ORIGIN",0),xn=new jn("TRANSFORM",1),kn=new jn("STAT",2)}function Rn(){return Ln(),wn}function In(){return Ln(),xn}function zn(){return Ln(),kn}function Dn(){Mn=this}vn.$metadata$={kind:h,simpleName:"Aes",interfaces:[_]},Sn.$metadata$={kind:f,simpleName:"Aesthetics",interfaces:[]},Tn.prototype.createApplicableDomain_yrwdxb$=function(t,e){return void 0===t&&(t=null),e?e(t):this.createApplicableDomain_yrwdxb$$default(t)},Tn.$metadata$={kind:f,simpleName:"ContinuousTransform",interfaces:[Sr]},On.prototype.isPointInLimits_k2qmv6$=function(t,e,n){return void 0===e&&(e=!0),n?n(t,e):this.isPointInLimits_k2qmv6$$default(t,e)},On.prototype.isRectInLimits_fd842m$=function(t,e,n){return void 0===e&&(e=!0),n?n(t,e):this.isRectInLimits_fd842m$$default(t,e)},On.prototype.isPathInLimits_f6t8kh$=function(t,e,n){return void 0===e&&(e=!0),n?n(t,e):this.isPathInLimits_f6t8kh$$default(t,e)},On.prototype.isPolygonInLimits_f6t8kh$=function(t,e,n){return void 0===e&&(e=!0),n?n(t,e):this.isPolygonInLimits_f6t8kh$$default(t,e)},On.$metadata$={kind:f,simpleName:"CoordinateSystem",interfaces:[]},Pn.$metadata$={kind:h,simpleName:"OrderSpec",interfaces:[]},Object.defineProperty(Nn.prototype,"isEmpty",{configurable:!0,get:function(){return this.myVectorByVar_0.isEmpty()}}),Nn.prototype.assertAllSeriesAreSameSize_0=function(t){if(t.size>1)for(var e=t.entries.iterator(),n=e.next().value.size;e.hasNext();)if(e.next().value.size!==n)throw d("All data series in data frame must have equal size\n"+this.dumpSizes_0(t))},Nn.prototype.dumpSizes_0=function(t){var e,n=m();for(e=t.entries.iterator();e.hasNext();){var i=e.next(),r=i.key,o=i.value;n.append_pdl1vj$(r.name).append_pdl1vj$(" : ").append_s8jyv4$(o.size).append_s8itvh$(10)}return n.toString()},Nn.prototype.rowCount=function(){return this.myVectorByVar_0.isEmpty()?0:this.myVectorByVar_0.entries.iterator().next().value.size},Nn.prototype.has_8xm3sj$=function(t){return this.myVectorByVar_0.containsKey_11rb$(t)},Nn.prototype.isEmpty_8xm3sj$=function(t){return this.get_8xm3sj$(t).isEmpty()},Nn.prototype.hasNoOrEmpty_8xm3sj$=function(t){return!this.has_8xm3sj$(t)||this.isEmpty_8xm3sj$(t)},Nn.prototype.get_8xm3sj$=function(t){return this.assertDefined_0(t),y(this.myVectorByVar_0.get_11rb$(t))},Nn.prototype.getNumeric_8xm3sj$=function(t){var n;this.assertDefined_0(t);var i=this.myVectorByVar_0.get_11rb$(t);return y(i).isEmpty()?$():(this.assertNumeric_0(t),e.isType(n=i,u)?n:s())},Nn.prototype.distinctValues_8xm3sj$=function(t){this.assertDefined_0(t);var n=this.myDistinctValues_0.get_11rb$(t);if(null==n){var i,r=v(this.get_8xm3sj$(t));r.remove_11rb$(null);var o=r;return e.isType(i=o,g)?i:s()}return n},Nn.prototype.variables=function(){return this.myVectorByVar_0.keys},Nn.prototype.isNumeric_8xm3sj$=function(t){if(this.assertDefined_0(t),!this.myIsNumeric_0.containsKey_11rb$(t)){var e=b.SeriesUtil.checkedDoubles_9ma18$(this.get_8xm3sj$(t)),n=this.myIsNumeric_0,i=e.notEmptyAndCanBeCast();n.put_xwzc9p$(t,i)}return y(this.myIsNumeric_0.get_11rb$(t))},Nn.prototype.range_8xm3sj$=function(t){if(!this.myRanges_0.containsKey_11rb$(t)){var e=this.getNumeric_8xm3sj$(t),n=b.SeriesUtil.range_l63ks6$(e);this.myRanges_0.put_xwzc9p$(t,n)}return this.myRanges_0.get_11rb$(t)},Nn.prototype.builder=function(){return Ai(this)},Nn.prototype.assertDefined_0=function(t){if(!this.has_8xm3sj$(t)){var e=d("Undefined variable: '"+t+"'");throw Yn().LOG_0.error_l35kib$(e,(n=e,function(){return y(n.message)})),e}var n},Nn.prototype.assertNumeric_0=function(t){if(!this.isNumeric_8xm3sj$(t)){var e=d("Not a numeric variable: '"+t+"'");throw Yn().LOG_0.error_l35kib$(e,(n=e,function(){return y(n.message)})),e}var n},Nn.prototype.selectIndices_pqoyrt$=function(t){return this.buildModified_0((e=t,function(t){return b.SeriesUtil.pickAtIndices_ge51dg$(t,e)}));var e},Nn.prototype.selectIndices_p1n9e9$=function(t){return this.buildModified_0((e=t,function(t){return b.SeriesUtil.pickAtIndices_jlfzfq$(t,e)}));var e},Nn.prototype.dropIndices_p1n9e9$=function(t){return t.isEmpty()?this:this.buildModified_0((e=t,function(t){return b.SeriesUtil.skipAtIndices_jlfzfq$(t,e)}));var e},Nn.prototype.buildModified_0=function(t){var e,n=this.builder();for(e=this.myVectorByVar_0.keys.iterator();e.hasNext();){var i=e.next(),r=this.myVectorByVar_0.get_11rb$(i),o=t(y(r));n.putIntern_bxyhp4$(i,o)}return n.build()},Object.defineProperty(An.prototype,"isOrigin",{configurable:!0,get:function(){return this.source===Rn()}}),Object.defineProperty(An.prototype,"isStat",{configurable:!0,get:function(){return this.source===zn()}}),Object.defineProperty(An.prototype,"isTransform",{configurable:!0,get:function(){return this.source===In()}}),An.prototype.toString=function(){return this.name},An.prototype.toSummaryString=function(){return this.name+", '"+this.label+"' ["+this.source+"]"},jn.$metadata$={kind:h,simpleName:"Source",interfaces:[w]},jn.values=function(){return[Rn(),In(),zn()]},jn.valueOf_61zpoe$=function(t){switch(t){case"ORIGIN":return Rn();case"TRANSFORM":return In();case"STAT":return zn();default:x("No enum constant jetbrains.datalore.plot.base.DataFrame.Variable.Source."+t)}},Dn.prototype.createOriginal_puj7f4$=function(t,e){return void 0===e&&(e=t),new An(t,Rn(),e)},Dn.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Mn=null;function Bn(){return null===Mn&&new Dn,Mn}function Un(t){return null!=t&&(!("number"==typeof t)||k(t))}function Fn(t){var n;return e.isComparable(n=t.second)?n:s()}function qn(t){var n;return e.isComparable(n=t.first)?n:s()}function Gn(){Hn=this,this.LOG_0=j.PortableLogging.logger_xo1ogr$(L(Nn))}An.$metadata$={kind:h,simpleName:"Variable",interfaces:[]},Nn.prototype.getOrderedDistinctValues_0=function(t){var e,n,i=Un;if(null!=t.aggregateOperation){if(!this.isNumeric_8xm3sj$(t.orderBy))throw d("Can't apply aggregate operation to non-numeric values".toString());var r,o=E(this.get_8xm3sj$(t.variable),this.getNumeric_8xm3sj$(t.orderBy)),a=D();for(r=o.iterator();r.hasNext();){var s,l=r.next(),u=l.component1(),p=a.get_11rb$(u);if(null==p){var h=c();a.put_xwzc9p$(u,h),s=h}else s=p;var _=s,f=_.add_11rb$,m=l.component2();f.call(_,m)}var y,$=B(M(a.size));for(y=a.entries.iterator();y.hasNext();){var v,g=y.next(),b=$.put_xwzc9p$,w=g.key,x=g.value,k=t.aggregateOperation,C=c();for(v=x.iterator();v.hasNext();){var j=v.next();i(j)&&C.add_11rb$(j)}b.call($,w,k.call(t,C))}e=S($)}else e=E(this.get_8xm3sj$(t.variable),this.get_8xm3sj$(t.orderBy));var L,R=e,I=c();for(L=R.iterator();L.hasNext();){var z=L.next();i(z.second)&&i(z.first)&&I.add_11rb$(z)}var U,F=O(I,T([Fn,qn])),q=c();for(U=F.iterator();U.hasNext();){var G;null!=(G=U.next().first)&&q.add_11rb$(G)}var H,Y=q,V=E(this.get_8xm3sj$(t.variable),this.get_8xm3sj$(t.orderBy)),K=c();for(H=V.iterator();H.hasNext();){var W=H.next();i(W.second)||K.add_11rb$(W)}var X,Z=c();for(X=K.iterator();X.hasNext();){var J;null!=(J=X.next().first)&&Z.add_11rb$(J)}var Q=Z;return n=t.direction<0?N(Y):Y,A(P(n,Q))},Gn.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Hn=null;function Yn(){return null===Hn&&new Gn,Hn}function Vn(){Ni(),this.myVectorByVar_8be2vx$=I(),this.myIsNumeric_8be2vx$=I(),this.myOrderSpecs_8be2vx$=c()}function Kn(){Oi=this}Vn.prototype.put_2l962d$=function(t,e){return this.putIntern_bxyhp4$(t,e),this.myIsNumeric_8be2vx$.remove_11rb$(t),this},Vn.prototype.putNumeric_s1rqo9$=function(t,e){return this.putIntern_bxyhp4$(t,e),this.myIsNumeric_8be2vx$.put_xwzc9p$(t,!0),this},Vn.prototype.putDiscrete_2l962d$=function(t,e){return this.putIntern_bxyhp4$(t,e),this.myIsNumeric_8be2vx$.put_xwzc9p$(t,!1),this},Vn.prototype.putIntern_bxyhp4$=function(t,e){var n=this.myVectorByVar_8be2vx$,i=R(e);n.put_xwzc9p$(t,i)},Vn.prototype.remove_8xm3sj$=function(t){return this.myVectorByVar_8be2vx$.remove_11rb$(t),this.myIsNumeric_8be2vx$.remove_11rb$(t),this},Vn.prototype.addOrderSpecs_l2t0xf$=function(t){var e,n=C("addOrderSpec",function(t,e){return t.addOrderSpec_22dbp4$(e)}.bind(null,this));for(e=t.iterator();e.hasNext();)n(e.next());return this},Vn.prototype.addOrderSpec_22dbp4$=function(t){var n,i=this.myOrderSpecs_8be2vx$;t:do{var r;for(r=i.iterator();r.hasNext();){var o=r.next();if(l(o.variable,t.variable)){n=o;break t}}n=null}while(0);var a=n;if(null==(null!=a?a.aggregateOperation:null)){var u,c=this.myOrderSpecs_8be2vx$;(e.isType(u=c,U)?u:s()).remove_11rb$(a),this.myOrderSpecs_8be2vx$.add_11rb$(t)}return this},Vn.prototype.build=function(){return new Nn(this)},Kn.prototype.emptyFrame=function(){return Pi().build()},Kn.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Wn,Xn,Zn,Jn,Qn,ti,ei,ni,ii,ri,oi,ai,si,li,ui,ci,pi,hi,_i,fi,di,mi,yi,$i,vi,gi,bi,wi,xi,ki,Ei,Ci,Si,Ti,Oi=null;function Ni(){return null===Oi&&new Kn,Oi}function Pi(t){return t=t||Object.create(Vn.prototype),Vn.call(t),t}function Ai(t,e){return e=e||Object.create(Vn.prototype),Vn.call(e),e.myVectorByVar_8be2vx$.putAll_a2k3zr$(t.myVectorByVar_0),e.myIsNumeric_8be2vx$.putAll_a2k3zr$(t.myIsNumeric_0),e.myOrderSpecs_8be2vx$.addAll_brywnq$(t.myOrderSpecs_0),e}function ji(){}function Li(t,e){var n;this.domainValues=t,this.domainLimits=e,this.numberByDomainValue_0=D(),this.domainValueByNumber_0=new G;var i=this.domainLimits.isEmpty()?this.domainValues:H(this.domainLimits,this.domainValues);for(this.numberByDomainValue_0.putAll_a2k3zr$(Ld().mapDiscreteDomainValuesToNumbers_7f6uoc$(i)),n=this.numberByDomainValue_0.entries.iterator();n.hasNext();){var r=n.next(),o=r.key,a=r.value;this.domainValueByNumber_0.put_ncwa5f$(a,o)}}function Ri(){}function Ii(){}function zi(t,e){w.call(this),this.name$=t,this.ordinal$=e}function Di(){Di=function(){},Wn=new zi("PATH",0),Xn=new zi("LINE",1),Zn=new zi("SMOOTH",2),Jn=new zi("BAR",3),Qn=new zi("HISTOGRAM",4),ti=new zi("TILE",5),ei=new zi("BIN_2D",6),ni=new zi("MAP",7),ii=new zi("ERROR_BAR",8),ri=new zi("CROSS_BAR",9),oi=new zi("LINE_RANGE",10),ai=new zi("POINT_RANGE",11),si=new zi("POLYGON",12),li=new zi("AB_LINE",13),ui=new zi("H_LINE",14),ci=new zi("V_LINE",15),pi=new zi("BOX_PLOT",16),hi=new zi("LIVE_MAP",17),_i=new zi("POINT",18),fi=new zi("RIBBON",19),di=new zi("AREA",20),mi=new zi("DENSITY",21),yi=new zi("CONTOUR",22),$i=new zi("CONTOURF",23),vi=new zi("DENSITY2D",24),gi=new zi("DENSITY2DF",25),bi=new zi("JITTER",26),wi=new zi("FREQPOLY",27),xi=new zi("STEP",28),ki=new zi("RECT",29),Ei=new zi("SEGMENT",30),Ci=new zi("TEXT",31),Si=new zi("RASTER",32),Ti=new zi("IMAGE",33)}function Mi(){return Di(),Wn}function Bi(){return Di(),Xn}function Ui(){return Di(),Zn}function Fi(){return Di(),Jn}function qi(){return Di(),Qn}function Gi(){return Di(),ti}function Hi(){return Di(),ei}function Yi(){return Di(),ni}function Vi(){return Di(),ii}function Ki(){return Di(),ri}function Wi(){return Di(),oi}function Xi(){return Di(),ai}function Zi(){return Di(),si}function Ji(){return Di(),li}function Qi(){return Di(),ui}function tr(){return Di(),ci}function er(){return Di(),pi}function nr(){return Di(),hi}function ir(){return Di(),_i}function rr(){return Di(),fi}function or(){return Di(),di}function ar(){return Di(),mi}function sr(){return Di(),yi}function lr(){return Di(),$i}function ur(){return Di(),vi}function cr(){return Di(),gi}function pr(){return Di(),bi}function hr(){return Di(),wi}function _r(){return Di(),xi}function fr(){return Di(),ki}function dr(){return Di(),Ei}function mr(){return Di(),Ci}function yr(){return Di(),Si}function $r(){return Di(),Ti}function vr(){gr=this,this.renderedAesByGeom_0=I(),this.POINT_0=X([Cn().X,Cn().Y,Cn().SIZE,Cn().COLOR,Cn().FILL,Cn().ALPHA,Cn().SHAPE]),this.PATH_0=X([Cn().X,Cn().Y,Cn().SIZE,Cn().LINETYPE,Cn().COLOR,Cn().ALPHA,Cn().SPEED,Cn().FLOW]),this.POLYGON_0=X([Cn().X,Cn().Y,Cn().SIZE,Cn().LINETYPE,Cn().COLOR,Cn().FILL,Cn().ALPHA]),this.AREA_0=X([Cn().X,Cn().Y,Cn().SIZE,Cn().LINETYPE,Cn().COLOR,Cn().FILL,Cn().ALPHA])}Vn.$metadata$={kind:h,simpleName:"Builder",interfaces:[]},Nn.$metadata$={kind:h,simpleName:"DataFrame",interfaces:[]},ji.prototype.defined_896ixz$=function(t){var e;if(t.isNumeric){var n=this.get_31786j$(t);return null!=n&&k("number"==typeof(e=n)?e:s())}return!0},ji.$metadata$={kind:f,simpleName:"DataPointAesthetics",interfaces:[]},Li.prototype.hasDomainLimits=function(){return!this.domainLimits.isEmpty()},Li.prototype.isInDomain_s8jyv4$=function(t){var n,i=this.numberByDomainValue_0;return(e.isType(n=i,Y)?n:s()).containsKey_11rb$(t)},Li.prototype.apply_9ma18$=function(t){var e,n=K(V(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.asNumber_0(i))}return n},Li.prototype.applyInverse_yrwdxb$=function(t){return this.fromNumber_0(t)},Li.prototype.asNumber_0=function(t){if(null==t)return null;if(this.numberByDomainValue_0.containsKey_11rb$(t))return this.numberByDomainValue_0.get_11rb$(t);throw q("value "+F(t)+" is not in the domain: "+this.numberByDomainValue_0.keys)},Li.prototype.fromNumber_0=function(t){var e;if(null==t)return null;if(this.domainValueByNumber_0.containsKey_mef7kx$(t))return this.domainValueByNumber_0.get_mef7kx$(t);var n=this.domainValueByNumber_0.ceilingKey_mef7kx$(t),i=this.domainValueByNumber_0.floorKey_mef7kx$(t),r=null;if(null!=n||null!=i){if(null==n)e=i;else if(null==i)e=n;else{var o=n-t,a=i-t;e=W.abs(o)0&&(l=this.alpha_il6rhx$(a,i)),t.update_mjoany$(o,s,a,l,r)},Qr.prototype.alpha_il6rhx$=function(t,e){return at.Colors.solid_98b62m$(t)?y(e.alpha()):st.SvgUtils.alpha2opacity_za3lpa$(t.alpha)},Qr.prototype.strokeWidth_l6g9mh$=function(t){return 2*y(t.size())},Qr.prototype.textSize_l6g9mh$=function(t){return 2*y(t.size())},Qr.prototype.updateStroke_g0plfl$=function(t,e,n){t.strokeColor().set_11rb$(e.color()),at.Colors.solid_98b62m$(y(e.color()))&&n&&t.strokeOpacity().set_11rb$(e.alpha())},Qr.prototype.updateFill_v4tjbc$=function(t,e){t.fillColor().set_11rb$(e.fill()),at.Colors.solid_98b62m$(y(e.fill()))&&t.fillOpacity().set_11rb$(e.alpha())},Qr.$metadata$={kind:p,simpleName:"AestheticsUtil",interfaces:[]};var to=null;function eo(){return null===to&&new Qr,to}function no(t){this.myMap_0=t}function io(){ro=this}no.prototype.get_31786j$=function(t){var e;return"function"==typeof(e=this.myMap_0.get_11rb$(t))?e:s()},no.$metadata$={kind:h,simpleName:"TypedIndexFunctionMap",interfaces:[]},io.prototype.create_wd6eaa$=function(t,e,n,i){void 0===n&&(n=null),void 0===i&&(i=null);var r=new lt(this.originX_0(t),this.originY_0(e));return this.create_e5yqp7$(r,n,i)},io.prototype.create_e5yqp7$=function(t,e,n){return void 0===e&&(e=null),void 0===n&&(n=null),new oo(this.toClientOffsetX_0(t.x),this.toClientOffsetY_0(t.y),this.fromClientOffsetX_0(t.x),this.fromClientOffsetY_0(t.y),e,n)},io.prototype.toClientOffsetX_4fzjta$=function(t){return this.toClientOffsetX_0(this.originX_0(t))},io.prototype.toClientOffsetY_4fzjta$=function(t){return this.toClientOffsetY_0(this.originY_0(t))},io.prototype.originX_0=function(t){return-t.lowerEnd},io.prototype.originY_0=function(t){return t.upperEnd},io.prototype.toClientOffsetX_0=function(t){return e=t,function(t){return e+t};var e},io.prototype.fromClientOffsetX_0=function(t){return e=t,function(t){return t-e};var e},io.prototype.toClientOffsetY_0=function(t){return e=t,function(t){return e-t};var e},io.prototype.fromClientOffsetY_0=function(t){return e=t,function(t){return e-t};var e},io.$metadata$={kind:p,simpleName:"Coords",interfaces:[]};var ro=null;function oo(t,e,n,i,r,o){this.myToClientOffsetX_0=t,this.myToClientOffsetY_0=e,this.myFromClientOffsetX_0=n,this.myFromClientOffsetY_0=i,this.xLim_0=r,this.yLim_0=o}function ao(){}function so(){uo=this}function lo(t,n){return e.compareTo(t.name,n.name)}oo.prototype.toClient_gpjtzr$=function(t){return new lt(this.myToClientOffsetX_0(t.x),this.myToClientOffsetY_0(t.y))},oo.prototype.fromClient_gpjtzr$=function(t){return new lt(this.myFromClientOffsetX_0(t.x),this.myFromClientOffsetY_0(t.y))},oo.prototype.isPointInLimits_k2qmv6$$default=function(t,e){var n,i,r,o,a=e?this.fromClient_gpjtzr$(t):t;return(null==(i=null!=(n=this.xLim_0)?n.contains_mef7kx$(a.x):null)||i)&&(null==(o=null!=(r=this.yLim_0)?r.contains_mef7kx$(a.y):null)||o)},oo.prototype.isRectInLimits_fd842m$$default=function(t,e){var n,i,r,o,a=e?new eu(this).fromClient_wthzt5$(t):t;return(null==(i=null!=(n=this.xLim_0)?n.encloses_d226ot$(a.xRange()):null)||i)&&(null==(o=null!=(r=this.yLim_0)?r.encloses_d226ot$(a.yRange()):null)||o)},oo.prototype.isPathInLimits_f6t8kh$$default=function(t,n){var i;t:do{var r;if(e.isType(t,g)&&t.isEmpty()){i=!1;break t}for(r=t.iterator();r.hasNext();){var o=r.next();if(this.isPointInLimits_k2qmv6$(o,n)){i=!0;break t}}i=!1}while(0);return i},oo.prototype.isPolygonInLimits_f6t8kh$$default=function(t,e){var n=ut.DoubleRectangles.boundingBox_qdtdbw$(t);return this.isRectInLimits_fd842m$(n,e)},Object.defineProperty(oo.prototype,"xClientLimit",{configurable:!0,get:function(){var t;return null!=(t=this.xLim_0)?this.convertRange_0(t,this.myToClientOffsetX_0):null}}),Object.defineProperty(oo.prototype,"yClientLimit",{configurable:!0,get:function(){var t;return null!=(t=this.yLim_0)?this.convertRange_0(t,this.myToClientOffsetY_0):null}}),oo.prototype.convertRange_0=function(t,e){var n=e(t.lowerEnd),i=e(t.upperEnd);return new et(o.Comparables.min_sdesaw$(n,i),o.Comparables.max_sdesaw$(n,i))},oo.$metadata$={kind:h,simpleName:"DefaultCoordinateSystem",interfaces:[On]},ao.$metadata$={kind:f,simpleName:"Projection",interfaces:[]},so.prototype.transformVarFor_896ixz$=function(t){return $o().forAes_896ixz$(t)},so.prototype.applyTransform_xaiv89$=function(t,e,n,i){var r=this.transformVarFor_896ixz$(n);return this.applyTransform_0(t,e,r,i)},so.prototype.applyTransform_0=function(t,e,n,i){var r=i.applyTransform_yzw12z$(t.get_8xm3sj$(e),!0);return t.builder().putNumeric_s1rqo9$(n,r).build()},so.prototype.hasVariable_vede35$=function(t,e){var n;for(n=t.variables().iterator();n.hasNext();){var i=n.next();if(l(e,i.name))return!0}return!1},so.prototype.findVariableOrFail_vede35$=function(t,e){var n;for(n=t.variables().iterator();n.hasNext();){var i=n.next();if(l(e,i.name))return i}var r,o="Variable not found: '"+e+"'. Variables in data frame: ",a=t.variables(),s=K(V(a,10));for(r=a.iterator();r.hasNext();){var u=r.next();s.add_11rb$("'"+u.name+"'")}throw d(o+s)},so.prototype.isNumeric_vede35$=function(t,e){return t.isNumeric_8xm3sj$(this.findVariableOrFail_vede35$(t,e))},so.prototype.sortedCopy_jgbhqw$=function(t){return ct.Companion.from_iajr8b$(new pt(lo)).sortedCopy_m5x2f4$(t)},so.prototype.variables_dhhkv7$=function(t){var e,n=t.variables(),i=ht("name",1,(function(t){return t.name})),r=_t(M(V(n,10)),16),o=B(r);for(e=n.iterator();e.hasNext();){var a=e.next();o.put_xwzc9p$(i(a),a)}return o},so.prototype.appendReplace_yxlle4$=function(t,n){var i,r,o=(r=this,function(t,n,i){var o,a=r;for(o=n.iterator();o.hasNext();){var s,l=o.next(),u=a.findVariableOrFail_vede35$(i,l.name);!0===(s=i.isNumeric_8xm3sj$(u))?t.putNumeric_s1rqo9$(l,i.getNumeric_8xm3sj$(u)):!1===s?t.putDiscrete_2l962d$(l,i.get_8xm3sj$(u)):e.noWhenBranchMatched()}return t}),a=Pi(),l=t.variables(),u=c();for(i=l.iterator();i.hasNext();){var p,h=i.next(),_=this.variables_dhhkv7$(n),f=h.name;(e.isType(p=_,Y)?p:s()).containsKey_11rb$(f)||u.add_11rb$(h)}var d,m=o(a,u,t),y=t.variables(),$=c();for(d=y.iterator();d.hasNext();){var v,g=d.next(),b=this.variables_dhhkv7$(n),w=g.name;(e.isType(v=b,Y)?v:s()).containsKey_11rb$(w)&&$.add_11rb$(g)}var x,k=o(m,$,n),E=n.variables(),C=c();for(x=E.iterator();x.hasNext();){var S,T=x.next(),O=this.variables_dhhkv7$(t),N=T.name;(e.isType(S=O,Y)?S:s()).containsKey_11rb$(N)||C.add_11rb$(T)}return o(k,C,n).build()},so.prototype.toMap_dhhkv7$=function(t){var e,n=I();for(e=t.variables().iterator();e.hasNext();){var i=e.next(),r=i.name,o=t.get_8xm3sj$(i);n.put_xwzc9p$(r,o)}return n},so.prototype.fromMap_bkhwtg$=function(t){var n,i=Pi();for(n=t.entries.iterator();n.hasNext();){var r=n.next(),o=r.key,a=r.value;if("string"!=typeof o){var s="Map to data-frame: key expected a String but was "+e.getKClassFromExpression(y(o)).simpleName+" : "+F(o);throw d(s.toString())}if(!e.isType(a,u)){var l="Map to data-frame: value expected a List but was "+e.getKClassFromExpression(y(a)).simpleName+" : "+F(a);throw d(l.toString())}i.put_2l962d$(this.createVariable_puj7f4$(o),a)}return i.build()},so.prototype.createVariable_puj7f4$=function(t,e){return void 0===e&&(e=t),$o().isTransformVar_61zpoe$(t)?$o().get_61zpoe$(t):Rv().isStatVar_61zpoe$(t)?Rv().statVar_61zpoe$(t):_o().isDummyVar_61zpoe$(t)?_o().newDummy_61zpoe$(t):new An(t,Rn(),e)},so.prototype.getSummaryText_dhhkv7$=function(t){var e,n=m();for(e=t.variables().iterator();e.hasNext();){var i=e.next();n.append_pdl1vj$(i.toSummaryString()).append_pdl1vj$(" numeric: "+F(t.isNumeric_8xm3sj$(i))).append_pdl1vj$(" size: "+F(t.get_8xm3sj$(i).size)).append_s8itvh$(10)}return n.toString()},so.prototype.removeAllExcept_dipqvu$=function(t,e){var n,i=t.builder();for(n=t.variables().iterator();n.hasNext();){var r=n.next();e.contains_11rb$(r.name)||i.remove_8xm3sj$(r)}return i.build()},so.$metadata$={kind:p,simpleName:"DataFrameUtil",interfaces:[]};var uo=null;function co(){return null===uo&&new so,uo}function po(){ho=this,this.PREFIX_0="__"}po.prototype.isDummyVar_61zpoe$=function(t){if(!ft.Strings.isNullOrEmpty_pdl1vj$(t)&&t.length>2&&dt(t,this.PREFIX_0)){var e=t.substring(2);return mt("[0-9]+").matches_6bul2c$(e)}return!1},po.prototype.dummyNames_za3lpa$=function(t){for(var e=c(),n=0;nb.SeriesUtil.TINY))throw d(("x-step is too small: "+h).toString());if(!(_>b.SeriesUtil.TINY))throw d(("y-step is too small: "+_).toString());var f=At(p.dimension.x/h)+1,m=At(p.dimension.y/_)+1;if(f*m>5e6){var $=p.center,v=["Raster image size","["+f+" X "+m+"]","exceeds capability","of","your imaging device"],g=$.y+16*v.length/2;for(a=0;a!==v.length;++a){var w=new ld(v[a]);w.textColor().set_11rb$(tt.Companion.DARK_MAGENTA),w.textOpacity().set_11rb$(.5),w.setFontSize_14dthe$(12),w.setFontWeight_pdl1vj$("bold"),w.setHorizontalAnchor_ja80zo$(fd()),w.setVerticalAnchor_yaudma$(vd());var x=c.toClient_vf7nkp$($.x,g,u);w.moveTo_gpjtzr$(x),t.add_26jijc$(w.rootGroup),g-=16}}else{var k=jt(At(f)),E=jt(At(m)),C=new lt(.5*h,.5*_),S=c.toClient_tkjljq$(p.origin.subtract_gpjtzr$(C),u),T=c.toClient_tkjljq$(p.origin.add_gpjtzr$(p.dimension).add_gpjtzr$(C),u),O=T.x=0?(n=new lt(r-a/2,0),i=new lt(a,o)):(n=new lt(r-a/2,o),i=new lt(a,-o)),new bt(n,i)},su.prototype.createGroups_83glv4$=function(t){var e,n=I();for(e=t.iterator();e.hasNext();){var i=e.next(),r=y(i.group());if(!n.containsKey_11rb$(r)){var o=c();n.put_xwzc9p$(r,o)}y(n.get_11rb$(r)).add_11rb$(i)}return n},su.prototype.rectToGeometry_6y0v78$=function(t,e,n,i){return X([new lt(t,e),new lt(t,i),new lt(n,i),new lt(n,e),new lt(t,e)])},lu.prototype.compare=function(t,n){var i=null!=t?t.x():null,r=null!=n?n.x():null;return null==i||null==r?0:e.compareTo(i,r)},lu.$metadata$={kind:h,interfaces:[pt]},uu.prototype.compare=function(t,n){var i=null!=t?t.y():null,r=null!=n?n.y():null;return null==i||null==r?0:e.compareTo(i,r)},uu.$metadata$={kind:h,interfaces:[pt]},su.$metadata$={kind:p,simpleName:"GeomUtil",interfaces:[]};var _u=null;function fu(){return null===_u&&new su,_u}function du(){mu=this}du.prototype.fromColor_l6g9mh$=function(t){return this.fromColorValue_o14uds$(y(t.color()),y(t.alpha()))},du.prototype.fromFill_l6g9mh$=function(t){return this.fromColorValue_o14uds$(y(t.fill()),y(t.alpha()))},du.prototype.fromColorValue_o14uds$=function(t,e){var n=jt(255*e);return at.Colors.solid_98b62m$(t)?t.changeAlpha_za3lpa$(n):t},du.$metadata$={kind:p,simpleName:"HintColorUtil",interfaces:[]};var mu=null;function yu(){return null===mu&&new du,mu}function $u(t,e){this.myPoint_0=t,this.myHelper_0=e,this.myHints_0=I()}function vu(){this.myDefaultObjectRadius_0=null,this.myDefaultX_0=null,this.myDefaultColor_0=null,this.myDefaultKind_0=null}function gu(t,e){this.$outer=t,this.aes=e,this.kind=null,this.objectRadius_u2tfw5$_0=null,this.x_is741i$_0=null,this.color_8be2vx$_ng3d4v$_0=null,this.objectRadius=this.$outer.myDefaultObjectRadius_0,this.x=this.$outer.myDefaultX_0,this.kind=this.$outer.myDefaultKind_0,this.color_8be2vx$=this.$outer.myDefaultColor_0}function bu(t,e,n,i){ku(),this.myTargetCollector_0=t,this.myDataPoints_0=e,this.myLinesHelper_0=n,this.myClosePath_0=i}function wu(){xu=this,this.DROP_POINT_DISTANCE_0=.999}Object.defineProperty($u.prototype,"hints",{configurable:!0,get:function(){return this.myHints_0}}),$u.prototype.addHint_p9kkqu$=function(t){var e=this.getCoord_0(t);if(null!=e){var n=this.hints,i=t.aes,r=this.createHint_0(t,e);n.put_xwzc9p$(i,r)}return this},$u.prototype.getCoord_0=function(t){if(null==t.x)throw d("x coord is not set");var e=t.aes;return this.myPoint_0.defined_896ixz$(e)?this.myHelper_0.toClient_tkjljq$(new lt(y(t.x),y(this.myPoint_0.get_31786j$(e))),this.myPoint_0):null},$u.prototype.createHint_0=function(t,e){var n,i,r=t.objectRadius,o=t.color_8be2vx$;if(null==r)throw d("object radius is not set");if(n=t.kind,l(n,tp()))i=gp().verticalTooltip_6lq1u6$(e,r,o);else if(l(n,ep()))i=gp().horizontalTooltip_6lq1u6$(e,r,o);else{if(!l(n,np()))throw d("Unknown hint kind: "+F(t.kind));i=gp().cursorTooltip_itpcqk$(e,o)}return i},vu.prototype.defaultObjectRadius_14dthe$=function(t){return this.myDefaultObjectRadius_0=t,this},vu.prototype.defaultX_14dthe$=function(t){return this.myDefaultX_0=t,this},vu.prototype.defaultColor_yo1m5r$=function(t,e){return this.myDefaultColor_0=null!=e?t.changeAlpha_za3lpa$(jt(255*e)):t,this},vu.prototype.create_vktour$=function(t){return new gu(this,t)},vu.prototype.defaultKind_nnfttk$=function(t){return this.myDefaultKind_0=t,this},Object.defineProperty(gu.prototype,"objectRadius",{configurable:!0,get:function(){return this.objectRadius_u2tfw5$_0},set:function(t){this.objectRadius_u2tfw5$_0=t}}),Object.defineProperty(gu.prototype,"x",{configurable:!0,get:function(){return this.x_is741i$_0},set:function(t){this.x_is741i$_0=t}}),Object.defineProperty(gu.prototype,"color_8be2vx$",{configurable:!0,get:function(){return this.color_8be2vx$_ng3d4v$_0},set:function(t){this.color_8be2vx$_ng3d4v$_0=t}}),gu.prototype.objectRadius_14dthe$=function(t){return this.objectRadius=t,this},gu.prototype.x_14dthe$=function(t){return this.x=t,this},gu.prototype.color_98b62m$=function(t){return this.color_8be2vx$=t,this},gu.$metadata$={kind:h,simpleName:"HintConfig",interfaces:[]},vu.$metadata$={kind:h,simpleName:"HintConfigFactory",interfaces:[]},$u.$metadata$={kind:h,simpleName:"HintsCollection",interfaces:[]},bu.prototype.construct_6taknv$=function(t){var e,n=c(),i=this.createMultiPointDataByGroup_0();for(e=i.iterator();e.hasNext();){var r=e.next();n.addAll_brywnq$(this.myLinesHelper_0.createPaths_edlkk9$(r.aes,r.points,this.myClosePath_0))}return t&&this.buildHints_0(i),n},bu.prototype.buildHints=function(){this.buildHints_0(this.createMultiPointDataByGroup_0())},bu.prototype.buildHints_0=function(t){var e;for(e=t.iterator();e.hasNext();){var n=e.next();this.myClosePath_0?this.myTargetCollector_0.addPolygon_sa5m83$(n.points,n.localToGlobalIndex,nc().params().setColor_98b62m$(yu().fromFill_l6g9mh$(n.aes))):this.myTargetCollector_0.addPath_sa5m83$(n.points,n.localToGlobalIndex,nc().params().setColor_98b62m$(yu().fromColor_l6g9mh$(n.aes)))}},bu.prototype.createMultiPointDataByGroup_0=function(){return Bu().createMultiPointDataByGroup_ugj9hh$(this.myDataPoints_0,Bu().singlePointAppender_v9bvvf$((t=this,function(e){return t.myLinesHelper_0.toClient_tkjljq$(y(fu().TO_LOCATION_X_Y(e)),e)})),Bu().reducer_8555vt$(ku().DROP_POINT_DISTANCE_0,this.myClosePath_0));var t},wu.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var xu=null;function ku(){return null===xu&&new wu,xu}function Eu(t,e,n){nu.call(this,t,e,n),this.myAlphaFilter_nxoahd$_0=Ou,this.myWidthFilter_sx37fb$_0=Nu,this.myAlphaEnabled_98jfa$_0=!0}function Cu(t){return function(e){return t(e)}}function Su(t){return function(e){return t(e)}}function Tu(t){this.path=t}function Ou(t){return t}function Nu(t){return t}function Pu(t,e){this.myAesthetics_0=t,this.myPointAestheticsMapper_0=e}function Au(t,e,n,i){this.aes=t,this.points=e,this.localToGlobalIndex=n,this.group=i}function ju(){Mu=this}function Lu(){return new zu}function Ru(){}function Iu(t,e){this.myCoordinateAppender_0=t,this.myPointCollector_0=e,this.myFirstAes_0=null}function zu(){this.myPoints_0=c(),this.myIndexes_0=c()}function Du(t,e){this.myDropPointDistance_0=t,this.myPolygon_0=e,this.myReducedPoints_0=c(),this.myReducedIndexes_0=c(),this.myLastAdded_0=null,this.myLastPostponed_0=null,this.myRegionStart_0=null}bu.$metadata$={kind:h,simpleName:"LinePathConstructor",interfaces:[]},Eu.prototype.insertPathSeparators_fr5rf4$_0=function(t){var e,n=c();for(e=t.iterator();e.hasNext();){var i=e.next();n.isEmpty()||n.add_11rb$(Ff().END_OF_SUBPATH),n.addAll_brywnq$(i)}return n},Eu.prototype.setAlphaEnabled_6taknv$=function(t){this.myAlphaEnabled_98jfa$_0=t},Eu.prototype.createLines_rrreuh$=function(t,e){return this.createPaths_gfkrhx$_0(t,e,!1)},Eu.prototype.createPaths_gfkrhx$_0=function(t,e,n){var i,r=c();for(i=Bu().createMultiPointDataByGroup_ugj9hh$(t,Bu().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(function(t){return function(e){return t(e)}}(e))),Bu().reducer_8555vt$(.999,n)).iterator();i.hasNext();){var o=i.next();r.addAll_brywnq$(this.createPaths_edlkk9$(o.aes,o.points,n))}return r},Eu.prototype.createPaths_edlkk9$=function(t,e,n){var i,r=c();for(n?r.add_11rb$(Ff().polygon_yh26e7$(this.insertPathSeparators_fr5rf4$_0(Gt(e)))):r.add_11rb$(Ff().line_qdtdbw$(e)),i=r.iterator();i.hasNext();){var o=i.next();this.decorate_frjrd5$(o,t,n)}return r},Eu.prototype.createSteps_1fp004$=function(t,e){var n,i,r=c();for(n=Bu().createMultiPointDataByGroup_ugj9hh$(t,Bu().singlePointAppender_v9bvvf$(this.toClientLocation_sfitzs$(fu().TO_LOCATION_X_Y)),Bu().reducer_8555vt$(.999,!1)).iterator();n.hasNext();){var o=n.next(),a=o.points;if(!a.isEmpty()){var s=c(),l=null;for(i=a.iterator();i.hasNext();){var u=i.next();if(null!=l){var p=e===ol()?u.x:l.x,h=e===ol()?l.y:u.y;s.add_11rb$(new lt(p,h))}s.add_11rb$(u),l=u}var _=Ff().line_qdtdbw$(s);this.decorate_frjrd5$(_,o.aes,!1),r.add_11rb$(new Tu(_))}}return r},Eu.prototype.createBands_22uu1u$=function(t,e,n){var i,r=c(),o=fu().createGroups_83glv4$(t);for(i=ct.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(o.keys).iterator();i.hasNext();){var a=i.next(),s=o.get_11rb$(a),l=R(this.project_rrreuh$(y(s),Cu(e))),u=N(s);if(l.addAll_brywnq$(this.project_rrreuh$(u,Su(n))),!l.isEmpty()){var p=Ff().polygon_yh26e7$(l);this.decorateFillingPart_e7h5w8$_0(p,s.get_za3lpa$(0)),r.add_11rb$(p)}}return r},Eu.prototype.decorate_frjrd5$=function(t,e,n){var i=e.color(),r=y(this.myAlphaFilter_nxoahd$_0(eo().alpha_il6rhx$(y(i),e)));t.color().set_11rb$(at.Colors.withOpacity_o14uds$(i,r)),eo().ALPHA_CONTROLS_BOTH_8be2vx$||!n&&this.myAlphaEnabled_98jfa$_0||t.color().set_11rb$(i),n&&this.decorateFillingPart_e7h5w8$_0(t,e);var o=y(this.myWidthFilter_sx37fb$_0(jr().strokeWidth_l6g9mh$(e)));t.width().set_11rb$(o);var a=e.lineType();a.isBlank||a.isSolid||t.dashArray().set_11rb$(a.dashArray)},Eu.prototype.decorateFillingPart_e7h5w8$_0=function(t,e){var n=e.fill(),i=y(this.myAlphaFilter_nxoahd$_0(eo().alpha_il6rhx$(y(n),e)));t.fill().set_11rb$(at.Colors.withOpacity_o14uds$(n,i))},Eu.prototype.setAlphaFilter_m9g0ow$=function(t){this.myAlphaFilter_nxoahd$_0=t},Eu.prototype.setWidthFilter_m9g0ow$=function(t){this.myWidthFilter_sx37fb$_0=t},Tu.$metadata$={kind:h,simpleName:"PathInfo",interfaces:[]},Eu.$metadata$={kind:h,simpleName:"LinesHelper",interfaces:[nu]},Object.defineProperty(Pu.prototype,"isEmpty",{configurable:!0,get:function(){return this.myAesthetics_0.isEmpty}}),Pu.prototype.dataPointAt_za3lpa$=function(t){return this.myPointAestheticsMapper_0(this.myAesthetics_0.dataPointAt_za3lpa$(t))},Pu.prototype.dataPointCount=function(){return this.myAesthetics_0.dataPointCount()},Pu.prototype.dataPoints=function(){var t,e=this.myAesthetics_0.dataPoints(),n=K(V(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(this.myPointAestheticsMapper_0(i))}return n},Pu.prototype.range_vktour$=function(t){throw q("MappedAesthetics.range: not implemented "+t)},Pu.prototype.overallRange_vktour$=function(t){throw q("MappedAesthetics.overallRange: not implemented "+t)},Pu.prototype.resolution_594811$=function(t,e){throw q("MappedAesthetics.resolution: not implemented "+t)},Pu.prototype.numericValues_vktour$=function(t){throw q("MappedAesthetics.numericValues: not implemented "+t)},Pu.prototype.groups=function(){return this.myAesthetics_0.groups()},Pu.$metadata$={kind:h,simpleName:"MappedAesthetics",interfaces:[Sn]},Au.$metadata$={kind:h,simpleName:"MultiPointData",interfaces:[]},ju.prototype.collector=function(){return Lu},ju.prototype.reducer_8555vt$=function(t,e){return n=t,i=e,function(){return new Du(n,i)};var n,i},ju.prototype.singlePointAppender_v9bvvf$=function(t){return e=t,function(t,n){return n(e(t)),Z};var e},ju.prototype.multiPointAppender_t2aup3$=function(t){return e=t,function(t,n){var i;for(i=e(t).iterator();i.hasNext();)n(i.next());return Z};var e},ju.prototype.createMultiPointDataByGroup_ugj9hh$=function(t,n,i){var r,o,a=I();for(r=t.iterator();r.hasNext();){var l,u,p=r.next(),h=p.group();if(!(e.isType(l=a,Y)?l:s()).containsKey_11rb$(h)){var _=y(h),f=new Iu(n,i());a.put_xwzc9p$(_,f)}y((e.isType(u=a,Y)?u:s()).get_11rb$(h)).add_lsjzq4$(p)}var d=c();for(o=ct.Companion.natural_dahdeg$().sortedCopy_m5x2f4$(a.keys).iterator();o.hasNext();){var m=o.next(),$=y(a.get_11rb$(m)).create_kcn2v3$(m);$.points.isEmpty()||d.add_11rb$($)}return d},Ru.$metadata$={kind:f,simpleName:"PointCollector",interfaces:[]},Iu.prototype.add_lsjzq4$=function(t){var e,n;null==this.myFirstAes_0&&(this.myFirstAes_0=t),this.myCoordinateAppender_0(t,(e=this,n=t,function(t){return e.myPointCollector_0.add_aqrfag$(t,n.index()),Z}))},Iu.prototype.create_kcn2v3$=function(t){var e,n=this.myPointCollector_0.points;return new Au(y(this.myFirstAes_0),n.first,(e=n,function(t){return e.second.get_za3lpa$(t)}),t)},Iu.$metadata$={kind:h,simpleName:"MultiPointDataCombiner",interfaces:[]},Object.defineProperty(zu.prototype,"points",{configurable:!0,get:function(){return new Ht(this.myPoints_0,this.myIndexes_0)}}),zu.prototype.add_aqrfag$=function(t,e){this.myPoints_0.add_11rb$(y(t)),this.myIndexes_0.add_11rb$(e)},zu.$metadata$={kind:h,simpleName:"SimplePointCollector",interfaces:[Ru]},Object.defineProperty(Du.prototype,"points",{configurable:!0,get:function(){return null!=this.myLastPostponed_0&&(this.addPoint_0(y(this.myLastPostponed_0).first,y(this.myLastPostponed_0).second),this.myLastPostponed_0=null),new Ht(this.myReducedPoints_0,this.myReducedIndexes_0)}}),Du.prototype.isCloserThan_0=function(t,e,n){var i=t.x-e.x,r=W.abs(i)=0){var _=y(u),f=y(r.get_11rb$(u))+h;r.put_xwzc9p$(_,f)}else{var d=y(u),m=y(o.get_11rb$(u))-h;o.put_xwzc9p$(d,m)}}}var $=I();i=t.dataPointCount();for(var v=0;v=0;if(C&&(C=y((e.isType(E=r,Y)?E:s()).get_11rb$(x))>0),C){var S,T=1/y((e.isType(S=r,Y)?S:s()).get_11rb$(x));$.put_xwzc9p$(v,T)}else{var O,N=k<0;if(N&&(N=y((e.isType(O=o,Y)?O:s()).get_11rb$(x))>0),N){var P,A=1/y((e.isType(P=o,Y)?P:s()).get_11rb$(x));$.put_xwzc9p$(v,A)}else $.put_xwzc9p$(v,1)}}else $.put_xwzc9p$(v,1)}return $},Kp.prototype.translate_tshsjz$=function(t,e,n){var i=this.myStackPosHelper_0.translate_tshsjz$(t,e,n);return new lt(i.x,i.y*y(this.myScalerByIndex_0.get_11rb$(e.index()))*n.getUnitResolution_vktour$(Cn().Y))},Kp.prototype.handlesGroups=function(){return gh().handlesGroups()},Kp.$metadata$={kind:h,simpleName:"FillPos",interfaces:[br]},Wp.prototype.translate_tshsjz$=function(t,e,n){var i=this.myJitterPosHelper_0.translate_tshsjz$(t,e,n);return this.myDodgePosHelper_0.translate_tshsjz$(i,e,n)},Wp.prototype.handlesGroups=function(){return xh().handlesGroups()},Wp.$metadata$={kind:h,simpleName:"JitterDodgePos",interfaces:[br]},Xp.prototype.translate_tshsjz$=function(t,e,n){var i=(2*Kt.Default.nextDouble()-1)*this.myWidth_0*n.getResolution_vktour$(Cn().X),r=(2*Kt.Default.nextDouble()-1)*this.myHeight_0*n.getResolution_vktour$(Cn().Y);return t.add_gpjtzr$(new lt(i,r))},Xp.prototype.handlesGroups=function(){return bh().handlesGroups()},Zp.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Jp=null;function Qp(){return null===Jp&&new Zp,Jp}function th(t,e){hh(),this.myWidth_0=0,this.myHeight_0=0,this.myWidth_0=null!=t?t:hh().DEF_NUDGE_WIDTH,this.myHeight_0=null!=e?e:hh().DEF_NUDGE_HEIGHT}function eh(){ph=this,this.DEF_NUDGE_WIDTH=0,this.DEF_NUDGE_HEIGHT=0}Xp.$metadata$={kind:h,simpleName:"JitterPos",interfaces:[br]},th.prototype.translate_tshsjz$=function(t,e,n){var i=this.myWidth_0*n.getUnitResolution_vktour$(Cn().X),r=this.myHeight_0*n.getUnitResolution_vktour$(Cn().Y);return t.add_gpjtzr$(new lt(i,r))},th.prototype.handlesGroups=function(){return wh().handlesGroups()},eh.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var nh,ih,rh,oh,ah,sh,lh,uh,ch,ph=null;function hh(){return null===ph&&new eh,ph}function _h(){Th=this}function fh(){}function dh(t,e,n){w.call(this),this.myHandlesGroups_39qcox$_0=n,this.name$=t,this.ordinal$=e}function mh(){mh=function(){},nh=new dh("IDENTITY",0,!1),ih=new dh("DODGE",1,!0),rh=new dh("STACK",2,!0),oh=new dh("FILL",3,!0),ah=new dh("JITTER",4,!1),sh=new dh("NUDGE",5,!1),lh=new dh("JITTER_DODGE",6,!0)}function yh(){return mh(),nh}function $h(){return mh(),ih}function vh(){return mh(),rh}function gh(){return mh(),oh}function bh(){return mh(),ah}function wh(){return mh(),sh}function xh(){return mh(),lh}function kh(t,e){w.call(this),this.name$=t,this.ordinal$=e}function Eh(){Eh=function(){},uh=new kh("SUM_POSITIVE_NEGATIVE",0),ch=new kh("SPLIT_POSITIVE_NEGATIVE",1)}function Ch(){return Eh(),uh}function Sh(){return Eh(),ch}th.$metadata$={kind:h,simpleName:"NudgePos",interfaces:[br]},Object.defineProperty(fh.prototype,"isIdentity",{configurable:!0,get:function(){return!0}}),fh.prototype.translate_tshsjz$=function(t,e,n){return t},fh.prototype.handlesGroups=function(){return yh().handlesGroups()},fh.$metadata$={kind:h,interfaces:[br]},_h.prototype.identity=function(){return new fh},_h.prototype.dodge_vvhcz8$=function(t,e,n){return new Vp(t,e,n)},_h.prototype.stack_4vnpmn$=function(t,n){var i;switch(n.name){case"SPLIT_POSITIVE_NEGATIVE":i=Lh().splitPositiveNegative_m7huy5$(t);break;case"SUM_POSITIVE_NEGATIVE":i=Lh().sumPositiveNegative_m7huy5$(t);break;default:i=e.noWhenBranchMatched()}return i},_h.prototype.fill_m7huy5$=function(t){return new Kp(t)},_h.prototype.jitter_jma9l8$=function(t,e){return new Xp(t,e)},_h.prototype.nudge_jma9l8$=function(t,e){return new th(t,e)},_h.prototype.jitterDodge_e2pc44$=function(t,e,n,i,r){return new Wp(t,e,n,i,r)},dh.prototype.handlesGroups=function(){return this.myHandlesGroups_39qcox$_0},dh.$metadata$={kind:h,simpleName:"Meta",interfaces:[w]},dh.values=function(){return[yh(),$h(),vh(),gh(),bh(),wh(),xh()]},dh.valueOf_61zpoe$=function(t){switch(t){case"IDENTITY":return yh();case"DODGE":return $h();case"STACK":return vh();case"FILL":return gh();case"JITTER":return bh();case"NUDGE":return wh();case"JITTER_DODGE":return xh();default:x("No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.Meta."+t)}},kh.$metadata$={kind:h,simpleName:"StackingStrategy",interfaces:[w]},kh.values=function(){return[Ch(),Sh()]},kh.valueOf_61zpoe$=function(t){switch(t){case"SUM_POSITIVE_NEGATIVE":return Ch();case"SPLIT_POSITIVE_NEGATIVE":return Sh();default:x("No enum constant jetbrains.datalore.plot.base.pos.PositionAdjustments.StackingStrategy."+t)}},_h.$metadata$={kind:p,simpleName:"PositionAdjustments",interfaces:[]};var Th=null;function Oh(t){Lh(),this.myOffsetByIndex_0=null,this.myOffsetByIndex_0=this.mapIndexToOffset_m7huy5$(t)}function Nh(t){Oh.call(this,t)}function Ph(t){Oh.call(this,t)}function Ah(){jh=this}Oh.prototype.translate_tshsjz$=function(t,e,n){return t.add_gpjtzr$(new lt(0,y(this.myOffsetByIndex_0.get_11rb$(e.index()))))},Oh.prototype.handlesGroups=function(){return vh().handlesGroups()},Nh.prototype.mapIndexToOffset_m7huy5$=function(t){var n,i=I(),r=I();n=t.dataPointCount();for(var o=0;o=0?f.second.getAndAdd_14dthe$(h):f.first.getAndAdd_14dthe$(h);i.put_xwzc9p$(o,d)}}}return i},Nh.$metadata$={kind:h,simpleName:"SplitPositiveNegative",interfaces:[Oh]},Ph.prototype.mapIndexToOffset_m7huy5$=function(t){var e,n=I(),i=I();e=t.dataPointCount();for(var r=0;r0&&r.append_s8itvh$(44),r.append_pdl1vj$(o.toString())}t.getAttribute_61zpoe$(st.SvgConstants.SVG_STROKE_DASHARRAY_ATTRIBUTE).set_11rb$(r.toString())},qf.$metadata$={kind:p,simpleName:"StrokeDashArraySupport",interfaces:[]};var Gf=null;function Hf(){return null===Gf&&new qf,Gf}function Yf(){Xf(),this.myIsBuilt_hfl4wb$_0=!1,this.myIsBuilding_wftuqx$_0=!1,this.myRootGroup_34n42m$_0=new kt,this.myChildComponents_jx3u37$_0=c(),this.myOrigin_c2o9zl$_0=lt.Companion.ZERO,this.myRotationAngle_woxwye$_0=0,this.myCompositeRegistration_t8l21t$_0=new ne([])}function Vf(t){this.this$SvgComponent=t}function Kf(){Wf=this,this.CLIP_PATH_ID_PREFIX=""}Object.defineProperty(Yf.prototype,"childComponents",{configurable:!0,get:function(){if(!this.myIsBuilt_hfl4wb$_0)throw d("Plot has not yet built".toString());return R(this.myChildComponents_jx3u37$_0)}}),Object.defineProperty(Yf.prototype,"rootGroup",{configurable:!0,get:function(){return this.ensureBuilt(),this.myRootGroup_34n42m$_0}}),Yf.prototype.ensureBuilt=function(){this.myIsBuilt_hfl4wb$_0||this.myIsBuilding_wftuqx$_0||this.buildComponentIntern_92lbvk$_0()},Yf.prototype.buildComponentIntern_92lbvk$_0=function(){try{this.myIsBuilding_wftuqx$_0=!0,this.buildComponent()}finally{this.myIsBuilding_wftuqx$_0=!1,this.myIsBuilt_hfl4wb$_0=!0}},Vf.prototype.onEvent_11rb$=function(t){this.this$SvgComponent.needRebuild()},Vf.$metadata$={kind:h,interfaces:[ee]},Yf.prototype.rebuildHandler_287e2$=function(){return new Vf(this)},Yf.prototype.needRebuild=function(){this.myIsBuilt_hfl4wb$_0&&(this.clear(),this.buildComponentIntern_92lbvk$_0())},Yf.prototype.reg_3xv6fb$=function(t){this.myCompositeRegistration_t8l21t$_0.add_3xv6fb$(t)},Yf.prototype.clear=function(){var t;for(this.myIsBuilt_hfl4wb$_0=!1,t=this.myChildComponents_jx3u37$_0.iterator();t.hasNext();)t.next().clear();this.myChildComponents_jx3u37$_0.clear(),this.myRootGroup_34n42m$_0.children().clear(),this.myCompositeRegistration_t8l21t$_0.remove(),this.myCompositeRegistration_t8l21t$_0=new ne([])},Yf.prototype.add_8icvvv$=function(t){this.myChildComponents_jx3u37$_0.add_11rb$(t),this.add_26jijc$(t.rootGroup)},Yf.prototype.add_26jijc$=function(t){this.myRootGroup_34n42m$_0.children().add_11rb$(t)},Yf.prototype.moveTo_gpjtzr$=function(t){this.myOrigin_c2o9zl$_0=t,this.myRootGroup_34n42m$_0.transform().set_11rb$(Xf().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0,this.myRotationAngle_woxwye$_0))},Yf.prototype.moveTo_lu1900$=function(t,e){this.moveTo_gpjtzr$(new lt(t,e))},Yf.prototype.rotate_14dthe$=function(t){this.myRotationAngle_woxwye$_0=t,this.myRootGroup_34n42m$_0.transform().set_11rb$(Xf().buildTransform_e1sv3v$(this.myOrigin_c2o9zl$_0,this.myRotationAngle_woxwye$_0))},Yf.prototype.toRelativeCoordinates_gpjtzr$=function(t){return this.rootGroup.pointToTransformedCoordinates_gpjtzr$(t)},Yf.prototype.toAbsoluteCoordinates_gpjtzr$=function(t){return this.rootGroup.pointToAbsoluteCoordinates_gpjtzr$(t)},Yf.prototype.clipBounds_wthzt5$=function(t){var e=new ie;e.id().set_11rb$(sd().get_61zpoe$(Xf().CLIP_PATH_ID_PREFIX));var n=e.children(),i=new re;i.x().set_11rb$(t.left),i.y().set_11rb$(t.top),i.width().set_11rb$(t.width),i.height().set_11rb$(t.height),n.add_11rb$(i);var r=e,o=new oe;o.children().add_11rb$(r);var a=o;this.add_26jijc$(a),this.rootGroup.clipPath().set_11rb$(new ae(y(r.id().get()))),this.rootGroup.setAttribute_qdh7ux$(se.Companion.CLIP_BOUNDS_JFX,t)},Yf.prototype.addClassName_61zpoe$=function(t){this.myRootGroup_34n42m$_0.addClass_61zpoe$(t)},Kf.prototype.buildTransform_e1sv3v$=function(t,e){var n=new le;return null!=t&&t.equals(lt.Companion.ZERO)||n.translate_lu1900$(t.x,t.y),0!==e&&n.rotate_14dthe$(e),n.build()},Kf.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Wf=null;function Xf(){return null===Wf&&new Kf,Wf}function Zf(){ad=this,this.suffixGen_0=Qf}function Jf(){this.nextIndex_0=0}function Qf(){return ue.RandomString.randomString_za3lpa$(6)}Yf.$metadata$={kind:h,simpleName:"SvgComponent",interfaces:[]},Zf.prototype.setUpForTest=function(){var t,e=new Jf;this.suffixGen_0=(t=e,function(){return t.next()})},Zf.prototype.get_61zpoe$=function(t){return t+this.suffixGen_0().toString()},Jf.prototype.next=function(){var t;return"clip-"+(t=this.nextIndex_0,this.nextIndex_0=t+1|0,t)},Jf.$metadata$={kind:h,simpleName:"IncrementalId",interfaces:[]},Zf.$metadata$={kind:p,simpleName:"SvgUID",interfaces:[]};var td,ed,nd,id,rd,od,ad=null;function sd(){return null===ad&&new Zf,ad}function ld(t){Yf.call(this),this.myText_0=ce(t),this.myTextColor_0=null,this.myFontSize_0=0,this.myFontWeight_0=null,this.myFontFamily_0=null,this.myFontStyle_0=null,this.rootGroup.children().add_11rb$(this.myText_0)}function ud(t){this.this$TextLabel=t}function cd(t,e){w.call(this),this.name$=t,this.ordinal$=e}function pd(){pd=function(){},td=new cd("LEFT",0),ed=new cd("RIGHT",1),nd=new cd("MIDDLE",2)}function hd(){return pd(),td}function _d(){return pd(),ed}function fd(){return pd(),nd}function dd(t,e){w.call(this),this.name$=t,this.ordinal$=e}function md(){md=function(){},id=new dd("TOP",0),rd=new dd("BOTTOM",1),od=new dd("CENTER",2)}function yd(){return md(),id}function $d(){return md(),rd}function vd(){return md(),od}function gd(){this.definedBreaks_0=null,this.definedLabels_0=null,this.name_iafnnl$_0=null,this.mapper_ohg8eh$_0=null,this.multiplicativeExpand_lxi716$_0=0,this.additiveExpand_59ok4k$_0=0,this.labelFormatter_tb2f2k$_0=null}function bd(t){return t.toString()}function wd(t){this.myName_8be2vx$=t.name,this.myBreaks_8be2vx$=t.definedBreaks_0,this.myLabels_8be2vx$=t.definedLabels_0,this.myLabelFormatter_8be2vx$=t.labelFormatter,this.myMapper_8be2vx$=t.mapper,this.myMultiplicativeExpand_8be2vx$=t.multiplicativeExpand,this.myAdditiveExpand_8be2vx$=t.additiveExpand}function xd(t,e,n,i){return void 0===n&&(n=null),i=i||Object.create(gd.prototype),gd.call(i),i.name_iafnnl$_0=t,i.mapper_ohg8eh$_0=e,i.definedBreaks_0=n,i.definedLabels_0=null,i.labelFormatter_tb2f2k$_0=null,i}function kd(t,e){return e=e||Object.create(gd.prototype),gd.call(e),e.name_iafnnl$_0=t.myName_8be2vx$,e.definedBreaks_0=t.myBreaks_8be2vx$,e.definedLabels_0=t.myLabels_8be2vx$,e.labelFormatter_tb2f2k$_0=t.myLabelFormatter_8be2vx$,e.mapper_ohg8eh$_0=t.myMapper_8be2vx$,e.multiplicativeExpand=t.myMultiplicativeExpand_8be2vx$,e.additiveExpand=t.myAdditiveExpand_8be2vx$,e}function Ed(){}function Cd(){this.continuousTransform_0=null,this.customBreaksGenerator_0=null,this.isContinuous_r02bms$_0=!1,this.isContinuousDomain_cs93sw$_0=!0,this.continuousDomainLimits=null}function Sd(t){wd.call(this,t),this.myContinuousTransform=t.continuousTransform_0,this.myCustomBreaksGenerator=t.customBreaksGenerator_0,this.myLowerLimit=t.continuousDomainLimits.first,this.myUpperLimit=t.continuousDomainLimits.second,this.myContinuousOutput=t.isContinuous}function Td(t,e,n,i){return xd(t,e,void 0,i=i||Object.create(Cd.prototype)),Cd.call(i),i.isContinuous_r02bms$_0=n,i.continuousDomainLimits=new de(Q.NEGATIVE_INFINITY,Q.POSITIVE_INFINITY),i.continuousTransform_0=zm().IDENTITY,i.customBreaksGenerator_0=null,i.multiplicativeExpand=.05,i.additiveExpand=0,i}function Od(){this.discreteTransform_0=null}function Nd(t){wd.call(this,t),this.myDomainValues_8be2vx$=t.discreteTransform_0.domainValues,this.myDomainLimits_8be2vx$=t.discreteTransform_0.domainLimits}function Pd(t,e,n,i){return i=i||Object.create(Od.prototype),xd(t,n,$e(e),i),Od.call(i),i.discreteTransform_0=new Li(e,$()),i.multiplicativeExpand=0,i.additiveExpand=.6,i}function Ad(){jd=this}ld.prototype.buildComponent=function(){},ud.prototype.set_11rb$=function(t){this.this$TextLabel.myText_0.fillColor(),this.this$TextLabel.myTextColor_0=t,this.this$TextLabel.updateStyleAttribute_0()},ud.$metadata$={kind:h,interfaces:[Qt]},ld.prototype.textColor=function(){return new ud(this)},ld.prototype.textOpacity=function(){return this.myText_0.fillOpacity()},ld.prototype.x=function(){return this.myText_0.x()},ld.prototype.y=function(){return this.myText_0.y()},ld.prototype.setHorizontalAnchor_ja80zo$=function(t){this.myText_0.setAttribute_jyasbz$(st.SvgConstants.SVG_TEXT_ANCHOR_ATTRIBUTE,this.toTextAnchor_0(t))},ld.prototype.setVerticalAnchor_yaudma$=function(t){this.myText_0.setAttribute_jyasbz$(st.SvgConstants.SVG_TEXT_DY_ATTRIBUTE,this.toDY_0(t))},ld.prototype.setFontSize_14dthe$=function(t){this.myFontSize_0=t,this.updateStyleAttribute_0()},ld.prototype.setFontWeight_pdl1vj$=function(t){this.myFontWeight_0=t,this.updateStyleAttribute_0()},ld.prototype.setFontStyle_pdl1vj$=function(t){this.myFontStyle_0=t,this.updateStyleAttribute_0()},ld.prototype.setFontFamily_pdl1vj$=function(t){this.myFontFamily_0=t,this.updateStyleAttribute_0()},ld.prototype.updateStyleAttribute_0=function(){var t=m();if(null!=this.myTextColor_0&&t.append_pdl1vj$("fill:").append_pdl1vj$(y(this.myTextColor_0).toHexColor()).append_s8itvh$(59),this.myFontSize_0>0&&null!=this.myFontFamily_0){var e=m(),n=this.myFontStyle_0;null!=n&&0!==n.length&&e.append_pdl1vj$(y(this.myFontStyle_0)).append_s8itvh$(32);var i=this.myFontWeight_0;null!=i&&0!==i.length&&e.append_pdl1vj$(y(this.myFontWeight_0)).append_s8itvh$(32),e.append_s8jyv4$(this.myFontSize_0).append_pdl1vj$("px "),e.append_pdl1vj$(y(this.myFontFamily_0)).append_pdl1vj$(";"),t.append_pdl1vj$("font:").append_gw00v9$(e)}else{var r=this.myFontStyle_0;null==r||pe(r)||t.append_pdl1vj$("font-style:").append_pdl1vj$(y(this.myFontStyle_0)).append_s8itvh$(59);var o=this.myFontWeight_0;null!=o&&0!==o.length&&t.append_pdl1vj$("font-weight:").append_pdl1vj$(y(this.myFontWeight_0)).append_s8itvh$(59),this.myFontSize_0>0&&t.append_pdl1vj$("font-size:").append_s8jyv4$(this.myFontSize_0).append_pdl1vj$("px;");var a=this.myFontFamily_0;null!=a&&0!==a.length&&t.append_pdl1vj$("font-family:").append_pdl1vj$(y(this.myFontFamily_0)).append_s8itvh$(59)}this.myText_0.setAttribute_jyasbz$(st.SvgConstants.SVG_STYLE_ATTRIBUTE,t.toString())},ld.prototype.toTextAnchor_0=function(t){var n;switch(t.name){case"LEFT":n=null;break;case"MIDDLE":n=st.SvgConstants.SVG_TEXT_ANCHOR_MIDDLE;break;case"RIGHT":n=st.SvgConstants.SVG_TEXT_ANCHOR_END;break;default:n=e.noWhenBranchMatched()}return n},ld.prototype.toDominantBaseline_0=function(t){var n;switch(t.name){case"TOP":n="hanging";break;case"CENTER":n="central";break;case"BOTTOM":n=null;break;default:n=e.noWhenBranchMatched()}return n},ld.prototype.toDY_0=function(t){var n;switch(t.name){case"TOP":n=st.SvgConstants.SVG_TEXT_DY_TOP;break;case"CENTER":n=st.SvgConstants.SVG_TEXT_DY_CENTER;break;case"BOTTOM":n=null;break;default:n=e.noWhenBranchMatched()}return n},cd.$metadata$={kind:h,simpleName:"HorizontalAnchor",interfaces:[w]},cd.values=function(){return[hd(),_d(),fd()]},cd.valueOf_61zpoe$=function(t){switch(t){case"LEFT":return hd();case"RIGHT":return _d();case"MIDDLE":return fd();default:x("No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor."+t)}},dd.$metadata$={kind:h,simpleName:"VerticalAnchor",interfaces:[w]},dd.values=function(){return[yd(),$d(),vd()]},dd.valueOf_61zpoe$=function(t){switch(t){case"TOP":return yd();case"BOTTOM":return $d();case"CENTER":return vd();default:x("No enum constant jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor."+t)}},ld.$metadata$={kind:h,simpleName:"TextLabel",interfaces:[Yf]},Object.defineProperty(gd.prototype,"name",{configurable:!0,get:function(){return this.name_iafnnl$_0}}),Object.defineProperty(gd.prototype,"mapper",{configurable:!0,get:function(){return this.mapper_ohg8eh$_0}}),Object.defineProperty(gd.prototype,"multiplicativeExpand",{configurable:!0,get:function(){return this.multiplicativeExpand_lxi716$_0},set:function(t){this.multiplicativeExpand_lxi716$_0=t}}),Object.defineProperty(gd.prototype,"additiveExpand",{configurable:!0,get:function(){return this.additiveExpand_59ok4k$_0},set:function(t){this.additiveExpand_59ok4k$_0=t}}),Object.defineProperty(gd.prototype,"labelFormatter",{configurable:!0,get:function(){return this.labelFormatter_tb2f2k$_0}}),Object.defineProperty(gd.prototype,"isContinuous",{configurable:!0,get:function(){return!1}}),Object.defineProperty(gd.prototype,"isContinuousDomain",{configurable:!0,get:function(){return!1}}),gd.prototype.hasBreaks=function(){return null!=this.definedBreaks_0},gd.prototype.getBreaksIntern=function(){var t;if(!this.hasBreaks()){var n="No breaks defined for scale "+this.name;throw q(n.toString())}return e.isType(t=this.definedBreaks_0,u)?t:s()},gd.prototype.getLabelsIntern=function(){if(null==this.definedLabels_0){var t="No labels defined for scale "+this.name;throw q(t.toString())}return this.definedLabels_0},gd.prototype.applyTransform_yzw12z$=function(t,n){var i,r=t;if(n&&this.hasDomainLimits()){var o,a=r,l=K(V(a,10));for(o=a.iterator();o.hasNext();){var u=o.next();l.add_11rb$(null==u||this.isInDomainLimits_za3rmp$(u)?u:null)}r=l}if(e.isType(this.transform,Tn)){var c=e.isType(i=this.transform,Tn)?i:s();if(c.hasDomainLimits()){var p,h=r,_=K(V(h,10));for(p=h.iterator();p.hasNext();){var f,d=p.next();_.add_11rb$(c.isInDomain_yrwdxb$(null==(f=d)||"number"==typeof f?f:s())?d:null)}r=_}}return this.transform.apply_9ma18$(r)},gd.prototype.getScaleBreaks=function(){if(!this.hasBreaks())return Hd().EMPTY;var t,e,n=this.getBreaksIntern(),i=this.getLabels_0(n),r=this.applyTransform_yzw12z$(n,!1),o=K(V(r,10)),a=0;for(t=r.iterator();t.hasNext();){var s=t.next(),l=o.add_11rb$,u=_e((a=(e=a)+1|0,e));l.call(o,null==s?null:u)}var p,h,_=A(he(o)),f=c(),d=0;for(p=n.iterator();p.hasNext();){var m=p.next();_.contains_11rb$(_e((d=(h=d)+1|0,h)))&&f.add_11rb$(m)}var y,$,v=he(r),g=c(),b=0;for(y=i.iterator();y.hasNext();){var w=y.next();_.contains_11rb$(_e((b=($=b)+1|0,$)))&&g.add_11rb$(w)}return new Fd(f,v,g)},gd.prototype.getLabels_0=function(t){var e,n;if(null!=this.definedLabels_0){var i=this.getLabelsIntern();if(i.isEmpty()){for(var r=t.size,o=K(r),a=0;a=this.continuousDomainLimits.first&&i<=this.continuousDomainLimits.second}else n=!1;return n},Cd.prototype.hasDomainLimits=function(){return k(this.continuousDomainLimits.first)||k(this.continuousDomainLimits.second)},Cd.prototype.with=function(){return new Sd(this)},Sd.prototype.lowerLimit_14dthe$=function(t){if(!k(t))throw d(("`lower` can't be "+t).toString());return this.myLowerLimit=t,this},Sd.prototype.upperLimit_14dthe$=function(t){if(!k(t))throw d(("`upper` can't be "+t).toString());return this.myUpperLimit=t,this},Sd.prototype.limits_pqjuzw$=function(t){throw d("Can't apply discrete limits to scale with continuous domain")},Sd.prototype.continuousTransform_gxz7zd$=function(t){return this.myContinuousTransform=t,this},Sd.prototype.breaksGenerator_6q5k0b$=function(t){return this.myCustomBreaksGenerator=t,this},Sd.prototype.build=function(){return function(t,e){kd(t,e=e||Object.create(Cd.prototype)),Cd.call(e),e.continuousTransform_0=t.myContinuousTransform,e.customBreaksGenerator_0=t.myCustomBreaksGenerator,e.isContinuous_r02bms$_0=t.myContinuousOutput;var n=b.SeriesUtil.isFinite_yrwdxb$(t.myLowerLimit)?y(t.myLowerLimit):Q.NEGATIVE_INFINITY,i=b.SeriesUtil.isFinite_yrwdxb$(t.myUpperLimit)?y(t.myUpperLimit):Q.POSITIVE_INFINITY;return e.continuousDomainLimits=new de(W.min(n,i),W.max(n,i)),e}(this)},Sd.$metadata$={kind:h,simpleName:"MyBuilder",interfaces:[wd]},Cd.$metadata$={kind:h,simpleName:"ContinuousScale",interfaces:[gd]},Object.defineProperty(Od.prototype,"transform",{configurable:!0,get:function(){return this.discreteTransform_0}}),Od.prototype.getBreaksGenerator=function(){throw q("No breaks generator for discrete scale '"+this.name+"'")},Od.prototype.hasDomainLimits=function(){return this.discreteTransform_0.hasDomainLimits()},Od.prototype.isInDomainLimits_za3rmp$=function(t){return this.discreteTransform_0.isInDomain_s8jyv4$(t)},Od.prototype.getBreaksIntern=function(){var t;if(this.hasDomainLimits()){var e,n=A(gd.prototype.getBreaksIntern.call(this)),i=this.discreteTransform_0.domainLimits,r=c();for(e=i.iterator();e.hasNext();){var o=e.next();n.contains_11rb$(o)&&r.add_11rb$(o)}t=r}else t=gd.prototype.getBreaksIntern.call(this);return t},Od.prototype.getLabelsIntern=function(){var t,e=gd.prototype.getLabelsIntern.call(this);if(!this.hasDomainLimits()||e.isEmpty())t=e;else{var n,i,r=gd.prototype.getBreaksIntern.call(this),o=K(V(r,10)),a=0;for(n=r.iterator();n.hasNext();)n.next(),o.add_11rb$(e.get_za3lpa$(_e((a=(i=a)+1|0,i))%e.size));var s,l=me(E(r,o)),u=this.discreteTransform_0.domainLimits,p=c();for(s=u.iterator();s.hasNext();){var h=s.next();l.containsKey_11rb$(h)&&p.add_11rb$(h)}var _,f=K(V(p,10));for(_=p.iterator();_.hasNext();){var d=_.next();f.add_11rb$(ye(l,d))}t=f}return t},Od.prototype.with=function(){return new Nd(this)},Nd.prototype.breaksGenerator_6q5k0b$=function(t){throw q("Not applicable to scale with discrete domain")},Nd.prototype.lowerLimit_14dthe$=function(t){throw q("Not applicable to scale with discrete domain")},Nd.prototype.upperLimit_14dthe$=function(t){throw q("Not applicable to scale with discrete domain")},Nd.prototype.limits_pqjuzw$=function(t){return this.myDomainLimits_8be2vx$=t,this},Nd.prototype.continuousTransform_gxz7zd$=function(t){return this},Nd.prototype.build=function(){return kd(t=this,e=e||Object.create(Od.prototype)),Od.call(e),e.discreteTransform_0=new Li(t.myDomainValues_8be2vx$,t.myDomainLimits_8be2vx$),e;var t,e},Nd.$metadata$={kind:h,simpleName:"MyBuilder",interfaces:[wd]},Od.$metadata$={kind:h,simpleName:"DiscreteScale",interfaces:[gd]},Ad.prototype.map_rejkqi$=function(t,e){var n=y(e(t.lowerEnd)),i=y(e(t.upperEnd));return new et(W.min(n,i),W.max(n,i))},Ad.prototype.mapDiscreteDomainValuesToNumbers_7f6uoc$=function(t){return this.mapDiscreteDomainValuesToIndices_0(t)},Ad.prototype.mapDiscreteDomainValuesToIndices_0=function(t){var e,n,i=D(),r=0;for(e=t.iterator();e.hasNext();){var o=e.next();if(null!=o&&!i.containsKey_11rb$(o)){var a=(r=(n=r)+1|0,n);i.put_xwzc9p$(o,a)}}return i},Ad.prototype.rangeWithLimitsAfterTransform_1g0x2p$=function(t,n,i,r){var o=null!=n&&k(n)?n:t.lowerEnd;if(!r.isInDomain_yrwdxb$(o)){var a="["+F(e.getKClassFromExpression(r).simpleName)+"] Lower end "+o+" is outside of transform's domain.";throw q(a.toString())}var s=null!=i&&k(i)?i:t.upperEnd;if(!r.isInDomain_yrwdxb$(s)){var l="["+F(e.getKClassFromExpression(r).simpleName)+"] Lower end "+s+" is outside of transform's domain.";throw q(l.toString())}var u=X([o,s]);return et.Companion.encloseAll_17hg47$(r.apply_9ma18$(u))},Ad.$metadata$={kind:p,simpleName:"MapperUtil",interfaces:[]};var jd=null;function Ld(){return null===jd&&new Ad,jd}function Rd(){Bd=this,this.IDENTITY=Md}function Id(t){throw q("Undefined mapper")}function zd(t,e){this.myOutputValues_0=t,this.myDefaultOutputValue_0=e}function Dd(t,e){this.myQuantizer_0=t,this.myDefaultOutputValue_0=e}function Md(t){return t}Rd.prototype.undefined_287e2$=function(){return Id},Rd.prototype.nullable_q9jsah$=function(t,e){return n=e,i=t,function(t){return null==t?n:i(t)};var n,i},Rd.prototype.constant_14dthe$=function(t){return e=t,function(t){return e};var e},Rd.prototype.mul_mdyssk$=function(t,e){var n=e/(t.upperEnd-t.lowerEnd);if(ve(n)||Ot(n))throw q(("Can't create mapper with ratio: "+n).toString());return this.mul_14dthe$(n)},Rd.prototype.mul_14dthe$=function(t){return e=t,function(t){return null!=t?e*t:null};var e},Rd.prototype.linear_1jkouz$=function(t,e,n){return void 0===n&&(n=!1),this.linear_yl4mmw$(t,n?e.upperEnd:e.lowerEnd,n?e.lowerEnd:e.upperEnd,Q.NaN)},Rd.prototype.linear_lww37m$=function(t,e,n){return this.linear_yl4mmw$(t,e.lowerEnd,e.upperEnd,n)},Rd.prototype.linear_yl4mmw$=function(t,e,n,i){var r,o,a,s=(n-e)/(t.upperEnd-t.lowerEnd);if(!b.SeriesUtil.isFinite_14dthe$(s)){var l=(n-e)/2+e;return this.constant_14dthe$(l)}return r=s,o=e-t.lowerEnd*s,a=i,function(t){return b.SeriesUtil.isFinite_yrwdxb$(t)?y(t)*r+o:a}},Rd.prototype.discreteToContinuous_83ntpg$=function(t,e,n){var i,r=Ld().mapDiscreteDomainValuesToNumbers_7f6uoc$(t);if(null==(i=b.SeriesUtil.range_l63ks6$(r.values)))return this.IDENTITY;var o=i;return this.linear_lww37m$(o,e,n)},Rd.prototype.discrete_rath1t$=function(t,e){return n=new zd(t,e),function(t){return n.apply_11rb$(t)};var n},Rd.prototype.quantized_hd8s0$=function(t,e,n){if(null==t)return i=n,function(t){return i};var i,r,o=new im;return o.domain_lu1900$(t.lowerEnd,t.upperEnd),o.range_brywnq$(e),r=new Dd(o,n),function(t){return r.apply_11rb$(t)}},zd.prototype.apply_11rb$=function(t){if(!b.SeriesUtil.isFinite_yrwdxb$(t))return this.myDefaultOutputValue_0;var e=jt(At(y(t)));return(e%=this.myOutputValues_0.size)<0&&(e=e+this.myOutputValues_0.size|0),this.myOutputValues_0.get_za3lpa$(e)},zd.$metadata$={kind:h,simpleName:"DiscreteFun",interfaces:[ot]},Dd.prototype.apply_11rb$=function(t){return b.SeriesUtil.isFinite_yrwdxb$(t)?this.myQuantizer_0.quantize_14dthe$(y(t)):this.myDefaultOutputValue_0},Dd.$metadata$={kind:h,simpleName:"QuantizedFun",interfaces:[ot]},Rd.$metadata$={kind:p,simpleName:"Mappers",interfaces:[]};var Bd=null;function Ud(){return null===Bd&&new Rd,Bd}function Fd(t,e,n){if(Hd(),this.domainValues=t,this.transformedValues=e,this.labels=n,this.domainValues.size!==this.transformedValues.size){var i="Scale breaks size: "+this.domainValues.size+" transformed size: "+this.transformedValues.size+" but expected to be the same";throw d(i.toString())}if(this.domainValues.size!==this.labels.size){var r="Scale breaks size: "+this.domainValues.size+" labels size: "+this.labels.size+" but expected to be the same";throw d(r.toString())}}function qd(){Gd=this,this.EMPTY=new Fd($(),$(),$())}Object.defineProperty(Fd.prototype,"isEmpty",{configurable:!0,get:function(){return this.domainValues.isEmpty()}}),Object.defineProperty(Fd.prototype,"size",{configurable:!0,get:function(){return this.domainValues.size}}),qd.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Gd=null;function Hd(){return null===Gd&&new qd,Gd}function Yd(){Vd=this}Fd.$metadata$={kind:h,simpleName:"ScaleBreaks",interfaces:[]},Yd.prototype.labelByBreak_x4zrm4$=function(t){var e=t.getScaleBreaks();return me(E(e.domainValues,e.labels))},Yd.prototype.map_dp4lfi$=function(t,e){return Ld().map_rejkqi$(t,e.mapper)},Yd.prototype.map_9ksyxk$=function(t,e){var n,i=e.mapper,r=K(V(t,10));for(n=t.iterator();n.hasNext();){var o=n.next();r.add_11rb$(i(o))}return r},Yd.prototype.inverseTransformToContinuousDomain_codrxm$=function(t,n){var i;if(!n.isContinuousDomain)throw q(("Not continuous numeric domain: "+n).toString());return(e.isType(i=n.transform,Tn)?i:s()).applyInverse_k9kaly$(t)},Yd.prototype.inverseTransform_codrxm$=function(t,n){var i,r=n.transform;if(e.isType(r,Tn))i=r.applyInverse_k9kaly$(t);else{var o,a=K(V(t,10));for(o=t.iterator();o.hasNext();){var s=o.next();a.add_11rb$(r.applyInverse_yrwdxb$(s))}i=a}return i},Yd.prototype.transformedDefinedLimits_x4zrm4$=function(t){var n;e.isType(t,Cd)||s();var i=t.continuousDomainLimits,r=i.component1(),o=i.component2(),a=e.isType(n=t.transform,Tn)?n:s(),l=new de(a.isInDomain_yrwdxb$(r)?y(a.apply_yrwdxb$(r)):Q.NaN,a.isInDomain_yrwdxb$(o)?y(a.apply_yrwdxb$(o)):Q.NaN),u=l.component1(),c=l.component2();return b.SeriesUtil.allFinite_jma9l8$(u,c)?new de(W.min(u,c),W.max(u,c)):new de(u,c)},Yd.$metadata$={kind:p,simpleName:"ScaleUtil",interfaces:[]};var Vd=null;function Kd(){Wd=this}Kd.prototype.continuousDomain_sqn2xl$=function(t,e){return Td(t,Ud().undefined_287e2$(),e.isNumeric)},Kd.prototype.continuousDomainNumericRange_61zpoe$=function(t){return Td(t,Ud().undefined_287e2$(),!0)},Kd.prototype.continuousDomain_lo18em$=function(t,e,n){return Td(t,e,n)},Kd.prototype.discreteDomain_uksd38$=function(t,e){return this.discreteDomain_l9mre7$(t,e,Ud().undefined_287e2$())},Kd.prototype.discreteDomain_l9mre7$=function(t,e,n){return Pd(t,e,n)},Kd.prototype.pureDiscrete_kiqtr1$=function(t,e,n,i){return this.discreteDomain_uksd38$(t,e).with().mapper_1uitho$(Ud().discrete_rath1t$(n,i)).build()},Kd.$metadata$={kind:p,simpleName:"Scales",interfaces:[]};var Wd=null;function Xd(t,e,n){if(this.normalStart=0,this.normalEnd=0,this.span=0,this.targetStep=0,this.isReversed=!1,!k(t))throw d(("range start "+t).toString());if(!k(e))throw d(("range end "+e).toString());if(!(n>0))throw d(("'count' must be positive: "+n).toString());var i=e-t,r=!1;i<0&&(i=-i,r=!0),this.span=i,this.targetStep=this.span/n,this.isReversed=r,this.normalStart=r?e:t,this.normalEnd=r?t:e}function Zd(t,e,n,i){var r;void 0===i&&(i=null),Xd.call(this,t,e,n),this.breaks_n95hiz$_0=null,this.formatter=null;var o=this.targetStep;if(o<1e3)this.formatter=new am(i).getFormatter_14dthe$(o),this.breaks_n95hiz$_0=new Jd(t,e,n).breaks;else{var a=this.normalStart,s=this.normalEnd,l=null;if(null!=i&&(l=ge(i.range_lu1900$(a,s))),null!=l&&l.size<=n)this.formatter=y(i).tickFormatter;else if(o>be.Companion.MS){this.formatter=be.Companion.TICK_FORMATTER,l=c();var u=we.TimeUtil.asDateTimeUTC_14dthe$(a),p=u.year;for(u.isAfter_amwj4p$(we.TimeUtil.yearStart_za3lpa$(p))&&(p=p+1|0),r=new Jd(p,we.TimeUtil.asDateTimeUTC_14dthe$(s).year,n).breaks.iterator();r.hasNext();){var h=r.next(),_=we.TimeUtil.yearStart_za3lpa$(jt(At(h)));l.add_11rb$(we.TimeUtil.asInstantUTC_amwj4p$(_).toNumber())}}else{var f=xe.NiceTimeInterval.forMillis_14dthe$(o);this.formatter=f.tickFormatter,l=ge(f.range_lu1900$(a,s))}this.isReversed&&vt(l),this.breaks_n95hiz$_0=l}}function Jd(t,e,n,i){var r,o;if(em(),void 0===i&&(i=!1),Xd.call(this,t,e,n),this.breaks_egvm9d$_0=null,!(n>0))throw q(("Can't compute breaks for count: "+n).toString());var a=i?this.targetStep:em().computeNiceStep_0(this.span,n);if(i){var s,l=ke(0,n),u=K(V(l,10));for(s=l.iterator();s.hasNext();){var c=s.next();u.add_11rb$(this.normalStart+a/2+c*a)}r=u}else r=em().computeNiceBreaks_0(this.normalStart,this.normalEnd,a);var p=r;o=p.isEmpty()?Ee(this.normalStart):this.isReversed?Ce(p):p,this.breaks_egvm9d$_0=o}function Qd(){tm=this}Xd.$metadata$={kind:h,simpleName:"BreaksHelperBase",interfaces:[]},Object.defineProperty(Zd.prototype,"breaks",{configurable:!0,get:function(){return this.breaks_n95hiz$_0}}),Zd.$metadata$={kind:h,simpleName:"DateTimeBreaksHelper",interfaces:[Xd]},Object.defineProperty(Jd.prototype,"breaks",{configurable:!0,get:function(){return this.breaks_egvm9d$_0}}),Qd.prototype.computeNiceStep_0=function(t,e){var n=t/e,i=W.log10(n),r=W.floor(i),o=W.pow(10,r),a=o*e/t;return a<=.15?10*o:a<=.35?5*o:a<=.75?2*o:o},Qd.prototype.computeNiceBreaks_0=function(t,e,n){if(0===n)return $();var i=n/1e4,r=t-i,o=e+i,a=c(),s=r/n,l=W.ceil(s)*n;for(t>=0&&r<0&&(l=0);l<=o;){var u=l;l=W.min(u,e),a.add_11rb$(l),l+=n}return a},Qd.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var tm=null;function em(){return null===tm&&new Qd,tm}function nm(t,e,n){this.formatter_0=null;var i=0===t?10*Q.MIN_VALUE:W.abs(t),r=0===e?i/10:W.abs(e),o="f",a="",s=W.abs(i),l=W.log10(s),u=W.log10(r),c=-u,p=!1;l<0&&u<-4?(p=!0,o="e",c=l-u):l>7&&u>2&&(p=!0,c=l-u),c<0&&(c=0,o="d");var h=c-.001;c=W.ceil(h),p?o=l>0&&n?"s":"e":a=",",this.formatter_0=Se(a+"."+jt(c)+o)}function im(){this.myHasDomain_0=!1,this.myDomainStart_0=0,this.myDomainEnd_0=0,this.myOutputValues_9bxfi2$_0=this.myOutputValues_9bxfi2$_0}function rm(){om=this}Jd.$metadata$={kind:h,simpleName:"LinearBreaksHelper",interfaces:[Xd]},nm.prototype.apply_za3rmp$=function(t){var n;return this.formatter_0.apply_3p81yu$(e.isNumber(n=t)?n:s())},nm.$metadata$={kind:h,simpleName:"NumericBreakFormatter",interfaces:[]},Object.defineProperty(im.prototype,"myOutputValues_0",{configurable:!0,get:function(){return null==this.myOutputValues_9bxfi2$_0?Tt("myOutputValues"):this.myOutputValues_9bxfi2$_0},set:function(t){this.myOutputValues_9bxfi2$_0=t}}),Object.defineProperty(im.prototype,"outputValues",{configurable:!0,get:function(){return this.myOutputValues_0}}),Object.defineProperty(im.prototype,"domainQuantized",{configurable:!0,get:function(){var t;if(this.myDomainStart_0===this.myDomainEnd_0)return Ee(new et(this.myDomainStart_0,this.myDomainEnd_0));var e=c(),n=this.myOutputValues_0.size,i=this.bucketSize_0();t=n-1|0;for(var r=0;r "+e).toString());return this.myHasDomain_0=!0,this.myDomainStart_0=t,this.myDomainEnd_0=e,this},im.prototype.range_brywnq$=function(t){return this.myOutputValues_0=R(t),this},im.prototype.quantize_14dthe$=function(t){var e=this.outputIndex_0(t);return this.myOutputValues_0.get_za3lpa$(e)},im.prototype.outputIndex_0=function(t){if(!this.myHasDomain_0)throw q("Domain not defined.".toString());var e=null!=this.myOutputValues_9bxfi2$_0;if(e&&(e=!this.myOutputValues_0.isEmpty()),!e)throw q("Output values are not defined.".toString());var n=this.bucketSize_0(),i=jt((t-this.myDomainStart_0)/n),r=this.myOutputValues_0.size-1|0,o=W.min(r,i);return W.max(0,o)},im.prototype.getOutputValueIndex_za3rmp$=function(t){return e.isNumber(t)?this.outputIndex_0(fe(t)):-1},im.prototype.getOutputValue_za3rmp$=function(t){return e.isNumber(t)?this.quantize_14dthe$(fe(t)):null},im.prototype.bucketSize_0=function(){return(this.myDomainEnd_0-this.myDomainStart_0)/this.myOutputValues_0.size},im.$metadata$={kind:h,simpleName:"QuantizeScale",interfaces:[sm]},rm.prototype.withBreaks_qt1l9m$=function(t,e,n){var i=t.getBreaksGenerator().generateBreaks_1tlvto$(e,n),r=i.domainValues,o=i.labels;return t.with().breaks_pqjuzw$(r).labels_mhpeer$(o).build()},rm.$metadata$={kind:p,simpleName:"ScaleBreaksUtil",interfaces:[]};var om=null;function am(t){this.minInterval_0=t}function sm(){}function lm(t){void 0===t&&(t=null),this.labelFormatter_0=t}function um(t,e){this.transformFun_vpw6mq$_0=t,this.inverseFun_2rsie$_0=e}function cm(){um.call(this,pm,hm)}function pm(t){return t}function hm(t){return t}function _m(t){mm(),void 0===t&&(t=null),this.formatter_0=t}function fm(){dm=this}am.prototype.getFormatter_14dthe$=function(t){return Te.Formatter.time_61zpoe$(this.formatPattern_0(t))},am.prototype.formatPattern_0=function(t){if(t<1e3)return Oe.Companion.milliseconds_za3lpa$(1).tickFormatPattern;if(null!=this.minInterval_0){var e=100*t;if(100>=this.minInterval_0.range_lu1900$(0,e).size)return this.minInterval_0.tickFormatPattern}return t>be.Companion.MS?be.Companion.TICK_FORMAT:xe.NiceTimeInterval.forMillis_14dthe$(t).tickFormatPattern},am.$metadata$={kind:h,simpleName:"TimeScaleTickFormatterFactory",interfaces:[]},sm.$metadata$={kind:f,simpleName:"WithFiniteOrderedOutput",interfaces:[]},lm.prototype.generateBreaks_1tlvto$=function(t,e){var n,i,r=this.breaksHelper_0(t,e),o=r.breaks,a=null!=(n=this.labelFormatter_0)?n:r.formatter,s=c();for(i=o.iterator();i.hasNext();){var l=i.next();s.add_11rb$(a(l))}return new Fd(o,o,s)},lm.prototype.breaksHelper_0=function(t,e){return new Zd(t.lowerEnd,t.upperEnd,e)},lm.prototype.labelFormatter_1tlvto$=function(t,e){var n;return null!=(n=this.labelFormatter_0)?n:this.breaksHelper_0(t,e).formatter},lm.$metadata$={kind:h,simpleName:"DateTimeBreaksGen",interfaces:[Ed]},um.prototype.apply_yrwdxb$=function(t){return null!=t?this.transformFun_vpw6mq$_0(t):null},um.prototype.apply_9ma18$=function(t){var e,n=this.safeCastToDoubles_9ma18$(t),i=K(V(n,10));for(e=n.iterator();e.hasNext();){var r=e.next();i.add_11rb$(this.apply_yrwdxb$(r))}return i},um.prototype.applyInverse_yrwdxb$=function(t){return null!=t?this.inverseFun_2rsie$_0(t):null},um.prototype.applyInverse_k9kaly$=function(t){var e,n=K(V(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.applyInverse_yrwdxb$(i))}return n},um.prototype.safeCastToDoubles_9ma18$=function(t){var e=b.SeriesUtil.checkedDoubles_9ma18$(t);if(!e.canBeCast())throw d("Not a collections of Double(s)".toString());return e.cast()},um.$metadata$={kind:h,simpleName:"FunTransform",interfaces:[Tn]},cm.prototype.hasDomainLimits=function(){return!1},cm.prototype.isInDomain_yrwdxb$=function(t){return b.SeriesUtil.isFinite_yrwdxb$(t)},cm.prototype.createApplicableDomain_yrwdxb$$default=function(t){if(null==t)return this.createApplicableDomain_yrwdxb$(0);var e=k(t)?t:0;return new et(e-.5,e+.5)},cm.prototype.toApplicableDomain_4fzjta$=function(t){return t},cm.prototype.apply_9ma18$=function(t){return this.safeCastToDoubles_9ma18$(t)},cm.prototype.applyInverse_k9kaly$=function(t){return t},cm.$metadata$={kind:h,simpleName:"IdentityTransform",interfaces:[um]},_m.prototype.generateBreaks_1tlvto$=function(t,e){var n,i,r=mm().generateBreakValues_omwdpb$(t,e),o=null!=(n=this.formatter_0)?n:mm().createFormatter_0(r),a=K(V(r,10));for(i=r.iterator();i.hasNext();){var s=i.next();a.add_11rb$(o(s))}return new Fd(r,r,a)},_m.prototype.labelFormatter_1tlvto$=function(t,e){var n;return null!=(n=this.formatter_0)?n:mm().createFormatter_0(mm().generateBreakValues_omwdpb$(t,e))},fm.prototype.generateBreakValues_omwdpb$=function(t,e){return new Jd(t.lowerEnd,t.upperEnd,e).breaks},fm.prototype.createFormatter_0=function(t){var e,n;if(t.isEmpty())n=new de(0,.5);else{var i=Ne(t),r=W.abs(i),o=Pe(t),a=W.abs(o),s=W.max(r,a);if(1===t.size)e=s/10;else{var l=t.get_za3lpa$(1)-t.get_za3lpa$(0);e=W.abs(l)}n=new de(s,e)}var u=n,c=new nm(u.component1(),u.component2(),!0);return C("apply",function(t,e){return t.apply_za3rmp$(e)}.bind(null,c))},fm.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var dm=null;function mm(){return null===dm&&new fm,dm}function ym(){gm(),um.call(this,bm,wm)}function $m(){vm=this,this.LOWER_LIM_TRANSFOTMED_8be2vx$=-Q.MAX_VALUE/10,this.LOWER_LIM_DOMAIN_8be2vx$=10*Q.MIN_VALUE}_m.$metadata$={kind:h,simpleName:"LinearBreaksGen",interfaces:[Ed]},ym.prototype.hasDomainLimits=function(){return!0},ym.prototype.isInDomain_yrwdxb$=function(t){return b.SeriesUtil.isFinite_yrwdxb$(t)&&y(t)>=gm().LOWER_LIM_DOMAIN_8be2vx$},ym.prototype.isZero_0=function(t){return b.SeriesUtil.isFinite_yrwdxb$(t)&&y(t)>=0&&t=0},Pm.prototype.createApplicableDomain_yrwdxb$$default=function(t){var e;if(this.isInDomain_yrwdxb$(t)){var n=y(t);e=W.max(n,0)}else e=1;var i=e,r=i-.5;return new et(W.max(r,0),i+.5)},Pm.prototype.toApplicableDomain_4fzjta$=function(t){var e=t.lowerEnd,n=W.max(e,0),i=t.upperEnd,r=W.max(i,0);return new et(n,r)},Pm.$metadata$={kind:h,simpleName:"SqrtTransform",interfaces:[um]},Lm.prototype.createBreaksGeneratorForTransformedDomain_5x42z5$=function(t,n){var i;if(void 0===n&&(n=null),l(t,this.IDENTITY))i=new _m(n);else if(l(t,this.REVERSE))i=new _m(n);else if(l(t,this.SQRT))i=new xm(this.SQRT,n);else{if(!l(t,this.LOG10))throw q("Unexpected 'transform' type: "+F(e.getKClassFromExpression(t).simpleName));i=new xm(this.LOG10,n)}return new Rm(t,i)},Lm.prototype.ensureApplicableDomain_wa8y5m$=function(t,e){if(null==t)return e.createApplicableDomain_yrwdxb$();var n=e.toApplicableDomain_4fzjta$(t);return b.SeriesUtil.isSubTiny_4fzjta$(n)?e.createApplicableDomain_yrwdxb$(n.upperEnd):n},Rm.prototype.labelFormatter_1tlvto$=function(t,e){var n,i=Ld().map_rejkqi$(t,(n=this,function(t){return n.transform_0.applyInverse_yrwdxb$(t)}));return this.breaksGenerator.labelFormatter_1tlvto$(i,e)},Rm.prototype.generateBreaks_1tlvto$=function(t,e){var n,i,r=Ld().map_rejkqi$(t,(i=this,function(t){return i.transform_0.applyInverse_yrwdxb$(t)})),o=this.breaksGenerator.generateBreaks_1tlvto$(r,e),a=o.domainValues,l=this.transform_0.apply_9ma18$(a),u=K(V(l,10));for(n=l.iterator();n.hasNext();){var c,p=n.next();u.add_11rb$("number"==typeof(c=p)?c:s())}return new Fd(a,u,o.labels)},Rm.$metadata$={kind:h,simpleName:"BreaksGeneratorForTransformedDomain",interfaces:[Ed]},Lm.$metadata$={kind:p,simpleName:"Transforms",interfaces:[]};var Im=null;function zm(){return null===Im&&new Lm,Im}function Dm(t,e,n,i,r,o,a,s,l,u){if(Um(),Fm.call(this,Um().DEF_MAPPING_0),this.bandWidthX_pmqi0t$_0=t,this.bandWidthY_pmqi1o$_0=e,this.bandWidthMethod_3lcf4y$_0=n,this.adjust=i,this.kernel_ba223r$_0=r,this.nX=o,this.nY=a,this.isContour=s,this.binCount_6z2ebo$_0=l,this.binWidth_2e8jdx$_0=u,this.kernelFun=yv().kernel_uyf859$(this.kernel_ba223r$_0),this.binOptions=new cy(this.binCount_6z2ebo$_0,this.binWidth_2e8jdx$_0),!(this.nX<=999)){var c="The input nX = "+this.nX+" > 999 is too large!";throw d(c.toString())}if(!(this.nY<=999)){var p="The input nY = "+this.nY+" > 999 is too large!";throw d(p.toString())}}function Mm(){Bm=this,this.DEF_KERNEL=q$(),this.DEF_ADJUST=1,this.DEF_N=100,this.DEF_BW=J$(),this.DEF_CONTOUR=!0,this.DEF_BIN_COUNT=10,this.DEF_BIN_WIDTH=0,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y)]),this.MAX_N_0=999}Dm.prototype.getBandWidthX_k9kaly$=function(t){var e;return null!=(e=this.bandWidthX_pmqi0t$_0)?e:yv().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0,t)},Dm.prototype.getBandWidthY_k9kaly$=function(t){var e;return null!=(e=this.bandWidthY_pmqi1o$_0)?e:yv().bandWidth_whucba$(this.bandWidthMethod_3lcf4y$_0,t)},Dm.prototype.consumes=function(){return X([Cn().X,Cn().Y,Cn().WEIGHT])},Dm.prototype.apply_kdy6bf$$default=function(t,e,n){throw q("'density2d' statistic can't be executed on the client side")},Mm.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Bm=null;function Um(){return null===Bm&&new Mm,Bm}function Fm(t){this.defaultMappings_lvkmi1$_0=t}function qm(t,e,n,i,r){Wm(),void 0===t&&(t=30),void 0===e&&(e=30),void 0===n&&(n=Wm().DEF_BINWIDTH),void 0===i&&(i=Wm().DEF_BINWIDTH),void 0===r&&(r=Wm().DEF_DROP),Fm.call(this,Wm().DEF_MAPPING_0),this.drop_0=r,this.binOptionsX_0=new cy(t,n),this.binOptionsY_0=new cy(e,i)}function Gm(){Km=this,this.DEF_BINS=30,this.DEF_BINWIDTH=null,this.DEF_DROP=!0,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y),Mt(Cn().FILL,Rv().COUNT)])}Dm.$metadata$={kind:h,simpleName:"AbstractDensity2dStat",interfaces:[Fm]},Fm.prototype.hasDefaultMapping_896ixz$=function(t){return this.defaultMappings_lvkmi1$_0.containsKey_11rb$(t)},Fm.prototype.getDefaultMapping_896ixz$=function(t){if(this.defaultMappings_lvkmi1$_0.containsKey_11rb$(t))return y(this.defaultMappings_lvkmi1$_0.get_11rb$(t));throw d("Stat "+e.getKClassFromExpression(this).simpleName+" has no default mapping for aes: "+F(t))},Fm.prototype.hasRequiredValues_xht41f$=function(t,e){var n;for(n=0;n!==e.length;++n){var i=e[n],r=$o().forAes_896ixz$(i);if(t.hasNoOrEmpty_8xm3sj$(r))return!1}return!0},Fm.prototype.withEmptyStatValues=function(){var t,e=Pi();for(t=Cn().values().iterator();t.hasNext();){var n=t.next();this.hasDefaultMapping_896ixz$(n)&&e.put_2l962d$(this.getDefaultMapping_896ixz$(n),$())}return e.build()},Fm.$metadata$={kind:h,simpleName:"BaseStat",interfaces:[kr]},qm.prototype.consumes=function(){return X([Cn().X,Cn().Y,Cn().WEIGHT])},qm.prototype.apply_kdy6bf$$default=function(t,n,i){if(!this.hasRequiredValues_xht41f$(t,[Cn().X,Cn().Y]))return this.withEmptyStatValues();var r=n.overallXRange(),o=n.overallYRange();if(null==r||null==o)return this.withEmptyStatValues();var a=Wm().adjustRangeInitial_0(r),s=Wm().adjustRangeInitial_0(o),l=fy().binCountAndWidth_11nzti$(b.SeriesUtil.span_4fzjta$(a),this.binOptionsX_0),u=fy().binCountAndWidth_11nzti$(b.SeriesUtil.span_4fzjta$(s),this.binOptionsY_0),c=Wm().adjustRangeFinal_0(r,l.width),p=Wm().adjustRangeFinal_0(o,u.width),h=fy().binCountAndWidth_11nzti$(b.SeriesUtil.span_4fzjta$(c),this.binOptionsX_0),_=fy().binCountAndWidth_11nzti$(b.SeriesUtil.span_4fzjta$(p),this.binOptionsY_0),f=e.imul(h.count,_.count),d=Wm().densityNormalizingFactor_0(b.SeriesUtil.span_4fzjta$(c),b.SeriesUtil.span_4fzjta$(p),f),m=this.computeBins_0(t.getNumeric_8xm3sj$($o().X),t.getNumeric_8xm3sj$($o().Y),c.lowerEnd,p.lowerEnd,h.count,_.count,h.width,_.width,fy().weightAtIndex_dhhkv7$(t),d);return Pi().putNumeric_s1rqo9$(Rv().X,m.x_8be2vx$).putNumeric_s1rqo9$(Rv().Y,m.y_8be2vx$).putNumeric_s1rqo9$(Rv().COUNT,m.count_8be2vx$).putNumeric_s1rqo9$(Rv().DENSITY,m.density_8be2vx$).build()},qm.prototype.computeBins_0=function(t,e,n,i,r,o,a,s,l,u){for(var p=0,h=I(),_=0;_!==t.size;++_){var f=t.get_za3lpa$(_),d=e.get_za3lpa$(_);if(b.SeriesUtil.allFinite_jma9l8$(f,d)){var m=l(_);p+=m;var $=(y(f)-n)/a,v=jt(W.floor($)),g=(y(d)-i)/s,w=jt(W.floor(g)),x=new de(v,w);if(!h.containsKey_11rb$(x)){var k=new Cb(0);h.put_xwzc9p$(x,k)}y(h.get_11rb$(x)).getAndAdd_14dthe$(m)}}for(var E=c(),C=c(),S=c(),T=c(),O=n+a/2,N=i+s/2,P=0;P0?1/d:1,$=fy().computeBins_3oz8yg$(n,i,a,s,fy().weightAtIndex_dhhkv7$(t),m);if($.x_8be2vx$.size!==a){var v="Internal: stat data size="+F($.x_8be2vx$.size)+" expected bin count="+F(a);throw q(v.toString())}return $},Qm.$metadata$={kind:h,simpleName:"XPosKind",interfaces:[w]},Qm.values=function(){return[ey(),ny(),iy()]},Qm.valueOf_61zpoe$=function(t){switch(t){case"NONE":return ey();case"CENTER":return ny();case"BOUNDARY":return iy();default:x("No enum constant jetbrains.datalore.plot.base.stat.BinStat.XPosKind."+t)}},ry.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var oy=null;function ay(){return null===oy&&new ry,oy}function sy(){_y=this,this.MAX_BIN_COUNT_0=500}function ly(t){return function(e){var n=t.get_za3lpa$(e);return b.SeriesUtil.asFinite_z03gcz$(n,0)}}function uy(t){return 1}function cy(t,e){this.binWidth=e;var n=W.max(1,t);this.binCount=W.min(500,n)}function py(t,e){this.count=t,this.width=e}function hy(t,e,n){this.x_8be2vx$=t,this.count_8be2vx$=e,this.density_8be2vx$=n}Jm.$metadata$={kind:h,simpleName:"BinStat",interfaces:[Fm]},sy.prototype.weightAtIndex_dhhkv7$=function(t){return t.has_8xm3sj$($o().WEIGHT)?ly(t.getNumeric_8xm3sj$($o().WEIGHT)):uy},sy.prototype.weightVector_5m8trb$=function(t,e){var n;if(e.has_8xm3sj$($o().WEIGHT))n=e.getNumeric_8xm3sj$($o().WEIGHT);else{for(var i=K(t),r=0;r0},cy.$metadata$={kind:h,simpleName:"BinOptions",interfaces:[]},py.$metadata$={kind:h,simpleName:"CountAndWidth",interfaces:[]},hy.$metadata$={kind:h,simpleName:"BinsData",interfaces:[]},sy.$metadata$={kind:p,simpleName:"BinStatUtil",interfaces:[]};var _y=null;function fy(){return null===_y&&new sy,_y}function dy(t,e){$y(),Fm.call(this,$y().DEF_MAPPING_0),this.whiskerIQRRatio_0=t,this.computeWidth_0=e}function my(){yy=this,this.DEF_WHISKER_IQR_RATIO=1.5,this.DEF_COMPUTE_WIDTH=!1,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y),Mt(Cn().YMIN,Rv().Y_MIN),Mt(Cn().YMAX,Rv().Y_MAX),Mt(Cn().LOWER,Rv().LOWER),Mt(Cn().MIDDLE,Rv().MIDDLE),Mt(Cn().UPPER,Rv().UPPER)])}dy.prototype.hasDefaultMapping_896ixz$=function(t){return Fm.prototype.hasDefaultMapping_896ixz$.call(this,t)||l(t,Cn().WIDTH)&&this.computeWidth_0},dy.prototype.getDefaultMapping_896ixz$=function(t){return l(t,Cn().WIDTH)?Rv().WIDTH:Fm.prototype.getDefaultMapping_896ixz$.call(this,t)},dy.prototype.consumes=function(){return X([Cn().X,Cn().Y])},dy.prototype.apply_kdy6bf$$default=function(t,e,n){var i,r,o,a;if(!this.hasRequiredValues_xht41f$(t,[Cn().Y]))return this.withEmptyStatValues();var s=t.getNumeric_8xm3sj$($o().Y);if(t.has_8xm3sj$($o().X))i=t.getNumeric_8xm3sj$($o().X);else{for(var l=s.size,u=K(l),c=0;c=G&&X<=H&&W.add_11rb$(X)}var Z=W,J=b.SeriesUtil.range_l63ks6$(Z);null!=J&&(Y=J.lowerEnd,V=J.upperEnd)}var tt,et=c();for(tt=R.iterator();tt.hasNext();){var nt=tt.next();(ntH)&&et.add_11rb$(nt)}for(o=et.iterator();o.hasNext();){var it=o.next();k.add_11rb$(L),C.add_11rb$(it),S.add_11rb$(Q.NaN),T.add_11rb$(Q.NaN),O.add_11rb$(Q.NaN),N.add_11rb$(Q.NaN),P.add_11rb$(Q.NaN),A.add_11rb$(z)}k.add_11rb$(L),C.add_11rb$(Q.NaN),S.add_11rb$(B),T.add_11rb$(U),O.add_11rb$(F),N.add_11rb$(Y),P.add_11rb$(V),A.add_11rb$(z)}return Re([Mt(Rv().X,k),Mt(Rv().Y,C),Mt(Rv().MIDDLE,S),Mt(Rv().LOWER,T),Mt(Rv().UPPER,O),Mt(Rv().Y_MIN,N),Mt(Rv().Y_MAX,P),Mt(Rv().COUNT,A)])},my.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var yy=null;function $y(){return null===yy&&new my,yy}function vy(){Cy(),this.myContourX_0=c(),this.myContourY_0=c(),this.myContourLevel_0=c(),this.myContourGroup_0=c(),this.myGroup_0=0}function gy(){Ey=this}dy.$metadata$={kind:h,simpleName:"BoxplotStat",interfaces:[Fm]},Object.defineProperty(vy.prototype,"dataFrame_0",{configurable:!0,get:function(){return Pi().putNumeric_s1rqo9$(Rv().X,this.myContourX_0).putNumeric_s1rqo9$(Rv().Y,this.myContourY_0).putNumeric_s1rqo9$(Rv().LEVEL,this.myContourLevel_0).putNumeric_s1rqo9$(Rv().GROUP,this.myContourGroup_0).build()}}),vy.prototype.add_e7h60q$=function(t,e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();this.myContourX_0.add_11rb$(i.x),this.myContourY_0.add_11rb$(i.y),this.myContourLevel_0.add_11rb$(e),this.myContourGroup_0.add_11rb$(this.myGroup_0)}this.myGroup_0+=1},gy.prototype.getPathDataFrame_9s3d7f$=function(t,e){var n,i,r=new vy;for(n=t.iterator();n.hasNext();){var o=n.next();for(i=y(e.get_11rb$(o)).iterator();i.hasNext();){var a=i.next();r.add_e7h60q$(a,o)}}return r.dataFrame_0},gy.prototype.getPolygonDataFrame_dnsuee$=function(t,e){var n,i=new vy;for(n=t.iterator();n.hasNext();){var r=n.next(),o=y(e.get_11rb$(r));i.add_e7h60q$(o,r)}return i.dataFrame_0},gy.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var by,wy,xy,ky,Ey=null;function Cy(){return null===Ey&&new gy,Ey}function Sy(t,e){By(),this.myLowLeft_0=null,this.myLowRight_0=null,this.myUpLeft_0=null,this.myUpRight_0=null;var n=t.lowerEnd,i=t.upperEnd,r=e.lowerEnd,o=e.upperEnd;this.myLowLeft_0=new lt(n,r),this.myLowRight_0=new lt(i,r),this.myUpLeft_0=new lt(n,o),this.myUpRight_0=new lt(i,o)}function Ty(t,n){return e.compareTo(t.x,n.x)}function Oy(t,n){return e.compareTo(t.y,n.y)}function Ny(t,n){return e.compareTo(n.x,t.x)}function Py(t,n){return e.compareTo(n.y,t.y)}function Ay(t,e){w.call(this),this.name$=t,this.ordinal$=e}function jy(){jy=function(){},by=new Ay("DOWN",0),wy=new Ay("RIGHT",1),xy=new Ay("UP",2),ky=new Ay("LEFT",3)}function Ly(){return jy(),by}function Ry(){return jy(),wy}function Iy(){return jy(),xy}function zy(){return jy(),ky}function Dy(){My=this}vy.$metadata$={kind:h,simpleName:"Contour",interfaces:[]},Sy.prototype.createPolygons_lrt0be$=function(t,e,n){var i,r,o,a=I(),s=c();for(i=t.values.iterator();i.hasNext();){var l=i.next();s.addAll_brywnq$(l)}var u=c(),p=this.createOuterMap_0(s,u),h=t.keys.size;r=h+1|0;for(var _=0;_0&&f.addAll_brywnq$(By().reverseAll_0(y(t.get_11rb$(e.get_za3lpa$(_-1|0))))),_=0},Dy.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var My=null;function By(){return null===My&&new Dy,My}function Uy(t,e){Gy(),Fm.call(this,Gy().DEF_MAPPING_0),this.myBinOptions_0=new cy(t,e)}function Fy(){qy=this,this.DEF_BIN_COUNT=10,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y)])}Sy.$metadata$={kind:h,simpleName:"ContourFillHelper",interfaces:[]},Uy.prototype.consumes=function(){return X([Cn().X,Cn().Y,Cn().Z])},Uy.prototype.apply_kdy6bf$$default=function(t,e,n){var i;if(!this.hasRequiredValues_xht41f$(t,[Cn().X,Cn().Y,Cn().Z]))return this.withEmptyStatValues();if(null==(i=Wy().computeLevels_wuiwgl$(t,this.myBinOptions_0)))return Ni().emptyFrame();var r=i,o=Wy().computeContours_jco5dt$(t,r);return Cy().getPathDataFrame_9s3d7f$(r,o)},Fy.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var qy=null;function Gy(){return null===qy&&new Fy,qy}function Hy(){Ky=this,this.xLoc_0=new Float64Array([0,1,1,0,.5]),this.yLoc_0=new Float64Array([0,0,1,1,.5])}function Yy(t,e,n){this.z=n,this.myX=0,this.myY=0,this.myIsCenter_0=0,this.myX=jt(t),this.myY=jt(e),this.myIsCenter_0=t%1==0?0:1}function Vy(t,e){this.myA=t,this.myB=e}Uy.$metadata$={kind:h,simpleName:"ContourStat",interfaces:[Fm]},Hy.prototype.estimateRegularGridShape_fsp013$=function(t){var e,n=0,i=null;for(e=t.iterator();e.hasNext();){var r=e.next();if(null==i)i=r;else if(r==i)break;n=n+1|0}if(n<=1)throw d("Data grid must be at least 2 columns wide (was "+n+")");var o=t.size/n|0;if(o<=1)throw d("Data grid must be at least 2 rows tall (was "+o+")");return new Ht(n,o)},Hy.prototype.computeLevels_wuiwgl$=function(t,e){if(!(t.has_8xm3sj$($o().X)&&t.has_8xm3sj$($o().Y)&&t.has_8xm3sj$($o().Z)))return null;var n=t.range_8xm3sj$($o().Z);return this.computeLevels_kgz263$(n,e)},Hy.prototype.computeLevels_kgz263$=function(t,e){var n;if(null==t||b.SeriesUtil.isSubTiny_4fzjta$(t))return null;var i=fy().binCountAndWidth_11nzti$(b.SeriesUtil.span_4fzjta$(t),e),r=c();n=i.count;for(var o=0;o1&&p.add_11rb$(_)}return p},Hy.prototype.confirmPaths_0=function(t){var e,n,i,r=c(),o=I();for(e=t.iterator();e.hasNext();){var a=e.next(),s=a.get_za3lpa$(0),l=a.get_za3lpa$(a.size-1|0);if(null!=s&&s.equals(l))r.add_11rb$(a);else if(o.containsKey_11rb$(s)||o.containsKey_11rb$(l)){var u=o.get_11rb$(s),p=o.get_11rb$(l);this.removePathByEndpoints_ebaanh$(u,o),this.removePathByEndpoints_ebaanh$(p,o);var h=c();if(u===p){h.addAll_brywnq$(y(u)),h.addAll_brywnq$(a.subList_vux9f0$(1,a.size)),r.add_11rb$(h);continue}null!=u&&null!=p?(h.addAll_brywnq$(u),h.addAll_brywnq$(a.subList_vux9f0$(1,a.size-1|0)),h.addAll_brywnq$(p)):null==u?(h.addAll_brywnq$(y(p)),h.addAll_u57x28$(0,a.subList_vux9f0$(0,a.size-1|0))):(h.addAll_brywnq$(u),h.addAll_brywnq$(a.subList_vux9f0$(1,a.size)));var _=h.get_za3lpa$(0);o.put_xwzc9p$(_,h);var f=h.get_za3lpa$(h.size-1|0);o.put_xwzc9p$(f,h)}else{var d=a.get_za3lpa$(0);o.put_xwzc9p$(d,a);var m=a.get_za3lpa$(a.size-1|0);o.put_xwzc9p$(m,a)}}for(n=nt(o.values).iterator();n.hasNext();){var $=n.next();r.add_11rb$($)}var v=c();for(i=r.iterator();i.hasNext();){var g=i.next();v.addAll_brywnq$(this.pathSeparator_0(g))}return v},Hy.prototype.removePathByEndpoints_ebaanh$=function(t,e){null!=t&&(e.remove_11rb$(t.get_za3lpa$(0)),e.remove_11rb$(t.get_za3lpa$(t.size-1|0)))},Hy.prototype.pathSeparator_0=function(t){var e,n,i=c(),r=0;e=t.size-1|0;for(var o=1;om&&r<=$)){var k=this.computeSegmentsForGridCell_0(r,d,u,l);s.addAll_brywnq$(k)}}}return s},Hy.prototype.computeSegmentsForGridCell_0=function(t,e,n,i){for(var r,o=c(),a=c(),s=0;s<=4;s++)a.add_11rb$(new Yy(n+this.xLoc_0[s],i+this.yLoc_0[s],e[s]));for(var l=0;l<=3;l++){var u=(l+1|0)%4;(r=c()).add_11rb$(a.get_za3lpa$(l)),r.add_11rb$(a.get_za3lpa$(u)),r.add_11rb$(a.get_za3lpa$(4));var p=this.intersectionSegment_0(r,t);null!=p&&o.add_11rb$(p)}return o},Hy.prototype.intersectionSegment_0=function(t,e){var n,i;switch((100*t.get_za3lpa$(0).getType_14dthe$(y(e))|0)+(10*t.get_za3lpa$(1).getType_14dthe$(e)|0)+t.get_za3lpa$(2).getType_14dthe$(e)|0){case 100:n=new Vy(t.get_za3lpa$(2),t.get_za3lpa$(0)),i=new Vy(t.get_za3lpa$(0),t.get_za3lpa$(1));break;case 10:n=new Vy(t.get_za3lpa$(0),t.get_za3lpa$(1)),i=new Vy(t.get_za3lpa$(1),t.get_za3lpa$(2));break;case 1:n=new Vy(t.get_za3lpa$(1),t.get_za3lpa$(2)),i=new Vy(t.get_za3lpa$(2),t.get_za3lpa$(0));break;case 110:n=new Vy(t.get_za3lpa$(0),t.get_za3lpa$(2)),i=new Vy(t.get_za3lpa$(2),t.get_za3lpa$(1));break;case 101:n=new Vy(t.get_za3lpa$(2),t.get_za3lpa$(1)),i=new Vy(t.get_za3lpa$(1),t.get_za3lpa$(0));break;case 11:n=new Vy(t.get_za3lpa$(1),t.get_za3lpa$(0)),i=new Vy(t.get_za3lpa$(0),t.get_za3lpa$(2));break;default:return null}return new Ht(n,i)},Hy.prototype.checkEdges_0=function(t,e,n){var i,r;for(i=t.iterator();i.hasNext();){var o=i.next();null!=(r=o.get_za3lpa$(0))&&r.equals(o.get_za3lpa$(o.size-1|0))||(this.checkEdge_0(o.get_za3lpa$(0),e,n),this.checkEdge_0(o.get_za3lpa$(o.size-1|0),e,n))}},Hy.prototype.checkEdge_0=function(t,e,n){var i=t.myA,r=t.myB;if(!(0===i.myX&&0===r.myX||0===i.myY&&0===r.myY||i.myX===(e-1|0)&&r.myX===(e-1|0)||i.myY===(n-1|0)&&r.myY===(n-1|0)))throw d("Check Edge Failed")},Object.defineProperty(Yy.prototype,"coord",{configurable:!0,get:function(){return new lt(this.x,this.y)}}),Object.defineProperty(Yy.prototype,"x",{configurable:!0,get:function(){return this.myX+.5*this.myIsCenter_0}}),Object.defineProperty(Yy.prototype,"y",{configurable:!0,get:function(){return this.myY+.5*this.myIsCenter_0}}),Yy.prototype.equals=function(t){var n,i;if(this===t)return!0;if(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))return!1;var r=null==(i=t)||e.isType(i,Yy)?i:s();return this.myX===y(r).myX&&this.myY===r.myY&&this.myIsCenter_0===r.myIsCenter_0},Yy.prototype.hashCode=function(){return De([this.myX,this.myY,this.myIsCenter_0])},Yy.prototype.getType_14dthe$=function(t){return this.z>=t?1:0},Yy.$metadata$={kind:h,simpleName:"TripleVector",interfaces:[]},Vy.prototype.equals=function(t){var n,i,r,o,a;if(!e.isType(t,Vy))return!1;var l=null==(n=t)||e.isType(n,Vy)?n:s();return(null!=(i=this.myA)?i.equals(y(l).myA):null)&&(null!=(r=this.myB)?r.equals(l.myB):null)||(null!=(o=this.myA)?o.equals(l.myB):null)&&(null!=(a=this.myB)?a.equals(l.myA):null)},Vy.prototype.hashCode=function(){return this.myA.coord.hashCode()+this.myB.coord.hashCode()|0},Vy.prototype.intersect_14dthe$=function(t){var e=this.myA.z,n=this.myB.z;if(t===e)return this.myA.coord;if(t===n)return this.myB.coord;var i=(n-e)/(t-e),r=this.myA.x,o=this.myA.y,a=this.myB.x,s=this.myB.y;return new lt(r+(a-r)/i,o+(s-o)/i)},Vy.$metadata$={kind:h,simpleName:"Edge",interfaces:[]},Hy.$metadata$={kind:p,simpleName:"ContourStatUtil",interfaces:[]};var Ky=null;function Wy(){return null===Ky&&new Hy,Ky}function Xy(t,e){o$(),Fm.call(this,o$().DEF_MAPPING_0),this.myBinOptions_0=new cy(t,e)}function Zy(){r$=this,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y)])}Xy.prototype.consumes=function(){return X([Cn().X,Cn().Y,Cn().Z])},Xy.prototype.apply_kdy6bf$$default=function(t,e,n){var i;if(!this.hasRequiredValues_xht41f$(t,[Cn().X,Cn().Y,Cn().Z]))return this.withEmptyStatValues();if(null==(i=Wy().computeLevels_wuiwgl$(t,this.myBinOptions_0)))return Ni().emptyFrame();var r=i,o=Wy().computeContours_jco5dt$(t,r),a=y(t.range_8xm3sj$($o().X)),s=y(t.range_8xm3sj$($o().Y)),l=y(t.range_8xm3sj$($o().Z)),u=new Sy(a,s),c=By().computeFillLevels_4v6zbb$(l,r),p=u.createPolygons_lrt0be$(o,r,c);return Cy().getPolygonDataFrame_dnsuee$(c,p)},Zy.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Jy,Qy,t$,e$,n$,i$,r$=null;function o$(){return null===r$&&new Zy,r$}function a$(t,e,n,i){v$(),Fm.call(this,v$().DEF_MAPPING_0),this.correlationMethod=t,this.type=e,this.fillDiagonal=n,this.threshold=i}function s$(t,e){w.call(this),this.name$=t,this.ordinal$=e}function l$(){l$=function(){},Jy=new s$("PEARSON",0),Qy=new s$("SPEARMAN",1),t$=new s$("KENDALL",2)}function u$(){return l$(),Jy}function c$(){return l$(),Qy}function p$(){return l$(),t$}function h$(t,e){w.call(this),this.name$=t,this.ordinal$=e}function _$(){_$=function(){},e$=new h$("FULL",0),n$=new h$("UPPER",1),i$=new h$("LOWER",2)}function f$(){return _$(),e$}function d$(){return _$(),n$}function m$(){return _$(),i$}function y$(){$$=this,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().Y),Mt(Cn().COLOR,Rv().CORR),Mt(Cn().FILL,Rv().CORR),Mt(Cn().LABEL,Rv().CORR)]),this.DEF_CORRELATION_METHOD=u$(),this.DEF_TYPE=f$(),this.DEF_FILL_DIAGONAL=!0,this.DEF_THRESHOLD=0}Xy.$metadata$={kind:h,simpleName:"ContourfStat",interfaces:[Fm]},a$.prototype.apply_kdy6bf$$default=function(t,e,n){if(this.correlationMethod!==u$()){var i="Unsupported correlation method: "+this.correlationMethod+" (only Pearson is currently available)";throw d(i.toString())}if(!Me(0,1).contains_mef7kx$(this.threshold)){var r="Threshold value: "+this.threshold+" must be in interval [0.0, 1.0]";throw d(r.toString())}var o,a=w$().correlationMatrix_ofg6u8$(t,this.type,this.fillDiagonal,C("correlationPearson",(function(t,e){return kg(t,e)})),this.threshold),s=a.getNumeric_8xm3sj$(Rv().CORR),l=K(V(s,10));for(o=s.iterator();o.hasNext();){var u=o.next();l.add_11rb$(null!=u?W.abs(u):null)}var c=l;return a.builder().putNumeric_s1rqo9$(Rv().CORR_ABS,c).build()},a$.prototype.consumes=function(){return $()},s$.$metadata$={kind:h,simpleName:"Method",interfaces:[w]},s$.values=function(){return[u$(),c$(),p$()]},s$.valueOf_61zpoe$=function(t){switch(t){case"PEARSON":return u$();case"SPEARMAN":return c$();case"KENDALL":return p$();default:x("No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Method."+t)}},h$.$metadata$={kind:h,simpleName:"Type",interfaces:[w]},h$.values=function(){return[f$(),d$(),m$()]},h$.valueOf_61zpoe$=function(t){switch(t){case"FULL":return f$();case"UPPER":return d$();case"LOWER":return m$();default:x("No enum constant jetbrains.datalore.plot.base.stat.CorrelationStat.Type."+t)}},y$.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var $$=null;function v$(){return null===$$&&new y$,$$}function g$(){b$=this}a$.$metadata$={kind:h,simpleName:"CorrelationStat",interfaces:[Fm]},g$.prototype.correlation_n2j75g$=function(t,e,n){var i=xb(t,e);return n(i.component1(),i.component2())},g$.prototype.createComparator_0=function(t){var e,n=Be(t),i=K(V(n,10));for(e=n.iterator();e.hasNext();){var r=e.next();i.add_11rb$(Mt(r.value.label,r.index))}var o,a=me(i);return new pt((o=a,function(t,e){var n,i;if(null==(n=o.get_11rb$(t)))throw q(("Unknown variable label "+t+".").toString());var r=n;if(null==(i=o.get_11rb$(e)))throw q(("Unknown variable label "+e+".").toString());return r-i|0}))},g$.prototype.correlationMatrix_ofg6u8$=function(t,e,n,i,r){var o,a;void 0===r&&(r=v$().DEF_THRESHOLD);var s,l=t.variables(),u=c();for(s=l.iterator();s.hasNext();){var p=s.next();co().isNumeric_vede35$(t,p.name)&&u.add_11rb$(p)}for(var h=u,_=Ue(),f=D(),d=function(t,e,n){return function(i,r,o){if(W.abs(o)>=t){e.add_11rb$(i),e.add_11rb$(r);var a=n,s=Mt(i,r);a.put_xwzc9p$(s,o)}}}(r,_,f),m=0,y=h.iterator();y.hasNext();++m){var $=y.next(),v=t.getNumeric_8xm3sj$($);n&&d($.label,$.label,1);for(var g=0;g 1024 is too large!";throw d(a.toString())}}function B$(t){return t.first}function U$(t,e){w.call(this),this.name$=t,this.ordinal$=e}function F$(){F$=function(){},O$=new U$("GAUSSIAN",0),N$=new U$("RECTANGULAR",1),P$=new U$("TRIANGULAR",2),A$=new U$("BIWEIGHT",3),j$=new U$("EPANECHNIKOV",4),L$=new U$("OPTCOSINE",5),R$=new U$("COSINE",6)}function q$(){return F$(),O$}function G$(){return F$(),N$}function H$(){return F$(),P$}function Y$(){return F$(),A$}function V$(){return F$(),j$}function K$(){return F$(),L$}function W$(){return F$(),R$}function X$(t,e){w.call(this),this.name$=t,this.ordinal$=e}function Z$(){Z$=function(){},I$=new X$("NRD0",0),z$=new X$("NRD",1)}function J$(){return Z$(),I$}function Q$(){return Z$(),z$}function tv(){ev=this,this.DEF_KERNEL=q$(),this.DEF_ADJUST=1,this.DEF_N=512,this.DEF_BW=J$(),this.DEF_FULL_SCAN_MAX=5e3,this.DEF_MAPPING_0=Bt([Mt(Cn().X,Rv().X),Mt(Cn().Y,Rv().DENSITY)]),this.MAX_N_0=1024}M$.prototype.consumes=function(){return X([Cn().X,Cn().WEIGHT])},M$.prototype.apply_kdy6bf$$default=function(t,n,i){var r,o,a,s,l,u,p;if(!this.hasRequiredValues_xht41f$(t,[Cn().X]))return this.withEmptyStatValues();if(t.has_8xm3sj$($o().WEIGHT)){var h=b.SeriesUtil.filterFinite_10sy24$(t.getNumeric_8xm3sj$($o().X),t.getNumeric_8xm3sj$($o().WEIGHT)),_=h.get_za3lpa$(0),f=h.get_za3lpa$(1),d=qe(O(E(_,f),new pt(D$(B$))));u=d.component1(),p=d.component2()}else{var m,$=he(t.getNumeric_8xm3sj$($o().X)),v=c();for(m=$.iterator();m.hasNext();){var g=m.next();k(g)&&v.add_11rb$(g)}for(var w=(u=Ge(v)).size,x=K(w),C=0;C0){var d=_/1.34;return.9*W.min(f,d)*W.pow(o,-.2)}if(f>0){return.9*f*W.pow(o,-.2)}break;case"NRD":if(_>0){var m=_/1.34;return 1.06*W.min(f,m)*W.pow(o,-.2)}if(f>0){return 1.06*f*W.pow(o,-.2)}}return 1},iv.prototype.kernel_uyf859$=function(t){var e;switch(t.name){case"GAUSSIAN":e=rv;break;case"RECTANGULAR":e=ov;break;case"TRIANGULAR":e=av;break;case"BIWEIGHT":e=sv;break;case"EPANECHNIKOV":e=lv;break;case"OPTCOSINE":e=uv;break;default:e=cv}return e},iv.prototype.densityFunctionFullScan_hztk2d$=function(t,e,n,i,r){return o=t,a=n,s=i*r,l=e,function(t){for(var e=0,n=0;n!==o.size;++n)e+=a((t-o.get_za3lpa$(n))/s)*l.get_za3lpa$(n);return e/s};var o,a,s,l},iv.prototype.densityFunctionFast_hztk2d$=function(t,e,n,i,r){var o,a,s,l,u,c=i*r;return o=t,a=5*c,s=n,l=c,u=e,function(t){var e,n=0,i=Ae(o,t-a);i<0&&(i=(0|-i)-1|0);var r=Ae(o,t+a);r<0&&(r=(0|-r)-1|0),e=r;for(var c=i;c=1))throw d("Degree of polynomial regression must be at least 1".toString());if(1===this.polynomialDegree_0)n=new db(t,e,this.confidenceLevel_0);else{if(!gb().canBeComputed_fgqkrm$(t,e,this.polynomialDegree_0))return p;n=new yb(t,e,this.confidenceLevel_0,this.polynomialDegree_0)}break;case"LOESS":var $=new mb(t,e,this.confidenceLevel_0,this.span_0);if(!$.canCompute)return p;n=$;break;default:throw d("Unsupported smoother method: "+this.smoothingMethod_0+" (only 'lm' and 'loess' methods are currently available)")}var v=n;if(null==(i=b.SeriesUtil.range_l63ks6$(t)))return p;var g=i,w=g.lowerEnd,x=(g.upperEnd-w)/(this.smootherPointCount_0-1|0);r=this.smootherPointCount_0;for(var k=0;ke)throw q(("NumberIsTooLarge - x0:"+t+", x1:"+e).toString());return this.cumulativeProbability_14dthe$(e)-this.cumulativeProbability_14dthe$(t)},zv.prototype.value_14dthe$=function(t){return this.this$AbstractRealDistribution.cumulativeProbability_14dthe$(t)-this.closure$p},zv.$metadata$={kind:h,interfaces:[ub]},Iv.prototype.inverseCumulativeProbability_14dthe$=function(t){if(t<0||t>1)throw q(("OutOfRange [0, 1] - p"+t).toString());var e=this.supportLowerBound;if(0===t)return e;var n=this.supportUpperBound;if(1===t)return n;var i,r=this.numericalMean,o=this.numericalVariance,a=W.sqrt(o);if(i=!(ve(r)||Ot(r)||ve(a)||Ot(a)),e===Q.NEGATIVE_INFINITY)if(i){var s=(1-t)/t;e=r-a*W.sqrt(s)}else for(e=-1;this.cumulativeProbability_14dthe$(e)>=t;)e*=2;if(n===Q.POSITIVE_INFINITY)if(i){var l=t/(1-t);n=r+a*W.sqrt(l)}else for(n=1;this.cumulativeProbability_14dthe$(n)=this.supportLowerBound){var h=this.cumulativeProbability_14dthe$(c);if(this.cumulativeProbability_14dthe$(c-p)===h){for(n=c;n-e>p;){var _=.5*(e+n);this.cumulativeProbability_14dthe$(_)1||e<=0||n<=0)o=Q.NaN;else if(t>(e+1)/(e+n+2))o=1-this.regularizedBeta_tychlm$(1-t,n,e,i,r);else{var a=new lg(n,e),s=1-t,l=e*W.log(t)+n*W.log(s)-W.log(e)-this.logBeta_88ee24$(e,n,i,r);o=1*W.exp(l)/a.evaluate_syxxoe$(t,i,r)}return o},sg.prototype.logBeta_88ee24$=function(t,e,n,i){return void 0===n&&(n=this.DEFAULT_EPSILON_0),void 0===i&&(i=2147483647),Ot(t)||Ot(e)||t<=0||e<=0?Q.NaN:Ag().logGamma_14dthe$(t)+Ag().logGamma_14dthe$(e)-Ag().logGamma_14dthe$(t+e)},sg.$metadata$={kind:p,simpleName:"Beta",interfaces:[]};var ug=null;function cg(){return null===ug&&new sg,ug}function pg(){this.BLOCK_SIZE_0=52,this.rows_0=0,this.columns_0=0,this.blockRows_0=0,this.blockColumns_0=0,this.blocks_4giiw5$_0=this.blocks_4giiw5$_0}function hg(t,e,n){return n=n||Object.create(pg.prototype),pg.call(n),n.rows_0=t,n.columns_0=e,n.blockRows_0=(t+n.BLOCK_SIZE_0-1|0)/n.BLOCK_SIZE_0|0,n.blockColumns_0=(e+n.BLOCK_SIZE_0-1|0)/n.BLOCK_SIZE_0|0,n.blocks_0=n.createBlocksLayout_0(t,e),n}function _g(t,e){return e=e||Object.create(pg.prototype),pg.call(e),e.create_omvvzo$(t.length,t[0].length,e.toBlocksLayout_n8oub7$(t),!1),e}function fg(){yg()}function dg(){mg=this,this.DEFAULT_ABSOLUTE_ACCURACY_0=1e-6}Object.defineProperty(pg.prototype,"blocks_0",{configurable:!0,get:function(){return null==this.blocks_4giiw5$_0?Tt("blocks"):this.blocks_4giiw5$_0},set:function(t){this.blocks_4giiw5$_0=t}}),pg.prototype.create_omvvzo$=function(t,n,i,r){var o;this.rows_0=t,this.columns_0=n,this.blockRows_0=(t+this.BLOCK_SIZE_0-1|0)/this.BLOCK_SIZE_0|0,this.blockColumns_0=(n+this.BLOCK_SIZE_0-1|0)/this.BLOCK_SIZE_0|0;var a=c();r||(this.blocks_0=i);var s=0;o=this.blockRows_0;for(var l=0;lthis.getRowDimension_0())throw q(("row out of range: "+t).toString());if(n<0||n>this.getColumnDimension_0())throw q(("column out of range: "+n).toString());var i=t/this.BLOCK_SIZE_0|0,r=n/this.BLOCK_SIZE_0|0,o=e.imul(t-e.imul(i,this.BLOCK_SIZE_0)|0,this.blockWidth_0(r))+(n-e.imul(r,this.BLOCK_SIZE_0))|0;return this.blocks_0[e.imul(i,this.blockColumns_0)+r|0][o]},pg.prototype.getRowDimension_0=function(){return this.rows_0},pg.prototype.getColumnDimension_0=function(){return this.columns_0},pg.prototype.blockWidth_0=function(t){return t===(this.blockColumns_0-1|0)?this.columns_0-e.imul(t,this.BLOCK_SIZE_0)|0:this.BLOCK_SIZE_0},pg.prototype.blockHeight_0=function(t){return t===(this.blockRows_0-1|0)?this.rows_0-e.imul(t,this.BLOCK_SIZE_0)|0:this.BLOCK_SIZE_0},pg.prototype.toBlocksLayout_n8oub7$=function(t){for(var n=t.length,i=t[0].length,r=(n+this.BLOCK_SIZE_0-1|0)/this.BLOCK_SIZE_0|0,o=(i+this.BLOCK_SIZE_0-1|0)/this.BLOCK_SIZE_0|0,a=0;a!==t.length;++a){var s=t[a].length;if(s!==i)throw q(("Wrong dimension: "+i+", "+s).toString())}for(var l=c(),u=0,p=0;p0?k=-k:x=-x,E=p,p=c;var S=y*k,T=x>=1.5*$*k-W.abs(S);if(!T){var O=.5*E*k;T=x>=W.abs(O)}T?p=c=$:c=x/k}r=a,o=s;var N=c;W.abs(N)>y?a+=c:$>0?a+=y:a-=y,((s=this.computeObjectiveValue_14dthe$(a))>0&&u>0||s<=0&&u<=0)&&(l=r,u=o,p=c=a-r)}},dg.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var mg=null;function yg(){return null===mg&&new dg,mg}function $g(t,e){return void 0===t&&(t=yg().DEFAULT_ABSOLUTE_ACCURACY_0),Vv(t,e=e||Object.create(fg.prototype)),fg.call(e),e}function vg(){wg()}function gg(){bg=this,this.DEFAULT_EPSILON_0=1e-8}fg.$metadata$={kind:h,simpleName:"BrentSolver",interfaces:[Yv]},vg.prototype.evaluate_12fank$=function(t,e){return this.evaluate_syxxoe$(t,wg().DEFAULT_EPSILON_0,e)},vg.prototype.evaluate_syxxoe$=function(t,e,n){void 0===e&&(e=wg().DEFAULT_EPSILON_0),void 0===n&&(n=2147483647);for(var i=1,r=this.getA_5wr77w$(0,t),o=0,a=1,s=r/a,l=0,u=Q.MAX_VALUE;le;){l=l+1|0;var c=this.getA_5wr77w$(l,t),p=this.getB_5wr77w$(l,t),h=c*r+p*i,_=c*a+p*o,f=!1;if(ve(h)||ve(_)){var d=1,m=1,y=W.max(c,p);if(y<=0)throw q("ConvergenceException".toString());f=!0;for(var $=0;$<5&&(m=d,d*=y,0!==c&&c>p?(h=r/m+p/d*i,_=a/m+p/d*o):0!==p&&(h=c/d*r+i/m,_=c/d*a+o/m),f=ve(h)||ve(_));$++);}if(f)throw q("ConvergenceException".toString());var v=h/_;if(Ot(v))throw q("ConvergenceException".toString());var g=v/s-1;u=W.abs(g),s=h/_,i=r,r=h,o=a,a=_}if(l>=n)throw q("MaxCountExceeded".toString());return s},gg.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var bg=null;function wg(){return null===bg&&new gg,bg}function xg(t){return Qe(t)}function kg(t,e){if(t.length!==e.length)throw d("Two series must have the same size.".toString());if(0===t.length)throw d("Can't correlate empty sequences.".toString());for(var n=xg(t),i=xg(e),r=0,o=0,a=0,s=0;s!==t.length;++s){var l=t[s]-n,u=e[s]-i;r+=l*u,o+=W.pow(l,2),a+=W.pow(u,2)}if(0===o||0===a)throw d("Correlation is not defined for sequences with zero variation.".toString());var c=o*a;return r/W.sqrt(c)}function Eg(t){if(Tg(),this.knots_0=t,this.ps_0=null,0===this.knots_0.length)throw d("The knots list must not be empty".toString());this.ps_0=tn([new Wg(new Float64Array([1])),new Wg(new Float64Array([-Qe(this.knots_0),1]))])}function Cg(){Sg=this,this.X=new Wg(new Float64Array([0,1]))}vg.$metadata$={kind:h,simpleName:"ContinuedFraction",interfaces:[]},Eg.prototype.alphaBeta_0=function(t){var e,n;if(t!==this.ps_0.size)throw d("Alpha must be calculated sequentially.".toString());var i=Pe(this.ps_0),r=this.ps_0.get_za3lpa$(this.ps_0.size-2|0),o=0,a=0,s=0;for(e=this.knots_0,n=0;n!==e.length;++n){var l=e[n],u=i.value_14dthe$(l),c=W.pow(u,2),p=r.value_14dthe$(l);o+=l*c,a+=c,s+=W.pow(p,2)}return new de(o/a,a/s)},Eg.prototype.getPolynomial_za3lpa$=function(t){var e;if(!(t>=0))throw d("Degree of Forsythe polynomial must not be negative".toString());if(!(t=this.ps_0.size){e=t+1|0;for(var n=this.ps_0.size;n<=e;n++){var i=this.alphaBeta_0(n),r=i.component1(),o=i.component2(),a=Pe(this.ps_0),s=this.ps_0.get_za3lpa$(this.ps_0.size-2|0),l=Tg().X.times_3j0b7h$(a).minus_3j0b7h$(Jg(r,a)).minus_3j0b7h$(Jg(o,s));this.ps_0.add_11rb$(l)}}return this.ps_0.get_za3lpa$(t)},Cg.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var Sg=null;function Tg(){return null===Sg&&new Cg,Sg}function Og(){Pg=this,this.GAMMA=.5772156649015329,this.DEFAULT_EPSILON_0=1e-14,this.LANCZOS_0=new Float64Array([.9999999999999971,57.15623566586292,-59.59796035547549,14.136097974741746,-.4919138160976202,3399464998481189e-20,4652362892704858e-20,-9837447530487956e-20,.0001580887032249125,-.00021026444172410488,.00021743961811521265,-.0001643181065367639,8441822398385275e-20,-26190838401581408e-21,36899182659531625e-22]);var t=2*Pt.PI;this.HALF_LOG_2_PI_0=.5*W.log(t),this.C_LIMIT_0=49,this.S_LIMIT_0=1e-5}function Ng(t){this.closure$a=t,vg.call(this)}Eg.$metadata$={kind:h,simpleName:"ForsythePolynomialGenerator",interfaces:[]},Og.prototype.logGamma_14dthe$=function(t){var e;if(Ot(t)||t<=0)e=Q.NaN;else{for(var n=0,i=this.LANCZOS_0.length-1|0;i>=1;i--)n+=this.LANCZOS_0[i]/(t+i);var r=t+607/128+.5,o=(n+=this.LANCZOS_0[0])/t;e=(t+.5)*W.log(r)-r+this.HALF_LOG_2_PI_0+W.log(o)}return e},Og.prototype.regularizedGammaP_88ee24$=function(t,e,n,i){var r;if(void 0===n&&(n=this.DEFAULT_EPSILON_0),void 0===i&&(i=2147483647),Ot(t)||Ot(e)||t<=0||e<0)r=Q.NaN;else if(0===e)r=0;else if(e>=t+1)r=1-this.regularizedGammaQ_88ee24$(t,e,n,i);else{for(var o=0,a=1/t,s=a;;){var l=a/s;if(!(W.abs(l)>n&&o=i)throw q(("MaxCountExceeded - maxIterations: "+i).toString());if(ve(s))r=1;else{var u=-e+t*W.log(e)-this.logGamma_14dthe$(t);r=W.exp(u)*s}}return r},Ng.prototype.getA_5wr77w$=function(t,e){return 2*t+1-this.closure$a+e},Ng.prototype.getB_5wr77w$=function(t,e){return t*(this.closure$a-t)},Ng.$metadata$={kind:h,interfaces:[vg]},Og.prototype.regularizedGammaQ_88ee24$=function(t,e,n,i){var r;if(void 0===n&&(n=this.DEFAULT_EPSILON_0),void 0===i&&(i=2147483647),Ot(t)||Ot(e)||t<=0||e<0)r=Q.NaN;else if(0===e)r=1;else if(e0&&t<=this.S_LIMIT_0)return-this.GAMMA-1/t;if(t>=this.C_LIMIT_0){var e=1/(t*t);return W.log(t)-.5/t-e*(1/12+e*(1/120-e/252))}return this.digamma_14dthe$(t+1)-1/t},Og.prototype.trigamma_14dthe$=function(t){if(t>0&&t<=this.S_LIMIT_0)return 1/(t*t);if(t>=this.C_LIMIT_0){var e=1/(t*t);return 1/t+e/2+e/t*(1/6-e*(1/30+e/42))}return this.trigamma_14dthe$(t+1)+1/(t*t)},Og.$metadata$={kind:p,simpleName:"Gamma",interfaces:[]};var Pg=null;function Ag(){return null===Pg&&new Og,Pg}function jg(t,e){void 0===t&&(t=0),void 0===e&&(e=new Rg),this.maximalCount=t,this.maxCountCallback_0=e,this.count_k39d42$_0=0}function Lg(){}function Rg(){}function Ig(t,e,n){if(Ug(),void 0===t&&(t=Ug().DEFAULT_BANDWIDTH),void 0===e&&(e=2),void 0===n&&(n=Ug().DEFAULT_ACCURACY),this.bandwidth_0=t,this.robustnessIters_0=e,this.accuracy_0=n,this.bandwidth_0<=0||this.bandwidth_0>1)throw q(("Out of range of bandwidth value: "+this.bandwidth_0+" should be > 0 and <= 1").toString());if(this.robustnessIters_0<0)throw q(("Not positive Robutness iterationa: "+this.robustnessIters_0).toString())}function zg(){Bg=this,this.DEFAULT_BANDWIDTH=.3,this.DEFAULT_ROBUSTNESS_ITERS=2,this.DEFAULT_ACCURACY=1e-12}Object.defineProperty(jg.prototype,"count",{configurable:!0,get:function(){return this.count_k39d42$_0},set:function(t){this.count_k39d42$_0=t}}),jg.prototype.canIncrement=function(){return this.countthis.maximalCount&&this.maxCountCallback_0.trigger_za3lpa$(this.maximalCount)},jg.prototype.resetCount=function(){this.count=0},Lg.$metadata$={kind:f,simpleName:"MaxCountExceededCallback",interfaces:[]},Rg.prototype.trigger_za3lpa$=function(t){throw q(("MaxCountExceeded: "+t).toString())},Rg.$metadata$={kind:h,interfaces:[Lg]},jg.$metadata$={kind:h,simpleName:"Incrementor",interfaces:[]},Ig.prototype.interpolate_g9g6do$=function(t,e){return(new rb).interpolate_g9g6do$(t,this.smooth_0(t,e))},Ig.prototype.smooth_1=function(t,e,n){var i;if(t.length!==e.length)throw q(("Dimension mismatch of interpolation points: "+t.length+" != "+e.length).toString());var r=t.length;if(0===r)throw q("No data to interpolate".toString());if(this.checkAllFiniteReal_0(t),this.checkAllFiniteReal_0(e),this.checkAllFiniteReal_0(n),Kg().checkOrder_gf7tl1$(t),1===r)return new Float64Array([e[0]]);if(2===r)return new Float64Array([e[0],e[1]]);var o=jt(this.bandwidth_0*r);if(o<2)throw q(("LOESS 'bandwidthInPoints' is too small: "+o+" < 2").toString());var a=new Float64Array(r),s=new Float64Array(r),l=new Float64Array(r),u=new Float64Array(r);en(u,1),i=this.robustnessIters_0;for(var c=0;c<=i;c++){for(var p=new Int32Array([0,o-1|0]),h=0;h0&&this.updateBandwidthInterval_0(t,n,h,p);for(var f=p[0],d=p[1],m=0,y=0,$=0,v=0,g=0,b=1/(t[t[h]-t[f]>t[d]-t[h]?f:d]-_),w=W.abs(b),x=f;x<=d;x++){var k=t[x],E=e[x],C=x=1)u[M]=0;else{var U=1-B*B;u[M]=U*U}}}return a},Ig.prototype.updateBandwidthInterval_0=function(t,e,n,i){var r=i[0],o=i[1],a=this.nextNonzero_0(e,o);if(a=1)return 0;var n=1-e*e*e;return n*n*n},Ig.prototype.nextNonzero_0=function(t,e){for(var n=e+1|0;n=o)break t}else if(t[r]>o)break t}o=t[r],r=r+1|0}if(r===a)return!0;if(i)throw q("Non monotonic sequence".toString());return!1},Fg.prototype.checkOrder_hixecd$=function(t,e,n){this.checkOrder_j8c91m$(t,e,n,!0)},Fg.prototype.checkOrder_gf7tl1$=function(t){this.checkOrder_hixecd$(t,Hg(),!0)},Fg.$metadata$={kind:p,simpleName:"MathArrays",interfaces:[]};var Vg=null;function Kg(){return null===Vg&&new Fg,Vg}function Wg(t){this.coefficients_0=null;var e=null==t;if(e||(e=0===t.length),e)throw q("Empty polynomials coefficients array".toString());for(var n=t.length;n>1&&0===t[n-1|0];)n=n-1|0;this.coefficients_0=new Float64Array(n),Je(t,this.coefficients_0,0,0,n)}function Xg(t,e){return t+e}function Zg(t,e){return t-e}function Jg(t,e){return e.multiply_14dthe$(t)}function Qg(t,n){if(this.knots=null,this.polynomials=null,this.n_0=0,null==t)throw q("Null argument ".toString());if(t.length<2)throw q(("Spline partition must have at least 2 points, got "+t.length).toString());if((t.length-1|0)!==n.length)throw q(("Dimensions mismatch: "+n.length+" polynomial functions != "+t.length+" segment delimiters").toString());Kg().checkOrder_gf7tl1$(t),this.n_0=t.length-1|0,this.knots=t,this.polynomials=e.newArray(this.n_0,null),Je(n,this.polynomials,0,0,this.n_0)}function tb(){eb=this,this.SGN_MASK_0=hn,this.SGN_MASK_FLOAT_0=-2147483648}Wg.prototype.value_14dthe$=function(t){return this.evaluate_0(this.coefficients_0,t)},Wg.prototype.evaluate_0=function(t,e){if(null==t)throw q("Null argument: coefficients of the polynomial to evaluate".toString());var n=t.length;if(0===n)throw q("Empty polynomials coefficients array".toString());for(var i=t[n-1|0],r=n-2|0;r>=0;r--)i=e*i+t[r];return i},Wg.prototype.unaryPlus=function(){return new Wg(this.coefficients_0)},Wg.prototype.unaryMinus=function(){var t,e=new Float64Array(this.coefficients_0.length);t=this.coefficients_0;for(var n=0;n!==t.length;++n){var i=t[n];e[n]=-i}return new Wg(e)},Wg.prototype.apply_op_0=function(t,e){for(var n=o.Comparables.max_sdesaw$(this.coefficients_0.length,t.coefficients_0.length),i=new Float64Array(n),r=0;r=0;e--)0!==this.coefficients_0[e]&&(0!==t.length&&t.append_pdl1vj$(" + "),t.append_pdl1vj$(this.coefficients_0[e].toString()),e>0&&t.append_pdl1vj$("x"),e>1&&t.append_pdl1vj$("^").append_s8jyv4$(e));return t.toString()},Wg.$metadata$={kind:h,simpleName:"PolynomialFunction",interfaces:[]},Qg.prototype.value_14dthe$=function(t){var e;if(tthis.knots[this.n_0])throw q((t.toString()+" out of ["+this.knots[0]+", "+this.knots[this.n_0]+"] range").toString());var n=Ae(sn(this.knots),t);return n<0&&(n=(0|-n)-2|0),n>=this.polynomials.length&&(n=n-1|0),null!=(e=this.polynomials[n])?e.value_14dthe$(t-this.knots[n]):null},Qg.$metadata$={kind:h,simpleName:"PolynomialSplineFunction",interfaces:[]},tb.prototype.compareTo_yvo9jy$=function(t,e,n){return this.equals_yvo9jy$(t,e,n)?0:t=0;_--)p[_]=s[_]-a[_]*p[_+1|0],c[_]=(n[_+1|0]-n[_])/r[_]-r[_]*(p[_+1|0]+2*p[_])/3,h[_]=(p[_+1|0]-p[_])/(3*r[_]);for(var f=e.newArray(i,null),d=new Float64Array(4),m=0;m1?0:Q.NaN}}),Object.defineProperty(ob.prototype,"numericalVariance",{configurable:!0,get:function(){var t=this.degreesOfFreedom_0;return t>2?t/(t-2):t>1&&t<=2?Q.POSITIVE_INFINITY:Q.NaN}}),Object.defineProperty(ob.prototype,"supportLowerBound",{configurable:!0,get:function(){return Q.NEGATIVE_INFINITY}}),Object.defineProperty(ob.prototype,"supportUpperBound",{configurable:!0,get:function(){return Q.POSITIVE_INFINITY}}),Object.defineProperty(ob.prototype,"isSupportLowerBoundInclusive",{configurable:!0,get:function(){return!1}}),Object.defineProperty(ob.prototype,"isSupportUpperBoundInclusive",{configurable:!0,get:function(){return!1}}),Object.defineProperty(ob.prototype,"isSupportConnected",{configurable:!0,get:function(){return!0}}),ob.prototype.probability_14dthe$=function(t){return 0},ob.prototype.density_14dthe$=function(t){var e=this.degreesOfFreedom_0,n=(e+1)/2,i=Ag().logGamma_14dthe$(n),r=Pt.PI,o=1+t*t/e,a=i-.5*(W.log(r)+W.log(e))-Ag().logGamma_14dthe$(e/2)-n*W.log(o);return W.exp(a)},ob.prototype.cumulativeProbability_14dthe$=function(t){var e;if(0===t)e=.5;else{var n=cg().regularizedBeta_tychlm$(this.degreesOfFreedom_0/(this.degreesOfFreedom_0+t*t),.5*this.degreesOfFreedom_0,.5);e=t<0?.5*n:1-.5*n}return e},ab.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var sb=null;function lb(){return null===sb&&new ab,sb}function ub(){}function cb(){}function pb(){hb=this}ob.$metadata$={kind:h,simpleName:"TDistribution",interfaces:[Iv]},ub.$metadata$={kind:f,simpleName:"UnivariateFunction",interfaces:[]},cb.$metadata$={kind:f,simpleName:"UnivariateSolver",interfaces:[ag]},pb.prototype.solve_ljmp9$=function(t,e,n){return $g().solve_rmnly1$(2147483647,t,e,n)},pb.prototype.solve_wb66u3$=function(t,e,n,i){return $g(i).solve_rmnly1$(2147483647,t,e,n)},pb.prototype.forceSide_i33h9z$=function(t,e,n,i,r,o,a){if(a===Xv())return i;for(var s=n.absoluteAccuracy,l=i*n.relativeAccuracy,u=W.abs(l),c=W.max(s,u),p=i-c,h=W.max(r,p),_=e.value_14dthe$(h),f=i+c,d=W.min(o,f),m=e.value_14dthe$(d),y=t-2|0;y>0;){if(_>=0&&m<=0||_<=0&&m>=0)return n.solve_epddgp$(y,e,h,d,i,a);var $=!1,v=!1;if(_=0?$=!0:v=!0:_>m?_<=0?$=!0:v=!0:($=!0,v=!0),$){var g=h-c;h=W.max(r,g),_=e.value_14dthe$(h),y=y-1|0}if(v){var b=d+c;d=W.min(o,b),m=e.value_14dthe$(d),y=y-1|0}}throw q("NoBracketing".toString())},pb.prototype.bracket_cflw21$=function(t,e,n,i,r){if(void 0===r&&(r=2147483647),r<=0)throw q("NotStrictlyPositive".toString());this.verifySequence_yvo9jy$(n,e,i);var o,a,s=e,l=e,u=0;do{var c=s-1;s=W.max(c,n);var p=l+1;l=W.min(p,i),o=t.value_14dthe$(s),a=t.value_14dthe$(l),u=u+1|0}while(o*a>0&&un||l0)throw q("NoBracketing".toString());return new Float64Array([s,l])},pb.prototype.midpoint_lu1900$=function(t,e){return.5*(t+e)},pb.prototype.isBracketing_ljmp9$=function(t,e,n){var i=t.value_14dthe$(e),r=t.value_14dthe$(n);return i>=0&&r<=0||i<=0&&r>=0},pb.prototype.isSequence_yvo9jy$=function(t,e,n){return t=e)throw q("NumberIsTooLarge".toString())},pb.prototype.verifySequence_yvo9jy$=function(t,e,n){this.verifyInterval_lu1900$(t,e),this.verifyInterval_lu1900$(e,n)},pb.prototype.verifyBracketing_ljmp9$=function(t,e,n){if(this.verifyInterval_lu1900$(e,n),!this.isBracketing_ljmp9$(t,e,n))throw q("NoBracketing".toString())},pb.$metadata$={kind:p,simpleName:"UnivariateSolverUtils",interfaces:[]};var hb=null;function _b(){return null===hb&&new pb,hb}function fb(t,e,n,i){this.y=t,this.ymin=e,this.ymax=n,this.se=i}function db(t,e,n){bb.call(this,t,e,n),this.n_0=0,this.meanX_0=0,this.sumXX_0=0,this.beta1_0=0,this.beta0_0=0,this.sy_0=0,this.tcritical_0=0;var i,r=xb(t,e),o=r.component1(),a=r.component2();this.n_0=o.length,this.meanX_0=Qe(o);var s=0;for(i=0;i!==o.length;++i){var l=o[i]-this.meanX_0;s+=W.pow(l,2)}this.sumXX_0=s;var u,c=Qe(a),p=0;for(u=0;u!==a.length;++u){var h=a[u]-c;p+=W.pow(h,2)}var _,f=p,d=0;for(_=fn(o,a).iterator();_.hasNext();){var m=_.next(),y=m.component1(),$=m.component2();d+=(y-this.meanX_0)*($-c)}var v=d;this.beta1_0=v/this.sumXX_0,this.beta0_0=c-this.beta1_0*this.meanX_0;var g=f-v*v/this.sumXX_0,b=W.max(0,g)/(this.n_0-2|0);this.sy_0=W.sqrt(b);var w=1-n;this.tcritical_0=new ob(this.n_0-2).inverseCumulativeProbability_14dthe$(1-w/2)}function mb(t,e,n,i){var r;bb.call(this,t,e,n),this.bandwidth_0=i,this.canCompute=!1,this.n_0=0,this.meanX_0=0,this.sumXX_0=0,this.sy_0=0,this.tcritical_0=0,this.polynomial_6goixr$_0=this.polynomial_6goixr$_0;var o=Eb(t,e),a=o.component1(),s=o.component2();this.n_0=a.length;var l,u=this.n_0-2,c=jt(this.bandwidth_0*this.n_0)>=2;this.canCompute=this.n_0>=3&&u>0&&c,this.meanX_0=Qe(a);var p=0;for(l=0;l!==a.length;++l){var h=a[l]-this.meanX_0;p+=W.pow(h,2)}this.sumXX_0=p;var _,f=Qe(s),d=0;for(_=0;_!==s.length;++_){var m=s[_]-f;d+=W.pow(m,2)}var y,$=d,v=0;for(y=fn(a,s).iterator();y.hasNext();){var g=y.next(),b=g.component1(),w=g.component2();v+=(b-this.meanX_0)*(w-f)}var x=$-v*v/this.sumXX_0,k=W.max(0,x)/(this.n_0-2|0);if(this.sy_0=W.sqrt(k),this.canCompute&&(this.polynomial_0=this.getPoly_0(a,s)),this.canCompute){var E=1-n;r=new ob(u).inverseCumulativeProbability_14dthe$(1-E/2)}else r=Q.NaN;this.tcritical_0=r}function yb(t,e,n,i){if(gb(),bb.call(this,t,e,n),this.p_0=null,this.n_0=0,this.meanX_0=0,this.sumXX_0=0,this.sy_0=0,this.tcritical_0=0,!(i>=2))throw d("Degree of polynomial must be at least 2".toString());var r,o=Eb(t,e),a=o.component1(),s=o.component2();if(this.n_0=a.length,!(this.n_0>i))throw d("The number of valid data points must be greater than deg".toString());this.p_0=this.calcPolynomial_0(i,a,s),this.meanX_0=Qe(a);var l=0;for(r=0;r!==a.length;++r){var u=a[r]-this.meanX_0;l+=W.pow(u,2)}this.sumXX_0=l;var c,p=(this.n_0-i|0)-1,h=0;for(c=fn(a,s).iterator();c.hasNext();){var _=c.next(),f=_.component1(),m=_.component2()-this.p_0.value_14dthe$(f);h+=W.pow(m,2)}var y=h/p;this.sy_0=W.sqrt(y);var $=1-n;this.tcritical_0=new ob(p).inverseCumulativeProbability_14dthe$(1-$/2)}function $b(){vb=this}fb.$metadata$={kind:h,simpleName:"EvalResult",interfaces:[]},fb.prototype.component1=function(){return this.y},fb.prototype.component2=function(){return this.ymin},fb.prototype.component3=function(){return this.ymax},fb.prototype.component4=function(){return this.se},fb.prototype.copy_6y0v78$=function(t,e,n,i){return new fb(void 0===t?this.y:t,void 0===e?this.ymin:e,void 0===n?this.ymax:n,void 0===i?this.se:i)},fb.prototype.toString=function(){return"EvalResult(y="+e.toString(this.y)+", ymin="+e.toString(this.ymin)+", ymax="+e.toString(this.ymax)+", se="+e.toString(this.se)+")"},fb.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*(t=31*t+e.hashCode(this.y)|0)+e.hashCode(this.ymin)|0)+e.hashCode(this.ymax)|0)+e.hashCode(this.se)|0},fb.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.y,t.y)&&e.equals(this.ymin,t.ymin)&&e.equals(this.ymax,t.ymax)&&e.equals(this.se,t.se)},db.prototype.value_0=function(t){return this.beta1_0*t+this.beta0_0},db.prototype.evalX_14dthe$=function(t){var e=t-this.meanX_0,n=W.pow(e,2),i=this.sy_0,r=1/this.n_0+n/this.sumXX_0,o=i*W.sqrt(r),a=this.tcritical_0*o,s=this.value_0(t);return new fb(s,s-a,s+a,o)},db.$metadata$={kind:h,simpleName:"LinearRegression",interfaces:[bb]},Object.defineProperty(mb.prototype,"polynomial_0",{configurable:!0,get:function(){return null==this.polynomial_6goixr$_0?Tt("polynomial"):this.polynomial_6goixr$_0},set:function(t){this.polynomial_6goixr$_0=t}}),mb.prototype.evalX_14dthe$=function(t){var e=t-this.meanX_0,n=W.pow(e,2),i=this.sy_0,r=1/this.n_0+n/this.sumXX_0,o=i*W.sqrt(r),a=this.tcritical_0*o,s=y(this.polynomial_0.value_14dthe$(t));return new fb(s,s-a,s+a,o)},mb.prototype.getPoly_0=function(t,e){return new Ig(this.bandwidth_0,4).interpolate_g9g6do$(t,e)},mb.$metadata$={kind:h,simpleName:"LocalPolynomialRegression",interfaces:[bb]},yb.prototype.calcPolynomial_0=function(t,e,n){for(var i=new Eg(e),r=new Wg(new Float64Array([0])),o=0;o<=t;o++){var a=i.getPolynomial_za3lpa$(o),s=this.coefficient_0(a,e,n);r=r.plus_3j0b7h$(Jg(s,a))}return r},yb.prototype.coefficient_0=function(t,e,n){for(var i=0,r=0,o=0;on},$b.$metadata$={kind:p,simpleName:"Companion",interfaces:[]};var vb=null;function gb(){return null===vb&&new $b,vb}function bb(t,e,n){if(!Me(.01,.99).contains_mef7kx$(n))throw d(("Confidence level is out of range [0.01-0.99]. CL:"+n).toString());if(t.size!==e.size){var i="X/Y must have same size. X:"+F(t.size)+" Y:"+F(e.size);throw d(i.toString())}}yb.$metadata$={kind:h,simpleName:"PolynomialRegression",interfaces:[bb]},bb.$metadata$={kind:h,simpleName:"RegressionEvaluator",interfaces:[]};var wb=Ye((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function xb(t,e){var n,i=c(),r=c();for(n=yn(mn(t),mn(e)).iterator();n.hasNext();){var o=n.next(),a=o.component1(),s=o.component2();b.SeriesUtil.allFinite_jma9l8$(a,s)&&(i.add_11rb$(y(a)),r.add_11rb$(y(s)))}return new de(dn(i),dn(r))}function kb(t){return t.first}function Eb(t,e){var n=function(t,e){var n,i=c();for(n=yn(mn(t),mn(e)).iterator();n.hasNext();){var r=n.next(),o=r.component1(),a=r.component2();b.SeriesUtil.allFinite_jma9l8$(o,a)&&i.add_11rb$(new de(y(o),y(a)))}return i}(t,e);n.size>1&&ze(n,new pt(wb(kb)));var i=function(t){var e;if(t.isEmpty())return new de(c(),c());var n=c(),i=c(),r=Ne(t),o=r.component1(),a=r.component2(),s=1;for(e=$n(mn(t),1).iterator();e.hasNext();){var l=e.next(),u=l.component1(),p=l.component2();u===o?(a+=p,s=s+1|0):(n.add_11rb$(o),i.add_11rb$(a/s),o=u,a=p,s=1)}return n.add_11rb$(o),i.add_11rb$(a/s),new de(n,i)}(n);return new de(dn(i.first),dn(i.second))}function Cb(t){this.myValue_0=t}function Sb(t){this.myValue_0=t}function Tb(){Ob=this}Cb.prototype.getAndAdd_14dthe$=function(t){var e=this.myValue_0;return this.myValue_0=e+t,e},Cb.prototype.get=function(){return this.myValue_0},Cb.$metadata$={kind:h,simpleName:"MutableDouble",interfaces:[]},Object.defineProperty(Sb.prototype,"andIncrement",{configurable:!0,get:function(){return this.getAndAdd_za3lpa$(1)}}),Sb.prototype.get=function(){return this.myValue_0},Sb.prototype.getAndAdd_za3lpa$=function(t){var e=this.myValue_0;return this.myValue_0=e+t|0,e},Sb.prototype.increment=function(){this.getAndAdd_za3lpa$(1)},Sb.$metadata$={kind:h,simpleName:"MutableInteger",interfaces:[]},Tb.prototype.sampleWithoutReplacement_o7ew15$=function(t,e,n,i,r){for(var o=e<=(t/2|0),a=o?e:t-e|0,s=Ie();s.size"],r=this.myPreferredSize_8a54qv$_0.get().y/2-8;for(t=0;t!==i.length;++t){var o=new x(i[t]);o.setHorizontalAnchor_ja80zo$(k.MIDDLE),o.setVerticalAnchor_yaudma$(E.CENTER),o.moveTo_lu1900$(this.myPreferredSize_8a54qv$_0.get().x/2,r),this.rootGroup.children().add_11rb$(o.rootGroup),r+=16}}},hr.prototype.onEvent_11rb$=function(t){var e=t.newValue;S(e).x>0&&e.y>0&&this.this$Plot.rebuildPlot_v06af3$_0()},hr.$metadata$={kind:$,interfaces:[T]},_r.prototype.doRemove=function(){this.this$Plot.myTooltipHelper_3jkkzs$_0.removeAllTileInfos(),this.this$Plot.myLiveMapFigures_nd8qng$_0.clear()},_r.$metadata$={kind:$,interfaces:[O]},cr.prototype.buildPlot_wr1hxq$_0=function(){this.rootGroup.addClass_61zpoe$(d_().PLOT),this.buildPlotComponents_8cuv6w$_0(),this.reg_3xv6fb$(this.myPreferredSize_8a54qv$_0.addHandler_gxwwpc$(new hr(this))),this.reg_3xv6fb$(new _r(this))},cr.prototype.rebuildPlot_v06af3$_0=function(){this.clear(),this.buildPlot_wr1hxq$_0()},cr.prototype.createTile_rg9gwo$_0=function(t,e,n,i){var r,o,a;if(null!=e.xAxisInfo&&null!=e.yAxisInfo){var s=S(e.xAxisInfo.axisDomain),l=e.xAxisInfo.axisLength,u=S(e.yAxisInfo.axisDomain),c=e.yAxisInfo.axisLength;r=this.coordProvider.buildAxisScaleX_ny58zc$(this.scaleXProto,s,l,S(e.xAxisInfo.axisBreaks)),o=this.coordProvider.buildAxisScaleY_ny58zc$(this.scaleYProto,u,c,S(e.yAxisInfo.axisBreaks)),a=this.coordProvider.createCoordinateSystem_uncllg$(s,l,u,c)}else r=new rr,o=new rr,a=new ir;var p=new Cr(n,r,o,t,e,a,i);return p.setShowAxis_6taknv$(this.isAxisEnabled),p.debugDrawing().set_11rb$(yr().DEBUG_DRAWING_0),p},cr.prototype.createAxisTitle_depkt8$_0=function(t,n,i,r){var o,a=k.MIDDLE;switch(n.name){case"LEFT":case"RIGHT":case"TOP":o=E.TOP;break;case"BOTTOM":o=E.BOTTOM;break;default:o=e.noWhenBranchMatched()}var s,l=o,u=0;switch(n.name){case"LEFT":s=new h(i.left+$p().AXIS_TITLE_OUTER_MARGIN,r.center.y),u=-90;break;case"RIGHT":s=new h(i.right-$p().AXIS_TITLE_OUTER_MARGIN,r.center.y),u=90;break;case"TOP":s=new h(r.center.x,i.top+$p().AXIS_TITLE_OUTER_MARGIN);break;case"BOTTOM":s=new h(r.center.x,i.bottom-$p().AXIS_TITLE_OUTER_MARGIN);break;default:e.noWhenBranchMatched()}var c=new x(t);c.setHorizontalAnchor_ja80zo$(a),c.setVerticalAnchor_yaudma$(l),c.moveTo_gpjtzr$(s),c.rotate_14dthe$(u);var p=c.rootGroup;p.addClass_61zpoe$(d_().AXIS_TITLE);var _=new N;_.addClass_61zpoe$(d_().AXIS),_.children().add_11rb$(p),this.add_26jijc$(_)},fr.prototype.handle_42da0z$=function(t,e){s(this.closure$message)},fr.$metadata$={kind:$,interfaces:[A]},cr.prototype.onMouseMove_hnimoe$_0=function(t,e){t.addEventHandler_mm8kk2$(P.MOUSE_MOVE,new fr(e))},cr.prototype.buildPlotComponents_8cuv6w$_0=function(){var t,e,n,i,r=this.myPreferredSize_8a54qv$_0.get(),o=new j(h.Companion.ZERO,r);if(yr().DEBUG_DRAWING_0){var a=L(o);a.strokeColor().set_11rb$(R.Companion.MAGENTA),a.strokeWidth().set_11rb$(1),a.fillOpacity().set_11rb$(0),this.onMouseMove_hnimoe$_0(a,"MAGENTA: preferred size: "+o),this.add_26jijc$(a)}var s=this.hasLiveMap()?$p().liveMapBounds_wthzt5$(o):o;if(this.hasTitle()){var l=$p().titleDimensions_61zpoe$(this.title);t=new j(s.origin.add_gpjtzr$(new h(0,l.y)),s.dimension.subtract_gpjtzr$(new h(0,l.y)))}else t=s;var u=t,c=null,p=this.theme_5sfato$_0.legend(),_=p.position().isFixed?(c=new np(u,p).doLayout_8sg693$(this.legendBoxInfos)).plotInnerBoundsWithoutLegendBoxes:u;if(yr().DEBUG_DRAWING_0){var f=L(_);f.strokeColor().set_11rb$(R.Companion.BLUE),f.strokeWidth().set_11rb$(1),f.fillOpacity().set_11rb$(0),this.onMouseMove_hnimoe$_0(f,"BLUE: plot without title and legends: "+_),this.add_26jijc$(f)}var d=_;if(this.isAxisEnabled){if(this.hasAxisTitleLeft()){var m=$p().axisTitleDimensions_61zpoe$(this.axisTitleLeft).y+$p().AXIS_TITLE_OUTER_MARGIN+$p().AXIS_TITLE_INNER_MARGIN;d=I(d.left+m,d.top,d.width-m,d.height)}if(this.hasAxisTitleBottom()){var y=$p().axisTitleDimensions_61zpoe$(this.axisTitleBottom).y+$p().AXIS_TITLE_OUTER_MARGIN+$p().AXIS_TITLE_INNER_MARGIN;d=I(d.left,d.top,d.width,d.height-y)}}var $=this.plotLayout().doLayout_gpjtzr$(d.dimension);if(this.myLaidOutSize_jqfjq$_0.set_11rb$(r),!$.tiles.isEmpty()){var v=$p().absoluteGeomBounds_vjhcds$(d.origin,$);p.position().isOverlay&&(c=new np(v,p).doLayout_8sg693$(this.legendBoxInfos));var g=$.tiles.size>1?this.theme_5sfato$_0.multiTile():this.theme_5sfato$_0,b=d.origin;for(e=$.tiles.iterator();e.hasNext();){var w=e.next(),C=w.trueIndex,S=this.createTile_rg9gwo$_0(b,w,this.tileLayers_za3lpa$(C),g),T=b.add_gpjtzr$(w.plotOrigin);S.moveTo_gpjtzr$(T),this.add_8icvvv$(S),null!=(n=S.liveMapFigure)&&z("add",function(t,e){return t.add_11rb$(e)}.bind(null,this.myLiveMapFigures_nd8qng$_0))(n);var O=w.geomBounds.add_gpjtzr$(T);this.myTooltipHelper_3jkkzs$_0.addTileInfo_t6qbjr$(O,S.targetLocators)}if(yr().DEBUG_DRAWING_0){var N=L(v);N.strokeColor().set_11rb$(R.Companion.RED),N.strokeWidth().set_11rb$(1),N.fillOpacity().set_11rb$(0),this.add_26jijc$(N)}if(this.hasTitle()){var P=new x(this.title);P.addClassName_61zpoe$(d_().PLOT_TITLE),P.setHorizontalAnchor_ja80zo$(k.LEFT),P.setVerticalAnchor_yaudma$(E.CENTER);var A=$p().titleDimensions_61zpoe$(this.title),D=I(v.origin.x,0,A.x,A.y);if(P.moveTo_gpjtzr$(new h(D.left,D.center.y)),this.add_8icvvv$(P),yr().DEBUG_DRAWING_0){var M=L(D);M.strokeColor().set_11rb$(R.Companion.BLUE),M.strokeWidth().set_11rb$(1),M.fillOpacity().set_11rb$(0),this.add_26jijc$(M)}}if(this.isAxisEnabled&&(this.hasAxisTitleLeft()&&this.createAxisTitle_depkt8$_0(this.axisTitleLeft,Jl(),_,v),this.hasAxisTitleBottom()&&this.createAxisTitle_depkt8$_0(this.axisTitleBottom,eu(),_,v)),null!=c)for(i=c.boxWithLocationList.iterator();i.hasNext();){var B=i.next(),U=B.legendBox.createLegendBox();U.moveTo_gpjtzr$(B.location),this.add_8icvvv$(U)}}},cr.prototype.createTooltipSpecs_gpjtzr$=function(t){return this.myTooltipHelper_3jkkzs$_0.createTooltipSpecs_gpjtzr$(t)},cr.prototype.getGeomBounds_gpjtzr$=function(t){return this.myTooltipHelper_3jkkzs$_0.getGeomBounds_gpjtzr$(t)},dr.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var mr=null;function yr(){return null===mr&&new dr,mr}function $r(t){this.myTheme_0=t,this.myLayersByTile_0=p(),this.myTitle_0=null,this.myCoordProvider_3t551e$_0=this.myCoordProvider_3t551e$_0,this.myLayout_0=null,this.myAxisTitleLeft_0=null,this.myAxisTitleBottom_0=null,this.myLegendBoxInfos_0=p(),this.myScaleXProto_s7k1di$_0=this.myScaleXProto_s7k1di$_0,this.myScaleYProto_dj5r5h$_0=this.myScaleYProto_dj5r5h$_0,this.myAxisEnabled_0=!0,this.myInteractionsEnabled_0=!0,this.hasLiveMap_0=!1}function vr(t){cr.call(this,t.myTheme_0),this.scaleXProto_rbtdab$_0=t.myScaleXProto_0,this.scaleYProto_t0wegs$_0=t.myScaleYProto_0,this.myTitle_0=t.myTitle_0,this.myAxisTitleLeft_0=t.myAxisTitleLeft_0,this.myAxisTitleBottom_0=t.myAxisTitleBottom_0,this.myAxisXTitleEnabled_0=t.myTheme_0.axisX().showTitle(),this.myAxisYTitleEnabled_0=t.myTheme_0.axisY().showTitle(),this.coordProvider_o460zb$_0=t.myCoordProvider_0,this.myLayersByTile_0=null,this.myLayout_0=null,this.myLegendBoxInfos_0=null,this.hasLiveMap_0=!1,this.isAxisEnabled_70ondl$_0=!1,this.isInteractionsEnabled_dvtvmh$_0=!1,this.myLayersByTile_0=q(t.myLayersByTile_0),this.myLayout_0=t.myLayout_0,this.myLegendBoxInfos_0=q(t.myLegendBoxInfos_0),this.hasLiveMap_0=t.hasLiveMap_0,this.isAxisEnabled_70ondl$_0=t.myAxisEnabled_0,this.isInteractionsEnabled_dvtvmh$_0=t.myInteractionsEnabled_0}function gr(t,e){var n;Er(),this.plot=t,this.preferredSize_sl52i3$_0=e,this.svg=new K,this.myContentBuilt_l8hvkk$_0=!1,this.myRegistrations_wwtuqx$_0=new V([]),this.svg.addClass_61zpoe$(d_().PLOT_CONTAINER),this.setSvgSize_2l8z8v$_0(this.preferredSize_sl52i3$_0.get()),this.plot.laidOutSize().addHandler_gxwwpc$(Er().sizePropHandler_0((n=this,function(t){var e=n.preferredSize_sl52i3$_0.get().x,i=t.x,r=X.max(e,i),o=n.preferredSize_sl52i3$_0.get().y,a=t.y,s=new h(r,X.max(o,a));return n.setSvgSize_2l8z8v$_0(s),W}))),this.preferredSize_sl52i3$_0.addHandler_gxwwpc$(Er().sizePropHandler_0(function(t){return function(e){return e.x>0&&e.y>0&&t.revalidateContent_r8qzcp$_0(),W}}(this)))}function br(){}function wr(){kr=this}function xr(t){this.closure$block=t}cr.$metadata$={kind:$,simpleName:"Plot",interfaces:[B]},Object.defineProperty($r.prototype,"myCoordProvider_0",{configurable:!0,get:function(){return null==this.myCoordProvider_3t551e$_0?F("myCoordProvider"):this.myCoordProvider_3t551e$_0},set:function(t){this.myCoordProvider_3t551e$_0=t}}),Object.defineProperty($r.prototype,"myScaleXProto_0",{configurable:!0,get:function(){return null==this.myScaleXProto_s7k1di$_0?F("myScaleXProto"):this.myScaleXProto_s7k1di$_0},set:function(t){this.myScaleXProto_s7k1di$_0=t}}),Object.defineProperty($r.prototype,"myScaleYProto_0",{configurable:!0,get:function(){return null==this.myScaleYProto_dj5r5h$_0?F("myScaleYProto"):this.myScaleYProto_dj5r5h$_0},set:function(t){this.myScaleYProto_dj5r5h$_0=t}}),$r.prototype.setTitle_pdl1vj$=function(t){this.myTitle_0=t},$r.prototype.setAxisTitleLeft_61zpoe$=function(t){this.myAxisTitleLeft_0=t},$r.prototype.setAxisTitleBottom_61zpoe$=function(t){this.myAxisTitleBottom_0=t},$r.prototype.setCoordProvider_sdecqr$=function(t){return this.myCoordProvider_0=t,this},$r.prototype.addTileLayers_relqli$=function(t){return this.myLayersByTile_0.add_11rb$(q(t)),this},$r.prototype.setPlotLayout_vjneqj$=function(t){return this.myLayout_0=t,this},$r.prototype.addLegendBoxInfo_29gouq$=function(t){return this.myLegendBoxInfos_0.add_11rb$(t),this},$r.prototype.scaleXProto_iu85h4$=function(t){return this.myScaleXProto_0=t,this},$r.prototype.scaleYProto_iu85h4$=function(t){return this.myScaleYProto_0=t,this},$r.prototype.axisEnabled_6taknv$=function(t){return this.myAxisEnabled_0=t,this},$r.prototype.interactionsEnabled_6taknv$=function(t){return this.myInteractionsEnabled_0=t,this},$r.prototype.setLiveMap_6taknv$=function(t){return this.hasLiveMap_0=t,this},$r.prototype.build=function(){return new vr(this)},Object.defineProperty(vr.prototype,"scaleXProto",{configurable:!0,get:function(){return this.scaleXProto_rbtdab$_0}}),Object.defineProperty(vr.prototype,"scaleYProto",{configurable:!0,get:function(){return this.scaleYProto_t0wegs$_0}}),Object.defineProperty(vr.prototype,"coordProvider",{configurable:!0,get:function(){return this.coordProvider_o460zb$_0}}),Object.defineProperty(vr.prototype,"isAxisEnabled",{configurable:!0,get:function(){return this.isAxisEnabled_70ondl$_0}}),Object.defineProperty(vr.prototype,"isInteractionsEnabled",{configurable:!0,get:function(){return this.isInteractionsEnabled_dvtvmh$_0}}),Object.defineProperty(vr.prototype,"title",{configurable:!0,get:function(){if(!this.hasTitle())throw G("No title".toString());return S(this.myTitle_0)}}),Object.defineProperty(vr.prototype,"axisTitleLeft",{configurable:!0,get:function(){if(!this.hasAxisTitleLeft())throw G("No left axis title".toString());return S(this.myAxisTitleLeft_0)}}),Object.defineProperty(vr.prototype,"axisTitleBottom",{configurable:!0,get:function(){if(!this.hasAxisTitleBottom())throw G("No bottom axis title".toString());return S(this.myAxisTitleBottom_0)}}),Object.defineProperty(vr.prototype,"legendBoxInfos",{configurable:!0,get:function(){return this.myLegendBoxInfos_0}}),vr.prototype.hasTitle=function(){return!w.Strings.isNullOrEmpty_pdl1vj$(this.myTitle_0)},vr.prototype.hasAxisTitleLeft=function(){return this.myAxisYTitleEnabled_0&&!w.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleLeft_0)},vr.prototype.hasAxisTitleBottom=function(){return this.myAxisXTitleEnabled_0&&!w.Strings.isNullOrEmpty_pdl1vj$(this.myAxisTitleBottom_0)},vr.prototype.hasLiveMap=function(){return this.hasLiveMap_0},vr.prototype.tileLayers_za3lpa$=function(t){return this.myLayersByTile_0.get_za3lpa$(t)},vr.prototype.plotLayout=function(){return S(this.myLayout_0)},vr.$metadata$={kind:$,simpleName:"MyPlot",interfaces:[cr]},$r.$metadata$={kind:$,simpleName:"PlotBuilder",interfaces:[]},Object.defineProperty(gr.prototype,"liveMapFigures",{configurable:!0,get:function(){return this.plot.liveMapFigures_8be2vx$}}),Object.defineProperty(gr.prototype,"isLiveMap",{configurable:!0,get:function(){return!this.plot.liveMapFigures_8be2vx$.isEmpty()}}),gr.prototype.ensureContentBuilt=function(){this.myContentBuilt_l8hvkk$_0||this.buildContent()},gr.prototype.revalidateContent_r8qzcp$_0=function(){this.myContentBuilt_l8hvkk$_0&&(this.clearContent(),this.buildContent())},br.prototype.css=function(){return d_().css},br.$metadata$={kind:$,interfaces:[H]},gr.prototype.buildContent=function(){if(this.myContentBuilt_l8hvkk$_0)throw d("Check failed.".toString());this.myContentBuilt_l8hvkk$_0=!0,this.svg.setStyle_i8z0m3$(new br);var t=new Y;t.addClass_61zpoe$(d_().PLOT_BACKDROP),t.setAttribute_jyasbz$("width","100%"),t.setAttribute_jyasbz$("height","100%"),this.svg.children().add_11rb$(t),this.plot.preferredSize_8be2vx$().set_11rb$(this.preferredSize_sl52i3$_0.get()),this.svg.children().add_11rb$(this.plot.rootGroup)},gr.prototype.clearContent=function(){this.myContentBuilt_l8hvkk$_0&&(this.myContentBuilt_l8hvkk$_0=!1,this.svg.children().clear(),this.plot.clear(),this.myRegistrations_wwtuqx$_0.remove(),this.myRegistrations_wwtuqx$_0=new V([]))},gr.prototype.reg_3xv6fb$=function(t){this.myRegistrations_wwtuqx$_0.add_3xv6fb$(t)},gr.prototype.setSvgSize_2l8z8v$_0=function(t){this.svg.width().set_11rb$(t.x),this.svg.height().set_11rb$(t.y)},xr.prototype.onEvent_11rb$=function(t){var e=t.newValue;null!=e&&this.closure$block(e)},xr.$metadata$={kind:$,interfaces:[T]},wr.prototype.sizePropHandler_0=function(t){return new xr(t)},wr.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var kr=null;function Er(){return null===kr&&new wr,kr}function Cr(t,e,n,i,r,o,a){B.call(this),this.myScaleX_0=e,this.myScaleY_0=n,this.myTilesOrigin_0=i,this.myLayoutInfo_0=r,this.myCoord_0=o,this.myTheme_0=a,this.myDebugDrawing_0=new U(!1),this.myLayers_0=null,this.myTargetLocators_0=p(),this.myShowAxis_0=!1,this.liveMapFigure_y5x745$_0=null,this.myLayers_0=q(t),this.moveTo_gpjtzr$(this.myLayoutInfo_0.getAbsoluteBounds_gpjtzr$(this.myTilesOrigin_0).origin)}function Sr(){this.myTileInfos_0=p()}function Tr(t,e){this.geomBounds_8be2vx$=t;var n,i=y(m(e,10));for(n=e.iterator();n.hasNext();){var r=n.next();i.add_11rb$(new Or(this,r))}this.myTargetLocators_0=i}function Or(t,e){this.$outer=t,Rc.call(this,e)}function Nr(){Ar=this}function Pr(t){this.closure$aes=t,this.groupCount_uijr2l$_0=it(function(t){return function(){return nt.Sets.newHashSet_yl67zr$(t.groups()).size}}(t))}gr.$metadata$={kind:$,simpleName:"PlotContainerPortable",interfaces:[]},Object.defineProperty(Cr.prototype,"liveMapFigure",{configurable:!0,get:function(){return this.liveMapFigure_y5x745$_0},set:function(t){this.liveMapFigure_y5x745$_0=t}}),Object.defineProperty(Cr.prototype,"targetLocators",{configurable:!0,get:function(){return this.myTargetLocators_0}}),Object.defineProperty(Cr.prototype,"isDebugDrawing_0",{configurable:!0,get:function(){return this.myDebugDrawing_0.get()}}),Cr.prototype.buildComponent=function(){var t,n,i,r=this.myLayoutInfo_0.geomBounds;if(this.myTheme_0.plot().showInnerFrame()){var o=L(r);o.strokeColor().set_11rb$(this.myTheme_0.plot().innerFrameColor()),o.strokeWidth().set_11rb$(1),o.fillOpacity().set_11rb$(0);var a=o;this.add_26jijc$(a)}this.addFacetLabels_0(r,this.myTheme_0.facets());var s,l=this.myLayers_0;t:do{var p;for(p=l.iterator();p.hasNext();){var h=p.next();if(h.isLiveMap){s=h;break t}}s=null}while(0);var _=s;if(null==_&&this.myShowAxis_0&&this.addAxis_0(r),this.isDebugDrawing_0){var f=this.myLayoutInfo_0.bounds,d=L(f);d.fillColor().set_11rb$(R.Companion.BLACK),d.strokeWidth().set_11rb$(0),d.fillOpacity().set_11rb$(.1),this.add_26jijc$(d)}if(this.isDebugDrawing_0){var m=this.myLayoutInfo_0.clipBounds,y=L(m);y.fillColor().set_11rb$(R.Companion.DARK_GREEN),y.strokeWidth().set_11rb$(0),y.fillOpacity().set_11rb$(.3),this.add_26jijc$(y)}if(this.isDebugDrawing_0){var $=L(r);$.fillColor().set_11rb$(R.Companion.PINK),$.strokeWidth().set_11rb$(1),$.fillOpacity().set_11rb$(.5),this.add_26jijc$($)}if(null!=_){var v=function(t,n){var i;return(e.isType(i=t.geom,tt)?i:c()).createCanvasFigure_wthzt5$(n)}(_,this.myLayoutInfo_0.getAbsoluteGeomBounds_gpjtzr$(this.myTilesOrigin_0));this.liveMapFigure=v.canvasFigure,this.myTargetLocators_0.add_11rb$(v.targetLocator)}else{var g=Z(),b=Z(),w=this.myLayoutInfo_0.xAxisInfo,x=this.myLayoutInfo_0.yAxisInfo,k=this.myScaleX_0.mapper,E=this.myScaleY_0.mapper,C=J.Companion.X;g.put_xwzc9p$(C,k);var T=J.Companion.Y;g.put_xwzc9p$(T,E);var O=J.Companion.SLOPE,N=u.Mappers.mul_14dthe$(S(E(1))/S(k(1)));g.put_xwzc9p$(O,N);var P=J.Companion.X,A=S(S(w).axisDomain);b.put_xwzc9p$(P,A);var j=J.Companion.Y,I=S(S(x).axisDomain);for(b.put_xwzc9p$(j,I),t=this.buildGeoms_0(g,b,this.myCoord_0).iterator();t.hasNext();){var z=t.next();z.moveTo_gpjtzr$(r.origin);var D=null!=(n=this.myCoord_0.xClientLimit)?n:new Q(0,r.width),M=null!=(i=this.myCoord_0.yClientLimit)?i:new Q(0,r.height),B=Xc().doubleRange_gyv40k$(D,M);z.clipBounds_wthzt5$(B),this.add_8icvvv$(z)}}},Cr.prototype.addFacetLabels_0=function(t,e){var n,i=this.myLayoutInfo_0.facetXLabels;if(!i.isEmpty()){var r=Vc().facetColLabelSize_14dthe$(t.width),o=new h(t.left+0,t.top-Vc().facetColHeadHeight_za3lpa$(i.size)+6),a=new j(o,r);for(n=i.iterator();n.hasNext();){var s=n.next(),l=L(a);l.strokeWidth().set_11rb$(0),l.fillColor().set_11rb$(e.labelBackground());var u=l;this.add_26jijc$(u);var c=a.center.x,p=a.center.y,_=new x(s);_.moveTo_lu1900$(c,p),_.setHorizontalAnchor_ja80zo$(k.MIDDLE),_.setVerticalAnchor_yaudma$(E.CENTER),this.add_8icvvv$(_),a=a.add_gpjtzr$(new h(0,r.y))}}if(null!=this.myLayoutInfo_0.facetYLabel){var f=I(t.right+6,t.top-0,Vc().FACET_TAB_HEIGHT-12,t.height-0),d=L(f);d.strokeWidth().set_11rb$(0),d.fillColor().set_11rb$(e.labelBackground()),this.add_26jijc$(d);var m=f.center.x,y=f.center.y,$=new x(this.myLayoutInfo_0.facetYLabel);$.moveTo_lu1900$(m,y),$.setHorizontalAnchor_ja80zo$(k.MIDDLE),$.setVerticalAnchor_yaudma$(E.CENTER),$.rotate_14dthe$(90),this.add_8icvvv$($)}},Cr.prototype.addAxis_0=function(t){if(this.myLayoutInfo_0.xAxisShown){var e=this.buildAxis_0(this.myScaleX_0,S(this.myLayoutInfo_0.xAxisInfo),this.myCoord_0,this.myTheme_0.axisX());e.moveTo_gpjtzr$(new h(t.left,t.bottom)),this.add_8icvvv$(e)}if(this.myLayoutInfo_0.yAxisShown){var n=this.buildAxis_0(this.myScaleY_0,S(this.myLayoutInfo_0.yAxisInfo),this.myCoord_0,this.myTheme_0.axisY());n.moveTo_gpjtzr$(t.origin),this.add_8icvvv$(n)}},Cr.prototype.buildAxis_0=function(t,e,n,i){var r=new Bs(e.axisLength,S(e.orientation));if(nr().setBreaks_6e5l22$(r,t,n,e.orientation.isHorizontal),nr().applyLayoutInfo_4pg061$(r,e),nr().applyTheme_tna4q5$(r,i),this.isDebugDrawing_0&&null!=e.tickLabelsBounds){var o=L(e.tickLabelsBounds);o.strokeColor().set_11rb$(R.Companion.GREEN),o.strokeWidth().set_11rb$(1),o.fillOpacity().set_11rb$(0),r.add_26jijc$(o)}return r},Cr.prototype.buildGeoms_0=function(t,e,n){var i,r=p();for(i=this.myLayers_0.iterator();i.hasNext();){var o=i.next(),a=ur().createLayerRendererData_knseyn$(o,t,e),s=a.aestheticMappers,l=a.aesthetics,u=new Fu(o.geomKind,o.locatorLookupSpec,o.contextualMapping,n);this.myTargetLocators_0.add_11rb$(u);var c=Hr().aesthetics_luqwb2$(l).aestheticMappers_4iu3o$(s).geomTargetCollector_xrq6q$(u).build(),h=a.pos,_=o.geom;r.add_11rb$(new Rr(l,_,h,n,c))}return r},Cr.prototype.setShowAxis_6taknv$=function(t){this.myShowAxis_0=t},Cr.prototype.debugDrawing=function(){return this.myDebugDrawing_0},Cr.$metadata$={kind:$,simpleName:"PlotTile",interfaces:[B]},Sr.prototype.removeAllTileInfos=function(){this.myTileInfos_0.clear()},Sr.prototype.addTileInfo_t6qbjr$=function(t,e){var n=new Tr(t,e);this.myTileInfos_0.add_11rb$(n)},Sr.prototype.createTooltipSpecs_gpjtzr$=function(t){var e;if(null==(e=this.findTileInfo_0(t)))return et();var n=e,i=n.findTargets_xoefl8$(t);return this.createTooltipSpecs_0(i,n.axisOrigin_8be2vx$)},Sr.prototype.getGeomBounds_gpjtzr$=function(t){var e;return null==(e=this.findTileInfo_0(t))?null:e.geomBounds_8be2vx$},Sr.prototype.findTileInfo_0=function(t){var e;for(e=this.myTileInfos_0.iterator();e.hasNext();){var n=e.next();if(n.contains_xoefl8$(t))return n}return null},Sr.prototype.createTooltipSpecs_0=function(t,e){var n,i=p();for(n=t.iterator();n.hasNext();){var r,o=n.next(),a=new Bu(o.contextualMapping,e);for(r=o.targets.iterator();r.hasNext();){var s=r.next();i.addAll_brywnq$(a.create_62opr5$(s))}}return i},Object.defineProperty(Tr.prototype,"axisOrigin_8be2vx$",{configurable:!0,get:function(){return new h(this.geomBounds_8be2vx$.left,this.geomBounds_8be2vx$.bottom)}}),Tr.prototype.findTargets_xoefl8$=function(t){var e,n=new Ju;for(e=this.myTargetLocators_0.iterator();e.hasNext();){var i=e.next().search_gpjtzr$(t);null!=i&&n.addLookupResult_9sakjw$(i,t)}return n.picked},Tr.prototype.contains_xoefl8$=function(t){return this.geomBounds_8be2vx$.contains_gpjtzr$(t)},Or.prototype.convertToTargetCoord_gpjtzr$=function(t){return t.subtract_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin)},Or.prototype.convertToPlotCoord_gpjtzr$=function(t){return t.add_gpjtzr$(this.$outer.geomBounds_8be2vx$.origin)},Or.prototype.convertToPlotDistance_14dthe$=function(t){return t},Or.$metadata$={kind:$,simpleName:"TileTargetLocator",interfaces:[Rc]},Tr.$metadata$={kind:$,simpleName:"TileInfo",interfaces:[]},Sr.$metadata$={kind:$,simpleName:"PlotTooltipHelper",interfaces:[]},Object.defineProperty(Pr.prototype,"aesthetics",{configurable:!0,get:function(){return this.closure$aes}}),Object.defineProperty(Pr.prototype,"groupCount",{configurable:!0,get:function(){return this.groupCount_uijr2l$_0.value}}),Pr.$metadata$={kind:$,interfaces:[Lr]},Nr.prototype.createLayerPos_2iooof$=function(t,e){return t.createPos_q7kk9g$(new Pr(e))},Nr.prototype.computeLayerDryRunXYRanges_gl53zg$=function(t,e){var n=Hr().aesthetics_luqwb2$(e).build(),i=this.computeLayerDryRunXYRangesAfterPosAdjustment_0(t,e,n),r=this.computeLayerDryRunXYRangesAfterSizeExpand_0(t,e,n),o=r.component1(),a=r.component2(),s=i.first;null==s?s=o:null!=o&&(s=s.span_d226ot$(o));var l=i.second;return null==l?l=a:null!=a&&(l=l.span_d226ot$(a)),new rt(s,l)},Nr.prototype.combineRanges_0=function(t,e){var n,i,r=null;for(n=t.iterator();n.hasNext();){var o=n.next(),a=e.range_vktour$(o);null!=a&&(r=null!=(i=null!=r?r.span_d226ot$(a):null)?i:a)}return r},Nr.prototype.computeLayerDryRunXYRangesAfterPosAdjustment_0=function(t,n,i){var r,o,a,s=nt.Iterables.toList_yl67zr$(J.Companion.affectingScaleX_shhb9a$(t.renderedAes())),l=nt.Iterables.toList_yl67zr$(J.Companion.affectingScaleY_shhb9a$(t.renderedAes())),u=this.createLayerPos_2iooof$(t,n);if(u.isIdentity){var c=this.combineRanges_0(s,n),p=this.combineRanges_0(l,n);return new rt(c,p)}var _=0,f=0,d=0,m=0,y=!1,$=e.imul(s.size,l.size),v=e.newArray($,null),g=e.newArray($,null);for(r=n.dataPoints().iterator();r.hasNext();){var b=r.next(),w=-1;for(o=s.iterator();o.hasNext();){var x=o.next(),k=b.numeric_vktour$(x);for(a=l.iterator();a.hasNext();){var E=a.next(),C=b.numeric_vktour$(E);v[w=w+1|0]=k,g[w]=C}}for(;w>=0;){if(null!=v[w]&&null!=g[w]){var T=v[w],O=g[w];if(ot.SeriesUtil.isFinite_yrwdxb$(T)&&ot.SeriesUtil.isFinite_yrwdxb$(O)){var N=u.translate_tshsjz$(new h(S(T),S(O)),b,i),P=N.x,A=N.y;if(y){var j=_;_=X.min(P,j);var L=f;f=X.max(P,L);var R=d;d=X.min(A,R);var I=m;m=X.max(A,I)}else _=f=P,d=m=A,y=!0}}w=w-1|0}}var z=y?new Q(_,f):null,D=y?new Q(d,m):null;return new rt(z,D)},Nr.prototype.computeLayerDryRunXYRangesAfterSizeExpand_0=function(t,e,n){var i=t.renderedAes(),r=i.contains_11rb$(J.Companion.WIDTH),o=i.contains_11rb$(J.Companion.HEIGHT),a=r?this.computeLayerDryRunRangeAfterSizeExpand_0(J.Companion.X,J.Companion.WIDTH,e,n):null,s=o?this.computeLayerDryRunRangeAfterSizeExpand_0(J.Companion.Y,J.Companion.HEIGHT,e,n):null;return new rt(a,s)},Nr.prototype.computeLayerDryRunRangeAfterSizeExpand_0=function(t,e,n,i){var r,o=n.numericValues_vktour$(t).iterator(),a=n.numericValues_vktour$(e).iterator(),s=i.getResolution_vktour$(t),l=new Float64Array([at.POSITIVE_INFINITY,at.NEGATIVE_INFINITY]);r=n.dataPointCount();for(var u=0;u=0?_=0:f=0)}var m,y,$,v=p-_,g=null!=(m=null!=u?u.apply_yrwdxb$(v):null)?m:v,b=pt(g)?t.lowerEnd:g,w=h+f,x=null!=($=null!=u?u.apply_yrwdxb$(w):null)?$:w;return y=pt(x)?t.upperEnd:x,new Q(b,y)},Nr.$metadata$={kind:l,simpleName:"PlotUtil",interfaces:[]};var Ar=null;function jr(){return null===Ar&&new Nr,Ar}function Lr(){}function Rr(t,e,n,i,r){B.call(this),this.myAesthetics_0=t,this.myGeom_0=e,this.myPos_0=n,this.myCoord_0=i,this.myGeomContext_0=r}function Ir(t,e){this.variable=t,this.aes=e}function zr(t,e,n,i){Ur(),this.legendTitle_0=t,this.transformedDomain_0=e,this.scale_0=n,this.theme_0=i,this.colorBarOptions_0=null}function Dr(t,e){this.closure$spec=t,Zc.call(this,e)}function Mr(){Br=this,this.DEBUG_DRAWING_0=Qi().LEGEND_DEBUG_DRAWING}Lr.$metadata$={kind:b,simpleName:"PosProviderContext",interfaces:[]},Rr.prototype.buildComponent=function(){this.buildLayer_0()},Rr.prototype.buildLayer_0=function(){this.myGeom_0.build_uzv8ab$(this,this.myAesthetics_0,this.myPos_0,this.myCoord_0,this.myGeomContext_0)},Rr.$metadata$={kind:$,simpleName:"SvgLayerRenderer",interfaces:[_t,B]},Ir.prototype.toString=function(){return"VarBinding{variable="+this.variable+", aes="+this.aes},Ir.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Ir)||c(),!!ft(this.variable,t.variable)&&!!ft(this.aes,t.aes))},Ir.prototype.hashCode=function(){var t=dt(this.variable);return(31*t|0)+dt(this.aes)|0},Ir.$metadata$={kind:$,simpleName:"VarBinding",interfaces:[]},Dr.prototype.createLegendBox=function(){var t=new Fs(this.closure$spec);return t.debug=Ur().DEBUG_DRAWING_0,t},Dr.$metadata$={kind:$,interfaces:[Zc]},zr.prototype.createColorBar=function(){var t=this.scale_0;t.hasBreaks()||(t=mt.ScaleBreaksUtil.withBreaks_qt1l9m$(t,this.transformedDomain_0,5));var e=t.getScaleBreaks();if(e.isEmpty)return ep().EMPTY;var n=Ur().createColorBarSpec_6r6r64$(this.legendTitle_0,this.transformedDomain_0,e,t,this.theme_0,this.colorBarOptions_0);return new Dr(n,n.size)},zr.prototype.setOptions_p8ufd2$=function(t){this.colorBarOptions_0=t},Mr.prototype.createColorBarSpec_6r6r64$=function(t,e,n,i,r,o){var a;void 0===o&&(o=null);var s=fo().legendDirection_730mk3$(r)===Rl(),l=null!=o?o.width:null,u=null!=o?o.height:null,c=el().barAbsoluteSize_kkcal5$(s,r);null!=l&&(c=new h(l,c.y)),null!=u&&(c=new h(c.x,u));var p=!s,_=s?Ws().horizontal_dwxw1i$(t,e,n,c,p):Ws().vertical_dwxw1i$(t,e,n,c,p);return new Xs(t,e,n,i,null!=(a=null!=o?o.binCount:null)?a:20,r,_,p)},Mr.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Br=null;function Ur(){return null===Br&&new Mr,Br}function Fr(){Zr.call(this),this.width=null,this.height=null,this.binCount=null}function qr(){this.myAesthetics_0=null,this.myAestheticMappers_0=null,this.myGeomTargetCollector_0=new yt}function Gr(t){this.myAesthetics=t.myAesthetics_0,this.myAestheticMappers=t.myAestheticMappers_0,this.targetCollector_2hnek9$_0=t.myGeomTargetCollector_0}function Hr(t){return t=t||Object.create(qr.prototype),qr.call(t),t}function Yr(){Xr(),this.myBindings_0=p(),this.myConstantByAes_0=new gt,this.myStat_mcjcnw$_0=this.myStat_mcjcnw$_0,this.myPosProvider_gzkpo7$_0=this.myPosProvider_gzkpo7$_0,this.myGeomProvider_h6nr63$_0=this.myGeomProvider_h6nr63$_0,this.myGroupingVarName_0=null,this.myPathIdVarName_0=null,this.myScaleProviderByAes_0=Z(),this.myDataPreprocessor_0=null,this.myLocatorLookupSpec_0=xt.Companion.NONE,this.myContextualMappingProvider_0=au().NONE,this.myIsLegendDisabled_0=!1}function Vr(t,e,n,i,r,o,a,s,l,u,c,p){var h,_;for(this.dataFrame_uc8k26$_0=t,this.myPosProvider_0=n,this.group_btwr86$_0=r,this.scaleMap_9lvzv7$_0=s,this.dataAccess_qkhg5r$_0=l,this.locatorLookupSpec_65qeye$_0=u,this.contextualMapping_1qd07s$_0=c,this.isLegendDisabled_1bnyfg$_0=p,this.geom_ipep5v$_0=e.createGeom(),this.geomKind_qyi6z5$_0=e.geomKind,this.aestheticsDefaults_4lnusm$_0=null,this.myRenderedAes_0=null,this.myConstantByAes_0=null,this.myVarBindingsByAes_0=Z(),this.myRenderedAes_0=q(i),this.aestheticsDefaults_4lnusm$_0=e.aestheticsDefaults(),this.myConstantByAes_0=new gt,h=a.keys_287e2$().iterator();h.hasNext();){var f=h.next();this.myConstantByAes_0.put_ev6mlr$(f,a.get_ex36zt$(f))}for(_=o.iterator();_.hasNext();){var d=_.next(),m=this.myVarBindingsByAes_0,y=d.aes;m.put_xwzc9p$(y,d)}}function Kr(){Wr=this}zr.$metadata$={kind:$,simpleName:"ColorBarAssembler",interfaces:[]},Fr.$metadata$={kind:$,simpleName:"ColorBarOptions",interfaces:[Zr]},qr.prototype.aesthetics_luqwb2$=function(t){return this.myAesthetics_0=t,this},qr.prototype.aestheticMappers_4iu3o$=function(t){return this.myAestheticMappers_0=t,this},qr.prototype.geomTargetCollector_xrq6q$=function(t){return this.myGeomTargetCollector_0=t,this},qr.prototype.build=function(){return new Gr(this)},Object.defineProperty(Gr.prototype,"targetCollector",{configurable:!0,get:function(){return this.targetCollector_2hnek9$_0}}),Gr.prototype.getResolution_vktour$=function(t){var e=0;return null!=this.myAesthetics&&(e=this.myAesthetics.resolution_594811$(t,0)),e<=ot.SeriesUtil.TINY&&(e=this.getUnitResolution_vktour$(t)),e},Gr.prototype.getUnitResolution_vktour$=function(t){var e,n,i;return"number"==typeof(i=(null!=(n=null!=(e=this.myAestheticMappers)?e.get_11rb$(t):null)?n:u.Mappers.IDENTITY)(1))?i:c()},Gr.prototype.withTargetCollector_xrq6q$=function(t){return Hr().aesthetics_luqwb2$(this.myAesthetics).aestheticMappers_4iu3o$(this.myAestheticMappers).geomTargetCollector_xrq6q$(t).build()},Gr.prototype.with=function(){return t=this,e=e||Object.create(qr.prototype),qr.call(e),e.myAesthetics_0=t.myAesthetics,e.myAestheticMappers_0=t.myAestheticMappers,e;var t,e},Gr.$metadata$={kind:$,simpleName:"MyGeomContext",interfaces:[no]},qr.$metadata$={kind:$,simpleName:"GeomContextBuilder",interfaces:[io]},Object.defineProperty(Yr.prototype,"myStat_0",{configurable:!0,get:function(){return null==this.myStat_mcjcnw$_0?F("myStat"):this.myStat_mcjcnw$_0},set:function(t){this.myStat_mcjcnw$_0=t}}),Object.defineProperty(Yr.prototype,"myPosProvider_0",{configurable:!0,get:function(){return null==this.myPosProvider_gzkpo7$_0?F("myPosProvider"):this.myPosProvider_gzkpo7$_0},set:function(t){this.myPosProvider_gzkpo7$_0=t}}),Object.defineProperty(Yr.prototype,"myGeomProvider_0",{configurable:!0,get:function(){return null==this.myGeomProvider_h6nr63$_0?F("myGeomProvider"):this.myGeomProvider_h6nr63$_0},set:function(t){this.myGeomProvider_h6nr63$_0=t}}),Yr.prototype.stat_qbwusa$=function(t){return this.myStat_0=t,this},Yr.prototype.pos_r08v3h$=function(t){return this.myPosProvider_0=t,this},Yr.prototype.geom_9dfz59$=function(t){return this.myGeomProvider_0=t,this},Yr.prototype.addBinding_14cn14$=function(t){return this.myBindings_0.add_11rb$(t),this},Yr.prototype.groupingVar_8xm3sj$=function(t){return this.myGroupingVarName_0=t.name,this},Yr.prototype.groupingVarName_61zpoe$=function(t){return this.myGroupingVarName_0=t,this},Yr.prototype.pathIdVarName_61zpoe$=function(t){return this.myPathIdVarName_0=t,this},Yr.prototype.addConstantAes_bbdhip$=function(t,e){return this.myConstantByAes_0.put_ev6mlr$(t,e),this},Yr.prototype.addScaleProvider_jv3qxe$=function(t,e){return this.myScaleProviderByAes_0.put_xwzc9p$(t,e),this},Yr.prototype.locatorLookupSpec_271kgc$=function(t){return this.myLocatorLookupSpec_0=t,this},Yr.prototype.contextualMappingProvider_td8fxc$=function(t){return this.myContextualMappingProvider_0=t,this},Yr.prototype.disableLegend_6taknv$=function(t){return this.myIsLegendDisabled_0=t,this},Yr.prototype.build_fhj1j$=function(t,e){var n,i,r=t;null!=this.myDataPreprocessor_0&&(r=S(this.myDataPreprocessor_0)(r,e)),r=ms().transformOriginals_si9pes$(r,this.myBindings_0,e);var o,s=this.myBindings_0,l=y(m(s,10));for(o=s.iterator();o.hasNext();){var u,c,h=o.next(),_=l.add_11rb$;c=h.aes,u=h.variable.isOrigin?new Ir(a.DataFrameUtil.transformVarFor_896ixz$(h.aes),h.aes):h,_.call(l,$t(c,u))}var f=lt(vt(l)),d=p();for(n=f.values.iterator();n.hasNext();){var $=n.next(),v=$.variable;if(v.isStat){var g=$.aes,b=e.get_31786j$(g);r=a.DataFrameUtil.applyTransform_xaiv89$(r,v,g,b),d.add_11rb$(new Ir(a.TransformVar.forAes_896ixz$(g),g))}}for(i=d.iterator();i.hasNext();){var w=i.next(),x=w.aes;f.put_xwzc9p$(x,w)}var k=new Xa(r,f,e);return new Vr(r,this.myGeomProvider_0,this.myPosProvider_0,this.myGeomProvider_0.renders(),new Es(r,this.myBindings_0,this.myGroupingVarName_0,this.myPathIdVarName_0,this.handlesGroups_0()).groupMapper,f.values,this.myConstantByAes_0,e,k,this.myLocatorLookupSpec_0,this.myContextualMappingProvider_0.createContextualMapping_8fr62e$(k,r),this.myIsLegendDisabled_0)},Yr.prototype.handlesGroups_0=function(){return this.myGeomProvider_0.handlesGroups()||this.myPosProvider_0.handlesGroups()},Object.defineProperty(Vr.prototype,"dataFrame",{get:function(){return this.dataFrame_uc8k26$_0}}),Object.defineProperty(Vr.prototype,"group",{get:function(){return this.group_btwr86$_0}}),Object.defineProperty(Vr.prototype,"scaleMap",{get:function(){return this.scaleMap_9lvzv7$_0}}),Object.defineProperty(Vr.prototype,"dataAccess",{get:function(){return this.dataAccess_qkhg5r$_0}}),Object.defineProperty(Vr.prototype,"locatorLookupSpec",{get:function(){return this.locatorLookupSpec_65qeye$_0}}),Object.defineProperty(Vr.prototype,"contextualMapping",{get:function(){return this.contextualMapping_1qd07s$_0}}),Object.defineProperty(Vr.prototype,"isLegendDisabled",{get:function(){return this.isLegendDisabled_1bnyfg$_0}}),Object.defineProperty(Vr.prototype,"geom",{configurable:!0,get:function(){return this.geom_ipep5v$_0}}),Object.defineProperty(Vr.prototype,"geomKind",{configurable:!0,get:function(){return this.geomKind_qyi6z5$_0}}),Object.defineProperty(Vr.prototype,"aestheticsDefaults",{configurable:!0,get:function(){return this.aestheticsDefaults_4lnusm$_0}}),Object.defineProperty(Vr.prototype,"legendKeyElementFactory",{configurable:!0,get:function(){return this.geom.legendKeyElementFactory}}),Object.defineProperty(Vr.prototype,"isLiveMap",{configurable:!0,get:function(){return e.isType(this.geom,tt)}}),Vr.prototype.renderedAes=function(){return this.myRenderedAes_0},Vr.prototype.createPos_q7kk9g$=function(t){return this.myPosProvider_0.createPos_q7kk9g$(t)},Vr.prototype.hasBinding_896ixz$=function(t){return this.myVarBindingsByAes_0.containsKey_11rb$(t)},Vr.prototype.getBinding_31786j$=function(t){return S(this.myVarBindingsByAes_0.get_11rb$(t))},Vr.prototype.hasConstant_896ixz$=function(t){return this.myConstantByAes_0.containsKey_ex36zt$(t)},Vr.prototype.getConstant_31786j$=function(t){if(!this.hasConstant_896ixz$(t))throw G(("Constant value is not defined for aes "+t).toString());return this.myConstantByAes_0.get_ex36zt$(t)},Vr.prototype.getDefault_31786j$=function(t){return this.aestheticsDefaults.defaultValue_31786j$(t)},Vr.prototype.rangeIncludesZero_896ixz$=function(t){return this.aestheticsDefaults.rangeIncludesZero_896ixz$(t)},Vr.prototype.setLiveMapProvider_kld0fp$=function(t){if(!e.isType(this.geom,tt))throw d("Not Livemap: "+e.getKClassFromExpression(this.geom).simpleName);this.geom.setLiveMapProvider_kld0fp$(t)},Vr.$metadata$={kind:$,simpleName:"MyGeomLayer",interfaces:[or]},Kr.prototype.demoAndTest=function(){var t,e=new Yr;return e.myDataPreprocessor_0=(t=e,function(e,n){var i=ms().transformOriginals_si9pes$(e,t.myBindings_0,n),r=t.myStat_0;if(ft(r,bt.Stats.IDENTITY))return i;var o=new wt(i),a=new Es(i,t.myBindings_0,t.myGroupingVarName_0,t.myPathIdVarName_0,!0);return ms().buildStatData_x40e2x$(i,r,t.myBindings_0,n,a,Lo().undefined(),o,et(),et(),null,z("println",(function(t){return s(t),W}))).data}),e},Kr.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Wr=null;function Xr(){return null===Wr&&new Kr,Wr}function Zr(){eo(),this.isReverse=!1}function Jr(){to=this,this.NONE=new Qr}function Qr(){Zr.call(this)}Yr.$metadata$={kind:$,simpleName:"GeomLayerBuilder",interfaces:[]},Qr.$metadata$={kind:$,interfaces:[Zr]},Jr.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var to=null;function eo(){return null===to&&new Jr,to}function no(){}function io(){}function ro(t,e,n){co(),this.legendTitle_0=t,this.guideOptionsMap_0=e,this.theme_0=n,this.legendLayers_0=p()}function oo(t,e){this.closure$spec=t,Zc.call(this,e)}function ao(t,e,n,i,r,o){var a,s;this.keyElementFactory_8be2vx$=t,this.varBindings_0=e,this.constantByAes_0=n,this.aestheticsDefaults_0=i,this.scaleMap_0=r,this.keyAesthetics_8be2vx$=null,this.keyLabels_8be2vx$=null;var l=Et();for(a=this.varBindings_0.iterator();a.hasNext();){var c=a.next().aes,p=this.scaleMap_0.get_31786j$(c);if(p.hasBreaks()||(p=mt.ScaleBreaksUtil.withBreaks_qt1l9m$(p,Ct(o,c),5)),!p.hasBreaks())throw d(("No breaks were defined for scale "+c).toString());var h=p.getScaleBreaks(),_=u.ScaleUtil.map_9ksyxk$(h.transformedValues,p),f=h.labels;for(s=St(f,_).iterator();s.hasNext();){var m,y=s.next(),$=y.component1(),v=y.component2(),g=l.get_11rb$($);if(null==g){var b=Z();l.put_xwzc9p$($,b),m=b}else m=g;var w=m,x=S(v);w.put_xwzc9p$(c,x)}}this.keyAesthetics_8be2vx$=fo().mapToAesthetics_8kbmqf$(l.values,this.constantByAes_0,this.aestheticsDefaults_0),this.keyLabels_8be2vx$=q(l.keys)}function so(){uo=this,this.DEBUG_DRAWING_0=Qi().LEGEND_DEBUG_DRAWING}function lo(t){var e=t.x/2,n=2*X.floor(e)+1+1,i=t.y/2;return new h(n,2*X.floor(i)+1+1)}Zr.$metadata$={kind:$,simpleName:"GuideOptions",interfaces:[]},io.$metadata$={kind:b,simpleName:"Builder",interfaces:[]},no.$metadata$={kind:b,simpleName:"ImmutableGeomContext",interfaces:[kt]},ro.prototype.addLayer_446ka8$=function(t,e,n,i,r,o){this.legendLayers_0.add_11rb$(new ao(t,e,n,i,r,o))},oo.prototype.createLegendBox=function(){var t=new gl(this.closure$spec);return t.debug=co().DEBUG_DRAWING_0,t},oo.$metadata$={kind:$,interfaces:[Zc]},ro.prototype.createLegend=function(){var t,n,i,r,o,a,s=Et();for(t=this.legendLayers_0.iterator();t.hasNext();){var l=t.next(),u=l.keyElementFactory_8be2vx$,h=l.keyAesthetics_8be2vx$.dataPoints().iterator();for(n=l.keyLabels_8be2vx$.iterator();n.hasNext();){var _,f=n.next(),d=s.get_11rb$(f);if(null==d){var m=new dl(f);s.put_xwzc9p$(f,m),_=m}else _=d;_.addLayer_w0u015$(h.next(),u)}}var y=p();for(i=s.values.iterator();i.hasNext();){var $=i.next();$.isEmpty||y.add_11rb$($)}if(y.isEmpty())return ep().EMPTY;var v=p();for(r=this.legendLayers_0.iterator();r.hasNext();)for(o=r.next().aesList_8be2vx$.iterator();o.hasNext();){var g=o.next();e.isType(this.guideOptionsMap_0.get_11rb$(g),mo)&&v.add_11rb$(e.isType(a=this.guideOptionsMap_0.get_11rb$(g),mo)?a:c())}var b=co().createLegendSpec_esqxbx$(this.legendTitle_0,y,this.theme_0,vo().combine_pmdc6s$(v));return new oo(b,b.size)},Object.defineProperty(ao.prototype,"aesList_8be2vx$",{configurable:!0,get:function(){var t,e=this.varBindings_0,n=y(m(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(i.aes)}return n}}),ao.$metadata$={kind:$,simpleName:"LegendLayer",interfaces:[]},so.prototype.createLegendSpec_esqxbx$=function(t,e,n,i){var r,o,a;void 0===i&&(i=new mo);var s=fo().legendDirection_730mk3$(n),l=lo,u=new h(n.keySize(),n.keySize());for(r=e.iterator();r.hasNext();){var c=r.next().minimumKeySize;u=u.max_gpjtzr$(l(c))}var p,_,f,d=e.size;if(i.isByRow){if(i.hasColCount()){var m=i.colCount;o=X.min(m,d)}else if(i.hasRowCount()){var y=d/i.rowCount;o=Tt(X.ceil(y))}else o=s===Rl()?d:1;var $=d/(p=o);_=Tt(X.ceil($))}else{if(i.hasRowCount()){var v=i.rowCount;a=X.min(v,d)}else if(i.hasColCount()){var g=d/i.colCount;a=Tt(X.ceil(g))}else a=s!==Rl()?d:1;var b=d/(_=a);p=Tt(X.ceil(b))}return(f=s===Rl()?i.hasRowCount()||i.hasColCount()&&i.colCount1)for(i=this.createNameLevelTuples_5cxrh4$(t.subList_vux9f0$(1,t.size),e.subList_vux9f0$(1,e.size)).iterator();i.hasNext();){var l=i.next();a.add_11rb$(Dt(zt($t(r,s)),l))}else a.add_11rb$(zt($t(r,s)))}return a},Po.prototype.reorderLevels_dyo1lv$=function(t,e,n){for(var i=vt(St(t,n)),r=p(),o=0,a=t.iterator();a.hasNext();++o){var s=a.next();if(o>=e.size)break;r.add_11rb$(this.reorderVarLevels_pbdvt$(s,e.get_za3lpa$(o),Ct(i,s)))}return r},Po.prototype.reorderVarLevels_pbdvt$=function(t,n,i){return null==t?n:(e.isType(n,Mt)||c(),i<0?Bt(n):Ut(n))},Po.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var jo=null;function Lo(){return null===jo&&new Po,jo}function Ro(t,e,n,i,r,o,a){this.col=t,this.row=e,this.colLabs=n,this.rowLab=i,this.xAxis=r,this.yAxis=o,this.trueIndex=a}function Io(){zo=this}Ro.prototype.toString=function(){return"FacetTileInfo(col="+this.col+", row="+this.row+", colLabs="+this.colLabs+", rowLab="+f(this.rowLab)+")"},Ro.$metadata$={kind:$,simpleName:"FacetTileInfo",interfaces:[]},No.$metadata$={kind:$,simpleName:"PlotFacets",interfaces:[]},Io.prototype.mappedRenderedAesToCreateGuides_rf697z$=function(t,e){var n;if(t.isLegendDisabled)return et();var i=p();for(n=t.renderedAes().iterator();n.hasNext();){var r=n.next();J.Companion.noGuideNeeded_896ixz$(r)||t.hasConstant_896ixz$(r)||t.hasBinding_896ixz$(r)&&(e.containsKey_11rb$(r)&&e.get_11rb$(r)===eo().NONE||i.add_11rb$(r))}return i},Io.prototype.guideTransformedDomainByAes_rf697z$=function(t,e){var n,i=Z();for(n=this.mappedRenderedAesToCreateGuides_rf697z$(t,e).iterator();n.hasNext();){var r=n.next(),o=t.getBinding_896ixz$(r).variable;if(!o.isTransform)throw d("Check failed.".toString());var a=t.getDataRange_8xm3sj$(o),s=t.getScale_896ixz$(r);if(s.isContinuousDomain){var l=this.refineTransformedDataRangeForContinuousDomain_0(a,s);i.put_xwzc9p$(r,l)}else null!=a&&i.put_xwzc9p$(r,a)}return i},Io.prototype.refineTransformedDataRangeForContinuousDomain_0=function(t,n){var i,r,o=null==t?new Ft(at.NaN,at.NaN):new Ft(t.lowerEnd,t.upperEnd),a=o.component1(),s=o.component2(),l=!0===n.hasDomainLimits()?u.ScaleUtil.transformedDefinedLimits_x4zrm4$(n):new Ft(at.NaN,at.NaN),p=l.component1(),h=l.component2(),f=_(p)?p:a,d=_(h)?h:s,m=_(f)&&_(d)?new Q(f,d):_(f)?new Q(f,f):_(d)?new Q(d,d):null;return r=e.isType(i=n.transform,ct)?i:c(),qt.Transforms.ensureApplicableDomain_wa8y5m$(m,r)},Io.prototype.createColorBarAssembler_mzqjql$=function(t,e,n,i,r,o){var a=n.get_11rb$(e);if(null==a)throw d("Domain for continuous data must not be null".toString());var s=new zr(t,a,i,o);return s.setOptions_p8ufd2$(r),s},Io.prototype.fitsColorBar_k9b7d3$=function(t,e){return t.isColor&&e.isContinuous},Io.prototype.checkFitsColorBar_k9b7d3$=function(t,e){if(!t.isColor)throw d(("Color-bar is not applicable to "+t+" aesthetic").toString());if(!e.isContinuous)throw d("Color-bar is only applicable when both domain and color palette are continuous".toString())},Io.$metadata$={kind:l,simpleName:"PlotGuidesAssemblerUtil",interfaces:[]};var zo=null;function Do(){return null===zo&&new Io,zo}function Mo(){Wo()}function Bo(){Ko=this}function Uo(t){this.closure$pos=t,Mo.call(this)}function Fo(){Mo.call(this)}function qo(t){this.closure$width=t,Mo.call(this)}function Go(){Mo.call(this)}function Ho(t,e){this.closure$width=t,this.closure$height=e,Mo.call(this)}function Yo(t,e){this.closure$width=t,this.closure$height=e,Mo.call(this)}function Vo(t,e,n){this.closure$width=t,this.closure$jitterWidth=e,this.closure$jitterHeight=n,Mo.call(this)}Uo.prototype.createPos_q7kk9g$=function(t){return this.closure$pos},Uo.prototype.handlesGroups=function(){return this.closure$pos.handlesGroups()},Uo.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.wrap_dkjclg$=function(t){return new Uo(t)},Fo.prototype.createPos_q7kk9g$=function(t){return Gt.PositionAdjustments.stack_4vnpmn$(t.aesthetics,Ht.SPLIT_POSITIVE_NEGATIVE)},Fo.prototype.handlesGroups=function(){return Yt.STACK.handlesGroups()},Fo.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.barStack=function(){return new Fo},qo.prototype.createPos_q7kk9g$=function(t){var e=t.aesthetics,n=t.groupCount;return Gt.PositionAdjustments.dodge_vvhcz8$(e,n,this.closure$width)},qo.prototype.handlesGroups=function(){return Yt.DODGE.handlesGroups()},qo.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.dodge_yrwdxb$=function(t){return void 0===t&&(t=null),new qo(t)},Go.prototype.createPos_q7kk9g$=function(t){return Gt.PositionAdjustments.fill_m7huy5$(t.aesthetics)},Go.prototype.handlesGroups=function(){return Yt.FILL.handlesGroups()},Go.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.fill=function(){return new Go},Ho.prototype.createPos_q7kk9g$=function(t){return Gt.PositionAdjustments.jitter_jma9l8$(this.closure$width,this.closure$height)},Ho.prototype.handlesGroups=function(){return Yt.JITTER.handlesGroups()},Ho.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.jitter_jma9l8$=function(t,e){return new Ho(t,e)},Yo.prototype.createPos_q7kk9g$=function(t){return Gt.PositionAdjustments.nudge_jma9l8$(this.closure$width,this.closure$height)},Yo.prototype.handlesGroups=function(){return Yt.NUDGE.handlesGroups()},Yo.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.nudge_jma9l8$=function(t,e){return new Yo(t,e)},Vo.prototype.createPos_q7kk9g$=function(t){var e=t.aesthetics,n=t.groupCount;return Gt.PositionAdjustments.jitterDodge_e2pc44$(e,n,this.closure$width,this.closure$jitterWidth,this.closure$jitterHeight)},Vo.prototype.handlesGroups=function(){return Yt.JITTER_DODGE.handlesGroups()},Vo.$metadata$={kind:$,interfaces:[Mo]},Bo.prototype.jitterDodge_xjrefz$=function(t,e,n){return new Vo(t,e,n)},Bo.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Ko=null;function Wo(){return null===Ko&&new Bo,Ko}function Xo(t){this.myLayers_0=null,this.myLayers_0=q(t)}function Zo(t){ta(),this.myMap_0=Vt(t)}function Jo(){Qo=this,this.LOG_0=D.PortableLogging.logger_xo1ogr$(M(Zo))}Mo.$metadata$={kind:$,simpleName:"PosProvider",interfaces:[]},Object.defineProperty(Xo.prototype,"legendKeyElementFactory",{configurable:!0,get:function(){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).legendKeyElementFactory}}),Object.defineProperty(Xo.prototype,"aestheticsDefaults",{configurable:!0,get:function(){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).aestheticsDefaults}}),Object.defineProperty(Xo.prototype,"isLegendDisabled",{configurable:!0,get:function(){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).isLegendDisabled}}),Xo.prototype.renderedAes=function(){return this.myLayers_0.isEmpty()?et():this.myLayers_0.get_za3lpa$(0).renderedAes()},Xo.prototype.hasBinding_896ixz$=function(t){return!this.myLayers_0.isEmpty()&&this.myLayers_0.get_za3lpa$(0).hasBinding_896ixz$(t)},Xo.prototype.hasConstant_896ixz$=function(t){return!this.myLayers_0.isEmpty()&&this.myLayers_0.get_za3lpa$(0).hasConstant_896ixz$(t)},Xo.prototype.getConstant_31786j$=function(t){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).getConstant_31786j$(t)},Xo.prototype.getBinding_896ixz$=function(t){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).getBinding_31786j$(t)},Xo.prototype.getScale_896ixz$=function(t){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).scaleMap.get_31786j$(t)},Xo.prototype.getScaleMap=function(){if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());return this.myLayers_0.get_za3lpa$(0).scaleMap},Xo.prototype.getDataRange_8xm3sj$=function(t){var e;if(!this.isNumericData_0(t))throw d(("Not numeric data ["+t+"]").toString());var n=null;for(e=this.myLayers_0.iterator();e.hasNext();){var i=e.next().dataFrame.range_8xm3sj$(t);n=ot.SeriesUtil.span_t7esj2$(n,i)}return n},Xo.prototype.isNumericData_0=function(t){var e;if(this.myLayers_0.isEmpty())throw d("Check failed.".toString());for(e=this.myLayers_0.iterator();e.hasNext();)if(!e.next().dataFrame.isNumeric_8xm3sj$(t))return!1;return!0},Xo.$metadata$={kind:$,simpleName:"StitchedPlotLayers",interfaces:[]},Zo.prototype.get_31786j$=function(t){var n,i,r;if(null==(i=e.isType(n=this.myMap_0.get_11rb$(t),g)?n:null)){var o="No scale found for aes: "+t;throw ta().LOG_0.error_l35kib$(d(o),(r=o,function(){return r})),d(o.toString())}return i},Zo.prototype.containsKey_896ixz$=function(t){return this.myMap_0.containsKey_11rb$(t)},Zo.prototype.keySet=function(){return this.myMap_0.keys},Jo.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Qo=null;function ta(){return null===Qo&&new Jo,Qo}function ea(t,n,i,r,o,a,s,l){void 0===s&&(s=Lo().DEF_FORMATTER),void 0===l&&(l=Lo().DEF_FORMATTER),No.call(this),this.xVar_0=t,this.yVar_0=n,this.xFormatter_0=s,this.yFormatter_0=l,this.isDefined_f95yff$_0=null!=this.xVar_0||null!=this.yVar_0,this.xLevels_0=Lo().reorderVarLevels_pbdvt$(this.xVar_0,i,o),this.yLevels_0=Lo().reorderVarLevels_pbdvt$(this.yVar_0,r,a);var u=i.size;this.colCount_bhcvpt$_0=X.max(1,u);var c=r.size;this.rowCount_8ohw8b$_0=X.max(1,c),this.numTiles_kasr4x$_0=e.imul(this.colCount,this.rowCount)}Zo.$metadata$={kind:$,simpleName:"TypedScaleMap",interfaces:[]},Object.defineProperty(ea.prototype,"isDefined",{configurable:!0,get:function(){return this.isDefined_f95yff$_0}}),Object.defineProperty(ea.prototype,"colCount",{configurable:!0,get:function(){return this.colCount_bhcvpt$_0}}),Object.defineProperty(ea.prototype,"rowCount",{configurable:!0,get:function(){return this.rowCount_8ohw8b$_0}}),Object.defineProperty(ea.prototype,"numTiles",{configurable:!0,get:function(){return this.numTiles_kasr4x$_0}}),Object.defineProperty(ea.prototype,"variables",{configurable:!0,get:function(){return Kt([this.xVar_0,this.yVar_0])}}),ea.prototype.dataByTile_dhhkv7$=function(t){var e,n,i,r;if(!this.isDefined)throw G("dataByTile() called on Undefined plot facets.".toString());e=Kt([this.xVar_0,this.yVar_0]),n=Kt([null!=this.xVar_0?this.xLevels_0:null,null!=this.yVar_0?this.yLevels_0:null]);var o=Lo().dataByLevelTuple_w4sfrb$(t,e,n),a=vt(o),s=this.xLevels_0,l=s.isEmpty()?zt(null):s,u=this.yLevels_0,c=u.isEmpty()?zt(null):u,h=p();for(i=c.iterator();i.hasNext();){var _=i.next();for(r=l.iterator();r.hasNext();){var f=r.next(),d=Kt([f,_]),m=Ct(a,d);h.add_11rb$(m)}}return h},ea.prototype.tileInfos=function(){var t,e,n,i,r,o=this.xLevels_0,a=o.isEmpty()?zt(null):o,s=y(m(a,10));for(r=a.iterator();r.hasNext();){var l=r.next();s.add_11rb$(null!=l?this.xFormatter_0(l):null)}var u,c=s,h=this.yLevels_0,_=h.isEmpty()?zt(null):h,f=y(m(_,10));for(u=_.iterator();u.hasNext();){var d=u.next();f.add_11rb$(null!=d?this.yFormatter_0(d):null)}var $=f,v=p();t=this.rowCount;for(var g=0;g=e.numTiles}}(function(t){return function(n,i){var r;switch(t.direction_0.name){case"H":r=e.imul(i,t.colCount)+n|0;break;case"V":r=e.imul(n,t.rowCount)+i|0;break;default:r=e.noWhenBranchMatched()}return r}}(this),this),E=p(),C=0,S=b.iterator();S.hasNext();++C){var T=S.next(),O=w(C),N=x(C),P=k(O,N),A=0===O;E.add_11rb$(new Ro(O,N,T,null,P,A,C))}return Wt(E,new te(oa(new te(ra(sa)),la)))},ua.$metadata$={kind:$,simpleName:"Direction",interfaces:[Xt]},ua.values=function(){return[pa(),ha()]},ua.valueOf_61zpoe$=function(t){switch(t){case"H":return pa();case"V":return ha();default:Zt("No enum constant jetbrains.datalore.plot.builder.assemble.facet.FacetWrap.Direction."+t)}},_a.prototype.numTiles_0=function(t,e){if(t.isEmpty())throw G("List of facets is empty.".toString());if(It(t).size!==t.size)throw G(("Duplicated values in the facets list: "+t).toString());if(t.size!==e.size)throw d("Check failed.".toString());return Lo().createNameLevelTuples_5cxrh4$(t,e).size},_a.prototype.shape_0=function(t,n,i,r){var o,a,s,l,u,c;if(null!=(o=null!=n?n>0:null)&&!o){var p=(u=n,function(){return"'ncol' must be positive, was "+f(u)})();throw G(p.toString())}if(null!=(a=null!=i?i>0:null)&&!a){var h=(c=i,function(){return"'nrow' must be positive, was "+f(c)})();throw G(h.toString())}if(null!=n){var _=X.min(n,t),d=t/_,m=Tt(X.ceil(d));s=$t(_,X.max(1,m))}else if(null!=i){var y=X.min(i,t),$=t/y,v=Tt(X.ceil($));s=$t(v,X.max(1,y))}else{var g=t/2|0,b=X.max(1,g),w=X.min(4,b),x=t/w,k=Tt(X.ceil(x)),E=X.max(1,k);s=$t(w,E)}var C=s,S=C.component1(),T=C.component2();switch(r.name){case"H":var O=t/S;l=new Ft(S,Tt(X.ceil(O)));break;case"V":var N=t/T;l=new Ft(Tt(X.ceil(N)),T);break;default:l=e.noWhenBranchMatched()}return l},_a.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var fa=null;function da(){return null===fa&&new _a,fa}function ma(){ya=this,this.SEED_0=ee,this.SAFETY_SAMPLING=w_().random_280ow0$(2e5,this.SEED_0),this.POINT=w_().random_280ow0$(5e4,this.SEED_0),this.TILE=w_().random_280ow0$(5e4,this.SEED_0),this.BIN_2D=this.TILE,this.AB_LINE=w_().random_280ow0$(5e3,this.SEED_0),this.H_LINE=w_().random_280ow0$(5e3,this.SEED_0),this.V_LINE=w_().random_280ow0$(5e3,this.SEED_0),this.JITTER=w_().random_280ow0$(5e3,this.SEED_0),this.RECT=w_().random_280ow0$(5e3,this.SEED_0),this.SEGMENT=w_().random_280ow0$(5e3,this.SEED_0),this.TEXT=w_().random_280ow0$(500,this.SEED_0),this.ERROR_BAR=w_().random_280ow0$(500,this.SEED_0),this.CROSS_BAR=w_().random_280ow0$(500,this.SEED_0),this.LINE_RANGE=w_().random_280ow0$(500,this.SEED_0),this.POINT_RANGE=w_().random_280ow0$(500,this.SEED_0),this.BAR=w_().pick_za3lpa$(50),this.HISTOGRAM=w_().systematic_za3lpa$(500),this.LINE=w_().systematic_za3lpa$(5e3),this.RIBBON=w_().systematic_za3lpa$(5e3),this.AREA=w_().systematic_za3lpa$(5e3),this.DENSITY=w_().systematic_za3lpa$(5e3),this.FREQPOLY=w_().systematic_za3lpa$(5e3),this.STEP=w_().systematic_za3lpa$(5e3),this.PATH=w_().vertexDp_za3lpa$(2e4),this.POLYGON=w_().vertexDp_za3lpa$(2e4),this.MAP=w_().vertexDp_za3lpa$(2e4),this.SMOOTH=w_().systematicGroup_za3lpa$(200),this.CONTOUR=w_().systematicGroup_za3lpa$(200),this.CONTOURF=w_().systematicGroup_za3lpa$(200),this.DENSITY2D=w_().systematicGroup_za3lpa$(200),this.DENSITY2DF=w_().systematicGroup_za3lpa$(200)}aa.$metadata$={kind:$,simpleName:"FacetWrap",interfaces:[No]},ma.$metadata$={kind:l,simpleName:"DefaultSampling",interfaces:[]};var ya=null;function $a(t){Wa(),this.geomKind=t}function va(t,e,n,i){this.myKind_0=t,this.myAestheticsDefaults_0=e,this.myHandlesGroups_0=n,this.myGeomSupplier_0=i}function ga(t,e){this.this$GeomProviderBuilder=t,$a.call(this,e)}function ba(){Ka=this}function wa(){return new ie}function xa(){return new ae}function ka(){return new se}function Ea(){return new le}function Ca(){return new ue}function Sa(){return new ce}function Ta(){return new pe}function Oa(){return new he}function Na(){return new _e}function Pa(){return new de}function Aa(){return new ye}function ja(){return new $e}function La(){return new ve}function Ra(){return new ge}function Ia(){return new be}function za(){return new we}function Da(){return new xe}function Ma(){return new Ee}function Ba(){return new Ce}function Ua(){return new Se}function Fa(){return new Te}function qa(){return new Oe}function Ga(){return new Ne}function Ha(){return new Pe}function Ya(){return new je}function Va(){return new Ie}Object.defineProperty($a.prototype,"preferredCoordinateSystem",{configurable:!0,get:function(){throw d("No preferred coordinate system")}}),$a.prototype.renders=function(){return ne.GeomMeta.renders_7dhqpi$(this.geomKind)},ga.prototype.createGeom=function(){return this.this$GeomProviderBuilder.myGeomSupplier_0()},ga.prototype.aestheticsDefaults=function(){return this.this$GeomProviderBuilder.myAestheticsDefaults_0},ga.prototype.handlesGroups=function(){return this.this$GeomProviderBuilder.myHandlesGroups_0},ga.$metadata$={kind:$,interfaces:[$a]},va.prototype.build_8be2vx$=function(){return new ga(this,this.myKind_0)},va.$metadata$={kind:$,simpleName:"GeomProviderBuilder",interfaces:[]},ba.prototype.point=function(){return this.point_8j1y0m$(wa)},ba.prototype.point_8j1y0m$=function(t){return new va(re.POINT,oe.Companion.point(),ie.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.path=function(){return this.path_8j1y0m$(xa)},ba.prototype.path_8j1y0m$=function(t){return new va(re.PATH,oe.Companion.path(),ae.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.line=function(){return new va(re.LINE,oe.Companion.line(),se.Companion.HANDLES_GROUPS,ka).build_8be2vx$()},ba.prototype.smooth=function(){return new va(re.SMOOTH,oe.Companion.smooth(),le.Companion.HANDLES_GROUPS,Ea).build_8be2vx$()},ba.prototype.bar=function(){return new va(re.BAR,oe.Companion.bar(),ue.Companion.HANDLES_GROUPS,Ca).build_8be2vx$()},ba.prototype.histogram=function(){return new va(re.HISTOGRAM,oe.Companion.histogram(),ce.Companion.HANDLES_GROUPS,Sa).build_8be2vx$()},ba.prototype.tile=function(){return new va(re.TILE,oe.Companion.tile(),pe.Companion.HANDLES_GROUPS,Ta).build_8be2vx$()},ba.prototype.bin2d=function(){return new va(re.BIN_2D,oe.Companion.bin2d(),he.Companion.HANDLES_GROUPS,Oa).build_8be2vx$()},ba.prototype.errorBar=function(){return new va(re.ERROR_BAR,oe.Companion.errorBar(),_e.Companion.HANDLES_GROUPS,Na).build_8be2vx$()},ba.prototype.crossBar_8j1y0m$=function(t){return new va(re.CROSS_BAR,oe.Companion.crossBar(),fe.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.lineRange=function(){return new va(re.LINE_RANGE,oe.Companion.lineRange(),de.Companion.HANDLES_GROUPS,Pa).build_8be2vx$()},ba.prototype.pointRange_8j1y0m$=function(t){return new va(re.POINT_RANGE,oe.Companion.pointRange(),me.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.contour=function(){return new va(re.CONTOUR,oe.Companion.contour(),ye.Companion.HANDLES_GROUPS,Aa).build_8be2vx$()},ba.prototype.contourf=function(){return new va(re.CONTOURF,oe.Companion.contourf(),$e.Companion.HANDLES_GROUPS,ja).build_8be2vx$()},ba.prototype.polygon=function(){return new va(re.POLYGON,oe.Companion.polygon(),ve.Companion.HANDLES_GROUPS,La).build_8be2vx$()},ba.prototype.map=function(){return new va(re.MAP,oe.Companion.map(),ge.Companion.HANDLES_GROUPS,Ra).build_8be2vx$()},ba.prototype.abline=function(){return new va(re.AB_LINE,oe.Companion.abline(),be.Companion.HANDLES_GROUPS,Ia).build_8be2vx$()},ba.prototype.hline=function(){return new va(re.H_LINE,oe.Companion.hline(),we.Companion.HANDLES_GROUPS,za).build_8be2vx$()},ba.prototype.vline=function(){return new va(re.V_LINE,oe.Companion.vline(),xe.Companion.HANDLES_GROUPS,Da).build_8be2vx$()},ba.prototype.boxplot_8j1y0m$=function(t){return new va(re.BOX_PLOT,oe.Companion.boxplot(),ke.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.livemap_d2y5pu$=function(t){return new va(re.LIVE_MAP,oe.Companion.livemap_cx3y7u$(t.displayMode),tt.Companion.HANDLES_GROUPS,(e=t,function(){return new tt(e.displayMode)})).build_8be2vx$();var e},ba.prototype.ribbon=function(){return new va(re.RIBBON,oe.Companion.ribbon(),Ee.Companion.HANDLES_GROUPS,Ma).build_8be2vx$()},ba.prototype.area=function(){return new va(re.AREA,oe.Companion.area(),Ce.Companion.HANDLES_GROUPS,Ba).build_8be2vx$()},ba.prototype.density=function(){return new va(re.DENSITY,oe.Companion.density(),Se.Companion.HANDLES_GROUPS,Ua).build_8be2vx$()},ba.prototype.density2d=function(){return new va(re.DENSITY2D,oe.Companion.density2d(),Te.Companion.HANDLES_GROUPS,Fa).build_8be2vx$()},ba.prototype.density2df=function(){return new va(re.DENSITY2DF,oe.Companion.density2df(),Oe.Companion.HANDLES_GROUPS,qa).build_8be2vx$()},ba.prototype.jitter=function(){return new va(re.JITTER,oe.Companion.jitter(),Ne.Companion.HANDLES_GROUPS,Ga).build_8be2vx$()},ba.prototype.freqpoly=function(){return new va(re.FREQPOLY,oe.Companion.freqpoly(),Pe.Companion.HANDLES_GROUPS,Ha).build_8be2vx$()},ba.prototype.step_8j1y0m$=function(t){return new va(re.STEP,oe.Companion.step(),Ae.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.rect=function(){return new va(re.RECT,oe.Companion.rect(),je.Companion.HANDLES_GROUPS,Ya).build_8be2vx$()},ba.prototype.segment_8j1y0m$=function(t){return new va(re.SEGMENT,oe.Companion.segment(),Le.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.text_8j1y0m$=function(t){return new va(re.TEXT,oe.Companion.text(),Re.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.prototype.raster=function(){return new va(re.RASTER,oe.Companion.raster(),Ie.Companion.HANDLES_GROUPS,Va).build_8be2vx$()},ba.prototype.image_8j1y0m$=function(t){return new va(re.IMAGE,oe.Companion.image(),ze.Companion.HANDLES_GROUPS,t).build_8be2vx$()},ba.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Ka=null;function Wa(){return null===Ka&&new ba,Ka}function Xa(t,e,n){var i;this.data_0=t,this.mappedAes_tolgcu$_0=Lt(e.keys),this.scaleByAes_c9kkhw$_0=(i=n,function(t){return i.get_31786j$(t)}),this.myBindings_0=Vt(e),this.myFormatters_0=Z()}function Za(t,e){Qa.call(this,t,e)}function Ja(){}function Qa(t,e){ns(),this.xLim_0=t,this.yLim_0=e}function ts(){es=this}$a.$metadata$={kind:$,simpleName:"GeomProvider",interfaces:[]},Object.defineProperty(Xa.prototype,"mappedAes",{configurable:!0,get:function(){return this.mappedAes_tolgcu$_0}}),Object.defineProperty(Xa.prototype,"scaleByAes",{configurable:!0,get:function(){return this.scaleByAes_c9kkhw$_0}}),Xa.prototype.isMapped_896ixz$=function(t){return this.myBindings_0.containsKey_11rb$(t)},Xa.prototype.getMappedData_pkitv1$=function(t,e){var n=this.getOriginalValue_pkitv1$(t,e),i=this.getScale_0(t),r=this.formatter_0(t)(n);return new Me(i.name,r,i.isContinuous)},Xa.prototype.getOriginalValue_pkitv1$=function(t,e){if(!this.isMapped_896ixz$(t))throw G(("Not mapped: "+t).toString());var n=Ct(this.myBindings_0,t),i=this.getScale_0(t),r=this.data_0.getNumeric_8xm3sj$(n.variable).get_za3lpa$(e);return i.transform.applyInverse_yrwdxb$(r)},Xa.prototype.getMappedDataLabel_896ixz$=function(t){return this.getScale_0(t).name},Xa.prototype.isMappedDataContinuous_896ixz$=function(t){return this.getScale_0(t).isContinuous},Xa.prototype.getScale_0=function(t){return this.scaleByAes(t)},Xa.prototype.formatter_0=function(t){var e,n=this.getScale_0(t),i=this.myFormatters_0,r=i.get_11rb$(t);if(null==r){var o=this.createFormatter_0(t,n);i.put_xwzc9p$(t,o),e=o}else e=r;return e},Xa.prototype.createFormatter_0=function(t,e){if(e.isContinuousDomain){var n=Ct(this.myBindings_0,t).variable,i=z("range",function(t,e){return t.range_8xm3sj$(e)}.bind(null,this.data_0))(n),r=ot.SeriesUtil.ensureApplicableRange_4am1sd$(i);return o=e.getBreaksGenerator().labelFormatter_1tlvto$(r,100),function(t){var e;return null!=(e=null!=t?o(t):null)?e:"n/a"}}var o,a;return a=u.ScaleUtil.labelByBreak_x4zrm4$(e),function(t){var e;return null!=(e=null!=t?Ct(a,t):null)?e:"n/a"}},Xa.$metadata$={kind:$,simpleName:"PointDataAccess",interfaces:[De]},Za.$metadata$={kind:$,simpleName:"CartesianCoordProvider",interfaces:[Qa]},Ja.$metadata$={kind:b,simpleName:"CoordProvider",interfaces:[]},Qa.prototype.buildAxisScaleX_ny58zc$=function(t,e,n,i){return ns().buildAxisScaleDefault_0(t,e,n,i)},Qa.prototype.buildAxisScaleY_ny58zc$=function(t,e,n,i){return ns().buildAxisScaleDefault_0(t,e,n,i)},Qa.prototype.createCoordinateSystem_uncllg$=function(t,e,n,i){var r,o,a=ns().linearMapper_mdyssk$(t,e),s=ns().linearMapper_mdyssk$(n,i);return Be.Coords.create_wd6eaa$(u.MapperUtil.map_rejkqi$(t,a),u.MapperUtil.map_rejkqi$(n,s),null!=(r=this.xLim_0)?u.MapperUtil.map_rejkqi$(r,a):null,null!=(o=this.yLim_0)?u.MapperUtil.map_rejkqi$(o,s):null)},Qa.prototype.adjustDomains_jz8wgn$=function(t,e,n){var i,r;return new rt(null!=(i=this.xLim_0)?i:t,null!=(r=this.yLim_0)?r:e)},ts.prototype.linearMapper_mdyssk$=function(t,e){return u.Mappers.mul_mdyssk$(t,e)},ts.prototype.buildAxisScaleDefault_0=function(t,e,n,i){return this.buildAxisScaleDefault_82iy2c$(t,this.linearMapper_mdyssk$(e,n),i)},ts.prototype.buildAxisScaleDefault_82iy2c$=function(t,e,n){return t.with().breaks_pqjuzw$(n.domainValues).labels_mhpeer$(n.labels).mapper_1uitho$(e).build()},ts.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var es=null;function ns(){return null===es&&new ts,es}function is(){rs=this}Qa.$metadata$={kind:$,simpleName:"CoordProviderBase",interfaces:[Ja]},is.prototype.cartesian_t7esj2$=function(t,e){return void 0===t&&(t=null),void 0===e&&(e=null),new Za(t,e)},is.prototype.fixed_vvp5j4$=function(t,e,n){return void 0===e&&(e=null),void 0===n&&(n=null),new os(t,e,n)},is.prototype.map_t7esj2$=function(t,e){return void 0===t&&(t=null),void 0===e&&(e=null),new as(new cs,new ps,t,e)},is.$metadata$={kind:l,simpleName:"CoordProviders",interfaces:[]};var rs=null;function os(t,e,n){Qa.call(this,e,n),this.ratio_0=t}function as(t,e,n,i){us(),Qa.call(this,n,i),this.projectionX_0=t,this.projectionY_0=e}function ss(){ls=this}os.prototype.adjustDomains_jz8wgn$=function(t,e,n){var i=Qa.prototype.adjustDomains_jz8wgn$.call(this,t,e,n),r=i.first,o=i.second,a=ot.SeriesUtil.span_4fzjta$(r),s=ot.SeriesUtil.span_4fzjta$(o);if(a1?l*=this.ratio_0:u*=1/this.ratio_0;var c=a/l,p=s/u;if(c>p){var h=u*c;o=ot.SeriesUtil.expand_mdyssk$(o,h)}else{var _=l*p;r=ot.SeriesUtil.expand_mdyssk$(r,_)}return new rt(r,o)},os.$metadata$={kind:$,simpleName:"FixedRatioCoordProvider",interfaces:[Qa]},as.prototype.adjustDomains_jz8wgn$=function(t,e,n){var i,r=Qa.prototype.adjustDomains_jz8wgn$.call(this,t,e,n),o=this.projectionX_0.toValidDomain_4fzjta$(r.first),a=this.projectionY_0.toValidDomain_4fzjta$(r.second),s=ot.SeriesUtil.span_4fzjta$(o),l=ot.SeriesUtil.span_4fzjta$(a);if(s>l){var u=o.lowerEnd+s/2,c=l/2;i=new rt(new Q(u-c,u+c),a)}else{var p=a.lowerEnd+l/2,h=s/2;i=new rt(o,new Q(p-h,p+h))}var _=i,f=this.projectionX_0.apply_14dthe$(_.first.lowerEnd),d=this.projectionX_0.apply_14dthe$(_.first.upperEnd),m=this.projectionY_0.apply_14dthe$(_.second.lowerEnd);return new os((this.projectionY_0.apply_14dthe$(_.second.upperEnd)-m)/(d-f),null,null).adjustDomains_jz8wgn$(o,a,n)},as.prototype.buildAxisScaleX_ny58zc$=function(t,e,n,i){return this.projectionX_0.nonlinear?us().buildAxisScaleWithProjection_0(this.projectionX_0,t,e,n,i):Qa.prototype.buildAxisScaleX_ny58zc$.call(this,t,e,n,i)},as.prototype.buildAxisScaleY_ny58zc$=function(t,e,n,i){return this.projectionY_0.nonlinear?us().buildAxisScaleWithProjection_0(this.projectionY_0,t,e,n,i):Qa.prototype.buildAxisScaleY_ny58zc$.call(this,t,e,n,i)},ss.prototype.buildAxisScaleWithProjection_0=function(t,e,n,i,r){var o=t.toValidDomain_4fzjta$(n),a=new Q(t.apply_14dthe$(o.lowerEnd),t.apply_14dthe$(o.upperEnd)),s=u.Mappers.linear_1jkouz$(a,o),l=ns().linearMapper_mdyssk$(n,i),c=this.twistScaleMapper_0(t,s,l),p=this.validateBreaks_0(o,r);return ns().buildAxisScaleDefault_82iy2c$(e,c,p)},ss.prototype.validateBreaks_0=function(t,e){var n,i=p(),r=0;for(n=e.domainValues.iterator();n.hasNext();){var o=n.next();"number"==typeof o&&t.contains_mef7kx$(o)&&i.add_11rb$(r),r=r+1|0}if(i.size===e.domainValues.size)return e;var a=ot.SeriesUtil.pickAtIndices_ge51dg$(e.domainValues,i),s=ot.SeriesUtil.pickAtIndices_ge51dg$(e.labels,i),l=ot.SeriesUtil.pickAtIndices_ge51dg$(e.transformedValues,i);return new Ue(a,l,s)},ss.prototype.twistScaleMapper_0=function(t,e,n){return i=t,r=e,o=n,function(t){return null!=t?o(r(i.apply_14dthe$(t))):null};var i,r,o},ss.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var ls=null;function us(){return null===ls&&new ss,ls}function cs(){this.nonlinear_z5go4f$_0=!1}function ps(){this.nonlinear_x0lz9c$_0=!0}function hs(){ds=this}function _s(t,n,i){return function(r){for(var o,a=!0===(o=t.isNumeric_8xm3sj$(r))?ot.SeriesUtil.mean_l4tjj7$(t.getNumeric_8xm3sj$(r),null):!1===o?ot.SeriesUtil.firstNotNull_rath1t$(t.get_8xm3sj$(r),null):e.noWhenBranchMatched(),s=n,l=y(s),u=0;u0&&t=_&&g<=d,w=y.get_za3lpa$(v%y.size),x=this.tickLabelOffset_0(v);v=v+1|0;var k=this.buildTick_0(w,x,b?this.gridLineLength.get():0);if(n=this.orientation_0.get(),ft(n,Jl())||ft(n,Ql()))fn.SvgUtils.transformTranslate_pw34rw$(k,0,g);else{if(!ft(n,tu())&&!ft(n,eu()))throw pn("Unexpected orientation:"+f(this.orientation_0.get()));fn.SvgUtils.transformTranslate_pw34rw$(k,g,0)}i.children().add_11rb$(k)}}}null!=h&&i.children().add_11rb$(h)},Bs.prototype.buildTick_0=function(t,e,n){var i,r=null;this.tickMarksEnabled().get()&&(r=new dn,this.reg_3xv6fb$(_n.PropertyBinding.bindOneWay_2ov6i0$(this.tickMarkWidth,r.strokeWidth())),this.reg_3xv6fb$(_n.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0,r.strokeColor())));var o=null;this.tickLabelsEnabled().get()&&(o=new x(t),this.reg_3xv6fb$(_n.PropertyBinding.bindOneWay_2ov6i0$(this.tickColor_0,o.textColor())));var a=null;n>0&&(a=new dn,this.reg_3xv6fb$(_n.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineColor,a.strokeColor())),this.reg_3xv6fb$(_n.PropertyBinding.bindOneWay_2ov6i0$(this.gridLineWidth,a.strokeWidth())));var s=this.tickMarkLength.get();if(i=this.orientation_0.get(),ft(i,Jl()))null!=r&&(r.x2().set_11rb$(-s),r.y2().set_11rb$(0)),null!=a&&(a.x2().set_11rb$(n),a.y2().set_11rb$(0));else if(ft(i,Ql()))null!=r&&(r.x2().set_11rb$(s),r.y2().set_11rb$(0)),null!=a&&(a.x2().set_11rb$(-n),a.y2().set_11rb$(0));else if(ft(i,tu()))null!=r&&(r.x2().set_11rb$(0),r.y2().set_11rb$(-s)),null!=a&&(a.x2().set_11rb$(0),a.y2().set_11rb$(n));else{if(!ft(i,eu()))throw pn("Unexpected orientation:"+f(this.orientation_0.get()));null!=r&&(r.x2().set_11rb$(0),r.y2().set_11rb$(s)),null!=a&&(a.x2().set_11rb$(0),a.y2().set_11rb$(-n))}var l=new N;return null!=a&&l.children().add_11rb$(a),null!=r&&l.children().add_11rb$(r),null!=o&&(o.moveTo_lu1900$(e.x,e.y),o.setHorizontalAnchor_ja80zo$(this.tickLabelHorizontalAnchor.get()),o.setVerticalAnchor_yaudma$(this.tickLabelVerticalAnchor.get()),o.rotate_14dthe$(this.tickLabelRotationDegree.get()),l.children().add_11rb$(o.rootGroup)),l.addClass_61zpoe$(d_().TICK),l},Bs.prototype.tickMarkLength_0=function(){return this.myTickMarksEnabled_0.get()?this.tickMarkLength.get():0},Bs.prototype.tickLabelDistance_0=function(){return this.tickMarkLength_0()+this.tickMarkPadding.get()},Bs.prototype.tickLabelBaseOffset_0=function(){var t,e,n=this.tickLabelDistance_0();if(t=this.orientation_0.get(),ft(t,Jl()))e=new h(-n,0);else if(ft(t,Ql()))e=new h(n,0);else if(ft(t,tu()))e=new h(0,-n);else{if(!ft(t,eu()))throw pn("Unexpected orientation:"+f(this.orientation_0.get()));e=new h(0,n)}return e},Bs.prototype.tickLabelOffset_0=function(t){var e=this.tickLabelOffsets.get(),n=null!=e?e.get_za3lpa$(t):h.Companion.ZERO;return this.tickLabelBaseOffset_0().add_gpjtzr$(n)},Bs.prototype.breaksEnabled_0=function(){return this.myTickMarksEnabled_0.get()||this.myTickLabelsEnabled_0.get()},Bs.prototype.tickMarksEnabled=function(){return this.myTickMarksEnabled_0},Bs.prototype.tickLabelsEnabled=function(){return this.myTickLabelsEnabled_0},Bs.prototype.axisLineEnabled=function(){return this.myAxisLineEnabled_0},Bs.$metadata$={kind:$,simpleName:"AxisComponent",interfaces:[B]},Object.defineProperty(Fs.prototype,"spec",{get:function(){return this.spec_xr0de$_0}}),Fs.prototype.appendGuideContent_26jijc$=function(t){var e,n=this.spec.layout,i=new N,r=n.barBounds,o=n.isHorizontal;this.addColorBar_0(i,this.spec.domain,this.spec.scale,this.spec.binCount,r,n.barLengthExpand,o,this.spec.reverse);var a=(o?r.height:r.width)/5,s=n.breakInfos_8be2vx$.iterator();for(e=this.spec.breaks.labels.iterator();e.hasNext();){var l=e.next(),u=s.next(),c=u.tickLocation,_=p();if(o){var f=r.left+c;_.add_11rb$(new h(f,r.top)),_.add_11rb$(new h(f,r.top+a)),_.add_11rb$(new h(f,r.bottom-a)),_.add_11rb$(new h(f,r.bottom))}else{var d=r.top+c;_.add_11rb$(new h(r.left,d)),_.add_11rb$(new h(r.left+a,d)),_.add_11rb$(new h(r.right-a,d)),_.add_11rb$(new h(r.right,d))}this.addTickMark_0(i,_.get_za3lpa$(0),_.get_za3lpa$(1)),this.addTickMark_0(i,_.get_za3lpa$(2),_.get_za3lpa$(3));var m=new x(l);m.setHorizontalAnchor_ja80zo$(u.labelHorizontalAnchor),m.setVerticalAnchor_yaudma$(u.labelVerticalAnchor),m.moveTo_lu1900$(u.labelLocation.x,u.labelLocation.y+r.top),i.children().add_11rb$(m.rootGroup)}if(i.children().add_11rb$(ul().createBorder_a5dgib$(r,this.spec.theme.backgroundFill(),1)),this.debug){var y=new j(h.Companion.ZERO,n.graphSize);i.children().add_11rb$(ul().createBorder_a5dgib$(y,R.Companion.DARK_BLUE,1))}return t.children().add_11rb$(i),n.size},Fs.prototype.addColorBar_0=function(t,e,n,i,r,o,a,s){for(var l=ot.SeriesUtil.span_4fzjta$(e),c=X.max(2,i),h=l/c,_=e.lowerEnd+h/2,f=p(),d=0;d0))throw d(("Row count must be greater than 0, was "+t).toString());this.rowCount_kvp0d1$_0=t}}),Object.defineProperty(bl.prototype,"colCount",{configurable:!0,get:function(){return this.colCount_nojzuj$_0},set:function(t){if(!(t>0))throw d(("Col count must be greater than 0, was "+t).toString());this.colCount_nojzuj$_0=t}}),Object.defineProperty(bl.prototype,"graphSize",{configurable:!0,get:function(){return this.ensureInited_chkycd$_0(),S(this.myContentSize_8rvo9o$_0)}}),Object.defineProperty(bl.prototype,"keyLabelBoxes",{configurable:!0,get:function(){return this.ensureInited_chkycd$_0(),this.myKeyLabelBoxes_uk7fn2$_0}}),Object.defineProperty(bl.prototype,"labelBoxes",{configurable:!0,get:function(){return this.ensureInited_chkycd$_0(),this.myLabelBoxes_9jhh53$_0}}),bl.prototype.ensureInited_chkycd$_0=function(){null==this.myContentSize_8rvo9o$_0&&this.doLayout_zctv6z$_0()},bl.prototype.doLayout_zctv6z$_0=function(){var t,e=_l().LABEL_SPEC_8be2vx$.height(),n=_l().LABEL_SPEC_8be2vx$.width_za3lpa$(1)/2,i=this.keySize.x+n,r=(this.keySize.y-e)/2,o=h.Companion.ZERO,a=null;t=this.breaks;for(var s=0;s!==t.size;++s){var l,u=this.labelSize_za3lpa$(s),c=new h(i+u.x,this.keySize.y);a=new j(null!=(l=null!=a?this.breakBoxOrigin_b4d9xv$(s,a):null)?l:o,c),this.myKeyLabelBoxes_uk7fn2$_0.add_11rb$(a),this.myLabelBoxes_9jhh53$_0.add_11rb$(I(i,r,u.x,u.y))}this.myContentSize_8rvo9o$_0=Xc().union_a7nkjf$(new j(o,h.Companion.ZERO),this.myKeyLabelBoxes_uk7fn2$_0).dimension},wl.prototype.breakBoxOrigin_b4d9xv$=function(t,e){return new h(e.right,0)},wl.prototype.labelSize_za3lpa$=function(t){var e=this.breaks.get_za3lpa$(t).label;return new h(_l().LABEL_SPEC_8be2vx$.width_za3lpa$(e.length),_l().LABEL_SPEC_8be2vx$.height())},wl.$metadata$={kind:$,simpleName:"MyHorizontal",interfaces:[bl]},xl.$metadata$={kind:$,simpleName:"MyHorizontalMultiRow",interfaces:[El]},kl.$metadata$={kind:$,simpleName:"MyVertical",interfaces:[El]},El.prototype.breakBoxOrigin_b4d9xv$=function(t,e){return this.isFillByRow?t%this.colCount==0?new h(0,e.bottom):new h(e.right,e.top):t%this.rowCount==0?new h(e.right,0):new h(e.left,e.bottom)},El.prototype.labelSize_za3lpa$=function(t){return new h(this.myMaxLabelWidth_0,_l().LABEL_SPEC_8be2vx$.height())},El.$metadata$={kind:$,simpleName:"MyMultiRow",interfaces:[bl]},Cl.prototype.horizontal_2y8ibu$=function(t,e,n){return new wl(t,e,n)},Cl.prototype.horizontalMultiRow_2y8ibu$=function(t,e,n){return new xl(t,e,n)},Cl.prototype.vertical_2y8ibu$=function(t,e,n){return new kl(t,e,n)},Cl.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Sl,Tl,Ol,Nl=null;function Pl(){return null===Nl&&new Cl,Nl}function Al(t,e,n,i,r){fl.call(this,t,n,r),this.breaks_8be2vx$=e,this.layout_ebqbgv$_0=i}function jl(t,e){Xt.call(this),this.name$=t,this.ordinal$=e}function Ll(){Ll=function(){},Sl=new jl("HORIZONTAL",0),Tl=new jl("VERTICAL",1),Ol=new jl("AUTO",2)}function Rl(){return Ll(),Sl}function Il(){return Ll(),Tl}function zl(){return Ll(),Ol}function Dl(t,e){Ul(),this.x=t,this.y=e}function Ml(){Bl=this,this.CENTER=new Dl(.5,.5)}bl.$metadata$={kind:$,simpleName:"LegendComponentLayout",interfaces:[cl]},Object.defineProperty(Al.prototype,"layout",{get:function(){return this.layout_ebqbgv$_0}}),Al.$metadata$={kind:$,simpleName:"LegendComponentSpec",interfaces:[fl]},jl.$metadata$={kind:$,simpleName:"LegendDirection",interfaces:[Xt]},jl.values=function(){return[Rl(),Il(),zl()]},jl.valueOf_61zpoe$=function(t){switch(t){case"HORIZONTAL":return Rl();case"VERTICAL":return Il();case"AUTO":return zl();default:Zt("No enum constant jetbrains.datalore.plot.builder.guide.LegendDirection."+t)}},Ml.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Bl=null;function Ul(){return null===Bl&&new Ml,Bl}function Fl(t,e){Wl(),this.x=t,this.y=e}function ql(){Kl=this,this.RIGHT=new Fl(1,.5),this.LEFT=new Fl(0,.5),this.TOP=new Fl(.5,1),this.BOTTOM=new Fl(.5,1),this.NONE=new Fl(at.NaN,at.NaN)}Dl.$metadata$={kind:$,simpleName:"LegendJustification",interfaces:[]},Object.defineProperty(Fl.prototype,"isFixed",{configurable:!0,get:function(){return this===Wl().LEFT||this===Wl().RIGHT||this===Wl().TOP||this===Wl().BOTTOM}}),Object.defineProperty(Fl.prototype,"isHidden",{configurable:!0,get:function(){return this===Wl().NONE}}),Object.defineProperty(Fl.prototype,"isOverlay",{configurable:!0,get:function(){return!(this.isFixed||this.isHidden)}}),ql.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Gl,Hl,Yl,Vl,Kl=null;function Wl(){return null===Kl&&new ql,Kl}function Xl(t,e,n){Xt.call(this),this.myValue_3zu241$_0=n,this.name$=t,this.ordinal$=e}function Zl(){Zl=function(){},Gl=new Xl("LEFT",0,"LEFT"),Hl=new Xl("RIGHT",1,"RIGHT"),Yl=new Xl("TOP",2,"TOP"),Vl=new Xl("BOTTOM",3,"BOTTOM")}function Jl(){return Zl(),Gl}function Ql(){return Zl(),Hl}function tu(){return Zl(),Yl}function eu(){return Zl(),Vl}function nu(){au()}function iu(){ou=this,this.NONE=new ru}function ru(){}Fl.$metadata$={kind:$,simpleName:"LegendPosition",interfaces:[]},Object.defineProperty(Xl.prototype,"isHorizontal",{configurable:!0,get:function(){return this===tu()||this===eu()}}),Xl.prototype.toString=function(){return"Orientation{myValue='"+this.myValue_3zu241$_0+String.fromCharCode(39)+String.fromCharCode(125)},Xl.$metadata$={kind:$,simpleName:"Orientation",interfaces:[Xt]},Xl.values=function(){return[Jl(),Ql(),tu(),eu()]},Xl.valueOf_61zpoe$=function(t){switch(t){case"LEFT":return Jl();case"RIGHT":return Ql();case"TOP":return tu();case"BOTTOM":return eu();default:Zt("No enum constant jetbrains.datalore.plot.builder.guide.Orientation."+t)}},ru.prototype.createContextualMapping_8fr62e$=function(t,e){return new kn(et(),null,null,null,!1,!1,!1,!1)},ru.$metadata$={kind:$,interfaces:[nu]},iu.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var ou=null;function au(){return null===ou&&new iu,ou}function su(t){cu(),this.myLocatorLookupSpace_0=t.locatorLookupSpace,this.myLocatorLookupStrategy_0=t.locatorLookupStrategy,this.myTooltipLines_0=t.tooltipLines,this.myTooltipProperties_0=t.tooltipProperties,this.myIgnoreInvisibleTargets_0=t.isIgnoringInvisibleTargets(),this.myIsCrosshairEnabled_0=t.isCrosshairEnabled}function lu(){uu=this}nu.$metadata$={kind:b,simpleName:"ContextualMappingProvider",interfaces:[]},su.prototype.createLookupSpec=function(){return new xt(this.myLocatorLookupSpace_0,this.myLocatorLookupStrategy_0)},su.prototype.createContextualMapping_8fr62e$=function(t,e){var n,i=cu(),r=this.myTooltipLines_0,o=y(m(r,10));for(n=r.iterator();n.hasNext();){var a=n.next();o.add_11rb$(km(a))}return i.createContextualMapping_0(o,t,e,this.myTooltipProperties_0,this.myIgnoreInvisibleTargets_0,this.myIsCrosshairEnabled_0)},lu.prototype.createTestContextualMapping_fdc7hd$=function(t,e,n,i,r,o){void 0===o&&(o=null);var a=yu().defaultValueSourceTooltipLines_dnbe1t$(t,e,n,o);return this.createContextualMapping_0(a,i,r,Om().NONE,!1,!1)},lu.prototype.createContextualMapping_0=function(t,n,i,r,o,a){var s,l=new En(i,n),u=p();for(s=t.iterator();s.hasNext();){var c,h=s.next(),_=h.fields,f=p();for(c=_.iterator();c.hasNext();){var d=c.next();e.isType(d,$m)&&f.add_11rb$(d)}var m,y=f;t:do{var $;if(e.isType(y,Pt)&&y.isEmpty()){m=!0;break t}for($=y.iterator();$.hasNext();){var v=$.next();if(!n.isMapped_896ixz$(v.aes)){m=!1;break t}}m=!0}while(0);m&&u.add_11rb$(h)}var g,b,w=u;for(g=w.iterator();g.hasNext();)g.next().initDataContext_rxi9tf$(l);t:do{var x;if(e.isType(w,Pt)&&w.isEmpty()){b=!1;break t}for(x=w.iterator();x.hasNext();){var k,E=x.next().fields,C=Nt("isOutlier",1,(function(t){return t.isOutlier}));e:do{var S;if(e.isType(E,Pt)&&E.isEmpty()){k=!0;break e}for(S=E.iterator();S.hasNext();)if(C(S.next())){k=!1;break e}k=!0}while(0);if(k){b=!0;break t}}b=!1}while(0);var T,O=b;t:do{var N;if(e.isType(w,Pt)&&w.isEmpty()){T=!1;break t}for(N=w.iterator();N.hasNext();){var P,A=N.next().fields,j=Nt("isAxis",1,(function(t){return t.isAxis}));e:do{var L;if(e.isType(A,Pt)&&A.isEmpty()){P=!1;break e}for(L=A.iterator();L.hasNext();)if(j(L.next())){P=!0;break e}P=!1}while(0);if(P){T=!0;break t}}T=!1}while(0);var R=T;return new kn(w,r.anchor,r.minWidth,r.color,o,O,R,a)},lu.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var uu=null;function cu(){return null===uu&&new lu,uu}function pu(t){yu(),this.mySupportedAesList_0=t,this.myIgnoreInvisibleTargets_0=!1,this.locatorLookupSpace_3dt62f$_0=this.locatorLookupSpace_3dt62f$_0,this.locatorLookupStrategy_gpx4i$_0=this.locatorLookupStrategy_gpx4i$_0,this.myAxisTooltipVisibilityFromFunctionKind_0=!1,this.myAxisTooltipVisibilityFromConfig_0=null,this.myAxisAesFromFunctionKind_0=null,this.myTooltipAxisAes_vm9teg$_0=this.myTooltipAxisAes_vm9teg$_0,this.myTooltipAes_um80ux$_0=this.myTooltipAes_um80ux$_0,this.myTooltipOutlierAesList_r7qit3$_0=this.myTooltipOutlierAesList_r7qit3$_0,this.myTooltipConstantsAesList_0=null,this.myUserTooltipSpec_0=null,this.myIsCrosshairEnabled_0=!1}function hu(){mu=this,this.AREA_GEOM=!0,this.NON_AREA_GEOM=!1,this.AES_X_0=zt(J.Companion.X),this.AES_XY_0=an([J.Companion.X,J.Companion.Y])}su.$metadata$={kind:$,simpleName:"GeomInteraction",interfaces:[nu]},Object.defineProperty(pu.prototype,"locatorLookupSpace",{configurable:!0,get:function(){return null==this.locatorLookupSpace_3dt62f$_0?F("locatorLookupSpace"):this.locatorLookupSpace_3dt62f$_0},set:function(t){this.locatorLookupSpace_3dt62f$_0=t}}),Object.defineProperty(pu.prototype,"locatorLookupStrategy",{configurable:!0,get:function(){return null==this.locatorLookupStrategy_gpx4i$_0?F("locatorLookupStrategy"):this.locatorLookupStrategy_gpx4i$_0},set:function(t){this.locatorLookupStrategy_gpx4i$_0=t}}),Object.defineProperty(pu.prototype,"myTooltipAxisAes_0",{configurable:!0,get:function(){return null==this.myTooltipAxisAes_vm9teg$_0?F("myTooltipAxisAes"):this.myTooltipAxisAes_vm9teg$_0},set:function(t){this.myTooltipAxisAes_vm9teg$_0=t}}),Object.defineProperty(pu.prototype,"myTooltipAes_0",{configurable:!0,get:function(){return null==this.myTooltipAes_um80ux$_0?F("myTooltipAes"):this.myTooltipAes_um80ux$_0},set:function(t){this.myTooltipAes_um80ux$_0=t}}),Object.defineProperty(pu.prototype,"myTooltipOutlierAesList_0",{configurable:!0,get:function(){return null==this.myTooltipOutlierAesList_r7qit3$_0?F("myTooltipOutlierAesList"):this.myTooltipOutlierAesList_r7qit3$_0},set:function(t){this.myTooltipOutlierAesList_r7qit3$_0=t}}),Object.defineProperty(pu.prototype,"getAxisFromFunctionKind",{configurable:!0,get:function(){var t;return null!=(t=this.myAxisAesFromFunctionKind_0)?t:et()}}),Object.defineProperty(pu.prototype,"isAxisTooltipEnabled",{configurable:!0,get:function(){return null==this.myAxisTooltipVisibilityFromConfig_0?this.myAxisTooltipVisibilityFromFunctionKind_0:S(this.myAxisTooltipVisibilityFromConfig_0)}}),Object.defineProperty(pu.prototype,"tooltipLines",{configurable:!0,get:function(){return this.prepareTooltipValueSources_0()}}),Object.defineProperty(pu.prototype,"tooltipProperties",{configurable:!0,get:function(){var t,e;return null!=(e=null!=(t=this.myUserTooltipSpec_0)?t.tooltipProperties:null)?e:Om().NONE}}),Object.defineProperty(pu.prototype,"isCrosshairEnabled",{configurable:!0,get:function(){return this.myIsCrosshairEnabled_0}}),pu.prototype.showAxisTooltip_6taknv$=function(t){return this.myAxisTooltipVisibilityFromConfig_0=t,this},pu.prototype.tooltipAes_3lrecq$=function(t){return this.myTooltipAes_0=t,this},pu.prototype.axisAes_3lrecq$=function(t){return this.myTooltipAxisAes_0=t,this},pu.prototype.tooltipOutliers_3lrecq$=function(t){return this.myTooltipOutlierAesList_0=t,this},pu.prototype.tooltipConstants_ayg7dr$=function(t){return this.myTooltipConstantsAesList_0=t,this},pu.prototype.tooltipLinesSpec_uvmyj9$=function(t){return this.myUserTooltipSpec_0=t,this},pu.prototype.setIsCrosshairEnabled_6taknv$=function(t){return this.myIsCrosshairEnabled_0=t,this},pu.prototype.multilayerLookupStrategy=function(){return this.locatorLookupStrategy=Cn.NEAREST,this.locatorLookupSpace=Sn.XY,this},pu.prototype.univariateFunction_7k7ojo$=function(t){return this.myAxisAesFromFunctionKind_0=yu().AES_X_0,this.locatorLookupStrategy=t,this.myAxisTooltipVisibilityFromFunctionKind_0=!0,this.locatorLookupSpace=Sn.X,this.initDefaultTooltips_0(),this},pu.prototype.bivariateFunction_6taknv$=function(t){return this.myAxisAesFromFunctionKind_0=yu().AES_XY_0,t?(this.locatorLookupStrategy=Cn.HOVER,this.myAxisTooltipVisibilityFromFunctionKind_0=!1):(this.locatorLookupStrategy=Cn.NEAREST,this.myAxisTooltipVisibilityFromFunctionKind_0=!0),this.locatorLookupSpace=Sn.XY,this.initDefaultTooltips_0(),this},pu.prototype.none=function(){return this.myAxisAesFromFunctionKind_0=q(this.mySupportedAesList_0),this.locatorLookupStrategy=Cn.NONE,this.myAxisTooltipVisibilityFromFunctionKind_0=!0,this.locatorLookupSpace=Sn.NONE,this.initDefaultTooltips_0(),this},pu.prototype.initDefaultTooltips_0=function(){this.myTooltipAxisAes_0=this.isAxisTooltipEnabled?this.getAxisFromFunctionKind:et(),this.myTooltipAes_0=Tn(this.mySupportedAesList_0,this.getAxisFromFunctionKind),this.myTooltipOutlierAesList_0=et()},pu.prototype.prepareTooltipValueSources_0=function(){var t;if(null==this.myUserTooltipSpec_0)t=yu().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0,this.myTooltipAxisAes_0,this.myTooltipOutlierAesList_0,null,this.myTooltipConstantsAesList_0);else if(null==S(this.myUserTooltipSpec_0).tooltipLinePatterns)t=yu().defaultValueSourceTooltipLines_dnbe1t$(this.myTooltipAes_0,this.myTooltipAxisAes_0,this.myTooltipOutlierAesList_0,S(this.myUserTooltipSpec_0).valueSources,this.myTooltipConstantsAesList_0);else if(S(S(this.myUserTooltipSpec_0).tooltipLinePatterns).isEmpty())t=et();else{var n,i=On(this.myTooltipOutlierAesList_0);for(n=S(S(this.myUserTooltipSpec_0).tooltipLinePatterns).iterator();n.hasNext();){var r,o=n.next().fields,a=p();for(r=o.iterator();r.hasNext();){var s=r.next();e.isType(s,$m)&&a.add_11rb$(s)}var l,u=y(m(a,10));for(l=a.iterator();l.hasNext();){var c=l.next();u.add_11rb$(c.aes)}var h=u;i.removeAll_brywnq$(h)}var _,f=this.myTooltipAxisAes_0,d=y(m(f,10));for(_=f.iterator();_.hasNext();){var $=_.next();d.add_11rb$(new $m($,!0,!0))}var v,g=d,b=y(m(i,10));for(v=i.iterator();v.hasNext();){var w,x,k,E=v.next(),C=b.add_11rb$,T=S(this.myUserTooltipSpec_0).valueSources,O=p();for(x=T.iterator();x.hasNext();){var N=x.next();e.isType(N,$m)&&O.add_11rb$(N)}t:do{var P;for(P=O.iterator();P.hasNext();){var A=P.next();if(ft(A.aes,E)){k=A;break t}}k=null}while(0);var j=k;C.call(b,null!=(w=null!=j?j.toOutlier():null)?w:new $m(E,!0))}var L,R=b,I=S(S(this.myUserTooltipSpec_0).tooltipLinePatterns),D=Dt(g,R),M=z("defaultLineForValueSource",function(t,e){return t.defaultLineForValueSource_u47np3$(e)}.bind(null,xm())),B=y(m(D,10));for(L=D.iterator();L.hasNext();){var U=L.next();B.add_11rb$(M(U))}t=Dt(I,B)}return t},pu.prototype.build=function(){return new su(this)},pu.prototype.ignoreInvisibleTargets_6taknv$=function(t){return this.myIgnoreInvisibleTargets_0=t,this},pu.prototype.isIgnoringInvisibleTargets=function(){return this.myIgnoreInvisibleTargets_0},hu.prototype.defaultValueSourceTooltipLines_dnbe1t$=function(t,n,i,r,o){var a;void 0===r&&(r=null),void 0===o&&(o=null);var s,l=y(m(n,10));for(s=n.iterator();s.hasNext();){var u=s.next();l.add_11rb$(new $m(u,!0,!0))}var c,h=l,_=y(m(i,10));for(c=i.iterator();c.hasNext();){var f,d,$,v,g=c.next(),b=_.add_11rb$;if(null!=r){var w,x=p();for(w=r.iterator();w.hasNext();){var k=w.next();e.isType(k,$m)&&x.add_11rb$(k)}$=x}else $=null;if(null!=(f=$)){var E;t:do{var C;for(C=f.iterator();C.hasNext();){var S=C.next();if(ft(S.aes,g)){E=S;break t}}E=null}while(0);v=E}else v=null;var T=v;b.call(_,null!=(d=null!=T?T.toOutlier():null)?d:new $m(g,!0))}var O,N=_,P=y(m(t,10));for(O=t.iterator();O.hasNext();){var A,j,L,R=O.next(),I=P.add_11rb$;if(null!=r){var D,M=p();for(D=r.iterator();D.hasNext();){var B=D.next();e.isType(B,$m)&&M.add_11rb$(B)}j=M}else j=null;if(null!=(A=j)){var U;t:do{var F;for(F=A.iterator();F.hasNext();){var q=F.next();if(ft(q.aes,R)){U=q;break t}}U=null}while(0);L=U}else L=null;var G=L;I.call(P,null!=G?G:new $m(R))}var H,Y=P;if(null!=o){var V,K=y(o.size);for(V=o.entries.iterator();V.hasNext();){var W=V.next(),X=K.add_11rb$,Z=W.value;X.call(K,new mm(Z,null))}H=K}else H=null;var J,Q=null!=(a=H)?a:et(),tt=Dt(Dt(Dt(Y,h),N),Q),nt=z("defaultLineForValueSource",function(t,e){return t.defaultLineForValueSource_u47np3$(e)}.bind(null,xm())),it=y(m(tt,10));for(J=tt.iterator();J.hasNext();){var rt=J.next();it.add_11rb$(nt(rt))}return it},hu.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var _u,fu,du,mu=null;function yu(){return null===mu&&new hu,mu}function $u(){Ou=this}function vu(t){this.target=t,this.distance_pberzz$_0=-1,this.coord_ovwx85$_0=null}function gu(t,e){Xt.call(this),this.name$=t,this.ordinal$=e}function bu(){bu=function(){},_u=new gu("NEW_CLOSER",0),fu=new gu("NEW_FARTHER",1),du=new gu("EQUAL",2)}function wu(){return bu(),_u}function xu(){return bu(),fu}function ku(){return bu(),du}function Eu(t,e){if(Tu(),this.myStart_0=t,this.myLength_0=e,this.myLength_0<0)throw d("Length should be positive")}function Cu(){Su=this}pu.$metadata$={kind:$,simpleName:"GeomInteractionBuilder",interfaces:[]},$u.prototype.polygonContainsCoordinate_sz9prc$=function(t,e){var n,i=0;n=t.size;for(var r=1;r=e.y&&a.y>=e.y||o.y=t.start()&&this.end()<=t.end()},Eu.prototype.contains_14dthe$=function(t){return t>=this.start()&&t<=this.end()},Eu.prototype.start=function(){return this.myStart_0},Eu.prototype.end=function(){return this.myStart_0+this.length()},Eu.prototype.move_14dthe$=function(t){return Tu().withStartAndLength_lu1900$(this.start()+t,this.length())},Eu.prototype.moveLeft_14dthe$=function(t){if(t<0)throw d("Value should be positive");return Tu().withStartAndLength_lu1900$(this.start()-t,this.length())},Eu.prototype.moveRight_14dthe$=function(t){if(t<0)throw d("Value should be positive");return Tu().withStartAndLength_lu1900$(this.start()+t,this.length())},Cu.prototype.withStartAndEnd_lu1900$=function(t,e){var n=X.min(t,e);return new Eu(n,X.max(t,e)-n)},Cu.prototype.withStartAndLength_lu1900$=function(t,e){return new Eu(t,e)},Cu.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Su=null;function Tu(){return null===Su&&new Cu,Su}Eu.$metadata$={kind:$,simpleName:"DoubleRange",interfaces:[]},$u.$metadata$={kind:l,simpleName:"MathUtil",interfaces:[]};var Ou=null;function Nu(){return null===Ou&&new $u,Ou}function Pu(t,e,n,i,r,o,a){void 0===r&&(r=null),void 0===o&&(o=null),void 0===a&&(a=!1),this.layoutHint=t,this.fill=n,this.isOutlier=i,this.anchor=r,this.minWidth=o,this.isCrosshairEnabled=a,this.lines=q(e)}function Au(t,e){Mu(),this.label=t,this.value=e}function ju(){Du=this}Pu.prototype.toString=function(){var t,e="TooltipSpec("+this.layoutHint+", lines=",n=this.lines,i=y(m(n,10));for(t=n.iterator();t.hasNext();){var r=t.next();i.add_11rb$(r.toString())}return e+i+")"},Au.prototype.toString=function(){var t=this.label;return null==t||0===t.length?this.value:f(this.label)+": "+this.value},ju.prototype.withValue_61zpoe$=function(t){return new Au(null,t)},ju.prototype.withLabelAndValue_f5e6j7$=function(t,e){return new Au(t,e)},ju.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Lu,Ru,Iu,zu,Du=null;function Mu(){return null===Du&&new ju,Du}function Bu(t,e){this.contextualMapping_0=t,this.axisOrigin_0=e}function Uu(t,e){this.$outer=t,this.myGeomTarget_0=e,this.myDataPoints_0=this.$outer.contextualMapping_0.getDataPoints_za3lpa$(this.hitIndex_0()),this.myTooltipAnchor_0=this.$outer.contextualMapping_0.tooltipAnchor,this.myTooltipMinWidth_0=this.$outer.contextualMapping_0.tooltipMinWidth,this.myTooltipColor_0=this.$outer.contextualMapping_0.tooltipColor,this.myIsCrosshairEnabled_0=this.$outer.contextualMapping_0.isCrosshairEnabled}function Fu(t,e,n,i){this.geomKind_0=t,this.lookupSpec_0=e,this.contextualMapping_0=n,this.coordinateSystem_0=i,this.myTargets_0=p(),this.myLocator_0=null}function qu(t,n,i,r){var o,a;this.geomKind_0=t,this.lookupSpec_0=n,this.contextualMapping_0=i,this.myTargets_0=p(),this.myTargetDetector_0=new rc(this.lookupSpec_0.lookupSpace,this.lookupSpec_0.lookupStrategy),this.mySimpleGeometry_0=Un([re.RECT,re.POLYGON]),o=this.mySimpleGeometry_0.contains_11rb$(this.geomKind_0)?Wu():this.lookupSpec_0.lookupSpace===Sn.X&&this.lookupSpec_0.lookupStrategy===Cn.NEAREST?Xu():this.lookupSpec_0.lookupSpace===Sn.X||this.lookupSpec_0.lookupStrategy===Cn.HOVER?Ku():this.lookupSpec_0.lookupStrategy===Cn.NONE||this.lookupSpec_0.lookupSpace===Sn.NONE?Zu():Wu(),this.myCollectingStrategy_0=o;var s,l=(s=this,function(t){var n;switch(t.hitShape_8be2vx$.kind.name){case"POINT":n=hc().create_p1yge$(t.hitShape_8be2vx$.point.center,s.lookupSpec_0.lookupSpace);break;case"RECT":n=mc().create_tb1cvm$(t.hitShape_8be2vx$.rect,s.lookupSpec_0.lookupSpace);break;case"POLYGON":n=gc().create_a95qp$(t.hitShape_8be2vx$.points,s.lookupSpec_0.lookupSpace);break;case"PATH":n=Oc().create_zb7j6l$(t.hitShape_8be2vx$.points,t.indexMapper_8be2vx$,s.lookupSpec_0.lookupSpace);break;default:n=e.noWhenBranchMatched()}return n});for(a=r.iterator();a.hasNext();){var u=a.next();this.myTargets_0.add_11rb$(new Gu(l(u),u))}}function Gu(t,e){this.targetProjection_0=t,this.prototype=e}function Hu(t,e,n){var i;this.myStrategy_0=e,this.result_0=p(),i=n===Sn.X?new vu(new h(t.x,0)):new vu(t),this.closestPointChecker=i,this.myLastAddedDistance_0=-1}function Yu(t,e){Xt.call(this),this.name$=t,this.ordinal$=e}function Vu(){Vu=function(){},Lu=new Yu("APPEND",0),Ru=new Yu("REPLACE",1),Iu=new Yu("APPEND_IF_EQUAL",2),zu=new Yu("IGNORE",3)}function Ku(){return Vu(),Lu}function Wu(){return Vu(),Ru}function Xu(){return Vu(),Iu}function Zu(){return Vu(),zu}function Ju(){ic(),this.myPicked_0=p(),this.myMinDistance_0=0,this.myAllLookupResults_0=p()}function Qu(t){return t.contextualMapping.hasGeneralTooltip}function tc(t){return t.contextualMapping.hasAxisTooltip||an([re.V_LINE,re.H_LINE]).contains_11rb$(t.geomKind)}function ec(){nc=this,this.CUTOFF_DISTANCE_8be2vx$=30,this.FAKE_DISTANCE_8be2vx$=15,this.UNIVARIATE_GEOMS_0=an([re.DENSITY,re.FREQPOLY,re.BOX_PLOT,re.HISTOGRAM,re.LINE,re.AREA,re.BAR,re.ERROR_BAR,re.CROSS_BAR,re.LINE_RANGE,re.POINT_RANGE]),this.UNIVARIATE_LINES_0=an([re.DENSITY,re.FREQPOLY,re.LINE,re.AREA,re.SEGMENT])}Au.$metadata$={kind:$,simpleName:"Line",interfaces:[]},Pu.$metadata$={kind:$,simpleName:"TooltipSpec",interfaces:[]},Bu.prototype.create_62opr5$=function(t){return q(new Uu(this,t).createTooltipSpecs_8be2vx$())},Uu.prototype.createTooltipSpecs_8be2vx$=function(){var t=p();return Rn(t,this.outlierTooltipSpec_0()),Rn(t,this.generalTooltipSpec_0()),Rn(t,this.axisTooltipSpec_0()),t},Uu.prototype.hitIndex_0=function(){return this.myGeomTarget_0.hitIndex},Uu.prototype.tipLayoutHint_0=function(){return this.myGeomTarget_0.tipLayoutHint},Uu.prototype.outlierHints_0=function(){return this.myGeomTarget_0.aesTipLayoutHints},Uu.prototype.hintColors_0=function(){var t,e=this.myGeomTarget_0.aesTipLayoutHints,n=y(e.size);for(t=e.entries.iterator();t.hasNext();){var i=t.next();n.add_11rb$($t(i.key,i.value.color))}return vt(n)},Uu.prototype.outlierTooltipSpec_0=function(){var t,e=p(),n=this.outlierDataPoints_0();for(t=this.outlierHints_0().entries.iterator();t.hasNext();){var i,r,o=t.next(),a=o.key,s=o.value,l=p();for(r=n.iterator();r.hasNext();){var u=r.next();ft(a,u.aes)&&l.add_11rb$(u)}var c,h=Nt("value",1,(function(t){return t.value})),_=y(m(l,10));for(c=l.iterator();c.hasNext();){var f=c.next();_.add_11rb$(h(f))}var d,$=z("withValue",function(t,e){return t.withValue_61zpoe$(e)}.bind(null,Mu())),v=y(m(_,10));for(d=_.iterator();d.hasNext();){var g=d.next();v.add_11rb$($(g))}var b=v;b.isEmpty()||e.add_11rb$(new Pu(s,b,null!=(i=s.color)?i:S(this.tipLayoutHint_0().color),!0))}return e},Uu.prototype.axisTooltipSpec_0=function(){var t,e=p(),n=J.Companion.X,i=this.axisDataPoints_0(),r=p();for(t=i.iterator();t.hasNext();){var o=t.next();ft(J.Companion.X,o.aes)&&r.add_11rb$(o)}var a,s=Nt("value",1,(function(t){return t.value})),l=y(m(r,10));for(a=r.iterator();a.hasNext();){var u=a.next();l.add_11rb$(s(u))}var c,h=z("withValue",function(t,e){return t.withValue_61zpoe$(e)}.bind(null,Mu())),_=y(m(l,10));for(c=l.iterator();c.hasNext();){var f=c.next();_.add_11rb$(h(f))}var d,$=$t(n,_),v=J.Companion.Y,g=this.axisDataPoints_0(),b=p();for(d=g.iterator();d.hasNext();){var w=d.next();ft(J.Companion.Y,w.aes)&&b.add_11rb$(w)}var x,k=Nt("value",1,(function(t){return t.value})),E=y(m(b,10));for(x=b.iterator();x.hasNext();){var C=x.next();E.add_11rb$(k(C))}var T,O,N=z("withValue",function(t,e){return t.withValue_61zpoe$(e)}.bind(null,Mu())),P=y(m(E,10));for(T=E.iterator();T.hasNext();){var A=T.next();P.add_11rb$(N(A))}for(O=Pn([$,$t(v,P)]).entries.iterator();O.hasNext();){var j=O.next(),L=j.key,R=j.value;if(!R.isEmpty()){var I=this.createHintForAxis_0(L);e.add_11rb$(new Pu(I,R,S(I.color),!0))}}return e},Uu.prototype.generalTooltipSpec_0=function(){var t,e,n=this.generalDataPoints_0(),i=y(m(n,10));for(e=n.iterator();e.hasNext();){var r=e.next();i.add_11rb$(Mu().withLabelAndValue_f5e6j7$(r.label,r.value))}var o,a=i,s=this.hintColors_0(),l=Et();for(o=s.entries.iterator();o.hasNext();){var u,c=o.next(),h=c.key,_=y(m(n,10));for(u=n.iterator();u.hasNext();){var f=u.next();_.add_11rb$(f.aes)}_.contains_11rb$(h)&&l.put_xwzc9p$(c.key,c.value)}var d,$=l;if(null!=(t=$.get_11rb$(J.Companion.Y)))d=t;else{var v,g=p();for(v=$.entries.iterator();v.hasNext();){var b;null!=(b=v.next().value)&&g.add_11rb$(b)}d=An(g)}var w=d,x=null!=this.myTooltipColor_0?this.myTooltipColor_0:null!=w?w:S(this.tipLayoutHint_0().color);return a.isEmpty()?et():zt(new Pu(this.tipLayoutHint_0(),a,x,!1,this.myTooltipAnchor_0,this.myTooltipMinWidth_0,this.myIsCrosshairEnabled_0))},Uu.prototype.outlierDataPoints_0=function(){var t,e=this.myDataPoints_0,n=p();for(t=e.iterator();t.hasNext();){var i=t.next();i.isOutlier&&!i.isAxis&&n.add_11rb$(i)}return n},Uu.prototype.axisDataPoints_0=function(){var t,e=this.myDataPoints_0,n=Nt("isAxis",1,(function(t){return t.isAxis})),i=p();for(t=e.iterator();t.hasNext();){var r=t.next();n(r)&&i.add_11rb$(r)}return i},Uu.prototype.generalDataPoints_0=function(){var t,e=this.myDataPoints_0,n=Nt("isOutlier",1,(function(t){return t.isOutlier})),i=p();for(t=e.iterator();t.hasNext();){var r=t.next();n(r)||i.add_11rb$(r)}var o,a=i,s=this.outlierDataPoints_0(),l=Nt("aes",1,(function(t){return t.aes})),u=p();for(o=s.iterator();o.hasNext();){var c;null!=(c=l(o.next()))&&u.add_11rb$(c)}var h,_=u,f=Nt("aes",1,(function(t){return t.aes})),d=p();for(h=a.iterator();h.hasNext();){var m;null!=(m=f(h.next()))&&d.add_11rb$(m)}var y,$=Tn(d,_),v=p();for(y=a.iterator();y.hasNext();){var g,b=y.next();(null==(g=b.aes)||jn($,g))&&v.add_11rb$(b)}return v},Uu.prototype.createHintForAxis_0=function(t){var e;if(ft(t,J.Companion.X))e=Ln.Companion.xAxisTooltip_cgf2ia$(new h(S(this.tipLayoutHint_0().coord).x,this.$outer.axisOrigin_0.y),Nh().AXIS_TOOLTIP_COLOR,Nh().AXIS_RADIUS);else{if(!ft(t,J.Companion.Y))throw d(("Not an axis aes: "+t).toString());e=Ln.Companion.yAxisTooltip_cgf2ia$(new h(this.$outer.axisOrigin_0.x,S(this.tipLayoutHint_0().coord).y),Nh().AXIS_TOOLTIP_COLOR,Nh().AXIS_RADIUS)}return e},Uu.$metadata$={kind:$,simpleName:"Helper",interfaces:[]},Bu.$metadata$={kind:$,simpleName:"TooltipSpecFactory",interfaces:[]},Fu.prototype.addPoint_cnsimy$$default=function(t,e,n,i,r){var o;(!this.contextualMapping_0.ignoreInvisibleTargets||0!==n&&0!==i.getColor().alpha)&&this.coordinateSystem_0.isPointInLimits_k2qmv6$(e)&&this.addTarget_0(new Pc(In.Companion.point_e1sv3v$(e,n),(o=t,function(t){return o}),i,r))},Fu.prototype.addRectangle_bxzvr8$$default=function(t,e,n,i){var r;(!this.contextualMapping_0.ignoreInvisibleTargets||0!==e.width&&0!==e.height&&0!==n.getColor().alpha)&&this.coordinateSystem_0.isRectInLimits_fd842m$(e)&&this.addTarget_0(new Pc(In.Companion.rect_wthzt5$(e),(r=t,function(t){return r}),n,i))},Fu.prototype.addPath_sa5m83$$default=function(t,e,n,i){this.coordinateSystem_0.isPathInLimits_f6t8kh$(t)&&this.addTarget_0(new Pc(In.Companion.path_ytws2g$(t),e,n,i))},Fu.prototype.addPolygon_sa5m83$$default=function(t,e,n,i){this.coordinateSystem_0.isPolygonInLimits_f6t8kh$(t)&&this.addTarget_0(new Pc(In.Companion.polygon_ytws2g$(t),e,n,i))},Fu.prototype.addTarget_0=function(t){this.myTargets_0.add_11rb$(t),this.myLocator_0=null},Fu.prototype.search_gpjtzr$=function(t){return null==this.myLocator_0&&(this.myLocator_0=new qu(this.geomKind_0,this.lookupSpec_0,this.contextualMapping_0,this.myTargets_0)),S(this.myLocator_0).search_gpjtzr$(t)},Fu.$metadata$={kind:$,simpleName:"LayerTargetCollectorWithLocator",interfaces:[Dn,zn]},qu.prototype.addLookupResults_0=function(t,e){if(0!==t.size()){var n=t.collection(),i=t.closestPointChecker.distance;e.add_11rb$(new Mn(n,X.max(0,i),this.geomKind_0,this.contextualMapping_0,this.contextualMapping_0.isCrosshairEnabled))}},qu.prototype.search_gpjtzr$=function(t){var e;if(this.myTargets_0.isEmpty())return null;var n=new Hu(t,this.myCollectingStrategy_0,this.lookupSpec_0.lookupSpace),i=new Hu(t,this.myCollectingStrategy_0,this.lookupSpec_0.lookupSpace),r=new Hu(t,this.myCollectingStrategy_0,this.lookupSpec_0.lookupSpace),o=new Hu(t,Wu(),this.lookupSpec_0.lookupSpace);for(e=this.myTargets_0.iterator();e.hasNext();){var a=e.next();switch(a.prototype.hitShape_8be2vx$.kind.name){case"RECT":this.processRect_0(t,a,n);break;case"POINT":this.processPoint_0(t,a,i);break;case"PATH":this.processPath_0(t,a,r);break;case"POLYGON":this.processPolygon_0(t,a,o)}}var s=p();return this.addLookupResults_0(r,s),this.addLookupResults_0(n,s),this.addLookupResults_0(i,s),this.addLookupResults_0(o,s),this.getClosestTarget_0(s)},qu.prototype.getClosestTarget_0=function(t){var e;if(t.isEmpty())return null;var n=t.get_za3lpa$(0);if(!(n.distance>=0))throw G("Failed requirement.".toString());for(e=t.iterator();e.hasNext();){var i=e.next();i.distanceic().CUTOFF_DISTANCE_8be2vx$||(this.myPicked_0.isEmpty()||this.myMinDistance_0>i?(this.myPicked_0.clear(),this.myPicked_0.add_11rb$(n),this.myMinDistance_0=i):this.myMinDistance_0===i&&ic().isSameUnivariateGeom_0(this.myPicked_0.get_za3lpa$(0),n)?this.myPicked_0.add_11rb$(n):this.myMinDistance_0===i&&(this.myPicked_0.clear(),this.myPicked_0.add_11rb$(n)),this.myAllLookupResults_0.add_11rb$(n))},Ju.prototype.chooseBestResult_0=function(){var t,n,i=Qu,r=tc,o=this.myPicked_0;t:do{var a;if(e.isType(o,Pt)&&o.isEmpty()){n=!1;break t}for(a=o.iterator();a.hasNext();){var s=a.next();if(i(s)&&r(s)){n=!0;break t}}n=!1}while(0);if(n)t=this.myPicked_0;else{var l,u=this.myAllLookupResults_0;t:do{var c;if(e.isType(u,Pt)&&u.isEmpty()){l=!0;break t}for(c=u.iterator();c.hasNext();)if(i(c.next())){l=!1;break t}l=!0}while(0);if(l)t=this.myPicked_0;else{var p,h=this.myAllLookupResults_0;t:do{var _;if(e.isType(h,Pt)&&h.isEmpty()){p=!1;break t}for(_=h.iterator();_.hasNext();){var f=_.next();if(i(f)&&r(f)){p=!0;break t}}p=!1}while(0);if(p){var d,m=this.myAllLookupResults_0;t:do{for(var y=m.listIterator_za3lpa$(m.size);y.hasPrevious();){var $=y.previous();if(i($)&&r($)){d=$;break t}}throw new qn("List contains no element matching the predicate.")}while(0);t=zt(d)}else{var v,g=this.myAllLookupResults_0;t:do{for(var b=g.listIterator_za3lpa$(g.size);b.hasPrevious();){var w=b.previous();if(i(w)){v=w;break t}}v=null}while(0);var x,k=v,E=this.myAllLookupResults_0;t:do{for(var C=E.listIterator_za3lpa$(E.size);C.hasPrevious();){var S=C.previous();if(r(S)){x=S;break t}}x=null}while(0);t=Kt([k,x])}}}return t},ec.prototype.distance_0=function(t,e){var n,i,r=t.distance;if(0===r)if(t.isCrosshairEnabled&&null!=e){var o,a=t.targets,s=p();for(o=a.iterator();o.hasNext();){var l=o.next();null!=l.tipLayoutHint.coord&&s.add_11rb$(l)}var u,c=y(m(s,10));for(u=s.iterator();u.hasNext();){var h=u.next();c.add_11rb$(Nu().distance_l9poh5$(e,S(h.tipLayoutHint.coord)))}i=null!=(n=Fn(c))?n:this.FAKE_DISTANCE_8be2vx$}else i=this.FAKE_DISTANCE_8be2vx$;else i=r;return i},ec.prototype.isSameUnivariateGeom_0=function(t,e){return t.geomKind===e.geomKind&&this.UNIVARIATE_GEOMS_0.contains_11rb$(e.geomKind)},ec.prototype.filterResults_0=function(t,n){if(null==n||!this.UNIVARIATE_LINES_0.contains_11rb$(t.geomKind))return t;var i,r=t.targets,o=p();for(i=r.iterator();i.hasNext();){var a=i.next();null!=a.tipLayoutHint.coord&&o.add_11rb$(a)}var s,l,u=o,c=y(m(u,10));for(s=u.iterator();s.hasNext();){var h=s.next();c.add_11rb$(S(h.tipLayoutHint.coord).subtract_gpjtzr$(n).x)}t:do{var _=c.iterator();if(!_.hasNext()){l=null;break t}var f=_.next();if(!_.hasNext()){l=f;break t}var d=f,$=X.abs(d);do{var v=_.next(),g=X.abs(v);e.compareTo($,g)>0&&(f=v,$=g)}while(_.hasNext());l=f}while(0);var b,w,x=l,k=p();for(b=u.iterator();b.hasNext();){var E=b.next();S(E.tipLayoutHint.coord).subtract_gpjtzr$(n).x===x&&k.add_11rb$(E)}var C=Ye(),T=p();for(w=k.iterator();w.hasNext();){var O=w.next(),N=O.hitIndex;C.add_11rb$(N)&&T.add_11rb$(O)}return new Mn(T,t.distance,t.geomKind,t.contextualMapping,t.isCrosshairEnabled)},ec.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var nc=null;function ic(){return null===nc&&new ec,nc}function rc(t,e){sc(),this.locatorLookupSpace_0=t,this.locatorLookupStrategy_0=e}function oc(){ac=this,this.POINT_AREA_EPSILON_0=.1,this.POINT_X_NEAREST_EPSILON_0=2,this.RECT_X_NEAREST_EPSILON_0=2}Ju.$metadata$={kind:$,simpleName:"LocatedTargetsPicker",interfaces:[]},rc.prototype.checkPath_z3141m$=function(t,n,i){var r,o,a,s;switch(this.locatorLookupSpace_0.name){case"X":if(this.locatorLookupStrategy_0===Cn.NONE)return null;var l=n.points;if(l.isEmpty())return null;var u=sc().binarySearch_0(t.x,l.size,(s=l,function(t){return s.get_za3lpa$(t).projection().x()})),c=l.get_za3lpa$(u);switch(this.locatorLookupStrategy_0.name){case"HOVER":r=t.xl.get_za3lpa$(l.size-1|0).projection().x()?null:c;break;case"NEAREST":r=c;break;default:throw d("Unknown lookup strategy: "+this.locatorLookupStrategy_0)}return r;case"XY":switch(this.locatorLookupStrategy_0.name){case"HOVER":for(o=n.points.iterator();o.hasNext();){var p=o.next(),h=p.projection().xy();if(Nu().areEqual_f1g2it$(h,t,sc().POINT_AREA_EPSILON_0))return p}return null;case"NEAREST":var _=null;for(a=n.points.iterator();a.hasNext();){var f=a.next(),m=f.projection().xy();i.check_gpjtzr$(m)&&(_=f)}return _;case"NONE":return null;default:e.noWhenBranchMatched()}break;case"NONE":return null;default:throw Gn()}},rc.prototype.checkPoint_w0b42b$=function(t,n,i){var r,o;switch(this.locatorLookupSpace_0.name){case"X":var a=n.x();switch(this.locatorLookupStrategy_0.name){case"HOVER":r=Nu().areEqual_hln2n9$(a,t.x,sc().POINT_AREA_EPSILON_0);break;case"NEAREST":r=i.check_gpjtzr$(new h(a,0));break;case"NONE":r=!1;break;default:r=e.noWhenBranchMatched()}return r;case"XY":var s=n.xy();switch(this.locatorLookupStrategy_0.name){case"HOVER":o=Nu().areEqual_f1g2it$(s,t,sc().POINT_AREA_EPSILON_0);break;case"NEAREST":o=i.check_gpjtzr$(s);break;case"NONE":o=!1;break;default:o=e.noWhenBranchMatched()}return o;case"NONE":return!1;default:throw Gn()}},rc.prototype.checkRect_fqo6rd$=function(t,e,n){switch(this.locatorLookupSpace_0.name){case"X":var i=e.x();return this.rangeBasedLookup_0(t,n,i);case"XY":var r=e.xy();switch(this.locatorLookupStrategy_0.name){case"HOVER":return r.contains_gpjtzr$(t);case"NEAREST":if(r.contains_gpjtzr$(t))return n.check_gpjtzr$(t);var o=t.xn(e-1|0))return e-1|0;for(var i=0,r=e-1|0;i<=r;){var o=(r+i|0)/2|0,a=n(o);if(ta))return o;i=o+1|0}}return n(i)-tthis.POINTS_COUNT_TO_SKIP_SIMPLIFICATION_0){var s=a*this.AREA_TOLERANCE_RATIO_0,l=this.MAX_TOLERANCE_0,u=X.min(s,l);r=Kn.Companion.visvalingamWhyatt_ytws2g$(i).setWeightLimit_14dthe$(u).points,this.isLogEnabled_0&&this.log_0("Simp: "+f(i.size)+" -> "+f(r.size)+", tolerance="+f(u)+", bbox="+f(o)+", area="+f(a))}else this.isLogEnabled_0&&this.log_0("Keep: size: "+f(i.size)+", bbox="+f(o)+", area="+f(a)),r=i;r.size<4||n.add_11rb$(new bc(r,o))}}return n},$c.prototype.log_0=function(t){s(t)},$c.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var vc=null;function gc(){return null===vc&&new $c,vc}function bc(t,e){this.edges=t,this.bbox=e}function wc(t){Oc(),lc.call(this),this.data=t,this.points=this.data}function xc(t,e,n){Cc(),this.myPointTargetProjection_0=t,this.originalCoord=e,this.index=n}function kc(){Ec=this}bc.$metadata$={kind:$,simpleName:"RingXY",interfaces:[]},yc.$metadata$={kind:$,simpleName:"PolygonTargetProjection",interfaces:[lc]},xc.prototype.projection=function(){return this.myPointTargetProjection_0},kc.prototype.create_hdp8xa$=function(t,n,i){var r;switch(i.name){case"X":case"XY":r=new xc(hc().create_p1yge$(t,i),t,n);break;case"NONE":r=Nc();break;default:r=e.noWhenBranchMatched()}return r},kc.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Ec=null;function Cc(){return null===Ec&&new kc,Ec}function Sc(){Tc=this}xc.$metadata$={kind:$,simpleName:"PathPoint",interfaces:[]},Sc.prototype.create_zb7j6l$=function(t,e,n){for(var i=p(),r=0,o=t.iterator();o.hasNext();++r){var a=o.next();i.add_11rb$(Cc().create_hdp8xa$(a,e(r),n))}return new wc(i)},Sc.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Tc=null;function Oc(){return null===Tc&&new Sc,Tc}function Nc(){throw d("Undefined geom lookup space")}function Pc(t,e,n,i){Lc(),this.hitShape_8be2vx$=t,this.indexMapper_8be2vx$=e,this.tooltipParams_0=n,this.tooltipKind_8be2vx$=i}function Ac(){jc=this}wc.$metadata$={kind:$,simpleName:"PathTargetProjection",interfaces:[lc]},Pc.prototype.createGeomTarget_x7nr8i$=function(t,e){return new Wn(e,Lc().createTipLayoutHint_17pt0e$(t,this.hitShape_8be2vx$,this.tooltipParams_0.getColor(),this.tooltipKind_8be2vx$,this.tooltipParams_0.getStemLength()),this.tooltipParams_0.getTipLayoutHints())},Ac.prototype.createTipLayoutHint_17pt0e$=function(t,n,i,r,o){var a;switch(n.kind.name){case"POINT":switch(r.name){case"VERTICAL_TOOLTIP":a=Ln.Companion.verticalTooltip_6lq1u6$(t,n.point.radius,i,o);break;case"CURSOR_TOOLTIP":a=Ln.Companion.cursorTooltip_itpcqk$(t,i,o);break;default:throw d(("Wrong TipLayoutHint.kind = "+r+" for POINT").toString())}break;case"RECT":switch(r.name){case"VERTICAL_TOOLTIP":a=Ln.Companion.verticalTooltip_6lq1u6$(t,0,i,o);break;case"HORIZONTAL_TOOLTIP":a=Ln.Companion.horizontalTooltip_6lq1u6$(t,n.rect.width/2,i,o);break;case"CURSOR_TOOLTIP":a=Ln.Companion.cursorTooltip_itpcqk$(t,i,o);break;default:throw d(("Wrong TipLayoutHint.kind = "+r+" for RECT").toString())}break;case"PATH":if(!ft(r,Bn.HORIZONTAL_TOOLTIP))throw d(("Wrong TipLayoutHint.kind = "+r+" for PATH").toString());a=Ln.Companion.horizontalTooltip_6lq1u6$(t,0,i,o);break;case"POLYGON":if(!ft(r,Bn.CURSOR_TOOLTIP))throw d(("Wrong TipLayoutHint.kind = "+r+" for POLYGON").toString());a=Ln.Companion.cursorTooltip_itpcqk$(t,i,o);break;default:a=e.noWhenBranchMatched()}return a},Ac.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var jc=null;function Lc(){return null===jc&&new Ac,jc}function Rc(t){this.targetLocator_q7bze5$_0=t}function Ic(){}function zc(t){if(this.axisBreaks=null,this.axisLength=0,this.orientation=null,this.axisDomain=null,this.tickLabelsBounds=null,this.tickLabelRotationAngle=0,this.tickLabelHorizontalAnchor=null,this.tickLabelVerticalAnchor=null,this.tickLabelAdditionalOffsets=null,this.tickLabelSmallFont=!1,this.tickLabelsBoundsMax_0=null,null==t.myAxisBreaks)throw G("Failed requirement.".toString());if(null==t.myOrientation)throw G("Failed requirement.".toString());if(null==t.myTickLabelsBounds)throw G("Failed requirement.".toString());if(null==t.myAxisDomain)throw G("Failed requirement.".toString());this.axisBreaks=t.myAxisBreaks,this.axisLength=t.myAxisLength,this.orientation=t.myOrientation,this.axisDomain=t.myAxisDomain,this.tickLabelsBounds=t.myTickLabelsBounds,this.tickLabelRotationAngle=t.myTickLabelRotationAngle,this.tickLabelHorizontalAnchor=t.myLabelHorizontalAnchor,this.tickLabelVerticalAnchor=t.myLabelVerticalAnchor,this.tickLabelAdditionalOffsets=t.myLabelAdditionalOffsets,this.tickLabelSmallFont=t.myTickLabelSmallFont,this.tickLabelsBoundsMax_0=t.myMaxTickLabelsBounds}function Dc(){this.myAxisLength=0,this.myOrientation=null,this.myAxisDomain=null,this.myMaxTickLabelsBounds=null,this.myTickLabelSmallFont=!1,this.myLabelAdditionalOffsets=null,this.myLabelHorizontalAnchor=null,this.myLabelVerticalAnchor=null,this.myTickLabelRotationAngle=0,this.myTickLabelsBounds=null,this.myAxisBreaks=null}function Mc(t,e,n){Fc(),this.myOrientation_0=n,this.myAxisDomain_0=null,this.myAxisDomain_0=this.myOrientation_0.isHorizontal?t:e}function Bc(){Uc=this}Pc.$metadata$={kind:$,simpleName:"TargetPrototype",interfaces:[]},Rc.prototype.search_gpjtzr$=function(t){var e,n=this.convertToTargetCoord_gpjtzr$(t);if(null==(e=this.targetLocator_q7bze5$_0.search_gpjtzr$(n)))return null;var i=e;return this.convertLookupResult_rz45e2$_0(i)},Rc.prototype.convertLookupResult_rz45e2$_0=function(t){return new Mn(this.convertGeomTargets_cu5hhh$_0(t.targets),this.convertToPlotDistance_14dthe$(t.distance),t.geomKind,t.contextualMapping,t.contextualMapping.isCrosshairEnabled)},Rc.prototype.convertGeomTargets_cu5hhh$_0=function(t){return q(nt.Lists.transform_l7riir$(t,(e=this,function(t){return new Wn(t.hitIndex,e.convertTipLayoutHint_jnrdzl$_0(t.tipLayoutHint),e.convertTipLayoutHints_dshtp8$_0(t.aesTipLayoutHints))})));var e},Rc.prototype.convertTipLayoutHint_jnrdzl$_0=function(t){return new Ln(t.kind,S(this.safeConvertToPlotCoord_eoxeor$_0(t.coord)),this.convertToPlotDistance_14dthe$(t.objectRadius),t.color,t.stemLength)},Rc.prototype.convertTipLayoutHints_dshtp8$_0=function(t){var e,n=Z();for(e=t.entries.iterator();e.hasNext();){var i=e.next(),r=i.key,o=i.value,a=this.convertTipLayoutHint_jnrdzl$_0(o);n.put_xwzc9p$(r,a)}return n},Rc.prototype.safeConvertToPlotCoord_eoxeor$_0=function(t){return null==t?null:this.convertToPlotCoord_gpjtzr$(t)},Rc.$metadata$={kind:$,simpleName:"TransformedTargetLocator",interfaces:[Dn]},Ic.$metadata$={kind:b,simpleName:"AxisLayout",interfaces:[]},zc.prototype.withAxisLength_14dthe$=function(t){var e=new Dc;return e.myAxisBreaks=this.axisBreaks,e.myAxisLength=t,e.myOrientation=this.orientation,e.myAxisDomain=this.axisDomain,e.myTickLabelsBounds=this.tickLabelsBounds,e.myTickLabelRotationAngle=this.tickLabelRotationAngle,e.myLabelHorizontalAnchor=this.tickLabelHorizontalAnchor,e.myLabelVerticalAnchor=this.tickLabelVerticalAnchor,e.myLabelAdditionalOffsets=this.tickLabelAdditionalOffsets,e.myTickLabelSmallFont=this.tickLabelSmallFont,e.myMaxTickLabelsBounds=this.tickLabelsBoundsMax_0,e},zc.prototype.axisBounds=function(){return S(this.tickLabelsBounds).union_wthzt5$(I(0,0,0,0))},Dc.prototype.build=function(){return new zc(this)},Dc.prototype.axisLength_14dthe$=function(t){return this.myAxisLength=t,this},Dc.prototype.orientation_9y97dg$=function(t){return this.myOrientation=t,this},Dc.prototype.axisDomain_4fzjta$=function(t){return this.myAxisDomain=t,this},Dc.prototype.tickLabelsBoundsMax_myx2hi$=function(t){return this.myMaxTickLabelsBounds=t,this},Dc.prototype.tickLabelSmallFont_6taknv$=function(t){return this.myTickLabelSmallFont=t,this},Dc.prototype.tickLabelAdditionalOffsets_eajcfd$=function(t){return this.myLabelAdditionalOffsets=t,this},Dc.prototype.tickLabelHorizontalAnchor_tk0ev1$=function(t){return this.myLabelHorizontalAnchor=t,this},Dc.prototype.tickLabelVerticalAnchor_24j3ht$=function(t){return this.myLabelVerticalAnchor=t,this},Dc.prototype.tickLabelRotationAngle_14dthe$=function(t){return this.myTickLabelRotationAngle=t,this},Dc.prototype.tickLabelsBounds_myx2hi$=function(t){return this.myTickLabelsBounds=t,this},Dc.prototype.axisBreaks_hbp697$=function(t){return this.myAxisBreaks=t,this},Dc.$metadata$={kind:$,simpleName:"Builder",interfaces:[]},zc.$metadata$={kind:$,simpleName:"AxisLayoutInfo",interfaces:[]},Mc.prototype.initialThickness=function(){return 0},Mc.prototype.doLayout_o2m17x$=function(t,e){var n=this.myOrientation_0.isHorizontal?t.x:t.y,i=this.myOrientation_0.isHorizontal?I(0,0,n,0):I(0,0,0,n);return(new Dc).axisBreaks_hbp697$(Ue.Companion.EMPTY).axisLength_14dthe$(n).orientation_9y97dg$(this.myOrientation_0).axisDomain_4fzjta$(this.myAxisDomain_0).tickLabelsBounds_myx2hi$(i).build()},Bc.prototype.bottom_gyv40k$=function(t,e){return new Mc(t,e,eu())},Bc.prototype.left_gyv40k$=function(t,e){return new Mc(t,e,Jl())},Bc.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Uc=null;function Fc(){return null===Uc&&new Bc,Uc}function qc(t,e){if(Vc(),fp.call(this),this.facets_0=t,this.tileLayout_0=e,this.totalPanelHorizontalPadding_0=Vc().PANEL_PADDING_0*(this.facets_0.colCount-1|0),this.totalPanelVerticalPadding_0=Vc().PANEL_PADDING_0*(this.facets_0.rowCount-1|0),this.setPadding_6y0v78$(10,10,0,0),!this.facets_0.isDefined)throw G("Undefined facets.".toString())}function Gc(t){this.layoutInfo_8be2vx$=t}function Hc(){Yc=this,this.FACET_TAB_HEIGHT=30,this.FACET_H_PADDING=0,this.FACET_V_PADDING=6,this.PANEL_PADDING_0=10}Mc.$metadata$={kind:$,simpleName:"EmptyAxisLayout",interfaces:[Ic]},qc.prototype.doLayout_gpjtzr$=function(t){var n,i,r,o,a,s=new h(t.x-(this.paddingLeft_0+this.paddingRight_0),t.y-(this.paddingTop_0+this.paddingBottom_0)),l=this.facets_0.tileInfos();t:do{var u;for(u=l.iterator();u.hasNext();){var c=u.next();if(!c.colLabs.isEmpty()){a=c;break t}}a=null}while(0);var _,f,d=null!=(r=null!=(i=null!=(n=a)?n.colLabs:null)?i.size:null)?r:0,m=p();for(_=l.iterator();_.hasNext();){var y=_.next();y.colLabs.isEmpty()||m.add_11rb$(y)}var $=Ye(),v=p();for(f=m.iterator();f.hasNext();){var g=f.next(),b=g.row;$.add_11rb$(b)&&v.add_11rb$(g)}var w,x=v.size,k=Vc().facetColHeadHeight_za3lpa$(d)*x;t:do{var E;if(e.isType(l,Pt)&&l.isEmpty()){w=!1;break t}for(E=l.iterator();E.hasNext();)if(null!=E.next().rowLab){w=!0;break t}w=!1}while(0);for(var C=new h((w?1:0)*Vc().FACET_TAB_HEIGHT,k),S=((s=s.subtract_gpjtzr$(C)).x-this.totalPanelHorizontalPadding_0)/this.facets_0.colCount,T=(s.y-this.totalPanelVerticalPadding_0)/this.facets_0.rowCount,O=this.layoutTile_0(S,T),N=0;N<=1;N++){var P=this.tilesAreaSize_0(O),A=s.x-P.x,L=s.y-P.y,R=X.abs(A)<=this.facets_0.colCount;if(R&&(R=X.abs(L)<=this.facets_0.rowCount),R)break;var z=O.geomWidth_8be2vx$()+A/this.facets_0.colCount+O.axisThicknessY_8be2vx$(),D=O.geomHeight_8be2vx$()+L/this.facets_0.rowCount+O.axisThicknessX_8be2vx$();O=this.layoutTile_0(z,D)}var M=O.axisThicknessX_8be2vx$(),B=O.axisThicknessY_8be2vx$(),U=O.geomWidth_8be2vx$(),F=O.geomHeight_8be2vx$(),q=new j(h.Companion.ZERO,h.Companion.ZERO),G=new h(this.paddingLeft_0,this.paddingTop_0),H=p(),Y=0,V=0,K=0,W=0;for(o=l.iterator();o.hasNext();){var Z=o.next(),J=U,Q=0;Z.yAxis&&(J+=B,Q=B),null!=Z.rowLab&&(J+=Vc().FACET_TAB_HEIGHT);var tt,et=F;Z.xAxis&&Z.row===(this.facets_0.rowCount-1|0)&&(et+=M);var nt=Vc().facetColHeadHeight_za3lpa$(Z.colLabs.size);tt=nt;var it=I(0,0,J,et+=nt),rt=I(Q,tt,U,F),ot=Z.row;ot>K&&(K=ot,V+=W+Vc().PANEL_PADDING_0),W=et,0===Z.col&&(Y=0);var at=new h(Y,V);Y+=J+Vc().PANEL_PADDING_0;var st=wp(it,rt,Ep().clipBounds_wthzt5$(rt),O.layoutInfo_8be2vx$.xAxisInfo,O.layoutInfo_8be2vx$.yAxisInfo,Z.xAxis,Z.yAxis,Z.trueIndex).withOffset_gpjtzr$(G.add_gpjtzr$(at)).withFacetLabels_5hkr16$(Z.colLabs,Z.rowLab);H.add_11rb$(st),q=q.union_wthzt5$(st.getAbsoluteBounds_gpjtzr$(G))}return new dp(H,new h(q.right+this.paddingRight_0,q.height+this.paddingBottom_0))},qc.prototype.layoutTile_0=function(t,e){return new Gc(this.tileLayout_0.doLayout_gpjtzr$(new h(t,e)))},qc.prototype.tilesAreaSize_0=function(t){var e=t.geomWidth_8be2vx$()*this.facets_0.colCount+this.totalPanelHorizontalPadding_0+t.axisThicknessY_8be2vx$(),n=t.geomHeight_8be2vx$()*this.facets_0.rowCount+this.totalPanelVerticalPadding_0+t.axisThicknessX_8be2vx$();return new h(e,n)},Gc.prototype.axisThicknessX_8be2vx$=function(){return this.layoutInfo_8be2vx$.bounds.bottom-this.layoutInfo_8be2vx$.geomBounds.bottom},Gc.prototype.axisThicknessY_8be2vx$=function(){return this.layoutInfo_8be2vx$.geomBounds.left-this.layoutInfo_8be2vx$.bounds.left},Gc.prototype.geomWidth_8be2vx$=function(){return this.layoutInfo_8be2vx$.geomBounds.width},Gc.prototype.geomHeight_8be2vx$=function(){return this.layoutInfo_8be2vx$.geomBounds.height},Gc.$metadata$={kind:$,simpleName:"MyTileInfo",interfaces:[]},Hc.prototype.facetColLabelSize_14dthe$=function(t){return new h(t-0,this.FACET_TAB_HEIGHT-12)},Hc.prototype.facetColHeadHeight_za3lpa$=function(t){return t>0?this.facetColLabelSize_14dthe$(0).y*t+12:0},Hc.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Yc=null;function Vc(){return null===Yc&&new Hc,Yc}function Kc(){Wc=this}qc.$metadata$={kind:$,simpleName:"FacetGridPlotLayout",interfaces:[fp]},Kc.prototype.union_te9coj$=function(t,e){return null==e?t:t.union_wthzt5$(e)},Kc.prototype.union_a7nkjf$=function(t,e){var n,i=t;for(n=e.iterator();n.hasNext();){var r=n.next();i=i.union_wthzt5$(r)}return i},Kc.prototype.doubleRange_gyv40k$=function(t,e){var n=t.lowerEnd,i=e.lowerEnd,r=t.upperEnd-t.lowerEnd,o=e.upperEnd-e.lowerEnd;return I(n,i,r,o)},Kc.prototype.changeWidth_j6cmed$=function(t,e){return I(t.origin.x,t.origin.y,e,t.dimension.y)},Kc.prototype.changeWidthKeepRight_j6cmed$=function(t,e){return I(t.right-e,t.origin.y,e,t.dimension.y)},Kc.prototype.changeHeight_j6cmed$=function(t,e){return I(t.origin.x,t.origin.y,t.dimension.x,e)},Kc.prototype.changeHeightKeepBottom_j6cmed$=function(t,e){return I(t.origin.x,t.bottom-e,t.dimension.x,e)},Kc.$metadata$={kind:l,simpleName:"GeometryUtil",interfaces:[]};var Wc=null;function Xc(){return null===Wc&&new Kc,Wc}function Zc(t){ep(),this.size_8be2vx$=t}function Jc(){tp=this,this.EMPTY=new Qc(h.Companion.ZERO)}function Qc(t){Zc.call(this,t)}Object.defineProperty(Zc.prototype,"isEmpty",{configurable:!0,get:function(){return!1}}),Object.defineProperty(Qc.prototype,"isEmpty",{configurable:!0,get:function(){return!0}}),Qc.prototype.createLegendBox=function(){throw d("Empty legend box info")},Qc.$metadata$={kind:$,interfaces:[Zc]},Jc.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var tp=null;function ep(){return null===tp&&new Jc,tp}function np(t,e){this.myPlotBounds_0=t,this.myTheme_0=e}function ip(t,e){this.plotInnerBoundsWithoutLegendBoxes=t,this.boxWithLocationList=q(e)}function rp(t,e){this.legendBox=t,this.location=e}function op(){ap=this}Zc.$metadata$={kind:$,simpleName:"LegendBoxInfo",interfaces:[]},np.prototype.doLayout_8sg693$=function(t){var e,n=this.myTheme_0.position(),i=this.myTheme_0.justification(),r=ol(),o=this.myPlotBounds_0.center,a=this.myPlotBounds_0,s=r===ol()?sp().verticalStack_8sg693$(t):sp().horizontalStack_8sg693$(t),l=sp().size_9w4uif$(s);if(ft(n,Wl().LEFT)||ft(n,Wl().RIGHT)){var u=a.width-l.x,c=X.max(0,u);a=ft(n,Wl().LEFT)?Xc().changeWidthKeepRight_j6cmed$(a,c):Xc().changeWidth_j6cmed$(a,c)}else if(ft(n,Wl().TOP)||ft(n,Wl().BOTTOM)){var p=a.height-l.y,_=X.max(0,p);a=ft(n,Wl().TOP)?Xc().changeHeightKeepBottom_j6cmed$(a,_):Xc().changeHeight_j6cmed$(a,_)}return e=ft(n,Wl().LEFT)?new h(a.left-l.x,o.y-l.y/2):ft(n,Wl().RIGHT)?new h(a.right,o.y-l.y/2):ft(n,Wl().TOP)?new h(o.x-l.x/2,a.top-l.y):ft(n,Wl().BOTTOM)?new h(o.x-l.x/2,a.bottom):sp().overlayLegendOrigin_tmgej$(a,l,n,i),new ip(a,sp().moveAll_cpge3q$(e,s))},ip.$metadata$={kind:$,simpleName:"Result",interfaces:[]},rp.prototype.size_8be2vx$=function(){return this.legendBox.size_8be2vx$},rp.prototype.bounds_8be2vx$=function(){return new j(this.location,this.legendBox.size_8be2vx$)},rp.$metadata$={kind:$,simpleName:"BoxWithLocation",interfaces:[]},np.$metadata$={kind:$,simpleName:"LegendBoxesLayout",interfaces:[]},op.prototype.verticalStack_8sg693$=function(t){var e,n=p(),i=0;for(e=t.iterator();e.hasNext();){var r=e.next();n.add_11rb$(new rp(r,new h(0,i))),i+=r.size_8be2vx$.y}return n},op.prototype.horizontalStack_8sg693$=function(t){var e,n=p(),i=0;for(e=t.iterator();e.hasNext();){var r=e.next();n.add_11rb$(new rp(r,new h(i,0))),i+=r.size_8be2vx$.x}return n},op.prototype.moveAll_cpge3q$=function(t,e){var n,i=p();for(n=e.iterator();n.hasNext();){var r=n.next();i.add_11rb$(new rp(r.legendBox,r.location.add_gpjtzr$(t)))}return i},op.prototype.size_9w4uif$=function(t){var e,n,i,r=null;for(e=t.iterator();e.hasNext();){var o=e.next();r=null!=(n=null!=r?r.union_wthzt5$(o.bounds_8be2vx$()):null)?n:o.bounds_8be2vx$()}return null!=(i=null!=r?r.dimension:null)?i:h.Companion.ZERO},op.prototype.overlayLegendOrigin_tmgej$=function(t,e,n,i){var r=t.dimension,o=new h(t.left+r.x*n.x,t.bottom-r.y*n.y),a=new h(-e.x*i.x,e.y*i.y-e.y);return o.add_gpjtzr$(a)},op.$metadata$={kind:l,simpleName:"LegendBoxesLayoutUtil",interfaces:[]};var ap=null;function sp(){return null===ap&&new op,ap}function lp(){}function up(t,e,n,i,r,o){hp(),this.scale_0=t,this.domainX_0=e,this.domainY_0=n,this.coordProvider_0=i,this.theme_0=r,this.orientation_0=o}function cp(){pp=this,this.TICK_LABEL_SPEC_0=s_()}lp.prototype.doLayout_gpjtzr$=function(t){var e=Ep().geomBounds_pym7oz$(0,0,t);return wp(e=e.union_wthzt5$(new j(e.origin,Ep().GEOM_MIN_SIZE)),e,Ep().clipBounds_wthzt5$(e),null,null,void 0,void 0,0)},lp.$metadata$={kind:$,simpleName:"LiveMapTileLayout",interfaces:[gp]},up.prototype.initialThickness=function(){if(this.theme_0.showTickMarks()||this.theme_0.showTickLabels()){var t=this.theme_0.tickLabelDistance();return this.theme_0.showTickLabels()?t+hp().initialTickLabelSize_0(this.orientation_0):t}return 0},up.prototype.doLayout_o2m17x$=function(t,e){return this.createLayouter_0(t).doLayout_p1d3jc$(hp().axisLength_0(t,this.orientation_0),e)},up.prototype.createLayouter_0=function(t){var e=this.coordProvider_0.adjustDomains_jz8wgn$(this.domainX_0,this.domainY_0,t),n=hp().axisDomain_0(e,this.orientation_0),i=Lp().createAxisBreaksProvider_oftday$(this.scale_0,n);return Dp().create_4ebi60$(this.orientation_0,n,i,this.theme_0)},cp.prototype.bottom_eknalg$=function(t,e,n,i,r){return new up(t,e,n,i,r,eu())},cp.prototype.left_eknalg$=function(t,e,n,i,r){return new up(t,e,n,i,r,Jl())},cp.prototype.initialTickLabelSize_0=function(t){return t.isHorizontal?this.TICK_LABEL_SPEC_0.height():this.TICK_LABEL_SPEC_0.width_za3lpa$(1)},cp.prototype.axisLength_0=function(t,e){return e.isHorizontal?t.x:t.y},cp.prototype.axisDomain_0=function(t,e){return e.isHorizontal?t.first:t.second},cp.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var pp=null;function hp(){return null===pp&&new cp,pp}function _p(){}function fp(){this.paddingTop_72hspu$_0=0,this.paddingRight_oc6xpz$_0=0,this.paddingBottom_phgrg6$_0=0,this.paddingLeft_66kgx2$_0=0}function dp(t,e){this.size=e,this.tiles=q(t)}function mp(){yp=this,this.AXIS_TITLE_OUTER_MARGIN=4,this.AXIS_TITLE_INNER_MARGIN=4,this.TITLE_V_MARGIN_0=4,this.LIVE_MAP_PLOT_PADDING_0=new h(10,0),this.LIVE_MAP_PLOT_MARGIN_0=new h(10,10)}up.$metadata$={kind:$,simpleName:"PlotAxisLayout",interfaces:[Ic]},_p.$metadata$={kind:b,simpleName:"PlotLayout",interfaces:[]},Object.defineProperty(fp.prototype,"paddingTop_0",{configurable:!0,get:function(){return this.paddingTop_72hspu$_0},set:function(t){this.paddingTop_72hspu$_0=t}}),Object.defineProperty(fp.prototype,"paddingRight_0",{configurable:!0,get:function(){return this.paddingRight_oc6xpz$_0},set:function(t){this.paddingRight_oc6xpz$_0=t}}),Object.defineProperty(fp.prototype,"paddingBottom_0",{configurable:!0,get:function(){return this.paddingBottom_phgrg6$_0},set:function(t){this.paddingBottom_phgrg6$_0=t}}),Object.defineProperty(fp.prototype,"paddingLeft_0",{configurable:!0,get:function(){return this.paddingLeft_66kgx2$_0},set:function(t){this.paddingLeft_66kgx2$_0=t}}),fp.prototype.setPadding_6y0v78$=function(t,e,n,i){this.paddingTop_0=t,this.paddingRight_0=e,this.paddingBottom_0=n,this.paddingLeft_0=i},fp.$metadata$={kind:$,simpleName:"PlotLayoutBase",interfaces:[_p]},dp.$metadata$={kind:$,simpleName:"PlotLayoutInfo",interfaces:[]},mp.prototype.titleDimensions_61zpoe$=function(t){if(w.Strings.isNullOrEmpty_pdl1vj$(t))return h.Companion.ZERO;var e=a_();return new h(e.width_za3lpa$(t.length),e.height()+2*this.TITLE_V_MARGIN_0)},mp.prototype.axisTitleDimensions_61zpoe$=function(t){if(w.Strings.isNullOrEmpty_pdl1vj$(t))return h.Companion.ZERO;var e=u_();return new h(e.width_za3lpa$(t.length),e.height())},mp.prototype.absoluteGeomBounds_vjhcds$=function(t,e){var n,i;if(e.tiles.isEmpty())throw G("Plot is empty".toString());var r=null;for(n=e.tiles.iterator();n.hasNext();){var o=n.next().getAbsoluteGeomBounds_gpjtzr$(t);r=null!=(i=null!=r?r.union_wthzt5$(o):null)?i:o}return S(r)},mp.prototype.liveMapBounds_wthzt5$=function(t){return new j(t.origin.add_gpjtzr$(this.LIVE_MAP_PLOT_PADDING_0),t.dimension.subtract_gpjtzr$(this.LIVE_MAP_PLOT_MARGIN_0))},mp.$metadata$={kind:l,simpleName:"PlotLayoutUtil",interfaces:[]};var yp=null;function $p(){return null===yp&&new mp,yp}function vp(t){fp.call(this),this.myTileLayout_0=t,this.setPadding_6y0v78$(10,10,0,0)}function gp(){}function bp(t,e,n,i,r,o,a,s,l,u,c){this.plotOrigin=t,this.bounds=e,this.geomBounds=n,this.clipBounds=i,this.xAxisInfo=r,this.yAxisInfo=o,this.facetXLabels=l,this.facetYLabel=u,this.trueIndex=c,this.xAxisShown=null!=this.xAxisInfo&&a,this.yAxisShown=null!=this.yAxisInfo&&s}function wp(t,e,n,i,r,o,a,s,l){return void 0===o&&(o=!0),void 0===a&&(a=!0),l=l||Object.create(bp.prototype),bp.call(l,h.Companion.ZERO,t,e,n,i,r,o,a,et(),null,s),l}function xp(){kp=this,this.GEOM_MARGIN=0,this.CLIP_EXTEND_0=5,this.GEOM_MIN_SIZE=new h(50,50)}vp.prototype.doLayout_gpjtzr$=function(t){var e=new h(t.x-(this.paddingLeft_0+this.paddingRight_0),t.y-(this.paddingTop_0+this.paddingBottom_0)),n=this.myTileLayout_0.doLayout_gpjtzr$(e),i=(n=n.withOffset_gpjtzr$(new h(this.paddingLeft_0,this.paddingTop_0))).bounds.dimension;return i=i.add_gpjtzr$(new h(this.paddingRight_0,this.paddingBottom_0)),new dp(zt(n),i)},vp.$metadata$={kind:$,simpleName:"SingleTilePlotLayout",interfaces:[fp]},gp.$metadata$={kind:b,simpleName:"TileLayout",interfaces:[]},bp.prototype.withOffset_gpjtzr$=function(t){return new bp(t,this.bounds,this.geomBounds,this.clipBounds,this.xAxisInfo,this.yAxisInfo,this.xAxisShown,this.yAxisShown,this.facetXLabels,this.facetYLabel,this.trueIndex)},bp.prototype.getAbsoluteBounds_gpjtzr$=function(t){var e=t.add_gpjtzr$(this.plotOrigin);return this.bounds.add_gpjtzr$(e)},bp.prototype.getAbsoluteGeomBounds_gpjtzr$=function(t){var e=t.add_gpjtzr$(this.plotOrigin);return this.geomBounds.add_gpjtzr$(e)},bp.prototype.withFacetLabels_5hkr16$=function(t,e){return new bp(this.plotOrigin,this.bounds,this.geomBounds,this.clipBounds,this.xAxisInfo,this.yAxisInfo,this.xAxisShown,this.yAxisShown,t,e,this.trueIndex)},bp.$metadata$={kind:$,simpleName:"TileLayoutInfo",interfaces:[]},xp.prototype.geomBounds_pym7oz$=function(t,e,n){var i=new h(e,this.GEOM_MARGIN),r=new h(this.GEOM_MARGIN,t),o=n.subtract_gpjtzr$(i).subtract_gpjtzr$(r);return o.x0&&(r.v=I(r.v.origin.x+s,r.v.origin.y,r.v.dimension.x-s,r.v.dimension.y)),l>0&&(r.v=I(r.v.origin.x,r.v.origin.y,r.v.dimension.x-l,r.v.dimension.y)),r.v=r.v.union_wthzt5$(new j(r.v.origin,Ep().GEOM_MIN_SIZE));var u=Op().tileBounds_0(n.v.axisBounds(),i.axisBounds(),r.v);return n.v=n.v.withAxisLength_14dthe$(r.v.width).build(),i=i.withAxisLength_14dthe$(r.v.height).build(),wp(u,r.v,Ep().clipBounds_wthzt5$(r.v),n.v,i,void 0,void 0,0)},Sp.prototype.tileBounds_0=function(t,e,n){var i=new h(n.left-e.width,n.top-Ep().GEOM_MARGIN),r=new h(n.right+Ep().GEOM_MARGIN,n.bottom+t.height);return new j(i,r.subtract_gpjtzr$(i))},Sp.prototype.computeAxisInfos_0=function(t,e,n){var i=t.initialThickness(),r=this.computeYAxisInfo_0(e,Ep().geomBounds_pym7oz$(i,e.initialThickness(),n)),o=r.axisBounds().dimension.x,a=this.computeXAxisInfo_0(t,n,Ep().geomBounds_pym7oz$(i,o,n));return a.axisBounds().dimension.y>i&&(r=this.computeYAxisInfo_0(e,Ep().geomBounds_pym7oz$(a.axisBounds().dimension.y,o,n))),new Ft(a,r)},Sp.prototype.computeXAxisInfo_0=function(t,e,n){var i=n.dimension.x*this.AXIS_STRETCH_RATIO_0,r=Ep().maxTickLabelsBounds_m3y558$(eu(),i,n,e);return t.doLayout_o2m17x$(n.dimension,r)},Sp.prototype.computeYAxisInfo_0=function(t,e){return t.doLayout_o2m17x$(e.dimension,null)},Sp.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Tp=null;function Op(){return null===Tp&&new Sp,Tp}function Np(t,e){this.domainAfterTransform_0=t,this.breaksGenerator_0=e}function Pp(){}function Ap(){jp=this}Cp.$metadata$={kind:$,simpleName:"XYPlotTileLayout",interfaces:[gp]},Object.defineProperty(Np.prototype,"isFixedBreaks",{configurable:!0,get:function(){return!1}}),Object.defineProperty(Np.prototype,"fixedBreaks",{configurable:!0,get:function(){throw d("Not a fixed breaks provider")}}),Np.prototype.getBreaks_5wr77w$=function(t,e){return this.breaksGenerator_0.generateBreaks_1tlvto$(this.domainAfterTransform_0,t)},Np.$metadata$={kind:$,simpleName:"AdaptableAxisBreaksProvider",interfaces:[Pp]},Pp.$metadata$={kind:b,simpleName:"AxisBreaksProvider",interfaces:[]},Ap.prototype.createAxisBreaksProvider_oftday$=function(t,e){return t.hasBreaks()?new Mp(t.getScaleBreaks()):new Np(e,t.getBreaksGenerator())},Ap.$metadata$={kind:l,simpleName:"AxisBreaksUtil",interfaces:[]};var jp=null;function Lp(){return null===jp&&new Ap,jp}function Rp(t,e,n){Dp(),this.orientation=t,this.domainRange_jxchw$_0=e,this.labelsLayout_ft0nu6$_0=n}function Ip(){zp=this}Rp.prototype.doLayout_p1d3jc$=function(t,e){var n=this.labelsLayout_ft0nu6$_0.doLayout_s0wrr0$(t,this.toAxisMapper_14dthe$(t),e),i=n.bounds;return(new Dc).axisBreaks_hbp697$(n.breaks).axisLength_14dthe$(t).orientation_9y97dg$(this.orientation).axisDomain_4fzjta$(this.domainRange_jxchw$_0).tickLabelsBoundsMax_myx2hi$(e).tickLabelSmallFont_6taknv$(n.smallFont).tickLabelAdditionalOffsets_eajcfd$(n.labelAdditionalOffsets).tickLabelHorizontalAnchor_tk0ev1$(n.labelHorizontalAnchor).tickLabelVerticalAnchor_24j3ht$(n.labelVerticalAnchor).tickLabelRotationAngle_14dthe$(n.labelRotationAngle).tickLabelsBounds_myx2hi$(i).build()},Rp.prototype.toScaleMapper_14dthe$=function(t){return u.Mappers.mul_mdyssk$(this.domainRange_jxchw$_0,t)},Ip.prototype.create_4ebi60$=function(t,e,n,i){return t.isHorizontal?new Bp(t,e,n.isFixedBreaks?Xp().horizontalFixedBreaks_3unth9$(t,e,n.fixedBreaks,i):Xp().horizontalFlexBreaks_4ebi60$(t,e,n,i)):new Up(t,e,n.isFixedBreaks?Xp().verticalFixedBreaks_3unth9$(t,e,n.fixedBreaks,i):Xp().verticalFlexBreaks_4ebi60$(t,e,n,i))},Ip.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var zp=null;function Dp(){return null===zp&&new Ip,zp}function Mp(t){this.fixedBreaks_cixykn$_0=t}function Bp(t,e,n){Rp.call(this,t,e,n)}function Up(t,e,n){Rp.call(this,t,e,n)}function Fp(t,e,n,i,r){Yp(),Vp.call(this,t,e,n,r),this.breaks_0=i}function qp(){Hp=this,this.HORIZONTAL_TICK_LOCATION=Gp}function Gp(t){return new h(t,0)}Rp.$metadata$={kind:$,simpleName:"AxisLayouter",interfaces:[]},Object.defineProperty(Mp.prototype,"fixedBreaks",{get:function(){return this.fixedBreaks_cixykn$_0}}),Object.defineProperty(Mp.prototype,"isFixedBreaks",{configurable:!0,get:function(){return!0}}),Mp.prototype.getBreaks_5wr77w$=function(t,e){return this.fixedBreaks},Mp.$metadata$={kind:$,simpleName:"FixedAxisBreaksProvider",interfaces:[Pp]},Bp.prototype.toAxisMapper_14dthe$=function(t){return e=this.toScaleMapper_14dthe$(t),n=Be.Coords.toClientOffsetX_4fzjta$(new Q(0,t)),function(t){var i=e(t);return null!=i?n(i):null};var e,n},Bp.$metadata$={kind:$,simpleName:"HorizontalAxisLayouter",interfaces:[Rp]},Up.prototype.toAxisMapper_14dthe$=function(t){return e=this.toScaleMapper_14dthe$(t),n=Be.Coords.toClientOffsetY_4fzjta$(new Q(0,t)),function(t){var i=e(t);return null!=i?n(i):null};var e,n},Up.$metadata$={kind:$,simpleName:"VerticalAxisLayouter",interfaces:[Rp]},Fp.prototype.labelBounds_0=function(t,e){var n=this.labelSpec.dimensions_za3lpa$(e);return this.labelBounds_gpjtzr$(n).add_gpjtzr$(t)},Fp.prototype.labelsBounds_c3fefx$=function(t,e,n){var i,r=null;for(i=this.labelBoundsList_c3fefx$(t,this.breaks_0.labels,n).iterator();i.hasNext();){var o=i.next();r=Xc().union_te9coj$(o,r)}return r},Fp.prototype.labelBoundsList_c3fefx$=function(t,e,n){var i,r=p(),o=e.iterator();for(i=t.iterator();i.hasNext();){var a=i.next(),s=o.next(),l=this.labelBounds_0(n(a),s.length);r.add_11rb$(l)}return r},Fp.prototype.createAxisLabelsLayoutInfoBuilder_fd842m$=function(t,e){return(new Jp).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(t)).smallFont_6taknv$(!1).overlap_6taknv$(e)},Fp.prototype.noLabelsLayoutInfo_c0p8fa$=function(t,e){if(e.isHorizontal){var n=I(t/2,0,0,0);return n=this.applyLabelsOffset_w7e9pi$(n),(new Jp).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(n).smallFont_6taknv$(!1).overlap_6taknv$(!1).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(k.MIDDLE).labelVerticalAnchor_yaudma$(E.TOP).build()}throw d("Not implemented for "+e)},qp.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Hp=null;function Yp(){return null===Hp&&new qp,Hp}function Vp(t,e,n,i){Xp(),this.orientation=t,this.axisDomain=e,this.labelSpec=n,this.theme=i}function Kp(){Wp=this,this.TICK_LABEL_SPEC=s_(),this.INITIAL_TICK_LABEL_LENGTH=4,this.MIN_TICK_LABEL_DISTANCE=20,this.TICK_LABEL_SPEC_SMALL=l_()}Fp.$metadata$={kind:$,simpleName:"AbstractFixedBreaksLabelsLayout",interfaces:[Vp]},Object.defineProperty(Vp.prototype,"isHorizontal",{configurable:!0,get:function(){return this.orientation.isHorizontal}}),Vp.prototype.mapToAxis_d2cc22$=function(t,e){return eh().mapToAxis_lhkzxb$(t,this.axisDomain,e)},Vp.prototype.applyLabelsOffset_w7e9pi$=function(t){return eh().applyLabelsOffset_tsgpmr$(t,this.theme.tickLabelDistance(),this.orientation)},Kp.prototype.horizontalFlexBreaks_4ebi60$=function(t,e,n,i){if(!t.isHorizontal){var r=t.toString();throw G(r.toString())}if(n.isFixedBreaks)throw G("fixed breaks".toString());return new ih(t,e,this.TICK_LABEL_SPEC,n,i)},Kp.prototype.horizontalFixedBreaks_3unth9$=function(t,e,n,i){if(!t.isHorizontal){var r=t.toString();throw G(r.toString())}return new nh(t,e,this.TICK_LABEL_SPEC,n,i)},Kp.prototype.verticalFlexBreaks_4ebi60$=function(t,e,n,i){if(t.isHorizontal){var r=t.toString();throw G(r.toString())}if(n.isFixedBreaks)throw G("fixed breaks".toString());return new bh(t,e,this.TICK_LABEL_SPEC,n,i)},Kp.prototype.verticalFixedBreaks_3unth9$=function(t,e,n,i){if(t.isHorizontal){var r=t.toString();throw G(r.toString())}return new gh(t,e,this.TICK_LABEL_SPEC,n,i)},Kp.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Wp=null;function Xp(){return null===Wp&&new Kp,Wp}function Zp(t){this.breaks=null,this.bounds=null,this.smallFont=!1,this.labelAdditionalOffsets=null,this.labelHorizontalAnchor=null,this.labelVerticalAnchor=null,this.labelRotationAngle=0,this.isOverlap_8be2vx$=!1,this.breaks=t.myBreaks_8be2vx$,this.smallFont=t.mySmallFont_8be2vx$,this.bounds=t.myBounds_8be2vx$,this.isOverlap_8be2vx$=t.myOverlap_8be2vx$,this.labelAdditionalOffsets=null==t.myLabelAdditionalOffsets_8be2vx$?null:q(S(t.myLabelAdditionalOffsets_8be2vx$)),this.labelHorizontalAnchor=t.myLabelHorizontalAnchor_8be2vx$,this.labelVerticalAnchor=t.myLabelVerticalAnchor_8be2vx$,this.labelRotationAngle=t.myLabelRotationAngle_8be2vx$}function Jp(){this.myBreaks_8be2vx$=null,this.myBounds_8be2vx$=null,this.mySmallFont_8be2vx$=!1,this.myOverlap_8be2vx$=!1,this.myLabelAdditionalOffsets_8be2vx$=null,this.myLabelHorizontalAnchor_8be2vx$=null,this.myLabelVerticalAnchor_8be2vx$=null,this.myLabelRotationAngle_8be2vx$=0}function Qp(){th=this}Vp.$metadata$={kind:$,simpleName:"AxisLabelsLayout",interfaces:[]},Jp.prototype.breaks_d6t06k$=function(t){return this.myBreaks_8be2vx$=t,this},Jp.prototype.bounds_wthzt5$=function(t){return this.myBounds_8be2vx$=t,this},Jp.prototype.smallFont_6taknv$=function(t){return this.mySmallFont_8be2vx$=t,this},Jp.prototype.overlap_6taknv$=function(t){return this.myOverlap_8be2vx$=t,this},Jp.prototype.labelAdditionalOffsets_eajcfd$=function(t){return this.myLabelAdditionalOffsets_8be2vx$=t,this},Jp.prototype.labelHorizontalAnchor_ja80zo$=function(t){return this.myLabelHorizontalAnchor_8be2vx$=t,this},Jp.prototype.labelVerticalAnchor_yaudma$=function(t){return this.myLabelVerticalAnchor_8be2vx$=t,this},Jp.prototype.labelRotationAngle_14dthe$=function(t){return this.myLabelRotationAngle_8be2vx$=t,this},Jp.prototype.build=function(){return new Zp(this)},Jp.$metadata$={kind:$,simpleName:"Builder",interfaces:[]},Zp.$metadata$={kind:$,simpleName:"AxisLabelsLayoutInfo",interfaces:[]},Qp.prototype.getFlexBreaks_73ga93$=function(t,e,n){if(t.isFixedBreaks)throw G("fixed breaks not expected".toString());if(!(e>0))throw G(("maxCount="+e).toString());var i=t.getBreaks_5wr77w$(e,n);if(1===e&&!i.isEmpty)return new Ue(i.domainValues.subList_vux9f0$(0,1),i.transformedValues.subList_vux9f0$(0,1),i.labels.subList_vux9f0$(0,1));for(var r=e;i.size>e;){var o=(i.size-e|0)/2|0;r=r-X.max(1,o)|0,i=t.getBreaks_5wr77w$(r,n)}return i},Qp.prototype.maxLength_mhpeer$=function(t){var e,n=0;for(e=t.iterator();e.hasNext();){var i=n,r=e.next().length;n=X.max(i,r)}return n},Qp.prototype.horizontalCenteredLabelBounds_gpjtzr$=function(t){return I(-t.x/2,0,t.x,t.y)},Qp.prototype.doLayoutVerticalAxisLabels_7l1gh9$=function(t,e,n,i,r){var o;if(r.showTickLabels()){var a=this.verticalAxisLabelsBounds_0(e,n,i);o=this.applyLabelsOffset_tsgpmr$(a,r.tickLabelDistance(),t)}else if(r.showTickMarks()){var s=new j(h.Companion.ZERO,h.Companion.ZERO);o=this.applyLabelsOffset_tsgpmr$(s,r.tickLabelDistance(),t)}else o=new j(h.Companion.ZERO,h.Companion.ZERO);var l=o;return(new Jp).breaks_d6t06k$(e).bounds_wthzt5$(l).build()},Qp.prototype.mapToAxis_lhkzxb$=function(t,e,n){var i,r=e.lowerEnd,o=p();for(i=t.iterator();i.hasNext();){var a=n(i.next()-r);o.add_11rb$(S(a))}return o},Qp.prototype.applyLabelsOffset_tsgpmr$=function(t,n,i){var r,o=t;switch(i.name){case"LEFT":r=new h(-n,0);break;case"RIGHT":r=new h(n,0);break;case"TOP":r=new h(0,-n);break;case"BOTTOM":r=new h(0,n);break;default:r=e.noWhenBranchMatched()}var a=r;return i===Ql()||i===eu()?o=o.add_gpjtzr$(a):i!==Jl()&&i!==tu()||(o=o.add_gpjtzr$(a).subtract_gpjtzr$(new h(o.width,0))),o},Qp.prototype.verticalAxisLabelsBounds_0=function(t,e,n){var i=this.maxLength_mhpeer$(t.labels),r=Xp().TICK_LABEL_SPEC.width_za3lpa$(i),o=0,a=0;if(!t.isEmpty){var s=this.mapToAxis_lhkzxb$(t.transformedValues,e,n),l=s.get_za3lpa$(0),u=nt.Iterables.getLast_yl67zr$(s);o=X.min(l,u);var c=s.get_za3lpa$(0),p=nt.Iterables.getLast_yl67zr$(s);a=X.max(c,p),o-=Xp().TICK_LABEL_SPEC.height()/2,a+=Xp().TICK_LABEL_SPEC.height()/2}var _=new h(0,o),f=new h(r,a-o);return new j(_,f)},Qp.$metadata$={kind:l,simpleName:"BreakLabelsLayoutUtil",interfaces:[]};var th=null;function eh(){return null===th&&new Qp,th}function nh(t,e,n,i,r){if(Fp.call(this,t,e,n,i,r),!t.isHorizontal){var o=t.toString();throw G(o.toString())}}function ih(t,e,n,i,r){if(Vp.call(this,t,e,n,r),this.myBreaksProvider_0=i,!t.isHorizontal){var o=t.toString();throw G(o.toString())}if(this.myBreaksProvider_0.isFixedBreaks)throw G("fixed breaks".toString())}function rh(t,e,n,i,r,o){sh(),Fp.call(this,t,e,n,i,r),this.myMaxLines_0=o,this.myShelfIndexForTickIndex_0=p()}function oh(){ah=this,this.LINE_HEIGHT_0=1.2,this.MIN_DISTANCE_0=60}nh.prototype.overlap_0=function(t,e){return t.isOverlap_8be2vx$||null!=e&&!(e.xRange().encloses_d226ot$(S(t.bounds).xRange())&&e.yRange().encloses_d226ot$(t.bounds.yRange()))},nh.prototype.doLayout_s0wrr0$=function(t,e,n){if(!this.theme.showTickLabels())return this.noLabelsLayoutInfo_c0p8fa$(t,this.orientation);var i=this.simpleLayout_0().doLayout_s0wrr0$(t,e,n);return this.overlap_0(i,n)&&(i=this.multilineLayout_0().doLayout_s0wrr0$(t,e,n),this.overlap_0(i,n)&&(i=this.tiltedLayout_0().doLayout_s0wrr0$(t,e,n),this.overlap_0(i,n)&&(i=this.verticalLayout_0(this.labelSpec).doLayout_s0wrr0$(t,e,n),this.overlap_0(i,n)&&(i=this.verticalLayout_0(Xp().TICK_LABEL_SPEC_SMALL).doLayout_s0wrr0$(t,e,n))))),i},nh.prototype.simpleLayout_0=function(){return new lh(this.orientation,this.axisDomain,this.labelSpec,this.breaks_0,this.theme)},nh.prototype.multilineLayout_0=function(){return new rh(this.orientation,this.axisDomain,this.labelSpec,this.breaks_0,this.theme,2)},nh.prototype.tiltedLayout_0=function(){return new hh(this.orientation,this.axisDomain,this.labelSpec,this.breaks_0,this.theme)},nh.prototype.verticalLayout_0=function(t){return new mh(this.orientation,this.axisDomain,t,this.breaks_0,this.theme)},nh.prototype.labelBounds_gpjtzr$=function(t){throw d("Not implemented here")},nh.$metadata$={kind:$,simpleName:"HorizontalFixedBreaksLabelsLayout",interfaces:[Fp]},ih.prototype.doLayout_s0wrr0$=function(t,e,n){for(var i=ph().estimateBreakCountInitial_14dthe$(t),r=this.getBreaks_0(i,t),o=this.doLayoutLabels_0(r,t,e,n);o.isOverlap_8be2vx$;){var a=ph().estimateBreakCount_g5yaez$(r.labels,t);if(a>=i)break;i=a,r=this.getBreaks_0(i,t),o=this.doLayoutLabels_0(r,t,e,n)}return o},ih.prototype.doLayoutLabels_0=function(t,e,n,i){return new lh(this.orientation,this.axisDomain,this.labelSpec,t,this.theme).doLayout_s0wrr0$(e,n,i)},ih.prototype.getBreaks_0=function(t,e){return eh().getFlexBreaks_73ga93$(this.myBreaksProvider_0,t,e)},ih.$metadata$={kind:$,simpleName:"HorizontalFlexBreaksLabelsLayout",interfaces:[Vp]},Object.defineProperty(rh.prototype,"labelAdditionalOffsets_0",{configurable:!0,get:function(){var t,e=this.labelSpec.height()*sh().LINE_HEIGHT_0,n=p();t=this.breaks_0.size;for(var i=0;ithis.myMaxLines_0).labelAdditionalOffsets_eajcfd$(this.labelAdditionalOffsets_0).labelHorizontalAnchor_ja80zo$(k.MIDDLE).labelVerticalAnchor_yaudma$(E.TOP).build()},rh.prototype.labelBounds_gpjtzr$=function(t){return eh().horizontalCenteredLabelBounds_gpjtzr$(t)},oh.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var ah=null;function sh(){return null===ah&&new oh,ah}function lh(t,e,n,i,r){ph(),Fp.call(this,t,e,n,i,r)}function uh(){ch=this}rh.$metadata$={kind:$,simpleName:"HorizontalMultilineLabelsLayout",interfaces:[Fp]},lh.prototype.doLayout_s0wrr0$=function(t,e,n){var i;if(this.breaks_0.isEmpty)return this.noLabelsLayoutInfo_c0p8fa$(t,this.orientation);if(!this.theme.showTickLabels())return this.noLabelsLayoutInfo_c0p8fa$(t,this.orientation);var r=null,o=!1,a=this.mapToAxis_d2cc22$(this.breaks_0.transformedValues,e);for(i=this.labelBoundsList_c3fefx$(a,this.breaks_0.labels,Yp().HORIZONTAL_TICK_LOCATION).iterator();i.hasNext();){var s=i.next();o=o||null!=r&&r.xRange().isConnected_d226ot$(ot.SeriesUtil.expand_wws5xy$(s.xRange(),Xp().MIN_TICK_LABEL_DISTANCE/2,Xp().MIN_TICK_LABEL_DISTANCE/2)),r=Xc().union_te9coj$(s,r)}return(new Jp).breaks_d6t06k$(this.breaks_0).bounds_wthzt5$(this.applyLabelsOffset_w7e9pi$(S(r))).smallFont_6taknv$(!1).overlap_6taknv$(o).labelAdditionalOffsets_eajcfd$(null).labelHorizontalAnchor_ja80zo$(k.MIDDLE).labelVerticalAnchor_yaudma$(E.TOP).build()},lh.prototype.labelBounds_gpjtzr$=function(t){return eh().horizontalCenteredLabelBounds_gpjtzr$(t)},uh.prototype.estimateBreakCountInitial_14dthe$=function(t){return this.estimateBreakCount_0(4,t)},uh.prototype.estimateBreakCount_g5yaez$=function(t,e){var n=eh().maxLength_mhpeer$(t);return this.estimateBreakCount_0(n,e)},uh.prototype.estimateBreakCount_0=function(t,e){var n=e/(Xp().TICK_LABEL_SPEC.width_za3lpa$(t)+Xp().MIN_TICK_LABEL_DISTANCE);return Tt(X.max(1,n))},uh.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var ch=null;function ph(){return null===ch&&new uh,ch}function hh(t,e,n,i,r){dh(),Fp.call(this,t,e,n,i,r)}function _h(){fh=this,this.MIN_DISTANCE_0=5,this.ROTATION_DEGREE_0=-30;var t=Xn(this.ROTATION_DEGREE_0);this.SIN_0=X.sin(t);var e=Xn(this.ROTATION_DEGREE_0);this.COS_0=X.cos(e)}lh.$metadata$={kind:$,simpleName:"HorizontalSimpleLabelsLayout",interfaces:[Fp]},Object.defineProperty(hh.prototype,"labelHorizontalAnchor_0",{configurable:!0,get:function(){if(this.orientation===eu())return k.RIGHT;throw pn("Not implemented")}}),Object.defineProperty(hh.prototype,"labelVerticalAnchor_0",{configurable:!0,get:function(){return E.TOP}}),hh.prototype.doLayout_s0wrr0$=function(t,e,n){var i=this.labelSpec.height(),r=this.mapToAxis_d2cc22$(this.breaks_0.transformedValues,e),o=!1;if(this.breaks_0.size>=2){var a=(i+dh().MIN_DISTANCE_0)/dh().SIN_0,s=X.abs(a),l=r.get_za3lpa$(0)-r.get_za3lpa$(1);o=X.abs(l)=-90&&dh().ROTATION_DEGREE_0<=0&&this.labelHorizontalAnchor_0===k.RIGHT&&this.labelVerticalAnchor_0===E.TOP))throw pn("Not implemented");var e=t.x*dh().COS_0,n=X.abs(e),i=t.y*dh().SIN_0,r=n+2*X.abs(i),o=t.x*dh().SIN_0,a=X.abs(o),s=t.y*dh().COS_0,l=a+X.abs(s),u=t.x*dh().COS_0,c=X.abs(u),p=t.y*dh().SIN_0,h=-(c+X.abs(p));return I(h,0,r,l)},_h.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var fh=null;function dh(){return null===fh&&new _h,fh}function mh(t,e,n,i,r){vh(),Fp.call(this,t,e,n,i,r)}function yh(){$h=this,this.MIN_DISTANCE_0=5,this.ROTATION_DEGREE_0=90}hh.$metadata$={kind:$,simpleName:"HorizontalTiltedLabelsLayout",interfaces:[Fp]},Object.defineProperty(mh.prototype,"labelHorizontalAnchor",{configurable:!0,get:function(){if(this.orientation===eu())return k.LEFT;throw pn("Not implemented")}}),Object.defineProperty(mh.prototype,"labelVerticalAnchor",{configurable:!0,get:function(){return E.CENTER}}),mh.prototype.doLayout_s0wrr0$=function(t,e,n){var i=this.labelSpec.height(),r=this.mapToAxis_d2cc22$(this.breaks_0.transformedValues,e),o=!1;if(this.breaks_0.size>=2){var a=i+vh().MIN_DISTANCE_0,s=r.get_za3lpa$(0)-r.get_za3lpa$(1);o=X.abs(s)0))throw G(("axis length: "+t).toString());var i=this.maxTickCount_0(t),r=this.getBreaks_0(i,t);return eh().doLayoutVerticalAxisLabels_7l1gh9$(this.orientation,r,this.axisDomain,e,this.theme)},bh.prototype.getBreaks_0=function(t,e){return eh().getFlexBreaks_73ga93$(this.myBreaksProvider_0,t,e)},bh.$metadata$={kind:$,simpleName:"VerticalFlexBreaksLabelsLayout",interfaces:[Vp]},kh.$metadata$={kind:l,simpleName:"Title",interfaces:[]};var Eh=null;function Ch(){Sh=this,this.TITLE_FONT_SIZE=12,this.ITEM_FONT_SIZE=10,this.OUTLINE_COLOR=R.Companion.parseHex_61zpoe$(Uh().XX_LIGHT_GRAY)}Ch.$metadata$={kind:l,simpleName:"Legend",interfaces:[]};var Sh=null;function Th(){Oh=this,this.MAX_POINTER_FOOTING_LENGTH=12,this.POINTER_FOOTING_TO_SIDE_LENGTH_RATIO=.4,this.MARGIN_BETWEEN_TOOLTIPS=5,this.DATA_TOOLTIP_FONT_SIZE=12,this.LINE_INTERVAL=3,this.H_CONTENT_PADDING=4,this.V_CONTENT_PADDING=4,this.LABEL_VALUE_INTERVAL=8,this.BORDER_WIDTH=4,this.DARK_TEXT_COLOR=R.Companion.BLACK,this.LIGHT_TEXT_COLOR=R.Companion.WHITE,this.AXIS_TOOLTIP_FONT_SIZE=12,this.AXIS_TOOLTIP_COLOR=Mh().LINE_COLOR,this.AXIS_RADIUS=1.5}Th.$metadata$={kind:l,simpleName:"Tooltip",interfaces:[]};var Oh=null;function Nh(){return null===Oh&&new Th,Oh}function Ph(){}function Ah(){jh=this,this.FONT_SIZE=12,this.FONT_SIZE_CSS=f(12)+"px"}xh.$metadata$={kind:$,simpleName:"Common",interfaces:[]},Ah.$metadata$={kind:l,simpleName:"Head",interfaces:[]};var jh=null;function Lh(){Rh=this,this.FONT_SIZE=12,this.FONT_SIZE_CSS=f(12)+"px"}Lh.$metadata$={kind:l,simpleName:"Data",interfaces:[]};var Rh=null;function Ih(){}function zh(){Dh=this,this.TITLE_FONT_SIZE=12,this.TICK_FONT_SIZE=10,this.TICK_FONT_SIZE_SMALL=8,this.LINE_COLOR=R.Companion.parseHex_61zpoe$(Uh().DARK_GRAY),this.TICK_COLOR=R.Companion.parseHex_61zpoe$(Uh().DARK_GRAY),this.GRID_LINE_COLOR=R.Companion.parseHex_61zpoe$(Uh().X_LIGHT_GRAY),this.LINE_WIDTH=1,this.TICK_LINE_WIDTH=1,this.GRID_LINE_WIDTH=1}Ph.$metadata$={kind:$,simpleName:"Table",interfaces:[]},zh.$metadata$={kind:l,simpleName:"Axis",interfaces:[]};var Dh=null;function Mh(){return null===Dh&&new zh,Dh}Ih.$metadata$={kind:$,simpleName:"Plot",interfaces:[]},wh.$metadata$={kind:l,simpleName:"Defaults",interfaces:[]};var Bh=null;function Uh(){return null===Bh&&new wh,Bh}function Fh(){qh=this}Fh.prototype.get_diyz8p$=function(t,e){var n=Zn();return n.append_pdl1vj$(e).append_pdl1vj$(" {").append_pdl1vj$(t.isMonospaced?"\n font-family: "+Uh().FONT_FAMILY_MONOSPACED+";":"\n").append_pdl1vj$("\n font-size: ").append_s8jyv4$(t.fontSize).append_pdl1vj$("px;").append_pdl1vj$(t.isBold?"\n font-weight: bold;":"").append_pdl1vj$("\n}\n"),n.toString()},Fh.$metadata$={kind:l,simpleName:"LabelCss",interfaces:[]};var qh=null;function Gh(){return null===qh&&new Fh,qh}function Hh(){}function Yh(){e_(),this.fontSize_yu4fth$_0=0,this.isBold_4ltcm$_0=!1,this.isMonospaced_kwm1y$_0=!1}function Vh(){t_=this,this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0=.67,this.FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0=.6,this.FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0=1.075,this.LABEL_PADDING_0=0}Hh.$metadata$={kind:b,simpleName:"Serializable",interfaces:[]},Object.defineProperty(Yh.prototype,"fontSize",{configurable:!0,get:function(){return this.fontSize_yu4fth$_0}}),Object.defineProperty(Yh.prototype,"isBold",{configurable:!0,get:function(){return this.isBold_4ltcm$_0}}),Object.defineProperty(Yh.prototype,"isMonospaced",{configurable:!0,get:function(){return this.isMonospaced_kwm1y$_0}}),Yh.prototype.dimensions_za3lpa$=function(t){return new h(this.width_za3lpa$(t),this.height())},Yh.prototype.width_za3lpa$=function(t){var e=e_().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_0;this.isMonospaced&&(e=e_().FONT_SIZE_TO_GLYPH_WIDTH_RATIO_MONOSPACED_0);var n=t*this.fontSize*e+2*e_().LABEL_PADDING_0;return this.isBold?n*e_().FONT_WEIGHT_BOLD_TO_NORMAL_WIDTH_RATIO_0:n},Yh.prototype.height=function(){return this.fontSize+2*e_().LABEL_PADDING_0},Vh.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Kh,Wh,Xh,Zh,Jh,Qh,t_=null;function e_(){return null===t_&&new Vh,t_}function n_(t,e,n,i){return void 0===e&&(e=!1),void 0===n&&(n=!1),i=i||Object.create(Yh.prototype),Yh.call(i),i.fontSize_yu4fth$_0=t,i.isBold_4ltcm$_0=e,i.isMonospaced_kwm1y$_0=n,i}function i_(){}function r_(t,e,n,i,r){void 0===i&&(i=!1),void 0===r&&(r=!1),Xt.call(this),this.name$=t,this.ordinal$=e,this.myLabelMetrics_3i33aj$_0=null,this.myLabelMetrics_3i33aj$_0=n_(n,i,r)}function o_(){o_=function(){},Kh=new r_("PLOT_TITLE",0,16,!0),Wh=new r_("AXIS_TICK",1,10),Xh=new r_("AXIS_TICK_SMALL",2,8),Zh=new r_("AXIS_TITLE",3,12),Jh=new r_("LEGEND_TITLE",4,12,!0),Qh=new r_("LEGEND_ITEM",5,10)}function a_(){return o_(),Kh}function s_(){return o_(),Wh}function l_(){return o_(),Xh}function u_(){return o_(),Zh}function c_(){return o_(),Jh}function p_(){return o_(),Qh}function h_(){return[a_(),s_(),l_(),u_(),c_(),p_()]}function __(){f_=this,this.JFX_PLOT_STYLESHEET="/svgMapper/jfx/plot.css",this.PLOT_CONTAINER="plt-container",this.PLOT="plt-plot",this.PLOT_TITLE="plt-plot-title",this.PLOT_TRANSPARENT="plt-transparent",this.PLOT_BACKDROP="plt-backdrop",this.AXIS="plt-axis",this.AXIS_TITLE="plt-axis-title",this.TICK="tick",this.SMALL_TICK_FONT="small-tick-font",this.BACK="back",this.LEGEND="plt_legend",this.LEGEND_TITLE="legend-title",this.PLOT_DATA_TOOLTIP="plt-data-tooltip",this.PLOT_AXIS_TOOLTIP="plt-axis-tooltip",this.CSS_0=Qn('\n |.plt-container {\n |\tfont-family: "Lucida Grande", sans-serif;\n |\tcursor: crosshair;\n |\tuser-select: none;\n |\t-webkit-user-select: none;\n |\t-moz-user-select: none;\n |\t-ms-user-select: none;\n |}\n |.plt-backdrop {\n | fill: white;\n |}\n |.plt-transparent .plt-backdrop {\n | visibility: hidden;\n |}\n |text {\n |\tfont-size: 12px;\n |\tfill: #3d3d3d;\n |\t\n |\ttext-rendering: optimizeLegibility;\n |}\n |.plt-data-tooltip text {\n |\tfont-size: 12px;\n |}\n |.plt-axis-tooltip text {\n |\tfont-size: 12px;\n |}\n |.plt-axis line {\n |\tshape-rendering: crispedges;\n |}\n ')}Yh.$metadata$={kind:$,simpleName:"LabelMetrics",interfaces:[Hh,i_]},i_.$metadata$={kind:b,simpleName:"LabelSpec",interfaces:[]},Object.defineProperty(r_.prototype,"isBold",{configurable:!0,get:function(){return this.myLabelMetrics_3i33aj$_0.isBold}}),Object.defineProperty(r_.prototype,"isMonospaced",{configurable:!0,get:function(){return this.myLabelMetrics_3i33aj$_0.isMonospaced}}),Object.defineProperty(r_.prototype,"fontSize",{configurable:!0,get:function(){return this.myLabelMetrics_3i33aj$_0.fontSize}}),r_.prototype.dimensions_za3lpa$=function(t){return this.myLabelMetrics_3i33aj$_0.dimensions_za3lpa$(t)},r_.prototype.width_za3lpa$=function(t){return this.myLabelMetrics_3i33aj$_0.width_za3lpa$(t)},r_.prototype.height=function(){return this.myLabelMetrics_3i33aj$_0.height()},r_.$metadata$={kind:$,simpleName:"PlotLabelSpec",interfaces:[i_,Xt]},r_.values=h_,r_.valueOf_61zpoe$=function(t){switch(t){case"PLOT_TITLE":return a_();case"AXIS_TICK":return s_();case"AXIS_TICK_SMALL":return l_();case"AXIS_TITLE":return u_();case"LEGEND_TITLE":return c_();case"LEGEND_ITEM":return p_();default:Zt("No enum constant jetbrains.datalore.plot.builder.presentation.PlotLabelSpec."+t)}},Object.defineProperty(__.prototype,"css",{configurable:!0,get:function(){var t,e,n=new Jn(this.CSS_0.toString());for(n.append_s8itvh$(10),t=h_(),e=0;e!==t.length;++e){var i=t[e],r=this.selector_0(i);n.append_pdl1vj$(Gh().get_diyz8p$(i,r))}return n.toString()}}),__.prototype.selector_0=function(t){var n;switch(t.name){case"PLOT_TITLE":n=".plt-plot-title";break;case"AXIS_TICK":n=".plt-axis .tick text";break;case"AXIS_TICK_SMALL":n=".plt-axis.small-tick-font .tick text";break;case"AXIS_TITLE":n=".plt-axis-title text";break;case"LEGEND_TITLE":n=".plt_legend .legend-title text";break;case"LEGEND_ITEM":n=".plt_legend text";break;default:n=e.noWhenBranchMatched()}return n},__.$metadata$={kind:l,simpleName:"Style",interfaces:[]};var f_=null;function d_(){return null===f_&&new __,f_}function m_(){}function y_(){}function $_(){}function v_(){b_=this,this.RANDOM=M_().ALIAS,this.PICK=R_().ALIAS,this.SYSTEMATIC=tf().ALIAS,this.RANDOM_GROUP=C_().ALIAS,this.SYSTEMATIC_GROUP=P_().ALIAS,this.RANDOM_STRATIFIED=H_().ALIAS_8be2vx$,this.VERTEX_VW=af().ALIAS,this.VERTEX_DP=cf().ALIAS,this.NONE=new g_}function g_(){}m_.$metadata$={kind:b,simpleName:"GroupAwareSampling",interfaces:[$_]},y_.$metadata$={kind:b,simpleName:"PointSampling",interfaces:[$_]},$_.$metadata$={kind:b,simpleName:"Sampling",interfaces:[]},v_.prototype.random_280ow0$=function(t,e){return new I_(t,e)},v_.prototype.pick_za3lpa$=function(t){return new A_(t)},v_.prototype.vertexDp_za3lpa$=function(t){return new sf(t)},v_.prototype.vertexVw_za3lpa$=function(t){return new nf(t)},v_.prototype.systematic_za3lpa$=function(t){return new Z_(t)},v_.prototype.randomGroup_280ow0$=function(t,e){return new x_(t,e)},v_.prototype.systematicGroup_za3lpa$=function(t){return new T_(t)},v_.prototype.randomStratified_vcwos1$=function(t,e,n){return new B_(t,e,n)},Object.defineProperty(g_.prototype,"expressionText",{configurable:!0,get:function(){return"none"}}),g_.prototype.isApplicable_dhhkv7$=function(t){return!1},g_.prototype.apply_dhhkv7$=function(t){return t},g_.$metadata$={kind:$,simpleName:"NoneSampling",interfaces:[y_]},v_.$metadata$={kind:l,simpleName:"Samplings",interfaces:[]};var b_=null;function w_(){return null===b_&&new v_,b_}function x_(t,e){C_(),S_.call(this,t),this.mySeed_0=e}function k_(){E_=this,this.ALIAS="group_random"}Object.defineProperty(x_.prototype,"expressionText",{configurable:!0,get:function(){return"sampling_"+C_().ALIAS+"(n="+f(this.sampleSize)+(null!=this.mySeed_0?", seed="+f(this.mySeed_0):"")+")"}}),x_.prototype.apply_se5qvl$=function(t,e){if(!this.isApplicable_se5qvl$(t,e))throw G("Failed requirement.".toString());var n=X_().distinctGroups_ejae6o$(e,t.rowCount());ti(n,this.createRandom_0());var i=ni(ei(n,this.sampleSize));return this.doSelect_z69lec$(t,i,e)},x_.prototype.createRandom_0=function(){var t,e;return null!=(e=null!=(t=this.mySeed_0)?ii(t):null)?e:ri.Default},k_.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var E_=null;function C_(){return null===E_&&new k_,E_}function S_(t){Y_.call(this,t)}function T_(t){P_(),S_.call(this,t)}function O_(){N_=this,this.ALIAS="group_systematic"}x_.$metadata$={kind:$,simpleName:"GroupRandomSampling",interfaces:[S_]},S_.prototype.isApplicable_se5qvl$=function(t,e){return this.isApplicable_ijg2gx$(t,e,X_().groupCount_ejae6o$(e,t.rowCount()))},S_.prototype.isApplicable_ijg2gx$=function(t,e,n){return n>this.sampleSize},S_.prototype.doSelect_z69lec$=function(t,e,n){var i,r=ks().indicesByGroup_wc9gac$(t.rowCount(),n),o=p();for(i=e.iterator();i.hasNext();){var a=i.next();o.addAll_brywnq$(S(r.get_11rb$(a)))}return t.selectIndices_pqoyrt$(o)},S_.$metadata$={kind:$,simpleName:"GroupSamplingBase",interfaces:[m_,Y_]},Object.defineProperty(T_.prototype,"expressionText",{configurable:!0,get:function(){return"sampling_"+P_().ALIAS+"(n="+f(this.sampleSize)+")"}}),T_.prototype.isApplicable_ijg2gx$=function(t,e,n){return S_.prototype.isApplicable_ijg2gx$.call(this,t,e,n)&&tf().computeStep_vux9f0$(n,this.sampleSize)>=2},T_.prototype.apply_se5qvl$=function(t,e){if(!this.isApplicable_se5qvl$(t,e))throw G("Failed requirement.".toString());for(var n=X_().distinctGroups_ejae6o$(e,t.rowCount()),i=tf().computeStep_vux9f0$(n.size,this.sampleSize),r=Ye(),o=0;othis.sampleSize},B_.prototype.apply_se5qvl$=function(t,e){var n,i,r,o,a;if(!this.isApplicable_se5qvl$(t,e))throw G("Failed requirement.".toString());var s=ks().indicesByGroup_wc9gac$(t.rowCount(),e),l=null!=(n=this.myMinSubsampleSize_0)?n:2,u=l;l=X.max(0,u);var c=t.rowCount(),h=p(),_=null!=(r=null!=(i=this.mySeed_0)?ii(i):null)?r:ri.Default;for(o=s.keys.iterator();o.hasNext();){var f=o.next(),d=S(s.get_11rb$(f)),m=d.size,y=m/c,$=Tt(ai(this.sampleSize*y)),v=$,g=l;if(($=X.max(v,g))>=m)h.addAll_brywnq$(d);else for(a=oi.SamplingUtil.sampleWithoutReplacement_o7ew15$(m,$,_,U_(d),F_(d)).iterator();a.hasNext();){var b=a.next();h.add_11rb$(d.get_za3lpa$(b))}}return t.selectIndices_pqoyrt$(h)},q_.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var G_=null;function H_(){return null===G_&&new q_,G_}function Y_(t){if(this.sampleSize=t,!(this.sampleSize>0)){var e="Sample size must be greater than zero, but was: "+f(this.sampleSize);throw d(e.toString())}}B_.$metadata$={kind:$,simpleName:"RandomStratifiedSampling",interfaces:[m_,Y_]},Y_.prototype.isApplicable_dhhkv7$=function(t){return t.rowCount()>this.sampleSize},Y_.$metadata$={kind:$,simpleName:"SamplingBase",interfaces:[$_]};var V_=Qt((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function K_(){W_=this}K_.prototype.groupCount_ejae6o$=function(t,e){var n,i=si(0,e),r=y(m(i,10));for(n=i.iterator();n.hasNext();){var o=n.next();r.add_11rb$(t(o))}return It(r).size},K_.prototype.distinctGroups_ejae6o$=function(t,e){var n,i=si(0,e),r=y(m(i,10));for(n=i.iterator();n.hasNext();){var o=n.next();r.add_11rb$(t(o))}return On(It(r))},K_.prototype.xVar_bbyvt0$=function(t){return t.contains_11rb$(bt.Stats.X)?bt.Stats.X:t.contains_11rb$(a.TransformVar.X)?a.TransformVar.X:null},K_.prototype.xVar_dhhkv7$=function(t){var e;if(null==(e=this.xVar_bbyvt0$(t.variables())))throw d("Can't apply sampling: couldn't deduce the (X) variable.");return e},K_.prototype.yVar_dhhkv7$=function(t){if(t.has_8xm3sj$(bt.Stats.Y))return bt.Stats.Y;if(t.has_8xm3sj$(a.TransformVar.Y))return a.TransformVar.Y;throw d("Can't apply sampling: couldn't deduce the (Y) variable.")},K_.prototype.splitRings_dhhkv7$=function(t){for(var n,i,r=p(),o=null,a=-1,s=new pf(e.isType(n=t.get_8xm3sj$(this.xVar_dhhkv7$(t)),Mt)?n:c(),e.isType(i=t.get_8xm3sj$(this.yVar_dhhkv7$(t)),Mt)?i:c()),l=0;l!==s.size;++l){var u=s.get_za3lpa$(l);a<0?(a=l,o=u):ft(o,u)&&(r.add_11rb$(s.subList_vux9f0$(a,l+1|0)),a=-1,o=null)}return a>=0&&r.add_11rb$(s.subList_vux9f0$(a,s.size)),r},K_.prototype.calculateRingLimits_rmr3bv$=function(t,e){var n,i=y(m(t,10));for(n=t.iterator();n.hasNext();){var r=n.next();i.add_11rb$(Vn(r))}var o,a,s=li(i),l=new ui(0),u=new ci(0);return yi(_i(di(_i(di(_i(hi(pi(t)),(a=t,function(t){return new rt(t,Vn(a.get_za3lpa$(t)))})),fi(new te(V_((o=this,function(t){return o.getRingArea_0(t)}))))),function(t,e,n,i,r,o){return function(a){var s=mi(a.second/(t-e.get())*(n-i.get()|0)),l=r.get_za3lpa$(o.getRingIndex_3gcxfl$(a)).size,u=X.min(s,l);return u>=4?(e.getAndAdd_14dthe$(o.getRingArea_0(a)),i.getAndAdd_za3lpa$(u)):u=0,new rt(o.getRingIndex_3gcxfl$(a),u)}}(s,l,e,u,t,this)),new te(V_(function(t){return function(e){return t.getRingIndex_3gcxfl$(e)}}(this)))),function(t){return function(e){return t.getRingLimit_66os8t$(e)}}(this)))},K_.prototype.getRingIndex_3gcxfl$=function(t){return t.first},K_.prototype.getRingArea_0=function(t){return t.second},K_.prototype.getRingLimit_66os8t$=function(t){return t.second},K_.$metadata$={kind:l,simpleName:"SamplingUtil",interfaces:[]};var W_=null;function X_(){return null===W_&&new K_,W_}function Z_(t){tf(),Y_.call(this,t)}function J_(){Q_=this,this.ALIAS="systematic"}Object.defineProperty(Z_.prototype,"expressionText",{configurable:!0,get:function(){return"sampling_"+tf().ALIAS+"(n="+f(this.sampleSize)+")"}}),Z_.prototype.isApplicable_dhhkv7$=function(t){return Y_.prototype.isApplicable_dhhkv7$.call(this,t)&&this.computeStep_0(t.rowCount())>=2},Z_.prototype.apply_dhhkv7$=function(t){if(!this.isApplicable_dhhkv7$(t))throw G("Failed requirement.".toString());for(var e=t.rowCount(),n=this.computeStep_0(e),i=p(),r=0;r180&&(h>=p?p+=360:h+=360)}return o=t,a=r,s=u.Mappers.linear_yl4mmw$(t,p,h,at.NaN),l=u.Mappers.linear_yl4mmw$(t,_,f,at.NaN),c=u.Mappers.linear_yl4mmw$(t,e.v,n.v,at.NaN),function(t){if(null!=t&&o.contains_mef7kx$(t)){var e=s(t)%360,n=e>=0?e:360+e,i=l(t),r=c(t);return Ni.Colors.rgbFromHsv_yvo9jy$(n,i,r)}return a}},Xf.$metadata$={kind:l,simpleName:"ColorMapper",interfaces:[]};var Zf=null;function Jf(){return null===Zf&&new Xf,Zf}function Qf(t,e){this.mapper_0=t,this.isContinuous_zgpeec$_0=e}function td(t,e,n){this.mapper_0=t,this.breaks_3tqv0$_0=e,this.formatter_dkp6z6$_0=n,this.isContinuous_jvxsgv$_0=!1}function ed(){rd=this,this.IDENTITY=new Qf(u.Mappers.IDENTITY,!1),this.UNDEFINED=new Qf(u.Mappers.undefined_287e2$(),!1)}function nd(t){return t.toString()}function id(t){return t.toString()}Object.defineProperty(Qf.prototype,"isContinuous",{get:function(){return this.isContinuous_zgpeec$_0}}),Qf.prototype.apply_11rb$=function(t){return this.mapper_0(t)},Qf.$metadata$={kind:$,simpleName:"GuideMapperAdapter",interfaces:[Ff]},Object.defineProperty(td.prototype,"breaks",{get:function(){return this.breaks_3tqv0$_0}}),Object.defineProperty(td.prototype,"formatter",{get:function(){return this.formatter_dkp6z6$_0}}),Object.defineProperty(td.prototype,"isContinuous",{configurable:!0,get:function(){return this.isContinuous_jvxsgv$_0}}),td.prototype.apply_11rb$=function(t){return this.mapper_0(t)},td.$metadata$={kind:$,simpleName:"GuideMapperWithGuideBreaks",interfaces:[Wf,Ff]},ed.prototype.discreteToDiscrete_udkttt$=function(t,e,n,i){var r=t.distinctValues_8xm3sj$(e);return this.discreteToDiscrete_pkbp8v$(r,n,i)},ed.prototype.discreteToDiscrete_pkbp8v$=function(t,e,n){var i,r=u.Mappers.discrete_rath1t$(e,n),o=p();for(i=t.iterator();i.hasNext();){var a;null!=(a=i.next())&&o.add_11rb$(a)}return new td(r,o,nd)},ed.prototype.continuousToDiscrete_fooeq8$=function(t,e,n){var i=u.Mappers.quantized_hd8s0$(t,e,n);return this.asNotContinuous_rjdepr$(i)},ed.prototype.discreteToContinuous_83ntpg$=function(t,e,n){var i,r=u.Mappers.discreteToContinuous_83ntpg$(t,e,n),o=p();for(i=t.iterator();i.hasNext();){var a;null!=(a=i.next())&&o.add_11rb$(a)}return new td(r,o,id)},ed.prototype.continuousToContinuous_lww37m$=function(t,e,n){return this.asContinuous_rjdepr$(u.Mappers.linear_lww37m$(t,e,n))},ed.prototype.asNotContinuous_rjdepr$=function(t){return new Qf(t,!1)},ed.prototype.asContinuous_rjdepr$=function(t){return new Qf(t,!0)},ed.$metadata$={kind:l,simpleName:"GuideMappers",interfaces:[]};var rd=null;function od(){return null===rd&&new ed,rd}function ad(){sd=this,this.NA_VALUE=wi.SOLID}ad.prototype.allLineTypes=function(){return an([wi.SOLID,wi.DASHED,wi.DOTTED,wi.DOTDASH,wi.LONGDASH,wi.TWODASH])},ad.$metadata$={kind:l,simpleName:"LineTypeMapper",interfaces:[]};var sd=null;function ld(){return null===sd&&new ad,sd}function ud(){cd=this,this.NA_VALUE=bi.TinyPointShape}ud.prototype.allShapes=function(){var t=an([Ai.SOLID_CIRCLE,Ai.SOLID_TRIANGLE_UP,Ai.SOLID_SQUARE,Ai.STICK_PLUS,Ai.STICK_SQUARE_CROSS,Ai.STICK_STAR]),e=Li(an(ji().slice()));e.removeAll_brywnq$(t);var n=q(t);return n.addAll_brywnq$(e),n},ud.prototype.hollowShapes=function(){var t,e=an([Ai.STICK_CIRCLE,Ai.STICK_TRIANGLE_UP,Ai.STICK_SQUARE]),n=Li(an(ji().slice()));n.removeAll_brywnq$(e);var i=q(e);for(t=n.iterator();t.hasNext();){var r=t.next();r.isHollow&&i.add_11rb$(r)}return i},ud.$metadata$={kind:l,simpleName:"ShapeMapper",interfaces:[]};var cd=null;function pd(){return null===cd&&new ud,cd}function hd(t,e){dd(),Gd.call(this,t,e)}function _d(){fd=this,this.DEF_RANGE_0=new Q(.1,1),this.DEFAULT=new hd(this.DEF_RANGE_0,Bf().get_31786j$(J.Companion.ALPHA))}_d.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var fd=null;function dd(){return null===fd&&new _d,fd}function md(t,n,i,r){var o,a;if(gd(),Hd.call(this,r),this.paletteTypeName_0=t,this.paletteNameOrIndex_0=n,this.direction_0=i,null!=(o=null!=this.paletteNameOrIndex_0?"string"==typeof this.paletteNameOrIndex_0||e.isNumber(this.paletteNameOrIndex_0):null)&&!o){var s=(a=this,function(){return"palette: expected a name or index but was: "+f(e.getKClassFromExpression(S(a.paletteNameOrIndex_0)).simpleName)})();throw G(s.toString())}if(e.isNumber(this.paletteNameOrIndex_0)&&null==this.paletteTypeName_0)throw G("brewer palette type required: 'seq', 'div' or 'qual'.".toString())}function yd(){vd=this}function $d(t){return"'"+t.name+"'"}hd.$metadata$={kind:$,simpleName:"AlphaMapperProvider",interfaces:[Gd]},md.prototype.createDiscreteMapper_7f6uoc$=function(t){var e=this.colorScheme_0(!0,t.size),n=this.colors_0(e,t.size);return od().discreteToDiscrete_pkbp8v$(t,n,this.naValue)},md.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r=this.colorScheme_0(!1),o=this.colors_0(r,r.maxColors),a=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i);return od().continuousToDiscrete_fooeq8$(a,o,this.naValue)},md.prototype.colors_0=function(t,n){var i,r,o=Ri.PaletteUtil.schemeColors_7q5c77$(t,n);return!0===(r=null!=(i=null!=this.direction_0?this.direction_0<0:null)&&i)?nt.Lists.reverse_bemo1h$(o):!1===r?o:e.noWhenBranchMatched()},md.prototype.colorScheme_0=function(t,n){var i;if(void 0===n&&(n=null),"string"==typeof this.paletteNameOrIndex_0){var r=Ri.PaletteUtil.paletteTypeByPaletteName_61zpoe$(this.paletteNameOrIndex_0);if(null==r){var o=gd().cantFindPaletteError_0(this.paletteNameOrIndex_0);throw G(o.toString())}i=r}else i=null!=this.paletteTypeName_0?gd().paletteType_0(this.paletteTypeName_0):t?Ii.QUALITATIVE:Ii.SEQUENTIAL;var a=i;return e.isNumber(this.paletteNameOrIndex_0)?Ri.PaletteUtil.colorSchemeByIndex_vfydh1$(a,Tt(this.paletteNameOrIndex_0)):"string"==typeof this.paletteNameOrIndex_0?gd().colorSchemeByName_0(a,this.paletteNameOrIndex_0):a===Ii.QUALITATIVE?null!=n&&n<=zi.Set2.maxColors?zi.Set2:zi.Set3:Ri.PaletteUtil.colorSchemeByIndex_vfydh1$(a,0)},yd.prototype.paletteType_0=function(t){var e;if(null==t)return Ii.SEQUENTIAL;switch(t){case"seq":e=Ii.SEQUENTIAL;break;case"div":e=Ii.DIVERGING;break;case"qual":e=Ii.QUALITATIVE;break;default:throw G("Palette type expected one of 'seq' (sequential), 'div' (diverging) or 'qual' (qualitative) but was: '"+f(t)+"'")}return e},yd.prototype.colorSchemeByName_0=function(t,n){var i;try{switch(t.name){case"SEQUENTIAL":i=Di(n);break;case"DIVERGING":i=Mi(n);break;case"QUALITATIVE":i=Bi(n);break;default:i=e.noWhenBranchMatched()}return i}catch(t){throw e.isType(t,Ui)?G(this.cantFindPaletteError_0(n)):t}},yd.prototype.cantFindPaletteError_0=function(t){return Qn("\n |Brewer palette '"+t+"' was not found. \n |Valid palette names are: \n | Type 'seq' (sequential): \n | "+this.names_0(Fi())+" \n | Type 'div' (diverging): \n | "+this.names_0(qi())+" \n | Type 'qual' (qualitative): \n | "+this.names_0(Gi())+" \n ")},yd.prototype.names_0=function(t){return Hi(t,", ",void 0,void 0,void 0,void 0,$d)},yd.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var vd=null;function gd(){return null===vd&&new yd,vd}function bd(t,e,n,i,r){kd(),df.call(this,r),this.myLow_0=null,this.myMid_0=null,this.myHigh_0=null,this.myMidpoint_0=null,this.myLow_0=null!=t?t:kd().DEF_GRADIENT_LOW_0,this.myMid_0=null!=e?e:kd().DEF_GRADIENT_MID_0,this.myHigh_0=null!=n?n:kd().DEF_GRADIENT_HIGH_0,this.myMidpoint_0=null!=i?i:0}function wd(){xd=this,this.DEF_GRADIENT_LOW_0=R.Companion.parseHex_61zpoe$("#964540"),this.DEF_GRADIENT_MID_0=R.Companion.WHITE,this.DEF_GRADIENT_HIGH_0=R.Companion.parseHex_61zpoe$("#3B3D96")}md.$metadata$={kind:$,simpleName:"ColorBrewerMapperProvider",interfaces:[Hd]},bd.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r,o,a,s=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i),l=s.lowerEnd,c=S(this.myMidpoint_0),p=s.lowerEnd,h=new Q(l,X.max(c,p)),_=this.myMidpoint_0,f=s.upperEnd,d=new Q(X.min(_,f),s.upperEnd),m=Jf().gradient_e4qimg$(h,this.myLow_0,this.myMid_0,this.naValue),y=Jf().gradient_e4qimg$(d,this.myMid_0,this.myHigh_0,this.naValue),$=(a=Pn([$t(h,m),$t(d,y)]),r=function(t){var e,n=null;if(ot.SeriesUtil.isFinite_yrwdxb$(t)){var i=at.NaN;for(e=a.keys.iterator();e.hasNext();){var r=e.next();if(r.contains_mef7kx$(S(t))){var o=r.upperEnd-r.lowerEnd;(null==n||0===i||o0)&&(n=a.get_11rb$(r),i=o)}}}return n},o=this,function(t){var e,n=r(t);return null!=(e=null!=n?n(t):null)?e:o.naValue});return od().asContinuous_rjdepr$($)},wd.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var xd=null;function kd(){return null===xd&&new wd,xd}function Ed(t,e,n){Td(),Hd.call(this,n),this.low_0=null!=t?t:Jf().DEF_GRADIENT_LOW,this.high_0=null!=e?e:Jf().DEF_GRADIENT_HIGH}function Cd(){Sd=this,this.DEFAULT=new Ed(null,null,Jf().NA_VALUE)}bd.$metadata$={kind:$,simpleName:"ColorGradient2MapperProvider",interfaces:[df]},Ed.prototype.createDiscreteMapper_7f6uoc$=function(t){var e=u.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(t),n=S(ot.SeriesUtil.range_l63ks6$(e.values)),i=Jf().gradient_e4qimg$(n,this.low_0,this.high_0,this.naValue);return od().asNotContinuous_rjdepr$(i)},Ed.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i),o=Jf().gradient_e4qimg$(r,this.low_0,this.high_0,this.naValue);return od().asContinuous_rjdepr$(o)},Cd.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Sd=null;function Td(){return null===Sd&&new Cd,Sd}function Od(t,e,n,i,r,o){Ad(),Dd.call(this,o),this.myFromHSV_0=null,this.myToHSV_0=null,this.myHSVIntervals_0=null;var a,s=Ad().normalizeHueRange_0(t),l=null==r||-1!==r,u=l?s.lowerEnd:s.upperEnd,c=l?s.upperEnd:s.lowerEnd,p=null!=i?i:Ad().DEF_START_HUE_0,h=s.contains_mef7kx$(p)&&p-s.lowerEnd>1&&s.upperEnd-p>1?an([$t(p,c),$t(u,p)]):zt($t(u,c)),_=(null!=e?e%100:Ad().DEF_SATURATION_0)/100,f=(null!=n?n%100:Ad().DEF_VALUE_0)/100,d=y(m(h,10));for(a=h.iterator();a.hasNext();){var $=a.next();d.add_11rb$($t(new Pi($.first,_,f),new Pi($.second,_,f)))}this.myHSVIntervals_0=d,this.myFromHSV_0=new Pi(u,_,f),this.myToHSV_0=new Pi(c,_,f)}function Nd(){Pd=this,this.DEF_SATURATION_0=50,this.DEF_VALUE_0=90,this.DEF_START_HUE_0=0,this.DEF_HUE_RANGE_0=new Q(15,375),this.DEFAULT=new Od(null,null,null,null,null,R.Companion.GRAY)}Ed.$metadata$={kind:$,simpleName:"ColorGradientMapperProvider",interfaces:[Hd]},Od.prototype.createDiscreteMapper_7f6uoc$=function(t){return this.createDiscreteMapper_q8tf2k$(t,this.myFromHSV_0,this.myToHSV_0)},Od.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i);return this.createContinuousMapper_ytjjc$(r,this.myHSVIntervals_0)},Nd.prototype.normalizeHueRange_0=function(t){var e;if(null==t||2!==t.size)e=this.DEF_HUE_RANGE_0;else{var n=t.get_za3lpa$(0),i=t.get_za3lpa$(1),r=X.min(n,i),o=t.get_za3lpa$(0),a=t.get_za3lpa$(1);e=new Q(r,X.max(o,a))}return e},Nd.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Pd=null;function Ad(){return null===Pd&&new Nd,Pd}function jd(t,e){df.call(this,e),this.max_ks8piw$_0=t}function Ld(t,e,n){zd(),Dd.call(this,n),this.myFromHSV_0=null,this.myToHSV_0=null;var i=null!=t?t:zd().DEF_START_0,r=null!=e?e:zd().DEF_END_0;if(!Yi(0,1).contains_mef7kx$(i)){var o="Value of 'start' must be in range: [0,1]: "+f(t);throw G(o.toString())}if(!Yi(0,1).contains_mef7kx$(r)){var a="Value of 'end' must be in range: [0,1]: "+f(e);throw G(a.toString())}this.myFromHSV_0=new Pi(0,0,i),this.myToHSV_0=new Pi(0,0,r)}function Rd(){Id=this,this.DEF_START_0=.2,this.DEF_END_0=.8}Od.$metadata$={kind:$,simpleName:"ColorHueMapperProvider",interfaces:[Dd]},jd.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i).upperEnd;return od().continuousToContinuous_lww37m$(new Q(0,r),new Q(0,this.max_ks8piw$_0),this.naValue)},jd.$metadata$={kind:$,simpleName:"DirectlyProportionalMapperProvider",interfaces:[df]},Ld.prototype.createDiscreteMapper_7f6uoc$=function(t){return this.createDiscreteMapper_q8tf2k$(t,this.myFromHSV_0,this.myToHSV_0)},Ld.prototype.createContinuousMapper_1g0x2p$=function(t,e,n,i){var r=u.MapperUtil.rangeWithLimitsAfterTransform_1g0x2p$(t,e,n,i);return this.createContinuousMapper_ytjjc$(r,zt($t(this.myFromHSV_0,this.myToHSV_0)))},Rd.$metadata$={kind:l,simpleName:"Companion",interfaces:[]};var Id=null;function zd(){return null===Id&&new Rd,Id}function Dd(t){Ud(),Hd.call(this,t)}function Md(){Bd=this}Ld.$metadata$={kind:$,simpleName:"GreyscaleLightnessMapperProvider",interfaces:[Dd]},Dd.prototype.createDiscreteMapper_q8tf2k$=function(t,e,n){var i=u.MapperUtil.mapDiscreteDomainValuesToNumbers_7f6uoc$(t),r=ot.SeriesUtil.ensureApplicableRange_4am1sd$(ot.SeriesUtil.range_l63ks6$(i.values)),o=e.h,a=n.h;if(t.size>1){var s=n.h%360-e.h%360,l=X.abs(s),c=(n.h-e.h)/t.size;lthis.$outer.contentRect.right?At():null;break;case"VERTICAL":i=t.y>this.$outer.contentRect.bottom?Lt():t.ye.end()?t.move_14dthe$(e.end()-t.end()):t},re.prototype.centered_0=function(t,e){return rt.Companion.withStartAndLength_lu1900$(t-e/2,e)},re.prototype.leftAligned_0=function(t,e,n){return rt.Companion.withStartAndLength_lu1900$(t-e-n,e)},re.prototype.rightAligned_0=function(t,e,n){return rt.Companion.withStartAndLength_lu1900$(t+n,e)},re.prototype.centerInsideRange_0=function(t,e,n){return this.moveIntoLimit_a8bojh$(this.centered_0(t,e),n).start()},re.prototype.select_0=function(t,e){var n,i=O();for(n=t.iterator();n.hasNext();){var r=n.next();ut(e,r.hintKind_8be2vx$)&&i.add_11rb$(r)}return i},re.prototype.isOverlapped_0=function(t,e){var n;t:do{var i;for(i=t.iterator();i.hasNext();){var r=i.next();if(!M(r,e)&&r.rect_8be2vx$().intersects_wthzt5$(e.rect_8be2vx$())){n=r;break t}}n=null}while(0);return null!=n},re.prototype.withOverlapped_0=function(t,e){var n,i=O();for(n=e.iterator();n.hasNext();){var r=n.next();this.isOverlapped_0(t,r)&&i.add_11rb$(r)}var o=i;return et(st(t,e),o)},re.$metadata$={kind:ct,simpleName:"Companion",interfaces:[]};var oe=null;function ae(){return null===oe&&new re,oe}function se(t){ve(),this.myVerticalSpace_0=t}function le(){me(),this.myTopSpaceOk_0=null,this.myTopCursorOk_0=null,this.myBottomSpaceOk_0=null,this.myBottomCursorOk_0=null,this.myPreferredAlignment_0=null}function ue(t){return me().getBottomCursorOk_bd4p08$(t)}function ce(t){return me().getBottomSpaceOk_bd4p08$(t)}function pe(t){return me().getTopCursorOk_bd4p08$(t)}function he(t){return me().getTopSpaceOk_bd4p08$(t)}function _e(t){return me().getPreferredAlignment_bd4p08$(t)}function fe(){de=this}Gt.$metadata$={kind:w,simpleName:"LayoutManager",interfaces:[]},se.prototype.resolve_yatt61$=function(t,e,n,i){var r,o=(new le).topCursorOk_1v8dbw$(!t.overlaps_oqgc3u$(i)).topSpaceOk_1v8dbw$(t.inside_oqgc3u$(this.myVerticalSpace_0)).bottomCursorOk_1v8dbw$(!e.overlaps_oqgc3u$(i)).bottomSpaceOk_1v8dbw$(e.inside_oqgc3u$(this.myVerticalSpace_0)).preferredAlignment_tcfutp$(n);for(r=ve().PLACEMENT_MATCHERS_0.iterator();r.hasNext();){var a=r.next();if(a.first.match_bd4p08$(o))return a.second}throw E("Some matcher should match")},le.prototype.match_bd4p08$=function(t){return this.match_0(ue,t)&&this.match_0(ce,t)&&this.match_0(pe,t)&&this.match_0(he,t)&&this.match_0(_e,t)},le.prototype.topSpaceOk_1v8dbw$=function(t){return this.myTopSpaceOk_0=t,this},le.prototype.topCursorOk_1v8dbw$=function(t){return this.myTopCursorOk_0=t,this},le.prototype.bottomSpaceOk_1v8dbw$=function(t){return this.myBottomSpaceOk_0=t,this},le.prototype.bottomCursorOk_1v8dbw$=function(t){return this.myBottomCursorOk_0=t,this},le.prototype.preferredAlignment_tcfutp$=function(t){return this.myPreferredAlignment_0=t,this},le.prototype.match_0=function(t,e){var n;return null==(n=t(this))||M(n,t(e))},fe.prototype.getTopSpaceOk_bd4p08$=function(t){return t.myTopSpaceOk_0},fe.prototype.getTopCursorOk_bd4p08$=function(t){return t.myTopCursorOk_0},fe.prototype.getBottomSpaceOk_bd4p08$=function(t){return t.myBottomSpaceOk_0},fe.prototype.getBottomCursorOk_bd4p08$=function(t){return t.myBottomCursorOk_0},fe.prototype.getPreferredAlignment_bd4p08$=function(t){return t.myPreferredAlignment_0},fe.$metadata$={kind:ct,simpleName:"Companion",interfaces:[]};var de=null;function me(){return null===de&&new fe,de}function ye(){$e=this,this.PLACEMENT_MATCHERS_0=_t([this.rule_0((new le).preferredAlignment_tcfutp$(Vt()).topSpaceOk_1v8dbw$(!0).topCursorOk_1v8dbw$(!0),Vt()),this.rule_0((new le).preferredAlignment_tcfutp$(Kt()).bottomSpaceOk_1v8dbw$(!0).bottomCursorOk_1v8dbw$(!0),Kt()),this.rule_0((new le).preferredAlignment_tcfutp$(Vt()).topSpaceOk_1v8dbw$(!0).topCursorOk_1v8dbw$(!1).bottomSpaceOk_1v8dbw$(!0).bottomCursorOk_1v8dbw$(!0),Kt()),this.rule_0((new le).preferredAlignment_tcfutp$(Kt()).bottomSpaceOk_1v8dbw$(!0).bottomCursorOk_1v8dbw$(!1).topSpaceOk_1v8dbw$(!0).topCursorOk_1v8dbw$(!0),Vt()),this.rule_0((new le).topSpaceOk_1v8dbw$(!1),Kt()),this.rule_0((new le).bottomSpaceOk_1v8dbw$(!1),Vt()),this.rule_0(new le,Vt())])}le.$metadata$={kind:w,simpleName:"Matcher",interfaces:[]},ye.prototype.rule_0=function(t,e){return new ht(t,e)},ye.$metadata$={kind:ct,simpleName:"Companion",interfaces:[]};var $e=null;function ve(){return null===$e&&new ye,$e}function ge(t,e){ke(),this.verticalSpace_0=t,this.horizontalSpace_0=e}function be(t){this.myAttachToTooltipsTopOffset_0=null,this.myAttachToTooltipsBottomOffset_0=null,this.myAttachToTooltipsLeftOffset_0=null,this.myAttachToTooltipsRightOffset_0=null,this.myTooltipSize_0=t.tooltipSize_8be2vx$,this.myTargetCoord_0=t.stemCoord;var e=this.myTooltipSize_0.x/2,n=this.myTooltipSize_0.y/2;this.myAttachToTooltipsTopOffset_0=new $(-e,0),this.myAttachToTooltipsBottomOffset_0=new $(-e,-this.myTooltipSize_0.y),this.myAttachToTooltipsLeftOffset_0=new $(0,n),this.myAttachToTooltipsRightOffset_0=new $(-this.myTooltipSize_0.x,n)}function we(){xe=this,this.STEM_TO_LEFT_SIDE_ANGLE_RANGE_0=rt.Companion.withStartAndEnd_lu1900$(-1/4*dt.PI,1/4*dt.PI),this.STEM_TO_BOTTOM_SIDE_ANGLE_RANGE_0=rt.Companion.withStartAndEnd_lu1900$(1/4*dt.PI,3/4*dt.PI),this.STEM_TO_RIGHT_SIDE_ANGLE_RANGE_0=rt.Companion.withStartAndEnd_lu1900$(3/4*dt.PI,5/4*dt.PI),this.STEM_TO_TOP_SIDE_ANGLE_RANGE_0=rt.Companion.withStartAndEnd_lu1900$(5/4*dt.PI,7/4*dt.PI),this.SECTOR_COUNT_0=36,this.SECTOR_ANGLE_0=2*dt.PI/36,this.POINT_RESTRICTION_SIZE_0=new $(1,1)}se.$metadata$={kind:w,simpleName:"VerticalAlignmentResolver",interfaces:[]},ge.prototype.fixOverlapping_jhkzok$=function(t,e){for(var n,i=O(),r=0,o=t.size;rdt.PI&&(i-=dt.PI),n.add_11rb$(e.rotate_14dthe$(i)),r=r+1|0,i+=ke().SECTOR_ANGLE_0;return n},ge.prototype.intersectsAny_0=function(t,e){var n;for(n=e.iterator();n.hasNext();){var i=n.next();if(t.intersects_wthzt5$(i))return!0}return!1},ge.prototype.findValidCandidate_0=function(t,e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();if(!this.intersectsAny_0(i,e)&&rt.Companion.withStartAndLength_lu1900$(i.origin.y,i.dimension.y).inside_oqgc3u$(this.verticalSpace_0)&&rt.Companion.withStartAndLength_lu1900$(i.origin.x,i.dimension.x).inside_oqgc3u$(this.horizontalSpace_0))return i}return null},be.prototype.rotate_14dthe$=function(t){var e,n=mt.NORMAL.value,i=new $(n*X.cos(t),n*X.sin(t)).add_gpjtzr$(this.myTargetCoord_0);if(ke().STEM_TO_BOTTOM_SIDE_ANGLE_RANGE_0.contains_14dthe$(t))e=i.add_gpjtzr$(this.myAttachToTooltipsBottomOffset_0);else if(ke().STEM_TO_TOP_SIDE_ANGLE_RANGE_0.contains_14dthe$(t))e=i.add_gpjtzr$(this.myAttachToTooltipsTopOffset_0);else if(ke().STEM_TO_LEFT_SIDE_ANGLE_RANGE_0.contains_14dthe$(t))e=i.add_gpjtzr$(this.myAttachToTooltipsLeftOffset_0);else{if(!ke().STEM_TO_RIGHT_SIDE_ANGLE_RANGE_0.contains_14dthe$(t))throw yt();e=i.add_gpjtzr$(this.myAttachToTooltipsRightOffset_0)}return new v(e,this.myTooltipSize_0)},be.$metadata$={kind:w,simpleName:"TooltipRotationHelper",interfaces:[]},we.$metadata$={kind:ct,simpleName:"Companion",interfaces:[]};var xe=null;function ke(){return null===xe&&new we,xe}ge.$metadata$={kind:w,simpleName:"VerticalTooltipRotatingExpander",interfaces:[]};var Ee=t.jetbrains||(t.jetbrains={}),Ce=Ee.datalore||(Ee.datalore={}),Se=Ce.plot||(Ce.plot={}),Te=Se.builder||(Se.builder={});Te.PlotContainer=$t;var Oe=Te.interact||(Te.interact={});(Oe.render||(Oe.render={})).TooltipLayer=wt;var Ne=Te.tooltip||(Te.tooltip={});Ne.CrosshairComponent=xt,Object.defineProperty(Et,"VERTICAL",{get:St}),Object.defineProperty(Et,"HORIZONTAL",{get:Tt}),kt.Orientation=Et,Object.defineProperty(Ot,"LEFT",{get:Pt}),Object.defineProperty(Ot,"RIGHT",{get:At}),Object.defineProperty(Ot,"UP",{get:jt}),Object.defineProperty(Ot,"DOWN",{get:Lt}),kt.PointerDirection=Ot,Ne.TooltipBox=kt,zt.Group_init_xdl8vp$=Ut,zt.Group=Bt;var Pe=Ne.layout||(Ne.layout={});return Pe.HorizontalTooltipExpander=zt,Object.defineProperty(Ht,"TOP",{get:Vt}),Object.defineProperty(Ht,"BOTTOM",{get:Kt}),Gt.VerticalAlignment=Ht,Object.defineProperty(Wt,"LEFT",{get:Zt}),Object.defineProperty(Wt,"RIGHT",{get:Jt}),Object.defineProperty(Wt,"CENTER",{get:Qt}),Gt.HorizontalAlignment=Wt,Gt.PositionedTooltip_init_3c33xi$=ee,Gt.PositionedTooltip=te,Gt.MeasuredTooltip_init_eds8ux$=ie,Gt.MeasuredTooltip=ne,Object.defineProperty(Gt,"Companion",{get:ae}),Pe.LayoutManager=Gt,Object.defineProperty(le,"Companion",{get:me}),se.Matcher=le,Object.defineProperty(se,"Companion",{get:ve}),Pe.VerticalAlignmentResolver=se,ge.TooltipRotationHelper=be,Object.defineProperty(ge,"Companion",{get:ke}),Pe.VerticalTooltipRotatingExpander=ge,t})?i.apply(e,r):i)||(t.exports=o)},958:function(t,e,n){var i,r,o;r=[e,n(421),n(767)],void 0===(o="function"==typeof(i=function(t,e,n){"use strict";var i,r,o,a,s,l,u,c,p,h,_,f,d,m,y,$,v,g,b,w,x,k,E,C,S,T,O,N,P,A,j,L,R,I,z,D,M,B,U=e.kotlin.Enum,F=e.Kind.CLASS,q=e.throwISE,G=e.Kind.OBJECT,H=Math,Y=e.Kind.INTERFACE,V=e.kotlin.collections.ArrayList_init_287e2$,K=e.kotlin.collections.ArrayList_init_ww73n8$,W=n.jetbrains.datalore.base.values.Color,X=n.jetbrains.datalore.base.gcommon.collect,Z=e.kotlin.Exception,J=e.throwCCE,Q=e.kotlin.collections.setOf_i5x0yv$,tt=e.kotlin.collections.HashMap_init_q3lmfv$,et=e.numberToInt,nt=e.ensureNotNull,it=n.jetbrains.datalore.base.gcommon.collect.ClosedRange,rt=n.jetbrains.datalore.base.gcommon.collect.Ordering,ot=e.kotlin.isFinite_yrwdxr$,at=e.kotlin.IllegalStateException_init_pdl1vj$,st=e.kotlin.collections.take_ba2ldo$,lt=e.kotlin.collections.toList_7wnvza$,ut=e.kotlin.collections.List,ct=e.kotlin.collections.listOf_i5x0yv$,pt=e.kotlin.collections.Iterable,ht=e.kotlin.isInfinite_yrwdxr$,_t=e.equals,ft=e.kotlin.collections.contains_2ws7j4$,dt=e.kotlin.IllegalArgumentException_init_pdl1vj$,mt=n.jetbrains.datalore.base.gcommon.collect.Stack,yt=e.kotlin.js.internal.DoubleCompanionObject,$t=n.jetbrains.datalore.base.values.Pair,vt=n.jetbrains.datalore.base.geometry.DoubleSegment,gt=e.kotlin.ranges.until_dqglrj$,bt=e.kotlin.isNaN_yrwdxr$,wt=e.kotlin.comparisons.reversed_2avth4$,xt=e.kotlin.collections.sortedWith_eknfly$,kt=e.kotlin.collections.sorted_exjks8$,Et=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,Ct=e.wrapFunction,St=e.kotlin.Comparator,Tt=e.kotlin.collections.binarySearch_vikexg$,Ot=n.jetbrains.datalore.base.dateFormat.Format_init_61zpoe$,Nt=e.numberToLong,Pt=n.jetbrains.datalore.base.datetime.Instant,At=e.getCallableRef,jt=n.jetbrains.datalore.base.datetime.tz.TimeZone,Lt=n.jetbrains.datalore.base.numberFormat.NumberFormat_init_61zpoe$,Rt=e.kotlin.math.roundToLong_yrwdxr$,It=e.kotlin.RuntimeException,zt=n.jetbrains.datalore.base.datetime.Date,Dt=n.jetbrains.datalore.base.datetime.DateTime,Mt=n.jetbrains.datalore.base.datetime.Duration,Bt=e.kotlin.RuntimeException_init_pdl1vj$,Ut=n.jetbrains.datalore.base.datetime.Month,Ft=e.kotlin.UnsupportedOperationException_init,qt=e.kotlin.text.startsWith_7epoxm$,Gt=e.kotlin.text.toInt_pdl1vz$,Ht=e.kotlin.NumberFormatException;function Yt(){Fe=this,this.MIN_COLOR_SET_SIZE_0=3}function Vt(t,e,n){U.call(this),this.myPresentation_6glhnl$_0=n,this.name$=t,this.ordinal$=e}function Kt(){Kt=function(){},i=new Vt("SEQUENTIAL",0,"sequential"),r=new Vt("DIVERGING",1,"diverging"),o=new Vt("QUALITATIVE",2,"qualitative")}function Wt(){return Kt(),i}function Xt(){return Kt(),r}function Zt(){return Kt(),o}function Jt(t,e,n,i){U.call(this),this.myPresentation_w2uxp8$_0=n,this.colorSet_b1v09h$_0=i,this.name$=t,this.ordinal$=e}function Qt(){Qt=function(){},a=new Jt("Blues",0,"blues",Ve().BLUES),s=new Jt("BuGn",1,"blue-green",Ve().BU_GN),l=new Jt("BuPu",2,"blue-purple",Ve().BU_PU),u=new Jt("GnBu",3,"green-blue",Ve().GN_BU),c=new Jt("Greens",4,"greens",Ve().GREENS),p=new Jt("Greys",5,"greys",Ve().GREYS),h=new Jt("Oranges",6,"oranges",Ve().ORANGES),_=new Jt("OrRd",7,"orange-red",Ve().OR_RD),f=new Jt("PuBu",8,"purple-blue",Ve().PU_BU),d=new Jt("PuBuGn",9,"purple-blue-green",Ve().PU_BU_GN),m=new Jt("PuRd",10,"purple-red",Ve().PU_RD),y=new Jt("Purples",11,"purples",Ve().PURPLES),$=new Jt("RdPu",12,"red-purple",Ve().RD_PU),v=new Jt("Reds",13,"reds",Ve().REDS),g=new Jt("YlGn",14,"yellow-green",Ve().YL_GN),b=new Jt("YlGnBu",15,"yellow-green-blue",Ve().YL_GN_BU),w=new Jt("YlOrBr",16,"yellow-orange-brown",Ve().YL_OR_BR),x=new Jt("YlOrRd",17,"yellow-orange-red",Ve().YL_OR_RD)}function te(){return Qt(),a}function ee(){return Qt(),s}function ne(){return Qt(),l}function ie(){return Qt(),u}function re(){return Qt(),c}function oe(){return Qt(),p}function ae(){return Qt(),h}function se(){return Qt(),_}function le(){return Qt(),f}function ue(){return Qt(),d}function ce(){return Qt(),m}function pe(){return Qt(),y}function he(){return Qt(),$}function _e(){return Qt(),v}function fe(){return Qt(),g}function de(){return Qt(),b}function me(){return Qt(),w}function ye(){return Qt(),x}function $e(){return[te(),ee(),ne(),ie(),re(),oe(),ae(),se(),le(),ue(),ce(),pe(),he(),_e(),fe(),de(),me(),ye()]}function ve(t,e,n,i){U.call(this),this.myPresentation_im16qo$_0=n,this.colorSet_las6nb$_0=i,this.name$=t,this.ordinal$=e}function ge(){ge=function(){},k=new ve("BrBG",0,"brown-blue/green",Ve().BR_BG),E=new ve("PiYG",1,"pink-yellow/green",Ve().PI_YG),C=new ve("PRGn",2,"purple/red-green",Ve().PR_GN),S=new ve("PuOr",3,"purple-orange",Ve().PU_OR),T=new ve("RdBu",4,"red-blue",Ve().RD_BU),O=new ve("RdGy",5,"red-grey",Ve().RD_GY),N=new ve("RdYlBu",6,"red-yellow-blue",Ve().RD_YL_BU),P=new ve("RdYlGn",7,"red-yellow-green",Ve().RD_YL_GN),A=new ve("Spectral",8,"spectral",Ve().SPECTRAL)}function be(){return ge(),k}function we(){return ge(),E}function xe(){return ge(),C}function ke(){return ge(),S}function Ee(){return ge(),T}function Ce(){return ge(),O}function Se(){return ge(),N}function Te(){return ge(),P}function Oe(){return ge(),A}function Ne(){return[be(),we(),xe(),ke(),Ee(),Ce(),Se(),Te(),Oe()]}function Pe(t,e,n,i){U.call(this),this.myPresentation_av4sq6$_0=n,this.colorSet_cgz7kp$_0=i,this.name$=t,this.ordinal$=e}function Ae(){Ae=function(){},j=new Pe("Accent",0,"accent",Ve().ACCENT),L=new Pe("Dark2",1,"dark 2",Ve().DARK_2),R=new Pe("Paired",2,"paired",Ve().PAIRED),I=new Pe("Pastel1",3,"pastel 1",Ve().PASTEL_1),z=new Pe("Pastel2",4,"pastel 2",Ve().PASTEL_2),D=new Pe("Set1",5,"set 1",Ve().SET_1),M=new Pe("Set2",6,"set 2",Ve().SET_2),B=new Pe("Set3",7,"set 3",Ve().SET_3)}function je(){return Ae(),j}function Le(){return Ae(),L}function Re(){return Ae(),R}function Ie(){return Ae(),I}function ze(){return Ae(),z}function De(){return Ae(),D}function Me(){return Ae(),M}function Be(){return Ae(),B}function Ue(){return[je(),Le(),Re(),Ie(),ze(),De(),Me(),Be()]}Vt.prototype=Object.create(U.prototype),Vt.prototype.constructor=Vt,Jt.prototype=Object.create(U.prototype),Jt.prototype.constructor=Jt,ve.prototype=Object.create(U.prototype),ve.prototype.constructor=ve,Pe.prototype=Object.create(U.prototype),Pe.prototype.constructor=Pe,on.prototype=Object.create(rn.prototype),on.prototype.constructor=on,an.prototype=Object.create(rn.prototype),an.prototype.constructor=an,ln.prototype=Object.create(rn.prototype),ln.prototype.constructor=ln,hn.prototype=Object.create(_n.prototype),hn.prototype.constructor=hn,Yn.prototype=Object.create(ii.prototype),Yn.prototype.constructor=Yn,Vn.prototype=Object.create(ii.prototype),Vn.prototype.constructor=Vn,Kn.prototype=Object.create(Vn.prototype),Kn.prototype.constructor=Kn,Zn.prototype=Object.create(ii.prototype),Zn.prototype.constructor=Zn,Jn.prototype=Object.create(ii.prototype),Jn.prototype.constructor=Jn,si.prototype=Object.create(Vn.prototype),si.prototype.constructor=si,Yt.prototype.colors_0=function(t,e){var n=e,i=n;n=H.max(3,i);var r=t.maxColors,o=n;return n=H.min(r,o),t.colorSet[n-3|0]},Yt.prototype.maxColorSetSize_0=function(t){var e=t.colorSet;return e[e.length-1|0].length},Vt.prototype.toString=function(){return this.myPresentation_6glhnl$_0},Vt.$metadata$={kind:F,simpleName:"Type",interfaces:[U]},Vt.values=function(){return[Wt(),Xt(),Zt()]},Vt.valueOf_61zpoe$=function(t){switch(t){case"SEQUENTIAL":return Wt();case"DIVERGING":return Xt();case"QUALITATIVE":return Zt();default:q("No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Type."+t)}},Object.defineProperty(Jt.prototype,"colorSet",{get:function(){return this.colorSet_b1v09h$_0}}),Object.defineProperty(Jt.prototype,"type",{configurable:!0,get:function(){return Wt()}}),Object.defineProperty(Jt.prototype,"maxColors",{configurable:!0,get:function(){return qe().maxColorSetSize_0(this)}}),Jt.prototype.getColors_za3lpa$=function(t){return qe().colors_0(this,t)},Jt.prototype.toString=function(){return this.myPresentation_w2uxp8$_0},Jt.$metadata$={kind:F,simpleName:"Sequential",interfaces:[Ge,U]},Jt.values=$e,Jt.valueOf_61zpoe$=function(t){switch(t){case"Blues":return te();case"BuGn":return ee();case"BuPu":return ne();case"GnBu":return ie();case"Greens":return re();case"Greys":return oe();case"Oranges":return ae();case"OrRd":return se();case"PuBu":return le();case"PuBuGn":return ue();case"PuRd":return ce();case"Purples":return pe();case"RdPu":return he();case"Reds":return _e();case"YlGn":return fe();case"YlGnBu":return de();case"YlOrBr":return me();case"YlOrRd":return ye();default:q("No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Sequential."+t)}},Object.defineProperty(ve.prototype,"colorSet",{get:function(){return this.colorSet_las6nb$_0}}),Object.defineProperty(ve.prototype,"type",{configurable:!0,get:function(){return Xt()}}),Object.defineProperty(ve.prototype,"maxColors",{configurable:!0,get:function(){return qe().maxColorSetSize_0(this)}}),ve.prototype.getColors_za3lpa$=function(t){return qe().colors_0(this,t)},ve.prototype.toString=function(){return this.myPresentation_im16qo$_0},ve.$metadata$={kind:F,simpleName:"Diverging",interfaces:[Ge,U]},ve.values=Ne,ve.valueOf_61zpoe$=function(t){switch(t){case"BrBG":return be();case"PiYG":return we();case"PRGn":return xe();case"PuOr":return ke();case"RdBu":return Ee();case"RdGy":return Ce();case"RdYlBu":return Se();case"RdYlGn":return Te();case"Spectral":return Oe();default:q("No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Diverging."+t)}},Object.defineProperty(Pe.prototype,"colorSet",{get:function(){return this.colorSet_cgz7kp$_0}}),Object.defineProperty(Pe.prototype,"type",{configurable:!0,get:function(){return Zt()}}),Object.defineProperty(Pe.prototype,"maxColors",{configurable:!0,get:function(){return qe().maxColorSetSize_0(this)}}),Pe.prototype.getColors_za3lpa$=function(t){return qe().colors_0(this,t)},Pe.prototype.toString=function(){return this.myPresentation_av4sq6$_0},Pe.$metadata$={kind:F,simpleName:"Qualitative",interfaces:[Ge,U]},Pe.values=Ue,Pe.valueOf_61zpoe$=function(t){switch(t){case"Accent":return je();case"Dark2":return Le();case"Paired":return Re();case"Pastel1":return Ie();case"Pastel2":return ze();case"Set1":return De();case"Set2":return Me();case"Set3":return Be();default:q("No enum constant jetbrains.datalore.plot.common.color.ColorPalette.Qualitative."+t)}},Yt.$metadata$={kind:G,simpleName:"ColorPalette",interfaces:[]};var Fe=null;function qe(){return null===Fe&&new Yt,Fe}function Ge(){}function He(){Ye=this,this.BU_GN_3=["#e5f5f9","#99d8c9","#2ca25f"],this.BU_GN_4=["#edf8fb","#b2e2e2","#66c2a4","#238b45"],this.BU_GN_5=["#edf8fb","#b2e2e2","#66c2a4","#2ca25f","#006d2c"],this.BU_GN_6=["#edf8fb","#ccece6","#99d8c9","#66c2a4","#2ca25f","#006d2c"],this.BU_GN_7=["#edf8fb","#ccece6","#99d8c9","#66c2a4","#41ae76","#238b45","#005824"],this.BU_GN_8=["#f7fcfd","#e5f5f9","#ccece6","#99d8c9","#66c2a4","#41ae76","#238b45","#005824"],this.BU_GN_9=["#f7fcfd","#e5f5f9","#ccece6","#99d8c9","#66c2a4","#41ae76","#238b45","#006d2c","#00441b"],this.BU_PU_3=["#e0ecf4","#9ebcda","#8856a7"],this.BU_PU_4=["#edf8fb","#b3cde3","#8c96c6","#88419d"],this.BU_PU_5=["#edf8fb","#b3cde3","#8c96c6","#8856a7","#810f7c"],this.BU_PU_6=["#edf8fb","#bfd3e6","#9ebcda","#8c96c6","#8856a7","#810f7c"],this.BU_PU_7=["#edf8fb","#bfd3e6","#9ebcda","#8c96c6","#8c6bb1","#88419d","#6e016b"],this.BU_PU_8=["#f7fcfd","#e0ecf4","#bfd3e6","#9ebcda","#8c96c6","#8c6bb1","#88419d","#6e016b"],this.BU_PU_9=["#f7fcfd","#e0ecf4","#bfd3e6","#9ebcda","#8c96c6","#8c6bb1","#88419d","#810f7c","#4d004b"],this.GN_BU_3=["#e0f3db","#a8ddb5","#43a2ca"],this.GN_BU_4=["#f0f9e8","#bae4bc","#7bccc4","#2b8cbe"],this.GN_BU_5=["#f0f9e8","#bae4bc","#7bccc4","#43a2ca","#0868ac"],this.GN_BU_6=["#f0f9e8","#ccebc5","#a8ddb5","#7bccc4","#43a2ca","#0868ac"],this.GN_BU_7=["#f0f9e8","#ccebc5","#a8ddb5","#7bccc4","#4eb3d3","#2b8cbe","#08589e"],this.GN_BU_8=["#f7fcf0","#e0f3db","#ccebc5","#a8ddb5","#7bccc4","#4eb3d3","#2b8cbe","#08589e"],this.GN_BU_9=["#f7fcf0","#e0f3db","#ccebc5","#a8ddb5","#7bccc4","#4eb3d3","#2b8cbe","#0868ac","#084081"],this.OR_RD_3=["#fee8c8","#fdbb84","#e34a33"],this.OR_RD_4=["#fef0d9","#fdcc8a","#fc8d59","#d7301f"],this.OR_RD_5=["#fef0d9","#fdcc8a","#fc8d59","#e34a33","#b30000"],this.OR_RD_6=["#fef0d9","#fdd49e","#fdbb84","#fc8d59","#e34a33","#b30000"],this.OR_RD_7=["#fef0d9","#fdd49e","#fdbb84","#fc8d59","#ef6548","#d7301f","#990000"],this.OR_RD_8=["#fff7ec","#fee8c8","#fdd49e","#fdbb84","#fc8d59","#ef6548","#d7301f","#990000"],this.OR_RD_9=["#fff7ec","#fee8c8","#fdd49e","#fdbb84","#fc8d59","#ef6548","#d7301f","#b30000","#7f0000"],this.PU_BU_3=["#ece7f2","#a6bddb","#2b8cbe"],this.PU_BU_4=["#f1eef6","#bdc9e1","#74a9cf","#0570b0"],this.PU_BU_5=["#f1eef6","#bdc9e1","#74a9cf","#2b8cbe","#045a8d"],this.PU_BU_6=["#f1eef6","#d0d1e6","#a6bddb","#74a9cf","#2b8cbe","#045a8d"],this.PU_BU_7=["#f1eef6","#d0d1e6","#a6bddb","#74a9cf","#3690c0","#0570b0","#034e7b"],this.PU_BU_8=["#fff7fb","#ece7f2","#d0d1e6","#a6bddb","#74a9cf","#3690c0","#0570b0","#034e7b"],this.PU_BU_9=["#fff7fb","#ece7f2","#d0d1e6","#a6bddb","#74a9cf","#3690c0","#0570b0","#045a8d","#023858"],this.PU_BU_GN_3=["#ece2f0","#a6bddb","#1c9099"],this.PU_BU_GN_4=["#f6eff7","#bdc9e1","#67a9cf","#02818a"],this.PU_BU_GN_5=["#f6eff7","#bdc9e1","#67a9cf","#1c9099","#016c59"],this.PU_BU_GN_6=["#f6eff7","#d0d1e6","#a6bddb","#67a9cf","#1c9099","#016c59"],this.PU_BU_GN_7=["#f6eff7","#d0d1e6","#a6bddb","#67a9cf","#3690c0","#02818a","#016450"],this.PU_BU_GN_8=["#fff7fb","#ece2f0","#d0d1e6","#a6bddb","#67a9cf","#3690c0","#02818a","#016450"],this.PU_BU_GN_9=["#fff7fb","#ece2f0","#d0d1e6","#a6bddb","#67a9cf","#3690c0","#02818a","#016c59","#014636"],this.PU_RD_3=["#e7e1ef","#c994c7","#dd1c77"],this.PU_RD_4=["#f1eef6","#d7b5d8","#df65b0","#ce1256"],this.PU_RD_5=["#f1eef6","#d7b5d8","#df65b0","#dd1c77","#980043"],this.PU_RD_6=["#f1eef6","#d4b9da","#c994c7","#df65b0","#dd1c77","#980043"],this.PU_RD_7=["#f1eef6","#d4b9da","#c994c7","#df65b0","#e7298a","#ce1256","#91003f"],this.PU_RD_8=["#f7f4f9","#e7e1ef","#d4b9da","#c994c7","#df65b0","#e7298a","#ce1256","#91003f"],this.PU_RD_9=["#f7f4f9","#e7e1ef","#d4b9da","#c994c7","#df65b0","#e7298a","#ce1256","#980043","#67001f"],this.RD_PU_3=["#fde0dd","#fa9fb5","#c51b8a"],this.RD_PU_4=["#feebe2","#fbb4b9","#f768a1","#ae017e"],this.RD_PU_5=["#feebe2","#fbb4b9","#f768a1","#c51b8a","#7a0177"],this.RD_PU_6=["#feebe2","#fcc5c0","#fa9fb5","#f768a1","#c51b8a","#7a0177"],this.RD_PU_7=["#feebe2","#fcc5c0","#fa9fb5","#f768a1","#dd3497","#ae017e","#7a0177"],this.RD_PU_8=["#fff7f3","#fde0dd","#fcc5c0","#fa9fb5","#f768a1","#dd3497","#ae017e","#7a0177"],this.RD_PU_9=["#fff7f3","#fde0dd","#fcc5c0","#fa9fb5","#f768a1","#dd3497","#ae017e","#7a0177","#49006a"],this.YL_GN_3=["#f7fcb9","#addd8e","#31a354"],this.YL_GN_4=["#ffffcc","#c2e699","#78c679","#238443"],this.YL_GN_5=["#ffffcc","#c2e699","#78c679","#31a354","#006837"],this.YL_GN_6=["#ffffcc","#d9f0a3","#addd8e","#78c679","#31a354","#006837"],this.YL_GN_7=["#ffffcc","#d9f0a3","#addd8e","#78c679","#41ab5d","#238443","#005a32"],this.YL_GN_8=["#ffffe5","#f7fcb9","#d9f0a3","#addd8e","#78c679","#41ab5d","#238443","#005a32"],this.YL_GN_9=["#ffffe5","#f7fcb9","#d9f0a3","#addd8e","#78c679","#41ab5d","#238443","#006837","#004529"],this.YL_GN_BU_3=["#edf8b1","#7fcdbb","#2c7fb8"],this.YL_GN_BU_4=["#ffffcc","#a1dab4","#41b6c4","#225ea8"],this.YL_GN_BU_5=["#ffffcc","#a1dab4","#41b6c4","#2c7fb8","#253494"],this.YL_GN_BU_6=["#ffffcc","#c7e9b4","#7fcdbb","#41b6c4","#2c7fb8","#253494"],this.YL_GN_BU_7=["#ffffcc","#c7e9b4","#7fcdbb","#41b6c4","#1d91c0","#225ea8","#0c2c84"],this.YL_GN_BU_8=["#ffffd9","#edf8b1","#c7e9b4","#7fcdbb","#41b6c4","#1d91c0","#225ea8","#0c2c84"],this.YL_GN_BU_9=["#ffffd9","#edf8b1","#c7e9b4","#7fcdbb","#41b6c4","#1d91c0","#225ea8","#253494","#081d58"],this.YL_OR_BR_3=["#fff7bc","#fec44f","#d95f0e"],this.YL_OR_BR_4=["#ffffd4","#fed98e","#fe9929","#cc4c02"],this.YL_OR_BR_5=["#ffffd4","#fed98e","#fe9929","#d95f0e","#993404"],this.YL_OR_BR_6=["#ffffd4","#fee391","#fec44f","#fe9929","#d95f0e","#993404"],this.YL_OR_BR_7=["#ffffd4","#fee391","#fec44f","#fe9929","#ec7014","#cc4c02","#8c2d04"],this.YL_OR_BR_8=["#ffffe5","#fff7bc","#fee391","#fec44f","#fe9929","#ec7014","#cc4c02","#8c2d04"],this.YL_OR_BR_9=["#ffffe5","#fff7bc","#fee391","#fec44f","#fe9929","#ec7014","#cc4c02","#993404","#662506"],this.YL_OR_RD_3=["#ffeda0","#feb24c","#f03b20"],this.YL_OR_RD_4=["#ffffb2","#fecc5c","#fd8d3c","#e31a1c"],this.YL_OR_RD_5=["#ffffb2","#fecc5c","#fd8d3c","#f03b20","#bd0026"],this.YL_OR_RD_6=["#ffffb2","#fed976","#feb24c","#fd8d3c","#f03b20","#bd0026"],this.YL_OR_RD_7=["#ffffb2","#fed976","#feb24c","#fd8d3c","#fc4e2a","#e31a1c","#b10026"],this.YL_OR_RD_8=["#ffffcc","#ffeda0","#fed976","#feb24c","#fd8d3c","#fc4e2a","#e31a1c","#b10026"],this.YL_OR_RD_9=["#ffffcc","#ffeda0","#fed976","#feb24c","#fd8d3c","#fc4e2a","#e31a1c","#bd0026","#800026"],this.BU_GN=[this.BU_GN_3,this.BU_GN_4,this.BU_GN_5,this.BU_GN_6,this.BU_GN_7,this.BU_GN_8,this.BU_GN_9],this.BU_PU=[this.BU_PU_3,this.BU_PU_4,this.BU_PU_5,this.BU_PU_6,this.BU_PU_7,this.BU_PU_8,this.BU_PU_9],this.GN_BU=[this.GN_BU_3,this.GN_BU_4,this.GN_BU_5,this.GN_BU_6,this.GN_BU_7,this.GN_BU_8,this.GN_BU_9],this.OR_RD=[this.OR_RD_3,this.OR_RD_4,this.OR_RD_5,this.OR_RD_6,this.OR_RD_7,this.OR_RD_8,this.OR_RD_9],this.PU_BU=[this.PU_BU_3,this.PU_BU_4,this.PU_BU_5,this.PU_BU_6,this.PU_BU_7,this.PU_BU_8,this.PU_BU_9],this.PU_BU_GN=[this.PU_BU_GN_3,this.PU_BU_GN_4,this.PU_BU_GN_5,this.PU_BU_GN_6,this.PU_BU_GN_7,this.PU_BU_GN_8,this.PU_BU_GN_9],this.PU_RD=[this.PU_RD_3,this.PU_RD_4,this.PU_RD_5,this.PU_RD_6,this.PU_RD_7,this.PU_RD_8,this.PU_RD_9],this.RD_PU=[this.RD_PU_3,this.RD_PU_4,this.RD_PU_5,this.RD_PU_6,this.RD_PU_7,this.RD_PU_8,this.RD_PU_9],this.YL_GN=[this.YL_GN_3,this.YL_GN_4,this.YL_GN_5,this.YL_GN_6,this.YL_GN_7,this.YL_GN_8,this.YL_GN_9],this.YL_GN_BU=[this.YL_GN_BU_3,this.YL_GN_BU_4,this.YL_GN_BU_5,this.YL_GN_BU_6,this.YL_GN_BU_7,this.YL_GN_BU_8,this.YL_GN_BU_9],this.YL_OR_BR=[this.YL_OR_BR_3,this.YL_OR_BR_4,this.YL_OR_BR_5,this.YL_OR_BR_6,this.YL_OR_BR_7,this.YL_OR_BR_8,this.YL_OR_BR_9],this.YL_OR_RD=[this.YL_OR_RD_3,this.YL_OR_RD_4,this.YL_OR_RD_5,this.YL_OR_RD_6,this.YL_OR_RD_7,this.YL_OR_RD_8,this.YL_OR_RD_9],this.BLUES_3=["#deebf7","#9ecae1","#3182bd"],this.BLUES_4=["#eff3ff","#bdd7e7","#6baed6","#2171b5"],this.BLUES_5=["#eff3ff","#bdd7e7","#6baed6","#3182bd","#08519c"],this.BLUES_6=["#eff3ff","#c6dbef","#9ecae1","#6baed6","#3182bd","#08519c"],this.BLUES_7=["#eff3ff","#c6dbef","#9ecae1","#6baed6","#4292c6","#2171b5","#084594"],this.BLUES_8=["#f7fbff","#deebf7","#c6dbef","#9ecae1","#6baed6","#4292c6","#2171b5","#084594"],this.BLUES_9=["#f7fbff","#deebf7","#c6dbef","#9ecae1","#6baed6","#4292c6","#2171b5","#08519c","#08306b"],this.GREENS_3=["#e5f5e0","#a1d99b","#31a354"],this.GREENS_4=["#edf8e9","#bae4b3","#74c476","#238b45"],this.GREENS_5=["#edf8e9","#bae4b3","#74c476","#31a354","#006d2c"],this.GREENS_6=["#edf8e9","#c7e9c0","#a1d99b","#74c476","#31a354","#006d2c"],this.GREENS_7=["#edf8e9","#c7e9c0","#a1d99b","#74c476","#41ab5d","#238b45","#005a32"],this.GREENS_8=["#f7fcf5","#e5f5e0","#c7e9c0","#a1d99b","#74c476","#41ab5d","#238b45","#005a32"],this.GREENS_9=["#f7fcf5","#e5f5e0","#c7e9c0","#a1d99b","#74c476","#41ab5d","#238b45","#006d2c","#00441b"],this.GREYS_3=["#f0f0f0","#bdbdbd","#636363"],this.GREYS_4=["#f7f7f7","#cccccc","#969696","#525252"],this.GREYS_5=["#f7f7f7","#cccccc","#969696","#636363","#252525"],this.GREYS_6=["#f7f7f7","#d9d9d9","#bdbdbd","#969696","#636363","#252525"],this.GREYS_7=["#f7f7f7","#d9d9d9","#bdbdbd","#969696","#737373","#525252","#252525"],this.GREYS_8=["#ffffff","#f0f0f0","#d9d9d9","#bdbdbd","#969696","#737373","#525252","#252525"],this.GREYS_9=["#ffffff","#f0f0f0","#d9d9d9","#bdbdbd","#969696","#737373","#525252","#252525","#000000"],this.ORANGES_3=["#fee6ce","#fdae6b","#e6550d"],this.ORANGES_4=["#feedde","#fdbe85","#fd8d3c","#d94701"],this.ORANGES_5=["#feedde","#fdbe85","#fd8d3c","#e6550d","#a63603"],this.ORANGES_6=["#feedde","#fdd0a2","#fdae6b","#fd8d3c","#e6550d","#a63603"],this.ORANGES_7=["#feedde","#fdd0a2","#fdae6b","#fd8d3c","#f16913","#d94801","#8c2d04"],this.ORANGES_8=["#fff5eb","#fee6ce","#fdd0a2","#fdae6b","#fd8d3c","#f16913","#d94801","#8c2d04"],this.ORANGES_9=["#fff5eb","#fee6ce","#fdd0a2","#fdae6b","#fd8d3c","#f16913","#d94801","#a63603","#7f2704"],this.PURPLES_3=["#efedf5","#bcbddc","#756bb1"],this.PURPLES_4=["#f2f0f7","#cbc9e2","#9e9ac8","#6a51a3"],this.PURPLES_5=["#f2f0f7","#cbc9e2","#9e9ac8","#756bb1","#54278f"],this.PURPLES_6=["#f2f0f7","#dadaeb","#bcbddc","#9e9ac8","#756bb1","#54278f"],this.PURPLES_7=["#f2f0f7","#dadaeb","#bcbddc","#9e9ac8","#807dba","#6a51a3","#4a1486"],this.PURPLES_8=["#fcfbfd","#efedf5","#dadaeb","#bcbddc","#9e9ac8","#807dba","#6a51a3","#4a1486"],this.PURPLES_9=["#fcfbfd","#efedf5","#dadaeb","#bcbddc","#9e9ac8","#807dba","#6a51a3","#54278f","#3f007d"],this.REDS_3=["#fee0d2","#fc9272","#de2d26"],this.REDS_4=["#fee5d9","#fcae91","#fb6a4a","#cb181d"],this.REDS_5=["#fee5d9","#fcae91","#fb6a4a","#de2d26","#a50f15"],this.REDS_6=["#fee5d9","#fcbba1","#fc9272","#fb6a4a","#de2d26","#a50f15"],this.REDS_7=["#fee5d9","#fcbba1","#fc9272","#fb6a4a","#ef3b2c","#cb181d","#99000d"],this.REDS_8=["#fff5f0","#fee0d2","#fcbba1","#fc9272","#fb6a4a","#ef3b2c","#cb181d","#99000d"],this.REDS_9=["#fff5f0","#fee0d2","#fcbba1","#fc9272","#fb6a4a","#ef3b2c","#cb181d","#a50f15","#67000d"],this.BLUES=[this.BLUES_3,this.BLUES_4,this.BLUES_5,this.BLUES_6,this.BLUES_7,this.BLUES_8,this.BLUES_9],this.GREENS=[this.GREENS_3,this.GREENS_4,this.GREENS_5,this.GREENS_6,this.GREENS_7,this.GREENS_8,this.GREENS_9],this.GREYS=[this.GREYS_3,this.GREYS_4,this.GREYS_5,this.GREYS_6,this.GREYS_7,this.GREYS_8,this.GREYS_9],this.ORANGES=[this.ORANGES_3,this.ORANGES_4,this.ORANGES_5,this.ORANGES_6,this.ORANGES_7,this.ORANGES_8,this.ORANGES_9],this.PURPLES=[this.PURPLES_3,this.PURPLES_4,this.PURPLES_5,this.PURPLES_6,this.PURPLES_7,this.PURPLES_8,this.PURPLES_9],this.REDS=[this.REDS_3,this.REDS_4,this.REDS_5,this.REDS_6,this.REDS_7,this.REDS_8,this.REDS_9],this.BR_BG_3=["#d8b365","#f5f5f5","#5ab4ac"],this.BR_BG_4=["#a6611a","#dfc27d","#80cdc1","#018571"],this.BR_BG_5=["#a6611a","#dfc27d","#f5f5f5","#80cdc1","#018571"],this.BR_BG_6=["#8c510a","#d8b365","#f6e8c3","#c7eae5","#5ab4ac","#01665e"],this.BR_BG_7=["#8c510a","#d8b365","#f6e8c3","#f5f5f5","#c7eae5","#5ab4ac","#01665e"],this.BR_BG_8=["#8c510a","#bf812d","#dfc27d","#f6e8c3","#c7eae5","#80cdc1","#35978f","#01665e"],this.BR_BG_9=["#8c510a","#bf812d","#dfc27d","#f6e8c3","#f5f5f5","#c7eae5","#80cdc1","#35978f","#01665e"],this.BR_BG_10=["#543005","#8c510a","#bf812d","#dfc27d","#f6e8c3","#c7eae5","#80cdc1","#35978f","#01665e","#003c30"],this.BR_BG_11=["#543005","#8c510a","#bf812d","#dfc27d","#f6e8c3","#f5f5f5","#c7eae5","#80cdc1","#35978f","#01665e","#003c30"],this.PI_YG_3=["#e9a3c9","#f7f7f7","#a1d76a"],this.PI_YG_4=["#d01c8b","#f1b6da","#b8e186","#4dac26"],this.PI_YG_5=["#d01c8b","#f1b6da","#f7f7f7","#b8e186","#4dac26"],this.PI_YG_6=["#c51b7d","#e9a3c9","#fde0ef","#e6f5d0","#a1d76a","#4d9221"],this.PI_YG_7=["#c51b7d","#e9a3c9","#fde0ef","#f7f7f7","#e6f5d0","#a1d76a","#4d9221"],this.PI_YG_8=["#c51b7d","#de77ae","#f1b6da","#fde0ef","#e6f5d0","#b8e186","#7fbc41","#4d9221"],this.PI_YG_9=["#c51b7d","#de77ae","#f1b6da","#fde0ef","#f7f7f7","#e6f5d0","#b8e186","#7fbc41","#4d9221"],this.PI_YG_10=["#8e0152","#c51b7d","#de77ae","#f1b6da","#fde0ef","#e6f5d0","#b8e186","#7fbc41","#4d9221","#276419"],this.PI_YG_11=["#8e0152","#c51b7d","#de77ae","#f1b6da","#fde0ef","#f7f7f7","#e6f5d0","#b8e186","#7fbc41","#4d9221","#276419"],this.PR_GN_3=["#af8dc3","#f7f7f7","#7fbf7b"],this.PR_GN_4=["#7b3294","#c2a5cf","#a6dba0","#008837"],this.PR_GN_5=["#7b3294","#c2a5cf","#f7f7f7","#a6dba0","#008837"],this.PR_GN_6=["#762a83","#af8dc3","#e7d4e8","#d9f0d3","#7fbf7b","#1b7837"],this.PR_GN_7=["#762a83","#af8dc3","#e7d4e8","#f7f7f7","#d9f0d3","#7fbf7b","#1b7837"],this.PR_GN_8=["#762a83","#9970ab","#c2a5cf","#e7d4e8","#d9f0d3","#a6dba0","#5aae61","#1b7837"],this.PR_GN_9=["#762a83","#9970ab","#c2a5cf","#e7d4e8","#f7f7f7","#d9f0d3","#a6dba0","#5aae61","#1b7837"],this.PR_GN_10=["#40004b","#762a83","#9970ab","#c2a5cf","#e7d4e8","#d9f0d3","#a6dba0","#5aae61","#1b7837","#00441b"],this.PR_GN_11=["#40004b","#762a83","#9970ab","#c2a5cf","#e7d4e8","#f7f7f7","#d9f0d3","#a6dba0","#5aae61","#1b7837","#00441b"],this.PU_OR_3=["#f1a340","#f7f7f7","#998ec3"],this.PU_OR_4=["#e66101","#fdb863","#b2abd2","#5e3c99"],this.PU_OR_5=["#e66101","#fdb863","#f7f7f7","#b2abd2","#5e3c99"],this.PU_OR_6=["#b35806","#f1a340","#fee0b6","#d8daeb","#998ec3","#542788"],this.PU_OR_7=["#b35806","#f1a340","#fee0b6","#f7f7f7","#d8daeb","#998ec3","#542788"],this.PU_OR_8=["#b35806","#e08214","#fdb863","#fee0b6","#d8daeb","#b2abd2","#8073ac","#542788"],this.PU_OR_9=["#b35806","#e08214","#fdb863","#fee0b6","#f7f7f7","#d8daeb","#b2abd2","#8073ac","#542788"],this.PU_OR_10=["#7f3b08","#b35806","#e08214","#fdb863","#fee0b6","#d8daeb","#b2abd2","#8073ac","#542788","#2d004b"],this.PU_OR_11=["#7f3b08","#b35806","#e08214","#fdb863","#fee0b6","#f7f7f7","#d8daeb","#b2abd2","#8073ac","#542788","#2d004b"],this.RD_BU_3=["#ef8a62","#f7f7f7","#67a9cf"],this.RD_BU_4=["#ca0020","#f4a582","#92c5de","#0571b0"],this.RD_BU_5=["#ca0020","#f4a582","#f7f7f7","#92c5de","#0571b0"],this.RD_BU_6=["#b2182b","#ef8a62","#fddbc7","#d1e5f0","#67a9cf","#2166ac"],this.RD_BU_7=["#b2182b","#ef8a62","#fddbc7","#f7f7f7","#d1e5f0","#67a9cf","#2166ac"],this.RD_BU_8=["#b2182b","#d6604d","#f4a582","#fddbc7","#d1e5f0","#92c5de","#4393c3","#2166ac"],this.RD_BU_9=["#b2182b","#d6604d","#f4a582","#fddbc7","#f7f7f7","#d1e5f0","#92c5de","#4393c3","#2166ac"],this.RD_BU_10=["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#d1e5f0","#92c5de","#4393c3","#2166ac","#053061"],this.RD_BU_11=["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#f7f7f7","#d1e5f0","#92c5de","#4393c3","#2166ac","#053061"],this.RD_GY_3=["#ef8a62","#ffffff","#999999"],this.RD_GY_4=["#ca0020","#f4a582","#bababa","#404040"],this.RD_GY_5=["#ca0020","#f4a582","#ffffff","#bababa","#404040"],this.RD_GY_6=["#b2182b","#ef8a62","#fddbc7","#e0e0e0","#999999","#4d4d4d"],this.RD_GY_7=["#b2182b","#ef8a62","#fddbc7","#ffffff","#e0e0e0","#999999","#4d4d4d"],this.RD_GY_8=["#b2182b","#d6604d","#f4a582","#fddbc7","#e0e0e0","#bababa","#878787","#4d4d4d"],this.RD_GY_9=["#b2182b","#d6604d","#f4a582","#fddbc7","#ffffff","#e0e0e0","#bababa","#878787","#4d4d4d"],this.RD_GY_10=["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#e0e0e0","#bababa","#878787","#4d4d4d","#1a1a1a"],this.RD_GY_11=["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#ffffff","#e0e0e0","#bababa","#878787","#4d4d4d","#1a1a1a"],this.RD_YL_BU_3=["#fc8d59","#ffffbf","#91bfdb"],this.RD_YL_BU_4=["#d7191c","#fdae61","#abd9e9","#2c7bb6"],this.RD_YL_BU_5=["#d7191c","#fdae61","#ffffbf","#abd9e9","#2c7bb6"],this.RD_YL_BU_6=["#d73027","#fc8d59","#fee090","#e0f3f8","#91bfdb","#4575b4"],this.RD_YL_BU_7=["#d73027","#fc8d59","#fee090","#ffffbf","#e0f3f8","#91bfdb","#4575b4"],this.RD_YL_BU_8=["#d73027","#f46d43","#fdae61","#fee090","#e0f3f8","#abd9e9","#74add1","#4575b4"],this.RD_YL_BU_9=["#d73027","#f46d43","#fdae61","#fee090","#ffffbf","#e0f3f8","#abd9e9","#74add1","#4575b4"],this.RD_YL_BU_10=["#a50026","#d73027","#f46d43","#fdae61","#fee090","#e0f3f8","#abd9e9","#74add1","#4575b4","#313695"],this.RD_YL_BU_11=["#a50026","#d73027","#f46d43","#fdae61","#fee090","#ffffbf","#e0f3f8","#abd9e9","#74add1","#4575b4","#313695"],this.RD_YL_GN_3=["#fc8d59","#ffffbf","#91cf60"],this.RD_YL_GN_4=["#d7191c","#fdae61","#a6d96a","#1a9641"],this.RD_YL_GN_5=["#d7191c","#fdae61","#ffffbf","#a6d96a","#1a9641"],this.RD_YL_GN_6=["#d73027","#fc8d59","#fee08b","#d9ef8b","#91cf60","#1a9850"],this.RD_YL_GN_7=["#d73027","#fc8d59","#fee08b","#ffffbf","#d9ef8b","#91cf60","#1a9850"],this.RD_YL_GN_8=["#d73027","#f46d43","#fdae61","#fee08b","#d9ef8b","#a6d96a","#66bd63","#1a9850"],this.RD_YL_GN_9=["#d73027","#f46d43","#fdae61","#fee08b","#ffffbf","#d9ef8b","#a6d96a","#66bd63","#1a9850"],this.RD_YL_GN_10=["#a50026","#d73027","#f46d43","#fdae61","#fee08b","#d9ef8b","#a6d96a","#66bd63","#1a9850","#006837"],this.RD_YL_GN_11=["#a50026","#d73027","#f46d43","#fdae61","#fee08b","#ffffbf","#d9ef8b","#a6d96a","#66bd63","#1a9850","#006837"],this.SPECTRAL_3=["#fc8d59","#ffffbf","#99d594"],this.SPECTRAL_4=["#d7191c","#fdae61","#abdda4","#2b83ba"],this.SPECTRAL_5=["#d7191c","#fdae61","#ffffbf","#abdda4","#2b83ba"],this.SPECTRAL_6=["#d53e4f","#fc8d59","#fee08b","#e6f598","#99d594","#3288bd"],this.SPECTRAL_7=["#d53e4f","#fc8d59","#fee08b","#ffffbf","#e6f598","#99d594","#3288bd"],this.SPECTRAL_8=["#d53e4f","#f46d43","#fdae61","#fee08b","#e6f598","#abdda4","#66c2a5","#3288bd"],this.SPECTRAL_9=["#d53e4f","#f46d43","#fdae61","#fee08b","#ffffbf","#e6f598","#abdda4","#66c2a5","#3288bd"],this.SPECTRAL_10=["#9e0142","#d53e4f","#f46d43","#fdae61","#fee08b","#e6f598","#abdda4","#66c2a5","#3288bd","#5e4fa2"],this.SPECTRAL_11=["#9e0142","#d53e4f","#f46d43","#fdae61","#fee08b","#ffffbf","#e6f598","#abdda4","#66c2a5","#3288bd","#5e4fa2"],this.BR_BG=[this.BR_BG_3,this.BR_BG_4,this.BR_BG_5,this.BR_BG_6,this.BR_BG_7,this.BR_BG_8,this.BR_BG_9,this.BR_BG_10,this.BR_BG_11],this.PI_YG=[this.PI_YG_3,this.PI_YG_4,this.PI_YG_5,this.PI_YG_6,this.PI_YG_7,this.PI_YG_8,this.PI_YG_9,this.PI_YG_10,this.PI_YG_11],this.PR_GN=[this.PR_GN_3,this.PR_GN_4,this.PR_GN_5,this.PR_GN_6,this.PR_GN_7,this.PR_GN_8,this.PR_GN_9,this.PR_GN_10,this.PR_GN_11],this.PU_OR=[this.PU_OR_3,this.PU_OR_4,this.PU_OR_5,this.PU_OR_6,this.PU_OR_7,this.PU_OR_8,this.PU_OR_9,this.PU_OR_10,this.PU_OR_11],this.RD_BU=[this.RD_BU_3,this.RD_BU_4,this.RD_BU_5,this.RD_BU_6,this.RD_BU_7,this.RD_BU_8,this.RD_BU_9,this.RD_BU_10,this.RD_BU_11],this.RD_GY=[this.RD_GY_3,this.RD_GY_4,this.RD_GY_5,this.RD_GY_6,this.RD_GY_7,this.RD_GY_8,this.RD_GY_9,this.RD_GY_10,this.RD_GY_11],this.RD_YL_BU=[this.RD_YL_BU_3,this.RD_YL_BU_4,this.RD_YL_BU_5,this.RD_YL_BU_6,this.RD_YL_BU_7,this.RD_YL_BU_8,this.RD_YL_BU_9,this.RD_YL_BU_10,this.RD_YL_BU_11],this.RD_YL_GN=[this.RD_YL_GN_3,this.RD_YL_GN_4,this.RD_YL_GN_5,this.RD_YL_GN_6,this.RD_YL_GN_7,this.RD_YL_GN_8,this.RD_YL_GN_9,this.RD_YL_GN_10,this.RD_YL_GN_11],this.SPECTRAL=[this.SPECTRAL_3,this.SPECTRAL_4,this.SPECTRAL_5,this.SPECTRAL_6,this.SPECTRAL_7,this.SPECTRAL_8,this.SPECTRAL_9,this.SPECTRAL_10,this.SPECTRAL_11],this.ACCENT_3=["#7fc97f","#beaed4","#fdc086"],this.ACCENT_4=["#7fc97f","#beaed4","#fdc086","#ffff99"],this.ACCENT_5=["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0"],this.ACCENT_6=["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0","#f0027f"],this.ACCENT_7=["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0","#f0027f","#bf5b17"],this.ACCENT_8=["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0","#f0027f","#bf5b17","#666666"],this.DARK_2_3=["#1b9e77","#d95f02","#7570b3"],this.DARK_2_4=["#1b9e77","#d95f02","#7570b3","#e7298a"],this.DARK_2_5=["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e"],this.DARK_2_6=["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e","#e6ab02"],this.DARK_2_7=["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e","#e6ab02","#a6761d"],this.DARK_2_8=["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e","#e6ab02","#a6761d","#666666"],this.PAIRED_3=["#a6cee3","#1f78b4","#b2df8a"],this.PAIRED_4=["#a6cee3","#1f78b4","#b2df8a","#33a02c"],this.PAIRED_5=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99"],this.PAIRED_6=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c"],this.PAIRED_7=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f"],this.PAIRED_8=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00"],this.PAIRED_9=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6"],this.PAIRED_10=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6","#6a3d9a"],this.PAIRED_11=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6","#6a3d9a","#ffff99"],this.PAIRED_12=["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6","#6a3d9a","#ffff99","#b15928"],this.PASTEL_1_3=["#fbb4ae","#b3cde3","#ccebc5"],this.PASTEL_1_4=["#fbb4ae","#b3cde3","#ccebc5","#decbe4"],this.PASTEL_1_5=["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6"],this.PASTEL_1_6=["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc"],this.PASTEL_1_7=["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc","#e5d8bd"],this.PASTEL_1_8=["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc","#e5d8bd","#fddaec"],this.PASTEL_1_9=["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc","#e5d8bd","#fddaec","#f2f2f2"],this.PASTEL_2_3=["#b3e2cd","#fdcdac","#cbd5e8"],this.PASTEL_2_4=["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4"],this.PASTEL_2_5=["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9"],this.PASTEL_2_6=["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9","#fff2ae"],this.PASTEL_2_7=["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9","#fff2ae","#f1e2cc"],this.PASTEL_2_8=["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9","#fff2ae","#f1e2cc","#cccccc"],this.SET_1_3=["#e41a1c","#377eb8","#4daf4a"],this.SET_1_4=["#e41a1c","#377eb8","#4daf4a","#984ea3"],this.SET_1_5=["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00"],this.SET_1_6=["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33"],this.SET_1_7=["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33","#a65628"],this.SET_1_8=["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33","#a65628","#f781bf"],this.SET_1_9=["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33","#a65628","#f781bf","#999999"],this.SET_2_3=["#66c2a5","#fc8d62","#8da0cb"],this.SET_2_4=["#66c2a5","#fc8d62","#8da0cb","#e78ac3"],this.SET_2_5=["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854"],this.SET_2_6=["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854","#ffd92f"],this.SET_2_7=["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854","#ffd92f","#e5c494"],this.SET_2_8=["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854","#ffd92f","#e5c494","#b3b3b3"],this.SET_3_3=["#8dd3c7","#ffffb3","#bebada"],this.SET_3_4=["#8dd3c7","#ffffb3","#bebada","#fb8072"],this.SET_3_5=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3"],this.SET_3_6=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462"],this.SET_3_7=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69"],this.SET_3_8=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5"],this.SET_3_9=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9"],this.SET_3_10=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd"],this.SET_3_11=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd","#ccebc5"],this.SET_3_12=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd","#ccebc5","#ffed6f"],this.ACCENT=[this.ACCENT_3,this.ACCENT_4,this.ACCENT_5,this.ACCENT_6,this.ACCENT_7,this.ACCENT_8],this.DARK_2=[this.DARK_2_3,this.DARK_2_4,this.DARK_2_5,this.DARK_2_6,this.DARK_2_7,this.DARK_2_8],this.PAIRED=[this.PAIRED_3,this.PAIRED_4,this.PAIRED_5,this.PAIRED_6,this.PAIRED_7,this.PAIRED_8,this.PAIRED_9,this.PAIRED_10,this.PAIRED_11,this.PAIRED_12],this.PASTEL_1=[this.PASTEL_1_3,this.PASTEL_1_4,this.PASTEL_1_5,this.PASTEL_1_6,this.PASTEL_1_7,this.PASTEL_1_8,this.PASTEL_1_9],this.PASTEL_2=[this.PASTEL_2_3,this.PASTEL_2_4,this.PASTEL_2_5,this.PASTEL_2_6,this.PASTEL_2_7,this.PASTEL_2_8],this.SET_1=[this.SET_1_3,this.SET_1_4,this.SET_1_5,this.SET_1_6,this.SET_1_7,this.SET_1_8,this.SET_1_9],this.SET_2=[this.SET_2_3,this.SET_2_4,this.SET_2_5,this.SET_2_6,this.SET_2_7,this.SET_2_8],this.SET_3=[this.SET_3_3,this.SET_3_4,this.SET_3_5,this.SET_3_6,this.SET_3_7,this.SET_3_8,this.SET_3_9,this.SET_3_10,this.SET_3_11,this.SET_3_12]}Ge.$metadata$={kind:Y,simpleName:"ColorScheme",interfaces:[]},He.$metadata$={kind:G,simpleName:"ColorSets",interfaces:[]};var Ye=null;function Ve(){return null===Ye&&new He,Ye}function Ke(){We=this}Ke.prototype.genColors_2c6x13$=function(t,e){var n,i=V(),r=V(),o=V();for(n=e.iterator();n.hasNext();){var a=n.next();i.add_11rb$(a.red),r.add_11rb$(a.green),o.add_11rb$(a.blue)}for(var s=new Qe(i),l=new Qe(r),u=new Qe(o),c=s.generate_za3lpa$(t).iterator(),p=l.generate_za3lpa$(t).iterator(),h=u.generate_za3lpa$(t).iterator(),_=K(t);c.hasNext()&&p.hasNext()&&h.hasNext();){var f=new W(c.next(),p.next(),h.next());_.add_11rb$(f)}return _},Ke.$metadata$={kind:G,simpleName:"ColorUtil",interfaces:[]};var We=null;function Xe(){return null===We&&new Ke,We}function Ze(){Je=this,this.NULL_COLOR=W.Companion.LIGHT_GRAY,this.EXTENSIBLE_COLOR_SCHEMES_0=Q([je(),Le(),Ie(),ze(),De(),Me(),Be()]),this.PAL_TYPE_BY_PAL_NAME_0=null;var t,e,n=tt(),i=$e(),r=K(i.length);for(t=0;t!==i.length;++t){var o=i[t];r.add_11rb$(o.name)}for(e=r.iterator();e.hasNext();){var a=e.next(),s=Wt();n.put_xwzc9p$(a,s)}var l,u,c=Ne(),p=K(c.length);for(l=0;l!==c.length;++l){var h=c[l];p.add_11rb$(h.name)}for(u=p.iterator();u.hasNext();){var _=u.next(),f=Xt();n.put_xwzc9p$(_,f)}var d,m,y=Ue(),$=K(y.length);for(d=0;d!==y.length;++d){var v=y[d];$.add_11rb$(v.name)}for(m=$.iterator();m.hasNext();){var g=m.next(),b=Zt();n.put_xwzc9p$(g,b)}this.PAL_TYPE_BY_PAL_NAME_0=n}Ze.prototype.isExtensibleScheme_0=function(t){return this.EXTENSIBLE_COLOR_SCHEMES_0.contains_11rb$(t)},Ze.prototype.schemeColors_7q5c77$=function(t,e){var n=t.getColors_za3lpa$(e),i=this.fromColorsHex_0(n);if(n.length=this.myMinRowSize_0){this.isMesh=!0;var a=nt(i[1])-nt(i[0]);this.resolution=H.abs(a)}},an.$metadata$={kind:F,simpleName:"MyColumnDetector",interfaces:[rn]},sn.prototype.tryRow_l63ks6$=function(t){var e=X.Iterables.get_dhabsj$(t,0,null),n=X.Iterables.get_dhabsj$(t,1,null);if(null==e||null==n)return this.NO_MESH_0;var i=n-e,r=H.abs(i);if(!ot(r))return this.NO_MESH_0;var o=r/1e4;return this.tryRow_4sxsdq$(50,o,t)},sn.prototype.tryRow_4sxsdq$=function(t,e,n){return new on(t,e,n)},sn.prototype.tryColumn_l63ks6$=function(t){return this.tryColumn_4sxsdq$(50,$n().TINY,t)},sn.prototype.tryColumn_4sxsdq$=function(t,e,n){return new an(t,e,n)},Object.defineProperty(ln.prototype,"isMesh",{configurable:!0,get:function(){return!1},set:function(t){e.callSetter(this,rn.prototype,"isMesh",t)}}),ln.$metadata$={kind:F,interfaces:[rn]},sn.$metadata$={kind:G,simpleName:"Companion",interfaces:[]};var un=null;function cn(){return null===un&&new sn,un}function pn(){var t;yn=this,this.TINY=1e-50,this.REAL_NUMBER_0=(t=this,function(e){return t.isFinite_yrwdxb$(e)}),this.NEGATIVE_NUMBER=mn}function hn(t){_n.call(this,t)}function _n(t){var e;this.myIterable_n2c9gl$_0=t,this.myEmpty_3k4vh6$_0=X.Iterables.isEmpty_fakr2g$(this.myIterable_n2c9gl$_0),this.myCanBeCast_310oqz$_0=!1,e=!!this.myEmpty_3k4vh6$_0||X.Iterables.all_fpit1u$(X.Iterables.filter_fpit1u$(this.myIterable_n2c9gl$_0,fn),dn),this.myCanBeCast_310oqz$_0=e}function fn(t){return null!=t}function dn(t){return"number"==typeof t}function mn(t){return t<0}rn.$metadata$={kind:F,simpleName:"RegularMeshDetector",interfaces:[]},pn.prototype.isSubTiny_14dthe$=function(t){return t0&&(p10?e.size:10,r=K(i);for(n=e.iterator();n.hasNext();){var o=n.next();o=0?i:e},pn.prototype.sum_k9kaly$=function(t){var e,n=0;for(e=t.iterator();e.hasNext();){var i=e.next();null!=i&&ot(i)&&(n+=i)}return n},pn.prototype.toDoubleList_8a6n3n$=function(t){return null==t?null:new hn(t).cast()},hn.prototype.cast=function(){var t;return e.isType(t=_n.prototype.cast.call(this),ut)?t:J()},hn.$metadata$={kind:F,simpleName:"CheckedDoubleList",interfaces:[_n]},_n.prototype.notEmptyAndCanBeCast=function(){return!this.myEmpty_3k4vh6$_0&&this.myCanBeCast_310oqz$_0},_n.prototype.canBeCast=function(){return this.myCanBeCast_310oqz$_0},_n.prototype.cast=function(){var t;if(!this.myCanBeCast_310oqz$_0)throw at("Can't cast to a collection of Double(s)".toString());return e.isType(t=this.myIterable_n2c9gl$_0,pt)?t:J()},_n.$metadata$={kind:F,simpleName:"CheckedDoubleIterable",interfaces:[]},pn.$metadata$={kind:G,simpleName:"SeriesUtil",interfaces:[]};var yn=null;function $n(){return null===yn&&new pn,yn}function vn(){this.myEpsilon_0=yt.MIN_VALUE}function gn(t,e){return function(n){return new vt(t.get_za3lpa$(e),n).length()}}function bn(t){return function(e){return t.distance_gpjtzr$(e)}}vn.prototype.calculateWeights_0=function(t){for(var e=new mt,n=t.size,i=K(n),r=0;ru&&(c=h,u=_),h=h+1|0}u>=this.myEpsilon_0&&(e.push_11rb$(new $t(a,c)),e.push_11rb$(new $t(c,s)),o.set_wxm5ur$(c,u))}return o},vn.prototype.getWeights_ytws2g$=function(t){return this.calculateWeights_0(t)},vn.$metadata$={kind:F,simpleName:"DouglasPeuckerSimplification",interfaces:[kn]};var wn=Ct((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function xn(t,e){Sn(),this.myPoints_0=t,this.myWeights_0=null,this.myWeightLimit_0=yt.NaN,this.myCountLimit_0=-1,this.myWeights_0=e.getWeights_ytws2g$(this.myPoints_0)}function kn(){}function En(){Cn=this}Object.defineProperty(xn.prototype,"points",{configurable:!0,get:function(){var t,e=this.indices,n=K(Et(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(this.myPoints_0.get_za3lpa$(i))}return n}}),Object.defineProperty(xn.prototype,"indices",{configurable:!0,get:function(){var t,e=gt(0,this.myPoints_0.size),n=K(Et(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(new $t(i,this.myWeights_0.get_za3lpa$(i)))}var r,o=V();for(r=n.iterator();r.hasNext();){var a=r.next();bt(this.getWeight_0(a))||o.add_11rb$(a)}var s,l,u=xt(o,wt(new St(wn((l=this,function(t){return l.getWeight_0(t)})))));if(this.isWeightLimitSet_0){var c,p=V();for(c=u.iterator();c.hasNext();){var h=c.next();this.getWeight_0(h)>this.myWeightLimit_0&&p.add_11rb$(h)}s=p}else s=st(u,this.myCountLimit_0);var _,f=s,d=K(Et(f,10));for(_=f.iterator();_.hasNext();){var m=_.next();d.add_11rb$(this.getIndex_0(m))}return kt(d)}}),Object.defineProperty(xn.prototype,"isWeightLimitSet_0",{configurable:!0,get:function(){return!bt(this.myWeightLimit_0)}}),xn.prototype.setWeightLimit_14dthe$=function(t){return this.myWeightLimit_0=t,this.myCountLimit_0=-1,this},xn.prototype.setCountLimit_za3lpa$=function(t){return this.myWeightLimit_0=yt.NaN,this.myCountLimit_0=t,this},xn.prototype.getWeight_0=function(t){return t.second},xn.prototype.getIndex_0=function(t){return t.first},kn.$metadata$={kind:Y,simpleName:"RankingStrategy",interfaces:[]},En.prototype.visvalingamWhyatt_ytws2g$=function(t){return new xn(t,new On)},En.prototype.douglasPeucker_ytws2g$=function(t){return new xn(t,new vn)},En.$metadata$={kind:G,simpleName:"Companion",interfaces:[]};var Cn=null;function Sn(){return null===Cn&&new En,Cn}xn.$metadata$={kind:F,simpleName:"PolylineSimplifier",interfaces:[]};var Tn=Ct((function(){var t=e.kotlin.comparisons.compareValues_s00gnj$;return function(e){return function(n,i){var r=e;return t(r(n),r(i))}}}));function On(){Ln(),this.myVerticesToRemove_0=V(),this.myTriangles_0=null}function Nn(t){return t.area}function Pn(t,e){this.currentVertex=t,this.myPoints_0=e,this.area_nqp3v0$_0=0,this.prevVertex_0=0,this.nextVertex_0=0,this.prev=null,this.next=null,this.prevVertex_0=this.currentVertex-1|0,this.nextVertex_0=this.currentVertex+1|0,this.area=this.calculateArea_0()}function An(){jn=this,this.INITIAL_AREA_0=yt.MAX_VALUE}Object.defineProperty(On.prototype,"isSimplificationDone_0",{configurable:!0,get:function(){return this.isEmpty_0}}),Object.defineProperty(On.prototype,"isEmpty_0",{configurable:!0,get:function(){return nt(this.myTriangles_0).isEmpty()}}),On.prototype.getWeights_ytws2g$=function(t){this.myTriangles_0=K(t.size-2|0),this.initTriangles_0(t);for(var e=t.size,n=K(e),i=0;io?a.area:o,r.set_wxm5ur$(a.currentVertex,o);var s=a.next;null!=s&&(s.takePrevFrom_em8fn6$(a),this.update_0(s));var l=a.prev;null!=l&&(l.takeNextFrom_em8fn6$(a),this.update_0(l)),this.myVerticesToRemove_0.add_11rb$(a.currentVertex)}return r},On.prototype.initTriangles_0=function(t){for(var e=K(t.size-2|0),n=1,i=t.size-1|0;ne)throw Bt("Duration must be positive");var n=Hn().asDateTimeUTC_14dthe$(t),i=this.getFirstDayContaining_amwj4p$(n),r=new Dt(i);r.compareTo_11rb$(n)<0&&(r=this.addInterval_amwj4p$(r));for(var o=V(),a=Hn().asInstantUTC_amwj4p$(r).toNumber();a<=e;)o.add_11rb$(a),r=this.addInterval_amwj4p$(r),a=Hn().asInstantUTC_amwj4p$(r).toNumber();return o},Vn.$metadata$={kind:F,simpleName:"MeasuredInDays",interfaces:[ii]},Object.defineProperty(Kn.prototype,"tickFormatPattern",{configurable:!0,get:function(){return"%b"}}),Kn.prototype.getFirstDayContaining_amwj4p$=function(t){var e=t.date;return zt.Companion.firstDayOf_8fsw02$(e.year,e.month)},Kn.prototype.addInterval_amwj4p$=function(t){var e,n=t;e=this.count;for(var i=0;i=t){n=t-this.AUTO_STEPS_MS_0[i-1|0]").find_905azu$(t);if(null==e||2!==e.groupValues.size)throw N("Couldn't find 'svg' tag".toString());var n=e.groupValues.get_za3lpa$(1),i=this.extractDouble_0(j('.*width="(\\d+)\\.?(\\d+)?"'),n),r=this.extractDouble_0(j('.*height="(\\d+)\\.?(\\d+)?"'),n);return new m(i,r)},tr.prototype.extractDouble_0=function(t,e){var n=L(t.find_905azu$(e)).groupValues;return n.size<3?R(n.get_za3lpa$(1)):R(n.get_za3lpa$(1)+"."+n.get_za3lpa$(2))},tr.$metadata$={kind:b,simpleName:"PlotSizeHelper",interfaces:[]};var er=null;function nr(){return null===er&&new tr,er}function ir(t){ar(),yl.call(this,t)}function rr(){or=this,this.DEF_ANGLE_0=30,this.DEF_LENGTH_0=10,this.DEF_END_0=U.LAST,this.DEF_TYPE_0=F.OPEN}ir.prototype.createArrowSpec=function(){var t=ar().DEF_ANGLE_0,e=ar().DEF_LENGTH_0,n=ar().DEF_END_0,i=ar().DEF_TYPE_0;if(this.has_61zpoe$(tl().ANGLE)&&(t=L(this.getDouble_61zpoe$(tl().ANGLE))),this.has_61zpoe$(tl().LENGTH)&&(e=L(this.getDouble_61zpoe$(tl().LENGTH))),this.has_61zpoe$(tl().ENDS))switch(this.getString_61zpoe$(tl().ENDS)){case"last":n=U.LAST;break;case"first":n=U.FIRST;break;case"both":n=U.BOTH;break;default:throw N("Expected: first|last|both")}if(this.has_61zpoe$(tl().TYPE))switch(this.getString_61zpoe$(tl().TYPE)){case"open":i=F.OPEN;break;case"closed":i=F.CLOSED;break;default:throw N("Expected: open|closed")}return new G(q(t),e,n,i)},rr.prototype.create_za3rmp$=function(t){var n;if(e.isType(t,A)){var i=_r().featureName_bkhwtg$(t);if(H("arrow",i))return new ir(e.isType(n=t,A)?n:c())}throw N("Expected: 'arrow = arrow(...)'")},rr.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var or=null;function ar(){return null===or&&new rr,or}function sr(t){var n,i;for(yl.call(this,t),this.myItems_0=d(),n=this.getList_61zpoe$(ra().ITEMS).iterator();n.hasNext();){var r=n.next();if(e.isType(r,A)){var o=new yl(e.isType(i=r,u)?i:c());this.myItems_0.add_11rb$(new lr(o.getMap_61zpoe$(na().FEATURE_SPEC),L(o.getDouble_61zpoe$(na().X)),L(o.getDouble_61zpoe$(na().Y)),o.getDouble_61zpoe$(na().WIDTH),o.getDouble_61zpoe$(na().HEIGHT)))}}}function lr(t,e,n,i,r){this.myFeatureSpec_0=t,this.x=e,this.y=n,this.myWidth_0=i,this.myHeight_0=r}function ur(){hr=this}function cr(t,e){var n,i=k(x(e,10));for(n=e.iterator();n.hasNext();){var r,o,a=n.next(),s=i.add_11rb$;o="string"==typeof(r=a)?r:c(),s.call(i,V.DataFrameUtil.findVariableOrFail_vede35$(t,o))}var l,u=i,p=K(0,t.rowCount()),h=k(x(p,10));for(l=p.iterator();l.hasNext();){var _,f=l.next(),d=h.add_11rb$,m=k(x(u,10));for(_=u.iterator();_.hasNext();){var y=_.next();m.add_11rb$(t.get_8xm3sj$(y).get_za3lpa$(f))}d.call(h,m)}return h}function pr(t){return W(t).size=0){var j,R;for(C.remove_11rb$(O),j=n.variables().iterator();j.hasNext();){var I=j.next();L(h.get_11rb$(I)).add_11rb$(n.get_8xm3sj$(I).get_za3lpa$(A))}for(R=t.variables().iterator();R.hasNext();){var z=R.next();L(h.get_11rb$(z)).add_11rb$(t.get_8xm3sj$(z).get_za3lpa$(P))}}}}for(b=C.iterator();b.hasNext();){var D;for(D=E(u,b.next()).iterator();D.hasNext();){var M,B,U=D.next();for(M=n.variables().iterator();M.hasNext();){var F=M.next();L(h.get_11rb$(F)).add_11rb$(n.get_8xm3sj$(F).get_za3lpa$(U))}for(B=t.variables().iterator();B.hasNext();){var q=B.next();L(h.get_11rb$(q)).add_11rb$(null)}}}var G,Y=h.entries,V=Q();for(G=Y.iterator();G.hasNext();){var K=G.next(),W=V,tt=K.key,et=K.value;V=W.put_2l962d$(tt,et)}return V.build()},ur.prototype.asVarNameMap_0=function(t){var n,i;if(null==t)return tt();var r=X();if(e.isType(t,A))for(n=t.keys.iterator();n.hasNext();){var o,a=n.next(),s=(e.isType(o=t,A)?o:c()).get_11rb$(a);if(e.isType(s,et)){var l=f(a);r.put_xwzc9p$(l,s)}}else{if(!e.isType(t,et))throw N("Unsupported data structure: "+e.getKClassFromExpression(t).simpleName);var u=!0,p=-1;for(i=t.iterator();i.hasNext();){var h=i.next();if(!e.isType(h,et)||!(p<0||h.size===p)){u=!1;break}p=h.size}if(u)for(var _=V.Dummies.dummyNames_za3lpa$(t.size),d=0;d!==t.size;++d){var m,y=_.get_za3lpa$(d),$=e.isType(m=t.get_za3lpa$(d),et)?m:c();r.put_xwzc9p$(y,$)}else{var v=V.Dummies.dummyNames_za3lpa$(1).get_za3lpa$(0);r.put_xwzc9p$(v,t)}}return r},ur.prototype.updateDataFrame_0=function(t,e){var n,i,r=V.DataFrameUtil.variables_dhhkv7$(t),o=t.builder();for(n=e.entries.iterator();n.hasNext();){var a=n.next(),s=a.key,l=a.value,u=null!=(i=r.get_11rb$(s))?i:V.DataFrameUtil.createVariable_puj7f4$(s);o.put_2l962d$(u,l)}return o.build()},ur.prototype.toList_0=function(t){var n;if(e.isType(t,et))n=t;else if(e.isNumber(t))n=_(nt(t));else{if(e.isType(t,it))throw N("Can't cast/transform to list: "+e.getKClassFromExpression(t).simpleName);n=_(t.toString())}return n},ur.prototype.createAesMapping_5bl3vv$=function(t,n){var i;if(null==n)return tt();var r=V.DataFrameUtil.variables_dhhkv7$(t),o=X();for(i=Fs().REAL_AES_OPTION_NAMES.iterator();i.hasNext();){var a,s=i.next(),l=(e.isType(a=n,A)?a:c()).get_11rb$(s);if("string"==typeof l){var u,p=null!=(u=r.get_11rb$(l))?u:V.DataFrameUtil.createVariable_puj7f4$(l),h=Fs().toAes_61zpoe$(s);o.put_xwzc9p$(h,p)}}return o},ur.prototype.toNumericPair_9ma18$=function(t){var n=0,i=0,r=t.iterator();if(r.hasNext())try{n=R(""+f(r.next()))}catch(t){if(!e.isType(t,rt))throw t}if(r.hasNext())try{i=R(""+f(r.next()))}catch(t){if(!e.isType(t,rt))throw t}return new m(n,i)},ur.$metadata$={kind:b,simpleName:"ConfigUtil",interfaces:[]};var hr=null;function _r(){return null===hr&&new ur,hr}function fr(t,e){yr(),yl.call(this,e),this.coord=gr().createCoordProvider_5ai0im$(t,this)}function dr(){mr=this}dr.prototype.create_za3rmp$=function(t){var n;if(e.isType(t,A)){var i=e.isType(n=t,A)?n:c();return this.createForName_0(_r().featureName_bkhwtg$(i),i)}return this.createForName_0(t.toString(),X())},dr.prototype.createForName_0=function(t,e){return new fr(t,e)},dr.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var mr=null;function yr(){return null===mr&&new dr,mr}function $r(){vr=this,this.X_LIM_0="xlim",this.Y_LIM_0="ylim",this.RATIO_0="ratio",this.EXPAND_0="expand",this.ORIENTATION_0="orientation",this.PROJECTION_0="projection"}fr.$metadata$={kind:v,simpleName:"CoordConfig",interfaces:[yl]},$r.prototype.createCoordProvider_5ai0im$=function(t,e){var n,i,r=e.getRangeOrNull_61zpoe$(this.X_LIM_0),o=e.getRangeOrNull_61zpoe$(this.Y_LIM_0);switch(t){case"cartesian":i=at.CoordProviders.cartesian_t7esj2$(r,o);break;case"fixed":i=at.CoordProviders.fixed_vvp5j4$(null!=(n=e.getDouble_61zpoe$(this.RATIO_0))?n:1,r,o);break;case"map":i=at.CoordProviders.map_t7esj2$(r,o);break;default:throw N("Unknown coordinate system name: '"+t+"'")}return i},$r.$metadata$={kind:b,simpleName:"CoordProto",interfaces:[]};var vr=null;function gr(){return null===vr&&new $r,vr}function br(){wr=this,this.prefix_0="@as_discrete@"}br.prototype.isDiscrete_0=function(t){return st(t,this.prefix_0)},br.prototype.toDiscrete_61zpoe$=function(t){if(this.isDiscrete_0(t))throw N(("toDiscrete() - variable already encoded: "+t).toString());return this.prefix_0+t},br.prototype.fromDiscrete_0=function(t){if(!this.isDiscrete_0(t))throw N(("fromDiscrete() - variable is not encoded: "+t).toString());return lt(t,this.prefix_0)},br.prototype.getMappingAnnotationsSpec_0=function(t,e){var n,i,r,o;if(null!=(i=null!=(n=Al(t,[Jo().DATA_META]))?Il(n,[Xo().TAG]):null)){var a,s=d();for(a=i.iterator();a.hasNext();){var l=a.next();H(Cl(l,[Xo().ANNOTATION]),e)&&s.add_11rb$(l)}o=s}else o=null;return null!=(r=o)?r:ut()},br.prototype.getAsDiscreteAesSet_bkhwtg$=function(t){var e,n,i,r,o,a;if(null!=(e=Il(t,[Xo().TAG]))){var s,l=xt(wt(x(e,10)),16),u=kt(l);for(s=e.iterator();s.hasNext();){var c=s.next(),p=ct(L(Cl(c,[Xo().AES])),L(Cl(c,[Xo().ANNOTATION])));u.put_xwzc9p$(p.first,p.second)}o=u}else o=null;if(null!=(n=o)){var h,_=pt("equals",function(t,e){return H(t,e)}.bind(null,Xo().AS_DISCRETE)),f=Et();for(h=n.entries.iterator();h.hasNext();){var d=h.next();_(d.value)&&f.put_xwzc9p$(d.key,d.value)}a=f}else a=null;return null!=(r=null!=(i=a)?i.keys:null)?r:ht()},br.prototype.createScaleSpecs_x7u0o8$=function(t){var e,n,i,r,o=this.getMappingAnnotationsSpec_0(t,Xo().AS_DISCRETE);if(null!=(e=Il(t,[ca().LAYERS]))){var a,s=k(x(e,10));for(a=e.iterator();a.hasNext();){var l=a.next();s.add_11rb$(this.getMappingAnnotationsSpec_0(l,Xo().AS_DISCRETE))}r=s}else r=null;var u,c=null!=(i=null!=(n=r)?_t(n):null)?i:ut(),p=ft(o,c),h=Et();for(u=p.iterator();u.hasNext();){var _,f=u.next(),m=L(Cl(f,[Xo().AES])),y=h.get_11rb$(m);if(null==y){var $=d();h.put_xwzc9p$(m,$),_=$}else _=y;_.add_11rb$(Cl(f,[Xo().PARAMETERS,Xo().LABEL]))}var v,g=kt(wt(h.size));for(v=h.entries.iterator();v.hasNext();){var b,w=v.next(),E=g.put_xwzc9p$,C=w.key,S=w.value;t:do{for(var T=S.listIterator_za3lpa$(S.size);T.hasPrevious();){var O=T.previous();if(null!=O){b=O;break t}}b=null}while(0);E.call(g,C,b)}var N,P=k(g.size);for(N=g.entries.iterator();N.hasNext();){var A=N.next(),j=P.add_11rb$,R=A.key,I=A.value;j.call(P,dt([ct(Is().AES,R),ct(Is().DISCRETE_DOMAIN,!0),ct(Is().NAME,I)]))}return P},br.prototype.createDataFrame_dgfi6i$=function(t,e,n,i,r){var o=_r().createDataFrame_8ea4ql$(t.get_61zpoe$(sa().DATA)),a=t.getMap_61zpoe$(sa().MAPPING);if(r){var s,l=V.DataFrameUtil.toMap_dhhkv7$(o),u=Et();for(s=l.entries.iterator();s.hasNext();){var c=s.next(),p=c.key;this.isDiscrete_0(p)&&u.put_xwzc9p$(c.key,c.value)}var h,_=u.entries,f=mt(o);for(h=_.iterator();h.hasNext();){var d=h.next(),m=f,y=d.key,$=d.value,v=V.DataFrameUtil.findVariableOrFail_vede35$(o,y);m.remove_8xm3sj$(v),f=m.putDiscrete_2l962d$(v,$)}return new D(a,f.build())}var g,b=this.getAsDiscreteAesSet_bkhwtg$(t.getMap_61zpoe$(Jo().DATA_META)),w=Et();for(g=a.entries.iterator();g.hasNext();){var E=g.next(),C=E.key;b.contains_11rb$(C)&&w.put_xwzc9p$(E.key,E.value)}var S,T=w,O=Et();for(S=i.entries.iterator();S.hasNext();){var P=S.next();yt(n,P.key)&&O.put_xwzc9p$(P.key,P.value)}var A,j=kr(O),L=pt("fromDiscrete",function(t,e){return t.fromDiscrete_0(e)}.bind(null,this)),R=k(x(j,10));for(A=j.iterator();A.hasNext();){var I=A.next();R.add_11rb$(L(I))}var z,M=R,B=$t(kr(a),kr(T)),U=$t(vt(kr(T),M),B),F=gt(V.DataFrameUtil.toMap_dhhkv7$(e),V.DataFrameUtil.toMap_dhhkv7$(o)),q=kt(wt(T.size));for(z=T.entries.iterator();z.hasNext();){var G=z.next(),H=q.put_xwzc9p$,Y=G.key,K=G.value;if("string"!=typeof K)throw N("Failed requirement.".toString());H.call(q,Y,this.toDiscrete_61zpoe$(K))}var W,X=gt(a,q),Z=Et();for(W=F.entries.iterator();W.hasNext();){var J=W.next(),Q=J.key;U.contains_11rb$(Q)&&Z.put_xwzc9p$(J.key,J.value)}var tt,et=kt(wt(Z.size));for(tt=Z.entries.iterator();tt.hasNext();){var nt=tt.next(),it=et.put_xwzc9p$,rt=nt.key;it.call(et,V.DataFrameUtil.createVariable_puj7f4$(this.toDiscrete_61zpoe$(rt)),nt.value)}var ot,at=et.entries,st=mt(o);for(ot=at.iterator();ot.hasNext();){var lt=ot.next(),ut=st,ct=lt.key,ht=lt.value;st=ut.putDiscrete_2l962d$(ct,ht)}return new D(X,st.build())},br.prototype.getOrderOptions_tjia25$=function(t,n){var i,r,o,a,s;if(null!=(i=null!=t?this.getMappingAnnotationsSpec_0(t,Xo().AS_DISCRETE):null)){var l,u=xt(wt(x(i,10)),16),p=kt(u);for(l=i.iterator();l.hasNext();){var h=l.next(),_=ct(L(Nl(h,[Xo().AES])),Al(h,[Xo().PARAMETERS]));p.put_xwzc9p$(_.first,_.second)}a=p}else a=null;if(null!=(r=a)){var f,m=d();for(f=r.entries.iterator();f.hasNext();){var y,$,v,g,b=f.next(),w=b.key,k=b.value;if(!(e.isType(v=n,A)?v:c()).containsKey_11rb$(w))throw N("Failed requirement.".toString());var E="string"==typeof($=(e.isType(g=n,A)?g:c()).get_11rb$(w))?$:c();null!=(y=bt.Companion.create_yyjhqb$(E,null!=k?Nl(k,[Xo().ORDER_BY]):null,null!=k?Cl(k,[Xo().ORDER]):null))&&m.add_11rb$(y)}s=m}else s=null;return null!=(o=s)?o:ut()},br.prototype.inheritToNonDiscrete_qxcvtk$=function(t,e){var n,i=kr(e),r=pt("isDiscrete",function(t,e){return t.isDiscrete_0(e)}.bind(null,this)),o=d();for(n=i.iterator();n.hasNext();){var a=n.next();r(a)||o.add_11rb$(a)}var s,l=d();for(s=o.iterator();s.hasNext();){var u,c,p=s.next();t:do{var h,_,f,m=d();for(_=t.iterator();_.hasNext();){var y=_.next();this.isDiscrete_0(y.variableName)&&m.add_11rb$(y)}e:do{var $;for($=m.iterator();$.hasNext();){var v=$.next();if(H(this.fromDiscrete_0(v.variableName),p)){f=v;break e}}f=null}while(0);if(null==(h=f)){c=null;break t}var g=h,b=g.byVariable;c=bt.Companion.create_yyjhqb$(p,H(b,g.variableName)?null:b,g.getOrderDir())}while(0);null!=(u=c)&&l.add_11rb$(u)}return ft(t,l)},br.$metadata$={kind:b,simpleName:"DataMetaUtil",interfaces:[]};var wr=null;function xr(){return null===wr&&new br,wr}function kr(t){var e,n=t.values,i=k(x(n,10));for(e=n.iterator();e.hasNext();){var r,o=e.next();i.add_11rb$("string"==typeof(r=o)?r:c())}return W(i)}function Er(t){yl.call(this,t)}function Cr(){Tr=this}function Sr(t,e){this.message=t,this.isInternalError=e}Er.prototype.createFacets_wcy4lu$=function(t){var e,n=this.getStringSafe_61zpoe$(Ms().NAME);switch(n){case"grid":e=this.createGrid_0(t);break;case"wrap":e=this.createWrap_0(t);break;default:throw N("Facet 'grid' or 'wrap' expected but was: `"+n+"`")}return e},Er.prototype.createGrid_0=function(t){var e,n,i=null,r=Ct();if(this.has_61zpoe$(Ms().X))for(i=this.getStringSafe_61zpoe$(Ms().X),e=t.iterator();e.hasNext();){var o=e.next();if(V.DataFrameUtil.hasVariable_vede35$(o,i)){var a=V.DataFrameUtil.findVariableOrFail_vede35$(o,i);r.addAll_brywnq$(o.distinctValues_8xm3sj$(a))}}var s=null,l=Ct();if(this.has_61zpoe$(Ms().Y))for(s=this.getStringSafe_61zpoe$(Ms().Y),n=t.iterator();n.hasNext();){var u=n.next();if(V.DataFrameUtil.hasVariable_vede35$(u,s)){var c=V.DataFrameUtil.findVariableOrFail_vede35$(u,s);l.addAll_brywnq$(u.distinctValues_8xm3sj$(c))}}return new Tt(i,s,St(r),St(l),this.getOrderOption_0(Ms().X_ORDER),this.getOrderOption_0(Ms().Y_ORDER),this.getFormatterOption_0(Ms().X_FORMAT),this.getFormatterOption_0(Ms().Y_FORMAT))},Er.prototype.createWrap_0=function(t){var e,n,i=this.getAsStringList_61zpoe$(Ms().FACETS),r=this.getInteger_61zpoe$(Ms().NCOL),o=this.getInteger_61zpoe$(Ms().NROW),a=d();for(e=i.iterator();e.hasNext();){var s=e.next(),l=Ot();for(n=t.iterator();n.hasNext();){var u=n.next();if(V.DataFrameUtil.hasVariable_vede35$(u,s)){var c=V.DataFrameUtil.findVariableOrFail_vede35$(u,s);l.addAll_brywnq$(Z(u.get_8xm3sj$(c)))}}a.add_11rb$(Nt(l))}var p,h=this.getAsList_61zpoe$(Ms().FACETS_ORDER),_=k(x(h,10));for(p=h.iterator();p.hasNext();){var f=p.next();_.add_11rb$(this.toOrderVal_0(f))}for(var m=_,y=i.size,$=k(y),v=0;v")+" : "+(null!=(i=r.message)?i:""),!0)},Sr.$metadata$={kind:v,simpleName:"FailureInfo",interfaces:[]},Cr.$metadata$={kind:b,simpleName:"FailureHandler",interfaces:[]};var Tr=null;function Or(){return null===Tr&&new Cr,Tr}function Nr(t,n,i,r){var o,a,s,l,u,p,h;jr(),this.dataAndCoordinates=null,this.mappings=null;var _,f,d,m=(d=i,function(t){var e,n,i;switch(t){case"map":if(null==(e=Al(d,[ga().GEO_POSITIONS])))throw z("require 'map' parameter".toString());i=e;break;case"data":if(null==(n=Al(d,[sa().DATA])))throw z("require 'data' parameter".toString());i=n;break;default:throw z(("Unknown gdf location: "+t).toString())}var r=i;return V.DataFrameUtil.fromMap_bkhwtg$(r)}),y=Tl(i,[Jo().MAP_DATA_META,Ho().GDF,Ho().GEOMETRY])&&!Tl(i,[_a().MAP_JOIN])&&!n.isEmpty;if(y&&(y=!r.isEmpty()),y){if(!Tl(i,[ga().GEO_POSITIONS]))throw N("'map' parameter is mandatory with MAP_DATA_META".toString());throw z(jr().MAP_JOIN_REQUIRED_MESSAGE.toString())}if(Tl(i,[Jo().MAP_DATA_META,Ho().GDF,Ho().GEOMETRY])&&Tl(i,[_a().MAP_JOIN])){if(!Tl(i,[ga().GEO_POSITIONS]))throw N("'map' parameter is mandatory with MAP_DATA_META".toString());if(null==(o=Ll(i,[_a().MAP_JOIN])))throw z("require map_join parameter".toString());var $=o;s=e.isType(a=$.get_za3lpa$(0),et)?a:c(),l=m(ga().GEO_POSITIONS),p=e.isType(u=$.get_za3lpa$(1),et)?u:c(),_=_r().join_h5afbe$(n,s,l,p),f=V.DataFrameUtil.findVariableOrFail_vede35$(_,jr().getGeometryColumn_gp9epa$(i,ga().GEO_POSITIONS))}else if(Tl(i,[Jo().MAP_DATA_META,Ho().GDF,Ho().GEOMETRY])&&!Tl(i,[_a().MAP_JOIN])){if(!Tl(i,[ga().GEO_POSITIONS]))throw N("'map' parameter is mandatory with MAP_DATA_META".toString());_=m(ga().GEO_POSITIONS),f=V.DataFrameUtil.findVariableOrFail_vede35$(_,jr().getGeometryColumn_gp9epa$(i,ga().GEO_POSITIONS))}else{if(!Tl(i,[Jo().DATA_META,Ho().GDF,Ho().GEOMETRY])||Tl(i,[ga().GEO_POSITIONS])||Tl(i,[_a().MAP_JOIN]))throw z("GeoDataFrame not found in data or map".toString());if(!Tl(i,[sa().DATA]))throw N("'data' parameter is mandatory with DATA_META".toString());_=n,f=V.DataFrameUtil.findVariableOrFail_vede35$(_,jr().getGeometryColumn_gp9epa$(i,sa().DATA))}switch(t.name){case"MAP":case"POLYGON":h=new qr(_,f);break;case"LIVE_MAP":case"POINT":case"TEXT":h=new Ur(_,f);break;case"RECT":h=new Gr(_,f);break;case"PATH":h=new Fr(_,f);break;default:throw z(("Unsupported geom: "+t).toString())}var v=h;this.dataAndCoordinates=v.buildDataFrame(),this.mappings=_r().createAesMapping_5bl3vv$(this.dataAndCoordinates,gt(r,v.mappings))}function Pr(){Ar=this,this.GEO_ID="__geo_id__",this.POINT_X="lon",this.POINT_Y="lat",this.RECT_XMIN="lonmin",this.RECT_YMIN="latmin",this.RECT_XMAX="lonmax",this.RECT_YMAX="latmax",this.MAP_JOIN_REQUIRED_MESSAGE="map_join is required when both data and map parameters used"}Pr.prototype.isApplicable_t8fn1w$=function(t,n){var i,r=n.keys,o=d();for(i=r.iterator();i.hasNext();){var a,s;null!=(a="string"==typeof(s=i.next())?s:null)&&o.add_11rb$(a)}var l,u=d();for(l=o.iterator();l.hasNext();){var p,h,_=l.next();try{h=new ee(Fs().toAes_61zpoe$(_))}catch(t){if(!e.isType(t,ne))throw t;h=new ee(ie(t))}var f,m=h;null!=(p=m.isFailure?null:null==(f=m.value)||e.isType(f,re)?f:c())&&u.add_11rb$(p)}var y,$=pt("isPositional",function(t,e){return t.isPositional_896ixz$(e)}.bind(null,Dt.Companion));t:do{var v;if(e.isType(u,oe)&&u.isEmpty()){y=!1;break t}for(v=u.iterator();v.hasNext();)if($(v.next())){y=!0;break t}y=!1}while(0);return!y&&(Tl(t,[Jo().MAP_DATA_META,Ho().GDF,Ho().GEOMETRY])||Tl(t,[Jo().DATA_META,Ho().GDF,Ho().GEOMETRY]))},Pr.prototype.isGeoDataframe_gp9epa$=function(t,e){return Tl(t,[this.toDataMetaKey_0(e),Ho().GDF,Ho().GEOMETRY])},Pr.prototype.getGeometryColumn_gp9epa$=function(t,e){var n;if(null==(n=Nl(t,[this.toDataMetaKey_0(e),Ho().GDF,Ho().GEOMETRY])))throw z("Geometry column not set".toString());return n},Pr.prototype.toDataMetaKey_0=function(t){switch(t){case"map":return Jo().MAP_DATA_META;case"data":return Jo().DATA_META;default:throw z(("Unknown gdf role: '"+t+"'. Expected: '"+ga().GEO_POSITIONS+"' or '"+sa().DATA+"'").toString())}},Pr.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Ar=null;function jr(){return null===Ar&&new Pr,Ar}function Lr(t,e,n){Vr(),this.dataFrame_0=t,this.geometries_0=e,this.mappings=n,this.dupCounter_0=d();var i,r=this.mappings.values,o=xt(wt(x(r,10)),16),a=kt(o);for(i=r.iterator();i.hasNext();){var s=i.next();a.put_xwzc9p$(s,d())}this.coordinates_0=a}function Rr(t){return y}function Ir(t){return y}function zr(t){return y}function Dr(t){return y}function Mr(t){return y}function Br(t){return y}function Ur(t,e){var n;Lr.call(this,t,e,Vr().POINT_COLUMNS),this.supportedFeatures_njr4m6$_0=_("Point, MultiPoint"),this.geoJsonConsumer_4woj0e$_0=this.defaultConsumer_5s5pfw$((n=this,function(t){return t.onPoint=function(t){return function(e){return Vr().append_ad8zgy$(t.coordinates_0,e),y}}(n),t.onMultiPoint=function(t){return function(e){var n;for(n=e.iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_ad8zgy$(r.coordinates_0,i)}return y}}(n),y}))}function Fr(t,e){var n;Lr.call(this,t,e,Vr().POINT_COLUMNS),this.supportedFeatures_ozgutd$_0=_("LineString, MultiLineString"),this.geoJsonConsumer_idjvc5$_0=this.defaultConsumer_5s5pfw$((n=this,function(t){return t.onLineString=function(t){return function(e){var n;for(n=e.iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_ad8zgy$(r.coordinates_0,i)}return y}}(n),t.onMultiLineString=function(t){return function(e){var n;for(n=Gt(qt(e)).iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_ad8zgy$(r.coordinates_0,i)}return y}}(n),y}))}function qr(t,e){var n;Lr.call(this,t,e,Vr().POINT_COLUMNS),this.supportedFeatures_d0rxnq$_0=_("Polygon, MultiPolygon"),this.geoJsonConsumer_noor7u$_0=this.defaultConsumer_5s5pfw$((n=this,function(t){return t.onPolygon=function(t){return function(e){var n;for(n=Gt(qt(e)).iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_ad8zgy$(r.coordinates_0,i)}return y}}(n),t.onMultiPolygon=function(t){return function(e){var n;for(n=Gt(Gt(qt(e))).iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_ad8zgy$(r.coordinates_0,i)}return y}}(n),y}))}function Gr(t,e){var n;Lr.call(this,t,e,Vr().RECT_MAPPINGS),this.supportedFeatures_bieyrp$_0=_("MultiPoint, LineString, MultiLineString, Polygon, MultiPolygon"),this.geoJsonConsumer_w3z015$_0=this.defaultConsumer_5s5pfw$((n=this,function(t){var e,i=function(t){return function(e){var n;for(n=Yt(pt("union",function(t,e){return Ht(t,e)}.bind(null,Mt.BBOX_CALCULATOR))(e)).splitByAntiMeridian().iterator();n.hasNext();){var i=n.next(),r=t;Vr().append_4y8q68$(r.coordinates_0,i)}}}(n),r=(e=i,function(t){e(_(t))});return t.onMultiPoint=function(t){return function(e){return t(Vt(e)),y}}(r),t.onLineString=function(t){return function(e){return t(Vt(e)),y}}(r),t.onMultiLineString=function(t){return function(e){return t(Vt(_t(e))),y}}(r),t.onPolygon=function(t){return function(e){return t(Kt(e)),y}}(r),t.onMultiPolygon=function(t){return function(e){return t(Wt(e)),y}}(i),y}))}function Hr(){Yr=this,this.POINT_COLUMNS=te([ct(Dt.Companion.X.name,jr().POINT_X),ct(Dt.Companion.Y.name,jr().POINT_Y)]),this.RECT_MAPPINGS=te([ct(Dt.Companion.XMIN.name,jr().RECT_XMIN),ct(Dt.Companion.YMIN.name,jr().RECT_YMIN),ct(Dt.Companion.XMAX.name,jr().RECT_XMAX),ct(Dt.Companion.YMAX.name,jr().RECT_YMAX)])}Nr.$metadata$={kind:v,simpleName:"GeoConfig",interfaces:[]},Lr.prototype.duplicate_0=function(t,e){var n,i,r=k(x(e,10)),o=0;for(n=e.iterator();n.hasNext();){for(var a=n.next(),s=r.add_11rb$,l=ot((o=(i=o)+1|0,i)),u=k(a),c=0;c=2)){var n=t+" requires a list of 2 but was "+e.size;throw N(n.toString())}return new D(e.get_za3lpa$(0),e.get_za3lpa$(1))},yl.prototype.getNumList_61zpoe$=function(t){var n;return e.isType(n=this.getNumList_q98glf$_0(t,gl),et)?n:c()},yl.prototype.getNumQList_61zpoe$=function(t){return this.getNumList_q98glf$_0(t,bl)},yl.prototype.getNumber_p2oh8l$_0=function(t){var n;if(null==(n=this.get_61zpoe$(t)))return null;var i=n;if(!e.isNumber(i)){var r="Parameter '"+t+"' expected to be a Number, but was "+f(e.getKClassFromExpression(i).simpleName);throw N(r.toString())}return i},yl.prototype.getNumList_q98glf$_0=function(t,n){var i,r,o=this.getList_61zpoe$(t);return El().requireAll_0(o,n,(r=t,function(t){return r+" requires a list of numbers but not numeric encountered: "+f(t)})),e.isType(i=o,et)?i:c()},yl.prototype.getAsList_61zpoe$=function(t){var n,i=null!=(n=this.get_61zpoe$(t))?n:ut();return e.isType(i,et)?i:_(i)},yl.prototype.getAsStringList_61zpoe$=function(t){var e,n=Z(this.getAsList_61zpoe$(t)),i=k(x(n,10));for(e=n.iterator();e.hasNext();){var r=e.next();i.add_11rb$(r.toString())}return i},yl.prototype.getStringList_61zpoe$=function(t){var n,i,r=this.getList_61zpoe$(t);return El().requireAll_0(r,wl,(i=t,function(t){return i+" requires a list of strings but not string encountered: "+f(t)})),e.isType(n=r,et)?n:c()},yl.prototype.getRange_y4putb$=function(t){if(!this.has_61zpoe$(t))throw N("'Range' value is expected in form: [min, max]".toString());var e=this.getRangeOrNull_61zpoe$(t);if(null==e){var n="'range' value is expected in form: [min, max] but was: "+f(this.get_61zpoe$(t));throw N(n.toString())}return e},yl.prototype.getRangeOrNull_61zpoe$=function(t){var n,i,r,o=this.get_61zpoe$(t),a=e.isType(o,et)&&2===o.size;if(a){var s;t:do{var l;if(e.isType(o,oe)&&o.isEmpty()){s=!0;break t}for(l=o.iterator();l.hasNext();){var u=l.next();if(!e.isNumber(u)){s=!1;break t}}s=!0}while(0);a=s}if(!0!==a)return null;var p=nt(e.isNumber(n=Fe(o))?n:c()),h=nt(e.isNumber(i=Qe(o))?i:c());try{r=new tn(p,h)}catch(t){if(!e.isType(t,ne))throw t;r=null}return r},yl.prototype.getMap_61zpoe$=function(t){var n,i;if(null==(n=this.get_61zpoe$(t)))return tt();var r=n;if(!e.isType(r,A)){var o="Not a Map: "+t+": "+e.getKClassFromExpression(r).simpleName;throw N(o.toString())}return e.isType(i=r,A)?i:c()},yl.prototype.getBoolean_ivxn3r$=function(t,e){var n,i;return void 0===e&&(e=!1),null!=(i="boolean"==typeof(n=this.get_61zpoe$(t))?n:null)?i:e},yl.prototype.getDouble_61zpoe$=function(t){var e;return null!=(e=this.getNumber_p2oh8l$_0(t))?nt(e):null},yl.prototype.getInteger_61zpoe$=function(t){var e;return null!=(e=this.getNumber_p2oh8l$_0(t))?C(e):null},yl.prototype.getLong_61zpoe$=function(t){var e;return null!=(e=this.getNumber_p2oh8l$_0(t))?en(e):null},yl.prototype.getDoubleDef_io5o9c$=function(t,e){var n;return null!=(n=this.getDouble_61zpoe$(t))?n:e},yl.prototype.getIntegerDef_bm4lxs$=function(t,e){var n;return null!=(n=this.getInteger_61zpoe$(t))?n:e},yl.prototype.getLongDef_4wgjuj$=function(t,e){var n;return null!=(n=this.getLong_61zpoe$(t))?n:e},yl.prototype.getValueOrNull_qu2sip$_0=function(t,e){var n;return null==(n=this.get_61zpoe$(t))?null:e(n)},yl.prototype.getColor_61zpoe$=function(t){return this.getValue_1va84n$(Dt.Companion.COLOR,t)},yl.prototype.getShape_61zpoe$=function(t){return this.getValue_1va84n$(Dt.Companion.SHAPE,t)},yl.prototype.getValue_1va84n$=function(t,e){var n;if(null==(n=this.get_61zpoe$(e)))return null;var i=n;return rc().apply_kqseza$(t,i)},xl.prototype.over_x7u0o8$=function(t){return new yl(t)},xl.prototype.requireAll_0=function(t,e,n){var i,r,o=d();for(r=t.iterator();r.hasNext();){var a=r.next();e(a)||o.add_11rb$(a)}if(null!=(i=nn(o))){var s=n(i);throw N(s.toString())}},xl.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var kl=null;function El(){return null===kl&&new xl,kl}function Cl(t,e){return Sl(t,rn(e,1),on(e))}function Sl(t,e,n){var i;return null!=(i=jl(t,e))?i.get_11rb$(n):null}function Tl(t,e){return Ol(t,rn(e,1),on(e))}function Ol(t,e,n){var i,r;return null!=(r=null!=(i=jl(t,e))?i.containsKey_11rb$(n):null)&&r}function Nl(t,e){return Pl(t,rn(e,1),on(e))}function Pl(t,e,n){var i,r;return"string"==typeof(r=null!=(i=jl(t,e))?i.get_11rb$(n):null)?r:null}function Al(t,e){var n;return null!=(n=jl(t,an(e)))?zl(n):null}function jl(t,n){var i,r,o=t;for(r=n.iterator();r.hasNext();){var a,s=r.next(),l=o;t:do{var u,c,p;if(null==(c=null!=(u=null!=l?Cl(l,[s]):null)&&e.isType(p=u,A)?p:null)){a=null;break t}a=c}while(0);o=a}return null!=(i=o)?zl(i):null}function Ll(t,e){return Rl(t,rn(e,1),on(e))}function Rl(t,n,i){var r,o;return e.isType(o=null!=(r=jl(t,n))?r.get_11rb$(i):null,et)?o:null}function Il(t,n){var i,r,o;if(null!=(i=Ll(t,n.slice()))){var a,s=d();for(a=i.iterator();a.hasNext();){var l,u,c=a.next();null!=(l=e.isType(u=c,A)?u:null)&&s.add_11rb$(l)}o=s}else o=null;return null!=(r=o)?Nt(r):null}function zl(t){var n;return e.isType(n=t,A)?n:c()}function Dl(t){var e,n;Ul(),yl.call(this,t,Ul().DEF_OPTIONS_0),this.layerConfigs=null,this.facets=null,this.scaleMap=null,this.scaleConfigs=null,this.sharedData_n7yy0l$_0=null;var i=xr().createDataFrame_dgfi6i$(this,Y.Companion.emptyFrame(),ht(),tt(),this.isClientSide),r=i.component1(),o=i.component2();this.sharedData=o,this.isClientSide||this.update_bm4g0d$(sa().MAPPING,r),this.layerConfigs=this.createLayerConfigs_usvduj$_0(this.sharedData);var a=!this.isClientSide;this.scaleConfigs=this.createScaleConfigs_9ma18$(ft(this.getList_61zpoe$(ca().SCALES),xr().createScaleSpecs_x7u0o8$(t)));var s=Ql().createScaleProviders_4llv70$(this.layerConfigs,this.scaleConfigs,a),l=Ql().createTransforms_9cm35a$(this.layerConfigs,s,a);if(this.scaleMap=Ql().createScales_a30s6a$(this.layerConfigs,l,s,a),this.has_61zpoe$(ca().FACET)){var u=new Er(this.getMap_61zpoe$(ca().FACET)),c=d();for(e=this.layerConfigs.iterator();e.hasNext();){var p=e.next();c.add_11rb$(p.combinedData)}n=u.createFacets_wcy4lu$(c)}else n=P.Companion.undefined();this.facets=n}function Ml(){Bl=this,this.ERROR_MESSAGE_0="__error_message",this.DEF_OPTIONS_0=ye(ct(ca().COORD,hl().CARTESIAN)),this.PLOT_COMPUTATION_MESSAGES_8be2vx$="computation_messages"}yl.$metadata$={kind:v,simpleName:"OptionsAccessor",interfaces:[]},Object.defineProperty(Dl.prototype,"sharedData",{configurable:!0,get:function(){return this.sharedData_n7yy0l$_0},set:function(t){this.sharedData_n7yy0l$_0=t}}),Object.defineProperty(Dl.prototype,"title",{configurable:!0,get:function(){var t;return null==(t=this.getMap_61zpoe$(ca().TITLE).get_11rb$(ca().TITLE_TEXT))||"string"==typeof t?t:c()}}),Object.defineProperty(Dl.prototype,"isClientSide",{configurable:!0,get:function(){return!1}}),Object.defineProperty(Dl.prototype,"containsLiveMap",{configurable:!0,get:function(){var t,n=this.layerConfigs,i=De("isLiveMap",1,(function(t){return t.isLiveMap}));t:do{var r;if(e.isType(n,oe)&&n.isEmpty()){t=!1;break t}for(r=n.iterator();r.hasNext();)if(i(r.next())){t=!0;break t}t=!1}while(0);return t}}),Dl.prototype.createScaleConfigs_9ma18$=function(t){var n,i,r,o=X();for(n=t.iterator();n.hasNext();){var a=n.next(),s=e.isType(i=a,A)?i:c(),l=Ou().aesOrFail_x7u0o8$(s);if(!o.containsKey_11rb$(l)){var u=X();o.put_xwzc9p$(l,u)}L(o.get_11rb$(l)).putAll_a2k3zr$(s)}var p=d();for(r=o.values.iterator();r.hasNext();){var h=r.next();p.add_11rb$(new _u(h))}return p},Dl.prototype.createLayerConfigs_usvduj$_0=function(t){var n,i=d();for(n=this.getList_61zpoe$(ca().LAYERS).iterator();n.hasNext();){var r=n.next();if(!e.isType(r,A)){var o="Layer options: expected Map but was "+f(e.getKClassFromExpression(L(r)).simpleName);throw N(o.toString())}e.isType(r,A)||c();var a=this.createLayerConfig_ookg2q$(r,t,this.getMap_61zpoe$(sa().MAPPING),xr().getAsDiscreteAesSet_bkhwtg$(this.getMap_61zpoe$(Jo().DATA_META)),xr().getOrderOptions_tjia25$(this.mergedOptions,this.getMap_61zpoe$(sa().MAPPING)));i.add_11rb$(a)}return i},Dl.prototype.replaceSharedData_dhhkv7$=function(t){if(this.isClientSide)throw z("Check failed.".toString());this.sharedData=t,this.update_bm4g0d$(sa().DATA,V.DataFrameUtil.toMap_dhhkv7$(t))},Ml.prototype.failure_61zpoe$=function(t){return ye(ct(this.ERROR_MESSAGE_0,t))},Ml.prototype.assertPlotSpecOrErrorMessage_x7u0o8$=function(t){if(!(this.isFailure_x7u0o8$(t)||this.isPlotSpec_bkhwtg$(t)||this.isGGBunchSpec_bkhwtg$(t)))throw N("Invalid root feature kind: absent or unsupported `kind` key")},Ml.prototype.assertPlotSpec_x7u0o8$=function(t){if(!this.isPlotSpec_bkhwtg$(t)&&!this.isGGBunchSpec_bkhwtg$(t))throw N("Invalid root feature kind: absent or unsupported `kind` key")},Ml.prototype.isFailure_x7u0o8$=function(t){return t.containsKey_11rb$(this.ERROR_MESSAGE_0)},Ml.prototype.getErrorMessage_x7u0o8$=function(t){return f(t.get_11rb$(this.ERROR_MESSAGE_0))},Ml.prototype.isPlotSpec_bkhwtg$=function(t){return H(Bo().PLOT,this.specKind_bkhwtg$(t))},Ml.prototype.isGGBunchSpec_bkhwtg$=function(t){return H(Bo().GG_BUNCH,this.specKind_bkhwtg$(t))},Ml.prototype.specKind_bkhwtg$=function(t){var n,i=Jo().KIND;return(e.isType(n=t,A)?n:c()).get_11rb$(i)},Ml.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Bl=null;function Ul(){return null===Bl&&new Ml,Bl}function Fl(t){var n,i;Hl(),Dl.call(this,t),this.theme_8be2vx$=new Lc(this.getMap_61zpoe$(ca().THEME)).theme,this.coordProvider_8be2vx$=null,this.guideOptionsMap_8be2vx$=null;var r=yr().create_za3rmp$(L(this.get_61zpoe$(ca().COORD))).coord;if(!this.hasOwn_61zpoe$(ca().COORD))for(n=this.layerConfigs.iterator();n.hasNext();){var o=n.next(),a=e.isType(i=o.geomProto,ro)?i:c();a.hasPreferredCoordinateSystem()&&(r=a.preferredCoordinateSystem())}this.coordProvider_8be2vx$=r,this.guideOptionsMap_8be2vx$=gt(Kl().createGuideOptionsMap_v6zdyz$(this.scaleConfigs),Kl().createGuideOptionsMap_e6mjjf$(this.getMap_61zpoe$(ca().GUIDES)))}function ql(){Gl=this}Dl.$metadata$={kind:v,simpleName:"PlotConfig",interfaces:[yl]},Object.defineProperty(Fl.prototype,"isClientSide",{configurable:!0,get:function(){return!0}}),Fl.prototype.createLayerConfig_ookg2q$=function(t,e,n,i,r){var o,a="string"==typeof(o=t.get_11rb$(_a().GEOM))?o:c();return new wo(t,e,n,i,r,new ro(ul().toGeomKind_61zpoe$(a)),!0)},ql.prototype.processTransform_2wxo1b$=function(t){var e=t,n=Ul().isGGBunchSpec_bkhwtg$(e);return e=ip().builderForRawSpec().build().apply_i49brq$(e),ip().builderForRawSpec().change_t6n62v$(Sp().specSelector_6taknv$(n),new kp).build().apply_i49brq$(e)},ql.prototype.create_vb0rb2$=function(t,e){var n=Ql().findComputationMessages_x7u0o8$(t);return n.isEmpty()||e(n),new Fl(t)},ql.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Gl=null;function Hl(){return null===Gl&&new ql,Gl}function Yl(){Vl=this}Fl.$metadata$={kind:v,simpleName:"PlotConfigClientSide",interfaces:[Dl]},Yl.prototype.createGuideOptionsMap_v6zdyz$=function(t){var e,n=X();for(e=t.iterator();e.hasNext();){var i=e.next();if(i.hasGuideOptions()){var r=i.getGuideOptions().createGuideOptions(),o=i.aes;n.put_xwzc9p$(o,r)}}return n},Yl.prototype.createGuideOptionsMap_e6mjjf$=function(t){var e,n=X();for(e=t.entries.iterator();e.hasNext();){var i=e.next(),r=i.key,o=i.value,a=Fs().toAes_61zpoe$(r),s=go().create_za3rmp$(o).createGuideOptions();n.put_xwzc9p$(a,s)}return n},Yl.prototype.createPlotAssembler_6u1zvq$=function(t){var e=this.buildPlotLayers_0(t),n=sn.Companion.multiTile_bm7ueq$(t.scaleMap,e,t.coordProvider_8be2vx$,t.theme_8be2vx$);return n.setTitle_pdl1vj$(t.title),n.setGuideOptionsMap_qayxze$(t.guideOptionsMap_8be2vx$),n.facets=t.facets,n},Yl.prototype.buildPlotLayers_0=function(t){var n,i,r=d();for(n=t.layerConfigs.iterator();n.hasNext();){var o=n.next().combinedData;r.add_11rb$(o)}var a=Ql().toLayersDataByTile_rxbkhd$(r,t.facets),s=d(),l=d();for(i=a.iterator();i.hasNext();){var u,c=i.next(),p=d(),h=c.size>1,_=t.layerConfigs;t:do{var f;if(e.isType(_,oe)&&_.isEmpty()){u=!1;break t}for(f=_.iterator();f.hasNext();)if(f.next().geomProto.geomKind===se.LIVE_MAP){u=!0;break t}u=!1}while(0);for(var m=u,y=0;y!==c.size;++y){if(!(s.size>=y))throw z("Check failed.".toString());if(s.size===y){var $=t.layerConfigs.get_za3lpa$(y),v=Zr().configGeomTargets_hra3pl$($,t.scaleMap,h,m,t.theme_8be2vx$);s.add_11rb$(this.createLayerBuilder_0($,v))}var g=c.get_za3lpa$(y),b=s.get_za3lpa$(y).build_fhj1j$(g,t.scaleMap);p.add_11rb$(b)}l.add_11rb$(p)}return l},Yl.prototype.createLayerBuilder_0=function(t,n){var i,r,o,a,s=(e.isType(i=t.geomProto,ro)?i:c()).geomProvider_opf53k$(t),l=t.stat,u=(new ln).stat_qbwusa$(l).geom_9dfz59$(s).pos_r08v3h$(t.posProvider),p=t.constantsMap;for(r=p.keys.iterator();r.hasNext();){var h=r.next();u.addConstantAes_bbdhip$(e.isType(o=h,Dt)?o:c(),L(p.get_11rb$(h)))}for(t.hasExplicitGrouping()&&u.groupingVarName_61zpoe$(L(t.explicitGroupingVarName)),null!=V.DataFrameUtil.variables_dhhkv7$(t.combinedData).get_11rb$(jr().GEO_ID)&&u.pathIdVarName_61zpoe$(jr().GEO_ID),a=t.varBindings.iterator();a.hasNext();){var _=a.next();u.addBinding_14cn14$(_)}return u.disableLegend_6taknv$(t.isLegendDisabled),u.locatorLookupSpec_271kgc$(n.createLookupSpec()).contextualMappingProvider_td8fxc$(n),u},Yl.$metadata$={kind:b,simpleName:"PlotConfigClientSideUtil",interfaces:[]};var Vl=null;function Kl(){return null===Vl&&new Yl,Vl}function Wl(){Jl=this}function Xl(t){var e;return"string"==typeof(e=t)?e:c()}function Zl(t,e){return function(n,i){var r,o;if(i){var a=Ct(),s=Ct();for(r=n.iterator();r.hasNext();){var l=r.next(),u=fn(t,l);a.addAll_brywnq$(u.domainValues),s.addAll_brywnq$(u.domainLimits)}o=new dn(a,Nt(s))}else o=n.isEmpty()?mn.Transforms.IDENTITY:fn(e,Fe(n));return o}}Wl.prototype.toLayersDataByTile_rxbkhd$=function(t,e){var n,i;if(e.isDefined){for(var r=e.numTiles,o=k(r),a=0;a1&&(H(t,Dt.Companion.X)||H(t,Dt.Companion.Y))?t.name:S(a)}else e=t.name;return e}),D=X();for(a=vt(d,pn([Dt.Companion.X,Dt.Companion.Y])).iterator();a.hasNext();){var M=a.next(),B=z(M),U=fn(i,M),F=fn(n,M);if(e.isType(F,dn))s=U.createScale_4d40sm$(B,F.domainValues);else if(I.containsKey_11rb$(M)){var q=fn(I,M);s=U.createScale_phlls$(B,q)}else s=U.createScale_phlls$(B,tn.Companion.singleton_f1zjgi$(0));var G=s;D.put_xwzc9p$(M,G)}return new $n(D)},Wl.prototype.computeContinuousDomain_0=function(t,e,n){var i;if(n.hasDomainLimits()){var r,o=t.getNumeric_8xm3sj$(e),a=d();for(r=o.iterator();r.hasNext();){var s=r.next();n.isInDomain_yrwdxb$(s)&&a.add_11rb$(s)}var l=a;i=je.SeriesUtil.range_l63ks6$(l)}else i=t.range_8xm3sj$(e);return i},Wl.prototype.isDiscreteScaleForEmptyData_0=function(t){var n,i;if(t.discreteDomain)return!0;var r=t.mapperProvider;if(e.isType(r,vn))return!0;if(e.isType(r,gn))return!1;var o,a=t.breaks,s=t.limits;if(null!=a){var l;t:do{var u;if(e.isType(a,oe)&&a.isEmpty()){l=!1;break t}for(u=a.iterator();u.hasNext();){var c=u.next();if(!e.isNumber(c)){l=!0;break t}}l=!1}while(0);o=l}else o=null;var p,h=null!=(n=o)&&n;if(null!=s){var _;if(s.size>2)_=!0;else{var f,d=Z(s);t:do{var m;if(e.isType(d,oe)&&d.isEmpty()){f=!1;break t}for(m=d.iterator();m.hasNext();){var y=m.next();if(!e.isNumber(y)){f=!0;break t}}f=!1}while(0);_=f}p=_}else p=null;var $=null!=(i=p)&&i;return h||$},Wl.$metadata$={kind:b,simpleName:"PlotConfigUtil",interfaces:[]};var Jl=null;function Ql(){return null===Jl&&new Wl,Jl}function tu(t,e){iu(),yl.call(this,e),this.pos=au().createPosProvider_d0u64m$(t,this.mergedOptions)}function eu(){nu=this}eu.prototype.create_za3rmp$=function(t){var n;if(e.isType(t,A)){var i=bn(e.isType(n=t,A)?n:c());return this.createForName_0(_r().featureName_bkhwtg$(i),i)}return this.createForName_0(t.toString(),X())},eu.prototype.createForName_0=function(t,e){return new tu(t,e)},eu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var nu=null;function iu(){return null===nu&&new eu,nu}function ru(){ou=this,this.IDENTITY_0="identity",this.STACK_8be2vx$="stack",this.DODGE_0="dodge",this.FILL_0="fill",this.NUDGE_0="nudge",this.JITTER_0="jitter",this.JITTER_DODGE_0="jitterdodge",this.DODGE_WIDTH_0="width",this.JITTER_WIDTH_0="width",this.JITTER_HEIGHT_0="height",this.NUDGE_WIDTH_0="x",this.NUDGE_HEIGHT_0="y",this.JD_DODGE_WIDTH_0="dodge_width",this.JD_JITTER_WIDTH_0="jitter_width",this.JD_JITTER_HEIGHT_0="jitter_height"}tu.$metadata$={kind:v,simpleName:"PosConfig",interfaces:[yl]},ru.prototype.createPosProvider_d0u64m$=function(t,e){var n,i=new yl(e);switch(t){case"identity":n=de.Companion.wrap_dkjclg$(me.PositionAdjustments.identity());break;case"stack":n=de.Companion.barStack();break;case"dodge":n=de.Companion.dodge_yrwdxb$(i.getDouble_61zpoe$(this.DODGE_WIDTH_0));break;case"fill":n=de.Companion.fill();break;case"jitter":n=de.Companion.jitter_jma9l8$(i.getDouble_61zpoe$(this.JITTER_WIDTH_0),i.getDouble_61zpoe$(this.JITTER_HEIGHT_0));break;case"nudge":n=de.Companion.nudge_jma9l8$(i.getDouble_61zpoe$(this.NUDGE_WIDTH_0),i.getDouble_61zpoe$(this.NUDGE_HEIGHT_0));break;case"jitterdodge":n=de.Companion.jitterDodge_xjrefz$(i.getDouble_61zpoe$(this.JD_DODGE_WIDTH_0),i.getDouble_61zpoe$(this.JD_JITTER_WIDTH_0),i.getDouble_61zpoe$(this.JD_JITTER_HEIGHT_0));break;default:throw N("Unknown position adjustments name: '"+t+"'")}return n},ru.$metadata$={kind:b,simpleName:"PosProto",interfaces:[]};var ou=null;function au(){return null===ou&&new ru,ou}function su(){lu=this}su.prototype.create_za3rmp$=function(t){var n,i;if(e.isType(t,u)&&_r().isFeatureList_511yu9$(t)){var r=_r().featuresInFeatureList_ui7x64$(e.isType(n=t,u)?n:c()),o=d();for(i=r.iterator();i.hasNext();){var a=i.next();o.add_11rb$(this.createOne_0(a))}return o}return _(this.createOne_0(t))},su.prototype.createOne_0=function(t){var n;if(e.isType(t,A))return hu().createSampling_d0u64m$(_r().featureName_bkhwtg$(t),e.isType(n=t,A)?n:c());if(H(il().NONE,t))return fe.Samplings.NONE;throw N("Incorrect sampling specification")},su.$metadata$={kind:b,simpleName:"SamplingConfig",interfaces:[]};var lu=null;function uu(){return null===lu&&new su,lu}function cu(){pu=this}cu.prototype.createSampling_d0u64m$=function(t,e){var n,i=El().over_x7u0o8$(e);switch(t){case"random":n=fe.Samplings.random_280ow0$(L(i.getInteger_61zpoe$(il().N)),i.getLong_61zpoe$(il().SEED));break;case"pick":n=fe.Samplings.pick_za3lpa$(L(i.getInteger_61zpoe$(il().N)));break;case"systematic":n=fe.Samplings.systematic_za3lpa$(L(i.getInteger_61zpoe$(il().N)));break;case"group_random":n=fe.Samplings.randomGroup_280ow0$(L(i.getInteger_61zpoe$(il().N)),i.getLong_61zpoe$(il().SEED));break;case"group_systematic":n=fe.Samplings.systematicGroup_za3lpa$(L(i.getInteger_61zpoe$(il().N)));break;case"random_stratified":n=fe.Samplings.randomStratified_vcwos1$(L(i.getInteger_61zpoe$(il().N)),i.getLong_61zpoe$(il().SEED),i.getInteger_61zpoe$(il().MIN_SUB_SAMPLE));break;case"vertex_vw":n=fe.Samplings.vertexVw_za3lpa$(L(i.getInteger_61zpoe$(il().N)));break;case"vertex_dp":n=fe.Samplings.vertexDp_za3lpa$(L(i.getInteger_61zpoe$(il().N)));break;default:throw N("Unknown sampling method: '"+t+"'")}return n},cu.$metadata$={kind:b,simpleName:"SamplingProto",interfaces:[]};var pu=null;function hu(){return null===pu&&new cu,pu}function _u(t){var n;Ou(),yl.call(this,t),this.aes=e.isType(n=Ou().aesOrFail_x7u0o8$(t),Dt)?n:c()}function fu(t){return"'"+t+"'"}function du(){Tu=this,this.IDENTITY_0="identity",this.COLOR_GRADIENT_0="color_gradient",this.COLOR_GRADIENT2_0="color_gradient2",this.COLOR_HUE_0="color_hue",this.COLOR_GREY_0="color_grey",this.COLOR_BREWER_0="color_brewer",this.SIZE_AREA_0="size_area"}_u.prototype.createScaleProvider=function(){return this.createScaleProviderBuilder_0().build()},_u.prototype.createScaleProviderBuilder_0=function(){var t,n,i,r,o,a,s,l,u,p,h,_,f=null,d=this.has_61zpoe$(Is().NA_VALUE)?L(this.getValue_1va84n$(this.aes,Is().NA_VALUE)):hn.DefaultNaValue.get_31786j$(this.aes);if(this.has_61zpoe$(Is().OUTPUT_VALUES)){var m=this.getList_61zpoe$(Is().OUTPUT_VALUES),y=rc().applyToList_s6xytz$(this.aes,m);f=hn.DefaultMapperProviderUtil.createWithDiscreteOutput_rath1t$(y,d)}if(H(this.aes,Dt.Companion.SHAPE)){var $=this.get_61zpoe$(Is().SHAPE_SOLID);"boolean"==typeof $&&H($,!1)&&(f=hn.DefaultMapperProviderUtil.createWithDiscreteOutput_rath1t$(wn.ShapeMapper.hollowShapes(),wn.ShapeMapper.NA_VALUE))}else H(this.aes,Dt.Companion.ALPHA)&&this.has_61zpoe$(Is().RANGE)?f=new xn(this.getRange_y4putb$(Is().RANGE),"number"==typeof(t=d)?t:c()):H(this.aes,Dt.Companion.SIZE)&&this.has_61zpoe$(Is().RANGE)&&(f=new kn(this.getRange_y4putb$(Is().RANGE),"number"==typeof(n=d)?n:c()));var v=this.getBoolean_ivxn3r$(Is().DISCRETE_DOMAIN),g=this.getBoolean_ivxn3r$(Is().DISCRETE_DOMAIN_REVERSE),b=null!=(i=this.getString_61zpoe$(Is().SCALE_MAPPER_KIND))?i:!this.has_61zpoe$(Is().OUTPUT_VALUES)&&v&&pn([Dt.Companion.FILL,Dt.Companion.COLOR]).contains_11rb$(this.aes)?Ou().COLOR_BREWER_0:null;if(null!=b)switch(b){case"identity":f=Ou().createIdentityMapperProvider_bbdhip$(this.aes,d);break;case"color_gradient":f=new Cn(this.getColor_61zpoe$(Is().LOW),this.getColor_61zpoe$(Is().HIGH),e.isType(r=d,En)?r:c());break;case"color_gradient2":f=new Sn(this.getColor_61zpoe$(Is().LOW),this.getColor_61zpoe$(Is().MID),this.getColor_61zpoe$(Is().HIGH),this.getDouble_61zpoe$(Is().MIDPOINT),e.isType(o=d,En)?o:c());break;case"color_hue":f=new Tn(this.getDoubleList_61zpoe$(Is().HUE_RANGE),this.getDouble_61zpoe$(Is().CHROMA),this.getDouble_61zpoe$(Is().LUMINANCE),this.getDouble_61zpoe$(Is().START_HUE),this.getDouble_61zpoe$(Is().DIRECTION),e.isType(a=d,En)?a:c());break;case"color_grey":f=new On(this.getDouble_61zpoe$(Is().START),this.getDouble_61zpoe$(Is().END),e.isType(s=d,En)?s:c());break;case"color_brewer":f=new Nn(this.getString_61zpoe$(Is().PALETTE_TYPE),this.get_61zpoe$(Is().PALETTE),this.getDouble_61zpoe$(Is().DIRECTION),e.isType(l=d,En)?l:c());break;case"size_area":f=new Pn(this.getDouble_61zpoe$(Is().MAX_SIZE),"number"==typeof(u=d)?u:c());break;default:throw N("Aes '"+this.aes.name+"' - unexpected scale mapper kind: '"+b+"'")}var w=new An(this.aes);if(null!=f&&w.mapperProvider_dw300d$(e.isType(p=f,jn)?p:c()),w.discreteDomain_6taknv$(v),w.discreteDomainReverse_6taknv$(g),this.getBoolean_ivxn3r$(Is().DATE_TIME)){var x=null!=(h=this.getString_61zpoe$(Is().FORMAT))?Ln.Formatter.time_61zpoe$(h):null;w.breaksGenerator_6q5k0b$(new Rn(x))}else if(!v&&this.has_61zpoe$(Is().CONTINUOUS_TRANSFORM)){var k=this.getStringSafe_61zpoe$(Is().CONTINUOUS_TRANSFORM);switch(k.toLowerCase()){case"identity":_=mn.Transforms.IDENTITY;break;case"log10":_=mn.Transforms.LOG10;break;case"reverse":_=mn.Transforms.REVERSE;break;case"sqrt":_=mn.Transforms.SQRT;break;default:throw N("Unknown transform name: '"+k+"'. Supported: "+S(le([dl().IDENTITY,dl().LOG10,dl().REVERSE,dl().SQRT]),void 0,void 0,void 0,void 0,void 0,fu)+".")}var E=_;w.continuousTransform_gxz7zd$(E)}return this.applyCommons_0(w)},_u.prototype.applyCommons_0=function(t){var n,i;if(this.has_61zpoe$(Is().NAME)&&t.name_61zpoe$(L(this.getString_61zpoe$(Is().NAME))),this.has_61zpoe$(Is().BREAKS)){var r,o=this.getList_61zpoe$(Is().BREAKS),a=d();for(r=o.iterator();r.hasNext();){var s;null!=(s=r.next())&&a.add_11rb$(s)}t.breaks_pqjuzw$(a)}if(this.has_61zpoe$(Is().LABELS)?t.labels_mhpeer$(this.getStringList_61zpoe$(Is().LABELS)):t.labelFormat_pdl1vj$(this.getString_61zpoe$(Is().FORMAT)),this.has_61zpoe$(Is().EXPAND)){var l=this.getList_61zpoe$(Is().EXPAND);if(!l.isEmpty()){var u=e.isNumber(n=l.get_za3lpa$(0))?n:c();if(t.multiplicativeExpand_14dthe$(nt(u)),l.size>1){var p=e.isNumber(i=l.get_za3lpa$(1))?i:c();t.additiveExpand_14dthe$(nt(p))}}}return this.has_61zpoe$(Is().LIMITS)&&t.limits_9ma18$(this.getList_61zpoe$(Is().LIMITS)),t},_u.prototype.hasGuideOptions=function(){return this.has_61zpoe$(Is().GUIDE)},_u.prototype.getGuideOptions=function(){return go().create_za3rmp$(L(this.get_61zpoe$(Is().GUIDE)))},du.prototype.aesOrFail_x7u0o8$=function(t){var e=new yl(t);if(!e.has_61zpoe$(Is().AES))throw N("Required parameter 'aesthetic' is missing".toString());return Fs().toAes_61zpoe$(e.getStringSafe_61zpoe$(Is().AES))},du.prototype.createIdentityMapperProvider_bbdhip$=function(t,e){var n=rc().getConverter_31786j$(t),i=new In(n,e);if($c().contain_896ixz$(t)){var r=$c().get_31786j$(t);return new Dn(i,zn.Mappers.nullable_q9jsah$(r,e))}return i},du.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var mu,yu,$u,vu,gu,bu,wu,xu,ku,Eu,Cu,Su,Tu=null;function Ou(){return null===Tu&&new du,Tu}function Nu(t,e){Mn.call(this),this.name$=t,this.ordinal$=e}function Pu(){Pu=function(){},mu=new Nu("IDENTITY",0),yu=new Nu("COUNT",1),$u=new Nu("BIN",2),vu=new Nu("BIN2D",3),gu=new Nu("SMOOTH",4),bu=new Nu("CONTOUR",5),wu=new Nu("CONTOURF",6),xu=new Nu("BOXPLOT",7),ku=new Nu("DENSITY",8),Eu=new Nu("DENSITY2D",9),Cu=new Nu("DENSITY2DF",10),Su=new Nu("CORR",11),Yu()}function Au(){return Pu(),mu}function ju(){return Pu(),yu}function Lu(){return Pu(),$u}function Ru(){return Pu(),vu}function Iu(){return Pu(),gu}function zu(){return Pu(),bu}function Du(){return Pu(),wu}function Mu(){return Pu(),xu}function Bu(){return Pu(),ku}function Uu(){return Pu(),Eu}function Fu(){return Pu(),Cu}function qu(){return Pu(),Su}function Gu(){Hu=this,this.ENUM_INFO_0=new Un(Nu.values())}_u.$metadata$={kind:v,simpleName:"ScaleConfig",interfaces:[yl]},Gu.prototype.safeValueOf_61zpoe$=function(t){var e;if(null==(e=this.ENUM_INFO_0.safeValueOf_pdl1vj$(t)))throw N("Unknown stat name: '"+t+"'");return e},Gu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Hu=null;function Yu(){return Pu(),null===Hu&&new Gu,Hu}function Vu(){Ku=this}Nu.$metadata$={kind:v,simpleName:"StatKind",interfaces:[Mn]},Nu.values=function(){return[Au(),ju(),Lu(),Ru(),Iu(),zu(),Du(),Mu(),Bu(),Uu(),Fu(),qu()]},Nu.valueOf_61zpoe$=function(t){switch(t){case"IDENTITY":return Au();case"COUNT":return ju();case"BIN":return Lu();case"BIN2D":return Ru();case"SMOOTH":return Iu();case"CONTOUR":return zu();case"CONTOURF":return Du();case"BOXPLOT":return Mu();case"DENSITY":return Bu();case"DENSITY2D":return Uu();case"DENSITY2DF":return Fu();case"CORR":return qu();default:Bn("No enum constant jetbrains.datalore.plot.config.StatKind."+t)}},Vu.prototype.defaultOptions_xssx85$=function(t,e){var n;if(H(Yu().safeValueOf_61zpoe$(t),qu()))switch(e.name){case"TILE":n=ye(ct("size",0));break;case"POINT":case"TEXT":n=te([ct("size",.8),ct("size_unit","x"),ct("label_format",".2f")]);break;default:n=tt()}else n=tt();return n},Vu.prototype.createStat_77pq5g$=function(t,e){switch(t.name){case"IDENTITY":return Re.Stats.IDENTITY;case"COUNT":return Re.Stats.count();case"BIN":return Re.Stats.bin_yyf5ez$(e.getIntegerDef_bm4lxs$(fs().BINS,30),e.getDouble_61zpoe$(fs().BINWIDTH),e.getDouble_61zpoe$(fs().CENTER),e.getDouble_61zpoe$(fs().BOUNDARY));case"BIN2D":var n=e.getNumPairDef_j0281h$(ys().BINS,new D(30,30)),i=n.component1(),r=n.component2(),o=e.getNumQPairDef_alde63$(ys().BINWIDTH,new D(Fn.Companion.DEF_BINWIDTH,Fn.Companion.DEF_BINWIDTH)),a=o.component1(),s=o.component2();return new Fn(C(i),C(r),null!=a?nt(a):null,null!=s?nt(s):null,e.getBoolean_ivxn3r$(ys().DROP,Fn.Companion.DEF_DROP));case"CONTOUR":return new qn(e.getIntegerDef_bm4lxs$(gs().BINS,10),e.getDouble_61zpoe$(gs().BINWIDTH));case"CONTOURF":return new Gn(e.getIntegerDef_bm4lxs$(gs().BINS,10),e.getDouble_61zpoe$(gs().BINWIDTH));case"SMOOTH":return this.configureSmoothStat_0(e);case"CORR":return this.configureCorrStat_0(e);case"BOXPLOT":return Re.Stats.boxplot_8555vt$(e.getDoubleDef_io5o9c$(ps().COEF,Hn.Companion.DEF_WHISKER_IQR_RATIO),e.getBoolean_ivxn3r$(ps().VARWIDTH,Hn.Companion.DEF_COMPUTE_WIDTH));case"DENSITY":return this.configureDensityStat_0(e);case"DENSITY2D":return this.configureDensity2dStat_0(e,!1);case"DENSITY2DF":return this.configureDensity2dStat_0(e,!0);default:throw N("Unknown stat: '"+t+"'")}},Vu.prototype.configureSmoothStat_0=function(t){var e,n;if(null!=(e=t.getString_61zpoe$(Cs().METHOD))){var i;t:do{switch(e.toLowerCase()){case"lm":i=Yn.LM;break t;case"loess":case"lowess":i=Yn.LOESS;break t;case"glm":i=Yn.GLM;break t;case"gam":i=Yn.GAM;break t;case"rlm":i=Yn.RLM;break t;default:throw N("Unsupported smoother method: '"+e+"'\nUse one of: lm, loess, lowess, glm, gam, rlm.")}}while(0);n=i}else n=null;var r=n;return new Vn(t.getIntegerDef_bm4lxs$(Cs().POINT_COUNT,80),null!=r?r:Vn.Companion.DEF_SMOOTHING_METHOD,t.getDoubleDef_io5o9c$(Cs().CONFIDENCE_LEVEL,Vn.Companion.DEF_CONFIDENCE_LEVEL),t.getBoolean_ivxn3r$(Cs().DISPLAY_CONFIDENCE_INTERVAL,Vn.Companion.DEF_DISPLAY_CONFIDENCE_INTERVAL),t.getDoubleDef_io5o9c$(Cs().SPAN,Vn.Companion.DEF_SPAN),t.getIntegerDef_bm4lxs$(Cs().POLYNOMIAL_DEGREE,1),t.getIntegerDef_bm4lxs$(Cs().LOESS_CRITICAL_SIZE,1e3),t.getLongDef_4wgjuj$(Cs().LOESS_CRITICAL_SIZE,Kn))},Vu.prototype.configureCorrStat_0=function(t){var e,n,i;if(null!=(e=t.getString_61zpoe$(xs().METHOD))){if(!H(e.toLowerCase(),"pearson"))throw N("Unsupported correlation method: '"+e+"'. Must be: 'pearson'");i=Wn.PEARSON}else i=null;var r,o=i;if(null!=(n=t.getString_61zpoe$(xs().TYPE))){var a;t:do{switch(n.toLowerCase()){case"full":a=Xn.FULL;break t;case"upper":a=Xn.UPPER;break t;case"lower":a=Xn.LOWER;break t;default:throw N("Unsupported matrix type: '"+n+"'. Expected: 'full', 'upper' or 'lower'.")}}while(0);r=a}else r=null;var s=r;return new Zn(null!=o?o:Zn.Companion.DEF_CORRELATION_METHOD,null!=s?s:Zn.Companion.DEF_TYPE,t.getBoolean_ivxn3r$(xs().FILL_DIAGONAL,Zn.Companion.DEF_FILL_DIAGONAL),t.getDoubleDef_io5o9c$(xs().THRESHOLD,Zn.Companion.DEF_THRESHOLD))},Vu.prototype.configureDensityStat_0=function(t){var n,i,r={v:null},o={v:Jn.Companion.DEF_BW};null!=(n=t.get_61zpoe$(Os().BAND_WIDTH))&&(e.isNumber(n)?r.v=nt(n):"string"==typeof n&&(o.v=Re.DensityStatUtil.toBandWidthMethod_61zpoe$(n)));var a=null!=(i=t.getString_61zpoe$(Os().KERNEL))?Re.DensityStatUtil.toKernel_61zpoe$(i):null;return new Jn(r.v,o.v,t.getDoubleDef_io5o9c$(Os().ADJUST,Jn.Companion.DEF_ADJUST),null!=a?a:Jn.Companion.DEF_KERNEL,t.getIntegerDef_bm4lxs$(Os().N,512),t.getIntegerDef_bm4lxs$(Os().FULL_SCAN_MAX,5e3))},Vu.prototype.configureDensity2dStat_0=function(t,n){var i,r,o,a,s,l,u,p,h,_={v:null},f={v:null},d={v:null};if(null!=(i=t.get_61zpoe$(As().BAND_WIDTH)))if(e.isNumber(i))_.v=nt(i),f.v=nt(i);else if("string"==typeof i)d.v=Re.DensityStatUtil.toBandWidthMethod_61zpoe$(i);else if(e.isType(i,et))for(var m=0,y=i.iterator();y.hasNext();++m){var $=y.next();switch(m){case 0:var v,g;v=null!=$?nt(e.isNumber(g=$)?g:c()):null,_.v=v;break;case 1:var b,w;b=null!=$?nt(e.isNumber(w=$)?w:c()):null,f.v=b}}var x=null!=(r=t.getString_61zpoe$(As().KERNEL))?Re.DensityStatUtil.toKernel_61zpoe$(r):null,k={v:null},E={v:null};if(null!=(o=t.get_61zpoe$(As().N)))if(e.isNumber(o))k.v=C(o),E.v=C(o);else if(e.isType(o,et))for(var S=0,T=o.iterator();T.hasNext();++S){var O=T.next();switch(S){case 0:var N,P;N=null!=O?C(e.isNumber(P=O)?P:c()):null,k.v=N;break;case 1:var A,j;A=null!=O?C(e.isNumber(j=O)?j:c()):null,E.v=A}}return n?new ti(_.v,f.v,null!=(a=d.v)?a:Qn.Companion.DEF_BW,t.getDoubleDef_io5o9c$(As().ADJUST,Qn.Companion.DEF_ADJUST),null!=x?x:Qn.Companion.DEF_KERNEL,null!=(s=k.v)?s:100,null!=(l=E.v)?l:100,t.getBoolean_ivxn3r$(As().IS_CONTOUR,Qn.Companion.DEF_CONTOUR),t.getIntegerDef_bm4lxs$(As().BINS,10),t.getDoubleDef_io5o9c$(As().BINWIDTH,Qn.Companion.DEF_BIN_WIDTH)):new ei(_.v,f.v,null!=(u=d.v)?u:Qn.Companion.DEF_BW,t.getDoubleDef_io5o9c$(As().ADJUST,Qn.Companion.DEF_ADJUST),null!=x?x:Qn.Companion.DEF_KERNEL,null!=(p=k.v)?p:100,null!=(h=E.v)?h:100,t.getBoolean_ivxn3r$(As().IS_CONTOUR,Qn.Companion.DEF_CONTOUR),t.getIntegerDef_bm4lxs$(As().BINS,10),t.getDoubleDef_io5o9c$(As().BINWIDTH,Qn.Companion.DEF_BIN_WIDTH))},Vu.$metadata$={kind:b,simpleName:"StatProto",interfaces:[]};var Ku=null;function Wu(){return null===Ku&&new Vu,Ku}function Xu(t,e,n,i){ec(),yl.call(this,t),this.constantsMap_0=e,this.groupingVarName_0=n,this.varBindings_0=i}function Zu(t,e,n,i){this.$outer=t,this.tooltipLines_0=e;var r,o=this.prepareFormats_0(n),a=kt(wt(o.size));for(r=o.entries.iterator();r.hasNext();){var s=r.next(),l=a.put_xwzc9p$,u=s.key,c=s.key,p=s.value;l.call(a,u,this.createValueSource_0(c.name,c.isAes,p))}var h,_=a,f=Et(),d=k(o.size);for(h=o.entries.iterator();h.hasNext();){var m=h.next(),$=d.add_11rb$,v=m.key,g=m.value,b=this.getAesValueSourceForVariable_0(v,g,_);f.putAll_a2k3zr$(b),$.call(d,y)}this.myValueSources_0=di(gt(_,f));var w,E=k(x(i,10));for(w=i.iterator();w.hasNext();){var C=w.next(),S=E.add_11rb$,T=this.getValueSource_1(this.varField_0(C));S.call(E,ri.Companion.defaultLineForValueSource_u47np3$(T))}this.myLinesForVariableList_0=E}function Ju(t,e){this.name=t,this.isAes=e}function Qu(){tc=this,this.AES_NAME_PREFIX_0="^",this.VARIABLE_NAME_PREFIX_0="@",this.LABEL_SEPARATOR_0="|",this.SOURCE_RE_PATTERN_0=j("(?:\\\\\\^|\\\\@)|(\\^\\w+)|@(([\\w^@]+)|(\\{(.*?)\\})|\\.{2}\\w+\\.{2})")}Xu.prototype.createTooltips=function(){return new Zu(this,this.has_61zpoe$(_a().TOOLTIP_LINES)?this.getStringList_61zpoe$(_a().TOOLTIP_LINES):null,this.getList_61zpoe$(_a().TOOLTIP_FORMATS),this.getStringList_61zpoe$(_a().TOOLTIP_VARIABLES)).parse_8be2vx$()},Zu.prototype.parse_8be2vx$=function(){var t,e;if(null!=(t=this.tooltipLines_0)){var n,i=pt("parseLine",function(t,e){return t.parseLine_0(e)}.bind(null,this)),r=k(x(t,10));for(n=t.iterator();n.hasNext();){var o=n.next();r.add_11rb$(i(o))}e=r}else e=null;var a,s=e,l=null!=s?ft(this.myLinesForVariableList_0,s):this.myLinesForVariableList_0.isEmpty()?null:this.myLinesForVariableList_0,u=this.myValueSources_0,c=k(u.size);for(a=u.entries.iterator();a.hasNext();){var p=a.next();c.add_11rb$(p.value)}return new ze(c,l,new ni(this.readAnchor_0(),this.readMinWidth_0(),this.readColor_0()))},Zu.prototype.parseLine_0=function(t){var e,n=this.detachLabel_0(t),i=ii(t,ec().LABEL_SEPARATOR_0),r=d(),o=ec().SOURCE_RE_PATTERN_0;t:do{var a=o.find_905azu$(i);if(null==a){e=i.toString();break t}var s=0,l=i.length,u=mi(l);do{var c=L(a);u.append_ezbsdh$(i,s,c.range.start);var p,h=u.append_gw00v9$;if(H(c.value,"\\^")||H(c.value,"\\@"))p=lt(c.value,"\\");else{var _=this.getValueSource_0(c.value);r.add_11rb$(_),p=Lt.Companion.valueInLinePattern()}h.call(u,p),s=c.range.endInclusive+1|0,a=c.next()}while(s0&&(y=v,$=g)}while(m.hasNext());f=y}while(0);var b=null!=(i=f)?i.second:null,w=this.myValueSources_0,x=null!=b?b:this.createValueSource_0(t.name,t.isAes);w.put_xwzc9p$(t,x)}return L(this.myValueSources_0.get_11rb$(t))},Zu.prototype.getValueSource_0=function(t){var e;if(st(t,ec().AES_NAME_PREFIX_0))e=this.aesField_0(lt(t,ec().AES_NAME_PREFIX_0));else{if(!st(t,ec().VARIABLE_NAME_PREFIX_0))throw z(('Unknown type of the field with name = "'+t+'"').toString());e=this.varField_0(this.detachVariableName_0(t))}var n=e;return this.getValueSource_1(n)},Zu.prototype.detachVariableName_0=function(t){return ui(lt(t,ec().VARIABLE_NAME_PREFIX_0),"{","}")},Zu.prototype.detachLabel_0=function(t){var n;if(O(t,ec().LABEL_SEPARATOR_0)){var i,r=ci(t,ec().LABEL_SEPARATOR_0);n=yi(e.isCharSequence(i=r)?i:c()).toString()}else n=null;return n},Zu.prototype.aesField_0=function(t){return new Ju(t,!0)},Zu.prototype.varField_0=function(t){return new Ju(t,!1)},Zu.prototype.readAnchor_0=function(){var t;if(!this.$outer.has_61zpoe$(_a().TOOLTIP_ANCHOR))return null;var e=this.$outer.getString_61zpoe$(_a().TOOLTIP_ANCHOR);switch(e){case"top_left":t=new _i(pi.TOP,hi.LEFT);break;case"top_center":t=new _i(pi.TOP,hi.CENTER);break;case"top_right":t=new _i(pi.TOP,hi.RIGHT);break;case"middle_left":t=new _i(pi.MIDDLE,hi.LEFT);break;case"middle_center":t=new _i(pi.MIDDLE,hi.CENTER);break;case"middle_right":t=new _i(pi.MIDDLE,hi.RIGHT);break;case"bottom_left":t=new _i(pi.BOTTOM,hi.LEFT);break;case"bottom_center":t=new _i(pi.BOTTOM,hi.CENTER);break;case"bottom_right":t=new _i(pi.BOTTOM,hi.RIGHT);break;default:throw N("Illegal value "+f(e)+", "+_a().TOOLTIP_ANCHOR+", expected values are: 'top_left'/'top_center'/'top_right'/'middle_left'/'middle_center'/'middle_right'/'bottom_left'/'bottom_center'/'bottom_right'")}return t},Zu.prototype.readMinWidth_0=function(){return this.$outer.has_61zpoe$(_a().TOOLTIP_MIN_WIDTH)?this.$outer.getDouble_61zpoe$(_a().TOOLTIP_MIN_WIDTH):null},Zu.prototype.readColor_0=function(){if(this.$outer.has_61zpoe$(_a().TOOLTIP_COLOR)){var t=this.$outer.getString_61zpoe$(_a().TOOLTIP_COLOR);return null!=t?pt("parseColor",function(t,e){return t.parseColor_61zpoe$(e)}.bind(null,fi.Colors))(t):null}return null},Zu.$metadata$={kind:v,simpleName:"TooltipConfigParseHelper",interfaces:[]},Ju.$metadata$={kind:v,simpleName:"Field",interfaces:[]},Ju.prototype.component1=function(){return this.name},Ju.prototype.component2=function(){return this.isAes},Ju.prototype.copy_ivxn3r$=function(t,e){return new Ju(void 0===t?this.name:t,void 0===e?this.isAes:e)},Ju.prototype.toString=function(){return"Field(name="+e.toString(this.name)+", isAes="+e.toString(this.isAes)+")"},Ju.prototype.hashCode=function(){var t=0;return 31*(t=31*t+e.hashCode(this.name)|0)+e.hashCode(this.isAes)|0},Ju.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.name,t.name)&&e.equals(this.isAes,t.isAes)},Qu.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var tc=null;function ec(){return null===tc&&new Qu,tc}function nc(){ic=this,this.CONVERTERS_MAP_0=new vc}Xu.$metadata$={kind:v,simpleName:"TooltipConfig",interfaces:[yl]},nc.prototype.getConverter_31786j$=function(t){return this.CONVERTERS_MAP_0.get_31786j$(t)},nc.prototype.apply_kqseza$=function(t,e){return this.getConverter_31786j$(t)(e)},nc.prototype.applyToList_s6xytz$=function(t,e){var n,i=this.getConverter_31786j$(t),r=d();for(n=e.iterator();n.hasNext();){var o=n.next();r.add_11rb$(i(L(o)))}return r},nc.prototype.has_896ixz$=function(t){return this.CONVERTERS_MAP_0.containsKey_896ixz$(t)},nc.$metadata$={kind:b,simpleName:"AesOptionConversion",interfaces:[]};var ic=null;function rc(){return null===ic&&new nc,ic}function oc(){}function ac(){uc()}function sc(){var t,e;for(lc=this,this.LINE_TYPE_BY_CODE_0=X(),this.LINE_TYPE_BY_NAME_0=X(),t=bi(),e=0;e!==t.length;++e){var n=t[e],i=this.LINE_TYPE_BY_CODE_0,r=n.code;i.put_xwzc9p$(r,n);var o=this.LINE_TYPE_BY_NAME_0,a=n.name.toLowerCase();o.put_xwzc9p$(a,n)}}oc.prototype.apply_11rb$=function(t){if(null==t)return null;if(e.isType(t,En))return t;if(e.isNumber(t))return $c().COLOR(nt(t));try{return fi.Colors.parseColor_61zpoe$(t.toString())}catch(n){throw e.isType(n,T)?N("Can't convert to color: '"+f(t)+"' ("+f(e.getKClassFromExpression(t).simpleName)+")"):n}},oc.$metadata$={kind:v,simpleName:"ColorOptionConverter",interfaces:[$i]},ac.prototype.apply_11rb$=function(t){return null==t?vi.SOLID:e.isType(t,gi)?t:"string"==typeof t&&uc().LINE_TYPE_BY_NAME_0.containsKey_11rb$(t)?L(uc().LINE_TYPE_BY_NAME_0.get_11rb$(t)):e.isNumber(t)&&uc().LINE_TYPE_BY_CODE_0.containsKey_11rb$(C(t))?L(uc().LINE_TYPE_BY_CODE_0.get_11rb$(C(t))):vi.SOLID},sc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var lc=null;function uc(){return null===lc&&new sc,lc}function cc(){}function pc(){fc()}function hc(){var t,e;_c=this,this.SHAPE_BY_CODE_0=null;var n=X();for(t=Ei(),e=0;e!==t.length;++e){var i=t[e],r=i.code;n.put_xwzc9p$(r,i)}var o=xi.TinyPointShape.code,a=xi.TinyPointShape;n.put_xwzc9p$(o,a),this.SHAPE_BY_CODE_0=n}ac.$metadata$={kind:v,simpleName:"LineTypeOptionConverter",interfaces:[$i]},cc.prototype.apply_11rb$=function(t){if(null==t)return null;if(e.isNumber(t))return nt(t);try{return R(t.toString())}catch(n){throw e.isType(n,rt)?N("Can't convert to number: '"+f(t)+"'"):n}},cc.$metadata$={kind:v,simpleName:"NumericOptionConverter",interfaces:[$i]},pc.prototype.apply_11rb$=function(t){return fc().convert_0(t)},hc.prototype.convert_0=function(t){return null==t?null:e.isType(t,wi)?t:e.isNumber(t)&&this.SHAPE_BY_CODE_0.containsKey_11rb$(C(t))?L(this.SHAPE_BY_CODE_0.get_11rb$(C(t))):this.charShape_0(t.toString())},hc.prototype.charShape_0=function(t){return t.length>0?46===t.charCodeAt(0)?xi.TinyPointShape:ki.BULLET:xi.TinyPointShape},hc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var _c=null;function fc(){return null===_c&&new hc,_c}function dc(){var t;for(yc=this,this.COLOR=mc,this.MAP_0=X(),t=Dt.Companion.numeric_shhb9a$(Dt.Companion.values()).iterator();t.hasNext();){var e=t.next(),n=this.MAP_0,i=zn.Mappers.IDENTITY;n.put_xwzc9p$(e,i)}var r=this.MAP_0,o=Dt.Companion.COLOR,a=this.COLOR;r.put_xwzc9p$(o,a);var s=this.MAP_0,l=Dt.Companion.FILL,u=this.COLOR;s.put_xwzc9p$(l,u)}function mc(t){if(null==t)return null;var e=Si(Ci(t));return new En(e>>16&255,e>>8&255,255&e)}pc.$metadata$={kind:v,simpleName:"ShapeOptionConverter",interfaces:[$i]},dc.prototype.contain_896ixz$=function(t){return this.MAP_0.containsKey_11rb$(t)},dc.prototype.get_31786j$=function(t){var e;if(!this.contain_896ixz$(t)){var n="No continuous identity mapper found for aes "+t.name;throw N(n.toString())}return"function"==typeof(e=L(this.MAP_0.get_11rb$(t)))?e:c()},dc.$metadata$={kind:b,simpleName:"TypedContinuousIdentityMappers",interfaces:[]};var yc=null;function $c(){return null===yc&&new dc,yc}function vc(){Tc(),this.myMap_0=X(),this.put_0(Dt.Companion.X,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.Y,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.Z,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.YMIN,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.YMAX,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.COLOR,Tc().COLOR_CVT_0),this.put_0(Dt.Companion.FILL,Tc().COLOR_CVT_0),this.put_0(Dt.Companion.ALPHA,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.SHAPE,Tc().SHAPE_CVT_0),this.put_0(Dt.Companion.LINETYPE,Tc().LINETYPE_CVT_0),this.put_0(Dt.Companion.SIZE,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.WIDTH,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.HEIGHT,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.WEIGHT,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.INTERCEPT,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.SLOPE,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.XINTERCEPT,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.YINTERCEPT,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.LOWER,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.MIDDLE,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.UPPER,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.FRAME,Tc().IDENTITY_S_CVT_0),this.put_0(Dt.Companion.SPEED,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.FLOW,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.XMIN,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.XMAX,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.XEND,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.YEND,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.LABEL,Tc().IDENTITY_O_CVT_0),this.put_0(Dt.Companion.FAMILY,Tc().IDENTITY_S_CVT_0),this.put_0(Dt.Companion.FONTFACE,Tc().IDENTITY_S_CVT_0),this.put_0(Dt.Companion.HJUST,Tc().IDENTITY_O_CVT_0),this.put_0(Dt.Companion.VJUST,Tc().IDENTITY_O_CVT_0),this.put_0(Dt.Companion.ANGLE,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.SYM_X,Tc().DOUBLE_CVT_0),this.put_0(Dt.Companion.SYM_Y,Tc().DOUBLE_CVT_0)}function gc(){Sc=this,this.IDENTITY_O_CVT_0=bc,this.IDENTITY_S_CVT_0=wc,this.DOUBLE_CVT_0=xc,this.COLOR_CVT_0=kc,this.SHAPE_CVT_0=Ec,this.LINETYPE_CVT_0=Cc}function bc(t){return t}function wc(t){return null!=t?t.toString():null}function xc(t){return(new cc).apply_11rb$(t)}function kc(t){return(new oc).apply_11rb$(t)}function Ec(t){return(new pc).apply_11rb$(t)}function Cc(t){return(new ac).apply_11rb$(t)}vc.prototype.put_0=function(t,e){this.myMap_0.put_xwzc9p$(t,e)},vc.prototype.get_31786j$=function(t){var e;return"function"==typeof(e=this.myMap_0.get_11rb$(t))?e:c()},vc.prototype.containsKey_896ixz$=function(t){return this.myMap_0.containsKey_11rb$(t)},gc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Sc=null;function Tc(){return null===Sc&&new gc,Sc}function Oc(t,e,n){Ac(),yl.call(this,t,e),this.isX_0=n}function Nc(){Pc=this}vc.$metadata$={kind:v,simpleName:"TypedOptionConverterMap",interfaces:[]},Oc.prototype.defTheme_0=function(){return this.isX_0?Bc().DEF_8be2vx$.axisX():Bc().DEF_8be2vx$.axisY()},Oc.prototype.optionSuffix_0=function(){return this.isX_0?"_x":"_y"},Oc.prototype.showLine=function(){return!this.disabled_0(al().AXIS_LINE)},Oc.prototype.showTickMarks=function(){return!this.disabled_0(al().AXIS_TICKS)},Oc.prototype.showTickLabels=function(){return!this.disabled_0(al().AXIS_TEXT)},Oc.prototype.showTitle=function(){return!this.disabled_0(al().AXIS_TITLE)},Oc.prototype.showTooltip=function(){return!this.disabled_0(al().AXIS_TOOLTIP)},Oc.prototype.lineWidth=function(){return this.defTheme_0().lineWidth()},Oc.prototype.tickMarkWidth=function(){return this.defTheme_0().tickMarkWidth()},Oc.prototype.tickMarkLength=function(){return this.defTheme_0().tickMarkLength()},Oc.prototype.tickMarkPadding=function(){return this.defTheme_0().tickMarkPadding()},Oc.prototype.getViewElementConfig_0=function(t){if(!this.hasApplicable_61zpoe$(t))throw z(("option '"+t+"' is not specified").toString());return Gc().create_za3rmp$(L(this.getApplicable_61zpoe$(t)))},Oc.prototype.disabled_0=function(t){return this.hasApplicable_61zpoe$(t)&&this.getViewElementConfig_0(t).isBlank},Oc.prototype.hasApplicable_61zpoe$=function(t){var e=t+this.optionSuffix_0();return this.has_61zpoe$(e)||this.has_61zpoe$(t)},Oc.prototype.getApplicable_61zpoe$=function(t){var e=t+this.optionSuffix_0();return this.hasOwn_61zpoe$(e)?this.get_61zpoe$(e):this.hasOwn_61zpoe$(t)?this.get_61zpoe$(t):this.has_61zpoe$(e)?this.get_61zpoe$(e):this.get_61zpoe$(t)},Nc.prototype.X_d1i6zg$=function(t,e){return new Oc(t,e,!0)},Nc.prototype.Y_d1i6zg$=function(t,e){return new Oc(t,e,!1)},Nc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Pc=null;function Ac(){return null===Pc&&new Nc,Pc}function jc(t,e){yl.call(this,t,e)}function Lc(t){Bc(),this.theme=new Ic(t)}function Rc(t,e){this.options_0=t,this.axisXTheme_0=Ac().X_d1i6zg$(this.options_0,e),this.axisYTheme_0=Ac().Y_d1i6zg$(this.options_0,e),this.legendTheme_0=new jc(this.options_0,e)}function Ic(t){Rc.call(this,t,Bc().DEF_OPTIONS_0)}function zc(t){Rc.call(this,t,Bc().DEF_OPTIONS_MULTI_TILE_0)}function Dc(){Mc=this,this.DEF_8be2vx$=new Li,this.DEF_OPTIONS_0=te([ct(al().LEGEND_POSITION,this.DEF_8be2vx$.legend().position()),ct(al().LEGEND_JUSTIFICATION,this.DEF_8be2vx$.legend().justification()),ct(al().LEGEND_DIRECTION,this.DEF_8be2vx$.legend().direction())]),this.DEF_OPTIONS_MULTI_TILE_0=gt(this.DEF_OPTIONS_0,te([ct("axis_line_x",al().ELEMENT_BLANK),ct("axis_line_y",al().ELEMENT_BLANK)]))}Oc.$metadata$={kind:v,simpleName:"AxisThemeConfig",interfaces:[Ti,yl]},jc.prototype.keySize=function(){return Bc().DEF_8be2vx$.legend().keySize()},jc.prototype.margin=function(){return Bc().DEF_8be2vx$.legend().margin()},jc.prototype.padding=function(){return Bc().DEF_8be2vx$.legend().padding()},jc.prototype.position=function(){var t,n,i=this.get_61zpoe$(al().LEGEND_POSITION);if("string"==typeof i){switch(i){case"right":t=Oi.Companion.RIGHT;break;case"left":t=Oi.Companion.LEFT;break;case"top":t=Oi.Companion.TOP;break;case"bottom":t=Oi.Companion.BOTTOM;break;case"none":t=Oi.Companion.NONE;break;default:throw N("Illegal value '"+f(i)+"', "+al().LEGEND_POSITION+" expected values are: left/right/top/bottom/none or or two-element numeric list")}return t}if(e.isType(i,et)){var r=_r().toNumericPair_9ma18$(L(null==(n=i)||e.isType(n,et)?n:c()));return new Oi(r.x,r.y)}return e.isType(i,Oi)?i:Bc().DEF_8be2vx$.legend().position()},jc.prototype.justification=function(){var t,n=this.get_61zpoe$(al().LEGEND_JUSTIFICATION);if("string"==typeof n){if(H(n,"center"))return Ni.Companion.CENTER;throw N("Illegal value '"+f(n)+"', "+al().LEGEND_JUSTIFICATION+" expected values are: 'center' or two-element numeric list")}if(e.isType(n,et)){var i=_r().toNumericPair_9ma18$(L(null==(t=n)||e.isType(t,et)?t:c()));return new Ni(i.x,i.y)}return e.isType(n,Ni)?n:Bc().DEF_8be2vx$.legend().justification()},jc.prototype.direction=function(){var t=this.get_61zpoe$(al().LEGEND_DIRECTION);if("string"==typeof t)switch(t){case"horizontal":return Pi.HORIZONTAL;case"vertical":return Pi.VERTICAL}return Pi.AUTO},jc.prototype.backgroundFill=function(){return Bc().DEF_8be2vx$.legend().backgroundFill()},jc.$metadata$={kind:v,simpleName:"LegendThemeConfig",interfaces:[Ai,yl]},Rc.prototype.axisX=function(){return this.axisXTheme_0},Rc.prototype.axisY=function(){return this.axisYTheme_0},Rc.prototype.legend=function(){return this.legendTheme_0},Rc.prototype.facets=function(){return Bc().DEF_8be2vx$.facets()},Rc.prototype.plot=function(){return Bc().DEF_8be2vx$.plot()},Rc.prototype.multiTile=function(){return new zc(this.options_0)},Rc.$metadata$={kind:v,simpleName:"ConfiguredTheme",interfaces:[ji]},Ic.$metadata$={kind:v,simpleName:"OneTileTheme",interfaces:[Rc]},zc.prototype.plot=function(){return Bc().DEF_8be2vx$.multiTile().plot()},zc.$metadata$={kind:v,simpleName:"MultiTileTheme",interfaces:[Rc]},Dc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Mc=null;function Bc(){return null===Mc&&new Dc,Mc}function Uc(t,e){if(Gc(),yl.call(this,e),this.name_0=t,!H(al().ELEMENT_BLANK,this.name_0))throw z("Only 'element_blank' is supported".toString())}function Fc(){qc=this}Lc.$metadata$={kind:v,simpleName:"ThemeConfig",interfaces:[]},Object.defineProperty(Uc.prototype,"isBlank",{configurable:!0,get:function(){return H(al().ELEMENT_BLANK,this.name_0)}}),Fc.prototype.create_za3rmp$=function(t){var n;if(e.isType(t,A)){var i=e.isType(n=t,A)?n:c();return this.createForName_0(_r().featureName_bkhwtg$(i),i)}return this.createForName_0(t.toString(),X())},Fc.prototype.createForName_0=function(t,e){return new Uc(t,e)},Fc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var qc=null;function Gc(){return null===qc&&new Fc,qc}function Hc(){Yc=this}Uc.$metadata$={kind:v,simpleName:"ViewElementConfig",interfaces:[yl]},Hc.prototype.apply_bkhwtg$=function(t){return this.cleanCopyOfMap_0(t)},Hc.prototype.cleanCopyOfMap_0=function(t){var n,i=X();for(n=t.keys.iterator();n.hasNext();){var r,o=n.next(),a=(e.isType(r=t,A)?r:c()).get_11rb$(o);if(null!=a){var s=f(o),l=this.cleanValue_0(a);i.put_xwzc9p$(s,l)}}return i},Hc.prototype.cleanValue_0=function(t){return e.isType(t,A)?this.cleanCopyOfMap_0(t):e.isType(t,et)?this.cleanList_0(t):t},Hc.prototype.cleanList_0=function(t){var e;if(!this.containSpecs_0(t))return t;var n=k(t.size);for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(this.cleanValue_0(L(i)))}return n},Hc.prototype.containSpecs_0=function(t){var n;t:do{var i;if(e.isType(t,oe)&&t.isEmpty()){n=!1;break t}for(i=t.iterator();i.hasNext();){var r=i.next();if(e.isType(r,A)||e.isType(r,et)){n=!0;break t}}n=!1}while(0);return n},Hc.$metadata$={kind:b,simpleName:"PlotSpecCleaner",interfaces:[]};var Yc=null;function Vc(){return null===Yc&&new Hc,Yc}function Kc(t){var e;for(ip(),this.myMakeCleanCopy_0=!1,this.mySpecChanges_0=null,this.myMakeCleanCopy_0=t.myMakeCleanCopy_8be2vx$,this.mySpecChanges_0=X(),e=t.mySpecChanges_8be2vx$.entries.iterator();e.hasNext();){var n=e.next(),i=n.key,r=n.value;if(r.isEmpty())throw z("Check failed.".toString());this.mySpecChanges_0.put_xwzc9p$(i,r)}}function Wc(t){this.closure$result=t}function Xc(t){this.myMakeCleanCopy_8be2vx$=t,this.mySpecChanges_8be2vx$=X()}function Zc(){np=this}Wc.prototype.getSpecsAbsolute_vqirvp$=function(t){var n,i=mp(an(t)).findSpecs_bkhwtg$(this.closure$result);return e.isType(n=i,et)?n:c()},Wc.$metadata$={kind:v,interfaces:[fp]},Kc.prototype.apply_i49brq$=function(t){var n,i=this.myMakeCleanCopy_0?Vc().apply_bkhwtg$(t):e.isType(n=t,u)?n:c(),r=new Wc(i),o=xp().root();return this.applyChangesToSpec_0(o,i,r),i},Kc.prototype.applyChangesToSpec_0=function(t,e,n){var i,r;for(i=e.keys.iterator();i.hasNext();){var o=i.next(),a=L(e.get_11rb$(o)),s=t.with().part_61zpoe$(o).build();this.applyChangesToValue_0(s,a,n)}for(r=this.applicableSpecChanges_0(t,e).iterator();r.hasNext();)r.next().apply_il3x6g$(e,n)},Kc.prototype.applyChangesToValue_0=function(t,n,i){var r,o;if(e.isType(n,A)){var a=e.isType(r=n,u)?r:c();this.applyChangesToSpec_0(t,a,i)}else if(e.isType(n,et))for(o=n.iterator();o.hasNext();){var s=o.next();this.applyChangesToValue_0(t,s,i)}},Kc.prototype.applicableSpecChanges_0=function(t,e){var n;if(this.mySpecChanges_0.containsKey_11rb$(t)){var i=d();for(n=L(this.mySpecChanges_0.get_11rb$(t)).iterator();n.hasNext();){var r=n.next();r.isApplicable_x7u0o8$(e)&&i.add_11rb$(r)}return i}return ut()},Xc.prototype.change_t6n62v$=function(t,e){if(!this.mySpecChanges_8be2vx$.containsKey_11rb$(t)){var n=this.mySpecChanges_8be2vx$,i=d();n.put_xwzc9p$(t,i)}return L(this.mySpecChanges_8be2vx$.get_11rb$(t)).add_11rb$(e),this},Xc.prototype.build=function(){return new Kc(this)},Xc.$metadata$={kind:v,simpleName:"Builder",interfaces:[]},Zc.prototype.builderForRawSpec=function(){return new Xc(!0)},Zc.prototype.builderForCleanSpec=function(){return new Xc(!1)},Zc.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Jc,Qc,tp,ep,np=null;function ip(){return null===np&&new Zc,np}function rp(){pp=this,this.GGBUNCH_KEY_PARTS=[ra().ITEMS,na().FEATURE_SPEC],this.PLOT_WITH_LAYERS_TARGETS_0=le([sp(),lp(),up(),cp()])}function op(t,e){Mn.call(this),this.name$=t,this.ordinal$=e}function ap(){ap=function(){},Jc=new op("PLOT",0),Qc=new op("LAYER",1),tp=new op("GEOM",2),ep=new op("STAT",3)}function sp(){return ap(),Jc}function lp(){return ap(),Qc}function up(){return ap(),tp}function cp(){return ap(),ep}Kc.$metadata$={kind:v,simpleName:"PlotSpecTransform",interfaces:[]},rp.prototype.getDataSpecFinders_6taknv$=function(t){return this.getPlotAndLayersSpecFinders_esgbho$(t,[sa().DATA])},rp.prototype.getPlotAndLayersSpecFinders_esgbho$=function(t,e){var n=this.getPlotAndLayersSpecSelectorKeys_0(t,e.slice());return this.toFinders_0(n)},rp.prototype.toFinders_0=function(t){var e,n=d();for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(mp(i))}return n},rp.prototype.getPlotAndLayersSpecSelectors_esgbho$=function(t,e){var n=this.getPlotAndLayersSpecSelectorKeys_0(t,e.slice());return this.toSelectors_0(n)},rp.prototype.toSelectors_0=function(t){var e,n=k(x(t,10));for(e=t.iterator();e.hasNext();){var i=e.next();n.add_11rb$(xp().from_upaayv$(i))}return n},rp.prototype.getPlotAndLayersSpecSelectorKeys_0=function(t,e){var n,i=d();for(n=this.PLOT_WITH_LAYERS_TARGETS_0.iterator();n.hasNext();){var r=n.next(),o=this.selectorKeys_0(r,t),a=le(this.concat_0(o,e).slice());i.add_11rb$(a)}return i},rp.prototype.concat_0=function(t,e){return t.concat(e)},rp.prototype.selectorKeys_0=function(t,n){var i;switch(t.name){case"PLOT":i=[];break;case"LAYER":i=[ca().LAYERS];break;case"GEOM":i=[ca().LAYERS,_a().GEOM];break;case"STAT":i=[ca().LAYERS,_a().STAT];break;default:e.noWhenBranchMatched()}return n&&(i=this.concat_0(this.GGBUNCH_KEY_PARTS,i)),i},op.$metadata$={kind:v,simpleName:"TargetSpec",interfaces:[Mn]},op.values=function(){return[sp(),lp(),up(),cp()]},op.valueOf_61zpoe$=function(t){switch(t){case"PLOT":return sp();case"LAYER":return lp();case"GEOM":return up();case"STAT":return cp();default:Bn("No enum constant jetbrains.datalore.plot.config.transform.PlotSpecTransformUtil.TargetSpec."+t)}},rp.$metadata$={kind:b,simpleName:"PlotSpecTransformUtil",interfaces:[]};var pp=null;function hp(){return null===pp&&new rp,pp}function _p(){}function fp(){}function dp(){this.myKeys_0=null}function mp(t,e){return e=e||Object.create(dp.prototype),dp.call(e),e.myKeys_0=St(t),e}function yp(t){xp(),this.myKey_0=null,this.myKey_0=S(L(t.mySelectorParts_8be2vx$),"|")}function $p(){this.mySelectorParts_8be2vx$=null}function vp(t){return t=t||Object.create($p.prototype),$p.call(t),t.mySelectorParts_8be2vx$=d(),L(t.mySelectorParts_8be2vx$).add_11rb$("/"),t}function gp(t,e){var n;for(e=e||Object.create($p.prototype),$p.call(e),e.mySelectorParts_8be2vx$=d(),n=0;n!==t.length;++n){var i=t[n];L(e.mySelectorParts_8be2vx$).add_11rb$(i)}return e}function bp(){wp=this}_p.prototype.isApplicable_x7u0o8$=function(t){return!0},_p.$metadata$={kind:Ri,simpleName:"SpecChange",interfaces:[]},fp.$metadata$={kind:Ri,simpleName:"SpecChangeContext",interfaces:[]},dp.prototype.findSpecs_bkhwtg$=function(t){return this.myKeys_0.isEmpty()?_(t):this.findSpecs_0(this.myKeys_0.get_za3lpa$(0),this.myKeys_0.subList_vux9f0$(1,this.myKeys_0.size),t)},dp.prototype.findSpecs_0=function(t,n,i){var r,o;if((e.isType(o=i,A)?o:c()).containsKey_11rb$(t)){var a,s=(e.isType(a=i,A)?a:c()).get_11rb$(t);if(e.isType(s,A))return n.isEmpty()?_(s):this.findSpecs_0(n.get_za3lpa$(0),n.subList_vux9f0$(1,n.size),s);if(e.isType(s,et)){if(n.isEmpty()){var l=d();for(r=s.iterator();r.hasNext();){var u=r.next();e.isType(u,A)&&l.add_11rb$(u)}return l}return this.findSpecsInList_0(n.get_za3lpa$(0),n.subList_vux9f0$(1,n.size),s)}}return ut()},dp.prototype.findSpecsInList_0=function(t,n,i){var r,o=d();for(r=i.iterator();r.hasNext();){var a=r.next();e.isType(a,A)?o.addAll_brywnq$(this.findSpecs_0(t,n,a)):e.isType(a,et)&&o.addAll_brywnq$(this.findSpecsInList_0(t,n,a))}return o},dp.$metadata$={kind:v,simpleName:"SpecFinder",interfaces:[]},yp.prototype.with=function(){var t,e=this.myKey_0,n=j("\\|").split_905azu$(e,0);t:do{if(!n.isEmpty())for(var i=n.listIterator_za3lpa$(n.size);i.hasPrevious();)if(0!==i.previous().length){t=Pt(n,i.nextIndex()+1|0);break t}t=ut()}while(0);return gp(zi(t))},yp.prototype.equals=function(t){var n,i;if(this===t)return!0;if(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))return!1;var r=null==(i=t)||e.isType(i,yp)?i:c();return H(this.myKey_0,L(r).myKey_0)},yp.prototype.hashCode=function(){return Ii(_(this.myKey_0))},yp.prototype.toString=function(){return"SpecSelector{myKey='"+this.myKey_0+String.fromCharCode(39)+String.fromCharCode(125)},$p.prototype.part_61zpoe$=function(t){return L(this.mySelectorParts_8be2vx$).add_11rb$(t),this},$p.prototype.build=function(){return new yp(this)},$p.$metadata$={kind:v,simpleName:"Builder",interfaces:[]},bp.prototype.root=function(){return vp().build()},bp.prototype.of_vqirvp$=function(t){return this.from_upaayv$(le(t.slice()))},bp.prototype.from_upaayv$=function(t){for(var e=vp(),n=t.iterator();n.hasNext();){var i=n.next();e.part_61zpoe$(i)}return e.build()},bp.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var wp=null;function xp(){return null===wp&&new bp,wp}function kp(){Sp()}function Ep(){Cp=this}yp.$metadata$={kind:v,simpleName:"SpecSelector",interfaces:[]},kp.prototype.isApplicable_x7u0o8$=function(t){return e.isType(t.get_11rb$(_a().GEOM),A)},kp.prototype.apply_il3x6g$=function(t,n){var i,r,o,a,s=e.isType(i=t.remove_11rb$(_a().GEOM),u)?i:c(),l=Jo().NAME,p="string"==typeof(r=(e.isType(a=s,u)?a:c()).remove_11rb$(l))?r:c(),h=_a().GEOM;t.put_xwzc9p$(h,p),t.putAll_a2k3zr$(e.isType(o=s,A)?o:c())},Ep.prototype.specSelector_6taknv$=function(t){var e=d();return t&&e.addAll_brywnq$(an(hp().GGBUNCH_KEY_PARTS)),e.add_11rb$(ca().LAYERS),xp().from_upaayv$(e)},Ep.$metadata$={kind:b,simpleName:"Companion",interfaces:[]};var Cp=null;function Sp(){return null===Cp&&new Ep,Cp}function Tp(t,e){this.dataFrames_0=t,this.scaleByAes_0=e}function Op(t){Lp(),Dl.call(this,t)}function Np(t,e,n,i){return function(r){return t(e,i.createStatMessage_omgxfc$_0(r,n)),y}}function Pp(t,e,n,i){return function(r){return t(e,i.createSamplingMessage_b1krad$_0(r,n)),y}}function Ap(){jp=this,this.LOG_0=M.PortableLogging.logger_xo1ogr$(B(Op))}kp.$metadata$={kind:v,simpleName:"MoveGeomPropertiesToLayerMigration",interfaces:[_p]},Tp.prototype.overallRange_0=function(t,e){var n,i=null;for(n=e.iterator();n.hasNext();){var r=n.next();r.has_8xm3sj$(t)&&(i=je.SeriesUtil.span_t7esj2$(i,r.range_8xm3sj$(t)))}return i},Tp.prototype.overallXRange=function(){return this.overallRange_1(Dt.Companion.X)},Tp.prototype.overallYRange=function(){return this.overallRange_1(Dt.Companion.Y)},Tp.prototype.overallRange_1=function(t){var e,n,i=V.DataFrameUtil.transformVarFor_896ixz$(t),r=new D(Di.NaN,Di.NaN);if(this.scaleByAes_0.containsKey_896ixz$(t)){var o=this.scaleByAes_0.get_31786j$(t);e=o.isContinuousDomain?zn.ScaleUtil.transformedDefinedLimits_x4zrm4$(o):r}else e=r;var a=e,s=a.component1(),l=a.component2(),u=this.overallRange_0(i,this.dataFrames_0);if(null!=u){var c=Mi(s)?s:u.lowerEnd,p=Mi(l)?l:u.upperEnd;n=ct(c,p)}else n=je.SeriesUtil.allFinite_jma9l8$(s,l)?ct(s,l):null;var h=n;return null!=h?new tn(h.first,h.second):null},Tp.$metadata$={kind:v,simpleName:"ConfiguredStatContext",interfaces:[Bi]},Op.prototype.createLayerConfig_ookg2q$=function(t,e,n,i,r){var o,a="string"==typeof(o=t.get_11rb$(_a().GEOM))?o:c();return new wo(t,e,n,i,r,new to(ul().toGeomKind_61zpoe$(a)),!1)},Op.prototype.updatePlotSpec_47ur7o$_0=function(){for(var t=Ot(),e=this.dataByTileByLayerAfterStat_5qft8t$_0(function(t,e){return function(n,i){return t.add_11rb$(n),Ql().addComputationMessage_qqfnr1$(e,i),y}}(t,this)),n=d(),i=this.layerConfigs,r=0;r!==i.size;++r){var o,a,s,l,u=X();for(o=e.iterator();o.hasNext();){var c=o.next().get_za3lpa$(r),p=c.variables();if(u.isEmpty())for(a=p.iterator();a.hasNext();){var h=a.next(),_=h.name,f=new Ui(h,St(c.get_8xm3sj$(h)));u.put_xwzc9p$(_,f)}else for(s=p.iterator();s.hasNext();){var m=s.next();L(u.get_11rb$(m.name)).second.addAll_brywnq$(c.get_8xm3sj$(m))}}var $=Q();for(l=u.keys.iterator();l.hasNext();){var v=l.next(),g=L(u.get_11rb$(v)).first,b=L(u.get_11rb$(v)).second;$.put_2l962d$(g,b)}var w=$.build();n.add_11rb$(w)}for(var x=0,k=i.iterator();k.hasNext();++x){var E=k.next();if(E.stat!==Re.Stats.IDENTITY||t.contains_11rb$(x)){var C=n.get_za3lpa$(x);E.replaceOwnData_84jd1e$(C)}}this.dropUnusedDataBeforeEncoding_r9oln7$_0(i)},Op.prototype.dropUnusedDataBeforeEncoding_r9oln7$_0=function(t){var e,n,i,r,o=kt(xt(wt(x(t,10)),16));for(r=t.iterator();r.hasNext();){var a=r.next();o.put_xwzc9p$(a,Lp().variablesToKeep_0(this.facets,a))}var s=o,l=this.sharedData,u=V.DataFrameUtil.variables_dhhkv7$(l),c=Ot();for(e=u.keys.iterator();e.hasNext();){var p=e.next(),h=!0;for(n=s.entries.iterator();n.hasNext();){var _=n.next(),f=_.key,d=_.value,m=L(f.ownData);if(!V.DataFrameUtil.variables_dhhkv7$(m).containsKey_11rb$(p)&&d.contains_11rb$(p)){h=!1;break}}h||c.add_11rb$(p)}if(c.size\n | .plt-container {\n |\tfont-family: "Lucida Grande", sans-serif;\n |\tcursor: crosshair;\n |\tuser-select: none;\n |\t-webkit-user-select: none;\n |\t-moz-user-select: none;\n |\t-ms-user-select: none;\n |}\n |.plt-backdrop {\n | fill: white;\n |}\n |.plt-transparent .plt-backdrop {\n | visibility: hidden;\n |}\n |text {\n |\tfont-size: 12px;\n |\tfill: #3d3d3d;\n |\t\n |\ttext-rendering: optimizeLegibility;\n |}\n |.plt-data-tooltip text {\n |\tfont-size: 12px;\n |}\n |.plt-axis-tooltip text {\n |\tfont-size: 12px;\n |}\n |.plt-axis line {\n |\tshape-rendering: crispedges;\n |}\n |.plt-plot-title {\n |\n | font-size: 16.0px;\n | font-weight: bold;\n |}\n |.plt-axis .tick text {\n |\n | font-size: 10.0px;\n |}\n |.plt-axis.small-tick-font .tick text {\n |\n | font-size: 8.0px;\n |}\n |.plt-axis-title text {\n |\n | font-size: 12.0px;\n |}\n |.plt_legend .legend-title text {\n |\n | font-size: 12.0px;\n | font-weight: bold;\n |}\n |.plt_legend text {\n |\n | font-size: 10.0px;\n |}\n |\n | \n '),E('\n |\n |'+Kp+'\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | Lunch\n | \n | \n | \n | \n | \n | \n | \n | \n | Dinner\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 0.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 1.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 2.0\n | \n | \n | \n | \n | \n | \n | \n | \n | 2.5\n | \n | \n | \n | \n | \n | \n | \n | \n | 3.0\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | count\n | \n | \n | \n | \n | \n | \n | time\n | \n | \n | \n | \n |\n '),E('\n |\n |\n |\n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | 3\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | b\n | \n | \n | \n | \n | \n | \n | a\n | \n | \n | \n | \n |\n |\n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | 0\n | \n | \n | \n | \n | \n | \n | \n | \n | 1\n | \n | \n | \n | \n | \n | \n | \n | \n | 2\n | \n | \n | \n | \n | \n | \n | \n | \n | 3\n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | \n | b\n | \n | \n | \n | \n | \n | \n | a\n | \n | \n | \n | \n |\n |\n '),t})?i.apply(e,r):i)||(t.exports=o)},698:function(t,e,n){var i,r,o;r=[e,n(421),n(770),n(767),n(836),n(52),n(958),n(623)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o,a,s){"use strict";e.kotlin.io.println_s8jyv4$,e.kotlin.Unit;var l=n.jetbrains.datalore.plot.config.PlotConfig,u=e.kotlin.IllegalArgumentException_init_pdl1vj$,c=n.jetbrains.datalore.plot.config.PlotConfigClientSide,p=(n.jetbrains.datalore.plot.config,n.jetbrains.datalore.plot.server.config.PlotConfigServerSide,i.jetbrains.datalore.base.geometry.DoubleVector,e.kotlin.collections.ArrayList_init_287e2$),h=e.kotlin.collections.HashMap_init_q3lmfv$,_=e.kotlin.collections.Map,f=(e.kotlin.collections.emptyMap_q3lmfv$,e.Kind.OBJECT),d=e.Kind.CLASS,m=n.jetbrains.datalore.plot.config.transform.SpecChange,y=r.jetbrains.datalore.plot.base.data,$=e.kotlin.collections.List,v=e.throwCCE,g=r.jetbrains.datalore.plot.base.DataFrame.Builder_init,b=o.jetbrains.datalore.plot.common.base64,w=e.kotlin.collections.ArrayList_init_mqih57$,x=e.kotlin.Comparator,k=e.kotlin.collections.sortWith_nqfjgj$,E=e.kotlin.collections.sort_4wi501$,C=a.jetbrains.datalore.plot.common.data,S=n.jetbrains.datalore.plot.config.transform,T=n.jetbrains.datalore.plot.config.Option,O=n.jetbrains.datalore.plot.config.transform.PlotSpecTransform,N=s.jetbrains.datalore.plot;function P(){}function A(){}function j(){R=this,this.DATA_FRAME_KEY_0="__data_frame_encoded",this.DATA_SPEC_KEY_0="__data_spec_encoded"}function L(t,n){return e.compareTo(t.name,n.name)}P.prototype.isApplicable_x7u0o8$=function(t){return I().isEncodedDataSpec_za3rmp$(t)},P.prototype.apply_il3x6g$=function(t,e){var n;n=I().decode1_6uu7i0$(t),t.clear(),t.putAll_a2k3zr$(n)},P.$metadata$={kind:d,simpleName:"ClientSideDecodeChange",interfaces:[m]},A.prototype.isApplicable_x7u0o8$=function(t){return I().isEncodedDataFrame_bkhwtg$(t)},A.prototype.apply_il3x6g$=function(t,e){var n=I().decode_bkhwtg$(t);t.clear(),t.putAll_a2k3zr$(y.DataFrameUtil.toMap_dhhkv7$(n))},A.$metadata$={kind:d,simpleName:"ClientSideDecodeOldStyleChange",interfaces:[m]},j.prototype.isEncodedDataFrame_bkhwtg$=function(t){var n=1===t.size;if(n){var i,r=this.DATA_FRAME_KEY_0;n=(e.isType(i=t,_)?i:v()).containsKey_11rb$(r)}return n},j.prototype.isEncodedDataSpec_za3rmp$=function(t){var n;if(e.isType(t,_)){var i=1===t.size;if(i){var r,o=this.DATA_SPEC_KEY_0;i=(e.isType(r=t,_)?r:v()).containsKey_11rb$(o)}n=i}else n=!1;return n},j.prototype.decode_bkhwtg$=function(t){var n,i,r,o;if(!this.isEncodedDataFrame_bkhwtg$(t))throw u("Not a data frame".toString());for(var a,s=this.DATA_FRAME_KEY_0,l=e.isType(n=(e.isType(a=t,_)?a:v()).get_11rb$(s),$)?n:v(),c=e.isType(i=l.get_za3lpa$(0),$)?i:v(),p=e.isType(r=l.get_za3lpa$(1),$)?r:v(),h=e.isType(o=l.get_za3lpa$(2),$)?o:v(),f=g(),d=0;d!==c.size;++d){var m,w,x,k,E,C="string"==typeof(m=c.get_za3lpa$(d))?m:v(),S="string"==typeof(w=p.get_za3lpa$(d))?w:v(),T="boolean"==typeof(x=h.get_za3lpa$(d))?x:v(),O=y.DataFrameUtil.createVariable_puj7f4$(C,S),N=l.get_za3lpa$(3+d|0);if(T){var P=b.BinaryUtil.decodeList_61zpoe$("string"==typeof(k=N)?k:v());f.putNumeric_s1rqo9$(O,P)}else f.put_2l962d$(O,e.isType(E=N,$)?E:v())}return f.build()},j.prototype.decode1_6uu7i0$=function(t){var n,i,r;if(!this.isEncodedDataSpec_za3rmp$(t))throw u("Not an encoded data spec".toString());for(var o=e.isType(n=t.get_11rb$(this.DATA_SPEC_KEY_0),$)?n:v(),a=e.isType(i=o.get_za3lpa$(0),$)?i:v(),s=e.isType(r=o.get_za3lpa$(1),$)?r:v(),l=h(),c=0;c!==a.size;++c){var p,_,f,d,m="string"==typeof(p=a.get_za3lpa$(c))?p:v(),y="boolean"==typeof(_=s.get_za3lpa$(c))?_:v(),g=o.get_za3lpa$(2+c|0),w=y?b.BinaryUtil.decodeList_61zpoe$("string"==typeof(f=g)?f:v()):e.isType(d=g,$)?d:v();l.put_xwzc9p$(m,w)}return l},j.prototype.encode_dhhkv7$=function(t){var n,i,r=h(),o=p(),a=this.DATA_FRAME_KEY_0;r.put_xwzc9p$(a,o);var s=p(),l=p(),u=p();o.add_11rb$(s),o.add_11rb$(l),o.add_11rb$(u);var c=w(t.variables());for(k(c,new x(L)),n=c.iterator();n.hasNext();){var _=n.next();s.add_11rb$(_.name),l.add_11rb$(_.label);var f=t.isNumeric_8xm3sj$(_);u.add_11rb$(f);var d=t.get_8xm3sj$(_);if(f){var m=b.BinaryUtil.encodeList_k9kaly$(e.isType(i=d,$)?i:v());o.add_11rb$(m)}else o.add_11rb$(d)}return r},j.prototype.encode1_x7u0o8$=function(t){var n,i=h(),r=p(),o=this.DATA_SPEC_KEY_0;i.put_xwzc9p$(o,r);var a=p(),s=p();r.add_11rb$(a),r.add_11rb$(s);var l=w(t.keys);for(E(l),n=l.iterator();n.hasNext();){var u=n.next(),c=t.get_11rb$(u);if(e.isType(c,$)){var _=C.SeriesUtil.checkedDoubles_9ma18$(c),f=_.notEmptyAndCanBeCast();if(a.add_11rb$(u),s.add_11rb$(f),f){var d=b.BinaryUtil.encodeList_k9kaly$(_.cast());r.add_11rb$(d)}else r.add_11rb$(c)}}return i},j.$metadata$={kind:f,simpleName:"DataFrameEncoding",interfaces:[]};var R=null;function I(){return null===R&&new j,R}function z(){D=this}z.prototype.addDataChanges_0=function(t,e,n){var i;for(i=S.PlotSpecTransformUtil.getPlotAndLayersSpecSelectors_esgbho$(n,[T.PlotBase.DATA]).iterator();i.hasNext();){var r=i.next();t.change_t6n62v$(r,e)}return t},z.prototype.clientSideDecode_6taknv$=function(t){var e=O.Companion.builderForRawSpec();return this.addDataChanges_0(e,new P,t),this.addDataChanges_0(e,new A,t),e.build()},z.prototype.serverSideEncode_6taknv$=function(t){var e;return e=t?O.Companion.builderForRawSpec():O.Companion.builderForCleanSpec(),this.addDataChanges_0(e,new B,!1).build()},z.$metadata$={kind:f,simpleName:"DataSpecEncodeTransforms",interfaces:[]};var D=null;function M(){return null===D&&new z,D}function B(){}function U(){F=this}B.prototype.apply_il3x6g$=function(t,e){if(N.FeatureSwitch.printEncodedDataSummary_d0u64m$("DataFrameOptionHelper.encodeUpdateOption",t),N.FeatureSwitch.USE_DATA_FRAME_ENCODING){var n=I().encode1_x7u0o8$(t);t.clear(),t.putAll_a2k3zr$(n)}},B.$metadata$={kind:d,simpleName:"ServerSideEncodeChange",interfaces:[m]},U.prototype.processTransform_2wxo1b$=function(t){var e=l.Companion.isGGBunchSpec_bkhwtg$(t),n=M().clientSideDecode_6taknv$(e).apply_i49brq$(t);return c.Companion.processTransform_2wxo1b$(n)},U.$metadata$={kind:f,simpleName:"PlotConfigClientSideJvmJs",interfaces:[]};var F=null;var q=t.jetbrains||(t.jetbrains={}),G=q.datalore||(q.datalore={}),H=G.plot||(G.plot={}),Y=H.config||(H.config={}),V=Y.transform||(Y.transform={}),K=V.encode||(V.encode={});K.ClientSideDecodeChange=P,K.ClientSideDecodeOldStyleChange=A,Object.defineProperty(K,"DataFrameEncoding",{get:I}),Object.defineProperty(K,"DataSpecEncodeTransforms",{get:M}),K.ServerSideEncodeChange=B;var W=H.server||(H.server={}),X=W.config||(W.config={});return Object.defineProperty(X,"PlotConfigClientSideJvmJs",{get:function(){return null===F&&new U,F}}),B.prototype.isApplicable_x7u0o8$=m.prototype.isApplicable_x7u0o8$,t})?i.apply(e,r):i)||(t.exports=o)},362:function(t,e,n){var i,r,o;r=[e,n(421),n(521),n(836),n(958),n(767),n(770),n(564),n(623)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o,a,s,l){"use strict";var u=n.jetbrains.livemap.ui.CursorService,c=e.Kind.CLASS,p=e.kotlin.IllegalArgumentException_init_pdl1vj$,h=e.numberToInt,_=e.toString,f=i.jetbrains.datalore.plot.base.geom.PathGeom,d=i.jetbrains.datalore.plot.base.geom.util,m=e.kotlin.collections.ArrayList_init_287e2$,y=e.getCallableRef,$=i.jetbrains.datalore.plot.base.geom.SegmentGeom,v=e.kotlin.collections.ArrayList_init_ww73n8$,g=r.jetbrains.datalore.plot.common.data,b=e.ensureNotNull,w=e.kotlin.collections.emptyList_287e2$,x=o.jetbrains.datalore.base.geometry.DoubleVector,k=e.kotlin.collections.listOf_i5x0yv$,E=e.kotlin.collections.toList_7wnvza$,C=e.equals,S=i.jetbrains.datalore.plot.base.geom.PointGeom,T=o.jetbrains.datalore.base.typedGeometry.explicitVec_y7b45i$,O=Math,N=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$,P=i.jetbrains.datalore.plot.base.aes,A=i.jetbrains.datalore.plot.base.Aes,j=e.kotlin.IllegalStateException_init_pdl1vj$,L=e.throwUPAE,R=a.jetbrains.datalore.plot.config.Option.Geom.LiveMap,I=e.throwCCE,z=e.kotlin.Unit,D=n.jetbrains.livemap.config.DevParams,M=n.jetbrains.livemap.config.LiveMapSpec,B=e.kotlin.ranges.IntRange,U=e.Kind.OBJECT,F=e.kotlin.collections.List,q=s.jetbrains.gis.geoprotocol.MapRegion,G=o.jetbrains.datalore.base.spatial.convertToGeoRectangle_i3vl8m$,H=n.jetbrains.livemap.core.projections.ProjectionType,Y=e.kotlin.collections.HashMap_init_q3lmfv$,V=e.kotlin.collections.Map,K=n.jetbrains.livemap.MapLocation,W=n.jetbrains.livemap.tiles,X=o.jetbrains.datalore.base.values.Color,Z=a.jetbrains.datalore.plot.config.getString_wpa7aq$,J=s.jetbrains.gis.tileprotocol.TileService.Theme.valueOf_61zpoe$,Q=n.jetbrains.livemap.api.liveMapVectorTiles_jo61jr$,tt=e.unboxChar,et=e.kotlin.collections.listOf_mh5how$,nt=e.kotlin.ranges.CharRange,it=n.jetbrains.livemap.api.liveMapGeocoding_leryx0$,rt=n.jetbrains.livemap.api,ot=e.kotlin.collections.setOf_i5x0yv$,at=o.jetbrains.datalore.base.spatial,st=o.jetbrains.datalore.base.spatial.pointsBBox_2r9fhj$,lt=o.jetbrains.datalore.base.spatial.makeSegments_8o5yvy$,ut=e.kotlin.collections.checkIndexOverflow_za3lpa$,ct=e.kotlin.collections.Collection,pt=e.kotlin.text.get_indices_gw00vp$,ht=e.toBoxedChar,_t=e.kotlin.ranges.reversed_zf1xzc$,ft=e.kotlin.text.iterator_gw00vp$,dt=i.jetbrains.datalore.plot.base.interact.GeomTargetLocator,mt=i.jetbrains.datalore.plot.base.interact.TipLayoutHint,yt=e.kotlin.collections.emptyMap_q3lmfv$,$t=i.jetbrains.datalore.plot.base.interact.GeomTarget,vt=i.jetbrains.datalore.plot.base.GeomKind,gt=e.kotlin.to_ujzrz7$,bt=i.jetbrains.datalore.plot.base.interact.GeomTargetLocator.LookupResult,wt=e.getPropertyCallableRef,xt=e.kotlin.collections.first_2p1efm$,kt=n.jetbrains.livemap.api.point_4sq48w$,Et=n.jetbrains.livemap.api.points_5t73na$,Ct=n.jetbrains.livemap.api.polygon_z7sk6d$,St=n.jetbrains.livemap.api.polygons_6q4rqs$,Tt=n.jetbrains.livemap.api.path_noshw0$,Ot=n.jetbrains.livemap.api.paths_dvul77$,Nt=n.jetbrains.livemap.api.line_us2cr2$,Pt=n.jetbrains.livemap.api.vLines_t2cee4$,At=n.jetbrains.livemap.api.hLines_t2cee4$,jt=n.jetbrains.livemap.api.text_od6cu8$,Lt=n.jetbrains.livemap.api.texts_mbu85n$,Rt=n.jetbrains.livemap.api.pie_m5p8e8$,It=n.jetbrains.livemap.api.pies_vquu0q$,zt=n.jetbrains.livemap.api.bar_1evwdj$,Dt=n.jetbrains.livemap.api.bars_q7kt7x$,Mt=n.jetbrains.livemap.config.LiveMapFactory,Bt=n.jetbrains.livemap.config.LiveMapCanvasFigure,Ut=o.jetbrains.datalore.base.geometry.Rectangle_init_tjonv8$,Ft=i.jetbrains.datalore.plot.base.geom.LiveMapProvider.LiveMapData,qt=l.jetbrains.datalore.plot.builder,Gt=e.kotlin.collections.drop_ba2ldo$,Ht=n.jetbrains.livemap.ui,Yt=n.jetbrains.livemap.LiveMapLocation,Vt=i.jetbrains.datalore.plot.base.geom.LiveMapProvider,Kt=e.kotlin.collections.checkCountOverflow_za3lpa$,Wt=o.jetbrains.datalore.base.gcommon.collect,Xt=e.kotlin.collections.ArrayList_init_mqih57$,Zt=l.jetbrains.datalore.plot.builder.scale,Jt=i.jetbrains.datalore.plot.base.geom.util.GeomHelper,Qt=i.jetbrains.datalore.plot.base.render.svg.TextLabel.HorizontalAnchor,te=i.jetbrains.datalore.plot.base.render.svg.TextLabel.VerticalAnchor,ee=n.jetbrains.livemap.api.limitCoord_now9aw$,ne=n.jetbrains.livemap.api.geometry_5qim13$,ie=e.kotlin.Enum,re=e.throwISE,oe=e.kotlin.collections.get_lastIndex_55thoc$,ae=e.kotlin.collections.sortedWith_eknfly$,se=e.wrapFunction,le=e.kotlin.Comparator;function ue(){this.cursorService=new u}function ce(t){this.myGeodesic_0=t}function pe(t,e){this.myPointFeatureConverter_0=new de(this,t),this.mySinglePathFeatureConverter_0=new fe(this,t,e),this.myMultiPathFeatureConverter_0=new _e(this,t,e)}function he(t,e,n){this.$outer=t,this.aesthetics_8be2vx$=e,this.myGeodesic_0=n,this.myArrowSpec_0=null,this.myAnimation_0=null}function _e(t,e,n){this.$outer=t,he.call(this,this.$outer,e,n)}function fe(t,e,n){this.$outer=t,he.call(this,this.$outer,e,n)}function de(t,e){this.$outer=t,this.myAesthetics_0=e,this.myAnimation_0=null}function me(t,e){this.myAesthetics_0=t,this.myLayerKind_0=this.getLayerKind_0(e.displayMode),this.myGeodesic_0=e.geodesic,this.myFrameSpecified_0=this.allAesMatch_0(this.myAesthetics_0,y("isFrameSet",function(t,e){return t.isFrameSet_0(e)}.bind(null,this)))}function ye(t,e,n){this.geom=t,this.geomKind=e,this.aesthetics=n}function $e(){Ce(),this.myAesthetics_rxz54u$_0=this.myAesthetics_rxz54u$_0,this.myLayers_u9pl8d$_0=this.myLayers_u9pl8d$_0,this.myLiveMapOptions_92ydlj$_0=this.myLiveMapOptions_92ydlj$_0,this.myDataAccess_85d5nb$_0=this.myDataAccess_85d5nb$_0,this.mySize_1s22w4$_0=this.mySize_1s22w4$_0,this.myDevParams_rps7kc$_0=this.myDevParams_rps7kc$_0,this.myMapLocationConsumer_hhmy08$_0=this.myMapLocationConsumer_hhmy08$_0,this.myCursorService_1uez3k$_0=this.myCursorService_1uez3k$_0,this.minZoom_0=1,this.maxZoom_0=15}function ve(){Ee=this,this.REGION_TYPE_0="type",this.REGION_DATA_0="data",this.REGION_TYPE_NAME_0="region_name",this.REGION_TYPE_IDS_0="region_ids",this.REGION_TYPE_COORDINATES_0="coordinates",this.REGION_TYPE_DATAFRAME_0="data_frame",this.POINT_X_0="lon",this.POINT_Y_0="lat",this.RECT_XMIN_0="lonmin",this.RECT_XMAX_0="lonmax",this.RECT_YMIN_0="latmin",this.RECT_YMAX_0="latmax",this.DEFAULT_SHOW_TILES_0=!0,this.DEFAULT_LOOP_Y_0=!1,this.CYLINDRICAL_PROJECTIONS_0=ot([H.GEOGRAPHIC,H.MERCATOR])}function ge(){be=this,this.URL="url"}_e.prototype=Object.create(he.prototype),_e.prototype.constructor=_e,fe.prototype=Object.create(he.prototype),fe.prototype.constructor=fe,Xe.prototype=Object.create(ie.prototype),Xe.prototype.constructor=Xe,dn.prototype=Object.create(ie.prototype),dn.prototype.constructor=dn,ue.prototype.defaultSetter_o14v8n$=function(t){this.cursorService.default=t},ue.prototype.pointerSetter_o14v8n$=function(t){this.cursorService.pointer=t},ue.$metadata$={kind:c,simpleName:"CursorServiceConfig",interfaces:[]},ce.prototype.createConfigurator_blfxhp$=function(t,e){var n,i,r,o=e.geomKind,a=new pe(e.aesthetics,this.myGeodesic_0);switch(o.name){case"POINT":n=a.toPoint_qbow5e$(e.geom),i=Je();break;case"H_LINE":n=a.toHorizontalLine(),i=en();break;case"V_LINE":n=a.toVerticalLine(),i=nn();break;case"SEGMENT":n=a.toSegment_qbow5e$(e.geom),i=tn();break;case"RECT":n=a.toRect(),i=Qe();break;case"TILE":case"BIN_2D":n=a.toTile(),i=Qe();break;case"DENSITY2D":case"CONTOUR":case"PATH":n=a.toPath_qbow5e$(e.geom),i=tn();break;case"TEXT":n=a.toText(),i=rn();break;case"DENSITY2DF":case"CONTOURF":case"POLYGON":case"MAP":n=a.toPolygon(),i=Qe();break;default:throw p("Layer '"+o.name+"' is not supported on Live Map.")}for(r=n.iterator();r.hasNext();)r.next().layerIndex=t+1|0;return Ye().createLayersConfigurator_7kwpjf$(i,n)},pe.prototype.toPoint_qbow5e$=function(t){return this.myPointFeatureConverter_0.point_n4jwzf$(t)},pe.prototype.toHorizontalLine=function(){return this.myPointFeatureConverter_0.hLine_8be2vx$()},pe.prototype.toVerticalLine=function(){return this.myPointFeatureConverter_0.vLine_8be2vx$()},pe.prototype.toSegment_qbow5e$=function(t){return this.mySinglePathFeatureConverter_0.segment_n4jwzf$(t)},pe.prototype.toRect=function(){return this.myMultiPathFeatureConverter_0.rect_8be2vx$()},pe.prototype.toTile=function(){return this.mySinglePathFeatureConverter_0.tile_8be2vx$()},pe.prototype.toPath_qbow5e$=function(t){return this.myMultiPathFeatureConverter_0.path_n4jwzf$(t)},pe.prototype.toPolygon=function(){return this.myMultiPathFeatureConverter_0.polygon_8be2vx$()},pe.prototype.toText=function(){return this.myPointFeatureConverter_0.text_8be2vx$()},he.prototype.parsePathAnimation_0=function(t){if(null==t)return null;if(e.isNumber(t))return h(t);if("string"==typeof t)switch(t){case"dash":return 1;case"plane":return 2;case"circle":return 3}throw p("Unknown path animation: '"+_(t)+"'")},he.prototype.pathToBuilder_zbovrq$=function(t,e,n){return Ke(t,this.getRender_0(n)).setGeometryData_5qim13$(e,n,this.myGeodesic_0).setArrowSpec_la4xi3$(this.myArrowSpec_0).setAnimation_s8ev37$(this.myAnimation_0)},he.prototype.getRender_0=function(t){return t?Qe():tn()},he.prototype.setArrowSpec_28xgda$=function(t){this.myArrowSpec_0=t},he.prototype.setAnimation_8ea4ql$=function(t){this.myAnimation_0=this.parsePathAnimation_0(t)},he.$metadata$={kind:c,simpleName:"PathFeatureConverterBase",interfaces:[]},_e.prototype.path_n4jwzf$=function(t){return this.setAnimation_8ea4ql$(e.isType(t,f)?t.animation:null),this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.singlePointAppender_v9bvvf$(d.GeomUtil.TO_LOCATION_X_Y)),!1)},_e.prototype.polygon_8be2vx$=function(){return this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.singlePointAppender_v9bvvf$(d.GeomUtil.TO_LOCATION_X_Y)),!0)},_e.prototype.rect_8be2vx$=function(){return this.process_0(this.multiPointDataByGroup_0(d.MultiPointDataConstructor.multiPointAppender_t2aup3$(d.GeomUtil.TO_RECTANGLE)),!0)},_e.prototype.multiPointDataByGroup_0=function(t){return d.MultiPointDataConstructor.createMultiPointDataByGroup_ugj9hh$(this.aesthetics_8be2vx$.dataPoints(),t,d.MultiPointDataConstructor.collector())},_e.prototype.process_0=function(t,e){var n,i=m();for(n=t.iterator();n.hasNext();){var r=n.next(),o=this.pathToBuilder_zbovrq$(r.aes,this.$outer.toVecs_0(r.points),e);y("add",function(t,e){return t.add_11rb$(e)}.bind(null,i))(o)}return i},_e.$metadata$={kind:c,simpleName:"MultiPathFeatureConverter",interfaces:[he]},fe.prototype.tile_8be2vx$=function(){return this.process_0(!0,this.tileGeometryGenerator_0())},fe.prototype.segment_n4jwzf$=function(t){return this.setArrowSpec_28xgda$(e.isType(t,$)?t.arrowSpec:null),this.setAnimation_8ea4ql$(e.isType(t,$)?t.animation:null),this.process_0(!1,y("pointToSegmentGeometry",function(t,e){return t.pointToSegmentGeometry_0(e)}.bind(null,this)))},fe.prototype.process_0=function(t,e){var n,i=v(this.aesthetics_8be2vx$.dataPointCount());for(n=this.aesthetics_8be2vx$.dataPoints().iterator();n.hasNext();){var r=n.next(),o=e(r);if(!o.isEmpty()){var a=this.pathToBuilder_zbovrq$(r,this.$outer.toVecs_0(o),t);y("add",function(t,e){return t.add_11rb$(e)}.bind(null,i))(a)}}return i.trimToSize(),i},fe.prototype.tileGeometryGenerator_0=function(){return t=this.getMinXYNonZeroDistance_0(this.aesthetics_8be2vx$),e=this,function(n){if(g.SeriesUtil.allFinite_rd1tgs$(n.x(),n.y(),n.width(),n.height())){var i=e.nonZero_0(b(n.width())*t.x,1),r=e.nonZero_0(b(n.height())*t.y,1);return d.GeomUtil.rectToGeometry_6y0v78$(b(n.x())-i/2,b(n.y())-r/2,b(n.x())+i/2,b(n.y())+r/2)}return w()};var t,e},fe.prototype.pointToSegmentGeometry_0=function(t){return g.SeriesUtil.allFinite_rd1tgs$(t.x(),t.y(),t.xend(),t.yend())?k([new x(b(t.x()),b(t.y())),new x(b(t.xend()),b(t.yend()))]):w()},fe.prototype.nonZero_0=function(t,e){return 0===t?e:t},fe.prototype.getMinXYNonZeroDistance_0=function(t){var e=E(t.dataPoints());if(e.size<2)return x.Companion.ZERO;for(var n=0,i=0,r=0,o=e.size-1|0;rh)throw p("Error parsing subdomains: wrong brackets order");var _,f=l+1|0,d=t.substring(f,h);if(0===d.length)throw p("Empty subdomains list");t:do{var m;for(m=ft(d);m.hasNext();){var y=tt(m.next()),$=ht(y),g=new nt(97,122),b=tt($);if(!g.contains_mef7kx$(String.fromCharCode(b).toLowerCase().charCodeAt(0))){_=!0;break t}}_=!1}while(0);if(_)throw p("subdomain list contains non-letter symbols");var w,x=t.substring(0,l),k=h+1|0,E=t.length,C=t.substring(k,E),S=v(d.length);for(w=ft(d);w.hasNext();){var T=tt(w.next()),O=S.add_11rb$,N=ht(T);O.call(S,x+String.fromCharCode(N)+C)}return S},ve.prototype.createGeocodingService_0=function(t){var n,i,r,o,a=we().URL;return null!=(i=null!=(n=(e.isType(r=t,V)?r:I()).get_11rb$(a))?it((o=n,function(t){var e;return t.url="string"==typeof(e=o)?e:I(),z})):null)?i:rt.Services.bogusGeocodingService()},ve.$metadata$={kind:U,simpleName:"Companion",interfaces:[]};var Ee=null;function Ce(){return null===Ee&&new ve,Ee}function Se(){Te=this}Se.prototype.calculateBoundingBox_d3e2cz$=function(t){return st(at.BBOX_CALCULATOR,t)},Se.prototype.calculateBoundingBox_2a5262$=function(t,e){if(t.size!==e.size)throw p("Longitude list count is not equal Latitude list count.".toString());return at.BBOX_CALCULATOR.calculateBoundingBox_qpfwx8$(lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),t.size),lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),t.size))},Se.prototype.calculateBoundingBox_55b83s$=function(t,e,n,i){var r=t.size;if(e.size!==r||n.size!==r||i.size!==r)throw p("Counts of 'minLongitudes', 'minLatitudes', 'maxLongitudes', 'maxLatitudes' lists are not equal.".toString());return at.BBOX_CALCULATOR.calculateBoundingBox_qpfwx8$(lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,t)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,n)),r),lt(y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,e)),y("get",function(t,e){return t.get_za3lpa$(e)}.bind(null,i)),r))},Se.$metadata$={kind:U,simpleName:"BboxUtil",interfaces:[]};var Te=null;function Oe(){return null===Te&&new Se,Te}function Ne(t,e){var n;this.myTargetSource_0=e,this.myLiveMap_0=null,t.map_2o04qz$((n=this,function(t){return n.myLiveMap_0=t,z}))}function Pe(){He=this}function Ae(t,e){return function(n){switch(t.name){case"POINT":Et(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toPointBuilder())&&y("point",function(t,e){return kt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"POLYGON":St(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i=n.next();Ct(e,i.createPolygonConfigurator())}return z}}(e));break;case"PATH":Ot(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toPathBuilder())&&y("path",function(t,e){return Tt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"V_LINE":Pt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toLineBuilder())&&y("line",function(t,e){return Nt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"H_LINE":At(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toLineBuilder())&&y("line",function(t,e){return Nt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"TEXT":Lt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toTextBuilder())&&y("text",function(t,e){return jt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"PIE":It(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toChartBuilder())&&y("pie",function(t,e){return Rt(t,e),z}.bind(null,e))(i)}return z}}(e));break;case"BAR":Dt(n,function(t){return function(e){var n;for(n=t.iterator();n.hasNext();){var i;null!=(i=n.next().toChartBuilder())&&y("bar",function(t,e){return zt(t,e),z}.bind(null,e))(i)}return z}}(e));break;default:throw j(("Unsupported layer kind: "+t).toString())}return z}}function je(t,e,n){if(this.myLiveMapOptions_0=e,this.liveMapSpecBuilder_0=null,this.myTargetSource_0=Y(),t.isEmpty())throw p("Failed requirement.".toString());if(!xt(t).isLiveMap)throw p("geom_livemap have to be the very first geom after ggplot()".toString());var i,r,o,a=Le,s=v(N(t,10));for(i=t.iterator();i.hasNext();){var l=i.next();s.add_11rb$(a(l))}var u=0;for(r=s.iterator();r.hasNext();){var c,h=r.next(),_=ut((u=(o=u)+1|0,o));for(c=h.aesthetics.dataPoints().iterator();c.hasNext();){var f=c.next(),d=this.myTargetSource_0,m=gt(_,f.index()),y=h.contextualMapping;d.put_xwzc9p$(m,y)}}var $,g=Gt(t,1),b=v(N(g,10));for($=g.iterator();$.hasNext();){var w=$.next();b.add_11rb$(a(w))}var x,k=v(N(b,10));for(x=b.iterator();x.hasNext();){var E=x.next();k.add_11rb$(new ye(E.geom,E.geomKind,E.aesthetics))}var C=k,S=a(xt(t));this.liveMapSpecBuilder_0=(new $e).liveMapOptions_d2y5pu$(this.myLiveMapOptions_0).aesthetics_m7huy5$(S.aesthetics).dataAccess_c3j6od$(S.dataAccess).layers_ipzze3$(C).devParams_5pp8sb$(new D(this.myLiveMapOptions_0.devParams)).mapLocationConsumer_te0ohe$(Re).cursorService_kmk1wb$(n)}function Le(t){return qt.LayerRendererUtil.createLayerRendererData_knseyn$(t,yt(),yt())}function Re(t){return Ht.Clipboard.copy_61zpoe$(Yt.Companion.getLocationString_wthzt5$(t)),z}$e.$metadata$={kind:c,simpleName:"LiveMapSpecBuilder",interfaces:[]},Ne.prototype.search_gpjtzr$=function(t){var e,n,i;if(null!=(n=null!=(e=this.myLiveMap_0)?e.searchResult():null)){var r,o,a;if(r=et(new $t(n.index,mt.Companion.cursorTooltip_itpcqk$(t,n.color),yt())),o=vt.LIVE_MAP,null==(a=this.myTargetSource_0.get_11rb$(gt(n.layerIndex,n.index))))throw j("Can't find target.".toString());i=new bt(r,0,o,a,!1)}else i=null;return i},Ne.$metadata$={kind:c,simpleName:"LiveMapTargetLocator",interfaces:[dt]},Pe.prototype.injectLiveMapProvider_q1corz$=function(t,n,i){var r;for(r=t.iterator();r.hasNext();){var o,a=r.next(),s=wt("isLiveMap",1,(function(t){return t.isLiveMap}));t:do{var l;if(e.isType(a,ct)&&a.isEmpty()){o=!1;break t}for(l=a.iterator();l.hasNext();)if(s(l.next())){o=!0;break t}o=!1}while(0);if(o){var u,c=wt("isLiveMap",1,(function(t){return t.isLiveMap}));t:do{var h;if(e.isType(a,ct)&&a.isEmpty()){u=0;break t}var _=0;for(h=a.iterator();h.hasNext();)c(h.next())&&Kt(_=_+1|0);u=_}while(0);if(1!==u)throw p("Failed requirement.".toString());if(!xt(a).isLiveMap)throw p("Failed requirement.".toString());xt(a).setLiveMapProvider_kld0fp$(new je(a,n,i.cursorService))}}},Pe.prototype.createLayersConfigurator_7kwpjf$=function(t,e){return Ae(t,e)},je.prototype.createLiveMap_wthzt5$=function(t){var e=new Mt(this.liveMapSpecBuilder_0.size_gpjtzr$(t.dimension).build()).createLiveMap(),n=new Bt(e);return n.setBounds_vfns7u$(Ut(h(t.origin.x),h(t.origin.y),h(t.dimension.x),h(t.dimension.y))),new Ft(n,new Ne(e,this.myTargetSource_0))},je.$metadata$={kind:c,simpleName:"MyLiveMapProvider",interfaces:[Vt]},Pe.$metadata$={kind:U,simpleName:"LiveMapUtil",interfaces:[]};var Ie,ze,De,Me,Be,Ue,Fe,qe,Ge,He=null;function Ye(){return null===He&&new Pe,He}function Ve(){this.myP_0=null,this.indices_0=w(),this.myArrowSpec_0=null,this.myValueArray_0=w(),this.myColorArray_0=w(),this.myLayerKind=null,this.geometry=null,this.point=null,this.animation=0,this.geodesic=!1,this.layerIndex=null}function Ke(t,e,n){return n=n||Object.create(Ve.prototype),Ve.call(n),n.myLayerKind=e,n.myP_0=t,n}function We(t,e,n){return n=n||Object.create(Ve.prototype),Ve.call(n),n.myLayerKind=e,n.myP_0=t.aes,n.indices_0=t.indices,n.myValueArray_0=t.values,n.myColorArray_0=t.colors,n}function Xe(t,e){ie.call(this),this.name$=t,this.ordinal$=e}function Ze(){Ze=function(){},Ie=new Xe("POINT",0),ze=new Xe("POLYGON",1),De=new Xe("PATH",2),Me=new Xe("H_LINE",3),Be=new Xe("V_LINE",4),Ue=new Xe("TEXT",5),Fe=new Xe("PIE",6),qe=new Xe("BAR",7),Ge=new Xe("HEATMAP",8)}function Je(){return Ze(),Ie}function Qe(){return Ze(),ze}function tn(){return Ze(),De}function en(){return Ze(),Me}function nn(){return Ze(),Be}function rn(){return Ze(),Ue}function on(){return Ze(),Fe}function an(){return Ze(),qe}function sn(){return Ze(),Ge}Object.defineProperty(Ve.prototype,"index",{configurable:!0,get:function(){return this.myP_0.index()}}),Object.defineProperty(Ve.prototype,"shape",{configurable:!0,get:function(){return b(this.myP_0.shape()).code}}),Object.defineProperty(Ve.prototype,"size",{configurable:!0,get:function(){return P.AestheticsUtil.textSize_l6g9mh$(this.myP_0)}}),Object.defineProperty(Ve.prototype,"speed",{configurable:!0,get:function(){return b(this.myP_0.speed())}}),Object.defineProperty(Ve.prototype,"flow",{configurable:!0,get:function(){return b(this.myP_0.flow())}}),Object.defineProperty(Ve.prototype,"fillColor",{configurable:!0,get:function(){return this.colorWithAlpha_0(b(this.myP_0.fill()))}}),Object.defineProperty(Ve.prototype,"strokeColor",{configurable:!0,get:function(){return C(this.myLayerKind,Qe())?b(this.myP_0.color()):this.colorWithAlpha_0(b(this.myP_0.color()))}}),Object.defineProperty(Ve.prototype,"label",{configurable:!0,get:function(){var t,e;return null!=(e=null!=(t=this.myP_0.label())?t.toString():null)?e:"n/a"}}),Object.defineProperty(Ve.prototype,"family",{configurable:!0,get:function(){return this.myP_0.family()}}),Object.defineProperty(Ve.prototype,"hjust",{configurable:!0,get:function(){return this.hjust_0(this.myP_0.hjust())}}),Object.defineProperty(Ve.prototype,"vjust",{configurable:!0,get:function(){return this.vjust_0(this.myP_0.vjust())}}),Object.defineProperty(Ve.prototype,"angle",{configurable:!0,get:function(){return b(this.myP_0.angle())}}),Object.defineProperty(Ve.prototype,"fontface",{configurable:!0,get:function(){var t=this.myP_0.fontface();return C(t,P.AesInitValue.get_31786j$(A.Companion.FONTFACE))?"":t}}),Object.defineProperty(Ve.prototype,"radius",{configurable:!0,get:function(){switch(this.myLayerKind.name){case"POLYGON":case"PATH":case"H_LINE":case"V_LINE":case"POINT":case"PIE":case"BAR":var t=b(this.myP_0.shape()).size_l6g9mh$(this.myP_0)/2;return O.ceil(t);case"HEATMAP":return b(this.myP_0.size());case"TEXT":return 0;default:return e.noWhenBranchMatched()}}}),Object.defineProperty(Ve.prototype,"strokeWidth",{configurable:!0,get:function(){switch(this.myLayerKind.name){case"POLYGON":case"PATH":case"H_LINE":case"V_LINE":return P.AestheticsUtil.strokeWidth_l6g9mh$(this.myP_0);case"POINT":case"PIE":case"BAR":return 1;case"TEXT":case"HEATMAP":return 0;default:return e.noWhenBranchMatched()}}}),Object.defineProperty(Ve.prototype,"lineDash",{configurable:!0,get:function(){var t=this.myP_0.lineType();if(t.isSolid||t.isBlank)return w();var e,n=P.AestheticsUtil.strokeWidth_l6g9mh$(this.myP_0);return Xt(Wt.Lists.transform_l7riir$(t.dashArray,(e=n,function(t){return t*e})))}}),Object.defineProperty(Ve.prototype,"colorArray_0",{configurable:!0,get:function(){return this.myLayerKind===on()&&this.allZeroes_0(this.myValueArray_0)?this.createNaColorList_0(this.myValueArray_0.size):this.myColorArray_0}}),Ve.prototype.allZeroes_0=function(t){var n,i=y("equals",function(t,e){return C(t,e)}.bind(null,0));t:do{var r;if(e.isType(t,ct)&&t.isEmpty()){n=!0;break t}for(r=t.iterator();r.hasNext();)if(!i(r.next())){n=!1;break t}n=!0}while(0);return n},Ve.prototype.createNaColorList_0=function(t){for(var e=v(t),n=0;n0&&(a=a+"/"+l);var u=a;return d(o).replaceFirst_x2uqeu$(t,u)},le.prototype.scaleFontValue_0=function(t,e){return null==t?"":(t*e).toString()+"px"},le.$metadata$={kind:s,simpleName:"CssStyleUtil",interfaces:[]};var ue=null;function ce(){this.myLastTick_0=g,this.myDt_0=g}function pe(){}function he(t,e){return function(n){return e.schedule_klfg04$(function(t,e){return function(){return t.success_11rb$(e),w}}(t,n)),w}}function _e(t,e){return function(n){return e.schedule_klfg04$(function(t,e){return function(){return t.failure_tcv7n7$(e),w}}(t,n)),w}}function fe(t){this.myEventHandlers_51nth5$_0=E()}function de(t,e,n){this.closure$addReg=t,this.this$EventPeer=e,this.closure$eventSpec=n}function me(t){this.closure$event=t}function ye(t,e,n){this.size_mf5u5r$_0=e,this.context2d_imt5ib$_0=1===n?t:new $e(t,n)}function $e(t,e){this.myContext2d_0=t,this.myScale_0=e}function ve(t){this.myCanvasControl_0=t,this.canvas=null,this.canvas=this.myCanvasControl_0.createCanvas_119tl4$(this.myCanvasControl_0.size),this.myCanvasControl_0.addChild_eqkm0m$(this.canvas)}function ge(){}function be(){this.myHandle_0=null,this.myIsStarted_0=!1,this.myIsStarted_0=!1}function we(t,n,i){var r;Ce(),ye.call(this,new Pe(e.isType(r=t.getContext("2d"),CanvasRenderingContext2D)?r:$()),n,i),this.canvasElement=t,N(this.canvasElement.style,n.x),P(this.canvasElement.style,n.y);var o=this.canvasElement,a=n.x*i;o.width=A(j.ceil(a));var s=this.canvasElement,l=n.y*i;s.height=A(j.ceil(l))}function xe(t){this.$outer=t}function ke(){Ee=this,this.DEVICE_PIXEL_RATIO=window.devicePixelRatio}ce.prototype.tick_s8cxhz$=function(t){return this.myLastTick_0.toNumber()>0&&(this.myDt_0=t.subtract(this.myLastTick_0)),this.myLastTick_0=t,this.myDt_0},ce.prototype.dt=function(){return this.myDt_0},ce.$metadata$={kind:a,simpleName:"DeltaTime",interfaces:[]},pe.$metadata$={kind:o,simpleName:"Dispatcher",interfaces:[]},de.prototype.dispose=function(){this.closure$addReg.remove(),u(this.this$EventPeer.myEventHandlers_51nth5$_0.get_11rb$(this.closure$eventSpec)).isEmpty&&(this.this$EventPeer.myEventHandlers_51nth5$_0.remove_11rb$(this.closure$eventSpec),this.this$EventPeer.onSpecRemoved_1gkqfp$(this.closure$eventSpec))},de.$metadata$={kind:a,interfaces:[p]},fe.prototype.addEventHandler_b14a3c$=function(t,e){if(!this.myEventHandlers_51nth5$_0.containsKey_11rb$(t)){var n=this.myEventHandlers_51nth5$_0,i=new x;n.put_xwzc9p$(t,i),this.onSpecAdded_1gkqfp$(t)}var r=u(this.myEventHandlers_51nth5$_0.get_11rb$(t)).add_11rb$(e);return c.Companion.from_gg3y3y$(new de(r,this,t))},me.prototype.call_11rb$=function(t){t.onEvent_11rb$(this.closure$event)},me.$metadata$={kind:a,interfaces:[k]},fe.prototype.dispatch_b6y3vz$=function(t,e){var n;null!=(n=this.myEventHandlers_51nth5$_0.get_11rb$(t))&&n.fire_kucmxw$(new me(e))},fe.$metadata$={kind:a,simpleName:"EventPeer",interfaces:[]},Object.defineProperty(ye.prototype,"size",{get:function(){return this.size_mf5u5r$_0}}),Object.defineProperty(ye.prototype,"context2d",{configurable:!0,get:function(){return this.context2d_imt5ib$_0}}),ye.$metadata$={kind:a,simpleName:"ScaledCanvas",interfaces:[Q]},$e.prototype.scaled_0=function(t){return this.myScale_0*t},$e.prototype.descaled_0=function(t){return t/this.myScale_0},$e.prototype.scaled_1=function(t){if(1===this.myScale_0)return t;for(var e=new Float64Array(t.length),n=0;n!==t.length;++n)e[n]=this.scaled_0(t[n]);return e},$e.prototype.scaled_2=function(t){return t.copy_edneyn$(void 0,void 0,t.fontSize*this.myScale_0)},$e.prototype.drawImage_xo47pw$=function(t,e,n){this.myContext2d_0.drawImage_xo47pw$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.drawImage_nks7bk$=function(t,e,n,i,r){this.myContext2d_0.drawImage_nks7bk$(t,this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r))},$e.prototype.drawImage_urnjjc$=function(t,e,n,i,r,o,a,s,l){this.myContext2d_0.drawImage_urnjjc$(t,this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r),this.scaled_0(o),this.scaled_0(a),this.scaled_0(s),this.scaled_0(l))},$e.prototype.beginPath=function(){this.myContext2d_0.beginPath()},$e.prototype.closePath=function(){this.myContext2d_0.closePath()},$e.prototype.stroke=function(){this.myContext2d_0.stroke()},$e.prototype.fill=function(){this.myContext2d_0.fill()},$e.prototype.fillRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.fillRect_6y0v78$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i))},$e.prototype.moveTo_lu1900$=function(t,e){this.myContext2d_0.moveTo_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.lineTo_lu1900$=function(t,e){this.myContext2d_0.lineTo_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.arc_6p3vsx$$default=function(t,e,n,i,r,o){this.myContext2d_0.arc_6p3vsx$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),i,r,o)},$e.prototype.save=function(){this.myContext2d_0.save()},$e.prototype.restore=function(){this.myContext2d_0.restore()},$e.prototype.setFillStyle_2160e9$=function(t){this.myContext2d_0.setFillStyle_2160e9$(t)},$e.prototype.setStrokeStyle_2160e9$=function(t){this.myContext2d_0.setStrokeStyle_2160e9$(t)},$e.prototype.setGlobalAlpha_14dthe$=function(t){this.myContext2d_0.setGlobalAlpha_14dthe$(t)},$e.prototype.setFont_ov8mpe$=function(t){this.myContext2d_0.setFont_ov8mpe$(this.scaled_2(t))},$e.prototype.setLineWidth_14dthe$=function(t){this.myContext2d_0.setLineWidth_14dthe$(this.scaled_0(t))},$e.prototype.strokeRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.strokeRect_6y0v78$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i))},$e.prototype.strokeText_ai6r6m$=function(t,e,n){this.myContext2d_0.strokeText_ai6r6m$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.fillText_ai6r6m$=function(t,e,n){this.myContext2d_0.fillText_ai6r6m$(t,this.scaled_0(e),this.scaled_0(n))},$e.prototype.scale_lu1900$=function(t,e){this.myContext2d_0.scale_lu1900$(t,e)},$e.prototype.rotate_14dthe$=function(t){this.myContext2d_0.rotate_14dthe$(t)},$e.prototype.translate_lu1900$=function(t,e){this.myContext2d_0.translate_lu1900$(this.scaled_0(t),this.scaled_0(e))},$e.prototype.transform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.transform_15yvbs$(t,e,n,i,this.scaled_0(r),this.scaled_0(o))},$e.prototype.bezierCurveTo_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.bezierCurveTo_15yvbs$(this.scaled_0(t),this.scaled_0(e),this.scaled_0(n),this.scaled_0(i),this.scaled_0(r),this.scaled_0(o))},$e.prototype.setLineJoin_v2gigt$=function(t){this.myContext2d_0.setLineJoin_v2gigt$(t)},$e.prototype.setLineCap_useuqn$=function(t){this.myContext2d_0.setLineCap_useuqn$(t)},$e.prototype.setTextBaseline_5cz80h$=function(t){this.myContext2d_0.setTextBaseline_5cz80h$(t)},$e.prototype.setTextAlign_iwro1z$=function(t){this.myContext2d_0.setTextAlign_iwro1z$(t)},$e.prototype.setTransform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.setTransform_15yvbs$(t,e,n,i,this.scaled_0(r),this.scaled_0(o))},$e.prototype.fillEvenOdd=function(){this.myContext2d_0.fillEvenOdd()},$e.prototype.setLineDash_gf7tl1$=function(t){this.myContext2d_0.setLineDash_gf7tl1$(this.scaled_1(t))},$e.prototype.measureText_61zpoe$=function(t){return this.descaled_0(this.myContext2d_0.measureText_61zpoe$(t))},$e.prototype.clearRect_wthzt5$=function(t){this.myContext2d_0.clearRect_wthzt5$(new C(t.origin.mul_14dthe$(2),t.dimension.mul_14dthe$(2)))},$e.$metadata$={kind:a,simpleName:"ScaledContext2d",interfaces:[kt]},Object.defineProperty(ve.prototype,"context",{configurable:!0,get:function(){return this.canvas.context2d}}),Object.defineProperty(ve.prototype,"size",{configurable:!0,get:function(){return this.myCanvasControl_0.size}}),ve.prototype.createCanvas=function(){return this.myCanvasControl_0.createCanvas_119tl4$(this.myCanvasControl_0.size)},ve.prototype.dispose=function(){this.myCanvasControl_0.removeChild_eqkm0m$(this.canvas)},ve.$metadata$={kind:a,simpleName:"SingleCanvasControl",interfaces:[]},ge.$metadata$={kind:o,simpleName:"CanvasFigure",interfaces:[S]},be.prototype.start=function(){this.myIsStarted_0||(this.myIsStarted_0=!0,this.requestNextFrame_0())},be.prototype.stop=function(){this.myIsStarted_0&&(this.myIsStarted_0=!1,window.cancelAnimationFrame(u(this.myHandle_0)))},be.prototype.execute_0=function(t){this.myIsStarted_0&&(this.handle_s8cxhz$(e.Long.fromNumber(t)),this.requestNextFrame_0())},be.prototype.requestNextFrame_0=function(){var t;this.myHandle_0=window.requestAnimationFrame((t=this,function(e){return t.execute_0(e),w}))},be.$metadata$={kind:a,simpleName:"DomAnimationTimer",interfaces:[V]},we.prototype.takeSnapshot=function(){return O.Asyncs.constant_mh5how$(new xe(this))},Object.defineProperty(xe.prototype,"canvasElement",{configurable:!0,get:function(){return this.$outer.canvasElement}}),xe.$metadata$={kind:a,simpleName:"DomSnapshot",interfaces:[tt]},ke.prototype.create_duqvgq$=function(t,n){var i;return new we(e.isType(i=document.createElement("canvas"),HTMLCanvasElement)?i:$(),t,n)},ke.$metadata$={kind:s,simpleName:"Companion",interfaces:[]};var Ee=null;function Ce(){return null===Ee&&new ke,Ee}function Se(t,e,n){this.myRootElement_0=t,this.size_malc5o$_0=e,this.myEventPeer_0=n}function Te(t){this.closure$eventHandler=t,be.call(this)}function Oe(t,n,i,r){return function(o){var a,s,l;if(null!=t){var u,c=t;l=e.isType(u=n.createCanvas_119tl4$(c),we)?u:$()}else l=null;var p=null!=(a=l)?a:Ce().create_duqvgq$(new M(i.width,i.height),1);return(e.isType(s=p.canvasElement.getContext("2d"),CanvasRenderingContext2D)?s:$()).drawImage(i,0,0,p.canvasElement.width,p.canvasElement.height),p.takeSnapshot().onSuccess_qlkmfe$(function(t){return function(e){return t(e),w}}(r))}}function Ne(t,e){var n;fe.call(this,q(G)),this.myEventTarget_0=t,this.myTargetBounds_0=e,this.myButtonPressed_0=!1,this.myWasDragged_0=!1,this.myButtonPressCoord_0=null,this.myDragToleranceDistance_0=3,this.handle_0(U.Companion.MOUSE_ENTER,(n=this,function(t){if(n.isHitOnTarget_0(t))return n.dispatch_b6y3vz$(G.MOUSE_ENTERED,n.translate_0(t)),w})),this.handle_0(U.Companion.MOUSE_LEAVE,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.dispatch_b6y3vz$(G.MOUSE_LEFT,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.CLICK,function(t){return function(e){if(!t.myWasDragged_0){if(!t.isHitOnTarget_0(e))return;t.dispatch_b6y3vz$(G.MOUSE_CLICKED,t.translate_0(e))}return t.myWasDragged_0=!1,w}}(this)),this.handle_0(U.Companion.DOUBLE_CLICK,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.dispatch_b6y3vz$(G.MOUSE_DOUBLE_CLICKED,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_DOWN,function(t){return function(e){if(t.isHitOnTarget_0(e))return t.myButtonPressed_0=!0,t.myButtonPressCoord_0=new M(A(e.x),A(e.y)),t.dispatch_b6y3vz$(G.MOUSE_PRESSED,F.DomEventUtil.translateInPageCoord_tfvzir$(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_UP,function(t){return function(e){return t.myButtonPressed_0=!1,t.myButtonPressCoord_0=null,t.dispatch_b6y3vz$(G.MOUSE_RELEASED,t.translate_0(e)),w}}(this)),this.handle_0(U.Companion.MOUSE_MOVE,function(t){return function(e){var n,i,r;if(t.myWasDragged_0)t.dispatch_b6y3vz$(G.MOUSE_DRAGGED,F.DomEventUtil.translateInPageCoord_tfvzir$(e));else if(t.myButtonPressed_0&&!t.myWasDragged_0)(null!=(r=null!=(i=null!=(n=t.myButtonPressCoord_0)?n.sub_119tl4$(new M(A(e.x),A(e.y))):null)?i.length():null)?r:0)>t.myDragToleranceDistance_0&&(t.myWasDragged_0=!0,t.dispatch_b6y3vz$(G.MOUSE_DRAGGED,F.DomEventUtil.translateInPageCoord_tfvzir$(e)));else if(!t.myButtonPressed_0&&!t.myWasDragged_0){if(!t.isHitOnTarget_0(e))return;t.dispatch_b6y3vz$(G.MOUSE_MOVED,t.translate_0(e))}return w}}(this))}function Pe(t){this.myContext2d_0=t}we.$metadata$={kind:a,simpleName:"DomCanvas",interfaces:[ye]},Object.defineProperty(Se.prototype,"size",{get:function(){return this.size_malc5o$_0}}),Te.prototype.handle_s8cxhz$=function(t){this.closure$eventHandler.onEvent_s8cxhz$(t)},Te.$metadata$={kind:a,interfaces:[be]},Se.prototype.createAnimationTimer_ckdfex$=function(t){return new Te(t)},Se.prototype.addEventHandler_mfdhbe$=function(t,e){return this.myEventPeer_0.addEventHandler_b14a3c$(t,L((n=e,function(t){return n.onEvent_11rb$(t),w})));var n},Se.prototype.createCanvas_119tl4$=function(t){var e=Ce().create_duqvgq$(t,Ce().DEVICE_PIXEL_RATIO);return I(e.canvasElement.style,R.ABSOLUTE),e},Se.prototype.createSnapshot_61zpoe$=function(t){return this.createSnapshotAsync_0(t,null)},Se.prototype.createSnapshot_50eegg$=function(t,e){var n={type:"image/png"};return this.createSnapshotAsync_0(URL.createObjectURL(new Blob([t],n)),e)},Se.prototype.createSnapshotAsync_0=function(t,e){void 0===e&&(e=null);var n=new z,i=new Image;return i.onload=this.onLoad_0(i,e,D("success",function(t,e){return t.success_11rb$(e),w}.bind(null,n))),i.src=t,n},Se.prototype.onLoad_0=function(t,e,n){return Oe(e,this,t,n)},Se.prototype.addChild_eqkm0m$=function(t){var n;this.myRootElement_0.appendChild((e.isType(n=t,we)?n:$()).canvasElement)},Se.prototype.addChild_fwfip8$=function(t,n){var i;this.myRootElement_0.insertBefore((e.isType(i=n,we)?i:$()).canvasElement,this.myRootElement_0.childNodes[t])},Se.prototype.removeChild_eqkm0m$=function(t){var n;this.myRootElement_0.removeChild((e.isType(n=t,we)?n:$()).canvasElement)},Se.prototype.schedule_klfg04$=function(t){t()},Ne.prototype.handle_0=function(t,e){var n;this.targetNode_0(t).addEventListener(t.name,new B((n=e,function(t){return n(t),!1})))},Ne.prototype.targetNode_0=function(t){return T(t,U.Companion.MOUSE_MOVE)||T(t,U.Companion.MOUSE_UP)?document:this.myEventTarget_0},Ne.prototype.onSpecAdded_1gkqfp$=function(t){},Ne.prototype.onSpecRemoved_1gkqfp$=function(t){},Ne.prototype.isHitOnTarget_0=function(t){return this.myTargetBounds_0.contains_119tl4$(new M(A(t.offsetX),A(t.offsetY)))},Ne.prototype.translate_0=function(t){return F.DomEventUtil.translateInTargetCoordWithOffset_6zzdys$(t,this.myEventTarget_0,this.myTargetBounds_0.origin)},Ne.$metadata$={kind:a,simpleName:"DomEventPeer",interfaces:[fe]},Se.$metadata$={kind:a,simpleName:"DomCanvasControl",interfaces:[et]},Pe.prototype.convertLineJoin_0=function(t){var n;switch(t.name){case"BEVEL":n="bevel";break;case"MITER":n="miter";break;case"ROUND":n="round";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertLineCap_0=function(t){var n;switch(t.name){case"BUTT":n="butt";break;case"ROUND":n="round";break;case"SQUARE":n="square";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertTextBaseline_0=function(t){var n;switch(t.name){case"ALPHABETIC":n="alphabetic";break;case"BOTTOM":n="bottom";break;case"MIDDLE":n="middle";break;case"TOP":n="top";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.convertTextAlign_0=function(t){var n;switch(t.name){case"CENTER":n="center";break;case"END":n="end";break;case"START":n="start";break;default:n=e.noWhenBranchMatched()}return n},Pe.prototype.drawImage_xo47pw$=function(t,n,i){var r,o=e.isType(r=t,xe)?r:$();this.myContext2d_0.drawImage(o.canvasElement,n,i)},Pe.prototype.drawImage_nks7bk$=function(t,n,i,r,o){var a,s=e.isType(a=t,xe)?a:$();this.myContext2d_0.drawImage(s.canvasElement,n,i,r,o)},Pe.prototype.drawImage_urnjjc$=function(t,n,i,r,o,a,s,l,u){var c,p=e.isType(c=t,xe)?c:$();this.myContext2d_0.drawImage(p.canvasElement,n,i,r,o,a,s,l,u)},Pe.prototype.beginPath=function(){this.myContext2d_0.beginPath()},Pe.prototype.closePath=function(){this.myContext2d_0.closePath()},Pe.prototype.stroke=function(){this.myContext2d_0.stroke()},Pe.prototype.fill=function(){this.myContext2d_0.fill("nonzero")},Pe.prototype.fillEvenOdd=function(){this.myContext2d_0.fill("evenodd")},Pe.prototype.fillRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.fillRect(t,e,n,i)},Pe.prototype.moveTo_lu1900$=function(t,e){this.myContext2d_0.moveTo(t,e)},Pe.prototype.lineTo_lu1900$=function(t,e){this.myContext2d_0.lineTo(t,e)},Pe.prototype.arc_6p3vsx$$default=function(t,e,n,i,r,o){this.myContext2d_0.arc(t,e,n,i,r,o)},Pe.prototype.save=function(){this.myContext2d_0.save()},Pe.prototype.restore=function(){this.myContext2d_0.restore()},Pe.prototype.setFillStyle_2160e9$=function(t){this.myContext2d_0.fillStyle=null!=t?t.toCssColor():null},Pe.prototype.setStrokeStyle_2160e9$=function(t){this.myContext2d_0.strokeStyle=null!=t?t.toCssColor():null},Pe.prototype.setGlobalAlpha_14dthe$=function(t){this.myContext2d_0.globalAlpha=t},Pe.prototype.toCssString_0=function(t){var n,i;switch(t.fontWeight.name){case"NORMAL":n="normal";break;case"BOLD":n="bold";break;default:n=e.noWhenBranchMatched()}var r=n;switch(t.fontStyle.name){case"NORMAL":i="normal";break;case"ITALIC":i="italic";break;default:i=e.noWhenBranchMatched()}return i+" "+r+" "+t.fontSize+"px "+t.fontFamily},Pe.prototype.setFont_ov8mpe$=function(t){this.myContext2d_0.font=this.toCssString_0(t)},Pe.prototype.setLineWidth_14dthe$=function(t){this.myContext2d_0.lineWidth=t},Pe.prototype.strokeRect_6y0v78$=function(t,e,n,i){this.myContext2d_0.strokeRect(t,e,n,i)},Pe.prototype.strokeText_ai6r6m$=function(t,e,n){this.myContext2d_0.strokeText(t,e,n)},Pe.prototype.fillText_ai6r6m$=function(t,e,n){this.myContext2d_0.fillText(t,e,n)},Pe.prototype.scale_lu1900$=function(t,e){this.myContext2d_0.scale(t,e)},Pe.prototype.rotate_14dthe$=function(t){this.myContext2d_0.rotate(t)},Pe.prototype.translate_lu1900$=function(t,e){this.myContext2d_0.translate(t,e)},Pe.prototype.transform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.transform(t,e,n,i,r,o)},Pe.prototype.bezierCurveTo_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.bezierCurveTo(t,e,n,i,r,o)},Pe.prototype.setLineJoin_v2gigt$=function(t){this.myContext2d_0.lineJoin=this.convertLineJoin_0(t)},Pe.prototype.setLineCap_useuqn$=function(t){this.myContext2d_0.lineCap=this.convertLineCap_0(t)},Pe.prototype.setTextBaseline_5cz80h$=function(t){this.myContext2d_0.textBaseline=this.convertTextBaseline_0(t)},Pe.prototype.setTextAlign_iwro1z$=function(t){this.myContext2d_0.textAlign=this.convertTextAlign_0(t)},Pe.prototype.setTransform_15yvbs$=function(t,e,n,i,r,o){this.myContext2d_0.setTransform(t,e,n,i,r,o)},Pe.prototype.setLineDash_gf7tl1$=function(t){this.myContext2d_0.setLineDash(H(t))},Pe.prototype.measureText_61zpoe$=function(t){return this.myContext2d_0.measureText(t).width},Pe.prototype.clearRect_wthzt5$=function(t){this.myContext2d_0.clearRect(t.left,t.top,t.width,t.height)},Pe.$metadata$={kind:a,simpleName:"DomContext2d",interfaces:[kt]},Y.AnimationTimer=V,Object.defineProperty(K,"Companion",{get:J}),Y.AnimationEventHandler=K;var Ae=t.jetbrains||(t.jetbrains={}),je=Ae.datalore||(Ae.datalore={}),Le=je.vis||(je.vis={}),Re=Le.canvas||(Le.canvas={});Re.AnimationProvider=Y,Q.Snapshot=tt,Re.Canvas=Q,Re.CanvasControl=et,Object.defineProperty(Re,"CanvasControlUtil",{get:function(){return null===wt&&new nt,wt}}),Re.CanvasProvider=xt,Object.defineProperty(Et,"BEVEL",{get:St}),Object.defineProperty(Et,"MITER",{get:Tt}),Object.defineProperty(Et,"ROUND",{get:Ot}),kt.LineJoin=Et,Object.defineProperty(Nt,"BUTT",{get:At}),Object.defineProperty(Nt,"ROUND",{get:jt}),Object.defineProperty(Nt,"SQUARE",{get:Lt}),kt.LineCap=Nt,Object.defineProperty(Rt,"ALPHABETIC",{get:zt}),Object.defineProperty(Rt,"BOTTOM",{get:Dt}),Object.defineProperty(Rt,"MIDDLE",{get:Mt}),Object.defineProperty(Rt,"TOP",{get:Bt}),kt.TextBaseline=Rt,Object.defineProperty(Ut,"CENTER",{get:qt}),Object.defineProperty(Ut,"END",{get:Gt}),Object.defineProperty(Ut,"START",{get:Ht}),kt.TextAlign=Ut,Object.defineProperty(Vt,"NORMAL",{get:Wt}),Object.defineProperty(Vt,"ITALIC",{get:Xt}),Yt.FontStyle=Vt,Object.defineProperty(Zt,"NORMAL",{get:Qt}),Object.defineProperty(Zt,"BOLD",{get:te}),Yt.FontWeight=Zt,Object.defineProperty(Yt,"Companion",{get:ie}),kt.Font_init_1nsek9$=function(t,e,n,i,r){return r=r||Object.create(Yt.prototype),Yt.call(r,null!=t?t:Wt(),null!=e?e:Qt(),null!=n?n:ie().DEFAULT_SIZE,null!=i?i:ie().DEFAULT_FAMILY),r},kt.Font=Yt,Re.Context2d=kt,Object.defineProperty(re,"Companion",{get:se}),Re.CssFontParser=re,Object.defineProperty(Re,"CssStyleUtil",{get:function(){return null===ue&&new le,ue}}),Re.DeltaTime=ce,Re.Dispatcher=pe,Re.scheduleAsync_ebnxch$=function(t,e){var n=new b;return e.onResult_m8e4a6$(he(n,t),_e(n,t)),n},Re.EventPeer=fe,Re.ScaledCanvas=ye,Re.ScaledContext2d=$e,Re.SingleCanvasControl=ve,(Le.canvasFigure||(Le.canvasFigure={})).CanvasFigure=ge;var Ie=Re.dom||(Re.dom={});return Ie.DomAnimationTimer=be,we.DomSnapshot=xe,Object.defineProperty(we,"Companion",{get:Ce}),Ie.DomCanvas=we,Se.DomEventPeer=Ne,Ie.DomCanvasControl=Se,Ie.DomContext2d=Pe,$e.prototype.arc_6p3vsx$=kt.prototype.arc_6p3vsx$,Pe.prototype.arc_6p3vsx$=kt.prototype.arc_6p3vsx$,t})?i.apply(e,r):i)||(t.exports=o)},179:function(t,e,n){var i,r,o;r=[e,n(421),n(331),n(799),n(767),n(602)],void 0===(o="function"==typeof(i=function(t,e,n,i,r,o){"use strict";var a=e.kotlin.collections.ArrayList_init_287e2$,s=n.jetbrains.datalore.vis.svg.slim.SvgSlimNode,l=e.toString,u=e.ensureNotNull,c=n.jetbrains.datalore.vis.svg.SvgElement,p=n.jetbrains.datalore.vis.svg.SvgTextNode,h=e.kotlin.IllegalStateException_init_pdl1vj$,_=n.jetbrains.datalore.vis.svg.slim,f=e.equals,d=e.Kind.CLASS,m=i.jetbrains.datalore.mapper.core.Synchronizer,y=e.kotlin.IllegalArgumentException_init_pdl1vj$,$=e.Kind.INTERFACE,v=(n.jetbrains.datalore.vis.svg.SvgNodeContainer,e.Kind.OBJECT),g=e.throwCCE,b=r.jetbrains.datalore.base.registration.CompositeRegistration,w=o.jetbrains.datalore.base.js.dom.DomEventType,x=o.jetbrains.datalore.base.event.dom,k=r.jetbrains.datalore.base.event.MouseEvent,E=r.jetbrains.datalore.base.registration.Registration,C=n.jetbrains.datalore.vis.svg.SvgImageElementEx.RGBEncoder,S=n.jetbrains.datalore.vis.svg.SvgNode,T=r.jetbrains.datalore.base.geometry.DoubleVector,O=r.jetbrains.datalore.base.geometry.DoubleRectangle_init_6y0v78$,N=e.kotlin.collections.HashMap_init_q3lmfv$,P=n.jetbrains.datalore.vis.svg.SvgPlatformPeer,A=n.jetbrains.datalore.vis.svg.SvgElementListener,j=i.jetbrains.datalore.mapper.core,L=n.jetbrains.datalore.vis.svg.event.SvgEventSpec.values,R=e.kotlin.IllegalStateException_init,I=r.jetbrains.datalore.base.function.Function,z=r.jetbrains.datalore.base.observable.property.WritableProperty,D=e.numberToInt,M=e.kotlin.collections.LinkedHashMap_init_q3lmfv$,B=i.jetbrains.datalore.mapper.core.Mapper,U=n.jetbrains.datalore.vis.svg.SvgImageElementEx,F=n.jetbrains.datalore.vis.svg.SvgImageElement,q=i.jetbrains.datalore.mapper.core.MapperFactory,G=n.jetbrains.datalore.vis.svg,H=(e.defineInlineFunction,e.kotlin.Unit),Y=e.kotlin.collections.AbstractMutableList,V=r.jetbrains.datalore.base.function.Value,K=r.jetbrains.datalore.base.observable.property.PropertyChangeEvent,W=r.jetbrains.datalore.base.observable.event.ListenerCaller,X=r.jetbrains.datalore.base.observable.event.Listeners,Z=r.jetbrains.datalore.base.observable.property.Property,J=e.kotlinx.dom.addClass_hhb33f$,Q=e.kotlinx.dom.removeClass_hhb33f$,tt=r.jetbrains.datalore.base.geometry.Vector,et=r.jetbrains.datalore.base.function.Supplier,nt=o.jetbrains.datalore.base.observable.property.UpdatableProperty,it=n.jetbrains.datalore.vis.svg.SvgEllipseElement,rt=n.jetbrains.datalore.vis.svg.SvgCircleElement,ot=n.jetbrains.datalore.vis.svg.SvgRectElement,at=n.jetbrains.datalore.vis.svg.SvgTextElement,st=n.jetbrains.datalore.vis.svg.SvgPathElement,lt=n.jetbrains.datalore.vis.svg.SvgLineElement,ut=n.jetbrains.datalore.vis.svg.SvgSvgElement,ct=n.jetbrains.datalore.vis.svg.SvgGElement,pt=n.jetbrains.datalore.vis.svg.SvgStyleElement,ht=n.jetbrains.datalore.vis.svg.SvgTSpanElement,_t=n.jetbrains.datalore.vis.svg.SvgDefsElement,ft=n.jetbrains.datalore.vis.svg.SvgClipPathElement;function dt(t,e,n){this.source_0=t,this.target_0=e,this.targetPeer_0=n,this.myHandlersRegs_0=null}function mt(){}function yt(){}function $t(t,e){this.closure$source=t,this.closure$spec=e}function vt(t,e,n){this.closure$target=t,this.closure$eventType=e,this.closure$listener=n,E.call(this)}function gt(){}function bt(){this.myMappingMap_0=N()}function wt(t,e,n){St.call(this,t,e,n),this.myPeer_0=n,this.myHandlersRegs_0=null}function xt(t){this.this$SvgElementMapper=t,this.myReg_0=null}function kt(t){this.this$SvgElementMapper=t}function Et(t){this.this$SvgElementMapper=t}function Ct(t,e){this.this$SvgElementMapper=t,this.closure$spec=e}function St(t,e,n){B.call(this,t,e),this.peer_cyou3s$_0=n}function Tt(t){this.myPeer_0=t}function Ot(t){At(),B.call(this,t,At().createDocument_0()),this.myRootMapper_0=null}function Nt(){Pt=this}vt.prototype=Object.create(E.prototype),vt.prototype.constructor=vt,St.prototype=Object.create(B.prototype),St.prototype.constructor=St,wt.prototype=Object.create(St.prototype),wt.prototype.constructor=wt,Ot.prototype=Object.create(B.prototype),Ot.prototype.constructor=Ot,jt.prototype=Object.create(St.prototype),jt.prototype.constructor=jt,Ft.prototype=Object.create(E.prototype),Ft.prototype.constructor=Ft,Qt.prototype=Object.create(Y.prototype),Qt.prototype.constructor=Qt,te.prototype=Object.create(Y.prototype),te.prototype.constructor=te,re.prototype=Object.create(E.prototype),re.prototype.constructor=re,oe.prototype=Object.create(E.prototype),oe.prototype.constructor=oe,pe.prototype=Object.create(nt.prototype),pe.prototype.constructor=pe,dt.prototype.attach_1rog5x$=function(t){if(this.myHandlersRegs_0=a(),e.isType(this.source_0,s)){var n="Slim SVG node is not expected: "+l(e.getKClassFromExpression(this.source_0).simpleName);throw y(n.toString())}this.targetPeer_0.appendChild_xwzc9q$(this.target_0,this.generateNode_0(this.source_0))},dt.prototype.detach=function(){var t;for(t=u(this.myHandlersRegs_0).iterator();t.hasNext();)t.next().remove();this.myHandlersRegs_0=null,this.targetPeer_0.removeAllChildren_11rb$(this.target_0)},dt.prototype.generateNode_0=function(t){if(e.isType(t,s))return this.generateSlimNode_0(t);if(e.isType(t,c))return this.generateElement_0(t);if(e.isType(t,p))return this.generateTextNode_0(t);throw h("Can't generate dom for svg node "+e.getKClassFromExpression(t).simpleName)},dt.prototype.generateElement_0=function(t){var e,n,i=this.targetPeer_0.newSvgElement_b1cgbq$(t);for(e=t.attributeKeys.iterator();e.hasNext();){var r=e.next();this.targetPeer_0.setAttribute_ohl585$(i,r.name,l(t.getAttribute_61zpoe$(r.name).get()))}var o=t.handlersSet().get();for(o.isEmpty()||this.targetPeer_0.hookEventHandlers_ewuthb$(t,i,o),n=t.children().iterator();n.hasNext();){var a=n.next();this.targetPeer_0.appendChild_xwzc9q$(i,this.generateNode_0(a))}return i},dt.prototype.generateTextNode_0=function(t){return this.targetPeer_0.newSvgTextNode_tginx7$(t)},dt.prototype.generateSlimNode_0=function(t){var e,n,i=this.targetPeer_0.newSvgSlimNode_qwqme8$(t);if(f(t.elementName,_.SvgSlimElements.GROUP))for(e=t.slimChildren.iterator();e.hasNext();){var r=e.next();this.targetPeer_0.appendChild_xwzc9q$(i,this.generateSlimNode_0(r))}for(n=t.attributes.iterator();n.hasNext();){var o=n.next();this.targetPeer_0.setAttribute_ohl585$(i,o.key,o.value)}return i},dt.$metadata$={kind:d,simpleName:"SvgNodeSubtreeGeneratingSynchronizer",interfaces:[m]},mt.$metadata$={kind:$,simpleName:"TargetPeer",interfaces:[]},yt.prototype.appendChild_xwzc9q$=function(t,e){t.appendChild(e)},yt.prototype.removeAllChildren_11rb$=function(t){if(t.hasChildNodes())for(var e=t.firstChild;null!=e;){var n=e.nextSibling;t.removeChild(e),e=n}},yt.prototype.newSvgElement_b1cgbq$=function(t){return _e().generateElement_b1cgbq$(t)},yt.prototype.newSvgTextNode_tginx7$=function(t){var e=document.createTextNode("");return e.nodeValue=t.textContent().get(),e},yt.prototype.newSvgSlimNode_qwqme8$=function(t){return _e().generateSlimNode_qwqme8$(t)},yt.prototype.setAttribute_ohl585$=function(t,n,i){var r;(e.isType(r=t,Element)?r:g()).setAttribute(n,i)},yt.prototype.hookEventHandlers_ewuthb$=function(t,n,i){var r,o,a,s=new b([]);for(r=i.iterator();r.hasNext();){var l=r.next();switch(l.name){case"MOUSE_CLICKED":o=w.Companion.CLICK;break;case"MOUSE_PRESSED":o=w.Companion.MOUSE_DOWN;break;case"MOUSE_RELEASED":o=w.Companion.MOUSE_UP;break;case"MOUSE_OVER":o=w.Companion.MOUSE_OVER;break;case"MOUSE_MOVE":o=w.Companion.MOUSE_MOVE;break;case"MOUSE_OUT":o=w.Companion.MOUSE_OUT;break;default:throw y("unexpected event spec "+l)}var u=o;s.add_3xv6fb$(this.addMouseHandler_0(t,e.isType(a=n,EventTarget)?a:g(),l,u.name))}return s},$t.prototype.handleEvent=function(t){var n;t.stopPropagation();var i=e.isType(n=t,MouseEvent)?n:g(),r=new k(i.clientX,i.clientY,x.DomEventUtil.getButton_tfvzir$(i),x.DomEventUtil.getModifiers_tfvzir$(i));this.closure$source.dispatch_lgzia2$(this.closure$spec,r)},$t.$metadata$={kind:d,interfaces:[]},vt.prototype.doRemove=function(){this.closure$target.removeEventListener(this.closure$eventType,this.closure$listener,!1)},vt.$metadata$={kind:d,interfaces:[E]},yt.prototype.addMouseHandler_0=function(t,e,n,i){var r=new $t(t,n);return e.addEventListener(i,r,!1),new vt(e,i,r)},yt.$metadata$={kind:d,simpleName:"DomTargetPeer",interfaces:[mt]},gt.prototype.toDataUrl_nps3vt$=function(t,n,i){var r,o,a=null==(r=document.createElement("canvas"))||e.isType(r,HTMLCanvasElement)?r:g();if(null==a)throw h("Canvas is not supported.");a.width=t,a.height=n;for(var s=e.isType(o=a.getContext("2d"),CanvasRenderingContext2D)?o:g(),l=s.createImageData(t,n),u=l.data,c=0;c>24&255,t,e),Vt(i,r,n>>16&255,t,e),Yt(i,r,n>>8&255,t,e),Ht(i,r,255&n,t,e)},gt.$metadata$={kind:d,simpleName:"RGBEncoderDom",interfaces:[C]},bt.prototype.ensureSourceRegistered_0=function(t){if(!this.myMappingMap_0.containsKey_11rb$(t))throw h("Trying to call platform peer method of unmapped node")},bt.prototype.registerMapper_dxg7rd$=function(t,e){this.myMappingMap_0.put_xwzc9p$(t,e)},bt.prototype.unregisterMapper_26jijc$=function(t){this.myMappingMap_0.remove_11rb$(t)},bt.prototype.getComputedTextLength_u60gfq$=function(t){var n,i;this.ensureSourceRegistered_0(e.isType(n=t,S)?n:g());var r=u(this.myMappingMap_0.get_11rb$(t)).target;return(e.isType(i=r,SVGTextContentElement)?i:g()).getComputedTextLength()},bt.prototype.transformCoordinates_1=function(t,n,i){var r,o;this.ensureSourceRegistered_0(e.isType(r=t,S)?r:g());var a=u(this.myMappingMap_0.get_11rb$(t)).target;return this.transformCoordinates_0(e.isType(o=a,SVGElement)?o:g(),n.x,n.y,i)},bt.prototype.transformCoordinates_0=function(t,n,i,r){var o,a=(e.isType(o=t,SVGGraphicsElement)?o:g()).getCTM();r&&(a=u(a).inverse());var s=u(t.ownerSVGElement).createSVGPoint();s.x=n,s.y=i;var l=s.matrixTransform(u(a));return new T(l.x,l.y)},bt.prototype.inverseScreenTransform_ljxa03$=function(t,n){var i,r=t.ownerSvgElement;this.ensureSourceRegistered_0(u(r));var o=u(this.myMappingMap_0.get_11rb$(r)).target;return this.inverseScreenTransform_0(e.isType(i=o,SVGSVGElement)?i:g(),n.x,n.y)},bt.prototype.inverseScreenTransform_0=function(t,e,n){var i=u(t.getScreenCTM()).inverse(),r=t.createSVGPoint();return r.x=e,r.y=n,r=r.matrixTransform(i),new T(r.x,r.y)},bt.prototype.invertTransform_12yub8$=function(t,e){return this.transformCoordinates_1(t,e,!0)},bt.prototype.applyTransform_12yub8$=function(t,e){return this.transformCoordinates_1(t,e,!1)},bt.prototype.getBBox_7snaev$=function(t){var n;this.ensureSourceRegistered_0(e.isType(n=t,S)?n:g());var i=u(this.myMappingMap_0.get_11rb$(t)).target;return this.getBoundingBox_0(i)},bt.prototype.getBoundingBox_0=function(t){var n,i=(e.isType(n=t,SVGGraphicsElement)?n:g()).getBBox();return O(i.x,i.y,i.width,i.height)},bt.$metadata$={kind:d,simpleName:"SvgDomPeer",interfaces:[P]},kt.prototype.onAttrSet_ud3ldc$=function(t){null==t.newValue&&this.this$SvgElementMapper.target.removeAttribute(t.attrSpec.name),this.this$SvgElementMapper.target.setAttribute(t.attrSpec.name,l(t.newValue))},kt.$metadata$={kind:d,interfaces:[A]},xt.prototype.attach_1rog5x$=function(t){var e;for(this.myReg_0=this.this$SvgElementMapper.source.addListener_e4m8w6$(new kt(this.this$SvgElementMapper)),e=this.this$SvgElementMapper.source.attributeKeys.iterator();e.hasNext();){var n=e.next(),i=n.name,r=l(this.this$SvgElementMapper.source.getAttribute_61zpoe$(i).get());n.hasNamespace()?this.this$SvgElementMapper.target.setAttributeNS(n.namespaceUri,i,r):this.this$SvgElementMapper.target.setAttribute(i,r)}},xt.prototype.detach=function(){u(this.myReg_0).remove()},xt.$metadata$={kind:d,interfaces:[m]},Ct.prototype.apply_11rb$=function(t){if(e.isType(t,MouseEvent)){var n=this.this$SvgElementMapper.createMouseEvent_0(t);return this.this$SvgElementMapper.source.dispatch_lgzia2$(this.closure$spec,n),!0}return!1},Ct.$metadata$={kind:d,interfaces:[I]},Et.prototype.set_11rb$=function(t){var e,n,i;for(null==this.this$SvgElementMapper.myHandlersRegs_0&&(this.this$SvgElementMapper.myHandlersRegs_0=M()),e=L(),n=0;n!==e.length;++n){var r=e[n];if(!u(t).contains_11rb$(r)&&u(this.this$SvgElementMapper.myHandlersRegs_0).containsKey_11rb$(r)&&u(u(this.this$SvgElementMapper.myHandlersRegs_0).remove_11rb$(r)).dispose(),t.contains_11rb$(r)&&!u(this.this$SvgElementMapper.myHandlersRegs_0).containsKey_11rb$(r)){switch(r.name){case"MOUSE_CLICKED":i=w.Companion.CLICK;break;case"MOUSE_PRESSED":i=w.Companion.MOUSE_DOWN;break;case"MOUSE_RELEASED":i=w.Companion.MOUSE_UP;break;case"MOUSE_OVER":i=w.Companion.MOUSE_OVER;break;case"MOUSE_MOVE":i=w.Companion.MOUSE_MOVE;break;case"MOUSE_OUT":i=w.Companion.MOUSE_OUT;break;default:throw R()}var o=i,a=u(this.this$SvgElementMapper.myHandlersRegs_0),s=Ut(this.this$SvgElementMapper.target,o,new Ct(this.this$SvgElementMapper,r));a.put_xwzc9p$(r,s)}}},Et.$metadata$={kind:d,interfaces:[z]},wt.prototype.registerSynchronizers_jp3a7u$=function(t){St.prototype.registerSynchronizers_jp3a7u$.call(this,t),t.add_te27wm$(new xt(this)),t.add_te27wm$(j.Synchronizers.forPropsOneWay_2ov6i0$(this.source.handlersSet(),new Et(this)))},wt.prototype.onDetach=function(){var t;if(St.prototype.onDetach.call(this),null!=this.myHandlersRegs_0){for(t=u(this.myHandlersRegs_0).values.iterator();t.hasNext();)t.next().dispose();u(this.myHandlersRegs_0).clear()}},wt.prototype.createMouseEvent_0=function(t){t.stopPropagation();var e=this.myPeer_0.inverseScreenTransform_ljxa03$(this.source,new T(t.clientX,t.clientY));return new k(D(e.x),D(e.y),x.DomEventUtil.getButton_tfvzir$(t),x.DomEventUtil.getModifiers_tfvzir$(t))},wt.$metadata$={kind:d,simpleName:"SvgElementMapper",interfaces:[St]},St.prototype.registerSynchronizers_jp3a7u$=function(t){B.prototype.registerSynchronizers_jp3a7u$.call(this,t),this.source.isPrebuiltSubtree?t.add_te27wm$(new dt(this.source,this.target,new yt)):t.add_te27wm$(j.Synchronizers.forObservableRole_umd8ru$(this,this.source.children(),_e().nodeChildren_b3w3xb$(this.target),new Tt(this.peer_cyou3s$_0)))},St.prototype.onAttach_8uof53$=function(t){B.prototype.onAttach_8uof53$.call(this,t),this.peer_cyou3s$_0.registerMapper_dxg7rd$(this.source,this)},St.prototype.onDetach=function(){B.prototype.onDetach.call(this),this.peer_cyou3s$_0.unregisterMapper_26jijc$(this.source)},St.$metadata$={kind:d,simpleName:"SvgNodeMapper",interfaces:[B]},Tt.prototype.createMapper_11rb$=function(t){if(e.isType(t,F)){var n=t;return e.isType(n,U)&&(n=n.asImageElement_xhdger$(new gt)),new wt(n,_e().generateElement_b1cgbq$(t),this.myPeer_0)}if(e.isType(t,c))return new wt(t,_e().generateElement_b1cgbq$(t),this.myPeer_0);if(e.isType(t,p))return new jt(t,_e().generateTextElement_tginx7$(t),this.myPeer_0);if(e.isType(t,s))return new St(t,_e().generateSlimNode_qwqme8$(t),this.myPeer_0);throw h("Unsupported SvgNode "+e.getKClassFromExpression(t))},Tt.$metadata$={kind:d,simpleName:"SvgNodeMapperFactory",interfaces:[q]},Nt.prototype.createDocument_0=function(){var t;return e.isType(t=document.createElementNS(G.XmlNamespace.SVG_NAMESPACE_URI,"svg"),SVGSVGElement)?t:g()},Nt.$metadata$={kind:v,simpleName:"Companion",interfaces:[]};var Pt=null;function At(){return null===Pt&&new Nt,Pt}function jt(t,e,n){St.call(this,t,e,n)}function Lt(t){this.this$SvgTextNodeMapper=t}function Rt(){It=this,this.DEFAULT="default",this.NONE="none",this.BLOCK="block",this.FLEX="flex",this.GRID="grid",this.INLINE_BLOCK="inline-block"}Ot.prototype.onAttach_8uof53$=function(t){if(B.prototype.onAttach_8uof53$.call(this,t),!this.source.isAttached())throw h("Element must be attached");var e=new bt;this.source.container().setPeer_kqs5uc$(e),this.myRootMapper_0=new wt(this.source,this.target,e),this.target.setAttribute("shape-rendering","geometricPrecision"),u(this.myRootMapper_0).attachRoot_8uof53$()},Ot.prototype.onDetach=function(){u(this.myRootMapper_0).detachRoot(),this.myRootMapper_0=null,this.source.isAttached()&&this.source.container().setPeer_kqs5uc$(null),B.prototype.onDetach.call(this)},Ot.$metadata$={kind:d,simpleName:"SvgRootDocumentMapper",interfaces:[B]},Lt.prototype.set_11rb$=function(t){this.this$SvgTextNodeMapper.target.nodeValue=t},Lt.$metadata$={kind:d,interfaces:[z]},jt.prototype.registerSynchronizers_jp3a7u$=function(t){St.prototype.registerSynchronizers_jp3a7u$.call(this,t),t.add_te27wm$(j.Synchronizers.forPropsOneWay_2ov6i0$(this.source.textContent(),new Lt(this)))},jt.$metadata$={kind:d,simpleName:"SvgTextNodeMapper",interfaces:[St]},Rt.$metadata$={kind:v,simpleName:"CssDisplay",interfaces:[]};var It=null;function zt(){return null===It&&new Rt,It}function Dt(t,e){return t.removeProperty(e),t}function Mt(t){return Dt(t,"display")}function Bt(t){this.closure$handler=t}function Ut(t,e,n){return qt(t,e,new Bt(n),!1)}function Ft(t,e,n){this.closure$type=t,this.closure$listener=e,this.this$onEvent=n,E.call(this)}function qt(t,e,n,i){return t.addEventListener(e.name,n,i),new Ft(e,n,t)}function Gt(t,e,n,i,r){Kt(t,e,n,i,r,3)}function Ht(t,e,n,i,r){Kt(t,e,n,i,r,2)}function Yt(t,e,n,i,r){Kt(t,e,n,i,r,1)}function Vt(t,e,n,i,r){Kt(t,e,n,i,r,0)}function Kt(t,n,i,r,o,a){n[(4*(r+e.imul(o,t.width)|0)|0)+a|0]=i}function Wt(t){return t.childNodes.length}function Xt(t,e){return t.insertBefore(e,t.firstChild)}function Zt(t,e,n){var i=null!=n?n.nextSibling:null;null==i?t.appendChild(e):t.insertBefore(e,i)}function Jt(){he=this}function Qt(t){this.closure$n=t,Y.call(this)}function te(t,e){this.closure$items=t,this.closure$base=e,Y.call(this)}function ee(t){this.closure$e=t}function ne(t){this.closure$element=t,this.myTimerRegistration_0=null,this.myListeners_0=new X}function ie(t,e){this.closure$value=t,this.closure$currentValue=e}function re(t){this.closure$timer=t,E.call(this)}function oe(t,e){this.closure$reg=t,this.this$=e,E.call(this)}function ae(t,e){this.closure$el=t,this.closure$cls=e,this.myValue_0=null}function se(t,e){this.closure$el=t,this.closure$attr=e}function le(t,e,n){this.closure$el=t,this.closure$attr=e,this.closure$attrValue=n}function ue(t){this.closure$el=t}function ce(t){this.closure$el=t}function pe(t,e){this.closure$period=t,this.closure$supplier=e,nt.call(this),this.myTimer_0=-1}Bt.prototype.handleEvent=function(t){this.closure$handler.apply_11rb$(t)||(t.preventDefault(),t.stopPropagation())},Bt.$metadata$={kind:d,interfaces:[]},Ft.prototype.doRemove=function(){this.this$onEvent.removeEventListener(this.closure$type.name,this.closure$listener)},Ft.$metadata$={kind:d,interfaces:[E]},Jt.prototype.elementChildren_2rdptt$=function(t){return this.nodeChildren_b3w3xb$(t)},Object.defineProperty(Qt.prototype,"size",{configurable:!0,get:function(){return Wt(this.closure$n)}}),Qt.prototype.get_za3lpa$=function(t){return this.closure$n.childNodes[t]},Qt.prototype.set_wxm5ur$=function(t,e){if(null!=u(e).parentNode)throw R();var n=u(this.get_za3lpa$(t));return this.closure$n.replaceChild(n,e),n},Qt.prototype.add_wxm5ur$=function(t,e){if(null!=u(e).parentNode)throw R();if(0===t)Xt(this.closure$n,e);else{var n=t-1|0,i=this.closure$n.childNodes[n];Zt(this.closure$n,e,i)}},Qt.prototype.removeAt_za3lpa$=function(t){var e=u(this.closure$n.childNodes[t]);return this.closure$n.removeChild(e),e},Qt.$metadata$={kind:d,interfaces:[Y]},Jt.prototype.nodeChildren_b3w3xb$=function(t){return new Qt(t)},Object.defineProperty(te.prototype,"size",{configurable:!0,get:function(){return this.closure$items.size}}),te.prototype.get_za3lpa$=function(t){return this.closure$items.get_za3lpa$(t)},te.prototype.set_wxm5ur$=function(t,e){var n=this.closure$items.set_wxm5ur$(t,e);return this.closure$base.set_wxm5ur$(t,u(n).getElement()),n},te.prototype.add_wxm5ur$=function(t,e){this.closure$items.add_wxm5ur$(t,e),this.closure$base.add_wxm5ur$(t,u(e).getElement())},te.prototype.removeAt_za3lpa$=function(t){var e=this.closure$items.removeAt_za3lpa$(t);return this.closure$base.removeAt_za3lpa$(t),e},te.$metadata$={kind:d,interfaces:[Y]},Jt.prototype.withElementChildren_9w66cp$=function(t){return new te(a(),t)},ee.prototype.set_11rb$=function(t){this.closure$e.innerHTML=t},ee.$metadata$={kind:d,interfaces:[z]},Jt.prototype.innerTextOf_2rdptt$=function(t){return new ee(t)},Object.defineProperty(ne.prototype,"propExpr",{configurable:!0,get:function(){return"checkbox("+this.closure$element+")"}}),ne.prototype.get=function(){return this.closure$element.checked},ne.prototype.set_11rb$=function(t){this.closure$element.checked=t},ie.prototype.call_11rb$=function(t){t.onEvent_11rb$(new K(this.closure$value.get(),this.closure$currentValue))},ie.$metadata$={kind:d,interfaces:[W]},re.prototype.doRemove=function(){window.clearInterval(this.closure$timer)},re.$metadata$={kind:d,interfaces:[E]},oe.prototype.doRemove=function(){this.closure$reg.remove(),this.this$.myListeners_0.isEmpty&&(u(this.this$.myTimerRegistration_0).remove(),this.this$.myTimerRegistration_0=null)},oe.$metadata$={kind:d,interfaces:[E]},ne.prototype.addHandler_gxwwpc$=function(t){if(this.myListeners_0.isEmpty){var e=new V(this.closure$element.checked),n=window.setInterval((i=this.closure$element,r=e,o=this,function(){var t=i.checked;return t!==r.get()&&(o.myListeners_0.fire_kucmxw$(new ie(r,t)),r.set_11rb$(t)),H}));this.myTimerRegistration_0=new re(n)}var i,r,o;return new oe(this.myListeners_0.add_11rb$(t),this)},ne.$metadata$={kind:d,interfaces:[Z]},Jt.prototype.checkbox_36rv4q$=function(t){return new ne(t)},ae.prototype.set_11rb$=function(t){this.myValue_0!==t&&(t?J(this.closure$el,[this.closure$cls]):Q(this.closure$el,[this.closure$cls]),this.myValue_0=t)},ae.$metadata$={kind:d,interfaces:[z]},Jt.prototype.hasClass_t9mn69$=function(t,e){return new ae(t,e)},se.prototype.set_11rb$=function(t){this.closure$el.setAttribute(this.closure$attr,t)},se.$metadata$={kind:d,interfaces:[z]},Jt.prototype.attribute_t9mn69$=function(t,e){return new se(t,e)},le.prototype.set_11rb$=function(t){t?this.closure$el.setAttribute(this.closure$attr,this.closure$attrValue):this.closure$el.removeAttribute(this.closure$attr)},le.$metadata$={kind:d,interfaces:[z]},Jt.prototype.hasAttribute_1x5wil$=function(t,e,n){return new le(t,e,n)},ue.prototype.set_11rb$=function(t){t?Mt(this.closure$el.style):this.closure$el.style.display=zt().NONE},ue.$metadata$={kind:d,interfaces:[z]},Jt.prototype.visibilityOf_lt8gi4$=function(t){return new ue(t)},ce.prototype.get=function(){return new tt(this.closure$el.clientWidth,this.closure$el.clientHeight)},ce.$metadata$={kind:d,interfaces:[et]},Jt.prototype.dimension_2rdptt$=function(t){return this.timerBasedProperty_ndenup$(new ce(t),200)},pe.prototype.doAddListeners=function(){var t;this.myTimer_0=window.setInterval((t=this,function(){return t.update(),H}),this.closure$period)},pe.prototype.doRemoveListeners=function(){window.clearInterval(this.myTimer_0)},pe.prototype.doGet=function(){return this.closure$supplier.get()},pe.$metadata$={kind:d,interfaces:[nt]},Jt.prototype.timerBasedProperty_ndenup$=function(t,e){return new pe(e,t)},Jt.prototype.generateElement_b1cgbq$=function(t){if(e.isType(t,it))return this.createSVGElement_0("ellipse");if(e.isType(t,rt))return this.createSVGElement_0("circle");if(e.isType(t,ot))return this.createSVGElement_0("rect");if(e.isType(t,at))return this.createSVGElement_0("text");if(e.isType(t,st))return this.createSVGElement_0("path");if(e.isType(t,lt))return this.createSVGElement_0("line");if(e.isType(t,ut))return this.createSVGElement_0("svg");if(e.isType(t,ct))return this.createSVGElement_0("g");if(e.isType(t,pt))return this.createSVGElement_0("style");if(e.isType(t,ht))return this.createSVGElement_0("tspan");if(e.isType(t,_t))return this.createSVGElement_0("defs");if(e.isType(t,ft))return this.createSVGElement_0("clipPath");if(e.isType(t,F))return this.createSVGElement_0("image");throw h("Unsupported svg element "+l(e.getKClassFromExpression(t).simpleName))},Jt.prototype.generateSlimNode_qwqme8$=function(t){switch(t.elementName){case"g":return this.createSVGElement_0("g");case"line":return this.createSVGElement_0("line");case"circle":return this.createSVGElement_0("circle");case"rect":return this.createSVGElement_0("rect");case"path":return this.createSVGElement_0("path");default:throw h("Unsupported SvgSlimNode "+e.getKClassFromExpression(t))}},Jt.prototype.generateTextElement_tginx7$=function(t){return document.createTextNode("")},Jt.prototype.createSVGElement_0=function(t){var n;return e.isType(n=document.createElementNS(G.XmlNamespace.SVG_NAMESPACE_URI,t),SVGElement)?n:g()},Jt.$metadata$={kind:v,simpleName:"DomUtil",interfaces:[]};var he=null;function _e(){return null===he&&new Jt,he}var fe=t.jetbrains||(t.jetbrains={}),de=fe.datalore||(fe.datalore={}),me=de.vis||(de.vis={}),ye=me.svgMapper||(me.svgMapper={});ye.SvgNodeSubtreeGeneratingSynchronizer=dt,ye.TargetPeer=mt;var $e=ye.dom||(ye.dom={});$e.DomTargetPeer=yt,$e.RGBEncoderDom=gt,$e.SvgDomPeer=bt,$e.SvgElementMapper=wt,$e.SvgNodeMapper=St,$e.SvgNodeMapperFactory=Tt,Object.defineProperty(Ot,"Companion",{get:At}),$e.SvgRootDocumentMapper=Ot,$e.SvgTextNodeMapper=jt;var ve=$e.css||($e.css={});Object.defineProperty(ve,"CssDisplay",{get:zt});var ge=$e.domExtensions||($e.domExtensions={});ge.clearProperty_77nir7$=Dt,ge.clearDisplay_b8w5wr$=Mt,ge.on_wkfwsw$=Ut,ge.onEvent_jxnl6r$=qt,ge.setAlphaAt_h5k0c3$=Gt,ge.setBlueAt_h5k0c3$=Ht,ge.setGreenAt_h5k0c3$=Yt,ge.setRedAt_h5k0c3$=Vt,ge.setColorAt_z0tnfj$=Kt,ge.get_childCount_asww5s$=Wt,ge.insertFirst_fga9sf$=Xt,ge.insertAfter_5a54o3$=Zt;var be=$e.domUtil||($e.domUtil={});return Object.defineProperty(be,"DomUtil",{get:_e}),t})?i.apply(e,r):i)||(t.exports=o)},331:function(t,e,n){var i,r,o;r=[e,n(421),n(767)],void 0===(o="function"==typeof(i=function(t,e,n){"use strict";var i=e.Kind.OBJECT,r=e.hashCode,o=e.throwCCE,a=e.equals,s=e.Kind.CLASS,l=e.ensureNotNull,u=e.kotlin.Enum,c=e.throwISE,p=e.Kind.INTERFACE,h=e.kotlin.collections.HashMap_init_q3lmfv$,_=e.kotlin.IllegalArgumentException_init,f=Object,d=n.jetbrains.datalore.base.observable.property.PropertyChangeEvent,m=n.jetbrains.datalore.base.observable.property.Property,y=n.jetbrains.datalore.base.observable.event.ListenerCaller,$=n.jetbrains.datalore.base.observable.event.Listeners,v=n.jetbrains.datalore.base.registration.Registration,g=n.jetbrains.datalore.base.listMap.ListMap,b=e.kotlin.collections.emptySet_287e2$,w=e.kotlin.text.StringBuilder_init,x=n.jetbrains.datalore.base.observable.property.ReadableProperty,k=(e.kotlin.Unit,e.kotlin.IllegalStateException_init_pdl1vj$),E=n.jetbrains.datalore.base.observable.collections.list.ObservableList,C=n.jetbrains.datalore.base.observable.children.ChildList,S=n.jetbrains.datalore.base.observable.children.SimpleComposite,T=e.kotlin.text.StringBuilder,O=n.jetbrains.datalore.base.observable.property.ValueProperty,N=e.toBoxedChar,P=e.kotlin.text.uppercaseChar_myv2d0$,A=e.getKClass,j=e.toString,L=e.kotlin.IllegalArgumentException_init_pdl1vj$,R=e.unboxChar,I=e.kotlin.collections.ArrayList_init_ww73n8$,z=e.kotlin.collections.ArrayList_init_287e2$,D=n.jetbrains.datalore.base.geometry.DoubleVector,M=e.kotlin.collections.ArrayList_init_mqih57$,B=Math,U=e.kotlin.text.split_ip8yn$,F=e.kotlin.text.contains_li3zpu$,q=n.jetbrains.datalore.base.observable.property.WritableProperty,G=e.kotlin.UnsupportedOperationException_init_pdl1vj$,H=n.jetbrains.datalore.base.observable.collections.list.ObservableArrayList,Y=e.numberToInt,V=n.jetbrains.datalore.base.event.Event,K=(e.numberToDouble,e.kotlin.text.toDouble_pdl1vz$,e.kotlin.collections.filterNotNull_m3lr2h$),W=e.kotlin.collections.emptyList_287e2$,X=e.kotlin.collections.collectionSizeOrDefault_ba2ldo$;function Z(t,e){tt(),this.name=t,this.namespaceUri=e}function J(){Q=this}Is.prototype=Object.create(S.prototype),Is.prototype.constructor=Is,la.prototype=Object.create(Is.prototype),la.prototype.constructor=la,Al.prototype=Object.create(la.prototype),Al.prototype.constructor=Al,Oa.prototype=Object.create(Al.prototype),Oa.prototype.constructor=Oa,et.prototype=Object.create(Oa.prototype),et.prototype.constructor=et,Qn.prototype=Object.create(u.prototype),Qn.prototype.constructor=Qn,ot.prototype=Object.create(Oa.prototype),ot.prototype.constructor=ot,ri.prototype=Object.create(u.prototype),ri.prototype.constructor=ri,sa.prototype=Object.create(Oa.prototype),sa.prototype.constructor=sa,da.prototype=Object.create(v.prototype),da.prototype.constructor=da,$a.prototype=Object.create(Oa.prototype),$a.prototype.constructor=$a,ka.prototype=Object.create(v.prototype),ka.prototype.constructor=ka,Ea.prototype=Object.create(v.prototype),Ea.prototype.constructor=Ea,Ta.prototype=Object.create(Oa.prototype),Ta.prototype.constructor=Ta,Va.prototype=Object.create(u.prototype),Va.prototype.constructor=Va,os.prototype=Object.create(u.prototype),os.prototype.constructor=os,hs.prototype=Object.create(Oa.prototype),hs.prototype.constructor=hs,ys.prototype=Object.create(hs.prototype),ys.prototype.constructor=ys,bs.prototype=Object.create(Oa.prototype),bs.prototype.constructor=bs,zs.prototype=Object.create(C.prototype),zs.prototype.constructor=zs,Fs.prototype=Object.create(O.prototype),Fs.prototype.constructor=Fs,Gs.prototype=Object.create(u.prototype),Gs.prototype.constructor=Gs,_l.prototype=Object.create(u.prototype),_l.prototype.constructor=_l,$l.prototype=Object.create(Oa.prototype),$l.prototype.constructor=$l,xl.prototype=Object.create(Oa.prototype),xl.prototype.constructor=xl,Il.prototype=Object.create(la.prototype),Il.prototype.constructor=Il,zl.prototype=Object.create(Al.prototype),zl.prototype.constructor=zl,Gl.prototype=Object.create(la.prototype),Gl.prototype.constructor=Gl,Ql.prototype=Object.create(Oa.prototype),Ql.prototype.constructor=Ql,ou.prototype=Object.create(H.prototype),ou.prototype.constructor=ou,iu.prototype=Object.create(Is.prototype),iu.prototype.constructor=iu,Nu.prototype=Object.create(V.prototype),Nu.prototype.constructor=Nu,Au.prototype=Object.create(u.prototype),Au.prototype.constructor=Au,Bu.prototype=Object.create(Is.prototype),Bu.prototype.constructor=Bu,Uu.prototype=Object.create(Yu.prototype),Uu.prototype.constructor=Uu,Gu.prototype=Object.create(Bu.prototype),Gu.prototype.constructor=Gu,qu.prototype=Object.create(Uu.prototype),qu.prototype.constructor=qu,J.prototype.createSpec_ytbaoo$=function(t){return new Z(t,null)},J.prototype.createSpecNS_wswq18$=function(t,e,n){return new Z(e+":"+t,n)},J.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Q=null;function tt(){return null===Q&&new J,Q}function et(){rt(),Oa.call(this),this.elementName_4ww0r9$_0="circle"}function nt(){it=this,this.CX=tt().createSpec_ytbaoo$("cx"),this.CY=tt().createSpec_ytbaoo$("cy"),this.R=tt().createSpec_ytbaoo$("r")}Z.prototype.hasNamespace=function(){return null!=this.namespaceUri},Z.prototype.toString=function(){return this.name},Z.prototype.hashCode=function(){return r(this.name)},Z.prototype.equals=function(t){var n;return this===t||!(null==t||null==(n=e.getKClassFromExpression(this))||!n.equals(e.getKClassFromExpression(t)))&&(e.isType(t,Z)||o(),!!a(this.name,t.name))},Z.$metadata$={kind:s,simpleName:"SvgAttributeSpec",interfaces:[]},nt.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var it=null;function rt(){return null===it&&new nt,it}function ot(){Jn(),Oa.call(this)}function at(){Zn=this,this.CLIP_PATH_UNITS_0=tt().createSpec_ytbaoo$("clipPathUnits")}Object.defineProperty(et.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_4ww0r9$_0}}),Object.defineProperty(et.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),et.prototype.cx=function(){return this.getAttribute_mumjwj$(rt().CX)},et.prototype.cy=function(){return this.getAttribute_mumjwj$(rt().CY)},et.prototype.r=function(){return this.getAttribute_mumjwj$(rt().R)},et.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},et.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},et.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},et.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},et.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},et.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},et.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},et.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},et.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},et.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},et.$metadata$={kind:s,simpleName:"SvgCircleElement",interfaces:[Tl,_u,Oa]},at.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var st,lt,ut,ct,pt,ht,_t,ft,dt,mt,yt,$t,vt,gt,bt,wt,xt,kt,Et,Ct,St,Tt,Ot,Nt,Pt,At,jt,Lt,Rt,It,zt,Dt,Mt,Bt,Ut,Ft,qt,Gt,Ht,Yt,Vt,Kt,Wt,Xt,Zt,Jt,Qt,te,ee,ne,ie,re,oe,ae,se,le,ue,ce,pe,he,_e,fe,de,me,ye,$e,ve,ge,be,we,xe,ke,Ee,Ce,Se,Te,Oe,Ne,Pe,Ae,je,Le,Re,Ie,ze,De,Me,Be,Ue,Fe,qe,Ge,He,Ye,Ve,Ke,We,Xe,Ze,Je,Qe,tn,en,nn,rn,on,an,sn,ln,un,cn,pn,hn,_n,fn,dn,mn,yn,$n,vn,gn,bn,wn,xn,kn,En,Cn,Sn,Tn,On,Nn,Pn,An,jn,Ln,Rn,In,zn,Dn,Mn,Bn,Un,Fn,qn,Gn,Hn,Yn,Vn,Kn,Wn,Xn,Zn=null;function Jn(){return null===Zn&&new at,Zn}function Qn(t,e,n){u.call(this),this.myAttributeString_ss0dpy$_0=n,this.name$=t,this.ordinal$=e}function ti(){ti=function(){},st=new Qn("USER_SPACE_ON_USE",0,"userSpaceOnUse"),lt=new Qn("OBJECT_BOUNDING_BOX",1,"objectBoundingBox")}function ei(){return ti(),st}function ni(){return ti(),lt}function ii(){}function ri(t,e,n){u.call(this),this.literal_7kwssz$_0=n,this.name$=t,this.ordinal$=e}function oi(){oi=function(){},ut=new ri("ALICE_BLUE",0,"aliceblue"),ct=new ri("ANTIQUE_WHITE",1,"antiquewhite"),pt=new ri("AQUA",2,"aqua"),ht=new ri("AQUAMARINE",3,"aquamarine"),_t=new ri("AZURE",4,"azure"),ft=new ri("BEIGE",5,"beige"),dt=new ri("BISQUE",6,"bisque"),mt=new ri("BLACK",7,"black"),yt=new ri("BLANCHED_ALMOND",8,"blanchedalmond"),$t=new ri("BLUE",9,"blue"),vt=new ri("BLUE_VIOLET",10,"blueviolet"),gt=new ri("BROWN",11,"brown"),bt=new ri("BURLY_WOOD",12,"burlywood"),wt=new ri("CADET_BLUE",13,"cadetblue"),xt=new ri("CHARTREUSE",14,"chartreuse"),kt=new ri("CHOCOLATE",15,"chocolate"),Et=new ri("CORAL",16,"coral"),Ct=new ri("CORNFLOWER_BLUE",17,"cornflowerblue"),St=new ri("CORNSILK",18,"cornsilk"),Tt=new ri("CRIMSON",19,"crimson"),Ot=new ri("CYAN",20,"cyan"),Nt=new ri("DARK_BLUE",21,"darkblue"),Pt=new ri("DARK_CYAN",22,"darkcyan"),At=new ri("DARK_GOLDEN_ROD",23,"darkgoldenrod"),jt=new ri("DARK_GRAY",24,"darkgray"),Lt=new ri("DARK_GREEN",25,"darkgreen"),Rt=new ri("DARK_GREY",26,"darkgrey"),It=new ri("DARK_KHAKI",27,"darkkhaki"),zt=new ri("DARK_MAGENTA",28,"darkmagenta"),Dt=new ri("DARK_OLIVE_GREEN",29,"darkolivegreen"),Mt=new ri("DARK_ORANGE",30,"darkorange"),Bt=new ri("DARK_ORCHID",31,"darkorchid"),Ut=new ri("DARK_RED",32,"darkred"),Ft=new ri("DARK_SALMON",33,"darksalmon"),qt=new ri("DARK_SEA_GREEN",34,"darkseagreen"),Gt=new ri("DARK_SLATE_BLUE",35,"darkslateblue"),Ht=new ri("DARK_SLATE_GRAY",36,"darkslategray"),Yt=new ri("DARK_SLATE_GREY",37,"darkslategrey"),Vt=new ri("DARK_TURQUOISE",38,"darkturquoise"),Kt=new ri("DARK_VIOLET",39,"darkviolet"),Wt=new ri("DEEP_PINK",40,"deeppink"),Xt=new ri("DEEP_SKY_BLUE",41,"deepskyblue"),Zt=new ri("DIM_GRAY",42,"dimgray"),Jt=new ri("DIM_GREY",43,"dimgrey"),Qt=new ri("DODGER_BLUE",44,"dodgerblue"),te=new ri("FIRE_BRICK",45,"firebrick"),ee=new ri("FLORAL_WHITE",46,"floralwhite"),ne=new ri("FOREST_GREEN",47,"forestgreen"),ie=new ri("FUCHSIA",48,"fuchsia"),re=new ri("GAINSBORO",49,"gainsboro"),oe=new ri("GHOST_WHITE",50,"ghostwhite"),ae=new ri("GOLD",51,"gold"),se=new ri("GOLDEN_ROD",52,"goldenrod"),le=new ri("GRAY",53,"gray"),ue=new ri("GREY",54,"grey"),ce=new ri("GREEN",55,"green"),pe=new ri("GREEN_YELLOW",56,"greenyellow"),he=new ri("HONEY_DEW",57,"honeydew"),_e=new ri("HOT_PINK",58,"hotpink"),fe=new ri("INDIAN_RED",59,"indianred"),de=new ri("INDIGO",60,"indigo"),me=new ri("IVORY",61,"ivory"),ye=new ri("KHAKI",62,"khaki"),$e=new ri("LAVENDER",63,"lavender"),ve=new ri("LAVENDER_BLUSH",64,"lavenderblush"),ge=new ri("LAWN_GREEN",65,"lawngreen"),be=new ri("LEMON_CHIFFON",66,"lemonchiffon"),we=new ri("LIGHT_BLUE",67,"lightblue"),xe=new ri("LIGHT_CORAL",68,"lightcoral"),ke=new ri("LIGHT_CYAN",69,"lightcyan"),Ee=new ri("LIGHT_GOLDEN_ROD_YELLOW",70,"lightgoldenrodyellow"),Ce=new ri("LIGHT_GRAY",71,"lightgray"),Se=new ri("LIGHT_GREEN",72,"lightgreen"),Te=new ri("LIGHT_GREY",73,"lightgrey"),Oe=new ri("LIGHT_PINK",74,"lightpink"),Ne=new ri("LIGHT_SALMON",75,"lightsalmon"),Pe=new ri("LIGHT_SEA_GREEN",76,"lightseagreen"),Ae=new ri("LIGHT_SKY_BLUE",77,"lightskyblue"),je=new ri("LIGHT_SLATE_GRAY",78,"lightslategray"),Le=new ri("LIGHT_SLATE_GREY",79,"lightslategrey"),Re=new ri("LIGHT_STEEL_BLUE",80,"lightsteelblue"),Ie=new ri("LIGHT_YELLOW",81,"lightyellow"),ze=new ri("LIME",82,"lime"),De=new ri("LIME_GREEN",83,"limegreen"),Me=new ri("LINEN",84,"linen"),Be=new ri("MAGENTA",85,"magenta"),Ue=new ri("MAROON",86,"maroon"),Fe=new ri("MEDIUM_AQUA_MARINE",87,"mediumaquamarine"),qe=new ri("MEDIUM_BLUE",88,"mediumblue"),Ge=new ri("MEDIUM_ORCHID",89,"mediumorchid"),He=new ri("MEDIUM_PURPLE",90,"mediumpurple"),Ye=new ri("MEDIUM_SEAGREEN",91,"mediumseagreen"),Ve=new ri("MEDIUM_SLATE_BLUE",92,"mediumslateblue"),Ke=new ri("MEDIUM_SPRING_GREEN",93,"mediumspringgreen"),We=new ri("MEDIUM_TURQUOISE",94,"mediumturquoise"),Xe=new ri("MEDIUM_VIOLET_RED",95,"mediumvioletred"),Ze=new ri("MIDNIGHT_BLUE",96,"midnightblue"),Je=new ri("MINT_CREAM",97,"mintcream"),Qe=new ri("MISTY_ROSE",98,"mistyrose"),tn=new ri("MOCCASIN",99,"moccasin"),en=new ri("NAVAJO_WHITE",100,"navajowhite"),nn=new ri("NAVY",101,"navy"),rn=new ri("OLD_LACE",102,"oldlace"),on=new ri("OLIVE",103,"olive"),an=new ri("OLIVE_DRAB",104,"olivedrab"),sn=new ri("ORANGE",105,"orange"),ln=new ri("ORANGE_RED",106,"orangered"),un=new ri("ORCHID",107,"orchid"),cn=new ri("PALE_GOLDEN_ROD",108,"palegoldenrod"),pn=new ri("PALE_GREEN",109,"palegreen"),hn=new ri("PALE_TURQUOISE",110,"paleturquoise"),_n=new ri("PALE_VIOLET_RED",111,"palevioletred"),fn=new ri("PAPAYA_WHIP",112,"papayawhip"),dn=new ri("PEACH_PUFF",113,"peachpuff"),mn=new ri("PERU",114,"peru"),yn=new ri("PINK",115,"pink"),$n=new ri("PLUM",116,"plum"),vn=new ri("POWDER_BLUE",117,"powderblue"),gn=new ri("PURPLE",118,"purple"),bn=new ri("RED",119,"red"),wn=new ri("ROSY_BROWN",120,"rosybrown"),xn=new ri("ROYAL_BLUE",121,"royalblue"),kn=new ri("SADDLE_BROWN",122,"saddlebrown"),En=new ri("SALMON",123,"salmon"),Cn=new ri("SANDY_BROWN",124,"sandybrown"),Sn=new ri("SEA_GREEN",125,"seagreen"),Tn=new ri("SEASHELL",126,"seashell"),On=new ri("SIENNA",127,"sienna"),Nn=new ri("SILVER",128,"silver"),Pn=new ri("SKY_BLUE",129,"skyblue"),An=new ri("SLATE_BLUE",130,"slateblue"),jn=new ri("SLATE_GRAY",131,"slategray"),Ln=new ri("SLATE_GREY",132,"slategrey"),Rn=new ri("SNOW",133,"snow"),In=new ri("SPRING_GREEN",134,"springgreen"),zn=new ri("STEEL_BLUE",135,"steelblue"),Dn=new ri("TAN",136,"tan"),Mn=new ri("TEAL",137,"teal"),Bn=new ri("THISTLE",138,"thistle"),Un=new ri("TOMATO",139,"tomato"),Fn=new ri("TURQUOISE",140,"turquoise"),qn=new ri("VIOLET",141,"violet"),Gn=new ri("WHEAT",142,"wheat"),Hn=new ri("WHITE",143,"white"),Yn=new ri("WHITE_SMOKE",144,"whitesmoke"),Vn=new ri("YELLOW",145,"yellow"),Kn=new ri("YELLOW_GREEN",146,"yellowgreen"),Wn=new ri("NONE",147,"none"),Xn=new ri("CURRENT_COLOR",148,"currentColor"),Zo()}function ai(){return oi(),ut}function si(){return oi(),ct}function li(){return oi(),pt}function ui(){return oi(),ht}function ci(){return oi(),_t}function pi(){return oi(),ft}function hi(){return oi(),dt}function _i(){return oi(),mt}function fi(){return oi(),yt}function di(){return oi(),$t}function mi(){return oi(),vt}function yi(){return oi(),gt}function $i(){return oi(),bt}function vi(){return oi(),wt}function gi(){return oi(),xt}function bi(){return oi(),kt}function wi(){return oi(),Et}function xi(){return oi(),Ct}function ki(){return oi(),St}function Ei(){return oi(),Tt}function Ci(){return oi(),Ot}function Si(){return oi(),Nt}function Ti(){return oi(),Pt}function Oi(){return oi(),At}function Ni(){return oi(),jt}function Pi(){return oi(),Lt}function Ai(){return oi(),Rt}function ji(){return oi(),It}function Li(){return oi(),zt}function Ri(){return oi(),Dt}function Ii(){return oi(),Mt}function zi(){return oi(),Bt}function Di(){return oi(),Ut}function Mi(){return oi(),Ft}function Bi(){return oi(),qt}function Ui(){return oi(),Gt}function Fi(){return oi(),Ht}function qi(){return oi(),Yt}function Gi(){return oi(),Vt}function Hi(){return oi(),Kt}function Yi(){return oi(),Wt}function Vi(){return oi(),Xt}function Ki(){return oi(),Zt}function Wi(){return oi(),Jt}function Xi(){return oi(),Qt}function Zi(){return oi(),te}function Ji(){return oi(),ee}function Qi(){return oi(),ne}function tr(){return oi(),ie}function er(){return oi(),re}function nr(){return oi(),oe}function ir(){return oi(),ae}function rr(){return oi(),se}function or(){return oi(),le}function ar(){return oi(),ue}function sr(){return oi(),ce}function lr(){return oi(),pe}function ur(){return oi(),he}function cr(){return oi(),_e}function pr(){return oi(),fe}function hr(){return oi(),de}function _r(){return oi(),me}function fr(){return oi(),ye}function dr(){return oi(),$e}function mr(){return oi(),ve}function yr(){return oi(),ge}function $r(){return oi(),be}function vr(){return oi(),we}function gr(){return oi(),xe}function br(){return oi(),ke}function wr(){return oi(),Ee}function xr(){return oi(),Ce}function kr(){return oi(),Se}function Er(){return oi(),Te}function Cr(){return oi(),Oe}function Sr(){return oi(),Ne}function Tr(){return oi(),Pe}function Or(){return oi(),Ae}function Nr(){return oi(),je}function Pr(){return oi(),Le}function Ar(){return oi(),Re}function jr(){return oi(),Ie}function Lr(){return oi(),ze}function Rr(){return oi(),De}function Ir(){return oi(),Me}function zr(){return oi(),Be}function Dr(){return oi(),Ue}function Mr(){return oi(),Fe}function Br(){return oi(),qe}function Ur(){return oi(),Ge}function Fr(){return oi(),He}function qr(){return oi(),Ye}function Gr(){return oi(),Ve}function Hr(){return oi(),Ke}function Yr(){return oi(),We}function Vr(){return oi(),Xe}function Kr(){return oi(),Ze}function Wr(){return oi(),Je}function Xr(){return oi(),Qe}function Zr(){return oi(),tn}function Jr(){return oi(),en}function Qr(){return oi(),nn}function to(){return oi(),rn}function eo(){return oi(),on}function no(){return oi(),an}function io(){return oi(),sn}function ro(){return oi(),ln}function oo(){return oi(),un}function ao(){return oi(),cn}function so(){return oi(),pn}function lo(){return oi(),hn}function uo(){return oi(),_n}function co(){return oi(),fn}function po(){return oi(),dn}function ho(){return oi(),mn}function _o(){return oi(),yn}function fo(){return oi(),$n}function mo(){return oi(),vn}function yo(){return oi(),gn}function $o(){return oi(),bn}function vo(){return oi(),wn}function go(){return oi(),xn}function bo(){return oi(),kn}function wo(){return oi(),En}function xo(){return oi(),Cn}function ko(){return oi(),Sn}function Eo(){return oi(),Tn}function Co(){return oi(),On}function So(){return oi(),Nn}function To(){return oi(),Pn}function Oo(){return oi(),An}function No(){return oi(),jn}function Po(){return oi(),Ln}function Ao(){return oi(),Rn}function jo(){return oi(),In}function Lo(){return oi(),zn}function Ro(){return oi(),Dn}function Io(){return oi(),Mn}function zo(){return oi(),Bn}function Do(){return oi(),Un}function Mo(){return oi(),Fn}function Bo(){return oi(),qn}function Uo(){return oi(),Gn}function Fo(){return oi(),Hn}function qo(){return oi(),Yn}function Go(){return oi(),Vn}function Ho(){return oi(),Kn}function Yo(){return oi(),Wn}function Vo(){return oi(),Xn}function Ko(){Xo=this,this.svgColorList_0=this.createSvgColorList_0()}function Wo(t,e,n){this.myR_0=t,this.myG_0=e,this.myB_0=n}Object.defineProperty(ot.prototype,"elementName",{configurable:!0,get:function(){return"clipPath"}}),Object.defineProperty(ot.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),ot.prototype.clipPathUnits=function(){return this.getAttribute_mumjwj$(Jn().CLIP_PATH_UNITS_0)},ot.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},ot.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},ot.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Qn.prototype.toString=function(){return this.myAttributeString_ss0dpy$_0},Qn.$metadata$={kind:s,simpleName:"ClipPathUnits",interfaces:[u]},Qn.values=function(){return[ei(),ni()]},Qn.valueOf_61zpoe$=function(t){switch(t){case"USER_SPACE_ON_USE":return ei();case"OBJECT_BOUNDING_BOX":return ni();default:c("No enum constant jetbrains.datalore.vis.svg.SvgClipPathElement.ClipPathUnits."+t)}},ot.$metadata$={kind:s,simpleName:"SvgClipPathElement",interfaces:[_u,Oa]},ii.$metadata$={kind:p,simpleName:"SvgColor",interfaces:[]},ri.prototype.toString=function(){return this.literal_7kwssz$_0},Ko.prototype.createSvgColorList_0=function(){var t,e=h(),n=Jo();for(t=0;t!==n.length;++t){var i=n[t],r=i.toString().toLowerCase();e.put_xwzc9p$(r,i)}return e},Ko.prototype.isColorName_61zpoe$=function(t){return this.svgColorList_0.containsKey_11rb$(t.toLowerCase())},Ko.prototype.forName_61zpoe$=function(t){var e;if(null==(e=this.svgColorList_0.get_11rb$(t.toLowerCase())))throw _();return e},Ko.prototype.create_qt1dr2$=function(t,e,n){return new Wo(t,e,n)},Ko.prototype.create_2160e9$=function(t){return null==t?Yo():new Wo(t.red,t.green,t.blue)},Wo.prototype.toString=function(){return"rgb("+this.myR_0+","+this.myG_0+","+this.myB_0+")"},Wo.$metadata$={kind:s,simpleName:"SvgColorRgb",interfaces:[ii]},Wo.prototype.component1_0=function(){return this.myR_0},Wo.prototype.component2_0=function(){return this.myG_0},Wo.prototype.component3_0=function(){return this.myB_0},Wo.prototype.copy_qt1dr2$=function(t,e,n){return new Wo(void 0===t?this.myR_0:t,void 0===e?this.myG_0:e,void 0===n?this.myB_0:n)},Wo.prototype.hashCode=function(){var t=0;return 31*(t=31*(t=31*t+e.hashCode(this.myR_0)|0)+e.hashCode(this.myG_0)|0)+e.hashCode(this.myB_0)|0},Wo.prototype.equals=function(t){return this===t||null!==t&&"object"==typeof t&&Object.getPrototypeOf(this)===Object.getPrototypeOf(t)&&e.equals(this.myR_0,t.myR_0)&&e.equals(this.myG_0,t.myG_0)&&e.equals(this.myB_0,t.myB_0)},Ko.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Xo=null;function Zo(){return oi(),null===Xo&&new Ko,Xo}function Jo(){return[ai(),si(),li(),ui(),ci(),pi(),hi(),_i(),fi(),di(),mi(),yi(),$i(),vi(),gi(),bi(),wi(),xi(),ki(),Ei(),Ci(),Si(),Ti(),Oi(),Ni(),Pi(),Ai(),ji(),Li(),Ri(),Ii(),zi(),Di(),Mi(),Bi(),Ui(),Fi(),qi(),Gi(),Hi(),Yi(),Vi(),Ki(),Wi(),Xi(),Zi(),Ji(),Qi(),tr(),er(),nr(),ir(),rr(),or(),ar(),sr(),lr(),ur(),cr(),pr(),hr(),_r(),fr(),dr(),mr(),yr(),$r(),vr(),gr(),br(),wr(),xr(),kr(),Er(),Cr(),Sr(),Tr(),Or(),Nr(),Pr(),Ar(),jr(),Lr(),Rr(),Ir(),zr(),Dr(),Mr(),Br(),Ur(),Fr(),qr(),Gr(),Hr(),Yr(),Vr(),Kr(),Wr(),Xr(),Zr(),Jr(),Qr(),to(),eo(),no(),io(),ro(),oo(),ao(),so(),lo(),uo(),co(),po(),ho(),_o(),fo(),mo(),yo(),$o(),vo(),go(),bo(),wo(),xo(),ko(),Eo(),Co(),So(),To(),Oo(),No(),Po(),Ao(),jo(),Lo(),Ro(),Io(),zo(),Do(),Mo(),Bo(),Uo(),Fo(),qo(),Go(),Ho(),Yo(),Vo()]}function Qo(){ta=this,this.WIDTH="width",this.HEIGHT="height",this.SVG_TEXT_ANCHOR_ATTRIBUTE="text-anchor",this.SVG_STROKE_DASHARRAY_ATTRIBUTE="stroke-dasharray",this.SVG_STYLE_ATTRIBUTE="style",this.SVG_TEXT_DY_ATTRIBUTE="dy",this.SVG_TEXT_ANCHOR_START="start",this.SVG_TEXT_ANCHOR_MIDDLE="middle",this.SVG_TEXT_ANCHOR_END="end",this.SVG_TEXT_DY_TOP="0.7em",this.SVG_TEXT_DY_CENTER="0.35em"}ri.$metadata$={kind:s,simpleName:"SvgColors",interfaces:[ii,u]},ri.values=Jo,ri.valueOf_61zpoe$=function(t){switch(t){case"ALICE_BLUE":return ai();case"ANTIQUE_WHITE":return si();case"AQUA":return li();case"AQUAMARINE":return ui();case"AZURE":return ci();case"BEIGE":return pi();case"BISQUE":return hi();case"BLACK":return _i();case"BLANCHED_ALMOND":return fi();case"BLUE":return di();case"BLUE_VIOLET":return mi();case"BROWN":return yi();case"BURLY_WOOD":return $i();case"CADET_BLUE":return vi();case"CHARTREUSE":return gi();case"CHOCOLATE":return bi();case"CORAL":return wi();case"CORNFLOWER_BLUE":return xi();case"CORNSILK":return ki();case"CRIMSON":return Ei();case"CYAN":return Ci();case"DARK_BLUE":return Si();case"DARK_CYAN":return Ti();case"DARK_GOLDEN_ROD":return Oi();case"DARK_GRAY":return Ni();case"DARK_GREEN":return Pi();case"DARK_GREY":return Ai();case"DARK_KHAKI":return ji();case"DARK_MAGENTA":return Li();case"DARK_OLIVE_GREEN":return Ri();case"DARK_ORANGE":return Ii();case"DARK_ORCHID":return zi();case"DARK_RED":return Di();case"DARK_SALMON":return Mi();case"DARK_SEA_GREEN":return Bi();case"DARK_SLATE_BLUE":return Ui();case"DARK_SLATE_GRAY":return Fi();case"DARK_SLATE_GREY":return qi();case"DARK_TURQUOISE":return Gi();case"DARK_VIOLET":return Hi();case"DEEP_PINK":return Yi();case"DEEP_SKY_BLUE":return Vi();case"DIM_GRAY":return Ki();case"DIM_GREY":return Wi();case"DODGER_BLUE":return Xi();case"FIRE_BRICK":return Zi();case"FLORAL_WHITE":return Ji();case"FOREST_GREEN":return Qi();case"FUCHSIA":return tr();case"GAINSBORO":return er();case"GHOST_WHITE":return nr();case"GOLD":return ir();case"GOLDEN_ROD":return rr();case"GRAY":return or();case"GREY":return ar();case"GREEN":return sr();case"GREEN_YELLOW":return lr();case"HONEY_DEW":return ur();case"HOT_PINK":return cr();case"INDIAN_RED":return pr();case"INDIGO":return hr();case"IVORY":return _r();case"KHAKI":return fr();case"LAVENDER":return dr();case"LAVENDER_BLUSH":return mr();case"LAWN_GREEN":return yr();case"LEMON_CHIFFON":return $r();case"LIGHT_BLUE":return vr();case"LIGHT_CORAL":return gr();case"LIGHT_CYAN":return br();case"LIGHT_GOLDEN_ROD_YELLOW":return wr();case"LIGHT_GRAY":return xr();case"LIGHT_GREEN":return kr();case"LIGHT_GREY":return Er();case"LIGHT_PINK":return Cr();case"LIGHT_SALMON":return Sr();case"LIGHT_SEA_GREEN":return Tr();case"LIGHT_SKY_BLUE":return Or();case"LIGHT_SLATE_GRAY":return Nr();case"LIGHT_SLATE_GREY":return Pr();case"LIGHT_STEEL_BLUE":return Ar();case"LIGHT_YELLOW":return jr();case"LIME":return Lr();case"LIME_GREEN":return Rr();case"LINEN":return Ir();case"MAGENTA":return zr();case"MAROON":return Dr();case"MEDIUM_AQUA_MARINE":return Mr();case"MEDIUM_BLUE":return Br();case"MEDIUM_ORCHID":return Ur();case"MEDIUM_PURPLE":return Fr();case"MEDIUM_SEAGREEN":return qr();case"MEDIUM_SLATE_BLUE":return Gr();case"MEDIUM_SPRING_GREEN":return Hr();case"MEDIUM_TURQUOISE":return Yr();case"MEDIUM_VIOLET_RED":return Vr();case"MIDNIGHT_BLUE":return Kr();case"MINT_CREAM":return Wr();case"MISTY_ROSE":return Xr();case"MOCCASIN":return Zr();case"NAVAJO_WHITE":return Jr();case"NAVY":return Qr();case"OLD_LACE":return to();case"OLIVE":return eo();case"OLIVE_DRAB":return no();case"ORANGE":return io();case"ORANGE_RED":return ro();case"ORCHID":return oo();case"PALE_GOLDEN_ROD":return ao();case"PALE_GREEN":return so();case"PALE_TURQUOISE":return lo();case"PALE_VIOLET_RED":return uo();case"PAPAYA_WHIP":return co();case"PEACH_PUFF":return po();case"PERU":return ho();case"PINK":return _o();case"PLUM":return fo();case"POWDER_BLUE":return mo();case"PURPLE":return yo();case"RED":return $o();case"ROSY_BROWN":return vo();case"ROYAL_BLUE":return go();case"SADDLE_BROWN":return bo();case"SALMON":return wo();case"SANDY_BROWN":return xo();case"SEA_GREEN":return ko();case"SEASHELL":return Eo();case"SIENNA":return Co();case"SILVER":return So();case"SKY_BLUE":return To();case"SLATE_BLUE":return Oo();case"SLATE_GRAY":return No();case"SLATE_GREY":return Po();case"SNOW":return Ao();case"SPRING_GREEN":return jo();case"STEEL_BLUE":return Lo();case"TAN":return Ro();case"TEAL":return Io();case"THISTLE":return zo();case"TOMATO":return Do();case"TURQUOISE":return Mo();case"VIOLET":return Bo();case"WHEAT":return Uo();case"WHITE":return Fo();case"WHITE_SMOKE":return qo();case"YELLOW":return Go();case"YELLOW_GREEN":return Ho();case"NONE":return Yo();case"CURRENT_COLOR":return Vo();default:c("No enum constant jetbrains.datalore.vis.svg.SvgColors."+t)}},Qo.$metadata$={kind:i,simpleName:"SvgConstants",interfaces:[]};var ta=null;function ea(){return null===ta&&new Qo,ta}function na(){oa()}function ia(){ra=this,this.OPACITY=tt().createSpec_ytbaoo$("opacity"),this.CLIP_PATH=tt().createSpec_ytbaoo$("clip-path")}ia.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ra=null;function oa(){return null===ra&&new ia,ra}function aa(){}function sa(){Oa.call(this),this.elementName_ohv755$_0="defs"}function la(){pa(),Is.call(this),this.myAttributes_9lwppr$_0=new ma(this),this.myListeners_acqj1r$_0=null,this.myEventPeer_bxokaa$_0=new wa}function ua(){ca=this,this.ID_0=tt().createSpec_ytbaoo$("id")}na.$metadata$={kind:p,simpleName:"SvgContainer",interfaces:[]},aa.$metadata$={kind:p,simpleName:"SvgCssResource",interfaces:[]},Object.defineProperty(sa.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_ohv755$_0}}),Object.defineProperty(sa.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),sa.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},sa.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},sa.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},sa.$metadata$={kind:s,simpleName:"SvgDefsElement",interfaces:[_u,na,Oa]},ua.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ca=null;function pa(){return null===ca&&new ua,ca}function ha(t,e){this.closure$spec=t,this.this$SvgElement=e}function _a(t,e){this.closure$spec=t,this.closure$handler=e}function fa(t){this.closure$event=t}function da(t,e){this.closure$reg=t,this.this$SvgElement=e,v.call(this)}function ma(t){this.$outer=t,this.myAttrs_0=null}function ya(){}function $a(){ba(),Oa.call(this),this.elementName_psynub$_0="ellipse"}function va(){ga=this,this.CX=tt().createSpec_ytbaoo$("cx"),this.CY=tt().createSpec_ytbaoo$("cy"),this.RX=tt().createSpec_ytbaoo$("rx"),this.RY=tt().createSpec_ytbaoo$("ry")}Object.defineProperty(la.prototype,"ownerSvgElement",{configurable:!0,get:function(){for(var t,n=this;null!=n&&!e.isType(n,zl);)n=n.parentProperty().get();return null!=n?null==(t=n)||e.isType(t,zl)?t:o():null}}),Object.defineProperty(la.prototype,"attributeKeys",{configurable:!0,get:function(){return this.myAttributes_9lwppr$_0.keySet()}}),la.prototype.id=function(){return this.getAttribute_mumjwj$(pa().ID_0)},la.prototype.handlersSet=function(){return this.myEventPeer_bxokaa$_0.handlersSet()},la.prototype.addEventHandler_mm8kk2$=function(t,e){return this.myEventPeer_bxokaa$_0.addEventHandler_mm8kk2$(t,e)},la.prototype.dispatch_lgzia2$=function(t,n){var i;this.myEventPeer_bxokaa$_0.dispatch_2raoxs$(t,n,this),null!=this.parentProperty().get()&&!n.isConsumed&&e.isType(this.parentProperty().get(),la)&&(e.isType(i=this.parentProperty().get(),la)?i:o()).dispatch_lgzia2$(t,n)},la.prototype.getSpecByName_o4z2a7$_0=function(t){return tt().createSpec_ytbaoo$(t)},Object.defineProperty(ha.prototype,"propExpr",{configurable:!0,get:function(){return this.toString()+"."+this.closure$spec}}),ha.prototype.get=function(){return this.this$SvgElement.myAttributes_9lwppr$_0.get_mumjwj$(this.closure$spec)},ha.prototype.set_11rb$=function(t){this.this$SvgElement.myAttributes_9lwppr$_0.set_qdh7ux$(this.closure$spec,t)},_a.prototype.onAttrSet_ud3ldc$=function(t){var n,i;if(this.closure$spec===t.attrSpec){var r=null==(n=t.oldValue)||e.isType(n,f)?n:o(),a=null==(i=t.newValue)||e.isType(i,f)?i:o();this.closure$handler.onEvent_11rb$(new d(r,a))}},_a.$metadata$={kind:s,interfaces:[ya]},ha.prototype.addHandler_gxwwpc$=function(t){return this.this$SvgElement.addListener_e4m8w6$(new _a(this.closure$spec,t))},ha.$metadata$={kind:s,interfaces:[m]},la.prototype.getAttribute_mumjwj$=function(t){return new ha(t,this)},la.prototype.getAttribute_61zpoe$=function(t){var e=this.getSpecByName_o4z2a7$_0(t);return this.getAttribute_mumjwj$(e)},la.prototype.setAttribute_qdh7ux$=function(t,e){this.getAttribute_mumjwj$(t).set_11rb$(e)},la.prototype.setAttribute_jyasbz$=function(t,e){this.getAttribute_61zpoe$(t).set_11rb$(e)},fa.prototype.call_11rb$=function(t){t.onAttrSet_ud3ldc$(this.closure$event)},fa.$metadata$={kind:s,interfaces:[y]},la.prototype.onAttributeChanged_2oaikr$_0=function(t){null!=this.myListeners_acqj1r$_0&&l(this.myListeners_acqj1r$_0).fire_kucmxw$(new fa(t)),this.isAttached()&&this.container().attributeChanged_1u4bot$(this,t)},da.prototype.doRemove=function(){this.closure$reg.remove(),l(this.this$SvgElement.myListeners_acqj1r$_0).isEmpty&&(this.this$SvgElement.myListeners_acqj1r$_0=null)},da.$metadata$={kind:s,interfaces:[v]},la.prototype.addListener_e4m8w6$=function(t){return null==this.myListeners_acqj1r$_0&&(this.myListeners_acqj1r$_0=new $),new da(l(this.myListeners_acqj1r$_0).add_11rb$(t),this)},la.prototype.toString=function(){return"<"+this.elementName+" "+this.myAttributes_9lwppr$_0.toSvgString_8be2vx$()+">"},Object.defineProperty(ma.prototype,"isEmpty",{configurable:!0,get:function(){return null==this.myAttrs_0||l(this.myAttrs_0).isEmpty}}),ma.prototype.size=function(){return null==this.myAttrs_0?0:l(this.myAttrs_0).size()},ma.prototype.containsKey_p8ci7$=function(t){return null!=this.myAttrs_0&&l(this.myAttrs_0).containsKey_11rb$(t)},ma.prototype.get_mumjwj$=function(t){var n;return null!=this.myAttrs_0&&l(this.myAttrs_0).containsKey_11rb$(t)?null==(n=l(this.myAttrs_0).get_11rb$(t))||e.isType(n,f)?n:o():null},ma.prototype.set_qdh7ux$=function(t,n){var i,r;null==this.myAttrs_0&&(this.myAttrs_0=new g);var s=null==n?null==(i=l(this.myAttrs_0).remove_11rb$(t))||e.isType(i,f)?i:o():null==(r=l(this.myAttrs_0).put_xwzc9p$(t,n))||e.isType(r,f)?r:o();if(!a(n,s)){var u=new Nu(t,s,n);this.$outer.onAttributeChanged_2oaikr$_0(u)}return s},ma.prototype.remove_mumjwj$=function(t){return this.set_qdh7ux$(t,null)},ma.prototype.keySet=function(){return null==this.myAttrs_0?b():l(this.myAttrs_0).keySet()},ma.prototype.toSvgString_8be2vx$=function(){var t,e=w();for(t=this.keySet().iterator();t.hasNext();){var n=t.next();e.append_pdl1vj$(n.name).append_pdl1vj$('="').append_s8jyv4$(this.get_mumjwj$(n)).append_pdl1vj$('" ')}return e.toString()},ma.prototype.toString=function(){return this.toSvgString_8be2vx$()},ma.$metadata$={kind:s,simpleName:"AttributeMap",interfaces:[]},la.$metadata$={kind:s,simpleName:"SvgElement",interfaces:[Is]},ya.$metadata$={kind:p,simpleName:"SvgElementListener",interfaces:[]},va.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var ga=null;function ba(){return null===ga&&new va,ga}function wa(){this.myEventHandlers_0=null,this.myListeners_0=null}function xa(t){this.this$SvgEventPeer=t}function ka(t,e){this.closure$addReg=t,this.this$SvgEventPeer=e,v.call(this)}function Ea(t,e,n,i){this.closure$addReg=t,this.closure$specListeners=e,this.closure$eventHandlers=n,this.closure$spec=i,v.call(this)}function Ca(t,e){this.closure$oldHandlersSet=t,this.this$SvgEventPeer=e}function Sa(t,e){this.closure$event=t,this.closure$target=e}function Ta(){Oa.call(this),this.elementName_84zyy2$_0="g"}function Oa(){Ya(),Al.call(this)}function Na(){Ha=this,this.POINTER_EVENTS_0=tt().createSpec_ytbaoo$("pointer-events"),this.OPACITY=tt().createSpec_ytbaoo$("opacity"),this.VISIBILITY=tt().createSpec_ytbaoo$("visibility"),this.CLIP_PATH=tt().createSpec_ytbaoo$("clip-path"),this.CLIP_BOUNDS_JFX=tt().createSpec_ytbaoo$("clip-bounds-jfx")}Object.defineProperty($a.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_psynub$_0}}),Object.defineProperty($a.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),$a.prototype.cx=function(){return this.getAttribute_mumjwj$(ba().CX)},$a.prototype.cy=function(){return this.getAttribute_mumjwj$(ba().CY)},$a.prototype.rx=function(){return this.getAttribute_mumjwj$(ba().RX)},$a.prototype.ry=function(){return this.getAttribute_mumjwj$(ba().RY)},$a.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},$a.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},$a.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},$a.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},$a.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},$a.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},$a.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},$a.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},$a.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},$a.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},$a.$metadata$={kind:s,simpleName:"SvgEllipseElement",interfaces:[Tl,_u,Oa]},Object.defineProperty(xa.prototype,"propExpr",{configurable:!0,get:function(){return this.toString()+".handlersProp"}}),xa.prototype.get=function(){return this.this$SvgEventPeer.handlersKeySet_0()},ka.prototype.doRemove=function(){this.closure$addReg.remove(),l(this.this$SvgEventPeer.myListeners_0).isEmpty&&(this.this$SvgEventPeer.myListeners_0=null)},ka.$metadata$={kind:s,interfaces:[v]},xa.prototype.addHandler_gxwwpc$=function(t){return null==this.this$SvgEventPeer.myListeners_0&&(this.this$SvgEventPeer.myListeners_0=new $),new ka(l(this.this$SvgEventPeer.myListeners_0).add_11rb$(t),this.this$SvgEventPeer)},xa.$metadata$={kind:s,interfaces:[x]},wa.prototype.handlersSet=function(){return new xa(this)},wa.prototype.handlersKeySet_0=function(){return null==this.myEventHandlers_0?b():l(this.myEventHandlers_0).keys},Ea.prototype.doRemove=function(){this.closure$addReg.remove(),this.closure$specListeners.isEmpty&&this.closure$eventHandlers.remove_11rb$(this.closure$spec)},Ea.$metadata$={kind:s,interfaces:[v]},Ca.prototype.call_11rb$=function(t){t.onEvent_11rb$(new d(this.closure$oldHandlersSet,this.this$SvgEventPeer.handlersKeySet_0()))},Ca.$metadata$={kind:s,interfaces:[y]},wa.prototype.addEventHandler_mm8kk2$=function(t,e){var n;null==this.myEventHandlers_0&&(this.myEventHandlers_0=h());var i=l(this.myEventHandlers_0);if(!i.containsKey_11rb$(t)){var r=new $;i.put_xwzc9p$(t,r)}var o=i.keys,a=l(i.get_11rb$(t)),s=new Ea(a.add_11rb$(e),a,i,t);return null!=(n=this.myListeners_0)&&n.fire_kucmxw$(new Ca(o,this)),s},Sa.prototype.call_11rb$=function(t){var n;this.closure$event.isConsumed||(e.isType(n=t,Pu)?n:o()).handle_42da0z$(this.closure$target,this.closure$event)},Sa.$metadata$={kind:s,interfaces:[y]},wa.prototype.dispatch_2raoxs$=function(t,e,n){null!=this.myEventHandlers_0&&l(this.myEventHandlers_0).containsKey_11rb$(t)&&l(l(this.myEventHandlers_0).get_11rb$(t)).fire_kucmxw$(new Sa(e,n))},wa.$metadata$={kind:s,simpleName:"SvgEventPeer",interfaces:[]},Object.defineProperty(Ta.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_84zyy2$_0}}),Object.defineProperty(Ta.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),Ta.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},Ta.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},Ta.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Ta.$metadata$={kind:s,simpleName:"SvgGElement",interfaces:[na,_u,Oa]},Na.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Pa,Aa,ja,La,Ra,Ia,za,Da,Ma,Ba,Ua,Fa,qa,Ga,Ha=null;function Ya(){return null===Ha&&new Na,Ha}function Va(t,e,n){u.call(this),this.myAttributeString_wpy0pw$_0=n,this.name$=t,this.ordinal$=e}function Ka(){Ka=function(){},Pa=new Va("VISIBLE_PAINTED",0,"visiblePainted"),Aa=new Va("VISIBLE_FILL",1,"visibleFill"),ja=new Va("VISIBLE_STROKE",2,"visibleStroke"),La=new Va("VISIBLE",3,"visible"),Ra=new Va("PAINTED",4,"painted"),Ia=new Va("FILL",5,"fill"),za=new Va("STROKE",6,"stroke"),Da=new Va("ALL",7,"all"),Ma=new Va("NONE",8,"none"),Ba=new Va("INHERIT",9,"inherit")}function Wa(){return Ka(),Pa}function Xa(){return Ka(),Aa}function Za(){return Ka(),ja}function Ja(){return Ka(),La}function Qa(){return Ka(),Ra}function ts(){return Ka(),Ia}function es(){return Ka(),za}function ns(){return Ka(),Da}function is(){return Ka(),Ma}function rs(){return Ka(),Ba}function os(t,e,n){u.call(this),this.myAttrString_w3r471$_0=n,this.name$=t,this.ordinal$=e}function as(){as=function(){},Ua=new os("VISIBLE",0,"visible"),Fa=new os("HIDDEN",1,"hidden"),qa=new os("COLLAPSE",2,"collapse"),Ga=new os("INHERIT",3,"inherit")}function ss(){return as(),Ua}function ls(){return as(),Fa}function us(){return as(),qa}function cs(){return as(),Ga}function ps(t){this.myElementId_0=t}function hs(){ds(),Oa.call(this),this.elementName_r17hoq$_0="image",this.setAttribute_qdh7ux$(ds().PRESERVE_ASPECT_RATIO,"none"),this.setAttribute_jyasbz$(ea().SVG_STYLE_ATTRIBUTE,"image-rendering: pixelated;image-rendering: crisp-edges;")}function _s(){fs=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT),this.HREF=tt().createSpecNS_wswq18$("href",Ou().XLINK_PREFIX,Ou().XLINK_NAMESPACE_URI),this.PRESERVE_ASPECT_RATIO=tt().createSpec_ytbaoo$("preserveAspectRatio")}Oa.prototype.pointerEvents=function(){return this.getAttribute_mumjwj$(Ya().POINTER_EVENTS_0)},Oa.prototype.opacity=function(){return this.getAttribute_mumjwj$(Ya().OPACITY)},Oa.prototype.visibility=function(){return this.getAttribute_mumjwj$(Ya().VISIBILITY)},Oa.prototype.clipPath=function(){return this.getAttribute_mumjwj$(Ya().CLIP_PATH)},Va.prototype.toString=function(){return this.myAttributeString_wpy0pw$_0},Va.$metadata$={kind:s,simpleName:"PointerEvents",interfaces:[u]},Va.values=function(){return[Wa(),Xa(),Za(),Ja(),Qa(),ts(),es(),ns(),is(),rs()]},Va.valueOf_61zpoe$=function(t){switch(t){case"VISIBLE_PAINTED":return Wa();case"VISIBLE_FILL":return Xa();case"VISIBLE_STROKE":return Za();case"VISIBLE":return Ja();case"PAINTED":return Qa();case"FILL":return ts();case"STROKE":return es();case"ALL":return ns();case"NONE":return is();case"INHERIT":return rs();default:c("No enum constant jetbrains.datalore.vis.svg.SvgGraphicsElement.PointerEvents."+t)}},os.prototype.toString=function(){return this.myAttrString_w3r471$_0},os.$metadata$={kind:s,simpleName:"Visibility",interfaces:[u]},os.values=function(){return[ss(),ls(),us(),cs()]},os.valueOf_61zpoe$=function(t){switch(t){case"VISIBLE":return ss();case"HIDDEN":return ls();case"COLLAPSE":return us();case"INHERIT":return cs();default:c("No enum constant jetbrains.datalore.vis.svg.SvgGraphicsElement.Visibility."+t)}},Oa.$metadata$={kind:s,simpleName:"SvgGraphicsElement",interfaces:[Al]},ps.prototype.toString=function(){return"url(#"+this.myElementId_0+")"},ps.$metadata$={kind:s,simpleName:"SvgIRI",interfaces:[]},_s.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var fs=null;function ds(){return null===fs&&new _s,fs}function ms(t,e,n,i,r){return r=r||Object.create(hs.prototype),hs.call(r),r.setAttribute_qdh7ux$(ds().X,t),r.setAttribute_qdh7ux$(ds().Y,e),r.setAttribute_qdh7ux$(ds().WIDTH,n),r.setAttribute_qdh7ux$(ds().HEIGHT,i),r}function ys(t,e,n,i,r){ms(t,e,n,i,this),this.myBitmap_0=r}function $s(t,e){this.closure$hrefProp=t,this.this$SvgImageElementEx=e}function vs(){}function gs(t,e,n){this.width=t,this.height=e,this.argbValues=n.slice()}function bs(){Ls(),Oa.call(this),this.elementName_7igd9t$_0="line"}function ws(){js=this,this.X1=tt().createSpec_ytbaoo$("x1"),this.Y1=tt().createSpec_ytbaoo$("y1"),this.X2=tt().createSpec_ytbaoo$("x2"),this.Y2=tt().createSpec_ytbaoo$("y2")}Object.defineProperty(hs.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_r17hoq$_0}}),Object.defineProperty(hs.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),hs.prototype.x=function(){return this.getAttribute_mumjwj$(ds().X)},hs.prototype.y=function(){return this.getAttribute_mumjwj$(ds().Y)},hs.prototype.width=function(){return this.getAttribute_mumjwj$(ds().WIDTH)},hs.prototype.height=function(){return this.getAttribute_mumjwj$(ds().HEIGHT)},hs.prototype.href=function(){return this.getAttribute_mumjwj$(ds().HREF)},hs.prototype.preserveAspectRatio=function(){return this.getAttribute_mumjwj$(ds().PRESERVE_ASPECT_RATIO)},hs.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},hs.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},hs.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},hs.$metadata$={kind:s,simpleName:"SvgImageElement",interfaces:[_u,Oa]},Object.defineProperty($s.prototype,"propExpr",{configurable:!0,get:function(){return this.closure$hrefProp.propExpr}}),$s.prototype.get=function(){return this.closure$hrefProp.get()},$s.prototype.addHandler_gxwwpc$=function(t){return this.closure$hrefProp.addHandler_gxwwpc$(t)},$s.prototype.set_11rb$=function(t){throw k("href property is read-only in "+e.getKClassFromExpression(this.this$SvgImageElementEx).simpleName)},$s.$metadata$={kind:s,interfaces:[m]},ys.prototype.href=function(){return new $s(hs.prototype.href.call(this),this)},ys.prototype.asImageElement_xhdger$=function(t){var e=new hs;gu().copyAttributes_azdp7k$(this,e);var n=t.toDataUrl_nps3vt$(this.myBitmap_0.width,this.myBitmap_0.height,this.myBitmap_0.argbValues);return e.href().set_11rb$(n),e},vs.$metadata$={kind:p,simpleName:"RGBEncoder",interfaces:[]},gs.$metadata$={kind:s,simpleName:"Bitmap",interfaces:[]},ys.$metadata$={kind:s,simpleName:"SvgImageElementEx",interfaces:[hs]},ws.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var xs,ks,Es,Cs,Ss,Ts,Os,Ns,Ps,As,js=null;function Ls(){return null===js&&new ws,js}function Rs(){}function Is(){S.call(this),this.myContainer_rnn3uj$_0=null,this.myChildren_jvkzg9$_0=null,this.isPrebuiltSubtree=!1}function zs(t,e){this.$outer=t,C.call(this,e)}function Ds(t){this.mySvgRoot_0=new Fs(this,t),this.myListeners_0=new $,this.myPeer_0=null,this.mySvgRoot_0.get().attach_1gwaml$(this)}function Ms(t,e){this.closure$element=t,this.closure$event=e}function Bs(t){this.closure$node=t}function Us(t){this.closure$node=t}function Fs(t,e){this.this$SvgNodeContainer=t,O.call(this,e)}function qs(t){pl(),this.myPathData_0=t}function Gs(t,e,n){u.call(this),this.myChar_90i289$_0=n,this.name$=t,this.ordinal$=e}function Hs(){Hs=function(){},xs=new Gs("MOVE_TO",0,109),ks=new Gs("LINE_TO",1,108),Es=new Gs("HORIZONTAL_LINE_TO",2,104),Cs=new Gs("VERTICAL_LINE_TO",3,118),Ss=new Gs("CURVE_TO",4,99),Ts=new Gs("SMOOTH_CURVE_TO",5,115),Os=new Gs("QUADRATIC_BEZIER_CURVE_TO",6,113),Ns=new Gs("SMOOTH_QUADRATIC_BEZIER_CURVE_TO",7,116),Ps=new Gs("ELLIPTICAL_ARC",8,97),As=new Gs("CLOSE_PATH",9,122),rl()}function Ys(){return Hs(),xs}function Vs(){return Hs(),ks}function Ks(){return Hs(),Es}function Ws(){return Hs(),Cs}function Xs(){return Hs(),Ss}function Zs(){return Hs(),Ts}function Js(){return Hs(),Os}function Qs(){return Hs(),Ns}function tl(){return Hs(),Ps}function el(){return Hs(),As}function nl(){var t,e;for(il=this,this.MAP_0=h(),t=ol(),e=0;e!==t.length;++e){var n=t[e],i=this.MAP_0,r=n.absoluteCmd();i.put_xwzc9p$(r,n);var o=this.MAP_0,a=n.relativeCmd();o.put_xwzc9p$(a,n)}}Object.defineProperty(bs.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_7igd9t$_0}}),Object.defineProperty(bs.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),bs.prototype.x1=function(){return this.getAttribute_mumjwj$(Ls().X1)},bs.prototype.y1=function(){return this.getAttribute_mumjwj$(Ls().Y1)},bs.prototype.x2=function(){return this.getAttribute_mumjwj$(Ls().X2)},bs.prototype.y2=function(){return this.getAttribute_mumjwj$(Ls().Y2)},bs.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},bs.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},bs.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},bs.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},bs.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},bs.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},bs.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},bs.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},bs.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},bs.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},bs.$metadata$={kind:s,simpleName:"SvgLineElement",interfaces:[Tl,_u,Oa]},Rs.$metadata$={kind:p,simpleName:"SvgLocatable",interfaces:[]},Is.prototype.isAttached=function(){return null!=this.myContainer_rnn3uj$_0},Is.prototype.container=function(){return l(this.myContainer_rnn3uj$_0)},Is.prototype.children=function(){var t;return null==this.myChildren_jvkzg9$_0&&(this.myChildren_jvkzg9$_0=new zs(this,this)),e.isType(t=this.myChildren_jvkzg9$_0,E)?t:o()},Is.prototype.attach_1gwaml$=function(t){var e;if(this.isAttached())throw k("Svg element is already attached");for(e=this.children().iterator();e.hasNext();)e.next().attach_1gwaml$(t);this.myContainer_rnn3uj$_0=t,l(this.myContainer_rnn3uj$_0).svgNodeAttached_vvfmut$(this)},Is.prototype.detach_8be2vx$=function(){var t;if(!this.isAttached())throw k("Svg element is not attached");for(t=this.children().iterator();t.hasNext();)t.next().detach_8be2vx$();l(this.myContainer_rnn3uj$_0).svgNodeDetached_vvfmut$(this),this.myContainer_rnn3uj$_0=null},zs.prototype.beforeItemAdded_wxm5ur$=function(t,e){this.$outer.isAttached()&&e.attach_1gwaml$(this.$outer.container()),C.prototype.beforeItemAdded_wxm5ur$.call(this,t,e)},zs.prototype.beforeItemSet_hu11d4$=function(t,e,n){this.$outer.isAttached()&&(e.detach_8be2vx$(),n.attach_1gwaml$(this.$outer.container())),C.prototype.beforeItemSet_hu11d4$.call(this,t,e,n)},zs.prototype.beforeItemRemoved_wxm5ur$=function(t,e){this.$outer.isAttached()&&e.detach_8be2vx$(),C.prototype.beforeItemRemoved_wxm5ur$.call(this,t,e)},zs.$metadata$={kind:s,simpleName:"SvgChildList",interfaces:[C]},Is.$metadata$={kind:s,simpleName:"SvgNode",interfaces:[S]},Ds.prototype.setPeer_kqs5uc$=function(t){this.myPeer_0=t},Ds.prototype.getPeer=function(){return this.myPeer_0},Ds.prototype.root=function(){return this.mySvgRoot_0},Ds.prototype.addListener_6zkzfn$=function(t){return this.myListeners_0.add_11rb$(t)},Ms.prototype.call_11rb$=function(t){t.onAttributeSet_os9wmi$(this.closure$element,this.closure$event)},Ms.$metadata$={kind:s,interfaces:[y]},Ds.prototype.attributeChanged_1u4bot$=function(t,e){this.myListeners_0.fire_kucmxw$(new Ms(t,e))},Bs.prototype.call_11rb$=function(t){t.onNodeAttached_26jijc$(this.closure$node)},Bs.$metadata$={kind:s,interfaces:[y]},Ds.prototype.svgNodeAttached_vvfmut$=function(t){this.myListeners_0.fire_kucmxw$(new Bs(t))},Us.prototype.call_11rb$=function(t){t.onNodeDetached_26jijc$(this.closure$node)},Us.$metadata$={kind:s,interfaces:[y]},Ds.prototype.svgNodeDetached_vvfmut$=function(t){this.myListeners_0.fire_kucmxw$(new Us(t))},Fs.prototype.set_11rb$=function(t){this.get().detach_8be2vx$(),O.prototype.set_11rb$.call(this,t),t.attach_1gwaml$(this.this$SvgNodeContainer)},Fs.$metadata$={kind:s,interfaces:[O]},Ds.$metadata$={kind:s,simpleName:"SvgNodeContainer",interfaces:[]},Gs.prototype.relativeCmd=function(){return N(this.myChar_90i289$_0)},Gs.prototype.absoluteCmd=function(){return N(P(this.myChar_90i289$_0))},nl.prototype.get_s8itvh$=function(t){if(this.MAP_0.containsKey_11rb$(N(t)))return l(this.MAP_0.get_11rb$(N(t)));throw L("No enum constant "+j(A(Gs))+"@myChar."+String.fromCharCode(N(t)))},nl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var il=null;function rl(){return Hs(),null===il&&new nl,il}function ol(){return[Ys(),Vs(),Ks(),Ws(),Xs(),Zs(),Js(),Qs(),tl(),el()]}function al(){cl=this,this.EMPTY=new qs("")}Gs.$metadata$={kind:s,simpleName:"Action",interfaces:[u]},Gs.values=ol,Gs.valueOf_61zpoe$=function(t){switch(t){case"MOVE_TO":return Ys();case"LINE_TO":return Vs();case"HORIZONTAL_LINE_TO":return Ks();case"VERTICAL_LINE_TO":return Ws();case"CURVE_TO":return Xs();case"SMOOTH_CURVE_TO":return Zs();case"QUADRATIC_BEZIER_CURVE_TO":return Js();case"SMOOTH_QUADRATIC_BEZIER_CURVE_TO":return Qs();case"ELLIPTICAL_ARC":return tl();case"CLOSE_PATH":return el();default:c("No enum constant jetbrains.datalore.vis.svg.SvgPathData.Action."+t)}},qs.prototype.toString=function(){return this.myPathData_0},al.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var sl,ll,ul,cl=null;function pl(){return null===cl&&new al,cl}function hl(t){void 0===t&&(t=!0),this.myDefaultAbsolute_0=t,this.myStringBuilder_0=null,this.myTension_0=.7,this.myStringBuilder_0=w()}function _l(t,e){u.call(this),this.name$=t,this.ordinal$=e}function fl(){fl=function(){},sl=new _l("LINEAR",0),ll=new _l("CARDINAL",1),ul=new _l("MONOTONE",2)}function dl(){return fl(),sl}function ml(){return fl(),ll}function yl(){return fl(),ul}function $l(){bl(),Oa.call(this),this.elementName_d87la8$_0="path"}function vl(){gl=this,this.D=tt().createSpec_ytbaoo$("d")}qs.$metadata$={kind:s,simpleName:"SvgPathData",interfaces:[]},_l.$metadata$={kind:s,simpleName:"Interpolation",interfaces:[u]},_l.values=function(){return[dl(),ml(),yl()]},_l.valueOf_61zpoe$=function(t){switch(t){case"LINEAR":return dl();case"CARDINAL":return ml();case"MONOTONE":return yl();default:c("No enum constant jetbrains.datalore.vis.svg.SvgPathDataBuilder.Interpolation."+t)}},hl.prototype.build=function(){return new qs(this.myStringBuilder_0.toString())},hl.prototype.addAction_0=function(t,e,n){var i;for(e?this.myStringBuilder_0.append_s8itvh$(R(t.absoluteCmd())):this.myStringBuilder_0.append_s8itvh$(R(t.relativeCmd())),i=0;i!==n.length;++i){var r=n[i];this.myStringBuilder_0.append_s8jyv4$(r).append_s8itvh$(32)}},hl.prototype.addActionWithStringTokens_0=function(t,e,n){var i;for(e?this.myStringBuilder_0.append_s8itvh$(R(t.absoluteCmd())):this.myStringBuilder_0.append_s8itvh$(R(t.relativeCmd())),i=0;i!==n.length;++i){var r=n[i];this.myStringBuilder_0.append_pdl1vj$(r).append_s8itvh$(32)}},hl.prototype.moveTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Ys(),n,new Float64Array([t,e])),this},hl.prototype.moveTo_k2qmv6$=function(t,e){return this.moveTo_przk3b$(t.x,t.y,e)},hl.prototype.moveTo_gpjtzr$=function(t){return this.moveTo_przk3b$(t.x,t.y)},hl.prototype.lineTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Vs(),n,new Float64Array([t,e])),this},hl.prototype.lineTo_k2qmv6$=function(t,e){return this.lineTo_przk3b$(t.x,t.y,e)},hl.prototype.lineTo_gpjtzr$=function(t){return this.lineTo_przk3b$(t.x,t.y)},hl.prototype.horizontalLineTo_8555vt$=function(t,e){return void 0===e&&(e=this.myDefaultAbsolute_0),this.addAction_0(Ks(),e,new Float64Array([t])),this},hl.prototype.verticalLineTo_8555vt$=function(t,e){return void 0===e&&(e=this.myDefaultAbsolute_0),this.addAction_0(Ws(),e,new Float64Array([t])),this},hl.prototype.curveTo_igz2nj$=function(t,e,n,i,r,o,a){return void 0===a&&(a=this.myDefaultAbsolute_0),this.addAction_0(Xs(),a,new Float64Array([t,e,n,i,r,o])),this},hl.prototype.curveTo_d4nu7w$=function(t,e,n,i){return this.curveTo_igz2nj$(t.x,t.y,e.x,e.y,n.x,n.y,i)},hl.prototype.curveTo_fkixjx$=function(t,e,n){return this.curveTo_igz2nj$(t.x,t.y,e.x,e.y,n.x,n.y)},hl.prototype.smoothCurveTo_84c9il$=function(t,e,n,i,r){return void 0===r&&(r=this.myDefaultAbsolute_0),this.addAction_0(Zs(),r,new Float64Array([t,e,n,i])),this},hl.prototype.smoothCurveTo_sosulb$=function(t,e,n){return this.smoothCurveTo_84c9il$(t.x,t.y,e.x,e.y,n)},hl.prototype.smoothCurveTo_qt8ska$=function(t,e){return this.smoothCurveTo_84c9il$(t.x,t.y,e.x,e.y)},hl.prototype.quadraticBezierCurveTo_84c9il$=function(t,e,n,i,r){return void 0===r&&(r=this.myDefaultAbsolute_0),this.addAction_0(Js(),r,new Float64Array([t,e,n,i])),this},hl.prototype.quadraticBezierCurveTo_sosulb$=function(t,e,n){return this.quadraticBezierCurveTo_84c9il$(t.x,t.y,e.x,e.y,n)},hl.prototype.quadraticBezierCurveTo_qt8ska$=function(t,e){return this.quadraticBezierCurveTo_84c9il$(t.x,t.y,e.x,e.y)},hl.prototype.smoothQuadraticBezierCurveTo_przk3b$=function(t,e,n){return void 0===n&&(n=this.myDefaultAbsolute_0),this.addAction_0(Qs(),n,new Float64Array([t,e])),this},hl.prototype.smoothQuadraticBezierCurveTo_k2qmv6$=function(t,e){return this.smoothQuadraticBezierCurveTo_przk3b$(t.x,t.y,e)},hl.prototype.smoothQuadraticBezierCurveTo_gpjtzr$=function(t){return this.smoothQuadraticBezierCurveTo_przk3b$(t.x,t.y)},hl.prototype.ellipticalArc_d37okh$=function(t,e,n,i,r,o,a,s){return void 0===s&&(s=this.myDefaultAbsolute_0),this.addActionWithStringTokens_0(tl(),s,[t.toString(),e.toString(),n.toString(),i?"1":"0",r?"1":"0",o.toString(),a.toString()]),this},hl.prototype.ellipticalArc_dcaprc$=function(t,e,n,i,r,o,a){return this.ellipticalArc_d37okh$(t,e,n,i,r,o.x,o.y,a)},hl.prototype.ellipticalArc_gc0whr$=function(t,e,n,i,r,o){return this.ellipticalArc_d37okh$(t,e,n,i,r,o.x,o.y)},hl.prototype.closePath=function(){return this.addAction_0(el(),this.myDefaultAbsolute_0,new Float64Array([])),this},hl.prototype.setTension_14dthe$=function(t){if(0>t||t>1)throw L("Tension should be within [0, 1] interval");this.myTension_0=t},hl.prototype.lineSlope_0=function(t,e){return(e.y-t.y)/(e.x-t.x)},hl.prototype.finiteDifferences_0=function(t){var e,n=I(t.size),i=this.lineSlope_0(t.get_za3lpa$(0),t.get_za3lpa$(1));n.add_11rb$(i),e=t.size-1|0;for(var r=1;r1){a=e.get_za3lpa$(1),r=t.get_za3lpa$(s),s=s+1|0,this.curveTo_igz2nj$(i.x+o.x,i.y+o.y,r.x-a.x,r.y-a.y,r.x,r.y,!0);for(var l=2;l9){var l=s;s=3*r/B.sqrt(l),n.set_wxm5ur$(i,s*o),n.set_wxm5ur$(i+1|0,s*a)}}}for(var u=z(),c=0;c!==t.size;++c){var p=c+1|0,h=t.size-1|0,_=c-1|0,f=(t.get_za3lpa$(B.min(p,h)).x-t.get_za3lpa$(B.max(_,0)).x)/(6*(1+n.get_za3lpa$(c)*n.get_za3lpa$(c)));u.add_11rb$(new D(f,n.get_za3lpa$(c)*f))}return u},hl.prototype.interpolatePoints_3g1a62$=function(t,e,n){if(t.size!==e.size)throw L("Sizes of xs and ys must be equal");for(var i=I(t.size),r=M(t),o=M(e),a=0;a!==t.size;++a)i.add_11rb$(new D(r.get_za3lpa$(a),o.get_za3lpa$(a)));switch(n.name){case"LINEAR":this.doLinearInterpolation_0(i);break;case"CARDINAL":i.size<3?this.doLinearInterpolation_0(i):this.doCardinalInterpolation_0(i);break;case"MONOTONE":i.size<3?this.doLinearInterpolation_0(i):this.doHermiteInterpolation_0(i,this.monotoneTangents_0(i))}return this},hl.prototype.interpolatePoints_1ravjc$=function(t,e){var n,i=I(t.size),r=I(t.size);for(n=t.iterator();n.hasNext();){var o=n.next();i.add_11rb$(o.x),r.add_11rb$(o.y)}return this.interpolatePoints_3g1a62$(i,r,e)},hl.$metadata$={kind:s,simpleName:"SvgPathDataBuilder",interfaces:[]},vl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var gl=null;function bl(){return null===gl&&new vl,gl}function wl(){}function xl(){Cl(),Oa.call(this),this.elementName_sgtow1$_0="rect"}function kl(){El=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT)}Object.defineProperty($l.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_d87la8$_0}}),Object.defineProperty($l.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),$l.prototype.d=function(){return this.getAttribute_mumjwj$(bl().D)},$l.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},$l.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},$l.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},$l.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},$l.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},$l.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},$l.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},$l.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},$l.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},$l.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},$l.$metadata$={kind:s,simpleName:"SvgPathElement",interfaces:[Tl,_u,Oa]},wl.$metadata$={kind:p,simpleName:"SvgPlatformPeer",interfaces:[]},kl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var El=null;function Cl(){return null===El&&new kl,El}function Sl(t,e,n,i,r){return r=r||Object.create(xl.prototype),xl.call(r),r.setAttribute_qdh7ux$(Cl().X,t),r.setAttribute_qdh7ux$(Cl().Y,e),r.setAttribute_qdh7ux$(Cl().HEIGHT,i),r.setAttribute_qdh7ux$(Cl().WIDTH,n),r}function Tl(){Pl()}function Ol(){Nl=this,this.FILL=tt().createSpec_ytbaoo$("fill"),this.FILL_OPACITY=tt().createSpec_ytbaoo$("fill-opacity"),this.STROKE=tt().createSpec_ytbaoo$("stroke"),this.STROKE_OPACITY=tt().createSpec_ytbaoo$("stroke-opacity"),this.STROKE_WIDTH=tt().createSpec_ytbaoo$("stroke-width")}Object.defineProperty(xl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_sgtow1$_0}}),Object.defineProperty(xl.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),xl.prototype.x=function(){return this.getAttribute_mumjwj$(Cl().X)},xl.prototype.y=function(){return this.getAttribute_mumjwj$(Cl().Y)},xl.prototype.height=function(){return this.getAttribute_mumjwj$(Cl().HEIGHT)},xl.prototype.width=function(){return this.getAttribute_mumjwj$(Cl().WIDTH)},xl.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},xl.prototype.fill=function(){return this.getAttribute_mumjwj$(Pl().FILL)},xl.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},xl.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Pl().FILL_OPACITY)},xl.prototype.stroke=function(){return this.getAttribute_mumjwj$(Pl().STROKE)},xl.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},xl.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Pl().STROKE_OPACITY)},xl.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Pl().STROKE_WIDTH)},xl.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},xl.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},xl.$metadata$={kind:s,simpleName:"SvgRectElement",interfaces:[Tl,_u,Oa]},Ol.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Nl=null;function Pl(){return null===Nl&&new Ol,Nl}function Al(){Rl(),la.call(this)}function jl(){Ll=this,this.CLASS=tt().createSpec_ytbaoo$("class")}Tl.$metadata$={kind:p,simpleName:"SvgShape",interfaces:[]},jl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ll=null;function Rl(){return null===Ll&&new jl,Ll}function Il(t){la.call(this),this.resource=t,this.elementName_1a5z8g$_0="style",this.setContent_61zpoe$(this.resource.css())}function zl(){Bl(),Al.call(this),this.elementName_9c3al$_0="svg"}function Dl(){Ml=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y"),this.WIDTH=tt().createSpec_ytbaoo$(ea().WIDTH),this.HEIGHT=tt().createSpec_ytbaoo$(ea().HEIGHT),this.VIEW_BOX=tt().createSpec_ytbaoo$("viewBox")}Al.prototype.classAttribute=function(){return this.getAttribute_mumjwj$(Rl().CLASS)},Al.prototype.addClass_61zpoe$=function(t){this.validateClassName_rb6n0l$_0(t);var e=this.classAttribute();return null==e.get()?(e.set_11rb$(t),!0):!U(l(e.get()),[" "]).contains_11rb$(t)&&(e.set_11rb$(e.get()+" "+t),!0)},Al.prototype.removeClass_61zpoe$=function(t){this.validateClassName_rb6n0l$_0(t);var e=this.classAttribute();if(null==e.get())return!1;var n=M(U(l(e.get()),[" "])),i=n.remove_11rb$(t);return i&&e.set_11rb$(this.buildClassString_fbk06u$_0(n)),i},Al.prototype.replaceClass_puj7f4$=function(t,e){this.validateClassName_rb6n0l$_0(t),this.validateClassName_rb6n0l$_0(e);var n=this.classAttribute();if(null==n.get())throw k("Trying to replace class when class is empty");var i=U(l(n.get()),[" "]);if(!i.contains_11rb$(t))throw k("Class attribute does not contain specified oldClass");for(var r=i.size,o=I(r),a=0;a0&&n.append_s8itvh$(32),n.append_pdl1vj$(i)}return n.toString()},Al.prototype.validateClassName_rb6n0l$_0=function(t){if(F(t," "))throw L("Class name cannot contain spaces")},Al.$metadata$={kind:s,simpleName:"SvgStylableElement",interfaces:[la]},Object.defineProperty(Il.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_1a5z8g$_0}}),Il.prototype.setContent_61zpoe$=function(t){for(var e=this.children();!e.isEmpty();)e.removeAt_za3lpa$(0);var n=new iu(t);e.add_11rb$(n),this.setAttribute_jyasbz$("type","text/css")},Il.$metadata$={kind:s,simpleName:"SvgStyleElement",interfaces:[la]},Dl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ml=null;function Bl(){return null===Ml&&new Dl,Ml}function Ul(t){this.this$SvgSvgElement=t}function Fl(){this.myX_0=0,this.myY_0=0,this.myWidth_0=0,this.myHeight_0=0}function ql(t,e){return e=e||Object.create(Fl.prototype),Fl.call(e),e.myX_0=t.origin.x,e.myY_0=t.origin.y,e.myWidth_0=t.dimension.x,e.myHeight_0=t.dimension.y,e}function Gl(){Vl(),la.call(this),this.elementName_7co8y5$_0="tspan"}function Hl(){Yl=this,this.X_0=tt().createSpec_ytbaoo$("x"),this.Y_0=tt().createSpec_ytbaoo$("y")}Object.defineProperty(zl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_9c3al$_0}}),Object.defineProperty(zl.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),zl.prototype.setStyle_i8z0m3$=function(t){this.children().add_11rb$(new Il(t))},zl.prototype.x=function(){return this.getAttribute_mumjwj$(Bl().X)},zl.prototype.y=function(){return this.getAttribute_mumjwj$(Bl().Y)},zl.prototype.width=function(){return this.getAttribute_mumjwj$(Bl().WIDTH)},zl.prototype.height=function(){return this.getAttribute_mumjwj$(Bl().HEIGHT)},zl.prototype.viewBox=function(){return this.getAttribute_mumjwj$(Bl().VIEW_BOX)},Ul.prototype.set_11rb$=function(t){this.this$SvgSvgElement.viewBox().set_11rb$(ql(t))},Ul.$metadata$={kind:s,interfaces:[q]},zl.prototype.viewBoxRect=function(){return new Ul(this)},zl.prototype.opacity=function(){return this.getAttribute_mumjwj$(oa().OPACITY)},zl.prototype.clipPath=function(){return this.getAttribute_mumjwj$(oa().CLIP_PATH)},zl.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},zl.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Fl.prototype.toString=function(){return this.myX_0.toString()+" "+this.myY_0+" "+this.myWidth_0+" "+this.myHeight_0},Fl.$metadata$={kind:s,simpleName:"ViewBoxRectangle",interfaces:[]},zl.$metadata$={kind:s,simpleName:"SvgSvgElement",interfaces:[Rs,na,Al]},Hl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Yl=null;function Vl(){return null===Yl&&new Hl,Yl}function Kl(t,e){return e=e||Object.create(Gl.prototype),Gl.call(e),e.setText_61zpoe$(t),e}function Wl(){Jl()}function Xl(){Zl=this,this.FILL=tt().createSpec_ytbaoo$("fill"),this.FILL_OPACITY=tt().createSpec_ytbaoo$("fill-opacity"),this.STROKE=tt().createSpec_ytbaoo$("stroke"),this.STROKE_OPACITY=tt().createSpec_ytbaoo$("stroke-opacity"),this.STROKE_WIDTH=tt().createSpec_ytbaoo$("stroke-width"),this.TEXT_ANCHOR=tt().createSpec_ytbaoo$(ea().SVG_TEXT_ANCHOR_ATTRIBUTE),this.TEXT_DY=tt().createSpec_ytbaoo$(ea().SVG_TEXT_DY_ATTRIBUTE)}Object.defineProperty(Gl.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_7co8y5$_0}}),Object.defineProperty(Gl.prototype,"computedTextLength",{configurable:!0,get:function(){return l(this.container().getPeer()).getComputedTextLength_u60gfq$(this)}}),Gl.prototype.x=function(){return this.getAttribute_mumjwj$(Vl().X_0)},Gl.prototype.y=function(){return this.getAttribute_mumjwj$(Vl().Y_0)},Gl.prototype.setText_61zpoe$=function(t){this.children().clear(),this.addText_61zpoe$(t)},Gl.prototype.addText_61zpoe$=function(t){var e=new iu(t);this.children().add_11rb$(e)},Gl.prototype.fill=function(){return this.getAttribute_mumjwj$(Jl().FILL)},Gl.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},Gl.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Jl().FILL_OPACITY)},Gl.prototype.stroke=function(){return this.getAttribute_mumjwj$(Jl().STROKE)},Gl.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},Gl.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Jl().STROKE_OPACITY)},Gl.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Jl().STROKE_WIDTH)},Gl.prototype.textAnchor=function(){return this.getAttribute_mumjwj$(Jl().TEXT_ANCHOR)},Gl.prototype.textDy=function(){return this.getAttribute_mumjwj$(Jl().TEXT_DY)},Gl.$metadata$={kind:s,simpleName:"SvgTSpanElement",interfaces:[Wl,la]},Xl.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Zl=null;function Jl(){return null===Zl&&new Xl,Zl}function Ql(){nu(),Oa.call(this),this.elementName_s70iuw$_0="text"}function tu(){eu=this,this.X=tt().createSpec_ytbaoo$("x"),this.Y=tt().createSpec_ytbaoo$("y")}Wl.$metadata$={kind:p,simpleName:"SvgTextContent",interfaces:[]},tu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var eu=null;function nu(){return null===eu&&new tu,eu}function iu(t){su(),Is.call(this),this.myContent_0=null,this.myContent_0=new O(t)}function ru(){au=this,this.NO_CHILDREN_LIST_0=new ou}function ou(){H.call(this)}Object.defineProperty(Ql.prototype,"elementName",{configurable:!0,get:function(){return this.elementName_s70iuw$_0}}),Object.defineProperty(Ql.prototype,"computedTextLength",{configurable:!0,get:function(){return l(this.container().getPeer()).getComputedTextLength_u60gfq$(this)}}),Object.defineProperty(Ql.prototype,"bBox",{configurable:!0,get:function(){return l(this.container().getPeer()).getBBox_7snaev$(this)}}),Ql.prototype.x=function(){return this.getAttribute_mumjwj$(nu().X)},Ql.prototype.y=function(){return this.getAttribute_mumjwj$(nu().Y)},Ql.prototype.transform=function(){return this.getAttribute_mumjwj$(mu().TRANSFORM)},Ql.prototype.setTextNode_61zpoe$=function(t){this.children().clear(),this.addTextNode_61zpoe$(t)},Ql.prototype.addTextNode_61zpoe$=function(t){var e=new iu(t);this.children().add_11rb$(e)},Ql.prototype.setTSpan_ddcap8$=function(t){this.children().clear(),this.addTSpan_ddcap8$(t)},Ql.prototype.setTSpan_61zpoe$=function(t){this.children().clear(),this.addTSpan_61zpoe$(t)},Ql.prototype.addTSpan_ddcap8$=function(t){this.children().add_11rb$(t)},Ql.prototype.addTSpan_61zpoe$=function(t){this.children().add_11rb$(Kl(t))},Ql.prototype.fill=function(){return this.getAttribute_mumjwj$(Jl().FILL)},Ql.prototype.fillColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.fill(),this.fillOpacity())},Ql.prototype.fillOpacity=function(){return this.getAttribute_mumjwj$(Jl().FILL_OPACITY)},Ql.prototype.stroke=function(){return this.getAttribute_mumjwj$(Jl().STROKE)},Ql.prototype.strokeColor=function(){return gu().colorAttributeTransform_dc5zq8$(this.stroke(),this.strokeOpacity())},Ql.prototype.strokeOpacity=function(){return this.getAttribute_mumjwj$(Jl().STROKE_OPACITY)},Ql.prototype.strokeWidth=function(){return this.getAttribute_mumjwj$(Jl().STROKE_WIDTH)},Ql.prototype.textAnchor=function(){return this.getAttribute_mumjwj$(Jl().TEXT_ANCHOR)},Ql.prototype.textDy=function(){return this.getAttribute_mumjwj$(Jl().TEXT_DY)},Ql.prototype.pointToTransformedCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).invertTransform_12yub8$(this,t)},Ql.prototype.pointToAbsoluteCoordinates_gpjtzr$=function(t){return l(this.container().getPeer()).applyTransform_12yub8$(this,t)},Ql.$metadata$={kind:s,simpleName:"SvgTextElement",interfaces:[Wl,_u,Oa]},iu.prototype.textContent=function(){return this.myContent_0},iu.prototype.children=function(){return su().NO_CHILDREN_LIST_0},iu.prototype.toString=function(){return this.textContent().get()},ou.prototype.checkAdd_wxm5ur$=function(t,e){throw G("Cannot add children to SvgTextNode")},ou.prototype.checkRemove_wxm5ur$=function(t,e){throw G("Cannot remove children from SvgTextNode")},ou.$metadata$={kind:s,interfaces:[H]},ru.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var au=null;function su(){return null===au&&new ru,au}function lu(t){pu(),this.myTransform_0=t}function uu(){cu=this,this.EMPTY=new lu(""),this.MATRIX="matrix",this.ROTATE="rotate",this.SCALE="scale",this.SKEW_X="skewX",this.SKEW_Y="skewY",this.TRANSLATE="translate"}iu.$metadata$={kind:s,simpleName:"SvgTextNode",interfaces:[Is]},lu.prototype.toString=function(){return this.myTransform_0},uu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var cu=null;function pu(){return null===cu&&new uu,cu}function hu(){this.myStringBuilder_0=w()}function _u(){mu()}function fu(){du=this,this.TRANSFORM=tt().createSpec_ytbaoo$("transform")}lu.$metadata$={kind:s,simpleName:"SvgTransform",interfaces:[]},hu.prototype.build=function(){return new lu(this.myStringBuilder_0.toString())},hu.prototype.addTransformation_0=function(t,e){var n;for(this.myStringBuilder_0.append_pdl1vj$(t).append_s8itvh$(40),n=0;n!==e.length;++n){var i=e[n];this.myStringBuilder_0.append_s8jyv4$(i).append_s8itvh$(32)}return this.myStringBuilder_0.append_pdl1vj$(") "),this},hu.prototype.matrix_15yvbs$=function(t,e,n,i,r,o){return this.addTransformation_0(pu().MATRIX,new Float64Array([t,e,n,i,r,o]))},hu.prototype.translate_lu1900$=function(t,e){return this.addTransformation_0(pu().TRANSLATE,new Float64Array([t,e]))},hu.prototype.translate_gpjtzr$=function(t){return this.translate_lu1900$(t.x,t.y)},hu.prototype.translate_14dthe$=function(t){return this.addTransformation_0(pu().TRANSLATE,new Float64Array([t]))},hu.prototype.scale_lu1900$=function(t,e){return this.addTransformation_0(pu().SCALE,new Float64Array([t,e]))},hu.prototype.scale_14dthe$=function(t){return this.addTransformation_0(pu().SCALE,new Float64Array([t]))},hu.prototype.rotate_yvo9jy$=function(t,e,n){return this.addTransformation_0(pu().ROTATE,new Float64Array([t,e,n]))},hu.prototype.rotate_jx7lbv$=function(t,e){return this.rotate_yvo9jy$(t,e.x,e.y)},hu.prototype.rotate_14dthe$=function(t){return this.addTransformation_0(pu().ROTATE,new Float64Array([t]))},hu.prototype.skewX_14dthe$=function(t){return this.addTransformation_0(pu().SKEW_X,new Float64Array([t]))},hu.prototype.skewY_14dthe$=function(t){return this.addTransformation_0(pu().SKEW_Y,new Float64Array([t]))},hu.$metadata$={kind:s,simpleName:"SvgTransformBuilder",interfaces:[]},fu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var du=null;function mu(){return null===du&&new fu,du}function yu(){vu=this,this.OPACITY_TABLE_0=new Float64Array(256);for(var t=0;t<=255;t++)this.OPACITY_TABLE_0[t]=t/255}function $u(t,e){this.closure$color=t,this.closure$opacity=e}_u.$metadata$={kind:p,simpleName:"SvgTransformable",interfaces:[Rs]},yu.prototype.opacity_98b62m$=function(t){return this.OPACITY_TABLE_0[t.alpha]},yu.prototype.alpha2opacity_za3lpa$=function(t){return this.OPACITY_TABLE_0[t]},yu.prototype.toARGB_98b62m$=function(t){return this.toARGB_tjonv8$(t.red,t.green,t.blue,t.alpha)},yu.prototype.toARGB_o14uds$=function(t,e){var n=t.red,i=t.green,r=t.blue,o=255*e,a=B.min(255,o);return this.toARGB_tjonv8$(n,i,r,Y(B.max(0,a)))},yu.prototype.toARGB_tjonv8$=function(t,e,n,i){return(i<<24)+((t<<16)+(e<<8)+n|0)|0},$u.prototype.set_11rb$=function(t){this.closure$color.set_11rb$(Zo().create_2160e9$(t)),null!=t?this.closure$opacity.set_11rb$(gu().opacity_98b62m$(t)):this.closure$opacity.set_11rb$(1)},$u.$metadata$={kind:s,interfaces:[q]},yu.prototype.colorAttributeTransform_dc5zq8$=function(t,e){return new $u(t,e)},yu.prototype.transformMatrix_98ex5o$=function(t,e,n,i,r,o,a){t.transform().set_11rb$((new hu).matrix_15yvbs$(e,n,i,r,o,a).build())},yu.prototype.transformTranslate_pw34rw$=function(t,e,n){t.transform().set_11rb$((new hu).translate_lu1900$(e,n).build())},yu.prototype.transformTranslate_cbcjvx$=function(t,e){this.transformTranslate_pw34rw$(t,e.x,e.y)},yu.prototype.transformTranslate_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).translate_14dthe$(e).build())},yu.prototype.transformScale_pw34rw$=function(t,e,n){t.transform().set_11rb$((new hu).scale_lu1900$(e,n).build())},yu.prototype.transformScale_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).scale_14dthe$(e).build())},yu.prototype.transformRotate_tk1esa$=function(t,e,n,i){t.transform().set_11rb$((new hu).rotate_yvo9jy$(e,n,i).build())},yu.prototype.transformRotate_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).rotate_14dthe$(e).build())},yu.prototype.transformSkewX_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).skewX_14dthe$(e).build())},yu.prototype.transformSkewY_wl99a6$=function(t,e){t.transform().set_11rb$((new hu).skewY_14dthe$(e).build())},yu.prototype.copyAttributes_azdp7k$=function(t,n){var i,r;for(i=t.attributeKeys.iterator();i.hasNext();){var a=i.next(),s=e.isType(r=a,Z)?r:o();n.setAttribute_qdh7ux$(s,t.getAttribute_mumjwj$(a).get())}},yu.prototype.pngDataURI_61zpoe$=function(t){return new T("data:image/png;base64,").append_pdl1vj$(t).toString()},yu.$metadata$={kind:i,simpleName:"SvgUtils",interfaces:[]};var vu=null;function gu(){return null===vu&&new yu,vu}function bu(){Tu=this,this.SVG_NAMESPACE_URI="http://www.w3.org/2000/svg",this.XLINK_NAMESPACE_URI="http://www.w3.org/1999/xlink",this.XLINK_PREFIX="xlink"}bu.$metadata$={kind:i,simpleName:"XmlNamespace",interfaces:[]};var wu,xu,ku,Eu,Cu,Su,Tu=null;function Ou(){return null===Tu&&new bu,Tu}function Nu(t,e,n){V.call(this),this.attrSpec=t,this.oldValue=e,this.newValue=n}function Pu(){}function Au(t,e){u.call(this),this.name$=t,this.ordinal$=e}function ju(){ju=function(){},wu=new Au("MOUSE_CLICKED",0),xu=new Au("MOUSE_PRESSED",1),ku=new Au("MOUSE_RELEASED",2),Eu=new Au("MOUSE_OVER",3),Cu=new Au("MOUSE_MOVE",4),Su=new Au("MOUSE_OUT",5)}function Lu(){return ju(),wu}function Ru(){return ju(),xu}function Iu(){return ju(),ku}function zu(){return ju(),Eu}function Du(){return ju(),Cu}function Mu(){return ju(),Su}function Bu(){Is.call(this),this.isPrebuiltSubtree=!0}function Uu(t){Yu.call(this,t),this.myAttributes_0=e.newArray(Wu().ATTR_COUNT_8be2vx$,null)}function Fu(t,e){this.closure$key=t,this.closure$value=e}function qu(t){Uu.call(this,Ju().GROUP),this.myChildren_0=I(t)}function Gu(t){Bu.call(this),this.myGroup_0=t}function Hu(t,e,n){return n=n||Object.create(qu.prototype),qu.call(n,t),n.setAttribute_vux3hl$(19,e),n}function Yu(t){Wu(),this.elementName=t}function Vu(){Ku=this,this.fill_8be2vx$=0,this.fillOpacity_8be2vx$=1,this.stroke_8be2vx$=2,this.strokeOpacity_8be2vx$=3,this.strokeWidth_8be2vx$=4,this.strokeTransform_8be2vx$=5,this.classes_8be2vx$=6,this.x1_8be2vx$=7,this.y1_8be2vx$=8,this.x2_8be2vx$=9,this.y2_8be2vx$=10,this.cx_8be2vx$=11,this.cy_8be2vx$=12,this.r_8be2vx$=13,this.x_8be2vx$=14,this.y_8be2vx$=15,this.height_8be2vx$=16,this.width_8be2vx$=17,this.pathData_8be2vx$=18,this.transform_8be2vx$=19,this.ATTR_KEYS_8be2vx$=["fill","fill-opacity","stroke","stroke-opacity","stroke-width","transform","classes","x1","y1","x2","y2","cx","cy","r","x","y","height","width","d","transform"],this.ATTR_COUNT_8be2vx$=this.ATTR_KEYS_8be2vx$.length}Nu.$metadata$={kind:s,simpleName:"SvgAttributeEvent",interfaces:[V]},Pu.$metadata$={kind:p,simpleName:"SvgEventHandler",interfaces:[]},Au.$metadata$={kind:s,simpleName:"SvgEventSpec",interfaces:[u]},Au.values=function(){return[Lu(),Ru(),Iu(),zu(),Du(),Mu()]},Au.valueOf_61zpoe$=function(t){switch(t){case"MOUSE_CLICKED":return Lu();case"MOUSE_PRESSED":return Ru();case"MOUSE_RELEASED":return Iu();case"MOUSE_OVER":return zu();case"MOUSE_MOVE":return Du();case"MOUSE_OUT":return Mu();default:c("No enum constant jetbrains.datalore.vis.svg.event.SvgEventSpec."+t)}},Bu.prototype.children=function(){var t=Is.prototype.children.call(this);if(!t.isEmpty())throw k("Can't have children");return t},Bu.$metadata$={kind:s,simpleName:"DummySvgNode",interfaces:[Is]},Object.defineProperty(Fu.prototype,"key",{configurable:!0,get:function(){return this.closure$key}}),Object.defineProperty(Fu.prototype,"value",{configurable:!0,get:function(){return this.closure$value.toString()}}),Fu.$metadata$={kind:s,interfaces:[ec]},Object.defineProperty(Uu.prototype,"attributes",{configurable:!0,get:function(){var t,e,n=this.myAttributes_0,i=I(n.length),r=0;for(t=0;t!==n.length;++t){var o,a=n[t],s=i.add_11rb$,l=(r=(e=r)+1|0,e),u=Wu().ATTR_KEYS_8be2vx$[l];o=null==a?null:new Fu(u,a),s.call(i,o)}return K(i)}}),Object.defineProperty(Uu.prototype,"slimChildren",{configurable:!0,get:function(){return W()}}),Uu.prototype.setAttribute_vux3hl$=function(t,e){this.myAttributes_0[t]=e},Uu.prototype.hasAttribute_za3lpa$=function(t){return null!=this.myAttributes_0[t]},Uu.prototype.getAttribute_za3lpa$=function(t){return this.myAttributes_0[t]},Uu.prototype.appendTo_i2myw1$=function(t){var n;(e.isType(n=t,qu)?n:o()).addChild_3o5936$(this)},Uu.$metadata$={kind:s,simpleName:"ElementJava",interfaces:[tc,Yu]},Object.defineProperty(qu.prototype,"slimChildren",{configurable:!0,get:function(){var t,e=this.myChildren_0,n=I(X(e,10));for(t=e.iterator();t.hasNext();){var i=t.next();n.add_11rb$(i)}return n}}),qu.prototype.addChild_3o5936$=function(t){this.myChildren_0.add_11rb$(t)},qu.prototype.asDummySvgNode=function(){return new Gu(this)},Object.defineProperty(Gu.prototype,"elementName",{configurable:!0,get:function(){return this.myGroup_0.elementName}}),Object.defineProperty(Gu.prototype,"attributes",{configurable:!0,get:function(){return this.myGroup_0.attributes}}),Object.defineProperty(Gu.prototype,"slimChildren",{configurable:!0,get:function(){return this.myGroup_0.slimChildren}}),Gu.$metadata$={kind:s,simpleName:"MyDummySvgNode",interfaces:[tc,Bu]},qu.$metadata$={kind:s,simpleName:"GroupJava",interfaces:[Qu,Uu]},Vu.$metadata$={kind:i,simpleName:"Companion",interfaces:[]};var Ku=null;function Wu(){return null===Ku&&new Vu,Ku}function Xu(){Zu=this,this.GROUP="g",this.LINE="line",this.CIRCLE="circle",this.RECT="rect",this.PATH="path"}Yu.prototype.setFill_o14uds$=function(t,e){this.setAttribute_vux3hl$(0,t.toHexColor()),e<1&&this.setAttribute_vux3hl$(1,e.toString())},Yu.prototype.setStroke_o14uds$=function(t,e){this.setAttribute_vux3hl$(2,t.toHexColor()),e<1&&this.setAttribute_vux3hl$(3,e.toString())},Yu.prototype.setStrokeWidth_14dthe$=function(t){this.setAttribute_vux3hl$(4,t.toString())},Yu.prototype.setAttribute_7u9h3l$=function(t,e){this.setAttribute_vux3hl$(t,e.toString())},Yu.$metadata$={kind:s,simpleName:"SlimBase",interfaces:[ic]},Xu.prototype.createElement_0=function(t){return new Uu(t)},Xu.prototype.g_za3lpa$=function(t){return new qu(t)},Xu.prototype.g_vux3hl$=function(t,e){return Hu(t,e)},Xu.prototype.line_6y0v78$=function(t,e,n,i){var r=this.createElement_0(this.LINE);return r.setAttribute_7u9h3l$(7,t),r.setAttribute_7u9h3l$(8,e),r.setAttribute_7u9h3l$(9,n),r.setAttribute_7u9h3l$(10,i),r},Xu.prototype.circle_yvo9jy$=function(t,e,n){var i=this.createElement_0(this.CIRCLE);return i.setAttribute_7u9h3l$(11,t),i.setAttribute_7u9h3l$(12,e),i.setAttribute_7u9h3l$(13,n),i},Xu.prototype.rect_6y0v78$=function(t,e,n,i){var r=this.createElement_0(this.RECT);return r.setAttribute_7u9h3l$(14,t),r.setAttribute_7u9h3l$(15,e),r.setAttribute_7u9h3l$(17,n),r.setAttribute_7u9h3l$(16,i),r},Xu.prototype.path_za3rmp$=function(t){var e=this.createElement_0(this.PATH);return e.setAttribute_vux3hl$(18,t.toString()),e},Xu.$metadata$={kind:i,simpleName:"SvgSlimElements",interfaces:[]};var Zu=null;function Ju(){return null===Zu&&new Xu,Zu}function Qu(){}function tc(){}function ec(){}function nc(){}function ic(){}Qu.$metadata$={kind:p,simpleName:"SvgSlimGroup",interfaces:[nc]},ec.$metadata$={kind:p,simpleName:"Attr",interfaces:[]},tc.$metadata$={kind:p,simpleName:"SvgSlimNode",interfaces:[]},nc.$metadata$={kind:p,simpleName:"SvgSlimObject",interfaces:[]},ic.$metadata$={kind:p,simpleName:"SvgSlimShape",interfaces:[nc]},Object.defineProperty(Z,"Companion",{get:tt});var rc=t.jetbrains||(t.jetbrains={}),oc=rc.datalore||(rc.datalore={}),ac=oc.vis||(oc.vis={}),sc=ac.svg||(ac.svg={});sc.SvgAttributeSpec=Z,Object.defineProperty(et,"Companion",{get:rt}),sc.SvgCircleElement=et,Object.defineProperty(ot,"Companion",{get:Jn}),Object.defineProperty(Qn,"USER_SPACE_ON_USE",{get:ei}),Object.defineProperty(Qn,"OBJECT_BOUNDING_BOX",{get:ni}),ot.ClipPathUnits=Qn,sc.SvgClipPathElement=ot,sc.SvgColor=ii,Object.defineProperty(ri,"ALICE_BLUE",{get:ai}),Object.defineProperty(ri,"ANTIQUE_WHITE",{get:si}),Object.defineProperty(ri,"AQUA",{get:li}),Object.defineProperty(ri,"AQUAMARINE",{get:ui}),Object.defineProperty(ri,"AZURE",{get:ci}),Object.defineProperty(ri,"BEIGE",{get:pi}),Object.defineProperty(ri,"BISQUE",{get:hi}),Object.defineProperty(ri,"BLACK",{get:_i}),Object.defineProperty(ri,"BLANCHED_ALMOND",{get:fi}),Object.defineProperty(ri,"BLUE",{get:di}),Object.defineProperty(ri,"BLUE_VIOLET",{get:mi}),Object.defineProperty(ri,"BROWN",{get:yi}),Object.defineProperty(ri,"BURLY_WOOD",{get:$i}),Object.defineProperty(ri,"CADET_BLUE",{get:vi}),Object.defineProperty(ri,"CHARTREUSE",{get:gi}),Object.defineProperty(ri,"CHOCOLATE",{get:bi}),Object.defineProperty(ri,"CORAL",{get:wi}),Object.defineProperty(ri,"CORNFLOWER_BLUE",{get:xi}),Object.defineProperty(ri,"CORNSILK",{get:ki}),Object.defineProperty(ri,"CRIMSON",{get:Ei}),Object.defineProperty(ri,"CYAN",{get:Ci}),Object.defineProperty(ri,"DARK_BLUE",{get:Si}),Object.defineProperty(ri,"DARK_CYAN",{get:Ti}),Object.defineProperty(ri,"DARK_GOLDEN_ROD",{get:Oi}),Object.defineProperty(ri,"DARK_GRAY",{get:Ni}),Object.defineProperty(ri,"DARK_GREEN",{get:Pi}),Object.defineProperty(ri,"DARK_GREY",{get:Ai}),Object.defineProperty(ri,"DARK_KHAKI",{get:ji}),Object.defineProperty(ri,"DARK_MAGENTA",{get:Li}),Object.defineProperty(ri,"DARK_OLIVE_GREEN",{get:Ri}),Object.defineProperty(ri,"DARK_ORANGE",{get:Ii}),Object.defineProperty(ri,"DARK_ORCHID",{get:zi}),Object.defineProperty(ri,"DARK_RED",{get:Di}),Object.defineProperty(ri,"DARK_SALMON",{get:Mi}),Object.defineProperty(ri,"DARK_SEA_GREEN",{get:Bi}),Object.defineProperty(ri,"DARK_SLATE_BLUE",{get:Ui}),Object.defineProperty(ri,"DARK_SLATE_GRAY",{get:Fi}),Object.defineProperty(ri,"DARK_SLATE_GREY",{get:qi}),Object.defineProperty(ri,"DARK_TURQUOISE",{get:Gi}),Object.defineProperty(ri,"DARK_VIOLET",{get:Hi}),Object.defineProperty(ri,"DEEP_PINK",{get:Yi}),Object.defineProperty(ri,"DEEP_SKY_BLUE",{get:Vi}),Object.defineProperty(ri,"DIM_GRAY",{get:Ki}),Object.defineProperty(ri,"DIM_GREY",{get:Wi}),Object.defineProperty(ri,"DODGER_BLUE",{get:Xi}),Object.defineProperty(ri,"FIRE_BRICK",{get:Zi}),Object.defineProperty(ri,"FLORAL_WHITE",{get:Ji}),Object.defineProperty(ri,"FOREST_GREEN",{get:Qi}),Object.defineProperty(ri,"FUCHSIA",{get:tr}),Object.defineProperty(ri,"GAINSBORO",{get:er}),Object.defineProperty(ri,"GHOST_WHITE",{get:nr}),Object.defineProperty(ri,"GOLD",{get:ir}),Object.defineProperty(ri,"GOLDEN_ROD",{get:rr}),Object.defineProperty(ri,"GRAY",{get:or}),Object.defineProperty(ri,"GREY",{get:ar}),Object.defineProperty(ri,"GREEN",{get:sr}),Object.defineProperty(ri,"GREEN_YELLOW",{get:lr}),Object.defineProperty(ri,"HONEY_DEW",{get:ur}),Object.defineProperty(ri,"HOT_PINK",{get:cr}),Object.defineProperty(ri,"INDIAN_RED",{get:pr}),Object.defineProperty(ri,"INDIGO",{get:hr}),Object.defineProperty(ri,"IVORY",{get:_r}),Object.defineProperty(ri,"KHAKI",{get:fr}),Object.defineProperty(ri,"LAVENDER",{get:dr}),Object.defineProperty(ri,"LAVENDER_BLUSH",{get:mr}),Object.defineProperty(ri,"LAWN_GREEN",{get:yr}),Object.defineProperty(ri,"LEMON_CHIFFON",{get:$r}),Object.defineProperty(ri,"LIGHT_BLUE",{get:vr}),Object.defineProperty(ri,"LIGHT_CORAL",{get:gr}),Object.defineProperty(ri,"LIGHT_CYAN",{get:br}),Object.defineProperty(ri,"LIGHT_GOLDEN_ROD_YELLOW",{get:wr}),Object.defineProperty(ri,"LIGHT_GRAY",{get:xr}),Object.defineProperty(ri,"LIGHT_GREEN",{get:kr}),Object.defineProperty(ri,"LIGHT_GREY",{get:Er}),Object.defineProperty(ri,"LIGHT_PINK",{get:Cr}),Object.defineProperty(ri,"LIGHT_SALMON",{get:Sr}),Object.defineProperty(ri,"LIGHT_SEA_GREEN",{get:Tr}),Object.defineProperty(ri,"LIGHT_SKY_BLUE",{get:Or}),Object.defineProperty(ri,"LIGHT_SLATE_GRAY",{get:Nr}),Object.defineProperty(ri,"LIGHT_SLATE_GREY",{get:Pr}),Object.defineProperty(ri,"LIGHT_STEEL_BLUE",{get:Ar}),Object.defineProperty(ri,"LIGHT_YELLOW",{get:jr}),Object.defineProperty(ri,"LIME",{get:Lr}),Object.defineProperty(ri,"LIME_GREEN",{get:Rr}),Object.defineProperty(ri,"LINEN",{get:Ir}),Object.defineProperty(ri,"MAGENTA",{get:zr}),Object.defineProperty(ri,"MAROON",{get:Dr}),Object.defineProperty(ri,"MEDIUM_AQUA_MARINE",{get:Mr}),Object.defineProperty(ri,"MEDIUM_BLUE",{get:Br}),Object.defineProperty(ri,"MEDIUM_ORCHID",{get:Ur}),Object.defineProperty(ri,"MEDIUM_PURPLE",{get:Fr}),Object.defineProperty(ri,"MEDIUM_SEAGREEN",{get:qr}),Object.defineProperty(ri,"MEDIUM_SLATE_BLUE",{get:Gr}),Object.defineProperty(ri,"MEDIUM_SPRING_GREEN",{get:Hr}),Object.defineProperty(ri,"MEDIUM_TURQUOISE",{get:Yr}),Object.defineProperty(ri,"MEDIUM_VIOLET_RED",{get:Vr}),Object.defineProperty(ri,"MIDNIGHT_BLUE",{get:Kr}),Object.defineProperty(ri,"MINT_CREAM",{get:Wr}),Object.defineProperty(ri,"MISTY_ROSE",{get:Xr}),Object.defineProperty(ri,"MOCCASIN",{get:Zr}),Object.defineProperty(ri,"NAVAJO_WHITE",{get:Jr}),Object.defineProperty(ri,"NAVY",{get:Qr}),Object.defineProperty(ri,"OLD_LACE",{get:to}),Object.defineProperty(ri,"OLIVE",{get:eo}),Object.defineProperty(ri,"OLIVE_DRAB",{get:no}),Object.defineProperty(ri,"ORANGE",{get:io}),Object.defineProperty(ri,"ORANGE_RED",{get:ro}),Object.defineProperty(ri,"ORCHID",{get:oo}),Object.defineProperty(ri,"PALE_GOLDEN_ROD",{get:ao}),Object.defineProperty(ri,"PALE_GREEN",{get:so}),Object.defineProperty(ri,"PALE_TURQUOISE",{get:lo}),Object.defineProperty(ri,"PALE_VIOLET_RED",{get:uo}),Object.defineProperty(ri,"PAPAYA_WHIP",{get:co}),Object.defineProperty(ri,"PEACH_PUFF",{get:po}),Object.defineProperty(ri,"PERU",{get:ho}),Object.defineProperty(ri,"PINK",{get:_o}),Object.defineProperty(ri,"PLUM",{get:fo}),Object.defineProperty(ri,"POWDER_BLUE",{get:mo}),Object.defineProperty(ri,"PURPLE",{get:yo}),Object.defineProperty(ri,"RED",{get:$o}),Object.defineProperty(ri,"ROSY_BROWN",{get:vo}),Object.defineProperty(ri,"ROYAL_BLUE",{get:go}),Object.defineProperty(ri,"SADDLE_BROWN",{get:bo}),Object.defineProperty(ri,"SALMON",{get:wo}),Object.defineProperty(ri,"SANDY_BROWN",{get:xo}),Object.defineProperty(ri,"SEA_GREEN",{get:ko}),Object.defineProperty(ri,"SEASHELL",{get:Eo}),Object.defineProperty(ri,"SIENNA",{get:Co}),Object.defineProperty(ri,"SILVER",{get:So}),Object.defineProperty(ri,"SKY_BLUE",{get:To}),Object.defineProperty(ri,"SLATE_BLUE",{get:Oo}),Object.defineProperty(ri,"SLATE_GRAY",{get:No}),Object.defineProperty(ri,"SLATE_GREY",{get:Po}),Object.defineProperty(ri,"SNOW",{get:Ao}),Object.defineProperty(ri,"SPRING_GREEN",{get:jo}),Object.defineProperty(ri,"STEEL_BLUE",{get:Lo}),Object.defineProperty(ri,"TAN",{get:Ro}),Object.defineProperty(ri,"TEAL",{get:Io}),Object.defineProperty(ri,"THISTLE",{get:zo}),Object.defineProperty(ri,"TOMATO",{get:Do}),Object.defineProperty(ri,"TURQUOISE",{get:Mo}),Object.defineProperty(ri,"VIOLET",{get:Bo}),Object.defineProperty(ri,"WHEAT",{get:Uo}),Object.defineProperty(ri,"WHITE",{get:Fo}),Object.defineProperty(ri,"WHITE_SMOKE",{get:qo}),Object.defineProperty(ri,"YELLOW",{get:Go}),Object.defineProperty(ri,"YELLOW_GREEN",{get:Ho}),Object.defineProperty(ri,"NONE",{get:Yo}),Object.defineProperty(ri,"CURRENT_COLOR",{get:Vo}),Object.defineProperty(ri,"Companion",{get:Zo}),sc.SvgColors=ri,Object.defineProperty(sc,"SvgConstants",{get:ea}),Object.defineProperty(na,"Companion",{get:oa}),sc.SvgContainer=na,sc.SvgCssResource=aa,sc.SvgDefsElement=sa,Object.defineProperty(la,"Companion",{get:pa}),sc.SvgElement=la,sc.SvgElementListener=ya,Object.defineProperty($a,"Companion",{get:ba}),sc.SvgEllipseElement=$a,sc.SvgEventPeer=wa,sc.SvgGElement=Ta,Object.defineProperty(Oa,"Companion",{get:Ya}),Object.defineProperty(Va,"VISIBLE_PAINTED",{get:Wa}),Object.defineProperty(Va,"VISIBLE_FILL",{get:Xa}),Object.defineProperty(Va,"VISIBLE_STROKE",{get:Za}),Object.defineProperty(Va,"VISIBLE",{get:Ja}),Object.defineProperty(Va,"PAINTED",{get:Qa}),Object.defineProperty(Va,"FILL",{get:ts}),Object.defineProperty(Va,"STROKE",{get:es}),Object.defineProperty(Va,"ALL",{get:ns}),Object.defineProperty(Va,"NONE",{get:is}),Object.defineProperty(Va,"INHERIT",{get:rs}),Oa.PointerEvents=Va,Object.defineProperty(os,"VISIBLE",{get:ss}),Object.defineProperty(os,"HIDDEN",{get:ls}),Object.defineProperty(os,"COLLAPSE",{get:us}),Object.defineProperty(os,"INHERIT",{get:cs}),Oa.Visibility=os,sc.SvgGraphicsElement=Oa,sc.SvgIRI=ps,Object.defineProperty(hs,"Companion",{get:ds}),sc.SvgImageElement_init_6y0v78$=ms,sc.SvgImageElement=hs,ys.RGBEncoder=vs,ys.Bitmap=gs,sc.SvgImageElementEx=ys,Object.defineProperty(bs,"Companion",{get:Ls}),sc.SvgLineElement_init_6y0v78$=function(t,e,n,i,r){return r=r||Object.create(bs.prototype),bs.call(r),r.setAttribute_qdh7ux$(Ls().X1,t),r.setAttribute_qdh7ux$(Ls().Y1,e),r.setAttribute_qdh7ux$(Ls().X2,n),r.setAttribute_qdh7ux$(Ls().Y2,i),r},sc.SvgLineElement=bs,sc.SvgLocatable=Rs,sc.SvgNode=Is,sc.SvgNodeContainer=Ds,Object.defineProperty(Gs,"MOVE_TO",{get:Ys}),Object.defineProperty(Gs,"LINE_TO",{get:Vs}),Object.defineProperty(Gs,"HORIZONTAL_LINE_TO",{get:Ks}),Object.defineProperty(Gs,"VERTICAL_LINE_TO",{get:Ws}),Object.defineProperty(Gs,"CURVE_TO",{get:Xs}),Object.defineProperty(Gs,"SMOOTH_CURVE_TO",{get:Zs}),Object.defineProperty(Gs,"QUADRATIC_BEZIER_CURVE_TO",{get:Js}),Object.defineProperty(Gs,"SMOOTH_QUADRATIC_BEZIER_CURVE_TO",{get:Qs}),Object.defineProperty(Gs,"ELLIPTICAL_ARC",{get:tl}),Object.defineProperty(Gs,"CLOSE_PATH",{get:el}),Object.defineProperty(Gs,"Companion",{get:rl}),qs.Action=Gs,Object.defineProperty(qs,"Companion",{get:pl}),sc.SvgPathData=qs,Object.defineProperty(_l,"LINEAR",{get:dl}),Object.defineProperty(_l,"CARDINAL",{get:ml}),Object.defineProperty(_l,"MONOTONE",{get:yl}),hl.Interpolation=_l,sc.SvgPathDataBuilder=hl,Object.defineProperty($l,"Companion",{get:bl}),sc.SvgPathElement_init_7jrsat$=function(t,e){return e=e||Object.create($l.prototype),$l.call(e),e.setAttribute_qdh7ux$(bl().D,t),e},sc.SvgPathElement=$l,sc.SvgPlatformPeer=wl,Object.defineProperty(xl,"Companion",{get:Cl}),sc.SvgRectElement_init_6y0v78$=Sl,sc.SvgRectElement_init_wthzt5$=function(t,e){return e=e||Object.create(xl.prototype),Sl(t.origin.x,t.origin.y,t.dimension.x,t.dimension.y,e),e},sc.SvgRectElement=xl,Object.defineProperty(Tl,"Companion",{get:Pl}),sc.SvgShape=Tl,Object.defineProperty(Al,"Companion",{get:Rl}),sc.SvgStylableElement=Al,sc.SvgStyleElement=Il,Object.defineProperty(zl,"Companion",{get:Bl}),zl.ViewBoxRectangle_init_6y0v78$=function(t,e,n,i,r){return r=r||Object.create(Fl.prototype),Fl.call(r),r.myX_0=t,r.myY_0=e,r.myWidth_0=n,r.myHeight_0=i,r},zl.ViewBoxRectangle_init_wthzt5$=ql,zl.ViewBoxRectangle=Fl,sc.SvgSvgElement=zl,Object.defineProperty(Gl,"Companion",{get:Vl}),sc.SvgTSpanElement_init_61zpoe$=Kl,sc.SvgTSpanElement=Gl,Object.defineProperty(Wl,"Companion",{get:Jl}),sc.SvgTextContent=Wl,Object.defineProperty(Ql,"Companion",{get:nu}),sc.SvgTextElement_init_61zpoe$=function(t,e){return e=e||Object.create(Ql.prototype),Ql.call(e),e.setTextNode_61zpoe$(t),e},sc.SvgTextElement=Ql,Object.defineProperty(iu,"Companion",{get:su}),sc.SvgTextNode=iu,Object.defineProperty(lu,"Companion",{get:pu}),sc.SvgTransform=lu,sc.SvgTransformBuilder=hu,Object.defineProperty(_u,"Companion",{get:mu}),sc.SvgTransformable=_u,Object.defineProperty(sc,"SvgUtils",{get:gu}),Object.defineProperty(sc,"XmlNamespace",{get:Ou});var lc=sc.event||(sc.event={});lc.SvgAttributeEvent=Nu,lc.SvgEventHandler=Pu,Object.defineProperty(Au,"MOUSE_CLICKED",{get:Lu}),Object.defineProperty(Au,"MOUSE_PRESSED",{get:Ru}),Object.defineProperty(Au,"MOUSE_RELEASED",{get:Iu}),Object.defineProperty(Au,"MOUSE_OVER",{get:zu}),Object.defineProperty(Au,"MOUSE_MOVE",{get:Du}),Object.defineProperty(Au,"MOUSE_OUT",{get:Mu}),lc.SvgEventSpec=Au;var uc=sc.slim||(sc.slim={});return uc.DummySvgNode=Bu,uc.ElementJava=Uu,uc.GroupJava_init_vux3hl$=Hu,uc.GroupJava=qu,Object.defineProperty(Yu,"Companion",{get:Wu}),uc.SlimBase=Yu,Object.defineProperty(uc,"SvgSlimElements",{get:Ju}),uc.SvgSlimGroup=Qu,tc.Attr=ec,uc.SvgSlimNode=tc,uc.SvgSlimObject=nc,uc.SvgSlimShape=ic,t})?i.apply(e,r):i)||(t.exports=o)},975:t=>{function e(t){var e=new Error("Cannot find module '"+t+"'");throw e.code="MODULE_NOT_FOUND",e}e.keys=()=>[],e.resolve=e,e.id=975,t.exports=e}},e={};function n(i){var r=e[i];if(void 0!==r)return r.exports;var o=e[i]={exports:{}};return t[i].call(o.exports,o,o.exports,n),o.exports}n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var i=n(837);window.LetsPlot=i})(); //# sourceMappingURL=js-package.js.map \ No newline at end of file diff --git a/python-package/lets_plot/_version.py b/python-package/lets_plot/_version.py index b909d9ba178..5290663443a 100644 --- a/python-package/lets_plot/_version.py +++ b/python-package/lets_plot/_version.py @@ -3,4 +3,4 @@ # Use of this source code is governed by the MIT license that can be found in the LICENSE file. # # see: https://www.python.org/dev/peps/pep-0440/#developmental-releases -__version__ = '2.0.6.dev1' \ No newline at end of file +__version__ = '2.1.0rc1' \ No newline at end of file